当前位置: 首页 > news >正文

OpenCV相机标定与3D重建(21)投影矩阵分解函数decomposeProjectionMatrix()的使用

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

算法描述

将投影矩阵分解为旋转矩阵和相机内参矩阵。

cv::decomposeProjectionMatrix 是 OpenCV 库中的一个函数,用于将投影矩阵(Projection Matrix)分解为相机内参矩阵(Camera Matrix)、旋转矩阵(Rotation Matrix)和平移向量(Translation Vector),以及可选的绕各轴的旋转矩阵和欧拉角。这个函数对于理解相机在三维空间中的位置和姿态非常有用。

函数原型

void cv::decomposeProjectionMatrix
(InputArray 	projMatrix,OutputArray 	cameraMatrix,OutputArray 	rotMatrix,OutputArray 	transVect,OutputArray 	rotMatrixX = noArray(),OutputArray 	rotMatrixY = noArray(),OutputArray 	rotMatrixZ = noArray(),OutputArray 	eulerAngles = noArray() 
)		

参数

  • 参数projMatrix:3x4 输入投影矩阵P。

  • 参数cameraMatrix:输出 3x3 相机内参矩阵 A = [ f x 0 c x 0 f y c y 0 0 1 ] \textbf A = \begin{bmatrix} f_x & 0 & c_x \\ 0 & f_y & c_y \\ 0 & 0 & 1 \end{bmatrix} A= fx000fy0cxcy1

  • 参数rotMatrix:输出 3x3 外部旋转矩阵R。

  • 参数transVect:输出 4x1 平移向量T。

  • 参数rotMatrixX:可选的绕 x 轴的 3x3 旋转矩阵。

  • 参数rotMatrixY:可选的绕 y 轴的 3x3 旋转矩阵。

  • 参数rotMatrixZ:可选的绕 z 轴的 3x3 旋转矩阵。

  • 参数eulerAngles:可选的包含三个旋转欧拉角(以度为单位)的三元素向量。

该函数计算一个投影矩阵分解为校准矩阵(相机内参矩阵)、旋转矩阵和相机位置。它还可以选择性地返回三个旋转矩阵,每个轴一个,以及三个欧拉角,这些可以在 OpenGL 中使用。注意,总是存在多于一种的绕三个主轴旋转的序列,它们会导致物体相同的朝向,例如见 [243] 。返回的三个旋转矩阵和对应的三个欧拉角只是可能解中的一个。

该函数基于 RQDecomp3x3。

代码示例


#include <iostream>
#include <opencv2/opencv.hpp>int main()
{// 假设我们已经得到了投影矩阵 Pcv::Mat projMatrix = ( cv::Mat_< double >( 3, 4 ) << 500, 0, 320, 0, 0, 500, 240, 0, 0, 0, 1, 0 );// 创建输出容器cv::Mat cameraMatrix;cv::Mat rotMatrix;cv::Mat transVect;// 分解投影矩阵cv::decomposeProjectionMatrix( projMatrix, cameraMatrix, rotMatrix, transVect );// 打印结果std::cout << "Camera Matrix:\n" << cameraMatrix << "\n";std::cout << "Rotation Matrix:\n" << rotMatrix << "\n";// 归一化平移向量以获得实际的平移向量double w = transVect.at< double >( 3 );if ( w != 0 ){transVect /= w;}std::cout << "Translation Vector:\n" << transVect.rowRange( 0, 3 ) << "\n";  // 只取前3行return 0;
}

运行结果

Camera Matrix:
[500, 0, 320;0, 500, 240;0, 0, 1]
Rotation Matrix:
[1, 0, 0;0, 1, 0;0, 0, 1]
Translation Vector:
[0;0;0]
http://www.lryc.cn/news/505041.html

相关文章:

  • Flink State面试题和参考答案-(下)
  • 111.【C语言】数据结构之二叉树的销毁函数
  • [论文阅读] |智能体长期记忆与反思
  • 【Trouble Shooting】Oracle ADG hung,出现ORA-04021
  • 基于springboot的招聘系统
  • 国科大智能设备安全-APK逆向分析实验
  • 使用SpaceDesk实现iPad成为电脑拓展屏(保姆级教程)
  • Unity UI Button 事件优先级调整技术方案
  • 算法训练营day1 | 704二分查找,27移除元素, 34, 35
  • 66 基于单片机的太阳能充电、温度检测、档位PWM调速系统
  • RK3576 Android14,内存大于4G时UVC应用无法申请内存
  • 12.12 深度学习-卷积的注意力机制-通道注意力SENet
  • H5 scss 移动端的样式适配
  • 【JAVA】Java项目实战—移动端项目:天气查询APP
  • SpringBoot - 动态端口切换黑魔法
  • Java爬虫技术:挖掘淘宝数据的利器
  • Chromium for Android 浏览器的编译和安装
  • 实景视频与模型叠加融合?
  • Scala的隐式类
  • 常见软件设计模式介绍:三层架构、MVC、SSM、EDD、DDD
  • Springboot技术栈常见问题及搭建步骤
  • session 共享服务器
  • vue2:v-for实现的el-radio-group选中时显示角标,并自定义选中按钮的字体颜色和背景色
  • 【Linux】-学习笔记10
  • 鸿蒙NEXT开发案例:九宫格随机
  • 深度解析:RTC电路上的32.768KHz时钟的频偏及测试
  • Scala的泛型
  • OpenGL ES详解——glUniform1i方法是否能用于设置纹理单元
  • 探索 Janus-1.3B:一个统一的 Any-to-Any 多模态理解与生成模型
  • 论文信息搜集