机器人标定:相机9点标定的补充-12点计算旋转中心
zhezhongyun 2025-07-24 23:18 7 浏览
1. 机器人在使用相机时,不论相机固定安装或者相机安装在机械臂末端,都需要先执行手眼标定。
2. 最常见的标定为9点标定,例如相机装在机械臂末端,机器人将法兰盘处于标准位置5处的x,y坐标及后续运动的x,y方向的间距发给相机,机械臂按照规则沿着机械臂base的x和y方向走如下轨迹,完成标定。此时机械臂走回标准拍照位置5,拍照得到的相机返回产品坐标所在的坐标系与机器人base坐标系平行。
3. 虽然机械臂在位置5处,将法兰盘的位置发给相机,但相机实际安装如下图(即相机安装不会在法兰盘位置5,相机与机械臂法兰盘有偏置)。所以需要计算得到相机和法兰盘的关系,这样相机返回的产品坐标可以直接是机器人base坐标下的值。
4. 海康相机直接提供了12点标定,其中最后3点为机器人以法兰盘为中心绕着大地的z旋转(若法兰盘平行base,直接旋转6轴),如下图。通过在相机中同一个mark点的不同位置,计算出3个mark位置对应的圆心(即法兰盘)。后续输出结果只需加上该偏差即可。
5. 若相机标定功能不具备自动计算旋转中心功能,则在完成9点标定后,旋转中心的计算和偏差计算可以放在机器人侧完成。具体代码如下:
PERS robtarget pNewActual:=[[0,0,0],[1,0,0,0],[0,0,0,0],[9E9,9E9,9E9,9E9,9E9,9E9]];
PERS robtarget pStdActual:=[[0,0,0],[1,0,0,0],[0,0,0,0],[9E9,9E9,9E9,9E9,9E9,9E9]];
! pStdActual是产品在标准位置时,计算得到的在机器人base下的实际位姿(包含了旋转中心偏差的补偿)
PERS robtarget pStdFromCam:=[[0,0,0],[1,0,0,0],[0,0,0,0],[9E9,9E9,9E9,9E9,9E9,9E9]];
! pStdFromCam是产品在标准位置时,相机返回的坐标值。相机仅和机器人做了9点标定,没有做旋转中心处理
PERS robtarget ptmp:=[[326.174,111.364,558],[5.75447E-8,-0.707136,-0.707078,-7.91093E-9],[0,0,0,0],[9E+9,9E+9,9E+9,9E+9,9E+9,9E+9]];
CONST robtarget pcam:=[[302,0,558],[5.505613E-08,-0.3187502,-0.9478387,1.851492E-08],[0,0,0,0],[9E+09,9E+09,9E+09,9E+09,9E+09,9E+09]];
CONST robtarget pPickStd:=[[302,0,558],[5.505613E-08,-0.3187502,-0.9478387,1.851492E-08],[0,0,0,0],[9E+09,9E+09,9E+09,9E+09,9E+09,9E+09]];
PERS pos pos10{3}:=[[248.922,75.1801,0],
[302,0,0],
[299.772,-70.4799,0]];
PERS pos camdata:=[0,0,-52.83];
PERS pos camdata_ini:=[0,0,-52.83];
PERS pos offset1:=[124.184,31.3486,0]; !计算出来的旋转中心偏移
PROC rInit()
rRotCenterCalib pcam,10;
! 执行该程序前,已经完成相机9点标定,但未做相机到法兰盘的旋转中心补偿
ENDPROC
PROC rRotCenterCalib(robtarget pCam0,num angle)
! pCam0 is robot take photo position with tool0
! angle will let robot rotate Rz, unit:deg
VAR robtarget pCamCalib{3};
pCamCalib{1}:=pCam0;
pCamCalib{2}:=pCam0;
pCamCalib{3}:=pCam0;
pCamCalib{1}.rot:=OrientZYX(-angle,0,0)*pcamcalib{1}.rot;
pCamCalib{3}.rot:=OrientZYX(angle,0,0)*pcamcalib{3}.rot;
MoveL pCamCalib{1},v1000,fine,tool0;
!pos10{1}:=机器人法兰盘旋转-AAA°,相机返回值
MoveL pCamCalib{2},v1000,fine,tool0;
!pos10{2}:=机器人法兰盘在标准位置,相机返回值
MoveL pCamCalib{3},v1000,fine,tool0;
!pos10{3}:= 机器人法兰盘旋转AAA°,相机返回值
offset1:=calCamRotOffs(pos10);
! 计算得到相机与法兰盘在机器人base方向上的偏差
stop;
ENDPROC
FUNC pos calCamRotOffs(pos posC{*})
!posC array are robot rotate Rz with flange(tool0)
!posC{1} : robot rotate Rz -AAA degree, camera result
!posC{2} : robot move to pCam0, camera result
!posC{3} : robot rotate Rz BBB degree, camera result
VAR pos pcenter;
VAR num r;
VAR pos n;
VAR pos normal;
fitcircle posC,pcenter,r,normal;
! fitcircle1 pos10{1},pos10{2},pos10{3},pcenter,r;
! 若现场机器人没有fitcircle内置函数,可以使用后续内容的fitcircle1函数计算圆心
RETURN [posC{2}.x-pcenter.x,posC{2}.y-pcenter.y,0];
ENDFUNC
!!!!! ! 以下为仿真测试
PROC testProcess()
MoveJ pcam,v1000,fine,tool0;
! take photo for new product ,移动到拍照位置
pStdActual:=pStdFromCam;
pStdActual.trans.x:=camdata_ini.x;
pStdActual.trans.y:=camdata_ini.y;
pStdActual.trans:=pStdActual.trans+offset1;
pNewActual:=pStdFromCam;
pNewActual.trans.x:=camdata.x;
pNewActual.trans.y:=camdata.y;
pNewActual.trans:=pNewActual.trans+offset1;
pNewActual.rot:=OrientZYX(camdata_ini.z-camdata.z,0,0)*pNewActual.rot;
ptmp:=calTarget(pStdActual,pNewActual,pPickStd);
! 通过标准产品位置,新产品位置和基于tool0的标准抓取位置,得到新的基于tool0抓取位置
MoveL ptmp,v1000,fine,tool0;
Stop;
ENDPROC
FUNC robtarget calTarget(robtarget pold,robtarget pnew,robtarget pStdPick)
VAR pose p1;
VAR pose p2;
VAR pose p3;
VAR pose ppick;
VAR pose ppicknew;
VAR robtarget pout:=[[0,0,0],[1,0,0,0],[0,0,0,0],[9E9,9E9,9E9,9E9,9E9,9E9]];
pout:=pStdPick;
p1:=[pold.trans,pold.rot];
p2:=[pnew.trans,pnew.rot];
p3:=PoseMult(p2,PoseInv(p1));
ppick:=[pStdPick.trans,pStdPick.rot];
ppicknew:=PoseMult(p3,ppick);
pout.trans:=ppicknew.trans;
pout.rot:=ppicknew.rot;
RETURN pout;
ENDFUNC
PROC fitCircle1(pos p1,pos p2,pos p3,inout pos pcenter,inout num radius)
! 三点计算圆心
VAR num x1;
VAR num y1;
VAR num z1;
VAR num x2;
VAR num y2;
VAR num z2;
VAR num x3;
VAR num y3;
VAR num z3;
VAR num a1;
VAR num b1;
VAR num c1;
VAR num d1;
VAR num a2;
VAR num b2;
VAR num c2;
VAR num d2;
VAR num a3;
VAR num b3;
VAR num c3;
VAR num d3;
VAR num x;
VAR num y;
VAR num z;
x1:=p1.x;
y1:=p1.y;
z1:=p1.z;
x2:=p2.x;
y2:=p2.y;
z2:=p2.z;
x3:=p3.x;
y3:=p3.y;
z3:=p3.z;
a1:=(y1*z2-y2*z1-y1*z3+y3*z1+y2*z3-y3*z2);
b1:=-(x1*z2-x2*z1-x1*z3+x3*z1+x2*z3-x3*z2);
c1:=(x1*y2-x2*y1-x1*y3+x3*y1+x2*y3-x3*y2);
d1:=-(x1*y2*z3-x1*y3*z2-x2*y1*z3+x2*y3*z1+x3*y1*z2-x3*y2*z1);
a2:=2*(x2-x1);
b2:=2*(y2-y1);
c2:=2*(z2-z1);
d2:=x1*x1+y1*y1+z1*z1-x2*x2-y2*y2-z2*z2;
a3:=2*(x3-x1);
b3:=2*(y3-y1);
c3:=2*(z3-z1);
d3:=x1*x1+y1*y1+z1*z1-x3*x3-y3*y3-z3*z3;
x:=-(b1*c2*d3-b1*c3*d2-b2*c1*d3+b2*c3*d1+b3*c1*d2-b3*c2*d1)/
(a1*b2*c3-a1*b3*c2-a2*b1*c3+a2*b3*c1+a3*b1*c2-a3*b2*c1);
y:=(a1*c2*d3-a1*c3*d2-a2*c1*d3+a2*c3*d1+a3*c1*d2-a3*c2*d1)/
(a1*b2*c3-a1*b3*c2-a2*b1*c3+a2*b3*c1+a3*b1*c2-a3*b2*c1);
z:=-(a1*b2*d3-a1*b3*d2-a2*b1*d3+a2*b3*d1+a3*b1*d2-a3*b2*d1)/
(a1*b2*c3-a1*b3*c2-a2*b1*c3+a2*b3*c1+a3*b1*c2-a3*b2*c1);
pcenter:=[x,y,z];
radius:=sqrt((x1-x)*(x1-x)+(y1-y)*(y1-y)+(z1-z)*(z1-z));
ENDPROC
********************************
相机9点标定的补充--12点计算旋转中心
http://bbs.plcjs.com/forum.php?mod=viewthread&tid=500885&fromuid=1
(出处: PLC论坛-全力打造可编程控制器专业技术论坛)
相关推荐
- Trump Pushes for 15%-20% Minimum Tariffs on EU, Sticks to Auto Duties: Report
-
TMTPOST--U.S.PresidentDonaldTrumpistakingatougherstanceduringtradenegotiationswiththe...
- Note-15.使用A4988控制步进电机(dvp15mc11t控制步进电机)
-
如果需要控制一堆步进电机,那么只使用一个Arduino来控制,就会占用大量的处理时间,而无法处理其他事情,除非使用一个独立的专用步进电机驱动器:A4988。A4988只需两个引脚就可以控制双极步进电机...
- Negotiated settlement, not sanctions, the right way to end the Ukraine crisis
-
Negotiatedsettlement,notsanctions,therightwaytoendtheUkrainecrisis:ChinaDailyeditorial...
- U.S. Services May be Added to EU's Retaliatory Target List as More Members Seek Powerful Trade Tool If Talks Fail
-
TMTPOST--AmericanservicescouldbeaddedtotheEuropeanUnion’sretaliatorytargetlist,highlig...
- S7-1200伺服指令运动指令(s71200伺服位置控制实例)
-
1.MC_Halt指令名称:停止轴运行指令功能:停止所有运动并以组态的减速度停止轴。使用技巧:常用MC_Halt指令来停止通过MC_MoveVelocity指令触发的轴的运行。『注意』部分输入/输出管...
- Deepseek太强了!等了10年的Excel模糊下拉,竟然5分钟就搞定了
-
今天跟大家分享下我们如何通过Deepseek来编写VBA代码,制作模糊搜索的下拉菜单,这个等来十来年的功能,用Deepseek竟然几分钟就搞定了,不得不感叹AI工具的强大,我们以后能干的过AI吗,这真...
- 7.Unity物理关节(unity物理骨骼)
-
7.物理关节Unity的物理关节组件将刚体连接到另一个刚体或空间中的固定点。施加使刚体移动的力,关节限制可以限制移动。关节赋予刚体一定的自由度,从而使这些刚体具有不同的运动。Unity提供的物理关...
- 西门子111报文对应FB284引脚(西门子111报文详解)
-
西门子FB284是基于111报文的功能块,使用FB284比较方便,直接调用就可以控制V90伺服的定位控制。下面是整理的FB284对应的111报文。便于理解FB284功能块,更方面应用在实际项目中。11...
- 数据质量动态探查及相关前端实现(数据质量改进实践指南)
-
需求背景数据探查上线之前,数据验证都是通过写SQL方式进行查询的,从编写SQL,到解析运行出结果,不仅时间长,还会反复消耗计算资源,探查上线后,只需要一次探查,就可以得到整张表的探查报告,但后续...
- 阿里面试官:你连个排序算法都讲不明白?出门右拐吧
-
排序算法一表总览其他注意事项:计数排序中,kkk是整数的范围稳定性是指,序列中相同的数是否有可能交换顺序,例如序列中有两个8,顺序为888和8′8^{'}8′,如果在排序完之后,顺序有...
- 直流电机速度、位置双环控制简明教程
-
速度、位置的双环控制是我们在电机的控制系统中常用的方法,很实用。下面让我们来看一下内部实现的原理。1.速度闭环控制我们一般在速度闭环控制系统里面,使用增量式PI控制。而在我们的微处理器里面,因为控制器...
- 纳米机器人的精准定位与导航(纳米机器人怎么控制位置)
-
纳米机器人的精准定位与导航涉及多学科交叉技术,其“源码”(控制逻辑与算法)需结合硬件特性、环境感知和执行器设计。以下从控制原理、算法逻辑、关键技术实现等方面提供概念性思路(非实际可运行代码),供技术探...
- C语言进阶教程:多级指针的应用(c语言一级指针和二级指针)
-
在C语言中,指针可以指向变量的地址。多级指针(PointerstoPointers或MultilevelPointers)则是指向另一个指针地址的指针。这种概念可以扩展到任意级别(二级指针、...
- 被 Trac 的文件整理能力圈粉了!这 “香” 气挡不住
-
前阵子整理电脑文件夹时,我遇到了个麻烦:上千个文档和照片,要是手动一个个重命名、分类,不仅手得点到发麻,估计还得耗上一上午。于是我就琢磨着,能不能找个办法实现一键批量重命名。我先在网上搜了些批量改名软...
- Enhancer-轻量化的字节码增强组件包
-
一、问题描述当我们的业务发展到一定阶段的时候,系统的复杂度往往会非常高,不再是一个简单的单体应用所能够承载的,随之而来的是系统架构的不断升级与演变。一般对于大型的ToC的互联网企业来说,整个系统都是...
- 一周热门
- 最近发表
-
- Trump Pushes for 15%-20% Minimum Tariffs on EU, Sticks to Auto Duties: Report
- Note-15.使用A4988控制步进电机(dvp15mc11t控制步进电机)
- Negotiated settlement, not sanctions, the right way to end the Ukraine crisis
- U.S. Services May be Added to EU's Retaliatory Target List as More Members Seek Powerful Trade Tool If Talks Fail
- S7-1200伺服指令运动指令(s71200伺服位置控制实例)
- Deepseek太强了!等了10年的Excel模糊下拉,竟然5分钟就搞定了
- 7.Unity物理关节(unity物理骨骼)
- 西门子111报文对应FB284引脚(西门子111报文详解)
- 数据质量动态探查及相关前端实现(数据质量改进实践指南)
- 阿里面试官:你连个排序算法都讲不明白?出门右拐吧
- 标签列表
-
- HTML 教程 (33)
- HTML 简介 (35)
- HTML 实例/测验 (32)
- HTML 测验 (32)
- JavaScript 和 HTML DOM 参考手册 (32)
- HTML 拓展阅读 (30)
- HTML文本框样式 (31)
- HTML滚动条样式 (34)
- HTML5 浏览器支持 (33)
- HTML5 新元素 (33)
- HTML5 WebSocket (30)
- HTML5 代码规范 (32)
- HTML5 标签 (717)
- HTML5 标签 (已废弃) (75)
- HTML5电子书 (32)
- HTML5开发工具 (34)
- HTML5小游戏源码 (34)
- HTML5模板下载 (30)
- HTTP 状态消息 (33)
- HTTP 方法:GET 对比 POST (33)
- 键盘快捷键 (35)
- 标签 (226)
- HTML button formtarget 属性 (30)
- CSS 水平对齐 (Horizontal Align) (30)
- opacity 属性 (32)