標(biāo)題: STM32正弦波發(fā)生器源程序 [打印本頁]

作者: 2271662542    時(shí)間: 2019-8-8 21:20
標(biāo)題: STM32正弦波發(fā)生器源程序
  1. #include "sign.h"
  2. u16 SineWave_Value[256];

  3. /********正弦波輸出表***********/
  4. //cycle        :波形表的位數(shù)        (0~256)
  5. //Um                :輸出電壓的峰值(0~1.5)
  6. /*******************************/
  7. void SineWave_Data( u16 cycle ,u16 *D,float Um)
  8. {
  9.     u16 i;
  10.     for( i=0;i<cycle;i++)
  11.     {
  12.         D[i]=(u16)((Um*sin(( 1.0*i/(cycle-1))*2*PI)+Um)*4095/3.3);
  13.     }
  14. }


  15. /****************初始化引腳******************/
  16. void SineWave_GPIO_Config(void)
  17. {
  18.     GPIO_InitTypeDef GPIO_InitStructure;
  19.     RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);  //開時(shí)鐘
  20.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;       //推挽輸出模式
  21.     GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;   //輸出速率
  22.     GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_4 ; //選擇引腳
  23.     GPIO_SetBits(GPIOA,GPIO_Pin_4)  ;   //拉高輸出
  24.     GPIO_Init(GPIOA, &GPIO_InitStructure);      //初始化
  25. }

  26. /******************DAC初始化ˉ*************************/
  27. void SineWave_DAC_Config( void)
  28. {
  29.     DAC_InitTypeDef            DAC_InitStructure;
  30.     RCC_APB1PeriphClockCmd(RCC_APB1Periph_DAC, ENABLE);//開DAC時(shí)鐘
  31.      
  32.   /**************DAC結(jié)構(gòu)初始化*******************/
  33.     DAC_StructInit(&DAC_InitStructure);   
  34.     DAC_InitStructure.DAC_WaveGeneration = DAC_WaveGeneration_None;//不產(chǎn)生波形
  35.     DAC_InitStructure.DAC_OutputBuffer = DAC_OutputBuffer_Disable; //不使能輸出緩存
  36.     DAC_InitStructure.DAC_Trigger = DAC_Trigger_T2_TRGO;//DAC觸發(fā)為定時(shí)器2觸發(fā)
  37.     DAC_Init(DAC_Channel_1, &DAC_InitStructure);//初始化
  38.     DAC_Cmd(DAC_Channel_1, ENABLE);    //使能DAC的通道1
  39.     DAC_DMACmd(DAC_Channel_1, ENABLE); //使能DAC通道1的DMA  
  40. }

  41. /*********定時(shí)器初始化************/
  42. void SineWave_TIM_Config(u32 Wave1_Fre)
  43. {
  44.     TIM_TimeBaseInitTypeDef    TIM_TimeBaseStructure;
  45.     RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);//開時(shí)鐘
  46.     TIM_TimeBaseStructInit(&TIM_TimeBaseStructure);
  47.     TIM_TimeBaseStructure.TIM_Prescaler = 0x0;     //不預(yù)分頻
  48.     TIM_TimeBaseStructure.TIM_ClockDivision = 0x0; //不分頻<br>  TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;//向上計(jì)數(shù)
  49.     TIM_TimeBaseStructure.TIM_Period = Wave1_Fre;//設(shè)置輸出頻率
  50.     TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);
  51.     TIM_SelectOutputTrigger(TIM2, TIM_TRGOSource_Update);//設(shè)置TIME輸出觸發(fā)為更新模式
  52. }

  53. /*********DMA配置***********/
  54. void SineWave_DMA_Config(void)
  55. {                  
  56.     DMA_InitTypeDef            DMA_InitStructure;
  57.     RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA2, ENABLE);//開啟DMA2時(shí)鐘
  58.      
  59.     DMA_StructInit( &DMA_InitStructure);        //DMA結(jié)構(gòu)體初始化
  60.     DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralDST;//從寄存器讀數(shù)據(jù)
  61.     DMA_InitStructure.DMA_BufferSize = 256;//寄存器大小
  62.     DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;//外設(shè)地址不遞增
  63.     DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; //內(nèi)存地址遞增
  64.     DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;//寬度為半字
  65.     DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;//寬度為半字
  66.     DMA_InitStructure.DMA_Priority = DMA_Priority_VeryHigh;//優(yōu)先級(jí)非常高
  67.     DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;//關(guān)閉內(nèi)存到內(nèi)存模式
  68.     DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;//循環(huán)發(fā)送模式
  69.        
  70.                 DMA_InitStructure.DMA_PeripheralBaseAddr = DAC_DHR12R1;//外設(shè)地址為DAC通道1的地址
  71.                 DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)SineWave_Value;//波形數(shù)據(jù)表內(nèi)存地址
  72.                 DMA_Init(DMA2_Channel3, &DMA_InitStructure);//初始化
  73.                 DMA_Cmd(DMA2_Channel3, ENABLE); //使能DMA通道3      
  74.                
  75. }

  76. /**********正弦波初始化**********************/
  77. //Wave1_Fre:        頻率值(0~60 000)Hz
  78. //Um                         :        電壓峰值(0.0~1.5)V
  79. /*******************************************/

  80. void SineWave_Init(u16 Wave1_Fre,float Um)
  81. {
  82.         u32 f1;
  83.         f1=(u32)(72000000/sizeof(SineWave_Value)*2/Wave1_Fre);//計(jì)算頻率
  84.         SineWave_Data(256,SineWave_Value,Um);     //生成輸出正弦波的波形表
  85.         SineWave_GPIO_Config();             //初始化io
  86.         SineWave_TIM_Config(f1);            //初始化定時(shí)器
  87.         SineWave_DAC_Config();              //配置DAC
  88.         SineWave_DMA_Config();              //配置DMA
  89.         TIM_Cmd(TIM2, ENABLE);             //開啟定時(shí)器
  90. }
復(fù)制代碼


波形發(fā)生器1.0.7z

184.25 KB, 下載次數(shù): 74, 下載積分: 黑幣 -5


作者: admin    時(shí)間: 2019-8-8 22:48
本帖需要重新編輯補(bǔ)全電路原理圖,源碼,詳細(xì)說明與圖片即可獲得100+黑幣(帖子下方有編輯按鈕)
作者: 張明211    時(shí)間: 2019-10-20 09:07
值得借鑒
作者: 甲魚單片機(jī)    時(shí)間: 2020-6-17 19:41
admin 發(fā)表于 2019-8-8 22:48
本帖需要重新編輯補(bǔ)全電路原理圖,源碼,詳細(xì)說明與圖片即可獲得100+黑幣(帖子下方有編輯按鈕)

請(qǐng)問您做出來嗎?
作者: 袁木子愛學(xué)習(xí)    時(shí)間: 2021-1-18 17:35
請(qǐng)問void SineWave_Data( u16 cycle ,u16 *D,float Um)
{
    u16 i;
    for( i=0;i<cycle;i++)
    {
        D[i]=(u16)((Um*sin(( 1.0*i/(cycle-1))*2*PI)+Um)*4095/3.3);
    }
}
這段程序里的公式怎么理解  謝謝




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1