 
              Reading Required: � Angel, sections 9.1 – 9.6, 9.8 Optional: � OpenGL Programming Guide , the Red Book, chapter 3 Hierarchical Modeling cse457-07-hierarchical 1 cse457-07-hierarchical 2 Symbols and instances Most graphics APIs support a few geometric primitives : � spheres, cubes, cylinders these procedures define points for you, but they're still � just points P These symbols are instanced using an instance transformation . the points are originally defined in a local coordinate � system (eg, unit cube) TRSP RSP SP P translated rotated scaled points to draw Q: What is the matrix for the instance transformation above? cse457-07-hierarchical 3 cse457-07-hierarchical 4
Connecting primitives 3D Example: A robot arm Consider this robot arm with 3 degrees of freedom: � Base rotates about its vertical axis by θ � Lower arm rotates in its xy -plane by φ � Upper arm rotates in its xy -plane by ψ P P Upper arm Lower arm h 2 h 3 h 1 Base Q: What matrix do we use to transform the base? Q: What matrix for the upper arm? Q: What matrix for the lower arm? cse457-07-hierarchical 5 cse457-07-hierarchical 6 Robot arm implementation The robot arm can be displayed by keeping a global matrix and computing it at each step: Matrix M_model; main() { . . . robot_arm(); . . . } robot_arm() { M_model = R_y(theta); base(); M_model = R_y(theta)*T(0,h1,0)*R_z(phi); lower_arm(); M_model = R_y(theta)*T(0,h1,0)*R_z(phi) *T(0,h2,0)*R_z(psi); upper_arm(); } Do the matrix computations seem a tad wasteful? cse457-07-hierarchical 7 cse457-07-hierarchical 8
Robot arm implementation, Robot arm implementation, better OpenGL OpenGL maintains a global state matrix called the Instead of recalculating the global matrix each time, we model-view matrix , which is updated by can just update it in place by concatenating matrices on concatenating matrices on the right . the right: main() Matrix M_model; { . . . main() glMatrixMode( GL_MODELVIEW ); { glLoadIdentity(); . . . M_model = Identity(); robot_arm(); robot_arm(); . . . . . . } } robot_arm() robot_arm() { { glRotatef( theta, 0.0, 1.0, 0.0 ); M_model *= R_y(theta); base(); base(); glTranslatef( 0.0, h1, 0.0 ); M_model *= T(0,h1,0)*R_z(phi); glRotatef( phi, 0.0, 0.0, 1.0 ); lower_arm(); lower_arm(); M_model *= T(0,h2,0)*R_z(psi); glTranslatef( 0.0, h2, 0.0 ); upper_arm(); glRotatef( psi, 0.0, 0.0, 1.0 ); } upper_arm(); } cse457-07-hierarchical 9 cse457-07-hierarchical 10 ObjectAxes.cpp Hierarchical modeling Hierarchical models can be composed of instances using trees or DAGs: • edges contain geometric transformations • nodes contain geometry (and possibly drawing attributes) How might we draw the tree for the robot arm? cse457-07-hierarchical 11 cse457-07-hierarchical 12
Human figure implementation, A complex example: human OpenGL figure figure() { torso(); glPushMatrix(); glTranslate( ... ); glRotate( ... ); torso head(); glPopMatrix(); glPushMatrix(); glTranslate( ... ); left upper right upper left upper right upper glRotate( ... ); head arm arm leg leg left_upper_arm(); glPushMatrix(); glTranslate( ... ); glRotate( ... ); left lower right lower left lower right lower left_lower_arm(); arm arm leg leg glPopMatrix(); glPopMatrix(); . . . } Q: What’s the most sensible way to traverse this tree? cse457-07-hierarchical 13 cse457-07-hierarchical 14 Order of transformations Global, fixed coordinate system Let’s revisit the very first simple example in this lecture. One way to think of transformations is as movement of points in a global, fixed coordinate To draw the transformed house, we would write system OpenGL code like: � Build the transformation matrix sequentially from left to right: T, then R, then S � Then apply the transformation matrix to the glMatrixMode( GL_MODELVIEW ); object points: multiply all the points in P by glLoadIdentity(); the composite matrix TRS glTranslatef( ... ); • this transformation takes the points from glRotatef( ... ); original to final positions glScalef( ... ); house(); TRSP RSP SP P Note that we are building the composite transformation matrix by starting from the left and postmultiplying each translated rotated scaled points to draw additional matrix cse457-07-hierarchical 15 cse457-07-hierarchical 16
Local, changing coordinate system Animation Another way to think of The above examples are called articulated transformations is as affecting a models : local coordinate system that the primitive is eventually drawn in. � rigid parts � connected by joints local frame They can be animated by specifying the joint angles (or other display parameters) as functions of time. translate rotate scale This is EXACTLY the same transformation as on the previous page, it's just how you look at it. Draw! cse457-07-hierarchical 17 cse457-07-hierarchical 18 Key-frame animation Scene graphs The most common method for character The idea of hierarchical modeling can be animation in production is key-frame animation . extended to an entire scene, encompassing: � Each joint specified at various key frames � many different objects (not necessarily the same as other joints) � lights � System does interpolation or in-betweening � camera position This is called a scene tree or scene graph . Scene Camera Object1 Light1 Light2 Object2 Object3 Doing this well requires: � A way of smoothly interpolating key frames: splines � A good interactive system � A lot of skill on the part of the animator cse457-07-hierarchical 19 cse457-07-hierarchical 20
Summary Here’s what you should take home from this lecture: � All the boldfaced terms . � How primitives can be instanced and composed to create hierarchical models using geometric transforms. � How the notion of a model tree or DAG can be extended to entire scenes. � How OpenGL transformations can be used in hierarchical modeling. � How keyframe animation works. cse457-07-hierarchical 21
Recommend
More recommend