Skip to main content

CLI to solve combinatoric chess puzzles.

Project description

CLI to solve combinatoric chess puzzles.

Stable release: Last release Python versions Software license Requirements freshness

Development: Unit-tests status Documentation Status Coverage Status Code Quality

Motivation

This project started its life as a coding challenge I was asked to solve while interviewing in 2015 for a software engineering position at Uber.

After the interview proccess ended, I kept toying with the code, as a playground to test some optimization strategies in Python. It is now a boilerplate that I use to:

Examples

Simple 3x3 board with 2 kings and a rook:

$ chessboard solve --length=3 --height=3 --king=2 --rook=1
<SolverContext: length=3, height=3, pieces={'rook': 1, 'king': 2, 'queen': 0, 'bishop': 0, 'knight': 0}>
Searching positions...
┌───┬───┬───┐
│ ♚ │   │   │
├───┼───┼───┤
│   │   │ ♜ │
├───┼───┼───┤
│ ♚ │   │   │
└───┴───┴───┘
┌───┬───┬───┐
│   │   │ ♚ │
├───┼───┼───┤
│ ♜ │   │   │
├───┼───┼───┤
│   │   │ ♚ │
└───┴───┴───┘
┌───┬───┬───┐
│ ♚ │   │ ♚ │
├───┼───┼───┤
│   │   │   │
├───┼───┼───┤
│   │ ♜ │   │
└───┴───┴───┘
┌───┬───┬───┐
│   │ ♜ │   │
├───┼───┼───┤
│   │   │   │
├───┼───┼───┤
│ ♚ │   │ ♚ │
└───┴───┴───┘
4 results found in 0.03 seconds.

Famous eight queens puzzle, without printing the solutions to speed things up:

$ chessboard solve --length=8 --height=8 --queen=8 --silent
<SolverContext: length=8, height=8, pieces={'rook': 0, 'king': 0, 'queen': 8, 'bishop': 0, 'knight': 0}>
Searching positions...
92 results found in 119.87 seconds.

Huge combinatoric problem can take some time to solve:

$ chessboard solve --length=7 --height=7 --king=2 --queen=2 --bishop=2 --knight=1 --silent
<SolverContext: length=7, height=7, pieces={'rook': 0, 'king': 2, 'queen': 2, 'bishop': 2, 'knight': 1}>
Searching positions...
3063828 results found in 9328.33 seconds.

The CLI allow the production of a profiling graph, to identify code hot spots and bottleneck:.

$ chessboard solve --length=6 --height=6 --king=2 --queen=2 --bishop=2 --knight=1 --silent --profile
<SolverContext: length=6, height=6, pieces={'rook': 0, 'king': 2, 'queen': 2, 'bishop': 2, 'knight': 1}>
Searching positions...
23752 results found in 207.25 seconds.
Execution profile saved at /home/kevin/chessboard/solver-profile.png
Solver profiling graph

Third-party

This project package’s boilerplate is sourced from the code I wrote for Scaleway’s postal-address module, which is published under a GPLv2+ License.

The CLI code is based on the one I wrote for the kdenlive-tools module, published under a BSD license.

Other resources

Changes for v1.5.4 (2017-08-11)

  • Show selected log level in debug mode.

  • Drop support and unittests on Mac OS X 10.9.

  • Add new macOS 10.12 target for Travis CI builds.

  • Bump requirement to readme_renderer >= 16.0.

  • Move installation instructions to documentation.

  • Move performance page to documentation.

  • Move CLI usage to own section in docs.

  • Activate unittests in Python 3.6.

  • Show environment variables in Travis jobs for debugging.

  • Check there is no conflicting dependencies in Travis jobs.

  • Show the graph of package dependencies in documentation.

  • Fix upgrade of setuptools in macOS + Python 3.3 Travis jobs.

Full changelog.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

chessboard-1.5.4.tar.gz (226.4 kB view details)

Uploaded Source

Built Distributions

chessboard-1.5.4-py2.py3-none-any.whl (29.0 kB view details)

Uploaded Python 2 Python 3

chessboard-1.5.4-py2.7.egg (24.9 kB view details)

Uploaded Source

File details

Details for the file chessboard-1.5.4.tar.gz.

File metadata

  • Download URL: chessboard-1.5.4.tar.gz
  • Upload date:
  • Size: 226.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for chessboard-1.5.4.tar.gz
Algorithm Hash digest
SHA256 7cab8f693e26a6ea1f381e898ff51ebd303daf1ac3f0d77254e83e87e99b6eb5
MD5 ae32b7f41f34fe543c688a021a03e461
BLAKE2b-256 2d7539bc4fa5af5e72abbb1ce067dfa907f580087b82e55362f6127d27719df0

See more details on using hashes here.

File details

Details for the file chessboard-1.5.4-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for chessboard-1.5.4-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 7a4cacd4e77d98fa93f05f047b6379e7c7dbed9808f67407a69b907952e423cc
MD5 6b26a36257a6b329a0c7d03cfae928f3
BLAKE2b-256 ca0f14ee176469309d389a27288633174299ab7ebac78ee4474b9a801d30325b

See more details on using hashes here.

File details

Details for the file chessboard-1.5.4-py2.7.egg.

File metadata

File hashes

Hashes for chessboard-1.5.4-py2.7.egg
Algorithm Hash digest
SHA256 703052428152d808a51b8a1cd22506f8ef20b8e1e09ba11b5f80fcffcb55acb8
MD5 3bbf190e8e943494110982bdf5452266
BLAKE2b-256 193b76052c79f9713ccca76b06613a04b93d65af435dd7dd86017459b80cac58

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page