

(An ISO 3297: 2007 Certified Organization)

Vol. 3, Issue 7, July 2015

# Design of Pulse Width Modulation Controller on FPGA using HDL

Sneha Kirnapure<sup>1</sup>, Vijay R. Wadhankar<sup>2</sup>

PG Scholar, Dept. of E&C, Agnihotri College of Engineering, Nagthana Road, Wardha (M.S), India<sup>1</sup>

Professor, Dept. of E&C, Agnihotri College of Engineering, Nagthana Road, Wardha (M.S), India<sup>2</sup>

**ABSTRACT**: The paper develops high frequency PWM controller using FPGA. Pulse width modulation (PWM) has been widely used in communication and control system. PWM control is the most powerful technique that offers a simple method for controlling of analog systems with digital output. The simulated results having PWM frequencies up to 248.69 MHz can be produced with a duty cycle resolution of 0.39%. The VHDL modeling is used in the design process of PWM.

KEYWORDS: Pulse width modulation, Field programmable gate array, Hardware description language

### I. INTRODUCTION

Pulse width modulation has been widely used in many applications especially in communication and control systems. The paper develops high frequency PWM generator architecture for using FPGA.Using pulse width modulation (PWM) in control system is not new, there are different approaches for developing pulse width modulation. Many digital circuits can generate PWM signals, but what is interesting is, to generate pulse width modulation using Hardware Description Language (VHDL) and implementing it on FPGA. FPGA implementation of PWM is selected because FPGA can process information faster, controller architecture can beoptimized for space or speed.In PWM, the time period of the square wave is kept constant and the time for which the signal remains high is varied.

PWM is a technique to provide a logic "1" and logic "0" for a controlled period of time. It is a signal source involves the modulation of its duty cycle to control the amount of power sent to a load. The following paper describe the design of PWM on a FPGA using very high speed integrated circuit hardware description language (VHDL). The PWM generates pulses on its output. The pulses are made in such a way that the average value of highs and lows is proportional to the PWM input. The duty cycle of the signal can be varied. A PWM input can be of any width. Most common values are 8-bits and 16-bits. A PWM signal is a constant period square wave with a varying duty cycle (on-time compared to off-time). In other words, the frequency of a PWM signal is constant but the time the signal remains high varies as shown in Figure 1. The duty cycle (percent on time) is given by  $\tau/T$ .



Fig.1 PWM signal with different duty cycles



(An ISO 3297: 2007 Certified Organization)

### Vol. 3, Issue 7, July 2015

FPGAs are configurable ICs (user can design, program and make changes to his circuit whenever he wants)and used to implement logic functions. Today's FPGAs can hold several millions gates and have some significant advantage. They ensure ease of design, lower development costs and the opportunity to speed products to market. FPGA are programmable semiconductor devices that are based around a matrix of configurable logic block (CLBs) connected via programmable interconnects. FPGA can be programmed to the desired application or functionality requirement.

VHDL is a language that is used to describe the behaviour of digital circuit designs. It is VHSIC (Very High Speed Integrated Circuit) Hardware Description Language, and now used extensively by industry and academia for the purpose of simulating and synthesizing digital circuit design. Its designs can be simulated and translated into a form suitable for hardware implementation.VHDL modelling is used to generate the PWM.

To design the PWM in Field programmable gate array, first the functional description of the design modelled in very high speed integrated circuit HDL using the behavioral abstraction level and this VHDL code is synthesized and simulated using Xilinx Synthesis and simulation tool. After successfully synthesized and simulated the design it can be downloaded to the targeting device (FPGA).

#### II. **Related work**

The digital implementation of PWM is an important research area. The arrival of FPGA in power electronics brings out a dramatic change in the digital PWM control applications. With FPGA, the researchers got a better alternative solution for the digital implementation of PWM. The content of this thesis are based on various scholastic papers. Some of the papers are mentioning below and a brief idea of what they are about are mentioned. The digital implementation of PWM is an important research area. The arrival of FPGA in power electronics brings out a dramatic change in the digital PWM control applications. With FPGA, the researchers got a better alternative solution for the digital implementation of this thesis are based on various scholastic papers. Some of the papers are mentioned of PWM is an important research area. The arrival of FPGA in power electronics brings out a dramatic change in the digital PWM control applications. With FPGA, the researchers got a better alternative solution for the digital implementation of PWM is an about are mentioned about are mentioned at the papers are based on various scholastic papers. Some of the papers are mentioning below and a brief idea of what they are about are mentioned.

In [6], in this paper results show that PWM frequencies up to 3.985 MHz can be produced using the proposed design method with a duty cycle resolution of 1.56% using the Xilinx Foundation software v3.1. In [7], in this paper experimental results show that PWM frequency with an 8-bit data input was 46.875 kHzusing the XS40 v1.2 board, which contains the Xilinx 4010XLPC84-3 FPGA and PWM frequencies up to 3.985MHz can be produced with a duty cycle resolution of 1.56%. In [8], in this paper generation of PWM signals with varying duty cycle using VHDL code and tested on FPGA. A FPGA SPARTAN3 board is used as hardware and ISE10.1 XILINX is used as software. The generated PWM signals have a fixed frequency 10MHz.In [9], the generation of PWM signals is discussed using VHDL based on FPGA. A board SPARTAN3AN is used as a hardware and ISE14.4 XILINX is used as software. The generated PWM signals have a fixed frequency(11.8 KHz) depended on the frequency of sawtooth, and a variable duty cycle that changes from 0% to 100%.In [10], in this paper there are two classes of PWM techniques identified optimal PWM and carrier PWM.

The optimal PWM requires lot of computation and hence extra hardware and hence extra cost .Carrier PWM techniques require a carrier signal which is modulated with modulating signal to produce desired PWM signal. There are various methods depending upon architecture and requirement of the system. Their design implementation depends upon application type, power consumption, semiconductor devices, performance and cost criteria.In [11],in this paper PWM Generator architecture is used for low power switching supplies. The architecture is based on the principle that due to triggering of a counter by clock signal, clock is set equal to some multiple of switching frequency with help of a counter. The PWM output signal is set high before the clock signal and it remains high until it is reset after the counter value becomes equal to the duty cycle value.



(An ISO 3297: 2007 Certified Organization)

### Vol. 3, Issue 7, July 2015

### III. FUNCTIONAL DESCRIPTION OF THE PWM DESIGN



Fig.2 Block Diagram of PWM

The block diagram of the proposed architecture is shown in Fig.1. The system input is an N-bit dataword, corresponding to the desired PWM duty cycle value. The register stores the input to be processed .So when load signal is '1' the register provides input to output. The counter used is 8 bit up-counter. The N-bit register output, containing the N-bit data input, is compared with the output value of an N-bit counter, by means of a comparator. When these two values become equal, the comparator output is used to reset the R/S latch output which produces the PWM wave. The R/S latch output is set when the counter reaches an overflow condition atthe end of a PWM period. Also, the counter overflow signal is used to load the N-bit data input to the input register. R S latch is used to set or reset the output. When 'r'signal is '1' output is reset to '0'.When 's' signal is '1' output is set to '1'.

The duty cycle is given from the following equation:

Duty Cycle = Data Value $/2^n$ 

where, Data Value is the N-bit input data value.

For an 8 bit input, resulting in 2<sup>8</sup> different duty cycle states. The duty cycle of the PWM signal is controlled by the data value. The higher the data value the higher the duty cycle. If an 8-bit input is used, then the duty cycle is in the range  $0 \le D \le \frac{255}{256} = 99.6\%$ . Since the PWMduty cycle has 2<sup>8</sup> different states, the generator resolution,  $\alpha$ , is defined as,

$$\alpha = \frac{1}{2^{N}} \bullet 100\% = \frac{1}{2^{8}} \bullet 100\% = 0.39\%$$

| Data value | Duty Cycles (%) |
|------------|-----------------|
| 00000011   | 1.95            |
| 00010001   | 7.42            |
| 0111110    | 50              |
| 11110000   | 94.53           |

Table 1: Some of the Data Values for different Duty Cycles (N=8)

![](_page_3_Picture_0.jpeg)

(An ISO 3297: 2007 Certified Organization)

### Vol. 3, Issue 7, July 2015

| Device Utilization Summary (estimated values) |      |           |             |  |  |  |  |  |
|-----------------------------------------------|------|-----------|-------------|--|--|--|--|--|
| Logic Utilization                             | Used | Available | Utilization |  |  |  |  |  |
| Number of Slices                              | 1    | . 192     | 0 0%        |  |  |  |  |  |
| Number of 4 input LUTs                        | 2    | 384       | 0 0%        |  |  |  |  |  |
| Number of bonded IOBs                         | 4    | 14        | 1 2%        |  |  |  |  |  |
| Number of GCLKs                               | 1    |           | 8 12%       |  |  |  |  |  |

### IV. SIMULATION RESULTS

A software program using the VHDL language was developed, for synthesizing the block diagram presented in theprevious section, using the Xilinx ISE Design Suite 13.1 software. The RTL view of block diagram in fig.1 is shown in fig.3 and 4 and simulated waveforms are shown in fig.5,6. From the simulated waveform, we observe that higher the data value, higher the duty cycle and lower the data value, lower the duty cycle.

![](_page_3_Figure_8.jpeg)

Fig.3 RTL view of PWM block

![](_page_4_Picture_0.jpeg)

(An ISO 3297: 2007 Certified Organization)

Vol. 3, Issue 7, July 2015

![](_page_4_Figure_5.jpeg)

Fig.4 RTL view of PWM block

|                |          | 10,295.640 ns     |          |           |           |   |           |           |           |           |           |  |
|----------------|----------|-------------------|----------|-----------|-----------|---|-----------|-----------|-----------|-----------|-----------|--|
| Name           | Value    | 9,600 ns          | 9,800 ns | 10,000 ns | 10,200 rs |   | 10,400 ns | 10,600 ns | 10,800 ns | 11,000 ns | 11,200 ns |  |
| din[7:0] U din | 00000011 | กกกกกกกกก         | นกกกกกกก | เกกกกกกกก |           |   | 00000011  |           |           |           |           |  |
| i st           | 1        |                   |          |           |           | _ |           |           |           |           |           |  |
|                |          |                   |          |           |           |   |           |           |           |           |           |  |
|                |          |                   |          |           |           |   |           |           |           |           |           |  |
|                |          |                   |          |           |           |   |           |           |           |           |           |  |
|                |          |                   |          |           |           |   |           |           |           |           |           |  |
|                |          |                   |          |           |           |   |           |           |           |           |           |  |
|                |          |                   |          |           |           |   |           |           |           |           |           |  |
|                |          |                   |          |           |           |   |           |           |           |           |           |  |
|                |          | X1: 10,295.640 ns |          |           |           |   |           |           |           |           |           |  |

Fig.5 Simulated waveform when din=00000011

![](_page_5_Picture_0.jpeg)

(An ISO 3297: 2007 Certified Organization)

#### Vol. 3, Issue 7, July 2015

|          |                    |      |                |                                         | 128,364.500 ns |   |                                         |            |                                         |                                          |               |            |
|----------|--------------------|------|----------------|-----------------------------------------|----------------|---|-----------------------------------------|------------|-----------------------------------------|------------------------------------------|---------------|------------|
| Name     | Value              |      | 127,800 ns     | 128,000 ns                              | 128,200 ns     |   | 128,400 rs                              | 128,600 ns | 128,800 ns                              | 129,000 ns                               | 129,200 ns    | 129,400 ns |
| din(7:0) | 00010001           |      |                |                                         |                | É | 0                                       | 010001     |                                         |                                          |               |            |
| Ug dk    | 0                  | UUUU | เกิดการแบบเกิด | บบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบ |                | П | บบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบ | ากกากกากกา | บบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบ | กการการการการการการการการการการการการการ | บาทกากการเป็น |            |
| lig est  | 1.                 |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
| 1g pwm   | 1                  |      |                |                                         |                |   | 1                                       |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          |                    |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |
|          | XI: 128,364.500 ns |      |                |                                         |                |   |                                         |            |                                         |                                          |               |            |

Fig.6 Simulated waveform when din=00010001

#### V. CONCLUSION AND FUTURE WORK

Using Xilinx ISE Design Suite 13.1 software we can develop the proposed PWM in Xilinx FPGA. Due to the need of design flexibility in FPGA, an 8 bit resolution PWM was developed using VHDL modelingin Field Programmable Gate Array. The simulation results prove that using the proposed method, PWM frequencies up to 248.69 MHz can be produced with a duty cycle resolution of 0.39%. The VHDL modeling is used in the design process of PWM. Depending upon the application the requirement of the resolution is different. it is evident that higher values of N provide better resolution of the duty cycle, but performance should be taken into consideration when doing so. Future work should include high resolution of the duty cycle and high frequency application.

#### REFERENCES

- 1. SnehaKirnapure, Vijay R. Wadhankar ,'Review on Design of PWM Controller Using FPGA'International Journal of ScienceandResearch(IJSR), Volume 4 Issue 4, April 2015, pp1489-1492, 201.
- 2. Brown, Vranesic, 'Fundamentals of Digital Logic with VHDL Design', Tata McGraw Hill.
- 3. Wolf Wayne,"FPGA-Based System Design", Pearson Education, Inc., USA, 2004.
- 4. FPGAs for DUMMIES ,Altera special Edition ,by Andrew Moore.
- 5. Gwaltney, "FPGA Implementation of controls," 2003.
- 6. Jakirhusen I. Tamboli, Prof. Satyawan R. Jagtap, Amol R. Sutar, 'Pulse Width Modulation Implementation using FPGA and CPLD IC's',
- 7. International Journal of Scientific & Engineering Research Volume 3, Issue 8,pp 1-5, August-2012.
- 8. EffichiosKoutroulis, ApostolosDollas, Kostas Kalaitzakis,'High-frequency pulse width modulation implementation using FPGA & CPLD ICs', Journal of Systems Architecture 52 (2006) 332–344, pp 332-344, Available online 25 October 2005
- 9. Suneeta, R Srinivasan, Ramsagar, 'Generation of Variable Duty Cycle PWM using FPGA', IOSR Journal of VLSI and Signal Processing (IOSR-JVSP) Volume 4, Issue 6, Ver. II, PP 01-03 e-ISSN: 2319 4200, p-ISSN No. : 2319 4197 www.iosrjournals.org,pp-1-3, Nov Dec. 2014.
- 10. ZiadNouman, BohumilKlima, Jan Knobloch 'Generating PWM Signals With Variable Duty From 0% to 100%
- 11. Based FPGA SPARTAN3ANAI'Electrorevue ISSN 1213-1539 VOL.4, NO.4, pp 75-80, DECEMBER 2013.
- 12. Rahim, N.A. and Islam Z.,'A single-phase series active power filter design', Proceeding of the International Conference on Electrical, Electronic and Computer Engineering, IEEE Xplore Press, Sept. 2004, pp: 926-929
- 13. Dancy A.P., Amirtharajah R. and Chandrakasan A.P., 'High-Efficiency Multiple-Output DC-DC Conversion for Low-Voltage Systems', IEEE Trans. on Very Large Scale Integration (VLSI) Systems, Vol. 8, No. 3, June 2000: pp.252-263.

#### BIOGRAPHY

**SnehaKirnapure**received her B.E. in Electronics from R.C.E.R.T., Chandrapur, India in 2009. Currently she is pursuing M.Tech in Electronics from A.C.E., Wardha, India.

**Prof. Vijay R. Wadhankar** eceivedhis B.E. in Electronics from B.D.C.O.E., Wardha , India and M.Tech in VLSI from G. H. Raisoni College, Nagpur, India. He is working as Head of Dept. in A.C.E., Wardha, India.