/*
Stockfish, a UCI chess playing engine derived from Glaurung 2.1
- Copyright (C) 2004-2020 The Stockfish developers (see AUTHORS file)
+ Copyright (C) 2004-2023 The Stockfish developers (see AUTHORS file)
Stockfish is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
#include "position.h"
#include "types.h"
-namespace Material {
+namespace Stockfish::Material {
/// Material::Entry contains various information about a material configuration.
/// It contains a material imbalance evaluation, a function pointer to a special
-/// endgame evaluation function (which in most cases is NULL, meaning that the
+/// endgame evaluation function (which in most cases is nullptr, meaning that the
/// standard evaluation function will be used), and scale factors.
///
/// The scale factors are used to scale the evaluation score up or down. For
struct Entry {
- Score imbalance() const { return make_score(value, value); }
- Phase game_phase() const { return gamePhase; }
+ Score imbalance() const { return score; }
+ Phase game_phase() const { return (Phase)gamePhase; }
bool specialized_eval_exists() const { return evaluationFunction != nullptr; }
Value evaluate(const Position& pos) const { return (*evaluationFunction)(pos); }
const EndgameBase<Value>* evaluationFunction;
const EndgameBase<ScaleFactor>* scalingFunction[COLOR_NB]; // Could be one for each
// side (e.g. KPKP, KBPsK)
- int16_t value;
+ Score score;
+ int16_t gamePhase;
uint8_t factor[COLOR_NB];
- Phase gamePhase;
};
-typedef HashTable<Entry, 8192> Table;
+using Table = HashTable<Entry, 8192>;
Entry* probe(const Position& pos);
-} // namespace Material
+} // namespace Stockfish::Material
#endif // #ifndef MATERIAL_H_INCLUDED