X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fpawns.h;h=684697acb1738846226910bafb5a3f79813ece39;hp=9dc08a669e1a63e24d9f47e2053aa0d3f19061c2;hb=548bae80bd1f04526667ddeeaf8f5f065c53b096;hpb=23ceb6695073cef741253ab175fabfde48415463 diff --git a/src/pawns.h b/src/pawns.h index 9dc08a66..684697ac 100644 --- a/src/pawns.h +++ b/src/pawns.h @@ -45,12 +45,12 @@ class PawnInfo { friend class PawnInfoTable; public: - PawnInfo() : key(0) { clear(); } + PawnInfo() { clear(); } - Value mg_value() const; - Value eg_value() const; + Score pawns_value() const; Value kingside_storm_value(Color c) const; Value queenside_storm_value(Color c) const; + Bitboard pawn_attacks(Color c) const; Bitboard passed_pawns() const; int file_is_half_open(Color c, File f) const; int has_open_file_to_left(Color c, File f) const; @@ -63,7 +63,8 @@ private: Key key; Bitboard passedPawns; - int16_t mgValue, egValue; + Bitboard pawnAttacks[2]; + Score value; int16_t ksStormValue[2], qsStormValue[2]; uint8_t halfOpenFiles[2]; Square kingSquares[2]; @@ -83,6 +84,9 @@ public: PawnInfo* get_pawn_info(const Position& pos); private: + template + Score evaluate_pawns(const Position& pos, Bitboard ourPawns, Bitboard theirPawns, PawnInfo* pi); + unsigned size; PawnInfo* entries; }; @@ -92,18 +96,18 @@ private: //// Inline functions //// -inline Value PawnInfo::mg_value() const { - return Value(mgValue); -} - -inline Value PawnInfo::eg_value() const { - return Value(egValue); +inline Score PawnInfo::pawns_value() const { + return value; } inline Bitboard PawnInfo::passed_pawns() const { return passedPawns; } +inline Bitboard PawnInfo::pawn_attacks(Color c) const { + return pawnAttacks[c]; +} + inline Value PawnInfo::kingside_storm_value(Color c) const { return Value(ksStormValue[c]); }