0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

手眼标定_全面细致的推导过程

工业机器人 来源:工业机器人 2020-07-11 09:57 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

本文解决的问题: 机械手搭载双目相机,手眼标定。 本文有细致的推导过程,非常全面。 什么是手眼标定 确定像素坐标系和空间机械手坐标系的坐标转化关系; 为什么会存在这个? 举一个生活中常见的例子——用手移动物体: 第一步:眼睛观察到三维世界,并将其转换到视网膜平面(三维空间转换到二维平面)传送信息给大脑; 第二步:大脑想要移动某个物体,假设想要将物体从A点移动B点(二维坐标),但是物体是三维空间中的物体,是三维坐标,需要将二维坐标换算成三维坐标; 第三步:大脑已经获得A点和B点的三维坐标,大脑给手(执行机构)发出指令去完成这个任务; 其中第二步就是手眼标定,得到二维坐标(像素坐标)到三维坐标的转换矩阵 在实际控制中,相机检测到目标在图像中的像素位置后,通过标定好的坐标转换矩阵将相机的像素坐标变换到机械手的空间坐标系中,然后根据机械手坐标系计算出各个电机该如何运动,从而控制机械手到达指定位置。这个过程中涉及到了图像标定,图像处理,运动学正逆解,手眼标定等。 相机的装载位置 不在手上(eye-to-hand) 相机固定在一个地方,机械手的运动不会带着相机一起移动。 在手上(eye-in-hand) 相机安装在机械手上,随着机械手一起移动。较为常用。这个实际上和eye-to-hand类似。 可以快速有效地标定被测物体的坐标。 这种情况的标定过程实际上和相机和机械手分离的标定方法是一样的,因为相机拍照时,机械手会运动到相机标定的时候的位置,然后相机拍照,得到目标的坐标,再控制机械手,所以简单的相机固定在末端的手眼系统很多都是采用这种方法,标定的过程和手眼分离系统的标定是可以相同对待的。 ●基于图像的视觉控制 ●基于位置的视觉控制 ●结合两者的混合视觉控制 在正式开始讲解之前,可以看一下:深入浅出地理解机器人手眼标定 对手眼标定有一个直观的认识。 正式开始 本文的相机搭载方案是,hand-in-eye。移动相机,标定求解过程 在推导过程中,我们会用到四个坐标系,分别是: ●基础坐标系(用base表示) ●机械手坐标系(用tool表示) ●相机坐标系(用cam表示) ●标定物坐标系(用cal表示) 下面先给出示意图:

坐标系之间的转换关系说明: ●baseHtool:表示机械手坐标系到基础坐标系的转换关系,可以由机器人系统中得出。(已知) ●toolHcam:表示相机坐标系到机械手坐标系的转换关系;这个转化关系在机械手移动过程中是不变的;(未知,待求) ●calHcam:表示相机坐标系到标定板坐标系的转换关系(相机外參),可以由相机标定求出;(相当于已知) ●baseHcal:表示标定板坐标系到基础坐标系的变换,这个是最终想要得到的结果;只要机械手和标定板的相对位置不变,这个变换矩阵不发生变化。

所以:其中的A已知,X待求,B需要通过相机标定得知(张正友标定法可以求得)。 验证结果

1. 基础坐标系(求解baseHtool) 符合右手定则的XYZ三个坐标轴 ●原点:机器人底座的中心点 ●X轴正向:指向机器人的正前方 ●Z轴正向:指向机器人的正上方 ●Y轴正向:由右手定则确定

六个自由度 ●三个位置:x、y、z(第六轴法兰盘圆心相对于原点的偏移量) ●三个角:Rx、Ry、Rz(第六轴法兰盘的轴线角度,由初始姿态即竖直向上绕x轴旋转Rx度,再绕Y轴旋转Ry度,再绕Z轴旋转Rz度得到) ●旋转方式(机器人RPY角和Euler角 – 基本公式)(机器人学-熊有伦36-40页) ●绕定轴X-Y-Z旋转(判断机械臂输出四元数与代码得到的四元数是否相等得到)

一定要注意欧拉角和李代数不一样,非常容易搞混,因为他们都是3个量 欧拉角:分别绕x、y、z轴旋转的角度,不一样的旋转次序,得到的R不一样; 李代数:维度是3,是绕一个轴转动一定的角度。欧拉角可以理解成李代数在x、y、z轴上的分解旋转。(不一定正确,不过比较形象) 注:不同机械臂示教器显示的法兰盘的数据格式不一样,有的是用欧拉角显示的,有的是用角轴显示的。 2. camHcal相机到标定板 ●注意:标定板坐标系下的坐标转换到相机坐标系下

思路大致如下: ●已知双目相机的内参、畸变系数、外参(Pr=R∗Pl+t P_r=R*P_l+tP r=R∗P l +t), ●对左右相机的两张图片调用OpenCV中的findChessboardCorners函数,找到内角点(如果结果不好,继续提取亚像素点); ●将左右相机的像素点对应起来,得到匹配的2d点; ●使用空间异面直线的方法,用对应的2d点计算出以右相机为世界坐标系的3维坐标Pcam P_{cam}P cam ;(立体视觉匹配) ●计算出每个角点以棋盘格为世界坐标的3维坐标Pcal P_{cal}P cal; ●通过解方程Pcam=camHcal∗Pcal P_{cam}=camHcal*P_{cal}P cam=camHcal∗P cal 求解出外参(3d-3d:ICP,SVD奇异值分解(十四讲173页)) 张正友相机标定Opencv实现

参数解释: ●第一个参数Image,传入拍摄的棋盘图Mat图像,必须是8位的灰度或者彩色图像; ●第二个参数patternSize,每个棋盘图上内角点的行列数,一般情况下,行列数不要相同,便于后续标定程序识别标定板的方向; ●第三个参数corners,用于存储检测到的内角点图像坐标位置,一般用元素是Point2f的向量来表示:vector image_points_buf; ●第四个参数flage:用于定义棋盘图上内角点查找的不同处理方式,有默认值。 3. 求解AX=XB 以下四篇论文对应着四种求解方法 Tsai, Roger Y., and Reimar K. Lenz. “A new technique for fully autonomous and efficient 3D robotics hand/eye calibration.” IEEE Transactions on robotics and automation 5.3 (1989): 345-358.(博客:Tsai-Lenz的OpenCV实现) Horaud, Radu, and Fadi Dornaika. “Hand-eye calibration.” The international journal of robotics research 14.3 (1995): 195-210. Park, Frank C., and Bryan J. Martin. “Robot sensor calibration: solving AX= XB on the Euclidean group.” IEEE Transactions on Robotics and Automation10.5 (1994): 717-721.(博客:Navy的OpenCV实现) Daniilidis, Konstantinos. “Hand-eye calibration using dual quaternions.” The International Journal of Robotics Research 18.3 (1999): 286-298. 网上有源代码可以下载:经典手眼标定算法C++代码 文献3采用的是李群的理论,将AX=XB转化成最小二乘问题; 文献4采用的时对偶四元数的知识,用对偶四元数表达旋转和平移,从而进行统一计算; 着四种算法精度差不多,不过文献4的效果要更好点。 具体实现文献3的算法,下面具体介绍 对数:乘法变加法 李群李代数

利用李群知识求解AX=XB

采用“两步法”求解上述方程,先解算旋转矩阵,再求得平移向量。

求解旋转矩阵

代码:用两组数据求解方程AX=XB

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 机械手
    +关注

    关注

    7

    文章

    357

    浏览量

    31151
  • 视网膜
    +关注

    关注

    0

    文章

    34

    浏览量

    13005

原文标题:手眼标定_全面细致的推导过程

文章出处:【微信号:indRobot,微信公众号:工业机器人】欢迎添加关注!文章转载请注明出处。

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

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    ECU刷写前的“隐藏关卡”:3分钟看懂XCP/CCP标定

    参数的优化过程。它通过使用标准的标定工具(例如USBCANFD-400U)标定ECU的各项参数并且查看标定效果。标定主要依赖两个标准协议:C
    的头像 发表于 11-28 11:35 193次阅读
    ECU刷写前的“隐藏关卡”:3分钟看懂XCP/CCP<b class='flag-5'>标定</b>

    CANape标定窗口被锁无法标定

    问题现象:解决方案:标定窗口被锁定无法标定除了ECU功能权限限制外可能存在的情况是CANape的工程配置影响的,主要有以下三个方面:1、CalibrateonlineDevice没有激活,需要将工程
    的头像 发表于 11-17 15:26 1537次阅读
    CANape<b class='flag-5'>标定</b>窗口被锁无法<b class='flag-5'>标定</b>

    IMU+多相机高速联合自动标定方案

    随着视觉惯性传感器在自动驾驶、机器人、AR/VR 等领域规模化落地,多相机+IMU 联合标定需求呈爆发式增长,多相机+IMU 联合标定领域尚属空白。 感算商城联合知名方案公司推出国内首台量产级
    发表于 10-23 14:04

    基于8位Booth编码的公式推导

    我们使用基于8位的Booth编码对乘法器进行修改 首先介绍一下基于4位的Booth编码公式推导: 对于P=A*B来说,将B以2进制码表示,可以转化为以下式子: 由于 将奇数位的运算拆分
    发表于 10-22 07:14

    什么是传感器标定?传感器标定真的如此重要吗?

    什么是传感器标定?在测量技术中,传感器标定是指在规定条件下确定测量仪器(例如传感器或测量系统)输出的具有相应测量不确定度的测量值与使用具有相应测量不确定度的标准建立的测量值的相应值之间的关系的任务
    的头像 发表于 08-25 09:10 1122次阅读
    什么是传感器<b class='flag-5'>标定</b>?传感器<b class='flag-5'>标定</b>真的如此重要吗?

    GraniStudio:相机标定例程

    说明 实现相机到标定位置进行标定。 注意:每次打开软件请先点击复位,确保位置安全;准备九点标定版;连接相机需加载对应GS提供的相机库,采用绝对路径,因此使用前如果相机库路径在电脑上没有,需手动导入相机DLL相机,使用
    的头像 发表于 08-22 17:38 770次阅读
    GraniStudio:相机<b class='flag-5'>标定</b>例程

    不确定度评估新实践:传感器标定中的置信概率与误差传递法则​

    提出更科学、更贴合工程实际的不确定度评估策略,提升标定结果的可信度与应用价值。 ​ ​引言​ ​ 在精密测量领域,传感器的性能依赖于严格的标定过程标定不仅仅是确定输入与输出关系的
    的头像 发表于 07-22 11:34 423次阅读

    【电磁兼容单位换算】EMC常用单位转换公式推导

    【电磁兼容单位换算】EMC常用单位转换公式推导
    的头像 发表于 06-24 17:28 4038次阅读
    【电磁兼容单位换算】EMC常用单位转换公式<b class='flag-5'>推导</b>

    陶瓷标定板技术--宏诚光学

    陶瓷标定板技术解析与应用指南一、核心特性与优势陶瓷标定板以陶瓷为基底,通过光刻工艺制作高精度图案(如棋盘格、圆点阵列等),具有以下特性:‌高环境适应性‌:热膨胀系数小(如8.6×10⁻⁶/°C),受
    的头像 发表于 05-07 16:09 576次阅读
    陶瓷<b class='flag-5'>标定</b>板技术--宏诚光学

    《聊一聊ZXDoc》之汽车标定、台架标定、三高标定

    ZXDoc支持XCP/CCP标定功能,标定工作贯穿主机厂与Tier1厂商汽车ECU研发、生产、测试的整个流程,是保障ECU性能达标、功能稳定的关键。什么是XCP/CCP标定?XCP/CCP标定
    的头像 发表于 04-27 11:36 1310次阅读
    《聊一聊ZXDoc》之汽车<b class='flag-5'>标定</b>、台架<b class='flag-5'>标定</b>、三高<b class='flag-5'>标定</b>

    史上最详细Buck公式推导及实验验证!

    先简要说明一下文章会说哪些内容。1、buck的拓扑结构,工作原理2、输入输出电容取值的推导过程,电感感量的计算过程3、boost各处电压,电流波形4、buck,boost公式汇总5、实际电路应用情
    发表于 03-31 11:34

    TIDA-00254使用SDK进行物体点云重建时在系统标定时DLP不打光,怎么解决?

    投影:DLP4500 相机:PointGray相机,具体型号:FL3-U3-13Y3M USB 3.0 SDK可以连接到相机与投影,且已完成相机标定(Calibrate camera),在进行系统标定(Calibrate system)时投影仪不打光,无法继续完成
    发表于 02-20 08:23

    请问做反射式血氧饱和度测量时如何进行标定呢?

    请问做反射式血氧饱和度测量时如何进行标定呢? 目前已完成透射式血氧饱和度测量仪的设计和实现,采用的Fluke的生命体征模拟仪Prosim8进行标定的,仪器有一个模拟手指,可以将指套式探头夹在模拟
    发表于 01-08 06:42

    三、麦克风阵列类型及分类之细致梳理

    麦克风阵列,作为声学领域的关键技术,拥有多种类型,每种类型都以独特的排列方式和卓越的性能,在不同的应用场景中发挥着重要作用,下面将为您细致梳理其类型与分类,展现麦克风阵列的奇妙世界。
    的头像 发表于 12-29 00:00 1544次阅读
    三、麦克风阵列类型及分类之<b class='flag-5'>细致</b>梳理