diff options
| -rw-r--r-- | src/board/engine.rs | 37 | ||||
| -rw-r--r-- | src/moves.rs | 9 | 
2 files changed, 31 insertions, 15 deletions
| diff --git a/src/board/engine.rs b/src/board/engine.rs index 47890ad..05cb1e7 100644 --- a/src/board/engine.rs +++ b/src/board/engine.rs @@ -1,4 +1,4 @@ -use std::{time::{Instant, Duration}, f32::INFINITY}; +use std::{time::{Instant, Duration}, f32::INFINITY, cmp::Ordering};  use crate::{bitboard::pop_count, board::*};  use super::ttable::{NodeType, TranspositionTableItem}; @@ -173,7 +173,7 @@ impl Board {      /// Evaluate move for move ordering, prioritizing efficient captures      /// where low-value pieces capture high-value pieces      fn eval_move(&self, m: Move) -> f32 { -        if m.kind == MoveKind::Capture || m.kind == MoveKind::EnPassant { +        if m.is_tactical() {              let [source_eval, target_eval] = [m.source, m.target]                  .map(|sq| self.piece_by_square(sq))                  .map(|p| { @@ -187,17 +187,29 @@ impl Board {          0.0      } -    pub fn negamax_search(&mut self, mut alpha: f32, beta: f32, depth_left: u8, deadline: Instant) -> (f32, Vec<Move>) { -        let mut principal_variation = Vec::new(); -        let color = self.color(); - -        let mut moves = self.generate_pseudolegal_moves(color); - +    pub fn order_moves(&self, moves: &mut Vec<Move>) {          moves.sort_unstable_by(|a, b| {              let a_eval = self.eval_move(*a);              let b_eval = self.eval_move(*b); +            if a_eval == 0.0 && b_eval == 0.0 { +                // Prioritize equal captures over non-captures +                if a.is_tactical() && !b.is_tactical() { +                    return Ordering::Less +                } +                if b.is_tactical() && !a.is_tactical() { +                    return Ordering::Greater +                } +            }              a_eval.total_cmp(&b_eval).reverse()          }); +    } + +    pub fn negamax_search(&mut self, mut alpha: f32, beta: f32, depth_left: u8, deadline: Instant) -> (f32, Vec<Move>) { +        let mut principal_variation = Vec::new(); +        let color = self.color(); + +        let mut moves = self.generate_pseudolegal_moves(color); +        self.order_moves(&mut moves);          match self.transposition_table[(self.hash % TTABLE_SIZE) as usize] {              Some(item) => { @@ -273,12 +285,7 @@ impl Board {      pub fn quiscence(&mut self, mut alpha: f32, beta: f32) -> f32 {          let color = self.color();          let mut moves = self.generate_pseudolegal_moves(color); - -        moves.sort_unstable_by(|a, b| { -            let a_eval = self.eval_move(*a); -            let b_eval = self.eval_move(*b); -            a_eval.total_cmp(&b_eval).reverse() -        }); +        self.order_moves(&mut moves);          match self.transposition_table[(self.hash % TTABLE_SIZE) as usize] {              Some(item) => { @@ -298,7 +305,7 @@ impl Board {              alpha = stand_pat;          } -        let tactical_moves = moves.iter().filter(|m| m.kind == MoveKind::Capture || m.kind == MoveKind::EnPassant); +        let tactical_moves = moves.iter().filter(|m| m.is_tactical());          for mov in tactical_moves {              let ep_target_before = self.ep_target.clone(); diff --git a/src/moves.rs b/src/moves.rs index 87b7c4b..34f8370 100644 --- a/src/moves.rs +++ b/src/moves.rs @@ -22,6 +22,15 @@ impl Move {          let bb = self.source.to_bitboard() | self.target.to_bitboard();          print(bb, format!("{:?}", self).as_str());      } + +    /// Tactical move is a move that changes material score +    pub fn is_tactical(&self) -> bool { +        match self.kind { +            MoveKind::Capture => true, +            MoveKind::EnPassant => true, +            _ => false, +        } +    }  } | 
