博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
STM32 ADC 采样 频率的确定
阅读量:4137 次
发布时间:2019-05-25

本文共 2188 字,大约阅读时间需要 7 分钟。

 

 

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 ADCPREADC预分频

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

00PCLK2 2分频后作为ADC时钟

01PCLK2 4分频后作为ADC时钟

10PCLK2 6分频后作为ADC时钟

11PCLK2 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);

 

    

    416.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的采样时间

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

0001.5周期 10041.5周期

0017.5周期 10155.5周期

01013.5周期 11071.5周期

01128.5周期 111239.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

转载地址:http://xqlvi.baihongyu.com/

你可能感兴趣的文章
88. Merge Sorted Array(easy)
查看>>
leetcode刷题191 位1的个数 Number of 1 Bits(简单) Python Java
查看>>
leetcode刷题198 打家劫舍 House Robber(简单) Python Java
查看>>
NG深度学习第一门课作业2 通过一个隐藏层的神经网络来做平面数据的分类
查看>>
leetcode刷题234 回文链表 Palindrome Linked List(简单) Python Java
查看>>
NG深度学习第二门课作业1-1 深度学习的实践
查看>>
Ubuntu下安装Qt
查看>>
Qt札记
查看>>
我的vimrc和gvimrc配置
查看>>
hdu 4280
查看>>
禁止使用类的copy构造函数和赋值操作符
查看>>
C++学习路线
查看>>
私有构造函数
查看>>
组队总结
查看>>
TitledBorder 设置JPanel边框
查看>>
DBCP——开源组件 的使用
查看>>
抓包工具
查看>>
海量数据相似度计算之simhash和海明距离
查看>>
DeepLearning tutorial(5)CNN卷积神经网络应用于人脸识别(详细流程+代码实现)
查看>>
DeepLearning tutorial(6)易用的深度学习框架Keras简介
查看>>