news 2026/4/23 14:37:52

四旋翼PID姿态控制实战指南

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
四旋翼PID姿态控制实战指南

目录

1. 无人机姿态控制系统架构

2. PID 控制器设计

PID 结构体与初始化

PID 更新函数

3. 电机混控(四旋翼 X 模式)

4. 姿态角到电机控制的完整流程

5. 示例代码(STM32 HAL 库)

6. 调试与优化建议


将 MPU-9250 解算出的欧拉角(Pitch、Roll、Yaw)作为反馈,输入到PID 控制器,输出控制信号到四个电机,实现姿态稳定控制。

我会给你一个模块化的实现方案,包括:

  1. 系统控制架构
  2. PID 控制器设计
  3. 电机混控(Motor Mixing)
  4. 姿态数据与 PID 输出的结合
  5. 示例代码(STM32/CH32 + HAL 库)

1. 无人机姿态控制系统架构

典型四旋翼无人机的姿态控制是一个级联 PID 结构

┌─────────────┐ ┌─────────────┐ ┌─────────────┐ │ 姿态环 PID │ │ 角速度环PID │ │ 电机混控 │ │ (Pitch/Roll/Yaw) │ │ (ωx/ωy/ωz) │ │ (Motor1~4) │ └──────┬──────┘ └──────┬──────┘ └──────┬──────┘ │ │ │ ▼ ▼ ▼ ┌─────────────┐ ┌─────────────┐ ┌─────────────┐ │ 期望姿态角 │ │ 期望角速度 │ │ PWM信号输出 │ └─────────────┘ └─────────────┘ └─────────────┘
  • 姿态环:输入期望欧拉角(如悬停时为 0°)和实际欧拉角(来自 MPU-9250 DMP),输出期望角速度。
  • 角速度环:输入期望角速度和实际角速度(来自陀螺仪),输出电机控制量。
  • 电机混控:将姿态控制量映射到四个电机的 PWM 信号。

2. PID 控制器设计

PID 公式:u(t)=Kp​⋅e(t)+Ki​⋅∫0t​e(τ)dτ+Kd​⋅dtde(t)​其中:

  • e(t)=SetPoint−Feedback (误差)
  • Kp​,Ki​,Kd​ 分别为比例、积分、微分系数
  • 输出限幅防止积分饱和和电机超调

PID 结构体与初始化

typedef struct { float Kp, Ki, Kd; float setpoint; float feedback; float error; float integral; float derivative; float prev_error; float output; float integral_limit; // 积分限幅 float output_limit; // 输出限幅 } PID_Controller; void PID_Init(PID_Controller *pid, float Kp, float Ki, float Kd, float integral_limit, float output_limit) { pid->Kp = Kp; pid->Ki = Ki; pid->Kd = Kd; pid->integral_limit = integral_limit; pid->output_limit = output_limit; pid->setpoint = 0.0f; pid->feedback = 0.0f; pid->error = 0.0f; pid->integral = 0.0f; pid->derivative = 0.0f; pid->prev_error = 0.0f; pid->output = 0.0f; }

PID 更新函数

void PID_Update(PID_Controller *pid, float dt) { pid->error = pid->setpoint - pid->feedback; // 比例项 float P = pid->Kp * pid->error; // 积分项(带限幅) pid->integral += pid->error * dt; if (pid->integral > pid->integral_limit) pid->integral = pid->integral_limit; if (pid->integral < -pid->integral_limit) pid->integral = -pid->integral_limit; float I = pid->Ki * pid->integral; // 微分项 pid->derivative = (pid->error - pid->prev_error) / dt; float D = pid->Kd * pid->derivative; // 总输出 pid->output = P + I + D; // 输出限幅 if (pid->output > pid->output_limit) pid->output = pid->output_limit; if (pid->output < -pid->output_limit) pid->output = -pid->output_limit; pid->prev_error = pid->error; }

3. 电机混控(四旋翼 X 模式)

四旋翼 X 模式的电机布局:

Motor2 (CCW) ↑ | Motor1 (CW) ←———→ Motor3 (CW) | ↓ Motor4 (CCW)

混控公式(简化版):Motor1=Throttle+Roll−Pitch−YawMotor2=Throttle−Roll−Pitch+YawMotor3=Throttle−Roll+Pitch−YawMotor4=Throttle+Roll+Pitch+Yaw

其中:

  • Throttle:油门(总升力)
  • RollPitchYaw:PID 输出的姿态控制量

4. 姿态角到电机控制的完整流程

  1. 读取 MPU-9250 姿态数据(Pitch, Roll, Yaw)和陀螺仪数据(ωx, ωy, ωz)。
  2. 姿态环 PID:输入期望姿态角(如悬停时为 0°)和实际姿态角,输出期望角速度。
  3. 角速度环 PID:输入期望角速度和实际角速度,输出姿态控制量(Roll, Pitch, Yaw)。
  4. 电机混控:结合油门和姿态控制量,计算四个电机的 PWM 值。
  5. 输出到电调:通过定时器 PWM 输出控制电机转速。

5. 示例代码(STM32 HAL 库)

#include "stm32f1xx_hal.h" #include "mpu9250.h" #include "pid.h" // 定义 PID 控制器 PID_Controller pid_pitch, pid_roll, pid_yaw; PID_Controller pid_rate_pitch, pid_rate_roll, pid_rate_yaw; // 姿态数据 EulerAngles euler; float gyro[3]; // ωx, ωy, ωz (°/s) // 电机 PWM 值(1000~2000us) uint16_t motor1, motor2, motor3, motor4; float throttle = 1000.0f; // 初始油门 // 初始化 void Drone_Init(void) { // 初始化 MPU-9250 mpu_init(); // 初始化姿态环 PID(角度控制) PID_Init(&pid_pitch, 5.0f, 0.1f, 0.2f, 100.0f, 500.0f); PID_Init(&pid_roll, 5.0f, 0.1f, 0.2f, 100.0f, 500.0f); PID_Init(&pid_yaw, 4.0f, 0.05f, 0.1f, 100.0f, 500.0f); // 初始化角速度环 PID(速率控制) PID_Init(&pid_rate_pitch, 2.0f, 0.05f, 0.1f, 100.0f, 500.0f); PID_Init(&pid_rate_roll, 2.0f, 0.05f, 0.1f, 100.0f, 500.0f); PID_Init(&pid_rate_yaw, 1.5f, 0.05f, 0.1f, 100.0f, 500.0f); // 初始化定时器 PWM(如 TIM1 CH1~CH4) HAL_TIM_PWM_Start(&htim1, TIM_CHANNEL_1); HAL_TIM_PWM_Start(&htim1, TIM_CHANNEL_2); HAL_TIM_PWM_Start(&htim1, TIM_CHANNEL_3); HAL_TIM_PWM_Start(&htim1, TIM_CHANNEL_4); } // 控制循环(100Hz) void Drone_Control_Loop(void) { float dt = 0.01f; // 10ms // 读取姿态和陀螺仪数据 read_dmp_data(&euler, gyro); // 姿态环:输入期望角度(此处为 0° 悬停) pid_pitch.setpoint = 0.0f; pid_roll.setpoint = 0.0f; pid_yaw.setpoint = 0.0f; pid_pitch.feedback = euler.pitch; pid_roll.feedback = euler.roll; pid_yaw.feedback = euler.yaw; PID_Update(&pid_pitch, dt); PID_Update(&pid_roll, dt); PID_Update(&pid_yaw, dt); // 角速度环:输入姿态环输出作为期望角速度 pid_rate_pitch.setpoint = pid_pitch.output; pid_rate_roll.setpoint = pid_roll.output; pid_rate_yaw.setpoint = pid_yaw.output; pid_rate_pitch.feedback = gyro[0]; pid_rate_roll.feedback = gyro[1]; pid_rate_yaw.feedback = gyro[2]; PID_Update(&pid_rate_pitch, dt); PID_Update(&pid_rate_roll, dt); PID_Update(&pid_rate_yaw, dt); // 电机混控 motor1 = throttle + pid_rate_roll.output - pid_rate_pitch.output - pid_rate_yaw.output; motor2 = throttle - pid_rate_roll.output - pid_rate_pitch.output + pid_rate_yaw.output; motor3 = throttle - pid_rate_roll.output + pid_rate_pitch.output - pid_rate_yaw.output; motor4 = throttle + pid_rate_roll.output + pid_rate_pitch.output + pid_rate_yaw.output; // 限幅 motor1 = (motor1 < 1000) ? 1000 : (motor1 > 2000) ? 2000 : motor1; motor2 = (motor2 < 1000) ? 1000 : (motor2 > 2000) ? 2000 : motor2; motor3 = (motor3 < 1000) ? 1000 : (motor3 > 2000) ? 2000 : motor3; motor4 = (motor4 < 1000) ? 1000 : (motor4 > 2000) ? 2000 : motor4; // 输出到电机 __HAL_TIM_SET_COMPARE(&htim1, TIM_CHANNEL_1, motor1); __HAL_TIM_SET_COMPARE(&htim1, TIM_CHANNEL_2, motor2); __HAL_TIM_SET_COMPARE(&htim1, TIM_CHANNEL_3, motor3); __HAL_TIM_SET_COMPARE(&htim1, TIM_CHANNEL_4, motor4); }

6. 调试与优化建议

  1. PID 参数整定
    • 先调角速度环,再调姿态环。
    • 从较小的 Kp 开始,逐步增加,直到系统有轻微振荡,再加入 Ki 和 Kd。
  2. 传感器校准
    • MPU-9250 陀螺仪和加速度计必须校准,磁力计建议做八位置校准。
  3. 安全保护
    • 加入低电压保护、失控保护(如油门低于阈值时自动降落到地面)。
  4. 滤波
    • 对姿态角和角速度数据进行滑动平均或卡尔曼滤波,减少噪声。
  5. 仿真
    • 可以先用 MATLAB/Simulink 搭建仿真模型,验证 PID 参数和控制逻辑。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 13:16:05

YOLOv8使用指南:Jupyter与SSH双模式开发环境详解

YOLOv8开发实战&#xff1a;Jupyter与SSH双模环境的高效构建与应用 在智能安防摄像头自动识别可疑行为、工业质检系统毫秒级定位产品缺陷的今天&#xff0c;目标检测早已不再是实验室里的概念模型。YOLO&#xff08;You Only Look Once&#xff09;系列自2015年横空出世以来&am…

作者头像 李华
网站建设 2026/4/23 13:59:56

YOLOv8 SOLO开创性实例分割架构适配

YOLOv8 SOLO开创性实例分割架构适配 在智能摄像头能识别行人轨迹、无人机自动圈出农田病害区域的今天&#xff0c;我们早已不再满足于“图中有辆车”这样的粗粒度判断。真正的智能视觉&#xff0c;需要回答的是&#xff1a;“哪一辆车&#xff1f;”、“它的轮廓有多长&#xf…

作者头像 李华
网站建设 2026/4/21 13:37:57

还在熬夜赶稿?这6款AI写论文工具,5分钟就能搞定全文!

还在为“引言”憋不出300字而痛苦抓狂&#xff1f;还在因为导师一句“逻辑混乱、重写”而通宵爆肝&#xff1f;还在为查重率、AI率双双飘红而心惊胆战&#xff0c;感觉毕业遥遥无期&#xff1f; 如果你的答案是肯定的&#xff0c;那么恭喜你&#xff0c;你正在经历学术写作中最…

作者头像 李华
网站建设 2026/4/23 13:59:55

YOLOv8推理演示:使用bus.jpg完成首次目标检测任务

YOLOv8推理演示&#xff1a;使用bus.jpg完成首次目标检测任务 在智能交通系统日益普及的今天&#xff0c;如何让一辆自动驾驶车辆“看清”前方道路上的公交车、行人和障碍物&#xff1f;这背后离不开高效的目标检测技术。而在这类应用中&#xff0c;YOLOv8正逐渐成为开发者的首…

作者头像 李华
网站建设 2026/4/18 1:49:56

YOLOv8 Low-rank Approximation低秩近似降维

YOLOv8 Low-rank Approximation低秩近似降维 在边缘计算设备日益普及的今天&#xff0c;如何让高性能目标检测模型在资源受限的场景下依然保持高效运行&#xff0c;已成为AI工程落地的核心挑战之一。YOLOv8作为当前最主流的目标检测框架之一&#xff0c;虽具备出色的精度与速度…

作者头像 李华
网站建设 2026/4/18 5:41:22

YOLOv8 Depthwise Separable Conv深度可分离卷积优化

YOLOv8中的深度可分离卷积&#xff1a;轻量化目标检测的工程实践 在智能安防摄像头、无人机避障系统或工业质检流水线上&#xff0c;我们常常面临一个共同挑战&#xff1a;如何在有限算力的边缘设备上实现高帧率、低延迟的目标检测&#xff1f;传统模型如YOLOv5虽然精度出色&am…

作者头像 李华