X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fhistory.h;h=2665f24fc34628d986edc57effe612ee8c7b06fc;hp=ae8345345ac73d85f6288a0eb89687b758ac1cbe;hb=201f924d5364e8151c41fa2840bacc8381450cc5;hpb=b98bcf858ba0cac58d52b76eb1bea40e25adcaa1 diff --git a/src/history.h b/src/history.h index ae834534..2665f24f 100644 --- a/src/history.h +++ b/src/history.h @@ -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 @@ -28,6 +28,7 @@ #include "depth.h" #include "move.h" #include "piece.h" +#include "value.h" //// @@ -47,14 +48,14 @@ public: History(); void clear(); void success(Piece p, Square to, Depth d); - void failure(Piece p, Square to); - int move_ordering_score(Piece p, Square to) const; - bool ok_to_prune(Piece p, Square to, Depth d) const; + void failure(Piece p, Square to, Depth d); + int value(Piece p, Square to) const; + void set_gain(Piece p, Square to, Value delta); + Value gain(Piece p, Square to) const; private: int history[16][64]; // [piece][square] - int successCount[16][64]; - int failureCount[16][64]; + int maxStaticValueDelta[16][64]; // [piece][from_square][to_square] }; @@ -70,7 +71,19 @@ private: /// recently have a bigger importance for move ordering than the moves which /// have been searched a long time ago. -const int HistoryMax = 25000 * OnePly; +const int HistoryMax = 50000 * OnePly; +//// +//// Inline functions +//// + +inline int History::value(Piece p, Square to) const { + return history[p][to]; +} + +inline Value History::gain(Piece p, Square to) const { + return Value(maxStaticValueDelta[p][to]); +} + #endif // !defined(HISTORY_H_INCLUDED)