2 Stockfish, a UCI chess playing engine derived from Glaurung 2.1
3 Copyright (C) 2004-2008 Tord Romstad (Glaurung author)
4 Copyright (C) 2008-2010 Marco Costalba, Joona Kiiski, Tord Romstad
6 Stockfish is free software: you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation, either version 3 of the License, or
9 (at your option) any later version.
11 Stockfish is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program. If not, see <http://www.gnu.org/licenses/>.
38 History::History() { clear(); }
41 /// History::clear() clears the history tables
43 void History::clear() {
44 memset(history, 0, 16 * 64 * sizeof(int));
45 memset(maxStaticValueDelta, 0, 16 * 64 * sizeof(int));
49 /// History::success() registers a move as being successful. This is done
50 /// whenever a non-capturing move causes a beta cutoff in the main search.
51 /// The three parameters are the moving piece, the destination square, and
54 void History::success(Piece p, Square to, Depth d) {
56 assert(piece_is_ok(p));
57 assert(square_is_ok(to));
59 history[p][to] += int(d) * int(d);
63 /// History::failure() registers a move as being unsuccessful. The function is
64 /// called for each non-capturing move which failed to produce a beta cutoff
65 /// at a node where a beta cutoff was finally found.
67 void History::failure(Piece p, Square to, Depth d) {
69 assert(piece_is_ok(p));
70 assert(square_is_ok(to));
72 history[p][to] -= int(d) * int(d);
76 /// History::set_gain() and History::gain() store and retrieve the
77 /// gain of a move given the delta of the static position evaluations
78 /// before and after the move.
80 void History::set_gain(Piece p, Square to, Value delta) {
82 if (delta >= maxStaticValueDelta[p][to])
83 maxStaticValueDelta[p][to] = delta;
85 maxStaticValueDelta[p][to]--;