UCI协议:修订间差异
无编辑摘要 |
无编辑摘要 |
||
第57行: | 第57行: | ||
引擎不会输出任何内容。 | 引擎不会输出任何内容。 | ||
== d == | |||
输出当前的局面、局面FEN、key信息和将军信息。 | |||
== eval == | |||
输出当前局面的评估信息。 |
2024年4月9日 (二) 08:29的版本
本页面正在施工中...
quit
退出引擎,输入后引擎将立即退出。引擎不会输出任何内容。
setoption
设置引擎选项,用法:setoption name <id> [value <x>]。
其中,<id>是UCI选项名,<x>是你要设置的值。
例如界面要将引擎的线程数设置为16,可发送“setoption name Threads value 16”。
某些选项,如Clear Hash(清空置换表),可省略value直接使用,例如:“setoption name Clear Hash”。
关于UCI选项,详见“UCI选项”页面,这里不再赘述。
引擎不会输出任何内容。
isready
用于检查引擎是否工作正常,引擎应始终输出“readyok”。
uci
用于获取引擎相关信息(如名称、作者、UCI选项等),输出示例如下:
id name Pikafish 2024-02-18 id author the Pikafish developers (see AUTHORS file)
option name Debug Log File type string default option name Threads type spin default 1 min 1 max 1024 option name Hash type spin default 16 min 1 max 33554432 option name Clear Hash type button option name Ponder type check default false option name MultiPV type spin default 1 min 1 max 128 ... uciok
其中,“uciok”是必需的。如果界面输入uci后,没有接收到引擎输出的“uciok”,那么界面会认为该程序不是UCI引擎。
[position] fen
给引擎输入FEN局面。
例如:
position fen 3k1a3/4a4/5n3/9/9/9/9/9/9/4KR3 w
或者在此基础上加上movelist(历史着法):
5a3/3ka4/5n3/9/9/9/9/9/9/4K1R2 w - - 0 1 moves g0f0 d8d9
注意,中国象棋引擎采用的是UCI-Cyclone,可以省略position,且表示行的数字从0开始。
引擎不会输出任何内容。
[position] startpos
设置当前局面为起始局面(rnbakabnr/9/1c5c1/p1p1p1p1p/9/9/P1P1P1P1P/1C5C1/9/RNBAKABNR w),“position”可省略。
引擎不会输出任何内容。
d
输出当前的局面、局面FEN、key信息和将军信息。
eval
输出当前局面的评估信息。