OpenEdv-开源电子网

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

关于提高STM32F4AD的采样率

[复制链接]

4

主题

17

帖子

0

精华

新手上路

积分
21
金钱
21
注册时间
2019-6-4
在线时间
16 小时
发表于 2019-7-24 17:00:15 | 显示全部楼层 |阅读模式
5金钱
给三个AD开启了各自的DMA数据流和中断,每个AD都是独立模式,通过定时器中断来控制三个AD轮流采样
结果发现定时器重装载值的时间设的比较小时(例如5us触发一次),实际的采样速度却大大折扣,是因为定时器中断的算法浪费了太多时间吗


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

使用道具 举报

31

主题

2183

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
14424
金钱
14424
注册时间
2018-8-3
在线时间
1157 小时
发表于 2019-7-24 19:40:55 | 显示全部楼层
可以试下使用三重ADC对同一个通道交替采集
回复

使用道具 举报

51

主题

2166

帖子

2

精华

论坛元老

Rank: 8Rank: 8

积分
10653
金钱
10653
注册时间
2017-4-14
在线时间
2780 小时
发表于 2019-7-24 21:31:12 | 显示全部楼层
f103是这样的  f4应该差不对   

RCC_PCLK2_Div6 72m/6=12m  转换时间=[采样时间+ 12.5个周期(固定值)]/12m =(239.5+12.5)/12m=21us
RCC_PCLK2_Div6 72m/6=12m  转换时间=[采样时间+ 12.5个周期(固定值)]/12m =(1.5+12.5)/12m=1.16us
回复

使用道具 举报

4

主题

17

帖子

0

精华

新手上路

积分
21
金钱
21
注册时间
2019-6-4
在线时间
16 小时
 楼主| 发表于 2019-7-24 21:45:45 | 显示全部楼层
翼行园子 发表于 2019-7-24 19:40
可以试下使用三重ADC对同一个通道交替采集

之前试过三重ADC模式,理论上有8.4M采样率,但是实际测出来只有4.2M,而且只能通过ADC_CommonInitStructure.ADC_TwoSamplingDelay = ADC_TwoSamplingDelay_5Cycles;这句话来控制采样率,感觉这种方式不能随心所欲地控制AD的采样率,就试了一下用定时器,刚刚把定时器的中断程序换成了寄存器版本,虽然快了一点,但是最高也只能到1M多
回复

使用道具 举报

4

主题

17

帖子

0

精华

新手上路

积分
21
金钱
21
注册时间
2019-6-4
在线时间
16 小时
 楼主| 发表于 2019-7-24 21:49:44 | 显示全部楼层
本帖最后由 Geez 于 2019-7-25 09:51 编辑

小白上路,附上我的程序
按下KEY1会开启一次TIM2,测量32次之后关闭定时器,并通过DMA存储数据,然后用串口发送到电脑,32*重装载值*分频/84M是一次测量的时间

21.三ADC+DMA可控 - 寄存器.zip

5.59 MB, 下载次数: 9

回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-10 18:09

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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