OpenCV相机标定与3D重建(19)将本质矩阵分解为旋转矩阵和平移向量函数decomposeEssentialMat()的使用

server/2024/12/17 12:57:27/

操作系统:ubuntu22.04

  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

将本质矩阵分解为可能的旋转和平移。
cv::decomposeEssentialMat 是 OpenCV 库中的一个函数,用于将本质矩阵(Essential Matrix)分解为旋转矩阵(Rotation Matrices)和平移向量(Translation Vector)。该函数能够从给定的本质矩阵中提取出两个可能的旋转矩阵和一个单位长度的平移向量,这些信息对于双视图几何分析非常重要。

函数原型

void cv::decomposeEssentialMat	
(InputArray 	E,OutputArray 	R1,OutputArray 	R2,OutputArray 	t 
)		

参数

  • 参数E:输入的本质矩阵。
  • 参数R1:一个可能的旋转矩阵。
  • 参数R2:另一个可能的旋转矩阵。
  • 参数t:一个可能的平移向量。

此函数使用奇异值分解(SVD decomposition)[115] 来分解本质矩阵 E。通常,E 的分解存在四种可能的姿态:
[R1, t]
[R1, -t]
[R2, t]
[R2, -t]
如果本质矩阵 E 给出了图像点 p1 在第一张图像和 p2 在第二张图像之间的极线约束
[ p 2 ; 1 ] T A − T E A − 1 [ p 1 ; 1 ] = 0 [p_2; 1]^T A^{-T} E A^{-1} [p_1; 1] = 0 [p2;1]TATEA1[p1;1]=0
[p1;1]=0,那么上述任一元组 [R1, t], [R1, -t], [R2, t], [R2, -t] 都是从第一个相机坐标系到第二个相机坐标系的基变换。然而,通过分解 E,只能获得平移的方向。因此,返回的平移向量 t 是单位长度的。

代码示例


#include <iostream>
#include <opencv2/opencv.hpp>int main()
{// 假设我们已经得到了本质矩阵 Ecv::Mat E = ( cv::Mat_< double >( 3, 3 ) << 0.998, -0.062, 0.007, 0.062, 0.998, -0.05, 0.007, 0.05, 0.999 );// 创建输出容器cv::Mat R1, R2, t;// 分解本质矩阵cv::decomposeEssentialMat( E, R1, R2, t );// 打印结果std::cout << "Rotation Matrix R1:\n" << R1 << "\n";std::cout << "Rotation Matrix R2:\n" << R2 << "\n";std::cout << "Translation Vector t:\n" << t << "\n";return 0;
}

运行结果

Rotation Matrix R1:
[0.4708471753884005, -0.7242019696996511, -0.5038198532331875;0.7242019696996562, -0.008852511933919548, 0.6895311016303745;-0.50381985323318, -0.6895311016303798, 0.5203003126776802]
Rotation Matrix R2:
[0.5574059775807584, 0.6671670718337697, -0.4941524809388223;-0.6671670718337639, 0.005688913976374822, -0.7448863903432057;-0.4941524809388299, 0.7448863903432006, 0.4482829363956166]
Translation Vector t:
[0.7170262034853253;0.03977183650238774;-0.6959106440748325]

http://www.ppmy.cn/server/150902.html

相关文章

python paddle实现语音识别、语音合成

1. 安装vs c++编译环境 对于 Windows 系统,需要安装 Visual Studio 来完成 C++ 编译环境的安装。 Microsoft C++ Build Tools - Visual Studio 2. 安装conda conda create --prefix=D:\conda_envs\paddle_env python=3.9 conda activate D:\conda_envs\paddle_env 4. 安装…

【论文笔记】CLIP-guided Prototype Modulating for Few-shot Action Recognition

&#x1f34e;个人主页&#xff1a;小嗷犬的个人主页 &#x1f34a;个人网站&#xff1a;小嗷犬的技术小站 &#x1f96d;个人信条&#xff1a;为天地立心&#xff0c;为生民立命&#xff0c;为往圣继绝学&#xff0c;为万世开太平。 基本信息 标题: CLIP-guided Prototype Mo…

【JavaSE基础】第十七章:反射+设计模式

一、反射 1.反射(Reflection)&#xff1a;允许在程序运行状态中&#xff0c;可以获取任意类中的属性和方法&#xff0c;并且可以操作任意对象内部的属性和方法&#xff0c;这种动态获取类的信息及动态操作对象的属性和方法对应的机制称为反射机制。 2.类对象 和 类的对象(实例…

Python单例模式的优雅实现:元类与装饰器的结合

Python单例模式的优雅实现:元类与装饰器的结合 引言 单例模式是一种常用的设计模式,旨在确保一个类只有一个实例,并提供一个全局访问点。在多线程环境下,如何保证单例的线程安全是一个重要的问题。本文将深入探讨Python中使用元类和装饰器实现线程安全单例模式的两种方式…

Vue Web开发(五)

1. axios axios官方文档 异步库axios和mockjs模拟后端数据&#xff0c;axios是一个基于promise的HTTP库&#xff0c;使用npm i axios。在main.js中引入&#xff0c;需要绑定在Vue的prototype属性上&#xff0c;并重命名。   &#xff08;1&#xff09;main.js文件引用 imp…

使用Python实现手写数字识别

引言: 手写数字识别是“光学字符识别技术”(简称OCR)的一个分支,它研究的对象是:如何利用电子计算机自动辨认人手写在纸张上的阿拉伯数字。 在整个OCR领域中,最为困难的就是脱机手写字符的识别。到目前为止,尽管人们在脱机手写英文、汉字识别的研究中已取得很多可喜成就…

vue使用pdfh5.js插件,显示pdf文件白屏

pdfh5&#xff0c;展示文件白屏&#xff0c;无报错 实现效果图解决方法(降版本)排查问题过程发现问题查找问题根源1、代码写错了&#xff1f;2、预览文件流的问题&#xff1f;3、pdfh5插件更新了&#xff0c;我的依赖包没更新&#xff1f;4、真相大白 彩蛋 实现效果图 解决方法…

ChatGPT突然全球宕机,OpenAI致歉:并查明原因,正积极修复

ChatGPT突然全球宕机&#xff0c;OpenAI致歉&#xff1a;并查明原因&#xff0c;正积极修复 在 2024 年 12 月 12 日上午的北京时间时段内&#xff0c;ChatGPT突发全球宕机&#xff0c;OpenAI致歉&#xff1a;已查明原因&#xff0c;正积极修复 官方证实了其备受瞩目的聊天机器…