单片机ADC为何漂?采样窗怎么定?
ADC 数值缓慢漂移时,问题未必在传感器,也未必靠平均就能消掉。单片机内部转换器如果没有满足采样保持和参考回流条件,软件读到的只是前端妥协后的电压。
采样窗首先要服从输入源阻抗。多数片上 ADC 前端都有开关和采样电容,转换前必须在很短时间内把这只电容充到目标电平附近。若前级来自高阻分压、热敏电阻桥或带大电阻滤波的传感器,采样窗太短就会来不及稳定,结果看上去像零点偏移或量程压缩。多通道轮询时更明显,前一个高电压通道残留在采样电容上的电荷会影响下一路低电平读数,首样偏差往往比后续样本大。此时继续增加软件平均,只会把结构性误差平均得更平滑。
解决这类问题要先让前端能驱动采样电容。可以延长采样周期、降低源阻抗、增加缓冲运放,或者在高低电平跨度大的通道之间插入虚采样。前端 RC 滤波也要重新核算:电阻太大虽然能限流降噪,却会拉长恢复时间;电容太大又可能让运放在瞬态负载下振铃。单片机数据手册里的最大源阻抗通常对应特定 ADC 时钟和分辨率,换了采样频率或温度范围后,不能直接照搬。
参考电压和地回流则决定读数基准会不会跟着负载走。ADC 参考脚、模拟地、数字地和大电流驱动若共用一段铜皮,PWM 翻转、继电器吸合或通信收发器突发电流都会在公共阻抗上制造压降。对数字口来说这只是几毫伏地弹跳,对 12 位或更高分辨率的 ADC 却已经足以改变多个码值。若参考源去耦离引脚太远,参考点还会被转换瞬间的电荷脉冲调制,漂移就会与采样节拍同步。参考电容的等效串联电感和回流过孔位置也会改变尖峰幅度,不能只按容量判断,也要看布局闭环和地线距离。
守住参考并不等于机械地切开所有地。更可靠的做法是让传感器回流、参考源、ADC 去耦和主控模拟脚形成短小闭环,再在明确位置与系统地汇合。远端传感器最好成对回流,避免把激励电流和测量参考挤在同一根细线里。若板上同时有电机、蜂鸣器或开关电源,还应让它们的脉冲回流远离参考岛。单片机板卡若把模拟参考当成普通供电脚处理,后期校准常常只能补掉静态误差,补不掉随负载变化的漂移。
验证时要把通道顺序、采样窗长度、负载开关相位和参考电压波形一起扫。把输入短到参考中点、改动通道前后顺序,再观察偏差是否随顺序改变,可以快速区分采样保持残留和参考回流污染。还应在最高采样率和最低源电压下复测,因为这时开关电荷注入和缓冲器输出摆幅最容易接近边界,温度变化还会改变输入开关电阻。若只在室温慢速下校准,量产后会把动态误差误写进补偿表。只有把这两类误差分开,后续是改采样时间、改前端阻抗还是改地回路,才不会靠猜。
所以,ADC 精度先取决于采样瞬间的电荷是否到位,再取决于参考点是否安静。把采样窗和回流路径算清楚,转换结果才有资格进入算法。





