FPGA-Realization of a Motion Control IC for X-Y Table by Kung, Ying-Shieh & Tai, Ting-Yu
Selection of our books indexed in the Book Citation Index 
in Web of Science™ Core Collection (BKCI)
Interested in publishing with us? 
Contact book.department@intechopen.com
Numbers displayed above are based on latest data collected. 
For more information visit www.intechopen.com
Open access books available
Countries delivered to Contributors from top 500 universities
International  authors and editors
Our authors are among the
most cited scientists
Downloads
We are IntechOpen,
the world’s leading publisher of
Open Access books
Built by scientists, for scientists
12.2%
122,000 135M
TOP 1%154
4,800
21 
FPGA-Realization of a Motion Control IC  
for X-Y Table 
Ying-Shieh Kung and Ting-Yu Tai 
Southern Taiwan University 
Taiwan  
1. Introduction      
The development of a compact and high performance motion controller for precision X-Y 
table, CNC machine etc. has been a popular field in literature (Goto et al., 1996; Wang & Lee, 
1999; Hanafi et al., 2003). In position control of X-Y table, there are two approaches to be 
considered. One is semi closed-loop control and the other is full closed-loop control. The full 
closed-loop control with feed-backed by a linear encoder as the table position signal has a 
better positioning performance than the semi closed-loop control that a rotary encoder 
attached to PMSM is feed-backed as the position signal. However, to develop a motion 
control IC for X-Y table, the fixed-point digital signal processor (DSP) and FPGA provide 
two possible solutions in this issue. Compared with FPGA, DSP suffers from a long period 
of development and exhausts many resources of the CPU (Zhou et al., 2004).  
For the progress of VLSI technology, the FPGA has been widely investigated due to its 
programmable hard-wired feature, fast time-to-market, shorter design cycle, embedding 
processor, low power consumption and higher density for implementing digital control 
system (Monmasson & Cirstea, 2007; Naouar et al., 2007; Jung & Kim, 2007). FPGA provides 
a compromise between the special-purpose ASIC (application specified integrated circuit) 
hardware and general-purpose processors (Wei et al., 2005). Therefore, using an FPGA to 
form a compact, low-cast and high performance servo system for precision machine has 
become an important issue. However, in many researches, the FPGA is merely used to 
realize the hardware part of the overall control system. Recently, fuzzy control has been 
successfully demonstrated in industrial control field (Sanchez-Solano et al., 2007; Kung & 
Tsai, 2007).Compared with other nonlinear approaches, FC has two main advantages, as 
follows: (1) FC has a special non-linear structure that is universal for various or uncertainty 
plants. (2) the formulation of fuzzy control rule can be easily achieved by control 
engineering knowledge, such as dynamic response characteristics, and it doesn’t require a 
mathematical model of controlled plant. In literature, Li et al. (2003) utilized an FPGA to 
implement autonomous fuzzy behavior control on mobile robot. Lin et al. (2005) presented a 
fuzzy sliding-mode control for a linear induction motor drive based on FPGA. But, due to 
the fuzzy inference mechanism module adopts parallel processing circuits, it consumes 
much more FPGA resources; therefore limited fuzzy rules are used in their proposed 
method. To solve this problem, a FSM joined by a multiplier, an adder, a LUT (Look-up 
table), some comparators and registers are proposed to model the FC algorithm of the 
 Motion Control 
 
396 
PMSM drive system. Then a VHDL is adopted to describe the circuit of the FSM (Hsu et al., 
1996). Due to the FSM belongs to the sequential processing method; the FPGA resources 
usage can be greatly reduced. Further, in recent years, an embedded processor IP and an 
application IP can now be developed and downloaded into FPGA to construct a SoPC 
environment (Altera, 2004), allowing the users to design a SoPC module by mixing 
hardware and software in one FPGA chip (Hall & Hamblen, 2004). The circuits required fast 
processing but fixed computation are suitable to be implemented by hardware in FPGA, and 
the heavy computation or complicated processing can be realized by software in FPGA 
(Kung et al., 2004; Kung & Shu, 2005). The results of the software/hardware co-design 
increase the programmability, flexibility of the designed digital system, enhance the system 
performance by parallel processing and reduce the development time.  
To exploit the advantages, a motion control IC for X-Y table based on the new-generation 
FPGA technology is developed in this study and shown in Fig.1 (Kung et al., 2006), which 
the scheme of position/speed/current vector control of two PMSMs can be realized by 
hardware in FPGA, and the motion trajectory for X-Y table can be realized by software using 
Nios II embedded processor. Hence, all functionalities, which are based on 
software/hardware co-design, required to construct a full closed-loop control for X-Y table 
can be integrated and implemented in one FPGA chip. In addition, the FPGA resources 
usage can be greatly reduced by using the FSM in the control algorithm design. Herein, the 
Altera Stratix II EP2S60F672C5ES (Altera, 2008), which has 48,352 ALUTs (Adaptive Look-
UP Tables), maximum 718 user I/O pins, total 2,544,192 RAM bits, and a Nios II embedded 
processor which has a 32-bit configurable CPU core, 16 M byte Flash memory, 1 M byte 
SRAM and 16 M byte SDRAM, are used. Finally, an experimental system included by an 
FPGA experimental board, two inverters, two sets of  A/D converter and an X-Y table, is set 
up to verify the correctness and effectiveness of the proposed FPGA-based motion control 
IC.   
 
FPGA-based Motion Control IC
SVPWM
PI
PI
rxv
ryv
rzv
ai
ci
*
qi
*
di
+
−
−
dv
qv
ADC
read in
qi
di
+
QEP Circuit
bi
Sin&Cos
= 0
px
eθ
py
QEP Circuit
SVPWM
PI
PI
rxv
ryv
rzv
ai
ci
*
qi
*
di
+
−
−
dv
qv
ADC
read in
qi
di
+
QEP Circuit
bi
Sin&Cos
= 0
QEP Circuit
e
+ _
11 −−Z
Fuzzy 
controller
P
−+Position 
controller
Speed 
controller
Two-axis motion controllers 
implemented by software using
Nios II embedded processor
*
px
fu
py
e
+ _
11 −−Z
Fuzzy 
controller
P
−+Position 
controller
Speed 
controller
*
py
fu
Motion 
Trajectory
Motion
Command
px
Y-axis position/speed/current vector controller  
implemented by hardware in FPGA
X-axis position/speed/current vector controller  
implemented by hardware in FPGA
eθ
Coordinate 
transformation
Coordinate 
transformation
A, B
U,V,W
z
A, B
z
PWM1
PWM6
U,V,W
X-Y Table
X-axis 
PMSM
Y-axis 
PMSM
B,B
A,A zz,
B,B
A,Azz,
To Y-axis PMSM
From Y-axis rotary encoder
From Y-axis 
linear encoder
From X-axis linear encoder
From X-axis rotary encoder
To X-axis PMSM
Y-axis 
Inverter
/
AD 
Converter
/
Comparator
A, B
z
A, B
z
PWM1
PWM6
X-axis 
Inverter
/
AD 
Converter
/
Comparator
B,B
A,Azz,
B,B
A,A zz,
 
Fig. 1. The architecture of the FPGA-based motion control system for X-Y table 
FPGA-Realization of a Motion Control IC for X-Y Table  
 
397 
2. System description and controller design of X-Y table  
The X-Y table is driven by two PMSMs which the current, speed and position loop in each 
PMSM drive adopts vector control, P control and fuzzy control, respectively The 
architecture of the proposed FPGA-based motion control IC for X-Y table is shown in Fig. 1. 
The modeling of PMSM, the fuzzy control algorithm and the motion trajectory planning are 
introduced as follows: 
2.1 Mathematical model of PMSM and current vector controller 
The typical mathematical model of a PMSM is described, in two-axis d-q synchronous 
rotating reference frame, as follows 
 
d
d
q
d
q
ed
d
sd v
L
i
L
L
i
L
R
dt
di 1++−= ω   (1) 
 
q
qq
f
eq
q
s
d
q
d
e
q
v
L
1
L 
 
i
L
R
i
L
L
dt
di +−−−= λωω   (2) 
where vd, vq are the d and q axis voltages; id, iq, are the d and q axis currents, Rs is the phase 
winding resistance; Ld, Lq are the d and q axis inductance; eω  is the rotating speed of 
magnet flux; 
fλ is the permanent magnet flux linkage. 
The current loop control of PMSM drive in Fig.1 is based on a vector control approach. That 
is, if the id is controlled to 0 in Fig.1, the PMSM will be decoupled and controlling a PMSM 
like to control a DC motor. Therefore, after decoupling, the torque of PMSM can be written 
as the following equation, 
 
qtqfe iK i
P
T Δ= λ
4
3
  (3) 
with  
 
ft
P
K λ
4
3=   (4) 
Finally, considering the mechanical load with linear table, the overall dynamic equation of 
linear table system is obtained by 
 
dt
ds
r
B
dt
sd
r
JTT
p
m
p
mLe
ππ 22
2
2
+=−   (5) 
where Te is the motor torque, Kt  is force constant, Jm is the inertial value, Bm is damping ratio, 
TL is the external torque, sp represents the displacement of X-axis or Y-axis table and  r is the 
lead of the ball screw.  
The current loop of the PMSM drive for X- or Y-table in Fig.1 includes two PI controllers, 
coordinate transformations of Clark, Modified inverse Clark, Park, inverse Park, SVPWM 
(Space Vector Pulse Width Muldulation), pulse signal detection of the encoder etc. The 
coordination transformation of the PMSM in Fig. 1 can be described in synchronous rotating 
reference frame. Figure 2 is the coordination system in rotating motor which includes 
 Motion Control 
 
398 
stationary a-b-c frame, stationary α-β frame and synchronously rotating d-q frame. Further, 
the formulations among three coordination systems are presented as follows.  
1. Clarke: stationary a-b-c frame to stationary α-β frame. 
 
⎥⎥
⎥
⎦
⎤
⎢⎢
⎢
⎣
⎡
⎥⎥
⎥⎥
⎦
⎤
⎢⎢
⎢⎢
⎣
⎡
−
−−
=⎥⎦
⎤⎢⎣
⎡
c
b
a
i
i
i
i
i
3
1
3
1
0
3
1
3
1
3
2
β
α   (6) 
2. Modified 1−Clarke : stationary α-β frame to stationary a-b-c frame. 
 ⎥⎦
⎤⎢⎣
⎡
⎥⎥
⎥
⎦
⎤
⎢⎢
⎢
⎣
⎡
=
⎥⎥
⎥
⎦
⎤
⎢⎢
⎢
⎣
⎡
−−
−
α
β
v
v
v
v
v
c
b
a
2
3
2
1
2
3
2
1
01
  (7) 
3. Park : stationary α-β frame to rotating d-q frame. 
 cos sin
sin cos
d e e
q e e
i i
i i
α
β
θ θ
θ θ
⎡ ⎤ ⎡ ⎤⎡ ⎤=⎢ ⎥ ⎢ ⎥⎢ ⎥−⎣ ⎦ ⎣ ⎦⎣ ⎦
  (8) 
4. 1−Park : rotating d-q frame to stationary α-β frame. 
 cos sin
sin cos
de e
qe e
vv
vv
α
β
θ θ
θ θ
− ⎡ ⎤⎡ ⎤ ⎡ ⎤= ⎢ ⎥⎢ ⎥ ⎢ ⎥⎣ ⎦⎣ ⎦ ⎣ ⎦
  (9) 
where 
eθ  is the electrical angle.  
In Fig. 1, two digital PI controllers are presented in the current loop of PMSM. For the 
example in d frame, the formulation is shown as follows. 
 )()()( * kikike ddd −=   (10) 
 )()(  __ kekkv ddpdp =   (11) 
 )1()1()(  ___ −+−= kekkvkv ddididi   (12) 
 )()()( __ kvkvkv didpd +=   (13) 
the 
de  is the error between current command and measured current. The dpk _ , dik _  are P 
controller gain and I controller gain, respectively. The )(_ kv dp , )(_ kv di , )(kvd  are the output 
of P controller only, I controller only and the PI controller, respectively. Similarity, the 
formulation of PI controller in q frame is the same. 
2.2 Fuzzy controller (FC) for position control loop 
The position controllers in X-axis and Y-axis table of Fig. 1 adopt fuzzy controller, which 
includes fuzzification, fuzzy rules, inference mechanism and defuzzification. Herein, an FC 
design method for X-axis and Y-axis table is presented. At first, position error and its error 
change, e , de  are defined by 
FPGA-Realization of a Motion Control IC for X-Y Table  
 
399 
:  3- axi s stationary frame
:  2- axi s stationary frame
:  2- axi s rotating frameqd −
βα −
cba −−
a
c
αf
βf
qf
rotor
stator
Sf
e
ω
eθ α
d
q β
b
df
 
Fig. 2. Transformation between stationary axes and rotating axes 
 )k(s)k(s)k(e p
*
p −=   (14) 
 )1()()( −−= kekekde   (15) 
The Ker and Kder are the gains of the input variables e  and de , respectively, as well as uf is 
the output variables of the FC. The design procedure of the FC is as follows:   
a. Take the E and dE as the input linguist variables, which are defined by {A0, A1, A2, A3, 
A4, A5, A6} and {B0, B1, B2, B3, B4, B5, B6}, respectively. Each linguist value of E and dE are 
based on the symmetrical triangular membership function which is shown in Fig.3. The 
symmetrical triangular membership function are determined uniquely by three real 
numbers
321 ξξξ ≤≤ , if one fixes 0ff 31 == )()( ξξ  and 1f 2 =)(ξ . With respect to the 
universe of discourse of [-6.6], the numbers for these linguistic values are selected as 
follows: 
A0=B0 : {-6,-6,-4},  A1=B1 : {-6,-4,-2}, A2=B2 : {-4,-2,0}, A3=B3: {-2,0,2}, 
 A4=B4 : {0,2,4}, A5=B5 : {2,4,6}, A6=B6: {4,6,6}  (16) 
b. Compute the membership degree of e and de. Figure 3 shows that the only two 
linguistic values are excited (resulting in a non-zero membership) in any input value, 
and the membership degree 
)(eAi
μ  can be derived, in which the error e is located 
between ei and ei+1, two linguist values of Ai and Ai+1 are excited, and the membership 
degree is obtained by 
     
2
ee
e 1iAi
−= +)(μ   and   )()( e1e i1i AA μμ −=+   (17) 
where )(* 1i26e 1i ++−+ Δ . Similar results can be obtained in computing the 
membership degree
)(deB j
μ .  
 Motion Control 
 
400 
 
c00
dE
1
A0 A1 A2 A3 A4 A5 A6
0 6-6
e
e
E
d
e
d
e
μ(e)
μ(d
e
)
1
μA3(e)
μA4(e)=1- μA3(e)
μ B
1
(d
e)
μ B
2
(d
e)
=
1
-
μ B
1
(d
e
)
Rule 1: e is A3 and de is B1 then uf is c13
Rule 2: e is A3 and de is B2 then uf is c23
Rule 3: e is A4 and de is B1 then uf is c14
Rule 4: e is A4 and de is B2 then uf is c24
Defuzzification
4224411432233113
42413231
4224411432233113
f
dcdcdcdc     
dddd
dcdcdcdc
u
****
****
+++=
+++
+++=
where
0
6
-6
Fuzzy Rule Table
Input of e  (for i=3)
In
p
u
t 
o
f 
d
e
  
(f
o
r 
j=
1
)
Fuzzy Inference and Output
A0 A1 A2 A3 A4 A5 A6
c01 c02 c03 c04 c05 c06
c10 c11 c12 c13 c14 c15 c16
c20 c21 c22 c23 c24 c25 c26
c30 c31 c32 c33 c34 c35 c36
c40 c41 c42 c43 c44 c45 c46
c50 c51 c52 c53 c54 c55 c56
c60 c61 c62 c63 c64 c65 c66
B0
B1
B2
B3
B4
B5
B6
B
0
B
1
B
2
B
3
B
4
B
5
B
6
d31 =μA3(e)*μB1(de)
d41 =μA4(e)*μB1(de) =(1-μA3(e))*μB1(de)
d32 =μA3(e)*μB2(de)=μA3(e)*(1-μB1(de))
d42 = μA4(e)*μB2(de)=(1-μA3(e))*(1-μB1(de))
42-4 -2
4
2
-4
-2
and d31 +d32+d41+d42=1
2
ei24
2
ee
e 1iAi
−+−=−= + *)(μ
)()( e1e
i1i AA
μμ −=+
If      is located between the      and         
then
e ie 1ie +
1
μ(e)
Ai Ai+1
e
e
ei = -6+2*i ei+1 = -4+2*i
)(e
iA
μ
)(e
1iA +μ
 
 
Fig. 3. Fuzzification, fuzzy rule table, fuzzy inference and defuzzication 
c. Select the initial fuzzy control rules by referring to the dynamic response characteristics 
(Liaw et al., 1999), such as, 
 
ij,fji c  is  u  THEN   B is e  and  A is  e  IF Δ   (18) 
where i and j = 0~6, Ai and Bj are fuzzy number, and cj,i is real number. The graph of 
fuzzification and fuzzy rule table is shown in Fig. 3.  
d. Construct the fuzzy system uf(e,de) by using the singleton fuzzifier, product-inference 
rule, and central average defuzzifier method. Although there are total 49 fuzzy rules in 
Fig. 3 will be inferred, actually only 4 fuzzy rules can be effectively excited to generate a 
non-zero output. Therefore, if the error e is located between ei and ei+1, and the error 
change de is located between dej and dej+1, only four linguistic values Ai, Ai+1, Bj, Bj+1 and 
corresponding consequent values cj,i, cj+1,i, cj,i+1, cj+1,i+1 can be excited, and the (18) can be 
replaced by the following expression: 
 
m,n
i
in
j
jm
n,mi
in
j
jm
BA
i
in
j
jm
BAn,m
f d*c
)de(*)e(
)]de(*)e([c
)de,e(u
mn
mn ∑∑
∑∑
∑∑ +
=
+
=+
=
+
=
+
=
+
==
1 1
1 1
1 1
  Δ
μμ
μμ
  (19) 
where )de(*)e( d
mn BAm,n
μμΔ . And those n,mc denote the consequent parameters of the 
fuzzy system. 
FPGA-Realization of a Motion Control IC for X-Y Table  
 
401 
2.3 Motion trajectory planning of X-Y table 
The point-to-point, circular and window motion trajectories are usually considered to 
evaluate the motion performance for X-Y table.  
a. In point-to-point motion trajectory, for smoothly running of the table, it is designed 
with the trapezoidal velocity profile and its formulation is shown as follows.  
 
    
ttt     )s(t)t-(tv)t-A(t
2
1
-
 ttt                           )s(t)t-(tv
tt0                                 sAt
2
1
s(t)
sdddm
2
d
daaam
a0
2
⎪⎪⎩
⎪⎪⎨
⎧
≤≤++
≤≤+
≤≤+
=   (20) 
Where 0<t<ta is at the acceleration region, ta<t<td is at the constant velocity region, and 
td<t<ts is at the deceleration region. The s represents the position command in X-axis or 
Y-axis table; A is the acceleration/deceleration value; s0 is the initial position; vm is the 
maximum velocity; ta, td and ts represents the end time of the acceleration region, the 
start time of the deceleration region and the end time of the trapezoidal motion, 
respectively.  
b. In circular motion trajectory, it is computed by 
 )sin( rx ii θ=   (21) 
 )(osc ry ii θ=   (22) 
with θΔθθ += −1ii . Where θΔ , r , ix , iy  are angle increment, radius, X-axis trajectory 
command and Y-axis trajectory command, respectively.  
c. The window motion trajectory is shown in Fig.4. The formulation is derived as follows: 
 a-trajectory : 
1 1,i i i ix x y S y− −= = +   (23) 
b-trajectory : ) and ,2
4
6
:( 1 θΔθθππθ +=→ −iii  
 
1 1cos( ), sin( )i x i i y ix O r y O rθ θ= + = +   (24) 
 c-trajectory :
1 1,i i i ix S x y y− −= + =   (25) 
d-trajectory : 
) and ,
4
6
:( 1 θΔθθππθ +=→ −iii  
 
2 2cos( ), sin( )i x i i y ix O r y O rθ θ= + = +   (26) 
 e-trajectory :
1 1,i i i ix x y S y− −= = − +   (27) 
f-trajectory : ) and ,
2
1
:( 1 θΔθθππθ +=→ −iii  
 Motion Control 
 
402 
 
3 3cos( ), sin( )i x i i y ix O r y O rθ θ= + = +   (28) 
 g-trajectory :
1 1,i i i ix S x y y− −= − + =   (29) 
h-trajectory : ) and ,
2
1
0:( 1 θΔθθπθ +=→ −iii   
 
4 4cos( ), sin( )i x i i y ix O r y O rθ θ= + = +   (30) 
 i-trajectory :
1 1,i i i ix x y S y− −= = +   (31) 
where S , θΔ , ix , iy  are position increment, angle increment, X-axis trajectory command 
and Y-axis trajectory command, respectively. In addition, the
1 1( , )x yO O
, 
2 2( , )x yO O
, 
3 3( , )x yO O
, 
4 4( , )x yO O
 are arc center of b-, d-, f-, and h-trajectory in the Fig. 4 and r is the radius. The 
motion speed of the table is determined by θΔ . 
 
1 1
( , )
x y
O O
x
y
2 2
( , )
x y
O O
4 4
( , )
x y
O O 3 3( , )x yO O
a
b
e
f
c
d
Start
g
h
i
θΔ
1i iθ θ θ−= + Δ
2 2
( , )
x y
O O
( , )
i i
x y
1 1
( , )
i i
x y+ +
1i
θ −
r
 
Fig. 4. Window motion trajectory 
3. Design of an FPGA-based motion control IC for X-Y table  
The architecture of the proposed FPGA-based motion control IC for X-Y table is shown in 
Fig. 1, in which the motion trajectory is implemented by software using Nios II embedded 
processor and the current vector controller, the position and speed controller for two 
PMSMs are implemented by hardware in FPGA chip. However, in this section, we firstly 
introduce the concept of finite state machine (FSM). Then use FSM to design the complicated 
control algorithm, such as the FC and the vector controller in PMSM drive.  
3.1 Finite state machine (FSM) 
To reduce the use of  the FPGA resource, FSM is adopted to describe the complicated control 
algorithm. Herein, the computation of a sum of product (SOP) shown below is taken as a 
case study to present the advantage of FSM. 
FPGA-Realization of a Motion Control IC for X-Y Table  
 
403 
 
332211 *** xaxaxaY ++=  (32) 
Two kinds of design method that one is parallel processing method and the other is FSM 
method are introduced to realize the the computation of SOP. In the former method, the 
designed SOP circuit is shown in Fig. 5(a), and it will operate continuously and 
simultaneously. The circuit needs 2 adders and 3 multipliers, but only one clock time can 
complete the overall computation. Although the parallel processing method has fast 
computation ability, it consumes much more FPGA resources. To reduce the resource usage 
in FPGA, the designed SOP circuit adopted by using the FSM method is proposed and 
shown in Fig. 5(b), which uses one adder, one multiplier and manipulates 5 steps (or 5 
clocks time) machine to carry out the overall computation of SOP. Although the FSM 
method needs more operation time  (if one clock time is 40ns, the 5 clocks needs 0.2μ s) 
than the parallel processing method in executing SOP circuit, it doesn’t loss any 
computation power. Therefore, the more complicated computation in algorithm, the more 
FPGA resources can be economized if the FSM is applied. Further, VHDL code to 
implement the computation of SOP is shown in Fig.6 
 
x
x
x
1a
1x
2a
2x
3a
3x
+
+ y
          
x
x
+
x
+
s0 s1 s2 s3 s4
1x
2x
3x
1a
2a
3a
y
 
(a)                                                                           (b) 
Fig. 5. Computation of SOP by using (a) parallel operation (b) FSM operation 
LIBRARY IEEE;
USE IEEE.std_logic_1164.all;
USE IEEE.std_logic_arith.all;
USE IEEE.std_logic_signed.all;
LIBRARY lpm;
USE lpm.LPM_COMPONENTS.ALL;
ENTITY SOP IS
port(CLK_40n             :IN  STD_LOGIC;
A1,A2,A3,X1,X2,X3          :IN  STD_LOGIC_VECTOR(11 downto 0);
Y              :OUT STD_LOGIC_VECTOR(23 downto 0)
);
END matrix;
ARCHITECTURE SOP_arch OF SOP IS
SIGNAL mula,mulb :STD_LOGIC_VECTOR(11 downto 0);
SIGNAL mulr :STD_LOGIC_VECTOR(23 downto 0);
SIGNAL adda,addb,addr :STD_LOGIC_VECTOR(23 downto 0);
SIGNAL CNT :STD_LOGIC_VECTOR(7 downto 0);
BEGIN
multiplier: lpm_mult
generic map(LPM_WIDTHA=>12,LPM_WIDTHB=>12,LPM_WIDTHS=>12,LPM_WI 
DTHP=>24,LPM_REPRESENTATION=>"signed",LPM_PIPELINE=>1)    
port map(dataa=> mula,datab=> mulb,clock=> clk,result=> mulr);
adder: lpm_add_sub
generic map(lpm_width=>24,LPM_REPRESENTATION=>"signed",lpm_pipeline=>1)
port map(dataa=>adda,datab=>addb,clock=> clk,result=>addr);
GEN: block
BEGIN
PROCESS(CLK_40n)
BEGIN
IF CLK_40n'EVENT and CLK_40n='1' THEN
CNT<=CNT+1;
IF CNT=X"00" THEN
mula <= A1;
mulb <= X1;
ELSIF CNT=X"01" THEN
adda <= mulr;
mula <= A2;
mulb <= X2; 
ELSIF CNT=X"02" THEN
addb <=  mulr;
mula <=  A3;
mulb <=  X3;
ELSIF CNT=X"03" THEN
adda <= addr;
addb <= mulr;
ELSIF CNT=X"04" THEN
Y <=  addr;
CNT <=  X"00";
END IF;
END IF;
END PROCESS;
END BLOCK GEN;
END SOP_arch;
 
(a)                                                                                  (a) continue 
Fig. 6. VHDL code to implement the computation of SOP 
 Motion Control 
 
404 
3.2 Design of an FPGA-based motion control IC for X-Y table 
The internal architecture of the proposed FPGA-based motion control IC for X-Y table is 
shown in Fig. 7. The FPGA is used by Altera Stratix II EP2S60 and a Nios II embedded 
processor can be downloaded into FPGA to construct an SoPC environment. The Altera 
Stratix II EP2S60 has 48,352 ALUTs (Adaptive Look-UP Tables), maximum 718 user I/O 
pins, total 2,544,192 RAM bits, and Nios II embedded processor is a 32-bit configurable CPU 
core, 16 M byte Flash memory, 1 M byte SRAM and 16 M byte SDRAM. A custom software 
development kit (SDK) consists of a compiled library of software routines for the SoPC 
design, a Make-file for rebuilding the library, and C header files containing structures for 
each peripheral. The motion control IC, which is designed in this SoPC environment, 
comprises a Nios II embedded processor IP and an application IP.  The application IP 
implemented by hardware is adopted to realize two position/speed/current vector 
controllers of PMSMs and two QEP circuits of linear encoder. The circuit of each current 
vector controller includes a current controller and coordinate transformation (CCCT), 
SVPWM generation, QEP detection and transformation, ADC interface, etc. The speed loop 
uses P controller and the position loop adopts FC. The sampling frequency of the position 
control loop is designed with 2kHz. The frequency divider generates 50 Mhz (Clk), 25 Mhz 
(Clk-sp), 16 kHz (Clk-cur), and 2 kHz (Clk-po) clock to supply all circuits in Fig. 7.   
 
xEncoder-A
STSB
RCB
RCA
STSA
CHB
CHA
SVPWM 
generation
ADC 
Interface
Frequency 
divider
QEP detection 
and 
transformation
CLK
xEncoder-B
xEncoder-Z
xPWM-1
xPWM-2
xPWM-3
xPWM-4
xPWM-5
xPWM-6
xADIN[11]
xADIN[0]
xBDIN[11]
xBDIN[0]
CPU
On-chip
ROM
On-chip
RAM
UART
PIO
Timer
SPI
A
v
a
lo
n
 B
u
s
A
v
a
lo
n
 B
u
s
Nios II Embedded Processor IP
sram_cs
sram_we
sram_oe
sram_be[3]
sram_be[2]
sram_be[1]
sram_be[0]
D[31]
D[0]
A[22]
A[0]
Current 
controllers and 
coordinate 
transformation
(CCCT)
From Linear
Encoder
of X-axis
[11..0]
[11..0]
ai
bi
[11..0]ci
[11..0]
[11..0]
[11..0]rxv
ryv
rzv
Clk
Clk-cur
[11..0]
Clk
Clk
Clk-cur
Clk-sp
Clk
Clk-cur
Clk
Clk-sp
[15..0]
*
py
[15..0]
STSB
RCB
RCA
STSA
CHB
CHA
SVPWM 
generation
ADC 
Interface
yPWM-1
yPWM-2
yPWM-3
yPWM-4
yPWM-5
yPWM-6
yADIN[11]
yADIN[0]
yBDIN[11]
yBDIN[0]
Current 
controllers and 
coordinate 
transformation
(CCCT)
yEncoder-A
yEncoder-B
yEncoder-Z
From Linear
Encoder
of Y-axis
[11..0]
[11..0]
ai
bi
[11..0]ci
[11..0]
[11..0]
[11..0]rxv
ryv
rzv
Clk
Clk-cur
[11..0]
*
qi
QEP detection 
and 
transformation
Clk
Clk
Clk-cur
Clk
Clk-sp
Y-axis position controller
[15..0]
[11..0]py
Application 
IP
X-axis position controller
Clk-sp
Clk-spCircuit of 
position FC  
and speed P 
controller
[15..0]px
Clk
Clk-sp
*
px [15..0]
Clk-po
*
qi
Clk-po*
px
px
Circuit of 
position FC  
and speed P 
controller
[15..0]
Clk
Clk-sp
*
py [15..0]
Clk-po
py
py [15..0]
QEP detection 
and 
transformation
xEncoder-A
xEncoder-B
xEncoder-Z
From Rotary
Encoder of X-axis
Clk
[11..0]
eθ
Altera FPGA (Stratix II EP2S60 )
QEP detection 
and 
transformation
yEncoder-A
yEncoder-B
yEncoder-Z
From Rotary
Encoder of Y-axis
Clk
[11..0]
eθ
 
Fig. 7. Internal circuit of the proposed FPGA-based motion control IC 
FPGA-Realization of a Motion Control IC for X-Y Table  
 
405 
The internal circuit of CCCT performs the function of two PI controllers, table look-up for 
sin/cos function and the coordinate transformation for Clark, Park, inverse Park, modified 
inverse Clarke. The CCCT circuit designed by FSM is shown in Fig. 8, which uses one adder, 
one multiplier, an one-bit left shifter, a look-up-table and manipulates 24 steps machine to 
carry out the overall computation. The data type is 12-bit length with Q11 format and 2’s 
complement operation. In Fig. 8, steps s0~s1 is for the look-up sin/cos table; steps s2~s5 and 
s5~s8 are for the transformation of  Clarke and Park, respectively; steps s9~s14 is for the 
computation of d-axis and q-axis PI controller; and steps s15~s19 and s20~s23 represent the 
transformation of the inverse Park and the modified inverse Clarke, respectively. The 
operation of each step in FPGA can be completed within 40ns (25 MHz clock); therefore total 
24 steps need 0.96 μs operation time. Although the FSM method needs more operation time 
than the parallel processing method in executing CCCT circuit, it doesn’t loss any control 
performance in overall system because the 0.96 μs operation time is much less than the 
designed sampling interval, 62.5 μs (16 kHz) of current control loop in Fig. 1. To prevent 
numerical overflow and alleviate windup phenomenon, the output values of I controller 
and PI controller are both limited within a specific range. 
 
LUT
s1
ki_d
e_d
kp_d
i_d
e_d
i_d
ki_q
e_q
kp_q
i_q
e_q
i_q
s2 s4s3 s5 s6 s8s7
-
s9 s10 s11 s13s12 s15
LS,1
2
3
-
s16s14
-
s17 s18 s19 s20 s21 s22 s23
+
x
x
+
ecosθ
esinθ
+
+
x
x
x
+
+
x
+
βv
+x
x
x
αv
+
+
dv
addre _θ
qv
-
0=*di
-
*
qi
rxv
ryv
rzv
+
+
dv
qv
s0
-
+
d-axis PI 
controller
Park-1ParkClark
Clark-1
q-axis PI 
controller
Look up
Sin/Cos 
Table
Modified
+
x : Multiplier
: Adder
LS,1 : Left shift with 
one bit
)11Q( 011011011000             
5774.03/1
)11Q( 110100100111             
  5774.0    3/1
)11Q( 000110111011             
   8660.0   2/3
≅
−≅−
≅
≅
≅
≅
3
1−
3
1
-x
αi
x
x
x
+
βi
x +
x +
qi
di
ai
bi
ci
2
βv
 
Fig. 8. Designed CCCT circuit in Fig. 7  
An FSM is employed to model the FC of the position loop and P controller of the speed loop 
in PMLSM and shown in Fig. 9, which uses one adder, one multiplier, a look-up table, 
comparators, registers, etc. and manipulates 23 steps machine to carry out the overall 
computation. With exception of the data type in reference model are 24-bits, others data 
type are designed with 12-bits length, 2’s complement and Q11 format. Although the 
algorithm of FC is highly complexity, the FSM can give a very adequate modeling and easily 
be described by VHDL. Furthermore, steps s0~s2 are for the computation of speed, position 
error and error change; steps s3~s6 execute the function of the fuzzification; s7 describes the 
look-up table and s8~s16 defuzzification; and steps s17~s22 execute the computation of speed 
 Motion Control 
 
406 
and current command output. The SD is the section determination of e and de, and its flow 
chart of circuit design is shown in Fig.10. And the RS,1 represents the right shift function 
with one bit. The operation of each step in Fig.9 can be completed within 40ns (25 MHz 
clock) in FPGA; therefore total 23 steps need 0.92μs operation time. It doesn’t loss any 
control performance in the overall system because the operation time with 0.92μs is much 
less than the sampling interval, 500 μs (2 kHz), of the position control loop in Fig.1.  
In Figure 7, with exception of the CCCT circuit, others circuit design, like SVPWM and QEP, 
are presented in Fig. 11(a) and 11(b), respectively. The SVPWM circuit is designed to be 12 
kHz frequency and 1μs dead-band. The circuit of the QEP module is shown in Fig.11(b), 
which consists of two digital filters, a decoder and an up-down counter. The filter is used for 
reducing the noise effect of the input signals PA and PB. The pulse count signal PLS and the 
rotating direction signal DIR are obtained using the filtered signals through the decoder 
circuit. The PLS signal is a four times frequency pulses of the input signals PA or PB. The 
QEP value can be obtained using PLS and DIR signals through a directional up-down 
counter. 
 
+
-
s0
+
-
+
-
s1 s2
)( 1kx p −
)(k v
)1( −ke
s3
Computation of speed, position 
error and error change   
s8
x
+
1
-
)(e
iA
μ
)(de
jB
μ
jid ,
+
-
x
x
x
s9 s10 s11
)(de
jB
μ
)e(
iA 1+μ
1
)de(
jB 1+μ
j,id 1+
1+j,id
11 ++ j,id
)(de
jB
μ
)(e
iA
μ
s12
x
x
+
x
x
+ + x +
ui
x +
s14 s15 s17 s18 s22s13 s16 s19
ijc ,
i,jc 1+
1+i,jc
11 ++ i,jc
jid ,
jid ,1+
1,1 ++ jid
1, +jid
iK
pK
fu
)(
*
kiq
ui
Defuzzification Computation of speed and current command
+
-
+
-
&
i
j
j&i
s4 s5 s6 s7
)(kde
)(e
iA
μ
)(de
jB
μ
ijc ,
1+i,jc
i,jc 1+
11 ++ i,jc
1+ie
1+jde
Look-up
Fuzzy rule 
table
RS,1
RS,1
Fuzzification
SD
ke
SD
kde
)(ke
)(
*
kxp
)(kx p
+
)(k v
x
vK
-
s20 s21
)(k u
Look-up fuzzy table
 
 
Fig. 9. State diagram of an FSM for describing the FC in position loop and P controller in 
speed loop 
FPGA-Realization of a Motion Control IC for X-Y Table  
 
407 
if e >= 0
if e >= 6
yes
if e >= 4
yes
if e >= 2
yes
if e <= -6
yes
if e <= -4
yes
if e >= -2
yes
no
no
no
i  := 5
ei+1 := 8
ek := 6
i  := 5
ei+1 := 6
ek := e
yes
i  := 4
ei+1 := 4
ek := e
e := e(k)
i  := 3
ei+1 := 2
ek := e
no
i  := 0
ei+1 := -4
ek := -6
i  := 0
ei+1 := -4
ek := e
i  := 1
ei+1 := -2
ek := e
i  := 2
ei+1 := 0
ek := e
no
no
no
 
Fig. 10. Section determination in Fig. 9 
Clk
S1
S2
S3S..
S12
PWMEA_2
PWM1
PWM2
PWM3
PWM4
PWM5
PWM6
PWMEA_1
PWMEB_2
PWMEB_1
Vrx
State Machine
SVPWM Algorithm
Vry
Vrz
12
12
12
Clk_sp
CMPR1
12
12
12
Clk
CMPR2
CMPR3
Comparator
(1)
Dead-band 
generation 
unit
Clk_sp
PWMEC_2
PWMEC_1
Generation of 
the symmetrical 
triangular wave
12
Q
Comparator
(2)
Comparator
(3)
 
(a) 
D Q
generation  
of 
4-times 
frequency 
and 
counter 
direction
Digital
Filter
Encoder-A
PHA
DLA
D Q
Digital
Filter
Clk
PHB
DLB
DIR
PLS
up/down 
counter
Digital
Filter
PHZ
address
generation 
of 
electrical angle
addre _θ
12
Encoder-B
Encoder-Z
 
(b) 
Fig. 11. Block diagram of (a) SVPWM circuit (b) QEP circuit 
The Nios II embedded processor IP is depicted to perform the function of the motion 
trajectory for X-Y table in software. Figure 12 illustrates the flow charts of the main program 
and the interrupt service routine (ISR), where the interrupt interval is designed with 2ms. 
 Motion Control 
 
408 
All programs are coded in the C programming language in Fig.10. Then, through the 
complier and linker operation in the Nios II IDE (Integrated Development Environment), 
the execution code is produced and can be downloaded to the external Flash or SDRAM via 
JTAG interface. Using the C language to develop the control algorithm has the portable 
merit and is easier to transfer the mature code from the other processor to the Nios II 
embedded processor. Finally, Table 1 shows the FPGA utility of the proposed motion 
control IC and the overall circuits included a Nios II embedded processor IP (5,059 ALUTs 
and 78,592 RAM bits) and an application IP (10,196 ALUTs and 102,400 RAM bits), use 
31.5% ALUTs resource and 7.1% RAM resource of Stratix II EP2S60. 
 
Start of 
main program
Initial interrupt
Initial timer
loop
Start of ISR
( each 500Hz )
Return
Set parameters
of each axis 
Output the control 
effort to position loop 
( X&Y axis)  
Computation of 
position value for each axis
from motion trajectory
command
 
Fig. 12. Flow chart of the main and ISR program in Nios II embedded processor 
IP Module circuit
Logic gate
(ALUTs)
Memory 
(Bits)
Nios II embedded processor IP 5,059 78,592
Application IP
( for X-axis and 
Y-axis )
Position fuzzy controller and       
speed P controller
1,943 × 2 0
Current controller and coordinate 
transformation (CCCT)
649 × 2 49,152 × 2
SVPWM generation 1,220 × 2 0
ADC interface 123 × 2 0
QEP detection and transformation 79 × 4 0
others 1,005 × 2 2,048 × 2
Total 15,255 180,992
 
Table 1. Utility evaluation of a motion contron IC for X-Y table in FPGA 
4. Experiments and results 
The overall experimental system is depicted in Fig. 1. This system includes an FPGA 
experimental board, two sets of voltage source IGBT inverter and an X-Y table which is 
driven by two PMSMs and two ball-screws. The power, rating, voltage, current and rating 
speed of PMSM are 200W, 92V, 1.6A and 3000rpm, respectively. A 2500 ppr rotary encoder 
attached to PMSM is used to measure the motor’s electrical angle. Two linear encoders with 
5μm resolution are mounted on the X-axis and Y-axis table as a position sensor. Each ball-
FPGA-Realization of a Motion Control IC for X-Y Table  
 
409 
screw has 5mm lead.  The inverter has 6 sets of IGBT type power transistors. The collector-
emitter voltage of the IGBT is rating 600V, the gate-emitter voltage is rating ±12V, and the 
collector current in DC is rating 25A and in short time (1ms) is 50A. The photo-IC, Toshiba 
TLP250, is used for gate driving circuit of IGBT. Input signals of the inverter are PWM 
signals from FPGA chip. The FPGA-Altera Stratix II EP2S60 in Fig.1 is used to develop a full 
digital motion controller for X-Y table. The motion trajectory are implemented by software 
using Nios II embedded processor, and the two axis position/speed/current vector 
controller are implemental by hardware in FPGA. In the experimental system, the PWM 
switching frequency of inverter is designed with 12k Hz, dead-band is 1μs, and the 
sampling frequency in current loop and position loop of the PMSM are designed with 
16kHz and 500Hz, respectively. The motion control algorithms are coded by C language.  
In experiment, the position step response and the motion trajectory control are used to 
evaluate the dynamic performance of the proposed system. In the experiment of the step 
response, the results of X-axis and Y-axis table under 10 mm amplitude and 0.5Hz square 
wave command are shown in Fig. 13. The rising time, overshoot and steady-state value in 
Fig. 13(a) are 110ms, 14% and near 0mm, and in Fig. 13(b) are 90ms, 15% and near 0mm. It 
reveals that the mass carried in X-axis table is heavier than those in Y-axis table. In the 
experiment of the motion trajectory tracking, one-dimensional trapezoidal motion trajectory, 
two-dimensional circular and window motion trajectory are tested and its experimental 
tracking results are shown in Figs. 14 ~ 16. In one-dimensional motion trajectory, the 
trapezoidal velocity profile is considered which the acceleration and deceleration is 
designed with 500mm/s2, maximum speed is 125mm/s, and the overall displacement is 
designed with moving from 0 mm to 100 mm position. The trajectory tracking results in 
each axis corresponding with the aforementioned input commands is shown in Fig. 14. It 
can be seen that the motion of X-axis and Y-axis table can give a perfect tracking with 
command target both in position or speed trajectory. Further, in two-dimensional motion 
trajectory, the circular motion trajectory control with center (60, 60) mm and radius 50mm is 
evaluated and the tracking errors are the maximum ± 0.55 mm in X-axis, and ± 0.75 mm in 
Y-axis in Fig. 15. The window motion trajectory designed as Fig.4 and its experimental result 
is shown in Fig. 16, which also shows the tracking errors maximum ± 0.5 mm in X-axis, and 
± 0.9 mm in Y-axis. Therefore, from the experimental results of Figs. 13~16, it demonstrates 
that the proposed FPGA-based motion controller IC for X-Y table is effective and correct. 
 
0 1 2 3 4 5 6 7 8 9
-5
0
5
10
15
Time (s)
P
o
s
it
io
n
 (
m
m
)
X-axisPosition response Position command
(a)
(b)
0 1 2 3 4 5 6 7 8 9
-5
0
5
10
15
Time (s)
P
o
s
it
io
n
 (
m
m
)
Y-axisPosition response Position command
 
Fig. 13. Step response for (a) X-axis table (b) Y-axis table 
 Motion Control 
 
410 
0 2 4 6 8 10 12 14
-50
0
50
100
150
Time (s)
P
o
s
it
io
n
 (
m
m
)
0 2 4 6 8 10 12 14
-200
0
200
Time (s)
S
p
e
e
d
 (
m
m
/s
)
0 2 4 6 8 10 12 14
-50
0
50
100
150
Time (s)
P
o
s
it
io
n
 (
m
m
)
0 2 4 6 8 10 12 14
-200
0
200
Time (s)
S
p
e
e
d
 (
m
m
/s
)
Mover position
X-axis
X-axisSpeed command
Mover tracking speed
(a)
Position command
Mover Position
Y-axis
Y-axisSpeed command
Mover tracking speed
Position command
(b)  
Fig. 14. (a) Position and speed tracking response in X-axis and in (b) Y-axis table  
0 20 40 60 80 100 120
0
20
40
60
80
100
120
0 1 2 3 4
0
50
100
150
Time (s)
0 1 2 3 4
-0.5
0
0.5
1
Time (s)
0 1 2 3 4
0
50
100
150
Time (s)
0 1 2 3 4
-1
-0.5
0
0.5
1
Time (s)
0 1 2 3 4
-0.5
0
0.5
Time (s)
0 1 2 3 4
-0.5
0
0.5
Time (s)(a)
(b) (d)
(c)X-axis (mm)
Y
-a
x
is
 (
m
m
)
P
o
s
it
io
n
 (
m
m
)
p
o
s
it
io
n
 e
rr
o
r 
(m
m
)
P
o
s
it
io
n
 (
m
m
)
P
o
s
it
io
n
  
e
rr
o
r
(m
m
)
iq
(A
)
iq
(A
)
X-axis
Y-axis
X-axis
Y-axis
X-axis
Y-axis
 
Fig. 15. Response of the circular trajectory (a) circular trajectory response (b) response for X- 
and Y- axis (c) control effort (d) tracking error 
FPGA-Realization of a Motion Control IC for X-Y Table  
 
411 
0 20 40 60 80 100 120
20
40
60
80
100
120
140
X-axis (mm)
Y
-a
x
is
 (
m
m
)
0 2 4 6 8
0
50
100
150
Time (s)
P
o
s
it
io
n
 (
m
m
)
0 2 4 6 8
-1
0.5
0 
-0.5
1 
Time (s)
p
o
s
it
io
n
 e
rr
o
r 
(m
m
)
0 2 4 6 8
0
50
100
150
Time (s)
P
o
s
it
io
n
 (
m
m
)
0 2 4 6 8
-1
-0.5
0
0.5
1
Time (s)
P
o
s
it
io
n
  
e
rr
o
r
(m
m
)
0 2 4 6 8
-1
0
1
Time (s)
iq
(A
)
0 2 4 6 8
-1
0
1
Time (s)
iq
(A
)
(a)
(b) (d)
(c)
X-axis
Y-axis
X-axis
Y-axis
X-axis
Y-axis
 
Fig. 16. Response of the window trajectory (a) window trajectory response (b) response for 
X- and Y- axis (c) control effort (d) tracking error 
5. Conclusion 
This study successfully presents a motion control IC for X-Y table based on novel FPGA 
technology. The works herein are summarized as follows. 
1. The functionalities required to build a fully digital motion controller of X-Y table, such 
as the two current vector controllers, two speed P controllers, and two position fuzzy 
controllers and one motion trajectory planning, have been integrated in one FPGA chip. 
2. An FSM joined by one multiplier, one adder, one LUT, or some comparators and 
registers has been employed to model the overall FC algorithm and the CCCT in vector 
control of the PMSM, such that it not only is easily implemented by VHDL but also can 
reduce the FPGA resources usage. 
3. The software/hardware co-design technology under SoPC environment has been 
successfully applied to the motion controller of X-Y table.  
However, the experimental results by step response, point-to-point, window and circular 
motion trajectory tracking, has been revealed that the software/hardware co-design 
technology with the parallel processing well in the motion control system of X-Y table.  
6. References 
Altera Corporation, (2004). SOPC World. 
Altera (2008): www.altera.com. 
Goto, S.; Nakamura M. & Kyura, N. (1996). Accurate contour control of mechatronic servo 
systems using gaussian networks, IEEE Trans. Ind. Electron., vol.43, no. 4, pp. 469-
476. 
 Motion Control 
 
412 
Hall, T.S. & Hamblen, J.O. (2004). System-on-a-programmable-chip development platforms 
in the classroom, IEEE Trans. on Education, vol.47, no.4, pp.502-507. 
Hanafi, D.; Tordon, M. & Katupitiya, J. (2003). An active axis control system for a 
conventional CNC machine, Proceedings of IEEE/ASME International Conference on 
Advanced Intelligent Mechatronics, pp. 1188-1193. 
Hsu, Y.C.; Tsai, K.F.;  Liu, J.T. & Lin, E.S. (1996) VHDL modeling for digital design synthesis, 
KLUWER ACADEMIC PUBLISHERS, TOPPAN COMPANY (S) PTE LTD. 
Jung, S. & Kim, S.S. (2007). Hardware implementation of a real-time neural network 
controller with a DSP and an FPGA for nonlinear systems, IEEE Trans. Ind. 
Electron., vol. 54, no. 1, pp. 265-271. 
Kung, Y.S.; Huang, P.G. & Chen, C.W. (2004). Development of a SOPC for PMSM drives, 
Proceedings of the IEEE International Midwest Symposium on Circuits and Systems, vol. 
II, pp. II-329~II-332. 
Kung, Y.S. & Shu, G.S. (2005). Design and Implementation of a Control IC for Vertical 
Articulated Robot Arm using SOPC Technology, Proceeding of IEEE International 
Conference on Mechatronics,  pp. 532~536. 
Kung, Y.S.; Tseng, K.H. & Tai, F.Y. (2006) FPGA-based servo control IC for X-Y table, 
Proceedings of the IEEE International Conference on Industrial Technology, pp. 2913-
2918. 
Kung, Y.S. & Tsai, M.H. (2007). FPGA-based speed control IC for PMSM drive with adaptive 
fuzzy control, IEEE Trans. on Power Electronics, vol. 22, no. 6, pp. 2476-2486. 
Li, T.S.; Chang S.J. & Chen, Y.X. (2003). Implementation of Human-like Driving Skills by 
Autonomous Fuzzy Behavior Control on an FPGA-based Car-like Mobile Robot, 
IEEE Trans. Ind. Electro., vol. 50, no.5, pp. 867-880. 
Liaw, C.M. & Kung, Y.S. (1999) Fuzzy control with reference model-following response, 
Fuzzy Theory Systems: Techniques and Applications, vol.1, pp. 129-158. 
Lin, F.J.; Wang, D.H. & Huang, P.K. (2005). FPGA-based fuzzy sliding mode control for a 
linear induction motor drive, IEE Proc.- Electr. Power Application, vol. 152, no.5, pp. 
1137-1148. 
Monmasson, E. & Cirstea, M.N. (2007). FPGA design methodology for industrial control 
systems – a review, IEEE Trans. on Industrial Electronics, Vol. 54, No. 4, pp.1824-
1842. 
Naouar, M.W.; Monmasson, E.; Naassani, A.A.; Slama-Belkhodja, I. & Patin, N. (2007). 
FPGA-based current controllers for AC machine drives – a review, IEEE Trans. Ind. 
Electron., vol. 54, no.4, pp.1907-1925. 
Sanchez-Solano, S.; Cabrera, A.J.; Baturone, I.; Moreno-Velo, F.J. & Brox, M. (2007). FPGA 
implementation of embedded fuzzy controllers for robotic applications, IEEE Trans. 
Ind. Electron., vol. 54, no. 4, pp. 1937-1945. 
Wang, G.J. & Lee, T.J. (1999). Neural-network cross-coupled control system with application 
on circular tracking of linear motor X-Y table, International Joint Conference on Neural 
Networks, pp. 2194-2199. 
Wei, R.; Gao, X.H.; Jin, M.H.; Liu, Y.W.; Liu, H.; Seitz, N.; Gruber, R. & Hirzinger, G. (2005). 
FPGA based Hardware Architecture for HIT/DLR Hand, Proceeding of the IEEE/RSJ 
International Conference on Intelligent Robots and System, pp. 523~528. 
Zhou, Z.; Li, T.; Takahahi, T. & Ho, E. (2004). FPGA realization of a high-performance servo 
controller for PMSM, Proceeding of the 9th IEEE Application Power Electronics 
conference and Exposition, vol.3, pp. 1604-1609. 
© 2010 The Author(s). Licensee IntechOpen. This chapter is
distributed under the terms of the Creative Commons Attribution-
NonCommercial-ShareAlike-3.0 License, which permits use,
distribution and reproduction for non-commercial purposes,
provided the original is properly cited and derivative works building
on this content are distributed under the same license.
