halcon标定_halcon两个不关联的轴九点标定-程序员宅基地

技术标签: 机器视觉  旋转中心  标定  

基于HALCON的机器人视觉标定
陈阳光 , 王磊     
厦门大学 机电工程系, 福建 厦门 361005
摘要: 基于HALCON平面标定板,充分考虑机器人末端中心和摄像机镜头径向畸变的影响,设计了一种新的Eye-to-Hand机器人视觉标定方法。该方法不仅标定了摄像机的内外参数,同时也建立了摄像机图像坐标系和机器人世界坐标系的关系。实验证明,该方法具有较高的标定精度和实用性,适用于工业机器人的视觉系统标定。
关键词: HALCON     机器视觉     Eye-to-Hand     工业机器人    
Robot visual calibration based on HALCON
CHEN Yangguang, WANG Lei     
Department of Mechanical and Electrical Engineering, Xiamen University, Xiamen 361005, China
Abstract: Based on plate calibration board of HALCON, a new Eye-to-Hand calibration method is schemed out.The method sufficiently involves the influence on robot terminal center and the radial distortion of camera lens.It calibrates the camera parameters and establishes the relationship between image coordinate and robotic coordinate.According to results of experiments, the method has more precision and it is applicable to industrial robot vision calibration.
Key words: HALCON     machine vision     Eye-to-Hand     industrial robot    
引言

机器人视觉控制[1-2]是机器人领域的重要研究方向, 也是当前的研究热点之一。其系统按照摄像机与机器人的相对位置分为Eye-to-Hand系统和Eye-in-Hand系统。Eye-to-Hand系统将摄像机固定安装于机器人本体之外。随着工业化水平与科技的不断发展, 劳动力成本增加, 对定位装配的精度和自动化要求也越来越高。基于机器视觉技术的工业机器人定位[3-4]具有定位精度高、自动化和智能化水平高、劳动力成本低等优点, 因此在定位装配领域有着广泛的应用。

本文建立了机器人Eye-to-Hand系统, 主要论述了一种基于HALCON的摄像机内外部参数和手眼关系标定方法与其实验过程。该标定方法具有操作简单, 定位精度高等特点, 适用于产品抓取定位。

1 机器人视觉标定模型

机器人视觉系统的标定其实是获取摄像机图像坐标系(ICS)与机器人坐标系(RCS)之间转换关系的过程, 在标定机器人视觉系统(Eye-to-Hand)之前, 首先要对摄像机进行标定。通常摄像机镜头会存在径向、切向和偏心等畸变, 因此需要选择合适的畸变模型对摄像机进行标定。工业镜头的畸变主要为径向畸变, 为线性畸变模型; 非线性模型畸变包括径向、切向和偏心等畸变。对于工业镜头, 使用非线性畸变模型往往不能提高其标定精度, 而且还会造成求解的不稳定[5-6]; 采用线性畸变模型, 可以使标定精度提高一个数量级, 与非线性畸变模型相比标定精度差别不大。因此本文在论述中采用线性畸变模型来标定机器人视觉系统, 其标定模型如图 1所示。

图 1
Figure 1
图 1 机器人视觉标定模型Figure 1 Model of robot vision calibration

图 1中, (Oc,Xc, Yc, Zc)为摄像机坐标系(CCS),Oc即为摄像机的投影中心, z轴与摄像机的主光轴重合; (Ow,Xw, Yw, Zw)为机器人坐标系(世界坐标系WCS); (Oi,Xi, Yi)为成像平面坐标系(IPCS); (Ou,Xu, Yu)为图像坐标系(ICS)。空间一点PCCS下的坐标为P(xc,yc, zc); 在WCS下的坐标为P(xw,yw, zw)。若不考虑畸变, 则点P以透视投影在成像平面投影, 投影点为Pn(xn,yn); 若考虑径向畸变, 镜头的畸变将导致P发生偏移, 投影点为(xi,yi)。

建立WCSICS的转换关系需要以下3个步骤:

(1) 点P(xw, yw,zw)变换到点P(xc, yc,zc), 其关系如式(1)所示, Rt共同构成摄像机的外参数, 决定了CCSWCS之间的相对位置。

(1)

式中:R为旋转矩阵; t为一个平移向量。

(2) 点P(xc, yc,zc)变换到点(xi, yi), 其关系式为

(2)

式中:f为摄像机的主距; 考虑畸变, 设为畸变后的成像平面内的坐标, 则径向畸变关系式为

(3)

(3) 点变换到ICS内的点, 其关系式为

(4)

式中:sxsy为缩放比例因子; 点(cx,cy)为图像的主点, 对于针孔摄像机模型而言, 这个点是投影中心Oc在成像平面上的投影。

综上所述, 摄像机标定实际上是确定内参cxcysxsyfk和外参Rt的过程, 标定摄像机是标定机器人视觉系统的必要条件。

2 基于HALCON的手眼标定 2.1 标定板

手眼标定之前, 必须通过固定在机器人末端的工具来建立机器人坐标系和图像坐标系之间的关系。与传统的使用固定针尖人工寻找图像点的方式相比, HALCON软件自带标定板具有标定点容易提取、标定精度高、方向唯一等特点, 因此本文标定摄像机内外参数和机器人视觉的标定均采用HALCON标定板来完成。标定板如图 2所示。通常, 标定板的尺寸为摄像机摄影的1/2~1/3;背光源选择玻璃标定板, 正面光源选择陶瓷标定板, 视野范围大的, 标定精度不高的可以选择打印的标定板。

图 2
Figure 2
图 2 标定板Figure 2 Calibration plate
2.2 机器人末端旋转中心

典型的四轴工业机器人如图 3所示, 机器人坐标点通常是末端z轴的旋转中心, 如何找到其对应的图像坐标点, 建立机器人坐标系和图像坐标系的关系, 是标定成功与否的关键。一般可以通过在末端固定特制的针尖来寻找机器人坐标的对应图像点。该方法虽然简单易行, 但是受针尖加工误差、安装误差和针尖对焦困难等影响, 不能获得良好的标定效果。将标定板固定于机器人末端, 取标定板中心点为Mark点, 在摄像机视野内, 旋转机器人z轴, 获取多张图像, 计算末端中心在图像坐标上的对应点。

图 3
Figure 3
图 3 四轴工业机器人Figure 3 4-orientation industrial robot

设(uc, vc)为末端中心点, 则点标定板中心圆点坐标与末端中心的距离为

(5)

利用最小二乘法解式(5), 因为式(5)中有3个未知变量, 所以至少需要3个点(即需要3个旋转位置)来计算末端中心。

2.3 机器人视觉标定

在标定完摄像机内外参数之后, 可以指定任意一个坐标系作为摄像机的世界坐标系。考虑到Eye-to-Hand系统中摄像机和机器人的相对位置固定, 所以采用机器人的本体坐标系作为摄像机的外参数(世界坐标系), 通过上述标定过程, 即可完成Eye-to-Hand系统的标定。应该注意的是, 在2.2中获得末端中心位置的图像坐标后, 每次在摄像机视野内移动机器臂, 需要保持机器人R轴和z轴的值不变, 获取的图像点增加一个偏移量, 换算成机器人末端中心的图像坐标, 即

(6)

其中, (u0, v0)为计算旋转中心时的一个Mark点, (Δu, Δv)为偏移量。

3 实验结果与分析

本实验是在日本ESPON公司的LS3-401S型号机器人上完成的。摄像机采用BASLER型号ACA1300-30GM的工业相机, 固定于第2机械臂下方, 并于镜头正上方固定一环形光源。视野大小为200 mm×150 mm, 选取标定板尺寸为100 mm×100 mm的自制打印标定板, 其中两张拍摄图如图 4~5所示。

图 4
Figure 4
图 4 标定板Figure 4 Calibration plate

图 5
Figure 5
图 5 标定板坐标Figure 5 Coordinate in calibration plate

整个机器人系统标定包括摄像机内参标定、计算末端中心和手眼标定, 三个模块均需要通过标定板来寻找图像Mark点。其算法流程如图 6~8所示。

图 6
Figure 6
图 6 寻找Mark点Figure 6 Find Marks

图 7
Figure 7
图 7 摄像机标定与末端中心计算Figure 7 Camera calibration and terminal center calculation

图 8
Figure 8
图 8 手眼标定Figure 8 Hand-to-Eye calibration

本文根据上述算法流程进行实验, 采集15张图像来标定摄像机内参数; 采集8张图像来计算机器人末端中心; 采集12张图像来手眼标定。标定得摄像机内参数:f=10.4 mm,k=-3 124.1, sx=3.75×10-6 mm, sy=3.75×10-6 mm,cx=693.2, cy=404.2, 标定误差error=0.15。末端轴心偏移量:Δu=2.16 pixel, Δv=-2.34 pixel。机器人坐标系如表 1所示。

表 1 ( Table 1)
表 1 手眼标定结果 Table 1 The result of Eye-to-Hand
标定变量 X/m Y/m Z/m X轴旋转角/(°) Y轴旋转角/(°) Z轴旋转角/(°)
标定结果 -0.72 0.61 1.43 359.926 0.014 0.430
表 1 手眼标定结果Table 1 The result of Eye-to-Hand

为验证标定的准确性, 在标定机器人视觉系统后, 采用校验点真实的世界坐标即机器人坐标和利用标定后参数所求得的坐标之差的平均值作为标定精度的度量参数, 如式(7)所示。

(7)

分别计算横坐标Xn=0.148 mm, 纵坐标Yn=0.084 mm。又因为ESPON机器人的XY轴坐标精度为0.01 mm, 本文采用的摄像机像素精度为0.154 mm, 所以可得标定精度在一个像素范围内, 精度较高。

另外计算得横坐标最大差值为0.361 mm, 横坐标最大差值为0.143 mm, 横坐标差值的标准差为0.128 mm, 纵坐标标准差为0.049 mm。文献[7]指出, 标准差可以表征测量系统的不确定度, 因此横纵坐标的不确定度都在一个像素范围内, 精度较好。

4 结论

采用本文所述方法进行Eye-to-Hand手眼标定, 充分发挥了HALCON视觉软件强大的计算分析能力, 其标定结果具有精度高、操作简单、开发周期短、跨平台性好等特点[8], 适用于工业上需要抓取定位及装配的机器人视觉系统。

参考文献
[1] STEGER C, ULRICH M, WIEDEMANN C.机器视觉算法与应用(双语版)[M].杨少荣, 吴迪靖, 段德山, 译.北京:清华大学出版社, 2009.
[2] 蔡自兴. 机器人学[M]. 北京: 清华大学出版社, 2000 .
[3] 马光, 申桂英. 工业机器人的现状及发展趋势[J]. 组合机床与自动化加工技术 , 2002 (3) :48–51.
[4] 王敏, 王万俊, 黄心汉. 空间物体定位的机器人手眼视觉标定方法[J]. 华中科技大学学报 , 2001, 29 (3) :45–47.
[5] TSAI R Y.An efficient and accurate camera calibration technique for 3D machine vision[C]//Proceedings of IEEE Conference on Computer Vision and Pattern Recognition[C].New York:IEEE, 1986:364-374..
[6] HEIKKILA T, SALLINEN M, MATSUSHITA T, et al.Flexible hand-eye calibration for multi-camera systems[C]//Proceeding of 2000 IEEE/RSJ International Conference on Intelligent Robots and Systems.Takamatsu:IEEE, 2000, 3:2292-2297.
[7] 王磊, 郭淑霞, 张凤玲, 等. 微型铣刀外径视觉测量的不确定度[J]. 光学精密工程 , 2012, 20 (4) :880–887.
[8] 卢泉奇, 苗同升, 汪地, 等. 基于HALCON的机械手视觉抓取应用研究[J]. 光学仪器 , 2014, 36 (6) :492–498. 
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/zzzkiti/article/details/78235684

智能推荐

如何配置DNS服务的正反向解析_dns反向解析-程序员宅基地

文章浏览阅读3k次,点赞3次,收藏13次。root@server ~]# vim /etc/named.rfc1912.zones #添加如下内容,也可直接更改模板。[root@server ~]# vim /etc/named.conf #打开主配置文件,将如下两处地方修改为。注意:ip地址必须反向书写,这里文件名需要和反向解析数据文件名相同。新建或者拷贝一份进行修改。nslookup命令。_dns反向解析

设置PWM占空比中TIM_SetCompare1,TIM_SetCompare2,TIM_SetCompare3,TIM_SetCompare4分别对应引脚和ADC通道对应引脚-程序员宅基地

文章浏览阅读2.5w次,点赞16次,收藏103次。这个函数TIM_SetCompare1,这个函数有四个,分别是TIM_SetCompare1,TIM_SetCompare2,TIM_SetCompare3,TIM_SetCompare4。位于CH1那一行的GPIO口使用TIM_SetCompare1这个函数,位于CH2那一行的GPIO口使用TIM_SetCompare2这个函数。使用stm32f103的除了tim6和tim7没有PWM..._tim_setcompare1

多线程_进程和线程,并发与并行,线程优先级,守护线程,实现线程的四种方式,线程周期;线程同步,线程中的锁,Lock类,死锁,生产者和消费者案例-程序员宅基地

文章浏览阅读950次,点赞33次,收藏19次。多线程_进程和线程,并发与并行,线程优先级,守护线程,实现线程的四种方式,线程周期;线程同步,线程中的锁,Lock类,死锁,生产者和消费者案例

在 Linux 系统的用户目录下安装 ifort 和 MKL 库并配置_在linux系统的用户目录下安装ifort和mkl库并配置-程序员宅基地

文章浏览阅读2.9k次。ifort 编译器的安装ifort 编译器可以在 intel 官网上下载。打开https://software.intel.com/content/www/us/en/develop/tools/oneapi/components/fortran-compiler.html#gs.7iqrsm点击网页中下方处的 Download, 选择 Intel Fortran Compiler Classic and Intel Fortran Compiler(Beta) 下方对应的版本。我选择的是 l_在linux系统的用户目录下安装ifort和mkl库并配置

使用ftl文件生成图片中图片展示无样式,不显示_ftl格式pdf的样式调整-程序员宅基地

文章浏览阅读689次,点赞7次,收藏8次。些项目时需要一个生成图片的方法,我在网上找到比较方便且适合我去设置一些样式的生成方式之一就是使用Freemarker,在对应位置上先写好一个html格式的ftl文件,在对应位置用${参数名}填写上。还记得当时为了解决图片大小设置不上,搜索了好久资料,不记得是在哪看到的需要在里面使用width与height直接设置,而我当时用style去设置,怎么都不对。找不到,自己测试链接,准备将所有含有中文的图片链接复制一份,在服务器上存储一份不带中文的文件。突然发现就算无中文,有的链接也是打不开的。_ftl格式pdf的样式调整

orin Ubuntu 20.04 配置 Realsense-ROS_opt/ros/noetic/lib/nodelet/nodelet: symbol lookup -程序员宅基地

文章浏览阅读1.5k次,点赞6次,收藏12次。拉取librealsense。_opt/ros/noetic/lib/nodelet/nodelet: symbol lookup error: /home/admin07/reals

随便推点

操作系统精选习题——第四章_系统抖动现象的发生由什么引起的-程序员宅基地

文章浏览阅读3.4k次,点赞3次,收藏29次。一.单选题二.填空题三.判断题一.单选题静态链接是在( )进行的。A、编译某段程序时B、装入某段程序时C、紧凑时D、装入程序之前Pentium处理器(32位)最大可寻址的虚拟存储器地址空间为( )。A、由内存的容量而定B、4GC、2GD、1G分页系统中,主存分配的单位是( )。A、字节B、物理块C、作业D、段在段页式存储管理中,当执行一段程序时,至少访问()次内存。A、1B、2C、3D、4在分段管理中,( )。A、以段为单位分配,每._系统抖动现象的发生由什么引起的

UG NX 12零件工程图基础_ug-nx工程图-程序员宅基地

文章浏览阅读2.4k次。在实际的工作生产中,零件的加工制造一般都需要二维工程图来辅助设计。UG NX 的工程图主要是为了满足二维出图需要。在绘制工程图时,需要先确定所绘制图形要表达的内容,然后根据需要并按照视图的选择原则,绘制工程图的主视图、其他视图以及某些特殊视图,最后标注图形的尺寸、技术说明等信息,即可完成工程图的绘制。1.视图选择原则工程图合理的表达方案要综合运用各种表达方法,清晰完整地表达出零件的结构形状,并便于看图。确定工程图表达方案的一般步骤如下:口分析零件结构形状由于零件的结构形状以及加工位置或工作位置的不._ug-nx工程图

智能制造数字化工厂智慧供应链大数据解决方案(PPT)-程序员宅基地

文章浏览阅读920次,点赞29次,收藏18次。原文《智能制造数字化工厂智慧供应链大数据解决方案》PPT格式主要从智能制造数字化工厂智慧供应链大数据解决方案框架图、销量预测+S&OP大数据解决方案、计划统筹大数据解决方案、订单履约大数据解决方案、库存周转大数据解决方案、采购及供应商管理大数据模块、智慧工厂大数据解决方案、设备管理大数据解决方案、质量管理大数据解决方案、仓储物流与网络优化大数据解决方案、供应链决策分析大数据解决方案进行建设。适用于售前项目汇报、项目规划、领导汇报。

网络编程socket accept函数的理解_当在函数 'main' 中调用 'open_socket_accept'时.line: 8. con-程序员宅基地

文章浏览阅读2w次,点赞38次,收藏102次。在服务器端,socket()返回的套接字用于监听(listen)和接受(accept)客户端的连接请求。这个套接字不能用于与客户端之间发送和接收数据。 accept()接受一个客户端的连接请求,并返回一个新的套接字。所谓“新的”就是说这个套接字与socket()返回的用于监听和接受客户端的连接请求的套接字不是同一个套接字。与本次接受的客户端的通信是通过在这个新的套接字上发送和接收数_当在函数 'main' 中调用 'open_socket_accept'时.line: 8. connection request fa

C#对象销毁_c# 销毁对象及其所有引用-程序员宅基地

文章浏览阅读4.3k次。对象销毁对象销毁的标准语法Close和Stop何时销毁对象销毁对象时清除字段对象销毁的标准语法Framework在销毁对象的逻辑方面遵循一套规则,这些规则并不限用于.NET Framework或C#语言;这些规则的目的是定义一套便于使用的协议。这些协议如下:一旦销毁,对象不可恢复。对象不能被再次激活,调用对象的方法或者属性抛出ObjectDisposedException异常重复地调用对象的Disposal方法会导致错误如果一个可销毁对象x 包含或包装或处理另外一个可销毁对象y,那么x的Disp_c# 销毁对象及其所有引用

笔记-中项/高项学习期间的错题笔记1_大型设备可靠性测试可否拆解为几个部分进行测试-程序员宅基地

文章浏览阅读1.1w次。这是记录,在中项、高项过程中的错题笔记;https://www.zenwu.site/post/2b6d.html1. 信息系统的规划工具在制订计划时,可以利用PERT图和甘特图;访谈时,可以应用各种调查表和调查提纲;在确定各部门、各层管理人员的需求,梳理流程时,可以采用会谈和正式会议的方法。为把企业组织结构与企业过程联系起来,说明每个过程与组织的联系,指出过程决策人,可以采用建立过程/组织(Process/Organization,P/O)矩阵的方法。例如,一个简单的P/O矩阵示例,其中._大型设备可靠性测试可否拆解为几个部分进行测试