X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fmain.cpp;h=01fb47860b092d43d837099234d56786f3c2164f;hp=9d2e1ef28c080061d0562f229c569ab5b5e0dcae;hb=fdb2242d3481116ebb5a235e5fd57b01e9f919ea;hpb=6e8bd8bf2d77eeb4414b6e533559dbda1f0211c9 diff --git a/src/main.cpp b/src/main.cpp index 9d2e1ef2..01fb4786 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -7,16 +7,18 @@ 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 . */ +// To profile with callgrind uncomment following line +//#define USE_CALLGRIND //// //// Includes @@ -39,9 +41,13 @@ #include "uci.h" #include "ucioption.h" +#ifdef USE_CALLGRIND +#include +#endif + using std::string; -//// +//// //// Functions //// @@ -52,7 +58,6 @@ int main(int argc, char *argv[]) { std::cin.rdbuf()->pubsetbuf(NULL, 0); // Initialization - init_mersenne(); init_direction_table(); init_bitboards(); @@ -64,6 +69,10 @@ int main(int argc, char *argv[]) { init_bitbases(); init_threads(); +#ifdef USE_CALLGRIND + CALLGRIND_START_INSTRUMENTATION; +#endif + // Make random number generation less deterministic, for book moves for (int i = abs(get_system_time() % 10000); i > 0; i--) genrand_int32(); @@ -71,16 +80,18 @@ int main(int argc, char *argv[]) { // Process command line arguments if (argc >= 2 && string(argv[1]) == "bench") { - if (argc < 4 || argc > 6) + if (argc < 4 || argc > 7) { - std::cout << "Usage: glaurung bench " - << "[time = 60s] [fen positions file = default]" + std::cout << "Usage: stockfish bench " + << "[time = 60s] [fen positions file = default] " + << "[time, depth or node limited = time]" << std::endl; exit(0); } string time = argc > 4 ? argv[4] : "60"; string fen = argc > 5 ? argv[5] : "default"; - benchmark(string(argv[2]) + " " + string(argv[3]) + " " + time + " " + fen); + string lim = argc > 6 ? argv[6] : "time"; + benchmark(string(argv[2]) + " " + string(argv[3]) + " " + time + " " + fen + " " + lim); return 0; }