[程式] 使用亂數種子確保雙方獲得相同高度圖
回應cowbaying:
推
11/03 21:51,
11/03 21:51
→
11/03 21:52,
11/03 21:52
→
11/03 22:23,
11/03 22:23
→
11/03 22:30,
11/03 22:30
→
11/03 22:31,
11/03 22:31
我先敘述一下我所謂的「只傳送亂數種子」是什麼:
假設亂數產生函數為 r(n+1) = (r(n)*3+1) % 5
則亂數種子r(0) = 0的情況,連續使用亂數函數會得出以下數列:
0, 1, 4, 3, 0, 1, 4, 3, 0
再假設你的地形生成演算法是橫向排列,
也就是利用剛才產生的亂數數列,排成
0, 1, 4,
3, 0, 1,
4, 3, 0
換句話說,由於產生亂數的函數、以及產生地形的演算法是固定的,
所以亂數種子"0",只要是同一套程式,不管到誰的電腦上(除非有硬體問題),
產生的永遠都是
0, 1, 4,
3, 0, 1,
4, 3, 0
這裡講得是簡化過的例子,
但只要是Pseudo-random(偽亂數),都是一樣的道理
而且就算地形生成演算法複雜很多,也不妨礙。
經典的例子應該算是新接龍牌局,
程式並沒有實際地儲存65535種牌局,
而是利用亂數種子來存。
所以我可以對朋友說「新接龍#1941超難的,你試試看」
而不用把整個牌局抄起來給他。
這裡要注意一件事,
這個方法並不適用於「我預先手動產生一張地形圖」的場合,
因為你很難去找到一組函數,可以恰好產生與你事先畫的圖一模一樣的地形圖。
至於cowbaying你提到你去拿了minecraft的seed出來,
卻還原不出一模一樣的地形圖,
我覺得有可能有幾個因素:
1. 你的地形生成演算法,跟minecraft的地形生成演算法不一樣。
換句話說,以剛剛那個例子來講,
可能你產生出來的是
0, 1, 4,
3, 0, 1,
4, 3, 0
而minecraft的演算法產生出來的是
0, 1, 1,
4, 0, 4,
3, 3, 0 (zig-zag)
2. 取亂數的途中多做了什麼事
可能minecraft在取亂數的時候,為了要回應使用者的輸入,多取了幾個
例如種子 = 0,minecraft實際取用的卻是
0, 1, 4, 3, 0, 1, (4), 3, 0, 1
^被拿去做動畫效果
生成
0, 1, 4,
3, 0, 1,
3, 0, 1
3. 亂數函數根本就不同
你用 r(n+1) = (r(n)*3+1) % 5
minecraft用 r(n+1) = (r(n)*7+0) % 5
以上是一點淺見,歡迎討論 ^^;
p.s. 我印象中planetary annihilation的星球好像也是只存亂數種子?
不知道釣不釣得到cjcat XD
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 27.105.12.240
推
11/03 23:38, , 1F
11/03 23:38, 1F
→
11/03 23:38, , 2F
11/03 23:38, 2F
推
11/04 00:17, , 3F
11/04 00:17, 3F
→
11/04 00:20, , 4F
11/04 00:20, 4F
→
11/04 00:25, , 5F
11/04 00:25, 5F
→
11/04 00:31, , 6F
11/04 00:31, 6F
→
11/04 00:36, , 7F
11/04 00:36, 7F
→
11/04 00:39, , 8F
11/04 00:39, 8F
推
11/05 10:28, , 9F
11/05 10:28, 9F
→
11/05 12:11, , 10F
11/05 12:11, 10F
→
11/05 12:13, , 11F
11/05 12:13, 11F
→
11/05 22:08, , 12F
11/05 22:08, 12F
→
11/05 22:09, , 13F
11/05 22:09, 13F
推
11/05 22:48, , 14F
11/05 22:48, 14F
推
11/08 22:33, , 15F
11/08 22:33, 15F