Skip to content

Path planning algorithm with Python and Pygame (RRT, RRT*, RRT modified, A*...).

Notifications You must be signed in to change notification settings

tienpp/pygame-path-finder-simulation

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

40 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

RRT algorithm implementation using Python and Pygame

This program implements the Rapidly-exploring Random Tree (RRT) algorithm, as described in https://en.wikipedia.org/wiki/Rapidly-exploring_random_tree

Demo video (March 2019): https://www.youtube.com/watch?v=cbYwxA9g_9k

May 2020 update: This program was rewritten, and now its code is more organized and better structured.

How to run

This program was written using Python 3.6.8 and Pygame 1.9.6, but newer versions of Python3 and Pygame must work too.

  1. If you don't have Python 3.6 (or newer) and Pygame installed on your system, you must first download and install Python and after that install the Pygame package.

  2. Clone or download this repository to your computer.

  3. Open a commands terminal in the 'rrt-path-finder' folder.

  4. Execute one of the following commands, according to your Python3 executable name:

    python3 src/main.py

    python src/main.py

    py src/main.py

The application must start, and you will see a new window like the one below:

The screenshot became unavailable.

Usage

The start position is represented as a green circle, and the goal position as a red circle. Use the mouse to move the start and goal positions. Use the left mouse button to draw obstacles, and the right button to erase them.

Keyboard:

When the algorithm is not running:

  • Return: Start the RRT algorithm on the current map.
  • b: Start the RRT* algorithm on the current map.
  • v: Start the RRT* modify algorithm on the current map.
  • n: Start the A* algorithm on the current map.
  • c: Clear the map's obstacles.
  • s: Save the current map as 'map.png'
  • l: Load an existing 'map.png' file as the new obstacles map.

When the algorithm is running or a path was found:

  • h: Show / hide information about the algorithm on the screen.

    If any key other than h is pressed now, then the algorithm stops and the program returns to the initial state.

About

Path planning algorithm with Python and Pygame (RRT, RRT*, RRT modified, A*...).

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%