max2201111

opraveny kod dost dobre AKkBb

Jul 5th, 2024
101
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Python 8.80 KB | Science | 0 0
  1. import chess
  2. import time
  3. from functools import lru_cache
  4. import traceback
  5. from typing import Iterator
  6. from chess import Move, BB_ALL, Bitboard, scan_reversed
  7.  
  8. # Definice nových figur
  9. AMAZON = 7
  10.  
  11. class CustomBoard(chess.Board):
  12.     def __init__(self, fen=None):
  13.         self.amazons = chess.BB_EMPTY
  14.         self.custom_bishops_white = chess.BB_EMPTY
  15.         self.custom_bishops_black = chess.BB_EMPTY
  16.         super().__init__(fen)
  17.         print("Šachovnice inicializována")
  18.         self.debug_amazons()
  19.         self.debug_custom_bishops()
  20.  
  21.     def set_chess_fen(self, fen):
  22.         super().set_chess_fen(fen)
  23.         self.custom_bishops_white = self.bishops & self.occupied_co[chess.WHITE]
  24.         self.custom_bishops_black = self.bishops & self.occupied_co[chess.BLACK]
  25.         print(f"Po nastavení FEN, bitboard amazonek: {self.amazons:064b}")
  26.         print(f"Po nastavení FEN, bitboard bílých vlastních střelců: {self.custom_bishops_white:064b}")
  27.         print(f"Po nastavení FEN, bitboard černých vlastních střelců: {self.custom_bishops_black:064b}")
  28.  
  29.     def _set_piece_at(self, square, piece, promoted=False):
  30.         super()._set_piece_at(square, piece, promoted)
  31.         if piece is not None:
  32.             piece_type = piece if isinstance(piece, int) else piece.piece_type
  33.             if piece_type == chess.BISHOP:
  34.                 color = self.color_at(square)
  35.                 if color == chess.WHITE:
  36.                     self.custom_bishops_white |= chess.BB_SQUARES[square]
  37.                 else:
  38.                     self.custom_bishops_black |= chess.BB_SQUARES[square]
  39.         else:
  40.             self.custom_bishops_white &= ~chess.BB_SQUARES[square]
  41.             self.custom_bishops_black &= ~chess.BB_SQUARES[square]
  42.  
  43.     def set_piece_at(self, square, piece, promoted=False):
  44.         self._set_piece_at(square, piece, promoted)
  45.  
  46.     def piece_type_at(self, square):
  47.         if self.amazons & chess.BB_SQUARES[square]:
  48.             return AMAZON
  49.         return super().piece_type_at(square)
  50.  
  51.     def generate_pseudo_legal_moves(self, from_mask: Bitboard = BB_ALL, to_mask: Bitboard = BB_ALL) -> Iterator[Move]:
  52.         print("Generování pseudo-legálních tahů...")
  53.        
  54.         # Generování standardních tahů
  55.         print("Generování standardních tahů...")
  56.         for move in super().generate_pseudo_legal_moves(from_mask, to_mask):
  57.             if self.piece_type_at(move.from_square) != AMAZON:
  58.                 print(f"Standardní pseudo-legální tah: {move}")
  59.                 yield move
  60.  
  61.         # Generování tahů vlastních střelců
  62.         print("Generování tahů vlastních střelců...")
  63.         our_bishops = self.custom_bishops_white if self.turn == chess.WHITE else self.custom_bishops_black
  64.         our_bishops &= from_mask
  65.         print(f"Naši střelci: {our_bishops:064b}")
  66.         for from_square in chess.scan_forward(our_bishops):
  67.             print(f"Generování tahů pro střelce na {chess.SQUARE_NAMES[from_square]}")
  68.             attacks = self.bishop_attacks(from_square)
  69.             print(f"Útoky střelce: {attacks:064b}")
  70.             valid_moves = attacks & ~self.occupied & to_mask
  71.             print(f"Platné cílové pole: {valid_moves:064b}")
  72.             for to_square in chess.scan_forward(valid_moves):
  73.                 move = Move(from_square, to_square)
  74.                 print(f"Pseudo-legální tah vlastního střelce: {move}")
  75.                 yield move
  76.  
  77.         # Generování tahů amazonek
  78.         print("Generování tahů amazonek...")
  79.         our_amazons = self.amazons & self.occupied_co[self.turn] & from_mask
  80.         print(f"Naše amazonky: {our_amazons:064b}")
  81.         for from_square in chess.scan_forward(our_amazons):
  82.             print(f"Generování tahů pro amazonku na {chess.SQUARE_NAMES[from_square]}")
  83.             attacks = self.amazon_attacks(from_square)
  84.             print(f"Útoky amazonky: {attacks:064b}")
  85.             valid_moves = attacks & ~self.occupied & to_mask
  86.             print(f"Platné cílové pole: {valid_moves:064b}")
  87.             for to_square in chess.scan_forward(valid_moves):
  88.                 move = Move(from_square, to_square)
  89.                 print(f"Pseudo-legální tah amazonky: {move}")
  90.                 yield move
  91.  
  92.         print("Dokončeno generování pseudo-legálních tahů")
  93.  
  94.     def amazon_attacks(self, square):
  95.         return (self.attacks_mask(chess.QUEEN, square, self.occupied) |
  96.                 self.attacks_mask(chess.KNIGHT, square, self.occupied))
  97.  
  98.     def bishop_attacks(self, square):
  99.         attacks = self.attacks_mask(chess.BISHOP, square, self.occupied)
  100.         print(f"Bishop attacks from {chess.SQUARE_NAMES[square]}: {attacks:064b}")
  101.         return attacks
  102.  
  103.     def is_pseudo_legal(self, move):
  104.         # Kontrola, zda je tah v rámci šachovnice
  105.         if not (chess.A1 <= move.from_square < chess.H8 and chess.A1 <= move.to_square < chess.H8):
  106.             return False
  107.  
  108.         # Kontrola, zda je na výchozím poli figura
  109.         piece = self.piece_at(move.from_square)
  110.         if not piece:
  111.             return False
  112.  
  113.         # Kontrola, zda figura patří hráči na tahu
  114.         if piece.color != self.turn:
  115.             return False
  116.  
  117.         # Kontrola, zda cílové pole není obsazeno vlastní figurou
  118.         if self.color_at(move.to_square) == self.turn:
  119.             return False
  120.  
  121.         # Speciální kontrola pro vlastní střelce
  122.         if piece.piece_type == chess.BISHOP and (self.custom_bishops_white & chess.BB_SQUARES[move.from_square] or self.custom_bishops_black & chess.BB_SQUARES[move.from_square]):
  123.             return bool(self.bishop_attacks(move.from_square) & chess.BB_SQUARES[move.to_square])
  124.  
  125.         # Kontrola pro ostatní figury
  126.         return move in super().generate_pseudo_legal_moves()
  127.  
  128.     def is_legal(self, move):
  129.         print(f"Kontrola legality tahu: {move}")
  130.         if not self.is_pseudo_legal(move):
  131.             print(f"Tah {move} není pseudo-legální")
  132.             return False
  133.         if self.is_into_check(move):
  134.             print(f"Tah {move} staví vlastního krále do šachu")
  135.             return False
  136.         print(f"Tah {move} je legální")
  137.         return True
  138.  
  139.     def piece_symbol(self, piece):
  140.         if piece is None:
  141.             return '.'
  142.         if piece.piece_type == AMAZON:
  143.             return 'A' if piece.color == chess.WHITE else 'a'
  144.         return piece.symbol()
  145.  
  146.     def debug_amazons(self):
  147.         print(f"Bitboard amazonek: {format(self.amazons, '064b')}")
  148.         for square in chess.SQUARES:
  149.             if self.amazons & chess.BB_SQUARES[square]:
  150.                 print(f"Amazonka na {chess.SQUARE_NAMES[square]}")
  151.  
  152.     def debug_custom_bishops(self):
  153.         print(f"Bitboard bílých vlastních střelců: {format(self.custom_bishops_white, '064b')}")
  154.         print(f"Bitboard černých vlastních střelců: {format(self.custom_bishops_black, '064b')}")
  155.         for square in chess.SQUARES:
  156.             if self.custom_bishops_white & chess.BB_SQUARES[square]:
  157.                 print(f"Bílý vlastní střelec na {chess.SQUARE_NAMES[square]}")
  158.             if self.custom_bishops_black & chess.BB_SQUARES[square]:
  159.                 print(f"Černý vlastní střelec na {chess.SQUARE_NAMES[square]}")
  160.  
  161.     @property
  162.     def legal_moves(self):
  163.         legal_moves = [move for move in self.generate_pseudo_legal_moves() if self.is_legal(move)]
  164.         for move in legal_moves:
  165.             print(f"Legální tah: {move}")
  166.         return legal_moves
  167.  
  168. if __name__ == "__main__":
  169.     start_fen = "1b6/3k4/8/8/1B6/8/8/6K1 w - - 0 1"
  170.    
  171.     try:
  172.         print(f"Vytváření šachovnice s FEN: {start_fen}")
  173.         initial_board = CustomBoard(start_fen)
  174.        
  175.         print("Ladění amazonek...")
  176.         print(f"Bitboard amazonek: {initial_board.amazons:064b}")
  177.         print(f"Bitboard bílých vlastních střelců: {initial_board.custom_bishops_white:064b}")
  178.         print(f"Bitboard černých vlastních střelců: {initial_board.custom_bishops_black:064b}")
  179.        
  180.         initial_board.debug_amazons()
  181.         initial_board.debug_custom_bishops()
  182.        
  183.         print("Současná pozice:")
  184.         print(initial_board)
  185.        
  186.         print("Generování legálních tahů pro počáteční pozici...")
  187.         legal_moves = list(initial_board.legal_moves)
  188.         print(f"Počet legálních tahů: {len(legal_moves)}")
  189.        
  190.         print("Legální tahy:")
  191.         for move in legal_moves:
  192.             from_square = chess.SQUARE_NAMES[move.from_square]
  193.             to_square = chess.SQUARE_NAMES[move.to_square]
  194.             piece = initial_board.piece_at(move.from_square)
  195.             print(f"{initial_board.piece_symbol(piece)}: {from_square}-{to_square}")
  196.        
  197.     except Exception as e:
  198.         print(f"Došlo k chybě: {str(e)}")
  199.         traceback.print_exc()
Add Comment
Please, Sign In to add comment