OpenCV之cv::undistort

在 OpenCV 中,cv::undistort 函数用于校正畸变的图像。它的基本形式如下:

void undistort(InputArray src, OutputArray dst, InputArray cameraMatrix, InputArray distCoeffs, InputArray newCameraMatrix = noArray());

参数解释:

  1. src:输入图像。这是需要进行畸变校正的原始图像。

  2. dst:输出图像。这是校正后的图像,应当预先分配空间。

  3. cameraMatrix:摄像机内参数矩阵(3x3)。这是摄像机的内部参数矩阵,包括焦距、主点的位置等信息。可以通过 cv::calibrateCamera 函数从一组标定图像中获取。

  4. distCoeffs:畸变系数。这是一个包含畸变系数的向量,通常有5个或更多参数,用于描述径向和切向畸变。

  5. newCameraMatrix:新的摄像机内参数矩阵(可选)。如果指定了这个参数,函数将使用它来重映射输出图像。默认情况下,使用输入的 cameraMatrix 进行校正。

参数详解:

  • 摄像机内参数矩阵 (cameraMatrix):这是一个 3x3 的矩阵,通常包含以下参数:

    • fx:焦距在 x 方向上的缩放因子。
    • fy:焦距在 y 方向上的缩放因子。
    • cx:主点在 x 方向上的偏移量。
    • cy:主点在 y 方向上的偏移量。
    • 1:固定为1。

    例如,一个典型的摄像机内参数矩阵可能是:

    [ fx  0  cx ]
    [ 0   fy cy ]
    [ 0   0   1 ]
    
     
  • 畸变系数 (distCoeffs):这个向量通常包含以下参数:

    • k1, k2, p1, p2, k3:径向畸变和切向畸变的系数。

distCoeffs 是用于描述摄像机畸变的系数向量。畸变是由于摄像机透镜的物理特性引起的,会导致图像中的直线弯曲或图像的形状发生变化。为了对图像进行校正,需要使用畸变系数来消除或减小这种畸变。

distCoeffs 通常包含以下参数:

  1. 径向畸变系数(Radial Distortion Coefficients):径向畸变是由于透镜形状与理想平面透镜之间的差异而导致的。它使得离光轴越远的像素比离光轴近的像素更远,从而产生了图像中的弯曲现象。径向畸变系数通常有两个或三个参数:

    • k1:主要径向畸变系数,控制着一阶径向畸变的影响。
    • k2:次要径向畸变系数,控制着二阶径向畸变的影响。
    • k3:三阶径向畸变系数,控制着更高阶径向畸变的影响。
  2. 切向畸变系数(Tangential Distortion Coefficients):切向畸变是由于透镜与图像平面之间不是完全平行而引起的。它会引起图像中的像素在水平和垂直方向上的扭曲。切向畸变系数通常有两个参数:

    • p1:第一个切向畸变系数,控制着水平方向上的切向畸变。
    • p2:第二个切向畸变系数,控制着垂直方向上的切向畸变。

这些畸变系数的值可以通过使用摄像机标定技术从一组畸变图像中获得。在标定过程中,通过对已知形状的标定板进行观察,计算出这些系数的值。然后,这些系数可以用于校正从相同摄像机拍摄的其他图像。

通过将畸变系数传递给 cv::undistort 函数,可以对图像进行畸变校正,以获得更准确、形状更正常的图像。

在讨论摄像机的径向畸变时,“一阶”、“二阶”和“三阶”是指畸变模型中不同阶次的多项式项。这些项用于描述图像中径向失真的复杂程度。具体来说:

  1. 一阶径向畸变 (First-order Radial Distortion)

    • 由系数 k1 控制,主要描述最基本的径向畸变。畸变量与半径的平方成正比。
    • 数学表达式中的一阶项:k1 * r^2,其中 r 是从图像中心(也称为主点)到当前像素的距离。
  2. 二阶径向畸变 (Second-order Radial Distortion)

    • 由系数 k2 控制,描述更复杂的径向畸变。畸变量与半径的四次方成正比。
    • 数学表达式中的二阶项:k2 * r^4
  3. 三阶径向畸变 (Third-order Radial Distortion)

    • 由系数 k3 控制,进一步描述了极端情况下的畸变。畸变量与半径的六次方成正比。
    • 数学表达式中的三阶项:k3 * r^6

这些项可以组合在一起,以提供对不同复杂程度的径向畸变的更精确描述。具体的畸变校正公式可以表示为:

[ x_{\text{corrected}} = x \cdot (1 + k1 \cdot r^2 + k2 \cdot r^4 + k3 \cdot r^6) ] [ y_{\text{corrected}} = y \cdot (1 + k1 \cdot r^2 + k2 \cdot r^4 + k3 \cdot r^6) ]

这里 ( (x, y) ) 是未校正的像素坐标,( (x_{\text{corrected}}, y_{\text{corrected}}) ) 是校正后的像素坐标,( r ) 是像素到图像中心的距离。

切向畸变 (Tangential Distortion)

切向畸变由两个系数 p1p2 控制,描述由于摄像机镜头与图像平面不完全平行导致的畸变。切向畸变校正公式如下:

[ x_{\text{corrected}} = x + [2 \cdot p1 \cdot x \cdot y + p2 \cdot (r^2 + 2 \cdot x^2)] ] [ y_{\text{corrected}} = y + [p1 \cdot (r^2 + 2 \cdot y^2) + 2 \cdot p2 \cdot x \cdot y] ]

综合畸变模型

综合考虑径向和切向畸变的校正公式如下:

[ x_{\text{corrected}} = x \cdot (1 + k1 \cdot r^2 + k2 \cdot r^4 + k3 \cdot r^6) + [2 \cdot p1 \cdot x \cdot y + p2 \cdot (r^2 + 2 \cdot x^2)] ] [ y_{\text{corrected}} = y \cdot (1 + k1 \cdot r^2 + k2 \cdot r^4 + k3 \cdot r^6) + [p1 \cdot (r^2 + 2 \cdot y^2) + 2 \cdot p2 \cdot x \cdot y] ]

通过上述公式,可以将包含畸变的像素坐标转换为校正后的像素坐标,从而消除摄像机拍摄图像中的畸变。

使用示例:

cv::Mat src = cv::imread("input_image.jpg", cv::IMREAD_COLOR);
cv::Mat dst;cv::Mat cameraMatrix; // 从标定结果中获取
cv::Mat distCoeffs;   // 从标定结果中获取cv::undistort(src, dst, cameraMatrix, distCoeffs);cv::imshow("Original Image", src);
cv::imshow("Undistorted Image", dst);
cv::waitKey(0);
 

在这个示例中,我们加载了一张图像 input_image.jpg,然后使用 cv::undistort 函数对它进行畸变校正,并显示校正前后的图像。

畸变校正是摄影测量中非常重要的步骤,可以提高图像处理和测量的精度。

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

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

相关文章

Vue与Web标准:如何在Vue项目中更好地利用Web标准,例如Web Components、PWA

理解Vue和Web标准 Vue.js 的定义、优点与缺点 定义:Vue.js 是一种轻量级的前端框架,它被设计为易于上手和集成。Vue 的核心库只关注视图层,使得 Vue 可以轻松地和其它库或已有项目整合。 优点: 易学易用:Vue.js 的 API 相对简单直观,学习曲线平缓。 灵活:Vue.js 提供了…

每天一个数据分析题(三百八十三)- 聚类

关于忽略自相关可以带来什么问题描述错误的是? A. 均方误差可能严重低估误差项的方差 B. 可能导致高估检验统计量t值,致使本不显著的变量变得显著了 C. 参数估计值的最小方差无偏性不再成立 D. 参数估计值的最小方差无偏性仍成立 数据分析认证考试介…

docker download failed after attempts=6:dial tcp IP:Port i/o timeout

国内服务器使用docker拉取镜像出现下载超时问题,直觉问题是网络不通,ping相关的域名或IP发现是无法ping通的,鉴于此本文提供两种方法: 1)添加公开的docker加速代理(下文的代理一段时间后可能失效): a&…

详解 HBase 的架构和基本原理

一、基本架构 StoreFile:保存实际数据的物理文件,StoreFile 以 HFile 的格式 (KV) 存储在 HDFS 上。每个 Store 会有一个或多个 StoreFile(HFile),数据在每个 StoreFile 中都是有序的MemStore:写缓存&#…

前端从零配置 基于 TypeScript 的 Jest 单元测试环境,手把手教程

写在前面 本教程从零开始而且不是基于一个 Vue 或者 React 框架,打破测试环境配置的心里障碍,如果从零都可以配置成功,上个框架原理和方法也会大差不差。 本教程基于 yarn 来进行安装,如果使用使用 npm 和 pnpm 的话方法类似&am…

【YOLOv5/v7改进系列】引入特征融合网络——ASFYOLO

一、导言 ASF-YOLO结合空间和尺度特征以实现精确且快速的细胞实例分割。在YOLO分割框架的基础上,通过引入尺度序列特征融合(SSFF)模块来增强网络的多尺度信息提取能力,并利用三重特征编码器(TFE)模块融合不同尺度的特征图以增加细节信息。此外&#xff…

信息打点web篇----web后端源码专项收集

前言 欢迎来到我的博客 个人主页:北岭敲键盘的荒漠猫-CSDN博客 专栏描述:因为第一遍过信息收集的时候,没怎么把收集做回事 导致后来在实战中,遭遇资产获取少,可渗透点少的痛苦,如今决定 从头来过,全面全方位…

手把手教你实现条纹结构光三维重建(3)——相机投影仪标定

我们都知道,投影仪其实就是个反向相机,如果我们了解双目标定的原理,那么相机和投影仪的标定就不难,关键是我们怎么得到投影仪在图像特征点(比如棋盘格角点)上的像素位置。 投影仪也类似于一个cmos&#xf…

WebSocket实现消息实时通知

参考文档:万字长文,一篇吃透WebSocket:概念、原理、易错常识、动手实践、WebSocket 教程 1 背景 有一个需求,需要实现实时通信的功能,如果有新消息,后端会主动发送请求告知前端有新消息,需要前…

改进YOLOv7 | 在 ELAN 模块中添加【Triplet】【SpatialGroupEnhance】【NAM】【S2】注意力机制 | 附详细结构图

改进 YOLOv7 | 在 ELAN 模块中添加【Triplet】【SpatialGroupEnhance】【NAM】【S2】注意力机制:中文详解 1. 简介 YOLOv7 是目前主流的目标检测算法之一,具有速度快、精度高的特点。但 YOLOv7 的原始模型结构中缺乏注意力机制,导致模型对全…

Matlab基础语法:变量和数据类型,基本运算,矩阵和向量,常用函数,脚本文件

目录 一、变量和数据类型 二、基本运算 三、矩阵和向量 四、常用函数 五、脚本文件 六、总结 一、变量和数据类型 Matlab 支持多种数据类型,包括数值类型、字符类型和逻辑类型。掌握这些基本的变量和数据类型,是我们进行数学建模和计算的基础。 数…

嵌入式软件stm32面试

一、STM32的内核型号有哪些? STM32系列是STMicroelectronics(意法半导体)生产的基于ARM Cortex-M内核的微控制器产品线。这些产品按照不同的内核架构和性能特点分为了主流产品、超低功耗产品和高性能产品。 1.1 主流产品 STM32F0 系列&…

利用sortablejs实现拖拽排序

import Sortable from "sortablejs";created() {//禁止火狐拖拽进行搜索document.body.ondrop function(event){event.preventDefault();event.stopPropagation();}}// 打开对话框的时候调用下openCustomDialog(){this.rowDrop()}// 行拖拽 rowDrop() {this.$nextTi…

Linux工具(包含sudo提权与vim快捷配置)

目录 什么是软件包 查看软件包 如何安装软件 1.官方yum源下载 2.扩展yum源下载 如何卸载软件 补充知识如何将普通用户加入白名单 补充知识rzsz vim编辑器 1.命令模式(进入默认为这个模式)用户所有的输入都会被当成命令 2.插入模式 3.底行模…

SpringCloud Maven多模块项目导包

目录 一、父项目配置 二、配置子项目 三、Maven执行 四、运行Jar包 一、父项目配置 所有父项目均需确保配置了 <packaging>pom</packaging> 因为Maven某人的打包方式是 <packaging>jar</packaging> 二、配置子项目 仅在有SpringBoot启动类的…

Qt Designer 中设置信号与槽,QT5的四种编辑模式

目录 QT5的四种编辑模式 Qt Designer 中设置信号与槽 Qt Designer 中设置信号与槽 QT5的四种编辑模式 在QT5中,特别是在使用Qt Designer进行界面设计时,存在多种编辑模式以满足不同的开发需求。以下是对QT5中四种主要编辑模式的详细解释: 控件编辑模式(Edit Widgets):…

速盾:cdn高防免备案

云计算和互联网技术的发展&#xff0c;带来了无数便利和机遇&#xff0c;但也带来了各种网络安全威胁。网站被黑、DDoS攻击、敏感信息泄露等问题&#xff0c;给企业和个人带来了巨大的损失和风险。因此&#xff0c;保护网络安全成为了当务之急。 CDN&#xff08;Content Deliv…

【PHP项目实战训练】——使用thinkphp框架对数据进行增删改查功能

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;开发者-曼亿点 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 曼亿点 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a…

Python网页爬虫爬取豆瓣Top250电影数据——Xpath数据解析

Python网页爬虫爬取豆瓣Top250电影数据——Xpath数据解析 将使用Python网页爬虫爬取豆瓣电影Top250的电影数据&#xff0c;网页解析方法使用xpath。 获取数据后会将数据保存到CSV文件中。一、分析网页&#xff0c;初步获取信息 1.1 查看原页面信息 首先打开豆瓣Top250电影页…

操作系统期末快速复习(概念)

文章目录 第一章&#xff1a;操作系统引论操作系统的目标是什么&#xff1f;分时系统是什么&#xff1f;实时系统是什么&#xff1f;分时系统和实时系统的比较操作系统的基本特征是什么&#xff1f;操作系统的主要功能&#xff1f;***重要第二章&#xff1a;进程管理程序的顺序…