diff options
| author | eug-vs <eugene@eug-vs.xyz> | 2023-02-20 18:56:19 +0300 | 
|---|---|---|
| committer | eug-vs <eugene@eug-vs.xyz> | 2023-02-20 18:56:19 +0300 | 
| commit | 5e4a7b49b0be5128b56ed6107f8593f134a49522 (patch) | |
| tree | 52a2886d7da75e65bc161d09ec211065930bb231 | |
| parent | fa6f6c3f5f8f872a216ccdb593492775c0d265a1 (diff) | |
| download | chessnost-5e4a7b49b0be5128b56ed6107f8593f134a49522.tar.gz | |
feat: apply late move reductions
| -rw-r--r-- | src/board/engine.rs | 21 | 
1 files changed, 17 insertions, 4 deletions
| diff --git a/src/board/engine.rs b/src/board/engine.rs index 1516784..7f2fef3 100644 --- a/src/board/engine.rs +++ b/src/board/engine.rs @@ -343,6 +343,7 @@ impl Board {          let mut principal_variation = Vec::new();          let mut killer_moves = Vec::new();          let color = self.color(); +        let is_in_check = self.is_king_in_check(color);          match self.transposition() {              Some(transposition) => { @@ -377,7 +378,7 @@ impl Board {              return (self.quiscence(alpha, beta), principal_variation);          } -        let mut should_pv_search = true; +        let mut should_pv_search = true; // = !should_apply_LMR          let mut legal_move_found = false;          for mov in moves {              let ep_target_before = self.ep_target.clone(); @@ -392,10 +393,22 @@ impl Board {                      // Assume PV-node is high in the list (if move ordering is good)                      self.negamax_search(-beta, -alpha, depth_left - 1, &mut killer_moves, deadline)                  } else { +                    // Apply late move reductions +                    let reduction = if +                        depth_left > 2 && +                        !is_in_check && +                        !mov.is_tactical() +                        { +                            1 +                        } else { +                            0 +                        }; +                      // After we have PV-node (that raised alpha) all other nodes will be searched -                    // with zero-window first to confirm this assumption +                    // with zero-window first to confirm this assumption. +                    // Also (optionally) apply Late Move Reductions                      // TODO: changing 0.001 -> 0.0001 leads to a weird bug -                    let result = self.negamax_search(-(alpha + 0.001), -alpha, depth_left - 1, &mut killer_moves, deadline); +                    let result = self.negamax_search(-(alpha + 0.001), -alpha, depth_left - 1 - reduction, &mut killer_moves, deadline);                      // In case some of the other nodes raises alpha, then it's true PV node now,                      // let's research with full window to find its exact value                      if -result.0 > alpha { @@ -459,7 +472,7 @@ impl Board {          }          if !legal_move_found { -            if self.is_king_in_check(color) { +            if is_in_check {                  return (-VALUE_WIN, principal_variation);              }          } | 
