【视觉SLAM十四讲学习笔记】第三讲——四元数

专栏系列文章如下:
【视觉SLAM十四讲学习笔记】第一讲——SLAM介绍
【视觉SLAM十四讲学习笔记】第二讲——初识SLAM
【视觉SLAM十四讲学习笔记】第三讲——旋转矩阵
【视觉SLAM十四讲学习笔记】第三讲——Eigen库
【视觉SLAM十四讲学习笔记】第三讲——旋转向量和欧拉角

本章将介绍视觉SLAM的基本问题之一:如何描述刚体在三维空间中的运动

四元数

四元数的定义

旋转矩阵用9个量描述3自由度的旋转,具有冗余性;欧拉角和旋转向量是紧凑的,但具有奇异性。事实上,我们找不到不带奇异性的三维向量描述方式。类似于用两个坐标表示地球表面(如经度和纬度),必定存在奇异性(纬度为 ±90° 时经度无意义)。回忆以前学习过的复数。我们用复数集C表示复平面上的向量,而复数的乘法则表示复平面上的旋转:乘上复数i相当于逆时针把一个复向量旋转 90°。类似地,在表达三维空间旋转时,也有一种类似于复数的代数:四元数(Quaternion)。四元数是Hamilton找到的一种扩展的复数。它既是紧凑的,也没有奇异性。缺点是四元数不够直观,其运算稍复杂些。

把四元数与复数类比可以更快地理解四元数。例如,当我们想要将复平面的向量旋转 θ 角时,可以给这个复向量乘以 e^iθ。这是极坐标表示的复数,它也可以写成普通的形式,只要使用欧拉公式即可:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

这是一个单位长度的复数。所以,在二维情况下,旋转可以由单位复数来描述。类似地,三维旋转则可以由单位四元数来描述。

一个四元数q拥有一个实部和三个虚部,示例如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

其中i,j,k为四元数的三个虚部。这三个虚部满足以下关系式:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

如果把i,j,k看成三个坐标轴,那么它们与自己的乘法和复数一样,相互之间的乘法和外积一样。有时人们也用一个标量和一个向量来表达四元数:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

这里,s 称为四元数的实部,v称为它的虚部。如果一个四元数的虚部为0,称之为实四元数。反之,若它的实部为 0,则称之为虚四元数

可以用单位四元数表示三维空间中任意一个旋转,不过这种表达方式和复数有些许不同。在复数中,乘以i意味着旋转 90°。这是否意味着四元数中,乘i就是绕i轴旋转90°?那么,ij=k是否意味着,先绕i转90°,再绕j转90°,就等于绕k转90°?

非也。应该是乘以i对应着旋转180◦,这样才能保证ij=k的性质。而i^2 = −1,意味着绕i轴旋转360°后得到一个相反的东西。这个东西要旋转两周(720°)才会和它原先的样子相等。(是不是很抽象)

四元数的运算

四元数常见的运算有四则运算、数乘、求逆、共轭等。

现在有两个四元数,原始表示为:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

它们的向量表示为:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

那么,其运算可表示如下:

  1. 加法和减法
    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  2. 乘法

    乘法是把qa的每一项和qb的每项相乘,最后相加:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

​ 如果写成向量形式并利用内外积运算,该表达式会更加简洁:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

​ 在该乘法定义下,两个实四元数乘积仍是实的,这与负数是一致的。然而我们注意到,由于最后一项外积的存在,四元数乘法通常是不可交换的,除非va和vb在R^3中共线,此时外积项为零。

  1. 模长

    四元数的模长定义为
    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

​ 可以验证,两个四元数乘积的模即模的乘积。这使得单位四元数相乘后仍是单位四元数。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  1. 共轭

    四元数的共轭是把虚部取成相反数:

    img

​ 四元数共轭与其本身相乘,会得到一个实四元数,其实部为模长的平方:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
5. 逆

一个四元数的逆为
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

​ 按此定义,四元数和自己的逆的乘积为实四元数1:
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

​ 如果q为单位四元数,其逆和共轭就是同一个量。同时,乘积的逆具有和矩阵相似的性质:
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  1. 数乘

    和向量相似,四元数可以与数相乘:
    在这里插入图片描述

用四元数表示旋转

我们可以用四元数表达对一个点的旋转。假设有一个空间三维点
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

以及一个由单位四元数q指定的旋转。三维点p经过旋转之后变为p‘。如果使用矩阵描述,那么有p’=Rp。而如果用四元数描述旋转,它们的关系又如何表达呢?

首先,把三位空间点用一个虚四元数来描述:
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

相当于把四元数的3个虚部与空间中的3个轴相对应。那么,旋转后的点p‘可表示为这样的乘积:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

这里的乘法均为四元数乘法,结果也是四元数。最后把p’的虚部取出,即得旋转之后点的坐标。并且,计算结果的实部为0,故为纯虚四元数。

四元数到其他旋转表示的转换

任意单位四元数描述了一个旋转,该旋转也可用旋转矩阵或旋转向量描述。四元数乘法也可以写成一种矩阵的乘法。设q = [s,v]^T,那么,定义如下的符号 + 和 ⊕ 为:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

这两个符号将四元数映射成为一个 4×4 的矩阵。于是四元数乘法可以写成矩阵的形式:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

同理亦可证:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

然后,考虑使用四元数对空间点进行旋转的问题:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

代入两个符号对应的矩阵,得:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

因为p′和p都是虚四元数,那么事实上该矩阵的右下角即给出了从四元数到旋转矩阵的变换关系:

img

对上式两侧求迹,得:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

又由

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

得到

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

所以

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

总而言之,四元数到旋转向量的转换公式如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

…(img-gkaQjiLn-1701177419079)]

代入两个符号对应的矩阵,得:

[外链图片转存中…(img-vQsuOEIL-1701177419080)]

因为p′和p都是虚四元数,那么事实上该矩阵的右下角即给出了从四元数到旋转矩阵的变换关系:

img

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

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

相关文章

【小白进阶】Linux 调试大法——gdb

初衷 gdb调试是每一个后端开发工程师所必备的技能,我们工作总是会用gdb协助我们去分析和调试问题。但是大部分同学的技能仅停留在最基础的查看问题。即gdb program -->r --> 问题复现 --> bt 查看源码中的哪一行出现了错误。再稍微熟练点的,可能…

Node.js 事件循环:定时任务、延迟任务和 I/O 事件的艺术

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6 🍨 阿珊和她的猫_CSDN个人主页 🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 🍚 蓝桥云课签约作者、已在蓝桥云…

python多线程和多进程

1.多线程 线程是程序执行的最小单位,一个进程至少有一个线程。 提高并发性。通过线程可方便有效地实现并发性。进程可创建多个线程来执行同一程序的不同部分。 进程之间不能共享内存,但线程之间共享内存非常容易。 Python 常用的多线程库有threading 和…

微信小程序Vue+nodejs教室自习室座位预约系统68u2m

本文从管理员、用户的功能要求出发,教室预约系统小程序中的功能模块主要是实现管理端;首页、个人中心、教室信息管理、教室设备管理、用户管理、教室预约管理、管理员管理、系统管理,微信端;首页、教室信息、教室设备、教室预约、…

【吞噬星空】弧刀盘价值180亿,购买1016名强者,保卫地球

Hello,小伙伴们,我是拾荒君。 国漫《吞噬星空》的第95集更新了,一更新,我和我的小伙伴们就迫不及待地去观看了。在这个集剧中,罗峰在一个奴隶拍卖场中深切地感受到了宇宙中弱肉强食的残酷现实。他看到,在宇宙中&#…

goweb入门教程

本文是作者自己学习goweb时写的笔记,分享给大家,希望能有些帮助 前言: 关于web:本质 ​ ​ web中最重要的就是浏览器和服务器的request(请求)和response(响应); ​ 一个请求对应一个响应。 一个请求对应一个响应&…

鸿蒙开发ArkUI -常用布局

线性布局(Row/Column) 间距/主轴排列方式/交叉轴对齐方式 Column({}) {Column() {}.width(80%).height(50).backgroundColor(0xF5DEB3)Column() {}.width(80%).height(50).backgroundColor(0xD2B48C)Column() {}.width(80%).height(50).backgroundColor(0xF5DEB3) } .width(1…

vue3通过v-model实现父子组件通信

单一值传递 父组件 <template><div ><h1>v-model实现父子组件通讯</h1><hr><child1 v-model"num"></child1><!-- 上下两个是等价的 --><child1 :modelValue"num" update:modelValue"handle&quo…

软件测试项目经验简历包装怎么写?

软件测试是使用人工或者自动的手段来运行或者测定某个软件系统的过程&#xff0c;其目的在于检验它是否满足规定的需求或弄清预期结果与实际结果之间的差别。 在软件投入使用前&#xff0c;要经过一系列的严格测试&#xff0c;才能保证交付质量。 一、引言 1.编写目的 本文档…

有趣的代码——猜数字游戏的实现

前面介绍过很多的C语言常识&#xff0c;但是我们都知道“兴趣是最好的老师”&#xff0c;所以&#xff0c;今天我们用之前讲过的一些知识&#xff0c;加上部分新补充的知识点&#xff0c;写一个“猜数字”的小游戏&#xff0c;来丰富我们的编程学习生活&#xff0c;感受来自C语…

【小布_ORACLE】Part11-1--RMAN Backups笔记

Oracle的数据备份于恢复RMAN Backups 学习第11章需要掌握&#xff1a; 一.RMAN的备份类型 二.使用backup命令创建备份集 三.创建备份文件 四.备份归档日志文件 五.使用RMAN的copy命令创建镜像拷贝 文章目录 Oracle的数据备份于恢复RMAN Backups1.RMAN Backup Concepts&#x…

云原生系列Go语言篇-编写测试Part 1

本文来自正在规划的​​Go语言&云原生自我提升系列​​&#xff0c;欢迎关注后续文章。 2000年以来&#xff0c;自动化测试的广泛应用可能比任何其他软件工程技术都更能提高代码质量。Go是一种专注于提高软件质量的语言和生态系统&#xff0c;很自然的在其标准库中包含了测…

《2023全球隐私计算报告》正式发布!

2023全球隐私计算报告 1、2023全球隐私计算图谱2、国内外隐私计算相关政策3、隐私计算技术的最新发展4、隐私计算技术的合规挑战5、隐私计算的应用市场动态6、隐私计算开源整体趋势7、隐私计算的未来趋势 11月23日&#xff0c;由浙江省人民政府、商务部共同主办&#xff0c;杭州…

Appium自动化如果出现报错怎么办?这么做确实解决问题

解决通过appium的inspector功能无法启动app的原因 在打开appium-desktop程序&#xff0c;点击inspector功能&#xff0c;填写app的配置信息&#xff0c;启动服务提示如下&#xff1a; 报错信息&#xff1a; An unknown server-side error occurred while processing the com…

牛客 算法题 记负均正II golang实现

题目 HJ105 记负均正II golang 实现 package mainimport ("bufio""fmt""io""os""strconv""strings" )func main() {scanner : bufio.NewScanner(os.Stdin)nums:make([]int,0)sum:0minus:0for scanner.Scan() {l…

java开发需要掌握的maven相关知识和Junit单元测试

maven简介 什么是maven&#xff1a; maven是一款管理和构建java项目的工具&#xff0c;是apache旗下的一个开源项目。 maven的作用&#xff1a; 依赖管理&#xff1a; 方便快捷的管理项目依赖的资源&#xff08;jar包&#xff09;。 项目构建&#xff1a; 标准化的跨平台&#…

20 章 多线程

20.1线程简介. 20.2创建线程 2.1继承Thread类 Thread 类是java.lang包中的一个类&#xff0c;从这个类中实例化的对象代表线程&#xff0c;程序员启动一个新线程需要建立Thread 实例。Thread类中常用的两个构造方法如下: public Thread():创建一个新的线程对象。 public Thre…

【LeetCode】128. 最长连续序列——哈希的应用(3)

文章目录 1、思路2、解题方法3、复杂度时间复杂度:空间复杂度: 4、Code Problem: 128. 最长连续序列 1、思路 我会用一种做题者的思路来去看待这道题。 我们在乍一看到这道题的时候&#xff0c;看到它的时间复杂度要求为O(N)&#xff0c;然后又要求去找序列(就是让你判断这个…

stm32 TIM

一、TIM简介 TIM&#xff08;Timer&#xff09;定时器定时器可以对输入的时钟进行计数&#xff0c;并在计数值达到设定值时触发中断。16位计数器、预分频器、自动重装寄存器的时基单元&#xff0c;在72MHz计数时钟下可以实现最大59.65s的定时定时器不仅具备基本的定时中断功能&…

前端 | iframe框架标签应用

文章目录 &#x1f4da;嵌入方式&#x1f4da;图表加载显示&#x1f4da;100%嵌入及滑动条问题&#x1f4da;加载动画保留 前情提要&#xff1a; 计划用iframe把画好的home1.html&#xff08;echarts各种图表组成的html数据大屏&#xff09;嵌入整合到index.html&#xff08;搭…