sjz commited on
Commit
6d4d507
·
1 Parent(s): 2f21cdd

fix AI win bug

Browse files
Gomoku_MCTS/__init__.py CHANGED
@@ -1,7 +1,7 @@
1
  from .mcts_pure import MCTSPlayer as MCTSpure
2
  from .mcts_alphaZero import MCTSPlayer as alphazero
3
- from .dueling_net import PolicyValueNet
4
- # from .policy_value_net_pytorch import PolicyValueNet
5
  import numpy as np
6
 
7
 
 
1
  from .mcts_pure import MCTSPlayer as MCTSpure
2
  from .mcts_alphaZero import MCTSPlayer as alphazero
3
+ # from .dueling_net import PolicyValueNet
4
+ from .policy_value_net_pytorch import PolicyValueNet
5
  import numpy as np
6
 
7
 
Gomoku_MCTS/__pycache__/__init__.cpython-38.pyc CHANGED
Binary files a/Gomoku_MCTS/__pycache__/__init__.cpython-38.pyc and b/Gomoku_MCTS/__pycache__/__init__.cpython-38.pyc differ
 
pages/Player_VS_AI.py CHANGED
@@ -332,11 +332,15 @@ def gomoku():
332
  # session_state.ROOM.BOARD[gpt_i][gpt_j] = session_state.ROOM.TURN
333
  session_state.ROOM.COORDINATE_1D.append(gpt_i * _BOARD_SIZE + gpt_j)
334
 
335
- copy_mcts = deepcopy(session_state.ROOM.MCTS.mcts)
336
- _, acts, probs, simul_mean_time = copy_mcts.get_move_probs(session_state.ROOM.BOARD)
337
- sorted_acts_probs = sorted(zip(acts, probs), key=lambda x: x[1], reverse=True)
338
- top_five_acts = [act for act, prob in sorted_acts_probs[:5]]
339
- top_five_probs = [prob for act, prob in sorted_acts_probs[:5]]
 
 
 
 
340
 
341
  # construction of clickable buttons
342
  for i, row in enumerate(session_state.ROOM.BOARD.board_map):
@@ -354,7 +358,7 @@ def gomoku():
354
  on_click=forbid_click
355
  )
356
  else:
357
- if session_state.USE_AIAID and i * _BOARD_SIZE + j in top_five_acts:
358
  # enable click for other cells available for human choices
359
  prob = top_five_probs[top_five_acts.index(i * _BOARD_SIZE + j)]
360
  BOARD_PLATE[i][j].button(
 
332
  # session_state.ROOM.BOARD[gpt_i][gpt_j] = session_state.ROOM.TURN
333
  session_state.ROOM.COORDINATE_1D.append(gpt_i * _BOARD_SIZE + gpt_j)
334
 
335
+ if not session_state.ROOM.BOARD.game_end()[0]:
336
+ copy_mcts = deepcopy(session_state.ROOM.MCTS.mcts)
337
+ _, acts, probs, simul_mean_time = copy_mcts.get_move_probs(session_state.ROOM.BOARD)
338
+ sorted_acts_probs = sorted(zip(acts, probs), key=lambda x: x[1], reverse=True)
339
+ top_five_acts = [act for act, prob in sorted_acts_probs[:5]]
340
+ top_five_probs = [prob for act, prob in sorted_acts_probs[:5]]
341
+ else:
342
+ top_five_acts = []
343
+ top_five_probs = []
344
 
345
  # construction of clickable buttons
346
  for i, row in enumerate(session_state.ROOM.BOARD.board_map):
 
358
  on_click=forbid_click
359
  )
360
  else:
361
+ if session_state.USE_AIAID and i * _BOARD_SIZE + j in top_five_acts and not session_state.ROOM.BOARD.game_end()[0]:
362
  # enable click for other cells available for human choices
363
  prob = top_five_probs[top_five_acts.index(i * _BOARD_SIZE + j)]
364
  BOARD_PLATE[i][j].button(