STM32_ADC采样时间_采样周期_采样频率计算方法分析

发布者:LogicLeaper最新更新时间:2023-10-17 来源: elecfans关键字:STM32  ADC  采样时间  采样周期  采样频率 手机看文章 扫描二维码
随时随地手机看文章

  因项目需要使用到STM32的ADC功能,虽然对ADC的使用并不陌生,但是第一接触stm32的ADC功能还是有种无从下手的感觉,主要是因为STM32ADC设计较为复杂,一时对相关的专业术语较为生疏,此外固件库中涉及到的函数虽都进行了分门别类但是还是感觉函数较多,难以很快掌握,现就将个人理解写出,以便大家共同进步。


  一、stm32 ADC特点

  认识事物首先还是要从整体上把握,ADC也一样的道理,STM32的ADC外设提供了非常完善的功能,虽然其中很大一部分不见得能在项目中使用,但加深对其的认识对于合理利用其资源也是非常有必要的。


  下面以项目采用的STM32L151为例,其他类型大同小异。

  先看原文:

  • 12-bit, 10-bit, 8-bit or 6-bit configurable resolution

  • Interrupt generation at the end of regular conversions, end of injected conversions, and in case of analog watchdog or overrun events (for regular conversions)

  //在规则转换结束、注入转换结束以及模拟看门狗溢出和overrun事件(规则转换模式)发生时能产生中断

  • Single and continuous conversion modes //有单次和连续转换模式

  • Scan mode for automatic conversions in a fully programmable order //在自动转换中支持完成可编程的扫描模式

  • Programmable data alignment with in-built data coherency //数据对齐方式可编程

  • Programmable and individual sampling time for each ADC channel //可以为每个通道设置独立的采样时间

  • External trigger option with configurable edge detection for both regular and injected

  conversions //外部触发模式对规则和注入转换模式均支持可配置的边沿触发方式

  • Discontinuous mode //非连续模式

  • ADC conversion time: 1 μs at full speed (ADC clocked at 16 MHz) down to 4 μs at low speed (ADC clocked at 4 MHz), independent of the APB clock//最低采样时间

  • Automatic power-up/power-down to reduce the power consumption//自动的上下电便于节能

  • ADC supply requirements:

  – 2.4 V to 3.6 V at full speed or with reference zooming (VREF+ 《 VDDA)

  – down to 1.8 V at slower speeds //工作电压范围

  • ADC input range: VREF– ≤ VIN ≤ VREF+

  • Automatic programmable hardware delay insertion between conversions

  • DMA request generation during regular channel conversion //规则转换支持DMA

  从官方的描述中可以了解到STM32ADC所提供的强大功能,及一些工作特性,那么如何才能使用这些功能呢?

  ADC转换就是输入模拟的信号量,单片机转换成数字量。读取数字量必须等转换完成后,完成一个通道的读取叫做采样周期。采样周期一般来说=转换时间+读取时间

  转换时间=采样时间+12.5个时钟周期。采样时间是你通过寄存器告诉STM32采样模拟量的时间,设置越长越精确。

  二、STM32 ADC采样频率时间、周期、计算方法分析

  1. :先看一些资料,确定一下ADC的时钟:

  (1),由时钟控制器提供的ADCCLK时钟和PCLK2(APB2时钟)同步。CLK控制器为ADC时钟提供一个专用的可编程预分频器

  (2) 一般情况下在程序 中将 PCLK2 时钟设为 与系统时钟 相同

  /* HCLK = SYSCLK */

  RCC_HCLKConfig(RCC_SYSCLK_Div1);

  /* PCLK2 = HCLK */

  RCC_PCLK2Config(RCC_HCLK_Div1);

  /* PCLK1 = HCLK/2 */

  RCC_PCLK1Config(RCC_HCLK_Div2);

  (3)在时钟配置寄存器(RCC_CFGR) 中 有 为ADC时钟提供一个专用的可编程预分器

  位15:14 ADCPRE:ADC预分频

  由软件设置来确定ADC时钟频率

  00:PCLK2 2分频后作为ADC时钟

  01:PCLK2 4分频后作为ADC时钟

  10:PCLK2 6分频后作为ADC时钟

  11:PCLK2 8分频后作为ADC时钟

  我们可对其进行设置 例如:

  /* ADCCLK = PCLK2/4 */

  RCC_ADCCLKConfig(RCC_PCLK2_Div4);

  另外 还有 ADC 时钟使能设置

  /* Enable ADC1, ADC2 and GPIOC clock */

  RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 | RCC_APB2Periph_ADC2 |

  RCC_APB2Periph_GPIOC, ENABLE);

  (4)16.7 可编程的通道采样时间

  ADC 使用若干个ADC_CLK 周期对输入电压采样,采样周期数目可以通过ADC_SMPR1和ADC_SMPR2寄存器中的SMP[2:0]位而更改。每个通道可以以不同的时间采样。

  总转换时间如下计算:

  TCONV(转换时间) = 采样时间+ 12.5 个周期

  例如:

  当ADCCLK=14MHz 和 1.5周期的采样时间:

  TCONV = 1.5 + 12.5 = 14周期= 1μs

  SMPx[2:0]:选择通道x的采样时间

  这些位用于独立地选择每个通道的采样时间。在采样周期中通道选择位必须保持不变。

  000:1.5周期100:41.5周期

  001:7.5周期101:55.5周期

  010:13.5周期110:71.5周期

  011:28.5周期111:239.5周期

  注:

  – ADC1的模拟输入通道16和通道17在芯片内部分别连到了温度传感器和VREFINT。

  – ADC2的模拟输入通道16和通道17在芯片内部连到了VSS。

  2. 具体分析如下:

  (1)我们的输入信号是50Hz (周期为20ms),初步定为1周期200个采样点,(注:一周期最少采20个点,即采样率最少为1k) ,每2个 采样点间隔为 20ms /200 = 100 us

  ADC可编程的通道采样时间 我们选最小的 1.5 周期,则 ADC采样周期一周期大小为

  100us /1.5=66us 。 ADC 时钟频率为 1/66us =15 KHz。

  ADC可编程的通道采样时间 我们选71.5 周期,则 ADC采样周期一周期大小为

  (100us /71.5) 。 ADC 时钟频率为 7.15MHz。

  (2)接下来我们要确定系统时钟:我们 用的是 8M Hz 的外部晶振做时钟源(HSE),估计得 经过 PLL倍频 PLL 倍频系数分别为2的整数倍,最大72 MHz。为了 提高数据 计算效率,我们把系统时钟定为72MHz,(PLL 9倍频)。则PCLK2=72MHz,PCLK1=36MHz;

  我们通过设置时钟配置寄存器(RCC_CFGR) 中 有 为ADC时钟提供一个专用的可编程预分器,将PCLK2 8 分频后作为ADC 的时钟,则可知ADC 时钟频率为 9MHz

  从手册可知: ADC 转换时间:

  STM32F103xx增强型产品:ADC时钟为56MHz时为1μs(ADC时钟为72MHz为1.17μs)

  (3)由以上分析可知:不太对应,我们重新对以上中 内容调整,提出如下两套方案:

  方案一:我们的输入信号是50Hz (周期为20ms),初步定为1周期2500个采样点,(注:一周期最少采20个点,即采样率最少为1k) ,每2个 采样点间隔为 20ms /2500 = 8 us

  ADC可编程的通道采样时间 我们选71.5周期,则 ADC采样周期一周期大小为

  8us /71.5 。 ADC时钟频率约为 9 MHz。

  将PCLK2 8 分频后作为ADC 的时钟,则可知ADC 时钟频率为 9MHz

  方案二:我们的输入信号是50Hz (周期为20ms),初步定为1周期1000个采样点,(注:一周期最少采20个点,即采样率最少为1k) ,每2个 采样点间隔为 20ms /1000= 20 us

  ADC可编程的通道采样时间 我们选239.5周期,则 ADC采样周期一周期大小为

  20us /239.5 。 ADC时钟频率约为 12 MHz。

  将PCLK2 6 分频后作为ADC 的时钟,则可知ADC 时钟频率为 12MHz


关键字:STM32  ADC  采样时间  采样周期  采样频率 引用地址:STM32_ADC采样时间_采样周期_采样频率计算方法分析

上一篇:STM32单片机的串口波特率计算方法
下一篇:STM32F103C8T6实现直流电机速度PID控制

推荐阅读最新更新时间:2024-11-07 14:41

请问ADC是如何在电动汽车充电器中实现高精度计量系统的?
电动汽车 (EV) 充电行业正在快速增长。随着消费者、行业和政府要求使用更环保、更可持续的交通工具,电动汽车充电基础设施必须更加高效和便捷。 与直流充电器不同,交流充电器不使用堆叠式电源模块,因此结构更紧凑,成本更低。其单一的电源模块架构限制了它们在公共充电站的使用,因为它们无法在合理的时间范围内提供所需的电量。相反,其 22kW 的充电速度更适合充电时间更久的家用场景。它们受欢迎的另一个原因是,有些交流充电器只需要一个标准插座。交流充电器利用电动汽车的车载充电装置将交流电转换为直流电。 直流充电器中的堆叠式电源模块可加快充电速度至 360kW 以上。堆叠式电源模块缩短了总充电时间,但增大了充电器的尺寸,更适合公共充电站而
[嵌入式]
请问<font color='red'>ADC</font>是如何在电动汽车充电器中实现高精度计量系统的?
stm32---usart1与电脑通信
usart.h #ifndef _USART_H_ #define _USART_H_ #include stm32f10x.h #include stdio.h //发送一个字节 void GPIO1_Configuration(void); void USART1_Configuration(unsigned long baund); int fputc(int ch, FILE *f); #endif usart.c #include usart.h #include string.h //重定义fputc(); //printf( hello world ); int fpu
[单片机]
STM32电机矢量控制】记录8——ADC三电阻采样
ADC的基本原理: ADC,Analog-to-Digital Converter的缩写,指模/数转换器或者模数转换器。是指将连续变化的模拟信号转换为离散的数字信号的器件。 与之相对应的DAC,Digital-to-Analog Converter,它是ADC模数转换的逆向过程。 STM32中的ADC: 12位ADC是一种逐次逼近型模拟数字转换器。它有多达18个通道,可测量16个外部和2个内部信号源。各通道的A/D转换可以单次、连续、扫描或间断模式执行。ADC的结果可以左对齐或右对齐方式存储在16位数据寄存器中。 ADC的通道概念: 有16个多路通道。可以把转换组织成两组:规则组和注入组。在任意多个通道上
[单片机]
【<font color='red'>STM32</font>电机矢量控制】记录8——<font color='red'>ADC</font>三电阻<font color='red'>采样</font>
关于STM32中管脚复用的使用方法
在STM32的数据手册的管脚分配图中可以看到:PC14与OSC32_IN公用一个引脚,PC15与OSC32_OUT公用一个引脚,管脚配置如图1、图2、图3所示。它们的使用方法如下: 当LSE(低速外部时钟信号)开启时,这两个公用管脚的功能是OSC32_IN和OSC32_OUT。 当LSE(低速外部时钟信号)关闭时这两个公用管脚的功能是PC14和PC15。 备用区域控制寄存器(RCC_BDCR)的LSEON用于控制LSE的开启或关闭。关于这个寄存器的用法请参看《STM3210x技术参考手册》。 图1 STM32 LQFP48封装引脚图 图2 STM32 LQFP64封装引脚图 图3 STM32 LQFP100封装
[单片机]
关于<font color='red'>STM32</font>中管脚复用的使用方法
stm32 i2c通信 [操作寄存器+库函数]
I2C总线是由NXP(原PHILIPS)公司设计,有十分简洁的物理层定义,其特性如下: 只要求两条总线线路:一条串行数据线SDA,一条串行时钟线SCL; 每个连接到总线的器件都可以通过唯一的地址和一直存在的简单的主机/从机关系软件设定地址,主机可以作为主机发送器或主机接收器; 它是一个真正的多主机总线,如果两个或更多主机同时初始化,数据传输可以通过冲突检测和仲裁防止数据被破坏; 串行的8 位双向数据传输位速率在标准模式下可达100kbit/s,快速模式下可达400kbit/s,高速模式下可达3.4Mbit/s; 连接到相同总线的IC 数量只受到总线的最大电容400pF 限制。 其典型的接口连线如下: I2C的协议
[单片机]
<font color='red'>stm32</font> i2c通信 [操作寄存器+库函数]
STM32的中断优先级设定
在STM32的手册里没有提到关于设置中断优先级的情况,只列给出了中断向量表。根据该向量表可以创建一个中断编号的枚举数据,方便设置优先级及使能等的使用。 先说一下如何设置优先级。 优先级的设置在Cortex-CM3中:异常 - 优先级定义 中有描述;针对优先级的寄存器描述需要查看Cortex-M3编程手册。 可在此处下载手册:http://download.csdn.net/detail/gao_xyz/9780686 1、优先级组的设置 在权威指南 优先级定义中有描述,其优先级由:抢占优先级 和 子优先级组成。 此处需注意:抢占优先级,顾名思义,可以抢占CPU的,当有更高的抢占优先级时,可打断低抢占优先级的
[单片机]
<font color='red'>STM32</font>的中断优先级设定
STM32:Step1工具安装
工具安装及首次测试 目标描述 教授如何安装STM32编程的主要工具: STM32CubeMX,一种用于设置和图形化编程所有 STM32 板和产品的工具 STM32CubeIDE,用于开发 STM32 软件的免费 IDE STM32CubeProg,一种在STM32内存中加载/监视软件的工具 STM32CubeL4,带有嵌入式示例的STM32L4 MCU软件包 完成本教程后,您应该能够打开 STM32 专业生态系统。 您还应该设法将应用程序从生态系统带到 NUCLEO 板上。 最后,您将能够在调试模式下运行闪烁的 LED 示例。 先决条件 装有 Windows 7(或更高版本)的计算机 安装Java 网络访问 硬件 NUCLEO-L
[单片机]
<font color='red'>STM32</font>:Step1工具安装
.\Obj\STM32-LD3320.axf: Error: L6200E: Symbol sRecog multiply defined
用Keil编译STM32时提示:.ObjSTM32-LD3320.axf: Error: L6200E: Symbol sRecog multiply defined (by ld3320_main.o and main.o). 解决办法:把相应的东西放在.c文件中就行,不要放在.h头文件中,如果别的地方要用到可以用extern声明。
[单片机]
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved