Perpendicular vectors in 2D
We consider as an orthonormal basis in a 2D vector
space. The coordinates in that basis of a
vector are , and we want to obtain another vector
, perpendicular to , and with the same length. The coordinates of
are (in what follows we identify vectors with its coordinates in ).
This perpendicular vector is obtained by rotating towards its left side (counterclockwise, as long
as we imagine to the left of ).
We could use the reverse convention (to rotate clockwise), and use , but the first option
is far more usual.
It is easy to show that the dot product of both vectors is cero, and that they are
also of equal length
The (lineal) relation between and can be expressed by
using a 2x2 matrix acting on coordinate column vectors (relative to ):
Rotations in 2D
In a 2D vector space we want to define the rotation transformation .
This rotation is a rotation around the origin of the vector space, with angle (in radians).
If we want to rotate vector , we begin by using the previous definition of and
define the rotated vector as
note that when , we have .
Let us assume that the coordinates of in the orthonormal basis
are (that is, ). This allows us
to compute the coordinates of , by substituting:
where
values are the coordinates of the rotated point .
Matrix form for 2D rotations
The rotation transformation
can we written in homogeneous coordinates by using a 3x3 matrix :
Matrix can also be obtained by writing as , where
is the identity matrix, and as , then:
this implies we can write as a combination of and :
Perpendicular vectors in 3D. Cross product.
In a 3D vector space, for any given vector , there are infinitelly many vectors perpendicular
to and with the same length as (all those form a circunference in the plane perpendicular to ).
To select one of those perpendicular vectors, we must use a third vector (non colinear with ), and compute
the cross product of and . Then, vector is perpendicular to (but not neccesarly
with the same length as ).
If are the coordinates of , then:
This cross-product operation (pre-multiplying by ), can also be written as a linear matrix operation by using matrix
defined as follows:
It is easy to check that pre-multiplying by is the same as to apply to
Rotations in 3D and Rodrigues formula
In 3D, the rotation transform uses an unit-length vector as the rotation axis, and an angle .
In order to rotate , we decompose it in two components, (parallel to ) and (perpendicular
to , but in the plane spawned by and )
where is obtained by projecting onto rotation axis, that is:
and is obtained as:
in the case and are collinear, vector is the null vector and .
We define an additional perpendicular vector , which is perpendicular to both and to ,
and has the same length as :
Note that, as is unit-length and perpendicular to , then has the same
length as .
With these definitions in mind, we can define the rotated vector by observing that its component parallel to
the axis does not changes, while the component perpendicular to the axis is rotated as in 2D (in the plane perpendicular to the axis),
that is, we define
We rewrite as follows:
Vector can we rewritten as:
here, as and are parallel, we have substituted their cross product by .
Now we can write the expression for which is called Rodrigues' Rotation formula:
Matrix form for 3D Rotations
We can express Rodrigues formula in terms of cross-products, this leads to the general
rotation matrix. We begin by rewriting as:
This allows to write by using cross-products:
Vector is expressed as follows:
So we end up with this expression for :
This last expression is written just in terms of and , uses just cross-products, and is equivalent to
Rodrigues' formula. From that
we obtain the matrix for rotation in 3D, which is expressed in terms of
the powers of matrix :
where is the identity matrix (that is, ), and
Thus:
where we have used .
By expanding the matrixes:
And finally:
More compactly:
(this page uses MathJax)