Як вже говорили інші, UCI - це той API, який ви хочете. Повні характеристики протоколу наведені тут (zip-файл витягується до текстового файлу): http://download.shredderchess.com/div/uci.zip
Це насправді дуже прямо і просто, двигун UCI повинен відповідати і відповідати простим текстом через stdin, stdout та stderr. Насправді ви повинні мати можливість запустити виконуваний двійковий файл будь-якого двигуна UCI на вашій платформі та видавати команди UCI вручну.
UCI полегшує вказівки від GUI чи іншого двигуна, щоб вказати конкретному двигуну робити все, що ви хочете зробити, включаючи аналіз конкретного PGN-файлу (завантаження його здійснюється через GUI або подібний фронт-інтерфейс, необроблені рухи потім подаються в двигун у розширеній алгебраїчній формі, наприклад, e4 стає e2e4). Другий та третій пункти ваших вимог є стандартними для UCI, але кожен розробник двигуна повинен їх підтримувати (враховуючи, наскільки вимогливі такі вимоги, таких повинно бути більшість).
Ось приклад UCI в дії в командному рядку:
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$
Команди, які я видав, були uci, готовими і кинутими.
Для використання команд UCI у вас є два основні варіанти; ви можете використовувати наявний інтерфейс (наприклад, ChessX, Arena та безліч інших) або написати власний код, щоб видавати інструкції двигуну чи групі двигунів. Я вважаю, що вже можуть бути обгортки Python для доступу до двигунів UCI, але мені потрібно ще раз перевірити. Виразно є python-chess (імпорт шахів) та pychess (import pychess), я просто не можу згадати ступінь їхніх функцій. Я не можу пригадати, де ховається pychess (можливо, код github чи google), але python-chess можна встановити за допомогою pip.