Minimization of Instantaneous Total Harmonic Distortion of Curents for Three-Phase Switching Power Converters by Günay, Murat & Gunay, Murat
MINIMISATION OF INSTANTANEOUS TOTAL HARMONIC DISTORTION OF
CURRENTS FOR THREE-PHASE SWITCHING POWER CONVERTERS
By
MURAT GÜNAY
Submitted to the Graduate School of Engineering and Natural Sciences
in partial fulfillment of
the requirements for the degree of
Master of Science
SABANCI UNIVERSITY
Spring 2002
MINIMISATION OF INSTANTANEOUS TOTAL HARMONIC DISTORTION OF
CURRENTS FOR THREE-PHASE SWITCHING POWER CONVERTERS
APPROVED BY:
Prof. Dr. ASIF ŞABANOVİÇ.………………….…….……
(Dissertation Supervisor)
Assistant Prof. Dr. AHMET ONAT……………….…….….
(Dissertation Co-advisor)
Assistant Prof. Dr. AYHAN BOZKURT…………….….….
Assistant Prof. Dr. KEMALETTİN ERBATUR.……………
Assoc. Prof. Dr. METİN GÖKAŞAN………………….……
DATE OF APPROVAL: …………………………
iii
 Murat Günay 2002
All rights reserved
iv
ABSTRACT
This work studies an application of the discontinuous control approach to the
design of the current control loop in switching power converters and electrical drives.
The role of the current control loop is to generate the switching patterns that will
determine the sequence and the duration ON and OFF states of the switches. The
reduction of the Instantaneous Total Harmonic Distortion of the currents for 3~Phase
Switching Power Converters and 3~Phase Electrical machines is being selected as
additional requirement determining the switching matrix operation. The approach is
based on the Direct Sliding Mode principle and the unified approach for control of a
PWM 3-phase switching matrix with six switches, common for 3-phase inverters,
rectifiers as well as 3-phase machines.
Conventional tracking control algorithms may provide the proper selection of
switching vector but not the proper timing since switching timing occurs only when the
control error is contacted pre-set hysteresis bounds. However this generates significant
harmonic distortion especially low order harmonic distortion compared with carrier
based algorithms.
The quality of the switching control algorithm is determined by both the proper
selection of switching vector and the proper switching timing.
The presented algorithm evaluates harmonic distortion in real time with
instantaneous THD definition and sequentially selects two switching vectors in one
control period in order to minimize the tracking error and timing is determined
according to the THD minimization theorem.
The simulation of the approach is performed on both Boost Rectifier and Buck
Inverter, and comparative simulation results with Relay Control approach are given.
vÖZET
Bu çalışmada, 3 fazlı Anahtarlamalı Güç Çeviricileri ve 3 fazlı Elektrik
Makinalarının akımlarındaki, Ani Toplam Harmonik Distorsiyonu azaltacak şekilde
kontrol edilebilmesi için gerekli anahtar pozisyonlarının üretilmesine ilişkin, ayrık
zamanda bir kontrol yöntemi önerilmektedir. Bu yaklaşım, 6 anahtarlı Darbe Genlik
Modülasyonu üreten 3 fazlı anahtarlama matrisinin, tüm 3 fazlı evirici, 3 fazlı
doğrultucu ve 3 fazlı elektrik makinaları için tekleştirilmiş modelini ve Direkt Kayan
Kipli Denetim ilkesini temel almaktadır.
Klasik izleme algoritmaları, kontrol vektörünün seçimini doğru yapabilirler ve
fakat zamanlamasını yapamazlar çünkü anahtarlama zamanı, hatanın daha önceden
belirlenmiş histerezis sınırlarına temasıyla gerçekleşmektedir. Fakat bu tip bir yaklaşım,
taşıyıcı temelli algoritmalarla kıyaslandığında özellikle düşük dereceden harmonikler
yüzünden büyük bir harmonik bozulmaya sebebiyet vermektedir.
Anahtarlama Algoritmasının iyiliği ise hem doğru vektörün seçimi, hem de
doğru zamanlamanın yapılmasıyla belirlenmektedir.
Önerlen yaklaşım, Ani Toplam Harmonik Distorsiyon tanımıyla Harmonik
distorsiyonu gerçek zamanda hesaplamakta, izleme hatasını minimize edecek şekilde
kontrol vektörlerini hesaplamakta, ardından Toplam Harmonik Distorsiyon
Minimizasyon ilkesine göre bir kontrol peryodu içinde iki kontrol vektörünün
zamanlamasını hesaplamaktadır.
Çalışmada, 3 fazlı Yukarıya doğru doğrultucunun ve 3 fazlı Aşağıya doğru
eviricinin önerilen yaklaşımla benzeşimi yapılmış, ve klasik Röle kontrolüyle olan
karşılaştırmalı benzeşim sonuçları verilmiştir.
vi
Dedicated to my family
vii
ACKNOWLEDGEMENTS
I am grateful to Professor Asif Sabanovic for his continuous encouragement and
invaluable support. Thanks for being there whenever I need you.
I would also like to thank Baris Arikan, dearest friend, for his support that he has
always served before I needed.
I would like to thank my family for their unbelievable patience and
encouragement. I promise to spend all my time with you as soon as possible.
Finally, thanks to all Mechatronics people, especially graduate students that we
have spent numerous nights in the Lab, for their friendship.
viii
TABLE OF CONTENTS
Page
ABSTRACT…………………………………………………………………………….iv
ÖZET…………………………………………………………………………………….v
DEDICATION…………………………………………………………………………..vi
ACKNOWLEDGEMENTS……………………………………………………………vii
TABLE OF CONTENTS…………………………………………………………...…viii
LIST OF FIGURES……………………………………………………………………..xi
LIST OF TABLES………………………………………………………….………….xiv
LIST OF SYMBOLS.…………………………………………………………………..xv
LIST OF ABBREVIATIONS………………………………………………………..xviii
1.  INTRODUCTION…………………………………………………………………..1
2.  DESCRIPTION AND MODEL OF 3~PHASE SWITCHING POWER
    CONVERTERS………………………………………………………………………4
2.1  Introduction……………………………….…………………………………4
2.2  Definition of Control Vector (Switching Vector) U And Permissible
       Control Vectors……………………………………………………………..6
2.3  Mathematical Model of 3~Phase Switching Power Converters…………….8
2.3.1  Boost Rectifier Description in Phase (abc) Frame………………..8
2.3.2  Buck Inverter Description in Phase (abc) Frame ………...………9
2.3.3  Buck Rectifier Description in Phase (abc) Frame……………….10
2.3.4  Boost Inverter Description in Phase (abc) Frame……………….11
2.3.5  Synchronously Rotating Frames of References (dq) Frame…….12
2.3.6  Boost Rectifier Description in Synchronously Rotating (dq)
Frame.………………………………………………….………..14
2.3.7  Buck Inverter Description in Synchronously Rotating (dq)
Frame……………………………………………………………15
ix
2.3.8  Buck Rectifier Description in Synchronously Rotating (dq)
Frame…………………………………………………………….15
2.3.9  Boost Inverter Description in Synchronously Rotating (dq)
Frame…………………………………………………………….16
2.3.10  General Description of 3~Phase Power Converters in
             Synchronously Rotating (dq) Frame.…………………………..16
3.  CONTROL OF 3~PHASE SWITCHING POWER CONVERTERS…….……18
3.1  Sliding Mode Control of Switching Power Converters……………………18
3.2  Relay Control Approach Vector Selection…………….…………………..20
3.3  Description of the THD Minimization Algorithm…………………………23
3.3.1  Selection of the First Vector…………………………….……….27
3.3.2  Selection of the Second Vector………………………….………28
3.3.3  Selection of Timing………………………………………..…….29
3.3.4  Obtaining Equivalent Control…………………………….……..30
3.3.5  Getting Use of Zero Vectors…………………………………….30
4.  SIMULATION RESULTS…………………..…………………………………….32
4.1  Boost Rectifier Simulation………………………………………………...32
4.1.1  Simulation for Current Control with THD Minimization
          Algorithm for Boost Rectifier……………………………………33
4.1.2  Simulation for Current Control with Relay Controller……….….38
4.1.3  Comparison of Relay Control Algorithm and THD
                      Minimization Algorithm on Boost Rectifier………………….….43
4.1.4  Voltage Control Design………………………………………….44
4.1.5  Simulation of THD Minimization Algorithm Combined
          with Voltage Controller …………………………………..……..48
4.2  Buck Inverter Simulation………………………………………………….52
4.2.1  Simulation for Current Control with THD Minimization
          Algorithm for Buck Inverter…………………………………….53
4.2.2  Simulation for Current Control with Relay Controller………….55
4.2.3  Comparison of Relay Control Algorithm and THD
          Minimization Algorithm on Buck Inverter.……………………..59
x5.  CONCLUSIONS…………...………………………………………………………60
APPENDIX A. Floppy Diskette including the MATLAB scripts and SIMULINK
             model files of the simulations………………………………………….61
APPENDIX B. Screen Captures of model files, Parameter M-files,
             S-function files’ program codes employed in the simulations………...62
REFERENCES…………………………………………………………………………88
xi
LIST OF FIGURES
 2.1 Structure of Three-phase system
 2.2 Common structures for Switching Power Converters
 2.3 Boost Rectifier
 2.4 Buck Inverter
 2.5 Buck Rectifier
 2.6 Boost Inverter
 2.7 Switching vectors a) for Boost Rectifier and Buck Inverter b) for Boost Inverter and
       Buck Rectifier, in stationary frames of references (αβ ), and illustration of (dq)
       frames of references
 3.1 Theoretical control and applicable controls for Relay control scheme for a particular
       system state
 3.2 Illustration of  measurement instances both at real time axis and normalized time
       axis and calling convention
 3.3 Illustration of derivative of error on the possible control vectors
 3.4 Illustration of final errors corresponding to possible vectors for a particular initial
       error
 3.5 Illustration of selection of first vector that causes minimum final error
 3.6 Selection of second the vector
 4.1 Simulation of Current Loop of Boost Rectifier with THD Minimization
       control scheme
 4.2 Timing scheme of the Boost Rectifier under THD Minimization controller
 4.3 a) Reference current d component reference b) Reference current q component
       reference c) Tracking for d component d) Tracking for q component current
       e) Ripple for d component f) Ripple for q component of currents in (dq) frame for
       Boost Rectifier under THD Minimization control scheme
 4.4 Input source voltages and input currents for Boost Rectifier under THD
       Minimization control scheme
 4.5 Steady state input currents and corresponding modulation functions for one period
       of input voltage for Boost Rectifier under THD Minimization control scheme
xii
 4.6 a) Control vector shown in (αβ ) frames of references b) Input currents shown in
       (αβ ) frames of references for Boost Rectifier under THD Minimization
       control scheme
 4.7 Simulation of Current Loop of Boost Rectifier with Relay Control
 4.8 Timing scheme of the Relay Controller for Boost Rectifier
 4.9 a) Reference current d component reference b) Reference current q component
       reference c) Tracking for d component d) Tracking for q component current
       e) Ripple for d component f) Ripple for q component of currents in (dq) frame for
       Boost Rectifier under Relay control scheme
 4.10 Input source voltages and input currents for Boost Rectifier under Relay control
         scheme
 4.11 Steady state input currents and corresponding modulation functions for one period
         of input voltage for Boost Rectifier under Relay control scheme
 4.12 a) Control vectors in (αβ ) frame b) Input currents in (αβ ) frame for Boost
         Rectifier under Relay control scheme
 4.13 Simulation of Boost Rectifier, currents controlled with THD Minimization scheme
         and  voltage controlled by Discrete-time Sliding Mode Control
 4.14 Boost Rectifier output voltage, currents controlled with presented scheme and
         voltage controlled by Discrete-time Sliding Mode Control
 4.15 Input source voltages and input currents for fully controlled Boost Rectifier
 4.16 a) Control vectors b) Currents c) Phase a Current and modulation function for
         completely controlled Boost Rectifier
 4.17 Simulation of Current Loop of Buck Inverter with THD Minimization Control
         scheme
 4.18 a) Reference current d component reference b) Reference current q component
         reference c) Tracking for d component d) Tracking for q component current
         e) Ripple for d component f) Ripple for q component of currents in (dq) frame for
         Buck Inverter under presented control scheme
 4.19 Input source voltages and input currents for Buck Inverter under THD
         Minimization control scheme
 4.20 Steady state input currents and corresponding modulation functions for one period
         of input voltage for Buck Inverter under THD Minimization control scheme
 4.21 Input currents shown in (αβ ) frames of references for Buck Inverter under
xiii
         THD Minimization control scheme
 4.22 Simulation of Buck Inverter, currents controlled with Relay Controller
 4.23 Tracking and transients of plant currents in (dq) frame for Buck Inverter under
         Relay control scheme
 4.24 Output Phase voltages and output currents for Buck Inverter under Relay control
         scheme
 4.25 Steady state phase currents and corresponding modulation functions for one period
         of input voltage for Buck Inverter under Relay control scheme
 4.26 Phase currents shown in (αβ ) frames of references for Buck Inverter under Relay
         control scheme
xiv
LIST OF TABLES
Table 1 Permissible connections for Boost Rectifier & Buck Inverter
Table 2 Permissible connections for Boost Inverter & Buck Rectifier
Table 3 Zero vector look-up table to reduce the number of switching actions for Boost
              Rectifier and Buck Inverter
Table 4 Zero vector look-up table to reduce the number of switching actions for Boost
              Inverter and Buck Rectifier
Table 5 Parameters for Boost Rectifier simulation
Table 6 Total harmonic distortions of the phase currents for 50 Hz fundamental Boost
             Rectifier under THD Minimization controller
Table 7 Total harmonic distortions of the phase currents for 50 Hz fundamental for
             Boost Rectifier under Relay control scheme
Table 8 Comparison of control algorithm performances for Boost Rectifier based on
             simulation results
Table 9 Parameters used in Buck Inverter simulation
Table 10 Comparison of control algorithm performances for Buck Inverter based on
               simulation results
xv
LIST OF SYMBOLS
jsw  Binary variable representing the status of j
th switch j=1,2…6
U Control Vector
IU  First control vector
IIU  Second control vector
u! Control vector represented in (dq) frames of references
ju Control vector component for (abc) frames of references, j=1,2,3
du  d component Control vector
qu  q component Control vector
i
!
Inductor currents vector represented in (dq) frames of references
ri
!
Reference inductor currents vector represented in (dq) frames of references
Lji Inductor current vector component in (abc) frames of references j=1,2,3
Ldi  d component of Inductor current vector
Lqi  q component of Inductor current vector
gdi  d component of Source current vector
gqi  q component of Source current vector
R Resistance
L Inductance
C Capacitance
SjV Input Source Voltage j=1,2,3
v!  AC voltage vector represented in (dq) frames of references
OV  DC Output voltage
OjV Output Voltage vector component in (abc) frames of references j=1,2,3
OdV  d component Output Voltage vector
OdV  q component Output Voltage vector
S Sliding Mode Manifold
xvi
σ
! Error Vector
)0(σ! Error vector value at beginning of the control period
)(τσ! Error vector value at the end of the control period
equ
! Equivalent control vector
equ
" Approximated equivalent control vector
LPFτ  Time constant of the Low Pass Filter
DCV  DC Source Voltage
(αβ  ) Stationary frame of reference, horizontal axis collinear with phase a base vector
( dq ) Synchronously Rotating frame of reference with the AC side of the converter
dq
abcT Frame transformation matrix, from (abc) frame to (dq) frame
rθ  Reference angular position
rω  Reference angular velocity
D
!
 Displacement vector for error
ID
!
 Displacement vector for the first vector
IID
!
 Displacement vector for the second vector
τ Normalized time variable
T Sampling period of the controller
jR  RMS value of the jth harmonic
1R RMS value of the fundamental harmonic
αβ
abcA Transformation matrix, from (abc) to ( )αβ  frame
dqAαβ Transformation matrix, from ( )αβ  to ( )dq  frame
dq
abcT Transformation matrix, from (abc) to ( )dq  frame
x! System state vector
rx! Reference system state vector
G Partial derivative of manifold with respect to system state
α Timing information for Second vector
optα Optimum timing information for Second vector
ref
di Reference for d component of current
xvii
ref
qi Reference for q component of current
ref
oV Reference output voltage
υ Quadratic Lypunov function candidate
µ Positive real number
refφ Reference angle between d component and q compponent of current
T Sampling period of the controller
uimin Lower bound of the control u
uimax Upper bound of the control u
H
!
Vector valued function
dH d component of H
!
qH q component of H
!
f
!
Continuous vector valued function
df d component of f
!
qf q component of f
!
xviii
LIST of ABBREVIATIONS
THD Total Hatmonic Distortion
AC Alternative Current
DC Direct Current
EMC Electromagnetic Compatibility
PWM Pulse Width Modulation
µ micro 610−
m mili 310−
k kilo 310
Hz Hertz (s-1)
A Amper
V Volt
s second
11.  INTRODUCTION
Switching Power Converters are the main building blocks of UPS, motor drives,
active filtering since efficiency and loss requirements dictate the control of power in a
switching mode. For all of these applications, high quality AC current tracking with
limited ripple is required.
In the Switching Power Converters, the modulation of the power flow between
the input side and output side is performed by switching matrix. This switching matrix
for the three-phase converters has six switches. The control input for switching power
converters is the positions of those switches as a function of time. The vector that has
the position information for the switches will be referred as switching vector.
The Pulse Width Modulation (PWM) is mostly used technique, that is varying
the duration of pulses with respect to magnitude, frequency or phase of  a voltage or
current, to form the average of  a given reference at the output.
In [1], an algeabraic synthesis for PWM methods, which can be the starting
point for every PWM method representation, is given. In the work, also, mentioned
PWM methods are compared in various aspects i.e harmonic content. It is apperant that
switching at a sufficiently high frequency with respect to the modulated function, the
ripple and Harmonic Distortion of AC currents can be reduced. But switching frequency
can not be increased arbitrarily. Because, first, the switching losses of semiconductor
devices increase proportional to the switching frequency. The converter switching losses
can be only reduced by the switching frequency of the converter. Second, the
regulations regarding electromagnetic compatibility (EMC) are stricter for power
conversion equipment operating at switching frequencies higher than 9 kHz [2]. Since
high frequency switching generates high frequency harmonics on the currents and
voltages, these high frequency harmonics of voltages and currents injected back into the
supply system, and coupled electromagnetically are function of the switching transition
2times and switching formats in the converter [3]. Third, switches for higher power rated
systems (Megawatt) should operate in low frequencies not to cause excessive losses.
Thus, converters should operate at a limited frequency as low as possible. The
switching algorithm chosen to meet the closed-loop specifications for the system,
should also end up with minimum switching actions, less Total Harmonic Distortion
(THD) and regularity in switching.
In [4-5-6-7], the Sliding Mode Control System design for Three Phase Power
converters is given. These researches reveal that both the PWM pattern selection and the
desired dynamical transients of the closed loop system can be solved together. The
scheme evaluates the system’s state and explores available control corresponding to the
system state.
In [8], keeping the Sliding Mode Approach, the evaluation of system state
together with the available controls are considered, and the selection is decided to
minimize the switching actions by minimizing the velocity of error.
In [9], which forms the basis of this work, keeping the Sliding Mode approach
for converters, the evaluation of controls corresponding to the system state together with
the minimization of a cost function, that is Instantaneous Total Harmonic Distortion, is
presented.
In [10], for a High-Power drive study, an optimal PWM is studied. Modulation
error caused by the conversion of a continuous reference signal into a discrete switching
sequence at low switching frequency is compensated by tracking controller which is
modifying the switching pattern in real time. Decomposition of the current vector
trajectory into its components enables the identification of the instantaneous
fundamental current, permitting the implementation of a fast current control system.
In [11], DSP based discrete-time integral-type optimal regulator (handling the
processor time lag) is considered for a robust control of an IM drive system composed
of a Boost Rectifier and an Inverter. To obtain higher control performance, a DC load
current is added from the Inverter side. Deviations in state variables cause stability
problems.
Generally, quality of switching control algorithms is determined by both proper
selection of switching vector and proper switching timing of switching vector.
Conventional tracking control algorithms (hysteresis comparator control, instantaneous
space vector control, sliding mode control etc.) may provide proper selection of
switching vector, but not proper switching timing since switching timing occurs only
3when the control error contacts pre-set hysteresis bounds. It is not reasonable since it
generates big harmonic distortion compared with carrier based algorithms and switching
frequency varies with different operation points [9].
This work aims to solve the problem of current control of 3~Phase Switching
Power Converters satisfying the followings at the same time for given specifications
• Better transient response
• Less ripple
• Less Harmonic Distortion
• Less losses in steady state operation
This work presents a current control scheme based on the work of Chen,
Sabanovic, and Ohnishi [9]. The solution is presented for the minimization of THD in
currents of 3~Phase switching power converters getting use of the unified description
for all 3~Phase switching power converters. This current control approach is based on
Sliding Mode Control with a unique correspondence between the state of the system and
switching configuration, and evaluates harmonic distortion in real time with
Instantaneous Total Harmonic distortion definition as a direct evaluation function.
Sliding Mode Control is suggested to have a robust performance against parameter
variations and load disturbances without stability problems. In sliding mode, the
trajectory of the system is constrained to move on a predetermined manifold in state
space. This is accomplished by designing a control law commutating at high frequency
among the different possible configurations. Sliding mode not only offers the parameter
insensitive features but also gives good system dynamic and static characteristics.
Because of the discontinuous control feature of Sliding Mode Control, the chattering
can occur in the control system.
Two switching vectors are selected sequentially in one control period according
to the error minimization theorem and timing is determined to minimize THD.
42.  FUNCTIONAL DESCRIPTION OF 3~PHASE SWITCHING POWER
CONVERTERS
2.1  Introduction
The role of the power converter, having matrix-like structure with three legs, is
the modulation of the electrical power flow between power sources, acting as a link.
Efficient modulation of power flow is realised using switches having zero voltage drop
when conducting, and fully blocks the current flow in cut-off region. Generic structure
of a 3~Phase Switching Power conversion system is shown in Figure 2.1 .
Rectifiers transform AC power into DC power, and Inverters transform DC
power into AC power. In Figure 2.2, the common structures for the switching converters
are depicted. These do not represent in any sense all of the 3-phase switching converters
but rather the structures with salient properties.
Due to the restriction of Kirchoff’s Circuit Law, the nature of sources at input
side and output side are different. The role of energy storing elements (L, C) is to
balance the power flow between source and sink by temporarily storage and release of
energy.
The control of power flow is done by varying the length of time intervals for
which the energy storing elements are connected to or disconnected from the energy
sources. The control input for these power converters, each having the same switching
matrix, is the positions of the switches.
5Figure 2.2 Common structures for Switching Power Converters
Switches are operated in such a way that the short circuit of the capacitors and
open circuit of the inductor currents are not permitted. These electrical circuit
constraints not only limit the number of permissible positions of the switches but also
define the number of independent controls, this number being less than the number of
switches.
INPUT
Side
dynamics
and
Sources
OUTPUT
Side
dynamics
and
Sources
RECTIFICATION
INVERSION
Figure 2.1 Structure of three-phase system
62.2  Definition of Control Vector (Switching Vector) U and Permissible Control
Vectors
Let, the vector U represents the states of the switches, which has six elements
corresponding to the each switch status (ON-OFF) in the switching matrix.
[ ]TswswswswswswU 654321      = where isw  (i=1,2…6) takes binary values from the set
{ }1,0 . The value 0 represents the OFF state of the corresponding switch, 1 represents the
ON state of the corresponding switch. When the electrical circuit constraints are
considered, control vector can be represented with 3 variables as [ ]TuuuU 321   =  where
iu (i=1,2,3) takes values from the set { }1,0,1−  for Buck Rectifier and Boost Inverter, and
iu (i=1,2,3) takes values from the set { }1,1− for Buck Inverter and Boost Rectifier. Each
component represents the status of the switches at the corresponding leg (each phase) of
the switching matrix according to the following:
• the value –1 represents that lower switch is ON, and upper switch is OFF in that leg,
• the value 0 represents that both switches are OFF in that leg,
• the value 1 represents that upper switch is ON and lower switch is OFF in that leg.
The representation of control vector with 3 components, each corresponding to
one phase in three-phase system is referred as representation in (abc) frames of
references. In the Table 1 and Table 2, the permissible states of the switches are
presented above converters.
For the Buck Inverter and the Boost Rectifier, the permissible number of control
vectors is 8. All these vectors can be represented with 3 components having values from
the set { }1,1 − .
7Table 1. Permissible connections for Boost Rectifier & Buck Inverter
Vector SW1 SW2 SW3 SW4 SW5 SW6
U1 ON OFF OFF OFF ON ON
U2 ON ON OFF OFF OFF ON
U3 OFF ON OFF ON OFF ON
U4 OFF ON ON ON OFF OFF
U5 OFF OFF ON ON ON OFF
U6 ON OFF ON OFF ON OFF
U7 ON ON ON OFF OFF OFF
U8 OFF OFF OFF ON ON ON
For the Boost Inverter and the Buck Rectifier the permissible number of control
vectors is 9. All these vectors can be represented with 3 components having values from
the set { }1,0,1 − .
Table 2. Permissible connections for Boost Inverter & Buck Rectifier
Vector SW1 SW2 SW3 SW4 SW5 SW6
U1 ON OFF OFF OFF OFF ON
U2 OFF ON OFF OFF OFF ON
U3 OFF ON OFF ON OFF OFF
U4 OFF OFF ON ON OFF OFF
U5 OFF OFF ON OFF ON OFF
U6 ON OFF OFF OFF ON OFF
U7 ON OFF OFF OFF ON OFF
U8 OFF ON OFF OFF ON OFF
U9 OFF OFF ON OFF OFF ON
82.3  Mathematical Model of 3~Phase Switching Power Converters
Derivation of the mathematical models of the switching power converters is out
of the scope of this work. Basically, symmetric, balanced three-phase system and ideal
switches are assumed. Following the steps at [14], mathematical descriptions of these
converters in phase frame, (abc) frames of references, are given in the proceeding parts.
2.3.1  Boost Rectifier Description in Phase (abc) Frame
Boost Rectifier circuit is shown in Figure 2.3. Its mathematical model in Phase
frame is as follows:
                                       
[ ]


 ++
−−=


 ++
−−=


 ++
−−=
−++=
32
.1
32
.1
32
.1
...
2
1
321
333
321
222
321
111
332211
uuu
u
L
V
V
L
i
dt
d
uuu
u
L
V
V
L
i
dt
d
uuu
u
L
V
V
L
i
dt
d
RC
V
uiuiui
C
V
dt
d
O
sL
O
sL
O
sL
O
LLLO
                         (2.1)
Where 




=
+
+
 ON is SW and OFF is SWwhen 1,-
OFF is SW and ON is SWwhen 1,
3ii
3ii
iu
Figure 2.3 Boost Rectifier
9is
V Denotes the 3 phase source voltages, defined as 


−−= )
3
2)1(cos(. πθ iVV rgis ,
where i=1,2,3
OV  Denotes the output voltage
R, L, C denotes the resistance, inductance, capacitance respectively.
iL
i Denotes the inductor currents where i=1,2,3
2.3.2  Buck Inverter Description in Phase (abc) Frame
Buck Inverter circuit is shown in Figure 2.4. Its mathematical model in Phase
frame is as follows:
                        
333
222
111
321
3
321
33
321
2
321
22
321
1
321
11
11
11
11
323
1
323
1
323
1
OLO
OLO
OLO
DCOOO
OL
DCOOO
OL
DCOOO
OL
V
RC
i
C
V
dt
d
V
RC
i
C
V
dt
d
V
RC
i
C
V
dt
d
uuuu
L
VVVVV
L
i
dt
d
uuuu
L
VVVVV
L
i
dt
d
uuuu
L
VVVVV
L
i
dt
d
−=
−=
−=


 ++
−−

 ++
−=


 ++
−−

 ++
−=


 ++
−−

 ++
−=
                (2.2)
Where 




=
+
+
 ON is SW and OFF is SWwhen 1,-
OFF is SW and ON is SWwhen 1,
3ii
3ii
iu
DCV  Denotes the DC voltage source,
R, L, C denotes the resistance, inductance, capacitance respectively.
iL
i Denotes the inductor currents where subscript i=1,2,3
OiV  Denotes the three-phase output voltages
where subscript i=1,2,3
10
2.3.3  Buck Rectifier Description in Phase (abc) Frame
Buck Rectifier circuit is shown in Figure 2.5. Its mathematical model in Phase
frame is as follows:
                                         
( )
RC
V
C
iV
dt
d
L
VuVuVuV
L
i
dt
d
OL
O
O
sssL
−=
−++= 332211 ...
1
                                (2.3)
Figure 2.4 Buck Inverter
Figure 2.5 Buck Rectifier
11
Where 






+
+
+
=
ON is 3iSW and OFF is iSWwhen 1,-
OFF is 3iSW and OFF is iSWwhen ,0
OFF is 3iSW and ON is iSWwhen 1,
iu
R, L, C denotes the resistance, inductance, capacitance respectively.
is
V Denotes the 3 phase source voltages defined as 


−−= )
3
2)1(cos(. πθ iVV rgis ,
where i=1,2,3
Li Denotes the inductor current
OV  Denotes the output voltage
2.3.4  Boost Inverter Description in Phase (abc) Frame
Boost Inverter circuit is shown in Figure 2.6. Its mathematical model in Phase
frame is as follows:
                                          
R
VVV
R
VuiV
dt
d
R
VVV
R
V
uiV
dt
d
R
VVV
R
V
uiV
dt
d
L
uVuVuV
L
V
i
dt
d
OOOO
LO
OOOO
LO
OOOO
LO
OOODC
L
3
3
3
3213
31
3212
21
3211
11
332211
++
+−=
++
+−=
++
+−=
++
−=
                           (2.4)
Where 






+
+
+
=
ON is 3iSW and OFF is iSWwhen 1,-
OFF is 3iSW and OFF is iSWwhen ,0
OFF is 3iSW and ON is iSWwhen 1,
iu
Li Denotes the inductor current
OiV  Denotes the three-phase output voltages where subscript i=1,2,3
R, L, C denotes the resistance, inductance, capacitance respectively.
12
2.3.5  Synchronously Rotating Frames of References (dq)
Leaning the AC side variables on basis vectors - CBA eee ,, , each shifted with
120°, forming the frame called as (abc) frames of references - the models in (abc)
frames of references has the control inputs coupled. So, control system design based on
those models is complicated. Transforming the variables and descriptions from (abc)
frames of reference to an orthogonal frame, called as ( )αβ  frame of reference,
horizontal axis (α ) collinear with phase A ( Ae ), will reduce the order, but still the
controls will be time varying. To solve the problem of controlling 3~Phase converters, it
is convenient to describe the dynamics of the switching converters in the orthogonal
frame of references, rotating synchronously related to the AC side of the converter
known as ( dq ) frames of references that serves the controls in the models both
decoupled and fixed.
For rectifiers d axis is collinear with the source voltage vector and for inverters
the d axis is collinear with the output reference vector. The q  axis is perpendicular to
the d axis.
The following matrices represent transformations between these frames for a
symmetric, balanced three-phase system.
From (abc) to ( )αβ  frame, the transformation is given by
                                                


−
−−
=
2/32/30
2/12/11
αβ
abcA                                        (2.5)
Figure 2.6 Boost Inverter
13
From ( )αβ  frame to ( dq ) frame, the transformation is given by
                                                   


−
=
rr
rrdqA
θθ
θθ
αβ cossin
sincos
                                          (2.6)
From (abc) to ( dq ) frame, the transformation is given by
a)
b)
Figure 2.7 Switching vectors a) for Boost Rectifier and Buck Inverter b) for
Boost Inverter and Buck Rectifier, in orthogonal frames of references (αβ ),
and illustration of Synchronously Rotating ( dq ) frames of references
14
                       








−−
−
−−
−
−
==
)
3
2sin( 
)
3
4cos(
)
3
2sin( 
)
3
2cos(
)sin(
)cos(
.
πθ
πθ
πθ
πθ
θ
θαβ
αβ
r
r
r
r
r
r
abc
dqdq
abc AAT                (2.7)
where rθ  is the angular position of the ( dq ) frame of references with respect to
orthogonal frame of references. trr .ωθ =  is the reference angular position and rω is the
reference angular velocity.
Three phase base vectors, control inputs in (abc) frames and ( )αβ  frames are
shown in Figure 2.7. Also ( dq ) frames of reference with respect to (abc) and ( )αβ
frames is shown in Figure 2.7.
2.3.6  Boost Rectifier Description in Synchronously Rotating (dq ) Frame
Boost Rectifier description in ( dq ) orthogonal frame of reference related to the
AC side is as follows:
                                             
q
O
LdrLq
d
ODC
LqrLd
qLqdLdOO
u
L
V
ii
dt
d
u
L
V
L
V
ii
dt
d
C
uiui
RC
V
dt
dV
2
.
2
.
2
..
−−=
−+=
+
+
−
=
ω
ω                                      (2.8)
where rω  is the angular velocity of the AC voltage sources, LqLd ii ,  are the components
of inductor current vector and qd uu ,  are the components of control vector, transformed
into (dq) frame.
15
2.3.7  Buck Inverter Description in Synchronously Rotating (dq ) Frame
Buck Inverter description in ( dq ) orthogonal frame of reference related to the
AC side is as follows:
                                          
q
DC
LdrOqLq
d
DC
LqrOdLd
LqOdrOqOq
LdOqrOdOd
u
L
V
iV
L
i
dt
d
u
L
V
iV
L
i
dt
d
i
C
VV
RC
V
dt
d
i
C
VV
RC
V
dt
d
2
.1
2
.1
1.1
1.1
+−
−
=
++
−
=
+−
−
=
++
−
=
ω
ω
ω
ω
                                  (2.9)
where rω is the angular velocity of the AC side voltage sources. LqLd ii ,  are the
components of inductor current vector, OqOd VV ,  are components of output voltage
vector and qd uu ,  are the components of control vector, transformed into (dq) frame.
2.3.8  Buck Rectifier Description in Synchronously Rotating (dq ) Frame
Buck Rectifier description in ( dq ) orthogonal frame of reference related to the
AC side is as follows:
                                                  
qLgq
dLgd
d
DCO
L
LO
O
uii
uii
u
L
V
L
Vi
dt
d
C
i
RC
V
V
dt
d
.
.
=
=
+−=
+−=
                                          (2.10)
16
where rω  is the angular velocity of the AC side voltage sources. gqgd ii ,  are the
components of current vector from the supply, qd uu ,  are the components of control
vector, transformed into (dq) frame.
2.3.9  Boost Inverter Description in Synchronously Rotating (dq ) Frame
Boost Inverter description in ( dq ) orthogonal frame of reference related to the
AC side is as follows:
                                          
L
Vu
L
V
u
L
Vi
dt
d
u
C
iV
RC
V
V
dt
d
u
C
iV
RC
V
V
dt
d
DC
q
Oq
d
Od
L
q
L
Odr
Oq
Oq
d
L
Oqr
Od
Od
+−−=
+−−=
++−=
ω
ω
                               (2.11)
where rω is the angular velocity of the AC side voltage outputs, OqOd VV ,  are
components of output voltage vector and qd uu ,  are the components of control vector,
transformed into (dq) frame.
2.3.10  General and Unified Description of 3~Phase Power Converters in
             Synchronously Rotating (dq ) Frame
In order to employ the same control approach for all 3~Phase switching power
converters, having the same switching matrix, a unified description is needed.
Considering (2.8), (2.9), (2.10), (2.11), general description of three-phase converters can
be expressed as:
17
                 
[ ] [ ] [ ]TTT    ,   ,  where
),(                                    ),(
)(),(                                       )(
ConvertersBoost For                                    ConvertersBuck For 
qdlqldqd
uiui
iviv
uuuiiivvv
uBivfi
dt
duBivfi
dt
d
iuBivfv
dt
diBvfv
dt
d
===
⋅+=⋅+=
⋅+=⋅+=
!!!
!!!!!!
!!!!!!
    (2.12)
Considering (2.12), it can be seen that output voltage is determined by the
currents, and currents are determined by the switching vectors. This enables the design
of the controller in two steps, namely the current control loop and voltage control loop
[7]. First control vector should be selected so that the current tracks its reference.
Second, the reference current should be selected so that the voltage tracks its reference.
Thus, designing the controller in ( dq ) frames of references is more convenient.
18
3.  CONTROL OF 3~PHASE SWITCHING POWER CONVERTERS
The control problem for 3~Phase switching power converter system is to find
the sequence and the duration of the ON and OFF states for switches so that the desired
dynamical specifications are met.
3.1  Sliding Mode Control of Switching Power Converters
Equations describing switching power converters have discontinuous right hand
side. In such a system sliding mode motion can result. Recalling equation (2.12), which
is also rewritten as (3.1), it is apparent that descriptions of the change of the current of
three-phase converters in (dq) frames of references are linear with respect to control
input.
                         For Buck Converters:        For Boost Converters
                              
uBivfi
dt
d
iBvfv
dt
d
ui
iv
!!!
!!!
⋅+=
⋅+=
),(
)(
         
uBivfi
dt
d
iuBivfv
dt
d
ui
iv
!!!
!!!
⋅+=
⋅+=
),(
)(),(
                   (3.1)
where [ ] [ ] [ ]TTT    ,   ,  qdqdqd uuuiiivvv === !!! .
In Sliding Mode Control, the goal is to force the system error to belong to the
predefined manifold in the state space. This manifold is usually defined with the set of
the linear or nonlinear functions called as sliding mode functions. In such a system so
called sliding mode may occur, exhibiting new type of the motion of the system. Thus,
the sliding mode existence conditions and the equations of motion in the sliding mode
19
should be derived in order to understand the benefits of establishing sliding mode
motion in the control system. As shown earlier the switching power converters are
described by the following model (2.12). For our explanations of the propertied of
behavior of the systems with sliding modes we will use a system defined by the
following equation:
                                                         uBtxfx !
!
"! .),( +=                                                   (3.2)
where [ ]Tqd  uuu =!  is the control-input vector, [ ]Tqd xxx  =! system state vector and
[ ]Tqd  fftxf =),(! is a continuous 1x2 vector valued function.
Assuming that the switching manifold is selected as
                                             }0)(),(:{ =−⋅== rxxGtxxS !!!! σ                                   (3.3)
where rx! is the reference vector corresponding to the desired output, and )/( xG !! ∂∂= σ
is a 2x2 matrix, with gradients of functions )(xiσ , can be regarded as gain.
To study the behavior of the system in sliding mode the projection of the system
in the sliding mode manifold should be derived first. For system (3.2), (3.3) this
projection has the form as in (3.4). In order to guarantee that system belongs to the
sliding manifold the origin of the system (3.4) should be stable and system state should
reach that origin from initial state The origin of (3.4) must be reachable in finite time.
From the above explanation the sliding mode may occur only in the origin of the system
(3.4) and it shall be treated as the stability in small. Contrarily, the reachibility should be
analyzed as the stability in large since the initial conditions for the system (3.2) may be
far away from the sliding manifold.
The motion of the system on the sliding mode manifold can be derived using the
so-called equivalent method. In this method, the control derived from the solution of the
equation 0=
= equu
!!
"!σ  is put back to the original equations and new set of the equations
with 0=σ!  represents the dynamical model that governs the behavior of the system in
the sliding mode. Assuming the matrix ( BG ⋅ ) has an inverse, equivalent control can be
derived as
20
                                    fGBGuuuGBfG eq
!!!!!"! .)(0 1−⋅−==⇒=+=σ                        (3.4)
From a geometrical viewpoint, the equivalent control means replacement of
discontinuous control in the intersection of switching surfaces by a continuous control
such that state velocity vector lies in the tangential manifold. Putting the equivalent
control, in other words, the average of the control, back in the equation results in the
motion of the system as equBxfx
!!"! .)( +=  and the velocity of error can be written as:
                                                          )( equuBG
#!"!
−⋅⋅=σ                                            (3.5)
Taking into account the changes in control, we see that, basically it has two
components: slow and fast components. The plant under control filters out the high
frequency changes and slow change determines the motion in the sliding mode. So, it is
reasonable to assume that equivalent control approximates to the slow component of
control and can be extracted using a low pass filter.
For the three-phase converters in order to have a better understanding of the
switching vector selection approach to be realized, first a conventional method called
Relay control will be explained and then presented control strategy will be described in
detail.
3.2 Relay Control Approach Vector Selection
For the system that has a uBf
dt
id !!
!
.+=  current loop dynamics, say the manifold
is selected as }0:{ =−== iiiS r
!!!
σ , and then choosing a positive definite Lypunov
function candidate as
                                                            2/σσν !! ⋅= T                                                    (3.6)
21
Its derivative becomes
                                             )( uBf
dt
id rTT !!
!
!"!!"
−−⋅=⋅= σσσν                                   (3.7)
So, if control is selected as
                                                         )(σ!
!! signHu ⋅−=                                                  (3.8)
where 


=
q
d
H
H
H
0
0!
, with  )( f
dt
idHB
r
TT !
!
!!!
+−⋅>⋅⋅ σσ , derivative of the
Lypunov function candidate becomes negative that means origin 0=σ  is stable.
Now having control as:
                                                   
)(.
     )(.
qqq
ddd
signHu
signHu
σ
σ
−=
−=
                                            (3.9)
in (dq) frames of reference, the back transformation can be of simply the projection to
the (abc) frame of references ensuring the signs which is [5]
                              
))
3
4sin(.)
3
4cos(.()(
))
3
2sin(.)
3
2cos(.()(
))sin(.)cos(.()(
3
2
1
πθπθ
πθπθ
θθ
−−−=
−−−=
−=
rqrd
rqrd
rqrd
uusignusign
uusignusign
uusignusign
                   (3.10)
This back transformation has some drawbacks. The calculated control in
)(σ!
!! signHu ⋅−=  is continuous, it has an amplitude and the direction data in it. But the
control specified in (3.10) does not have the corresponding amplitude data. In addition,
the exact direction data is not satisfied. Figure 3.1 illustrates the zone in which the
theoretical control should exist and applicable controls corresponding to the theoretical
control for a particular system state.
22
Timing of control, that is time instant that the control vector is changed to
another is determined whenever the error hits preset error bounds. As mentioned in the
introduction chapter, such a conventional tracking control algorithm may provide the
proper selection of switching vector but not the proper timing since switching timing
occurs only when the control error is contacted pre-set hysteresis bounds. This generates
big harmonic distortion, especially in low order harmonics.
Quality of the switching control algorithm is determined by both proper
selection of the switching vector and the proper switching timing. Such an approach has
been studied in [9], and we will use the basic idea of their study for the realization of the
current control loop.
The basic idea of the approach is to evaluate harmonic distortion in real time
with instantaneous THD definition and selects necessary sequence of the switching
determined according to the THD minimization theorem.
Theoretical control
lies within this zone
Applicable
controls in the
zone
Figure 3.1 Theoretical control and applicable controls
for Relay control scheme for a particular system state
23
3.3  Description of the THD Minimization Algorithm
This algorithm is applicable for the 3-phase converters current control loop and
is intended for discrete-time implementation. Basically, the algorithm calculates 2
vectors for each control period. One of them is targeted to minimize the tracking error at
the end of the control period while the other is targeted to improve Instantaneous Total
Harmonic Distortion. Thus, the algorithm evaluates harmonic distortion in real time
with instantaneous THD definition and sequentially selects two switching vectors in one
control period in order to minimize the tracking error and improve Instantaneous Total
Harmonic Distortion while timing of the second vector is determined according to the
THD minimization theorem.
Error in current is defined as a two-component vector
                                                               rii
!!!
−=σ                                                     (3.11)
where [ ]Tqd σσσ =! , [ ]TqdT iii =! , [ ]Trqrdr iii =! , and normalizing the time axis with
respect to converters switches switching interval T as:
                                                                  
T
t
=τ                                                       (3.12)
the motion of error in one control period can be written as in (3.13)
                                                        στστσ
!
"
!! .)0()( +=                                               (3.13)
24
Normalized
Time axis
k kT+T
Sampling
Instant
Time t
Sampling
Instant
0 τ
 T
τ
Measured error )0(σ!
Measured error
 )(kTσ!
Figure 3.2 Illustration of measurement instances both at real time axis
and normalized time axis and calling convention
In (3.13), )0(σ!  denotes the error at the begining of the switching interval and
[ ]Tqd σσσ ""!"  =  is the velocity of the error vector, assuming the applied vector at t=kT will
be fixed during the whole control period T. Real time axis and normalization of time
axis both with sampling instances are illustrated in Figure 3.2 .
Let iD
!
 be the displacement of the error from t=kT to t=kT+T corresponding to
ith  control vector which would be on the plant and fixed during the whole control
period. Thus it is defined as τσ  iiD
!
"
!
=  where iσ
!
"  is the velocity of the error
corresponding to the ith permissible switching vector. Note that σ
!
" is given by (3.5). The
relationship between the permissible switching vectors and velocity of error is shown in
Figure 3.3.
25
Figure 3.3 Illustration of derivative of error on the possible control vectors
Knowing the velocity of the error corresponding to a certain vector and the
initial error, final error,that is the error at the end of the control period, can be calculated
corresponding to that paticular control vector. In Figure 3.4, if a particular vector will be
applied to the plant, error at the end of the control period, that is )(τσ! , corresponding to
the switching vectors is shown .
26
The vector delivered to the plant at the beginning of every control period, at
t=kT (in normalized time 0=τ ), targeting to minimize the tracking error at the end of
the control period , at t=kT+T (in normalized time 1=τ ), will be referred as First
Vector - IU . The other vector, targeting minimizing the final error, too, to be delivered
to the plant within the control period (kT,kT+T) will be referred as Second vector -
IIU . Timing instant for the Second Vector targets to improve the Instantaneous THD.
Generally speaking, some timing instant in normalized time axis, for the second
vector will be referred as α . The optimal timing instant, in normalized time axis, which
minimizes the Instantaneous THD will be referred as optα .
Figure 3.4 Illustration of final errors corresponding to possible vectors for a
particular initial error
27
3.3.1  Selection of the First Vector
In the selection of the First vector, the main idea is, if the first vector is selected
during the full control period, the final error will be minimum. Final error
corresponding to ith control vector can be expressed as
                                                      iD
!!!
+= )0()( στσ                                              (3.14)
Thus, selection of first vector can be expressed as;
                                       First vector 





+= iiI DUU
!! )0(min   
i
σ                            (3.15)
Selection of First Vector, for an arbitrary initial error, is depicted in Figure 3.5.
Figure 3.5 Illustrattion of selection of first vector that causes
minimum final error
28
3.3.2  Selection of the Second Vector
In the selection of the second vector, the governing principle is if the First vector
IU  is selected and changed to second vector at some proper timing ατ = , final error,
( )τσ , will be nearest to zero.
Selection of Second Vector is illustrated in Figure 3.6. In the figure, two
displacement vectors corresponding to the selected vectors, for an arbitrary initial error
( )0σ! , are shown. If First vector would be applied during the whole control period, the
error would come to point K. If Second vector would be applied during the whole
control period, the error would come to point L. When the First Vector is applied to the
plant, the initial error ( )0σ!  will move along ID! . Before the movement is completed, in
other words within the control period, at some time, say time ατ = , if controller jumps
to the second vector, the error will move along the line that is parallel to IID
!
 and will
hit to the III DD
!!
−  at the end of the control period. Thus IIU  should be selected such
that the final error is minimum.
Figure 3.6 Selection of second the vector
K
L
29
Application of the First vector IU  between [ ]α,0  and then jumping to the
Second vector for the interval ( )1,α , in normalized time, is to be considered. Let ID!  be
the displacement of error within a control period corresponding to the selected first
vector. Since the final error will be on the vector Ii DD
!!
− , the closest point is the
intersection of the lines from origin to the Ii DD
!!
−  vector which results with the final
error
                                                     )sin(.)( θστσ I
!!
=                                               (3.16)
Thus the smaller the theta, the smaller the final error. Minimizing θ  means
minimization of the inner product of the following vectors that is expressed as;
                       Second vector ( ) ( ) 





−⋅+=   )0(  min  
i
Ii
T
IiII DDDUU
!!!!
σ             (3.17)
At the moment that First vector is selected, Second vector is selected, too.
3.3.3  Selection of Timing
The Selection of timing is determined according to THD minimization. Let IID
!
be the displacement of error during the whole control period corresponding to the
selected second vector if selected second vector would be applied to the plant during the
whole control period.
Intantaneous THD is defined as ττσζ d
21
0
)(∫= ! , and the value of α  minimizing ζ  is:
                                             
( ) ( )
( ) ( )IIITIII
III
T
IIopt
DDDD
DDD
!!!
!!!!
−⋅−
−⋅+
=
2
)0(2σ
α                               (3.18)
30
If the solution of optα  falls in 0 ~ 1, then two vectors will be selected during one
control period, otherwise, only one vector is selected that excludes useless switching
actions.
3.3.4  Obtaining Equivalent Control
Equivalent control is defined as the control, needed to keep the system on the
manifold if the system is on the manifold
                                                          fGBGueq
!!
⋅⋅⋅−=
−1)(                                     (3.19)
Equivalent control is used to determine the velocity of error as stated in (3.5), so
that the presented algorithm proceeds and selects the control vectors. When (3.19) is
considered, over f
!
, equivalent control is very dependent on the plant parameters. Not
only the change of parameters but also computation is problematic.
On the other hand, taking into account the equivalent control as the slow
frequency component of the control, it can be obtained by filtering the control such as
                                                         uuu eqeqLPF
!$"$
=+.τ                                               (3.20)
will converge to equivalent control. Here equ
$  is the approximated equivalent control.
3.3.5  Getting Use of Zero Vectors
There are 2 combination of the switches for Boost Rectifier and Buck Inverter,
and 3 vectors for Boost Inverter and Buck Rectifier that result in the zero control vector.
Since their values are the same, they cause the same error motion on the plant. Thus this
offers an option when a zero vector is selected by the algorithm. The realization of the
zero vector shall be selected in such a way that the number of the switches that should
change their state should be minimal.
31
For a Boost Rectifier or a Buck Inverter, application of a zero vector after vector
U3 - that is (-1, 1, -1) - would cause the following actions according to the preferred zero
vector.
If U8 is preferred, that is (-1,-1,-1),
• OFF the upper transistor of the phase b leg of the switching matrix
• ON the lower transistor of the phase b leg of the switching matrix
ends up with 2 actions.
On the other hand if U7 preferred, that is (1,1,1),
• ON the upper transistor of the phase a leg of the switching matrix
• OFF the lower transistor of the phase a leg of the switching matrix
• ON the upper transistor of the phase c leg of the switching matrix
• OFF the upper transistor of the phase c leg of the switching matrix
ends up with 4 actions.
Thus, preference of the zero vectors, taking into account the previous control
vector, reduces the number of switching actions. The look-up tables for zero vector
selection is shown in Table 3 and Table 4
Table 3. Zero vector look-up table to reduce the number of switching actions for Boost
Rectifier and Buck Inverter
Current Vector on the switching matrix Zero vector to be applied
U2 or U4 or U6 or U7 U7
U1 or U3 or U5  or U8 U8
Table 4. Zero vector look-up table to reduce the number of switching actions for Boost
Inverter and Buck Rectifier
Current Vector on the switching matrix Zero vector to be applied
U1 or U3 or U4 or U6 or U7 U7
U2 or U3 or U5 or U6 or U8 U8
U1 or U2 or U4 or U5 or U9 U9
32
4.  SIMULATION RESULTS
Simulations are performed on Boost Rectifier and Buck Inverter. AC current
control for these plants is simulated both with THD Minimization algorithm and Relay
Control Algorithm. Matlab/Simulink files for all the simulations are in Appendix-A.
Results, regarding the dynamic response, steady state ripple, number of switching at
steady state, Total harmonic distortion of phase currents, regularity of switching are
compared. Also, the Voltage controller is integrated to presented current control scheme
and completely controlled plant outputs are observed.
The Total Harmonic Distorsion in phase currents is measured according to
                                                           
1
2
2
R
R
THD
N
j
j∑
=
=                                                 (4.1)
where Rj is the RMS value of the jth harmonic and R1 is the RMS value of the
fundamental component of the AC side currents.
4.1  Boost Rectifier Simulation
System requirements for a well controlled three-phase Boost Rectifier are
• The output voltage should track its reference value refoV
• Input current should be sinusoidal
• The input current phase angle should trace its reference value 



=
−
ref
q
ref
dref
i
i1tanφ
33
Figure 4.1 Simulation of Current Loop of Boost Rectifier with THD
Minimization control scheme
Parmeters used in Boost Rectifier simulation are shown in Table 5.
Table 5 Parameters for Boost Rectifier
R
(Resistance)
L
(Inductance)
C
(Capacitance)
Vg
(Input Voltage
Amplitude)
ω
(Input Voltage
Frequency)
50 Ω 20 mH 700 µF 10 V 50 Hz
4.1.1  Simulation for Current Control with THD Minimization Algorithm for
          Boost Rectifier
Simulated system is shown in Figure 4.1. It consists of Boost Rectifier as plant
and current controller employing THD Minimization algorithm. Control inputs for the
Boost rectifier system is set as d component of current and input currents phase angle
that also determines the q component of current.
In this simulation, sampling period (T) is set to 50 µs. We inserted a
computational delay of 20 µs for the controller. Timing scheme used in this simulation
is shown in Figure 4.2.
34
Sampling instant kT
Time (t)
kT kT+T
Delivering control
corresponding to
 Sampling instant kT
Computational Delay
caused by the controller
Sampling instant kT+T
Figure 4.2 Timing scheme of the Boost Rectifier under THD Minimization
controller
Current references are given in ( )dq  frames of references as follows:
The q component of the current is controlled via refφ  which is set to 0° degrees until
time 0.1 seconds (t=0.1 s) to have unity power factor and then changed to 45° degrees. d
component of the current is set to 2.5 A until time 0.1 seconds and then changed to 3 A.
In Figure 4.3, reference currents, tracking of plant currents and the ripple are shown.
Ripple in currents is maximum 50 mA-pp.
35
0 0.1 0.2
2.4
2.6
2.8
3
a)    time [s]
[A]
idref
0 0.1 0.2
0
1
2
3
4
c)    time [s]
[A]
idref
id
0.18 0.19 0.2
2.9
2.95
3
3.05
e)    time [s]
[A]
idref
id
0 0.1 0.2
0
1
2
3
b)    time [s]
[A]
iqref
0 0.1 0.2
-1
0
1
2
3
4
d)    time [s]
[A]
iqref
iq
0.18 0.19 0.2
2.9
2.95
3
3.05
f)    time [s]
[A]
iqref
iq
Figure 4.3 a) Reference current d component reference b) Reference current q
component reference c) Tracking for d component d) Tracking for q component current
e) Ripple for d component f) Ripple for q component of currents in (dq) frame for Boost
Rectifier under THD Minimization control scheme
36
0.18 0.185 0.19 0.195 0.2
-4
-2
0
2
4
time [s]
[A
]
phase a current (ia)
modulation function
0.18 0.185 0.19 0.195 0.2
-4
-2
0
2
4
time [s]
[A
]
phase b current (ib)
modulation function
0.18 0.185 0.19 0.195 0.2
-4
-2
0
2
4
time [s]
[A
]
phase c current (ic)
modulation function
0 0.05 0.1 0.15 0.2
-10
-5
0
5
10
time [s]
[V
,A
]
Source Voltage Phase a
Phase a current (ia)
0 0.05 0.1 0.15 0.2
-10
-5
0
5
10
time [s]
[V
,A
]
Source Voltage Phase b
Phase b current (ib)
0 0.05 0.1 0.15 0.2
-10
-5
0
5
10
time [s]
[V
,A
]
Source Voltage Phase c
Phase c current (ic)
Figure 4.4 Input source voltages and
input currents for Boost Rectifier under
THD Minimization control scheme
Figure 4.5 Steady state input currents and
corresponding modulation functions for
one period of input voltage for Boost
Rectifier under THD Minimization control
scheme
In Figure 4.4, input source voltages and input currents are presented to show the
agreement of the change of the angle and the proper sinusoidal waveform of the
Currents. Since phase angle is changed from 0° degrees to 45° degrees at time 0.1 s, a
sharpe change in currents is observed at that instant. Before that time (t=0.1 s), voltages
and currents are in phase as asked, and then shifted for 45° degrees as asked, too.In
37
Figure 4.5, steady state waveforms of phase current and modulation function of
switches are presented for one period of input voltage.
In Figure 4.6, control vector in (αβ ) frames of references and the input currents
in (αβ ) frames are illustrated. Selection of control vectors is regular so higher
frequency harmonics and transients are avoided. Input currents shown in (αβ ) frame
also verifies the fast dynamic response and small ripple. In Table 6, Total hormanic
distortions for input currents are listed.
Table 6. Total harmonic distortions of the phase currents for 50 Hz fundamental Boost
Rectifier under THD Minimization controller
THD
Phase a 0.0086
Phase b 0.0085
Phase c 0.0082
Figure 4.6 a) Control vector shown in (αβ ) frames of references b) Input currents
shown in (αβ ) frames of references for Boost Rectifier under THD Minimization
control scheme
38
4.1.2  Simulation for Current Control with Relay Controller
This simulation is aimed to see the performance of Relay controller in terms of,
ripple of currents, dynamic response, Total Harmonic Distortion, regularity of
switching, controller parameters, hysteresis band width, discrete operation with
sampling period and carry out a comparison with the THD Minimization algorithm.
Simulated system is shown in Figure 4.7. It consists of Boost Rectifier as plant
and current controller employing Relay Control algorithm. Control inputs for the Boost
rectifier system is set as d component of current and input currents phase angle that also
determines the q component of current.
The ripple for presented algorithm is 50 mA-pp. The hysteresis band width is set
to ±0.05 A. To give the facility of same number of switchings, Sampling Period is set to
25 µs. In addition, no computational delay is employed for Relay Controller. Timing
scheme for this simulation is shown in Figure 4.8.
The same reference current profiles, required from the THD Minimization
controller, are asked, q component of the current is controlled via refφ  which is set to 0°
degrees until time 0.1 s (t=0.1 s) to have unity power factor and changed to 45° degrees.
Figure 4.7 Simulation of Current Loop of Boost Rectifier with Relay
Control
39
d component is set to 2.5 A and then changed to 3 A at time 0.1 s to illustrate the
transients.
In Figure 4.9, reference currents, tracking of plant currents and the ripple are
shown. Ripple in currents is 80 mA-pp. Although the relay band is set to 50 mA-pp, the
ripple is greater. If Relay Controller would have been operated in continuous time, it
would have sustained the ripple exactly the same value set by its hystresis band. The
deviation is caused by the discrete operation of the Relay Controller since it is not
designed for discrete-time operation.
Sampling instant kT
Time (t)
kT kT+T
Delivering control
corresponding to
 Sampling instant kT
Sampling instant kT+T
No computational delay
Figure 4.8 Timing scheme of the Relay Controller for Boost Rectifier
40
0 0.1 0.2
2.4
2.5
2.6
2.7
2.8
2.9
3
a)    time [s]
[A
]
idref
0 0.1 0.2
0
1
2
3
4
c)    time [s]
[A
]
idref
id
0.18 0.19 0.2
2.9
2.95
3
3.05
e)    time [s]
[A
]
idref
id
0 0.1 0.2
0
0.5
1
1.5
2
2.5
3
b)    time [s]
[A
]
iqref
0 0.1 0.2
-1
0
1
2
3
4
d)    time [s]
[A
]
iqref
iq
0.18 0.19 0.2
2.9
2.95
3
3.05
f)    time [s]
[A
]
iqref
iq
Figure 4.9 a) Reference current d component reference b) Reference current q
component reference c) Tracking for d component d) Tracking for q component current
e) Ripple for d component f) Ripple for q component of currents in (dq) frame for Boost
Rectifier under Relay control scheme
41
0.18 0.185 0.19 0.195 0.2
-4
-2
0
2
4
time [s]
[A]
phase a current (ia)
modulation function
0.18 0.185 0.19 0.195 0.2
-4
-2
0
2
4
time [s]
[A]
phase b current (ib)
modulation function
0.18 0.185 0.19 0.195 0.2
-4
-2
0
2
4
time [s]
[A]
phase c current (ic)
modulation function
0 0.05 0.1 0.15 0.2
-10
-5
0
5
10
time [s]
[V,
A]
Source Voltage Phase a
Phase a current (ia)
0 0.05 0.1 0.15 0.2
-10
-5
0
5
10
time [s]
[V,
A]
Source Voltage Phase b
Phase b current (ib)
0 0.05 0.1 0.15 0.2
-10
-5
0
5
10
time [s]
[V,
A]
Source Voltage Phase c
Phase c current (ic)
Figure 4.10 Input source voltages and
input currents for Boost Rectifier under
Relay control scheme
Figure 4.11 Steady state input currents and
corresponding modulation functions for
one period of input voltage for Boost
Rectifier under Relay control scheme
In Figure 4.10, input source voltages and input currents are presented to show
the agreement of the change of the angle and the proper sinusoidal waveform of the
currents.
In Figure 4.11, steady state waveforms of phase current and modulation function
of switches are presented. It is seen that number of switchings are greater than that of
THD Minimization algorithm.
42
In Figure 4.12, Modulation functions in (αβ ) frame and input currents are
shown in (αβ ) frames of references. Selected switching vectors are not regular that
causes undesired high frequency harmonics and transitions at the switches. In Table 7,
total hormanic distortions for input currents are listed.
Table 7. Total harmonic distortions of the phase currents for 50 Hz fundamental for
Boost Rectifier under Relay control scheme
THD
Phase a 0.013
Phase b 0.013
Phase c 0.013
Figure 4.12 a) Control vectors in (αβ ) frame b) Input currents in (αβ ) frame
for Boost Rectifier under Relay control scheme
43
4.1.3  Comparison of Relay Control Algorithm and THD Minimization
          Algorithm on Boost Rectifier
Current loop, with same reference current profiles, is simulated with both Relay
Control and THD Minimization control on Boost Rectifier. And results are summarized
as follows:
Table 8. Comparison of control algorithm performances for Boost Rectifier based on
simulation results
Relay Control THD Minimization Control
Sampling Period (T) 25 µs 50 µs
Computational Delay 0 s 20 µs
Ripple in currents ±40 mA ±25 mA
Settling time of currents
for the step change in
reference
2 ms 2 ms
Total Harmonic Distortion
at AC currents
0.013 0.0086
Regularity in switching No Yes
Number of switchings More Less
Computational Load Less More
From simulation results, one can easily conclude that, THD Minimization
algorithm is functioning correctly. Relay controller has functioned at, not only ideal
conditions ,in other words infinite computation speed, but also had the possibility of
higher frequency.
Although having more disadventageous conditions (but closer to real life
conditions), THD Minimization algorithm not only succeeds in minimization of Total
Harmonic Distorsion but also succeeds in better tracking performance with less number
of switching actions.
44
4.1.4 Voltage Control Design
Continuous nonlinear dynamical system,linear with respect to control
                              mutxutxBtxf
dt
dx ℜ∈ℜ∈+= ,x          ),().,(),( n                         (4.2)
where all elements of vector f and matrix B are continuous and bounded,and having
continuous and bounded first order time derivatives. Rank B(x,t)=m, ∀x,t>0 and all
components of control input u are bounded by known functions uimin and uimax . The aim
is to stabilize the system motion on the smooth manifold
                                           



∂
∂
===
x
txGtxxS σσ ),(;0),(:                                     (4.3)
where mℜ∈σ ,and all elements of G and
t∂
∂σ are continuous and bounded and rank
G=m, ∀x,t>0.
Selecting Lypunov function candidate in quadratic form
                                                             
2
.σσ
υ
T
=                                                        (4.4)
and putting its derivative into the following form:
                                                          σµσυ ..T
dt
d
−=                                                   (4.5)
where 0>µ , will lead to
                                   0,0... ≠∀=+⇒−= σµσσσµσσσ
dt
d
dt
d TT                           (4.6)
45
On the other hand, using the derivative of the error,
                                                      
t
BufG
dt
d
∂
∂
++=
σσ )(                                           (4.7)
one ends up with the following control input
                                    σµσ ..)(.)(),( 11 −− −


+
∂
∂
−= GBGf
t
GBtxu                             (4.8)
In continuous time control, if one can calculate and apply this control input to
the plant, system motion will move towards the manifold since Lypunov Asymptotic
stability conditions are satisfied.
The motion of the system on the manifold can be written using the so-called
equivalent control concept. Since equ  is the control needed to keep the motion in the
manifold if system states are in the manifold
                     )..()(0)( 1
t
fGGBu
t
BufG
dt
d
eqeq
uu eq ∂
∂
+−=⇒=
∂
∂
++= −
=
σσσ            (4.9)
So system motion equation on the manifold S is
                                                ),().,(),( txutxBtxf
dt
dx
eq+=                                     (4.10)
So that (4.8) can be organised as follows:
                                              ( ) µσ1)(,),( −−= GBtxutxu eq                                      (4.11)
Organising (4.7) and getting use of (4.9) one has
                                                         )( equuGBdt
d
−=
σ                                              (4.12)
46
which leads to write equivalent control as
                                                      
dt
dBGuueq
σ.).( 1−−=                                            (4.13)
If we assume that equ  does not change significantly within a control period, then
we can have the following approximation for (4.11) as
                                       ( ) )(..)()( 1 −−−+ −= kTGBkTukTu eq σµ                             (4.14)
which can be rewritten as
                               ( ))(.)(.)()()( 1 −−−−+ +−= kTkTGBkTukTu σµσ!                      (4.15)
and the following controller:
                        ( ))()()1(.)()()( 1 TkTkTTGBTkTukTu −−+−= −−+ σσµ               (4.16)
which is very convenient for discrete time realization.[14]
Adopting this idea to voltage control of Buck Converters is straightforward, but
adoption to Boost Converters needs more effort. Design for Boost Converters is worked
at [4].
For Boost Rectifier, assuming the currents are tracking their references, voltage
equation becomes
                             



+−⋅=+⋅
dt
id
dt
idLiV
R
V
dt
dVC refqrefdref
dDC
OO
2222 )()(
22
                    (4.17)
This equation can be rewritten as follows; assuming that voltage drop on
inductance is small leading to the neglection of the second term on the right hand side
47
                                                  refdDC
OO iV
R
V
dt
dVC
⋅=+⋅
22
2
                                         (4.18)
This subsystem model obeys to the format in (4.2) with the mapping xVO =
2  and
ui refd = . Thus ;
                 ( ))()()1()()()( 1 TkTkTTGBTTkTikTi refdrefd −−+−−= − σσµ          (4.20)
Since currents should be limited, the controller outputs should be bounded as
               ( ){ })()()1()()()( 1 TkTkTTGBTTkTisatkTi refdrefd −−+−−= − σσµ     (4.21)
where 
C
VB DC
2
=  and T is the sampling period for the controller.
And defining the manifold as
                     



=
∂
∂
==−=−== 1),(;0)(),(: 22
x
txGVVxxtxxS refOO
ref σσ           (4.22)
The controller design is completed. Stability issues and upper bound of the control
period for this discrete controller will not be discussed. Just the results at [13] will be
satisfied and be employed within the Voltage Loop.
48
4.1.5  Simulation of THD Minimization Algorithm Combined with Voltage
          Controller
Simulated system is shown in Figure 4.13. It consists of Boost Rectifier as plant and
current controller employing THD Minimization algorithm and voltage controller
mentioned in 4.1.4. Control inputs is set as Reference output voltage and input currents
phase angle that also determines the q component of current.
Voltage controller structure is out of this work’s scope. But for the sake of
completeness, the overview is expressed at section 4.1.4. Voltage controller is based on
the the extension of continuous Sliding Mode Control to discrete time [14].
In this simulation Voltage loop sampling period is set to 500 µs and current loop
sampling period is set to 50 µs. Computational delay is set to 25 µs.
Reference voltage is set to 28 V and changed to 30 V at time 0.2 s. Unity power factor is
aimed so the angle is set refφ =0. Asked voltage profile and response are shown in
Figure 4.14. Ripple at output voltage is ±0.06 Volts.
Figure 4.13 Simulation of Boost Rectifier, currents controlled with THD
Minimization scheme and voltage controlled by discrete time Sliding Mode Control
49
In Figure 4.15, input currents and input voltages are shown. They are in phase as
asked and currents are clear sinusoids in steady state.
0 0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4
23
24
25
26
27
28
29
30
31
32
33
time [s]
[V
]
Output Voltage
Figure 4.14 Boost rectifier output voltage, currents controlled with presented scheme
and voltage controlled by Discrete-Time Sliding Mode Control
In Figure 4.16, in a) control vectors applied to the plant during the simulation, in
b) currents in (αβ) frames and in c) phase a current and corresponding modulation
function are shown.
50
0 0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4
-10
-5
0
5
10
time [s]
[V,
A]
Source Voltage Phase
Phase a current
0 0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4
-10
-5
0
5
10
time [s]
[V,
A]
Source Voltage Phase
bPhase b current
0 0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4
-10
-5
0
5
10
time [s]
[V,
A]
Source Voltage Phase
Phase c current
Figure 4.15 Input source voltages and input currents for fully controlled Boost Rectifier
51
-2 -1 0 1 2
-2
-1.5
-1
-0.5
0
0.5
1
1.5
2
uα
u β
-3 -2 -1 0 1 2 3
-2.5
-2
-1.5
-1
-0.5
0
0.5
1
1.5
2
2.5
iα  [A]
i β 
[A
]
a) Control Vectors in ( )αβ  frame b) Currents in ( )αβ  frame
0.38 0.382 0.384 0.386 0.388 0.39 0.392 0.394 0.396 0.398 0.4
-1.5
-1
-0.5
0
0.5
1
1.5
time [s]
[A
]
Phase a current
Phase a modulation function
c)Phase a current and corresponding modulation function for one period of input voltage
Figure 4.16 a) Control vectors b) Currents c) Phase a Current and modulation function
for completely controlled Boost Rectifier
52
4.2 Buck Inverter Simulation
Since presented control algorithm is based on the unified description of all 3~Phase
Switching power converters, in this part, simulation on an Inverter type converter is
performed. on Buck Inverter, current control is simulated both with THD Minimization
control scheme and Relay control scheme. System requirements for a well controlled
three-phase Buck Inverter are:
• The output voltages should track their reference value, refoV , which are supposed to
have reference frequency and reference amplitude
• Output currents should be sinusoidal
Parmeters used in Buck Inverter simulation are shown in Table 5.
Table 9. Parameters used in Buck Inverter simulation
R
(Resistance)
L
(Inductance)
C
(Capacitance)
Vg
(Input Source
Voltage)
ω
(Output Voltages
reference Frequency)
7 Ω 40 mH 30 µF 300 V 50 Hz
4.2.1 Simulation for Current Control with THD Minimization Algorithm for Buck
         Inverter
In this simulation, Buck Inverter is simulated with THD Minimization current
control scheme. Simulated structure is shown in Figure 4.17. Sampling period of the
controller is taken as 50 µs and, since the controller is the same, computational delay of
20 µs is reused. Timing scheme used in the simulation is the same as shown in Figure
4.2.
Control inputs for the Buck Inverter system are current references and are set as
follows: Until time t=0.2 s, d component is set to 3 A. And q component is set to 0 A.
Afterwards, d component is set to 0 A and q component is set to 3 A.
In Figure 4.18 a) and b), reference currents in c) and d) actual currents are shown
in (dq) frame. Current settling time 1 ms, and peak to peak ripple is 350 mA.
53
0 0.2 0.4
-1
0
1
2
3
4
a)  time[s]
[A
]
idref
0 0.2 0.4
-1
0
1
2
3
4
c)  time[s]
[A
]
idref
id
0.18 0.19 0.2
2.6
2.8
3
3.2
e)  time[s]
[A
]
idref
id
0 0.2 0.4
-1
0
1
2
3
4
b)  time [s]
[A
]
iqref
0 0.2 0.4
-1
0
1
2
3
4
d)  time[s]
[A
]
iqref
iq
0.18 0.19 0.2
-0.4
-0.2
0
0.2
0.4
f)  time[s]
[A
]
iqref
iq
Figure 4.18 a) Reference current d component reference b) Reference current q
component reference c) Tracking for d component d) Tracking for q component current
e) Ripple for d component f) Ripple for q component of currents in (dq) frame for Buck
Inverter under presented control scheme
Settling time for currents is 0.8 ms. Total Harmonic Distortion of the currents is
measured as 0.036.
Figure 4.17 Simulation of Current Loop of Buck Inverter
with THD Minimization Control scheme
54
In Figure 4.19, phase currents and voltages are illustrated. They are always in
phase since active load is used.
0 0.1 0.2 0.3 0.4
-20
-10
0
10
20
time [s]
[V
,A
]
Phase a Voltage
Phase a current
0 0.1 0.2 0.3 0.4
-20
-10
0
10
20
time [s]
[V
,A
]
Phase b Voltage
Phase b current
0 0.1 0.2 0.3 0.4
-20
-10
0
10
20
time [s]
[V
,A
]
Phase c Voltage
Phase c current
0.18 0.185 0.19 0.195 0.2
-4
-2
0
2
4
time [s]
[A
]
phase a current (ia)
modulation function
0.18 0.185 0.19 0.195 0.2
-4
-2
0
2
4
time [s]
[A
]
phase b current (ib)
modulation function
0.18 0.185 0.19 0.195 0.2
-4
-2
0
2
4
time [s]
[A
]
phase c current (ic)
modulation function
Figure 4.19 Input source voltages and
input currents for Buck Inverter under
THD Minimization control scheme
Figure 4.20 Steady state input currents and
corresponding modulation functions for
one period of output voltages for Buck
Inverter under THD Minimization control
scheme
In Figure 4.20, phase currents are corresponding modulation functions in steady state
for one period of input voltage are shown. In Figure 4.21, input currents are shown in
(αβ ) frames of references.
55
4.2.2  Simulation for Current Control with Relay Controller
This simulation aims to see the performance of Relay controller, ripple of
currents, dynamic response, Total Harmonic Distortion, regularity of switching,
controller parameters, hysteresis band width, discrete operation with sampling period
and carry out a comparison with the THD Minimization algorithm.
Simulated system is shown in Figure 4.22. It consists of Buck Inverter as plant
and current controller employing Relay Control algorithm. Control inputs for the Buck
Inverter system is set as d and q components of currents and reference frequency for
output voltages.
To give the facility of same number of switchings, sampling period is set to 25
µs. In addition, no computational delay is employed for Relay Controller. Timing
scheme for this simulation is as the same shown in Figure 4.8.
Figure 4.21 Input currents shown in (αβ ) frames of references
for Buck Inverter under THD Minimization control scheme
56
0 0.1 0.2
-1
0
1
2
3
4
time [s]
[A
]
idref
0 0.1 0.2
-1
0
1
2
3
4
time [s]
[A
]
idref
id
0.18 0.19 0.2
-0.4
-0.2
0
0.2
0.4
time [s]
[A
]
idref
id
0 0.1 0.2
-1
0
1
2
3
4
time [s]
[A
]
iqref
0 0.1 0.2
-1
0
1
2
3
4
time [s]
[A
]
iqref
iq
0.18 0.19 0.2
2.6
2.8
3
3.2
time [s]
[A
]
iqref
iq
Figure 4.23 Tracking and transients of plant currents in d-q frame for Buck Inverter
under Relay control scheme
The same reference current profiles, required from the presented controller, are
asked, that is, until time 0.2 s (t=0.2 s.), d component is set to 3 A. and q component is
set to 0 A. Afterwards, d component is set to 0A and q component is set to 3 A. (Figure
4.23)
Figure 4.22 Simulation of Buck Inverter, currents controlled with
Relay Controller
57
Figure 4.24 Output Phase voltages and
output currents for Buck Inverter under
Relay control scheme
Figure 4.25 Steady state phase currents
and corresponding modulation functions
for one period of output voltages for Buck
Inverter under Relay control scheme
The hysteresis band width is set to ±0.05 A to have ripple as small as possible,
since simple Relay controller operating in discrete time can not avoid ripple extending
the hysteresis band. Employing too narrow hysteresis band to avoid excessive ripple
causes over-switching.
In Figure 4.23, (dq) reference and actual currents are illustrated and observed
that ripple in currents is 450 mA peak-to-peak. Settling time for currents is 1 ms.
In Figure 4.24, output voltages and phase currents are shown. Total Harmonic
distortion of the currents are measured as 0.08.
In Figure 4.25, phase currents and corresponding modulation functions for one
period of output voltage is shown. The switching frequency is greater than the situation
for presented algorithm, which is shown in Figure 4.20.
58
In Figure 4.26 currents are shown in (αβ ) frames of references. The amount of
ripple and deviation of the system state from the reference is observed clearly when
compared with the motion obtained with the THD Minimization algorithm (Figure
4.21).
Figure 4.26 Phase currents shown in (αβ ) frames of
references for Buck Inverter under Relay control
59
4.2.3  Comparison of Relay Control Algorithm and THD Minimization Algorithm
          on Buck Inverter
Current loop, with same reference current profiles, is simulated with both Relay Control
and THD Minimization control on Buck Inverter. Results are summarized as follows:
Table 10. Comparison of control algorithm performances for Buck Inverter based on
simulation results
Relay Control THD Minimization Control
Sampling Period (T) 25 µs 50 µs
Computational Delay 0 s 20 µs
Ripple in currents ±225 mA ±175 mA
Settling time of currents
for the step change in
reference
1 ms 0.8 ms
Total Harmonic Distortion
at AC currents
0.08 0.0036
Regularity in switching No Yes
Number of switchings More Less
Computational Load Less More
From simulation results, one can easily conclude that, THD Minimization
algorithm is functioning correctly. Relay controller has functioned at, not only ideal
conditions ,in other words infinite computation speed, but also had the possibility of
higher frequency.
Although having more disadventageous conditions (but closer to real life
conditions), presented algorithm not only succeeds in minimization of Total Harmonic
Distorsion but also succeeds in better tracking performance with less number of
switching actions.
60
5.  CONCLUSIONS
In this work, a discrete current control scheme is defined for all 3~Phase
Switching Power Converters and 3~Phase Electrical machines and verified by
simulation.
The presented algorithm is outputting the switching patterns for the switching
matrix and is designed to minimize the Instantaneous Total Harmonic Distortion in AC
currents.
The algorithm evaluates harmonic distortion in real time with calculation of the
instantaneous THD and sequentially selects two switching vectors in one control period
in order to minimize the tracking error and timing is determined according to the THD
minimization requirements.
Simulation results show that presented method has good performance in the
minimization of Total Harmonic Distortion and in current tracking. It has much better
dynamic response with less number of switching actions compared with the basic
Sliding Mode scheme.
The simulation results are very encouraging, and confirm the theoretical results,
further work shall be concentrated on the validation of the algorithm with experiments.
61
APPENDIX A
62
APPENDIX B
APPENDIX B.1
BOOST RECTIFIER CURRENT CONTROL WITH RELAY CONTROLLER
Simulink Model File: \Relay_Boost_Inner\ Relay_Boost_Inner.mdl
Parameter M file: \ Relay_Boost_Inner\RelayBoostInner.m
%Parameters file to be used with Boost Rectifier
%controlled with RELAY CONTROLLER
%Source parameters
ws=2*pi*50;%source voltage angular frequency[rad/sec]
3~Phase BOOST RECTIFIER
CURRENT LOOP CONTROLLER-RELAY CONTROLLER
to set the parameters,double click the block below with shadowed border
to change the parameters see the file RelayBoostInner.m
Originator:Murat GUNAY
Status:OK
Date:25 April 2002
vs3
vs3
vs2
vs2
vs1
vs1
u3
u3
u2
u2
u1
u1
3~input
3~refinput
d
q
observation
purposes 
iqref
iqref
iqr
iq
iq
idref
idref
idr
id and iq
id
id
i3
i3
i2
i2
i123
i1
i1
Terminator
3~Vs
3~i
idref
iqref
u123
Relay Controller
Double Click here
to set the Parameters
emu
emu
emu
emu
Vs123
u123
i123
Vo
Boost Rectifier
VS
3~voltage
source
63
Vg=10;  %Source Voltage amplitude
%Plant parameters
R=50; %Resistance [ohms]
L=0.02; %Inductance [Henry]
C=0.0007; %Capacitor [Farads]
IPMAX=50; %max current that plant can allow
IPMIN=-50; %min current that plant can allow
VOPMAX=100; %max voltage that plant can allow
VOPMIN=0;  %min voltage that plant can allow
VO_0=25;    %initial value of the output voltage
I1_0=0;   %initial value of the plant phase a current
I2_0=0;   %initial value of the plant phase b current
I3_0=0;  %initial value of the plant phase c current
%Relay controller parameters
TS_c=25e-6;  %Sampling Period of current loop
bound=0.05;%hystrezis bound --> +-bound
64
APPENDIX B.2
BOOST RECTIFIER CURRENT CONTROL WITH THD MINIMIZATION
ALGORITHM
Simulink Model File:\Thd_Boost_Inner\ Thd_Boost_Inner.mdl
Parameter M file: \ThdBoostInner.m
%Parameters file to be used with Boost Rectifier
%controlled with THD MinimizationController
ws=2*pi*50;%source voltage angular frequency[rad/sec]
Vg=10;     %Source Voltage amplitude[V]
3~Phase BOOST RECTIFIER
CURRENT LOOP CONTROLLER-THD MINIMIZATION CONTROLLER
to set the parameters,double click the block below with shadowed border
to change the parameters see the file ThdBoostInner.m
Originator:Murat GUNAY
Status:OK
Date:25 Apri l 2002
vs3
vs3
vs2
vs2
vs1
vs1
u3
u3
u2
u2
u1
u1
3~input
3~refinput
d
q
observation
purposes
iqref
iqref
iq
iq
idref
idref
id and iq
id
id
i3
i3
i2
i2
i123
i1
i1
Vo
Output votage
idref
iqref
Vs123
i123
Vo
u123
Thd_Controller
IQREF
IDREF
Double Click here
to set the Parameters
emu
emu
emu
emu
Vs123
u123
i123
Vo
Boost Rectifier
VS
3~voltage
source
65
%Plant parameters
R=50;       %Resistance [ohms]
L=0.02;     %Inductance [Henry]
C=0.0007;   %Capacitor [Farads]
IPMAX=50;   %max current that plant can allow
IPMIN=-50;  %min current that plant can allow
VOPMAX=100; %max voltage that plant can allow
VOPMIN=0;   %min voltage that plant can allow
VO_0=25;    %initial value of the output voltage
I1_0=0;     %initial value of the plant phase a current
I2_0=0;     %initial value of the plant phase b current
I3_0=0;     %initial value of the plant phase c current
%Presented controller parameters
TS_c=50e-6;   %Sampling Period of current loop
Compdel=20e-6;%computational delay
%filter parameter
wc=2*pi*20;%filter corner angular frequency
S-function file: \Thd_Boost_Inner\thdfboost.c
/*=============================================================
==*/
#define S_FUNCTION_LEVEL 2
#define S_FUNCTION_NAME thdfboost
#include "simstruc.h"
#include "math.h"
#define Rx *mxGetPr(ssGetSFcnParam(S,0))   /*first parameter */
#define Lx *mxGetPr(ssGetSFcnParam(S,1))   /*second parameter*/
#define Cx *mxGetPr(ssGetSFcnParam(S,2))   /*third parameter */
#define Ts *mxGetPr(ssGetSFcnParam(S,3))   /*fourth parameter*/
#define cdel *mxGetPr(ssGetSFcnParam(S,4)) /*fifth parameter */
66
/*Friendly access to inputs to S fcn block*/
#define U(element) (*uPtrs[element])
/*************************************************************/
/*                     mdlInitializeSizes                    */
/*************************************************************/
static void mdlInitializeSizes(SimStruct *S)
{
    ssSetNumContStates(S,0);
    ssSetNumDiscStates(S,0);
    if (!ssSetNumInputPorts(S,1)) return;
    ssSetInputPortWidth(S,0,13);                /*input number*/
    ssSetInputPortDirectFeedThrough(S,0,0);
    if (!ssSetNumOutputPorts(S,1)) return;
    ssSetOutputPortWidth(S,0,12);              /*output number*/
    ssSetNumSampleTimes(S,1);
    ssSetNumSFcnParams(S,5);          /*S Fcn parameter number*/
    ssSetNumRWork(S,0);
    ssSetNumIWork(S,0);
    ssSetNumPWork(S,0);
    ssSetNumModes(S,0);
    ssSetNumNonsampledZCs(S,0);
    ssSetOptions(S, SS_OPTION_EXCEPTION_FREE_CODE);
}
/*************************************************************/
/*                mdlInitializeSampleTimes                   */
/*************************************************************/
static void mdlInitializeSampleTimes(SimStruct *S)
{
    ssSetSampleTime(S,0,CONTINUOUS_SAMPLE_TIME);
    ssSetOffsetTime(S,0,0.0);
}
67
/*************************************************************/
/*                        mdlOutputs                         */
/*************************************************************/
static void mdlOutputs(SimStruct *S,int_T tid)
{
    InputRealPtrsType uPtrs = ssGetInputPortRealSignalPtrs(S,0);
    real_T            *y    = ssGetOutputPortRealSignal(S,0);
    int birindex=7;    /*index of the first vector selected */
    int ikiindex=7;    /*index of the second vector selexted*/
    float alpha;       /*timing parameter*/
    int myflag=1;int k;int i;
    float Udq[8][2];     /*Declaration for Udq (Array to store the representations of the
switching vectors in d-q frame)         */
    float Pdq[8][2];     /*Declaration for Pdq (Array to store the velocities of the error
corresponding to the switching vectors)*/
    float Ddq[8][2];     /*Declaration for Ddq (Array to store the d-q distances
conrresponding to the swictching vectors)        */
    float canfI[8];      /*Declaration for canfI (Array to store the candidates for the
selection of Fisrt Vector)                */
    float canfII[8];
    float dummy_min;         /*Declaration for dummy_min (Temporary placeholder for
instantenous min of the candidates)*/
    float pay;float payda;   /*Declaration for pay payda (Note that alpha=pay/payda)*/
    float Valfa;float Vbeta; /*Declaration for Valfa Vbeta*/
    float id;float iq;       /*Declaration for id iq*/
    float sigmad;float sigmaq;       /*Declaration for sigmad sigmaq */
    float u1I;float u2I;float u3I;   /*Declaration for u1 u2 u3 related to First Vector*/
    float u1II;float u2II;float u3II;/*Declaration for u1 u2 u3 related to Second Vector*/
    float udI;float uqI;             /*Declaration for ud uq related to First Vector*/
    float udII;float uqII;           /*Declaration for ud uq related to Second Vector*/
    /* S w i t c h i n g   v e c t o r s  in  abc  f r a m e */
68
    static int SW[8][3]={{1,-1,-1},{1,1,-1},{-1,1,-1},{-1,1,1},{-1,-1,1},{1,-
1,1},{1,1,1},{-1,-1,-1}};
    int sonvec=7;      /*index of the last vector applied to the plant */
    float saat=U(0);   /*real time info  */
    /* s u b s t u t i n g  i n p u t s */
    float idref=U(1);float iqref=U(2);float i1=U(3);float i2=U(4);float i3=U(5);float
Vo=U(6);
    float udeq=U(7);float uqeq=U(8);float nT=U(9);float V1=U(10);float V2=U(11);float
V3=U(12);
    float theta;float GB;float dis1=cdel;float dis2=0;
    float pred_d=0;float pred_q=0;/*prediction term for latency*/
    if(saat==nT)     /*------------ s a m p l i n g      i n s t a n t ------------*/
    {
        Valfa=V1-0.5*V2-0.5*V3;       /*transformation of source voltages  */
        Vbeta=0.5*sqrt(3)*(V2-V3);    /*into othgononal alpha-beta frame  */
        theta=atan2(Vbeta,Valfa);     /*and determining theta                   */
        id=(i1-0.5*i2-0.5*i3)*cos(theta)+(0.5*sqrt(3)*(i2-i3))*sin(theta);
/*Transformation of measured currents*/
        iq=(i1-0.5*i2-0.5*i3)*(-sin(theta))+(0.5*sqrt(3)*(i2-i3))*cos(theta); /*into the d-q
frame using theta info   */
        sigmad=pred_d+id-idref;       /*Since we have plant currents in d-q frame and
reference currents coming from voltage controller        */
        sigmaq=pred_q+iq-iqref;       /*we can determine the error in currents and add
some prediction term to compansate the computation delay*/
        GB=-Vo/(2*Lx);                /*Calculation of GB parameter,effecting the velocity of
error  */
        for(i=0;i<=7;i++)             /*Transformation of switching vectors into d-q frame  */
    {
    Udq[i][0]=(SW[i][0]-0.5*SW[i][1]-
0.5*SW[i][2])*cos(theta)+sqrt(3)*0.5*(SW[i][1]-SW[i][2])*sin(theta);
69
    Udq[i][1]=(SW[i][0]-0.5*SW[i][1]-0.5*SW[i][2])*(-
sin(theta))+sqrt(3)*0.5*(SW[i][1]-SW[i][2])*cos(theta);
    }
    for(i=0;i<=7;i++)
    {
    Pdq[i][0]=GB*(Udq[i][0]-udeq);
    Pdq[i][1]=GB*(Udq[i][1]-uqeq);
    }
    for(i=0;i<=7;i++)
    {
    Ddq[i][0]=Pdq[i][0]*Ts;
    Ddq[i][1]=Pdq[i][1]*Ts;
    }
    for(i=0;i<=7;i++)
    {                  
    canfI[i]=sqrt(
(sigmad+Ddq[i][0])*(sigmad+Ddq[i][0])+(sigmaq+Ddq[i][1])*(sigmaq+Ddq[i][1]) );
    }                               
    dummy_min=canfI[0];
k=0;
for(i=1;i<=7;i++)
{
if(dummy_min>canfI[i])
    {
dummy_min=canfI[i];
k=i;
}
}                      
if((k==6) || (k==7))
{
if((sonvec==7) || (sonvec==4) || (sonvec==2) ||
(sonvec==0)){k=7;}
else{k=6;}
}
70
birindex=k;
for(i=0;i<=7;i++)
{
canfII[i]=sqrt( (sigmad + Ddq[birindex][0])* (Ddq[i][0]-
Ddq[birindex][0]) + (sigmaq+Ddq[birindex][1])*(Ddq[i][1]-Ddq[birindex][1]) );
/*        SQRT( (sigma_d+DId)              *(Di_d-DId)                    +
(sigma_q+DI_q)           *(Di_q-DI_q) )                  */
}             
dummy_min=canfII[0];
k=0;
for(i=1;i<=7;i++)
{
if(dummy_min>canfII[i])
    {
dummy_min=canfII[i];
k=i;
}
    }                       
    if((k==6) || (k==7))
{
if( (birindex==7) || (birindex==4) || (birindex==2) ||
(birindex==0)){k=7;}/*optimization for zero vector */
else{k=6;}
}
ikiindex=k;
/*****************************Calculation of
ALPHA****************************************************************
******************************************/
payda=(Ddq[ikiindex][0]-2*Ddq[birindex][0])*(Ddq[ikiindex][0]-
Ddq[birindex][0]) + (Ddq[ikiindex][1]-2*Ddq[birindex][1])*(Ddq[ikiindex][1]-
Ddq[birindex][1]);
/*    (DIId-2*DId)                         *(DIId-DId)                          + (DIIq-
2*DIq)                         *(DIIq-DIq)                         */
71
pay=(Ddq[ikiindex][0]+2*sigmad)*(Ddq[ikiindex][0]-Ddq[birindex][0])
+ (Ddq[ikiindex][1]+2*sigmaq)*(Ddq[ikiindex][1]-Ddq[birindex][1]);
/*  (DII_d+2*sigma_d)           *(DII_d-DI_d)                     +
(DII_q+2*sigma_q)           *(DII_q-DI_q)     */
alpha=pay/(payda+0.000001);
if(alpha>=0.9||alpha<=0.2)
{   alpha=1000;
    sonvec=birindex;
    dis1=cdel;
    dis2=0;                                  
    myflag=0; }
else
{   myflag=1;
    sonvec=ikiindex;
    dis1=0;
    dis2=cdel;
}
pred_d=Pdq[birindex][0]*dis1+Pdq[ikiindex][0]*dis2; /*Predictions for
d and q components */
pred_q=Pdq[birindex][1]*dis1+Pdq[ikiindex][1]*dis2; /*Predictions for
d and q components */
udI=Udq[birindex][0];uqI=Udq[birindex][1];
udII=Udq[ikiindex][0];uqII=Udq[ikiindex][1];
u1I=SW[birindex][0];u2I=SW[birindex][1];u3I=SW[birindex][2];
/*output Variables are ok */
u1II=SW[ikiindex][0];u2II=SW[ikiindex][1];u3II=SW[ikiindex][2];
/*output Variables are ok */
/*outputs are posted*/
y[0]=u1I;y[1]=u2I;y[2]=u3I;y[3]=udI;y[4]=uqI;    /*First vector related
vars*/
y[5]=u1II;y[6]=u2II;y[7]=u3II;y[8]=udII;y[9]=uqII;/*Second vector
related vars*/
y[10]=alpha;/*timing info*/
y[11]=myflag;
72
}/**************************************************END OF
SAMPLING INSTANT*******************/
}
/**************************************************************/
/*                       mdlTerminate                         */
/**************************************************************/
/* Function: mdlTerminate
 * Abstract:
 *    No termination needed, but we are required to have this routine.
 */
static void mdlTerminate(SimStruct *S)
{
}
#ifdef  MATLAB_MEX_FILE    /* Is this file being compiled as a MEX-file? */
#include "simulink.c"      /* MEX-file interface mechanism */
#else
#include "cg_sfun.h"       /* Code generation registration function */
#endif
S-function file: S-function file: \Thd_Boost_Inner\myalfa.c
#define S_FUNCTION_LEVEL 2
#define S_FUNCTION_NAME myalfa
#include "simstruc.h"
#include "math.h"
#define Tp *mxGetPr(ssGetSFcnParam(S,0))   /*Sampling Period*/
#define cdel *mxGetPr(ssGetSFcnParam(S,1)) /*Computation delay*/
#define U(element) (*uPtrs[element])       /*Friendly access to inputs to S fcn block*/
/*************************************************************/
/*                     mdlInitializeSizes                    */
73
/*************************************************************/
static void mdlInitializeSizes(SimStruct *S)
{
    ssSetNumContStates(S,0);
    ssSetNumDiscStates(S,0);
    if (!ssSetNumInputPorts(S,1)) return;
    ssSetInputPortWidth(S,0,4);                /*input number*/
    ssSetInputPortDirectFeedThrough(S,0,0);
    if (!ssSetNumOutputPorts(S,1)) return;
    ssSetOutputPortWidth(S,0,1);              /*output number*/
    ssSetNumSampleTimes(S,1);
    ssSetNumSFcnParams(S,2);         /*S Fcn parameter number*/
    ssSetNumRWork(S,0);
    ssSetNumIWork(S,0);
    ssSetNumPWork(S,0);
    ssSetNumModes(S,0);
    ssSetNumNonsampledZCs(S,0);
    ssSetOptions(S, SS_OPTION_EXCEPTION_FREE_CODE);
}
/*************************************************************/
/*                mdlInitializeSampleTimes                    */
/*************************************************************/
static void mdlInitializeSampleTimes(SimStruct *S)
{
    ssSetSampleTime(S,0,CONTINUOUS_SAMPLE_TIME);
    ssSetOffsetTime(S,0,0.0);
}
/*************************************************************/
/*                        mdlOutputs                         */
/*************************************************************/
static void mdlOutputs(SimStruct *S,int_T tid)
{
    InputRealPtrsType uPtrs = ssGetInputPortRealSignalPtrs(S,0);
    real_T            *y    = ssGetOutputPortRealSignal(S,0);
74
    float enb=U(0);float clkreal=U(1);float kT=U(2);float incalpha=U(3);
    if(enb==1)
    {
        if(clkreal>=(kT+incalpha*Tp))
            {y[0]=0;}
        else{y[0]=1;}
    }
    else
    {
    y[0]=1;
    }
}
/**************************************************************/
/*                       mdlTerminate                         */
/**************************************************************/
/* Function: mdlTerminate
 * Abstract:
 *    No termination needed, but we are required to have this routine.
 */
static void mdlTerminate(SimStruct *S)
{
}
#ifdef  MATLAB_MEX_FILE    /* Is this file being compiled as a MEX-file? */
#include "simulink.c"      /* MEX-file interface mechanism */
#else
#include "cg_sfun.h"       /* Code generation registration function */
#endif
75
APPENDIX B.3
BOOST RECTIFIER CURRENT CONTROL WITH THD MINIMIZATION
VOLTAGE CONTROLLE WITH DISCRETE TIME SLIDING MODE ALGORITHM
Simulink Model File:\Thd_with_Outer_Loop_Boost\ Thd_Boost_Inner.mdl
Parameter M file: \Thd_with_Outer_Loop_Boost\ BoostInnerOuterPar.m
%Parameters file to be used with Boost Rectifier
%controlled with Presented Controller
ws=2*pi*50;%source voltage angular frequency[rad/sec]
Vg=10;     %Source Voltage amplitude[V]
%Plant parameters
R=50;      %Resistance [ohms]
3~Phase BOOST RECTIFIER
CURRENT LOOP CONTROLLER-THD MINIMIZING CONTROLLER
VOLTAGE LOOP CONTROLLER - Extension of continiouus SMC not needing ueq caculation
to set the parameters,double click the block below with shadowed border
to change the parameters see the file BoostInnerOuterPar.m
Originator:Murat GUNAY
Status:OK
Date:25 April  2002
3~input
3~refinput
d
q
observation
purposes
id and iq
i123Vo
Output votage
VOREF
idref
iqref
Vs123
i123
Vo
u123
Thd_Controller
0
PHIREF
Double Click here
to set the Parameters
emu
Vs123
u123
i123
Vo
Boost Rectifier
Vref
Phiref
Vo
idref
iqref
Boost Rec
Voltage Controller
VS
3~voltage
source
76
L=0.02;    %Inductance [Henry]
C=0.0007;  %Capacitor [Farads]
IPMAX=50;  %max current that plant can allow
IPMIN=-50; %min current that plant can allow
VOPMAX=100;%max voltage that plant can allow
VOPMIN=0;  %min voltage that plant can allow
VO_0=25;   %initial value of the output voltage
I1_0=0;    %initial value of the plant phase a current
I2_0=0;    %initial value of the plant phase b current
I3_0=0;    %initial value of the plant phase c current
%controller parameters
TS_c=50e-6;   %Sampling Period of current loop
Compdel=20e-6;%computational delay
%filter parameters
wc=2*pi*20;   %filter corner angular frequency
%Voltage controller
offsetboo=0.0015;%offset for voltage controller
D=500;           %convergence rate for voltage controller
TS_v=500e-6;     %Voltage Loop Sampling Period
umax=6;          %Maximum ref current that voltage controller can allow
errvolzero=1.5;  %initial error of voltage
S-function file: \ Thd_with_Outer_Loop_Boost \myalfa.c
This is the same as S-function file: \Thd_Boost_Inner\ myalfa.c
S-function file: \ Thd_with_Outer_Loop_Boost \ thdfboost.c
This is the same as S-function file: \Thd_Boost_Inner\thdfboost.c
77
APPENDIX B.4
BUCK INVERTER CURRENT CONTROL WITH RELAY CONTROLLER
Simulink Model File: \Relay_Buck_Inner\ Relay_Buck_Inner.mdl
Parameter M file: \Relay_Buck_Inner\ RelayBuckInnerPar.m
%Parameters file to be used with
%Buck Inverter controlled with Relay Controller
wr=2*pi*50;%source voltage angular frequency[rad/sec]
Vg=300;%DC Voltage source [V]
%Plant parameters
R=7;%rezistance [ohms]
3~Phase BUCK INVERTER
CURRENT LOOP CONTROLLER-RELAY CONTROLLER
to set the parameters,double click the block below with shadowed border
to change the parameters see the file RelayBuckInnerPar.m
Originator:Murat GUNAY
Status:OK
Date:25 April 2002
v3
v3
v2
v2
v1
v1
u3
u3
u2
u2
u1
u1
thetaref
theta
iqref
iqref
iq
iq
idref
idref
id
id
i3
i3
i2
i2
i1
i1
theta ref
3~input
d
q
d-q currents
observation
3~currents
THETAREF
idref
iqref
u123
Relay Controller
Plant output 
id and iq
Plant Output
voltages
Plant Output
Currents
IQREF
IDREF
Double Click here
to set the Parameters
emu
emu
emu
U-ABC
3~Vo_cikis
3~iL_cikis
BUCKINVERTER-plant
78
L=0.04;%inductance [H]
C=0.00003;%capacitance [F]
IPMAX=50; %max current that plant can allow
IPMIN=-50; %min current that plant can allow
VOPMAX=100; %max voltage that plant can allow
VOPMIN=0;  %min voltage that plant can allow
I1_0=0;   %initial value of the plant phase a current
I2_0=0;   %initial value of the plant phase b current
I3_0=0;  %initial value of the plant phase c current
%Relay controller parameters
TS_c=25e-6;  %Sampling Period of current loop
bound=0.05;%hystrezis bound --> +-bound
79
APPENDIX B.5
BUCK INVERTER CURRENT CONTROL WITH THD MINIMIZATION
CONTROLLER
Simulink Model File: \Thd_Buck_Inner\ Thd_Buck_Inner.mdl
Parameter M file: \ Thd_Buck_Inner\ BuckInnerParameters.m
%Buck Inverter parameters controlled with presented algorithm
3~Phase BUCK INVERTER
CURRENT LOOP CONTROLLER-THD MINIMIZING CONTROLLER
to set the parameters,double click the block below with shadowed border
to change the parameters see the file BuckInverterParameters.m
Originator:Murat GUNAY
Status:OK
Date:25 April 2002
v3
v3
v2
v2
v1
v1
u3
u3
u2
u2
u1
u1
thetaref
theta
iqref
iqref
iq
iq
idref
idref
id
id
i3
i3
i2
i2
i1
i1
3~input
theta ref
d
q
d-q currents
observation
idref
iqref
Vo123
i123
thetaREF
u123
THD Minimizing
Current
Controller
Plant output 
id and iq
Plant Output
Phase Currents
IQREF
IDREF
Double Click here
to set the Parameters
emu
emu
emu
U-ABC
3~Vo_cikis
3~iL_cikis
BUCKINVERTER-plant
80
%Source parameters
wr=2*pi*50;%reference angular velocity for output voltages
Vg=300;    %DC Voltage source Volts
%Plant parameters
R=7;       %rezistance ohms
L=0.04;    %inductance Henry
C=0.00003; %capacitance Farad
%Controller Parameters
TS_c=50e-6;    %Current controller sampling period
Compdel=20e-6; %Current controller computational delay
%Filter parameter
fc=2*pi*20;  %filter corner frequency
S-function file: \Thd_Buck_Inner\thdfbuck.c
/*=============================================================
==*/
#define S_FUNCTION_LEVEL 2
#define S_FUNCTION_NAME thdfbuck
#include "simstruc.h"
#include "math.h"
#define Rx *mxGetPr(ssGetSFcnParam(S,0))   /*first parameter */
#define Lx *mxGetPr(ssGetSFcnParam(S,1))   /*second parameter*/
#define Cx *mxGetPr(ssGetSFcnParam(S,2))   /*third parameter */
#define Ts *mxGetPr(ssGetSFcnParam(S,3))   /*fourth parameter*/
#define cdel *mxGetPr(ssGetSFcnParam(S,4)) /*fifth parameter */
#define Vdc  *mxGetPr(ssGetSFcnParam(S,5)) /*sixth parameter */
#define U(element) (*uPtrs[element])       /*Friendly access to inputs to S fcn block*/
/*************************************************************/
81
/*                     mdlInitializeSizes                    */
/*************************************************************/
static void mdlInitializeSizes(SimStruct *S)
{
    ssSetNumContStates(S,0);
    ssSetNumDiscStates(S,0);
    if (!ssSetNumInputPorts(S,1)) return;
    ssSetInputPortWidth(S,0,13);                /*input number*/
    ssSetInputPortDirectFeedThrough(S,0,0);
    if (!ssSetNumOutputPorts(S,1)) return;
    ssSetOutputPortWidth(S,0,12);              /*output number*/
    ssSetNumSampleTimes(S,1);
    ssSetNumSFcnParams(S,6);          /*S Fcn parameter number*/
    ssSetNumRWork(S,0);
    ssSetNumIWork(S,0);
    ssSetNumPWork(S,0);
    ssSetNumModes(S,0);
    ssSetNumNonsampledZCs(S,0);
    ssSetOptions(S, SS_OPTION_EXCEPTION_FREE_CODE);
}
/*************************************************************/
/*                mdlInitializeSampleTimes                   */
/*************************************************************/
static void mdlInitializeSampleTimes(SimStruct *S)
{
    ssSetSampleTime(S,0,CONTINUOUS_SAMPLE_TIME);
    ssSetOffsetTime(S,0,0.0);
}
/*************************************************************/
/*                        mdlOutputs                         */
/*************************************************************/
static void mdlOutputs(SimStruct *S,int_T tid)
{
82
    InputRealPtrsType uPtrs = ssGetInputPortRealSignalPtrs(S,0);
    real_T            *y    = ssGetOutputPortRealSignal(S,0);
    int birindex=7;    /*index of the first vector selected */
    int ikiindex=7;    /*index of the second vector selexted*/
    float alpha;       /*calculated timing information*/
    int myflag=1;int k;int i;
    float Udq[8][2];   /*Declaration for Udq (Array to store the representations of the
switching vectors in d-q frame)         */
    float Pdq[8][2];   /*Declaration for Pdq (Array to store the velocities of the error
corresponding to the switching vectors)*/
    float Ddq[8][2];   /*Declaration for Ddq (Array to store the d-q distances
conrresponding to the swictching vectors)        */
    float canfI[8];    /*Declaration for canfI (Array to store the candidates for the
selection of Fisrt Vector)                */
    float canfII[8];
    float dummy_min;         /*Declaration for dummy_min (Temporary placeholder for
instantenous min of the candidates)*/
    float pay;float payda;   /*Declaration for pay payda (Note that alpha=pay/payda)*/
    float Valfa;float Vbeta; /*Declaration for Valfa Vbeta*/
    float id;float iq;       /*Declaration for id iq*/
    float sigmad;float sigmaq;      /*Declaration for sigmad sigmaq */
    float u1I;float u2I;float u3I;  /*Declaration for u1 u2 u3 for First Vector */
    float u1II;float u2II;float u3II;/*Declaration for u1 u2 u3 for Second Vector*/
    float udI;float uqI;             /*Declaration for ud uq for First Vector */
    float udII;float uqII;           /*Declaration for ud uq for Second Vector*/
    /* S w i t c h i n g   v e c t o r s  in  abc  f r a m e */
    static int SW[8][3]={{1,-1,-1},{1,1,-1},{-1,1,-1},{-1,1,1},{-1,-1,1},{1,-
1,1},{1,1,1},{-1,-1,-1}};
    int sonvec=7;      /*index of the last vector applied to the plant */
    /*substuting inputs*/
83
    float saat=U(0);float idref=U(1);float iqref=U(2);float i1=U(3);float i2=U(4);
    float i3=U(5);float thetaref=U(6);float udeq=U(7);float uqeq=U(8);float nT=U(9);
    float V1=U(10);float V2=U(11);float V3=U(12);
    float theta;float GB;float dis1=cdel;float dis2=0;
    float pred_d=0;float pred_q=0;
    if(saat==nT)     /*------------ s a m p l i n g      i n s t a n t ------------*/
    {
        theta=thetaref;
        id=(i1-0.5*i2-0.5*i3)*cos(theta)+(0.5*sqrt(3)*(i2-i3))*sin(theta);
/*Transformation of measured currents*/
        iq=(i1-0.5*i2-0.5*i3)*(-sin(theta))+(0.5*sqrt(3)*(i2-i3))*cos(theta); /*into the d-q
frame using theta info   */
        sigmad=pred_d+id-idref;       /*Since we have plant currents in d-q frame and
reference currents coming from voltage controller        */
        sigmaq=pred_q+iq-iqref;       /*we can determine the error in currents and add
some prediction term to compansate the computation delay*/
        GB=Vdc/(2*Lx);                /*Calculation of GB parameter,effecting the velocity of
error  */    
        for(i=0;i<=7;i++)             /*Transformation of switching vectors into d-q frame  */
    {
    Udq[i][0]=(SW[i][0]-0.5*SW[i][1]-
0.5*SW[i][2])*cos(theta)+sqrt(3)*0.5*(SW[i][1]-SW[i][2])*sin(theta);
    Udq[i][1]=(SW[i][0]-0.5*SW[i][1]-0.5*SW[i][2])*(-
sin(theta))+sqrt(3)*0.5*(SW[i][1]-SW[i][2])*cos(theta);
    }
    for(i=0;i<=7;i++)
    {       
    Pdq[i][0]=GB*(Udq[i][0]-udeq);
    Pdq[i][1]=GB*(Udq[i][1]-uqeq);
    }                                      
    for(i=0;i<=7;i++)
    {
    Ddq[i][0]=Pdq[i][0]*Ts;
84
    Ddq[i][1]=Pdq[i][1]*Ts;
    }                                 
    for(i=0;i<=7;i++)
    {
    canfI[i]=sqrt(
(sigmad+Ddq[i][0])*(sigmad+Ddq[i][0])+(sigmaq+Ddq[i][1])*(sigmaq+Ddq[i][1]) );
    }                                   
    dummy_min=canfI[0];
k=0;
for(i=1;i<=7;i++)
{
if(dummy_min>canfI[i])
    {
dummy_min=canfI[i];
k=i;
}
}                      
if((k==6) || (k==7))
{
if((sonvec==7) || (sonvec==4) || (sonvec==2) ||
(sonvec==0)){k=7;}
else{k=6;}
}
birindex=k;               
for(i=0;i<=7;i++)
{
canfII[i]=sqrt( (sigmad + Ddq[birindex][0])* (Ddq[i][0]-
Ddq[birindex][0]) + (sigmaq+Ddq[birindex][1])*(Ddq[i][1]-Ddq[birindex][1]) );
/*        SQRT( (sigma_d+DId)              *(Di_d-DId)                    +
(sigma_q+DI_q)           *(Di_q-DI_q) )                  */
}             
dummy_min=canfII[0];
k=0;
for(i=1;i<=7;i++)
85
{
if(dummy_min>canfII[i])
    {         
dummy_min=canfII[i];
k=i;
}
    }                       
    if((k==6) || (k==7))
{
if( (birindex==7) || (birindex==4) || (birindex==2) ||
(birindex==0)){k=7;}/*optimization for zero vector */
else{k=6;}
}
ikiindex=k;                          
/*****************************Calculation of
ALPHA****************************************************************
******************************************/
payda=(Ddq[ikiindex][0]-2*Ddq[birindex][0])*(Ddq[ikiindex][0]-
Ddq[birindex][0]) + (Ddq[ikiindex][1]-2*Ddq[birindex][1])*(Ddq[ikiindex][1]-
Ddq[birindex][1]);
/*    (DIId-2*DId)                         *(DIId-DId)                          + (DIIq-
2*DIq)                         *(DIIq-DIq)                         */
pay=(Ddq[ikiindex][0]+2*sigmad)*(Ddq[ikiindex][0]-
Ddq[birindex][0]) + (Ddq[ikiindex][1]+2*sigmaq)*(Ddq[ikiindex][1]-
Ddq[birindex][1]);
/*  (DII_d+2*sigma_d)           *(DII_d-DI_d)                     +
(DII_q+2*sigma_q)           *(DII_q-DI_q)     */
alpha=pay/(payda+0.000001);
if(alpha>=0.9||alpha<=0.2)
{   alpha=1000;    
    sonvec=birindex;
86
    dis1=cdel;
    dis2=0;
    myflag=0; }
else
{   myflag=1;
    sonvec=ikiindex;
    dis1=0;
    dis2=cdel;
}
pred_d=Pdq[birindex][0]*dis1+Pdq[ikiindex][0]*dis2; /*Predictions for
d and q components */
pred_q=Pdq[birindex][1]*dis1+Pdq[ikiindex][1]*dis2; /*Predictions for
d and q components */                                          
udI=Udq[birindex][0];uqI=Udq[birindex][1];
udII=Udq[ikiindex][0];uqII=Udq[ikiindex][1]; 
u1I=SW[birindex][0];u2I=SW[birindex][1];u3I=SW[birindex][2];
/*output Variables are ok */
u1II=SW[ikiindex][0];u2II=SW[ikiindex][1];u3II=SW[ikiindex][2];
/*output Variables are ok */
y[0]=u1I;y[1]=u2I;y[2]=u3I;/*switching vector components for First
Vector*/
y[3]=udI;y[4]=uqI;    /*d-q components of the First Vector*/
y[5]=u1II;y[6]=u2II;y[7]=u3II;/*switching vector components for
Second Vector*/
y[8]=udII;y[9]=uqII;/*d-q components of the Second Vector*/
y[10]=alpha;y[11]=myflag;
}/**************************************************END OF
SAMPLING INSTANT******************/
}
/**************************************************************/
/*                       mdlTerminate                         */
/**************************************************************/
/* Function: mdlTerminate
87
 * Abstract:
 *    No termination needed, but we are required to have this routine.
 */
static void mdlTerminate(SimStruct *S)
{
}
#ifdef  MATLAB_MEX_FILE    /* Is this file being compiled as a MEX-file? */
#include "simulink.c"      /* MEX-file interface mechanism */
#else
#include "cg_sfun.h"       /* Code generation registration function */
#endif
S-function file: \Thd_Buck_Inner\myalfa.c
This is the same as used in: \Thd_Boost_Inner\myalfa.c
88
REFERENCES
1. S.L. Capitaneanu, B. de Fornel, M. Fadel, J. Faucher “Graphical and Algebraic
Synthesis for PWM Methods”, EPE Journal, Vol. 11, No 3, August 2001, pp16-28
(2001).
2. P519, IEEE Recommended Practices and Requirements for Harmonic Control in
Electric Power Systems.
3. ”Power Electronics and Variable Frequency Drives, Technology and Applications”
Edited by Bimal K. Bose, IEEE Press, 445 Hoes Lane P.O. Box 1331 Piscataway, NJ.
08855-1331, Chapter 3 “Power Electronic Converters for Drives” pp80-173, Chapter 4
“Pulse Width Modulation for Electronic Power Conversion”, pp138-208.
4. Sabanovic N., Ninomiya T., Sabanovic A., Perunicic B. “Sliding Mode Approach to
Control of Three-Phase Switching Converter”, Elektrik Vol. 3, No.1, pp22-31, (1995).
5. Nadira Sabanovic-Behlilovic, Tamotsu Ninomiya, Asif Sabanovic, Branislava
Perunicic “Control of Three-Phase Switching Converters: A Sliding Mode Approach”
PESC’93, pp630-635, (1993).
6. Nadira Sabanovic-Behlilovic, Asif Sabanovic, Kouhei Ohnishi “Sliding Modes in
Three-Phase Switching Power Converters Control”, T.IEE Japan, Vol.113-D, No.7,
pp883-890 (1993).
7. Asif Sabanovic, Kouhei Ohnishi, Nadira Sabanovic “Control of PWM Three-Phase
Converters: A Sliding Mode Approach ”, PCC Yokohama 93, IEEE Catalogue Number
TH0406-9/93, pp188-193 (1993).
8. Sabanovic N., Sabanovic A., K. Jezernik, O. M. Kaynak, “Current Control in Three-
Phase Switching Power Converters and AC Electrical Machines”, Proc. IECON’94, pp
581-586 (1994).
9. Chen Y., Fujikawa K., Ohnishi K., Sabanovic A. “Direct Instantaneous Minimization
Control for Three-Phase Converter”, Trans IEEJ, Vol. 117-D, No.7 (1997).
10. Joachim Holtz, Bernd Beyer “The trajectory Tracking Approach-A New Method for
Minimum Distortion PWM in Dynamic High-Power Drives”, IEEE Transactions on
Industry Applications Vol. 30, No: 4, pp1048-1057 (1994).
89
11. S.Fukuda, K. Koizumi “Optimal Control of a Three Phase Boost Rectifier for Unity
Power Factor and Reduced Harmonics” IEEE Catalogue No 95TH8025 0-7803-2423-
4/95 (1995).
12. A. S. Toledo, S. Guffon, G. Bornard, S.Bacha  “Sliding Mode Control of a Three-
Phase Switching Converter”, Journal de Physique (1997).
13. Discussions with Asif Sabanovic during EE523 -Sabanci University- “Power
conversion and Motion Control” class (2001).
14. Karel Jezernik, Boris Curk, Joze Harnik, Asif Sabanovic ”Discontinuous and
continuous sliding mode motion control”, AMC96, IEEE Catalogue Number 0-7803-
3219-9/96 (1996).
