基于OpenCv的机器人手眼标定(九点标定法)《转载》

转载链接:

基于OpenCv的机器人手眼标定(九点标定法)

对于初学者而言,对相机的标定经常模糊不清。不知道机器坐标与相机坐标如何转换,两个坐标系又是如何建立?
我们通常是利用张氏标定法,针对于相机的畸变进行标定,利用校正得到的参数对图形进行处理后再呈现出来。这个方法网上用的人很多,资料也较为全面。这里就不做说明了。本文主要是针对机械手的手眼标定,一般而言目前相机的畸变较小,精度也较为准确,使用该方法进行标定也能得到较好的效果。
首先,对于九点标定而言。我们使用到的是OpenCv中的estimateRigidTransform 函数。
函数定义如下:
Mat estimateRigidTransform(InputArraysrc,InputArraydst,boolfullAffine)
前两个参数,可以是 :src=srcImage (变换之前的图片Mat) dst=transImage(变换之后的图片Mat)
也可以: src=array(变换之前的关键点Array) dst=array(变换之后的关键点Array)
第三个参数: 1(全仿射变换,包括:rotation, translation, scaling,shearing,reflection)

其主要原理为:如果我们有一个点变换之前是[x,y,1],变换后是[x’,y’,1] 则fullAffine表示如下:

在这里插入图片描述

TX=Y
在这里插入图片描述

展开后表示

在这里插入图片描述

如果我们想求这【a-f】 6个变量需要有6个方程,也就是3组点。但是比三个点多呢?
比如:20个点。那就是用最小方差。
在这里插入图片描述
标定步骤
1、首先我们需要准备一块,标定板。如果条件不足,可以使用白纸画上九个圆进行代替。
在这里插入图片描述
2、相机位置,机械手位置全部固定好,标定针固定在机械手上,固定好后不能够再移动。标定针的位置一定要与夹手或吸盘之内的工具同一位置高度。
3、将标定板放到相机下方,位置区域要与机械手工作的区域一样,包括高度必须尽量一致,这是标定准确度的关键。
4、调整好相机焦距,拍照,然后识别9个圆圆心的坐标并进行记录。关于如何找圆,可以参考我的上一篇博文,对于圆形的查找十分精准。
5、将机械手依次移动到9个圆的圆心位置,记下机械手坐标

做完以上五步,我们会得到两个点集。一个为9个圆圆心坐标(points_camera),一个为9个圆心对应的机械手坐标(points_robot)。

	Mat warpMat;
	vector<Point2f>points_camera;
	vector<Point2f>points_robot;`
	vector<Point2f>points_camera;
	vector<Point2f>points_robot;
	warpMat =estimateRigidTransform(points_camera, points_robot, true);
	 A = warpMat.ptr<double>(0)[0];
	 B = warpMat.ptr<double>(0)[1];
	 C = warpMat.ptr<double>(0)[2];
	 D = warpMat.ptr<double>(1)[0];
	 E = warpMat.ptr<double>(1)[1];
	 F = warpMat.ptr<double>(1)[2];

得出来的6个double类型的参数,就是我们此次标定最终得到的标定参数了。
之后我们把检测得到的图像坐标(t_px,t_py)代入,就可以得到与之相对应的机械手坐标(t_rx,t_ry)
t_rx= (A * t_px) + B * t_py + C);
t_ry= (D * t_px) + E * t_py+ F);
至此标定结束,我们可以控制相机拍照进行定位,然后转换成机械手坐标,指哪打哪了。希望对初学者有所帮助,转载请注明出处。

  • 1
    点赞
  • 68
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: OpenCV中的9点标定是一种用于计算相机的内外参数的方。它根据相机的一组已知的图像点和相应的物理世界点,通过构建相机的投影矩阵来计算相机的内参矩阵和外参矩阵。以下是该算的步骤: 1. 收集一组至少9个已知的图像点和相应的物理世界点。这些图像点和物理世界点之间应该具有已知的对应关系。 2. 根据收集到的图像点和物理世界点,使用cv2.findHomography()函数计算单应性矩阵。单应性矩阵可以将物理世界点映射到图像坐标系。 3. 将单应性矩阵分解为相机的旋转矩阵和平移矩阵。根据这两个矩阵可以计算相机的外参矩阵。 4. 使用cv2.calibrateCamera函数计算相机的内参矩阵、畸变系数和旋转平移矩阵。该函数将输入所有的图像点和物理世界点,并根据9点标定进行计算。 5. 根据计算得到的内外参数,可以进行相机校正和图像修正等操作。 9点标定通过使用最小二乘来最小化图像点和重投影点之间的误差,从而得到最佳的相机参数估计。该算在相机标定中广泛应用,可以用于计算相机的焦距、主点和畸变系数等重要参数,为计算机视觉应用提供支持。 ### 回答2: OpenCV 9点标定是一种计算机视觉中常用的摄像机标定,用于确定摄像机的内外参数。该算基于摄像机的几何特性和投影原理,通过将物体上的9个已知的二维点与其对应的三维点进行匹配,求解摄像机的内外参数矩阵。 具体步骤如下: 1. 收集标定棋盘图像。在不同的角度和位置下,拍摄多张包含标定棋盘的图像。 2. 检测角点。使用OpenCV提供的角点检测算,找到每张图像中标定棋盘上的角点。 3. 提取角点。将每张图像中检测到的角点坐标保存下来,与标定棋盘上真实的三维坐标进行对应。 4. 根据已知的内外参数,计算像平面到物体平面的投影矩阵。 5. 使用求解器进行标定。将所有图像中的像素坐标与物体平面上的三维坐标进行匹配,使用OpenCV的求解器对内外参数矩阵进行求解。 6. 评估标定结果。使用重投影误差等指标评估标定结果的准确性。 7. 保存标定结果。将求解得到的摄像机内外参数矩阵保存下来,以备后续使用。 总的来说,OpenCV 9点标定通过收集多个不同角度和位置下的标定图像,找到图像中的角点,并与真实的三维坐标进行对应,最终通过求解器计算出摄像机的内外参数矩阵,用于后续的图像处理、目标检测等计算机视觉任务。 ### 回答3: OpenCV中的9点标定是用于相机姿态估计和相机校正的一种方。该算使用了至少9个已知空间点和它们在图像中的对应点来计算相机的内参矩阵和外参矩阵。 首先,我们需要准备一个已知的3D棋盘格形状,并将其固定在一个平面上。然后,我们需要采集不同位置和角度下棋盘格在图像中的对应点。为了增加精度,我们最好采集至少10个不同角度下的图像。 接下来,我们将使用OpenCV的`findChessboardCorners`函数来检测图像中的棋盘格角点,并使用`cornerSubPix`函数进行子像素精确化。然后,我们使用`calibrateCamera`函数来计算摄像机的内参矩阵和畸变系数。 最后,我们使用`solvePnP`函数来计算相机在3D空间中的姿态。这个函数将根据9个或更多的已知3D点和它们在图像中的对应点,计算相机的旋转向量和平移向量。 使用这些计算得到的内参矩阵和外参矩阵,我们可以校正畸变图像,获得准确的图像尺寸和坐标。此外,我们还可以使用相机的外参矩阵来估计相机在三维空间中的位置和朝向。 总的来说,OpenCV的9点标定是一种常用的相机校正和姿态估计方,可以用于计算相机的内参矩阵和外参矩阵,以及校正畸变图像并估计相机在三维空间中的位置和姿态。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值