X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fpawns.cpp;h=52bc9f88eea5eb031931cfe1aa17dce81fde575e;hp=3ad88fb206aa011ece4fb6dca4c75acf17edb758;hb=ed04c010eb4a569532f322f5030d468380b3ab57;hpb=8447248705bc6cf91fc8cdbb519c31925862ea74 diff --git a/src/pawns.cpp b/src/pawns.cpp index 3ad88fb2..52bc9f88 100644 --- a/src/pawns.cpp +++ b/src/pawns.cpp @@ -79,8 +79,6 @@ namespace { PawnInfo* PawnInfoTable::get_pawn_info(const Position& pos) const { - assert(pos.is_ok()); - Key key = pos.get_pawn_key(); PawnInfo* pi = probe(key); @@ -127,15 +125,15 @@ Score PawnInfoTable::evaluate_pawns(const Position& pos, Bitboard ourPawns, Rank r; bool passed, isolated, doubled, opposed, chain, backward, candidate; Score value = SCORE_ZERO; - const Square* ptr = pos.piece_list_begin(Us, PAWN); + const Square* pl = pos.piece_list(Us, PAWN); // Loop through all pawns of the current color and score each pawn - while ((s = *ptr++) != SQ_NONE) + while ((s = *pl++) != SQ_NONE) { assert(pos.piece_on(s) == make_piece(Us, PAWN)); - f = square_file(s); - r = square_rank(s); + f = file_of(s); + r = rank_of(s); // This file cannot be half open pi->halfOpenFiles[Us] &= ~(1 << f); @@ -230,7 +228,7 @@ Score PawnInfo::updateShelter(const Position& pos, Square ksq) { for (int i = 0; i < 3; i++) { r += Shift; - shelter += BitCount8Bit[(pawns >> r) & 0xFF] * (64 >> i); + shelter += BitCount8Bit[(pawns >> r) & 0xFF] << (6 - i); } } kingSquares[Us] = ksq;