自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

對(duì)不起!這篇Svpwm來(lái)晚了!

開(kāi)發(fā) 前端
SVPWM是空間矢量脈寬調(diào)制(Space Vector Pulse Width Modulation)的簡(jiǎn)稱,通常由三相逆變器的六個(gè)功率開(kāi)關(guān)管組成,經(jīng)過(guò)特定的時(shí)序和換相所所產(chǎn)生的脈沖寬度調(diào)制波,最終輸出的波形可能會(huì)十分接近理想的正弦波形。

 [[379610]]

本文轉(zhuǎn)載自微信公眾號(hào)「小麥大叔」,可以通過(guò)以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系小麥大叔公眾號(hào)。

SVPWM

SVPWM是空間矢量脈寬調(diào)制(Space Vector Pulse Width Modulation)的簡(jiǎn)稱,通常由三相逆變器的六個(gè)功率開(kāi)關(guān)管組成,經(jīng)過(guò)特定的時(shí)序和換相所所產(chǎn)生的脈沖寬度調(diào)制波,最終輸出的波形可能會(huì)十分接近理想的正弦波形。具體如下圖所示;左側(cè)為復(fù)平面,即空間矢量,右側(cè)為時(shí)域的正弦波形;

關(guān)于SVPWM原理的文章非常多,這里可以推薦一下網(wǎng)上一個(gè)非常不錯(cuò)的教程《SVPWM的原理及法則推導(dǎo)和控制算法詳解第五修改版》,本文將如何實(shí)現(xiàn)SVPWM進(jìn)行簡(jiǎn)單的介紹。

IQMATH

TI的片子很香,控制方面,TI無(wú)疑是做的最好的方案之一,相對(duì)來(lái)說(shuō)資料也非常齊全;另外TI針對(duì)沒(méi)有浮點(diǎn)運(yùn)算器的定點(diǎn)DSP推出了IQMATH庫(kù),在使用Q格式對(duì)數(shù)據(jù)進(jìn)行分析和處理的過(guò)程中,十分方便,代碼也變得更加簡(jiǎn)潔,本文將使用TI的提供的SVPWM算法基于STM32平臺(tái)實(shí)現(xiàn)SVPWM調(diào)制。

測(cè)試平臺(tái)參數(shù):硬件:stm32f103軟件:標(biāo)準(zhǔn)外設(shè)庫(kù)3.5IDE:MDK-ARM

IQmathLib

本文使用了IQMathLib的Cortex-M3版本,這樣一來(lái),對(duì)于沒(méi)有浮點(diǎn)處理器的定點(diǎn)MCU來(lái)說(shuō),對(duì)數(shù)據(jù)統(tǒng)一進(jìn)行Q格式的處理會(huì)變得更加便捷,并且高效;

首先將IQmathlib解壓可以得到如下文件,其中包含各個(gè)平臺(tái)下的靜態(tài)庫(kù),本文使用STM32F1在keil環(huán)境下進(jìn)行開(kāi)發(fā),需要使用的是rvmdk-cm3。

打開(kāi)一個(gè)keil工程,在菜單界面點(diǎn)擊如下圖所示的圖標(biāo)進(jìn)入project items;

添加IQmath組,并添加rvmdk-cm3路徑下的靜態(tài)庫(kù),和頭文件;

點(diǎn)擊下圖所示的圖標(biāo)進(jìn)入工程熟悉的設(shè)置;

添加rvmdk-cm3靜態(tài)庫(kù)的路徑,和頭文件的包含路徑,如下圖所示;

最終,build整個(gè)工程即可。

測(cè)試部分程序

  1. /** 
  2. #include "stm32f10x.h" 
  3. #include <stdio.h> 
  4. #include <stdint.h> 
  5.  
  6. #include "serial_scope.h" 
  7. #include "common.h" 
  8. #include "IQmathLib.h" 
  9. #include "usart_driver.h" 
  10. #include "clarke.h" 
  11. #include "park.h" 
  12. #include "svpwm.h" 
  13.  
  14. /** 
  15.   * @brief  Main program. 
  16.   * @param  None 
  17.   * @retval None 
  18.   */ 
  19. sv_mod_t svpwm = SVGEN_DEFAULTS; 
  20.  
  21. #define CLARK  0 
  22. #define PARK  1 
  23. #define SVPWM  2 
  24. #define SVPWM_REG 3 
  25.  
  26. int main(void) 
  27.  int user_data[4] = { 0 }; 
  28.  static int16_t time_cnt = 0; 
  29.  Trig_Components a; 
  30.  Trig_Components b; 
  31.  _iq final_angle; 
  32.  usart_init();  
  33.  
  34.  while (1) 
  35.  {   
  36.   time_cnt-=32; 
  37.    
  38.   clarke_parameter.As = _IQsinPU(time_cnt); 
  39.   clarke_parameter.Bs = _IQsinPU(time_cnt-0x5555); 
  40.    
  41.   if(clarke_parameter.As > 32767){ 
  42.    clarke_parameter.As = 32767; 
  43.   } 
  44.   if(clarke_parameter.As < -32768){ 
  45.    clarke_parameter.As = -32768; 
  46.   } 
  47.    
  48.   if(clarke_parameter.Bs > 32767){ 
  49.    clarke_parameter.Bs = 32767; 
  50.   } 
  51.   if(clarke_parameter.Bs < -32768){ 
  52.    clarke_parameter.Bs = -32768; 
  53.   } 
  54.    
  55.   clarke_calc(&clarke_parameter); 
  56.    
  57.   park_parameter.Alpha = clarke_parameter.Alpha; 
  58.   park_parameter.Beta = clarke_parameter.Beta; 
  59.    
  60.   park_parameter.Sin = trig_functions(time_cnt).hsin; 
  61.   park_parameter.Cos = trig_functions(time_cnt).hcos; 
  62.   park_parameter.Angle = -time_cnt; 
  63.   park_calc(&park_parameter); 
  64.    
  65.   svpwm.Ualpha = clarke_parameter.Alpha; 
  66.   svpwm.Ubeta = clarke_parameter.Beta; 
  67.    
  68.   svpwm_calc(&svpwm); 
  69.    
  70.   #define FOC_DEBUG  SVPWM_REG 
  71. #if (FOC_DEBUG == CLEAK) 
  72.   user_data[0] = clarke_parameter.As
  73.   user_data[1] = clarke_parameter.Bs; 
  74.   user_data[2] = clarke_parameter.Alpha; 
  75.   user_data[3] = clarke_parameter.Beta;   
  76. #elif (FOC_DEBUG == PARK) 
  77.   user_data[0] = clarke_parameter.As
  78.   user_data[1] = clarke_parameter.Bs; 
  79.   user_data[2] = park_parameter.Ds; 
  80.   user_data[3] = park_parameter.Qs; 
  81. #elif (FOC_DEBUG == SVPWM)  
  82.   user_data[0] = (uint16_t)svpwm.Ta; 
  83.   user_data[1] = (uint16_t)svpwm.Tb; 
  84.   user_data[2] = (uint16_t)svpwm.Tc; 
  85.   user_data[3] = svpwm.VecSector*5000; 
  86. #elif (FOC_DEBUG == SVPWM_REG) 
  87.    
  88.   //換算的CCRx寄存器的值 
  89.   sv_regs_mod_t sv_regs = svpwm_get_regs_mod(7200,&svpwm); 
  90.    
  91.   user_data[0] = sv_regs.ccr1; 
  92.   user_data[1] = sv_regs.ccr2; 
  93.   user_data[2] = sv_regs.ccr3; 
  94.   user_data[3] = svpwm.VecSector*1000; 
  95. #endif 
  96.   SDS_OutPut_Data_INT(user_data); 
  97.  } 
  98.  return 0; 

最終通過(guò)串口輸出串口圖形化軟件的Ta,Tb,Tc 如下圖所示;

關(guān)于STM32的配置,需要配置三路互補(bǔ)PWM波形輸出;例如配置了TIM1的CH1,CH2,CH3這三路PWM輸出,然后可以把Ta,Tb,Tc的值分別賦值給CCR1,CCR2,CCR3即可;

具體如下圖所示;左側(cè)是復(fù)平面的矢量合成動(dòng)態(tài)圖;右側(cè)是三路PWM輸出通道的比較狀態(tài);

開(kāi)關(guān)狀態(tài)

附件

 

 

責(zé)任編輯:武曉燕 來(lái)源: 小麥大叔
相關(guān)推薦

2020-08-14 07:25:51

設(shè)計(jì)模式

2020-02-25 09:43:13

區(qū)塊鏈blockchain疫情

2015-02-28 14:05:08

FDD-LTETD-LTE

2017-05-29 21:46:06

數(shù)博會(huì)馬化騰驚喜

2023-01-09 07:50:29

開(kāi)源開(kāi)發(fā)者項(xiàng)目

2023-12-14 17:31:10

SQL表格模型功能

2011-03-03 15:51:54

2020-12-14 09:33:56

大數(shù)據(jù)IT技術(shù)

2015-08-17 09:43:12

編程創(chuàng)造程序員

2009-11-24 09:09:05

Chrome OS發(fā)布

2021-12-14 15:30:02

數(shù)字化企業(yè)轉(zhuǎn)型運(yùn)營(yíng)商轉(zhuǎn)型

2024-06-20 13:44:48

OpenAIV2A模型

2012-05-24 15:53:57

獵豹瀏覽器

2018-10-19 16:35:20

運(yùn)維

2020-01-18 11:13:08

CPU程序存儲(chǔ)

2013-07-01 13:25:43

SDN控制器軟件控制網(wǎng)絡(luò)SDN

2020-11-18 07:47:09

ElasticSear Lucene搜索服務(wù)器

2011-06-15 11:03:54

Linux內(nèi)核Xen

2012-04-30 20:54:01

Android

2013-05-20 16:30:37

移動(dòng)應(yīng)用App推廣
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)