Advertisement
max2201111

best minimax

May 1st, 2024
564
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Python 2.21 KB | Science | 0 0
  1. import chess
  2.  
  3. def simplify_fen_string(fen):
  4.     """Odstraní z FEN řetězce části týkající se počtu tahů, zachovává pozici, hráče na tahu, rošády a en passant."""
  5.     parts = fen.split(' ')
  6.     simplified_fen = ' '.join(parts[:4])  # Zachováváme informace o pozici, hráči na tahu, rošádách a en passant
  7.     return simplified_fen
  8.  
  9. def minimax(board, depth, alpha, beta, maximizing_player):
  10.     if depth == 0 or board.is_game_over():
  11.         return None, evaluate_board(board)
  12.    
  13.     best_move = None
  14.    
  15.     if maximizing_player:
  16.         max_eval = float('-inf')
  17.         for move in board.legal_moves:
  18.             board_copy = board.copy()
  19.             board_copy.push(move)
  20.             _, eval = minimax(board_copy, depth - 1, alpha, beta, False)
  21.             if eval > max_eval:
  22.                 max_eval = eval
  23.                 best_move = move
  24.             alpha = max(alpha, eval)
  25.             if beta <= alpha:
  26.                 break
  27.         return best_move, max_eval
  28.     else:
  29.         min_eval = float('inf')
  30.         for move in board.legal_moves:
  31.             board_copy = board.copy()
  32.             board_copy.push(move)
  33.             _, eval = minimax(board_copy, depth - 1, alpha, beta, True)
  34.             if eval < min_eval:
  35.                 min_eval = eval
  36.                 best_move = move
  37.             beta = min(beta, eval)
  38.             if beta <= alpha:
  39.                 break
  40.         return best_move, min_eval
  41.  
  42. def evaluate_board(board):
  43.     if board.is_checkmate():
  44.         # Pokud je král matován a na tahu je bílý, vrátí -1000, pokud je na tahu černý, vrátí 1000
  45.         return -1000 if board.turn == chess.WHITE else 1000
  46.     elif board.is_stalemate() or board.is_insufficient_material():
  47.         # Remíza nebo nedostatek materiálu pro mat
  48.         return 0
  49.     # Základní neutrální hodnota pro nekoncové pozice
  50.     return 0
  51.  
  52. # Nastavení startovní pozice
  53. start_fen = "6k1/3Q4/8/8/4K3/8/8/8 w - - 0 1"
  54. board = chess.Board(start_fen)
  55.  
  56. # Spuštění minimaxu s maximální hloubkou 3
  57. best_move, best_score = minimax(board, 6, float('-inf'), float('inf'), True)
  58. print(f"Nejlepší tah z pozice {start_fen} je {board.san(best_move)} s hodnocením {best_score}.")
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement