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

    文章

    412

    浏览量

    25509

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

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

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    什邡离线扫描设备如何测量长材直线度

    、每米等多种直线度误差和外径。 1、基本原理 两组测头可组成坐标系,通过每个测头测量的被测物中心位置可计算出被测物中心在坐标系中的坐标位置 离线扫描式直线度测量仪是
    发表于 09-05 14:05

    亳州ZG02-D/SY系列 离线扫描直线度测量仪

    、每米等多种直线度误差和外径。 1、基本原理 两组测头可组成坐标系,通过每个测头测量的被测物中心位置可计算出被测物中心在坐标系中的坐标位置 2、数据计算方法 测量仪通过
    发表于 07-31 15:33

    坐标和激光跟踪仪的不同之处

    激光跟踪仪和三坐标测量机(CMM)是工业领域两大高精度测量设备,但它们在原理、适用范围和典型场景上存在显著差异。下面从核心区别与应用领域两方面进行系统分析:、核心区别对比1.测量原理与工作方式激光
    的头像 发表于 07-21 15:07 1129次阅读
    三<b class='flag-5'>坐标</b>和激光跟踪仪的不同之处

    鸿蒙地图功能开发【3. 代码开发】##地图开发##

    以后再去更新这个配置参数。 第二,定要注意经纬度坐标坐标系。从大家的惯性认知中,既然我是通过原生鸿蒙的Location Kit获取的经纬度坐标,那么当然适用于原生鸿蒙的Map Ki
    发表于 06-29 22:59

    电机矢量控制中坐标变换的详细推导(可下载)

    、Clarke 变换推导(三相静止坐标与两相静止坐标换算)通过三相静止坐标系(ABC)和两相静止坐标系(αβ)的换算,可以实现电机三相电源
    发表于 04-03 11:35 5次下载

    克拉克变换&amp;帕克变换:电机界的“变形金刚”双人组

    ”综合征。它们能让复杂的旋转电流瞬间变老实,就像把孙悟空绑在五指山下,任你施法! 二、克拉克变换:三相变两相的“空间折叠术” 1. 核心功能:把三相静止坐标系“拍扁” 操作方式:用个2/3的“魔法系数”把
    发表于 03-22 17:48

    LSM6DSV16X内置的传感器融合算法SFLP,输出的四元数是自身坐标系下的还是全局坐标系下的?

    请问各位大佬,LSM6DSV16X内置的传感器融合算法SFLP,输出的四元数是自身坐标系下的还是全局坐标系下的?以及输出的陀螺仪偏置是实时更新的吗?谢谢!
    发表于 03-14 07:22

    坐标测量机的机器坐标系和原点介绍

    坐标测量机的机器坐标系和原点是其测量系统中的重要概念,以下是详细介绍、机器坐标系(1)定义:机器
    的头像 发表于 03-10 10:34 1093次阅读
    三<b class='flag-5'>坐标</b>测量机的机器<b class='flag-5'>坐标系</b>和原点<b class='flag-5'>介绍</b>

    电机矢量控制分析方法介绍

    控制问题的研究,能否由仪器直接得到D-Q变换的结果呢? D-Q变换是一种解耦控制方法,它将异步电动机的三相绕组变换为等价的二相绕组,并且把旋转坐标系变换成正交的静止坐标,即可得到用直流量表示电压及电流的关系式。D-Q变换使得各个
    的头像 发表于 01-15 17:23 1332次阅读
    电机矢量控制分析方法<b class='flag-5'>介绍</b>

    FRED应用:偏振分色显示空间光谱分布

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

    偏振分析器

    摘要 线栅偏振器,可以使透射光产生线性偏振状态,是众多应用中常见的一种光学元件。由于它们的结构在亚波长范围内,因此必须对光的传播进行严格的处理。VirtualLab的偏振分析器及其内置的RCWA
    发表于 01-13 08:59

    Chart FX——坐标轴简介

    坐标轴是最重要的元素之,因为读者需要借由其所包含的信息来理解图表。在大多数情况下,图表是以 XY 坐标系绘制的。数值或 Y 轴显示数值数据所代表的数值范围,而类别轴或 X 轴则显示图表中数据的细分
    的头像 发表于 01-07 11:05 1190次阅读
    Chart FX——<b class='flag-5'>坐标</b>轴简介

    关于三坐标测量机的常见问题及回答

    、三坐标测量机的基本原理相关问题1.三坐标测量机是如何进行测量的?-三坐标测量机通过探测系统(如接触式测头或非接触式测头)获取工件表面上点的坐标
    的头像 发表于 01-02 13:41 1421次阅读
    关于三<b class='flag-5'>坐标</b>测量机的常见问题及回答

    坐标测量机的工作原理 三坐标测量机在质量控制中的应用

    在现代工业生产中,产品质量的控制至关重要。三坐标测量机作为一种精密测量工具,能够提供精确的几何尺寸数据,对于确保产品质量和提高生产效率起着关键作用。 、三
    的头像 发表于 12-19 10:08 1863次阅读

    偏振分色

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