

# High Performance FPGA Based Digital Space Vector PWM Three Phase Voltage Source Inverter

Bahram Rashidi Isfahan University of technology, IRAN E-mail: b.rashidi@ec.iut.ac.ir

> Mehran Sabahi University of Tabriz E-mail: sabahi@tabrizu.ac.ir

Abstract— This paper focuses on the design of a low power and high performance FPGA based Digital Space Vector Pulse Width Modulation (DSVPWM) controller for three phase voltage source inverter. A new method is proposed to realize easy, accurate and high performance DSVPWM technique based on FPGA with low resource consumption and reduced execution time than conventional methods. Equations of SVPWM are relatively complicated and need a considerable time to execute on a typical microcontroller, therefore a simple method is presented to minimize run time of instructions, e.g. the multiplication operation used in these equations is replaced by a proposed signed and unsigned shifter using 2 to 1 multiplexer unit. Total power consumption of controller is reduced to 37 mW at 100MHz clock frequency. The proposed DSVPWM technique algorithm was synthesized and implemented using Quartus II 9.1V and Cyclone II FPGA, to target device EP2C20F484C6. Also power is analyzed using XPower analyzer. Experimentation and results demonstrate that proposed method have high performance than other works.

*Index Terms*— DSVPWM, Voltage Source Inverter, FPGA, VHDL, Combinational Logic

### I. INTRODUCTION

The SVPWM technique offers significant performance benefits and has proved to be very popular in three-phase systems [1-4]. Pulse Width Modulation variable speed drives are increasingly applied in many new industrial applications that require superior performance. Recently, developments in power electronics and semiconductor technology have lead improvements in power electronic systems. Hence, different circuit configurations namely multilevel inverters have become popular and considerable interest by researcher are given on them. Variable voltage and frequency supply to ac drives is invariably obtained from a three-phase voltage source inverter. A number of Pulse width modulation (PWM) schemes are used to

obtain variable voltage and frequency supply. The most widely used PWM schemes for three-phase voltage source inverters are carrier-based sinusoidal PWM and space vector PWM (SVPWM). There is an increasing trend of using Space Vector PWM (SVPWM) because of their easier digital realization and better dc bus utilization. As seen from the above discussion Space Vector PWM is superior as compared to Sinusoidal pulse width modulation in many aspects like:

- 1- The Modulation Index is higher for SVPWM as compared to SPWM.
- 2- The output voltage is about 15% more in case of SVPWM as compared to SPWM.
- 3- The current and torque harmonics produced are much less in case of SVPWM.

However despite all the above mentioned advantages that SVPWM enjoy over SPWM, SVPWM algorithm used in three-level inverters is more complex because of large number of inverter switching states. Hence we see that there is a certain trade off that exists while using SVPWM for inverters for Adjustable speed Drive Operations. Due to this we have to choose carefully as to which of the two techniques to use weighing the pros and cons of each method [2]. Recently some control systems have been considered to deign using fieldprogrammable gate array, FPGA integrated circuit. Implementation of SVPWM by using FPGA has been studied by a few researchers; a novel space vector pulse width modulation (SVPWM) algorithm for multilevel multiphase voltage source converters is presented in [1]. In [3], a resource efficient SVPWM algorithm is proposed which reduces computational overheads and solves the problem of high sampling time in real time applications. In [4], a simple realization of 5-segment discontinuous SVPWM, with simple calculation of the firing has been presented.

This paper focuses on the design of a low power and high performance FPGA based Digital Space Vector Pulse Width Modulation (DSVPWM) controller for three phase voltage source inverter.

# II. THE PROPOSED HIGH PERFORMANCE DSVPWM SIGNAL GENERATION STRATEGY

A 3-phase output can be obtained from a configuration of six transistors as shown in Fig. 1. The concept of SVPWM has been fully studied in several lectures therefore the required equations are available. The proposed method used in this design, is to replace the conventional method with the hardware description language VHDL on FPGA, based on high performance digital circuit, which better accuracy and performance are obtained by field generated pulses of PWM. The use of the FPGA brings flexibility to change the real-time control algorithms without further changes in hardware. It will reduce the overall cost and has a small size of control circuit for the three phase full bridge inverter. The aim of this research is mainly to design and develop the SPWM switching method to FPGA based DSVPWM on three phase voltage source inverter. Proposed design is based on optimized digital circuit.



Fig.1: Full bridge 3-phase inverter.

### A. Principle of Space Vector PWM

The sinusoidal voltage treats as a constant amplitude vector rotating at constant frequency. This PWM technique approximates the reference voltage  $V_{ref}$  by a combination of the eight switching patterns ( $V_0$  to  $V_7$ ). Coordinate Transformation (abc reference frame to the stationary d-q frame): A three-phase voltage vector is transformed into a vector in the stationary d-q coordinate frame which represents the spatial vector sum of the three-phase voltage. The vectors ( $V_1$  to  $V_6$ ) divide the plane into six sectors (each sector: 60 degrees).  $V_{ref}$  is generated by two adjacent non zero vectors and two zero vectors. Basic switching vectors and Sectors [7]:

6 active vectors  $(V_1, V_2, V_3, V_4, V_5, V_6)$ 

Axes of a hexagonal

DC link voltage is supplied to the load Each sector (1 to 6): 60 degrees

Basic switching vectors and Sectors are shows in Fig.2.



Fig.2: Basic switching vectors and sectors.

#### B. Realization of Space Vector PWM:

- Step 1. Determine  $V_d$ ,  $V_q$ ,  $V_{ref}$ , and angle ( $\alpha$ )
- Step 2. Determine time duration  $T_1$ ,  $T_2$ ,  $T_0$
- Step 3. Determine the switching time of each transistor (S<sub>1</sub> to S<sub>6</sub>)

### Step 1: Determine $V_d$ , $V_q$ , $V_{ref}$ , and angle ( $\alpha$ )

To implement the space vector PWM, the voltage equations in the abc reference frame can be transformed into the stationary d-q reference frame that consists of the horizontal (d) and vertical (q) axis as depicted in Fig.3.



Fig.3: Voltage Space Vector and its components in (d, q).

The relationship between switching variable vector and phase voltage vector  $[V_a V_b V_c]$  can be expressed as follows [3]:

$$V_{d} = V_{an} - V_{bn} \cdot \cos 60 - V_{cn} \cdot \cos 60$$
  
=  $V_{an} - \frac{1}{2} V_{bn} - \frac{1}{2} V_{cn}$   
$$V_{q} = 0 + V_{bn} \cdot \cos 30 - V_{cn} \cdot \cos 30$$
  
=  $\frac{\sqrt{3}}{2} V_{bn} - \frac{\sqrt{3}}{2} V_{cn}$ 

$$\left[ \begin{matrix} \mathbf{V}_{d} \\ \mathbf{V}_{q} \end{matrix} \right] = \frac{2}{3} \begin{bmatrix} 1 & -\frac{1}{2} & -\frac{1}{2} \\ 0 & \frac{\sqrt{3}}{2} & -\frac{\sqrt{3}}{2} \end{bmatrix} \begin{bmatrix} \mathbf{V}_{an} \\ \mathbf{V}_{bn} \\ \mathbf{V}_{cn} \end{bmatrix}$$
(1)

The reference vector  $V_{ref}$  is calculated as [3]:

$$\left|\overline{\mathbf{V}}_{ref}\right| = \sqrt{\mathbf{V}_{d}^{2} + \mathbf{V}_{q}^{2}}$$
  
$$\alpha = \tan^{-1}\left(\frac{\mathbf{V}_{q}}{\mathbf{V}_{d}}\right) = \omega_{s} \mathbf{t} = 2\pi\pi_{s} \mathbf{t}$$
(2)

(Where,  $f_s =$  fundamental frequency)

In general,  $V_{ref}$  in 'n' sector is obtained by two adjacent non-zero vectors  $(V_n, V_{n+1})$  and two-zero vectors.  $V_{ref}$  is expressed as [3]:

$$V_{\rm ref} = \frac{T_{\rm n}}{T_{\rm Z}} \cdot V_{\rm n} + \frac{T_{\rm n+1}}{T_{\rm Z}} V_{\rm n+1}$$
(3)

Where  $T_n \& T_{n+1}$  are on time of  $V_n$  and  $V_{n+1}$  during each sampling period  $(T_z)$  respectively and 'n' is the sector number in which  $V_{ref}$  resides.

### Step 2: Determine Time Duration $T_1$ , $T_2$ , $T_0$

The switching time duration  $T_1$ ,  $T_2$  and  $T_0$  for a particular sector can be calculated from following equations [3].

Fig. 4 shows reference vector as a combination of adjacent vectors at sector 1.



Fig. 4: Reference vector as a combination of adjacent vectors at sector 1

Step 3. Determine The Switching Time Of Each Transistor  $(S_1 To S_6)$ 

Switching time duration at Sector 1:

$$\begin{split} & \int_{0}^{T_{z}} \overline{\mathbf{V}}_{ref} = \int_{0}^{T_{1}} \overline{\mathbf{V}}_{1} dt + \int_{T_{1}}^{T_{1}+T_{2}} \overline{\mathbf{V}}_{2} dt + \int_{T_{1}+T_{2}}^{T_{z}} \overline{\mathbf{V}}_{0} \\ & \therefore \mathbf{T}_{z} \cdot \overline{\mathbf{V}}_{ref} = (\mathbf{T}_{1} \cdot \overline{\mathbf{V}}_{1} + \mathbf{T}_{2} \cdot \overline{\mathbf{V}}_{2}) \\ & \Rightarrow \mathbf{T}_{z} \cdot \left| \overline{\mathbf{V}}_{ref} \right| \cdot \begin{bmatrix} \cos\left(\alpha\right) \\ \sin\left(\alpha\right) \end{bmatrix} = \mathbf{T}_{1} \cdot \frac{2}{3} \cdot \mathbf{V}_{dc} \cdot \begin{bmatrix} 1 \\ 0 \end{bmatrix} + \\ & \mathbf{T}_{2} \cdot \frac{2}{3} \cdot \mathbf{V}_{dc} \cdot \begin{bmatrix} \cos\left(\pi/3\right) \\ \sin\left(\pi/3\right) \end{bmatrix}; \end{split}$$
(4)

(where,  $0 \le \alpha \le 60^\circ$ )

$$\therefore T_{1} = T_{z} \cdot a \cdot \frac{\sin(\pi/3 - \alpha)}{\sin(\pi/3)}$$
  
$$\therefore T_{2} = T_{z} \cdot a \cdot \frac{\sin(\alpha)}{\sin(\pi/3)}$$
  
$$\therefore T_{0} = T_{z} - (T_{1} + T_{2}), \quad \left( \text{where,} \quad T_{z} = \frac{1}{f_{s}} \quad \text{and} \quad a = \frac{\left| \overline{V}_{\text{ref}} \right|}{\frac{2}{3} V_{\text{dc}}} \right)$$
(5)

Switching time duration at any Sector

$$\therefore T_{1} = \frac{\sqrt{3} \cdot T_{z} \cdot |\overline{V}ref|}{V_{dc}} \left( \sin\left(\frac{\pi}{3} - \alpha + \frac{n-1}{3}\pi\right) \right)$$

$$= \frac{\sqrt{3} \cdot T_{z} \cdot |\overline{V}ref|}{V_{dc}} \left( \sin\frac{n}{3}\pi - \alpha \right)$$

$$= \frac{\sqrt{3} \cdot T_{z} \cdot |\overline{V}ref|}{V_{dc}} \left( \sin\frac{n}{3}\pi \cos\alpha - \cos\frac{n}{3}\pi \sin\alpha \right)$$

$$\therefore T_{2} = \frac{\sqrt{3} \cdot T_{z} \cdot |\overline{V}ref|}{V_{dc}} \left( \sin\left(\alpha - \frac{n-1}{3}\pi\right) \right)$$

$$= \frac{\sqrt{3} \cdot T_{z} |\overline{V}ref|}{V_{dc}} \left( -\cos\alpha \cdot \sin\frac{n-1}{3}\pi + \sin\alpha \cdot \cos\frac{n-1}{3}\pi \right)$$

$$\therefore T_{0} = T_{z} - T_{1} - T_{2},$$

$$\left( \begin{array}{c} n = 1 \text{ through } 6(\text{ that is, Sector } 1 \text{ to } 6) \\ 0 \le \alpha \le 60^{\circ} \end{array} \right)$$

$$(6)$$

The switching time of each switching devices  $(S_1 \sim S_6)$  per sector is given as per Table I

TABLE I: SWITCHING TIME AT EACH SECTOR.

| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |                           |                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------|---------------------------|
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Sector | $S_1, S_3, S_5$           | $S_2, S_4, S_6$           |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        | $S_1 = T_1 + T_2 + T_0/2$ | $S_4 = T_0/2$             |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1      | $S_3 = T_2 + T_0/2$       | $S_6 = T_1 + T_0/2$       |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        | $S_5 = T_0/2$             | $S_2 = T_1 + T_2 + T_0/2$ |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        | $S_1 = T_1 + T_0/2$       | $S_4 = T_2 + T_0/2$       |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 2      | $S_3 = T_1 + T_2 + T_0/2$ | $S_6 = T_0/2$             |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        | $S_5 = T_0/2$             | $S_2 = T_1 + T_2 + T_0/2$ |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        | S1=T0/2                   | $S_4 = T_1 + T_2 + T_0/2$ |
| $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 3      | S3 = T1 + T2 + T0/2       | $S_6 = T_0/2$             |
| $\begin{array}{c ccccc} S_1 = T_0/2 & S_4 = T_1 + T_2 + T_0/2 \\ S_3 = T_1 + T_0/2 & S_6 = T_2 + T_0/2 \\ S_5 = T_1 + T_2 + T_0/2 & S_2 = T_0/2 \\ \hline \\ S & S_1 = T_2 + T_0/2 & S_4 = T_1 + T_0/2 \\ S_5 = T_1 + T_2 + T_0/2 & S_6 = T_1 + T_2 + T_0/2 \\ \hline \\ S & S_1 = T_1 + T_2 + T_0/2 & S_4 = T_0/2 \\ \hline \\ 6 & S_3 = T_0/2 & S_6 = T_1 + T_2 + T_0/2 \\ \hline \\ 6 & S_3 = T_0/2 & S_6 = T_1 + T_2 + T_0/2 \\ \hline \\ 8 & S_5 = T_1 + T_0/2 & S_2 = T_2 + T_0/2 \\ \hline \end{array}$ |        | S5 = T1 + T2              | $S_2 = T_1 + T_0/2$       |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        | $S_1 = T_0/2$             | $S_4 = T_1 + T_2 + T_0/2$ |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 4      | $S_3 = T_1 + T_0/2$       | $S_6 = T_2 + T_0/2$       |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        | $S_5 = T_1 + T_2 + T_0/2$ | $S_2 = T_0/2$             |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        | $S_1 = T_2 + T_0/2$       | $S_4 = T_1 + T_0/2$       |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 5      | $S_3 = T_0/2$             | $S_6 = T_1 + T_2 + T_0/2$ |
| $ \begin{array}{ c c c c c c c } 6 & S_1 = T_1 + T_2 + T_0/2 & S_4 = T_0/2 \\ S_3 = T_0/2 & S_6 = T_1 + T_2 + T_0/2 \\ S_5 = T_1 + T_0/2 & S_2 = T_2 + T_0/2 \end{array} $                                                                                                                                                                                                                                                                                                                                     |        | $S_5 = T_1 + T_2 + T_0/2$ | $S_2 = T_0/2$             |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        | $S_1 = T_1 + T_2 + T_0/2$ | $S_4 = T_0/2$             |
| $S_5 = T_1 + T_0/2$ $S_2 = T_2 + T_0/2$                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 6      | $S_3 = T_0/2$             | $S_6 = T_1 + T_2 + T_0/2$ |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        | $S_5 = T_1 + T_0/2$       | $S_2 = T_2 + T_0/2$       |

The sector identification criterion of conventional algorithm involves floating point operations as to get angle that requires calculating inverse tan function. Because of sine function and square root values involved in computation switching time duration i.e.  $T_1$ ,  $T_2$  and  $T_0$ , implementation of conventional algorithm using digital processor becomes difficult [3].

### C. Proposed Implementation of DSVPWM on FPGA

Today digital designers use hardware description languages (HDLs) to design digital systems. The most widely used HDLs are VHDL and Verilog. Both of these hardware description languages allow the user to design digital systems by writing a program that describes the behavior of the digital circuit. The program can then be used to both simulate the operation of the circuit and synthesize an actual implementation of the circuit in a CPLD, an FPGA, or an application specific integrated circuit (ASIC). Another recent trend is to design digital circuits using block diagrams or graphic symbols that represent higher-level design constructs. These block diagrams can then be compiled to produce Verilog or VHDL code. VHDL is based on the Ada software programming language but it is not Ada nor is it a software programming language. VHDL is a hardware description language that is designed to model digital logic circuits. It simply has syntax similar to the Ada programming language but the way it behaves is different [8]. In this paper we use of hardware description language VHDL for design and implement full-DSVPWM based on combinational logic circuits with low resource utilization and reduces execution time. We use simplify mathematical equations which require only addition, subtraction, shifting (combinational based on proposed signed shifter). We implement the DSVPWM algorithm for three phase voltage source inverter on an Induction Motor based on FPGA. in continue we decryption proposed method.

# D. Computation $X_d$ and $X_q$ based on $V_a$ , $V_b$ and $V_c$ with proposed signed shifter

The conventional SVPWM algorithm includes d-q transformation of three input voltages  $V_{an}$ ,  $V_{bn}$  and  $V_{cn}$  as given by equation (4) this transformation requires value of  $\sqrt{3}$  to be calculated it is difficult to implement floating point numbers using FPGA. Hence instead of d-q transformation, intermediate transformation vectors are used. The eq. (1) can be written as [3]:

$$V_{d} = \frac{2}{3} V_{a} - \frac{1}{3} V_{b} - \frac{1}{3} V_{c}$$

$$V_{q} = \frac{1}{\sqrt{3}} V_{b} - \frac{1}{\sqrt{3}} V_{c}$$

$$\therefore V_{d} = \frac{1}{2} [2 V_{a} - V_{b} - V_{c}]$$
(7)

$$V_{q} = \frac{3}{\sqrt{3}} [V_{b} - V_{c}]$$
(8)

By defining intermediate variables as Xd and Xq, the eq. (7) written as [3]:

$$X_{d} = 2V_{a} - V_{b} - V_{c}$$
$$X_{a} = V_{b} - V_{c}$$

In continue we present proposed circuit and digital design for implementation of  $X_d$  and  $X_a$  based on eq.(9) thus we for this work implement 2V<sub>a</sub> alone with shift operation without use multiplier and two subtractor. For implementation of 2V<sub>a</sub> proposed combinational signed shifter based on (2 to 1) multiplexer, Shifter block is made only based on multiplexer. The input is an 8-bit vector, the output is a shifted version of the input, it shift input to left from 0 to 7(if number is 8 bits) proportional to the weight of select bits (sel[2..0]). If the value of select bits is 0, we have non-shift otherwise we have shift proportional to the weight of select bits. The circuit consists of three individual barrel shifters. Notice that the first barrel has only one '0' connected to one of the multiplexers while the second has two, and the third has four. For larger vectors, we would just keep doubling the number of '0' inputs. If shift "001", for example, then only the first barrel should cause a shift; on the other hand, if shift "111", then all barrels should cause a shift. Thus for compute  $2V_a$  we select  $S1_0='1'$ ,  $S1_1='0'$ , S1 2='0'. Fig. 5 shows an unsigned shifter block.



Fig.5: Unsigned shifter block.

Hence the proposed method to calculate  $X_d$  and  $X_q$  needs only simple operators namely shifter (for  $2V_a$  i.e. multiplication by 2), and subtractor that all are combinational circuits without clock signal and extra hardware proposed implementation of this block is completely optimized and low power because this block is only based on 2 to 1 multiplexer. Fig. 6 and Fig. 7 shows schematic and waveform of proposed VHDL code for compute  $X_d$  and  $X_q$  based on  $V_a$ ,  $V_b$  and  $V_c$ .

|                            | svpwm_3_2_trasform      |  |
|----------------------------|-------------------------|--|
| va[70] INPUT               | va[70] xq[70]           |  |
| vc[70] VCC<br>vc[70] INPUT | vb[70] xd[70]<br>vc[70] |  |
|                            | inst1                   |  |

Fig. 6: Schematic of  $X_d$  and  $X_q$  based on  $V_a$ ,  $V_b$  and  $V_c$ .

| ± va | S 1  | 17  | χ 20 |   | -120 | X | 56 |  |
|------|------|-----|------|---|------|---|----|--|
| 🛨 vb | S1   | 16  | χ 30 |   | -100 | X | 40 |  |
| ± vc | S3   | 30  | χ 10 |   | -100 | X | 40 |  |
| 🗄 Xd | S -1 | -12 | X O  | X | -40  | X | 32 |  |
| ± xq | S -1 | -14 | X 20 | X | 0    | X | 0  |  |
|      |      |     |      |   |      |   |    |  |

Fig.7: waveform of  $X_d$  and  $X_q$  based on  $V_a$ ,  $V_b$  and  $V_c$ .

By combining eq. (8) and (9), the  $V_d$  and  $V_q$  are expressed in terms of intermediate vectors as [3]:

$$\therefore \mathbf{V}_{d} = \frac{1}{3} [\mathbf{X}_{d}]$$

$$\mathbf{V}_{q} = \frac{1}{\sqrt{3}} [\mathbf{X}_{q}]$$
(9)

# E. Determination of The Sectors With Proposed Digital Design

The determination of sector depends only on the sign of  $X_d$  and  $X_q$  as per following rules. Determination of the sectors can be done by simply checking 3 conditions:

Condition 1: sign of  $X_d$ Condition 2: sign of  $X_q$ Condition 3:  $|X_d| > |X_q/2|$ 

We do this part with a simple combination logic circuits have been implemented. First implement condition 1 and then condition 2 is implemented in continue we implement Expression Xq/2 with Shift to the right one bit. Than  $|X_d|$ ,  $|X_q/2|$  with proposed digital circuit implemented without use of *abs* () function. Total of three condition 1, condition 2 and condition 3 are design and implementation with optimized and combinational logic circuit.

The rules to find sectors base on [3]:

 $\begin{array}{l} \mbox{Rule 1: if } (X_d \!\!>\!\!0 \& X_q \!\!>\!\!0 \& |X_d| \!\!>\!\!|X_q/2|) \mbox{Sector-1} \\ \mbox{Rule 2: if } (X_d \!\!>\!\!0 \& X_q \!\!>\!\!0 \& |X_d| \!\!<\!\!|X_q/2|) \mbox{Sector-2} \mbox{ OR if} \\ (X_d \!\!<\!\!0 \& X_q \!\!>\!\!0 \& |X_d| \!\!<\!\!|X_q/2|) \mbox{Sector-2} \\ \mbox{Rule 3: if } (X_d \!\!<\!\!0 \& X_q \!\!>\!\!0 \& |X_d| \!\!>\!\!|X_d| \!\!>\!\!|X_q/2|) \mbox{Sector-3} \\ \mbox{Rule 4: if } (X_d \!\!<\!\!0 \& X_q \!\!<\!\!0 \& |X_d| \!\!>\!\!|X_d| \!\!>\!\!|X_q/2|) \mbox{Sector-4} \\ \mbox{Rule 5: if } (X_d \!\!>\!\!0 \& X_q \!\!<\!\!0 \& |X_d| \!\!<\!\!|X_q/2|) \mbox{Sector-5} \mbox{ OK } \\ \mbox{Kull 6: if } (X_d \!\!>\!\!0 \& X_q \!\!<\!\!0 \& |X_d| \!\!<\!\!|X_q/2|) \mbox{Sector-5} \\ \mbox{Rule 6: if } (X_d \!\!>\!\!0 \& X_q \!\!<\!\!0 \& |X_d| \!\!<\!\!|X_d/2|) \mbox{Sector-6} \\ \end{array}$ 

Proposed digital design for sector determination is shows in Fig. 8 as see we implement Rule 1 to Rule 6 based on simple and low power logic circuits proposed design is based on combinational logic circuits thus we increase performance and reduced power consumption. This proposed digital circuit implement sector determination completely and accurate. For increase performance of design can use sub-pipelining technique.



Fig. 8: Proposed digital design for sector determination.



Fig.9: (a) Proposed signed shifter B, (b) Proposed signed shifter A.

For compute  $X_q/2$  use signed shift to right one bit thus we make a signed shifter in this signed shifter, ordering of input number be inverse indeed  $X_q$ [7..0] replace with  $X_q$ [0..7] that must enter to proposed signed shifter. Signed shifter A and B are based on combinational digital circuits with 2 to 1 multiplexer. Proposed signed shifter block is shown in Fig. 9.

Schematic and waveform of sector determination are shows in Fig. 10 and Fig. 11.



Fig.10: Schematic proposed method for implementation sector determination.

| € Xd     | S2 | 20 | ( 5    | .70  | 80   | (25)    | 100          |
|----------|----|----|--------|------|------|---------|--------------|
| 🗄 Xq     | S  | 5  | ( 20 ) | X 40 | (-30 | ( -90 ) | ( <u>70)</u> |
| ± sector | H  |    | X 2    | χ3   | X4   | X 5     | K 6 K        |

Fig. 11: Waveform proposed method for implementation sector determination.

### F. Determination Switching Times With Proposed Digital Design

For a symmetric space vector PWM, the output voltage i.e.  $X_d$  and  $X_q$  can be in any of the sector 1 to sector 6 is given by the equation [3]:

$$\begin{bmatrix} T_{n} \\ T_{n+1} \end{bmatrix} = T_{PWM} M_{0} \begin{bmatrix} X_{d} \\ X_{q} \end{bmatrix}$$
(10)

Eq. (11) shows that every PWM period, the output voltages are approximated as  $(T_z/V_{dc})$  by switching between the two none zero basic vectors that border the sector of the current output voltages. The sum of  $T_n$  and  $T_{n+1}$  should be less than or equal to  $T_{PWM}$  and rest of period the switching time should be  $T_0$  The  $M_0$  is called as decomposition matrix, given as applying equation (10) to (6), the switching time can be calculated as [3]:

$$M_{0} = \begin{bmatrix} M_{00} & M_{01} \\ M_{10} & M_{11} \end{bmatrix}$$
(11)  
$$= \begin{bmatrix} \frac{2}{\sqrt{3}} \sin\left(\frac{\pi}{3}n\right) & -\cos\left(\frac{\pi}{3}n\right) \\ -\frac{2}{\sqrt{3}} \sin\left(\frac{\pi}{3}(n-1)\right) & \cos\left(\frac{\pi}{3}(n-1)\right) \end{bmatrix}$$
(12)

If  $v_{dc}$  is normalized with  $\sqrt{3}$  per unit, and  $T_z$  is set to  $\sqrt{3}$  per unit, the four coefficients in eq. (12) will alter their values according to the sector 'n'. If reference vector is located in sector I, then 'n'=1, then  $M_{00}=1$ ,  $M_{01}=-1/2$ ,  $M_{10}=0$ ,  $M_{11}=1$ . The coefficients of decomposition matrix according to sector are given in Table II [3].

TABLE II: COEFFICIENTS OF DECOMPOSITION MATRIX

| Sector 'n'      | 1       | 2     | 3    | 4   | 5     | 6   |
|-----------------|---------|-------|------|-----|-------|-----|
| M <sub>00</sub> | 1       | 1     | 0    | -1  | -1    | 0   |
| M <sub>01</sub> | -1/2    | 1/2   | 1    | 1/2 | -1/2  | -1  |
| M <sub>10</sub> | 0       | -1    | -1   | 0   | 1     | 1   |
| M <sub>11</sub> | 1       | 1/2   | -1/2 | -1  | -1/2  | 1/2 |
| 0 0             | (11) (1 | • , • | 1 •  |     | 1 1 / | 1   |

So form eq.(11) the switching times are calculated as:

$$\begin{bmatrix} \mathbf{T}_{n}' \end{bmatrix} = \begin{bmatrix} \mathbf{M}_{00} & \mathbf{M}_{01} \end{bmatrix} \begin{bmatrix} \mathbf{X}_{d} \\ \mathbf{X}_{q} \end{bmatrix}$$
$$\begin{bmatrix} \mathbf{T}_{n+1}' \end{bmatrix} = \begin{bmatrix} \mathbf{M}_{10} & \mathbf{M}_{11} \end{bmatrix} \begin{bmatrix} \mathbf{X}_{d} \\ \mathbf{X}_{q} \end{bmatrix}$$
$$\begin{bmatrix} \mathbf{T}_{0}' \end{bmatrix} = \sqrt{3} - \mathbf{T}_{n}' + \mathbf{T}_{n+1}'$$
(13)

Proposed implementation algorithm for compute the switching times show in below

$$\begin{split} &If(sector=1) => T_n = X_{d^-} \\ &shift\_to\_right(X_q), T_{n+1} = X_q, T_0 = \sqrt{3} \cdot T_n + T_{n+1} \\ &If(sector=2) => T_n = X_d + shift\_to\_right(X_q), T_{n+1} = \\ &shift\_to\_right(X_q) - X_{d_0} T_0 = \sqrt{3} \cdot T_n + T_{n+1} \\ &If(sector=3) => T_n = X_q, T_{n+1} = -X_{d^-} \\ &shift\_to\_right(X_q), T_0 = \sqrt{3} \cdot T_n + T_{n+1} \\ &If(sector=4) => T_n = -X_d + shift\_to\_right(X_q), T_{n+1} = -X_{q^0} \\ &X_q, T_0 = \sqrt{3} \cdot T_n + T_{n+1} \\ &If(sector=5) => T_n = -X_d - shift\_to\_right(X_q), T_{n+1} = X_{d^-} \\ &shift\_to\_right(X_q), T_0 = \sqrt{3} \cdot T_n + T_{n+1} \\ &If(sector=6) => T_n = -X_d, \\ &shift\_to\_right(X_q), T_0 = \sqrt{3} \cdot T_n + T_{n+1} \\ &If(sector=6) => T_n = -X_q, \\ &T_{n+1} = X_d + shift\_to\_right(X_q), T_0 = \sqrt{3} \cdot T_n + T_{n+1} \\ &If(sector=6) => T_n = -X_q, \\ &T_{n+1} = X_d + shift\_to\_right(X_q), T_0 = \sqrt{3} \cdot T_n + T_{n+1} \\ &If(sector=6) => T_n = -X_q, \\ &T_{n+1} = X_d + shift\_to\_right(X_q), T_0 = \sqrt{3} \cdot T_n + T_{n+1} \\ &If(sector=6) => T_n = -X_q, \\ &T_{n+1} = X_d + shift\_to\_right(X_q), T_0 = \sqrt{3} \cdot T_n + T_{n+1} \\ &If(sector=6) => T_n = -X_q, \\ &T_{n+1} = X_d + shift\_to\_right(X_q), T_0 = \sqrt{3} \cdot T_n + T_{n+1} \\ &If(sector=6) = T_n = -X_q, \\ &T_{n+1} = X_d + shift\_to\_right(X_q), T_0 = \sqrt{3} \cdot T_n + T_{n+1} \\ &If(sector=6) = T_n = -X_q, \\ &T_n = T_n = T_n = T_n = T_n = T_n \\ &T_n = T_n \\ &T_n = T_n = T_n = T_n = T_n = T_n \\ &T_n = T_n \\ &T_n = T_n \\ &T_n = T_n = T$$

In this part for implementation we use of  $T_n$ ,  $T_{n+1}$  and T<sub>0</sub> use shift to the right, additional and subtraction operation without use multiplier. We for implement  $\sqrt{3}$ use a new technique based on logic shift without any Logic shifter is based on unsigned complexity. combinational shifter show in figure 4 that is design only with 2 to 1 multiplexer schematic of operation proposed method for implement  $\sqrt{x}$  thus beginning number 1 with unsigned shift block shifted one bit to left and then compare with input number if input number is bigger of shifted number counter one unit increase until shifted number being bigger input number in end counter number is load in output register. Schematic of proposed method is shown in Fig.12 if input equal 3 thus  $\sqrt{3}$  is compute.



Fig.12: Schematic of proposed method for implementation  $\sqrt{x}$ 

Fig. 13 shows waveform of implementation  $\sqrt{x}$ .

| dook     | H | הההההה | ההההההה    |    | תתתתתת |   |
|----------|---|--------|------------|----|--------|---|
| 🗄 input  | U | 0 3    | (16)       | 25 | 37     | 0 |
| tuqtuo 🗄 | U | 0 ) 2  | <u>X</u> 4 | χ5 | χ      | 6 |

Fig. 13: Waveform of proposed method for implementation  $\sqrt{x}$ 

Schematic and waveform of switching times are shows in Figure 14 and Figure 15.

|            | svpwm_switching_tin | le      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|---------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Xd[70]     | x_dB[70]            | T0[70]  | OUTPUT TO[70]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Xq[70]     | x gB(7,0)           | T1/7 01 | OUTPUT T1[70]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| sector[30] | sectorBB[30]        | T2[70]  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|            | inst1               |         | . <u>Supported and a second seco</u> |

Fig. 14: Schematic proposed method for implementation switching times.

| 🗄 Xd        | S2  | 20  | (5)    | -70  | (50)         | 25 ) | 10 )    |           |
|-------------|-----|-----|--------|------|--------------|------|---------|-----------|
| 🗄 Xq        | S   | 5   | ( 20 ) | ( 40 | ( .30 )      | -90  | -70 )   |           |
| 🗄 sector    | S   |     | ( 2 )  | 3    | ( 4 )        | 5)   | 6)      |           |
| ± TO        | S-i | -11 | -8     | 12   | 97           | 52   | ( -93 ) |           |
|             | S 1 | 18  | 15     | X 40 | <b>(</b> -65 | 20   | ( 70 )  | $\square$ |
| <b>Ξ</b> Τ2 | S   | 5   | 5      | X 50 | <b>X</b> 30  | 70   | -25     |           |
|             |     |     |        |      |              |      |         |           |

Fig.15: Waveform proposed method for implementation switching times.

#### G. Proposed SVPWM Pulses Generation Module

In following proposed PWM generation module is presented. Time duration of any PWM pulse is dependent number of sector and switching times T0, T1 and T2 in order to implementation of PWM generation use a counter. Range of counter is 1 to (T0/2 + T2 + T1 + T0/2 + T0/2 + T1 + T2 + T0/2 = 2\*T0 + 2\*T1 + 2\*T2) now proportional number of sector and counter amount PWM pulse is '0' or '1'.

For sector 1 and 2 range of counter is 1 to (2\*T0 + 2\*T1 + 2\*T2):

If  $(Sector=1) => \{$ If (counter =T0/2) => PWM\_A='1', PWM\_B='0', PWM C = '0';If (counter = T0/2+T1) => PWM A='1', PWM B='1',PWM C = '0': If (counter = T0/2 + T1 + T2) => PWM A = '1', PWM B = '1', PWM C = '1';If (counter = T0+T1+T2) => PWM A='1'. PWM B = '1', PWM C = '1';If (counter = T0 + T1 + T2 + T0/2) => PWM A = '1'. PWM B = '1', PWM C = '0';If (counter = T0+T1+2T2+T0/2) => PWM A='1', PWM B = '0', PWM C = '0';If (counter = T0+2T1+2T2+T0/2) => PWM A='0', PWM B = '0', PWM C = '0'; If (counter = 2T0 + 2T1 + 2T2) => PWM A = '0',PWM B = '0', PWM C = '0';

The proposed calculation for this block is implemented based on simple operators such as shifters, adders. Thus the proposed implementation reduces the complexity, power consumption and increase performance total of algorithm of conventional SVPWM implementation.

#### III. COMPARISON AND EXPERIMENTATION

In order to get actual numbers for the hardware usage, this work is synthesized and implemented by Quartus-II-9.1V software and cyclone-II FPGA to target device EP2C20F484C6, also power is analyzed using Xilinx XPower analyzer. SVPWM pulses are applied to a three phase VSI via an optical interface. A low power induction motor is used as output load of the inverter. Also a dc power supply is used to provide dc-link voltage. Fig.16 shows waveform of proposed PWM generation for sectors 5 and 6 Fig. 17 shows waveform of proposed PWM generation for sectors1 and 2.



Fig.16: Waveform of proposed PWM generation for sectors 5 and 6.



Fig.17: Waveform of proposed PWM generation for sectors 1 and 2.

Fig.18 shows waveform of proposed PWM generation for sectors 3 and 4.



Fig.18: Waveform of proposed PWM generation for sectors 3 and 4.

Fig. 19 shows total block diagram of proposed DSVPWM on FPGA. Pipelining techniques between blocks and also sub-pipelining techniques in any blocks can be used to increase the total performance design for future works.



Fig. 19: Total block diagram of proposed DSVPWM on FPGA.

Waveform of proposed DSVPWM on FPGA is shows in Fig. 20.



Fig.20: Waveform of proposed DSVPWM on FPGA.

The Fig.21 shows starter board cyclone II to target device EP2C20F484C6 and Fig.22 shows figures of actual hardware and experimentation for proposed method.



Fig. 21: Starter board cyclone II to target device EP2C20F484C6.



Fig. 22: Figures of actual hardware and experimentation for proposed method.

Table III shows the comparison between utilized hardware on FPGA and the type of device that has been used in proposed method, also Table IV shows Summary of data obtained from power consumption of our proposed method with Xpower and Tables V, VI, VII shows utilized hardware on FPGA and the type of device that has been used in [4][3][9].

TABLE III: UTILIZED HARDWARE ON FPGA IN PROPOSED METHOD

| Implementati<br>on | Total<br>logic<br>elements | Total<br>combination<br>al functions | Total<br>registers | Frequenc<br>y(Mhz) |
|--------------------|----------------------------|--------------------------------------|--------------------|--------------------|
| Proposed<br>method | 392(2%)                    | 388(2%)                              | 88(1%)             | 253.852            |

### TABLE IV: SUMMARY OF DATA OBTAINED FROM POWER CONSUMPTION OF PROPOSED METHOD WITH XPOWER

| Clock Frequncy(MHz) | Dynamic power<br>consumption(mW) |
|---------------------|----------------------------------|
| 100                 | 37                               |
| 75                  | 33                               |
| 50                  | 28                               |
| 25                  | 23                               |

#### TABLE V: UTILIZED HARDWARE ON FPGA IN [4]

| Implementati<br>on | Device                | Total of<br>logic<br>elements | Total<br>memory<br>bits | LC<br>Register<br>s |
|--------------------|-----------------------|-------------------------------|-------------------------|---------------------|
| [4]                | EP20k200E<br>FC484-2X | 520(6%)                       | 9216(9%)                | 31                  |

TABLE VI: UTILIZED HARDWARE ON FPGA IN [3]

| Implement<br>ation | Multipliers | Dividers | Adders/s<br>ubtractor<br>s | CLB<br>s | Utilizat<br>ion |
|--------------------|-------------|----------|----------------------------|----------|-----------------|
| [3]                | 0           | 0        | 32                         | 490      | 4%              |

TABLE VII: UTILIZED HARDWARE ON FPGA IN [9]

| Implementatio<br>n | Device      | Numbe<br>r of<br>CLBs | Numbe<br>r of<br>flip-<br>flops | Max<br>RAM<br>bits | Numb<br>er of<br>IOBs |
|--------------------|-------------|-----------------------|---------------------------------|--------------------|-----------------------|
| [9]                | Xc4003<br>A | 100                   | 360                             | 3200               | 80                    |

#### IV. CONCLUSION

In this paper a novel FPGA based digital space vector pulse width (DSVPWM) for three phase voltage source inverter has been designed using VHDL hardware description language. The advantages of this technique over the other literatures include flexibility, high accuracy and reduced area. Therefore a simple method has been presented to change complicate SVPWM equations to collection of shift, add and other similar uncomplicated orders to minimize run time of instructions. Proposed method has high performance, Stress Reduction, low power and high accuracy. To verify the proposed design a laboratory prototype has been arranged using of cyclone II FPGA board, an optical interface as IGBT drivers of voltage source inverter with an induction motor output load. Laboratory experiments and Xpower analyzer results demonstrate that, because of reduced hardware usage percentage, easy and fast instructions, proposed method has better performance and less power consumption than others works.

### REFERENCE

- Óscar López, Jacobo Álvarez, Jesús Doval-Gandoy, and Francisco D. Freijedo, "Multilevel Multiphase Space Vector PWM Algorithm", IEEE TRANSACTIONS ON INDUSTRIAL ELECTRONICS, VOL. 55, NO. 5, pp. 1933-1942, MAY 2008.
- [2] Sunil Panda, Anupam Mishra, B. Srinivas, "Control of Voltage Source Inverters using PWM/SVPWM for Adjustable Speed Drive Applications", the award of the degree of BACHELOR OF TECHNOLOGY in ELECTRICAL ENGINEERING, Department of Electrical Engineering National Institute Of Technology Rourkela, May 2009.
- [3] D. N. Sonawane, M. S. Sutaone, B. N. Choudhari and Abhijeet Badurkar, "FPGA Implementation of Simplified SVPWM Algorithm for Three Phase Voltage Source Inverter", International Journal of Computer and Electrical Engineering, Vol.2, No.6, pp. 1010-1017, December, 2010.
- [4] Tole Sutikno, Member, IEEE, Auzani Jidin, Member, IEEE and Mohd Farriz Basar, Member, IEEE, "Simple Realization of 5-Segment Discontinuous SVPWM Based on FPGA", International Journal of Computer and Electrical Engineering, Vol. 2, No. 1, pp. 147-157, February, 2010.
- [5] N. M. Nayan, "Design of a Microcontroller-Based Converter for 3-Phase Brushless DC Motor Drives", Thesis for Masters of Science, UNIVERSITI SAINS MALAYSIA, September 2009.
- [6] BAHARUDDIN BIN ISMAIL, "DESIGN AND DEVELOPMENT OF UNIPOLAR SPWM SWITCHING PULSES FOR SINGLE PHASE FULL BRIDGE INVERTER APPLICATION", Thesis submitted in fulfilment of the requirements for the degree of Master of Science, May 2008.
- [7] H.W. van der Broeck, H.-C. Skudelny, and G.V. Stanke, "Analysis and realization of a pulsewidth modulator based on voltage space vectors," *IEEE Transactions on Industry Applications*, vol.24, pp. 142-150, 1988.
- [8] Richard E. Haskell, Darrin M. Hanna, "Introduction to Digital Design Using Digilent FPGA Boards", Published by LBE Books, LLC, 2009.
- [9] Ying-Yu Tzou, Member, IEEE, and Hau-Jean Hsu, "FPGA Realization of Space-Vector PWM Control IC for Three-Phase PWM Inverters", IEEE TRANSACTIONS ON POWER ELECTRONICS, VOL. 12, NO. 6, pp. 953-963, NOVEMBER 1997.



**Bahram Rashidi**, was born in 1986 in Boroujerd-Lorestan, Iran. He received his B.SC. Degree in Electrical Engineering from the Lorestan University, Iran, in 2009 and he received his M.SC. in the Tabriz university, Iran in 2011 also he is now

Ph.D. student in Isfahan University of technology, respectively. His research interests include digital signal processing, DSP processors, computer vision, Hardware modeling with hardware description languages VHDL and VERILOG, He now continues on his interest in digital circuits design with research in embedded processor systems and VLSI digital chip design.



**Mehran Sabahi** was born in Tabriz, Iran, in 1968. He received the B.Sc. degree in Electronic Electrical Engineering from the University of Tabriz, the M.Sc. degree in electrical Engineering from Tehran University, Tehran, Iran, and the Ph.D. degree in electrical engineering from the

University of Tabriz, in 1991, 1994, and 2009, respectively. In 2009, he joined the Faculty of Electrical and Computer Engineering, University of Tabriz, where he has been an assistant professor since 2009. His current research interests include power electronic converters and renewable energy systems.