![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=1739090728-LlqbOXXXiT8XGl6AiuDoXZhH6Q7EBKay-0-14f6f23d550053b4e17c3954d0fae90e)
图1-45 三点计算坐标系
把经过点p1和点p2的空间直线称为L1,可以用式(1-31)表示:
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_48_4.jpg?sign=1739090728-ZXqazmNZ7aRp2WsK2dXAct7BzVelIQn2-0-691ad28162498df7eb265b1662e072e3)
由于向量垂直于
,根据向量点积规则,
。
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_48_8.jpg?sign=1739090728-PNVyiURqsNR7izFpPBso5BCUWMF1WxE2-0-49e94437970ae32ceccc1f517cae8a49)
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_48_9.jpg?sign=1739090728-q7oidGwHcC1JYO0YWxedbxaBo6otCBzj-0-f011d4b647d17c5afc056df2bd39ccbf)
为方便书写,记:
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_49_1.jpg?sign=1739090728-3s4GhB0aLDgEZ6IL7Yd7KEdxqrIunnah-0-5e786613237ea60e5f5a4a3d16c0067e)
将式(1-31)和式(1-32)整理为式(1-33):
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_49_2.jpg?sign=1739090728-ToS1dl7GOgBFPn94o8ttnpEUeLaDcZHe-0-8e2d833efa36a79fab9c648192bc292e)
计算式(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=1739090728-krNMFgKBlXmFBqn0lvTSo3Gmd5CPklHJ-0-48d5b06b603c9073f420335757993368)
图1-46 三点计算坐标系姿态
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_49_4.jpg?sign=1739090728-qxLkKUvMND7F9TzfHg4Z43UX5KJJhose-0-f837c49bd7dc308359e0cc44b40c36cd)
图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=1739090728-1olbSs1hLwt8QoPslNQsZubf5e16FX6c-0-43ebf218354c2e98c5754a8cbcaa15b1)
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_50_1.jpg?sign=1739090728-BiqvuVEPLrmSaWNEm9zl4o4zIOKw1bGo-0-48a55dd8f459fbba605b83e9a19c852b)
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_51_1.jpg?sign=1739090728-P2bocpJ6P3OSMQwKEaK5mUgt7tqxygdM-0-764912c32d065e5146b02e178bff5178)
![](https://epubservercos.yuewen.com/315336/23950325101463306/epubprivate/OEBPS/Images/43597_52_1.jpg?sign=1739090728-dkwJ8KydeAfjt7rNhNoUmDkp2ovbqITm-0-4bce842182b7d785d268f220ae5474f8)