8_手眼标定总结_auboi5机械臂与海康平面相机

       经过不断地学习与调试,不断地学习网络上其他同志分享的资料,opencv手眼标定迎来了阶段性结束。实际测试结果在机械臂坐标系中X方向差5mm左右。

       代码参考《https://blog.csdn.net/wanggao_1990/article/details/81435660》   

       注意事项:

①标定板占据相机视野1/3左右,否则找不到角点

②代码未使用opencv的手眼标定接口

③需要注意图像标定角点的顺序,由于姿态关系,可能会旋转90度,导致结果异常

测试平台与道具:

①海康工业黑白相机

②遨博i5机械臂

③Ubuntu18.04  Qt组织代码

④圆网格标定板

⑤对位置用的尖端

一、opencv手眼标定

1、操作流程

为了验证流程,只采集了5张图片,第一张图片相机平行标定板,用于调整相机焦距,剩余4张分别前后左右稍稍改变相机姿态。每个姿态需采集海康相机图片(MVS软件获取)与机械臂位姿(sdk获取),机械臂位姿存取csv文件,之后我手动录入了xml文件中。    

c19d2c09eab7331f97bf347894725389.png

10f6c70031207323f92c4b874d4313a1.png

csv数据是机械臂基于base坐标系的位置、四元数姿态,欧拉角(ZYX)姿态。

第六行数据是标定板中心点对应机械臂位置,用于验证标定结果的手眼矩阵。 

2、代码流程

              ①doCalibration()->runCalibration()->calibrateCamera()

       如果看过之前的系列文章,再看代码,这块和网上是一致。得到相机内参和外参。

       ②readDatasFromFile()->attitudeVectorToMatrix()

       Hg:机械臂齐次矩阵

Hc:相机外参齐次矩阵

③convertVectors2Hij()    

// camera: A = A2*A1.inv();   robot:  B = B2.inv()*B1

计算AX=BX中的A和B.

Hgij:机械臂的B

Hcij:相机的A

可以继续了解矩阵的左乘与右乘。

④computerHandEyeMatrix()

这块没看

⑤getWorldPos()

将像素坐标转为机械臂基坐标系下的映射。

这块也没看

我的验证结果:

前面5行是机械臂的四元数姿态;

hcg是手眼矩阵;

最后一行是像素转为Word的结果,对比(359.844,-436.166);

获取图片像素我有一个单独程序;需要各部分加起来才是相对完整,这部分有

兴趣的同志可以自己搞下。

423c806a7db0484dab8299753e6638f7.png    

hcg是相机相对于末端tcp的位置和姿态,如果相机像识别标定板一样可以识

别出位置和姿态,那就是单目识别标识物实现2.5D的效果了。

其实后续还有要验证的:

1>械臂固定位姿,相机拍照模板匹配的像素精度

2>增加相机拍照图片数量,对比测试结果精度提升

3>标定姿态与使用姿态一致,应该可以增加精度

对这个6维的标定结果还需要进一步加深理解。

二、9点法标定

       这个是计算两个平面坐标系的相对关系,有3个自由度:位置x和y,还有一个旋转角θ.

       流程:

1>相机拍摄一张图片:

2>机械臂末端走4个位置与像素点对应

3>计算矩阵

机械臂用法兰尖端分别对了4个圆的中心。    

6ecc3f3a9996cc43f36be6d77b098ca8.png

测试程序如下:

//camera pixelcv::Mat A = (cv::Mat_(4, 3) <<1482, 579, 1,2221, 571, 1,2233, 1316, 1,1490, 1322, 1);// 4x3   //robot base pointcv::Mat B = (cv::Mat_(4, 3) <<412.918, -430.683, 1,365.714, -488.583, 1,307.422, -441.517, 1,354.509, -383.258, 1);   cv::Mat X;cv::solve(A, B, X, CV_SVD);std::cout << "X=" << std::endl << X << std::endl;   cv::Mat a1 = (cv::Mat_(1, 3) << 1370, 1450, 1.0);//352.412  -365.895  1370 1450//359.844  -436.166 1857  947cv::Mat b1 = a1*X;std::cout << "b1=" << std::endl << b1 << std::endl;std::cout << "真实值为:" << "359.844, -436.166, 1" << std::endl;

1137bc438d56c373dd7883d74aee4137.png

                     欢迎大家关注:

2f6ed1e53906b6fc3e1a32789d05f63e.png

需要opencv手眼标定工程可在后台留言“opencv手眼标定工程”。

                     之前的过程在这里:

7_手眼标定_3_求解AX=XB理论

手眼标定问题排查_圆网格数据排查

手眼标定问题排查_1_棋盘格相机内参标定姿态数据

7_手眼标定_1_一个失败的流程记录

6_相机坐标系_相机4个坐标系详述

6_相机坐标系_1_相机标定概述

5_相机标定_3_calibrateCamera()例子

5_相机标定2_calibrateCamera()与内外参

5_相机标定_1_标定板选取与角点绘制

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/4709.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MT3608B 航天民芯代理 1.2Mhz 24V输入 升压转换器

深圳市润泽芯电子有限公司为航天民芯一级代理商 技术支持欢迎试样~Tel&#xff1a;18028786817 简述 MT3608B是恒定频率的6针SOT23电流模式升压转换器&#xff0c;用于小型、低功耗应用。MT3608B开关频率为1.2MHz&#xff0c;允许使用微小、低电平成本电容器和电感器高度不…

http的basic 认证方式

写在前面 本文看下http的basic auth认证方式。 1&#xff1a;什么是basic auth认证 basic auth是一种http协议规范中的一种认证方式&#xff0c;即一种证明你就是你的方式。更进一步的它是一种规范&#xff0c;这种规范是这样子&#xff0c;如果是服务端使用了basic auth认证…

【源码阅读】 Golang中的database/sql库源码探究

Note&#xff1a;文章待完结 文章目录 前言一、整体目录结构二、driver包1、驱动相关driver.Driver2、驱动连接&#xff1a;driver.Conn3、预处理结构&#xff1a;Stmt4、执行结果 driver.Result5、查询结果&#xff1a;driver.Rows6、driver.RowsAffected7、driver.Value8、Va…

IMU识别高尔夫球击球位置

近日&#xff0c;来自欧洲的一支奥地利科研团队联合高校和业界专家&#xff0c;通过在高尔夫球杆上安装IMU传感器&#xff0c;用来实时精准识别球杆与球的接触点位置&#xff0c;以增强高尔夫训练效果。 该团队致力于开发一种移动式解决方案&#xff0c;以替代传统的静态检测技…

python基础知识(17)面向对象 1

一、面向对象的概念 1、面向对象的两个基本概念 编程语言中&#xff0c;一般有两种编程思维&#xff0c;面向过程和面向对象。 面向过程&#xff0c;看重的是解决问题的过程。 这好比我们解决日常生活问题差不多&#xff0c;分析解决问题的步骤&#xff0c;然后一步一步的解决…

MySQL 之 主从复制

1. 主配置文件&#xff08;win下是my.ini&#xff0c;linux下是my.cnf&#xff09; #mysql 服务ID,保证整个集群环境中唯一 server-id1 #mysql binlog 日志的存储路径和文件名 log-bin/var/lib/mysql/mysqlbin #错误日志,默认已经开启 #log-err #mysql的安装目录 #basedir #mys…

E-MapReduce极客挑战赛季军方案

前一段时间我参加了E-MapReduce极客挑战赛&#xff0c;很幸运的获得了季军。在这把我的比赛攻略给大家分享一下&#xff0c;希望可以抛砖引玉。 赛题分析与理解 赛题背景&#xff1a; 大数据时代&#xff0c;上云已成为越来越多终端客户大数据方案的落地选择&#xff0c;阿里…

特别的时钟特别的倒计时

念念不忘的歌曲&#xff1a;Thats Why You Go Away <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title&…

测算sample gpt

测算代码 import pandas as pd import matplotlib.pyplot as pltlosspd.read_pickle("loss_8.pkl") plt.plot(loss) losspd.read_pickle("loss_16.pkl") plt.plot(loss) losspd.read_pickle("loss_4_8.pkl") plt.plot(loss) losspd.read_pickle(…

进程的概念(2)

进程优先级 1.什么的优先级 概念&#xff1a;指定进程获取某种资源&#xff08;CPU&#xff09;的先后顺序 本质&#xff1a;优先级的本质是优先级数字的大小&#xff0c;Linux中优先级数字越小&#xff0c;优先级越高 task_struct 进程控制快-> struct -> 内部字段 -&g…

Modbus转Profinet网关连接打印设备与PLC通讯

Modbus转Profinet网关&#xff08;XD-MDPN100&#xff09;是一种能够实现Modbus协议和Profinet协议之间转换的设备。Modbus转Profinet网关可提供单个或多个RS485接口&#xff0c;使得不同设备之间可以顺利进行通信。当我们需要连接打印设备与PLC进行通讯时&#xff0c;Modbus转…

pycharm 安装“通义灵码“并测试

过程&#xff1a;“File>setting>Plugins” 提示&#xff1a; 翻译之后&#xff1a; 点击"接受"之后&#xff0c;提示一下图片&#xff0c;点击ok 安装完成&#xff1a; 安装完"通义灵码"之后&#xff0c;需要登陆&#xff0c;登陆后测试 参考…

vue实现滚动条联动(一个滚动条控制两个或多个)

两个表格需要进行比对&#xff0c;两个表格是互相独立的&#xff0c;如果滚动条不能同步&#xff0c;用户就要操作两个两次&#xff0c;体验不是太好&#xff0c;如下图&#xff1a; 因此想使两个滚动条同步&#xff0c;思路如下&#xff1a; 给两个表格定义ref&#xff08;便…

uniapp微信小程序开发踩坑日记:由于图表数据渲染不出来,我第一次在项目中用watch函数监听数据变化

一、发现问题 在我们团队自己开发的微信小程序中&#xff0c;引入了Echarts图表库 然后突然有一天&#xff0c;后端队友反应图表渲染有问题。后面我去试了一下&#xff0c;确实20次里面必有一次数据渲染不出来 断定代码没问题&#xff0c;于是我们将其鉴定为玄学 二、问题原因…

VS2022 配置OpenCV开发环境详细教程

OpenCV OpenCV&#xff08;Open Source Computer Vision Library&#xff09;是一个开源的计算机视觉和机器学习软件库&#xff0c;由Intel开发并首先发布于1999年。OpenCV被广泛用于实时图像处理、视频分析、物体检测、面部识别、机器人视觉以及许多其他领域。它支持C、Pytho…

代码+视频,R语言绘制生存分析模型的时间依赖(相关)性roc曲线和时间依赖(相关)性cindex曲线

ROC曲线分析是用于评估一个因素预测能力的手段&#xff0c;是可以用于连续型变量分组的方法。在生存分析中&#xff0c;疾病状态和因素取值均会随时间发生变化。而标准的ROC曲线分析将个体的疾病状态和因素取值视作固定值&#xff0c;未将时间因素考虑在分析之中。在这种情况下…

STM32入门_江协科技_1~2_OB记录的自学笔记_STM32简介

1.综述 1.1. 课程简介 手打代码是加入了实操&#xff0c;增加学习效果&#xff1b; STM最小系统板面包板的硬件平台&#xff1b; 配套0.96寸的显示屏&#xff0c;便于调试&#xff1b; 因为使用面板板&#xff0c;所以如果程序现象不出来也有可能是硬件连接的问题&#xff1b; …

Linux 小技巧1

目录 一. 统计文件的总行数二. 获取从第二行开始的内容三. 合并两个文件为一个文件四. 统计指定列唯一值的数量五. 列出文件的绝对路径六. 获取除了空白行和注释之外的部分 一. 统计文件的总行数 ⏹非压缩文件 统计当前文件夹下csv文件的行数 wc -l ./*.csv统计指定文件夹下…

甘特图是什么?利用甘特图来优化项目管理流程

在现代项目管理中,图表是一种强大而直观的工具,可以帮助项目经理和团队成员清晰地了解并掌控整个项目进程。其中,甘特图是最常用和最有效的图表之一。 甘特图是一种条形图,可以用来直观地展示项目中各个任务的进度、持续时间和相互关系。它由一个横轴和一个纵轴组成。横轴代表时…

基于单片机的多功能电子万年历系统

摘要:该题目要求学生综合运用单片机原理、低频电子线路、数字电路与逻辑设计等相关知识,设计完成多功能电子万年历系统。通过完成设计任务,使学生掌握单片机设计开发的基本流程,增强学生动手实践能力,培养学生分析和解决实际问题的能力,为后续课程的学习和工作打下良好基础。 关…