Links and Joints Links and Joints Links Joints: End Effector 2 DOF’s Robot Basis Denavit – Hartenberg details and examples DENAVIT-HARTENBERG REPRESENTATION Chapter 2 Symbol Terminologies : Robot Kinematics: Position Analysis ⊙ : A rotation about the z-axis. ⊙ d : The distance on the z-axis. ⊙ a : The length of each common normal (Joint offset). ⊙ : The angle between two successive z-axes (Joint twist) Only and d are joint variables. Joints U Links S Z-axis aligned with joint X-axis aligned with outgoing limb Y-axis is orthogonal Joints are numbered to represent hierarchy Ui-1 is parent of Ui Parameter ai-1 is outgoing limb length of joint Ui-1 Joint angle, i, is rotation of xi-1 about zi1 relative to xi Link twist, i-1, is the rotation of ith z-axis about xi-1-axis relative to z-axis of i-1th frame Link offset, di-1, specifies the distance along the zi-1-axis (rotated by i-1) of the ith frame from the i-1th x-axis to the ith x-axis DENAVIT-HARTENBERG REPRESENTATION PROCEDURES Start point: • Assign joint number n to the first shown joint. • Assign a local reference frame for each and every joint before or after these joints. • Y-axis is not used in D-H representation. DENAVIT-HARTENBERG REPRESENTATION Procedures for assigning a local reference frame to each joint: 1. ٭All joints are represented by a z-axis. • (right-hand rule for rotational joint, linear movement for prismatic joint) 2. The common normal is one line mutually perpendicular to any two skew lines. 3. Parallel z-axes joints make a infinite number of common normal. 4. Intersecting z-axes of two successive joints make no common normal between them(Length is 0.). DENAVIT-HARTENBERG ChapterREPRESENTATION 2 Robot Kinematics: Positionto Analysis The necessary motions transform from one reference frame to the next. (I) Rotate about the zn-axis an able of n+1. (Coplanar) (II) Translate along zn-axis a distance of dn+1 to make xn and xn+1 colinear. (III) Translate along the xn-axis a distance of an+1 to bring the origins of xn+1 together. (IV) Rotate zn-axis about xn+1 axis an angle of n+1 to align zn-axis with zn+1-axis. Denavit Hartenberg Parameters – a general explanation Denavit-Hartenberg Notation Only and d are joint variables Z(i - 1) Y(i -1) Yi Zi Xi a(i - 1 ) X(i -1) ai di i ( i - 1) • IDEA: Each joint is assigned a coordinate frame. • Using the Denavit-Hartenberg notation, you need 4 parameters to describe how a frame (i) relates to a previous frame ( i -1 ). ⊙ : A rotation about the z-axis. • THE PARAMETERS/VARIABLES: ⊙ d : The distance on the z-axis. ⊙ a : The length of each common normal (Joint offset). ⊙ : The angle between two successive z-axes (Joint twist) , a , d, The a(i-1) Parameter Z(i - 1) Y(i -1) X(i -1) • 1) a(i-1) ( i - 1) Yi a(i - 1 ) Zi Xi di ai You can align the two axis just using the 4 parameters i • Technical Definition: a(i-1) is the length of the perpendicular between the joint axes. • The joint axes are the axes around which revolution takes place which are the Z(i-1) and Z(i) axes. • These two axes can be viewed as lines in space. • The common perpendicular is the shortest line between the two axis-lines and is perpendicular to both axis-lines. a(i-1) cont... The alpha a(i-1) Parameter Visual Approach - “A way to visualize the link parameter a(i-1) is to imagine an expanding cylinder whose axis is the Z(i-1) axis - when the cylinder just touches the joint axis i the radius of the cylinder is equal to a(i-1).” (Manipulator Kinematics) Z(i - 1) Y(i -1) Yi Zi Xi a(i - 1 ) X(i -1) ⊙ : A rotation about the z-axis. ( i - 1) ⊙ d : The distance on the z-axis. ⊙ a : The length of each common normal (Joint offset). ⊙ : The angle between two successive z-axes (Joint twist) ai di i • It’s Usually on the Diagram Approach If the diagram already specifies the various coordinate frames, then the common perpendicular is usually the X(i-1) axis. • So a(i-1) is just the displacement along the X(i-1) to move from the (i-1) frame to the i frame. • If the link is prismatic, then a(i-1) is a variable, not a parameter. Z(i - 1) Y(i -1) X(i -1) ( i - 1) ⊙ : A rotation about the z-axis. ⊙ d : The distance on the z-axis. ⊙ a : The length of each common normal (Joint offset). ⊙ : The angle between two successive z-axes (Joint twist) Yi a(i - 1 ) Zi Xi di ai i 2)(i-1) The (i-1) Parameter Technical Definition: Amount of rotation around the common perpendicular so that the joint axes are parallel. i.e. How much you have to rotate around the X(i-1) axis so that the Z(i-1) is pointing in the same direction as the Zi axis. Positive rotation follows the right hand rule. Z(i - 1) Y(i -1) X(i -1) ( i - 1) Yi a(i - 1 ) Zi Xi di ai i 3) d(i-1) The d(i-1) Parameter Technical Definition: The displacement along the Zi axis needed to align the a(i-1) common perpendicular to the ai common perpendicular. In other words, displacement along the Zi to align the X(i-1) and Xi axes. The i Parameter 4) i Amount of rotation around the Zi axis needed to align the X(i-1) axis with the Xi axis. Z(i - 1) Y(i -1) X(i -1) ( i - 1) The same table as last slide Yi Z i a(i - 1 ) Xi di ai i The Denavit-Hartenberg Matrix cosθ i sinθ i sinθ cosα cosθ i cosα (i 1) i (i 1) sinθ i sinα (i 1) cosθ i sinα (i 1) 0 0 0 sinα (i 1) cosα (i 1) 0 a(i 1) sinα (i 1)d i cosα (i 1)d i 1 Just like the Homogeneous Matrix, the Denavit-Hartenberg Matrix is a transformation matrix from one coordinate frame to the next. Using a series of D-H Matrix multiplications and the D-H Parameter table, the final result is a transformation matrix from some frame to your initial frame. Put the transformation here Z(i - Y(i - 1) 1) X(i - ⊙ : A rotation about the z-axis. ⊙ d : The distance on the z-axis. ⊙ a : The length of each common normal (Joint offset). ⊙ : The angle between two successive z-axes (Joint twist) ( i - 1) 1) Y Z i a(i - d 1) i i X a i i i Example: Calculating the final DH matrix with the DH Parameter Table Example with three Revolute Joints The DH Parameter Table Y2 Z1 Z0 X2 X0 d2 X1 Y0 Y1 a0 Denavit-Hartenberg Link Parameter Table a1 i (i-1) a(i-1) di i 1) To describe the robot with its variables and parameters. 0 0 0 0 0 2) To describe some state of the robot by having a numerical values for the variables. 1 0 a0 0 1 2 -90 a1 d2 2 Notice that the table has two uses: We calculate with respect to previous Example with three Revolute Joints Y2 Z1 Z0 X2 X0 d2 X1 Y0 Y1 a0 Denavit-Hartenberg Link Parameter Table a1 i (i-1) a(i-1) di i 1) To describe the robot with its variables and parameters. 0 0 0 0 0 2) To describe some state of the robot by having a numerical values for the variables. 1 0 a0 0 1 2 -90 a1 d2 2 Notice that the table has two uses: The same table as last slide Y2 Z1 Z0 X2 X0 X1 Y0 Y1 a0 i (i-1) a(i-1) di i 0 0 0 0 0 1 0 a0 0 1 2 -90 a1 d2 2 d2 a1 The same table as last slide V X 0 Y0 Z 0 World coordinates V X 2 Y2 V T Z V 2 1 tool coordinates T ( 0T)( 01T)( 12T) Note: T is the D-H matrix with (i-1) = 0 and i = 1. These matrices T are calculated in next slide The same table as last slide i (i-1) a(i-1) di i 0 0 0 0 0 1 0 a0 0 1 2 cosθ1 sinθ 1 0 T 1 0 0 -90 a1 sinθ1 cosθ1 0 0 d2 2 0 a0 0 0 0 0 0 1 This is a translation by a0 followed by a rotation around the Z1 axis cosθ 0 sinθ 0 sinθ cosθ 0 0 0T 0 0 0 0 0 0 0 0 1 0 0 1 This is just a rotation around the Z0 axis cosθ 2 0 1 2T sinθ 2 0 sinθ 2 0 cosθ 2 0 0 a1 1 d 2 0 0 0 1 This is a translation by a1 and then d2 followed by a rotation around the X2 and Z2 axis T ( 0T)( 01T)( 12T) Conclusions V X 0 Y0 Z 0 World coordinates V X 2 Y2 V T Z V 2 1 tool coordinates T ( 0T)( 01T)( 12T) Forward Kinematics Forward Kinematics Problem The Situation: You have a robotic arm that starts out aligned with the xo-axis. You tell the first link to move by 1 and the second link to move by 2. The Quest: What is the position of the end of the robotic arm? Solution: 1. Geometric Approach This might be the easiest solution for the simple situation. However, notice that the angles are measured relative to the direction of the previous link. (The first link is the exception. The angle is measured relative to it’s initial position.) For robots with more links and whose arm extends into 3 dimensions the geometry gets much more tedious. 2. Algebraic Approach Involves coordinate transformations. Example Problem with H matrices: 2. 3. 4. 1. You have a three link arm that starts out aligned in the x-axis. Each link has lengths l1, l2, l3, respectively. You tell the first one to move by 1 , and so on as the diagram suggests. Find the Homogeneous matrix to get the position of the yellow dot in the X0Y0 frame. Y3 3 Y2 2 l2 X3 l3 X2 H = Rz( 1 ) * Tx1(l1) * Rz( 2 ) * Tx2(l2) * Rz( 3 ) Y0 1. 2. 3. 4. l1 1 Rotating by 1 will put you in the X1Y1 frame. Translate in the along the X1 axis by l1. Rotating by 2 will put you in the X2Y2 frame. and so on until you are in the X3Y3 frame. X0 • The position of the yellow dot relative to the X3Y3 frame is (l3, 0). • Multiplying H by that position vector will give you the coordinates of the yellow point relative the X0Y0 frame. Slight variation on the last solution: Make the yellow dot the origin of a new coordinate X4Y4 frame Y3 Y4 3 2 Y2 2 3 X3 added X2 X4 H = Rz( Y0 1 1 ) * Tx1(l1) * Rz( 2 ) * Tx2(l2) * Rz( 3 ) * Tx3(l3) This takes you from the X0Y0 frame to the X4Y4 frame. 1 X0 X 0 Y 0 H Z 0 1 1 The position of the yellow dot relative to the X4Y4 frame is (0,0). THE INVERSE KINEMATIC SOLUTION OF A ROBOT THE INVERSE KINEMATIC SOLUTION OF ROBOT Determine the value of each joint to place the arm at a desired position and orientation. TH A1 A2 A3 A4 A5 A6 R C1 (C234C5C6 S 234S 6 ) S S C 1 5 6 S1 (C234C5C6 S 234S 6 ) C1S5C6 S 234C5C6 C234S 6 0 nx n y nz 0 ox a x p x o y a y p y oz a z p z 0 0 1 RHS C1 (C234C5C6 S 234C6 ) C1 (C234S5 ) S1C5 C1 (C234a4 C23a3 C2 a2 ) S1S5C6 S1 (C234C5C6 S 234C6 ) S1 (C234S5 ) C1C5 S1 (C234a4 C23a3 C2 a2 ) C1S5C6 S 234C5C6 C234C6 S 234S5 S 234a4 S 23a3 S 2 a2 0 0 1 Multiply both sides by A1 -1 THE INVERSE KINEMATIC SOLUTION OF ROBOT nx n 1 y A1 nz 0 ox a x p x oy a y p y A11[ RHS ] A2 A3 A4 A5 A6 oz a z p z 0 0 1 C1 S1 0 0 S1 C1 0 0 A1 -1 0 n x 0 n y 0 n z 0 1 0 0 1 0 ox a x p x oy a y p y A2 A3 A4 A5 A6 oz a z p z 0 0 1 THE INVERSE KINEMATIC SOLUTION OF ROBOT We calculate all angles from px, py, a1, a2, ni, oi, etc py px 1 tan 1 2 tan 1 (C3a3 a2 )( pz S 234a4 ) S3a3 ( pxC1 p y S1 C234a4 ) (C3a3 a2 )( pxC1 p y S1 C234a4 ) S3a3 ( Pz S 234a4 ) S3 C 3 3 tan 1 4 234 2 3 5 tan 1 C234 (C1ax S1a y ) S 234az S1ax C1a y 6 tan 1 S 234 (C1nx S1n y ) S 234nz S 234 (C1ox S1o y ) C234oz INVERSE KINEMATIC PROGRAM: a predictable path on a straight line A robot has a predictable path on a straight line, Or an unpredictable path on a straight line. ٭A predictable path is necessary to recalculate joint variables. (Between 50 to 200 times a second) ٭To make the robot follow a straight line, it is necessary to break the line into many small sections. ٭All unnecessary computations should be eliminated. Fig. 2.30 Small sections of movement for straightline motions PROBLEMS with DH DEGENERACY AND DEXTERITY Degeneracy : The robot looses a degree of freedom and thus cannot perform as desired. ٭When the robot’s joints reach their physical limits, and as a result, cannot move any further. ٭In the middle point of its workspace if the z-axes of two similar joints becomes collinear. Dexterity : The volume of points where one can position the robot as desired, but not orientate it. Fig. 2.31 An example of a robot in a degenerate position. THE FUNDAMENTAL PROBLEM WITH D-H REPRESENTATION Defect of D-H presentation : D-H cannot represent any motion about the y-axis, because all motions are about the x- and z-axis. TABLE 2.3 THE PARAMETERS TABLE FOR THE STANFORD ARM Fig. 2.31 The frames of the Stanford Arm. # d a 1 1 0 0 -90 2 2 d1 0 90 3 0 d1 0 0 4 4 0 0 -90 5 5 0 0 90 6 6 0 0 0