31337fa676ef9fba1de2c99d4f3ade7bf7bde8d2
[stockfish] / src / main.cpp
1 /*
2   Stockfish, a UCI chess playing engine derived from Glaurung 2.1
3   Copyright (C) 2004-2008 Tord Romstad (Glaurung author)
4   Copyright (C) 2008-2012 Marco Costalba, Joona Kiiski, Tord Romstad
5
6   Stockfish is free software: you can redistribute it and/or modify
7   it under the terms of the GNU General Public License as published by
8   the Free Software Foundation, either version 3 of the License, or
9   (at your option) any later version.
10
11   Stockfish is distributed in the hope that it will be useful,
12   but WITHOUT ANY WARRANTY; without even the implied warranty of
13   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14   GNU General Public License for more details.
15
16   You should have received a copy of the GNU General Public License
17   along with this program.  If not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #include <iostream>
21 #include <string>
22
23 #include "bitboard.h"
24 #include "evaluate.h"
25 #include "position.h"
26 #include "search.h"
27 #include "thread.h"
28 #include "ucioption.h"
29
30 using namespace std;
31
32 extern void uci_loop();
33 extern void benchmark(int argc, char* argv[]);
34 extern void kpk_bitbase_init();
35
36 int main(int argc, char* argv[]) {
37
38   // Don't sync with C library I/O buffers, faster but now using printf()
39   // or scanf() could yield to issues because buffers are independent.
40   cout.sync_with_stdio(false);
41   cin.sync_with_stdio(false);
42
43   cout << engine_info() << endl;
44
45   bitboards_init();
46   Position::init();
47   kpk_bitbase_init();
48   Search::init();
49   Threads.init();
50   Eval::init();
51   TT.set_size(Options["Hash"]);
52
53   if (argc == 1)
54       uci_loop();
55
56   else if (string(argv[1]) == "bench")
57       benchmark(argc, argv);
58
59   else
60       cerr << "\nUsage: stockfish bench [hash size = 128] [threads = 1] "
61            << "[limit = 12] [fen positions file = default] "
62            << "[limited by depth, time, nodes or perft = depth]" << endl;
63
64   Threads.exit();
65 }