Skip to content

Use deep learning to recognise a Sudoku puzzle from a scanned image

Notifications You must be signed in to change notification settings

taylorjg/sudoku-scanner

Repository files navigation

Description

I want to create a web app to scan and solve a Sudoku puzzle. Apps already exist for Android and iOS but I haven't seen this done as a web app before. The hard part is scanning the puzzle which is what I am attempting to do in this repo. My plan is to use TensorFlow.js to:

  • Train a model to find the bounding box of a Sudoku puzzle
  • Calculate the grid squares from the bounding box
  • Train a model to distinguish between blank grid squares and digits
  • Train a model to recognise digits 1-9

UPDATE I have been unable to train a model to find the bounding box of a Sudoko puzzle. Therefore, I have reluctantly decided to follow the OpenCV route. I say reluctantly because OpenCV.js is massive. I borrowed heavily from the following links to get something working using OpenCV.js:

Training Failure

TODO: describe the problem that I encountered

Further Work

TODO: describe plans to have another go at training a model to find the bounding box

Instructions

  • Open https://sudoku-scanner.herokuapp.com/
  • Click 'Load' under 'Training - Blanks' to load a pre-trained model to distinguish between blank grid squares and digits
    • Or, click 'Train' to train a new model
  • Click 'Load' under 'Training - Digits' to load a pre-trained model to recognise digits 1-9
    • Or, click 'Train' to train a new model
  • Click 'Start Camera'
  • Click 'Capture Camera' to take a photo of a Sudoku puzzle from a newpaper or similar
  • Try to get the puzzle grid to:
    • roughly fill the guide lines
    • be in focus
    • not be wonky
  • Click 'Predict Capture' to scan and solve the puzzle

TODO

These are some of my major TODO items:

  • Instead of using a trial and error process of capturing images and trying to scan them, automatically try to scan an image from the video stream and stop the camera once a convincing match has been found
  • Take the results of this repo and feed them into sudoku-buster
    • The idea is for sudoku-buster to be a polished Sudoku scanning/solving web app whereas this repo is a laboratory experiment
  • Persevere with trying to train a model to find the bounding box of a Sudoku puzzle so that everything is done via TensorFlow.js and I no longer need to bring in OpenCV.js (which is massive)

Links

About

Use deep learning to recognise a Sudoku puzzle from a scanned image

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published