您好,欢迎访问三七文档
当前位置:首页 > 电子/通信 > 综合/其它 > STM32-ADC采样频率的确定
STM32ADC采样频率的确定1.先看一些资料,确定一下ADC的时钟:(1)、由时钟控制器提供的ADCCLK时钟和PCLK2(APB2时钟)同步。CLK控制器为ADC时钟提供一个专用的可编程预分频器。(2)、一般情况下在程序中将PCLK2时钟设为与系统时钟相同RCC_HCLKConfig(RCC_SYSCLK_Div1);RCC_PCLK2Config(RCC_HCLK_Div1);RCC_PCLK1Config(RCC_HCLK_Div2);(3)、在时钟配置寄存器(RCC_CFGR)中有为ADC时钟提供一个专用的可编程预分器。位15:14ADCPRE:ADC预分频由软件设置来确定ADC时钟频率00:PCLK22分频后作为ADC时钟01:PCLK24分频后作为ADC时钟10:PCLK26分频后作为ADC时钟11:PCLK28分频后作为ADC时钟我们可对其进行设置例如:RCC_ADCCLKConfig(RCC_PCLK2_Div4);另外ADC时钟使能设置:RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1|RCC_APB2Periph_ADC2|RCC_APB2Periph_GPIOC,ENABLE);(4)、可编程的通道采样时间ADC使用若干个ADC_CLK周期对输入电压采样,采样周期数目可以通过ADC_SMPR1和ADC_SMPR2寄存器中的SMP[2:0]位而更改。每个通道可以以不同的时间采样。总转换时间如下计算:TCONV=采样时间+12.5个周期例如:当ADCCLK=14MHz和1.5周期的采样时间TCONV=1.5+12.5=14周期=1μsSMPx[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=100usADC可编程的通道采样时间我们选最小的1.5周期,则ADC采样周期一周期大小为100us/1.5=66us。ADC时钟频率为1/66us=15KHz。ADC可编程的通道采样时间我们选71.5周期,则ADC采样周期一周期大小为(100us/71.5)。ADC时钟频率为7.15MHz。(2)接下来我们要确定系统时钟:我们用的是8MHz的外部晶振做时钟源(HSE),估计得经过PLL倍频PLL倍频系数分别为2的整数倍,最大72MHz。为了提高数据计算效率,我们把系统时钟定为72MHz,(PLL9倍频)。则PCLK2=72MHz,PCLK1=36MHz;我们通过设置时钟配置寄存器(RCC_CFGR)中有为ADC时钟提供一个专用的可编程预分器,将PCLK28分频后作为ADC的时钟,则可知ADC时钟频率为9MHz。从手册可知:ADC转换时间:STM32F103xx增强型产品:ADC时钟为56MHz时为1μs(ADC时钟为72MHz为1.17μs)(3)由以上分析可知:不太对应,我们重新对以上中内容调整,提出如下两套方案:方案一:我们的输入信号是50Hz(周期为20ms),初步定为1周期2500个采样点,(注:一周期最少采20个点,即采样率最少为1k),每2个采样为20ms/2500=8usADC可编程的通道采样时间我们选71.5周期,则ADC采样周期一周期大小为8us/71.5。ADC时钟频率约为9MHz。将PCLK2进行8分频后作为ADC的时钟,则可知ADC时钟频率为9MHz。方案二:我们的输入信号是50Hz(周期为20ms),初步定为1周期1000个采样点,(注:一周期最少采20个点,即采样率最少为1k),每2个采样点间隔为20ms/1000=20usADC可编程的通道采样时间我们选239.5周期,则ADC采样周期一周期大小为20us/239.5。ADC时钟频率约为12MHz。将PCLK2进行6分频后作为ADC的时钟,则可知ADC时钟频率为12MHz。
本文标题:STM32-ADC采样频率的确定
链接地址:https://www.777doc.com/doc-4643353 .html