Maison >interface Web >js tutoriel >Comment créer un générateur de nombres aléatoires amorceables en JavaScript ?

Comment créer un générateur de nombres aléatoires amorceables en JavaScript ?

Susan Sarandon
Susan Sarandonoriginal
2024-11-04 17:35:02582parcourir

How to Create a Seedable Random Number Generator in JavaScript?

Générateur de nombres aléatoires JavaScript amorçables

La fonction JavaScript Math.random() génère des valeurs aléatoires entre 0 et 1 en fonction de l'heure actuelle, similaire au générateur de nombres aléatoires de Java. Cependant, il lui manque la possibilité de spécifier une valeur de départ pour contrôler la séquence des nombres générés.

Création d'un générateur de nombres aléatoires personnalisé avec prise en charge de départ

Pour créer un générateur de nombres aléatoires générateur de nombres avec prise en charge des graines, envisagez les options suivantes :

Implémentation d'un générateur congruentiel linéaire (LCG)

Les LCG sont relativement simples à mettre en œuvre et offrent des qualités aléatoires décentes. Vous pouvez utiliser les constantes suivantes :

m = 0x80000000; // 2**31
a = 1103515245;
c = 12345;

Voici un exemple d'implémentation en JavaScript :

<code class="javascript">function RNG(seed) {
  this.m = 0x80000000;
  this.a = 1103515245;
  this.c = 12345;

  this.state = seed ? seed : Math.floor(Math.random() * (this.m - 1));
}
RNG.prototype.nextInt = function() {
  this.state = (this.a * this.state + this.c) % this.m;
  return this.state;
}</code>

Vous pouvez étendre cette classe RNG pour fournir des méthodes supplémentaires telles que nextFloat, nextRange et les choix basés sur sur le noyau LCG.

Utilisation de bibliothèques pour les RNG courts amorçables

Bibliothèques telles que [js-random](https://www.npmjs.com/package/ js-random) fournissent des RNG courts et amorceables avec des options pour différents algorithmes.

Exemple de mise en œuvre

Voici un exemple simple utilisant un RNG basé sur LCG :

<code class="javascript">var rng = new RNG(20);
for (var i = 0; i < 10; i++) {
  console.log(rng.nextRange(10, 50));
}</code>

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn