找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

帖子
查看: 5993|回復(fù): 4
打印 上一主題 下一主題
收起左側(cè)

ATMEGA16A單片機的多點測溫系統(tǒng)完成版 Proteus仿真程序

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:525479 發(fā)表于 2019-6-26 20:28 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機源程序如下:
  1. /**************************************************************************
  2. *實驗名   :DS18B20模塊
  3. *實驗效果 :單總線調(diào)試,此代碼可用于測多點溫度
  4. *顯示     :此代碼用了LCD顯示讀取地址位
  5. *平臺     : Atmega16,基于8MHz
  6. *調(diào)試時間 :2019年6月7日 23:14
  7. **************************************************************************/
  8. #include <iom16v.h>
  9. #include <macros.h>
  10. #include "ds18b20.h"
  11. //#include "lcd1602.h"
  12. //微妙級延遲函數(shù)avr 16 以8MHz為例加上for循環(huán),他需要執(zhí)行1142條指令才是1ms,
  13. void delay_1us(void)
  14. {
  15.   asm("nop");
  16. }
  17. void Delay_1us(unsigned int x)//所以這里存在一定的偏差。
  18. {
  19.    unsigned int i=0;     
  20.    for( i=0;i<x;i++)delay_1us();
  21. }
  22. //DS18B20復(fù)位函數(shù)
  23. void DS18B20_Reset(void)
  24. { /*
  25.     DQ_1;   //輸出低電平
  26. DQ_OUT;   //DQ為輸出狀態(tài)
  27. DQ_0;   //輸出低電平
  28. Delay_1us(500);   //延遲500微妙
  29. DQ_1;    //釋放總線
  30. Delay_1us(60);   //延遲60微妙
  31. DQ_IN;   //DQ位輸入狀態(tài)
  32. while(DQ_RD); //等待從機DS18B20應(yīng)答(低電平有效)
  33. while(!(DQ_RD));*/ //等待從機DS18B20釋放總線機DS18B20釋放總線
  34.     //這里要加個括號判斷優(yōu)先級
  35.   while(1)
  36. {
  37.        DQ_OUT;
  38.     DQ_0;
  39.     Delay_1us(480);   //延時480us
  40.     DQ_1;
  41.     Delay_1us(60);
  42.     DQ_IN;  //設(shè)置為輸入端,接收應(yīng)答信號
  43.     if(!(DQ_RD))      //收到應(yīng)答信號
  44.    {
  45.   DQ_1;
  46.   Delay_1us(240);
  47.   break;
  48.    }  //延時240us
  49. }  
  50. }
  51. //DS18B20寫字節(jié)函數(shù)
  52. void DS18B20_Write(unsigned char Data)
  53. {
  54. unsigned char i;
  55. DQ_OUT;  //DQ為輸出
  56. for(i=0;i<8;i++)
  57. {
  58.   DQ_0;   //拉低總線
  59.   Delay_1us(10);     //延遲10微妙(最大15微妙)
  60.   if(Data&0x01)DQ_1;
  61.   else DQ_0;   
  62.   Delay_1us(40);      //延遲40微妙(最大45微妙)
  63.   DQ_1;     //釋放總線
  64.   Delay_1us(1);     //稍微延遲
  65.   Data>>=1;
  66. }
  67. }
  68. //DS18B20讀字節(jié)函數(shù)
  69. unsigned char DS18B20_Read(void)
  70. {
  71. unsigned char i,Temp;         
  72. for(i=0;i<8;i++)
  73. {
  74.     Temp>>=1;      //數(shù)據(jù)右移
  75.     DQ_OUT;     //DQ為輸出狀態(tài)
  76.     DQ_0;    //拉低總線,啟動輸入
  77.     DQ_1;     //釋放總線
  78.     DQ_IN;     //DQ為輸入狀態(tài)
  79.     Delay_1us(2);
  80.     if(DQ_RD) Temp|=0x80;
  81.     Delay_1us(60);      //延遲45微妙(最大45微妙)
  82. }

  83. return Temp;
  84. }
  85. /*void GetROMSequence()//讀地址號代碼,用lcd1602顯示
  86. {
  87. unsigned char i,temp;
  88. DS18B20_Reset();
  89. DS18B20_Write(READ_ROM);
  90. for (i = 0; i < 8; i++)
  91. ROMData1[i] = DS18B20_Read();
  92. lcd_com(0x80);   
  93. for(i=0;i<8;i++)
  94.     {
  95.        temp=ROMData1[i]>>4;
  96.        if(temp<10)
  97.        {
  98.          lcd_dat(0x30+temp);
  99.        }
  100.        else
  101.        {
  102.          lcd_dat(0x37+temp);
  103.        }
  104.        temp=ROMData1[i]&0x0f;
  105.        if(temp<10)
  106.        {
  107.          lcd_dat(0x30+temp);
  108.        }
  109.        else
  110.        {
  111.          lcd_dat(0x37+temp);
  112.        }
  113.     }
  114. }*/
  115. //讀溫度,然后拆字用結(jié)構(gòu)體存起來。
  116. TEMPDATA ReadTemperature(const unsigned char *pMatchData)
  117. {
  118. TEMPDATA TempData;
  119. unsigned int iTempDataH;
  120. unsigned char btDot, iTempDataL;
  121. static unsigned char i = 0;
  122. TempData.btNegative = 0;      //為0溫度為正

  123. DS18B20_Reset();   //DS18B20復(fù)位
  124. DS18B20_Write(SKIP_ROM);  //跳過ROM
  125. DS18B20_Write(TEMP_SWITCH);  //溫度轉(zhuǎn)換

  126. DS18B20_Reset();   //DS18B20復(fù)位
  127. DS18B20_Write(MATCH_ROM);//讀取地址
  128. for (i = 0; i < 8; i++) DS18B20_Write(*(pMatchData + i));
  129. //DS18B20_Write(SKIP_ROM);  //跳過ROM,單個讀取直接跳過ROM
  130. DS18B20_Write(READ_MEMORY);  //讀取RAM      //讀數(shù)據(jù)

  131. iTempDataL = DS18B20_Read();
  132. iTempDataH = DS18B20_Read();
  133. DS18B20_Reset(); //讀取數(shù)值完要復(fù)位,要不然讀取不了數(shù)值
  134. iTempDataH <<= 8;
  135. iTempDataH |= iTempDataL;
  136. if (iTempDataH & 0x8000)
  137. {
  138.   TempData.btNegative = 1;
  139.   iTempDataH = ~iTempDataH + 1;    //負(fù)數(shù)求補
  140. }
  141. //為了省去浮點運算帶來的開銷,而采用整數(shù)和小數(shù)部分分開處理的方法(沒有四舍五入)
  142. btDot = (unsigned char)(iTempDataH & 0x000F); //得到小數(shù)部分
  143. iTempDataH >>= 4;        //得到整數(shù)部分
  144. btDot *= 5;          //btDot*10/16得到轉(zhuǎn)換后的小數(shù)數(shù)據(jù)
  145. btDot >>= 3;
  146. //數(shù)據(jù)處理
  147. TempData.btThird   = (unsigned char)iTempDataH / 100;
  148. TempData.btSecond  = (unsigned char)iTempDataH % 100 / 10;
  149. TempData.btFirst   = (unsigned char)iTempDataH % 10;
  150. TempData.btDecimal = btDot;
  151. return TempData;
  152. }
復(fù)制代碼

全部資料51hei下載地址:
基于ATMEGA16A多點測溫系統(tǒng)完成版.rar (621.51 KB, 下載次數(shù): 108)

評分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏4 分享淘帖 頂1 踩
回復(fù)

使用道具 舉報

沙發(fā)
ID:328014 發(fā)表于 2019-6-29 16:20 | 只看該作者
好資料,51黑有你更精彩!!!
回復(fù)

使用道具 舉報

板凳
ID:549610 發(fā)表于 2019-7-18 15:17 | 只看該作者
感謝樓主分享!
回復(fù)

使用道具 舉報

地板
ID:413383 發(fā)表于 2019-12-26 20:33 | 只看該作者
剛好在研究ATMEGA16A,好資料,51黑有你更精彩!!!
回復(fù)

使用道具 舉報

5#
ID:1034213 發(fā)表于 2022-6-13 00:57 | 只看該作者
感謝樓主,對我很有用
回復(fù)

使用道具 舉報

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

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表