找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

基于stm32的平衡小車源程序+電路+視頻

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:479765 發(fā)表于 2019-8-19 13:32 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
由于硬件知識不足,平衡小車硬件部分就直接那個寶上買了,小車通過藍牙模塊使用電腦串口助手實現(xiàn)前進和左右轉(zhuǎn),因為不是通過手機app控制,所以控制起來有點麻煩,在一個就是由于時間原因左右旋轉(zhuǎn)的參數(shù)并不是很完美,現(xiàn)在我把我的程序 原理圖 打包上傳,有需要的可以下載,覺得不好,也請不要噴,畢竟我也是第一次做,經(jīng)驗不足,請多多理解包涵

附件內(nèi)附視頻演示:

電路原理圖如下:



單片機源程序如下:
  1. #include "sys.h"

  2. u16 flag=0;

  3. /*
  4. * 函數(shù)名:main
  5. * 描述  :主函數(shù)
  6. */

  7. int main(void)
  8. {       

  9.          u8 a;
  10.         SystemInit();                   //=====系統(tǒng)初始化
  11.         Timer1_Init(499,7199);                                   //定時器TIM1
  12.        
  13.         USART1_Config();                                                //串口1初始化 上位機
  14.         USART3_Config();                                                //串口3初始化 藍牙與USART3公用相同IO口

  15.         TIM2_PWM_Init();                                           //PWM輸出初始化
  16.         MOTOR_GPIO_Config();                                  //電機IO口初始化


  17.         TIM3_Encoder_Init();                       //編碼器獲取脈沖數(shù) PA6 7
  18.         TIM4_Encoder_Init();                       //編碼器獲取脈沖數(shù) PB6 7       
  19.         ////////////////////DMP/////////////////////////////////
  20.         i2cInit();                                                           //IIC初始化 用于掛靠在總線上的設(shè)備使用
  21.         delay_ms(10);                                                   //延時10ms
  22.         MPU6050_Init();                                                   //MPU6050 DMP陀螺儀初始化

  23.         SysTick_Init();                                                  //SysTick函數(shù)初始化       
  24. //        CarUpstandInit();                                          //小車直立參數(shù)初始化
  25.         SysTick->CTRL |=  SysTick_CTRL_ENABLE_Msk;         //使能總算法時鐘

  26.         while (1)
  27.         {

  28.      MPU6050_Pose();                                                 //獲取MPU6050角度狀態(tài)
  29. //        printf("CLS(0);\r\n");//用串口屏?xí)r先單獨發(fā)送這個函數(shù),清空一下,再屏蔽這個函數(shù),其他函數(shù)就可以調(diào)用了
  30. //              USART1_printf("X軸-滾轉(zhuǎn)角-Roll%d',1);\r\n",Left_encouder);//不知道什么原因usart會和什么沖突(可能是I2C)
  31. //                   USART1_printf("Y軸-俯仰角-Pitch:%d',2);\r\n",Right_encouder); //以至于函數(shù)發(fā)送有限制,超出了程序就會出錯
  32. //                   USART1_printf("DR2;DS16(0,40,'Z軸-航偏角-Yaw:%.3f',3);\r\n",Yaw);     //波特率越高可發(fā)送的函數(shù)越多
  33.                
  34.                 if(USART_GetFlagStatus(USART3,USART_FLAG_RXNE) != RESET) //查詢串口待處理標志位
  35.                 {  
  36.                         a =USART_ReceiveData(USART3);//讀取接收到的數(shù)據(jù)
  37.                        
  38.                         if(a=='1'){Speed_P+=0.2;USART3_printf("Speed_P=%.2f \r\n",Speed_P);}        //把收到的數(shù)據(jù)發(fā)送回電腦(不知道什么原因在usart接收數(shù)據(jù)時輸入只能是%c即一個ASCII碼,用scanf函數(shù)也一樣)               
  39.                         if(a=='2'){Speed_P-=0.2;USART3_printf("Speed_P=%.2f \r\n",Speed_P);}
  40.                         if(a=='3'){Speed_I+=0.2;USART3_printf("Speed_I=%.2f \r\n",Speed_I);}
  41.                         if(a=='4'){Speed_I-=0.2;USART3_printf("Speed_I=%.2f \r\n",Speed_I);}
  42.                         if(a=='5'){Angle_P+=0.01;USART3_printf("Angle_P=%.2f \r\n",Angle_P);}
  43.                         if(a=='6'){Angle_P-=0.01;USART3_printf("Angle_P=%.2f \r\n",Angle_P);}
  44.                         if(a=='7'){Angle_D+=0.001;USART3_printf("Angle_D=%.3f \r\n",Angle_D);}
  45.                         if(a=='8'){Angle_D-=0.001;USART3_printf("Angle_D=%.3f \r\n",Angle_D);}
  46.                         if(a=='9'){Turn_P+=0.1;USART3_printf("Turn_P=%.2f \r\n",Turn_P);}
  47.       if(a=='0'){Turn_P-=0.1;USART3_printf("Turn_P=%.2f \r\n",Turn_P);}
  48.                         if(a=='a'){flag=1;USART3_printf("flag=1 PartTurn=%0.1f \r\n",PartTurn);}//左右轉(zhuǎn)
  49.                         if(a=='b'){flag=2;USART3_printf("flag=2 PartTurn=%0.1f \r\n",PartTurn);}
  50.                         if(a=='c'){PartTurn+=50;ExtraPosition=0;USART3_printf("PartTurn=%0.1f  \r\n",PartTurn);}//左右旋轉(zhuǎn)
  51.                         if(a=='d'){PartTurn-=50;ExtraPosition=0;USART3_printf("PartTurn=%0.1f  \r\n",PartTurn);}
  52.                         if(a=='e'){ExtraPosition+=100;USART3_printf("ExtraPosition=%.2f \r\n",ExtraPosition);}//前進后退
  53.       if(a=='f'){ExtraPosition-=100;USART3_printf("ExtraPosition=%.2f \r\n",ExtraPosition);}
  54.                        

  55.                 }

  56.        
  57. //                          USART3_printf("X軸-滾轉(zhuǎn)角-Roll%.3f \r\n",Roll);//不知道什么原因usart會和什么沖突(可能是I2C)
  58. //                   USART3_printf("Y軸-俯仰角-Pitch:%.3f \r\n",Pitch); //以至于函數(shù)發(fā)送有限制,超出了程序就會出錯
  59. //                   USART3_printf("Z軸-航偏角-Yaw:%.3f \r\n",Yaw);     //波特率越高可發(fā)送的函數(shù)越多
  60. //                   USART3_printf("速度環(huán)P-Speed_P:%.2f \r\n",Speed_P);
  61. //                         USART3_printf("速度環(huán)D-Speed_I:%.2f \r\n",Speed_I);
  62. //                   USART3_printf("角度環(huán)P-Yaw:%.2f\r\n",Angle_P);
  63. //                         USART3_printf("角度環(huán)D-Angle_P:%.2f\r\n",Angle_D);
  64. //                   USART3_printf("轉(zhuǎn)向環(huán)P-Turn_P:%.2f\r\n",Turn_P);
  65. //       USART3_printf("AT");
  66. //                         USART3_printf("AT+BAUD4");
  67. //                   USART3_printf("P-Turn_P:%.2f\r\n",Turn_P);

  68. ////               
  69.          }
  70.        
  71.          
  72. }
復(fù)制代碼

所有資料51hei提供下載:
平衡小車.7z (12.41 MB, 下載次數(shù): 124)



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

使用道具 舉報

沙發(fā)
ID:814485 發(fā)表于 2020-8-15 18:48 | 只看該作者
很有創(chuàng)意
回復(fù)

使用道具 舉報

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

本版積分規(guī)則

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

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

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