Design and Implementation of a CPLD-Based Multilevel Inverter Depending on a Complex Programmable Logic Device (CPLD)

Bashar S. Mohamad-Ali Taha A. Hussein Laith A. Mohammed
Lecturer Lecturer Assistant Lecturer
Technical College/Mosul

Abstract

A complex programmable logic device (CPLD) based multilevel inverter has been designed and implemented. The design involves three main parts. The first part is the switching angle generator (SAG), which determines the switching angles from an optimized primitive angle. The second part is the switching pulse generator (SPG), which controls the drive circuit of the inverter. The timing circuit is the third part, which provides the necessary timing for both SAG and SPG. Implementing both SAG and SPG using a CPLD device mean high speed cycle time. Hence an accurate timing for the switching angles is obtained compared to other procedures that uses software for calculating and generating the switching angles, such as microcontroller. MATLAB work space has been used to acquire and analyze the inverter output via the PC sound card. Results of the implemented inverter staircase output voltage, as well as the output frequency spectrum are obtained.

Keywords: Multilevel Inverter, Switching-Angles, Optimized Harmonics, CPLD

Introduction

Cascaded H-Bridge Inverter

The multilevel inverters have a unique structure allowing them to reach high voltages with low harmonics. The general function of multilevel inverter is to synthesize a desired voltage from several levels of dc voltages. The popular type structure of the multilevel inverter is the cascaded H-Bridge type. This type of inverter consists of full bridge or H-bridge inverters connected in series, and the output voltage is equal to the sum of the outputs of all H-bridge inverters.
inversors. Fig. (1) Shows a single phase configuration where \( V_{AN} \) represents the output phase voltage. The output of each H-bridge can be controlled by four switches. The output phase voltage levels are defined by \( m=2k+1 \), where \( k \) is number of levels and is the number of DC sources.

**Optimized Harmonics Stepped Waveform**

Using Fourier series expansion of the (stepped) output voltage waveform of the multilevel inverter shown in Fig. (2), the output voltage \( V(\omega t) \) can be written as follows \([3-8]\):

\[
V(\omega t) = \frac{4V_{DC}}{n\pi} \sum_{n=1,3,5,..} \left( \cos(n\alpha_1) + \cos(n\alpha_2) + \ldots \right) \sin n\omega t .................(1)
\]

Where \( V_{DC} \) is the DC level voltage

\( n \) is an odd harmonic order

The normalized magnitude of Fourier coefficients \( H(n) \) with respect to \( V_{DC} \) can be written as:

\[
H(n) = \frac{4V_{DC}}{n\pi} \sum_{l=1}^{k} \cos(n\alpha_l) .................(2)
\]

According to Fig. (2), the angles \( \alpha_1 \) to \( \alpha_k \) must satisfy the following condition \( \alpha_1 < \alpha_2 < \ldots < \pi/2 \). The goal is to eliminate the lower dominated harmonics, and filter the higher residual frequency. From Equation (2), the amplitude of odd harmonic components in a quarter-wave symmetry of a multilevel waveform is:

\[
H(n) = \frac{4V_{DC}}{n\pi} \left[ \cos(n\alpha_1) + \cos(n\alpha_2) + \cos(n\alpha_3) \right] .................(3)
\]

where \( n = 1, 3, 5, 7 \).

The set of non-linear equations corresponding to Eq.(3) can be given as follows:

\[
\frac{4V_{DC}}{\pi} \left[ \cos(3\alpha_1) + \cos(3\alpha_2) + \ldots \right] = H_3 \ldots (4)
\]

\[
\frac{4V_{DC}}{3\pi} \left[ \cos(5\alpha_1) \right] = H_5 \ldots (5)
\]

\[
\frac{4V_{DC}}{5\pi} \left[ \cos(5\alpha_1) + \cos(5\alpha_2) + \ldots \right] = H_5 \ldots (6)
\]

\[
\frac{4V_{DC}}{n\pi} \left[ \cos(n\alpha_1) + \cos(n\alpha_2) + \ldots \right] = H_n \ldots (7)
\]

where \( H_1 \) is the amplitude of fundamental component at \( n = 1 \), and \( H_n \) is the amplitude of the \( n \)th component. The set of nonlinear Equations (4-7) can be solved by iterative methods such as Newton-Raphson method or by using trigonometric identities to expand the terms \( \cos(n\alpha_n) \) and then using resultant theory \([6]\). The switching angles may also be solved to minimize total harmonic distortion. The THD for the voltage waveform may be written as \([7]\).

\[
THD(\%) = \frac{\sqrt{\sum_{n=2}^{\infty} (H(n))^2}}{H_1} .................(8)
\]

The modulation index \( M \) of the specified multilevel inverter is defined as follows \([3]\)

\[
M = \frac{V_L}{V_{L_{max}}} .................(9)
\]

Where \( V_L^* \) is the amplitude command of the inverter output voltage \( (H_1) \). \( V_{L_{max}} \) is the maximum attainable amplitude of the inverter. Five level inverter \( (m = 5) = 2k + 1 \) is constructed with two DC source \( (k = 2) \), therefore two H-bridges with two switching angle equations can be written to eliminate the harmonic component.

\[
\cos(\alpha_1) + \cos(\alpha_2) = \frac{kM\pi}{4} .................(10)
\]

\[
\cos(3\alpha_1) + \cos(3\alpha_2) = 0 .................(11)
\]
Solving above equations using Newton-Raphson method, values of $\alpha_1, \alpha_2$ and THD are obtained for different values of modulation index $M$ and are given in Table 1. In the waveform shown in Fig. (2), the first quarter cycle has a zero output voltage level from $\omega t = 0$ to $\omega t = \alpha_1$. At $\omega t = \alpha_1$, the output voltage level is changed from zero to $+V_1$, and from $+V_1$ to $+(V_1+V_2)$ at $\omega t = \alpha_2$. The process will be repeated until $\omega t = \pi/2$, and the output voltage level becomes $+V_1$, $+V_2$, ... $+V_{(k-1)}$, $+V_k$. Then in the second quarter, the level of the output voltage will be decreased to $+V_1$, $+V_2$, ... $+V_{(k-1)}$ at $\omega t = \pi - \alpha_k$. The process will be repeated until $\omega t = \pi - \alpha_1$ and output voltage becomes zero again. In the second half cycle of the waveform, the process will be repeated as in the previous steps except the changes in the dc sources amplitudes from positive to negative. The next period will then be repeated in the same sequence as in the first cycle. In this work, the first set of angles ($\alpha_1, \alpha_2$), which corresponds to the minimum THD in (Table 1), are chosen. To obtain a symmetrical output waveform, eight switching angles can be derived from the primitive switching angles ($\alpha_1, \alpha_2$) as shown in (Table 2).

**Inverter Implementation**

The inverter can be implemented in three methods. The first is the old traditional methods that uses either fixed function integrated circuits or microcontrollers [8]. The first method suffer from flexibility lack, while the second has limited performance due to low level programming. Recent advances in PLD devices has drawn much attention due to their shorter design cycle, high computation speed that can ensure the accuracy of the instants that gating signals [9]. In this work, CPLD (ATF1508AS of Atmel) is used to implement the inverter.

**CPLD Implementation of Control Circuit**

CPLD had made a revolution in implementing control circuits in the field of gating drives for inverters [10]. Fig. (3) Shows a block diagram of the inverter system. The control circuit is implemented on a Complex Programmable Logic Device (CPLD). The CPLD is driven by a clock CLK of 1 MHz, and a reset CLR signal to initialize the circuit. The CPLD is fed with the primitive optimized angles ($\alpha_1$ and $\alpha_2$), which are calculated off-line, and then the CPLD calculates the switching angles which are derived from the primitive angles, and generates the appropriate switching pulses. These switching pulses are fed to the 5-level inverter. The control circuit has been designed using the CAD software MAX+PLUS II (ver. 10.0) of Altera[11]. The schematic capture approach is chosen to implement the design (Fig.4).

The main function of the control circuit is to generate eight gate pulses for eight MOSFETs which act as switches ($S_{11}$, $S_{12}$, $S_{13}$, $S_{14}$, $S_{21}$, $S_{22}$, $S_{23}$, and $S_{24}$) for a 5-level inverter (Fig.1). The control circuit can be divided into three main sections; the timing circuit, the switching angles generator (SAG), and the switching pulses generator (SPG). The timing circuit includes two binary counters. The first is a 16-bit up counter, which is driven by an external 1 MHz clock (CLK) to provide an accuracy of 1 $\mu$S in determining the time positions of the switching angles. Since a 50 Hz sine wave has a time period of 20 mS, the switching angle could be any number between (0-20000 $\mu$S). Hence the 16-bit counter should count from (0 to 20000) repeatedly. The second counter is a 4-bit binary counter. This counter is driven by a clock from the output (A=B) of a 16-bit comparator. This counter provides the timing for the eight switching angles.
Notice that only the least three significant bits are used from the outputs of this counter, since only 8-states are required corresponding to 8 switching angles. The comparator compares between the output of the 16-bit counter and the next angle which is calculated by SAG circuit, and it produces a pulse when the counter output reaches the switching angle. Hence the comparator produces 8 pulses during one cycle of a 50 Hz sine wave. These pulses drive the clock of the 4-bit counter. An external clear (CLR) signal is provided for the timing circuit to initiate all flip-flops, and counters. The SAG circuit includes four multiplexers and an adder/subtractor. Both are controlled by the outputs of the 4-bit counter. The main function of the SAG circuit is to calculate the next angle in time domain from the optimized primitive angles (in case of 5-level inverter, two angles $\alpha_1$, and $\alpha_2$ according to Table 2). The four multiplexers select two parameters to be either added or subtracted by the adder/subtractor. Therefore, the eight angles are calculated sequentially and sent to the comparator input in the timing circuit. The SPG circuit consists of a 2 to 4 decoder, four j-k flip-flops, and four d-type flip-flops. Since in each switching mode there is a switch which is switched ON, while another is switched OFF (Table 3), the control signals of the eight switches (of a 5-level inverter) can be reduced to only four signals. The other four signals can be derived by complementing the first four signals. The four j-k flip-flops outputs provide the first four signals, while the four d-type flip-flops provide the other four signals after complementing the first four signals. The presence of the d-type flip-flops which are triggered by the positive edge of the main CLK is to provide a delay of less than 1µS to prevent a short circuit on the supply batteries during switching. Revising (Table 3), enable to conclude that there is only four switching sequences in the first half of the cycle. The same switching sequence is being repeated in the next half cycle. Hence a 2 to 4 decoder whose inputs are taken from least two significant bits (D0, D1) of the 4-bit counter, can be used to clock the j-k flips-flops (Fig. 4). Having built the control circuit in MAX+PLUS II software, the circuit is simulated and the simulation results are shown in Figure(5). Then the circuit data file is downloaded into the CPLD to get the actual pulses which drive the MOSFETs main power switches.

**Results**

**Simulated Results**

Simulated results for $m=1$, the switching angles $\alpha_1=5.08^\circ$ and $\alpha_2=54.9^\circ$ (from Table 1), shows that the THD has minimum value and an RMS output voltage = 220V (for equal H bridge input when DC voltage = 120V) as shown in Figure (6), compared with $m=0.8$, switching angles $\alpha_1=13.48^\circ$ and $\alpha_2=73.48^\circ$ an RMS output voltage = 170V as shown in Figure (7).

**Practical Results**

Figure (8) shows the obtained output voltage waveform for the implemented 5-level inverter for $m=1$. The frequency spectrum for the 50Hz output is shown in Figure (9). The fundamental component has the highest magnitude, while the harmonic components have a decreasing magnitudes. The CPLD input parameters are set to give an output frequency of 50Hz. Any other desired frequency can be attained by simply adjusting the input frequency of the CPLD without any changes in the schematics of the inverter.
Conclusions and Suggestions

1. Implementing both (SAG) and (SPG) using CPLD meant high flexibility to change both ($\alpha_1$ and $\alpha_2$) and the input clock frequency. Hence the inverter output RMS voltage and its frequency can be changed easily.

2. Inverter applications such as speed control of AC motors can be easily carried out using the proposed inverter. This is of a great benefit compared with other implementations of the inverter based on micro-controllers or fixed function integrated circuits.

It is suggested to introduce the calculation of the primitive angles to be held in system by adding a unit of digital signal processor (DSP) before the CPLD unit, thereby getting a fully automotive inverter.

References


Figure (1) single phase configuration for m-level inverter in cascaded form

Figure (2) Output voltage waveform of m-level inverter

Figure (3) Block diagram of the proposed inverter system

Figure (4) CPLD schematic of the implemented inverter using MAX+PLUS II

Figure (5) Simulated gate pulses using MAX+PLUS II software

Figure (6) Simulated inverter output for \( m=1, \alpha_1=5.08^\circ \) and \( \alpha_2=54.9^\circ \)
Figure (7) Simulated inverter output for $m=0.8$, $\alpha_1=13.48^\circ$ and $\alpha_2=73.48^\circ$.

Figure (8) Practical inverter output waveform $m=1$, $\alpha_1=5.08^\circ$ and $\alpha_2=54.9^\circ$.

Figure (9) Frequency spectrum of the inverter output.
Table (1) The output voltage THD corresponding to the switching angles for 5-level inverter

<table>
<thead>
<tr>
<th>Modulation Index M</th>
<th>$a_1$, (Degree)</th>
<th>$a_2$, (Degree)</th>
<th>THD, (%)</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.0</td>
<td>5.08</td>
<td>54.91</td>
<td>25.16</td>
</tr>
<tr>
<td>0.95</td>
<td>0.50</td>
<td>60.50</td>
<td>30.66</td>
</tr>
<tr>
<td>0.9</td>
<td>5.29</td>
<td>65.29</td>
<td>29.54</td>
</tr>
<tr>
<td>0.85</td>
<td>9.56</td>
<td>69.29</td>
<td>29.58</td>
</tr>
<tr>
<td>0.8</td>
<td>13.48</td>
<td>73.48</td>
<td>30.27</td>
</tr>
<tr>
<td>0.75</td>
<td>17.14</td>
<td>77.14</td>
<td>31.25</td>
</tr>
<tr>
<td>0.7</td>
<td>20.59</td>
<td>80.59</td>
<td>32.19</td>
</tr>
<tr>
<td>0.65</td>
<td>23.87</td>
<td>83.87</td>
<td>32.70</td>
</tr>
<tr>
<td>0.6</td>
<td>27.03</td>
<td>87.03</td>
<td>32.37</td>
</tr>
</tbody>
</table>

Table (2) The switching angles and the equivalent time periods

<table>
<thead>
<tr>
<th>The angle in degrees</th>
<th>Equivalent time period in μS</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>$a_1 = 5.08$ 282</td>
</tr>
<tr>
<td>2</td>
<td>$a_2 = 54.91$ 3051</td>
</tr>
<tr>
<td>3</td>
<td>$\pi - \alpha_2 = 125.09$ 6949</td>
</tr>
<tr>
<td>4</td>
<td>$\pi - \alpha_1 = 174.92$ 9718</td>
</tr>
<tr>
<td>5</td>
<td>$\pi + \alpha_1 = 185.08$ 10282</td>
</tr>
<tr>
<td>6</td>
<td>$\pi + \alpha_2 = 234.91$ 13051</td>
</tr>
<tr>
<td>7</td>
<td>$2\pi - \alpha_2 = 305.09$ 16949</td>
</tr>
<tr>
<td>8</td>
<td>$2\pi - \alpha_1 = 354.92$ 19718</td>
</tr>
</tbody>
</table>

Table (3) Power switches states for 5-level inverter

<table>
<thead>
<tr>
<th>Switching angle interval</th>
<th>$S_{11}$</th>
<th>$S_{12}$</th>
<th>$S_{13}$</th>
<th>$S_{14}$</th>
<th>$S_{21}$</th>
<th>$S_{22}$</th>
<th>$S_{23}$</th>
<th>$S_{24}$</th>
<th>Vout</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 to $\alpha_1$</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>$\alpha_1$ to $\alpha_2$</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>+Vdc</td>
</tr>
<tr>
<td>$\alpha_2$ to $(\pi - \alpha_2)$</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>+2Vdc</td>
</tr>
<tr>
<td>$(\pi - \alpha_2)$ to $(\pi - \alpha_1)$</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>+Vdc</td>
</tr>
<tr>
<td>$(\pi - \alpha_1)$ to $(\pi + \alpha_1)$</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>$(\pi + \alpha_1)$ to $(\pi + \alpha_2)$</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>-Vdc</td>
</tr>
<tr>
<td>$(\pi + \alpha_2)$ to $(2\pi - \alpha_2)$</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>-2Vdc</td>
</tr>
<tr>
<td>$(2\pi - \alpha_2)$ to $(2\pi - \alpha_1)$</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>-Vdc</td>
</tr>
<tr>
<td>$(2\pi - \alpha_1)$ to $2\pi$</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>