Embedded system based on a real time fuzzy motor speed controller  by Ramadan, Ebrahim Abd El-Hamid Mohamed et al.
Ain Shams Engineering Journal (2014) 5, 399–409Ain Shams University
Ain Shams Engineering Journal
www.elsevier.com/locate/asej
www.sciencedirect.comELECTRICAL ENGINEERINGEmbedded system based on a real time fuzzy
motor speed controller* Corresponding author.
E-mail addresses: Eng_ebrahimramadan@yahoo.com (Ebrahim Abd
El-Hamid Mohamed Ramadan), Drelbardini@ieee.org (M. El-Bardi-
ni), Nabila2100@gmail.com (N.M. El-Rabaie), mafkirin@yahoo.com
(M.A. Fkirin).
1 Fax: +20 483660716 (work).
Peer review under responsibility of Ain Shams University.
Production and hosting by Elsevier
2090-4479  2013 Production and hosting by Elsevier B.V. on behalf of Ain Shams University.
http://dx.doi.org/10.1016/j.asej.2013.10.001Ebrahim Abd El-Hamid Mohamed Ramadan *, Mohammad El-Bardini 1,
Nabila M. El-Rabaie 1, Mohamed A. Fkirin 1Department of Industrial Electronics and Control, Faculty of Electronic Engineering – Menof., Menoﬁa University,
32952 Menof., EgyptReceived 11 May 2013; revised 26 September 2013; accepted 8 October 2013
Available online 15 November 2013KEYWORDS
Fuzzy logic control;
PI controller;
VHDL;
FPGA;
Spartan-3E starter kitAbstract This paper describes an implementation of a fuzzy logic control (FLC) system and a/the
conventional proportional-integral (PI) controller for speed control of DC motor, based on ﬁeld
programmable gate array (FPGA) circuit. The proposed scheme is aimed to improve the tracking
performance and to eliminate the load disturbance in the speed control of DC motors. The pro-
posed fuzzy system has been applied to a permanent magnet DC motor, via a conﬁguration of
H-bridge. The fuzzy control algorithm is designed and veriﬁed with a nonlinear model, using the
MATLAB tools. Both FLC and conventional PI controller hardware are synthesized, functionally
veriﬁed and implemented using Xilinx Integrated Software Environment (ISE) Version 11.1i. The
real time implementation of these controllers is made on Spartan-3E FPGA starter kit (XC3S500E).
The practical results showed that the proposed FLC scheme has better tracking performance than
the conventional PI controller for the speed control of DC motors.
 2013 Production and hosting by Elsevier B.V. on behalf of Ain Shams University.1. Introduction
Intelligent controllers as new technologies have recently been
applied to electrical power control systems in general and mo-tor control systems in particular [1]. Many digital techniques
have been used to implement a digital controller. However,
the conventional proportional–integral–derivative (PID) con-
troller is still being a key component in industrial control sys-
tems, because it is simple and provides useful solutions to
many industrial processes [2].
Fuzzy logic control (FLC) provides an alternative to the
PID controller since it is a good tool for the control of nonlin-
ear systems that are difﬁcult in modeling [3–5]. PID controller
can be transformed into a PID-like structure of fuzzy
controllers.
Several fuzzy control applications including the physical
systems, require a real time operation to interface high speed
constraints [6,7]. Higher density programmable logic devices,
such as ﬁeld programmable gate array (FPGA) can be used
Figure 1 DC motor equivalence circuit.
Figure 4 Triangular type membership function.
400 Ebrahim Abd El-Hamid Mohamed Ramadan et al.to integrate large amounts of fuzzy logic in a single integrated
circuit (IC) [8,9]. FPGAs are one of the fastest growing parts of
the digital integrated circuit market in recent times. Reconﬁg-
urable FPGA systems provide additional ﬂexibility and can
adapt to various computational tasks through hardware reuse.
Therefore, FPGA becomes one of the most successful technol-Fuzzification 
stage
Crisp input
Error &change of 
error
Active Ru
addres
generato
Figure 3 FLC
Table 1 The proposed fuzzy characteristics.
Fuzzy inference system
Inputs
Input resolution
Outputs
Output resolution
Antecedent MF’s
Antecedent MF degree of truth resolution
Consequent MF’s
Consequent MF degree of truth resolution
Aggregation method
Implication method
Defuzziﬁcation method
1Z
+
_
Kp +
+
+
+
Ki
Prop. term
Integ. term
speed 
PI-controller
Reference
Figure 2 Overall block diagram of PIogies for developing the systems which require a real time
operation [10–12].
Many researchers discussed the design of the hardware fuz-
zy logic controller. Numbers of these works were specialized in
control application [13–15] and were aimed to get better con-
trol responses [16]. The proposed design in this paper aimsles 
s
rs
Rules data 
base
Rules
inference
Aggregation
defuzzification
Crisp
output
architecture.
Mamdani FIS
2
8-bit
1
8-bit
7 triangular per fuzzy se
8-bit
7 triangular per fuzzy set
8-bit
MAX
MIN
Center of Gravity (COG)
Control signal
Actual
speedu DC 
motor++
1Z
Δ
based control system for DC motor.
FLC
+
+
_
Δe
espeed
Reference
Control signal
Actual
speed
_
t
up
ni
psirC
t
upt
u
o
psirC
+
+
Δu DC
motor
Z
Z
Fuzzy Controller
1
1
Figure 5 Overall block diagram of FLC based control system for DC motor.
MF1 MF2 MF3 MF4 MF5 MF6 MF7
2550
1
μ (x)
Input-variable
Output-variable
128
Figure 6 Input and output membership functions.
Table 3 The synthesis report from ISE WebPack program.
Device utilization summary (estimated values)
Logic utilization Used Available Utilization (%)
Number of slices 2193 4656 47
Number of slice Flip ﬂops 1900 9312 20
Number of 4 input LUTs 4048 9312 43
Number of bonded IOBs 282 232 121
Number of MULT 18X18SIOs 16 20 80
Number of GCLKs 2 24 8
Embedded system based on a real time fuzzy motor speed controller 401to employ the new techniques of PI-fuzzy algorithm in estimat-
ing and controlling the speed of a separately excited DC motor
and compare it to the conventional PI control to serve these
applications efﬁciently. The two controllers are coded in
VHDL. Xilinx ISE which is used for synthesis and implemen-
tation of controllers on the Spartan-3E FPGA Kit.
2. Modeling of DC motor
A schematic representation of an armature controlled DC mo-
tor is given in Fig. 1. According to this schematic representa-
tion, the equations based on the Kirchoff’s voltage law
combined with the Newton’s moment law can write as follows
[17,18];Table 2 Fuzzy controller operation.
e MF1 MF2 MF3 MF4 MF5 MF6 MF7
De Du 001 010 011 100 101 110 111
MF1 MF1 MF1 MF1 MF1 MF2 MF3 MF4
001 001 001 001 001 010 011 100
MF2 MF1 MF1 MF1 MF2 MF3 MF4 MF5
010 001 001 001 010 011 100 101
MF3 MF1 MF1 MF2 MF3 MF4 MF5 MF6
011 001 001 010 011 100 101 110
MF4 MF1 MF2 MF3 MF4 MF5 MF6 MF7
100 001 010 011 100 101 110 111
MF5 MF2 MF3 MF4 MF5 MF6 MF7 MF7
101 010 011 100 101 110 111 111
MF6 MF3 MF4 MF5 MF6 MF7 MF7 MF7
110 011 100 101 110 111 111 111
MF7 MF4 MF5 MF6 MF7 MF7 MF7 MF7
111 100 101 110 111 111 111 111
Figure 7 Spartan 3E layout.
Accessory Header
J1 6-pin 
6-pin DAC Header (J5)
Figure 8 Spartan 3E starter kit.
402 Ebrahim Abd El-Hamid Mohamed Ramadan et al.Va ¼ La dia
dt
þ Raia þ Vb ð1Þ
Tm ¼ Jm þ 1
K2g
J‘
 !
dxm
dt
þ 1
K2g
btxm ð2Þ
Tm ¼ KTia ð3Þ
Vb ¼ Kbxm ð4Þ
In addition, the transfer function from input Va to output x‘ is
given by the following:
x‘ðsÞ
VaðsÞ ¼
KgKT
LaJeqS
2 þ ðLabt þ RaJeqÞSþ Rabt þ K2gKTKb
ð5Þ
where Jeq ¼ ðK2gJm þ J‘Þ and kg ¼ xmx‘
Tm motor torque,
KT motor torque constant,
Kb motor constant,
xm armature angular velocity,
Jm motor inertia,
J‘ load inertia,
x‘ shaft angular velocity,
hm armature angular position,
Va(t) armature voltage,
ia(t) armature current,
Vb back e.m.f,FPGA 
Spartan 3E
Kit J1-
A
cc
es
so
ry
 
H
ea
de
r
 
D
A
C 
H
ea
de
r 
(J5
)
+5V
+
-
470220k
33k1uF
Triangle generator
Control Signal
+
1k
PWM si
Figure 9 Block diagram of the DC mRa armature resistance,
La armature inductance,
Kg gear-box ratio,
bt rotational viscous friction,
h‘ shaft angular position.
3. Modeling of PI controller using VHDL
The standard representation of a PI controller is given by Eq.
(6); where, there are two main components that can be identi-
ﬁed; they are the proportional and integral terms as shown in
Fig. 2. The error signal e(t) is deﬁned by Eq. (7), and it is the
difference between the process output and the desired speed.
The integral term was obtained using the method of rectangu-
lar integration. In this equation, Kp and Ki, are parameters re-
lated to the gain of each term.
uPIðtÞ ¼ kpeðtÞ þ ki
Z t
0
eðtÞdt ð6ÞeðtÞ ¼ Reference speedActual speed ð7Þ
The algorithm given by Eq. (6) is seldom used in practice. In this
work, for speed control of aDCmotor, a cascaded control struc-
ture is usually preferred. This controller is known as parallelism
controller which is being used [19]. By differentiating Eqs. (6)
and (8) can be obtained, where UPI is the control signal.
duPIðtÞ
dt
¼ kp deðtÞ
dt
þ kieðtÞ ð8Þ
In discrete-time systems, Eq. (8) can be written as follows:
uPIðkTÞ  uPIðkT TÞ ¼ kpðeðkTÞ  eðkT TÞÞ þ kieðkTÞ ð9Þ
In simulation, the parameters Va, x‘, Ra, La, Kg, Jeq, bt, Kb and
KT in Fig. 1 are set as 24 vdc, 300 rpm, 4.67 X, 170 mH, 0.16,
42.6e6 kg m2, 47.3e6 N m s/rad, 14.7e3 V s/rad and
14.7e6 N m/A, respectively [20]. From the open loop step re-
sponse of Permanent Magnet DC motor, the values of the con-
troller parameters are tuned using Ziegler-Nichole method [4].
The values found are Kp = 0.19 and Ki = 0.0301.Optical 
encoderChannel A
Channel B
Index
+24V
Mechanical
coupling10k
M
10k
Vcc
Same signal
gnal
otor speed control using FPGA.
clk
Reset
en
Fu
zz
y 
-e
n
Fu
zz
y 
-R
es
et
Fu
zz
y 
-e
n
-
R
es
et
Fu
zz
y 
– 
va
lid
-o
ut
en-Reset
Fuzzy - Inputs
validout
INs-Mfs-Param
Crisp - Inps INs-ActMfs-val
INs-ActMfs-lbl
clk
A
ct
vR
ul
es
 G
en
-e
n
en
ActvRules-Gen
RulesInf-en-Reset
Rules-Inf-validout
clk
Reset
en
R
ul
es
In
f-e
n
R
ul
es
In
f-R
es
et
A
ct
vR
ul
es
 
G
en
-
v
a
lid
o
u
t
RulesInferenceActvRules
CLK
Reset
en
Aggregation
clk
Reset
en
A
gg
r-
en
A
gg
r-
R
es
et
AggConseq-val
AggConseq-LbL
Out-Mfs-Param
clk
en-Reset
validout
A
gg
r-
va
lid
ou
t
A
gg
r-
en
-R
es
et
Reset
en
de
ffu
zz
-e
n
de
fu
zz
-
R
es
et
deffuzzification
en-Reset
validout
de
fu
zz
-v
a
lid
ou
t
de
fu
zz
-
en
-
R
es
et
Reset
en
D
iv
-e
n
D
iv
-R
es
et
Denominator
Numenator
clk
Division
validout
ON-validout
Crisp-out
en-Reset
Crisp-out
valid - out
ActvRules -val
Actvconseq -LbL
Control signal process
Control signal process
SPI - MOSI
SPI - SCK
DAC - CS
DAC - Clr
AMP - CS
AD - Conv
SPI – MIS0
Dac - A
Dac - B
Dac - C
Dac - D
SPI - MOS1
SPI - SCK
DAC - CS
DAC - Clr
SPI – SS - B
AMP - CS
AMP - SHDN
AD - Conv
SF - CE
FPGA – Init -B
1
1
1
1
SPI – MIS0
ch - CS
CLK
RoT- A
CLK
RoT- B
speed
CLK
speed
Reference Ref
crispInp
Reset
en
enable
CLK
en - Reset
validout
crisp - out
Error - process
Con – Sign – Process
EncoderCount.proc.
Kit - input
S3E -Analog IO Kit - out
FLC - Components
(a)
(b)
Figure 10 Internal architecture of the FPGA-based speed control for DC motor (a) Internal FLC-components architecture and (b)
internal component architecture.
Embedded system based on a real time fuzzy motor speed controller 403
0 5 7 10 14 15 20 25
0
50
100
150
170
200
Speed control under PI-Controller
time (sec)
Sp
ee
d 
(rp
m
)
0 5 7 10 14 15 20 25
0
1
2
3
3.5
Control Signal
time (sec)
Vo
lt
Figure 12 System response of PI controller for changes in the operating point.
DC motor system
- H- Bridge
- PWM driver
- optical encoder
- Mechanical Coupling
FPGA Spartan-3E Kit
Speed response under FLC
Figure 11 Real system of the DC motor speed control using FPGA.
404 Ebrahim Abd El-Hamid Mohamed Ramadan et al.4. Fuzzy logic controller structure
A fuzzy controller structure for control consists respectively of
fuzziﬁcation, rule data base, rules inference and defuzziﬁcation
[21], as shown in Fig. 3, which has the characteristic parame-
ters as shown in Table 1.
 Fuzziﬁcation stage: The crisp input of Error (e) and Change
of Error (De) are deﬁned by:eðkTÞ ¼ xref  x‘ ð10Þ
DeðkTÞ ¼ eðkTÞ  eðkT TÞ ð11Þ
where xref is the reference and x‘ is the system output. The
fuzziﬁcation process changes input signal value (e, De) from
the ﬁelds of real numbers to the value of membership function
l(x) of the fuzzy sets. In the proposed fuzzy system, the fuzz-iﬁcation process is performed by reading out from the system’s
memory the values of membership function of activated sets
and also codes of these sets [22].
Symmetric triangular MFs are used; each membership
function can be completely described by only two points (a,
b) and two slope values [23]. The entire membership function
can be divided into three portions: 0, 1 and 2, as shown in
Fig. 4. It shows how triangular input membership functions
are formed in the fuzziﬁcation stage.
The degree of membershipðlÞ ¼
ð1Þ Portion0; l ¼ 0;
ð2Þ Portion1; l ¼ ðInput value aÞ  slope1
ð3Þ Portion2; l ¼ 1 ðInput value bÞ  slope2
8><
>:
The two input variables are coded as 8-bit hexadecimal value
(00 – FF); each input of crisp input is entered at the same time
for the membership function to calculate the l value. As an
example, let us use the input value of 150 to calculate the
Optical 
encoderChannel A
Channel B
Index
FPGA 
Spartan 3E
Kit J1-
A
cc
es
so
ry
 
H
ea
de
r
 
D
A
C 
H
ea
de
r 
(J5
)
+24V
Mechanical
coupling10k
M
10k
+5V
+
-
470220k
33k1uF
Triangle generator
Control Signal
+Vcc
1k
Same signal
PWM signal
0 5 7 10 14 15 20 25
0
50
100
150
200
Speed control under FLC
time (sec)
Sp
ee
d 
(rp
m
)
0 5 7 10 14 15 20 25
0
1
2
3
Control Signal
time (sec)
Vo
lt
Figure 13 System response of PI-FLC for changes in the operating point.
Table 4 Comparison between two responses.
PI controller PI-FLC
Rise time (s) 0.8050 0.7368
Settling time (s) 6.5390 6.886
Over shoot (rpm) 3.6364 1.75
Peak time (s) 4.2800 1.08
RMSE without load 15.3512 11.5399
RMSE with load
Under 10% load 14.6333 14.3861
Under 20% load 16.8462 15.6657
Under 25% load 20.5089 16.7217
Embedded system based on a real time fuzzy motor speed controller 405degree of membership function. Using an 8-bit computerized
resolution, l= 1 equals to $FF or 255 in decimal (the ‘‘$’’ sign
indicates the hexadecimal number representation). The values
of (a) and (b) are $46 and $7F; respectively, and the two slopes
can be calculated as follows:
Slope ð1Þ ¼ 1=ð127 70Þ ¼ FF=39 ¼ 255=57 ¼ 4 ¼ 04: And
Slope ð2Þ ¼ 1=ð191 127Þ ¼ FF=40 ¼ 255=64 ¼ 3 ¼ 03:
Since the input value of 150 ($96) is greater than (b) and lies in
portion 2, therefore:
l ¼ FF0 ðInput value bÞ  slopeð2Þ
¼ FF ð96 7FÞ  03 ¼ BA:
 Active rules generator: each input variable generates the
address of memory, which indicates the appropriate discrete
sample of the point of the rule activation stored in the mem-
ory. Therefore, the output of the fuzziﬁcation stage consists
of a couple of 3-bit codes (Active MF Labels). Rule evaluation and inference stages: the input variables (e,
De) are processed by an inference engine that executes a
set of control rules contained in rule bases. The control
rules are formulated using the knowledge of the DC motor
behavior [24]. Each rule is expressed in the form:IF e is Ai and De is Bi THEN Uf is Ci ð12Þ
where i= 1, 2, 3, m. There are seven fuzzy sets for each lin-
guist value {Ai, Bi, Ci} and 49 fuzzy control rules (rule bases)
are designed for the two inputs and one output fuzzy system.
Different inference algorithms can be used to produce the fuz-
zy set values for the output fuzzy variable Uf. In this paper, the
max–min inference algorithm is used, in which the membership
degree is equal to the maximum of the product of (e, De) mem-
bership degree [3].
 The truth values Wi of the premises are calculated by:Wi ¼ minblAiðeÞ; lBiðDeÞc ð13Þ
 The membership function lc(u) of the inferred consequence
is given by:lcðuÞ ¼ max½minðW1; lc1Þ; minðW2; lc2Þ ð14Þ
In the proposed fuzzy system, once the degree of member-
ship of the two inputs is tested, the Active MF Labels are
used to generate the addresses which needed to select just
the fuzzy active rules. The conclusion codes are stored at
precisely determined address, which values correspond to
the premises of activated rules. During the reading of indi-
cated codes of rule conclusion, the fuzzy AND is computed
applying the (MIN) operator to the two 8-bit membership
values [25], which relies on the choice of the smallest value
0 5 10 15 20 25
0
20
40
60
80
100
120
140
Speed Control under PI-controller with Disturbance
Time (sec)
Sp
ee
d 
(r
pm
)
Reference
10% Load
20% Load
25% load
0 5 10 15 20 25
0
0.5
1
1.5
2
2.5
3
3.5
control signal of PI-controller with Disturbance
Time (sec)
C
on
tr
ol
 s
ig
na
l (
Vo
lt)
10% Load
20% Load
25% Load
(a)
(b)
Figure 14 Regulatory responses of PI controller under 10%,
20% and 25% load changes speed control under PI controller
with difference loads 10%, 20% and 25%. (b) Control signal
of the PI controller.
0 5 10 15 20 250
20
40
60
80
100
120
140
Speed Control under FLC with Disturbance
Time (sec)
Sp
ee
d 
(r
pm
)
Reference
10% Load
20% Load
25% Load
0 5 10 15 20 250
0.5
1
1.5
2
2.5
3
3.5
control signal of FLController with Disturbance
Time (sec)
C
on
tr
ol
 S
ig
na
l (
Vo
lt)
10% Load
20% Load
25% Load
(a)
(b)
Figure 15 Regulatory responses of PI – FLC under 10%,
20% and 25% load changes (a) speed control under PI-FLC
with difference loads 10%, 20% and 25% and (b) control
signal of the PI-FLC.
406 Ebrahim Abd El-Hamid Mohamed Ramadan et al.of the membership values. After this, the operation of aggre-
gation (MAX) begins [16]. Finally, the inference stage deci-
des what the fuzzy control output by using fuzzy reasoning
is performed by inference engine strategy. Since rule outputs
are expressed by fuzzy numerical values, the numerical re-
sults from this calculation are called fuzzy outputs.
 Defuzziﬁcation stage: Interface converts the fuzzy control
action into the inputs to the plant (crisp output). The crisp
output (8-bit) is computed using the Center Of Gravity
(COG) [26].crisp output ¼
Pn
i¼1lðuiÞ  uiPn
i¼1lðuiÞ
ð15Þ
where l(ui) is the values of membership function for output
and ui is the values of locations of output MFs. Next, this re-
sult is transferred to DC motors.5. Modeling of fuzzy logic controller using VHDL
There are a number of reasons for using fuzzy logic in the
speed control of DC motor. The main advantage is the ﬂexibil-
ity offered by fuzzy logic [11,27]. Fig. 5 shows a block diagram
demonstrating the implementation of the FLC in a speed con-
trol of DC motor. In this application, the input interface
converts the output of the speed encoder into error and change
of error which are used as the two inputs to the FLC.
The fuzzy PI controller was implemented according to
Fig. 3. There are seven triangle memberships representing the
Error (e) and Change of Error (De) inputs. The normalizing
Embedded system based on a real time fuzzy motor speed controller 407of these membership functions is shown in Fig. 6, where, real
range of Error (e) and Change of Error (De) are converted to
8-bits digital scale vectors escale and Descale from 0 to 255 which
represent the inputs of FLC. The mathematical equations for
this process are as follows:
escale ¼ 1:25 e 127:5 ð16Þ
Descale ¼ 25:5 De 127:5 ð17Þ
The two scale inputs of Error (e) and Change of Error (De) can
have negative physical values. Since the universe of discourse
can handle 8-bit vector, the digital representations of (escale)
and (Descale) are biased by 128 bits as shown:
ðescale or DescaleÞ ¼
> 0 Then 128 < value 6 255;
¼ 0 Then value ¼ 128;
< 0 Then 0 6 value < 128;
8><
>:
The basis of choice for the universe of discourse range (0–255)
is to reduce the computational complexity of the different sets
of FLC. Since the memory space in FPGA Spartan-3E starter
kit is limited, and the smallest number of bits can be used for
representing the real error and change of error is 8-bit. Hence,
when the universe of discourse is increased above 8-bit, the
computation size will be increased. The FLC works in a way
that relates the controlled system output to the reference input
by a set of fuzzy rules. These rules are the most important part
of the FLC and they must be obtained correctly so that the
relation between input and output of the system is represented
properly [28]. Fuzzy rule’s operation is based on the control
expression of Table 2.
The inputs and outputs, with the gate level details of the
subsystem and the synthesis report that is created from ISE
WebPack program, are shown in Table 3.
6. Controller design for FPGA implementation
The Spartan-3E FPGA is embedded with the 90 nm technol-
ogy at the heart of its architecture. This reduces the die size
and cost, increases manufacturing efﬁciency, and addresses a
wider range of applications. The Spartan-3E diagram, shown
in Fig. 7, allows users to easily migrate to different densities
across multiple packages and supports 18 different single-
ended and differential I/O standards [29].
The speed of the motor is measured by means of optical en-
coder and is given as an input to the expansion connectors on
board (J1 6-pin Accessory Header) [30]. As shown in Fig. 8.
The reference speed is assigned to motor internal conﬁgura-
tion memory of the FPGA. To verify the performance of the
controller design on the hardware, the VHDL code (Bit ﬁle)
is downloaded into the target FPGA device (Spartan-3E fam-
ily XC3S500) using Xilinx ISE pack 11.1i. The complete exper-
imental system consists of a DC motor, FPGA kit, and the
circuits of (PWM driver and H-bridge). The overall block dia-
gram of DC motor speed control is shown in Fig. 9, and the
internal architecture of the proposed FPGA-based speed con-
trol is shown in Fig. 10. Fig. 11 shows the real system.
Results of measurements conﬁrmed again correct operation
of the system. The time of system processing was sample
time = 0.05 s based on clock frequency 50 MHz.7. Results and discussion
The proposed controllers are implemented in FPGA for real
time control of speed in the DC motor. The servo responses
of the PI controller and PI-FLC are shown in Figs. 12 and
13; respectively. The reference speed is varied from 100 rpm
to 170 rpm. For the PI controller (shown in Fig. 12), reference
speed tracking performance is characterized by lack of smooth
transition between desired speed, as well as the presence of
overshoot and higher rise time. From Fig. 13, it can be ob-
served that the PI-FLC has less oscillation, zero overshoot
and less rise time. From Figs. 12 and 13 and Table 4, it is clear
that PI-FLC performs signiﬁcantly better than PI controller.
The PI-FLC is used to control the speed of the motor while
applying a different loads changing as 10%, 20% and
25% [11]. The motor is also run with a PI controller while
applying the same load changes. The variations in speed with
time for these load changes for PI controller and PI-FLC are
shown in Figs. 14 and 15 respectively. An abrupt change can
be seen in the results with the 25% load as it observes in
Fig. 14. The control signal gets out to the motor during the
Digital-to-Analog Converter (DAC) output channel of FPGA
device. It is represented in VHDL code by 12-bit vector. Once
it is fully ones and the analog signal reaches the maximum va-
lue (3.3v), the next step it will start from initial zeros. The PI-
FLC is able to compensate the load changes considerably bet-
ter than the PI controller as shown in Figs. 14 and 15 and
Table 4.
8. Conclusions
The main contribution of this work is to present an approach
of real time fuzzy logic controller for DC motor using VHDL
description and FPGA technology. FLC based on FPGA has
some advantages such as ﬂexible design (the membership func-
tions and rule base can be easily changed), feature accuracy,
high reliability, cost improvement, and high speed. The perfor-
mance of the FLC is compared with the PI controller for ref-
erence speed and load changes. The satisﬁed ability of the
system control with FLC is better than PI controller. In a fu-
ture work it is planned to investigate implementation of adap-
tive fuzzy controllers on FPGA.
References
[1] Hamed B, Al-Mobaied M. Fuzzy PID controllers using FPGA
technique for real time DC motor speed control. Intell Control
Autom 2011;2(August):233–40.
[2] Millan I, Montiel O, Sepulveda R, Castillo O. Design and
implementation of a hybrid fuzzy controller using VHDL. Soft
computing for hybrid Intel. systems. Berlin, Heidelberg: Springer-
Verlag; 2008, SCI 154.
[3] Nagib G, Gharieb W, Binder Z. Application of fuzzy control to a
non-linear thermal process. In: The 31st conference of the IEEE on
decision and control, Tucson, Arizona, December 1992.
[4] Kumar V, Rana KPS, Kumar V. Real time comparative study of
the performance of FPGA based PID and fuzzy controllers for a
rectilinear plant. In: IEEE conference publications, power
electronics (IICPE), 2010 India international conference, 28–30,
January 2011.
408 Ebrahim Abd El-Hamid Mohamed Ramadan et al.[5] Kaur A, Kaur A. Development of neuro fuzzy controller
algorithm for air conditioning system. (IJEST) Int J Eng Sci
Technol 2012;4(04):1667–71, ISSN: 0975-5462.
[6] Sakthivel G, Anandhi TS, Natarajan SP. Design of optimized
fuzzy logic controller for area minimisation and its FPGA
implementation. (IJCSNS) Int J Comput Sci Network Secur
2010;10(8):187–92.
[7] Precup RE, Hellendoorn H. A survey on industrial applications of
fuzzy control’’, computers in industry, vol. 62. Elsevier; 2011, p.
213–226.
[8] Kung YSh, Fung RF, Tai TY. Realization of a motion control IC
for XY table based on novel FPGA technology. IEEE Trans
Industr Electron 2009;56(1):43–53.
[9] Hamed BM, El-Moghany MS. Fuzzy controller design using
FPGA for sun tracking in solar array system. I.J. Intell Syst Appl
2012;1(February):46–52.
[10] Monmasson Eric, Cirstea Marcian N. FPGA design methodology
for industrial control systems – a review. IEEE Trans Industr
Electron 2007;54(4).
[11] Sakthivel G, Anandhi TS, Natarajan SP. Real time implementa-
tion of a fuzzy logic controller on FPGA using VHDL for DC
motor speed control, G. Sakthivel et al.. Int J Eng Sci Technol
2010;2(9):4511–9.
[12] Monmasson E, Cirstea MN. FPGA design methodology for
industrial control systems–a review. IEEE Trans Industr Electron
2007;54(4).
[13] Karasakal O, Yesil E, Guzelkaya M, Eksin I. Implementation of a
new self-tuning fuzzy PID controller on PLC. Turk J Electr Eng
2005;13(2):277–86.
[14] Tipsuwanpornm V, Runglimmawan T, Intajag S, Krongratana V.
Fuzzy logic PID controller based on FPGA for process control.
In: IEEE international symposium on industrial, electronics, vol.
2, 4–7 May, 2004. P. 1495–1500.
[15] Sulaiman N, Obaid ZA, Marhaban MH, Hamidon MN. FPGA-
based fuzzy logic: design and applications – a review. (IACSIT)
Int J Eng Technol 2009;1(5):491–503, ISSN: 1793-8236.
[16] Hassan MY, Sharif WF. Design of FPGA based PID-like fuzzy
controller for industrial applications. IAENG Int J Comput Sci
2007;34(2), 17 November, IJCS-34-2-05.
[17] Kuo B. Automatic control systems. Englewood Cliffs, NJ:
Prentice-Hall; 1995.
[18] Ogata K. Modern control engineering. 3rd ed. Upper Saddle
River, NJ: Prentice-Hall; 1997.
[19] Qu L, Huang Y, Ling L. Design of intelligent PID controller
based on adaptive genetic algorithm and implementation of
FPGA. Berlin, Heidelberg: Springer-Verlag; 2008, Part II, LNCS
5264.
[20] Tipsuwan Y, Chow MY. Fuzzy PID controllers using 8-Bit
microcontroller for U-board speed control. In: IECON ‘99’, the
25th annual conference of the IEEE, vol. 3; 1999.
[21] Passino KM, Yurkovich S. Fuzzy control. Addison Wesley
Longman, Inc.; 1998, ISBN 0-201-18074-X.
[22] Poplawski M, Bialko M. Implementation of parallel fuzzy logic
controller in FPGA circuit for guiding electric wheelchair.
Krakow, Poland: IEEE – HIS; 2008. p. 25–7, May.
[23] Vuong PT, Madni AM, Vuong JB. VHDL implementation for a
fuzzy logic controller. In: IEEE conference publications, world
automation congress, Budapest, Hungary, July 24–26, 2006.
[24] Sousa GCD, Bose BK. A fuzzy set theory based control of a
phase- controlled converter Dc machine drive. IEEE Trans Ind
Appl 1994;30(1).[25] Di Stefano A, Giaconia C. An FPGA-based adaptive fuzzy
coprocessor. Berlin, Heidelberg: Springer-Verlag; 2005, IWANN
2005, LNCS 3512.
[26] Liza´rraga G, Sepu´lveda R, Montiel O, Castillo O. Modeling and
simulation of the defuzziﬁcation stage using xilinx system gener-
ator and simulink. Soft computing for hybrid intelligent systems.
Berlin, Heidelberg: Springer Verlag; 2008.
[27] Wang HP. Design of fast fuzzy controller and its application on
position control of DC motor. IEEE conference publications,
(CECNet) consumer electronics communications and network. In:
2011 International conference; 2011. P. 4902–5.
[28] Eminoglu I, Altas IH. A method to form fuzzy logic control rules
for a PMDC motor drive system. Electric power systems research,
vol. 39. Elsevier; 1996, p. 81–87.
[29] Shrikanth G, Subramanian K. Implementation of FPGA based
object tracking algorithm, Postgraduate Thesis, (SVCE, India);
2008.
[30] Spartan-3E FPGA Starter Kit Board User Guide, UG230, vol. 1,
No. 1, 20 June, 2008. <http://www.xilinx.com/support/documen-
tation/boards_and_kits/ug230.pdf> [Last modiﬁed in January
2013].
Ebrahim Abd El-Hamid Mohamed Ramadan
received the B.Sc. and M.Sc. degrees in auto-
matic control engineering from Faculty of
Electronic Engineering, Menoﬁa University,
Menof, Egypt. He is currently working
toward the Ph.D. degree in automatic control
engineering. He is currently Assistant Lecture
with the department of Industrial Electronics
and Control Engineering, Faculty of Elec-
tronic Engineering, Menoﬁa University,
Menof Egypt. His current research Embedded
Intelligent Control System Based on FPGA.Mohammad El-Bardini is currently an Asso-
ciate Professor with the Department of
Industrial Electronic and Control Engineer-
ing, Faculty of Electronic Engineering;
Menouﬁa University. His research interests
include Robotics, Computer Controlled Sys-
tems and the Embedded System design for
Control Systems. He has coauthored many
journal and conference papers and has
supervised many Ph.D. andM.Sc. for students
working in the ﬁeld of Intelligent Control
Systems, Embedded Control Systems, Advanced Techniques for Sys-tems Modeling, and Vision based Control of Robotic Systems. He is
the recipient of the best students project Award in Egyptian Engi-
neering Day.
Nabila M. El-Rabaie is currently a Professor with the Department of
Industrial Electronic and Control Engineering, Faculty of Electronic
Engineering; Menoﬁa University. Her research interests include mod-
elling, adaptive control and neural control. She has co-authored many
journal and conference papers and has supervised many Ph.D. and
M.Sc. for students working in the ﬁeld of Adaptive Control Systems,
Intelligent Control Systems, and Advanced Techniques for Systems
Modelling.
Embedded system based on a real time fuzzy motor speed controller 409Mohamed A. Fkirin is currently a Professor
with the Department of Industrial Electronic
and Control Engineering, Faculty of Elec-
tronic Engineering; Menouﬁa University. He
got B.Sc. (1971-1976) and M.Sc. (1977-1980)
in automatic control systems identiﬁcation, in
Egypt. After then he went to England and
achieved the PhD degree (1982-1986), from
Birmingham University. He has authored 55
publications (53 papers and 2 books). He has
published 30 publications as single author. He
has signiﬁcant contributions in evolving appropriate strategies ofoptimal exploitation for online identifying and predicting of dynamic
systems. In particular for his pioneering studies on the smoothingforms to identify the SISO and MIMO systems, and for his key role in
developing new effective prediction algorithms based on Kalman and
lattice ﬁlters. These strategies are used for solving prediction problems
in developing countries (Egypt and Saudi Arabia), such as econo-
metric, hydrological, industrial and medical applications. Also, his
research interests include the development of advanced models of
educational and computer-control systems. He was awarded the prize
of Young Arab scientists, in 1991. He was selected to be formal referee
in Jordanian board for choosing the new winners for the Young Arab
scientists prize. He was awarded the First Prize of the Third Interna-
tional Symposium of Date Palm, Saudi Arabia, 1993.
