【摄像头标定】使用opencv进行双目摄像头的标定及矫正(python)

warning: 这篇文章距离上次修改已过193天,其中的内容可能已经有所变动。



import numpy as np
import cv2
import glob
 
# 准备对象点,如 (0,0,0), (1,0,0), (2,0,0) ....,(6,5,0)
objp = np.zeros((6*7,3), np.float32)
objp[:,:2] = np.mgrid[0:7,0:6].T.reshape(-1,2)
 
# 准备一个用于存储所有图片对象点和图像点的空列表
objpoints = [] # 3d 点
imgpoints_l = [] # 左图像的 2d 点
imgpoints_r = [] # 右图像的 2d 点
 
images_left = glob.glob('left/*.jpg')  # 获取左图像文件列表
images_right = glob.glob('right/*.jpg') # 获取右图像文件列表
 
for img_left, img_right in zip(images_left, images_right):
    img_l = cv2.imread(img_left)
    img_r = cv2.imread(img_right)
    
    gray_l = cv2.cvtColor(img_l, cv2.COLOR_BGR2GRAY)
    gray_r = cv2.cvtColor(img_r, cv2.COLOR_BGR2GRAY)
    
    # 寻找像素特征
    ret_l, corners_l = cv2.findChessboardCorners(gray_l, (7,6), None)
    ret_r, corners_r = cv2.findChessboardCorners(gray_r, (7,6), None)
    
    # 如果找到足够的特征点,将它们添加到对应的列表中
    if ret_l and ret_r:
        objpoints.append(objp)
        imgpoints_l.append(corners_l)
        imgpoints_r.append(corners_r)
        # 绘制特征点
        cv2.drawChessboardCorners(img_l, (7,6), corners_l, ret_l)
        cv2.drawChessboardCorners(img_r, (7,6), corners_r, ret_r)
        # 展示图片
        # cv2.imshow('img_l', img_l)
        # cv2.imshow('img_r', img_r)
        # cv2.waitKey(500)
 
cv2.destroyAllWindows()
 
# 标定双目摄像头
ret_l, cameraMatrix_l, distCoeffs_l, rvecs_l, tvecs_l = cv2.calibrateCamera(objpoints, imgpoints_l, gray_l.shape[::-1], None, None)
ret_r, cameraMatrix_r, distCoeffs_r, rvecs_r, tvecs_r = cv2.calibrateCamera(objpoints, imgpoints_r, gray_r.shape[::-1], None, None)
 
# 获取立体校正的参数
(roi_l, roi_r) = cv2.stereoCalibrate(objpoints, imgpoints_l, imgpoints_r, cameraMatrix_l, distCoeffs_l, cameraMatrix_r, distCoeffs_r, gray_l.shape[::-1][1:], None, None)
 
# 获取立体校正映射
map_lx, map_ly = cv2.initUndistortRectifyMap(cameraMatrix_l, distCoeffs_l, None, cameraMatrix_l, gray_l.shape[::-1], cv2.CV_16SC2)
map_rx, map_ry = cv2.initUndistortRectifyMap(cameraMatrix_r, distCoeffs_r, None, cameraMatrix_r, gray_r.shape[::-1], cv2.CV_16SC2)
 
# 立体校正
img_l_rect = cv2.remap(img_l, map_lx, map_ly,
最后修改于:2024年08月13日 09:34

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日