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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機PID控制螺旋槳到特定角度Proteus仿真程序

  [復制鏈接]
跳轉到指定樓層
樓主
我們單片機設計要求我們用51單片機控制螺旋槳到特定角度,并通過lcd102顯示出來,按鍵設置角度,電位器通過pcf8591讀取角度
包含pcb文件,程序,仿真,設計書等。做的仍有瑕疵希望見諒。

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


單片機源程序如下:
  1. #include <reg52.h>               
  2. #include "i2c.h"
  3. #include "delay.h"
  4. #include "1602.h"
  5. #include <stdio.h>
  6. #include <math.h>
  7. #define AddWr 0x90   //寫數據地址
  8. #define AddRd 0x91   //讀數據地址
  9. #define wait_speak 1
  10. #define speaked  0
  11. sbit PWM=P1^2;
  12. sbit led=P1^6;
  13. sbit target_up=P3^0;
  14. sbit target_down=P3^1;
  15. sbit beep=P1^5;       
  16. float target=40.0;
  17. float Kp=0.05,Ki=0.4,Kd=0.15;
  18. unsigned int value,timer1;
  19. char flag=wait_speak;
  20. unsigned char confirtime=0;
  21. extern bit ack;
  22. unsigned char ReadADC(unsigned char Chl);
  23. float pid(float input);
  24. void control();
  25. void Timer1Init();
  26. void Timer0Init();
  27. void change_target();
  28. void  beep_1s();
  29. void display();

  30. bit WriteDAC(unsigned char dat);
  31. void delay100us(int i)   //誤差 0us
  32. {
  33.     unsigned char a,b;
  34.         while(i--)
  35.     for(b=1;b>0;b--)
  36.         for(a=47;a>0;a--);
  37. }
  38. /*------------------------------------------------
  39.               主程序
  40. ------------------------------------------------*/
  41. main()
  42. {


  43. LCD_Init();           //初始化液晶
  44. DelayMs(20);          //延時有助于穩定
  45. LCD_Clear();          //清屏
  46. Timer1Init();
  47.         value=0;
  48.         led=0;
  49. while (1)              //主循環
  50.   {
  51.   control();       
  52. change_target();

  53.   }
  54. }
  55. /*------------------------------------------------
  56.              讀AD轉值程序
  57. 輸入參數 Chl 表示需要轉換的通道,范圍從0-3
  58. 返回值范圍0-255
  59. ------------------------------------------------*/
  60. unsigned char ReadADC(unsigned char Chl)
  61. {
  62.    unsigned char Val;
  63.    Start_I2c();               //啟動總線
  64.    SendByte(AddWr);             //發送器件地址
  65.      if(ack==0)return(0);
  66.    SendByte(0x40|Chl);            //發送器件子地址
  67.      if(ack==0)return(0);
  68.    Start_I2c();
  69.    SendByte(AddWr+1);
  70.       if(ack==0)return(0);
  71.    Val=RcvByte();
  72.    NoAck_I2c();                 //發送非應位
  73.    Stop_I2c();                  //結束總線
  74.   return(Val);
  75. }
  76. float pid(float input)
  77. {
  78.   static float error2,error1,error3,t,Velocity;
  79.   error1 = target-input ;
  80.   Velocity+=(Kp*(error1-error2))+Ki*error1+Kd*(error1-2*error2+error3);
  81.   t=error2;
  82.   error2= error1 ;
  83.   error3 = t;
  84. return Velocity;

  85. }
  86. //電壓分辨率0.0196V
  87. //滿電壓3.9V所以角度分辨率0.0196/3.9*360=1.8度 所以增大角度分辨率要嘛增加滿量程電壓3.9V要嘛減小其對應的角度,其實就都是增大電壓
  88. void control()
  89. {
  90.   
  91.         unsigned char num=0,i;
  92.         int sum_num=0;
  93.   unsigned char temp[7];//定義顯示區域臨時存儲數組
  94.         float Voltage,angle;        //定義浮點變量
  95.         float temp_value;
  96.         for(i=0;i<5;i++)
  97.   {   
  98.                 sum_num+=ReadADC(0);   
  99.         }       
  100.         num=sum_num/5;
  101.         sum_num=0;
  102.   Voltage=(float)num;   
  103.   angle=(Voltage-16);//*1.41-23.91);
  104.   //angle=-(((Voltage-4.96)/0.0136)+341.73);
  105.         //pid計算
  106.         temp_value=(int)pid(angle);
  107.                 if(temp_value<0)
  108.                 value=0;
  109.         else if(temp_value>=100)
  110.                 value=100;
  111.         else
  112.         value=(int)temp_value;

  113.        
  114.         if(flag==wait_speak&&abs(angle-target)<=5)
  115.                    confirtime++;
  116.   if(abs(angle-target)>=20)  //如果角度差大于20度 將嗡鳴器設置為待激活狀態
  117.                 flag=wait_speak;
  118.         if(confirtime==10&&(flag==wait_speak))
  119.         {       
  120.                 //beep_1s();
  121.                 sprintf(temp,"Achieve the goal:");//格式輸出電壓值,%3.2f 表示浮點輸出,共3位數,小數點后2位  
  122.           LCD_Write_String(0,1,temp);
  123.                 delay100us(10000);
  124.                  LCD_Clear();          //清屏
  125.                 flag=speaked;
  126.                 confirtime=0;
  127.         }
  128.        
  129.        

  130.        
  131.   sprintf(temp,"DQJD:%3.2f ", angle);
  132.   LCD_Write_String(0,0,temp);
  133.   sprintf(temp,"SDJD:%d",(int)target);
  134.         LCD_Write_String(0,1,temp);
  135.         //sprintf(temp,"PWM:%d", value);
  136.         //LCD_Write_String(10,1,temp);
  137. }
  138. //定時器1服務函數
  139. void Time1(void) interrupt 3   
  140. {
  141.         TH1 = 0x0FF;
  142.         TL1 = 0x9C;
  143.         timer1++;
  144.                 if(timer1>100)  //PWM周期為100*100us
  145.                 {
  146.                         timer1=0;
  147.                 }
  148.                 if(timer1 <value)       
  149.                 {
  150.                         PWM=1;
  151.                 }
  152.                 else
  153.                 {
  154.                         PWM=0;
  155.                 }
  156.        
  157.        
  158. }
  159. //定時器1初始化函數
  160. void Timer1Init()
  161. {
  162.         TMOD|=0X10;//選擇為定時器1模式,工作方式1,僅用TR1打開啟動。
  163.         TH1 = 0x0FF;
  164.   TL1 = 0x9C;       
  165.         ET1=1;//打開定時器1中斷允許
  166.         EA=1;//打開總中斷
  167.         TR1=1;//打開定時器                       
  168. }

  169. void change_target()
  170. {
  171. unsigned char temp[7];//定義顯示區域臨時存儲數組
  172.         if(target_up==0)
  173.         {
  174.                 delay100us(100);
  175.                 if(target_up==0)
  176.                 {         flag=wait_speak;
  177.                         while(target_up==0)
  178.                         {               
  179.         if(target<=80)               
  180.                                 target=45;               
  181.                     sprintf(temp,"Target:%d",(int)target);//格式輸出電壓值,%3.2f 表示浮點輸出,共3位數,小數點后2位  
  182.               LCD_Write_String(0,1,temp);
  183.                           delay100us(1000);
  184.                        
  185.                         }
  186.                 }
  187.         }
  188.         if(target_down==0)
  189.         {
  190.                 delay100us(100);
  191.                 if(target_down==0)
  192.                 {        flag=wait_speak;
  193.                         while(target_down==0)
  194.                         {                               
  195.                                  if(target>=10)
  196.                                 target=0;               
  197.                     sprintf(temp,"Target:%d",(int)target);//格式輸出電壓值,%3.2f 表示浮點輸出,共3位數,小數點后2位  
  198.               LCD_Write_String(0,1,temp);
  199.                           //delay10us(1000);
  200.                        
  201.                         }
  202.                 }
  203.         }
  204. }
  205. void display()
  206. {
  207. //        unsigned char temp[7];//定義顯示區域臨時存儲數組
  208. //  sprintf(temp,"Reality: %3.2f ", angle);//格式輸出電壓值,%3.2f 表示浮點輸出,共3位數,小數點后2位
  209. //  LCD_Write_String(0,0,temp);
  210. //  sprintf(temp,"Target:%d",(int)target);//格式輸出電壓值,%3.2f 表示浮點輸出,共3位數,小數點后2位  
  211. //        LCD_Write_String(0,1,temp);
  212. //        sprintf(temp,"PWM:%d", value);//格式輸出電壓值,%3.2f 表示浮點輸出,共3位數,小數點后2位  
  213. //        LCD_Write_String(9,1,temp);

  214. }
  215. void  beep_1s()
  216. {
  217.         unsigned char i;
  218. for(i=0;i<=200;i++)
  219.   {
  220.         delay100us(1);
  221.         beep=~beep;
  222.         }

  223. }
復制代碼

所有資料51hei提供下載:
新建 好壓 ZIP 壓縮文件.zip (1.38 MB, 下載次數: 114)

評分

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

查看全部評分

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

使用道具 舉報

沙發
ID:230742 發表于 2020-12-13 19:30 | 只看該作者
我是小白,看過很多設計。看了你的設計,我沒明白的是用讀取電位器角度。沒搞錯吧。你設計的是一個飛機啊。難道你要在飛機的電位器上掛個重錘?來讀取電位器的角度?
回復

使用道具 舉報

板凳
ID:47286 發表于 2021-11-16 10:00 來自手機 | 只看該作者
啤酒瓶子老大 發表于 2020-12-13 19:30
我是小白,看過很多設計。看了你的設計,我沒明白的是用讀取電位器角度。沒搞錯吧。你設計的是一個飛機啊。 ...

我想重錘是不用 但用電位器的話 轉速得很低吧 轉速高了采集不對
回復

使用道具 舉報

地板
ID:658144 發表于 2022-6-23 11:11 | 只看該作者
支持51黑,感謝分享!
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产精品国产 | 99riav3国产精品视频 | 欧美成人精品 | 欧美综合一区二区三区 | 欧美成年网站 | 国内精品视频免费观看 | 国产成人精品久久二区二区91 | 国产成人精品一区二 | 成人精品国产一区二区4080 | 欧美日韩国产综合在线 | 欧美日韩一区二区电影 | 国产精品一区久久久 | 欧美一级高潮片免费的 | 欧美xxxⅹ性欧美大片 | 请别相信他免费喜剧电影在线观看 | 毛片久久久 | 激情亚洲 | 日日操av | www.99热.com| 免费黄色网址视频 | 亚洲国产成人精品女人 | 酒色成人网 | 综合网伊人 | 国产精品成av人在线视午夜片 | 在线观看免费av网站 | 免费观看一级毛片 | 国产xxxx在线| 91视频在线观看 | 999精品视频 | 国产精品久久久久久一级毛片 | 一区二区免费在线视频 | 日本一区二区三区四区 | 五月婷婷婷 | 日韩欧美成人一区二区三区 | 国产精品99一区二区 | 视频在线日韩 | 黄色三级在线播放 | 狠狠爱视频 | 精品国产乱码久久久久久88av | 天天综合久久 | 国产亚洲精品久久久久久牛牛 |