Skip to content

sachinbhatia4/Rubik-Cube-Solver-Updated

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

37 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Rubik's Cube Solver Robot updated 07192021 - Added updated command line for opencv and updated requirements.txt.

The software that solves the Rubik's Cube on a physical machine. The detailed post on how this robot works can be found here.

An example of the robot scanning and then solving the Rubik's cube is shown in the next video.

GUI App

The GUI app has 3 tabs. These tab-accessible pages can be seen in the following images.

Imgur

Imgur

Imgur

Overall Architecture

The architecture of the program is shown in the following diagram.

Imgur

The FSM (Finite State Machine) observed in the above diagram as a thread is described next.

Imgur

Source Code

  1. In the hw directory, all the CAD components and assemblies are found. They were designed in SolidWorks.

  2. In rubiks_solver directory, the source code of the program that runs on the robot is found. In there, there are 2 core modules. Alongside these 2 modules, there is also a config.json file and modules needed to make the PivotPi to work (the servo controller).

    • arms.py - a module which hosts the classes needed to map a solution of a cube to a list of sequences that have to be directly applied to all 4 arms of the robot. The classes are particularized to the given robot.

    • main.py - the main script which upon launch spawns the GUI app and also runs in the background different threads needed to scan or solve the cube.

Things to consider when running the GUI app:
  1. The configuration of the robot can only be updated when it's found in the rest state - aka when the servos are stopped.

  2. The configuration file written config.json must have all fields already present upon the app's launch. In this repo, all required fields are already present.

  3. Pressing the Release/Fix/Stop/Cut Power buttons will execute as many times as they are pressed and in the same order as they were pressed.

  4. When calibrating the camera or the arms, click on Save to propagate the new configuration throughout the app and also to save it to disk.

Installing

Update the package manager:

sudo apt-get update

Numpy/Sklearn Dependencies:

sudo apt-get install gfortran libatlas-base-dev libopenblas-dev liblapack-dev

Dependencies for Pillow:

sudo apt-get install libjpeg-dev zlib1g-dev libfreetype6-dev liblcms1-dev libopenjp2-7 libtiff5 -y

Dependencies for muodov/kociemba library:

sudo apt-get install libffi-dev python-dev python3-dev

Dependencies for OpenCV:

sudo apt install -y libhdf5-103 libharfbuzz0b libwebp6 libjasper1 libopenexr23 libgstreamer1.0-0 libatlas-base-dev libgtk-3-0 libqtgui4 libqt4-test libilmbase23 libavcodec-extra58 libavformat58 libswscale5  libjpeg8-dev zlib1g-dev libffi-dev libopenjp2-7-dev libtiff5

Then, after having installed the dependencies, go on and install the actual libraries:

virtualenv -p python3 .venv # this has been tested against 3.5
source .venv/bin/activate
cd Rubik-Cube-Solver-Updated\Rubiks_Solver
#Go to https://pypi.org and put latest version of projects from requirement.txt and update same before running below command.
pip install -r requirements.txt --index-url https://piwheels.org/simple --extra-index-url https://pypi.org/simple

Usage

To run this, execute

python main.py

This launches a GUI app, so be sure you've got an X11 client running on your computer if you're running this headless.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published