Blending & State Machines. CSE169: Computer Animation Instructor: Steve Rotenberg UCSD, Winter 2017

Similar documents
Channels & Keyframes. CSE169: Computer Animation Instructor: Steve Rotenberg UCSD, Winter 2017

MOTION CAPTURE DATA PROCESSING - MOTION EDITING / RETARGETING - MOTION CONTROL / GRAPH - INVERSE KINEMATIC. Alexandre Meyer Master Informatique

Animation. Keyframe animation. CS4620/5620: Lecture 30. Rigid motion: the simplest deformation. Controlling shape for animation

Animation. CS 4620 Lecture 32. Cornell CS4620 Fall Kavita Bala

the gamedesigninitiative at cornell university Lecture 12 2D Animation

BONE CONTROLLER ASSET VERSION 0.1 REV 1

Animation. CS 4620 Lecture 33. Cornell CS4620 Fall Kavita Bala

Inverse Kinematics (part 1) CSE169: Computer Animation Instructor: Steve Rotenberg UCSD, Winter 2018

MOTION CAPTURE DATA PROCESSING - MOTION EDITING / RETARGETING - MOTION CONTROL / GRAPH - INVERSE KINEMATIC. Alexandre Meyer Master Informatique

Animations. Hakan Bilen University of Edinburgh. Computer Graphics Fall Some slides are courtesy of Steve Marschner and Kavita Bala

Character Animation 1

Overview. Animation is a big topic We will concentrate on character animation as is used in many games today. humans, animals, monsters, robots, etc.

3D Modelling: Animation Fundamentals & Unit Quaternions

Chapter 5.2 Character Animation

Chapter 9- Animation Basics

Breathing life into your applications: Animation with Qt 3D. Dr Sean Harmer Managing Director, KDAB (UK)

CMSC 425: Lecture 10 Skeletal Animation and Skinning

Character Animation. Presented by: Pam Chow

Advanced Graphics and Animation

CS354 Computer Graphics Rotations and Quaternions

Agenda. Introduction Curve implementation. Particle System. - Requirements -What are all those vectors? -Where should I put things?

Shadows in the graphics pipeline

Animation. CS 465 Lecture 22

Actions and Graphs in Blender - Week 8

Character animation Christian Miller CS Fall 2011

Chapter Adding 1- T Mo he tio B n le to nde Yo r ur Inte Scerfac ne e Landscape Scene Stormy Night.mp4 End 200 Default Animation frame 1 Location

Very Animation Version 1.0.7

COMPUTER ANIMATION 3 KEYFRAME ANIMATION, RIGGING, SKINNING AND CHARACTER ANIMATION. Rémi Ronfard, Animation, M2R MOSIG

Quaternions and Rotations

Synthesis by Example. Connecting Motion Planning and Example based Movement. Michael Gleicher

Blender Animation Editors

Tangents. In this tutorial we are going to take a look at how tangents can affect an animation.

2D/3D Geometric Transformations and Scene Graphs

Quaternions and Rotations

Week 5: Assignment: Animation

CS 4621 PPA3: Animation

Animation. Traditional Animation Keyframe Animation. Interpolating Rotation Forward/Inverse Kinematics

IAT 445 Lab 10. Special Topics in Unity. Lanz Singbeil

Who has worked on a voxel engine before? Who wants to? My goal is to give the talk I wish I would have had before I started on our procedural engine.

Creating animation rigs that solve problems, are fun to use, and don t cause nervous breakdowns.

Animator Friendly Rigging Part 1

3D Rotations and Complex Representations. Computer Graphics CMU /15-662, Fall 2017

} Evaluate the following expressions: 1. int x = 5 / 2 + 2; 2. int x = / 2; 3. int x = 5 / ; 4. double x = 5 / 2.

Computer Animation Fundamentals. Animation Methods Keyframing Interpolation Kinematics Inverse Kinematics

Animation. Computer Graphics COMP 770 (236) Spring Instructor: Brandon Lloyd 4/23/07 1

Lecture 16. Introduction to Game Development IAP 2007 MIT

Human body animation. Computer Animation. Human Body Animation. Skeletal Animation

Lecture 22 of 41. Animation 2 of 3: Rotations, Quaternions Dynamics & Kinematics

Lecture 22 of 41. Animation 2 of 3: Rotations, Quaternions Dynamics & Kinematics

Intro to Animation. Introduction: Frames and Keyframes. Blender Lesson: Grade Level: Lesson Description: Goals/Objectives: Materials/Tools: 4th and up

Carrara Enhanced Remote Control (ERC)

12.1 Quaternions and Rotations

IntroductionToRobotics-Lecture02

Parametric curves. Reading. Curves before computers. Mathematical curve representation. CSE 457 Winter Required:

Render-To-Texture Caching. D. Sim Dietrich Jr.

Creating Loopable Animations By Ryan Bird

Geometric Transformations

animation computer graphics animation 2009 fabio pellacini 1 animation shape specification as a function of time

Kinematics and Orientations

AGDC Per-Pixel Shading. Sim Dietrich

animation computer graphics animation 2009 fabio pellacini 1

Animations. 1. Ogre Animation 2. Frames and Keyframes 3. Bind Pose and skinning 4. Clip Continuity and Additive Blending

Replicating Chaos Vehicle Replication in Watch Dogs 2. Matt Delbosc Team Lead Programmer Ubisoft Toronto

Quaternions and Rotations

Computer Graphics II

Animation Curves and Splines 2

To Do. Advanced Computer Graphics. The Story So Far. Course Outline. Rendering (Creating, shading images from geometry, lighting, materials)

Quaternions and Rotations

EEN118 LAB FOUR. h = v t ½ g t 2

Course Outline. Advanced Computer Graphics. Animation. The Story So Far. Animation. To Do

Lecture 25 of 41. Spatial Sorting: Binary Space Partitioning Quadtrees & Octrees

Chapter 9 Animation System

EEN118 LAB FOUR. h = v t ½ g t 2

Orientation & Quaternions

Ryan Marcotte CS 499 (Honours Seminar) March 16, 2011

Quick Start - Simple Motions

Game Programming. Bing-Yu Chen National Taiwan University

Chapter 6- Lighting and Cameras

Ray Cast Geometry. RayCast Node for Motion, Displacements and Instancing. New to The Ray Cast Geometry node has received an upgrade for 2018.

Animation. Itinerary. What is Animation? What is Animation? Animation Methods. Modeling vs. Animation Computer Graphics Lecture 22

Animation. Itinerary Computer Graphics Lecture 22

Unity Animation. Objectives. Animation Overflow. Animation Clips and Animation View. Computer Graphics Section 2 ( )

Computer Graphics. Si Lu. Fall uter_graphics.htm 11/27/2017

6.001 Notes: Section 8.1

Pong in Unity a basic Intro

Computer Animation II

AN INTRODUCTION TO SCRATCH (2) PROGRAMMING

3D Transformations and Complex Representations. Computer Graphics CMU /15-662, Fall 2016

Parametric curves. Brian Curless CSE 457 Spring 2016

EEN118 LAB FOUR. h = v t - ½ g t 2

Animator Friendly Rigging Part 3b

CS184: Using Quaternions to Represent Rotation

Math 5320, 3/28/18 Worksheet 26: Ruler and compass constructions. 1. Use your ruler and compass to construct a line perpendicular to the line below:

INFOMCANIM Computer Animation Motion Synthesis. Christyowidiasmoro (Chris)

Spiky Sphere. Finding the Sphere tool. Your first sphere

CS 445 / 645 Introduction to Computer Graphics. Lecture 21 Representing Rotations

Installation. Launching from a toolbar

Aircraft Smooth Motion Controls with Intel Perceptual Computing SDK. Cédric Andreolli - Intel

Integrating Physics into a Modern Game Engine. Object Collision. Various types of collision for an object:

IMAGE-BASED RENDERING AND ANIMATION

Transcription:

Blending & State Machines CSE169: Computer Animation Instructor: Steve Rotenberg UCSD, Winter 2017

Blending & Sequencing Now that we understand how a character rig works and how to manipulate animation data, we can edit and play back simple animation The subject of blending and sequencing encompasses a higher level of animation playback, involving constructing the final pose out of a combination of various inputs We will limit today s discussion to encompass only pre-stored animation (channel) data as the ultimate input. Later, we will consider how to mix in procedural animation

Blending & Sequencing Most areas of computer animation have been pioneered by the research and special effects industries Blending and sequencing, however, is one area where video games have made a lot of real progress in this area towards achieving interactively controllable and AI characters in complex environments The special effects industry is using some game related technology more and more (battle scenes in Lord of the Rings )

Animation Playback

Poses A pose is an array of values that maps to a rig If the rig contains only simple independent DOFs, the pose can just be an array of floats If the rig contains quaternions or other complex coupled DOFs, they may require special handling by higher level code Therefore, for generality, we will assume that a pose contains both an array of M 0 floats and an additional array of N 0 quaternions 0... M 1 q 0... q N 1

Animation Clip Remember that the AnimationClip stores an array of channels for a particular animation (or it could store the data as an array of poses ) This should be treated as constant data, especially in situations where multiple animating characters may simultaneously need to access the animation (at different time values) For playback, animation is accessed as a pose. Evaluation requires looping through each channel. class AnimationClip { void Evaluate(float time,pose &p); }

Animation Player We need something that plays an animation. We will call it an animation player At it s simplest, an animation player would store a AnimationClip*, Rig*, and a float time As an active component, it would require some sort of Update() function This update would increment the time, evaluate the animation, and then pose the rig However, for reasons we will see later, we will leave out the Rig* and just have the player generate and output a Pose

Animation Player class AnimationPlayer { float Time; AnimationClip *Anim; Pose P; public: void SetClip(AnimationClip &clip); const Pose &GetPose(); void Update(); };

Animation Player A simple player just needs to increment the Time and access the new pose once per frame The first question that comes up though, is what to do when it gets to the end of the animation clip? Loop back to start Hold on last frame Deactivate itself (return 0 pose?) Send a message

Animation Player Some features we may want to add for a more versatile animation player include: Variable playback rate Play backwards (& deal with hitting the beginning) Pause It s kinda like a DVD player

Animation Player The animation player is a basic component of an animation blending & sequencing system Many of these might ultimately be combined to get the final blended pose. This is why we only want it to output a pose By the way, remember the issue of sequential access for keyframes? The animation player should ultimately be responsible for tracking the current keyframe array (although the details could be pushed down to a specific class for dealing with that)

Animation Player As we will use players and static poses as basic components in our blending discussion, we will make a notation for them: look_right walk static pose current pose (Animation Player)

Animation Blending

Blending Overview We can define blending operations that affect poses A blend operation takes one or more poses as input and generates one pose as output In addition, it may take some auxiliary data as input (control parameters, etc.)

Generic Blend Operation pose1...posen aux data BLENDER output pose

Cross Dissolve Perhaps the most common and useful pose blend operation is the cross dissolve Also known as: Lerp (linear interpolation), blend, dissolve The cross dissolve blender takes two poses as input and an additional float as the blend factor (0 1)

Cross Dissolve The two poses are basically just interpolated The DOF values can use Lerp, but the quaternions should use the Slerp operation (spherical linear interpolate) q Lerp Slerp t,, 1 t 1 t, q 1 2, q 2 sin 1 2 1 t sin t sin t q 1 sin q 2

Cross Dissolve: Handling Angles If a DOF represents an angle, we may want to have the interpolation check for crossing the +180 / -180 boundary if 180 Lerpt, 360, else else 1 if 2 180 Lerpt,, 360 2 1 Lerp t,, 1 2 Unfortunately, this complicates the concept of a DOF (and a pose) a bit more. Now we must also consider that some DOFs behave in different ways than others 1 1 2 2

Cross Dissolve: Quaternions Also, for quaternions, we may wish to force the interpolation to go the short way : if q q 0 q Slerp t, q, q else 1 q 2 Slerp t, q 1, q 2 1 2

Cross Dissolve: Stand to Walk Consider a situation where we want a character to blend from a stand animation to a walk animation stand walk f DISSOLVE output pose

Cross Dissolve: Stand to Walk We could have two independent animations playing (stand & walk) and then gradually ramp the t value from 0 to 1 If the transition is reasonably quick (say <0.5 second), it might look OK Note: this is just a simple example of a dissolve and not necessarily the best way to make a character start walking

Cross Dissolve: Walk to Run Blending from a walk to a run requires some additional consideration walk run f DISSOLVE output pose

Cross Dissolve: Walk to Run Lets say that we have a walk and a run animation Each animation is meant to play as a loop and contains one full gait cycle They are set up so the character is essentially moving in place, as on a treadmill Let s assume that the duration of the walk animation is d walk seconds and the run is d run seconds Let s also assume that the velocity of the walk is v walk and run is v run (these represent the speed that the character is supposed to be moving forward, but keep in mind, the animation itself is in place)

Cross Dissolve: Walk to Run We want to make sure that the walk and run are in phase when we blend between them One could animate them in a consistent way so that the two clips both start at the same phase But, let s assume they aren t in sync Instead, we ll just store an offset for each clip that marks some synchronization point (say at the time when the left foot hits the ground) We ll call these offsets o walk and o run

Cross Dissolve: Walk to Run Let s assume that f is our dissolve factor (0 1) where f=0 implies walking and f=1 implies running The resulting velocity that the character should move is simply: v'=lerp(f,v walk,v run ) To get the animations to stay in phase, however, we need to adjust the speeds that they are playing back This means that when we re halfway between walk and run, the walk will need to be sped up and the run will need to be slowed down

Cross Dissolve: Walk to Run As we are sure that we want the two to stay in phase, we can just lock them together For example, we will just say that if t walk is the current time of the walk animation, then t run should be: d run t run mod twalk owalk d walk orun, d run d walk

Cross Dissolve: Walk to Run To speed up the walk animation appropriately, we will define a rate r walk that the walk animation plays at (default would be 1.0) r walk Lerp f,1.0, d d walk run

Basic Math Blend Operations We can also define some blenders for basic math operations: pose1 pose2 pose1 pose2 pose1 ADD SUBTRACT f SCALE pose1 + pose2 pose1 - pose2 f * pose1

Basic Math Blend Operations Its not always obvious how to define consistent behaviors between independent DOFs and quaternions Quaternion addition and subtraction don t really give an expected result Addition of orientations implies that you start with the first orientation and then you do a rotation from there that corresponds to how the second orientation is rotated from neutral This behavior is more like quaternion multiplication (although quaternion multiplication is not commutative)

Add & Subtract Blenders A reasonable behavior for an add blender could be: For subtraction, we could multiply by the conjugate of the quaternion 2 1 2 1 q q q 2 1 2 1 q q q 3 2 1 0 q q q q q

Scale Blender As we want our quaternions to stay unit length, we don t really want to scale them In any case, scaling a quaternion has no effect on the resulting orientation! Instead, we can think of scaling as moving towards or away from 0 (I.e., scaling by a number less than 1 brings us closer to 0, scaling by >1 takes us away from 0 ) Therefore, we could define the scale blender as: f q 1 Slerp f, 1 0 0 0, q 1

Math Operations: Body Turn look_right default SUBTRACT walk f SCALE ADD output pose

Body Turn As an example of math blending operations, consider a character that walks and turns One approach to achieving this is to have an underlying walk animation and layer (add) some body turn on top of it We make a static look_right pose and a static default pose The subtraction gives us the difference between look_right and default If we scale this and then add it on top of the underlying walk animation. The scale we use can be based on how hard the character is turning (-1 1)

Body Turn We can also speed this up by precomputing the subtraction and making a combined add/scale blender turn_delta walk turn_delta walk f SCALE f ADD/SCALE ADD output pose output pose

Bilinear Blend pose1 pose2 pose3 pose4 pose1 pose2 pose3 pose4 s,t BILINEAR s DISSOLVE s DISSOLVE t DISSOLVE output pose output pose

Bilinear Blend Bilinear blend is an extension to the cross dissolve that takes four input poses and two interpolation parameters s & t pose3 pose4 (0,1) (1,1) t (s,t) (0,0) pose1 s (1,0) pose1

Bilinear Blend Bilinear (and trilinear ) blends can be useful for a wide range of applications As one example, consider a video game character who has to aim a weapon The character must be able to stand still and aim at any object within +/- 135 degrees to the side to side and +/- 45 degrees up and down An animator can supply key poses at 45 degree increments in both directions Then, for any desired angle, we can find the right four targets and do a bilinear blend

Combine Blender We can also have a blender that combines poses in different ways For example, we might want to treat the upper body separately from the lower body, or treat each limb separately, etc. We can use different blenders for each body section and then combine them into a final pose This also implies that we can use smaller pose vectors in each body section to save computations and memory The actual combine operation could just have lookup tables that map index values of the incoming poses to index values of the final pose

Mirror Blender Mirroring animations across the x=0 plane can be an effective way to save memory and complexity It requires that a character is symmetrical (or close enough ) Like the combine blender, mirroring requires some sort of table as input that describes how to mirror each DOF Different DOFs will need different treatment Translation Rotation Quaternion : q : : x x x, x, q 0 y y q Also, DOFs on the right need to be swapped with DOFs on the left 1 y, y, q z 2 z z z q 3

Clamp Blender DOF limits can be implemented as a blend operation This can be for performance, as it allows precise control over when (and if) DOF limits are used For example, consider that DOF limits should not be necessary when cross dissolving between two animations (assuming the animations are already within the legal limits) Use of add, subtract, and scale operations may require clamping for safety

Animation State Machines

State Machines Blending is great for combining a few motions, but it does not address the issue of sequencing different animations over time For this, we will use a state machine We will define the state machine as a connected graph of states and transitions At any time, exactly one of the states is the current state Transitions are assumed to happen instantaneously

EVENT6 State Machines state_a EVENT1 EVENT2 state_b EVENT3 EVENT4 state_d state_c EVENT5 state_e

State Machines In the context of animation sequencing, we think of states as representing individual animation clips and transitions being triggered by some sort of event An event might come from some internal logic or some external input (button press )

Simple Jump State Machine Consider a simple state machine where a character jumps upon receiving a JUMP_PRESS message stand JUMP_PRESS jump

More Complex Jump stand JUMP_PRESS stand2crouch JUMP_RELEASE crouch hop JUMP_RELEASE takeoff float NEAR_GROUND land

State Machine (Text Version) stand {JUMP_PRESS stand2crouch } stand2crouch { JUMP_RELEASE hop END crouch } crouch {JUMP_RELEASE takeoff } takeoff {END float } hop {END float } float {NEAR_GROUND land } land {END stand }

State Machine Extensions Global transitions Logic in states Combining blenders & state machines State machines within state machines etc.

Creating State Machines Typing in text Graphical state machine editor Automated state machine generation (motion graphing)

Character Mover

Character Mover When we want an interactive character to move around through a complex environment, we need something to be responsible for the overall placement of the character We call this the character mover We can think of the mover as a matrix that positions the character s root

Character Mover Usually, we think of the mover matrix as being on the ground right below the character s center The mover sits perfectly still when the character isn t moving and generally moves at a smooth constant rate as the character walks The character s root translation would be animated relative to the mover

Character Mover: Walking Consider a walk animation where the character is moving at a rate of v meters/second The actual animation is animated as if on a treadmill (but the root may still have some translation (bobbing up/down back/forth, left/right)) If the mover is moving at v meters/second though, the animation will look correct

Character Mover The mover might be coded up to do some simple accelerations, decelerations, turning, and collision detection with the ground and walls (note that these could trigger events in the animation state machine ) Depending on the speed that the mover is moving, we might blend to an appropriate gait animation

Character Mover Sometimes, we want the character to do more complex moves, such as a dive roll to the right In this situation, we might want to explicitly animate what the mover should do This data can be written out with the animation and stored as additional channel data (3 translations, 3 rotations) These extra channels can be blended like any other channel, and then finally added to the mover when we pose the rig

Project 3 Load an.anim file and play back a keyframed animation on a skinned character Due Thursday, February 16, 4:45 pm Extra Credit: Display the channel curve Simple channel editor

Anim File animation { range [time_start] [time_end] numchannels [num] channel { extrapolate [extrap_in] [extrap_out] keys [numkeys] { [time] [value] [tangent_in] [tangent_out] } } channel }

Project 3 The first 3 channels will be the root translation (x,y,z) After that, there will be 3 rotational channels for every joint (x,y,z) in the same order that the joints are listed in the.skel file

Project 3 Suggested classes: Keyframe: stores time, value, tangents, cubics Channel: stores an array (or list) of Keyframes Animation: stores an array of Channels Player: stores pointer to an animation & pointer to skeleton. Keeps track of time, accesses animation data & poses the skeleton. Optional: Rig: simple container for a skeleton, skin, and morphs Pose: array of floats (or just use stl vector) ChannelEditor: it s always nice to separate editor classes from the data that they edit