A pathfinding visualization of A* Algorithm using python's pygame module.
A* is a famous algorithm for search problems in Computer Science. A* guarantees the shortest path from 2 nodes. It uses heuristics to decide which node to explore next, prioritizing nodes that are known to be closer to the goal based on the Euclidean distance that is returned by a heuristic function.
To visualize the algorithm a 2d grid in pygame was created, and represented each cell of the grid as a node. A node can either be a wall, start, or end. The pathing can either be both diagonal and across (default), or it can only be across. Usage and Basic Controls may be found below and in src/pathfind.py.
git clone https://github.com/CSjianbel/A-Pathfinding-Visualization.git
Install Dependencies through package manager pip
pip install -r requirements.txt
-
START: 's'
-
END: 'e'
-
WALL: left click
-
REMOVE WALL: right click
-
FIND PATH: 'a'
-
STOP FINDING PATH: '0'
-
SET PATHING:
- SET ACROSS AND DIAGONAL: 'p' (DEFAULT)
- SET ACROSS ONLY: 'o'
-
SET SPEEDS:
- 3: FAST (DEFAULT)
- 2: MEDIUM
- 1: SLOW
-
GENERATE RANDOM MAZE: '9'
-
RESETS:
- SOFT RESET: 'q'
- HARD RESET: 'r'
- Turquoise
- START NODE
- Purple
- END NODE
- Black
- WALL
- White
- OPEN PATH
- Green
- NODES IN OPEN SET
- Red
- NODES IN CLOSED SET
- Yellow
- PATH FROM START TO END
python pathfind.py
Optionally you may change the WIDTH of the window. Width must be divisible by 15, if not the program will automatically adjust the specified width to be divisible by 15. Invalid command line arguments will result to default width of 600.
python pathfind.py --width
python pathfind.py --width 900
optional arguments:
-h, --help show this help message and exit
-w WIDTH, --width WIDTH
Enter width of the pygame window : default - 600
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
A Project by Jiankarlo A. Belarmino