TMS320F2812的AD及其精度校准.docVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
TMS320F2812的AD及其精度校准.doc

TMS320F2812内部集成了ADC转换模块,该模块具有如下的功能: 1.12位ADC核,内置了双采样-保持器(S/H); 2.顺序采样模式或者同步采样模式; 3.模拟输入:0V~3V; 4.快速转换时间运行在25MHz,ADC时钟,或12.5MSPS; 5.16通道,多路选择输入; 6.自动序列化,在单一时间段内最大能提供16个自动A/D转换,每个转换可编程对16个输入通道中的任何一个进行选择。 7.序列发生器可按2个独立的8状态序列发生器或1个16状态序列发生器。 我们在项目实际研发过程中采用的AD采样的硬件电路如下图所示: 图1为电流信号检测与调理电路,电压信号的检测与调理电路与此相类似。从电流传感器输出的信号CT1首先经过了由R1、C1组成的低通滤波电路,滤除高频干扰信号,然后通过U1构成的电压跟随器,实现了电路前后两级的隔离。由于2812的I/O口输入电平必须低于3.3V,因此在芯片引脚的输入前端加了一个稳压管Z1,使AD口输入的电压幅值不超过3V。 TMS320F2812虽然有12位精度,但在实际的使用过程中,我们发现,ADC的转换结果误差较大,如果直接将此转换结果用于控制回路,必然会降低控制精度,最大的转换误差可以达到9%。那么如何来提高AD采样的精度呢,下面列出了几种常见的方法: 1.硬件角度 (1)硬件滤波,滤除干扰信号; (2)电路板布线时需要注意不要让ADCINxx引脚运行在靠近数字信号通路的地方,这样能使耦合到ADC输入端的数字信号开关噪声大大降低; (3)采用适当的隔离技术,将ADC模块电源引脚和数字电源隔离; (4)如果采样电路部分是经过多路开关切换的,可以在多路开关输出上接下拉电阻到地; (5)采样通道上的电容效应也可能会导致AD采样误差,因为采样通道上的等效电容可能还在保持有上一个采样数据的数值的时候,就对当前数据进行采样,会造成当前数据不准确。如果条件允许,可以在每次转化完成后现将输入切换到参考地,然后在对信号进行下一次采样。 2.软件角度 (1)多次采样取平均值算法,最为简单; (2)数字滤波算法,例如采用中值滤波法,具体方法为:连续采样20个数据,对这些数据进行排序之后,去掉最小的5个和最大的5个,然后取中间10个采样数据的平均值。 (3)软件校正算法。F2812的ADC转换精度较差的主要原因是存在增益误差(Gain Error)和偏置误差(Offset Error),要提高转换精度就必须对两种误差进行补偿,下面将具体介绍这种实用的补偿方法。 理想的12位ADC应该是没有增益误差和偏置误差的,因此其转换的计算公式为: Y=x*mi 其中,x=input count=inputvoltage*4095/3.0V Y=output count Mi=ideal gain=1 但是,实际上F2812的AD是存在增益误差和偏置误差的,其转换的计算公式如式2所示: Y=x*ma+mb 其中,ma=actual gain B=actualoffset (与输入为0时相关) 实际的和理想的转换计算曲线如图2所示: 在校正的时候,首先选用ADC的任意两个通道(例如A1,A2)作为参考输入通道,并分别 输入已知的直流参考电压,通过读取相应的结果寄存器获取转换值,利用两组输出值便可求 得ADC模块得校正增益和校正偏置,然后利用这两个值对其他通道转换数据进行补偿。 首先,计算两个通道得参考电压转换后得理想结果。在讲述算法之前,我们先来看看各个参数之间的关系,如下图所示: 由图可以得到各参数之间的关系如下: y = x * ma + b ma = (yH – yL)/(xH – xL) b = yL – xL*ma CalGain = (xH – xL)/(yH – yL) CalOffset = yL * CalGain – xL x = y * CalGain – CalOffset 给A1通道加2.5V,给A2通道加0.5V。 A1input=VHigh=2.5V,则2.5*4095/3.0=3413(理想值) A2input=VLow=0.5V,则0.5*4095/3.0=683(理想值) 校正C语言的算法如下: #defineHIGH_IDEAL_COUNT 3413//理想高值 #defineLOW_IDEAL_COUNT 683//理想低值 #define SAMPLES20//采样次数 //定义所需的各个变量 Uint16Avg_HighActualCount; Uint16Avg_LowActualCount; Uint16Sum_HighActualCount; Uint16Sum_LowActualCount; Uint16 CalGain; Uint16CalOf

文档评论(0)

天马行空 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档