逆向运动学(IK)是根据末端执行器目标位置反推关节角度的过程,无唯一解析解;2D双连杆可用几何法求解,需判断可达性并用余弦定理与atan2计算两关节角;3D多关节常用CCD迭代法,逐关节旋转优化至收敛。
逆向运动学是给定末端执行器(比如机械臂末端或角色的手)的目标位置,反推各关节角度的过程。和正向运动学(已知关节角求末端位置)相反,IK没有唯一解析解,尤其对3自由度以上链式结构。但对简单场景(如2D双连杆、3D三连杆),可以用几何法或数值法快速求解。
最基础也最实用的案例:平面内两个旋转关节组成的机械臂,目标是让末端到达指定(x, y)点。假设两节长度为 L1 和 L2,基座在原点,关节1绕z轴旋转,关节2同理。
关键步骤:
若小于 abs(L1 - L2),也无解(目标太近)代码片段(C++,返回角度对):
#include#include std::pair
solve2DIK(double x, double y, double L1, double L2) { double d_sq = xx + yy; double d = std::sqrt(d_sq); if (d > L1 + L2 || d < std::abs(L1 - L2)) return {0.0, 0.0}; // 不可达 double cos_theta2 = (d_sq - L1*L1 - L2*L2) / (2*L1*L2); cos_theta2 = std::clamp(cos_theta2, -1.0, 1.0); // 防浮点误差 double theta2 = std::acos(cos_theta2); // 默认肘向下解 double theta1 = std::atan2(y, x) - std::atan2(L2*std::sin(theta2), L1 + L2*std::cos(theta2)); return {theta1, theta2};}
当关节多于2个、或需在3D空间中工作时,几何法变复杂。CCD是一种轻量、稳定、易实现的迭代数值法:从末端关节开始,逐个调整每个关节,使末端更接近目标,直到误差足够小或达到最大迭代次数。
核心思想:每次只优化一个关节,保持其余部分不变,用“局部最优”逼近全局目标。
优点是无需雅可比矩阵,不涉及求导或矩阵求逆,适合嵌入式或实时动画系统。
写IK解算器不是一劳永逸的事,要注意几个现实问题:
基本上就这些。从2D几何解出发,再到3D CCD迭代,你已经掌握了机器人和动画中最常用、最可控的IK实现路径。