找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 8420|回復: 8
打印 上一主題 下一主題
收起左側(cè)

基于51單片機控制的DS18B20數(shù)字溫度系統(tǒng)

  [復制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:527981 發(fā)表于 2020-12-31 22:07 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
本文主要介紹了一個基于 AT89C51單片機的測溫系統(tǒng),詳細描述了利用數(shù)字溫度傳感器 DS18B20 開發(fā)測溫系統(tǒng)的過程。對采集的信息都希望用最直接的方式顯示出來,但是傳感器所采集的信息是模擬的信號,并且信號是非常微小的,需要用放大器進行放大。模擬信號不能直接用數(shù)字儀器直接顯示,通過模數(shù)轉(zhuǎn)換之后就可以將模擬量轉(zhuǎn)變成數(shù)字量,在通過數(shù)碼管進行顯示。有些可以直接與單片機鏈接。數(shù)碼管有共陽極與共陰極兩類,本次設計采用的是共陰極的七段數(shù)碼管。
  設計要求:利用數(shù)字溫度傳感器 DS18B20 與單片機結(jié)合來測量溫度。利用數(shù)字 溫度傳感器 DS18B20 測量溫度信號,計算后在 LED 數(shù)碼管上顯示 相應的溫度值。其溫度測量范圍為−55℃~125℃,精確到 0.5℃;實 現(xiàn)超限報警
  DS18B20 數(shù)字溫度計是 DALLAS 公司生產(chǎn)的 1-Wire ,即單總線器件,具有線路簡單、體積小的特點。因此用它來組成一個測溫系統(tǒng),線路簡單,在一根通信線上,可以掛很多這樣的數(shù)字溫度計,十分方便。 DS18B20 是美國DALLAS 公司新推出的一種可組網(wǎng)數(shù)字式溫度傳感器,與 DS1820 相似,DS18B20 也能夠直接讀取被測物體的溫度值。但是與 DS1820 相比, DS18B20 的功能更強大些。它體積小,電壓適用范圍寬( 3--5V ),用戶還可以通過編程實現(xiàn) 9--12 位的溫度讀數(shù),即具有可調(diào)的溫度分辨率,因此它的實用性和可靠性比同類產(chǎn)品更高。
總原理圖

程序部分c
  1. #include<reg51.h>
  2. #include<intrins.h>
  3. sbit DQ=P1^7;           //定義DS18B20的接受端口
  4. sbit p0_7=P0^7;
  5. sbit p3_0=P3^0;                //以下五個端口為按鈕
  6. sbit p3_1=P3^1;
  7. sbit p3_2=P3^2;
  8. sbit p3_3=P3^3;
  9. sbit p3_4=P3^4;
  10. sbit p1_0=P1^0;
  11. #define uchar unsigned char
  12. #define uint  unsigned int         
  13. void yanshi(int );                            //普通延時函數(shù)
  14. void jinyan(int );                          //  精確延時
  15. void yan_us        (uchar);                   // us級延時
  16. bit chushi(void);                           // DS18B20通信初始化
  17. void xie(uchar );                           //  向DS18B20寫數(shù)據(jù)
  18. uint du(void);                                   //  讀取DS18B20的數(shù)據(jù)
  19. float chuli(uint);                           // 處理DS18B20返回的數(shù)據(jù)
  20. void xianshi(float);                  //  數(shù)碼管顯示函數(shù)
  21. uchar biao[12]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x39,0x71};//        數(shù)碼管0-9 的顯示數(shù)據(jù)
  22. bit huan=1;

  23. void main(void){
  24.         uint ab=0;
  25.         float ac=0;
  26.         char shang=50;
  27.         char xia  =10;
  28.         int bian=0;
  29.     DQ=1;
  30.         p3_0=1;
  31.         p3_1=1;
  32.         p3_2=1;
  33.         p3_3=1;
  34.         p3_4=1;
  35.         TMOD=0x01;
  36.         EA=0;
  37.         ET0=0;
  38. while(1){
  39.         if((ab==1)&&chushi()){                //         向DS18B20發(fā)送轉(zhuǎn)換溫度指令
  40.          yan_us(100);
  41.          xie(0xcc);
  42.          xie(0x44);
  43.         }
  44.         if((DQ==1)&&(ab==500)&&chushi()){         //接受DS18B20的數(shù)據(jù)
  45.          yan_us(100);
  46.          xie(0xcc);
  47.          xie(0xbe);
  48.          ac=chuli(du());
  49.          ab=0;
  50.         }
  51.         ab++;
  52.         xianshi(ac);                                         //         顯示DS18B20的溫度數(shù)據(jù)
  53.         if(p3_4==0){                                         //         切換溫度顯示方式C  F
  54.                 huan=~huan;
  55.                 while(!p3_4);
  56.         }                                                                 
  57.         if(p3_0==0){                                                //調(diào)整上限增加
  58.          bian=0;
  59.          while(!p3_0){
  60.           if(bian==200){
  61.           shang++;
  62.           bian=0;
  63.           }
  64.           bian++;
  65.           xianshi(shang);
  66.          }
  67.         }
  68.         if(p3_1==0){                                 //                調(diào)整上限減少
  69.          bian=0;
  70.          while(!p3_1){
  71.           if(bian==200){
  72.           shang--;
  73.           bian=0;
  74.           }
  75.           bian++;
  76.           xianshi(shang);
  77.          }
  78.         }
  79.         if(p3_2==0){                                //          調(diào)整下限增加
  80.          bian=0;
  81.          while(!p3_2){
  82.           if(bian==200){
  83.           xia++;
  84.           bian=0;
  85.           }
  86.           bian++;
  87.           xianshi(xia);
  88.          }
  89.         }
  90.         if(p3_3==0){                                 //           調(diào)整下限減少
  91.          bian=0;
  92.          while(!p3_3){
  93.           if(bian==200){
  94.           xia--;
  95.           bian=0;
  96.           }
  97.           bian++;
  98.           xianshi(xia);
  99.          }
  100.         }
  101.         if(ac<xia||ac>shang)                   // 判斷溫度示數(shù)是否超上下限
  102.                 p1_0=1;
  103.         else
  104.                 p1_0=0;
  105. }

  106. }

  107. void yanshi(int a){
  108. int b;
  109. while(a--){
  110. for(b=0;b<110;b++);
  111. }

  112. }

  113. void jinyan(int a){
  114. TH0=(65536-a)/256;
  115. TL0=(65536-a)%256;
  116. TR0=1;
  117. while(!TF0);
  118. TF0=0;
  119. TR0=0;
  120. }

  121. void yan_us(uchar a){
  122. while(a--);
  123. }

  124. bit chushi(void){
  125. uchar a=0;
  126. DQ=0;
  127. yan_us(100);
  128. DQ=1;
  129. while(DQ){
  130. if(a==200)
  131. return 0;
  132. a++;
  133. }
  134. a=0;
  135. while(!DQ){
  136. if(DQ==250)
  137. return 0;
  138. a++;
  139. }
  140. return 1;
  141. }

  142. void xie(uchar a){
  143. char b;
  144. bit c;
  145. for(b=0;b<8;b++){
  146. c=a&0x01;
  147. if(c){
  148. DQ=0;
  149. _nop_();
  150. _nop_();
  151. DQ=1;
  152. yan_us(13);
  153. }
  154. else  {
  155. DQ=0;
  156. yan_us(13);
  157. DQ=1;
  158. }
  159. a=a>>1;
  160. }
  161. }

  162. uint du(void){
  163. uint a=0,b=0;
  164. bit c=0;
  165. char d;
  166. for(d=0;d<16;d++){
  167. DQ=0;
  168. _nop_();
  169. _nop_();
  170. DQ=1;
  171. _nop_();
  172. _nop_();
  173. _nop_();
  174. c=DQ;
  175. b=c;
  176. b=b<<d;
  177. a=a|b;
  178. b=0;
  179. yan_us(9);
  180. }
  181. DQ=0;
  182. yanshi(2);
  183. DQ=1;
  184. return a;
  185. }
  186. float chuli(uint a){
  187. float b;
  188. if(a>=32768){
  189. a=~a;
  190. a++;
  191. b=(float)a;
  192. b=b/(-16);
  193. }
  194. else  {
  195. b=(float)a;
  196. b=b/16;
  197. }
  198. return b;
  199. }
  200. void xianshi(float a){
  201. uint b,c;
  202. if(!huan)
  203.         a=32+a*1.8;
  204. if(a<0){
  205.         a=a*(-1);
  206.         b=(uint)a;
  207.         a=(a-b)*10;
  208.         c=(uint)a;
  209.         P2=0x00;
  210.         P0=0x40;
  211.         P0=0x00;
  212. }
  213. else{
  214.         b=(uint)a;
  215.         a=(a-b)*10;
  216.         c=(uint)a;
  217. }
  218. P2=0x01;
  219. P0=biao[b/100];
  220. P0=0x00;
  221. P2=0x02;
  222. P0=biao[(b/10)%10];
  223. P0=0x00;
  224. P2=0x03;
  225. P0=biao[b%10];
  226. p0_7=1;
  227. P0=0x00;
  228. P2=0x04;
  229. P0=biao[c];
  230. P0=0x00;
  231. P2=0x05;
  232. if(huan)
  233.         P0=biao[10];
  234. else
  235.         P0=biao[11];
  236. P0=0x00;
  237. }
復制代碼



仿真結(jié)果




溫控仿真2.png (105.59 KB, 下載次數(shù): 164)

溫控仿真2.png

51hei.png (3.28 KB, 下載次數(shù): 171)

51hei.png

51溫控系統(tǒng).rar

26.09 KB, 下載次數(shù): 102, 下載積分: 黑幣 -5

51基于DS18B20的溫控

評分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 贊一個!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏11 分享淘帖 頂2 踩
回復

使用道具 舉報

沙發(fā)
ID:390416 發(fā)表于 2021-1-1 09:55 | 只看該作者
這是我分享到51hei的DS18B20資料包 包含時序圖。 http://www.torrancerestoration.com/bbs/dpj-200465-1.html
回復

使用道具 舉報

板凳
ID:872200 發(fā)表于 2021-1-2 20:53 | 只看該作者
四位數(shù)碼管顯示的,需要對代碼進行哪些修改?
回復

使用道具 舉報

地板
ID:527981 發(fā)表于 2021-1-29 22:14 | 只看該作者
zhaozhulei 發(fā)表于 2021-1-2 20:53
四位數(shù)碼管顯示的,需要對代碼進行哪些修改?

一位用作正負,剩下的用于溫度就行了
回復

使用道具 舉報

5#
ID:736988 發(fā)表于 2021-3-15 22:17 | 只看該作者
這個代碼不行呀,樓主
回復

使用道具 舉報

6#
ID:894438 發(fā)表于 2021-3-20 22:31 來自手機 | 只看該作者
為啥我一打開isis他就顯示什么新設計,然后里面什么也沒有啊
回復

使用道具 舉報

7#
ID:894438 發(fā)表于 2021-3-20 22:45 來自手機 | 只看該作者
為啥我也不行啊,是不是我的仿真軟件有問題啊
回復

使用道具 舉報

8#
ID:859816 發(fā)表于 2021-4-1 20:15 | 只看該作者
這個里面沒有hex文件啊
回復

使用道具 舉報

9#
ID:887933 發(fā)表于 2021-4-19 09:11 | 只看該作者
王家光軍 發(fā)表于 2021-3-20 22:31
為啥我一打開isis他就顯示什么新設計,然后里面什么也沒有啊

你需要下載protues 8的版本
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

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

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

快速回復 返回頂部 返回列表