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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3699|回復: 2
打印 上一主題 下一主題
收起左側

51單片機水箱檢測系統程序 檢測溫度ph值 PID算法控制溫度到設置值

  [復制鏈接]
跳轉到指定樓層
樓主
51單片機檢測水箱內溫度,ph值;
使用pid算法控制溫度到設置值;
普通控制ph值到設定值

溫度低,啟動加熱;PH值過高,啟動進水;PH值過低,啟動進料。
水位過高,啟動放水。

電路原理圖如下:


仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


程序流程圖



元件清單:
元件    型號    數量
單片機    AT89C51    1
電容    10uf    1
電容    30pf    2
晶振    12MHZ    1
電阻    10k    1
按鈕        7
溫度傳感器    DS18B20    1
模數芯片    ADC0832    1
電位器    1k    2
電阻    1k    4
三極管    PNP    4
繼電器    5V    4
顯示器    LCD1602    1
排阻    10k    1

單片機源程序如下:
  1. #include "reg51.h"
  2. #include "lcd1602.h"
  3. #include "Ds18b20.h"
  4. #include "ADC0832.h"
  5. #include"pid_pwm.h"
  6. #define uchar unsigned char
  7. #define uint unsigned int
  8. sbit k1=P3^2;//按鈕
  9. sbit k2=P3^3;
  10. sbit k3=P3^4;
  11. sbit k4=P3^5;
  12. sbit k5=P3^6;
  13. sbit k6=P3^7;
  14. sbit out1=P2^4;//輸出控制
  15. sbit out2=P2^5;
  16. sbit out3=P2^6;
  17. sbit out4=P2^7;

  18. uchar time=0,mode=0;//系統變量
  19. uchar wendu=0,ph=0,water=0;//溫度,pH值,水位
  20. uchar lim1=25,lim2=7,lim3=100;//閥值
  21. uchar disp1[]="T:000 P:00 H:000";
  22. uchar disp2[]="  000   00   000";
  23. uchar pwm=0;
  24. //主函數
  25. void main()
  26. {
  27.         uchar i=0;
  28.         init_1602();
  29.         TMOD|=0X01;
  30.         TH0=0X3C;
  31.         TL0=0XB0;        
  32.         ET0=1;//打開定時器0中斷允許
  33.         EA=1;//打開總中斷
  34.         TR0=1;//打開定時器
  35.         while(1)
  36.         {
  37.                 //PWM輸出
  38.                 if(i<99)
  39.                          i++;
  40.                 else
  41.                         i=0;
  42.                 if(i<pwm)
  43.                         out4=0;
  44.                 else
  45.                         out4=1;
  46.                 //按鍵檢測
  47.                 if(!k1)
  48.                 {
  49.                         if(lim1<120)
  50.                                 lim1++;
  51.                         while(!k1);
  52.                 }
  53.                 if(!k2)
  54.                 {
  55.                         if(lim1>0)
  56.                                 lim1--;
  57.                         while(!k2);
  58.                 }
  59.                 if(!k3)
  60.                 {
  61.                         if(lim2<14)
  62.                                 lim2++;
  63.                         while(!k3);
  64.                 }
  65.                 if(!k4)
  66.                 {
  67.                         if(lim2>0)
  68.                                 lim2--;
  69.                         while(!k4);
  70.                 }
  71.                 if(!k5)
  72.                 {
  73.                         if(lim3<127)
  74.                                 lim3++;
  75.                         while(!k5);
  76.                 }
  77.                 if(!k6)
  78.                 {
  79.                         if(lim3>0)
  80.                                 lim3--;
  81.                         while(!k6);
  82.                 }
  83.         }
  84. }
  85. //定時器中斷
  86. void Timer0() interrupt 1
  87. {
  88.         uint i=0;
  89.         if(time<10)//0.5s
  90.                 time++;
  91.         else
  92.         {
  93.                 time=0;
  94.                 Ds18b20ReadTemp();//測溫
  95.                 wendu=ds18b20_temp;
  96.                 ph=ADC(1);//PH
  97.                 i=ph;
  98.                 ph=i*14/127;
  99.                 water=ADC(2);//水位
  100.                 //顯示
  101.                 disp1[2]=wendu/100+0x30;
  102.                 disp1[3]=wendu%100/10+0x30;
  103.                 disp1[4]=wendu%10+0x30;
  104.                 disp1[8]=ph/10+0x30;
  105.                 disp1[9]=ph%10+0x30;
  106.                 disp1[13]=water/100+0x30;
  107.                 disp1[14]=water%100/10+0x30;
  108.                 disp1[15]=water%10+0x30;
  109.                 write_string(1,0,disp1);
  110.                 disp2[2]=lim1/100+0x30;
  111.                 disp2[3]=lim1%100/10+0x30;
  112.                 disp2[4]=lim1%10+0x30;
  113.                 disp2[8]=lim2/10+0x30;
  114.                 disp2[9]=lim2%10+0x30;
  115.                 disp2[13]=lim3/100+0x30;
  116.                 disp2[14]=lim3%100/10+0x30;
  117.                 disp2[15]=lim3%10+0x30;
  118.                 write_string(2,0,disp2);
  119.                 //PID控制
  120.                 pwm=PID(lim1,wendu);
  121.                 //PH值控制
  122.                 if(ph>lim2)
  123.                         out1=0;
  124.                 else
  125.                         out1=1;
  126.                 if(ph<lim2)
  127.                         out3=0;
  128.                 else
  129.                         out3=1;
  130.                 //水位控制
  131.                 if(water>lim3)
  132.                         out2=0;
  133.                 else
  134.                         out2=1;
  135.         }
  136.         TH0=0X3C;
  137.         TL0=0XB0;
  138. }
復制代碼
  1. #include"pid_pwm.h"

  2. uchar P_dat=1,I_dat=1,D_dat=1;//PID參數
  3. uint pid_dat[]={0,0,0,0,0}; //臨時數據
  4. //PID計算,返回占空比
  5. uchar PID(uint mub,uint dat)//調整目標+測量數據
  6. {
  7.         uchar i=0;
  8.         uint j=0,sum=0,k=0;
  9.         //存儲數據
  10.         for(i=0;i<4;i++)
  11.                 pid_dat[i]=pid_dat[i+1];
  12.         pid_dat[4]=dat;

  13.         //P調節
  14.         j=0;
  15.         if(dat<mub)
  16.         {
  17.                 j=j+(mub-dat)*P_dat;
  18.                 if(j>100)
  19.                         j=100;
  20.         }
  21.         else
  22.         {
  23.                 k=(dat-mub)*P_dat;
  24.                 if(j>k)
  25.                         j=j-k;
  26.         }
  27.         //I調節
  28.         sum=0;
  29.         for(i=0;i<5;i++)
  30.                 sum+=pid_dat[i];
  31.         sum=sum/5;
  32.         if(sum>mub)//減小
  33.         {
  34.                 k=(sum-mub)*I_dat;
  35.                 if(j>k)
  36.                         j=j-k;
  37.         }
  38.         else  //增加
  39.         {
  40.                 k=(mub-sum)*I_dat;
  41.                 j+=k;
  42.                 if(j>100)
  43.                         j=100;
  44.         }
  45.         //D調節
  46.         if(dat>pid_dat[3])//減小
  47.         {
  48.                 k=(dat-pid_dat[3])*D_dat;
  49.                 if(j>k)
  50.                         j=j-k;
  51.         }
  52.         else  //增加
  53.         {
  54.                 k=(pid_dat[3]-dat)*D_dat;
  55.                 j+=k;
  56.                 if(j>100)
  57.                         j=100;
  58.         }
  59.         return j;
  60. }
復制代碼

Keil代碼與Proteus仿真下載:
51水箱水質溫度檢測系統.7z (911.22 KB, 下載次數: 102)

評分

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

查看全部評分

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

使用道具 舉報

沙發
ID:429944 發表于 2023-12-6 08:15 | 只看該作者
P_dat=1,I_dat=1,D_dat=1;PID參數一直是不變的話是不是有什么不妥?
回復

使用道具 舉報

板凳
ID:433219 發表于 2025-3-5 10:35 | 只看該作者
PID參數一直是不變 ??? 有何意義???
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 欧美在线视频一区二区 | 岛国av一区二区三区 | 国产伦精品一区二区三区高清 | 精品在线一区二区 | 午夜精品久久久久久久久久久久 | 国产精品污www一区二区三区 | 欧美理论| 国产精品日日夜夜 | 天天操天天拍 | 狠狠操电影 | 男女羞羞在线观看 | 久久人 | 国产91精品久久久久久久网曝门 | 天天操天天干天天曰 | 精品国产区| 91在线视频免费观看 | 免费一区二区三区 | 激情欧美一区二区三区中文字幕 | 国产精品自产拍 | 国产精品久久久久久久午夜片 | 91 视频网站| av在线天堂网 | 亚洲天堂一区二区 | 成年人网站在线观看视频 | 欧美色性 | 亚洲九九 | www.嫩草| 欧美视频免费在线观看 | 日韩精品一区二区三区老鸭窝 | 一区二区三区影院 | 精品久久久久一区二区国产 | 欧美精产国品一二三区 | 久久免费看 | 三极网站| 色综合99 | 91porn国产成人福利 | 午夜一区二区三区在线观看 | 天天玩天天干天天操 | 亚洲在线 | 亚洲精品一区二区网址 | 久久午夜视频 |