首頁 >web前端 >js教程 >如何在 JavaScript 中產生可重複的隨機數?

如何在 JavaScript 中產生可重複的隨機數?

DDD
DDD原創
2024-12-11 09:31:09371瀏覽

How Can I Generate Repeatable Random Numbers in JavaScript?

在JavaScript 中播種隨機數產生器

簡介:

<script></script>

Java. random( ) 函數雖然提供隨機性,但不允許播種。這意味著每次呼叫函數時,它都會產生一個新的數字序列,這對於需要可重複隨機序列的情況可能會出現問題。

可種子偽隨機數產生器:

由於Math.random() 缺乏播種功能,因此有必要實現外部偽隨機數產生器(PRNG)提供播種功能。 PRNG 提供高品質的隨機數,並允許使用一個或多個種子值進行初始化。

種子初始化:

PRNG 需要正確的初始化以確保隨機性。分佈良好的高熵種子值對於穩健的隨機性至關重要。雜湊函數(例如 cyrb128)可以從短字串產生合適的種子。或者,可以使用虛擬資料作為多次生成器迭代的填充,以徹底混合初始狀態。

效能注意事項:

JavaScript 數字僅支援最多 53 位元整數解析度和位元運算的 32 位元解析度。現代 PRNG 通常使用 64 位元運算,但 JS 實作需要墊片,這會大大降低效能。所提出的 PRNG 演算法優先考慮 32 位元操作,以在 JavaScript 中實現最佳效能。

推薦的PRNG:

sfc32(簡單快速計數器)

sfc32 是一個快速PRNG,具有128 位內部狀態,擅長JavaScript。它表現出出色的隨機性質量,常用於 PractRand 隨機數測試套件。

範例用法:
function sfc32(a, b, c, d) {
  return function() {
    // State update logic
    ...
    return (t >>> 0) / 4294967296;  // Convert to floating-point number in the range [0, 1)
  };
}

const seedgen = () => (Math.random() * 2 ** 32) >>> 0;
const getRand = sfc32(seedgen(), seedgen(), seedgen(), seedgen());

請注意,此範例使用簡單的種子產生方法用於示範目的。在實踐中,應該採用更強大的種子生成機制。

以上是如何在 JavaScript 中產生可重複的隨機數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn