Hand–eye calibration problem
Robotics problem on coordinating two parts of a robot From Wikipedia, the free encyclopedia
Robotics problem on coordinating two parts of a robot From Wikipedia, the free encyclopedia
In robotics and mathematics, the hand–eye calibration problem (also called the robot–sensor or robot–world calibration problem) is the problem of determining the transformation between a robot end-effector and a sensor or sensors (camera or laser scanner) or between a robot base and the world coordinate system.[1] It is conceptually analogous to biological hand–eye coordination (hence the name). It takes the form of AX=ZB, where A and B are two systems, usually a robot base and a camera, and X and Z are unknown transformation matrices. A highly studied special case of the problem occurs where X=Z, taking the form of the problem AX=XB. Solutions to the problem take the forms of several types of methods, including separable closed-form solutions, simultaneous closed-form solutions, and iterative solutions.[2] The covariance of X in the equation can be calculated for any randomly perturbed matrices A and B.[3]
The problem is an important part of robot calibration, with efficiency and accuracy of the solutions determining the speed accuracy of the calibrations of robots.
Many different methods and solutions developed to solve the problem, broadly defined as either separable, simultaneous solutions. Each type of solution has specific advantages and disadvantages as well as formulations and applications to the problem. A common theme throughout all of the methods is the common use of quaternions to represent rotations.
Given the equation AX=ZB, it is possible to decompose the equation into a purely rotational and translational part; methods utilizing this are referred to as separable methods. Where RA represents a 3×3 rotation matrix and tA a 3×1 translation vector, the equation can be broken into two parts:[4]
The second equation becomes linear if RZ is known. As such, the most frequent approach is to solve for Rx and Rz using the first equation, then using Rz to solve for the variables in the second equation. Rotation is represented using quaternions, allowing for a linear solution to be found. While separable methods are useful, any error in the estimation for the rotation matrices is compounded when being applied to the translation vector.[5] Other solutions avoid this problem.
Simultaneous solutions are based on solving for both X and Z at the same time (rather than basing the solution of one part off of the other as in separable solutions), propagation of error is significantly reduced.[6] By formulating the matrices as dual quaternions, it is possible to get a linear equation by which X is solvable in a linear format.[5] An alternative way applies the least-squares method to the Kronecker product of the matrices A⊗B. As confirmed by experimental results, simultaneous solutions have less error than separable quaternion solutions.[6]
Iterative solutions are another method used to solve the problem of error propagation. One example of an iterative solution is a program based on minimizing ||AX−XB||. As the program iterates, it will converge on a solution to X independent to the initial robot orientation of RB. Solutions can also be two-step iterative processes, and like simultaneous solutions can also decompose the equations into dual quaternions.[7] However, while iterative solutions to the problem are generally simultaneous and accurate, they can be computationally taxing to carry out and may not always converge on the optimal solution.[5]
The matrix equation AX=XB, where X is unknown, has an infinitive number of solutions that can be easily studied by a geometrical approach.[8] To find X it is necessary to consider a simultaneous set of 2 equations A1X=XB1 and A2X=XB2; the matrices A1, A2, B1, B2 have to be dermined by experiments to be performed in an optimized way. [9]
where represents the unknown coordinate of the point in the robot base system, represent the known relationship between the robot base system and end-effector, are the unknown relationship between the end-effector and the scanner, and is the known coordinate of the point in the local scanner system. Methods are as follows,
There is a method using straight edges for hand-eye calibration.[10]
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.