No version for distro humble. Known supported distros are highlighted in the buttons above.
No version for distro jazzy. Known supported distros are highlighted in the buttons above.
No version for distro rolling. Known supported distros are highlighted in the buttons above.

global_localizer package from kidnapped_robot_finder repo

global_localizer

Package Summary

Tags No category tags.
Version 0.0.0
License TODO: License declaration
Build type AMENT_PYTHON
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/saadi-tech/kidnapped_robot_finder.git
VCS Type git
VCS Version main
Last Updated 2024-12-25
Dev Status UNMAINTAINED
CI status No Continuous Integration
Released UNRELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

TODO: Package description

Additional Links

No additional links.

Maintainers

  • saad

Authors

No additional authors.

Global Localizer / Kidnap pose solver

This ROS2 package is dedicated to estimate the position of a ‘kidnapped’ mobile robot in a given map. This package will find estimate the robot’s current position in the map, by matching the features in the lidar-scan with the map’s features. The output of this package can be used to give initial pose estimate to other localizers like AMCL.

GIF File 1

Assuming the robot is equipped with a 2d Lidar scanner, this package takes following inputs:

  • Map image (.png).
  • Current lidar scan (from a published topic: “/scan” by default)

Description

This package contains works on an innovative approach to estimate the position of a kidnapped robot in a 2d map. It uses following approach:

  • Read map_image.
  • Take lastest 2d lidar scan from the robot, create a scan_image (keeping lidar at the center)
  • ‘Simulate’ scans on the map: Use the map-image and lidar parameters to simulate scans on different positions on the map (using ray-casting), i.e. how the scan would look like if the robot is present at that specific position (by using map_image).
  • Compare those simulated scans with original scan_image, find ORB features using openCV, match them and find the transform between simulated & original scan.
  • Align the simulated and original scan with the previously found affine transformation.
  • Find the best ‘aligning’ simulated scan with the original scan using F1 score metric.
  • Use the best aligned simulated scan to then calculate the position of the robot on the map.

Currently, the output is Uni-modal (it will give the highest probable position of the robot). But I will further make it multi-modal (to give multiple position estimates if there are similar locations in the map.)

Instead of taking random points on the map (as candidate positions), this package uses an optimized approach. It gets the distance to the closest obstacle from the lidar scan, and selects ONLY the area on the map which has almost similar distance to nearest obstacle pixels. Then we select the candidates by adaptive randomized selection. It helps us to reduce the search area by a big factor, so we get very good results in very few iterations.

Installation

This package was developed and tested on ROS2 Humble:

  1. Clone the repository & build the workspace after adding the correct configurations in config.yaml file.

Usage

To use the Global Localizer package, follow these steps:

  1. Add the “absolute” path to map-image (in image formats e.g. png) in the config.yaml file, and rebuild the package.
  2. Launch the simulated/real robot, make sure the /scan topic is publishing the current scan.
  3. Initialize the localization service: ‘ros2 run global_localizer global_localizer’
  4. The service would be ready, you can call the kidnap solving solution by: ‘ros2 service call /global_localization_srv std_srvs/srv/Empty’
  5. It will run the iterations and find the best, probable position for the kidnapped robot.

Demo

demo-1

demo-2

Closer look

Here is a closer look:

Robot Position

Robot-Position

Estimated Pose

Esimtated Pose

Contributing

Contributions to the Global Localizer package are welcome! If you encounter any issues or have suggestions for improvements, please open an issue on the GitHub repository.

CHANGELOG
No CHANGELOG found.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Package Dependencies

System Dependencies

Dependant Packages

No known dependants.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged global_localizer at Robotics Stack Exchange

No version for distro noetic. Known supported distros are highlighted in the buttons above.
No version for distro ardent. Known supported distros are highlighted in the buttons above.
No version for distro bouncy. Known supported distros are highlighted in the buttons above.
No version for distro crystal. Known supported distros are highlighted in the buttons above.
No version for distro eloquent. Known supported distros are highlighted in the buttons above.
No version for distro dashing. Known supported distros are highlighted in the buttons above.
No version for distro galactic. Known supported distros are highlighted in the buttons above.
No version for distro foxy. Known supported distros are highlighted in the buttons above.
No version for distro iron. Known supported distros are highlighted in the buttons above.
No version for distro lunar. Known supported distros are highlighted in the buttons above.
No version for distro jade. Known supported distros are highlighted in the buttons above.
No version for distro indigo. Known supported distros are highlighted in the buttons above.
No version for distro hydro. Known supported distros are highlighted in the buttons above.
No version for distro kinetic. Known supported distros are highlighted in the buttons above.
No version for distro melodic. Known supported distros are highlighted in the buttons above.