|
发表于 2013-10-28 14:34:36
|
显示全部楼层
- /*
- *******************************************************************************
- * ntc对应采样电压值数组
- *------------------------------------------------------------------------------
- * 注释第一行:对应温度
- *-------------------------------------------------------------------------------
- * 测量温度范围定为-10℃-150℃(可能会有零点几的数据出入)
- ********************************************************************************
- */
- static int16u code ntc_adc[] =
- {
- 62454 , 61415 , 60359 , 59286 , 58199 , 57098 , 55985 , 54862 ,
- 53730 , 52592 , 51448 , 50302 , 49153 , 48005 , 46858 , 45715 ,
- 44576 , 43444 , 42320 , 41205 , 40101 , 39009 , 37930 , 36865 ,
- 35816 , 34783 , 33767 , 32769 , 31790 , 30829 , 29889 , 28968 ,
- 28068 , 27189 , 26331 , 25494 , 24678 , 23883 , 23110 , 22358 ,
- 21627 , 20916 , 20226 , 19557 , 18908 , 18279 , 17669 , 17078 ,
- 16506 , 15952 , 15416 , 14898 , 14396 , 13912 , 13444 , 12991 ,
- 12554 , 12132 , 11724 , 11331 , 10951 , 10584 , 10230 , 9889 ,
- 9559 , 9241 , 8935 , 8639 , 8353 , 8078 , 7813 , 7557 ,
- 7310 , 7072 , 6842 , 6620 , 6407 , 6201 , 6002 , 5810 ,
- 5625 , 5446 , 5274 , 5108 , 4948 , 4793 , 4644 , 4500 ,
- 4361 , 4227 , 4098 , 3973 , 3852 , 3735 , 3623 , 3514 ,
- 3409 , 3308 , 3210 , 3115 , 3024 , 2936 , 2850 , 2768 ,
- 2688 , 2611 , 2536 , 2464 , 2394 , 2327 , 2262 , 2198 ,
- 2137 , 2078 , 2021 , 1966 ,
- };
- #define NTC_ADC_ARRAY_NUM (sizeof(ntc_adc)/sizeof(int16u))
- #define INDEX_MAX NTC_ADC_ARRAY_NUM-2 /* 数组下标的最大可用取值,对应 80℃采样值下标 */
- #define INDEX_MIN 2 /* 数组下标的最小可用取值,对应-10℃采样值下标 */
- #define TEMPER_REF -15 /* 温度基准点,即下标为0时对应的温度 */
- #define TEMPER_LAST 100 /* 温度最后值,即数组最后一个对应的温度 */
- /*
- *******************************************************************************
- * 函数名称: search_data()
- * 输 入: search_value 查找基准值
- * 输 出:
- * 作 者:
- * 日 期: 2010.08.11
- * 功能描述: 二分查找adc采样值
- *------------------------------------------------------------------------------
- *注 意:
- * 1. 返回值为查找表格中第一个小于查找值(search_value)的下标;
- * 2. 查找值(search_value)大于查找表格中最大值时,返回1
- * 查找值(search_value)小于查找表格中最小值时,返回查找表格数量,即最大下标+1
- *******************************************************************************
- */
- static int16u search_data(int16u search_value)
- {
- register int16u max = NTC_ADC_ARRAY_NUM - 1;
- register int16u min = 1;
- register int16u mid;
- while(min <= max)
- {
- mid = (max + min) / 2;
- if(search_value > ntc_adc[mid])
- {
- max = mid - 1;
- }
- else
- {
- min = mid + 1;
- }
- }
- return min;
- }
- /*
- *******************************************************************************
- * 函数名称: temper_calc()
- * 输 入: index 数组下标
- * adc0_value ad滤波后的采样值
- * 输 出: ntc温度测量值
- * 作 者:
- * 日 期: 2010.10.26
- * 功能描述: 温度计算(分段线性插值算法)
- *******************************************************************************
- */
- static int16s temper_calc(int16u index, int16u adc0_value)
- {
- if (index > INDEX_MAX || index < INDEX_MIN)
- {
- return TEMPER_ERROR; // 返回错误采样温度
- }
- // else if (index < INDEX_MIN)
- // {
- // return -150; // 返回-15.0℃
- // }
- else
- {
- /*************************************************
- === 直线近似计算 ===
- y1 = kx1+b x <-> adc_value
- y2 = kx2+b y <-> temper
- yn = kxn+b
- y2 - y1 yn - y1
- k = --------- = ---------
- x2 - x1 xn - x1
- (y2 - y1)*(xn - x1)
- yn = --------------------- + y1
- (x2 - x1)
- *************************************************/
- int16s temper;
-
- temper = 10*(ntc_adc[index-1] - adc0_value); // 放大10倍,temper放大10倍
- temper /= (ntc_adc[index-1] - ntc_adc[index]); // (xn - x1)
- temper += 10*(index + TEMPER_REF - 1);
-
- return temper;
- }
- }
- /*
- *******************************************************************************
- * 函数名称: adc0_battery_temper_calc()
- * 输 入: adc0_sample_num ad采样次数
- * adc0_sample_sum ad采样总和
- * 输 出:
- * 作 者:
- * 日 期: 2011.11.23
- * 功能描述: 输出220V电压计算
- *******************************************************************************
- */
- void adc0_battery_temper_calc(int16u adc_value)
- {
- register int16s temper; // 温度值
- register int16u index; // 查表下标值
- index = search_data(adc_value); // 取温度数组下标
- temper = temper_calc(index, adc_value); // 温度计算
- battery_sample.battery_temper = temper;
- }
复制代码 |
|