manzunzu 发表于 2022-12-13 11:33:27

关于开天斧 热敏电阻NTC / ADC测温 案例的疑惑

#define Vref   2.5



    float Temperature = 0.0;
    float R2 = 0.0;
    float R1 = 10000.0;
    float T2 = 298.15;//273.15+25;
    float B = 3435.0;
    float K = 273.15;
    float R2V = 0.0;


案例是挺好下载进去就能检测环境温度了,只是上面这些没有注释不太理解什么意思。热敏电阻B值是3435.0吗
如果更换热敏电阻需要修改那些参数,

32位8051 发表于 2022-12-13 14:50:37


https://www.stcai.com/filedownload/630381   代码下载在这,我们 STC 的专家也可以及时提供支持哦!

manzunzu 发表于 2022-12-13 16:45:37

就是这个代码,只是不明白具体的代码含义

乘风飞扬 发表于 2022-12-13 20:25:31

本帖最后由 乘风飞扬 于 2022-12-13 20:26 编辑

NTC 热敏电阻温度计算公式:Rt = R *EXP(B*(1/T1-1/T2))

(1) T1和T2指的是K度,即开尔文温度。
(2) K = 273.15 (绝对温度)
(3) Rt 是热敏电阻在T1温度下的阻值。
(4) R1是热敏电阻在T2常温下的标称阻值。10K的热敏电阻25℃的值为10K(即R1=10K)。
(5) T2 = (273.15+25)。
(6) EXP(n) 是 e 的 n 次方。
(7) B值是热敏电阻的重要参数。

通过转换可以得到温度T1与电阻Rt的关系T1=1/(1/T2+ln(Rt/R1)/B)
对应的摄氏温度t=T1-273.15,同时+0.5的误差矫正。

梁工 发表于 2022-12-13 20:40:31

如果想减少计算时间,可以二分法查表,先建一个ADC读数表格,1度C一个数据,0.1度用线性插补。查表法不需要测量电阻的实际值,不影响精度。

manzunzu 发表于 2022-12-14 13:07:27

明白了,谢谢

liushiming82 发表于 2024-4-28 09:56:22

梁工 发表于 2022-12-13 20:40
如果想减少计算时间,可以二分法查表,先建一个ADC读数表格,1度C一个数据,0.1度用线性插补。查表法不需要 ...

线性插补怎么理解,能否举例说明?谢谢,能否提供一个温度表格吗?

梁工 发表于 2024-4-28 10:26:20

liushiming82 发表于 2024-4-28 09:56
线性插补怎么理解,能否举例说明?谢谢,能否提供一个温度表格吗?

请去官网下载实验箱例程参考,二分法查表。







liushiming82 发表于 2024-4-28 10:50:02

梁工 发表于 2024-4-28 10:26
请去官网下载实验箱例程参考,二分法查表。

谢谢,梁工,这个例程中怎么没有视频中那个温度查询表呀

梁工 发表于 2024-4-28 11:02:52

本帖最后由 梁工 于 2024-4-28 11:04 编辑

liushiming82 发表于 2024-4-28 10:50
谢谢,梁工,这个例程中怎么没有视频中那个温度查询表呀
有啊,没看到吗?在程序比较后面的位置:

//========================================================================
// 函数: u16 Get_ADC12bitResult(u8 channel)
// 描述: 查询法读一次ADC结果.
// 参数: channel: 选择要转换的ADC.
// 返回: 12位ADC结果.
// 版本: V1.0, 2012-10-22
//========================================================================
u16 Get_ADC12bitResult(u8 channel)//channel = 0~15
{
    ADC_RES = 0;
    ADC_RESL = 0;

    ADC_CONTR = (ADC_CONTR & 0xF0) | 0x40 | channel;    //启动 AD 转换
    _nop_();
    _nop_();
    _nop_();
    _nop_();

    while((ADC_CONTR & 0x20) == 0);   //wait for ADC finish
    ADC_CONTR &= ~0x20;   //清除ADC结束标志
    return(((u16)ADC_RES << 8) | ADC_RESL);
}


//MF52E 10K at 25, B = 3950, ADC = 12 bits
u16 code temp_table[]={
      140,    //;-400
      149,    //;-391
      159,    //;-382
      168,    //;-373
      178,    //;-364
      188,    //;-355
      199,    //;-346
      210,    //;-337
      222,    //;-328
      233,    //;-319
      246,    //;-3010
      259,    //;-2911
      272,    //;-2812
      286,    //;-2713
      301,    //;-2614
      317,    //;-2515
      333,    //;-2416
      349,    //;-2317
      367,    //;-2218
      385,    //;-2119
      403,    //;-2020
      423,    //;-1921
      443,    //;-1822
      464,    //;-1723
      486,    //;-1624
      509,    //;-1525
      533,    //;-1426
      558,    //;-1327
      583,    //;-1228
      610,    //;-1129
      638,    //;-1030
      667,    //;-9   31
      696,    //;-8   32
      727,    //;-7   33
      758,    //;-6   34
      791,    //;-5   35
      824,    //;-4   36
      858,    //;-3   37
      893,    //;-2   38
      929,    //;-1   39
      965,    //;0    40
      1003,   //;1    41
      1041,   //;2    42
      1080,   //;3    43
      1119,   //;4    44
      1160,   //;5    45
      1201,   //;6    46
      1243,   //;7    47
      1285,   //;8    48
      1328,   //;9    49
      1371,   //;10   50
      1414,   //;11   51
      1459,   //;12   52
      1503,   //;13   53
      1548,   //;14   54
      1593,   //;15   55
      1638,   //;16   56
      1684,   //;17   57
      1730,   //;18   58
      1775,   //;19   59
      1821,   //;20   60
      1867,   //;21   61
      1912,   //;22   62
      1958,   //;23   63
      2003,   //;24   64
      2048,   //;25   65
      2093,   //;26   66
      2137,   //;27   67
      2182,   //;28   68
      2225,   //;29   69
      2269,   //;30   70
      2312,   //;31   71
      2354,   //;32   72
      2397,   //;33   73
      2438,   //;34   74
      2479,   //;35   75
      2519,   //;36   76
      2559,   //;37   77
      2598,   //;38   78
      2637,   //;39   79
      2675,   //;40   80
      2712,   //;41   81
      2748,   //;42   82
      2784,   //;43   83
      2819,   //;44   84
      2853,   //;45   85
      2887,   //;46   86
      2920,   //;47   87
      2952,   //;48   88
      2984,   //;49   89
      3014,   //;50   90
      3044,   //;51   91
      3073,   //;52   92
      3102,   //;53   93
      3130,   //;54   94
      3157,   //;55   95
      3183,   //;56   96
      3209,   //;57   97
      3234,   //;58   98
      3259,   //;59   99
      3283,   //;60   100
      3306,   //;61   101
      3328,   //;62   102
      3351,   //;63   103
      3372,   //;64   104
      3393,   //;65   105
      3413,   //;66   106
      3432,   //;67   107
      3452,   //;68   108
      3470,   //;69   109
      3488,   //;70   110
      3506,   //;71   111
      3523,   //;72   112
      3539,   //;73   113
      3555,   //;74   114
      3571,   //;75   115
      3586,   //;76   116
      3601,   //;77   117
      3615,   //;78   118
      3628,   //;79   119
      3642,   //;80   120
      3655,   //;81   121
      3667,   //;82   122
      3679,   //;83   123
      3691,   //;84   124
      3702,   //;85   125
      3714,   //;86   126
      3724,   //;87   127
      3735,   //;88   128
      3745,   //;89   129
      3754,   //;90   130
      3764,   //;91   131
      3773,   //;92   132
      3782,   //;93   133
      3791,   //;94   134
      3799,   //;95   135
      3807,   //;96   136
      3815,   //;97   137
      3822,   //;98   138
      3830,   //;99   139
      3837,   //;100140
      3844,   //;101141
      3850,   //;102142
      3857,   //;103143
      3863,   //;104144
      3869,   //;105145
      3875,   //;106146
      3881,   //;107147
      3887,   //;108148
      3892,   //;109149
      3897,   //;110150
      3902,   //;111151
      3907,   //;112152
      3912,   //;113153
      3917,   //;114154
      3921,   //;115155
      3926,   //;116156
      3930,   //;117157
      3934,   //;118158
      3938,   //;119159
      3942    //;120160
};

/********************计算温度 ***********************************************/
// 计算结果: 0对应-40.0度, 400对应0度, 625对应25.0度, 最大1600对应120.0度.
// 为了通用, ADC输入为12bit的ADC值.
// 电路和软件算法设计: Coody
/**********************************************/

#define   D_SCALE   10      //结果放大倍数, 放大10倍就是保留一位小数
u16 get_temperature(u16 adc)
{
    u16 code *p;
    u16 i;
    u8j,k,min,max;
   
    adc = 4096 - adc;   //Rt接地
    p = temp_table;
    if(adc < p)      return (0xfffe);
    if(adc > p)    return (0xffff);
   
    min = 0;      //-40度
    max = 160;      //120度

    for(j=0; j<5; j++)//对分查表
    {
      k = min / 2 + max / 2;
      if(adc <= p) max = k;
      else            min = k;
    }
         if(adc == p)i = min * D_SCALE;
    else if(adc == p)i = max * D_SCALE;
    else    // min < temp < max
    {
      while(min <= max)
      {
            min++;
            if(adc == p)   {i = min * D_SCALE; break;}
            else if(adc < p)
            {
                min--;
                i = p; //min
                j = (adc - i) * D_SCALE / (p - i);   // 这句就是线性插补
                i = min;
                i *= D_SCALE;
                i += j;
                break;
            }
      }
    }
    return i;
}
页: [1] 2
查看完整版本: 关于开天斧 热敏电阻NTC / ADC测温 案例的疑惑