X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fpawns.cpp;h=1ccc0958ca432e870629231b9676651f4765710b;hp=74b3fd5e5d9c473f32ead6551ba5163931c52562;hb=20023ac9b8c28d8b15308d7bf5be4fad8501535d;hpb=16c603ce9baa464c2f59cbd001987ec3a7cbc01f diff --git a/src/pawns.cpp b/src/pawns.cpp index 74b3fd5e..1ccc0958 100644 --- a/src/pawns.cpp +++ b/src/pawns.cpp @@ -124,7 +124,7 @@ namespace { opposed = theirPawns & forward_bb(Us, s); stoppers = theirPawns & passed_pawn_mask(Us, s); lever = theirPawns & pawnAttacksBB[s]; - doubled = ourPawns & forward_bb(Us, s); + doubled = ourPawns & (s + Up); neighbours = ourPawns & adjacent_files_bb(f); phalanx = neighbours & rank_bb(s); supported = neighbours & rank_bb(s - Up); @@ -150,7 +150,7 @@ namespace { // Passed pawns will be properly scored in evaluation because we need // full attack info to evaluate them. Only the frontmost passed // pawn on each file is considered a true passed pawn. - if (!(stoppers | doubled)) + if (!(stoppers | doubled)) // FIXME this is just doubled by adjacent pawn e->passedPawns[Us] |= s; // Score this pawn @@ -167,7 +167,7 @@ namespace { score += Connected[opposed][!!phalanx][more_than_one(supported)][relative_rank(Us, s)]; if (doubled) - score -= Doubled / distance(s, frontmost_sq(Us, doubled)); + score -= Doubled; if (lever) score += Lever[relative_rank(Us, s)];