normal_distribution::operator()
Retourne une valeur aléatoire.
template<class Engine>
result_type operator()(Engine& eng);
template<class Engine>
result_type operator()(Engine& eng,
const param_type& par0);
Paramètres
Engine
Le type du moteur aléatoire.eng
Le moteur aléatoire.par0
Le module de paramètre utilisé comme source de la valeur aléatoire.
Notes
La première fonction membre utilise le moteur eng comme une source de valeurs aléatoires régulièrement distribuées et retourne des valeurs avec une yyyy'- de probabilité qu' pr(x) = 1 / (√(2 * pi) * stored_sigma) * (e)^(-(x - stored_mean)2 / (2 * stored_sigma^2)).
La deuxième fonction membre se comporte de la même manière, excepté qu'elle utilise les paramètres stockés dans par0.
Exemple
// std_tr1__random__normal_distribution_operator_fn.cpp
// compile with: /EHsc
#include <random>
#include <iostream>
typedef std::ranlux64_base_01 Myeng;
typedef std::normal_distribution<double> Mydist;
int main()
{
Myeng eng;
Mydist dist(1.5, 2.0);
Mydist::input_type engval = eng();
Mydist::result_type distval = dist(eng);
distval = distval; // to quiet "unused" warnings
engval = engval;
std::cout << "mean == " << dist.mean() << std::endl;
std::cout << "sigma == " << dist.sigma() << std::endl;
dist.reset(); // discard any cached values
std::cout << "a random value == " << dist(eng) << std::endl;
std::cout << "a random value == " << dist(eng) << std::endl;
std::cout << "a random value == " << dist(eng) << std::endl;
return (0);
}
Configuration requise
en-tête : <random>
l'espace de noms : DST