« previous | Wednesday, April 23, 2014 | next »
Quaternions and Complex Numbers
how they should be used.
Complex Numbers
Defined by a real and imaginary part:
, where
.
Simple operations:
data:image/s3,"s3://crabby-images/91531/91531935dfba8ded106cad3f51445b5b1d3f66f3" alt="{\displaystyle \left(a+b\,i\right)+\left(c+d\,i\right)=(a+c)+(b+d)\,i}"
data:image/s3,"s3://crabby-images/b4798/b479871fe0950f0662f085bc49f3f21a0f7810f0" alt="{\displaystyle \left\langle a+b\,i\right\rangle \,\left(c+d\,i\right)=a\,c-b\,d+\left(a\,d+b\,c\right)\,i}"
- Conjugation:
becomes
. What's impressive about this is that
, where data:image/s3,"s3://crabby-images/77673/776735462d9cef48700ab21a5df0a2ca0978c9ea" alt="{\displaystyle \left|z\right|={\sqrt {a^{2}+b^{2}}}}"
Relation to Graphics
Given a point
, rotate that point about the origin by
:
Represent
by a complex number:
Rotation is just multiplication by a complex number.
Quaternions
Sir William Rowan Hamilton attempted to extend complex numbers from 2D to 3D, but this is now provably impossible. He discovered a generalization to 4D and wrote it on the side of a bridge in Dublin.
One real part, 3 complex parts:
From this, we get
data:image/s3,"s3://crabby-images/69931/69931f8fb25a40855e87afb0f31fda02d9165a24" alt="{\displaystyle i\,j=k}"
data:image/s3,"s3://crabby-images/31065/31065f1b93350fd288bb5fedb53140d25ef57f7a" alt="{\displaystyle j\,i=-k}"
data:image/s3,"s3://crabby-images/7e9d6/7e9d6c3fdef75fd75babf4709d8fb05d3fe851ea" alt="{\displaystyle j\,k=i}"
data:image/s3,"s3://crabby-images/f340b/f340b0181ab46304cc0bafbfdc990548ef1ad5e3" alt="{\displaystyle k\,j=-i}"
data:image/s3,"s3://crabby-images/60914/60914a25942d7b726482daa6baf7dc9f45912c69" alt="{\displaystyle k\,i=j}"
data:image/s3,"s3://crabby-images/c5ff9/c5ff935dad35c1ba0b367e28d63ec5d3c42aa029" alt="{\displaystyle i\,k=-j}"
We can define an algebra on
and
- Multiplication:
- Order matters in quaternion multiplication!
- Conjugation:
, and data:image/s3,"s3://crabby-images/9e751/9e7512330912fc3038b0e4c0f1b3da4beb351bd2" alt="{\displaystyle \left\langle q\,{\bar {s}}\right\rangle =s^{2}+\left|v\right|^{2}=\left|q\right|^{2}}"
- Inversion:
data:image/s3,"s3://crabby-images/f59ac/f59acbd6bcce3e224ae46cd567d9207947bb3f07" alt="{\displaystyle q^{-1}={\frac {\bar {q}}{\left|q\right|}}}"
Relation to Graphics
Claim: unit quaternions represent 3D rotation
Convert from 3D to 4D:
, where
.
, where
.
let
be parallel to the axis of rotation in 3D.
In this case,
. This gives a nonzero real component... uh oh, we now have a 4D number, not a 3D number.
let
be a vector component in the plane normal to
:
represents a positive (ccw) rotation, and
represents a negative (cw) rotation.
Computing
rotates the component of
perpendicular to
by
and leaves the parallel component alone.
Thus the quaternion representing rotation about the unit axis
data:image/s3,"s3://crabby-images/fd1cb/fd1cba9b075209b9990f5e6a42f3ae0e97ccf5d9" alt="{\displaystyle {\vec {v}}}"
by
data:image/s3,"s3://crabby-images/1536a/1536a901f0f85345875ab3c78fef47c9e2dd30f6" alt="{\displaystyle \theta }"
is
, where data:image/s3,"s3://crabby-images/fd209/fd209432730ea058fb16a739f94dd5d04c70fa46" alt="{\displaystyle q=\left(\cos {\left({\frac {\theta }{2}}\right)},\sin {\left({\frac {\theta }{2}}\right)}{\vec {v}}\right)}"
Quaternions vs. Matrices
This seems like magic... This is perhaps the wrong use for quaternions
- Quaternions take less space (4 vs. 9)
- Rotating a vector requires 28 multiplications using quaternions vs. 9 for matrices
- Composing two rotations using quaternions
requires 16 multiplications vs. 27 for matrices
- Quaternions are not hardware-accelerated whereas matrices are.
Quaternions and Interpolation
Unit quaternions represent points on a 4D hypersphere
Interpolation on the sphere gives rotations that bend the least.
Recall we used SLERP to interpolate vectors on the surface of a 3D sphere.
May need to interpolate between
and
.
, where
.
Other Graphics Uses for Quaternions
Skeletal animation: moving bones usually requires a lot of composed rotations.