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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

STM32板球控制系統單點定位代碼

[復制鏈接]
跳轉到指定樓層
樓主
全國電子設計競賽,STM32F4+ov76攝像頭  PID控制  供參考使用
制作出來的實物圖如下:


單片機源程序如下:
  1. #include "sys.h"
  2. #include "delay.h"
  3. #include "usart.h"
  4. #include "led.h"
  5. #include "key.h"
  6. #include "lcd.h"
  7. #include "usmart.h"  
  8. #include "usart2.h"  
  9. #include "timer.h"
  10. #include "ov2640.h"
  11. #include "dcmi.h"
  12. #include "string.h"
  13. #include "pwm.h"



  14. //JPEG尺寸支持列表
  15. const u16 jpeg_img_size_tbl[][2]=
  16. {
  17.         176,144,        //QCIF
  18.         160,120,        //QQVGA
  19.         352,288,        //CIF
  20.         320,240,        //QVGA
  21.         640,480,        //VGA
  22.         800,600,        //SVGA
  23.         1024,768,        //XGA
  24.         1280,1024,        //SXGA
  25.         1600,1200,        //UXGA
  26. };


  27. void TIM3_Int_Init(u16 arr,u16 psc);
  28. //RGB565測試
  29. //RGB數據直接顯示在LCD上面
  30. void rgb565_test(void)
  31. {
  32.         u8 key;
  33.         LCD_Clear(WHITE);
  34.   POINT_COLOR=RED;
  35.         
  36.   OV2640_ImageWin_Set((800-480)/2,(600-600)/2,480,600);
  37.         OV2640_RGB565_Mode();        //RGB565模式
  38.         My_DCMI_Init();                        //DCMI配置
  39.         DCMI_DMA_Init((u32)&LCD->LCD_RAM,1,DMA_MemoryDataSize_HalfWord,DMA_MemoryInc_Disable);//DCMI DMA配置  
  40.          OV2640_OutSize_Set(lcddev.width,600);
  41.         DCMI_Start();                 //啟動傳輸
  42.         while(1)
  43.         {
  44.                 key=KEY_Scan(0);
  45.                 if(key)
  46.                 {
  47.                         DCMI_Stop(); //停止顯示
  48.                         switch(key)
  49.                         {                                    
  50.                                 case KEY0_PRES:        //對比度設置
  51.                
  52.                                         break;
  53.                                 case KEY1_PRES:        //飽和度Saturation
  54.                                 
  55.                                         break;
  56.                                 case KEY2_PRES:        //特效設置                                 
  57.                                 
  58.                                         break;
  59.                                 case WKUP_PRES:                    
  60.                                        
  61.                                         break;
  62.                         }
  63.                         
  64.                         DCMI_Start();//重新開始傳輸
  65.                 }
  66.                 delay_ms(10);               
  67.         }   
  68. }




  69. u16 rgb_buf[144][176];        
  70. u16 gray;
  71. extern u8 flag;
  72. u16 hang=0;
  73. u8 X_MAX,Y_MAX=0;    //小球的坐標信息
  74. u8 X_MAX_LSAT, X_MIN_LSAT, Y_MAX_LSAT, Y_MIN_LSAT=0;   //上一次小球坐標位置信息
  75. u8 X,Y=0;      //小球的質心信息
  76. u8 X_MIN,Y_MIN=180;

  77. int PWM_X,PWM_Y=0;          //pid參數初始化
  78. float Err_X,Err_Y=0;
  79. float Err_X_LAST,Err_Y_LAST=0;
  80. float Aim_X,Aim_Y=0;
  81. float Kp,Ki,Kd=0;

  82. int main(void)
  83. {
  84.     u16 i,j;
  85.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設置系統中斷優先級分組2
  86.         delay_init(168);  //初始化延時函數
  87.         uart_init(115200);                //初始化串口波特率為115200
  88.         usart2_init(42,115200);                //初始化串口2波特率為115200
  89.         LED_Init();                                        //初始化LED
  90.          LCD_Init();                                        //LCD初始化  
  91.          KEY_Init();                                        //按鍵初始化
  92.         TIM3_Int_Init(200-1,8400-1);//10Khz計數,1秒鐘中斷一次
  93.         
  94.         TIM14_PWM_Init(10000-1,168-1);        //重裝載值10000,所以PWM頻率為 150hz.      //舵機預留
  95.         TIM11_PWM_Init(10000-1,336-1);        //重裝載值10000,所以PWM頻率為 150hz.        
  96.         
  97.          usmart_dev.init(84);                //初始化USMART
  98.          POINT_COLOR=RED;//設置字體為紅色
  99.         LCD_ShowString(30,50,200,16,16,"Explorer STM32F4");        
  100.         LCD_ShowString(30,70,200,16,16,"OV2640 TEST");        
  101.         LCD_ShowString(30,90,200,16,16,"ATOM@ALIENTEK");
  102.         LCD_ShowString(30,110,200,16,16,"2014/5/14");           
  103.         while(OV2640_Init())//初始化OV2640
  104.         {
  105.                 LCD_ShowString(30,130,240,16,16,"OV2640 ERR");
  106.                 delay_ms(200);
  107.             LCD_Fill(30,130,239,170,WHITE);
  108.                 delay_ms(200);
  109.         }
  110.         LCD_ShowString(30,130,200,16,16,"OV2640 OK");  
  111.    
  112.     OV2640_OutSize_Set(176,144);       //注意此處圖像選取QCIF格式
  113.     OV2640_RGB565_Mode();        //RGB565模式
  114.     My_DCMI_Init();                        //DCMI配置
  115.     DCMI_DMA_Init((u32)rgb_buf,sizeof(rgb_buf)/4,DMA_MemoryDataSize_HalfWord,DMA_MemoryInc_Enable);//DCMI DMA配置
  116.     DCMI_Start();                 //啟動傳輸
  117.         
  118.         
  119.         //=============================================二值化和尋點部分========================================================
  120.     while(1)
  121.     {
  122.             hang=0;
  123.             LCD_SetCursor(0,0);  
  124.             LCD_WriteRAM_Prepare();                //開始寫入GRAM
  125.             for(i=0;i<144;i++)
  126.             {
  127.                 for(j=0;j<176;j++)
  128.                 {
  129.                     if(j==175)
  130.                     {
  131.                         hang++;
  132.                         LCD_SetCursor(0,i+1);  
  133.                         LCD_WriteRAM_Prepare();                //開始寫入GRAM
  134.                     }
  135.                     gray=((rgb_buf[i][j]>>11)*19595+((rgb_buf[i][j]>>5)&0x3f)*38469 +(rgb_buf[i][j]&0x1f)*7472)>>16;  //灰度計算。公式請百度
  136.                     if(gray>=23)  //固定閾值二值化
  137.                     {
  138.                                                                                           
  139.                                                                                           if(i>8&&i<136&&j<160&&j>16)  //此處遍歷圖像尋找小球最上最下 最左 最右四個點坐標
  140.                                                                                                 {
  141.                                                                                             if(i>X_MAX) X_MAX=i;
  142.                                                                                              if(i<X_MIN) X_MIN=i;
  143.                                                                                          
  144.                                                                                          
  145.                                                                               
  146.                                                                                             if(j>Y_MAX) Y_MAX=j;
  147.                                                                                              if(j<Y_MIN) Y_MIN=j;
  148.                                                                                          
  149.                                                                                                 }
  150.                         LCD->LCD_RAM=WHITE;
  151.                     }
  152.                     else
  153.                     {
  154.                                                                                          
  155.                         LCD->LCD_RAM=BLACK;
  156.                     }
  157.                 }
  158.             }
  159.                                                 
  160.                                         X_MAX_LSAT =        X_MAX;    //更新pid的real坐標信息
  161.                                   X_MIN_LSAT =        X_MIN;
  162.                                   Y_MAX_LSAT =        Y_MAX;
  163.                                   Y_MIN_LSAT =        Y_MIN;   
  164.                                                 
  165.                                   X_MAX=0;
  166.                                   X_MIN=180;
  167.                                         Y_MAX=0;
  168.                                   Y_MIN=180;   //清除掉本次坐標用于再次遍歷最大值 最小值
  169.                                                 
  170.                                         X=(X_MAX_LSAT+X_MIN_LSAT)/2;
  171.                                   Y=(Y_MAX_LSAT+Y_MIN_LSAT)/2;     //通過四個點坐標計算小球質心
  172.                                        
  173.                         //                TIM_SetCompare1(TIM14,9340);        //修改比較值,修改占空比   調試舵機使用
  174.                         
  175.                         //                TIM_SetCompare1(TIM11,9300);        //修改比較值,修改占空比   調試舵機使用
  176.                                                 
  177.     }
  178. }




  179. //=============================================pid計算部分(中斷?=============================================



  180. void TIM3_IRQHandler(void)           //pid控制中斷函數 沒記錯的話是50Hz
  181. {
  182.         if(TIM_GetITStatus(TIM3,TIM_IT_Update)==SET) //溢出中斷
  183.         {

  184.                 Kp=2.4;                              //pd參數
  185.                 Kd=90.9;

  186.                 Aim_X=72;                             //目標點
  187.                 Aim_Y=88;
  188.                
  189.                 Err_X=X-Aim_X;                    
  190.                 Err_Y=Y-Aim_Y;
  191.                
  192.                
  193.                 PWM_X=9360+(Err_X*Kp+(Err_X-Err_X_LAST)*Kd);                //增量式pd計算
  194.                 PWM_Y=9300+(Err_Y*Kp+(Err_Y-Err_Y_LAST)*Kd);
  195.                
  196.                 if(PWM_Y>9370)PWM_Y=9370;                                    //pid輸出限幅度 防止抽風
  197.                 if(PWM_Y<9230)PWM_Y=9230;
  198.                
  199.                 if(PWM_X>9410)PWM_X=9410;
  200.                 if(PWM_X<9270)PWM_X=9270;
  201.                
  202.                 Err_X_LAST=Err_X;
  203.                 Err_Y_LAST=Err_Y;
  204.                
  205.                         TIM_SetCompare1(TIM14,PWM_X);        //修改比較值,修改占空比      輸出pid計算值
  206.                         TIM_SetCompare1(TIM11,PWM_Y);        //修改比較值,修改占空比
  207.         }
  208.         TIM_ClearITPendingBit(TIM3,TIM_IT_Update);  //清除中斷標志位
  209. }
復制代碼

所有資料51hei提供下載:
板球系統單點定位代碼.7z (371.15 KB, 下載次數: 13)


評分

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

查看全部評分

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

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 在线天堂免费中文字幕视频 | 欧美精品在线一区二区三区 | 成人在线免费网站 | 欧美在线视频网站 | 色.com| 六月色婷| 日韩资源| 毛片视频观看 | 在线欧美一区 | 日韩欧美在线观看 | 综合久久av | 国产福利视频在线观看 | 在线国产一区二区三区 | 日韩在线综合 | 日韩在线小视频 | 久久精品91 | 国产精品国产a | 国产一级特黄视频 | 91精品国产综合久久精品图片 | 亚洲狠狠爱 | 国产成人一区二区 | 深夜福利亚洲 | 九色av| 人人cao| 亚洲欧美日韩精品 | 色婷婷av久久久久久久 | 一区二区中文 | 久久精品国产一区二区电影 | 成人啊啊啊| 亚洲视频自拍 | 国产精品777一区二区 | 一区在线观看 | 成人在线观看免费观看 | 91精品国产麻豆 | 日日操夜夜操视频 | 精品伊人| 国产精品久久影院 | 日韩在线观看一区 | 亚洲精品久久久一区二区三区 | 特级毛片爽www免费版 | www.一区二区三区 |