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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機溫度控制PID算法

[復制鏈接]
跳轉到指定樓層
樓主
ID:492205 發表于 2019-3-16 20:44 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
  1. #include <main.h>
  2. extern unsigned char time_value;
  3. extern bit flag;
  4. int PWM=0;
  5. int PWM_I,PWM_P;
  6. unsigned char time_value=0;
  7. bit flag;
  8. uint temp_m1=0;
  9. int temp_m=0;  //溫度放大100倍后的中轉值
  10. int set_temp=0; //設置溫度*100
  11. void InitTimer0(void)
  12. {
  13.     TMOD = 0x01;
  14.     TH0 = 0x0EC;
  15.     TL0 = 0x078;
  16.     EA = 1;
  17.     ET0 = 1;
  18.     TR0 = 1;
  19. }
  20. void main()//主函數
  21. {
  22.     init();//初始化函數
  23.     pid_init (&temp_PID);
  24.     InitTimer0();
  25.     temp_PID.Proportion =120;              //  Set PID Coefficients   比例
  26.     temp_PID.Integral   =5;                            //積分
  27.     temp_PID.Derivative =2;                            //導數



  28.         while(1)
  29.         {
  30.                 temp_control();//控制按鍵函數
  31.                 if(time_value<PWM)
  32.                 {
  33.                         heatting=1;
  34.                 }
  35.                 else
  36.                 {
  37.                 heatting=0;
  38.                 }
  39.                         
  40.                 if(time_value==30)            
  41.                 {               
  42.                         display_real_tenp(temp_m1);
  43.             }//顯示函數        
  44.             if(time_value==60)
  45.                         temp_m=unnormal_proccessing(temp_m1);//溫度轉換函數*100
  46.                 if(time_value==100)
  47.                 {
  48.                         if(set_temp-temp_m>250)
  49.                         {
  50.                                 PWM=PWM_MAX;
  51.                         }
  52.                         else
  53.                         {
  54.                                 PWM_I=pid_calc(&temp_PID,temp_m);
  55.                                 PWM  =PWM_I ;
  56.                                 if( PWM>=100)PWM=100;
  57.                                 else if(PWM<=PWM_MIN)  PWM=PWM_MIN;
  58.                         }
  59.                            
  60.                           
  61.                 }
  62.                 if(time_value==120)
  63.                 {               
  64.                         PWM_P=PWM/2;
  65.                         LcdWriteCom(0x80+0X40+0x0C);
  66.                         LcdWriteData('0'+PWM_P/100);
  67.                         LcdWriteCom(0x80+0X40+0x0D);
  68.                         LcdWriteData('0'+PWM_P%100/10);
  69.                          LcdWriteCom(0x80+0X40+0x0E);
  70.                         LcdWriteData('0'+PWM_P%10);
  71.                 }
  72.         }               
  73. }

  74. void init()//初始化函數
  75. {
  76.         uint i,j;
  77.         //函數初始化
  78.         LcdInit();//LCD初始化函數
  79.         Ds18b20Init();
  80.         //I/O口初始化
  81.         heatting=0;//不制熱  
  82.            //LCD初始化顯示
  83.         LcdWriteCom(0x80);//第一行顯示
  84.         j=strlen(num1);
  85.         for(i=0; i<j; i++)
  86.         {
  87.                 LcdWriteData(num1[i]);        
  88.                 delay_ms(1);
  89.         }
  90.         LcdWriteCom(0x80+0x40);//第二行顯示
  91.         j=strlen(num2);
  92.         for(i=0; i<j; i++)
  93.         {
  94.                 LcdWriteData(num2[i]);        
  95.                 delay_ms(1);
  96.         }
  97.         LcdWriteCom(0x04);  //關閉寫一個指針加1
  98. }

  99. uint get_temp(uint temp)//計算溫度函數
  100. {
  101.         float tp;
  102.         tp=temp;//因為數據處理有小數點所以將溫度賦給一個浮點型變量
  103.         //如果溫度是正的那么,那么正數的原碼就是補碼它本身
  104.         temp=tp*0.0625*100+0.5;        
  105.         //留兩個小數點就*100,+0.5是四舍五入,因為C語言浮點數轉換為整型的時候把小數點
  106.         //后面的數自動去掉,不管是否大于0.5,而+0.5之后大于0.5的就是進1了,小于0.5的就
  107.         //算加上0.5,還是在小數點后面。
  108.         return temp;
  109. }

  110. void display_real_tenp(uint temp)//實時溫度顯示函數
  111. {
  112.         uchar datas[] = {0, 0, 0, 0}; //定義數組
  113.         datas[0] = temp % 10000 / 1000;
  114.         datas[1] = temp % 1000 / 100;
  115.         datas[2] = temp % 100 / 10;
  116.         datas[3] = temp % 10;
  117.         LcdWriteCom(0x80+0x0a);                 //寫地址 80表示初始地址
  118.         LcdWriteData('0'+datas[0]); //十位
  119.         LcdWriteCom(0x80+0x0b);        //寫地址 80表示初始地址
  120.         LcdWriteData('0'+datas[1]); //個位

  121.     LcdWriteCom(0x80+0x0d);         //寫地址 80表示初始地址
  122.         LcdWriteData('0'+datas[2]); //顯示小數點  

  123.         LcdWriteCom(0x80+0x0e);                 //寫地址 80表示初始地址
  124.         LcdWriteData('0'+datas[3]); //顯示小數點  

  125. }

  126. void temp_control()//控制溫度上下限函數
  127. {
  128.         if(limit_choise==0)//選擇按鍵
  129.         {
  130.                 delay_ms(5);
  131.                 if(limit_choise==0)
  132.                 {
  133.                         while(!limit_choise);
  134.                         limit_choise_num++;
  135.                         if(limit_choise_num>=2)
  136.                         {
  137.                     limit_choise_num=0;
  138.                         }
  139.                 }
  140.         }
  141.         if(limit_choise_num==0)//正常顯示
  142.         {
  143.                 LcdWriteCom(0x0c);//關閉光標
  144.         }                 
  145.         if(limit_choise_num==1)//調節上限溫度
  146.         {
  147.                 LcdWriteCom(0x80+0X40+2);
  148.                 LcdWriteCom(0x0f);//開啟光標
  149.                         if(increase_temperature==0)//增加溫度
  150.                         {
  151.                                 delay_ms(5);
  152.                                 if(increase_temperature==0)
  153.                                 {
  154.                                         while(!increase_temperature);
  155.                                         up_limit_temp++;
  156.                                         if(up_limit_temp>=100)
  157.                                         {
  158.                                                 up_limit_temp=0;
  159.                                         }
  160.                                         //寫入新數據
  161.                                         LcdWriteCom(0x80+0X40+0x03);
  162.                                         LcdWriteData('0'+up_limit_temp/10);
  163.                                         LcdWriteCom(0x80+0X40+0x04);
  164.                                LcdWriteData('0'+up_limit_temp%10);
  165.                                   LcdWriteCom(0x80+0X40+2);//光標回寫
  166.                                 }
  167.                         }
  168.                 if(reduce_temperature==0)//減少溫度
  169.                 {
  170.                         delay_ms(5);
  171.                         if(reduce_temperature==0)
  172.                         {
  173.                                 while(!reduce_temperature);
  174.                                 up_limit_temp--;
  175.                                 if(up_limit_temp<0)
  176.                                 {
  177.                                         up_limit_temp=99;
  178.                                  }
  179.                                 //寫入新數據
  180.                                 LcdWriteCom(0x80+0X40+0x03);
  181.                                 LcdWriteData('0'+up_limit_temp/10);
  182.                                  LcdWriteCom(0x80+0X40+0x04);
  183.                                 LcdWriteData('0'+up_limit_temp%10);
  184.                                 LcdWriteCom(0x80+0X40+2);//光標回寫
  185.                         }
  186.                 }
  187.         }
  188.                 set_temp=up_limit_temp*100;
  189.         temp_PID.SetPoint   =set_temp;
  190. }

  191. int unnormal_proccessing(uint temp)//溫度轉換函數
  192. {
  193.         uchar datas[] = {0, 0, 0, 0}; //定義數組
  194.         int temp1=0;

  195.         datas[0] = temp % 10000 / 1000;
  196.          datas[1] = temp % 1000 / 100;
  197.         datas[2] = temp % 100 / 10;
  198. }
復制代碼
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:1 發表于 2019-3-18 04:05 | 只看該作者
本帖需要重新編輯補全電路原理圖,源碼,詳細說明與圖片即可獲得100+黑幣(帖子下方有編輯按鈕)
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 天天色图 | 视频一区二区中文字幕 | 亚洲国产精品久久久久秋霞不卡 | 蜜臀网站| 人人做人人澡人人爽欧美 | 91精品久久久久久久久中文字幕 | 91传媒在线观看 | 国产目拍亚洲精品99久久精品 | 成人在线观看网站 | 亚洲成av人片在线观看无码 | 免费观看色 | 欧美a v在线 | 中文字幕日韩三级 | 狠狠干狠狠插 | 精品国产乱码久久久久久88av | 色婷婷久久久亚洲一区二区三区 | 亚洲电影第1页 | 精品一区二区观看 | 91精品国产乱码久久久久久 | 91精品久久久久久久久久入口 | 成人久久久 | 免费看国产一级特黄aaaa大片 | 欧美二区乱c黑人 | 亚洲精品在线视频 | 久久国产欧美日韩精品 | 亚洲性视频网站 | 国产精品伦理一区二区三区 | 久久久精品一区 | 国产午夜精品一区二区三区四区 | 亚洲成av | 精品成人av | 久久国产综合 | 一区二区三区国产 | 国产乱码精品一品二品 | 中文字幕在线视频免费观看 | 黄色成人免费在线观看 | 成人免费看黄网站在线观看 | 中文字幕一区在线观看视频 | 日韩精品一 | 久久在线 | 91在线视频播放 |