大佬们的视频里面都提到adc采样速度越慢越精准.最慢是多少
大佬们的视频里面都提到adc采样速度越慢越精准.最慢是多少我的采样不需要速度,哪怕1秒采样一次都行.
我在ISP软件上面设置的最慢的都是7ksps
这已经是最慢了吗?
我在主循环里面是采样一次.
不想让adc太快了怕拖慢cpu,还可以更慢吗?不改变主频的情况下
根据ADC的特性,其采样速度主要由ADC的带宽决定,通常ADC的带宽是固定的,无法无限提高采样速度。例如,大多数ADC型号的带宽为200kHz,这意味着采样速度约为200千赫兹。如果用户设置的软件软件是最慢的,那么7千赫兹可能已经是ADC的最低限制了。如果用户希望进一步降低ADC的采样速度,可以通过调整软件设置,例如使用更慢的采样器配置,但ADC的带宽无法进一步降低。此外,如果用户希望在保持主频的情况下让ADC更慢,那么这在理论上是不可行的,因为ADC的带宽是固定的。
[本文内容由国芯人工智能辅助生成,仅供参考] 国芯人工智能 发表于 2025-6-4 20:18
根据ADC的特性,其采样速度主要由ADC的带宽决定,通常ADC的带宽是固定的,无法无限提高采样速度。例如,大 ...
谢谢,这次回答挺满意的
应该是受带宽影响了
触发一下转换一次
快慢指的是单次转换的时序
最慢就是ADC时序都设置最长时间
只要ADC时序都设置最长时间,并且都是完成上一次转换再触发,那么不受触发频率影响,与触发频率无关
要精度可以多次转换取平均值,可以用DMA也可以不用DMA
要精度可以这样操作,开启16点均值采样,数据12位右对齐,然后软件做16点求和,结果可以当16位数据用,也可以只取高12位相当于256点均值滤波,一般来说已经压榨到ADC的极限精度了,
对于噪声特别大的信号,还可以通过软件进一步增加过采样点数,具体需要实际调试。 “大佬们的视频里面都提到adc采样速度越慢越精准”,这说法不全面,不是绝对的。
ADC里面有模拟比较器,模拟器件都有带宽,其带宽限制了速度,ADC的速度过快,确实会影响精度。
但是当速度低于比较器的带宽,则再降低速度也不会影响精度。
对于STC的8系列、32系列、8051u系列,当MCU工作于5V,ADC时钟为5MHz以下就能保证精度。
除非确实需要很快(比如简易示波器的采样),否则我大部分的应用ADC时钟都是3MHz。
ADC转换的时间由下面的项组成:
//==================== 常规设置=============================================
#define FOSC 24000000UL /* 定义主时钟 */
#define ADC_SPEED3 /* 0~15, ADC时钟 = SYSclk/2/(n+1) */
#define CSSETUP (1<<7) /* 0~1,ADC通道选择时间 0: 1个ADC时钟, 1: 2个ADC时钟,默认0(默认1个ADC时钟) */
#define CSHOLD (1<<5) /* 0~3,ADC通道选择保持时间(n+1)个ADC时钟, 默认1(默认2个ADC时钟) */
#define SMPDUTY 20 /* 10~31, ADC模拟信号采样时间(n+1)个ADC时钟, 默认10(默认11个ADC时钟) */
/* ADC转换时间: 10位ADC固定为10个ADC时钟, 12位ADC固定为12个ADC时钟. */
上面是我常用的速度参数,ADC时钟为 24/2/(3+1) = 3MHz.
10位ADC时钟 = 2+2+21+10 = 35,35/3=11.7us。
12位ADC时钟 = 2+2+21+12 = 37,37/3=12.3us。
//==================== 最慢设置=============================================
如果要设置为最慢,则各个参数都设置为最大值:
#define FOSC 6000000UL /* 定义主时钟 */
#define ADC_SPEED15 /* 0~15, ADC时钟 = SYSclk/2/(n+1) */
#define CSSETUP (1<<7) /* 0~1,ADC通道选择时间 0: 1个ADC时钟, 1: 2个ADC时钟,默认0(默认1个ADC时钟) */
#define CSHOLD (1<<5) /* 0~3,ADC通道选择保持时间(n+1)个ADC时钟, 默认1(默认2个ADC时钟) */
#define SMPDUTY 31 /* 10~31, ADC模拟信号采样时间(n+1)个ADC时钟, 默认10(默认11个ADC时钟) */
/* ADC转换时间: 10位ADC固定为10个ADC时钟, 12位ADC固定为12个ADC时钟. */
ADC时钟为 6/2/(15+1) = 0.1875MHz.
10位ADC时钟 = 2+2+32+10 = 46,46/0.1875=245us。
12位ADC时钟 = 2+2+32+12 = 48,48/0.1875=256us。
//==================== 最快设置=============================================
如果要设置为最快,则各个参数都设置为最小值(但SMPDUTY最小值为9):
#define FOSC 40000000UL /* 定义主时钟 */
#define ADC_SPEED0 /* 0~15, ADC时钟 = SYSclk/2/(n+1) */
#define CSSETUP (0<<7) /* 0~1,ADC通道选择时间 0: 1个ADC时钟, 1: 2个ADC时钟,默认0(默认1个ADC时钟) */
#define CSHOLD (0<<5) /* 0~3,ADC通道选择保持时间(n+1)个ADC时钟, 默认1(默认2个ADC时钟) */
#define SMPDUTY 9 /* 10~31, ADC模拟信号采样时间(n+1)个ADC时钟, 默认10(默认11个ADC时钟) */
/* ADC转换时间: 10位ADC固定为10个ADC时钟, 12位ADC固定为12个ADC时钟. */
ADC时钟为 40/2/(0+1) = 20MHz.
10位ADC时钟 = 1+1+10+10 = 22,22/20=1.1us。
12位ADC时钟 = 1+1+10+12 = 24,24/20=1.2us。
特别提醒:上述ADC转换时间,是在触发ADC转换再过一个ADC时钟后开始的,直到ADC结束的时间,并不包括进中断(如果允许的话)、读取数据、清除标志的时间,所以执行这些操作,还要加上一点时间。如果使用DMA,则能缩短取数时间。
DebugLab 发表于 2025-6-5 00:59
触发一下转换一次
快慢指的是单次转换的时序
最慢就是ADC时序都设置最长时间
懂了,就是说我不管多块的频率。只要我设置触发间隔,不会影响速度 vb2002 发表于 2025-6-5 11:42
懂了,就是说我不管多块的频率。只要我设置触发间隔,不会影响速度
触发间隔跟ADC速度没有直接关系,只要ADC完成后再触发,则你触发频率是100Hz与100KHz都不影响ADC速度。 梁工 发表于 2025-6-5 11:55
触发间隔跟ADC速度没有直接关系,只要ADC完成后再触发,则你触发频率是100Hz与100KHz都不影响ADC速度。 ...
那就没问题了.
不会影响单片机速度就行.
感谢梁工 vb2002 发表于 2025-6-5 13:57
那就没问题了.
不会影响单片机速度就行.
感谢梁工
ADC是硬件外设,启动后在ADC时钟驱动下自动完成,不需要CPU介入,不消耗CPU时间,不会影响单片机的运行速度。
页:
[1]
2