Remarque
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de vous connecter ou de modifier des répertoires.
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de modifier des répertoires.
Injecte le moteur
void seed(UIntType x0 = default_seed);
template<class Gen>
void seed(Gen& gen);
Paramètres
x0
La valeur initiale.Gen
Le type du générateur de départ.gen
Le concepteur de départ.
Notes
La première fonction de départ définit la valeur signalée stored_value à 1 mod M si c mod M == 0 et x0 mod M == 0, sinon elle définit la valeur stockée à x0 mod M.Le deuxième appel de fonction valeur de seed(gen()).
Exemple
// std_tr1__random__linear_congruential_seed.cpp
// compile with: /EHsc
#include <random>
#include <iostream>
typedef std::mt19937 Myeng;
typedef std::linear_congruential<int, 16807, 0,
(int)((1U << 31) - 1)> Myceng; // same as minstd_rand0
int main()
{
Myeng eng;
Myceng ceng;
Myceng::result_type compval = ceng();
compval = compval; // to quiet "unused" warnings
std::cout << "A == " << Myceng::multiplier << std::endl;
std::cout << "C == " << Myceng::increment << std::endl;
std::cout << "M == " << Myceng::modulus << 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
return (0);
}
Configuration requise
en-tête : <random>
l'espace de noms : DST