
1.什么是过采样 过采样技术是一种以牺牲采样速度来提高ADC分辨率的技术。部分STM32单片机是支持硬件过采样的,如STM32G0系列。通过过采样,可以将12位的ADC提升到16位,非常实用。* h p$ d9 r1 q' \7 {+ M+ O ) m. d0 |/ P* f# v$ o4 Q ![]() 根据过采样技术,每提高1位ADC分辨率,需要增加4倍的采样率。也就是说1次采样是12Bit,4次是13Bit,16次是14Bit,64次是15Bit,256次是16Bit,如果要更高分辨率,那么STM32的硬件过采样就无能为力了。7 Q& Q! n5 z0 t+ L" B ~3 z7 p/ s 过采样主要通过配置ADC_SMPR寄存器的下面几位即可实现,配置移位位数、过采样倍数以及使能位。如下: / d; u3 V1 ^: z" V+ Y6 Q ![]() 1 b- n5 Q- k: O 最大可配置为256倍过采样,实现16位分辨率。当采用256倍过采样时,得到的结果是20位的,但ADC_DR寄存器是16位的,所以此时必须右移4位才行。如下图:* {! u( w% y& J5 C5 `7 y4 |( |/ P . r9 A# {5 G/ u5 L9 x5 ~1 @ ![]() ! J2 Q: o+ V) n. l' [( @9 |! e 2.STM32CubeMX配置 ADC配置如下,使能了一个通道,打开DMA和连续采样。使能过采样,右移4位,256倍过采样。这样就可以直接当作16位ADC来用了。 7 s( Z5 Q# y7 d9 a- B% @9 ] ![]() 生成代码后,输入2.5V的电压,进行采样测试,程序如下:
采样结果如下,可以看到,有最大4个字的跳动。当然这也跟硬件的布局布线等设计有关系。测试使用的开发板,效果不是特别好,但过采样对于提升分辨率还是有用的。$ y) A% V* k6 v4 _$ `$ k : C+ ] S! I# E! F V% V ![]() 如果再对结果进去求平均值,可以进一步提升分辨率,结果如下,基本上只有1个字的跳动。 ![]() ———————————————— 版权声明:天外飞仙CUG 如有侵权请联系删除2 [6 ~- c0 R4 b e % c4 F8 }- o o5 U! x. [3 f( Z$ m @: b. W: M+ ]* a$ w, g' u" Z |
基于STM32使用ADC的多通道采样经验分享
基于STM32利用ADC+DMA采样显示经验分享
基于STM32的ADC+DMA采样与板载运放跟随经验分享
基于STM32F407和Cubemx的ADC采集+DMA传输实现简易示波器经验分享
基于STM32CubeMX实现ADC的经验分享
基于STM32的ADC+DMA采样与板载运放跟随经验分享
基于STM32双定时器+ADC+DMA实战经验分享
基于STM32的定时器触发ADC时可能遇到的情形
基于STM32的ADC片内信号经验分享
基于STM32U5 ADC+DMA配置经验分享