X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fpawns.cpp;h=e3201081635be80e9aaa5a3520b13ff90cf3d21e;hp=658a570079509e1aee2efad52bef96c887705e8f;hb=7614501362896ddee902c1257f1b56ad148bc4d3;hpb=9c9914d72aa68ac73bec163f7aea361e42bf9be5 diff --git a/src/pawns.cpp b/src/pawns.cpp index 658a5700..e3201081 100644 --- a/src/pawns.cpp +++ b/src/pawns.cpp @@ -91,7 +91,7 @@ PawnInfoTable::PawnInfoTable() { { std::cerr << "Failed to allocate " << (PawnTableSize * sizeof(PawnInfo)) << " bytes for pawn hash table." << std::endl; - Application::exit_with_failure(); + exit(EXIT_FAILURE); } memset(entries, 0, PawnTableSize * sizeof(PawnInfo)); } @@ -172,7 +172,7 @@ Score PawnInfoTable::evaluate_pawns(const Position& pos, Bitboard ourPawns, // Passed, isolated, doubled or member of a pawn // chain (but not the backward one) ? passed = !(theirPawns & passed_pawn_mask(Us, s)); - doubled = ourPawns & squares_behind(Us, s); + doubled = ourPawns & squares_in_front_of(Us, s); opposed = theirPawns & squares_in_front_of(Us, s); isolated = !(ourPawns & neighboring_files_bb(f)); chain = ourPawns & neighboring_files_bb(f) & b; @@ -212,15 +212,10 @@ Score PawnInfoTable::evaluate_pawns(const Position& pos, Bitboard ourPawns, && (b = attack_span_mask(opposite_color(Us), s + pawn_push(Us)) & ourPawns) != EmptyBoardBB && count_1s(b) >= count_1s(attack_span_mask(Us, s) & theirPawns); - // In order to prevent doubled passed pawns from receiving a too big - // bonus, only the frontmost passed pawn on each file is considered as - // a true passed pawn. - if (passed && (ourPawns & squares_in_front_of(Us, s))) - passed = false; - // Mark the pawn as passed. Pawn will be properly scored in evaluation - // because we need full attack info to evaluate passed pawns. - if (passed) + // because we need full attack info to evaluate passed pawns. Only the + // frontmost passed pawn on each file is considered a true passed pawn. + if (passed && !doubled) set_bit(&(pi->passedPawns[Us]), s); // Score this pawn @@ -239,6 +234,5 @@ Score PawnInfoTable::evaluate_pawns(const Position& pos, Bitboard ourPawns, if (candidate) value += CandidateBonus[relative_rank(Us, s)]; } - return value; }