« previous | Monday, February 10, 2014 | next »
3D Transformations
The following transformations are the same:
- Transformations
- Uniform Scaling
- Non-Uniform Scaling
Rotation
Rotation in 3D is slightly different.
Given a unit vector
, a point
, which is the 'origin' of
, and a point
to rotate,
- Compute
data:image/s3,"s3://crabby-images/8aa80/8aa807bcac76fe24b36ee9342ba00fc4ae79ec9e" alt="{\displaystyle {\vec {q}}=P-O}"
- Decompose
into its components parallel (
) and perpendicular (
) to
using vector projections:
data:image/s3,"s3://crabby-images/8da8e/8da8e1e9c0caafc706131ca01d336da2655857b3" alt="{\displaystyle {\vec {q}}^{\parallel }=({\vec {v}}\cdot {\vec {q}})\,{\vec {v}}}"
data:image/s3,"s3://crabby-images/4e9e0/4e9e088091d83246bcf284cf8948458f25ddc8dc" alt="{\displaystyle {\vec {q}}^{\perp }={\vec {q}}^{\parallel }-{\vec {v}}}"
- Compute cross product
to define the basis for a plane perpendicular to
with
as an axis.
- Use
and
as a new 2D coordinate system.
- Find a new rotated form of
with data:image/s3,"s3://crabby-images/44abb/44abb98fecff3e74499b3a246e8451f323b5e62b" alt="{\displaystyle \left({\vec {v}}\times {\vec {q}}^{\perp }\right)\,\sin {\theta }+{\vec {q}}^{\perp }\,\cos {\theta }}"
- Add
and
to this rotated vector to get the rotated point:
Mirror Image
A new transformation for 3D space.
Given unit vector
, a point
, which is the 'origin' of reflection, and a point
, we will mirror
about the plane defined by the normal vector
and point
.
- Compute
data:image/s3,"s3://crabby-images/8aa80/8aa807bcac76fe24b36ee9342ba00fc4ae79ec9e" alt="{\displaystyle {\vec {q}}=P-O}"
- Decompose
into its components parallel (
) and perpendicular (
) to
:
data:image/s3,"s3://crabby-images/ceac9/ceac9ac45c70f799aeccbd28f148e82466b73d59" alt="{\displaystyle {\vec {q}}^{\parallel }=\mathrm {proj} _{\vec {v}}({\vec {q}})=\left({\vec {v}}\cdot {\vec {q}}\right)\,{\vec {v}}}"
data:image/s3,"s3://crabby-images/cc43b/cc43bda73f4523d94633f442f784ca640db88526" alt="{\displaystyle {\vec {q}}^{\perp }={\vec {q}}-{\vec {q}}^{\parallel }}"
- Subtract
from
to get the vector from
to its reflection: data:image/s3,"s3://crabby-images/eed13/eed13573619b41aa7a8f1b632adec13234dd6abe" alt="{\displaystyle {\hat {P}}=P-2{\vec {q}}^{\parallel }}"
Note: This is identical to non-uniform scaling with a scale factor of data:image/s3,"s3://crabby-images/6be76/6be76d46d54d9fe4953d0434bd8e1b761a60052c" alt="{\displaystyle -1}"
Orthogonal Projection
Useful for projecting 3D objects onto the screen for rendering.
Given a point
, which is the 'origin' (like in mirror image), the orthogonal projection of a point
is given by:
- Compute
data:image/s3,"s3://crabby-images/8aa80/8aa807bcac76fe24b36ee9342ba00fc4ae79ec9e" alt="{\displaystyle {\vec {q}}=P-O}"
- Decompose
into its components parallel (
) and perpendicular (
) to
as above
- Subtract
from
(instead of
like in above)
Thus
Note: This is identical to non-uniform scaling with a scale factor of data:image/s3,"s3://crabby-images/c7edc/c7edca7f10e358fc0c2b36ba37a49c753c4e11c0" alt="{\displaystyle 0}"
Perspective Projection
Using a new point
, which is the eye of the observer,
is the intersection of
and the plane defined by
and
.
- The equation of the plane is
data:image/s3,"s3://crabby-images/85f5e/85f5e32b31bb0dc34cf9bf76be92f0a97c2a1121" alt="{\displaystyle {\vec {v}}\cdot (X-O)=0}"
- The equation of the line from
to
is data:image/s3,"s3://crabby-images/83674/83674be1b5f8e48247bcfcd6e4587132377c2509" alt="{\displaystyle \ell (t)=E+t\,({\vec {P}}-E)=(1-t)\,E+t\,P}"
- Substitute the line equation for
in the plane equation and solve for
: data:image/s3,"s3://crabby-images/2177a/2177a2b3abac65719fd511af100a0243cf2af482" alt="{\displaystyle {\vec {v}}\cdot \left(\left((1-t)\,E+t\,P\right)-O\right)=0}"
data:image/s3,"s3://crabby-images/a13cb/a13cb382e8edcb667b5caf17a08b518c687e3811" alt="{\displaystyle t={\frac {{\vec {v}}\cdot \left(O-E\right)}{{\vec {v}}\cdot \left(P-E\right)}}}"
- evaluate
to find the intersection point
Precondition:
cannot be parallel to the plane? (since denominator wold be zero)
Perspective projection of vectors is not defined because we would get different projections depending on the location of the vector to project.
Warning: Perspective transformation is not affine
3D Transformations as Matrices
Exactly like 2D, but the matrices are now 4 × 4
Similar block-structure
, but
is a 3 × 3 matrix.
Dot Product
Still
.
Cross Product
Component Decomposition
data:image/s3,"s3://crabby-images/6ed08/6ed08370537b656a44e1c99db60d77d97d9322bb" alt="{\displaystyle {\vec {q}}^{\parallel }={\vec {v}}\,{\vec {v}}^{T}\,{\vec {q}}}"
data:image/s3,"s3://crabby-images/25049/250491c324fe4c788d4a1e1487ea9b835e540f46" alt="{\displaystyle {\vec {q}}^{\perp }=\left(I-{\vec {v}}\,{\vec {v}}^{T}\right)\,{\vec {q}}}"
Translation
Uniform Scaling
What's multiplied by
?
data:image/s3,"s3://crabby-images/d431c/d431c9c0ea6f7e03418910bf8d5af923c72ba679" alt="{\displaystyle \alpha \,I}"
What's added to
?
data:image/s3,"s3://crabby-images/42e9d/42e9d74436d1ef9d576ca91c1d34e201c7784794" alt="{\displaystyle \left(1-\alpha \right)\,o}"
and
Non-Uniform Scaling
What's multiplied by
?
data:image/s3,"s3://crabby-images/78f89/78f89995590a40c2e28a3f2107833b7a9a38c044" alt="{\displaystyle I}"
data:image/s3,"s3://crabby-images/6a4af/6a4affdfa2c71dc8c9d8b4a333c0f7a142c1b2fb" alt="{\displaystyle \left(\alpha -1\right)\,{\vec {v}}\,{\vec {v}}^{T}}"
What's added to
?
data:image/s3,"s3://crabby-images/39bc6/39bc6b23a11b0baba9a353fe1c029915e46acc50" alt="{\displaystyle -\left(\alpha -1\right)\,{\vec {v}}\,{\vec {v}}^{T}\,o}"
and
Next time
Continue with rotation about an arbitrary axis.