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

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

3天内不再提示

提高ADC采集精度的办法

5RJg_mcuworld 来源:lq 2019-02-04 11:09 次阅读

想要提高ADC采集精度,软件和硬件工程师都应该了解一下相关的内容!

1写在前面

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做更多了解。下面章节带领大家了解相关内容。

2

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表示偏移误差。可通过应用固件轻松校准偏移误差。

正偏移误差的表示方法:

负偏移误差的表示方法:

B.增益误差

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

正增益误差的表示方法:

负增益误差的表示方法:

C.微分线性误差

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

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

D.积分线性误差

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

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

E.总未调整误差

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

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转换范围,也会使转换后信号精度下降。

3

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

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

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

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

之前在分享的代码中有提到,比如:ADC_StartCalibration(ADC1);

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

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

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

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

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

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

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

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

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转换期间来自微控制器的干扰尽可能小。

·使采样和转换期间的数字信号变化量最小化(数字静默)。

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

    关注

    146

    文章

    16013

    浏览量

    343574
  • 控制器
    +关注

    关注

    112

    文章

    15217

    浏览量

    171156
  • 模数转换
    +关注

    关注

    1

    文章

    205

    浏览量

    36090

原文标题:想提高ADC采集精度,你有办法吗?

文章出处:【微信号:mcuworld,微信公众号:嵌入式资讯精选】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    如何提高AT32 MCU ADC转换精度

    AT32的微控制器内置最多三个高级12位片上SAR模拟数字转换器(ADC)并提供自校准功能,用于提高环境条件变化时的ADC精度。在涉及模数转换的应用中,
    发表于 10-24 12:04 2391次阅读

    ADC精度采集

    ADC
    橙群微电子
    发布于 :2023年02月24日 09:37:18

    过采样提高ADC精度

    本帖最后由 eehome 于 2013-1-5 09:55 编辑 过采样提高ADC精度
    发表于 08-15 16:23

    提高STM32ADC精度

    提高STM32ADC精度
    发表于 08-27 13:58

    请问有什么办法可以提高tms320f2812精度的吗?

    本帖最后由 一只耳朵怪 于 2018-6-11 14:23 编辑 最近在用2812的AD进行模拟信号的采集,2812数据表上写着AD是十二位的,但是我采集同一电平怎么后3位数据一直在跳动?有什么好的办法
    发表于 06-11 08:36

    STM8S ADC采集精度不够有什么解决办法吗?

    10K电阻接到IO口上的,10位ADC精度0.003V,显示精度别人都是做到0.01的精度,我期望表头能显示到0.001的精度,有什么
    发表于 11-20 11:21

    如何提高STM8S ADC采集精度

    是直接10K电阻接到IO口上的,10位ADC精度0.003V,显示精度别人都是做到0.01的精度,我期望表头能显示到0.001的精度,有什么
    发表于 11-27 17:03

    请问如何提高数据采集系统的精度

    我是一枚在荷兰电子信息工程专业留学生,我的同学外国同学正在做一项实习设计,他想请教一些问题。设计内容:提高数据采集系统的精度和改善其延时问题。该系统为传感器→抗混淆滤波器→ADC→FP
    发表于 05-24 06:25

    有什么办法可以提高脉冲S参数的精度?

    脉冲S参数测量是什么?有什么办法可以提高脉冲S参数的精度?
    发表于 04-13 06:37

    ADC误差的产生以及如何提高ADC精度

    ,用过STM32 ADC的人是不是想到了参考手册中关于12位ADC转换时间的公式:ST官方就如何保障或改善ADC精度写了一篇应用笔记AN2834。该应用笔记旨在帮助用户了解
    发表于 07-09 07:30

    查看ADC转化时间采集精度

    文章目录系统时间查看ADC转化时间采集精度提高稳定性示例代码系统时间查看ADC挂在APB2上,对应的时钟为PCLK2,由系统时钟SYSCLK
    发表于 08-04 07:26

    如何提高AT32的ADC转换精度

    本帖最后由 李佳昕70 于 2022-3-7 20:38 编辑 如何提高AT32的ADC转换精度1概述AT32的微控制器内置最多三个高级12位片上SAR模拟数字转换器(ADC)并
    发表于 09-26 19:12

    如何提高AT32的ADC转换精度

    如何提高AT32的ADC转换精度设计者在使用AT32芯片ADC模块时,提供注意事项和软、硬件的设计建议。
    发表于 10-24 07:36

    ADC的各种指标如何理解如何提高ADC转换精度

    在此我们简要总结一下ADC的各种指标如何理解,以及从硬件到软件都有哪些可以采用的手段来提高ADC的转换精度
    发表于 03-18 01:16 26次下载
    <b class='flag-5'>ADC</b>的各种指标如何理解如何<b class='flag-5'>提高</b><b class='flag-5'>ADC</b>转换<b class='flag-5'>精度</b>

    AN059 提高ADC采样精度的方法

    AN059 提高ADC采样精度的方法
    发表于 03-01 18:50 14次下载
    AN059 <b class='flag-5'>提高</b><b class='flag-5'>ADC</b>采样<b class='flag-5'>精度</b>的方法