Factorization of Rational Curves in the
Study Quadric and Revolute Linkages
Gabor Hegedüs∗, Josef Schicho∗, and Hans-Peter Schröcker†
March 21, 2018
Given a generic rational curve C in the group of Euclidean displacements
we construct a linkage such that the constrained motion of one of the links is
exactly C. Our construction is based on the factorization of polynomials over
dual quaternions. Low degree examples include the Bennett mechanisms and
contain new types of overconstrained 6R-chains as sub-mechanisms.
Keywords: Dual quaternions, rational motion, factorization, Bennett mechanism, over-
constrained mechanism, 6R-chain.
MSC 2010: 12D05, 51J15, 68T40
1 Introduction
The research on this paper started with an attempt to understand the geometry of
Bennett linkages [1–6] from the point of view of dual quaternions. The group of Eu-
clidean displacements can be embedded as an open subset of the Study quadric in the
projectivization of the dual quaternions regarded as a real vector space of dimension
eight. Rotation subgroups and and their composition then get an algebraic meaning (see
Hao [7], Selig [8, Chapter 9 and 10]). This was exploited in [4] to devise an algorithm
for the synthesis of a Bennett linkage to three pre-assigned poses. The key observation
there was that the coupler curve is the intersection of a unique 2-plane with the Study
quadric. Here, we translate the synthesis problem entirely into the language of dual
quaternions and we show that the problem is equivalent to the factorization of a left
quadratic polynomial into two linear ones.
∗Johann Radon Institute for Computational and Applied Mathematics Austrian Academy of Sciences (RI-
CAM), Altenbergerstrasse 69, 4040 Linz, Austria, e-mail: {gabor.hegedues}{josef.schicho}@oeaw.ac.at
RICAM Linz
†University Innsbruck, Unit Geometry and CAD, Technikerstraße 13, 6020 Innsbruck, Austria, e-mail:
hans-peter.schroecker@uibk.ac.at
1
arXiv:1202.0139v4  [math.RA]  9 May 2012
Factorizations of left polynomials over the quaternions have been studied by Niven in
[9], who was interested in the number of such factorizations, and Gordon and Motzkin
in [10], who proved that this number is either infinite or at most equal to the factorial
of the degree of the polynomial. ([10] studies more generally polynomials over central
simple algebras over commutative fields.) The more recent paper [11] by Huang and So
gives an explicit solution formula for quadratic polynomials. It is not difficult to extend
these results to dual quaternions.
Once the relation between the closure conditions in linkages and the factorizations
of left polynomials over dual quaternions became clear, it also became clear that this
relation holds for arbitrary linkages with rotational joints. Given a generic rational
curve C of degree n on the Study quadric with parametrization P(t), we construct n!
different factorizations P(t) = (t−h1) · · · (t−hn) with rotation quaternions h1, . . . , hn (or
translation quaternions in limiting cases). Each factorization corresponds to the movement
of an open nR-chain that guides the end-effector along C (Section 3). Combining all open
chains yields an overconstrained mechanism whose combinatorial structure is investigated
in Section 4. In Section 5, we discuss the extension to linkages with prismatic joints.
The case n = 2 is just the Bennett case. Our results agree with the recent findings of
[12] and naturally include the limit case of Bennett linkages (RPRP linkages). For n = 3
we obtain linkages that contain new examples of overconstrained 6R-chains. We present
them in more detail in Section 6.
A preliminary short version of this article is [13]. The present article is more complete.
We give strict proofs for all new results, discuss the extension to prismatic joints, present
additional examples and illustrate our results by figures. The Maple source for some
of the examples and additional animations can be found on the accompanying web-site
http://geometrie.uibk.ac.at/schroecker/qf/.
2 Preliminaries
In this section, we recall the well-known and classical description of the group of Euclidean
displacement by dual quaternions. The presentation is already adapted to our needs in
later sections. More general references are [7, 8].
We denote by SE3 the group of direct Euclidean displacements, i.e., the group of maps
from R3 to itself that preserves distances and orientation. It is well-known that SE3 is a
semidirect product of the translation subgroup T and the special orthogonal group SO3,
which may be identified with the stabilizer of a single point.
We denote by D := R + ϵR the ring of dual numbers, with multiplication defined by
ϵ2 = 0. The algebra H is the non-commutative algebra of quaternions, and DH is the
algebra of quaternions with coefficients in D. Every dual quaternion has a primal and a
dual part (both quaternions in H), a scalar part in D and a vectorial part in D3. The
conjugated dual quaternion h of h is obtained by multiplying the vectorial part of h by
−1. The dual numbers hh and h + h are called the norm and trace of h, respectively.
By projectivizing DH as a real 8-dimensional vectorspace, we obtain P7. The condition
that the norm of h is strictly real, i.e. its dual part is zero, is a homogeneous quadratic
2
equation. Its zero set, denoted by S, is called the Study quadric. The linear 3-space
of all dual quaternions with zero primal part is denoted by E. It is contained in the
Study quadric. The complement S −E can be identified with SE3. The primal part
describes SO3. Translations correspond to dual quaternions with primal part ±1 and
strictly vectorial dual part. More precisely, the group isomorphism is given by sending
h = p + ϵq to the map
v ∈R3 7→pvp + qp
pp
∈R3.
The image of this map is strictly vectorial, the map is in SE3, and the above formula
indeed provides a group homomorphism. Its bijectivity follows from the fact that both
groups are connected and of the same dimension.
A nonzero dual quaternion h = p + ϵq represents a rotation if and only if its norm and
trace are strictly real (hh, h + h ∈R) and its primal vectorial part is nonzero (p /∈R). It
represents a translation if and only if its norm and trace are strictly real and its primal
vectorial part is zero (p ∈R). The 1-parameter rotation subgroups with fixed axis and
the 1-parameter translation subgroups with fixed direction can be characterized as lines
on S through the identity element 1. Translations are characterized as those lines that
meet the exceptional 3-plane E.
3 Rational motions and open linkages
In this section we study rational curves in the Study quadric and construct a linkage
with rotational joints such that the last link moves along the prescribed curve. The main
technique is the factorization of polynomials over the dual quaternions.
3.1 Polynomial factorization over dual quaternions
Let C ⊂S be a rational curve of degree n > 0. Then there exists a parametrization of
C by a polynomial (antn + an−1tn−1 + an−2tn−2 + · · · + a0)t∈P1, where a0, . . . , an ∈DH
and P1 denotes the real projective line. It is no loss of generality to assume that this
polynomial is monic (an = 1). This can always be achieved by an appropriate choice of
coordinates.
Conversely, let DH[t] be the set of left polynomials with coefficients over DH. This set
can be given a ring structure by the convention that t commutes with the coefficients.
Let P ∈DH[t] be a polynomial of degree n > 0. We call the map fP : P1 →P7, t 7→P(t)
the map associated to P. The image is a rational curve of degree at most n.
If Q ∈R[t], Q ̸= 0, then the maps fP and fPQ are equal. Conversely, if P has a factor
in R[t] of positive degree, we can divide by it without changing the associated map. Note
that, in general, the set of right factors is different from the set of left factors. However,
a polynomial in R[t] or in D[t] is a left factor if and only if it is a right factor, because it
is in the center of DH[t].
For n > 0, an open linkage with n rotational joints can be described algebraically as
follows. Let h1, . . . , hn be rotations; for each i, the group parametrized by (t −hi)t∈P1 –
the parameter t determines the rotation angle – is the group of the (i + 1)-th link relative
3
to the i-th link. If we choose the same parameter for the n rotations, then the position
of the last link with respect to the first link is given by a product
P = (t −h1)(t −h2) · · · (t −hn)
with
t ∈P1.
(1)
P is a monic polynomial of degree n. Because it describes a rigid motion, it satisfies
the Study condition PP ∈R[t]. In this case we call P a motion polynomial. We ask
the converse question: Given a monic motion polynomial P of degree n, is it possible to
construct a factorization of type (1)? We will see that, in general, the answer is positive
(Theorem 3, below).
For the time being we restrict ourselves to factorizations with rotation quaternions
only. Later, in Section 5, we will show how to incorporate translation quaternions as well.
Lemma 1. If h is a rotation quaternion then M := (t −h)(t −h) is in R[t] and has no
real roots.
Proof. The first claim follows from the expansion M = t2 −t(h + h) + hh and the
observations that h + h ∈R (because the scalar dual part of h is zero) and hh ∈R
(because h lies on the Study quadric).
The discriminant of M equals ∆= (h + h)2 −4hh = (h −h)2. Since h is a rotation
quaternion, ∆is negative and M has no real roots. (The case ∆= 0 characterizes
translations.)
Proposition 2. Let P ∈DH[t] be a motion polynomial of degree n > 0 without strictly
real factors. If there is a factorization P(t) = (t−h1) · · · (t−hn) with rotation quaternions
h1, . . . , hn ∈DH, the polynomial PP ∈R[t] has no real zeroes.
Proof. Assume P = (t −h1) · · · (t −hn) and let Mi := (t −hi)(t −hi) for i = 1, . . . , n. By
Lemma 1, Mi is in R[t] and has no real roots. The same is true for PP = (t −h1) · · · (t −
hn)(t −hn) · · · (t −h1) = M1 · · · Mn.
We call a motion polynomial P ∈DH[t] of degree n > 0 generic if PP has n distinct
quadratic, irreducible factors. This implies that primal(P) has no strictly real factors,
because any such factor would appear with multiplicity ≥2 in the factorization of PP.
Theorem 3. Let P ∈DH[t] be a generic motion polynomial of degree n > 0. Then there
exists a factorization P(t) = (t −h1) · · · (t −hn) with hi ∈DH representing rotations.
We divide the proof of Theorem 3 into several lemmas. A central tool (also for the
computation of the factorization) is polynomial division in DH[t].
Lemma 4 (polynomial division). Let P1, P2 ∈DH[t] and assume P2 is monic. Then there
exists a unique representation P1 = QP2 + R with Q, R ∈DH[t] and deg(R) < deg(P2).
Moreover, if h ∈DH such that P2(h) = 0, then P1(h) = R(h).
Proof. The proof is a generalization of polynomial division to the non-commutative
case. Let n := deg(P1) and m := deg(P2). Existence of the representation is trivial if
n < m (Q = 0, R = P1). Assume inductively that polynomial division is possible for
4
all polynomials of degree less than n. We can write P1 = atn + P3 with deg(P3) < n,
and atn = atn−mP2 + P4 with deg(P4) < n. By the induction hypothesis, we have
P3 = Q3P2 +R3 and P4 = Q4P2 +R4 with deg(R3), deg(R4) < m. Combining, we obtain
P1 = (atn−m + Q4 + Q3)P2 + R3 + R4. This shows existence.
Now, assume that P1 = Q1P2 + R1 = Q2P2 + R2. Then (Q1 −Q2)P2 = R1 −R2. If
Q1 ̸= Q2, the polynomial on the left has degree greater or equal m while the polynomial
on the right has degree less than m. This is impossible, so that Q1 = Q2 and R1 = R2.
This shows uniqueness.
For the last statement, we have to show that P2(h) = 0 implies (QP2)(h) = 0. This is
not trivial, because h does not commute with the coefficients of P2. But the statement is
linear in Q, hence it is enough to prove it for monomials: If P2(h) = 0 and Q = atr, then
(QP2)(h) = aP2(h)hr = 0.
Lemma 5. Let P ∈DH[t] and h ∈DH. Then (t −h) is a right factor of P if and only
if P(h) = 0.
Proof. By Lemma 4, there is a unique representation P = Q(t −h) + R, and R is a
constant equal to P(h).
Lemma 6. Let P ∈DH[t] be a motion polynomial. Let M ∈R[t] be a monic polynomial
of degree two that divides PP but not primal(P). Then there exists a unique h ∈DH
such that P(h) = M(h) = 0.
Proof. By Lemma 4, we may write P = QM + R with Q, R ∈DH[t], deg(R) < 2. Since
M does not divide primal(P), we have primal(R) ̸= 0. On the other hand,
PP = (QM + R)(MQ + R) = (QQM + QR + RQ)M + RR.
Because M divides PP, we conclude RR = cM for some c ∈D, c ̸= 0. Assume that the
primal part of c is zero, that is, RR = ϵkM with k ∈H. This implies primal(R) = 0 and
contradicts our assumption. Hence primal(c) ̸= 0. The leading coefficient r1 of R cannot
have zero primal part because otherwise we get the contradiction r1r1 = 0 = c. Hence,
r1 is invertible in DH and, because of r1r1 = c, so is c. The polynomial R = r1t + r0 is
linear with invertible leading coefficient. Hence it has a unique zero h = −r−1
1 r0 ∈DH.
From R(h) = 0, we obtain cM(h) = 0 and, because c is invertible, M(h) = P(h) = 0.
This shows existence.
In order to show uniqueness, assume there exists h′ ∈DH with P(h′) = M(h′) = 0.
This implies R(h′) = 0. But then h′ = h because the zero of R is unique.
Proof of Theorem 3: We proceed by induction on n. For n = 0, the statement is trivial.
Assume n ≥1. Since the primal part of P has no strictly real factors, P itself has no
strictly real factors. Consequently, PP has no linear factors.
Let M be one of the irreducible quadratic factors of PP. By Lemma 6, there is a
unique h such that M(h) = P(h) = 0. By Lemma 5, there exists Q ∈DH[t] such
that P = Q(t −h). Obviously, Q is monic of degree n −1. Moreover, we have PP =
Q(t−h)(t−h)Q = QQM so that QQ is in R[t]. Furthermore, Q cannot have a strictly real
5
factor: This factor would also be a left factor and hence divide P. For similar reasons, the
primal part of Q cannot have strictly real factor (it would divide primal(P)). By induction
hypothesis, we obtain Q = (t −h1) · · · (t −hn−1) and so P = (t −h1) · · · (t −hn−1)(t −h).
Because of PP ∈R[t], h must be a rotation or translation quaternion. By genericity of
P, it is actually a rotation quaternion.
Remark 7. Theorem 3 is almost a converse to Proposition 2. But there are polynomials
P without real factors such that PP ∈R[t] where the proposition and the theorem do
not say anything. In this case, there exists an irreducible polynomial R ∈R[t] dividing
the primal part of P but not the dual part. Since R then also divides the primal part
of P and PP ∈R[t], the factor R appears with multiplicity two in the factorization of
PP. For instance, if P = t2 + 1 + ϵi, it can be shown that P is not the product of two
linear rotation polynomials. (Here, we assume that (1, i, j, k) is the standard basis of the
quaternion algebra H.) On the other hand, P = t2 + 1 + ϵjt + ϵi = (t −k)(t −k + ϵj) is
a product of two rotation polynomials. A systematic analysis would be good, but it is
probably more difficult. At this place, we only observe that P = t2 + 1 + ϵi is a quadratic
parametrization of a straight line.
3.2 Computing the factorization
Our proof of Theorem 3 is constructive and, with exception of the factorization of
PP, can be implemented in rational arithmetic. We describe this in more detail. Our
considerations will lead us to two new insights:
• The factorization depends on an ordering of the n quadratic factors of the polynomial
PP. Hence, there exist n! different factorizations and Theorem 3 actually admits a
stronger version (Theorem 8, below).
• If one factorization of P is known, the remaining factorizations can be computed
in rational arithmetic. In particular, it is possible to construct completely rational
examples by starting with the polynomial P = (t −h1) · · · (t −hn) where h1, . . . , hn
are rotation quaternions with rational coefficients.
Given is a motion polynomial P ∈DH[t]. We want to compute rotation quaternions
h1, . . . , hn such that P = (t −h1) · · · (t −hn). The pseudo-code for this calculation is
given in Algorithm 1. It returns an n-tuple H = (h1, . . . , hn). Here are some remarks on
the actual calculations:
• In Line 4, the choice of Mi ∈M is arbitrary. Thus, Algorithm 1 is not deterministic.
• The common root hi of Mi and P in Line 5 is found by computing the remainder
R = r1t + r0 of the polynomial division of P by Mi and setting hi = −r−1
1 r0. This
is justified in the proof of Lemma 6.
• The proof of Theorem 3 shows that the polynomial division of P by (t −hi) is
possible without remainder. Moreover, the quotient satisfies all requirements of
Theorem 3 so that it is suitable as input for yet another repeat-loop.
6
Algorithm 1 Compute factorization P = (t −h1) . . . (t −hn)
Require: generic motion polynomial P
1: M ←{M1, . . . , Mn} where PP = M1 · · · Mn.
2: Let H denote the empty tuple.
3: repeat
4:
Choose Mi ∈M and set M ←M \ {Mi}.
5:
Compute hi such that Mi(hi) = P(hi) = 0.
6:
Append hi to H.
7:
P ←P/(t −hi)
8: until deg P = 0
9: return H = (h1, . . . , hn)
Maple source code for Algorithm 1 can be found on the web-site http://geometrie.
uibk.ac.at/schroecker/qf/. The non-deterministic nature of Algorithm 1 implies
existence of different factorizations into products of rotation quaternions.
Theorem 8. Let P ∈DH[t] be a generic motion polynomial of degree n > 0. Then there
is a one-to-one correspondence between factorizations P(t) = (t −h1) · · · (t −hn) into
linear polynomials over DH and permutations of the n distinct quadratic irreducible factors
M1, . . . , Mn of PP. In any of these factorizations we have Mi(hi) = 0 for i = 1, . . . , n.
Proof. Our proof of Theorem 3 can be translated into a construction of a factorization
of P into linear factors over DH. The only non-deterministic step is the choice of a
quadratic factor of P ′P ′, where P ′ is the left factor from which the next right linear
factor is going to be constructed. The construction is also complete in the sense that
every factorization can be obtained by this non-deterministic algorithm.
Example 1. We give an example that illustrates some of the results we obtained so far.
Consider the quadratic polynomial
P = t2 −t(1 + (ϵ −1)i + (1 −ϵ)j + 2(1 + ϵ)k) −1 −2ϵ + i −ϵj + (2 −ϵ)k.
We can write PP = M1M2 where
M1 = t2 + 2
and
M2 = t2 −2t + 3.
In order to find the common root h2 of P and M1, we compute the remainder of the
polynomial division of P by M1. It is R = r1t + r0 where
r1 = −1 + (1 −ϵ)i + (ϵ −1)j −2(1 + ϵ)k,
r0 = −3 −2ϵ + i −ϵj + (2 −ϵ)k.
Now
h2 = −r−1
1 r0 =
−4
7 + 30
49ϵ

i −
1
7 + 3
49ϵ

j +
9
7 + 13
49ϵ

k
and, by polynomial division, we find P = (t −h1)(t −h2) with
h1 = 1 +
−3
7 + 19
49ϵ

i +
8
7 + −46
49 ϵ

j +
5
7 + 85
49ϵ

k.
7
Note that P(h2) = M1(h2) = 0.
Using M2 instead of M1, we can compute a second factorization P = (t −h′
1)(t −h′
2)
where
h′
1 = (1 −ϵ)j + (1 + ϵ)k,
h′
2 = 1 −(1 −ϵ)i + (1 + ϵ)k.
Here, P(h′
2) = M2(h′
2) = 0.
We already showed how to compute the rotation quaternion hi from the factor Mi. But
it is also possible to compute Mi from hi. Clearly, Mi is the unique monic polynomial
of degree two such that Mi(hi) = 0 (the minimal polynomial of hi). It is given by
Mi = t2−(hi+hi)t+hihi. This observation is important, because it allows us to construct
completely rational examples. Setting P = (t −h1) · · · (t −hn) with h1, . . . , hn ∈DH we
can directly compute the minimal polynomials M1, . . . , Mn and also the factorization in
Line 1 of Algorithm 1. The polynomials in our examples were actually obtained in this
way.
3.3 Kinematic interpretation
Now we are going to translate Theorem 3 into the language of kinematics. A precise
formulation takes into account the possibility of neighboring factors t −hi and t −hi+1
that describe rotations about the same axis. In this case, we call hi and hi+1 compatible.
This is the case if and only if hihi+1 = hi+1hi.
Let h ∈DH be a dual quaternion representing a rotation.
The parametrization
(t −h)t∈P1 of the rotation group defined by h is called a linear parametrization. More
generally, let R1, R2 ∈R[t] such that R1 is monic, deg(R1) = n, deg(R2) < n, without
common factor. Then the parametrization (R1(t) −h1R2(t))t∈P1 is called a rational
parametrization of degree n. Higher degree parametrizations of rotation groups may
arise as the product of linear parametrizations, if the two axes coincide, that is, if the
rotation quaternions are compatible.
A rational curve C ⊂S of degree n in the Study quadric admits a parametrization by
a motion polynomial P of degree n. We say that C is a generic rational curve of degree
n in the Study quadric if P is generic (its norm polynomial has n distinct irreducible
quadratic factors). It is straightforward to show that this notion of genericity of C is
well-defined, i.e., it does not depend on the choice of the motion polynomial P.
Corollary 9. Let C ⊂S be a generic rational curve of degree n in the Study quadric,
passing through 1. Then C can be obtained as movement of the last link of an open
kR-linkage, with k ≤n. The rotations in the k joints have a simultaneous rational
parametrization, and the sum of the degree of these parametrizations equals n.
Proof. Let P ∈DH[t] be a motion polynomial of degree n that parametrizes C. The
primal part of P cannot have real factors because C is generic. By Theorem 3, there exists
a factorization P = (t −h1) · · · (t −hn) with rotation quaternions h1, . . . , hn. Assume
that hi, . . . , hi+m−1 are compatible. Because every dual quaternion compatible with hi is
a real linear combination of 1 and hi, the product (t −hi) · · · (t −hi+m−1) can be written
8
as R1 −hiR2 for R1, R2 ∈R[t] such that R1 is monic, deg(R1) = m, deg(R2) < m. This
already implies the corollary’s statement.
Remark 10. It is sometimes advantageous to think of the open kR-chain referred to in
Corollary 9 as an open nR-chain with the possibility of coinciding consecutive axes. See,
for example, Theorem 11, below.
Example 2. We give a kinematic interpretation of the calculation in Example 1. The
two factorizations
P = (t −h1)(t −h2) = (t −h′
1)(t −h′
2)
show that the motion parametrized by P occurs as end-effector motion of two open
2R-chains, parametrized with the same rational parameter t. The axes of the rotation
quaternions h2, h1, k1, k2 in the moving frame form a closed 4R-chain whose coupler
motion is parametrized by P. Hence, we actually presented a method to synthesize a
Bennett mechanism to three given poses. Without loss of generality, we assume that
one of the poses is the identity. From this data, it is easy to compute the quadratic
parametrization of the Bennett motion as in [4]. It serves as input for our factorization
algorithm. Note that in general a cubic algebraic number needs to be introduced for the
factorization of the real quartic polynomial PP. This has also been observed in other
synthesis algorithms for Bennett linkages.
4 Interchanging factors and closed linkages
In this chapter, we investigate the linkage formed by combining the n! open nR-chains
that can be used to generate a generic rational curve C of degree n on the Study quadric.
In order to describe the combinatorial structure of a linkage, we recall the definition of
the link graph. Recall that the rigid parts of a linkage are called links, and the existence
of a rotational joint between two links means that the two links share a fixed line, the
rotation axis. It is possible that m > 2 links share the same rotation axis. In this case,
we have
�m
2
 different joints supported at this axis. The link graph consists of a node for
each link and an edge for each joint connecting two links. This should not be confused
with the axis graph, which is also used in the literature. There, the nodes correspond to
the axes of joints and the edges correspond to links.
If the linkage moves rationally with mobility one, for every link there exists an algebraic
function from P1 to P7, mapping a time parameter t ∈P1 to the pose of the link at time
t. The pose can be represented by an element of SE3 or, equivalently, by a point on the
Study quadric. If two links L1 and L2 are connected by a joint J, the relative motion
of L2 with respect to L1 is parametrized by the quotient ψJ := φ1φ−1
2
of the two pose
functions. This motion is a rotation. Hence it also has parametrization by a motion
polynomial of degree one. The linkage we construct will have the property that ψJ is a
linear polynomial (t −hJ).
Note that when hJ is specified for all joints J, the relative motions of any pair of links
can be obtained by multiplication; the linkage kinematics is fully determined. It is easy
9
to extract the Denavit-Hartenberg parameters from the rotation quaternions hJ. In this
paper we are content with the linkage specification by dual quaternions.
Theorem 11. Let C ⊂S be a generic rational curve of degree n in the Study quadric,
passing through 1. Then C is contained in the motion of a link in a mechanism with
revolute joints, 2n links and n2n−1 joints. The link graph is the 1-skeleton of the n-
dimensional hypercube.
Remark 12. In Theorem 11 we can only state that C is contained in the motion of one
link. It cannot be excluded that the mechanism has more than one degree of freedom.
An extreme case arises from the product P = (t −h1) · · · (t −hn) of compatible rotation
quaternions h1, . . . , hn. With the understanding of Remark 10, the corresponding link
graph can still be considered as 1-skeleton of a hypercube but the linkage has n trivial
degrees of freedom. A sufficient condition that ensures equality of C and the link motion
is that every 4-cycle in the link graph corresponds to a non-degenerate Bennett linkage.
Proof of Theorem 11. Let P(t) be a generic motion polynomial of degree n, parametrizing
C. We denote the n irreducible quadratic factors of PP by M1, . . . , Mn and construct
a linkage whose nodes are labelled by the subsets of G := {1, . . . , n}. Two nodes are
connected by an edge if and only if the corresponding subsets differ by exactly one
element (Figure 1). This graph is known as Hamming graph.
Let F ⊆G be a subset of cardinality m ≤n. By successively dividing out right factors
(t −hi) with Mi = (t −hi)(t −hi) ∈F, we obtain a factorization P = UV with monic
U, V ∈DH[t], and V V is the product of the factors in F. This can be done in m! ways.
We claim that the result is always the same. To show this, we assume that we have two
factorizations P = U1V1 = U2V2 corresponding to two different permutations σ1, σ2 of
M1, . . . , Mn. In our situation, the first m elements in σ1 are a permutation of the first
m elements in σ2, in fact this is the set F, and we assume that the remaining elements
are equal. This is possible because we are free to choose any order in the remaining
factors in G \ F. Now we apply our non-deterministic algorithm of dividing out right
factors to P, in the reverse order of the permutations. We obtain the two factorizations
P = V1U1 = V2U2. But in these two division processes, the first n −m choices are equal,
and it follows that U1 = U2. Consequently, we get U1 = U2 and V1 = V2. Hence F
determines the right factor V (and also the left factor U) uniquely, and we place the link
LF at position V (t), depending on one real parameter t but not on an ordering of F.
This already proves the claim on the linkage graph.
Now we show that linkage consists of revolute joints only. Assume that F1 and F2 differ
by a single element Mi. Without loss of generality we may assume F2 = F1 ∪{Mi}. Let
P = U1V1 = U2V2 be the factorizations obtained as above. Then we have V2 = (t −hi)V1,
where hi is unique common solution of U1 and Mi (see Lemma 6). Hence the relative
position of LF2 with respect to LF1, depending on t, is a rotation group parametrized by
(t −hi)t∈P1. So we see that LF2 is connected with LF1 by a rotational joint.
The two links whose relative movement is the curve C are easy to determine: They
are labelled by the empty set and by G.
10
{}
{1}
{2}
{3}
{1, 2}
{1, 3}
{2, 3}
{1, 2, 3}
h4,1 = h6,1
h2,1 = h5,1
h1,1 = h3,1
h1,2
h2,2
h3,2
h4,2
h5,2
h6,2
h1,3 = h2,3
h3,3 = h4,3
h6,3 = h5,3
Figure 1: Linkage graph obtained by factorizing a cubic curve
Example 3. We present the construction of a linkage to the graph of Figure 1. A
parametrization of a rational cubic curve C ⊂S reads
P = t3 −t2(3 + (4 −ϵ)i + (1 + 3ϵ)j + 2(1 + ϵ)k)−
t(3(1 + ϵ) −3(3 −ϵ)i −(1 + 11ϵ)j −(3 + 5ϵ)k)+
2(3 −(1 −3ϵ)i −(1 + 2ϵ)j −(1 + ϵ)k).
The real polynomial PP factors as
PP = (t2 −2t + 2
|
{z
}
=:M1
)(t2 −2t + 4
|
{z
}
=:M2
)(t2 −2t + 6
|
{z
}
=:M3
).
The polynomial P admits six factorizations P = (t −hl,1)(t −hl,2)(t −hl,3), one for each
permutation of the triple (M1, M2, M3):
(M1, M2, M3):
h1,1 = 1 + (65
31 −814
961ϵ)i + (16
31 + 1373
961 ϵ)j + (18
31 + 1719
961 ϵ)k
h1,2 = 1 + (395
403 −94035
162409ϵ)i + (319
403 + 53380
162409ϵ)j + ( 41995
162409ϵ + 479
403)k
h1,3 = 1 + (12
13 + 72
169ϵ)i + (210
169ϵ −4
13)j + ( 3
13 −
8
169ϵ)k
(M1, M2, M3):
h1,1 = 1 + (65
31 −814
961ϵ)i + (16
31 + 1373
961 ϵ)j + (18
31 + 1719
961 ϵ)k
h1,2 = 1 + (395
403 −94035
162409ϵ)i + (319
403 + 53380
162409ϵ)j + ( 41995
162409ϵ + 479
403)k
h1,3 = 1 + (12
13 + 72
169ϵ)i + (210
169ϵ −4
13)j + ( 3
13 −
8
169ϵ)k
(M1, M3, M2):
h2,1 = 1 + (5
3 −5
9ϵ)i + (1
3 + 11
9 ϵ)j + (14
9 ϵ + 1
3)k
h2,2 = 1 + (55
39 −1324
1521ϵ)i + (38
39 + 814
1521ϵ)j + ( 748
1521ϵ + 56
39)k
11
h2,3 = 1 + (12
13 + 72
169ϵ)i + (210
169ϵ −4
13)j + ( 3
13 −
8
169ϵ)k
(M2, M1, M3):
h3,1 = 1 + (65
31 −814
961ϵ)i + (16
31 + 1373
961 ϵ)j + (1719
961 ϵ + 18
31)k
h3,2 = 1 + ( 72
217 −16813
47089ϵ)i + (136
217 −7695
47089ϵ)j + (14752
47089ϵ + 153
217)k
h3,3 = 1 + (11
7 + 10
49ϵ)i −(1
7 −85
49ϵ)j + (5
7 −5
49ϵ)k
(M2, M3, M1):
h4,1 = 1 + i + ϵj + ϵk
h4,2 = 1 + (10
7 −59
49ϵ)i + (8
7 + 13
49ϵ)j + (54
49ϵ + 9
7)k
h4,3 = 1 + (11
7 + 10
49ϵ)i −(1
7 −85
49ϵ)j + (5
7 −5
49ϵ)k
(M3, M1, M2):
h5,1 = 1 + (5
3 −5
9ϵ)i + (1
3 + 11
9 ϵ)j + (14
9 ϵ + 1
3)k
h5,2 = 1 + (1
3 −4
9ϵ)i + (2
3 −2
9ϵ)j + (2
3 + 4
9ϵ)k
h5,3 = 1 + 2i + 2ϵj + k
(M3, M2, M1):
h6,1 = 1 + i + ϵj + ϵk
h6,2 = 1 + (1 −ϵ)i + j + (1 + ϵ)k
h6,3 = 1 + 2i + 2ϵj + k
The rotation quaternions hl,i correspond to edges of the linkage graph in Figure 1. The
six rotation quaternions hl,2 are all different. The six rotation quaternions hl,1 come in
three pairs, corresponding to permutations of the shape (Mi, Mj, Mk) and (Mj, Mi, Mk).
Similarly, equal rotation quaternions hl,3 come from permutations (Mi, Mj, Mk) and
(Mi, Mk, Mj), respectively.
Remark 13. There exist cases where two consecutive rotation quaternions, like h6,1 and
h6,2 in the above example, are compatible. In this case, the linkage graph of Figure 1 is
still correct but with the understanding that the revolute axes to h6,1 and h6,2 coincide
(compare Remark 10). It is possible to reflect this in the linkage graph by removing
the edge labeled h6,2 and inserting an additional edge connecting {} and {1, 2}. The
relative motion between the the links {} and {1, 2} is then the product of two linearly
parametrized rotations about the same axis, that is, a quadratically parametrized rotation.
From the description of the linkage graph given in Theorem 11 we can draw even more
conclusions:
• Every 4-cycle in the mechanism corresponds to a Bennett linkage (general case), to
a planar or spherical 4-bar linkage with a rational coupler curve, or to four joints
sharing a common revolute axis.
• Any of the n! paths of length n that connects the base {} with the platform
{1, . . . , n} corresponds to an open nR-chain. Just as any two permutations can
be transformed into each other by transpositions, any two of these nR-chains are
connected by a series of Bennett substitutions, where two consecutive revolute axes
Hl,i, Hl,i+1 are replaced by two axes Hm,i, Hm,i+1 that complete the first axis pair
to the axis quadruple of a Bennett mechanism.
• The mechanism’s theoretical degree of freedom, computed according to the formula
of Chebychev-Grübler-Kutzbach, is fn = 6(2n −1) −5n2n−1. Thus, f2 = −2,
f3 = −18, f4 = −70, f5 = −214 etc. with rapid decrease as n goes to ∞.
12
B0
B1
B2
P0
P1
P2
Figure 2: Planar overconstrained linkage
• Our construction stays within the planar motion group SE(2) or the spherical
motion group SO(3). That is, if the polynomial P describes a planar or spherical
motion, all rotation quaternions obtained from different factorizations of P belong
to the same group. Thus, we can construct planar or spherical linkages with
the same combinatorics as in the spatial case but with a theoretical degree of
freedom of gn = 3(2n −1) −n2n, that is g2 = 1, g3 = −3, g4 = −19, g5 = −67
etc. One example is depicted in Figure 2. It can be thought of as a linkage
which is composed of two planar 3RRR-platforms with identical anchor points
on the base (B0, B1, B2) and on the platform (P0, P1, P2). In addition, there
exists a hexagon formed by the middle revolute joints, whose side lengths remain
constant during the motion. In Figure 2, the hexagon sides are drawn as double
lines.
An animation of this linkage can be found on the accompanying web-
site http://geometrie.uibk.ac.at/schroecker/qf/. Its theoretical degree of
freedom is −3.
5 Translation quaternions and prismatic joints
Theorem 11 admits a small but interesting generalization that allows for a mixture of
translational and rotational joints. In fact, the factorization Algorithm 1 also works
under slightly more general assumptions: We can allow that the norm polynomial PP has
a factorization into n distinct monic quadratic polynomials M1, . . . , Mn, each of which
is either irreducible or the square of a linear polynomial. In this case, the assumptions
of Lemma 6 are fulfilled and we again get n! factorizations of P into linear motion
polynomials.
If M is a square factor of the norm polynomial PP, the factor (t −h) satisfying
M = (t −h)(t −h) parametrizes a translational one-parameter subgroup. The primal
part of h is a scalar, say λ, and M = (t −λ)2; the dual part of H is purely vectorial and
specifies the direction of the translation.
13
If the motion polynomial P has a factorization PP ∈R[t] as P = (t −h1) · · · (t −hn)
such that the minimal polynomials M1, . . . , Mn of h1, . . . , hn are all distinct, we can find
this factorization by Algorithm 1, regardless whether h1, . . . , hn represent rotations or
translations. As in the purely rotational case, there will be exactly n! such factorizations.
If the factorization P = (t −h1) · · · (t −hn) contains a translation polynomial hi with
primal part pi, the point P(pi) lies in the exceptional three-space E. Conversely, if the
curve C intersects E and admits a factorized parametrization P = (t −h1) · · · (t −hn)
with rotation or translation polynomials h1, . . . , hn, primal(P) must vanish for some
parameter value p. This implies that one of the factors (p −h1), . . . , (p −hn) has zero
primal part, that is, primal(hi) = p ∈R and hi is a translation polynomial.
We illustrate this at hand of two examples.
Example 4. Assume that P(t) = (t −h1) · · · (t −hn) and all quaternions h1, . . . , hn are
translation quaternions. This means, that the motion is a pure translation which can
be described by the sum of vectors s(t) = (u1 + tv1) + · · · + (un + tvn) with ui, vi ∈R3.
But s(t) also equals the sum of any permutation of the summands ui + tvi. This trivial
statement is a special case of Theorem 8.
Example 5. The polynomial
P = t2 −t(2 + (1 −ϵ)i + (1 + ϵ)j + (1 + 2ϵ)k) + 1 −2ϵ + (1 −ϵ)i + (1 + 2ϵ)j + (1 + ϵ)k
admits the factorizations P = (t −h1)(t −h2) = (t −k1)(t −k2) where
h1 = 1 + 1
3((3 −7ϵ)i + (3 + 2ϵ)j + (3 + 5ϵ)k),
h2 = 1 + ϵ
3(4i + j + k)
k1 = 1 + ϵj + ϵk,
k2 = 1 + (1 −ϵ)i + j + (1 + ϵ)k.
Both, k1 and h2 are translation quaternions. Indeed, P(1) = ϵ(−2 + j + k) ∈E, that is,
the curve C with parametrization P intersects the exceptional three-space E.
The kinematic interpretation of Example 5 is well-known. The motion C is the coupler
motion of an RPRP linkage [14] and can be obtained as the limiting case of the Bennett
motion The observations made in Example 5 immediately generalize to higher degree
polynomials.
6 New overconstrained 6R-chains
For n = 3, the mechanism described in the preceding section contains a number of
overconstrained 6R-chains, some of which are new. This is also true for certain examples
in case of n = 4. Although only a side result, the discovery of new overconstrained
6R-chains is an important contribution of this article. Therefore we present a more
detailed discussion.
14
(a)
F
G
(b)
F
G
(c)
F
G
Figure 3: Different types of closed 6R-chains: Bennett linkage plus dangling link (trivial)
(a), Waldron’s double Bennett hybrid (b), and new (c)
6.1 Coupler curves of degree three
Here, we assume n = 3. The link graph is the 1-skeleton of a three-dimensional cube.
The relative motion between the link labeled by the empty set F = {} (the base) and
the link labeled G = {1, 2, 3} (the platform) is a rational cubic curve C ⊂S in the Study
quadric. In general, there is nothing special about links F and G. We could as well take
any two links which are diagonally opposite in the cube.
Every path of length three that connects F and G corresponds to an open 3R-chain
which is capable of performing the motion C. Combining two of these paths yields
an overconstrained 6R-chain with coupler motion C. There is a total of six paths of
lengths three connecting F and G and a total of 15 possible combinations of two such
paths. They can be classified into three types of different combinatorics (Figure 3) or,
equivalently, into different types of pairs of permutations. We say that two permutations
σ1 and σ2 differ by σ2 ◦σ−1
1 .
• The first type (a) corresponds to permutations which differ by a neighbor transpo-
sition. The resulting 6R-chain is trivial. It consists of a Bennett linkage plus one
dangling link. The complete mechanism contains six sub-linkages of this type.
• The second type (b) corresponds to permutations that differ by a cyclic permutation.
The resulting 6R-chain is Waldron’s double Bennett hybrid [15, pp. 63–65]. There
are six sub-linkages of this type.
• The third type (c) is new.
It corresponds to permutations that differ by the
permutation (3, 2, 1). Three of the 15 6R-chains are of this type.
Currently, overconstrained 6R-chain are classified by relations between their Denavit-
Hartenberg parameters (distance, angle, and offset) on the cyclic sequence of revolute
axes, see for example the list at the end of [16]. The reasons for their mobility are of
geometric nature. Often, they are inferred from the mobility of related structures that are
already known to be flexible. Our newly found examples are mobile for algebraic reasons
or, more precisely, our construction and proof of mobility is algebraic. Therefore, we do
not offer simple relations between their Denavit-Hartenberg parameters. However, it is
possible to compute exact symbolic expressions of these parameters for numeric examples.
15
Below we list the angles, distances and offsets for the three new overconstrained 6R-chains
obtained from Example 3.
Linkage h1,3, h1,2, h1,1, h6,1, h6,2, h6,3
Distances: 16
√
29
377 ,
√
1115179082
63302
, 37
√
854
1586 , 24
√
145
899
,
√
2
2 ,
√
6
6
Offsets:
7945
59218, 38174
√
3
62281 , 545
√
5
3538 ,
7
58, 2
√
3
3 , 11
√
5
58
Angle cosines: 27
√
5
65 , 29
√
3
93 , 41
√
15
195 , 13
√
5
31 ,
√
3
3 ,
√
15
5
Linkage h2,3, h2,2, h2,1, h4,1, h4,2, h4,3
Distances:
√
1115179082
185822
, 8
√
29
87 , 37
√
854
1586 ,
√
2
6 , 12
√
145
203
,
√
6
6
Offsets:
7945
59218, 1765
√
5
3538 , 16
√
3
61 ,
7
58, 31
√
5
58 , 968
√
3
3063
Angle cosines: 151
√
3
273 , 4
√
5
15 , 41
√
15
195 , 5
√
3
9 , 2
√
5
7 ,
√
15
5
Linkage h3,3, h3,2, h3,1, h5,1, h5,2, h5,3
Distances:
√
6
42 ,
√
1115179082
63302
, 12
√
145
203
, 37
√
854
11346 ,
√
2
2 , 8
√
29
87
Offsets: 968
√
3
3063 , 53315
59218, 545
√
5
3538 , 16
√
3
61 , 53
58, 11
√
5
58
Angle cosines: 9
√
15
35 , 29
√
3
93 , 2
√
5
7 , 359
√
15
1395 ,
√
3
3 , 4
√
5
15
6.2 Coupler curves of degree four
Now we consider a second construction of new overconstrained 6R-chains whose coupler
curve is of degree four (n = 4). Let h1, h2, h3, h4 be dual quaternions representing
rotations. Set P = (t −h1)(t −h2)(t −h3)(h −h4) and Mi := (t −hi)(t −hi) for
i = 1, 2, 3, 4. The link graph of the linkage constructed in Theorem 11 has 16 links and
32 joints. Any open chain connecting base and platform has four links, any closed chain
composed of two open chains of this type has eight links. In order to get a 6R-chain,
we assume that (h1, h2) and (h3, h4) are compatible pairs. Now we use Algorithm 1 to
compute another factorization P = (t −g1)(t −g2)(t −g3)(t −g4). This gives rise to an
8R-linkage. But we can remove the link between h1 and h2 and the link between h3 and
h4 in order to get a 6R-linkage. In contrast to the previous examples, the relative motion
of some neighbouring links is rational of degree two.
The second factorization depends on the chosen permutation of the factors Mi, i =
1, . . . , 4. Of course, using the permutation (M1, M2, M3, M4) is prohibited. Because of
compatibility relations, we also have
P = (t −h2)(t −h1)(t −h3)(t −h4) = (t −h1)(t −h2)(t −h4)(t −h3).
Hence, we must avoid common right or left factors with these two factorizations as they
lead to dangling links. In total, there are 16 permutations of this type, because they
start with M1 or M2, or end with M3 or M4, or both.
16
A possible choice of a permutation is (M3, M1, M4, M2). The resulting linkage is known
as “serial Goldberg 6R linkage” (see [15, 4.3.1]). There are four permutations that lead
to this type of linkage.
Another possible choice is (M3, M4, M1, M2). The resulting linkage is of a new type
and, again, can be obtained from four different permutations. There are some apparent
relations between the Denavit-Hartenberg parameters, which can be explained by the fact
that the axes of three joints of the 6R-linkage are axes of a 4-cycle of the full “hypercube”
linkage. But these relations are not sufficient for the mobility.
7 Conclusion
Factorization of motion polynomials is a new and powerful method for synthesizing
linkages with a prescribed rational coupler motion. We gave an explicit construction,
based on dual quaternion factorization, for such linkages.
It allows to incorporate
translation quaternions (prismatic joints) and compatible quaternions (high degree
relative rotations of neighboring links).
We studied the resulting linkages and explained how to obtain new types of closed
6R-chains from them. We provided ideas for their construction, but the method leaves
room for creativity which may lead to more new types. For example, it is possible
to construct overconstrained chains with 2k prismatic and 6 −2k revolute joints by
combining the ideas of Sections 5 and 6. Coinciding consecutive joints will produce
overconstrained chains consisting of five joints (Goldberg linkages).
An important new insight is that flexibility of overconstrained 6R-chains has rather
algebraic than geometric reasons. Currently, the authors work on a systematic description
and computational tools for synthesizing linkages based on this new method.
Acknowledgements
This research was supported by the Austrian Science Fund (FWF): I 408-N13 and
DK W 1214-N15.
References
[1] G. T. Bennett, A New Mechanism, Engineering 76 (1903) 777–778.
[2] G. T. Bennett, The skew isogramm-mechanism, Proc. London Math. Soc. 13 (2nd
Series) (1913–1914) 151–173.
[3] O. Bottema, B. Roth, Theoretical Kinematics, Dover Publications, 1990.
[4] K. Brunnthaler, H.-P. Schröcker, M. Husty, A New Method for the Synthesis of
Bennett Mechanisms, in: Proceedings of CK 2005, International Workshop on
Computational Kinematics, Cassino, 2005.
17
[5] J. Krames, Zur Geometrie des Bennett’schen Mechanismus, Österreich. Akad. Wiss.
Math.-Natur. Kl. S.-B. II 146 (1937) 159–173.
[6] A. J. Perez, J. M. McCarthy, Bennett’s linkage and the cylindroid, Mech. Machine
Theory 37 (11) (2002) 1241–1445.
[7] K. Hao, Dual number method, rank of a screw system and generation of Lie sub-
algebras, Mech. Mach. Theory 33 (7) (1998) 1063–1084.
[8] J. Selig, Geometric Fundamentals of Robotics, Monographs in Computer Science,
Springer, 2 edn., 2005.
[9] I. Niven, Equations in quaternions, Amer. Math. Monthly 48 (10) (1941) 654–661.
[10] B. Gordon, T. S. Motzkin, On the zeros of polynomials over division rings, Trans.
Amer. Math. Soc. 116 (1965) 218–226.
[11] L. Huang, W. So, Quadratic formulas for quaternions, Appl. Math. Lett. 15 (5)
(2002) 533–540.
[12] M. Hamann, Line-symmetric motions with respect to reguli, Mech. Mach. Theory
46 (7) (2011) 960–974.
[13] G. Hegedűs, J. Schicho, H.-P. Schröcker, Construction of Overconstrained Linkages
by Factorization of Rational Motions, Accepted for publication in the proceedings
of ARK, 2012.
[14] A. Perez-Gracia, Synthesis of Spatial RPRP Closed Linkages for a Given Screw
System, ASME J. Mechanisms and Robotics 3 (2).
[15] P. Dietmaier, Einfach übergeschlossene Mechanismen mit Drehgelenken, Habilitation
thesis, Graz University of Technology, 1995.
[16] J. E. Baker, Screw replacements in isomeric variants of Bricard’s line-symmetric
six-bar, Proc. Inst. Mech. Eng., Part C: J. Mech. Eng. Science 223 (2009) 2391–2398.
18