找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 11471|回復(fù): 6
收起左側(cè)

如何使用STM32的定時(shí)器產(chǎn)生SPWM波,濾波可產(chǎn)生正弦波。

[復(fù)制鏈接]
ID:101736 發(fā)表于 2016-1-4 12:05 | 顯示全部樓層 |閱讀模式
如題stm32如何實(shí)現(xiàn)spwm:

回復(fù)

使用道具 舉報(bào)

ID:1 發(fā)表于 2016-1-4 17:16 | 顯示全部樓層
使用STM32大家的定時(shí)器產(chǎn)生SPWM波,經(jīng)過濾波可產(chǎn)生正弦波源碼下載: SPWM輸出.rar (283.04 KB, 下載次數(shù): 588)
  1. #include "SPWM.h"
  2. #include "led.h"
  3. #include "usart.h"


  4. u16 TimerPeriod = 7200;
  5. u16 DutyFactor = 50;


  6. void TIM_Int_Init(void)
  7. {
  8.           GPIO_InitTypeDef GPIO_InitStructure;
  9.     TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
  10.           NVIC_InitTypeDef NVIC_InitStructure;

  11.          RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB, ENABLE);        
  12.    RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4 | RCC_APB1Periph_TIM3,ENABLE);            //時(shí)鐘使能
  13.    
  14.         
  15.                   /* GPIOA配置:通道PA.6和PA.7作為輸出引腳*/
  16.          GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6 | GPIO_Pin_7;
  17.          GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  18.          GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  19.          GPIO_Init(GPIOA, &GPIO_InitStructure);
  20.         
  21.         
  22.          TIM_TimeBaseStructure.TIM_Prescaler = 0;
  23.          TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;                //計(jì)數(shù)方式
  24.          TIM_TimeBaseStructure.TIM_Period = TimerPeriod - 1;
  25.          TIM_TimeBaseStructure.TIM_ClockDivision = 0;
  26.          TIM_TimeBaseStructure.TIM_RepetitionCounter = 0;
  27.          TIM_TimeBaseInit(TIM3, &TIM_TimeBaseStructure);
  28.          
  29.          TIM_DeInit(TIM4);                //這邊是普通定時(shí)器的初始化和中斷申請(qǐng)
  30.          TIM_TimeBaseStructure.TIM_Period=1;    //自動(dòng)重裝載寄存器的值
  31.          TIM_TimeBaseStructure.TIM_Prescaler= 3599;   //時(shí)鐘預(yù)分頻數(shù)
  32.          TIM_TimeBaseStructure.TIM_ClockDivision=TIM_CKD_DIV1; //采樣分頻
  33.          TIM_TimeBaseStructure.TIM_CounterMode=TIM_CounterMode_Up;//計(jì)數(shù)方式
  34.          TIM_TimeBaseInit(TIM4, &TIM_TimeBaseStructure);
  35.          TIM_ClearFlag(TIM4, TIM_FLAG_Update); //清除溢出中斷標(biāo)志
  36.          TIM_ITConfig(TIM4,TIM_IT_Update,ENABLE);  // 計(jì)數(shù)溢出時(shí)觸發(fā)中斷  
  37. //根據(jù)NVIC_InitStruct中指定的參數(shù)初始化外設(shè)NVIC寄存器

  38.          NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);
  39.          NVIC_InitStructure.NVIC_IRQChannel = TIM4_IRQn; //通道TIM3
  40.          NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;//占優(yōu)先級(jí)
  41.          NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1; //副優(yōu)先級(jí)
  42.          NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  43.          NVIC_Init(&NVIC_InitStructure);
  44.                   
  45. }
  46. //定時(shí)器4中斷服務(wù)程序
  47. void TIM4_IRQHandler(void)
  48. {
  49. static vu16 sign = 0;
  50. static vu16 Counter_sine=0;
  51. static vu16 Duty_Cycle_sinewavetable[128]={0x0,0x83,0x105,0x187,0x209,0x28A,0x30A,0x38A,
  52.                                                                                                                                                                                 0x409,0x486,0x502,0x57D,0x5F7,0x66F,0x6E5,0x75A,
  53.                                                                                                                                                                                 0x7CC,0x83D,0x8AB,0x917,0x981,0x9E8,0xA4D,0xAAF,
  54.                                                                                                                                                                                 0xB0E,0xB6B,0xBC4,0xC1B,0xC6E,0xCBE,0xD0B,0xD54,
  55.                                                                                                                                                                                 0xD9A,0xDDD,0xE1C,0xE57,0xE8F,0xEC3,0xEF3,0xF1F,
  56.                                                                                                                                                                                 0xF48,0xF6C,0xF8D,0xFA9,0xFC2,0xFD6,0xFE6,0xFF3,
  57.                                                                                                                                                                                 0xFFB,0xFFF,0xFFF,0xFFB,0xFF3,0xFE6,0xFD6,0xFC2,
  58.                                                                                                                                                                                 0xFA9,0xF8D,0xF6C,0xF48,0xF1F,0xEF3,0xEC3,0xE8F,
  59.                                                                                                                                                                                 0xE57,0xE1C,0xDDD,0xD9A,0xD54,0xD0B,0xCBE,0xC6E,
  60.                                                                                                                                                                                 0xC1B,0xBC4,0xB6B,0xB0E,0xAAF,0xA4D,0x9E8,0x981,
  61.                                                                                                                                                                                 0x917,0x8AB,0x83D,0x7CC,0x75A,0x6E5,0x66F,0x5F7,
  62.                                                                                                                                                                                 0x57D,0x502,0x486,0x409,0x38A,0x30A,0x28A,0x209,
  63.                                                                                                                                                                                 0x187,0x105,0x83,0x0};
  64. if (TIM_GetITStatus(TIM4 ,TIM_IT_Update) == SET)
  65. {
  66.   if(sign == 0)
  67.   {
  68.          TIM_SetCompare1(TIM3,Duty_Cycle_sinewavetable[Counter_sine]);
  69.          TIM_SetCompare2(TIM3,0);
  70.          Counter_sine++;
  71.          if(Counter_sine==100)  //半周期采樣100個(gè)點(diǎn)
  72.          {
  73.               Counter_sine=0;
  74.               sign = 1;
  75.          }
  76.   }else{
  77.          TIM_SetCompare1(TIM3,0);
  78.          TIM_SetCompare2(TIM3,Duty_Cycle_sinewavetable[Counter_sine]);
  79.          Counter_sine++;
  80.          if(Counter_sine==100)
  81.          {
  82.               Counter_sine=0;
  83.               sign = 0;  
  84.          }
  85.    }
  86. }
  87. TIM_ClearITPendingBit(TIM4 , TIM_FLAG_Update);
  88. }



  89. //TIM3 PWM部分初始化
  90. //PWM輸出初始化
  91. //arr:自動(dòng)重裝值
  92. //psc:時(shí)鐘預(yù)分頻數(shù)
  93. void TIM_PWM_Init(void)
  94. {  
  95.         
  96.               TIM_OCInitTypeDef  TIM_OCInitStructure;
  97.               TIM_BDTRInitTypeDef TIM_BDTRInitStructure;
  98.         

  99.                TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
  100.          TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
  101.          TIM_OCInitStructure.TIM_OutputNState = TIM_OutputNState_Enable;
  102.          TIM_OCInitStructure.TIM_Pulse = DutyFactor * 7200 / 100;//設(shè)置占空比
  103.          TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;//以上四行代碼設(shè)置PWM的空閑電平、波形方式的!
  104.         
  105.                TIM_OCInitStructure.TIM_OCNPolarity = TIM_OCNPolarity_High;
  106.          TIM_OCInitStructure.TIM_OCIdleState = TIM_OCIdleState_Set;
  107.          TIM_OCInitStructure.TIM_OCNIdleState = TIM_OCIdleState_Reset;
  108.          TIM_OC1Init(TIM3, &TIM_OCInitStructure);
  109.          TIM_OC2Init(TIM3, &TIM_OCInitStructure);                        //初始化兩組互補(bǔ)的PWM
  110.          /* 自動(dòng)輸出使能,中斷,死區(qū)相關(guān)的設(shè)置*/  
  111.          TIM_BDTRInitStructure.TIM_OSSRState = TIM_OSSRState_Enable;
  112.          TIM_BDTRInitStructure.TIM_OSSIState = TIM_OSSIState_Enable;
  113.          TIM_BDTRInitStructure.TIM_LOCKLevel = TIM_LOCKLevel_1;
  114.          TIM_BDTRInitStructure.TIM_DeadTime = 12;//死區(qū)時(shí)間為 12/SYSTEMCLK (ns)
  115.          TIM_BDTRInitStructure.TIM_Break = TIM_Break_Disable;//關(guān)閉外部break功能
  116.          TIM_BDTRInitStructure.TIM_BreakPolarity = TIM_BreakPolarity_High;
  117.          TIM_BDTRInitStructure.TIM_AutomaticOutput = TIM_AutomaticOutput_Enable;
  118.          TIM_BDTRConfig(TIM3, &TIM_BDTRInitStructure);
  119.          TIM_CtrlPWMOutputs(TIM3, ENABLE);


  120. }
復(fù)制代碼


回復(fù)

使用道具 舉報(bào)

ID:222482 發(fā)表于 2017-7-26 10:39 | 顯示全部樓層
admin 發(fā)表于 2016-1-4 17:16
使用STM32大家的定時(shí)器產(chǎn)生SPWM波,經(jīng)過濾波可產(chǎn)生正弦波源碼下載:

你好請(qǐng)問兩個(gè)輸出口對(duì)應(yīng)兩個(gè)通道輸出時(shí)怎么對(duì)應(yīng)的
回復(fù)

使用道具 舉報(bào)

ID:222615 發(fā)表于 2017-8-7 15:21 | 顯示全部樓層
你好,這個(gè)在A6,A7口測(cè)出來的是一對(duì)相反的方波,
回復(fù)

使用道具 舉報(bào)

ID:219141 發(fā)表于 2018-5-30 17:13 | 顯示全部樓層
admin 發(fā)表于 2016-1-4 17:16
使用STM32大家的定時(shí)器產(chǎn)生SPWM波,經(jīng)過濾波可產(chǎn)生正弦波源碼下載:

你好,請(qǐng)問按照你的代碼,為什么在第二個(gè)通道每次最后會(huì)突變?yōu)楦唠娖揭欢螘r(shí)間呢?
回復(fù)

使用道具 舉報(bào)

ID:403087 發(fā)表于 2018-11-8 22:37 | 顯示全部樓層
謝謝分享!
回復(fù)

使用道具 舉報(bào)

ID:254226 發(fā)表于 2022-3-27 23:36 | 顯示全部樓層
測(cè)試成功,感謝分享!
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表