微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > STM32 ADC 采样频率的确定

STM32 ADC 采样频率的确定

时间:11-28 来源:互联网 点击:
(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=66usADC时钟频率为1/66us =15 KHz。

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

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

(2)接下来我们要确定系统时钟:我们 用的是8MHz的外部晶振做时钟源(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.5ADC时钟频率约为9 MHz。

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

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

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

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

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

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top