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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

智能車競賽入門巡線代碼分析-基于OV7620與STM32

[復制鏈接]
跳轉到指定樓層
樓主
ID:694984 發表于 2021-7-18 20:41 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
本帖最后由 火鳥雪中飛 于 2021-7-30 20:50 編輯

經典的智能車入門基礎代碼(ov7620)
工程:IAR
單片機:stmf10x
使用人群:單片機初學者 智能車入門 智能車競賽參與者
注意:體會智能車制作的軟件入門思想 化為己用


下面是主函數
包括四個主要內容:
DataAnalyse(1) ----> 將圖像二值化 單片機最后處理的就是黑點和白點
mygetLmr() --------> 橫向掃描找出兩條黑線的中點 即賽道的中線
SmoothMid() ------>  中線濾波 使其更平滑
Steer_control() SpeedControl(420)-->偏差傳遞 舵機與電機PID控制
  1. int main(void)
  2. {
  3.   
  4.      Init();
  5.      delay_ms(300);  
  6.   while(1)
  7.   {
  8.       
  9.      if(DataReadyFlag)
  10.      {
  11.       EXTI->IMR &=~(1<<5);  //屏蔽中斷
  12.       EXTI->IMR &=~(1<<6);  //屏蔽中斷
  13.       EXTI->PR |=(1<<5);  //清楚懸掛標記位;
  14.       EXTI->PR |=(1<<6);  //清楚懸掛標記位;
  15.       
  16.       DataReadyFlag=0;   //將標志位清零

  17.       DataAnalyse(1);  //處理圖像,濾波,二值化
  18.       mygetLmr();      //找到中線
  19.       SmoothMid() ;    //平滑中線
  20.       Steer_control(); //控制舵機
  21.       SpeedControl(420);
  22.            
  23.     // send_pic();
  24.          
  25.       EXTI->IMR &=~(1<<5);  //屏蔽中斷
  26.       EXTI->IMR &=~(1<<6);  //屏蔽中斷
  27.       EXTI->IMR |=(1<<5);  //開中斷
  28.   
  29.      }
  30.   }
  31. }
復制代碼
以下為中線處理函數
主要的思想就是單行點數查找 確定兩側黑白交接點位置 取兩側點中間值
但掃描方式有所不同
采用先向左找第一個點 再向右找第二個點 并掃描數行 形成中線
  1. void mygetLmr()
  2. {
  3.          
  4.         u8 i=0;
  5.         u8 j=0;      
  6.               u8 pLeft,pRight ;
  7.               u8 bFoundLeft = 0;
  8.               u8 bFoundRight = 0;
  9.       ///        unsigned char TripLen = 4;
  10.         char bLeftEnd=0;
  11.         char bRightEnd=0;
  12.         char bMidEnd=0;
  13.            
  14.         BlackLineData[R-1]=LastFieldMid1;
  15.         for (i=R-2;i>3&&bMidEnd!=1;i--)
  16.         {
  17.                      
  18.             //清零,以備下一行使用
  19.               bFoundLeft=0;
  20.               bFoundRight=0;               
  21.             
  22.           //向左掃描  找到左邊界,沒有找到黑線,左邊界值設為1
  23.            
  24.             for (pLeft=BlackLineData[i+1];pLeft>2;pLeft--)
  25.             {
  26.               if (*(Data+i*C+pLeft)==Black)
  27.               {
  28.                
  29.                   bFoundLeft=1;
  30.                   Left[i]=pLeft;
  31.                   pLeft=1;
  32.                
  33.               }
  34.             }
  35.             if(bFoundLeft!=1) //若沒有找到黑線,左邊界值設為1
  36.                
  37.              Left[i]=1;
  38.             
  39.             //檢測是否到了盡頭
  40.                   
  41.             //向右掃描,找到右邊界,若沒有找到黑線,有邊界值設為C-1
  42.                
  43.             for (pRight=BlackLineData[i+1];pRight<C-2;pRight++)
  44.             {
  45.               if (*(Data+i*C+pRight)==Black)
  46.               {
  47.                 bFoundRight=1;
  48.                 Right[i]=pRight;
  49.                 pRight=C;
  50.               
  51.               }
  52.             }
  53.             if (bFoundRight!=1)//若沒有找到黑線,有邊界值設為C-1
  54.                
  55.              Right[i]=C-1;
  56.             
  57.             
  58.             //求左右邊界的中點,求得中線值
  59.             BlackLineData[i]=((Left[i]+Right[i]))/2;
  60.                
  61.             if ((BlackLineData[i]>C-4)||BlackLineData[i]<4)
  62.             bMidEnd=1;        
  63.       
  64.         }
  65.          
  66.         LastFieldMid1= BlackLineData[ R-5];
  67.         LastFieldMid2=BlackLineData[ R-6];      
  68. }
復制代碼
進行平滑濾波原理較為簡單 數組值循環平均即可 自行百度原理
  1. void SmoothMid()
  2. {
  3. u8  i;
  4. for (i=R-3;i>2;i--)
  5. {
  6.   if (Abs8(BlackLineData[i]-BlackLineData[i-1])>5&& Abs8(BlackLineData[i]-BlackLineData[i+1])>5 )
  7.              BlackLineData[i]=(BlackLineData[i-1]+BlackLineData[i+1] )/2;
  8. }
  9. }
復制代碼
對于控制部分只是簡單的實現PID讓車動起來,對于真正參加比賽還需要學弟學妹們自己努力調試
  1. void Steer_control(void)
  2. {   

  3.   u8 kp,kd,ki;
  4.   s16 steererr  = 0;
  5.   Err=(BlackLineData[7]+BlackLineData[8]+BlackLineData[9]+BlackLineData[10]+BlackLineData[11])/5-45;
  6.   
  7.   //簡單PID編寫
  8.   kp=2;   //P控制
  9.   kd=0;   //D控制
  10.   ki=0;   //I控制
  11.   
  12.   steererr  = kp*Err;
  13.   Steerangle  = STRM-steererr;
  14.   ////舵機限位,很重要,此代碼不能刪除
  15.   if(Steerangle<=STRL) Steerangle=STRL;
  16.   if(Steerangle>=STRR) Steerangle=STRR;

  17. //設置PWM占空比,控制舵機
  18.   SpeedControl(Steerangle);

復制代碼

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

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日韩精品免费一区 | 91在线网站 | 日本大香伊一区二区三区 | 午夜小电影 | 日韩视频高清 | 日本视频中文字幕 | 国产一区二区三区视频 | 久草免费电影 | 在线中文视频 | 黄色国产区 | 成人av网页 | 国产精品久久久亚洲 | 精品国产乱码久久久久久丨区2区 | 欧美综合一区二区三区 | 久久国产精品视频 | 久久精品中文字幕 | 日韩中文一区 | 亚洲欧美成人影院 | 欧美性网站| 黄色免费网 | 亚洲欧美在线视频 | 一区二区三区四区不卡 | 黄视频网站免费观看 | 性高湖久久久久久久久aaaaa | 一区二区小视频 | 精品久久久久久久人人人人传媒 | 日韩毛片免费看 | 91亚洲精选 | 精品一区二区久久 | 99视频在线 | 麻豆一区二区三区精品视频 | 亚洲一一在线 | 国内精品视频在线观看 | 美女视频一区 | 黄网站涩免费蜜桃网站 | 青青草av在线播放 | 亚洲精品日韩精品 | 国产成人自拍av | 国产高清一区二区三区 | 久久精片 | 亚洲成人av|