Int. J. of Computers, Communications & Control, ISSN 1841-9836, E-ISSN 1841-9844 Vol. V (2010), No. 5, pp. 968-975 Robust 2-DoF PID control for Congestion control of TCP/IP Networks R. Vilanova, V. M. Alfaro Ramón Vilanova Department de Telecomunicació i Enginyeria de Sistemes Universitat Autònoma de Barcelona 08193, Bellaterra, Spain, E-mail: ramon.vilanova@uab.cat Víctor M. Alfaro Escuela de Ingeniería Eléctrica Universidad de Costa Rica San José, 11501-2060, Costa Rica. E-mail: victor.alfaro@ucr.ac.cr Abstract: This paper presents how Robust PID control can improve the per- formance of congesion control on TCP/IP networks. The proposed approach is compared with other control methods, such as PI control or RED/AQM, showing the advantages of the proposed technique. Keywords: Congestion control, Active Queue Management, PID Control. 1 Introduction Internet congestion control and congestion avoidance have been active research interests in the area of networking (see, for example [1] [2] [3]) during the last two decades. It has two components: (1) the end-to-end congestion control protocol, such as TCP [4], and (2) an active queue management (AQM) scheme implemented in routers. AQM signals congestion by discard- ing or marking packets. When congestion is detected by TCP, it will take actions to reduce the source sending rate. Normally, AQM objectives are: to stabilize the buffer queue length at a given target, thereby achieving predictable queueing delay, and to minimize the occurrences of queue overflow and underflow, thus reducing packet loss and maximizing link utilization. Thus, it is necessary to reduce as much as possible this problem. At present, there are methodologies to deal with this issue [5]: congestion control which is used after the network is overloaded and congestion avoidance which takes action before the problem appears. This paper deals with con- gestion control because it is where feedback control techniques can be openly and easily applied. Recently several mathematical models of active queue management (AQM) schemes sup- porting transmission control protocol (TCP) flows in communication networks have been pro- posed [2] [3]. From these models a control theory-based approach can be used to analyze or to design AQM schemes. The more well known AQM scheme is probably RED [1]. RED can detect and respond to long-term traffic patterns, but it cannot detect congestion caused by short-term traffic load changes. In addition, it is well known that an appropriate tuning of RED parameters is not an easy task an may result in a non stabilizing controls scheme. This fact has motivated the research for alternative control approaches. This paper presents the application of a Robust PID approach as an AQM controller. The controller can be easily tuned from the network parameters and it is compared with RED and the PI controller proposed in [3]. The performance under different load conditions shows the robustness and superiority of the presented approach. In addition the simple formulation of the PID controller also constitutes a motivation for implementation. Copyright c⃝ 2006-2010 by CCC Publications Robust 2-DoF PID control for Congestion control of TCP/IP Networks 969 The rest of the paper is organized as follows. Next section presents the nonlinear model for a TCP router as well as the TCP control problem formulation. Section 3 reviews the RED and PI controller approaches for AQM control whereas section 4 presents the Robust 2-DoF PID approach. In section 5 a discussion and comparison is conducted. The paper ends with drawing some conclusions on the reported results. 2 AQM Router Dynamic Model and Control problem statement In this section the dynamic nonlinear/linearized equations of TCP behavior developed in [3] are briefly reviewed as well as the purposes of AQM control stated. 2.1 Dynamic TCP Model As in the literature, a network configuration consisting of a single congested router with a transmission capacity C is considered in this paper. TCP timeout mechanisms have been ignored for simplification. Using fluid-flow and stochastic differential equation analysis, the following coupled, nonlinear differential equations have been proposed as the dynamic model of the TCP behavior: ˙W(t) = 1 R(t) − W(t) 2 W(t − R(t − R(t))) R(t − R(t)) p(t − R(t)) (2.1) ˙q(t) = { −C + N(t) R(t) W(t) q(t) > 0 max 0, −C + N(t) R(t) W(t) q(t) = 0 where W . = average TCP window size (packets) q . = average queue length (packets) R(t) . = round-trip time= q(t) C + Tp (secs) C . = link capacity Tp . = propagation delay (secs) N . = Number of active TCP sessions p . = probability of packet mark The queue length q, and window-size W, are positive bounded quantities; i.e., q ∈ [0, q̄] and W ∈ [0, W̄] where q and W denote buffer capacity and maximum window size respectively. In this formulation, the congestion window size W(t) is increased by one every round-trip time if no congestion is detected, and is halved upon a congestion detection. Moreover it has been assumed that the AQM scheme implemented at the router marks packets using Explicit Congestion No- tification (ECN) to inform the TCP sources of impending congestion. To linearize (2.1), it is assumed that the number of active TCP sessions and the link capacity are time-invariant, i.e., N(t) ≡ N and C(t) ≡ C. In addition the dependence of the time delay argument t − R on queue length q, is ignored and it is assumed to be fixed to t − Ro. Then, local linearization of (2.1) about the operating point results in the following equation: 970 R. Vilanova, V. M. Alfaro Figure 1: AQM Block Diagram of the linearized model along with High frequency uncertain dynamics ˙δW(t) = − N R2oC (δW(t) + δW(t − Ro)) (2.2) − 1 R2oC (δq(t) − δq(t − Ro)) − R2oC 2N2 δq(t − Ro) ˙δq(t) = N Ro δW(t) − 1 Ro δq(t) where δW(t) = W(t) − Wo and δq(t) = q(t) − qo are the incremental variables with respect to an operating point. The operating point for a desired equilibrium queue length qo is given by: Ro = qo C + Tp Wo = RoC N po = 2 W2o (2.3) This leads to a low order nominal model of the network dynamics that is accurate at a particular operating point (Ro, qo, Co, Wo, po) given by: P(s) = Po(s)e −Ros = C2/(2N) (s + 2N R2oC )(s + 1 Ro ) (2.4) By modelling the high frequency dynamics using a block ∆(s) such that ∆(s) = 2N2 R3oC 3 s(1 − e−Ros) (2.5) This term represents the high frequency, necessarily parasitic, network uncertainty in the model. Computational experience has shown that this can adequately capture certain deviations from nominal network performance. These considerations lead to the generation of a simplified feedback control system as shown in Fig. (1) 2.2 AQM Control problem The function of an AQM control law is to mark packets (with probability p) as a function of measured queue length q. Marking of packets is consecutively used by the sender to throttle the amount of data sent; if no marked packets are received the window size is increased. Upon reception of a marked packet the window size is halved. The principal performance objectives for an AQM control law are: 1. Efficient queue utilization, to avoid overflow or emptiness of the queue buffer. Robust 2-DoF PID control for Congestion control of TCP/IP Networks 971 2. Regulated queueing delay, to minimize (optimize) the time required for a data packet to be serviced by the routing queue. The queueing delay is equal to q/C. 3. Robustness, to maintain closed-loop performance in spite of plant uncertainties, N, Ro and C. 3 RED and PI Approaches to AQM this section reviews two of the more well established approaches for AQM control, say RED and the PI approach presented in [3]. 3.1 RED approach to AQM Random Early Detection (known as RED) was presented by [1]. A RED gateway calculates the average queue size, using a low-pass filter with an exponential weighted moving average. The average queue size is compared to two thresholds (minimum and maximum). When the average queue size is less than the minimum threshold, no packets are marked. When the average queue size is greater than the maximum threshold, every arriving packet is marked. If marked packets are in fact dropped, or if all source nodes are cooperative, this ensures that the average queue size does not significantly exceed the maximum threshold. When the average queue size is between the minimum and the maximum threshold, each arriving packet is marked with probability p, where p is a function of the measured queue length q. Hollot et al. in [3] proposed the following transfer function model for the RED controller: Cred(s) = KLred s + K = Kred s/kred + 1 (3.1) where Lred = pmax (maxth − minth) Kred = R3oC 2 (2N)2 kred = −C ln(1 − αred) (3.2) and where αred is REDs queue-averaging weight. The corresponding controller block diagram is shown in figure (2). Figure 2: Block Diagram of RED as a cascade of low-pass filter and nonlinear gain element. 3.2 PI approach to AQM According to [3] the transfer function of a PI controller can be written as: CPI = KPI s/z + 1 s (3.3) This controller is very well known by the control community. Its parameters can be tuned following methods proposed in the control literature. For example, [3] gave guidelines based on the Bode diagram tuning technique: 972 R. Vilanova, V. M. Alfaro Figure 3: 2-DOF Control System z = 2N R2oN KPI = ωgz ∣∣∣∣jωg + 1/RoC2/(2N) ∣∣∣∣ ωg = βRo (3.4) where β determines the phase margin of the resulting nominal control system. The PI proposed in [3] is designed for a phase margin of about 30o. 4 Robust PID Control This section briefly presents the approach for Analytical Robust Tuning (ART) of 2-DoF PID controllers recently presented in [6]. Consider the Two-Degree-of-Freedom (2-DOF) control system of Fig. 3, where P(s) is the controlled process transfer function, Cr(s) the set-point controller transfer function, Cy(s) the feedback controller transfer function, and r(s) the set- point, d(s) the load-disturbance, and y(s) the controlled variable. The output of the 2-DOF controller is given by u(s) = Cr(s)r(s) − Cy(s)y(s) (4.1) For a PID2 [7] it is u(s) = Kc ( β + 1 Tis ) r(s) − Kc ( 1 + 1 Tis + Tds ) y(s) (4.2) where Kc is the controller gain, Ti the integral time constant, Td the derivative time constant, and β the set-point weighting factor (0 ≤ β ≤ 1). We will start right now with a Second-Order-Plus-Dead-Time (SOPDT) model of the form P(s) = Kpe −L ′′ s (T ′′ s + 1)(aT ′′ s + 1) , τo = L′′ T ′′ (4.3) The PID controller parameters are determined by the following equations for processes with parameters in the range 0.1 ≤ τo ≤ 1.0 and 0.15 ≤ a ≤ 1.0. κc = 10τi 21τc + 10τo − 10τi (4.4) τi = (21τc + 10τo)[(1 + a)τo + a] − τ 2 c(τc + 12τo) 10(1 + a)τo + 10a + 10τ2o (4.5) τd = 12τ2c + 10τiτo − (1 + a)(21τc + 10τo − 10τi) 10τi (4.6) Robust 2-DoF PID control for Congestion control of TCP/IP Networks 973 β = min { 1 Kc , τcT ′′ Ti , 1 } (4.7) The controller normalized parameters κc, τi and τd, and β depend on the model normalized dead-time τo and time constants ratio a, and on the design parameter τc. A minimum system robustness level is incorporated into the design process estimating a recommended maximum speed (τcmin) of the resulting closed-loop control system parameterized in terms of the maximum sensitivity function (Ms) by using τcmin = k11(Ms) + k12(Ms)a k13(Ms) (4.8) k11(Ms) = 2.442 − 2.219Ms + 0.515Ms 2 k12(Ms) = 10.518 − 8.990Ms + 2.203Ms 2 k13(Ms) = 0.949 − 0.197Ms Combining the performance and robustness consideration above the design parameter may be selected in the range τcmin ≤ τc ≤ 1.25 + 2.25a. The range limits for the design parameter selection then combine the necessary restriction so that all controller parameters are positive and the accomplishment of a specified maximum sensitivity, with the necessity that the obtained response does not deviate too much away from the desired response, due of the dead-time approx- imation used in obtaining the tuning equations. For a more detailed presentation and discussion of the method please see [6]. 5 Discussion In order to illustrate the effectiveness of the Robust 2-DoF PID method, a numerical situation will be presented by taking the network simulation parameters of [3] where qo = 175 packets, Tp = 0.2 seconds, C = 3750 packets/s (this corresponds to a 15MB/s link with an average packet size of 500 Bytes.). For a load of N = 60 TCP sessions we have Wo = 15 packets, po = 0.008, and Ro = 0.246. Therefore P(s) = Po(s)e −0.246 = 1.17126 105 (s + 0.53)(s + 4.1) e−0.246 ∆(s) = 2.24 10−6s(1 − e−0.246s) (5.1) The corresponding RED controller parameters are (see [3]) K = 0.005 and Lred = 1.86 10−4 whereas those of the PI controller KPI = 9.64 10−6 and z = 0.53. On the other hand, for the application of the ART method the parameters of the SOPTD model are needed. These result to be a = 0.1297, L′′ = 0.2467 and T ′′ = 1.9014. And the controller parameters depend upon the desired robustness level expressed in terms of te Ms level. A minimum robustness is assured by Ms = 2.0 whereas highly robust systems are designed with Ms = 1.4. Here we take an intermediate level with Ms = 1.6. The resulting 2-DoF PID controller parameters are: Kc = 4.4241 10 −5, Ti = 2.1443, Td = 0.3436 and β = 0.6172. Figure (4) shows the performance of the three presented control strategies applied to the nonlinear system (2.1). As it can be seen the RED controller cannot reach the new references. This is an inherent drawback because it lacks the corresponding integrator. On the other hand both the PI and ART-PID controllers reach the desired targets. On the right part of figure (4) it can de observed that the ART-PID controller reaches the desired set-point faster and without any overshoot. In addition, a test under different load conditions has been performed. In this case the number of TCP sessions 974 R. Vilanova, V. M. Alfaro 0 50 100 150 200 160 180 200 220 240 260 RED (Dash−dot) PI (Dash) ART (Solid) Time (sec) 0 50 100 150 200 5 6 7 8 9 10 11 x 10 −3 RED (Dash−dot) PI (Dash) ART (Solid) Time (sec) 10 12 14 16 18 20 160 180 200 220 240 260 RED (Dash−dot) PI (Dash) ART (Solid) Time (sec) Q u e u e L e n g th 10 12 14 16 18 20 5 6 7 8 9 10 11 x 10 −3 RED (Dash−dot) PI (Dash) ART (Solid) Time (sec) P a c k e t M a rk in g Figure 4: Changes on desired queue length. Comparison of PI, PID and RED performance. Plots on the right side show a zoomed version to better compare PI and PID is a signal of the form N(t) = N(1 + 0.01 ∗ sin(0.05t)) + v(t) being v(t) a normally gaussian distributed random number of zero mean and variance 0.01 ∗ N. v(t) is assumed to change with a sampling time of 5 sec. It can be seen that the ART-PID provides faster response to the load variation and faster recuperation of the desired queue length. Table (1) shows the mean value and standard deviation of the queue length error computed with respect to the desired target qo = 175packets. As a proof of performance, as we achieve a lower variation of the queue, a predictable performance will be expected. Therefore better QoS. Table 1: Mean and standard Deviation of the queue length error Controller RED PI ART mean -0.43 -0.27 -0.1 std 10.9 9.2 5.0 6 Conclusions In this paper the suitability of applying Robust PID controllers for the purpose of improving internet congestion control has been presented. The main advantage of the ART PID tuning is its one-parameter tuning. In addition this parameter is a direct specification of the desired robust- ness level. Therefore suitable for the sittuations with changes in load and system parameters. The performance has been compared to that of RED and a PI controller previously proposed in the literature. Acknowledgment This work has received financial support from the Spanish CICYT program under grant DPI2007-63356. Support from the Universidad de Costa Rica is greatly appreciated. Robust 2-DoF PID control for Congestion control of TCP/IP Networks 975 0 20 40 60 80 100 120 140 160 180 200 150 160 170 180 190 200 RED (Dash−dot) PI (Dash) ART (Solid) Time (sec) 0 20 40 60 80 100 120 140 160 180 200 5 6 7 8 9 10 11 12 x 10 −3 RED (Dash−dot) PI (Dash) ART (Solid) Time (sec) Figure 5: Regulation performance on a desired queue length of qo = 175packets facing random variations of the number of TCP sessions Bibliography [1] S. Floyd and V. Jacobson, “Random early detection gateways for congestion avoidance.,” IEEE/ACM Transactions on Networking, vol. 1, pp. 397–413, 1993. [2] F. Kelly, “Mathematical modeling of the internet, in mathematics unlimited-2001 and be- yond,” B. Enquist and W. Schmid, Eds, Berlin, Germany, Springer-Verlag., 2001. [3] C. Hollot, V. Misra, D. Towsley, and W. Gong, “Analysis and design of controllers for AQM routers supporting TCP flows,” IEEE Trans. Automat. Contr., vol. 47, pp. 945–959, 2002. [4] J. Postel, “Transmission control protocol,” RFC 793, 1981. [5] S. Ryu, C. Rump, and C. Qiao, “Advances in active queue management (AQM) based tcp congestion control,” Telecommunication Systems, vol. 25, pp. 317–351, 2004. [6] V. Alfaro, R. Vilanova, and O. Arrieta, “A single-parameter robust tuning approach for two- degree-of-freedom pid controllers,” The European Control Conference,Budapest, Hungary, August 23-26, 2009, 2009. [7] K. Åström and T. Hägglund, Advanced PID Control. ISA - The Instrumentation, Systems, and Automation Society, 2006.