arXiv:1610.02881v2 [cs.RO] 9 Dec 2016 Essential Properties of Numerical Integration for Time-optimal Trajectory Planning Along a Specified Path Peiyao Shen, Xuebo Zhang and Yongchun Fang Abstract— This letter summarizes some known properties and also presents several new properties of the Numerical Integration (NI) method for time-optimal trajectory planning along a speci- fied path. The contribution is that rigorous mathematical proofs of these properties are presented, most of which have not been reported in existing literatures. We first give some properties regarding switch points and accelerating/decelerating curves of the NI method. Then, for the fact that when kinematic constraints are considered, the original version of NI which only considers torque constraints may result in failure of trajectory planning, we give the concrete failure conditions with rigorous mathematical proof. Accordingly, a failure detection algorithm is given in a ‘run-and-test’ manner. Some simulation results on a unicycle vehicle are provided to verify those presented properties. Note that though those known properties are not discovered first, their mathematical proofs are given first in this letter. The detailed proofs make the theory of NI more complete and help interested readers to gain a thorough understanding of the method. Index Terms— Time-optimal trajectory planning, Numerical Integration, Properties with rigorous proofs. I. INTRODUCE Due to low computational complexity, decoupled planning [1]–[3] becomes a popular motion planning method, which consists of two stages. In the first stage, path planning methods are used to generate a geometric path with high level constraints including obstacle avoidance, curvature, and so on. In the second stage, trajectory planning, which aims to assign a motion time profile to the specified path, could be then simplified as a planning problem in two-dimensional path parametrization space (s, ˙s), with s and ˙s being the path coordinate and path velocity respectively. To improve working efficiency, several time-optimal methods have been reported for the trajectory planning stage along a specified path, including Dynamic Programming [4]–[6], Convex Op- timization [7]–[9] and NI [10]–[22]. In addition, the work in [23] proposes a real-time trajectory generation approach for omni-directional vehicles by constrained dynamic inversion. In this letter, we will focus on the NI method, since its computational efficiency is shown in [13] to be better than other methods. The original version of NI is proposed at almost the same time in the works [10], [11], which aims to give a time-optimal trajectory along a specified path in the presence of only torque constraints for manipulators. This work is supported in part by National Natural Science Foundation of China under Grant 61573195 and Grant 613205017. The authors are with the Institute of Robotics and Automatic Information System, Nankai University, Tianjin 300071, China, and also with the Tianjin Key Laboratory of Intelligent Robotics, Nankai University, Tianjin 300071, China (e-mail: zhangxuebo@nankai.edu.cn) Based on Pontryagin Maximum Principle, NI possesses a bang-bang structure of torque inputs, thus, the core of NI is the computation of switch points. The accelerating and decelerating curves, integrated from those switch points, constitute the time-optimal trajectory. The work in [12] presents three types of switch points: tangent, discontinuity and zero-inertia points. The detection methods for zero- inertia switch points are presented in [13]–[15]. Based on previous works, Pham [13] provides a fast, robust and open- source implementation for NI in C++/Python, which is subse- quently extended to the case of redundantly-actuated systems in the work [16]. In addition to manipulators [17], [18], NI is also applied to spacecrafts [19] and humanoid robots [20]. In real applications, in addition to torque constraints, velocity constraints (bounded actuator velocity and path velocity) should also be considered. Under these constraints, the works in [21], [22] indicate that the original NI method with only torque constraints [10] can not be directly applied. Considering velocity and acceleration constraints, the work [18] focuses on detecting tangent, discontinuity and zero- inertia switch points on the speed limit curve decided by velocity constraints. However, rigorous proofs have not been reported to expose the conditions and underlying reasons of failure cases in aforementioned literatures. In this brief, we summarize some known properties and amend corresponding mathematical proofs which have not been reported in existing literatures; in addition, some new properties are excavated and proven rigorously. Some proper- ties indicate the evolution of accelerating/decelerating curves and their intersection points. And another important property indicates that, when kinematic constraints are considered, the original version of NI which only considers torque con- straints, may result in failure of trajectory planning tasks. For this property, we first give the concrete failure conditions and detailed proofs. Accordingly, the failure detection algorithm is given in a ‘run-and-test’ manner. Simulation results on a unicycle vehicle are provided to verify these properties. The main contribution of this letter is the rigorous and detailed proofs for all presented properties: 1) For Properties 2-3 reported in [24], we first give their mathematical proofs in Section III-A. 2) Some new properties are presented and proven, includ- ing Property 4 in Section III-B and Properties 5-6 in Section III-C. These properties and proofs make the theory of NI more complete and help interested readers to gain an thorough understanding of the NI method. The remainder of this letter is divided into four sections. Section II introduces notations and procedures of the NI method. Section III presents essential properties of the NI method, and provides rigorous mathematical proofs. In Section IV, simulation results are provided to verify the properties. Finally, Section V gives some conclusions. II. NUMERICAL INTEGRATION In this section, we briefly introduce the notations and procedures of the NI method in [10], [11]. For the time- optimal path-constrained trajectory planning problem, based on Pontryagin Maximum Principle, the original NI method [10], [11] uses a bang-bang structure of torque input to generate a time-optimal trajectory. First, torque constraints are converted to path acceleration constraints along the given path. Then, switch points of path acceleration are found. Finally, a time-optimal trajectory is integrated numerically with maximum and minimum path acceleration. A stable and open-source implementation of NI method can be found in [13], and kinematic constraints are handled in the im- plementation with the method proposed in [21]. Yet, in the presence of kinematic constraints, the rigorous proof showing conditions of failure of the original NI with only torque constraints, has not been reported. A. Time-optimal Path-constrained Trajectory Planning The time-optimal path-constrained trajectory planning problem is to find a time-optimal velocity profile along the given path for a robot under various constraints such as torque constraints, velocity constraints, and so on. Note that the direction of the path velocity is supposed to be tangent to the given path. B. Notations In order to explain various notations clearer, we will refer to Fig. 1 in the following. s 0 es 0s e 0 1 1 ! " MVC s sp ! " sp ! " s es Fig. 1. Red solid curves β0,β1 represent accelerating β-profiles. Green solid curves α1,αe represent decelerating α-profiles. Red ⊲and green ⊳ denote the points spβ→α and spα→β , respectively. The scalars ˙s0, ˙se are respectively the starting and terminal path velocity at the endpoints of the given path. The se is the total length of the given path. s : Path coordinate along a specified path. ˙s : Path velocity along a specified path. ¨s : Path acceleration along a specified path. AAA(s)¨s + BBB(s)˙s2 +CCC(s) ≤000 [10]: The inequality constraint along a specified path for s, ˙s, ¨s, which is derived from torque constraints. As an example, for an n-dof manipulator, in order to guarantee torque constraints in a path-constrained trajectory planning task, the inequality constraint [10] M(ξξξ) ¨ξξξ + ˙ξξξ TP(ξξξ) ˙ξξξ + QQQ(ξξξ) ≤000 (1) should hold, where the state ξξξ is an n-dimensional vector, M is an m × n matrix, P is an n × m × n tensor and QQQ is an m-dimensional vector. Along the specified path, the robot state and its differentials are ξξξ = ξξξ(s), ˙ξξξ = ξξξ s ˙s, ¨ξξξ = ξξξ ss ˙s2 + ξξξ s ¨s (2) where ξξξ s = dξξξ/ds, ξξξ ss = dξξξ s/ds. After substituting (2) into (1), we obtain that AAA(s)¨s + BBB(s)˙s2 +CCC(s) ≤000, (3) with AAA(s) = M(ξξξ(s))ξξξ s(s), BBB(s) = M(ξξξ(s))ξξξ ss(s)+ ξξξ s(s)TP(ξξξ(s))ξξξ s(s), CCC(s) = QQQ(ξξξ(s)). α(s, ˙s),β(s, ˙s) : In order to guarantee torque constraints, the scalars s, ˙s, ¨s should satisfy the inequality (3). Therefore, given the path coordinate s and path velocity ˙s, the path acceleration ¨s satisfies the following inequality α(s, ˙s) ≤¨s ≤β(s, ˙s), (4) where the minimum path acceleration α(s, ˙s) and maximum path acceleration β(s, ˙s) are computed as α(s, ˙s) = max{αi|αi = −Bi(s)˙s2 −Ci(s) Ai(s) ,Ai(s) < 0}, (5) β(s, ˙s) = min{βi|βi = −Bi(s)˙s2 −Ci(s) Ai(s) ,Ai(s) > 0}, (6) wherein the integer i ∈[1,m], with m being the dimension of the vector AAA. Please see the detailed description in [11]. MVC: The maximum velocity curve in the plane (s, ˙s) is represented as MVC(s) = min{˙s ≥0|α(s, ˙s) = β(s, ˙s)}, s ∈[0,se]. (7) For instance, the cyan dash curve in Fig. 1 is MVC. If the robot state is on the MVC, there exists at least one saturated actuator torque. AR: The admissible region, in the plane (s, ˙s), is enclosed by the curve MVC and the lines ˙s = 0,s = 0,s = se. Within the AR except for the boundary MVC, all actuator torques are between lower and upper bounds (α(s, ˙s) < β(s, ˙s)). α-pro file: The decelerating curve, in the plane (s, ˙s), is integrated backward with minimum acceleration α(s, ˙s) in (5). The slope kα is computed as kα = d ˙s/ds = α(s, ˙s)/˙s. β-pro file: The accelerating curve, in the plane (s, ˙s), is integrated forward with maximum acceleration β(s, ˙s) in (6). The slope kβ is computed as kβ = d ˙s/ds = β(s, ˙s)/˙s. spα→β [12]: Switch points from decelerating to acceler- ating curves, such as the green ⊳in Fig. 1. They are on the MVC curve, and there are three different types: tangent, discontinuity or zero-inertia points. At tangent points, the slope kmvc = d ˙s/ds of MVC is equal to kα(= kβ). At discontinuity points, MVC is discontinuous. At zero-inertia points, at least one Ai(s) = 0 holds for the corresponding path coordinate s. spβ→α: Switch points from accelerating to decelerating curves, such as the red ⊲in Fig. 1. C. Numerical Integration Algorithm Procedures of the original version of NI [10] which only considers torque constraints are given as follows: NI-1. In the plane (s, ˙s), starting from (s = 0, ˙s = ˙s0), the accelerating curve β-pro file is integrated forward with maximum path acceleration β(s, ˙s) until one of the following cases occurs: • the curve MVC is hit, and go to NI-2; • the line ˙s = 0 is hit, and output that this path is not traversable; • the line s = se is hit, and go to NI-3. NI-2. From the hitting point, searching forward along MVC, the first tangent, discontinuity or zero-inertia point found is spα→β. • If spα→β is detected, from the switch point, an α-pro file is integrated backward with α(s, ˙s) until it intersects the generated β-pro file in NI-1, NI-2 at a point spβ→α, and one new β-pro file is integrated forward as NI-1. • If spα→β is not detected, go to NI-3. NI-3. Starting from (s = se, ˙s = ˙se), the decelerating curve α-pro file is integrated backward with minimum path acceleration α(s, ˙s) until it intersects the gen- erated β-pro file in NI-1, NI-2 at a point spβ→α. Finally, output a time-optimal trajectory consisting of those generated accelerating and decelerating curves in NI-1, NI-2 and NI-3. Note that chattering or vibration is usually caused by high- frequent switching of acceleration. Fortunately, the work in [10] has indicated that switch points are finite for the NI method, which generally does not cause severe chattering phenomenons. III. PROPERTIES In this section, essential properties of NI are provided with rigorous mathematical proofs. Note that Property 1 has been presented and proven in [24]; Properties 2-3 have been re- ported in [24], and we will amend their mathematical proofs; Properties 4-5 are first exposed in this letter with rigorous proofs; in the presence of kinematic constraints, the failure of the original NI with only torque constraints is reported in [21], [22], and we will give the mathematical conditions and underlying reasons of failure cases in Property 6. See the proofs of Properties 2-5 in Appendix A-D, respectively. A. Property of α-pro files and β-pro files In the admissible region except for the boundary MVC (AREM), the inequality α(s, ˙s) < β(s, ˙s) holds, which indi- cates kα < kβ for each point. Three known properties are summarized in the following, and we will give rigorous s s profile ! profile ! 1 X m X 1 m * m Y 0 sp ! " sp ! " MVC 1 1Y D Fig. 2. m > 1 : Intersection points Xi, i ∈[1,m] are on β ∗, wherein Xj, 1 < j < m is on X1Xm ⌢. Each Xi has one corresponding decelerating curve αi and one switch point Yi. The region D is enclosed by α1, β ∗and MVC. s s 0 ! MVC s † MVC 1 MVC 2 MVC 3 MVC ! V s p sp ! " 1o 2o Fig. 3. The maximum velocity curve is altered from MVC = MVC1 + MVC2 +MVC3 to MVC∗= MVC1 +MVC† +MVC3. mathematical proofs for Properties 2-3, which have not been reported in existing literatures. Property 1: In the AREM region, any two α-pro files never intersect with each other. Neither do β-pro files. (Please see the proof in [24].) Property 2: In the AREM region, if an α-pro file inter- sects another β-pro file at a point (s = sc, ˙s = ˙sc), in terms of path velocity, the α-pro file is greater than the β-pro file in the left neighborhood of sc, but less than the β-pro file in the right neighborhood of sc. Property 3: In the AREM region, an α-pro file is not tangent to another β-pro file at any point. B. Property of spβ→α The point spβ→α is the intersection point between α-pro file and β-pro file, denoted as the red ⊲in Fig. 2. In the iterative process of NI (see Section II-C), a β-pro file may intersect a finite number of integrated back- ward α-pro files [10]. Which one of these intersection points is finally chosen as spβ→α on the β-pro file? The answer is given in Property 4, which is first presented in this letter with rigorous proof. Property 4: If one β-pro file intersects m ≥1 α-pro files, respectively at points Xi,i ∈[1,m], and in terms of path coordinate, Xi is less than Xj, 1 ≤i < j ≤m, then, X1 is finally chosen as spβ→α on the β-pro file after finite iterations. Remark 1: In Fig. 2, Y1 may be the terminal point (se, ˙se). In this special situation, Property 4 still holds. The case m = 1 obviously holds. Meanwhile, the case m > 1 also holds since the trajectory starting from Xi,i > 1 cannot arrive at the terminal point according to Properties 1-3. In addition, other points Yi, i > 1 cannot be the terminal point (se, ˙se) since NI has completed all procedures at the terminal point (see the procedure NI-3 in Section II-C). □ The Properties 1-4 show the evolution of accelerat- ing/decelerating curves and their intersection points. C. Property of NI with kinematic constraints The original NI method [10] generates a time-optimal trajectory with bounded torque. However, when velocity constraints (bounded actuator velocity and path velocity) are taken into account, the original NI (as shown in Section II-C) may result in a failure. Several examples for this property are shown in the work in [21], [22], but the concrete failure conditions and the detailed proof have not been reported. In the subsequent Property 6, we will elaborate the failure conditions and provide the mathematical proof. Note that Property 5 is first presented and proven to indicate the existence of tangent switch points on the limit curve considering velocity constraints, which is used in the proof of Property 6. Actuator velocity constraints are transformed into path velocity constraints by kinematic models of robots, therefore, velocity constraints are represented as V(s) : s →˙s, s ∈[0,se], (8) where the scalar V(s) is the maximum path velocity. Due to the velocity constraints, the maximum velocity curve is altered as MVC∗(s) = min(MVC(s),V(s)), s ∈[0,se]. (9) In the region enclosed by MVC∗,s = 0,s = se, ˙s = 0, acceler- ating and decelerating curves satisfy all velocity and torque constraints. In addition, the part of MVC∗, which is different from MVC, is represented as MVC†(s)={MVC∗(s)|MVC∗(s) 1. Case 1: m = 1. There is only one intersection point, so the point spβ→α on the β-pro file is X1. This property holds for m = 1. Case 2: m > 1. There are m intersection points as Fig. 2. In terms of path coordinate, the intersection point Xi is less than Xj, 1 ≤i < j ≤m. Each Xi has one corresponding decelerating curve αi and one switch point Yi. According to Property 1, Yi is at the right side of Yj, i < j. If Xi, i > 1 is chosen as spβ→α on β ∗, then, starting from Xi, the trajectory consisting of α-pro files and β-pro files cannot leave the region D, which is enclosed by α1, β ∗and MVC, across α1 due to Properties 1-3. Thus, X1 is chosen as spβ→α on β ∗, which can aid the trajectory to leave the region D along α1 and go on extending to the right side of Y1 with β1. This property holds for m > 1. In summary, Property 4 holds. D. Proof of Property 5 Proof: Due to (10), MVC† is less than MVC. According to the definition of AR, the inequality α(s, ˙s) < β(s, ˙s) holds on MVC†. Then, based on the facts kα = α(s, ˙s)/˙s,kβ = β(s, ˙s)/˙s, the inequality kα < kβ also holds on MVC†, which violates kα = kβ in the definition of tangent switch points (see spα→β in Section II-B). Therefore, tangent switch points on MVC† are nonexistent. REFERENCES [1] E. Barnett and C. Gosselin, “Time-optimal trajectory planning of cable-driven parallel mechanisms for fully-specified paths with G1 discontinuities,” Journal of Dynamic Systems Measurement and Con- trol, vol. 137, no. 7, pp. 603-617, 2013. [2] K. Kim and B. Kim, “Minimum-time trajectory for three-wheeled omnidirectional mobile robots following a bounded-curvature path with a referenced heading profile,” IEEE Transactions on Robotics, vol. 27, no. 4, pp. 800-808, 2011. [3] S. Macfarlane and E. Croft, “Jerk-bounded manipulator trajectory planning: design for real-time applications,” IEEE Transactions on Robotics and Automation, vol. 19, no. 1, pp. 42-52, 2003. [4] K. Shin and N. McKay, “Selection of near-minimum time geometric paths for robotic manipulators,” IEEE Transactions on Automatic Control, vol. 31, no. 6, pp. 501-511, 1986. [5] K. Shin and N. McKay, “A dynamic programming approach to trajec- tory planning of robotic manipulators,” IEEE Transactions Automatic Control, vol. 31, no. 6, pp. 491-500, 1986. [6] S. Singh and M. Leu, “Optimal trajectory generation for robotic ma- nipulators using dynamic programming,” Journal of Dynamic Systems Measurement and Control, vol. 109, no. 2, pp. 88-96, 1987. [7] D. Verscheure, B. Demeulenaere, J. Swevers, J. Schutter, and M. Diehl, “Time-optimal path tracking for robots: A convex optimization approach,” IEEE Transactions on Automatic Control, vol. 54, no. 10, pp. 2318-2327, 2009. [8] K. Hauser, “Fast interpolation and time-optimization with contact,” International Journal of Robotics Research, vol. 33, no. 9, pp. 1231- 1250, 2014. [9] F. Debrouwere, W. Loock, G. Pipeleers, Q. Dinh, M. Diehl, J. Schutter and J. Swevers, “Time-optimal path following for robots with convex- concave constraints using sequential convex programming,” IEEE Transactions on Robotics, vol. 29, no. 6, pp. 1485-1495, 2013. [10] K. Shin and N. Mckay, “Minimum-time control of robotic manipula- tors with geometric path constraints,” IEEE Transactions on Automatic Control, vol. 30, no. 6, pp. 531-541, 1985. [11] J. Bobrow, S. Dubowsky and J. Gibson, “Time-optimal control of robotic manipulators along specified paths,” International Journal of Robotics Research, vol. 4, no. 3, pp. 3-17, 1985. [12] J. Slotine and H. Yang, “Improving the efficiency of time-optimal path-following algorithms,” IEEE Transactions on Robotics and Au- tomation, vol. 5, no. 1, pp. 118-124, 1989. [13] Q. Pham, “A general, fast, and robust implementation of the time- optimal path parameterization algorithm,” IEEE Transactions on Robotics, vol. 30, no. 6, pp. 1533-1540, 2014. [14] F. Pfeiffer and R. Johanni, “A concept for manipulator trajectory planning,” IEEE Journal on Robotics and Automation, vol. 3, no. 2, pp. 115-123, 1987. [15] Z. Shiller, “On singular time-optimal control along specified paths,” IEEE Transactions on Robotics and Automation, vol. 10, no. 4, pp. 561-566, 1994. [16] Q. Pham and O. Stasse, “Time-optimal path parameterization for redundantly actuated robots: A numerical integration approach,” IEEE/ASME Transactions on Mechatronics, vol. 20, no. 6, pp. 3257- 3263, 2015. [17] S. Behzadipour and A. Khajepour, “Time-optimal trajectory planning in cable-based manipulators,” IEEE Transactions on Robotics, vol. 22, no. 3, pp. 559-563, 2006. [18] T. Kunz and M. Stilman, “Time-optimal trajectory generation for path following with bounded acceleration and velocity,” Robotics: Science and Systems, vol. 8, no. 12, pp. 9-13, 2012. [19] H. Nguyen and Q. Pham, “Time-optimal path parameterization of rigid-body motions: Applications to spacecraft reorientation,” Journal of Guidance Control and Dynamics, vol. 39, no. 7, pp. 1667-1671, 2016. [20] Q. Pham and Y. Nakamura, “Time-optimal path parameterization for critically dynamic motions of humanoid robots,” Proceedings of the 2012 IEEE International Conference on Humanoid Robots, pp. 165- 170, 2012. [21] L. ˇZlajpah, “On time optimal path control of manipulators with bounded joint velocities and torques,” Proceedings of the 1996 IEEE International Conference on Robotics and Automation, pp. 1572-1577, 1996. [22] F. Lamiraux and J. Laumond, “From paths to trajectories for multi- body mobile robots,” Proceedings of the 5th International Symposium on Experimental Robotics, pp. 301-309, 1998. [23] T. Kalm´ar-Nagy, “Real-time trajectory generation for omni-directional vehicles by constrained dynamic inversion,” Mechatronics, vol. 35, pp. 44-53. [24] Q. Pham, S. Caron and Y. Nakamura, “Kinodynamic planning in the configuration space via velocity interval propagation,” Proceedings of Robotics: Science and Systems, 2013. [25] C. Bianco and M. Romano, “Optimal velocity planning for au- tonomous vehicles considering curvature constraints,” Proceedings of the 2007 IEEE International Conference on Robotics and Automation, pp. 2706-2711, 2007. [26] G. Birkhoff and G. Rota, “Ordinary differential equations,” Ussr Computational Mathematics Physics, vol. 4, no. 4, pp. 230-232, 1964.