![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=1738837707-kEWq19fIZUs4G71xH1I37KJWXpJAV5wF-0-1aff559a7371edfd8cb653429c213603)
图1-45 三点计算坐标系
把经过点p1和点p2的空间直线称为L1,可以用式(1-31)表示:
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_48_4.jpg?sign=1738837707-JryVAJBoOuN64BwAaWnmrhNFA9oUBhS8-0-b9d612b0fe6c72c6542a09fc59d262c4)
由于向量垂直于
,根据向量点积规则,
。
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_48_8.jpg?sign=1738837707-oyLGGPI6D7lcFbHbMguTi64rD4IBlYzw-0-3aecc97f1db20c8a4213d2f6dc483e5c)
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_48_9.jpg?sign=1738837707-Km0SZPbrqfY6KbdwLkhfRrxHdEKmIryD-0-6b0d167884b1a19146025fc092a6f420)
为方便书写,记:
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_49_1.jpg?sign=1738837707-yvr2csvzmAr2jgYkM8IVp9FvIBlahbhk-0-3a80fe0458bdc107018ea9dec655ae79)
将式(1-31)和式(1-32)整理为式(1-33):
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_49_2.jpg?sign=1738837707-dQpyQcVHGnjxzVWOcfoUsHNfUMIaMCtg-0-22243350f570e011531967273b1eca8d)
计算式(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=1738837707-HsQGbPocHvmjBYirR24Kn4Rhv5BZheQ1-0-4d82917c7fc945f19833fc1cead187b5)
图1-46 三点计算坐标系姿态
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_49_4.jpg?sign=1738837707-sHqiHiPiByQhbAy6zb7V08QeDApkChfb-0-fea439f745697be6b94a1e694b6f06f5)
图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=1738837707-cCC6NXbpqImArOLsLzHY34x2fGOYfB4f-0-4709755fabbf1bd1c0963ff5711177cb)
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_50_1.jpg?sign=1738837707-ID7CEfp49GA3SpHbEJwcJQL82KKUwUXy-0-80898eb795a332288b27163a7dda5452)
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_51_1.jpg?sign=1738837707-sExxieXNVBmQrAik79i8qaVRLFf6xqEL-0-b28c76d5bc5bc3bfb221e78962dcb6b3)
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_52_1.jpg?sign=1738837707-1kyZDWgPnNLC8uZXLVrgO3uGauXU45Ug-0-3c671775e32bdf05ad57e58ea953e690)