Model-predictive control (MPC) is a powerful tool for controlling highly dynamic robotic systems subject to complex constraints. However, MPC is computationally demanding, and is often impractical to implement on small, resource-constrained robotic platforms. We present TinyMPC, a high-speed MPC solver with a low memory footprint targeting the microcontrollers common on small robots. Our approach is based on the alternating direction method of multipliers (ADMM) and leverages the structure of the MPC problem for efficiency. We demonstrate TinyMPC both by benchmarking against the state-of-the-art solver OSQP, achieving nearly an order of magnitude speed increase, as well as through hardware experiments on a 27 g quadrotor, demonstrating high-speed trajectory tracking and dynamic obstacle avoidance.
翻译:模型预测控制(MPC)是控制受复杂约束的高动态机器人系统的强大工具。然而,MPC计算量大,在小型资源受限的机器人平台上往往难以实现。我们提出TinyMPC,一种面向小型机器人常用微控制器、具有低内存占用的高速MPC求解器。我们的方法基于交替方向乘子法(ADMM),并利用MPC问题的结构特性提升效率。我们通过与最先进的求解器OSQP进行基准测试(实现近一个数量级的速度提升)以及在27克四旋翼飞行器上的硬件实验(展示高速轨迹跟踪与动态避障能力)验证了TinyMPC的性能。