#### Overview of this book

Animation is one of the most important parts of any game. Modern animation systems work directly with track-driven animation and provide support for advanced techniques such as inverse kinematics (IK), blend trees, and dual quaternion skinning. This book will walk you through everything you need to get an optimized, production-ready animation system up and running, and contains all the code required to build the animation system. You’ll start by learning the basic principles, and then delve into the core topics of animation programming by building a curve-based skinned animation system. You’ll implement different skinning techniques and explore advanced animation topics such as IK, animation blending, dual quaternion skinning, and crowd rendering. The animation system you will build following this book can be easily integrated into your next game development project. The book is intended to be read from start to finish, although each chapter is self-contained and can be read independently as well. By the end of this book, you’ll have implemented a modern animation system and got to grips with optimization concepts and advanced animation techniques.
Preface
Chapter 1: Creating a Game Window
Free Chapter
Chapter 2: Implementing Vectors
Chapter 3: Implementing Matrices
Chapter 4: Implementing Quaternions
Chapter 5: Implementing Transforms
Chapter 6: Building an Abstract Renderer
Chapter 7: Exploring the glTF File Format
Chapter 8: Creating Curves, Frames, and Tracks
Chapter 9: Implementing Animation Clips
Chapter 10: Mesh Skinning
Chapter 11: Optimizing the Animation Pipeline
Chapter 12: Blending between Animations
Chapter 13: Implementing Inverse Kinematics
Chapter 14: Using Dual Quaternions for Skinning
Chapter 15: Rendering Instanced Crowds
Other Books You May Enjoy

# Common quaternion operations

Like vectors, quaternions also have component-wise operations. Common

component-wise operations are adding, subtracting, multiplying, or negating

quaternions. Component-wise quaternion multiplication multiplies a quaternion

by a single scalar value.

Since these functions are component-wise, they just perform the appropriate action on similar components of the input quaternions. Implement these functions in `quat.cpp` and add declarations for each function in `quat.h`:

```quat operator+(const quat& a, const quat& b) {
return quat(a.x+b.x, a.y+b.y, a.z+b.z, a.w+b.w);
}
quat operator-(const quat& a, const quat& b) {
return quat(a.x-b.x, a.y-b.y, a.z-b.z, a.w-b.w);
}
quat operator*(const quat& a, float b) {
return quat(a.x * b, a.y * b, a.z * b, a.w * b);
}
quat operator-(const quat& q) {
return quat(-q.x, -q.y, -q.z, -q.w);
}```
...