找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 8307|回復(fù): 13
打印 上一主題 下一主題
收起左側(cè)

STC12C5A60S2單片機(jī)PID溫度調(diào)節(jié)程序

  [復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:379018 發(fā)表于 2018-12-6 19:27 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
采用DS18B20采集溫度,電熱絲加熱。或者是專用模塊。

單片機(jī)源程序如下:
  1. #include "pid.h"

  2. PID pid; //存放PID算法所需要的數(shù)據(jù)


  3. void PID_Calc()  //pid計(jì)算
  4. {
  5.         float DelEk;
  6.         float ti,ki;
  7.         float td;
  8.         float kd;
  9.         float out;

  10. if(pid.C1ms<(pid.T/10))  //計(jì)算周期未到
  11. {
  12.     return ;
  13. }

  14. pid.Ek=pid.Sv-pid.Pv;   //得到當(dāng)前的偏差值
  15. pid.Pout=pid.Kp*pid.Ek;      //比例輸出

  16. pid.SEk+=pid.Ek;        //歷史偏差總和

  17. DelEk=pid.Ek-pid.Ek_1;  //最近兩次偏差之差

  18. ti=pid.T/pid.Ti;
  19. ki=ti*pid.Kp;

  20.   pid.Iout=ki*pid.SEk;//*pid.Kp;  //積分輸出

  21. td=pid.Td/pid.T;
  22. kd=pid.Kp*td;

  23.   pid.Dout=kd*DelEk;    //微分輸出

  24. out= pid.Pout+ pid.Iout+ pid.Dout;

  25. //////////////////////////////////////////////////////////

  26. if(out>pid.pwmcycle)
  27. {
  28.   pid.OUT=pid.pwmcycle;
  29. }
  30. else if(out<0)
  31. {
  32.   pid.OUT=pid.OUT0;
  33. }
  34. else
  35. {
  36.   pid.OUT=out;
  37. }
  38. pid.Ek_1=pid.Ek;  //更新偏差

  39. pid.C1ms=0;

  40. }

  41. /*====================================
  42. 初始化  PID  函數(shù)
  43. =================================*/
  44. void PID_Init()
  45. {
  46.     pid.Sv=40;//用戶設(shè)定溫度
  47.         pid.Kp=30;
  48.         pid.T=1000;//PID計(jì)算周期
  49.     pid.Ti=500000;//積分時(shí)間
  50.         pid.Td=1000;//微分時(shí)間
  51.         pid.pwmcycle=200;//pwm周期1000
  52.         pid.OUT0=10;
  53. }
復(fù)制代碼

主程序:
  1. #include "DS18B20.h"
  2. #include "pid.h"
  3. #include "LCD.H"

  4. sbit pwmout=P1^5;          //PWM輸出口,此口可任意設(shè)定
  5. sbit wela=P2^7;
  6. sbit dula=P2^6;
  7. uchar count;           //占空比最小單位,也是以后的計(jì)數(shù)值
  8. void PID_out()  //輸出PID運(yùn)算結(jié)果到負(fù)載---每1ms被調(diào)用1次
  9. {
  10.    static u16 pw;
  11.          pw++;
  12.          if(pw>=pid.pwmcycle)  //
  13.          {
  14.            pw=0;
  15.          }
  16.           //0  ~  pid.pwmcycle-1
  17.          
  18.          if(pw<pid.OUT)
  19.          {
  20.            pwmout=0;//加熱
  21.          }
  22.          else
  23.          {
  24.            pwmout=1;//停止加熱
  25.          }
  26.          
  27. }
  28. void init()
  29. {
  30.         TMOD=0x11;          
  31.         TH1=(65536-9174)/256;           //65526/256         這兩句記錄1個(gè)脈沖,即10毫秒產(chǎn)生一個(gè)中斷
  32.         TL1=(65536-9174)%256;           //65526%256         
  33.         TH0=(65536-9174)/256;           //65526/256         這兩句記錄500個(gè)脈沖,即10m秒產(chǎn)生一個(gè)中斷
  34.         TL0=(65536-9174)%256;           //65526%256         
  35.         EA=1;                   //開總中斷
  36.         ET0=1;                   //開定時(shí)器0中斷
  37.         ET1=1;                   //開定時(shí)器1中斷
  38.         pwmout=0;                   //先置輸出口為低電平
  39.         TR0=1;                        //以上設(shè)置完畢后,最后開啟定時(shí)器0
  40.         TR1=1;                        //以上設(shè)置完畢后,最后開啟定時(shí)器1
  41. }
  42. void tim0() interrupt 1                 //定時(shí)器0中斷函數(shù)
  43. {

  44.         TH0=(65536-9174)/256;
  45.         TL0=(65536-9174)%256;
  46.         pid.C1ms++;
  47.         PID_Calc();       
  48.        
  49. }
  50. /**/         
  51. void tim1() interrupt 3                 //定時(shí)器0中斷函數(shù)
  52. {
  53.         TH1=(65536-9174)/256;
  54.         TL1=(65536-9174)%256;                 
  55.         PID_out();
  56. }

  57. void main()
  58. {
  59.         uint i;
  60.         uchar datas1[]={0,0,0};
  61.         wela=0;
  62.         dula=0;
  63.         delay(2);
  64.         lcd_init();       
  65.         PID_Init();       
  66.         init();
  67. /*        ds_init( );//初始化DS18B20
  68.         write_byte(0xcc);//發(fā)送跳躍ROM指令
  69.         write_byte(0x4e);//寫暫存器指令
  70.         write_byte(0x7f);
  71.         write_byte(0xf7);
  72.         write_byte(0x1f);//配置工作在9位模式下
  73.         ds_init();//初始化DS18B20
  74.         write_byte(0xcc);//發(fā)送跳躍ROM指令
  75.         write_byte(0x48);         */       
  76.                 while(1)
  77.                 {                  
  78.                 datas1[2]=(int)pid.OUT%1000/100;
  79.                 datas1[3]=(int)pid.OUT%100/10;
  80.                 datas1[4]=(int)pid.OUT%10;
  81.                 lcd_pos(2,0);
  82.                 for(i=2;i<5;i++)
  83.                 write_dat(0x30+datas1[i]);       
  84.                 if(pid.C1ms>(pid.T/11))
  85.                 {
  86.                 Display_temp();
  87.                 }       
  88.                 }
  89. }
復(fù)制代碼


所有資料51hei提供下載:
PID溫度控制.zip (50.08 KB, 下載次數(shù): 335)


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

使用道具 舉報(bào)

沙發(fā)
ID:277550 發(fā)表于 2018-12-31 21:58 | 只看該作者
不錯(cuò),不過少了lcd.c文件
回復(fù)

使用道具 舉報(bào)

板凳
ID:412814 發(fā)表于 2019-1-25 14:27 | 只看該作者
這個(gè)真挺好,先研究下。謝謝樓主
回復(fù)

使用道具 舉報(bào)

地板
ID:475247 發(fā)表于 2019-2-10 16:54 | 只看該作者
devcang 發(fā)表于 2018-12-31 21:58
不錯(cuò),不過少了lcd.c文件

LCD就用不到吧,畢竟是很基礎(chǔ)的東西

評(píng)分

參與人數(shù) 2黑幣 +47 收起 理由
春風(fēng)十里吹 + 12 很給力!
jinsheng7533967 + 35

查看全部評(píng)分

回復(fù)

使用道具 舉報(bào)

5#
ID:71618 發(fā)表于 2019-4-25 11:09 | 只看該作者
學(xué)習(xí)一下!
回復(fù)

使用道具 舉報(bào)

6#
ID:524445 發(fā)表于 2019-4-29 15:11 | 只看該作者
不錯(cuò)!比較簡(jiǎn)單,好理解!
回復(fù)

使用道具 舉報(bào)

7#
ID:607640 發(fā)表于 2019-11-4 20:01 | 只看該作者
你真是個(gè)好家伙,謝謝分享!
回復(fù)

使用道具 舉報(bào)

8#
ID:607640 發(fā)表于 2019-11-4 20:02 | 只看該作者
感謝分享!
回復(fù)

使用道具 舉報(bào)

9#
ID:97678 發(fā)表于 2019-12-4 20:43 | 只看該作者
初學(xué)者,最好還是文件完整,學(xué)習(xí)起來比較方便。希望補(bǔ)充完整
回復(fù)

使用道具 舉報(bào)

10#
ID:676336 發(fā)表于 2020-2-20 20:27 | 只看該作者
為什么if(pw<pid.out)就加熱,不然就停止加熱,這里不懂
回復(fù)

使用道具 舉報(bào)

11#
ID:299193 發(fā)表于 2020-3-11 01:03 | 只看該作者
真不錯(cuò),謝謝了!
回復(fù)

使用道具 舉報(bào)

12#
ID:299193 發(fā)表于 2020-3-13 22:41 | 只看該作者
不錯(cuò),好好學(xué)習(xí)一下
回復(fù)

使用道具 舉報(bào)

13#
ID:364328 發(fā)表于 2020-3-19 21:10 | 只看該作者
只有程序沒有電路圖嗎請(qǐng)問
回復(fù)

使用道具 舉報(bào)

14#
ID:239055 發(fā)表于 2020-3-20 07:07 來自手機(jī) | 只看該作者
學(xué)習(xí)了,51黑的資源有點(diǎn)少,希望大家多參與
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

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

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