STM32使用ADC、定时器进行数据采集时的采样率问题

本文详细探讨了STM32F103ZE上使用定时器配合ADC进行数据采集时,采样率不稳定的问题。通过分析代码执行顺序,解释了为何定时器溢出次数计算不准确,并提供了正确的代码实现方式。关键在于理解time变量清零时机对采样率的影响。
摘要由CSDN通过智能技术生成

STM32使用ADC、定时器进行数据采集时的采样率问题

问题描述

在使用STM32进行数据采集的时候,利用定时器确定采样率,但是有时设置不当,会导致采样率与实际不一样。

实验平台

STM32F103ZE

问题解决

如图所示,定时器每溢出一次,time+1,定时器设置为每1ms溢出一次,所以这段代码实际上是将采样率设置为100fps。
但是,如果像下图这样写,实际采样率实测是76.666fps左右。

在这里插入图片描述

究其原因,是time清零的语句应该放在最开始,否则会导致采样率不准确。

在这里插入图片描述

原因分析

如果不在代码最开始将time清零,而是在语句末尾将time清零,那么会出现如下情况。

  1. time第一次等于10之后,先执行一步计算、再执行printf,这时候定时器内部已经开始计数了
  2. 在if语句末尾将time清零,此时定时器内部计数值不是0
  3. 随着time==10的次数增多,在time清零时,定时器计数值会很接近溢出值
  4. 由于定时器计数值接近溢出值,在某一次time==10时,再执行计算语句与printf语句的时候,time就会等于1
  5. time等于1之后,计时器继续计数,然后被清零
  6. 这意味着从这次printf语句到下一次printf语句时间会多于10ms,所以造成采样率不准
  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值