3D相机的9点标定

这篇具有很好参考价值的文章主要介绍了3D相机的9点标定。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本文已参与「新人创作礼」活动,一起开启掘金创作之路。

9 点标定法


1 适用范围及情形

1.1      在机器人外固定安装的3D相机与机器人的手眼标定,X36相机等安装与固定支架上,不依赖与外部运动机构而自动获取3D图像的情形**

1.2      在机器人外部安装于运动机构上的3D相机与机器人的手眼标定,由电机带着相机运动来获取3D图像;

1.3      相机安装于机器人第6轴上,相机由机器人轨迹驱动从而获取3D图像,但是机器人只需要带动相机在固定位置/轨迹获取图像,或者不需机器人频繁变换取图位置(只有有限几个取图路径),此时可以视作同情形1.2。

2 标定原理

(备注:我们此处多处以齐次坐标矩阵形式描述的坐标关系是为了便于理解而为之,也是大部分其他工具如机器人、图像处理软件等底层的运算方式,但在使用层使用较多的是位置坐标x,y,z结合欧拉角形式的姿态角a,b,c或Rx,Ry,Rz进行表达的,详请参阅相关资料加以理解,此处不再赘述)

以上所列举的使用情形均可归结为“眼在手外”的安装情形,即便是相机安装在机器人手臂上由机器人轨迹来驱动获取图像,但由于机器人轨迹较为固定,所以可以将其视作固定安装的直线运动单元,只是需要保证机器人的运动方向及安装姿态与相机自身的坐标系对齐。

3D相机的9点标定3D相机的9点标定  

\

针对该情形下相机与机器人的位置关系标定,则可采用9点标定法。所谓9点标定,实际上是9组点的对齐。该标定是将相机坐标系与机器人基座建立位置关联,得到相机坐标系到机器人基座的转换关系(即相机坐标系在机器人基座坐标系下的表达)。一般来说,我们需要选取9个前后、左右、上下位置各不相同的参考点(一般选取标定锥或者标有十字交叉点的纸板等)放置在相机视野范围内,使其尽可能覆盖将来相机在实际生产中的工作范围。然后使用机器人已知TCP的尖点触碰9点中的第1点,得到该点在机器人基座坐标系下的位置坐标,记作(Xr1,Yr1,Zr1); 接下来使用相机取图得到包含第1点的3D图像,在得到图像的强度图中通过鼠标指针获取对应的第1点在相机中的位置坐标,记作(Xc1,Yc1,Zc1)。依次对第2~9点做相同操作并分别记录下来。最终得到9个点分别在机器人基座坐标系下的位置坐标和对应点在相机坐标系下的位置坐标。

然后将上述记录的9组点通过Halcon算子或者EasyRanger软件工具等运算可得到相机到机器人基座的转换关系,记作 robotHcamera ,一般使用机器人可理解的方式表达为(x,y,z,Rx,Ry,Rz)或者(x,y,z,a,b,c)。

3 操作流程及使用

3.1      安装标定针及TCP示教

在机器人末端安装标定针(标定针可以是任意尖锐物体,并具有一定的长度),使用4点法示教标定针的TCP,为了保证最终标定的系统精度,最好将标定针的TCP最大误差控制在0.5mm以内。

3.2      确定相机安装方式

a.     如果相机安装在外部支架或机构上,相机取图与机器人轨迹没有关系,则忽略此步;

b.    如果相机安装在机器人上,并且依靠机器人的固定直线轨迹方可进行取图,则应首先确保驱动相机取图的机器人轨迹应与相机自身坐标系的Y方向(垂直于相机激光的射出平面)平行,不可有上下、左右的倾斜及俯仰角,其平行程度直接影响最终的系统精度。然后示教并确定相机的取图轨迹。

3.3      !

可以选择圆锥作为标定物(需要圆锥拟合尖点坐标),也可以自制标有十字交叉点的纸板标定物,如果操作得当,均不影响最终的标定精度,我们推荐较为低成本的十字交叉点纸板(下述使用)。3D相机的9点标定

从如图所示相似的硬纸箱上取一块平整的纸板(该材质有较好的成像效果,如果手头没有类似纸板,可以选用A4纸并粘贴于硬平板上),在纸板中心使用黑色中性笔划出两条约4~5cm的十字交叉线,无需介意线是否平直,形成的十字交叉点用于我们后续的标定过程。

3.4      标定

将纸板的十字交叉点朝向相机,并稳固放置于相机工作视野内(触发相机取图验证十字交叉点在相机获取的强度图中可见性)。

操作机器人使其标定针轻轻触碰纸板的十字交叉点,记录当前机器人的标定针TCP在机器人基座坐标系下的坐标位置,记作(Xr1,Yr1,Zr1),然后移开机器人;

驱动/触发相机取图,将软件切换至强度图模式(或者使用SICK EasyRanger软件导入图像后切换至强度图模式),将鼠标移至纸板的十字交叉点读取该点的坐标值,记作(Xc1,Yc1,Zc1)。

然后保持纸板的十字交叉点朝向相机,移动纸板至相机视野内的9个不同位置,使这9个位置能够覆盖生产中的相机实际有效工作范围,并且保证9个点的前后左右上下位置不同。依次重复上述测量,并得到点在机器人和相机坐标系下的坐标:

| 机器人坐标系下的坐标 | 相机坐标系下的坐标 | | ----------- | ----------- | | Xr1,Yr1,Zr1 | Xc1,Yc1,Zc1 | | Xr2,Yr2,Zr2 | Xc1,Yc1,Zc1 | | … | … | | Xr9,Yr9,Zr9 | Xc9,Yc9,Zc9 |

3.5      计算转换关系

通过以上所测得的数据,可以通过Halcon,Eigen数学库,SICK EasyRanger工具等进行计算得到相机到机器人基座的转换关系,可记作robotHcamera , 该转换关系以机器人可理解的方式表达为(x,y,z,Rx,Ry,Rz)或者(x,y,z,a,b,c)。

3.6      如何使用标定得到的转换关系

接下来在生产中使用相机取图,图像经过处理后可以得到目标物体在相机中的位姿,记作cameraHobject ,将姿态统一成欧拉角形式可记作(xo,yo,zo,a,b,c)。如果物体的姿态不是生产中所关注的,那么可以将其记作(xo,yo,zo,0,0,0)。

然后将标定所得到的转换关系与目标物体在相机中的位姿相乘(robotHcamera* cameraHobject),即可得到目标物体在机器人基座坐标系下的位姿,即robotHobject , 当然最终仍需以机器人理解的方式表达为(x,y,z,rx,ry,rz)或(x,y,z,a,b,c)。该位姿即为最终机器人需要到达的目标点,从而进行抓取或其他作业。

以上所述二者相乘可以使用自行开发的程序进行,或使用第三方库(如Halcon,Eigen)进行,也可使用SICK EasyRanger进行。

4 总结

9点标定法操作相对简单,且容易理解,有较广的应用范围。针对前述的应用的场景,如操作得当,可以得到较高的系统精度。如果使用较为低精度的3D相机(比如TOF原理相机),则很难通过图像准确观察到十字交叉点的位置,此时可以推荐使用圆锥作为标定物,使用相机获取的图像进行圆锥拟合得到锥尖坐标,机器人触碰锥尖得到另一组坐标,其他操作方式与纸板标定类同。文章来源地址https://www.toymoban.com/news/detail-449446.html

到了这里,关于3D相机的9点标定的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 激光雷达与相机外参标定(附open3d python代码)

    现在的激光雷达与相机的标定程序基本都是Ubuntu框架下面的,并且都是C++代码,需要安装的依赖也比较复杂,于是自己写了一个python版本的标定程序,依赖非常简单,Windows系统也可以运行。并且代码简单一个文件搞定,符合python简单易行的风格。 先上最后标定后的效果图​

    2024年02月11日
    浏览(43)
  • 从0到1搭建一套属于你自己的高精度实时结构光3D相机(8):结构光系统模型与逆相机法投影仪标定

    在前面的博客中,介绍了采用同心双圆环靶标下的相机标定算法与代码实践。在这篇博客中,博主将介绍 结构光相机模型与逆相机法投影仪标定 。完成本篇博客的学习内容后,你将收获投影仪逆相机法标定和结构光相机模型算法与代码实践经验。 本系列博客的完整项目代码

    2024年04月15日
    浏览(53)
  • 讲讲微信小程序分包——本文来自AI创作助手

    微信小程序分包是为了解决小程序包体积过大而引入的一个功能。通过将小程序分为多个子包,每个子包可以独立加载和升级,从而让小程序的启动速度更快,用户体验更好。 具体实现: 在小程序根目录下创建一个名为 subpackage 的目录,用于存放子包相关的文件和页面。 在

    2024年02月09日
    浏览(46)
  • 相机标定和双目相机标定标定原理推导及效果展示

      参考了一些大佬的文章,整理了一下相机标定和双目标定的原理和推导。   摄像机成像就是空间场景投影至二维图像平面的空间变换过程。摄像机标定的要解决两个问题:首先确定三维空间点与像素平面像素点间的转换关系,即求解相机内外参;然后确定相机成像过程中

    2023年04月09日
    浏览(44)
  • 相机标定 - (02) - 相机标定步骤与原理

    目录 2 相机标定步骤 2.1 张正有标定操作步骤 2.2 张正有标定原理 参考文章: 三步骤详解张正友标定法_谜之_摄影爱好者的博客-CSDN博客         1998年,张正友提出了基于二维平面靶标的标定方法,使用相机在不同角度下拍摄多幅平面靶标的图像,比如棋盘格的图像,然

    2024年02月11日
    浏览(67)
  • 关于相机内参与外参的浅读

    原文地址:https://tunmx.github.io/posts/CH-Camera-internal-and-external-parameters/ 学习人脸3D重建的第一天,在首次接触3D相关的内容,必须要搞清楚相机的成像原理,如何将真实三维空间中的三维点与显示器、屏幕和图像等二维成像的平面映射,以及了解该过程的推导方式和相关坐标系的

    2024年02月15日
    浏览(38)
  • 相机标定-机器视觉基础(理论推导、Halcon和OpenCV相机标定)

             相机标定是获得目标工件精准坐标信息的基础。首先,必须进行相机内参标定,构建一个模型消除图像畸变;其次,需要对相机和机器人的映射关系进行手眼标定,构建一个模型将图像坐标系上的点映射到世界坐标系。主要分为背景知识、相机内外参模型推导、

    2023年04月21日
    浏览(45)
  • 相机标定—— 张正友标定法(1)

    我们首先要明白两个问题:1、相机是如何成像的?2、相机标定的目的是什么? 相机的成像过程涉及了 4 种坐标系与 3 种变换关系,这 3种变换关系分别是刚体变换、投影变换和离散化。 图 1 : 四 种 坐 标 系 的 关 系 图1 :四种坐标系的关系 图 1 : 四 种 坐 标 系 的 关 系

    2023年04月09日
    浏览(82)
  • 【相机标定】相机内参

    相机在计算机视觉方面的一些应用一般需要相机标定。我们总是听到标定这个词,那么具体标定的是什么呢?相机的拍摄是一个三维到二维(透视投影)的过程,这个过程可以用数学模型去表述,标定便是计算这个数学模型中的参数,我们最终希望通过这些参数能够从二维的

    2023年04月10日
    浏览(45)
  • 相机标定-张正友棋盘格标定法

    目录 1.针孔相机模型 2.相机成像过程 2.1  各个坐标系之间的转换 2.1.1 图像坐标系到像素坐标系  2.1.2 相机坐标系到图像坐标系  2.1.3世界坐标系到相机坐标系  2.1.4世界坐标系到像素坐标系 3.畸变与畸变矫正 3.1 畸变 3.2 畸变公式 4.相机标定原理 5.张正友标定法介绍 5.1张正友

    2024年01月16日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包