From 2a72cd6cfb239e2cc95174b96ae8b9fbe7969c3d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Eduardo=20C=C3=A1ceres?= Date: Thu, 2 Jan 2025 11:56:36 +0100 Subject: [PATCH] Save always static eval (no final position eval) + re-use TT static eval in QSearch --- src/Lynx/Model/TranspositionTable.cs | 6 ++++-- src/Lynx/Search/NegaMax.cs | 7 ++----- 2 files changed, 6 insertions(+), 7 deletions(-) diff --git a/src/Lynx/Model/TranspositionTable.cs b/src/Lynx/Model/TranspositionTable.cs index 6d8be26b1..e5d9964bd 100644 --- a/src/Lynx/Model/TranspositionTable.cs +++ b/src/Lynx/Model/TranspositionTable.cs @@ -72,8 +72,9 @@ public void PrefetchTTEntry(Position position) // We want to translate the checkmate position relative to the saved node to our root position from which we're searching // If the recorded score is a checkmate in 3 and we are at depth 5, we want to read checkmate in 8 var recalculatedScore = RecalculateMateScores(entry.Score, ply); + var recalculatedStaticEval = RecalculateMateScores(entry.StaticEval, ply); - return (recalculatedScore, entry.Move, entry.Type, entry.StaticEval, entry.Depth); + return (recalculatedScore, entry.Move, entry.Type, recalculatedStaticEval, entry.Depth); } /// @@ -105,8 +106,9 @@ public void RecordHash(Position position, int staticEval, int depth, int ply, in // We want to store the distance to the checkmate position relative to the current node, independently from the root // If the evaluated score is a checkmate in 8 and we're at depth 5, we want to store checkmate value in 3 var recalculatedScore = RecalculateMateScores(score, -ply); + var recalculatedStaticEval = RecalculateMateScores(staticEval, -ply); - entry.Update(position.UniqueIdentifier, recalculatedScore, staticEval, depth, nodeType, move); + entry.Update(position.UniqueIdentifier, recalculatedScore, recalculatedStaticEval, depth, nodeType, move); } /// diff --git a/src/Lynx/Search/NegaMax.cs b/src/Lynx/Search/NegaMax.cs index fee6ee1f2..ead23e36a 100644 --- a/src/Lynx/Search/NegaMax.cs +++ b/src/Lynx/Search/NegaMax.cs @@ -497,7 +497,7 @@ void RevertMove() Debug.Assert(bestMove is null); var finalEval = Position.EvaluateFinalPosition(ply, isInCheck); - _tt.RecordHash(position, finalEval, depth, ply, finalEval, NodeType.Exact); + _tt.RecordHash(position, staticEval, depth, ply, finalEval, NodeType.Exact); return finalEval; } @@ -556,13 +556,10 @@ public int QuiescenceSearch(int ply, int alpha, int beta, CancellationToken canc _maxDepthReached[ply] = ply; - /* var staticEval = ttHit ? ttProbeResult.StaticEval : position.StaticEvaluation(Game.HalfMovesWithoutCaptureOrPawnMove).Score; - */ - var staticEval = position.StaticEvaluation(Game.HalfMovesWithoutCaptureOrPawnMove).Score; Debug.Assert(staticEval != EvaluationConstants.NoHashEntry, "Assertion failed", "All TT entries should have a static eval"); Game.UpdateStaticEvalInStack(ply, staticEval); @@ -677,7 +674,7 @@ public int QuiescenceSearch(int ply, int alpha, int beta, CancellationToken canc Debug.Assert(bestMove is null); var finalEval = Position.EvaluateFinalPosition(ply, position.IsInCheck()); - _tt.RecordHash(position, finalEval, 0, ply, finalEval, NodeType.Exact); + _tt.RecordHash(position, staticEval, 0, ply, finalEval, NodeType.Exact); return finalEval; }