X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fposition.cpp;h=1b2defa54662a34718bb46c79e40ae9abffbe595;hp=ad699cc0e93423ef4112093b442da41c0466cb72;hb=d23454854e72e1311363a8c98cd58a5d44c427f9;hpb=9a1d5f0f1d8a12a85b198688d4f1d636a146eb7a diff --git a/src/position.cpp b/src/position.cpp index ad699cc0..1b2defa5 100644 --- a/src/position.cpp +++ b/src/position.cpp @@ -1148,6 +1148,21 @@ int Position::see_sign(Move m) const { } int Position::see(Move m) const { + return do_see(m, 0); +} + +/// Position::see_asymm() takes tempi into account. +/// If the side who initiated the capturing sequence does the last capture, +/// he loses a tempo. In this case if the result is below asymmThreshold +/// the capturing sequence is considered bad. + +int Position::see_asymm(Move m, int asymmThreshold) const +{ + return do_see(m, asymmThreshold); +} + +template +int Position::do_see(Move m, int asymmThreshold) const { Square from, to; Bitboard occupied, attackers, stmAttackers; @@ -1224,6 +1239,18 @@ int Position::see(Move m) const { } while (stmAttackers); + // If we are doing asymmetric SEE evaluation and the same side does the first + // and the last capture, he loses a tempo and gain must be at least worth "asymmThreshold". + // If not, we replace the score with a very low value, before negamaxing. + if (Asymmetric) + { + for (int i = 0; i < slIndex ; i += 2) + { + if (swapList[i] < asymmThreshold) + swapList[i] = - QueenValueMg * 16; + } + } + // Having built the swap list, we negamax through it to find the best // achievable score from the point of view of the side to move. while (--slIndex)