cbgl
is a ROS package written in C++ that allows you to localise your 2D LIDAR sensor in a given 2D occupancy grid map under global uncertainty in position and orientation in minimal time
-
You can expect the execution time to roughly have an order of magnitude of
$10e \cdot \text{area} \cdot N_s$ microseconds, where$\text{area}$ is the area of the map's free space and$N_s$ is the LIDAR's number of rays. (Strictly speaking the execution time varies according to the geometry of the environment and other factors.) In the video below the environment area is$2000$ m$^2$ and localisation is performed in under four seconds -
CBGL does not require motion for performing global localisation: it's a one-shot approach that only requires a single laser scan measurement and the map of the sensor's environment
cbgl_in_willowgarage.mp4
A panoramic 2D LIDAR sensor mounted on a turtlebot 2 is spawned into
an environment at a pose whose immediate surroundings are repeated in (almost)
the same geometry and proportions at locations other than the sensor's spawning
ground. The user calls the global localisation service once before moving the
robot at a second challenging pose, at which she calls it for a second time.
Both times cbgl
is successful in estimating the sensor's pose. Sensor
characteristics:
If this is your first time running docker then I happen to find this docker installation guide very friendly and easy to follow.
Build the image with the most recent code of this repository with:
git clone git@github.com:li9i/cbgl.git
cd cbgl
docker compose build
or pull the docker image and run it with
docker pull li9i/cbgl:latest
docker run -it \
--name=cbgl_container \
--env="DISPLAY=$DISPLAY" \
--net=host \
--rm \
li9i/cbgl:latest
This package was tested and works under Ubuntu 16.04 and ROS kinetic.
You will need csm
, CGAL 4.7
and fftw3
as dependencies. Then, as always
cd ~/catkin_ws/src
git clone git@github.com:li9i/cbgl.git
cd cbgl; mv cbgl/* $PWD; rmdir cbgl; cd ../..
catkin build cbgl
Before launching your robot, cbgl
, etc, you will need to
- export the map of your environment, say
map_x.pgm
, into a .png
file (that ismap_x.png
;gimp
does it) - place
map_x.png
intocbgl/map/
- in file
configuration_files/params_cbgl.yaml
: set themap_png_file
variable to point to the absolute path ofmap_x.png
- If you run
cbgl
via docker then the path needs to be expressed relative to the container's path structure, e.g.map_png_file: "/home/user_cbgl/catkin_ws/src/cbgl/map/map_x.png"
- If you run
cbgl
via traditional means then the path needs to be expressed relative to your own machine's path structure, e.g.map_png_file: "/home/me/catkin_ws/src/cbgl/map/map_x.png"
- If you run
docker compose up
roslaunch cbgl cbgl.launch
Launching cbgl
simply makes it go into stand-by mode and does not actually execute global localisation. To do so simply call the provided service
docker exec -it cbgl_container sh -c "source ~/catkin_ws/devel/setup.bash; rosservice call global_localization"
rosservice call /global_localization
- [in] A
sensor_msgs/LaserScan
message published through topicconfiguration_files/scan_topic
- [in] A
nav_msgs/OccupancyGrid
message published through topicconfiguration_files/map_topic
- [out] A
geometry_msgs/PoseWithCovarianceStamped
message published through topicconfiguration_files/output_pose_topic
- [out] The transform between the
odom
frame and themap
frame ifconfiguration_files/tf_broadcast
is set totrue
The theoretical underpinning, key aspects, and experimental performance of CBGL are presented in the preprint cited through
@article{cbgl,
title={CBGL: Fast Monte Carlo Passive Global Localisation of 2D LIDAR Sensor},
author={Filotheou, Alexandros},
journal={arXiv:2307.14247},
url={https://arxiv.org/abs/2307.14247}
year={2023}}