Jak powiedzieli inni, UCI jest interfejsem API, którego potrzebujesz. Pełna specyfikacja protokołu znajduje się tutaj (plik zip wypakowuje do pliku tekstowego): http://download.shredderchess.com/div/uci.zip
Jest to bardzo proste i proste, silnik UCI musi odpowiadać i odpowiadać zwykłym tekstem poprzez stdin, stdout i stderr. W rzeczywistości powinieneś być w stanie uruchomić wykonywalny plik binarny dowolnego silnika UCI na swojej platformie i ręcznie wydawać polecenia UCI.
UCI ułatwia instrukcje z GUI lub innego silnika, aby powiedzieć konkretnemu silnikowi, aby zrobił wszystko, co chcesz, w tym analizować konkretny plik PGN (ładowanie odbywa się za pomocą GUI lub podobnego interfejsu, surowe ruchy są następnie podawane do silnika w rozszerzonej formie algebraicznej, np. e4 staje się e2e4). Drugi i trzeci punkt twoich wymagań są standardowe w UCI, ale każdy deweloper silnika musi je wspierać (biorąc pod uwagę, jak wąskie są te wymagania, powinno to być większość z nich).
Oto przykład działania UCI w wierszu poleceń:
bash-3.2$ ./stockfish-5-64
Stockfish 5 64 by Tord Romstad, Marco Costalba and Joona Kiiski
uci
id name Stockfish 5 64
id author Tord Romstad, Marco Costalba and Joona Kiiski
option name Write Debug Log type check default false
option name Write Search Log type check default false
option name Search Log Filename type string default SearchLog.txt
option name Book File type string default book.bin
option name Best Book Move type check default false
option name Contempt Factor type spin default 0 min -50 max 50
option name Mobility (Midgame) type spin default 100 min 0 max 200
option name Mobility (Endgame) type spin default 100 min 0 max 200
option name Pawn Structure (Midgame) type spin default 100 min 0 max 200
option name Pawn Structure (Endgame) type spin default 100 min 0 max 200
option name Passed Pawns (Midgame) type spin default 100 min 0 max 200
option name Passed Pawns (Endgame) type spin default 100 min 0 max 200
option name Space type spin default 100 min 0 max 200
option name Aggressiveness type spin default 100 min 0 max 200
option name Cowardice type spin default 100 min 0 max 200
option name Min Split Depth type spin default 0 min 0 max 12
option name Threads type spin default 1 min 1 max 128
option name Hash type spin default 32 min 1 max 16384
option name Clear Hash type button
option name Ponder type check default true
option name OwnBook type check default false
option name MultiPV type spin default 1 min 1 max 500
option name Skill Level type spin default 20 min 0 max 20
option name Emergency Move Horizon type spin default 40 min 0 max 50
option name Emergency Base Time type spin default 60 min 0 max 30000
option name Emergency Move Time type spin default 30 min 0 max 5000
option name Minimum Thinking Time type spin default 20 min 0 max 5000
option name Slow Mover type spin default 80 min 10 max 1000
option name UCI_Chess960 type check default false
uciok
isready
readyok
quit
bash-3.2$
Polecenia, które wydałem, to uci, już gotowe i zakończ.
Aby użyć poleceń UCI, zasadniczo masz dwie główne opcje; możesz użyć istniejącego interfejsu (np. ChessX, Arena i wielu innych) lub możesz napisać własny kod do wydawania instrukcji do silnika lub grupy silników. Wierzę, że mogą już istnieć opakowania Pythona do uzyskiwania dostępu do silników UCI, ale musiałbym dwukrotnie sprawdzić. Zdecydowanie są szachy pytona (szachy importowe) i szachy (importowe szachy), po prostu nie pamiętam zakresu ich funkcji. Nie pamiętam, gdzie czai się pychess (prawdopodobnie github lub kod Google), ale szachy python można zainstalować za pomocą pip.