Rev 154 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 154 | Rev 169 | ||
---|---|---|---|
Line 4... | Line 4... | ||
4 | Copyright (C) 2008-2015 Marco Costalba, Joona Kiiski, Tord Romstad |
4 | Copyright (C) 2008-2015 Marco Costalba, Joona Kiiski, Tord Romstad |
5 | Copyright (C) 2015- |
5 | Copyright (C) 2015-2018 Marco Costalba, Joona Kiiski, Gary Linscott, Tord Romstad |
6 | 6 | ||
7 | Stockfish is free software: you can redistribute it and/or modify |
7 | Stockfish is free software: you can redistribute it and/or modify |
8 | it under the terms of the GNU General Public License as published by |
8 | it under the terms of the GNU General Public License as published by |
9 | the Free Software Foundation, either version 3 of the License, or |
9 | the Free Software Foundation, either version 3 of the License, or |
10 | (at your option) any later version. |
10 | (at your option) any later version. |
Line 21... | Line 21... | ||
21 | #include <fstream> |
21 | #include <fstream> |
22 | #include <iostream> |
22 | #include <iostream> |
23 | #include <istream> |
23 | #include <istream> |
24 | #include <vector> |
24 | #include <vector> |
25 | 25 | ||
26 | #include "misc.h" |
- | |
27 | #include "position.h" |
26 | #include "position.h" |
28 | #include "search.h" |
- | |
29 | #include "thread.h" |
- | |
30 | #include "uci.h" |
- | |
31 | 27 | ||
32 | using namespace std; |
28 | using namespace std; |
33 | 29 | ||
34 | namespace { |
30 | namespace { |
35 | 31 | ||
36 | const vector<string> Defaults = { |
32 | const vector<string> Defaults = { |
- | 33 | "setoption name UCI_Chess960 value false", |
|
37 | "rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR w KQkq - 0 1", |
34 | "rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR w KQkq - 0 1", |
38 | "r3k2r/p1ppqpb1/bn2pnp1/3PN3/1p2P3/2N2Q1p/PPPBBPPP/R3K2R w KQkq - 0 10", |
35 | "r3k2r/p1ppqpb1/bn2pnp1/3PN3/1p2P3/2N2Q1p/PPPBBPPP/R3K2R w KQkq - 0 10", |
39 | "8/2p5/3p4/KP5r/1R3p1k/8/4P1P1/8 w - - 0 11", |
36 | "8/2p5/3p4/KP5r/1R3p1k/8/4P1P1/8 w - - 0 11", |
40 | "4rrk1/pp1n3p/3q2pQ/2p1pb2/2PP4/2P3N1/P2B2PP/4RRK1 b - - 7 19", |
37 | "4rrk1/pp1n3p/3q2pQ/2p1pb2/2PP4/2P3N1/P2B2PP/4RRK1 b - - 7 19", |
41 | "rq3rk1/ppp2ppp/1bnpb3/3N2B1/3NP3/7P/PPPQ1PP1/2KR3R w - - 7 14", |
38 | "rq3rk1/ppp2ppp/1bnpb3/3N2B1/3NP3/7P/PPPQ1PP1/2KR3R w - - 7 14 moves d4e6", |
42 | "r1bq1r1k/1pp1n1pp/1p1p4/4p2Q/4Pp2/1BNP4/PPP2PPP/3R1RK1 w - - 2 14", |
39 | "r1bq1r1k/1pp1n1pp/1p1p4/4p2Q/4Pp2/1BNP4/PPP2PPP/3R1RK1 w - - 2 14 moves g2g4", |
43 | "r3r1k1/2p2ppp/p1p1bn2/8/1q2P3/2NPQN2/PPP3PP/R4RK1 b - - 2 15", |
40 | "r3r1k1/2p2ppp/p1p1bn2/8/1q2P3/2NPQN2/PPP3PP/R4RK1 b - - 2 15", |
44 | "r1bbk1nr/pp3p1p/2n5/1N4p1/2Np1B2/8/PPP2PPP/2KR1B1R w kq - 0 13", |
41 | "r1bbk1nr/pp3p1p/2n5/1N4p1/2Np1B2/8/PPP2PPP/2KR1B1R w kq - 0 13", |
45 | "r1bq1rk1/ppp1nppp/4n3/3p3Q/3P4/1BP1B3/PP1N2PP/R4RK1 w - - 1 16", |
42 | "r1bq1rk1/ppp1nppp/4n3/3p3Q/3P4/1BP1B3/PP1N2PP/R4RK1 w - - 1 16", |
46 | "4r1k1/r1q2ppp/ppp2n2/4P3/5Rb1/1N1BQ3/PPP3PP/R5K1 w - - 1 17", |
43 | "4r1k1/r1q2ppp/ppp2n2/4P3/5Rb1/1N1BQ3/PPP3PP/R5K1 w - - 1 17", |
47 | "2rqkb1r/ppp2p2/2npb1p1/1N1Nn2p/2P1PP2/8/PP2B1PP/R1BQK2R b KQ - 0 11", |
44 | "2rqkb1r/ppp2p2/2npb1p1/1N1Nn2p/2P1PP2/8/PP2B1PP/R1BQK2R b KQ - 0 11", |
Line 50... | Line 47... | ||
50 | "r1q2rk1/2p1bppp/2Pp4/p6b/Q1PNp3/4B3/PP1R1PPP/2K4R w - - 2 18", |
47 | "r1q2rk1/2p1bppp/2Pp4/p6b/Q1PNp3/4B3/PP1R1PPP/2K4R w - - 2 18", |
51 | "4k2r/1pb2ppp/1p2p3/1R1p4/3P4/2r1PN2/P4PPP/1R4K1 b - - 3 22", |
48 | "4k2r/1pb2ppp/1p2p3/1R1p4/3P4/2r1PN2/P4PPP/1R4K1 b - - 3 22", |
52 | "3q2k1/pb3p1p/4pbp1/2r5/PpN2N2/1P2P2P/5PP1/Q2R2K1 b - - 4 26", |
49 | "3q2k1/pb3p1p/4pbp1/2r5/PpN2N2/1P2P2P/5PP1/Q2R2K1 b - - 4 26", |
53 | "6k1/6p1/6Pp/ppp5/3pn2P/1P3K2/1PP2P2/3N4 b - - 0 1", |
50 | "6k1/6p1/6Pp/ppp5/3pn2P/1P3K2/1PP2P2/3N4 b - - 0 1", |
54 | "3b4/5kp1/1p1p1p1p/pP1PpP1P/P1P1P3/3KN3/8/8 w - - 0 1", |
51 | "3b4/5kp1/1p1p1p1p/pP1PpP1P/P1P1P3/3KN3/8/8 w - - 0 1", |
55 | "2K5/p7/7P/5pR1/8/5k2/r7/8 w - - 0 1", |
52 | "2K5/p7/7P/5pR1/8/5k2/r7/8 w - - 0 1 moves g5g6 f3e3 g6g5 e3f3", |
56 | "8/6pk/1p6/8/PP3p1p/5P2/4KP1q/3Q4 w - - 0 1", |
53 | "8/6pk/1p6/8/PP3p1p/5P2/4KP1q/3Q4 w - - 0 1", |
57 | "7k/3p2pp/4q3/8/4Q3/5Kp1/P6b/8 w - - 0 1", |
54 | "7k/3p2pp/4q3/8/4Q3/5Kp1/P6b/8 w - - 0 1", |
58 | "8/2p5/8/2kPKp1p/2p4P/2P5/3P4/8 w - - 0 1", |
55 | "8/2p5/8/2kPKp1p/2p4P/2P5/3P4/8 w - - 0 1", |
59 | "8/1p3pp1/7p/5P1P/2k3P1/8/2K2P2/8 w - - 0 1", |
56 | "8/1p3pp1/7p/5P1P/2k3P1/8/2K2P2/8 w - - 0 1", |
60 | "8/pp2r1k1/2p1p3/3pP2p/1P1P1P1P/P5KR/8/8 w - - 0 1", |
57 | "8/pp2r1k1/2p1p3/3pP2p/1P1P1P1P/P5KR/8/8 w - - 0 1", |
Line 77... | Line 74... | ||
77 | 74 | ||
78 | // 7-man positions |
75 | // 7-man positions |
79 | "8/R7/2q5/8/6k1/8/1P5p/K6R w - - 0 124", // Draw |
76 | "8/R7/2q5/8/6k1/8/1P5p/K6R w - - 0 124", // Draw |
80 | 77 | ||
81 | // Mate and stalemate positions |
78 | // Mate and stalemate positions |
- | 79 | "6k1/3b3r/1p1p4/p1n2p2/1PPNpP1q/P3Q1p1/1R1RB1P1/5K2 b - - 0 1", |
|
- | 80 | "r2r1n2/pp2bk2/2p1p2p/3q4/3PN1QP/2P3R1/P4PP1/5RK1 w - - 0 1", |
|
82 | "8/8/8/8/8/6k1/6p1/6K1 w - -", |
81 | "8/8/8/8/8/6k1/6p1/6K1 w - -", |
83 | " |
82 | "7k/7P/6K1/8/3B4/8/8/8 b - -", |
- | 83 | ||
84 |
|
84 | // Chess 960 |
85 | " |
85 | "setoption name UCI_Chess960 value true", |
- | 86 | "bbqnnrkr/pppppppp/8/8/8/8/PPPPPPPP/BBQNNRKR w KQkq - 0 1 moves g2g3 d7d5 d2d4 c8h3 c1g5 e8d6 g5e7 f7f6", |
|
86 | " |
87 | "setoption name UCI_Chess960 value false" |
87 | }; |
88 | }; |
88 | 89 | ||
89 | } // namespace |
90 | } // namespace |
90 | 91 | ||
91 | /// |
92 | /// setup_bench() builds a list of UCI commands to be run by bench. There |
- | 93 | /// are five parameters: TT size in MB, number of search threads that |
|
92 | /// |
94 | /// should be used, the limit value spent for each position, a file name |
93 | /// |
95 | /// where to look for positions in FEN format and the type of the limit: |
- | 96 | /// depth, perft, nodes and movetime (in millisecs). |
|
- | 97 | /// |
|
94 | /// |
98 | /// bench -> search default positions up to depth 13 |
- | 99 | /// bench 64 1 15 -> search default positions up to depth 15 (TT = 64MB) |
|
95 | /// |
100 | /// bench 64 4 5000 current movetime -> search current position with 4 threads for 5 sec |
96 | /// |
101 | /// bench 64 1 100000 default nodes -> search default positions for 100K nodes each |
97 | /// |
102 | /// bench 16 1 5 default perft -> run a perft 5 on default positions |
98 | 103 | ||
99 |
|
104 | vector<string> setup_bench(const Position& current, istream& is) { |
100 | 105 | ||
101 | string token; |
- | |
102 | vector<string> |
106 | vector<string> fens, list; |
103 |
|
107 | string go, token; |
104 | 108 | ||
105 | // Assign default values to missing arguments |
109 | // Assign default values to missing arguments |
106 | string ttSize = (is >> token) ? token : "16"; |
110 | string ttSize = (is >> token) ? token : "16"; |
107 | string threads = (is >> token) ? token : "1"; |
111 | string threads = (is >> token) ? token : "1"; |
108 | string limit = (is >> token) ? token : "13"; |
112 | string limit = (is >> token) ? token : "13"; |
109 | string fenFile = (is >> token) ? token : "default"; |
113 | string fenFile = (is >> token) ? token : "default"; |
110 | string limitType = (is >> token) ? token : "depth"; |
114 | string limitType = (is >> token) ? token : "depth"; |
111 | 115 | ||
112 | Options["Hash"] = ttSize; |
- | |
113 | Options["Threads"] = threads; |
- | |
114 | Search::clear(); |
- | |
115 | - | ||
116 | if (limitType == "time") |
- | |
117 | limits.movetime = stoi(limit); // movetime is in millisecs |
- | |
118 | - | ||
119 | else if (limitType == "nodes") |
- | |
120 | limits.nodes = stoi(limit); |
- | |
121 | - | ||
122 | else if (limitType == "mate") |
- | |
123 | limits.mate = stoi(limit); |
- | |
124 | - | ||
125 | else |
- | |
126 |
|
116 | go = "go " + limitType + " " + limit; |
127 | 117 | ||
128 | if (fenFile == "default") |
118 | if (fenFile == "default") |
129 | fens = Defaults; |
119 | fens = Defaults; |
130 | 120 | ||
131 | else if (fenFile == "current") |
121 | else if (fenFile == "current") |
Line 137... | Line 127... | ||
137 | ifstream file(fenFile); |
127 | ifstream file(fenFile); |
138 | 128 | ||
139 | if (!file.is_open()) |
129 | if (!file.is_open()) |
140 | { |
130 | { |
141 | cerr << "Unable to open file " << fenFile << endl; |
131 | cerr << "Unable to open file " << fenFile << endl; |
142 |
|
132 | exit(EXIT_FAILURE); |
143 | } |
133 | } |
144 | 134 | ||
145 | while (getline(file, fen)) |
135 | while (getline(file, fen)) |
146 | if (!fen.empty()) |
136 | if (!fen.empty()) |
147 | fens.push_back(fen); |
137 | fens.push_back(fen); |
148 | 138 | ||
149 | file.close(); |
139 | file.close(); |
150 | } |
140 | } |
151 | 141 | ||
152 | uint64_t nodes = 0; |
- | |
153 |
|
142 | list.emplace_back("ucinewgame"); |
154 | Position pos; |
- | |
155 | - | ||
156 | for (size_t i = 0; i < fens.size(); ++i) |
- | |
157 | { |
- | |
158 |
|
143 | list.emplace_back("setoption name Threads value " + threads); |
159 | pos.set(fens[i], Options["UCI_Chess960"], &states->back(), Threads.main()); |
- | |
160 | - | ||
161 |
|
144 | list.emplace_back("setoption name Hash value " + ttSize); |
162 | - | ||
163 | if (limitType == "perft") |
- | |
164 | nodes += Search::perft(pos, limits.depth * ONE_PLY); |
- | |
165 | 145 | ||
- | 146 | for (const string& fen : fens) |
|
- | 147 | if (fen.find("setoption") != string::npos) |
|
- | 148 | list.emplace_back(fen); |
|
166 | else |
149 | else |
167 | { |
150 | { |
168 | limits.startTime = now(); |
- | |
169 |
|
151 | list.emplace_back("position fen " + fen); |
170 | Threads.main()->wait_for_search_finished(); |
- | |
171 |
|
152 | list.emplace_back(go); |
172 | } |
153 | } |
173 | } |
- | |
174 | - | ||
175 | elapsed = now() - elapsed + 1; // Ensure positivity to avoid a 'divide by zero' |
- | |
176 | - | ||
177 | dbg_print(); // Just before exiting |
- | |
178 | 154 | ||
179 | cerr << "\n===========================" |
- | |
180 |
|
155 | return list; |
181 | << "\nNodes searched : " << nodes |
- | |
182 | << "\nNodes/second : " << 1000 * nodes / elapsed << endl; |
- | |
183 | } |
156 | } |