STM32上SVPWM輸出的實現(xiàn)方案
摘要:在STM32F103VET6上實現(xiàn)了SVPWM輸出。介紹了SVPWM的優(yōu)點及原理。結合STM32F103VET6上的硬件資源,給出了SVPWM在高級定時器上實現(xiàn)的方式和三相橋式驅動電路的設計。分析了該方案所占用的CPU資源。實驗結果表明,該設計方案可行,能夠實現(xiàn)SVPWM輸出。
關鍵詞:SVPWM;STM32;定時器;三相橋式驅動
引言
SVPWM與SPWM相比,是一種比較新穎的控制方法,能夠使輸出電流波形盡可能接近于理想的正弦波形,使直流母線電壓的利用率有了很大提高。SVPWM主要應用在變頻器領域,控制過程中需要對坐標進行變換及計算輸出時間,所以整個過程有一定的計算量,使得51單片機力不從心。人們只能采用價格昂貴、內部資源偏少的DSP作為控制芯片。隨著STM32系列芯片的出現(xiàn),其豐富的片內資源、較高的處理能力、極低的價格,使其得到開發(fā)人員的青睞。
1 SVPWM原理
在傳統(tǒng)的三相橋式驅動電路中,MOS管的開關狀態(tài)一共有8種組合。如果將這幾種開關方式加到三個相差120°的繞組上,則會產(chǎn)生8個電壓矢量。這8個電壓矢量被稱為基本空間電壓矢量,如圖1所示。為了能夠得到一個圓形旋轉磁場,SVPWM可以通過控制8個基本空間電壓矢量的作用時間,來合成每個扇區(qū)內的任意電壓矢量。
2 系統(tǒng)設計方案
2.1 控制芯片
采用STMicroelectronics公司的STM32F103VET6作為其控制芯片,其內核為ARM公司Cortex—M3,最高時鐘頻率可達72 MHz,包括512K片內FLASH、64K片內RAM、ADC、SPI、CAN、FSMC等豐富的內部資源。STM32F103VET6內部包含8個定時器,其中有2個高級定時器,所有的定時器都包含一個16位自動裝載寄存器。高級定時器支持嵌入死區(qū)時間的互補PWM,而且支持剎車信號的輸入,所以非常適合應用在變頻器、電機控制器等場合。
2.2 定時器工作模式
根據(jù)SVPWM的快速算法可以得到各個基本空間電壓矢量的作用時間和輸出順序。知道輸出順序后,就可以確定高級定時器的工作模式。由于SVPWM的輸出波形是很對稱的,所以選用TIM1的中央對齊模式:
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_CenterAlignedl;
此模式下,計數(shù)器從0開始計數(shù)到自動加載值減1,同時產(chǎn)生一個計數(shù)器溢出事件。然后向下計數(shù)到1,并且產(chǎn)生一個計數(shù)器下溢事件,再從0開始重新計數(shù)。
2.3 定時器計數(shù)周期
為了提高定時器的分辨率,直接將72 MHz作為定時器的計數(shù)時鐘,沒有任何預分頻。假設SVPWM的調制頻率為frq,則可以計算時間基的計數(shù)值tpwm:
TIM_CLOCK是定時器的計數(shù)頻率,本系統(tǒng)為72 MHz。如果調制頻率設為20 kHz,則計數(shù)器的值則為3 600。
2.4 波形輸出
TIM1的CH1、CH1N、CH2、CH2N、CH3、CH3N通道對應的GPIO引腳須設為GPIO_Mode_AF_PP模式才能正常輸出。根據(jù)各個基本空間電壓矢量的作用時間,可以計算出TIM1上三個通道各自的OCRx值。圖2為各個通道OCRx的值對應的輸出波形。
2.5 中斷子程序
為了減少中斷的時間,在中斷程序中僅保留了輸出SVPWM所必要的運算及對TIM1必要的操作。整個程序中的所有的電壓量全部轉化為標幺值。由于STM32是一款32位的控制器,所以需要參與計算值都采用Q15的形式,這樣可以在提高精度的同時保證乘法運算不會溢出。中斷子程序的流程如圖3所示。
2.6 CPU資源占用分析
由圖2可以看出,在定時器輸出波形時有兩個觸發(fā)產(chǎn)生。TIM1_CH4可以用來觸發(fā)芯片的其他功能(如ADC采樣),這樣就可以自動完成一些工作,避免消耗CPU資源。
為了在一個周期調制完成后馬上進行下一個周期的調制,下次調制的時間需要提前計算,此時就必須打開定時器的預裝載功能。在發(fā)生計數(shù)器溢出中斷后,計算下一次調制時各個通道的時間。計算完成后將結果寫入預裝載寄存器,以便在下次更新時寫入新的比較值??梢钥闯?,SVPWM只在中斷中耗費了CPU的一點資源用來計算,其余全是定時器自動完成,而且在兩次調制之間沒有任何延遲。
3 系統(tǒng)實驗
3.1 實驗硬件電路
實驗硬件電路包括主控芯片及外圍電路、MOS驅動器和由6個MOS管組成的逆變器。其部分電路如圖4所示。ADUM3223驅動器的輸入來自STM32F103VET6中TIM1的CH1和CH1N,兩者為互補輸出。使能輸入端連接到芯片的PE15引腳,并且有一個4.7 KΩ的上拉電阻。在輸出端的高端設計了一個泵電源,保證高端MOS管能夠可靠導通。R1用來保證充電速度不會過快,可根據(jù)實際需求更改大小。在MOS管的柵極有一個限流電阻,用來防止MOS管漏源極電壓dv/dt太大,導致?lián)p壞。
3.2 實驗結果
由于SVPWM的輸入為αβ坐標系下的Uα和Uβ,在讓矢量運行軌跡為圓形時特別困難,所以在輸入端前加入了一個Park變換算法,使其變?yōu)閁d和Uq。這樣只需要設置合成矢量的角度和大小,而角度可以人為設為一個勻速圓周運動的值。圖5為第一扇區(qū)下的調制輸出波形。圖6為矢量圓周運動時,輸出相電壓濾波后的馬鞍波形。
結語
由實驗結果可知,該設計方案可以方便地實現(xiàn)SVPWM輸出,計算量并不大。其功能主要是靠硬件實現(xiàn),所以占用CPU資源很少,完全可以當作一個模塊應用到其他場合中。
評論