【视觉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.mzph.cn/news/178909.shtml

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

相关文章

anaconda换源安装pytorch(附带bug解决办法)

1.安装anaconda 如何安装anaconda可以看这篇文章:如何安装anaconda 2.换源安装pytorch: 首先进入到pytorch官网,选对好参数之后复制命令进入到anaconda prompt即可: 然后进入自己的环境之后输入该命令(即conda install …),则可以进行下载。下载完成…

【DevOps】SonarQube 指标解读

SonarQube 指标解读 1.BUG 评级计算方法(可靠性)2.漏洞评级计算方法(安全性)3.债务和坏味道4.覆盖率4.1 代码覆盖率4.2 分支覆盖率4.3 单元测试覆盖率 5.重复 1.BUG 评级计算方法(可靠性) ✅ A&#xff1a…

1128. 等价多米诺骨牌对的数量

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/number-of-equivalent-domino-pa…

Day12 qt QMianWindow,资源文件,对话框,布局方式,常用ui控件

QMianWindow 概述 QMainWindow 是一个为用户提供主窗口程序的类,包含一个菜单栏( menu bar )、多 个工具栏 (tool bars) 、多个铆接部件 (dock widgets) 、一个状态栏 (status bar) 及 一个中心部件 (central widget) 许多应用程序的基础…

postgresql-shared_buffers参数详解

shared_buffers 是 PostgreSQL 中一个非常关键的参数,用于配置服务器使用的共享内存缓冲区的大小。这些缓冲区用于存储数据页,以便数据库可以更快地访问磁盘上的数据。 这个参数在 PostgreSQL 的性能方面有着重要的影响。增加 shared_buffers 可以提高数…

【并发编程】ConcurrentHashMap底层结构和原理

📫作者简介:小明Java问道之路,2022年度博客之星全国TOP3,专注于后端、中间件、计算机底层、架构设计演进与稳定性建设优化,文章内容兼具广度、深度、大厂技术方案,对待技术喜欢推理加验证,就职于…

wmvcore.dll丢失怎么办?解决电脑出现wmvcore.dll丢失问题5个方法

wmvcore.dll缺失5个解决方法与wmvcore.dll丢失原因及文件介绍 引言: 在日常使用电脑的过程中,我们可能会遇到一些错误提示,其中之一就是wmvcore.dll缺失。wmvcore.dll是Windows Media Video编码解码相关动态链接库文件之一,它对…

Linux 项目自动化构建工具:make/makefile

什么是 make make 是一个命令,他会在源文件的当前目录下寻找 makefile 或者 Makefile 文件执行这个文件中的代码。 makefile 文件的编写 我们先来见见猪跑,看看 make 怎么用的: 下面是 makefile 文件的内容: 这是 test.c 中的…

WPF创建进度条

使用wpf做一个原生的进度条,进度条上面有值,先看效果。 功能就是点击按钮,后台处理数据,前台显示处理数据的变化,当然还可以对进度条进行美化和关闭的操作,等待后台处理完毕数据,然后自动关闭。…

Python入职某新员工大量使用Lambda表达式,却被老员工喷是屎山

Python中Lambda表达式是一种简洁而强大的特性,其在开发中的使用优缺点明显,需要根据具体场景权衡取舍。 Lambda表达式的优点之一是它的紧凑语法,适用于一些短小而简单的函数。这种形式使得代码更为精炼,特别在一些函数式编程场景中,Lambda表达式可以提高代码的表达力。此外…

DMX512协议及对接口电路的分析

1、DMX512协议简介 DMX 是Digital MultipleX 的缩写,意为多路数字传输(具有512条信息的数字多路复用”)。DMX512控制协议是美国舞台灯光协会(usITT)于1990年发布的灯光控制器与灯具设备进行数据传输的工业标准,全称是USITTDMX512(1990); DMX512 在其物理…

福州大学《嵌入式系统综合设计》 实验八:FFMPEG视频编码

一、实验目的 掌握使用算能平台进行视频编码的流程,包括开发主机环境与云平台的配置,视频编码程序的编写与理解,代码的编译、运行以及学习使用码流分析工具分析视频压缩码流等。 二、实验内容 搭建实验开发环境,编译并运行编码…

Spring Boot 3.2.0 虚拟线程初体验 (部分装配解析)

写在前面 spring boot 3 已经提供了对虚拟线程的支持。 虚拟线程和平台线程主要区别在于,虚拟线程在运行周期内不依赖操作系统线程:它们与硬件脱钩,因此被称为 “虚拟”。这种解耦是由 JVM 提供的抽象层赋予的。 虚拟线程的运行成本远低于平…

组合设计模式

package com.jmj.pattern.combination;/*** 菜单组件,属于抽象根节点*/ public abstract class MenuComponent {//菜单组件的名称protected String name;//菜单组件的层级protected int level;//添加子菜单public void add(MenuComponent menuComponent) {throw new…

12.Spring源码解析-其它标签解析

容易看出,Spring其实使用了一个Map了保存其映射关系,key就是命名空间的uri,value是NamespaceHandler对象或是Class完整名,如果发现是类名,那么用反射的方法进行初始化,如果是NamespaceHandler对象&#xff…

计算虚拟化之CPU——qemu解析

解析 qemu 的命令行,qemu 的命令行解析,就是下面这样一长串。 qemu_add_opts(&qemu_drive_opts);qemu_add_opts(&qemu_chardev_opts);qemu_add_opts(&qemu_device_opts);qemu_add_opts(&qemu_netdev_opts);qemu_add_opts(&qemu_nic_…

C语言枚举的作用是什么?

我在知乎上看到这个问题,一开始,也有一些疑惑,后面查了一些资料,对于这个问题,简单的说一下我的看法。 枚举有多大 枚举类型到底有多大,占多少空间呢?这个要具体情况具体分析,编译器…

【shell】多行重定向与免交互expect与ssh、scp的结合使用

目录 一、多行重定向 举例1:使用read命令接收用户的输入值会有交互过程 举例2:设置变量的值 举例3:创建用户密码 举例4:使用多行重定向写入文件中(以repo文件举例) 举例5:变量设定 二、免…

C++初阶模板

介绍: 我们先认识以下C中的模板。模板是一种编程技术,允许程序员编写与数据类型无关的代码,它是一种泛型编程的方式,可以用于创建可处理多种数据类型的函数或类,也就是说泛型编程就是编写与类型无关的通用代码&#xf…

多线程(补充知识)

STL库,智能指针和线程安全 STL中的容器是否是线程安全的? 不是. 原因是, STL 的设计初衷是将性能挖掘到极致, 而一旦涉及到加锁保证线程安全,会对性能造成巨大的影响. 而且对于不同的容器, 加锁方式的不同, 性能可能也不同(例如hash表的锁表和锁桶). 因此 STL 默认…