X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fpawns.cpp;h=9a0059dcec379e7e64a3e20ad43525601aaa8f4d;hp=0ab1c2622f14372b39baf9f82d99e744a0a9f97a;hb=9ca4359f3691305fc5e3306c3084c83557ce09c0;hpb=7b721b3663920a2b74039ad6588ba4ed638c368b diff --git a/src/pawns.cpp b/src/pawns.cpp index 0ab1c262..9a0059dc 100644 --- a/src/pawns.cpp +++ b/src/pawns.cpp @@ -70,36 +70,6 @@ namespace { S(34,68), S(83,166), S(0, 0), S( 0, 0) }; - // Pawn storm tables for positions with opposite castling - const int QStormTable[64] = { - 0, 0, 0, 0, 0, 0, 0, 0, - -22,-22,-22,-14,-6, 0, 0, 0, - -6,-10,-10,-10,-6, 0, 0, 0, - 4, 12, 16, 12, 4, 0, 0, 0, - 16, 23, 23, 16, 0, 0, 0, 0, - 23, 31, 31, 23, 0, 0, 0, 0, - 23, 31, 31, 23, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0 - }; - - const int KStormTable[64] = { - 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0,-10,-19,-28,-33,-33, - 0, 0, 0,-10,-15,-19,-24,-24, - 0, 0, 0, 0, 1, 1, 1, 1, - 0, 0, 0, 0, 1, 10, 19, 19, - 0, 0, 0, 0, 1, 19, 31, 27, - 0, 0, 0, 0, 0, 22, 31, 22, - 0, 0, 0, 0, 0, 0, 0, 0 - }; - - // Pawn storm open file bonuses by file - const int16_t QStormOpenFileBonus[8] = { 31, 31, 18, 0, 0, 0, 0, 0 }; - const int16_t KStormOpenFileBonus[8] = { 0, 0, 0, 0, 0, 26, 42, 26 }; - - // Pawn storm lever bonuses by file - const int StormLeverBonus[8] = { -8, -8, -13, 0, 0, -13, -8, -8 }; - #undef S } @@ -120,6 +90,7 @@ PawnInfoTable::PawnInfoTable() { << " bytes for pawn hash table." << std::endl; Application::exit_with_failure(); } + memset(entries, 0, PawnTableSize * sizeof(PawnInfo)); } @@ -175,35 +146,23 @@ Score PawnInfoTable::evaluate_pawns(const Position& pos, Bitboard ourPawns, Square s; File f; Rank r; - int bonus; bool passed, isolated, doubled, opposed, chain, backward, candidate; Score value = SCORE_ZERO; + const BitCountType Max15 = CpuIs64Bit ? CNT64_MAX15 : CNT32_MAX15; const Square* ptr = pos.piece_list_begin(Us, PAWN); - // Initialize pawn storm scores by giving bonuses for open files + // Initialize halfOpenFiles[] for (f = FILE_A; f <= FILE_H; f++) if (!(ourPawns & file_bb(f))) - { - pi->ksStormValue[Us] += KStormOpenFileBonus[f]; - pi->qsStormValue[Us] += QStormOpenFileBonus[f]; pi->halfOpenFiles[Us] |= (1 << f); - } // Loop through all pawns of the current color and score each pawn while ((s = *ptr++) != SQ_NONE) { - f = square_file(s); - r = square_rank(s); - assert(pos.piece_on(s) == piece_of_color_and_type(Us, PAWN)); - // Calculate kingside and queenside pawn storm scores for both colors to be - // used when evaluating middle game positions with opposite side castling. - bonus = (f >= FILE_F ? evaluate_pawn_storm(s, r, f, theirPawns) : 0); - pi->ksStormValue[Us] += KStormTable[relative_square(Us, s)] + bonus; - - bonus = (f <= FILE_C ? evaluate_pawn_storm(s, r, f, theirPawns) : 0); - pi->qsStormValue[Us] += QStormTable[relative_square(Us, s)] + bonus; + f = square_file(s); + r = square_rank(s); // Our rank plus previous one. Used for chain detection. b = rank_bb(r) | rank_bb(Us == WHITE ? r - Rank(1) : r + Rank(1)); @@ -249,7 +208,7 @@ Score PawnInfoTable::evaluate_pawns(const Position& pos, Bitboard ourPawns, // Test for candidate passed pawn candidate = !(opposed | passed) && (b = attack_span_mask(opposite_color(Us), s + pawn_push(Us)) & ourPawns) != EmptyBoardBB - && count_1s_max_15(b) >= count_1s_max_15(attack_span_mask(Us, s) & theirPawns); + && 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 @@ -288,59 +247,3 @@ Score PawnInfoTable::evaluate_pawns(const Position& pos, Bitboard ourPawns, return value; } - -/// PawnInfoTable::evaluate_pawn_storm() evaluates each pawn which seems -/// to have good chances of creating an open file by exchanging itself -/// against an enemy pawn on an adjacent file. - -template -int PawnInfoTable::evaluate_pawn_storm(Square s, Rank r, File f, Bitboard theirPawns) const { - - const Bitboard StormFilesBB = (Side == KingSide ? FileFBB | FileGBB | FileHBB - : FileABB | FileBBB | FileCBB); - const int K = (Side == KingSide ? 2 : 4); - const File RookFile = (Side == KingSide ? FILE_H : FILE_A); - - Bitboard b = attack_span_mask(Us, s) & theirPawns & StormFilesBB; - int bonus = 0; - - while (b) - { - // Give a bonus according to the distance of the nearest enemy pawn - Square s2 = pop_1st_bit(&b); - Rank r2 = square_rank(s2); - int v = StormLeverBonus[f] - K * rank_distance(r, r2); - - // If enemy pawn has no pawn beside itself is particularly vulnerable. - // Big bonus, especially against a weakness on the rook file - if (!(theirPawns & neighboring_files_bb(s2) & rank_bb(s2))) - v *= (square_file(s2) == RookFile ? 4 : 2); - - bonus += v; - } - return bonus; -} - - -/// PawnInfo::updateShelter calculates and caches king shelter. It is called -/// only when king square changes, about 20% of total king_shelter() calls. -Score PawnInfo::updateShelter(const Position& pos, Color c, Square ksq) { - - Bitboard pawns; - unsigned r, k, shelter = 0; - - if (relative_rank(c, ksq) <= RANK_4) - { - pawns = pos.pieces(PAWN, c) & this_and_neighboring_files_bb(ksq); - r = ksq & (7 << 3); - k = (c ? -8 : 8); - for (int i = 1; i < 4; i++) - { - r += k; - shelter += BitCount8Bit[(pawns >> r) & 0xFF] * (128 >> i); - } - } - kingSquares[c] = ksq; - kingShelters[c] = make_score(shelter, 0); - return kingShelters[c]; -}