Misplaced Pages

Forward kinematics

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Computing a robot's end-effector position from joint values and kinematic equations
An articulated six DOF robotic arm uses forward kinematics to position the gripper.
The forward kinematics equations define the trajectory of the end-effector of a PUMA robot reaching for parts.

In robot kinematics, forward kinematics refers to the use of the kinematic equations of a robot to compute the position of the end-effector from specified values for the joint parameters.

The kinematics equations of the robot are used in robotics, computer games, and animation. The reverse process, that computes the joint parameters that achieve a specified position of the end-effector, is known as inverse kinematics.

Forward vs Backwards Kinematics

Kinematics equations

The kinematics equations for the series chain of a robot are obtained using a rigid transformation to characterize the relative movement allowed at each joint and separate rigid transformation to define the dimensions of each link. The result is a sequence of rigid transformations alternating joint and link transformations from the base of the chain to its end link, which is equated to the specified position for the end link,

[ T ] = [ Z 1 ] [ X 1 ] [ Z 2 ] [ X 2 ] [ X n 1 ] [ Z n ] , {\displaystyle =\ldots ,\!}

where is the transformation locating the end-link. These equations are called the kinematics equations of the serial chain.

Link transformations

In 1955, Jacques Denavit and Richard Hartenberg introduced a convention for the definition of the joint matrices and link matrices to standardize the coordinate frame for spatial linkages. This convention positions the joint frame so that it consists of a screw displacement along the Z-axis

[ Z i ] = Trans Z i ( d i ) Rot Z i ( θ i ) , {\displaystyle =\operatorname {Trans} _{Z_{i}}(d_{i})\operatorname {Rot} _{Z_{i}}(\theta _{i}),}

and it positions the link frame so it consists of a screw displacement along the X-axis,

[ X i ] = Trans X i ( a i , i + 1 ) Rot X i ( α i , i + 1 ) . {\displaystyle =\operatorname {Trans} _{X_{i}}(a_{i,i+1})\operatorname {Rot} _{X_{i}}(\alpha _{i,i+1}).}

Using this notation, each transformation-link goes along a serial chain robot, and can be described by the coordinate transformation,

i 1 T i = [ Z i ] [ X i ] = Trans Z i ( d i ) Rot Z i ( θ i ) Trans X i ( a i , i + 1 ) Rot X i ( α i , i + 1 ) , {\displaystyle {}^{i-1}T_{i}==\operatorname {Trans} _{Z_{i}}(d_{i})\operatorname {Rot} _{Z_{i}}(\theta _{i})\operatorname {Trans} _{X_{i}}(a_{i,i+1})\operatorname {Rot} _{X_{i}}(\alpha _{i,i+1}),}

where θi, di, αi,i+1 and ai,i+1 are known as the Denavit-Hartenberg parameters.

Kinematics equations revisited

The kinematics equations of a serial chain of n links, with joint parameters θi are given by

[ T ] = 0 T n = i = 1 n i 1 T i ( θ i ) , {\displaystyle ={}^{0}T_{n}=\prod _{i=1}^{n}{}^{i-1}T_{i}(\theta _{i}),}

where i 1 T i ( θ i ) {\displaystyle {}^{i-1}T_{i}(\theta _{i})} is the transformation matrix from the frame of link i {\displaystyle i} to link i 1 {\displaystyle i-1} . In robotics, these are conventionally described by Denavit–Hartenberg parameters.

Denavit-Hartenberg matrix

The matrices associated with these operations are:

Trans Z i ( d i ) = [ 1 0 0 0 0 1 0 0 0 0 1 d i 0 0 0 1 ] , Rot Z i ( θ i ) = [ cos θ i sin θ i 0 0 sin θ i cos θ i 0 0 0 0 1 0 0 0 0 1 ] . {\displaystyle \operatorname {Trans} _{Z_{i}}(d_{i})={\begin{bmatrix}1&0&0&0\\0&1&0&0\\0&0&1&d_{i}\\0&0&0&1\end{bmatrix}},\quad \operatorname {Rot} _{Z_{i}}(\theta _{i})={\begin{bmatrix}\cos \theta _{i}&-\sin \theta _{i}&0&0\\\sin \theta _{i}&\cos \theta _{i}&0&0\\0&0&1&0\\0&0&0&1\end{bmatrix}}.}

Similarly,

Trans X i ( a i , i + 1 ) = [ 1 0 0 a i , i + 1 0 1 0 0 0 0 1 0 0 0 0 1 ] , Rot X i ( α i , i + 1 ) = [ 1 0 0 0 0 cos α i , i + 1 sin α i , i + 1 0 0 sin α i , i + 1 cos α i , i + 1 0 0 0 0 1 ] . {\displaystyle \operatorname {Trans} _{X_{i}}(a_{i,i+1})={\begin{bmatrix}1&0&0&a_{i,i+1}\\0&1&0&0\\0&0&1&0\\0&0&0&1\end{bmatrix}},\quad \operatorname {Rot} _{X_{i}}(\alpha _{i,i+1})={\begin{bmatrix}1&0&0&0\\0&\cos \alpha _{i,i+1}&-\sin \alpha _{i,i+1}&0\\0&\sin \alpha _{i,i+1}&\cos \alpha _{i,i+1}&0\\0&0&0&1\end{bmatrix}}.}

The use of the Denavit-Hartenberg convention yields the link transformation matrix, as

i 1 T i = [ cos θ i sin θ i cos α i , i + 1 sin θ i sin α i , i + 1 a i , i + 1 cos θ i sin θ i cos θ i cos α i , i + 1 cos θ i sin α i , i + 1 a i , i + 1 sin θ i 0 sin α i , i + 1 cos α i , i + 1 d i 0 0 0 1 ] , {\displaystyle \operatorname {} ^{i-1}T_{i}={\begin{bmatrix}\cos \theta _{i}&-\sin \theta _{i}\cos \alpha _{i,i+1}&\sin \theta _{i}\sin \alpha _{i,i+1}&a_{i,i+1}\cos \theta _{i}\\\sin \theta _{i}&\cos \theta _{i}\cos \alpha _{i,i+1}&-\cos \theta _{i}\sin \alpha _{i,i+1}&a_{i,i+1}\sin \theta _{i}\\0&\sin \alpha _{i,i+1}&\cos \alpha _{i,i+1}&d_{i}\\0&0&0&1\end{bmatrix}},}

known as the Denavit-Hartenberg matrix.

Computer animation

This section does not cite any sources. Please help improve this section by adding citations to reliable sources. Unsourced material may be challenged and removed. (July 2014) (Learn how and when to remove this message)

The forward kinematic equations can be used as a method in 3D computer graphics for animating models.

The essential concept of forward kinematic animation is that the positions of particular parts of the model at a specified time are calculated from the position and orientation of the object, together with any information on the joints of an articulated model. So for example if the object to be animated is an arm with the shoulder remaining at a fixed location, the location of the tip of the thumb would be calculated from the angles of the shoulder, elbow, wrist, thumb and knuckle joints. Three of these joints (the shoulder, wrist and the base of the thumb) have more than one degree of freedom, all of which must be taken into account. If the model were an entire human figure, then the location of the shoulder would also have to be calculated from other properties of the model.

Forward kinematic animation can be distinguished from inverse kinematic animation by this means of calculation - in inverse kinematics the orientation of articulated parts is calculated from the desired position of certain points on the model. It is also distinguished from other animation systems by the fact that the motion of the model is defined directly by the animator - no account is taken of any physical laws that might be in effect on the model, such as gravity or collision with other models.

See also

References

  1. Paul, Richard (1981). Robot manipulators: mathematics, programming, and control : the computer control of robot manipulators. MIT Press, Cambridge, Massachusetts. ISBN 978-0-262-16082-7.
  2. J. M. McCarthy, 1990, Introduction to Theoretical Kinematics, MIT Press, Cambridge, Massachusetts.
  3. J. Denavit and R.S. Hartenberg, 1955, "A kinematic notation for lower-pair mechanisms based on matrices." Trans ASME J. Appl. Mech, 23:215–221.
  4. Hartenberg, R. S., and J. Denavit. Kinematic Synthesis of Linkages. New York: McGraw-Hill, 1964 on-line through KMODDL
  5. Jennifer Kay. "Introduction to Homogeneous Transformations & Robot Kinematics" (PDF). Archived from the original (PDF) on 2021-04-12. Retrieved 2010-09-11.
  6. Learn About Robots. "Robot Forward Kinematics". Retrieved 2007-02-01.
Categories: