OpenCV相机标定与3D重建(15)计算给定图像点对应的极线(epipolar lines)函数computeCorrespondEpilines()的使用

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

计算给定图像点对应的极线(epipolar lines)。

对于立体图像对中一个图像的点,计算这些点在另一个图像中对应的极线。

cv::computeCorrespondEpilines 是 OpenCV 库中的一个函数,用于计算给定图像点对应的极线(epipolar lines)。这个函数在立体视觉和多视图几何中非常重要,因为它帮助确定一个点在一个图像中的对应点在另一个图像中的可能位置。这有助于减少匹配问题的搜索空间。

函数原型

cpp 复制代码
void cv::computeCorrespondEpilines
(
	InputArray 	points,
	int 	whichImage,
	InputArray 	F,
	OutputArray 	lines 
)		

参数

  • 参数points:输入点。类型为 CV_32FC2 的 N×1 或 1×N 矩阵,或 vector 类型的向量。
  • 参数whichImage:包含这些点的图像索引(1 或 2)。
  • 参数F:基础矩阵,可以通过 findFundamentalMat 或 stereoRectify 函数估计得到。
  • 参数lines:输出的极线向量,对应于另一图像中的点。每条极线 ax+by+c=0 由三个数 (a, b, c) 编码。
    对于立体图像对中的一个图像中的每一个点,该函数计算其在另一个图像中对应的极线方程。

根据基础矩阵的定义(参见 findFundamentalMat),对于第一个图像中的点 l i ( 2 ) l^{(2)}_i li(2)(当 whichImage=1 时),第二个图像中的极 p i ( 1 ) p^{(1)}_i pi(1)计算为:

l i ( 2 ) = F p i ( 1 ) l^{(2)}_i = F p^{(1)}_i li(2)=Fpi(1)

反之,当 whichImage=2 时,从第二个图像中的点 l i ( 1 ) l^{(1)}_i li(1)计算第一个图像中的极线 p i ( 2 ) p^{(2)}_i pi(2)为:
l i ( 1 ) = F T p i ( 2 ) l^{(1)}_i = F^T p^{(2)}_i li(1)=FTpi(2)

极线系数定义到一个比例因子。它们被归一化以满足 a i 2 + b i 2 = 1 a_i^2+b_i^2=1 ai2+bi2=1

代码示例

cpp 复制代码
#include <iostream>
#include <opencv2/opencv.hpp>

using namespace cv;
using namespace std;

int main()
{
    // 假设有一些特征点从第一张图像中提取出来
    vector< Point2f > points1 = { Point2f( 100, 150 ), Point2f( 200, 250 ) };

    // 假设我们已经计算得到了基础矩阵 F
    Mat F = ( Mat_< double >( 3, 3 ) << 1, 0, 0, 0, 1, 0, 0, 0, 1 );  // 这里只是示例,实际的基础矩阵需要通过其他方法计算得到

    // 计算这些点在第二张图像中的对应极线
    vector< Vec3f > lines2;
    computeCorrespondEpilines( points1, 1, F, lines2 );

    // 打印结果
    for ( size_t i = 0; i < lines2.size(); ++i )
    {
        cout << "Line corresponding to point (" << points1[ i ].x << ", " << points1[ i ].y << ") is: " << lines2[ i ] << endl;
    }

    return 0;
}

运行结果

bash 复制代码
Line corresponding to point (100, 150) is: [0.5547, 0.83205, 0.005547]
Line corresponding to point (200, 250) is: [0.624695, 0.780869, 0.00312348]
相关推荐
cy_cy0029 小时前
互动滑轨屏如何优化参观动线?
科技·3d·人机交互·交互·软件构建
Coovally AI模型快速验证10 小时前
CVPR 2026|PanDA:首个多模态3D全景分割的无监督域适应框架
人工智能·3d·视觉检测·工业质检
AGV算法笔记14 小时前
CVPR 2024顶级SLAM论文精读:SplaTAM如何用3D高斯实现稠密RGB-D SLAM?
深度学习·3d·机器人视觉·slam·三维重建
hhhhhh_we15 小时前
皮肤人格的工程化实现:预颜美历如何用3D点云与循环神经网络构建数字孪生人格
图像处理·人工智能·rnn·深度学习·神经网络·3d·产品运营
Coovally AI模型快速验证15 小时前
YOLO26仓储检测实战:物体定位+有向边界框+姿态估计+实例分割,一个模型盯住整个仓库
大数据·人工智能·3d·视觉检测·工业质检
三维频道16 小时前
柔性材料3D数字化:蓝光扫描在内衣胸垫设计与质检中的应用
人工智能·3d·逆向工程·蓝光3d扫描仪·服装数字化·内衣设计·柔性材料检测
三维频道18 小时前
岩土力学微观探索:蓝光3D扫描在断面粗糙度分析中的应用
3d·新拓三维·xtom·蓝光3d扫描仪·岩土力学·结构面粗糙度·jrc
SunnyDays101118 小时前
如何使用 C# 转换 PowerPoint 为 HTML:完整指南
人工智能·opencv·计算机视觉·c#
不知名的老吴18 小时前
渲染器Corona 11.2 for 3ds Max全流程下载与安装指南
3d
LateFrames1 天前
5 种 3D 模型文件格式比对( .asc / .stl / .obj / .ply / .3mf )
3d