CSCE 641: Forward kinematics and inverse kinematics Jinxiang Chai.

Slides:



Advertisements
Similar presentations
COMP Robotics: An Introduction
Advertisements

Animating Speed Position and Orientation Presented by Kailash Sawant Hemanth Krishnamachari.
Inverse Kinematics Professor Nicola Ferrier ME 2246,
Outline: Introduction Link Description Link-Connection Description
Manipulator Dynamics Amirkabir University of Technology Computer Engineering & Information Technology Department.
Manipulator’s Inverse kinematics
Review: Homogeneous Transformations
Animation Following “Advanced Animation and Rendering Techniques” (chapter 15+16) By Agata Przybyszewska.
Forward and Inverse Kinematics CSE 3541 Matt Boggus.
Trajectory Generation
Inverse Kinematics Set goal configuration of end effector
CSCE 641: Forward kinematics and inverse kinematics Jinxiang Chai.
1Notes  Handing assignment 0 back (at the front of the room)  Read the newsgroup!  Planning to put 16mm films on the web soon (possibly tomorrow)
1Notes  Assignment 0 marks should be ready by tonight (hand back in class on Monday)
Motion Editing and Retargetting Jinxiang Chai. Outline Motion editing [video, click here]here Motion retargeting [video, click here]here.
Introduction to Robotics
Ch. 7: Dynamics.
Methods For Nonlinear Least-Square Problems
“Inverse Kinematics” The Loop Closure Problem in Biology Barak Raveh Dan Halperin Course in Structural Bioinformatics Spring 2006.
Ch. 3: Forward and Inverse Kinematics
IK: Choose these angles!
Kinematics. ILE5030 Computer Animation and Special Effects2 Kinematics The branch of mechanics concerned with the motions of objects without regard to.
Introduction to ROBOTICS
CSCE 689: Forward Kinematics and Inverse Kinematics
Animation CS 551 / 651 Kinematics Lecture 09 Kinematics Sarcos Humanoid.
Serial and Parallel Manipulators
Introduction to ROBOTICS
Inverse Kinematics Jacobian Matrix Trajectory Planning
1cs426-winter-2008 Notes  SIGGRAPH crunch time - my apologies :-)
역운동학의 구현과 응용 Implementation of Inverse Kinematics and Application 서울대학교 전기공학부 휴먼애니메이션연구단 최광진
ME/ECE Professor N. J. Ferrier Forward Kinematics Professor Nicola Ferrier ME Room 2246,
Advanced Graphics (and Animation) Spring 2002
Definition of an Industrial Robot
Computer Animation Rick Parent Computer Animation Algorithms and Techniques Kinematic Linkages.
Chap 5 Kinematic Linkages
Inverse Kinematics Kris Hauser
Lecture 2: Introduction to Concepts in Robotics
Chapter 2 Robot Kinematics: Position Analysis
Inverse Kinematics.
INVERSE KINEMATICS ANALYSIS TRAJECTORY PLANNING FOR A ROBOT ARM Proceedings of th Asian Control Conference Kaohsiung, Taiwan, May 15-18, 2011 Guo-Shing.
Chapter 5 Trajectory Planning 5.1 INTRODUCTION In this chapters …….  Path and trajectory planning means the way that a robot is moved from one location.
Chapter 5 Trajectory Planning 5.1 INTRODUCTION In this chapters …….  Path and trajectory planning means the way that a robot is moved from one location.
1 Fundamentals of Robotics Linking perception to action 2. Motion of Rigid Bodies 南台科技大學電機工程系謝銘原.
CSCE 441: Computer Graphics Forward/Inverse kinematics Jinxiang Chai.
Inverting the Jacobian and Manipulability
Review: Differential Kinematics
CS-378: Game Technology Lecture #13: Animation Prof. Okan Arikan University of Texas, Austin Thanks to James O’Brien, Steve Chenney, Zoran Popovic, Jessica.
Kinematics. The function of a robot is to manipulate objects in its workspace. To manipulate objects means to cause them to move in a desired way (as.
1cs426-winter-2008 Notes  Will add references to splines on web page.
Just a quick reminder with another example
Outline: Introduction Solvability Manipulator subspace when n<6
Trajectory Generation
Robotics II Copyright Martin P. Aalund, Ph.D.
Rick Parent - CIS681 Reaching and Grasping Reaching control synthetic human arm to reach for object or position in space while possibly avoiding obstacles.
1cs426-winter-2008 Notes. 2 Kinematics  The study of how things move  Usually boils down to describing the motion of articulated rigid figures Things.
CSCE 441: Computer Graphics Forward/Inverse kinematics Jinxiang Chai.
COMP322/S2000/L111 Inverse Kinematics Given the tool configuration (orientation R w and position p w ) in the world coordinate within the work envelope,
Fundamentals of Computer Animation
Robotics Chapter 3 – Forward Kinematics
Kinematics 제어시스템 이론 및 실습 조현우
CSCE 441: Computer Graphics Forward/Inverse kinematics
Trajectory Generation
Character Animation Forward and Inverse Kinematics
INVERSE MANIPULATOR KINEMATICS
CSCE 441: Computer Graphics Forward/Inverse kinematics
Manipulator Dynamics 2 Instructor: Jacob Rosen
Computer Animation Algorithms and Techniques
Outline: Introduction Solvability Manipulator subspace when n<6
Chapter 4 . Trajectory planning and Inverse kinematics
CHAPTER 3-2. Planar Cartesian Kinematics
Presentation transcript:

CSCE 641: Forward kinematics and inverse kinematics Jinxiang Chai

Outline Kinematics –Forward kinematics –Inverse kinematics

Required Readings IK survey paper IK using nonlinear programming

Kinematics The study of movement without the consideration of the masses or forces that bring about the motion

Degrees of freedom (Dofs) The set of independent displacements that specify an object’s pose

Degrees of freedom (Dofs) The set of independent displacements that specify an object’s pose How many degrees of freedom when flying?

Degrees of freedom (Dofs) The set of independent displacements that specify an object’s pose How many degrees of freedom when flying? So the kinematics of this airplane permit movement anywhere in three dimensions Six x, y, and z positions roll, pitch, and yaw

Degrees of Freedom How about this robot arm? Six again 2-base, 1-shoulder, 1-elbow, 2-wrist

Work Space vs. Configuration Space Work space –The space in which the object exists –Dimensionality R 3 for most things, R 2 for planar arms Configuration space –The space that defines the possible object configurations –Degrees of Freedom The number of parameters that are necessary and sufficient to define position in configuration

Forward vs. Inverse Kinematics Forward Kinematics –Compute configuration (pose) given individual DOF values Inverse Kinematics –Compute individual DOF values that result in specified end effector position

Example: Two-link Structure Two links connected by rotational joints Base End Effector θ2θ2 θ1θ1 X=(x,y) l2l2 l1l1

Example: Two-link Structure Animator specifies the joint angles: θ 1 θ 2 Computer finds the position of end-effector: x Base End Effector θ2θ2 θ1θ1 x=f(θ 1, θ 2 ) l2l2 l1l1 (0,0) X=(x,y)

Example: Two-link Structure Animator specifies the joint angles: θ 1 θ 2 Computer finds the position of end-effector: x Base End Effector θ2θ2 θ1θ1 x = (l 1 cosθ 1 +l 2 cos(θ 2 + θ 2 ) y = l 1 sinθ 1 +l 2 sin(θ 2 + θ 2 )) (0,0) θ2θ2 l2l2 l1l1 X=(x,y)

Forward kinematics Base End Effector θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 Create an animation by specifying the joint angle trajectories θ1θ1 θ2θ2 X=(x,y)

Inverse kinematics What if an animator specifies position of end- effector? Base End Effector θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 X=(x,y)

Inverse kinematics Animator specifies the position of end-effector: x Computer finds joint angles: θ 1 θ 2 Base End Effector θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 (θ 1, θ 2 )=f -1 (x) X=(x,y)

Inverse kinematics Animator specifies the position of end-effector: x Computer finds joint angles: θ 1 θ 2 Base End Effector θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 X=(x,y)

Why Inverse Kinematics? Basic tools in character animation - key frame generation - animation control - interactive manipulation Computer vision (vision based mocap) Robotics Bioinfomatics (Protein Inverse Kinematics)

Inverse kinematics Given end effector position, compute required joint angles In simple case, analytic solution exists –Use trig, geometry, and algebra to solve

Inverse kinematics Analytical solution only works for a fairly simple structure Iterative approach needed for a complex structure

Iterative approach Inverse kinematics can be formulated as an optimization problem

Iterative approaches Find the joint angles θ that minimizes the distance between the character position and user specified position Base θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 C=(Cx,Cy)

Iterative approaches Find the joint angles θ that minimizes the distance between the character position and user specified position Base θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 C=(c 1,c 2 )

Iterative approach Mathematically, we can formulate this as an optimization problem: The above problem can be solved by many nonlinear optimization algorithms: - Steepest descent - Gauss-newton - Levenberg-marquardt, etc

Gauss-newton approach Step 1: initialize the joint angles with Step 2: update the joint angles:

Gauss-newton approach Step 1: initialize the joint angles with Step 2: update the joint angles: How can we decide the amount of update?

Gauss-newton approach Step 1: initialize the joint angles with Step 2: update the joint angles:

Gauss-newton approach Step 1: initialize the joint angles with Step 2: update the joint angles: Known!

Gauss-newton approach Step 1: initialize the joint angles with Step 2: update the joint angles: Taylor series expansion

Gauss-newton approach Step 1: initialize the joint angles with Step 2: update the joint angles: Taylor series expansion rearrange

Gauss-newton approach Step 1: initialize the joint angles with Step 2: update the joint angles: Taylor series expansion rearrange Can you solve this optimization problem?

Gauss-newton approach Step 1: initialize the joint angles with Step 2: update the joint angles: Taylor series expansion rearrange This is a quadratic function of

Gauss-newton approach Optimizing an quadratic function is easy It has an optimal value when the gradient is zero

Gauss-newton approach Optimizing an quadratic function is easy It has an optimal value when the gradient is zero b J Δθ Linear equation!

Gauss-newton approach Optimizing an quadratic function is easy It has an optimal value when the gradient is zero b J Δθ

Gauss-newton approach Optimizing an quadratic function is easy It has an optimal value when the gradient is zero b J Δθ

Jacobian matrix Jacobian is a M by N matrix that relates differential changes of θ to changes of C Jacobian maps the velocites in joint space to velocities in Cartesian space Jacobian depends on current state Dofs (N) The number of constraints (M)

Jacobian matrix Jacobian maps the velocity in joint angle space to velocities in Cartesian space (x,y) θ1θ1 θ2θ2

Jacobian matrix Jacobian maps the velocity in joint angle space to velocities in Cartesian space (x,y) θ1θ1 θ2θ2 A small change of θ 1 and θ 2 results in how much change of end-effector position (x,y)

Jacobian matrix Jacobian maps the velocity in joint angle space to velocities in Cartesian space (x,y) θ1θ1 θ2θ2 A small change of θ 1 and θ 2 results in how much change of end-effector position (x,y)

Jacobian matrix Jacobian maps the velocity in joint angle space to velocities in Cartesian space (x,y) θ1θ1 θ2θ2 The ratio between angular velocities and linear velocities

Jacobian matrix: 2D-link structure Base θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 C=(c 1,c 2 )

Jacobian matrix: 2D-link structure Base θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 C=(c 1,c 2 ) f1f1 f2f2

Jacobian matrix: 2D-link structure Base θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 C=(c 1,c 2 )

Jacobian matrix: 2D-link structure Base θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 C=(c 1,c 2 )

Jacobian matrix: 2D-link structure Base θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 C=(c 1,c 2 )

Jacobian matrix: 2D-link structure Base θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 C=(c 1,c 2 )

Jacobian matrix: 2D-link structure Base θ2θ2 θ1θ1 (0,0) θ2θ2 l2l2 l1l1 C=(c 1,c 2 )

Gauss-newton approach Step 1: initialize the joint angles with Step 2: update the joint angles: Step size: specified by the user

Another Example A 2D lamp character 50

Composite 2D Transformation What’s the current coordinate A ? 51

More Complex Characters? A 2D lamp with 6 degrees of freedom base Upper arm lower arm middle arm If you do inverse kinematics with position of this point What’s the size of Jacobian matrix?

More Complex Characters? A 2D lamp with 6 degrees of freedom base Upper arm lower arm middle arm If you do inverse kinematics with position of this point What’s the size of Jacobian matrix? 2-by-6 matrix

More Complex Characters? How to compute the Jacobian matrix, e.g. base Upper arm lower arm middle arm

More Complex Characters? How to compute the Jacobian matrix, e.g. base Upper arm lower arm middle arm The ratio between angular velocities and linear velocities!

More Complex Characters? base The ratio between angular velocities and linear velocities! Rotation axis v 2 How to compute the Jacobian matrix, e.g.

More Complex Characters? base The ratio between angular velocities and linear velocities! x Rotation axis v 2 How to compute the Jacobian matrix, e.g. From college physics

More Complex Characters? base The ratio between linear velocities and linear velocities! - For more details, check the paper from required readings How to compute the Jacobian matrix, e.g.

Human Characters 59

Inverse kinematics Analytical solution only works for a fairly simple structure Iterative approach needed for a complex structure

Inverse kinematics Is the solution unique? Is there always a good solution?

Ambiguity of IK Multiple solutions

Ambiguity of IK Infinite solutions

Failures of IK Solution may not exist

Inverse kinematics Generally ill-posed problem when the number of Dofs is higher than the number of constraints

Inverse kinematics Generally ill-posed problem when the number of Dofs is higher than the number of constraints Additional objective –Minimal Change from a reference pose θ 0

Inverse kinematics Generally ill-posed problem when the number of Dofs is higher than the number of constraints Additional objective –Minimal Change from a reference pose θ 0

Inverse kinematics Generally ill-posed problem when the number of Dofs is higher than the number of constraints Additional objective –Minimal Change from a reference pose θ 0 Satisfy the constraints Minimize the difference between the solution and a reference pose

Inverse kinematics Generally ill-posed problem when the number of Dofs is higher than the number of constraints Additional objective –Minimal Change from a reference pose θ 0 –Naturalness g(θ) (particularly for human characters)

Inverse kinematics Generally ill-posed problem when the number of Dofs is higher than the number of constraints Additional objective –Minimal Change from a reference pose θ 0 –Naturalness g(θ) (particularly for human characters)

Inverse kinematics Generally ill-posed problem when the Dofs is higher than the number of constraints Additional objective –Minimal Change from a reference pose θ 0 –Naturalness g(θ) (particularly for human characters) Satisfy the constraints How natural is the solution pose?

Interactive Human Character Posing video