mirror of
https://github.com/HChaZZY/Stockfish.git
synced 2025-12-26 20:16:14 +08:00
This patch corrects both MultiPV behaviour and "go searchmoves" behaviour for tablebases. We change the logic of table base probing at root positions from filtering to ranking. The ranking code is much more straightforward than the current filtering code (this is a simplification), and also more versatile. If the root is a TB position, each root move is probed and assigned a TB score and a TB rank. The TB score is the Value to be displayed to the user for that move (unless the search finds a mate score), while the TB rank determines which moves should appear higher in a multi-pv search. In game play, the engine will always pick a move with the highest rank. Ranks run from -1000 to +1000: 901 to 1000 : TB win 900 : normally a TB win, in rare cases this could be a draw 1 to 899 : cursed TB wins 0 : draw -1 to -899 : blessed TB losses -900 : normally a TB loss, in rare cases this could be a draw -901 to -1000 : TB loss Normally all winning moves get rank 1000 (to let the search pick the best among them). The exception is if there has been a first repetition. In that case, moves are ranked strictly by DTZ so that the engine will play a move that lowers DTZ (and therefore cannot repeat the position a second time). Losing moves get rank -1000 unless they have relatively high DTZ, meaning they have some drawing chances. Those get ranks towards -901 (when they cross -900 the draw is certain). Closes https://github.com/official-stockfish/Stockfish/pull/1467 No functional change (without tablebases).
80 lines
2.4 KiB
C++
80 lines
2.4 KiB
C++
/*
|
|
Stockfish, a UCI chess playing engine derived from Glaurung 2.1
|
|
Copyright (c) 2013 Ronald de Man
|
|
Copyright (C) 2016-2018 Marco Costalba, Lucas Braesch
|
|
|
|
Stockfish is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
Stockfish is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef TBPROBE_H
|
|
#define TBPROBE_H
|
|
|
|
#include <ostream>
|
|
|
|
#include "../search.h"
|
|
|
|
namespace Tablebases {
|
|
|
|
enum WDLScore {
|
|
WDLLoss = -2, // Loss
|
|
WDLBlessedLoss = -1, // Loss, but draw under 50-move rule
|
|
WDLDraw = 0, // Draw
|
|
WDLCursedWin = 1, // Win, but draw under 50-move rule
|
|
WDLWin = 2, // Win
|
|
|
|
WDLScoreNone = -1000
|
|
};
|
|
|
|
// Possible states after a probing operation
|
|
enum ProbeState {
|
|
FAIL = 0, // Probe failed (missing file table)
|
|
OK = 1, // Probe succesful
|
|
CHANGE_STM = -1, // DTZ should check the other side
|
|
ZEROING_BEST_MOVE = 2 // Best move zeroes DTZ (capture or pawn move)
|
|
};
|
|
|
|
extern int MaxCardinality;
|
|
|
|
void init(const std::string& paths);
|
|
WDLScore probe_wdl(Position& pos, ProbeState* result);
|
|
int probe_dtz(Position& pos, ProbeState* result);
|
|
bool root_probe(Position& pos, Search::RootMoves& rootMoves);
|
|
bool root_probe_wdl(Position& pos, Search::RootMoves& rootMoves);
|
|
void rank_root_moves(Position& pos, Search::RootMoves& rootMoves);
|
|
|
|
inline std::ostream& operator<<(std::ostream& os, const WDLScore v) {
|
|
|
|
os << (v == WDLLoss ? "Loss" :
|
|
v == WDLBlessedLoss ? "Blessed loss" :
|
|
v == WDLDraw ? "Draw" :
|
|
v == WDLCursedWin ? "Cursed win" :
|
|
v == WDLWin ? "Win" : "None");
|
|
|
|
return os;
|
|
}
|
|
|
|
inline std::ostream& operator<<(std::ostream& os, const ProbeState v) {
|
|
|
|
os << (v == FAIL ? "Failed" :
|
|
v == OK ? "Success" :
|
|
v == CHANGE_STM ? "Probed opponent side" :
|
|
v == ZEROING_BEST_MOVE ? "Best move zeroes DTZ" : "None");
|
|
|
|
return os;
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|