图像缩放对相机内外参矩阵的影响

参考资料:https://zhuanlan.zhihu.com/p/87185139

一、3D空间中点到图像的投影

  设3D空间中的点 ( x , y , z ) (x,y,z) (x,y,z)投影到图像上的像素坐标(连续值,以左上角像素的左上角为原点的坐标系,注意与整数值的图像像素索引相区别,详见此文第2部分)为 ( u , v ) (u,v) (u,v),深度为 d d d,图像内参矩阵为 I 3 × 3 I_{3\times3} I3×3,外参矩阵为 E 3 × 4 E_{3\times4} E3×4。则存在如下关系:
( u d v d d ) = I 3 × 3 E 3 × 4 ( x y z 1 ) \begin{pmatrix} ud \\ vd \\ d \end{pmatrix}=I_{3\times3}E_{3\times4}\begin{pmatrix} x \\ y \\ z \\ 1 \end{pmatrix} udvdd =I3×3E3×4 xyz1
I 3 × 3 E 3 × 4 = M 3 × 4 = ( m 1 m 2 m 3 ) ,    P = ( x y z 1 ) I_{3\times3}E_{3\times4}=M_{3\times4}=\begin{pmatrix} m_1 \\ m_2 \\ m_3 \end{pmatrix},\ \ P=\begin{pmatrix} x \\ y \\ z \\ 1 \end{pmatrix} I3×3E3×4=M3×4= m1m2m3 ,  P= xyz1 其中 m i ∈ R 1 × 3 m_i\in\mathbb{R}^{1\times3} miR1×3,易得
{ u d = m 1 P v d = m 2 P    d = m 3 P \left\{ \begin{matrix} ud=m_1P \\ vd=m_2P \\ \ \ d=m_3P \end{matrix}\right. ud=m1Pvd=m2P  d=m3P

二、图像缩放及同一3D点在缩放前后图像中的投影坐标

  设原始图像的宽和高分别为 W W W H H H,其缩放比例(缩放因数)分别为 s 1 s_1 s1 s 2 s_2 s2(即缩放后图像的宽和高分别为 s 1 W s_1W s1W s 2 H s_2H s2H),如下图所示(图中 W = 6 , H = 4 , s 1 = 1 / 3 , s 2 = 1 / 2 W=6,H=4,s_1=1/3,s_2=1/2 W=6,H=4,s1=1/3,s2=1/2;左图为原始图像,右图为缩放后的图像):
在这里插入图片描述
  对于3D空间中的同一个点,其投影到缩放前后图像上的相对位置是相同的(图中黄点)。换句话说,若以左上角像素的左上角为原点建立图像坐标系,其在缩放前后图像中的坐标(分别记为 ( u , v ) (u,v) (u,v) ( u ′ , v ′ ) (u',v') (u,v))之比即为 ( 1 / s 1 , 1 / s 2 ) (1/s_1,1/s_2) (1/s1,1/s2)
  由深度的几何(物理)含义可知同一个点在缩放前后图像中的深度不变。

三、图像缩放后内外参矩阵的变化

  根据第一节中的最后一个公式和第二节中的分析: { u d = m 1 P v d = m 2 P    d = m 3 P ,     { u ′ d ′ = s 1 u d = m 1 ′ P v ′ d ′ = s 2 v d = m 2 ′ P d ′ = d = m 3 ′ P \left\{ \begin{matrix} ud=m_1P \\ vd=m_2P \\ \ \ d=m_3P \end{matrix}\right.,\ \ \ \left\{ \begin{matrix} u'd'=s_1ud=m'_1P \\ v'd'=s_2vd=m'_2P \\ d'=d=m'_3P \end{matrix}\right. ud=m1Pvd=m2P  d=m3P,    ud=s1ud=m1Pvd=s2vd=m2Pd=d=m3P可知 m 3 ′ = m 3 m'_3=m_3 m3=m3,而 m 1 ′ = s 1 m 1 ,   m 2 ′ = s 2 m 2 m'_1=s_1m_1,\ m'_2=s_2m_2 m1=s1m1, m2=s2m2
  故结论为:图像缩放时,内外参矩阵之积的第一行需要乘上宽的缩放因数,第二行需要乘上高的缩放因数

注意:设缩放前像素的整数索引为 ( u , v ) (u,v) (u,v),图像的宽和高分别为 W W W H H H,缩放比例(缩放因数)分别为 s 1 s_1 s1 s 2 s_2 s2,若仍按照第二节的方式计算缩放后的坐标 ( u ′ , v ′ ) (u',v') (u,v)(即 u ′ = s 1 u , v ′ = s 2 v u'=s_1u,v'=s_2v u=s1u,v=s2v),则存在参考资料中所谓的“0.5像素问题”。这是因为像素的整数索引和像素的连续坐标之间相差了0.5(同样可见此文第2部分)。如果在缩放时考虑到了这一点(如使用cv2.resize()函数实现缩放),则可直接使用第三节的结论。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

HTTPS的加密原理(工作机制)

现在很多网站使用的都是HTTPS协议,比如CSDN他们为什么要使用HTTPS协议而不是继续使用HTTP协议呢?以及HTTPS都做了些什么?HTTP协议与HTTPS有哪些区别? 下面我来 讲解这些问题?(篇幅可能有些长,请求耐心观看,我以0基础的角度去讲解这些东西, 如果你有一定的基础前面的跳过就好…

docker安装elasticsearch与head教程完整版—.NET Core Web Api与elasticsearch打造全站全文搜索引擎

默认已经有docker环境 下载与安装 elasticsearch ,从hub.docker里面可以看到最新版本的镜像,选择你想要的版本 本教程是以 7.17.7 为案例,为啥不适用最新的,首先个人一般需用最新的版本,如果有亢很难填,其次…

三体到底是啥?用Python跑一遍就明白了

文章目录拉格朗日方程推导方程组微分方程算法化求解画图动图绘制温馨提示,只想看图的画直接跳到最后一节拉格朗日方程 此前所做的一切三体和太阳系的动画,都是基于牛顿力学的,而且直接对微分进行差分化,从而精度非常感人&#xf…

如何用Python求解微分方程组

文章目录odeint简介示例odeint简介 scipy文档中将odeint函数和ode, comples_ode这两个类称为旧API,是scipy早期使用的微分方程求解器,但由于是Fortran实现的,尽管使用起来并不方便,但速度没得说,所以有的时候还挺推荐…

Vite4 + Vue3 + vue-router4 动态路由

动态路由,基本上每一个项目都能接触到这个东西,通俗一点就是我们的菜单是根据后端接口返回的数据进行动态生成的。表面上是对菜单的一个展现处理,其实内部就是对router的一个数据处理。这样就可以根据角色权限或者一些业务上的需求&#xff0…

机器学习入门——线性回归

线性回归什么是线性回归?回归分析:线性回归:回归问题求解单因子线性回归简单实例评估模型表现可视化模型展示多因子线性回归什么是线性回归? 回归分析: 根据数据,确定两种或两种以上变量间相互依赖的定量…

自学大数据第六天~HDFS命令(一)

HDFS常用命令 查看hadoop版本 version hadoop version注意,没有 ‘-’ [hadoopmaster ~]$ hadoop version Hadoop 3.3.4 Source code repository https://github.com/apache/hadoop.git -r a585a73c3e02ac62350c136643a5e7f6095a3dbb Compiled by stevel on 2022-07-29T12:3…

【电赛MSP430系列】GPIO、LED、按键、时钟、中断、串口、定时器、PWM、ADC

文章目录MSP430一、GPIO二、点亮LED三、按键控制LED四、更改主时钟五、串口通信六、串口中断七、外部中断八、定时器九、定时器中断十、PWM十一、ADCMSP430 MSP430 是德州仪器(TI)一款性能卓越的超低功耗 16 位单片机,自问世以来&#xff0c…

程序员的逆向思维

前要: 为什么你读不懂面试官提问的真实意图,导致很难把问题回答到面试官心坎上? 为什么在面试结束时,你只知道问薪资待遇,不知道如何高质量反问? 作为一名程序员,思维和技能是我们职场生涯中最重要的两个方面。有时候…

【微信小程序】-- 网络数据请求(十九)

💌 所属专栏:【微信小程序开发教程】 😀 作  者:我是夜阑的狗🐶 🚀 个人简介:一个正在努力学技术的CV工程师,专注基础和实战分享 ,欢迎咨询! &…

到底什么是跨域,如何解决跨域(常见的几种跨域解决方案)?

文章目录1、什么是跨域2、解决跨域的几种方案2.1、JSONP 方式解决跨域2.2、CORS 方式解决跨域(常见,通常仅需服务端修改即可)2.3、Nginx 反向代理解决跨域(推荐使用,配置简单)2.4、WebSocket 解决跨域2.5、…

软测面试了一个00后,绝对能称为是内卷届的天花板

前言 公司前段缺人,也面了不少测试,结果竟然没有一个合适的。一开始瞄准的就是中级的水准,也没指望来大牛,提供的薪资也不低,面试的人很多,但平均水平很让人失望。令我印象最深的是一个00后测试员&#xf…

【JavaScript 逆向】百度旋转验证码逆向分析

声明本文章中所有内容仅供学习交流,相关链接做了脱敏处理,若有侵权,请联系我立即删除!案例目标爱企查百度安全验证百度搜索:aHR0cHM6Ly93YXBwYXNzLmJhaWR1LmNvbS9zdGF0aWMvY2FwdGNoYS8以上均做了脱敏处理,B…

操作系统(2.2)--进程的描述与控制

目录 二、进程的描述 1.进程的定义和特征 1.1进程的定义 1.2进程的特征 2.进程的基本状态及转换 2.1进程的三种基本状态 2.2 三种基本状态的转换 2.3创建状态和中止状态 3.挂起操作和进程状态的转换 3.1 挂起状态的引入 3.2 引入挂起操作后三个进程状态的转换 …

07从零开始学Java之如何正确的编写Java代码?

作者:孙玉昌,昵称【一一哥】,另外【壹壹哥】也是我哦CSDN博客专家、万粉博主、阿里云专家博主、掘金优质作者前言在上一篇文章中,壹哥带领大家开始编写了第一个Java案例,在我们的cmd命令窗口中输出了”Hello World“这…

【蓝桥杯-筑基篇】常用API 运用(1)

🍓系列专栏:蓝桥杯 🍉个人主页:个人主页 目录 🍍1.输入身份证,判断性别🍍 🍍2.输入英语句子,统计单词个数🍍 🥝3.加密解密🥝 🌎4.相邻重复子串…

【6G 新技术】6G数据面介绍

博主未授权任何人或组织机构转载博主任何原创文章,感谢各位对原创的支持! 博主链接 本人就职于国际知名终端厂商,负责modem芯片研发。 在5G早期负责终端数据业务层、核心网相关的开发工作,目前牵头6G算力网络技术标准研究。 博客…

订单30分钟未支付自动取消怎么实现?

目录了解需求方案 1:数据库轮询方案 2:JDK 的延迟队列方案 3:时间轮算法方案 4:redis 缓存方案 5:使用消息队列了解需求在开发中,往往会遇到一些关于延时任务的需求。例如生成订单 30 分钟未支付&#xff0…

HashMap的实际开发使用

目 录 前言 一、HashMap是什么? 二、使用步骤 1.解析一下它实现的原理 ​编辑 2.实际开发使用 总结 前言 本章,只是大概记录一下hashMap的简单使用方法,以及理清一下hashMap的put方法的原理,以及get方法的原理。 一、Has…

如何使用 Python 检测和识别车牌(附 Python 代码)

文章目录创建Python环境如何在您的计算机上安装Tesseract OCR?技术提升磨砺您的Python技能车牌检测与识别技术用途广泛,可以用于道路系统、无票停车场、车辆门禁等。这项技术结合了计算机视觉和人工智能。 本文将使用Python创建一个车牌检测和识别程序。…