Skip to main content

Demystify is a tool which allows puzzles to be expressed in a high-level constraint programming language and uses MUSes to automatically produce descriptions of steps in the puzzle solving.

Project description

Demystify

Pen and paper puzzles like Sudoku, Futoshiki and Skyscrapers are hugely popular. Solving such puzzles can be a trivial task for modern AI systems. However, most AI systems solve problems using a form of backtracking, while people try to avoid backtracking as much as possible. This means that existing AI systems do not output explanations about their reasoning that are meaningful to people.

Demystify is a tool which allows puzzles to be expressed in a high-level constraint programming language and uses MUSes to automatically produce descriptions of steps in the puzzle solving.

Install Instructions

Install conjure (in conjure git checkout):

git clone https://github.com/conjure-cp/conjure && cd conjure && make && make solvers && make install

Install some python packages:

pip3 install python-sat z3-solver numpy sortedcontainers

Then try:

python3 demystify --eprime eprime/binairo.eprime --eprimeparam eprime/binairo-1.param

Visualizer

Demystify also has a visual interface, which you can find in a separate repository here

Implemented Puzzles

  • Binairo
  • Futoshiki
  • Sudoku
  • Jigsaw Sudoku
  • X-Sudoku
  • Miracle Sudoku
  • Kakuro
  • Skyscrapers
  • Star Battle
  • Tents and Trees
  • Thermometers

All the models can be found in the eprime directory. If you are interested in a puzzle that is not implemented, there is a guide for modelling your own puzzles here.

Publications

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

demystify-0.0.5.tar.gz (31.5 kB view details)

Uploaded Source

Built Distribution

demystify-0.0.5-py3-none-any.whl (44.8 kB view details)

Uploaded Python 3

File details

Details for the file demystify-0.0.5.tar.gz.

File metadata

  • Download URL: demystify-0.0.5.tar.gz
  • Upload date:
  • Size: 31.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.5.0.1 requests/2.25.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.8.3

File hashes

Hashes for demystify-0.0.5.tar.gz
Algorithm Hash digest
SHA256 2d7ade4be44afb3b8749b41a66c45e70580a74b0d712779afd87fa32c4cd529a
MD5 a9086c067b32224ff7203547d1908429
BLAKE2b-256 ea611a46ab522a33aa2ef50bda6855f1914e223daa578d63d5d635916a080a5e

See more details on using hashes here.

File details

Details for the file demystify-0.0.5-py3-none-any.whl.

File metadata

  • Download URL: demystify-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 44.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.5.0.1 requests/2.25.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.8.3

File hashes

Hashes for demystify-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 27f426a91826e2b9fd6342eca160d9754536f043a9e15d8e8b417284e010d21a
MD5 1f06dc0532c9e89777bbbd9523c0ec1e
BLAKE2b-256 5b925c6187d0fb8377842f82b362ca165cd24ba6118398fc5babab641ddfc51a

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