...
The current method uses the robot to calibrate the sensors. The robot will need to hold a calibration tag and move through positions with the tag in the sensors field of view during calibration process. The positions will need to be set by the user. A calibration tag will also need to be mounted stationary in the scene in the field of view of the sensors in order for the system to be able to detect if the sensors have shifted out of calibration.
The cal.json file contains all the relevant information to calibrate and run the rapidsense system with multiple cameras.
Calibration Requirements
The requirements for calibration are:
Aruco tag mounted off of the robot faceplate
Static Aruco tag placed in the scene which is easily visible to the sensor
Calibration preset in RPC called “Calibration” with accurate TCP frame located at the center of the Aruco tag. More details in the cal.json file linked below
For calibrating, create a frame on the aruco tag face center with its X axis (Red) pointing to the right, Y (Green) pointing upwards and Z (Blue) coming out of the face. Something like this:
...
cal.json file which has all the camera serial_numbers and it’s corresponding robot target positions for calibration which have the Aruco tag on the robot in the sensor field of view
A home robot target position with the following naming convention: robotname_home.
The calibration robot target positions present in cal.json should be connected on Roadmap to the home target in RPC project in order for the calibration to succeed.
Setup and Running Calibration Process
To easily generate the cal.json file and save it in /etc/rapidsense/cal.json, there is a calibration_generator.py script which prompts the user for all the necessary information and generates the cal.json file. Run the calibration_generator.py script as a sudo user and follow the prompts to create a cal.json file.
After the cal.json file has been generated, run the calibration_service.py script and go to localhost:9000/calibration to calibrate all the cameras after rapidsense_app and proxy are running. This script will pull in information from the cal.json file and make the robots move to the cal_targets sequentially, extrinsically calibrating all corresponding cameras. The robot will then return to the home location and all the cameras will save the pose of the static marker placed in the scene. After a successful calibration, all the values will be automatically updated in the cal.json file.
Current calibration implementation looks like this and follows these states:
Code Block |
---|
from state import *
from statemachine import StateMachine
from controller import Controller
class CalibrationSequence(StateMachine):
def __init__(self, steps, robot_name):
states = list()
for data in steps:
states.append(MoveToTarget(data["cal_target"]))
states.append(Calibrate(data["serial_number"]))
states.append(MoveToTarget(robot_name + "_home"))
states.append(StaticCalibrate("stationary"))
StateMachine.__init__(self, states, robot_name)
|
Info |
---|
Further details of components can be found in the section below: |
...
The following prerequisites should be met before running calibration:
|
Calibration ASCII Interface
...
During the calibration process, the static Aruco tag in the scene is found and the image is cached to compare against during system running in order to detect when the sensors may have been shifted out of calibration. When it is detected that a sensor may have been shifted out of calibration, GetRapidSenseStatus is set to false for Is_calibrated for that particular sensor in order to warn the user that the calibration needs to be adjusted and run again.
Sample cal.json File for (2) Sensors
Code Block |
---|
{ "calibration": [ { "extrinsics": [ 0.6799281765861674, 0.2802809975592367, -0.6775988772586244, 0.6467668192828412, 0.7295545356046743, -0.35158241966904175, 0.5866344469518174, -0.7283175603639641, -0.07380936334901554, -0.8932146044064257, -0.44353109067951274, 0.9372694073404532, 0.0, 0.0, 0.0, 1.0 ], "serial": "046322250262", "marker" : { "robot_mounted" : { "id": 6, "length": 0.0097, "robot" : "UR", "cal_target": "target_out69" }, "stationary" : { "id": 8, "length": 0.009, "pose" : [ 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0 ] } } }, { "extrinsics": [ 0.6799281765861674, 0.2802809975592367, -0.6775988772586244, 0.6467668192828412, 0.7295545356046743, -0.35158241966904175, 0.5866344469518174, -0.7283175603639641, -0.07380936334901554, -0.8932146044064257, -0.44353109067951274, 0.9372694073404532, 0.0, 0.0, 0.0, 1.0 ], "serial": "035322250884", "marker" : { "robot_mounted" : { "id": 6, "length": 0.0097, "robot" : "Fanuc", "cal_target": "_approach_1_1" }, "stationary" : { "id": 7, "length": 0.009, "pose" : [ 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0 ] } } } ] } |
Demo Video of Calibration
...