X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fevaluate.cpp;h=1a1334fe1e4e3f8858ba70f245c23a1b875f5851;hb=e00bb13e8540058987ccfb8006f164acfd0acdcf;hp=5a8a292f9a24c34596309562f6c86c79a29fb4c0;hpb=3b41e626668ed22d4267f7e79193d852b4d1edd1;p=stockfish diff --git a/src/evaluate.cpp b/src/evaluate.cpp index 5a8a292f..1a1334fe 100644 --- a/src/evaluate.cpp +++ b/src/evaluate.cpp @@ -651,19 +651,19 @@ Value do_evaluate(const Position& pos, Value& margin) { if ( file_of(ksq) >= FILE_E && file_of(s) > file_of(ksq) - && (relative_rank(Us, ksq) == RANK_1 || rank_of(ksq) == rank_of(s))) + && (relative_rank(Us, ksq) == RANK_1 || rank_of(ksq) == rank_of(s)) + && !ei.pi->has_open_file_to_right(Us, file_of(ksq))) { // Is there a half-open file between the king and the edge of the board? - if (!ei.pi->has_open_file_to_right(Us, file_of(ksq))) score -= make_score(pos.can_castle(Us) ? (TrappedRookPenalty - mob * 16) / 2 : (TrappedRookPenalty - mob * 16), 0); } else if ( file_of(ksq) <= FILE_D && file_of(s) < file_of(ksq) - && (relative_rank(Us, ksq) == RANK_1 || rank_of(ksq) == rank_of(s))) + && (relative_rank(Us, ksq) == RANK_1 || rank_of(ksq) == rank_of(s)) + && !ei.pi->has_open_file_to_left(Us, file_of(ksq))) { // Is there a half-open file between the king and the edge of the board? - if (!ei.pi->has_open_file_to_left(Us, file_of(ksq))) score -= make_score(pos.can_castle(Us) ? (TrappedRookPenalty - mob * 16) / 2 : (TrappedRookPenalty - mob * 16), 0); }