subtract_with_carry_01::seed
Semena motoru.
template<class Gen>
void seed(Gen& gen);
void seed(result_type x0 = 19780503UL);
Parametry
Gen
Typ generátoru osiva.gen
Generátor osiva.x0
Hodnota osiva.
Poznámky
Předběžná podmínka:0 < x0
První funkce osiva generuje long_lag historické hodnoty z hodnot typu unsigned long vrácené po sobě jdoucích vyvolání gen.Každá historická hodnota je generována prostřednictvím nízké 32 bitů na jednotlivých long_lag * (word_size + 31) / 32 hodnot z inicializační; Výsledná hodnota je rozdělena podle 2.0word_size a nedílnou součástí zahozeny.Každá historická hodnota tedy desetinná hodnota větší než nebo rovno 0,0 a menší než 1,0 s word_size významné bity.
Druhá funkce osiva účinně provede následující kód:
linear_congruential<unsigned long, 40014, 0, 2147483563> gen(x0);
seed(gen);
Příklad
// std_tr1__random__subtract_with_carry_01_seed.cpp
// compile with: /EHsc
#include <random>
#include <iostream>
typedef std::mt19937 Myeng;
typedef std::subtract_with_carry_01<float, 24, 10, 24> Myceng;
int main()
{
Myeng eng;
Myceng ceng;
Myceng::result_type compval = ceng();
compval = compval; // to quiet "unused" warnings
std::cout << "W == " << Myceng::word_size << std::endl;
std::cout << "S == " << Myceng::short_lag << std::endl;
std::cout << "R == " << Myceng::long_lag << std::endl;
std::cout << "min == " << ceng.min() << std::endl;
std::cout << "max == " << ceng.max() << std::endl;
ceng.seed(); // reseed base engine
std::cout << "a random value == " << ceng() << std::endl;
std::cout << "a random value == " << ceng() << std::endl;
std::cout << "a random value == " << ceng() << std::endl;
Myceng ceng2(eng); // construct with generator
ceng2.seed(eng); // seed with generator
Myceng ceng3(5UL); // construct with unsigned long seed
ceng3.seed(5UL); // seed with unsigned long
return (0);
}
Požadavky
Záhlaví: <random>
Obor názvů: std