From 3fe4b8c196c42c2ca8eaec529e759c85ec3a49ff Mon Sep 17 00:00:00 2001 From: dogeystamp Date: Thu, 26 Dec 2024 11:18:48 -0500 Subject: [PATCH] feat: contempt factor --- src/search.rs | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/src/search.rs b/src/search.rs index 7cdedea..6d747eb 100644 --- a/src/search.rs +++ b/src/search.rs @@ -112,6 +112,18 @@ pub struct SearchConfig { pub depth: usize, /// Limit quiescence search depth pub qdepth: usize, + + /// Parameter that sets how confident the engine is. + /// + /// Positive means avoid draws, and try to win instead. + /// + /// Depending on the game phase, an extra factor will be multiplied too; in the beginning of + /// the game the opponent is more likely to blunder later and lose their advantage, so we don't + /// go for draws. Later, the result is more certain, so reduce the contempt factor. + /// + /// An alternative interpretation of this: the contempt factor is the negative of the value + /// assigned to a draw. + pub contempt: EvalInt, /// Enable transposition table. pub enable_trans_table: bool, /// Transposition table size (2^n where this is n) @@ -124,6 +136,7 @@ impl Default for SearchConfig { alpha_beta_on: true, depth: 16, qdepth: 6, + contempt: 23, enable_trans_table: true, transposition_size: 24, } @@ -209,6 +222,11 @@ fn minmax(board: &mut Board, state: &mut EngineState, mm: MinmaxState) -> (Vec= 2; + let phase_factor = EvalInt::from(board.eval.min_maj_pieces / 5); + // positive here since we're looking from the opposite perspective. + // if white caused a draw, then we'd be black here. + // therefore, white would see a negative value for the draw. + let contempt = state.config.contempt * phase_factor; // quiescence stand-pat score (only calculated if needed). // this is where static eval goes. @@ -216,7 +234,7 @@ fn minmax(board: &mut Board, state: &mut EngineState, mm: MinmaxState) -> (Vec (Vec