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

QQ登錄

只需一步,快速開始

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

51單片機(jī)PID控制電壓的仿真和源程序

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
給51黑電子論壇的朋友們奉獻(xiàn)一個(gè)51單片機(jī)做的pid電壓控制的仿真,上面是仿真圖。

源程序:
  1. #include<reg52.h>
  2. #include "ADC.h"
  3. #include "LCD1602.h"
  4. #include "PID.h"

  5. uchar str[]="Set the voltage!";
  6.    
  7. float INPUT=2.5;
  8. float out;

  9. uchar DA,AD;//AD,DA為0-255

  10. void key_process()
  11. {
  12.         uchar key;
  13.         if(P3==0xff)
  14.         {
  15.                 delay(100);
  16.                        
  17.                 key=P3;       
  18.                 switch (key)
  19.                 {
  20.                     case 0xFE: INPUT=INPUT+1;     break;
  21.                         case 0xFD: INPUT=INPUT-1;     break;
  22.                         case 0xFB: INPUT=INPUT+0.1;          break;
  23.                         case 0xF7: INPUT=INPUT-0.1;   break;
  24.                         case 0xEF: INPUT=INPUT+0.01;  break;
  25.                         case 0xDF: INPUT=INPUT-0.01;  break;
  26.                     default: break;
  27.                 }
  28.                 if(INPUT>5.0)
  29.                 {
  30.                         INPUT=5.0;
  31.                 }
  32.                 else if(INPUT<0.0)
  33.                 {
  34.                         INPUT=0.0;
  35.                 }
  36.         }
  37. }

  38. void LCD_voltage()
  39. {
  40.         uint voltage;
  41.         uchar i;
  42.         uchar tab[5];
  43.         voltage=(uint)(INPUT*100);
  44.         tab[0]=voltage/100+'0';
  45.         tab[1]='.';
  46.         tab[2]=voltage%100/10+'0';
  47.         tab[3]=voltage%10+'0';
  48.         tab[4]='V';
  49.         write_com(0xc0);
  50.         for(i=0;i<5;i++)
  51.         {
  52.                 write_data(tab[i]);
  53.         }
  54. }

  55. void main()
  56. {
  57.         uchar i;

  58.         pid_init();
  59.         LCD_init();

  60.         write_com(0x80);
  61.         for(i=0;i<16;i++)
  62.         write_data(str[i]);

  63.         while(1)
  64.         {
  65.                 key_process();
  66.                 LCD_voltage();
  67.                 out=pid_process();//讀取PID運(yùn)算結(jié)果
  68.                    DA=(uchar)(out*255/5);//轉(zhuǎn)換成DA數(shù)據(jù)
  69.         P0=DA;                          //轉(zhuǎn)換成對(duì)應(yīng)的電壓值
  70.                 AD=ADC0832(0);    //AD采集DA所輸出的電壓值
  71.                 y_cur=(float)AD*5/255;//反饋給PID
  72.         }
  73. }
復(fù)制代碼



PID控制電壓.rar

96.05 KB, 下載次數(shù): 161, 下載積分: 黑幣 -5

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

使用道具 舉報(bào)

沙發(fā)
ID:1939 發(fā)表于 2016-10-25 11:20 | 只看該作者
多謝分享,下載來研究下。
回復(fù)

使用道具 舉報(bào)

板凳
ID:570565 發(fā)表于 2020-4-12 09:38 | 只看該作者
謝謝!
回復(fù)

使用道具 舉報(bào)

地板
ID:81918 發(fā)表于 2020-4-12 12:42 | 只看該作者
多謝分享,下載來研究下。
回復(fù)

使用道具 舉報(bào)

5#
ID:294062 發(fā)表于 2021-6-6 10:21 | 只看該作者
有參考價(jià)值
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

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

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