为什么STM32的ADC转换时钟不能大于14MHz

先简单介绍一下ADC:STM32F103 拥有 1~3 个 ADC(STM32F101/102 系列只有 1 个 ADC),这些 ADC 可以独立使用,也可以使用双重模式(提高采样率)。 STM32 的 ADC 是 12 位逐次逼近型的模拟数字转换器。它有 18 个通道,可测量 16 个外部和 2 个内部信号源。各通道的 A/D 转换可以单次、连续、扫描或间断模式执行。 ADC 的结果可以左对齐或右对齐方式存储在 16 位数据寄存器中。 模拟看门狗特性允许应用程序检测输入电压是否超出用户定义的高/低阀值。
 

基础就不讲了吧,CSDN有很多关于基础的文章,但是我没有看到见解为什么ADC的时钟不能超过14MHz的,这里讲解一下:

 

看一个寄存器,这个是设置ADC的采样时间,采样时间:

ADC转换时间的公式:

                                   

 ADC采样时间的最小周期为1.5个周期,加上12.5个周期,那就是最小为14个周期,即总转换时间会大于或等于14个周期

STM32 的 ADC 最大的转换速率为 1Mhz,也就是转换时间为 1us

当选择14MHz的时钟频率作为ADC的时钟频率时;

因为ADC最小转换周期为14个时钟周期,14MHz的时钟,转换时间刚好为1us

而STM32 的 ADC 最大的转换速率为 1Mhz,转换最小时间为 1us,

如果选择大于14MHz的时钟频率作为ADC的时钟频率时,转换时间就会少于1us,所以会降低结果的准确性。

 

 

 

 

 

  • 9
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值