[Theory of Computer Game 11]
PNS (Proof-Number Search)
Chinese
遊戲AI
written by
LiaoWC
on 2022-02-18
PNS (Proof-Number Search) 是一種適合最接近終盤使用或是要證明一個盤面是否為必勝/必敗。它會優先選擇有較少節點要解的分支來做。先了解一下名詞,再來看範例。
名詞
- proof number:要證明一個狀態至少還有幾個狀態要解。0 表示 true;∞ 表示 false。在 OR 層取下一層 proof number 的 min,在 AND 層取下一層 proof number 的 sum。
- disproof number:要反證一個獎至少還有幾個狀態要解。0 表示 false;∞ 表示 true。在 OR 層取下一層 disproof number 的 sum,在 AND 層取下一層 disproof number 的 min。
(true 表這個狀態會贏;false 表這個狀態會輸)
- AND-OR tree:抽象化 Minimax 樹,原本取 max 的用 OR 表示(方形),取 min 的用 AND 表示(圓形)。範例會用這種形式呈現。
- most proving node:AND-OR tree 每次會選擇 most proving node 來展開。OR 層選 proof number 最小的,AND 層選 disproof number 最小的。遇到一樣我們就選左邊的。
範例
我們來看範例。每個節點旁的數字為(proof number, disproof number),每輪找 most proving node 來展開,並向上更新回去。如果 most proving node 是 terminal state,看是勝還是負,如果是勝的話,proof/disproof number 為 0/∞;如果是負的話,proof/disproof number 為 ∞/0。
從根節點開始:
data:image/s3,"s3://crabby-images/99a11/99a111e5dde4e50368744907386c396483637e3a" alt="untitled-8.png"
data:image/s3,"s3://crabby-images/e1464/e146464f5d14cb01c91e6e5b413090db5cb5cbd8" alt="untitled-9.png"
data:image/s3,"s3://crabby-images/04a7f/04a7f85a38075644a1833fe3afe1dd8729b4647b" alt="untitled-10.png"
data:image/s3,"s3://crabby-images/d4e91/d4e91c54e5b1bbfa1ce8c0ee9a1575c265039d25" alt="untitled-11.png"
data:image/s3,"s3://crabby-images/5e6f3/5e6f39886c6834bf502ec42c8de715ec419964b1" alt="untitled-12.png"
data:image/s3,"s3://crabby-images/b74d7/b74d78481b3a21c2458e5075a88149f67985f91f" alt="untitled-13.png"
data:image/s3,"s3://crabby-images/83431/83431e53692cb27084bbe2a53c984c66c8aaf527" alt="untitled-14.png"
data:image/s3,"s3://crabby-images/71ff8/71ff87f526377484fc3f070b2d2d4cba4c737649" alt="untitled-15.png"
data:image/s3,"s3://crabby-images/ad730/ad730bd1b244fc5ab3f7102ae7c144d9291af82c" alt="untitled-16.png"
data:image/s3,"s3://crabby-images/3d31f/3d31f701cdba4d9b657b401df5ed37ac982fa011" alt="untitled-17.png"
data:image/s3,"s3://crabby-images/36a37/36a3720e3e518b109fc3429f7241f591c2ed915f" alt="untitled-18.png"
data:image/s3,"s3://crabby-images/05da1/05da1fc609590ac617b8bf416fdc5f9444710212" alt="untitled-19.png"
data:image/s3,"s3://crabby-images/ebdc4/ebdc4ba2360348932da19d9f03df2438bf290bd7" alt="untitled-20.png"
data:image/s3,"s3://crabby-images/e8e00/e8e00b709d2df9a44c2f141f078458008fba0366" alt="untitled-21.png"
經過 Proof Number Search,我們成功證明根節點為必勝!
Reference
Allis, L. V., Searching for solutions in games and artificial intelligence, Ph.D. Thesis, University of Limburg, Maastricht, 1994.