# ADAPTIVE CONTROL OF CONVERTER FED D.C. DRIVE

### A DISSERTATION

submitted in partial fulfilment of the requirements for the award of the degree of MASTER OF ENGINEERING in ELECTRICAL ENGINEERING (Power Apparatus and Electric Drives)



P. S. PUTTASWAMY

By



DEPARTMENT OF ELECTRICAL ENGINEERING UNIVERSITY OF ROORKEE ROORKEE-247 667 (INDIA)

SEPTEMBER, 1989

#### CANDIDATE'S DECLARATION

I hereby certify that the work which is being presented in the dissertation entitled, ADAPTIVE CONTROL OF CONVERTER FED D.C. DRIVE, in partial fulfilment of the requirements for the award of the degree of MASTER OF ENGINEERING IN ELECTRICAL ENGINEERING with specialization in POWER APPARATUS AND ELECTRIC DRIVES, submitted in the Department of Electrical Engineering, University of Roorkee, Roorkee, is an authentic record of my own work carried out for a period of about seven months from August 1988 to Feb 1989 under the supervision of Dr.BHIM SINGH and Dr.AMBRISH CHANDRA, Readers in Electrical Engineering, University of Roorkee, Roorkee.

The matter embodied in this dissertation has not been submitted by me for the award of any other degree or diploma.

(CANDIDATE S SIGNATURE)

Date: 16.9.89

This is to certify that the above statement made by the candidate is correct to the best of my knowledge.

Ambrich Chandr.

Dr.AMBRISH CHANDRA Reader Department of Electrical Engg. Department of Electrical Engg. University of Roorkee Roorkee-247667

Dr.BHIM SINGH

्र वर्षे ग्र

Reader University of Roorkee Roorkee-247667

#### ACKNOWLEDGEMENTS

I wish to express my deep sense of gratitude and indebtedness to myguides, Dr.BHIM SINGH and Dr.AMBRISH CHANDRA, Readers in Electrical Engineering for invaluable assistance, excellent guidence and sincere advice given by them during this thesis work.

I am highly thankful to Dr.R.B.SAXENA, Professor and Head of the Department of Electrical Engineering, University of Roorkee, Roorkee for providing laboratory facilities.

faculty Ι much grateful to our member very am Dr.V.K.VERMA his invaluable suggestions and kind for co-operation during the work. Ι also grateful to am Mr.M.K.VASANTHA, Mr.Y.P.SINGH and Mr.PRAMOD AGARWAL for their kind suggestions.

I am highly thankful to my wife N.NALINI for her constant encouragement and co-operation during this work.

I am also thankful to P.E.S.COLLEGE OF ENGINEERING, Mandya, for sponsoring to this M.E. Course.

I am deeply grateful to all the laboratory staff for their co-operation during the fabrication of this work.

Thanks are also due to those who helped me directly or indirectly in preparing this dissertation.

(P.S.PUTTASWAMY)

#### SYNOPSIS

This dissertation deals with the experimental studies on self tuning control of a closed loop variable speed d.c. motor drive system.

A self tuning controller for speed control is developed and realised through software on IBM PC. And thyristorized three phase fully controlled converter, microprocessor controlled firing circuit, current controller (PI) and digital speed measurement circuit have been designed, fabricated and tested.

Chapter-I consists of literature review and brings out the advantages of self tuning control over other control schemes. Chapter-II gives the complete details of self tuning controller design. Chapter-III deals with the study of motor speed control and system hardware. Chapter-IV describes the system software and their flow charts. Chapter-V deals with the experimental results. In the last chapter-VI conclusions and scope of further work have been described.

# CONTENTS

|         |                                         | РА    | GE NO. |  |  |  |
|---------|-----------------------------------------|-------|--------|--|--|--|
|         | CANDIDATE DECLARATION                   | ••    | (i)    |  |  |  |
| r.      | ACKNOWLEDGEMENTS                        | ••    | (ii)   |  |  |  |
|         | SYNOPSIS                                | • •   | (iii)  |  |  |  |
| CHAPTER |                                         |       |        |  |  |  |
| 1       | INTRODUCTION                            |       |        |  |  |  |
|         | l.l General                             |       | 1      |  |  |  |
|         | 1.2 Literature Survey Review            | ••    | -      |  |  |  |
|         | 1.2.1 Adaptive control schemes          | • •   | 5      |  |  |  |
|         | 1.2.2 Firing and control schemes        | ••    | 8      |  |  |  |
|         | 1.3 Scope of the Present Work           | ••    | 13     |  |  |  |
|         | 1.4 Outline of Chapters                 | ••    | . 14   |  |  |  |
| 2       | ADAPTIVE CONTROLLER                     |       |        |  |  |  |
|         | 2.1 General                             | ••    | 16     |  |  |  |
|         | 2.2 System Model                        | ••    | 16     |  |  |  |
|         | 2.3 Test Signals                        | ••    | 18     |  |  |  |
| •       | 2.4 System Identification               | ••    | 19     |  |  |  |
| • • = • | 2.5 Control Stratagies                  | • • • | .23    |  |  |  |
|         | 2.6 Self Tuning Control                 | ••    | .24    |  |  |  |
|         | 2.7 Algorithm                           | ••    | 25     |  |  |  |
|         | 2.8 Conclusions                         | • •   | 26     |  |  |  |
| 3       | HARDWARE IMPLEMENTATION                 |       |        |  |  |  |
|         | 3.1 General                             | ••    | 28     |  |  |  |
|         | 3.2 System Description                  | •, •  | 28     |  |  |  |
|         | 3.3 Based Self Tuning Controller        | ••    | 30     |  |  |  |
|         | 3.4 Power Circuit and Its Working       | ••    | 30     |  |  |  |
|         | 3.5 Microprocessor Based Control Scheme | ••    | 2      |  |  |  |
|         |                                         |       |        |  |  |  |

2

Contd..

CHAPTER

4

· · -

ş

|                |       | 3.5.1             | Synchronizing technique                 | • • | 36              |
|----------------|-------|-------------------|-----------------------------------------|-----|-----------------|
|                |       | 3.5.2             | Pulse amplifier circuit                 | ••  | 38              |
|                | 3.6   | Conclus           | sions                                   | • • | 39              |
|                | SYST  | em softv          | VARE IMPLEMENTATION                     |     |                 |
|                | AND 2 | FLOW CHA          | ARTS                                    |     |                 |
| и              | 4.1   | General           | L                                       | ••  | 40              |
|                | 4.2   |                   | re Implementation of Self<br>Controller | ••  | 40 -            |
|                | 4.3   | Softwar<br>System | ce for 8085 Microprocessor              | ••  |                 |
|                |       | 4.3.1             | Main program                            | ••  | 41              |
|                |       | 4.3.2             | Closed loop initialization              | ••  | 44 <sup>·</sup> |
|                |       | 4.3.3             | ADC Subroutine                          | ••  | 44              |
| ۰ <sup>۲</sup> |       | 4.3.4             | Constrained current error subroutine    | • • | 46              |
|                |       | 4.3.5             | PI current controller<br>subroutine     | ••  | 47              |
|                |       | 4.3.7             | Constrained voltage subroutine          | • • | 50              |
|                |       | 4.3.8             | Look up subroutine                      | • • | 51              |
|                |       | 4.3.9             | mode selection subroutine               | • • | 54              |
|                |       | 4.3.10            | Multiplication subroutine               | • • | 55              |
|                | · -   | 4.3.11            | IR interrupt subroutine                 | • • | 55              |
|                |       | 4.3.12            | IR <sub>1</sub> interrupt subroutine    | ••  | 56              |
|                | 4.4   | Conclu            | sions                                   | ••  | 57              |
|                | PERF  | ORMANCE           | OF THE SYSTEM                           |     |                 |
|                | 5.1   | Genera            | 1                                       | ••  | 59              |
|                | 5.2   | Experi            | mentation                               | ••  | 59              |
|                | 5.3   | Discus            | sion of Results                         | ••  | 61              |
|                | 5.4   | Conclu            | sions                                   | ••  | 63              |
|                |       |                   |                                         |     |                 |
|                |       |                   |                                         |     |                 |

6

|        | CONCLUSIONS AND SUGGESTIONS FOR<br>FURTHER WORK |    |  |  |  |  |  |  |
|--------|-------------------------------------------------|----|--|--|--|--|--|--|
| 6.1 Ma | in Conclusions                                  | 65 |  |  |  |  |  |  |
| 6.2 Su | ggestions for Further Work                      |    |  |  |  |  |  |  |
|        |                                                 |    |  |  |  |  |  |  |
| APP.A  | Chip Details                                    |    |  |  |  |  |  |  |
| APP.B  | Pin Details                                     | :  |  |  |  |  |  |  |
| APP.C  | PI Controller Design                            |    |  |  |  |  |  |  |
| APP.D  | STC Software                                    |    |  |  |  |  |  |  |
| APP.E  | μp Software Program                             |    |  |  |  |  |  |  |
| APP. F | MP and its PeriPherials.                        |    |  |  |  |  |  |  |
| REFERE | NCES                                            | 69 |  |  |  |  |  |  |

#### CHAPTER-1

#### INTRODUCTION

#### 1.1 GENERAL

Many modern variable speed drives require a precise and smooth control of speed with longterm stability and good transient performance. From the very beginning, the conventional d.c. motors have been used as variable speed drives in many industrial applications due to the following\_ advantages.

- D.C. motors can provide high starting torque which are required for several applications such as traction drives.
- (ii) D.C. motor's speed can be controlled easily over a wide range both below and above rated speed.
- (iii) The methods of control are similar and less expensive than those of a.c. motors.

In modern d.c. drives, the classical motor-generator set has been replaced by a solidstate controlled d.c. drive which has numerous advantages such as minimum maintenance, less bulk and weight, higher efficiency, faster time response and above all low cost[1].

For a reversible drive with continuous speed control over a wide range, the d.c. motor drive is the most popular solution. The speed of the d.c. motor can be controlled by controlling either armature voltage or the field current. Former is for speed control below the rated value and the latter is for speed control above the rated value of speed of the motor. D.C. motors can closely match the needs of the application as the speed-torque characteristics can be varied to any useful form, for both motoring and regenerating applications. Dynamic or regenerative braking is easily obtainable with the d.c. motors for application, requiring quick stopping or speed reversals.

As mentioned earlier, d.c. motors are easily adaptable to variable speed drives. The speed characteristics of a seperately excited d.c. motor is given by

$$N = (V_a - I_a R_a) | KI_f$$

The seperately excited d.c. motor is rapidly and efficiently controlled by the variation of armature voltage and field current.

Solid state controllers enable in developing more accurate, efficient and compact control scheme for d c. motors [1.2]. In addition they help in obtaining variable characteristics of these motors. The conventional methods of speed control are gradually being replaced by thyristor control. The use of thyristors for power control affords considerable advantages over conventional methods owing to the possibilities of obtaining better economy, efficiency.

reliability fastness facilities and their compatibility to adopt for closed loop system of speed control.

Now a days, the speed control of a d.c. drives is also tried with adaptive controllers. Adaptive control has been a challenge for control engineers for a long time [3]. It has been their dream for more than a quarter of a century. It arose from a desire and need for improved performance of complex engineering systems with large increasingly uncertainties. This is specially important in system with many unknown parameters that change with time. An adaptive system is one that continually monitors the changes and adjusts the control parameters automatically to maintain good performance. Hence, adaptive systems can be considered as a class of control systems that have been made deliberately non-linear.

The tuning problem is one reason for using adaptive control. It is a well known fact that many processes can be regulated satisfactorily with proportional integral (PI) or proportional integral derivative (PID) regulators. It is fairly easy to tune a PI regulator which only has two parameters to adjust. However, for an installation which has several hundred regulators, it is a substantial task to keep all regulators well tuned. A PID regulator which has three or four parameters is not always easy to tune particularly if the process dynamics is slow. The derivative action is

therefore frequently switched off in industrial controllers. Since many control loops are not critical, three term controllers will be extensively used in future too.

Conventional control theory deals with the control of dynamical systems whose mathematical representations are completely known. In contrast to this adaptive control it refers to the control of partially known systems. For many years, there has been an increasing interest in adaptive control which can be attributed to the fact that there is invariably some uncertainity in the dynamic characteristics of most practical systems. The tools of conventional control theory, even when used efficiently in the design of controllers for such systems, are inadequate to achieve satisfactory performance in the entire range over which the characteristics of the system vary.

While feedback, in general, improves the performance of a system it could also make the system unstable [3]. Since adaptive control systems are non-linear feedback systems, there is the distinct possibility that such system can become unstable.

Research on adaptive control was very active in the fifties. It was motivated by the need of autopilots for high performance aircraft. The work was characterized by a lot of enthusiasm, bad hardware, and nonexisting theory. Interest in the area diminished due to lack of well developed stability theory and a fight disaster. Due to some recent developments

in the stability theory of such systems, the application of adaptive control to practical systems is being attempted on a large scale [3,4].

#### 1.2 LITERATURE SURVEY REVIEW

#### 1.2.1 Adaptive Control Schemes

The adaptive control of systems has been a dream of control system theorists and practitioners for atleast a quarter of a century. In the past decade the progress of adaptive control has been slow in coming to fruition. The early schemes for adaptive control, though ingeneous, did not gaurantee the stability of the system. Globally stable adaptive control algorithm have been developed very recently. With recent advances in microprocessor technology, it has become feasible to implement adaptive control algorithms efficiently in real time at reasonable cost.

To understand the recent developments in theory and the keen interest shown by industries in adaptive control promoted to organise the workshop on applications to the adaptive cotrol. Many workshops have been held to bringout the fruitful application [3].

Clarke and Gawtrop [5] have discussed the closed loop properties of various classes of selftuner, convergence concepts and results. They have suggested a new technique to design a selftuning controller which does not appear to suffer excessively from the disadvantages of previous adaptive methods. Some of the technical problems involved with implementing selftuners on small computers or microprocessors are also discussed.

6

have discussed a selftuning Allidina and Hughes [6] controler that minimises cost function incorporating system input, output and setpoint variations, and adapts in such a way that the closed loop poles are located on prespecified locations. The link between classical control strategy of pole assignment and the suboptimal strategy of the selftuning demonstrated and made use to produce controller is generalised controller which possesses the advantages of The proposed controller combines the robustness of a both. pole assignment regulator with the ease of reference tracking. Simulation methods for first and second order systems are also discussed.

Gawtrop [7] has discussed the design of selftuning controller including rational transfer function terms in the associated cost function. Two interpretations of the selftuning controller, a model reference adaptive control and a selftuning least square predictor in conjunction with conventional compensation are examined in detail. Using standard form of techniques, the discrete time systems with step responses are determined. The proposed controller shows the advantages over Smith Control law. Brickwedde [8] has discussed the application of microprocessor based adaptive control for electric drives. For its implementation as an on-line adaptive control system, the recursive least squares algorithm for the on line parameter identification combined with a pole assignment procedure is suggested. The proposed controller is implemented on a 16 bit microprocessor to control the speed of a 40 k.w d.c. drive. Experimental results of a drive under load conditions are also discussed.

A robust selftuning controller that can track a constant reference and rejects load disturbance developed by Balasubramanian and Kong Hung Wong [9], proposed controller is implemented on a microprocessor to control the speed of a d.c. motor under varying load and operating conditions. Experimental results are also discussed, which confirm the controller excellent adaption capability as well as transient recovery under load changing conditions.

Stephan et.al. [10] have discussed a cascade speed control strategy for a thyristor fed d.c. motor subjected to parameter variations. This is called as dual mode used with inner current loop and outer speed loop. The scheme is implemented on a 16 bit microprocessor using a floating point coprocessor to control the speed of a l.l k.w d.c. motor, and experimental results are also given. The proposed controller makes the behaviour of armature circuit practically

independent of the current conduction mode. Response is extremely fast and it gaurantee the stability and predefined performance under all operating conditions.

Liu et.al. [11] have discussed a controller design based on the placement of poles and zeros of the state tracking error transfer function. The problem formulation, parameter and state estimation, considering noisy and noise free systems are discussed. The proposed self tuning control is found very effective for both regulation and reference tracking signal.

A common problem in the d.c. motor drives is torque saturation. In order to overcome this, a generalised predictive control is suggested by Tsang and Clarke [12], which, shows improvements in performance without major increase in computations.

Cluett et.al. [13] have discussed the consolidation of stability and robustness results based on input-output theory for discrete adaptive control systems. In this, an algorithm for a generic direct discrete time adaptive controller is presented. To obtain the stability of the system normalisation, and weighting of the polynomials are suggested.

#### 1.2.2 Firing and Control Schemes

Ilango et.al. [14] have discussed the compact firing'

scheme for three phase bridge rectifiers using minimum integrated circuit components. The proposed scheme had shown fast response for triggering angle and gives a fullrange of voltage, because the response of the firing angle to control voltage is almost instantaneous.

Alimirbod and Ahmed el-amawy [15] discussed a general purpose microprocessor based control circuit for a three phase controlled rectifier. For the proper operation of controlled rectifiers, the gating patterns are synchronized with the zero crossing of line to line voltage by properly compensating the effect of source impedance by compensation circuit. The proposed controller exihibited superior performance to previously presented circuits. The hardware and software implementation on 8086 microprocessor are discussed.

A firing scheme based on microprocessor to control an antiparallel connected 3 phase thyristor dual converter is discussed by Tang et.al. [16]. Look up algorithm is used to speed up the response, which gives full range control of the firing angle between  $0-180^{\circ}$  for both positive and negative current control. The proposed scheme is reported to give good dynamic response and high system reliability.

Independently of the method of algorithm used to control thyristor firing of a three phase static converter, the signals that synchronize them with a.c. supply are always

necessary. A microprocessor based scheme is proposed [17] for this purpose. This scheme is tested as a part of the complete digital current control system feeding a 5 k.w d.c. motor also in a rectifier system fed by a 13 KVA synchronous generator. The results obtained are very good, and for a self controlled synchronous motor system, this scheme is more precise than a set of selective filters.

Remy Simard and Rajagopalan [18] have discussed a simple equidistant pulse firing scheme. The proposed scheme is economical to use with individual phase control circuits for industrial applications. Experimental results obtained on a laboratory d.c. drive are also discussed.

El-Bolok [19] has described a novel microprocessor based scheme for constant angle triggering operating under a variable anode frequency, in which the triggering angle is controllable by software. Implementation and testing of this scheme had shown a fast response to changes in anode supply frequency. This scheme is not affected by the number of phases of the supply voltage and/or its phase sequence.

Mario Benedetti and Carlos F. Christiansen [20] have described the design of a trigger system for full or half controlled thyristor converter upto 6 pulses using 8 bit microprocessor. This scheme provides more flexibility in which the triggering angle may take any value from 0 to 180° between pulses, thus achieving the maximum rate of change of

the output voltage. The necessary hardware is also reduced to minimum. The design procedure and experimental setup are discussed.

Thadiappan Krishnan and Bellamkonda Ramaswami [21] proposed the design construction and testing of thyristorized speed control unit for a seperately excited d.c. motor. The motor is fed from a three phase six pulse fully controlled thyristor bridge. The speed and current loops are used to maintain the desired speed and to provide fast response overcoming the effect of disturbances. But this scheme is useful for only one direction of rotation.

Soon Chan Hong and Min ho Park [22] have described a . method to improve the efficiency of d.c. motors based upon the field control. The power circuits and the control loops are suggested to realise the principle, and the real time control is implemented with a microprocessor. Experimental results had shown the remarkable improvement in efficiency as - well-as stability. -

Sule et.al. [23] have proposed a digital speed control system for a d.c. motor with a pulse tachogenerator for speed sensing. The scheme provides a fast and accurate digital speed measurement and control by means of a microprocessor system. The measurement accuracy obtained is  $\pm$  0.0125 percent with reference to maximum speed and the time constant is approximately 8 m.s.

Plant et.al. [24] have proposed a suitable method for microprocessor implementation of controlling the speed of an S.C.R. controlled d.c. motor drive which uses a halfwave single phase supply, and realisation by a microprocessor. The determination of the necessary control requires only table look up operations and computations are kept minimum. The control algorithm, using the table look up, becomes simple, meets the real time requirement, and its implementation is well within the capability of the present day microprocessors. Experimental results of a 3HP d.c. motor. control are also discussed.

Guyolvier et.al. [25] have discussed the operation of the modified thyristor bridge converter, the control algorithm and microprocessor implementation. The proposed scheme is shown to have faster response, precise and equidistant control of the thyristor triggerings.

Verma and Agarwal [26] have described the design and experimental studies of variable d.c. drive, fed from a single phase dual converter. The drive incorporates an inner current loop (PI) and outer speed loop (PI). The analytical and experimental studies had shown good transient and steady state drive performance.

Tadashi Egame and Takeshi Tsuchiya [27] have discussed a partial state and an output feedback control system synthesis method with feedforward compensation. It

doesn't make use of the state observer procedure. The proposed scheme can be applied to all control systems and its effectiveness tested experimentally.

Nandam and Sen [28] have discussed the comparative study of proportional and integral proportional schemes, for the speed control of a d.c. drive using both analog and microprocessor based digital system. It is confirmed that IP control has distinct advantages over PI control. Experimental and simulation results are discussed.

1.3 SCOPE OF THE PRESENT WORK

The exhaustive literature survey reveals that little research work has been reported on the performance of converter fed d.c. drive using adaptive controller. Therefore, a need is felt to investigate the variable speed operation and performance of a adaptive control of the d.c. drive.

In the proposed scheme, a three phase a.c. supply of fixed frequency and voltage is converted into a variable voltage d.c. supply which is being fed to a d.c. motor. The commutation of thyristor converter is achieved by line commutation. Self tuning controller suggested by Clarke and Gawtrop [5] is used to control the speed of a d.c. drive.

The objectives of the proposed work are the following:

- (i) To design a self tuning controller for the speed control of a d.c. drive.
- (ii) To design and develop a suitable firing scheme and control schemes for operating the converter.
- (iii) To design proportional plus integral control for current loop processing.
- (iv) To study the feasibility of the whole system as a variable speed drive and to obtain experimentally its no load and load characteristics.

The whole scheme has been fabricated and tested in a laboratory and the performance of the motor is obtained experimentally.

#### 1.4 OUT LINE OF CHAPTERS

In Chapter-II, the various aspects of different types of adaptive controllers are described. The algorithm involved in the design of self tuning controller is also discussed.

In Chapter-III, the complete hardware of the present scheme is described in detail. The design of power circuit, microprocessor based firing control circuit using reduced hardware components and pulse amplifier circuit are also given in this chapter.

The implementation of software and flow charts of the

seperately excited d.c. motor speed control is illustrated in Chapter-IV. The various subroutines used in conjunction with the main program such as ADC subroutine, MODE selection subroutine, MULT subroutine, SMULT subroutine, PI processing subroutine  $V_{dc}^*$  CONSTRAINED subroutine, IR<sub>0</sub> interrupt subroutine, IR<sub>1</sub> interrupt subroutine are also developed in this chapter.

The behaviour of a drive on no load as well as on load condition is described in detail along with the performance characteristics in Chapter-V.

The suggestions are proposed to improve the drive performance is given in Chapter-VI.

The pin detail connections and function of various chips, the design of PI controller for current loop, basic language program for the selftuning controller and machine level language program for microprocessor system are given in appendices.

#### CHAPTER-2

#### ADAPTIVE CONTROLLER

#### 2.1 GENERAL

Different types of controllers are suggested in literature to control the speed of a d.c. motor. In this work, adaptive selftuning controller (STC) is used for this purpose. An adaptive controller is one that continuously monitors the change in system parameters and adjusts its control parameters automatically to give good performance. In this chapter, selftuning controller algorithm is discussed in detail.

#### 2.2 SYSTEM MODEL

A physical object, in whose behaviour we are interested in studying, affecting or controlling is known as system. The knowledge of the properties of a system is generally called a model. The concept of a mathematical model is necessary when complex problems are treated. A mathematical model of a given system can build up by two approaches. In the first approach, by looking directly into the mechanisms of the system that generate signals and variables inside the system and construct a mathematical model. In second approach, knowledge of the systems mechanism is incomplete or system properties are inpredictable, in those cases, signals produced by the system can be measured and be used to construct a mathematical model.

A practical system can be either single input/single output or multi input/multi output. But as for as d.c. motor is concerned, it can be regarded as single input/single output. Therefore, in this investigation, only the single input single output system is discussed. The mathematic modelconsidered, in this work, is of the discrete form (difference equation) due to digital computer application. Many types of discrete mathematical model such as ARMA (Auto Regressive Moving Average), ARMAX (Auto Regressive Exogeneous), and LR (Linear Regression) are used in adaptive control techniques. ARMA model is not suitable for the present problem because it has no control over input. ARMAX model which uses the principal property of Recursive least square identification is not holds good because the prediction error is Therefore uncorrelated. to overcome this difficulty, 'Recursive extended Least squares' (RELS) identification is used with this type of model. RELS is not robust as that of RLS and the convergence can not be proved for all cases, it also increases the computational burden and hence it may create problems in real time implementation. That is why linear regression model is considered here due to its suitability and simplicity.

The system model is assumed to be of the form

$$A(Z^{-1}) y(t) = Z^{-k}B(Z^{-1}) u(t) + \xi(t)$$
 .. (2.1)

Where A and B are polynomials in  $Z^{-1}$  (backward shift operator) defined as

$$A(Z^{-1}) = a_{0} + a_{1}Z^{-1} + \dots + a_{n_{a}}Z^{-n_{a}}$$
$$B(Z^{-1}) = b_{0} + b_{1}Z^{-1} + \dots + b_{n_{b}}Z^{-n_{b}}$$

Where  $n_a$  and  $n_b$ , are the orders of polynomials A and B respectively. K represents the system time delay in sample ~ intervals. y and u are the system output and input, with  $\xi(t)$  an uncorrelated random sequence of zero mean which disturbs the system.

#### 2.3 TEST SIGNALS

To obtain the information about the system and to identify it, the system should be excited by some input signal. Several researchers have treated the design of input signal for enhancing the parameter estimation for discrete time processes used in adaptive control techniques. The input signal should excite all models of the system to guarantee, the estimated parameters converge to the reasonably correct values. The signal having this quality is called 'rich enough' (having sufficiently rich frequency content) or persistently existing.' While doing literature survey it is found that most of researchers have considered white noise as a suitable signal. Hence, in this work, white noise is chosen for excitation purpose [5].

#### 2.4 SYSTEM IDENTIFICATION

The type of a model mainly depends upon the method of identification. identification of a system model The provides the essential aspects of an existing system and represents the knowledge of that system in useful form. Identification may be either 'on-line' (recursive) or 'off-line' algorithm. On-line identification has two main disadvantages in comparison to 'off-line' identification. Firstly, a decision must be made regarding the structure of the model before starting the identification. Secondly, since 'off-line' methods can reprocess data many times, they are more accurate than recursive methods. Recursive least square identification algorithm is the most popular technique which has been used successfully in many applications. Therefore, in the thesis, this algorithm has been used and is briefly discussed below.

The RLS identification technique is mainly used to treat the LR model (eqn.2.1) defining the parameter vector:

$$\hat{\Theta}^{T}(t) = [a_{1}, \dots, a_{n_{a}}, b_{0}, b_{1}, \dots, b_{n_{b}}] \dots (2.2)$$
  
and  $x^{T}(t) = [-y(t-1), \dots, -y(t-n_{a}), u(t-k), \dots, u(t-k-n_{b})] \dots (2.3)$ 

Vector containing measured data.

Vector containing measured data.

Therefore, the equation (2.1) can be written as:

$$y(t) = \hat{\Theta}^{T}(t) x(t) + \not \in (t)$$
 ... (2.4)

Let y(t) be an estimate of y(t) based on  $\hat{\theta}(t)$  and x(t) and it is as:

$$\hat{y}(t) = \hat{\Theta}^{T}(t) x(t)$$
 ... (2.5)

There may be an error in the estimation because the data may be complicated by random measurement of noise, error in the model or combination of both. It is given by:

$$\xi(t) = y(t) - \hat{y}(t) = \xi(t)$$
 .. (2.6)

Now  $\hat{\theta}$  is chosen in such a way that the criterion J is minimized.

$$J = \sum_{t=1}^{m} \epsilon^{2}(t)$$
 ... (2.7)

Expressing  $J = (y - \hat{\Theta}^T x)^T (y - \hat{\Theta}^T x)$ 

$$y^{T}y - y^{T}\hat{\Theta}^{T}x - x^{T}\hat{\Theta}y + x^{T}\hat{\Theta}\hat{\Theta}^{T}x$$

where

 $X = \begin{bmatrix} x^{T}(t) \\ x^{T}(t+1) \\ \vdots \\ \vdots \\ x^{T}(t+m) \end{bmatrix}$ 

$$-y(t-1) \dots -y(t-n_{a}), u(t-k) \dots u(t-k-n_{b})$$

$$-y(t) \dots -y(t-n_{a}+1), u(t-k+1) \dots u(t-k-n_{b}+1)$$

$$\vdots$$

$$-y(t+m-1) \dots -y(t-n_{a}+m-1), u(t-k+m-1) \dots u(t-k-n_{b}+m-1)$$

and

a da ser a ser

$$Y = [y(t), y(t+1), \dots, y(t+m)]^{T}$$
  

$$m = number of samples$$
  

$$\frac{\delta J}{\delta \hat{\Theta}} = -2 x^{T} y + 2 x^{T} x \hat{\Theta} = 0$$
  

$$x^{T} x \hat{\Theta} = x^{T} y$$
  

$$\hat{\Theta} = (x^{T} x)^{-1} x^{T} y$$
...(2.8)

The above result represents the least square estimator of  $\theta$ , and the least square estimates can be computed recursively as:

$$\hat{\Theta}(t) = \hat{\Theta}(t-1) + k(t) [y(t) - \hat{\Theta}^{T}(t-1) x(t)]$$
 .. (2.9)

$$k(t) = \frac{P(t-1) x (t)}{[1 + x^{T}(t) P(t-1) x(t)]} \dots (2.10)$$
  

$$P(t) = [1 - k^{T} x(t)] P(t-1) \dots (2.11)$$

where k(t) is considered as the gain matrix and P(t) is proportional to the error covariance matrix.

From equation (2.9) it is evident that the estimated parameter  $\hat{\Theta}(t)$  is the weighted sum of the last. estimation and prediction error  $\in (t)$ . As time increases, in case of

time in-variant system  $\Theta(t)$  converges to its true value along with prediction error  $\in (t)$ , gain vector k(t) and covariance matrix P(t) tend to zero. But this new information is not making any contribution to the parameter estimation. In time variant system, if the estimated parameter reach its true value once the above problem is eliminated, but affects the parameter tracking.

The algorithm which is derived above based on criterion J considering equal weightage for every error. -For time varying system the above criterion gives an estimate of the average behaviour during the period  $1 \le t \le m$ . As the time increases the number of measurements becomes very large and the contribution of each individual measurements to the parameter estimation tends to zero.

In order to increase the tracking capability, it is necessary to consider a criterion in which older values are discounted by an exponential weighting scheme which places heavy emphasis on more recent data.

Consider a criterion

$$J = \sum_{i=1}^{m} \beta^{n-i} t^{2}(i), \ 0 < \beta < 1$$

In this criterion the later errors are given more weight than earlier ones.

Therefore, the algorithm explained above can be modified by changing equation (2.11) to

$$P(t) = \frac{[1-K^{T}(t) x(t)] P(t-1)}{\beta} \qquad .. (2.12)$$

If  $\sqrt{3} < 1$  then P(t) will not tend to zero and the algorithm is more capable of tracking the parameter variation.

#### 2.5 CONTROL STRATAGIES

1)

Adaptive Control can be classified into two categories Model reference adaptive control (MRAC)

• •

2) Self tuning control (STC)

The choice of reference model is the first step in case of MRAC. The controller parameters are adjusted so that the output co-ordinate of the system agrees with that of the reference model. To perform parameter adjustemnt the value of mismatch between the controlled co-ordinates of the system and the model is to be used. The main problem associated with MRAC is that, to obtain a closed loop response, the system zeros must be cancelled by controller poles. Hence it 'is not useful for the systems outside the stability region [6]. It is also found that the discrete time cancellation of zeros by poles that correspond to oscillatory continuous time functions can lead to unacceptable intersample behaviour. Therefore this technique is not very much suitable for d.c. motor systems.

The STC consisting with two loops an inner loop or the control loop and an outer loop that adjusts the control

parameters in the inner loop. STC deals with discrete systems and is applicable to a wider class of problems though the stability of such schemes may be harder to prove. Self tuning controller gained more popularity because of some advantages over MRAC. In this thesis self tuning controller [5] is used and here it is discussed in detail.

#### 2.6 SELF TUNING CONTROL

Kalman probably was the first to propose selftuning under the title 'self optimizing'. It had little immediate consequence at the time due to lack of suitable technology. Moreover, MRAC could be implemented using analog hardware encouraging more work on its development. With the development of microprocessor technology there have been stimulating developments in self tuning control, although no guarantee that self tuning would be successful in practical applications, because the theory is proven for small cases only and even under the favourable conditions there is no guarantee of convergence.

with Even the incompleteness of established theoritical results, there is a development work on selftuning controller. The popularity of this control can be gauged from the number of paper published and the succesful applications reported in the literature. Now а days selftuning controller is mostly preferred because of the following reasons:

- i) The algorithms used are very simple.
- ii) It is derived in discrete form which can be readily implemented on microcomputers.
- iii) It has been found possible to establish some theoretical results which, although incomplete indicate that satisfactory stable performance can be expected.

The controlled system parameters are identified in these techniques, on line and the control is calculated using a preselected strategy as shown in Fig. 2.1.

### 2.7 ALGORITHM

The algorithm for the generalised selftuning controller [5], used in this work can be summarized as follows:

- i) Form a generalised cost function (k=1)  $\phi(t) = Py(t) + Qu(t-1) - Rw(t-1)$
- ii) Estimate the control parameters,  $\Theta(t)$  by a standard recursive least square algorithm
  - $\hat{\Theta}(t) = \hat{\Theta}(t-1) + k(t) \left[\phi(t) \hat{\Theta}^{T}(t) x(t)\right]$

$$k(t) = \frac{P(t-1) x(t)}{[1 + x^{T}(t) P(t-1) x(t)]}$$

$$P(t) = \frac{[1 - k^{T}(t) x(t)] P(t-1)]}{\beta}$$



# FIG.2.I BLOCK DIAGRAM OF A SELF TUNING CONTROLLER.

where

$$\theta(t) = [h_0, h_1, \dots, h_{n_H}, g_0, g_1, \dots, g_{n_G}, e_0, e_1, \dots, e_{n_E}]$$

h, g and e are the co-efficients of the general polynomials  $H(z^{-1})$ ,  $G(z^{-1})$  and  $E(z^{-1})$  of order  $n_{\rm H}^{}$ ,  $n_{\rm G}^{}$  and  $n_{\rm F}^{}$  respectively.

The data vector is,

x(t) = [u(t), u(t-1)..., y(t), y(t-1), ..., w(t), w(t-1),

P(t) is a matrix proportional to the covariance of estimated parameters.

k(t) is the updating gain matrix, and is forgetting factor for exponential weighting of last data values.

iii) Compute Control Form

 $u(t) = -[g_0 y(t) + g_1 y(t) + \dots + e_0 w(t) + e_1 w(t-1) + \dots$ .... + h\_1 u(t-1) + ... ] / h\_0

iv) Repeat from (i) for the incremented value of 't'.

The algorithm may be started with  $P_0$  of polynomial P set equal to unity and the rest of the co-efficients of R and Q polynomials set to any arbitrary values. Generally 'R' is equal to 'P'.

#### 2.8 CONCLUSIONS

In this chapter, the selection of system model, test

....]

signal, system parameter identification techniques and briefly about MRAC & STC strategies have been described. The reasons to use STC instead of MRAC are also discussed. The complete algorithm of selftuning control, used in this work, is also explained.

#### CHAPTER-, 3.

#### HARDWARE IMPLEMENTATION

#### 3.1 GENERAL

The complete scheme for adaptive speed cotrol of the seperately excited d.c. motor is discussed in this chapter. The power converter used is a three phase fully controlled bridge converter. A adaptive controller based on selftuning, control is realised on IBM personal computer. Microprocessor based scheme for its firing angle control is discussed in detail, together with the hardware requirements. An 8085 microprocessor based system is used for the current error software proportional processing by plus integral а controller (PI) and personal computer (PC) is used to process the software of self tuning controller (STC) which helps in controlling the speed of a d.c. motor.

## 3.2 SYSTEM DESCRIPTION

The complete block diagram of the system is shown in Figure 3.1. The system implementation is started with the reference speed signal and the speed of the machine has to follow this signal. The controller (STC) parameters are computed in real time on line with IBM personal computer which are essential to calculate the controller output,



FIG.3.I SYSTEM BLOCK DIAGRAM.

obtained from personal computer (P.C.) in analog form through DAC is considered as current reference signal  $(I_{dc}^*)$  and it is converted into digital signal through 8 bit ADC 0809 which is being fed to the microcomputer 8085. The actual current signal corresponding to motor current is also fed to another channel of ADC 0809. The current error is generated by comparing the reference and actual current signals. This error may be either positive or negative and it is limited to a corresponding to about  $\pm 25$ % of full load current of the motor.

RECIBURI controlling signal The is generated bv а microprocessor according to the current error using proportional plus integral (PI) control algorithm. The PI controller processing is carried out through microp rocessor software. The control algorithm implemented in the microprocessor is a simple computation rule so that the response of the system can be fast. The PI control algorithm is easy to implement and does not need too much time to compute the controlling signals. Depending on this signal, constrained value is obtained from which corresponding firing angle is selected from the lookup algorithm. Using this firing angle first pair of the thyristors are fired and the remaining five pairs are fired at 60° interval. The converter output voltage is fed to a d.c. motor system. The speed of the machine being adjusted through self tuning controller in such a way that irrespective of the load

condition the actual speed of the machine has to follow the reference speed signal. The design of PI controller is given in Appendix C.

# 3.3 PC BASED SELF TUNING CONTROLLER

Clarke and Gawthrop algorithm is used to develop the selftuning controller and it is realised through software on IBM personal computer (PC). Reference speed signal is set through a potential divider and is being fed to PC via one channel of 12 bit ADC. Actual motor speed signal is fed to PC via second channel of ADC. Depending on the difference between these two values, the controller parameters are generated which are essential in obtaining the controller output (u). This controller output is outputted through a channel of DAC which has been considered as the reference current signal to the microprocessor system for the processing of PI current controller

### 3.4 POWER CIRCUIT AND ITS WORKING [1,30,31]

For the experimental purpose, a 1 H.P., 220 V, 1500 RPM d.c. machine is used. The fullwave thyristor bridge rectifier is employed to feed the proposed machine. The ratio of PIV and line to neutral voltage is given by  $E_{PIV}/E_{LN} = 2.45$ . Therefore

$$E_{PIV} = 2.45 \times \frac{400}{\sqrt{3}} = 566 V$$

Taking a factor of safety 2, a 1200 PIV Thyristors are used for the rectifier.

The output average d.c. voltage of a full wave rectifier is given by  $V_{dc} = 3\sqrt{6} /\pi \quad \cos \propto$ . The output voltage is taken equal to the rated voltage of the machine corresponding to minimum firing angle i.e.  $V_{dc} = 220$  V. Assuming the efficiency of 70% of d.c. motor the input power (P/n) is as

$$P_I = V_{dc} I_{dc} = P/n = 746/0.7 = 1065$$
 Watts  
 $I_{dc} = \frac{1065}{220} = 4.85 \approx 5$  Amps.

Taking a factor of safety 2 the thyristor current rating  $I_m = 2x5 = 10$  Amps

So the thyristor of 12 Amp, 1200 V can be selected to meet the requirements. However the available thyristors of 16 A and 1200 PIV are used.

Figure 3.2 shows a three phase fully controlled converter. It consists of six thyristors connected in the form of bridge configuration These thyristors are connected to phases RYB will be denoted by  $(T_1, T_4)$   $(T_3, T_6)$  and  $(T_5, T_2)$ . Each thyristor conducts for 1/3 of a cycle i.e for  $120^\circ$ 



FIG.3.2 POWER CIRCUIT CONFIGURATION.

duration, and at any instant of time two thyristors are conducting. With respect to phase sequence RYB,  $T_1$ commutates with  $T_3$ ,  $T_3$  with  $T_5$  and  $T_5$  with  $T_1$ . On the other side  $T_6$  commutates with  $T_2$ ,  $T_2$  with  $T_4$  and  $T_4$  with  $T_6$ . Commutation from one thyristor to other occurs when two anodes pass-through-the-same-potential-,-one-going up takes over\_from the other going down. This is called natural commutation. Thyristors are switched faster in three phase converters and therefore the time available for any current delay is less compared to the single phase case. This tends to make the motor current continuous.

Figure 3.2(a) shows the input supply line voltages and 3.2 (b) shows at which instants, the particular pair of thyristors are conducting. In this work six sequence of operation is assumed which can be understand from the following table.

| Sequence          | 0     | í     | 2     | 3     | 4     | 5     |
|-------------------|-------|-------|-------|-------|-------|-------|
| Conducting SCR's  | (6,1) | (1,2) | (2,3) | (3,4) | (4,5) | (5,6) |
| SCR's to be fired | 1 ·   | 2     | 3     | · 4   | . 5   | 6     |
| Outgoing SCR      | 6     | 1     | 2     | 3     | 4     | 5     |

The above firing sequence is used when the firing angle is less than  $60^{\circ}$ . If the firing angle becomes greater than  $60^{\circ}$  then the following sequence is used.



0 1 2 3 5 Sequence (5,6) (6,1) (1,2) (2,3) (3,4) (4,5) Conducting SCR's 6 1 2 3 4 5 SCR's to be fired 1 2 5 3 4 6 Outgoing SCR

If the firing angle becomes greater than  $120^{\circ}$  the following sequence is used

| •                 | · ·   |       |       |       |       |       |
|-------------------|-------|-------|-------|-------|-------|-------|
| Sequence          | 0     | 1     | 2     | 3     | 4     | 5     |
| Conducting SCR's  | (4,5) | (5,6) | (6,1) | (1,2) | (2,3) | (3,4) |
| SCR's to be fired | 5     | 6     | 1     | 2     | 3     | 4     |
| Outgoing SCR      | 4     | 5     | 6     | 1     | 2     | 3     |

To maintain a symmetrical waveform of the input current the firing sequences are necessary. The frequency of firing will be six times the supply frequency.

The average output voltage of a fully controlled converter is given by

 $V_{dc} = \frac{3\sqrt{6}}{\pi} V \cos \alpha$  ... (3.1)

If  $\propto = 0^{\circ}$  then  $V_{dc} = V_{max}$  and if  $\propto = 90^{\circ}$  then  $V_{dc} = 0$ .

Therefore equation (3.1) shows the output voltage depends upon the firing angle information.

For a seperately excited d.c. motor the back e.m.f.  $E_g = K_a \phi N$ In terms of average voltages

Equation (3.2) represents the average speed.

In a seperately excited d.c. motor  $T = K_a \phi I_a$  and motor speed (N) is

$$N = \frac{V_{dc}}{K_a \phi} - \frac{R_a}{(K_a \phi)^2} T \qquad .. (3.3)$$

The first term in equation (3.3) represents the ideal no load speed (T $\approx$ 0), which, therefore, depends on V<sub>dc</sub>. If the motor current is assumed continuous, motor terminal voltage  ${\tt V}_{\rm dc}$  depends only on the firing angle  $\ll$  . The variation of  $V_{dc}$  with  $\propto$  for continuous motor current is shown in Fig.3.3(c). These curves also represent the theoritical no load speed as a function of firing angle. The second term in equation (3.3) represents the decrease in speed as the motor torque increases. Since the armature resistance is small, the decrease in speed is small. In large motors, the motor current at no load (i.e. motor idling) is not small, and if a three phase converter is used the motor current is likely to be continuous even at no load condition. Therefore, three phase converter fed dc drives provide better speed regulation and improved performance as compared to single phase converter fed dc drives.

The motor terminal voltage can become negative for the triggering angle  $=120^{\circ}$ . This is the inversion mode of operation of the converter. If the motor voltage is reversed

with a reversing contactor or by reversing the field current, power can be transferred from the motor to the a.c. supply. That is what commonly known as regeneration. The motor will slow down due to power feeding back, and thus the motor voltage decreases. Therefore, as the motor slows down, the firing angle of the converter is to be adjusted to keep the current up and to regenerate power.

#### 3.5 MICROPROCESSOR BASED CONTROL SCHEME

Microprocessor based firing scheme is shown in Fig.3.4 and it is used for generating the firing pulses for converter thyristor in proper sequence decided by the control circuit and software. This scheme has several advantages over the analog firing control schemes. This scheme requires less number of hardware components and simple synchronizing technique. For this, one programmable peripheral interface 8255, one programmable interval timer and one programmable interrupt controller 8259. The pin diagram and operational details of these ICs are given in Appendices A and B . The synchronizing signal which is obtained from synchronizing circuit is inputted to IR interrupt. Gate of timer TM, is always made high by connecting it to +5V. Counter  $TM_1(1)$  get the clock of 1.535 MHZ from µP. ADC 0809 is interfaced to microprocessor through port B and port C of 8255. ADC provides the information about the reference current and actual current. The firing angle information is obtained



FIG. 3.4 MICROPROCESSOR BASED SYSTEM CONFIGURATION.

from the lookup table, and the pulses are outputted through port A of 8255 as per firing command. Different wave shapes for interrupt signals are given in Figure 3.5.

## 3.5.1 Synchronizing Technique

Independently of the method or algorithm used to control thyristors firing of a three phase static power converter, the signals that synchronize them with the alternating supply voltages are always necessary. For a three phase converter, there are six such logical signals, each one associated with a thyristor and defined from the natural commutation instant i.e. at the intersection of two phase to phase voltages, which coincides with zero crossing of the other one. The zerc crossing voltage detector fulfills two different functions, the synchronization of the thyristor circuit to the input line frequency and the phase sequence identification.

Synchronizing signal is generated by sensing line to line voltages  $V_{RB}$  and  $V_{BY}$  of the supply mains. This signal has pulses of 60° duration corresponding to supply voltage frequency at every 360° interval. This signal provides the information about frequency of supply voltage and the instant of loading a counter of PIT 8253 with firing angle delay count. Synchronizing signal is required for generating firing pulses for converter thyristor in proper sequence.



FIG.3.5 SYNCHRONIZING SIGNAL,  $R_0 \otimes R_1$  INTERRUPT SIGNALS & FIRING PULSES IN PROPER SEQUENCE.

Synchronizing circuit uses less number of components and is shown in Figure 3.6. This circuit consists of the following components.

i) Step down transformer

ii) Comparator

iii) Transistor drive

iv) AND gate

Stepdown transformer is a single phase 440 V/6 V transformer to realise voltage sensor for a wide range of frequency. The primary and secondary connections are made in such a way that secondary voltage is 180° out of phase with respect to the primary voltage. Comparator circuit is realised with the help of operational amplifier IC 741. The inverting terminal of IC 741 is connected to common ground. The output of the comparator ideally swings between +12V to -12V at zero crossing of supply voltages and frequency is same as supply frequency. The output of comparator is reduced to a lower voltage by a series connected resistor and applied to the base of the transistor. Transistor stage is very important and required to interface the analog system to a digital system. Transistor is used to control the state of the TTL input. TTL outputs of transistors are shown in Figure 3.7.

The diode in the base circuit protects the base against excessive reverse voltage. Since the negative output



FIG.3.6 SYNCHRONIZING CIRCUIT



FIG.3.7 VOLTAGE WAVEFORM AT DIFFERENT POINTS OF SYNCHRONIZING SIGNAL .

of the comparator approaches -12V, we need to use a protective diode between the base and ground. This diode clamps the base voltage at approximately -0.7V on the negative swing. AND gate is used for necessary AND operation. The synchronizing signal is obtained after ANDING two output signals of the transistors. The microcomputer makes use of this signal for generating firing pulses in proper sequence and firing angle control.

### 3.5.2 Pulse Amplifier Circuit

The duration of firing pulses generated by the microprocessor via port A is not sufficient to trigger converter thyristors. The required pulse width is obtained using monostable circuit. The output of the monostable is applied to the pulse amplifier circuit as shown in Figure 3.8.

A pulse transformer is used for electrical isolation between control circuit and power circuit. The pulse at the transistor collector is the amplified inverted form of the input signal. But the isolating transformer connection are made in such a way that the final firing pulses has no phase shift with respect to the input pulse. A diode is connected across the transformer primary to avoid saturation of the pulse transformer. Another diode is connected in series with the secondary of the pulse transformer to block negative pulses. The diode across the primary also serves to protect



the transistor. The capacitor at the secondary prevents any spurious high frequency from triggering the thyristor. The gate of the thyristor can be protected from long reverse voltage by connecting a diode across the gate as shown in Figure 3.8.

## 3.6 CONCLUSIONS

In this chapter, the complete hardware philosophy of the speed control of a d.c. motor has been described using self tuning controller. The STC adaptive controller for speed control loop has been realised on IBM PC system and current control loop using PI controller has been realised through 8085 microprocessor based system. The design of power circuit and synchronizing circuit has been developed. The details of microcomputer based firing control scheme has been described in detail.

### CHAPTER - 4

#### SYSTEM SOFTWARE IMPLEMENTATION AND FLOW CHARTS

### 4.1 GENERAL

In this chapter, the complete software for self tuning controller (STC) based closed loop speed control of thyristor converter fed d.c. motor is described. The self tuning controller is realised through IBM personal computer (PC) in which speed feedback and reference speed signals are inputted through 12 bit 16 channel ADC Card and output of controller (STC) is obtained through a DAC channel of same card from The analog output of self tuning personal computer. controller is considered as current reference signal and inputted to 8085 based microcomputer system via 8 bit 8 channel ADC 0809 along with motor current feedback signal. A current proportional integral (PI) controller is realized through software on 8085 based system which also provides various firing commands for thyristors of converter in proper synchronization with mains through various hardware interrupts. The complete software for microprocessor 8085 based system is explained through main programme and associated various subroutines.

### 4.2 SOFTWARE IMPLEMENTATION OF SELF TUNING CONTROLLER

In the present work, the speed control of a d.c. motor is achieved by self tuning controller. The flowchart of implementation of STC algorithm is given in Fig.4.1. The program starts with the initialization of variables which are necessary to carryout the processing in order to obtain controller parameters and controller output. Proper weightage of polynomials P,Q and R is considered. Reference speed is set through the potential divider, and actual speed signal of a d.c. motor is measured through a.c. tachogenerator after rectifying and filtering. These two signals are taken as input via AD converter channels ( $I_0$  and  $I_1$ ) of ADC card of IBM (PC). Depending on these signals the controller parameters are estimated which adjust the controller output (U). The value of 'U' is computed and limited in the manner as demanded by controller to maintain constant speed of a d.c. motor irrespective of the load conditions. The developed basic language program for self tuning controller is given in appendix 'D'.

# 4.3 SOFTWARE FOR 8085 MICROPROCESSOR SYSTEM

#### 4.3.1 Main Program

The flow chart of the main program is shown in Fig.4.2. The program is started with initialization of STACK pointer and input-output ports. In the 8085 system, two timers of PIT 8253, six input-output ports with two PPI 8255 and one interrupt controller PIC 8259 are available to the user at  $J_1, J_2$  and  $J_3$  space. In the present work, one timer  $TM_1$  is used for loading firing angle as well as  $60^{\circ}$  count. Out of



FIG.4.1 FLOW CHART OF SELF TUNING CONTROLLER.



Initialise stack pointer, 8255, 8253 and 8259 with their modes, starting cycle index (s). Call closed loop initialization subroutine.

Select INo channel of ADC, Read reference current from PC via DAC. Select INi channel of ADC, Read actual current.

Call constrained current error subroutine, call PI current controller subroutine. Call constrained voltage subroutine.

Call look up : select corresponding firing . .

Call mode selection subroutine. Call multiplication subroutine, Get firing angle count.

Is starting index = 00 Yes Enable of interrupt. Incrementing starting cycle index = 01

FIG.4.2 FLOW CHART OF MAIN PROGRAM.

six input-output ports, three input-output ports of PPI 8255(1) are used in the present work. It is initialized as follows:

| 8255(1) | (Control word | registor = (        | )3H)                |               |
|---------|---------------|---------------------|---------------------|---------------|
| PORT A  | PORT B        | port c <sub>u</sub> | port C <sub>l</sub> | •             |
| OUT     | IN            | IN                  | OUT                 | 10001010 = 8A |

Figure 3.4 given in the previous chapter shows the configuration of the microprocessor based control scheme. Port A is used for firing the converter thyristors (Bits  $PA_0$  to  $PA_5$ ), port B is used for inputting digital output of ADC. Port C is used to send start of convertion (SOC) and end of conversion (EOC) signals. The timer  $TM_1$  is used for loading both firing angle count as well as  $60^{\circ}$  count for triggering converter thyristors. The timer is initialised as follows.

| TM1 | (11H) in mode ' | 0'     |                      |
|-----|-----------------|--------|----------------------|
| TMl | R/L             | MODE 0 | CODE                 |
| 01  | 11              | 000    | 0 = 70H <sub>+</sub> |

After initialization of all the necessary chips, all firing bits are made low and the status of output ports are stored. Starting cycle index 'S' is stored with initial value as OOH and the  $60^{\circ}$  count value is also stored. The PIC is initialized for the vector addresses of the interrupts  $IR_{0}$ ,  $IR_{1}$ . All interrupts are considered edge triggered.

After initialization process, two ADC channels are inputted one by one by selecting channels through port  $C_{\rm L}$ . Reference current is inputted by selecting IN<sub>0</sub> channel of ADC 0809 from personal computer (PC) via DAC, actual current is inputted by selecting IN<sub>1</sub> channel of ADC 0809.

After the measurement of reference and actual currents, the current error is constrained and stored at the end of constrained current error subroutine. Now, it enters PI subroutine.

In the PI control part, the change in error is calculated from the constrained current error and previous constrained current error. This change in error is used to obtain the new output unconstrained voltage of 2 byte, and then program enters constrained voltage subroutine.

In the constrained voltage part, previously obtained unconstrained voltage of 2 byte is considered to one byte only, because the voltage values stored are of one byte. This value of constrained voltage is limited between minimum (00H) to maximum (FFH) output voltage (Vdn), then it enters lookup algorithm to select the corresponding firing angle.

The firing angle which has been selected through look up subroutine is used to select the particular sequence of firing the thyristors of converter. This is being done in 'MODE SELECTION' subroutine. The above obtained firing angle



FIG.4.3 FLOW CHART OF CLOSED LOOP INITIALIZATION.

is converted into its equivalent counts by multiplying it with 'K' counts using 'MULT' subroutine. This firing angle count is used to load the timer  $(TM_1)$ .

After this starting cycle index 'S' is checked. If it is found as zero then the interrupt are enabled and increment index 'S' to one, otherwise jump back to 'CALL ADC' and carryout other processings.

The IR<sub>o</sub> interrupt service susbroutine is used to load the timer with firing angle count once in every cycle and  $IR_1$ interrupt service subroutine is used to load the timer with  $60^{\circ}$  count five times in every cycle, and to issue all six firing commands.

The machine level language programs are given in Appendix E.

## 4.3.2 Close Loop Initialization

In order to carryout the PI processing it is necessary to initialise some of the variables such as error, change in error, maximum voltage, maximum current, controller constant etc. This is done using closed loop initialization subroutine. The self explainatory of which is shown in Figure 4.3.

#### 4.3.3 ADC Subroutine

Reference current is measured and stored through this

subroutine. The self tuning controller output from PC via DAC converter is considered the value of reference current. An ADC converts this analog signal into digital signal. This ADC conversion is done once in every cycle of the main programme.

ADC clock in is given from a timer of 380 KHz frequency. ADC starts converting the analog signal into digital signal at the instant, when the start conversion (SOC) bit of ADC goes from low to high to low. ADC sends a signal to I/O port through end of conversion (EOC) bit going high, indicating that the conversion process is over. The ADC count is measured and stored in the memory location alloted for reference current. The flow diagram of ADC subroutine is shown in Fig. 4.4.

NAME OF SUBROUTINE

: ADC SUBROUTINE

: Input to DAC through AD/DA converter from PC via channel IN<sub>o</sub> which is selected.

: Reference current I dc

: None

: A, F

: This subroutine measures the reference current  $I_{dc}^{\star}$ . The result is stored in the reference current  $I_{dc}^{\star}$  at the end of subroutine, and it is displayed in the address field.

OUTPUTS CALLS DESTROYS

DESCRIPTION



FIG.4.4 FLOW CHART FOR ADC SUBROUTINE.

# 4.3.4 Constrained Current Error Subroutine

This subroutine is used to limit the magnitude of current error corresponding to actual current and reference The maximum magnitude of current error is decided current. initialization routine. Difference between in the CLI reference current and actual current results in error, this error is being limited not to cross the specified limits. The error may be positive or negative, if the magnitude of the current error is greater than the maximum current error, then the error is set equal to maximum current error, if the magnitude of -ve current error is greater than the maximum current error then error is set equal to maximum value and 2's complement of it. This value is the constrained value of current error. The flow chart of this subroutine is given in Fig. 4.5.

NAME OF SUBROUTINE

- : Constrained Current Error Subroutine.
- : Reference Current I<sup>\*</sup><sub>dc</sub> Actual 1 byte Current Idc each
  - : Constrained Current Error
    - (1 byte 2's Complement)
  - : A, F, H, L.
  - : This subroutine limits the current error between minimum and maximum error.

OUTPUT

INPUTS

DESTROYS

DESCRIPTION.





#### 4.3.5. PI Current Controller Subroutine

This subroutine computes and stores the unconstrained voltage  $V_{dn}^{\star}$ . During the execution of this subroutine, voltage and current error is updated. The constrained current error is considered as present status of error, which is used along with integral gain to obtain  $K_{I}e_{n}$ , the change in error is used with proportional gain  $K_{p} \bigtriangleup e_{n}$ . In both these case 'SMULT' subroutine is used, resulting in partial product. The product being added to get change in voltage. This change in voltage is added with previous voltage to obtain present status of voltage which is unconstrained 2-byte in 2's complement and is stored in the alloted memory location. The flow chart of it is given in Fig.4.6.

NAME OF SUBROUTINE

INPUTS

: PI Subroutine

: V<sup>\*</sup>dn

: V<sup>\*</sup><sub>dn-1</sub>

one byte each

: e<sub>n</sub> [ 1 byte 2's complement form] : e<sub>n-1</sub> [ 1 byte 2's complement form] : e<sub>n</sub> [ 1 byte 2's complement form] : Constrained current error [1 byte 2's complement form]

- : Unconstrained V<sup>\*</sup>
- : SMULT
- ALL

: This subroutine measures and stores the unconstrained  $V_{dn}^{*}$  value

OUTPUT

CALLS

DESTROYS

DESCRIPTION



FIG.4.6 FLOW CHART OF PI CONTROLLER OF CURRENT ERROR.

[2 byte 2's complement] in  $V_{dn}^*$  address at the end of Subroutine.

#### 4.3.6 Subroutine SMULT

Two's complement numbers can not be multiplied with the algorithm for unsigned binary numbers, because if either or - both the operands are negative, the result is incorrect. In one of the methods for multiplying two's complement number, first determine and save the signs of operands. Negative operands are made positive, and the operands are multiplied using the add and shift algorithm. If the operand signs are different, then the two's complement of the product is taken.

Booth's algorithm is direct а mere method of multiplying two's complement numbers. Booth's algorithm is based on the fact that a string of zeros in the multiplier requires no addition, just shifting and string of 1's running from  $2^p$  to  $2^q$  is treated as  $2^{q+1} - 2^p$ . In Booth's algorithm, the multiplication requires only two operations in addition to the shifts, one subtraction and one addition. This results in a faster multiplication because fewer operations are required.

Booth's algorithm is used which is as follows. Let  $X_i$  be the i<sup>th</sup> bit of an n-bit multiplier. But  $X_{n-1}$  is the most significant bit and  $X_0$  the least significant bit. A bit  $X_{-1}=0$ 

is assumed. The multiplicant is Y. Starting with i=0,  $X_{i}$  and  $X_{i-1}$  are compared. Depending on the comparison, one of the following action occurs.

| Xi | × <sub>i-1</sub> | operation                                       |
|----|------------------|-------------------------------------------------|
| 0  | 0                | Shift Y (left with respect to partial product)  |
| 0  | 1                | Add Y to partial product and Shift Y.           |
| 1  | 0                | Subtract Y from partial product<br>and Shift Y. |
| 1  | 1                | Shift Y                                         |

This process is repeated unitl n comparisons are made completing the multiplication.

The flow chart of subroutine is given in Fig.4.7 which implements Booth's algorithm for an 8-bit multiplicand and 8-bit multiplier. The subroutine is entered with the multiplicand in register D and the multiplier in register C. The 16 bit product is retained in register pair HL. This susbroutine is called in the PI subroutine for software implementation of PI controller.

NAME OF SUBROUTINE : SMULT

INPUTS

: Register B has multiplicand, Regist L has multiplier, Register C is used as counter.



FIG.4.7 FLOW CHART FOR SMULT SUBROUTINE.

OUTPUT

CALLS DESTROYS DESCRIPTION Register pair HL has the 16 bit product of the multiplication.

: None

:

- : A,F,B,C,H,L Registers.
- : This susbroutine multiplies two numbers (1 byte each), which are in 2's complement form. It stores the result of multiplication in register pair HL. This subroutine can be used for both unsigned numbers multiplication and for 2's complement numbers multiplication.

## 4.3.7 Constrained Voltage Subroutine

As mentioned in Appendix-C, in the design of PI controller, the maximum value of output voltage is to be limited between maximum and minimum specified limits. In the case of fully controlled converter, the normalised output voltage 00H corresponds to the maximum firing angle i.e.  $90^{\circ}$ , and FFH corresponds to the minimum firing angle i.e.  $0^{\circ}$ . The maximum and minimum value of output voltage is limited between FFH and 00H.

The flow diagram of it is given in Fig.4.8. The value of 00H if  $V_{dn}$  value to 00H if  $V_{dn}$  unconstrained is positive also greater than maximum voltage.

NAME OF SUBROUTINE : Constrained Voltage Subroutine.



· •

# FIG.4.8 FLOW CHART OF CONSTRAINED VOLTAGE SUBROUTINE.

OUTPUT

CALLS

DESTROYS

DESCRIPTION

: V<sup>\*</sup><sub>dn</sub> unconstrained

[2 byte data in 2's complement form]

v<sub>dn</sub> maximum voltage [1 byte]

: Constrained V<sup>\*</sup><sub>dn</sub> @[1 byte]

then it is set as FFH.

: None

: All

: This subroutine limits  $V_{dn}$  value between 00H and FFH, i.e. if  $V_{dn}$  is negative,  $V_{dn}$  is set as 00H, and if  $V_{dn}$  is positive and greater than FFH,

#### 4.3.8 Lookup algorithm Subroutine

While microprocessors potentially offer more flexibility and economy than the analog circuits, their relatively limited real time capabilities restrict their functions to table lookups and simple arithmatic operations. The determination of the necessary control requires only table lookup operations and computations are kept to a minimum. The control algorithm using the table lookup, becomes simple, meets the real time requirements, and its implementation is well within the capability of the present day microprocessors.

## Determination of lookup table values:

Assuming (1) continuous conduction mode of thyristor bridge converter.

- (2) Ignoring overlap period.
- (3) Fixed sequence R-Y-B of R.M.S. input voltage with constant frequency.



FIG.4.9 FLOW CHART FOR LOOK UP TABLE.

For a three phase fully controlled converter, D.C. . output voltage

$$V_{dc} = \frac{3\sqrt{6}}{\pi} V \cos \alpha$$

where V = RMS phase voltage

 $\propto$  = Firing angle Maximum value of V<sub>dc</sub> occurs at  $\propto$  = 0<sup>0</sup>

$$V_{dc}$$
 (max) =  $\frac{3\sqrt{6}}{11}$  V

Therefore 
$$\frac{V_{dc}}{V_{dc}(max)} = \frac{\frac{3\sqrt{6}}{7T} \vee \cos \alpha}{\frac{3\sqrt{6}}{T} \vee} = \cos \alpha$$

 $V_{dc}$  (normalised or  $V_{dn}$ ) varies from 'l' to '0' as firing angle ' $\propto$ ' is varied from 0<sup>°</sup> to 90<sup>°</sup>. The  $V_{dn}$  is represented by a one byte number and have  $V_{dn}$  (max) equal to 256 states. Therefore one state is of 1/256 equal to 0.003911 units.

For ' $\propto$ ' count;

360° corresponds to 20 m sec, Hence

 $1^{\circ}$  corresponds to 20/360 m sec = 20/360 x  $10^{-3}$  sec.

Clock frequency of timer = 1.535 MHz

$$= 1.535 \times 10^{6} Hz$$

Time for one 'T' State =  $\frac{1}{1.535 \times 10^6}$  Secs

· · · Sec corresponds to 1.535 x  $10^6$  'T' States.

.:  $\frac{20}{360} \times 10^{-3}$  Sec corresponds to 1.535 x 10<sup>6</sup> x  $\frac{20}{360} \times 10^{3}$  'T' State

= 82.57 'T' States

l<sup>o</sup> count corresponds to 82.57 'T' States (Decimal)
l<sup>o</sup> count corresponds to 55H 'T' States (Hexa)

 $\therefore \alpha_{\rm C} = \alpha^{\rm O} \times 55 {\rm H}$ 

The value of  $%_{\rm C}$  and  $V_{\rm dn}$  are formulated from the above equations for every 1° variation of firing angle in the range of 0° to 90°. The calculated value of  $\propto$ o and  $V_{\rm dc}$  are converted into Hexadecimal form and stored in the memory locations.

 $V_{dn}$  is of one byte and  $\propto^{\circ}$  is also one byte. So in the look up table  $V_{dn}$  takes 90 memory locations and corresponding  $\propto^{\circ}$  takes 90 memory locations for storing.

The look up table consider here in which the  $V_{dn}$  values in decreasing order are stored at higher memory locations. The flowchart of it is shown in Fig.4.9.

NAME OF SUBROUTINE : Lookup INPUTS :

Constrained  $V_{dn}$  which is of 1 byte stored at CVDC address. Its 'm' pointer is loaded with the address having the starting address of  $V_{dn}$ .

It stores 'm' pointer (lookup) table address of  $V_{dn}$  (new) at

OUTPUTS

: 'm' address and also stores  $\propto^{\circ}$  corresponding to this voltage.

CALLS : None

DESTROYS : A, F, H, L

DESCRIPTION

: This subroutine stores lookup table address of  $V_{dn}$  (new) at 'm' address, and also stores  $\propto^{\circ}$  corresponds to  $V_{dn}$  (new) which is displayed in data field.

## 4.3.9 Mode Selection Subroutine

Depending upon the firing angle, it is necessary to fix up the sequence of thyristor firing. This is being done using Mode Selection Subroutine. If the firing angle is between  $0^{\circ}$  to  $60^{\circ}$  then Mode '0' is selected which specifies thyristor pair (6,1) has to be fired first and then the remaining pairs. If the firing angle is between  $60^{\circ}$  to  $120^{\circ}$ , then  $60^{\circ}$  is subtracted from it and Mode '5' being selected which specifies Thyristors pair (5,6) has to be fired first and then the remaining pairs. If the firing angle is between  $120^{\circ}$  to  $180^{\circ}$ , then  $120^{\circ}$  is subtracted from it and Mode '4' being selected which specifies thyristor pair (4,5) has to be fired first and the remaining pairs. Therefore, the mode selection helps us in fixing up the particular sequence of firing of thyristor.

NAME OF SUBROUTINE : MODE

INPUTS

Register B has 60° count.
Register C has 120° count.
Accumulator is having an 8 bit value of selected mode index.

OUTPUTS



FIG.4.10 FLOW CHART FOR MODE SELECTION SUBROUTINE.

-

| DESTROYS : A,F,B,C Registers.<br>DESCRIPTION : This subroutine gives us the particular<br>sequence of Thyristor firing depending<br>upon the firing angle | CALLS       | : | None               |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---|--------------------|
| sequence of Thyristor firing depending                                                                                                                    | DESTROYS    | : | A,F,B,C Registers. |
|                                                                                                                                                           | DESCRIPTION |   | <b>,</b> -         |

## 4.3.10 Multiplication Subroutine

This subroutine is used to multiply two unsigned numbers. During the execution of this subroutine the firing angle which has been selected from look up table is converted into its equivalent counts by multiplying with 55H counts. This is the firing angle count which is to be loaded to the timer while serving IR<sub>o</sub> interrupt Service Subroutine. The flow chart of it is shown in Fig. 4.11.

NAME OF SUBROUTINE : MULT

| INPUTS      | : Firing Angle                                                                                                                              |   |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|---|
|             | : One degree equivalent counts.                                                                                                             |   |
| OUTPUTS     | : Firing angle count                                                                                                                        |   |
| CALLS       | : None                                                                                                                                      |   |
| DESCRIPTION | : This subroutine multiply the fi<br>angle obtained with 1 <sup>0</sup> equivalent of<br>and is stored in the memory s<br>allocated for it. | • |

## 4.3.11 IR Interrupt Subroutine

This subroutine is needed to load the



FIG.4.11 FLOW CHART OF MULTIPLECATION SUBROUTINE.

timer or counter  $TM_1$  with firing angle count and also fix up the sequence of firing. The subroutine is entered with saving of all registers, which will be used in the processing. Timer is given with the microprocessor system clock frequency of 1.535 MHz, and gate is made always high by connecting it to +5V. Synchronizing signal is connected to  $IR_0$  pin. The  $IR_0$  interrupt is served according to the status of the synchronizing signal. When synchronizing signal becomes high it enters  $IR_0$  subroutine, then the counter starts down counting till it becomes equal to firing angle count, and when the synchronizing signal becomes low it is disabled. This subroutine is served once in every cycle. The flow chart of IR\_ subroutine is shown in Fig. 4.12.

NAME OF SUBROUTINE : IR

INPUTS

: Firing angle count : Starting mode index.

OUTPUTS CALLS DESTROYS

DESCRIPTION

: None : A,F,H,L

:

: This subroutine load the timer TM<sub>l</sub> with firing angle count and triggered it. The output of this subroutine is outputted to IR<sub>1</sub> interrupt subroutine.

IR, interrupt output signal.

## 4.3.12 IR, Interrupt Subroutine

This subroutine is used to issue all six firing commands. The subroutine is entered with saving of all registers.



EIG.4.12 FLOW CHART FOR IRO INTERRUPT SUBROUTINE.



FIG.4.13 FLOW CHART FOR IR, INTERRUPT SUBROUTINE

:

During the execution of subroutine first M3 index is checked whether timer  $TM_1$  to be loaded with  $60^{\circ}$  count or not. The timer is loaded again when the  $M_3$  index is less than 06, after loading the timer with  $60^{\circ}$  count each time M<sub>3</sub> index is incremented. When M<sub>3</sub> index becomes equal to 06 indicating that loading of timer is over. Firing command has been issued as per M<sub>2</sub> index which is decided from mode selection subroutine. After issuing each firing command  $M_2$  index is incremented and is checked whether all six firing commands has been issued or not, if not once again IR, interrupt subroutine is served to issue next firing command. This is continued till all six firing commands are over. This subroutine is served six times in every cycle. The flow chart of it is given in Fig. 4.13.

NAME OF SUBROUTINE : IR,

| INPUTS      | : | 60 <sup>°</sup> count, M <sub>3</sub> index, M <sub>2</sub> index. |
|-------------|---|--------------------------------------------------------------------|
| OUTPUTS     | : | six firing commands.                                               |
| CALLS       | : | None                                                               |
| DESTROYS    | : | A11                                                                |
| DESCRIPTION | : | This subroutine is used to issue six firing commands.              |

## 4.4 CONCLUSIONS

In this chapter, the complete software implementation is discussed. The self tuning controller program is developed in basic language and is realised through IBM personal computer (PC). Ť.,

In the 8085 microprocessor system, current proportional plus integral controller is realised through software. The various subroutines used in conjunction with main routine are also discussed. The various described subroutines are ADC subroutine, constrained current error subroutine, PI subroutine, SMULT subroutine, constrained voltage subroutine, mode selection subroutine, IR<sub>0</sub> interrupt service subroutine, IR<sub>1</sub> interrupt service subroutine. The various subroutine software programs are developed and tested individually.

Speed control through selftuning controller on personal computer together with 8085 microprocessor based current loop PI controller scheme has worked satisfactorily with the developed software for the system.

.58

#### CHAPTER-5

#### PERFORMANCE OF THE SYSTEM

#### 5.1 GENERAL

This chapter deals with the simulation of self tuning controller for the known system as well as for the d.c. motor considered for the testing purpose. It is realised through software on PC. Recorded waveforms of the self tuning controller are presented here.

The microprocessor based system software 18 implemented to generate the firing pulses for thyristors triggering at different instants. The recorded waveforms of input voltage, IR interrupt, IR, interrupt, zero crossing presented here. The current controller signals are integral (PI) plus is realised through proportional microprocessor software system. Motor voltage and motor current at different points of the firing angle control are presented and discussed.

#### 5.2 EXPERIMENTATION

The objectives of the experimentation is to investigate the steady state performance and transient performance of the system. The experimental investigations to obtain the steady state and transient response are done for both on no load and on load conditions. The steady state performance of the





<sup>•</sup> 

.





FIG.5.4 VOLTAGE, CURRENT WAVEFORMS OF RESISTIVE LOAD FIRING ANGLE AROUND 40°, 2 ms/division



FIG.5.5VOLTAGE, CURRENT WAVEFORMS OF RESISTIVE LOAD FIRING ANGLE AROUND 75°, 2 ms/division

.



Fig.5.7 VOLTAGE, CURRENT WAVEFORMS FOR R-L- LOAD FIRING ANGLE AROUND 75°, 2ms/division.





FIG. 5.10 FIRING ANGLE Vs D.C. OUTPUT VOLTAGE.



FIG.5.11 TORQUE (T\_ < I\_) Vs SPEED,

drive remains same on both conditions, but changes during transient condition.

The thyristors of the converter are switched ON for 120<sup>0</sup> duration and at any instant of time two thyristors conduct together. The thyristors are switched ON in the proper sequence depending upon the firing angle information. Port 'A' bits from PA to PAs are used to send the firing command from the microprocessor. Six firing commands are executed for completion of one cycle of converter operation based on interrupt signals. This cycle is repeated again and The converter develops a variable d.c. output again. voltage. Recording of a.c. input voltage, synchronizing signal, the interrupt signal, IR, interrupt signal and the firing pulses obtained for all six thyristors are shown in Figs.5.1 to 5.3. All these waveforms are taken at a firing angle about 40 degrees. Sufficient inductance is added to smoothen the armature current.

The converter performance is first tested for both resistive load and on RL load; The recorded waveforms are shown in Figs.5.4 to 5.7. The converter output voltage is then fed to a d.c. motor to study the behaviour of the system on no load condition (open loop). While conducting these tests the input a.c. voltage is adjusted in such a way that for minimum firing angle the full load d.c. output voltage is obtained. The characteristic curves obtained are shown in Figs. 5.8 to 5.10.



FIG.5.13 NO LOAD MOTOR VOLTAGE AND CURRENT WAVEFORMS = 75°, N = 440 rpm,  $V_m = 65V$ ,  $I_m = .5A$ ,  $V_{ac} = 185V$ , 2 ms/divi

ı. SI. FIG.5.14 NO LOAD MOTOR VOLTAGE AND CURRENT WAVEFORMS  $\propto = 40^{\circ}, N=1530, V_m=210 \forall I_m=.7A, V_{ac}=185V, 2ms/division$ FIG.5.15 LOAD VOLTAGE AND CURRENT WAVEFORMS

 $V_m = 200V$ ,  $I_m = 2.05A$ , N = 1400 rpm,  $V_{ac} = 185$ ,  $I_g = 1.4A$ ,  $V_g = 200V$  $\propto = 40^\circ$ , 2ms/divisioN. 



I. FIG.5.17 LOAD MOTOR VOLTAGE AND CURRENT WAVEFORMS  $V_m = 50V$ ,  $I_m = 1.1A$ , N = 250 pm,  $I_g = .6A$ ,  $V_g = 40V$  $V_{ac} = 185 V$ , = 75°, 2 ms/division FIG.5.18 WAVE FORMS OF REFERENCE TRACKING SIGNAL & CONTROLLER OUTPUT. . .... . 11 2 ms/division. н

•

The behaviour of the system on load condition (open loop) is studied. During these tests the firing angle is set to a particular value and then the machine is loaded by maintaining the field current as constant. The characteristic curves obtained for various firing angles are shown in Fig. 5.11.

The d.c. motor voltage and current on no load condition for various firing angles are recorded which are shown in Figs. 5.12 and 5.13. The d.c. motor voltage and current waveforms for about 20% and 80% of full load conditions are also recorded and shown in Figs. 5.14 to 5.17.

Self tuning controller which has been realised through the software on PC works satisfactorily for 'OFF' line studies. Recording of the reference tracking signal (W) and the controller output (U) while keeping actual speed (YW) constant as shown in Fig. 5.18.

#### 5.3 DISCUSSION OF RESULTS

The following salient features on the performance of the system may be observed from the results.

The pulses generated to trigger the converter thyristors alongwith the synchronizing signal, IR<sub>o</sub> and IR<sub>1</sub> interrupt signal are similar to the theoritical wave forms given earlier in Chapter-III.

The converter which has been tested with resistive load as well as RL load confirms that the current in case of RL load is continuous where as the current may be discontinuous in case of resistive load.

The motor output voltage and current waveforms obtained experimentally are exactly identical with the theoritical ones given in Chapter-III. It shows that the no load motor current is small for lower speed than the higher speed of the machine. For larger firing angle the drive operates in discontinuous current mode of operation which is evident from Fig. 5.13.

From Fig.5.8 it is observed that under no load condition speed increases with increase in voltage. The motor speed rises almost linearly with increase in d.c. voltage, which is one of the desirable feature of the drive.

Fig. 5.9 shows the variation of no load speed of the motor with variation in firing angle. The speed of the motor is large for minimum firing angle and then decreases as the firing angle increases.

The converter output d.c. voltage  $V_{dc} \propto V_m \cos \alpha$ , confirms the variation of output voltage as a function of cosine angle as shown in Fig. 5.10, which resembles the theoritical wave form.

It is observed from Fig. 5.11 that the motor exhibits the natural torque versus speed characteristics. It is obvious that at lower torque the motor speed is high and speed is low at higher torques. It is also observed that for different firing angles there is a shift in maximum and minimum speed range which decreases as the firing angle increases along with the increase in torque.

The motor output voltage and current waveforms on loaded condition reveals that at lower firing angle the current is more continuous where as at higher firing angles current becomes discontinuous. There is a dip in the curve because of back emf of motor, at this instant current becomes. zero as shown in Figs. 5.15 and 5.17.

The self tuning controller with constant actual speed of the machine had confirmed that the controller output is tracking according to the variation of reference signal, which is the essential feature of self tuning controller,

## 5.4 CONCLUSIONS

The 'OFF' line studies on self tuning controller for reference tracking shows the satisfactory performance for known system and for discretized model of a d.c. drive under consideration.

Even on the 'ON' line implementation the self tuning controller output is following with respect to reference tracking signal with little oscillations in the controller output because of slow response of DAC and larger execution time.

The firing control scheme results in satisfactory performance and is capable of controlling the firing angle of converter over a wide range. The recorded waveforms confirms that the wave forms of control scheme are identical to theoritical expected ones giving its reliable and satisfactory performance.

The current controller realised through microprocessor based system results in satisfactory performance and capable of maintaining the current constant with in a few cycles of a.c. supply.

The performance of a converter fed d.c. motor has been found satisfactory at different values of firing angles and load conditions.

The motor output voltage and current on load condition shows the continuous current mode and discontinuous current mode of operation of the drive. At larger firing angle the \_current\_wave form confirms the discontinuous current mode of operation than at lower firing angles.

#### CHAPTER - 6

#### CONCLUSIONS AND SUGGESTIONS FOR FURTHER WORK

#### 6.1 MAIN CONCLUSIONS

reported, here, the design, The covers work fabrication and testing of closed loop speed control of seperately excited d.c. drive. A three phase fully controlled thyristor bridge is used to feed the variable voltage d.c. supply to armature of d.c motor. The adaptive controller based on self tuning principle has been realised through IBM PC for speed loop and current loop based on proportional integral controller (PI) is achieved through eight bit microprocessor system. The firing pulses for thyristors of converter have been obtained from microprocessor and fabricated hardware in proper sequence at appropriate instants. The scope and main conclusions of the present work are given as follows.

(i) · The proposed self tuning controller (STC) for reference tracking has been simulated for the known second order system. From the simulated results it is observed that the controller output and its parameters are setled very quickly within two-three iterations. Moreover, the simulated results of discrete model of consideration motor under also d.c. show the satisfactory response of controller. Based on this investigation it may be concluded that the proposed STC gives the satisfactory performance for known system of second order and discretized model of d.c. drive system under consideration.

(ii)

The control scheme for generating the firing pulses of thyristors used in bridge converter has been developed using minimum hardware and software on eight bit 8085A microprocessor based system. The hardware includes only two hardware interrupts (IR, and IR, of PIC 8259) and only one counter (TM, of PIT 8253), synchronizing circuit, ADC interfacing (ADC-0809) and amplifier amplify the firing pulses circuit to issued by microprocessor through the bits of ports (PPI 8255). Apart from reduced hardware, the scheme has only small software due to involvement of only two interrupt The firing scheme results in satisfactory routines. operation and capable of controlling the firing angle of converter over the wide range. The recorded wave forms of control scheme are identical to theoritical expected ones giving its reliable and satisfactory performance.

- The current loop of the drive is also realised through (iii) same microprocessor system in which the reference current signal is fed through ADC obtained from IBM PC via DAC channel and armature current feedback is fed through another channel of ADC. These current signals are processed using PI controller and resulted output is taken as d.c. voltage to find delay angle of converter from look-up table. The current PI controller results in satisfactory performance and capable of maintaining the current within few cycles of a.c. supply.
- (iv) The self tuning controller for speed tracking is implemented through IBM PC. In which the reference speed (W) and motor speed (YW) signals are fed through the two channels of 12 bit ADC and the output of controller (U) is considered as current reference for

the inner current control loop of the drive. STC output responds very quickly and satisfactory manner reference perturbations. Moreover, it also to: responds to load perturbations on the dirve but in The sluggish response of slightly sluggish manner. STC results in oscillations in the speed of drive Its main reasons are the delay and error in system. speed signal sensing, large computation time in high level language (BASIC) and low speed of IBMPC (around 5 MHz).

(v) The performance of converter fed d.c. motor has been obtained experimentally at different values of control parameters. The speed drop of drive for a fixed firing angle of converter is found more compared to case of ideal d.c. supply. The wide range of speed control of drive is observed by using the developed control scheme.

(vi) The motor current wave forms are found continuous over the wide range of speed even at no load and more undulations are observed at low speeds of the drive. The voltage wave forms observed are similar to theoritically expected ones.

Based on the investigations carred out it may be concluded that the STC type of adaptive controller is quite suitable for reference tracking for the slightly slow processes such as in chemical industries, voltage regulating systèm etc. However, the developed control scheme with reduced hardware is found quite suitable for speed control of d.c. drive. However by improving speed sensing and decreasing computation time of PC by operating it at higher

frequency and choosing suitable programming language it is possible to get the satisfactory speed control of d.c. drive.

6.2 SUGGESTIONS FOR FURTHER WORK

During the course of investigations, certain problems arose which require attention. These problems alongwith some additional aspects for further extension of work are listed as follows:

- (i) Development of dedicated system using 8086 microprocessor with 8087 coprocessor may improve the system response.
  - (ii) Improvement in sped signal sensing using fast encoder will result in fast response and accuracy in control of speed of the drive.
  - (iii) For fast response and four quadrant operation of the drive, the dual converter or the diode bridge with chopper may be used with additional features of regeneration and bracking.
  - (iv) The proposed adaptive controller may also be used for higher rating of the drive to justify its cost consideration in various industrial applications.
  - (v) The reference tracking STC adaptive controllers may also be used for the control of a.c. drive with suitable converter systems.
  - (vi) The other types of adaptive controllers such as sliding mode (SM) may also be used for control of d.c. drive and performance may be compared with the proposed adaptive controller.

### REFERNECES

- P.C.Sen 'Thyristor d.c. drives', A Wiley-Inter science publications, John Wiley and Sons, Newyork 1985.
- Y.Pradeep Kumar, 'A microprocessor controlled thyristorized d.c. drive system', M.E. Thesis, March 1985.
- 3. Kumpati S. Narendra and Richard V. Monopoli, 'Applications of adaptive control', Acedamic press, 1980.
- Ambrish Chandra, 'Self tuning AVR cum stabilizer', Ph.D. Thesis, June 1987.
- 5. D.W. Clarke and P.J.Gawtrop, 'Self tuning control', IEE proceedings, Vol-126, No.6, pp 633-639, June 1979.
- A.Y.Allidina and Hughes, 'Generalised self tuning controller with pole assignment', IEE Proceedings, Vol-127, No.1, pp 13-18, Jan 1980.
- 7. P.J.Gawtrop, 'Some interpretations of the self-tuning controller', IEE Proceedings, Vol-124, No.10, pp 889-894, October 1977.
- A.Brickwedde, 'Microprocessor based adaptive control for electrical drives', IFAC control in power electronics, Switzerland, pp 119-123, 1983.
- 9. Rama chandran Balasubramanian and Kong Hung Wong, 'A micro computer based self tuning IP controller for d.c.

Machines', IEEE Transactions on IA, Vol.IA-22, No.6, pp 989-998, Nov/Dec.1986.

- 10. R.M.Stephan, V.Hahn, H.Unbehauen, 'Cascade adaptive speed control of a thyristor driven d.c. motor', IEE Proceedings, Vol-135, No.1, pp 49-54, June 1988.
- 11. L.Liu and N.K.Sinha, 'Adaptive state tracking', IEE Proceedings, Vol-135, No.6, pp 429-434, Nov. 1988.
- 12. T.T.C.Tsang and D.W.Clarke, 'Generalised predictive control with input constraints', IEE Proceedings, Vol-135 No.6, pp 451-460, Nov. 1988.
- 13. W.R.Cluett, S.L.Shah and D.G.Fisher, 'Robustness analysis of discrete-time adaptive control systems using input-output stability theory: a tutorial', IEE Proceedings, Vol-135, No.2, pp 133-141, March 1988.
- 14. B.Ilango, R.Krishnan, R.Subramanian and Sadasivam, 'Firing circuit for three phase thyristor bridge rectifier', IEEE Transactions on IECI, Vol.IECI-25, No.1 pp 45-49, Feb. 1978.
- 15. Alimirbod and Ahmed El-Amawy, 'A general purpose microprocessor based control circuit for a three phase controlled rectifier bridge', IEEE Transcations on IE, Vol.IE-33, No.3, pp 310-317, Aug. 1986.

70

- 16. Pei-Chong Tang, Shui-Shonglu and Yung-Chunwu, 'Microprocessor based design of a firing circuit for three phase fullwave thyristor converter', IEEE Transactions on IE, Vol.IE-29, No.1, pp 67-73, Feb 1982.
- 17. Gerson H. Pfitsher, 'A microprocessor based synchronization scheme for digitally controlled three phase thyristor power converters', IEEE Transactions on IE, Vol.IE-30, No.4, pp 330-333, Nov. 1983.
- 18. Remy Simard and V.Rajagopalan 'Economical equidistant pulse firing scheme for thyristorized d.c. drive', IEEE Transactions on IECI, Vol.IECI-22, No.3, pp 425-429, Aug. 1975.
- 19. H.M.El-Bolock, 'A microprocessor based novel scheme for constant angle triggering of thyristors under a variable frequency anode supply', IEEE Transactions on IA, Vol.IA-16, No.2, pp 165-171, March/April 1980.
- 20. Mario Benedetti and Carlos F. Christiansen, 'Universal microprocessor controller for thyristor phase control of multiphase converters', Int.J.Electronics, Vol-62, No.3, pp 385-392, 1987.
- 21. Thadiappan Krishnan and Bellakonda Ramaswami, 'A fast response d.c. motor speed control system', IEEE Transactions on IA Vol.IA-10, No.5, pp 643-651, Sept./Oct. 1974.

- 22. Soon Chan Hong and Min ho Park, 'Microprocessor based high efficiency drive of a d.c. motor', IEEE Transactions on IE, Vol.IE-34, No.4, pp 433-440, Nov.1987.
- 23. R.R.Sule, Balakrishna J. Vasanth, P.C.Sen and Mudit Kumar, 'Microprocessor based speed control system for high accuracy drives', IEEE Transactions on IE, Vol.IE-32, No.3, pp 209-214, Aug. 1985. ,
- 24. J.B.Plant, S.J.Jorna and Y.T.Chan, 'Microprocessor control of position or speed of an S.C.R. d.c. motor <u>drive'</u>, IEEE Transactions on IECI, Vol.IECI-27, No.3, pp 228-234, Aug. 1980.
- 25. G.Olvier, V.R.Stefanovic and G.E.April, 'Microprocessor controller for a thyristor converter with an improved powerfactor',\_\_IEEE Transactions on IECI, Vol.IECI-28, No.3, pp 188-194, Aug. 1981.
- 26. V.K.Verma and Pramod Agarwal, 'Parameter plane synthesis of a dual converter fed variable d.c. drive system', Electric machine and power system, No.12, pp 65-68,1987.
- 27. Tadeshi Egame, Jiaging Wang and Takeshi Tsuchiya, 'Efficiency-optimized speed control system synthesis method based on improved optimal regulator theory application to seperately exited d.c. motor system', IEEE Transactions on IE., Vol.IE-32, No.4, pp 372-380, Nov. 1985.

- 28. Pradeep K.Nandam and P.C.Sen, 'Analog and digital speed control of d.c. drives using proportional integral and integral proportional control techniques', IEEE Transactions on IE, Vol.IE-34, No.2, pp 227-233, May.1987.
- 29. B.R.Pelly, 'Thyristor phase controlled converters and and cycloconverters', A Wiley-Inter science publications John Wiley and Sons, New York, 1971.
- 30. G.K.Dubey, S.R.Doralda, A.Joshi and P.M.K. Sinha, 'Thyristorized power controllers', A Wiley easter limited, 1986.
- 31. M.Ramamoorthy, 'Introduction to thyristors and applications', East West Press, New Delhi, Second Edition, 1977.

73

#### BIBLIOGRAPHY

- 32. K.P.Gokale and G.N.Revankar, 'Microprocessor controlled seperately exited d.c. motor drive system', IEE Proceedings, Part B, Vol-129, No.6, pp 344-352, Nov.1982.
- 33. Richard Bonert, 'Digital tachometer with fast dynamic response implemented by a microprocessor', IEEE Transactions on IA, Vol.IA-19, No. 4, pp 1052-1056, Nov/Dec 1983.
- 34. S.K.Tsu and F.W.Pu, 'Software realization of synchronization and firing control of thyristor converters', IEE Proceedings, Vol-131, No.4, pp 141-148, July 1984.
- 35. T.J.Maloney and F.L.Alvarado, 'A digital method sfor d.c. motor speed control system', IEEE Trans. on IECI, Vol.IECI-23, No.1, pp 44-46, Feb 1976.
- 36. B.K.Bose and K.J.Jentzen, 'Digital speed control of a d.c. motor with phase locked loop regulations', IEEE Transactions' on IECI, Vol.IECI-25, No.1, pp 10-13, Feb.1978.
- 37. A.P.Malvino, 'Digital Computer Electronics', TMH, New Delhi, Second Edition, 1983.
- 38. Ramesh S. Goankar, 'Microprocessor Architecture, programming and applications with the 8085/8086A', Wiley Eastern limited, New Delhi.

# APPENDIX-A

CHIP DETAILS.

ľ

| F         | Pin Configuration |            |                    |  |  |
|-----------|-------------------|------------|--------------------|--|--|
| PA3       | $_{1}$ $\cup$     | 40         | 🗆 PA4              |  |  |
| PAL C     | 1                 | 39         | PAs                |  |  |
| PA, C     | 3                 |            | 1] PA6             |  |  |
| PA0 🗆     | 4                 | 37         | ] PA7              |  |  |
| RD []     |                   | 36         | II WR              |  |  |
| टे हे 🖂   | ŧ,                | - 1        | 🗆 RESET            |  |  |
|           | 7                 |            | D <sub>0</sub>     |  |  |
|           | 8                 | 33         | ⊒D,                |  |  |
| - Ao 🗂    |                   | 32         | $\Box D_{\lambda}$ |  |  |
| 1 1       | 10 8255A          | 31         | 🖾 D3               |  |  |
| ્રે Pናc 🖾 | H j               | 30         | □ D <sub>4</sub>   |  |  |
| pc5 [     |                   | 29         | Ds                 |  |  |
| PC, []    | 13                | 26         | De 1               |  |  |
| PCo 🖂     | 14                | 27         | ⊡ D7 É             |  |  |
| PC,       | 15                | 26         | □ Vcc              |  |  |
| PC1 □     | 16                | 25         | 🗆 P87              |  |  |
| PC,       | 17                | 14         | T PBe              |  |  |
| PBo 🗔     | 18                | <u>2</u> 3 | D PBs              |  |  |
| PB, 🗔     | 19                | 22         |                    |  |  |
| PB1 [     | 20                | 24         | D PB3              |  |  |

| Pin Names  |                          |  |  |
|------------|--------------------------|--|--|
| D7-D0      | Data Bus (Bidircetional) |  |  |
| RESET      | Reset Input              |  |  |
| <b>Č</b> Š | Chip Scient              |  |  |
| RO         | Read Input               |  |  |
| WR         | Write Input              |  |  |
| Ao, Ai     | Port Address             |  |  |
| PA7-PA0    | Poitt:A (Ba)             |  |  |
| PB,-PB,    | for E (2n)               |  |  |
| PC7-PC0    | Port C (Bit)             |  |  |
| Vcc        | +5 Volte                 |  |  |
| GND        | 0 Votrs -                |  |  |

FIGURE AL. 8255A Block Diagram

| F                  | in Coofigu | ation                | * .  |
|--------------------|------------|----------------------|------|
|                    |            | •                    |      |
|                    |            | 28 🗆 V <sub>CC</sub> |      |
| WX 🗋 2             |            | 27 🗋 🗛               |      |
| का 🗋 उ             |            |                      |      |
| D- 🗖 4             |            | 25 🗍 iR,             |      |
| D, C 5             |            | 24 🗍 IR,             | ÷    |
| U, 🗖 6             |            | 23 🗖 IR ;            |      |
| D, [7              | 8259A      | 22 🗍 IR.             |      |
| 0, 🗖 8             | 02.JJA     | 21 🗍 IR ,            |      |
| D <sub>2</sub> 🗍 9 |            | 20 🗖 IR,             |      |
| ם, 🗖 ונ            | )          | 19 🗖 IR,             | 20   |
| D <sub>o</sub> C   | 1          | 18 🗆 IR.             | • 7. |
| CASOCI             | 2 ·        | זראו 🗖 דו            |      |
| CAS 1 🗂 1.         | 3          | 16 🗆 SP EN           |      |
|                    | 4          | 15 D CAS 2           |      |

| ľ | ۱N | ina | me |  |
|---|----|-----|----|--|
|   |    |     |    |  |

| ()().                 | Data Bus (Bidirectional)    |
|-----------------------|-----------------------------|
| кD                    | Read Input                  |
| WK                    | Write Input                 |
| A., .                 | Command Select Address      |
| 775                   | Chip Select                 |
| CAS: CAS <sub>0</sub> | Cascade Lines               |
| <u>SP EN</u>          | Slave Program/Enable Buffer |
| INT                   | Interrupt Output            |
| INTA                  | Interrupt Acknowledge Input |
| IR.,-IR-              | Interrupt Request Inputs    |

FIGURE A'3. The \$259A Block Diagram





FIG. A4 8085A PINOUT DIAGRAM



.

.

# APPENDIX-B

PIN CONNECTION DIAGRAMS OF VARIOUS IC CHIPS USED BY THE AUTHOR IN THE PRESENT WORK ARE GIVEN AS FOLLOWS.



# FIG.B1 0809 (ADC) PIN CONNECTION









FIG. B4 7408 (QUAD 2-INPUT NAND GATE)

#### APPENDIX-C

### DESIGN OF PI CONTROLLER

Considering the steady state operation only, integral control system seems preferable to proportional systems. When a controller generates only a signal proportional to error the steady state error or offset remains as a result of sustained disturbance. The controllers which generate integral control in addition are able to regulate without leaving a steady state error. It is possible to combine the basic features of proportional controller and an integral controller to form a proportional plus integral controller. The action of a proportional plus integral controller in response to change in the input of external disturbance is initially similar to that of proportional controller, but as the new equilibrium point is reached, the control action becomes 'as that of an integral controller. This general purpose nature of the control system makes it applicable to numerous motor drive systems. Although the proportional and integral control algorithm is easily implemented, the control co-efficients must be carefully selected to assure that the operating system is stable.

In the present work a proportional plus integral controller has been designed and implemented through software for the current controlling purpose. The equation for the PI controller is

Output Voltage V =  $(K_p + \frac{K_i}{s})$  (I<sub>ref</sub>-I) .. (C1)

Where  $K_p = Proportional controller constant,$ 

$$K_{i} = \text{Integral controller constant,}$$

$$I_{ref} = \text{Reference current in Amps,}$$

$$I = \text{Actual current in Amps,}$$

$$S = \frac{d}{dt} \text{Sec}^{-1}.$$

$$V_{n} = K_{p}e_{n} + K_{i} \int_{-\infty}^{nT} e \cdot dt - --- at the n^{th} \text{ sampling instant}} (t = nT) \dots (C2)$$

$$e_{n} = \text{Error in reference current and actual current at the n^{th} instant.}$$

$$e_{n} = (I_{ref}-I) \text{ in amps.}$$

$$V_{n-1} = K_{p} \cdot e_{n-1} + K_{i} \int_{-\infty}^{(n-1)T} e \cdot dt - at the (n-1)^{th} \text{ sampling instant}} \dots (C3)$$

$$e_{n-1} = (I_{ref} - I_{n-1})$$
 in amps.  
 $V_n - V_{n-1} = K_p (e_n - e_{n-1}) + K_i \int_{(n-1)T}^{nT} e.dt$  .. (C4)

$$\Delta V_n \approx K_{\dot{p}} \Delta e_n + K_{\dot{i}} \cdot T \cdot e_n \qquad \dots \quad (C5)$$

 $K_{i}T$  can be expressed as  $K'_{i}$ 

$$\Delta V_n = (K_p \cdot \Delta e_n + K_i' e_n) \qquad \dots \quad (C6)$$

: 
$$V_n = V_{n-1} + K_p [e_n - e_{n-1}] + K'_i e_n$$
 .. (C7)

$$V_n = V_{n-1} + \Delta V_n \qquad \dots \tag{C8}$$

٠

As the bit length of 8085 microprocessor is 8 bits, the maximum value of d.c. output voltage is digitized form



FIG. C-I LIMITING THE OUTPUT VOLTAGE.





i.e.  $V_{dn}$  is limited to 256 bits of digital scale. Expressing the value of  $\Delta V_n$  in digital form.

$$\frac{V_{dn} \max}{256} \Delta V_n \text{ (Bits)} = [K_p \cdot \Delta e_n + K_i \cdot e_n] \dots (C9)$$

Where  $e_n$  and  $\Delta e_n$  are in amps.

The current scale calculated in digital form 1 amps = 8 bits

$$\therefore \Delta V_n = [K_p, \Delta e_n + K'_i, e_n] \frac{8 \times 256}{V_{dn}^{max}} \qquad \dots (C10)$$

where  $\Delta V_n$ ,  $e_n$  and  $\Delta e_n$  are in bits. If the maximum value of d.c. output voltage  $V_{max}$  is limited to 25% of current error as shown in Fig. (C-1).

Considering only the proportional controller

$$V_{\text{max}}$$
 Volts =  $K_p \triangle e_n$  .. (Cll)

As the maximum speed of the drive is 1500 rpm and the rated current of 4.6 Amps.

25% of full load current error =  $[25/100] \times 4.6$  = 1.15 Amps.

Maximum value of D.C. output voltage is limited to 220V 220 = K<sub>p</sub> [1.15]

: 
$$K_p = \frac{220}{1 \cdot 15} \approx 191$$

As an integral controller keeps the steady state error to minimum possible value, it is also incorporated in the controller. For accomadating the integral constant, the proportional controller constant  $K_p$  must be kept low. From equation (C10), with  $\Delta V_n$ ,  $\Delta e_n$  and  $e_n$  in bits

$$\Delta V_n = [K_p. \Delta e_n + K'_i.e_n] \frac{8x256}{220} \dots (C12)$$

$$\Delta V_n = [K_p \cdot \Delta e_n + K'_i \cdot e_n] \qquad \dots (C13)$$

or 
$$\triangle V_n(\text{Hexa}) = C_p \triangle e_n(\text{Hexa}) + C_i \cdot e_n(\text{Hexa})$$
 .. (C14)

Where  $C_p$  and  $C_i$  are in the order of 0-10 (Binary) or OAH. The equation (Cl4) is implemented through software as a PI controller algorithm.

Thus the error is limited between the limits before the PI control processing. If the reference current is greater than the actual current, then the error will be positive, and if the reference current is less than the actual current, then the error will be negative. For this the error is limited on either side as shown in Fig.(C2)'. The error is limited to +25% of rated current, when the error is positive, and the error is limited to -25% of rated current, when the error is negative.

25% of maximum current = 
$$\frac{25}{100} \times 4.6 = 1.15$$
 Amps. = 20 bits

So the error is limited to 20 bits on either side. The complete PI control algorithm is processed in 2's complement form, since the error may have positive or negative values. The calculated value V is limited to  $V_{max}$  if it is greater than  $V_{max}$ , and to zero if its calculated value is negative.

The maximum d.c. voltage output is limited for a given 3 phase a.c. input with firing angle at zero degrees.

Thus the designed controller has excellent flexibility, and the optimum values for  $C_p$  and  $C_i$  can be chosen for a satisfactory system response experimentally.

## APPENDIX D

```
5 REM self-tunning controller for dc motor cotrol
20 DIM X(6), P(6,6), SITA(6), PXT(6), AK(6), AKT(6), AKXPX(6), AKXK(6,6), PK(6,6)
25 OPEN "WN200" FOR INFUT AS #1
30 BETA=.98:AY2=0!:AY1=0!:W2=0!:W1=0!:U1=0!:U2=0!:
40 FOR I=1 TO 6:P(I,I)=100!:SITA(I)=.001:NEXT I
50 A=10
60 FOR L=1 TO 200
70 T = L
80 AX = A
90 GOSUB 600
100 W=10*AW
110 AS=-1
120 \text{ AL} = (200/\text{A}) + 1
125 FOR JL=1 TO AL
130 AX=AX+A
140 GOSUB 600
150 IF AX<=200 THEN 170
160 IF AX>200 THEN 185
170 W=W+10*AS*AW
180 AS=-AS
185 NEXT JL
190 INPUT #1,UN
200 YW=1.5*AY1-.7*AY2+U1+.5*U2+UN
210 GOSUB 250
220 PRINT L, W, YW, U, SITA(1)
225 PRINT SITA(2), SITA(3), SITA(4), SITA(5), SITA(6)
230 NEXT L
240 IF EOF(1) THEN CLOSE #1
245 REM COTROLLER
250 FAI=YW-W1+.5*U1
260 X(1)=AY1:X(2)=AY2:X(3)=U1:X(4)=U2:X(5)=W1:X(6)=W2
270 FOR I= 1 TO 6:PXT(I)=0!:FOR K= 1 TO 6
280 PXT(I)=PXT(I)+P(I,K)*X(I):AKXK(I,K)=0!
290 NEXT K,I
300 XPXT=0!:FOR K= 1 TO 6
310 XPXT=XPXT+X(K)*PXT(K)
320 NEXT K
330 XPX=1!+XPXT:XPXIN=1!/XPX
340 FOR I= 1 TO 6:AK(I)=PXT(I)*XPXIN:NEXT I
350 FOR I= 1 TO 6:AKXPX(I)=AK(I)*XPX:NEXT I
360 FOR I= 1 TO 6:FOR J= 1 TO 6
370 AKXK(I,J)=AKXK(I,J)+AKXPX(I)*AK(J)
380 NEXT J,I
390 FOR I= 1 TO 6:FOR J= 1 TO 6
400 PK(I,J) = P(I,J) - AKXK(I,J)
410 P(I,J)=PK(I,J)/BETA
420 NEXT J, I
430 S=0!
440 FOR I=1 TO 6:S=S-X(I)*SITA(I):NEXT I
450 FXTH=FAI+S
460 FOR I= 1 TO 6:SITA(I)=SITA(I)+AK(I)*FXTH:NEXT I
470 U=-(SITA(1)*YW+SITA(2)*AY1+SITA(4)*U1+SITA(5)*W+SITA(6)*W1)/SITA(3)
500 AY2=AY1:AY1=YW:U2=U1:U1=U:W2=W1:W1=W
510 RETURN
600 IF T>AX THEN AW=1
610 IF T<=AX THEN AW=0
620 RETURN
```

| 1.                                                                                                               | 0              | .046312              | 046312        | .001      |
|------------------------------------------------------------------------------------------------------------------|----------------|----------------------|---------------|-----------|
| ,001                                                                                                             | .001           | .001                 | .001          | .001      |
| 2                                                                                                                | 0              | 009133               | -8.962501E-03 |           |
| .001                                                                                                             | .1071327       | .001                 | ,001          | .001      |
| 3                                                                                                                | 0              | 0560984              | -2.542441E-02 |           |
| - 19858                                                                                                          | ,<br>1457563   | .2005801             | .001          | .001      |
| 4                                                                                                                | 0              | 1713942              | .2524076      | .7002136  |
| -6.486835E-02                                                                                                    | .4929877       | ,3170308             | .001          | .001      |
|                                                                                                                  | ()             | 6.362604E-02         |               | .4681342  |
| 1947735                                                                                                          | ,9676786       | .2647103             | . 001         | . 001     |
| 6                                                                                                                | 0              | .1480407             | 4.891717E-03  | . 4964408 |
| 3206402                                                                                                          |                | . 427857             | .001          | .001      |
| 7                                                                                                                | ()             | .0422181             | 1.250662E-02  | .591459   |
| 2545559                                                                                                          | .8990299       | .3006209             | .001          | .001      |
| 8                                                                                                                | 0              |                      | 2.418479E-02  | .5808638  |
| 3195583                                                                                                          | .894776        |                      | .001          | .001      |
| •                                                                                                                | 0<br>0         |                      | 3.011107E-02  | .6227276  |
| 3482514                                                                                                          | 、<br>.8124193  | .2365447             | .001          | .001      |
| 10                                                                                                               | , GIZ4170<br>Ö | 1365673              | .173416       | . 9046934 |
| 3214852                                                                                                          | .6039417       | -1.464433E-02        |               | .001      |
| 11                                                                                                               | 10             | .1096528             | 1232258       | .5644613  |
| 361092                                                                                                           | 1.17333        | .1347999             |               |           |
| 12                                                                                                               | 10             |                      |               | .001      |
| 3592802                                                                                                          | 1.178485       | .2007205             | 8.297165      | . 5583221 |
| 13                                                                                                               | 10             | .1199615<br>8.482436 | 9845974       | .001      |
| 3589733                                                                                                          |                |                      | 1.719219      | .560635   |
|                                                                                                                  | 1.25163<br>10  | .1178056             | 9874096       | .2061321  |
| 14                                                                                                               |                | 18.39602             | -7.002163     | 1.017934  |
| 3563188<br>15                                                                                                    | 1,261034       | .8205232             | -, 9867544    | . 1583376 |
|                                                                                                                  |                | 15.51429             | -9,799779E-02 | .9264608  |
| -3.028819E-02                                                                                                    | 1.170775       | .8168611             | 9871749       | . 1890075 |
| 16                                                                                                               | 10             | 6.805222             | 4.108249      | . 893577  |
| 1805827                                                                                                          | 1.172304       | .8071902             | 9871266       | .1854876  |
| 17                                                                                                               | 10             | 3.462917             | .4837133      | .8391091  |
|                                                                                                                  | -2.38933       | .7965697             | 9860614       | . 1078095 |
| 18                                                                                                               | 10             | 3.03232              | -3.298171     | .8877452  |
|                                                                                                                  | -2.028201      | 1.033686             | 9890582       | .3263478  |
| 19                                                                                                               | 10             | 9766312              | 5.562347      | .8357604  |
| 4421621                                                                                                          | 2.218232       | 1,002655             | -,988714      | .30125    |
| 20                                                                                                               | 10             | .2868398             | 8.450682E-02  | . 8098664 |
| -1.186393                                                                                                        | 1.111934       | -8203325             | 9898909       | .3870531  |
| 21                                                                                                               | 0              | 3.992002             | -11.16665     | . 7753781 |
| -1.28682                                                                                                         |                | -1.289644            | 9975032       | .9420276  |
|                                                                                                                  | 0              |                      | -2.957633     | . 6965627 |
| -1.278659                                                                                                        | 1.862378       |                      | 9975032       | ,7493881  |
| and the second | 0              | -19,44428            | -2.872797     | .1581535  |
| -1.76859                                                                                                         | 1.450788       | .7683785             | 9975032       | .7493881  |
| 24                                                                                                               | Ö              | -29.75796            | 5.408876      | 2.002086  |
| -2.598889                                                                                                        | 1.861657       | .3567991             | 9975032       | .7493881  |
| 25                                                                                                               | ()             | -27.01397            | 15.6796       |           |
| 1,526621                                                                                                         | 3.030169       | .9588192             | 9975032       | .7493881  |
| 26                                                                                                               | 0              | •                    | 6.236061      | .3861332  |
| 1.259407                                                                                                         | 3.148697       | .9483588             | -,9975032     | .7493881  |
| 27                                                                                                               | Ö              | 31.00856             | -5.029572     | .4160233  |
| -4.786074E-02                                                                                                    | 3.493824       | .7396007             | 9975032       | .7493881  |

•

.

CONTROLLER PAPRAMETERS OBTAINED FOR DISCRETIZED MODEL OF A D.C. MOTOR

١

| CONTROLLER PARAMETERS       | $\Theta_1 = 0.5115$ , $\Theta_2 = 0.5609$<br>$\Theta_3 = .8143$ $\Theta_4 = .1132$<br>$\Theta_5 =9546$ , $\Theta_6 =1162$ | $\Theta_1 = 0.5114, \Theta_2 = 0.5571$<br>$\Theta_3 = 0.8142, \Theta_4 = 0.1170$ | $ \Theta_5 = -0.9543, \Theta_6 = -0.1166 $ $ \Theta_1 = 0.5126, \Theta_2 = 0.5808 $ $ \Theta_3 = 0.6205, \Theta_4 = 0.1835 $ | θ θ θ θ = = = = = = = = = = = = = = = =                                | $\Theta_5 =9472$ , $\Theta_6 = -0.1141$ |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-----------------------------------------|
| SYSTEM OUTPUT EQUATION (YW) | .9969 ay <sub>1</sub> -0.000094 ay <sub>2</sub> +0.1769 u <sub>1</sub>                                                    | 1.0082 ay1-0.0097 ay2+ 0.1755 ul                                                 | .9985 ayı00096 ay2 +0.1768 u <sub>l</sub>                                                                                    | 1.0979 ay <sub>1</sub> -0.0986 ay <sub>2</sub> + 0.1598 u <sub>1</sub> |                                         |
| SAMPLING PERIOD             | T = 0.1 Sec                                                                                                               | T = .05 Sec                                                                      | T = .075 Sec                                                                                                                 | T = .025 Sec                                                           |                                         |
| sl.No.                      | Т                                                                                                                         | 7                                                                                | m                                                                                                                            | 4                                                                      |                                         |

· · · · · ·

1

0

# APPENDIX-E

## MAIN PROGRAM

|   | 2050  | 31,00,27 | LXIH, 2700 | Initialize Stack Pointer                         |
|---|-------|----------|------------|--------------------------------------------------|
|   | 2053  | 3E,8A    | MVIA, 8A   | ·<br>·                                           |
|   | 2055  | D3,03    | OUT 03     | Initialize 8255(1)<br>in mode zero               |
|   | 2057  | 3E,00    | MVI A,00   | Cat mont & bits low                              |
|   | 2059  | D3,00    | OUT 00     | Set port A bits low                              |
|   | 205B  | 3E,00    | MVI A,00   | Sat part C bits low                              |
|   | 205D  | D3,02    | OUT 02     | Set port C bits low<br>and store the status 2007 |
|   | 205F  | 32,07,20 | STA 2007   |                                                  |
|   | 2062  | 3E,00    | MVI A,00   | Set the index $S = 0$                            |
|   | 2064  | 32,01,20 | STA 2001   | and store it at 2001                             |
|   | 2067  | 3E,70    | MVI A,70   | Initialize TM <sub>l</sub> in                    |
|   | 2069  | D3,13    | OUT 13     | 'mode' 0;                                        |
|   | 206B  | 3E,16    | MVI A,16   | Triticlication control                           |
|   | .206D | D3,28    | OUT 28     | Initialization control<br>word ICW <sub>1</sub>  |
|   | 206F  | 3E,2B    | MVI A,2B   | Initialization control                           |
|   | 2071  | D3,29    | OUT 29     | word ICW <sub>2</sub>                            |
|   | 2073  | 3E,FC    | MVI A,FC   |                                                  |
| 2 | 2075  | D3,29    | OUT 29     | Operational control word<br>OCW <sub>1</sub>     |
| ; | 2077  | 32,00,20 | STA 2000   | Store mask address<br>at 2000.                   |
|   | 207D  | 22,04,20 | SHLD 2004  | Load 60 <sup>0</sup> count in<br>HL Pair.        |
|   | 2080  | CD,00,29 | CALL CLI   | Call closed loop initialization.                 |
|   | 2083  | 3A,07,20 | LDA 2007   |                                                  |

ŧ

| · | 2086  | E6,F3                | ANI F3                      |                                                            |
|---|-------|----------------------|-----------------------------|------------------------------------------------------------|
|   | 2088  | F6,00                | ORI 00                      |                                                            |
|   | 208A  | D3,02                | OUT 02                      | Select IN Channel                                          |
|   | 208C  | 32,07,20             | STA 2007                    |                                                            |
|   | 208F  | CD,00,28             | CALL ADC                    |                                                            |
|   | 2092  | 32,85,23             | STA I* <sub>dc</sub> (n)    | I <sub>dc</sub> =I* <sub>dc</sub>                          |
|   | 2095  | 32,86,23             | STA I*dc(n-1)               | I <sub>dc</sub> =I* <sub>dc(n-1)</sub>                     |
|   | 2098  | 32,87,23             | STA I <sub>dc</sub> (n)     | I <sub>dc</sub>                                            |
|   | 2098  | 3A,07,20 <u>BACK</u> | LDA 2007                    |                                                            |
|   | 209E  | F6,00                | ORI 00                      |                                                            |
|   | 20A0  | D3,02                | OUT 02                      |                                                            |
|   | 20A2  | 32,07,20             | STA 2007                    | Select IN <sub>o</sub> channel                             |
|   | 2•0A5 | CD,00,28             | CALL ADC                    | and store actual current                                   |
|   | 20A8  | 32,87,23             | STA 2387                    | <sup>I</sup> dc <sup>•</sup>                               |
|   | 20AB  | 32,F4,27             | STA 27F4                    |                                                            |
|   | 20AE  | 3A,07,20             | LDA 2007                    |                                                            |
|   | 20B1  | E6,F3                | ANI F3                      |                                                            |
|   | 20B3  | F6,06                | ORI 06                      |                                                            |
|   | 2085  | D3,02                | OUT 02                      |                                                            |
|   | 20B7  | 32,07,20             | STA 2007                    | Select IN <sub>1</sub> channel and store reference current |
|   | 20BA  | CD,00,28             | CALL ADC                    |                                                            |
|   | 20BD  | 32,85,23             | STA 2385                    |                                                            |
|   | 20C0  | 32,F5,27             | STA 27F5                    |                                                            |
|   | 20C3  | CD,70,2A             | CALL CCI SR                 | Call constrained current                                   |
|   |       |                      |                             | Subroutine                                                 |
|   | 20C6  | CD,30,2B             | CALL PI                     | Call PI Subroutine                                         |
|   | 20C9  | CD,70,2B             | CALL V* <sub>dc</sub> (n)SR | Call constrained voltage                                   |
|   | 20CC  | 3A,8A,23             | LDA V* <sub>dc</sub> (n)    | subroutine                                                 |
|   | 20CF  | CD,A0,2B             | CALL 'LOOK'                 |                                                            |
|   |       |                      |                             |                                                            |

.

.

| 20D2 | 32,10,20 | STA $\propto$ add |                                |
|------|----------|-------------------|--------------------------------|
| 20D5 | 32,F6,27 | STA 27F6          |                                |
| 2008 | CD,25,23 | CALL MODE         | Call mode selection subroutine |
| 20DB | CD,00,23 | CALL MULT         | Call mult subroutine           |
| 20DE | CD,E3,06 | CALL MOD AD       | Call for display               |
| 20El | CD,FA,06 | CALL MODDT        | •                              |
| 20E4 | 3A,01,20 | LDA 2001          | , ·                            |
| 20E7 | FE,00    | CPI 00            |                                |
| 20E9 | С2,9В,20 | JNZ BACK          |                                |
| 20EC | FB       | EI .              |                                |
| 20ED | 3C       | INR C             |                                |
| 20EE | 32,01,20 | STA 2001          |                                |
| 20F1 | С3,9В,20 | JMP BACK          |                                |
|      | 1        |                   | × •                            |

-

IR<sub>0</sub>. INTERRUPT

| 2100 F5 PUSH PSW SAVE REGISTERS                                     |    |
|---------------------------------------------------------------------|----|
| 2101 E5 PUSH H                                                      |    |
| 2102 2A,02,20 LHLD $\propto_{count}$ Load HL with $\propto_{count}$ |    |
| address and output<br>Timer <sup>TM</sup> l                         | to |
| 2105 7D MOVA,L                                                      |    |
| 2106 D3,11 OUT 11                                                   |    |
|                                                                     |    |
| 2109 D3,11 OUT 11                                                   |    |
| 210B 3A,15,20 LDA S.M.I. add. SMI is stored                         |    |
| 210E 32,14,20 STA 2014                                              |    |

| 2111 | 3E,00    | MVIA,00                    | Set $M_3$ index = 00              |
|------|----------|----------------------------|-----------------------------------|
| 2113 | 32,08,20 | STA 2008                   |                                   |
| 2116 | F3       | DI                         | Disable of Interrupt              |
| 2117 | 3E,60    | MVIA,60                    | Specific EOI                      |
| 2119 | D3,28    | OUT 28                     |                                   |
| 211B | El       | POP H                      |                                   |
| 211C | Fl       | POP PSW                    | Recover Registers                 |
| 211D | FB       | EI                         | Enable of Interrupt               |
| 211E | C9       | RETURN                     |                                   |
| •    |          |                            |                                   |
|      | 1        | IR SUBROUTINE              | •                                 |
| 2200 | F5       | PUSH PSW                   | Save all registers                |
| 2201 | E5       | PUSH H                     |                                   |
| 2202 | C5.      | PUSH B                     |                                   |
| 2203 | 3A,08,20 | LDA M <sub>3</sub> Index   | Load M <sub>3</sub> index address |
| 2206 | FE,06    | CPI 06                     |                                   |
| 2208 | CA,57,22 | JZ LOOPl                   | $(A) = M_3$                       |
| 220B | 2A,04,20 | LHLD 60 <sup>0</sup> C add | HL 60 <sup>0</sup> count address  |
| 220E | 7D       | MOV A,L                    | LSB of 60 <sup>0</sup> count      |
| 220F | D3,11    | OUT 11                     |                                   |
| 2211 | 7C       | MOV A, H                   | MSB of 60° count                  |
| 2212 | D3,11    | OUT 11                     |                                   |
| 2214 | 3A,08,20 | LDA M <sub>3</sub> index   | (A)←M <sub>3</sub> Index          |
| 2217 | 3C       | INR A                      | $M_3 = M_3 + 1$ & Store it        |
| 2218 | 32,08,20 | STA 2008                   |                                   |
| 221B | 3A,14,20 | LDA M <sub>2</sub> Index   | (A)←M <sub>2</sub> index address  |
|      |          |                            | •<br>•                            |
|      |          |                            |                                   |

.

E-4

|        |              |                   | ,                        | 5-2                                         |
|--------|--------------|-------------------|--------------------------|---------------------------------------------|
|        |              |                   |                          |                                             |
|        | 221E         | FE,00             | CPI 00                   | Compare immediate<br>with 00                |
|        | 2220         | CA,5F,22          | JZo                      | $(M_2) = 00$ , Jump to JZ                   |
|        | 2223         | FE,01             | CPI 01                   |                                             |
|        | 2225         | CA,6C,22          | JZl                      | M2=01,Jump to JZ1                           |
|        | 2228         | FE,02             | CPI 02                   |                                             |
|        | 222A         | CA,79,22          | JZ2                      | $M_2 = 02$ , jump to $JZ_2$                 |
|        | 222D         | FE,03             | CPI 03                   |                                             |
|        | 222F         | CA,86,22          | JZ3                      | M <sub>2</sub> =03,Jump to JZ <sub>3</sub>  |
|        | 2232         | FE,04             | CPI 04                   | M <sub>2</sub> =04, Jump to JZ <sub>4</sub> |
|        | 2234         | CA,93,22          | JZ4                      |                                             |
|        | 223 <b>7</b> | FE,05             | CPI 05                   |                                             |
|        | 2239         | CA,A0,22          | JZ <sub>5</sub>          | M <sub>2</sub> =05,Jump to JZ <sub>5</sub>  |
|        | 223C         | 3E,00 <u>BACK</u> | MVIA,00                  | Set firing bits as zero                     |
|        | 223E         | D3,00             | OUT 00                   |                                             |
| •<br>• | 2240         | 3A,14,20          | LDA M <sub>2</sub> index | •                                           |
|        | 2243         | FE,06             | CPI 06                   |                                             |
|        | 2245         | DA,4D,22          | JC SAVE                  | M <sub>2</sub> <06,Jump to save             |
|        | 2248         | 3E,00             | MVIA,00                  |                                             |
|        | 224A         |                   | STA 2014                 |                                             |
|        | 224D         | F3 <u>SAVE</u>    | DI                       | Disable of interrupt                        |
|        | 224E         | 3E,61             | MVIA,61                  | Specific EOI of $IR_1$                      |
|        | 2250         | D3,28             | OUT 28                   |                                             |
|        | 2252         | Cl                | POP B                    | Recover Registers                           |
|        | 2253         | El                | POP H                    |                                             |
|        | 2254         | Fl                | POP PSW                  |                                             |
|        | 2255         | FB                | EI                       |                                             |
|        | 2256         | С9                | RETURN                   |                                             |

| 2257 | 3E,00 LOOP1          | MVIA,00  | Set M <sub>3</sub> index = 00       |
|------|----------------------|----------|-------------------------------------|
| 2259 | 32,08,20             | STA 2008 | & stoře it                          |
| 225C | C3,4D,22             | JMP SAVE |                                     |
| 225F | 3A,20,20 <u>JZ</u> o | LDA 2020 | FC=00 Ist firing command            |
| 2262 | D3,00                | OUT 00 . |                                     |
| 2262 | 3E,01                |          | Sot M -0]                           |
|      |                      | MVIA,01  | Set $M_2 = 01$                      |
| 2266 | 32,14,20             | STA 2014 | Store M <sub>2</sub> index at 2014  |
| 2269 | C3,3C,22             | JMP BACK |                                     |
| 226C | 3A,21,20 <u>JZ1</u>  | LDA 2021 | FC=01,2nd Firing Command            |
| 226F | D3,00.               | 00 TUO   |                                     |
| 2271 | 3E,02                | MVIA,02  | M <sub>2</sub> =02                  |
| 2273 | 32,14,20             | STA 2014 | Store M <sub>2</sub> index at 2014  |
| 2276 | C3,3C,22             | JMP BACK |                                     |
| 2279 | 3A,22,20 <u>JZ2</u>  | LDA 2022 | FC=02,3rd firing command            |
| 2270 | D3,00                | OUT 00   |                                     |
| 227E | 3E,03                | MVIA,03  | M <sub>2</sub> =03                  |
| 2280 | 32,14,20             | STA 2014 | Store M <sub>2</sub> index at 2014  |
| 2283 | C3,3C,22             | JMP BACK |                                     |
| 2286 | 3A,23,20 JZ3         | LDA 2023 |                                     |
| 2289 | D3,00                | OUT,00   | Issue 4th firing command            |
| 228B | 3E,04                | MVIA,04  | M <sub>2</sub> =04                  |
| 228D | 32,14,20             | STA 2014 | Store M <sub>2</sub> index at 2014, |
| 2290 | C3,3C,22             | JMP BACK |                                     |
| 2293 | 3A,24,20 <u>JZ4</u>  | LDA 2024 | FC=04,issue 5th firing command      |
| 2296 | D3,00                | OUT 00   |                                     |
| 2298 | 3E,05                | MVIA,05  | M <sub>2</sub> =05                  |
|      |                      |          |                                     |

| 229A         | 32,14,20            | STA 2014 | Store M <sub>2</sub> index at 2014  |
|--------------|---------------------|----------|-------------------------------------|
| 229D         | C3,3C,22            | JMP BACK | -                                   |
| 22A0         | 3A,25,20 <u>JZ5</u> | LDA 2025 | FC=06,issue 6th firing<br>command   |
| 22A3         | D3,00               | OUT 00   |                                     |
| 22A5         | 3E,06               | MVIA,06  | M <sub>2</sub> =06                  |
| 22A <b>7</b> | 32,14,20            | STA 2014 | Store M <sub>2</sub> index at 2014. |
| 20AA         | C3,3C,22            | JMP BACK |                                     |

ADC SUBROUTINE

| 2800              | 3E,00      | MVIA,00 | Set PC low         |
|-------------------|------------|---------|--------------------|
| 2802              | D3,03      | OUT 03  |                    |
| 2804              | 3C         | INR A   | Set PC high        |
| 2805              | D3,03      | OUT 03  |                    |
| 2807 <sup>.</sup> | 3D         | DCR A   | Set PC low         |
| 2808              | D3,03      | OUT 03  |                    |
| 280A              | DB,02 LOOP | IN 02   | In Port 'C' Status |
| 280C              | E6,40      | ANI 40  | Check SOC is over  |
| 280E              | CA, OA, 28 | JZ LOOP | •                  |
| 2811              | DB,01      | IN Ol   | In port 'B' signal |
| 2813              | С9         | RETURN  |                    |

## MODE SELECTION SUBROUTINE

| 2325 | 3A,10,20 | LDA 2010 | (A) $\ll_{f}$ address      |
|------|----------|----------|----------------------------|
| 2328 | 06,3C    | MVIB,3CH | (B) 60 <sup>0.</sup> Value |
| 232A | 0E,78    | MVIC,78H | (C) 120 <sup>0</sup> Value |
| 232C | B.9      | CMP C    |                            |

,

E**\_**7

| 232D | D2,3D,23        | JMC LOOP1  | $\approx_{f}$ >120 <sup>0</sup> ,jump to loopl |
|------|-----------------|------------|------------------------------------------------|
| 2330 | FE,3D           | CPI 3D     | 1                                              |
| 2332 | D2,49,23        | JNC Loop2  | ≪_>60 <sup>0</sup> Jump to loop2               |
| 2335 | 3E,00           | MVIA,00    | Set S.M.I.=00 & Store it                       |
| 2337 | 32,15,20        | STA 2015   |                                                |
| 233A | C3,52,23        | JMP RETURN |                                                |
| 233D | 91 <u>LOOP1</u> | SUB C      | (A)←(A)-120 <sup>0</sup> & Store it.           |
| 233E | 32,10,20        | STA 2010   |                                                |
| 2341 | 3E,04           | MVIA, 04   | Set SMI=04 & Store it.                         |
| 2343 | 32,15,20        | STA 2015   |                                                |
| 2346 | C3,52,23        | JMP RETURN | · · · · · · · · · · · · · · · · · · ·          |
| 2349 | 90 <u>LOOP2</u> | SUB B      | (A)←(A)-60 <sup>0</sup> & Store it.            |
| 234A | 32,10,20        | STA 2010   |                                                |
| 234D | 3E,05           | MVIA,05    | Set SMI=05 & Store it.                         |
| 234F | 32,15,20        | STA 2015   |                                                |
| 2352 | C9              | RETURN     |                                                |

# MULTIPLICATION SUB ROUTINE

|      |                |           | •                                     |
|------|----------------|-----------|---------------------------------------|
| 2300 | 3A,10,20       | LDA 2010  | $(A) \leftarrow \simeq_{f}$           |
| 2303 | 6 F            | MOVL,A    | (L) ~~                                |
| 2304 | 3E,00          | MVI A,00  | (A) <- 00                             |
| 2306 | 67             | MOV H,A   | (H) ← 00                              |
| 2307 | EB             | XCHG      | (HL) ← (DE)                           |
| 2308 | 3A,55,25       | LDA 2555  | (A) ← equivalent l <sup>O</sup> count |
| 230B | 21,00,00       | LXIH,0000 | Set product in (HL)=00                |
| 230E | 0E,08          | MVI C,08  | Set Count in C=08                     |
| 2310 | 29 <u>LOOP</u> | DAD H     | (HL) < (HL) + (HL)                    |

| 2311 | 17              | RAL       | Rotate ACC. left                         |
|------|-----------------|-----------|------------------------------------------|
| 2312 | D2,16,23        | JNC AHEAD | Is multiplication is over go ahead       |
| 2315 | 19              | DAD D     | (HL) ← (HL) + (DE)                       |
| 2316 | 0D <u>AHEAD</u> | DCR C     | (C) 🛩 (08) - 1                           |
| 2317 | C2,10,23        | JNZ LOOP  | Is C=00,No jump to loop                  |
| 231A | 22,02,20        | SHLD 2002 | Store $\propto_{count}$ at 2002 and 2003 |
| 231D | C9              | RETURN    |                                          |

# CLOSED LOOP INITIALIZATION OF VARIABLES

• .

| 2900 | 3E,00    | MVI | A,00                    | A ← 00                           |
|------|----------|-----|-------------------------|----------------------------------|
| 2902 | 32,88,23 | STA | CCE                     | (A) ← CCE address                |
| 2905 | 32,80,23 | STA | e <sub>n</sub> add      | $e_n + 238C$                     |
| 2908 | 32,8D,23 | STA | e <sub>n-1</sub>        | e <sub>n-1</sub> ← 238D          |
| 290B | 32,8E,23 | STA | e <sub>n</sub> add      | e <sub>n</sub> ← 238E            |
| 290E | 32,9A,23 | STA | e <sub>n-l</sub> add    | e <sub>n-1</sub> -239A           |
| 2911 | 3E,10    | MVI | A,I <sub>dc</sub> max   | Max.error = 10% of rated current |
| 2913 | 32,89,23 | STA | 2389                    |                                  |
| 2916 | 3A,0F,20 | LDA | V* <sub>dc</sub> add    |                                  |
| 2919 | 32,8A,23 | STA | V* (n) add              | a                                |
| 291C | 32,8B,23 | STA | V*dc(n-1)ad             | dd                               |
| 291F | 3E,01    | MVI | A,K <sub>p</sub>        |                                  |
| 2921 | 32,8F,23 | STA | 238F                    | Store proportional               |
| 2924 | 3E,01    | MVI | A,KI <sup>T</sup> S     | controller constant              |
| 292C | 32,90,23 | STA | 2390                    |                                  |
| 2929 | 3E,FF    | MVI | A + V <sub>dc</sub> (ma | x)                               |
|      |          |     |                         |                                  |

| 292B | 32,93,23 | STA 2393                         |
|------|----------|----------------------------------|
| 292E | 3E,78    | MVI A,+ I <sub>dc</sub> (max)    |
| 2930 | 32,A6,23 | STA 23A6                         |
| 2933 | 21,00,24 | LXIH,2400 'm' pointer address    |
| 2936 | 22,11,20 | SHLD,2011                        |
| 2939 | 3E,55    | MVI A,55 $1^{\circ} = 55$ counts |
| 293B | 32,55,25 | STA 2555                         |
| 293E | C9       | RETURN                           |

1

٠,

.

# CONSTRAINT CURRENT ERROR SR

|   | 2A70       | 3A,87,23     |     | LDA I* (n)add<br>dc           | Load with reference current address.             |
|---|------------|--------------|-----|-------------------------------|--------------------------------------------------|
|   | 2A73       | 21,85,23     | •   | LXIH, I <sub>dc</sub> (n)add  | HL has I <sub>dc</sub> (n) address               |
|   | 2A76       | BE           |     | CMP M                         |                                                  |
|   | 2A77       | DA,86,2A     |     | JC LP1                        | I* <sub>dc</sub> < I <sub>dc</sub> the jump LP1, |
|   | 2A7A       | 96           |     | SUB M                         | $(A) \leftarrow (A) - (M)$                       |
|   | 2A7B<br>2A | 21,89,23     |     | LXIH,Max.add                  | I<br>dc max.add.at 2389                          |
|   | 2A<br>2A7E | BE           |     | CMP M                         |                                                  |
| • | 2A7F       | <br>DA,95,2A | ·   | JC STORE                      | I                                                |
|   | 2A82       | 7E           |     | MOV A,M                       | (A)←I <sub>dc</sub> (max)                        |
|   | 2A83       | C3,95,2A     |     | JMP STORE                     |                                                  |
|   | 2A86       | 7E           | LPl | MOV A,M                       |                                                  |
|   | 2A87       | 21,87,23     |     | LXIH, I* <sub>dc</sub> (n)add | 3                                                |
|   | 2A8A       | 96           |     | SUB M                         | (A) ← (A)-(M)                                    |
|   | 2A8B       | 21,89,23     |     | LXIH,Max.add                  | I <sub>dc</sub> max.add.is in HL pair            |
|   | 2A8E       | BE           |     | СМР М                         |                                                  |
|   | 2A8F       | DA,93,2A     |     | JC LP2                        | · · ·                                            |
|   |            |              |     |                               |                                                  |

E\_10

| 2A92   | 7E                    | MOV A,M    | (A) ← I <sub>dc</sub> (max.) |
|--------|-----------------------|------------|------------------------------|
| 2A93   | 2F <u>LP2</u>         | CMA        | Complement accum-<br>ulator  |
| 2A94 . | 3C                    | INR A      | Increment Acc.               |
| 2A95   | 32,88,23 <u>STORE</u> | STA C.C.E. |                              |
| 2A98   | C9                    | RETURN     |                              |

¢

# PI CONTROLLER SUBROUTINE

| 2B30 | 3A,8A,23   | LDA V*dc <sup>(n)</sup>                | A V* (n) add.                       |
|------|------------|----------------------------------------|-------------------------------------|
| 2B33 | 32,88,23   | STA V* <sub>dc</sub> (n-1)             | V*dc=V*dc(n-1)                      |
| 2B36 | 3A,8C,23   | LDA e <sub>n</sub> add.                | ·<br>·                              |
| 2B39 | 32,8D,23   | STA e <sub>n</sub> add.                |                                     |
| 2B3C | 47         | MOV B,A                                |                                     |
| 2B3D | 3A,88,23   | LDA CCE add.                           | Load CCE add.from<br>CCE Subroutine |
| 2B40 | 32,8C,23   | STA $e_n$ add.                         |                                     |
| 2843 | 90         | SUB B                                  | $\Delta e_n = e_n - e_{n-1}$        |
| 2B44 | 32,8E,23   | STA e <sub>n</sub> add.                |                                     |
| 2B47 | 47         | MOV B,A                                | $B \leftarrow \Delta e_n$           |
| 2B48 | 3A,8F,23   | LDA K <sub>p</sub> add.                | $A \leftarrow K_p$                  |
| 2B4B | 6 <b>F</b> | MOV L,A                                | $L \leftarrow K_p$ add.             |
| 2B4C | CD, A02A   | CALL SMULT                             |                                     |
| 2B4F | 22,91,23   | SHLD PR RESULT                         | Store the partial result at 2391.   |
| 2852 | 3A,8C,23   | LDA e <sub>n</sub> add.                |                                     |
| 2855 | 47         | MOV B,A                                |                                     |
| 2B56 | 3A,90,23   | LDA K <sub>I</sub> T <sub>S</sub> add. | A ← K <sub>I</sub> T <sub>S</sub>   |
| 2B59 | 6 F        | MOV L,A                                | L ← K <sub>I</sub> T <sub>S</sub>   |

| 2B5A<br>2B5D | CD,A0,2A<br>EB | CALL SMULT<br>XCHG           | (DE) ← (HL)                                       |
|--------------|----------------|------------------------------|---------------------------------------------------|
| 2B5E         | 2A,91,23       | LHLD PR RESULT               | Store PR Result at<br>2391                        |
| 2B61         | 19             | DAD D                        | $K_{p} \Delta e_{n} + K_{I} T_{S} = V *_{dc} (n)$ |
| 2B62         | EB             | XCHG                         | (DE) ← (HL)                                       |
| 2B63         | 32,8B,23       | LDA V* <sub>dc</sub> (n-1)ad | ld.                                               |
| 2B66         | 6F             | MOV L,A                      | (L) ← (A)                                         |
| 2B67         | 26,00          | MVIH,00                      | (H) ← (00)                                        |
| 2B69         | 19             | DAD D                        | $HL \leftarrow (HL) + (DE)$                       |
| 2B6A         | 22,91,23       | SHLD V* <sub>dc</sub> (n)ad  | đ                                                 |
| 2B6D         | C9             | RETURN                       |                                                   |

.

# SMULT SUBROUTINE

| 2AA0 | 26,00          | MVIH,00  | Clear MS Byte of<br>product                          |
|------|----------------|----------|------------------------------------------------------|
| 2AA2 | 0E,08          | MVI C,08 | Set Counter in<br>register C = 08                    |
| 2AA4 | AF             | XRA A    | Clear accumulator<br>set X <sub>i</sub> =0           |
| 2AA5 |                | MOV A,L  |                                                      |
| 2AA6 | DA, B2, 2A LP1 | JC LOOP2 | Check X <sub>i-1</sub>                               |
| 2AA9 | 0 <b>F</b>     | RRC      | Rotate right 'A'<br>with carry X <sub>i-1</sub> =0.  |
| 2AAA | 7C             | MOV A,H  | A ← H                                                |
| 2AAB | D2,B8,2A       | JNC LP3  | Check X                                              |
| 2AAE | 90             | SUB B    | $(A) \leftarrow (H) - (B)$                           |
| 2AAF | C3,B8,2A       | JMP LP3  |                                                      |
| 2AB2 | OF LP2         | RRC      | X <sub>i-l</sub> =l place X <sub>i</sub><br>in carry |
| 2AB3 | 7C             | MOV A,H  | Move partial product in ACC.                         |

| 2AB4 | DA, B8, 2A    | JC LP3  | Check X <sub>i</sub>      |
|------|---------------|---------|---------------------------|
| 2AB7 | 80            | ADD B   | (A) ← (H)+(B)             |
| 2AB8 | 67 <u>LP3</u> | MOV H,A | (H) < (A)                 |
| 2AB9 | 17            | RAL     |                           |
| 2ABA | 7C            | MOV A,H | Load MSB of PP            |
| 2ABB | lF            | RAR     | Arithmatic right<br>shift |
| 2ABC | 67            | MOV H,A | Save Shifted MSB          |
| 2ABD | 7D            | MOV A,L | Load LSB of PP            |
| 2ABE | lF            | RAR     | Arithmatic right<br>shift |
| 2ABF | 6F            | MOV L,A | Save shifted LSB          |
| 2AC0 | 0 D           | DCR C   | Check for completion      |
| 2AC1 | C2,A6,2A      | JNZ LP1 |                           |
| 2AC4 | C9            | RETURN  |                           |

CONSTRAINED V\* (n) SUBROUTINE

.

1

|    | 2B70          | 2A,91,23      | LHLD V* <sub>dc</sub> (n) ad | ld                              |
|----|---------------|---------------|------------------------------|---------------------------------|
|    | 2B73          | 44            | MOV B,H                      | (HL) < (BC)                     |
| J. | 2B74          | 4D            | MOV C,L                      | · · ·                           |
|    | 2B75          | 3A, 93,23     | LDA V <sub>dc</sub> (max.)   |                                 |
|    | 2В78          | 57            | MOV D,A                      | $D \leftarrow V_{dc}(max) add.$ |
|    | 2B <b>7</b> 9 | 29            | DAD H                        | (HL) - (HL)+(HL)                |
|    | 2B7A          | DA,92,2B      | JC LP1                       | If V* is -ve<br>jump to LP1.    |
|    | 2B7D          | 78 <u>LP3</u> | MOV A,B                      |                                 |
|    | 2B7E          | в7            | ORA A                        | Is MSB of $V_{dc}^{*}=00$       |
|    | 2B7F          | CA,85,2A      | JZ LP2                       | Yes,go to LP2.                  |
|    | 2B82          | C3,8A,2B LP4  | JMP Prestore                 | · · ·                           |
|    |               |               |                              |                                 |

E-13

|   |              |                       |                            | E-14                                     |
|---|--------------|-----------------------|----------------------------|------------------------------------------|
|   | -            |                       |                            | · · · · · · · · · · · · · · · · · · ·    |
|   | 2885         | 79                    | NOT D O                    |                                          |
|   |              |                       | MOV A,C                    | MSB of $V^*_{dc}=00$                     |
|   | 2886         | BA                    | CMP D                      | Is LSB > max.value                       |
|   | 2887         | DA,8B,2B              | JC Store                   | Yes, Jump to Store                       |
|   | 2B8A         | 7A <u>PRE STORE</u>   | MOV A,D                    | •                                        |
|   | 2B8B         | 32,8A,23 <u>STORE</u> | STA V* <sub>dc</sub> (n)   |                                          |
|   | · 2B8E       | CD,40,28              | CALL V* dc add             |                                          |
|   | 2891         | C9                    | RETURN                     |                                          |
|   | 2B <b>92</b> | 3E,00                 | MVI A,00                   | Set $V_{dc}^{*}=00$ and                  |
| · | 2B94         | C3,8B,2B              | JMP STORE                  | Jump to store it.                        |
|   | , ·          |                       |                            |                                          |
|   |              | V*<br>dc              | (n) <u>SUBROUTINE</u>      |                                          |
|   | 2840         | 3A,8B,23              | LDA V <sub>dn-l</sub> add. |                                          |
|   | 2843         | 57                    | MOV D,A                    |                                          |
|   | 2844         | 3A,8A,23              | LDA                        | V <sub>dn</sub> add                      |
|   | 2847         | BA                    | CMP D                      | un                                       |
|   | 2848         | DA,60,28              | JC LP1                     | V <sub>dn</sub> <v<sub>dn-1, yes</v<sub> |
|   |              |                       |                            | Jump to loopl.                           |
|   | 284B         | CA,60,28              | JZ LP1                     | V <sub>dn</sub> =V <sub>dn-1</sub>       |
|   |              | •<br>• •              | -                          | Jump to LP1.                             |
|   | 284E         | 92                    | SUB D                      | $v_{dn} - v_{dn-1} = v_{dn}$             |
|   | 284F         | FE,05                 | CPI 05                     |                                          |
|   | 2851         | DA,78,28              | JC LP2                     | V <sub>dn</sub> <05,Jump to LP2          |
|   | 2854         | CA,78,28              | JZ LP2                     | V <sub>dn</sub> =05 Jump to LP2          |
|   | 2857         | 3A,8B,23              | LDA V <sub>dn-l</sub> add. | · · ·                                    |
|   | 285A         | C6,05                 | an-1<br>ADI 05 、           |                                          |
|   | 285C         | 32,8A,23 <u>STORE</u> | STA V <sub>dn</sub> add.   |                                          |
|   | 285F         |                       | an<br>RETURN               | х.                                       |
|   |              | ·                     |                            |                                          |
|   |              |                       |                            |                                          |

| 2860 | 3A,8A,23 | LPl | LDA V <sub>dn</sub> add.   |                                                        |
|------|----------|-----|----------------------------|--------------------------------------------------------|
| 2863 | 57       |     | MOV D,A                    |                                                        |
| 2864 | 3A,8B,23 |     | LDA V <sub>dn-l</sub> add. | ·                                                      |
| 2867 | 92       |     | SUB D                      | V <sub>dn-1</sub> - V <sub>dn</sub> = △V <sub>dn</sub> |
| 2868 | FE,05    | · • | CPI 05                     |                                                        |
| 286A | DA,78,28 |     | JC LP2                     | $\Delta V_{dn}^{<05,Jump}$ to LP2                      |
| 286D | CA,78,28 |     | JZ LP2                     | $\Delta V_{dn} = 05$ Jump to LP2                       |
| 2870 | 3A,8B,23 |     | LDA V <sub>dn-l</sub> add. |                                                        |
| 2873 | D6,05    |     | SUI 05                     |                                                        |
| 2875 | C3,5C,28 | ,   | JMP STORE                  |                                                        |
| 2878 | 3A,8A,23 | LP2 | LDA V <sub>dn</sub> add.   |                                                        |
| 287B | C3,5C,28 |     | JMP STORE                  |                                                        |

## LOOK UP SUBROUTINE

2A,11,20 LHLD M POINTER ADD. 2BA0 BE 2BA3 LPl CMPM V<sub>dc</sub><V<sub>dc</sub>(n-1) If. JC LP2 2BA4 DA,AE,2B Jumpt to Loop2. JZ LP3 A=M, Jumpt to LP3. 2BA7 CA,B3,2B DCX H  $(HL) \leftarrow (HL)-1$ 2BAA 2B 2BAB C3,A3,2B JMP LP1 23 INX H  $(HL) \leftarrow (HL)+1$ 2BAE LP22BAF ΒE CMP M JC LP2 A<M Jump to LP2 2BB0 DA,AE,2B

| 2BB3 | 22,11,20 LP3 | SHLD M POINTER | ADD.             |
|------|--------------|----------------|------------------|
| 2886 | 11,60,00     | LXID,0060      | (DE) ← 0060      |
| 2889 | 19           | DAD D          | (HL) < (HL)+(DE) |
| 2BBA | 7E           | MOV A,M        | (A) ← (M)        |
| 2BBB | C9           | RETURN         |                  |

# # # # # # #

2

#### APPENDIX - E

#### MICROPROCESSOR AND ITS PERIPHERALS

The complete control scheme for the Adaptive Controller fed d.c. drive has been developed using personal computer (PC) and microprocessor 8085A system. An 8085A is 8 bit INTEL's most popular microprocessor system. In this system, the programmable interrupt controller (PIC) 8259A programmable interval timer (PPI) 8253, and the programmable peripheral interface (PPI) 8255A are interfaced.

Peripherals are used to facilitate parallel data transfer between microprocessor and input output devices. These devices can act as input port which is tristated buffer to read data from inputting devices. They can act as output port to latch data sent by the microprocessor for output These devices can generate an interrupt signal and device. receive/transmit certain control signals for data communication between microprocessor and input output devices.

The 8255Ais a programmable peripheral interface (PPI). It can be programmed to transfer data under various conditions. It has 24 I/O pins, that can be grouped primarily into 8 bit parallel ports, port A, Port B, and remaining 8 bits as port C. Eight bits of port C can be used individually or be grouped in two 4 bit ports. Port C upper

 $(PC_{11})$  and port C lower  $(PC_{11})$ . The functions of these ports are defined by writing a control word in control word register, format of which is shown in Fig. B-1. Functions of > the 8255A are classified according to two modes: the Bit set/Reset (BSR) mode and the I/O mode. The BSR mode is to set or reset the bits of port C. The I/O mode is further divided into three modes: Mode 0, Mode 1, and Mode 2. 1n mode 0 all ports function as simple input output ports. In Mode 1 port A and/or port B use bits from port C as handshaking signals that is why this mode is named as hand-shake mode. handshake mode, In two types of input/output data transfer can be implemented: status check interrupt. Mode 2, port A and In can be set for bydirectional data transfer using hand-shake signals from port C, and port B can be set up either in Mode 'O' or in Mode '1'.

The 8253 programmable interval timer (PIT) is a support chip to the system. The 8253 includes three identical 16 bit counters that can operate independently in any one of the six modes. Each counter has two input signals CLOCK and GATE and one output signal OUT. The clock input pin is connected to a clock of suitable frequency. To operate a counter, a 16 bit count to be loaded in its register and depending upon the additional formation of the timer, logic high voltage or low to high voltage transition at GATE initiates or enables counting process. The

F-2

different six modes of operation are Mode 0 - interrupt on terminal count, Mode 1 - programmable monoshot, Mode 2 - rate generator or devide by counter, Mode 3 - square wave generater, Mode 4 - software triggered strobe, Mode 5 - Hardware triggered strobe. The control word format of 8253 is shown in Fig. B-2.

The 8259A is a programmable interrupt controller (PIC) designed to work with INTEL microprocessor 8080A, 8085A, 8086 and 8088. The 8259A can manage eight interrupts according to the instructions written into its control word registers. This is equivalent to providing eight interrupt pins on the processor in place of INTER/INT Pin. It can vector an interrupt request anywhere in the memory map. However, all eight interrupts are spaced at the interval of either eight or four locations. It can resolve eight levels of interrupt priorities as a variety of modes, such as fully nested mode, automatic rotation mode and specific rotation mode. It can mask each interrupt request individually. The 8259A can read status of in-service interrupts pending, and masked interrupts. It can accept either the level-triggered or the edge-triggered interrupt request. It can be expanded to 64 priority levels by cascading additional 8259's. To implement interrupts, interrupt enable the flip flop in the microprocessor should be enabled by writing EI instruction and the 8259 should be initialized by writing control words in control word register. The 8259 requires the two types of

F-3

control words: Initialization command words (ICWS) and operation command words (OCWS). The 8259 can be initialized with four ICWS; the first two are essential, and the other two are optional. Based on the modes being used, these words must be issued in a given sequence. Once initialized, the 8259 can be setup to operate in various modes by using three different OCWS; however, they no longer need to be issued in a specific sequences.

1 []

\_ A XDULLA

F-4

different six modes of operation are Mode 0 - interrupt on terminal count, Mode 1 - programmable monoshot, Mode 2 - rate generator or devide by counter, Mode 3 - square wave generater, Mode 4 - software triggered strobe, Mode 5 - Hardware triggered strobe. The control word format of 8253 is shown in Fig. B-2.

The 8259A is a programmable interrupt controller (PIC) designed to work with INTEL microprocessor 8080A, 8085A, 8086 and 8088. The 8259A can manage eight interrupts according to the instructions written into its control word registers. This is equivalent to providing eight interrupt pins on the processor in place of INTER/INT Pin. It can vector an interrupt request anywhere in the memory map. However, all eight interrupts are spaced at the interval of either eight or four locations. It can resolve eight levels of interrupt priorities as a variety of modes, such as fully nested mode, automatic rotation mode and specific rotation mode. It can mask each interrupt request individually. The 8259A can read pending, in-service interrupts and masked status of It can accept either the level-triggered or the interrupts. edge-triggered interrupt request. It can be expanded to 64 priority levels by cascading additional 8259's. To implement interrupts, the interrupt enable flip flop in the microprocessor should be enabled by writing EI instruction and the 8259 should be initialized by writing control words in control word register. The 8259 requires the two types of





Fig. 2 : CONTROL WORD FORMAT OF 8253

control words: Initialization command words (ICWS) and operation command words (OCWS). The 8259 can be initialized with four ICWS; the first two are essential, and the other two are optional. Based on the modes being used, these words must be issued in a given sequence. Once initialized, the 8259 can be setup to operate in various modes by using three different OCWS; however, they no longer need to be issued in a specific sequences.

1 B

\_\_\_\_\_.....