OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 7880|回复: 5

原子哥和各位大侠,我想用DA采集声音信号,好像stm32的DA达不到8k的采样率啊?

[复制链接]

22

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
154
金钱
154
注册时间
2012-11-21
在线时间
0 小时
发表于 2013-3-13 19:20:17 | 显示全部楼层 |阅读模式
1.如何配置DA为8k的采样率呢?
2.还有 如果用定时器可以吗?如果用定时器配置8k的采样率的话怎么配置呢?

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

22

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
154
金钱
154
注册时间
2012-11-21
在线时间
0 小时
 楼主| 发表于 2013-3-13 22:02:51 | 显示全部楼层
回复【楼主位】xiaozi:
---------------------------------
原子哥,帮帮忙
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-3-13 22:21:58 | 显示全部楼层
回复【楼主位】xiaozi:
---------------------------------
DAC的话,你用定时器8Khz的中断,在中断里面改变DAC输出就是了。
DAC最快可以到250K左右。所以8K无压力。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

1

主题

22

帖子

0

精华

初级会员

Rank: 2

积分
53
金钱
53
注册时间
2012-11-21
在线时间
1 小时
发表于 2013-3-14 08:43:47 | 显示全部楼层
DAC输出怎么能叫采样呢?呵呵
回复 支持 反对

使用道具 举报

22

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
154
金钱
154
注册时间
2012-11-21
在线时间
0 小时
 楼主| 发表于 2013-3-15 19:47:42 | 显示全部楼层
回复【4楼】zyw19987:
---------------------------------
哎呦,写错了,是AD
void TIM2_Configuration(void)
{

     NVIC_InitTypeDef NVIC_InitStructure;
       TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
       TIM_DeInit(TIM2);
       TIM_TimeBaseStructure.TIM_Period =29;  
       TIM_TimeBaseStructure.TIM_Prescaler = 29;
       TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1 ;
       TIM_TimeBaseStructure.TIM_RepetitionCounter =10 ;//只有高级定时器才有用
       TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
       RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);
     
       TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);
       
       TIM_ClearFlag(TIM2, TIM_FLAG_Update); //清除更新标志位
    // TIM_ARRPreloadConfig(TIM2, DISABLE);//预装载寄存器的内容被立即传送到影子寄存器                       
       TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE);     
       TIM_Cmd(TIM2, ENABLE);
      
}


void ADC_Configuration(void)
{

ADC_InitTypeDef ADC_InitStructure;
GPIO_InitTypeDef GPIO_InitStructure;
DMA_InitTypeDef DMA_InitStructure;

    //设置AD模拟输入端口为输入 1路AD 规则通道
   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
   GPIO_Init(GPIOA, &GPIO_InitStructure);
/* Enable DMA clock */
    RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);

   /* Enable ADC1 and GPIOC clock */
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 , ENABLE);

   /* DMA channel1 configuration ----------------------------------------------*/
//使能DMA
DMA_DeInit(DMA1_Channel1);
DMA_InitStructure.DMA_PeripheralBaseAddr = ADC1_DR_Address;             //DMA通道1的地址 
DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&ADC_ConvertedValue;             //DMA传送地址
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;             //传送方向
DMA_InitStructure.DMA_BufferSize = 1;             //传送内存大小,100个16位
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;  
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;             //传送内存地址递增
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord; //ADC1转换的数据是16位
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord; //传送的目的地址是16位宽度
DMA_InitStructure.DMA_Mode = DMA_Mode_Circular; //循环
DMA_InitStructure.DMA_Priority = DMA_Priority_High;
DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;
DMA_Init(DMA1_Channel1, &DMA_InitStructure);
    
/* 允许DMA1通道1传输结束中断 */
//DMA_ITConfig(DMA1_Channel1,DMA_IT_TC, ENABLE);
//使能DMA通道1
DMA_Cmd(DMA1_Channel1, ENABLE); 
  
 //ADC配置
  // TIM2_Configuration();
ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; //ADC1工作在独立模式
ADC_InitStructure.ADC_ScanConvMode = ENABLE; //模数转换工作在扫描模式(多通道)还是单次(单通道)模式
ADC_InitStructure.ADC_ContinuousConvMode = DISABLE; //模数转换工作在扫描模式(多通道)还是单次(单通道)模式
ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_T2_CC2;//转换由软件而不是外部触发启动
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;//ADC数据右对齐
ADC_InitStructure.ADC_NbrOfChannel = 1;               //规定了顺序进行规则转换的ADC通道的数目。这个数目的取值范围是1到16
ADC_Init(ADC1, &ADC_InitStructure);

/* ADC1 regular channels configuration [规则模式通道配置]*/ 

//ADC1 规则通道配置
   ADC_RegularChannelConfig(ADC1, ADC_Channel_11, 1, ADC_SampleTime_13Cycles5);   //通道11采样时间 55.5周期
  

//使能ADC1 DMA 
ADC_DMACmd(ADC1, ENABLE);
//使能ADC1
ADC_Cmd(ADC1, ENABLE);

// 初始化ADC1校准寄存器
ADC_ResetCalibration(ADC1);
//检测ADC1校准寄存器初始化是否完成
while(ADC_GetResetCalibrationStatus(ADC1));

//开始校准ADC1
ADC_StartCalibration(ADC1);
//检测是否完成校准
while(ADC_GetCalibrationStatus(ADC1));

//ADC1转换启动
ADC_SoftwareStartConvCmd(ADC1, ENABLE);
//   AD_value=ADC_GetConversionValue(ADC1);
// if(i<5000)
//    converted[i++]=AD_value ;


}

这样配置对吗
回复 支持 反对

使用道具 举报

22

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
154
金钱
154
注册时间
2012-11-21
在线时间
0 小时
 楼主| 发表于 2013-3-15 19:48:24 | 显示全部楼层
回复【3楼】正点原子:
---------------------------------
哎呦,写错了,是AD用定时器触发 8k采样率
void TIM2_Configuration(void)
{

     NVIC_InitTypeDef NVIC_InitStructure;
       TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
       TIM_DeInit(TIM2);
       TIM_TimeBaseStructure.TIM_Period =29;  
       TIM_TimeBaseStructure.TIM_Prescaler = 29;
       TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1 ;
       TIM_TimeBaseStructure.TIM_RepetitionCounter =10 ;//只有高级定时器才有用
       TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
       RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);
     
       TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);
       
       TIM_ClearFlag(TIM2, TIM_FLAG_Update); //清除更新标志位
    // TIM_ARRPreloadConfig(TIM2, DISABLE);//预装载寄存器的内容被立即传送到影子寄存器                       
       TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE);     
       TIM_Cmd(TIM2, ENABLE);
      
}


void ADC_Configuration(void)
{

ADC_InitTypeDef ADC_InitStructure;
GPIO_InitTypeDef GPIO_InitStructure;
DMA_InitTypeDef DMA_InitStructure;

    //设置AD模拟输入端口为输入 1路AD 规则通道
   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
   GPIO_Init(GPIOA, &GPIO_InitStructure);
/* Enable DMA clock */
    RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);

   /* Enable ADC1 and GPIOC clock */
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 , ENABLE);

   /* DMA channel1 configuration ----------------------------------------------*/
//使能DMA
DMA_DeInit(DMA1_Channel1);
DMA_InitStructure.DMA_PeripheralBaseAddr = ADC1_DR_Address;             //DMA通道1的地址 
DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&ADC_ConvertedValue;             //DMA传送地址
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;             //传送方向
DMA_InitStructure.DMA_BufferSize = 1;             //传送内存大小,100个16位
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;  
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;             //传送内存地址递增
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord; //ADC1转换的数据是16位
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord; //传送的目的地址是16位宽度
DMA_InitStructure.DMA_Mode = DMA_Mode_Circular; //循环
DMA_InitStructure.DMA_Priority = DMA_Priority_High;
DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;
DMA_Init(DMA1_Channel1, &DMA_InitStructure);
    
/* 允许DMA1通道1传输结束中断 */
//DMA_ITConfig(DMA1_Channel1,DMA_IT_TC, ENABLE);
//使能DMA通道1
DMA_Cmd(DMA1_Channel1, ENABLE); 
  
 //ADC配置
  // TIM2_Configuration();
ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; //ADC1工作在独立模式
ADC_InitStructure.ADC_ScanConvMode = ENABLE; //模数转换工作在扫描模式(多通道)还是单次(单通道)模式
ADC_InitStructure.ADC_ContinuousConvMode = DISABLE; //模数转换工作在扫描模式(多通道)还是单次(单通道)模式
ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_T2_CC2;//转换由软件而不是外部触发启动
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;//ADC数据右对齐
ADC_InitStructure.ADC_NbrOfChannel = 1;               //规定了顺序进行规则转换的ADC通道的数目。这个数目的取值范围是1到16
ADC_Init(ADC1, &ADC_InitStructure);

/* ADC1 regular channels configuration [规则模式通道配置]*/ 

//ADC1 规则通道配置
   ADC_RegularChannelConfig(ADC1, ADC_Channel_11, 1, ADC_SampleTime_13Cycles5);   //通道11采样时间 55.5周期
  

//使能ADC1 DMA 
ADC_DMACmd(ADC1, ENABLE);
//使能ADC1
ADC_Cmd(ADC1, ENABLE);

// 初始化ADC1校准寄存器
ADC_ResetCalibration(ADC1);
//检测ADC1校准寄存器初始化是否完成
while(ADC_GetResetCalibrationStatus(ADC1));

//开始校准ADC1
ADC_StartCalibration(ADC1);
//检测是否完成校准
while(ADC_GetCalibrationStatus(ADC1));

//ADC1转换启动
ADC_SoftwareStartConvCmd(ADC1, ENABLE);
//   AD_value=ADC_GetConversionValue(ADC1);
// if(i<5000)
//    converted[i++]=AD_value ;


}
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-23 14:02

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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