NTC(3950K ,100k Ohms at 25deg. C)程序的实现

/*------------------------------------------------------
  TEMPERATURE VS RESISTANCE TABLE
  Resistance                    100k Ohms at 25deg. C
  Resistance Tolerance          +/- 1%
  B Value                       3950K at 25/50deg. C
  B Value Tolerance             +/- 1%
------------------------------------------------------*/
#include "bsp_ntc.h"

#include "sysparam.h"

#define      N                  191                    //NTC温度对应阻值个数,即ntc[]数组大小 


const static float ntc[N]=
{ 
    //-20℃  //-19    //-18    //-17    //-16    //-15    //-14    //-13    //-12    //-11
    975.8038,920.5962,868.8615,820.3603,774.8710,732.1889,692.1238,654.4999,619.1540,585.9346,    
    //-10℃  //-9     //-8     //-7     //-6     //-5     //-4     //-3     //-2     //-1    
    554.7016,525.3245,497.6821,471.6621,447.1599,424.0781,402.3264,381.8204,362.4818,344.2375,    
    //0℃    //1      //2      //3      //4      //5      //6      //7      //8      //9
    327.0195,310.7640,295.4121,280.9084,267.2014,254.2428,241.9877,230.3940,219.4224,209.0361,    
    //10℃   //11     //12     //13     //14     //15     //16     //17     //18     //19    
    199.2007,189.8841,181.0559,172.6881,164.7540,157.2290,150.0898,143.3144,136.8825,130.7749, 
    //20℃   //21     //22     //23     //24     //25     //26     //27     //28     //29    
    124.9734,119.4612,114.2223,109.2417,104.5053,100.0000,95.7132, 91.6333, 87.7492, 84.0505,    
    //30℃   //31     //32     //33     //34     //35     //36     //37     //38     //39
    80.5274, 77.1707, 73.9717, 70.9222, 68.0144, 65.2411, 62.5954, 60.0707, 57.6610, 55.3604,        
    //40℃   //41     //42     //43     //44     //45     //46     //47     //48     //49
    53.1635, 51.0651, 49.0602, 47.1443, 45.3130, 43.5621, 41.8878, 40.2862, 38.7539, 37.2876,   
    //50℃   //51     //52     //53     //54     //55     //56     //57     //58     //59
    35.8842, 34.5405, 33.2538, 32.0214, 30.8408, 29.7096, 28.6253, 27.5860, 26.5895, 25.6338,   
    //60℃   //61     //62     //63     //64     //65     //66     //67     //68     //69 
    24.7171, 23.8376, 22.9937, 22.1836, 21.4061, 20.6594, 19.9424, 19.2537, 18.5920, 17.9562,    
    //70℃   //71     //72     //73     //74     //75     //76     //77     //78     //79
    17.3452, 16.7578, 16.1930, 15.6499, 15.1276, 14.6251, 14.1417, 13.6764,13.2286, 12.7976,    
    //80℃   //81     //82     //83     //84     //85     //86     //87     //88     //89
    12.3825, 11.9828, 11.5978, 11.2270, 10.8697, 10.5254, 10.1935, 9.8736, 9.5652,  9.2678,    
    //90℃   //91     //92     //93     //94     //95     //96     //97     //98     //99
    8.9809,  8.7042,  8.4373,  8.1797,  7.9312, 7.6912,   7.4596,  7.2360, 7.0201,  6.8115,        
    //100℃  //101    //102    //103    //104    //105    //106    //107    //108    //109
    6.6101,  6.4155, 6.2274,  6.0457,   5.8701,  5.7003,  5.5362,  5.3775,  5.2240, 5.0755,                                      
    //110℃  //111    //112    //113    //114    //115    //116    //117    //118    //119 
    4.9319,  4.7930, 4.6586,  4.5285,   4.4026,  4.2807,  4.1627,  4.0484, 3.9378,  3.8306,                                     
    //120℃  //121    //122    //123    //124    //125    //126    //127    //128    //129
    3.7268, 3.6263,  3.5289,  3.4345,   3.3430,  3.2543,  3.1683,  3.0850,  3.0042,  2.9258,    
    //130℃  //131    //132    //133    //134    //135    //136    //137    //138    //139
    2.8498, 2.7761,  2.7045,  2.6352,   2.5678,  2.5025, 2.4391,   2.3775,  2.3178,  2.2598,                                    
    //140℃  //141    //142    //143    //144    //145    //146    //147    //148    //149
    2.2034, 2.1487, 2.0956,  2.0440,    1.9939,  1.9452,  1.8978,  1.8518,  1.8071, 1.7637,        
    //150℃  //151    //152    //153    //154    //155    //156    //157    //158    //159
    1.7215, 1.6804, 1.6405,  1.6017,   1.5640,  1.5273,  1.4915,  1.4568,  1.4230,  1.3901,   
    //160℃  //161    //162    //163    //164    //165    //166    //167    //168    //169   
    1.3582, 1.3270, 1.2967,  1.2672,   1.2385,  1.2106,  1.1833,  1.1568,  1.1310,  1.1059,    
    //170℃
    1.0814
};


State_Enum_TypeDef Samp_Temp_Volt_State = FLG_SAMP_START;         //开机上电后即执行温度电压采样

/*************************************************************
函数:  void handle_temperature_volt(vu16 *ADCConvertedValue,variables *outpc)
功能:  配合中断,采集气温\缸温\电池电压
参数:  ADCConvertedValue: ADC数组
       outpc            : 串口发送数据
返回:  none
描述:  
**************************************************************/
void handle_temperature_volt(vu16 *ADCConvertedValue,variables *topc)    
{
  //采集气温,缸温,电池电压,分别存入
  switch(Samp_Temp_Volt_State)
    {
      case FLG_SAMP_START:                
           ADC_SoftwareStartConvCmd(ADC1,ENABLE);                 //开启ADC转换,气温,缸温,电池电压    
           Samp_Temp_Volt_State = FLG_SAMP_WAIT;                
           break;         
            
      case FLG_SAMP_END:                                          //等待ADC转换完成,则处理ADC数据,得到气温,缸温,电池电压                                            
           get_temperature_volt(ADCConvertedValue,topc);            
           Samp_Temp_Volt_State = FLG_SAMP_OVER;                  //气温,缸温,电池电压采样完成
           break;
            
      default: break;                
   }    
}

/*************************************************************
函数:  void get_temperature_volt(vu16 *ADCConvertedValue,variables *outpc)
功能:  得到气温、缸温、电池电压,深度为3的滑动平均算法平滑数据
参数:  ADCConvertedValue: ADC数组
       outpc            : 串口发送数据
返回:  none
描述:  Third-order moving average algorithm,get ntc temperature
       and battery voltage
**************************************************************/
static void get_temperature_volt(vu16 *ADCConvertedValue,variables *topc)    
{
    uint32_t temp = 0;
    static uint16_t ad_air_temp[3];          //气温,滑动平均深度为3
    static uint16_t ad_cyl_temp[3];          //缸温,滑动平均深度为3
    static uint16_t ad_vol_temp[3];          //电池电压,滑动平均深度为3
    
    temp = (ADCConvertedValue[0]+ADCConvertedValue[3]+ADCConvertedValue[6])/3; //气温的ADC平均值                            
    ad_air_temp[0] = ad_air_temp[1];           
    ad_air_temp[1] = ad_air_temp[2];
    ad_air_temp[2] = temp;     
    temp = (ad_air_temp[0] + ad_air_temp[1] + ad_air_temp[2])/3;                     
    topc->mat = get_ntc_temperature((u16)temp,inpram.Temp_Units);              //得到气温X10    
    
    temp = (ADCConvertedValue[1]+ADCConvertedValue[4]+ADCConvertedValue[7])/3; //缸温的ADC平均值
    ad_cyl_temp[0] = ad_cyl_temp[1];
    ad_cyl_temp[1] = ad_cyl_temp[2];
    ad_cyl_temp[2] = temp;        
    temp = (ad_cyl_temp[0] + ad_cyl_temp[1] + ad_cyl_temp[2])/3; 
    topc->clt = get_ntc_temperature((u16)temp,inpram.Temp_Units);              //得到缸温X10 

    temp = (ADCConvertedValue[2]+ADCConvertedValue[5]+ADCConvertedValue[8])/3; //电池电压的ADC平均值    
    ad_vol_temp[0] = ad_vol_temp[1];
    ad_vol_temp[1] = ad_vol_temp[2];
    ad_vol_temp[2] = temp;        
    temp = (ad_vol_temp[0] + ad_vol_temp[1] + ad_vol_temp[2])/3;         
    topc->batt = temp*132/4095;                                                //电池电压X10
}

/*************************************************************
函数:  static int16_t get_ntc_temperature(uint16_t ad_data)
功能:  
参数:  ad_data: STM32的ADC采集到的NTC电路分压AD值
返回:  根据单位换算成摄氏度/华氏度,返回温度值*10
描述:  10K与NTC串联,接到3V3电源上    
**************************************************************/
static int16_t get_ntc_temperature(uint16_t ad_data,uint8_t Temp_Units)
{
  float Rntc,t;
    
  uint8_t index;  
    
  Rntc = 10.0*ad_data/(4095 - ad_data);//求出Rntc阻值,单位为Komh
    
  for(index = 0;index < (N-1);index++)
    {
      if(Rntc > ntc[index])
        {
          break;
        }        
    }
        
  if(index <= 0)                       //temp lower than -20℃
    {
      t = -20.0;                       //rail at -20℃    
    }    
  else
  if(index >= (N-1))                   //temp higher than 170℃
    {
      t = 170.0;                       //rail at 170℃    
    }
  else                                 //temp between -20℃ and 170℃
    {
      t = (-20 + index) - (Rntc-ntc[index])/(ntc[index]-ntc[index-1]);
} if(Temp_Units) // 摄氏度 ℃ { t = t*10; // 温度扩大10倍 } else // 华氏度 F { t = (t*1.8 + 32)*10; // 温度扩大10倍 } return (int16_t)t; // 类型转换为int16_t }

猜你喜欢

转载自www.cnblogs.com/xyelectric/p/12200024.html