# FIELD PROGRAMMABLE GATE ARRAY ARCHITECTURE OF PROPORTIONAL-INTEGRAL-DERIVATIVE CONTROLLER

ZULKIFLI YUSOF

UNIVERSITI TEKNOLOGI MALAYSIA

Replace this page with form PSZ 19:16 (Pind. 1/07), which can be obtained from SPS or your faculty.

Replace this page with the Cooperation Declaration form, which can be obtained from SPS or your faculty.

## FIELD PROGRAMMABLE GATE ARRAY ARCHITECTURE OF PROPORTIONAL-INTEGRAL-DERIVATIVE CONTROLLER

ZULKIFLI YUSOF

A project report submitted in partial fulfilment of the requirements for the award of the degree of Master of Engineering (Electrical - Computer and Microelectronic System)

> Faculty of Electrical Engineering Universiti Teknologi Malaysia

> > JUNE 2015

"in The Name of Allah The Most Gracious The Most Merciful

seeking forgiveness from Rabb All-Hearer All-Sufficient"

### ACKNOWLEDGEMENT

Alhamdulillah, firstly I would like to express my highest and sincere gratefulness to the Almighty Allah S.W.T for his uncountable favor has helped me to completing this course.

Secondly, I would like to express my deepest gratitude to Dr. Muhammad Nadzir Marsono, my research supervisor, for his patient, guidance, enthusiastic encouragement and useful critiques of this project.

Beside that, I would like to give my very highest appreciation to my employer, Intel for give oppotunity and funding my study.

Finally, I wish to extend my thanks to my beloved family and friends for their patient, support and encouragement towards completing this course work.

#### ABSTRACT

Proportional-integral-derivative (PID) control is widely used in control and automation. PID implementation in software especially using microcontroller requires a lot of CPU execution time. The performance of PID controller can be improved by accelerating control function in hardware. Thus, the performance and throughput can be further improved when incorporated in FPGA architecture system. This project focuses on exploration of hardware architecture of PID controller and targeted for implementation on FPGA system. The architecture exploration include concurrent, serial and pipeline designs, functionality correctness and non-functional verification. These architectures was designed to support modularity and can be use for other control applications. Serial design architecture of PID is able to reduce  $\sim 60\%$  of datapath unit resources compared to concurrent design but it required five cycles to produce the output. High throughput can be achieve using pipeline design and required 7 more registers compared to serial design architecture.

#### ABSTRAK

Kawalan berkadar terus-berkamiran-pembeza (PID) digunakan secara meluas dalam sistem automasi. Perlaksanaan sistem kawalan berkadar terus-berkamiranpembeza dalam bentuk perisian terutama pegawal terbenam memerlukan masa yang panjang memproses arahan. Prestasi kawalan berkadar terus-berkamiran-pembeza dapat ditingkatkan dengan menjana fungsi kawalan ke dalam perkakasan. Oleh itu, prestasi dan hasil keluaran dapat ditingkatkan dengan lebih tinggi melalui penggabungan sistem seni bina FPGA. Projek ni memberi tumpuan kepada penerokaan seni bina perkakasan kawalan berkadar terus-berkamiran-pembeza yang boleh dilaksanakan melalui sistem FPGA. Penerokaan meliputi reka bentuk serentak, sesiri dan saluran paip, menguji ketepatan fungsinya dan aspek yang lain. Reka bentuk seni bina yang dibangunkan direka untuk menyokong kesesuaian modul dan boleh diguna pakai untuk kegunaan kawalan yang lain. Seni bina pengawal dengan reka bentuk sesiri dapat mengurangkan sumber pembinaan laluan data sebanyak 60 peratus berbanding rekabentuk serentak tetapi memerlukan masa lima kali ganda untuk mengeluarkan hasil keluaran. Pemprosessan tinggi boleh dihasilkan dengan menggunakan reka bentuk saluran paip dan ia memerlukan lebih tujuh penyimpan memori berbanding rekabentuk serentak dengan kelebihan 1.5 kali ganda hasil keluaran and lima kali ganda dibandingkan dengan reka bentuk sesiri.

## TABLE OF CONTENTS

| CHAPTER | TITLE             |                             |                         | PAGE |  |  |  |
|---------|-------------------|-----------------------------|-------------------------|------|--|--|--|
|         | DECLARATION       |                             |                         | ii   |  |  |  |
|         | DEDIC             | iii                         |                         |      |  |  |  |
|         | ACKNO             | OWLEDO                      | GEMENT                  | iv   |  |  |  |
|         | ABSTR             | ACT                         |                         | v    |  |  |  |
|         | ABSTR             | AK                          | AK                      |      |  |  |  |
|         | TABLE             | OF CON                      | vii                     |      |  |  |  |
|         | LIST O            | F TABLI                     | ix                      |      |  |  |  |
|         | LIST O            | IST OF FIGURES              |                         |      |  |  |  |
|         | LIST O            | LIST OF ABBREVIATIONS       |                         |      |  |  |  |
|         |                   |                             |                         |      |  |  |  |
| 1       | INTRO             | DUCTION                     |                         | 1    |  |  |  |
|         | 1.1               | Overvie                     | W                       | 1    |  |  |  |
|         | 1.2               | PID Cor                     | ntroller                | 2    |  |  |  |
|         | 1.3               | Problem                     | n Statement             | 3    |  |  |  |
|         | 1.4               | Project                     | Objective               | 3    |  |  |  |
|         | 1.5               | Scope o                     | f Work                  | 4    |  |  |  |
|         | 1.6               | Report                      | Overview                | 5    |  |  |  |
|         |                   |                             |                         |      |  |  |  |
| 2       | LITERATURE REVIEW |                             |                         | 6    |  |  |  |
|         | 2.1               | Introduc                    | ction to PID controller | 6    |  |  |  |
|         | 2.2               | Closed-                     | Loop Control System     | 7    |  |  |  |
|         | 2.3               | PID Cor                     | ntrol                   | 8    |  |  |  |
|         |                   | 2.3.1                       | Proportional            | 8    |  |  |  |
|         |                   | 2.3.2                       | Integral                | 9    |  |  |  |
|         |                   | 2.3.3                       | Derivative              | 9    |  |  |  |
|         | 2.4               | PID Des                     | PID Design Techniques   |      |  |  |  |
|         | 2.5               | FPGA f                      | or Digital Design       | 11   |  |  |  |
|         | 2.6               | Related Work on PID in FPGA |                         | 12   |  |  |  |
|         | 2.7               | Chapter Summary             |                         | 13   |  |  |  |

| 3 | PID C | CONTROLLER ARCHITECTURE |                                      |    |
|---|-------|-------------------------|--------------------------------------|----|
|   | 3.1   | Introdu                 | ction                                | 14 |
|   | 3.2   | PID In                  | PID Incremental Algorithm            |    |
|   |       | 3.2.1                   | PID Architecture Development on FPGA | 16 |
|   |       | 3.2.2                   | Concurrent Architecture Design       | 16 |
|   |       | 3.2.3                   | Serial Architecture Design           | 18 |
|   |       | 3.2.4                   | Pipeline Architecture Design         | 23 |
|   | 3.3   | Chapte                  | r Summary                            | 28 |
| 4 | RESU  | ULTS AND                | ANALYSIS                             | 29 |
|   | 4.1   | Verifica                | ation Methodology                    | 29 |
|   | 4.2   | Simula                  | tion Result                          | 30 |
|   |       | 4.2.1                   | Concurrent Timing Simulation Result  | 30 |
|   |       | 4.2.2                   | Serial Timing Simulation Result      | 30 |
|   |       | 4.2.3                   | Pipeline Timing Simulation Result    | 31 |
|   | 4.3   | Perform                 | nance Analysis                       | 32 |
|   | 4.4   | Chapte                  | r Summary                            | 33 |
| 5 | CON   | CLUSION                 | AND FUTURE WORK                      | 34 |
|   | 5.1   | Conclu                  | sion                                 | 34 |
|   | 5.2   | Future                  | Works                                | 34 |
|   |       |                         |                                      |    |

REFERENCES

viii

35

## LIST OF TABLES

# TABLE NO.

## TITLE

### PAGE

| 2.1 | Effects of individual PID variable adjustment              | 11 |  |
|-----|------------------------------------------------------------|----|--|
| 2.2 | Previous works of PID controller on FPGA                   | 13 |  |
| 3.1 | RTL-CS Table for serial design                             | 22 |  |
| 4.1 | PID controller output result using calculation with random |    |  |
|     | feedback input                                             | 29 |  |
| 4.2 | Performance output analysis                                | 32 |  |

## LIST OF FIGURES

## FIGURE NO.

## TITLE

### PAGE

| Close-loop control system                                | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| block diagram of closed-loop control system              | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Block diagram of PID controller                          | 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ASM chart- Concurrent PID                                | 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| DFG - Concurrent Design                                  | 18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Functional block diagram (datapath) of concurrent design | 19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Serial design DFG and scheduling                         | 19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ASM chart for serial design architecture                 | 20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Serial Design Functional Block Diagram                   | 21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Datapath Unit(DU) for serial design                      | 21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Control Unit functional block                            | 22                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ASM chart for pipeline design                            | 23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| DFG for pipeline design                                  | 24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Pipeline schedule and pipeline register placed           | 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Pipeline Space-Time diagram                              | 26                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Datapath unit of pipeline design                         | 27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Concurrent design timing simulation result               | 30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Serial design timing simulations result                  | 31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Pipeline design timing simulation result                 | 31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                          | Close-loop control system<br>block diagram of closed-loop control system<br>Block diagram of PID controller<br>ASM chart- Concurrent PID<br>DFG - Concurrent Design<br>Functional block diagram (datapath) of concurrent design<br>Serial design DFG and scheduling<br>ASM chart for serial design architecture<br>Serial Design Functional Block Diagram<br>Datapath Unit(DU) for serial design<br>Control Unit functional block<br>ASM chart for pipeline design<br>DFG for pipeline design<br>DFG for pipeline design<br>Pipeline schedule and pipeline register placed<br>Pipeline Space-Time diagram<br>Datapath unit of pipeline design<br>Concurrent design timing simulation result<br>Serial design timing simulation result |

# LIST OF ABBREVIATIONS

| ASIC   | - | Application Specific Integrated Circuit |
|--------|---|-----------------------------------------|
| ASM    | - | Algorithmic State Machine               |
| CAD    | - | Computer Added Design                   |
| CU     | - | Control Unit                            |
| DSP    | - | Digital Signal Processor                |
| DFG    | - | Design Flow Graph                       |
| DU     | - | Datapath Unit                           |
| FPGA   | - | Field-Programmable Gate Array           |
| NS     | - | Next State                              |
| PID    | - | Proportional-Integral-Derivative        |
| PLC    |   | programmable logic controller           |
| PLD    | - | programmable logic devices              |
| PWM    | - | Pulse Width Modulation                  |
| RTL    | - | Register Tranfer Level                  |
| RTL-CS | - | Register Tranfer Level-Control State    |
| VHDL   | - | VHSIC Hardware Description Language     |
| VHSIC  | - | Very High Speed Integrated Circuit      |

### **CHAPTER 1**

### **INTRODUCTION**

### 1.1 Overview

Majority of industrial dynamic systems which utilizing digital control operate in continuous domain, rather than in discrete domain. Such systems typically involve processing analog signals from sensors as input data to produce system output information. This requires analog-to-digital conversion. Digital control signals produced by converter then require conversion back to analog signal through digitalto-analog converter. Both process can introduce errors, delays or loses of information which produce inaccurate control response [1].

In order to eliminate errors, increase system accuracy and produce better control response, output feedback is needed to monitor system output known as closedloop control [2]. Close-loop control systems widely are use in real-time embedded systems. These decision are normally made by software evaluation using feedback data from the hardware equipment under control. Proportional-Integral-Derivative (PID) control is one of the mostly used closed-loop control system and has been used in variety of applications in various industries [3]. Figure 1.1 shows a model of closed-loop control system to control servo motor.  $P_d$  and P correspond to the control variables where  $P_d$  is desired value and P is real output value measured by sensor. The different values of P and  $P_d$  will create error signal, e(t) and u(t) is the controller output to control the device to meet desired value.



Figure 1.1: Close-loop control system

### 1.2 PID Controller

PID controllers have been in use and established as a key component in industrial process control and today, over 90% industrial process are controlled by PID controllers [4]. From their simple structure design, versatility, flexibility, reliability, speed and robustness, majority of industries still rely on this controller for almost all types of control systems.

PID controller has evolved from analog controllers using mechanical integrators and differentiator to digital controllers using programmable logic controller (PLC), microprocessor, digital signal processor (DSP) and the latest using field-programmable gate arrays (FPGA) [5]. Digital controllers can be implemented either software based or hardware based. Digital PID controller is less expensive to implement compared to its analog version. Besides that, it is capable of utilizing advanced control algorithm, flexible in changing its parameters and have greater insensitivity to noisy external signals.

From the topology perspective, PID controller utilizes three terms which are **proportional**, **integral** and **derivative** [6]. P is proportional term which correspond to proportional control. The second term is I for integral term. This term used to control action and it is proportional to the time integral of error. This action is designed to monitor that steady state error of the system become zero. The last term D is derivative. It is proportional to the time derivative of the control error. This feature allows system to predict the future error. Figure 1.1 shows the topology of the PID system where output signal, u(t) is the summation of proportional, integral and derivative components. There are many other variations of basic PID algorithm that improved its performance and operability.

### 1.3 Problem Statement

There are two methods to implement digital control system in digital technology. First is software implementation based approach and secondly using hardware based approach. Software-based solutions use memory-processor interactions whereby application programs will be stored in memory and at the same time, the processor proceeds to fetch, decodes, and execute the program instruction sequently. The speed of operation depend purely on software size and instruction complexity. As a result, this approach requires many cycles to execute all the instructions and commands. Software-based implementation can be in Programmable Logic Controllers (PLC), microcontroller, microprocessors, Digital Signal Processors (DSP) and general purpose computers.

Hardware-based approach implementation previously using Application Specific Integrated Circuit (ASIC) are utilized when system size and complexity increase. Recently, high-end FPGAs that have several million gates have given significant advantage over ASIC. Their features to assure ease of design, reduce development cost, produce extra product income and give opportunity to reduce time for product launch given superior advantage than software-based implementations. Implementation in hardware-based also produce more compact design interm of size, power efficient and high speed capabilities.

Based on significant advantage in hardware-based design, implementation of FPGA-based digital PID controller given some benefits which have better speed performance with all operations are executed in parallel, archiving better accuracy and faster operation on FPGA.

### 1.4 Project Objective

Generally, this project aims to design PID controller using PID incremental algorithm that is targeted for implementation in field-programmable gate arrays (FPGA). This aims is achieve by these two objectives.

 The first objective is to design an RTL architecture of PID controller. Based on PID incremental algorithm, it is simplified into its basic arithmetic operations. From this point on, a PID controller architecture design for FPGA implementation has been developed. This controller architecture design includes exploration of arithmetic operations, writing Verilog code for FPGA implementation, synthesis and simulation.

 Second objective is to perform design space exploration of PID controller architecture. The PID controller architectures include serial, concurrent, and pipeline design. From these exploration, performance analysis is done based on simulation result.

### 1.5 Scope of Work

Few scopes and checklists has been identified to determine this project is planning well within given time frame. It is important to make sure the project is done correctly and achieve their objectives.

- 1. The first scope is design the controller based on PID incremental algorithm. The focus of this work is to design the controller from the algorithm based on arithmetic operation which decomposed form PID incremental algorithm [4].
- Reconstruct PID hardware architecture for implementation on an FPGA system. Architecture design is written in Verilog code and then synthesized using Altera Quartus II software before proceeding to the simulation using ModelSim from Altera.
- 3. PID implementation based on fixed point arithmetic and all operations in this design use real data type for a numbers.
- 4. For this project, the system is totally designed in software and a test bench is used to validate the design. Both RTL design and test bench are written in System Verilog programming using Altera Quartus II and Modelsim-Altera CAD tool as logic synthesizing tool and hardware simulation tool.

### 1.6 Report Overview

This report consists of five chapters. The rest of the report is organize as follow.

- Chapter 2 reviews existing works in literature including PID controller algorithm and discusses several techniques and architectures on implement PID controller on FPGA. The algorithm and architecture of each technique will be examined and explored. Several hardware architecture approaches will be compared and analyzed in this chapter.
- 2. Chapter 3 covers the system overview and implementation details of several PID architectures explored in this project. This chapter describes the PID algorithm development into PID incremental algorithm and decomposed into basic arithmetic operation. Architecture development that show the hardware design steps are presented in this chapter.
- 3. Chapter 4 shows the result of the system output and the discussion of the system performance and limitation.
- 4. Finally in Chapter 5, the conclusion from this project and suggestion for future works are presented and discussed to improve PID contorller design in the future.

This document was created with Win2PDF available at <a href="http://www.win2pdf.com">http://www.win2pdf.com</a>. The unregistered version of Win2PDF is for evaluation or non-commercial use only. This page will not be added after purchasing Win2PDF.

#### REFERENCES

- 1. M. Abdelati, "FPGA-Based PID Controller Implementation," *The Islamic University of Gaza, Palestine*, 2005.
- K. J. Aström and T. Hägglund, "PID controllers: theory, design and tuning," 1995.
- 3. M. A. Johnson and M. H. Moradi, *PID control.* Springer, 2005.
- 4. L. Rozsa, "Design and Implementation of Practical Digital PID Controllers," in *IFAC Proceedings Series*, no. 15, 1990, pp. 115–121.
- 5. I. Grout, *Digital systems design with FPGAs and CPLDs*. Newnes, 2011.
- 6. R. Isermann, *Digital control systems*. Springer, 1991.
- S. Bennett, "The past of PID controllers," *Annual Reviews in Control*, vol. 25, pp. 43–53, 2001.
- 8. A. KRIGMAN, "Computers in process control-a panel discussion," 1970.
- 9. R. C. Dorf and R. H. Bishop, "Modern control systems," 1998.
- D. of Scientific and I. R. Großbritannien, Automation: a report on the technical trends and their impact on management and labour. HM Stationery Office, 1956.
- 11. D. Xue, Y. Chen, and D. P. Atherton, "Linear feedback control," *Analysis and design with Matlab, Springer*, 2002.
- W. Zhao, B. H. Kim, A. C. Larson, and R. M. Voyles, "FPGA implementation of closed-loop control system for small-scale robot," in *Advanced Robotics*, 2005. ICAR'05. Proceedings., 12th International Conference on. IEEE, 2005, pp. 70–77.
- S. S. K. N. Raju, "Implementation of FPGA based PID Controller for DC Motor Speed Control System," in *Proceedings of the World Congress on Engineering and Computer Science*, vol. 2, 2010, pp. 20–22.
- A. Trimeche, A. Mtibaa, A. Sakly, and M. Benrejeb, *PID Controller Using FPGA Technology*. INTECH Open Access Publisher, 2011.

- J. Lima, R. Menotti, J. M. Cardoso, and E. Marques, "A methodology to design FPGA-based PID controllers," in *Systems, Man and Cybernetics, 2006. SMC'06. IEEE International Conference on*, vol. 3. IEEE, 2006, pp. 2577– 2583.
- S. C.Senthilsingh, "Design and Implementation of FPGA Based PID Controller," in *International Conference on System Dynamics and Control* (*ICSDC*), 2010. ICSDC, Karnakata, India, 2010, pp. 233–236.
- Y. Chen and Q. Wu, "Design and implementation of PID controller based on FPGA and genetic algorithm," in *Electronics and Optoelectronics (ICEOE)*, 2011 International Conference on, vol. 4. IEEE, 2011, pp. V4–308.
- V. Gupta, K. Khare, and R. Singh, "Efficient FPGA implementation of 2nd order digital controllers using MATLAB/Simulink," *Journal of Engineering* & *Applied Sciences*, vol. 6, no. 8, 2011.