# Screw theory

**Screw theory** is the algebraic calculation of pairs of vectors, such as forces and moments or angular and linear velocity, that arise in the kinematics and dynamics of rigid bodies.^{[1]}^{[2]} The mathematical framework was developed by Sir Robert Stawell Ball in 1876 for application in kinematics and statics of mechanisms (rigid body mechanics).^{[3]}

Screw theory provides a mathematical formulation for the geometry of lines which is central to rigid body dynamics, where lines form the screw axes of spatial movement and the lines of action of forces. The pair of vectors that form the Plücker coordinates of a line define a unit screw, and general screws are obtained by multiplication by a pair of real numbers and addition of vectors.^{[3]}

An important result of screw theory is that geometric calculations for points using vectors have parallel geometric calculations for lines obtained by replacing vectors with screws. This is termed the *transfer principle.*^{[4]}

Screw theory has become an important tool in robot mechanics,^{[5]}^{[6]} mechanical design, computational geometry and multibody dynamics. This is in part because of the relationship between screws and dual quaternions which have been used to interpolate rigid-body motions.^{[7]} Based on screw theory, an efficient approach has also been developed for the type synthesis of parallel mechanisms (parallel manipulators or parallel robots).^{[8]}

Fundamental theorems include Poinsot's theorem (Louis Poinsot, 1806) and Chasles' theorem (Michel Chasles, 1832). Felix Klein saw screw theory as an application of elliptic geometry and his Erlangen Program.^{[9]} He also worked out elliptic geometry, and a fresh view of Euclidean geometry, with the Cayley–Klein metric. The use of a symmetric matrix for a von Staudt conic and metric, applied to screws, has been described by Harvey Lipkin.^{[10]} Other prominent contributors include Julius Plücker, W. K. Clifford, F. M. Dimentberg, Kenneth H. Hunt, J. R. Phillips.^{[11]}

A spatial displacement of a rigid body can be defined by a rotation about a line and a translation along the same line, called a screw displacement. This is known as Chasles' theorem. The six parameters that define a screw displacement are the four independent components of the Plücker vector that defines the screw axis, together with the rotation angle about and linear slide along this line, and form a pair of vectors called a **screw**. For comparison, the six parameters that define a spatial displacement can also be given by three Euler angles that define the rotation and the three components of the translation vector.

A screw is a six-dimensional vector constructed from a pair of three-dimensional vectors, such as forces and torques and linear and angular velocity, that arise in the study of spatial rigid body movement. The components of the screw define the Plücker coordinates of a line in space and the magnitudes of the vector along the line and moment about this line.

The force and torque vectors that arise in applying Newton's laws to a rigid body can be assembled into a screw called a **wrench**. A force has a point of application and a line of action, therefore it defines the Plücker coordinates of a line in space and has zero pitch. A torque, on the other hand, is a pure moment that is not bound to a line in space and is an infinite pitch screw. The ratio of these two magnitudes defines the pitch of the screw.

A **twist** represents the velocity of a rigid body as an angular velocity around an axis and a linear velocity along this axis. All points in the body have the same component of the velocity along the axis, however the greater the distance from the axis the greater the velocity in the plane perpendicular to this axis. Thus, the helicoidal field formed by the velocity vectors in a moving rigid body flattens out the further the points are radially from the twist axis.

The points in a body undergoing a constant screw motion trace helices in the fixed frame. If this screw motion has zero pitch then the trajectories trace circles, and the movement is a pure rotation. If the screw motion has infinite pitch then the trajectories are all straight lines in the same direction.

where **S** and **V** are three-dimensional real vectors. The sum and difference of these ordered pairs are computed componentwise. Screws are often called *dual vectors*.

Now, introduce the ordered pair of real numbers â = (*a*, *b*) called a *dual scalar*. Let the addition and subtraction of these numbers be componentwise, and define multiplication as

The multiplication of a screw *S* = (**S**, **V**) by the dual scalar â = (*a*, *b*) is computed componentwise to be,

Finally, introduce the dot and cross products of screws by the formulas:

which is a screw. The dot and cross products of screws satisfy the identities of vector algebra, and allow computations that directly parallel computations in the algebra of vectors.

Let the dual scalar ẑ = (*φ*, *d*) define a *dual angle*, then the infinite series definitions of sine and cosine yield the relations

which are also dual scalars. In general, the function of a dual variable is defined to be *f*(ẑ) = (*f*(*φ*), *df*′(*φ*)), where *f*′(*φ*) is the derivative of *f*(*φ*).

A common example of a screw is the *wrench* associated with a force acting on a rigid body. Let *P* be the point of application of the force **F** and let **P** be the vector locating this point in a fixed frame. The wrench *W* = (**F**, **P**×**F**) is a screw. The resultant force and moment obtained from all the forces **F**_{i}, *i* = 1,...,*n*, acting on a rigid body is simply the sum of the individual wrenches *W*_{i}, that is

Notice that the case of two equal but opposite forces **F** and −**F** acting at points **A** and **B** respectively, yields the resultant

In order to define the *twist* of a rigid body, we must consider its movement defined by the parameterized set of spatial displacements, D(t)=([A(t)],**d**(t)), where [A] is a rotation matrix and **d** is a translation vector. This causes a point **p** that is fixed in moving body coordinates to trace a curve **P**(t) in the fixed frame given by,

where **v** is velocity of the origin of the moving frame, that is d**d**/dt. Now substitute **p** = [*A*^{T}](**P** − **d**) into this equation to obtain,

where [Ω] = [d*A*/d*t*][*A*^{T}] is the angular velocity matrix and ω is the angular velocity vector.

is the *twist* of the moving body. The vector **V** = **v** + **d** × *ω* is the velocity of the point in the body that corresponds with the origin of the fixed frame.

There are two important special cases: (i) when **d** is constant, that is **v** = 0, then the twist is a pure rotation about a line, then the twist is

and (ii) when [Ω] = 0, that is the body does not rotate but only slides in the direction **v**, then the twist is a pure slide given by

For a revolute joint, let the axis of rotation pass through the point **q** and be directed along the vector *ω*, then the twist for the joint is given by,

For a prismatic joint, let the vector **v** pointing define the direction of the slide, then the twist for the joint is given by,

The coordinate transformations for screws are easily understood by beginning with the coordinate transformations of the Plücker vector of line, which in turn are obtained from the transformations of the coordinate of points on the line.

Let the displacement of a body be defined by *D* = ([*A*], **d**), where [*A*] is the rotation matrix and **d** is the translation vector. Consider the line in the body defined by the two points **p** and **q**, which has the Plücker coordinates,

then in the fixed frame we have the transformed point coordinates **P** = [*A*]**p** + **d** and **Q** = [*A*]**q** + **d**, which yield.

Thus, a spatial displacement defines a transformation for Plücker coordinates of lines given by

The matrix [*D*] is the skew-symmetric matrix that performs the cross product operation, that is [*D*]**y** = **d** × **y**.

The 6×6 matrix obtained from the spatial displacement *D* = ([*A*], **d**) can be assembled into the dual matrix

The dual matrix [*Â*] = ([*A*], [*DA*]) has determinant 1 and is called a *dual orthogonal matrix*.

Consider the movement of a rigid body defined by the parameterized 4x4 homogeneous transform,

This notation does not distinguish between **P** = (*X*, *Y*, *Z*, 1), and **P** = (*X*, *Y*, *Z*), which is hopefully clear in context.

The velocity of this movement is defined by computing the velocity of the trajectories of the points in the body,

The dot denotes the derivative with respect to time, and because **p** is constant its derivative is zero.

Substitute the inverse transform for **p** into the velocity equation to obtain the velocity of *P* by operating on its trajectory **P**(*t*), that is

Recall that [Ω] is the angular velocity matrix. The matrix [*S*] is an element of the Lie algebra se(3) of the Lie group SE(3) of homogeneous transforms. The components of [*S*] are the components of the twist screw, and for this reason [*S*] is also often called a twist.

From the definition of the matrix [*S*], we can formulate the ordinary differential equation,

and ask for the movement [*T*(*t*)] that has a constant twist matrix [*S*]. The solution is the matrix exponential

This formulation can be generalized such that given an initial configuration *g*(0) in SE(*n*), and a twist *ξ* in se(*n*), the homogeneous transformation to a new location and orientation can be computed with the formula,

In transformation geometry, the elemental concept of transformation is the reflection (mathematics). In planar transformations a translation is obtained by reflection in parallel lines, and rotation is obtained by reflection in a pair of intersecting lines. To produce a screw transformation from similar concepts one must use planes in space: the parallel planes must be perpendicular to the screw axis, which is the line of intersection of the intersecting planes that generate the rotation of the screw. Thus four reflections in planes effect a screw transformation. The tradition of inversive geometry borrows some of the ideas of projective geometry and provides a language of transformation that does not depend on analytic geometry.

The combination of a translation with a rotation effected by a screw displacement can be illustrated with the exponential mapping. This idea in transformation geometry was advanced by Sophus Lie more than a century ago. Even earlier, William Rowan Hamilton displayed the versor form of unit quaternions as exp(*a r*)= cos *a* + *r* sin *a*. The idea is also in Euler's formula parametrizing the unit circle in the complex plane.

Since *ε*^{2} = 0 for dual numbers, exp(*aε*) = 1 + *aε*, all other terms of the exponential series vanishing.

Let *a* be half the angle of the desired turn about axis *r*, and *br* half the displacement on the screw axis. Then form *z* = exp((*a* + *bε*)*r* ) and z* = exp((*a* − *bε*)*r*). Now the homography is

Now for any quaternion vector *p*, *p** = −*p*, let *q* = 1 + *pε* ∈ *F* where the required rotation and translation are effected.

William Kingdon Clifford initiated the use of dual quaternions for kinematics, followed by Aleksandr Kotelnikov, Eduard Study (*Geometrie der Dynamen*), and Wilhelm Blaschke. However, the point of view of Sophus Lie has recurred.^{[12]}
In 1940, Julian Coolidge described the use of dual quaternions for screw displacements on page 261 of *A History of Geometrical Methods*. He notes the 1885 contribution of Arthur Buchheim.^{[13]} Coolidge based his description simply on the tools Hamilton had used for real quaternions.

Evidently the group of units of the ring of dual quaternions is a Lie group. A subgroup has Lie algebra generated by the parameters *a r* and *b s*, where *a*, *b* ∈ **R**, and *r*, *s* ∈ **H**. These six parameters generate a subgroup of the units, the unit sphere. Of course it includes *F* and the 3-sphere of versors.

Consider the set of forces **F**_{1}, **F**_{2} ... **F**_{n} act on the points **X**_{1}, **X**_{2} ... **X**_{n} in a rigid body. The trajectories of **X**_{i}, *i* = 1,...,*n* are defined by the movement of the rigid body with rotation [*A*(*t*)] and the translation **d**(*t*) of a reference point in the body, given by

where **ω** is the angular velocity vector and **v** is the derivative of **d**(*t*).

The work by the forces over the displacement *δ***r**_{i}=**v**_{i}*δt* of each point is given by

Define the velocities of each point in terms of the twist of the moving body to obtain

Introduce the twist of the moving body and the wrench acting on it given by

The 6×6 matrix [Π] is used to simplify the calculation of work using screws, so that

If the virtual work of a wrench on a twist is zero, then the forces and torque of the wrench are constraint forces relative to the twist. The wrench and twist are said to be *reciprocal,* that is if

In the study of robotic systems the components of the twist are often transposed to eliminate the need for the 6×6 matrix [Π] in the calculation of work.^{[4]} In this case the twist is defined to be