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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1559|回復: 0
收起左側

STM32F103風力擺系統程序,陀螺儀使用基于DMP的MPU6050可自行增加卡爾曼濾波

[復制鏈接]
ID:640768 發表于 2023-11-21 17:01 | 顯示全部樓層 |閱讀模式
基于STM32F103的風力擺系統,陀螺儀使用基于DMP的MPU6050可自行增加卡爾曼濾波

單片機源程序如下:
  1. #include "sys.h"       
  2. #include "delay.h"       
  3. #include "key.h"   
  4. #include "mpu6050.h"  
  5. #include "inv_mpu.h"
  6. #include "inv_mpu_dmp_motion_driver.h"
  7. #include "USART2.h"
  8. #include "pwm.h"
  9. #include "PID.h"
  10. #include "TIM.h"
  11. #include "KEY.h"
  12. #include "outputdata.h"

  13. u8 RUN_MODE=0;
  14. u8 Print=0;

  15. float pitch,roll,yaw;                 //歐拉角
  16. short aacx,aacy,aacz;                //加速度傳感器原始數據
  17. short gyrox,gyroy,gyroz;        //陀螺儀原始數據
  18. Pid_struct motor13_parameter,motor24_parameter;  // 電機pid參數

  19. void NVIC_Config(void);

  20. int main(void)
  21. {
  22.           short temp;                                        //溫度            
  23.           
  24.                 SystemInit();
  25.                 NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
  26.     NVIC_Config();
  27.            delay_init();                     //延時函數初始化       
  28.     PWM_Init(3000,0);    //0分頻。PWM頻率=72000/(4000*1)=14Khz
  29.     PWM_Init_2(3000,0);   
  30.     USART1_Config();   
  31.     KEY_Init();   

  32.    Speed_PIDInit(&motor13_parameter,30,0.2,100);   // 電機pid 參數初始化
  33.          Speed_PIDInit(&motor24_parameter,60,0.2,200);
  34.        
  35.          MPU_Init();               
  36.    delay_ms(500);   
  37.    while(mpu_dmp_init());   //初始化MPU6050_DMP
  38.      
  39.    TIM4_Init(10000-1,71);   //定時器初始化
  40.    uprintf(USART1," 系統啟動成功!\r\n");
  41.          
  42. while(1)
  43. {               
  44.    //           MPU_Get_Accelerometer(&aacx,&aacy,&aacz);        //得到加速度傳感器數據
  45.    //    MPU_Get_Gyroscope(&gyrox,&gyroy,&gyroz);        //得到陀螺儀數據   
  46.   KEY_Scan();
  47.   if(Print==1){   // 發送曲線到上位機
  48.    
  49.      OutData[0]=pitch;
  50.      OutData[1]=roll;
  51.      OutData[2]= motor13_parameter.out_duty/100;         
  52.      OutPut_Data();
  53. }          }         }


  54. void NVIC_Config(void)
  55. {
  56.          
  57.    
  58.          NVIC_InitTypeDef NVIC_InitStructure;                                          //復位NVIC寄存器為默認值       
  59.      NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);           //設置中斷優先級組

  60.         RCC_APB2PeriphClockCmd(   RCC_APB2Periph_GPIOA
  61.                                                         | RCC_APB2Periph_GPIOB
  62.                                                             | RCC_APB2Periph_GPIOC
  63.          //   | RCC_APB2Periph_GPIOD
  64.                                         //        | RCC_APB2Periph_AFIO
  65.                                                         | RCC_APB2Periph_TIM1
  66.                                   //        | RCC_APB2Periph_ADC1
  67.               | RCC_APB2Periph_USART1
  68.                                                         , ENABLE );

  69.         RCC_APB1PeriphClockCmd( RCC_APB1Periph_TIM3
  70.                                                         | RCC_APB1Periph_TIM4
  71.               | RCC_APB1Periph_TIM2
  72.                                                         , ENABLE);
  73.       
  74.    
  75.               //復位NVIC寄存器為默認值          
  76.     NVIC_InitStructure.NVIC_IRQChannel = TIM4_IRQn;       
  77.           NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;   //搶占優先級2
  78.     NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;              //響應優先級0
  79.           NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                   
  80.           NVIC_Init(&NVIC_InitStructure);
  81.    
  82.     NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
  83.     NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority =0;
  84.                 NVIC_InitStructure.NVIC_IRQChannelSubPriority =0;
  85.     NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  86.     NVIC_Init(&NVIC_InitStructure);
  87. }

復制代碼

原理圖: 無
仿真: 無
代碼: MPU6050_DMP_Stm32.7z (289.75 KB, 下載次數: 18)

評分

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

查看全部評分

回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 久久久不卡 | 中国少妇xxxxhd做受 | 欧美又大粗又爽又黄大片视频 | 久久在线免费视频 | 国产对白videos麻豆高潮 | 色哟哟一区二区三区 | 97在线观看免费视频 | 亚洲精品一二 | 久久人人爽人人爽人人片 | 黄视频在线播放 | 午夜视频一区二区三区 | 国产高清91 | 久久综合久 | 午夜在线观看免费视频 | 九九九久久久 | 伊人网在线播放 | 黄色三级视频在线观看 | 久久视频一区 | 亚洲第一区在线观看 | 欧美另类z0zx974 | 国产网友自拍 | 操操操日日日 | 久久午夜视频 | 91视频免费在线观看 | 日韩一级欧美一级 | 欧美区日韩区 | 成人免费福利视频 | 黄色片www| 亚洲国产一区在线观看 | 免费看黄色录像 | 久久免费精品视频 | h片免费观看 | 欧美不卡一区 | 九九热九九 | 色啪视频 | 成人免费视频视频 | 久久精品视频一区 | 综合网在线 | 亚洲69| 午夜视频一区二区三区 | 激情综合久久 |