[閒聊] 替RandomVariate提供提取seed的功能

看板Mathematica作者 (Amiba Gelos)時間7年前 (2016/10/11 12:28), 編輯推噓2(2016)
留言18則, 3人參與, 最新討論串1/1
最近在用MMA跑Monte Carlo,覺得MMA不能提取seed實在是很不方便,所以就做了一個可以 提取seed的RandomVariate Module[{seed, store = {}, temp = 1, Storing}, RandomMemory[1, opt___] := RandomMemory[temp, opt]; RandomMemory[in__] := (Storing[in]; RandomVariate[in]); Storing[dist_, opt___] := AppendTo[ store, {Evaluate[If[dist === temp, 1, temp = dist]], opt}]; SetSeed[InSeed_, InStore_: {}] := (store = {}; temp = 1; SeedRandom[seed = InSeed]; (RandomMemory[##];) & @@@ InStore;); ExtractSeed[] := {seed, store}; SetSeed[0];]; 這個設計在跑custom distribution的時候蠻好用的, 不過AppendTo會是瓶頸 目前只有想到hash, 不過有新distribution還是得重建table 不知道有沒有更漂亮的寫法? -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.112.4.208 ※ 文章網址: https://www.ptt.cc/bbs/Mathematica/M.1476160101.A.361.html

10/11 21:30, , 1F
不懂! seed不就使用者設定的嗎? 不能提取自己設的seed?
10/11 21:30, 1F

10/11 21:31, , 2F
不懂!seed不就使用者設定的嗎?不能提取自己設的seed?
10/11 21:31, 2F

10/12 03:29, , 3F
他要的是跑到一半記錄目前 PRNG 的 state 吧
10/12 03:29, 3F

10/12 03:34, , 4F
不過記得不少演算法的 state 並不只有 seed 所以有點難
10/12 03:34, 4F

10/12 03:36, , 5F
提供一個統一界面, 例如 MT19937 需要 624 個 32 位元整數
10/12 03:36, 5F

10/12 03:36, , 6F
但種子只有 32 位元, 所以不可能用單一整數表示狀態
10/12 03:36, 6F

10/12 03:38, , 7F
然後, 剛剛翻 Help 有看到 BlockRandom 或許也符合你的需要
10/12 03:38, 7F

10/12 09:57, , 8F
謝謝樓上解釋~MMA預設CA是80*64b,最小是64*64所以不可
10/12 09:57, 8F

10/12 09:58, , 9F
能用long描述, MMA的seed我覺得實際上是被hash處理過
10/12 09:58, 9F

10/12 09:59, , 10F
這方面我還在測試,不過想從這邊retrive state也是很難
10/12 09:59, 10F

10/12 10:02, , 11F
BlockRandom只是freeze state而已,應該不能做到同時跑
10/12 10:02, 11F

10/12 10:03, , 12F
兩個prng,更做不到resume吧@@
10/12 10:03, 12F

10/12 10:07, , 13F
其實有種最偷懶的做法是每次要存檔的時候就另開一個
10/12 10:07, 13F

10/12 10:09, , 14F
kernel專門跑rng,用mathlink連到另一個MMA也許更clear
10/12 10:09, 14F

10/12 10:09, , 15F
忽然覺得這應該就是最佳解了@@
10/12 10:09, 15F

10/12 10:16, , 16F
唯一可惜的是還是得額外存一套distribution,跑MCMC有
10/12 10:16, 16F

10/12 10:17, , 17F
點浪費ram...
10/12 10:17, 17F

10/12 18:31, , 18F
謝謝L兄,懂了.另MMAseed代表所有狀態,沒看過找seed指令
10/12 18:31, 18F
文章代碼(AID): #1N_6fbDX (Mathematica)
文章代碼(AID): #1N_6fbDX (Mathematica)