ADAPTIVE TUNING METHOD FOR A DIGITAL PID CONTROLLER

Information

  • Patent Application
  • 20220357708
  • Publication Number
    20220357708
  • Date Filed
    June 27, 2022
    2 years ago
  • Date Published
    November 10, 2022
    2 years ago
  • Inventors
    • Dimakov; Valentin
Abstract
The aim of the invention is rapid automatic tuning the parameters of a digital proportional-integral-derivative (PID) controller by analog feedback of an actual value for automation of technological processes with programmable logic controllers (PLCs).
Description
BACKGROUND ART
Technical Field of Invention

The invention relates to rapid automatic tuning the parameters of a digital proportional-integral-derivative (PID) controller for automation of technological processes with programmable logic controllers.


Description of the Prior Art

In many cases, the programmable logic controllers (PLCs) are used for automation of technological processes. A PLC usually consists of a CPU and some input and output signal modules. This composition of electronic modules processes signals from digital and analog sensors and controls the various drives of compressors, pumps or valves.


It is frequently necessary to maintain a temperature, pressure, liquid level or gas volume constant by automatic regulation in a segment of an industrial plant. This can be achieved by means of a PID controller, which has proven its reliability and universality through long-term application.


Manual parameterization of a PID controller is not complicated if, for example, a temperature or pressure sensor is located near an actuator (valve or pump), or if the actuator influence on a sensor is not so significant.


However, the manual parameterization of a PID controller becomes much more complicated when a sensor is far away from an actuator, and it is affected with a significant delay. Or, for example, the refrigerant overheating temperature in a chiller is controlled simultaneously by two values from a temperature and pressure transducer. In these or other cases, the manual parameterization of a PID controller requires considerable experience and extensive knowledge of the process equipment. Therefore, it can be helpful to have a device that could do this automatically.


Solving the automatic tuning problem of a PID controller may be compared to the search for an optimal solution. An important factor is determining the initial PID controller parameters Kp, Ki, and Kd (i.e., proportional Kp, integral action Ki, and derivative action Kd coefficients) that serve as a starting point for the adaptive tuning method.


Scientific publications and inventions on this subject prefer the automatic tuning methods of a PID controller based on the fuzzy logic mechanism, which allows to achieve a result with high solution quality. However, the overall value of this solution is also high, considering the following features:


The relatively high computational load of the fuzzy logic mathematical means. The PLCs usually perform various tasks for automation of technological processes and can simultaneously use several PID controllers for this purpose. If the fuzzy logic mechanism is permanently used with PID controllers for modifying the control variables, the cumulative computational load may be very high even for modern PLCs.


Linking to the specific problems. A rule set of the fuzzy inference method as well as the function parameters for fuzzification and defuzzification are usually chosen to solve a clearly defined problem. This leads to loss of universality of such a solution method.


There are also alternative solutions that use various methods depending on the complexity of controlled systems. At that, the adaptive tuning process usually consists of two stages [1, 2]. In the first stage, the Ziegler and Nichols method is used to set a closed control loop on the stability boundary.


In [1] an assumption is often made about a type of a controlled system of second or third order. Thus, in the second stage the necessary methods for tuning the PID controller parameters are selected: the pole placement, Banyász-Keviczky's or Dahlin's method. Conclusions [1] indicate that this automatic tuning method was tested only on second- and third-order controlled systems.


In [2] only one problem is solved, namely, the automatic tuning of PID controller parameters for a heat exchanger. For this purpose, the Augmented Ziegler and Nichols method is used in the second stage, but a choice of tuning coefficients is not disclosed.


DISCLOSURE OF INVENTION

The aim of the invention is rapid automatic tuning the PID controller parameters by analog feedback of an actual value for automation of technological processes with programmable logic controllers.


The proposed invention is based on the use of nine tuning equations derived by reverse engineering of a PID controller. The adaptive tuning of the PID controller parameters Kp, Ki, and Kd is performed separately in time, i.e. at any time point t only one PID parameter is modified. This feature is characterized by equations derived for the adaptive tuning method. Therefore, no simultaneous modification of all three PID controller parameters is allowed. In some tuning equations, the additional limiting coefficients are used to ensure a smooth attenuation of the adaptive tuning method and to prevent an abrupt modification of PID controller parameters in the final phase.


Features of the invention:


The adaptive tuning method is compact, independent of other methods and algorithms, mathematically balanced (i.e., minimal computational resource requirements), and easy to implement.


Setting up a PID controller by this method does not require a preliminary evaluation of a controlled system and the creation of its mathematical model. This implies its universal applicability, i.e. no linking to a specific controlled system.


Possible application restriction:


The method convergence depends on the given initial values of the PID controller parameters Kp, Ki, and Kd analogues to the search algorithms for a minimum in optimization problems.





BRIEF DESCRIPTION OF DRAWINGS

All features that accentuate novelty of the invention are described in detail in the claims attached. However, the essence of the invention is shown in the following detailed description with references to drawings of the best mode for carrying out the invention:



FIG. 1. Time scale for tuning of a PID controller



FIG. 2A. Flowchart of the adaptive tuning method for a PID controller (start)



FIG. 2B. Flowchart of the adaptive tuning method for a PID controller (end)



FIG. 3. Closed control loop



FIG. 4. Reaction of controlled system no. 1 to a step function



FIG. 5. Reaction of controlled system no. 2 to a step function



FIG. 6. Reaction of controlled system no. 3 to a step function



FIG. 7. Reaction of controlled system no. 4 to a step function



FIG. 8. Reaction of controlled system no. 5 to a step function





BEST MODE FOR CARRYING OUT THE INVENTION

The following detailed description with accompanying drawings refers to the best mode for carrying out the invention, which should not be considered as a stripped-down form of the invention object. All amendments and supplements contained in the claims are disclosed in the relevant claims.


The best mode for carrying out the invention is described below.


The proposed invention relates to the adaptive tuning of a PID controller described by a standard equation as follows [3]:











y
t

=



K
p

·

e

t




+


K
i

·




e
t


dt



+


K
d

·


de
t

dt




,




(
1
)







in which:


yt is a control variable at time t;


et is a control error between a setpoint w and an actual value xt at time t, which is calculated as et=w-xt;


Kp is a proportional coefficient;


Ki is an integral action coefficient;


Kd is a derivative action coefficient.


The PID controller (1) is a basis for reverse engineering to derive the tuning equations for parameters Kp, Ki, and Kd. This derivation method is characterized by the following sequence of steps:


Step 01: Eliminate an integrator represented explicitly in a PID controller. This is achieved by differentiating both sides of equation (1) according to the time t[3]:










dy
t

=



K

p



·

de
t


+


K

i



·

e
t

·
dt

+


K
d

·



d
2



e
t


dt







(
2
)







Step 02: Fixing two of the three PID controller parameters at any time point t. To maximally simplify the derivation method of tuning equations, two of the three PID controller parameters Kp, Ki, and Kd are used as fixed values in succession. That is, Ki and Kd are used as fixed values in tuning equations for Kp at time t. Kp and Kd are used as fixed values in tuning equations for Ki at time t+1. And Kp and Ki are used as fixed values in tuning equations for Kd at time t+2. Thus, the adaptive tuning of all three PID controller parameters Kp, Ki, and Kd is performed separately in time, i.e. only one PID parameter is modified at any time point t. To separate the parameter modifications in the tuning method over time and determine the iteration steps, three additional indices k for Kp, m for Ki, and n for Kd are used (see FIG. 1). With these indices the PID controller (2) takes its final form:










dy
t

=



K

p
k


·

de
t


+


K

i
m


·

e
t

·
dt

+


K

d
n


·



d
2



e
t


dt







(
3
)







Step 03: Derive an equation to calculate an adjustment step value dKp k for the proportional coefficient Kp. For this purpose, the parameter Kp k is expressed from (3), and the derived equation is differentiated according to the time t:











dK

p
k


=





(



d
2



y
t


-


K

i

m
-
1



·

de
t

·
dt

-


K

d

n
-
1



·



d
3



e
t


dt



)

·

de
t




(

de
t

)

2


--






(


dy
t

-


K

i

m
-
1



·

e
t

·
dt

-


K

d

n
-
1



·



d
2



e
t


dt



)

·

d
2




e
t




(

de
t

)

2




,




(
4
)







in which:


dyt is a control variable change at time t, which is determined as dyt=yt-yt−1;


d2yt is a 2nd order differential of the control variable yt at time t, which is calculated as d2yt=dyt-dyt−1;


det is a 1st order differential of the control error et at time t, which is calculated as det=et-et−1;


d2et is a 2nd order differential of the control error et at time t, which is calculated as d2et=et-2⋅et−1+et−2;


d3et is a 3rd order differential of the control error et at time t, which is calculated as d3et=et-3⋅et−1⋅et−2-et−3;


Ki m−1 i is the actual integral action coefficient Ki at time t, which was modified in iteration step m−1;


Kd n−1 is the actual derivative action coefficient Kd at time t, which was modified in iteration step n−1.


Step 04: Determine a rule to adjust the proportional coefficient Kp in iteration step k as follows:






K
p

k

=K
p

k−1
−αpk⋅dKpk,60pk⋅dKpk∈[−0.5, +0.5],tm (5)


in which:


Kp k−1 is the actual proportional coefficient Kp at time t, which was modified in iteration step k−1;


αp k is an adjustment speed for the proportional coefficient Kp in iteration step k.


Equation (5) limits the maximum modification of the parameter Kp up to ±0.5 to prevent uncontrollability of the tuning method.


Step 05: Derive an equation to calculate an adjustment speed αp k for the proportional coefficient Kp. For this purpose, equation (5) is substituted into (3), and the control error et is expressed from the derived equation. Considering that a limit of etas t→+∞ equals zero, αp k is expressed from the derived equation:











α

p
k


=





K

p

k
-
1



·

de
t


+


K

d

n
-
1



·



d
2



e
t


dt


-

dy
t




dK

p
k


·

de
t



·
dt


,




(
6
)










α

p
k




[

0.001
,



e
t
4

2.718282



[

0.0001
,
1

]



]





This equation is characterized by an additional limitation of the parameter αp k in the range from 0.0001 to 1 depending on the control error et. This ensures a smooth attenuation of the adaptive tuning method in the final phase. In addition, this prevents an abrupt modification of the proportional coefficient Kp when the control error et approaches zero.


Step 06: Derive an equation to calculate an adjustment step value dKi m for the integral action coefficient Ki. For this purpose, the parameter Ki m is expressed from (3), and the derived equation is differentiated according to the time t:










dK

i
m


=





(



d
2



y
t


-



K

p
k


·

d
2





e
t

·
dt


-


K

d

n
-
1



·



d
3



e
t


dt



)

·

e
t




e
t
2

·
dt


--





(


dy
t

-


K

p
k


·

de
t


-


K

d

n
-
1



·



d
2



e
t


dt



)

·

de
t




e
t
2

·
dt







(
7
)







Step 07: Determine a rule to adjust the integral action coefficient Ki in iteration step m as follows:






K
i

m

=K
i

m−1
im⋅dKim, αim⋅dKim∈[−0.5, +0.5],  (8)


in which:


αi m is an adjustment speed for the integral action coefficient Ki in iteration step m.


Equation (8) limits the maximum modification of the parameter Ki up to ±0.5 to prevent uncontrollability of the tuning method.


Step 08: Derive an equation to calculate an adjustment speed αi m for the integral action coefficient Ki. For this purpose, equation (8) is substituted into (3), and the 1st order differential of the control error det is expressed from the derived equation. Considering that a limit of det as t→+∞ equals zero, αi m is expressed from the derived equation:











α

i
m


=




dy
t

-


K

i

m
-
1



·

e
t

·
dt

-


K

d

n
-
1



·



d
2



e
t


dt





dK

i
m


·

e
t



·
dt


,




(
9
)










α

i
m




[

0.001
,



4
·



"\[LeftBracketingBar]"


e
t
3



"\[RightBracketingBar]"



2.71828



[

0.0001
,
1

]



]





This equation is characterized by an additional limitation of the parameter αi m in the range from 0.0001 to 1 depending on the control error et. This ensures a smooth attenuation of the adaptive tuning method in the final phase. In addition, this prevents an abrupt modification of the integral action coefficient Ki when the control error et approaches zero.


Step 09: Derive an equation to calculate an adjustment step value dKd n for the derivative action coefficient Kd. For this purpose, the parameter Kd n is expressed from (3), and the derived equation is differentiated according to the time t:










dK

d
n


=


(






(



d
2



y
t


-



K

p
k


·

d
2




e
t


-


K

i
m


·

de
t

·
dt


)

·

d
2




e
t




(


d
2



e
t


)

2


--






(


dy
t

-


K

p
k


·

de
t


-


K

i
m


·

e
t

·
dt


)

·

d
3




e
t




(


d
2



e
t


)

2



)

·
dt





(
10
)







Step 10: Determine a rule to adjust the derivative action coefficient Kd in iteration step n as follows:






K
d

n

=K
d

n−1
−αdn⋅dKdn, αdn⋅dKdn∈[−0.5 +0.5],  11)


in which:


αd n is an adjustment speed for the derivative action coefficient Kd in iteration step n.


Equation (11) limits the maximum modification of the parameter Kd up to ±0.5 to prevent uncontrollability of the tuning method.


Step 11: Derive an equation to calculate an adjustment speed αd n for the derivative action coefficient Kd. For this purpose, equation (11) is substituted into (3), and the control error et is expressed from the derived equation. Considering that a limit of et as t→+∞ equals zero, αd n is expressed from the derived equation:











α

d
n


=





K

p
k


·

de
t


+


K

d

n
-
1



·



d
2



e
t


dt


-

dy
t





dK

d
n


·

d
2




e
t



·

dt
2



,




(
12
)










α

d
n




[

0.001
,





"\[LeftBracketingBar]"


e
t
5



"\[RightBracketingBar]"


13.5914



[

0.0001
,
1

]



]





This equation is characterized by an additional limitation of the parameter αd n in the range from 0.0001 to 1 depending on the control error et. This ensures a smooth attenuation of the adaptive tuning method in the final phase. In addition, this prevents an abrupt modification of the derivative action coefficient Kd when the control error et approaches zero.


Step 12: Select a digital PID controller. The PID velocity algorithm is the most suitable variant for this adaptive tuning method (see [4], p. 1085):














y
t

=




y

t
-
1


+

dy

t
+
1



=







=



y

t
-
1


+


(


K
p

+


K
i

·
dt

+


K
d

dt


)

·

e
t


-












(


K
p

+

2
·


K
d

dt



)

·

e

t
-
1



+



K
d

dt

·

e

t
-
2




,










y
t



[

0
,

100

%


]


,


y

t

0


=


dy

t

0


=
0


,





(
13
)







in which:


dyt+1 is a control variable change for the time t+1;


dt is a sampling time of a digital PID controller.


In this equation the actual values of the PID controller parameters Kp, Ki, and Kd are always used at time t.


A choice of the PID velocity algorithm is caused by the following criterion:


Direct integration of control errors et into the control variable yt. In practice, this allows the control variable yt to be forcibly modified as needed without explicitly correcting an integrator for seamless functionality (as distinct from the PID position algorithm)


Finally, a flowchart shown in drawings FIG. 2A and FIG. 2B integrates and arranges the equations for automatic tuning of a digital PID controller as a sequence of steps to illustrate the entirety and completeness of the proposed invention description.


Demonstration of the Invention


To illustrate the description, the invention is demonstrated on some mathematical models of controlled systems.



FIG. 3 shows a closed control loop with negative feedback that consists of a PID controller and a controlled system.


To demonstrate the invention, the adaptive digital PID controller developed for a PLC in the programming language SCL (Structured Control Language [5], see Appendix A) was used with some transfer functions as controlled systems (see Table I).









TABLE I







Transfer functions G(s) of controlled systems in the Laplace s-domain









No.
Transfer functions G(s)
Reference





1





G


(
s
)


=


5

0

0

0



(

s
+
1

)



(

s
+
5

)



(

s
+

1

0

0


)







[6]





2





G


(
s
)


=


1

6

0

0

0

0




7
.
2


2






s
3


+


8
.
2


65






s
2


+

3

81600





s

+

1600

0

0







[7]





3





G


(
s
)


=

1


s
2

+
s
+
1






[8]





4





G


(
s
)


=



0.1





s

+
10




0
.
0


004






s
4


+


0
.
0


45






s
3


+


0
.
5


55






s
2


+


1
.
4


1





s

+
1






[9]





5





G


(
s
)


=




0
.
0


5

1

8

7

9

3

6

-


3
.
5


9

4
×
1


0

-
6







s





0
.
0


0

02979






s
2


+


0
.
0


1

0

11916





s

+

0.00

9

2







[10] 









Since the transfer functions G(s) in the Laplace s-domain cannot be used explicitly in a PLC, they are to be converted beforehand into equivalent equations of the time domain. For this purpose, the transfer functions G(s) are first converted by the MATLAB function c2d from the Laplace s-domain into similar discrete transfer functions in the Z-domain with a sampling time dt=0.1 s (see Table II).









TABLE II







Equivalent transfer functions in the z-domain with a


sampling time dt = 0.1 s










No.
Discrete transfer functions in the z-domain G(z)







1





G


(
z
)


=




0
.
0


5

4

8

8

+

0.2462






z

-
1



+


0
.
0


7307






z

-
2



+


0
.
0


0

02884






z

-
3





1
-


1
.
5


11






z

-
1



+


0
.
5


489






z

-
2



-


2
.
4


9

2
×
1


0

-
5








z

-
3
















2





G


(
z
)


=




0
.
0


2

0

55

+

0.0421






z

-
1



+


0
.
0


4063






z

-
2



+


0
.
0


1885






z

-
3





1
+

0

08548






z

-
1



-


0
.
0


7151






z

-
2



-


0
.
8


918






z

-
3
















3





G


(
z
)


=




0
.
0


0

1

6

2

5

+


0
.
0


06338






z

-
1



+


0
.
0


01546






z

-
2





1
-


1
.
8


95






z

-
1



+


0
.
9


048






z

-
2
















4





G


(
z
)


=






0008

0

9

+

0

06928






z

-
1



+

0

05295






z

-
2



+







00036






z

-
3



-


9
.
1


8

2
×
1


0

-
8








z

-
4











1
-

2059






z

-
1



+

1327






z

-
2



-







02546






z

-
3



+

1

3

0

1
×
1


0

-
5








z

-
4



















5





G


(
z
)


=




0
.
1


4

6

4

+


0
.
3


096






z

-
1



+


0
.
0


2883






z

-
2





1
-


0
.
9


475






z

-
1



+


0
.
0


3348






z

-
2



















The transfer functions in the -domain are then converted into recurrent equations of the time domain as polynomials as follows (for details, see [4], pp. 443-444):






x
t=b1⋅xt−1+b2⋅xt−2+b3⋅xt−3+b4⋅xt−40⋅yt1⋅yt−1++α2⋅yt−23⋅yt−34⋅yt−4,  (14)


in which:


yt is a control variable of a PID controller at time t;


xt is a controlled system response on the control variable as a simulated sensor value at time t.


All polynomial parameters (14) for the simulated controlled systems are given in Table III.









TABLE III







Polynomial parameters (14) for transfer functions of the controlled systems
















No.
b1
b2
b3
b4
a0
a1
a2
a3
a4





1
1.511 
−0.5489
2.492 ×
0
5.488 ×
0.2462
7.307 ×
2.884 ×
0





10−5

10−2

10−2
10−4



2
−8.548 ×
  7.151 ×
0.8918
0
2.055 ×
  4.21 ×
4.063 ×
1.885 ×
0



10−2
10−2


10−2
10−2
10−2
10−2



3
1.895 
−0.9048
0   
0
1.625 ×
6.338 ×
1.546 ×
0
0







10−3
10−3
10−3




4
2.059 
−1.327 
0.2546
−1.301 ×
 8.09 ×
6.928 ×
5.295 ×
 3.6 ×
−9.182 ×






10−5
10−3
10−2
10−2
10−3
10−8


5
0.9475
−3.348 ×
0   
0
0.1464
0.3096
2.883 ×
0
0




10−2




10−2









The simulation was performed on a computer-aided PLC simulator as a closed control loop (see FIG. 3). The results shown in Table IV were obtained for all mathematical models of the controlled systems from Table I. Here Ti is a reset time, which is determined as Ti=Kp/Ki, and Td is a derivative time, which is determined as Td=Kd/Kp. All experiments were performed with initial parameters Kp=1, Ki=1, Kd=1, and a sampling time dt=0.1 s. A step function 0→1 was used as an activation trigger.









TABLE IV







Parameters of a digital PID controller found


using the adaptive tuning method










Parameters of a PID controller for controlled systems












No.
Kp
Ti [s]
Td [S]
FIG.





1
0.167542959333063
1.274823369
0.381714789
4


2
0.998936489520022
0.791433896
0.945415624
5


3
1.16564861359731 
0.999456194
0.999827146
6


4
0.330603372851095
1.025824996
0.260850227
7


5
0.128946021372936
1.275031550
0.390702812
8









References

[1] Vladimir Bobal et. al., “AUTO-TUNING OF DIGITAL PID CONTROLLERS USING RECURSIVE IDENTIFICATION”, Adaptive systems in Control and Signal Processing, Jun. 16, 1995 (1995-06-16), pp. 359-364, XP055754038, Great Britain, ISBN: 978-0-08-042375-3.


[2] Sukede Abhijeet Kishorsingh et al., “Auto tuning of PID controller”, 2015 International Conference on Industrial Instrumentation and Control (ICIC), IEEE, May 28-30, 2015, pp. 1459-1462, XP033170865.


[3] “Three Types of PID Equations”, http://bestune.50megs.com/typeABC.htm


[4] Lutz H., Wendt W., “Taschenbuch der Regelungstechnik mit MATLAB and Simulink”, 10., ergänzte Auflage, Verlag Europa-Lehrmittel, Haan-Gruiten, 2014.


[5] International standard IEC 61131-3:2013. Programmable controllers—Part 3: Programming languages.


[6] Lin Feng, Brandt Robert D., Saikalis George, “Self-tuning of PID Controllers by Adaptive Interaction”, Proceedings of the 2000 American Control Conference, pp. 3676-3681.


[7] Y. Chen et al., “Design of PID Controller of Feed Servo-System Based on Intelligent Fuzzy Control”, Key Engineering Materials, Vol. 693, pp. 1728-1733, 2016.


[8] X. Wang et al., “Simulation Research of CNC Machine Servo System Based on Adaptive Fuzzy Control”, Advanced Materials Research, Vol. 819, pp. 181-185, 2013.


[9] T. Boone et al., “PID Controller Tuning Based on the Guardian Map Technique”, International Journal of Systems Applications, Engineering& Development, Vol. 9, pp. 192-196, 2015.


[10] Dipraj, Dr. A. K. Pandey, “Speed Control of D.C. Servo Motor By Fuzzy Controller”, International Journal of Scientific& Technology Research, Vol. 1, Issue 8, pp. 139-142, 2012.


INDUSTRIAL APPLICABILITY

This invention is preferably used in automation systems of industrial facilities with programmable logic controllers, where the individual tuning of PID controller parameters is required to regulate the technological processes in production.









APPENDIX A





A source code of the adaptive digital PID controller
















001
FUNCTION_BLOCK ″A-PID_CONTROL″









002
TITLE
= A-PID controller


003
AUTHOR
 : Valentin_Dimakov


004
FAMILY
 : PID_CONTROL


005
NAME
 : ′A-PID_CONTROL′


006
VERSION
 : 13.44








007
// FUNCTION


008
// Digital PID controller with automatic tuning of parameters


009
//


010
// Called blocks: none


011



012
VAR_INPUT











013
 MAN_ON
: Bool
:= FALSE;
// Switch-over between manual & automatic mode (0=A/1=M)


014
 AUTO_ON
: Bool
:= FALSE;
// Activate automatic mode for the A-PID controller


015
 INV_CONTROL
: Bool
:= FALSE;
// Control direction (0 = SP > PV, 1 = PV > SP)


016
 CYCLE
: Time
:= T#100MS;
// Sampling time dt for the controller [10 ms. .10 s]


017
 SP
: LReal
:= 0.0;
// Setpoint w <temperature, pressure, etc.>


018
 PV
: LReal
:= 0.0;
// Actual value xt <temperature, pressure, etc.>


019
 LMN_LLM
: LReal
:= 0.0;
// Lower limit for the control variable yt [0..99 %]


020
 LMN_HLM
: LReal
:= 100.0;
// Upper limit for control variable yt [LMN_LLM..100 %]








021
END_VAR


022



023
VAR_OUTPUT











024
 CTRL_ERR
: LReal
:= 0.0;
// Actual control error et


025
 LMN
: LReal
:= 0.0;
// Control variable yt [0..100 %]


026
 ERR_CODE
: USInt
:= 0;
// Error code of the A-PID controller < > 0, 0 = no error








027
END_VAR


028



029
VAR_IN_OUT











030
 SELF_TUN_ON
: Bool
:= FALSE;
// Activate auto-tuning for the A-PID controller


031
 GAIN
: LReal
:= 1.0;
// Proportional coefficient Kp [0.01..30]


032
 TI
: LTime
:= LT#1S;
// Reset time Ti [CYCLE. .100 m]


033
 TD
: LTime
:= LT#1S;
// Derivative time Td [0..60 s]


034
 TUN_ERR_TOLER
: LReal
:= 0.01;
// Threshold value to stop auto-tuning [0..100]


035
 TUN_COMPL_TM
: Time
:= T#3S;
// Delay to stop auto-tuning [1 s..1 m]


036
 LMN_MAN
: LReal
:= 0.0;
// Control variable for the manual mode [0..100 %]








037
END_VAR


038



039
VAR











040
 Kp
: LReal
:= 1.0;
// Proportional coefficient Kp


041
 Ki
: LReal
:= 1.0;
// Integral action coefficient Ki


042
 Kd
: LReal
:= 1.0;
// Derivative action coefficient Kd


043
 PASS_NO
: USInt
:= 0;
// Pass counter for auto-tuning [0..2]








044



045
 e: STRUCT // Control errors at different times










046
  t
: LReal;
// Control error et at time t


047
  t1
: LReal;
// Control error et−1 at time t−1


048
  t2
: LReal;
// Control error et−2 at time t−2


049
  t3
: LReal;
// Control error et−3 at time t−3


050
  t4
: LReal;
// Control error et−4 at time t−4


051
  sqr
: LReal;
// Control error squared e2t at time t








052
 END_STRUCT;


053



054
 y: STRUCT // Control variables


055
  out: LReal; // Internal control variable yt [0..100 %]


056
 END_STRUCT;


057



058
 d: STRUCT // Calculated 1st order differentials










059
  e
: LReal;
// 1st order differential det of the control error et


060
  Kp
: LReal;
// Adjustment step value dKp for the proportional coefficient Kp


061
  Ki
: LReal;
// Adjustment step value dKi for the integral action coefficient Ki


062
  Kd
: LReal;
// Adjustment step value dKd for the derivative action coefficient Kd


063
  y
: LReal;
// Control variable change dyt+1 for the time t+1


064
  y_t1
: LReal;
// Control variable change dyt in previous cycle








065
 END_STRUCT;


066



067
 d2: STRUCT // Calculated 2nd order differentials










068
  e:
LReal;
// 2nd order differential d2et of the control error et


069
  y:
LReal;
// 2nd order differential d2yt of the control variable yt








070
 END_STRUCT;


071



072
 d3: STRUCT // Calculated 3rd order differentials


073
  e: LReal; // 3rd order differential d3et of the control error et


074
 END_STRUCT;


075



076
 a: STRUCT // Adjustment speeds for parameters of the A-PID controller











077
  Kp:
LReal
:= 1.0;
// Adjustment speed ap for the proportional coefficient Kp


078
  Ki:
LReal
:= 1.0;
// Adjustment speed ai for the integral action coefficient Ki


079
  Kd:
LReal
:= 1.0;
// Adjustment speed ad for the derivative action coefficient Kd








080
 END_STRUCT;


081



082
 T_TUN_MON: TON_TIME; // Timer to stop auto-tuning for the A-PID controller


083
END_VAR


084



085
VAR_TEMP










086
 LT_CYCLE
: LTime;
// Sampling time dt for the A-PID controller


087
 Ts
: LReal;
// Sampling time dt for the A-PID controller [sec]


088
 dKp
: LReal;
// Adjustment value for the proportional coefficient Kp


089
 dKi
: LReal;
// Adjustment value for the integral action coefficient Ki


090
 dKd
: LReal;
// Adjustment value for the derivative action coefficient Kd


091
 a_mx_Kp
: LReal;
// Upper limit of the adjustment speed ap for parameter Kp


092
 a_mx_Ki
: LReal;
// Upper limit of the adjustment speed ai for parameter Ki


093
 a_mx_Kd
: LReal;
// Upper limit of the adjustment speed ad for parameter Kd


094
 fact_1
: LReal;
// 1st factor in an equation


095
 fact_2
: LReal;
// 2nd factor in an equation


096
 divisor
: LReal;
// Divisor in an equation








097



098
 r: STRUCT // Time parameters converted to seconds










099
  TI:
LReal;
// Reset time Ti [sec]


100
  TD:
LReal;
// Derivative time Td [sec]








101
 END_STRUCT;


102
END_VAR


103



104
VAR CONSTANT











105
 GAIN_MN
: LReal
:= 0.01;
// Lower limit for the proportional coefficient Kp


106
 GAIN_MX
: LReal
:= 30.0;
// Upper limit for the proportional coefficient Kp


107
 TI_MK
: LTime
:= LT#100M;
// Upper limit for the reset time Ti


108
 TD_MK
: LTime
:= LT#1M;
// Upper limit for the derivative time Td


109
 LMN_MN
: LReal
:= 0.0;
// Lower limit for the control variable yt [%]


110
 LMN_MK
: LReal
:= 100.0;
// Upper limit for the control variable yt [%]


111
 TUN_ACCURACY
: LReal
:= 1.0E−07;
// Computational accuracy for auto-tuning


112
 TUN_ERR_TOLER_MN
: LReal
:= 0.0;
// Minimum control error et to stop auto-tuning


113
 TUN_ERR_TOLER_MK
: LReal
:= 100.0;
// Maximum control error et to stop auto-tuning


114
 TUN_COMPL_TM_MN
: Time
:= T#1S;
// Minimum delay to stop auto-tuning


115
 TUN_COMPL_TM_MK
: Time
:= T#1M;
// Maximum delay to stop auto-tuning


116
 CF_MN
: LReal
:= 0.0001;
// Lower limit for an adjustment speed


117
 CF_MK
: LReal
:= 1.0;
// Upper limit for an adjustment speed








118
END_VAR


119



120
BEGIN


121
 // Reset an error code of the A-PID controller


122
 #ERR_CODE := 0;


123



124
 IF #CYCLE < T#10MS OR #CYCLE > T#10S THEN


125
   // E01 = Sampling time CYCLE is out of the range [10 ms. .10 s]









126
   #ERR_CODE
:= 1;


127
   #y.out
:= 0.0;








128
 ELSIF #LMN_LLM > #LMN_HLM THEN


129
   // E02 = Lower limit for the control variable LMN_LLM > upper limit LMN_HLM









130
   #ERR_CODE
:= 2;


131
   #y.out
:= 0.0;








132
 ELSIF #LMN_LLM < #LMN_MN THEN


133
   // E03 = Lower limit for the control variable LMN_LLM < 0 %









134
   #ERR_CODE
:= 3;


135
   #y.out
:= 0.0;








136
 ELSIF #LMN_HLM > #LMN_MK THEN


137
   // E04 = Upper limit for the control variable LMN_HLM > 100 %









138
   #ERR_CODE
:= 4;


139
   #y.out
:= 0.0;








140
 ELSE


141
   // Convert the sampling time dt to seconds


142
   #Ts := DINT_TO_LREAL(TIME_TO_DINT(#CYCLE)) / 1000.0;


143



144
   // Convert the sampling time dt to IEC high resolution time


145
   #LT_CYCLE := TIME_TO_LTIME(#CYCLE);


146



147
   // Check the permissible values of the A-PID controller parameters












148
   #GAIN
:= LIMIT(IN
:= #GAIN,
MN := #GAIN_MN,
MX := #GAIN_MK);


149
   #TI
:= LIMIT(IN
:= #TI,
MN := #LT_CYCLE,
MX := #TI_MK);


150
   #TD
:= LIMIT(IN
:= #TD,
MN := LT#0NS,
MX := #TD_ME);










151
   #TUN_ERR_TOLER
:= LIMIT(IN := #TUN_ERR_TOLER,
MN := #TUN_ERR_TOLER_MN,


152


MX := #TUN_ERR_TOLER_MX);


153
   #TUN_COMPL_TM
:= LIMIT(IN := #TUN_COMPL_TM,
MN := #TUN_COMPL_TM_MN,


154


MX := #TUN_COMPL_TM_MX);


155
   #LMN_MAN
:= LIMIT(IN := #LMN_MAN,
MN := #LMN_MN, MX := #LMN_MX) ;








156



157
   // Save the previous control errors


158
   #e.t4 := #e.t3;


159
   #e.t3 := #e.t2;


160
   #e.t2 := #e.t1;


161
   #e.t1 := #e.t;


162



163
   // Calculate a control error et according to the specified control direction


164
   IF #INV_CONTROL THEN


165
    #e.t := #PV − #SP;


166
   ELSE


167
    #e.t := #SP − #PV;


168
   END_IF;


169



170
   // Output an actual control error et


171
   IF #INV_CONTROL THEN


172
    #CTRL_ERR := −#e.t;


173
   ELSE


174
    #CTRL_ERR := #e.t;


175
   END_IF;


176



177
   // Activate the A-PID controller in automatic mode


178
   IF #AUTO_ON AND NOT #MAN_ON THEN


179
    // Stop condition for auto-tuning of the A-PID controller


180
    #T_TUN_MON(IN:= #SELF_TUN_ON AND ABS(#e.t) <= #TUN_ERR_TOLER, PT: =



    #TUN_COMPL_TM);


181
    IF #T_TUN_MON.Q THEN









182
     #SELF_TUN_ON
:= FALSE;


183
     #PASS_NO
:= 0;








184
    END_IF;


185



186
    // Convert a reset time Ti to seconds


187
    #r.TI := LINT_TO_LREAL(LTIME_TO_LINT(#TI)) / 1.0E+9;


188



189
    // Calculate an integral action coefficient Ki


190
    #Ki := #GAIN / #r.TI;


191



192
    // Convert a derivative time Td to seconds


193
    #r.TD := LINT_TO_LREAL(LTIME_TO_LINT(#TD)) / 1.0E+9;


194



195
    // Calculate a derivative action coefficient Kd


196
    #Kd := #GAIN * #r.TD;


197



198
    // Save a proportional coefficient Kp


199
    #Kp := #GAIN;


200



201
    (************************************************************************


202
     *     AUTO-TUNING OF THE A-PID CONTROLLER PARAMETERS     *


203
     ************************************************************************)


204
    IF #SELF_TUN_ON AND ABS (#e.t4) > 0.0 AND ABS (#d.y_t1) > 0.0 THEN


205
     // Calculate a 2nd order differential d2yt for the control variable yt


206
     #d2.y := #d.y - #d.y_t1;


207



208
     // Calculate a 1st order differential det for a control error et


209
     #d.e := #e.t − #e.t1;


210



211
     // Calculate a 2nd order differential d2et for a control error et


212
     #d2.e := #e.t − 2.0 * #e.t1 + #e.t2;


213



214
     // Calculate a 3rd order differential d2et for a control error et


215
     #d3.e := #e.t − 3.0 * #e.t1 + 3.0 * #e.t2 − #e.t3;


216



217
     // Calculate upper limits for the adjustment speeds of controller parameters









218
     #e.sgr
:= #e.t * #e.t;










219
     #a_mx_Kp
:= LIMIT(IN := #e.sgr * #e.sgr / 2.71828,
MN := #CF_MN, MX := #CF_ME);









220
     #a_mx_Ki
:= LIMIT(IN := 4.0 * ABS(#e.sgr * #e.t) / 2.71828,










221


MN := #CF_MN, MX := #CF_ME);









222
     #a_mx_Kd
:= LIMIT(IN := ABS(#e.t * #e.sgr * #e.sgr) / 13.5914,










223


MN := #CF_MN, MX := #CF_ME);








224
     (************************************************************************


225
      *        AUTO-TUNING OF THE PROPORTIONAL PART        *


226
      ************************************************************************)


227
     // Perform auto-tuning for the proportional coefficient Kp


228
     IF #PASS_NO = 0 THEN


229
      // Calculate an adjustment step value dKp for the proportional coefficient Kp


230
      IF ABS(#d.e) > #TUN_ACCURACY THEN









231
       #fact_1
:= #d2.y − #Ki * #d.e * #Ts − #Kd * #d3.e / #Ts;


232
       #fact_2
:= #d.y − #Ki * #e.t * #Ts − #Kd * #d2.e / #Ts;


233
       #d.Kp
:= (#fact_1 * #d.e − #fact_2 * #d2.e) / (#d.e * #d.e);








234
      ELSE


235
       #d.Kp := 0.0;


236
      END_IF;


237



238
      // Calculate an adjustment speed ap for the proportional coefficient Kp


239
      #divisor := #d.Kp * #d.e;


240
      IF ABS(#divisor) > #TUN_ACCURACY THEN


241
       #a.Kp := (#Kp * #d.e + #Kd * #d2.e / #Ts − #d.y) * #Ts / #divisor;


242
       #a.Kp := LIMIT(IN := #a.Kp, MN := #CF_MN, MX := #a_mx_Kp);


243
      ELSE


244
       #a.Kp := #CF_MN;


245
      END_IF;


246



247
      // Adjust the proportional coefficient Kp











248
      #dKp
:= LIMIT(IN := #a.Kp * #d.Kp,
MN := −0.5,
MX := 0.5);


249
      #GAIN
:= LIMIT(IN := #GAIN − #dKp ,
MN := #GAIN_MN,
MX := #GAIN_MX);


250
      #Kp
:= #GAIN;










251
     END_IF;


252



253
     (************************************************************************


254
      *        AUTO-TUNING OF THE INTEGRAL PART         *


255
      ************************************************************************)


256
     // Perform auto-tuning for the integral action coefficient Ki


257
     IF #PASS_NO = 1 THEN


258
      // Calculate an adjustment step value dKi for integral action coefficient Ki


259
      IF ABS(#e.t) > #TUN_ACCURACY THEN









260
       #fact_1
:= #d2.y − #Kp * #d2.e − #Kd * #d3.e / #Ts;


261
       #fact_2
:= #d.y − #Kp * #d.e − #Kd * #d2.e / #Ts;


262
       #d.Ki
:= (#fact_1 * #e.t − #fact_2 * #d.e) / (#e.t * #e.t * #Ts);








263
      ELSE









264
       #d.Ki
:= 0.0;








265
      END_IF;


266



267
      // Calculate an adjustment speed ai for the integral action coefficient Ki


268
      #divisor := #d.Ki * #e.t;


269
      IF ABS(#divisor) > #TUN_ACCURACY THEN


270
       #a.Ki := (#d.y − #Ki * #e.t * #Ts − #Kd * #d2.e / #Ts) * #Ts / #divisor;


271
       #a.Ki := LIMIT(IN := #a.Ki, MN := #CF_MN, MX := #a_mx_Ki);


272
      ELSE


273
       #a.Ki := #CF_MN;


274
      END_IF;


275



276
      // Adjust the integral action coefficient Ki










277
      #dKi
:= LIMIT(IN
:= #a.Ki * #d.Ki, MN := −0.5, MX := 0.5);


278
      #Ki
:= LIMIT(IN
:= #Ki + #dKi,









279
        MN
:= #GAIN * 1.0E+9 / LINT_TO_LREAL(LTIME_TO_LINT(#TI_MX)),


280
        MX
:= #GAIN / #Ts);








281



282
      // Convert Ki to a reset time Ti [sec]


283
      #r.TI := #GAIN / #Ki;


284



285
      // Convert a reset time Ti [sec] to IEC high resolution time


286
      #TI := LINT_TO_LTIME(LREAL_TO_LINT(#r.TI * 1.0E+9));


287
     END_IF;


288



289
     (************************************************************************


290
      *        AUTO-TUNING OF THE DERIVATIVE PART         *


291
      ************************************************************************)


292
     // Perform auto-tuning for the derivative action coefficient Kd


293
     IF #PASS_NO = 2 THEN


294
      // Calculate an adjustment step value dKd for the derivative action coeff. Kd


295
      IF ABS(#d2.e) > #TUN_ACCURACY THEN


296
       #fact_1 := #d2.y − #Kp * #d2.e − #Ki * #d.e * #Ts;


297
       #fact_2 := #d.y − #Kp * #d.e − #Ki * #e.t * #Ts;


298
       #d.Kd := (#fact_1 * #d2.e − #fact_2 * #d3.e) * #Ts / (#d2.e * #d2.e);


299
      ELSE


300
       #d.Kd := 0.0;


301
      END_IF;


302



303
      // Calculate an adjustment speed ad for the derivative action coefficient Kd


304
      #divisor := #d.Kd * #d2.e;


305
      IF ABS(#divisor) >#TUN_ACCURACY THEN


306
       #a.Kd := (#Kp * #d.e + #Kd * #d2.e / #Ts − #d.y) * #Ts * #Ts / #divisor;


307
       #a.Kd := LIMIT(IN := #a.Kd, MN := #CF_MN, MX := #a_mx_Kd);


308
      ELSE


309
       #a.Kd := #CF_MN;


310
      END_IF;


311



312
      // Adjust the derivative action coefficient Kd












313
      #dKd
:= LIMIT(IN
:= #a.Kd * #d.Kd,
MN := −0.5,
MX := 0.5);


314
      #Kd
:= LIMIT(IN
:= #Kd − #dKd,
MN := 0.0,










315
        MX
:= #GAIN * LINT_TO_LREAL(LTIME_TO_LINT(#TD_MX))/ 1.0E+9);








316



317
      // Convert Kd to a derivative time Td [sec]


318
      #r.TD := #Kd / #GAIN;


319



320
      // Convert a derivative time Td [sec] to IEC high resolution time


321
      #TD := LINT_TO_LTIME(LREAL_TO_LINT(#r.TD * 1.0E+9));


322
     END_IF;


323



324
     // Increase a pass counter by one for auto-tuning


325
     #PASS_NO := #PASS_NO + 1;


326



327
     // Reset a pass counter if it is greater than 2


328
     IF #PASS_NO > 2 THEN


329
      #PASS_NO := 0;


330
     END_IF;


331
    ELSE


332
     #PASS_NO := 0;


333
    END_IF;


334



335
    (****************************************************


336
     *         DRIVE CONTROL         *


337
     ****************************************************)


338
    // Save a control variable change dyt


339
    #d.y_t1 := #d.y;


340



341
    // Calculate a control variable change dyt+i for the time t+1


342
    #d.y := (#Kp + #Ki * #Ts + #Kd / #Ts) * #e.t − (#Kp + 2.0 * #Kd / #Ts) * #e.t1 +


343
       #Kd / #Ts * #e.t2;


344



345
    // Modify the control variable yt at time t


346
    #y.out := LIMIT(IN := #y.out + #d.y, MN := #LMN_LLM, MX := #LMN_HLM);


347
   ELSE


348
    IF #MAN_ON THEN


349
     // Use the control variable for manual mode


350
     #y.out := LIMIT(IN := #LMN_MAN, MN := #LMN_MN, MX := #LMN_MX);


351
    ELSE


352
     // Reset a control variable yt at standstill


353
     #y.out := #LMN_MN;


354
    END_IF;


355
    // Reset the internal controller variables










356
    #d.y
:= #d.y_t1
:= 0.0;


357
    #e.t
:= #e.t1
:= #e.t2 := #e.t3 := 0.0;









358
    #PASS_NO
:= 0;








359
   END_IF;


360
 END_IF;


361



362
 // Move the actual control variable yt to the control variable for manual mode


363
 #LMN_MAN := #y.out;


364



365
 // Output a control variable yt


366
 #LMN := #y.out;


367



368
END_FUNCTION_BLOCK








Claims
  • 1. The subject matter of the invention is an adaptive tuning method for parameters of a digital PID controller, which is characterized by using the nine tuning equations derived by reverse engineering of a PID controller.
  • 2. An adaptive tuning method for parameters of a digital PID controller according to claim 1, which is characterized by adaptive tuning of the PID controller parameters Kp, Ki and Kd in the following: the adaptive tuning is performed in a closed control loop separately in time by means of a pass counter and three additional indices k for Kp, m for Ki, and n for Kd that are used as iteration steps in order to modify only one PID parameter at any time point t;the separate tuning of PID parameters over time is caused by the derived tuning equations.
  • 3. An adaptive tuning method for parameters of a digital PID controller according to claim 2, which is characterized in that the adaptive tuning of the PID controller parameters Kp, Ki and Kd is performed cyclically in equal time intervals and comprises the following sequence of steps: S01: StartS02: Reset a time index t to 0 and set a time counter to 0 secondsS03: Reset an iteration step k for Kp to 0S04: Reset an iteration step m for Ki to 0S05: Reset an iteration step n for Kd to 0S06: Set the proportional coefficient Kp to an initial value when k=0S07: Set the integral action coefficient K to an initial value when m=0S08: Set the derivative action coefficient Kd to an initial value when n=0S09: Increase an iteration step k for Kp by 1S10: Increase an iteration step m for Ki by 1S11: Increase an iteration step n for Kd by 1S12: Reset a pass counter to 0S13: Set a control variable yt to 0 at time tS14: Set a control variable change dyt to 0 at time tS15: Set a control variable change dyt+1 to 0 for the time t+1S16: Increase a time index t by 1 and a time counter by a sampling time dtS17: Calculate an actual control error et between a setpoint w and an actual value xt at time t as et=w−xt S18: If a time index t>3, go to step S19, otherwise go back to step S13S19: If an absolute value of the actual control error et falls below a specified threshold, go to step S41, otherwise go to step S20S20: Evaluate a pass counter between 0 and 2: if its value is 0, go to step S21; if its value is 1, go to step S25; or if its value is 2, go to step S29S21: Calculate an adjustment step value dKp k for the proportional coefficient Kp in iteration step k at time t
Continuation in Parts (1)
Number Date Country
Parent PCT/DE2019/000338 Dec 2019 US
Child 17809162 US