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));
}
assert(square_is_ok(to));
history[p][to] += int(d) * int(d);
- successCount[p][to]++;
// Prevent history overflow
if (history[p][to] >= HistoryMax)
for (int i = 0; i < 16; i++)
for (int j = 0; j < 64; j++)
- history[i][j] /= 4;
+ history[i][j] /= 2;
}
/// 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;
}
}
-/// History::ok_to_prune() decides whether a move has been sufficiently
-/// unsuccessful that it makes sense to prune it entirely.
-
-bool History::ok_to_prune(Piece p, Square to, Depth d) const {
+/// 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.
- 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]);
}