-
-
Notifications
You must be signed in to change notification settings - Fork 201
Usage
See below for some general information on how to use Fairy-Stockfish. If you want to share information with other users or have questions regarding Fairy-Stockfish, you are welcome to join our discord server.
For offline usage of Fairy-Stockfish, download the latest release or compile it from source and use it together with one of the GUIs listed below or any other chess variant GUI that is compatible with the supported protocols. If you are unsure which version to download, use the most compatible versions for Windows or for Linux.
Fairy-Stockfish also supports the CECP/XBoard protocol, so it can easily be used in XBoard/WinBoard. On Windows, it is recommended to use an up-to-date WinBoard version.
- Download the Fairy-Stockfish executable from the latest release.
- Download WinBoard and extract the zip archive.
- Open the Winboard folder and double click the winboard.exe.
- Click on
Engines
>Edit Engine List...
- Add one line similar to
"Fairy-SF" /variant=janggi -fcp "C:\fairy-stockfish-largeboard_x86-64.exe"
(adjust the path to where you put the .exe in step 1, and replacejanggi
by the default variant of your choice). Click oncommit changes
andOK
. - Click on
Engines
>Load New 1st Engine...
and double click on Fairy-SF. - The default variant you entered in step 5 should now be loaded automatically.
For Janggi there is a youtube video (스톡피쉬 장기 간편 설치 방법 - 업데이트) explaining the installation process in Korean, including a description how to replace the fonts of the pieces. If you do not speak Korean, turn on auto-translated subtitles.
- If an engine-defined variant uses special moves or adjudication like, e.g., Janggi,
Test Legality
underOptions
>General...
needs to be disabled or otherwise Winboard/XBoard might reject some engine moves or win claims. - You can select other variants via
File
>New Variant...
, or if the variant you are looking for is not in the list (as not all supported variants are displayed in the list) then you can enforce the variant by changing the default variant in the engine command from step 5 and redoing step 6. If you do this frequently, you can also copy&paste the entry in the variant list and create multiple entries for your favorite variants.
See this guide to compile XBoard on Linux. You can skip the --enable-zippy
flag if you do not intend to use XBoard to run an engine on ICS/FICS.
Cutechess supports many of the built-in variants supported by Fairy-Stockfish. It is very well suited for playing games (engine/human), but analysis functionality is very limited.
Engines can be added via Tools
>Settings
. Select the Engines
tab, click on +
and select the engine executable via the Browse
dialog.
PyChess also supports some of the variants, including Crazyhouse, Losers, Giveaway, Three-check, King of the Hill, ASEAN, Makruk, and Sittuyin.
Fairy-Stockfish can be used in gShogi and other USI compatible GUIs to play Shogi by adding it as a USI engine. In case of problems make sure in the engine configuration that the options Protocol
and UCI_Variant
are set to their defaults for the USI protocol, namely usi
and shogi
, respectively, and that you downloaded the large-board version (fairy-stockfish-largeboard...
).
Fairy-Stockfish also has basic support for byoyomi time controls that are supported by some Shogi GUIs.
Fairy-Stockfish can be used in Xiangqi GUIs by adding it as a UCCI engine. In case of problems make sure in the engine configuration that the options Protocol
and UCI_Variant
are set to their defaults for the UCCI protocol, namely ucci
and xiangqi
, respectively, and that you downloaded the large-board version (fairy-stockfish-largeboard...
).
On Pychess you can play various chess variants against Fairy-Stockfish, e.g., Xiangqi, Shogi, Makruk, Janggi, and more.
To play bughouse against Fairy-Stockfish on FICS, you need to set up Fairy-Stockfish with XBoard/Winboard zippy mode.
Fairy-Stockfish supports the UCI, UCCI, UCI-cyclone, USI, and CECP/XBoard protocol. A variant can be selected via the UCI_Variant
option in UCI/UCCI/USI or with the variant
command in CECP. For variants that are not supported by any GUI, the CECP protocol is the least verbose for manual use via the command line. For programmatic use, the UCI protocol is the recommended choice.
E.g., to begin a game of Kyoto shogi after starting Fairy-Stockfish, enter:
-
xboard
to set the protocol. -
variant kyotoshogi
to select the variant. - (Optional)
d
to print a board representation. - E.g.,
b1b2+
to make your first move. -
go
to ask the engine to play its first move. - Repeat steps 3.-4. in order to show the board and play moves. The engine will reply automatically to your moves once you sent one
go
command.
See https://www.gnu.org/software/xboard/engine-intf.html for more info on the CECP/XBoard protocol, e.g., on how to set the time control or the like.
-
uci
to set the protocol -
setoption name UCI_Variant value seirawan
to select the variant. -
position startpos
to set up the starting position. Note: The position command is strictly required after setting a new variant, otherwise the engine will continue to play the previously set position, i.e., also the previous variant. -
go movetime 1000
to ask the engine to search.
See http://wbec-ridderkerk.nl/html/UCIProtocol.html for the documentation of the UCI protocol.
-
usi
to set the protocol -
setoption name UCI_Variant value minishogi
to select the variant. Can be skipped for playing shogi (the default). -
position startpos
to set up the starting position. Note: The position command is strictly required after setting a new variant, otherwise the engine will continue to play the previously set position, i.e., also the previous variant. -
go movetime 1000
to ask the engine to search.
-
ucci
to set the protocol -
setoption UCI_Variant minixiangqi
to select the variant. Can be skipped for playing xiangqi (the default). -
position startpos
to set up the starting position. Note: The position command is strictly required after setting a new variant, otherwise the engine will continue to play the previously set position, i.e., also the previous variant. -
go movetime 1000
to ask the engine to search.
The UCI-cyclone protocol is supposed to be only used for Xiangqi.
-
uci
to set the protocol -
startpos
to set up the starting position. Important: Skipping theposition
keyword indicated to the engine that it should use the UCI-cyclone dialect instead of standard UCI. -
go movetime 1000
to ask the engine to search.
A python binding is also maintained in the repository and can be installed via the setup.py
or as pyffish
via pip. It can be used to query the engine for legal moves, FEN, etc. from python.
The ffishjs library also is part of this project, and can be used as a library for chess variant game logic in javascript.