久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 2398|回復(fù): 0
收起左側(cè)

STC8H8L64U單片機(jī)使用NTC采集轉(zhuǎn)換溫度程序

[復(fù)制鏈接]
ID:1020872 發(fā)表于 2023-10-14 13:59 | 顯示全部樓層 |閱讀模式
傳統(tǒng)的NTC檢測(cè)溫度,需要根據(jù)規(guī)格書去查表對(duì)應(yīng)溫度的電阻值,每更換一種NTC就需要重新移植NTC對(duì)應(yīng)的溫度電壓表。
對(duì)于嚴(yán)格要求溫度的精確度的產(chǎn)品建議查表進(jìn)行
對(duì)于可容忍正負(fù)1攝氏度的產(chǎn)品建議查用算法進(jìn)行計(jì)算,這樣就不需要在更換NTC后進(jìn)行溫度表的重新抄寫移植。
中間顯示的是NTC的電壓值,左上顯示的第一個(gè)溫度是NTC的溫度25,右下角顯示的溫度是DS18B20讀取的溫度23,
兩個(gè)溫度相差2度,如果對(duì)溫度不是很嚴(yán)格我建議就是使用一個(gè)NTC就行,NTC溫度換算有兩種方式,一種是查表法,
通過羅列每個(gè)溫度對(duì)應(yīng)的電阻值去查詢,我覺得太麻煩了,所以我就使用了公式法,套用了公式,計(jì)算出來(lái)的結(jié)果還行,
比較接近,但是占用運(yùn)行空間比較大,因?yàn)橐褂胢ath.h函數(shù)開始上圖,歡迎大家討論

制作出來(lái)的實(shí)物圖如下:
37e3463f95ddab58fcf7879540429db.jpg

電路原理圖如下:
bd0bf2f71980b821c46917645ad9756.png

單片機(jī)源程序如下:

  1. /*初始化時(shí)先把要ADC轉(zhuǎn)換的引腳設(shè)置為高阻輸入.

  2. 過采樣提升N位分辨率:進(jìn)行2的2N次方轉(zhuǎn)換,累加值右移N位,提升N位分辨率

  3. 12位ADC,采樣4次數(shù)值累加后除以2,結(jié)果便為13位過采樣ADC數(shù)值.

  4. 同理12位ADC,采樣16次數(shù)值累加以后除以4,結(jié)果便為14位過采樣ADC數(shù)值.

  5. 程序提供了兩種軟件防抖的方式供參考選用:
  6. 1. 使用冒泡排序,去掉最高值、最低值,求中間平均值(不需要的話屏蔽 BUBBLE_SORT 定義)
  7. 2. 采樣累加,求平均值(不需要的話可將 SUM_LENGTH 定義值改為 1 )
  8. ******************************************/

  9. #include <ADC.h>
  10. #include <delay.h>
  11. #include "TFT.h"

  12. #define BUBBLE_SORT     //設(shè)置使用冒泡排序,去掉最高值、最低值,求中間平均值(不需要的話屏蔽此行)

  13. #define SUM_LENGTH        16        /* 平均值采樣次數(shù) 最大值16(不需要的話可將定義值改為 1 )*/

  14. /*************        本地常量聲明        **************/

  15. #define        ADC_SPEED        15                /* 0~15, ADC轉(zhuǎn)換時(shí)間(CPU時(shí)鐘數(shù)) = (n+1)*32  ADCCFG */
  16. #define        RES_FMT                (1<<5)        //1右移5位即為00100000,這個(gè)位設(shè)置為1  /* ADC結(jié)果格式 0: 左對(duì)齊, ADC_RES: D11 D10 D9 D8 D7 D6 D5 D4, ADC_RESL: D3 D2 D1 D0 0 0 0 0 */
  17.                                                         /* ADCCFG      1: 右對(duì)齊, ADC_RES: 0 0 0 0 D11 D10 D9 D8, ADC_RESL: D7 D6 D5 D4 D3 D2 D1 D0 */


  18. #ifdef BUBBLE_SORT  //使用冒泡排序,去掉最高值、最低值,求中間平均值
  19. u16 ADC_Buffer[16];
  20. #endif

  21. /**********************************************/
  22. void ADCINIT()
  23. {
  24.         ADCTIM = 0x3f;  //設(shè)置通道選擇時(shí)間、保持時(shí)間、采樣時(shí)間
  25.         ADCCFG = RES_FMT + ADC_SPEED;
  26.         //ADC模塊電源打開后,需等待1ms,MCU內(nèi)部ADC電源穩(wěn)定后再進(jìn)行AD轉(zhuǎn)換
  27.         ADC_CONTR = 0x80;        //ADC on + channel
  28. }

  29. /******************** 計(jì)算溫度 *********************/
  30. /*傳統(tǒng)的NTC檢測(cè)溫度,需要根據(jù)規(guī)格書去查表對(duì)應(yīng)溫度的電阻值,每更換一種NTC就需要重新移植NTC對(duì)應(yīng)的溫度電壓表。
  31. 對(duì)于嚴(yán)格要求溫度的精確度的產(chǎn)品建議查表進(jìn)行
  32. 對(duì)于可容忍正負(fù)1攝氏度的產(chǎn)品建議查用算法進(jìn)行計(jì)算,這樣就不需要在更換NTC后進(jìn)行溫度表的重新抄寫移植。
  33. NTC熱敏電阻的計(jì)算公式為:
  34. Rt = R EXP(B(1/T1-1/T2))
  35. 其中:
  36. T1:單位為開爾文溫度,T1=當(dāng)前攝氏度+273.15
  37. T2:單位為開爾文溫度,T2=25+273.15
  38. Rt:即為NTC在T1溫度下的電阻值(這個(gè)可以通過2.5V電壓串聯(lián)一個(gè)10K電阻和10KNTC,通過計(jì)算流過電阻的電流和NTC上的分壓計(jì)算而出)
  39. R:熱敏電阻在T2常溫下的標(biāo)稱阻值。100K的熱敏電阻25℃的值為100K(即R=100K)。此值可以查表NTC規(guī)格書
  40. B:是熱敏電阻的參數(shù),NTC的規(guī)格書會(huì)標(biāo)出
  41. EXP:舉個(gè)例子EXP(2),即為無(wú)理數(shù)e的2次方

  42. 當(dāng)前已知NTC電阻值,求此時(shí)的溫度,將公式進(jìn)行換算得
  43. T1 =1/(ln(Rt/R)/B+1/T2)
  44. 所求攝氏度為
  45. C= T1-273.15                     
  46. */

  47. #define Vref     2.5

  48. float BSP_Get_Temperature(float vadc)
  49. {
  50.     float temp,r,x;
  51.           float Rp=10000.0;                 //10K,25度時(shí)的阻值          
  52.           float T2 = (273.15+25.0);   //T2,25度時(shí)的開爾文溫度
  53.           float Bx = 3435.0;                //B值
  54.           float Ka = 273.15;        //開爾文溫度
  55.                 r=vadc/((Vref-vadc)/10000);//此處是為了計(jì)算NTC的電阻,NTC是通過2.5V電壓串聯(lián)一個(gè)10K電阻和10KNTC,通過計(jì)算流過電阻的電流和NTC上的分壓計(jì)算而出
  56.                 temp=1/(log(r/Rp)/Bx+(1/T2));
  57.                 if(temp<Ka)
  58.                 {
  59.                         x=Ka-temp;
  60.                         Display_Digit_16x24(0, 74, GREEN, BLACK,10);
  61.                 }
  62.                 else
  63.                 {
  64.                         x=temp-Ka;
  65.                         Display_Digit_16x24(0, 74, BLACK, BLACK,15);
  66.                 }
  67.                 return x;
  68. }


  69. #ifdef BUBBLE_SORT  //使用冒泡排序
  70. //========================================================================
  71. // 函數(shù): void DataSwap(u16* data1, u16* data2)
  72. // 描述: 數(shù)據(jù)交換函數(shù)。
  73. // 參數(shù): data1,data2 要交換的數(shù)據(jù).
  74. // 返回: none.
  75. // 版本: VER1.0
  76. // 日期: 2021-9-27
  77. // 備注:
  78. //========================================================================
  79. void DataSwap(u16* data1, u16* data2)
  80. {
  81.         u16 temp;
  82.         temp = *data1;
  83.         *data1 = *data2;
  84.         *data2 = temp;
  85. }

  86. //========================================================================
  87. // 函數(shù): void BubbleSort(u16* pDataArry, u8 DataNum)
  88. // 描述: 冒泡排序函數(shù)。
  89. // 參數(shù): pDataArry需要排序的數(shù)組,DataNum需要排序的數(shù)據(jù)個(gè)數(shù).
  90. // 返回: none.
  91. // 版本: VER1.0
  92. // 日期: 2021-9-27
  93. // 備注:
  94. //========================================================================
  95. void BubbleSort(u16* pDataArry, u8 DataNum)
  96. {
  97.         bit flag;
  98.         u8 i,j;
  99.         for(i=0;i<DataNum-1;i++)
  100.         {
  101.                 flag = 0;
  102.                 for(j=0;j<DataNum-i-1;j++)
  103.                 {
  104.                         if(pDataArry[j] > pDataArry[j+1])
  105.                         {
  106.                                 flag = 1;
  107.                                 DataSwap(&pDataArry[j], &pDataArry[j+1]);
  108.                         }
  109.                 }
  110.                 if(!flag)  //上一輪比較中不存在數(shù)據(jù)交換,則退出排序
  111.                 {
  112.                         break;
  113.                 }
  114.         }
  115. }
  116. #endif

  117. //========================================================================
  118. // 函數(shù): u16 Get_ADC12bitResult(u8 channel))        //channel = 0~15
  119. // 描述: 查詢法讀一次ADC結(jié)果.
  120. // 參數(shù): channel: 選擇要轉(zhuǎn)換的ADC, 0~15.
  121. // 返回: 12位ADC結(jié)果.
  122. // 版本: V1.0, 2016-4-28
  123. //========================================================================
  124. u16        Get_ADC12bitResult(u8 channel)        //channel = 0~15
  125. {
  126.         ADC_RES = 0;
  127.         ADC_RESL = 0;

  128.     ADC_CONTR = (ADC_CONTR & 0xF0) | 0x40 | channel;    //啟動(dòng) AD 轉(zhuǎn)換
  129.     _nop_();
  130.     _nop_();
  131.     _nop_();
  132.     while((ADC_CONTR & 0x20) == 0);   //等待ADC結(jié)束
  133.     ADC_CONTR &= ~0x20;     //清除ADC結(jié)束標(biāo)志
  134.     return (((u16)ADC_RES << 8) | ADC_RESL);
  135. }

  136. /***********************************
  137. 查詢方式做一次ADC, chn為通道號(hào), chn=0~7對(duì)應(yīng)P1.0~P1.7, chn=8~14對(duì)應(yīng)P0.0~P0.6, chn=15對(duì)應(yīng)BandGap電壓.
  138. ***********************************/
  139. float ADC_convert(u8 chn)
  140. {
  141.         u16        j;
  142.         u8        k;                //平均值濾波時(shí)使用
  143.     float vADC;

  144.         Get_ADC12bitResult(chn);                //參數(shù)i=0~15,查詢方式做一次ADC, 切換通道后第一次轉(zhuǎn)換結(jié)果丟棄. 避免采樣電容的殘存電壓影響.
  145.         Get_ADC12bitResult(chn);                //參數(shù)i=0~15,查詢方式做一次ADC, 切換通道后第二次轉(zhuǎn)換結(jié)果丟棄. 避免采樣電容的殘存電壓影響.

  146. #ifdef BUBBLE_SORT  //使用冒泡排序,去掉最高值、最低值,求中間平均值

  147.         for(k=0; k<16; k++)        ADC_Buffer[k] = Get_ADC12bitResult(chn);
  148.         BubbleSort(ADC_Buffer,16);  //冒泡排序
  149.         for(k=4, j=0; k<12; k++) j += ADC_Buffer[k];  //取中間8個(gè)數(shù)據(jù)
  150.         j >>= 3;                // 右移3位(除8),求平均

  151. #else   //采樣累加,求平均值(不需要的話可將 SUM_LENGTH 定義值改為 1 )

  152.         for(k=0, j=0; k<SUM_LENGTH; k++)        j += Get_ADC12bitResult(chn);        // 采樣累加和 參數(shù)0~15,查詢方式做一次ADC, 返回值就是結(jié)果
  153.         j = j / SUM_LENGTH;                // 求平均

  154. #endif
  155.     vADC = ((float)j * 2.5 / 4096);  //計(jì)算NTC電壓, Vref=2.5V
  156.     //過采樣例子
  157. //        for(k=0, j=0; k<16; k++)        j += Get_ADC12bitResult(chn);        // 采樣累加和 參數(shù)0~15,查詢方式做一次ADC, 返回值就是結(jié)果
  158. //        vADC = j / 4;                // 12位ADC,采樣16次數(shù)值累加后除以4,結(jié)果便為14位過采樣ADC數(shù)值
  159. //    vADC = (vADC * 2.5 / 16384);  //計(jì)算NTC電壓, Vref=2.5V
  160. return(vADC);
  161. }


  162. void displayADC()
  163. {
  164.          unsigned int m1,m2,m3,m4,m5,m6,VADC,tADC;
  165.    VADC=ADC_convert(3)*1000;//讀取溫度
  166.          tADC = BSP_Get_Temperature(ADC_convert(3)); //計(jì)算溫度值
  167.    
  168.          m1=VADC/1000;  ///號(hào)是求整 %是求余  
  169.          m2=VADC%1000/100;//為什么要除于10000呢,因?yàn)橐婚_始溫度換算的時(shí)就已經(jīng)乘以100倍了,如果溫度是110度,此時(shí)得出來(lái)的數(shù)就是11000,所以要除于10000
  170.          m3=VADC%100/10;
  171.          m4=VADC%10;
  172.          m5=tADC%100/10;
  173.          m6=tADC%10;
  174.        
  175. //         Display_Digit_12x24(12, 94, LIGHT_BLUE, BLACK,m1);
  176.          Display_Digit_16x24(0, 50, GREEN, BLACK,m1);
  177.          Display_Digit_16x24(16, 50, GREEN, BLACK,12);
  178.          Display_Digit_16x24(32, 50, GREEN, BLACK,m2);
  179.          Display_Digit_16x24(48, 50, GREEN, BLACK,m3);
  180.          Display_Digit_16x24(64, 50, GREEN, BLACK,m4);
  181.          Display_Digit_16x24(16, 74, GREEN, BLACK,m5);
  182.          Display_Digit_16x24(32, 74, GREEN, BLACK,m6);
  183. //         Display_Digit_12x24(48, 94, LIGHT_BLUE, BLACK,12);
  184. //         Display_Digit_12x24(60, 94, LIGHT_BLUE, BLACK,m4);
  185. //         Display_Digit_12x24(72, 94, LIGHT_BLUE, BLACK,m5);
  186.         // Display_Digit_12x24(72, 94, LIGHT_BLUE, BLACK,13);
  187.          
  188. }


復(fù)制代碼





評(píng)分

參與人數(shù) 1黑幣 +70 收起 理由
admin + 70 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 日韩在线欧美 | 欧美xxxx网站 | 精品视频一区二区三区在线观看 | 欧美一区免费 | 国产日韩精品在线 | 亚洲精品久久久久久一区二区 | 国产精品久久久久久吹潮 | 狠狠操狠狠操 | 在线中文字幕国产 | 九九热精品在线 | 日本中文字幕在线视频 | 九九热在线免费观看 | 精品国产一区二区三区成人影院 | 久久一区二区三区四区 | 狠狠骚| 欧美99| 国产99久久精品一区二区300 | 日韩欧美精品一区 | 中文字幕99| 久久小视频 | 亚洲精品一| 午夜小视频在线播放 | 国产区在线免费观看 | 日本国产欧美 | 久久99精品久久久久久国产越南 | 91pron在线 | 日韩电影中文字幕 | 精品久久中文 | 黄色网址大全在线观看 | 亚洲一级在线 | 久久久久久黄 | 国产黄色av电影 | 日本三级做a全过程在线观看 | 色香蕉在线 | 国产成人精品一区二区三 | 91九色视频在线 | 丝袜美腿一区二区三区 | 在线播放一区二区三区 | 国产精品一区二区三区四区 | 最新av中文字幕 | 欧美一区二区三区在线 |