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

QQ登錄

只需一步,快速開(kāi)始

帖子
查看: 6571|回復(fù): 3
收起左側(cè)

單片機(jī)PID循跡小車(chē)代碼

[復(fù)制鏈接]
ID:423284 發(fā)表于 2019-1-2 18:36 | 顯示全部樓層 |閱讀模式
就是比較簡(jiǎn)單的循跡小車(chē),可以循黑線的那種,因?yàn)樵趯W(xué)PID,所以給它加了個(gè)PD控制,不過(guò)效果不太好這是實(shí)現(xiàn)PID控制的主要代碼

  1. #include"PID.h"
  2. #include"Trace.h"

  3. extern  int flag;
  4. int    RK=6;   //固定基準(zhǔn),不能變得               


  5. int    KP=4;     //比例調(diào)節(jié)參數(shù)
  6. int    out;      //最后輸出結(jié)果
  7. //int   out0=40; //初始偏移分量
  8. int    Td=7;     //微分時(shí)間常數(shù)
  9. int    Ti=1;     //積分時(shí)間常數(shù)
  10. int    T =1;     //采樣周期
  11. int    Sk;       //積分,微分
  12. int    Dk;

  13. int  Ek[]={0,0,0,0,0};

  14. /*================================================================
  15. 將flag的值與RK=5相減,當(dāng)右邊的紅外對(duì)管檢測(cè)到黑線時(shí)
  16. ,即flag為7  8  9  10 11  12時(shí)小車(chē)發(fā)生了左偏,增加左輪轉(zhuǎn)速,減小右輪

  17. 將flag的值與RK=5相減,當(dāng)左邊的紅外對(duì)管檢測(cè)到黑線時(shí)
  18. ,即flag為5  4  3  2  1   0 時(shí)小車(chē)發(fā)生了右偏,增加右輪轉(zhuǎn)速,減小左輪
  19. //================================================================*/

  20. void  PID (int flag)
  21. {
  22.           Ek[4]=Ek[3];
  23.           Ek[3]=Ek[2];
  24.           Ek[2]=Ek[1];
  25.           Ek[1]=Ek[0];
  26.           Ek[0]=RK-flag;

  27. //Sk = (T/Ti)*(Ek[0]+Ek[1]+Ek[2]+Ek[3]+Ek[4]);
  28.      Dk = (Td/T)*(Ek[0]-Ek[1]);
  29.            out = KP*Ek[0]+Sk+Dk;
  30.            turn(25+out,25-out);
  31.        
  32.        

  33.                
  34. }
  35.        
復(fù)制代碼


extern  int flag;
int    RK=6;   

int    KP=4;  
int    out;   
//int   out0=40;
int    Td=7;   
int    Ti=1;  
int    T =1;  
int    Sk;      
int    Dk;

int  Ek[]={0,0,0,0,0};


void  PID (int flag)
{
          Ek[4]=Ek[3];
          Ek[3]=Ek[2];
          Ek[2]=Ek[1];
          Ek[1]=Ek[0];
          Ek[0]=RK-flag;

//Sk = (T/Ti)*(Ek[0]+Ek[1]+Ek[2]+Ek[3]+Ek[4]);
     Dk = (Td/T)*(Ek[0]-Ek[1]);
           out = KP*Ek[0]+Sk+Dk;
           turn(25+out,25-out);
        }




void xunji (void)
{
if(count ==200)//采樣周期
{
           if(input==0x77)//0111 0 111
        flag=6;

      else if(input==0x7b)//0111 0 01
        flag=7;
                  else if(input==0x7b)//0111 1 011
        flag=8;
                        else if(input==0x75)//0111 1 001
        flag=9;
      else if(input==0x7d)//0111 1 101
        flag=10;
                        else if(input==0x7c)//0111 1 100
        flag=11;
                  else if(input==0x7e)//0111 1 110
        flag=12;
                        else if(input==0x6d)//0110 0 111
        flag=5;
      else if(input==0x6f)//0110 1 111
        flag=4;
                        else if(input==0x4f)//0100 1 111                  
        flag=3;
                        else if(input==0x5f)//0101 1 111                  
        flag=2;
                        else if(input==0x1f)//0001 1 111                 
        flag=1;
                        else if(input==0x10)//0011 1 111         
        flag=0;


   count=0;
}

PID (flag);


}
51hei.png
全部資料51hei下載地址:
循跡小車(chē)PID算法.rar (42.84 KB, 下載次數(shù): 133)

評(píng)分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

回復(fù)

使用道具 舉報(bào)

ID:871292 發(fā)表于 2021-1-30 12:13 | 顯示全部樓層
非常感覺(jué),剛好在學(xué)習(xí)做智能車(chē)底盤(pán)
回復(fù)

使用道具 舉報(bào)

ID:646870 發(fā)表于 2021-4-21 17:48 | 顯示全部樓層
請(qǐng)問(wèn)程序中定義input為P0系列口的目的是啥
回復(fù)

使用道具 舉報(bào)

ID:789726 發(fā)表于 2021-4-25 18:57 | 顯示全部樓層
剛好可以借鑒做小車(chē)
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

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

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