標(biāo)題: ATMEGA16A單片機(jī)的多點(diǎn)測(cè)溫系統(tǒng)完成版 Proteus仿真程序 [打印本頁(yè)]

作者: zxxlw    時(shí)間: 2019-6-26 20:28
標(biāo)題: ATMEGA16A單片機(jī)的多點(diǎn)測(cè)溫系統(tǒng)完成版 Proteus仿真程序
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機(jī)源程序如下:
  1. /**************************************************************************
  2. *實(shí)驗(yàn)名   :DS18B20模塊
  3. *實(shí)驗(yàn)效果 :?jiǎn)慰偩調(diào)試,此代碼可用于測(cè)多點(diǎn)溫度
  4. *顯示     :此代碼用了LCD顯示讀取地址位
  5. *平臺(tái)     : Atmega16,基于8MHz
  6. *調(diào)試時(shí)間 :2019年6月7日 23:14
  7. **************************************************************************/
  8. #include <iom16v.h>
  9. #include <macros.h>
  10. #include "ds18b20.h"
  11. //#include "lcd1602.h"
  12. //微妙級(jí)延遲函數(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); //等待從機(jī)DS18B20應(yīng)答(低電平有效)
  33. while(!(DQ_RD));*/ //等待從機(jī)DS18B20釋放總線機(jī)DS18B20釋放總線
  34.     //這里要加個(gè)括號(hào)判斷優(yōu)先級(jí)
  35.   while(1)
  36. {
  37.        DQ_OUT;
  38.     DQ_0;
  39.     Delay_1us(480);   //延時(shí)480us
  40.     DQ_1;
  41.     Delay_1us(60);
  42.     DQ_IN;  //設(shè)置為輸入端,接收應(yīng)答信號(hào)
  43.     if(!(DQ_RD))      //收到應(yīng)答信號(hào)
  44.    {
  45.   DQ_1;
  46.   Delay_1us(240);
  47.   break;
  48.    }  //延時(shí)240us
  49. }  
  50. }
  51. //DS18B20寫(xiě)字節(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;    //拉低總線,啟動(dòng)輸入
  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()//讀地址號(hào)代碼,用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)體存起來(lái)。
  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);  //跳過(guò)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);  //跳過(guò)ROM,單個(gè)讀取直接跳過(guò)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ù)求補(bǔ)
  140. }
  141. //為了省去浮點(diǎn)運(yùn)算帶來(lái)的開(kāi)銷(xiāo),而采用整數(shù)和小數(shù)部分分開(kāi)處理的方法(沒(méi)有四舍五入)
  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多點(diǎn)測(cè)溫系統(tǒng)完成版.rar (621.51 KB, 下載次數(shù): 108)

作者: 51hei團(tuán)團(tuán)    時(shí)間: 2019-6-29 16:20
好資料,51黑有你更精彩!!!
作者: W_Cartman    時(shí)間: 2019-7-18 15:17
感謝樓主分享!
作者: hulilanyua    時(shí)間: 2019-12-26 20:33
剛好在研究ATMEGA16A,好資料,51黑有你更精彩!!!
作者: fieb    時(shí)間: 2022-6-13 00:57
感謝樓主,對(duì)我很有用





歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1