aboutsummaryrefslogtreecommitdiff
path: root/src/board/mod.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/board/mod.rs')
-rw-r--r--src/board/mod.rs50
1 files changed, 25 insertions, 25 deletions
diff --git a/src/board/mod.rs b/src/board/mod.rs
index 854ce0e..5317cc2 100644
--- a/src/board/mod.rs
+++ b/src/board/mod.rs
@@ -1,6 +1,6 @@
use crate::{bitboard::{Bitboard, BitboardFns}, moves::{Move, MoveKind}, attacks::Attacks, square::Square, board::io::IO};
-use self::{ttable::{TranspositionTable, TTABLE_SIZE}, zobrist::ZobristSeed};
+use self::{ttable::{TranspositionTable, TTABLE_SIZE}, zobrist::{ZobristSeed, Zobrist}};
pub mod io;
mod zobrist;
mod engine;
@@ -405,7 +405,7 @@ impl Board {
let mut captured_piece = match self.piece_by_square(mov.target) {
Some(target_piece) => {
self.piece_sets[target_piece as usize] ^= move_target_bb;
- self.hash ^= self.zobrist_seed[(target_piece as usize) * 64 + mov.target as usize];
+ self.zobrist_toggle_piece(target_piece, mov.target);
Some(target_piece)
},
None => None,
@@ -419,8 +419,8 @@ impl Board {
Some(pawn_type) => {
let captured_bb = captured_square.to_bitboard();
self.piece_sets[pawn_type as usize] ^= captured_bb;
- self.occupancy ^= captured_bb;
- self.hash ^= self.zobrist_seed[pawn_type as usize* 64 + captured_square as usize];
+ self.occupancy ^= captured_bb;
+ self.zobrist_toggle_piece(pawn_type, captured_square);
Some(pawn_type)
},
None => panic!("Pawn captured by En Passant was not found"),
@@ -435,21 +435,21 @@ impl Board {
MoveKind::Promotion(promotion_piece) => {
let promo_id = promotion_piece as usize;
self.piece_sets[source_id] ^= move_source_bb;
- self.occupancy ^= move_source_bb;
- self.hash ^= self.zobrist_seed[source_id * 64 + mov.source as usize];
+ self.occupancy ^= move_source_bb;
+ self.zobrist_toggle_piece(source_piece, mov.source);
self.piece_sets[promo_id] |= move_target_bb;
- self.occupancy |= move_target_bb;
- self.hash ^= self.zobrist_seed[promo_id * 64 + mov.target as usize];
+ self.occupancy |= move_target_bb;
+ self.zobrist_toggle_piece(promotion_piece, mov.target);
},
_ => {
self.piece_sets[source_id] ^= move_source_bb;
- self.occupancy ^= move_source_bb;
- self.hash ^= self.zobrist_seed[source_id * 64 + mov.source as usize];
+ self.occupancy ^= move_source_bb;
+ self.zobrist_toggle_piece(source_piece, mov.source);
self.piece_sets[source_id] |= move_target_bb;
- self.occupancy |= move_target_bb;
- self.hash ^= self.zobrist_seed[source_id * 64 + mov.target as usize];
+ self.occupancy |= move_target_bb;
+ self.zobrist_toggle_piece(source_piece, mov.target);
}
}
PieceType::from(source_piece)
@@ -479,11 +479,11 @@ impl Board {
let rook_id = rook_type as usize;
self.piece_sets[rook_id] ^= rook_source_bb;
self.occupancy ^= rook_source_bb;
- self.hash ^= self.zobrist_seed[rook_id * 64 + rook_source_square as usize];
+ self.zobrist_toggle_piece(rook_type, rook_source_square);
self.piece_sets[rook_id] |= rook_target_bb;
self.occupancy |= rook_target_bb;
- self.hash ^= self.zobrist_seed[rook_id * 64 + rook_target_square as usize];
+ self.zobrist_toggle_piece(rook_type, rook_target_square);
},
None => panic!("Rook was not found when castling"),
}
@@ -491,7 +491,7 @@ impl Board {
// Double push should set En Passant target square
self.ep_target = if mov.kind == MoveKind::DoublePush {
- self.hash ^= self.zobrist_seed[64 * 12 + 4 + mov.source.file() as usize];
+ self.zobrist_toggle_ep_square(mov.source);
match mov.source.rank() {
1 => Some(mov.source.nort_one()),
6 => Some(mov.source.sout_one()),
@@ -500,23 +500,23 @@ impl Board {
} else { None };
// Withdraw castling rights when moving rooks or king
- let source_color = Color::from_piece(source_piece) as usize;
+ let source_color = Color::from_piece(source_piece);
match source_piece.without_color() {
PieceType::King => {
- self.castling_rights[source_color][CastlingSide::King as usize] = false;
- self.castling_rights[source_color][CastlingSide::Queen as usize] = false;
- self.hash ^= self.zobrist_seed[64 * 12 + source_color * 2 + 0];
- self.hash ^= self.zobrist_seed[64 * 12 + source_color * 2 + 1];
+ self.castling_rights[source_color as usize][CastlingSide::King as usize] = false;
+ self.castling_rights[source_color as usize][CastlingSide::Queen as usize] = false;
+ self.zobrist_toggle_castling_right(source_color, CastlingSide::King);
+ self.zobrist_toggle_castling_right(source_color, CastlingSide::Queen);
},
PieceType::Rook => {
match mov.source.file() {
0 => {
- self.castling_rights[source_color][CastlingSide::Queen as usize] = false;
- self.hash ^= self.zobrist_seed[64 * 12 + source_color * 2 + CastlingSide::Queen as usize];
+ self.castling_rights[source_color as usize][CastlingSide::Queen as usize] = false;
+ self.zobrist_toggle_castling_right(source_color, CastlingSide::Queen);
}
7 => {
- self.castling_rights[source_color][CastlingSide::King as usize] = false;
- self.hash ^= self.zobrist_seed[64 * 12 + source_color * 2 + CastlingSide::King as usize];
+ self.castling_rights[source_color as usize][CastlingSide::King as usize] = false;
+ self.zobrist_toggle_castling_right(source_color, CastlingSide::King);
}
_ => {},
}
@@ -525,7 +525,7 @@ impl Board {
}
self.ply += 1;
- self.hash ^= self.zobrist_seed[780];
+ self.zobrist_toggle_color();
captured_piece
}