Skip to content

A fast particle filter localization algorithm for the MIT Racecar. Uses RangeLibc for accelerated ray casting.

Notifications You must be signed in to change notification settings

vaul-ulaval/particle_filter

 
 

Repository files navigation

Particle Filter Localization

This code implements the MCL algorithm for the RACECAR.

YouTube Demo

For high efficiency in Python, it uses Numpy arrays and RangeLibc for fast 2D ray casting.

Installation

To run this, you need to ensure that both the map_server ROS package, and the python wrappers for RangeLibc are installed.

For the map server :

# Do this at the root of your colcon workspace
sudo apt-get update
rosdep install -r --from-paths src --ignore-src --rosdistro foxy -y

For RangeLibc:

# No need to clone this in your workspace, we will only use the python wrapper
git clone https://github.com/f1tenth/range_libc
sudo apt-get install python3-dev cython3
cd range_libc/pywrappers
# on VM
./compile.sh
# on car - compiles GPU ray casting methods
./compile_with_cuda.sh

Utilisation dans le simulateur

Pour l'utiliser dans le simulateur, il faut commenter le lancement du map_server dans le launch file. Dans le fichier launch/localize_launch.py, commenter ces deux lignes (Vers la fin du fichier) :

    ld.add_action(nav_lifecycle_node)
    ld.add_action(map_server_node)

Ensuite, dans le fichier config/localize.yaml, change le 'odometry_topic' pour '/ego_racecar/odom' et 'range_method' pour 'glt'

Usage

The majority of parameters you might want to tweak are in the launch/localize.launch file. You may have to modify the "odometry_topic" or "scan_topic" parameters to match your environment.

ros2 launch particle_filter localize_launch.py

Once the particle filter is running, you can visualize the map and other particle filter visualization message in RViz. Use the "2D Pose Estimate" tool from the RViz toolbar to initialize the particle locations.

See launch/localize.launch for docs on available parameters and arguments.

The "range_method" parameter determines which RangeLibc ray casting method to use. The default is cddt because it is fast and has a low initialization time. The fastest option on the CPU is "glt" but it has a slow startup. The fastest version if you have can compile RangeLibc with CUDA enabled is "rmgpu". See this performance comparison chart:

Range Method Performance Comparison

Docs

This code is the staff solution to the lab guide found in the /docs folder. A mathematical derivation of MCL is available in that guide.

There is also documentation on RangeLibc in the /docs folder.

The code itself also contains comments describing purpose of each method.

Cite

This library accompanies the following publication.

@article{walsh17,
    author = {Corey Walsh and 
              Sertac Karaman},
    title  = {CDDT: Fast Approximate 2D Ray Casting for Accelerated Localization},
    volume = {abs/1705.01167},
    url    = {http://arxiv.org/abs/1705.01167},
    year   = {2017}}

About

A fast particle filter localization algorithm for the MIT Racecar. Uses RangeLibc for accelerated ray casting.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 92.8%
  • CMake 7.2%