Skip to content

combination of cpp and python with swig to solve mazes with an a-star algorithm

License

Notifications You must be signed in to change notification settings

Tastaturtaste/mazesolver

Repository files navigation

A*-Mazesolver

Example project using the a_star extension module, comparing its performance to a pure python implementation.

Setup

Get repository

Since submodule is used to include the functionality of the A*-Extension the additional parameter --recurse-submodules has to be used while cloning the repository:
git clone --recurse-submodules https://github.com/Tastaturtaste/mazesolver.git

Optional: Setup virtual environment

In the root directory of this project run python -m venv venv-name where venv-name can be any name you like.
Activate it using venv-name/scripts/activate.
Read more about it here.

Required

For this step a compatible c++-compiler is likely necessary, since the c++-binary extension has to interact with the python interpreter. Linux users should have one by default while windows users may have to install one. But first proceed as follows. In the root directory run pip install -r requirements.txt. This will install all required dependencies as well as my c++-extension module.
If you did not have the correct compiler installed at this stage and the provided wheel is not suitable for your platform the generated error message will tell you which compiler you need and where you can get one.

Usage

To solve a maze run python mazesolve.py path/to/maze.png.

mazesolve.py reads in the three color channels of the picture. The start position for the maze should be marked in red, the exit in blue. Then the picture is converted to gray-scale. Per default grey values of 0 (completely black) are considered unpassable, values above (lighter color) are considered passable. Grey values that are passable are translated to pathing costs.
mazesolve.py then calls and times the respective functions for the A*-Algorithm of both the pure python and the c++ module and prints the runtime to the console. The resulting path as well as the explored area is drawn into the maze and saved to a file for both modules seperately.
The behaviour can be influenced via the commandline arguments passed to mazesolve.py. These can be explored with python mazesolve.py -h

Comparison

Depending on the size of the maze the c++ module is about 10 to 30 time faster than the pure python module. This gain gets smaller the larger the maze is.

On Errors

If an import error gets triggered while using the script, make sure the package is correctly installed and you have the correct vc++ redistributable on the system. Most people should have it already installed. If not or you are unsure you can download it here: https://support.microsoft.com/en-us/help/2977003/the-latest-supported-visual-c-downloads

About

combination of cpp and python with swig to solve mazes with an a-star algorithm

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages