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.

Package Summary

Tags No category tags.
Version 0.0.0
License Apache-2.0
Build type AMENT_PYTHON
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/shengyangzhuang/handeye_calibration_ros2.git
VCS Type git
VCS Version main
Last Updated 2025-01-22
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

ROS2 package for hand-eye calibration

Additional Links

No additional links.

Maintainers

  • szhuang

Authors

No additional authors.

handeye_realsense

This is a ROS2 handeye calibration package for RealSense depth camera. Here we provided a more detailed example for the usage.

A video of the full process can be viewed here

Example with RealSense D415

  1. Camera and robot setup

    Prepare a camera holder. This image shows two camera holders example designed for KUKA LBR iiwa 7/14 and RealSense, Azure Kinect depth camera.

    Camera and robot setup

    Prepare an ArUco marker. Attach the camera to the robot.

    aruco realsense_setup

  2. Camera intrinsic calibration

    Calibrate the camera matrix K and distortion coefficient D. This can be done with the camera_calibration package we provided by using a chessboard. If you use RealSense/Azure Kinect camera, you can also get the camera parameters directly with ros2 topic echo "/specific_camera_topic".

    When you are sure camera parameters are correct, you can record it in the handeye_realsense/realsense_info.yaml.

  3. Specifying the parameters of your robot

    Under handeye_realsense/config.yaml file, modify the aruco_marker_side_length, image_topic, and relevant robot link names as per your setups.

  4. Bring up the robot and camera

    If you use lbr_fri_ros2_stack for KUKA LBR robots, please refer to the guideline here

    Start the RealSense camera ROS2 driver

    ros2 run realsense2_camera realsense2_camera_node
   
  1. Taking samples You can use moveit, custom control script, or admittance control mode to guide the robot around to take unique samples of the camera poses.

    Go into your handeye calibration workspace and launch the calibration file

    cd handeye_calibration_ws
    colcon build --packages-select handeye_realsense
    source install/setup.bash
    ros2 launch taking_sample_launch.py
   
<p align="left">
    <img src="https://github.com/user-attachments/assets/e226deb3-02cd-4fde-a34d-0f211de4c859" alt="cali_experiment_combined" width="500"/>
</p>
  1. Computing and publishing the result

    To compute the eye-in-hand calibration result

   ros2 run handeye_realsense handeye
   

To publish the result and visualize in rviz

   ros2 run handeye_realsense eye2hand
   

cali_experiment_combined

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.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged handeye_realsense 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.