
Abstract-The Space Vector Pulse Width Modulation (SVPWM) is possibly the best among all the PWM techniques for variable frequency drive applications. Unfortunately, the modulation algorithm is mainly implemented with software based on microcontroller or digital signal processors (DSP). These are software-based technique purely and obviously not an ideal solution. Employing Field Programmable Gate Array (FPGA) to realize SVPWM strategies provides advantages that it is considered as an appropriate solution to boost system performance of an SVPWM algorithm. Moreover, although in the literatures the implementation for three-phase SVPWM based on FPGA is not lacking, however all these designs are based on the conventional SVPWM without considering hardware-resource saving and not simple. This paper present a simple realization of 5-segment discontinuous SVPWM with a difference approach based on FPGA, in which the judging of sectors and the calculation of the firing time to generate the SVPWM waveform is simple, and also the switching losses is low. The proposed discontinuous SVPWM has been designed and successfully implemented by using APEX20KE Altera FPGA considering hardware-resource saving and has successfully driven a three phase inverter system with induction machine 1.5 kW as load.
Index Terms-space vector, pulse width modulation, discontinuous SVPWM, FPGA, simple realization
I. INTRODUCTION
The Space Vector Pulse Width Modulation (SVPWM) method is an advanced PWM method and it is possibly the best among all the PWM techniques for variable frequency drive applications. In recent years, this method gradually obtains widespread applications in the power electronics and the electrical drives, because of its superior performance characteristics. Compared to the Sinusoidal Pulse Width Modulation (SPWM), SVPWM is more suitable for digital implementation and can increase the obtainable DC voltage utilization ratio very much. Moreover, it can obtain a better voltage total harmonic distortion factor [1] [2] [3] [4] . Up to now, its theories and algorithms have been well developed and applied more widely with the progress of power electronics. In most engineering practice, the SVPWM algorithm is mainly implemented with software based on microcontroller or digital signal processors (DSP) are widely adopted. They perform control procedure sequentially by exploiting their mathematically oriented resources. That is the instructions of different procedures are executed one after the other. Thus, the purely software-based technique is not an ideal solution. Employing Field Programmable Gate Array (FPGA) to realize SVPWM strategies provides advantages such as rapid prototyping, simpler hardware and software design, and higher switching frequency. Differ from software implementation; FPGA performs the entire procedures with concurrent operation (parallel processing by means of hardware mode and not occupying) by using its reconfigurable hardware. For its powerful computation ability and flexibility, an FPGA is considered as an appropriate solution to boost system performance of a digital controller including an SVPWM algorithm [2, [5] [6] [7] [8] .
However, this conventional SVPWM suffers from the drawbacks like computational burden, inferior performance at high modulation indices and high switching losses of the inverter. Hence to reduce the switching losses and to improve the performance in high modulation region, several discontinuous SVPWM methods have been proposed [9] [10] [11] .
Although in the literatures the implementation for three-phase conventional SVPWM and discontinuous SVPWM based on FPGA is not lacking, however all these designs are based on the conventional SVPWM without considering hardware-resource saving. In this paper, we design and implement a FPGA based SVPWM with a difference approach, in which the judging of sectors and the calculation of the firing time to generate the SVPWM waveform is simple, and also the switching losses is low. In this paper, a novel 5-segment discontinuous SVPWM design based on the basic idea from [4] and [12] is proposed. This scheme is hoped that it has lower switching losses, simpler algorithm and can be implemented easily based on APEX20KE Altera FPGA.
II. THE PRINCIPLES OF CONVENTIONAL SVPWM
The main aim of any modulation technique is to obtain variable output having a maximum fundamental component with minimum harmonics and less switching losses. The SVPWM technique is more popular than conventional technique. This technique was originally developed as a vector approach to pulse width modulation (PWM) for three phase inverter [1] . It is a more sophisticated technique for generating sinusoidal wave that provides a higher voltage to Table I . ) can be used to frame the vector plane, which is illustrated in Figure1. The rotating reference vector can be approximated in each switching cycle by switching between the two adjacent active vectors and the zero vectors. In order to maintain the effective switching frequency at a minimal value, the sequence of the toggling between these vectors is organized in such way that only one leg is affected in every step.
A. Identification of the sector
The sector judgment and application time of active vector for all SVM strategies are the same. Based on Figure 1 (a), it is obvious that the sector number is determined by the angle of the reference vector. The identification of k can be generally in αβ coordinates deal with by the appropriate boundary condition according to Table II .
B. Determination of the duration of active vectors
For digital control application, the reference inputs are sampled in a regular sampling interval to determine the switching duration of the active vectors. That it, any reference vector inside the hexagon can be obtained two adjacent active vector (V 
Where T 
Where V dc is the dc-link voltage of the inverter, and T 0 is the switching duration of a zero vector in each sampling period. Suppose the reference is keeping a circular trajectory, the T 0 >0, the output voltage is a regular sinusoidal in linear modulation. As (3), it is theoretically simple but it is obvious that this algorithm required complicated computations with trigonometric function.
C. Switching sequence (switching pattern)
This SVPWM strategy aims to minimize harmonic distortion in the current by selecting the appropriate switching vectors and determining of their corresponding dwelling widths. The flux produced by the reference voltage vector in a SVPWM switching period is a combination of each individual flux resulted by corresponding voltage vector. There are many switching pattern to implementation SVPWM. The choice of the null vector determines the SVPWM scheme. There are a few options: the null vector V 0 only, the null vector V 7 only, or a combination of the null vectors. 
A. Proposed SVPWM switching Pattern (5-segment discontinuous switching sequence)
There has been reported many discontinuous SVPWM pattern [5, [9] [10] [11] 13] . However, not all those patterns have lower switching losses, simpler algorithm and can be implemented based on FPGA easily. In this paper, a novel symmetric 5-segment discontinuous SVPWM design refer to the basic idea from [4] and [12] is proposed. This pattern has been successfully implemented based on DSP by Yu [12] . It is known has lower switching losses, simpler algorithm and can be implemented easily. Therefore, this paper proposes to implement this pattern based on FPGA in order to boost system performance of SVPWM. In this pattern, there is always a channel staying constant for the entire PWM period. The state sequence in this pattern is X-Y-Z-Y-X, where Z=1 in sector I, III and V, and Z=0 in the remaining sector. So the number of switching time for this pattern is less than the conventional pattern. The obvious result of this is reduced 151 switching losses.
B. Proposed identification of the sector
There are many kinds of methods to judge the sector that the reference space voltage vector lies in. Zhi-pu [14] 
Then, based on equation (), they calculate N=sign(Va) + 2*sign(Vb) + 4*sign(Vc). Map N to the actual sector of the output voltage reference by referring to Table III.   TABLE III: MAP N TO THE ACTUAL SECTOR OF THE OUTPUT  VOLTAGE REFERENCE   N  1  2  3  4  5  6 sector 2 6 1 4 3 5 Fig.6 The plotting of  as decompose the conventional SVPWM, which will properly counteract the redundant calculations to identify sector location, but it imported the complicated matrix calculations. In this paper, based on analyzing the principle of SVPWM in [7, [15] [16] [17] Table  IV .
C. Determination of the duration of active vectors
The space vector technique allows to synthesizing a desired vector V 
In this design, the switching time of the active vectors for each sector can be calculated as shown in Table V .
D. Proposed SVPWM switching sequence generating method based on calculation of the duration of active vectors
In this paper, with refer to equation Moreover, the PWM generating in other sectors can be obtained in the similar way.
IV. FPGA IMPLEMENTATION OF A PROPOSED NOVEL SVPWM
In previous section, the principle of SVPWM is analyzed. In this section FPGA implementation of a proposed novel SVPWM will be presented. Overall of the proposed SVPWM design is shown in Figure 8 . This top module can be sub divided into 5 sub modules, namely ajust_freq, Vbeta_Valfa, find_sector, SVM_generator and deadtime_sytem module.
A. Adjust of Carrier and Fundamental Frequency Module
In this module, the main clock frequency is designed to connect L6 pin at APEX20KE Altera FPGA board system. It is 33.33 MHz dedicated clock generator in this board. The clocking system to adjust carrier and fundamental frequency is done in this module. In this research, carrier frequency is set to 20 kHz and in temporary, fundamental frequency is set fixed to 50 Hz. It to get carrier and fundamental frequency is done through clock dividing. For example, because of the triangle signal generator design in this research is sampled 32 times per period, then it to get 20 kHz is done through dividing of the main clock generator above with 13 (33.33MHz:(13x32)=20 kHz). The fundamental frequency also can be gotten through similar dividing.
B. V α and V β Module
In this research, V α and V β is generated using sine and cosine function through look up table (LUT) with memory mapping 360 addresses. The lower, base, and higher number of sine and cosine function is represented with 96, 224 and 352 respectively in 9 unsigned bits. The design of V α and V β module is shown in Figure 9 . Because in this design it uses memory mapping 360 addresses, then the counter mod-360 is used to count LUT of V α and V β .
153 
C. Sector Finder Module
Due to existing different switching time equations, the reference voltage sector knowledge is necessary. The SF module is responsible judging the reference vector sector and does it using Table 2 above. As Figure 10 , the "x_pos_akar" and "x_neg_akar" module are used to multiply between Table VI through "csector" module. 
D. Three phase SVPWM signal generator module
The overall of three phase SVPWM signal generator module is shown in Figure 11 . This module can be sub divided into 4 sub modules, namely Triangle, Duration_Ta, Duration_TaTb, and SVM pattern module. Triangle module is functioned as triangle signal generator. In this research, one period of triangle signal generator is sampled 32 times, and then it is represented in the digital number 9 unsigned bit, with lower (in this case is same with base number) and higher number each are 224 and 352 respectively. Due to Duration_Ta and Duration_TaTb module, these modules are digital solution of each second and fourth column respectively. And SVM pattern module as the last module is functioned as SVPWM switching sequence generating as it is described in section 3.4 and it is illustrated in Figure 7 . 
A. Simulation
This mode is based on the Quartus II, the parameters are listed as follows: V dc /T=1, switching frequency has been tried at 2.5 and 20 kHz, and fundamental frequency 50 Hz. The compilation report of proposed SVPWM generator design is shown in Figure 12 (a), and it more detail for each module in Figure 12 (b). It can be seen that the design requires 520 logic elements and 9.216 memory bits. Figure 13 show simulation results of the proposed SVPWM generator. These results verify by simulation that the proposed design runs with the desired.
B. Experimental
In previous section it has been shown that the proposed SVPWM generator has worked properly in simulation mode. Therefore, the design can be continued to hardware implementation based on FPGA (programmer level). In this research, the proposed SVPWM generator design with some carrier frequency has programmed to APEX20KE Altera FPGA successfully.
The sequence of switching state in each sector and the dead time with 2 µs that they also has been done successfully as shown in Figure 14 and 15 respectively. Inherently, Figure  16 shows hardware implementation of proposed SVPWM generator at carrier frequency 20 kHz. The first, second and third channel at Figure 16 (a) and (b) is each S a , S b , and S c switching state respectively, otherwise fourth channel is each (S a -S b ) line-to-line switching state and its frequency spectrum respectively. The harmonics due to the 20 kHz switching frequency are clearly visible in Figure 16 (b). The results above have proved that the proposed SVPWM generator has realized in hardware platform based on FPGA and has run with desired. Inherently, Figure 16 shows hardware implementation of proposed SVPWM generator at carrier frequency 20 kHz. The first, second and third channel at Figure 16 (a) and (b) is each S a , S b , and S c switching state respectively, otherwise fourth channel is each (S a +S b ) line-to-line switching state and its frequency spectrum respectively. The harmonics due to the 20 kHz switching frequency are clearly visible in Figure 16 (b). The similar condition is shown in Figure 17 . In this case, carrier frequency is set to 40 kHz; although the testing result as Figure 17 (b) showed that it is detected 38.5 kHz (error 3.75%). These results above have proved that the proposed SVPWM generator has realized in hardware platform based on FPGA and has run with desired. To test the performance of FPGA based proposed SVPWM generator design, this design has been used to drive a three phase inverter system with induction machine 1.5 kW as load. Figure 18 shows the practical result for output stator current (I a ), output phase-to-phase voltage (V ab ), frequency spectrum and output voltage line-to-neutral (V an ). This figure shows that the practical result obtained from test-rig is in good agreement.
(a) the switching state and its line-to-line (b) The signal gating and its frequency spectrum The results above have proved that the proposed SVPWM generator has realized in hardware platform based on FPGA and has run with desired.
VI. CONCLUSION
This paper presents the design and simple realization of FPGA based a novel 5-segment discontinuous SVPWM with a difference approach, in which the judging of sectors and the calculation of the firing time to generate the SVPWM waveform is simple, and also the switching losses is low. The proposed SVPWM scheme has been designed and successfully implemented by using APEX20KE Altera FPGA considering hardware-resource saving. It is simple and without compute the angles of each sector to determine number of sector and the commutation pattern and that it has programmed to FPGA successfully in some carrier frequency until 40 kHz. Moreover, this scheme has simple algorithm that it can be implemented easily based on FPGA without computational burden and has successfully driven a three phase inverter system with induction machine 1.5 kW as load. 
