xor_combine::seed
propaga el generador.
void seed();
template<class Gen>
void seed(Gen& gen);
Parámetros
Engine
El tipo de motor aleatorio seed.eng
El motor aleatorio seed.
Comentarios
Las primeras llamadas de función stored_eng1.seed() miembro y llamar a stored_eng2.seed().La segunda llamadas de función stored_eng1.seed(gen) miembro y llamar a stored_eng2.seed(gen).
Ejemplo
// std_tr1__random__xor_combine_seed.cpp
// compile with: /EHsc
#include <random>
#include <iostream>
typedef std::subtract_with_carry<unsigned int,
1 << 24, 10, 24> Myeng1;
typedef std::linear_congruential<unsigned int,
16807, 0, (1U << 31) - 1> Myeng2;
typedef std::xor_combine<Myeng1, 1, Myeng2, 2> Myceng;
int main()
{
Myeng1 eng1;
Myeng2 eng2;
Myceng ceng;
const Myceng::base1_type& base1 = ceng.base1(); // get base engine
const Myceng::base2_type& base2 = ceng.base2(); // get base engine
Myceng::result_type compval = ceng();
compval = compval; // to quiet "unused" warnings
base1.min();
base2.min();
std::cout << "S1 == " << Myceng::shift1 << std::endl;
std::cout << "S2 == " << Myceng::shift2 << 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(eng1); // construct with generator
ceng2.seed(eng1); // seed with generator
return (0);
}
Requisitos
encabezado: <aleatorio>
espacio de nombres: std