SVPWM
SVPWM是空間矢量脈寬調制(Space Vector Pulse Width Modulation)
的簡稱,通常由三相逆變器的六個功率開關管組成,經過特定的時序和換相所所產生的脈沖寬度調制波,最終輸出的波形可能會十分接近理想的正弦波形。具體如下圖所示;左側為復平面,即空間矢量,右側為時域的正弦波形。
關于SVPWM原理的文章非常多,這里可以推薦一下網上一個非常不錯的教程《SVPWM的原理及法則推導和控制算法詳解第五修改版》,本文將如何實現SVPWM進行簡單的介紹。
IQMATH
TI
的片子很香,控制方面,TI
無疑是做的最好的方案之一,相對來說資料也非常齊全;另外TI
針對沒有浮點運算器的定點DSP
推出了IQMATH
庫,在使用Q格式對數據進行分析和處理的過程中,十分方便,代碼也變得更加簡潔,本文將使用TI
的提供的SVPWM
算法基于STM32平臺實現SVPWM
調制。
測試平臺參數:硬件:stm32f103
軟件:標準外設庫3.5
IDE:MDK-ARM
IQmathLib
本文使用了IQMathLib
的Cortex-M3
版本,這樣一來,對于沒有浮點處理器的定點MCU來說,對數據統一進行Q格式的處理會變得更加便捷,并且高效;
首先將IQmathlib
解壓可以得到如下文件,其中包含各個平臺下的靜態庫,本文使用STM32F1
在keil
環境下進行開發,需要使用的是rvmdk-cm3
。打開一個
keil
工程,在菜單界面點擊如下圖所示的圖標進入project items
;
添加IQmath
組,并添加rvmdk-cm3
路徑下的靜態庫,和頭文件;
點擊下圖所示的圖標進入工程熟悉的設置;
添加rvmdk-cm3
靜態庫的路徑,和頭文件的包含路徑,如下圖所示;
最終,
build
整個工程即可。
測試部分程序
/**
#include"stm32f10x.h"
#include
#include
#include"serial_scope.h"
#include"common.h"
#include"IQmathLib.h"
#include"usart_driver.h"
#include"clarke.h"
#include"park.h"
#include"svpwm.h"
/**
*@briefMainprogram.
*@paramNone
*@retvalNone
*/
sv_mod_tsvpwm=SVGEN_DEFAULTS;
#defineCLARK0
#definePARK1
#defineSVPWM2
#defineSVPWM_REG3
intmain(void)
{
intuser_data[4]={0};
staticint16_ttime_cnt=0;
Trig_Componentsa;
Trig_Componentsb;
_iqfinal_angle;
usart_init();
while(1)
{
time_cnt-=32;
clarke_parameter.As=_IQsinPU(time_cnt);
clarke_parameter.Bs=_IQsinPU(time_cnt-0x5555);
if(clarke_parameter.As>32767){
clarke_parameter.As=32767;
}
if(clarke_parameter.As-32768){
clarke_parameter.As=-32768;
}
if(clarke_parameter.Bs>32767){
clarke_parameter.Bs=32767;
}
if(clarke_parameter.Bs-32768){
clarke_parameter.Bs=-32768;
}
clarke_calc(&clarke_parameter);
park_parameter.Alpha=clarke_parameter.Alpha;
park_parameter.Beta=clarke_parameter.Beta;
park_parameter.Sin=trig_functions(time_cnt).hsin;
park_parameter.Cos=trig_functions(time_cnt).hcos;
park_parameter.Angle=-time_cnt;
park_calc(&park_parameter);
svpwm.Ualpha=clarke_parameter.Alpha;
svpwm.Ubeta=clarke_parameter.Beta;
svpwm_calc(&svpwm);
#defineFOC_DEBUGSVPWM_REG
#if(FOC_DEBUG==CLEAK)
user_data[0]=clarke_parameter.As;
user_data[1]=clarke_parameter.Bs;
user_data[2]=clarke_parameter.Alpha;
user_data[3]=clarke_parameter.Beta;
#elif(FOC_DEBUG==PARK)
user_data[0]=clarke_parameter.As;
user_data[1]=clarke_parameter.Bs;
user_data[2]=park_parameter.Ds;
user_data[3]=park_parameter.Qs;
#elif(FOC_DEBUG==SVPWM)
user_data[0]=(uint16_t)svpwm.Ta;
user_data[1]=(uint16_t)svpwm.Tb;
user_data[2]=(uint16_t)svpwm.Tc;
user_data[3]=svpwm.VecSector*5000;
#elif(FOC_DEBUG==SVPWM_REG)
//換算的CCRx寄存器的值
sv_regs_mod_tsv_regs=svpwm_get_regs_mod(7200,&svpwm);
user_data[0]=sv_regs.ccr1;
user_data[1]=sv_regs.ccr2;
user_data[2]=sv_regs.ccr3;
user_data[3]=svpwm.VecSector*1000;
#endif
SDS_OutPut_Data_INT(user_data);
}
return0;
}
最終通過串口輸出串口圖形化軟件的Ta,Tb,Tc 如下圖所示;
關于STM32的配置,需要配置三路互補PWM波形輸出;例如配置了TIM1
的CH1
,CH2
,CH3
這三路PWM輸出,然后可以把Ta
,Tb
,Tc
的值分別賦值給CCR1
,CCR2
,CCR3
即可;
具體如下圖所示;左側是復平面的矢量合成動態圖;右側是三路PWM輸出通道的比較狀態;
![c4dfa8da-d34d-11ec-bce3-dac502259ad0.gif](https://file1.elecfans.com//web2/M00/95/5C/wKgZomTm_oOAO7HOAELUrwLftLA951.gif)
原文標題:通俗易懂!這篇SVPWM來晚了!
文章出處:【微信公眾號:硬件攻城獅】歡迎添加關注!文章轉載請注明出處。
-
ti
+關注
關注
112文章
7987瀏覽量
212945 -
調制
+關注
關注
0文章
164瀏覽量
29738 -
STM32
+關注
關注
2272文章
10923瀏覽量
357576 -
SVPWM
+關注
關注
14文章
614瀏覽量
90730
原文標題:通俗易懂!這篇SVPWM來晚了!
文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論