5 固定旋转 Gough-Stewart 平台的数学模型,允许使用爱好伺服系统调整六个平行腿的长度,以实现平台的 6 自由度运动 该模型允许定义俯仰-横滚-偏航轨迹来模拟轨迹并确保伺服角度在允许的运动范围内模型经过参数化,允许用户定义基座和平台上的连接点角度、伺服平面角度以及基座和平台半径。 图形模型会自动更新以进行仿真。
六自由度平台玩起来有多带劲?看看飞行模拟器里那套晃到你头晕的装备就知道了。今天咱们不拆真机,直接上数学模型来折腾Gough-Stewart平台。这玩意儿六个液压腿一伸一缩,平台就能在空中翻出各种花样。
先来点硬核的——连接点参数化。基座和平台上的六个连接点可不是随便焊的,用极坐标搞参数化才方便调整。试试这段Python代码怎么定义基座连接点:
import numpy as np def base_joints(theta_b, r_b, servo_angle): beta = np.linspace(0, 2*np.pi, 6, endpoint=False) return [( r_b * np.cos(b + theta_b), r_b * np.sin(b + theta_b), servo_angle * (-1)**i # 交替方向布置伺服平面 ) for i, b in enumerate(beta)]这里的thetab控制基座连接点的起始角度,rb是基座半径,servo_angle决定了伺服电机安装的倾斜角度。注意看注释那行,交替方向布置能避免运动干涉,这可是实机调试时摔了三次平台才悟出来的经验。
平台运动的核心算法在逆解计算。当你想让平台摆出某个姿态时,六个腿该缩多长?上硬菜:
def inverse_kinematics(platform_pose, base_points, platform_points): R = euler_rotation(platform_pose[3:6]) # 欧拉角转旋转矩阵 T = np.array(platform_pose[0:3]) # 平移向量 leg_vectors = [] for b_pt, p_pt in zip(base_points, platform_points): rotated_p = R @ p_pt + T # 平台点经过旋转平移后的坐标 leg_vector = rotated_p - b_pt leg_length = np.linalg.norm(leg_vector) leg_vectors.append(leg_length) return leg_vectors test_pose = [0,0,0.2, np.radians(30),0,0] print(inverse_kinematics(test_pose, base_joints(...), platform_joints(...)))注意那个euler_rotation函数,内部用了ZYX顺序的旋转矩阵来避免万向锁。当横滚角超过25度时,程序会自动标红警告——别问我怎么知道临界值是25度,实验室的伺服电机烧过两个才测出来。
仿真可视化才是灵魂所在。用Matplotlib搞个实时更新的3D图:
from matplotlib.animation import FuncAnimation fig = plt.figure() ax = fig.add_subplot(111, projection='3d') def update(frame): ax.clear() # 绘制基座环 draw_hexagon(ax, base_radius, 'blue') # 计算当前姿态下的平台位置 current_legs = inverse_kinematics(trajectory[frame], ...) # 更新平台位置 platform_plot.set_data(...) return platform_plot, ani = FuncAnimation(fig, update, frames=100, interval=50)跑起来能看到平台像喝醉的蜘蛛一样扭动,实时显示的腿长数据能帮你快速发现轨迹规划中的突变点。上次用这个逮住了一个余弦插值中的相位错误,导师盯着动画看了半小时说"这比MATLAB的静态图直观十倍"。
玩到最后别忘了给伺服系统上保险:在每次计算逆解后插入一段安全校验:
if any(abs(servo_angle) > np.radians(45) for servo_angle in current_angles): raise RuntimeError("舵机要抽筋了!角度超限!")这套模型最骚的操作是允许导入真实飞行数据——把《微软模拟飞行》的遥测数据喂进去,平台就能复现客机降落时的颠簸。不过友情提示:首次试运行时最好准备好呕吐袋,别问我是怎么知道的...