计算机器人正反运动学方程,机器人运动学方程

2.8机器人正运动学方程的D-H表示法

在1955年,Denavit和Hartenberg在“ASME Journal of Applied Mechanics”发表了一篇论文,后来利用那个这篇论文来对机器人进行表示和建模,并导出了它们的运动方程,这已成为表示机器人和对机器人运动进行建模的标准方法,所以必须学习这部分内容。Denavit-Hartenberg(D_H)模型表示了对机器人连杆和关节进行建模的一种非常简单的方法,可用于任何机器人构型,而不管机器人的结构顺序和复杂程度如何。它也可用于表示已经讨论过的在任何坐标中的变换,例如直角坐标、圆柱坐标、球坐标、欧拉角坐标及RPY坐标等。另外,它也可以用于表示全旋转的链式机器人、SCARA机器人或任何可能的关节和连杆组合。尽管采用前面的方法对机器人直接建模会更快、更直接,但D-H表示法有其附加的好处,使用它已经开发了许多技术,例如,雅克比矩阵的计算和力分析等。

假设机器人由一系列关节和连杆组成。这些关节可能是滑动(线性)的或旋转(转动)的,它们可以按任意的顺序放置并处于任意的平面。连杆也可以是任意的长度(包括零),它可能被弯曲或扭曲,也可能位于任意平面上。所以任何一组关节和连杆都可以构成一个我们想要建模和表示的机器人。

为此,需要给每个关节指定一个参考坐标系,然后,确定从一个关节到下一个关节(一个坐标系到下一个坐标系)来进行变换的步骤。如果将从基座到第一个关节,再从第一个关节到第二个关节直至到最后一个关节的所有变换结合起来,就得到了机器人的总变换矩阵。在下一节,将根据D-H表示法确定一个一般步骤来为每个关节指定参考坐标系,然后确定如何实现任意两个相邻坐标系之间的变换,最后写出机器人的总变换矩阵。

clip_image002.jpg

图2.25    通用关节—连杆组合的D-H表示

假设一个机器人由任意多的连杆和关节以任意形式构成。图2.25表示了三个顺序的关节和两个连杆。虽然这些关节和连杆并不一定与任何实际机器人的关节或连杆相似,但是他们非常常见,且能很容易地表示实际机器人的任何关节。这些关节可能是旋转的、滑动的、或两者都有。尽管在实际情况下,机器人的关节通常只有一个自由度,但图2.25中的关节可以表示一个或两个自由度。

图2.25(a)表示了三个关节,每个关节都是可以转动或平移的。第一个关节指定为关节n,第二个关节为关节n+1,第三个关节为关节n+2。在这些关节的前后可能还有其他关节。连杆也是如此表示,连杆n位于关节n与n+1之间,连杆n+1位于关节n+1与n+2之间。

为了用D-H表示法对机器人建模,所要做的第一件事是为每个关节指定一个本地的参考坐标系。因此,对于每个关节,都必须指定一个z轴和x轴,通常并不需要指定y轴,因为y轴总是垂直于x轴和z轴的。此外,D-H表示法根本就不用y轴。以下是给每个关节指定本地参考坐标系的步骤:

所有关节,无一例外的用z轴表示。如果关节是旋转的,z轴位于按右手规则旋转的方向。如果关节是滑动的,z轴为沿直线运动的方向。在每一种情况下,关节n处的z轴(以及该关节的本地参考坐标系)的下表为n-1。例如,表示关节数n+1的z轴是

clip_image004.gif。这些简单规则可使我们很快地定义出所有关节的z轴。对于旋转关节,绕z轴的旋转(

clip_image006.gif角)是关节变量。对于滑动关节,沿z轴的连杆长度d是关节变量。

如图2.25(a)所示,通常关节不一定平行或相交。因此,通常z轴是斜线,但总有一条距离最短的公垂线,它正交于任意两条斜线。通常在公垂线方向上定义本地参考坐标系的x轴。所以如果

clip_image008.gif表示

clip_image010.gif

clip_image004_0000.gif之间的公垂线,则

clip_image013.gif的方向将沿

clip_image008_0000.gif。同样,在

clip_image004_0001.gif

clip_image010_0000.gif之间的公垂线为

clip_image015.gif

clip_image017.gif的方向将沿

clip_image015_0000.gif。注意相邻关节之间的公垂线不一定相交或共线,因此,两个相邻坐标系原点的位置也可能不在同一个位置。根据上面介绍的知识并考虑下面例外的特殊情况,可以为所有的关节定义坐标系。

如果两个关节的z轴平行,那么它们之间就有无数条公垂线。这时可挑选与前一关节的公垂线共线的一条公垂线,这样做就可以简化模型。

入股两个相邻关节的z轴是相交的,那么它们之间就没有公垂线(或者说公垂线距离为零)。这时可将垂直于两条轴线构成的平面的直线定义为x轴。也就是说,其公垂线是垂直于包含了两条z轴的平面的直线,它也相当于选取两条z轴的叉积方向作为x轴。这也会使模型得以简化。

在图2.25(a)中,

clip_image006_0000.gif角表示绕z轴的旋转角,d表示在z轴上两条相邻的公垂线之间的距离,a表示每一条公垂线的长度(也叫关节偏移量),角

clip_image020.gif表示两个相邻的z轴之间的角度 (也叫关节扭转)。通常,只有

clip_image006_0001.gif和d是关节变量。

下一步来完成几个必要的运动,即将一个参考坐标系变换到下一个参考坐标系。假设现在位于本地坐标系

clip_image022.gif,那么通过以下四步标准运动即可到达下一个本地坐标系

clip_image024.gif

(1)绕

clip_image026.gif轴旋转

clip_image028.gif(如图2.25(a)与(b)所示),它使得

clip_image013_0000.gif

clip_image031.gif互相平行,因为

clip_image008_0001.gif

clip_image034.gif都是垂直于

clip_image026_0000.gif轴的,因此绕

clip_image026_0001.gif轴旋转

clip_image038.gif使它们平行(并且共面)。

(2)沿

clip_image004_0002.gif轴平移

clip_image041.gif距离,使得

clip_image013_0001.gif

clip_image017_0000.gif共线(如图2.25(c)所示)。因为

clip_image013_0002.gif

clip_image017_0001.gif已经平行并且垂直于

clip_image004_0003.gif,沿着

clip_image004_0004.gif移动则可使它们互相重叠在一起。

(3)沿

clip_image013_0003.gif轴平移

clip_image015_0001.gif的距离,使得

clip_image013_0004.gif

clip_image031_0000.gif的原点重合(如图2.25(d)和(e)所示)。这是两个参考坐标系的原点处在同一位置。

(4)将

clip_image026_0002.gif轴绕

clip_image031_0001.gif轴旋转

clip_image052.gif,使得

clip_image026_0003.gif轴与

clip_image055.gif轴对准(如图2.25(f)所示)。这时坐标系n和n+1完全相同(如图2.25(g)所示)。至此,我们成功地从一个坐标系变换到了下一个坐标系。

在n+1和n+2坐标系间严格地按照同样的四个运动顺序可以将一个坐标变换到下一个坐标系。如有必要,可以重复以上步骤,就可以实现一系列相邻坐标系之间的变换。从参考坐标系开始,我们可以将其转换到机器人的基座,然后到第一个关节,第二个关节……,直至末端执行器。这里比较好的一点是,在任何两个坐标系之间的变换均可采用与前面相同的运动步骤。

通过右乘表示四个运动的四个矩阵就可以得到变换矩阵A,矩阵A表示了四个依次的运动。由于所有的变换都是相对于当前坐标系的(即他们都是相对于当前的本地坐标系来测量与执行),因此所有的矩阵都是右乘。从而得到结果如下:

clip_image057.gif

clip_image059.gif

clip_image061.gif           (2.51)

clip_image063.gif       (2.52)

比如,一般机器人的关节2与关节3之间的变换可以简化为:

clip_image065.gif           (2.53)

在机器人的基座上,可以从第一个关节开始变换到第二个关节,然后到第三个……,再到机器人的手,最终到末端执行器。若把每个变换定义为,则可以得到许多表示变换的矩阵。在机器人的基座与手之间的总变换则为:

clip_image067.gif                  (2.54)

其中n是关节数。对于一个具有六个自由度的机器人而言,有6个A矩阵。

为了简化A矩阵的计算,可以制作一张关节和连杆参数的表格,其中每个连杆和关节的参数值可从机器人的原理示意图上确定,并且可将这些参数代入A矩阵。表2.1可用于这个目的。

在以下几个例子中,我们将建立必要的坐标系,填写参数表,并将这些数值代入A矩阵。首先从简单的机器人开始,以后再考虑复杂的机器人。

表2.1     D-H参数表

#

clip_image006_0002.gif

d

a

clip_image020_0000.gif

1

2

3

4

5

6

对于如图2.26所示的简单机器人,根据D-H表示法,建立必要的坐标系,并填写相应的参数表。

解:

为方便起见,在此例中,假设关节2,3和4在同一平面内,即它们的

clip_image071.gif值为0。为建立机器人的坐标系,首先寻找关节(如图2.26所示)。该机器人有六个自由度,在这个简单机器人中,所有的关节都是旋转的。第一个关节(关节1)在连杆0(固定基座)和连杆1之间,关节2在连杆1和连杆2之间,等等。首先,如前面已经讨论过的那样,对每个关节建立z轴,接着建立z轴。观察图2.27和图2.28所示的坐标可以发现,图2.28是图2.27的简化线图。应注意每个坐标系原点3在它所在位置的原因。

clip_image073.jpg

图2.26    具有六个自由度的简单链式机器人

clip_image075.jpg

图2.27    简单六个自由度链式机器人的参考坐标系

clip_image077.jpg

图2.28    简单六个自由度链式机器人的参考坐标系线图

从关节1开始,

clip_image079.gif表示第一个关节,它是一个旋转关节。选择

clip_image081.gif与参考坐标系的x轴平行,这样做仅仅是为了方便,

clip_image081_0000.gif是一个固定的坐标轴,表示机器人的基座,它是不动的。第一个关节的运动是围绕着

clip_image079_0000.gif-

clip_image081_0001.gif轴进行的,但这两个轴并不运动。接下来,在关节2处设定

clip_image084.gif,因为坐标轴

clip_image079_0001.gif

clip_image084_0000.gif是相交的,所以

clip_image086.gif垂直于

clip_image079_0002.gif

clip_image084_0001.gif

clip_image088.gif

clip_image084_0002.gif

clip_image090.gif之间的公垂线方向上,

clip_image092.gif

clip_image090_0000.gif

clip_image094.gif之间的公垂线方向上,类似地,

clip_image096.gif

clip_image094_0000.gif

clip_image098.gif之间的公垂线方向上。最后,

clip_image100.gif

clip_image102.gif是平行且共线的。

clip_image100_0000.gif表示关节6的运动,而

clip_image102_0000.gif表示末端执行的运动。通常在运动方程中不包含末端执行器,但应包含末端执行器的坐标系,这是因为它可以容许进行从坐标系

clip_image104.gif出发的变换。同时也要注意第一个和最后一个坐标系的原点的位置,它们将决定机器人的总编换方程。可以在第一个和最后的坐标系之间建立其他的(或不同的)中间坐标系,但只要第一个和最后的坐标系没有改变,机器人的总变换便是不变的。应注意的是,第一个关节的原点并不在关节的实际位置,但证明这样做是没有问题的,因为无论实际关节是高一点还是低一点,机器人的运动并不会有任何差异。因此,考虑原点位置时可不用考虑基座上关节的实际位置。

接下来,我们将根据已建立的坐标系来填写表2.2中的参数。参考前一节中任意两个坐标系之间的四个运动的顺序。从

clip_image106.gif开始,有一个旋转运动将

clip_image081_0002.gif转到了

clip_image086_0000.gif,为使得

clip_image081_0003.gif

clip_image086_0001.gif轴重合,需要沿

clip_image084_0003.gif和沿

clip_image086_0002.gif的平移均为零,还需要一个旋转将

clip_image079_0003.gif转到

clip_image084_0004.gif,注意旋转是根据右手规则进行的,即将右手手指按旋转的方向弯曲,大拇指的方向则为旋转坐标轴的方向。到了这时,

clip_image106_0000.gif就变换到了

clip_image114.gif

接下来,绕

clip_image084_0005.gif旋转

clip_image116.gif,将

clip_image086_0003.gif转到了

clip_image088_0000.gif,然后沿

clip_image088_0001.gif轴移动距离

clip_image120.gif,使坐标系原点重合。由于前后两个z轴是平行的,所以没有必要绕x轴旋转。按照这样的步骤继续做下去,就能得到所需要的结果。

必须要认识到,与其他机械类似,机器人也不会保持原理图中所示的一种构型不变。尽管机器人的原理图是二维的,但必须要想象出机器人的运动,也就是说,机器人的不同连杆和关节在运动时,与之相连的坐标系也随之运动。如果这时原理图所示机器人构型的坐标轴处于特殊的位姿状态,当机器人移动时它们又会处于其他的点和姿态上。比如,

clip_image092_0000.gif总是沿着关节3与关节4之间连线

clip_image123.gif的方向。当机器人的下臂绕关节2旋转而运动。在确定参数时,必须记住这一点。

表2.2     例2.19机器人的参数

#

clip_image006_0003.gif

d

a

clip_image020_0001.gif

1

clip_image125.gif

0

0

90

2

clip_image116_0000.gif

0

clip_image120_0000.gif

0

3

clip_image129.gif

0

clip_image123_0000.gif

0

4

clip_image132.gif

0

clip_image134.gif

-90

5

clip_image136.gif

0

0

90

6

clip_image138.gif

0

0

0

clip_image006_0004.gif表示旋转关节的关节变量,d表示滑动关节的关节变量。因为这个机器人的关节全是旋转的,因此所有关节变量都是角度。

通过简单地从参数表中选取参数代入A矩阵,便可写出每两个相邻关节之间的变换。例如,在坐标系0和1之间的变换矩阵

clip_image140.gif可通过将

clip_image020_0002.gif(sin

clip_image142.gif=1,cos

clip_image142_0000.gif=0,

clip_image020_0003.gif=

clip_image142_0001.gif)以及指定

clip_image145.gif

clip_image125_0000.gif等代入A矩阵得到,对其他关节的

clip_image147.gif~

clip_image149.gif矩阵也是这样,最后得:

clip_image151.gif       

clip_image153.gif

clip_image155.gif   

clip_image157.gif        (2.55)

clip_image159.gif        

clip_image161.gif

特别注意:为简化最后的解,将用到下列三角函数关系式:

clip_image163.gif                (2.56)

在机器人的基座和手之间的总变换为:

clip_image165.gif                                                   (2.57)

clip_image167.gif

斯坦福机械手臂。在斯坦福机械手臂上指定坐标系(如图2.29所示),并填写参数表。斯坦福机械手臂是一个球坐标手臂,即开始的两个关节是旋转的,第三个关节是滑动的,最后三个腕关节全是旋转关节。

clip_image169.jpg

图2.29    斯坦福机械手臂示意图

解:

在看本题解答之前,现根据自己的理解来做,问题的答案在本章的最后。建议在看解答中建立的坐标系和机械手臂的解之前,先试着自己做。

机器手臂最后的正运动学解是相邻关节之间的6个变换矩阵的乘积:

clip_image171.gif

其中

clip_image173.gif

clip_image175.gif

clip_image177.gif                             (2.58)

clip_image179.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值