diff options
Diffstat (limited to 'src/grossmeister')
-rw-r--r-- | src/grossmeister/mod.rs | 2 | ||||
-rw-r--r-- | src/grossmeister/move_generation.rs | 23 | ||||
-rw-r--r-- | src/grossmeister/search.rs | 73 |
3 files changed, 41 insertions, 57 deletions
diff --git a/src/grossmeister/mod.rs b/src/grossmeister/mod.rs index b7c134d..6ed5f17 100644 --- a/src/grossmeister/mod.rs +++ b/src/grossmeister/mod.rs @@ -26,7 +26,7 @@ pub struct Grossmeister { impl Grossmeister { pub fn new(board: Board) -> Self { - return Self { + Self { board, attacks: Attacks::new(), transposition_table: vec![None; TTABLE_SIZE as usize], diff --git a/src/grossmeister/move_generation.rs b/src/grossmeister/move_generation.rs index 25d92c7..c3acc91 100644 --- a/src/grossmeister/move_generation.rs +++ b/src/grossmeister/move_generation.rs @@ -153,7 +153,7 @@ impl Grossmeister { } } } - return moves + moves } /// Evaluate move for move ordering, prioritizing efficient captures @@ -195,25 +195,20 @@ impl Grossmeister { let mut ordered_moves: Vec<Move> = moves_with_eval.iter().map(|(m, _)| *m).collect(); // Insert killer moves after winning captures - let equal_capture_index = match moves_with_eval.iter().position(|(m, eval)| m.is_tactical() && *eval == 0.0) { - Some(x) => x, - None => 0, - }; + let equal_capture_index = moves_with_eval + .iter() + .position(|(m, eval)| m.is_tactical() && *eval == 0.0) + .unwrap_or(0); for killer in killer_moves { - match ordered_moves.iter().position(|m| *m == killer) { - Some(index) => { + if let Some(index) = ordered_moves.iter().position(|m| *m == killer) { let mov = ordered_moves.remove(index); ordered_moves.insert(equal_capture_index, mov); - } - None => {} - }; - + } } - match self.transposition() { - Some(transposition) => ordered_moves.insert(0, transposition.mov), - None => {}, + if let Some(transposition) = self.transposition() { + ordered_moves.insert(0, transposition.mov); } ordered_moves diff --git a/src/grossmeister/search.rs b/src/grossmeister/search.rs index 57ce672..3efa9f8 100644 --- a/src/grossmeister/search.rs +++ b/src/grossmeister/search.rs @@ -21,30 +21,27 @@ impl Grossmeister { let mut killer_moves = Vec::new(); let color = self.board.color(); - match self.transposition() { - Some(transposition) => { - if transposition.depth == depth_left { - match transposition.node_type { - NodeType::PV => { // PV-nodes have exact score + if let Some(transposition) = self.transposition() { + if transposition.depth == depth_left { + match transposition.node_type { + NodeType::PV => { // PV-nodes have exact score + principal_variation.push(transposition.mov); + return (transposition.score, principal_variation); + } + NodeType::Cut => { + if transposition.score >= beta { principal_variation.push(transposition.mov); - return (transposition.score, principal_variation); - } - NodeType::Cut => { - if transposition.score >= beta { - principal_variation.push(transposition.mov); - return (beta, principal_variation); - } + return (beta, principal_variation); } - NodeType::All => { - if transposition.score <= alpha { - principal_variation.push(transposition.mov); - return (alpha, principal_variation); - } + } + NodeType::All => { + if transposition.score <= alpha { + principal_variation.push(transposition.mov); + return (alpha, principal_variation); } } } } - None => {}, } if depth_left == 0 { @@ -57,9 +54,9 @@ impl Grossmeister { let mut should_pv_search = true; let mut legal_move_found = false; for mov in moves { - let ep_target_before = self.board.ep_target.clone(); - let castling_rights_before = self.board.castling_rights.clone(); - let hash_before = self.board.hash.clone(); + let ep_target_before = self.board.ep_target; + let castling_rights_before = self.board.castling_rights; + let hash_before = self.board.hash; let captured_piece = self.board.make_move(mov); if !self.board.is_king_in_check(color) { @@ -135,10 +132,8 @@ impl Grossmeister { } } - if !legal_move_found { - if self.board.is_king_in_check(color) { - return (-VALUE_WIN, principal_variation); - } + if !legal_move_found && self.board.is_king_in_check(color) { + return (-VALUE_WIN, principal_variation); } (alpha, principal_variation) @@ -161,18 +156,14 @@ impl Grossmeister { } // If we are not in check, we can only search tactical moves - moves = moves - .iter() - .filter(|m| m.is_tactical()) - .map(|m| *m) - .collect() + moves.retain(|m| m.is_tactical()) } let mut legal_move_found = false; for mov in moves { - let ep_target_before = self.board.ep_target.clone(); - let castling_rights_before = self.board.castling_rights.clone(); - let hash_before = self.board.hash.clone(); + let ep_target_before = self.board.ep_target; + let castling_rights_before = self.board.castling_rights; + let hash_before = self.board.hash; let captured_piece = self.board.make_move(mov); if !self.board.is_king_in_check(color) { @@ -191,10 +182,8 @@ impl Grossmeister { } } - if !legal_move_found { - if self.board.is_king_in_check(color) { - return -VALUE_WIN - } + if !legal_move_found && self.board.is_king_in_check(color) { + return -VALUE_WIN } alpha @@ -252,7 +241,7 @@ impl Grossmeister { continue; } - if search_result.1.len() > 0 { + if !search_result.1.is_empty() { depth += 1; gradual_widening_counter = 0; alpha = search_result.0 - window_size; @@ -265,7 +254,7 @@ impl Grossmeister { } match result { - Some(r) => return r, + Some(r) => r, None => panic!("Could not find a move in time"), } } @@ -287,9 +276,9 @@ impl Grossmeister { } for mov in moves { - let ep_target_before = self.board.ep_target.clone(); - let castling_rights_before = self.board.castling_rights.clone(); - let hash_before = self.board.hash.clone(); + let ep_target_before = self.board.ep_target; + let castling_rights_before = self.board.castling_rights; + let hash_before = self.board.hash; let captured_piece = self.board.make_move(mov); // King can not be in check after our own move if !self.board.is_king_in_check(color) { |