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

📄 14kcal.c

📁 TI公司的CCS一些常用的函数库
💻 C
字号:
////////////////////////////////////////////////////////////////////////////
////        (C) Copyright 1996,2003 Custom Computer Services            ////
//// This source code may only be used by licensed users of the CCS C   ////
//// compiler.  This source code may only be distributed to other       ////
//// licensed users of the CCS C compiler.  No other use, reproduction  ////
//// or distribution is permitted without written permission.           ////
//// Derivative programs created using this software in object code     ////
//// form are not restricted in any way.                                ////
////////////////////////////////////////////////////////////////////////////

enum ADC_SOURCE {an0, an1, an2, an3, bandgap, srefh, srefl, itemp, refa,
                                    refb, an4, an5, an6, an7};

float READ_FLOAT_CAL(int n)
{
   int i;
   float data;

   for (i = 0; i < 4; i++)
     *(&data + i) = READ_CALIBRATION(i + n);
   return(data);
}

float READ_CALIBRATED_AD(ADC_SOURCE ch)
{
   #bit TEMP_SENSOR_OFF = 0x8F.1

   float Nch, Noff, Nbg;
   static int const_loaded = 0;
   static float Kref, Kbg, Vtherm, Ktc;

   if (ch == itemp)
      TEMP_SENSOR_OFF = 0;

   if (!const_loaded)
   {
      Kref = READ_FLOAT_CAL(0);
      Kbg = READ_FLOAT_CAL(4);
      Vtherm = READ_FLOAT_CAL(8);
      Ktc = READ_FLOAT_CAL(12);
      const_loaded = 1;
   }

   set_adc_channel(ch);
   Nch = (float)read_adc();

   if (Nch < 0.0)
      Nch += 65536.0;

   Noff = 0.0;
   set_adc_channel(srefh);
   Noff -= Kref*(float)read_adc();

   set_adc_channel(srefl);
   Noff += (1 + Kref)*(float)read_adc();

   set_adc_channel(bandgap);
   Nbg = (float)read_adc() - Noff;

   Nch = Kbg*(Nch - Noff)/Nbg;

   if (ch == itemp)
      Nch = (Nch - Vtherm)/Ktc + 25.0;

   return(Nch);
}

⌨️ 快捷键说明

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