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

    文章

    314

    浏览量

    23575

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

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

收藏 人收藏

    评论

    相关推荐

    机械手 OEM 的应用

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

    abb机器人工具坐标系问题

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

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

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

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

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

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

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

    arcmap如何设置地理坐标系

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

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

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

    机器视觉之Halcon入门学习

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

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

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

    相机标定中的坐标变换原理难点分析

    相机标定中的基本坐标系有:像素坐标系、图像坐标系相机坐标系
    发表于 12-19 10:42 1195次阅读
    <b class='flag-5'>相机</b><b class='flag-5'>标定</b>中的<b class='flag-5'>坐标</b>变换原理难点分析

    三维空间直角坐标系的平移和旋转变换

    这次的文章,我们来看看三维空间直角坐标系的平移和旋转变换,尽管这个内容早已见诸文献资料,但自己在看书籍以及期刊论文时,总是遇到让人百思不得其解的事情,就是不同的文献给出的同类型的旋转矩阵居然有不样的,这让小D对文献中的公式产
    的头像 发表于 12-18 09:48 7150次阅读
    三维空间直角<b class='flag-5'>坐标系</b>的平移和旋转变换

    坐标机械手配件有哪些?

    直线模组是一种常见的机械传动装置,广泛应用于机械手等自动化设备中,在机械手中的主要作用是实现机械手的运动控制和定位。
    的头像 发表于 12-07 17:38 853次阅读
    <b class='flag-5'>坐标</b><b class='flag-5'>机械手</b>配件有哪些?

    机器人坐标系Launch文件解析

    Launch文件解析 先来看下刚才运行的launch文件,里边启动了四个节点,分别是: 小海龟仿真器 海龟1的坐标系广播 海龟2的坐标系广播 海龟跟随控制 其中,两个坐标系的广播复用
    的头像 发表于 11-22 17:44 568次阅读

    机器人坐标系管理TF跟随功能解析

    ** ros2 run turtlesim turtle_teleop_key 看到的效果和ROS自带的例程相同。 原理解析 在两只海龟的仿真器中,我们可以定义三个坐标系,比如仿真器的全局参考叫做
    的头像 发表于 11-22 17:35 569次阅读
    机器人<b class='flag-5'>坐标系</b>管理TF跟随功能解析

    机器人中都有哪些坐标系

    坐标系是我们非常熟悉的个概念,也是机器人学中的重要基础,在个完整的机器人系统中,会存在很多坐标系,这些坐标系之间的位置关系该如何管理?
    的头像 发表于 11-22 17:20 1410次阅读
    机器人中都有哪些<b class='flag-5'>坐标系</b>