# ASIC Implementation of High Throughput PID Controller

<sup>1</sup>Chavan Suyog, <sup>2</sup>Sameer Nandagave, <sup>3</sup>P.Arunkumar

<sup>1,2</sup>M.Tech Scholar, <sup>3</sup>Assistant Professor School of Electronics Engineering VLSI Division, VIT University, Vellore (India)

*Abstract* - In this paper we implemented the pipelined Proportional Integral Derivative (PID) controller using the ASIC Implementation. We used Han Carlson adder and pipelined multiplier to design the PID controller which results into the implemented design can be useful to the modern controlling operations which requires low power and improved speed performance. The implemented design is tuned and analyzed with frequency responses for various error coefficients values using the Matlab. The Controller algorithm is simulated and synthesized using Modelsim and Cadence RC Compiler and ASIC Implementation is done with Cadence Encounter tool. The results are compared with the traditional architecture in terms of power, speed and the area.

# Index Terms - PID, Han Carlson Adder, ASIC

# I. INTRODUCTION

Proportional Integral derivative (PID) controllers have been wide used over the last several decades due to their simplicity, robustness, effectiveness and relevance for a broad category of systems. Despite the numerous control style approaches that have appeared within the literature, it is calculable that nowadays PID controllers are still used in additional than 95th of business processes a vital feature of this controller is that it does not require an explicit analytical model of the system that is being controlled and less manual control. for this reason, PID controllers have been wide used in robotics, automation, method control, producing, transportation, and apparently in real time multi tasking applications.

Implementation of digital PID controller has responded to several stages of evolution, from the mechanical form of the the PID controller is now evolved into the compact and digital form. The PID controller is the amalgam of three basic controlling actions called as Proportional (P), Integral (I) and derivative as shown in figure 1.



## Fig 1 Parallel Form of PID Controller

These controlling actions can be interpreted as representation of various errors in terms of time. Proportional (P) control represents the present errors, Integral (I) control represents the accumulation of past time errors and Derivative (D) control determines the future errors in the system which depends on the current rate of change The algebraic sum of all these controlling action is used to control the process as all are the controlling actions are taking place simultaneously in PID which results into the higher stability and excellent steady state performance.

This Paper has been divided into four sections. First section introduces PID controller with structure and controlling algorithm. In the second section the discrete form of the PID controller has been discussed. In the third section the proposed architecture of PID controller has been discussed. In the fourth section we put the experimental and simulation results along with comparison table

# II. DISCRETE FORM OF PID

The HDL implementation of continuous form of PID is very difficult as the equation contains derivative and integral terms hence we have to first convert continuous form of PID into discrete form. According to the literature review there are plenty of conversion methods available, here we have chosen the backward difference method to discretize the PID equation.

The general continuous form of the PID controller is given by the following equation

$$U(t) = K_g \left( e(t) + \frac{1}{T_i} \int_0^t e(\tau) d\tau + T_d \frac{de(t)}{dt} \right) \rightarrow (1)$$

In the above equation Kp is the proportional gain Ti is the integration time, Td is the derivative time and u(t) is the standard output of PID. The standard parallel form of PID is given by equation 2.

$$u(t) = K_{\underline{k}} e(t) + K_{\underline{l}} \int_{0}^{t} e(\tau) d\upsilon + K_{\underline{d}} \frac{de(t)}{dt} \rightarrow (2)$$

Where  $K_i = K_p / T_i$  and  $K_d = K_p T_d$ 

Differentiating both sides of equation (2)

$$\dot{u}(t) = K_{p}\dot{e}(t) + K_{i}e(t) + K_{d}\ddot{e}(t) \rightarrow (3)$$

Now applying Backward difference method to above equation

$$\frac{u(n) - u(n-1)}{T_s} = K_p \frac{e(n) - e(n-1)}{T_s} + K_i e(n) + K_d \frac{\dot{e}(t) - \ddot{e}(t)}{T_s}$$

-----→(4)

Again applying backward difference method on equation (4)

$$\frac{u(n) - u(n-1)}{T_{s}} = K_{p} \frac{e(n) - e(n-1)}{T_{s}} + K_{i}e(n)$$
$$+ K_{d} \frac{\frac{e(n) - e(n-1)}{T_{s}} - \frac{e(n) - e(n-2)}{T_{s}}}{T_{s}}$$

Solving the equation (5) gives the controller output u(n) in discrete form

$$u(n) = u(n-1) + K_{p} \quad \{e(n) - e(n-1)\} \quad + K$$
  
$$T_{s}e(n) + \frac{K_{d}}{T_{s}} \{e(n) - 2e(n-1) + e(n-2)\}$$

Where u(n)=controller output e(n)=Error signal Ts=Sampling Period of A/D Converter This is the required discrete form of the PID equation which can be implemented by the HDL languages.

# III. METHODOLOGY

To design the high throughput PID controller it is essential to chose the transfer function of the system or a plant process and tune the PID to appropriate values of error coefficients Kp,Kd and Ki.PID tuning is the crucial step in the whole PID algorithm.PID controller is fully automated and requires only manual tuning .The PID tuning means changing the values of the error coefficients to get the desired output response.

#### Matlab Simulation

To find the values of error coefficients and to tune the PID .We used Matlab simulation. First we have chosen the transfer function as

$$\frac{2.38e - 005 z^2 + 4.76e - 005 z + 2.38e - 005}{z^2 - 1.903 z + 0.9048}$$

With sampling period  $T_s=0.01$  Sec

We first set the values of error coefficients such that we get the step as a output response of the PID, then we chosen the different value sets of error coefficients and tuned the PID for getting the same output response as original. The set with error coefficients values producing desired response is to be selected for HDL simulation. The one tuning set of error coefficients has been shown in figure (2)



Fig 2 Matlab Simulation Result of PID Tuning

#### Implemented PID Architecture

We implemented the high throughput PID architecture in this paper, the controller algorithm based on discrete form of PID equation uses the values of error coefficients obtained from the Matlab simulation. To get the high throughput we adder two parallel structures namely 20 bit Han Carlson adder and 8 stages pipelined multiplier in the traditional architecture. Due to the parallel processing architecture we got the improved speed performance as compared to the traditional architecture.

#### Han Carlson adder

This adder is parallel form of the look ahead carry generator. Its algorithm uses tree like structure to do the operations parallel so that we get the high throughput. Nowadays this addition algorithm is popular in Intel Pentium processors because it is area efficient and gives excellent speed performance.

The operation of Han Carlson adder is similar to the Kogge-Stone adder which depends on generation of generate (G) and propagate (P) terms at each stage of addition and adding to the next stage in specific direction. The carry operator is as shown in figure 3



Fig 3 Carry Operator

Each vertical stage produces a "propagate (P)" and a "generate(G)"bit, as shown. The culminating generate bits (the carries) are produced in the last stage vertically, and these bits are XOR with the initial propagate after the input (as shown in the red boxes) to produce the sum bits. The addition algorithm is explained with example shown in the figure 4.



Fig 4 Han Carlson Addition Principle

The Han Carlson algorithm uses the parallel processing to improve the speed performance the major difference between Kogge-Stone adder and Han Carlson adder is shifting of bits towards the carry operator in each stage. In Kogge-Stone adder the shifting pattern is straight forward but in Han Carlson adder each time shifting of bits to the carry operator follows certain rules .The bit shifting pattern in Han Carlson adder is shown in figure 5.



# **Pipelined Multiplier**

Multiplication is one of the supreme operation in PID controller. Generally multiplication process consumes more power and gives sluggish speed performance due to several addition operations involved in it. Since the multiplier is the slowest data processing element the modern market needs speed improvement. One of the best approaches to improve the speed performance is to implement the pipelining in the design. Pipelining does all the operations concurrently without waiting for completion of other operation.

We implemented 8 stage pipelined multiplier in the PID algorithm. We introduced several registers to store the data. This stored data processed in the parallel form and reduces the number of clock cycles required for the operation. The literature review tells that we can get the double speed of operation with the introduction in the pipelining in the design.

# IV. PHYSICAL DESIGN

The physical design involves the floorplaning, routing and the creating GDS II file for fabrication. After the successful synthesis we created the physical design using the CADENCE ENCOUNTER tool to create the physical design by following the ASIC design flow we followed the following steps sequentially.

- 1. Generate the netlist file of the RTL design using 180nm technology library
- 2. Generate the IO Port mapping file, which has to import in ENCOUNTER.
- 3. After importing the file in ENCOUNTER generate the floorplan.
- 4. Create power pads, rings and stripes

- 5. Generate different types of routing like special routing trial routing and nano routing.
- 6. Place the standard cell and see the physical view, amoeba view and floorplan view of physical design.
- 7. Check for the timing analysis and generate GDS II file.



Fig 6 Physical View of Implemented Architecture using ENCOUNTER

# V. EXPERIMENTAL RESULTS

In this paper we simulated and synthesized using the Modelsim and different types of analysis is performed using Cadence RC compiler. By selecting the different sets of error coefficients we simulated the implemented PID algorithm .One of the simulation result is shown in figure 7.



Fig 7 Simulation Result using MODELSIM

After the simulation we synthesized both pipelined and non pipelined architectures using Cadence RC compiler .We performed DFT and low power synthesis of both the design and find out the power and clock period require for each design .To do the speed comparison between two architectures. We set the timing slack and calculate the clock period requires for both the design comparison table with respect to power and speed and has been mentioned below.

| FACTOR          | TRADITIONA<br>L<br>DESIGN | PIPELINED<br>DESIGN | COMMENT                                                      |
|-----------------|---------------------------|---------------------|--------------------------------------------------------------|
| CLOCK<br>PERIOD | 5000 pSec                 | 1050 pSec           |                                                              |
| FREQUENCY       | 200 MHz                   | 952MHz              | Pipelined<br>design is 5<br>times<br>faster                  |
| POWER           | 354784nW                  | 439029 <b>n</b> W   | Power is<br>more for<br>pipelined<br>design but<br>tolerable |

# Table 1 Comparison of Traditional and Pipelined Architecture

# VI. CONCLUSION

In this paper we introduced the high throughput parallel architecture of PID controller which uses the Pipelined multiplier and Han Carlson adder. We found that delay has been reduced by considerable amount of time, so we can conclude that use of pipelining and use of parallel prefix adder like Han Carlson adder improves the speed performance of the design. The implemented architecture can be used in automation industries, Power electronics applications and DSP applications and its give improved speed performance as compared to the traditional architectures.

# REFERENCES

- [1] Yuen Fong Chan M. Moallem "Design and Implementation of Modular FPGA-Based PID Controllers." IEEE Transactions on Industrial Electronics, Vol.54 (2007).
- [2] L Samet, N. Masmoudi, M. W. Kharrat, and L. Kamoun, "A Digital PID controller for real-time and multi-loop control: A comparative study," in Proc. IEEE International. Conference on Electronic Circuits and Systems., Sep. 1998, vol. 1.
- [3] S. L. Jung, M. Y. Chang, J. Y. Jyang, L. C. Yeh, and Y. Y. Tzou, "Design and implementation of an FPGA-based control IC for AC-voltage regulation," IEEE Transaction on. Power Electronics., vol. 14, no. 3, pp. 522–532.
- [4] R. Chen, L. Chen, and L. Chen, "System design consideration for digital wheelchair controller," IEEE Transaction on. Industrial. Electronics, vol. 47, no. 4, pp. 898–907, Aug. 2000.
- [5] Yajuan Chena, Qinghai Wu. "Design and Implementation of PID Controller based on FPGA and Genetic Algorithm." International Conference on Electronics and Optoelectronics