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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1826|回復: 0
收起左側

單片機DS18B20 DHT11溫控風扇程序與Proteus仿真 帶PID

[復制鏈接]
ID:1105344 發表于 2023-12-20 13:44 | 顯示全部樓層 |閱讀模式
利用51單片機和溫度傳感器DS18B20和濕度傳感器DHT11,STC89C52R作為處理器,通過單總線將采集數據實時顯示于本地LCD顯示屏端。用電機風扇轉速,溫度控制風扇調整高時風扇轉速加快,溫度低時風扇轉速減小,濕度高時風扇轉速加快,濕度低時風扇轉速減小。四個按鍵分別控制:切換控制溫度/濕度;增大要控制的溫度/濕度的標準;減小要控制的溫度/濕度的標準;切換控制方式(PID算法/檔位)。

仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)
51hei.gif
單片機程序
  1. #include <REG52.H>
  2. #include "intrins.h"
  3. #include "LCD1602.h"        //包含LCD1602頭文件
  4. #include "Delay.h"                //包含Delay頭文件
  5. #include "DS18B20.h"
  6. #include "DHT11.h"
  7. #include "Timer0.h"

  8. sbit Motor=P0^0;
  9. sbit P34 = P3^4;
  10. sbit P35 = P3^5;
  11. sbit P36 = P3^6;
  12. sbit P37 = P3^7;
  13. float T = 0;
  14. extern unsigned char  hum;//濕度

  15. unsigned char k1 = 5, k2 = 1, k3 = 10;
  16. int sbz = 38, speed = 0, wbz = 25;
  17. float bz = 0, xz = 0;
  18. float p = 0,i = 0,d = 0;
  19. float pid = 0;
  20. int Compare = 0;
  21. unsigned char DHTC = 0,DHTF = 0;
  22. unsigned char sw = 0; //0濕度 , 1溫度
  23. unsigned char kz = 0; //0檔位控制, 1pid
  24. unsigned char key = 0, key_keyNumber = 0;

  25. void main()
  26. {        
  27.         Motor = 0;
  28.         LCD_Init();
  29.         DHT11_Init();
  30.         DS18B20_ConvertT();
  31.         Delay(1000);

  32.         Timer0Init();
  33.         Timer1Init();
  34.         TR0 = 1;                                //定時器0開始計時
  35.         ET0=1;
  36.         TR1 = 1;
  37.         ET1 = 1;
  38.         EA=1;//開啟總中斷

  39.         while(1)
  40.         {        
  41.                 LCD_ShowString(1,1,"Tem:");
  42.                 LCD_ShowString(2,1,"Hum:");
  43.                 LCD_ShowChar(1,8,'.');        
  44.                 LCD_ShowChar(2,7,'%');

  45.                 TR0 = 0;
  46.                 TR1 = 0;
  47.                 DS18B20_ConvertT();        //轉換溫度
  48.                 T=DS18B20_ReadT();        //讀取溫度
  49.                 if(DHTF == 1)
  50.                 {
  51.                         DHT11_receive();
  52.                         DHTF = 0;
  53.                 }        
  54.                 TR0 = 1;
  55.                 TR1 = 1;

  56.                 LCD_ShowNum(1,5,T,3);                //顯示溫度整數部分
  57.                 LCD_ShowNum(1,9,(unsigned long)(T*10000)%10000,4);//顯示溫度小數部分
  58.                 LCD_ShowNum(2,5,hum,2);

  59.                 //LCD_ShowNum(1,5,Compare,4);
  60.                 //LCD_ShowNum(1,10,hu,2);LCD_ShowSignedNum(2,1,p,4);LCD_ShowSignedNum(2,6,i,4);LCD_ShowSignedNum(2,11,d,4);

  61.                 key = key_keyNumber;
  62.                 key_keyNumber = 0;
  63.                 {
  64.                         if(key == 1)
  65.                         {
  66.                                 sw = 1 - sw;
  67.                         }
  68.                         else if(key == 2)
  69.                         {
  70.                                 if(sw == 0)
  71.                                         sbz++;
  72.                                 else
  73.                                         wbz++;
  74.                         }
  75.                         else if(key == 3)
  76.                         {
  77.                                 if(sw == 0)
  78.                                         sbz--;
  79.                                 else
  80.                                         wbz--;
  81.                         }
  82.                         else if(key == 4)
  83.                         {
  84.                                 kz = 1 - kz;
  85.                         }
  86.                 }

  87.                 if(sw == 1)
  88.                 {
  89.                         LCD_ShowNum(1,14,wbz,3);
  90.                         LCD_ShowString(2,14,"   ");
  91.                         xz = T;
  92.                         bz = wbz;
  93.                 }
  94.                 else
  95.                 {
  96.                         LCD_ShowNum(2,14,sbz,3);
  97.                         LCD_ShowString(1,14,"   ");
  98.                         xz = hum;
  99.                         bz = sbz;
  100.                 }

  101.                 if(kz)
  102.                 {
  103.                         LCD_ShowString(2,10,"PID");
  104.                         d = xz - bz - p;
  105.                         p = xz - bz;
  106.                         i += p;
  107.                         pid += (k1*p + k2*i + k3*d);

  108.                         if(pid>=0 && pid<=1000)
  109.                         {
  110.                                 Compare = pid;
  111.                         }
  112.                         else if(pid<0)
  113.                         {
  114.                                 Compare = 0;
  115.                                 pid = 0;
  116.                         }
  117.                         else
  118.                         {
  119.                                 Compare = 1000;
  120.                                 pid = 1000;
  121.                         }
  122.                 }
  123.                 else
  124.                 {
  125.                         LCD_ShowString(2,10,"   ");
  126.                         p = 0;i = 0; d = 0; pid = 0;
  127.                         if(xz - bz >=10)
  128.                         {
  129.                                 speed = 1000;
  130.                         }
  131.                         else if(xz - bz <=0)
  132.                         {
  133.                                 speed = 0;
  134.                         }
  135.                         else
  136.                         {
  137.                                 speed = (int)((xz - bz)*100);
  138.                         }
  139.                         Compare = speed ;
  140.                 }
  141.                 Delay(50);
  142.         }
  143. }

  144. unsigned char Key_GetState()
  145. {
  146.         unsigned char keynum = 0;
  147.         if(P34 == 0){keynum=1;}        //一有按鍵被按下,標志位keynum立即置位并返回,給key_loop函數處理
  148.         if(P35 == 0){keynum=2;}
  149.         if(P36 == 0){keynum=3;}
  150.         if(P37 == 0){keynum=4;}
  151.         return keynum;
  152. }

  153. void key_loop()
  154. {
  155.         static unsigned char before_state,now_state;
  156.         before_state = now_state;
  157.         now_state = Key_GetState();                //獲取按鍵標志位
  158.         if(before_state == 1 && now_state == 0)        
  159.         {
  160.                 key_keyNumber = 1;        //全局變量key_keyNumber置1,使用key_return函數返回給main函數使用
  161.         }
  162.         if(before_state == 2 && now_state == 0)        
  163.         {
  164.                 key_keyNumber = 2;
  165.         }
  166.         if(before_state == 3 && now_state == 0)        
  167.         {
  168.                 key_keyNumber = 3;
  169.         }
  170.         if(before_state == 4 && now_state == 0)        
  171.         {
  172.                 key_keyNumber = 4;
  173.         }
  174. }

  175. void Timer0_Routine() interrupt 1
  176. {
  177.         static unsigned int T0Count;
  178.         TL0 = 0xA4;                                //設置定時初始值
  179.         TH0 = 0xFF;
  180.         T0Count++;
  181.         if(T0Count < Compare)
  182.         {
  183.                 Motor = 1;
  184.         }
  185.         else
  186.         {
  187.                 Motor = 0;
  188.         }
  189.         if (T0Count >= 1000)
  190.         {
  191.                 T0Count = 0;
  192.         }
  193. }

  194. void Timer1_Routine() interrupt 3
  195. {
  196.         static unsigned int T1Count;
  197.         TL1 = 0x00;                                
  198.         TH1 = 0xDC;
  199.         T1Count++;
  200.         DHTC ++;
  201.         if(T1Count>=20)
  202.         {
  203.                 key_loop();
  204.                 T1Count = 0;
  205.         }
  206.         if(DHTC >=75)
  207.         {
  208.                 DHTC = 0;
  209.                 DHTF = 1;
  210.         }
  211. }
復制代碼
Proteus8.13仿真程序下載: 仿真 代碼 keil文件.7z (79.93 KB, 下載次數: 109)

評分

參與人數 2黑幣 +80 收起 理由
lyxxzrb + 30 贊一個!
admin + 50 共享資料的黑幣獎勵!

查看全部評分

回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日韩精品极品视频在线观看免费 | 91精品国产91久久久久久吃药 | 韩日视频在线观看 | caoporn免费在线视频 | 日本三级线观看 视频 | 秋霞av国产精品一区 | 中文字幕一级 | 国产精品一区二区不卡 | 亚洲精品一二区 | 色婷婷婷婷色 | 亚洲国产精品美女 | 久久国产精品一区 | 国产在线观看网站 | 欧美国产视频一区二区 | 毛片免费在线 | 亚洲精品乱码久久久久久按摩观 | www.色五月.com| 欧美中文字幕在线观看 | 国产丝袜一区二区三区免费视频 | 日韩中文字幕一区 | 日韩中文字幕 | 中文精品视频 | 国产精品久久久久影院色老大 | 91精品国产综合久久婷婷香蕉 | 99资源| 中文字幕一区二区三区四区五区 | 日韩美女爱爱 | 国产一区二区三区四区区 | 一区二区三区视频在线 | 欧美激情视频一区二区三区在线播放 | 精品视频久久久 | 黄色大片免费网站 | 美女黄网 | www国产成人免费观看视频,深夜成人网 | 亚洲精品一 | 国产亚洲第一页 | 中国一级毛片免费 | 亚洲精品乱码久久久久v最新版 | 特一级毛片 | 中文字幕av一区二区三区 | 亚洲精品日韩精品 |