Skip to content

Python scripts to manipulate and provide mating PVs for Chest-like EPD files. Includes a collection of 1m proven mates.

License

Notifications You must be signed in to change notification settings

robertnurnberg/matetools

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

matetools

A collection of Python scripts to manipulate and provide mating PVs for Chest-like EPD files. Such files store chess mate puzzles in the form

<FEN>' bm #'<bm>';'{<comments>}

Here FEN usually means just the first four fields of a standard FEN, and bm is a nonzero integer that indicates the (currently) fastest known mate for the given position, assuming best play from both sides.

The aim of the scripts in the repo is to convert such collections of puzzles into the format

<FEN>' bm #'<bm>';'{' PV: '<PV>}';'{<comments>}

where PV is a proven PV for the claimed mate. A compressed collection of 1 million proven mates is provided in fishmates.epd.gz.

Scripts

The following scripts are provided:

  • addpvs.py: adds (missing) PVs to a given EPD file using a local engine (the script uses concurrency, results are available once all positions have been processed)
  • advancepvs.py: advances a number of plies in the given PVs to create new puzzles
  • deducepvs.py: uses proven PVs, and the associated PVs for all the positions along the mating lines, to find possibly missing PVs
  • diffmates.py: compares two Chest-like EPD files
  • filterpvs.py: filters positions by the status of their PVs
  • matestats.py: generates a distribution plot for the bm values found in a given EPD file
  • matetb.py: constructs the PV for a single EPD with the help of a custom tablebase for a reduced game tree; see also the much more efficient C++ version at matetb
  • mergepvs.py: merges several EPD files containing PVs into one
  • provepvs.py: uses conjectured PVs to guide a local engine to find mates and prove PVs (the script works sequentially, proven PVs are available immediately)
  • shortenpvs.py: removes moves from the end of existing PVs (only used in development, for debugging other scripts)
  • sortbymates.py: sorts the positions in an EPD file

Mate collections

By way of example, the following EPD files are provided:

  • ChestUCI_23102018.epd: The original suite derived from publicly available ChestUCI.epd files, see FishCooking. It contains 6566 positions, with one definite and five likely draws, some illegal positions and some positions with a sub-optimal or likely incorrect value for the fastest known mate.
  • matetrack.epd: The successor to ChestUCI_23102018.epd, with all illegal positions removed and all known errors corrected. It contains 6554 mate problems, ranging from mate in 1 (#1) to #126 for positions with between 4 and 32 pieces. In 26 positions the side to move is going to get mated. See plot.
  • matetrackpv.epd: The same as matetrack.epd but with PVs leading to the checkmate where such a PV is known.
  • matedtrackpv.epd: Derived from matetrackpv.epd (using the script advancepvs.py) by advancing one ply in all positions with bm>1 that have a PV. It contains 6536 unique positions, and in 6529 of these the side to move is going to get mated.
  • matedtrack.epd: The same as matedtrackpv.epd, but with the PV information removed. See plot.
  • mate-in-2.epd: A collection of 6332 bm #2 puzzles derived from matetrackpv.epd. The positions have between 3 and 32 pieces.
  • mates2000.epd: A smaller test suite with 2000 positions ranging from #1 to #27 used as part of the CI workflow for Stockfish. It contains positions with between 4 and 32 pieces, and in 1105 positions the side to move is going to get mated. See plot.
  • fishmates.epd.gz: A collection of 1M mates from LTC fishtest games, ranging from #3 to #35. The positions have between 6 and 31 pieces, and in 202213 positions the side to move is going to get mated. See plot. Note: Some of the bm values at present are only upper bounds for the fastest possible mate, see WIP for improvements.

Automatic creation of new test positions

With the help of the script advancepvs.py it is easy to derive new mate puzzles from the information stored in matetrackpv.epd. For example, the file matedtrack.epd has been created with the command

python advancepvs.py --plies 1 --mateType won && sed 's/; PV.*/;/' matedtrackpv.epd > matedtrack.epd

Similarly, the file mate-in-2.epd was created with

python advancepvs.py --targetMate 2 && grep 'bm #2;' matedtrackpv.epd | awk -F'; PV' '\!seen[$1]++' > mate-in-2.epd

Trivia

A collection of games from the Lichess masters db that feature positions in matetrack.epd can be found in matetrack_masters.pgn. The file contains 32 white wins, 10 black wins and (surprisingly) 1 draw. The collection was created with the command

python get_lichess_pgns.py matetrack.epd --db master --pgnFile matetrack_masters.pgn

Related repositories


Code style: black

About

Python scripts to manipulate and provide mating PVs for Chest-like EPD files. Includes a collection of 1m proven mates.

Topics

Resources

License

Stars

Watchers

Forks

Languages