手眼标定之基本原理

手眼标定之基本原理文章目录一前言二Eye-in-Hand2.1基础知识准备2.2Eye-in-Hand基本原理三跋原文首发于微信公众号【视觉IMAX】。一前言机器人的视觉系统分为固定场景视觉系统和运动的「手-眼」视觉系统。摄像机与机器人的手部末端,构成手眼视觉系统。根据摄像机与机器人相互位置的不同,手眼视觉系统分为Eye-in-Hand系统和Eye-to-Hand系统。Eye-in-Hand…

大家好,又见面了,我是你们的朋友全栈君。

原文首发于微信公众号【3D视觉工坊】。

一 前言

机器人的视觉系统分为固定场景视觉系统和运动的「手-眼」视觉系统。摄像机与机器人的手部末端,构成手眼视觉系统。根据摄像机与机器人相互位置的不同,手眼视觉系统分为Eye-in-Hand系统和Eye-to-Hand系统。Eye-in-Hand系统的摄像机安装在机器人手部末端(end-effector),在机器人工作过程中随机器人一起运动。Eye-to-Hand系统的摄像机安装在机器人本体外的固定位置,在机器人工作工程中不随机器人一起运动。

Eye-in-Hand系统的在工业机器人中应用比较广泛,随着机械手逐渐接近目标,摄像机与目标的距离越来越小,被测物体位置参数的绝对误差会随之降低。在Eye-in-Hand系统中,采用基于图像的视觉控制、基于位置的视觉控制以及结合两者的混合视觉控制,可以快速有效地标定被测物体的坐标。

手眼标定方法通常分为3类:标准手眼标定、基于旋转运动的手眼标定以及在线手眼标定。以上方法是将摄像机标定与手眼标定分开进行,也有的论文采用的是联合标定法。

本文重点讲解Eye-in-Hand的一般方法,重在阐述其基本原理。

二 Eye-in-Hand

2.1 基础知识准备

在研究相机标定时,已较为熟悉,在本公众号「视觉IMAX」里已有几篇文章做过总结,如:
a) 一分钟详解OpenCV之相机标定函数calibrateCamera()
b) 一分钟详解「本质矩阵」推导过程
c) 计算机视觉基本原理——RANSAC
d) 再谈「相机标定」

此处就不详细展开叙述了。

2.2 Eye-in-Hand基本原理

对目标点的空间三维坐标进行变换的过程中,首先遇到的问题是机器人末端关节坐标系与摄像机坐标系之间的位置变换关系,也就是机器人的手眼位置关系,该关系用符号X表示,具体可以用方程AX=XB求解。其中A表示相邻两次运动时机器人末端关节的变换关系;B表示相邻两次运动时摄像机坐标的相对运动。

下面,简单介绍一下本问题模型中为何会引入AX=XB模型。
如图1所示,为眼在手上,也即eye-in-hand。(本篇文章重点讨论的是双目,所以此处仅是为了演示效果图,而非真实的实验场景)。相机固定在机械臂末端,会随着机械臂的运动而运动。

图1 眼在手上


图1 眼在手上

我们会得到一堆坐标系和坐标变换关系:

  • A:机器人末端在机械臂坐标系下的位姿,这其实就是机器人运动学正解的问题。(已知)。

  • B:相机在机器人末端坐标系下的位姿,这个变换是固定的,只要知道这个变换,我们就可以随时计算相机的实际位置,所以这就是我们想求的东西。(未知,待求)

  • C:相机在标定板坐标系下的位姿,这个其实就是求解相机的外参(已知)。

  • D:相机在机器人基坐标系下的位姿。实际使用过程中标定板并不存在,所以这个变换关系我们不关心。

所以,只要我们能计算得到B变换,那么相机在机器人坐标系下的位姿D也就自然得到了。

如图2所示,我们让机械臂运动两个位置,保证这两个位置下都可以看到标定板,然后构建空间变换回路:
图2 机械臂运动到两个位置,构建变换回路

在这里插入图片描述

图3 谷歌学术搜索

在谷歌学术用关键词「AX=XB」搜索便可以得到各种求解办法,见图3所示。

以上图中的几篇论文,都很详细地给出了推导过程,按照它们写程序基本没问题。

这样,我们便有了A、B和C,就能直接求解得到我们想要的手眼标定结果D了。

前面主要是为了理清思路,对于每个部分的细节都给省略掉了,接下来进行详细说明。

1)变换A: 它是机械臂末端在机器人基座坐标系下的位姿,其实就是机器人学里面最基础的运动学正解。如图4所示。
图4 机器人运动学正解模型
用DH矩阵等方法来计算机器人运动学正解。可以参看熊有伦主编的《机器人技术基础》这本书。在实际操作中,根据机器人的示教器读出欧拉角,即可换算出机械手爪坐标系到机械臂基座的转换矩阵。

2)变换C: 它是相机在标定板坐标系下的位姿。其实就是相机的外参。如图5所示,其中的R,T 即为相机在标定板下的位姿。
图5 相机在标定板板坐标系下的位姿
在这里插入图片描述
图6 相机模型

相机模型有了,我们要做的就是先确定内参矩阵,然后根据不同时刻拍摄的标定板图片来求取外参矩阵:也即相机在世界坐标系下的变换关系C

目前来说,要解决这个问题,基本上都是采用张正友老师的方法。这个在之前的相机标定过程中,已经实现。

3)求解AX=XB。

关于这个公式的求解,对应着多种不同的解法,此处推荐一篇文章,如下:

  1. Daniilidis, Konstantinos. “Hand-eye calibration using dual quaternions.” The International Journal of Robotics Research 18.3 (1999): 286-298.

注: 在公众号【视觉IMAX】后台回复「解AX=XB」,即可获得下载上述文章的下载链接。

得到X也即手眼关系,最后得到相机坐标系到机器人基座的坐标变换关系:D=A*X。
式中A代表:机器人手抓到机器人基座坐标变换;X表示相机到机器人手抓的坐标变换。
在这里插入图片描述

以上手眼标定流程,大体可以总结如图7所示:
图7 手眼标定流程示意图

手眼标定的基本原理如上所述,至于正确性,仍需由实验进一步验证。

三 跋

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/131366.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • PCIe卡的主要引脚 及 热插拔

    PCIe卡的主要引脚 及 热插拔目录1PCIe总线使用的信号1.1收发数据信号1.2辅助信号2热插拔参考资料1PCIe总线使用的信号PCIex1,x4,x8,x16卡的连接器引脚如下图所示,数据收发引脚为白色,辅助引脚为灰色:mechanicalkey对应防呆缺口的位置。1.1收发数据信号PCIe总线的层次分层图:与收发数据相关的线就是每个通路(lane)的两对差分传输线。PCIex1,x2,x4,x8,x16分别代表有1,2,4,8,16条lane。1.2辅助信号在连接器上提供辅助引脚来辅助

  • Java学习书籍整理

    Java学习书籍整理不知不觉中,做Java开发已经四年了,趁着现在换了工作,还算比较闲,就整理一下自己学习的一些知识。在学习过程中,我喜欢找的一些电子书来系统化的学习,多数时候我都只是做一个大概的了解,没有深入学习,基本就是看下目录,看下前几章的内容,深入的只会在实际用的时候才去详细看了。我从以下几个方面整理了一下这些学习的电子书,分享给大家,免得到处去找这些资源,百度脑图里面的分类也…

  • List集合的sublist方法

    List集合的sublist方法

  • docker(7)docker-compose容器集群编排「建议收藏」

    docker(7)docker-compose容器集群编排「建议收藏」前言实际工作中我们部署一个应用,一般不仅仅只有一个容器,可能会涉及到多个,比如用到数据库,中间件MQ,web前端和后端服务,等多个容器。我们如果一个个去启动应用,当项目非常多时,就很难记住了,所有

  • python 获取图片大小_python用户输入矩形的长和宽

    python 获取图片大小_python用户输入矩形的长和宽#coding:utf8fromPILimportImageimg=Image.open(“img.jpg”)printimg.sizeprintimg.format

  • java的filter方法(过滤器的功能)

    一.什么是Filter?Filter译为过滤器。 由于Servlet规范是开放的,借助于公众与开源社区的力量,Servlet规范越来越科学,功能也越来越强大。2000年,Sun公司在Servlet2.3规范中添加了Filter功能,并在Servlet2.4中对Filter进行了细节上的补充。二.运行原理:当客户端向服务器端发送一个请求时,如果有对应的过滤器进行拦截,过滤器可以改变请求的内容、或者重…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号