/HandEyeCalib-ROS

Detailed Eye in Hand calibration tutorial with ROS intergration

Primary LanguagePython

HandEyeCalib-ROS

Introduction

This repo provides a detailed tutorial to eye-in-han calibration, eye-to-hand calibration, and downstream grasp execution. The ultimate goal is to build a handy toolbox for either desktop or mobile grasping/manipulation. We will update this repo from time to time to make sure the latest progress is included. Feel free to leave any questions or comments, we are willing to discuss.

Progress

  • Eye-hand calibration with built-in aruco detecter (for opencv version after 3.2.0)
  • Eye-in-hand calibration with aruco_ros package (for ubuntu 18.04 with default opencv 3.2.0)
  • Eye-to-hand calibration with aruco_ros package (for ubuntu 18.04 with default opencv 3.2.0)
  • open-loop planar grasp execution
  • open-loop 6-DOF grasp execution
  • close-loop planar grasp execution
  • close-loop 6-DoF grasp execution

Setup

  • system: Ubuntu 18.04
  • ROS version: melodic
  • OpenCV version: 3.2.0
  • Robot: KINOVA Gen3 & Gen3 Lite
  • Camera: Intel Realsense D435i

Pre-requisites

Make sure you git clone the right branch and put all the packages under the same ROS worksapce.

Eye-hand calibration with built-in aruco detecter (for opencv version after 3.2.0)

Warning to Melodic users
OpenCV 3.2, which is the version in Ubuntu 18.04, has a buggy ArUco board pose detector. Do not expect adequate results if you are using an ArUco board with OpenCV 3.2. Jump directly to eye-hand calibration with aruco_ros package. We got your back!

Moveit provides a convenient eye-hand calibration package. It's a good idea to follow this tutorial step by step.

The whole process includes: start your camera, set tag parameters, print Aruco tag, set context configuration, take at least 5 samples, solve camera pose, save cameras poses & joint states. It uses opencv built-in aruco detector, which is buggy in opencv 3.2.0. We actually tested on opencv 3.2.0 and it gave very bad results.

Take care of which sensor frame you are using. Moveit calibration uses the right-down-forward standard as specified here. You might get totally different frame coordinates before and after loading camera into HandEyeCalibration For Intel Realsesne D435i, we found the frame coordinates of camea_color_frame has x axis pointing outwards while it is forced to z axis pointing outwards after being loaded. For this reason, we suggest using camera_color_optical_frame. Both camea_color_frame and camera_color_optical_frame are not located at camera center since RGB camera is on rightmost side of D534i.

Eye-in-hand calibration with aruco_ros package (for ubuntu 18.04 with default opencv 3.2.0)

Since the built-in aruco detecter is buggy in opencv 3.2.0, we instead use aruco_ros package. This section details the eye-in-hand calibration with aruco_ros package. First, in addition to the standard pre-requisites you may have downloaded, git clone aruco_ros with the link below:

This package supports single or double aruco tags detection. After compiling the package, generate a aruco tag with appropriate size via this link and print it out. Then edit marker configuration:

cd PATH/TO/YOUR/WORKSPACE/src/aruco_ros/aruco_ros/launch
sudo gedit single.launch

Here we use single aruco tag with markID as 9, marksize as 0.160m, camera_frame as camera_color_optical_frame. The launch file is configured as below:

Run the command below to test if printed marker is detected successfully:

roslaunch realsense2_camera rs_camera.lanuch  # launch your camera
roslaunch aruco_ros sinlge.launch  # launch your marker detecter
rosrun image_view image_view image:=/aruco_single/result  # visualize detected marker

You should be able to see something like:

Then, you may continue to launch you robot. In our case, we run:

roslaunch kortex_driver kortex_driver

For some one who is using the same robot or camera, drivers can be downloaded and installed as below:

After launching the camera, aruco and robot successfully, you can load HandEyeCalibration in RViz as below:

In HandEyeCalibration, go to Context. Set the parameters as below:

  • Sensor configuration: Eye-in-hand
  • Sensor frame: camera_color_optical_frame
  • End-effector frame: tool_frame
  • Robot base frame: base_link

Go to Calibrate. Now, you may start to move the camera around the take some samples and solve for the transform. Be sure to include some rotation between each pair of poses, and don’t always rotate around the same axis–at least two rotation axes are needed to uniquely solve for the calibration. Calibration will be performed automatically, and updated each time a new sample is added. It needs at least 5 sample, but the more the better. You might need to install extra packages for solver if error pops out. Press the save joint states and save camera pose upon getting the result.

For the record, our tf tree is as below:

Eye-to-hand calibration with aruco_ros package (for ubuntu 18.04 with default opencv 3.2.0)

Eye-to-hand calibration is almost identical to eye-in-hand calibration. The only difference is where to attach the marker and sensor configuration in Moveit HandEye Calibration.

First, attach the marker to the end-effector (shown below), and move the end-effector into the camera's view.

Then, in HandEyeCalibration, go to Context. Set the parameters as below:

  • Sensor configuration: Eye-to-hand
  • Sensor frame: camera_color_optical_frame
  • End-effector frame: tool_frame
  • Robot base frame: base_link

Your RViz should look like this:

The rest is the same as eye-in-hand calibration.

Open-loop planar grasp execution

To grasp with 4-DoF (2.5d planar grasp), we modify GGCNN to fit our robot and setup (original implementation can be found here). We choose GGCNN becuase it's light-weight and easy to deploy on any machine.

To detect 2.5d planar grasp, run the following commands:

cd PATH/TO/HandEyeCalib-ROS/planar_grasp_ggcnn
roslaunch kortex_driver kortex_driver.launch # start robot arm driver
roslaunch YOUR_HAND_EYE_CALIBRATION.launch # hand-eye calibration from last step, not included here

The commands above first launches KINOVA Gen3/Gen3 Lite dirver and then adds the calibrated hand-eye transform to arm tf tree.

Run modified ggcnn:

conda activate YOUR_GGCNN_ENV
python vis_ggcnn.py

After running viz_ggcnn.py, RGB stream with detected planar grasp will pop out. By default, only the best grasp is shown. Feel free to change --n-grasps to any number you like. Aside from detecting grasps, the code will also publish a rostopic /ggcnn_grasp_pose. This topic includes grasp center(point), quality, angle, length, and depth value. To execute published grasp on your robot, open another terminal, run:

python ggcnn_pickNplace_gen3lite_full_arm_movement.py

It subscribes to /ggcnn_grasp_pose, converts the received grasp from camera frame to robot frame, and executes the grasp.

Open-loop 6-DOF grasp execution

TBA

Close-loop planar grasp execution

TBA

Close-loop 6-DoF grasp execution

TBA