CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Lecture VII Rigid Body Dynamics CS274: Computer Animation and Simulation
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Rigid Bodies Rigid bodies have both a position and orientation Rigid bodies assume no object deformation Rigid body motion is represented by 2 parameters - center of mass - orientation (rotation matrix)
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Rigid Bodies Objects are defined in body space and transformed by the position and orientation into world space
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Linear Velocity The change of the center of mass over time For a pure translation ( constant), all points move with velocity
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Angular Velocity The change in orientation over time Encodes both the axis and speed of the rotation direction encodes the axis magnitude encodes the speed (rad/s) But, how are and related?
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Angular Velocity For a given vector The columns of represent the transformed axes
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer We can represent the cross product with a matrix Angular Velocity Therefore
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Since a point can be represented at any time by Velocity of a Point Total velocity can then be expressed as Which can be rewritten as
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer We can apply forces to the object at any point Force Total force on an object is simply No information about where the forces are applied
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Torque describes the “rotational force” Torque Total torque on an object is simply Tells us about the force distribution over the object
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Linear momentum of a particle is Linear Momentum Linear momentum of a rigid body is then density integration over the body
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Linear momentum can be simplified as follows Linear Momentum Assuming constant mass gives
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Angular momentum of a rigid body Angular Momentum Taking the time derivative inertia tensor Angular momentum is conserved for no torque
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Describes how mass is distributed in the body Inertia Tensor Analogous to mass in linear velocity Measures the preferred axis of rotation Expensive to compute this at every time step
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Rewrite the tensor as Inertia Tensor Integrals can now be precomputed
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Combining the equations Rigid Body Equations of Motion Discretize these continuous equations and integrate
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Use quaternions to represent orientation Using Quaternions The update rule is then
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Using quaternions gives Rigid Body Equations of Motion Discretize these continuous equations and integrate
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer So far, no interaction between rigid bodies Collisions and Contact Collision detection – determining if, when and where a collision occurs Collision response – calculating the state (velocity, …) after the collision
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer What should we do when there is a collision? Collisions and Contact
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Restart the simulation at the time of the collision Rolling Back the Simulation Collision time can be found by bisection, etc.
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Exploit coherency through witnessing Collision Detection Speed up with bounding boxes, grids, hierarchies, etc. separating plane Two convex objects are non-penetrating iff there exists a separating plane between them First find a separating plane and see if it is still valid after the next simulation step
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Conditions for collision Collision Detection separatingcontactcolliding
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Soft Body Collision Collision Force is applied to prevent interpenetration
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Soft Body Collision Collision Apply forces and change the velocity
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Harder Collision Collision Higher force over a shorter time
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Rigid Body Collision Collision Impulsive force produces a discontinuous velocity
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer We need to change velocity instantaneously Impulse Infinite force in an infinitesimal time An impulse changes the velocity as or
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer An impulse also creates an impulsive torque Impulse The impulsive torque changes the angular velocity or
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer For a frictionless collision Impulse But how do we calculate ?
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer For a frictionless collision Impulse Given this equation and knowing how affects the linear and angular velocities of the two bodies, we can solve for
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Bodies are neither colliding nor separating Resting Contact We want a force strong enough to resist penetration but only enough to maintain contact
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer We want to prevent interpenetration Resting Contact Since we should keep it from decreasing Describes the objects’ acceleration towards one another
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Contact forces only act in the normal direction Resting Contact Contact forces should avoid interpenetration be repulsive workless force become zero if the bodies begin to separate
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer The relative accelerations can be written in terms of all of the contact forces Resting Contact So we can simply solve a Quadratic Program to find the solution to all the constraints
CS274 Spring 01 Lecture 7 Copyright © Mark Meyer Algorithm with collisions and contact Simulation Algorithm compute new statedetect collisions and backtrack compute and apply impulses compute and apply constraint forces current state next state collision state post-collision state