Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/neeru1207/ai_sudoku
GUI based Smart Sudoku Solver that tries to extract a sudoku puzzle from a photo and solve it
https://github.com/neeru1207/ai_sudoku
blob-detection cnn cnn-tensorflow cv2 digit-recognition-application digital-image-processing gui hough-line-transform hough-lines hough-transform image-processing image-segmentation knn-classification knn-classifier machine-learning opencv-python sudoku-grabber sudoku-solver tkinter-gui tkinter-python
Last synced: about 2 hours ago
JSON representation
GUI based Smart Sudoku Solver that tries to extract a sudoku puzzle from a photo and solve it
- Host: GitHub
- URL: https://github.com/neeru1207/ai_sudoku
- Owner: neeru1207
- License: cc0-1.0
- Created: 2019-12-24T12:24:37.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-07-06T21:46:47.000Z (over 1 year ago)
- Last Synced: 2025-01-14T21:09:17.889Z (7 days ago)
- Topics: blob-detection, cnn, cnn-tensorflow, cv2, digit-recognition-application, digital-image-processing, gui, hough-line-transform, hough-lines, hough-transform, image-processing, image-segmentation, knn-classification, knn-classifier, machine-learning, opencv-python, sudoku-grabber, sudoku-solver, tkinter-gui, tkinter-python
- Language: Python
- Size: 33.2 MB
- Stars: 1,004
- Watchers: 24
- Forks: 153
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# AI_Sudoku
[![forthebadge made-with-python](http://ForTheBadge.com/images/badges/made-with-python.svg)](https://www.python.org/)
[![forthebadge cc-0](http://ForTheBadge.com/images/badges/cc-0.svg)](http://ForTheBadge.com)GUI Smart Sudoku Solver that tries to extract a sudoku puzzle from a photo and solve it.
## Table Of Contents:
[Installation](https://github.com/neeru1207/AI_Sudoku/blob/master/README.md#installation)
[Usage](https://github.com/neeru1207/AI_Sudoku/blob/master/README.md#usage)
[Working](https://github.com/neeru1207/AI_Sudoku/blob/master/README.md#working)
* [Image Preprocessing](https://github.com/neeru1207/AI_Sudoku/blob/master/README.md#image-preprocessing)
* [Recognition](https://github.com/neeru1207/AI_Sudoku/blob/master/README.md#recognition)[ToDo](https://github.com/neeru1207/AI_Sudoku/blob/master/README.md#todo)
[Contributing](https://github.com/neeru1207/AI_Sudoku/blob/master/README.md#contributing)
## Installation
1. Download and install Python3 from [here](https://www.python.org/downloads/)
2. I recommend using [virtualenv](https://virtualenv.pypa.io/en/latest/). Download virtualenv by opening a terminal and typing:
```bash
pip install virtualenv
```
3. Create a virtual environment with the name sudokuenv.* Windows
```bash
virtualenv sudokuenv
cd sudokuenv/Scripts
activate
```
* Linux:
```bash
source sudokuenv/bin/activate
```
4. Clone this repository, extract it if you downloaded a .zip or .tar file and cd into the cloned repository.* For Example:
```bash
cd A:\AI_Sudoku-master
```
5. Install the required packages by typing:
```bash
pip install -r requirements.txt
```
## Usage
* Before running the application, know that you can set the **modeltype** variable in **Run.py** to either "CNN" or "KNN" to choose the Convolutional Neural Network or the K Nearest Neighbours Algorithm for Recognition. By default it is set to "KNN" and I got a way higher accuracy using KNN itself, so I would recommend that you don't change it.
```Python
'''Run this file to run the application'''
from MainUI import MainUI
from CNN import CNN
from KNN import KNN
import os
# Change the model type variable value to "CNN" to use the Convolutional Neural Network
# Change the model type variable value to "KNN" to use the K Nearest Neighbours Classifier
modeltype = "KNN"
```
* Type the below command to run the Application. You *need* to be connected to the Internet and it might take 5-10 minutes to create the **knn.sav** file so please wait patiently. This delay is only during the first run as once created, the application will use the local file
```bash
python Run.py
```
* The GUI Homepage that opens up as soon as you run the application.![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/1.png)
* You need to select an image of a Sudoku Puzzle through the GUI Home Page.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/2.png)
* Once you press **Next**, a number of stages of image processing take place which are displayed by the GUI leading up to recognition. Here are snapshots of two of the stages:
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/4.png)
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/7.png)
* For recognition, a **CNN** or **KNN** can be used. This option can be toggled as mentioned in the first point. Once recognized, the board is displayed and you can rectify any wrongly recognized entries in the board.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/18.png)
* Finally click on **reveal solution** to display the solution.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/19.png)
## Working
### Image Preprocessing
* **Gaussian Blurring** Blurring using a Gaussian function. This is to reduce noise and detail.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/4.png)
* **Adaptive Gaussian Thresholding** Adaptive thresholding with a Gaussian Function to account for different illuminations in different parts of the image.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/5.png)
* **Inverting** to make the digits and lines white while making the background black.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/6.png)
* **Dilation** with a plus shaped 3X3 Kernel to fill out any cracks in the board lines and thicken the board lines.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/7.png)
* **Flood Filling** Since the board will probably be the largest blob a.k.a connected component with the largest area, floodfilling from different seed points and finding all connected components followed by finding the largest floodfilled area region will give the board.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/8.png)
* The **largest blob** a.k.a the board is found after the previous step. Let's call this the outerbox
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/9.png)
* **Eroding** the grid a bit to undo the effects of the dilation on the outerbox that we did earlier.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/10.png)
* **Hough Line Transform** to find all the lines in the detected outerbox.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/11.png)
* **Merging** related lines. The lines found by the Hough Transform that are close to each other are fused together.
* **Finding the Extreme lines** . We find the border lines by choosing the nearest line from the top with slope almost 0 as the upper edge, the nearest line from the bottom with slope almost 0 as the lower edge, the nearest line from the left with slope almost infinity as the left edge and the nearest line from the right with slope almost infinity as the right edge.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/12.png)
* **Finding the four intersection points**. The four intersection points of these lines are found and plotted along with the lines.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/13.png)
* **Warping perspective**. We find the perspective matrix using the end points, correct the perspective and crop the board out of the original image.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/14.png)
* **Thresholding and Inverting the grid**. The cropped image from the previous step is adaptive thresholded and inverted.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/15.png)
* **Slicing** the grid into 81 slices to get images of each cell of the Sudoku board.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/16.png)
* **Blackfilling and centering the number**. Any white patches other than the number are removed by floodfilling with black from the outer layer points as seeds. Then the approximate bounding box of the number is found and centered in the image.
![](https://github.com/neeru1207/AI_Sudoku/blob/master/Screenshots/17.png)
### Recognition
#### Convolutional Neural Network
Read about CNNs [here](https://towardsdatascience.com/a-comprehensive-guide-to-convolutional-neural-networks-the-eli5-way-3bd2b1164a53)
* **Layers** A Convolution Layer, a Max Pooling layer flattened into a hidden layer followed by some Dropout Regularization, another hidden layer and finally the output layer. Each of the inner layer uses *ReLu* while the output layer uses *softmax*.
* **Compilation** *Adam* optimizer and *sparse categorical cross entropy* loss.
* **Training** The model is trained on the **MNIST** handwritten digits dataset which has around 70,000 28X28 images.
* **Accuracy** Around 98 percent accuracy on the test set.#### K Nearest Neighbours
Read about KNN [here](https://towardsdatascience.com/machine-learning-basics-with-the-k-nearest-neighbors-algorithm-6a6e71d01761)
* **K** value used is 3.
* **Training** Trained on the **MNIST** handwritten digits dataset which has around 70,000 28X28 images.
* **Accuracy** Around 97 percent accuracy on the test set.
## ToDo* Improve Accuracy.
* Resolve Bugs/Issues if any found.
* Optimize Code to make it faster.## Contributing
Contributions are welcome :smile:
### Pull requests
Just a few guidelines:
* Write clean code with appropriate comments and add suitable error handling.
* Test the application and make sure no bugs/ issues come up.
* Open a pull request and I will be happy to acknowledge your contribution after some checking from my side.### Issues
If you find any bugs/issues, raise an issue.