找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3085|回复: 4
收起左侧

STM32正弦波发生器源程序

[复制链接]
ID:598018 发表于 2019-8-8 21:20 | 显示全部楼层 |阅读模式
  1. #include "sign.h"
  2. u16 SineWave_Value[256];

  3. /********正弦波输出表***********/
  4. //cycle        :波形表的位数        (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);  //开时钟
  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时钟
  31.      
  32.   /**************DAC结构初始化*******************/
  33.     DAC_StructInit(&DAC_InitStructure);   
  34.     DAC_InitStructure.DAC_WaveGeneration = DAC_WaveGeneration_None;//不产生波形
  35.     DAC_InitStructure.DAC_OutputBuffer = DAC_OutputBuffer_Disable; //不使能输出缓存
  36.     DAC_InitStructure.DAC_Trigger = DAC_Trigger_T2_TRGO;//DAC触发为定时器2触发
  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. /*********定时器初始化************/
  42. void SineWave_TIM_Config(u32 Wave1_Fre)
  43. {
  44.     TIM_TimeBaseInitTypeDef    TIM_TimeBaseStructure;
  45.     RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);//开时钟
  46.     TIM_TimeBaseStructInit(&TIM_TimeBaseStructure);
  47.     TIM_TimeBaseStructure.TIM_Prescaler = 0x0;     //不预分频
  48.     TIM_TimeBaseStructure.TIM_ClockDivision = 0x0; //不分频<br>  TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;//向上计数
  49.     TIM_TimeBaseStructure.TIM_Period = Wave1_Fre;//设置输出频率
  50.     TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);
  51.     TIM_SelectOutputTrigger(TIM2, TIM_TRGOSource_Update);//设置TIME输出触发为更新模式
  52. }

  53. /*********DMA配置***********/
  54. void SineWave_DMA_Config(void)
  55. {                  
  56.     DMA_InitTypeDef            DMA_InitStructure;
  57.     RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA2, ENABLE);//开启DMA2时钟
  58.      
  59.     DMA_StructInit( &DMA_InitStructure);        //DMA结构体初始化
  60.     DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralDST;//从寄存器读数据
  61.     DMA_InitStructure.DMA_BufferSize = 256;//寄存器大小
  62.     DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;//外设地址不递增
  63.     DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; //内存地址递增
  64.     DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;//宽度为半字
  65.     DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;//宽度为半字
  66.     DMA_InitStructure.DMA_Priority = DMA_Priority_VeryHigh;//优先级非常高
  67.     DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;//关闭内存到内存模式
  68.     DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;//循环发送模式
  69.        
  70.                 DMA_InitStructure.DMA_PeripheralBaseAddr = DAC_DHR12R1;//外设地址为DAC通道1的地址
  71.                 DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)SineWave_Value;//波形数据表内存地址
  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);//计算频率
  84.         SineWave_Data(256,SineWave_Value,Um);     //生成输出正弦波的波形表
  85.         SineWave_GPIO_Config();             //初始化io
  86.         SineWave_TIM_Config(f1);            //初始化定时器
  87.         SineWave_DAC_Config();              //配置DAC
  88.         SineWave_DMA_Config();              //配置DMA
  89.         TIM_Cmd(TIM2, ENABLE);             //开启定时器
  90. }
复制代码


波形发生器1.0.7z

184.25 KB, 下载次数: 73, 下载积分: 黑币 -5

回复

使用道具 举报

ID:1 发表于 2019-8-8 22:48 | 显示全部楼层
本帖需要重新编辑补全电路原理图,源码,详细说明与图片即可获得100+黑币(帖子下方有编辑按钮)
回复

使用道具 举报

ID:281113 发表于 2019-10-20 09:07 | 显示全部楼层
值得借鉴
回复

使用道具 举报

ID:782432 发表于 2020-6-17 19:41 | 显示全部楼层
admin 发表于 2019-8-8 22:48
本帖需要重新编辑补全电路原理图,源码,详细说明与图片即可获得100+黑币(帖子下方有编辑按钮)

请问您做出来吗?
回复

使用道具 举报

ID:851922 发表于 2021-1-18 17:35 | 显示全部楼层
请问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);
    }
}
这段程序里的公式怎么理解  谢谢
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表