找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4697|回复: 7
打印 上一主题 下一主题
收起左侧

stm32 HAL库 mpu6050源程序

[复制链接]
跳转到指定楼层
楼主
ID:420065 发表于 2019-7-31 21:14 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
采用了模拟IIC,读取mpu6050数据,以及滤波
人懒,不想附图。

cubeMX配置的STM32F103ZETx的文件

单片机源程序如下:
  1. /* Includes ------------------------------------------------------------------*/
  2. #include "main.h"

  3. /* Private includes ----------------------------------------------------------*/
  4. /* USER CODE BEGIN Includes */
  5. #include "usart.h"
  6. #include "mpu6050.h"
  7. #include "mpu_i2c.h"
  8. #include "stm32f1xx_it.h"
  9. #include "OLED.h"
  10. #include "OLED_I2C.h"
  11. #include "filter.h"
  12. #include "math.h"
  13. /* USER CODE END Includes */

  14. /* Private typedef -----------------------------------------------------------*/
  15. /* USER CODE BEGIN PTD */
  16. extern unsigned int Task_Delay[NumOfTask];
  17. /* USER CODE END PTD */

  18. /* Private define ------------------------------------------------------------*/
  19. /* USER CODE BEGIN PD */

  20. /* USER CODE END PD */

  21. /* Private macro -------------------------------------------------------------*/
  22. /* USER CODE BEGIN PM */

  23. /* USER CODE END PM */

  24. /* Private variables ---------------------------------------------------------*/
  25. UART_HandleTypeDef huart1;

  26. /* USER CODE BEGIN PV */
  27. #define TASK_ENABLE 0
  28. #define PI 3.14159265
  29. float Angle_Balance,Gyro_Balance,Gyro_Turn;  //平衡环控制相关变量
  30. float Encoder_left,Encoder_right;            //速度环控制相关变量
  31. /* USER CODE END PV */

  32. /* Private function prototypes -----------------------------------------------*/
  33. void SystemClock_Config(void);
  34. static void MX_GPIO_Init(void);
  35. void MX_USART1_UART_Init(void);
  36. /* USER CODE BEGIN PFP */

  37. /* USER CODE END PFP */

  38. /* Private user code ---------------------------------------------------------*/
  39. /* USER CODE BEGIN 0 */

  40. /* USER CODE END 0 */

  41. /**
  42.   * @brief  The application entry point.
  43.   * @retval int
  44.   */
  45. int main(void)
  46. {
  47.   /* USER CODE BEGIN 1 */
  48.         short Accel[3];
  49.         short Gyro [3];
  50.         short Temp;
  51.         int Accel_Y,Accel_X,Accel_Z,Gyro_X,Gyro_Y,Gyro_Z;
  52.         float Acceleration_Z;                       //Z轴加速度计
  53.         //uint8_t i;
  54.        
  55.   /* USER CODE END 1 */
  56.   

  57.   /* MCU Configuration--------------------------------------------------------*/

  58.   /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  59.   HAL_Init();

  60.   /* USER CODE BEGIN Init */

  61.   /* USER CODE END Init */

  62.   /* Configure the system clock */
  63.   SystemClock_Config();

  64.   /* USER CODE BEGIN SysInit */

  65.   /* USER CODE END SysInit */

  66.   /* Initialize all configured peripherals */
  67.   MX_GPIO_Init();
  68.   MX_USART1_UART_Init();
  69.   /* USER CODE BEGIN 2 */
  70.        
  71.         //********OLED和OLED对应的iic初始化*******//
  72.         OLED_Init();
  73.        
  74.         /*MPU_I2C初始化*/
  75.   MPU_I2C_InitGPIO();
  76.        
  77.   /*MPU6050初始化*/
  78.   MPU6050_Init();
  79.         HAL_Delay(10);
  80.         /**********OLED清屏**************/
  81.         OLED_CLS();
  82.        
  83.   /* 调用格式化输出函数打印输出数据 */
  84.         //检测MPU6050
  85.         if (MPU6050ReadID() == 0)
  86.         {       
  87.     OLED_ShowStr(3,0,(unsigned char*)"can't find mpu6050!",1);
  88.                 while(1);
  89.         }
  90.        
  91.   /* USER CODE END 2 */

  92.   /* Infinite loop */
  93.   /* USER CODE BEGIN WHILE */
  94.   while (1)
  95.   {
  96.     /* USER CODE END WHILE */

  97.     /* USER CODE BEGIN 3 */
  98.                 if(Task_Delay[0]==TASK_ENABLE)
  99.     {
  100.       Task_Delay[0]=1000;
  101.     }
  102.                
  103.                 if(Task_Delay[1]==0)
  104.     {
  105.       MPU6050ReadAcc(Accel);                       
  106.       //dprintf("\r\n加速度: %8d%8d%8d    ",Accel[0],Accel[1],Accel[2]);
  107.                         Accel_X = Accel[0];
  108.                         Accel_Y = Accel[1];
  109.                         Accel_Z = Accel[2];
  110.                        
  111.                         //OLED_ShowNum(40,1,Accel[0],5,20);
  112.       MPU6050ReadGyro(Gyro);
  113.       //printf("陀螺仪: %8d%8d%8d    ",Gyro[0],Gyro[1],Gyro[2]);
  114.                         Gyro_X = Gyro[0];
  115.                         Gyro_Y = Gyro[1];
  116.                         Gyro_Z = Gyro[2];
  117.       
  118.       MPU6050_ReturnTemp(&Temp);
  119.       //printf("温度: %d",Temp);
  120.                        
  121.                         if(Gyro_Y>32768)  Gyro_Y-=65536;                       //数据类型转换  也可通过short强制类型转换
  122.                         if(Gyro_Z>32768)  Gyro_Z-=65536;                       //数据类型转换
  123.                   if(Accel_X>32768) Accel_X-=65536;                      //数据类型转换
  124.                   if(Accel_Z>32768) Accel_Z-=65536;                      //数据类型转换
  125.                         //Gyro_Balance=-Gyro_Y;                                //更新平衡角速度
  126.                    Accel_Y=atan2(Accel_X,Accel_Z)*180/PI;                 //计算倾角       
  127.                   Gyro_Y =Gyro_Y/16.4;                                   //陀螺仪量程转换       
  128.              Kalman_Filter(Accel_Y,-Gyro_Y);                                                                                                 //卡尔曼滤波
  129.                        
  130.                        
  131.                         //Angle_Balance = angle;                                                                                                                                 //更新平衡倾角
  132.                         //Gyro_Turn=Gyro_Z;                                                                                                                                                         //更新转向角速度
  133.                         //Acceleration_Z=Accel_Z;                                                                                                                                 //跟新z轴加速度
  134.                         printf("\r\nY轴加速度和pitch:  %8d,%8d",Gyro_Y,Accel_Y);
  135.                         //printf("%8d\n",Accel_Y);
  136.             //Angle_Balance=angle;                                   //更新平衡倾角
  137.                         //Gyro_Turn=Gyro_Z;                                      //更新转向角速度
  138.                         //Acceleration_Z=Accel_Z;                                //===更新Z轴加速度计       
  139.                         //Gyro_Balance=-Gyro_Y;
  140.                         //printf("卡尔曼滤波值%8f,%8f\n",Angle_Balance,Gyro_Turn);
  141.                        
  142.                        
  143.                        
  144.       //OLED_ShowNum(40,2,Temp,5,10);
  145.       Task_Delay[1]=100;//此值每1ms会减1,减到0才可以重新进来这里,所以执行的周期是100ms
  146.     }
  147.   }
  148.   /* USER CODE END 3 */
  149. }

  150. /**
  151.   * @brief System Clock Configuration
  152.   * @retval None
  153.   */
  154. void SystemClock_Config(void)
  155. {
  156.   RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  157.   RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};

  158.   /** Initializes the CPU, AHB and APB busses clocks
  159.   */
  160.   RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  161.   RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  162.   RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
  163.   RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  164.   RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  165.   RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  166.   RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
  167.   if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  168.   {
  169.     Error_Handler();
  170.   }
  171.   /** Initializes the CPU, AHB and APB busses clocks
  172.   */
  173.   RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
  174.                               |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  175.   RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  176.   RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  177.   RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
  178.   RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;

  179.   if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
  180.   {
  181.     Error_Handler();
  182.   }
  183. }

  184. /**
  185.   * @brief USART1 Initialization Function
  186.   * @param None
  187.   * @retval None
  188.   */
  189. void MX_USART1_UART_Init(void)
  190. {

  191.   /* USER CODE BEGIN USART1_Init 0 */

  192.   /* USER CODE END USART1_Init 0 */

  193.   /* USER CODE BEGIN USART1_Init 1 */

  194.   /* USER CODE END USART1_Init 1 */
  195.   huart1.Instance = USART1;
  196.   huart1.Init.BaudRate = 115200;
  197.   huart1.Init.WordLength = UART_WORDLENGTH_8B;
  198.   huart1.Init.StopBits = UART_STOPBITS_1;
  199.   huart1.Init.Parity = UART_PARITY_NONE;
  200.   huart1.Init.Mode = UART_MODE_TX_RX;
  201.   huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  202.   huart1.Init.OverSampling = UART_OVERSAMPLING_16;
  203.   if (HAL_UART_Init(&huart1) != HAL_OK)
  204.   {
  205.     Error_Handler();
  206.   }
  207.   /* USER CODE BEGIN USART1_Init 2 */

  208.   /* USER CODE END USART1_Init 2 */

  209. }

  210. /**
  211.   * @brief GPIO Initialization Function
  212.   * @param None
  213.   * @retval None
  214.   */
  215. static void MX_GPIO_Init(void)
  216. {

  217.   /* GPIO Ports Clock Enable */
  218.   __HAL_RCC_GPIOA_CLK_ENABLE();

  219. }

  220. /* USER CODE BEGIN 4 */

  221. /* USER CODE END 4 */

  222. /**
  223.   * @brief  This function is executed in case of error occurrence.
  224.   * @retval None
  225.   */
  226. void Error_Handler(void)
  227. {
  228.   /* USER CODE BEGIN Error_Handler_Debug */
  229.   /* User can add his own implementation to report the HAL error return state */

  230.   /* USER CODE END Error_Handler_Debug */
  231. }

  232. #ifdef  USE_FULL_ASSERT
  233. /**
  234.   * @brief  Reports the name of the source file and the source line number
  235.   *         where the assert_param error has occurred.
  236.   * @param  file: pointer to the source file name
  237.   * @param  line: assert_param error line source number
  238.   * @retval None
  239.   */
  240. void assert_failed(uint8_t *file, uint32_t line)
  241. {
  242.   /* USER CODE BEGIN 6 */
  243.   /* User can add his own implementation to report the file name and line number,
  244.      tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  245.   /* USER CODE END 6 */
  246. }
  247. #endif /* USE_FULL_ASSERT */

  248. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
复制代码

所有资料51hei提供下载:
mpu_fliter_oled.7z (271.84 KB, 下载次数: 143)


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:282095 发表于 2019-8-1 00:23 | 只看该作者
有些地方不是很清楚,可以注释解释一下吗
回复

使用道具 举报

板凳
ID:484435 发表于 2019-8-1 11:08 | 只看该作者
谢谢分享
回复

使用道具 举报

地板
ID:420065 发表于 2019-8-1 11:55 | 只看该作者
鹏博士PBs 发表于 2019-8-1 00:23
有些地方不是很清楚,可以注释解释一下吗

本人比较菜,现在还在准备着今年电设用代码,比赛完了之后补解释
回复

使用道具 举报

5#
ID:593684 发表于 2019-8-1 16:20 | 只看该作者
看下 学习学习
回复

使用道具 举报

6#
ID:496481 发表于 2019-8-1 16:51 | 只看该作者
有msp430f5529的6050 pid 代码吗
回复

使用道具 举报

7#
ID:356403 发表于 2019-8-2 10:02 | 只看该作者
找了好久,非常感谢,试试看
回复

使用道具 举报

8#
ID:772085 发表于 2020-6-7 18:37 | 只看该作者
积分不够 难受啊
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表