返回列表 发新帖我要提问本帖赏金: 10.00元(功能说明)

[应用方案] ML51单片机通过ADC驱动NTC传感器测量温度

[复制链接]
 楼主| gaoyang9992006 发表于 2020-11-12 15:49 | 显示全部楼层 |阅读模式
<
#申请原创# @21小跑堂

NTC传感器如下图所示,NTC的阻抗随着温度升高而降低。手册给出了阻抗到温度的转换公式。
322635face805e22b5.png 838315face81deedd5.png

我们可以通过ML51单片机提供的 12位ADC来读取该串联电阻的分压,从而根据参考电阻计算出传感器的阻抗,然后利用手册的温度计算公式计算出温度。下图是手册给出的几个常用计算常数B,可根据测量的范围合理的选择,用于提高测量精度。
578245face94a9493f.png
实现温度转换

根据手册提供的公式:R=R0 exp B(1/T - 1/T0);
其中R是待测电阻,R0是某个温度T0 K下的已知电阻,B是温度传感器常数
通过以上公式反推T = temp=1/((1/T0)+(log(RT/R0)/B));
代入数据测试,例如T0=25摄氏度时候R0=10K欧姆,主意以上代入实际计算时候要使用绝对温度,单位开尔文
经过测试上述公式可以完成验算,即,正确。
根据手册该型号的B常数在25到50度之间采用3380,25到80之间采用3428,25到85之间采用3434,25到100摄氏度之间采用3455.
为了方便,本项目采用3455计算。
完成代码如下所示。

  1. //***********************************************************************************************************
  2. //  File Function: ML51 series ADC software trigger on shot demo code
  3. //***********************************************************************************************************
  4. #include "ML51.h"
  5. #include "math.h"
  6. #include "NTC.h"
  7. /******************************************************************************
  8. The main C function.  Program execution starts
  9. here after stack initialization.
  10. ******************************************************************************/



  11. void main ()
  12. {
  13.   unsigned int ADCRESULT;
  14.         float Rval;
  15.         float temp;

  16. /*
  17. For UART0 P0.5 TXD output setting
  18. * include gipo.c in Library for GPIO mode setting
  19. * include uart.c in Library Setting for UART0
  20. */
  21.     MFP_P31_UART0_TXD;                              // UART0 TXD use P0.5
  22.     P31_QUASI_MODE;                                 // set P0.5  as Quasi mode for UART0 trasnfer
  23.     UART_Open(24000000,UART0_Timer3,115200);        // Open UART0 use timer1 as baudrate generate and baud rate = 115200
  24.     ENABLE_UART0_PRINTF;  
  25. /*
  26.   ADCS to trig ADC convert
  27.   * include adc.c in Library for ADC initial setting
  28. */
  29.     ADC_Open(ADC_SINGLE,1);                                        //Enable ADC_CH4
  30.     ADC_ConvertTime(3,7);
  31. //* find ADC result in ADC interrupt*/
  32.                                             
  33.     while(1)
  34.     {
  35.         set_ADCCON0_ADCS;                           // Software trig adc start
  36.         while((ADCCON0|CLR_BIT7)==CLR_BIT7);         // wait ADCF = 1;
  37.         ADCRESULT = (ADCRH<<4)+ADCRL;
  38.         printf("\n ADC result = %d  ", ADCRESULT);
  39.         Timer0_Delay(24000000,100,5000);
  40.                                 Rval=1000*((ADCRESULT*6.2)/(4095-ADCRESULT));
  41.                                 printf("\n Rval=%d Ohm",(unsigned int)Rval);
  42.                                 temp=Res_to_Tem(Rval);
  43.                                 printf("\n temp=%.2f",temp-K);
  44.                                 printf("\n----------------");                                       
  45.     }
  46.   
  47. }

将阻抗转换为温度作为一个独立的头文件
NTC.h
  1. #define K 273.15
  2. #define T0 (25.0+K)
  3. #define R0 10000.0
  4. #define B 3455.0        

  5. /*
  6. 电阻值换算到温度
  7. adc_val:NTC当前的阻抗值,单位欧姆
  8. 返回值:摄氏度
  9. */

  10. float Res_to_Tem(float adc_val)
  11. {
  12.         float temp;
  13.         temp=1/((1/T0)+(log(adc_val/R0)/B));
  14.         return temp-K;
  15. }
这样就可以直接调用得出摄氏度了。本例子,采用串口打印的测量结果如下图所示。 276085face9e97738d.png
手册还给出的查表方法,给出了几个特殊点,如下图所示
379445facea12d6351.png
绘制出曲线如下图所示。
759945facea08d4af8.png
点评:NTC测量温度成本低,响应迅速,只需要使用1路ADC通道即可。比数字类型的温度计驱动更加容易,使用更加灵活,还可以自己实现校准功能。



打赏榜单

21小跑堂 打赏了 10.00 元 2020-11-13
理由:恭喜通过原创文章审核!

antusheng 发表于 2020-11-12 16:03 | 显示全部楼层
漂亮,多谢分享,公式通用吗
wahahaheihei 发表于 2020-11-13 09:56 | 显示全部楼层
不错不错,给力。
xuanhuanzi 发表于 2020-11-13 11:19 | 显示全部楼层
来个点赞。
gejigeji521 发表于 2020-11-13 11:41 | 显示全部楼层
研究的透彻,学习学习。
 楼主| gaoyang9992006 发表于 2020-11-17 17:34 | 显示全部楼层
448545fb3947572235.png
GPIO_I2C_OLED.rar (100.87 KB, 下载次数: 27)




734774645 发表于 2022-5-23 15:15 | 显示全部楼层
真不错,直接可以拿走用了。
match007 发表于 2022-6-12 13:35 | 显示全部楼层
adc不是采样么
怎么能驱动?
huahuagg 发表于 2022-11-21 14:15 | 显示全部楼层
这个贴,真棒,不仅有理论还有直接可以用的公式。
huahuagg 发表于 2022-11-21 14:15 | 显示全部楼层
match007 发表于 2022-6-12 13:35
adc不是采样么
怎么能驱动?

是提供测温公式吧
 楼主| gaoyang9992006 发表于 2022-11-21 14:48 | 显示全部楼层
match007 发表于 2022-6-12 13:35
adc不是采样么
怎么能驱动?

不驱动怎么能从热敏电阻获得温度值呢。
pmp 发表于 2022-12-15 09:51 | 显示全部楼层
ML51是自带ADC的吗?              
 楼主| gaoyang9992006 发表于 2022-12-15 10:30 | 显示全部楼层
pmp 发表于 2022-12-15 09:51
ML51是自带ADC的吗?

是的,自带ADC,功能强大。
benjaminka 发表于 2022-12-15 14:12 | 显示全部楼层
这个转换的公式在哪里?              
 楼主| gaoyang9992006 发表于 2022-12-15 14:16 | 显示全部楼层
benjaminka 发表于 2022-12-15 14:12
这个转换的公式在哪里?

看不到吗?我贴的代码里就有转换公式啊。公式是我根据手册的说明自己推出来的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

个人签名:如果你觉得我的分享或者答复还可以,请给我点赞,谢谢。

2046

主题

16351

帖子

222

粉丝
快速回复 在线客服 返回列表 返回顶部