机器人学(MATLAB机器人工具箱10.x)——3.5-特殊问题

本文介绍了MATLAB机器人工具箱中处理机器人学问题的方法,特别是关节角偏移和D-H参数的确定。关节角偏移允许设定任意位形为零关节坐标,D-H参数可以通过经典方法或改进方法来描述机器人结构。工具箱支持两种D-H参数形式,包括标准和改进版,并展示了如何创建和理解这些参数在机器人运动学中的应用。
摘要由CSDN通过智能技术生成

关节角偏移

机器人的零关节角位姿往往是某个很不寻常的(甚至是机械无法实现的)位姿。对于 Puma 机器人,其零角度位姿就呈现出一种不是很明显的 L 形状,机器人的上臂水平,下臂垂直向上,如图所示。
在这里插入图片描述
这一结果是由机器人的 D-H 参数形式所决定的。机器人的控制设计人员可能会选择零关节角位姿为一些更为明显的位形。关节坐标偏移提供了一种机制,它使我们可以设置任意位形作为零关节坐标。偏移向量 q 0 q_0 q0 要在任何运动学或动力学函数被调用之前被加到用户指定的关节角度上。例如:
ξ = K ( q + q 0 ) \xi=\mathcal{K}(q+q_0) ξ=K(q+q0)
类似地,它要在执行一次运算操作后被减去,如逆运动学:
q = K − 1 ( ξ ) − q 0 q = \mathcal{K}^{-1}(\xi)-q_0 q=K1(ξ)q0
偏移量设置是通过设定Link对象的offset属性来完成的。例如:

>> L = Link([0 0 1 0]);
>> L.offset = pi/4
 
L = 
Revolute(std): theta=q, d=0, a=1, alpha=0, offset=0.785398

或者

>> p560.links(2).offset = pi/2

如图所示
在这里插入图片描述

确定 D-H 参数

确定 D-H 参数的经典方法是系统地为每个连杆分配一个坐标系。Puma 机器人的连杆坐标系就是采用标准 D-H 形式进行设定的,如图所示。
在这里插入图片描述
然而,每一个坐标系都有很强的约束,因为关节旋转必须围绕 z z z 轴,连杆位移必须沿 x x x 方向。这也为基座和末端执行器坐标系的设定施加了约束,进而最终决定了前面讨论的零角度位姿。因此为一个全新的机械臂确定 D-H 参数和连杆坐标系要比想象的困难。
工具箱还支持另一种方法,它简单地将机械臂描述为一系列从末端执行器基座到顶端的基本平移和旋转。有些基本操作是常数,如表示连杆长度或偏移量的平移,而一些操作是广义关节坐标 q i q_i qi 的函数。不同于传统的方法,我们不对这些有可能发生旋转和平移的轴施加任何约束。
在这里插入图片描述
如上图所示的一个例子,我们首先在基座上随便定义一个坐标系,然后把从基座到顶端的平移和旋转序列写入一个字符串:

>>  s = 'Tz(L1) Rz(q1) Ry(q2) Ty(L2) Tz(L3) Ry(q3) Tx(L4) Ty(L5) Tz(L6) Rz(q4) Ry(q5) Rz(q6)'

请注意,我们已经将第二关节描述为Ry(q2),即绕 y y y 轴的旋转,它不能使用 D-H 形式。
该字符串被输入一个符号代数函数:

>> dh = DHFactor(s);

它返回一个 DHFactor 对象,其中保存了已被分解为 D-H 参数的机器人运动学结构。我们可以将该结构以一种可读形式显示出来:

>> dh
dh =
DH(q1, L1, 0, -90).DH(q2+90, 0, -L3, 0).DH(q3-90, L2+L5, L4, 90).DH(q4, L6, 0, -90).DH(q5, 0, 0, 90).DH(q6, 0, 0, 0)

其显示的各关节 D-H 参数顺序分别为 θ \theta θ d d d a a a α \alpha α。关节角偏移量(一个加到或减去的常量,相对于从关节角变量,如 q 2 q_2 q2 q 3 q_3 q3)是自动生成的,基座和工具变换也是自动生成的。这个对象还可以生成一个字符串,它是一个工具箱命令,用于创建一个名为“puma”的机器人:

>> cmd = dh.command('puma');
>> cmd
cmd =
SerialLink([0, L1, 0, -pi/2, 0; 0, 0, -L3, 0, 0; 0, L2+L5, L4, pi/2, 0; 0, L6, 0, -pi/2, 0; 0, 0, 0, pi/2, 0; 0, 0, 0, 0, 0; ], 'name', 'puma', 'base', eye(4,4), 'tool', eye(4,4), 'offset', [0 pi/2 -pi/2 0 0 0 ])

当定义了L1L6后,这个命令可以被执行:

>> robot = eval(cmd);

它创建一个名为robot的工作空间变量,该变量是一个SerialLink对象。

改进型 D-H 参数

1986年,克雷格[Craig 1986]首先提出了一种改进的 D-H 参数,如图所示
在这里插入图片描述

其中每个连杆坐标系被固接到该连杆的近端(靠近前一个连杆),而不是其远端。经过这种修改,使得参数符号在某些方面显得更加清晰和简洁,因而目前这种 D-H 参数法也更为常用。然而它的引入也增加了更多的混乱,特别是对那些机器人运动学的初学者。该问题的根源在于运动学、雅可比矩阵和动力学的算法都是依赖于其使用的运动学约定。根据克雷格的约定,连杆变换矩阵是
j − 1 A j = R x ( α j − 1 ) T x ( a j − 1 ) R z ( θ j ) T z ( d j ) ^{j-1}A_j=R_x(\alpha_{j-1})T_x(a_{j-1})R_z(\theta_j)T_z(d_j) j1Aj=Rx(α

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值