PID算法的極好學習資料,匿名四軸資料
stm32單片機風力擺源程序如下:
- #include "sys.h"
- #include "delay.h"
- #include "usart.h"
- #include "led.h"
- #include "key.h"
- #include "mpu6050.h"
- #include "pwmset.h"
- #include "niming.h"
- #include "pid.h"
- #include "usmart.h"
- #include "inv_mpu.h"
- #include "inv_mpu_dmp_motion_driver.h"
- volatile float pitch,roll,yaw; //歐拉角
- volatile u8 mode = 1; //當前工作方式
- volatile float step = 0;
- int main(void)
- {
- Stm32_Clock_Init(9); //系統時鐘設置
- uart_init(72,500000); //串口初始化為500000
- delay_init(72); //延時初始化
- usmart_dev.init(72); //初始化USMART
- LED_Init(); //初始化與LED連接的硬件接口
- KEY_Init(); //初始化按鍵
- MPU_Init(); //初始化MPU6050
- TIM3_PWM_Init(999,8); //初始化脈寬波輸出
- TIM2_Int_Init(4999,71); //初始化定時器2,每5ms產生一次中斷
- while(mpu_dmp_init())
- {
- delay_ms(20);
- }
-
- while(1)
- {
- key=KEY_Scan(0);
- if(key==KEY2_PRES) //測試發送pid數據給上位機
- {
- pid_send_data(rol_p,rol_i,rol_d,pit_p,pit_i,pit_d);
- }
-
- if(key==KEY0_PRES) //開啟或關閉下位機數據發送開關
- {
- report=!report;
- }
- if(key==KEY1_PRES) //開啟或關閉下位機數據發送開關
- {
- Rol_SumError = 0;
- }
- if(key == KEY8_PRES) //PE8按下
- {
- rol_p += 1;
- LED0 = ~LED0;
- }
- if(key == KEY9_PRES)
- {
- rol_i += 0.1;
- LED0 = ~LED0;
- }
- if(key == KEY10_PRES)
- {
- R += 0.05;
- LED0 = ~LED0;
- }
- if(key == KEY11_PRES) //模式切換
- {
- mode++;
- LED0 = ~LED0;
- }
- if(key == KEY12_PRES)
- {
- rol_p -= 1;
- LED0 = ~LED0;
- }
- if(key == KEY13_PRES)
- {
- rol_i -= 0.1;
- LED0 = ~LED0;
- }
- if(key == KEY14_PRES)
- {
- R -= 0.05;
- LED0 = ~LED0;
- }
- if(key == KEY15_PRES)
- {
- mode--; //模式切換
- LED0 = ~LED0;
- }
-
- if(USART_RX_STA == 1) //檢測是否接收到了數據。
- {
- USART_RX_STA = 0; //清除接收標志,防止多次判斷。
- LED1 = ~LED1;
- rol_p = (USART_RX_BUF[4]<<8)|USART_RX_BUF[5];
- rol_i = (USART_RX_BUF[6]<<8)|USART_RX_BUF[7];
- rol_d = (USART_RX_BUF[8]<<8)|USART_RX_BUF[9];
- pit_p = (USART_RX_BUF[10]<<8)|USART_RX_BUF[11];
- pit_i = (USART_RX_BUF[12]<<8)|USART_RX_BUF[13];
- pit_d = (USART_RX_BUF[14]<<8)|USART_RX_BUF[15];
- }
-
- }
- }
復制代碼
所有資料51hei提供下載:
15電賽風力擺源碼及上位機.rar
(3.81 MB, 下載次數: 144)
2017-8-12 00:06 上傳
點擊文件名下載附件
|