vb2002 发表于 2025-6-4 20:17:05

大佬们的视频里面都提到adc采样速度越慢越精准.最慢是多少

大佬们的视频里面都提到adc采样速度越慢越精准.最慢是多少

我的采样不需要速度,哪怕1秒采样一次都行.
我在ISP软件上面设置的最慢的都是7ksps
这已经是最慢了吗?
我在主循环里面是采样一次.
不想让adc太快了怕拖慢cpu,还可以更慢吗?不改变主频的情况下


国芯人工智能 发表于 2025-6-4 20:18:00

根据ADC的特性,其采样速度主要由ADC的带宽决定,通常ADC的带宽是固定的,无法无限提高采样速度。例如,大多数ADC型号的带宽为200kHz,这意味着采样速度约为200千赫兹。如果用户设置的软件软件是最慢的,那么7千赫兹可能已经是ADC的最低限制了。如果用户希望进一步降低ADC的采样速度,可以通过调整软件设置,例如使用更慢的采样器配置,但ADC的带宽无法进一步降低。此外,如果用户希望在保持主频的情况下让ADC更慢,那么这在理论上是不可行的,因为ADC的带宽是固定的。

[本文内容由国芯人工智能辅助生成,仅供参考]

vb2002 发表于 2025-6-4 21:39:36

国芯人工智能 发表于 2025-6-4 20:18
根据ADC的特性,其采样速度主要由ADC的带宽决定,通常ADC的带宽是固定的,无法无限提高采样速度。例如,大 ...

谢谢,这次回答挺满意的
应该是受带宽影响了

DebugLab 发表于 2025-6-5 00:59:49

触发一下转换一次
快慢指的是单次转换的时序
最慢就是ADC时序都设置最长时间
只要ADC时序都设置最长时间,并且都是完成上一次转换再触发,那么不受触发频率影响,与触发频率无关
要精度可以多次转换取平均值,可以用DMA也可以不用DMA








晓飛飛 发表于 2025-6-5 10:46:23

要精度可以这样操作,开启16点均值采样,数据12位右对齐,然后软件做16点求和,结果可以当16位数据用,也可以只取高12位相当于256点均值滤波,一般来说已经压榨到ADC的极限精度了,
对于噪声特别大的信号,还可以通过软件进一步增加过采样点数,具体需要实际调试。

梁工 发表于 2025-6-5 10:48:04

“大佬们的视频里面都提到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,则能缩短取数时间。

vb2002 发表于 2025-6-5 11:42:21

DebugLab 发表于 2025-6-5 00:59
触发一下转换一次
快慢指的是单次转换的时序
最慢就是ADC时序都设置最长时间


懂了,就是说我不管多块的频率。只要我设置触发间隔,不会影响速度

梁工 发表于 2025-6-5 11:55:19

vb2002 发表于 2025-6-5 11:42
懂了,就是说我不管多块的频率。只要我设置触发间隔,不会影响速度

触发间隔跟ADC速度没有直接关系,只要ADC完成后再触发,则你触发频率是100Hz与100KHz都不影响ADC速度。

vb2002 发表于 2025-6-5 13:57:43

梁工 发表于 2025-6-5 11:55
触发间隔跟ADC速度没有直接关系,只要ADC完成后再触发,则你触发频率是100Hz与100KHz都不影响ADC速度。 ...

那就没问题了.
不会影响单片机速度就行.
感谢梁工

梁工 发表于 2025-6-5 14:46:18

vb2002 发表于 2025-6-5 13:57
那就没问题了.
不会影响单片机速度就行.
感谢梁工

ADC是硬件外设,启动后在ADC时钟驱动下自动完成,不需要CPU介入,不消耗CPU时间,不会影响单片机的运行速度。
页: [1] 2
查看完整版本: 大佬们的视频里面都提到adc采样速度越慢越精准.最慢是多少