std:: random_device
|
Défini dans l'en-tête
<random>
|
||
|
class
random_device
;
|
(depuis C++11) | |
std::random_device
est un générateur de nombres aléatoires entiers uniformément distribués qui produit des nombres aléatoires non déterministes.
std::random_device
peut être implémenté en termes d'un moteur de nombres pseudo-aléatoires défini par l'implémentation si une source non déterministe (par exemple un périphérique matériel) n'est pas disponible pour l'implémentation. Dans ce cas, chaque
std::random_device
objet peut générer la même séquence de nombres.
Table des matières |
Types membres
| Type de membre | Définition |
result_type
(C++11)
|
unsigned int |
Fonctions membres
Construction |
|
|
construit le moteur
(fonction membre publique) |
|
|
operator=
(deleted)
(C++11)
|
l'opérateur d'affectation est supprimé
(fonction membre publique) |
Génération |
|
|
avance l'état du moteur et retourne la valeur générée
(fonction membre publique) |
|
Caractéristiques |
|
|
(C++11)
|
obtient l'estimation d'entropie pour le générateur de nombres aléatoires non déterministe
(fonction membre publique) |
|
[static]
|
obtient la plus petite valeur possible dans la plage de sortie
(fonction membre statique publique) |
|
[static]
|
obtient la plus grande valeur possible dans la plage de sortie
(fonction membre statique publique) |
Notes
Une implémentation notable où
std::random_device
est déterministe dans les anciennes versions de MinGW-w64 (
bug 338
, corrigé depuis GCC 9.2). Les dernières versions de MinGW-w64 peuvent être téléchargées depuis
GCC avec le modèle de thread MCF
.
Exemple
#include <iostream> #include <map> #include <random> #include <string> int main() { std::random_device rd; std::map<int, int> hist; std::uniform_int_distribution<int> dist(0, 9); for (int n = 0; n != 20000; ++n) ++hist[dist(rd)]; // note: démonstration uniquement: la performance de nombreuses // implémentations de random_device se dégrade fortement // une fois que le pool d'entropie est épuisé. Pour un usage pratique // random_device est généralement utilisé uniquement pour initialiser // un générateur pseudo-aléatoire tel que mt19937 for (auto [x, y] : hist) std::cout << x << " : " << std::string(y / 100, '*') << '\n'; }
Sortie possible :
0 : ******************** 1 : ******************* 2 : ******************** 3 : ******************** 4 : ******************** 5 : ******************* 6 : ******************** 7 : ******************** 8 : ******************* 9 : ********************