Trajectory Tracking Control for Flexible-Joint Robot Based on Extended Kalman Filter and PD Control
- 1Key Laboratory of Mechanism Theory and Equipment Design of Ministry of Education, Tianjin University, Tianjin, China
- 2School of Mechanical Engineering, Tianjin University, Tianjin, China
- 3Centre for Robotics Research School of Natural and Mathematical Sciences, King's College London, London, United Kingdom
The robot arm with flexible joint has good environmental adaptability and human robot interaction ability. However, the controller for such robot mostly relies on data acquisition of multiple sensors, which is greatly disturbed by external factors, resulting in a decrease in control precision. Aiming at the control problem of the robot arm with flexible joint under the condition of incomplete state feedback, this paper proposes a control method based on closed-loop PD (Proportional-Derivative) controller and EKF (Extended Kalman Filter) state observer. Firstly, the state equation of the control system is established according to the non-linear dynamic model of the robot system. Then, a state prediction observer based on EKF is designed. The state of the motor is used to estimate the output state, and this method reduces the number of sensors and external interference. The Lyapunov method is used to analyze the stability of the system. Finally, the proposed control algorithm is applied to the trajectory control of the flexible robot according to the stability conditions, and compared with the PD control algorithm based on sensor data acquisition under the same experimental conditions, and the PD controller based on sensor data acquisition under the same test conditions. The experimental data of comparison experiments show that the proposed control algorithm is effective and has excellent trajectory tracking performance.
With the increasing use of robots in the fields of industry, the rehabilitation, aviation, and marine exploration, the demand for robots that can adapt to complex environments and enable human-robot interaction is increasing, which introduces flexible structure onto robotic joints (Schiavi et al., 2008; Grioli et al., 2015). The general flexible design is to adopt elastic elements and harmonic reducers to reduce the rigidity of robot joint (Zhu and Schutter, 1999). For higher usage requirements, the flexible cushioning is realized by a variable stiffness driver, and the stiffness performance can be adjusted in a wide range (Wolf and Hirzinger, 2008; Ham et al., 2009; Jafari et al., 2011; Torreaiba and Udelman, 2016). The reduction in the stiffness of the robot increases the safety, but at the same time leads to a reduction in the dynamic performance of the structure, which includes slow response, delayed control, and limited bandwidth. It makes the flexible robot based on variable stiffness more difficult to control (Hogan, 1985; Hurst et al., 2004; Erler et al., 2014).
In recent years, research on the control of flexible-joint robots has become more and more attractive. A spring-damping mode was first proposed to simplify the flexible-joint, and at the same time, the flexible-joint is divided into two subsystems for control by integral flow and perturbation theory (Spong, 1987), and the sliding mode controller was designed (Sira-ramirez and Spong, 1988). Then, based on this model, the robustness analysis of the feedback linearization method suitable for this simplified model was given (Grimm, 1990). A method for compensation system with parameter uncertainty was desidned (Zeman et al., 1997; Ge et al., 1998). To reduce the number of differentials required for motion equations and task equations the design method for task space tracking control and proposed an implicit numerical integration method was proposed which is effective (Ider and Ozgoren, 2000). The impedance model formed on the basis of the simplified spring- damping model is considered to be a typical compliant control strategy, that is, cross-compatibility is achieved through the interaction between the robot system and the external environment, allowing a certain degree of partial movement of the actual trajectory and a given trajectory (Jamwal et al., 2016; Losey et al., 2016). In order to control the robot trajectory more precisely, the effects of flexible properties on the dynamic performance of robots was systematically analyzed (Zaher and Megahed, 2015), and the control problems of flexible-joint robot position, torque, and impedance control based on passivity were studied (Albu- schäffer et al., 2007). However, these control models are somewhat stretched when it comes to external disturbances and non-linear systems.
In order to solve the problem of jitter and friction in flexible robot tracking control, the adaptive CFBC (command-filtered backstepping control) was proposed to improve tracking accuracy (Pan et al., 2018). For the purpose of solving the interference problem of control, the ADRC (Active Disturbance Rejection Control) was designed based on the modern control theory which relies on the accurate mathematical model, that can effectively control the system with uncertainty and external interference (Han, 2009). However, more parameters need to be calculated for non-linear systems. The disturbance observer proposed by Ohnishi in 1987 can be used for the disturbance that is difficult to measure in the system (Nakao et al., 1987). The external disturbance is estimated by the input amount and the feedback value of the inner loop, as the observation compensation amount, and it is added to the control to cancel the actual interference (Sariyildiz and Ohnishi, 2013; Sariyildiz et al., 2015). However, as the order for the filter increases, the large phase lag causes the system to be underdamped and even makes the system unstable.
Throughout the above control methods, the classic PD controller, with its “natural” anti-interference and model-independence, is widely used in the control of series elastic actuators by matching feedforward control (Zhu et al., 2012). It is worth noting that the PD controller relies on the data feedback of the system, therefore, its performance can be greatly affected by external disturbance introduced via sensory collection, and moreover, the use of multiple sensors increases the cost and structural design difficulty of the robot.
In order to solve the above problems, this paper first proposes the state estimation of non-linear stiffness-driven flexible robot with EKF, as it has good convergence and low computational complexity, and can handle system uncertainty and external disturbances in real time (Reif et al., 1998; Lightcap and Banks, 2010). This method can reduce the use of the sensor and introduce noise covariance into the observer design to reduce estimation error. Considering the external disturbance, a closed-loop PD controller based on EKF is designed to achieve precise position control that requires only joint motor side position and speed measurements.
This paper is organized as follows. The model, principle and dynamics analysis of the flexible-joint robot are introduced in section Robotic Prototype and its Dynamic Model. Subsequently, the design of the closed-loop PD controller and EKF state observer is introduced in section EKF Based Controller. The stability analysis based on Lyapunov method is presented in section Lyapunov Stability Analysis. The experimental results are presented in section Experimental Results. Finally, a conclusion is provided in section Conclusion.
Robotic Prototype and Dynamic Model of Robot
In order to demonstrate our method, a 3-DOF robot with flexible joint is introduced in this section to verify the algorithm. As shown in Figure 1, the robot can be regarded as an open-chain series connected by two rotations and one moving joint. In the linkage system, each joint is driven by a non-linear actuator, and the third joint turns the rotation of the joint into translation through the slider and the guide rail.
Since the control target of this paper is the trajectory output of the tip, based on the configuration of the robot, the variables of the three joints are respectively calculated by the inverse kinematics according to the desired trajectory output, and the three joints are respectively controlled according to the timing.
The structure of the three actuators is basically the same. In this paper, the first joint actuator is taken as an example to introduce the structure. As shown in Figure 2A, the structure of the non-linear stiffness actuator mainly includes the support frame, motor combination (DC brushless motor, reducer, encoder), pulley, outer cylinder, wire, inner cylinder, and elastic structure. The motor is the power source driving the pulley, which drives the outer cylinder through the wire. The inner wall of the outer cylinder is provided with a radially uniform roller shaft, and the rotation of the roller presses and fixes the bidirectional elastic structure fixed on the inner cylinder, thereby driving the inner cylinder to rotate.
The non-linear elastic structure is shown in Figure 2B, the non-linear elastic structure is the core mechanical structure of the non-linear stiffness actuator and consists of a roller and an elastic component. The elastic component is composed of symmetrical elastic units, each of which consists of a cantilever beam portion and a contact portion. Although the two parts are made of the same material, when the roller presses the contact portion, the deformation of the contact portion can be regarded as a rigid structure, and the cantilever beam portion is deformed, and the deflection and the deflection angle of the elastic portion will cause the position of the contact point to change. There is a certain mapping relationship between the positional change of the contact point caused by the deflection perpendicular to the end of the cantilever beam portion and the pressing force.
In addition, the change of the deflection angle also affects the vertical component of the contact point position. Therefore, the relationship between the positional change in the vertical direction of the contact point and the pressing force is no longer a simple proportional relationship, but the combination of the deflection and the deflection angle. In short, the contour curve of the contact surface determines the relationship between the pressing force and displacement of the contact point, that is, the stiffness variation curve. The specific design scheme and the non-linear mechanism have been deeply studied by the researcher group (Lan and Song, 2016), and this paper will not go into details.
Non-linear stiffness actuator can be divided into power systems, transmission systems, elastic structures, and external loads. The power system is the motor combination, which mainly includes the motor rotor and the gear reducer. The equivalent moment of inertia of the motor combination can be obtained from the dynamics model of the motor combination. The dynamic equation of the rotor of the motor is:
where Jr and br are the moment of inertia and damping of the rotor of the motor respectively; and are the angular velocity and angular acceleration of the rotor of the motor respectively; τm is the torque generated by the rotor of the motor; τr is the torque output by the rotor of the motor.
The dynamic equation of the motor reducer is:
where Jg and bg are the moment of inertia and damping of the motor reducer respectively; and are the angular velocity and angular acceleration of the motor reducer respectively; R1 is the reduction ratio; τg is the torque output by the motor reducer.
Since the motor rotor and the gear reducer are rigidly connected, the following relationship is used:
where θr and θg are the motor rotor angle and the gear reducer angle respectively. Combined with Equations (1–4) can be obtained:
The schematic diagram of the actuator from the motor combination to the output is shown in Figure 3.
The dynamic equation of the outer cylinder section is:
where: Jw and bw are the moment of inertia and damping of the outer drum, respectively; and are the angular velocity and angular acceleration of the output shaft of the outer drum of the non-linear stiffness drive, respectively; R2 is the reduction ratio of the wire drive, and the relationship between the angular velocity and the angular velocity of the outer cylinder is:
where θw is the angle of rotation of the outer cylinder for the non-linear stiffness drive, simultaneous Equations (4–6) can obtain:
Then the equivalent dynamic equation of the motor assembly to the elastic part is:
where is the actuator equivalent inertia and is the actuator equivalent damping.
The dynamic equation of the outer cylinder part is:
where: Je and be are the moment of inertia and damping of the external load, respectively; τe is the output torque of the drive; and are the angular velocity and angular acceleration of the external load, respectively.
Ekf Based Controller
Equation of State
It can be seen from the above formula that the dynamic equation from the motor to the output shaft without considering the external torque input is:
The EKF based PD controller is shown in Figure 4.
In the control system, τm can be considered to consist of two parts:
where τdy is the part consumed by the equilibrium dynamics, and its expression is:
τd is the torque required for the end output, which is output by the PD controller. The design expression is as follows:
where Kp is the proportional stiffness coefficient and Kd is the differential damping coefficient, substituting (11–13) into (10), we can get:
It can be simplified to:
where ; ; b0 = 0; ; .
The formula is a typical input-output equation with a derivative term, so the state variables are chosen as follows:
where h1 = b1 − a1b0, then the equation of state of the system is:
where h2 = (b2 − a2b0) − a1h1, rewritten into a matrix form:
Ekf State Observer Design
According to the control frame we designed in the previous section, we can see that the PD position controller based on EKF requires the output shaft angle and angular velocity to be the feedback amount. In order to solve the sensor's measurement interference, cost, and structural design issues, we use the EKF state observer to predict the angle of the output shaft and the angular velocity. The inputs are only the angle and angular velocity of the motor. The angular acceleration is obtained from the first derivative of the angular velocity and filtered by a low-pass filter to eliminate high-frequency interference.
According to , the relationship between the output torque of the elastic component and the rotor angle of the motor and the output angle of the shutdown section is as follows:
Then the overall dynamic equation can be written as:
According to the formula, it can be seen that the experimental platform of this paper is a typical non-linear system. According to the EKF observation method in document , combined with the control objectives of this paper, the state variables are defined as:
Deriving it to time t and substituting it into the dynamics equation, we get the state function f(x):
where ; We can obtain state function by partial differentiation of equation (23):
where ; ; ; ; ;
Define the observation vector as:
Then the state observation matrix is:
The EKF iteration formula is as follows:
where is the predicted estimate of x; Q(t) and R(t) are the process noise and measurement noise obeying the Gaussian distribution; G(t) is the extended Kalman gain, and P(t) is the predicted error covariance. Without external disturbance, we can accurately capture the information we need to know through the sensor, but in the presence of external noise and unknown factors, our prediction will be biased. After each prediction, the EKF state observer adds new uncertainty to establish a connection with external disturbances, that is, the measurement covariance R(t) and system covariance Q(t) obeying the Gaussian distribution. The end of the robot may be affected by other disturbances. By establishing different observation matrices, we can reasonably estimate and compensate for the disturbance force experienced by the robot joints.
Lyapunov Stability Analysis
According to the research of extended Kalman filter, the stability of the control system of the flexible joint robot proposed in this paper is that the overall PD control system is stable, and the EKF observer is stable. The system stability analysis in this paper is divided into the following two steps:
Step 1: Proof of PD controller stability.
The Lyapunov method is used to prove the stability of the controller. Therefore, the previous system state Equation (18) can be written as:
Define the Lyapunov equation as:
where E is unit matrix, then U can be contained:
It is a positive definite matrix. Then the derivative of the Lyapunov equation is:
Through the adjustment of the PD parameters, it can make . The PD controller system is stable, and the intermediate calculation process will not be described in detail herein.
Step 2: Proof of EKF observer stability
Defining observation error: .
Expand f(x) and h(x):
where α and β are the higher order terms of μ, then:
Define the Lyapunov equation as:
where Π = P−1, then:
Assumption: , ,, ,,, where kα, kβ, , , , and are positive constants.
Lemma: According to the assumptions, there are ε > 0 and κ > 0, then:
for any ‖μ‖ that satisfies ‖μ‖ ≤ ε
Proof: According to Π = P−1 and assumption, it can be obtained that:
Using triangular inequalities, G = PHTR−1, Π = P−1, and ‖μ‖ ≤ ε, it can be obtained that:
Inequality can be obtained as follows according to assumption:
According to the lemma and G = PHτR−1, we can obtain that:
where i > 0, for any ‖μ‖ that satisfies , we can obtain that:
By using separation variable method, we can obtain that
so Ẇ(t) < 0. According to the inequality , we can get the solution:
That is, the EKF state observer is exponentially stable.
In summary, step 1 and step 2 respectively prove that the PD control system is stable and the EKF state observer is stable. Therefore, the stability of the incomplete state feedback control system of the entire flexible joint robot is proved.
In this part, the proposed control algorithm is applied to the prototype to prove the feasibility and stability of the control algorithm to compare with the sensor-based PD trajectory controller under the same experimental conditions.
A 64-bit-Windows-8.1-based host computer with an Intel Core i7 processor @2.40 GHz and 8-GB RAM is used to run the Kalman estimation and calculate the input torque to the motor. The control algorithm is able to operate on an execution rate of 1 kHz using Visual C++ 2010, which is enough for real-time applications. The DSP board is used to read, process, and calculate the signal from the motor encoder and transmit it to the computer, that is, obtain the real-time position information of the motor through the QEP module of the DSP chip. Then the results calculated by the host computer are sent to the DSP board through a RS232 serial port. The DSP board then converts the input torque command into a PWM wave signal to drive the motor, and the A-D electromagnetic tracking system (trakSTAR, produced by NDI) is used to measure the position of the robot end. Through the USB cable, the location data is sent to the host for comparative verification of the experimental results. The entire experimental platform is shown in Figure 5.
For the fairness of the experiment and the validity of the comparison verification, the experiment was carried out in the same environment using the same machine, and the same PD controller parameters were used. The desired trajectory is a closed circular trajectory. The trajectory tracking results are shown in Figure 6.
Figure 6. Experimental results (A) EKF-based PD controller experimental result. (B) Sensor-based PD controller experimental result.
To further analyze the experimental data, define the error mean square error:
where ξe(t) and ξexp(t) represent the actual trajectory and the desired trajectory, respectively.
Through the experimental results shown in Figures 6–8, we can see that the mean square value of the trajectory tracking error of the PD controller based on EKF is smaller, and tracking error of each joint is also smaller, which indicates that under the same conditions, the control algorithm proposed in this paper has better control effect.
Figure 7. Trajectory tracking variance mean square. (A) EKF-based PD controller trajectory tracking variance mean square. (B) Sensor-based PD controller trajectory tracking variance mean square.
Figure 8. Comparison of tracking error of each joint. (A) First joint tracking error comparison. (B) Second joint tracking error comparison. (C) Third joint tracking error comparison.
The EKF observer in the control system can handle external disturbances in real time. In order to prove its ability to handle real-time interference, a force of sinusoidal variation along the direction of the guide rail is applied at the end of the robot. The force changes are shown in Figure 9. The experimental results are shown in Figures 10–12.
Figure 10. Experimental results with disturbance force (A) EKF-based PD controller experimental result. (B) Sensor-based PD controller experimental result.
Figure 11. Trajectory tracking variance mean square with disturbance force. (A) EKF-based PD controller trajectory tracking variance mean square. (B) Sensor-based PD controller trajectory tracking variance mean square.
Figure 12. Comparison of tracking error with disturbance force of each joint. (A) First joint tracking error comparison. (B) Second joint tracking error comparison. (C) Third joint tracking error comparison.
From Figures 10–12, we can see that in the case of external disturbance, the control result based on EKF observer is more stable, and the position deviation of the robot end is almost unchanged, which means that the control based on EKF observer can effectively Handle external interference in real time.
In this paper, the trajectory tracking control problem of flexible joint robot is discussed. Aiming at the problem that sensor data acquisition is susceptible to interference, an EKF-based PD controller is proposed. The EKF state observer is designed for the control target to observe the output position, and only the position and speed feedback amount of the motor rotor is needed. And the stability analysis of the designed control system is given according to the Lyapunov method. Finally, the effectiveness and superiority of the proposed control algorithm are verified by experiments.
All datasets generated for this study are included in the manuscript and/or the supplementary files.
TM: theoretical analysis. ZS: guide control plan. ZX: guide doing experiment. JD: guide writing paper.
Conflict of Interest Statement
The authors declare that the research was conducted in the absence of any commercial or financial relationships that could be construed as a potential conflict of interest.
This work was supported by Tianjin Municipal Science and Technology Department Program (Grant No. 17JCZDJC30300), the Natural Science Foundation of China (Project No. 51475322), and the Programme of Introducing Talents of Discipline to Universities (111 Program) under Grant No. B16034.
Albu- schäffer, A., Ott, C., and Hirzinger, G. (2007). A unified passivity-based control framework for position, torque and impedance control of flexible joint robots. Int. J. Robot. Res. 26, 23–39. doi: 10.1177/0278364907073776
Erler, P., Beckerle, P., Strah, B., and Rinderknecht, S. (2014). Experimental comparison of nonlinear motion control methods for a variable stiffness actuator. Biomed. Robot. Biomech. 2014, 1045–1050. doi: 10.1109/BIOROB.2014.6913918
Grioli, G., Wolf, S., Garabin, M., Catalano, M., Burdet, E., Caldwell, D., et al. (2015). Variable stiffness actuators: the user's point of view. Int. J. Robot. Res. 34, 727–743. doi: 10.1177/0278364914566515
Hurst, W., Chestnutt, E., and Rizzi, A. (2004). “An actuator with physically variable stiffness for highly dynamic legged locomotion,” in IEEE International Conference on Robotics and Automation, ICRA 2004, April 26 - May 1, 2004, New Orleans, LA, 4662–4667.
Jafari, A., Tsagarakis, N. G., and Caldwell, G. (2011). “AwAS-II: a new actuator with adjustable stiffness based on the novel princi-ple of adaptable pivot point and variable lever ratio,” in IEEE International Conference on Robotics and Automation, Piscat-away, NJ: IEEE Press, 4638–4643.
Jamwal, K., Hussain, S., Ghayesh, H., Rogozina, S. V., et al. (2016). Impedance control of an intrinsically compliant parallel ankle rehabilitation robot. IEEE Trans. Indus. Electron. 63, 3638–3647. doi: 10.1109/TIE.2016.2521600
Lightcap, C. A., and Banks, S. A. (2010). An extended Kalman filter for real-time estimation and control of a rigid-link flexible-joint manipulator. IEEE Trans. Control Syst. Technol. 18, 91–103. doi: 10.1109/TCST.2009.2014959
Losey, P., Erwin, A., Mcdonald, G., Sergi, F., and O'Malley, M. K. (2016). A time-domain approach to control of series elastic actuators: adaptive torque and passivity-based impedance control. IEEE/ASME Trans. Mech. 21, 2085–2096. doi: 10.1109/TMECH.2016.2557727
Nakao, M., Ohnishi, K., and Miyachi, K. (1987). “A robust decentralized joint control based on interference estimation,” in IEEE International Conference on Robotics and Automation. Piscataway, NJ: IEEE Press, 326–331.
Pan, Y., Wang, H., Li, X., and Yu, H. (2018). Adaptive command-filtered backstepping control of robot arms with compliant actuators. IEEE Trans. Control Syst. Technol. 26, 1149–1156. doi: 10.1109/TCST.2017.2695600
Sariyildiz, E., Chen, G., and Yu, H. (2015). “Robust position control of a novel series elastic actuator via disturbance observer,” in IEEE/RSJ International Conference on Intelligent Robots and Systems, Piscataway, NJ: IEEE Press, 54235428.
Schiavi, R., Grioli, G., and Sen, S. (2008). “VSA-III: a novel proto-type of variable stiffness actuator for safe and performing robots interacting with humans,” in IEEE International Conference on Robotics and Automation, Piscataway, NJ: IEEE Press, 71–2176.
Torreaiba, R., and Udelman, B. (2016). Design of cam shape for maximum stiffness variability on a novel compliant actuator using differential evolution. Mech. Mach. Theory 9 5, 114–124. doi: 10.1016/j.mechmachtheory.2015.09.002
Wolf, S., and Hirzinger, G. (2008). “A new variable stiffness design: Matching requirements of the next robot generation,” in IEEE International Conference on Robotics and Automation, Piscataway, NJ: IEEE Press, 17411–17746.
Keywords: flexible joint, extended Kalman filter, closed-loop PD controller, lyapunov stability, trajectory tracking
Citation: Ma T, Song Z, Xiang Z and Dai JS (2019) Trajectory Tracking Control for Flexible-Joint Robot Based on Extended Kalman Filter and PD Control. Front. Neurorobot. 13:25. doi: 10.3389/fnbot.2019.00025
Received: 26 March 2019; Accepted: 30 April 2019;
Published: 24 May 2019.
Edited by:Yongping Pan, National University of Singapore, Singapore
Reviewed by:Jie Ling, Wuhan University, China
Xinan Pan, Shenyang Institute of Automation (CAS), China
Copyright © 2019 Ma, Song, Xiang and Dai. This is an open-access article distributed under the terms of the Creative Commons Attribution License (CC BY). The use, distribution or reproduction in other forums is permitted, provided the original author(s) and the copyright owner(s) are credited and that the original publication in this journal is cited, in accordance with accepted academic practice. No use, distribution or reproduction is permitted which does not comply with these terms.
*Correspondence: Zhibin Song, email@example.com