相机外参和内参矩阵介绍

news/2025/1/12 6:15:16/文章来源:https://www.cnblogs.com/ymzcch12/p/18244362

相机与变换

一、内参与外参概念

在计算机视觉中,特别是在相机标定和立体视觉领域,内参(intrinsic parameters)和外参(extrinsic parameters)是非常重要的概念。它们与相机的几何属性和姿态有关。

  • 内参(Intrinsic Parameters): 内参是描述相机内部属性的参数,包括焦距、主点(光学中心)坐标、畸变系数等。内参通常在相机标定时确定,因为它们通常对于特定相机型号是固定的,不随时间变化。一旦相机内参被确定,它们在相机的使用过程中通常是保持不变的。
  • 外参(Extrinsic Parameters): 外参是描述相机在世界坐标系中的位置和姿态的参数,通常包括旋转矩阵和平移向量。外参在不同的相机位置或拍摄时刻可能会发生变化。例如,在立体视觉中,如果有两个相机,那么它们的相对位置和方向会在每次移动相机时发生变化,从而导致外参的变化。

如果相机不发生位置和方向的变化,比如相机固定在一个固定位置,那么外参在很长一段时间内可能保持不变。然而,如果相机的位置或方向发生变化,例如移动相机或更改拍摄角度,外参会随之变化。

二、四个坐标系

四个坐标系的意义,世界坐标系(参考坐标系)摄像机坐标系图像物理坐标系像素坐标系

  1. 世界坐标系就是物体在真实世界中的坐标,比如黑白棋盘格的世界坐标系原点定在第一个棋盘格的顶点,Xw,Yw,Zw互相垂直,Zw方向就是垂直于棋盘格面板的方向。可见世界坐标系是随着物体的大小和位置变化的,单位是长度单位。只要棋盘格的大小决定了,无论板子怎么动,棋盘格角点坐标一般就不再变动(因为是相对于世界坐标系原点的位置不变),且认为是Zw=0。
  2. 相机坐标系以光心为相机坐标系的原点,以平行于图像的x和y方向为Xc轴和Yc轴,Zc轴和光轴平行,Xc,Yc,Zc互相垂直,单位是长度单位。
  3. 图像物理坐标系以主光轴和图像平面交点为坐标原点,x和y方向如图所示,单位是长度单位。
  4. 图像像素坐标系以图像的顶点为坐标原点,u和v方向平行于x和y方向,单位是以像素计。

image

图片借用link

相机成像过程涉及到四个坐标系的变换,变换关系如下:

(U,V,W)是世界坐标系,经过刚体变换(如:旋转、平移)后变为了相机坐标系,再次经过透视投影转变为了图像坐标系,最后经仿射变换转换为了像素坐标系(u,v)。转换关系如下(Z是尺度因子):

三、相机内参

然后就来到了图中的虚线部分,考虑相机坐标下的\(P(x_c,y_c,z_c)\),焦距为\(f_c\),由相似三角形可以得到:

\[\frac{x_c}x=\frac{y_c}y=\frac{z_c}{f_c} \]

写成矩阵形式为:

\[z_c\begin{bmatrix}x\\y\\1\end{bmatrix}=\begin{bmatrix}f_c&0&0\\0&f_c&0\\0&0&1\end{bmatrix}\begin{bmatrix}x_c\\y_c\\z_c\end{bmatrix} \]

最后得到了投影平面上图像的坐标,但要注意,我们此时仍然在物理坐标系下。即如果现在这些字母都有个单位的话,那么它们应该是米或毫米。距离我们熟悉的图片还有一步:从图像坐标系变换至像素坐标系。为了实现这一点,我们进行了水平和竖直方向的伸缩变换以及平移变换,将坐标系的原点从光心转移到(通常时候)图像的左上角:

\[\begin{bmatrix}u\\v\\1\end{bmatrix}=\begin{bmatrix}\frac{1}{\mathrm{d}x}&0&u_0\\0&\frac{1}{\mathrm{d}y}&v_0\\0&0&1\end{bmatrix}\begin{bmatrix}x\\y\\1\end{bmatrix} \]

这里\(u_0\)一般近似为\(W/2\),\(v_0\)一般近似为\(H/2\)。所以整个的这个变换过程可以整理成:

\[\begin{gathered}z_{c}\begin{bmatrix}u\\v\\1\end{bmatrix}=\begin{bmatrix}\frac1{\mathrm{d}x}&0&u_0\\0&\frac1{\mathrm{d}y}&v_0\\0&0&1\end{bmatrix}\begin{bmatrix}f_c&0&0&0\\0&f_c&0&0\\0&0&1&0\end{bmatrix}\begin{bmatrix}R&T\\\mathbf{0}&1\end{bmatrix}\begin{bmatrix}x_w\\y_w\\z_w\\1\end{bmatrix}\\=\begin{bmatrix}f_x&0&u_0&0\\0&f_y&v_0&0\\0&0&1&0\end{bmatrix}\begin{bmatrix}\mathop{R}\limits_{3 \times 3 }&\mathop{T}\limits_{3\times1}\\\mathbf{0}&1\end{bmatrix}\begin{bmatrix}x_w\\y_w\\z_w\\1\end{bmatrix}\end{gathered} \]

其中,\(f_x=\frac f{\mathrm{d}x},f_y=\frac f{\mathrm{d}y}\)。表示将物理坐标上的焦距映射进像素尺寸\((dx,dy)\)中的缩放,然而其实大多数情况下其实都有\(dx=dy\),即像素是一个正方形。得到的第一个矩阵简记为\(K\),也叫相机内参。获取相机内参和外参的方法即相机标定。

四、相机外参

首先,体素所在的( 整个场)有一个默认坐标系,称为世界坐标系\(O-x_{w}y_{w}z_{w}\)。不同的相机可能会从不同的角度进行拍摄。即不同的\(\phi,\theta,\) 以及此时小孔位置的三维坐标。即我们可以通过绕\(z_{w}\)轴和绕\(x_{z}\)轴旋转坐标系、然后再对坐标系进行平移,来将世界坐标系上的一个点转移到相机坐标系下的表示。假设此时相机的位置是\((x,y,z)\),那么可以先绕\(x_{w}\)轴旋转\(\phi\),再绕\(z_{w}\)轴旋转\(\theta\):

\[\begin{gathered} R_\theta=\begin{bmatrix}\cos\theta&-\sin\theta&0\\\sin\theta&\cos\theta&0\\0&0&1\end{bmatrix} , \qquad R_{\phi}=\begin{bmatrix}1&0&0\\0&\cos\phi&-\sin\phi\\0&\sin\phi&\cos\phi\end{bmatrix} \\ R=R_\theta R_\phi=\begin{bmatrix}\cos\theta&-\sin\theta\cos\phi&\sin\theta\sin\phi\\\sin\theta&\cos\theta\cos\phi&-\cos\theta\sin\phi\\0&\sin\phi&\cos\phi\end{bmatrix} \end{gathered} \]

同时,平移向量可以表示为\(T=[x,y,z]\),那么我们可以通过齐次坐标构造一个位姿矩阵C:

\[C=\begin{bmatrix}\mathop{R}\limits_{3 \times 3 }&\mathop{T}\limits_{3\times1}\\\mathbf{0}&1\end{bmatrix} \]

矩阵C又叫相机外参。这样就能通过左乘将世界坐标转换成相机坐标(w2c):

\[\begin{bmatrix}x_c\\y_c\\z_c\\1\end{bmatrix}=\begin{bmatrix}\mathop{R}\limits_{3 \times 3 }&\mathop{T}\limits_{3\times1}\\\mathbf{0}&1\end{bmatrix}\begin{bmatrix}x_w\\y_w\\z_w\\1\end{bmatrix} \]

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

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

相关文章

用ChatmoneyAI打造模拟面试服务

引言 想要跟上时代潮流,那就利用ChatmoneyAI在模拟面试行业赚钱吧!通过智能机器人提供个性化的面试辅导服务,帮助他人事半功倍地备战面试,同时也实现自己的财务自由。这个创新的商机不仅切合时代需求,还让你在激烈的市场竞争中脱颖而出。心动了吗?赶紧了解如何在这个领域…

e语言 构造json案例

1,类_json demo代码本文来自博客园,作者:__username,转载请注明原文链接:https://www.cnblogs.com/code3/p/18244499

springboot rabbitmq如何保证消息顺序消费

很多时候,消息的消费是不用保证顺序的,比如借助mq实现订单超时的处理。但有些时候,业务中可能会存在多个消息需要顺序处理的情况,比如生成订单和扣减库存消息,那肯定是先执行生成订单的操作,再执行扣减库存的操作。 那么这种情况下,是如何保证消息顺序消费的呢? 首先,…

e语言 json创建案例

demo代码本文来自博客园,作者:__username,转载请注明原文链接:https://www.cnblogs.com/code3/p/18244499

系统内存占用下降 20%,卓创网络应用 OpenCloudOS 实践

卓创网络主营产品「招采星」在使用 OpenCloudOS 后,系统内存占用由原来的 33% 降低到 11.7%,本文将深入探讨卓创网络从传统架构到 OpenCloudOS 的转变。导语:卓创网络作为一家专注于招标采购领域的企业,主营产品「招采星」为超过 4000 家公司提供电子采购系统及相关配套服务…

深入解析 JMeter TPS 测试:从理论到实践

前言 作为一名测试工程师,理解并能够准确测量每秒事务数(Transactions Per Second, TPS)是确保系统性能的关键指标之一。本文将详细介绍如何使用 Apache JMeter 进行 TPS 测试,包括理论基础、配置步骤和结果分析。 什么是 TPS? TPS(Transactions Per Second)表示系统每秒…

掌握 JMeter 插件管理器:提升性能测试的利器

前言 Apache JMeter 是一款强大的性能测试工具,其灵活性和扩展性使其在性能测试领域广受欢迎。JMeter 插件管理器(JMeter Plugins Manager)为用户提供了一个方便的平台来安装、更新和管理各种插件,从而大大扩展了 JMeter 的功能。本文将详细介绍如何使用 JMeter 插件管理器…

linux mysql麒麟系统部署

1、安装mysqlapt-get install mysql-server mysql-common2、取消大小写敏感(1)、先删除mysql数据库rm -rf /var/lib/mysql (2)、设置my.cnf[mysqld] lower-case-table-names=1 (3)、初始化数据库,取消大小写敏感mysqld --initialize --user=mysql --lower-case-table-…

掌握JMeter:深入解析如何提取和利用JSON数据

前言 Apache JMeter不仅是一个功能强大的性能测试工具,它还可以用于提取和处理响应中的数据。对于现代Web应用,JSON(JavaScript Object Notation)已经成为主要的数据交换格式。本文将详细介绍如何在JMeter中提取JSON数据,并将其用于后续的请求或断言。 环境准备 在开始之前…

Postman变量使用指南

前言 在API测试过程中,变量的使用能够大大提高测试的灵活性和效率。Postman提供了多种变量类型,帮助我们更方便地管理和重用数据。本文将详细介绍Postman中变量的使用方法和实际应用场景。 为什么要使用变量? 在API测试中,变量可以帮助我们:避免重复输入相同的数据 管理和…

深入探索Chrome开发者工具:开发者的利器

前言 作为一名测试,我们经常需要对web页面进行测试,很多时候我们都需要借助Chrome开发者工具(Chrome DevTools)来进行测试,无论是前端开发还是调试问题,都是必不可少的利器。本文就来给大家介绍一下Chrome开发者的使用。 什么是Chrome开发者工具? Chrome开发者工具(Dev…

VSCode安装使用教程,保姆级!

前言 Visual Studio Code(简称 VS Code)是一款由微软开发的免费、开源的轻量级代码编辑器,它支持多种编程语言和平台,并提供丰富的扩展功能,让开发者能够更高效地编写代码。本文将向您介绍如何安装和使用 VS Code,以及一些常用的功能和技巧。 VSCode 下载、安装 我们可以…