]> git.sesse.net Git - stockfish/commitdiff
Merge branch 'simplify_eval' into bishop_pin_clop
authorGary Linscott <glinscott@gmail.com>
Wed, 13 Feb 2013 17:19:54 +0000 (12:19 -0500)
committerGary Linscott <glinscott@gmail.com>
Wed, 13 Feb 2013 17:19:54 +0000 (12:19 -0500)
src/evaluate.cpp
src/ucioption.cpp

index 984a85a65e0492c3daaa46ddc72f06709ae32487..56bcbc683e521232ba24a016d8d19e8f1759689a 100644 (file)
@@ -150,6 +150,8 @@ namespace {
 
   #undef S
 
+  Score BishopPinBonus = make_score(66, 11);
+
   // Bonus for having the side to move (modified by Joona Kiiski)
   const Score Tempo = make_score(24, 11);
 
@@ -306,6 +308,8 @@ namespace Eval {
         KingDangerTable[0][i] = apply_weight(make_score(t, 0), make_score(KingDanger[0], 0));
         KingDangerTable[1][i] = apply_weight(make_score(t, 0), make_score(KingDanger[1], 0));
     }
+
+    BishopPinBonus = make_score(Options["pin_open"], Options["pin_end"]);
   }
 
 
@@ -581,6 +585,11 @@ Value do_evaluate(const Position& pos, Value& margin) {
         // of threat evaluation must be done later when we have full attack info.
         if (ei.attackedBy[Them][PAWN] & s)
             score -= ThreatenedByPawnPenalty[Piece];
+        else if (Piece == BISHOP && (PseudoAttacks[Piece][pos.king_square(Them)] & s)) {
+             const Bitboard between = BetweenBB[s][pos.king_square(Them)] & pos.pieces();
+             if (!more_than_one(between))
+                 score += BishopPinBonus;
+        }
 
         // Bishop and knight outposts squares
         if (    (Piece == BISHOP || Piece == KNIGHT)
index e59a43a9148f620c7ccbc7000bd0d806fc53eda0..bc4a64814d2f747dda86c578489a46e2c249e50d 100644 (file)
@@ -87,6 +87,8 @@ void init(OptionsMap& o) {
   o["Slow Mover"]                  = Option(100, 10, 1000);
   o["UCI_Chess960"]                = Option(false);
   o["UCI_AnalyseMode"]             = Option(false, on_eval);
+  o["pin_open"] = Option(66, -100, 100, on_eval);
+  o["pin_end"] = Option(11, -100, 100, on_eval);
 }