0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

单片机中ADC采集都存在哪些误差?

jf_pJlTbmA9 来源:jf_pJlTbmA9 作者:jf_pJlTbmA9 2023-09-18 16:31 次阅读

ADC的种类很多,对应的精度和误差也有很多,本文就来讲讲关于ADC精度和误差的内容。

ADC介绍

ADC:Analog Digital Converter,指模数转换,也就是(电压)模拟量转换成数字量。

大多数MCU中都集成了ADC模块,同时ADC也是在产品开发中使用率较高的一个模块,相信大部分人都使用过ADC这个功能。

STM32中内置最多四个高级12位ADC控制器(ADC1、2、3、4)。当然,ADC控制器数量多少取决于STM32型号,还有部分STM32具有16位采样的ADC(如STM32F373)。他们提供自校准功能,用于提高环境条件变化时的ADC精度。

我们平时在使用ADC中要求不是很高,可能就没有在于ADC转换的值是否精确。但是,有些特定场合就需要更精确的转换值,那么我们就需要对ADC做更多了解。下面章节带领大家了解相关内容。

ADC误差

在涉及模数转换的应用中, ADC精度会影响整体的系统质量和效率。为了提高此精度,有必要了解与ADC相关的误差。

ADC误差主要包含:ADC自身和环境导致的误差。

1、ADC自身导致的误差

说误差之前,先说下ADC精度,为便于参考,将精度误差表达为1 LSB的倍数:

1 LSB = VREF+ / 2^12

A、偏移误差

偏移误差是第一次实际转换和第一次理想转换之间的偏离。第一次转换发生在数字ADC输出从0变为1时。理想情况下,当模拟输入介于0.5 LSB和1.5 LSB之间时,数字输出应为1。

仍然是理想情况下,第一次转换发生在0.5 LSB处。用EO表示偏移误差。可通过应用固件轻松校准偏移误差。

正偏移误差的表示方法:

wKgZomUD9RCAanAJAACoJC2Cxro529.jpg

负偏移误差的表示方法:

wKgaomUD9RKAdyrlAACozR1FBNQ977.jpg

B、增益误差

增益误差是最后一次实际转换和最后一次理想转换之间的偏离。增益误差用EG表示。

正增益误差的表示方法:

wKgZomUD9RSAfI6uAACy5k3h0cY998.jpg

负增益误差的表示方法:

wKgaomUD9RWAHgJMAADvP7HnBsc789.jpg

C、微分线性误差

微分线性误差( DLE)为实际步进和理想步进之间的最大偏离。这里的“理想情况”不是指理想传输曲线,而是指ADC分辨率。

理想情况下, 1 LSB的模拟输入电压变化量应导致数字代码变化。如果需要大于1 LSB的模拟输入电压才能导致数字代码变化,将观察到微分线性误差。因此, DLE对应于从一个数字代码变为下一个数字代码所需的最大额外电压。

wKgaomUD9RiAaqB7AADoe5ESd7o793.jpg

D、积分线性误差

积分线性误差为任何实际转换和端点相关线间的最大偏离,用EL表示ILE。

端点相关线可以定义为A/D传输曲线上连接第一次实际转换与最后一次实际转换的线。EL是指与每一次转换的这条线的偏离。因此,端点相关线对应于实际传输曲线并且与理想传输曲线不相关。

wKgaomUD9RmAE9KSAADEcFycu50188.jpg

E、总未调整误差

总未调整误差( TUE)为实际和理想传输曲线间的最大偏离。此参数指定可能发生的会导致理想数字输出与实际数字输出之间最大偏离的总误差。TUE是记录到的任何输入电压的理想预期值与从ADC获得的实际值之间的最大偏离。

wKgZomUD9RuAfxnlAADkWHQv70M980.jpg

2、ADC环境导致的误差

A、参考电压噪声

由于ADC输出为模拟信号电压与参考电压之比,因此模拟参考上的任何噪声都会导致转换后数字值的变化。在某些封装中, VDDA模拟电源被用作参考电压( VREF+),因此VDDA电源的质量会影响ADC误差。

B、参考电压/电源调节

电源调节对于ADC精度十分重要,因为转换结果是模拟输入电压与VREF+值之比。
当连接到VDDA或VREF+时,如果这些输入上的负载及其输出阻抗导致电源输出下降,将在转换结果中产生误差。

C、外部参考电压参数

当使用外部参考电压源( VREF+引脚上)时,该外部参考源有一些重要参数。必须考虑三个参考电压规格:温度漂移、电压噪声和长期稳定性。

D、模拟输入信号噪声

在采样时间内,小而高频率的信号变化可导致较大转换误差。此噪声由电气设备(例如电机、发动机点火、电源线)生成。它增加了不需要的信号,因此会影响源信号(例如传感器)。这样一来,导致ADC转换结果不准确。

E、最大输入信号幅度的ADC动态范围匹配不佳

为获得最高ADC转换精度, ADC动态范围必须与待转换信号的最大幅度相匹配。

我们假设待转换信号在0 V与2.5 V之间变化,并且VREF+等于3.3 V。如下图,有部分未使用的ADC转换范围,也会使转换后信号精度下降。

wKgaomUD9R2AZdEtAAEPKXG9qh8553.jpg

如何提高ADC采集数据准确性

这个问题之前写过相关的内容,只是没有单独提出来说,这里汇总一下。

1、减少ADC相关误差的影响

上面描述了“ADC自身导致的误差”,使用STM32 ADC自校准功能或通过微控制器固件可以轻松补偿偏移误差和增益误差。

之前在分享的代码中有提到,比如通过软件校正:

ADC_StartCalibration(ADC1);

2、使外部环境误差最小化

A、参考电压/电源噪声最小化

也就是在VREF和VDDA引脚连接外部去耦电容。

wKgaomUD9R-AZIiNAAEvgpDER9M825.jpg

B、模拟输入信号噪声消除

通过添加外部RC滤波器以消除高频。

C、将ADC动态范围与最大信号幅度进行匹配

也就是将参考电压范围匹配采样电压(当然,需要有参考电压引脚的芯片才行)。

wKgaomUD9SKARHZsAAHd3FLrqpM912.jpg

同时,也可以使用放大器针对ADC范围调整输入信号范围:

wKgaomUD9SSAQpqeAAGuJOyJ2zg106.jpg

D、温度影响补偿

第一种方法是完整描述偏移和增益漂移特性,并在存储器中提供查询表,以便根据温度变化修正测量值。此校准方法需要额外的成本和时间。

第二种方法包括使用内部温度传感器和ADC看门狗,以在温度变化达到给定值时重新校准ADC。

E、优化PCB布局

将模拟和数字布局分开

隔离模拟和数字电路电源

供电和接地使用单独的PCB层

3、提高精度的软件方法

A、平均采样

·平均会降低速度但可以提高精度

B、数字滤波(抑制DC值中的50/60 Hz噪声)

·设置适当的采样频率(这种情况下,从计时器触发十分有用)。
·对采样数据执行软件后处理(例如,对50 Hz噪声及其谐波抑制进行组合滤波)。

C、AC测量的快速傅里叶变换( FFT)

·此方法可以显示被测信号中的谐波部分。
·由于使用了更强的计算能力,因此速度较慢。

D、ADC校准:偏移、增益、位权重校准

·ADC校准可减少内部ADC误差。但是,必须知道内部ADC结构。

E、使CPU生成的内部噪声最小化

应用设计必须确保

·ADC转换期间来自微控制器的干扰尽可能小。
·使采样和转换期间的数字信号变化量最小化(数字静默)。

审核编辑:彭菁

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 单片机
    +关注

    关注

    6001

    文章

    43973

    浏览量

    620832
  • 控制器
    +关注

    关注

    112

    文章

    15223

    浏览量

    171188
  • adc
    adc
    +关注

    关注

    95

    文章

    5651

    浏览量

    539460
  • 计时器
    +关注

    关注

    1

    文章

    395

    浏览量

    32156
收藏 人收藏

    评论

    相关推荐

    影响单片机ADC转换精度的主要误差

    本篇文章列出了影响模数转换精度的主要误差。这些类型的误差存在于所有模数转换器中,转换质量将取决于它们的消除情况。STM32微控制器数据手册的ADC特性部分规定了这些
    发表于 08-04 10:35 1539次阅读
    影响<b class='flag-5'>单片机</b><b class='flag-5'>ADC</b>转换精度的主要<b class='flag-5'>误差</b>

    单片机ADC指的什么?

    单片机ADC指的什么
    发表于 02-04 06:06

    请问单片机ADC问题

    比如我学习的C8051F330的单片机,有一个ADC模块。然后又很多IO口可以设置为模拟输入,那么明明只有一个ADC模块。为什么可以有多个IO设置为模拟输入。
    发表于 02-17 21:30

    gps的输出数据如何保存在51单片机

    gps的输出数据如何保存在51单片机?求大神教,gps'烧了2个了
    发表于 06-27 04:35

    单片机消除随机误差的方法

    单片机的数据采集系统,测量通道串入随机干扰是难免的,从而使A/D转换送入单片机的数据存在误差
    发表于 07-08 06:08

    单片机adc采样原理

    单片机adc采样原理,关于卡尔曼滤波,看看百度百科上的定义算法的核心思想是,根据当前的仪器"测量值" 和上一刻的 "预测量" 和 "误差"
    发表于 07-14 06:09

    单片机控制AD7766采集ADC信号

    单片机控制AD7766采集ADC信号
    发表于 08-17 06:56

    请问单片机如何控制AD7766采集ADC信号?

    请问单片机如何控制AD7766采集ADC信号?
    发表于 11-18 07:13

    单片机是如何采样ADC值的?

    最近在调按键和电池,和ADC采集有很大关系。那么单片机是如何采样ADC值的呢,每个单片机ADC
    发表于 11-24 07:41

    怎样去解决使用单片机 ADC采集的数值过大的问题

    对电的知识了解太少了。。。遇到问题就不懂。。。采集光电探测器输出电压的大小,使用单片机自带AD采集,最大采集电压5v遇到一个问题,就是我的探测器输出电压明明为4v(使用万用表测量),但
    发表于 12-02 06:49

    如何将ADC采集的数据放在RAM中和从RAM取出再发送给单片机

    如何将ADC采集的数据放在RAM中和从RAM取出再发送给单片机
    发表于 02-17 06:39

    ADC中的增益误差和失调误差的分析

    本技术简介对 ADC 中的增益误差和失调误差进行了简要介绍。它还介绍了一种在带有 Arm® Cortex®-M0+内核的 SAM 系列单片机(MCU)中校准增益
    发表于 04-01 10:14 42次下载
    <b class='flag-5'>ADC</b>中的增益<b class='flag-5'>误差</b>和失调<b class='flag-5'>误差</b>的分析

    观看单片机系统设计第一篇之单片机在哪里的笔记

    一、单片机在哪里?1.1、冰箱里面存在单片机1.2、MP3与单片机1.3、单片机与电磁炉1.4、
    发表于 11-15 19:51 1次下载
    观看<b class='flag-5'>单片机</b>系统设计第一篇之<b class='flag-5'>单片机</b><b class='flag-5'>在哪</b>里的笔记

    关于MCU的ADC采集的理解

    最近在调按键和电池,和ADC采集有很大关系。那么单片机是如何采样ADC值的呢,每个单片机ADC
    发表于 11-16 09:36 79次下载
    关于MCU的<b class='flag-5'>ADC</b><b class='flag-5'>采集</b>的理解

    STM32单片机ADC采集

    STM32单片机ADC采集
    发表于 11-18 20:36 74次下载
    STM32<b class='flag-5'>单片机</b><b class='flag-5'>ADC</b><b class='flag-5'>采集</b>