Vector controlled induction motor drive using transputer parallel processors by Sumner, M.
Sumner, M. (1990) Vector controlled induction motor 
drive using transputer parallel processors. PhD thesis, 
University of Nottingham. 
Access from the University of Nottingham repository: 
http://eprints.nottingham.ac.uk/14104/1/335288.pdf
Copyright and reuse: 
The Nottingham ePrints service makes this work by researchers of the University of 
Nottingham available open access under the following conditions.
· Copyright and all moral rights to the version of the paper presented here belong to 
the individual author(s) and/or other copyright owners.
· To the extent reasonable and practicable the material made available in Nottingham 
ePrints has been checked for eligibility before being made available.
· Copies of full items can be used for personal research or study, educational, or not-
for-profit purposes without prior permission or charge provided that the authors, title 
and full bibliographic details are credited, a hyperlink and/or URL is given for the 
original metadata page and the content is not changed in any way.
· Quotations or similar reproductions must be sufficiently acknowledged.
Please see our full end user licence at: 
http://eprints.nottingham.ac.uk/end_user_agreement.pdf 
A note on versions: 
The version presented here may differ from the published version or from the version of 
record. If you wish to cite this item you are advised to consult the publisher’s version. Please 
see the repository url above for details on accessing the published version and note that 
access may require a subscription.
For more information, please contact eprints@nottingham.ac.uk
VECTOR CONTROLLED INDUCTION MOTOR DRIVE
USING TRANSPUTER PARALLEL PROCESSORS
by M. Sumner.
Thesis submitted to the University of Nottingham
for the degree of Doctor of Philosophy, May, 1990.
ACKNOWLEDGEMENTS
I would like express my gratitude to my supervisor,
Dr. G.M. Asher for his guidance and support over the
course of this project.
I would also like to thank the staff of the
Department of Electrical and Electronic Engineering,
University of Nottingham, for their technical assistance,
and the Science and Engineering Research Council of Great
Britain, for the project funding.
Finally, I would like to thank my friends and
colleagues for their emotional support, when needed, over
the last three years.
TABLE OF CONTENTS
ABSTRACT ..................• ..• ...................... 1
LIST OF SYMBOLS 2
CHAPTER 1 INTRODUCTION 4
1.1)VARIABLE SPEED DRIVES 4
1.2)DEVELOPMENT OF AC INDUCTION MOTOR DRIVES 5
1.3)PROJECT OBJECTIVES 6
CHAPTER 2 CONTROL OF INDUCTION MOTORS 9
2.1)INTRODUCTION 9
2.2)THE VARIABLE SPEED DRIVE EMPLOYING AN INDUCTION
MOTOR 9
2.3)CLASSICAL CONTROL TECHNIQUES 11
2.4)FIELD ORIENTATED OR VECTOR CONTROL 12
2.S)IMPLEMENTATION OF VECTOR CONTROL 17
2.S.1)V - Type Control
............................ 20
2.5.2)V - Type Control with Current Feedback 21
2.5.3)I-Type Control 23
2.6)ROTOR TIME CONSTANT DETUNING 29
2.6.1)Reactive Power Measurement 32
2.6.2)PRBS Injection 33
CHAPTER 3 PARALLELISM AND MOTOR CONTROL 36
3.1)INTRODUCTION 36
3.2)MICROPROCESSOR TECHNOLOGY AVAILABLE FOR REAL TIME
CONTROL APPLICATIONS 36
3.3)THE PARALLEL STRUCTURE OF MOTOR CONTROL 38
3.4)VECTOR CONTROL FOR INDUCTION MOTORS USING
CONVENTIONAL SEQUENTIAL PROCESSORS 40
3.S)TRANSPUTER IMPLEMENTATION OF A PARALLEL PROCESSING
NETWORK FOR VECTOR CONTROL 43
3.5.1)THE TRANSPUTER 43
3.5.2)THE TRANSPUTER PARALLEL PROCESSING NETWORK 00 45
CHAPTER 4 THE TRANSPUTER NETWORK - INVERTER
INTERFACE BOARDS 48
4.1)INTRODUCTION ............• ...................... 48
4.2)THE C011 LINK ADAPTER 48
4 .3 )THE SPEED INPUT BOARD 50
4.4)THE CURRENT INPUT BOARD 56
4.4.1)The Analogue Signal Board 56
4.4.2)The Analogue-Digital Conversion Board 57
4.5)THE PULSE GENERATION BOARD ......• .............. 60
4.6)INTERFACE BOARD DESIGN AND CONTROLLER LAYOUT ... 66
CHAPTER 5 TRANSPUTER IMPLEMENTATION OF VECTOR CONTROL 69
5.1 )INTRODUCTION 69
5.2)ACTUATION SIGNAL GENERATION 69
5.2.1)Pulse Width Modulation 70
5.2.1 .1)The PWM Algorithm 70
5.2.1.2)Occam Implementation 73
5.2.2)The Bang-Bang Controller 76
5.2.2.1)The Bang-Bang Algorithm 76
5.2.2.2)Occam Implementation..................... 76
5.3)SUPERVISORY ROUTINES 79
5.3.1)Occam Implementation of the IBMPC Supervisor 80
5.3.2)Occam Implementation of the B004 Supervisor. 83
5.4)THE CONTROL TRANSPUTER ROUTINES 88
5.4.1)V-Type Control 88
5.4.1.1)V-Type Control Algorithm 88
5.4.1.2)Occam Implementation 90
5.4.2)V-Type Control with Current Feedback 93
5.4.2.1)Control Algorithm 93
5.4.2.2)Occam Implementation 93
5.4.3)I-Type Control 95
5.4.3.1 )Control Algorithm 95
5.4.3.2)Occam Implementation 96
5.5)THE TR IDENTIFICATION ROUTINES .....• ........... 98
5.5.1)PRBS and Cross-Correlation Algorithm 101
5.5.2)Occam Implementation 103
5.5.3)Reactive Power Algorithm 104
5.5.4)Occam Implementation 104
CHAPTER 6 EXPERIMENTAL PROCEDURES AND RESULTS 106
6.1) INTRODUCTION 106
6.2)THE DESIGN OF THE SPEED CONTROLLERS 106
6.3)THE DESIGN OF THE CURRENT CONTROLLERS 109
6.4)V-TYPE VECTOR CONTROL 112
6.4. 1)The Cage Induction Motor 112
6.4.2)The Wound Rotor Induction Motor 116
6.5) I-TYPE VECTOR CONTROL 116
6.5.1)The Cage Induction Motor .....• .............. 116
6.5.2)The Wound Rotor Induction Motor 123
6.6)V-TYPE VECTOR CONTROL WITH CURRENT FEEDBACK 123
6.6. 1)The Cage Induction Motor 123
6.6.2)The Wound Rotor Induction Motor 131
6.7)ROTOR TIME CONSTANT IDENTIFICATION 134
6.7.1)Reactive Power Measurement 134
6.7.2)PRBS and Cross-Correlation 141
6.8)TRANSIENT PERFORMANCE ANALYSIS 141
6.9)TRANSPUTER UTILISATION 145
CHAPTER 7 FURTHER DISCUSSION AND CONCLUSIONS 148
7.1)INDIRECT VECTOR CONTROL 148
7.1.1)V Type Control 148
7.1.2)1 Type Control 148
7.1.3)V Type Control with Current Feedback 149
7.1.4)Rotor Time Constant Identification 149
7 .2 )FUTURE WORK 150
7.3)THE TRANSPUTER AND PARALLEL PROCESSING FOR
MOTOR DRIVES 151
REFERENCES
.......................................... 153
APPENDIX A DEVICE SPECIFICATIONS 159
APPENDIX BD - Q AXIS INDUCTION MOTOR MODEL 161
APPENDIX C TRANSFORMATION EQUATIONS
................. 166
APPENDIX D THE TRANSPUTER 168
APPENDIX E DIGITAL IMPLEMENTATION OF CONTROLLERS .... 177
ABSTRACT
This thesis describes the design and construction of
a high performance induction motor drive, controlled by a
network of parallel (INMOS) Transputer processors. The
flexibility and high computational ability of the
controller is demonstrated by the implementation of three
forms of indirect vector control for the induction motor
(here termed "V-Type, "V-Type with Current Feedback" and
"I-Type") on two motor drive rigs. Results show that V-
Type control with current feedback is superior, and that
on-line parameter estimation (namely the rotor time
constant) is required.
The controller has been expanded to incorporate two
parameter identification strategies for assessment. The
first, termed "Reactive Power Measurement", has proved
successful in matching the controller value of rotor time
constant to the actual machine value of rotor time
constant. The second, termed "PRBS Injection with Cross-
Correlation" has proved inconclusive and is the subject of
on-going research.
The performance of the transputer parallel processing
network for real time control is discussed. This
assessment is felt to be significant since parallel
architectures are likely to become increasingly exploited
as the processors become cheaper, more powerful and
flexible, and with enhanced system support.
1
p,
M,
LIST OF SYMBOLS
instantaneous three phase stator voltages.
instantaneous three phase stator currents.
stator voltage/current vector defined in the
stationary frame of reference
rotor current vector defined in the rotor
frame of reference
stator voltage/current vector defined in the
synchronously rotating frame of reference
rotor current vector defined in the
synchronously rotating frame of reference
stator voltage in a synchronously rotating
d - q axis frame of reference.
stator current in a synchronously rotating
d - q axis frame of reference.
rotor currents in a synchronously rotating
d - q axis frame of reference.
d and q axis flux linking the rotor winding.
electrically developed torque.
number of pole pairs.
stator/rotor mutual inductance.
stator and rotor self-inductance.
2
a, leakage coefficient.
Rs,Rr, stator and rotor resistance.
rotor time constant.
magnetising current.
stator angular velocity.
rotor angular velocity.
wslip, slip angular velocity.
angular co-ordinates.
s, differential operator.
s, Laplace operator.
3
CHAPTER 1
INTRODUCTION
1.1)VARIABLE SPEED DRIVES
Up until the mid 80's industry traditionally relied
upon the DC Motor drive for variable speed applications
such as machine tool drives, paper and steel mills,
traction drives and crane drives. The drive permits
operation in all four quadrants of the torque-speed plane,
gives good efficiency, and excellent dynamic response. The
DC Machine itself suffers from several economic
disadvantages when compared to the AC Induction motor: the
induction motor is cheaper, more reliable, and requires
less periodic maintenance. Moreover, the induction motor
has a lower rotor inertia for a given power rating than
the DC machine. The induction motor thus has the
capability of higher dynamic performance for a given power
rating. The advantages of the DC drive result from the
simpliCity of the power converter and control circuitry
required to complete the variable speed drive.
The power converter employed by power DC drives is
based on the line commutated thyristor bridge rectifier.
The induction motor needs a converter capable of
transforming fixed frequency ac into a variable frequency,
variable voltage source at low losses. This originally
necessitated the use of thyristors which cannot be
commutated naturally. The extra components required for
forced commutation increased the cost of the converter
substantially.
The simplicity of the control circuitry derives from
the fact that the DC motor has a simple control structure
wherein the torque and air-gap flux of the machine are
able, by the action on the commutator, to be controlled
4
independently. By contrast the induction motor has a
complex control structure as the voltage, current,
and speed are all interdependent, resulting in a
torque
highly
coupled, non-linear, multivariable control problem.
The complexity of the original AC thyristor
converters together with the complexity of the controller
circuitry for induction motor control are the reasons why
the DC drive was the automatic choice for high performance
drives until relatively recently.
1.2)DEVELOPMENT OF AC INDUCTION MOTOR DRIVES
The development of AC drives over the last 10 years
as variable speed drives has derived from the power
switching devices developed over the same period as an
alternative to thyristors [1],[2],[3]. The introduction of
such devices as the Gate Turn Off Thyristor and high power
Bipolar Junction and Field Effect Transistors for low to
medium power applications has removed the need for
auxiliary commutating circuits. The resulting reduction in
cost of the power converter means that the AC drive has
become more commonplace in variable speed drive
applications.
Over the same period the problem of obtaining a fast
torque response from the induction motor has received
considerable attention [1],[4]. A control strategy for
achieving this was derived originally by Blaschke [5] and
developed by Leonhard [6],[7]. Termed "vector" or "Field-
Orientated" control, this method involves the
transformation of the machine dynamics into those of a
"pseudo-DC machine equivalent" in which a torque and field
component of machine current are obtained. This method
described in chapter 2 - derives its transformations from
the instantaneous rotor flux vector and allows the torque
and flux of the induction motor to be controlled
independently in a similar manner to the DC machine. The
5
development of microprocessor technology, as described in
chapter 3, has provided devices capable of handling the
computational tasks demanded by this strategy, and drives
of comparable performance to equivalent DC drives have
resulted [8],[9],[10]. Some of these are also described in
chapter 3.
The area of vector control can be subdivided into two
generic categories, each with its own advantages and
disadvantages. The first, termed "direct" vector control,
uses flux sensing coils mounted within the machine itself
to detect the rotor flux vector. This provides accurate
field orientation and results in excellent decoupling of
the torque and field components of the motor current. The
modifications to the machine and extra interface hardware
are however expensive. The other method, termed "indirect"
vector control, either uses a machine model to calculate
the rotor flux vector, or imposes the vector control
condition in a feed forward manner [9]. Both require an
accurate knowledge of the machine parameters, (namely the
rotor time constant) in order to provide accurate tracking
of the flux vector. These parameters can vary during
machine operation due to temperature and saturation
effects, and the resultant loss of tracking can impair
both transient and steady state performance. This problem
is described in chapter 2.
1.3)PROJECT OBJECTIVES
The objective of this project was to construct a high
performance induction motor rig controlled by a network of
parallel (INMOS) Transputer processors. The rig therefore
contains a controller of high computational ability and
flexibility, which allows for multiple strategies to be
investigated. The transputer network is easily expandable
to cater for future research requirements in this area.
The indirect strategy for vector control was chosen
6
since this has been adopted by industry for commercial
drives as it requires no alteration to the basic induction
motor. No "standard" implementation of vector control
exists and so the rig should be able to implement several
control algorithms for evaluation, without major hardware
changes. The requirement for on-line machine parameter
identification is essential for high performance drives
[11],[12],[13], and although several schemes for this have
been proposed, none as yet have been adopted as a
standard. The rig should be capable of testing several
different schemes.
The INMOS Transputer was chosen as the basis of the
control hardware for two reasons. Firstly, the control
structure can be seen to be parallel in nature,
particularly if extensive monitoring and fault finding
capabilities are required, and this is discussed in
chapter 3. The transputer was developed specifically as a
device to be implemented in parallel processing networks.
It is a highly efficient microcomputer in itself, but is
easily interconnected with other transputers. Secondly it
was desired to demonstrate the effectiveness of the
transputer as a real time control device, and evaluate it
and its associated software as a versatile development
system for real time control problems. When the project
was started there had been no work carried out in this
area. The programming and interfacing of the transputer
are discussed in chapters 5 and 4 respectively.
The project has investigated the implementation of
three different forms of indirect vector control, here
termed V-Type Control, V-Type control with Current
Feedback, and I-Type Control. All these implemented forms
are types of what are generally termed "feedforward
indirect vector control" [9]. V-Type control employs only
a speed feedback signal, and imposes stator voltages on
the motor, calculated on the basis of the steady state
voltage equations in the field orientated frame of
7
reference. V-Type control with current feedback uses
current transducers to measure the stator currents. These
are then transformed to the field orientated frame of
reference and controlled again by impressed stator
voltages. I-Type control uses a fast current loop around
the power converter to provide a "current fed" converter.
These control strategies are described in chapter 2.
Two induction motors have been used. The first
machine is a low inertia squirrel-cage machine which
demonstrates the potential high performance obtainable.
The second was a wound rotor machine, here used only to
demonstrate the flexibility of the control rig, but
intended for future use in the area of rotor parameter
identification. Additionally, two different schemes for
on-line rotor time constant identification have been
initially tested. The performance of the vector control
strategies, the rotor time constant identification
schemes, and of the transputer system itself are presented
and discussed in chapters 6 and 7. The on-going nature of
the project is also discussed.
8
CHAPTER 2
CONTROL OF INDUCTION MOTORS
2.1)INTRODUCTION
This chapter introduces the concept of Field
Orientated or Vector Control for high performance
induction motor drives, and compares it with operation of
a DC variable speed drive system. The first section
describes the typical inverter driven induction motor
plant and its application to variable speed drives. The
second section outlines classical control methods for "low
performance" induction motor drives. Section three
outlines the mathematical structure of vector control
based on Generalised Machine Theory. Section four gives a
brief description of how a vector control algorithm may be
implemented as a practical induction motor drive. The
final section introduces the problem arising from this
form of control , the variation of the rotor time constant
during machine operation, and outlines several of the
mathematical techniques which may be employed for on line
identification of that parameter.
2.2)THE VARIABLE SPEED DRIVE EMPLOYING AN INDUCTION MOTOR
The basis of the work presented in this thesis is an
induction motor driven by a voltage source inverter as
illustrated in Fig. 2.1. The base drive signals for the
switching elements are derived from a Pulse Width
Modulation strategy used by the controller and provide a
three phase voltage source of variable amplitude, phase
and frequency for the induction motor. A speed signal is
derived from a speed encoder mounted on the shaft of the
9
~o
+>
o
£.
10
cv
>+>
-p c
d :J
s.... CD
QJ c
c --
OJ..::t.
(J)d
OJ ~
s.._.Q
s,
o
-p
o
:E:
c
cv
>
s,
~
s,
cv
-p
s....
QJ
,.--i
> ru
c
~ cv
QJ
s,
U
::;>
s,
_QJ
::;> u,
0
V)
QJ
(J)
d
+>
0
>
induction motor, and line currents are measured using
current transformers. A DC generator is directly coupled
to the induction motor to provide a means for varying the
load torque. Two different induction motors have been
employed in this project, a low inertia cage machine, and
a higher inertia wound rotor machine. The specifications
for the motors, inverter and transducers used are given in
Appendix A. A Regenerative Braking Unit is connected
across the DC link of the inverter to provide a means for
dissipating regenerative energy from the induction motor
during braking. This consists of a switching transistor
and resistance bank. The transistor is turned on when the
link voltage exceeds a preset limit and the regenerative
energy is dissipated as resistor heating.
2.3)CLASSICAL CONTROL TECHNIQUES
The techniques outlined in this section employ an
inverter driven induction motor as a low performance
variable speed drive, and provide "speed holding" rather
than good dynamic performance. The simplest form of speed
holding is an open loop system whereby the stator
frequency is imposed upon the motor and the voltage
amplitude is controlled proportionally to this value in
order to maintain constant flux within the machine. The
motor runs with a small slip frequency, the value of which
will increase with machine loading. A low frequency
voltage boost is required with this scheme to overcome
stator resistance drops at low frequency.
To overcome the slip error associated with the open
loop scheme a speed feedback system can be employed [3]
whereby the stator frequency demand is provided by a PI
controller acting on the error signal derived from the
speed demand and measured signals. A further improvement
to this scheme is slip frequency control, also known as
slip compensation or scalar control,[3], whereby the speed
11
error controller provides a slip frequency reference value
which is added to the measured rotor speed to provide a
stator frequency reference value. This scheme is
illustrated in Fig. 2.2. Again this system controls the
stator voltage proportionally to the stator frequency,
with a low voltage boost. The machine torque can be
regarded as being proportional to the slip frequency and
thus this system is in effect a torque controller within a
speed controller.
The problem with these systems is that flux and
torque are not closed loop controlled quantities and if
the flux drifts from its preset value, the torque
developed at a given slip will vary. Furthermore
fluctuations in the machine parameters due to temperature
effects or saturation will further impair the performance
of the drive. For low performance drives these are minor
considerations; however if dynamic performance is required
then these problems must be overcome.
A control scheme which employs independent torque and
flux control using the machine stator voltages and current
measurements to synthesise torque and flux signals can be
employed [3]; however the added complexity of the control
circuitry does not provide a drive with dynamic
performance comparable with a DC motor variable speed
drive.
2.4)FIELD ORIENTATED OR VECTOR CONTROL
Vector control for induction machines was devised by
Blaschke [5] and developed by Leonhard [6],[7],[8]. It is
a technique for controlling independently the rotor flux
and electrically developed torque of the machine. The
resultant drive scheme becomes similar to that of a
separately excited DC machine and transient response is
proven to be superior to the "classical" induction motor
drive strategies.
12
L
ClJ
+>
L
L ClJ
Cl! >
3:: c
o 0
Q_ \_U ______
-----~
*
* * *d _Q U
> > >
.
c
ClJ
(J)
*>
L
oQJ
ClJo
GJ 0
o..U
lJ) C
QJ
.
L
0
+>
0
L:
c
0
-P
U
::J
0
C
1--1
C
d
L
0
4-
_.;
OJ0
L ru
* -POJ
c ClJ~ 0 LL U ::J+ 3:: (J)
>.
U u,+ c
ClJ
~ ::J
ITl/)
OJ3::
LLJ_.;
u,ClJO
ClJL
0.Cl.-P
_.;l/)C (/)1--10
Q_U
+
13
In a separately excited DC machine the field current
(If) and the armature current (la) are independent
control variables which control the air-gap flux (~g) and
the developed torque (Te) , in accordance with equations
2.1 and 2.2. K1 and K2 are constants of proportionality.
equations which ignore the
flux (armature reaction),
will put a more important
limit on transient performance than the current capability
of the converter and machine armature.
For sub-base speed operation the field current is
maintained constant at its rated value and the developed
torque is controlled by variation of the armature current.
It is important to note that air-gap flux and torque are
controlled orthogonally by the switching action of the
commutator, and thus the torque sensitivity remains
maximum in both steady state and transient operation.
Speed may be increased above base speed by reduction of
the air gap flux, i.e. reducing If, and this mode of
operation is termed "field weakening".
To provide a similar control strategy for the
induction motor it is necessary to define orthogonal
components of the stator current such that one acts as a
torque producing component and one acts as an air-gap flux
producing component. The vector control algorithm proposed
provides these parameters and suggests a means for
controlling these values independently.
The typical starting point for a derivation of the
vector control algorithm is a generalised d q axis
~g = K1If
Te = K2Ifla
These are simplified
effect of la on the machine
which for small DC machines
( 2 • 1 )
( 2 • 2 )
dynamic
rotating
B. Slot
model of the induction motor in a synchronously
frame of reference. This is derived in Appendix
effects, spatial harmonics and end effects are
14
ignored as are the harmonics of the voltage source. The
equations derived in Appendix B reduce to the 4th order
differential equation set given here
vsd = Rs+SaLs -weaLs SM/Lr -WeM/Lr Isd
Vsq weaLs Rs+SaLs weM/Lr SM/Lr Isq
0
-MRr/Lr 0 (Rr/Lr)+S -(we-pwr) 4>rd
0 0
-MRr/Lr we-pwr (Rr/Lr)+S Wrq
(2.3)
The d axis flux linking the rotor windings is
4>rd = Misd + Lrird
The q axis flux linking the rotor windings is
Wrq = Misq + Lrirq
The torque equation for this system is
Te = (2pM/3Lr) (isq4>rd - isdWrq)
(2.4)
(2.5)
(2.6)
It can be seen that if the d axis of the rotating frame of
reference is aligned to the rotor flux axis, then the d
q model simplifies significantly, particularly :_
Wrq = 0 ( 2 . 7 )
(2.8)
It should be noted that it is the total flux linking
the rotor that is under consideration. This differs from
the air - gap flux (which is used for the DC machine) by
the rotor leakage. The rotor flux is used as it simplifies
15
dynamic equations used later, and is compensated for in
the torque expression by the factor (M/Lr).
Putting ~rq = 0 as demanded by the orientation
described above, then row 4 of eqn. 2.3 becomes :_
(2.10)
The second term on the right hand side is seen to
represent the slip angular velocity. Considering row 3 of
eqn. 2.3 gives :-
isd = «1/M) + S(Lr/(MRr»)~rd (2.11)
If a new term is introduced, the magnetising current
vector imr where :-
(2.12)
then eqn. 2.11 can be rewritten as
(2.13)
For an induction motor operating with a constant rotor
flux,
~rd = Mimr = Misd (2.14)
and the torque equation becomes
(2.15)
Equations 2.10, 2.13 and 2.15 are the fundamental
equations for vector control. Equation 2.13 is directly
analogous to the field equation of a DC. machine where isd
is the steady state field current and is directly
proportional to the rotor flux. It is qualitatively
analogous to the applied field voltage in the DC machine
16
and imr is analogous to If. Equation 2.15 corresponds to
the torque equation of a DC. machine and thus isq is the
torque producing component of the stator current. Under
field weakening control eqn. 2.13 becomes important as the
rotor flux, being proportional to imr through eqn. 2.12
responds to changes in isd with a significant time
constant Lr/Rr.
2.5)IMPLEMENTATION OF VECTOR CONTROL
For implementation of vector control for induction
motor drives some means for identifying the instantaneous
position of the rotor flux vector is essential. Early
experimentation with this technique employed flux sensing
coils mounted in the stator slots [8] and provided a good
flux measurement down to about O.5Hz. This method however
requires the use of modified or specially constructed
machines, not considered generally practicable. A second
method used in the early history of vector control used
the stator voltages (either measured using sensing coils
again or by using the reference values controlling a PWM
generator) and by means of integration provided an
estimate of the rotor flux vector [8]. This method however
proved unreliable at low speed due to the cut off
frequency of the integrators employed. Variations in the
stator parameters due to temperature and saturation had a
marked effect on the control scheme. Techniques employing
direct sensing of the rotor flux signal are known as
"Direct Vector Control". A general scheme for direct
vector control using a voltage fed inverter is illustrated
in Fig. 2.3. It is also possible to employ the same vector
control scheme using a fast "local" current loop around
the inverter.
17
"Vl
"OJ
:Cl)
"0
".p
:-0
:>
"Cl)
:c:
"Vi
:c:
"OJ
:Vl
u
>
.ri
>
a
>
s,
OJ
.p
s,
OJ
>
c:
......
E:.
s,
o
"0 4-
"- Vl
o c:
o 0
u .f;
.p~
c: 0
OJ ~
I... .p
I... c:
~ 0
U U
-0
"0 ~
OJ.p
OJ c:
0.0
Vl U
18
.p~
c: 0
OJ I...
I....p
~ c:
3 0
U U
s,
o
-P
o
L
c
o
-P
U
:J
~
C
I-l
c
o
4-
o
-J
o
s,
-P
c
o
u
L
o
-P
U
Q)
>
An alternative and simpler approach to this control
strategy is to employ a technique known as "Indirect
vector Control" where the rotor flux is not directly
measured or derived and no modifications to the induction
motor are required. As mentioned in chapter 1, there are
two forms of indirect vector control. The first uses a
flux model to calculate the rotor flux vector [6]. The
second imposes vector control in a feed forward manner
[9]. It implicitly aligns the d axis to the rotor flux
vector by controlling the slip angular velocity according
to equation 2.10. using the controller reference values of
isq and ~rd rather than the actual machine values. It thus
relies upon the precise control of the d and q axis
currents using fast stator current controllers. No
comparison of the two schemes as yet exists. For this
project the computationally simpler "feedforward" indirect
vector control approach has been used. A general scheme
for such an indirect vector controller employs two
quadrature current controllers for isd and isq and
controls the inverter frequency according to eqn. 2.10.
The controller imposes a rotor flux vector angle ge which
is implicitly aligned to the d axis such that
(2.16)
Its magnitude is controlled directly by isd. The torque
current reference is derived from the speed controller,
whereas the flux current reference under sub base speed
operating conditions is maintained constant at just under
saturation level. For operation above base speed field
weakening is introduced whereby the flux current reference
is reduced gradually with speed in a similar manner to
field weakening operation of a DC machine.
If the stator currents are controlle~ accurately and
the flux reference does not change dynamically (ie. no
field weakening) then this method should be the same as if
a flux model had been used.
19
The transformation of the instantaneous stator
current values into field orientated d and q axis
components is achieved using the equations given in
Appendix C. This transformation will be here termed
"demodulation". The equations employ matrix multiplication
using the sine and cosine of the instantaneous flux vector
angle, and this is abbreviated for the schematic diagrams
by use of the equivalent complex operator ejee. The
corresponding modulation routines (i.e. transformation
of d and q axis values to instantaneous stator reference
frame values) are also given in Appendix C, and are
represented by the complex operator e-jee.
The precise control of the stator currents using a
voltage source inverter can be achieved by one of three
methods, each of which have been investigated
experimentally. In this project these are termed V - Type
control [9], V - Type control with current feedback
[9],[10], and I - Type control [8].
2.5.1)V - Type Control
The basis of this control strategy is the steady
state field orientated stator voltage equations derived
from eqn. 2.3. [9]. If the differential terms are removed
from rows I~ and 3 the d and q axis voltages can be defined
as :-
(2.17)
Vsq = isqRs + weLsisd (2.18)
The stator voltage demands are derived directly from
these equations using the reference demands for isd, isq
and we and imposed on the machine using a sinusoidal PWM
generator which provides the required base drive
to the inverter [14],[2]. This method does not
signals
employ
closed loop current control, and is thus inherently sub-
20
optimal because it requires the precise knowledge of the
stator and rotor parameters (which may change with
temperature, frequency and saturation), and demands a
correct calibration between the pwm voltage reference
signals and the generated motor voltages. Its main
advantage however is that it is easy to implement an6
requires only a speed feedback signal. The schematic for
this controller is shown in Fig. 2.4.
2.5.2)V - Type Control with Current Feedback
This method employs current feedback to provide
closed loop control of the d and q axis currents and is
based on the stator dynamic equations derived from eqn.
2.3 namely [10] :-
(2.19)
(2.20)
The current controllers themselves were designed
using Laplace techniques and employed proportional plus
integral control. The controllers were designed on the
basis of the following equations
(2.21)
21
1Il
s,
U
il!
-E
.p
d
s,
c
s, il!
>,
OJ >
~
3: c
0 0
s,
Cl \U
0
+>
d
.p
Cl)
~* ""D Q.J Cl.OJo 0OJ 0 0Cl.U
_j
IJi C
Q) C
OJ
Cl.
0OJ
"'C)
CD
C
-J
d
Q.J
»<:
* _.JIJi 0
0-
OJ s,>
O).p
d c
.p 0
_.J U0
> OJ
0..
L5 >,
il! f-s,
IJi
+
3: IJi > .OJ ..q-<:»s, ru
Cl c
-£ 0 OJ
.......
+> s,
::50) o
C VI 0)
-- C u,l/l OJ
::5 Q.
_.J £
0 0
s, U
.p
C
0
U
s,
0
+>
U
OJ
*
>
0
t->
U
OJ
s,
L5
C
.......
22
Vsq = (Rs + SaLs)isq (2.22)
The overall motor control scheme is shown in Fig 2.5.
It can be seen that the terms underlined on the right
hand side of equations 2.19. and 2.20. constitute
additional coupling terms which must be compensated for at
the output of each current controller. The schematic for
the two current controllers with compensation is
illustrated in Fig. 2.6.The voltage reference signals vsd,
Vsq are again used as the input signals for a sinusoidal
PWM generator. This current control method requires an
increased computational ability from the controller to
carry out the control strategy, compensation and the
transformations.
2.5.3)I-Type Control
The third method of current control implements a fast
"local" current control in the stator frame of reference
[6]. The reference values for isd and isq generated by the
controller are modulated to form three instantaneous
reference phase currents. These are compared with the
corresponding measured phase currents and the result
decides which of the transistors of each phase should be
turned on. A preferred switching frequency is usually
introduced so that a lower limit is provided for the time
between two subsequent switching operations, dictated by
the minimum on and off times of the transistors employed.
This method is also known as "Hysteresis" control [6] and
is illustrated in Fig 2.7. It has been reported that [6],
[15] this method works very well if a sufficiently high
switching frequency can be employed and the inverter has
sufficient ceiling voltage to overcome the back EMF at
higher frequencies. Under these conditions the stator
windings can be considered to be fed from current sources.
23
L
() OJ
OJ ()
ClJ 0
Q_ U
1ft C
ClJ
s,
- 1
~* 1----0~
0
-
+>
-0-T 0
-
E41
... A ~ A
* * *
_Q
--
o
~
U o
> >
*<:5
>
-P
c
OJ
L__,
L 0
::5 L
U-P
c
........0
o_ U
A"
I
.....
+ ...
1. "
*0-
>
+ A
-P
*c
__,
ClJ 1ft
L __, 3:
L 0
::5 L
U -Pc
*........ 0 ('j
Q_ U ~ -L
~
I-
I..~
*
-q.-----------------~
('j
Q)__,
Q) 0
D-L
lJ1-P
c
f-f 0
o_ U
+~~~I_~------------------~
ClJ
L
3:
24
ClJ
::5
IT
L
0
I-
-n
c
d
~
__,
OJ
u,
~
or-.
..Y
__,u
o c
L...Q
-P('j
C ilJ
o ilJ
Uu_
-n..p
c c
d ilJ
1ft s,
OJ t-
0)::5
dU
±::..s:::
o-i:
> ~
-nilJ
OJQ
1ft>"
1ft I-
OJ If)
L>
0..'-" (\J
E
f-flj) OJ
..p L
CJ)C ::::i
C ilJ 0)
-(i) C
u,
:::JO
D-
__,£
o 0
LU
-P
C..p
o C
UClJ
L
L t-
o ::5
-PU
U
OJ
>
-j->
U
OJ
L
-0
C
I-i
=
~
-0
*
..Q
c5
o
> >
OJ OJ c
CS>
CD 0
-i
-i I +>OJ OJ cSIfl
OJ c
CD OJ
~
0..
£:
0
U
L Ifl
0- <::5 ~ X
..- cS
+ 0-
-P
*
I
c --'
OJ lfJ
-r>
L __, ~
L 0
<:5
:5 L
c
U -P
o
c
*'I-l 0 <:5 0
0..... U .-f L '-.0L -
~
+> (\J
c
*
0 OJ
*<::5 a-
u L
*
:5
OJ +> OJ
3: c LLOJ
+
s,
L
*
::5
*
a- u
-r> _£
-r> +>
QJ--, 3:
QJ 0
o..L OJ
lJl-P
c
0..
I-i 0
»,
Q_ U ~
>
+
4-
OJ
L
~
25
L
o
-P
o
E
--0--
",.....
OJ
D..
>.
I-
I---l
<:»
IJl
-P
c
OJ
L
L
:::5
U
L
0
-P
d
-P
(/)
(J
L OJ
::: IJl
IJl
OJ
L
0..
E
I---l
0)
-c r-,
IJl (\J
:::J
OJ
0 L
L ::J
-P 0)
c LL0
U
L
0
-P
U
OJ
>
-P
U
OJ
L
(J
C
I---l
d S2 U
1 .. ,
OJ
CD
--,
~ I
QJ
~
lIE""
~r ...
Cl.!
-0 IT
3: + -- --
?\ ...
+ .~""
*--'IJl
:::
* * *0 _Q U
-_
--
--
Q;
cr> L..
"J f"'"
QJ
• A
c:5.
Qj-J
ru 0
o..L
lJ)-P
c
f-i 0
Q_ U
26
However the carrier frequency is limited. If a purely
digitally implemented controller, (here termed "Bang-Bang"
control) is employed a finite time is required for the
processor to calculate the reference currents, sample the
motor currents, and determine the transistor switching
configuration. Also the ceiling voltage of the inverter
may not
result in
current.
adversely
be sufficiently large, and these limitations
inaccuracies in the actual imposed stator
The "lag" introduced by the digital controller
affects the modulation of isd and isq and
introduces a discrepancy between the real flux axis in the
machine and the controller's flux axis. Two possible
methods to overcome these problems have been proposed by
Leonhard [6], namely
1)the inclusion of a lead lag network in the stator
reference frame for the modulated stator currents
2)the inclusion of decoupling terms in the field
orientated frame of reference, such that the adjusted
reference signals ('isdref, 'isqref) are calculated as :-
'isdref = isdref - weTisqref (2.23)
'isqref = isqref + weTisdref (2.24)
where T represents the lag of the current loops, obtained
experimentally. The revised I - Type controller is shown
in Fig. 2.8.
The major disadvantages of indirect control over
direct control result from the need for precision control
of the d and q axis currents, and accurate knowledge of
the rotor time constant. This is because the flux vector
angle imposed by the controller is derived directly from
isdref' isqref and Tr on the assumption that these match
the corresponding parameters in the machine itself. If
this is not the case then the torque and flux will not be
controlled independently by isq and isd respectively.
27
lfl
-Vi s,
ClJ~ :
~O :
ClJL:
+>.p:
lflc'
>,0 :
...c U .
+
*er
(S.
(lJ~
(lJ 0
o...s....
l/l-P
c
........0
CL U
+~
28
c
o
+>
o
1Il
c
OJ
0...
£.
o
U
CJ)
o
_j
"TI
o
Cl!
_j
L
o
+>
o
+>
(.I)
"TI
c
d
1Il cri
X (\j
<t
0-
OJ
L
I :::5
"TI
_Q>
...c l.i;
+>
~
o
L
+>
c
o
u
OJ
Q_
>...
I-
Direct control is somewhat robust to changes in the rotor
time constant during operation, and is not dependent on
the performance of the current control loops. This is
because there is closed loop control of the flux vector
and thus torque and flux are controlled orthogonally by
isq and isd. Indirect control is susceptible to both of
these problems, and these may lead to significant steady
state errors in the flux and torque, and undesirable
oscillations during transient operation. The problem of
variation in Tr will now be discussed.
2.6)ROTOR TIME CONSTANT DETUNING
In order that the controller may truly follow the
position of the flux vector in the machine, the controller
parameters Lr and Rr must accurately reflect those
parameters in the machine itself, such that eqn 2.10 is
validly imposed on the motor by the controller. If the
rotor resistance or rotor self inductance vary during
operation of the drive, due to temperature, frequency or
saturation effects, then the values of the control
parameters Lr and Rr become "detuned" and the flux axis
set by the controller becomes misaligned from the real
flux axis in the motor, as illustrated by Fig 2.9.
Changes in the rotor resistance during operation may
be compounded by saturation or underfluxing effects caused
by the resultant misalignment of the real and controller
flux vectors. If a change in isq is imposed by the
controller then there will be an undesired significant
change in the d axis current of the motor i.e coupling
effects. A reduction of the motor's d axis current will
result in underfluxing of the motor, and can result in a
significant change in Lr itself (the motor will now be
operating on a different
curve) .
part of its magnetisation
29
lfl
X
0
X
::5
__,
4-
L
Vl OJ
X
0 0
L
X .p
:5 c0
4- U
.p
0 c
Il.J 0 .p
L- U cZ> OJ
lfl L lfl
L L
::5 ::5
U U
U
-~ I L OJ 00 s:
L .p ..
L 0)
OJ 4- c
0 c
::5
Q_ .p (J\OJ
.c
~ C\J
lfl ..
c OJ0 c
OJ L
.p
...c ::50 0)
.p '. __, :i:
c OJ u,
0 Cl:::: lfl
U L-
0- L 0
'.~
d .p
__,
__, U0 ::::5
OJ 0) OJ
L c: >
0- <[
lfl
30
The effect of detuning on the torque and flux
response in the induction motor has been described as
follows. Garces [11] provides analytical expressions to
relate the steady state error in the real d axis flux
magnitude and real q axis flux magnitude (which should be
zero) to 6Tr - the discrepancy between the controller
value for Tr and the actual machine value - and the slip
frequency. Matsuo and Lipo [12] describe the torque and
flux vector deviation due to variation of rotor
resistance, suggesting that the percentage deviation in
detuning of Tr results in a similar percentage deviation
in the rotor flux vector and expected steady state torque.
Sugimoto and Tarnai [33] describe the effect on the
transient response of the motor due to detuning, showing
that the d axis flux, q axis flux and developed torque
have transient terms varying with Tr for a step change in
torque demand. The expressions are experimentally
verified. Krishnan and Doran [16] describe two separate
cases of detuning:- error in rotor resistance due to
temperature effects and error in magnetising inductance
caused by saturation in the machine, and provide
analytical expressions to relate the parameter sensitivity
to the steady state and dynamic operation of the drive
system. Ho and Sen [17] describe three different control
structures based on the stator flux vector, rotor flux
vector and airgap flux vector, and conclude that parameter
sensitivity is similar for all three methods.
The net conclusion from these papers is that an on
line method for Tr identification is essential for correct
implementation of an indirect vector controller,
particularly for Tr deviation due to temperature and
frequency effects, but preferably also to estimate changes
in Lr during changes in flux levels such as field
weakening. Matsuo [12] and Sugimoto [18] describe methods
for Tr identification using extra sensory coils. Matsuo
[12] employs negative sequence current injection and
measures the resultant negative sequence voltage using
31
sensing coils, in order to identify Rr. Sugimoto [18]
employs a Model Reference Adaptive Strategy. but again
requires a modified machine which employs search coils,
and it seems that these coils may be better employed as a
direct vector controller.
The two methods for Tr identification employed in
this project were chosen because they did not require
modifications to the induction motor. The first method is
here termed "Reactive Power Measurement" and the second
"PRBS Injection".
2.6.1)Reactive Power Measurement
Garces [11] proposes a method of comparing demanded
and measured reactive powers. He relates the
to a 6Tr function and provides analogue
simulations to justify the method. Krishnan
discrepancy
computer
[ 19] and
Koyama [13] describe experimental implementations of this
algorithm with limited success, both in steady state and
transient Tr identification. The basis of this technique
is the derivation of a function which gives the necessary
information on the position and magnitude of the flux
vector. The function (Fo) itself is derived from the
reactive power expression ([11] and [13]) and can be
calculated in two ways. The first method uses the demanded
values for vsd and Vsq (assuming that these are correctly
imposed on the motor) and measured values for isd and isq
to calculate Fo as :-
F . . ( . 2o = Vsd1sq - Vsq1sd + oLswe 1sd + . 2)1sq (2.25)
A corresponding function (Fo*) can be calculated from the
controller reference values :-
(2.26)
32
The calculation of oTr is based on the error between
Fa and Fo* and provides a correction term for the value of
Tr used by the slip frequency controller. The block
diagram for this control scheme is illustrated in Fig.
2.10. This scheme works in parallel to the speed control
and will only work if the slip frequency and the stator
frequency are not zero. It will identify changes in rotor
resistance, but does not consider changes due to under-
fluxing or over-fluxing.
2.6.2)PRBS Injection
Leonhard [6] proposes the injection of a Pseudo
Random Binary Signal (PRBS) onto the d axis current
reference demand. The clock frequency of the
is chosen to be sufficiently high to
disturbances
avoid direct
influence on the machine torque due to deviations in imr·
Indirect disturbances on the machine torque are seen as
disturbances on the motor speed, and these indicate that
there is a discrepancy between the demanded and actual
rotor flux angle ee' due to detuning. Cross-correlation of
the injected and measured disturbances gives an estimate
of the error function 6Tr. The block diagram illustrating
this identification scheme is illustrated in Fig 2.11.
This method is again only useful for identification of
temperature changes in Tr.
These methods require background computational
injection
strategies
required.
and
the
Tr
controller to carry out disturbance
update. The main advantage of these
ability from
however is that no extra sensory devices are
Assuming that the motor voltage and current
references are correctly imposed on the machines using V -
Type or V - Type with current feedback control, then the
controller reference signal can be used for
identification. Krishnan [19] describes an accurate method
for calculating the instantaneous motor line voltages from
33
Id*
ca.lcula. tlon Fa,*,
iq*
of Fa*
we'*'
+ L::. F0 co.lcula. +ton .6.(l/Tr)
of !::. C1/Tr) lITr
vd* l/TrO
vq* co.lculo. tlon
Id
iq of Fa Fa
we
Rotor TiMe Corist o.nt Iderrt+Ficc +ton using
Reo.ctive Power Meo5ureMents
Figure 2.10,
eno.ble PRBS
genera. +ton
,0.Cl/Tr)
lITr
lITrO
wr
to vector
controller
frOM vector
controller
Rotor TiMe Constont IdentificQ tion using
PRBS Injection
Figure 2.11.
34
the inverter base drive signals. It is assumed that a fast
PI current controller can overcome the effects of changes
in the stator parameters due to temperature although
Lorenz [20] suggests that this is not necessarily the case
and proposes a state variable controller which provides a
current control more robust than the standard PI
regulator.
As an alternative approach to the problem of detuning
Krishnan [16] concludes that methods for improving the
physical design of the induction machine to alleviate the
severity of parameter sensitivity, may be of benefit.
35
CHAPTER 3
PARALLELISM AND MOTOR CONTROL
3.1)INTRODUCTION
This chapter outlines the proposed implementation of
the transputer network to the vector control of an
induction motor. The first section outlines the range of
products available for implementing digital control
strategies to complex real time control applications. The
second section describes the parallel nature of motor
control. The next section outlines several implementations
of multiprocessor controllers to vector control algorithms
to demonstrate the effectiveness of this approach and
illustrates the disadvantages of using conventional
processors for this application. The final section
introduces the transputer as a device designed
specifically for parallel processing applications and
compares it to parallel processing techniques employing
conventional sequential processors. It then outlines the
transputer network employed in this project and the
breakdown of the vector control algorithm into the
individual
transputer.
parallel processes implemented on each
3.2)MICROPROCESSOR TECHNOLOGY AVAILABLE FOR REAL TIME
CONTROL APPLICATIONS
The recent development of microprocessor technology
has been such that the control engineer now has a large
selection of processor hardware from which to choose. The
substantial increase in processor speed has made possible
the digital implementation of control strategies such as
36
optimal control and adaptive control for induction motors,
which were once of only theoretical value. The advent of
Very Large Scale Integration (VLSI) means that processor
design is no longer a restriction and dedicated processors
for drive control can now be manufactured.
The range of processor hardware to handle complex
real time control problems can be said to fall into the
following categories:-
1) Single conventional processor: In its baseline form
this constitutes the memory and arithmetic unit of
the control system. A high interface chip count
together with an external coprocessor or analogue
processing is usually necessary if fast real time
processing is required.
2} Microcontroller: Control orientated processor in
which common interface components such as Analogue-
to-Digital converters, Digital-to-Analogue
converters, timers, interrupt controllers and pulse
width modulated outputs are carried on board chip
thus reducing off processor chip count.
3} Application Specific Integrated Circuits (ASICS): An
extension of (2) which minimises off processor chip
count and on-chip silicon for a specific application.
4} Digital Signal Processor: A high-speed development of
(1) utilising high clock rates and reduced
instruction set on-chip architecture for fast
multiply-shift-add operations.
5) Concurrent or Parallel Architectures: Either a number
of conventional processors or specific parallel
processors are used in an effort to obtain increased
speed and/or flexibility of control processing.
For real time control problems of low to medium
complexity, microcontrollers and ASICS are principally
exploited for direct commercial application. For the
"modern", state variable based control problems, with
matrix manipulation based strategies, the DSP chips may be
37
thought to be very attractive with their pipe-lined
architecture. Parallel architectures, and particularly the
Transputer still however remain largely unassessed for
real time control. Superficially they offer an increase in
speed and hence an increase in the degree of processing
within the control system sample time. It is equally
intuitive that two or more processes operating in parallel
may continuously require each other's data so that the
processing may degenerate into "all talk and no work".
This is a significant factor in the assessment of the
suitability of parallism for a motor drive control.
3.3)THE PARALLEL STRUCTURE OF MOTOR CONTROL
A general motor drive tasking schemat is shown in
Fig. 3.1. The low level consists of signal input,
conditioning, control processing and actuator output for
the power converter. This level corresponds to the
conventional "interrupt" processing that must be serviced
for the drive function. For example in DC drives this
equates to speed, armature current and field current
measurement, speed and current control, and then the
production of the firing pulses for use with say a 3 phase
bridge converter. A switched reluctance drive requires
speed and current measurement, control calculation and
then suitable energisation of the required phases. In a
basic slip controlled induction motor drive, again speed
measurement is required, calculation of the slip frequency
and voltage amplitude is then performed, and then
production of the transistor base drives for say a PWM
inverter.
The next level covers the drive's intelligence,
supervision and memory. Intelligence is used to describe
on-going background calculations, the principle examples
being parameter estimation procedures for a partly or
wholly undefined drive system. The supervision function
38
user
I/O Tro.nsputer 1
Tro.nsputer 4
bo.ckground
cclc. ~--r---.t Interfo.ce "---toIdlo.gnostlc
Input control
Tro.nsputer 2 Tro.nsputer 3
Figure 3.1. Ta.sKing ScheMa.t for Motor Control
(Tra.nsputer Ma.pping for Vector Control)
39
covers the assessment of drive performance and arbitration
with respect to faults and perhaps various drive control
modes such as self commissioning and piecewise control.
System memory is the drive's data logger providing the
information as
drive fault.
input/output.
the form of
to performance and system status upon a
At the highest level is shown user
For a development rig this is normally of
a local keyboard/terminal for on-line
commands, parameter modification, data display and
software development. For commercial drives it is more
likely to take the form of a user control panel or a
remote communication link either to a modem or
programmable controller.
3.4)VECTOR CONTROL FOR INDUCTION MOTORS USING CONVENTIONAL
SEQUENTIAL PROCESSORS
The development of vector control for induction
motors has utilised parallel processing techniques which
use networks comprised of "conventional" sequential
processors. Gabriel [8] describes a multiprocessor
"direct" vector controller for a current controlled
voltage source inverter which uses two Intel 8085
microprocessors. One performs the speed, torque and flux
control algorithms and input /output routines. The second
performs the flux detection (using sensing coils mounted
within the machine) and current control with co-ordinate
transformations. Harashima [9] describes the
implementation of two "indirect" control structures based
on three microprocessors :- two i-8031 chips are assigned
to the 3-2 and 2-3 phase transformations and an i-8086
performs vector and speed control. For both of these
structures the signal actuation for the power converter
are not derived from the microprocessors. Kubo [10]
describes "indirect" vector control using four 16bit 8086
microprocessors for speed control and slip frequency
40
calculation, current control and vector calculation,
current component and speed detection, and pwm wave form
generation. Other examples of multiprocessor vector
control can be found in [17] and [6].
These implementations have proved the effectiveness
of applying parallel processing architectures to vector
control of induction motors. It is obvious that the major
consideration when applying parallel processing techniques
to a control algorithm is the breakdown of that algorithm
into subroutines (processes) which can run concurrently
(at the same time). It is also apparent that the actual
processor time for each of these processes will differ,
resulting in some "redundancy" of the individual
processors. It is necessary to strike a balance therefore
between the reduction of this process redundancy, and
obtaining a low process time per sample of information. A
further consideration in this respect arises from the
amount of inter-process communication required by the
algorithm, as experience has shown that this is the
principle factor in determining "processor performance".
In an attempt to lend a quantitative measure tb parallel
processor performance for motor control the following
parameters are defined for each process within the system
[46]:
tc: the time taken to transfer one byte of data from one
parallel process to another.
the communication period whose inverse is the
frequency at which inter-process communication takes
place
tt: the total process communication time within ts
tp: the process time for a given parallel process,
including communications.
The times ts and tp are application specific. Two
ratios are defined: a = tt/ts which is a measure of
computational overhead incurred in making an n
system/subsystem work to achieve the
processor
required
41
system/subsystem performance, and 8 = tp/ts which is a
measure of the processor utilisation. Expressed as
percentages, Q should be low whilst B should be high.
The major hardware design problem to be overcome by
the previously described systems has been the organisation
of inter - process communication. Perhaps the most basic
conventional approach to inter process communications
using conventional microprocessors consists of a processor
with access to local memory, the bus being connected to a
network bus via a bi-directional buffer or crossbar
switch. Communication involves a second processor holding
the processor of the receiving system, enabling the
buffer, writing to the local memory, disabling the buffer,
and releasing the held processor which can then read the
local memory. If controlled in software this gives a worst
case tc between 2~s and 5~s. A minimum tc for a
conventional bussed system is achieved with dual port RAM
in which communication proceeds within a successive
read/write cycle by the send and receive processors
respectively. This can be as little as 200ns for the
latest processors. Leaving aside the high cost of the dual
port RAM it can be shown that parallel bussed
architectures suffer from the following disadvantages:-
1) arbitration logic establishing a priority for sending
and receiving processes must be implemented in
hardware, thereby increasing design complexity and
chip count. Arbitration logic must also be present
when a processor has access to two or more dual port
RAMS.
2) the hardware complexity reduces the flexibility with
regard to system expansion.
3) multiprocessor bussing imposes severe board layout
problems, high tracking densities, multilayering and
corresponding high board costs.
4) any alleviation of the hardware and tracking
complexities result in hierarchical systems involving
master-slave architectures ego Bose [3] describes a
42
"mailbox" approach to inter - process communication
and a further alternative in the form of a "radial"
approach to the multiprocessor network, whereby data
transfer is achieved via a "supervisor" processor.
This reduces the options for task assignments.
5) software development is cumbersome, the user
generally responsible for code to download programs
to the appropriate processor.
3.5)TRANSPUTER IMPLEMENTATION OF A PARALLEL PROCESSING
NETWORK FOR VECTOR CONTROL
3.5.1)The Transputer
The Transputer is available as either a 16 bit
(T212/T222) or 32 bit (T414/T425) microcomputer and is
specifically designed for parallel processing. The device
itself contains a medium speed processor with an integer
word multiply time of 2.5~s, 2K Bytes of RAM, a memory
interface to access external local memory, two on board
timers, four bi-directional serial links for communication
with other transputers or transputer look-alike
peripherals, and an event pin for use with external
interrupts. Data transfer using the links takes place at a
nominal 10M bits/second, which results in a transfer time,
as measured for the T212 Transputer, of tc ~ 5~s per byte.
This is slow and must be considered as a significant
factor in the design and assessment of transputer
implemented algorithms. A full description of the
transputer is given in Appendix D.
A transputer based parallel processing network
suffers from none of the disadvantages associated with
parallel bussed architectures. The serial link arrangement
results in a true grid modular structure in which inter-
processor links are by the standard four wire connection.
The hardware structure itself is implicitly non-
43
hierarchical. Communication priorities and the parallel
and hierarchical planning are designated to user defined
software and system configuration using respectively, the
transputer's high level programming language, OCCAM, and
the Transputer Development System(TDS}. It is worth
emphasising that these two system utilities are as
instrumental in producing a flexible parallel processing
system as the transputer hardware itself. The OCCAM
language was developed specifically for parallel
processing and is based on modular process modelling in
which a process is defined as an independent and self-
sufficient software routine. Several processes can be
defined to run concurrently with inter process
communication being achieved using defined communication
channels. In addition to the usual arithmetic, boolean,
conditional and repeat statements, OCCAM also allows the
designation of priority to particular processes. The TDS
provides the environment for editing, compiling, and
configuring the processes to run on the transputer
network. Following the separate compilation of the
individual processes, a high level editor is invoked to
assign a particular process and communication links to
each transputer or peripheral in the network. A full
description of the OCCAM language and the TDS is given in
Appendix D.
The above is illustrative of the benefits of the
transputer system and its supporting utilities over a
parallel architecture using conventional processors. The
OCCAM structure is conducive to a systematic and
disciplined planning of parallel algorithms with tne
resulting low system development time. The hardware is
remarkably user-transparent, easily expanded and,
considering the complexity of the devices, has a low board
cost. Furthermore 16 bit, 32 bit and floating point (T800)
transputers are directly interconnectable, and slave
processors (such as DSP's which may be more suitable for
intensive vector computation or modern control than a
44
transputer) can be interfaced to the transputer network.
The fact that different computer architectures may be
combined under transputer control illustrates the powerful
modularity of the system. The disadvantages are mainly the
high cost per chip, and the long byte communication time
tc. It has been noted however that the value of tc of less
than 5~s has been reported for T800 processors operating
at 20Mbits/s communication rate.
3.5.2)The Transputer Parallel Processing Network
The parallel implementation strategies for the vector
control schemes described in chapter 2 are derived from
the tasking philosophy of Fig. 3.1. The philosophy rests
on the assumption that since the transputer inter-process
communication time is comparable, if not longer than the
arithmetic operation times, mathematical operations such
as background calculations, control processing and co-
ordinate transformations should not be parallelized. The
parallelism operates upon the strategic functions within
the overall controller, all of which operate on the data
pertaining to each sample instant. Delays incurred through
any pipelining of sample data through successive strategic
operations (eqn. between the control and actuation
processes) can if necessary be accounted for by the z-
transform delay operator. The chief consequence of the
parallelization employed is that the "low level" processes
execute sequential procedures: there are no parallel
constructs within a process. All statements and procedures
within a process are timed to execute within the system
sample time ts' This sample time is obtained from one
transputer acting as "synchronisation master", and is
communicated to other transputers via communication
protocol. It thus follows that the communication
statements themselves must be sequentially constructed: no
work can be done whilst the transputer is waiting to
communicate. In a sense this is intuitive: a process which
45
takes longer than ts will result in loss of
synchronisation, whilst a process which takes less than ts
does not need to utilise the communication wait time. The
only instance when a communication is not sequentially
constructed is when an input is totally asynchronous, ie.
user input from the host to the supervising transputer.
Here the transputer does not know when a user input will
occur. The user input statement is merely "paralleled"
with a timer process using an OCCAM ALT construction (see
Appendix D.): if no input communication occurs within a
set time, the input is ignored and the rest of the process
continues. The time spent waiting is obviously a component
making up the time ts of the supervisor.
The breakdown of the vector control algorithm into
parallel processes running on the individual transputers
(T1 - T4) is also illustrated in Fig 3.1. The transputer
network employed is described in Appendix D. The
overriding consideration is that the communication time ts
must be equal to the sample time corresponding to the
fastest closed loop dynamics of the drive itself. The
fastest drive dynamics invariably relate to the motor
drive's current or torque feedback loops which for power
drives is generally not less than 2ms. It was found that
the calculation routine for the actuation signal
generation, ie. pwm calculation or bang - bang control
required a significant process time, and this was thus
solely assigned to a T212 processor (T3), and dictated
the system sample time ts (ie. acted as synchronisation
master). For this project ts was chosen to be 250~s,
primarily as this was the minimum time required to execute
the actuation calculations for the bang - bang controller
on T3. It was then found that the signal acquisition,
speed control, vector control calculations and current
control could be implemented on a single T212 transputer
(T2) running in parallel. The control calculations would
be initiated by communication with T3 and would be
completed before the next communication with T3 to ensure
46
synchronisation of the processes. The timing and
synchronisation are discussed in detail in chapter 5. The
supervisory routine for the drive was implemented on the
T414 (T1) so that the 32 bit range of the device could be
exploited for signal analysis, and the 2M Byte memory
array used for data capture. Connected directly to this is
the host machine which provides user interaction, and
access to the hard disk for permanent data storage,
graphics and plot utilities. The third T212 processor (T4)
is also connected directly to the T414 transputer and
provides the drive's background computational ability for
parameter identification.
47
CHAPTER 4
THE TRANSPUTER NETWORK - INVERTER INTERFACE BOARDS
4.l)INTRODUCTION
This chapter will outline the design and operation of
the interface circuits used for motor speed and current
measurement, and for base drive signal generation for the
inverter. The philosophy behind the design of external
circuits which have to interface with the transputer
network is that they should "appear" to the network as
parallel processors, which communicate to the network via
standard transputer serial communication links.
4.2)THE COll LINK ADAPTER
The communication interface for the peripheral
devices on the external interface boards used in this
project has been the INMOS IMS COll Link Adapter [21], a
device which acts a transputer "look alike" peripheral
when connected to a transputer via a link. The C01l can be
configured to operate in two modes. In Mode 1 it has two
byte wide parallel ports, one for input, one for output.
Serial information transmitted from the transputer is
converted to latched parallel output, and conversely
latched parallel input can be transmitted to the
transputer in correct serial form. In Mode 2 it provides
an interface between the serial communication link and a
microprocessor bus via a bi-directional byte wide port.
All of the Link Adapters employed in this project have
been used in Mode 1.
The schematic diagram for the C011 configured for
Mode 1 is illustrated in Fig. 4.1.
48
-n
.::f. ._/
U d
d >
o cs
I"'--
I
C)
cs
-
11~ro~.I co
Cl! Cl!
U
-P U
o :::> d
+> 4- 0.4-
:::> s,
-P ~0.. ())
:::> Cl!c
-P o -P
--
c c
--
--
I I
I
£:
If)
Cl!Cl! U .x+> -- c
If) >
--
s, -oJ>,
lfl Cl!
lfl
I II r1
49
£:
o
s.
0)
o
~
.x
U
0
_.;
P=l
s,
Cl!
-P
0.
o
-n
-r
.::f.
c
...-i
_J
~
...-i
...-i Cl!
0 s,
U :::J
(/)
CJ)
L u,
........
(/)
0
L
Z
t--f
The control logic consists of the SeparateIQ
connected to
communication
ground to select Mode
speed of 10 Mbits/sec,
1 with a
the Reset
pin,
link
pin,
connected to a momentary action switch to allow the Link
Adapter to be reset at start up, the Clockln pin which is
connected to an externalS MHz clock circuit, and the
CapMinus pin. The serial link is connected directly to
LinkIn and LinkOut using non buffered twisted pair cables.
The Linkln pin of the Link Adapter is directly connected
to the LinkOut pin of the transputer data source, and the
LinkOut pin of the Link Adapter is connected to the
transputer's Linkln pin.
To output data to the serial link from the interface
board, the information must be presented to input port
(pins 10 - 17) and IValid must be taken high by external
circuitry to commence the handshake. The data is then
transmitted along the link, via LinkOut, and the link
provides an acknowledge signal on LinkIn. This signal
makes the Link Adapter take lAck high for a prescribed
period, and IValid must then be taken low to complete the
handshake. The timing diagram for this procedure is shown
in Fig. 4.2.
Data is input from the serial link via LinkIn, and
immediately latched to the output port (pins QO Q7).
QValid is taken high to commence the handshake and Qack
must be taken high by external circuitry to acknowledge.
The Link Adapter then transmits the acknowledgement on
LinkOut. The timing diagram for this procedure is
illustrated in Fig. 4.3.
4.3)THE SPEED INPUT BOARD
The motor speed signal is derived from an Incremental
Optical Encoder mounted directly on the shaft of the
induction motor. The general specifications for this
device are given in Appendix A. The encoder provides a
50
10-7 ~,- XXXXX>!0<---- ~~~~h~r~(
! ~ inposed by"--_ ____/ per-ipher-o.lIVo.lId
lAck ! IMposed byCall
! Id
!
LlnkDut _l._d:::.;o.~t:.::o.:........!... _
Llnkln
TiMing Dio.gro.M for Do.-to. Input -to
-the link Ado.p-ter
Figure 4,2,
Llnklnl '-d_o._t_o.L-1 _:IL,::d=o.....::..tO'::JI --1..::1d
QO-7 "O<XX>('----------.. r------- ~fu~sed by
QVo.lld ~ _../ IMposed byCall
IMposed by
perlphero.(QAck
UnkDut _JI~O'c:::C!2.kIL- .L:1 o,:!.:::ck
TiMing Dio.gro.M for Do.+c Ou-tput Fr-on
the link Ado.pter
Figure 4,3,
51
pulse train on one of two lines dependent on the direction
of rotation of the shaft. The form of these signals are 5
Volt CMOS using complementary drivers, and 10,000 pulses
are produced per revolution of the shaft. The method
chosen for speed measurement was to count the number of
pulses produced on each line in a set sample period (2
ms), dictated by the control transputer. The speed input
board thus requires two 16 bit counters (one for each
direction) and a suitable multiplexer to channel the four
bytes into the byte wide input port of the link adapter.
The schematic diagram for the speed input board is given
in Fig 4.4.
The pulse train signals are input to the board via
DSa8C20 CMOS Compatible Differential Line Receivers. Logic
is provided for counter clear pulses to be superimposed
at start up and the pulse train is then fed directly to
the counter. The 16 bit counter is made up of two 74LS591
a-Bit Binary Counters, specifically chosen as they have an
a-bit output register, and can be easily cascaded. The
four resultant byte values are passed to the link adapter
via four 74LS153 Dual 4 Input Multiplexers. The control
logic for the counters, multiplexers and the handshaking
of the C011 itself is shown in Fig. 4.5.
The signals QValid and QAck are wired together to
create the correct handshake for receiving data from the
link. The counters are disabled directly when Q4 is taken
low by the controlling transputer at the start of the
counter read cycle, and the inverse of this signal, QO is
used to enable IValid for the output of data to the link.
The address lines (select 0 and select 1) of the
multiplexers are changed by JK Flip-Flops triggered by the
rising edge of lAck. Also IValid is taken low when the
lAck signal goes high, resulting in the Link Adapter being
"disabled" during the changeover of the multiplexers. When
the four bytes have been read by the transputer it outputs
two further control bytes to clear the counters, restart
the counters and reset the JK Flip-Flops. The timing
52
If)
-,
-,
~
I
,..
0
c:s
lfl :::I. L
-J U
0 If) <l:
Q;
......
LC5Q;U ... -P
~
...--I
.x Q_
-r> cL-en ...--I
c O"TI 0 0 E: 0
0 "TI-J .. U -J"TI
U 0 ~ 7 d
d
OJ
> L ~
......
~
12
Cl cS
(to Vl
CO
U ~
s, ~ Vl
OJ (to Vl L
+' +'
(to
c c ~
(l)
~
~ <:5
0 0 <:5 j~ Xu u cS Q;
o....Q -JQ_
. C --,.. -- Cl) -P
-J
~ ::J
£
L ';'L ~ L ~L :=I
\
1\
'"
If)
....
I CO I co
0 CO
u... u, If)
r-, ....
I CO I CO
L 0 r--.
-P Q; ~ ~
.. ..
_Q -P
-JII'"
C
--,.. -,o ::J
~ 0
U L
-P (l)
..II" ...Q -t->
..
c
... <o ::J
..
~ 0
.. U
..
"TI
Q;
L
If)
0 S · . L3: Q;L · .. >
0
~
· .
(l)
4- · .
L
~o~LQJ
C\J
QJc:5
Q; 0
o.U
Vl cQJ
53
~
L
0
0
P=l
-P
::5
Q_
C
f-i
"TIQ;
(l)
Q_
V)
Q;
...s::::: -
-P ..q-
-
"¢
L
0 Cl!
4- L
::>
£ 0)
0 u_
L
0)
0
~
.x
U
0
P=l
I I 1 1 L 1 1 f'.0 ......
t= .p .p .p +> +' .p +'
S). S). S). 12 12 12 12 12
......
("') <l:
r-- l() 1- M ("I) I- M
...... l[") l[") l()
V ..... ...... .....
r-, ..q- ..q- 0 ..q-
r-
r-, r-, <[ r-,
......C\.J("I)v
......(\.JM..q- ..... (\.J("I)v I- i-
.£.£.£.£odd d ..Q..Q..Q_Q
I
~
II
0...... ,,' r-, CO (J\ l()
u.u, u, u...u._"'L:
o 0
0\ (J'I
If) l[")
V ..q-
.::t.::i."O .::f.::i.f'.
~Uu U UU~
ULU L ~U u
~ I~I
0...... r-,
~~"'~
o
(J\
l()
v
.::t..::t." 0
L u u u
U LU L
4W I 11
-
o
54
("')
J C3
(5
s,
o
0
~
ClJ
U
d
4-
s,
ClJ
-t->
c
I--l
(5
ClJ
ClJ
0... l.()(/)
~
s, Cl.!0 s,
4- :::>
(J)
£. u,
d
s,
(J)
d
--
~
-t->
--::s
u
s,
u
QOand Q2
u-Ql
Q4
IValicl _j U U U I
lAck n n n Il
AO
Ai
cck o.nd rck IUl nJUl
TiMing Dto.qr-o.n for Speed Input BOQrd
Figure 4,6,
55
diagrams for the control signals are shown in Fig. 4.6.
The occam procedure executed every speed sample
instant on the controlling transputer for inputting the
two speed count values is (see Appendix D for syntax):-
SEQ -- input speed
control.to.speed #07
speed.to.control ? BYTE O;BYTE 1;BYTE 2;BYTE 3
control.to.speed #10; #12
forward .- (BYTE 1 < < 8) \/ BYTE 0.-
reverse .- (BYTE 3 < < 8) \/ BYTE 2.-
It can be seen that the counters are disabled during
the read cycle. A total of seven byte transfers are
required during this period resulting in a "dead time" of
35~s. This is felt to be negligible for a 2ms sample time
(1.7%).
4.4)THE CURRENT INPUT BOARD
The Current Input Board is made up of two separate
circuits. One conditions the analogue signals derived from
the transducers. The second converts the information to
digital form and passes it to the serial link.
4.4.1)The Analogue Signal Board
The three transducers employed for this
measure motor line currents are LEM LT-80-P
project to
Hall Effect
devices described in Appendix A. The magnetic flux created
by the primary current is balanced through a secondary
coil with a Hall effect sensor. Its main advantages are
that it can correctly follow any current signal, offers
complete electrical isolation, and has a large measurement
range (80 A). The transformer ratio used was 1 : 1000, and
the secondary current is converted to a voltage in the
56
range +/- 2.5 V using a 47kC resistor. The signal is then
buffered using a simple voltage follower. These devices
are mounted near the inverter. The buffered signals are
transmitted to filter board mounted within the control box
using screened cable to reduce noise pickup. Each signal
then passes through a standard low pass filter circuit
(cut-off frequency 2 kHz). Gain and offset adjustment for
each filter are provided to correct for any discrepancy
between the transducers and sensing resistors. The
schematic for this circuit is illustrated in Fig. 4.7.
4.4.2)The Analogue to Digital Conversion Board
This circuit was developed as a multi-channel
analogue to digital card for interfacing to a
and provides access to up to 8 independently
transputer,
addressable
analogue signals. The circuit diagram for this system is
illustrated in Fig. 4.8.
The 3 analogue current signals are fed into a DG508
Analogue Multiplexer, whose address lines are fed directly
from QO-Q2 of the Link Adapter. The analogue-to-digital
converter is an AD 7572 12 bit device with a conversion
time of 5~s. The input requirement to this device is a 0-
5V signal and the corresponding output is in the range
#0000 #OFFF. Therefore the buffer circuit is included
to give bipolar offset and gain adjust for the +/-2.5V
input signal. Conversion is initiated by the controlling
transputer by outputting the address byte for the
multiplexer to the Link Adapter. The signal QValid takes
the control input to the AD 7572 (HBEN) low and starts the
conversion process on the multiplexed analogue signal. The
BUSY 'output signal of the device is taken low for the
period of conversion (tcon). On completion of the
conversion the lower 8 bits of the digital value obtained
are presented to IO-I7 of the link adapter, and the signal
BUSY goes high, which takes IValid high and initiates
communication to the transputer of this byte.
57
-J
d
-p
-(5) """0
--L
"""0 d
o 0
-p..Q
L
CJJ
-p U
c ::::5
CJJ """0
L V1
L c
::::5 d
U L
-p
-p
c
CJJ
£
ClJ
L
::::5
V1
d
CJJ
L
-p
c
ClJ
L
L
::::5
U
L
o
4-
"""0
L
d
o
P=1"TI
QJ
c
QJClJ
QJ-
s......Q
Ud
l/lU
-J
o
c
CJ)
(/)
-p
c
ClJ
ClJL
cs....
-- ::::5
-JU
OJ ~
::::5
Q) ClJ
_9 L
d :::5
C Q)
<[ Le;
L
o
4-
£
o
L
Q)
d
~
-p
-5
U
L
U
58
59
o
c
0)
D5
Communication is acknowledged by the transputer by taking
lAck high. This takes IValid low, HBEN high and the signal
input READ to the AD 7572 high for a time dictated by an
RC timing circuit. The higher 8 bits of the digital value
are then presented to the link adapter and when READ
returns low, the new byte is read by the transputer. The
circuit is then ready for the next conversion.
The software procedure running on the transputer for
current input is
SEQ -- current input
control. to.current #01
current. to.control ? BYTE 0; BYTE 1
control. to.current #02
current. to.control ? BYTE 2; BYTE 3
control. to.current #03
current. to.control ? BYTE 4; BYTE 5
la .- (BYTE 1 « 8) \/ BYTE 0.-
lb .- (BYTE 3 « 8) \/ BYTE 2.-
lc .- (BYTE 5 « 8) \/ BYTE 4.-
The timing diagram for communication with the current
board is illustrated in Fig. 4.9.
The current
calibrated using
503 Current probe
was 1 bit per 27
input circuits were balanced and
a Tektronix A6303 Current Probe and AM
amplifier. The resultant scaling factor
rnA, allowing a maximum peak current of
55A to be measured.
4.5)THE PULSE GENERATION BOARD
The PWM actuation transputer provides three byte
values corresponding to the three phase pulse widths
required per carrier half cycle (250~s). The reason for
this time value is discussed in chapter 3. The pulse
generation board is thus designed to convert these values
60
QVo.lid
_ll~------------------~I
QO - Q2 =X~ M..:...U.:...:lt..!:.IP__..:le:_X_er_o._dd_r_e_Ss )(
QAck
HBEN
BUSY
tconII·...--- ...~I
IAck
----------~~---------
____________~n__nL_ __
IV o.lid
RD
Signo.l TiMing Dto.qr on for the
Current Input Boo.rd
Figure 4,9,
besic P'w'M wo.vef or n
upper tro.nsistor bo.se
drive
la wer t r 0.nsis tor bo.5e IL___JnL- _ ____,nL- __ __.nL. __ 1
drive
Figure 4,10, Inverter Drive Slgno.l Requirerlents
61
to into three pulse trains and then convert these into the
correct drive signals for the inverter. The inverter
requires nine drive signals, three per phase: namely a
basic pwm pulsetrain, a base drive signal for the upper
transistor per phase and a base drive signal for the lower
transistor per phase. The transistor base drive signals
must have a lockout introduced onto the rising edge to
prevent "shoot through" faults. This was set to 20}J.son
the recommendation of the manufacturers of the inverter
used. An example of the signals required for a single
phase is shown in Fig. 4.10.
Two further requirements of this circuit are
electrical isolation between the control network
electronics and the inverter's electronics, and 5V to 15V
step up as the transputer network is 5V CMOS whereas the
input signals to the inverter need to be 15V CMOS
compatible. The protection circuitry of the inverter
itself comes between the pulse generation board output and
the transistor base drive units themselves. This means
that the inverter's protection circuits (overcurrent,
overload, overvoltage, undervoltage, overtemperature, and
external trips) could be utilised.
The circuit diagram for the pulse generation board is
shown in Fig. 4.11.
The device chosen for pulse width timing was the
INTEL 8253 Programmable Interval Timer (PIT), which when
configured in Mode 1 provides three separate programmable
monostables [22]. The device contains three internal
registers for the three count values (8 bit) and a further
register to store the mode configuration. Information is
passed to the PIT using two C011 Link Adapters, one to
provide the control and address signals, and the other to
provide the configuration data and count values. When a
count register is to be loaded with a new value, the
transputer outputs a control byte to the address link
adapter (LA1) which correctly addresses the required
register using AO and A1, and disables the read, write and
62
a<: I.
:z:
~~ Ia<:0l:J ~~> <I:
<I: a<:w
~ ~~
:z: D!aI
~ ItQ._ Q._
:::>
:>
.If")
-
:>o...1f")
::>.
0...
w·f-:
(I).
Iii
~.
z·
<t:
it
I I
I I
I I
I I
I I
<:S
c
d
C a.
o :::s
+>'d a.
-0 Q}
U1 ~
Cl "C3 - • - C3
63
+,""
+,Q}
-+'t: s,
.s:Q}
u >
U1~
15
L
0
0
~
c
0
-P
0
L
OJ
c
OJ
1.'J
OJ
lJ'\
:5
CL
OJ ..-I
.£: ..-I
-P .q-
L OJ
0 L
4- :5
CJ)
£. u_
0
L
CJ)
cS
t=:l
-r>
:5
U
L
U
gate enable signals. The count value is then presented to
the PIT using the data link adapter (LA 2). This is
written to the register by outputting a further byte to LA
1 which takes the write pin low. This process is repeated
for the other two count registers. The three counters are
initiated by taking the gate pin high (rising edge
triggered) using LA 1 and the count values are then timed
out using a 1 ~s external clock circuit. The counter
enable signal is synchronised to the carrier "peaks" and
"troughs" generated by the transputer's on board timer,
but actual loading of the count values can be done at any
time during the carrier half cycle. When the gate is
enabled the output of the counter goes low and when the
terminal count is reached the output goes high. The
software procedure for loading the counters is
SEQ
counter.add ! #8F
counter.data ! pulse1
counter.add ! #OF;#AF
counter.data ! pulse2
counter.add 1 #2Fi#CF
counter.data ! pulse3
counter.add ! #4Fi#FF
The timing diagram for counter loading and enabling
is shown in Fig. 4.12.
The pulses provided by the PIT are passed through
opto-isolators and voltage step up devices with negligible
delay to the rising and falling edges. The correct PWM
waveforms are then produced by using the rising edge of
these signals to clock a JK Flip-Flop. The non-inverted
output of the JK Flip-Flop is used as the PWM drive signal
and the basis of the upper transistor base signal. The
inverted output is used as the basis of lower transistor
base drive signal. The 20 ~s lock-out delay (as
recommended by the inverter manufacturers) is then
64
AO
A1
\JR
GATE
QO - Q7 ~ pulse 1 X pulse 2 X,--,-pU_lS_E?_3 _
Figure 4,12, Signo.l TiMing Dio.gro.M for the Pulse
Gener-o i:ion BOQrd
PIT Output
P\JM 'Wa..ve+cr n 11----1
Upper i:r~nsisi:orl
co se drive .
Lower -tra..nsisi:or __j
ba..se drive .:
I U
I I l__j
~ __~I1~ ~Il~ _
_ .._
lockout
Figure 4,13, Pulse Genera..'tion BOQrd Output \J 0.ve+or ns
65
introduced onto the rising edge of the transistor drive
signals using a simple RC variable delay network. Before
being passed to the inverter the transistor drive signals
pass through AND gates with control signals derived
directly from LA 1. This allows only two phases of the
inverter to be used if required, a technique to be
employed in the future for self-commissioning. The
thegeneration of the drive signals for one phase of
inverter is shown in Fig. 4.13.
The operation of this circuit has proved
effective up to 2 kHz carrier frequency, and it is
the "load time" of 50 }J.S (10 byte outputs) which
restrictive.
very
mainly
proves
4.6)INTERFACE BOARD DESIGN AND CONTROLLER LAYOUT
It is worth mentioning the considerations made when
designing the interface board layout and the overall
attention paid to system noise, grounding and interference
problems. Experience showed that the operation of the C011
and its associated components was particularly prone to
ground noise, and resulted in communication failure and
control system "crashing". Furthermore the serial nature
of the communication links proved susceptible to airborne
electromagnetic interference caused by the switching of
the power transistors within the inverter. The
configuration of the boards and power supply layout was a
result of "trial and error" based on methods described by
Horowitz [23], and is described here.
The interface boards were laid out on double sided
PCBs, with tracks routed in order to minimise route length
and capacitive and inductive coupling between signals.
74HC series components were used where TTL compatibility
was required, but 40 series CMOS used where possible to
increase ground noise immunity. Liberal use of ground
planes and decoupling capacitors were also used in order
66
to increase ground noise immunity and common mode
rejection.
The B004 board was mounted within the IBM PC itself
and derived its 5V power supply from it. The power supply
for the IBM PC was isolated from the mains earth. The
interface boards were mounted within an earthed aluminium
box to provide a Faraday shield against airborne carried
noise. A single 5V power supply was used for the B006
board, current input board digital circuitry, speed input
board and speed encoder, and the non isolated pulse
generation board circuitry, and this was mounted within
the box. The ground point of this supply acted as the star
point for the grounds of all the boards used, and it was
at this point that the transputer network was earthed.
Further power supplies for the pulse generation board (5V
and 15V isolated) and the analogue current input board
(+/- 15V) were mounted within the box and all used mains
filters. Thick wires were employed to connect power supply
grounds to the relevant boards. This configuration reduced
the susceptibility of the control circuitry to ground
noise carried on the mains earth and ground loops.
The main sources of airborne interference were the
signal leads connecting the current and speed transducers
to the interface boards, and the cable connecting the
pulse generation board to the inverter itself. The current
transducers were mounted close to the inverter and used a
separate +/- 15V power supply (with mains filter). This
supply also powered the buffer amplifiers. The cable used
for the current signals was single core screened, with the
screen used to common the grounds at sending and receiving
ends. The speed encoder signals were derived from
differential line drivers within the encoder itself, which
provided sufficient airborne noise immunity. The pulse
train signals for the inverter were screened with the
screen grounded at the control circuit end.
67
The resultant control circuit worked effectively.
However, it was noticed that when high acceleration
currents were used by the controller, the whole
microprocessor system would "crash" on an intermittant
basis. The nature of this problem was found to be
"Transputer Deadlock" - a problem associated specifically
with parallel processing.
The term Deadlock describes a situation whereby a
process is waiting for a communication from another
parallel process before it can procede, and that
communication does not arrive. This scenario is normally
due to incorrect implementation of the parallel
algorithms, but in this case the cause is associated with
the physical operation of the transputer's serial links
themselves. The high acceleration currents cause increased
airborne and ground noise, which can interfere with the
data transmission from the link adapters to the control
transputer. If the acknowledge data on the serial link is
corrupterd during a communication, then the recieving
process will not complete the communication. It cannot
therefore proceed to its next instruction and this
causes the process to stop. If the control processor
stops, it cannot then provide the communications required
to the overseer and actuation processors, and these
processes will also stop. The deadlock is thus
throughout the whole of the control network,
system must then be shut down and rebooted.
propogated
and the
It is thus essential that attention be paid to the
problems of noise reduction in a transputer based control
system in order to ensure the correct operation of the
communication links.
68
CHAPTER 5
TRANSPUTER IMPLEMENTATION OF VECTOR CONTROL
5.1)INTRODUCTION
This chapter describes the occam implementation of
the vector control algorithms described in chapter 2. The
actuation procedures are described initially so that the
output requirements from the control processors can be
precisely defined. The supervisory routines running on the
host and the B004 motherboard are described next as they
are common to all of the vector control algorithms
employed. Sections three, four and five describe the
control processes employed and how they interface with the
actuation transputer and the transducer boards. Finally
the implementation of the Tr identification strategies on
a fourth transputer are described, noting their
"background" nature.
5.2)ACTUATION SIGNAL GENERATION
The control strategies employed demanded that two
separate actuation routines be devised for providing the
required drive signals to the inverter. The first method,
commonly termed Pulse Width Modulation (PWM) imposes motor
voltages, whereas the second method, here termed "Bang-
Bang" control, imposes motor currents. It was decided that
the routines should calculate the required pulsewidths for
each phase of the inverter and then output the values to a
custom built interface board which would then convert them
to real time pulses with suitable "lock out" protection.
The operation of the board is described in chapter 4, and
requires only byte wide output on two separate serial
69
links from the actuation transputer.
5.2.1)PULSE WIDTH MODULATION
5.2.1.1)The PWM Algorithm
The principle of sine weighted pulse width modulation
utilises the comparison of a triangular "carrier wave"
with a sinusoidal "modulation wave" in order to generate
the pulses. The most popular techniques employ a fixed
amplitude carrier wave, and a modulation wave whose
amplitude, phase and frequency are controlled. The
frequency of the carrierwave can be held constant
(asynchronous PWM) or varied such that the carrierwave is
always in synchronism with the modulation wave
(synchronous PWM). Digital generation of PWM waveforms is
typically based on one of these analogue techniques
[24],[25],[26],[14],[27] and although the main advantage
of synchronous PWM over asynchronous PWM is that unwanted
harmonics are reduced at higher speeds, asynchronous
techniques are easier to implement. For this reason a
fixed frequency carrier wave was employed in this project.
The calculation strategy employed in this project is
directly analogous to the traditional analogue method for
pulse width modulation, and is known as "asynchronous
symmetrical regular sampling". A fixed frequency, fixed
amplitude triangular carrier wave is compared with a
sinusoidal modulation wave, whose frequency, amplitude and
phase are control inputs. The ratio of the modulation wave
amplitude to the carrierwave amplitude is called the
"modulation index" (m). Calculations based on the
instantaneous values of the carrier and modulation waves
at each sample point provide the pwm waveform. The basic
principle behind this strategy is shown in Fig. 5.1. and
compared to the analogue derived output.
70
OJ
:J
.. (J)
0) O.I.Il £ d:J Q_ c: Cl0 E d cc
QJ0 0 +>L I.Il
c 1Il
.c OJ ()U cSc L 0 OJ>.
:J ~ >1Il +> :J s,0 Cl (J" OJc OJ
-0..
71
c
o
-p
o
At each sample instant Tn the time until the next
crossing point of the carrier and modulation waves (tn)
can be approximated by
tn = (hn - vn)/slope ( 5 . 1 )
where hn is the instantaneous carrierwave value, vn is the
instantaneous modulation wave value at the sample point
Tn' and slope is the slope of the carrier half cycle. The
sample instants are chosen to be the peak and trough of
the carrier wave, and thus hn and slope are software
constants. The modulation wave is derived from the
reference values input from the control transputer. The
frequency demand is suitably scaled to provide a step
angle through a sine "look-up" table, and any phase change
demand can be easily added to this. The voltage amplitude
demand acts as the modulation index and when multiplied
with the
modulation
sine value, provides suitable
wave with respect to
scaling of the
the carrierwave
amplitude. The resultant count value tn is in ~s, and
ready to be sent to the interface board.
It can be seen that as m approaches unity, the
calculated pulsewidths become small. A requirement of the
switching transistors used by the inverter is that they be
switched on or off for a minimum period of 20~s so that
correct switching is achieved. Therefore a procedure is
required to detect pulses less than 20~s long and ignore
or "drop" them. Furthermore, as m extends beyond unity it
can be seen that a significant number of pulses need to be
dropped from the peak of the modulation wave, ie. set the
pulses generated to greater than the sample time. This
consideration proves quite complicated as the design of
the interface board requires that in this mode, the next
generated pulse may have to be altered or ignored to
provide correct clocking of JK Flip-Flops.
72
S.2.1.2)OCCAM Implementation of the PWM Algorithm
The occam pseudo-code (see Appendix D) for the PWM
routine (PWM.TST) is shown here. The numbers shown in
brackets next to a particular process represent the time
taken to execute that process in microseconds.
SEQ
setup
startup
PRI PAR
SEQ
WHILE TRUE
SEQ
PWM generation
initiate low to high half cycle (2)
read control variables (30)
enable counters (5)
access sine look-up table (10)
calculate modulation voltages (12)
calculate pulsewidths (20)
load pulsewidths to counters (45)
time out half cycle (1)
initiate high to low half cycle (2)
pass flux angle data to control (20)
enable counters (5)
access sine look-up table (10)
calculate modulation voltages (12)
calculate pulsewidths (20)
load pulsewidths to counters (45)
time out half cycle (1)
SEQ -- dummy
do nothing
73
The setup process defines the variables and
constants employed in the program, and also defines the
procedure "buffer" which is used at startup to read in the
values for the look-up table and assign them to memory
addresses. The start-up procedure executes buffer, assigns
the initial values to the variables, and programs the
interface board to run in the correct mode by outputting
the required control and mode information to the interface
links. The initial count values are then passed to the
interface board.
The
sequential
PWM routine itself is actually a
process, but is defined in software as a
single
high
priority process running in parallel with a low priority
process called "dummy". The reason for this is that the
process requires access to the transputer's high priority
timer, and this is only achieved by defining it as a high
priority process. Dummy does not actually do anything. The
PWM routine is governed by a WHILE TRUE construct which
means that the process will be repeated indefinitely.
The low to high carrier half cycle is initiated by
reading the value of the transputer clock to the variable
"now". The control variables are then read in from the
control transputer from the link "control.to.pwm", and the
design of the algorithms running on the other transputers
dictates that this information will be available as soon
as the pwm transputer is ready to receive it, ie. the
control transputer will be waiting for this communication.
The counter start signal is passed to the interface board
precisely 35~s after the start of the cycle by employing
the "TIME? AFTER (clock value)", which provides a wait
until the transputer clock value specified is reached.
This initiates the timing out of the count values loaded
in the previous half cycle. The look-up table pointers are
then incremented using the step angle derived from the
frequency input. The look-up table itself consists of
10,000 integer values (0 - 100) representing 0 180
degrees of a sinewave. The same look-up table is accessed
74
for 180 360 degrees and a toggle is set to -1. Two
pointers are used at 90 degrees phase shift to access sine
and cosine information for a particular flux angle. The
three demodulation voltages are calculated directly from
the d and q axis voltage demands and flux angle
information using the transformations given in Appendix c.
The parameter "hI!is calculated as the difference
between the carrier and modulation values. If this value
is negative then the pulsedropping is required and the
output must remain high for the whole of the carrier half
cycle (positive pulsedropping). The routine checks the
previous pulsewidth to see if a dummy pulse must be
generated to correctly clock the interface board.
Similarly if the value of h is greater than 20,000, the
output must remain low for the whole of the half cycle
(negative pulsedropping). If pulsedropping is not
required, the pulsewidth is calculated and checked to
ensure that it is not too long or too short (minimum
pulsewidth requirement of the transistors). Again the
previous pulse must be checked and this one altered if
necessary to maintain correct clocking of the interface
board.
The calculated pulsewidths are loaded onto the
interface using byte output instructions to the serial
links. The transputer then waits until the clock value has
reached (now + 247) and then initiates the high to low
carrier h~lf cycle. This results in a process time for the
sample of 250~s. This was chosen as the lockout time and
minimum pulse time for the inverter are 20~s and thus will
form only a small percentage of the PWM sample time. The
second cycle is again initiated by reading the transputer
clock value, and then outputs the flux angle sine and
cosine values to the control transputer. The rest of the
routine is similar to the first half cycle, except that
the carrier value and slope are inverted, and no control
variables are input. At the end of this half cycle the
routine repeats itself.
75
The resultant system provides a 2 kHz PWM
with a 250~s delay between input of the control
and enabling of the count values.
waveform,
variables
5.2.2}THE "BANG-BANG" CURRENT CONTROLLER
5.2.2.1)The Bang-Bang Algorithm
The actuation transputer employed in this mode
provides a fast "localised" current control for the
inverter itself, by comparing the reference and measured
line currents at a sample instant and switching the upper
or lower transistor of the line according to the result,
for the whole of the sample period. For this mode the the
current measurement needs to be performed by the actuation
transputer itself. The inverter drive signals are produced
using the same pulse generation board as for PWM
generation. The operation of the current detection board
is described in chapter 4, and for the purposes of program
development can be considered as presenting the
instantaneous current measurement as a 16 bit word on the
serial link "current.to.control", immediately after an
address byte has been output to the link
"control.to.current". This algorithm is implemented with a
sample time of 250~s, and again can be considered as a
carrier with two distinct half cycles, although in this
case the carrier has no influence on the calculation
strategy.
5.2.2.2}OCCAM Implementation of the Bang-Bang Algorithm
The occam pseudo-code for the bang-bang controller
(CCON.TST) is given here.
76
SEQ
setup
startup
PRI PAR
SEQ
WHILE TRUE
SEQ
pulse generation
initiate first half cycle
read control variables
access sine look-up table
(2)
(30)
(10)
calc modulated reference currents (12)
lead lag compensation (23)
measure line currents (43)
compare meas and ref currents
and calculate pulses (7)
demodulate measured currents (27)
load and enable counters (50)
time out half cycle (1)
initiate second half cycle (2)
pass measured currents to control (20)
access sine look-up table (10)
calc modulated reference currents (12)
lead lag compensation (23)
measure line currents (43)
compare meas and ref currents
and calculate pulses (7)
demodulate measured currents (27)
load and enable counters (50)
time out half cycle (1)
SEQ -- dummy
do nothing
77
The structure of this program is similar to that of
the PWM program. The setup and startup procedures define
the variables, constants and initial values, load the sine
look-up table, and program the pulse generation board. The
calculation strategy is implemented as a high priority
parallel process in order to access the high priority
timer and is executed in an infinite loop. The low
priority process "dummy" does nothing.
The first carrier half cycle is initiated by reading
the current value of the transputer clock to the variable
"now", and then the reference values for frequency, id and
iq are read immediately from the control transputer. The
flux angle pointers are incremented and the flux angle
sine and cosine values accessed from the look-up table.
The three instantaneous reference values for the line
currents are calculated from id, iq, sineSe and cosSe
using the transformation given in Appendix C. If required,
Lead-Lag compensation is introduce onto these reference
values using the binomial transformation outlined in
Appendix E.
The three instantaneous values of line current are
measured directly from the current input board by sending
a control byte to address the relevant transducer, and
then reading the measured value. The measured and
(compensated) reference values for the instantaneous line
currents are then compared for each phase and the result
used to determine whether the upper or lower transistor of
each inverter leg should be switched on for the next half
cycle. These switching states are then compared with the
previous switching states for each leg, to determine
whether a "short" (10}J.s)pulsewidth is required to clock
the interface JK Flip-Flops, or a "long" (255}J.s)pulse is
required so that the Flip-Flops are not clocked during the
half cycle. Modulation of the measured line currents for
monitoring purposes is then carried out using the
transformations given in Appendix C. The interface board
counters are then loaded using the same routine as for the
78
PWM strategy. A TIME? AFTER (now + 210) wait statement is
then employed to ensure that the pulse initiation is
synchronised to the same point of every carrier half
cycle, and the counters enable by outputting the correct
control byte to the interface board. The half cycle is
completed by a further wait statement to time out the
250~s sample period. This value is chosen as the minimum
time required for the actuation calculations. The second
half carrier cycle is identical to the first, except that
the measured values of id and iq are output to the control
transputer,
modulation
and no reference values are input. The
of the measured currents is redundant in this
half cycle. The resultant system gives a 2 kHz sample
time.
5.3)SUPERVISORY ROUTINES
The user interface to the vector control network is
provided by supervisory routines running on the B004
motherboard and the IBM PC itself. The specification for
these routines were that they were to provide
1)keyboard and screen drivers for direct motor speed
control
2)an initialisation routine to allow the user to
change the control parameters at startup
3)an ability to change the value of rotor time
constant used by the controller whilst the motor is
running
4)access to instantaneous variables used by the
controller
5)an ability to capture data over a prescribed period
and transfer this data to a disk file
6)access to graphics and plot routines to allow
visual data analysis whilst the motor is running
7)an ability to call up background Tr identification
routines when required for assessment
79
The basis of the software design was to put the onus
of the supervisory work onto the B004 motherboard and use
the host only as a "buffer" routine. Provision for writing
to disk files must be provided within the host routine,
and it must also be capable of accessing graphics and plot
routines without disturbing the operation of the
transputer network.
5.3.1)The OCCAM Implementation of the IBM PC Supervisor
This program is written in occam as a sequential
procedure, (SETUP.EXE) and compiled and linked to the
host's processor using the TDS development system. The
occam pseudo-code for this process is given here.
SEQ
setup
startup
WHILE TRUE
SEQ
IF
choice = 'y'
... read and display current measurements
choice = 'c'
... change speed
choice = 'r'
... take 600 consecutive measurements
choice = 'f'
... file measurements
choice = 't'
... change rotor time constant
choice = 'i'
SEQ
select type of id strategy
execute id strategy
file results
80
choice = Iq'
... quit program
... read new choice
The setup procedure consists of defining variables,
constants and procedures used by the program. The
procedures defined are "write.word.to.link" and
"read.word.from.link", which provide 32bit word
communication from the host to the B004 motherboard via
the IBM PC input/output port - transputer serial link
interface, "display" which converts an integer value to a
string and sends it to the screen, "readparameters" which
reads a string from the keyboard and converts it to an
integer value, and "openfile" and "closefile", which
provide access to hard disk files.
The start up routine invokes the procedure
load.table, which opens the disk file "result18" and
passes its contents to the transputer network to be loaded
into memory on the actuation transputer as the sine look-
up table. It assigns initial values to the variables
employed, sends the initial values of the control
parameters to the screen (namely Ls,Rs,aLs,Tr,isdref and
the torque current limit value), and asks the user to
modify these values if required. When these values have
been corrected the host then passes them to the B004 for
distribution to the correct routines. A set of
instructions for using the host interface is then
displayed.
The
program
on line supervisor consists of a sequential
which monitors input commands from the keyboard
and acts accordingly on them. The command message for
inputting a new speed is displayed on the screen and the
user input converted to integer form and passed to the
B004 via the serial link. The variable "choice" is set to
'y' and the program then passes to an infinite loop which
executes a process on the basis of the command variable
choice using a simple "IF" statement. It then reads in
81
the new command variable from the keyboard. If the command
variable is :-
'y' the process passes this value to the B004 transputer
and then reads in the single set of five control and
measured variables used by the control transputer at
that particular instant, and displays them on the
screen.
'c' the supervisor then asks the user to input a new
speed within a prescribed range. It then passes the
control value and new speed demand to the B004. The
speed transient is initiated and 600 consecutive data
samples are stored on the B004. The last set of
captured data is then passed to the supervisor and
this is displayed on the screen.
'r' this control value is passed to the motherboard and
600 consecutive steady state data samples are stored
on the B004.
'f' this value is sent to the motherboard and the 600
stored samples are read into five memory arrays on
the host processor. The supervisor then asks the user
to input a file name for the data and this file is
opened using the predefined procedure. The array
information is then written to this hard disk file
and the file closed on completion.
't' the supervisor asks the user to input a new value for
the control value Tr (rotor time constant) within a
prescribed range. The supervisor then passes the
command value and the new control variable to the
B004 for incorporation into the control strategy.
'i' the supervisor asks the user which type of
identification strategy is to be employed, ie.
reactive power (v) or PRBS injection (p). It passes
these values to the motherboard and initiates a rotor
time constant identification routine. This routine
will run for a period of 600 samples, updating the
controller rotor time constant value or isd reference
value depending on which mode is chosen, and storing
82
five calculation variables on the motherboard every
sample. The 600 sample sets are then passed to the
supervisor via the serial link and stored in the
host's memory. The supervisor then asks the user if
this data should be written to a hard disk file, and
if so to input the filename. The file is then opened,
written and closed, and the process finished by
displaying two final results from the Tr
identification routine on the screen. Note that this
is available for the V type with current feedback
controller only.
Iq' which terminates the execution of this program and
returns the host to its operating system.
Once a command variable has been executed the
supervisor asks the user to input a new command variable
and the procedure repeats itself.
When the supervisory program is terminated the
transputer network continues to run but with no user
interface. The plot and graphics routines can then be
called up for visual analysis of the transient and steady
state data. User interface can be restored by calling up
the supervisor routine and initial setup and startup
processes are by-passed.
5.3.2)The OCCAM Implementation of the B004 Supervisor
This routine (OVS.TST) makes use of the ability of a
single transputer to execute parallel processes on a time
slicing basis. Two procedures are defined, one high and
one low priority process. The high priority process
(buffer) provides synchronised communication with the
control transputer whereas the low priority process
(overseer) interfaces between the buffer and the host and
Tr identification processes as a "background" routine,
preventing the long interface and calculation processes
from extending the sample time of the control system. The
83
occam pseudo code for this program is given here.
SEQ -- B004 supervisory routine
setup
startup
PRI PAR
SEQ buffer
WHILE TRUE
SEQ
pass control values to controller
read measurements from controller
read clock
ALT
overseer.to.buffer ? fe
SEQ
read control vars from overseer
write measurements to overseer
TIME.?AFTER (now + 1800)
SKIP
SEQ -- overseer
WHILE TRUE
SEQ
input command variable from host
IF
choice = 'Cl
input speed reference from host
pass new speed reference to buffer
store 600 samples from buffer
pass last sample set to host
choice = 'r'
... store 600 samples from buffer
choice = 'y'
read one set of samples from buffer
and pass to host
84
choice = 'f'
... pass 600 data samples to host
choice = 't'
input new Tr from host
pass new Tr to buffer
choice = 'i'
SEQ
input ident mode from host
IF
mode = 'v'
... reactive power identification
mode = 'p'
... PRBS identification
pass identification data to host
The setup process defines variables, constants,
internal channels and the procedures used by the program.
The three procedures used are "read16" and "write16",
which provide correct serial link interface between the
32bit T414 motherboard transputer and the 16bit host and
T212 control transputers, and "load.pwm" which simply
reads the values for the sine look-up table from the host
and passes them to the control transputer. The start up
procedure executes "load.pwm", reads the control
parameters from the host and passes them to the control
transputer, and sets up the initial values for the
variables used.
The
using the
program is configured to run in parallel
PRI PAR statement which governs the
mode
two
processes "buffer" and "overseer". "Buffer" has its own
local variables defined within the process and is executed
in an infinite loop. The control values for speed, flux
current and rotor time constant are passed directly to the
control transputer via the serial link. These values will
be read by the control routine when it is ready, and it
will pass the set of five sampled values of control and
measured parameters to the buffer immediately after. The
85
current value of the transputer clock is then read to the
variable "now". The interface between the user and the
control network is created by the ALT construct, using the
input from the internal channel "overseer.to.buffer" and
input from the transputer clock as its operands. If the
overseer routine is ready to communicate with the network
it will output the speed demand to the buffer on
"overseer.to.buffer". The buffer will then read in the
flux current and rotor time constant demands from
overseer, and pass the last set of five sampled control
and measured parameters read from the control transputer
to the overseer routine using, the channel
"buffer.to.overseer". The overseer has a period of 180011S
in which to initiate this communication from the time that
the transputer clock was read. If this communication does
not occur the TIME 7 AFTER (now + 1800) input to the ALT
construct dictates that this communication is ignored for
this cycle, and the buffer procedure returns to its
initial mode in readiness for communication with the
control transputer. The principle behind the time-slicing
technique employed by the transputer ensures that the
buffer process will always be executed on demand and as
such the overseer can be treated as a "background"
routine.
The overseer routine acts as a software buffer
between the host or Tr identification routine and the
control transputer. The routine is governed by a WHILE
TRUE
The
from
the
statement and is thus executed as an infinite loop.
routine starts by reading the command value "choice"
the supervisor, and selects a process depending on
value of this parameter. These values are :-
'e' the new speed demand is read from the supervisor.
This is then passed to the buffer along with the
current flux current and rotor time constant
the previous set of sampled data are
process from buffer and put into a
demands, and
read into this
two dimensional array. The array pointer is
86
incremented and this process repeated 600 times to
capture data over the transient period.
'r' this command initiates a capture of data over 600
consecutive samples and so a steady state "window" is
stored.
'y' then only a single sample set is captured and this is
passed to the host for screen display.
If' the process invoked passes the whole of the two
dimensional array previously captured to host for
writing to a hard disk file. In this case there is no
interaction between buffer and overseer.
It' the new value of rotor time constant is read from the
supervisor. This is then passed to the buffer along
with the current speed and flux current demands, and
the single set of variables passed from the buffer is
ignored.
Ii' the supervisor becomes an interface between the
control transputer and the transputer executing the
background calculation routines. Its mode of action
depends on the identification routine selected. For
the reactive power process the supervisor writes the
demand variables for speed, flux current and rotor
time constant to, and reads the control and measured
data from buffer as before. It then passes the
measured data to the Tr identification transputer
which performs the identification routine. It then
reads in the modified demand values of Tr from the
identification transputer and this is passed to the
buffer on the next iteration.
This process is executed over a period of 600
samples, and relevant parameters are stored in the
two dimensional array as before. The PRBS process
updates id every sample according to the value passed
from the identification transputer, and passes the
measured value of speed to it. After 600 iterations
the identification
correlation routine
transputer performs
and passes the results to
its
the
87
supervisor for storage. The modified value of Tr is
then passed to the buffer. When the identification is
complete the array is passed to the host for storage
in a hard disk file, and the final value of two
relevant parameters are passed to the host for screen
display. Note that this is available for the V type
with current feedback controller only.
On completion of any of these processes the routine
returns to the start to wait for the new command value
from the host.
5.4)THE CONTROL TRANSPUTER ROUTINES
The three control algorithms employed, namely V Type,
V-Type with Current Feedback and I-Type control, are
similar in structure and implemented as a single
sequential program on the control transputer. They are
divided into two distinct "half cycles" with each half
cycle being initiated by communication with the actuation
transputer.
5.4.1)V-Type Control
5.4.1.1)The V-Type Control Algorithm
For V-Type Control the control transputer uses one
bi-directional serial link for communication with the
supervisor, one for communication with the speed input
board, one for communication with the current input board,
and one for communication with the actuation transputer,
programmed in this application to run as a PWM generator.
The control algorithm demands that when a new speed demand
is input from the supervisor routines, the controller
calculates suitable reference signals for the PWM
88
s,
OJ
OJ
U
+>
d
s,
s, 4-
s, OJ
X
0 L
OJ >
OJ L
+> ~-'
~ C
000
0.. 3:
0.. c 0+> 0.. U
+> o __~
(:5 <, +>-' L
<[ o, c:3 OJ Eof: OJ+>s,
lJ) c .Y U U
0
c
-' ::5+>
::5 0 _j
ClJ cs
o..u
1fI L
+>
-' ClJ +>
~
c
:3
o, c c
<,
<[ 0 1fI
ClJ 0
<[ +>
_j u OJ
Q) U
c
0)
1fI
0
OJ
L
U
+>[1SJ Q; d+>
L
c
+>
:3
0
V)U
0d
L+>
+>o £: c(:5
£. 0
0 lJ) uc 0
-'u 0
- o
0 s,
f: c L
+>
+> CD o:
+> +> £/'. 0) 0
C
d (lJ 1fI W
o c 0 ~ +>
0 (:5 4- 0 l- f: 0 U 0 lJ) u
u
0- u ::) s, U 0.. ClJoS Q_C\J 0
-' '-/ L
>
>
c (/)
~ cs ClJ-0 4-~ lJ) Z 1fI 0 s, III .£W
lJ) 0) >
<[
c +> OJ :::5 +> ClJ
I- U c
~ o u 1fI...Q 0 o, (\J»,
::) cs E I-
~ OJ
I- m
B5(Y)u+>
+> > inT* * > OJZ ~C5 L<[ :3 c L(:5 4- :3~ Q_ d 3: __ 0- (J)I- > IT" 0
~~
L
LL3:
c> --
0
+>+
dlJ)
+>
ClJ
~ L £
c
-'
W 0 £. OJ
OJ...Q
I- 1fI 0 ClJ £.
C d
::::)
> U ~ ClJ
-t]) +>
Q_
0 -'~
0..
(/)..-i
ClJ ~ cs+>
£.
z 0.. ClJ () 1fI
,__.
<[
::5 VI
~ 1fI ~I-
-'~
~_jd OJ+> c+>o ::5lJ) Vlo..0 L EI ClJ 0
o_u
89
generator on the basis of this and the measured motor
speed. The speed and thus the PWM command values are
updated every 2ms, however pulsewidth modulation is
carried out every 250~s. The control method is
illustrated in Fig. 2.4. and the transputer network
employed is illustrated in Fig. 5.2.
The speed sample time can be considered to be
comprised of eight carrier half cycles of the PWM routine,
and in each half cycle a different process is performed,
namely :-
l)speed sampling and vector control calculations
2)input/output to the supervisor
3)input of current (for monitoring purposes only)
It can be seen that five half cycles contain no executable
processes. This is intuitive as the voltage and thus
current control are dependent on the mechanical time
constant of the motor drive and the resolution of the
speed encoder and doe not make full use of the
computational capabilities of the processing network.
5.4.1.2)OCCAM Implementation of the V-Type Controller
The occam pseudo-code for the V-Type controller is
shown here (VCON.TST).
SEQ control routine
setup
startup
WHILE TRUE
SEQ
output PWM variables (30)
IF
x = 4
SEQ
measure line currents (43)
demodulate and filter currents (44)
increment x (1)
90
input flux angle data (20)
IF
x = 1
SEQ
read commands from supervisor (30)
pass measured data to supervisor(SO)
x = 7
SEQ
measure speed
PI speed control
calculate PWM variables
increment x
(30)
( 2 )
(29)
(1 )
The setup process is used as before to define the
variables and constants used by this program and defines
the procedure "load.pwm" which is used to pass the values
for the sine look-up table to the PWM generator. The
startup procedure executes "load.pwrn",and then reads the
control parameters from the supervisor. It then assigns
initial values to the variables used in the program. The
control routine then runs as a sequential procedure
governed by a WHILE TRUE construct.
The first carrier half-cycle is initiated by
communicating the control values vd, Vq and fe to the PWM
generator. The overall programming strategy ensures that
the sender is ready before the receiver and synchronises
the controller to the PWM timing. The routine then uses a
flag ("x") to determine the process to be executed in this
half-cycle. At startup, "x" is set to O. If the flag is
'4' the three phase currents are read directly from the
current input board, and converted to instantaneous values
of id, iq using the transformations given in Appendix c.
The measured currents are then passed through a digital
low pass filter, the algorithm for which is outlined in
Appendix E. If the flag has another value no process is
implemented. At the end of the half-cycle the flag is
incremented. The resultant current measurements are
91
sampled almost directly in the middle of the PWM output
pulses, resulting in significant reduction of the carrier
frequency harmonic content. The timing of the current
input is such that they are read in the middle of a speed
sample period as well.
The second carrier half cycle is initiated as soon as
the PWM generator is ready to transfer the flux angle sine
and cosine values required for current demodulation. The
value of the flag is again used to determine which process
is implemented. If "x = '1 '" the controller reads the
speed, flux current and rotor time constant demands from
the supervisor, and passes the current values of speed,
demanded vd and Vq' and measured id and iq to it. If the
flag is '7', the controller measures the speed from the
speed input board and performs the vector control
calculations. The flux current demand id is a control
value passed from the host. The torque current demand iq
is derived from a digitally implemented PI controller
acting on the speed error value, the algorithm for which
is described in Appendix E. A limit is placed on this
value to prevent excessive motor currents. The
frequency demand is derived directly from equation
and suitably scaled to be in electrical Hz. This is
slip
2.10
added
to the measured speed signal (also scaled in electrical
Hz) to provide the frequency demand for the PWM generator.
The d and q axis voltage demands for the PWM generator are
calculated using equations 2.17. and 2.18., again with
limits placed on these values. If the flag is equal to '3'
or '5' no process is performed. The carrier half cycle
ends with the flag being incremented or reset if "x =
, 7 ' " •
The V-Type controller thus provides a 500Hz speed
sample frequency and monitor sample frequency, and
although the control parameters for the PWM generator are
updated at this frequency, pulsewidths are updated at a
rate of 2kHz.
92
5.4.2)V-Type Control with Current Feedback
5.4.2.1)The Control Algorithm
The transputer network and program structure are
identical to those used by the V-Type controller. The
major changes are that the d and q axis currents are
sampled every carrier cycle and the reference values for
the PWM generator are calculated every carrier cycle using
PI controllers acting on the current error signals. The
speed is still sampled at a rate of 500 Hz. The control
method is illustrated if Fig 2.6.
5.4.2.2)OCCAM Implementation of V-Type Control with Current
Feedback
The occam pseudo code for the control program is
illustrated here (ICON.TST).
SEQ control routine
setup
startup
WHILE TRUE
SEQ
output PWM variables
measure line currents
demodulate and filter currents
increment x
input flux angle data
(30)
(43)
(44)
( 1 )
(20)
IF
x = 1
SEQ
read commands from supervisor (30)
pass measured data to supervisor(SO)
93
x = 7
SEQ
measure speed
calculate isqref
(30)
( 2 )
IF
softstart = TRUE
... use preset PWM variables
softstart = FALSE
SEQ
PI control of currents
and d - q axis compensation (26)
increment x (1)
Setup and startup are identical to that of V-Type
control, however a further flag ("softstart") is set to
TRUE. The transputer network is initiated before the
inverter itself is enabled (by an external push-button).
The purpose of the softstart flag is to prevent the closed
loop current controllers from working (and saturating)
when the controller is activated and before the inverter
is enabled, and prevents closed loop current control until
the user "says its OK" by inputting a non zero speed
demand.
The first control half-cycle is initiated by
outputting the command signals to the PWM generator. For
each iteration of this half cycle the currents are read,
demodulated and filtered as before, and a 2kHz sample rate
ensues. The flag "x" is incremented at the end of the
half-cycle.
The second half-cycle is initiated by reading the
flux angle sine and cosine values from the PWM transputer,
and then the value of "x" is used to determine the next
process. If "x = '1'" the controller inputs the demand
values for speed, flux current and rotor time constant
from the supervisor and outputs the measured values for
speed, id and iq, and command values for vd, and Vq to it.
If "x = '7'" the speed is measured and the torque current
94
reference generated as before using a PI controller. This
process also generates the PWM frequency demand. The next
process is then executed for each iteration of this half-
cycle. D axis current control is achieved using a PI
controller acting on the error between the flux current
reference and the d axis current measured in the
half-cycle. The controller was designed using
2.19. and implemented using the bilineQr
previous
equation
transform
outlined in Appendix E. Similarly q-axis current control
is implemented based on equation 2.20. The outputs of the
controllers are the d and q axis voltage demands for the
PWM generator. The compensation outlined in section 2.5.2
can be included by using the demand values for id, iq and
frequency to modify the d and q axis voltage demands as
outlined in equations 5.1 and 5.2.
(5.2)
(5.3)
Note that the current controllers are disabled until the
user inputs an initial non zero speed demand. When this
occurs the softstart flag is set to FALSE and the current
controllers enabled. The voltage demands used prior to
this are "safe" preset values that prevent current surge
when the inverter is enabled. The final instruction of
this half cycle increments or resets the flag "x"
accordingly.
5.4.3)I-Type Control
5.4.3.1}The I-Type Control Algorithm
The hardware layout for this algorithm differs
slightly from that used for the voltage controlled modes
in that the current detection board is now connected to
the actuation transputer, which performs the bang-bang
95
local current controller. The control algorithm is similar
in structure to that of V-Type control, and in this case
only two of the eight carrier half cycle which make up a
2ms speed sample time, actually do any operations. The
control method is illustrated Fig. 2.8. and the transputer
network implemented for this control strategy is shown in
Fig. 5.3.
5.4.3.2)OCCAM Implementation ofI-Type Control
The occam pseudo-code for this program is shown here
(SCON.TST).
SEQ control routine
setup
startup
WHILE TRUE
SEQ
output ref currents and frequency (30)
increment x (1)
input measured currents (20)
filter currents (17)
IF
x = 3
SEQ
read commands from supervisor (30)
pass measured data to supervisor(50)
x = 7
SEQ
measure speed (30)
calculate isqref, fe
and d - q axis compensation (27)
increment x (1)
96
s,
OJ
-P
s,
~ OJ
OJ >
~ c
000
-p 0. U
L
o
OJ -P
lfl d
..J ~
::5 QJ
0. cQJ
CJ)
l/)
L
QJ
-P
c
::5
o
U
-P d
c -p
o d
U <:)
ClJ
..J
QJ_Q
_'= o
lfl-P
..J L
d OJ
-pc-P
lfl
0 ::5
lfl 0.
o L £:
I OJ 0
o.u
o
-P
o
<:)
d
-p
c
o
u
<[
_J
-P
c
o
u
x
OJ
0.
-P
s,
OJ OJlflt
..J ::5
::5 0
O_u
-p
c
o
u
o
-p
d
<:)
C ..J
o 0
L
-P
c
o
U
s,
o
.p
u
OJ
>
+
~ lfl
o £:
lfl £:o
> u
L
OJ L
o.OJ
::5 lfl
lfl ::5
97
OJ
U
<:5
L 4-
o L
-P OJ
o_.p..J
o C 0
-- ~
l5 "'--p
<[ _9- c
cc s: 0
c U U
_J
l-p
c
<[ 0
_J U
1nl
ClJ
d L
-P 0
d-P
<:) lfl
>,
(J)
OJ
.p
o
L
-P
(/)
o
s,
.p
c
o
U
L
o
-P
U
OJ
>
OJ
0.
»,
I-
I--l (Y)
If)
4-
o OJ
L
c ::5
o CJ)
-P u_
o
+>
c
OJ
£:
OJ
0.
£:
I--l
The setup and startup routines are identical to those
used by the V-Type controller. The first carrier half
cycle is initiated by outputting the command values isd,
isq and fe to the bang bang controller. The rest of the
carrier half-cycle is redundant apart from incrementing
the flag "x".
The second half-cycle is initiated by inputting the
measured values if isd and isq from the actuation
transputer. These values are digitally filtered using the
billOear. transformation outlined in Appendix E. The
routine then uses the flag to chose its mode of action. If
"x = 3" the control transputer reads the demand values for
speed, flux current and rotor time constant from the
supervisor and passes the measured values of speed, isd,
and isq, and the reference values of isd and isq to it. If
"x=7" the control transputer inputs the speed value from
the speed measurement board. The torque current reference
is generated as before by a PI controller acting on the
speed error signal. The inverter frequency is calculated
using equation 2.10. Note that the decoupling terms for d-
q axis compensation, outlined in chapter 2 can be included
at this point to provide compensated reference currents in
accordance with equations 2.23 and 2.24. If "x=1" or "x=S"
no process is invoked. This carrier half-cycle is
concluded by incrementing or resetting the flag
accordingly.
This routine thus provides a fast local current loop
controller operating with a sample frequency of 4 kHz. The
reference values for the current are calculated on the
basis of the measured and demanded speed and are thus
updated at a rate of 500 Hz.
5.5)THE Tr IDENTIFICATION ROUTINES
The two methods
outlined
for rotor
chapter
time constant
identification in 2 have been
98
incorporated into the vector control algorithm using a
further T212 transputer connected to the B004 supervisor
via a bi-directional serial link. The extension to the
transputer network is illustrated in Fig 5.4. It must be
noted here that the identification algorithms were only
employed on the vector control using V-Type control
current feedback, as this was the only method which
both reasonable estimates of the d and q axis
with
gave
motor
voltages, and provided accurate current control. The
routines were only implemented on the cage motor. The
strategies are computationally intensive, demanding the
use of real number routines. However it was found that the
2ms sample time dictated by the speed control loop was
sufficient to allow both strategies to be performed on the
sampled data. Both strategies are implemented using a
single routine running on the identification transputer.
The identification is triggered by the user and a command
variable is used to decide which strategy to use. The
pseudo code for the overall routine is given here, and the
pseudo code for the two processes are given later in the
chapter.
SEQ -- identification routine
setup
startup
WHILE TRUE
SEQ
input trigger and choice
IF
choice = 'v'
... reactive power process
choice = lp'
... PRBS injection process
The setup routine defines variables and constants
used by the program, as well as the real number procedures
"IntegerToReal", "ReaIOp", and "ReaITolnteger" which are
99
c
0
+>
d
U
4-
.p
c
cv
zs
........
.p
c
d
~
tJ) Q)
.p
W U
C
lfl
l- e
0
c
--'
:J d £.
.p
0
B;(Y)u.p
o
U
Z L(5
£.
CV
s,
<[ :3 e
0-
0
£.
~ Q_ d
>
4- s,
l-
I-
-d'
tJ) 0
C .p
s,
>
d U
0
,
s, CV
.p
*CV
.p >
0
4-
~
c
o
+>
o
L
cv
e
cv
OJ
100
+
~
l.()
OJ
4- ~
o ::5
Ol
C LL
o
.p
d
.p
C
OJ
£.
cv
__,
0...
£.
........
III
~ £.
o £.
tJ) 0
":> u
s,
cv ~
o...ClJ
::5 III
tJ) ::::5
required
procedure
by the calculation strategy. The startup
certainsimply assigns initial values to
variables used.
5.5.1)PRBS and Cross-Correlation Algorithm
The algorithm for this procedure requires that a PRBS
signal be generated over a predefined period and injected
onto the d axis current demand. If the flux vector
calculated within the controller is not exactly aligned to
the flux vector in the motor itself, the PRBS will have a
direct influence on the torque of the machine and
disturbances will be seen in the measured motor speed.
Cross correlation of the injected signal and the measured
disturbance can be used to give an indication of the flux
angle discrepancy and the controller value of rotor time
constant can be modified accordingly.
The main considerations for the implementation of
this routine are that the PRBS should have no direct
action on the motor torque, and also the action of the
speed controller should not "swamp" disturbances due to
flux vector misalignment. Thus the clock rate of the PRBS
on id should be sufficiently high that the disturbances
are not seen on the flux vector itself ie. are filtered
out before affecting imr. However the PRBS rate should not
be so high as to be effectively filtered out by the
current controller time constant of the machine. The rotor
time constant has an order of magnitude of 100ms, and the
current controller time constant designed to be 5ms, and
so a PRBS clock period of 20ms was chosen.
The PRBS was generated using an 8 bit software shift
register employing feedback, as illustrated in Fig 5.5.
Cross correlation of the injected and measured
disturbance was achieved using equation 5.4.
101
bits
76543210
Shift Register EMpLoying FeedbQCK to
Function os a. PRBS Genera. tor
Figure 5.5.
102
rck = (1/r) E dn.m(n+k)
n=1
(5.4)
where: ck is the kth correlation function
dn is the disturbance injection at the nth sample
m(n+k) is the measured disturbance at the (n+k)th
sample (ie. difference between speed demand and
measured speed)
r is the total number of disturbances injected
The amplitude and phase of the peak correlation
function value can be used to determine whether Tr should
be increased or reduced. This procedure must be repeated
several times in order to "hone in" on the correct value
of Tr.
5.5.2)PRBS OCCAM Implementation
This algorithm was implemented as a sequential
process outlined by the occam pseudo-code given here. The
data sampling and disturbance injection are implemented as
a process which iterates for 600 cycles. The routine is
completed by then completing the correlation caLcu.Lat.Lons,
determining the maximum correlation coefficient, and using
this value to update the rotor time constant.
SEQ
SEQ
-- PRBS injection process
i = [0 FOR 600]
SEQ
read data from supervisor
pass data to supervisor
calculate disturbance
calculate correlation functions
sort correlation functions
pass correlation functions to supervisor
pass modified Tr to supervisor
103
The first process invoked is the communication of
measured data from the supervisor and passing of command
values for flux current and rotor time constant to the
supervisor. The next process provides the PRBS
This is "turned off" for the first 100 samples,
for samples 100 -500, and then turned off again
signal.
clocked
for the
last 100 samples. The clock rate is 10 samples, resulting
in an injection of 40 disturbances, each lasting 20ms.
These disturbances provide a +/- 10% deviation to the flux
current reference signal. The routine then invokes the
summation calculations required by the correlation
routines as the data becomes available. When the 600
iterations are completed the correlation coefficient
calculations are completed, and a sorting process employed
to determine the signum and amplitude of the maximum
value. These are then used to determine the adjusted value
of Tr which is then passed to the supervisor.
5.5.3)Reactive Power Measurement and Tr Adaption Algorithm
The algorithm for this strategy provides an
adjustment for the rotor time constant every sample (2ms)
on the basis of the discrepancy between the measured and
demanded reactive power. The main consideration for the
implementation of this algorithm is how the error function
should be scaled in order to adjust Tr and whether some
sort of integral control should be put onto the error
function. A Proportional plus Integral controller was
employed in order to remove steady state errors from this
function.
5.5.4)Reactive Power OCCAM Implementation
The occam implementation of the algorithm is shown
by the pseudo-code given here. It is implemented as a
sequential program which iterates for 600 cycles.
104
SEQ -- reactive power process
SEQ i = [0 FOR 600]
SEQ
read data from supervisor
pass data to supervisor
calculate Fo and Fo*
PI control of oFo
calculate new Tr
Each calculation process is initiated by inputting
the measured variables from the supervisory transputer,
and outputting the new command variables, and certain
calculation parameters to it. In this algorithm the value
of Tr only is adjusted. When the values are input they are
converted to real numbers and equations 2.25 and 2.26
employed to calculate the error function. This value is
then used to drive a proportional plus integral controller
(K = 0.5, w = 200) scaled (and limited if necessary) and
the output is converted to an integer ready to be passed
to the supervisor at the start of the next cycle. The
adjustment to Tr is carried out by the supervisor.
105
IMPORTANT NOTES
(A) The following results were taken using an
which had an 8% imbalance on the voltage
produced on each phase. The effects
inverter
magnitude
of this
imbalance are significantly reduced when current
feedback is employed, however it is an important
factor when assessing the performance of the control
system when running under voltage only type control
(pages 112 - 116),
(B) The performance of the speed measurement technique
is of importance when assessing the transient
behaviour of the control systems, particularly at
low speeds. The speed resolution can be described
quantitatively as follows :-
At 1500 rpm - speed resolution = 0.2%
At 150 rpm - speed resolution = 2%
C~P~R6
EXPERIMENTAL PROCEDURES AND RESULTS
6.1)INTRODUCTION
This chapter will reproduce the experimental results
obtained when the vector control networks are configured
to the two motor drive systems outlined in Appendix 1. The
design of the basic speed and (where applicable) current
controllers is described, and simulation and test results
for transient and steady-state operation of each control
strategy on the wound and cage rotor motors are given.
Noticeable problems with the coupling of the d-q axis
current control loops are described as are the design and
implementation of appropriate compensation. Signs of rotor
time constant detuning are described and the
implementation of the Tr identification routines is
examined with suitable experimental verification. The
final section discusses the transputer utilisation for the
three networks implemented and provides information on the
communication time and process time used by the individual
devices.
6.2)THE DESIGN OF THE SPEED CONTROLLERS (ALL CONTROL
STRATEGIES)
PI speed controllers were employed for both of the
drive systems, to provide a speed control system with no
steady-state error, and minimal overshoot during a
transient. It was predicted that in most trans{ent tests
performed the output of the speed controller would be
limited during most of the transient to avoid unacceptably
large currents in the motor. For this reason more
106
elaborate controllers such as PID were felt to be
unnecessary. The controllers were designed on the basis of
the Laplace block diagram illustrated in Fig 6.1. This
approach is based on the following assumptions
1: that a vector controlled AC motor is equivalent to
a separately excited DC machine, with a constant
field current in this application.
2: the inner current control loop's response time is
negligible compared to the speed response time, and
thus the torque is imposed immediately on the
machine.
3: the motor load is purely inertial.
The SIMBOL CAD package [28], was used for the design
of the controllers using Root Locus techniques, and
allowed provision for sample delays, and limiters. This
meant that a "mixed" system of s-plane and z-plane
transforms could be used to more accurately model the
drive. The main restriction of this package was that the
saturation of integral elements of the controllers (or
anti-wind-up) could not be included. The block diagram
consists of the PI controller with gain Kc and angular
frequency wc' a limiter for the torque current reference,
a delay of SOO~s to represent the processing time of the
controller, and the mechanical characteristics of the
machine - the torque constant Kt and the inertia, J.
The resultant PI controller for the cage rotor
machine had Kc = 1 and Wc = 10. The resultant closed loop
control system was slightly underdamped. A simulation
speed transient for a 4.SA torque current limit (torque
limit = 34Nm) is shown in Fig. 6.2. This is the motor's
rated current. It can be seen from this plot that the
acceleration rate for rated torque is 14000rpm/s, which is
to be expected considering the torque constant of the
machine (7.S8NmA-1 for a 2.2A magnetising current) and the
inertia (0.023kgm2).
107
W~lIE Kc
i
wr
J
Lo pl o.ce Block Dio.gro.l""l for the Design
of the Speed Controller
Figure 6,1.
X : 2,4E-~03 PLOT OF ~aa!~p/TIHE X : 2,5E-~01
Y:1. 4E tBB3 I·----------,~,...-::=----=---------
I .../
I /,/
...
/
."l
/
/
/
,I
/1
/
,I
/'
/'
/
I
,I
//
,I
/
,I,
,/'
t'
---------------------------
Y:2,5Et~Ol
SYMBOL Sil""lulo.+ton of 0. Speed Tro.nsient
(C<lge Motor)
Figure 6,2,
108
The resultant PI controller for the wound rotor
machine has Kc = 1 and Wc = 2. The resultant closed loop
control system was overdamped. A SIMBOL simulation for a
speed transient is illustrated in Fig. 6.3, for a torque
current limit of 8.3A (torque limit = 4SNm). This was the
rated current for the machine. The rated torque
acceleration (with Kt = S.6NmA-1 for a 2.9A magnetising
current, and J = 0.32kgm2) as seen from the plot is
1333rpm/s. This is considerably less than that of the cage
machine because the inertia of the wound machine is far
greater.
6.3)THE DESIGN OF THE CURRENT CONTROLLERS (V-TYPE WITH I
FEEDBACK ONLY)
The PI d and q axis current controllers for this
drive system were designed on the basis of the Laplace
block diagram illustrated in Fig 6.4. These consist of the
PI controller (Kc and wc), a limiter to represent the
maximum phase voltage obtainable from the inverter used
(260V for the wound machine, 4S0V for the cage machine), a
delay of SOO~s to represent the control processing time,
and the stator characteristics of the machine the
resistance Rs and effective inductance aLso The block
diagram is common to both d and q axis controllers, as
both are governed by the same "effective" armature
constant. The controllers were designed to give a
current response « 10ms total response time for a
input of rated current) with up to 20% overshoot.
The resultant PI d and q axis current controllers for
the cage rotor machine had Kc = 20 and Wc = 500 (Rs =
5.40, aLs = O.026H). The resultant closed loop control
system gave a simulated transient response with 7%
overshoot, as illustrated in Figure 6.5. for rated
time
fast
step
current. The total response time (time to reach steady
state conditions) was around 9ms.
109
X : 1,5E-~~2 PLOT OF wound/TIME
~:B,7Et~B2 -----------------
..-----
,"
"/ ....
,l
,I
//""/
i
...
/
"/
/'./
/
/
,/
,//
l
/
,/
Y:2 I gE+~Bl/ '-- _,
-_
-_
,--------
SYMBOL 5iMUlCltion of Cl Speed Tro.nsient
(~ound Rotor Motor)
Figure 6,3,
iqiqllE .../0. I.':'I
~
t.cpto.ce Block Droqr on for the Design
of -the Current Controller
Figure 6.4,
110
X : 1,8E-004 PLOT OF stato~!TIME X : 2,0E-002
~:5, 0[+000 .-----------------------
.,.,....--- ...._.
... ---I" --._-_,
.' _._-)t;---
,//
I
l
i
i
i
I
~:5 ,4E -BBl ~-~-_ _. _ -:- _
,--------
Figure 6.5. SIMBOL Simulation of a Current Transient
(cage machine)
X : 1,8E-004 PLOT OF stato~/TIME X : 2,0[-002
Y:9,6E+B00 .---:::==:.:----------------
i' -'.! ..../ _
/ ._-_'---
/
I
/
I
II
I
I
IY:1. 2E+000
~-----~~--~ --_.-..-..-
Figure 6.6. SIMBOL Simulation of a Current Transient
(wound machine)
111
The same PI controller was used for the wound rotor
machine, and a simulation transient response for rated
current is given in Figure 6.6. (Rs = 2Q, aLs = O.021H).
With this system the overshoot it seen to be 17% and total
response time is around 8.5ms.
6.4)V-TYPE VECTOR CONTROL
6.4.1)The Cage Rotor Motor
Figures 6.7 and 6.8 show transient performance of the
cage motor when run under voltage only type control, with
torque current limits of 4.5A (rated current) and 9.0A
respectively. The motor in this instance is uncoupled from
the DC generator and thus the load is merely the inertia
of the motor itself (low) and the light load from the
cooling fan attached to the rotor. Figure 6.9 shows
transient performance of the motor when loaded with the
high inertia DC. generator and with a steady state torque
of 19Nm using a resistance bank. In this case the torque
current limit is 9A. The d axis current demand is held
constant at 2.2A - the value required to fully flux the
machine - found from the machine open-circuit test. During
most of the transient the torque current demand saturates,
and only comes out of saturation as the motor approaches
final speed.
The no-load transients show that the control of the d
axis current is significantly impaired as the torque
current is increased for acceleration, and also as it
comes out of saturation. It can also be seen that the
torque current is not maintained constant at its saturated
level during the transient, and the discrepancy appears to
be frequency dependent. This indicates that the stator
parameters are not accurately known and that coupling is
occurring between the controller d and q axis current
demands and those actually imposed on the motor. As the
112
speed (rpm). Current (A).
1400 6
1120
840
560
280
0
-280
-560
-840
-1120
-1400
0
5 _ Speeo.
..... Id.
4 ..... Iq.
~..". ....:'\ 3
.....\.
."
"\.:/\~ j(···· • •f··· .....:
, ~.
. : ; -, /
=,:«
..~ ,...}
2
1
o
-1
-2
-3
50 100 150 200 250 300 230 400 450 500
TIME (ms) .
Figure 6.7. Speed Transient for the Unloaded Cage Motor
with a 4.SA Torque Current Limit with V Type Control
speed (rpm). Current (A).
1400 (\
! \1120
840
,
\
;
\560
280
0
-280
-560
-840
-1120
-1400
0 50 100 150 200 250 300 230 400 450 500
TIME (ms) .
Figure 6.8. Speed Transient for the Unloaded Cage Motor
with a 9A Torque Current Limit with V Type Control
113
1400
1120
840
560
280
0
-280
-560
-840
-1120
-1400
0
speed (rpm). Current (A).
200 600 800400
TIME (ms) .
Figure 6.9. Speed Transient for the loaded Cage Motor
with a 9A Torque Current Limit with V Type Control
FOOTNOTE For acceleration curves using the loaded cage
machine, the initial kink in the speed curve is
due the effect of torque reversal with a loose
coupling between the motor and load.
114
torque limit is increased the current control is seriously
degraded. However, the average acceleration rate for Fig.
6.8. is approximately twice that of Fig. 6.7. suggesting
that there is a degree of flux tracking and vector control
does occur. The average rate of acceleration in Fig. 6.7.
is measured as 12100rpm/s, which is lower than that
expected from the simulation (14000rpm/s). However the
torque current has a mean value of less than 4.SA over the
saturated period.
The initial acceleration of the loaded motor during a
transient as seen in Fig. 6.9. is greater than the average
acceleration and this is due to the large value of actual
d axis motor current during this part of the transient
having an effect on the developed torque.
As mentioned earlier the control method is somewhat
crude as it relies heavily on an accurate knowledge of the
stator parameters as well as the rotor time constant,
which may change with frequency due to "skin depth"
effects as well as temperature. It also assumes an
accurate calibration of the PWM generator which is not
correct during deceleration as the kinetic energy
recovered from the rotor initially charges the link
capacitor of the inverter to 3.4% above its nominal value
(S80V). It also has a "current control" sample rate equal
to the speed sample rate (2ms) which is rather slow, and
comparable with the effective armature time constant (aLs
~ Sms). A further source of inaccuracy at lower speeds
results from the method of speed sampling. The number of
pulses generated by the encoder during a set clock period
(2ms) is taken as the speed measurement, and thus the
effect of the "loss" of a single bit of the count on a low
speed signal will be far more significant an error on the
overall reading than at high speeds.
See important notes (A) and (B) opposite page 106
115
6.4.2)The Wound Rotor Induction Motor
Figure 6.10 illustrates a typical speed transient for
the wound rotor motor running unloaded. The field current
is maintained constant at 2.9A. Again this value was
derived from the open-circuit machine test as the value to
fully flux the machine. Rated torque current in this case
is 8.3A. There is no precise control of the d and q axis
currents during the transient and the oscillations in both
currents can be seen as causing torque oscillations during
the transient, which are represented as kinks on the
acceleration curve. It has proved impossible to get a
significantly higher acceleration current into the motor
using this type of control.
The average acceleration rate as measured from Fig.
6.10 is 1300rpm/s which compares favourably with the
simulation for rated current (1333 rpm/s).
This method of vector control may be crude but it is
effective as a means of obtaining a good dynamic
performance from the induction motor drive using a speed
sensor only. The main problem arises from the peak
currents generated during acceleration, which are not
consistent with the controller values and may exceed the
rating of the inverter used.
6.5)I-TYPE VECTOR CONTROL
6.5.1)The Cage Rotor Motor
Initial experimentation with the bang-bang controller
was to ascertain whether lead-lag and d-q axis
compensation was required for the current controllers. The
results of Figures 6.11, 6.12, and 6.13 are taken for the
116
800
640
480
320
160
0
-160
-320
-480
-640
-800
0
speed (rpm). Current (A).
9
_ Speed.
Id.
e
..... Iq.
7
6
5
4
3
2
1
0
400 BOO 1200 1600 2000 2400 2BOO 3200 3600 4000
TIME ems).
Figure 6.10 Speed Transient for the Unloaded Wound Motor
with a 8.3A Torque Current Limit with V Type Control
1200
960
720
480
240
0
-240
-480
-720
-960
-1200
0
speed (rpm). Current (A).
3
2 _ Speed.
Id.
1 ..... Iq.
o
-1
-2
-3
-4
-6
50 100 150 200 250 300 350 400 450 500
TIME ems).
Figure 6.11 Speed trarrsi.ent;for the Unloaded Cage Motor
I Type Control with no Compensation
117
1200
960
720
480
240
0
-240
-480
-720
-960
-1200
0
speed (rpm). Current (A).
3
M/!
'I
!
I
1\ /: /
1\ ..1i. )'\ \ .•/)'j
1 I ~'",/, J
it (. ItI ~
\ rj
\
,..l";
..,
f
,1\V"
50 100 150 200 250 300 350 400 450 500
TIME (ms) .
2 _ Speed .
..... Id.
1 ..... Iq.
o
-1
-2
-3
-4
-5
-6
Figure 6.12 Speed transient for the Unloaded Cage Motor
I Type Control with Lead-Lag Compensation
speed (rpm).
1200
960
720
480
240
0
-240
-480
-720
-960
-1200
0
Current (A).
3
..........\ f\ -v • .:.},• .~,:-....• .: !""""_'"\':\'''''''''';''''''''':. ..'. \ : \_,.j ':'" : • ... ," :. , ,_
. .;",-,\./.r··~···........,.... ...~. .... .., \ v..f
....\,.J
50 100 150 200 250 300 350 400 450 500
TIME (ms) .
2 _ Speed .
Id.
1 ..... Iq.
o
-1
-2
-3
-4
-5
-6
Figure 6.13 Speed transient for the Unloaded Cage Motor
I Type Control with Lead-Lag and D-Q Axis Compensation
118
uncoupled cage motor with a torque current limit of 4.5A
during a transient. Note that the plotted current
measurements are filtered with a low pass digital filter
(cut-off frequency of 70Hz), but the control strategy uses
unfiltered current measurements. Again a constant field
current of 2.2A was used. It can be seen from trace 6.11.
that when no compensation is employed there is serious
coupling between the d and q axis currents during the
transient, and the steady state measured currents are
significantly lower than the controller demanded currents
due to the lag of the current control loops and inverter
delay a discussed in chapter 2. When the measured and
reference line currents were compared over a range of
frequencies it was found that there was a significant
phase lag (70 max) and amplitude difference (92.5%)
between them. The lead-lag compensators were designed to
overcome the amplitude discrepancy and gave a gain of 1.08
to frequencies above 1Hz. The resultant compensation was
:-
'iaref := iaref(1 + sO.143)/(1 + sO.133) ( 6 . 1 )
Figure 6.12
effect on the d-q
axis current of
controller.
The d-q axis compensation was designed to overcome
the phase shift over the full operating frequency range
and implemented as :-
shows that this compensation
coupling, but produces steady a
similar magnitude to that set
has no
state d
by the
'idref := idref - iqref/T (6.2)
'iqref := iqref + idref/T (6.3)
T := 28 - (fe/5) (6.4)
119
It can be seen from Fig 6.13. that there is a
significant reduction of the d-q axis coupling effects
using this form of compensation, but the problem is not
completely removed. No further improvement could be made
on the q axis current control as degradation of the d axis
control would occur. It must be noted that the 4kHz sample
rate used for the bang-bang controller is slow.
Transient performance of the I Type controller for
differing current and load conditions is shown in Figures
6.14 and 6.15 for the uncoupled motor and Figure 6.16 for
the motor loaded as for V type control. The acceleration
of the unloaded machine is noticeably better than V Type
control as the d and q axis currents are controlled more
accurately over the transient period. The average rate for
rated current is 16S00rpm/s which is higher than the
simulation, but in this case the mean torque current over
the saturated period is greater than 4.SA. The currents do
not fully follow the controller values and the resultant
loss of flux tracking can be seen as a degradation of
acceleration rate (and thus torque) over the transient
period. It can also be seen that the average acceleration
of Fig. 6.15. is only 1.5 times that of Fig. 6.14. a
further sign of loss of flux tracking.
The average acceleration of Fig. 6.16. (the loaded
machine) is worse than that of V Type control. The overall
transient time is significantly greater than that of the
unloaded machine and thus the loss of tracking and torque
degradation resulting from the fact that the d and q axis
currents are not precisely controlled are much more
obvious. If the rotor resistance does increase due to
temperature during the period of this transient, then
although the stator current is maintained constant, the
change will result in an increase in the actual field
current of the machine, and a reduction
current [15]. The resultant generated
reduced, because the speed controller
modified to account for the change in Rr.
on the rotor
torque will be
has not been
120
1400
1120
840
560
280
o
-280
-560
-840
-1120
-1400
spee::: (rpm). Current (A).
4
• :: ; ': f ....
l·o, t-> J /r\.: .....,~.~f..../ \ ...i.:• • •,,' • • • .• .' ..~,........... . .• • . ...":. .:.; •
. ". . .. '... ' . "'/"-: j : -, / ..
.' ., , , ,:,..:../,'/.1" ..'" \/ V \ ,,/
~,/~f\..,..{ \....... ._
o 50 100 150 200 250 300 350 400 450 500
TIME (ms) .
3 _ Speed.
..... Id.
2 ..... Iq.
1
o
-1
-2
-3
-4
-5
-6
Figure 6.14 Speed Transient for the Unloaded Cage Motor
with a 4.SA Torque Current Limit with I Type Control
1400
1120
840
560
290
0
-280
-560
-840
-1120
-1400
0
speed (rpm). Current (A),
~I n
," \i\_ i\ ,I
'\ . ;\'\ _ II I :.... r j i iV\.,
/
1 'J\ ,r''',\,!Ii'I,. ,'I \,~Ai\'i·.~..\'v' "\1 , '\ ,I \ ,I ":,V ~ ...., " t ... VV 'oj V\j 'rc ... \;
1_/'\\\\ ",,'
!'
3
2
_ Speed.
1 ..... Id,
.....t o ,
o
-1
-2
-3
-4
Figure 6.1S Speed Transient for the Unloaded Cage Motor
with a 9A Torque Current Limit with I Type Control
-5
-6
-7
-8
-9
-f--~fL---r--~~--T-~-r~~----,-~~~~~~~-10
50 100 150 200 250 300 350 400 450 500
TIME (ma) .
1400
1120
840
S60
280
o
-280
-560
-840
-1120
-1400
spe eo (rpm). Current (A).
3
2
_ Speed.
1 Id.
o Iq.
-1
-2
-3
-4
-5
-6
-7
-8
-9
-10
o
Figure 6.16 Speed Transient for the loaded Cage Motor
with a 9A Torque Current Limit with I Type Control
See footnote on page 114
122
6.5.2)The Wound Rotor Induction Motor
The d and q axis currents measured for a speed
transient of the wound rotor machine without any form of
current compensation are shown in Fig. 6.17. Again there
is significant coupling between the two controllers during
a transient, and the steady state values of d and q axis
currents obtained are lower than expected. Lead Lag
compensation in the stator frame of reference (Fig. 6.18,
eqn. 6.5) increases the steady state values slightly but
has no serious effect on the transient performance. D - q
axis compensation (Fig. 6.19, eqn. 6.6) has a considerable
effect on the d and q axis current control with a slight
improvement in the acceleration rate of the motor.
'iaref := iaref(1 + sO.159)/(1 + sO.138) (6.5)
T = 20 - (fe/S) (6.6)
The
1230rpm/s
average acceleration rate as measured is
which is lower than the simulation. This
suggests that the flux angle is not fully tracked during
the transient, with a resulting loss of torque.
6.6)V-TYPE VECTOR CONTROL WITH CURRENT FEEDBACK
The results for this form of control are discussed in
slightly more detail as this was found to be the best form
of implementing the vector control algorithm, and provided
the basis of the identification strategies employed.
6.6.1}The Cage Rotor Motor
The initial experimentation with this form of control
was concerned with the need for employing d-q axis
compensation to the output of the two current controllers.
123
800
640
480
320
160
o
-160
-320
-480
-640
-800
spe en (rpm). Current (A).
5
4
3 - Speed.
Id.
2 ..... Iq.
1
o
-1
-2
-3
-4
-5
-6
-7
-8
-9
-10
-i~~.---~----,----r~~P---~--~----~--~----+--11
400 800 1200 1600 2000 2400 2BOO 3200 3600 4000o
TIME (ms) .
Figure 6.17 Speed transient for the Unloaded Wound Motor -
I Type Control with no Compensation
800
6i10
480
320
160
0
-160
-320
-480
-640
-800
0
speed (rpm). Current (A).
400 800 1200 1600 2000 2400 2800 3200 3600 4000
TIME (ms) .
Figure 6.18 Speed transient for the Unloaded Wound Motor -
I Type Control with Lead-Lag Compensation
124
speed (rpm). Current (A).
800
r: ~
• 'i:I\~:'i}tvt!/\V!,jfV\J\\t)..r;,:(} ..•i"!i''<Y.!'''~\')''':''''>·~'\~''\'\.}.'.?-V'\'\",: ..;·-.-,~-·",." ..i·i,N.-~"A!>·,:'
640
480
320
160
0
-160
-320
-480
-6':0
-800
0 800 1200 1600 2000 2400 2800 3200 3600 4000
TIME (ms) .
Figure 6.19 Speed transient for the Unloaded Wound Motor -
I Type Control with Lead-Lag and D-Q Axis Compensation
125
Figure 6.20 shows a speed transient when no compensation
is used, whereas Figure 6.21 employs compensation outlined
in chapter 2 (both with an uncoupled motor). It can be
seen that there is a slight improvement to the d axis
current control - the disturbance caused during a high
d(iq)/dt is reduced - and the steady state value of the
torque current is improved slightly. Leonhard [7]
suggests that this form of compensation is only necessary
for sample frequencies less than 1 kHz.
The performance of the current controllers was found
to be better than the SIMBOL design. The rise time of a
step input of current demand was comparable with the
simulated result, but the overshoot was negligible,
resulting in a settling time of 6ms. The reduction of
overshoot was due to the suppression of the integral part
of the controller during controller saturation, a feature
which could not be included on the SIMBOL design.
Figures 6.21 and 6.22 (uncoupled motor), and 6.23
(motor loaded as before) illustrate the transient
performance of this system for comparison with V Type and
I Type control. Torque and flux current are accurately
controlled. The rate of acceleration for the unloaded
motor at rated torque is 14000rpm/s which compares
favourably with the SIMBOL simulation.
Figures 6.21, 6.22 and 6.24 illustrate the effect of
increasing the torque current limit for the uncoupled
machine. A torque current limit of 4.5A results in a
1400rpm to -1400rpm average acceleration time of ~ 200ms.
A 9A limit results in a transient time of ~ 100ms. Three
times rated torque limit gives a transient time of ~ 80ms.
The corresponding acceleration times for the loaded
machine are ~ 1600ms (Fig. 6.25 4.5A), ~ 800ms (Fig 6.26
9A) and ~ 620ms (Fig 6.27 13.5A). This is good evidence
that he v ctor control strategy is working effectively.
However 't also shows that when very high acceleration
currents are employed some slight detuning of the rotor
time constant occurs (three times rated torque current
126
speed (rpm).
1400
1120
840
560
280
0
-280
-560
-840
-1120
-1400
0
Current (A).
3
2 - Speed .
..... Id .
..... Iq.
o
-1
-2
-3
-4
50 100 150 200 250 300 350 400 450 500
TIME (ms) •
Figure 6.20 Speed transient for the Unloaded Cage Motor
VI Type Control with no Compensation
1400
1120
840
S60
280
0
-280
-560
-840
-1120
-1400
0
speed (rpm). Current (A).
3
~I'\,!'r· ....../\lv .,..,.v...,.,.,·,·,.~\i;'''y\"..,...iVV'...'''-\''.j'··\,,·,,··,,·..j·'·/V/\····..,·/' ·\.......··'\·..,···..v.f\ ../··....·./\...... 2 _ S pee d .
..... Id .
..... Iq.
1
o
-1
-2
-3
-4
50 100 150 200 250 300 350 400 450 500
TIME (ms) .
Figure 6.21 Speed transient for the Unloaded Cage Motor
VI Type Control with D-Q Axis Compensation
127
1400
1120
840
560
280
0
-280
-560
-840
-1120
-1400
0
speed (rpm). Current (A).
3
2
_ Speed.
1 ..... Id .
...__Iq.
o
-1
-2
-3
-4
-5
-6
-7
-8
-9
-4--~~--~--~----r_--_,--_,----r_--_r--~----T_-10
50 100 150 200 250 300 350 400 450 500
TIME (ms) .
Figure 6.22 Speed Transient for the Unloaded Cage Motor
with a 9A Torque Current Limit with VI Type Control
speed (rpm).
1400
Current (A).
1120
840
560
260
0
-280
-560
-840
-1120
-1400
0
3
2
_ Speed.
1 ..... Id .
. Iq.
o
-1
-2
-3
-4
-5
-6
-7
-8
-9
-+---,r---~---r---.~~~~~---r--~----~--~-10
200 400 600 800 1000 1200 1400 1600 1800 2000
TIME (ms) .
Figure 6.23 Sp ed Transient for the loaded Cage Motor
with 9A Torque Current Limit with VI Type Control
see footnote on page 114
spe o (rpm).
1400
1 20
BI10
560
2BO
0
-280
-560
-B40
-1120
-1400
0
Current CA).
3
2
1
::8ed.
-
- .
0 -
- .
-1
-2
-3
-4
-5
-6
-7
-8
-9
-10
-11
-12
-13
•
~~"\"'''\..~.:'1''''' , ~. '''• ... ,,, , - -t / _.'\ : - : _ _.: ~ ~ .
,,,/...;.,,,"1"1\,1\. .... "-,........\ ...\ ....,...\., .......\ .....'.·'\/ ....\., ...... '\..<r ..·........·~·.....· ·" ..·.t'~.r-,·..;·_··,.·\ .._..,··......._-·l·· ......,-.lo'
r
I
50 100 150 200 250 300 350 400 450 500
TIME (rns) .
Figure 6.24 Speed Transient for the Unloaded Cage Motor
wi h 13.SA Torque Current Limit with VI Type Control
Current CA).speed (rpm).
200
960
720
480
240
0
-240
-480
-720
-960
- 200
0
3
2 - Speed.
.....I: .
.....Ic; .
1
o
-1
-2
-3
-4
200 400 600 800 1000 1200 1400 1600 1800 2000
TIME (ms) .
Fi u 6.2S Transient for the loaded Cage Motor
wi h .SA Torque Current Limit with VI Type Control
S footnote on page 114
1200
960
720
480
240
0
-240
-480
-720
-960
-1200
0
speed (rpm). Current (A).
3
2
_ Speed.
1 .....Ie .
.....Ie.
o
~l'~, -1
:!Ff'\l,,,,.,,, j IJ . I I U! ''rr·,~·\r';';1't·'ifrti"'\""''rr'M~r~I'fifiyrl'·f..y;'-I\Ji -2
J' ~:
I
~ -5
;1 -6
I 7I -
I -8
,
I -9
\\·i".,vy4
-+--~~--.----r~-T~==~~~--~~~~~~~~-10
200 400 600 800 1000 1200 1400 1600 1800 2000
TIME ems).
Figure 6.26 Sp ed Transient for the loaded Cage Motor
wi h A Torque Current Limit with VI Type Control
speed (rpm). Current (A).
200 3
960 1 = i~~ed.
720 0 ._.. I:;.
480
240
0
-240
-480
-720
-960
-1200
0
-1
-2
-3
-4
-5
-6
-7
-8
-9
-10
-11
-12
-+~~~~~~~~~~~--~~~--~~~~~r--13
200 400 600 800 1000 1200 1400 1600 1800 2000
TIME (ms).
Figur 6.27 Sp d Transient for the loaded Cage Motor
w' h 13.5A Torque Current Limit with VI Type
Con 01
S footnote on page 114
should yield verage acceleration times of 75ms and 600ms
resp 0 ively).
It w s occasionally noticed that when higher
currents were used, there was sometimes a
in the acceleration curve around 0 rpm. This
n bout 5% of the transients captured. When
this occurr d the final value obtained for torque current
after h transient differed slightly from the value
befor the r nSient, as shown in Figure 6.28. This
sug9 s h t in some instances the rotor flux tracking is
being 10 du to a significant change in Tr. Under these
circum is thought that the change is more likely
due 0 tur tion effects on Lr rather than temperature
eff cts on Rr. This hypothesis is discussed further in
section 6.8.
acceler tion
slight t'k nk"
was no '0 b
6.6.2)
y
d and q axis current controllers worked
y w' hout compensation on the output. Again the
of h current controllers was better than the
mu ticn (no overshoot and 5.5ms settling time)
uppr ssicn of the controller integrator during
Sp d transients for 8.3A (rated) and 12A
l'mits are shown in Figures 6.29, and
o acceleration for the unloaded motor at
1311rpm/s which compares favourably with
'mu! tion. It is noticable that there only a
in acceleration rate for an increase of
limit from 8.3A to 12A, suggesting some
c s within the motor. Furthermore the
orgue current after a transient (and thus
qu ncy) ppeared to change, suggesting some
n ro or time constant variation during a
n . Th' ph nomena is further discussed in section
Th
eff c iv
p rfo m
SIMBOL
due 0 h
satu
·orq
6.30. Th
rate 0 u
he S OL
sl'gh ncr
torqu cu
s ur
sl'p
d unin
tr n
6,B.
131
1400
1120
840
560
280
0
-280
-560
-840
-1120
-1400
0
speed (rpm).
r----------------------------------r- 10
Current (A).
50 100 150 200 250 300 350 400 450 500
TIME (ms) .
9
_ Speed.
S ..... Id.
..... Iq.
7
6
5
4
3
2
1
0
-1
-2
Figure 6.28 Speed Transient for the Unloaded Cage Motor
with a 9A Torque Current Limit with VI Type Control
Showing Loss of Flux Tracking.
800
640
480
320
160
0
-160
-320
-480
-640
-800
0
speed (rpm). Current (A).
-T4--,----r---~--1I--_r--_,----r_--,_--_.--_+_-1
400 800 1200 1600 2000 2400 2800 3200 3600 4000
TIME (ms) .
9
S _ Speed.
..... Id .
7 ..... Iq.
6
5
4
3
2
1
0
Figure 6.29 Speed Transient for the Unloaded Wound Motor
with a 8.3A Torque Current Limit with VI Type Control
132
Current (A)speed (rpm) .
800
640
480
320
160
0
-160
-320
-480
-640
-800
0 400 800
13
12
_ Speed.
11 Id.
10 .....t c .
9
8
7
6
5
4
3
2
1
o
~~--~--~---r---,----r---~---r---'----r---T--1
1200 1600 2000 2400 2800 3200 3600 4000
TIME (ms) .
Figure 6.30 Speed Transient for the Unloaded Wound Motor
with a 12A Torque Current Limit with VI Type Control
133
6.7)ROTOR TIME CONSTANT IDENTIFICATION
6.7.1)Reactive Power Measurement
The identification strategies update the parameter K
(the slip gain) within the vector controller, where K is
the constant of proportionality between the slip and isq
when equation 2.10 is implemented by the controller. Its
dependence on the rotor time constant is as follows :-
(6.7)
K = (50/2n)(Rr/Lr) (6.8)
The value for K calculated from the measured cage motor
parameters is 65.
Figure 6.31 shows a speed transient for the unloaded
cage motor with a torque current limit of 9A when the
value of K is "detuned" from the actual motor Tr. In this
case K = 100. It can be seen that the discrepancy in K
from the measured value leads to a slight degradation of
the acceleration curve, but because the load is so small,
steady state error of the torque current is difficult to
perceive. Figure 6.32 illustrates a steady state
implementation of the reactive power identification
strategy with K initially 100. The expected final value is
k = 65, and the trace shows that the routine hones in on
a value within 10% of this within 500ms. Figure 6.33 shows
a transient taken immediately after identification and the
improvement of the acceleration curve can be seen in a
reduction of 30 ms for the transient time. The average
acceleration of Fig. 6.33. is very similar to that of Fig.
6.22. which is good evidence of the identification
strategy working effectively. Again it was noticed that
for a few post transient identification implementations
(about 5%) some discrepancy occurred, in this case being
the calculation of a value of K different to that
134
speeo (rpm).
1000
800
600
400
200
0
-200
-400
-600
-800
-1000
0
Current (A).
3
.........\('v.\ .,\ ,' ,,' "" ~ " '-, "/',,'-,",-, '..,' -,.~ - '.~..'" ", ".,.. ,' ".'", . 2
_ Speed.
1 ..... Id .
..... Iq.
o
-2
-4
-7
50 100 150 200 250 300 350 400 450 500
TIME (ms) .
Figure 6.31 Speed Transient for the "Detuned" Unloaded
Cage Motor (K = 100)
K.speed (rpm).
1000
900
800
700
600
500
400
300
200
100
o
100
90 _ Speed.
..... K.
80
70
60
50
40
30
20
10
o 100 200 300 400 500 600 700 800 900 1000
TIME (ms) .
Figure 6.32 Steady State Tr Identification using Reactive
Power Measurement (K = 100 Initially)
135
1000
800
600
400
200
0
-200
-400
-600
-800
-1000
0
speed (rpm). Current (A).
3
2
_ Speed.
1 ..... Id .
'" .f!''''-_, ', ":, -, "., ..', .." ...." ..",.,,, r-,......' ,r ,....'".,.i", ...,,·......." ,.,..'","',,""." ,"."".".",.",,' .• """' ...,"r.,:,.".,'.."""""""..-,..'"_",,,",.
..... Iq.
o
-1
-2
-3
-4
-5
-6
-7
-8
-9
~----~--~~=ro=~~--~--~---r--~----r---~-10
50 100 150 200 250 300 350 400 450 500
TIME (ms) ,
Figure 6.33 Speed Transient for the Unloaded Cage Motor
After Steady State Tr Identification
K.speed (rpm).
1000
800
600
400
200
0
-200
-400
-600
-800
-1000
0
130
120
.. _ Speed.
\\ 110 ..···K.
\;
~ 100
\.~
",..', 90
'.. \'1\\,
-, 80
\ ....•
~ 70
, ,,... . ",., "- 60
' "..,., ,.''',.." .,''.~ .,~.... 50
40
30
20
10
-4----~---r--~----~---r--~----T---~----r---~0
50 100 150 200 250 300 350 400 450 500
TIME (ms i .
Figure 6.34 Transient Tr Identification for the Unloaded
Cage Motor (K = 100 Initially)
136
expected (in the range of 45 to 75). This was particularly
noticable as the acceleration current is increased. This
again suggests that during some transients the value of
the actual rotor time constant is changing due to
saturation effects, which the reactive power method cannot
identify due to its reliance on an accurate knowledge of
M.
Figure 6.34 illustrates the use of the identification
strategy during a speed transient, with K initially 100.
During the transient there is no real correlation between
the calculated value of K and expected value of K, and it
is not until a steady speed is reached that the Tr
identification works predictably.
Similar identification traces are shown for the
loaded motor in Figures 6.35 - 6.38. The detuned value for
Fig 6.35 is again K = 100, and steady state identification
gives a correction to K = 62 (Fig 6.36). This value is
expected to be slightly different from the value found
for the unloaded motor as the steady state torque current
is significantly larger and results in some temperature
change in Rr. Results show that the routine comes to
within 10% of the expected value for K. These errors are
to be expected as the method depends on an accurate
calibration of the PWM generator voltage and knowledge of
the exact value of the magnetising inductance, rotor self
inductance and stator self inductance; these parameters
are used by the identification calculations. The
improvement in the speed transient time seen in Fig 6.37
as a reduction of 175ms and an average acceleration very
similar to that of Fig. 6.23. Again the transient
identifica ion (Fig 6.38) cannot be regarded as effective
during the transient.
Figures 6.39 and 6.40 illustrate the rotor
time constant identification strategy employed on the
wound machine. The first trace has an initial slip gain of
35 and hones in on the measured slip gain of 110 within
SOOms. The second trace starts with K = 160 and identifies
137
1000
800
600
400
200
0
-200
-400
-600
-800
-1000
0
speec (rpm). Current (A).
3
2
_ Speed.
1 .....Id .
.....t o ,
o
-1
-2
-3
-4
-5
-6
-7
-8
-9
~----'----'----~----~~-r~~~---r~--~~~1~~+--10
1000 1200 1400 1600 1800 2000200 400 600 800
TIME (ms) ,
Figure 6.35 Speed Transient for the "Detuned" loaded
Cage Motor (K = '100)
1000
900
800
700
600
500
400
300
200
100
o
speed (rpm). K.
90 _ Speed.
..... K.
80
70
60
50
40
30
20
10
o 200 400 600 800 1000 1200 1400 1600 1800 2000
TIME (msi .
Figure 6.36 ste dy State Tr Identification using Reactive
Pow r Measurement (K = 100 Initially)
138
Current (A).speed (rpm).
000
800
600
400
200
0
-200
-400
-600
-800
-1000
0
3
·It \l'\~~{.!..· ·'~~·,·~~· '.· .p.f:.~J:~~··..t..~··,. ":·~~'io;,.. ,': • .:...:.,~.~ ~:.:,j.• .• .11.:"::;.:· -, ~:-,~.·~ v:•···'~·'1.·=r{·:·:f~!·~.~~"~:h···2
_ Speed.
1 ..... Id .
..... Iq.
o
-1
-2
-3
-4
-5
-6
-7
-8
-9
I -10
200 400 600 800 1000 1200 1400 1600 1800 2000
TIME (ms).
Figure 6.37 Sp ed Transient for the loaded Cage Motor
Af r Steady State Tr Identification
speed (rpm) .
1000
800
600
400
200
0
-200
-400
-600
-800
-1000
Figur
K.
130
120
_ Speec.
110 .....K.
100
90
80
70
- 60
50
40
30
20
10
-t---'.---~---r--~~~~~~~~~~~~~~~o
200 400 600 800 1000 1200 1400 1600 1800 2000o
TIME (ms) ,
. 8 Tr nsient Tr Identification for the loaded
C 9 Motor (K = 100 Initially)
139
speec (rpm) . K.
800 110
720 .v'"
..... \ ..... '''' • • ' ,,"O'~# ............ , ":. ·~,t.• • .• ~.. ' ',• • ~• .• _• • • ~.• .. -• ..~.:.' ... - • ./'-t.' ~ ..,! • • • •>... ',.\." .....".\ • • •
100
~ -
Speed.
/
..... K .
640 90
560
80
480
70
60
400
50
320
40
240
30
160 20
80 10
0 0
0 100 200 300 400 500 600 700 800 900 1000
TIME (ms)
Figure 6.39 S dy State Tr Identification for the Wound
Motor using R c ive Power Measurement (K = 35 Initially)
speea (rpm) . K.
800 160
150
720 ''''~'''a..~ 140- Speed.
............ _.\ ..............\- .. ..... K .
640
, 130
"· .."~'- ..·'··~·.·• .'• .•!.h..,..• .~"."......._ .............,<, ,.-'w , ....._w_. 120
560 110
480
100
90
400 80
70
320 60
240 50
40
160 30
eo
20
10
0 -0
0 200 400 600 800 1000 1200 1400 1600 1800 2000
TIME (ms) .
Figur 6. 0 S dy Sate Tr Identification for the Wound
c v Power Measurement (K = 160 Initially)Mo or usi
140
the correct K within ls, showing that the strategy
works re on bly effectively. However in this case the
number of "rogue" results obtained for a steady state
identific tion fter a transient was significantly
increased ( bout 30%).
6.7.2)
The
proved u
speed
generat
and pwm
peak cou
implem ntation of this identification strategy
ucc ful. The disturbances measured on the
gn 1 w r small, and comparable to the noise
by round'ng errors within the speed controller
n r or. This meant that no correlation function
oun nd thus no correction factor for K
could be c cu t d. Since this is at variance with
publish d r ults more work is necessary here. It is
though 0 x mpl that the PRBS magnitude injected onto
the d axi current should be increased in order to
incre s th m ni ude of the disturbances.
ORMANCE ANALYSIS6.8
I
of h
feedb ck
felt 0 b
curren
main r
assum
and h
therm
"per v
obviou u
0
ace
u
h d scussing here some of the
s obt ined with the V Type
implications
with current
r. As mentioned earlier this method was
mo t ccurate at controlling the d and q axis
w Is the slip frequency, suppOsedly the
m nt of indirect vector control. If it is
h 0 or time constant is accurately known
h rotor resistance does not change
y during speed transient, (because the
on nt of the motor coils is large) then a
o controlled drive would be expected. The
m n of this perfect drive are that:-
'v n 0 or flux magnitude and torque limit
v n i nts imposed on the controller
'41
hou
acc
prove consistent ie. straight line
curves (assuming a fairly constant
10 d torque), nd same initial rate of acceleration.
b)After r ns'ents have been imposed as in a), the
dy torque current and slip frequency
hou d b h s me.
c)Th cc
.hou d
curr
con
r tion rate for a given change in speed
ncre s proportionally with the torque
et at the output of the speed
. In theory this should only be limited by
c p bilities of the motor windings or the
d.
th
inv r
d)If
f r
th c
m y b
r
R ul
clos 0
som d
(a) ( )
degr d 'on
mach1n
wound 0 0
for 10
te identification strategy is employed
r 'ent there should be no large change in
cu d controller slip gain. A small change
xp C due to thermal changes in the rotor
nc uring the transient.
k n for the cage motor show that it is
1 fy'n hese conditions when unloaded, but
n 0 p rformance as defined by the criteria
ob erv d when loaded. More noticable
in form nce was noted for the wound rotor
hown that (c) does not occur for the
, and that (a), (b), and (d) only occur
taken. Operating conditions after a
nd when this does occur, if a Tr
9'1 is employed, the resultant
t an n
'den
ca cu 0
exp c d.
sch
ax!
wn'ch
h
do v 'i,
on r
P 9 in varies significantly with that
u rement of an indirect vector control
flux vector be imposed of constant
ee with respect to the stator fixed
s controlled according to eqn. 2.11
n v ue of ~rd can be rewritten as
M (6.9)
142
'rh ro 0
of th c u
in App nd,.)(S,
ux vector can also be considered in terms
tor and rotor current vectors, as given
ueh that :-
~d • • + zrs (6 . 10 )
wher· h ot 1 flux linking the rotor "coil" due to
the ro 0 ell r n only, and ttrsis the flux linking the
rotor du 0 h or currents. This can be rewritten as
:.-
L i Hi -j& (6.11)
h n 1 between the stator reference current
h 0 0 r ference current axis. It can be seen
on 0 th vector controller will .inevitably
o high values during a transient, and
oRis controlled by the angle & by
on. Thus under controlled conditions the
will not exceed its preset value and
o further into saturation. However,
y rrors introduced into the flux angle
or, due to say a slight inaccuracy in K,
p d (and thus angular) resolution at
ux vector misalignment will occur and
w 11 attempt to increase or reduce
n'tud , depending on the sign of the
illustrated in Figures 6.41a. and
rotor time constant for the two
motor) and 111ms (wound motor).
lux magnitude due to detuning under
v y po ible given the time duration of
n . For the case of increasing flux,
is will result in the iron going
e using a reduction in the values
o or time constant will thus change.
n ly operated with the iron in near
o Ow that a reduction in flux will
wh re
axis
th
incre
thus
vee or d
ro or f ux
th mo 0
sholld h r b
m 0 on h ID
compoun
low
the hi 0
th ro
ang 1
6.41 .
mach
Som v
high
h h
th
fu
0
S' c
u n,
143
.rs
IqMO or
"
.,'
iqcon r-ot . idfY'lotor
idcontrol
8Motor
sto. tor o.xis
Figure 6, 10., Increo.se in Rotor Flux
e 0 Detuning,
IqMO or
"
"
. Idcontrol
rqcon rot tdno t or-
8fY'1otor
FIg r 6.
0con rot
Decreo.se in Rotor Flux
o e tnlng
144
resul
betw
affec
in n'ne s in Lr and Tr. This discrepancy
h 0 0 T nd the controller Tr will further
or in the rotor flux angle. Eventually an
equl 'br
ob
of mo or Tr and flux angle error will be
o is held constant as is returns to
th n the result would be a net change
t dy state isq required to run the
. The effects are precisely those
c for the cage machine and 30% for the
Why t only occurs for a small fraction of
own bu i is expected to depend on the
lux ngle error during detuning. This
a s
in f ux
motor
observ
woun
cas
s ems to be supported by the
o d' crepancy for this phenomena for
m ch'n . The rated current of the wound
h im s the value of the magnetising
f et of is causing iron saturation
ID wou d certainly be expected. The rated
m chin is only twice the magnetising
probl rns should not be so evident. It
h c reful consideration of the type
for indirect vector control should
u9gests the use of a saturation
motor in order to estimate the best
p cific motor drive.
o course that the indirect control
ck of explicit flux control, is
hniqu to that of direct control.
n chapter 7.
dif
th
cu
cu
is c
of mo or
b
con v
'W
p
T
6. ON
v c 0
n
h P rallel implementation of the
m y be assessed by the a and B
n ch pter 3) for the processesp
'4S
running on T2 and T3. The assessment is complicated by the
fact that there are two timing loops, 250~s and 2ms
corresponding to the sample times of the fast current
loops and the slower speed loop respectively. Within the
philosophy described the latter timing loop can only be
obtained by activating the speed processing loop every 8
cycles of the ts = 250~s loop. Furthermore the procedures
executed for the speed loop processing can be farmed out
to successive 250~s cycles. Thus the times tp and tt vary
according to whether the speed processing is active and
according to which speed processing procedure is active.
In Table 1 of Figure 6.42. the best and worst case values
of a and a are given (where appropriate) for T2 and T3 for
each implementation.
The results of Table 1 are rather enlightening albeit
in a rather negative sense. The problem derives from the
ratio of a/a as shown in Table 1. This ratio represents
the percentage work load taken up in communicating data
from one process to another. The absolute values of a and
B are low, and indicate that a faster process sample time
could be employed by the transputer network.
For the V Type control strategy, T2, for example
spends most of its time merely communicating data (a/B =
100%; row 2) and acting as a buffer between T1, T3 and
sampling external signals. Only when speed processing and
deriving the vector control frequency demand does T2 begin
to do "real" work. For the V Type control with current
feedback, a and a for T2 falls to 48% (for the non speed
processing 250~s loop) on account of T2 being responsible
for the id and iq feedback loops. For this strategy, the
best ratio of a/a for T2, when T2 is processing both
current loops, the speed loop, the vector control and the
3-2 phase current transformations, is 55%. This
illustrates the performance of a microcomputer with high
arithmetic speed and slow communication time.
146
E-<
U) 0
........ oa 0 It) r-
rJ(> 0 .... \0 co
-
3:
0
cQ I-- ("") 0 f-- ("") CO ~ ("") N I---
..._ \0 .... \0 '<:I' If') r--
tl E-<
U) N It) "'"W \0 It) \0
III
E-<
U)
~
\0 0'1 0
.--. 0 N "'"
(""')
rJ(> 3:
- r--- CO 0 ~ CO (""') r-- 0 "'"
I--
cQ
"'"
....
"'"
("") CO ....
E-<
Cl) CO 0 co
W N
"'"
N
III
E-<
U)
oa \0 N \0
0 N ("") N
----
3:
.JP
-
I--- 0 0 ~ 0 \0 r-- N 0 ~
("") .... ("") ....
"'"
....
tl E-< 1.0U) \0 N
W .... N ....
III
.---
~
Z
E-< H
::J U)
0 Cl)
::r: w E-< 8 8
8 U o ::> ::J
H 0 0 0 0
3: ~ 1 ::r:: :x: I ::r:: ::r: I ::r:: ::r:
..._
~ 8 8 8 8 8 E-<
::r: H H H H H H
E-< Cl 3: 3: 3: 3: 3: 3:
H W
3: W
~
U)
~
W
&1 U)
::J U)
~ W
Cl) U M N N ("") N N ("") N N
Z 0 E-< E-< 8 E-< 8 8 E-< E-< E-<
.et: ~
~ ~
E-<
Z
0 ::r::
H 8
8 H
.et: 3: 8 ~
&1 ..:l Z 0 ~
Z W 0 W IJ:l ~ IJ:l 0
W Il.I ~ Il.I ~ 8 P-4 ~
:E :M 8 .~ oa z ~ 8
W 8 Z 8 ::> 0 8 Z
~ 0 U U 0
~ >- u :> H U
:E
H
'47
----Cl)
Cl)
<l)
0
0
I-l
0..
I-l
<l)
0.. <l)
-
<l) e:
e: 0r-l
Cl) 0r-l +l
H +l
0 <l)
-+J <l) r-I
U r-I 0..
cO 0.. e:
~ e: cO
cO til
<l) til ..._
U ..._ <1J
C <1J El
.... cO El 0r-l
e: 0r-l +l
W I-l +l
H 0 Cl)
III ~ C til
..:x: H 0 <1J
8 <1J 0r-l 0
~ +l 0
cO I-l
C U 0..
0 0r-l
0r-l C <1J
-+J ::l >
cO e: 0r-l
+l e: +l
C 0 0
<1J 0 cO
e:
<1J
...-l tl cQ
0.,
N e:
"'"
H
\D ...-l
<1J
<l)
...-l
I-l ...-l
::l cO
0'1 H
0r-l cO
~ Il.I
C~P~R7
FURTHER DISCUSSION AND CONCLUSIONS
7.1)INDIRECT VECTOR CONTROL
7.1.1)V-Type Control
V Type control has been seen to give a fairly good
transient speed control, although the current control was
rather crude. It is obvious that current control without
current feedback will be somewhat deficient due to the
slow sample time employed, and the accuracy of the machine
parameters used by the controller. However if the maximum
current demanded by the controller is set to well within
the ratings of the inverter and motor, then this is a
means for getting reasonable transient performance from
the drive with only a speed feedback signal.
The transputer implementation performance data
indicates that this form of control (both vector control
calculations and PWM calculations) could be implemented on
a single transputer or high performance sequential
processor, albeit with very limited monitoring
capabilities. This may be of interest to drive
manufacturers.
7.1.2)I-Type Control
The main problems ar~s~ng from this type of control
arise from the fairly low switching frequency of the 4kHz
bang-bang controller, which results in a long inverter
delay. Lead-Lag and D-Q axis compensation do have an
effect on the current control of this strategy, and it is
felt that the fast current loop should be implemented in
analogue (downstream of the transputer) in order to
148
increase accuracy of the current control and minimise the
inverter delay. If this were the case, then if a
reasonably high performance drive is required with no Tr
identification, it is felt that this system could also be
implemented on a single processor.
7.1.3)V-TyPe Control with Current Feedback
This
provide
controlled
form of
the best
indirect vector
foundation for
control
an all
appears to
digitally
high performance drive. The results indicate
that current and speed control are carried out effectively
using the pre-measured values for Tr and current loop
design. The use of two processors is mandatory for such a
controller. However if a PWM carrier frequency of 4kHz
could be employed the control and actuation routines would
make optimum use of the processing power of tha transputer
network.
7.1.4)Rotor Time Constant Identification
The need for rotor time constant identification has
been demonstrated, and initial results indicate that the
Reactive Power Measurement strategy certainly improves the
performance of the drive. It is felt however that under
the experimental conditions used, the variation of the
rotor time constant that tends to cause detuning result
from flux change and hence change of the mutual inductance
rather that variations in the rotor resistance due to
temperature. This should make the method of identification
somewhat invalid due to its dependence on accurate pre-
measured values of Ls, Lr, and M. The exact nature of the
problem of flux variation during a speed transient - its
cause and effect, and stability - is still a subject of
research.
It is felt that until the problem of rotor time
constant detuning is fully understood and compensated for,
149
direct vector control is a superior technique for
obtaining a high performance induction motor drive.
Whether the increase in performance justifies the machine
modification required is a question only answered by a
particular drive specification.
7 • 2 ) FUTURE WORK
The ease of alteration to particular parts of the
vector control scheme allows the investigation of various
implementations of the vector control algorithm and
actuation routines. Work in this area may include the use
of modern control theory for the current control loops as
described for example by Lorenz [20], Taufiq [30],[31],
and Kumamoto [32]. It may also include the assessment of
the other PWM strategies such as synchronous PWM, the Five
Mode PWM control suggested by Nordby [27] and the recently
proposed voltage vector control strategy [33]. The
implementation of an analogue bang-bang controller for
further appraisal of the I Type control strategy is also
under consideration.
The control network constructed here provides the
processing power and the potential for further study into
the area of on line global and rotor parameter adaption
and the influence of motor saturation. The network not
only provides the computational facilities but is also
able to take in more signal measurements (DC Link voltage,
rotor currents and direct rotor flux measurement if
required) without modification. The possible application
and evaluation of Kalman Filtering techniques for optimal
estimation [34],[35], would require the "number crunching"
capability of the transputer network. Such a rig would
truly be able to assess the effectiveness of Tr
identification schemes by measuring and comparing the
controller and machine rotor flux vectors.
The drive rig constructed also provides the ability
150
to appraise Self-Commissioning of induction motor drives,
as proposed by Schierling [36],[37]. The capability of
taking an "off the shelf" motor and connecting it directly
to a vector controller without the need for extensive
machine tests to determine the machine paramete~s would be
of particular interest to drive manufacturers.
7.3)THE TRANSPUTER AND PARALLEL PROCESSING FOR MOTOR
DRIVES
The functions of a high performance field orientated
drive controller exhibit a natural parallism. In
particular a three way parallelism exists between control,
supervisor/communication, and background computing
functions. The latter is likely to become increasingly
more important in future as a single drive package becomes
more capable of optimised performance over a wide range of
user applications. It is worth noting that at least one
manufacturer has utilised the parallelism between the
control and supervisory functions using two processors.
This has led to the capability of remote commissioning and
monitoring and it is likely that this too will be a growth
area.
The effectiveness of the transputer for real time
control applications has been demonstrated. The transputer
system has significant advantages, particularly if
modularity and ease of modification to meet multifarious
specifications are the main criteria. It is for example
ideal for use in drive research rigs for evaluating
algoriths over the whole spectrum of drive controller
functions. Although hardware development and board costs
are low, the transputers are not low cost devices at the
moment and for commercial drives, their application would
be expected to be restricted to the high power range. For
low and medium performance it is envisaged that a hardware
specific parallelism involving conventional processors
151
with a defined, restrictive specification is likely to
remain the most economic option for some time. In
conclusion it can be said that the transputer behaves as a
powerful computer with a slow communication time: this
results in fast computation with a lot of communication
which is not particularly elegant. The use of T800
transputers with their associated faster communication
rate (20 Mbits/s resulting in tc less than 5~s) will
improve this. On the positive side the ease of high level
language programming, the high degree of on line user
interaction whilst the drive is operational, the absence
of interrupt processing and the simplicity of process
synchronisation, and the ease and efficiency with which
fundamentally different schemes can be implemented with no
change in hardware must be emphasised. If flexibility of
the controller hardware is the principle criteria for a
motor drive research rig then the selection of a
transputer system is eminently justified.
152
REFERENCES
[1J LIPO, T.A.: "Recent Progress in the Development of
Solid- State AC Motor Drives", IEEE Trans. Power
Electronics, vol 3, April 1988, pp 105 - 117.
[2] FINNEY, D.,: "Variable Frequency AC Motor Drive
Systems.", Peter Peregrinus Ltd., London, 1988.
[3) BOSE, B.K.: "Power Electronics and AC Drives",
Prentice Hall New Jersey, 1986.
[4] KUME, T. and IWAKANE, T.: "High-Performance Vector-
Controlled AC Motor Drives: Applications and New
Technologies", IEEE Trans. Ind. Appl., vol 1A-23,
September/October 1987, pp 872 - 880.
[5] BLASCHKE, F.: "The Principle of Field Orientation as
Applied to the New TRANSVEKTOR Closed Loop Control
System for Rotating Field Machines", Siemens Review,
1972, pp 217.
[6] LEONHARD, W.: "Control of Electrical
Springer Verlag, 1985.
Drives",
[7] LEONHARD, W.: "Field-Orientation for Controlling AC
Machines Principle and Application", lEE PEVD
Conference, London, July 1988, pp 277 - 285.
[8] GABRIEL, R., LEONHARD, W., and NORDBY, C.J. : "Field-
Oriented Control of a Standard AC Motor Using
Microprocessors", IEEE Trans. Ind. Appl., vol 1A-16,
March/April 1980, pp 186 - 192.
153
[9] HARASHIMA, F., KONDO, S., OHNISHI, K., KAJITA, M.,
and SUSONO, M.: "Multirnicroprocessor-Based Control
System for Quick Response Induction Motor Drive",
IEEE Trans. Ind. Appl., vol 1A-21, May/June 1985, pp
603 - 609.
[10] KUBO, K., WATANABE, M., OHMAE, T., and KAMIYAMA, K.:
" A Fully Digitalized Speed Regulator using
Multimicroprocessor System for Induction Motor
Drives", IEEE Trans. Ind. Appl., vol
July/August 1985, pp 1001 - 1007.
1A-21,
[11] GARCES, L.J.: "Parameter Adaption for the Speed-
Controlled Static AC Drive with a Squirrel-Cage
Induction Motor",IEEE Trans. Ind. Appl., vol 1A-16,
March/April 1980, pp 173 - 178.
[12) MATSUO, T., and LIPO, T.A.: "A Rotor Parameter
Identification Scheme for Vector-Controlled Induction
Motor Drives", IEEE Trans. Ind. Appl., vol 1A-21,
May/June 1985, pp 624 - 632.
[13] KOYAMA, M., YANO, M., KAMIYAMA, I., and YANO, S.:
"Microprocessor-Based Vector Control System for
Induction Motor Drives with Rotor Time Constant
Identification Function", IEEE Trans. Ind. Appl.,
vol 1A-22, May/June 1986, pp 453 - 459.
[14] HOULDSWORTH, J.A. and ROSINK, W.B.: "Introduction to
PWM Speed Control System for 3 Phase AC Motors",
Electronic Components and Applications, Vol. 2, No.
2, February 1980.
[15] BROD, D.M.,and NOVOTNY, D.W.,: "Current Control of
VSI-PWM Inverters.", IEEE Trans. Ind. Appl., vol 1A-
21, May/June 1985, pp 562 - 570.
154
[16 J KRISHNAN, R. , and DORAN, F. C. : "Study of Parameter
Sensitivity in High Performance Inverter-Fed
Induction Motor Drive Systems " IEEE Trans.,
Ind. Appl. , vol 1A - 23, July/August 1987, pp 623
635.
[17] HO, E.Y.Y., and SEN, P.C.: "Decoupling Control of
Induction Motor Drives", IEEE Trans. Ind.
Electronics, vol 35, May 1988, pp 253 - 262.
[18] SUGIMOTO, H., and TAMAI, S.: "Secondary Resistance
Identification of an Induction-Motor Applied Model
Reference Adaptive System and Its Characteristics",
IEEE Trans. Ind. Appl., vol 1A-23, March/April 1987,
pp 296 - 303
[19 J KRISHNAN, R. , and DORAN, F.C. : "A Method of Sensing
Line Voltages for Parameter Adaption of Inverter-Fed
Induction Motor Servo Drives", IEEE Trans. Ind.
Appl. , vol 1A-23, July/August 1987, pp 617 - 622.
[20] LORENZ, R.D., and LAWSON, D.B.:
Feedforward Current Regulators
"Performance of
for Field-Oriented
Induction Machine Controllers", IEEE Trans. Ind.
Appl., vol 1A-23, July/August 1987, pp 597 - 601.
[21] "IMS C011 Link Adapter", INMOS Data Sheet.
[22] "8253 Programmable Interval Timer", INTEL Data Sheet,
INTEL Corperation, 1983.
[23] HOROWITZ, P. and HILL, W.: "The Art of Electronics",
Cambridge University Press, 1989.
[24] BOWES, S.R., and MOUNT, M.J.: "Microprocessor Control
of PWM Inverters", lEE Proe., vol 128, Pt. B, No.6,
November 1981, pp 293 - 305.
155
[25] BOWES, S.R., and DAVIES, T.: "Microprocessor-Based
Development System for PWM Variable-Speed Drives",
IEE Proc. vol 132, Pt. B, No.1, January 1985, pp 18
- 45.
[26] BOSE, B.K., and SUTHERLAND, H.A.: "A High-Performance
Pulsewidth Modulator for an Inverter-Fed Drive System
Using
1A-19,
a Microcomputer", IEEE Trans. Ind. Appl.,
March/April 1983, pp 235 - 243.
vol
[27] ZUBEK, J., ABBONOANTI, A., and NORDBY, C. J• :
"Pulsewidth Modulated Inverter Motor Drives with
Improved Modulation.", IEEE Trans. Ind. Appl., vol 1A
-11, November/December 1975, pp 695 - 703.
[28] "SIMBOL User Manual", Cambridge Control Publication,
Cambridge Control Ltd., Cambridge, CB3 OEI, UK, 1987.
[29] KHATER, F.M.H., LORENZ, R.D., NOVOTNY, D.W., and
TANG, K.: "Selection of Flux Level in Field-Oriented
Induction Machine Controllers with Consideration of
Magnetic saturation Effects", IEEE Trans. Ind.
Appl., vol 1A- 23, March/April 1987, pp 276 - 281.
[30] GARCIA-CERRADA, A., and TAUFIQ, J.,: "Convergence of
Rotor Flux Estimation in Field Orientated Control.",
IEE PEVD Conference, London, July 1988, pp 283
286.
[31] TAUFIQ, J., and GARCIA-CERRADA, A.,: "State Feedback
Control of Induction Motor Drives.", IEE Colloquium
on Control of Induction Motors, London, April 1989.
156
[32J KUMAMOTO, A., and HlRANE, Y.,: "An Experimental
Implementation of a Variable Speed Induction Motor
Drive System Based on Modern Adaptive Control
Theory.", EPEC, Grenoble, France, sept. 1987, pp 889
- 894.
[33] VAN DER BROECK, H.W., SKUDELNY, H.C., and STANKE,
G.V.,: "Analysis and Realisation of a Pulse Width
Modulator Based on Voltage Space Vectors.", IEEE
Trans. Ind. Appl., Vol 24, Jan/Feb 1988, pp 142 -149.
[34] ATKINSON, D.J., and ARCARNLEY, P.P.,: "Parameter
Identification Techniques for Induction Motor
Drives.", EPEC, Aachen, West Germany, Oct. 1989, pp
307 - 312.
[35] ZAI, L.V., and LIPO, T.A.,: "An Extended Kalman
Filter Approach to Rotor Time Constant Identification
in PWM Induction Motor Drives.", IEEE lAS, 1987, pp
177 - 183.
[36] SCHIERLING, H.,: "Self Commissioning A Novel
Feature of Modern Inverter Fed Induction Motor
Drives.",IEE PEVD Conference, London, July 1988, pp
287 - 291.
[37] JOETTEN, R., and SCHIERLING, H.,: "Adaptive and Self-
Commissioning Control for a Drive with Induction
Motor and Voltage Source Inverter.", EPEC , Grenoble,
France, Sept. 1987, pp 883 - 889.
[38] FLEMMING, P.J. (editor): "Parallel Processing in
Control: the transputer and other architectures. II,
Peter Peregrinus Ltd., London, 1988.
[39] "The Transputer Data Book", INMOS Publication, INMOS
Ltd., Bristol, BS12, 4SQ, UK, 1989.
157
[40] filMS 0700 User Manual", INMOS Publication, INMOS Ltd,
Bristol, BS12, 4SQ, UK.
[41] "Occam Tutorial", INMOS Publication, INMOS
Bristol, BS12, 4SQ, UK, 1989.
Ltd. ,
[42] GHEE, S.: "IMS B004 IBM PC Add In Board", INMOS
Technical
UK.
Note 11, INMOS Ltd, Bristol, BS12, 4SQ,
[43] "The Transputer Reference Manual", INMOS Publication,
INMOS Ltd., Bristol, BS12, 4SQ, UK, 1989.
[44] VADHER, A.: "IMS B006 Board", INMOS Technical Note
14, INMOS Ltd, Bristol, BS12, 4SQ, UK.
[45] SUMNER, M. and ASHER, G.M.: "PWM Induction Motor
Drive using the INMOS Transputer Parallel
Processor", IEEE APEC 88 Conference, New Orleans, pp
121 - 129.
[46] ASHER, G.M. and SUMNER, M.: "Real Time Motor Control
using a Transputer Parallel Processor Network",
EPEC, Aachen, 1989.
158
APPENDIX A
SPECIFICATIONS
A.1)WOUND ROTOR MACHINE
The parameters of the three phase, 50Hz, 380V, star
connected, 5hp 8.6A, 930rpm slip ring induction motor are:
Rs 20 Rr 2.10
Ls 0.235H Lr 0.234H
M 0.224H a 0.0875
Rated Torque 38 Nm.
Moment of Inertia 0.32kgm2 (coupled to DC generator)
A.2)SQUIRREL CAGE MACHINE
The parameters of the three phase, 50Hz, 415V, delta
connected, 5.5hp 8.1A, 1420rpm squirrel cage induction
motor are:
RS
Ls
M
Rated Torque
Moment of Inertia
5.40
0.600H
0.S85H
27 Nm.
0.023kgm2
a
4.80
0.596H
0.043
A.3)THE PWM INVERTER
Supplied by Control Techniques pIc, the
transistorised PWM inverter has the following ratings
159
Input
Power Output
Rated Current
3ph/415V +/- 6% 50-60 Hz
22kW
48A
Recommended "lockout time" 20}J.s
Recommended transistor "minimum on time" 20}J.s
Recommended transistor "minimum off time" 20}J.s
A.4)THE SPEED ENCODER
Muirhead Vactric Components Ltd.
H25D-2500-P4ZC-88C30-EM18
Counts per shaft turn 10,000
Type
Supply Requirements 5V, 175 rnA
Output signals clockwise, counter-clockwise and index
Output format complementary pair using CMOS line
driver
A.5)THE CURRENT TRANSDUCER
Type
Ratio
Accuracy
Linearity
Band Width
Supply Req.
LEM SA LT-80-P
1 : 1000
1%
0.1%
100kHz
+/- 15V
160
APPENDIX B
THE MATHEMATICAL MODEL OF THE INDUCTION MOTOR
The voltage across the "a" phase stator coil of the
induction motor can be written as :-
(B.1)
where ~a is the total flux linked to the coil. Similar
equations can be written for the "b" and "c" phase coils
of the motor, displaced from the "a" phase in space by
1200 and 2400 respectively. The resultant voltage vector
obtained by complex addition in the Argand plane can be
written as :-
(B. 2)
Similar vectors can be written for the stator current
and stator flux linkage, and thus B.1 can be rewritten in
terms of vectors as :-
Ys = Rsis + d(!s)/dt (B. 3)
It should be noted that these equations are in the stator
fixed frame of reference.
The rotor voltage vector equation can be written as
o = Rrir + d(!r)/dt (B. 4)
where the rotor vectors are defined in the rotor reference
frame, rotating with an angular velocity wr with respect
to the stator frame. If the instantaneous rotor position
with respect to the stator frame is defined by the angle E
161
then rotor vector quantities are transferred to the stator
frame of reference by a multiplication factor ejE.
The stator flux vector may be rewritten as :-
where Ls is the stator self inductance, and M is the
mutual inductance between the stator and rotor. It is
assumed that the turns ratio of the stator to the rotor is
unity. Similarly the rotor flux vector may be rewritten as
~ L' M_;se-jE
~ = r~r + • (B.G)
where Lr is the rotor self inductance. Thus equations
and B.4 can be rewritten as
B.3
(B.7)
(B.8)
The torque generated from the interaction of the stator
currents with the rotor flux vector can be written as :-
*Te = Imag K{!s!r } (B.g)
. *
Te = Imag KM{!s(!reJE )} (B.10)
*where represents the complex conjugate.
Equations B.2 and B.3 constitute a three to two phase
transformation which does not conserve power. A correction
factor of (2/3) must be included in the torque equation.
The number of pole pairs (p) must also be included as the
angle used for the derivation of the torque equation is in
mechanical radians, whereas E is measured in electrical
radians. Equation B.10 thus becomes :-
1G2
· *Te = (2/3)(Mp) Imag {!s(!reJE )} (B.11)
This model of the induction motor can now be
transformed to a synchronously rotating frame of reference
whose instantaneous angle is defined as Se where
Se = J (we) c!t
Transformation of equation B.7 gives
(B.12)
(B.13)
or p
Yse = Rs!se + Lsd(ise)/dt + jWeLsise + Md(ire)/dt
~
(B.14)
where the subscript e denotes vectors defined in the
synchronous frame of reference. The rotor currents are
inaccessible quantities in a cage machine and so it is
more convenient to rewrite the synchronous rotor current
vector in terms of the synchronous stator current vector
and the synchronous rotor flux vector i.e.
ire = !re/Lr - (M/Lr)ise (B.15)
Equation B.14 now becomes :-
+ jWe(M/Lr)!re
(B.16)
163
where a is the leakage coefficient such that
(B.17)
Transforming the rotor dynamic equation B.B gives
(B.1B)
Equations B.17 and B.18 can be rewritten in terms of real
(d axis) and imaginary (q axis) parts such that :-
(B.19)
(B.20)
(B.21)
(B.22)
which corresponds to the 4th order differential equation
set eqn. 2.3. The angular relationship of the d and q axis
currents to the stator current vector is illustrated in
Figure B.1.
The torque equation can be rewritten as
(B.23)
*Te = (2/3)pM Imag {!se(!re/Lr) } (B.24)
(B.25)
164
is rotor (Axis
id
Angulo.r Relo.+tons htp of Current Vectors
Figure B.1.
165
APPENDIX C
TRANSFORMATION EQUATIONS
C.1)THREE TO TWO PHASE TRANSFORMATION (DEMODULATION)
The instantaneous line quantities are transformed to
the field orientated reference frame using a three to two
phase transformation in the stator frame of reference, and
then using the flux angle (ae) information for conversion
to the synchronous frame of reference. The stator two
phase quantities are denoted by the subscripts a and S.
Transformation of the current vector is shown as an
example.
The stator current vector is defined as
is
. j4n/3
+ ~ce (C.1)
Three to two phase transformation is achieved using
equations C.2 and C.3.
ia = (3/2)ia (C.2)
is = «~3)/2)(ib - ic) (C.3)
Transformation to field co-ordinates then follows
ise-
jge
= (ia + jiB)(COSSe -jsinSe) = isd + jisq (C.4)
(C.4)
(C.S)
166
C.2)TWO TO THREE PHASE TRANSFORMATION (MODULATION)
Modulation is achieved using the flux angle
information as follows
is = (ia + jig) =
,-/ ... ,
~
(l.'sd .. ) -jge+ )l.sq e (C.6)
(C. 7)
(C.B)
Phase splitting is as follows :-
ia = (2/3)ia (C. 9)
ib = (-1/3)ia + (1/~3)ig (C.10)
ic = (-1/3)ia - (1/~3)ig (C.11)
The coefficients in the equations above are
consistent with the constant (2/3) used in the torque
equations (B.23) to (B.25).
167
APPENDIX D
THE TRANSPUTER
D.1)INTRODUCTION
Standard computer architectures have until recently
been based upon the premise that the processor is more
expensive than the memory which it serves and this has
resulted in the use of the "Van Neumann" architecture for
system design. This principle has a single central
processor surrounded by a large array of memory and
peripherals, all communicating via shared buses.
Performance improvement is achieved by speeding up the
clock speed of the system and enhancing memory access
times. However the performance which can be achieved by a
single processor is now approaching a physical limit. The
future of computer architecture design has been radically
altered by the advent of Very Large Scale Integration
(VLSI) whereby processor design is no longer a restriction
and alternatives to the Von Neumann architecture can now
be examined.
The two principle alternatives so far developed are
the pipeline architecture found in Digital Signal
Processors (DSPs) and the parallel or concurrent
architecture. Both appear to offer an increase in speed,
but the suitability of these architectures seems to be
application dependent. The DSP achieves its speed by
exploiting specific hardware for successive multiply-
shift-add operations. This results in a system which is
ideal for "number crunching" applications such as matrix
manipulation and signal analysis, but such power is wasted
on simple algorithms such as text manipulation. Parallel
processing can be formally defined as "a technique for
increasing the computation speed for a task by dividing
168
the algorithm into several sub tasks and allocating
multiple processors to execute multiple sub tasks
simultaneously" [38]. It can be immediately seen that the
use of a parallel processing network will only increase
processor speed significantly if the algorithm can be
split into concurrent routines. The inherent parallelism
associated with vector control for induction motors is
discussed in chapter 3, and thus the following discussion
is limited to the development of parallel processing
architectures using the transputer.
D.2)OCCAM AND THE TRANSPUTER
The Transputer, commercially introduced by INMOS Ltd.
in 1986 has provided a significant alternative to
conventional processing techniques, as it has been
designed in accordance with the OCCAM model for parallel
processing applications [38],[39]. It is not intended for
use as a stand alone processor performing sequential tasks
(although it can work effectively in this manner) but as a
component part of a network of transputers where
concurrency can be exploited to extend system performance
and increase processing speed. Before describing the
transputer device itself it is worth outlining the occam
model for parallelism and describing the main features of
the OCCAM parallel processing language itself.
D.2.1)THE OCCAM MODEL FOR CONCURRENCY
An excellent introduction to parallel processing
architectures is provide by Flemming [38], and this
section will summarise the main features of occam. The
basis of this language is the modular "process model"
whereby a process is defined as an independent sequential
routine which performs a set of operations and then
169
terminates. Several processes can be defined to run
simultaneously, and inter-process data transfer is via
point to point links called communication channels.
Parallel processes do not share access to global
variables. Each process has its own local variables, and
communication is solely through channels. Data transfer is
synchronised so that communication takes place only when
the transmitter and receiver are ready. If either process
becomes ready for data transfer, then it will
automatically have to wait until the other process is
ready.
D.2.2)THE OCCAM LANGUAGE
A more formal definition of the language structures
is provided by [40],[38],[41] and the following is
intended as a summary.
Occam is a high level language, which allows for a
fairly straightforward programming strategy, but compiled
occam is as efficient as hand written machine code. As
mentioned earlier the basis for the language is the
process, the most basic of which are ,assignment, input and
output. These operate on two basic data structures namely
the variable, used to store data, and the channel, used to
transfer data between processes. Assignment (represented
by :=) sets the value of a variable according to an
expression. The language provides the basic mathematical
operators (multiply, divide, add, subtract, remainder),
boolean operators (greater than, less than, equal to, AND,
OR, NOT), shift operators «<,») and bitwise operators
(\/,/\). Real number routines, trigonometrical routines
and power routines are provided as software packages.
Input and output (represented by ? and ! respectively) are
used for inter process communications. A process itself
may be built up from other processes by using the
constructs SEQ, IF, PAR and ALT.
170
The SEQuential construct defines that the processes
that follow should be executed sequentially and is similar
to programs written in conventional high level programming
languages. The occam pseudo-code format for this construct
is illustrated here where ... represents a process and the
indentation following the constructor indicates that those
processes are governed by that particular constructor.
SEQ
process 1
process 2
process 3
The PARallel construct defines that the processes
following should be executed concurrently (with
communication channels having been previously defined), as
illustrated :-
PAR
process 1
process 2
process 3
Note that
constructs
processes 1, 2 and
themselves, but are
3 will
treated
invariable be
as independent
processes by this construct.
The IF construct is the conditional construct which
determines which process to execute on the basis of a
boolean guard. Again this construct is already employed in
conventional high level languages. This construct is shown
here :-
IF
x = 1
process 1
x = 2
process 2
171
TRUE
process 3
Note that the "TRUE" statement employed here provides a
process to be executed should none of the guards be TRUE.
The ALTernative construct is illustrated :-
ALT
channel.1.input ? x
... process 1
channel.2.input ? x
... process 2
channel.3.input ? x
process 3
This construct uses the first input from several channels
to become ready to decide which of its component processes
to execute. Once a channel has become ready for data
transfer then only its associated process is performed. No
equivalent construct is available for output.
priority can be assigned to PAR and ALT constructs.
If the PAR statement were replaced by a PRI PAR statement
then this would assign a high priority to process 1 and
low priority to processes 2 and 3. The uses and
implications of this are explained later. Similarly if ALT
were replaced by PRI ALT then if all the inputs to the
three channels became available simultaneously, then
process 1 would always be executed. Previously the
determination of which process to execute under those
conditions was undefined.
One further feature of the occam language and its
implementation on the transputer is the access to two on
chip timers which can be used for internal measurement or
for real time scheduling. The high priority timer can only
be accessed by a high priority routine and operates with a
1 ~s tick. The low priority timer can be accessed by all
other processes and operates with a 64 ~s tick.
172
D.2.3)THE TRANSPUTER
The transputer is available as either a 16 bit (T212)
or 32 bit (T414) microcomputer, containing all the
resources required by a computer system. A simplified
block diagram of the internal structure of the T414 is
shown in Fig. 0.1.
The T414 [39],[42] device itself contains a medium
speed microprocessor with an integer multiply time of 2.5
~s when operated at a clock frequency of 15 MHz. This
processor features a Reduced Instruction Set whereby the
number of instructions available is limited to about sixty
in order to increase processor speed. This provides an
efficient implementation of high level languages and
allows the processor to operate at a rate of 10 MIPS. 2 k
Bytes of on-chip RAM are provided with a nominal access
time of 80 MBytes/s. A configurable memory/peripheral
interface is also provide which can access up to 4
gigabytes of external memory at a nominal rate of 26.6
Mbytes/s. Four bi-directional serial communication links
are provided for point to point data transfer to or from
other transputers or transputer look-alike peripherals.
These operate at a rate of 10 Mbits/s which results in a
transfer time of 5 ~s per byte. This is slow and is thus a
significant factor when trying to assess the performance
of the transputer network in comparison with other
parallel structures. The Event pin provides a means for
synchronising separate processes and is in effect an
interrupt capability. System services include reset, error
reporting and analysis, clockin and the power supply.
The transputer is designed so that it can implement a
set of parallel processes. This is achieved using a time
slicing technique based on the following laws:- a high
priority process will proceed until it has to wait for a
communication or time-out; once it has to wait low
priority processes will be executed on a time sliced
basis. The transputer is also designed such that it
173
CT~ 0....-10 ..... ('IJ CV) OJ U °0.....
o-P ~-P ('IJ-P CV)-P
~<[ L 4_('f)
C :3 c :3 c :3 c :3 -P -P 3~1f--<D ~D f--<D ~D c c -P-P('IJ
.:::L.:::L .:::L.:::L .:::L~ .:i.~ OJ OJ 000
_S _S c c c c _S _S > > CC<[
_j_j _j.:J
.:J.:J _j_j ww £ £ £
1I11 11 1I11 OJ OJ OJ::L2:2:
L
0 til OJ OJ OJ OJ
-P 1Il OJ U U U UVl U d d d d -p
_.Q OJ 4- 4- 4- 4- c
U > L L L L OJ('IJ 0 ~s.... .:i.OJ .:i. OJ
.:::LOJ ~OJ >CV) s.... cOJ _S -P _S -P
_S +> _S -P OJ
0... :::;t/l --' c --'c --' c --' c
-- --
-- --
L;). .(). z:;: i). i).
(\J (\J (\J (\J (\J
C") C") C") C") ('1
.~_L ..'\7 _\ .7 '\7 '\7
I I
.(). .().
(\J (\J(")
C")
~7 ,\7 \7
lfl 1Il o, --' OJ£ OJ Cl! -- d >-.UOJ u lfl -P .c 2: c L d
-P
--
s, >-'4- U <[ L o 4-lfl > OJ ..Q 0 I OJ £ L
>. L £ .:::L c ~ -P OJ OJ
lfl OJ +> ru 0 X s; -Plfl OJ c
--
174
£
d
L
Q)
d
~
.x
u
0
~
L
OJ
~
+>
:::s 0
o,
OJlfl
c s....
d ::5
L Q)
l- LL
'<;j-
..-.
'<;j-
l-
V)
2:f--<
appears as a process to a surrounding network. Thus a
parallel processing algorithm can be mapped onto a single
transputer or onto a network of several transputers with
minimal software changes. This capability is surprisingly
useful as a software design aid.
One final point to note is that the
architecture is wordlength independent. This
transputer
means that
transputers of different wordlengths may be interconnected
freely and programmed as a single system.
D.3) IMPLEMENTATION OF A TRANSPUTER NETWORK
The transputer network used for this project
consisted of an IMS B004 IBM PC Add-In Board and aIMS
B006 Transputer Evaluation Board, both supplied by INMOS
Ltd. The B004 board [42] is mounted directly inside an IBM
PC AT host computer and contains a T414 transputer (32
bit) and 2 Mbytes of dynamic RAM. The board is linked to
the host via aIMS C002 Link Adapter [43] connected to the
PC's I/O ports. Logic is provided to for Reset, Analyse
and subsystem control, allowing the board to control a
transputer subsystem or be a component of a transputer
system. External connections are provided for the
transputer links and the subsystem control signals.
The B006 board [44] contains a master T212 (16 bit)
transputer and has expansion slots to accommodate a
further eight T212's. The master provides access to the
EPROM, UART, and switches mounted on the board, and has 56
Kbytes of external RAM. Each of the additional transputers
has 8 kbytes of external RAM.
the
The
D700
occam programs were designed and debugged using
Transputer Development System (TDS) [40], a
software package running on the host machine. It provides
the necessary environment for editing, compiling and
configuring the occam routines to run on the transputer
network. The separate processes are created and compiled
175
individually, and then a higher level editor is invoked to
assign a particular process and communication links to
each transputer or peripheral in the network. The TDS then
downloads the resulting code into the corresponding system
and it is executed. The TDS also provides on line access
to the host's keyboard and screen, or by using programs
written in most high level languages, routines can be
provided to access to the disk files or graphics
capabilities.
The combination of the TDS system with a B004 board
provides an excellent development system for transputer
applications. Particularly useful are the folding editor
[40J and the ability to simulate multiprocessor networks
on a single transputer. The addition of a B006 board
provides a network of transputers easily interconnected
and controlled by the B004 master transputer.
176
APPENDIX E
DIGITAL IMPLEMENTATION OF LAPLACE COMPENSATION FUNCTIONS
E.1)INTRODUCTION
The discretisation of the Laplace transfer functions
employed in this project was achieved using the Bilinear
Transformation given in eqn. E.1.
-1 I -1s = (2 IT) ( (1 - z ) (1 + z ) ) (E.1)
where :-
s: is the Laplace Operator.
-1 .
z : 1S a unit delay operator
T: is the system sampling time.
Discretisation of the original transfer function is
accomplished by substituting eqn. E.1. into the the
Laplace
to give
signals
following
equation and manipulating the resultant equation
a transfer function for the current sampled
in terms of previously sampled signals. The
definitions are required for the digitised
transforms described, :-
Yk: current transfer function output.
ek: current transfer function input.
Y(k - 1): previous transfer function output.
e(k - 1): previous transfer function input.
177
E.2)FIRST ORDER LOW-PASS FILTER
A simple first order low-pass filter is given by the
Laplace transfer function
y/e = w/(s + w) (E.2)
where w is the cut off angular velocity. Substitution of
the bilinear transformation and rearranging gives :-
-1 I / -1y(1 + «w - 2/T)/(w + 2/T»z ) = e(w (w + 2 T»(1 + z )
(E.3)
The resultant digital filter is thus implemented as :-
Yk = Y(k - 1)«2/T - w)/(2/T + w» +
(ek + e(k _ 1»(w/(w + 2/T) (E.4)
E.3)PROPORTIONAL PLUS INTEGRAL COMPENSATION
The Laplace transform for a PI controller is given as
y/e = K(s + w)/s (E.5)
Substitution of the bilinear transformation and
rearranging gives
-1 I / -1 Iy(1 - z ) = e(KT 2)[«2 T) + w) - z «2 T) - w)] (E.5)
The resultant digital PI controller is thus :-
Yk = y(k - 1) + (K + (wKT)/2)ek - (K - (WKT)/2)e(k - 1)
(E.6)
178
E.3)LEAD LAG COMPENSATION
The Laplace transform for a lead lag compensator is
given as
(E. 7)
Substitution of the bilinear transformation and
rearranging gives :-
-1 /z (2 T - w1»
(E.8 )
The resultant digitised lead lag compensator is thus
(E.9 )
179
