Tuesday, December 31, 2019

Parallelograms, Plucker Coordinates and Dual Numbers

Figure $\mathrm{1}$ will be used to point out some properties of parallelograms that have bearing on Plucker coordinates. The two parallelograms $\mathrm{1}$ and $\mathrm{2}$ shown in the figure have the same base lengths $\mathrm{b}$ and the same length heights $\mathrm{h}$.


Figure 1

The area $\mathrm{A}$ of a parallelogram is just:

$$\mathrm{A} = \mathrm{b}\mathrm{h}\tag{1}$$

So both parallelograms have the same area:

$$\mathrm{A_1} = \big(\mathrm{a} + \mathrm{b}\big)\mathrm{h} - \frac{1}{2}\big(\mathrm{a}\mathrm{h} + \mathrm{a}\mathrm{h}\big) = \mathrm{b}\mathrm{h}$$ $$\mathrm{A_2} = \big(\mathrm{c} + \mathrm{b}\big)\mathrm{h} - \frac{1}{2}\big(\mathrm{c}\mathrm{h} + \mathrm{c}\mathrm{h}\big) = \mathrm{b}\mathrm{h}$$

Therefore

$$\mathrm{A_1} = \mathrm{A_2} $$

This will be the case for all parallelograms of same length bases and heights independent of the lengths like $\mathrm{a}$ and $\mathrm{c}$ and therefore independent of the length of their diagonals like $\mathrm{d_1}$ and $\mathrm{d_2}$.

Since the acute angle between a diagonal $\mathrm{d}$ and it's base $\mathrm{b}$ is $\theta$ then the area of a parallelogram can be written as:

$$\mathrm{A} = \mathrm{b}\mathrm{d}\sin{(\theta)}\tag{2}$$

If we associate the vector $\vec{b}$ with the base $\mathrm{b}$ and vector $\vec{d}$ with the diagonal $\mathrm{d}$ then the area of the parallelogram is the same as the absolute value of $\vec{b} \times \vec{d}$:

$$\Vert \vec{b} \times \vec{d} \Vert = \Vert \vec{b} \Vert\Vert \vec{d} \Vert \sin{(\theta)} = \mathrm{A}\tag{3}$$

Which also means from our two parallelograms that:

$$\begin{align} \Vert \vec{b} \Vert\Vert \vec{d_1} \Vert \sin{(\theta_1)} &= \Vert \vec{b} \Vert\Vert \vec{d_2} \Vert \sin{(\theta_2)} \\ \Vert \vec{b} \times \vec{d_1} \Vert &= \Vert \vec{b} \times \vec{d_2} \Vert \end{align}$$

Let the direction of the cross products be given by the unit vector $\vec{u_m}$ then:

$$\vec{b} \times \vec{d} = \Vert \vec{b} \Vert\Vert \vec{d} \Vert \sin{(\theta)} \vec{u_m}$$

If both cross products have the same direction $\vec{u_m}$ we then have:

$$ \vec{b} \times \vec{d_1} = \vec{b} \times \vec{d_2}$$

Figure $\mathrm{2}$ shows a line $\mathrm{L}$ in $\mathrm{3D}$ space with vectors $\vec{p}$ and $\vec{p_{\perp}}$ to points on $\mathrm{L}$, a vector $\vec{l}$ parallel with line $\mathrm{L}$ and the vector $\vec{m} = \vec{p} \times \vec{l}$.


Figure 2

The vector $\vec{p_{\perp}}$ happens to be perpendicular to $\mathrm{L}$ but from our previous discussion, a vector $\vec{q}$ to any point on $\mathrm{L}$ will satisfy the following equality:

$$ \vec{q} \times \vec{l} = \vec{p} \times \vec{l} = \vec{m} $$

Now if you have $\vec{l}$ and $\vec{m}$ then how do you find $\vec{q}$ given that $\vec{q}$ can be to any point on the line $\mathrm{L}$? We can make this well-defined by choosing $\vec{q} = \vec{p_{\perp}}$. With this choice, $\vec{l}$, $\vec{p_{\perp}}$ and $\vec{m}$ are orthogonal thus $\vec{l} \cdot \vec{p_{\perp}} = 0$ and vector $\vec{l} \times \vec{m}$ is in the same direction as $\vec{p_{\perp}}$ with magnitude

$$\begin{align} \Vert \vec{l} \times \vec{m} \Vert &= \Vert \vec{l} \Vert\Vert \vec{m} \Vert \\ &= \Vert \vec{l} \Vert\Vert \vec{p_{\perp}} \times \vec{l} \Vert \\ &= {\Vert \vec{l} \Vert}^{2}\Vert \vec{p_{\perp}}\Vert \end{align}$$

and therefore

$$\Vert \vec{p_{\perp}} \Vert = \frac{\Vert \vec{l} \times \vec{m} \Vert}{{\Vert \vec{l} \Vert}^{2}} = \frac{\Vert \vec{m} \Vert}{\Vert \vec{l} \Vert}\tag{4}$$ $$\vec{p_{\perp}} = \frac{\vec{l} \times \vec{m}}{{\Vert \vec{l} \Vert}^{2}}\tag{5}$$

By making $\vec{l}$ a unit vector, $\Vert \vec{l} \Vert = 1$, we get:

$$\Vert \vec{p_{\perp}} \Vert = \Vert \vec{m} \Vert\tag{6}$$ $$\vec{p_{\perp}} = \vec{l} \times \vec{m}\tag{7}$$

Another way to get equation $(7)$ is with a vector triple product expansion of $\vec{l} \times \vec{m} = \vec{l} \times \big(\vec{p_{\perp}} \times \vec{l}\big)$.

$$\begin{align} \vec{l} \times \big(\vec{p_{\perp}} \times \vec{l}\big) &= \big(\vec{l} \cdot \vec{l} \big)\vec{p_{\perp}} - \big(\vec{l} \cdot \vec{p_{\perp}} \big) \vec{l} \\ &= {\Vert \vec{l} \Vert}^{2} \vec{p_{\perp}} \\ {\Vert \vec{l} \Vert}^{2} \vec{p_{\perp}} &= \vec{l} \times \vec{m} \\ \vec{p_{\perp}} &= \frac{\vec{l} \times \vec{m}}{{\Vert \vec{l} \Vert}^{2}} = \vec{l} \times \vec{m} \tag{8} \end{align}$$

Unit vector $\vec{l}$ and vector $\vec{m}$ will be the Plucker coordinates $\big(\vec{l}, \vec{m}\big)$ of line $\mathrm{L}$. The dual number representation $\pmb{\hat{l}}$ of these coordinates is:

$$\begin{align} \pmb{\hat{l}} &= \pmb{l} + \epsilon \pmb{m} \\ &= \big(0 + \vec{l}\big) + \epsilon \big(0 + \vec{m}\big) \\ &= \vec{l} + \epsilon \vec{m} \end{align}$$

where $\vec{l} = \mathrm{x_l}\vec{i} + \mathrm{y_l}\vec{j} + \mathrm{z_l}\vec{k}$ and $\vec{m} = \mathrm{x_m}\vec{i} + \mathrm{y_m}\vec{j} + \mathrm{z_m}\vec{k}$.

Wednesday, December 25, 2019

Unit Dual Quaternion For Translation And Rotation

Like in regular unit quaternion product or "sandwich" for a rotation, we will use the unit dual quaternion $\pmb{\hat{q}}$ and one of it's conjugates $\pmb{\bar{\hat{q}}^{*}}$ on a dual quaternion of a vector $\vec{v} = a\vec{i} + b\vec{j} + c\vec{k}$ to first perform product ("sandwich") for a translation of $\vec{v}$.

$$\begin{align} \big(\pmb{q_0} + \epsilon\pmb{q_{\epsilon}}\big)&\big( 1 + \epsilon\vec{v}\big)\big( \pmb{q_{0}^{*}} - \epsilon\pmb{q_{\epsilon}^{*}} \big) \\ &= \big(\pmb{q_0} + \epsilon\pmb{q_{\epsilon}}\big)\big( \pmb{q_{0}^{*}} - \epsilon\pmb{q_{\epsilon}^{*}} \big) + \big(\pmb{q_0} + \epsilon\pmb{q_{\epsilon}}\big)\epsilon\vec{v}\big( \pmb{q_{0}^{*}} - \epsilon\pmb{q_{\epsilon}^{*}} \big) \\ &= \pmb{q_0}\pmb{q_{0}^{*}} - \epsilon\big(\pmb{q_0}\pmb{q_{\epsilon}^{*}} - \pmb{q_{0}^{*}}\pmb{q_{\epsilon}}\big) - {\epsilon}^2\pmb{q_{\epsilon}}\pmb{q_{\epsilon}^{*}} + \epsilon\pmb{q_0}\vec{v}\pmb{q_{0}^{*}} - {\epsilon}^2\big(\pmb{q_0}\vec{v}\pmb{q_{\epsilon}^{*}} - \pmb{q_{\epsilon}}\vec{v}\pmb{q_{0}^{*}}\big) - {\epsilon}^3\pmb{q_{\epsilon}}\vec{v}\pmb{q_{\epsilon}^{*}} \\ &= 1 - \epsilon\big(\pmb{q_0}\pmb{q_{\epsilon}^{*}} - \pmb{q_{0}^{*}}\pmb{q_{\epsilon}}\big) + \epsilon\pmb{q_0}\vec{v}\pmb{q_{0}^{*}}\tag{1} \end{align}$$

Expanding the following terms from equation $\big(1\big)$:

$$\begin{align} \pmb{q_0}\pmb{q_{\epsilon}^{*}} - \pmb{q_{0}^{*}}\pmb{q_{\epsilon}} &= \big(w_0 + \vec{q}_{0}\big)\big( w_{\epsilon} - \vec{q}_{\epsilon}\big) - \big(w_0 - \vec{q}_{0}\big)\big( w_{\epsilon} + \vec{q}_{\epsilon}\big) \\ &= -2w_0\vec{q}_{\epsilon} + 2\vec{q}_{0}w_{\epsilon} \end{align}$$

Since $\pmb{\hat{q}}$ is a unit dual quaternion, we can choose $w_0 = 1$, $\vec{q}_{0} = 0$ and $w_{\epsilon} = 0$ then

$$w_0^2 + x_0^2 + y_0^2 + z_0^2 = (1)^2 + (0)^2 + (0)^2 + (0)^2 = 1$$ $$w_0 w_{\epsilon} + x_0 x_{\epsilon} + y_0 y_{\epsilon} + z_0 z_{\epsilon} = (1)(0) + (0)x_{\epsilon} + (0)y_{\epsilon} + (0)z_{\epsilon} = 0$$

These values satisfy the unit condition and we get:

$$-2w_0\vec{q}_{\epsilon} + 2\vec{q}_{0}w_{\epsilon} = -2\vec{q}_{\epsilon}$$

Likewise for the remaining term of equation $\big(1\big)$ we have

$$\epsilon\pmb{q_0}\vec{v}\pmb{q_{0}^{*}} = \epsilon\vec{v}$$

Thus this quaternion product has no rotational effect on vector $\vec{v}$ and equation $\big(1\big)$ becomes:

$$1 + 2\epsilon\vec{q}_{\epsilon} + \epsilon\vec{v}\tag{2}$$

which is a dual quaternion representation of the resultant of $\vec{v}$ added to the vector associated with $2\vec{q}_{\epsilon}$. In other words, a translation of the point $\vec{v}$ in direction $\vec{q}_{\epsilon}$ by distance $\Vert 2\vec{q}_{\epsilon} \Vert$. If the translation vector is $\vec{d} = x_{d}\vec{i} + y_{d}\vec{j} + z_{d}\vec{k}$ then we can correct the translation distance doubling in our dual quaternion term $\big(\pmb{q_0} + \epsilon\pmb{q_{\epsilon}}\big)$ by using half the length of $\vec{d}$:

$$\begin{align} \big(1 + \frac{\epsilon}{2}\vec{d}\big)\big(1 + \epsilon\vec{v}\big)\big(1 - \frac{\epsilon}{2}\vec{d^{*}}\big) &= \big(1 + \epsilon\vec{v} + \frac{\epsilon}{2}\vec{d}\big)\big(1 - \epsilon\vec{d^{*}}\big) \\ &= 1 - \frac{\epsilon}{2}\vec{d^{*}} + \epsilon\vec{v} + \frac{\epsilon}{2}\vec{d} \\ &= 1 + \epsilon\vec{d} + \epsilon\vec{v} \end{align}$$

Therefore unit dual quaternion for a translation $\pmb{\hat{t}}$ is:

$$\pmb{\hat{t}} = 1 + \frac{\epsilon}{2}\vec{d}\tag{3}$$

Now we perform a second dual quaternion product on $1 + \epsilon\vec{v}$ for the rotation on $\vec{v}$. Using the unit dual quaternion $\pmb{\hat{r}} = \pmb{r_0} + \epsilon(0)$, which means $\pmb{r_0}$ is a unit quaterion, gives:

$$\begin{align} \pmb{\hat{r}}\big( 1 + \epsilon\vec{v} \big) \pmb{\bar{\hat{r}}^{*}} &= \pmb{r_0}\big( 1 + \epsilon\vec{v} \big) \pmb{{r_0}^{*}} \\ &= 1 + \epsilon \pmb{r_0}\vec{v}\pmb{{r_0}^{*}} \end{align}$$

Combining the two products for translation then rotation gives the dual quaterion $\pmb{\hat{s}}$:

$$\begin{align} \pmb{\hat{s}} &= \pmb{\hat{r}}\pmb{\hat{t}} \\ &= \pmb{r_0}\big(1 + \frac{\epsilon}{2}\vec{d}\big) \\ &= \pmb{r_0} + \frac{\epsilon}{2}\pmb{r_0}\vec{d}\tag{4} \end{align}$$

and it's conjugate

$$\begin{align} \pmb{\bar{\hat{s}}^{*}} &= \pmb{\bar{\hat{t}}}^{*}\pmb{\bar{\hat{r}}}^{*} \\ &=\pmb{{r_0}^{*}} - \frac{\epsilon}{2}\vec{d}^{*}\pmb{{r_0}^{*}}\tag{5} \end{align}$$

Applying the quaternion product with $\pmb{\hat{s}}$ to vector $\vec{v}$:

$$\begin{align} \pmb{\hat{s}}\big( 1 + \epsilon\vec{v}\big)\pmb{\bar{\hat{s}}^{*}} &= \big(\pmb{r_0} + \frac{\epsilon}{2}\pmb{r_0}\vec{d}\big)\big( 1 + \epsilon\vec{v}\big)\big(\pmb{{r_0}^{*}} - \frac{\epsilon}{2}\vec{d}^{*}\pmb{{r_0}^{*}}\big) \\ &= \big(\pmb{r_0} + \epsilon\pmb{r_0}\vec{v} + \frac{\epsilon}{2}\pmb{r_0}\vec{d}\big)\big(\pmb{{r_0}^{*}} - \frac{\epsilon}{2}\vec{d}^{*}\pmb{{r_0}^{*}}\big) \\ &= 1 - \frac{\epsilon}{2}\pmb{r_0}\vec{d}^{*}\pmb{{r_0}^{*}} + \epsilon\pmb{r_0}\vec{v}\pmb{{r_0}^{*}} + \frac{\epsilon}{2}\pmb{r_0}\vec{d}\pmb{{r_0}^{*}} \\ &= 1 + \epsilon\pmb{r_0}\big(\vec{v} + \frac{\vec{d}}{2} - \frac{\vec{d}^{*}}{2} \big)\pmb{{r_0}^{*}} \end{align}$$

However, $\vec{d}$ is a pure regular quaternion, so

$$ -\vec{d}^{*} = \vec{d}$$

Therefore

$$\pmb{\hat{s}}\big( 1 + \epsilon\vec{v}\big)\pmb{\bar{\hat{s}}^{*}} = 1 + \epsilon\pmb{r_0}\big(\vec{v} + \vec{d}\big)\pmb{{r_0}^{*}}\tag{6}$$

If we reverse the order of the operations and perform a rotation then translation, we get:

$$\begin{align} \pmb{\hat{s}}\big( 1 + \epsilon\vec{v}\big)\pmb{\bar{\hat{s}}^{*}} &= \big(\pmb{r_0} + \frac{\epsilon}{2}\vec{d}\pmb{r_0}\big)\big( 1 + \epsilon\vec{v}\big)\big( \pmb{{r_0}^{*}} - \frac{\epsilon}{2}\pmb{{r_0}^{*}}\vec{d}^{*}\big) \\ &= \big(\pmb{r_0} + \epsilon\pmb{r_0}\vec{v} + \frac{\epsilon}{2}\vec{d}\pmb{r_0}\big)\big( \pmb{{r_0}^{*}} - \frac{\epsilon}{2}\pmb{{r_0}^{*}}\vec{d}^{*}\big)\\ &= \pmb{r_0}\pmb{{r_0}^{*}} - \frac{\epsilon}{2}\pmb{r_0}\pmb{{r_0}^{*}}\vec{d}^{*} + \epsilon\pmb{r_0}\vec{v}\pmb{{r_0}^{*}} + \frac{\epsilon}{2}\vec{d}\pmb{r_0}\pmb{{r_0}^{*}}\\ &= 1 + \epsilon\big(\pmb{r_0}\vec{v}\pmb{{r_0}^{*}} + \vec{d}\big)\tag{7} \end{align}$$

We can modify the regular unit quaternion $\pmb{r_0} = r_0 + \vec{r}$ into one that uses angles of rotation around the axis $\vec{r}$. See Extracting the Cross and Dot Products from the Quaternion Rotation Operator. The scalar part is $\cos{\Big(\frac{\theta}{2}\Big)}$ and the vector part is the unit vector $\vec{u}$ of $\vec{r}$ scaled by $\sin{\Big(\frac{\theta}{2}\Big)}$.

$$\pmb{r_0} = \cos{\Big(\frac{\theta}{2}\Big)} + \sin{\Big(\frac{\theta}{2}\Big)}\vec{u}\tag{8}$$

Substituting $(8)$ into $(4)$:

$$\begin{align} \pmb{\hat{s}} &= \pmb{r_0} + \frac{\epsilon}{2}\pmb{r_0}\vec{d} \\ &= \cos{\Big(\frac{\theta}{2}\Big)} + \sin{\Big(\frac{\theta}{2}\Big)}\vec{u} + \frac{\epsilon}{2}\bigg( \cos{\Big(\frac{\theta}{2}\Big)} + \sin{\Big(\frac{\theta}{2}\Big)}\vec{u} \bigg)\vec{d} \\ &= \cos{\Big(\frac{\theta}{2}\Big)} + \sin{\Big(\frac{\theta}{2}\Big)}\vec{u} + \frac{\epsilon}{2}\bigg( \cos{\Big(\frac{\theta}{2}\Big)}\vec{d} + \sin{\Big(\frac{\theta}{2}\Big)}\Big(\vec{u}\times\vec{d}\Big) - \sin{\Big(\frac{\theta}{2}\Big)}\Big(\vec{u}\cdot\vec{d}\Big) \bigg)\tag{9} \end{align}$$

Likewise, substituting $(8)$ into $(5)$:

$$\begin{align} \pmb{\hat{s}} &= \pmb{{r_0}^{*}} - \frac{\epsilon}{2}\vec{d}^{*}\pmb{{r_0}^{*}} \\ &= \cos{\Big(\frac{\theta}{2}\Big)} - \sin{\Big(\frac{\theta}{2}\Big)}\vec{u} - \frac{\epsilon}{2} \bigg(\cos{\Big(\frac{\theta}{2}\Big)}\vec{d}^{*} - \sin{\Big(\frac{\theta}{2}\Big)}\Big(\vec{d}^{*} \times \vec{u}\Big) +\sin{\Big(\frac{\theta}{2}\Big)}\Big(\vec{d}^{*}\cdot\vec{u}\Big)\bigg)\tag{10} \\ \end{align}$$

Monday, December 23, 2019

How To Represent A 3D Vector As A Unit Dual Qauternion

To see how any $3D$ vector $\vec{v} = \big(a, b, c\big)$ can be represented as a unit dual quaternion, let's start with the dual quaternion $\pmb{\hat{q}} = \pmb{q_0} + \epsilon\pmb{q_{\epsilon}}$ with quaternions components $\pmb{q_0}$ and $\pmb{q_{\epsilon}}$. The real and imaginary parts of $\pmb{q_0}$ and $\pmb{q_{\epsilon}}$ are given as follows with the imaginary part italicized and an arrow above:

$$\begin{align} \pmb{q_0} &= w_0 + \vec{q}_{0} = w_0 + \big(x_0\vec{i} + y_0\vec{j} + z_0\vec{k}\big)\\ \pmb{q_{\epsilon}} &= w_{\epsilon} + \vec{q}_{\epsilon} = w_{\epsilon} + \big(x_{\epsilon}\vec{i} + y_{\epsilon}\vec{j} + z_{\epsilon}\vec{k} \big) \end{align}$$

Their respective conjugates are:

$$\begin{align} \pmb{q_{0}^{*}} &= w_0 - \vec{q}_{0} = w_0 - \big(x_0\vec{i} + y_0\vec{j} + z_0\vec{k}\big)\\ \pmb{q_{\epsilon}^{*}} &= w_{\epsilon} - \vec{q}_{\epsilon} = w_{\epsilon} - \big(x_{\epsilon}\vec{i} + y_{\epsilon}\vec{j} + z_{\epsilon}\vec{k} \big) \end{align}$$

Unlike regular quaternions, there are three different conjugations of dual quaternions which depend on whether:

  1. The dual number is conjugated

    $$\pmb{\bar{\hat{q}}} = \pmb{q_0} - \epsilon\pmb{q_{\epsilon}}$$

    This finds little use except in deriving the third type of conjugation $\pmb{\bar{\hat{q}}^{*}}$.

  2. The quaternion components are conjugated

    $$\pmb{\hat{q}^{*}} = \pmb{q_{0}^{*}} + \epsilon\pmb{q_{\epsilon}^{*}}$$

    The result of $\pmb{\hat{q}}\pmb{\hat{q}^{*}}$ is a dual scalar but it can be just a regular scalar when the dot-product $\pmb{q_{0}} \cdot \pmb{q_{\epsilon}} = 0$ (i.e. when $\pmb{q_{0}}$ and $\pmb{q_{\epsilon}}$ are orthogonal 4-tuples).

  3. The dual number and quaternion components are both conjugated.

    $$\pmb{\bar{\hat{q}}^{*}} = \pmb{q_{0}^{*}} - \epsilon\pmb{q_{\epsilon}^{*}}$$

    The product $\pmb{\hat{q}}\pmb{\bar{\hat{q}}^{*}}$ is a dual quaternion whose real part is a scalar and dual part is a vector.

The conjugate $\pmb{\hat{q}^{*}} = \pmb{q_{0}^{*}} + \epsilon\pmb{q_{\epsilon}^{*}}$ is used to define the norm of $\pmb{\hat{q}}$:

$$\begin{align} \Vert \pmb{\hat{q}} \Vert &= \sqrt{\pmb{\hat{q}\hat{q}^{*}}} \\ &= \sqrt{\big(\pmb{q_0} + \epsilon\pmb{q_{\epsilon}}\big)\big(\pmb{q_{0}^{*}} + \epsilon\pmb{q_{\epsilon}^{*}}\big)} \\ &= \sqrt{\pmb{q_0q_{0}^{*}} + \epsilon\big(\pmb{q_0q_{\epsilon}^{*}} + \pmb{q_{\epsilon}q_0^{*}}\big)} \\ &= \sqrt{\pmb{q_0q_{0}^{*}} + 2\epsilon\big(\pmb{q_0} \cdot \pmb{q_{\epsilon}}\big)} \end{align}$$

where

$$\begin{align} \pmb{q_0q_{0}^{*}} &= \big(w_0 + x_0\pmb{i} + y_0\pmb{j} + z_0\pmb{k}\big)\big( w_0 - x_0\pmb{i} - y_0\pmb{j} - z_0\pmb{k}\big) \\ &= w_0^2 + x_0^2 + y_0^2 + z_0^2 \end{align}$$

and

$$\begin{align} \pmb{q_0q_{\epsilon}^{*}} + \pmb{q_{\epsilon}q_0^{*}} &= 2\big(w_0 w_{\epsilon} + x_0 x_{\epsilon} + y_0 y_{\epsilon} + z_0 z_{\epsilon} \big) \\ &= 2\big(\pmb{q_0} \cdot \pmb{q_{\epsilon}}\big) \end{align}$$

A unit dual quaternion has a norm $\Vert \pmb{\hat{q}} \Vert = 1$. Choosing $\pmb{q_0}$ and $\pmb{q_{\epsilon}}$ to be orthogonal makes the dot-product $\pmb{q_0} \cdot \pmb{q_{\epsilon}} = 0$ which then leaves us with $\sqrt{\pmb{q_0q_{0}^{*}}} = 1$ and therefore $w_0^2 + x_0^2 + y_0^2 + z_0^2 = 1$. Choosing $\vec{q}_{0} = 0$, $\mathrm{q_{\epsilon}} = 0$ and the coefficients of $\vec{q}_{\epsilon}$ to be $\big(a, b, c\big)$ of vector $\pmb{v}$ satisfies the conditions of the $\pmb{q_0} \cdot \pmb{q_{\epsilon}} = 0$ and $w_0^2 + x_0^2 + y_0^2 + z_0^2 = 1$:

$$w_0 w_{\epsilon} + x_0 x_{\epsilon} + y_0 y_{\epsilon} + z_0 z_{\epsilon} = w_0(0) + (0)a + (0)b + (0)c = 0$$
$$w_0^2 + x_0^2 + y_0^2 + z_0^2 = w_0^2 + (0)^2 + (0)^2 + (0)^2 = w_0^2$$ $$w_0^2 = 1$$

Thus $w_0 = 1$ and the vector $\vec{v} = \big(a, b, c\big)$ is encoded in a dual quaternion as:

$$\begin{align} &1 + \epsilon\big( a\vec{i} + b\vec{j} + c\vec{k} \big) \\ &1 + \epsilon\vec{v} \end{align}$$

Wednesday, July 3, 2019

Mozzi-Chasles' Screw Theorem, Half-Turn Equivalence and Combining Successive Screw Displacements

Any displacement of an object in 3D-space from an initial position to a final position can be replicated by a single helical screw-like motion around a unique axis (i.e, screw-axis). See Chasles' theorem (kinematics) for more details. Note that this post will not go over simple "edge" cases like when the body just does a slide (i.e. rectilinear translation) from one location to another without changing it's orientation nor the case when it just does a rotation around some axis (i.e, zero pitch helix). What will be discussed is the most general case of screw displacement from four perspectives:
  1. How to find the screw-axis given the initial and final positions of a body (e.g. triad).
  2. How to find a final point position on a body given an initial point position and the parameters of a screw displacement. Also finding an initial point position given the final point position and screw parameters.
  3. How the product of two half-turns is equivalent to a screw displacement.
  4. How to combine two successive screw displacements into one resultant screw displacement using a simple vector approach.
Three distinct non-collinear points of a body (i.e. triad) are used to define it's configuration in space because this is the minimum number required to fully establish it's placement. The reason for this is simple. Obviously one fixed point on the body isn't enough so what about two? The problem with just using two points is that the body can take up an infinity of orientations around the line through the first two points. A third point is needed that is not inline with the other two points to establish which orientation the body has around that line.



Finding The Screw-Axis and Screw-Displacement Parameters

Let's start by considering Figure 1. The three non-collinear points of the triad (i.e. body) in their initial positions are $\mathrm{A_i}, \mathrm{B_i}$ and $\mathrm{C_i}$ where $\mathrm{C_i}$ happens to coincide in this example with the origin $\mathrm{O}$ of the coordinate system. The final positions of these points after displacement are $\mathrm{A_f}, \mathrm{B_f}$ and $\mathrm{C_f}$.


Figure 1

Table 1 gives the coordinates for these point locations.


Table 1

The first step in finding the screw axis is shown in Figure 2. Imagine sliding the triad without changing it's orientation from it's final position to initial position so one of it's three points coincide. Say point $\mathrm{C_f}$ with point $\mathrm{C_i}$. This imaginary intermediate position of the triad is highlighted in blue and it's three points are now at $\mathrm{A_1}, \mathrm{B_1}$ and $\mathrm{C_i}$.



Figure 2

To find the associated coordinates, adding the vector $\mathrm{C_i} - \mathrm{C_f} = -\mathrm{C_f}$ to the coordinates of $\mathrm{A_f}, \mathrm{B_f}$ and $\mathrm{C_f}$, gives the coordinates for $\mathrm{A_1}, \mathrm{B_1}$ and $\mathrm{C_i}$ in Table 2 below.


Table 2

Now consider Figure 3 and the two triads at their initial and intermediate 1 positions. Imagine a plane $\mathrm{X}$ which is normal to and bisects line segment $\mathrm{A_{i}A_{1}}$ of triangle $\mathrm{A_{i}A_{1}C_{i}}$. Since $\mathrm{C_{i}A_{i}}$ and $\mathrm{C_{i}A_{1}}$ are equal length then plane $\mathrm{X}$ intersects $\mathrm{C_{i}}$. Any line $\mathrm{L_{1}}$ on plane $\mathrm{X}$ that intersects $\mathrm{C_{i}}$ will have angles $\mathrm{A_{i}C_{i}L_{1}}$ and $\mathrm{A_{1}C_{i}L_{1}}$ that are equal. $\mathrm{A_{i}}$ can be rotated by some amount to coincide with $\mathrm{A_{1}}$ around line $\mathrm{L_{1}}$. However, this same amount of rotational displacement may not move $\mathrm{B_{i}}$ to $\mathrm{B_{1}}$ around $\mathrm{L_{1}}$. So consider a second plane $\mathrm{Y}$ which is normal to and bisects line segment $\mathrm{B_{i}B_{1}}$ of triangle $\mathrm{B_{i}B_{1}C_{i}}$. Similarly, it to must intersect $\mathrm{C_{i}}$ and angles $\mathrm{B_{i}C_{i}L_{1}}$ and $\mathrm{B_{1}C_{i}L_{1}}$ are equal. Since planes $\mathrm{X}$ and $\mathrm{Y}$ intersect in a line common to both, let $\mathrm{L_{1}}$ be this line which then relates to segments $\mathrm{C_{i}A_{i}}$ and $\mathrm{C_{i}B_{i}}$ in exactly the same way as it relates to segments $\mathrm{C_{i}A_{1}}$ and $\mathrm{C_{i}B_{1}}$. Furthermore, the angles $\mathrm{A_{i}C_{i}L_{1}}$ and $\mathrm{B_{i}C_{i}L_{1}}$ are respectively equal to angles $\mathrm{A_{1}C_{i}L_{1}}$ and $\mathrm{B_{1}C_{i}L_{1}}$. Figure $\mathrm{A_{i}C_{i}B_{i}L_{1}}$ can now be moved so segments $\mathrm{C_{i}A_{i}}$ and $\mathrm{C_{i}B_{i}}$ respectively coincide to segments $\mathrm{C_{i}A_{1}}$ and $\mathrm{C_{i}B_{1}}$ with $\mathrm{L_{1}}$ retaining it's position unchanged. Thus a rotation by some amount, say $\Phi$ degrees, around $\mathrm{L_{1}}$ gives the needed displacement.



Figure 3

To find the unit direction vector $n$ of line $\mathrm{L_{1}}$, simply find the normalized cross-product of the red vector $f$ from $\mathrm{B_{i}}$ to $\mathrm{B_{1}}$ at the bottom of Figure 4 and green vector $g$ from $\mathrm{A_{i}}$ to $\mathrm{A_{1}}$ at the top of Figure 4.

$$ f = (-0.05060153, -0.10689649, 0.12795914)$$ $$ g = (0.00711297, -0.06315574, 0.18399511)$$ $$n = \frac{f \times g}{\left|\left| f \times g \right|\right|} \tag{1}$$ $$n = (-0.726506, 0.640829, 0.248048)$$

To find the angle of rotation $\Phi$, consider the top green vectors that lie in the same plane normal to $\mathrm{L_{1}}$.


Figure 4

These green vectors can be viewed from above as shown in Figure 5. One can see that $\Phi$ is related to $\left|\left|g\right|\right|$ and $\left|\left|h\right|\right|$ by:

$$ \tan\Big(\frac{\Phi}{2}\Big) = \frac{\frac{1}{2}\left|\left|g\right|\right|}{\frac{1}{2}\left|\left|h\right|\right|} = \frac{\left|\left|g\right|\right|}{\left|\left|h\right|\right|} = \frac{\left|\left|r_2 - r_1\right|\right|}{\left|\left|r_2 + r_1\right|\right|}\tag{2}$$

Figure 5

By preforming a cross-product of $r_2 + r_1$ with unit vector $n$ and using equation $(2)$ we get:

$$ r_2 - r_1 = (r_2 + r_1) \times \tan\Big(\frac{\Phi}{2}\Big)n \tag{3}$$

We can relate vectors $r_1$ and $r_2$ to the position vectors $R_1$ of point $\mathrm{A_{i}}$ and $R_2$ of point $\mathrm{A_{1}}$. Using the length of line segment $\mathrm{C_{i}}\mathrm{P}$ with the unit vector $n$ gives $r_1 = R_1 - (\mathrm{C_{i}}\mathrm{P})n$ and $r_2 = R_2 - (\mathrm{C_{i}}\mathrm{P})n$. Substituting these in $(3)$ gives:

$$ R_2 - R_1 = \big(R_2 + R_1 - 2(\mathrm{C_{i}}\mathrm{P})n\big) \times \tan\Big(\frac{\Phi}{2}\Big)n \tag{4} $$

Figure 6 illustrates the geometric relations between vectors $r_1, r_2, R_1$ and $R_2$.


Figure 6

Since $n \times n = 0$, equation $(4)$ becomes:

$$R_2 - R_1 = (R_2 + R_1) \times \tan\Big(\frac{\Phi}{2}\Big)n \tag{5}$$

Thus we get the following equation which is used to find the angle $\Phi$.

$$\tan\Big(\frac{\Phi}{2}\Big) = \frac{\left|\left|g\right|\right|}{\left|\left|(R_2 + R_1) \times n\right|\right|} \tag{6}$$

Therefore

$$ \Phi = 2 \tan^{-1} \Big(\frac{0.194662}{0.417455}\Big) = 50^\circ $$

Next, Figure 7 illustrates a slide of the triad in a direction parallel to $n$ from it's final position to an intermediate 2 position (highlighted in blue) a distance $\mathrm{d}$ so a point of the body, say $\mathrm{C_f}$, will be at an intermediate location $\mathrm{C_2}$ that is intersected by a line perpendicular to the $n$ direction and extending from the initial point position $\mathrm{C_i}$.


Figure 7

Since the direction vector of $\mathrm{L_1}$ is $n$, $\mathrm{C_i}$ is at the origin and $c_f$ is the direction vector of $\mathrm{C_f}$ then the distance $\mathrm{d}$ is:

$$ \mathrm{d} = (\mathrm{C_f} - \mathrm{C_i}) \cdot n = c_f \cdot n = 0.6 \tag{7}$$

Table 3 gives the coordinates of points $\mathrm{A_2}$, $\mathrm{B_2}$ and $\mathrm{C_2}$.



Table 3

The two triads at their initial and intermediate 2 locations have matching point-pairs, $(\mathrm{A_i},\mathrm{A_2}), (\mathrm{B_i}, \mathrm{B_2}), (\mathrm{C_i}, \mathrm{C_2})$, on planes parallel to each other and normal to $n$. The displacement of the triad from it's initial to intermediate 2 position is a planar movement, see Figure 8. A complete description of planar displacements, requires the tracking of at least two unique points on the body not collinear in a normal to the movement plane, say points $\mathrm{A_i}$ and $\mathrm{B_i}$. Let two planes $\mathrm{V}$ and $\mathrm{W}$ respectively perpendicularly bisect segments $\mathrm{A_{i}A_{2}}$ and $\mathrm{B_{i}B_{2}}$. These planes will then intersect in a line $\mathrm{L_{S}}$ that is parallel to $n$. Now from any arbitrary point $\mathrm{S}$ on $\mathrm{L_{S}}$ we can use the same logic as for Figure 3. $\mathrm{L_{S}}$ relates to segments $\mathrm{SA_{i}}$ and $\mathrm{SB_{i}}$ in exactly the same way as it relates to segments $\mathrm{SA_{2}}$ and $\mathrm{SB_{2}}$. Furthermore, the angles $\mathrm{A_{i}SL_{S}}$ and $\mathrm{B_{i}SL_{S}}$ are respectively equal to angles $\mathrm{A_{2}SL_{S}}$ and $\mathrm{B_{2}SL_{S}}$. Figure $\mathrm{A_{i}SB_{i}L_{S}}$ can now be moved so segments $\mathrm{SA_{i}}$ and $\mathrm{SB_{i}}$ respectively coincide to segments $\mathrm{SA_{2}}$ and $\mathrm{SB_{2}}$ with $\mathrm{L_{S}}$ retaining it's position unchanged.


Figure 8

The amount of angular displacement $\Phi$ in Figure 4 will be the same amount as around $\mathrm{L_S}$ shown in Figure 9. The reason for this is that line segments $\mathrm{A_{1}B_{1}}$ of Figure 4 and $\mathrm{A_{2}B_{2}}$ of Figure 9 are parallel, so their perpendicular projections on any plane must also be parallel. If you do the same projection for line segment $\mathrm{A_{i}B_{i}}$ and measure the angles between this projection and each of the other two then both angles will be measured on the same plane and they must be equal. Since $\mathrm{L_{1}}$ and $\mathrm{L_{S}}$ are parallel, rotations are on the same plane and rotation by $\Phi$ around $\mathrm{L_{1}}$ produces the same change in orientation as rotation by $\Phi$ around $\mathrm{L_{S}}$. Thus a rotation by $\Phi$ degrees around $\mathrm{L_{S}}$ gives the needed orientation.

Using the same type of vector construction as Figure 5 but in Figure 9 with the plane normal to $\mathrm{L_{S}}$ containing points $\mathrm{A_i}$, $\mathrm{A_2}$, $\mathrm{T}$ and vectors $a$, $v$, we can find the angle $\Phi$ around $\mathrm{L_{S}}$ analytically and show it has the same value as in Figure 4.


Figure 9

In Figure 9, vector $u_S$ is the position vector of $\mathrm{S}$ then $a_i = \mathrm{A_i} - u_S$ and $a_2 = \mathrm{A_2} - u_S $. Vectors $a$ and $v$ are:

$$\begin{align} a \; &= \; a_2 - a_i \; = \; \mathrm{A_2} - \mathrm{A_i} \\ v \; &= \; a_2 + a_i \; = \; \mathrm{A_2} + \mathrm{A_i} - 2u_S \end{align}$$

Deriving an equation similar to $(3)$ but for vectors $a$ and $v$ we have:

$$\begin{align} a &= v \times \tan\Big(\frac{\Phi}{2}\Big)n \\ \mathrm{A_2} - \mathrm{A_i} &= (\mathrm{A_2} + \mathrm{A_i} - 2u_S) \times \tan\Big(\frac{\Phi}{2}\Big)n \end{align}$$

Substituting $\mathrm{A_2} = \mathrm{A_f} - (\mathrm{d}) n$:

$$\mathrm{A_f} - (\mathrm{d})n - \mathrm{A_i} = (\mathrm{A_f} - (\mathrm{d})n + \mathrm{A_i} - 2u_S) \times \tan\Big(\frac{\Phi}{2}\Big)n $$

Rearranging terms, using $\mathrm{S}$ instead of $u_S$ and since $n \times n = 0$ gives:

$$\mathrm{A_f} - \mathrm{A_i} = (\mathrm{A_f} + \mathrm{A_i} - 2\mathrm{S}) \times \tan\Big(\frac{\Phi}{2}\Big)n + (\mathrm{d})n\tag{12}$$

As a quick check of $(12)$, plugging in our numbers and solving for $\Phi$ gives our expected value:

$$\begin{align} \Phi &= 2 \tan^{-1} \frac{\left|\left|\mathrm{A_f} - \mathrm{A_i} - (\mathrm{d})n\right|\right|}{\left|\left|(\mathrm{A_f} + \mathrm{A_i} - 2\mathrm{S}) \times n\right|\right|}\tag{13}\\ \\ &= 2 \tan^{-1} \bigg(\frac{0.543407}{1.16534}\bigg) = 50^\circ \end{align}$$

Next we derive the equation for point location $\mathrm{S}$ using equation $(12)$. It is common to choose the position vector $u_S$ of $\mathrm{S}$ so $n \cdot u_S = 0$ which also means $n \cdot \mathrm{S} = 0$. Letting $Q = \tan\Big(\frac{\Phi}{2}\Big)n$:

$$\begin{align} \mathrm{A_f} - \mathrm{A_i} &= (\mathrm{A_f} + \mathrm{A_i} - 2\mathrm{S}) \times Q + (\mathrm{d})n \\ &= (\mathrm{A_f} + \mathrm{A_i})\times Q - 2\mathrm{S}\times Q + (\mathrm{d})n\\ \mathrm{A_f} - \mathrm{A_i} - (\mathrm{A_f} + \mathrm{A_i})\times Q - (\mathrm{d})n &= - 2\mathrm{S}\times Q \end{align}$$

Left cross-multiplying each side by $Q$ and since $n \times n = 0$ then $n \times Q = 0$ and we get:

$$\big(\mathrm{A_f} - \mathrm{A_i} - (\mathrm{A_f} + \mathrm{A_i})\times Q \big)\times Q = - 2(\mathrm{S}\times Q)\times Q$$

Rearranging sides, using the vector triple product expansion of $(\mathrm{S}\times Q)\times Q = -(Q \cdot Q)\mathrm{S} + (Q \cdot \mathrm{S})Q$ and since $n \cdot \mathrm{S} = 0$ then $\mathrm{S} \cdot Q = 0$ which gives:

$$\begin{align} (\mathrm{S}\times Q)\times Q &= \frac{\big(\mathrm{A_f} - \mathrm{A_i}- (\mathrm{A_f} + \mathrm{A_i})\times Q\big)\times Q}{-2} \\ -(Q \cdot Q)\mathrm{S} + (Q \cdot \mathrm{S})Q &= \frac{\big(\mathrm{A_f} - \mathrm{A_i}- (\mathrm{A_f} + \mathrm{A_i})\times Q \big)\times Q}{-2} \\ \mathrm{S} &= \frac{\big(\mathrm{A_f} - \mathrm{A_i} - (\mathrm{A_f} + \mathrm{A_i})\times Q \big) \times Q}{2Q \cdot Q}\tag{14} \end{align}$$

Plugging our values into $(14)$ gives:

$$\mathrm{S} = \frac{(0.25286, 0.266901, 0.0510644)}{0.434885081686} = (0.581441, 0.613728, 0.11742)$$

With the screw axis and helical motion fully defined, the triad is moved helically from it's initial to final position. Figure 10 shows the helical movement following the right-hand rule but to keep the angular displacement at $\Phi$ degrees a left-hand helix is given in Figure 11.


Figure 10



Figure 11



Point Position Given Screw Displacement Parameters

In this second situation you are given an initial point position $\mathrm{A_i}$ with parameters for it's screw displacement, $n$, $\mathrm{S}$, $\Phi$ and $\mathrm{d}$, and you would like to calculate $\mathrm{A_i}$'s final position at $\mathrm{A_f}$. Likewise but in reverse, you are given the final point position and screw parameters and you would like to find the initial point position.

Consider Figure 9, where vectors $v_i$ and $v_2$ extend perpendicularly from point $\mathrm{T}$ on the screw axis to intersect respectively points $\mathrm{A_i}$ and $\mathrm{A_2}$. A black dashed construction line is extended from point $\mathrm{A_2}$ perpendicularly onto vector $v_i$. Since $\left|\left|v_i\right|\right| = \left|\left|v_2\right|\right|$ and from the geometry associated with the construction line we have:

$$\begin{align} \left|\left|v_i\right|\right|\cos(\Phi) &= \left|\left|v_2\right|\right|\cos(\Phi) \\ \left|\left|v_i\right|\right|\sin(\Phi) &= \left|\left|v_2\right|\right|\sin(\Phi) \end{align}$$

So we can get the following relationship for $v_2$ in terms of $v_i$:

$$v_2 = v_i\cos(\Phi) + v_i \sin (\Phi) \times n\tag{15}$$

Substitute $v_i = a_i - (a_i \cdot n)n$ and $v_2 = a_2 - (a_2 \cdot n)n$ in $(15)$ and using $a_2 \cdot n = a_i \cdot n$ gives:

$$ a_2 - (a_i \cdot n)n = \big(a_i - (a_i \cdot n)n\big) \cos(\Phi) + \big(a_i - (a_i \cdot n)n\big) \sin(\Phi)\times n $$ $$\begin{align} a_2 &= \big(a_i - (a_i \cdot n)n\big) \cos(\Phi) + \big(a_i - (a_i \cdot n)n\big) \sin(\Phi)\times n + (a_i \cdot n)n\\ &= a_i \cos(\Phi) + a_i \sin(\Phi)\times n - (a_i \cdot n)n \cos(\Phi) - (a_i \cdot n)n \sin(\Phi)\times n + (a_i \cdot n)n\\ &= a_i \cos(\Phi) + a_i \sin(\Phi)\times n + (a_i \cdot n) n ( 1 - \cos(\Phi))\tag{16} \end{align}$$

Next, the slide of distance $\mathrm{d}$ is added to $(16)$ giving $a_f$:

$$a_f = a_i \cos(\Phi) + a_i \sin(\Phi)\times n + (a_i \cdot n) n ( 1 - \cos(\Phi)) + (\mathrm{d})n\tag{17}$$

Finally, the origin is re-established back in it's original position, $a_f$ is correspondingly re-assigned coordinated $\mathrm{A_f}$ by $\mathrm{A_f} = a_f + u_S$, equation $(17)$ is changed in terms of $\mathrm{A_i}$ by $a_i = \mathrm{A_i} - u_S$, and using $\mathrm{S}$ instead of $u_S$ gives:

$$\mathrm{A_f} = (\mathrm{A_i} - \mathrm{S})\cos(\Phi) + (\mathrm{A_i} - \mathrm{S})\sin(\Phi)\times n + \big((\mathrm{A_i} - \mathrm{S}) \cdot n\big) n ( 1 - \cos(\Phi)) + (\mathrm{d})n + \mathrm{S}\tag{18}$$

Check $(18)$ by plugging in our values:

$$\begin{align} \mathrm{A_f} &= (-0.373742, -0.201661, -0.0754761) \\ &\quad + (-0.00197151, 0.175831, -0.460032) \\ &\quad + (-0.0498915, 0.0440079, 0.0170342) \\ &\quad + (0.145536, 0.998226, 0.266249) \\ \\ &= (-0.280069, 1.0164, -0.252225) \end{align}$$

Using a similar approach for finding $(16)$ but with the reverse situation where one wants to find $a_i$ given $a_2$ results in:

$$a_i = a_2 \cos (\Phi) + n \times \big(a_2 \sin (\Phi)\big) + (a_2 \cdot n)n\big(1 - \cos(\Phi)\big)\tag{19}$$

Equation $(19)$ in terms of $\mathrm{A_i}$ given $\mathrm{A_2}$ is:

$$\mathrm{A_i} = (\mathrm{A_2} - \mathrm{S}) \cos (\Phi) + n \times \big((\mathrm{A_2} - \mathrm{S}) \sin (\Phi)\big) + \big((\mathrm{A_2} - \mathrm{S}) \cdot n\big)n\big(1 - \cos(\Phi)\big) + \mathrm{S}\tag{20}$$

For $\mathrm{A_i}$ given $\mathrm{A_f}$ and simplify the expression by letting $\mathrm{X} = \mathrm{A_f} - \mathrm{S} - (\mathrm{d})n$ gives:

$$\mathrm{A_i} = \mathrm{X}\cos(\Phi) + n \times\big(\mathrm{X}\sin(\Phi)\big) + \big(\mathrm{X}\cdot n\big) n \big( 1 - \cos(\Phi)\big) + \mathrm{S}\tag{21}$$

Check $(21)$ by plugging in our values:

$$\begin{align} \mathrm{X} &= (-0.425605, 0.018174, -0.518499) \\ \\ \mathrm{A_i} &= (-0.273574, 0.011682, -0.333285) \\ &\quad + (-0.257986, -0.369435, 0.198816) \\ &\quad + (-0.049889, 0.0440057, 0.0170334) \\ &\quad + (0.58144, 0.613729, 0.11742) \\ \\ &= (0.0000, 0.3000, 0.0000) \end{align}$$


Half-Turns and Screw Displacements

As depicted in Figure 12, it will be shown that two half-turns of an object (i.e. triad) about two reference lines $\mathrm{H_1}$ and $\mathrm{H_2}$ that are skewed with each other and extend perpendicularly off the screw axis $s_1$ will be always reproduce a general screw displacement.


Figure 12

First, with a screw displacement any object will always face the axis in the same way. Consider Figure 12 and the red-dashed perpendiculars at locations $\mathrm{1}$ and $\mathrm{3}$. They are collinear with the triads blue rod which points away from the axis. The green rod points in the positive direction of the axis and the red rod points right when looked at toward the axis in the direction of the red-dashed perpendiculars from the end of the blue rod. This can also be seen in Figures 13 a, c and makes intuitive sense since the triads motion is analogous to moving on the outside surface of a cylinder centered at the axis. However, a single half-turn of an object around a perpendicular line extending off an axis like $\mathrm{H_1}$, that bisects the line segment connecting any point pair at $\mathrm{1}$ and $\mathrm{2}$, will reverse the objects orientation in the following way. The red-dashed perpendicular at $\mathrm{1}$ will remain perpendicular at $\mathrm{2}$ so the blue rod at $\mathrm{2}$ remains pointing perpendicularly away from the axis. The green rod at $\mathrm{2}$ points in the opposite direction when looking toward the axis in the direction of the red-dashed perpendicular from the end of the blue rod at $\mathrm{2}$. Likewise, the red rod at $\mathrm{2}$ points in the opposite direction when looked at in the same way because your point of view has changed to the other side of the axis causing this relative reversal. This can be seen in Figure 13 b.

a b c
Figure 13

Second, as the geometric symmetries depicted in Figure 14 with the two red-dashed perpendiculars for an arbitrary point at positions $\mathrm{1}$ and $\mathrm{2}$, all points of the object maintain their same perpendicular distance with respect to the axis with a half-turn.


Figure 14

Third, these relationships are general for these type of half-turns between bodies in any two positions. So a second half-turn around another line $\mathrm{H_2}$ for the triad from positions $\mathrm{2}$ to $\mathrm{3}$ will re-orient the object in the same way. However, since this is a reversal of a reversal, the triad is restored to it's original orientation facing the axis which is depicted in Figures 13 b, c. Furthermore, the same point perpendicular distance of the object from the axis at $\mathrm{1}$ and $\mathrm{2}$ are equal. Likewise, the same point perpendicular distance at $\mathrm{2}$ and $\mathrm{3}$ from the axis are equal. Since the point perpendicular distances at $\mathrm{2}$ are common to both half-turns then at all of objects three locations the point perpendicular distances (e.g. red-dashed lines in Figure 12) remain the same. Thus a two half-turn displacement is equivalent to a screw displacement.

Note that starting with just positions $\mathrm{1}$ and $\mathrm{3}$ of the screw displacement, one can arbitrarily pick a position for the first half-turn perpendicular and it can be for either the first or second half-turn. This establishes where position $\mathrm{2}$ will be and then the second perpendicular for the other half-turn is not arbitrary and is located based on position $\mathrm{2}$.

In Figure 15, let $\mathrm{t}$ be the distance between the points of the half-turn perpendiculars $\mathrm{H_1}$ and $\mathrm{H_2}$ on the axis. We can relate $\mathrm{t}$ to the amount of slide $\mathrm{d}$ for the screw displacement from $1$ to $3$. Let $\mathrm{l_1}$ be the distance between the points of the red-dashed perpendiculars on the axis between positions $1$ and $2$. Let $\mathrm{l_2}$ be the distance between the points of the red-dashed perpendiculars on the axis between positions $2$ and $3$. Since $\mathrm{l_1} - \mathrm{l_2} = \mathrm{d}$ and $\frac{\mathrm{l_1}}{2} - \frac{\mathrm{l_2}}{2} = \mathrm{t}$ then:

$$\mathrm{t} = \frac{\mathrm{d}}{2}\tag{22}$$

Figure 15

The view in Figure 16 is looking in the direction of the axis from the arrowhead side and is used to relate the screw displacements rotation angle $\Phi$, in this case clockwise between red-dashed perpendiculars at $\mathrm{1}$ and $\mathrm{3}$, to the angle $\theta$ between the half-turn perpendiculars $\mathrm{H_1}$ and $\mathrm{H_2}$ around the axis. Since $\Phi = α + β$ and $θ = \frac{α}{2} + \frac{\mathrm{β}}{2}$ then:

$$θ = \frac{\Phi}{2}\tag{23}$$

Figure 16



Combining Two Successive Screw Displacements

Figure 17 shows the idea of two successive screw displacements being replaced by a single screw displacement. The first displacement moves the object from positions $\mathrm{1}$ to $\mathrm{2}$ and the second from $\mathrm{2}$ to $\mathrm{3}$. These are replaced by one resultant screw displacement which moves the object from $\mathrm{1}$ to $\mathrm{3}$.



Figure 17

In $1882$, French mathematician Georges Halphen first proved this result and a proof using half-turns will be shown here. Also, vectors will later be used to derive formulas which only need the $n$, $\Phi$, $\mathrm{S}$ and $\mathrm{d}$ parameters of two successive screw displacement to find the parameters of the resultant screw displacement. Fortunately, this vector approach is not the typical, more obscure way that you find in textbooks.

A key point in this proof is that a common perpendicular exists between skewed screw axes of the two successive displacements. This sets your first half-turn perpendicular and is for both the second half-turn off the first screw axis and for the first half-turn off the second screw axis. As is apparent in Figure 18, the positioning of the other two half-turn perpendiculars, the first off the first axis and the second off the second axis, will now depend on the objects extra half-turn displacement position $\mathrm{2'}$ around the common perpendicular. From Figure 18:

  1. The first half-turn off the first axis moves the triad from it's initial location $\mathrm{1}$ to $\mathrm{2'}$.
  2. A second half-turn around the common half-turn perpendicular moves it from $\mathrm{2'}$ to $\mathrm{2}$.
  3. A third half-turn again around the common perpendicular moves it from $\mathrm{2}$ back to $\mathrm{2'}$.
  4. Finally the last half-turn off the second axis moves it from $\mathrm{2'}$ to it's final location $\mathrm{3}$.

Figure 18

Note that these two half-turn perpendiculars like the screw axes are assumed skewed to each other but there are other cases which they are not and these will be looked at later. To find the resultant screw axis let's look at the half-turns. The first half-turn moves the triad from $\mathrm{1}$ to $\mathrm{2'}$, the last half-turn moves it from $\mathrm{2'}$ to $\mathrm{3}$. The two skewed perpendiculars of these half-turns will also have a common perpendicular between them and since perpendicular distances from it to similar points at $\mathrm{1}$ and $\mathrm{3}$ are equal then this perpendicular line is collinear with the resultant screw axis for the displacement from $\mathrm{1}$ to $\mathrm{3}$. The resulting structure of three screw axes and three common half-turn perpendiculars is referred to as the screw triangle. This is shown in a common more compact form with the tips and tails of the screw axes touching the half-turn perpendiculars which have been highlighted green in Figure 19 and thus have length $\mathrm{t}_i$. Also shown are the angles $\theta_{ij}$ between pairs of half-turn perpendiculars with the order of the subscripts being the same as the order of the half-turns.


Figure 19

Before proceeding to both the geometric and vector analysis of combining successive screw displacements, the independence of object orientation from it's slide (i.e. rectilinear translation) needs to be pointed out. It should be obvious that slides do not change object orientation but orientations can be changed by rotations around axes. So if you have two successive screw displacements and you are interested in just the objects change in orientation then the slide components can be ignored. One thing to remember is that rotations are generally non-commutative so order of rotation around axes matters to what will be the final orientation.

For the screw triangle in Figure 20, each screw $s_i$ is fully specified by it's unit normal $n_i$, rotation angle $\Phi_i$, slide distance $\mathrm{d_i}$ and location $\mathrm{S_i}$. These parameters are written within a brace notation $\big\{n_i, \Phi_i, \mathrm{d_i}, \mathrm{S_i}\big\}$. For our three screws in Figure 20 we have the following values measured off CAD software that modeled this screw triangle example:

$$\begin{align} s_1&: \big\{(0.000000, 1.000000, 0.000000), 75.406^\circ, 2.311715, (1.2065, 0, -0.397253)\big\}\\ s_2&: \big\{(0.248398, 0.775381, -0.580589), -34.916^\circ, 1.38437516, (1.98205, -0.0717971, 0.752112)\big\}\\ s_3&: \big\{(-0.374394, 0.903483, 0.208679), 52.464^\circ, 2.15106828, (-0.439634, 0.427021, -2.63756)\big\} \end{align}$$ with associated $Q$ values calculated as:
$$\begin{align} Q_1 &= (0.000000, 0.772971, 0.000000) \\ Q_2 &= (-0.0781194, -0.243852, 0.182591) \\ Q_3 &= (-0.184485, 0.445196, 0.102828) \end{align}$$

Unit normal's of the screw triangle axes are all located at the origin with their tips on the surface of a unit radius sphere. Let normal's $n_1$, $n_2$ be for the two successive screw displacements $s_1$, $s_2$ and normal $n_3$ for the resultant screw displacement $s_3$. Given all this we will start by showing that the product of two rotations is a rotation by looking at Donkin's theorem.


Figure 20

In Figure 21 a, b, the first and second screw rotations through angles $\Phi_1$ and $\Phi_2$ respectively are shown moving a shape on the surface of the unit sphere. A right-hand convention will be used for positive rotations and note that $\Phi_2$ will have a negative value by this convention. Also, the shape and it's initial position can be arbitrary but a spherical triangle of certain proportions with a certain placement was chosen. This triangle is first rotated from position $1$ to $2$ through angle $\Phi_1$ around $n_1$ then from position $2$ to $3$ through angle $\Phi_2$ around $n_2$. However, the triangle can also be rotated from $1$ to $3$ through angle $\Phi_3$ around $n_3$ into congruence with the result of the two successive rotations around $n_1$ and $n_2$. Dorkin's theorem just picks the size, shape and initial placement of this triangle to make this congruence obvious and the geometric relationship between these three rotations evident.


a

b

c

Figure 21

To understand the choice of spherical triangle shape, it's size and initial placement in Dorkin's theorem consider Figure 22. The great circles are shown of the rotations around $n_1$, $n_2$, $n_3$. A blue spherical triangle is formed by arcs of these three great circles with vertices labelled $\mathrm{A}$, $\mathrm{B}$ and $\mathrm{C}$ and three line segments are extended from the origin to these vertices for future reference. The red triangle is shown in it's three locations, the size of the arc edges of the red triangle are chosen to be equal with corresponding arc edges of the blue triangle so all triangles are of equal size and shape.

The red triangle is initially placed so that the arc edge which corresponds to the blue triangles arc edge on $n_1$'s great circle, is also on $n_1$'s great circle and just the ends of these two edges touch. When the red triangle is rotated around $n_1$ by $\Phi_1$ to position $\mathrm{2}$, another one of it's edges is made to correspond to the blue triangles arc edge on $n_2$'s great circle, this edge is also on $n_2$'s great circle and just the ends of these two edges touch. Finally, the third edge of the red triangle at the initial position corresponds to the blue triangles arc edge on $n_3$'s great circle, it also is on $n_3$'s great circle and just the ends of these two edges touch.

Figure 22

In Figures 21, the red triangle was shown rotating on the surface of the unit radius sphere around vectors $n_1$, $n_2$ and $n_3$ and these figures could be used to show how a rotation $n_3$ is equivalent to the two successive rotations $n_1$ and $n_2$.

However, with the help of Figure 22 you can also show this result another way because the displacement for each of the rotations around the normals $n_i$ is equivalent to a pair of half-turns of the red triangle around two lines extending from $\mathrm{O}$. At position $1$, the top arc of the red triangle was chosen to have length equal to arc $\overparen{\mathrm{AB}}$ of the blue triangle. From position $1$, the red triangle is half-turned around line $\mathrm{OA}$ on the surface of the sphere which brings it's top arc into congruence with the blue triangles bottom arc. A second half-turn around line $\mathrm{OB}$ on the surface of the sphere then brings that same arc into congruence with the top arc of the red traingle at position $\mathrm{2}$. Since this top arc has equal length to arc $\overparen{\mathrm{AB}}$, rotation of the red-triangle around $n_1$ must be twice the length of $\overparen{\mathrm{AB}}$ and because a unit radius circle has arc lengths equal to their associated angles in radians then $\overparen{\mathrm{AB}} = \frac{1}{2}\Phi_1$. Similarly, a second arc of the red triangle was chosen to be the one on the great circle of $n_2$ when at position $2$ and have length equal to $\overparen{\mathrm{BC}}$. Half-turning the red triangle at $\mathrm{2}$ around $\mathrm{OB}$ and then $\mathrm{OC}$ brings this second arc into congruence with the corresponding edge of the red triangle positioned at $\mathrm{3}$. So $\overparen{\mathrm{BC}} = \frac{1}{2}\Phi_2$. Finally, the remaining arc of the red triangle was chosen to be the one on the great circle of $n_3$ when at position $3$ and to have a length equal to $\overparen{\mathrm{AC}}$. Half-turning the red triangle at $\mathrm{1}$ around $\mathrm{OA}$ and $\mathrm{OC}$ brings this remaining arc into congruence with the corresponding edge of the red triangle positioned at $\mathrm{3}$. So $\overparen{\mathrm{AC}} = \frac{1}{2}\Phi_3$. Thus the size of the triangles arc edges are chosen based on their corresponding angles of rotation, $\Phi_1$, $\Phi_2$ and $\Phi_3$.

Note that the lines $\mathrm{OA}$, $\mathrm{OB}$ and $\mathrm{OC}$ in Figure 22 are parallel with the green half-turn lines of the screw-triangle in Figure 20. Each line $\mathrm{OA}$, $\mathrm{OB}$ and $\mathrm{OC}$ is a common normal to vector pairs $(n_1, n_3)$, $(n_1, n_2)$ and $(n_2, n_3)$ respectively. This is obvious from Figure 22 since $\mathrm{OA}$, $\mathrm{OB}$ and $\mathrm{OC}$ are collinear with the line of intersection between the two planes of rotation normal to each vector pair of $n$'s. Now since the green half-turn lines are common normals between pairs of screw axes then it follows that they will be parallel with common normals between the associated pairs of $n$'s of these axes. We have also previously shown that half-turns around $\mathrm{OA}$, $\mathrm{OB}$ and $\mathrm{OC}$ will properly orientate our object and thus they are analogous to the half-turns around the green lines of the screw triangle.

Furthermore, we can see from the structure of the blue triangle and the line segments extending from $\mathrm{O}$ to $\mathrm{A}$, $\mathrm{B}$ and $\mathrm{C}$ that rotating the vertex $\mathrm{A}$ by $\frac{\Phi_1}{2}$ around $n_1$ is on the plane $\mathrm{OAB}$ normal to $n_1$ and brings it to $\mathrm{B}$ and then rotating by $\frac{\Phi_2}{2}$ around $n_2$ is on the plane $\mathrm{OBC}$ normal to $n_2$ and brings it to $\mathrm{C}$. Alternatively, rotating $\mathrm{A}$ by $\frac{\Phi_3}{2}$ around $n_3$ is on the plane $\mathrm{OAC}$ normal to $n_3$ and brings it to $\mathrm{C}$. Letting $a$, $b$ and $c$ be the position vectors of $\mathrm{A}$, $\mathrm{B}$ and $\mathrm{C}$, and examining their vector relationships with $n_1$, $n_2$ and $n_3$ in Figure 22, we can derive the formula for $Q_3 = \tan\Big(\frac{\Phi_3}{2}\Big)n_3$ in terms of $Q_1 = \tan\Big(\frac{\Phi_1}{2}\Big)n_1$ and $Q_2 = \tan\Big(\frac{\Phi_2}{2}\Big)n_2$.

Figure 23 is a version of Figure 22, simplified to look at the first rotation of vertex $\mathrm{A}$ to $\mathrm{B}$. Let point $\mathrm{M}$ be colinear with $\mathrm{OB}$, $\mathrm{M}$ is off the surface of the sphere and $\mathrm{M}$ is intersected by the perpendicular to vector $a$ that extends from point $\mathrm{A}$. Letting $m$ be the position vector of $\mathrm{M}$ we derive the formula for point $\mathrm{B}$.


Figure 23

Since $\tan\Big(\frac{\Phi_1}{2}\Big) = \left|\left|m - a\right|\right|\big/\left|\left|a\right|\right|$ then:

$$m - a = \tan\Big(\frac{\Phi_1}{2}\Big)n_1 \times a\tag{25}$$ $$m = a + Q_1 \times a\tag{26}$$

The unit vector for $m$ is the position vector $b$ and therefore:

$$\begin{align} b &= \frac{m}{\left|\left|m\right|\right|}\\ \\ &= \frac{a + Q_1 \times a}{\left|\left|a + Q_1 \times a\right|\right|}\tag{27} \end{align}$$

Similarily, going from $\mathrm{B}$ to $\mathrm{C}$:

$$c = \frac{b + Q_2 \times b}{\left|\left|b + Q_2 \times b\right|\right|}\tag{28}$$

Finally, from $\mathrm{A}$ to $\mathrm{C}$:

$$c = \frac{a + Q_3 \times a}{\left|\left|a + Q_3 \times a\right|\right|}\tag{29}$$

Inserting equation $(27)$ into $(28)$ gives:

$$c = \frac{a + Q_1 \times a + Q_2 \times a + Q_2 \times (Q_1 \times a)}{\left|\left|a + Q_1 \times a + Q_2 \times a + Q_2 \times (Q_1 \times a)\right|\right|}\tag{30}$$

Equating the right-hand sides of $(29)$ and $(30)$:

$$\frac{a + Q_3 \times a}{\left|\left|a + Q_3 \times a\right|\right|} = \frac{a + Q_1 \times a + Q_2 \times a + Q_2 \times (Q_1 \times a)}{\left|\left|a + Q_1 \times a + Q_2 \times a + Q_2 \times (Q_1 \times a)\right|\right|}\tag{31}$$

The numerator and denominator of $(31)$'s left-side can be multiplied by the same constant $\mathrm{k}$ without affecting the ratio on that side:

$$\bigg(\frac{\mathrm{k}}{\mathrm{k}}\bigg)\bigg(\frac{a + Q_3 \times a}{\left|\left|a + Q_3 \times a\right|\right|}\bigg) = \frac{a + Q_1 \times a + Q_2 \times a + Q_2 \times (Q_1 \times a)}{\left|\left|a + Q_1 \times a + Q_2 \times a + Q_2 \times (Q_1 \times a)\right|\right|}\tag{32}$$

Constant $\mathrm{k}$ can then be chosen so both numerators are equal:

$$\mathrm{k}(a + Q_3 \times a) = a + Q_1 \times a + Q_2 \times a + Q_2 \times (Q_1 \times a)\tag{33}$$

Using the vector triple product of $Q_2 \times (Q_1 \times a)$ which is $(Q_2 \cdot a)Q_1 - (Q_2 \cdot Q_1)a$ gives:

$$\mathrm{k}(a + Q_3 \times a) = a + Q_1 \times a + Q_2 \times a + (Q_2 \cdot a)Q_1 - (Q_2 \cdot Q_1)a\tag{34}$$

Rearranging and combining terms:

$$\mathrm{k}(Q_3 \times a) + ((Q_2 \cdot Q_1) - 1 + \mathrm{k})a = (Q_1 \times a) + (Q_2 \times a) + (Q_2 \cdot a)Q_1\tag{35}$$

Using the vector triple product expansion $-(a \cdot Q_1)Q_2 + (a \cdot Q_2)Q_1 = (Q_2 \times Q_1) \times a$ and taking into account that $a$ is perpendicular to $Q_1$ we then omit the term $(a \cdot Q_1)Q_2$. This gives $(a \cdot Q_2)Q_1 = (Q_2 \times Q_1) \times a$ which is substituted into $(35)$:

$$\mathrm{k}(Q_3 \times a) + ((Q_2 \cdot Q_1) - 1 + \mathrm{k})a = (Q_1 \times a) + (Q_2 \times a) + (Q_2 \times Q_1) \times a\tag{36}$$

Except for one summand in equation $(36)$, all other summands are perpendicular to $a$ because they are each cross products of $a$ with another vector. The exception is $((Q_2 \cdot Q_1) - 1 + \mathrm{k})a$ which just scales $a$ and thus is obviously parrallel to $a$. Since the right-hand side of $(36)$ result in a vector perpenducular to $a$ then $(36)$ can only be true if the left-hand side does as well. So the exception summand has to be zero, that is, $Q_2 \cdot Q_1 - 1 + \mathrm{k} = 0$. Inserting $\mathrm{k} = 1 - Q_2 \cdot Q_1$ into equation $(36)$ we get:

$$(1 - Q_2 \cdot Q_1)(Q_3 \times a) = (Q_1 \times a) + (Q_2 \times a) + (Q_2 \times Q_1) \times a\tag{37}$$

Hence

$$Q_3 \times a = \frac{Q_1 + Q_2 + Q_2 \times Q_1}{1 - Q_2 \cdot Q_1} \times a\tag{38}$$

Finally

$$Q_3 = \frac{Q_1 + Q_2 + Q_2 \times Q_1}{1 - Q_2 \cdot Q_1}\tag{39}$$

For our example, the calculated value of $Q_3$ from $(39)$ is:

$$Q_3 = \frac{(-0.219257, 0.529119, 0.122207)}{1.18849} = (-0.184484, 0.445203, 0.102825)$$


Next, we will find angle $\Phi_3$ from the spherical law of cosines for triangle $\mathrm{ABC}$.

$$\cos \Big(\frac{\Phi_3}{2}\Big) = \cos \Big(\frac{\Phi_1}{2}\Big)\cos \Big(\frac{\Phi_2}{2}\Big) - \cos \Big(\alpha\Big)\sin \Big(\frac{\Phi_1}{2}\Big)\sin \Big(\frac{\Phi_2}{2}\Big)\tag{40}$$ where $\cos(\alpha) = \left|\left|n_1 \cdot n_2\right|\right|$. For our values, $\cos(\alpha) = 0.775381$ and
$$\begin{align} \cos \Big(\frac{\Phi_3}{2}\Big) &= (0.791192)(0.953937) - (0.775381)(0.611568)(-0.300007) \\ &= 0.897010 \\ \\ \Phi_3 &= 2 \cos^{-1}(0.897010) = 52.46^\circ \end{align}$$ Hence
$$n_3 = \frac{(-0.184484, 0.445203, 0.102825)}{\tan(26.23^\circ)} = (-0.374426, 0.903577, 0.208692)$$


Finally, given $n_3$ and $\Phi_3$, we will find the slide distance $\mathrm{d_3}$ and then the location of $s_3$. It was mentioned before that the intersection point of a line from the origin $\mathrm{O}$ that is perpendicular to the screw axis is used as it's location point. In Figure 24, three black dashed lines are these perpendiculars, they intersect screws $s_1$, $s_2$, $s_3$ at points $\mathrm{S_1}$, $\mathrm{S_2}$, $\mathrm{S_3}$.


Figure 24

If $s_1$ was applied on a point to place it at a final position $\mathrm{S_2}$ then we can find it's initial position $\mathrm{S^{'}_{2}}$ by using equation $(21)$, but modifying it for a right-hand positive rotation convention which changes the order of the vector pairs in the cross-product term. Letting $\mathrm{X} = \mathrm{S_2} - \mathrm{S_1} - (\mathrm{d_1})n_1$ gives:

$$\mathrm{S^{'}_{2}} = \mathrm{X}\cos(\Phi_1) + \big(\mathrm{X}\sin(\Phi_1)\big) \times n_1 + \big(\mathrm{X}\cdot n_1\big) n_1 \big( 1 - \cos(\Phi_1)\big) + \mathrm{S_1}\tag{41}$$ $$\begin{align} \mathrm{X} &= (0.77555, -2.38351, 1.14937) \\ \\ \mathrm{S^{'}_{2}} &= (0.195414, -0.600568, 0.289604) \\ &+ (-1.11229, 0, 0.750527) \\ &+ (0, -1.78287, 0) \\ &+ (1.2065, 0, -0.397253) \\ \\ &= (0.289624, -2.38344, 0.642878) \end{align}$$

which closely agrees with the measured value $(0.289635, -2.38351, 0.642876)$.

When $s_2$ is applied on point $\mathrm{S_2}$ then it will only slide that point a distance $\mathrm{d_2}$ along $s_2$ to it's final position $\mathrm{S^{"}_{2}}$ which is found with:

$$\begin{align} \mathrm{S^{"}_{2}} &= \mathrm{S_2} + (\mathrm{d_2})n_2\tag{42} \\ \\ &= (1.98205, -0.071798, 0.752112) + (1.38438)(0.248398, 0.775381, -0.580589) \\ &= (2.32593, 1.00162, -0.051644) \end{align}$$

which closely agrees with the measured value $(2.32593, 1.00162, -0.0516412)$.

The slide distance $\mathrm{d_3}$ is then:

$$\begin{align} \mathrm{d_3} &= (\mathrm{S^{"}_{2}} - \mathrm{S^{'}_{2}}) \cdot n_3\tag{43} \\ \\ &= (2.03631, 3.38506, -0.694522) \cdot (-0.374394, 0.903483, 0.208679)\\ &= 2.15103 \end{align}$$

Finally, to find $\mathrm{S_3}$ with points $\mathrm{S^{'}_{2}}$ and $\mathrm{S^{"}_{2}}$, use the following version of equation $(14)$ which is again modified for a right-hand positive rotation convention that changes the order of the vector pairs in the cross-product terms:

$$\begin{align} \mathrm{S_3} &= \frac{Q_3 \times \big(\mathrm{S^{"}_{2}} - \mathrm{S^{'}_{2}} - Q_3 \times (\mathrm{S^{"}_{2}} + \mathrm{S^{'}_{2}}) \big)}{2Q_3 \cdot Q_3}\tag{44} \\ \\ &= \frac{(-0.213503, 0.207373, -1.28088)}{0.485616}\\ \\ &= (-0.439654, 0.427031, -2.63764) \end{align}$$


Now let's look at some edge cases with the screw-triangle. Note that the following figures use a left-hand screw because this gives a better view of the spirals.

First as shown in Figure 25, if either of the screws $s_1$, $s_2$ have no rotation and only a slide occurs like with screw $s_1$ then this screw will have both it's half-turn lines parallel and the resultant screw $s_3$ will have $n_3$ parallel with the other screw $s_2$. So $n_3$ and $n_2$ are parallel, $\Phi_3 = \Phi_2$ and equations $(42)$, $(43)$ and $(44)$ are used to find $\mathrm{d_3}$ and $\mathrm{S_3}$.


Figure 25

Second, what if axes $s_1$ and $s_2$ are not skewed but parallel like in Figure 26? No unique common perpendicular exists between them, the rotational portions of their displacements will be on parrallel planes so the resultant screw $s_3$ will be parallel to $s_1$ and $s_2$. This means that $n_1$, $n_2$ and $n_3$ are parallel, the angle $\left|\left|\Phi_3\right|\right| = \left|\left|\Phi_1 \pm \Phi_2\right|\right|$ and equations $(42)$, $(43)$ and $(44)$ are used to find $\mathrm{d_3}$ and $\mathrm{S_3}$.


Figure 26