Skip to content

Solving the Yashi game using a combination of graph theory and SAT-solving. First, connectivity of the graph is verified, and if true, identification of all possible cycles is done. Then, after generating all necessary constraints, they are passed to a SAT solver.

Notifications You must be signed in to change notification settings

Di40/Yashi-Game-SAT-Logic

Repository files navigation

Yashi puzzle solver: A constraint-based approach with SAT solver

Introduction

Goal: Connect all the dots while following these constraints (rules):

  1. Diagonal lines aren’t allowed;
  2. All points must be connected;
  3. Lines cannot cross each other;
  4. Exactly $n-1$ lines must be used, where $n$ is the number of points;
  5. No closed loops.

A thorough explanation about the game and my approach can be found in the project Presentation.
If you would like to play Yashi and explore more examples, visit Yashi Puzzle.

The game can be divided up in two sub-games:

  • Version 1: If there is a solution, return one solution.

Example of a Version 1 Yashi game

  • Version 2: If there is a solution, return a minimum-length solution.

Example of a Version 2 Yashi game

To find a solution to the game, I employed a combination of graph theory and SAT-solving. First, a graph theory-based approach is used to check whether the initial graph is connected, and if it is, the next step is to discover all possible cycles. Then, after generating all the necessary constraints (no cycles, no crossing lines, and exactly $n-1$ lines), they are passed to a SAT solver.

Requirements

Before running the application be sure to have installed all the required libraries:

$ pip install -r requirements.txt

Usage

The application can be executed by simply running main.py, where you can modify several constants:

  • game_version: Enter 1 or 2, depending on the game version you want to play.
  • path_to_file: The path to the CSV file containing the game configuration you wish to use.
  • show_plot: A flag indicating whether to display the plot.
  • count_sol: A flag indicating whether to count how many solutions there are in Version 1.

Alternatively, you can run all possible game versions and configurations by using run_all_game_configurations(True) instead of main().

The format of the CVS file is the following:

point,x,y
---,---,---

and some examples are located in the game_data folder.

The results will be saved in the game_results folder.

References

About

Solving the Yashi game using a combination of graph theory and SAT-solving. First, connectivity of the graph is verified, and if true, identification of all possible cycles is done. Then, after generating all necessary constraints, they are passed to a SAT solver.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages