子坐标系C在父坐标系W中的旋转问题
关键词:空间旋转、旋转轴、刚体旋转
用途:相机位姿估计、无人机位姿估计
文章类型:概念、公式总结(本文不带推倒过程,若想了解公式是如何推出来的请自习搜索文献),C++函数展示
@Author:VShawn(singlex@foxmail.com)
@Date:2016-11-04
@Lab: CvLab202@CSU
本文接上一篇《空间点绕轴旋转公式&程序(C++)》,继续讨论空间内的旋转问题,可能会用到上一篇中定义的函数。
问题四:空间内的坐标系旋转(相机坐标系在世界坐标系中的旋转)
好了,现在问题越来越复杂了,这次的问题涉及两个坐标系:世界坐标系W与相机坐标系C。
做过相机标定或者研究过相机模型的人对这两个坐标系应该是相当熟悉的了,对于不了解这方面的同学可以这样理解:
- 世界坐标系就是前文一直在用着的坐标系,它规定了所有东西的绝对坐标。
- 相机坐标系是人眼或者是相机看物体的一个坐标系,它能够表示我观测的这个物体距离我有多远,方向角是多少。(其z轴为视线正中线)
下图中的O即为相机坐标系原点,也就是人眼的位置,OZc表示的是当前视线的方向,
Ow则是世界坐标系原点。

于是我们的问题就是,人站在某点拍摄世界坐标系的原点Ow(下标w表示该坐标是在世界坐标系中的),拍摄出的原点正好落在图像中心,现在我通过某种方法(解PNP问题)计算出Ow在相机坐标系下的坐标为(下标c表示该坐标定义在相机坐标系内),求相机或者说是人位于世界坐标系的哪里。
这个问题,当相机坐标系跟世界坐标系完全平行(指两对坐标系的三个轴都相互对应平行)的时候很简单,无需考虑旋转,相机的位置就是。实际上,只要相机坐标系的三根轴与世界的三轴平行(这种平行不需要保证一一对应),这个问题都很好解决。比如下面几幅图的情况(黄点为世界坐标系原点Ow),只要知道世界坐标系的原点Ow在相机坐标系中的坐标,就可以很容易计算出相机的位置。

然而,一旦出现了下面的情况,那么问题就不那么好解决了。
比如说相机的状态是这样:

你就很难通过相机坐标系下的Ow坐标,计算出相机在世界坐标系下的位置。因为其中涉及到了相机坐标系在世界坐标系中的旋转问题。
那么如何求解这个问题呢,事实上,在上文中通过某种方法(解PNP问题)求出原点Ow在相机坐标系下的坐标的同时,我们也获得了相机坐标系的旋转矩阵(没错,就是求相机的外参数矩阵:旋转矩阵r&平移矩阵t),这个"某种方法"我将在其他文章中给大家展示。平移矩阵t可以告诉世界坐标系原点Ow在相机坐标系中的坐标,我们暂且假设为点P=(x0,y0,z0),向量OcP为Oc指向Ow的向量。而旋转矩阵r,可以求出三个欧拉角
【具体如何计算参考《根据相机旋转矩阵求解三个轴的旋转角/欧拉角》】。当相机坐标系C按照z轴、y轴、x轴的顺序旋转以上角度后变成坐标系C3,C3将与世界坐标系W完全平行。此时如果知道Ow在C3系中的坐标,自然就知道了Oc在世界坐标系W中的坐标。

显然,相机坐标系经历了三次旋转后,原点Oc位置会保持不变,而点P跟随坐标系进行了三次旋转,那么向量OcP不再指向Ow。
为了抵消旋转的作用,每次对坐标轴旋转后,我们需要对点P进行反向旋转,使得坐标系C3中的向量OcP依然能指向Ow。
于是得到解决问题的步骤:
第一次旋转:
原始相机坐标系C绕z轴旋转了
变为C1系,此时P=P0=(x0,y0,z0),那么单独将P点绕z轴旋转
,得到P1=(x1,y1,z1),为C1系中Ow的坐标。
第二次旋转:
C1绕y轴旋转了
变为C2系,此时P1=(x1,y1,z1),那么将P1点绕y轴旋转
,得到P2=(x2,y2,z2),为C2系中Ow的坐标。
第三次旋转:
C2绕x轴旋转了
变为C3系,此时P2=(x2,y2,z2),那么将P2点绕x轴旋转
,得到P3=(x3,y3,z3),为C3系中Ow的坐标。
于是世界坐标系中,相机的位置坐标为(-x3,-y3,-z3)。
至于程序就很简单了,只需要调用几次《空间点绕轴旋转公式&程序(C++)》中的函数即可。
最后,本文的成果用在了《相机位姿估计1:根据四个特征点估计相机姿态》中。
子坐标系C在父坐标系W中的旋转问题的更多相关文章
- Repeater 嵌套,子级Repeater获取 父级Repeater 中的值
第一种方法,子级Repeater中绑定父级的某个字段: <%# DataBinder.Eval((Container.NamingContainer.NamingContainer as Rep ...
- ocos2d-x 3.0坐标系详解--透彻篇 ---- convertToWorldSpace:把基于当前节点的本地坐标系下的坐标转换到世界坐标系中。
convertToWorldSpace:把基于当前节点的本地坐标系下的坐标转换到世界坐标系中.重点说明:基于... 不一定要是真实的, convertToWorldSpace 的结果也只是一个新 ...
- 子窗口访问父页面iframe中的iframe,top打开的子窗口访问父页面中的iframe中的iframe
子窗口访问父页面iframe中的iframe 子窗口访问最顶层页面中的iframe中的iframe top打开的子窗口访问父页面中的iframe中的iframe top打开的子窗口访问最顶层页面中的i ...
- 在idea中创建maven父子工程,子工程无法导入父工程依赖的问题
创建maven父子工程时遇到一个问题,当子工程的名称前缀和父工程的名称一样时,子工程会出现一系列的问题.比如我的父工程名称是microservicecloud,子工程名称是microservicecl ...
- WPF关于控件 父级控件,子级控件,控件模板中的控件,等之间的相互访问
原文:WPF关于控件 父级控件,子级控件,控件模板中的控件,等之间的相互访问 1,在菜单中访问 弹出菜单的控件 var mi = sender as MenuItem;//菜单条目 MenuItem ...
- spring 中<ref parent="">标签是什么意思;ref标签与ref属性有什么不同;子容器如何引用父容器的bean
spring的配置文件可能会有多个<property name="a" ref="b" />就是找当前配置文件里的bean 也就是id为b的 < ...
- JS子元素oumouseover触发父元素onmouseout
原文:JS子元素oumouseover触发父元素onmouseout JavaScript中,父元素包含子元素: 当父级设置onmouseover及onmouseout时,鼠标从父级移入子级,则触发父 ...
- uni-app 子组件如何调用父组件的方法
1.在父组件methods中定义一个方法: changeType:function(type){ this.typeActive = type; alert(type); } 2.在父组件引用子组件时 ...
- 二、vue学习--父元素如何获取子元素的值,子元素如何获取父元素的值
下图是父元素: 下图是子元素,获取父元素的值,使用props定义属性,这样就可以获取到父元素上传过来的set .place.type,拿到值就可以做一些自己的逻辑处理 二.子元素给父元素传值? 下 ...
随机推荐
- python知识点总结
此知识要点,是根据学习廖雪峰phthon3.0教程总结的,所以结构基本和这个教程的结构相同. 背景知识 python是什么?(1)python是一门编程语言,意味着可以用python编写程序,完成一定 ...
- font-family:“微软雅黑” OR font-family:Microsoft Yahei
sublime对中文编码支持的不好,可以考虑用后者.
- YbSoftwareFactory 代码生成插件【十九】:实体类配合数据库表字段进行属性扩展的小技巧
实体类通常需要和数据库表进行了ORM映射,当你需要添加新的属性时,往往同时也需要在数据库中添加相应的字段并配置好映射关系,同时可能还需对数据访问组件进行重新编译和部署才能有效.而当你开始设计一个通用数 ...
- YbSoftwareFactory 代码生成插件【十三】:Web API 的安全性
ASP.NET Web API 可非常方便地创建基于 HTTP 的 Services,这些服务可以非常方便地被几乎任何形式的平台和客户端(如浏览器.Windows客户端.Android设备.IOS等) ...
- SQL2008完全卸载详解(图解)
一. SQL2008卸载. 1.从控制面板卸载 1)点击计算机右下角“开始”,点击“控制面板”
- Clouda聊天室实践
1.Clouda说明 Clouda是简单,可依赖的实时Javascript框架.对一个想开发移动webapp的开发者来说,可以使用clouda开发框架,实现一个功能和体验与native app齐平的轻 ...
- 《C++ API设计》作者Martin Reddy访谈问题征集
Martin Reddy博士是软件行业的一名老兵,有着15年以上的从业经验,共撰写过40多篇论文,拥有3项软件专利,并与他人合著了Level of Detail for 3D Graphics.另外, ...
- Thinkphp批量添加数据
//新建规格public function construction(){ $id = $_GET['id'];//dump($id);die; $this->assign('id', $id) ...
- [转]struct.pack 用法手记
原文:http://hi.baidu.com/tibelf/item/8b463d15edfdf10bd1d66d83 看到在进行c格式的二进制文件读取的过程中,用到了struct.unpack方法, ...
- wps使用技巧
1.和word一样的文档结构图: 视图->文档结构图 (不是导航窗格) 2.粘贴时,出现乱码: WPS->选项->默认粘贴方式:无格式文本. 3.浏览当前文档所在目录: 在WPS的标 ...