Abstract
Derivatives of equations of motion (EOM) describing the dynamics of rigid body systems are becoming increasingly relevant for the robotics community and find many applications in design and control of robotic systems. Controlling robots, and multibody systems comprising elastic components in particular, not only requires smooth trajectories but also the time derivatives of the control forces/torques, hence of the EOM. This paper presents the time derivatives of the EOM in closed form up to second-order as an alternative formulation to the existing recursive algorithms for this purpose, which provides a direct insight into the structure of the derivatives. The Lie group formulation for rigid body systems is used giving rise to very compact and easily parameterized equations.
Similar content being viewed by others
Explore related subjects
Discover the latest articles, news and stories from top researchers in related subjects.Avoid common mistakes on your manuscript.
1 Introduction
Rigid body dynamics algorithms for evaluating the equations of motion (EOM) and their derivatives find numerous applications in the design optimization and control of modern robotic systems. The equations of motion can be differentiated with respect to state variables, control output (generalized forces), time and physical parameters of the robot (see [8] for an overview). These derivatives can be computed with several methods: 1) approximation by finite differences, 2) automatic differentiation [31], i.e. by applying the chain rule formula in an automatic way knowing the derivatives of basic functions (cos, sin or exp), 3) closed-form derivatives of the EOM and 4) recursive and analytical formulations exploiting the structure of the closed-form equations of motion. While the first two methods are generic and numerical in nature, the latter two are analytical in nature and exploit the structure of the EOM. Analytical and recursive partial derivatives of the EOM of rigid body systems with respect to state variables and generalized forces have been reported in the literature [3, 17]. These are useful in optimal control of legged robots (e.g. differential dynamic programming [19]) and their computational design and optimization [12]. Time derivatives of EOM are required for the model-based control and motion planning of robots with higher-order continuity [27], since for highly dynamic applications not only the actuation forces but also their derivatives must be bounded in order to ensure feasibility. Flatness-based control of robots with flexible joints, and of robots equipped with series elastic actuators (SEA) or variable stiffness actuators (VSA), necessitate the first and second time derivatives of the EOM of the robot [6, 9, 26]. Therefore, recursive \(O\left ( n\right ) \)-algorithms for the evaluation of the time derivatives were developed [1, 2, 10, 11, 21, 24] extending existing \(O\left ( n\right ) \)-formulations for the evaluation of EOM. While \(O\left ( n\right ) \)-formulations are deemed computationally advantageous when dealing with large systems, formulating and evaluating the EOM in closed form remains an efficient alternative for many robotic systems and provides insights into the structure of the problem. Yet, such closed-form formulations were not reported in the literature, with the exception of [13] where first-order time derivatives of the EOM were presented within the so-called spatial operator framework. A relatively recent research topic, where higher-order derivatives of the EOM are required, is the dynamic balancing of articulated mechanisms [4, 30, 32]. In [5], the time derivatives of the spatial momentum were used to derive global balancing conditions. Recently, we also proposed \(n\)th order time derivatives of EOM in both recursive and closed forms [15].
In this paper, the first and second time derivatives of the EOM are presented. For the subsequent treatment, the EOM are written in the form suitable for solving the inverse dynamics problem
where the vector of generalized coordinates \(\mathbf{q}=\left ( q_{1},\ldots ,q_{n}\right ) ^{T}\) comprises the \(n\) joint variables, \(\mathbf{M}\) and \(\mathbf{C}\) is the generalized mass and Coriolis matrix, respectively, and \(\mathbf{Q}_{\mathrm{grav}}\) represents generalized gravity forces. The generalized forces due to external loads (e.g. interaction/contact forces and torques) are summarized in \(\mathbf{Q}_{\mathrm{ext}}\). Finally, \(\mathbf{Q}\) are the generalized forces (drive forces/torques) required for a prescribed motion \(\mathbf{q}\left ( t\right ) \).
In the following, the derivatives of (1) are derived using the Lie group formalism reported in [23], which is equivalent to those presented in [18] and [25]. A salient feature of the Lie group formulation is that it admits model description in terms of readily available data without compromising computational efficiency (of closed-form expressions as well as \(O\left ( n\right ) \) algorithms). As a side contribution, we also prove the structural properties of EOM from a closed-form perspective. For the sake of simplicity, and without loss of generality a single serial kinematic chain, comprising 1-DOF joints, mounted at the ground is considered. The generalizations to systems with arbitrary tree-topologies is straightforward, but will not be considered here in order to simplify notation and make the paper easily accessible.
Organization:
Section 2 presents the equations of motion of serial kinematic chain in closed form using the body–fixed representation of the twists. Section 3 and Sect. 4 presents the first- and second-order time derivatives of the equations of motion in closed form, respectively. Section 5 proves the structural properties of the EOM using the closed-form formulations. Section 6 presents the application of the proposed derivatives in evaluating second-order inverse dynamics of two exemplary robot manipulators and a discussion on its computational performance. Section 7 concludes the paper.
2 Equations of motion in closed form
2.1 Kinematics in terms of joint screws
In the following, the notation and formulation of the EOM are adopted from [23]. The configuration (pose, posture) of body \(i=1,\ldots ,n\) is denoted \(\mathbf{C}_{i}\in SE\left ( 3\right ) \), which describes the frame transformation from a body-fixed frame (arbitrarily located at the body) to the inertial frame. Bodies and joints are numbered increasing order starting from the ground, so that joint \(i\) links body \(i\) to its predecessor \(i-1\), while the ground is indexed with 0, and by convention \(\mathbf{C}_{0}=\mathbf{I}\). The relative configuration of body \(j\) with respect to body \(i\) is then
where \(\mathbf{R}_{ij}\in SO\left ( 3\right ) \) is the rotation matrix transforming coordinates expressed in the reference frame on body \(j\) to their expression in the reference frame on body \(i\), and \({^{i}}\mathbf{r}_{i,j}\in {\mathbb{R}}^{3}\) is the position vector from the origin of frame \(i\) to the origin of frame \(j\) expressed in frame \(i\). Without loss of generality, all joints are assumed to have 1-DOF. Denote with \(q_{i}\) the joint variable (rotation angle, translation) of joint \(i\). The configuration of body \(i\) is determined by the product of exponential (POE) as
where \({\mathbf{B}}_{i}:=\mathbf{C}_{i-1,i}\left ( \mathbf{0}\right ) \in SE \left ( 3\right ) \) is the configuration of body \(i\) relative to its predecessor \(i-1\), in the reference configuration \(\mathbf{q}=\mathbf{0}\), and \({^{i}\mathbf{X}}_{i}\) is the screw coordinate vector associated to joint \(i\) represented in the body-frame of body \(i\) [22]. The vectors \({^{i}\mathbf{X}}_{i}\) are constant due to the body-fixed representation. For 1-DOF lower-pair joints they are given as
where \({^{i}}\mathbf{e}_{i}\in {\mathbb{R}}^{3}\) is a unit vector along the joint axis, \({^{i}}\mathbf{x}_{i}\in {\mathbb{R}}^{3}\) is the vector to a point on this axis, and \(h_{i}\in {\mathbb{R}}\) is the pitch of the joint. In particular, for a revolute and prismatic joint, the screw coordinate vector is, respectively,
In terms of these screw coordinates \({\mathbf{X}}\), the exponential map attains the explicit form [18, 20]
where the rotation matrix is determined by the Euler–Rodrigues formula
Denote with \(\mathbf{V}_{i}^{{\mathsf{b}}}=(\boldsymbol{\omega }_{i}^{ {\mathsf{b}}},\mathbf{v}_{i}^{{\mathsf{b}}})^{T}\) the twist of body \(i\) represented in the body-fixed frame. The superscript b is used to indicate the body-fixed representation [23, 25]. An alternative representation is so-called spatial representation of twist, which would be indicated by a superscript s. A recursive \(O\left ( n\right ) \)-algorithm for evaluating the EOM and their higher-order derivatives using the spatial representation was reported in [24]. In [14] the EOM were presented in closed form in terms of the spatial representation of twists. The potential advantage of using the spatial representation to express the EOM in closed form remains to be explored, however. In this paper the (classical) body-fixed representation is used.
The individual twists of all bodies are summarized in the vector \(\mathsf{V}\in {\mathbb{R}}^{6n}\), which is referred to as the system twist in body-fixed representation. It is determined as
with the system Jacobian \(\mathsf{J}\left ( \mathbf{q}\right ) \). The latter admits the factorization
in terms of the block-triangular and block-diagonal matrices
The matrix \(\mathbf{Ad}_{\mathbf{C}_{i,j}}\) transforms screw coordinates represented in the reference frame at body \(j\) to those represented in the frame on body \(i\) [18, 25, 28]. With the relative configuration (2) this matrix is
where \(\tilde{\mathbf{x}}\in so\left ( 3\right ) \) is the skew-symmetric matrix associated to vector \(\mathbf{x}\in {\mathbb{R}}^{3}\) so that \(\tilde{\mathbf{x}}\mathbf{y}=\mathbf{x}\times \mathbf{y}\). A central relation for deriving the EOM in closed form is the following expression for the time derivative of the matrix \(\mathsf{A}\) and thus of the system Jacobian [23]:
where
Therein, the matrix \(\mathbf{ad}_{{{^{i}}\mathbf{X}_{i}}}\) (also called as spatial cross product by Featherstone [7]) is given in terms of the joint screw coordinate vector (4) as
This gives rise to the closed-form expressions for the system acceleration
For calculating the derivatives, the time derivative of matrix \(\mathsf{A}\) will be needed. To this end, the expression
is used [23], with the matrix
With (16), the derivative of \(\mathsf{A}\) is then
Using the relation \(\dot{\mathbf{Ad}}_{\mathbf{C}_{i,j}}=-\dot{q}_{i}\mathbf{ad}_{{^{i}\mathbf{X}}_{i}}\mathbf{Ad}_{\mathbf{C}_{i,-1}}\) [23], the derivative of \(\mathsf{D}\) attains the closed form \(\dot{\mathsf{D}}=-\mathsf{aD}\). Finally, with \(\mathsf{D}=\mathbf{I}-\mathsf{A}^{-1}\), it follows
Clearly, the derivative (12) of the system Jacobian is recovered as \(\dot{\mathsf{J}}=\dot{\mathsf{A}}\mathsf{X}\) noting that \(\mathsf{aX}\equiv \mathbf{0}\).
2.2 Equations of motion
The generalized mass and Coriolis matrix in the EOM (1) of a simple kinematic chain mounted at the ground are found via Jourdain’s principle of virtual power as (or likewise as the Lagrange equations) [23]
where
and
Therein, the (constant) \(6\times 6\) inertia matrix of body \(i\) expressed in the body-frame is defined as
where \(m_{i}\) is the body mass, \({^{i}}\mathbf{c}_{i}\) is the position vector to the COM of body \(i\) measured in the reference frame at body \(i\), and \({\boldsymbol{\varTheta }_{i}^{\mathsf{b}}}\) is the inertia tensor with respect to the body-fixed frame. The latter is related to the inertia tensor with respect to the COM, denoted \({\boldsymbol{\varTheta }_{i}^{\mathsf{c}}}\), via Steiner’s (parallel axis) theorem \(\boldsymbol{\varTheta }_{i}^{\mathsf{b}}=\mathbf{R}_{\mathsf{b},\mathsf{c}}\boldsymbol{\varTheta }_{i}^{\mathsf{c}}\mathbf{R}_{\mathsf{b}, \mathsf{c}}^{T}-m_{i}{^{i}}\widetilde{\mathbf{c}}_{i}{^{i}} \widetilde{\mathbf{c}}_{i}\) where \(\mathbf{R}_{\mathsf{b},\mathsf{c}}\) denotes the rotation matrix of the COM frame to the body frame.
A closed form of the EOM is obtained after replacing the system twist by (8). Alternatively, first the kinematic relation (8) and then the coefficient matrices in (22) are evaluated for a given state \(\mathbf{q},\dot{\mathbf{q}}\). The generalized gravity forces are given as
with
Here, \(^{0}\mathbf{g}\) is the vector of gravitational acceleration expressed in the inertial frame, which is transformed to the individual bodies by \(\mathsf{U}\). The effect of contact or external wrenches acting on the bodies is given by the generalized forces
The vector \(\mathsf{W}_{\mathrm{ext},i}\) accounts for applied load at body \(i \). For instance, \(\mathbf{W}_{\mathrm{ext},n}\) can be used to describe the wrench at the end-effector of a robotic arm. More generally, \(\mathsf{W}_{\mathrm{ext}}\) and thus \(\mathbf{Q}_{\mathrm{ext}}\), may account for arbitrary (time and velocity dependent) loads at the system.
3 First time derivative of the equations of motion
The first time derivative of the generalized forces is
The time derivative of the generalized mass matrix \(\mathbf{M}\) in (20) follows with \(\dot{\mathsf{J}}\) in (12) as
with
where \(\mathsf{A}=\mathsf{A}\left ( \mathbf{q}\right ) \) and \(\mathsf{a}=\mathsf{a}\left ( \dot{\mathbf{q}}\right ) \). By the same token, the time derivative of the generalized Coriolis matrix \(\mathbf{C}\) is
where now
The expression for \(\mathsf{C}\) in (22) together with (12) yields
with \(\dot{\mathsf{a}}=\dot{\mathsf{a}}\left ( \ddot{\mathbf{q}}\right ) , \dot{\mathsf{b}}=\mathsf{\dot{\mathsf{b}}}(\mathsf{\dot{\mathsf{V}}})\), and thus
The form (34) allows for reusing expression (22) for the matrix \(\mathsf{C}\), where (22) is evaluated with \(\ddot{\mathbf{q}},\mathsf{\dot{\mathsf{V}}}\) instead with the velocities. Also in the second form (35), terms like \(\mathsf{Aa}\), \(\mathsf{MAa}\), and \(\mathsf{b}^{T}\mathsf{M}\) can be reused. A direct calculation yields
where the relation \(\dot{\mathsf{U}}=-\mathsf{AaU}\) (obtained by time differentiation of (26) and using the identity in (19)) and the fact that \(\mathbf{G}\) is constant has been used. The time derivative of (27) along with (12) yields the expression for calculating first-order derivative of generalized forces due to external wrenches
4 Second time derivative of the equations of motion
The second time derivative of the generalized motor forces (1) is determined by
The second time derivative of the generalized mass matrix is
with \(\mathsf{M}^{\left ( 2\right ) }:=\dot{\mathsf{M}}^{\left ( 1\right ) }-\mathsf{M}^{\left ( 1\right ) }\mathsf{Aa}-\mathsf{a}^{T}\mathsf{A}^{T} \mathsf{M}^{\left ( 1\right ) }\). Inserting relation (19) in the differentiation of (30) yields
which leads immediately to the explicit form
Equation (43) allows for reusing \(\mathsf{M}^{\left ( 1\right ) }\left ( \mathbf{q},\dot{\mathbf{q}} \right ) \). It should be observed that the term \(\mathsf{M}^{\left ( 1\right ) }\left ( \mathbf{q}, \ddot{\mathbf{q}}\right ) \) is the relation (30) evaluated with \(\ddot{\mathbf{q}}\) instead of \(\dot{\mathbf{q}}\).
Repeated time derivative of the generalized Coriolis matrix yields
with
Taking the derivative of (32) yields \(\dot{\mathsf{C}}^{\left ( 1\right ) }(\mathbf{q},\dot{\mathbf{q}}, \ddot{\mathbf{q}},\dddot{\mathbf{q}},\mathsf{\dot{\mathsf{V}}},\ddot{\mathsf{V}})\) in closed form as
This requires the derivative of (33), which are found to be
Also here it should be observed that the matrix \(\mathsf{C}(\mathbf{q},\dddot{\mathbf{q}},\mathsf{\ddot{\mathsf{V}}})\) is the expression for \(\mathsf{C}\) in (22) evaluated with \(\dddot{\mathbf{q}},\mathsf{\ddot{\mathsf{V}}}\). Inserting (48) along with (49) into (46) yields \(\mathsf{C}^{\left ( 2\right ) }\left ( \mathbf{q},\dot{\mathbf{q}},\ddot{\mathbf{q}},\dddot{\mathbf{q}}\right ) \) in the explicit form
with \(\ddot{\mathsf{a}}=\ddot{\mathsf{a}}\left ( \dddot{\mathbf{q}}\right ) \) and \(\ddot{\mathsf{b}}=\ddot{\mathsf{b}}(\ddot{\mathsf{V}})\) in (13) and (23) evaluated with \(\dddot{\mathbf{q}}\) and \(\ddot{\mathsf{V}}\), respectively. The first form (51) may be beneficial since it involves \(\mathsf{C}\) and \(\mathsf{C}^{\left ( 1\right ) }\), which are already available from (22) and (34).
Taking the derivative of (36) yields the second time derivative of the generalized gravity forces
The second time derivative of the generalized forces (27) due to end-effector loads is readily found to be
5 Structural properties of the EOM
There are two important and well-known structural properties of EOM:
-
1.
The generalized mass matrix \(\mathbf{M}\) is symmetric and positive definite.
-
2.
\(\dot{\mathbf{q}}^{T}\left ( \dot{\mathbf{M}}\left ( \mathbf{q}, \dot{\mathbf{q}}\right ) -2\mathbf{C}\left ( \mathbf{q},\dot{\mathbf{q}} \right ) \right ) \dot{\mathbf{q}}\equiv 0\) for any \(\dot{\mathbf{q}}\)
Positive definiteness and the symmetric properties of the generalized mass matrix follows directly from its definition in (20). The symmetry property indeed applies to all higher derivatives, which is also evident from (29) and (40). An important property of the EOM (1), which is crucial for proving stability of passivity-based control schemes, is that the Coriolis matrix can be formulated as
so that \(\dot{\mathbf{M}}-2\bar{\mathbf{C}}\) is skew symmetric. To show this property, notice that \(\mathsf{bJ}\dot{\mathbf{q}}=\mathsf{bV}=\mathrm{diag}\left ( \mathbf{ad}_{\mathbf{V}_{1}}\mathbf{V}_{1},\ldots , \mathbf{ad}_{\mathbf{V}_{n}}\mathbf{V}_{n}\right ) \equiv \mathbf{0}\), so that \(\mathbf{C}\dot{\mathbf{q}}\) can be rewritten as
In view of the time derivative (29) of \(\mathbf{M}\), the so defined Coriolis matrix \(\bar{\mathbf{C}}\) satisfies the relation
With (54), it hence follows
It should be remarked that the Coriolis matrix is not unique, and the property 2) holds true for the particular arrangement as in (22). It may not hold if the equations are arranged differently. The skew symmetry of \(\dot{\mathbf{M}}-2\bar{\mathbf{C}}\) is indeed carried over to its derivatives.
6 Examples
The higher-order closed-form inverse dynamics formulation presented in Sect. 3 and Sect. 4 were implemented in MATLAB.Footnote 1 This MATLAB implementation can also be used for efficient symbolic code generation in MATLAB and C languages. This section presents the application of this work to the computation of higher-order inverse dynamics of two robot manipulators and presents a discussion on its computational efficiency.
6.1 Planar 2R robot
A 2R serial chain consists of a base, two links, and two revolute joints. A simple 2R chain is shown in Fig. 1. First link of length \(L_{1}\) is connected to the base or ground through a revolute joint. The second link of length \(L_{2}\) is connected to first link through a revolute joint. The center of mass is shown with a red circle on the links and lies at the end of each link. The mass of first and second links are \(m_{1}\) and \(m_{2}\) respectively. The gravity acting on the system is shown as \(g\) in the figure.
Kinematic model The \(z\)-axes represent the joint axes, and thus the joint screw coordinates in body-fixed representation for the two revolute joints are
The relative reference configurations for the two bodies are
The mass matrices of the two bodies in the body-fixed configuration according to (24) are
Second-order inverse dynamics With the above information about the robot, using the closed-form expressions of \(\mathbf{M}(\mathbf{q}), \mathbf{C}(\mathbf{q},\mathbf{\dot{q}})\) and \(\mathbf{Q}_{\text{grav}}(\mathbf{q})\) provided in Sect. 2.2 in (1), one can arrive at the analytical expression for generalized forces \((\tau _{1},\tau _{2})\) which solves inverse dynamics problem as follows:
These expressions are indeed identical to those reported in [18] for instance.
Using the closed-form expressions of \(\dot{\mathbf{M}}(\mathbf{q,\dot{q}}),\dot{\mathbf{C}}(\mathbf{q},\mathbf{\dot{q}},\mathbf{\ddot{q}})\) and \(\dot{\mathbf{Q}}_{\text{grav}}(\mathbf{q},\mathbf{\dot{q}})\) provided in Sect. 3 in (28), one obtains the analytical expression for first-order time derivatives \((\dot{\tau }_{1},\dot{\tau }_{2})\) of the generalized forces, which solves the first-order inverse dynamics problem, as follows:
The correctness can be easily checked taking the analytical time derivative of \((\tau _{1},\tau _{2})\) above.
Using the closed-form expressions of \(\ddot{\mathbf{M}}(\mathbf{q,\dot{q}, \ddot{q}}),\ddot{\mathbf{C}}(\mathbf{q},\mathbf{\dot{q}}, \mathbf{\ddot{q}},\mathbf{\dddot{q}})\) and \(\ddot{\mathbf{Q}}_{\text{grav}}(\mathbf{q},\mathbf{\dot{q}},\mathbf{\ddot{q}})\) provided in Sect. 4 in (38), one obtains the analytical expression for second-order time derivatives of generalized forces \((\ddot{\tau }_{1},\ddot{\tau }_{2})\), solving the second-order inverse dynamics problem:
They can again be verified by taking analytic derivatives of the above \((\dot{\tau }_{1},\dot{\tau }_{2})\).
6.2 KUKA LBR iiwa manipulator
The closed-form formulation presented in this paper are used to compute the second-order inverse dynamics of the 7 degrees of freedom KUKA LBR iiwa robot.
Kinematic model The body-fixed frames are introduced according to [29], which follow the modified Denavit–Hartenberg (DH) convention. As the \(z\)-axis represents the joint axis in this convention, the joint screw coordinates in body-fixed representation are
The relative reference configurations \({\mathbf{B}}_{i}\) in (3) have the form (2), with the relative rotation matrix \(\mathbf{R}_{i-1,i}\) and the position vector \({^{i-1}}\mathbf{r}_{i-1,i}\) from the origin of the reference of body \(i-1\) to that of its successor body \(i\). According to the zero reference configuration shown in Fig. 2 in [29], the body-fixed displacement vectors are
and the relative rotation matrices are
Dynamic model parameters The mass and inertia data used in this example is taken from the identified model of KUKA LBR iiwa robot reported in [29] as listed in Table 1. The COM position vector \({}^{i}\mathbf{c}_{i}=({^{i}}c_{i,x},{^{i}}c_{i,y},{^{i}}c_{i,z})^{T}\in \mathbb{R}^{3}\) of link \(i\) is measured with respect to the link \(i\) frame. The parameters in the symmetric inertia tensor of link \(i\) are defined relative to the COM of link \(i\) in the \(i\)th link frame.
Second-order inverse dynamics The joint trajectory is described by means of cos-function as shown in Fig. 3a, and used for the inverse dynamics computation of the robotic manipulator (see Fig. 3b). Figure 4a and Fig. 4b show first- and second-order time derivatives of the generalized forces. The results computed from the closed-form expressions are compared against the numerical differentiation. As apparent from Fig. 4, the closed-form derivatives match the numerical time differentiation of generalized forces in both cases which attests the correctness of the formulation presented in this paper.
Computational performance The computational performance of the closed-form algorithm was evaluated by measuring the total CPU time spent in 10000 evaluations of second-order inverse dynamics on a standard laptop with Intel Core i9-7960X CPU clocked at 2.80 GHz and 128 GB RAM. It was found that the closed-form implementation takes 16.34 seconds leading to the average computational time of 1.6 milliseconds per evaluation, which is sufficient for many real-time control applications.
7 Conclusion and outlook
This paper presents closed-form expressions for the first and second time derivative of the EOM of a kinematic chain. Building upon the Lie group formulation of the EOM, the formulations are advantageous as they are expressed in terms of joint screw coordinates, and thus facilitate parameterization in terms of vector quantities that can be easily obtained. The computationally efficiency of these closed-form relations compared to recursive algorithms and their efficient implementation will be a topic of further research. It is already obvious from the presented expressions that they involve many repeated terms that can be precomputed and reused. Future research will also address the time derivatives of general mechanisms with kinematic loops and an efficient C++ based implementation in Hybrid Robot Dynamics (HyRoDyn) software framework [16].
Notes
The source code as well as robot data are openly available at https://github.com/shivesh1210/2nd_order_closed_form_time_derivatives_eom.
References
Buondonno, G., De Luca, A.: A recursive Newton-Euler algorithm for robots with elastic joints and its application to control. In: 2015 IEEE/RSJ IROS, pp. 5526–5532 (2015)
Buondonno, G., De Luca, A.: Efficient computation of inverse dynamics and feedback linearization for VSA-based robots. IEEE Robot. Autom. Lett. 1(2), 908–915 (2016)
Carpentier, J., Mansard, N.: Analytical derivatives of rigid body dynamics algorithms. In: Robotics: Science and Systems (2018)
De Jong, J.J., Wu, Y.Q., Carricato, M., Herder, J.L.: A pure-inertia method for dynamic balancing of symmetric planar mechanisms. In: Advances in Robot Kinematics, vol. 5, pp. 1–8 (2018)
de Jong, J.J., Müller, A., Herder, J.L.: Higher-order derivatives of rigid body dynamics with application to the dynamic balance of spatial linkages. Mech. Mach. Theory 155, 104059 (2021)
De Luca, A.: Decoupling and feedback linearization of robots with mixed rigid/elastic joints. Int. J. Robust Nonlinear Control 8, 965–977 (1998)
Featherstone, R.: Rigid Body Dynamics Algorithms. Springer, Berlin (2008)
Garofalo, G., Ott, C., Albu-Schäffer, A.: On the closed form computation of the dynamic matrices and their differentiations. In: 2013 IEEE/RSJ International Conference on Intelligent Robots and Systems, Tokyo, pp. 2364–2369 (2013)
Gattringer, H., et al.: Recursive methods in control of flexible joint manipulators. Multibody Syst. Dyn. 32, 117–131 (2014)
Guarino Lo Bianco, C.: Evaluation of generalized force derivatives by means of a recursive Newton–Euler approach. IEEE Trans. Robot. 25(4), 954–959 (2009)
Guarino Lo Bianco, C., Fantini, E.: A recursive Newton–Euler approach for the evaluation of generalized forces derivatives. In: 12th IEEE Int. Conf. Methods Models Autom. Robot., pp. 739–744 (2006)
Ha, S., Coros, S., Alspach, A., Kim, J., Yamane, K.: Joint optimization of robot design and motion parameters using the implicit function theorem. In: Robotics: Science and Systems (2017)
Jain, A.: Robot and Multibody Dynamics. Springer, US (2011)
Kumar, S.: Modular and Analytical Methods for Solving Kinematics and Dynamics of Series-Parallel Hybrid Robots. PhD diss., Universität Bremen (2019)
Kumar, S., Mueller, A.: Nth order analytical time derivatives of inverse dynamics in recursive and closed forms. In: 2021 IEEE International Conference on Robotics and Automation (ICRA) (2021)
Kumar, S., Szadkowski, K.A.V., Mueller, A., Kirchner, F.: An analytical and modular software workbench for solving kinematics and dynamics of series-parallel hybrid robots. J. Mech. Robot. 12(2), 021114 (2020). https://doi.org/10.1115/1.4045941
Lee, S.-H., Kim, J., Park, F.C., Kim, M., Bobrow, J.E.: Newton-type algorithms for dynamics-based robot movement optimization. IEEE Trans. Robot. 21(4), 657–667 (2005)
Lynch, K.M., Park, F.C.: Modern Robotics. Cambridge University Press, Cambridge (2017)
Mastalli, C., Budhiraja, R., Merkt, W., Saurel, G., Hammoud, B., Naveau, M., Carpentier, J., Vijayakumar, S., Mansard, N.: Crocoddyl: an efficient and versatile framework for multi-contact optimal control. In: 2020 IEEE International Conference on Robotics and Automation (ICRA), pp. 2536–2542 (2020). https://doi.org/10.1109/ICRA40945.2020.9196673
Müller, A.: Coordinate mappings for rigid body motions. J. Comput. Nonlinear Dyn. 12(2), 021010 (2017)
Müller, A.: Recursive second-order inverse dynamics for serial manipulators. In: IEEE Int. Conf. Robotics Automations (ICRA), Singapore, May 29-June 3 (2017)
Müller, A.: Screw and Lie group theory in multibody dynamics – motion representation and recursive kinematics of tree-topology systems. Multibody Syst. Dyn. 43(1), 1–34 (2018)
Müller, A.: Screw and Lie group theory in multibody dynamics – recursive algorithms and equations of motion of tree-topology systems. Multibody Syst. Dyn. 42(2), 219–248 (2018)
Müller, A.: An \(O(n)\)-algorithm for the higher-order kinematics and inverse dynamics of serial manipulators using spatial representation of twists. IEEE Robot. Autom. Lett. 6(2), 397–404 (2021)
Murray, R.M., Li, Z., Sastry, S.S.: A Mathematical Introduction to Robotic Manipulation. CRC Press, Boca Raton (1994)
Palli, G., Melchiorri, C., De Luca, A.: On the feedback linearization of robots with variable joint stiffness. In: IEEE Int. Conf. Rob. Aut. (IROS), Pasadena, CA, USA, May 19-23 (2008)
Reiter, A., Müller, A., Gattringer, H.: On higher-order inverse kinematics methods in time-optimal trajectory planning for kinematically redundant manipulators. IEEE Trans. Ind. Inform. 14(4), 1681–1690 (2018)
Selig, J.: Geometric Fundamentals of Robotics. Monographs in Computer Science Series. Springer, New York (2005)
Stürz, Y.R., Affolter, L.M., Smith, R.S.: Parameter identification of the KUKA LBR iiwa robot including constraints on physical feasibility. IFAC-PapersOnLine 50(1), 6863–6868 (2017)
Van der Wijk, V., Krut, S., Pierrot, F., Herder, J.L.: Design and experimental evaluation of a dynamically balanced redundant planar 4-RRR parallel manipulator. Int. J. Robot. Res. 32(6), 744–759 (2013)
Walther, A., Griewank, A.: Getting started with ADOL-C. Comb. Sci. Comput. 09061, 181–202 (2009)
Wu, Y., Gosselin, C.M.: Synthesis of reactionless spatial 3-DoF and 6-DoF mechanisms without separate counter-rotations. Int. J. Robot. Res. 23(6), 625–642 (2004)
Acknowledgements
This work has been supported by the LCM K2 Center for Symbiotic Mechatronics within the framework of the Austrian COMET-K2 program. The second author acknowledges the support of Q-RoCK (Grant Number: FKZ 01IW18003) and VeryHuman (Grant Number: FKZ 01IW20004) projects funded by the German Aerospace Center (DLR) with federal funds from the Federal Ministry of Education and Research (BMBF).
Both authors have equally contributed to this paper. The authors further thank Rohit Kumar from the University Genoa for helping with the implementation and testing of the symbolic code.
Funding
Open access funding provided by Johannes Kepler University Linz.
Author information
Authors and Affiliations
Corresponding author
Additional information
Publisher’s Note
Springer Nature remains neutral with regard to jurisdictional claims in published maps and institutional affiliations.
Rights and permissions
Open Access This article is licensed under a Creative Commons Attribution 4.0 International License, which permits use, sharing, adaptation, distribution and reproduction in any medium or format, as long as you give appropriate credit to the original author(s) and the source, provide a link to the Creative Commons licence, and indicate if changes were made. The images or other third party material in this article are included in the article’s Creative Commons licence, unless indicated otherwise in a credit line to the material. If material is not included in the article’s Creative Commons licence and your intended use is not permitted by statutory regulation or exceeds the permitted use, you will need to obtain permission directly from the copyright holder. To view a copy of this licence, visit http://creativecommons.org/licenses/by/4.0/.
About this article
Cite this article
Müller, A., Kumar, S. Closed-form time derivatives of the equations of motion of rigid body systems. Multibody Syst Dyn 53, 257–273 (2021). https://doi.org/10.1007/s11044-021-09796-8
Received:
Accepted:
Published:
Issue Date:
DOI: https://doi.org/10.1007/s11044-021-09796-8