arXiv:1706.00339v1 [cs.RO] 1 Jun 2017 Bipedal locomotion using variable stiffness actuation Ludo C. Visser, Stefano Stramigioli, and Raffaella Carloni Abstract —Robust and energy-efficient bipedal locomotion in robotics is still a challenging topic. In order to address issues in this field, we can take inspiration from nature, by study- ing human locomotion. The Spring-Loaded Inverted Pendulum (SLIP) model has shown to be a good model for this purpose. However, the human musculoskeletal system enables us to actively modulate leg stiffness, for example when walking in rough terrain with irregular and unexpected height variations of the walking surface. This ability of varying leg stiffness is not considered in conventional SLIP-based models, and therefore this paper explores the potential role of active leg stiffness variation in bipedal locomotion. It is shown that the conceptual SLIP model can be iteratively extended to more closely resemble a realistic (i.e., non-ideal) walker, and that feedback control strategies can be designed that reproduce the SLIP behavior in these extended models. We show that these extended models realize a cost of transport comparable to human walking, which indicates that active leg stiffness variation plays an important role in human locomotion that was previously not captured by the SLIP model. The results of this study show that active leg stiffness adaptation is a promising approach for realizing more energy-efficient and robust bipedal walking robots. I. I NTRODUCTION Robust and energy-efficient bipedal locomotion in robotics is an interesting research topic with many open questions. In particular, on one side of the spectrum, robust bipedal robots are being developed, but without much consideration for energy efficiency [1]. On the other side of the spectrum, extremely efficient bipedal locomotion is being achieved by exploiting passive robot dynamics [2]. However, the gaits of such passive dynamic walkers lack robustness [3]. In contrast, human walking is both robust and energy efficient, and, therefore, a better understanding of human walking could aid the design of robots achieving similar performance levels. To develop this understanding, models have been proposed that capture the essential properties of human gaits. One remarkably simple model is the bipedal spring-loaded inverted pendulum (SLIP) model, proposed in [4]. Despite its simplicity, the model accurately reproduces the hip trajectory and ground reaction force profiles observed in human gaits. Furthermore, the model encodes a wide variety of gaits, ranging from slow walking to running [5]. It has been shown that the bipedal SLIP model can be used to generate reference gaits for a fully actuated bipedal robot [6], [7]. However, the human musculoskeletal system enables the leg stiffness to be varied continuously, in order to adapt to different gaits and terrains. These stiffness variations also play This work has been partly funded by the European Commission’s Seventh Framework Programme as part of the project VIACTORS under grant no. 231554. { l.c.visser, s.stramigioli, r.carloni } @utwente.nl, MIRA Institute, Faculty of Electrical Engineering, Mathematics and Computer Science, University of Twente, The Netherlands. a role in disturbance rejection, for example in uneven terrain with sudden and unexpected changes in the walking surface. Variable stiffness in the legs of the bipedal SLIP walker has been shown to increase energy efficiency [8], [9] and improve robustness [10], but continuous leg stiffness adaptation has not yet been considered. Recent advances in the field of variable stiffness actuators, a class of actuators that allow the actuator output stiffness to be changed independently from the actuator output position [11], are enabling the realization of robotic walkers with physically variable leg stiffness. There- fore, further research into bipedal walking with variable leg stiffness should be pursued, with the aim of getting closer to realizing bipedal walking robots with human-like performance characteristics. In this work, we explore modeling and control of bipedal walking with controllable leg stiffness. The aim of this work is to show that SLIP-like walking behavior can be embedded in more sophisticated models of bipedal walkers. This is achieved by the development of control strategies based on the principles of leg stiffness variation, inspired by the capa- bilities of the human musculoskeletal system. Starting from the conventional bipedal SLIP model, we iteratively extend this model, first by making the leg stiffness controllable, then by adding a swing leg and its dynamics, and then further by including a knee in the swing leg. In parallel, we derive a control strategy, which is extended with each model iteration. For each iteration, we show the stabilizing properties of the controller, demonstrating that the controller derived for the SLIP model in the first iteration is sufficiently robust to handle the increasingly complex dynamics in subsequent iterations. The final model and controller can serve as a template for bipedal robot control strategies. The paper is organized as follows. In Section II, we revisit the bipedal SLIP model, as presented in [4], and analyze its dynamics. Then, in Section III, we extend the bipedal SLIP model to have controllable stiffness (the V-SLIP model, for Variable SLIP), and derive a control strategy that renders a natural gait of the SLIP model asymptotically stable. In Section IV, the controlled V-SLIP model is extended to include feet, with the aim of introducing swing leg dynamics. The V- SLIP control strategy is extended to handle the extra degrees of freedom, and the stabilizing properties of the controller are demonstrated. The swing leg model is further refined in Section V by adding knees, with again further extension of the control strategy. A comparison of the models and their controllers is presented in Section VI, and Section VII concludes the paper with a discussion and final remarks. Conventions in Notation To avoid notational clutter, variable names will be reused for different models. However, this reuse is consistent, and q 1 q 2 m h k 0 k 0 c 2 c 1 Fig. 1. The bipedal SLIP model—The model consists of a point mass m h , located in the hip joint, i.e. where two massless telescopic springs, with a constant spring stiffness k 0 and rest length L 0 , are connected. The configuration variables ( q 1 , q 2 ) describe the position of the hip. variables with the same name indicate the same quantity in the various models. For example, q i denotes configuration variables, and p i denotes momentum variables, state vectors are named x , and f ( x ) and g i ( x ) are drift and input vector fields on the state manifold respectively. The Lie-derivative of a function h along a vector field X is denoted by L X h . Function arguments are omitted where this is considered possible. II. T HE B IPEDAL SLIP M ODEL In this Section, we revisit the bipedal SLIP model, as presented in [4]. The model is depicted in Figure 1. It consists of a point mass m h , located in the joint connecting the two legs, i.e. the hip joint. The legs consist of massless telescopic springs of stiffness k 0 and rest length L 0 . The configuration variables ( q 1 , q 2 ) =: q describe the planar position of the point mass, with ( p 1 , p 2 ) =: p the associated momentum variables. In the following, we derive the dynamic equations for this system, and analyze its dynamics. A. System Dynamics The bipedal SLIP model shows, for appropriately chosen initial conditions [4], [5], a passive walking gait as illustrated in Figure 2. In order to derive the dynamic equations that describe the gait of this model, two phases need to be considered: 1) two legs are in contact with the ground (i.e. the double support phase), and 2) one leg is in contact with the ground (i.e. the single support phase). Furthermore, we consider the parameter α 0 , which is the angle at which the massless leg touches down at the end of the single support phase, as indicated in Figure 2. The contact conditions are determined by the spring rest length L 0 and angle of attack α 0 , as shown in Figure 2. In particular, if the system is in the single support phase, the touchdown event of the trailing leg occurs when q 2 = L 0 sin( α 0 ) , (1) and at this moment the foot contact point c 2 is calculated as c 2 = q 1 + L 0 cos( α 0 ) . L 0 α 0 q ( t ) L 0 sin( α 0 ) SS DS SS DS SS Fig. 2. Passive gait of the bipedal SLIP model—The model alternates between single support ( SS ) and double support ( DS ) phases, depending on the hip height and the model parameters L 0 and α 0 . The gray shading will be used throughout this paper to indicate that the walker is in the double support phase. Conversely, when the system is in the double support phase, the transition to the single support phase occurs when either of the two springs reaches its rest length with non-zero speed, and thus loses contact with the ground, i.e. when √ ( q 1 − c i ) 2 + q 2 2 = L 0 , i = 1 , 2 . (2) In nominal conditions, only the trailing leg is allowed to lift off, after which the contact point c 2 is relabeled as c 1 to correspond to the notation used for the single support phase. In order to derive the dynamic equations, we define the kinetic energy function K = 1 2 p T M − 1 p , where M = diag( m h , m h ) (3) is the mass matrix and p := M ̇ q are the momentum variables. The potential energy function is defined as V = m h g 0 q 2 + 1 2 k 0 ( L 0 − L 1 ) 2 + 1 2 k 0 ( L 0 − L 2 ) 2 , where L i := √ ( q 1 − c i ) 2 + q 2 2 , and g 0 is the gravitational acceleration. During the single support phase, we set L 2 ≡ L 0 to eliminate the influence of this virtually swinging leg. The dynamic equations in Hamiltonian form are defined through the Hamiltonian energy function H = K + V and given by d d t [ q p ] = [ 0 I − I 0 ] [ ∂H ∂q ∂H ∂p ] . (4) From (4), it can be noted that the configuration variables q ( t ) are of class C 2 . This is due to the fact that the ∂V ∂q is not differentiable at the moment of phase transition. This is because the massless second leg does not have a zero rate of change of length at the moment of touchdown, i.e. d d t L 2 ∣ ∣ ∣ t = t + touchdown 6 = 0 , where t + touchdown indicates that the time-derivative is taken on the right of the discontinuity. It will be shown later that this has consequences for the controller design. q 1 q 2 m h k 0 + u 2 k 0 + u 1 c 2 c 1 Fig. 3. The V-SLIP model—In contrast to the bipedal SLIP model, the V- SLIP model has a controllable leg stiffness. This provides two control inputs during the double support phase, but only one control input during the single support phase, rendering the system underactuated. III. T HE C ONTROLLED V-SLIP M ODEL The passive bipedal SLIP model provides no control inputs, and therefore the only way to influence its behavior is by the choice of initial conditions. Therefore, it is proposed to extend the bipedal SLIP model to have massless telescopic springs with variable stiffness [12]. This bipedal V-SLIP (for Variable SLIP) model is depicted in Figure 3. The difference with respect to the bipedal SLIP model is that the leg stiffness now has a controllable part, i.e. k i = k 0 + u i , i = 1 , 2 . In this Section we give the dynamic equations for this system and present a stabilizing controller. A. System Dynamics In deriving the dynamics of the V-SLIP model, we assume that: • no slip or bouncing occurs in the foot contact points; • the springs are unilateral, meaning that we only allow them to be compressed; The autonomous part of the dynamics of the bipedal V-SLIP model is the same as for the bipedal SLIP model. To include the control inputs, (4) is extended, arriving at the dynamics for the V-SLIP model in port-Hamiltonian form: d d t [ q p ] = [ 0 I − I 0 ] [ ∂H ∂q ∂H ∂p ] + [ 0 B ] u y = [ 0 B T ] [ ∂H ∂q ∂H ∂p ] , (5) with u = ( u 1 , u 2 ) the controlled leg stiffness, and H is as defined in Section II-A. The input matrix B is given by B = [ ∂φ 1 ∂q 1 ∂φ 2 ∂q 1 ∂φ 1 ∂q 2 ∂φ 2 ∂q 2 ] , with φ 1 = − 1 2 ( L 0 − L 1 ) 2 and φ 2 = − 1 2 ( L 0 − L 2 ) 2 . The output y is dual to u , and it is readily verified that the dual product 〈 u | y 〉 has the units of power [13]. As in Section II-A, we set L 2 ≡ L 0 during the single support phase to eliminate the influence of the swing leg. It is emphasized that the control inputs u i , i = 1 , 2 are restricted, such that the total leg stiffness is physically meaningful, i.e. u i ∈ R | 0 < k 0 + u i < ∞ . (6) B. Controller Design The bipedal SLIP model already shows stable walking gaits, with a relatively large basin of attraction [5]. As shown in our previous work, it is possible to tune the spring stiffness k to further increase the robustness of the gait, while minimally modifying the natural dynamics of the walker [12]. The control strategy uses a natural gait of the bipedal SLIP model as reference, i.e. trajectories ( q ◦ ( t ) , ̇ q ◦ ( t )) that are a solution of (4), where ̇ q is defined as ̇ q = M − 1 p . However, the bipedal V-SLIP model is underactuated during the single support phase (since there is only one leg in contact with the ground), and thus it is not possible to track ( q ◦ ( t ) , ̇ q ◦ ( t )) exactly. To avoid that the walker lags behind the reference during the underactuated phase, we propose to instead de- fine a curve in the configuration space by parameterizing ( q ◦ ( t ) , ̇ q ◦ ( t )) by the horizontal position q 1 , similar to the approach presented in [14]. This is possible 1 as long as ̇ q 1 > 0 . Then, the desired reference gait can be equivalently described as ( q ∗ 2 ( q 1 ) , ̇ q ∗ 1 ( q 1 )) . The control objective is to have the hip trajectory converge to an arbitrary small neighborhood of this reference gait. In formulating the control strategy, we define the state x = ( q, p ) and rewrite (5) in standard form as ̇ x = f ( x ) + ∑ i g i ( x ) u i . (7) The following control strategy is proposed. Proposition 1: Given parameterized reference state trajec- tories ( q ∗ 2 , ̇ q ∗ 1 ) , define the error functions h 1 = q ∗ 2 − q 2 , h 2 = ̇ q ∗ 1 − ̇ q 1 . Then the following control strategy renders solutions of (5) asymptotically converging to ( q ∗ 2 , ̇ q ∗ 1 ) : • during the single support phase, u 1 = − 1 L g 1 L f h 1 ( L 2 f h 1 + κ d L f h 1 + κ p h 1 ) (8) and u 2 ≡ 0 ; • during the double support phase, when the leading leg length satisfies L 0 − L e ≤ L 1 < L 0 (i.e. just after the touchdown event), or when the trailing leg length satisfies L 0 − L e ≤ L 2 < L 0 (just before the lift-off event), for some small L e > 0 : [ u 1 u 2 ] = − A ♯ ( L 2 f h 1 + κ d L f h 1 + κ p h 1 ) , (9) with A = [ L g 1 L f h 1 L g 2 L f h 1 ] , 1 Exact parameterization is not possible, because q ( t ) is of class C 2 only, as outlined in Section II-A. Approximating ( q ◦ ( t ) , ̇ q ◦ ( t )) by finite Fourier series is an alternative that gives satisfactory results, as will be demonstrated. and with ♯ denoting the Moore-Penrose 2 pseudo inverse; • during the double support phase, when both leg lengths satisfy L i < L 0 − L e , [ u 1 u 2 ] = − A − 1 [ L 2 f h 1 + κ d L f h 1 + κ p h 1 L f h 2 + κ v h 2 ] , (10) with A = [ L g 1 L f h 1 L g 2 L f h 1 L g 1 h 2 L g 2 h 2 ] . For any arbitrary small ε > 0 , there exist constants κ p , κ d , κ v > 0 for the control strategy (8) , (9) , (10) such that: lim t →∞ q ∗ 2 ( q 1 ( t )) − q 2 ( t ) = 0 and lim t →∞ | ̇ q ∗ 1 ( q 1 ( t )) − ̇ q 1 ( t ) | < ε. Remark 1: The control input (9) is introduced, because the system (5) is no longer controllable when one of the legs reaches its rest length L 0 . As such, the transition domain defined by L e is necessary to comply with (6). ⊳ Remark 2: As observed in Section II-A, the state trajectories q ( t ) are of class C 2 only, and therefore it is not possible to make the leg stiffness a state of the system, because higher order Lie-derivatives do not exist. ⊳ Remark 3: The control inputs, as given by Proposition 1, renders solutions of (5) asymptotically converging to ( q ∗ 2 , ̇ q ∗ 1 ) , which are parametrized by the horizontal position q 1 . Since q 1 is strictly monotonically increasing, the control inputs asymptotically stabilize the system (5). ⊳ Proof 1: It is straightforward to show that, during the single support phase, L g 1 L f h 1 in (8) is bounded away from zero if 0 < L 1 < L 0 . Similarly, during the double support phase, the matrix A in (10) is invertible if 0 < L i < L 0 , i = 1 , 2 and in addition c 1 6 = c 2 . These conditions are met through the definition of the phase transitions (1) and (2) . During the double support phase, (10) renders the system strongly input-output decoupled, i.e. h i is invariant under u j for i 6 = j [15]. Therefore, and by (8) , (9) , during both the single and double support phases the error dynamics h 1 ( t ) are described by ̈ h 1 + κ d ̇ h 1 + κ p = 0 . If κ p , κ d are chosen such that the zeros of the characteristic polynomial are in the open left half-plane, then the dynamics of h 1 are asymptotically stable during each phase. The error function h 1 depends on the configuration q only, and q ( t ) is continuous and differentiable across the phase transitions. Therefore, lim t →∞ q ∗ 2 ( q 1 ( t )) − q 2 ( t ) = 0 will be achieved. The dynamics of the error function h 2 are, during the double support phase, described by ̇ h 2 + κ v h 2 = 0 , which has as analytic solution h 2 ( t ) = e − κ v ( t − t ds ) h 2 ( t ds ) , t ≥ t ds , 2 Since we are addressing a numerical issue, we are not concerned about deriving a proper invariant metric for defining the pseudo-inverse. Instead, we use the Euclidian metric. TABLE I C ONTROLLED V-SLIP MODEL PARAMETER VALUES . Parameter Value Unit Description m h 15 . 0 kg Hip mass L 0 1 . 0 m Spring rest length L e 0 . 01 m Phase transition margin α 0 62 . 5 ◦ Angle of attack k 0 2000 N/m Nominal leg stiffness k min 0 N/m Lower bound on leg stiffness k max 10000 N/m Upper bound on leg stiffness κ p 350 Control parameter κ d 40 Control parameter κ v 15 Control parameter where t ds is the time instant of the last touchdown event. For any κ v > 0 , h 2 ( t ) is asymptotically stable during the double support phase. However, during the single support phase, the dynamics of h 2 ( t ) are uncontrolled. During this phase, the control action of u 1 will result in a change of kinetic energy with respect to the constant energy level of the SLIP reference gait. Since u 1 is bounded, as defined in (6) , the total increase in kinetic energy is also bounded. Let ∆ E ss denote the increase of energy during the single support phase due to u 1 . There exists a constant C 1 such that | ∆ E | < C 1 , which implies, since h 2 ( t ) is a function of the momentum variable p 2 , that | h 2 ( t ds ) | < C 2 < C 1 . This in turn implies that there exists κ v < ∞ that brings h 2 ( t ) in a neighborhood ε of zero within the duration of the double support phase. With the parameters as listed in Table I, a numeric sim- ulation has been carried out using the PyDSTool software package [16]. The reference ( q ∗ 2 , ̇ q ∗ 1 ) has been obtained by searching for a limit cycle of the uncontrolled SLIP model with the same parameters. As shown in Figure 4, the controller indeed achieves the converges as claimed in Proposition 1. The error h 2 is never exactly zero, because the solutions to (4) are not analytical. Therefore the parameterized reference is not an exact representation of the natural dynamics, yielding the mismatch in h 2 during the single support phase. IV. T HE C ONTROLLED V-SLIP M ODEL WITH S WING L EG D YNAMICS While the bipedal (V-)SLIP models do accurately reproduce hip trajectories observed in human walking, and thus can give insights in human walking performance, the models are con- ceptual. In particular, all mass is assumed to be concentrated in a single point mass at the hip, and the legs are assumed to be massless springs—assumptions that cannot be considered valid for a robotic system. In this Section we extend the V-SLIP model to incorporate swing leg dynamics. This is done by adding a foot mass, as shown in Figure 5 [17]. During the swing phase, the leg is assumed to have a fixed length L 0 , while during the stance phase it is again assumed to be a massless spring connecting -0.01 0.00 0.01 h 1 25 26 27 28 29 30 Time [s] -0.01 0.00 0.01 h 2 Fig. 4. Steady-state error functions for the controlled V-SLIP model—It can be seen that for the control parameters listed in Table I the error functions converge like claimed in Proposition 1. q 1 q 2 q 3 m h m f m f k 0 + u 1 L 0 τ Fig. 5. The V-SLIP model with feet—By adding feet masses m f to the V- SLIP model, swing leg dynamics are introduced. The swing leg is assumed to be constraint at a length L 0 during swing, and the stance foot is assumed to be fixed to the ground, i.e. no slip or bouncing in the contact point. the foot and the hip masses. In this Section we derive the dynamic equations that govern the system behavior, and extend the controller from Section III-B to handle the swing leg dynamics. A. System Dynamics In deriving the dynamics of the V-SLIP model with feet, we assume that: • no slip or bouncing occurs in the foot contact points; • the springs are unilateral, meaning that we only allow them to be compressed; • during the single support phase, the swing leg is con- straint to have length L 0 . Under these assumptions, during the double support phase, we can use the double support phase model used in Section III-A, and the model behavior is described accordingly by (5). During the single support phase, the model can be simplified as shown in Figure 6. The configuration of the system can be described by ( q 1 , q 2 , q 3 ) , where q 3 ∈ [0 , π ) is the orientation of the swing leg. The total mass of the swing leg is m = m h + m f . Since the swing leg is assumed to be a rigid link of length L 0 , its center of mass is at a distance d com = m f L 0 m h + m f q 1 q 2 q 3 m, J com k 0 + u 1 L 0 d com τ c 1 Fig. 6. Model simplification—Under the assumptions of a rigid swing leg and no slip or bouncing in the foot contact point, the model depicted in Figure 5 can be simplified during the single support phase. During the double support phase, the model is reduced to the V-SLIP model, as shown in Figure 3. from the hip joint (as indicated in Figure 6). The moment of inertia of the leg around its center of mass is given by J com = m h d 2 com + m f ( L 0 − d com ) 2 . In order to derive the dynamic equations of the system for the single support phase, we let ( v 1 , v 2 , v 3 ) =: v denote the horizontal, vertical and rotational velocity of the (center of mass of the) swing leg. These velocities are related to the rate of change of the configuration variables ̇ q by the Jacobian matrix S ( q ) , defined as: S ( q ) =   1 0 d com sin( q 3 ) 0 1 − d com cos( q 3 ) 0 0 1   , (11) such that v = S ( q ) ̇ q . This allows to have the configuration variables q coincide with those used in the V-SLIP model of Section III. In particular, by defining p := M v , with M = diag( m h + m f , m h + m f , J com ) (12) the mass matrix of the rigid body representing swing leg, the dynamics during the single support phase can be derived in terms of ( q, p ) as follows. The kinetic energy is given by K = 1 2 p T M − 1 p , and we derive the potential energy function V as V = ( m h + m f ) g 0 ( q 2 − d com sin( q 3 )) + 1 2 k 0 ( L 0 − L 1 ) 2 . Then, the Hamiltonian energy function is given by H = K + V , and we derive the dynamic equations in port-Hamiltonian form by using the Boltzmann-Hamel equations [18], yielding: d d t [ q p ] = J [ ∂H ∂q ∂H ∂p ] + [ 0 B ] u y = [ 0 B T ] [ ∂H ∂q ∂H ∂p ] , (13) where the skew-symmetric matrix J is given by J = [ 0 S − 1 − S − T S − T ( ∂ T ( S T p ) ∂q − ∂ ( S T p ) ∂q ) S − 1 ] . Again, the output y is dual to the input u , so that 〈 u | y 〉 defines a power flow. The control input u = ( u 1 , τ ) , i.e. the controllable part of the stance leg stiffness, and the torque applied to the swing leg. The input matrix B is given by B = S − T    ∂φ 1 ∂q 1 0 ∂φ 1 ∂q 2 0 0 1    , with φ 1 = − 1 2 ( L 0 − L 1 ) 2 . The mapping by S − T is necessary because the inputs are not collocated with v , but with ̇ q , as can be seen in Figure 6. B. Phase Transitions Unlike the V-SLIP model, where in both the double and single support phases the same configuration variables are used, this model uses two sets of configuration variables: in the double support phase only the position of the hip with respect to the foot contact points is relevant, while in the single support phase also the swing leg orientation is required. Therefore, phase transition mappings need to be defined as follows. Transition Conditions: Similar to the (V-)SLIP models, the touchdown event occurs when the foot of the swing leg has passed in front of the hip, 3 and in addition, recalling that the swing leg is constraint to have length L 0 during the swing phase, q 2 = L 0 sin( q 3 ) . At the time instance that both of these conditions are met, the new foot contact point c 2 is computed as c 2 = q 1 − L 0 cos( q 3 ) . The lift-off event occurs when the trailing leg reaches its rest length L 0 with non-zero speed, since we do not allow the springs to pull. 4 Momentum Variable Mapping: To complete the phase tran- sitions, the momentum variables of the double support phase need to be mapped to the momentum variables for the single support phase and vice versa. This mapping also needs to ensure that the constraints on the foot contact points are maintained. In particular, upon touchdown, the foot of the former swing leg needs to be instantaneously constraint to fulfill the no-slip condition. This can be realized by applying a momentum reset at the instant of touchdown [19]. It was shown in our previous work that, despite the energy loss associated with the impact, energy-efficient locomotion can be realized [17]. However, in this work, we will focus on the added benefit of the compliant legs, and thus assume a compliant impact. This implies that, upon impact, the foot mass m f will instantaneously dissipate its kinetic energy, while the hip mass m h remains unaffected by the impact due to the compliant leg. 3 Essentially the swing leg is allowed to swing through the floor. This will be addressed in the next model iteration in Section V. 4 To be accurate, the transition occurs when the foot starts to accelerate away from the floor. However, this is practically equivalent to assuming that the transition occurs at the moment the spring length becomes equal to its rest length and assuming that the leg instantly becomes rigid at the same moment. To map the momentum variables between the phases, we need to account for the disappearing and reappearing of the foot mass. For this purpose, we define new coordinates z 1 = ( q 1 , q 2 , q 3 ) and z 2 = ( q 1 , q 2 , c i ) , where c i denotes the contact point that is subject to change due to the transition. During both the touchdown and the lift-off event, the leg length is assumed to be L 0 , so that we obtain z 2 ( z 1 ) =   q 1 q 2 q 1 − L 0 cos( q 3 )   . We define the Jacobian matrix Z := ∂z 2 /∂z 1 accordingly. For the transition from single support to double support, using the subscripts “old” and “new” for post- and pre- transition values, we have: ̇ z 2 , new = Z ̇ z 1 , old , where ̇ z 1 , old is defined by the momentum variables p old just before the phase transition: ̇ z 1 , old = S − 1 ( q ) M − 1 ss p old , with S ( q ) defined in (11) and M ss the mass matrix defined in (12). Note that the expression for ̇ c 2 is irrelevant in this phase transition, since we assume that the foot is instantly constraint. The post-transition momentum variables for the double support phase p new are then given by p new = M ds [ ̇ q 1 ̇ q 2 ] ︸ ︷︷ ︸ ∈ ̇ z 2 , new , with M ds the mass matrix defined in (3). Similarly, for the transition from double support to single support, we have ̇ z 1 , new = Z − 1 ̇ z 2 , old , where ̇ z 2 , old is defined through the momentum variables p old just before the phase transition: ̇ z 2 , old = M − 1 ds p old , with M ds the mass matrix defined in (3), and setting ̇ c 1 = 0 , since the foot is stationary at the moment of lift-off. The post- transition momentum variables p new for the single support phase are then calculated as p new = M ss S ( q ) ̇ z 1 , new , with S ( q ) defined in (11). C. Controller Design During the double support phase, the model is equivalent to the V-SLIP model, and therefore, during this phase, the control strategy proposed in Proposition 1 can be used. For the single support phase, the control strategy has to be extended to regulate the swing leg trajectory q 3 ( t ) . For this purpose, we define a reference trajectory q ∗ 3 ( t ) as a polynomial: q ∗ 3 ( t ) = 5 ∑ i =0 a i ( t − t lo ) i , t lo ≤ t < t lo + T swing , where T swing is the desired swing time, e.g. obtained from the nominal single support phase time of the SLIP model reference gait, and t lo is the time instant of the last lift-off event. The coefficients a i are such that q ∗ 3 ( t ) is a minimum-jerk trajectory with boundary conditions 5   q ∗ 3 ( t lo ) ̇ q ∗ 3 ( t lo ) ̈ q ∗ 3 ( t lo )   =   q 3 ( t lo ) 0 0   and   q ∗ 3 ( t lo + T swing ) ̇ q ∗ 3 ( t lo + T swing ) ̈ q ∗ 3 ( t lo + T swing )   =   π − α 0 0 0   . In formulating the control strategy, we will define for both the double support and single support phases a state vector of the form x = ( q, p ) and write the respective differential equations (5) and (13) in the standard form (7). The following control strategy is proposed, extending the V-SLIP control strategy formulated in Proposition 1. Proposition 2: Given reference state trajectories ( q ∗ 2 , ̇ q ∗ 1 , q ∗ 3 ) , define the error functions h 1 = q ∗ 2 − q 2 , h 2 = ̇ q ∗ 1 − ̇ q 1 , h 3 = q ∗ 3 − q 3 . During the double support phase, the corresponding control strategy formulated in Proposition 1 renders solutions of (5) asymptotically converging to ( q ∗ 2 , ̇ q ∗ 1 ) . During the single support phase, the following control strategy renders solutions of (13) asymptotically converging to ( q ∗ 2 , q ∗ 3 ) : [ u 1 τ ] = − A − 1 [ L 2 f h 1 + κ d L f h 1 + κ p h 1 L 2 f h 3 + κ w L f h 3 + κ a h 3 ] , (14) with A = [ L g 1 L f h 1 L g 2 L f h 1 L g 1 L f h 3 L g 2 L f h 3 ] . For any arbitrary small ε 1 , ε 2 , δ > 0 , there exist constants κ p , κ d , κ v , κ a , κ w > 0 for the control strategy (9) , (10) , (14) such that lim t →∞ | q ∗ 2 ( t ) − q 2 ( t ) | < ε 1 , and lim t →∞ | ̇ q ∗ 1 ( t ) − ̇ q 1 ( t ) | < ε 2 , and, during t lo ≤ t < t lo + T swing , | q ∗ 3 ( t lo + T swing ) − q 3 ( t lo + T swing ) | < δ. Proof 2: The control strategy is such that the system is strongly input-output decoupled. Therefore, the dynamics of h 1 ( t ) are given by ̈ h 1 + κ d ̇ h 1 + κ p h 1 = e 1 , where e 1 ( t ) is a disturbance due to the phase transitions. As a result, q 2 ( t ) is continuous, but not differentiable. However, 5 The velocity ̇ q 3 ( t lo ) and the acceleration ̈ q 3 ( t lo ) are not matched by the reference trajectory q ∗ 3 ( t ) , because these quantities are in practice very difficult to measure accurately. -0.01 0.00 0.01 h 1 -0.20 0.00 0.20 0.40 0.60 0.80 1.00 h 2 25 26 27 28 29 30 Time [s] -0.05 0.00 0.05 0.10 0.15 0.20 h 3 Fig. 7. Steady-state error functions for the controlled V-SLIP model with swing leg—It can be seen that the error functions converge like claimed in Proposition 2. Note that h 3 ≡ 0 during the double support phase. e 1 ( t ) is bounded and impulsive, and therefore there exists con- stants κ p , κ d > 0 such that h 2 ( t ) converges to a neighborhood ε 1 of zero. Similarly, the dynamics dynamics of h 2 ( t ) are given by ̇ h 2 + κ v h 2 = e 2 , where e 2 ( t ) is also a disturbance due to the phase transitions. As a result of these disturbances, ̇ q 1 ( t ) is not continuous. However, since e 2 ( t ) is bounded and impulsive, there exist a κ v > 0 such that h 2 ( t ) converges to a neighborhood ε 2 of zero. During the single support phase, the dynamics h 3 ( t ) are given by ̈ h 3 + κ w ̇ h 3 + κ a h 3 = 0 . For suitably chosen constant κ a , κ w > 0 , such that the zero are in the open left half-plane, the error function h 3 ( t ) converges to a neighborhood δ of zero in finite time. The proposed control strategy has been validated through numeric simulations. The same parameters were used as for the V-SLIP model as listed in Table I, and m f = 2 . 5 kg. Furthermore, κ a = 1000 and κ w = 40 . It can be observed that the error functions converge as claimed in Proposition 2. In particular, the influence of the swing leg can be clearly observed when the plots are compared to Figure 4. Specif- ically, we can see the influence of the swing leg motion in the error function h 1 at the onset of the single support phases (the unshaded areas of the plot). The error function h 2 also shows a significant increase in amplitude during the swing. We can also observe in h 2 the lift-off of the swing leg in the form of discontinuities at the moment of transition from the double support phase (shaded areas) to the single support phase (unshaded areas). The error function h 3 shows that the swing leg motion is controlled as claimed by the proposed q 1 q 2 θ 1 θ 2 m h m f m f k 0 + u 1 τ ℓ ℓ Fig. 8. The V-SLIP model with feet and knees—By adding an actuated knee joint to the model of Section IV, the leg can be retracted during the single support phase. This allows the leg to swing forward without scuffing the ground. It is assumed that no slip or bouncing occurs in the foot contact point of the stance leg. control law. Note that the degree of freedom q 3 is not defined during the double support phase, and therefore h 3 ≡ 0 during this phase. V. T HE C ONTROLLED V-SLIP MODEL WITH R ETRACTING S WING L EG D YNAMICS In this Section, we further refine the model presented in Section IV by adding a knee, as shown in Figure 8. This allows the swing leg to be retracted, so that it can be swung forward without scuffing the ground. We derive in this Section the dynamic equations for this model, and further extend the controller. A. System Dynamics Similar to the model presented in Section IV, we will assume that: • no slip or bouncing occurs in the foot contact points; • the spring are unilateral. These assumptions allow to again use the double support phase model used in Section III-A. To avoid notational clutter due to goniometric relations, the simplified model depicted in Figure 9 is used. The simplifi- cation is possible, because the introduction of the knee joint introduces only a kinematic relation between the hip mass and the foot mass, since these are located at the extremities of the swing leg. In deriving the dynamic equations for the single support phase of this model, we define new coordinates as z 1 = ( q 1 , q 2 , q 3 , q 4 ) and z 2 = ( q 1 , q 2 , s 1 , s 2 ) (15) where s 1 = q 1 − q 4 cos( q 3 ) , s 2 = q 2 − q 4 sin( q 3 ) , (16) i.e. the position of the foot of the swing leg. We furthermore define the tangent map Z = ∂z 2 /∂z 1 . Using this relation and q 1 q 2 q 3 q 4 , τ 2 τ 1 m h m f k 0 + u 1 c 1 Fig. 9. Model simplification—The configuration of the swing leg can be equivalently described by a linear degree of freedom q 4 , corresponding to the distance between the hip and the foot, and the orientation q 3 , analogous to the model of Figure 5. During the double support phase, the model is reduced to the V-SLIP model, as shown in Figure 3. noting that z 1 = q and thus that ̇ z 2 = Z ̇ q , we can derive the mass matrix M ( q ) from the energy equality 1 2 ̇ q T M ( q ) ̇ q = 1 2 ̇ z T 2 M 0 ̇ z 2 = 1 2 ̇ q T Z T M 0 Z ̇ q, (17) with M 0 = diag( m h , m h , m f , m f ) . By defining the momentum variables p := M ( q ) ̇ q , the kinetic energy K = 1 2 p T M − 1 ( q ) p , and the potential energy function V is found to be: V = m h g 0 q 2 + m f g 0 ( q 2 − q 4 sin( q 3 )) + 1 2 k 0 ( L 0 − L 1 ) 2 . Then, the Hamiltonian energy function H = K + V and the dynamic equations in port-Hamiltonian form are given by d d t [ q p ] = [ 0 I − I 0 ] [ ∂H ∂q ∂H ∂p ] + [ 0 B ] u y = [ 0 B T ] [ ∂H ∂q ∂H ∂p ] , (18) where u = ( u 1 , τ 1 , τ 2 ) , i.e. the controllable parts of the stance leg stiffness, and the torques collocated with q 3 and q 4 . The input matrix B is given by B =      ∂φ 1 ∂q 1 0 0 ∂φ 1 ∂q 2 0 0 0 1 0 0 0 1      , with φ 1 = − 1 2 ( L 0 − L 1 ) 2 . B. Phase Transitions Just as in the model described in Section IV, also in this model we need to consider the different sets of configuration variables in the single and double support phases. Therefore, in the following the phase transition mappings are defined. Transition Conditions: The touchdown event occurs when the swing leg foot hits the ground, i.e. when, using (16), q 2 = q 4 sin( q 3 ) . At this time instant, the new foot contact point c 2 (see Figure 3) is computed as c 2 = q 1 − q 4 cos( q 3 ) . The lift-off event is defined the same as in Section IV-B, since both models are reduced to the V-SLIP model during the double support phase. Momentum variable mapping: Similarly to the approach taken in Section IV-B, we start from the new set of coordinates defined in (15) and the corresponding Jacobian matrix Z . Thus, for the transition from single support to double support: ̇ z 2 , new = Z ̇ z 1 , old , where ̇ z 1 , old is defined by the pre-transition momentum vari- ables p old through ̇ z 1 , old = M − 1 ss p old . Here, M ss is the mass matrix defined in (17). As in Sec- tion IV-A, the post-transition momentum variables for the double support phase p new are given by p new = M ds [ ̇ q 1 ̇ q 2 ] ︸ ︷︷ ︸ ∈ ̇ z 2 , new , with M ds the mass matrix defined in (3). For the transition from double support to single support, we again have ̇ z 1 , new = Z − 1 ̇ z 2 , old , where ̇ z 2 , old is defined through the momentum variables p old just before the phase transition: ̇ z 2 , old = M − 1 ds p old , with M ds the mass matrix defined in (3), and setting ̇ s 1 = ̇ s 2 = 0 , since the foot is stationary at the moment of lift-off. The post-transition momentum variables p new for the single support phase are then calculated as p new = M ss ̇ z 1 , new . C. Controller Design During the double support phase, the control strategy pro- posed in Proposition 1 can again be used because of the model correspondence during this phase. For the single support phase, the control strategy has to be extended with respect to the control strategy presented in Proposition 2. In particular, in addition to the control of the swing leg orientation, the swing leg length has to be regulated as well. For this purpose, we define a reference trajectory q ∗ 4 ( t ) of the form q ∗ 4 ( t ) = b 0 + b 1 t + b 2 t 2 , t lo ≤ t ≤ t lo + T swing . The coefficients b i are such that the trajectory q ∗ 4 ( t ) satisfies the following conditions:   q ∗ 4 ( t lo ) q ∗ 4 ( t lo + 1 2 T swing ) q ∗ 4 ( t lo + T swing )   =   q 4 ( t lo ) L 0 − ∆ L 0   , with ∆ > 0 the amount of retraction of the swing leg. This trajectory ensures that at the moment of lift-off the swing leg is immediately accelerating away from the floor, reaching the maximum retraction during the predicted mid-stance. At touchdown, the swing leg will have length L 0 , corresponding to the (V-)SLIP model. Defining the state vector of the form x = ( q, p ) and writing (5) and (18) in the standard form (7), the following control strategy is proposed, extending the strategy formulated in Proposition 2. Proposition 3: Given reference state trajectories ( q ∗ 2 , ̇ q ∗ 1 , q ∗ 3 , q ∗ 4 ) , define the error functions h 1 = q ∗ 2 − q 2 , h 2 = ̇ q ∗ 1 − ̇ q 1 , h 3 = q ∗ 3 − q 3 , h 4 = q ∗ 4 − q 4 . During the double support phase, the corresponding control strategy formulated in Proposition 1 renders solutions of (5) asymptotically converging to ( q ∗ 2 , ̇ q ∗ 1 ) . During the single support phase, the following control strategy renders solutions of (18) asymptotically converging to ( q ∗ 2 , q ∗ 3 , q ∗ 4 ) : [ u 1 τ ] = − A − 1   L 2 f h 1 + κ d L f h 1 + κ p h 1 L 2 f h 3 + κ w L f h 3 + κ a h 3 L 2 f h 4 + κ n L f h 4 + κ ℓ h 4   , (19) with A =   L g 1 L f h 1 L g 2 L f h 1 L g 3 L f h 1 L g 1 L f h 3 L g 2 L f h 3 L g 3 L f h 3 L g 1 L f h 4 L g 2 L f h 4 L g 3 L f h 4   . For any arbitrary small ε 1 , ε 2 , δ 1 , δ 2 > 0 , there exist con- stants κ p , κ d , κ v , κ a , κ w , κ ℓ , κ n > 0 for the control strategy (9) , (10) , (19) such that lim t →∞ | q ∗ 2 ( t ) − q 2 ( t ) | < ε 1 , and lim t →∞ | ̇ q ∗ 1 ( t ) − ̇ q 1 ( t ) | < ε 2 , and, during t lo ≤ t < t lo + T swing , | q ∗ 3 ( t lo + T swing ) − q 3 ( t lo + T swing ) | < δ 1 | q ∗ 4 ( t lo + T swing ) − q 4 ( t lo + T swing ) | < δ 2 The proof is analogous to the proof given in Section IV-C and is omitted for brevity. The control strategy is validated through numeric simulations, with the same model parameters as used in Section IV-C, and in addition κ ℓ = 1000 and κ n = 40 , with a leg retraction ∆ = 7 . 5 cm. The resulting error function plots are shown in Figure 10, and it can be seen that they converge as claimed in Proposition 3. The error functions show now significantly bigger influences of the swing leg dynamics when compared to Figure 7. -0.01 0.00 0.01 h 1 -0.20 0.00 0.20 0.40 0.60 0.80 1.00 h 2 -0.05 0.00 0.05 0.10 0.15 0.20 h 3 25 26 27 28 29 30 Time [s] -0.06 -0.04 -0.02 0.00 0.02 h 4 Fig. 10. Steady-state error functions for the controlled V-SLIP model with leg retraction—It can be seen that the error functions converge like claimed in Proposition 3. Note that h 3 ≡ 0 and h 4 ≡ 0 during the double support phase. VI. C OMPARISON BY N UMERICAL S IMULATION Starting from the bipedal SLIP model, three iterations of model refinement have been presented in Section III, Sec- tion IV, and Section V. Also, in the first iteration, a robust controller for leg stiffness has been presented in Section III-B, which has been extended in subsequent iterations. In this section, a comparison of the performance of these controllers is presented. A. Comparison of Gait Control Figure 11 shows the horizontal hip trajectory q 1 ( t ) , and a detail of the corresponding vertical hip trajectory q 2 ( t ) . The most notable difference between the three models is their average forward velocity, which is 1 . 18 m/s for the V- SLIP model, but only 1 . 01 m/s and 0 . 64 m/s for the models including the swing leg dynamics and the knee. Looking at the hip trajectories, it can be seen that this is due to the inclusion of the swing leg dynamics, which introduces a lag in forward motion with respect to the V-SLIP dynamics. The leg stiffness trajectories k i = k 0 + u i are shown in Figure 12. Since the reference trajectory is the natural gait of the bipedal SLIP model, it is not surprising that the V- SLIP model requires very little control action to track the 0 5 10 15 20 25 30 Time [s] 0.00 10.00 20.00 30.00 40.00 q 1 [m] V-SLIP + swing leg + retraction 25 26 27 28 29 30 Time [s] 0.84 0.86 0.88 0.90 0.92 0.94 0.96 0.98 q 2 [m] Fig. 11. Hip trajectories q 1 ( t ) and q 2 ( t ) —It can be observed that swinging and retracting the leg has a negative influence on the forward velocity. This influence is particularly apparent in the vertical hip position trajectories. 0 1000 2000 3000 4000 5000 6000 7000 k 0 + u 1 [N/m] 25 26 27 28 29 30 Time [s] 0 1000 2000 3000 4000 5000 6000 7000 k 0 + u 2 [N/m] Fig. 12. Control inputs—See Figure 11 for the legend. The controlled V-SLIP model hardly requires any control input to track the reference, which is by design of the control strategy. Adding the swing leg and retracting introduces a significant disturbance in the dynamics, and thus more control input. Note that u 2 ≡ 0 during the single support phase. reference. The small amount that is required is due to the small mismatch between the parameterized reference trajectory and the true dynamics, as pointed out already in Section III-B. The introduction of the swing leg dynamics introduces a significant disturbance to the V-SLIP dynamics, exemplified by the larger magnitude of the control inputs. It is interesting to note that the V-SLIP model with swing leg, as introduced in Section IV, requires an impulse-like control input during the single support phase to counter the acceleration and deceleration of the swing leg. In contrast, including the leg retraction (Section V) results in a smaller moment of inertia, resulting in a smoother control. However, it is noted that the swing leg retraction does result in larger deceleration of the hip, which manifests itself in larger control inputs during the double support phase (bottom plot), actually reaching the lower bound of zero leg stiffness k 2 = k 0 + u 2 for short periods of time. B. Energy Balance The natural gait of the bipedal SLIP model is associated to a constant energy level [4], [5]. Since the V-SLIP model presented in Section III matches the bipedal SLIP model, its energy balance is the same if the reference trajectory for the V- SLIP controller exactly matches the solutions of (4). However, 25 26 27 28 29 30 Time [s] 0 20 40 60 80 100 120 140 160 180 Energy [J] Total energy Kinetic energy Potential energy Elastic energy Fig. 13. Energy balance for the controlled V-SLIP model with swing leg—The dashed line indicates the constant energy level of the bipedal SLIP model. The influence of the swing leg is clearly seen in the bulges in the kinetic energy. 25 26 27 28 29 30 Time [s] 0 20 40 60 80 100 120 140 160 180 Energy [J] Total energy Kinetic energy Potential energy Elastic energy Fig. 14. Energy balance for the controlled V-SLIP model with leg retraction— The dashed line indicates the constant energy level of the bipedal SLIP model. Also here the influence of swinging and retracting the swing leg is clearly seen. as already noted before, the solutions of (4) are not analytical, and therefore a small mismatch between the natural dynamics of the V-SLIP model and the reference is inevitable, resulting in small control action even in nominal conditions, as shown in Figure 12. The energy balance for the model including the swing leg (Section IV) is presented in Figure 13. It can be seen that the introduction of the swing leg dynamics introduces a significant deviation of the constant energy level of the bipedal SLIP model, indicated by the dashed line. The bulges in the kinetic energy plot clearly show the accelerating and the decelerating of the swing leg. The energy balance for the swing leg model with leg retraction (Section V) is shown in Figure 14. It clearly shows that the leg retraction further slows down the system, as exemplified by the lower total energy level when compared to Figure 13. However, it is also noted that the bulges observed in Figure 13 have been reduced in amplitude in Figure 14. This is because the leg retraction results in a lower swing leg inertia, mitigating the influence of the swing of the leg. Both Figure 13 and Figure 14 show relatively small varia- tions in the total energy level. This signifies that only small amounts of energy are exchanged with the environment and via the control action. C. Cost of Transport Cost of transport (also known as specific resistance) is a measure of energy efficiency, as it measures the energy that a system uses to travel a specified distance [20], [21]. Using the definition proposed in [21], the cost of transport is obtained by exploiting the port-Hamiltonian formulation of the dynamic equations (5), (13), (18): C = 1 m total g 0 ∆ x ∫ T |〈 u | y 〉| d t, (20) where m total denotes the total mass and ∆ x the distance traveled during the time T . The cost C captures the amount of energy required for walking the distance ∆ x , taking into account that, in general, actuators dissipate energy when negative work is done, rather than storing it. Using (20), we find C = 3 · 10 − 3 for the controlled V-SLIP model. The cost is not exactly zero due to the aforementioned mismatch between the reference trajectory and the true natural dynamics: if the reference had been exact, we would have C ≡ 0 . For the model with swing leg (Section IV), we obtain C = 0 . 32 . For the model with the retracting swing leg (Section V), we obtain C = 0 . 34 . While Figure 14 hinted to lower energy expenditure when compared to Figure 13, this gain in efficiency is offset by the lower average velocity. The cost of transport C = 0 . 34 is in the same range as of human walking [20], and thus the proposed control strategy allows for a theoretical performance that s approaches that of human walking. VII. C ONCLUSIONS In this paper, we started from the bipedal SLIP model, and showed how active leg stiffness variation can render gaits of this model more robust. In particular, it was shown that the model could be extended to include swing leg dynamics, while still embedding the SLIP-like walking behavior by employing feedback control strategies. These control strategies are inspired by the capabilities of the human musculoskeletal capability of varying leg stiffness. It was shown that this ap- proach yields a theoretical cost of transport that is comparable to human performance. This shows that active leg stiffness variation can be an important concept in human walking, which has not yet been transferred to the domain of realizing performant robotic walkers. The starting point for the analysis presented in this work was the bipedal SLIP model, extended by variable leg stiffness to provide control inputs. Subsequent modeling iterations extended the model to include full swing leg dynamics, while at the same time the control strategy was extended to handle the refined models. The final result is a template model of a bipedal walker, based on the principles of the bipedal SLIP model, and a stabilizing controller that realizes an energetic performance level comparable to human walking. This model plus controller can serve as a basis for control of bipedal robots. R EFERENCES [1] Boston Dynamics, “PETMAN - BigDog gets a big brother,” online: http://www.bostondynamics.com/robot petman.html, 2011. [2] S. Collins, A. Ruina, R. Tedrake, and M. Wisse, “Efficient bipedal robots based on passive-dynamic walkers,” Science , vol. 307, no. 5712, pp. 1082–1085, 2005. [3] A. L. Schwab and M. Wisse, “Basin of attraction of the simplest walking model,” in Proceedings of the ASME Design Engineering Technical Conference , 2001. [4] H. Geyer, A. Seyfarth, and R. Blickhan, “Compliant leg behaviour explains basic dynamics of walking and running,” Proceedings of the Royal Society B , vol. 273, no. 1603, pp. 2861–2867, 2006. [5] J. Rummel, Y. Blum, and A. Seyfarth, “Robust and efficient walking with spring-like legs,” Bioinspiration and Biomimetics , vol. 5, no. 4, p. 046004, 2010. [6] G. Garofalo, C. Ott, and A. Albu-Sch ̈ affer, “Walking control of fully actuated robots based on the bipedal SLIP model,” in Proceedings of the IEEE International Conference on Robotics and Automation , 2012, pp. 1456–1463. [7] J. G. Ketelaar, L. C. Visser, S. Stramigioli, and R. Carloni, “Controller design for a bipedal walking robot using variable stiffness actuators,” in Proceedings of the IEEE International Conference on Robotics and Automation , 2013, pp. 5650–5655. [8] R. Q. van der Linde, “Active leg compliance for passive walking,” in Proceedings of the IEEE International Conference on Robotics and Automation , 1998, pp. 2339–2344. [9] R. Ghorbani, “On controllable stiffness bipedal walking,” Ph.D. disser- tation, University of Manitoba, 2008. [10] M. Jafarian, G. van Oort, R. Carloni, and S. Stramigioli, “Performance comparison of a planar bipedal robot with rigid and compliant legs,” in Proceedings of the IFAC World Congress , 2011, pp. 6924–6929. [11] B. Vanderborght, A. Albu-Schaeffer, A. Bicchi, E. Burdet, D. Caldwell, R. Carloni, M. Catalano, O. Eiberger, W. Friedl, G. Ganesh, M. Gara- bini, M. Grebenstein, G. Grioli, S. Haddadin, H. Hoppner, A. Jafari, M. Laffranchi, D. Lefeber, F. Petit, S. Stramigioli, N. Tsagarakis, M. V. Damme, R. V. Ham, L. Visser, and S. Wolf, “Variable impedance actu- ators: a review,” Robotics and Autonomous Systems, Elsevier , vol. 61, pp. 1601–1614, 2013. [12] L. C. Visser, S. Stramigioli, and R. Carloni, “Robust bipedal walking with variable leg stiffness,” in Proceedings of the IEEE International Conference on Biomedical Robotics and Biomechatronics , 2012, pp. 1626–1631. [13] V. Duindam, A. Macchelli, S. Stramigioli, and H. Bruyninckx, Modeling and Control of Complex Physical Systems . Springer, 2009. [14] A. Shiriaev, J. W. Perram, and C. Canudas-de-Wit, “Constructive tool for orbital stabilization of underactuated nonlinear systems: Virtual constraints approach,” IEEE Transactions on Automatic Control , vol. 50, no. 8, pp. 1164–1176, 2005. [15] H. Nijmeijer and A. J. van der Schaft, Nonlinear Dynamical Control Systems . Springer, 1990. [16] R. H. Clewley, W. E. Sherwood, M. D. LaMar, and J. M. Guckenheimer, “PyDSTool, a software environment for dynamical systems modeling,” online: http://pydstool.sourceforge.net, 2007. [17] L. C. Visser, S. Stramigioli, and R. Carloni, “Control strategy for energy efficient bipedal walking with variable leg stiffness,” in Proceedings of the IEEE International Conference on Robotics and Automation , 2013. [18] V. Duindam and S. Stramigioli, “Singularity-free dynamic equations of open-chain mechanisms with general holonomic and nonholonomic joints,” IEEE Transactions on Robotics , vol. 24, no. 3, pp. 517–526, 2008. [19] ——, Modeling and Control for Efficient Bipedal Walking Robots . Springer, 2009. [20] P. Gregorio, M. Ahmadi, and M. Buehler, “Design, control, and ener- getics of an electrically actuated legged robot,” IEEE Transactions on Systems, Man, and Cybernetics , vol. 27, no. 4, pp. 626–634, 1997. [21] D. G. E. Hobbelen and M. Wisse, “Controlling the walking speed in limit cycle walking,” International Journal of Robotics Research , vol. 27, no. 9, pp. 989–1005, 2008.