2014-03-13 72 views
3

我有一個很簡單的問題: 當我們拿梅森扭轉機-19937發生器並修復種子時,每當我們調用發生器時,它就會產生一系列具有某些特徵的數字(獨立性,統一分配)。這裏重要的是獨立性(或兩次連續呼叫之間的低相關性)。現在Mersenne Twister的特徵 - 19937

,如果我有不同的(但固定)種子梅森難題-19937兩個instaces和我曾經呼籲每個發電機會發生什麼。在這種情況下,我得到的兩組隨機數的獨立性,相關性結構如何?

很多謝謝

+2

這個問題*必須*被固定在特定的發電機。一般來說,任何事情都可能發生密碼強的發生器根本就沒有相互關係。生成器'return 0;'有很多。 – usr

回答

1

「保證」不存在了。很可能有一個隨機生成器爲兩個不同的種子生成完全相同的值。

這不是一個問題,除非你依賴於隨機性的一些行爲。當然,主要的問題是密碼學 - 即使你是例如,密碼隨機數發生器也很難做到非常隨機。並行運行10臺發電機。但是,這種做法違背了可重複性的目的(例如程序生成等)。

然而,兩臺發電機都獨立保持他們的擔保。這意味着只要它們不「互動」(例如遊戲中的兩個區域,每個區域都有自己的發生器),隨機性將被保留。

一個很好的原則進行的拇指是測試它(除非隨機性是至關重要的,那麼它的數學一路:))。繪圖。在現實世界中找出:)

編輯:既然您已經添加了特定的算法,讓我擴大答案了一下。梅森扭轉者是非常隨機的。但是,隨機性非常依賴於初始值。對於某些種子,即使有幾個並行發生器,它也可能產生非常隨機的值。對於一些種子,結果非常接近。正如維基指出的那樣:

這樣做的一個後果是,兩個發生器實例(初始狀態幾乎相同)在最終發散之前會爲許多​​迭代輸出幾乎相同的序列。

+0

謝謝!將嘗試在現實世界中發現! :) – VLT

+0

好,因此選擇的種子是從另一個完全不同的人應該在這件事上幫 – VLT

+0

@VLT的確。然而,這比看起來更棘手:D當創建它們時,可能使用密碼RNG爲不同的生成器生成種子。但是,這也不能保證任何東西。總的來說,關注你的實際案例。唯一讓你感到困擾的是,假冒隨機性對於觀察者而言變得明顯(儘管注意到人們在找到模式時即使沒有這種模式也是過分熱衷)。 – Luaan

相關問題