]> git.sesse.net Git - stockfish/commitdiff
Remove a drawing rule from KBPsK function
authorChris Caino <chricainogithub@gmail.com>
Mon, 14 Oct 2013 17:53:08 +0000 (19:53 +0200)
committerMarco Costalba <mcostalba@gmail.com>
Mon, 14 Oct 2013 17:55:07 +0000 (19:55 +0200)
The rule can be incorrect if the attacking king is
well placed e.g. 8/6K1/8/8/7k/1B6/7P/8 w - - 0 1

bench: 8279065

src/endgame.cpp

index c8d222804008c5d78019439bf5a53da610642d5f..b9ac17a2e9cf6486c4ca8ae22600bf46845d8753 100644 (file)
@@ -407,19 +407,8 @@ ScaleFactor Endgame<KBPsK>::operator()(const Position& pos) const {
       Square kingSq = pos.king_square(weakSide);
 
       if (   opposite_colors(queeningSq, bishopSq)
-          && abs(file_of(kingSq) - pawnFile) <= 1)
-      {
-          // The bishop has the wrong color, and the defending king is on the
-          // file of the pawn(s) or the adjacent file. Find the rank of the
-          // frontmost pawn.
-          Square pawnSq = frontmost_sq(strongSide, pawns);
-
-          // If the defending king has distance 1 to the promotion square or
-          // is placed somewhere in front of the pawn, it's a draw.
-          if (   square_distance(kingSq, queeningSq) <= 1
-              || relative_rank(weakSide, kingSq) <= relative_rank(weakSide, pawnSq))
-              return SCALE_FACTOR_DRAW;
-      }
+          && square_distance(queeningSq, kingSq) <= 1)
+          return SCALE_FACTOR_DRAW;
   }
 
   // All pawns on same B or G file? Then potential draw