Namespaces
Variants

std:: gamma_distribution

From cppreference.net
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|α,β) =
e -x/β
β α
· Γ(α)
· x α-1

α 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

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)
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.