【opencv】图像畸变校正

接上篇文章:【鱼眼+普通相机】相机标定

附代码:

方法一:

使用cv2.undistort

python 复制代码
"""
    Create May 11, 2024
    @author Wang Jiajun
"""

import cv2
import numpy as np


def correct(img,camera_file='E:/calib_yaml/ship_calib.yaml'):
    """
    矫正图像,去除畸变
        img: 输入图像
        camera_file: 相机参数文件
        return: 矫正后的图像
    """
    fs = cv2.FileStorage(camera_file, cv2.FILE_STORAGE_READ)
    camera_matrix = fs.getNode("camera_matrix").mat()
    dist_coeffs = fs.getNode("dist_coeffs").mat()  # 畸变参数--顺序很重要!!!:k1,k2,p1,p2,k3
    resolution = fs.getNode("resolution").mat()  # 图像分辨率
    imSize = (resolution[0][0], resolution[1][0])
    fs.release()

    # 矫正图像
    img_distort = cv2.undistort(img, np.array(camera_matrix), np.array(dist_coeffs))
    return img_distort 


if __name__ == '__main__':
    camera_file = 'E:/calib_yaml/ship_calib.yaml'
    video = cv2.VideoCapture(0)
    while True:
        ret, img = video.read()
        # 3. 矫正图像
        img = cv2.resize(img, (640, 480))
        cv2.putText(img, "Press q to exit", (20, 30), cv2.FONT_HERSHEY_SIMPLEX, 0.6, (255, 200, 0), 2)
        img_distort = cv2.correct(img, camera_file )
        # 4. 显示原图和矫正后的图像
        cv2.imshow('img_original', img)
        cv2.imshow('img_distort', img_distort)
        key = cv2.waitKey(1)
        # 5. 按q退出
        if key & 0xFF == ord('q'):
            break
    # 6. 关闭窗口
    video.release()
    cv2.destroyAllWindows()

方法二:

使用cv2.initUndistortRectifyMap建立映射关系,就不用每次读取内参了,速度更快。

python 复制代码
"""
    Create May 11, 2024
    @author Wang Jiajun
"""

import cv2
import numpy as np


def correct(camera_file='E:/calib_yaml/ship_calib.yaml'):
    """
    矫正图像,去除畸变
        img: 输入图像
        camera_file: 相机参数文件
        return: 矫正后的图像
    """
    fs = cv2.FileStorage(camera_file, cv2.FILE_STORAGE_READ)
    camera_matrix = fs.getNode("camera_matrix").mat()
    dist_coeffs = fs.getNode("dist_coeffs").mat()  # 畸变参数--顺序很重要!!!:k1,k2,p1,p2,k3
    resolution = fs.getNode("resolution").mat()  # 图像分辨率
    imSize = (resolution[0][0], resolution[1][0])
    fs.release()

    # 矫正图像
    new_camera_matrix, roi = cv2.getOptimalNewCameraMatrix(np.array(camera_matrix), np.array(dist_coeffs),
                                                           imSize, 0,
                                                           imSize)
    map1, map2 = cv2.initUndistortRectifyMap(np.array(camera_matrix), np.array(dist_coeffs), None, new_camera_matrix,
                                             imSize, cv2.CV_32FC1)
    # img_distort = cv2.undistort(img, np.array(camera_matrix), np.array(dist_coeffs))
    return map1, map2


if __name__ == '__main__':
    camera_file = 'E:/calib_yaml/ship_calib.yaml'
    map1, map2 = correct(camera_file)
    video = cv2.VideoCapture(0)
    while True:
        ret, img = video.read()
        # 3. 矫正图像
        img = cv2.resize(img, (640, 480))
        cv2.putText(img, "Press q to exit", (20, 30), cv2.FONT_HERSHEY_SIMPLEX, 0.6, (255, 200, 0), 2)
        img_distort = cv2.remap(img, map1, map2, cv2.INTER_LINEAR)
        # 4. 显示原图和矫正后的图像
        cv2.imshow('img_original', img)
        cv2.imshow('img_distort', img_distort)
        key = cv2.waitKey(1)
        # 5. 按q退出
        if key & 0xFF == ord('q'):
            break
    # 6. 关闭窗口
    video.release()
    cv2.destroyAllWindows()
相关推荐
夜幕龙3 分钟前
ViT 模型介绍(三)——简单实战项目
人工智能·深度学习·transformer
wangtaohappy7 分钟前
AI写代码工具赋能前端开发:高效学习与应用AI前端框架
前端·人工智能·学习·前端框架
HHUCESTA12 分钟前
2025年信息科学与工程学院科协机器学习介绍——机器学习基本模型介绍
人工智能·机器学习
wangtaohappy39 分钟前
AI写代码工具ScriptEcho:赋能数据分析,驱动精准营销
前端·人工智能·信息可视化·数据分析
歌刎42 分钟前
DeepSeek开源周Day1:FlashMLA引爆AI推理性能革命!
人工智能·深度学习·nlp·aigc·deepseek
AWS官方合作商44 分钟前
DeepSeek开源FlashMLA:颠覆大模型训练效率的新一代技术解析
人工智能·ai·开源
小宇爱1 小时前
48、深度学习-自学之路-自己搭建深度学习框架-9、添加嵌入层为了浮现RNN的神经网络使用框架。
人工智能·深度学习
Ai多利1 小时前
登上Nature子刊!因果机器学习起步A会!
人工智能·机器学习·因果推断
CS创新实验室1 小时前
《机器学习数学基础》补充资料:欧几里得空间的推广
人工智能·机器学习·机器学习数学基础
阿正的梦工坊2 小时前
Fisher信息矩阵(Fisher Information Matrix, FIM)与自然梯度下降:机器学习中的优化利器
人工智能·机器学习·矩阵