Bendjeghaba 2013
Bendjeghaba 2013
Abstract— This paper presents a firefly algorithm (FA) for tuning the cooperating firefly’s agents to solve optimization problems
the proportional-integral-derivative (PID) controller parameters in was introduced by Xin-She Yang at Cambridge University and
order to achieve a desired transient response. The proposed presented in [7] then extended in his further works [8]. It has
approach has superior features including easy implementation, been recently adapted for solving various design problems
stable convergence characteristic and good computational [9,10,11].
efficiency. Comparing with Ziegler-Nichols method, the proposed
method is more efficient in improuving the step response The FA has been successfully applied to the Permutation
characteristics. Flow Shop Scheduling Problems in [9], to the Clustering
problem in [10], and to Mixed variable structural optimization
Keywords-firefly algortihm ; pid controller; optimization; in [11]. Ant algorithm shows very good results in each applied
metaheuristic. area. In this paper a new tuning method is proposed and used
for tuning the PID controller parameters of three different
I. INTRODUCTION processes. The obtained results are compared through
The conventional PID controller’s is the most widely used simulation with Ziegler-Nichols (ZN) existing method. The
control strategy in many industrial processes. This popularity is simulation experimentations show that the FA based approach
due to their functional simplicity, reliability and broad outperforms the Ziegler-Nichols method.
applicability. The PID control algorithm is used to control
The paper is organized as follows. Section II presents the
approximately all loops in process industries and it is also
PID parameters tuning problem formulation. In section III we
the cornerstone for many advance control algorithms and
describe the basics of the FA. The proposed approach
strategies [1]. However, industrial implementations of PID
implementation is explained in section IV. Numerical
controllers show that their parameter tuning still presents a
simulation and comparisons are provided in Section V. Finally,
challenge in many applications. Traditionally, the problem has
some conclusions are drawn in Section VI.
been handled by a trial and error approach. In the past decades
more systemic methods have been introduced. Ziegler-Nichols II. FORMULATION OF PID PARAMETERS TUNING PROBLEM
and Cohen-Coon’s are the best known tuning methods [2,3].
Despite the hug number of proposed approaches, they are not We consider the block diagram shown in Fig.1. In this
completely systemic and more of them occasionally yield poor figure GPID ( s ) is the controller and GP ( s ) is the process to be
performance in practice. controlled. In practice the output and the transfer function (in
parallel structure) of the PID controller are given respectively
Recently, metaheuristic approaches have received increased by the equations [1]:
attention from researchers dealing with engineering control
problems. In 1997 a modified GA approach was presented by ª 1 de ( t ) º
Bagis to find the optimal parameters of the PID controller so
that the desired system specifications are satisfied [4].
u ( t ) = k p ( t ) «e ( t ) +
¬« Ti
³ e ( t ) dt + T
d
dt ¼»
» (1)
For a given plant or process, the main goal of PID tuning Where, r is the distance between any two fireflies, β0 is the
problem, is to adjust optimally as fast as possible the PID initial attractiveness at r = 0 , and γ is the absorption
controller parameters for getting a desired performance with a
good closed loop time response of the considered process. For parameter which control the decrease of the light intensity.
this purpose, the proposed PID tuning based FA is
schematically shown in Fig.2 Procedure of the CFA Metaheuristic
Begin;
FA Initialize algorithm parameters;
Kp, Ki, Kd Define the objective function of f(x), where x=(x1,........,xd)T
Input Output
PID Plant Generate the initial population of fireflies or xi (i=1, 2 ,..., n)
Determine the light intensity of Ii at xi via f(xi)
Sensor While (t<MaxGen)
Figure 2. PID tuning scheme with FA For i = 1 to n (all n fireflies);
For j=1 to n (n fireflies)
The objective of the FA is to determine theses optimal
parameters values by minimization of predetermined fitness if (Ij > Ii), move firefly i towards j;
function. In time domain, the fitness function can be formed by end if
different performance specifications such as the integral of Attractiveness varies with distance r via Exp[-Ȗr2];
time multiplied by absolute-error value (ITAE), rise time,
settling time, overshoot and steady state error. In this paper, the Evaluate new solutions and update light intensity;
following performance function is used as fitness function End for j;
during the design of PID controller:
End for i;
(
F = (1 − e− ρ )(OS + Ess) + e− ρ(ts + tr ) ) (3) Rank the fireflies and find the current best;
End while;
Where, is a weighting factor, OS , Ess , ts and tr are
ρ
Post process results and visualisation;
respectively the integral of time multiplied by absolute-
End procedure;
error value, the maximum overshoot, the steady state
error, the settling time and the rising time of the
performance criteria in the time domain. Figure 3. Pseudo code of the CFA Metaheuristic.
III. BASICS OF FIREFLY ALGORITHM The distance r between any two fireflies i and j , at
Firefly Algorithm is a nature inspired algorithms, which is position xi and x j , respectively, can be defined as a Cartesian
based on the flashing light of fireflies. In fact the algorithm has
three particular idealized rules which are based in real on some or Euclidean as follows :
major flashing characteristics of real fireflies [7]. These are the d
¦ (x )
following: (1) all fireflies are unisex, and they will move 2
rij = i,k − x j,k (5)
towards more attractive and brighter ones regardless their sex.
k =1
(2) the degree of attractiveness of a firefly is proportional to its
brightness which decreases as the distances from the other Where, xi,k is the k th component of the spatial coordinate
fireflies increases. (3) If there is not brighter or more attractive
firefly then a particular one, then it will move randomly. xi of the i th firefly and d is the dimension number.
For an optimization problem, the flashing light is associated • Movement
with the fitness function in order to obtain efficient optimal
solutions. The main steps of standard firefly algorithm are The movement of a firefly i which is attracted by a
given by the pseudo code shown in Fig.3. brighter firefly j is given by the following equation:
In this algorithm, when searching for solutions the fireflies
uses two main procedures: attractiveness and movement, which (
xi = xi + β 0 * exp −γ rij2 * x j − xi + ) ( )
are defined as follows: (6)
α * §¨ rand − ·¸
1
• Attractiveness © 2¹
The form of the attractiveness function of a firefly is the Where the first term is the current position of a firefly, the
following monotonically decreasing function: second term is used for considering a firefly’s attractiveness to
light intensity seen by adjacent fireflies, and the third term is
(
β ( r ) = β0 exp −γ r m , with m ≥ 1 ) (4) used for the random movement of a firefly in case there are not
any brighter ones. The coefficient α is a randomization
TABLE II. BEST SOLUTIONS USING FA AND Z-N FOR DIFFERENT PROCESSES WITH ρ = 1.5
The time responses for the ZN and the FA based PID It is observed from these figures that the FA based PID
controllers are also plotted on Fig.5, Fig.6 and Fig.7 controller has better set point tracking compared to Ziegler-
Nichols based PID controller.
1.4
Step Response
VI. CONLUSION
1.2
The parameters tuning problem of PID controller has been
Z-N efficiently solved in this paper by using a new metaheuristic
1
based on firefly algorithm. Three test processes have been
0.8
FA examined and results have been attractive. When compared to
Z-N method, FA results in a superior system performance in
term of time domain specifications. Finally, we can say that the
A m p lit u d e
0.6
FA
2010, 170–174.
0.6
0.8 FA
A m p litu d e
0.6
0.4
0.2
0
0 1 2 3 4 5 6 7 8 9 10
Time (sec)