Spatial Description & Transformation¶
Descriptions¶
Note that we use capital form (upper-case) \(X\) or bold form of lower case \(\pmb{x}\) to denote vectors.
Descriptions of a position, an orientation
In a coordinate system \(\{A\}\) (three orthogonal unit vectors), we use \(\hat{X}\) to denote the norm of vector \(X\) equals \(1\), and use subscript \(\hat{X}_A\) to denote \(X\) is the unit vector of frame \(\{A\}\) along \(x\)-axis.
(i) A point \(^AP\) (superscript on the left means reference frame is \(\{A\}\)) is expressed by a vector
or a vector expressed by unit vectors
(ii) Attach another coordinate system \(\{B\}\), with its unit vectors \(\hat{X}_B\), \(\hat{Y}_B\) and \(\hat{Z}_B\). If they are represented by system \(\{A\}\), as \(^A\hat{X}_B\), \(^A\hat{Y}_B\), and \(^A\hat{Z}_B\). Stack these three vectors together, and we have a Rotation Matrix from \(A\) to \(B\)
Actually, it represents the poze (orientation) transfer from \(\{A\}\) to \(\{B\}\). It is also a method to get a rotation matrix, using expression of \(\{B\}\) basis expressed in \(\{A\}\).
Properties of Rotation Matrix
(i) Calculate elements of rotation matrix.
Note that inner product is irrelevant with the choice of frame.
(ii) Show that
and then
(iii) \(^A_BR\) is reversible, and
If we consider from linear algebra, denoting \(\hat{\pmb{e}}_1,\hat{\pmb{e}}_2,\hat{\pmb{e}}_3\) as basis of \(\{B\}\), \(\pmb{e}_1,\pmb{e}_2,\pmb{e}_3\) as basis of \(\{A\}\), so
From inner product, we have
So a rotation matrix from \(\{A\}\) to \(\{B\}\), we have
\(\square\)
from (i) we could know that
Similarly we have
which is just the transpose of the first line of \(^A_BR\).
\(\square\)
Since
So \((^A_BR)^{-1}={^B_A}R^T\).
\(\square\)
Same Points in different frames¶
Now we could discuss the description of points within different frames.
Same points within different frames in simple cases
The following process is called analyze points from moving frame into fixed frame.
(i) \(\{B\}\) is a translation of \(\{A\}\). Then
(ii) \(\{B\}\) is a rotation of \(\{A\}\). Then
Note the we premultiply rotation matrix to \(^BP\), while we postmultiply rotation matrix to basis vectors in \(\{B\}\) to get basis vectors in \(\{A\}\).
(i) Easy to see.
(ii) Using relationship between basis vectors
we have
\(\square\)
Combined from the above two simple cases, we have the following general cases.
Same points within different frames in general cases
Assume \(\{B\}\) is translation and rotation of \(\{A\}\), then
Homogeneous Transform Matrix¶
It is usually good to think of the above formula as a mapping from \(^BP\) to \(^AP\), but if we write
where \(T_{3\times 3}\) is not just the rotation matrix or the translation, which is left out. We are adept to making use of \(^A_BR\) and \(^AO_B\) if we expend one dimension, as the following definition shows.
Homogeneous Transform
Define Homogeneous Transform to be
such that
Actually it is equivalent to equation \(\ref{3times3}\), because equation \(\ref{4times4}\) demonstrates
Properties of Homogeneous Transform
Inverse of Homogeneous Transform Matrix.
Assume homogeneous transform matrix \(^A_BT\) from \(\{A\}\) to \(\{B\}\), then it is reversible and
We make use of structure inherent of \(^A_BT\).
- For rotation matrix \(^A_BR\), by Properties of Rotation Matrix we have
- For translation vector \(^AO_B\), we want to know \(^BO_A\). This is a little tricky. We apply Same points within different frames in general cases to \(O_B\), in terms of \(\{B\}\). That is, we have the \(O_B\) in frame \(\{B\}\) expressed by frame \(\{A\}\)
which gives
Conbined with equation \(\ref{Rotation}\) and \(\ref{Translation}\), we have
So \({^A_BT}\cdot {^B_AT}=I_{4\times 4}\), which is reversible.
\(\square\)
The above proof also gives the method to quickly solve the inverse of \(^A_BT\).
Chain Rule¶
Chain Rule: Same points with multiple different frames
Assume frame \(\{C\}\) is known relative to frame \(\{B\}\), frame \(\{B\}\) is known relative to frame \(\{A\}\). Their relationship is expressed by \(^B_CT\) and \(^A_BT\), respectively. Then expression of point \(P\) in frame \(A\) could be expressed by transform of its expression in frame \(C\) as
That is, the relationship from \(\{A\}\) to \(\{C\}\) is
Notice that by Homogeneous Transform
\(\square\)
Operators¶
Operators like translation, rotation could ba accomplished by the same mathematics as mapping the point to a second frame.
Translation Operator
In frame \(\{A\}\), vector \(^AP_1\) is translated by a vector \(^AQ\), the result denoted by
We could use another perspective, i.e. construct a imaginary frame \(\{B\}\) with same orientation of \(\{A\}\) but origins at point \(Q\). The homogeneous transform matrix is
so the same point \(P\) (after translation) in frame \(\{A\}\) could be expressed in terms of that in frame \(\{B\}\)
Rotation Operator
Similar as we have in translation operator, we shall interpret a rotation to be a transform between two frames, i.e.
where
Here we discuss a little more about \(R_K(\theta)\) using different perspectives.
Fixed angles¶
X-Y-Z Fixed angles
Assume frame \(\{B\}\) coincides with a known reference frame \(\{A\}\), then rotate \(\{B\}\) about \(\hat{X}_A\) by an angle \(\gamma\), then rotate about \(\hat{Y}_A\) by an angle \(\beta\), and finally about \(\hat{Z}_A\) by an angle \(\alpha\).
We can interpret these three steps as moving the same vector \(P\) in three steps. Assume initially its expression in frame \(\{A\}\) is \(^AP\), the final point \(P'\) could be expressed by
On the other hand, expression of \(P'\) in frame \(\{B\}\) is the same as in frame \(\{A\}\), i.e. \({^BP'}={^AP}\). So
meaning \(^A_BR=R_Z(\alpha)\cdot R_Y(\beta)\cdot R_X(\gamma)\) by same point in different frames, which is also called X-Y-Z fixed angle, achieved by premultiplying rotation matrices. We define X-Y-Z fixed angle as
Euler angles¶
Z-Y-X Euler angles
Assume frame \(\{B\}\) coincides with a known reference frame \(\{A\}\), then rotate \(\{B\}\) about \(\hat{Z}_B\) by an angle \(\alpha\), then rotate about \(\hat{Y}_B\) by an angle \(\beta\), and finally about \(\hat{X}_B\) by an angle \(\gamma\).
For these three steps, we could construct three frames \(\{C\}\), \(\{D\}\) and \(\{E\}\). Easy to see that
and
By chain rule we have
meaning the whole process could be achieved by postmultiplying rotation matrices, which is also called Z-Y-X fixed angles. We define Z-Y-X Euler angle as
Notice the above process is the same as we have in fixed angles.
We have 6 symmetric and 6 non-symmetric forms of fixed angles or Euler angles.
Equivalent angle-axis¶
Definition of Equivalent angle-axis representations
Given a random axis \(^AK={^A\pmb{r}_{OK}}=[\begin{array}{ccc}k_x &k_y&k_z\end{array}]^T\) expressed in frame \(\{A\}\), rotate the original frame \(\{A\}\) about axis \(\pmb{r}_{OK}\) and get another frame \(\{B\}\). How to get the corresponding rotation matrix?
Assume \(\pmb{r}_{OK}\) is a unit vector. We want to find the expression of base vector \(\hat{X}_A\) after it is rotated.
Gimbal Lock¶
Does every matrix could be expressed by \(Z-Y-X\) angle?
When \(\beta=\frac{\pi}{2}\) in Euler's angle, then we lose a degree of freedom, solution is not unique.