Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 1 - POLYNOMIAL TRAJECTORY ALGORITHM FOR A BIPED ROBOT ERIK CUEVAS 1,2 , DANIEL ZALDIVAR 1,2 , MARCO PEREZ-CISNEROS 2 MARTE RAMIREZ 1 1 Institut für Informatik, Freie Universität Berlin Takustr. 9, 14195 Berlin, Germany 2 CUCEI, Universidad de Guadalajara Av. Revolucion 1500,C.P. 44430 Guadalajara, Jal., Mexico {daniel.zaldivar, erik.cuevas, marco.perez}@cucei.udg.mx Abstract Building trajectories for biped robot walking is a complex task considering all degrees of freedom (DOFs) commonly bound within the mechanical structure. A typical problem for such robots is the instability produced by violent transitions between walking phases in particular when a swinging leg impacts the surface. Although extensive research on novel efficient walking algorithms has been conducted, falls commonly appear as the walking speed increases or as the terrain condition changes. This paper presents a polynomial trajectory generation algorithm (PTA) to implement the walking on biped robots following the cubic Hermitian polynomial interpolation between initial and final conditions. The proposed algorithm allows smooth transitions between walking phases, significantly reducing the possibility of falling. The algorithm has been successfully tested by generating walking trajectories under different terrain conditions on a biped robot of 10 DOFs. PTA has shown to be simple and suitable to generate real time walking trajectories, despite reduced computing resources of a commercial embedded microcontroller. Experimental evidence and comparisons to other state-of-the-art methods demonstrates a better performance of the proposed method in generating walking trajectories under different ground conditions. Keywords: Biped robots, trajectory generation, dynamic walking. 1. Introduction Robots must successfully deal with complicated environments such as rugged terrain, sloped surfaces, and steep stairs. Although it is assumed that biped robots can walk in almost any type of terrain surpassing some of the wheeled robots capabilities [1] [2] [3], they are complex nonlinear systems with many degrees of freedom that may fall down easily while walking due to its relatively small feet and other important design constraints. Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 2 - A popular technique to implement biped walking is to keep the zero moment point (ZMP) constraint within a supporting feet polygon in order to ensure stable walking gaits [4]. Several methods have been proposed to generate walking trajectories satisfying this condition such as those referred in [5]-[17]. They fall into two groups: time-dependent and time-invariant algorithms. By far, the most popular algorithms are time-dependent which involve the tracking of pre-calculated trajectories. The second group requires the precise knowledge of biped dynamics in order to solve complex nonlinear models to generate walking patterns. This paper focuses only on the time-invariant algorithms. Several techniques for generating walking motion for biped robots may be found in the literature. For instance, Ohishi et. al, [11] approximated the biped movement as a three dimensional Inverted Pendulum Model (IPM), using the resulting points as tracking reference in Cartesian space. Some other algorithms with small variations of IPM can also be found. In [17] the IPM is transformed into a cart-table model, with the cart movements corresponding to the trajectory of the Center of Mass (CoM). In [12] and [13], Kajita et al, demonstrated the use of a length-varying inverted pendulum as reference point to generate trajectories. The pendulum’s length varies as to keep the biped’s COM at a constant height above the walking surface (see also [8]). Grishin et al. [14] used a pre-computed trajectory with online adjustment to improve stability of the biped robot. Other works such as those in [5],[6],[7] and [10], use a different inverted pendulum method to generate the walking trajectory. Most of the works on three-dimensional walking movements compute decoupled trajectories from the frontal and sagittal planes. Katoh and Mori demonstrated in [15] that using a Van der Pol oscillator as generator of the tracking reference would induce walking trajectories for a biped robot. Moreover, Furusho and Masubuchi in [16] presented the walking control algorithms by tracking a piecewise-linear joint reference trajectory. Another method for trajectory generation is to mimic the human rhythmic function by means of a central pattern generator, just as it is reported in [9]. In this method, one self-oscillating system is designed as to generate synchronized periodic motions for each joint. Although extensive research on novel efficient walking algorithms has been conducted, the reported results still show a trend for falling down as walking speed increases or when terrain conditions change. Slow down the walking pace will be a temporary solution as the problem remains unsolved as walking deterioration is inflicted on subsequent walking phases. Some previous works [18] have shown the negative effect of a violent impact Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 3 - between the feet and the ground which yields a reaction force R F and increases the possibility of falls. The effect can be even worse, when the robots’ velocity is increased or the terrain conditions change. Although some IPM algorithms have attempted to solve the problem, they require extensive computation unsuitable for real-time applications. This paper presents the polynomial trajectory algorithm (PTA) which is a simple and effective walking trajectory algorithm based on cubic Hermitian polynomial interpolation of the kinematics positions of the robot. A Hermite spline (HS) is a cubic polynomial interpolation in segments with adjustable derivatives at each control point that allows decreasing link’s velocities when they do reach the target point. Therefore, the impact on the leg caused by the ground contact or by violent transitions among different walking phases may also be reduced. The walking trajectory is generated for each joint, adjusting some intermediate positions in order to assure the best ZMP trajectory. The resulting approach generates suitable bipedal walking gaits in real time considering only modest computing resources, such as a microcontroller embedded platform. Experimental evidence shows the effectiveness of the method to generate walking trajectories under different ground conditions. The proposed algorithm was successfully tested on a biped robot of 10 DOF’s [19] under different walking conditions. This paper presents a comparison between several state-of-the-art methods and it demonstrates a better relationship between the link velocities and the reaction forces produced by the proposed method. It reduces the ZMP instability created by violent transitions between walking phases such as the swinging leg impacting the surface. This paper is organized as follows: Section 2 introduces the biped robot model and the walking gait. Section 3 discusses on the impact model and its velocity discontinuity. Section 4 describes PTA and its parameters while Section 5 features the walking motions generated by the PTA, despite terrain changes. This section also discusses on comparing the PTA performance to other related methods. Finally, Section 6 draws some conclusions. 2. Robot model and bipedal walking 2.1 Robot description The dynamics of a biped robot is closely related to its structure [20]. This work employs the “Dany Walker” robot [19], built on 10 low-density aluminum links. Each link consists of a structure which has been carefully designed to allow an effective torque transmission and low deformation. All links are connected within the biped robot structure of 10 degrees of freedom as shown in Fig. 1. The motors allow movements within the frontal and sagittal plane. Figure 2a shows the frontal plane of the robot while the Figure 2b shows the sagittal plane. The Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 4 - embedded control computer system is based on a PIC18F4550 microcontroller executing concurrent tasks such as trajectory generation, servo-motor control, and sensor signal collection. The ZMP is estimated through data integration from pressure sensors (Flexiforce type) located on each foot . The centre of pressure (CoP) matches the ZMP if and only if the latter falls inside the supporting foot polygon (SfP). In the “Dany Walker” biped robot, the ZMP was found by using feedback from triangular force sensor arrangement as it is described in [19,21]. Figure 1 shows the positive direction of the x-axis corresponding to the robot’s forward movement. The positive direction of the y-axis corresponds to the robot’s movement to its left, while the positive direction of the z-axis is the opposite direction of gravity. Each mass is assumed to be located on the midpoint of its corresponding link. The parameters of the robot model follow the convention presented in [22]. The parameters are summarized in Table 1 following locations drawn in Figure 3. Fig. 1. “Dany Walker” biped robot. a) b) Fig. 2. Dany Walker robot a) frontal plane b) sagittal plane. M1 M6 M5 M10 M 2, 7 M 3, 8 M 4, 9 M1 M2 M3 M4 M5 M6 M7 M8 M9 M10 1 m 2 m 3 m 4 m 5 m 6 m 7 m x y z Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 5 - Parameter Value 1 m 0.2Kg 2 m 0.3Kg 3 m 0.3Kg 4 m 0.455Kg 5 m 0.3Kg 6 m 0.3Kg 7 m 0.2Kg 1 l 10cm 2 l 11m 3 l 11cm 4 l 10cm 5 l 11cm 6 l 11cm 7 l 10cm w l 11.2cm fl l 10cm fw l 8cm 1 f l 5cm 2 f l 4cm Table 1. Parameters of the biped robot. The foot’s length and width are 10cm and 8cm respectively. Let position ( , , ) s s s x y z be middle point of the supporting foot. Thus the robot motion may be expressed with respect to the reference frame whose centre is ( , , ) s s s x y z . The x-directional ZMP ( ZMP x ) and the y-directional ZMP ( ZMP y ) should be located in the following region: −5cm < ZMP x < 5cm −4cm < ZMP y < 4cm. (1) Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 6 - For the single support phase, such region is a convex hull for all contact points between the foot and the ground. Thus, if the ZMP falls within this area, the biped robot can walk without falling down [23]. However, it is difficult to calculate the ZMP from an 3D robot model as in Figure 1 because of the coupling motion between the frontal plane (y–z plane) and sagittal plane (x–z plane). Therefore, the walking motion may be generated from two 2D models including the sagittal plane model with 8 segments and 7 DoFs as shown in Figure 3(a). The frontal plane model has 6 segments and 5 DoFs as shown by Figure 3(b). The ZMP equations of the sagittal plane robot model (Fig. 3(a)) and the frontal plane robot model (Fig. 3(b)) are: Fig. 3. (a) Foot parameters, (b) sagittal plane and (c) frontal plane configuration. 7 7 1 1 7 1 ( ) ( ) i i i i i i i i ZMP i i i m z g x m x z x m z g = = = + − = + ∑ ∑ ∑ && && && (2) 7 7 1 1 7 1 ( ) ( ) i i i i i i i i ZMP i i i m z g y m y z y m z g = = = + − = + ∑ ∑ ∑ && && && (3) 1 m 2 m 3 m 5 m 6 m 7 m 4 m 4 m 3 m 2 m 7 m 6 m 5 m 1 m 1 l 2 l 3 l 4 l 5 l 6 l 7 l ( , ) fs fs x z (0, 0) (0, 0) ( , ) fs fs y z Sagittal plane Frontal plane x z y z y x 1 lf 2 lf a) b) c) fl l fw l w l Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 7 - with g being the gravity, ( , , ) i i i x y z and i m being the position and mass of the i -th point mass ( i = 1, . . . , 7) [7]. In Equations 2 and 3, the inertia factors can be ignored assuming that the mass of link i is uniformly distributed about the centre of mass [11,24]. 2.2 Bipedal Walking. In the context of biped robots, walking can be considered as a repetition of one-step motion [10,25]. The motion cycle can be divided into the single support phase and the double support phase just as shown in Figure 4. Single support refers to the fact that one foot holds the robot’s weight while the other foot is moving forward on the air. The hip moves parallel to the ground keeping a constant height as shown in Figure 4. (a) (b) Fig. 4. Walking phases, a) single support, b) double support. In the case of human walking, the orientation of the swing foot changes in order to reduce the impact between the foot and the ground. For robotic bipedal walking, this impact can be reduced by the z-directional motions of the swing foot and body and therefore the relative foot position and the ground must be known at all times. This fact indeed implies a full feedback and sensor data integration design considering that terrain conditions may change [10, 11, 12, 13]. 3. Impact model and velocity discontinuity. This section describes the effects in terminal velocities in the foot-ground impact. This condition occurs when the swing leg touches the walking surface. Let s Q be the N -dimensional configuration space of the robot when the stance leg end is acting as a pivot and let 1 ( , , ) s N s q q q Q = ∈ K be a set of generalized coordinates. The swing phase model corresponds to an open kinematic chain. Applying the method of Lagrange (see [26]), the model is written in the form Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 8 - ( ) ( , ) ( ) ( ) s s s s s s s s s s s D q q C q q q G q B q u + + = && & & (4) The matrix s D being the inertia matrix, s C being the Coriolis matrix, s G representing the gravity vector and s B mapping the joint torques to generalized forces. Expression 1 ( , , ) N N u u u = ∈ R K holds the torque being applied to each joint i ( (1, , ) i N ∈ K . It is clear so far that not all configurations of the model are physically compatible to the single support phase concept of walking as presented before. For example, all points of the robot should be above the walking surface excluding the end of the stance leg of course. In addition, there are some other kinematic constraints [27] that also must be considered. The impact event is very short [28], so the ground reaction forces may be replaced by an impulse. The impact model therefore involves the reaction forces at the leg’s end and requires the model of the biped robot [18,26]. Let s q be the generalized coordinates for the single support model and ( , , ) x y z c c c = c the Cartesian coordinates of some fixed point mass on the robot. By using the generalized coordinates ( , ) e s q q = c , the Lagrange method yields ( ) ( , ) ( ) ( ) e e e e e s e e e e e R D q q C q q q G q B q u F δ + + = + && & & (5) with R F δ representing the reaction force acting on the robot due to the contact between the swing leg’s end and the ground. According to [18], that results in a discontinuity for the velocity components of the biped robot. This will therefore be a new initial condition from which the single support model would evolve until the next impact appears as follows: ( ) e e q q + − = ∆ & & , (6) with e q + & and e q − & being the velocities values just after and just before the impact respectively. Considering no rebounds, the impact can thus be modeled as in [18] as follows: ( ) ( ) , e e e e e e R D q q D q q F + + − − − = & & (7) Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 9 - According to Equation 7, the value of the reaction force R F (impact) decreases when the difference among e q + & and e q − & is minimized. Such condition may be induced, according to Equation 6, if the trajectory speed e q − & is minimized before impacting the ground [18]. 4. Polynomial Trajectory Algorithm (PTA). The position of the robot is controlled with respect to the frontal plane by motors M1, M6, M5 and M10 (See Figure 2(a)). The walking sequence of a biped robot can thus be determined by computing the hip and swing foot trajectories in the sagittal and frontal plane [29,30]. For the sagittal case, the servo control system drives motors M7, M8 and M9 for the left leg and M2, M3 and M4 for the right leg (Fig. 2(b)). In this work, the robot ́s stability was achieved by applying the ZMP criteria, while Hermite spline interpolation is used to generate the walking trajectories as explained below. 4.1 Hermite spline interpolation Cubic polynomials offer a reasonable balance between interpolation smoothness and computation speed. In comparison to polynomials of higher degree, the cubic splines require less calculations and smaller storage spaces, besides they are more stable. A Hermite spline [31] is a cubic polynomial interpolation in segments with adjustable derivatives (velocities) at each control point. Opposite to natural cubic splines, Hermitian allows to define the segment locally because each part of the curve only depends on the conditions of its initial and final points. This is an important property to generate robot's trajectories, since it allows diminishing the speed while arriving to the final point, reducing the characteristic impact as the leg contacts the ground (see section 3). If ( ) P u represents a cubic parametric function that interpolates values between two control points (see Fig. 5), then the conditions to define the Hermite curve are: (0) s P P = (1) e P P = (0) s P v ′ = (1) e P v ′ = (8) Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 10 - with s v and e v expressing the initial and final velocity of the segment respectively. Fig. 5. Interpolation values between two control points. The Hermite curve is thus defined as: 3 2 ( ) 0 1 P u au bu cu d u = + + + ≤ ≤ (9) with a, b, c and d being the function parameters. This expression and its derivative can be expressed in matrix form yielding: 3 2 ( ) 1 a b P u u u u c d         = ⋅         2 ( ) 3 2 1 0 a b P u u u c d       ′   = ⋅         (10) By substituting the values of the initial and final points s P and e P , as well as their velocities s v and e v , the expression becomes 2 2 1 1 3 3 2 1 0 0 1 0 1 0 0 0 s e s e P a P b v c v d −             − − −       = ⋅                   (11) Now by replacing values a, b, c and d in Equation 9 and re-arranging the final polynomial emerges as follows: (0) P (1) P s v e v ( ) P u Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 11 - 3 2 3 2 3 2 3 2 ( ) (2 3 1) ( 2 3 ) ( 2 ) ( ) s e s e P u P u u P u u v u u u v u u = − + + − + + − + − − (12) 4.2 Trajectory generation One walking motion can be considered as a repetition of one-step motion being repeated within a s T period. In order to achieve robust walking, the impact with the walking surface at the end of the single support phase should be executed smoothly by reaching zero velocity at the very contact spot. The walking sequence can thus be determined by only computing the trajectory of the hip and the swing foot and using the inverse kinematics to generate the trajectory for each independent joint in the biped structure. 4.3 Hip trajectory in sagittal plane Hip trajectory can be generated using the Hermite spline polynomial algorithm considering that the initial and final states (position and velocities) are known from the single support phase. Figure 6 shows the initial position defined by [ x hs ,z hs ] and the final position represented by [ x he ,z he ]. The initial velocity [ v xhs ,v zhs ] (produced when the robot leaves the initial position) is also specified in the trajectory model. The same applies for the final velocity [ v xhe ,v zhe ], exhibited when the robot contacts the walking surface. Fig. 6. Hip and swing foot trajectories in sagittal plane. 5 m 6 m 7 m 4 m 4 m 3 m 3 m 5 m 6 m 7 m 2 m 2 m s L − 0 s L ( , ) hs hs x z ( , ) xhs zhs v v ( , ) he he x z ( , ) xhe zhe v v ( , ) fs fs x z ( , ) fe fe x z ( , ) xfs zfs v v ( , ) xfe zfe v v z x ( , ) fm m z T 1 1 ( , ) h x T Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 12 - The initial and final positions for the cubic trajectory in z (the z h (t) direction), can be expressed as follows: ( )  =  =  = +   hs h he s z if t kT z t z if t kT T (13) with T being the period for the robot's step and T s the period in single support phase. ( ) zhs h zhe s v if t kT z t v if t kT T  =  =  = +   & (14) Considering Eq. 12 the cubic polynomial can be defined as: 2 2 3( ) 2 ( ) ( ) ( ) he hs zhs s zhe s h hs zhs s z z v T v T z t z v t kT t kT T − − − = + − + − 3 3 2( ) ( ) ( ) hs he zhs zhe s s s z z v v T t kT kT t kT T T − + + + − < ≤ + (15) x h (t) is divided into two parts: from x h (KT) to x h (kT+T 1 ) and from x h (kT+T 1 ) to x h (kT+T p ) . The definition for x h (t) can be summarized as follows: 1 1 . 1 0 ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) h hs h h h he s h xhs h h h xhe s h x t x t kT x t x t kT T x t x t kT T x t v t kT x t x t t kT T x t v t kT T x t a t kT − +  = =   = = +   = = +   = =    = = +   = = +  = =   & & & && (16) with a o being pre-specified to satisfy the initial condition of acceleration. The cubic polynomial trajectory can thus be calculated using (15), yielding: Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 13 - 2 0 2 3 1 1 0 1 1 3 1 1 1 1 2 1 1 1 1 2 1 3 1 1 2 1 1 3 1 1 ( ) ( ) 2 1 ( )( ) 2 ( ) ( ) (3( ) 2 ( ))( ) ( ) (2( ) ( )( ))( ) ( ) hs xhs h hs xhs h h xh he h xh p p h he xh x p p x v t kT a t kT x x v T a T t kT kT t kT T T x t x v t kT T x x v T T t kT T T T x x v v T T t kT T kT T T + − + − − − − − + < ≤ + = + − − − − − − − + − − + + − − − + + − 1 s T t kT T               < ≤ +    (17) 4.4 Swing foot trajectory in sagittal plane. Hermite spline polynomial interpolation is used to generate the foot trajectory in the single support phase. In order to assure a smooth transition, velocities ( ( , ) xhs zhs v v and ( , ) xfe zfe v v ) should be defined near zero. The final foot position (Figure 6) representing target positions and velocities can thus be obtained following: ( ) ( ) ( ) ( ) 0 ( ) 0 f fs f fe s f f f s x t x t kT x t x t kT T x t x t t kT x t t kT T  = =   = = +  =  = =   = = +   & & (18) ( ) ( ) ( ) ( ) 0 ( ) 0 f fs f fe s f f f s z t z t k T z t z t k T T z t z t t k T z t t k T T  = =   = = +  =  = =   = = +   & & (19) From the initial and the final positions in x and z axis, a smooth trajectory can be generated by the Hermite spline interpolation yielding: for x f (t): 2 3 2 3 ( ) ( ) ( ) 3( ) 2( ) f fs fe fs fe fs s s s t kT t kT x t x x x x x kT t kT T T T − − = + − − − < ≤ + (20) Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 14 - and for z f (t): 2 3 2 2 2 3 2 3 ( ) ( ) 3( ) 2( ) ( ) ( ) 3( ) 2( ) ( ) ( ) fs fm fs fm fs m m m m m fm fe fm fe fm m s s m s m t kT t kT z z z z z kT t kT T T T t kT T t kT T z z z z z kT T t kT T T T T T  − − + − − − < ≤ +    − − − −  + − − − + < ≤ +  − −  (21) The hip and knee positions required to produce appropriate movements for each leg can thus be calculated using the inverse kinematics of the robot's structure. 4.5 Hip trajectory in frontal plane The hip trajectory can also be generated by the Hermite spline polynomial algorithm. However, all movements in the frontal plane should be performed within a cycle (see Figure 7). The hip moves from the initial position ( hs y ) to the maximum allowed displacement ( he y ), with an initial velocity ( yhs v ). Such movement must be completed within the half of the walking period ( 2 / 2 s T T = ). From that position ( he y ), the hip moves again to its initial position ( hs y ), by executing a very smooth trajectory. It allows diminishing the speed while arriving to the final point by reducing the characteristic impact on the leg at ground contact. Fig. 7. Hip and swing foot trajectories in the frontal plane. w l − 0 1 m 2 m 3 m 3 m 4 m 4 m 5 m 5 m 3 m 3 m 7 m 7 m hs y he y yhs v 0 yhe v = z y Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 15 - From initial and final positions in y , a smooth trajectory can be generated by the Hermite spline interpolation yielding: for 2 kT t T < ≤ 2 2 2 3 2 3 2 2 3( ) 2 2(( ) ( ) ( ) ( ) ( ) he hs yhs hs he yhs h hs yhs y y v T y y v T y t y v t kT t kT t kT T T − − − + = + − + − + − (22) for 2 s T t T < ≤ 2 3 2 3 2 2 3( ) 2(( ) ( ) ( ) ( ) ( ) ( ) hs he hs he h he s s y y y y y t y t kT t kT T T T T − − = + − − − − − (23) 4.6 Determination of the algorithm parameters Tuning v xhs , T l , T m , z fm and yhs v has immediate impact on the smoothness of the trajectory with respect to velocities and accelerations. Recalling that the link’s speed at the end of the single support phase should be approaching zero in order to assure a smooth contact with the floor surface, a proper selection is relevant for the overall performance. If 1 m v T T T = = then only v T needs to be fixed. If v T is close to / 2 s T then a robust walking trajectory with smooth impact transition may be obtained. In turn, this feature allows robustness against disturbances either from non-modeled dynamics of the biped robot or from the walking surface. 0 0.5 1 1.5 2 −10 −8 −6 −4 −2 0 2 4 6 8 10 Time (s) x (cm) m1 m2 m3 m4 m5 m6 m7 0 0.5 1 1.5 2 −15 −10 −5 0 5 Time (s) y (cm) m1 m2 m3 m4 m5 m6 m7 Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 16 - (a) (b) 0 0.5 1 1.5 2 0 5 10 15 20 25 30 35 Time (s) z (cm) m1 m2 m3 m4 m5 m6 m7 (c) Fig. 8. Walking motion, (a) x trajectory, (b) y trajectory and (c) z trajectory. 5. Walking motions Motion can be thus generated according the PTA algorithm following Equations 13-23. The trajectory for each point mass ( ) i m is shown in Figure 8. A step period of period s T = 2 s and step length s L = 10 cm are considered. Figure 9 shows the motion on the saggital plane for each link, considering the trajectory of each mass point. The evolution of the trajectories may be simulated considering the “Dany Walker" model according to Table 1. It can be seen that the trajectories shown in Figure 9 match those calculated for PTA as it is shown by Figure 8. All tests consider a flat walking surface. Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 17 - −15 −10 −5 0 5 10 15 0 5 10 15 20 25 30 x (cm) z (cm) m4 m4 m5 m3 m3 m5 m6 m6 m7 m7 m1 m2 m2 Fig. 9. Walking motion trajectory in the saggital plane. Figure 10 shows the trajectories for the ZMP as they are generated by PTA for real-time experiments in the robot. The values of the ZMP were calculated from a triangular arrangement of force sensors located at each foot of the “Dany Walker" robot [19,21]. −20 −10 0 10 20 30 40 50 60 −30 −20 −10 0 10 20 x (cm) y (cm) Fig. 10. ZMP trajectory using PTA. 5.1 Experiments In order to demonstrate the effectiveness of the PTA algorithm, the step motion is tested under the assumption that the contact between the swing foot and the ground happens on uneven terrain. Two experiments are prepared. First, the impact is simulated over a variable-height surface in order to test the PTA performance. The experiment Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 18 - includes a comparison between PTA and other trajectory generation methods. The second experiment is a real-time test of the resulting PTA’s trajectories. Small wooden pieces are arranged over the robot’s path. They are lightly bigger that the size of the robot’s foot, aiming to create a changing relationship between the swinging foot and the floor. In order to compare the results, the same experiment was proved with the broadly well-known approach (according to references [33-37] found in the literature) presented in [10]. 5.1.1 Simulation of the impact on the floor. The first experiment employs the “Dany Walker" biped robot. The kinematic and dynamic models of the robot are presented in [20] and [19]. The impact model proposed in [18] is used to test the actual ability of PTA to achieve a stable walking within a variable-height terrain whose attitude varies from 0 to 1cm at about 6cms away from the starting point (see Figure 11). The simulation considers s T = 5 s and s L = 10 cm. Figure 11 shows the trajectories produced by PTA and the zoom of the transitory produced over the mass 6, at the impact instant. After the simulation, it can be assumed that the speed of 7 m ( 7 m − & ) was 3.17cm/s producing an equivalent force of 0.11 R F N = at the impact. −15 −10 −5 0 5 10 15 0 5 10 15 20 25 30 x (cm) z (cm) m5 m3 m4 m4 m3 m5 m6 m7 m7 m2 m2 m6 FR Fig. 11. Walking PTA trajectory in the saggital plane under variable terrain conditions. (Upper right) A zoom view of the transient response of the mass m6. Table 2 shows the performance of the PTA as it is compared to other IPM trajectory generation algorithms such as the Ohishi’s method [11], the Kajita’s algorithm [17], Park’s contribution in [10] and the Van der Pol oscillator 5.5 6 6.5 7 7.5 15 15.5 16 16.5 17 17.5 18 m6 Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 19 - as it is applied in [15]. The experiment employed the same parameters reported by the authors in order to ease the comparison to the “Dany Walker” robot. −20 −10 0 10 20 30 40 50 60 −30 −20 −10 0 10 20 30 x (cm) y (cm) wooden pieces (a) −20 −10 0 10 20 30 40 50 60 −30 −20 −10 0 10 20 30 x (cm) y (cm) wooden pieces the biped falls (b) Fig. 12. Second experiment: real-time impacts on the ground. The ZMP trajectories are shown while the robot walks over an uneven terrain. (a) Shows the PTA operation while (b) shows the IPM Park’s algorithm. Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 20 - Algorithms Velocity of 7 m ( 7 m − & ) before the impact R F PTA 3.17cm/s 0.11 N IPM Ohishi version 9.51cm/s 0.821 N IPM Kajita version 10.44cm/s 0.902 N IPM Park version 8.82cm/s 0.711 N Van der Pol oscillator 13.71cm/s 1.05 N Table 2. Results of the first experiment: PTA vs. other trajectory generation algorithms under changing terrain conditions. The PTA reduces the speed and therefore produces a small reaction force R F at the impact (near to zero), compared to other algorithms based on IPM or on Van der Pol oscillators which hold the highest velocity at the impact with 13.71cm/s. The IPM algorithms adjust the trajectories according to accelerations yielding higher velocities before the impact while the Van de Pol-based algorithm keeps constant speeds even when the surface’s height is increased. The value of the reaction force R F (impact) decreases when the velocity 7 m − & is minimized. 5.1.2 Impacts on the real-time walking This experiment aims to set a new walking surface by scattering wooden pieces of same dimensions of the biped’s foot but being 2 cm taller than them at each side. Obstacles begin at about 15 cm away from the initial position and they end at about 50 cm at the robot’s front flank. Figure 12(a) shows the results of PTA, while Figure 12(b) presents the performance of the IPM Park algorithm [10] over the same experimental setting. The ZMP trajectory presented in Figure 12(a) demonstrates that the ZMP is always kept inside the foot support area using PTA, despite disturbances related to the terrain type. Figure 12(b) shows the ZMP trajectory is not always kept within the foot support area. Therefore, the robot is only able to complete two steps before falling down at an uneven terrain. The ZMP readings were estimated from the triangular arrangement of force sensors at each foot [19, 21]. The generation of both trajectories considers s T = 5 sec and s L = 10 cm. The PTA algorithm was programmed using Visual C++ and was tested on the “Dany Walker” biped robot [19]. Figure 13 shows the real-time walking sequence. Table 3 shows the average values of the reaction force for 20 cycles. In order to measure the reaction force, a force-voltage relationship [38] is used. Only left foot impacts have been considered. Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 21 - Algorithms R F IPM Park version 0.717N PTA 0.201 N Table 3. Results of the second experiment: PTA vs. IPM Park algorithms under changing terrain conditions. 5.2 Computational Cost This section compares the computational cost of PTA to other generation algorithms such as Hermitian polynomials and B-Splines. The time required to calculate the solution and the required storage space are considered as comparison indexes. All systems are compiled using the CCS PIC-C® 4.068 compiler aiming for the PIC18F4550 microcontroller platform. Fig. 13. Walk sequence using the TPA algorithm. The experiment considers a complete step trajectory and its computation. Table 4 shows results considering several methods such as PTA, IPM Ohishi method [11], IPM Kajita algorithm [17], IPM Park procedure [10] and the Van der Pol oscillator algorithm [15]. Table 3 shows that only the IPM Park version can actually generate acceptable gaits, considering the modest computer resources of the robot. Other methods cannot generate speeds smaller than 4 seconds which poses a serious difficulty to perform control on the system by considering the signal sensors feedback and the calculus of Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 22 - the ZMP. Besides, to implement the IPM-based algorithms (Ohishi, and Kajita) and the Van del pol oscillator, it was necessary to expand the memory of the host computer system because one numerical method is required to solve the pendulum-based system for IPM methods or to generate the oscillation trajectories for the Van der Pol method. Algorithm Calculus time Storage space PTA 0.4s 86 Bytes IPM Ohishi version 4s 415 Bytes IPM Kajita version 4s 415 Bytes IPM Park version 2s 211 Bytes Van der Pol oscillator 12s 518 Bytes Table 4. PTA computational cost vs other trajectory generation algorithms. The B-splines class is a very well-known tool which following the Hermitian polynomials method, may be generated by simply approaching their control points (allowing to configure positions and speeds). However the B-spline allows a better control of the intermediate points of the trajectory, in such a way that they can be modified locally without a substantial change in the complete trajectory. In the case of the generation of trajectories for biped robots, the intermediate points are not modified because the final point of the trajectory is what really matters. Under this fact, the use of B-splines would not represent any advantage in comparison to the Hermitian polynomials. However its use would imply a bigger computational cost, since its calculation involves the use of more complex algorithms [32]. 6. Conclusions In this paper, the Polynomial Trajectory Algorithm (PTA) was proposed as a simple algorithm to generate successful walking trajectories for biped robots. The equations used by PTA are obtained from the Hermite spline interpolation of initial and final conditions. The algorithm is able to generate smooth impacts against the ground when the robot changes between different walking phases. It was demonstrated that these trajectories reduce the trend for falling down when the terrain condition changes. Several joint trajectories for walking motion on the 3D robot “Dany walker” were tested and compared to the results offered by other IPM methods. The results showed Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 23 - that by using PTA the impact effect is minimized. The paper also studies the ZMP trajectory produced by PTA and the IPM Park’s method. The results showed that applying the IPM algorithm, the robot is able to complete only two steps within an uneven surface before falling down. PTA is shown to be simple and suitable to generate trajectories for bipedal walking in real time despite the use of modest computing resources such as a commercial embedded microcontroller. Since PTA only implements Equations 13- 23, it does demand modest computing resources allowing its application to other humanoid robot platforms. References [1] R. Goddard, Y. Zheng and H. Hemami, Control of the heel-off to toe-off motion of a dynamic biped gait, IEEE Trans. Syst . Man. Cayb., vol.22 , no. 1, 1992. [2] N. Kanehira, T. Kawasaki, S. Ohta, T. Isozumi, T. Kawada, F. Kanehiro, S. Kajita & K. Kaneko, Design and experiments of advanced module (HRPL-2L) for humanoid robot (HRP-2) development, Proc. 2002, IEEE-RSJ Int. Conf. Intell. Rob. Sys. EPFL , Lausanne, Switzerland, 2002, 2455-2460. [3] A. Konno, N. Kato, S. Shirata, T. Furuta & M. Uchiyama, Development of a light-weight biped humanoid robot in Proc. 2000 IEEE-RSJ Int. Con. Intell. Rob. Sys ., 2000, 1565-1570. [4] M. Vukobratović, B. Borovac, D. Surla, D. Stokic, Biped Locomotion. Dynamics, Stability, Control and Application , Springer-Verlag, London, UK, 1990. [5] Amos Albert, Wilfried Gerth, Analytic path planning algorithms for bipedal robots without a trunk, Journal of Intelligent and Robotic Systems 36 (2003) 109–127. [6] Atsuo Takanishi, Mamoru Tochizawa, Hideyuki Karaki, Ichiro Kato, Dynamic Biped Walking Stabilized with Optimal Trunk and Waist Motion, in: Proceedings of the IEEE/RSJ International Conference on Intelligent Robots and Systems , Sept. 1989, pp. 187–192. [7] Jong Hyeon Park, Fuzzy-logic zero-moment-point trajectory generation for reduced trunk motions of biped robots, Fuzzy Sets and Systems 134 (2003) 189–203. [8] Taesi Ha, Chong-Ho Choi, An effective trajectory generation method for bipedal walking. Robotic and Autonomus Systems 55 (2007) 795-810. [9] R. Héliot, B. Espiau, Online generation of cyclic leg trajectories synchonized with sensor measurement. Robotics and Autonomus Systems . In press. (2007) [10] Jong H. Park, Kyoung D. Kim, Biped Robot Walking Using Gravity Compensated Inverted Pendulum Mode and Computed Torque Control, in: Proceedings of the IEEE International Conference on Robotics and Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 24 - Automation , vol. 4, May 1998, pp. 3528–3533. [11] K. Ohishi, K. Majima, T. Fukunaga and T. Miyazaki. Gait Control of a Biped Robot Based on Kinematics and Motion Description in Cartesian Space. 23 International Conference on Industrial Electronics, Control and Instrumentation (IECON 97) , pp 1317-1322. [12] S. Kajita and K. Tani. Experimental study of biped dynamic walking. IEEE Control Systems Magazine , 16(1):13–9, February 1996. [13] S. Kajita, T. Yamaura, and A. Kobayashi. Dynamic walking control of biped robot along a potential energy conserving orbit. IEEE Transactions on Robotics and Automation , 8(4):431–37, August 1992. [14] A. A. Grishin, A. M. Formal’sky, A. V. Lensky, and S. V. Zhitomirsky. Dynamical walking of a vehicle with two legs controlled by two drives. International Journal of Robotics Research , 13(2):137–47, 1994. [15] R. Katoh and M. Mori. Control method of biped locomotion giving asymptotic stability of trajectory. Automatica , 20(4):405–14, 1984. [16] J. Furusho and M. Masubuchi. Control of a dynamical biped locomotion system for steady walking. Journal of Dynamic Systems, Measurement and Control , 108:111–8, 1986. [17] S. Kajita, F. Kanehiro, K. Kaneko, K. Fijiware, K. Harada, K. Yokoi and H. Hirukawa. Biped Walking Pattern generation by using Preview Control of Zero-Moment Point. IEEE International Conference on Robotics & Automation, , pp 1620-1626. 2003. [18] Y. Hürmüzlü and D. B. Marghitu. Rigid body collisions of planar kinematic chains with multiple contact points. International Journal of Robotics Research , 13(1):82–92, 1994. [19] Zaldivar-Navarro, Daniel, 2006, “A Biped Robot Design”, PhD Thesis, FU Berlin, Fachbereich Mathematik u. Informatik, Freie Universität Berlin, available on-line http://www.diss.fu-berlin.de/2006/664/indexe.html. [20] Erik V. Cuevas, Daniel Zaldívar, and Raúl Rojas, Bipedal robot description, Technical Report B-03-19, Freie Universität Berlin, Fachbereich Mathematik und Informatik , Berlin, Germany, 2004. [21] Erbatur, K., Okazaki, A., Obiya, K., Takahashi, T., and Kawamura, A. A study on the zero moment point measurement for biped walking robots. 7th International Workshop on Advanced Motion Control, IEEE . (2002). [22] Qiang Huang, K. Yokoi, S. Kajita, K. Kaneko, H. Arai, N. Koyachi, K. Tanie, Planning walking patterns for a biped robot, IEEE Transactions on Robotics and Automation, 17 (2001) 280–289. [23] Duško Katić, Miomir Vukobratović, Survey of intelligent control techniques for humanoid robots, Journal of Intelligent and Robotic Systems 37 (2003) 117–141. [24] Erbatur, K., Okazaki, A., Obiya, K., Takahashi, T., and Kawamura, A.. A study on the zero moment point measurement for biped walking robots. 7th International Workshop on Advanced Motion Control, 2002 . [25] A. Yonemura, Y. Nakajima, A.R. Hirakawa, A. Kawamura, Experimental approach for the biped walking Please cite this article as: Cuevas, E., Zaldivar, D., Pérez-Cisneros, M., Ramírez-Ortegón, M. Polynomial trajectory algorithm for a biped robot, International Journal of Robotics and Automation 25 (4), (2010), pp. 294-303. - 25 - robot MARI-1, in: 6th InternationalWorkshop on Advanced Motion Control , March–April 2000, pp. 548–553. [26] E. Westervelt, J. Grizzle, C. Chevallerau, J Choi and B. Morris. Feedback Control of Dynamic Bipedal Robot Locomotion . CRC Press, NW, US, 2007. [27] B. Brogliato. Nonsmooth Impact Dynamics: Models, Dynamics and Control, volume 220 of Lecture Notes in Control and Information Sciences . Springer, London, 1996. [28] Y. Fujimoto and A. Kawamura. Simulation of an autonomous biped walking robot including environmental force interaction. IEEE Robotics and Automation Magazine , pages 33–42, June 1998. [29] A. Takanishi, M. Ishida, Y. Yamazaki & I. Kato, The realization of dynamic walking robot WL-10RD , in Proc. 1985 , Int. Conf. Advanced Robotics , 1985, 459-466. [30] K. Hiria, M Hirose, Y. Haikawa, & T.Takenaka, The development of Honda Humanoid robot, in IEEE Int. Conf. Rob. and Aut. , 1998, 1321-132. [31] M. Fedoryuk, Hermite polynomials, Encyclopaedia of Mathematics , Kluwer Academic Publishers, ISBN 978-155608010, 2001. [32] T. Popiel, On parametric smoothness of generalised B-spline curves, Computer Aided Geometric Design , Volume 23, Issue 8, November 2006, Pages 655-668. [33] K. Nishiwaki and S. Kagami, Online Walking Control for Humanoids with Short Cycle Pattern Generation, The international Journal of Robotics Research , 28 (2009) 729–742. [34] S. Bououden, F. Abdessemed and B. Abderraouf, Control of a Bipedal Walking Robot Using a Fuzzy Precompensator, Agent and Multi-Agent Systems: Technologies and Applications , A. Håkansson et. Al (Eds), Springer-Verlag, Berlin 2009. [35] C. Zeng, Y. Cheng, H. Liang, L. Dai and H. Liu, Research on the model of the inverted pendulum and its control based on biped robot, IEEE Pacific-Asia Workshop on Computational and Industrial Application , 2008. [36] J. Park, Fuzzy-logic zero moment point trajectory generation for reduced trunk motions of biped robots, Fuzzy Sets and Systems 134, (2003), 189-203. [37] S. Kajita, F. Kanehiro, K. Kaneko and K. Fujiwara, A real-time Pattern generation for a Biped Walking, International Conference on Robotics & Automation , 2002, Washington, DC. [38] http://www.tekscan.com/flexiforce/flexiforce.html