Opencv相机标定角点提取算法之角点排序

相机标定角点提取算法之角点排序

相机标定:常用于单目、双目标定过程
标定原理可参考:
1.相机标定原理:相机成像+单应性变换+相机标定+立体校正
2.单目、双目标定Opencv实现:Opencv例程之双目相机标定
3.双目相机误差估计:三位重建之双目相机误差分析

已知很奇怪Opencv的标定算法中角点提取中排序一直很好,究其原理:
角点分布角度各有不同,它会将n*n个角点呈矩形分布的角点首先进行透视变换,将所有的点映射到一个标准的矩形区域下,然后再对各个角点进行统计排序

在这里插入图片描述

自己生成了一些点,尝试着试了一下效果,图1是角点的来南通与,图2是包含所有点的凸包,我首先想先通过凸包找出所有角点区域的四个端点,然后对这四个点进行透视变换,当然需要有一组透视变换的基准点(4),这个可以在图3中看到,最后在图4中可以看到透视变换的结果,当然,从下图中看

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
以下是使用 OpenCV 进行相机标定角点检测代码,其中假设使用的棋盘格为 9x6 的: ```python import numpy as np import cv2 # 棋盘格尺寸(单位:毫米) CHESSBOARD_SQUARE_SIZE = 20 # 棋盘格大小 CHESSBOARD_SIZE = (9, 6) # 获取棋盘格角点 def get_chessboard_corners(image): gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) ret, corners = cv2.findChessboardCorners(gray, CHESSBOARD_SIZE, None) if ret: corners = cv2.cornerSubPix(gray, corners, (11, 11), (-1, -1), criteria=(cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_MAX_ITER, 30, 0.001)) return ret, corners # 读取一组图片进行标定 def calibrate_camera(images): # 预期的标定角点数量 expected_corners_count = CHESSBOARD_SIZE[0] * CHESSBOARD_SIZE[1] # 准备用于标定的数据 object_points = [] image_points = [] # 准备物体坐标系中的点 objp = np.zeros((expected_corners_count, 3), np.float32) objp[:, :2] = np.mgrid[0:CHESSBOARD_SIZE[0], 0:CHESSBOARD_SIZE[1]].T.reshape(-1, 2) * CHESSBOARD_SQUARE_SIZE # 遍历每张图片进行处理 for image in images: # 获取角点 ret, corners = get_chessboard_corners(image) if not ret: continue # 确保找到了预期数量的角点 if len(corners) != expected_corners_count: continue # 保存物体坐标系中的点和图像平面中的点 object_points.append(objp) image_points.append(corners) # 进行相机标定 ret, mtx, dist, rvecs, tvecs = cv2.calibrateCamera(object_points, image_points, images[0].shape[:2], None, None) return ret, mtx, dist, rvecs, tvecs ``` 这段代码首先定义了棋盘格的尺寸和大小,然后定义了 `get_chessboard_corners` 函数用于获取图像中的棋盘格角点。这里使用了 OpenCV 的 `findChessboardCorners` 方法来找到棋盘格,然后使用 `cornerSubPix` 方法对角点进行亚像素级别的精确化处理。 接下来定义了 `calibrate_camera` 函数来进行相机标定。这个函数首先准备了用于标定的数据,包括物体坐标系中的点和图像平面中的点。然后遍历输入的图片,使用 `get_chessboard_corners` 函数获取角点,并且将找到的角点保存到物体坐标系中的点和图像平面中的点中。最后使用 `calibrateCamera` 方法进行相机标定,得到相机的内参和外参。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

明月醉窗台

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值