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.

multi_lidar_calibrator package from multi_lica repo

multi_lidar_calibrator

Package Summary

Tags No category tags.
Version 0.0.1
License LGPL-3.0 license
Build type AMENT_PYTHON
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/tumftm/multi_lica.git
VCS Type git
VCS Version main
Last Updated 2025-02-17
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

Multi - LiDAR-to-LiDAR calibration framework for ROS 2 and non-ROS applications

Additional Links

No additional links.

Maintainers

  • Andrii Chumak
  • Dominik Kulmer

Authors

No additional authors.

Multi - LiCa

Multi - LiDAR-to-LiDAR calibration framework for ROS 2 and non-ROS applications [![Linux](https://img.shields.io/badge/os-linux-blue.svg)](https://www.linux.org/) [![Docker](https://badgen.net/badge/icon/docker?icon=docker&label)](https://www.docker.com/) [![ROS2humble](https://img.shields.io/badge/ros2-humble-blue.svg)](https://docs.ros.org/en/humble/index.html) [![arXiv](https://img.shields.io/badge/arXiv-1234.56789-b31b1b.svg)](https://arxiv.org/abs/2501.11088) [![DOI:10.1109/MFI62651.2024.10705773](http://img.shields.io/badge/DOI-10.1109/MFI62651.2024.10705773-00629B.svg)](https://doi.org/10.1109/MFI62651.2024.10705773)

Introduction

This project provides an extrinsic calibration framework for quickly calibrating multiple LiDAR sensors. It employs the Generalized Iterative Closest Point (GICP) algorithm for LiDAR-to-LiDAR extrinsic calibration and uses the RANdom SAmple Consensus (RANSAC) method to calibrate the pitch and z-distance to the ground of a single LiDAR, assuming other coordinates are known.

It has proven to be robust for different sensor setups and environments without the need of an initial guess.
We use a FPFH-based feature vector creation with an TEASER++ feature matching for the coarse alignment, which is used as initial guess for the GICP algorithm.

Overview

_Motion- and targetless multi - LiDAR-to-LiDAR Calibration Pipeline, developed at the Institute of Automotive Technology, TUM_

Limitations

  • Our tool was specifically developed for motionless calibration.
  • We assume that each LiDAR to be calibrated has either a directly overlapping FOV with the target LiDAR FOV or has overlap with other LiDAR(s) with overlap to the target. This can be cascading dependency to the target.
  • We assume that the ground is flat and the environment is static.
  • Input point clouds for the calibration are in sensor_msgs/PointCloud2 or in .pcd format.

Prerequisites

The bare minimum requirement for our tool is a Linux-based OS and Docker, as we provide a Docker image with our framework.
You do not need to build anything locally, but you are free to do so as described in the following section.
For the local build, you will need ROS 2 - humble, Python 3.10 with opend3d, scipy, ros2_numpy and pandas (optional).

Installation and Usage

We use submodules, therefore, use git clone --recurse-submodules git@github.com:TUMFTM/Multi_LiCa.git

🐋 Docker Environment

  1. Build the Docker image:
   ./docker/build_docker.sh
   
  1. Run the container:
   ./docker/run_docker.sh
   

🖥 Local Build

  1. Install ROS2 humble (might work with other ROS2 distributions but wasn’t tested): https://docs.ros.org/en/humble/Installation.html

  2. Create a ROS 2 workspace:

   mkdir -p ~/ros2_ws
   cd ~/ros2_ws
   
  1. Clone the repository:
   git clone --recurse-submodules git@github.com:TUMFTM/Multi_LiCa.git
   
  1. Install dependencies:
   cd Multi_LiCa
   pip install --no-cache-dir --upgrade pip
   pip install --no-cache-dir -r requirements.txt
   
  1. Source the ROS 2 environment and build the project using colcon:
   source /opt/ros/$ROS_DISTRO/setup.bash
   colcon build --symlink-install --packages-up-to multi_lidar_calibrator --cmake-args -DCMAKE_BUILD_TYPE=Release
   

⏯️ Usage

  1. Configure the parameters to fit your data:
   vim config/<params-file>.yaml
   
  1. Launch the multi_lidar_calibrator node:
   ros2 launch multi_lidar_calibrator calibration.launch.py parameter_file:=/path/to/parameter/file
   

⚙️ Configuration

  • We provided a detailed parameter file with explanation with config/params.yaml

  • Configure config/params.yaml to fit your data. Depending on the application, you may need to specify the LiDARs, paths to .pcd files, or LiDAR topic names. You may also change GICP and RANSAC parameters.

  • In addition to LiDAR-to-LiDAR calibration, you can perform target LiDAR-to-ground/base calibration if your x,y translation and roll, yaw rotation are precisely known.
    If you are using to-base calibration, you may choose a URDF file to save the calibration so that it can be directly used in your ROS robot-state-publisher.

  • When running in a container, ensure that your local and container environments have the same ROS_DOMAIN_ID. If not, set it to be the same with export ROS_DOMAIN_ID=<ID>.

  • When using ROS 2, verify that the transformation guess is published on the /tf_static topic and that the data is published for all specified LiDARs.

🎞️ Demo

On default, the tool will launch a demo with data from OpenCalib.
It will open a window and will display three pointclouds and their initial transforms. You can inspect the files in the interactive window. After closing the window (press Q), the tool will calculate the transformations ans will print the results to the terminal, write them to the output directory and will display a windows with the transformed pointclouds.

Citation

@article{kulmermfi2024,
  author    = {Kulmer, Dominik and Tahiraj, Ilir and Chumak, Andrii and Lienkamp, Markus},
  title     = {{Multi-LiCa: A Motion- and Targetless Multi - LiDAR-to-LiDAR Calibration Framework}},
  journal   = {2024 IEEE International Conference on Multisensor Fusion and Integration for Intelligent Systems (MFI)},
  pages     = {1-7},
  doi       = {10.1109/MFI62651.2024.10705773},
  year      = {2024},
  codeurl   = {https://github.com/TUMFTM/Multi_LiCa},
}

Other OSS Calibration Frameworks

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

No direct 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 multi_lidar_calibrator 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.