![]() | ||
In geometry, various formalisms exist to express a rotation in three dimensions as a mathematical transformation. In physics, this concept is applied to classical mechanics where rotational (or angular) kinematics is the science of quantitative description of a purely rotational motion. The orientation of an object at a given instant is described with the same tools, as it is defined as an imaginary rotation from a reference placement in space, rather than an actually observed rotation from a previous placement in space.
Contents
- Rotations and motions
- Rotation matrix
- Euler axis and angle rotation vector
- Euler rotations
- Quaternions
- Rodrigues parameters and Gibbs representation
- CayleyKlein parameters
- Rotation matrix Euler angles
- Rotation matrix Euler angles z x z extrinsic
- Euler angles z y x intrinsic Rotation matrix
- Rotation matrix Euler axisangle
- Rotation matrix quaternion
- Euler angles z x z extrinsic Quaternion
- Euler angles z y x intrinsic Quaternion
- Quaternion Euler angles z x z extrinsic
- Quaternion Euler angles z y x intrinsic
- Euler axisangle quaternion
- Rotation matrix angular velocities
- Quaternion angular velocities
- Rotors in a geometric algebra
- References
According to Euler's rotation theorem the rotation of a rigid body (or three-dimensional coordinate system with the fixed origin) is described by a single rotation about some axis. Such a rotation may be uniquely described by a minimum of three real parameters. However, for various reasons, there are several ways to represent it. Many of these representations use more than the necessary minimum of three parameters, although each of them still has only three degrees of freedom.
An example where rotation representation is used is in computer vision, where an automated observer needs to track a target. Let's consider a rigid body, with three orthogonal unit vectors fixed to its body (representing the three axes of the object's local coordinate system). The basic problem is to specify the orientation of these three unit vectors, and hence the rigid body, with respect to the observer's coordinate system, regarded as a reference placement in space.
Rotations and motions
Rotation formalisms are focused on proper (orientation-preserving) motions of the Euclidean space with one fixed point, that a rotation refers to. Although physical motions with a fixed point are an important case (such as ones described in the center-of-mass frame, or motions of a joint), this approach creates a knowledge about all motions. Any proper motion of the Euclidean space decomposes to a rotation around the origin and a translation. Whichever the order of their composition will be, the "pure" rotation component wouldn't change, uniquely determined by the complete motion.
One can also understand "pure" rotations as linear maps in a vector space equipped with Euclidean structure, not as maps of points of a corresponding affine space. In other words, a rotation formalism captures only the rotational part of a motion, that contains three degrees of freedom, and ignores the translational part, that contains another three.
Rotation matrix
The above-mentioned triad of unit vectors is also called a basis. Specifying the coordinates (components) of vectors of this basis in its current (rotated) position, in terms of the reference (non-rotated) coordinate axes, will completely describe the rotation. The three unit vectors,
These parameters can be written as the elements of a 3×3 matrix A, called a rotation matrix. Typically, the coordinates of each of these vectors are arranged along a column of the matrix (however, beware that an alternative definition of rotation matrix exists and is widely used, where the vectors coordinates defined above are arranged by rows)
The elements of the rotation matrix are not all independent—as Euler's rotation theorem dictates, the rotation matrix has only three degrees of freedom.
The rotation matrix has the following properties:
The angle
The above properties are equivalent to:
which is another way of stating that
Two successive rotations represented by matrices
(Note the order, since the vector being rotated is multiplied from the right). The ease by which vectors can be rotated using a rotation matrix, as well as the ease of combining successive rotations, make the rotation matrix a useful and popular way to represent rotations, even though it is less concise than other representations.
Euler axis and angle (rotation vector)
From Euler's rotation theorem we know that any rotation can be expressed as a single rotation about some axis. The axis is the unit vector (unique except for sign) which remains unchanged by the rotation. The magnitude of the angle is also unique, with its sign being determined by the sign of the rotation axis.
The axis can be represented as a three-dimensional unit vector
Since the axis is normalized, it has only two degrees of freedom. The angle adds the third degree of freedom to this rotation representation.
One may wish to express rotation as a rotation vector, or Euler vector, an un-normalized three-dimensional vector the direction of which specifies the axis, and the length of which is θ,
The rotation vector is in some contexts useful, as it represents a three-dimensional rotation with only three scalar values (its components), representing the three degrees of freedom. This is also true for representations based on sequences of three Euler angles (see below).
If the rotation angle
Euler rotations
The idea behind Euler rotations is to split the complete rotation of the coordinate system into three simpler constitutive rotations, called Precession, Nutation, and intrinsic rotation, being each one of them an increment on one of the Euler angles. Notice that the outer matrix will represent a rotation around one of the axes of the reference frame, and the inner matrix represents a rotation around one of the moving frame axis. The middle matrix represent a rotation around an intermediate axis called line of nodes.
However, the definition of Euler angles is not unique and in the literature many different conventions are used. These conventions depend on the axes about which the rotations are carried out, and their sequence (since rotations are not commutative).
The convention being used is usually indicated by specifying the axes about which the consecutive rotations (before being composed) take place, referring to them by index (1, 2, 3) or letter (X, Y, Z). The engineering and robotics communities typically use 3-1-3 Euler angles. Notice that after composing the independent rotations, they do not rotate about their axis anymore. The most external matrix rotates the other two, leaving the second rotation matrix over the line of nodes, and the third one in a frame comoving with the body. There are 3×3×3 = 27 possible combinations of three basic rotations but only 3×2×2 = 12 of them can be used for representing arbitrary 3D rotations as Euler angles. These 12 combinations avoid consecutive rotations around the same axis (such as XXY) which would reduce the degrees of freedom that can be represented.
Therefore, Euler angles are never expressed in terms of the external frame, or in terms of the co-moving rotated body frame, but in a mixture. Other conventions (e.g., rotation matrix or quaternions) are used to avoid this problem.
In aviation orientation of the aircraft is usually expressed as intrinsic Tait-Bryan angles following z-y’-x″ convention, which are called heading, elevation and bank, or yaw, pitch and roll.
Quaternions
Quaternions, that form a four-dimensional vector space, have proven very useful in representing rotations due to several advantages above the other representations mentioned in this article.
A quaternion representation of rotation is written as a versor (normalized quaternion)
The above definition stores quaternion as an array following the convention used in (Wertz 1980) and (Markley 2003). An alternative definition used for example in (Coutsias 1999) and (Schmidt 2001) defines the "scalar" term as the first quaternion element, with the other elements shifted down one position.
In terms of the Euler axis
and angle
this versor's components are expressed as follows:
Inspection shows that the quaternion parametrization obeys the following constraint:
The last term (in our definition) is often called the scalar term, which has its origin in quaternions when understood as the mathematical extension of the complex numbers, written as
and where
Quaternion multiplication, that is used to specify a composite rotation, is performed in the same manner as multiplication of complex numbers, except that the order of elements must be taken into account, since multiplication is not commutative. In matrix notation we can write quaternion multiplication as
Combining two consecutive quaternion rotations is therefore just as simple as using the rotation matrix. Remember that two successive rotation matrices,
We can represent this with quaternion parameters in a similarly concise way:
Quaternions are a very popular parametrization due to the following properties:
Like rotation matrices, quaternions must sometimes be re-normalized due to rounding errors, to make sure that they correspond to valid rotations. The computational cost of re-normalizing a quaternion, however, is much less than for normalizing a 3×3 matrix.
Quaternions also capture the spinorial character of rotations in three dimensions. For a three-dimensional object connected to its (fixed) surroundings by slack strings or bands, the strings or bands can be untangled after two complete turns about some fixed axis from an initial untangled state. Algebraically, the quaternion describing such a rotation changes from a scalar +1 (initially), through (scalar + pseudovector) values to scalar -1 (at one full turn), through (scalar + pseudovector) values back to scalar +1 (at two full turns). This cycle repeats every 2 turns. After 2n turns (integer n > 0), without any intermediate untangling attempts, the strings/bands can be partially untangled back to the 2(n-1) turns state with each application of the same procedure used in untangling from 2 turns to 0 turns. Applying the same procedure n times will take a 2n tangled object back to the untangled or 0 turn state. The untangling process also removes any rotation-generated twisting about the strings/bands themselves. Simple 3D mechanical models can be used to illustrate these facts.
Rodrigues parameters and Gibbs representation
Rodrigues parameters can be expressed in terms of Euler axis and angle as follows,
This has a discontinuity at 180° (π radians): each vector, r, with a norm of π radians represent the same rotation as −r.
Similarly, the Gibbs representation can be expressed as follows,
A rotation g followed by a rotation f in the Gibbs representation has the simple form
Today, the most straightforward way to prove this formula is in the (faithful) doublet representation, where g = ∧n tan a, etc.
The Gibbs vector has the advantage (or disadvantage, depending on context) that 180° rotations cannot be represented in it. (Even using floating point numbers that include infinity, rotation direction cannot be well-defined; for example, naively, a 180° rotation about the axis (1, 1, 0) would be (∞, ∞, 0), which is the same representation as 180° rotation about (1, 0.0001, 0).)
Modified Rodrigues parameters (MRPs) can be expressed in terms of Euler axis and angle by
The modified Rodrigues parameterization shares many characteristics with the rotation vector parametrization, including the occurrence of discontinuous jumps in the parameter space when incrementing the rotation.
Cayley–Klein parameters
See definition at Wolfram Mathworld.
Rotation matrix ↔ Euler angles
The Euler angles
Rotation matrix → Euler angles (z-x-z extrinsic)
Using the x-convention, the 3-1-3 extrinsic Euler angles
Note that
When implementing the conversion, one has to take into account several situations:
Euler angles ( z-y’-x″ intrinsic) → Rotation matrix
The rotation matrix
The axes of the rotation depend on the specific convention being used. For the x-convention the rotations are about the
This yields
Note: This is valid for a right-hand system, which is the convention used in almost all engineering and physics disciplines.
Rotation matrix ↔ Euler axis/angle
If the Euler angle
Alternatively, the following method can be used:
Eigen-decomposition of the rotation matrix yields the eigenvalues 1, and
The Euler axis can be also found using Singular Value Decomposition since it is the normalized vector spanning the null-space of the matrix
To convert the other way the rotation matrix corresponding to an Euler axis
with
is the cross-product matrix.
This expands to...
Rotation matrix ↔ quaternion
When computing a quaternion from the rotation matrix there is a sign ambiguity, since
One way of computing the quaternion
There are three other mathematically equivalent ways to compute
The rotation matrix corresponding to the quaternion
with
which gives
or equivalently
Euler angles (z-x-z extrinsic) → Quaternion
We will consider the x-convention 3-1-3 extrinsic Euler Angles for the following algorithm. The terms of the algorithm depend on the convention used.
We can compute the quaternion
Euler angles (z-y’-x″ intrinsic) → Quaternion
Quaternion equivalent to yaw (
Quaternion → Euler angles (z-x-z extrinsic)
Given the rotation quaternion
Quaternion → Euler angles (z-y’-x″ intrinsic)
Given the rotation quaternion
Euler axis/angle ↔ quaternion
Given the Euler axis
can be computed by
Given the rotation quaternion
Rotation matrix ↔ angular velocities
The angular velocity vector
The derivation is adapted from as follows:
For any vector
The derivative of a vector is the linear velocity of its tip. Since A is a rotation matrix, by definition the length of
By the transitivity of the above-mentioned equations,
which implies (Q.E.D.),
Quaternion ↔ angular velocities
The angular velocity vector
where
Conversely, the derivative of the quaternion is
Rotors in a geometric algebra
The formalism of geometric algebra (GA) provides an extension and interpretation of the quaternion method. Central to GA is the geometric product of vectors, an extension of the traditional inner and cross products, given by
where the symbol
Bivectors in GA have some unusual properties compared to vectors. Under the geometric product, bivectors have negative square: the bivector
This result holds generally for all bivectors, and as a result the bivector plays a role similar to the imaginary unit. Geometric algebra uses bivectors in its analogue to the quaternion, the rotor, given by
where
Example. A rotation about the axis
Recognizing that
The result of the rotation is then
A simple check on this result is the angle
exactly as expected. This rotation formula is valid not only for vectors but for any multivector. In addition, when Euler angles are used, the complexity of the operation is much reduced. Compounded rotations come from multiplying the rotors, so the total rotor from Euler angles is
but
where
Thus, the compounded rotations of Euler angles become a series of equivalent rotations in the original fixed frame.
While rotors in geometric algebra work almost identically to quaternions in three dimensions, the power of this formalism is its generality: this method is appropriate and valid in spaces with any number of dimensions. In 3D, rotations have three degrees of freedom, a degree for each linearly independent plane (bivector) the rotation can take place in. It has been known that pairs of quaternions can be used to generate rotations in 4D, yielding six degrees of freedom, and the geometric algebra approach verifies this result: in 4D, there are six linearly independent bivectors that can be used as the generators of rotations.