Use an affine formula to mix stats and eval
authorStéphane Nicolet <cassio@free.fr>
Fri, 17 Aug 2018 23:23:36 +0000 (01:23 +0200)
committerStéphane Nicolet <cassio@free.fr>
Fri, 17 Aug 2018 23:23:36 +0000 (01:23 +0200)
commitf3b8a699194515e0b74f5349cf84175a97f824e8
tree8c75855c013e516e88fabf8d85697359801b217f
parent96c3a1f2eca1dfb96fdddc03630e6d984c358a2b
Use an affine formula to mix stats and eval

Follow-up for the previous patch: we use an affine formula to mix stats
and evaluation in search. The idea is to give a bonus if the previous
move of the opponent was historically bad, and a malus if the previous
move of the opponent was historically good.

More precisely, if x is the stat score of the previous move by the opponent,
we implement the following formulas to tweak the evaluation at an internal
node of the tree for our pruning decisions at this node:

if x = 0, use v' = eval(P)
if x > 0, use v' = eval(P) - 5 - x/1024
if x < 0, use v' = eval(P) + 5 - x/1024

For reference, the previous master had this simpler rule:

if x > 0, use v' = eval(P) - 10
if x <= 0, use v' = eval(P)

STC:
LLR: 2.95 (-2.94,2.94) [0.00,5.00]
Total: 29322 W: 6359 L: 6088 D: 16875
http://tests.stockfishchess.org/tests/view/5b76a5980ebc5902bdba957f

LTC:
LLR: 2.96 (-2.94,2.94) [0.00,5.00]
Total: 30893 W: 5154 L: 4910 D: 20829
http://tests.stockfishchess.org/tests/view/5b76ca6d0ebc5902bdba9914

Closes https://github.com/official-stockfish/Stockfish/pull/1740

Bench: 4592766
src/search.cpp