ADC外部RC电路电阻和电容选取计算方法

这篇具有很好参考价值的文章主要介绍了ADC外部RC电路电阻和电容选取计算方法。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

ADC采样过程中遇到的问题

ADC是从模拟到数字世界的桥梁,当前ADC模块基本是MCU的标配,而且在转换速度和精度都有很好的表现,如NXP Kinetis KE15内部有2个16bit SAR型ADC模块(以精度制胜),可以配合EDMA完美实现双ADC的同步采样,STM32G4系列也有2个12bit但速度可达5M的ADC(以速度见长)。

相比很多以前需要MCU+外置ADC应用的场合来说,在成本上具有很大的优势。这些ADC通常都是SAR型(逐次逼近型)的,相比较∑Δ类型的ADC来说通常速度要快很多,但是精度会差些,但已足够满足大部分的应用。然而想要在实际应用中达到标称的精度,仅仅依赖ADC模块本身是不够的,实际的测量精度还会受到诸多外在因素的影响,例如:

  • ADC时间配置(包括采集时间、转换时间、采样时间、采样时钟抖动等等)
  • 电源性能(噪声和内部阻抗)
  • 数据采集系统中数字和模拟部分的隔离情况
  • 内部阻抗与外部阻抗的匹配
  • 输入/输出开关切换的影响
  • PCB布局布线

但是在实际应用中发现,ADC引脚外部的RC电路的电阻和电容的取值对ADC的性能影响比较大,如有客户反馈在ADC采样期间会在ADC输入端观察到严重的电压扰动(电压跌落/电压尖峰),如下图1 所示,从而影响实际采样精度。这种现象在多通道顺序采样,且前后两个连续采样通道信号电压差比较大时,现象会更加明显,因为ADC引脚的RC重新充电需要时间,这种扰动来源于SAR型ADC内部固有的采样电路,是不可避免的。

那既然无法避免,如何采取措施避免这种扰动对ADC采样的影响呢,尽可能的提高ADC的精度呢?答案是选择合适的采样时间和ADC采样引脚RC电路中电阻和电容的值,从原理上讲,其目的是保证在采样时间Taq内,采样电容Csh充分充电,使其两端电压与待测输入电压之间的差值达到一个可接受的范围内(通常在采样时间结束时刻,两者的差值不能超过满量程的 0.5LSB)。NXP AN4373文档对这块进行了深入的探讨,但是文章冗长不好理解,本文档尝试化繁为简先介绍RC值求取的公式理论推导,然后给出具体实例,方便理解。
ADC外部RC电路电阻和电容选取计算方法

理论分析

在一般的采样过程中,我们将采样时间内的待测输入信号当作一个有着恒定电压的直流电压源。通常设计人员会假设该电压源有着很大的内阻(即Rin>>Rsh)。在此假设下,采样电容充电期间将会出现两个明显不同的时间段,如图3所示。图中所绘为采样电容(红色)和输入电容(绿色) 两端的电压波形,其中,采样电容是指外部的电容,输入电容是指ADC内部电容。
ADC外部RC电路电阻和电容选取计算方法ADC外部RC电路电阻和电容选取计算方法

图3所示为输入电容上的初始电压大于采样电容上的初始电压的情况(即Vcin>Vcsh)。此时,输入电容两端的电压将出现电压降落。反之,当Vcin<Vcsh时,输入电容两端的电压将出现电压尖峰。

可以看到,图3中采样电容Csh两端的电压曲线可以划分为两个时间段,高输入阻抗阶段和低输入阻抗阶段,在高输入阻抗的情况下,时间段Ⅱ的曲线变化要比时间段Ⅰ缓慢许多。其中,时间段Ⅰ采样电容充电来自于外部输入电容Cin,时间段Ⅱ采样电容充电来自于外部流过Rin的外部电压输入因而,图2所示的等效电路可以根据时间段的不同划分为两个新的等效电路,如图4 所示。
ADC外部RC电路电阻和电容选取计算方法
ADC外部RC电路电阻和电容选取计算方法

首先,先讨论时间段I内采样电容充电的波形,如上面图5所示。通过一系列公式推导(此处忽略推导过程,详见AN4373),可以得出电压降落/电压尖峰的幅度大小由后面的公式如下:
ADC外部RC电路电阻和电容选取计算方法
其中,α为输入电容和采样电容之比:
ADC外部RC电路电阻和电容选取计算方法
根据以上公式,可以发现输入电容与采样电容的比值越大,产生的电压降落(或电压尖峰)的幅度将越小。接着,讨论时间段II内采样电容充电的波形,其波形如下图6所示,而为了提高精度,我们的目标是保证图7中Vcx在Taq点采样的电压接近于真实值,也就是Vin-Vcx<0.5 LSB。
ADC外部RC电路电阻和电容选取计算方法
ADC外部RC电路电阻和电容选取计算方法
而想要使采样电容两端电压与实际待测电压之间的误差小于0.5LSB,则采样保持开关必须在采样 时间Taq内保持闭合,Taq需要满足:
ADC外部RC电路电阻和电容选取计算方法
另外,如果采样时间Taq已经确定(对于Kinetis,软件可以设置),其它的变量包括Csh、Vfsr都是datasheet决定的,未知的两个变量分别为Cin和Rin,对于Kinetis,通常选择Cin为33pf,则对于设计者来说只需要考虑输入电阻Rin,其计算方法是:
ADC外部RC电路电阻和电容选取计算方法
Note:具体为何是33pF?AN4373文档表述为:参照数据手册8.2节中的建议,每个 ADC 输入端接不小于 33 pF的输入电容和不小于10 Ω 的输入电阻。需要注意的是,这个值是最小的值,实际选取可以适当大一些。通常在选择设计外部RC元件时,我们常常犯这样的错误,希望通过增加输入电阻来降低输入电流,或是实现测量源和ADC之间的阻抗隔离。现在考虑这样的情况,如果增加到10 kΩ,使得在采样时间内不能充分充电,那么采样值也会不准确。所以,对于硬件设计者来说,问题的焦点集中在外部电阻的设计。

实例分析

此处以Kinetis为例(同样使用其他配备SAR型ADC的MCU),ADC时钟为12M,16bit模式,采样时间设置尽可能的小(ADLSMP=0, ADLSTS=3,ADHSC=1),按照以上设置,ADC理论计算的总转换时间约为2.7 μs,采样时间Taq=6xADCK cycle=6x1/12=500ns,其中,为何乘数是6,请参见ADLSTS的配置,理论上可以设置更长,对精度有好处,但会影响速度,需要用户去平衡,本示例是按照最快速度去计算的。
ADC外部RC电路电阻和电容选取计算方法
按照以下公式片刻计算得出合适的Rin,Taq上面得出是500ns,从Kinetis datasheet上可以查到,输入电容Cadin或者Csh最大值为10pF, 数据手册中对Cin输入电容没有限制(数据手册中表述为Cas,选择为33pF,

ADC外部RC电路电阻和电容选取计算方法
ADC外部RC电路电阻和电容选取计算方法
忽略其他的寄生参数, 现在我们得到了计算外部 RC 元件取值所需要的所有参数。

  • Taq=500ns, 取决于软件配置
  • Cin=33pf,取决于经验
  • Csh=10pf,取决于datasheet
  • Vin=3.3V,取决于参考电源
  • Vcsh=0V,求取最差情况,就是连续采集的两个通道差值最大,分别为VCC和GND
  • Vfsr=3.3V,同上
  • N=16,精度

代入公式,可以计算出Rin的最大取值为:
ADC外部RC电路电阻和电容选取计算方法
其中:
ADC外部RC电路电阻和电容选取计算方法
计算的输入电阻最大取值表示我们可以在模拟输入端加上的最大电阻, 同时又不会损失采样的精度。如果选用超过最大取值的电阻,则将导致转换结果的错误。datasheet数据手册中给出的最大取值5kΩ,原因在于,其计算的配置与本例中给出的最大取值因条件不同而不同(数据手册中为 12/13-bit分辨率模式以及更低的ADC 时钟频率)。其电压跌落也能通过公式计算出来。
ADC外部RC电路电阻和电容选取计算方法
如图 11 所示,采样电容的充电过程在500 ns的采样时间内已经完成。因此,可以预见在结果寄存器中能够得到准确的转换结果。ADC0 模块的 DAD0 通道实际结果稳定在 65535(这与理想值的偏差为 0,即没有错误)。
ADC外部RC电路电阻和电容选取计算方法

图12是将输入电阻从 1.1 kΩ 改为 5.1 kΩ 时的电压波形,从图中能明显观察到在 500 ns 的采样时间内,采样电容的充电过程还没有完成。因此, 结果寄存器中的转换结果不可能正确, ADC0模块的 DAD0 通道实际结果在 64750 附近变化。
ADC外部RC电路电阻和电容选取计算方法

总结

  • 在采样时间Taq内,采样电容Csh必须充分充电,使其两端电压与待测输入电压之间的差值达到一个可接受的范围内。通常在采样时间结束时刻,两者的差值不能超过满量程的 0.5LSB。
  • 如果采用了高阻抗的输入电阻(更高的外部元件时间常数),则采样电容Csh将会首先由外部输入电容Cin的能量充电(更低的输入元件时间常数)。采样电容上的充放电过程导致了输入电容Cin两端电压的电压降落(或电压尖峰)。之后采样电容的充电过程由于较高的输入阻抗而变化的缓慢。
  • 因此,外部 RC 元件的取值会从本质上影响ADC转换的精度,为了获得最佳的 ADC 性能,我们需要小心对待并设计外部 RC 元件,在选取采样时间时也必须参考采样电容充电的时间常数。其他需要满足的条件,详见器件的参考手册与数据手册。

示例中计算电阻R是基于33pF电容的,实际使用中,用户还需要对信号和外部可能的干扰信号的频率等综合考虑,但计算公式和选取思路是一样的,即在采样时间Taq内,采样电容Csh必须充分充电。

尽管示例中选取Kinetis MCU作为计算对象,但实际该计算方法也适用于其他的SAR型ADC。

Note:本文所涉及到的参数名字可能和数据手册中的表述有所不同。例如:Rin=Ras(模拟源电阻),Cin=Cas(模拟源电容),Rsh=Radin(输入电阻),Csh=Cadin(采样电容),等式左边为本文所用符号,等式右边为数据手册用到的符号。

参考:痞子衡嵌入式文章来源地址https://www.toymoban.com/news/detail-410401.html

到了这里,关于ADC外部RC电路电阻和电容选取计算方法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 一种电阻电感电容自动识别及阻抗值测量电路

    笔者大学里一个模拟电赛的题目,做完之后闲着没事就传到这,希望和大家学习交流。 摘要 本电路能够实现自动识别电阻电感电容,并对它们的阻抗值进行测量。当分别接入电阻电感电容时,对应的小灯泡会发光,指示使用者查看相应的万用表。电阻测量范围为0.1 - 1k欧姆,

    2024年02月14日
    浏览(38)
  • Buck电路输入电容计算方法详解,再也不用死记硬背!

         在进行DCDC设计的时候,我们根据芯片手册看到的输入电容选择如下图所示,那么到底都是怎么来的呢?                                 Buck 电路中 输入电容纹波电流的有效值计算公式 推导过程如下:     根据上图可以得到如下公式:    根据BUCK电路占空比公式:

    2024年01月21日
    浏览(32)
  • 用STM32单片机ADC+NTC热敏电阻采集温度的设计思路 | 附参考电路

    目录 前言 一、热敏电阻NTC 二、参考电路  三、激励电压选择 记录一些我在工作和学习过程中遇到的问题 NTC:在淘宝随便买的 单片机型号:STM32G030C8T6 目的:用单片机采集NTC温度 本文主要是介绍关于NTC激励电压的选择        热敏电阻 NTC(Negative Temperature Coefficient) , 直

    2024年02月02日
    浏览(35)
  • 从电容充放电公式推导到MOSFET驱动电阻功耗计算

     在之前的文章中写到过电容充放电表达式,式中R表示串联电阻,C表示电容容值,V1表示电源电压,V0表示电容两端初始电压,Vt代表在t时刻电容两端电压。本篇将研究该公式的推导过程及延伸计算。  一.充电公式推导    推导过程中主要用到3个公式:  对以上三个公式求导

    2024年02月07日
    浏览(32)
  • 精密电阻的测量方法:电桥电路,三线制、四线制测量方法

    本节我们讲几个测量电阻的方法。 先了解一下最基本的电桥电路,如下图: 图中R4是待测电阻,一般在调整电路参数时,选择合适的R1、R2、R3,使得: R1/R2 = R3/R4 此时图中电压表的读数近似为0,电桥平衡。 之后,如果R4电阻值发生变化,则两边电压会不相等,电压表示数不

    2024年02月07日
    浏览(41)
  • 51单片机复位电容计算与分析(附带Proteus电路图)

    因为C=dQ/dU=(i x dt)/dU;            =====         i=C  x   (dU/dt). 所以在上电瞬间,U从0变化到U,所以这一瞬间就是通的,然后电压稳定在5V,这个时候这就是一个直流回路,因为dU=0,所以I=0,所以就不通了。 然后来分析一下这个电容的电压到底是能不能达到单片机需要的复位

    2024年02月06日
    浏览(38)
  • 寄生电容/寄生电阻/寄生电感

    寄生电特性: 我们常用的电气元件一般都是根据材料学上各种不同材料的特性,经过计算和塑形或复合而来的。 众所周知,生活中可接触的一切实物的参数在读值的时候都是没有绝对值的,只能是无穷接近,也就是说几乎相当于的概念。 当然,电子元器件的各种参数数值也

    2024年02月11日
    浏览(46)
  • MOS驱动自举电容和限流电阻的选取

    最近做逆变时出现了异常,使用2104驱动MOS管  蓝色为滤波后双端带载时出现的波形,一端带载时没有问题 放大波形后发现输出波形在占空比满值时垮掉,产生严重的震荡   可以看到波形顶部斜向下,我们可以推断是驱动自举电容值偏小,当占空比增大时无法为高端MOS提供足

    2024年02月12日
    浏览(40)
  • HFSS 3D LYAOUT中创建电容,电阻,电感等模型

    关于3D LAYOUT的教程实在是太少了,以下是我自己的一些总结,如有错误请指正。 像是在高速信号方面,经常用到电容AC耦合,那么如何才能在3D LAYOUT创建电容模型呢。 ①先放一个VIA的模型  ,在属性里改成PIN   ②进入padstack界面,编辑为只有TOP层有正方形的焊盘 ③好了以后,

    2024年02月09日
    浏览(74)
  • 【其他-3C数码】电容屏和电阻屏的区别

    工作原理不同 电容屏利用电容原理工作,通过触摸屏上的电容板,可以i感知到人体电荷的变化,从而实现触摸操作。 电阻屏利用电阻原理工作,触摸时需要施加一定的压力,使两个电极之间的电阻发生变化,从而实现触摸操作。 灵敏度不同 电容屏灵敏度更高,可以感知到

    2024年01月16日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包