# INTEL 8086 MICROPROCESSOR BASED DIGITAL FILTER REALIZATION

# A DISSERTATION

submitted in partial fulfilment of the requirements for the award of the Degree

of

# MASTER OF ENGINEERING

in

ELECTRICAL ENGINEERING (System Engineering & Operational Research)

SAROJ AMBARDAR

by



DEPARTMENT OF ELECTRICAL ENGINEERING UNIVERSITY OF ROORKEE ROORKEE U.P. (INDIA) August, 1982

# CERTIFICATE

Certified that the dissertation entitled "INTEL 8086 MICROPROCESSOR BASED DIGITAL FILTER REALIZATION" which is being submitted by Ms Saroj Ambardar in partial fulfilment for the award of the degree of MASTER OF ENGINEERING in ELECTRICAL ENGINEERING (System Engineering & Operational Research) of the University of Roorkee, Roorkee, is a record of student's own work carried out by her under my supervision and guidance. The matter embodied in this dissertation has not been submitted for the award of any other degree or diploma.

This is further to certify that she has worked for a period of about 7 months from Jan. 1982 to August 1982 for preparing this dissertation at this University.

asan 14ai 1982

(M. K. VASANTA) Reader Electrical Engineering Department University of Roorkee Dated August 16, 1982 Roorkee

(i)

# ACKNOWLEDGEMENTS

I wish to express my indebtedness and grateful thanks to Shri M. K. Vasanta, of the Department of Electrical Engineering for the invaluable guidance provided by him in carrying out the work contained in these pages. His guidance has been a constant source of encouragement and inspiration throughout the course of this study.

I also thank all those who helped me directly or indirectly in preparing this dissertation.

Saroje Ambardar

(ii)

(SAROJ AMBARDAR)

(iii)

### ABSTRACT

Digital filtering is a major subdivision of Digital signal processing. The practical realizations of a Digital filter have been discussed in this dissertation. To avoid coefficient sensitivity problems, the Z-Transfer function of a Digital filter is implemented as a cascaded or parallel combination of second order modules. Each module in itself can be one of the four Direct structures.

The significant break-through in the area of IC technology have opened up new options for the implementation of Digital filters. The present day research is centred around the microprocessor based design of a Digital filter. Digital filters are now implemented making use of 16-bit word length microprocessors. Intel 8086 has been considered in this dissertation. The Assembly language of 3086 is used to implement all the Digital filter modules. The software programs are given for K'th order Digital filter using N second order modules in cascade. It has also been shown that the same subroutines developed for second order modules can be used for parallel structure implementation.

# CONTENTS

| Chapter |      |                        |       |                                |         |       | Page   | No. |
|---------|------|------------------------|-------|--------------------------------|---------|-------|--------|-----|
| 0       | INTR | ODUCTIC                | N     | • • •                          |         | • • • | 1 –    | 6   |
|         | 0.1  | Histor                 | ical  | Introduction                   |         | • • • | 1      |     |
|         | 0.2  | Outlin                 | e of  | Work                           |         | • • • | 5      |     |
| I .     |      | SFER FU<br>DIGITA      |       | ON AND REALIZ.<br>LTER         | ATIONS  | •••   | 7 -    | 17  |
|         | 1.1  | Introd                 | ucti  | on                             |         | •••   | 7      |     |
|         | 1.2  | Z-Tran                 | sfer  | Function                       |         | • • • | 7      |     |
|         | 1.3  | Filter                 | Rea   | lization Tech                  | niques  | • • • | 10     |     |
|         |      | 1.3-1                  | Dir   | ect form Real:                 | ization | 1     | 10     |     |
|         |      | 1.3-2                  | Cas   | cade form Real                 | lizatio | n     | 14     |     |
|         |      | 1.3-3                  | Par   | allel form Re                  | alizat  | Lon   | 16     |     |
|         | 1.4  | Summar                 | У     |                                |         | • • • | 17     |     |
| ĨĨ      |      | ENT FEA<br>OPROCES     |       | S OF INTEL 80                  | 86      | • • • | 18 -   | 42  |
|         | 2.1  | Introd                 | lucti | on                             |         | • • • | 18     |     |
|         | 2.2  | <b>Salie</b> n<br>8086 | nt Fe | atures of Mic                  | roproc  | essor | · 18   |     |
|         |      | 2.2-1                  | Fun   | ctional Pin D                  | escrip  | tion  | 19     |     |
|         |      | 2,2-2                  | Reg   | ister Organiz                  | ation   | • • • | 24     |     |
|         |      | 2.2-3                  | Mem   | ory Organizat                  | ion     | • • • | 26     |     |
|         |      | 2.2-4                  | Add   | lressing Modes                 |         | •••   | - 29   |     |
|         |      | 2.2-5                  | Ins   | truction set                   |         | • • • | 33     |     |
|         | 2.3  | Summar                 | у     |                                |         | • • • | 42     |     |
| III     |      |                        |       | DIGITAL FILTE<br>URE AS BASICI |         |       | . 43 – | 64  |
|         | 3.1  | Introd                 | lucti | on                             |         | •••   | 43     |     |
|         | 3.2  | Why a                  | Seco  | nd O <b>rde</b> r Moáu         | le      | • • • | 43     |     |

\_\_\_

| 3.3  | Second                                                                               | Order Digital Filter                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 3.3-1                                                                                | Mathematical Derivation                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 3.3-2                                                                                | Algorithm for Implementation                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 46                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 3.3-3                                                                                | Software Program using Intel<br>8086 Instruction Set                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 47                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3.4  |                                                                                      |                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 3.4-1                                                                                | I'th Module                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 51                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 3.4-2                                                                                | Memory Organization                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 51                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 3.4-3                                                                                | Identification of Subroutine                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 53                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 3.4-4                                                                                | Subroutine Thitilization 1D                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 54                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 3.4-5                                                                                | Subrottine Input 1D                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 55                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 3.4-6                                                                                | Subroutine Output 1D                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 57                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 3.4-7                                                                                | Subroutine Delay 1D                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 58                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 3.4-8                                                                                | Subroutine Preprocessing 1D                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 59                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 3.4-9                                                                                | Main Program                                                                                                                                                                                                                                                                                                                               | ٠                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 60                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3.5  |                                                                                      | -                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 61                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3.6  | Summar                                                                               | У                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 64                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      |                                                                                      |                                                                                                                                                                                                                                                                                                                                            | 65                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | - 82                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 4.1  | Introd                                                                               | uction                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 65                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4.2  | 2D Str                                                                               | acture                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 65                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4.3  | 3D Str                                                                               | uctura                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 69                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4•4  | 4D Str                                                                               | ucture                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 73                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4•5  | 1X and                                                                               | 2X Structure                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 76                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4.6  | Summar                                                                               | y                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 82                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| CONC | LUSIONS                                                                              | & SUGGESTIONS FOR FURTHER WORK                                                                                                                                                                                                                                                                                                             | 83                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | - 85                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| REFE | RENCES                                                                               |                                                                                                                                                                                                                                                                                                                                            | 86                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | - 90                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| APPE | NDICES                                                                               | (I to V)                                                                                                                                                                                                                                                                                                                                   | 91                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | - 128                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|      | 3.4<br>3.5<br>3.6<br>IMPLI<br>4.1<br>4.2<br>4.3<br>4.4<br>4.5<br>4.6<br>CONC<br>REFE | 3.3-1<br>3.3-2<br>3.3-3<br>3.4 Cascade<br>Second<br>3.4-1<br>3.4-2<br>3.4-3<br>3.4-3<br>3.4-4<br>3.4-5<br>3.4-6<br>3.4-7<br>3.4-6<br>3.4-7<br>3.4-8<br>3.4-9<br>3.5 Parall<br>Order<br>3.6 Summary<br>IMPLEMENTATY<br>DIGITAL FILM<br>4.1 Introdu<br>4.2 2D Structure<br>4.3 3D Structure<br>4.4 4D Structure<br>4.5 1X and<br>4.6 Summary | <ul> <li>SOBE Instruction Set</li> <li>3.4 Cascade Structure of K'th order Filter - N<br/>Second Order 1D Modules in Cascade</li> <li>3.4-1 I'th Module</li> <li>3.4-2 Memory Organization</li> <li>3.4-3 Identification of Subroutine</li> <li>3.4-3 Identification of Subroutine</li> <li>3.4-4 SubroutineTwitilization 1D</li> <li>3.4-5 Subroutine Input 1D</li> <li>3.4-6 Subroutine Output 1D</li> <li>3.4-7 Subroutine Preprocessing 1D</li> <li>3.4-8 Subroutine Preprocessing 1D</li> <li>3.4-9 Main Program</li> </ul> 3.5 Parallel Implementation of K'th<br>Order Digital Filter 3.6 Summary IMPLEMENTATION OF SECOND ORDER<br>DIGITAL FILTER THROUGH OTHER STRUCTURES 4.1 Introduction 4.2 2D Structure 4.3 3D Structure 4.4 4D Structure 4.5 1X and 2X Structure 4.6 Summary CONCLUSIONS & SUGGESTIONS FOR FURTHER WORK | <ul> <li>3.3-1 Nathematical Derivation</li> <li>3.3-1 Nathematical Derivation</li> <li>3.3-2 Algorithm for Implementation</li> <li>3.3-2 Algorithm for Implementation</li> <li>3.3-2 Algorithm for Implementation</li> <li>3.3-2 Algorithm for Implementation</li> <li>3.3-3 Software Program using Intel<br/>8086 Instruction Set</li> <li>3.4 Cascade Structure of K'th order Filter - N<br/>Second Order 1D Modules in Cascade</li> <li>3.4-1 I'th Module</li> <li>3.4-2 Memory Organization</li> <li>3.4-2 Memory Organization</li> <li>3.4-3 Identification of Subroutine</li> <li>3.4-4 SubroutineTMitlization 1D</li> <li>3.4-5 Subroutine Input 1D</li> <li>3.4-6 Subroutine Output 1D</li> <li>3.4-7 Subroytine Dalay 1D</li> <li>3.4-8 Subroutine Prepro cessing 1D</li> <li>3.4-9 Main Program</li> </ul> 3.5 Parallel Implementation of K'th<br>Order Digital Filter 3.6 Summary IMPLEMENTATION OF SECOND ORDER INFIGURAL FILTER THROUGH OTHER STRUCTURES 4.1 Introduction 4.2 2D Structure 4.3 3D Structures 4.5 1X and 2X Structure 4.6 Summary CONCLUSIONS & SUGGESTIONS FOR FURTHER WORK 83 REFERENCES |

IV

V

#### CHAPTER - O

# INTRODUCTION

# 0.1 HISTORICAL INTRODUCTION

As man becomes more certain of his control of physical things, an ever more important part of his work is the manipulation of symbols he uses to describe and control these physical things. The field of waveform manipulation or signal processing as in radio, radar, sonar, seismology etc., is one of the keystones of science and technology. The techniques and applications of this field are as old as Newton and Gauss and as new as digital computer and intograted circuits.

During the decade of 1960-70, it became practical to represent information-bearing waveforms digitally and to do signal processing on the digital representation of the waveform. The availability of high speed digital computers fostered the development of increasingly complex and sophisticated signal processing algorithms. The significant break through in the area of integrated circuit technology promise occonomical implementations of very complex digital signal processing systems.

Fig. (0.1) illustrates one view of how the field has emerged and spread out. Digital filtering is one of the major subdivisions of Digital signal processing. Digital filtering processing algorithms have been used primarily in



; ; ;

------

į

| |

ļ

; ;

ţ

computer simulation, sampled data analysis and data reduction computations. With the increasing extensive application of digital processors to many systems, more and more importance is place on the development of mathematical tools for its analysic and dosign. The 'Z-transform' result in considerable simplification and understanding. The work of Kaiser, the first major contribution to the field of Digital signal processing, showed how much of the well. developed theory of the design of filters made of resistors, capacitors and inductors could be translated, with the aid of the Z-transform into straightforward digital filter techniques. At about the same time tremendous impetus was given to this emerging field by the Cooley-Tukey (1965) paper on a fast method of computing the discrete Fourier transform, a method that was subsequently popularized and extended via. many papers in the IEEE Transactions of the Group on Audio and Electroacoustics and other journals. At this time. the development of a formal and quite comprehensive theory of digital filters was well under way.

Perhaps the most interesting aspect of the development of the field of Digital signal processing is the changing relationship between the roles of FIR (finite impulse response) and IIR (infinite impulse response) digital filters. Initially Kaiser analysed FIR filters

using window functions, which indicated that IIR filters were more efficient than FIR filters. However, Stockham's work on the FFT method of performing convolution, or more specifically FIR digital filtering, indicated that implementation of high-order FIR filters could be made extremely computationally efficient; thus comparisons between FIR and IIR filters are no longer strongly biased towards the latter. These results also inspired significant research for efficient design for FIR filters.

The Digital filter implementation till now was confined primarily to computer programs for simulation work or for processing relatively small amounts of data. However, with the rapid development of integrated circuit technology and especially the potential for large-scale-integration (LSI) of digital circuits made many of the Digital filters more attractive from the standpoint of cost, size and  $e \times theme$ reliability.

The design of high space multipliers was of prime concern to many hardware and software implementations of signal processing algorithms. Standard TTL components gave sufficient speed to allow an effective filter to be implemented. Integrated circuits such as the Advanced Micro Devices AM25 LS14 2's complement multiplier was introduced specifically for signal processing applications. Peled and Liu

used semiconductor memories for the purpose of fast multiplication, and resulted in significant saving in the cost and power consumption.

The Digit filter may be regarded as a special purpose computer built from an 'off-the shelf' logic family. The design depends upon the sampling rate and flexibility required. For simple sections a special purpose hardwork filter will be more efficient than a general purpose microprocessor. Instruction sets allow greater flexibility. The suitable microprocessor selected depends upon the particular application. Digital filters for different purposes have been implemented making use of 8 bit, 16 bit microprocessors Much credit here goes to Nagle & Nelson.For most applications 16-bit accuracy is sufficient to avoid qualization problems with filtors of moderate order  $(n \leq 10)$ . It has been seen that with Intel 8086 (and other 16 bit microprocessors presently available) a significant improvement over the sampling rates can be achieved as compared with the previous generation of microprocessors, without significant increase in system cost.

### 0.2 OUTLINE OF THE PRESENT WORK

Chapter I discusses the general Transfer function and the various techniques for realizing a Digital filter.

Four Direct structures have been derived and it is in one of these structures that a Digital filter is usually implemented.

The salient features of Intel 8086 microprocessor which is selected for our purpose has been carried out in considerable detail in Chapter II. 8086 microprocessor is a totally new design, than any microprocessor previous offered by the Intel group and has a powerful set of instructions. Memory to memory string operations, hardwired multiplication and division, and flexible addressing modes are some of the significant operations.

Referring to Kaiser's work a second order structure is best suited for implementing higher order filters. Chapter III presents the implementation of a second order 1D module. A flow chart and a main program in 8086 Assembly language and the various subroutines with explanations is given. A K'th order cascaded filter has been discussed. Also a 4th order parallel filter has been given as an example. Use of 1D second order module subroutine is made in the programs:

Chapter IV discusses the other types of structures used for realization of Digital filters. The sequence of study here is the derivation of the necessary equations, algorithm and the flow chart programs in 8086 Assembly

language. A second order module is considered in each of the five cases viz. 2D, 3D, 4D, 1X, 2X.

The dissertation concludes with the summary of the work done alongwith suggestions for future study and development.

#### CHAPTER - I

TRANSFER FUNCTION AND REALIZATIONS OF A DIGITAL FILTER

#### 1.1 INTRODUCTION

A major subdivision of Digital Signal Processing is Digital filtering - a computational algorithm performed on a sampled input signal resulting in a transformed output signal. Digital filtering processing algorithms have been used in computer simulation, sampled data analysis and data reduction computations. Kaiser <sup>6</sup> shows that the Z-Transform results in considerable simplification and understanding of problems associated with sampled data system. In this chapter the Transfor function of a Digital filter and its pictorial representations are discussed. Also, the various types of realizations of a Digital filter are studied.

# 1.2 Z-TRANSFER FUNCTION

In Linear continuous (Analog) filter theory, linear differential equation is one of the mathematical tools available to describe the Transfer function. Similarly, in linear Digital (Sampled) filter theory the linear difference equation is available as a mathematical tool for analysis and synthesis.

The linear difference equation <sup>7</sup> defines the sampled output pulse amplitude as a function of the present input pulse and any number of past input and output pulses. A

general form of the difference equation is

$$Y(nT) = \sum_{i=0}^{N} A_i \cdot X(nT - iT) - \sum_{i=1}^{N} B_i \cdot Y(nT - iT) \dots (1.1)$$

where X(nT) represents the present input samples and X(iT) are the past input samples. Similarly, Y(nT) and Y(iT) are present output samples and past output samples respectively. A<sub>i</sub> and B<sub>i</sub> coefficients are constants which determine the response of the filter.

The Z-Transform  $^{1,3,5,7}$  of the above mentioned general difference equation (1.1) is :

$$Y(z) = X(z) \cdot \sum_{i=0}^{N} A_{i} \cdot Z^{-i} - Y(z) \cdot \sum_{i=0}^{M} B_{i} \cdot Z^{-i} \dots (1.2)$$

This equation is interpreted as : the present output is dependent on the present and past inputs, each multiplied by the respective coefficients  $A_i$  and the past output each multiplied by the respective coefficient  $B_i$ . Equation (1.2) is represented in the Transfer function form as :

$$D(z) = \frac{Y(z)}{X(z)} = \frac{\frac{Y(z)}{X(z)}}{\frac{1}{z}} = \frac{\frac{1}{1} \sum_{i=0}^{N} A_i \cdot z^{-i}}{\frac{1}{1} + \sum_{i=1}^{N} B_i \cdot z^{-i}} \dots (1.3)$$

Equation (1.3) is the Transfer function representation of a Recursive type of Digital filters. Appendix-I gives the classification of Digital filters.

In order to represent Digital filters in the form of a block diagram, the purpose of which is to graphically depict the way in which a particular system is realized, the terminology 4,8 shown in Fig. (1.1) is recommended.

# A first order difference equation is :

 $Y(nT) = A_0 \cdot X(nT) + A_1 \cdot X(nT - T) - B_1 \cdot Y(nT - T) \dots (1.4)$ Z-transform of equation (1.4) is :

$$Y(z) = A_0 \cdot X(z) + A_1 \cdot z^{-1} \cdot X(z) - B_1 \cdot z^{-1} \cdot Y(z)$$
 (1.5)

hence,

$$D(z) = \frac{Y(z)}{X(z)} = \frac{A_0 + A_1 \cdot Z^{-1}}{1 + B_1 \cdot Z^{-1}} \qquad \dots \qquad (1.6)$$

A second order difference equation is represented as :  $Y(nT) = A_0 \cdot X(nT) + A_1 \cdot X(nT-T) + A_2 \cdot X(nT - 2T)$  $= B_1 \cdot Y(nT-T) - B_2 \cdot Y(nT - T) \dots (1:7)$ 

Z-transform of equation (1.7) is :

$$Y(z) = A_0 \cdot X(z) + A_1 \cdot z^{-1} \cdot X(z) + A_2 \cdot z^{-2} \cdot X(z) - B_1 \cdot z^{-1} \cdot Y(z) - B_2 \cdot z^{-2} \cdot Y(z) \qquad \dots \qquad (1.8)$$

hence,

$$D(z) = \frac{Y(z)}{X(z)} = \frac{A_0 + A_1 \cdot Z^{-1} + A_2 \cdot Z^{-2}}{1 + B_1 \cdot Z^{-1} + B_2 \cdot Z^{-2}} \dots (1.9)$$

Fig. (1.2) represents the block diagram representation of the above derived general first and second order Digital transfer functions of equations (1.6) and (1.9) respectively.









# 1.3 FILTER REALIZATION TECHNIQUES

This section gives the signal flow diagrams for Digital filter Transfer function in terms of the Digital filter elements namely, the adder, multiplier and the delay. These diagrams are known as realization structures <sup>4,5,8</sup> because it is in one of these forms that the practical realization is usually carried out. These different structures are classified into canonic and non-canonic realizations. By the term canonic realization <sup>2,9</sup> it is meant that the number of delay elements employed is precisely equal to the order of Transfer function (i.e. the highest degree between the numerator and denominator polynomials). The realization tochniques include the following forms :

(1) Direct form (a) Direct form (canonical)
(b) Direct form (non-canonical)

(2) Cascade or Series Canonic form

(3) Parallel Canonic form

# 1.3-1 <u>DIRECT FORM REALIZATION</u>

This form includes all those Digital filters in which the real coefficients  $A_i$  and  $B_i$  of equation (1.3) appear as multipliers in the block diagram implementation. The following sections describe four types of direct structures.

# 1.3 - 1.1 FIRST DIRECT STRUCTURE (1D)

From equation (1.3)

$$D(z) = \frac{\sum_{i=0}^{N} A_i \cdot Z^{-i}}{\sum_{i=0}^{N} B_i \cdot Z^{-i}} \dots \dots (1.10)$$

where,  $B_0 = 1$  and  $M = N \star$ 

Introducing intermediate variable M(z) $D(z) = \frac{Y(z)}{X(z)} = \frac{Y(z)}{M(z)} \cdot \frac{M(z)}{X(z)} = \frac{\sum_{i=0}^{N} A_i \cdot Z^{-i}}{\sum_{i=0}^{N} B_i \cdot Z^{-i}} \dots (1.11)$ 

Equating numerator and denominator separately

$$\frac{Y(z)}{M(z)} = \sum_{i=0}^{N} A_i \cdot Z^{-i} \quad \text{and} \quad \frac{X(z)}{M(z)} = \sum_{i=0}^{N} B_i \cdot Z^{-i} \quad \dots \quad (1.12)$$

$$Y(z) = \sum_{\substack{i=0\\N}}^{N} A_i \cdot Z^{-i} \cdot (M(z)) \dots \dots (1.13)$$

$$X(z) = \sum_{i=0}^{N} B_{i} \cdot Z^{-i} \cdot M(z)$$
 ... (1.14)

or 
$$M(z) = X(z) - \sum_{i=1}^{N} B_i \cdot Z^{-i} \cdot M(z)$$
 ... (1.15)

In the time domain equations (1.15) and (1.13) become

$$m(k) = x(k) - \sum_{i=1}^{N} B_{i}.m(k-i)$$
 ... (1.16)

$$y(k) = \sum_{i=0}^{N} A_{i} \cdot m(k-i)$$
 ... (1.17)

Equations (1.16) and (1.17) define the first Direct structure 1D and is shown in Fig. (1.3). This structure is canonical because it possesses only N time delay elements, the minimum number for the N'th order Transfer function of equation (1.10).

#### 1.3 - 1.2 SECOND DIRECT STRUCTURE (2D)

2D realization of Digital filter makes use of the principle of transposition <sup>4,11</sup>. Appendix-II, explains the transpose principle. The transpose of a Digital filter structure is accomplished by reversing the signal flow in all branches of the block diagram but leaving their transmittances the same. The transpose of a filter structure has the same Transfer function as the original structure.

The 2D structure represented in Fig. (1.4) is the transpose of 1D structure. It implements equation (1.10) but requires (n + 1) difference equations (Summing Junctions). The 2D structure difference equations are of the form :

$$p_{i}(k) = p_{i+1}(k-1) + A_{i} \cdot x(k) - B_{i} \cdot y(k); i=1, N-1 \dots (1.18)$$

$$p_{N}(k) = A_{N} \cdot x(k) - B_{N} \cdot y(k) \dots (1.19)$$

$$y(k) = A_{0} \cdot x(k) + p_{1}(k-1) \dots (1.20)$$

This structure is also canonical because it possesses only N time-delay elements, the minimum number required for an N'th order Transfer function of equation (1.10).



1.3 - 1.3 THIRD DIRECT STRUCTURE (3D)

Rewriting equation (1.10)

$$D(z) = \frac{Y(z)}{X(z)} = \frac{\sum_{i=0}^{N} A_i \cdot z^{-i}}{\sum_{i=0}^{N} B_i \cdot z^{-i}} \dots (1.21)$$

or 
$$\sum_{i=0}^{N} B_{i} \cdot z^{-i} \cdot Y(z) = \sum_{i=0}^{N} A_{i} \cdot z^{-i} \cdot X(z) \dots (1.22)$$

or 
$$Y(z) = \sum_{i=0}^{N} A_i \cdot z^{-i} \cdot X(z) - \sum_{i=1}^{N} B_i \cdot z^{-i} \cdot Y(z) \dots (1.23)$$

In the time domain, equation (1.23) becomes

$$y(k) = \sum_{i=0}^{N} A_i \cdot x(k-i) - \sum_{i=1}^{N} B_i \cdot y(k-i) \dots \dots (1.24)$$

Equation (1.24) is the difference equation for the 3D Direct structure, which is block diagramed in Fig. (1.5). This structure has only one summing junction, but has 2N time delay elements, hence, a noncanonical form.

## 1.3 - 1.4 FOURTH DIRECT STRUCTURE (4D)

The 4D Direct structure is the transpose of 3D structure and is shown in Fig. (1.6). This structure has only one signal distribution point, but has 2N difference equations, expressed as follows :

| $r_{0}(k)$         | = | $x(k) + r_1(k - 1)$                                | • 0 • | (1.25) |
|--------------------|---|----------------------------------------------------|-------|--------|
| q <sub>N</sub> (k) | ÷ | $A_{\rm N}.r_{\rm o}(k)$                           | • • • | (1.26) |
| r_(k)              | = | $-\mathbf{B}_{N} \cdot \mathbf{r}_{0}(\mathbf{k})$ | • • • | (1.27) |





$$q_{i}(k) = A_{i} \cdot r_{o}(k) + q_{i+1}(k-1) ; i = 1, N-1 \dots (1.28)$$
  
$$r_{i}(k) = -B_{i} \cdot r_{o}(k) + r_{i+1}(k-1) \dots (1.29)$$

A comparison of the various characteristics of the four Direct structures discussed in Section 1.3-1 is summarized in TABLE - 1.1.

### TABLE - 1.1

PROPERTIES OF DIRECT STRUCTURES

| CHARACTERISTICS            | <b>1</b> D | 2D   | 3D   | 4D           |
|----------------------------|------------|------|------|--------------|
| Time Delay Elements        | N          | N    | 2N   | 2N           |
| Multipliers                | 2N+1       | 2N+1 | 2N+1 | 2N <b>+1</b> |
| Summing Junctions          | 2          | N+1  | 1    | 2N           |
| Signal Distribution Points | N+1        | 2 •  | 2N   | 1            |
|                            | -          |      |      |              |

As will be explained in A later chapter second order Digital filter is the basic building block for realizing any N'th order Digital filter. The Transfer function of equation (1.10) can be implemented making use of these four structures. Fig. (1.7) illustrates the 1D, 2D, 3D and 4D structures for second order modules.

#### 1.3-2 CASCADE FORM REALIZATION

The Cascade or Series canonic form structure for Digital filter is implemented from the Transfer function of equation (1.10), written as a product of factors.

$$D(z) = \prod_{i=1}^{N} H_i(z) \dots \dots \dots \dots (1.30)$$

whore,

$$H_{i}(z) = \frac{A_{0i} + A_{1i} \cdot Z^{-1}}{1 + B_{1i} \cdot Z^{-1}} \quad \text{for first order..(1.31)}$$

or 
$$H_{i}(z) = \frac{A_{0i} + A_{1i} \cdot Z^{-1} + A_{2i} \cdot Z^{-2}}{1 + B_{1i} \cdot Z^{-1} + B_{2i} \cdot Z^{-2}}$$
 for second  
order ... (1.32)

The configuration is shown in Fig. (1.8). It consists of a series of lower order filters connected in cascade. The individual second order or first order equations are generally realized in one of the Direct forms. Fig. (1.9) illustrates the use of the Direct structures in cascade. Equations derived for the cascaded structures is same as that derived for the Direct form structures. These structures are compared in TABLE - 1.2.

TABLE -1.2

### PROPERTIES OF CASCADED STRUCTURES

| CHARACTERISTIC             | 1 D | 2D  | 3D           | 4D   |
|----------------------------|-----|-----|--------------|------|
| Time Delay Elements        | 2N  | 2N  | 2N+2         | 2N+2 |
| Multipliers                | 5N  | 5N  | 5N           | 5N   |
| Summing junctions          | N+1 | 3N  | N            | 3N+1 |
| Signal Distributing Points | 3N  | N+1 | 3N+ <b>1</b> | N    |
|                            |     |     |              |      |



FIG 19 CASCADED FILTER STRUCTURES

· · -

#### 1.3-3 PARALLEL FORM REALIZATION

The Parallel Canonic form structure for Digital filter is implemented by expanding the equation (1.10) in partial fraction form as

$$D(z) = \beta_0 + \sum_{i=1}^{N} H_i(z) \dots (1.33)$$

where,

$$H_{i}(z) = \frac{\frac{A_{i} + A_{i}z^{-1}}{0i + 1i^{2}z^{-1}}}{1 + B_{2i}z^{-1}} \text{ for first}$$
(1.34)

or 
$$H_{i}(z) = \frac{A_{1i} + A_{1i} \cdot z^{-1} + A_{2i} \cdot z^{-2}}{1 + B_{i} \cdot z^{-1} + B_{i} \cdot z^{-2}}$$
 for second  
order ... (1.35)

This configuration is shown in Fig. (1.10) and consists of a group of lower order filters each operating on the input signal with the output parallel bank summed up together. The individual second order or first order sections can be realized in one of the direct forms. If the Direct structures are used some element sharing may be the accomplished as was done in/cascade case. Fig. (1.11) shows the direct parallel structure and TABLE - 1.3 compares their characteristics. Equations for the parallel structure is same as that derived for Direct form structure.





FIG 1.11 PARALLEL FILTER STRUCTURES

.

| TABLE | - | 13 |  |
|-------|---|----|--|
|       |   |    |  |

|                            |              | Art 10 M The 2 M A cardina documents |              |            |
|----------------------------|--------------|--------------------------------------|--------------|------------|
| CHARACTERISTIC             | 1 D          | 2D                                   | 3D           | 4D         |
| Time Delay Elements        | 2N           | 2N                                   | 2N+1         | 2N+1       |
| Multipliers                | 4N+1         | 4N+1                                 | 4N+1         | 4N+1       |
| Summing Junctions          | N+1          | 2N <b>+1</b>                         | N+1          | 2N+3       |
| Signal Distributing Points | 2N <b>+1</b> | N+1                                  | 2N <b>+3</b> | <b>ℕ+1</b> |
|                            |              |                                      |              |            |

PROPERTIES OF PARALLEL STRUCTURE

### 1.4 SUMMARY

The Z-Transform calculus is the mathematical basis for the analysis and design of Digital filters. Such Digital' filters are best understood by emphasizing the relations between the difference equations, the block diagram and filter response function. Various realization types have been discussed and the general equations involved, derived. Also, a comparison of the different characteristic present in each structure is made. The second order Digital filter, a basic module for realization of a N'th order structure, will be discussed in later chapters.

#### CHAPTER - II

SALIENT FEATURES OF INTEL 8086 MICROPROCESSOR

#### 2.1 <u>INTRODUCTION</u>

Intel introduced its first microprocessor in November 1971. This was followed with the delivery of 8008 in 1972, the 8080 in 1974, the 8085 in 1976 and 8086 in 1978. Each successive product implementation depended on fabrication innovations, sophisticated software, and throughout this development upward compatibility not envisioned by the first designer was maintained.

The selection of a suitable microprocessor <sup>13</sup> depends primarily on the particular application. Since the characteristics of the various processors are quite different, a number of factors must be considered in making a good choice. The selection process involves investigating the software, hardware and system design of the microprocessor.

In this chapter the salient features of Intel 8086 microprocessor are discussed. The various microprocessor of the Intel group have been compared in Appendix -III for the selection of this suitable microprocessor.

### 2.2 SALIENT FEATURES OF MICROPROCESSOR 8086

Intel 8086 <sup>20,21,22</sup> introduced in June 1978 is the first of the high performance generation of 16 bit microprocessors. It is implemented in N channel depletion load, silicon gate technology (HMOS) and packaged in a 40 pin Cer. DIP package. The 8086 is able to directly address one megabytes (1024 K bytes) of external memory. The detailed pin out of the 8086 is shown in Fig. (2.1).

# 2.2-1 FUNCTIONAL PIN DESCRIPTION

1.  $AD_{15} - AD_{0}$ : 2 - 16, 39, (I/O) Address Data Bus Time multiplexed memory / IO address (T<sub>1</sub>) and data (T<sub>2</sub>, T<sub>3</sub>, T<sub>w</sub>, T<sub>4</sub>) bus,

2.  $A_{19}/S_6 - A_{16}/S_3$ : 35-38, (OUT) Address / Status During  $T_1$ , used as address lines for memory operations. Lines LOW during I/O operation. In  $T_2$ ,  $T_3$ ,  $T_m$  and  $T_4$  status information is available on these lines.  $S_3$  and  $S_4$  indicate which of the segment (relocation) register is used (to construct the physical address used in the bus cycle).  $S_5$ reflects the state of the interrupt enable flag.  $S_6$  is always LOW.

| s <sub>4</sub> | s <sub>3</sub> | · · ·                          |
|----------------|----------------|--------------------------------|
| 0              | 0              | Extra Segment (Alternate Data) |
| 0              | 1              | Stack Segment                  |
| 1              | 0              | Code Segment or none           |
| 1              | 1              | Data Segment                   |

3.  $\overline{\text{BHE}}/\text{S}_7$ : 34, (OUT) Bus High Enable / Status During T<sub>1</sub> the B<sub>as</sub> high enable signal ( $\overline{\text{BHE}}$ ) is used to enable data on the most significant half of data bus



FIG. 2.1 8086 PIN DIAGRAM

(pin  $D_{15} - D_8$ ).  $S_7$  is a spare status line whose contents are undefined.

4. MN/MX : 33, (IN) Minimum / Maximum modē Indicates the system configuration. When this pin is grounded the 8086 treats pins 24 through 31 in maximum mode, when it is strapped to 5V it acts in the minimum mode.

5. RD : 32, (OUT) Road

Indicates that processor is performing a memory or I/O read cycle.

6. TEST : 23 , (IN) Test

TEST input examined by the WAIT (wait for TEST) instruction. If the signal goes LOW execution continues, otherwise the processor waits in the 'Idle' state.

7. RESET: 21, (IN) Reset

Causes the processor to immediately terminate its present activity and starts execution from FFFFO (H).

8. CLK: 19, (IN) Clock

Provides basic timing for the processor and bus controller.

9. INTR: 18, (IN) Interrupt Request

It is a single interrupt request line which can be masked internally by software with the resetting of the Interrupt enable flag status bit. During the interrupt response sequence further interrupts are disabled. A single byte is then expected from interrupting device which is multiplied by 4 and gives the address of service routine pointer stored from 00000 (H) to 003FF (H).

10. NMI: 17, (IN) Nonmaskable interrupt

Is a single nonmaskable interrupt which has a higher priority than the maskable interrupt request pin and causes a type 2 interrupt.

 11. GND:
 1, 20
 Ground pin

 12. VCC:
 40
 + 5V + 10 %

Pin functions which are unique in the minimum mode are defined below.

(1) INTA 24, (OUT) Interrupt Acknowledge

Is used as a read strob<sup> $\circ$ </sup> for interrupt acknowledge cycle. It is active LOW in T<sub>2</sub>, T<sub>3</sub> and T<sub>w</sub> states.

(2) ALE: 25, (OUT) Address Latch Enable

Is provided to latch the address into the 8282/8283 address latch.

(3) DEN: 26, (OUT) Data Enable

Is provided as an output enable for the data bus , transceiver.

(4)  $DT/\overline{R}$ : 27, (OUT) Data Transmit/Receive This is needed in minimum mode system that desires to use a data bus transceiver. It is used to control the direction of data flow through the transciever.

5.  $M/\overline{IO}$ : 28, (OUT) Status line

Is used to distinguish a memory access from an I/O access. HIGH, on this line indicates a memory operation and a LOW indicates an I/O operation.

6. WR : 29, (OUT) Write

Indicates that the processor is performing a write memory or write I/O cycle, depending on the state of the M/IO signal.

7. HOLD and HLDA 31, 30 (I/0)

Indicates that another master is requesting to take control of the address and data bus. To be acknowledged, HOLD must be active HIGH. The processor receiving the 'hold' request will issue HLDA (HIGH) as an acknowledgement. When HOLD goes LOW, the processor will LOWer HLDA and the processor start on its next cycle.

When the 8086 is in the maximum mode the functions unique to it are described below.

1.  $QS_1, QS_2$ : 24, 25, (OUT) Queue Status

Queue status valid during the CLK cycle after which the queue operation is performed. These provide status to allow external tracking of internal 8086 inst. queue.

| ର୍ତ୍ତ 1 | <b>೧</b> ೮ <sub>೦</sub> |                                 |
|---------|-------------------------|---------------------------------|
| Ô       | Q                       | No operation                    |
| 0       | 1                       | First Byte of Opcode from queue |
| 1       | 0                       | Empty the queue                 |
| 1       | 1                       | Subsequent byte from queue      |

Status is used by the 8288 Bus Controller to generate all memory and I/O access control signals. These status lines are encoded as

| .s <sub>2</sub> | s <sub>1</sub> | so |                       |
|-----------------|----------------|----|-----------------------|
| 0               | 0              | 0  | Interrupt Acknowledge |
| 0               | 0              | 1  | Read I/O Port         |
| Ō               | 1              | 0  | Write I/O Port        |
| 0               | 1              | 1  | Halt                  |
| 1               | 0              | 0  | Code Access           |
| 1               | 0              | 1  | Read Memory           |
| 1               | 1              | 0  | Write Memory          |
| 1               | 1              | 1  | Passive               |

3. LOCK : 29, (OUT) Lock

It indicates that other system bus masters are not to gain control of the system bus while  $\overline{\text{LOCK}}$  is active LOW. It is activated by the 'LOCK' prefix inst . and remains active until the completion of next instruction.

4.  $\overline{RQ} / \overline{GT}_0$ ,  $\overline{RQ} / \overline{GT}_1$  30, 31, (OUT) Request/Grant.

These are used by local bus masters to force the processor to release the local bus at the end of the processor's current bus cycle. Each pin is bidirectional with  $\overline{RQ} / \overline{GT}_0$  having higher priority than  $\overline{RQ} / \overline{GT}_1$ .

## 2.2-2 REGISTER ORGANIZATION

The 8086 processor contains a total of thirteen 16-bit registers and nine 1-bit flags. The set of registers Fig. (2.2) can be divided into the following four groups.

General Registers - There are four 16-bit general registers which can be used as either 8- or 16- bit registers. The dual nature of these registers permits them to handle both byte and word quantities with equal ease. They are Accumulator (AX), Base (BX), Count (CX) and Data (DX). The X can be replaced by H or L for referring to high or low order byte respectively.

The AX register is used in arithmetic operations to hold one of the two operands. The BX register can be used to hold an offset address for computing the effective address (EA) of an instruction operand. The CX and DX registers are used for specific purposes (dedicated general registers). These may be used as scratch pad during the evaluation of expressions or for holding the shift count in some shift and rotate instructions.









## FIG. 2.2 8086 REGISTER STRUCTURE

Pointer and Index Registers - This group consists of the 16-bit registers Stackpointer (SP), Base pointer (BP) Source Index (SI) and Destination Index (DI). These registers usually contain offset addresses for addressing within a segment. They reduce the size of programs by not requiring each instruction to specify frequently used addresses. Another important function is that they provide for dynamic effective-address computations. In order to accomplish this the pointer and index registers participates in arithmetic and logical operations alongwith 16-bit general registers.

<u>Segment Registers</u> - This group consists of four 16-bit registers Code Segment (CS), Data Segment (DS), Stack Segment (SS) and Extra Segment (ES). Each segment can be at most 64K bytes in size. A segment can begin from any location in the memory that is divisible by 16.

The segment registers are used for calculation of physical address (PA). All instruction fotches are taken from the current code segment (CS) using the offset specified in the instruction pointer (IP) register. The (SS) register points to the current stack segment; stack operations are performed on locations in this segment. The (DS) points to current data segment and generally contains program variables. The ES contents define the current extra segment, it has no

specific use although it is usually treated as an additional data segment.

Instruction Pointer and Flag Registers - The 16-bit instruction pointer (IP) (analogous to the program counter in the 8080/8085), is not directly accessible to the programmer; it is manipulated with control transfer instructions. There are nine 1-bit flags; six of these Carry (CF), Parity (PF), Auxillary carry (AF), Zero (ZF), Sign (SF) and Overflow (OF) flags record processor status information of the latest arithmetic and logical operation and the additional three flags Direction (DF), Interrupt (IF) and Trap (TF) control processor operations.

#### 2.2-3 MEMORY ORGANIZATION

The 8086 can address up to 1 Megabyte or 512 K words of memory directly. Logically the memory is organized as a sequence of  $2^{20}$  bytes but physically it is organized in two banks each of 512 K bytes Fig. (2.3). One bank is connected to the lower half of the sixteen-bit data bus  $(D_7 - D_0)$  and contains even addressed bytes. The other bank is connected to the upper half of the data bus  $(D_{15} - D_8)$  and contains odd addressed bytes. A specific byte within each bank is selected by address lines  $A_{19} - A_1$ . The most significant address bit  $A_0(AD_0)$  and the output signal BHE are used to select appropriate bytes to be read from or written into the memory.







2 4(a) EVEN ADDRESS WORD TRANSFER

FIG 2 4(b) ODE ADDRESS BYTE TRANSFER



. ....





TABLE - 2.1 describes the use of  $\overline{BHE}$  and  $A_{0}$  combination.

| <br>BHE | л <sub>о</sub> |                                 |
|---------|----------------|---------------------------------|
| 0       | 0              | One 16 bit word                 |
| 0.      | 1              | One byte from / to edd address  |
| 1       | 0              | One type from / to even address |
| 1       | 1              | None                            |
|         |                |                                 |

TABLE - 2.1

Organization of N bytes of memory is shown in Fig. (2.4). The low bank consists of only even-address bytes and the high bank consists of only odd-address bytes.

(1) A word is to be fetched from an even byte location. For this  $\overline{BHE}$  A<sub>0</sub> = 0 0; low byte of word falling on evenaddress byte and high byte on odd-address byte.

(2) A word is to be fetched from odd-address. This shall require two machine cycles. In the first, odd byte shall be read and in the next machine cycle the even byte shall be read.

(3) A byte is to be fetched from even-address location. For this  $\overrightarrow{BHE}$  A<sub>0</sub> = 1 0 and data shall be transferred on D<sub>0</sub> - D<sub>7</sub> lines. (4) A byte is to be fetched from odd-address. For this  $\overrightarrow{BHE}$  A<sub>0</sub> = 0 1 and data shall be transferred on  $D_8 - D_{15}$  lines.

The memory can be further logically divided into code, data, alternate data and stack segments of upto 64 K bytes each, with each segment falling on 16 byte boundary (Fig. 2.5).

Certain memory locations are reserved for specific processor operations. Locations 00000 (H) through 003FF (H) are, reserved for interrupt operations. Each of the 256 possible interrupts have their service routine pointed by a 4-byte pointer element. Following RESET, the processor will jump to FFFFO (H). FFFFO (H) through FFFFF(H) are reserved for operation including a jump to the initial program loading routine (Fig. 2.6).

It is useful to think of every memory location as having two kinds of addresses, physical and logical. A physical address is the 20-bit value that uniquely identifies each byte location in the megabyte memory space. Physical address may range from O(H) through FFFFF (H). All exchanges between the CPU and memory components use this physical address.

Programs deal with logical, rather than physical addresses and allow code to be developed without prior



FIG 2.5 MEMORY ORGANIZATION



## FIG.2 6 RESERVED MEMORY LOCATIONS

knowledge of where the code is to be located in memory. A logical address consists of a segment base value and an offset value. For any given memory location, the segment base value locates the first byte of the containing segment and the offset value is the distance, in bytes, of the target location from the beginning of the segment. Segment base and offset values are unsigned 16-bit quantities. Many different logical addresses can map to the same physical location.

A physical address is generated from a logical address by shifting the segment base value four bit positions and adding the offset. Calculation of the offset of a memory variable is based on the addressing mode specified in the instruction; the result is called the operand's effective address (EA).

#### 2.2-4 ADDRESSING MODES

Following are the different ways of calculating effective address (EA) and are shown in Fig. (2.7).

<u>Direct Addressing</u> - It is the simplest memory addressing mode. No registers are involved; the EA is taken directly from the displacement field of the instruction. Direct addressing is used to access simple variables. The EA is added to the DS segment to get the physical address.

> (EA) = DISP(PA) = (DS) \* 16 + DISP

Example : The instruction MOV AX , VALUE specifies that the contents of VALUE are to be moved to 16-bit accumulator. Let address associated with VALUE be O21(H), then the physical address from which the low data byte will be fetched is

$$= 1000(H) * 16 + 021(H)$$

= 10000(H) + 021(H) = 10021(H)

The high byte will be fetched from the physical address 10022(H).

<u>Based Addressing - Here the effective address is the</u> sum of a displacement value and the content of register BX or BP. If BP is specified as a base register, the BIU is directed to obtain the operand from the current stack segment. This makes based addressing a very convenient way to access stack data.

Based addressing provides a straightforward way to address structures which may be located at different places in memory. A base register can be pointed at the base of the structure and elements of the structure addressed by their displacements from the base. Different copies of the same structure can be accessed by simply changing the base register. (EA) = (BX/BP) + DISPfor BX, (PA) = (DS) \* 16 + (BX) + DISP for BP, (PA) = (SS) \* 16 + (BP) + DISP

Example : The instruction MUL BETA (BX) implies that the contents of AX are to be multiplied by the contents of (EA). The (EA) is computed as DISP + (BX) where DISP is the 16 bit address of BETA. The 32 bit product will be placed in registers DX (high word) and AX (low word).

Indexed Addressing - The effective address is calculated from the sum of a displacement plus content of an index register (SI or DI, SP or BP). Indexed addressing often is used to access elements in an array. Also it is assumed that the operand resides in the current data segment and hence DS register is used for computing physical address.

> (EA) = (IX) + DISP(PA) = (DS) \* 16 + (IX) + DISP

Based Index (Indirect) Addressing - This addressing generates an effective address that is the sum of a base register, an index register and a displacement. Based index addressing is a very flexible mode because two address components can be varied at execution time. It provides a convenient way for a procedure to address an array allocated on a stack. Arrays contained in structures and matrices (two dimensional arrays) also could be accessed with based

index addressing.

(EA) = (BX/BP) + (IX) + DISP(PA) = (BX) + (IX) + DISP + (DS) \* 16(PA) = (BP) + (IX) + DISP + (SS) \* 16

<u>String Addressing</u> - String instructions do not use the normal memory addressing modes to access their operands. Instead, the index registers are used implicitly, when a string instruction is executed, SI is assumed to point to the first byte or word of the source string, and DI is assumed to point to the first byte or word of the destination string. In a repeated string operation the CPU automatically adjust SI and DI to obtain subsequent bytes or words.

<u>I/O Port Addressing</u> - If an I/O port is memory mapped, any of the memory operand addressing modes may be used to access the port. String instructions also can be used to transfer data to memory-mapped ports with appropriate hardware interface.

Two different addressing modes can be used to access ports located in the I/O space. In direct port addressing, the port number is an 8 bit immediate operand. This allows fixed access to ports numbered 0-255. Indirect port addressing is similar to register indirect addressing of memory operands. The port number is taken from register DX and can range from 0 to 65,535.







# REGISTER INDIRECT ADDRESSING







-----

#### 2.2-5 INSTRUCTION SET

The 8086 instruction set is divided in six groups

| (1) | Data Transfer    | (4) | String Manipulation |
|-----|------------------|-----|---------------------|
| (2) | Arithmetic       | (5) | Control Transfer    |
| (3) | Bit Manipulation | (6) | Processor Control   |

These instructions treat different type of operands uniformly. Nearly every instruction can operate on either byte or word data. Register, memory and immediate operands may be specified interchangeably in most instructions. The instruction set can be viewed as existing at two levels; the assembly level and the machine level. These two levels address two different requirements; efficiency and simplicity The numerous forms of machine level instructions allow these instructions to make very efficient use of storage. The assembly-level instructions simplify the programmer's view of the instruction set.

To pack instructions into memory as densely as possible the 8086 CPU utilizes an efficient coding techniques. Machine instructions vary from one to six bytes in length. One byte instructions, which generally operate on single registers or flags, are simple to identify. The key to decoding longer instructions are in the first two bytes. The format of these bytes can vary, but most instructions follow the format shown in Fig. (2.8). The first six bits of a multibyte instruction generally contain an opcode that identifies the basic instruction type ADD, XOR, etc. The following bit, called the D\_field, generally specifies the 'direction' of the operation :

1 = the REG field in the 2nd byte identifies the destination operand.

0 = the REG field identifies the source operand The w field distinguishes between byte and word operations :

 $0 = byte, \qquad 1 = word$ 

One of the three additional single bit fields, S, V or Z appears in some instruction formats. S is used in conjunction with W to indicate sign extension of immediate fields in arithmetic instructions. V distinguishes between single and variable bit shifts and rotates. Z is used as a compare bit with the zero flag in conditional repeat and loop instructions. All single bit field settings are summarized in TABLE 2.2.

TABLE 2.2 SINGLE BIT FIELD ENCODING

| FIELD | VALUE | FUNCTION                                      |
|-------|-------|-----------------------------------------------|
| S .   | 0     | No sign extension                             |
|       | 1     | Sign extension 8-bit immediate data to 16-bit |
| W     | 0     | Inst. operates on byte data if w =1           |
|       | 1     | Inst. operates on word data                   |
| D     | 0     | Inst. source specified in REG field           |
|       | 1     | Inst. Destination specified in REG field      |
| V     | Ó     | Shift/rotate count is one                     |
|       | 1     | Shift/rotate count specified in CX register   |
| Z     | 0     | Repeat/Loop while zero flag is clear          |
|       | . 1   | Repeat/Loop while zero flag is set.           |

The second byte usually identifies the instruction's operands. The mode (MOD) field indicates whether one of the operands is in memory or whether both operands are registers TABLE - 2.3. The register (REG) field identifies a register that is one of the instruction operands. TABLE - 2.4. In a number of instructions, chiefly the immediate-to-memory variety, REG is used as an extension of the opcode to identify the type of operation. The encoding of the R/M (register/memory) field in TABLE - 2.5, depends upon how the mode field is set. If MOD = 11 (register to-register mode), then R/M identifies the second register operand. If MOD selects memory mode, then R/M indicates how the effective address of the memory operand is to be calculated.

Bytes 3 through 6 of an instruction are optional fields that usually contain the displacement value of a memory operand and/or the actual value of an immediate constant operand. Ther may be one or two displacement bytes. The MOD field indicates how many displacement bytes are present. Following Intel convention, if the displacement is two bytes the most significant byte is stored second in the instruction. If the displacement is only a single byte the 8086 automatically sign-extends this quantity to 16 bits before using the information in further address calculations. Immediate values always follow any displace-

# TABLE - 2.3

# MODE FIELD ENCODING

| CODE | EXPLANATION                                                   |
|------|---------------------------------------------------------------|
| 00   | Hemory mode, no displacement follows (except when R/M is 110) |
| 01   | Memory mode, 8-bit displacement .<br>follows                  |
| 10   | . Memory mode, 16-bit displacement follows                    |
| 11   | Register mode, no displacement                                |

TABLE - 2.4

| REGISTER | ₩ = 0 | W == 1 | Q |
|----------|-------|--------|---|
|          |       |        |   |
| 0001     | AL    | AX     |   |
| ÓO1      | CT    | CX     |   |
| 010      | DL    | DX     |   |
| 011      | BL    | BX     |   |
| 100      | AH    | SP     |   |
| 101      | CH    | BP     | x |
| 110      | DH    | SI     |   |
| 111      | BH    | DI     |   |
|          |       |        |   |

REGISTER/FIELD ENCODING

TABLE - 2.5 R/M FIELD ENCODING

(BX) + (SI) + D16(BX) + (DI) + D16+ D16 + D16 (IC) + (IS) + D16 D16 + D16 0 + + MOD (BP)(BP)(BP) (IS) (DI) EFFECTIVE ADDRESS CALCULATIONS 80 + 80 + 80 + 80 + D8 means Sign extended (IC) MOD 01 (BX) + (SI)(IC) + (IS) 89 g g + + + +(BX) (BP) (BP) (BP) (IS) (IU Direct Address (BX) + (DI) (BP) + (SI) (JU) + (JU) (BX) + (SI) 8 (IS) (DI) MOD R/M000 010 100 001 011 101 110 ЫХ ВΧ ß ß ВР AX Ч 11 -3 11 0 MOD ET E IJ AH AL 뜅 円 H  $\geq$ R/M000 010 011 100 001 110 101

37

D16

+

(BX)

g

+

(BX)

(BX)

111

Ц

BH

ment values that may be present. The second byte of a two byte immediate value is the most significant.

Some of the instructions from the instruction set given in Appendix-IV are explained here with examples.

The Data Transfer Group included MOV, PUSH, POP, XCHG. IN. OUT, LOAD and STORE instructions.

Example : MOV CX, TOP (BX) This instruction shall move the contents of TOP + (BX) to the CX register and will occupy 4 bytes.

> w = 1, it is a word operation d = 1, the destination is a register mod = 10, DISP = disp. high, disp. low destination register CX = 001 r/m field = 111 EA = (BX) + (TOP) address PA = DS \* 16 + (BX) + (TOP) address

| 100010 | 1 | 1  | 10           | 001               | 111          | DISP | Disp. |
|--------|---|----|--------------|-------------------|--------------|------|-------|
|        | d | ົລ | mod<br>field | dest<br>reg<br>Cx | r/m<br>field |      |       |

The Arithmetic Group includes ADD, ADC, DEC, INC, MUL, IDIV etc. instructions which can operate on signed and unsigned numbers. Example: ADI AX, OO5F(H)

This is an add immediate the value 005F to AX register and occupies 4 bytes

r/m = 000, ; destination register (AX) = 000

| 1 | 00 | 000 | > 0 | 1  | 11           | 000           | 000         | Data | Data if SW=01 |
|---|----|-----|-----|----|--------------|---------------|-------------|------|---------------|
|   |    |     | d   | IJ | mod<br>fielo | dest.<br>reg. | r/m<br>fice | d    |               |

The Logical Group includes AND, OR, NOT, ROTATE, SHIFT, TEST instructions

Example: SHL ALPHA

The contents of memory location ALPHA (16 bit value) shift by 'n', where 'n' is the shift count stored in the CX register.

It occupies 4 consecutive bytes V = 1 as the shifting is to be done'n' times W = 1 word operation mod = 00EA = disp. high; disp. low.

| 5 |    |    |    | v | ω |               | Reg. |              |      |      |
|---|----|----|----|---|---|---------------|------|--------------|------|------|
|   | 11 | 01 | 00 |   | 0 | 00            | 100  | 110          | DISP | DISP |
| - |    |    |    |   |   | mode<br>field |      | r/m<br>field |      |      |

The String Manipulation group is a set of very useful instruction used for moving blocks of data. MOVS Fig. (2.9) is a single byte instruction with the least significant bit (the w-field) specifying whether a word or a byte is to be The source is picked-up from the address specified moved. in SI register and the destination from the address specified in the DI registers. After transferring the source byte (s) to destination, the SI and DI index registers are incremented/ decremented by 1 or 2 depending upon whether W = 0 or 1. The direction flag DF is used to determine whether the index register are to be decremented (DF = 1 by STD) or incremented (DF = 0 by CLD) after data has been moved. If a REP (single byte) instruction procedes the MOVS instruction the latter is executed repetitively while the CX register remains non zero. Each time the MOVS instruction is executed, CX is decremented by 1, and if not zero, the instruction is executed again. Four more useful instructions for string manipulation are CMPS, SCAS, LODS, STOS.



Example CLD

REP.

MOVS NEW, OLD

W = 1; transfer word.

The words starting from location OLD shall be transferred to locations starting from NEW. The REPoat instruction precoding the MOVS shall repeat till  $CX \neq 0$ .

> For OLD(EA) = (SI) \* 16 + DISPand NEW(EA) = (DI) \* 16 + DISP

The Control Transfor group comprises of CALL, RET, JMP, LOOP, INT instructions.

Examplo: LOOP NUMBER

Decrement CX by 1 and transfer to NUMBER if CX  $\neq$  0. In this case, the 16 bit displacement is calculated by extending 8 bit displacement. This is a two byte instruction so can only loop  $\pm$  128 bytes from the present location, otherwise use JMP.

The Processor Control group has instructions for carry, direction, and interrupt flags : HALT, WAIT, LOCK and ESC.

Example :

LOCK

ADI NUMBER FB8C(H)

The bus shall be locked till the end of the instruction. No external device shall be able to take over the bus till ADI is executed.

### 2.5 SUMMARY

In this chapter a study of the salient features of Intel 8086 microprocessor has been carried out in considerable detail. This study indicates that the CPU of 8086 is more powerful than any microprocessor previously offered by Intel group.8086 is totally a new design and has a power set of instructions discussed in Appendix - IV. Memory to memory string operation is available for efficient character data manipulation, hence useful for reducing the complexibility of the program. The various types of addressing modes are useful in solving many problems. The hardwire multiplication and division of signed and unsigned binary numbers are quite powerful instruction **s**.

In the next chapter use is made of the 8086 Assembly language to implement the Digital filter structure described carlier in Chapter I.

#### CHAPTER - III

### REALIZATION OF DIGITAL FILTERS USING SECOND ORDER 1D STRUCTURE AS BASIC MODULES

#### 3.1 INTRODUCTION

Filters have been implemented in hardwired logic, special purpose computers and general purpose computers. The high speed 16-bit microcomputers with built in multiplication hardware has created a new option for implementing Digitalfilter 23, 24, with high sampling rate. In this chapter the Intel 8086 microcomputer is used to implement the individual second order 1D module. Also the Intel 8086 is used to implement Digital filters by cascaded and paralleled second order module.

#### 3.2 WHY A SECOND ORDER MODULE

The three basic forms for realizing linear Digital filters of the Recursive type are the Direct, Cascade and Parallel forms. As far as the stability question goes the two variations of the Direct form Fig. (1.3) and Fig. (1.5) are entirely equivalent, with the configuration of Fig. (1.3) requiring fewer delay elements. The stability result derived indicates clearly that the coefficient accuracy problem will be by far the most acute for the Direct form realization. For any reasonably complex filter with steep transitions between pass and stop bands the use of Direct form should be avoided.

The choice between the utilization of either the cascade or parallel forms is not clear cut but depends



FIG 3.1 SIGNAL FLOW DIAGRAM IN Z-DOMAIN OF A SECOND ORDER DIGITAL FILTER

somewhat on the initial form of the continuous filter and on the digitilization scheme  $^{6}$  used. In any case the denominator of D(z) must be known in factored form. In order to avoid coefficient sensitivity problems, the transfer function D(z) of equation (1.3) is implemented as a cascade or parallel combination of second order modules.

## 3.3 SECOND ORDER DIGITAL FILTER - 1D STRUCTURE

Second order Digital filter has the form

$$D(z) = \frac{A_0 + A_1 \cdot z^{-1} + A_2 \cdot z^{-2}}{1 + B_1 \cdot z^{-1} + B_2 \cdot z^{-2}} \dots (3.1)$$

and can be represented by any form explained in Section 1.3-1 with N = 2 Hg.(1.7). In this chapter 1D structure is specifically chosen for explanation and implementation using Intel 8086 microprocessor instruction set.

## 3.3-1 MATHEMATICAL DERIVATION

The Transfer function of second order Digital filter is given in equation (3.1). Introducing an intermediate variable M(z)

$$D(z) = \frac{Y(z)}{M(z)} \cdot \frac{M(z)}{X(z)} \cdots \cdots \cdots (3.2)$$
  
Therefore

$$\frac{Y(z)}{M(z)} \cdot \frac{M(z)}{X(z)} = \frac{A_0 + A_1 \cdot Z^{-1} + A_2 \cdot Z^{-2}}{1 + B_1 \cdot Z^{-1} + B_2 \cdot Z^{-2}} \dots (3.3)$$

Equating the neumerator and denominator separately

$$\frac{Y(z)}{M(z)} = A_0 + A_1 \cdot Z^{-1} + A_2 \cdot Z^{-2} \qquad (3.4)$$

and 
$$\frac{X(z)}{M(z)} = 1 + B_1 \cdot Z^{-1} + B_2 \cdot Z^{-2}$$
 .... (3.5)  
From equation (3.4)

$$Y(z) = A_0 \cdot M(z) + A_1 \cdot Z^{-1} \cdot M(z) + A_2 \cdot Z^{-2} \cdot M(z) \dots (3.6)$$

and from equation (3.5)

$$M(z) = X(z) - B_1 \cdot Z^{-1} \cdot M(z) - B_2 \cdot Z^{-2} \cdot M(z) \qquad \dots \qquad (3.7)$$

Equations (3.6) and (3.7) in time domain are

$$y(k) = A_0 \cdot m(k) + A_1 \cdot m(k-1) + A_2 \cdot m(k-2)$$
 ... (3.8)

$$m(k) = x(k) - B_1 \cdot m(k-1) - B_2 \cdot m(k-2)$$
 (3.9)

Equations (3.8) and (3.9) clearly show that m(k) is to be found out before y(k) is calculated.

Let 
$$T_1 = -B_1 \cdot m(k-1) - B_2 \cdot m(k-2)$$
 ... (3.10)  
and  $T_2 = A_1 \cdot m(k-1) + A_2 \cdot m(k-2)$  ... (3.11)

Equations (3.8) and (3.9) becomes

$$y(k) = A_0 \cdot m(k) + T_2$$
 ... (3.12)  
 $m(k) = x(k) + T_1$  ... (3.13)

Equations (3.6) through (3.13) define first direct structure, 1D, for second order Digital filter. Fig. (3.1) is the signal flow diagram in Z domain for the second order Digital filter in 1D form, and uses these equations. This signal flow diagram can be used to implement, through hardwired logic a second order Digital filter using summers, multipliers and two delay elements <sup>4,8</sup>.

It is to be noted that the intermediate variable  $T_1$  and  $T_2$  depend on the previous samples and therefore can be evaluated in the interval  $(K-1)T \cdot t \in KT$  and shall be available before KT sampling point. The output  $\cdot y(k)$  may rapidly be calculated upon the receipt of input x(k).

### 3.3-2 ALGORITHM FOR IMPLEMENTATION

Equations (3.6) through (3.13) can also be used for obtaining the algorithm for the implementation in a microprocessor. The information can be grouped as follows :

| OUTPUT          | $m(k) = x(k) + T_1$                                | • • • | (3.13) |
|-----------------|----------------------------------------------------|-------|--------|
|                 | $y(k) = A_0 \cdot m(k) + T_2$                      | •••   | (3.12) |
| DELAY           | $m(k-2) \leftarrow m(k-1)$                         |       |        |
|                 | $m(k-1) \leftarrow m(k)$                           |       |        |
| PRECALCULATIONS | $T_{1} = -B_{1} \cdot m(k-1) - B_{2} \cdot m(k-2)$ | • • • | (3.10) |

| PRECALCOLATIONS                     | <sup>⊥</sup> 1 | = | $-D_1 \cdot m(K-1)$ |   | D2•m(K-2)    | • • • |        |
|-------------------------------------|----------------|---|---------------------|---|--------------|-------|--------|
| in the interval.<br>(K-1)T < t < KT | T <sub>2</sub> | = | $A_1.m(k-1)$        | + | $A_2.m(k-2)$ | • • • | (3.11) |

It is to be noted that the above algorithm when implemented gives the maximum sampling rate possible in a microprocessor.

#### 3.3-3 SOFTWARE PROGRAM USING INTEL 8086 INSTRUCTION SET

The flow chart representing the process of 1D Structure derived above is shown in Fig. (3.2). Steps involved are

- (1) Initialization ; A/D, D/A converters and all variables.
- (2) Input X(k) ; From A/D converter.
- (3) Compute MØ and Y(k)
- (4) Output Y(k) ; To D/A converter.
- (5) Perform Time Delay
- (6) Compute  $T_1$  and  $T_2$ ; Precalculation of  $T_1 \& T_2$ .

The Assembly language software program is given in PROGHAM-3.1. The following salient features of the software program written are to be noted.

1. Input/Output are connected through A/D and D/A converters for Memory Mapped I/O operations.

2. The value of X(k) is inputed from A/D converter through CPU initiated Polled I/O transfer.

3. The value of the constants  $A_0$ ,  $A_1$ ,  $A_2$ ,  $B_1$  and  $B_2$ are stored as half values. This is explained in detail in Appendix - V. Thus the VALUE STORED = L'Value' \*  $2^{14} + 0.5$ J where [x] means largest integer smaller than or equal to X. 'Value' in the paranthesis is the value of the constant which is assumed to lie between -1 and 2.



4. This program is written exclusively for second order Digital filter. Once started it continues to sample input X(k)at maximum sampling rate and outputs Y(k) immediately thereafter, this continues till the processor is instructed to stop. This is done through an input PORT4.

PROGRAM - 3.1

FILTER SECOND ORDER 1D STRUCTURE

; INITIALIZATION CLEAR MØ, M1, M2, T1 AND T2

| T<br>T<br>Ţ |  | AX<br>CX<br>DI | , |  | 6 | 9<br>9<br>9 | CLEAR ACCUMULATOR<br>STORE 6 * N IN CX REGISTER<br>DI POINTS TOWARDS ADDR LOC M1Ø<br>STORES CONTENTS OF AX<br>IN LOCATIONS |
|-------------|--|----------------|---|--|---|-------------|----------------------------------------------------------------------------------------------------------------------------|
|-------------|--|----------------|---|--|---|-------------|----------------------------------------------------------------------------------------------------------------------------|

; INPUT X FROM A/D CONVERTER THROUGH POLLED I/O TRANSFER ; A/D CONNECTED FOR MEMORY MAPPED I/O OPERATION

CONT : MOV PORT3, AX ; ISSUE START CONVERSION PULSE ; TO A/D CONVERTER IN-LP : MOV AX , PORT2 ; READ 'BUSY' SIGNAL FROM A/D AND AX , 8000(H) JZ IN-LP ; WAIT UNTIL READY MOV AX , PORT1 ; X IS NOW IN A/D CONVERTER

; COMPUTE OUTPUT SAMPLE Y

~ ~

; NOTE THAT ADJUSTMENTS ARE NECESSARY SINCE CONSTANTS ; ARE STORED AS HALF VALUES

OUTP-1D. : ADD AX, T1 ; MØ IS NOW IN AX : \*\*\* X + T1 MOV MØ, AX ; STORE MØ IN ITS LOCATION IMUL AØ ;  $M\emptyset * A\emptyset/2$  IN DX, AX ; MØ \* AØ IN DX SAL DX , 1 ;  $A\emptyset * M\emptyset + T2$  IN DX = YADD DX., T2 MOV AX DX : Y IN AX

; OUTPUT Y IN AX TO OUT PORTØ, PORTØ BEING THE ADDRESS ; ASSIGNED TO D/A CONVERTER IN MEMORY MAPPED I/O MODE

MOV PORTØ AX

: PERFORM DELAY OPERATION SO THAT M2 - M1 AND M1 - MØ. DELAY-1D: LEA DI, T1-2; DI POINTS TO M2 LEA SI, M2-2; SI POINTS TO M1 ; COUNT DATA MOVE MOV CX ,  $\neq 2$ ; SET D FLAG FOR AUTODECREMENT STD REP MOVS : CLEARS D FLAG FOR AUTOINCREMENT CLD ; PREPROCESSING CALCULATIONS BEGINS HERE TO CALCULATE T1 AND T2 ;  $T1 = -(B1 \neq M1 + B2 \neq M2)$ ,  $T2 = A1 \neq M1 + A2 \neq M2$ ; SI POINTS TO COEFF A1 LEA SI, A1 PRE-1D : LODW ; A1/2 IS LOADED TO AX AND ; SI <del> S</del>I + 2 ; A1 \* M1/2 IN DX, AX IMUL M1 ; SAVE A1 \* M1/2 IN BX MOV BX, DX ; A2/2 IS NOW LOADED TO AX LODW

; AND SI 👉 SI + 2 ; A2 \* M2/2 IN DX, AX ; T2/2 IS NOW IN BX ; T2 IS NOW IN BX IMUL M2 ADD BX , DX SAL BX , 1 ; STORE NEW VALUE OF T2 MOV T2, BX ; B1/2 IS NOW IN AX AND SI - SI+2 LODW IMUL M1 MOV BX, DX LODVI ; B1 \* M1/2 IS IN DX, AX ; SAVE B1 \* M1/2 IN BX LODW ; B2/2 IS IN AX NOW ; M2 \* B2/2 IN DX, AX IMUL M2 ; -T1/2 IS IN BX ADD BX, DX ; BX THEN CONTAINS -T. SAL BX, 1 , NOT AND INC INSTRUCTIONS NOT BX ; TOGETHER NEGATES BX, SO T1 IN BX INC BX MOV T1, BX ; STORE NEW VALUE IN T1

; IT IS ASSUMED INPUT DEVICE PORT4 SHALL CONTAIN NO FFFF IF ; PROCESS CONTINUES, OTHERWISE STCP.

> MOV AX, PORT4 ; NOT AX JZ CONT HALT

## 3.4 <u>CASCADE STRUCTURE OF K'TH ORDER DIGITAL FILTER</u> <u>N SECOND ORDER 1D MODULES IN CASCADE</u>

In order to avoid coefficient sensitivity problems, the Digital filter Transfer function is implemented using a cascade of second order modules.

$$D(z) = \frac{\prod_{i=1}^{N} (A_{oi} + A_{1i} \cdot Z^{-1} + A_{2i} \cdot Z^{-2})}{\prod_{i=1}^{N} (1 + B_{1i} \cdot Z^{-1} + B_{2i} \cdot Z^{-2})} \dots (3.14)$$

where N is the smallest integer greater than or equal to K/2. If the numerator and denominator factors are paired and the modules ordered in cascade, then

$$D(z) = \prod_{i=1}^{N} H_i(z)$$
 ... (3.15)

where 
$$H_{i}(z) = \frac{A_{0i} + A_{1i} \cdot Z^{-1} + A_{2i} \cdot Z^{-2}}{1 + B_{1i} \cdot Z^{-1} + B_{2i} \cdot Z^{-2}} \dots (3.16)$$

Equations (3.14) and (3.15) are the same as discussed in Section (1.3-2). The problems encountered in pairing and ordering in cascaded second order modules has been extensively studied in the literature  $\frac{26,27,28}{\text{which provides guidelines for}}$  designing filters.

The cascaded block diagram in Z-domain for equation (3.1) is shown in Fig. (3.3). The signal flow diagram for i'th cascaded block is shown in Fig. (3.4), this is similar to



FIG 3 3 BLOCK ELAGRAM OF N-STAGES IN CASCADE



FIG.3.4 SIGNAL FLOW DIAGRAM IN Z-DOMAIN FOR ith CASCADED BLOCK

Fig. (3.1) except for introducing 'i' for i'th block identification, which implements equation (3.16).

#### 3.4-1 ALGORITHM FOR I'TH MODULE

Using the equations derived from Section (3.3), the following equations can be written for i'th stage.

OUTPUT  

$$: m_{i}(k) = x_{i}(k) + T_{1i} \dots (3.17)$$

$$y_{i}(k) = A_{0i} \cdot m_{i}(k) + T_{2i} \dots (3.18)$$

$$DELAY : m_{i}(k-2) \leftarrow m_{i}(k-1) \dots (3.19)$$

$$m_{j}(k-1) \leftarrow m_{j}(k)$$
 ... (3.20)

PRECALCULATION: 
$$T_{1i} = -B_{1i} \cdot m_i(k-1) - B_{2i} \cdot m_i(k-2) \dots (3.21)$$

$$T_{2i} = A_{1i} \cdot m_i(k-1) + B_{2i} \cdot m_i(k-2) ,, (3.22)$$

These equations are valid for all i = 1 to N.

#### 3.4-2 MEMORY ORGANIZETION

From equations (3.17) through (3.22) for all i = 1 to N it is obvious that coefficients ( $A_{oi}$ ,  $A_{1i}$  etc.), delayed value of the intermediate variables ( $m_i(k)$ ,  $m_i(k-1)$  etc.) and temporary storage variables ( $T_{1i}$ ,  $T_{2i}$  etc.) are to be stored in the RAM memory interfaced with Intel 8086 microprocessor. They are to be arranged in a particular way so that the String Manipulation instructions can be effectively used. The arrangement is shown in Fig. (3.5).



A11, A21, B11, B21

The displacement variable MØ initially points towards MØ1 with index zero. After performing the desired calculation the index is incremented by two and by the index addressing modes available, the pointer is changed to MØ2. Thus MØ pointer points to  $m_i(k)$  of all the cascaded stages, i = 1 to Similarly, M1 is the displacement pointer initially pointed towards  $m_i(k-1)$  of all the stages, i = 1 to N. This follows immediately after N values of MØ. Soon after N values of  $m_i(k-1)$ , the storage of second delay values  $m_i(k-2)$  should start. M2 is the displacement pointer address  $m_i(k-2)$ , i = 1 to N. Thus (M2 - 2) gives the address of the last location of first delay storage which stores  $m_N(k-1)$ . The stores  $m_N(k-1)$  is the store of is the pointer for temporary storage  $T_{1i}$ , i = 1 to N and this follows soon after the second delay storage values. Thus T1 - 2 gives the address of the last location of second delay storage which stores  $m_N(k-2)$ . After all  $T_{1i}$  are stored, T<sub>2i</sub> variables are stored consecutively starting from T2 displacement address.

Fig. 3.6 gives the memory organisation for constant coefficients. These are stored as half values as explained in Appendix - V.

Note that by properly loading SI and DI registers with proper starting indices, the pointer displacement address can be used along with indexed addressing modes to identify any address in the corresponding pointer blocks. For example, AØ pointer address can point to any address AØ1 to AØN. Similarly A1 pointer address can address all the constants of N stages (Fig. 3.6b). Similarly, M2 pointer address can be used along with index addressing modes to identify all the addresses from M21(=M2) to M2N.

## 3.4-3 IDENTIFICATION OF DIFFERENT SUBROUTINES

The operations involved in the cascaded modules can be broken up into different parts giving rise to the following subroutines.

(1) SUBROUTINE INITIALIZATION called INIT-1D.

This initializes  $m_{0i}$ ,  $m_{1i}$ ,  $m_{2i}$ ,  $T_{1i}$ ,  $T_{2i}$  locations by clearing all the memory locations given in Fig. (3.5).

(2) SUBROUTINE INPUT called INP-1D.

As explained earlier CPU initiated Polled 1/0 transfer is used for inputting X(k) and storing it in AX register through Memory Mapped I/0 connection.

(3) SUBROUTINE OUTPUT called OUT-1D.

This calculates equations (3.17) and (3.18) for all i = 1 to N. This subroutine is entered only after passing X(k) value in AX register and the number of stages N in CX register. The calculated value Y(k) of the last stage is returned in AX register when the subroutine is executed. (4) SUBROUTINE DELAY called DEL-1D.

This subrouting implements the transfers given in equations (3.19) and (3.20) for all i = 1 to N. The String Manipulation block move instructions (REP MOVS) is very useful here.

(5) SUBROUTINE PREPROCESSING called PRE-1D.

This subroutine calculates all the temporary storage values  $T_{1i}$  and  $T_{2i}$ , i = 1 to N for each sampling period and updates the information during (K-1) < t < KT. Again String Manipulation instructions and LOOP instruction simplifies the software program to a very great extent.

#### 3.4-4 SUBROUTINE FOR INITIALIZATION

The R.T.L. (Register Transfer Logic) flow chart for initialization subroutine is shown in Fig. 3.7, and the corresponding subroutine program is given in PROGRAM - 3.2. In PROGRAM - 3.2 the String Manipulation instruction STOSW along with REPeat instruction is used to implement the last three blocks of the flow chart. Thus, REP STOSW clears all the memory locations MØ to MØN, M1 to M1N, M2 to M2N, T1 to T1N and T2 to T2N. One more block of N word locations will also be cleared as 6\*N has been stored in CX register N should be known, and 6\*N should be loaded into the CX register before clearing the memory locations.



FIG. 3.7 R.T.L. FLOW CHART OF SUBROUTINE INITILIZATION-ID

PROGRAM - 3.2

| INIT-1D | : | CLD        |    | AX , ≇<br>CX , ≢ |    |             |                                       | CLEAR ACCUMULATOR<br>STORE 6*N IN CX |
|---------|---|------------|----|------------------|----|-------------|---------------------------------------|--------------------------------------|
|         |   | LEA<br>REP | DI | ,                | МØ |             | 9                                     | DI POINTS TOWARDS M1 $\emptyset$     |
|         |   | STOSW      |    |                  |    | 0<br>9<br>9 | STORES CONTENTS OF AX<br>IN LOCATIONS |                                      |
|         |   | RET        |    |                  |    | •           |                                       |                                      |

#### 3.4-5 SUBROUTINE INPUT - 1D

Here, it is assumed that the I/O operation is Memory Mapped, i.e., I/O devices may be placed in the memory space. An advantage of Memory-Mapped I/O is that it provides additional programming flexibility.

A/D converters are devices that convert analog input data into digital form. The block diagram of a tristate A/D converter is shown in Fig. (3.8a). The analog input voltage is converted into its 16-bit equivalent digital output. The output appears at the OUTPUT terminals only when Output-Enable goes LOW from HIGH. When Output-Enable is LOW the 16 output terminals are in tristate condition. Start-pulse is a control input terminal, when it is LOW the A/D converter is dead — not working and when this Start-pulse goes from HIGH to LOW the A/D converter starts the conversion process. The A/D conversion is not instantaneous and takes some time.



During the conversion process the A/D converter is said to be BUSY and is indicated by Busy-control output signal. This BUSY is normally HIGH goes LOW at the start of A/D conversion, remains BOW for 't<sub>c</sub>' sec., till the conversion is complete and the required data is ready for transfer.

To perform the operations as in Fig. (3.9) different signals of Fig. (3.8b) are to be issued by proper interfacing of Fig. (3.8a) of A/D converter with the given microprocessor This is shown in Fig. (3.10) and the corresponding subroutine program is given in PROGRAM - 3.3. Twenty-bit address bus is got by making use of 8282 latches (3 Nos.). The ALE issued out of microprocessor latches the address in first  $(T_1)$  state The 8282 propogates the address through to the outputs while ALE is high and latches the address on the falling edge of ALE.

PROGRAM - 3.3

| INP-1D :<br>IN-LP : | MOV | AX, PORT2<br>AX, 8000(H)<br>IN-LP | °<br>? | ISSUE START CONVERSION PULSE<br>READ BUSY SIGNAL FROM A/D<br>WAIT UNTIL READY<br>X IS NOW IN A/D |
|---------------------|-----|-----------------------------------|--------|--------------------------------------------------------------------------------------------------|
|                     | RET |                                   |        |                                                                                                  |



3.4-6 SUBROUTINE OUTPUT - 1D

The R.T.L. flowchart is shown in Fig. (3.11) and the corresponding program is given in PROGRAM - 3.4. The following points are to be noted while reading the flowchart.

(1) X(K) is passed in AX register before entering this subroutine.

(2) N, the number of cascades second order modules, is passed in CX register before entering the subroutine.

(3) The coefficients are assumed to be arranged as shown in Fig. (3.6a) and stored as half values as explained.in Appendix - V.

(4) MØ, M1, M2, T1 and T2 pointers points to the first address of the corresponding block, Sixteen bit operations are assumed.

PROGRAM - 3.4

| OUT-1D : | lea di , mø                   | ; STAGE INDEX<br>; M(K) POINTER POINTS TO FIRST<br>; ADDRESS                                                          |
|----------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| OLP-1D : | CLD<br>ADD AX, T1 SI<br>STOSW | ; MØ is NOW IN AX<br>; STORE IN MØ LOCATION<br>: DI ← DI + 2                                                          |
|          | IMUL AØ SI<br>SAL DX, 1       | ; MØ * AØ/2 IN DX, AX                                                                                                 |
|          | ADD DX, T2[SI]<br>MOV AX, DX  | ; TRONCALL AND MOLITIPLE BY 2<br>; TO GET MØ * AØ IN DX<br>; Y(K) IN DX<br>; Y(K) NOW IN AX READY FOR<br>; NEXT STAGE |
|          | ADD SI, $\neq$ 2              | ; MOVE INDEX TO POINT NEXT<br>; STAGE LOCATIONS                                                                       |
|          | LOOP OLP-1D                   | ; LOOP BACK TO CALCULATE<br>: NEXT STAGE                                                                              |
|          | RET                           | , transie wierden                                                                                                     |



## 3.4-7 SUBROUTINE DELAY - 1D

The R.T.L. flowchart for this subroutine is shown in Fig. (3.12) and the corresponding program in PROGRAM - 3.5. The following points must be noted.

(1) MØ, M1, M2, T1 & T2 displacement addresses points to the first address of each block as given in Fig. (3.5). From Fig. (3.5) it is clear that M2-2 points to M1N namely m(k-1) of the N'th stage and T1-2 points to m(k-2) of the last stage (= M2N).

(2) N, the number of cascade stages of second order modules is passed in CZ register before entering the delay subroutine.

(3) The String Manipulation block move instructions alongwith REPeat instruction performs the complete transfer operations so that all  $m_i(k-1)$  are transferred to  $m_i(k-2)$ locations and thereafter all  $m_i(k)$  are transferred to  $m_i(k-1)$ . locations. Thus, 2N locations are to be transferred from one block to the other. Hence, the count in CX register must be multiplied by 2 before executing the block move instructions.

PROGRAM - 3.5

| SAL CX, 1<br>REP | ; POINTS TO M2 |
|------------------|----------------|
|------------------|----------------|



#### 3.4-8 SUBROUTINE PROCESSING - 1D

The R.T.L. flowchart is shown in Fig. (3.13) and the corresponding program in PROGRAM - 3.6. As before, N, number of cascaded stages should be passed in CX before entering th subroutine. Also M1, M2, T1, T2 displacement addresses points to the first address of each block as given in Fig. (3.5)

A1 displacement address points to the first address of the coefficients, A11, A21, B11, B21 etc., as shown in Fig. (3.6b). The coefficients are stored in these locations as half values explained in Appendix - V. Again the use of String Manir Plation instructions and LOOF instruction simplifies writing the Assembly language Program shown in PROGRAM - 3.6.

PROGRAM - 3.6

| MOV DI , $\neq \phi$                                                                                                                         | ; POINTS TO FIG. 3.6(%) COEFS<br>; INDEX TO POINT CURRENT STAGE<br>; CALCULATIONS                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IMUL M1 (DI)<br>MOV BX,DX<br>LODSW<br>IMUL M2 (DI)<br>ADD BX,DX<br>SAL BX,1<br>MOV T2 (DI),BX<br>LODSW<br>IMUL M1 (DI)<br>MOV BX,DX<br>LODSW | ; A1/2 IS NOW IN AX AND SI $\leftarrow$ SI +2<br>; A1 * M1/2 IN DX , AX<br>; A1 * M1/2 IN BX SAVE<br>; A2/2 IS NOW IN AX AND SI $\leftarrow$ SI +2<br>; A2 * M2/2 IS NOW IN DX, AX<br>; T2/2 IS NOW IN BX<br>; T2 IS NOW IN BX<br>; T2 IS NOW IN BX<br>; STORE T2 IN ITS LOCATION<br>; B1/2 IS NOW IN AX AND SI $\leftarrow$ SI +2<br>; B1 * M1/2 IN DX, AX<br>; B1 * M1/2 IS NOW IN BX<br>; B2/2 IS NOW IN AX AND SI $\leftarrow$ SI +2<br>; SI THEN POINTS TO NEXT STAGE<br>; CONSTANT A1. |
| IMUL M2 (DI)<br>ADD BX, DX                                                                                                                   | ; B2 * M2/2 IN DX, AX<br>; -T1/2 IS NOW IN BX                                                                                                                                                                                                                                                                                                                                                                                                                                                |





CONTD.



# -LOW CHART FOR PREPROCESSING - 1D SUBROUTINE

SAL BX, 1; -T1 IN BX NEG BX; T1 IS NOW IN BX MOV T1 / DI , BX; STORE T1 IN ITS LOCATION ADD DI , # 2; DI THEN POINTS TO NEXT STAGE LOCATIONS LOOP PLP-1D; CX IS DECREMENTED AND LOOPS ; BACK IF NOT ZERO RET

#### 3.4-9 MAIN PROGRAM

The flowchart for the main program is shown in Fig. (3.14) and the corresponding program in PROGRAM - 3.7. The main program is written in the same way as in PROGRAM - 3.1 but by utilizing the subroutine programs (3.2 to 3.6) explaired in earlier sections in sequence. Fig. (3.3) is implemented this main program.

PROGRAM - 3.7

| NFILTR | : CALL                                                    | INIT-1D                                                                                | ; IN THE PROGRAM PROPER CONST. NTS<br>: BE LOADED IN CX REGISTER                                                                                                                                                                                                                                                                           |
|--------|-----------------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S.MPLE | : CALL<br>IMUL<br>SAL<br>MOV<br>MOV<br>CALL<br>MOV<br>MOV | INP-1D<br>SØ<br>DX, 1<br>AX, DX<br>CX, $\neq N$<br>OUT-1D<br>PORTØ, AX<br>CX, $\neq N$ | <ul> <li>INPUTS X(K) INTO AX</li> <li>X(K) * SØ/2 IN DX, AX</li> <li>X(K) * SØ IN DX</li> <li>AX NOW CONTAINS SCALED X(K)</li> <li>NUMERICAL 'N' BE LOADED TO CX</li> <li>COMPUTE Y(K) AND MAKE IT</li> <li>AVAILABLE IN AX</li> <li>PORTØ IS THE OUTPUT PORT ADDR.</li> <li>LOAD CX AGAIN WITH NUMERICAL</li> <li>VALUE OF 'N'</li> </ul> |
|        | CALL<br>MOV                                               | $\frac{\text{Del}-1 \text{ D}}{\text{CX}}, \neq \text{N}$                              | ; BLOCK MOVE M2 - M1; M1 - MØ<br>; LOAD CX WITH 'N' FOR PRE-<br>; CALCULATIONS                                                                                                                                                                                                                                                             |
|        | CALL                                                      | PRE-1D                                                                                 | ; CALCULATES T1 AND T2 OF ALL<br>; STAGES                                                                                                                                                                                                                                                                                                  |



| NOT        |        | 9<br>9<br>9 | READ PORT4 FOR<br>OVER OR NOT<br>PORT4 CONTAINS<br>TO CONTINUE |  |
|------------|--------|-------------|----------------------------------------------------------------|--|
| JZ<br>HALT | SAMPLE | 9           | IO CONTINUE                                                    |  |

#### 3.5 PARALLEL IMPLEMENTATION OF K'TH ORDER DIGITAL FILTER

Another method of avoiding coefficient sensitivity is to implement the filter as a sum of partial fraction of the given Transfer function. Equation for Parallel Canonic form is

$$D(z) = \beta_0 + \prod_{i=1}^{N} H_i(z) \dots (3.23)$$

where 
$$\mathcal{O}^{H_{i}(z)} = B_{i} \cdot \frac{A_{0i} + A_{1i} \cdot Z^{-1} + A_{2i} \cdot Z^{-2}}{1 + B_{1i} \cdot Z^{-1} + B_{2i} \cdot Z^{-2}} \dots (3.24)$$

where,  $A_{oi} = 0$  and is introduced to make the second order Z-Transfer function identical to equation (3.1). This end ares that the subroutine developed for cascaded structure can be made use of judiciously in parallelstructure implementation The coefficients of Fig. (3.15) are adjusted such that  $\beta_i = 2^K$ , this ensures that the results obtained from output subroutine program can be easily modified by shifting the result left by K-bits, which is equivalent to multiplying by  $2^K$ .



. ....

-

Fig. (3.15) gives the block diagram representation of the parallel N'th order Digital filter. As a specific example <sup>29</sup> for parallel structure implementation consider a 4th order Digital filter. Transfer function is as

$$D(z) = B_0 - 8. \frac{A_{01} + A_{11} \cdot z^{-1} + A_{21} \cdot z^{-2}}{1 + B_{11} \cdot z^{-1} + B_{21} \cdot z^{-2}}$$
  
-4. 
$$\frac{A_{02} + A_{12} \cdot z^{-1} + A_{22} \cdot z^{-2}}{1 + B_{12} \cdot z^{-1} + B_{22} \cdot z^{-2}}$$
  
(3.25)

Where,  $A_{01} = A_{02} = 0$ , and all the constant  $A_{11}$ ,  $A_{21}$ , etc. lie between -2 and +2 so that they can be stored as half values and  $B_1 = -8$ ,  $B_2 = -4$ . It can be realized shown in Fig. (3.16). The complete program for implementing equation (3.25) is shown in PROGRAM - 3.8. The comments in the comment field of each instruction in the program are self-explanatory.

PROGRAM - 3.8

MAIN PROGRAM FOR 4TH ORDER DIGITAL FILTER PARALLEL STRUCTURE ; THE EQUN BE MADE AVAILABLE AS GIVEN IN EQUN 3.25 ; THE COEFFICIENTS ARE STORED AS HALF VALUES AS ; EXPLAINED IN FIG. 3.6A, FIG. 3.6B WITH A $\emptyset$ 1 =  $A\emptyset$ 2 =  $\emptyset$ ; CALLS ALL SUBROUTINES DEVELOPED FOR CASCADED STRUCTURE

|                                                                     | 1D ;                                          | CLEAR M1, M2, T1 AND T2<br>GET X(K) FROM AYD<br>X(K) IS NOW IN AX                                 |
|---------------------------------------------------------------------|-----------------------------------------------|---------------------------------------------------------------------------------------------------|
| IMUL BØ<br>SAL DX,                                                  | AZ ;<br>1 ;                                   | X(K) IS NOW IN BX<br>BØ * X(K)/2 IN DX , AX<br>BØ * X(K) IN DX<br>TEMP LOCATION NOW CONTAINS THE  |
| MOV AX,                                                             | BX ;<br>, , , , , , , , , , , , , , , , , , , | FIRST TERM OF OUTPUT Y(K)<br>AX AND BX HAS X(K)<br>CALCULATE FIRST STAGE OUTPUT                   |
| CALL OUT                                                            | 2-1D ;                                        | FROM HERE ONWARDS<br>CALCULATE $Y_{11}(K)$ .<br>$Y_{1}(K)$ IS IN AX AND SI $\leftarrow$ SI+2 '    |
| SAL AX<br>NEG AX                                                    | , 3 ;                                         | WHEN RETURNED<br>-Y. (K) IS NOW IN AX(=8.Y.11(K))<br>Y. (K) IN AX NOW                             |
|                                                                     |                                               | AX NOW CONTAINS SUM OF TWO TERMS<br>OF OUTPUT = $B_X(K) + Y_1(K)$<br>(TEMP) - $B_X(K) + Y_1(K)$   |
| MOV AX                                                              | , BA ;                                        | $(\text{TEMP}) = B_X(K) + Y_1(K)$<br>AX AND BX BOTH CONTAIN X(K)<br>CALCULATE SECOND STAGE OUTPUT |
| ; DO NOT CALL OUTP-1<br>; BECAUSE INDEX SI N<br>; DI POINTING TO MØ | UST POINT                                     | HERE ONWARDS<br>OMIT FIRST TWO INSTRUCTIONS<br>TO SECOND STAGE LOCATIONS WITH<br>CALL FROM OPL-1D |

.

.

•

| CALL OPL-1D         | ; Y <sub>21</sub> (K) IS REFURNED IN AX                  |
|---------------------|----------------------------------------------------------|
| SAL AX, 2           | ; -Y <sub>2</sub> (K) IS NOW IN AX                       |
| NEG AX              | ; Y <sub>2</sub> (K) IS IN AX NOW                        |
| ADD AX, TEMP        | ; $A\overline{X} \leftarrow B_0, X(K) + Y_1(K) + Y_2(K)$ |
| MOV PORTØ AX        | ; MOVE OUT TO D/A IN PORTØ                               |
| MOV $CX$ , $4/2$    | ; DELAY-1D INITIALIZATION                                |
| CALL DEL-1D         | ; M2 👉 M1 AND M1 🗲 MØ FOR                                |
|                     | ; TWO STAGES                                             |
| MOV $CX$ , $\neq 2$ | ; FRE-1D INITIALIZATION                                  |
| CALL PRE-1D         | ; CALCULATES T1 AND T2 FOR                               |
|                     | ; TWO STAGES                                             |
| MOV AX, PORT4       | ; INPUT PROCESSING OVER                                  |
|                     | , OR NOT SIGNAL ISSUED                                   |
| NOT AX              | SIGNAL IS FFFF(H) CONTINUE                               |
| JZ CONT             | ; JUMP TO START IF AX IS ZERO                            |
| HALT                |                                                          |

## 3.6 SUMMARY

In order to avoid coefficient sensitivity problems a Digital filter is implemented as a cascade or parallel combination of second order modules. In this chapter the second order 1D module has been extensively dealt with. The mathematical derivation, algorithm and the software program using Intel 8086 instruction set has been derived. The K'th order Digital filter using N second order 1D modules in cascade and in parallels have also been discussed : the various subroutines for these structures are written. Finally, a main program for the cascade and parallel (4th order) structure using these subroutines written.

#### CHAPTER - IV

## IMPLEMENTATION OF SECOND ORDER DIGITAL FILTER THROUGH OTHER STRUCTURES

## 4.1 INTRODUCTION

The Transfer function for the **1**<sup>t</sup> th stage second order module is rewritten as

$$D(z) = \frac{A_{0i} + A_{1i} \cdot z^{-1} + A_{2i} \cdot z^{-2}}{1 + B_{1i} \cdot z^{-1} + B_{2i} \cdot z^{-2}} \dots (4.1)$$

Equation (4.1) can be implemented by any of the realization structures discussed earlier in section 1.3. Fig. (4.1) is a flow chart that models all the second order modules implemented by these Direct structures <sup>25</sup>.

In this chapter the necessary mathematical equations, algorithm and finally the subroutine programs for 2D, 3D and 4D second order structures will be discussed. Also two other structures viz. 1X and 2X crosscoupled structures <sup>30</sup> will be used to implement the above equation (4.1).

## 4.2 2D STRUCTURE

1

Cross Multiplying both sides of equation (4.1)

 $Y(z) + B_{1} \cdot Z^{-1} \cdot Y(z) + B_{2} \cdot Z^{-2} \cdot Y(z) = A_{0} \cdot X(z) + A_{1} \cdot Z^{-1} \cdot X(z) + A_{2} \cdot Z^{-2} \cdot X(z) \dots (4.2)$ 



$$Y(z) = A_0 \cdot X(z) + A_1 \cdot Z^{-1} \cdot X(z) + A_2 \cdot Z^{-2} \cdot X(z) - B_1 \cdot Z^{-1} \cdot Y(z) - B_2 \cdot Z^{-2} \cdot Y(z) \qquad (4.3)$$

Arranging in the powers of  $z^{-1}$  and  $z^{-2}$ 

$$Y(z) = A_0 \cdot X(z) + (A_1 \cdot X(z) - B_1 \cdot Y(z)) \cdot z^{-1} + (A_2 \cdot X(z) - B_2 \cdot Y(z)) \cdot z^{-2} \quad \dots \quad (4.4)$$

Let 
$$P_2(z) = A_2 \cdot X(z) - B_2 \cdot Y(z)$$
 ... (4.5)

So 
$$P_2(z) \cdot z^{-1} = (A_2 \cdot X(z) - B_2 \cdot Y(z)) \cdot z^{-1}$$
 ... (4.6)

Also let 
$$P_1(z) = (A_1 \cdot X(z) - B_1 \cdot Y(z)) + P_2(z) \cdot z^{-1} \cdots (4.7)$$
  
So  $P_1(z) \cdot z^{-1} = (A_1 \cdot X(z) - B_1 \cdot Y(z)) \cdot z^{-1} + P_2(z) \cdot z^{-2} \cdots (4.8)$ 

Substituting the value of  $P_1(z) \cdot z^{-1}$  and  $P_2(z) \cdot z^{-1}$ 

in equation (4.4)

$$Y(z) = A_0 \cdot X(z) + P_1(z) \cdot Z^{-1}$$
 (4.9)

$$P_{1}(z) = A_{1} \cdot X(z) - B_{1} \cdot Y(z) + P_{2}(z) \cdot Z^{-1} \quad ... \quad (4.10)$$

and 
$$P_2(z) = A_2 \cdot X(z) - B_2 \cdot Y(z)$$
 ... (4.11)

In the time domain

$$y(k) = A_0 \cdot x(k) + p_1(k-1)$$
 ... (4.12)

$$p_1(k) = A_1 \cdot x(k) - B_1 \cdot y(k) + p_2(k-1) \dots (4.13)$$

$$p_2(k) = A_2 \cdot x(k) - B_2 \cdot y(k)$$
 ... (4.14)

From equations (4.12) through (4.14) y(k) is to be found out first. The values of  $p_1(k)$  and  $p_2(k)$  are calculated during KT < t < KT + T. A stepwise procedure is

| OUTPUT                             | $y(k) = A_0 \cdot x(k) + p_1(k-1)$                    |
|------------------------------------|-------------------------------------------------------|
| POST PROCESSING<br>in the interval | $p_1(k) = A_1 \cdot x(k) - B_1 \cdot y(k) + p_2(k-1)$ |
| $\frac{11}{KT} < t < KT + T$       | $p_2(k) = A_2 \cdot x(k) - B_2 \cdot y(k)$            |
| DELAY                              | $p_2(k-1) - p_2(k)$                                   |
|                                    | $p_{1}(k-1) \leq p_{1}(k)$                            |

The flow chart of Fig. (4.1) represents the process. Precalculation is not needed. The steps involved are

- (1) Initialization; A/D, D/A converters and all ; variables
- (2) Input X(k) ; From A/D convertor
- (3) Compute Y(k)
- (4) Output Y(k) ; To D/A converter
- (5) Perform Tine Dalay
- (6) Compute P1 and P2; Bost calculation of P1 and P2

The subroutines for 2D structure making use of the instruction set of 8086 microprocessor are given in PROGRAM - 4.1.

#### PROGRAM - 4.1

#### FILTER SECOND ORDER 2D STRUCTURE

; SUBROUTINE INITIALIZATION AND SUBROUTINE INPUT ARE SAME ; AS IN PROGRAM - 3.2 FIG. (3.7) AND PROGRAM - 3.3 FIG. (3.8) ; RESPECTIVELY.

: SUBROUTINE OUTPUT COMPUTES OUTPUT SAMPLE Y =  $A\emptyset \cdot X + P12$ : X PASSED IN AX Y RETURNED IN AX.LOOP COUNT IN CX. SI #Ø OUT - 2D; MOV ;STAGE INDEX DI, X(K) ;POINTS TO X LEA : STOSW SAVE X OLP - 2DAØ [SI] ;X \* AØ / 2 IN DX IMUL DX , 1 ;X \* AØ IN DX SAL DX , P11[SI ;Y ADD MOV AX , DX Y IN AX READY FOR NEXT STAGE SI # 2 :MOVE INDEX TO POINT NEXT STAGE ADD :LOCATION LOOP OLP-2D :USE COUNT IN CX RET ;OUTPUT Y IN AX TO OUTPUT PORTØ. PORTØ BEING THE ADDRESS ;ASSIGNED TO D/A CONVERTER IN MEMORY MAPPED 1/0 MODE portø , AX MOV ; COMPUTE DELAY P12 - P1,  $P22 \longleftarrow P2$ LEA DI, P1 ;P(k) DEL-2D ;P(k-1)LEA SI: PERFORM BLOCK MOVE REP MOVS RET :PREPROCESSING 2D NOT USED IN 2D MODULE SECOND ORDER : STRUCTURE RET PRE-2D : POST PROCESSING - 2D CALCULATIONS BEGIN HERE TO CALCULATE P1 = A1\*X - B1\*Y + P22 AND P2 = A2\*X - B2\*YLOOP COUNT IN CX POST - 2D : LEA SI , A1 ; COEFFICIENT LOINTER LEA BX, X MOV DI # Ø :POINTS TO INPUTS ;STAGE INDEX ;A1/2 IN AX AND SI 🦛 SI + 2LODSW POLP-2D : IMUL BX DI ; A1 \*-X/2 IN DX,; AX AND ;BX 🗲 DX + 2 ; SAVE PUSH DX LODSW ;B1/2 2 BX / DI B1 + Y/2 IN DX, AX and IMUL : AND BX - BX + 2 POP AX (A1 \* X - B1 \* Y)/2XX, DX SUB ;A1 \* X - B1 \* Y AX , 1 ;A1 \* X - B AX , P21 DI ;COMPUTE P1 SAL ADD P1[DI], AX STORE P1 MOV A2/2 IN AX AND SI  $\leftarrow$  SI + 2 LODSW X + A2/2 IN DX,  $AX^{\prime}$ IMUL BX ; AND BX 🗲 BX + 2

| TODGH              | DX<br>official fort                     | ;B2/2 IN AX AND SI <- SI + 2               |
|--------------------|-----------------------------------------|--------------------------------------------|
| IMUL<br>POP<br>SUB | $2 \left[ DX \right] \left[ DI \right]$ | ;Y * B2/2<br>;F2/2 = (X * A2 - Y * B2)/2   |
| SAL<br>MOV         | AX , 1<br>P2 [DI]                       | ;F2<br>;STORE P2                           |
| ADD                | DI #2                                   | MOVE INDEX TO POINT NEXT<br>STAGE LOCATION |
| LOOP<br>RET        | POLP-2D                                 | HUSE COUNT IN CX                           |

2D CONSTANT STORAGE FOR N ST.GES

AØ : DW AØ1, AØ2,,,,, AØN ; AØ FOR N STAGES A1 : DW A11, B11, A21, B21 ; STAGE 1 COEFFICIENTS DW A12, B12, A22, B22 ; STAGE 2 COEFFICIENTS ... DW A1N, B1N. A2N, B2N ; STAGE N COEFFICIENTS 2D TEMFORARY STORAGE FOR N STORAGE

| X  | DW | 、(N+1) | DUFØ | 9 | INPUTS/OUTPUTS |
|----|----|--------|------|---|----------------|
| P1 | DW | N N    | DULØ |   |                |
| F2 | DW | N      | DUFØ |   |                |

# 4.3 3D STRUCTURE

Equation (4.1) can be written as

 $Y(z) = (A_{0} + A_{1} \cdot Z^{-1} + A_{2} \cdot Z^{-2}) \cdot X(z) - (B_{1} \cdot Z^{-1} + B_{2} \cdot Z^{-2}) \cdot Y(z)$ (4.15)

or 
$$Y(z) = A_0 \cdot X(z) + A_1 \cdot Z^{-1} \cdot X(z) + A_2 \cdot Z^{-2} \cdot X(z)$$
  
-  $B_1 \cdot Z^{-1} \cdot Y(z) - B_2 \cdot Z^{-2} \cdot Y(z) \cdot . \quad (4.16)$ 

In the time domain

$$y(k) = A_0 \cdot x(k) + A_1 \cdot x(k-1) + A_2 \cdot x(k-2) - B_1 \cdot y(k-1) - B_2 \cdot y(k-2) \qquad (4.17)$$

Let  $T_3 = A_1 \cdot x(k-1) + A_2 \cdot x(k-2) - B_1 \cdot y(k-1) - B_2 \cdot y(k-2)$ ... (4.18)

Equation (4.17) is represented as

$$y(k) = A_0 \cdot x(k) + T_3$$
 ... (4.19)

It is to be noted that the intermediate variable  $T_3$  depends on the previous samples and is evaluated in the interval KT - T < t < KT and shall be available before KT sampling point. The output y(k) can be calculated upon the receipt of input x(k). A stepwise procedure is

CUTPUT: 
$$y(k) = A_0 \cdot x(k) + T_3$$
FREIRCCESSING:  $T_3 = A_1 \cdot x(k-1) + A_2 \cdot x(k-2) - B_1 \cdot y(k-1)$ in the interval:  $T_3 = A_1 \cdot x(k-1) + A_2 \cdot x(k-2) - B_1 \cdot y(k-1)$ KT-T < t < KT- B\_2 \cdot y(k-2)DELAY:  $x(k-1) \leftarrow x(k)$ ,  $x(k-2) \leftarrow x(k-1)$  $y(k-1) \leftarrow y(k)$ ,  $y(k-2) \leftarrow y(k-1)$ 

The flow chart of Fig. 4.1 represents the process. Fost calculation is not needed. Following are the steps involved.

> (1) Initialization; A/D D/A convertors and all ; variables
> (2) Compute X(k) ; From A/D converter
> (3) Compute Y(k)
> (4) Output Y(k) ; To D/a converter

(5) Perform Time Delay

(6) Compute  $T_3$ ; Precalculation of  $T_3$ 

Various subroutines in the 3D implementation are given in PROGRAM - 4.2.

PROGRAM -4.2

FILTER SECOND ORDER 3D STRUCTURE

SUBROUTINE INITIALIZATION AND SUBROUTINE INPUT ARE SAME

;AS IN PROGRAM - 3.2 FIG. (3.7) AND PROGRAM - 3.3 FIG. (3.8)

; RESPECTIVELY.

; SUBROUTINE OUTPUT COMPUTES Y = A $\phi$  \* X + T3

:LOOP COUNT IN CX

MOV SI, # & : STACE THOM OUT - 3D : CLP - 3D : STOSW ; SAVE X , Y ; A\$ \* X/2 IN DX ; A\$ \* X AØ [SI] IMUL DX , 1 SAL DX , T3 [SI] ; COMPUTE Y ADD ; RETURN Y IN AX AX, DX MOV ADD SI, # 2 ; PCINTS TO NEXT STAGE LCOP OLP-3D STOSW : SAVE LAST Y RET

;OUTPUT Y IN AX TO OUT PUT PORTØ. PORTØ BEING THE ADDRESS ;ASSIGNED TO D/A CONVERTER IN MEMORY MAPPED I/O MODE

MCV PCRT $\emptyset$ , AX ; COMPUTE DELAY X<sub>2</sub>  $\leftarrow$  X1. LCOP COUNT IN CX DEL - 3D : LEA SI, X1 ; POINTS TO X(k) LEA DI, X2 ; FOINTS TO X(k-1) ; DEL - 3D SUBROUTINE CONTINUES

|                                                      | INC CX<br>REF<br>MCVS<br>RET                                                                                       | ; MCVE X VALUES AND Y<br>; FERFCIMS<br>; BLOCK MOVE OPERATION<br>;                                                                                                                                                                                                                     |            |
|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| ; PREPRC CESS<br>; T3 = A1.X1<br>; LOOP COUNT<br>PRE | + A2.X2 - B1.J                                                                                                     | TICNS BEGIN HERE TO CALCULATE                                                                                                                                                                                                                                                          |            |
| PRE - 3D :                                           | MOV DI, $\#$                                                                                                       |                                                                                                                                                                                                                                                                                        |            |
|                                                      | LODSW<br>IMUL X1+2 DI<br>SUB BX; DX<br>LODSW<br>IMUL X2+2 DI<br>SUB BX, DX<br>SAL BX, 1<br>MCV T3 DI<br>ADD DI, #2 | ; A1/2<br>; X1 * A1/2 IN DX<br>; FARTIAL SUM IN BX<br>; A2/2<br>; X2 * A2/2 IN DX<br>; FARTIAL SUM<br>; B1/2<br>; Y1 * B1/2 IN DX<br>; TCTAL<br>; B2/2<br>; Y2 * B2/2<br>; Y2 * B2/2<br>; T3<br>BX ; STORE<br>2<br>; MCVE INDEX TO FOINT<br>; NEXT STAGE LOCATION<br>; USE COUNT IN CX |            |
| ; POST TROCES                                        | SSING 3D NOT UJ<br>POST-3D                                                                                         | ED IN 3D SECOND ORDER MODULE                                                                                                                                                                                                                                                           |            |
|                                                      | RET                                                                                                                |                                                                                                                                                                                                                                                                                        |            |
| AV : DW AV<br>A1 : DW A1                             | STCRAGE FOR N S<br>1, AØ2<br>1, B11, A21, B2<br>2, B42, A22, B2                                                    | AZN ; AZ FOR N STAGES<br>21 ; STAGE 1 COEFFICIEN                                                                                                                                                                                                                                       | NTS<br>NTS |
|                                                      | ) DULA                                                                                                             |                                                                                                                                                                                                                                                                                        | S TR       |

# 4.4 <u>41 STRUCTURE</u>

Introducing intermediate variable 
$$R_0(z)$$
 in equation (4.1)  

$$\frac{Y(z)}{R_0(z)} \cdot \frac{R_0(z)}{X(z)} = \frac{A_0 + A_1 \cdot z^{-1} + A_2 \cdot z^{-2}}{1 + B_1 \cdot z^{-1} + B_2 \cdot z^{-2}} \cdots (4.20)$$

$$Y(z) = A_0 \cdot R_0(z) + A_1 \cdot z^{-1} \cdot R_0(z) + A_2 \cdot z^{-2} \cdot R_0(z) \cdots (4.21)$$
and  $X(z) = R_0(z) + B_1 \cdot z^{-1} \cdot R_0(z) + B_2 \cdot z^{-2} \cdot R_0(z) \cdots (4.22)$ 
Hence  $R_0(z) = X(z) - B_1 \cdot z^{-1} \cdot R_0(z) - B_2 \cdot z^{-2} \cdot R_0(z) \cdots (4.23)$ 
Let  $R_1(z) = -B_1 \cdot R_0(z) - B_2 \cdot z^{-1} \cdot R_0(z) \cdots (4.24)$ 
So  $R_0(z) = X(z) + R_1(z) \cdot z^{-1} \cdots (4.25)$ 
Let  $Q_1(z) = A_1 \cdot R_0(z) + A_2 \cdot z^{-1} \cdot R_0(z) \cdots (4.26)$ 
So  $Y(z) = A_0 \cdot R_0(z) + Q_1(z) \cdot z^{-1} \cdots (4.27)$ 
Rewriting equations (4.23) through (4.27)
 $R_0(z) = X(z) + R_1(z) \cdot z^{-1} \cdots (4.25)$ 

$$Y(z) = A_0 \cdot R_0(z) + Q_1(z) \cdot Z^{-1}$$
 ... (4.27)

$$-\frac{1}{1-z} = -\frac{B_1 - B_2 -$$

$$Q_1(z) = A_1 \cdot R_0(z) + A_2 \cdot R_0(z) \cdot Z^{-1}$$
 ... (4.26)

In the time domain this set of equations is

$$r_{0}(k) = x(k) + r_{1}(k-1)$$

$$y(k) = A_{0} \cdot r_{0}(k) + q_{1}(k-1)$$

$$r_{1}(k) = B_{1} \cdot r_{0}(k) - B_{2} \cdot r_{0}(k-1)$$

$$q_{1}(k) = A_{1} \cdot r_{0}(k) + A_{2} \cdot r_{0}(k-1)$$

From above it is clear that y(k) is to be calculated first and  $r_1(k)$  and  $q_1(k)$  can be calculated in the interval KT < t < KT + T. A stepwise procedure is

74

CUTPUT  
: 
$$\mathbf{r}_{0}(\mathbf{k}) = \mathbf{x}(\mathbf{k}) + \mathbf{r}_{1}(\mathbf{k}-1)$$
  
 $\mathbf{y}(\mathbf{k}) = \mathbf{A}_{0} \cdot \mathbf{r}_{0}(\mathbf{k}) + \mathbf{q}_{1}(\mathbf{k}-1)$   
POSTCAL CULATION:  $\mathbf{r}_{1}(\mathbf{k}) = -\mathbf{B}_{1} \cdot \mathbf{r}_{0}(\mathbf{k}) - \mathbf{B}_{2} \cdot \mathbf{r}_{0}(\mathbf{k}-1)$   
in the interval  
 $\mathbf{KT} < \mathbf{t} < \mathbf{KT} + \mathbf{T}$   
 $\mathbf{q}_{1}(\mathbf{k}) = \mathbf{A}_{1} \cdot \mathbf{r}_{0}(\mathbf{k}) + \mathbf{A}_{2} \cdot \mathbf{r}_{0}(\mathbf{k}-1)$   
DELAY  
:  $\mathbf{r}_{0}(\mathbf{k}-1) \leftarrow \mathbf{r}_{0}(\mathbf{k})$ ;  
 $\mathbf{r}_{1}(\mathbf{k}-1) \leftarrow \mathbf{r}_{1}(\mathbf{k})$   
 $\mathbf{q}_{1}(\mathbf{k}-1) \leftarrow \mathbf{q}_{1}(\mathbf{k})$ 

Flow chart of Fig. (4.1) represent the 4D structure and the program is given in PROGRAM - 4.3. No precalculation is needed.

FILTER SECOND ORDER 4D STRUCTURE

; INITIALIZATION SUBROUTINE AND INPUT SUBROUTINE ARE SAME ; AS IN. PROGRAM - 3.2 FIG. (3.7) AND PROGRAM - 3.3 FIG. (3.8) ; RESPECTIVELY. ; SUBROUTINE OUTPUT COMPUTES  $R\emptyset = X + R11$  AND OUTPUT SAMPLE ;  $Y = A\emptyset * R\emptyset + Q.11$ . PASS X IN AX, RETURN Y IN AX

; LOCP COUNT IN CX.

LEA DI ; RØ ; PCINT TO RØ MOV ST  $\not= \emptyset$  : STAGE INDEX CUT - 4D : MUV SI  $\neq \emptyset$ ; STAGE INDEX ADD AX, R1 [SI]; R $\emptyset = X + R11$ STCSW ; STORE IN LOCATION CLP - 4D : STCSW IMUL AV SI ; RØ \* AØ  $S_{a}L$ DA, 1 DX , Q1 [SI] ; Y = AU \* RU + Q11ADD AX, DX ; METURN IN AX MUV ; MCVE INDEX TO POINT NEXT SI , # 2 ADD ; STAGE LOCATIONS LOOP OLP-4D : USE COUNT IN CX RET

; OUTPUT YIIN AX TO OUTPUT PORTØ. PORTØ BEING THE ADDRESS ;ASSIGNED TO D/A CONVERTER IN MEMORY MAPPED I/O MODE

MOV PORTØ ; AX

PREPROCESSING 4D NOT USED IN 4D SECOND ORDER STRUCTURE

PRE-4D RET

SAL

:DELAY 4-D CALCULATIONS BEGIN RØ <- RØ AND SO ON ; SI POINTS TO RØ LEA SI, RØ DEL-4D : ; DI POINTS TO RØ1 LEA DI, RØ1 INC CX CLD REP ; PERFORMS ; BLUCK MOVE MOVS RET : POST PROCESSING 4-D CALCULATIONS BEGIN HERE TO CALCULATE  $R1 = -B1.R\emptyset - B2.R\emptyset1$ ,  $Q1 = A1.R\emptyset + A2.R\emptyset1$ . : LOOP COUNT IN CX ; COEFFICIENT POINTER POST-4D0 LEA SI, B1 MOV DI, # ø ; STAGE INDEX ; B1/2 POLP-4D : LODSW IMUL RØ [ DI ] ; RØ \* B1/2 IN DX. AX MOV BX, DX LODSW ; B2/2 ; RØ1 \* B2/2 IN DX, AX IMUL RØ1 [DI] BX, DX  $i_{\rm F} = R1/2$ ADD

> NEG BX ; R1 MOV R1 (DI), BX; STORE R1 IN LOCATION

BX, 1 ; - R1

| LODSW<br>IMUL RØ(DI)<br>MOV BX, DX | ; A1/2<br>; RØ * A1/2            |
|------------------------------------|----------------------------------|
| LODSW                              | ; A2/2                           |
| IMUL RØ1[DI]                       | ; RØ1 * A2/2                     |
| ADD DX, DX                         | ; Q1/2                           |
| SAL BX/, 1                         | ; Q1                             |
| MOV Q1[DI], DX                     | ; STORE Q1 IN LOCATIONS          |
| ADD DI # 2                         | ; MOVE INDEX TO POINT NEXT STAGE |
| LOOP POLP-4D                       | ; LOCATION                       |
| RET                                | ; USE COUNT IN CX                |

4D CONSTANT STORAGE FOR N STAGES

AØ : DW AØ1, AØ2 .... AØN ; AØ FOR N STAGES A1 : DW A11, B11, A21, B21 ; STAGE 1 COEFFICIENTS DW A12, B12, A22, B22 ; STAGE 2 COEFFICIENTS ... DW A1N, B1N, A2N, B2N : STAGE N COEFFICIENTS 4D TEMPORARY STORAGE FOR N STAGES

| RØ :<br>RØ1: |    |    | $DUP(\emptyset)$ |   | $R\emptyset(k)$   |
|--------------|----|----|------------------|---|-------------------|
| ny           | ЪМ | £Ν | $DUP(\emptyset)$ | 0 | $R\emptyset(k-1)$ |
| R1 :         |    |    | $DUP(\phi)$      |   | R1(k)             |
| Q1 :         | DW | Ν  | $DUP(\emptyset)$ |   | Q1(k)             |

# 4.5 <u>1X AND 2X STRUCTURES</u>

Another method of realizing a Digital filter is the cross coupled structure of Fig. 4.2. These derivations of these structures is extensively dealt with in <sup>30</sup>. The difference equations (in time domain) employed for 1X Structure :

$$y(k) = A_0 \cdot x(k) + s_2(k-1) \qquad (4.28)$$
  

$$s_1(k) = g_1 \cdot s_1(k-1) - g_2 \cdot s_2(k-1) + g_3 \cdot x(k) \qquad (4.29)$$
  

$$s_2(k) = g_1 \cdot s_1(k-1) + g_2 \cdot s_2(k-1) + g_3 \cdot x(k) \qquad (4.30)$$

where the g<sub>i</sub> comes from

$$D(z) = A_0 + \frac{A}{Z+p} + \frac{A^*}{Z+p^*}$$

This is a canonical structure, since two delay elements are used for implementing a second order module. A stepwise procedure is

OUTPUT : 
$$y(k) = A_0 \cdot x(k) + s_2(k-1)$$

$$s_{1}(k) = \tilde{s}_{1} \cdot \tilde{s}_{1}(k-1) - \tilde{s}_{2} \cdot s_{2}(k-1) + \tilde{s}_{3} \cdot x(k)$$

$$s_{2}(k) = \tilde{s}_{1} \cdot s_{1}(k-1) + \tilde{s}_{2} \cdot s_{2}(k-1) + \tilde{s}_{4} \cdot x(k)$$

$$s_{1}(k-1) \leftarrow s_{1}(k)$$

$$s_{2}(k-1) \leftarrow s_{2}(k)$$

DELAY

The flow chart of Fig. (4.1) also represents the 1X structure and the program is given in PROGRAM - 4.4.

PROGRAM - 4.4

FILTER SECOND ORDER 1X STRUCTURE

•

; INITIALIZATION AND INPUT SUBROUTINES ARE SAME

; AS IN PROGRAM - 3.2 FIG. (3.7) AND PROGRAM - 3.3 FIG. (3.8) ; RESPECTIVELY.

and the state of t



FIG 4.2 1X AND 2X STRUCTURES

g,

94

2X STRUCTURE

\_\_\_\_

: SUBROUTINE OUTPUT COMPUTES Y = AØ \*X+ S2 : PASS X IN AX, RETURN Y IN AX. LOOP COUNT IN CX DI, X ; POINT TO X OUTP - 1X : LEA ; STAGE INDEX MOV SI,  $\# \emptyset$ ; SAVE X - 1X : STOSW OLP  $\Delta A = \frac{1}{2}$ , 1,  $X = A = \frac{1}{2}$ ,  $X = A = \frac{1}{2}$ ,  $X = A = \frac{1}{2}$ ,  $Y = A = A = \frac{1}{2}$ ,  $Y = A = A = \frac{1}{2}$ ,  $A = X = \frac{1}{2}$ ,  $A = \frac{1}{2$ ; X \* AØ/2 IMUL AØ SI SAL ADD MOV SI , # 2 : MOVE INDEX TO-POINT ADD ; NEXT STAGE LOCATIONS LOOP OLP-1X : USE COUNT IN CX RET : OUTBUT Y IN AX TO OUTPUT PORTØ. PORTØ BEING THE ADDRESS : ASSIGNED TO D/A CONVERTER IN MEMORY MAPPED I/O MODE PORTØ , AX MOV : PREPROCESSING1X NOT USED IN 1X SECOND ÓRDER STRUCTURE PRE-1X RET ; DELAY 1X CALCULATIONS BEGIN  $\mathfrak{S1}(k-1) \leftarrow \mathfrak{S1}(k)$ ;  $\mathfrak{S2}(k-1) \leftarrow$ : S2(k), LOOP COUNT IN CX. ; SOURCE DEL - 1X : LEA SI, S1 ; DESTINATION LEA DI, S11 ; DOUBLE COUNT FOR X1 AND X2 CX, CX ADD ; PERFORM REP MOVS : BLOCK MOVE RET ; POSTCALCULATIONS 1X BEGIN. S1 = G1\*S11 - G2\*S21 + G3\*X ,  $S2 = G1*S21 - G2*S11 + G4*X_{\odot}$ ; COEFFICIENT POINTER POST-1X : LEA SI, G1 ; STAGE INDEX MOV DI, #Ø POLP-1X : LODSV ; G1/2 S11[DI IMUL ; S11\*G1/2 MOV BX, DX LODSW ; G2/2 S21 DI IMUL ; S21\*G2/2 SUB BX, DX ; G3/2 LODSW IMUL X DI ; **∡\***G3/2 ; S1/2 ADD BX, DX ; S1 SAL BX, 1 S1 [DI]. BX ; STORE S1 MOV

### : POSTCALCULATIONS SUBROUTINE FOR 1X MODULE CONTINUES

; G1/2 ; S21\*G1/2 LODSW IMUL S21[DI] MOV BX, DX ; G2/2 ; S11\*G2/2 LODSW IMUL S11 [DI] ADD BX, DX LODSW ; G4/2 IMUL X [DI] ; X\*G4/2 ; X2/2 ADD BX, DX SAL DX, 1 MOV S2[DI], BX ; S2 ; STORE S2 ADD DI # 2 : MOV IN NEXT TO POINT ; NEXT STAGE LOCATIONS LOOP POLP-1X : USE COUNT IN CX RET

: 1X CONSTANT STORAGE FOR N STAGES AO : DW AØ1, AØ2 .... AØN ; AØ FOR N STAGES G1 : DW G11, G21, G31, G11, G21, G41 ; STAGE 1 COEFFICIENTS DW G1N, G2N, G3N, G1N, G2N, G4N; STAGE N COEFFICIENTS ; 1X DATA STORAGES FOR N STAGES N DUP $(\emptyset)$ N DUP $(\emptyset)$  S1(k) X:DW ; INPUTS ; S1(k)S1: DW ; S2(k) ; S1(k-1) ; S2(k-1) N  $DUP(\emptyset)$ S2 : D₩ N DUPQØ) S S11: Dw

Β. 2X STRUCTURE :

S12: DW

N DUP( $\emptyset$ )

This structure is the transpose (Appendix - II) of 1X structure. Equations involved are

$$y(k) = A_0 \cdot x(k) + g_3 \cdot l_1(k-1) + g_4 \cdot l_2(k-1) \dots (4.31)$$

 $l_1(k) = g_1 \cdot l_1(k-1) + g_2 \cdot l_2(k-1) \dots (4.32)$ 

$$l_2(k) = x(k) + g_1 \cdot l_2(k-1) - g_2 \cdot l_1(k-1) \dots (4.33)$$

A Stepwise procedure is

| OUTPUT                                             | : $y(k) = A_0 \cdot x(k) + L_3$                   |
|----------------------------------------------------|---------------------------------------------------|
| POSTCALCULATIONS<br>in the interval<br>KT t KT + T | ;                                                 |
| PRECALCULATIONS                                    | : $L_3 = g_3 \cdot l_1(k-1) + g_4 \cdot l_2(k-1)$ |
| DELAY                                              | : Not necessary                                   |

Fig. (4.1) also represents this 2X structure and the program is given in PROGRAM - 4.5.

FILTER SECOND ORDER 2X STRUCTURE : INITIALIZATION AND INPUT SUBROUTINES ARE SAME : AS IN PROGRAM - 3.2 FIG. (3.7) AND PROGRAM - 3.3 FIG. (3.8) ; RESPECTIVELY. ; SUBROUTINE OUTPUT COMPUTES  $Y = A\emptyset \cdot X + L\beta$  . PASS X IN AX : LOOP COUNT IN CX. OUTP - 2X: LEA DI, X ; POINT TO X SI,  $\neq \emptyset$ ; STAGE INDEX MOV ; SAVE INPUTS TO STAGES OLP - 2X : STOSW ; X\*AØ/2 AØSI IMUL DX, 1 ; X\*AØ SAL DX, L3(SI); COMPUTE Y ADD ; RETURN IN AX MOV MX, DX SI, # 2 : MOVE INDEX TO POINT "DD ; NEXT STAGE LOCATIONS TOOD OTD-5X ; USL COUNT IN CX RETURN

; POSTCALCULATIONS 2X BEGIN L1 = G1.L1(k-1) + G2.L2(k-1), ; L2 = X + G1.L2 (k-1) - G2.L1(k-1). LCOP COUNT IN CX.

|          | ]   | LEA<br>MOV    | SI, G1<br>DI, #≠Ø            | ŝ              | COEFFICIENT POINTER<br>STAGE INDEX                         |
|----------|-----|---------------|------------------------------|----------------|------------------------------------------------------------|
| POLP-2X  |     |               | L11[DI]<br>BX, DX            |                | G1/2<br>L11*G1/2                                           |
|          | -   | LODSW<br>IMUL | L21 [DI]<br>BX, DX           | ŝ              | G2/2<br>L 2 <del>1</del> *g2/2<br>L1/2                     |
|          | ]   | SAL'<br>Mov   | BX, 1                        | 9<br>9         | L1<br>STORE L1(k)<br>BACK POINTER UPTO G1/2                |
|          | . • | LODSW<br>IMUL | Le1 [DI]                     | ŝ              | G1/2<br>G1*L21/2                                           |
| •<br>• . |     | LODSW<br>IMUL | -                            | °<br>9         | G2/2<br>G2* L11/2                                          |
|          |     | SAL<br>ADD    | BX, DX<br>BX, 1<br>BX, Z[DI] | 60 <b>1</b> 00 | PARTIAL SUM<br>L2 - X<br>L2                                |
|          |     | MOV<br>ADD    | L2[DI], BX .<br>DI, # 2      | ŝ              | STORE L2(k)<br>MOVE INDEX TO POINT<br>NEXT STAGE LOCATIONS |
|          |     | LOOP I<br>RET | POLP-2X                      | 2<br>0<br>7    | USE COUNT IN CX                                            |

; DELAY 1X CALCULATION NOT NECESSARY FOR 2X

DEL-2X RET

; PREPROCESSING CALCULATIONS 2X BEGIN. ;  $L^3 = G^{+1}(k-1) + G^{+1}(k-1)$ . LOGP COUNT IN CX.

| PRE-2X | : | LEA SI, G3<br>MOV DI, # Ø                                                          | 9<br>9<br>9                                                                                 | COEFFICIENT POINTER<br>STAGE INDEX                                   |
|--------|---|------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| PLF-2X | : | LODSW<br>IMUL L11[DI]<br>MOV BX, DX                                                | ş                                                                                           | G3/2<br>G3*L11/2                                                     |
|        |   | LODSW<br>IMUL L3 (DI)<br>nDD BX, DX<br>SAL BX, 1<br>MOV L3[DI], BX<br>ADD D1 , # 2 | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5 | G4/2<br>G4*L21/2<br>L3/2<br>L3<br>STORE L3(k)<br>NOVE INDEX TO POINT |
| •      |   | LOOF-PIP-2X.<br>RET                                                                | 9<br>09<br>9<br>9                                                                           | NEXT STAGE LOCATIONS                                                 |

2X CONSTANT STORAGE FOR N STAGES

| G1:  | DW G11,<br>DW G21  |                 |        | STAGE<br>STAGE |   |                            |
|------|--------------------|-----------------|--------|----------------|---|----------------------------|
| •.   | DW-GN1,            | GN2             | 0<br>9 | STAGE          | N |                            |
|      | DW G13,<br>DW G23, |                 |        |                |   | COEFFICIENT<br>COEFFICIENT |
|      | DW GN3,            | GN 4            | ş      | STAGE          | W | COEFFICIENT                |
| АØ   | :DW AØ1,           | AØ2 AØN         |        |                |   |                            |
| 2X / | TEMPORAR           | Y STORAGE FCR 1 | N i    | STLGES         |   |                            |

| Χ:   | DW | Ν | DUP(Ø)           | 9      | IMPUTS TO STAGES           |
|------|----|---|------------------|--------|----------------------------|
| L11  | D₩ | N | DUP(Ø)           | e<br>9 | L1(k) OR L1(k-1)           |
| ·T12 | DW | N | DUP(Ø)           | e<br>J | $L_{2(k)}$ CR $L_{2(k-1)}$ |
| L3   | DW | N | $DUP(\emptyset)$ | ,<br>9 | LJ(k)                      |

4.6 <u>SUMMARY</u>

In this chapter, all the other realization techniques discussed in Section 1.3 are used to implement a second order module. The necessary equations for the Algorithm are derived and the various subroutines implementing the main flow chart of Fig. (4.1) written. Finally, two cross coupled structures are used to implement the same flow chart of Fig. (4.1).

#### CHAPTER - V

CONCLUSIONS AND SUGGESTIONS FOR FURTHER WORK

5.1 CONCLUSIONS

Digital filters have been implemented in harwired logic, special purpose computers and general purpose computers. The recent advent of 16-bit microcomputers with built in multiplication hardware has created a new option for implementing Digital filters. A typical 16bit microcomputer, Intel 8086 has been selected here. There is a significant improvement in the sampling rate because of the availability of multiplication instruction in the Instruction set of 8086 microprocessor.

In this dissertation, the various realization techniques for Digital filters are discussed and their characteristics compared. All the Direct form structures suffer extreme coefficient sensitivity as N, the order of the filter grows large. In order to avoid coefficient sensitivity, the Digital filter Transfer function is implemented as a cascaded or parallel combination of second order modules. The second order module in itself can be any one of the Direct form structures.

The salient features of the Intel 8086 microprocessor has been studied in considerable detail. Using the Instruction set of 8086 microprocessor the Assembly language programs for the various realizations of a second order module written. The mathematical equations for the corresponding algorithms are derived prior to the R.T.L. flowchart model. Main programs for the cascade and parallel Digital filters are also written making use of the various subroutines and each stage in itself is a second order 1D structure.

5.2 SUGGESTIONS FOR FUTURE WORK

Because of the non-availability of the Intel 8086 microcomputer kit the various programs could not be tested. These programs can be tested as and when a kit is made available in the Department.

All of 16-bit microprocessors viz. Intel 8086 Motorola MC 68000, Texas Instruments TMS 9900, Zilog Z8000, Fairchild 9445 are similar in basic word size and arithmetic capabilities. The programs written down using the Intel 8086 microprocessor can be modified for the rest of the microprocessors.

In this dissertation Intel 8086 microprocessor is used to implement Digital filters - one section of Digital signal processing. It can be extended to other sections of Digital signal processing. This leads to the microcomputer study of **S**ampled Data Systems.

#### REFERENCES

- Rabiner, L. R. and Gold, B. 'Theory and Application of Digital Signal Proceeding', Englewood Cliffs, N.J.; Prentice-Hall, Inc., 1975.
- 2. Bogner, R. E. and Constantinides, A. G. 'Introduction to Digital Filtering', New York : John Wiley, 1975.
- 3. Tretter, S. A. 'Introduction to Discrete Time Signal Frocessing', New York : John Wiley, 1976.
- 4. Oppenheim, A. V. and Schafer, R.W. 'Digital Signal Processing', Englewood Cliffs, N. J. : Prentice Hall, Inc., 1975.
- 5. Lam, H. Y-F. 'Analog and Digital Filters Design and Realisation', Englewood Cliffs, N. J. : Prentice Hall, Inc., 1979.
- Kaiser, J. F. 'Digital Filters' in Kuo, F. F. and Kaiser, J. F. eds., System Analysis by Digital Computer, Chap. 7, New York : John Wiley, 1966.
- 7. Rader, C. M. and Gold, B. 'Digital Filter Design Techniques in the Frequency Domain', Proc. IEEE, Vol. 55, Feb. 1967, pp. 149-171.

- 8. Rabiner, L. R., Cooley, J. W. et.al 'Terminology in Digital Signal Processing' IEEE Trans. on Audio Electroacoust., Vol. AU-20. Dec. 1972, pp 322-377.
- 9. Jackson, L. B., Kaiser, J. F., and Mc donald, H. S. 'An approach to the Implementation of Digital Filters', IEEE Trans. on Audio Electroacoust., Vol. AU-16, Sept. 1968, pp. 413-421.
- 10. Rabiner, L. R., Zaiser, J. F., Herrmann, O. and Dolan, M. T. 'Some Comparisons between FIR and IIR Digital Filters'. Bell System Tech. J. Vol. 53, 1974, pp. 305-331.
- 11. Fettweis, A. 'A general Theorem for Signal Flow Networks with Applications', 'Arch. Elek. Übertragung' Vol. 25 1971. pp. 557-561. Reprinted in Lawrence, R. R. & Rader, C. M. 'Selected Papers in Digital Signal Processing' New York : John Wiley, 1972.
- 12. Seviora, R. E. and Sabaltash, M. 'A Tellegen's Theorem for Digital Filters', IEEE Trans. Circuit Theory, Vol. CT-18, Jan. 1971, pp 201-203.
- 13. Weissberger, A. J. 'MG3/LSI Microprocessor Solection', Electronic Design, Vol. 22 No. 12, June 1974.

- 14. Ogdin, J. L. 'Microcomputers : Promises and Practices', IEEE Intercon. 74, Session 17, N.Y., March 1974,
- 15. Cushman, R. H. 'The Intel 8080 : First of the Second Generation Microprocessors', EDN, Vol. 19, No. 9, May 1974.
- 16: George, A: 'Get minicomputer feature at ten times the 8080 speed with the 8086', Electronic Design, Vol: 26, Sept. 1978, pp: 60-66.
- 17. Katz, B. J., Morso, S. P., Pohlam, W. P. and Brucc,
  W. R. 18086 microcomputer bridges the gap between
  8 and 16 bit designs', Electronics International,
  Vol: 51, Feb. 1978, pp. 99-104.
- 18. Morse, S. P., Pohlman, W. B., and Ravenel, B. W. !The Intel 8086 microprocessor, a 16 bit Evolution of the 8080! [EEE Trans. Computer, Vol. 11 No. 6, June 1978,
- 19. Morse, S. P., Ravenel, B. W., Mazor, S. and Pohlman, W; B., Intel Microprocessors - 8008 to 8086!, IEEE Trans, Computer, Vol.13NOG. Feb. 1980, pp. 42-60.
- 20. Garland, M. 'Introduction to Microprocessor System Design', Tokko: Mc Graw Hill Kogakusha, 1979.

- 21. Mathur, A. P. 'Introduction to Microprocessors', New Delhi : Tata Mc Graw Hill, 1980.
- 22. MCS-86 User's Manual, Intel Corp., Santa Clara, CA, 1979.
- 23. Neale, D. F., and Wilson, D. R. 'Application of Microprocessors in Signal Processing', Warsaw, Polish-English Sominar on Real Time Process Control, Jan. 1977.
- 24. Nagle, Jr., H. T., and Carrol, C. C. 'Organizing a Special Purcose Computer to realize Digital Filters for Samplea data Systems', IEEE Trans. Audio Electroacoust. Vol. AU-16, Sept. 1978.
- 25. Nagle, Jr., H. T. and Nelson, V. P., 'Digital Filter Implementation on 16-bit Microcomputers', IEEE Micro, Fet. 1981, pp. 23-41.
- 26. Hwang, S. Y. 'An Optimization of Cascade Fixed Point Digital Filters!, IEEE Trans. Circuits and Systems, Vol. CAS-21, No. 5, Jan. 1974, pp 163-168
- 27. Lee, W. S. 'Optimization of Digital Filters for Low Round off Noise,' IEEE Trans. Circuits and Systems, Vol. CAS-21, No. 5, May 1974, pp. 423-431

28. Liu, B. and Peled, A. 'Heuristic Optimization of the Cascade Realization of Fixed Point Digital Filters IEEE Trans. Acoustics, Speech and Signal Processia Vol. ASSP-23, No. 5, Oct. 1975, pp. 464-473.

- 29. Nagle, Jr., H. T., and Carroll, C. C. 'Realization of Digital Controllers', Proc. IFAC Symp. Auto Control in Space, Armenia, USSR, Aug. 1974, pp. 23-35.
- 30. Jackson, L. B., Lindgren, A. G., and Kim, Y. "Optimal Synthesis for Second Order State Space Structure for Digital Filters", IEEE Trans. Circuits and Systems, Vol. CAS-26, No. 3, March 1979, pp. 149-152.

#### APPEND'X - I

#### CLASSIFICATION OF DIGITAL FILTERS

The <u>term</u> Digital filtering refers to a computational algorithm performed on a sampled input signal resulting in a transformed output signal. The computational process can correspond to high pass filtering, low pass filtering, band pass filtering, integration, differentiation etc. The process is assumed to be linter, that means the principle of superposition applies to the input output relationship. The input signal is a sequence of numbers from either an Analog-to-Digital (A/D) converter or a direct digital input -source. The output signal is either a direct digital sequence or a regenerated analog signal from a Digital-to-Analog (D/A).

The unique advantages offered by Digital filters are :

- 1. The performance from unit to unit is stable and repeatable.
- 2. Arbitrarily high procision is achieved that is limited only by the number of bits carried in memory and by the input and output resolution capabilities
- 3. No impedance matching problems exist in the digital domain.
- 4. Oritical filter frequency can be placed without restriction but it influences the required precision
- 5. Component value variation problems are non existent
- 6. Greater flexibility is achieved since filter response can be changed by varying the proper arithmetic coefficients,

- 7. The intrinsic possibility of time sharing major implementation section exist.
- 8. Small size results from integrated circuit implementation.
- 9. Periodic calibration as is required with analog circuits is eliminated.
- 10. Performance limitations of physical analog components are avoided.

Two general types<sup>1,5,8</sup> of configurations of Digital filters are :

- (a) Recursive Digital filter
- (b) Non-Recursive Digital filter

The Recursive Digital filter is a discrete time filter which is realized via a recursion relation. It means the output samples of the filter are explicitly determined as a weighted sum of past output samples as well as past and/or present input samples. For example

$$y(n) = a_0 \cdot x(n) + a_1 \cdot x(n-1) + a_2 \cdot x(n-2)$$
  
-  $b_1 \cdot y(n-1) - b_2 \cdot y(n-2) \dots (A1,1)$ 

The Non-Recursiva Digital filter is a discrete time filter for which the output samples of the filter are explicitly determined as a weighted sum of past and present input samples only. For example,

 $y(n) = a_{0.x(n) + a_1.x(n-1) + a_2.x(n-2)}$  (A.1.2)

Thus Recursive Digital filters are those filters which possess a transfer function as given by equation (1.3)

$$D(z) = \frac{\sum_{i=0}^{M} A_{i} \cdot z^{-1}}{1 + \sum_{i=1}^{N} B_{i} \cdot z^{-1}} \dots \dots (A1.3)$$

It has all common factors cancelled, The denominator coefficients are identically nonzero. The zeros and poles are located on the  $z^{-1}$  plane. The Non Recursive Digital filters however possess a transfer function which is a polynomial of  $z^{-1}$  and all common factor in equation (1.3) are cancelled. this case, the transfer function is of the form

$$D(z) = D_0 + D_1 \cdot z^{-1} + D_2 \cdot z^{-2} \cdots D_N z^{-N} \cdots (A1 \cdot 4)$$

This equation is a finite degree polynomial, no poles can appear in any finite part of the  $Z^{-1}$  plane. Non Recursive filter, as a result is always stable. (This of course is consistent with the absence of feed back).

Consider the General transfer function of equation (A1.3) which is reproduced here for convenience in the factor form.

$$D(z) = \frac{\prod_{i=1}^{N} (1 - Z_i z^{-1})}{\prod_{i=1}^{N} (1 - p_k z^{-1})} \dots (A1.5)$$

where  $p_1, p_2 \cdots p_M$  are the poles and  $Z_1, Z_2 \cdots Z_M$  are the zeros.

Any filter whose transfer function is given by (A1.5) with  $N \ge |$ is called an infinite impulse response (IIR) pigital filter, because there does not exist a finite integer L such that

$$d(n) = 0$$
 for  $n > L$ 

where d(n) is the impulse response of the filter. For IIR digital filters assume  $M \leq N$ . This assumption holds true for almost all cases of practical interest. A partial fraction expansion of (A1.5) is

$$D(z) = \int_{0}^{+} \frac{\int_{1}^{-} \frac{1}{z^{-1}}}{1 - p_{1} z^{-1}} + \frac{\int_{2}^{-} \frac{1}{z^{-1}}}{1 - p_{2} z^{-1}} + \frac{\int_{N}^{-} \frac{1}{z^{-1}}}{1 - p_{N} z^{-1}}$$

where  $\xi_0 = \emptyset$  if N = M= 0 if N > H

and  $\xi_i = (1 - p_j Z^{-1}) D(Z)/Z = p_j$  for  $i = 1, 2 \dots N$ Hence, the corresponding impulse response is

$$h(n) = \left[ \xi_1 \cdot p_1^{n} + \xi_2 \cdot p_2^{n} + \dots + \xi_N \cdot p_N^{n} \right] \mathcal{U}(n) + \xi_0 \cdot \delta(n)$$

Clearly, the necessary and sufficient conditions for the impulse response above to satisfy the stability criteria of

$$\sum_{n=-\infty}^{\infty} |h(n)| < 2$$

is that

 $p_{i} < 1$  for  $i = 1, 2 \dots N$ 

That is, all the pole locations of the digital filter are within the unit circle in the Z-plane.

When the transfer function of a Digital filter is given by equation

 $D(z) = D_0 + D_1 \cdot Z^{-1} + \dots D_M \cdot Z^{-M} \dots$  (A1.6)

which is equivalent to the case when N = 0, the Agital filter is said to be of finite impulse response (FIR) type. This name is used because the impulse response of equation (A1.6) has the property that h(n) = 0 for n > M and for n < 0. That is the corresponding impulse response is of finite duration. In this case, there are no poles and this type of filter is always stable.

From the above it is clear that Transfer function in equation (A1.3) represents an IIR Digital filter while the Transfer function of equation (A1.4) represents an FIR Digital filter. The FIR filters are all stable and casual while the IIR filter is stable if the poles of D(2) are within the unit circle in the Z plane, and casual if  $B_0$  is the first nonzero coefficient in the denominator. As we are concerned with casual filters it is convenient to assume  $B_0 = 1$ .

The major differences are listed in 10 . TIR Digital filters cannot have perfect linear phase characteristics while FIR filters are always designed to have linear phase characteristic. Implementation of an FIR Digital filter requires more computations and more digital compononts; hence FIR filters are more expensive than IIR filters The amount of computation and hardware needed to perform a filtering process is usually an important practical consider tion. In general IIR Digital filters require lesser computations and/or hardware to achieve a particular filtering function than those required by the corresponding FIR Digital filtors. FIR Digital filters are called for to perform tasks not possible and/or not practical by IIR Digital filters such as linear phase filters, and multirate filters where the input signals and the corresponding output signals are sampled at different rates.

Although IIR Digital filters are generally realized recursively and FIR filters nonrecursively, IIR filters can be realized nonrecursively and FIR filters can be realized recursively.

APPENDIX - II

97

PRINCIPLE OF TRANSPOSE AND TRANSPOSITION THEOREM

Tellegen's theorem is an important basic theorem of conventional network theory. As Digital filter networks are not subject to Kirchoff's laws, Tellegen's theorem in its most general form does not apply. A restricted form of Tellegen's theorem referred to as the difference form, can be derived 5,11,12 rom this a number of useful properties of digital networks can be developed. In classical networks Tellegen's theorem is in the form of a relationship between the voltage distribution in one network and the current distribution in a second network, where the only relationship between the networks is that they have the same topology but otherwise unrelated. In a similar manner, if we consider every flowgraph to have a branch in each direction between every pair of nodes, with the transmission of some of the branches being zero. then any two flow graphs with the same number of nodes can be considered to be topologically equivalent.

Consider two signal flow-graphs with the same topology Let N denote the number of network nodes. The network node variables, branch outputs and source node values in the first network are denoted by  $w_k$ ,  $v_{jk}$  and  $x_j$  respectively and in the second network by  $w'_k$ ,  $v'_{jk}$  and  $x'_j$ . Then, the Tellegen's

$$\sum_{k=1}^{N} \sum_{j=1}^{N} (w_{k} \cdot v'_{jk} - w'_{k} \cdot v_{jk}) + \sum_{k=1}^{N} (w'_{k} \cdot x_{k} - w'_{k} x_{k}) = 0$$
... (A2.1)

Proof: The proof of equation (A2.1) follows almost directly from the definition of a signal flow graph. The branch outputs are related to the node variables and source inputs by

$$w_{k} = \sum_{j=1}^{N} v_{jk} + \sum_{j=1}^{M} S_{jk} \dots (A2.2)$$

Adopting the convention that each network is drawn in such a way that each network node has associated with it a source node connected to it by a branch with unity transmittance. Also, this source node is not connected to any other network nodes.

With the convention regarding source nodes equation (A2.2). changes to

$$w_k = \sum_{j=1}^{N} v_j + x_k$$
 .... (A2.3)

Writing the identify

$$\sum_{k=1}^{N} (w_{k} w'_{k} - w'_{k} w_{k}) = 0 \qquad \dots \qquad (A2.4)$$

Equation (A2.1) follows in a straightforward manner by substituting equation (A2.3) into equation (A2.4).

Equation (A2.1) is referred to as Tellegen's theorem for signal flow graphs or for digital filters. If variables  $W_k$ ,  $W_k$ ,  $V_{jk}$ ,  $V'_{jk}$ ,  $X_k$  and  $X'_k$  are derived through a linear operation from  $w_k$ ,  $w'_k$ ,  $v'_{jk}$ ,  $v'_{ik}$ ,  $x_k$  and  $x_k$  respectively, then

$$\sum_{k=1}^{N} \sum_{k=1}^{N} (N \cdot V'_{jk} - W_{k} \cdot V_{jk}) + \sum_{k=1}^{N} (W_{k} \cdot X'_{k} - W'_{k} \cdot X_{k}) = 0$$
... (A2.5)

Thus Tellegen's theorem applies either to the sequence values or to the Z-transforms.

For passive analog networks consisting of interconnections of resistors, inductors and capacitors, the notion of reciprocity plays an important role. For digital networks there exists corresponding notions of reciprocity and interreciprocity consider a given network excited by two different sets of sources. The Z-transforms of the source node values for the two different sets will be denoted by  $X_k$  and  $X'_k$ . The value of the node variables of the k'th node when the network is excited by the unprimed sources will be denoted by  $V_k$ . When the network is excited by the primed sources, this variable will be denoted by  $W'_k$ . The network is said to satisfy reciprocity if for any two signal distributions.

$$\sum_{k=1}^{N} (W_k X'_k - W'_k X_k) = 0 \qquad \dots \qquad (A2.6)$$

As a consequence of reciprocity, if we excite the graph at network node [a! and observe the output at node [b]; then for a reciprocal graph, the same excitation at node [b] will result in the same output at node [a]:

Most digital networks are not reciprocal: A related concept that is more useful with regard to digital network is that of interreciprocity: In this case we consider two distinct signal flow graphs: Let  $X_k$  denote the source node values and  $W_k$  denote the node variables for one network and  $X'_k$  and  $W'_k$  the source node values and network node variables for the second network; Then the two networks are said to be interreciprocal if

$$\sum_{k=1}^{N} (\mathbf{x}_{k} \mathbf{x}_{k}^{*} - \mathbf{x}_{k}^{*} \mathbf{x}_{k}) = 0 \quad \dots \quad (A2:7)$$

Equations (A2:7) is similar to equation (A2.6); here for reciprocity the primed and unprimed network differ only in the sources, whereas for interreciprocity both the sources an and branch transmittance: can differ in the primed and unprimed networks. A network that is reciprocal is also interreciprocal with its lf.

#### TRANSPOSITION THEOREM

A property of digital networks is that they are interreciprocal with their transpose. The transpose of a flow graph is generated by reversing the directions of all

the branches but leaving their transmittances the same.

Consider a digital network where  $W_k$  denotes the node variable for the k'th node. The transmission from node 'j' to node 'k' is denoted by ' $F_{ik}$ '.

$$S_{o}.V_{jk} = F_{jk}.H_{j}$$

In the transposed network, the node variable of the k'th node is denoted by  $J_k$  and the branch transmittance between nodes 'j' and 'k' is denoted by F'<sub>ik</sub>, so that

$$V'_{jk} = F'_{jk} \cdot w'_{j}$$

By definition of the transposed network  $F'_{jk} = F_{jk}$ 

To prove that a network and its transpose are interreciprocal - i.e. to show that equation (A2.7) holds for the above conditions, we utilize the fact that a network and its its transpose have the same topology so that Tellegen's theorem equation (A2.5) holds.

#### Thus,

$$\sum_{j=1}^{N} \sum_{k=1}^{N} (W_{k} \cdot V'_{jk} - W'_{k} \cdot V_{jk}) + \sum_{k=1}^{N} (W_{k} \cdot X'_{k} - W'_{k} \cdot X_{k}) = 0$$
... (A2.8)

Substituting value of  $V_{jk}$  and  $V'_{jk}$  in (A2.8) we obtain

$$\frac{\sum_{j=1}^{N} \sum_{k=1}^{N} (W_{k}, W_{j}, F'_{jk} - W'_{k}, W_{j}, F_{jk})}{+ \sum_{k=1}^{N} (W_{k}, X'_{k} - W'_{k}, X_{k})} = 0$$

or 
$$\sum_{j=1}^{N}$$
,  $\sum_{k=1}^{N}$   $W_k \cdot W'_j \cdot F'_{jk} - \sum_{j=1}^{N}$   $\sum_{k=1}^{N}$   $W'_k \cdot W_j \cdot F_{jk}$   
+  $\sum_{k=1}^{N}$   $(W_k \cdot X'_k - W'_k - W'_k \cdot X_k) = 0$  ... (A2.9)

102

Interchanging the indicaes of summation in the first double sum of equation (A2.9).

$$\sum_{j=1}^{N} \sum_{k=1}^{N} (W'_{k} \cdot W_{j} \cdot F'_{jk} - W'_{k} \cdot W_{j} \cdot F_{jk}) + \sum_{k=1}^{N} (W_{k} \cdot X'_{k} - W'_{k} \cdot X_{k}) = 0 \dots (A2.10)$$

Since, the primed and unprimed networks are transposes,  $F'_{jk} = F_{jk}$ , and therefore the double sum is zero and  $N_{k=1}^{(W_k \cdot X'_k - W'_k \cdot X_k)} = 0$ , which proves that a network and its transpose are interreciprocal.

For single input - single output networks, a network and its transpose have the same transfer function. For a 2nd order section the diagramatic changes are shown in Fig. (A2.1).



10.3

#### <u>APPENDIX - III</u>

## RISE OF INTEL MICROPROCESSOR 8008 TO MICROPROCESSOR 8086 AND THEIR COMPARISON

The Intel 8008 <sup>14,17,19</sup> was the first 8 bit, monolithic, p channel MOS device to be developed. The 8008 processor architecture is quite simple compared to that of today's microprocessors. The instruction set is small but symmetrical with only a few operand addressing modes available. The addressable memory space is 16K bytes which seemed to be lot back in 1970 when memories were expensive and LSI devices were slow. The memory size limitation was imposed by the lack of available pins.

The microprocessor does not have instructions with direct addresses since two CPU registers must be used to reference main storage. Also, some operations such as moving data from one place in storage to another, are somewhat awkward. Another problem area is that associated with an interrupt. Interrupt processing was not a requirement for the 8008, only the most primitive mechanism conceivable not incrementing the program counter was provided. Such a mechanism permits an interrupting device to jam an instruction into the processor's instruction stream. Since memory is addressed during the interrupt, two of the s Cratchpad registers are to be reserved as interrupt

and the second of the second second

registers. This reduces the effective number of the registers in the scratch pad file from seven to five. There is no instruction for disabling the interrupt mechanism; thus this function must be realized with external hardware. Finally, the single 8 bit bus into processor requires a large amount of support hardware. If a single IC is produced which will replace these components, this processor will be valuable in many more applications.

The Intel 8080 <sup>16,17,19</sup> an 8 bit, monolithic. n channel MOS device is a second generation microprocessor with many improvements over its predecessor, the 8008<sup>15</sup> The 8080 was the first processor designed specifically for the microprocessor market. The main objective of the 8080 was to obtain a ten-to-one improvement in throughput eliminate many of the 8008 short comings that has by 1973 become apparent and provide new processing capabilities not found in the 8008. The latter included handling of the 16 bit data types, BCD arithmetic, enhanced operand addressing modes, and improved interrupt processing. Memory costs had come down and processing speed was approaching TTL, so larger memory spaces seemed more practical and direct addressing of more than 16K bytes was achieved. Symmetry was not a goal because the benefits to be gained from making the extensions symmetric would not have

justified the resulting increase in chip size and opcode space. Most of the external logic required to support the 8008 is on the 8080 CPU, and all the important interfacing signals are generated on designated processor pins.

The 8080 architecture is significantly different from that of 8008. The byte handling facilities are augmented with a limited number of 16-bit facilities. The memory space is 64K bytes, the address bus 16 bits wide, so an entire address can be sent down the bus in one memory cycle. The 8080 extends the 32 port capacity of the 8008 to 256 input ports and 256 output ports. The 8080 processor contains a file of seven 8-bit general registers, a 16-bit program counter and stack pointer and five 1-bit flags. The stack is contained in memory (RAM) instead of on the chip, a strategy which removes the restriction of only seven levels of nested subroutines. The programmer can directly access the stack pointer in 8080, unlike in the 8008. A fifth flag, Auxiliary Carry, augments the 8008 flag set. It indicates whether a carry was generated out of the four low order bits. This flag, in conjunction with a decimal adjust instruction, makes possible packed BCD addition. The 8080 includes the entire 8008 instruction set as a subset. The added instructions provide some new operand addressing modes and some 16 bit data manipulation

facilities. The 8080 has an interrupt mechanism identical to that of 8008, but includes instructions for enabling and disabling the mechanism.

The 8080 is packaged in a 40 pin DIP and has separate address and data buses having instate outputs. As a result of the separate data and address buses, a microcomputer is formed with as few as six TTL packages. A disadvantage, however, is that 8080 requires three separate power supplies.

In 1976 advances in technology allowed Intel to consider enhancing the 8080. The objective was a processor set utilizing a single power supply and requiring fewer chips (the 8080 required both an oscillator chip and a system controller chip). The new processor, called the Intel 8085 was constrained to be compatible with the 8080 at the machine-code level. This meant that extensions to the instruction set could use only the 12 unused opcodes of the 8080. Architecturally, the 8085 turned out to be not much more than a repackaging of the 8080. The major differences were added features such as on chip oscillator, power on reset, vectored interrupts, decoded control lines, a serial I/O port and a single power supply. Two new instructions RIM and SIM, were added to handle the serial port and the interrupt mask.

The Intel 8086 was designed to provide an order of magnitude <sup>17,18,19</sup> increase in processing throughput over the 8080. The processor was to be compatible with the 8080 at the assembly language level, so that existing 8080 software could be reassembled and correctly executed on the 8086. To allow this, the 8080 register and instruction set were to appear as logical subsets of the 8086 registers and instructions.

The goals of the 8086 architecture were symmetric extension of existing 8080 features and the addition of processing capabilities not found in the 8080. New features and capabilities included 16 bit arithmetic, signed 8-16-bit arithmetic (including multiply and divide), efficient interruptible byte string operations, improved bit manipulation facilities and mechanisms to provide for re-entrant code, position-independent code, and dynamically relocatable programs. By 1977 memory had become inexpensive and microprocessors were being used in applications requiring large amounts of code and data. Another achievament was the direct addressing of more than 64K bytes and support of multiprocessor configurations.

The 8086 processor architecture comprises a memory structure, a register structure, an instruction set, and an external interface. The 8086 external interface consists of

interrupts, multiprocessor synchronization and resource sharing, this all goes way beyond the facilities provided in the 8080. The 8086 can access upto one million bytes of memory and upto 64K input/output ports. The I/O space ports a 256-fold increase over the 8080. consists of 6.4 K The processor contains a total of thirteen 16-bit registers and nine 1-bit flags. The 8080 register set is a subset of the 8086 register set as shown in Fig. (A3.1). The 8086 instruction set is not a superset of the 8080/8085 instruction set. Most of the 8080/8085 instructions are included in the 8086 while some of the infrequently used ones (e.g. conditional calls and returns) are not. The operand addressing modes of the 8080 have been greatly enhanced. Significant new operations includes : (a) multiplication and division of signed and unsigned binary numbers as well as unpacked decimal numbers, (b) move, scan and compare operations for strings up to 64 K bytes in length, (c) nondestructive bit testing, (d) byte translation from one code to another. (e) software generated interrupts and (f) a group of instructions that can help coordinate the activities of multiprocessor systems.

The more six years of microprocessor evolution has yielded a three orders of magnitude performance improvement. TABLE - 2.1 and TABLE 2.2 trace the comparison of these processors in respect of features, and technology.



# FIG A 3.1 8080 SUBSET OF 8086 REGISTER

. . . . . .

TABLE - A2.1

FEATURE COMPARISON - INTEL MICROPROCESSORC 1972-78

|          |                          |                      |                         | -                       |                                    |
|----------|--------------------------|----------------------|-------------------------|-------------------------|------------------------------------|
|          | FEATURE                  | 8008                 | 8080                    | 8085                    | 8086                               |
|          | Introduction<br>date     | 1972                 | 1974                    | 1976                    | 1978                               |
| ŝ        | No. of instruc-<br>tions | 48                   | 72                      | 85                      | 97                                 |
| ě.       | No. of flags             | 4                    | Ŀ                       | Ŀ                       | 6                                  |
| 4        | Maximum memory<br>size   | 16 K bytes           | 64 K bytes              | 64 K bytes              | 1 M bytes                          |
| 2        | I/O ports                | 8 input<br>24 output | 256 input<br>256 output | 256 input<br>256 output | 64 K input<br>64 K ou <b>p</b> put |
| 6.       | No. of pins              | 18                   | 40                      | 40                      | 40                                 |
| ٦.       | Address Bus<br>width     | *                    | 16                      | 16                      | 20 <b>*</b>                        |
| ŵ        | Data Bus<br>width        | *<br>თ               | ω                       | ω                       | 16*                                |
| <b>o</b> | Data types               | 8 bit unsigned       | 8 bit unsigned          | 8 bit unsigned          | 8-16 bit<br>unsigned               |
|          |                          |                      | 16 bit unsigned<br>Itd. | 16 bit "<br>Ltd.        | 8-16 bit "                         |
|          |                          |                      | Packed BCD Ltd.         | Packed BCD Ltd.         | Packed BCD<br>Unpacked BCD         |

TABLE - A2.1 (Contd.)

.

| 8086 | Memory direct         | •                       | Immeatave               |                                                                                                                |  |
|------|-----------------------|-------------------------|-------------------------|----------------------------------------------------------------------------------------------------------------|--|
| 8085 | Mamory direct<br>Ltd. | Memory irdiract<br>Ltd. | Register<br>Tmmediate** | are a part of the second s |  |
| 8080 | Memory direct         | Manory indirect<br>Ltd. | Rogistor                | Imnediate**                                                                                                    |  |
|      | Barister              | Tmpediate**             |                         |                                                                                                                |  |
|      | FEADURE               | 10. Addressing<br>modes |                         |                                                                                                                |  |

.

Address and Data bit multiplexed

\*

Memory can be addressed as a special case by using register M.

No. of Concession, Name

r;

.

\*\*

,

.

| 1. Sil:<br>2. Clo<br>3. Min:<br>5. Appi<br>6. Ave | CHARACTERISTICS<br>CHARACTERISTICS<br>Silicon gate technology<br>Silicon gate dalay<br>Minimum gate dalay<br>Typical speed<br>an gate dalay<br>Typical speed<br>power product<br>Approximate Nos.<br>of Transistors<br>Average Transistor<br>density | 8008<br>P-Channel<br>Enhancement<br>Load Device<br>0.5 - 0.8<br>MHz<br>30 :-anos<br>100 pj<br>2000<br>8.4 | 8080<br>N-Channel E.L.D<br>2 - 3 MHz<br>15 ns<br>40 pj<br>40 pj<br>15<br>7.5 | 8085<br>N-Channel<br>Depletion<br>Load Device<br>5 ms<br>10 pj<br>6500<br>5°7 | 8086<br>Scaled N-Channel<br>(HMOS) D.I.D.<br>5 - 8 MHz<br>3 ns<br>2 pj<br>2 ocooo<br>20000<br>2.5 |
|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|

TABLE - A2.2

111

.

-

## APPENDIX - IV

## INSTRUCTION SET OF 8086 MICROPROCESSOR

The instruction set of 8086 microprocessor can be studied under the following heads :

- (A) Data Transfer Instructions
- (R) Arithmotic Instructions
- (C) Bit Manipulation Instructions
- (D) String Instructions
- (E) Program Transfer Instructions
- (F) Processor Control Instructions

The fourteen data transfer instructions can be studied under the following four heads. The flags in this case remain unaltared. (A) DATA TRANSFER INSTRUCTION (a) General Purpose 1. MOV Move byte or word (a) Rug / mamory, rog 100010dw mod rog r/m Reg16/memory16, (b) 100011d0 mod reg r/m Seg.reg (c) Acc, memory 101000dw Addr low Addr high

|     | · · · | immod | 1011w <b>r</b> eg | daba    | data if w=1            |
|-----|-------|-------|-------------------|---------|------------------------|
| (೧) | Mom,  | immud | 1100011w          | moā 000 | r/m data data<br>if w= |

2. PUSH PUSH word onto stack (a) Register 01010 reg

(b) Seg-reg 000reg110 (CS legal)

(c) Memory 16/reg16 11111111 mod110r/m

3. POP POP word off stack

(a) Register 01011reg

(b) Seg-reg 000reg11<sub>1</sub> (CS-illegal)

(c) Memory/reg 10001111 mod000r/m

4. XCHG Exchange byte or word

(a) Reg/mem with '1000011w modregr/m register

(b) Reg, acc 10010 reg

5. XLAT Translate byte

(a) Translate byte 11010111 to AL

#### (b) Input/Output

6. IN Input byte or word
(a) Acc, immed 1110010w Port
(b) Acc, DX 1110110w
7. OUT Cutput byte or word
(a) Acc, immed 1110011w Port
(b) Acc, DX 1110111w

- (c) Address Object
  - 8. LEA Load Effective Address
    - (a) Load EA to reg 10001101 modregr/m
  - 9. LDS Load pointer using DS
    - (a) Load pointer to DE 11000101 modregr/m
  - 10. LES Load pointer using ES
    - (a) Load pointer to ES 11000100 modregr/m

#### (d) Flag Transfer

- 11. PUSHF Push flags onto stack
  - (a) Load AH with flags 10011100
- 12. POPF Pop flags off stack
  - (a) Pop flags 10011101
- 13. SAHF Store AH register in flags
  - (a) Store AH into flags 10011110
- 14. LAHF Load AH register from flags
  - (a) Load AH with flags 100:1111

#### B. ARITHMETIC INSTRUCTIONS

8086 arithmetic operations may be performed on 4 types of numbers unsigned, binary, signed binary, unsigned packed decimal and unsigned unpacked decimal. Following is the effect of the flags.

CF Carry flag : ADC and SBB incorporate the Carry flag in their operations. The Carry flag is set(a) if an addition results in a carry out of the high order bit of the result and (b) if a subtraction results in a borrow into the high order bit of the result. Otherwise the CF is cleared.

AF Auxiliary Carry flag : The AF is set (a) if an addition results in a carry out of the lower order half byte of the result and (b) if a subtraction results in a borrow into the lower order half byte of the result. The AF is provided for the decimal adjust instructions.

SF Sign flag : Arithmetic and Logical instruction set the Sign flag equal to the high order bit (7 or 15) of the result. Programs performing unsigned operations ignore SF.

ZF Zeroflag : If the result of an Arithmetic or Logical Operation is zero, the ZF is set, otherwise ZF is cleared.

PF Parity flag : If the low order eight bits of an Arithmetic or Logical result contains an even number of 1-bits, then the PF is set, otherwise it is cleared. It also checks ASCII characters for correct parity.

OF Overflow flag : If the result of an operation is too large a positive number, or too small a negative number to fit in the destination operand (excluding the

sign bit) then the OF is set, otherwise it is cleared. OF indicates signed arithmetic overflow.

(a) Addition

(b)

1. ADD Add byte or word Reg /memory with register to either (a)000000dw modregr/m (b) Immed, reg/mem 100000sw mod000r/mData (c)Immed, acc 0000010w Data Data w = 1Add hyte or word with carry 2. ADC (a)Reg / mem with register to either 000100dw modregr/m Immed , reg / mem 100000sw mod010r/m (b)Data (c) 0001010w Data Immed, acc Data w = 1Increment byte or word by one INC 3. (a)Register 01000reg ,1111111 w modOOCr/m (b) Reg/mem ASCII adjust for addition 4. AAA (a) ASCII adjust for add 00110:11 5. DAA Decimal adjust for addit: on (a) Decimal adjust for add 00100111 Subtraction 6. SUB Subtract byte or word

(a) Reg/mem and register to either

001010dw modregr/m

100000sw mod011r/m Data (b) Immed, reg/mem 0010110w Data Data if w=1 (c) Immed , acc' Subtract byte or word with borrow 7. **B**BB (a) Reg/memory and register to either 000110dw modregr/m Immed . reg/mem 100000sw mod011r/m Data (b) (c) Immed, acc 0001110w Data Data if w=1 Decrement byte or word by one 8. DEC (a)Reg/mem  $111111 \, \text{wmodOO1r/m}$ (b) register 01001reg Negate byte or word 9. NEG (a)Change sign 1111011w modO11r/mCMP Compare byte or word 10. Reg/mem , reg (a) 001110dw modregr/m Immed . reg/mem (b) 100000sw / mod111r/m Data (c) Immed , acc 0011110w Data Data if w=1 ASCII Adjust for subtraction 00111111 AAS 11. Decimal adjust for subtraction 00101111 12. DAS (c) Multiplication Multiply byte or word unsigned MUL 13. 1111011w mod100r/mIMUL Integer multiply byte or word 14.  $1111011 \, \text{wmod} 101 \, \text{r/m}$ 

117

# 15. AAM ASCII Adjust for multiply 11010100 00001010

(d) Division

16. DIV Divide byte or word unsigned 1111011w mod110r/m

17. IDIV Integer divide byte or word 1111011w mod111r/m

18. AAD ASCII adjust for division 11010101 00001010

19. CBWConvert byte to word1001100020. CWDConvert word to double word10011001

## (C) BIT MANIPULATION INSTRUCTIONS

8086 provides three groups of bit manipulating instructions.

(a) Logicals - Here NOT has no effect on the flags. AND OR, XOR, TEST affect the flags as : The OF and CF are always cleared, the contents of the AF is always undefined following execution of a logical instruction. The SF, ZF, PF are always posted to reflect the result of operation and can be tested by conditional jimp instruction.

- 1. NOT Invert 1111011w mod010r/m
- 2. AND 'And' byte or word
  - (a) Reg/mem, register

001000dw modreg/rm

|    | (b)  | Immed, reg/mem<br>1000000w mod100r/m Data         |
|----|------|---------------------------------------------------|
|    | ( c) | Immed, Acc<br>0010010w Data Data if $N = 1$       |
| 3. | OR   | 'Inclusive or (byte or word                       |
|    | (a)  | Reg/mem ,register<br>000010dw modregr/m           |
|    | (b)  | Immed, reg/mem<br>100000w mod001r/m Data          |
|    | ( c) | Immed, acc<br>0000110w Data Data if $w = 1$       |
| 4. | XOR  | 'Exclusive or: byte or word                       |
|    | (a)  | Reg/mem , register<br>001100dw modregr/m          |
|    | (b)  | Immed, reg/mem<br>1000000w mod110r/m Data         |
|    | ( c) | Immed, acc $0011010w$ Data Data if $w = 1$        |
| 5. | TES  | I 'Test' byte or word                             |
|    | (a)  | Reg/mem , register<br>1000010w modreg <b>r/</b> n |
|    | (b)  | Immed , reg/mem<br>1111011w mod000r/m Data        |
|    | ( c) | Immed, acc<br>0011010w Data Data if w = 1         |

.

,

•

(b) Shift - Bits are shifted arithmetically or logically. Upto 255 shifts may be performed according to the value of the count operand coded in the instruction. The continuery be specified as a constant 1, or as reg. CL allowing the shift count to be a variable supplied at execution time. Arithmetic shifts may be used to multiply or divide binary numbers by powers of two. Logical shifts can be used to isolate bits. Shift instructions affect the flags as follows: AF is always undefined following a shift operation. PD, SF, ZF are updated. CF contains the value of the last bit shifted out of the destination operand. OF is undefined following a multibit shift. In a single bit shift, OF is set if the value of the high order (sign) bit retains the original value, otherwise OF is cleared.

| 6. | SHL/SHA<br>or word | Shift logical arithmetic left by te<br>110100vw mod100r/m |
|----|--------------------|-----------------------------------------------------------|
| 7. | SHR                | Shift logical right byte or cord<br>110100vw mod101r/m    |
| 8. | SAR                | Shif arithmetic right byte or wor                         |

5. SAR Shiff arithmetic right byte or word 110100vw mod111r/n

(c) Rotate - Here the CF may act as an extension of the operand in two of the rotate instructions. allowing a bit to be isolated in CF and then tested by a jump if carry or jump if not carry instruction.

- 9. ROL Rotate left byte or word 110100vw mod00or/m
- 10. ROR Rotate right byte or word 110100vw mod001r/m
- 11. RCL Rotate through carry left byte or word 110100vw mod010r/m
- 12. RCR Rotate through carry right byte or word 110100vw mod011r/m ·

## D. STRING INSTRUCTIONS

String instructions do not use the normal memory addressing modes to access their operands. Instead Index registers are used implicitly. Following are the string instructions which allow strings of bytes or words to be operated on, o ne element at a time.

| 1. | MOVS    | Move byte or word string    | 1010010w              |
|----|---------|-----------------------------|-----------------------|
| 2. | CMPS    | Compare byte or word string | 1010011w              |
| 3. | SCAS    | Scan byte or word string    | 1010111w              |
| 4. | LODS    | Load byte or word string    | 1010110w              |
| 5. | STOS    | Store byte or word string   | 1010101w              |
| 6. | REP     | Repeat                      | 1111001 <sub>23</sub> |
| E. | PROGRAM | TRANSFER INSTRUCTIONS       |                       |

The sequence of execution of instructions in a program is determined by the CS & IP. CS contains the base address of the current code segment (64 K portion of memory) from which instructions are presently being fetched. IP is used

as an offset from the beginning of the code sediment. The combination of CS & IP points to the memory location from which the next instruction is to be fetched.

The program transfer instructions operate on the IP and CS thereby changing their contents; This changing causes normal sequential execution to be altered. When a program transferred occurs the queue no longer contains the correct instructions and the BIU obtains the next instructions from memory using the new IP and CS values. and passes the instruction directly to the EU and then begins refilling the queue from the new locations. The flags are not effected except in interrupt related instructions.

(a) Unconditional Transfer

| (1) | ) CALL | Call procedure |
|-----|--------|----------------|
|-----|--------|----------------|

- (a) Direct within segment 11101000 Disp low Disp High
  - (b) Indirect within segment 11111111 modO10r/m
- (d) Indirect intersegment 11111111 modOl1r/m

Return from procedure RET 2. within segment 11000011 (a) within seg. adding Immed. to SP (b) 11000010 Data low Data High Intersegment 11001011 (c) Interseg. adding immed. to SP (d) 11001010 Data low Data high Unconditional jump JMP 3. Direct within segment (a)1110100! displacement low displacement high Direct within seg. - short (b) 11101011 disp. (c) Indirect within segment 11111111 mod100r/m (d) Direct intersegment offset high 11101010 offset low seg. low seg. high (e) Indirect intersegment 11111111 mod101r/m Conditional Transfer 01110000 Disp JO Jump if overflow JNO Jump if not overflow 01110001 displacement Jump on below/not above or equal/carry JB/JNAE/JC

(b)

4.

5.

6.

01110010 displacement

| 7•  | JNE/JAE/JNC | Jump if not equal/not carry/above or equal |
|-----|-------------|--------------------------------------------|
|     |             | 01110101 disp                              |
| 8.  | JE/JZ       | Jump if equal/zero                         |
|     |             | 01110100 disp                              |
| 9.  | JL/JNGE     | Jump if less/not greater or equal          |
|     |             | 01111100 disp                              |
| 10. | JLE/JNG     | Jump if less or equal/not greater          |
|     |             | 01111110 disp                              |
| 11. | JBE/JNA     | Jump if above or equal/not above           |
|     |             | 01110110 disp                              |
| 12. | JP/JPE      | Jump if parity/parity even                 |
|     |             | 01111010 disp                              |
| 13. | JS          | Jump if sign                               |
|     |             | 01111000 disp                              |
| 14. | JNL/JGE     | Jump if not less/greater or equal          |
|     |             | 01111101 disp                              |
| 15. | JNLE/JG     | Jump if not less or equal/greater          |
|     |             | 01111111 disp                              |
| 16. | JNBE/JA     | Jump if not below or equal/above           |
|     |             | 01110111 disp                              |
| 17, | JNP/JPO     | Jump if not parity/parity odd              |
|     |             | 01111011 disp                              |
| 18. | JNS         | Jump if not sign                           |
|     |             | <b>0</b> 1111001 disp                      |

•

Loop CX times 11100010 19. LOOP disp Loop while zero/equal 20. LOOPZ/LOOPE 11100001 disp 21. LOOPNZ/LOOPNE Loop while not zero/not equal 11100000 disp JCXZ 22. Jump on CX zero 11100011 disp

## (d) Interrupt

| 23. | Type | specified |           | 11001101    | type     |
|-----|------|-----------|-----------|-------------|----------|
| 24. | Type | 3         |           | 11001100    |          |
| 25. | INTO |           | Interrupt | on overflow | 11001110 |
| 26. | IRET |           | Interrupt | return      | 11001111 |

### PROCESSOR CONTROL INSTRUCTION

These instructions allow programs to control various CPU, functions. There are three groups (a) Flag operation - this updates flags, (b) External Synchronization - used for synchronizing the 8086 with external events, (c) No operation causes CPU to do nothing. Except for the flag operation none of the processor control instructions affect the flags.

| 1.  | CT C  | Clear carry               | 11111000           |
|-----|-------|---------------------------|--------------------|
| 2.  | QMC   | Complement carry          | 11110101           |
| 3.  | STC   | Set carry                 | 11111001           |
| 4.  | CLD   | Clear direction           | 11111100           |
| 5.  | STD   | Set direction             | 11111101           |
| 6.  | CLI   | Clear interrupt           | 11111010           |
| 7.  | STI   | Set interrupt             | 11111011           |
| 8.  | HALT  | Halt                      | 11110100           |
| 9.  | TIAW  | Wait                      | 10011011           |
| 10. | ESC   | Escape to external device | 11011xxx modxxxr/m |
| 11. | TO CK | Bus lock prefix           | 11110000           |

Consider multiplication in the two's complement number system. An n-bit multiplicand (perhaps a signal variable) is multiplied by an n-bit multiplier (perhaps a filter coefficient). The product has 2n bits and may be used as another multiplicand in a later multiplication so it is quantized (truncated here) back to n bits.

Suppose the multiplier is 'X' and the coefficient is 'a', then

and the product is quantized Q

 $Q[aX] = [aX / 2^n]$ 

The computer hardware actually handles the integers of equation (15.1) so that in hardware

$$X * 2^{n-1}$$
  
\* a \* 2^{n-1}  
a X \* 2^{2n-2}

is quantized as Q  $\begin{bmatrix} a \\ X \end{bmatrix} = \begin{bmatrix} a \\ X \\ * \\ 2^{2n-2} \end{bmatrix} = \begin{bmatrix} a \\ X \\ * \\ 2^{n-2} \end{bmatrix}$ Consequently, the product must be multiplied by 2 (shifted one place left) so that the final truncated term is

$$Q[aX] = [aX * 2^{n-1}]$$

Code sequence in Intel 8086 programing language is as

| LEA  | SI, A  | ; COEFF. POINTER        |
|------|--------|-------------------------|
| LODW |        | ; A / 2 LOADED          |
| IMUL | X      | ; AX / 4 IN DX REGISTER |
| SAL  | DX , 2 | ; AX IN DX REGISTER     |

# 126

#### APPENDIX - V

#### COEFFICIENT REPRESENTATION

Intel 8086 represents all the numbers in the two's complement number system, so

 $N = (S M_{14} M_{13} \cdots M_{1} M_{0}) 2 cns \cdots (A5.1)$  where,

$$-2^{15} \le \mathbb{N} \le 2^{15} -1$$

If we consider all numbers to be scaled, such that

 $N = (S. M_{14} M_{13} \dots M_{1} M_{0}) 2 cns$ 

thus,

$$-1 \leq N \leq 1 - \overline{2}^{15}$$

As a result, coefficients in the range  $1 \le N \le 2$  cannot be represented. Therefore, all coefficients will be stored as half their actual value, and

VALUE STORED =  $Value * 2^{14} + 0.5$ 

and a left shift (multiply by 2) operation will be performed in each routine to compensate for this change. The symbol [X]means the largest integer less than X.

As an example suppose coefficient  $S\emptyset = -.4383164$  is to be stored in the Intel 8086. microprocessor.

VALUE STORED = 
$$1.50 \times 2^{14} + .5$$
  
=  $1.4383164 \times 16384 + .5$   
=  $1.7181.3759 + .5$   
=  $1.7181.8759$  =  $7181$ 

The following operations are actually performed

(1) Load the coefficient 'a' into AX register

$$AX = a * 2^{n-2}$$

(2) Multiply by the variable 'X'  
DX, 
$$AX = (a * 2^{n-2}) * (X * 2^{n-1})$$
  
 $= a X * 2^{2n-3}$   
 $= (a X / 4) * 2^{2n-1}$ 

the product is now in the DX, AX register.

(3) Shift DX Register left 2 places (quantize to 16 bits and multiply by 4).

$$DX = \lfloor (a X / 4) * 2^{2n-1} / 2^n \rfloor * 4$$
$$= \lfloor a X / 4 * 2^{2n-1} \rfloor * 4$$
$$= a X * 2^{n-1}$$

The operation left justifies the register DX and fills in two zeros in the least significant bits. The DX register now contains the truncated, properly scaled result.

On computers with double register shifting, one would perform the double left shift first.

Double register = 
$$(a X / 4 # 2^{2n-1}) * 4$$
  
=  $a X * 2^{2n-1}$ 

and then truncate to the n most significant bits.

For Single register =  $(a X * 2^{2n-1}) / 2^n$ =  $(a X * 2^{n-1})$ 

which is more accurate than above.