std:: gamma_distribution
|
Défini dans l'en-tête
<random>
|
||
|
template
<
class
RealType
=
double
>
class gamma_distribution ; |
(depuis C++11) | |
Produit des valeurs aléatoires positives à virgule flottante x , distribuées selon la fonction de densité de probabilité :
-
P(x|α,β) =
· x α-1e -x/β
β α
· Γ(α)
où α est connu comme le paramètre de forme et β est connu comme le paramètre d' échelle . Le paramètre de forme est parfois désigné par la lettre k et le paramètre d'échelle est parfois désigné par la lettre θ .
Pour une valeur à virgule flottante α , la valeur obtenue est la somme de α variables aléatoires indépendantes distribuées exponentiellement, dont chacune a une moyenne de β .
std::gamma_distribution
satisfait
RandomNumberDistribution
.
Table des matières |
Paramètres du modèle
| RealType | - | Le type de résultat généré par le générateur. L'effet est indéfini si ce n'est pas l'un des float , double , ou long double . |
Types membres
| Type de membre | Définition |
result_type
(C++11)
|
RealType |
param_type
(C++11)
|
le type du jeu de paramètres, voir RandomNumberDistribution . |
Fonctions membres
|
(C++11)
|
construit une nouvelle distribution
(fonction membre publique) |
|
(C++11)
|
réinitialise l'état interne de la distribution
(fonction membre publique) |
Génération |
|
|
(C++11)
|
génère le prochain nombre aléatoire dans la distribution
(fonction membre publique) |
Caractéristiques |
|
|
(C++11)
|
retourne les paramètres de la distribution
(fonction membre publique) |
|
(C++11)
|
obtient ou définit l'objet paramètre de distribution
(fonction membre publique) |
|
(C++11)
|
retourne la valeur potentiellement générée minimale
(fonction membre publique) |
|
(C++11)
|
retourne la valeur potentiellement générée maximale
(fonction membre publique) |
Fonctions non membres
|
(C++11)
(C++11)
(supprimé en C++20)
|
compare deux objets de distribution
(fonction) |
|
(C++11)
|
effectue des opérations d'entrée/sortie sur flux pour une distribution de nombres pseudo-aléatoires
(modèle de fonction) |
Exemple
#include <iomanip> #include <iostream> #include <map> #include <random> #include <string> int main() { std::random_device rd; std::mt19937 gen(rd()); // Une distribution gamma avec alpha = 1 et beta = 2 // approxime une distribution exponentielle. std::gamma_distribution<> d(1, 2); std::map<int, int> hist; for (int n = 0; n != 10000; ++n) ++hist[2 * d(gen)]; for (auto const& [x, y] : hist) if (y / 100.0 > 0.5) std::cout << std::fixed << std::setprecision(1) << x / 2.0 << '-' << (x + 1) / 2.0 << ' ' << std::string(y / 100, '*') << '\n'; }
Sortie possible :
0.0-0.5 ********************** 0.5-1.0 **************** 1.0-1.5 ************* 1.5-2.0 ********** 2.0-2.5 ******** 2.5-3.0 ****** 3.0-3.5 ***** 3.5-4.0 **** 4.0-4.5 *** 4.5-5.0 ** 5.0-5.5 ** 5.5-6.0 * 6.0-6.5 * 6.5-7.0 7.0-7.5 7.5-8.0
Liens externes
| Weisstein, Eric W. "Gamma Distribution." De MathWorld — Une ressource Web Wolfram. |