INTERNATIONAL JOURNAL OF COMPUTERS COMMUNICATIONS & CONTROL ISSN 1841-9836, 9(4):471-481, August, 2014. Networked Predictive Fuzzy Control of Systems with Forward Channel Delays Based on a Linear Model Predictor S.W. Tong, D.W. Qian, G.P. Liu Shiwen Tong∗ College of Automation Beijing Union University Beijing 100101, China ∗ Corresponding author: shiwen.tong@buu.edu.cn Dianwei Qian School of Control and Computer Engineering North China Electric Power University Beijing 102206, China dianwei.qian@ncepu.edu.cn Guo-Ping Liu 1.School of Engineering University of South Wales Portypridd CF37 1DL, UK 2.CTGT Center Harbin Institute of Technology Harbin 150001, China guoping.liu@southwales.ac.uk Abstract: This paper presents a novel networked control framework, using fuzzy logic control, for systems with network delays which are known to greatly weaken the control performance of the controlled system. To deal with the network delays, the predicted differences between the desired future set-points and the predicted outputs from a model predictor are utilized as the inputs of a fuzzy controller, thus a series of future control actions are generated. By selecting the appropriated control sequence in the plant side, the network delays are compensated. The simulative results demon- strate that the proposed method can obviously reduce the effect of network delays, and improve the system dynamic performance. Keywords: networked control, model prediction, fuzzy control, delay compensation. 1 Introduction The emergence of the network technology has changed the communication architecture of control systems from traditional point-to-point to current common bus. Sensors, actuators and controllers are connected through network, formed a feedback control system (namely, networked control system). This architecture has injected fresh blood to the classic and modern control theories and also arises higher challenges to the controller design at the same time. On the one hand, the introduction of the network to the control system brings many advantages such as low cost, easy maintenance and high reliability. On the other hand, the unavoidable time delay, data dropout and other complicated phenomenon existing in the network should be considered. In recent years, networked control theory and technology have become an important and hot research area. Scholars from different countries have made a lot of breakthroughs in the networked control [1]- [8]. Network delay has become one of the most concerned issues in the networked control system. Because the network delays can dramatically degrade the control performance of the systems Copyright © 2006-2014 by CCC Publications 472 S.W. Tong, D.W. Qian, G.P. Liu even makes the systems unstable. From recent published literatures, it can be seen that the treatment of the network delays can be summarized in the following: The first one is to integrate delay information into the controller design by designing a robust controller to decrease the effect of time delay [3], [6]- [8]; The second one is to estimate delay information in the backward or forward channel by using reason-rule-table, average-value or delay windows (DW) method [9,10]; The third one is to eliminate the network delays in the return path by using a cascade control structure with P (proportion) control in the inner loop and fuzzy adaptive control in the outer loop [4]; As we all known, one of the obvious characteristics of the networked control system is that the communication networks can transmit a packet of data simultaneously. This feature provides another solution to compensate for network delays in the forward channel [11,12]. Based on it, Liu et al. [1, 2] proposed networked predictive control (NPC), using the strings of future control actions, to compensate for the forward channel delays. In this paper, we try to design a networked controller by using fuzzy control theories. Different from networked predictive control method, we separate the model prediction from the controller design. The function of the model predictor is just to produce future predicted outputs. A fuzzy controller is designed to generate a series of future control sequence based on the errors between the desired future outputs and the model predicted outputs. Then the strings of future control actions are packed and sent to the plant side through the communication channel. Thus, the effect of delays in the forward channel is lessened by using a delay compensator in the plant side. Predictive control and fuzzy control are powerful tools. They have been used in the design of the networked controller [1]- [5], [7, 8]. Some researchers have connected the prediction to the fuzzy control and have proposed ’predictive fuzzy control’ method [13, 14]. They use ’future error’ and ’future error change’ as inputs of the fuzzy controller to produce the control actions at the current time. To my knowledge, the combination of networked control system and the predictive fuzzy control has not been reported except one paper written by us in 2007 [15]. We call it ’networked predictive fuzzy control’ with abbreviation NPFC. The core idea of the NPFC is producing ’future control actions’ by fuzzy controller design according to the ’future error’ and ’future error change’ from a model predictor. Then the network delays can be compensated by choosing the ’future control actions’. This paper is organized as follows: The architecture of networked predictive fuzzy control (NPFC) is firstly presented. Secondly, a model predictor based on Diophantine equation is pro- posed. Thirdly, the fuzzy controller using ’future errors’ and ’future error changes’ as inputs to derive ’future control actions’ is designed. Then the delay compensation mechanism is discussed and the method is implemented in a servo control system. Finally, the conclusions are drawn in Section 4. 2 Design of networked control systems 2.1 Structure of Networked Predictive Fuzzy Control Systems The networked predictive fuzzy control system as shown in Fig. 1 mainly consists of three key parts: the model predictor, the fuzzy controller and the delay compensator. The model predictor is used to predict future outputs of the controlled system y(t|t), y(t + 1|t), · · · , y(t + N − 1|t) according to the delayed output y(t − 1) of the controlled system in the backward channel and the control actions u(t − d − 1), u(t − d − 2), · · · , u(t − d − nb) in the past. The errors e(t|t), e(t + 1|t), · · · , e(t + N − 1|t) between the desired future outputs r(t|t), r(t + 1|t), · · · , r(t + N − 1|t) and the predictive future outputs y(t|t), y(t + 1|t), · · · , y(t + N − 1|t) of the controlled system can be used to design a fuzzy controller to produce the future control sequences u(t|t), u(t + Networked Predictive Fuzzy Control of Systems with Forward Channel Delays Based on a Linear Model Predictor 473 1|t), · · · , u(t+Nu −1|t). Then the future control sequences are packed and sent to the plant side through network. In the plant side, a delay compensator is used to compensate for the forward network delays by selecting appropriate control sequence. Figure 1: Structure of Networked Predictive Fuzzy Control System 2.2 Model Predictor The function of the model predictor is to produce a series of future outputs of the controlled object according to the delayed output in the backward channel and the control actions in the past. Models, no matter linear or nonlinear model, of such functions can all be the predictor. To simplified the issue and focus on the research work step by step, we only consider forward channel delays in this paper. This consideration is reasonable in some cases. For example, in a network that the transmission velocity in the backward channel is faster than the forward channel thus the delays in the backward channel can be neglected. Therefore a linear model predictor based on the Diophantine equation is proposed. Consider a single-input and single-output process with the following form A(z−1)y(t) = z−dB(z−1)u(t) (1) where, A(z−1) = 1 + a1z −1 + · · · + anaz −na B(z−1) = b0 + b1z −1 + · · · + bnbz −nb Introducing a Diophantine equation to derive the model predictor. ∆A(z−1)Ei(z −1) + z−iFi(z −1) = 1 (2) where, Ei(z−1) is of order i − 1 and Fi(z−1) is of order na. Ei(z −1) = 1 + i−1∑ j=1 ei,jz −j, Fi(z −1) = na∑ j=0 fi,jz −j. 474 S.W. Tong, D.W. Qian, G.P. Liu Define N as predictive horizon, Nm as model control horizon, from (1) and (2), the predicted value Yp(t + 1) of the controlled system can be obtained. Yp(t + 1) = P∆U(t − d) + Q∆U(t − d − 1) + Fy(t − 1) (3) where, P =   g0 0 · · · 0 g1 g0 · · · 0 ... ... . . . ... gNm−1 · · · · · · g0 ... ... · · · ... gN−1 gN−2 · · · gN−Nm   Yp(t + 1) = [yp(t|t), yp(t + 1|t), · · · , yp(t + N − 1|t)]T ∆U(t − d) = [∆u(t − d), ∆u(t − d + 1), · · · , ∆u(t − d + Nm − 1)]T ∆U(t − d − 1) = [∆u(t − d − nb), ∆u(t − d − nb + 1), · · · , ∆u(t − d − 1)]T F = [F1(z −1), F2(z −1), · · · , FN(z−1)]T Q =   gnb · · · g1... · · · ... gnb+N−1 · · · gN   Let Gi(z−1) = B(z−1)Ei(z−1) = g0+g1z−1+· · ·+gnb+i−1z −(nb+i−1), we can construct matrix P and Q by solving the Diophantine equation. It should be noted that the item ∆U(t−d) = [∆u(t−d), ∆u(t−d+1), · · · , ∆u(t−d+Nm−1)]T in equation (3) can not be obtained at the current time t. We assume ∆u(t − d + i) = 0, i = 0, 1, · · · , Nm − 1. This assumption is reasonable. On the one hand, the dynamic response of the future time can be reflected by using the past control actions and the previous process outputs. On the other hand, the item y(t − 1) is corresponding to the correction of the predicted model. That is y(t − 1) = ym(t − 1) + e(t − 1), where ym(t − 1) is the model output and e(t − 1) is the error between the process output and the model output. 2.3 Fuzzy Controller The successful implementation of networked predictive fuzzy control relies on an assurance that the fuzzy controller must calculate all the pre-defined control actions in every sample time. So the fuzzy control algorithm should be simple and suitable to the real-time control. A real- time simplified fuzzy controller [16] is used to generate the future control actions. Unlike the ordinary fuzzy control, which uses error and error change at the present time to produce the current control action, the networked predictive fuzzy controller uses ’future error’ and ’future error change’ to derive ’future control actions’. The ordinary fuzzy control can be regarded as a special condition of the networked fuzzy control when the predictive step is equal to zero. This networked predictive fuzzy controller has two-input one-output. One input is the error e between the desired future output and the predicted output. The other one is the change of the error ec. The output of the fuzzy controller is the change of the future control action ∆u. The membership functions of e and ec are adopted as triangular forms and the membership function of the output ∆u is adopted discrete form as Fig. 2 shown. The ’Simplification’ of the fuzzy controller relays on the inference process. For the typical two-input-one-output fuzzy controller, only four control rules are excited at each cycle time with Networked Predictive Fuzzy Control of Systems with Forward Channel Delays Based on a Linear Model Predictor 475 Figure 2: Membership functions of e, ec and ∆u. (a) is the membership function of input e, (b) is the membership function of input ec, (c) is the discrete form membership function of output ∆u. the form ’If e is Le and ec is Lec, then ∆u is L∆u’, where L is the linguistic variables PB, PM, PS, ZE, NS, NM, NB. Due to the characteristic of the triangular membership function, e is at most belong to two membership functions µie and µ i+1 e , ec is at most belong to two membership functions µjec and µ j+1 ec , thus ∆u has 2 × 2 combinations, that is four control rules: if e is L(i)e and if ec is L (j) ec then ∆u is L (i,j) ∆u if e is L(i)e and if ec is L (j+1) ec then ∆u is L (i,j+1) ∆u if e is L(i+1)e and if ec is L (j) ec then ∆u is L (i+1,j) ∆u if e is L(i+1)e and if ec is L (j+1) ec then ∆u is L (i+1,j+1) ∆u From Fig. 2(c) shown, output ∆u is adopted discrete form membership function. It is assumed that output domain has been divided into cm(k), m = 1, 2, · · · , n. Do minimum and maximum operator, calculate µ̃ (m) L (i,j) ∆u = ∧(µ L (i) e , µ L (j) ec , µ (m) L (i,j) ∆u ) µ̃ (m) L (i,j+1) ∆u = ∧(µ L (i) e , µ L (j+1) ec , µ (m) L (i,j+1) ∆u ) µ̃ (m) L (i+1,j) ∆u = ∧(µ L (i+1) e , µ L (j) ec , µ (m) L (i+1,j) ∆u ) µ̃ (m) L (i+1,j+1) ∆u = ∧(µ L (i+1) e , µ L (j+1) ec , µ (m) L (i+1,j+1) ∆u ) (4) and ˜̃µ(m)∆u = ∨(µ̃(m) L (i,j) ∆u , µ̃ (m) L (i,j+1) ∆u , µ̃ (m) L (i+1,j) ∆u , µ̃ (m) L (i+1,j+1) ∆u ) (5) where m = 1, 2, · · · , n It is not easy to directly get the inference rules of the future; however, the typical dynamic of the second order system can be obtained ahead of time. Fig. 3 presents the phase plane of 476 S.W. Tong, D.W. Qian, G.P. Liu −0.04 −0.02 0 0.02 0.04 0.06 0.08 0.1 −0.08 −0.06 −0.04 −0.02 0 0.02 0.04 e ec PB NB PS NS ZE NB NM NS PB PM PS ZE ZE ZE Figure 3: Phase plane and fuzzy control rules analysis of typical second order linear system. the typical second order linear system with the x-axis standing for variable e and y-axis standing for variable ec. From this figure, it can be seen that the points in x-axis and y-axis are crucial. If these points are controlled very well, the control performance is guaranteed. So the main inference rules are deduced as shown in Table 1. Table 1: Main control rules of the fuzzy controller in NPFC No. Control rules 1 if e = PB and ec = ZE then ∆u = PB 2 if e = ZE and ec = NB then ∆u = NB 3 if e = NB and ec = ZE then ∆u = NB 4 if e = ZE and ec = PB then ∆u = PB 5 if e = PS and ec = ZE then ∆u = PS 6 if e = ZE and ec = NM then ∆u = NM 7 if e = NS and ec = ZE then ∆u = NS 8 if e = ZE and ec = PM then ∆u = PM 9 if e = ZE and ec = NS then ∆u = NS 10 if e = ZE and ec = PS then ∆u = PS 11 if e = ZE and ec = ZE then ∆u = ZE Thus, the incremental control actions ∆u(t + η) = n∑ m=1 ˜̃µ(m)∆u ∗ cm n∑ m=1 ˜̃µ(m)∆u (6) and the predicted control actions u(t + η) = u(t + η − 1) + ∆u(t + η), η is integer and 0 ≤ η ≤ Nu − 1 (7) can be given, where Nu is the control horizon. If e is the error and ec is the error change at present time, then ∆u is the incremental control action at present time. If e and ec are the values of the future time, then the future incremental control actions can be derived. Networked Predictive Fuzzy Control of Systems with Forward Channel Delays Based on a Linear Model Predictor 477 As paper [17]- [19] presents, variable domain implemented in the fuzzy control can greatly improve the control accuracy, which has successfully been applied to the control of a quadruple inverted pendulum [20] and the wing rock phenomenon [21]. This is achieved by the domain contraction and expansion. Domain contraction is equivalent to the increase of the control rules. Although the real-time algorithm has considered only 11 rules, together with the variable domain strategy, the fuzzy controller can acquire satisfactory control performance. The varies of domain can be achieved by multiplying flex factors α(e), β(ec) and γ(e, ec) of domains E, EC and ∆U, respectively. There are many different forms of flex factors. In this paper, we adopt the exponential form of functions: α(e) = [ |e| E ]τ1 , 0 < τ1 < 1 β(ec) = [ |ec| EC ]τ2 , 0 < τ2 < 1 γ(e, ec) = [[ |e| E ]τ1 [ |ec| EC ]τ2]τ3 , 0 < τ1, τ2, τ3 < 1 (8) To summarized, the networked predictive fuzzy controller has eleven parameters to be de- signed. Four parameters are related to the model predictor. They are the order of the predictive model na and nb, the predictive horizon N, and the model control horizon Nm. Seven parameters are belong to the networked fuzzy controller. They are the control horizon Nu, the scaling gains Ke, Kec, K∆u of error e, error change ec and incremental control action ∆u, and the variable domain parameters τ1, τ2 and τ3. The program steps for the networked predictive fuzzy control plus variable domain strategy are summarized below: Step 1 : Use equation (3), calculate the future outputs yp(t|t), yp(t + 1|t), · · · , yp(t + N − 1|t) of the controlled system according to the delayed output of the feedback channel and the previous control actions. Step 2 : Calculate the differences between the desired future outputs r(t|t), r(t + 1|t), · · · , r(t + N −1|t) and the model predicted values yp(t|t), yp(t+1|t), · · · , yp(t+N −1|t) to get e(t|t), e(t+ 1|t), · · · , e(t + N − 1|t) and ec(t|t), ec(t + 1|t), · · · , ec(t + N − 1|t). Step 3 : Adjust input and output domain using equation (8) in terms of e(t + η) and ec(t + η). Step 4 : Calculate membership functions of input e(t + η) and ec(t + η) and output ∆u(t + η). Step 5 : Use minimum-maximum inference method [see equation (4) and (5)]. Step 6 : Calculate the predicted control actions u(t + η) using equation (6) and (7). Step 7 : Let η = 0 to Nu − 1, repeat step 3-6. Step 8 : Send the control actions ∆u(t),∆u(t + 1),· · · ,∆u(t + Nu − 1) with a packet to the plant side. Step 9 : Select the control action u(t|t − k) and add to the controlled process. Step 10 : In the next sample time, repeat step 1-9. 2.4 Network Delays Compensation It is assumed that the network communication delay in the forward channel is not greater than the length of the predicted control horizon. To make use of the ’packet transmission’ characteristic of the network, a string of future control actions which contain u(t), u(t+1), · · · u(t+ Nu − 1) at sample time t are sent to the plant side at the same time. Then the control value from the latest control sequence available on the plant side is chosen as a control input of the plant to compensate for the forward channel delay. For example, if the latest control sequence 478 S.W. Tong, D.W. Qian, G.P. Liu on the plant side is   u(t − k|t − k) u(t − k + 1|t − k) ... u(t − k + Nu − 1|t − k)   Then the output selected control signal will be u(t) = u(t|t − k) 0 2 4 6 8 10 12 −5 0 5 10 15 20 25 30 35 40 45 Time(s) A n g le (d eg re e) NPC NPFC Reference No delay compensation Figure 4: The step responses of NPC and NPFC with 1-step forward channel delay. 3 Simulations Consider the servo control system as reference [2] shown. The system model with discrete form is as follows: G(z−1) = −0.00886z−1 + 1.268227z−2 1 − 1.66168z−1 + 0.6631z−2 (9) where sample time is 0.04 second. Suppose there is one step delay in the forward channel, following Section 2.2 and Section 2.3, we design a linear model predictor and a real-time fuzzy controller. The parameters of the model predictor are: na = 2, nb = 2, N = 12, Nm = 10. The parameters of the networked fuzzy controller are: Nu = 10, Ke = 0.00125, Kec = 0.02, K∆u = 0.6, τ1 = 0.1, τ2 = 0.1 and τ3 = 0.01. The NPC parameters are set to N = 12, Nu = 10, ρ = 1500. Fig. 4 shows the control performance of NPFC and NPC. The dot line is the set-point. The solid line stands for the NPFC method. The dash line stands for NPC method. The dash-dot line stands for the NFPC method without delay compensation. From the figure, it can be seen that the NPFC can be regulated better than the NPC in control performance with rapid dynamic and small overshot. The delay compensation mechanism is very effective. Suppose the case that six step delays exist in the forward channel. The NPFC controller parameters are adjusted as: Ke = 0.0004, Kec = 0.008, K∆u = 0.08, and the NPC parameters Networked Predictive Fuzzy Control of Systems with Forward Channel Delays Based on a Linear Model Predictor 479 are set to N = 25, Nu = 10, ρ = 100000. To testify the control performance of the networked predictive fuzzy control method, the results of the NPC and the NPFC are presented in Fig. 5. Through model prediction, fuzzy controller design and delay compensation, the NPFC presents very obviously better performance than NPC method. The rising time of NPFC is about 1.1 seconds while 1.5 seconds for NPC method. Moreover, NPC has 3.75% overshot while NPFC has nearly no overshot. When NPFC method not considers delay compensation, static errors can be seen in Fig. 5. On the contrary, the dynamic response reaches steady state after 1.4 seconds when the delay compensator is acting. 0 2 4 6 8 10 12 −5 0 5 10 15 20 25 30 35 40 45 Time(s) A ng le (d eg re e) NPC NPFC Reference No delay compensation Figure 5: The step responses of NPC and NPFC with 6-step forward channel delay. 4 Conclusions This paper proposes a network predictive fuzzy controller structure. By solving the Diophan- tine equation, the linear model predictor generates a series of predictive outputs of the controlled system according to the outputs and the control sequence in the past time. The errors between the desired future outputs and the predictive outputs from the linear model predictor and the error change are used to design a real-time fuzzy controller. So a series of future control sequence is produced in the controller side. By selecting the appropriate control sequence in the plant side, the delays in the forward channel are compensated. Because NPFC has more parameters which can be regulated, the control performance can be adjusted better than NPC method. Acknowledgments This work was supported in part by the Beijing Municipal Excellent Talents Funded Project (Grant No. 2013D005022000003), the Korea Foundation for Advanced Studies Fellowship to Dianwei Qian, and the National Natural Science Foundation of China (Grant No. 61273104 and 61333003). 480 S.W. Tong, D.W. Qian, G.P. Liu Bibliography [1] Liu G. P.; Rees D.; Chai S. C.; Nie X. Y. (2005); Design, simulation and implementation of netowrked predictive control systems, Measurement and Control, ISSN 2029-2940, 38:17-21. [2] Liu G. P.; Mu J. X.; Rees D.; Chai S. C. (2006); Design and stability analysis of networked control systems with random communication time delay using the modified MPC, Interna- tional Journal of Control, ISSN 0020-7179, 79(4):288-297. [3] Mahmoud M. S.; Saif A. A. (2012); Robust quantized approach to fuzzy networked control systems, IEEE Journal on Emerging and Selected Topics in Circuits and Systems, ISSN 2156-3357, 2(1):71-81. [4] Du F.; Qian Q. Q. (2008); The research of heterogeneous networked control systems based on modify smith predictor and fuzzy adaptive control, IEEE International Conference on Fuzzy Systems. [5] Tang P. L.; De S. C. W. (2006); Compensation for transmission delays in an ethernet-based control network using variable-horizon predictive control, IEEE Transactions on Control Sys- tems Technology, ISSN 1063-6536, 14(4):707-718. [6] Jia X. C.; Zhang D. W.; Zheng L. H.; Zheng N. N. (2008); Modeling and stabilization for a class of nonlinear networked control systems: A T-S fuzzy approach, Progress in Natural Science, ISSN 1002-0071, 18(8):1031-1037. [7] Jiang X. F.; Han Q. L. (2008); On designing fuzzy controllers for a class of nonlinear net- worked control systems, IEEE Transactions on Fuzzy System, ISSN 1063-6706, 16(4):1050- 1060. [8] Hajebi P.; Almodarresi S. M. T. (2012); Online adaptive fuzzy logic controller using neural network for Networked Control Systems, International Conference on Advanced Communi- cation Technology. [9] Ren C. Q.; Wu P. D.; Wang X. F.; Ma S. Y.; Chen Z. L. (2002); A study on the forecast arithmatic of hydraulic telecontrol system based on internet, Journal of Beijng Institute of Technology, ISSN 1004-0579, 22(1):85-89. (In Chinese) [10] Zhen W.; Xie J. Y. (2002); On-line delay-evaluation control for networked control systems, IEEE Conference on Decision and Control. [11] Zhang Y. Y.; Zhang J. L.; Luo X. Y.; Guan X. P. (2013); Faults detection for networked control systems via predictive control, International Journal of Automation and Computing, ISSN 1476-8186, 10(3):173-180. [12] Tang X. M.; Ding B. C. (2012); Design of networked control systems with bounded arbitrary time delays, International Journal of Automation and Computing, ISSN 1476-8186, 9(2):182- 190. [13] Li P. F.; Yan X. P.; Qiu L. P.; Zhou Q. Y.(2009); Study on predictive fuzzy control of great inertia system based on grey model, 2009 Second International Conference on Intelligent Computation Technology and Automation. [14] Hu J. Q.; Rose E.(1997); Predictive fuzzy control applied to the sinter strand process, Control Engineering Practice, ISSN 0967-0661, 5(2):247-252. Networked Predictive Fuzzy Control of Systems with Forward Channel Delays Based on a Linear Model Predictor 481 [15] Tong S. W.; Liu G. P.(2007); Design and Simulation of Fuel Cell Networked Predictive Fuzzy Control Systems, Proceedings of the 26th Chinese Control Conference. [16] Tong S. W.; Liu G. P.(2008); Real-time simplified variable domain fuzzy control of pem fuel cell flow systems, European Journal of Control, ISSN 0947-3580, 14(3):223-233. [17] Li H. X. (1995); To see the success of fuzzy logic from mathematical essence of fuzzy control, Fuzzy Systems and Mathematics, ISSN 1001-7402, 9(4):1-14. (In Chinese) [18] Oh S. Y.; Park D. J. (1995); Self-tuning controller with variable universe of discourse, IEEE International Conference on Systems, Man and Cybernetics. [19] Li H. X. (1999); Variable universe adpative fuzzy controller, Science in China (Series E), ISSN 1006-9321, 20(1):32-42. [20] Li H. X.; Miao Z. H.; Wang J. Y. (2002); Variable universe adaptive fuzzy control on the quadruple inverted pendulum, Science in China (Series E), ISSN 1006-9321, 45(2):213-224. [21] Liu Z. L.; Su C. Y.; Svoboda J. (2004); Control of wing rock phenomenon with a variable universe fuzzy controller, Proceeding of the American Control Conference.