OpenCV相机标定与3D重建(16)将点从齐次坐标转换为非齐次坐标函数convertPointsFromHomogeneous()的使用

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

算法描述

cv::convertPointsFromHomogeneous 是 OpenCV 库中的一个函数,用于将点从齐次坐标(homogeneous coordinates)转换为非齐次坐标(Euclidean coordinates)。在计算机视觉和图形学中,齐次坐标是一种常用的表示方法,它允许使用统一的数学框架处理平移、旋转和其他变换。

函数原型

cpp 复制代码
void cv::convertPointsFromHomogeneous
(
	InputArray 	src,
	OutputArray 	dst 
)	

参数

  • 参数src:输入的点集,通常是齐次坐标形式的点。这些点可以存储在一个 cv::Mat 或 std::vectorcv::Vec 中,每个点是一个长度为 n+1 的向量,其中 n 是空间维度(例如,2D 空间中齐次坐标为 (x, y, w),3D 空间中为 (x, y, z, w))。
  • 参数dst:输出的点集,转换后的非齐次坐标形式的点。每个点是一个长度为 n 的向量,表示 Euclidean 坐标(例如,2D 空间中为 (X, Y),3D 空间中为 (X, Y, Z))。转换公式为X=x/w, Y=y/w,对于 3D 点还包括Z=z/w。

代码示例

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

using namespace cv;
using namespace std;

int main()
{
    // 定义一些齐次坐标的点
    vector< Vec3f > points_homogeneous = { Vec3f( 100, 200, 1 ), Vec3f( 200, 400, 2 ) };

    // 创建一个用于存储转换后点的容器
    vector< Point2f > points_euclidean;

    // 执行转换
    convertPointsFromHomogeneous( points_homogeneous, points_euclidean );

    // 打印结果
    for ( size_t i = 0; i < points_euclidean.size(); ++i )
    {
        cout << "Point " << i + 1 << ": (" << points_euclidean[ i ].x << ", " << points_euclidean[ i ].y << ")" << endl;
    }

    return 0;
}

运行结果

bash 复制代码
Point 1: (100, 200)
Point 2: (100, 200)
相关推荐
彭祥.4 小时前
Jetson边缘计算主板:Ubuntu 环境配置 CUDA 与 cudNN 推理环境 + OpenCV 与 C++ 进行目标分类
c++·opencv·分类
Tony沈哲5 小时前
macOS 上为 Compose Desktop 构建跨架构图像处理 dylib:OpenCV + libraw + libheif 实践指南
opencv·算法
SDUERPANG10 小时前
三维目标检测|Iou3D 代码解读一
人工智能·目标检测·3d
视觉人机器视觉14 小时前
Visual Studio2022和C++opencv的配置保姆级教程
c++·opencv·visual studio
PyAIExplorer15 小时前
图像旋转:从原理到 OpenCV 实践
人工智能·opencv·计算机视觉
PyAIExplorer20 小时前
OpenCV 图像操作:颜色识别、替换与水印添加
人工智能·opencv·计算机视觉
whoarethenext1 天前
使用 C++/OpenCV 和 MFCC 构建双重认证智能门禁系统
开发语言·c++·opencv·mfcc
jndingxin1 天前
OpenCV CUDA模块设备层-----高效地计算两个 uint 类型值的带权重平均值
人工智能·opencv·计算机视觉
晨同学03271 天前
opencv的颜色通道问题 & rgb & bgr
人工智能·opencv·计算机视觉
看到我,请让我去学习1 天前
OpenCV开发-初始概念
人工智能·opencv·计算机视觉