Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/raklaptudirm/ucim
The UCI-iMproved Protocol Specification for Chess Engine Communication
https://github.com/raklaptudirm/ucim
chess chess-engine communication protocol specification
Last synced: 20 days ago
JSON representation
The UCI-iMproved Protocol Specification for Chess Engine Communication
- Host: GitHub
- URL: https://github.com/raklaptudirm/ucim
- Owner: raklaptudirm
- Created: 2023-07-13T18:04:11.000Z (over 1 year ago)
- Default Branch: master
- Last Pushed: 2023-07-20T09:37:28.000Z (over 1 year ago)
- Last Synced: 2024-10-11T20:20:07.828Z (3 months ago)
- Topics: chess, chess-engine, communication, protocol, specification
- Homepage:
- Size: 13.7 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Foreword
UCI protocol is the most popular protocol used by chess engines to communicate with GUIs. However, it has been the opinion of
a lot of engine developers that the protocol is one of the worst software communication protocols ever drafted. Some of the
biggest issues with UCI is fuzzy command matching, optional commands, and garantees of statelessness when it isn't in any way
stateless. In fact, a stateless protocol is an **extremely** bad idea for a chess engine.However, due to the enormous userbase of the protocol, switching over to a better protocol is a herculean task. There is also
the issue of standard proliferation, and creation of GUIs supporting the new standard.Therefore UCiM tries to improve upon the UCI protocol, trying to remain backwards compatible wherever possible. However
all the bad design decisions are not supported, so something like `joho go` is no longer a valid command, even though
the go command is supported by UCiM. Most of the places where the backwards compatibility garuntee is broken,
the new version is the de facto standard used by the community. For example, no popular GUI exploits the fuzzy command
matching of UCI and sends commands like `joho debug on`. Therefore, most engines should already be UCiM compliant to a
high percentage.UCiM also adds specifications for important things that UCI doesn't handle, like error reporting.
# Description of the UCIM Standard
- Specification is independent of Operating System.
- All communication is done by the standard input and output streams.
- An engine to enable all UCIM functions on receiving the uci command.
- All command strings sent by both the engine and the GUI should end with `\n`.
- UCIM is an extension of the UCI standard, with some new features added and some old features removed from the new standard.# UCIM Commands
- A command comprises tokens separated by arbitrary whitespace tokens, that is space and tab characters.
- The first token in a command is the command name.
- Each command can accept a variety of flags, which are in the format ` [args]...`
- Errors in the commands from GUIs should not be ignored and should be reported using the `info error ` command.## Command Specification Syntax
- All command syntax definitions start with the name of the command.
- Following the name, the different flags supported by the command are specified.
- () are used for grouping flags. & and | can be used inside groupings to specify relationships between flags. For example `( fen | startpos )` implies only one of the `fen` and `startpos` flags must be present at any given time.
- [] are used to specify optional flags. Flags inside the [] may or may not be present in the command. [] also acts similar to (), and can be used for grouping flags.
- Commands can have 3 types of arguments excluding the no arguments case (boolean flag): single argument, a fixed number of arguments and variadic arguments.
- Single arguments are specified using the syntax `<>`. For example: `name `.
- A fixed number of arguments are specified using the syntax `<>...`, where n is the number of arguments. For example: `fen ...6`.
- Variadic flags may only be present as the last flag in the command. All tokens following the variadic flag are consumed as its arguments. They are specified using the syntax `<>...`. For example: `moves ...`# Commands: GUI to Engine
## uci
```
uci
```Tells the engine to switch to UCIM mode. The command name has been kept consistent with the UCI standard so that UCIM is backwards compatible.
After receiving the uci command, an engine **must** identify itself with the id command.
After completing any necessary setup steps, the engine should send the uciok command to indicate that it is ready to be used.
## isready
```
isready
```Used to synchronize the GUI with the engine. This command is usually sent when the GUI has assigned the engine with a time-consuming task and needs to wait for it to finish. This command can also check if an engine is still alive.
The engine must answer the isready command with readyok as soon as it's ready to receive and parse commands, including when it's searching.
## setoption
```
setoption name [ value ... ]
```Tells the engine to set one of its internal parameters named `name` to `value`. The `value` flag can be dropped when setting a boolean option.
The name of the option **must** be a single token.
`value` can consist of multiple tokens only in the case of a `string` option.
## ucinewgame
```
ucinewgame
```Used to signal to the engine that the next position is from a different game compared to the current position.
The GUI **must** send this command when sending a position from a new game, and thus engines can depend on this command.
The engine may spend some time setting up after receiving this command, so the GUI **must** send an isready command following this.
## position
```
position ( fen ...6 | startpos ) [ moves ... ]
```Sets up the given position in the engine's internal board. First, the given fen is setup, and then the provided moves are
played in the given order. `startpos` is equivalent to `fen rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR w KQkq - 0 1`
The GUI **MUST** send this command before setting up a position from a new game.## go
```
go [ infinite | ponder | wtime btime [ winc binc ] [ movestogo ] ]
[ depth ] [ nodes ] [ mate ] [ movetime ] [ searchmoves ... ]
```Start calculating on the current internal position. Provided flags can be separated into two types, search type flags, and
limit flags.`infinite`, `ponder`, and `wtime and others` are search type flags.
- `infinite` should start an infinite search, where the search doesn't exit till the stop command, even when mate is found.
- `ponder` should start a ponder search, where search exits on the ponderhit command.
- `wtime and others` should start a normal time bound search.
- `wtime` and `btime` are the time remaining in milliseconds for white and black respectively.
- `winc` and `binc` are the increments per moves for white and black respectively.
- `movestogo` is the number of moves remaining till the next time control.
- If no search type flags are provided, an infinite search is started which exits when search is "complete".`depth`, `nodes`, `mate`, `movetime`, and `searchmoves` are limit flags.
- `depth` sets the maximum depth limit. Search should exit on reaching that depth.
- `nodes` sets the maximum nodes limit. It is a soft limit and can be exceeded, but immidiate exit is reccommended.
- `mate` sets the mate finding limit. Search should exit when a mate equal to or shorter than the provided number of moves is found.
- `movetime` sets the time to be used for searching. Search should exit on exceeding the allocated time.
- `searchmoves` sets the move searching limits. Only the provided moves should be searched at root.## stop
```
stop
```Stops calculating as soon as possible. bestmove command is sent on exit.
## ponderhit
```
ponderhit
```Opponent has played the move the engine was pondering on. Switch to a normal search from the ponder search.
## quit
```
quit
```Quit the program as soon as possible.