如何提高单片机ADC的精度?.docx
ADC(模数转帙)是我们常用的一种器件,特别是众多模拟传感器的采集就需要用ADC,以至于市面上大部分单片机都集成了ADC这种外设.在描述如何ADC精度之前,我们先来简单的J'解一下ADC,ADC(AnaIog-to-Digita1.Converter的缩写)意思是模数,+换器。是指将连续变化的模拟信号转换为离散的数字信号的器件.班实世界的模拟信号,例如温度、压力、声音或者图像等,需要转换成更容易存储、处理和传送的数字形式。ADC(模/数转换器)可以实现这个功能,在各种不同的产品中可以找到它的身影.与之相对应的是DAC(DigitaI-to-Ana1.ogConverter的缩写).遨思是数模转换器,它是ADC模数转换的逆变换“接下来看一下我们常说的ADC精度到底是指什么呢?提到一颗MCU的ADC精度,大家首先想到的是多少位,比如10位、12位。其实准确来说,10位、12位是分辨率,并非精度.ADC的精度和分辨率是两个不同的概念。精度是指转换后所得结果相对与实际值的准硬度:分辨率是指转换器所能分辨的模拟信号的最小变化值,一般来讲,分辨率越高,转换误差越小;但影晌精度的因素较多,分辨率很高的ADC,可晶并不一定具有很高的精度。所以,在实际应用中,更应该关注的是精度这个参数“另外,AD转换结果的精度除了ADC模块本身性能的影响,还受其他因素的影响,比如外部环境温度的变化、内部ADC参考电压等。以瑞萨RA2A1中24位Sigma-De1.taADC为例,我们可以通过RA2A1硬件手册和Sigma-De1.taADC性能文档得到以下ADC精度参数。Tf47.49ProgfmmabgaintfnerumnUtionamptf*fMdiQm-<S>UAjDcrt*(2)CondAXAVOC/WCO-VCC127toSSV.*5MaMOAVXSI-OVThetr<h>c<Acm>4eMMre-1.v11tModeeVICrrMIOodi«v«4vm<1.&三1MKt<>C*R三0V,uMmote*w*!<eh*<MPSramtcSbe4T»pUaaUnATFc«n<SO0rt<SIgrtoFtoMKO,>.Jv10三ov加K»IMCsSfi(cn1O5R91M<c*.05«,心乡6“心KZMutenRAto-',«,>*-OKZ82S(S<11=1,C11*,0R=2MtoC1.S<CT1.<C11"OW194T4<s<ct<Mn三1O5R2M.*teen>c<1.mMeMeTMCfMiK1.erates<pg刖KncMsetfcV224-MAOWmeUrvWe<mJhk*1.SNR"MHADmi>Z,atoIo09SoaIUngP1.TSH)OtVMto9rwMHUw«*6Enc>tewnewatwutaQ<aA*2W<V<o>>tOG11>t3*t*4*Xc<Wr*yc*4to*4ueto(>EwfEaOH«Emr(toeX>toft>Aa4rwwt.SahMn"ratedSw1M4137tortfweOtmtw*«wnMc«BU“dy(MPUk*3HaiPradMC1.aMntajMnVAarwitMdbyWdngnanAchMadwwtcnParameterUESJTypUnitTestConditionsEffecbvenumbrofbitsfin83HzENOB121bitG«n-1,Gt21.PGACnpGAAvE1:0OOborO1.bOSR-64137OSR三12814.3OSR256147OSR三512149OSR三102415.2OSR三204811.7bitGser8,G«n-4.PGACnPGAAVE1:0OOborO1.bOSRW12.6OSR三12813.2OSR25613.6OSR-512140OSR三102414.3OSR2048EffcbvRetoIuCionENOB(RMS)141bitGseTi1,GseT2三1.PGACnPGAAVE(1:0«OObor01b.VtMM1.6VOSR=6415.6OSR三12816.3OSR三25616.8OSR51217.3OSR三102417.8OSR204813.6bitGe8.G«t24.PGACCPGAAvEn:0OObor01b.V1.a0.05VOSR-64145OSR三12815.0OSR256155OSR«512160OSR«102416.4OSR三2048在实际ADC应用中,用户十分关注精度这个指标,所以本篇文章从以卜6个方面出发,来介绍提高ADC精度的方法1采用差分输入降低输入的共模干扰模拟输入可以是中端输入或是差分输入。差分输入尤其适用于要求精度在12位或以上的设计,这种输入方式能消除输入线路上可能存在的共模噪声.一些A/D转换器具有伪差分输入.在伪差分配置下,两个引脚(VIN+和VIN-)用作输入信号线。伪差分输入与标准差分输入的区别在于:VIN-引脚上的信号只能相对TVSS电源轨的电压偏离一个很小的范围.虽然这种限制要求此类A/D转换涔必须与单端信号源连接,但它的输入级仍然具有消除输入引脚上微小的共模波动的能力.2采用高精度稳定电源供给成少电源电压变化误差一般MCU中的ADC可以使用内部参考电压或者外部参考电压,可以从数据手册中/解内部参考电压的误差。以RX23E-A中24位Sigma-De1.taADC的内部参考电压源为例,其误差范用如卜.表:Tab1.e8.SBIASDriftCharacteristicsEva1.uationResu1.tC<x1.ibons:VCC-AVCCO-AVCCI-2.7Vto5.5V.VSS-AVSSO-AVSS1-OV.Ta-40Xto105*C,SDADCSTCtVREFSE1.-O.ConnectthSB1.ASMRE曰pintoAVSSIpinbya022F(-20%to20%).ParameterSymbo1.yp,Max2UnitTestConditionsSBIASdftdEsevs18.789.1PPmrCSBIAS=0.8V16.6790SBIAS-1.0V14.873.4SBIAS=1.2V14.269.4SBIAS=1.4V132666SBAS16V12.664.7SBIAS=1.8V12.1636SBIAS«20V11.9627SBIAS«22VNoieSB1.ASd11t!isCa1.cUotedAIMaX(SIASe11or<T(-40*0toT(125X>)-Mm(SBIASeoc(T<-4<rC>toT(125X>)<125C-(-4(rC>)No1.esIAverage±12Average15在实际应用中,基准电压是提供ADC转换时的参考电压,是保证转换精度的基本条件。在要求较高精度时,基准电压要考虑单独用高精度稳定电源供给。此外,外加模拟电源和数字电源也要尽量采用稳定性高(电源电压敏感度<0.002%),受温度变化小的电源.请根据实际情况进行评估,是否选用更高精度并且稳定的外部参考电压,从而提高精度。3如果PGA可调增益系数一般是越小噪声越低ADC内部的PGA增益越大,本身PGA的噪声会增加,另外ADC输入噪声被放大的越多。所以ADC内部增益越大,有效位数越小。还是以RX23E-A中24(Sigma-De1.taADC的精度特性指标为例,在测试条件一致的情况下,PGA增益越大,有效位数的值越小。ParameterSymbo1.TypUnitTestCondmonsEffcbvnumber”bits«83HzENOB121137-14.3bitG»n«1.PGACnPGAAVEtO«OObOf01bOSR«64OSR,128OSR2514.7149152OSR-512OSR三1024OSR三2X8117c三8,Gscn三4,PGACnPGAAVEt000b<xO1.bOSR=64126OSR三12813213.614.014.3OSR三2OSR712OSR1024OSR2(M8但是这点需要注意,使用ADC时一般推荐最好用到满址程,此时ADC精度不浪费。在实际应用中,需要权衡这两点,从而达到更好的精度。4通过软件源波算法改善测,的果在采样过程中,导致采样电压波动的因素有很多.可能是由于外界的随机信号干扰引起。也可能是由于电路中产生的谐波信号引起的周期性干扰信号。用软件漉波方法则可以有效减小此类误差。常用漉波算法如下: 算术平均谑波法 递推平均浊波法(又称激动平均谑波法) 中值沙波法 一阶滞后浊波法 加权平均造波法使用ADC模块自带的平均功能某些MCU的ADC模块具有平均功能,比如RX23E-A的24位Sigma-De1.taADC模块就自带平均功能,可以从8、16、32或者64中选择想要平均的数据个数,详细内容请参看下表。A1DCcnversionavergmgOto<OrIhe唠TOgm9operationNg的IeetaWe- AvwangnotPCdonned- Avec>1196<<fxmed.endaADconversione<jS1.eCn<t$9÷nef1.0d*ev«<yAOconvomon- AEwMg«sperformedandaAD8<v帕c*oendn<<<tsgeneratedwf*<thebmw*<ajotorodTbennbe<<MaiobeavmoedBMIeCtaMperChMwI(8.16.32.or64)但是需要注意的是,使用模块自带的平均功能,将会延长得到转换结果的时间,所以需要按照用户要求进行评估。6改善ADC电路和PCB布线为了使ADC达到最佳的性能,我们需要正确地设计和配置整个系统。在硬件方面,可进行以下配置,例如: 在芯片电源弓I脚间放词0.1UF的电容,电容应尽可能施贴近芯片封装(每对电源引脚间放置一个电容) PC8走线长度应该尽砧短 在实际应用设计中应充分考虑PCB走线上寄生参数的影响 必须小心处理模拟电源以及参考引脚,使它们的噪声幅度减小 针对数字部分和根拟部分使用不同的供电电源和地平面如果数字部分和模拟部分连接到了相同的供电电源.则应该在数字部分和模拟部分之间使用个小的电那或避珠进行连接使用地平面构有噪声的数字元件与模拟元件隔离开来,走线时用模拟地符模拟信号包国起来外部RC元件的取值会从本质上影响ADC转换的精度,为了获得最佳的ADC性能,我们需要小心对待并设计外部RC元件,在选取采样时间时也必须参考采样电容充电的时间常数因此,在使用ADC时,除了前期选型注意精度要求以外,在实际调试时注意以上6个方面的内容,也可以在一定程度上提高转换精度。