Microsoft Word - vol 6-2p3V2-press.doc IIUM Engineering Journal, Vol. 6, No. 2, 2005 K. Rahman AND S. J. M. Idrus 27 AN AT89C52 MICROCONTROLLER BASED HIGH RESOLUTION PWM CONTROLLER FOR 3-PHASE VOLTAGE SOURCE INVERTERS K. M. RAHMAN AND S. J. M. IDRUS Department of Mechatronics Engineering Faculty of Engineering, International Islamic University Malaysia, P.O. Box 10, 50728, Malaysia kazi@iiu.edu.my, junita@iiu.edu.my Abstract: A novel technique for generating real time high resolution pulse width modulated patterns for a three phase voltage source inverter is presented in this paper. An AT89C52 microcontroller computes the PWM pulse widths on carrier cycle basis based on the input frequency. The microcontroller send the pulse width information for the three phases to a memory minimized ROM lookup table, which is scanned by a binary counter to generate the real time PWM patterns. The on board timer of AT89C52 is utilized to generate programmed clock for the scanning binary counter. The overall design is hardware minimized and compact that makes it feasible for low cost high performance ac drive applications. The proposed PWM controller supports variable frequency variable voltage operation for wide range and hence is ideally suited for industrial drives requiring wide speed variations. Keywords: Pulse width modulation, Microcontroller application, Voltage source inverter, variable speed ac drives. 1. INTRODUCTION Three phase voltage source inverters are controlled by pulse width modulation (PWM) techniques. The prime goal of a PWM technique is to minimize the harmonics in the phase voltage and phase current spectrum. Different PWM strategies are available in the literature for controlling three phase inverters using per phase modulation such as regular sampled PWM (RSPWM) or voltage space vector (SVPWM) technique. Both RSPWM [1-4] and SVPWM [5-6] have well defined switching equations for computing PWM pulse widths and are usually implemented using timers and a microprocessor. The SVPWM needs more computations than the RSPWM, however, SVPWM have linear over modulation capability. Harmonic elimination PWM (HEPWM) is another technique that computes switching points strategically eliminating some selective harmonics and is the most computation intensive PWM technique that cannot be implemented directly in real time. Switching patterns close to HEPWM are obtainable using regular sampled harmonic elimination PWM (RSHEPWM), where, the leading edge of a PWM switching pulse for any phase is calculated from the sine modulating reference and the trailing edge is computed from a shifted sine reference [7-8]. Considering harmonic behaviour, the RSPWM is the most efficient PWM technique for feed forward inverter control IIUM Engineering Journal, Vol. 6, No. 2, 2005 K. Rahman AND S. J. M. Idrus 28 applications. The RSPWM is one of the mostly used PWM techniques and have a number of derivatives. The symmetric time averaged RSPWM [9] is very efficient in respect of both performance and speed. The performance of a PWM scheme depends on how the PWM control patterns are calculated and also on the implementation strategy. Even the most efficient PWM technique may offer worst performance if the resolution of the PWM pattern is not maintained properly. This happens because of the limitations of the digital hardware through which the PWM strategy is implemented in real time. 2. PULSE WIDTH CALCULATIONS The PWM pulse widths are to be calculated such that the inverter output has the lowest order harmonic near the carrier switching frequency. Amongst the various PWM strategies, the regular sampled PWM is found to give better output at lesser computation complexity. 2.1 Regular Sampled PWM The modulating signal is a sinusoid at the inverter fundamental frequency (f). The modulating signal is sampled at regular intervals at the carrier frequency (fs). The number of samples in a fundamental period is Nmax given by, f fN smax (1) The three phase modulating signals are, )3/4sin( )3/2sin( )sin(       tVv tVv tVv mc mb ma (2) Fig. 1: Pulse width calculations for two-level PWM, the area under the modulating signal for nth carrier period is equated to be same as the area of the two-level PWM pulse. For the nth PWM pulse, the area of the two-level PWM pulse should be equal to the shaded area under the modulating signal as illustrated in Fig. 1, +Vs/2 0 -Vs/2 nTs twa(n) Ts va = Vm sin(t) IIUM Engineering Journal, Vol. 6, No. 2, 2005 K. Rahman AND S. J. M. Idrus 29   ssmwasswas TTnVntT V nt V  )sin()( 2 )( 2  (3) Solving (3), the PWM pulse width is given by,        )sin( 2 1 2 )( s s ms wa TnV VT nt  (4)  )sin(1 2 )( s s wa TnM T nt  (5) where, M is the index of modulation, M = 2Vm/Vs. Equation (5) gives the PWM pulse width for phase A. For phases B and C, the PWM pulse widths are,  )3/2sin(1 2 )(   s s wb TnM T nt (6)  )3/4sin(1 2 )(   s s wc TnM T nt (7) Adding (5), (6) and (7) results, 2 3 )()()( swcwbwa T ntntnt  (8) From (8), the PWM pulse width for phase C can be obtained as,  )()( 2 3 )( ntnt T nt wbwa s wc  (9) 2.2 PWM Pulse Width in Sampled Domain For generating real time PWM waveforms for the three phase inverter using a digital hardware, the PWM pulse widths are transformed into sampled domain. Considering Kmax samples in a carrier period Ts, the sampling time Ts is given by, maxK TT ss  (10) If Ka(n), Kb(n), and Kc(n) are the numbers of ‘HIGH’ samples for the phases A, B, and C respectively in sampled domain, their magnitudes are given by, )sin( 22 )( )( maxmax s s wa a TnM KK T nt nK    (11) )3/2sin( 22 )( )( maxmax     s s wb b TnM KK T nt nK (12)  )()( 2 3)( )( max nKnK K T nt nK ba s wc c   (13) 3. IMPLEMENTATION SCHEME The PWM implementation scheme is shown in Fig. 2. The core processor is an AT89C52 microcontroller, where, the desired frequency/speed is set by an analogue potentiometer. An 8-bit ADC (ADC0804) converts the frequency/speed setting into digital binary code that is given as input to port 2 of AT89C52. IIUM Engineering Journal, Vol. 6, No. 2, 2005 K. Rahman AND S. J. M. Idrus 30 Fig. 2. An AT89C52 microcontroller based scheme for three-phase PWM pattern generation using three ROM lookup tables and a scan counter. The microcontroller calculates the scan clock frequency and sets the corresponding RCAP2L and RCAP2H values for the onboard Timer 2. The Timer 2 of AT89C52 is configured in clock generator mode that gives the programmed clock output at P1.1. The scan counter is clocked from P1.1 and the ripple carry out from the scan counter is made to interrupt the microcontroller after every 256 counts that correspond to the total number samples in a carrier period. The PWM waveform pattern samples are sent to ROM lookup tables through port P0. The PWM patterns for three phases are sent through the same port P0 using multiplexing and latch principle. For each phase there is a set of latch and ROM lookup table, so that they can generate the PWM patterns independently. 3.1 Frequency Setting The fundamental frequency of the PWM output patterns are dependent on the microcontroller clock frequency (fCPU), counter clock frequency (fCLK) and the number of carrier pulses per fundamental cycle (Nmax). Since the counter clock (fCLK) is derived from the microcontroller clock frequency (fCPU) by a divide by counter (Timer 2 of the microcontroller), the output frequency (f) is given by 256 1 max CLKf N f  (14) AT89C52 8-bit binary counterClock Latch 1 Latch 3 Latch 2 8 Select 1 P1.0 P0 Select 2 Select 3 Interrupt g 1 g4 g 3 g 6 g 5 g 2 Scan Pulse width Pulse width Scan Pulse width Scan Ripple carry output P1.2 P1.3 P1.4 P1.5 8 8-bit ADC +5V Pot Frequency P2 ROM enable P1.6 +5V Start/Stop P1.7 R IIUM Engineering Journal, Vol. 6, No. 2, 2005 K. Rahman AND S. J. M. Idrus 31 DIVN65536 1 4   CPUCLK f f (15) Combining (1) and (2), the DIVN value is given by max1024 65536DIVN fN f CPU (16)        256 DIVN RCAP2H floor (17) RCAP2H-DIVN RCAP2L  (18) 3.2 Integer Arithmetic Models for PWM Patterns The microcontroller does not have floating point computation support. Hence, it can not compute sine functions directly. Rather, it has to be calculated using tailor series expansion method that require huge computation time. To reduce the computation complexity, (11) and (12) are simplified having only integer manipulations. )( 2 2 )( 22/2 )( 2 )sin( 22 )( max max max max maxmaxmaxmax nS K MK nS K K MK nMS K Tn K M K nK a tag aasa          (19) where, )sin( 2 )( max sa Tn K nS  and 2 maxKMM tag  . For phase B, )( 2 2 )( max max nS K MK nK b tag b  (20) where, )3/2sin( 2 )( max   sb Tn K nS and 2 maxKMM tag  . The values of Sa(n) and Sb(n) are computed off line, rounded to integer numbers and stored in lookup table inside the program code of the AT89C52. The Mtag value is chosen from the ADC output that is always an integer. Hence, the computations of Ka(n), Kb(n) using (19) and (20) involves only integer arithmetic that can be done efficiently with AT89C52 in real time. 3.3 Real Time PWM Pattern Generation PWM patterns having 256 different duties are stored in the PWM ROMs as a lookup table. The microcontroller computes the PWM patterns on carrier cycle basis and the real time PWM patterns are generated in the ROM data bus using the following algorithm: Algorithm for PWM Pattern Generation Step 1. Set P1.5 = 1 to disable the PWM ROMs. Step 2. Initialize n = 1. Step 3. Read P2 and set ftag = P2. Step 4. Choose Nmax and fclock, set RCAP2L and RCAP2H. Step 5. Compute Ka(n), Kb(n) and Kc(n). Step 6. Set P0 = Ka(n) and P1.2 = 0 (Ka(n) data to Latch 1). IIUM Engineering Journal, Vol. 6, No. 2, 2005 K. Rahman AND S. J. M. Idrus 32 Step 7. Set P0 = Kb(n) and P1.3 = 0 (Kb(n) data to Latch 2). Step 8. Set P0 = Kc(n) and P1.4 = 0 (Kc(n) data to Latch 3). Step 9. Wait for interrupt at P1.6 and goto step 10 if interrupt occurs, otherwise loop to Step 10. Enable the data ROMs by setting P1.5 = 0. Step 11. Read the shut down status at P1.7. Step 12. If P1.7 = 0, disable the data ROMs (set P1.5 = 1) and goto step 16, else goto step . Step 13. Increment n, n = n+1. Step 14. If n>Nmax, set n = 1. Step 15. Goto step 3. Step 16. Halt operation. 3.4 Performance simulation The performances of the proposed PWM scheme are studied through simulation with a three phase voltage source inverter. The inverter is shown in Fig. 3 and drives a star connected inductive load with insulated neutral. The switching functions for phases A, B and C are Sa, Sb and Sc respectively. The switching function and associated transistor status are shown in Table 1. Each switching function has two level statuses; either +1 or - 1, where, +1 drives the top transistor and -1 drives the bottom transistor of a leg of the inverter. Fig. 3: Three phase voltage source inverter connected to star connected R-L load with insulated neutral (Sa, Sb and Sc are two level switching functions having magnitudes +1 and -1, for driving the associate top and bottom transistors in a leg). The PWM switching patterns for three phases and inverter output phase voltages are shown in Fig. 4 for supply voltage Vs = 600V (1 pu), modulation index M = 1 at f = 50 Hz, and carrier frequency fs = 1.2 kHz. The corresponding Fourier frequency spectrum of the PWM switching function (Sa) and line to neutral (phase) voltage van are shown in Fig. 5. The noticeable point is that although the fundamental frequency amplitude in Sa is 1 pu (equal to M), the fundamental phase voltage output is 0.5 pu, that confirms the analysis described earlier. The inverter output currents (three phases) and Fourier frequency spectrum are shown in Fig. 6 for an R-L load of 10 ohms at 0.8 pf lagging. Due to low vcn vbn van n A C B Q5 Q2 Q3 Q6 Q1 Q4 ic ib ia + - Vs R L R L R L Sa Sb Sc IIUM Engineering Journal, Vol. 6, No. 2, 2005 K. Rahman AND S. J. M. Idrus 33 pass action in the output current, the harmonics die out in the current spectrum (Fig. 6) although they are noticeable in the phase voltage spectrum (Fig. 5). Table 1: Switching functions and transistor operating status for the three phase voltage source inverter. Switching function Switching status Transistor status Sa (Leg a) +1 Q1 = ON Q4 = OFF -1 Q1 = OFF Q4 = ON Sb (Leg b) +1 Q3 = ON Q6 = OFF -1 Q3 = OFF Q6 = ON Sc (Leg c) +1 Q5 = ON Q2 = OFF -1 Q5 = OFF Q2 = ON 0 0.005 0.01 0.015 0.02 -1 0 1 Time (s) S a (p u) 0 0.005 0.01 0.015 0.02 -1 0 1 Time (s) S b (p u) 0 0.005 0.01 0.015 0.02 -1 0 1 Time (s) S c (p u) 0 0.005 0.01 0.015 0.02 -1 0 1 Time (s) v a (p u) 0 0.005 0.01 0.015 0.02 -1 0 1 Time (s) v b (p u) 0 0.005 0.01 0.015 0.02 -1 0 1 Time (s) v c ( pu ) Fig. 4: PWM switching patterns at f = 50 Hz, fs = 1.2 kHz, M = 1 for the three phase legs of the inverter and the phase voltages for star connected load with insulated neutral. IIUM Engineering Journal, Vol. 6, No. 2, 2005 K. Rahman AND S. J. M. Idrus 34 0 10 20 30 40 50 60 70 80 90 100 0 0.2 0.4 0.6 0.8 1 (a) Frequency (xf) S a (p u) 0 10 20 30 40 50 60 70 80 90 100 0 0.5 1 Frequency (xf) v a ( pu ) (b) Fig. 5: Voltage spectrum of (a) switching function Sa and (b) the corresponding phase voltage va for the three phase inverter. 0 0.002 0.004 0.006 0.008 0.01 0.012 0.014 0.016 0.018 0.02 -20 0 20 Time (s) C ur re nt (A ) (a) 0 10 20 30 40 50 60 70 80 90 100 0 10 20 30 Frequency (xf) M ag ni tu de i a (A ) (b) Fig. 6: Inverter output currents (three phases, a, b and c) and Fourier frequency spectrum at f = 50 Hz, M = 1, fs = 1.2 kHz, Vs = 600V, Z = 10 ohm at 0.8 pf lagging. IIUM Engineering Journal, Vol. 6, No. 2, 2005 K. Rahman AND S. J. M. Idrus 35 4. CONCLUSIONS A simplified technique of implementing regular sampled sine PWM is presented. The simplification involves integer arithmetic only that can be implemented with a low cost microcontroller at moderate speed. The simulation results show no deterioration in performance, although computations are all transformed from floating point into integer arithmetic. The hardware implementation scheme is compact, employing a memory minimized real time PWM pattern generator having less burden on the microcontroller. Due to low cost and high performance operating characteristics, the proposed PWM scheme is suitable for household, commercial and industrial applications for efficient control of voltage source inverters. REFERENCES [1] K. M. Rahman and M. Quamruzzaman, “A new hybrid PWM scheme for voltage source inverters,” in Proc. ICECE 2002, Dhaka, Bangladesh, pp. 332-335, 26-28 December 2002. [2] S. R. Bowes, “Novel real-time harmonic minimized PWM control for drives and static power converters,” IEEE Trans. Power Electron., vol. 9, no. 3, pp. 256-262, May 1994. [3] S. R. Bowes, “Advanced regular sampled PWM control techniques for drives and static power converters,” IEEE Trans. Ind. Electron., vol. 42, no. 4, pp. 367-373, August 1995. [4] S. R. Bowes, “Regular sampled harmonic elimination PWM control of inverter drives,” IEEE Trans. Power Electron., vol. 10, no. 5, pp. 521-531, September 1995. [5] K. M. Rahman, “PC controlled look-up table based PWM scheme for voltage source inverters and ac drives,” in Proc. ICCIT 99, Dhaka, Bangladesh, pp. 84-88, 3-5 December 1999. [6] K. M. Rahman, “PC based regular sampled pulse width modulator for inverters and drives,” in Proc. ICCIT 99, Dhaka, Bangladesh, pp. 89-93, 3-5 December 1999. [7] K. M. Rahman, “Analysis and implementation of PC based space vector PWM controller for VSI inverters and ac drives,” in Proc. ICCIT 2000, Dhaka, Bangladesh, pp. 49-54, 25-26 January 2001. [8] K. M. Rahman, K. M. Z. Shams and A. H. M. Z. Alam, “FPGA implementation of space vector PWM controller for three phase voltage source inverters,” in Proc. ICCIT 2001, Dhaka, Bangladesh, pp. 154159, 28-29 December 2001. [9] S. R. Bowes and S. S. Grewal, “Novel space-vector harmonic elimination inverter control,” IEEE Trans. Ind. Applicat., vol. 36, no. 2, pp. 549-557, March 2000. [10] Y. S. Lai and S. R. Bowes, “A new suboptimal pulse-width modulation technique for per-phase modulation and space vector modulation,” IEEE Trans. Energy Convert., vol. 12, no. 4, pp. 310-316, December 1997.