![ABB工业机器人进阶编程与应用](https://wfqqreader-1252317822.image.myqcloud.com/cover/794/44819794/b_44819794.jpg)
1.3.4 工件坐标系计算原理及实现
1.3.3节介绍了如何使用DefFrame函数计算获得坐标系。在ABB工业机器人的示教器中定义坐标系时,默认使用的是“DefFrame(p1,p2,p3\Origin:=3)”的函数,即坐标系原点在点p3到p1p2连线的垂足处。
DefFrame函数返回的是pose类型的数据(位姿数据),即在计算时,要计算坐标系的原点位置(x、y、z)和坐标系姿态。
假设空间3点为p1(x1,y1,z1)、p2(x2,y2,z2)和p3(x3,y3,z3)。由点p3向p1p2连线做垂线,垂足为点p4(x,y,z),p4即为需要求解的坐标系原点(见图1-45)。
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_48_3.jpg?sign=1738862751-JdGvI6ORkcJE4uCHclYFPGSNp1RhUuLt-0-3fdeacd19934d9a986075b5f6521c1b2)
图1-45 三点计算坐标系
把经过点p1和点p2的空间直线称为L1,可以用式(1-31)表示:
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_48_4.jpg?sign=1738862751-QLpBP7GBewl2jgyEYWTeURGHtebhuewT-0-add6a3f52d082fe89912f4a7c3717758)
由于向量垂直于
,根据向量点积规则,
。
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_48_8.jpg?sign=1738862751-rbo9j659t1AskKaCTbajgV2zE3HcAq2Y-0-82426d284446454200acb879b5274926)
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_48_9.jpg?sign=1738862751-TFSbLSvdrT8lngMFuL8KktQ9daaVlB0u-0-b2978ee687863e4a5aef531f5d431749)
为方便书写,记:
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_49_1.jpg?sign=1738862751-E1mLdpE7qvURQ8IEJqAUJm7B7q9BjSqI-0-059074fa1d3da5f867014ce7647b32df)
将式(1-31)和式(1-32)整理为式(1-33):
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_49_2.jpg?sign=1738862751-MEvz7fAlBVmkfa1pvu5uhYaSW2XbolOD-0-c5babd3ee636471cde692c99310a06ef)
计算式(1-33)即可得到由点p1、p2和p3构成的坐标系原点。RAPID提供求解AX=B的指令“MatrixSolve A,B,X”,计算结果存储于X数组中。MatrixSolve中使用的数据类型为dnum,在调用时可以使用NumToDnum和DnumToNum函数进行转化。
对于坐标系原点姿态,则可以通过向量的叉乘得到,如图1-46及图1-47所示。
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_49_3.jpg?sign=1738862751-Vj3y8LYFp8Smz5Anj5VudiAYsnOXcSU9-0-5574ce77d8e06eb910d2a638dfc810cf)
图1-46 三点计算坐标系姿态
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_49_4.jpg?sign=1738862751-cerCaDpzDGg7QaTpkIWKTXqjc1xTn1Xi-0-f3ffc7959d1fbc330af2ac9a080b847f)
图1-47 叉乘运算表示
计算过程如下:
(1)向量单位化,得到单位向量
;
(2)向量单位化,得到单位向量
;
(3)向量叉乘向量
,得到单位向量
;
(4)单位向量等于单位向量
叉乘单位向量
;
(5)得到单位向量、单位向量
、单位向量
;
(6)将旋转矩阵转化为欧拉角;
(7)利用OrientZYX函数将欧拉角转化为四元数。
综合以上计算坐标系原点与姿态的介绍,可以编写RAPID代码如下,运算结果与DefFrame(p1,p2,p3\Origin:=3)相同:
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_49_19.jpg?sign=1738862751-Yd1Xvqs3193LQ8CFouZeFA0L9j1BSkG4-0-4b5b2aeb810056781501bc5161d557cc)
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_50_1.jpg?sign=1738862751-4VOLyEhWMq20eMzi31wxP9QLaXHV3Hac-0-91dc57a0643e85d86aed59cec698e8f1)
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_51_1.jpg?sign=1738862751-bgSswapVcE7vAsWOncSXzXl8Kio4AQDd-0-c16cc8d88b1f497073d5eedcad3ab601)
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_52_1.jpg?sign=1738862751-pKY3pcDUNsRO7xHarkZEsj4UJEonwZp7-0-7e9522c67db6d3a153482e0dc6346acf)