Adaptive proportional-integral-derivative controller on field programmable gate array by Ee Luan, Prak Yut
ADAPTIVE PROPORTIONAL-INTEGRAL-DERIVATIVE CONTROLLER ON
FIELD PROGRAMMABLE GATE ARRAY
PRAK YUT A/L EE LUAN
A project report submitted in partial fulfilment of the
requirements for the award of the degree of
Master of Engineering (Computer and Microelectronics System)
Faculty of Electrical Engineering
Universiti Teknologi Malaysia
JUNE 2016
iii
Dedicated, in thankful appreciation for support and encouragement to my lovely wife
Chantheve Syita, both of my sons Krydtanand Srisuwan and Krydchakphorn
Srisuwan, my parents, families and friends.
iv
ACKNOWLEDGEMENT
First and foremost, I would like to express my gratitude and sincere thanks to
my supervisor Associate Prof Dr Muhammad Nadzir Marsono who has supported me
throughout my research with patience, diligence, guidance, enthusiastic, continuous
encouragement and useful critiques towards excellence of this project. He also allowed
me to work in my own way and maintain a great deal of independence. One could not
simply wish for a more supportive and approachable supervisor.
I would also like to acknowledge the half financial support provided by Intel. I
wish to express my warmest and sincerest thanks to my lovely wife, whose generosity
and endless love were vital to the success of my thesis. She was helpful in developing
this project . She has been my inspiration in overcoming all the obstacles that existed
throughout the completion of this research; to her I dedicate this thesis. I wish to thank
several individuals for helping me get through difficult times. My sons, who provided
me with invaluable emotional support, caring, understanding and encouragement.
Without their support, I would not have been able to achieve my Master’s degree.
vABSTRACT
Proportional-Integral-Derivative (PID) controllers tuned with heuristic tuning
methods such as Ziegler-Nichols method are not completely capable to perform high
precision control, typically due to large overshoots and poor load regulation. Any
changes to the tunable PID parameters we done accordingly offline. Current Field
Programmable Gate Array (FPGA) based platform can be used as a high-precision
controller implementation. Using FPGA for high precision control offer good resource
utilization, power consumption, programmability, cost, and more importantly, it can
support parallel controllers. With the improvement of FPGA devices that sometime
mirror the performance of the general purpose processor, more complex PID design
such as adaptive PID can be implemented. Adaptive PID controller can adjust its own
parameters and is able to simultaneously support multiple applications at once. The
objective of this project is to design adaptive PID controller on FPGA and analyze the
performance of it adaptive or self-tuning capabilities when reference and error signal
vary. Another objective is to minimize the instability and reducing the overshoot,
undershoot, settling time and ringing. The Altera Quartus and Altera ModelSim
environments are used to model the adaptive PID using Verilog Hardware Description
Language through Register Transfer Level modeling methodology. These tools are
also used for simulating the controller and evaluating non-functional performance
characterization.The overall adaptive PID result outperforms the conventional PID and
offer slight improvement on noise injection test case.
vi
ABSTRAK
Pengawal berkadar terus-berkamiran-pembeza (PID) dilaraskan mengunakan
kaedah heuristik seperti kaedah Ziegler-Nichols kebiasaanya tidak memuaskan dalam
kawalan yang mementingkan ketepatan. Setiap perubahan parameter PID perlu
dilakukan sesuai secara luar talian. Platform berasaskan penggabungan sistem
seni bina (FPGA) boleh digunakan untuk melaksanakan pengawal yang mempunyai
ketepatan yang tinggi. Menggunakan FPGA untuk kawalan ketepatan yang tinggi
menawarkan penggunaan sumber yang optimum, mengurangkan penggunaan kuasa,
memudahkan penyusunan program, mengurangkan kos dan yang lebih penting ialah
kebolehan menyokong pengawal selari. Dengan peningkatan prestasi peranti FPGA
ia seakan mencerminkan prestasi mikro pemproses, ia sesuai untuk reka bentuk PID
yang lebik kompleks. Pengawal PID adaptasi yang boleh melaraskan parameter sendiri
secara dalam talian. Objektif projek ini adalah untuk mereka bentuk pengawal PID
adaptive di platform FPGA dan menganalisis prestasi dan keupayaan sistem mudah
suai ketika berlaku kesilapan atau isyart yang berbeza. Satu lagi objektif adalah untuk
meminimumkan ketidakstabilan dan mengurangkan isyarat lampau, masa pengenapan
dan ketidaksabilan. Altera Quartus II dan Altera ModelSim digunakan untuk mereka
bentuk PID dengan menggunakan verilog. Perisian yang sama juga digunakan untuk
simulasi pengawal PID dan menganalisis prestasinya.
vii
TABLE OF CONTENTS
CHAPTER TITLE PAGE
DECLARATION ii
DEDICATION iii
ACKNOWLEDGEMENT iv
ABSTRACT v
ABSTRAK vi
TABLE OF CONTENTS vii
LIST OF TABLES ix
LIST OF FIGURES x
LIST OF ABBREVIATIONS xi
1 INTRODUCTION 1
1.1 Problem Statement 2
1.2 Objective 2
1.3 Scope 3
1.4 Organization 3
2 LITERATURE REVIEW 4
2.1 Intoduction 4
2.2 Closed Loop Control System 4
2.3 PID Controller Design 5
2.3.1 Proportional Action 6
2.3.2 Integral Action 7
2.3.3 Derivative Action 7
2.4 PID characteristic 8
2.5 PID Tuning Rules 8
2.5.1 Zeigler-Nichols 9
2.5.2 Cohen-Coons Method 10
2.6 Related Works 11
2.7 Chapter Summary 12
viii
3 RESEARCH METHODOLOGY 13
3.1 Introduction 13
3.2 RTL Design Methodology 13
3.3 Design and validation tools 14
3.4 Discrete PID algorithm 15
3.5 Adaptive PID algorithm 18
3.6 Adaptive PID architecture 21
3.7 Chapter Summary 24
4 RESULT AND DISCUSSION 26
4.1 Verification and discussion 27
4.2 Chapter Summary 30
5 CONCLUSION 32
5.1 Project Accomplishments 32
5.2 Future Works 33
REFERENCES 34
ix
LIST OF TABLES
TABLE NO. TITLE PAGE
2.1 The PID characteristic 8
2.2 PID tuning methods 9
2.3 Ziegler-Nichols method 10
2.4 Cohen-Coon Method 11
3.1 Ziegler-Nichols tuning rule 18
4.1 The adaptive PID input and constant 27
4.2 Comparison between PID vs adaptive PID for step input from
low to high 29
4.3 Comparison between PID vs APID for step input from high
to low 30
4.4 Comparison between PID vs APID with noise injection 30
xLIST OF FIGURES
FIGURE NO. TITLE PAGE
2.1 Closed loop control system 4
2.2 PID block diagram 6
3.1 The project methodology 14
3.2 Altera Quartus II 15
3.3 Discrete time PID architecture 17
3.4 PID DFG 21
3.5 Adaptive module DFG 22
3.6 PID controller scheduler 23
3.7 PID data path unit 24
4.1 The adaptive PID controller block diagram 26
4.2 The simulation result 27
4.3 The result transcript 28
4.4 Step input low to high result 28
4.5 Step input from high to low 29
4.6 Step input with noise injection 30
xi
LIST OF ABBREVIATIONS
APID - Adaptive Proportional-Integral-Derivative
ASIC - Application Specific Integrated Circuit
DC - Direct Current
DSP - Digital Signal Processor
DFG - Design Flow Graph
DU - Datapath Unit
FPGA - Field-Programmable Gate Array
IC - Intergrated Circuit
P - Proportional
PI - Proportional-Integral
PID - Proportional-Integral-Derivative
ZN - Ziegler-Nichols
CHAPTER 1
INTRODUCTION
Around 60 years in the industry, PID (Proportional-Integral-Derivative)
controller was the only one design method in the control system. The most common
controllers are PID controller and the variant.PID controller is simple to design
and offers robust performance.Besides that, the PID controller also knows as a
good noise tolerance and cheaper solution. Operation of digital PID controller
has gone over several stages of evolution. It is from the early mechanical and
pneumatic designs to the microprocessor based systems. On the other hand, these
systems have the disadvantages of demanding control requirements of modern power
conditioning systems will excess most of the microprocessors and the computing speed
limits the use of microprocessor in complex algorithms. However, microprocessors,
microcontrollers and digital signal processors (DSPs) can no longer keep pace with
the new generation of applications. This is because it requires more flexible and higher
performance without increasing any resources and cost. Additionally the tasks are
executed consecutively which takes longer processing time to achieve the same task in
microcontrollers and DSPs.
Lately, Field Programmable Gate Arrays (FPGA) has becoming another option
for digital control systems realization. There are few benefits provided in FPGA
based controllers. For examples faster computation time, complex functionality, real-
time processing abilities and the power consumption is low[3]. Through this project,
the design consideration is digital PID controller with adaptive module implemented
in FPGA platform. The controller functionality is defined in Verilog following the
standard digital design practices.The project is therefore targeted toward the FPGA
board by using the synthesis tool. The FPGA stands a greater substitute to cover
programmed ASICs. Moreover, FPGAs is cheaper platform, reduce the development
time and the inflexibility of ASICs. Furthermore, the programmability of FPGA
is allowed the design changes or upgrades in the field without any replacement of
hardware that not possible with ASICs.
21.1 Problem Statement
Proportional-Integral-Derivative (PID) controllers tuned with heuristic tuning
methods such as Ziegler-Nichols method are not completely capable to perform high
precision control, typically due to large overshoots and poor load regulation. Any
changes to the tunable PID parameters is done accordingly offline.
Current FPGA based platform can be used as a high-precision controller
implementation. Using FPGA for high precision control offer good resource
utilization, power consumption, programmability, cost, and more importantly, it can
support parallel controllers. Current PID controller realization on FPGA only adopt
this type of method. With the improvement of FPGA devices that sometime mirror
the performance of the general purpose processor, more complex PID design such as
adaptive PID can be implemented. Adaptive PID that can adjust its own parameters on
the fly and is able to simultaneously support multiple applications at once.
1.2 Objective
The general goal for this project is to design and simulate the adaptive PID
controller in Verilog. The project objective can be described as:
• To design the conventional PID as a benchmark for adaptive PID controller.
• The adaptive PID controller is design based on conventional with adaptive block
or updating factor β(k).
• To compare the performance between conventional PID versus adaptive PID
controller.
• To analyze the performance of it adaptive or self-tuning capabilities when
reference and error signals vary.
• To minimize the instability and reducing the overshoot, undershoot, settling time
and ringing.
31.3 Scope
The project scope is another important criteria that lead the project according
to the objective. This is important key that to ensure the project is done correctly and
meet the goal. The scope of work are:
• Analyse discrete PID controller algorithm
• RTL design and testbench written in Verilog programming using Altera Quartus
II and ModelSim-Altera.
• A testbench is used to validate the PID
• Compare the expected result versus simulated result.
1.4 Organization
There are five chapters in this project report.
Chapter 2 consist of the literature review and discussion about the research of
the PID controller design.
Chapter 3 consist of the system overview, methodology and implementation of
the project. This will mention about the algorithm of the PID and also the adaptive
module algorithm. Lastly, the architecture development and hardware design step.
Chapter 4 will explains the testing and result of the design. This including the
discussion and the performance comparison analysis.
Chapter 5 conclude about the project result and the recommendation to enhance
the design in the future.
REFERENCES
1. Fakhrulddin H. Ali, S. M. I., Mohammed Mahmood Hussien. Labview
FPGA Implementation Of a PID Controller for D.C. Motor Speed Control.
International Conference on Energy, Power and Control(EPC-IQ). 2010.
2. Wang Yu, W. S., Jiang Cunbo. Improvement and Simulation of Temperature
Parameter Identification. Third International Conference on Measuring
Technology and Mechatronics Automation. 2011.
3. Sreenivasappa.B.V, D. U. Design and Implementation of FPGA Based Low
Power Digital PID Controllers. International Conference on Industrial and
Information Systems. 2009.
4. ASTROM, K. J. PID Controllers: Theory, Design, and Tuning. 1995.
5. k. J.Astrom and Hagglund, T. Revisiting the Ziegler-Nichols step response
method of PID controller. 2004.
6. K. J. ASK. J, C. H. P. and W.K.Ho. Towards intelligent PID control. 1992.
7. C. C. Hang, K. and W.K.Ho. Refinements of Ziegler-Nichols tuning formula.
1991.
8. K.H.Ang, G. and Y.Li. PID Control system analysis, design and technology.
IEEE Transaction on Control System Technology, Vol 13, No4. 2005.
9. W.Stefanutti, S., P.Mattavelli and M.Ghioni. Auto-Tuning of Digitally
controlled DC-DC converters based on relay feedback. IEEE Trans, On Power
Electronics, Vol22, No1. 2007.
10. W.-D. Chang, R.-C. H. and Hsieh, J.-G. A Multivariable Online Adaptive PID
Controller using Auto-Tuning Neurons. , Engineering Application of Artificial
Intelligence, vol.16,. 2003.
11. T. Kono, T. H., T. Yamamoto and Shah, S. L. Design of a Data-Driven
Performance-Adaptive PID Controller. In Proceedings of 9th IFAC workshop
on ALCOSP. 2007.
12. Takagi, T. and Mizumoto, I. Adaptive and Performance-Driven PID
Control System Design for Discrete-time Systems with a Parallel Feedforward
35
Compensator Designed via FRIT. ADCONP. 2014.
13. Subhash Chander, P. A. . I. G. Auto-tuned, discrete PID controller for DC-DC
converter for fast transient response. India International Conference on Power
Electronics 2010. 2011.
14. Wei Zhao, B. H. K. . A. C. L. . R. M. V. FPGA implementation of closed-loop
control system for small-scale robot. Advanced Robotics,2005. 2005.
15. Design of FPGA-based All Digital PID Controller for Dynamic Systems,
2012.
