X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fhistory.cpp;h=a57e6de8da5a5324d09f586304130b64881573f1;hp=6fe222feb4dfe7bec169d177bbb4b985ff350bc7;hb=6c0a37bbf2ecb828cb41cb3cfac122f34c2a6e4b;hpb=436fa5c8fa5302f69a83ad28491702c5dc3d4af7 diff --git a/src/history.cpp b/src/history.cpp index 6fe222fe..a57e6de8 100644 --- a/src/history.cpp +++ b/src/history.cpp @@ -1,7 +1,7 @@ /* Stockfish, a UCI chess playing engine derived from Glaurung 2.1 Copyright (C) 2004-2008 Tord Romstad (Glaurung author) - Copyright (C) 2008-2009 Marco Costalba + Copyright (C) 2008-2010 Marco Costalba, Joona Kiiski, Tord Romstad Stockfish is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -42,8 +42,7 @@ History::History() { clear(); } void History::clear() { memset(history, 0, 2 * 8 * 64 * sizeof(int)); - memset(successCount, 0, 2 * 8 * 64 * sizeof(int)); - memset(failureCount, 0, 2 * 8 * 64 * sizeof(int)); + memset(maxStaticValueDelta, 0, 2 * 8 * 64 * sizeof(int)); } @@ -58,7 +57,6 @@ void History::success(Piece p, Square to, Depth d) { assert(square_is_ok(to)); history[p][to] += int(d) * int(d); - successCount[p][to]++; // Prevent history overflow if (history[p][to] >= HistoryMax) @@ -72,12 +70,18 @@ void History::success(Piece p, Square to, Depth d) { /// called for each non-capturing move which failed to produce a beta cutoff /// at a node where a beta cutoff was finally found. -void History::failure(Piece p, Square to) { +void History::failure(Piece p, Square to, Depth d) { assert(piece_is_ok(p)); assert(square_is_ok(to)); - failureCount[p][to]++; + history[p][to] -= int(d) * int(d); + + // Prevent history underflow + if (history[p][to] <= -HistoryMax) + for (int i = 0; i < 16; i++) + for (int j = 0; j < 64; j++) + history[i][j] /= 2; } @@ -93,13 +97,19 @@ int History::move_ordering_score(Piece p, Square to) const { } -/// History::ok_to_prune() decides whether a move has been sufficiently -/// unsuccessful that it makes sense to prune it entirely. +/// History::set_gain() and History::gain() store and retrieve the +/// gain of a move given the delta of the static position evaluations +/// before and after the move. -bool History::ok_to_prune(Piece p, Square to, Depth d) const { - - assert(piece_is_ok(p)); - assert(square_is_ok(to)); +void History::set_gain(Piece p, Square to, Value delta) +{ + if (delta >= maxStaticValueDelta[p][to]) + maxStaticValueDelta[p][to] = delta; + else + maxStaticValueDelta[p][to]--; +} - return (int(d) * successCount[p][to] < failureCount[p][to]); +Value History::gain(Piece p, Square to) const +{ + return Value(maxStaticValueDelta[p][to]); }