1 S INGULAR C URVES IN THE J OINT S PACE AND C USP P OINTS OF 3-RPR PARALLEL MANIPULATORS Mazen ZEIN, Philippe Wenger and Damien Chablat Institut de Recherche en Communications et Cybernétique de Nantes UMR CNRS 6597 1, rue de la Noë, BP 92101, 44312 Nantes Cedex 03 France E-mail address: Mazen.Zein@irccyn.ec-nantes.fr Phone: 0033240376955 Fax: 0033240376930 Abstract This paper investigates the singular curves in the joint space of a family of planar parallel manipulators. It focuses on special points, referred to as cusp points, which may appear on these curves. Cusp points play an important role in the kinematic behavior of parallel manipulators since they make possible a nonsingular change of assembly mode. The purpose of this study is twofold. First, it exposes a method to compute joint space singular curves of 3-RPR planar parallel manipulators. Second, it presents an algorithm for detecting and computing all cusp points in the joint space of these same manipulators. 1. Introduction Because at a singularity a parallel manipulator loses its stiffness, it is of primary importance to be able to characterize these special configurations. This is, however, a very challenging task for a general parallel manipulator 1 . Planar parallel manipulators have received a lot of attention 1-8 because of their relative simplicity with respect to their spatial counterparts. Moreover, studying the former may help understand the latter. Planar manipulators with three extensible leg rods, referred to as 3- RPR manipulators, have often been studied. Such manipulators may have up to six assembly modes 7 . The direct kinematics can be written in a polynomial of degree six 3 . Moreover, as is the case in most parallel manipulators, the singularities coincide with the set of configurations where two direct kinematic solutions coincide. It was first pointed out that to move from one assembly 2 mode to another, the manipulator should cross a singularity 7 . However, Innocenti 8 showed, using numerical experiments, that this statement is not true in general. More precisely, this statement is only true under some special geometric conditions, such as similar base and mobile platforms 9,10 . In fact, an analogous phenomenon exists in serial manipulators that can change their posture (inverse kinematic solution) without meeting a singularity in general, but not under special geometric simplifications 8,11-13 . The nonsingular change of posture in serial manipulators was shown to be associated with the existence of points in the workspace where three inverse kinematic solutions meet, called cusp points 13 . Cusp points in serial manipulators were determined by looking for the triple roots of the inverse kinematics polynomial 13 or from the equation of the workspace boundary 14 . Likewise, McAree 9 pointed out that for a 3 -RPR parallel manipulator (as well as for its spatial counterpart, the octahedral manipulator), if a point with triple direct kinematic solutions exists in the joint space, then the nonsingular change of assembly mode is possible. A condition for three direct kinematic solutions to coincide was established. However, no systematic exploitation of this condition was possible because the algebra involved was too complicated and to the authors’ knowledge, the work of McAree 9 has never been pursued yet. Wenger 15 showed that to accomplish a non-singular assembly-mode changing motion, a 3-RPR manipulator platform should encircle a cusp point in its joint space. Thus, determination of cusp points is of interest for planning trajectories. A procedure for computing joint space singularities of 3-RPR parallel manipulators was established in a previous paper 16 , where the cusp points were shown on the joint space singularities of these manipulators but no solution was proposed for computing these cusp points. In this paper, the abovementioned condition for computing cusp points is reviewed and exploited. An algorithm for the systematic detection of cusp points is developed. The method 16 for computing and representing joint space singularities of 3- RPR planar parallel manipulators is first recalled. A descriptive analysis of the singular curves in slices of the joint space of 3- RPR parallel manipulators is conducted. It is shown that the number of cusp points depends on the slice of the 3 joint space in which these cusp points are determined. Moreover, the maximum number of cusp points depends on the geometry of the manipulator. This work helps better understand the topology of the joint space of parallel manipulators and finds applications in both design and trajectory planning. The following section introduces the 3 -RPR manipulator and its constraint equations. Section 3 is devoted to the determination of the singular curves in slices of the joint space. The existence condition of cusp points is derived in section 4 and an algorithm to determine these points automatically is provided. Section 6 is devoted to a descriptive analysis of singular curves in slices of the joint space. 2. Preliminaries 2.1 Manipulators under study The manipulators under study are 3-DOF planar parallel manipulators with three extensible leg rods (Fig. 1). These manipulators have been frequently studied 4-8 . Each of the three extensible leg rods is actuated with a prismatic joint. The geometric parameters of the manipulators are the three sides of the moving platform d 1 , d 2 , d 3 and the position of the base revolute joint centers defined by A 1 , A 2 and A 3 . The reference frame is centered at A 1 and the x -axis passes through A 2 . Thus, A 1 = (0, 0), A 2 = ( A 2 x , 0) and A 3 = ( A 3 x , A 3 y ). x A 1 A 2 B 2 B 3 B 1 θ ρ 1 ρ 2 θ 2 d 1 d 3 d 2 θ 1 y A 3 ρ 3 θ 3 α β h Fig 1. The 3-RPR parallel manipulator under study. 4 2.2 Constraint equations Let L ≡ ( ρ 1 , ρ 2 , ρ 3 ) define the lengths of the three leg rods and let θ ≡ ( θ 1 , θ 2 , θ 3 ) define the three angles between the leg rods and the x -axis. The six parameters ( L, θ ) can be regarded as a configuration of the manipulator but only three of them are independent, so that the configuration space is a 3-dimensional manifold embedded in a 6-dimensional space. The dependency between ( L, θ ) can be identified by writing the fixed distances between the three vertices of the mobile platform B 1 , B 2 , B 3 : [ ] [ ] [ ] [ ] [ ] [ ] 2 1 2 1 2 1 1 2 2 3 2 3 2 2 2 3 1 3 1 3 3 ( , ) ( , ) ( , ) ( , ) ( , ) 0 ( , ) ( , ) ( , ) ( , ) ( , ) 0 ( , ) ( , ) ( , ) ( , ) 0 ( , ) T T T d d d ⎧ Γ = − − − = ⎪ ⎪Γ = − − − = ⎨ ⎪ Γ = − − − = ⎪ ⎩ L θ b L θ b L θ b L θ b L θ L θ b L θ b L θ b L θ b L θ L θ b L θ b L θ b L θ b L θ (1) where b i is the vector defining the coordinates of B i in the reference frame as function of L and θ . For more simplicity, ( L, θ ) will be omitted in the following equations. Expanding each Γ i as a series about the configuration ( L, θ ) yields 2 3 3 3 3 1 1 1 1 3 3 1 1 2 .. 0 1 ... ! 1 ! i i i i i i i j j j j j j j j n i i i j j j j n θ θ θ ρ θ ρ θ θ ρ ρ ρ ρ = = = = = = ⎛ ⎞ ⎛ ⎞ ∂ ∂ ∂ ∂ ΔΓ = Δ + Δ Γ + Δ + Δ Γ ⎜ ⎟ ⎜ ⎟ ⎜ ⎟ ⎜ ⎟ ∂ ∂ ∂ ∂ ⎝ ⎠ ⎝ ⎠ ⎛ ⎞ ∂ ∂ Δ + Δ Γ + = ⎜ ⎟ ⎜ ⎟ ∂ ∂ ⎝ ⎠ + + ∑ ∑ ∑ ∑ ∑ ∑ (2) If one keeps only the first-order and second-order terms, Eq.(2) can be written in matrix form as follows: 2 2 2 1 1 1 2 2 2 2 2 2 2 2 2 2 2 2 2 3 3 3 2 2 1 1 0 2 2 T T T T T T T T T ⎡ ⎤ ∂ Γ ⎡ ⎤ ⎡ ⎤ ∂ Γ ∂ Γ Δ Δ Δ Δ Δ Δ ⎢ ⎥ ⎢ ⎥ ⎢ ⎥ ∂ ∂ ∂ ∂ ⎢ ⎥ ⎢ ⎥ ⎢ ⎥ ⎢ ⎥ ∂ ∂ ∂ Γ ∂ Γ ∂ Γ ⎢ ⎥ ⎢ ⎥ Δ = Δ + Δ + Δ Δ + Δ Δ + Δ Δ = ⎢ ⎥ ⎢ ⎥ ⎢ ⎥ ∂ ∂ ∂ ∂ ∂ ∂ ⎢ ⎥ ⎢ ⎥ ⎢ ⎥ ⎢ ⎥ ∂ Γ ∂ Γ ⎢ ⎥ ⎢ ⎥ ∂ Γ Δ Δ Δ Δ ⎢ ⎥ Δ Δ ⎢ ⎥ ⎢ ⎥ ∂ ∂ ∂ ∂ ⎣ ⎦ ⎣ ⎦ ⎢ ⎥ ⎣ ⎦ θ L θ θ L L θ L θ L Γ Γ Γ θ L θ θ θ L L L θ L θ θ L L θ θ L L θ L θ L θ L (3) Equation (3) can be used to describe an arbitrary local motion at a given configuration of the manipulator 9 . When first order terms of Eq.(3) are sufficient to describe the motion, the manipulator 5 is in a regular configuration and the following equation (4) can be used instead of Eq.(3): ( ) ( ) , , 0 ∂ ∂ Δ + Δ = ∂ ∂ Γ L θ Γ L θ θ L θ L (4) Otherwise the configuration ( L, θ ) is special and the manipulator meets a singularity. This happens when the constraint Jacobian ∂ ∂ Γ / θ drops rank so that the second order terms of equation (3) are required to describe the constraints. The three vertices of the moving platform have the following coordinates in the fixed reference frame, ( ) ( ) ( ) ( ) ( ) ( ) 1 1 1 1 1 2 2 2 2 2 2 3 3 3 3 3 3 3 cos sin ; cos sin ; cos sin . T T x T x y A A A ρ θ ρ θ ρ θ ρ θ ρ θ ρ θ = = + ⎡ ⎤ ⎡ ⎤ ⎣ ⎦ ⎣ ⎦ ⎡ ⎤ = + + ⎣ ⎦ b b b Thus, the constraint Jacobian can be put in the following form: ( ) ( ) ( ) ( ) 1 2 1 2 12 2 1 21 2 2 2 2 3 2 3 2 3 3 3 23 3 2 2 23 3 3 1 3 1 3 31 3 3 3 1 31 3 1 3 3 0 ( ) ( ) 2 0 ( ( 0 ) ) x x x x x x y y x x y y A s s s A s A A s A A s s A c s A c A s s A s s A c A c ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ⎡ ⎤ ⎢ ⎥ + − ⎢ ⎥ ⎢ ⎥ − − − ⎢ ⎥ ∂ = ⎢ ⎥ ∂ − + − + ⎢ ⎥ ⎢ ⎥ ⎢ ⎥ − − − ⎢ ⎥ − − ⎢ ⎥ ⎣ ⎦ Γ θ (5) where ( ) sin i i s θ = , ( ) cos i i c θ = and ( ) sin ij i j s θ θ = − . 3. Jointspace Singular Curves The manipulator is in a singular configuration whenever the axes of its three leg rods are concurrent or parallel 17 . 6 x A 1 A 2 B 1 θ 2 θ 1 y A 3 θ 3 B 2 B 3 d 1 d 3 d 2 α β Axis 1 Axis 3 Axis 2 ρ 2 ρ 1 ρ 3 Fig 2. A 3-RPR parallel manipulator on a singular configuration We derive the condition for the three leg axes to intersect at a common point (possibly at infinity). We first write the equations of the three leg axes: 1 1 2 2 2 3 3 3 3 3 (Axis 1) : cos( ) sin( ) (Axis 2) : cos( ) ( ) sin( ) (Axis 3) : cos( ) ( ) sin( ) cos( ) x x y y x y x A y x A A θ θ θ θ θ θ θ ⎧ = ⎪ = − ⎨ ⎪ = − + ⎩ (6) Eliminating x and y in (6) yields the following singularity equation in the task parameters ( θ 1 , θ 2 , θ 3 ): ( ) 2 2 31 3 3 3 3 12 0 x x y A s s A s A c s + − = (7) where ( ) sin i i s θ = , ( ) cos i i c θ = and ( ) sin ij i j s θ θ = − . It is possible to express Eq (7) as function of the joint space parameters ρ 1 , ρ 2 and ρ 3 by using the constraint equations of the 3-RPR manipulator. However, the resulting equation would be too complicated to yield real insights and difficult to handle. Our approach to compute the singular configurations in the joint space consists in reducing the dimension of the problem. We consider two-dimensional slices of the configuration space by fixing the first leg rod length ρ 1 . Step 1: We rewrite Eq. (7) as a function of ρ 1 , α and θ 1 using the constraint equations of the manipulator: 7 ( ) ( ) ( ) ( ) 2 2 2 1 1 1 2 2 1 1 1 3 3 3 1 1 3 3 3 3 1 1 3 c c cos 0 s s sin 0 c c cos 0 s s sin 0, x x y A d d A d A d ρ ρ α ρ ρ α ρ ρ α β ρ ρ α β + − − = ⎧ ⎪ − − = ⎪ ⎨ + − − + = ⎪ ⎪ + − − + = ⎩ (8) The first (resp. last) two equations make it possible to express ρ 2 (resp. ρ 3 ) as function of ρ 1 , α and θ 1 . Then, c 2 and s 2 (resp. c 3 and s 3 ) are calculated as function of ρ 1 , α and θ 1 from the first (resp. last) two equations of (8) and their expressions are input in Eq. (7), which, now, depend only on ρ 1 , α and θ 1 . Step 2: We fix a value for ρ 1 , so Eq. (7) depends now only on α and θ 1 . By varying α or θ 1 , we compute the roots of the equation, to obtain the singular configurations ( α s , θ 1s ) for a fixed ρ 1s . Step 3: For every singular configuration computed in the second step of the approach, we calculate the corresponding values ρ 2s and ρ 3s using equation system (9). We have thus the singular configurations curves in a slice of the joint space ( ρ 2 , ρ 3 ) for a fixed value of ρ 1 : ( ) ( ) ( ) ( ) 2 2 1 1 1 2 2 1 1 1 2 3 1 1 3 3 2 3 1 1 3 cos( ) cos( ) sin( ) sin( ) cos( ) cos( ) sin( ) sin( ) x x y A d d A d A d ρ θ α ρ ρ θ α ρ θ α β ρ ρ θ α β ⎧ − + + + ⎪ = ⎪ + ⎪ ⎨ ⎪ − − + + ⎪ = ⎪ − − + ⎩ (9) Figure 3 shows a slice of the joint space singular configurations for ρ 1 =17 obtained for the same 3 -RPR manipulator used by several authors 1,8,9 , which has the following geometric parameters: A 1 = (0, 0), A 2 = (15.91,0), A 3 = (0, 10), d 1 = 17.04, d 2 = 16.54 and d 3 = 20.84 in an arbitrary length unit. We refer only to this manipulator in this paper in order to illustrate our work. 8 Fig 3. Singular curves in ( α , θ 1 ) for ρ 1 =17. Number of assembly modes is displayed in each region Figure 3 shows the singular curves in the joint space slice ( ρ 2 , ρ 3 ) defined by ρ 1 =17. These curves give rise to several regions with 2, 4 or 6 direct kinematic solutions. The six points pinpointed with circles are cusp points, where three direct kinematic solutions coincide. 4. Determination of the Cusp Points 4.1 Existence condition of cusp points For serial 3-DOF manipulators, the cusp points can be determined by deriving the condition under which the inverse kinematics polynomial admits three identical roots 13 . However this approach is much more complicated when applied to the direct kinematics polynomial of 3 -RPR manipulators because this polynomial is of degree 6. An interesting alternative approach was proposed in McAree’s study 9 by writing the condition under which the manipulator loses first and second order constraints. The resulting condition for triple coalescence of assembly modes was shown to take the following form: 2 2 2 3 1 2 1 2 3 2 2 2 0, T u u u ⎡ ⎤ ∂ Γ ∂ Γ ∂ Γ + + = ⎢ ⎥ ∂ ∂ ∂ ⎣ ⎦ v v θ θ θ (10) where v is a unit vector in the right kernel of matrix ∂ ∂ Γ / θ , and u 1 , u 2 , u 3 are the three 9 components of the unit vector u that spans the left kernel. Vectors u and v can be chosen in the set of nonzero rows and columns of the adjoint of matrix ∂ ∂ Γ / θ (i.e. the matrix of cofactors of the transpose of ∂ ∂ Γ / θ ), respectively. Calculating the adjoint of ∂ ∂ Γ / θ from Eq. (5) yields: adj 1 2 2 5 3 5 3 4 2 6 3 6 1 4 4 5 1 6 k k k k k k k k k k k k k k k k k k − ⎛ ⎞ ∂ ⎛ ⎞ ⎜ ⎟ = ⎜ ⎟ ⎜ ⎟ ∂ ⎝ ⎠ ⎜ ⎟ − ⎝ ⎠ Γ θ (11) where ( ) ( ) ( ) ( ) ( ) 1 2 3 2 2 3 23 3 2 2 3 1 13 3 3 3 3 3 3 3 2 3 2 23 3 3 2 2 2 x x y x y x x y k A A s s A c k s A s A c k A A s s A c ρ ρ ρ ρ ρ ρ = − + − = − + − = − − + − ( ) ( ) ( ) 4 1 3 13 3 1 3 1 5 2 1 12 2 2 6 1 2 12 2 1 2 2 2 x y x x k s A s A c k s A s k s A s ρ ρ ρ ρ ρ ρ = + − = − + = + (12) Taking u (resp. v ) as the first row (resp. column) of (11), Eq. (10) can be written as ( ) 1 2 2 2 2 3 1 2 1 2 3 4 1 4 1 2 2 5 3 5 3 4 2 2 2 1 4 0 k k k k k k k k k k k k k k k k k k ⎛ ⎞ ⎛ ⎞ ∂ Γ ∂ Γ ∂ Γ ⎜ ⎟ − − + = ⎜ ⎟⎜ ⎟ ∂ ∂ ∂ ⎝ ⎠⎜ ⎟ − ⎝ ⎠ θ θ θ (13) where ( ) ( ) ( ) ( ) ( ) 2 1 2 1 2 21 1 2 21 1 1 2 21 2 2 2 1 21 2 2 2 2 3 2 2 2 3 23 2 3 23 3 2 3 2 3 3 2 3 23 2 23 3 3 1 3 1 3 31 3 1 1 3 2 3 2 0 2 0 0 0 0 0 0 0 ( ) 2 0 ( ) 0 0 2 x x x x y x x y x y A c c c c A c c A A c c c A s A A c c c A s A c c A s ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ ρ + − ⎡ ⎤ ∂ Γ ⎢ ⎥ = − − − ∂ ⎢ ⎥ ⎣ ⎦ ⎡ ⎤ ⎢ ⎥ ⎢ ⎥ − − ⎢ ⎥ ∂ Γ = − ⎢ ⎥ − − ∂ ⎢ ⎥ ⎢ ⎥ − − ⎢ ⎥ + − ⎢ ⎥ ⎣ ⎦ + + − ∂ Γ = ∂ θ θ θ ( ) 31 1 3 31 3 1 31 3 3 3 3 0 0 0 0 x y c c c A c A s ρ ρ ρ ρ ⎡ ⎤ ⎢ ⎥ ⎢ ⎥ − − − ⎢ ⎥ ⎣ ⎦ (14) In McAree’s study 9 , Eq. (13) was not expanded. McAree 9 noted that the expansion of this equation was too complicated to yield any real insight. We have developed an algorithm to solve this equation for any 3- RPR manipulator and we have 10 implemented it in Maple. This algorithm detects all the cusp points inside the joint space of any 3- RPR manipulators and computes their coordinates. We present it in next section. 4.2 Algorithm for calculating cusp points The presence of cusp points allows the 3-RPR manipulator to undertake non-singular assembly mode changing trajectories; these special trajectories can be executed by encircling a cusp point. In their study 9 , the authors stated that cusp points are pernicious and should be avoided or designed out by judicious dimensioning. The configuration of the 3-RPR manipulator is given by six parameters: the three rod lengths ( ρ 1 , ρ 2 , ρ 3 ), and the platform position variables ( θ 1 , θ 2 , θ 3 ). Only three of these parameters are independent. In order to reduce the dimension of the problem, McAree 9 shows that it is possible to consider two-dimensional slices of the configuration space by fixing one of the leg rod lengths. By doing so, the manipulator configuration can be fully defined by only two parameters. For example, for a fixed value of ρ 1 , a configuration may be fully defined by either ( α , θ 1 ) or ( ρ 2 , ρ 3 ). Note that in the first case, the configuration is defined in the output space by the position and the orientation of the moving platform ( ρ 1 and θ 1 define the position of B 1 in the plane and α defines the orientation of the moving platform in the plane). In the second case, the configuration is defined in the joint space by the lengths of the three leg rods. In our work, we have always taken ρ 1 as the fixed parameter. After fixing the value of ρ 1 , we first calculate the singularity curves in ( ρ 2 , ρ 3 ), and then we compute all the cusp points of this two- dimensional slice. 4.2.1 Algorithm If we consider equation (7), we notice that it is a function of ( θ 1 , θ 2 , θ 3 ). The existence condition of cusp points (13) is a function of ( ρ 1 , ρ 2 , ρ 3 ) and ( θ 1 , θ 2 , θ 3 ). Our first goal is to establish an equation, which is a function of ( ρ 1 , α , θ 1 ), and then to solve it to obtain the coordinates of the cusp points. Thus, we first derive a set of equations from the geometry of the manipulator: 11 ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) 2 1 1 1 2 2 3 1 1 3 3 3 1 1 1 2 2 3 1 1 3 3 3 cos cos cos cos cos s sin sin sin sin sin sin x x y A d A d co d A d ρ θ α θ ρ ρ θ α β θ ρ ρ θ α θ ρ ρ θ α β θ ρ ⎧ − + + = ⎪ ⎪ ⎪ − + + + = ⎪ ⎪ ⎨ + ⎪ = ⎪ ⎪ − + + + ⎪ = ⎪ ⎩ (15) The algorithm for detecting cusp points is implemented in MAPLE; its steps are presented below: 1. First, the expression of cos( θ 2 ), cos( θ 3 ), sin( θ 2 ) and sin( θ 3 ) in (15) are substituted into the singularity equations (7). Then, sin( α ) and cos( α ) (resp. cos( θ 1 ) and sin( θ 1 )) are written as function of tan( α /2 ) (resp. of tan( θ 1 /2 )). As a consequence we obtain an equation of the form: ( ) 1 1 1 , , 0 F t t ρ = (16) where ( ) tan t α = and ( ) 1 1 tan t θ = . 2. Then, the expression of cos( θ 2 ), cos( θ 3 ), sin( θ 2 ) and sin( θ 3 ) in (15) are substituted into equations (12) and (14). Applying then the tan-half substitution as above yields an equation of the form: ( ) 1 1 1 , , 0 E t t ρ = (17) So, we notice that the two equations (7) and (13) are written now as function of three parameters only. 3. We fix now ρ 1 , and we input the manipulator parameters d 1 , d 2 , d 3 , A 2 x , A 3 x and A 3 y . We have noticed that the direct substitution of the real values of ( ) sin β and ( ) cos β into equations (16) and (17) make the equations resolution very complicated in the following steps. Thus, 12 we write ( ) sin β and ( ) cos β as a function of an intermediate parameter h , which is the altitude of the moving triangle. 4. The Maple resultant function is used to eliminate ( ) tan t α = from the two equations (16) and (17). The resulting equation is a polynomial of degree 96 in ( ) 1 1 tan t θ = , which can be factored as follows: 3 1 1 2 1 2 3 1 ... 0 n n a a a a a n n P P P P P Q − − = (18) where Q is a 24 th -order univariate polynomial in t 1 and P 1 , P 2 ,..., P n are quadratic and quartic polynomials in t 1 . Note that the factor form could not be obtained without the intermediate parameter h . 5. We input the parameter h value. We solve equation (18). Each real root t 1i is back- substituted into (16), which is then solved for t . For every t 1i , we obtain different values for t ij . Finally, we get a number of solution couples ( t ij , t 1i ). 6. We substitute the values of each solution couple ( t ij , t 1i ) into (17), and we keep only those solutions that satisfy this equation. The solutions ( t ij , t 1i ) kept in the last step should give the coordinates of the cusp points. To verify this, we calculate the direct kinematic solutions for each solution ( t ij , t 1i ). In many instances, we have found that some solutions do not yield three coincident solutions. This means that they are not associated with cusp points. So we reject them and we keep only those solutions that give three coincident direct kinematic solutions. These couples are the coordinates of the cusp points, we call them ( α ij , θ 1i ) cusp . After running our algorithm hundreds of times, we have noticed that in each case all cusp points were determined by the 24 th -order polynomial Q of equation (18), that is, all remaining factors provided spurious solutions. Thus, we may conjecture that the cusp points are determined by Q , although we have no mathematical proof for this fact. All real roots of Q are the cusp points. 13 With this conjecture, our algorithm simplifies significantly because instead of solving (18) (a 96 th order polynomial), we just have to solve polynomial Q (a 24 th order polynomial). To implement this result in the algorithm, we must change steps 5 and 6 into the following steps 5’ and 6’, and eliminate step 7: 5'. We input the real value of parameter h . We solve the polynomial Q . We substitute every real root θ 1i of Q into equation (16), and solve it for tan( α /2 ). For every θ 1i , we obtain different values α ij . Finally, we get a number of couples ( α ij , θ 1i ). 6'. We substitute the values of each couple ( α ij , θ 1i ) into equation (17). The couples that satisfy this equation are the coordinates of the cusp points. We call them ( α ij , θ 1i ) cusp . Finally, to obtain the coordinates of the cusp points in the joint space ( ρ 1 , ρ 2 , ρ 3 ), we use the system of equations (9) computed from the geometry of the manipulator. We then obtain the cusp points in a slice of the joint space for a fixed value of ρ 1 . In step 7 of the algorithm, we have noticed that the existence condition of cusps generates solutions that do not provide triple direct kinematic solutions. This confirms the statement of McAree 9 that the cusp existence condition that he established is a sufficient condition but not a necessary one. 4.2.2 Algorithm Execution The algorithm execution time slightly depends on the value of ρ 1 and of the 3-RPR manipulator parameters. It highly depends on the number of digits required for the calculation. For 90 digits (which is necessary to guaranty a good accuracy), it is about two minutes on a computer equipped with a 3GHz-Pentium 4 with 512 Mo of Ram. We present the results of an execution of the algorithm, for the same 3-RPR parallel manipulator introduced in section 3. For the same fixed value ρ 1 =14.98, as the one used in previous papers 8,9 , the algorithm detects six cusp points instead of five identified in the paper 9 . Figure 4 shows the singular curves of the 3 -RPR manipulator for ρ 1 =14.98, and the six cusp points 14 pinpointed with circles. The sixth point missed by McAree 9 is the point A, it is circled with bold lines and in-boxed in a separate view. The zoomed view shows that it is really a cusp point. ρ 2 ρ 3 Fig 4. Singular curves and cusp points in a slice of the 3-RPR manipulator joint space ( ρ 2 ,, ρ 3 ) for ρ 1 =14.98. The coordinates of the six cusp points are given in the table 1 below α θ 1 ρ 2 ρ 3 Cusp A 50.67 deg -69.12 deg 0.84 3.77 Cusp B -2.59 deg 177.32 deg 13.85 6.26 Cusp C -122.89 deg 114.05 deg 31.27 16.17 Cusp D 57.48 deg 133.77 deg 30.44 26.61 Cusp E -0.59 deg 15.46 deg 16.02 29.56 Cusp F 170.37 deg -10.65 deg 17.98 26.44 Tab 1. Coordinates of the six cusp points for ρ 1 =14.98. 5. Descriptive Analysis In this section, the singular curves are analysed in several slices of the joint space for the manipulator studied in papers 8,9 and whose geometric parameters were given in section 3. Figure 5 depicts the singular curves for increasing values of ρ 1 and shows that the number of cusp points is not the same for all slices as we may have 0, 2, 4, 6 or 8 cusp points. In Fig. 5, regions with two assembly modes (resp. four, six) are filled in light grey (resp. in dark grey, in black). Zero-cusp slices are obtained for very small values of ρ 1 only ( ρ 1 =0.05 in Fig. 5), where the singular curves are made of two separate closed curves that define only one small region with two assembly modes and a large void (note, the two curves are so close that the region cannot be seen in Fig. 5). When ρ 1 is 15 increased, two cusp points appear, the void gets smaller and a four-solution region appears ( ρ 1 =2). Then two more cusp points appear, defining one more four-solution region ( ρ 1 =2.8). We have six cusp points and a small void at ρ 1 =6; for ρ 1 =8, 10, 12, 14, 16, 18, 20, 24 and 26, we have always six cusp points but the void is replaced with a six-solution region. Eight cusp points exist in a small vicinity of ρ 1 =27. Then two cusp points and the six-solution region disappear ( ρ 1 =29). Finally, the number of cusp points stabilizes to four, defining one central four-solution region surrounded by a two-solution region ( ρ 1 =31, ...). Interestingly, this last pattern is very similar to the one often observed in a cross-section of the workspace of 3- R serial manipulators 19 . However, serial manipulators feature the same pattern in all cross-sections (the sections which passes through the first revolute joint axis), and variation in the number of cusp points arises only from a modification of the manipulator geometry. The above analysis shows that the joint space topology of 3 -RPR manipulators is very complicated. Contrary to serial manipulators, the shape of the singular curves and the number of cusps points depend on which slice is chosen in the joint space. Thus, planning trajectories is not easy. However, we have noticed that the pattern stabilizes for sufficiently large values of ρ 1 . 16 ρ 2 ρ 2 ρ 2 ρ 2 ρ 3 ρ 3 ρ 3 ρ 3 ρ 1 = 27 ρ 1 = 29 ρ 1 = 31 ρ 1 = 26 ρ 2 ρ 2 ρ 2 ρ 1 = 16 ρ 1 = 18 ρ 1 = 20 ρ 1 = 24 ρ 2 ρ 3 ρ 3 ρ 3 ρ 3 ρ 2 ρ 1 = 8 ρ 1 = 10 ρ 2 ρ 2 ρ 1 = 12 ρ 2 ρ 3 ρ 3 ρ 3 ρ 3 ρ 1 = 14 ρ 2 ρ 1 = 0.05 ρ 2 ρ 1 = 2 ρ 2 ρ 2 ρ 1 = 6 ρ 3 ρ 3 ρ 3 ρ 3 ρ 1 = 2.8 ρ 2 ρ 1 = 34 ρ 2 ρ 1 = 50 ρ 1 = 75 ρ 2 ρ 2 ρ 3 ρ 3 ρ 3 ρ 3 ρ 1 = 100 Fig 5. Singular curve patterns for increasing values of ρ 1 . Figure 6 represents the singularities in the joint space of the manipulator studied when ρ 1 varies from 0 to 50 . To obtain this surface, we have imported the solutions obtained in step 4 into a CAD software, and we have meshed them together. 17 ρ 2 ρ 1 ρ 3 0 1 0 2 0 3 0 7 0 6 0 5 0 4 0 60 70 Fig 6. Joint space singularity surfaces of the 3 -RPR manipulator studied when ρ 1 varies from 0 to 50. The surface depicted in Figure 6 is of interest: i. for planning trajectories in the joint space because it shows clearly the joint space regions that are free of singularities. ii. for manipulator design, because it offers a tool for defining the values of the joint limits such that the joint space is a singularity-free box. We can see clearly in figure 6 how the number of cusp points and the topology of the slices stabilize for ρ 1 >31. This feature has been observed in many other manipulator geometries. For example, the 3- RPR manipulator defined by the following geometric parameters: A 1 = (0,0), A 2 = (3,0), A 3 = (1.1,2.7), d 1 = 1.3, d 2 = 0.9 and d 3 = 0.4 in an arbitrary length unit, has a constant pattern as soon as ρ 1 >5 (Fig. 7). Note that, in contrast with the stabilized pattern obtained for the preceding manipulator, this pattern features a large void. Most of the research work on parallel manipulators has focused on the analysis and optimization of the workspace. If the workspace is useful for manipulator design, the analysis of 18 singular curve patterns in the joint space can be used as a complementary tool to compare several manipulator geometries. Fig 7. Stabilized singular curve patterns for another manipulator geometry plotted for ρ 1 =5 (left) and ρ 1 =20 (right). 6. Conclusions A procedure for computing joint space singularities of 3-RPR parallel manipulators has been presented in this paper. Then, the existence condition of cusp points defined by McAree 9 has been reviewed and exploited. An algorithm able to detect and to compute cusp points inside any section of the joint space of any 3-RPR parallel manipulator has been established. To the best of the authors’ knowledge, such an algorithm had never been proposed before. The algorithm results in a 96 th degree univariate polynomial that can be put in a factored form. We have showed with intensive numerical experiments that the coordinates of the cusp points are the real roots of a 24 th degree univariate polynomial, which is one of the factors of the 96 th polynomial. Finally, a descriptive analysis of the singular curves in slices of the joint space of 3- RPR parallel manipulators has been conducted, with a special focus on the cusp points on these singular curves. It has been shown that, contrary to what arises in serial manipulators where any cross section of the workspace exhibits the same pattern of singular curves and cusp points, this pattern depends on the choice of the slice in the joint space for a given 3- RPR parallel manipulator. On the other hand, we have noticed that it is possible to have a constant pattern by adjusting the joint limits. It has been observed that the 19 maximum number of cusps depends on the manipulator geometry . No manipulators were found with more than eight cusp points. Most of the research work on parallel manipulators has been focused on the analysis and optimization of the workspace. This paper provides a complementary tool that helps better understand the topology of the joint space of parallel manipulators and finds applications in both design and trajectory planning. 7. References 1. J-P. Merlet, Parallel Robots, Kluwer Academics, 2000. 2. C. Gosselin, and J. Angeles, “Singularity analysis of closed loop kinematic chains,” IEEE Transactions on Robotics and Automation , vol. 6, no. 3, 1990. 3. C. Gosselin, J. Sefrioui, and M.J. Richard, “Solution polynomiale au problème de la cinématique directe des manipulateurs parallèles plans à 3 degrés de liberté,” Mechanism and Machine Theory , vol. 27, no. 2, pp. 107-119, 1992. 4. J. Sefrioui, and C. Gosselin, “On the quadratic nature of the singularity curves of planar three- degree-of-freedom parallel manipulators,” Mechanism and Machine Theory , vol. 30, no. 4, pp. 535-551, 1995. 5. P. Wenger, and D. Chablat, “Definition sets for the direct kinematics of parallel manipulators,” 8 th Conference on Advanced Robotics , pp. 859-864, 1997. 6. I. Bonev, D. Zlatanov, and C. Gosselin, “Singularity Analysis of 3-DOF Planar Parallel Mechanisms via Screw Theory,” ASME Journal of Mechanical Design , vol. 125, no. 3, pp. 573– 581, 2003. 7. K.H. Hunt, and E.J.F. Primrose, “Assembly configurations of some In-parallel-actuated manipulators,” Mechanism and Machine Theory , vol. 28, no. 1, pp.31-42, 1993. 8. C. Innocenti, and V. Parenti-Castelli, “Singularity-free evolution from one configuration to another in serial and fully-parallel manipulators. Journal of Mechanical design . 120. 1998. 9. P.R. McAree, and R.W. Daniel, “An explanation of never-special assembly changing motions for 3-3 parallel manipulators,” The International Journal of Robotics Research , vol. 18, no. 6, pp. 556-574. 1999. 10. Xianwen Kong and Clément M. Gosselin, “Forward displacement analysis of third-class analytic 3- RPR planar parallel manipulators,” Mechanism and Machine Theory , Vol. 36, No. 9, pp. 1009--1018. 20 11. J. W. Burdick, “A Classification of 3R regional manipulator Singularities and Geometries,” In Proceeding IEEE International Conference on Robotics and Automation , pp. 2670-2675, Sacramento, California, 1991. 12. Ph. Wenger, “A New General Formalism for the Kinematic Analysis for all Non-Redundant Manipulators,” In Proceeding International Conference on Robotics and automation, pp. 442- 447, Nice, France, 1992 13. J. El Omri and P. Wenger, “How to recognize simply a non-singular posture changing 3-DOF manipulator,” Proc. 7th Int. Conf. on Advanced Robotics , p. 215-222, 1995. 14. E. Ottaviano, M. Husty and M. Ceccarelli, “A cartesian representation for the boundary workspace of 3R manipulators,” In Proc. On Advances on Robots Kinematics , p. 247-254, 2004. 15. Ph. Wenger and D. Chablat, “Workspace and Assembly modes in Fully-Parallel Manipulators : A Descriptive Study,” Advances in Robot Kinematics and Computational Geometry , Kluwer Academic Publishers, pp. 117-126, 1998. 16. M. Zein, Ph. Wenger and D. Chablat, “Singular curves and cusp points in the joint space of 3- RPR parallel manipulators”, Proceedings of the 2006 IEEE International Conference on Robotics and Automation , Orlando, Florida, May 2006. 17. K. H. Hunt, “Geometry of Mechanisms,” Clarendon Press , Oxford, 1978 . 18. B. Buchberger, G. E Collins and R. Loos: “Computer Algebra: Symbolic & Algebraic Computation,” Springer-Verlag , Wien, pp. 115-138, 1982. 19. M. Baili, P. Wenger and D. Chablat, “A classification of 3R orthogonal manipulators by the topology of their workspace,” IEEE Int. Conf. on Robotics and Automation , Louisiana, USA 2004.