International Journal of Computers, Communications & Control Vol. III (2008), No. 1, pp. 80-89 Adaptive Compensation of Friction Forces with Differential Filter Kouichi Mitsunaga, Takami Matsuo Abstract: In this paper, we design an adaptive controller to compensate the non- linear friction model when the output is the position. First, we present an adaptive differential filter to estimate the velocity. Secondly, the dynamic friction force is compensated by a fuzzy adaptive controller with position measurements. Finally, a simulation result for the proposed controller is demonstrated. Keywords: nonlinear friction, adaptive controller, fuzzy basis function expansion, adaptive differential filter. 1 Introduction Friction is one of the greatest obstacles in high precision positioning systems. Since it can cause steady state and tracking errors, its influence on the response of the systems must be considered seriously ([10]). Many friction models have been proposed that differ on the friction effects that are modeled in a lubricated contact. These models are divided into two categories: the kinetic and dynamic friction models. The kinetic friction models take into account the friction effects such as the viscous friction, the Coulomb friction, and the Stribeck effect. Another category of friction model includes dynamic friction model that embody the natural mechanism of friction generation such as the LuGre model ([2]). The coefficients of the various friction-related effects are usually very difficult to measure. A num- ber of methods for friction estimation and compensation have been proposed for these models: adaptive control, joint torque control, learning control, variable structure control, and so on. Friedland et al.[5] proposed a reduced-order nonlinear observer to estimate the velocity-dependent coefficient of the clas- sical nonlinear friction model with velocity measurements. Huang et al.[9] presented an adaptive radial basis function observer to compensate for the effects of the dynamic friction model full-states measure- ments. Tomei[15] considered the tracking problem for robot manipulators with unknown parameters and dynamic LuGre model using full-states information. Ge et al.[6] presented adaptive controllers by combining neural network parameterization, dual observer for state estimation/stability and adaptive control techniques based on the dynamic LuGre friction model. Sato et al.[14] proposed an adaptive friction compensation method with an H∞ performance using the neural network approximation that is equivalent to the radial basis function approximation or fuzzy basis function approximation. They used the neural network approximation to parameterize the nonlinear characteristics of the dynamic LuGre model. A sliding-mode type error function is introduced that requires full-states measurements. Canudas de Wit et al.[3] designed an observer-based adaptive friction compensation scheme for systems with generalized position/velocity static characteristics based on full stats measurement. The proposed con- troller guarantees the global asymptotic stability of the tracking error while preserving boundedness of all the internal signals. The nonlinear friction is approximated either by a linear span of set of contin- uous known function, or by a neural network of bounded basis function. Putra et al.[12] proposed an observer-based friction compensation for a class of the kinetic friction models with known system param- eters based on the strictly positive real condition. In the case of partial-states measurements, an adaptive estimator that does not require the strictly positive realness of the plants is needed. Ray et al.[13] pre- sented a non-model-based friction estimation method using extended Kalman-Bucy filtering. The filter is used to estimate a friction force with the full-states measurements. For the classical nonlinear friction model without velocity measurements, Xia et al.[17] employed a velocity observer based on state space nonlinear friction model and designed an adaptive controller that achieved a semi-global asymptotically stability. The velocity observer is a model-based estimator that requires plant parameters to estimate the velocity. Park et al.[11] proposed a non-model-based differential filter of a nonlinear function based on Copyright © 2006-2008 by CCC Publications Adaptive Compensation of Friction Forces with Differential Filter 81 the adaptive control theory. The proposed differential filter is applied to estimate the time-derivative of a nonlinear function of the intensity for each pixel to detect moving objects within a scene acquired by a stationary camera. In estimating the friction forces, the differential filter is applicable to estimate the velocity with the position measurements. In this paper, we design a friction compensator with the position measurement. To begin with, an adaptive differential filter that is a non-model based adaptive algorithm to estimate the derivative of a signal, is designed to estimate the velocity signal. Next, the velocity signal in friction compensator proposed by Canudas de Wit et al.[3] is replaced by the estimate of the adaptive differential filter. Finally, a simulation result of the proposed compensator is presented. From the simulation result, it is shown that the proposed compensator is robust against additive noises. 2 Adaptive differential filter The velocity information is the most important data to estimate and compensate the friction forces. Most of the conventional papers assume that the velocity is measurable. If the velocity information is not available, we have to estimate the velocity signal. Park et al.[11] proposed the adaptive estimator of the time-derivative of an output that is called the adaptive differential filter. Their estimator causes the estimation error in the case of fast time-varying signals. In this paper, we present another adaptive differential filter applicable to fast time-varying signals. Let y(t) be a measurement signal at a time t and f (y(t)) be its nonlinear function. We define θT (t) as the derivative with respect to time of the nonlinear function f (y(t)), i.e. θT (t) = d f (y(t)) dt = d f (y) dy dy(t) dt . (1) If d f (x)dx has the inverse ( d f (x) dx )−1 , we have ẏ(t) = θT (t)ξ (t), (2) ξ (t) = ( d f (y) dy )−1 . (3) The problem is defined as follows: Problem 1. Design a differential filter to estimate the derivative, θT (t), of the nonlinear function f (y(t)) with available signal y(t) and without any knowledge of its dynamics. If the signal ξ (t) is available, Problem 1 is equivalent to the estimation problem of the time-varying parameter θT in Eq.(2) with the available signals y(t) and ξ (t). It is assumed that the time-varying parameter in (2) is satisfied the following inequality: |θT (t)−θT 0| ≤ εT 0 where θ0 is an unknown constant, and ε0 is a known constant. Eq.(2) can be rewritten as ẏ = θT 0ξ (t) + εT (t)ξ (t) (4) where εT (t) = θT (t)−θT 0. We give an adaptive observer as ˙̂yT = −k(ŷT −y) + θ̂T (t)ξ (t)− ε̂T (t)sgn(ŷT −y)|ξ (t)| (5) where k > 0. Defining the observer error as eT (t) = ŷT (t)−y(t), we obtain the error system as ėT = −keT + θ̃T (t)ξ (t)− ε̂T (t)sgn(eT )|ξ (t)|−εT (t)ξ (t) (6) 82 Kouichi Mitsunaga, Takami Matsuo where θ̃T (t) = θ̂T (t)−θT 0. The parameter update laws are selected as ˙̃θT (t) = ˙̂θT (t) = −γ eT (t)ξ (t) (7) ˙̂εT (t) = |eT (t)||ξ (t)| (8) where γ > 0. We can prove the following lemma: Lemma 1. Consider the error system (6). The parameter update laws guarantee the stability of the origin of the error system as follows: eT (t) → 0 (t → ∞). Moreover, if limt→∞ėT (t) = 0, then limt→∞θ̃T ε (t) = 0, where θ̃T ε (t) = θ̂T (t)−θT (t). Proof: The whole system can be written by ėT = −keT + θ̃T (t)ξ (t)− ε̂T (t)sgn(eT )|ξ (t)|−εT (t)ξ (t) ˙̃θT = −γ eT ξ (t) ˙̂εT = |eT ||ξ (t)|. Define a Lyapunov-like function as V1 = 1 2 ( e2T (t) + 1 γ θ̃ 2T (t) + ε̃ 2 T (t) ) where ε̃T (t) = ε̂T (t)−εT 0. Its time derivative is given by V̇1 = eT ėT + 1 γ θ̃T ˙̃θT + ε̃T ˙̂εT = eT (−keT + θ̃T (t)ξ (t)− ε̂T (t)sgn(eT )|ξ (t)| −εT (t)ξ (t)) + 1 γ θ̃T ˙̃θT + ε̃T ˙̂εT = −ke2T + θ̃T ( eT ξ (t) + 1 γ ˙̃θT ) −eT ε̂T sgn(eT )|ξ (t)| −eT εT ξ (t) + ε̂T ˙̂εT −εT 0 ˙̂εT = −ke2T −(eT εT ξ (t) + eT εT 0sgn(eT )|ξ (t)|) = −ke2T −(eT εT ξ (t) + εT 0|eT ||ξ (t)|) ≤ −ke2T +|eT ||εT ||ξ|−εT 0|eT ||ξ (t)| ≤ −ke2T ≤ 0. Hence, we have eT ∈ L2 ∩ L∞, θ̃T ∈ L∞, ε̃T ∈ L∞. Since eT ∈ L∞, θ̃T ∈ L∞, ε̃T ∈ L∞, we have ėT ∈ L∞. From Barbalat’s lemma, we conclude that limt→∞ eT (t) = 0. Moreover, setting u as uT = θ̃T (t)ξ (t)− ε̂T (t)sgn(eT )|ξ (t)|−εT (t)ξ (t), the error dynamics can be expressed in a first-order system: ėT (t) = −keT (t) + uT (t). Adaptive Compensation of Friction Forces with Differential Filter 83 If limt→∞ėT (t) = 0, then lim t→∞ (θ̂T (t)−θT 0 −εT (t)) = lim t→∞ (θ̂T (t)−θT (t)) = 0. We obtain the estimator for the differential of the signal y(t) by selecting the nonlinear function f (y(t)) as the linear function f (y(t)) = y(t). In this case, the regressor signal ξ (t) is equal to 1. The adaptive observer and the update laws are given by ˙̂yT = −k(ŷT −y) + θ̂T (t)− ε̂T (t)sgn(ŷT −y) (9) ˙̂θT (t) = −γ eT (t), ˙̂εT (t) = |eT (t)| (10) where eT (t) = ŷT (t)−y(t). Thus, we get the estimate of the differential of the signal y(t) as ˆ̇y = θ̂T = − ∫ t 0 γ eT (τ)dτ. (11) We call this estimator (11) the adaptive differential filter. 3 Nonlinear friction model Canudas de Wit et al. present a new dynamic friction model that captures dynamic friction effects (the Gahl effect, frictional memory, stick-slip motion) as well as steady state friction effects, including the Stribeck effect ([2, 8]). The interface between two surfaces is modeled by contact between sets of bristles. If z represents the average bristle deflection, ẏ the velocity between two surfaces, the friction force Ff can be expressed as Ff = σ0z + σ1ż + σ2ẏ ż = −α(ẏ)|ẏ|z + ẏ α(ẏ) = σ0 fc + ( fs − fc) exp{−(ẏ/ẏs)2} where σ0 is the stiffness for deflection angle, σ1 the damping coefficient for slip, σ2 the viscous friction coefficient, fc the Coulomb friction level, fs the level of the stiction force, and ẏs the Stribeck velocity. The system under discussion is the following equation: Mÿ(t) + Ff (t) = u(t) (12) where M is known and Ff is unknown. As in Canudas de Wit et al.[3], the nonlinear function α(ẏ) is approximated by FBFE as α(ẏ) = kT ζ (ẏ) + ε f (13) k = [ k1, ··· , kM ]T (14) ζ (ẏ) = [ ζ 1(ẏ), ··· , ζ M(ẏ) ]T (15) where ε is the approximation error and ζ j is defined as ζ j(ẏ) = µA j (ẏ(t)) ∑Mj=1 µA j (ẏ(t)) . where the membership functions are selected as the Gaussian functions: µA j (v) = exp(− (v− v̄ j)2 2σ 2j ) σ j = σ , j = 1,··· , M. The approximation error is assumed to be bounded and sufficiently small. 84 Kouichi Mitsunaga, Takami Matsuo 4 Controller design Consider the tracking control problem of system (12) under the assumption that (i) the parameters M, σ0, σ1, σ2 are known and the nonlinear function α(ẏ) in unknown. The desired trajectory yd is smooth enough and bounded. The tracking error and its derivatives are defined as e = yd −y, ė = ẏd − ẏ, ë = ÿd − ÿ. 4.1 Adaptive controller with full-states measurements We review the adaptive controller proposed by Canudas de Wit et al.[3] with full-states measure- ments. They presented the internal state observer for the average bristle deflection as: ˙̂z = ẏ− k̂T ζ (ẏ)|ẏ|ẑ + k0z̃ + k1e (16) z̃ = m σ1 ė + Kd −mρ σ1 e + e f (17) ė f = −ρ e f + cρ e (18) where ẑ is the estimate of the average bristle deflection and k0 > 0, k1 > 0, c = Kp−ρ Kd +mρ 2 σ0 . Defining the estimation error of the average bristle deflection as z̃ = z− ẑ, (19) we have the following estimation error equation: ˙̃z = −α(ẏ)|ẏ|z̃− k̃T ζ (ẏ)|ẏ|ẑ−k0z̃−k1e (20) where k̃ = k − k̂. The controller is given as follows[3] u = mÿd + H(p)e + F̂f (21) F̂f = σ0ẑ + σ1 ˙̂z + σ2ẏ (22) where H(p) is the following differentiator: H(p) = Kd p + Kp, p = d dt . (23) Moreover, we obtain the tracking error equation as më + Kd ė + Kpe = σ1 ˙̃z + σ0z̃. (24) We give the same adaptive update law as in [3]: ˙̂k = −Γ 1 k1 ζ (ẏ)|ẏ|z̃ẑ. (25) 4.2 Adaptive controller with position measurements In the position measurement case, we use the estimate ˆ̇y of the adaptive differential filter instead of the velocity signal ẏ. They presented the internal state observer for the average bristle deflection as: ˙̂z = ˆ̇y− k̂T ζ ( ˆ̇y)| ˆ̇y|ẑ + k0z̃ + k1e (26) z̃ = m σ1 ˆ̇e + Kd −mρ σ1 e + e f (27) ė f = −ρ e f + cρ e (28) Adaptive Compensation of Friction Forces with Differential Filter 85 where ˆ̇y is the estimate of the velocity by the adaptive differential filter and ˆ̇e = ẏd − ˆ̇y. Defining the estimation error of the adaptive differential filter ε as ε = ˆ̇y− ẏ, we have ˆ̇e = ė−ε. We have the following estimation error equation: ˙̃z = −α(ẏ)|ẏ|z̃− k̃T ζ ( ˆ̇y)| ˆ̇y|ẑ−k0z̃−k1e−kT ε 0ẑ−ε (29) where k̃ = k − k̂ and ε 0 is caused by estimation error of the adaptive differential filter. Moreover, we obtain the tracking error equation as më + Kd ė + Kpe = σ1 ˙̃z + σ0z̃ + (Kd −σ2)ε. (30) The controller is given as follows: u = Mÿd + Kd ˆ̇e + Kpe + F̂f (31) F̂f = σ0ẑ + σ1 ˙̂z + σ2 ˆ̇y. (32) Replacing the velocity signal by its estimate of the adaptive differential filter, the adaptive update law is given by: ˙̂k = −Γ 1 k1 ζ ( ˆ̇y)| ˆ̇y|z̃ẑ. (33) 4.3 Simulation example Next example is the following LuGre model: M = 10, σ0 = 5, σ1 = 2 √ 5, σ2 = 0.01, fc = 1, fs = 1.5, vs = 0.1. The initial conditions are selected as y(0) = 0, ẏ(0) = 0.2, z(0) = 1. The desired reference signals yd , ẏd , ÿd are given by yd = 3 sin 0.02πt, ẏd = 0.06π cos 0.02πt, ÿd = −0.0012π sin 0.02πt. The parameters of the fuzzy basis function are selected as follows: σ j = 0.5( j = 1,··· , 5), v̄1 = −1, v̄2 = −0.5, v̄3 = 0.0, v̄4 = 0.5, v̄5 = 1. The parameters of the adaptive differential filter is given by k = 1, γ = 0.5. The simulation parameters of the compensator are selected as follows: Kd = Kp = 1, k0 = 1, k1 = 0.1, Γ = 50   1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 1   . 86 Kouichi Mitsunaga, Takami Matsuo 0 50 100 150 200 250 300 −3 −2 −1 0 1 2 3 time[sec] o u t p u t a n d i t s r e f e r e n c e [ m ] 0 50 100 150 200 250 300 −3 −2 −1 0 1 2 3 time[sec] o u t p u t a n d i t s r e f e r e n c e [ m ] Figure 1: The output y(solid line) and its desired reference yd (dotted line) in the time range [0, 300]. Left: noise free ,Right: additive noise N(0, 10−4). 0 20 40 60 80 100 −3 −2 −1 0 1 2 3 time[sec] o u t p u t a n d i t s r e f e r e n c e [ m ] 0 20 40 60 80 100 −3 −2 −1 0 1 2 3 time[sec] o u t p u t a n d i t s r e f e r e n c e [ m ] Figure 2: The output y(solid line) and its desired reference yd (dotted line) in the time range [0, 100]. Left: noise free ,Right: additive noise N(0, 10−4). The simulation is carried out in the noise free case and in the case where the output yd with the additive noise N(0, 10−4). Figure 1 shows the outputs y(solid line) and its desired references yd (dotted line) in the time range [0, 300] in both cases. Figure 2 shows the outputs y(solid line) and its desired references yd (dotted line) in the time range [0, 100] in both cases. Figure 3 shows the velocities ẏ(solid line) and its estimates ŷ by the adaptive differential filter (dotted line) in both cases. Figure 4 shows the inputs u in both cases. Figure 5 shows the friction force(solid line) and its estimate(dotted line). From these figures, the proposed friction compensator is robust against the additive noise. 5 Conclusion We proposed the adaptive differential filter and its application to friction compensation. Specifically, the velocity information in the friction compensator proposed by Canudas de Wit et al.[3] is replaced by the estimate with the adaptive differential filter. From the simulation results, the proposed friction compensator is robust against the additive noise. Adaptive Compensation of Friction Forces with Differential Filter 87 0 50 100 150 200 250 300 −0.4 −0.2 0 0.2 0.4 0.6 0.8 1 time[sec] v e l o c i t y a n d i t s e s t i m a t e [ m / s e c ] 0 50 100 150 200 250 300 −0.4 −0.2 0 0.2 0.4 0.6 0.8 1 time[sec] v e l o c i t y a n d i t s e s t i m a t e [ m / s e c ] Figure 3: The velocity ẏ(solid line) and its estimate ˆ̇y(dotted line). Left: noise free ,Right: additive noise N(0, 10−4). 0 50 100 150 200 250 300 −3 −2 −1 0 1 2 3 4 time[sec] i n p u t [ N ] 0 50 100 150 200 250 300 −3 −2 −1 0 1 2 3 4 time[sec] i n p u t [ N ] Figure 4: The input signal. Left: noise free ,Right: additive noise N(0, 10−4). 0 50 100 150 200 250 300 −3 −2 −1 0 1 2 3 4 5 time[sec] f r i c t i o n f o r c e a n d i t s e s t i m a t e [ N ] 0 50 100 150 200 250 300 −3 −2 −1 0 1 2 3 4 5 time[sec] f r i c t i o n f o r c e a n d i t s e s t i m a t e [ N ] Figure 5: The friction(solid line) and its estimate(dotted line). Left: noise free ,Right: additive noise N(0, 10−4). 88 Kouichi Mitsunaga, Takami Matsuo Bibliography [1] B. Armstrong-Helouvry, P. Dupont, C. Canudas de Wit, “ A Survey of Models, Analysis Tools and Compensation Methods for the Control of Machines with Friction”. Automatica, vol.30, pp.1083– 1138, 1994. [2] C. Canudas de Wit, H. Olsson, K.J. Astrom, and P. Lischinsky, “ A New Model for Control of Systems with Friction”. IEEE Transaction on Automatic Control, vol.40-3, pp.419–425, 1995. [3] C. Canudas de Wit and S.S. Ge, “ Adaptive Friction Compensation for Systems with Generalized Velocity/Position Friction Dependency”. Proc. of the 36th IEEE Conference on Decision and Con- trol, pp.2465–2470, 1997. [4] D. V.-Díaz and Y. Tang, “ Adaptive Robust Control of Nonlinear Systems”. IEEE Trans. on Systems, Man, and Cybernetics, Part B, vol.34-3, pp.1596–1601, 2004. [5] B. Friedland and Y.-J. Park, “ On Adaptive Friction Compensation”. IEEE Transaction on Auto- matic Control, vol.37-10, pp.1609–1612, 1992. [6] S.S. Ge, T.H. Lee, and J. Wang, “ Adaptive NN Control of Dynamic Systems with Unknown Dy- namic Friction”. Proc. of the 39th IEEE IEEE Conference on Decision and Control, pp.1760–1765, 2000. [7] H. Han and C.-Y. Su, “ Robust fuzzy control of nonlinear systems using shape-adaptive radial basis functions”. Fuzzy Sets and Systems, vol.125, pp.23–38, 2002. [8] R.M. Hirschorn and G. Miller, “ Control of Nonlinear Systems with Friction”. IEEE Trans. on Control Systems Technology, vol.7-5, 588–595, 1999. [9] S.N. Huang, K.K. Tan, T.H. Lee, “ Adaptive motion control using neural network approximations”. Automatica, vol.38, pp.227–233, 2002. [10] E. Papadopoulos and G. Chasparis, “ Analysis and Model-based Control of Servomechanisms with Friction”. ASME J. Dynamic Systems, Measurement and Control, vol.126-4, pp.911–915, 2004. [11] S.-H. Park and T. Matsuo, “ Time-Derivative Estimation of Noisy Movie Data Using Adaptive Control Theory”. International Journal of Signal Processing, vol.2-3, pp.170–177, 2005. [12] D. Putra, L.P.M. Moreau, and H. Nijmeijer, “ Observer-Based Compensation of Discontinuous Friction”. Proc. of the 43rd IEEE Conference on Decision and Control, pp.4940–4945, 2004. [13] L. R. Ray, A. Ramasubramanian, and J. Townsend, “ Adaptive Friction Compensation Using Ex- tended Kalman-Bucy filter Friction Estimation”. Control Engineering Practice, vol.9, pp.169–179, 2001. [14] K. Sato, Y. Mishima, K. Tsuruta, and K. Murata, “ Adaptive Positioning Control for Linear Slider with Friction Compensation”. Trans. of Society of the Instrument and Control Engineers,Japan, vol.40-2, pp.275–277, 2004 (in Japanese). [15] P. Tomei, “ Robust Adaptive Friction Compensation for Tracking Control of Robot Manipulators”. IEEE Transaction on Automatic Control, vol.45-6, pp.2164–2169, 2000. [16] J. Wang, S.S. Ge and T.H. Lee, “ Adaptive Friction Compensation for Servo Mechanism”. in: Adaptive Control of Nonsmooth Dynamic Systems G. Tao and F.L. Lewis (Eds.), Springer, pp.211– 248, 2001. Adaptive Compensation of Friction Forces with Differential Filter 89 [17] Q.H. Xia, S.Y. Lin, M.H. Ang Jr. and T.M. Lim, “ Adaptive Joint Friction Compensation Using a Model-Based Operational Space Velocity Observer”. Proc. of IEEE International Conf. on Robotics and Automation, pp.3081–3086, 2004. Kouichi Mitsunaga Oita Institute of Technology Control Engineering Department 407-27 Higashihama, Nakatsu, Oita, Japan 871-0006 E-mail: mitu@oita-it.ac.jp Takami Matsuo Oita University Department of Architecture and Mechatronics 700 Dannoharu, Oita, Japan 870-1192 E-mail: matsuo@cc.oita-u.ac.jp Received: August 4, 2007 Kouichi Mitsunaga was born in Japan on July 19,1963. He re- ceived the B.S. degree in electrical engineering from Oita Univer- sity, Oita, Japan, in 1986. He is currently an assistant professor in the Control Engineering Department, Oita Institute of Technol- ogy, Japan. He has worked in control system engineering. Takami Matsuo was born in Japan on March 24,1958. He re- ceived the doctoral degree in engineering from Kyushu Univer- sity, Fukuoka, Japan, in 1985. He is currently a Professor in the Department of Architecture and Mechatronics, Oita University, Japan. He has worked in control system theory and its applica- tions. Matsuo is a member of IEEE, and SIAM.