0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

介绍一种比较简单的工业现场相机坐标系和机械手坐标系的标定方案

新机器视觉 来源:CSDN 作者:KayChanGeek 2022-09-05 11:09 次阅读

工业现场使用视觉时一般需要相机坐标系和机械手臂坐标系的转化,这里介绍一种比较简单的标定方案。没有使用到标定板。经过几个项目的测试,精度还算可以,如果要求高精度的场合,就用标定板标定吧!

037c648a-2c53-11ed-ba43-dac502259ad0.png

如上图所示:OXY为机械手坐标系,O'X'Y'为相机坐标系。theta为两个坐标系之间的夹角。假设P点在图像上的位置如图,则P在机械手坐标系有一个坐标,在图像坐标系也有一个坐标。我们要做的工作就是图像上的任意一点都可以转化为机械手坐标系上的坐标点:P(Machine) = f(P(Image))。接下来介绍如何找到这个关系。

OXY为机械手坐标系 O'X'Y'为相机坐标系从上图可以看出坐标转化关系:

x= x' * r * cos(theta) - y' * r * sin(theta) + x0;

y = x' * r * sin(theta) + y' * r * cos(theta) + y0;

其中r是毫米像素比、(mm/pixel)就是一个毫米有几个像素,theta为两个坐标系之间的夹角,(x0,y0)为图像坐标原点到机械坐标原点的距离。

简化抽象公式,假设:

a = r * cos(theta);

b = r * sin(theta);

c = x0;

d = y0;

得到:

x= x' * a - y' * b + c;

y = x' * b + y' * a + d;

很显然,要解出这个方程,需要两组对应关系,就是两组对应的坐标点。设两组坐标点,如下:

第一组:图像坐标点:(xImage1,yImage1) 对应的机械坐标点:(xMachine1,yMachine1)

第二组:图像坐标点:(xImage2,yImage2) 对应的机械坐标点:(xMachine2,yMachine2)

则可以解出a ,b, c, d。如下:

038f3254-2c53-11ed-ba43-dac502259ad0.jpg

所以,就得出了图像上任意一点的像素坐标转成机械手坐标的关系。

以下是我写的一个求解a ,b, c, d软件:

03acdc82-2c53-11ed-ba43-dac502259ad0.png

下面举个栗子说明一下操作吧!这是我实际项目中的机械手和相机布局情况,画图真T``M`累!,如下图:

03c0c008-2c53-11ed-ba43-dac502259ad0.png

首先将产品上的目标点搞到机械手的Z轴的中心,然后移动到相机视野范围内,让识别产品上的目标点,这时,你会读到一组机械手坐标(也就是上面所说的(xMachine1,yMachine1)),和一组相机坐标(也就是上面所说的(xImage1,yImage1)),再在相机视野范围内移动机械手,就可以得到第二组数据(xMachine2,yMachine2)和(xImage2,yImage2),写入标定软件就可以求出a, b, c, d。就求出了图像上任意一点对应的机械坐标,然后你下次移动第二个产品到相机视野时,首先识别目标点的像素坐标,经过对应的转换就可以得出机械坐标,然后进行相应的偏移即可实现你想要的操作!

当然,有些时候,实际现场并没有如你所愿,现在出现一种情况就是以机械手自带的Z轴无法移动到视野中去,这样就无法进行上面的操作了,系不系!这也是我遇到的情况,SO,我的解决方案如下:先上示意图:

03d7d2f2-2c53-11ed-ba43-dac502259ad0.png

如图,就是在机械手Z轴的横杆上加上一个横条,使得产品可以移动到视野范围内。然后进行上面的操作,虽然现在可以将产品移动到视野范围内了,但是你会发现此时机械手的坐标并不是产品的坐标,因为他们之间隔着一个横条,那我们要怎么换算过来呢!

首先,我们可以这么假定的认为,他们是机械手的坐标就是产品的坐标,然后就可以用上面取两组对应点的方法求出图像上每个点的机械坐标了,但是,此时的机械坐标并不是真正的机械坐标,但是,我们可以利用这些坐标找出机械手U轴的旋转中心就是Z轴(就是实际机械坐标所在的位置)在我们所建立的不是真正的机械坐标系中的坐标。是不是有点不好理解,我也不大清楚怎么描述!求U轴的旋转中心的过程如下:上图:

03f10268-2c53-11ed-ba43-dac502259ad0.png

如图:将产品的目标点绕机械手的U轴的旋转中心旋转得到3的目标点的不是真正的机械坐标系的坐标P1,P2,P3,必须让每次旋转的目标点在视野范围内,然后通过圆弧上的3点就可以求得圆心。此时的圆心坐标为不是真正的机械坐标系的坐标。然后我们就可以求出产品中心和机械手U轴旋转中心的deltaX,deltaY,然后就可以结合真正的机械坐标系建立工件坐标系,要对机械手有些了解才比较好理解这些拗口的话!然后对于每一个新的产品都可以建立合适的工件坐标系,然后进行补正和一些操作!

相机跟随着机械手运动(它们绑定在一起了),如果还将标定靶标也固定在机械手上的话,三个对象都相对运动,就无法标定了!那要怎么利用标定助手完成标定呢?经过思考,我给出了以下标定思路:

整个标定系统的初始状态

相机和机械手绑定在一起并且机械手旋转中心处于机械原点,这时候相机中心和机械手中心有一个相对的偏移并且是固定的(相机中心和机械手旋转中心的相对距离设为(detX,detY)),将标定靶标放置在工作区域(实际机械手的工作区域)中的合适位置。

第一步:求取第一组图像点坐标C1

移动机械手(相机会跟着移动)到相机能够清晰拍摄到标定靶标的位置(设该位置的机械坐标为(x0,y0))。然后调整标定靶标的识别参数,使得能够实时的识别标定靶标的中心位置,手动移动靶标最好让它远离图像中心,越远越好(精度越高)但是不能超出相机的视野范围,我就把靶标放在相机视野的左上角的区域吧,然后我们识别当前靶标的图像位置C1,就是第一组数据的图像点。

第二步:求取第一组机械点坐标M1

进入“标定”选项卡,勾选“显示十字标”,这时候会在实时图像中间显示一个蓝色的十字光标,然后,慢速移动机械手,直到C1点和十字光标的交点重合(也就是说移动机械手让实时识别到的靶标中心坐标处于图像的中心,比如采集的图像为2048*1536大小的,你需要缓慢移动机械手(靶标保持不动)直到靶标的中心处于(1024,768)的这个位置),然后记下当前的机械手坐标也就是第一组数据的机械点M1(注意:此时实际是让相机中心和靶标中心重合,并非机械手旋转中心和靶标中心重合,它们之间差了一个detX,detY的距离,具体怎么换算,等下再说)。

第三步:求取第二组图像点坐标C2

将机械手移动回到初始的工作坐标点(x0,y0),将靶标放在相机视野的右下角的区域,识别当前的靶标图像坐标C2,就是第二组数据的图像点。

第四步:求取第二组机械点坐标M2

同理,慢速移动机械手,直到C2点和十字光标的交点重合(就是移动机械手让实时识别到的靶标中心坐标处于图像的中心),然后记下当前的机械手坐标也就是第二组数据的机械点M2。

第五步:求取整个机械手工作区域坐标系和相机坐标系的对应关系

不知道你有没有发现,上面求得工作区域只对工作区域(x0,y0)开始到相机视野结束的位置有效(比如你在机械手移动到工作区域(x0,y0)为起点的位置识别靶标的图像位置坐标为(100,100),但是你将机械手移动到工作区域(x1,y1)为起点的位置识别靶标的图像位置坐标也可能为(100,100))。这样换算过来的机械坐标就是错误的,其实我们上面求得是小区域的转换关系,那我们要怎么扩展到整个机械手的工作区域呢?

我们只需要这样做:在机械手工作的时候是可以知道自己在哪里的,比如:现在机械手移动到工作区域(x1,y1)为起点的位置识别靶标的图像位置坐标为(100,100),我们将(100,100)代入转换关系trans得出来的机械坐标是对应(x0,y0)的,要转换到对应(x1,y1)的只需要将换算处理的坐标加上(x1 - x0,y1 - y0)即可!抽象的公式如下:

0407b490-2c53-11ed-ba43-dac502259ad0.jpg

其中trans函数就是将图像坐标转换为相对于(x0,y0)工作区域的机械坐标,再加上坐标(x1 - x0,y1 - y0)就是当前正确的机械坐标。到此,我们得到了图像坐标和整个机械手工作区域的坐标的关系,但是此时的机械坐标指的是相机的中心,并不是机械手的旋转中心。

第六步:将相机中心转换为机械手的旋转中心

首先,你可以利用目测法,游标卡尺法等等粗略的算出detX,detY的值,然后,进行实时识别和移动测试进行细调,因为粗略的估算有误差,你可以经过多次微调直到精确到机械手的旋转中心移动到产品的上方就成功了。记下此时的detX,detY,代入以下公式就可以算出了最终的机械手应该去的地方了。最终的换算公式如下:

0421837a-2c53-11ed-ba43-dac502259ad0.jpg

整个过程的伪代码运算过程如下:

0437da44-2c53-11ed-ba43-dac502259ad0.jpg

利用标定助手求取[a,b,c,d]外参矩阵的输入参数[C1,M1]和[C2,M2]的操作方法如下图所示:

045571a8-2c53-11ed-ba43-dac502259ad0.jpg




审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 工业相机
    +关注

    关注

    5

    文章

    320

    浏览量

    23621

原文标题:工业现场相机坐标系和机械手坐标系的标定

文章出处:【微信号:vision263com,微信公众号:新机器视觉】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    偏振分色

    坐标系Y轴的方向偏振。\"Synthesize a Color\"(合成一种颜色)的功能是用来创建和权衡模拟“白色”的均匀空间波长范围。 追迹光源 用 Color Image
    发表于 12-12 10:31

    机械手 OEM 的应用

    机械手的结构类似于直角坐标系,由三个相互垂直的直线运动轴组成,可以在三维空间内进行精确的直线运动。它具有结构简单、精度高、运动范围大等优点,适用于些对位置精度要求较高的应用场景,如电
    发表于 09-18 10:31

    【原创】 drawbot 平面机械臂scara写字画画机器人DIY教程贴

    工业scara机械臂副臂控制电机位于主臂和副臂上,电机控制的大臂小臂之间的角度,属于“相对”角度scara。如下图和drawbot样的平行四边形结构,副臂电机控制的副臂相对于世界坐标系
    发表于 08-30 11:54

    abb机器人工具坐标系问题

    各位大佬请教下,abb机器人工具坐标系用四点法,六点法,手动输入等方式标定出的工具坐标系的Z方向与实际工具的长度不符,实际工具长度越长坐标系
    发表于 08-07 11:11

    桥式三坐标测量机和影像测量三坐标介绍

    桥式三坐标测量机和影像测量三坐标在多个方面存在显著的差异。以下是它们之间的主要区别:、测量维度:1.桥式三坐标测量机:主要测量三维坐标系
    的头像 发表于 06-18 11:54 688次阅读
    桥式三<b class='flag-5'>坐标</b>测量机和影像测量三<b class='flag-5'>坐标</b><b class='flag-5'>介绍</b>

    GNSS仿真测试之三常用坐标系与转换

    、可靠地工作的关键步骤。无论是为了确保定位精度、测试信号干扰的影响,还是评估在复杂环境下的导航可靠性,掌握正确的坐标系知识对于进行有效的仿真测试至关重要。 在GNSS仿真测试的领域,三关键的坐标系构成了我们工作的核心:地心地固
    的头像 发表于 05-24 13:17 1129次阅读
    GNSS仿真测试之三<b class='flag-5'>种</b>常用<b class='flag-5'>坐标系</b>与转换

    深入解析坐标转换应用实践

    测量坐标转换般包括两方面的内容:坐标系转换和坐标基准转换。同一坐标基准下,空间点不同表现形式的转换叫做
    的头像 发表于 04-01 14:33 502次阅读
    深入解析<b class='flag-5'>坐标</b>转换应用实践

    机器人手眼标定技术你真的懂吗?

    相机知道的是像素坐标机械手是空间坐标系,所以手眼标定就是得到像素坐标系和空间
    发表于 03-18 09:44 1003次阅读
    机器人手眼<b class='flag-5'>标定</b>技术你真的懂吗?

    OpenCV筑基之图像的透视变换

    透视变换是一种非线性变换,它可以将个二维坐标系中的点映射到三维坐标系中的点,然后再将其投影到另个二维
    的头像 发表于 03-15 09:51 940次阅读
    OpenCV筑基之图像的透视变换

    信号之时域如何转换成频域

    频域也叫Frequency Domain,是描述信号在频率方面特性时用到的一种坐标系。放在直角坐标系中,横轴是频率,纵轴(Y)是信号的幅度,也就是通常说的频谱图。
    发表于 03-05 10:46 6514次阅读
    信号之时域如何转换成频域

    arcmap如何设置地理坐标系

    ArcMap是个功能强大的地图制作和分析软件,可以用来设置地理坐标系。地理坐标系一种将地球表面上的位置表示出来的方法,它使用经度和纬度来确定地点。 要设置地理
    的头像 发表于 02-25 13:41 3870次阅读

    【先楫HPM5361EVK开发板试用体验】06-基于MPU9250的姿态解算

    采用欧拉角、四元数或旋转矩阵等方式来表示物体的姿态,欧拉角会更加直观点。 而欧拉角是一种用于描述物体在三维空间中姿态的表示方法,它通过三个旋转角度来定义物体相对于某个参考坐标系的旋转状态。这三个角度
    发表于 01-17 14:55

    机器视觉之Halcon入门学习

    视觉定位应用主要是找到物体的位置,那么怎么找?在这里个重要的步骤就是标定标定是把相机的像素坐标系转换为
    发表于 01-08 15:43 2283次阅读
    机器视觉之Halcon入门学习

    从KMGTP和mµnpf看技术的发展及局限性

    这篇文章提出了个“技术自由空间”的概念,并应用了一种MmT坐标系
    的头像 发表于 01-05 10:01 1078次阅读
    从KMGTP和mµnpf看技术的发展及局限性

    应用卫星通信领域的坐标转换过程—机体坐标系与ENU坐标系的转换

    今天我们要讲的是应用于卫星通信领域的坐标转换过程——机体坐标系与ENU坐标系的转换。
    的头像 发表于 12-27 09:30 4331次阅读
    应用卫星通信领域的<b class='flag-5'>一</b>个<b class='flag-5'>坐标</b>转换过程—机体<b class='flag-5'>坐标系</b>与ENU<b class='flag-5'>坐标系</b>的转换