⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tms320f2812 dsp编程之ad采样精度的校准算法.txt

📁 TMS320F2812 DSP编程之AD采样精度的校准算法
💻 TXT
字号:
TMS320F2812 DSP编程之AD采样精度的校准算法  没有公告

                        加入收藏
                        设为首页
                        联系站长



       . 网站首页 . 新闻 . 新品 . 方案 . 专访 . 活动 . DSP . EDA . 评测 . 技术文库 . 会员区 . 商城 . 服务导航 
      . 邮购 . 资源 . 
      | DSP首页 | DaVinci文章 | C6000文章 | C5000文章 | C3000文章 | C2000文章 | ADI DSP | 
      MOTO DSP | FAQ | 代码示例 | 电路应用 | 

            您现在的位置: 61IC中国电子在线 >> DSP >> C2000文章 >> C28X系列 >> 文章正文




             TMS320F2812 DSP编程之AD采样精度的校准算法          ★★★【字体:小 大】

      TMS320F2812 DSP编程之AD采样精度的校准算法

      作者:Free    文章来源:本站原创    点击数:329    更新时间:2008-2-21    

      F2812内部集成了ADC转换模块。该模块是一个12位、具有流水线结构的模数转换器,内置双采样保持器(S/H),可多路选择16通道输入,快速转换时间运行在25 
      MHz、ADC时钟或12.5 
      Msps,16个转换结果寄存器可工作于连续自动排序模式或启动/停止模式。在实际使用中,ADC的转换结果误差较大,如果直接将此转换结果用于控制回路,必然会降低控制精度。(最大转换误差可以达到9%左右)
       
      F2812的ADC转换精度较差的主要原因是存在增益误差和失调误差,要提高转换精度就必须对两种误差进行补偿。
       
      对于ADC模块采取了如下方法对其进行校正:
       
      选用ADC的任意两个通道(如A3,A4)作为参考输入通道,并分别提供给它们已知的直流参考电压作为输入(RefHigh和RefLow),通过读取相应的结果寄存器获取转换值,利用两组输入输出值求得ADC模块的校正增益和校正失调,然后利用这两个值对其他通道的转换数据进行补偿,从而提高了ADC模块转换的准确度。
      实现校准的硬件电路在本文中不作描述,在有关资料中可以查到。下面是该算法的C语言实现:
      //首先计算两个通道的参考电压转换后的理想结果
       //     A4 = RefHigh = 2.5V  ( 2.5*4095/3.0 = 3413 ideal count)
      //     A3 = RefLow  = 0.5V  ( 0.5*4095/3.0 = 683 ideal count)
       
      #define     REF_HIGH_IDEAL_COUNT   3413
      #define     REF_LOW_IDEAL_COUNT    683
      #define  SAMPLES       63
      //定义所需的各个变量
      Uint16  Avg_RefHighActualCount;  
      Uint16  Avg_RefLowActualCount; /   
      Uint16  CalGain;                                                 // 
      Calibration Gain     
      Uint16  CalOffset;                                              // 
      Calibration Offset 
      Uint16  SampleCount;
      Uint16 RefHighActualCount;
      Uint16 RefLowActualCount;
      //对各个变量进行初始化
      void InitCalib()
      {
          Avg_RefLowActualCount = 0;
          Avg_RefLowActualCount  = 0;
          Avg_RefHighActualCount = 0;
          RefHighActualCount = 0;
          RefLowActualCount = 0;
          
          CalGain   = 0; 
          CalOffset = 0;
          
          SampleCount = 0;
      }
      //获得校准增益和校准失调
      // Algorithm: Calibration formula used is:
      //
      //  ch(n) = ADCRESULTn*CalGain - CalOffset    
      // n = 0 to 15 channels
      //  CalGain =   (RefHighIdealCount - RefLowIdealCount)
      //                       -----------------------------------------
      //                      (Avg_RefHighActualCount  - Avg_RefLowActualCount)
      //
      //  CalOffset = Avg_RefLowActualCount*CalGain - RefLowIdealCount
      //
      //  A running weighted average is calculated for the reference inputs:
      //
      //  Avg_RefHighActualCount = (Avg_RefHighActualCount*SAMPLES 
      //                            + RefHighActualCount) / (SAMPLES+1)
      //
      //  Avg_RefLowActualCount  = (Avg_RefLowActualCount*SAMPLES 
      //                                         + RefLowActualCount) / 
      (SAMPLES+1)
      //     
      void GetCalibParam()
      {
       RefHighActualCount = AdcRegs.ADCRESULT4 >>4;
       RefLowActualCount = AdcRegs.ADCRESULT3 >>4;
       
       if(SampleCount > SAMPLES)
        SampleCount = SAMPLES;
       
       Avg_RefHighActualCount = (Avg_RefHighActualCount * SampleCount
               + RefHighActualCount) / (SampleCount+1);
       
       Avg_RefLowActualCount  = (Avg_RefLowActualCount * SampleCount 
                                    + RefLowActualCount) / (SampleCount+1);
       
       CalGain = (REF_HIGH_IDEAL_COUNT - REF_LOW_IDEAL_COUNT) 
                              / (Avg_RefHighActualCount  - 
      Avg_RefLowActualCount);
       
       CalOffset = Avg_RefLowActualCount*CalGain - RefLowIdealCount;
       
       SampleCount++;
       
      }
       //在ADC_ISR中,对其他各个通道的结果进行修正:
      interrupt void  adc_isr(void)
      {
      GetCalibParam();
      ......
      newResult n= AdcRegs.ADCRESULTn*CalGain - CalOffset;
      ......
       }
      通过上面的代码,配合硬件电路改动,可以大幅实现提高ADC采样的精度,实现更灵敏、更精确的控制。
                     欢迎点击进入:TI德州中文网   (国内唯一针对TI应用的中文技术网站)    文章录入:admin    
      责任编辑:admin 
      上一篇文章: 基于DSP的无速度传感器直接转矩控制系统设计

      下一篇文章: 没有了

      【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口】

      最新热点最新推荐相关文章
       TMS320C3x源码/范例
       [组图]基于TLV320AIC23和T…
       RGB,YUV的来历及其相互转…
       [组图]基于DM642的网络视觉…
       DSP中内部Flash的应用研究
       [图文]智能视频监控系统及…
       [组图]F28335:DSK28335-I…
       [图文]F28335:DSK28335-I…
       [组图]AVS编码和DSP实现的…
       [组图]定点DSP C55X实现浮…
       TMS320C3x源码/范例
       [组图]XDS510 DSP系列仿真…
       [图文]JTAG口与仿真器连接…
       [图文]TMS320VC5410硬件连…
       [图文]采用ADuC834的口0与…
       [图文]AD73360与TMS320VC5…
       [图文]DSP5402和MAX3110硬…
       [图文]主从模式的TLC320AC…
       [组图]DSP2407全系列开发板…
       [组图]DSP器件的现场可编程…
      TMS320F2812的SPWM原程序
      基于LabVIEW和TMS320F2812的…
      TMS320F2812的CAN调试成功经…
      基于TMS320F2812和μC/OS II…
      TMS320F2812 全局汇编函数
      TMS320F2812 CMD 文件各段含…
      基于TMS320F2812集中供电系统…
      TMS320F2812的CMD文件配置详…
      基于TMS320F2812的多轴伺服控…
      利用TMS320F2812 DSP&DRV592…


        网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!) 
          没有任何评论

      | 设为首页 | 加入收藏 | 联系站长 | 友情链接 | 版权申明 | 网站公告 | 管理登录 | 
             站长:61IC 湘ICP备05002478号 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -