From: Marco Costalba Date: Thu, 15 Apr 2010 13:54:44 +0000 (+0200) Subject: Add "Best Book Move" UCI option X-Git-Url: https://git.sesse.net/?p=stockfish;a=commitdiff_plain;h=94bb1964f6b5b4b9abca0bde03367d071922f449;hp=13431922a3c732f9cf1e28364d91c1b0c2a45e7f Add "Best Book Move" UCI option Is a boolean option that when set allows Stockfish to select the best book move across the possible ones. Feature requested by Salvo Spitaleri. No functional change. Signed-off-by: Marco Costalba --- diff --git a/src/book.cpp b/src/book.cpp index 20861988..dbd03788 100644 --- a/src/book.cpp +++ b/src/book.cpp @@ -399,14 +399,15 @@ const string Book::file_name() { // Not const to compile on HP-UX 11.X /// Book::get_move() gets a book move for a given position. Returns /// MOVE_NONE if no book move is found. -Move Book::get_move(const Position& pos) { +Move Book::get_move(const Position& pos, bool findBestMove) { if (!is_open() || bookSize == 0) return MOVE_NONE; - int bookMove = 0, scoresSum = 0; - uint64_t key = book_key(pos); BookEntry entry; + int bookMove = MOVE_NONE; + int scoresSum = 0, bestScore = 0; + uint64_t key = book_key(pos); // Choose a book move among the possible moves for the given position for (int idx = find_key(key); idx < bookSize; idx++) @@ -419,6 +420,17 @@ Move Book::get_move(const Position& pos) { assert(score > 0); + // If findBestMove is true choose highest rated book move + if (findBestMove) + { + if (score > bestScore) + { + bestScore = score; + bookMove = entry.move; + } + continue; + } + // Choose book move according to its score. If a move has a very // high score it has more probability to be choosen then a one with // lower score. Note that first entry is always chosen. diff --git a/src/book.h b/src/book.h index 9e775ede..32b6e607 100644 --- a/src/book.h +++ b/src/book.h @@ -61,7 +61,7 @@ public: void open(const std::string& fName); void close(); const std::string file_name(); - Move get_move(const Position& pos); + Move get_move(const Position& pos, bool findBestMove); private: Book& operator>>(uint64_t& n) { n = read_integer(8); return *this; } diff --git a/src/search.cpp b/src/search.cpp index fff523c3..0e65d19f 100644 --- a/src/search.cpp +++ b/src/search.cpp @@ -387,7 +387,7 @@ bool think(const Position& pos, bool infinite, bool ponder, int side_to_move, if (get_option_value_string("Book File") != OpeningBook.file_name()) OpeningBook.open(get_option_value_string("Book File")); - Move bookMove = OpeningBook.get_move(pos); + Move bookMove = OpeningBook.get_move(pos, get_option_value_bool("Best Book Move")); if (bookMove != MOVE_NONE) { if (PonderSearch) diff --git a/src/ucioption.cpp b/src/ucioption.cpp index 154e1410..990c748c 100644 --- a/src/ucioption.cpp +++ b/src/ucioption.cpp @@ -79,6 +79,7 @@ namespace { o["Use Search Log"] = Option(false); o["Search Log Filename"] = Option("SearchLog.txt"); o["Book File"] = Option("book.bin"); + o["Best Book Move"] = Option(false); o["Mobility (Middle Game)"] = Option(100, 0, 200); o["Mobility (Endgame)"] = Option(100, 0, 200); o["Pawn Structure (Middle Game)"] = Option(100, 0, 200);