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

news2025/1/12 13:16:22

专栏系列文章如下:
【视觉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.coloradmin.cn/o/1264149.html

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

相关文章

【前端首屏加载速度优化(一) :nginx 开启gzip压缩】

开启gzip压缩前后对比: nginx.conf具体配置: server {# 启动后的端口listen 8882;# 开启gzip压缩gzip on;gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.1; gzip_comp_level 6; gzip_types text/plain application/x-javascript…

前端 | iframe框架标签应用

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

为第一个原生Spring5应用程序添加上Log4J日志框架!

😉😉 学习交流群: ✅✅1:这是孙哥suns给大家的福利! ✨✨2:我们免费分享Netty、Dubbo、k8s、Mybatis、Spring...应用和源码级别的视频资料 🥭🥭3:QQ群:583783…

如何一分钟内画好可视化图形?

一、定类数据 饼图 描述:用形状类似“饼”的形态描述数据的占比,并且参与绘制的数值没有负值,比如想要直观的查看“月生活费各个板块的占比”。 操作:以SPSSAU为例,使用“频数分析”即可。 示例: 圆环图…

使用C语言库函数qsort排序注意点

目录 题目背景错误C语言代码:正确C语言代码:注意点 题目背景 高校团委组织校园歌手比赛,进入决赛的校园歌手有10位,歌手编号从1到10进行编号。组委会随机抽取方式产生了决赛次序为:3,1,9,10,2,7,5,8,4,6。比赛现场有5个评委为参赛…

js逆向-某赞滑块

声明 本文仅供学习参考,如有侵权可私信本人删除,请勿用于其他途径,违者后果自负! 如果觉得文章对你有所帮助,可以给博主点击关注和收藏哦! 前言 目标网站:aHR0cHM6Ly9hY2NvdW50LnlvdXphbi5j…

3个.NET开源免费的仓库管理系统(WMS)

前言 今天给大家推荐3个.NET开源免费的WMS仓库管理系统(注意:以下排名不分先后)。 仓储管理系统介绍 仓储管理系统(Warehouse Management System,WMS)是一种用于管理和控制仓库操作的软件系统&#xff0…

Python 装饰器与偏函数

目录 装饰器 概念 简单的装饰器 复杂点的装饰器 通用装饰器 定义通用装饰器 使用装饰器 偏函数 引入类库 应用 总结 装饰器 概念 装饰器就是个闭包;把一个函数当做参数,返回一个修改过功能的函数; 本质上是一个返回函数的函数。…

同旺科技 USB 转 RS-485 适配器 -- 隔离型(定制款)

内附链接 1、USB 转 RS-485 适配器 隔离版主要特性有: ● 支持USB 2.0/3.0接口,并兼容USB 1.1接口; ● 支持USB总线供电; ● 支持Windows系统驱动,包含WIN10 / WIN11 系统32 / 64位; ● 支持Windows …

三维gis中用纹理限定多边形地理区域

在三维 gis 中经常需要在指定的多边形地理范围内做一些操作,比如地形的多边形裁剪、压平多边形区域内的倾斜摄影模型、在指定地理范围内绘制等间距的点等。这都涉及到限定多边形区域的问题。 所谓的限定多边形地理区域,核心问题在于判断某个片元是否处于…

Python入门学习篇(四)——if详解

if详解 1 单项分支 1.1 语法结构 if 条件:逻辑代码(条件为真时执行的代码) # 注: 如果条件不满足,那么则不执行if下面的逻辑代码1.2 示例代码 username input("请输入您的用户名: ") if username "admin":print("管理员登录成功")1.3 运行…

python环境的搭建+pytharm安装教程

一、Anaconda安装 1、去官网下载anaconda >百度搜索anaconda按回车键 >找到官网地址进去(注意看网址) >下载位置 2、安装anaconda 具体就安装步骤就不演示了(写文章时已经安装好了) 二、pycharm安装 1、去官网下载py…

深信服防火墙设置应用控制策略(菜鸟必看)

PS:前几天发布了关于深信服防火墙路由部署的流程:深信服防火墙路由模式开局部署-手把手教学(小白篇)-CSDN博客 昨天晚上有csdn的朋友联系我,说有一个关于ACL访问的问题要帮忙看一下 解决了以后,写个大概的…

Python(八十九)函数的参数的内存分析

❤️ 专栏简介:本专栏记录了我个人从零开始学习Python编程的过程。在这个专栏中,我将分享我在学习Python的过程中的学习笔记、学习路线以及各个知识点。 ☀️ 专栏适用人群 :本专栏适用于希望学习Python编程的初学者和有一定编程基础的人。无…

[学习记录]Node event loop 总结流程图

文章目录 文章来源根据内容输出的流程图待处理遗留的问题参考 文章来源 详解JavaScript中的Event Loop(事件循环)机制 根据内容输出的流程图 待处理 这里从polling阶段开始 好像有些问题 遗留的问题 为什么“在I/O事件的回调中,setImmediate…

【动态规划】求最长递增子序列问题

目录 问题描述递推关系建立递推关系的思路约束条件:以 s [ k ] s[k] s[k] 结尾约束条件:以 s [ k ] s[k] s[k] 开头约束条件:增加子问题参数(前缀)约束条件:增加子问题参数(后缀)约束条件:LIS长度为k且末尾元素最小 运行实例 问…

mysql主从复制-redis集群扩容缩容、缓存优化(缓存更新策略、穿透,击穿,雪崩)、mysql主从搭建、django实现读写分离

基于Docker实现读写分离 1 redis集群扩容缩容 1.1 集群扩容 1.2 集群缩容 2 缓存优化 2.1 缓存更新策略 2.2 穿透,击穿,雪崩 3 mysql主从搭建 4 django实现读写分离 1 redis集群扩容缩容 1.1 集群扩容 # 6台机器,3个节点集群# 8台机器&am…

Blazor Select 实现点击一次选项触发一次后台事件

Blazor的官方案例中,Select组件只有两个事件 1、OnSelectedItemChanged 每次选项的时候改变触发,如果你点击同一个选项是不会触发后台的方法的 2、OnBeforeSelectedItemChange 我们可以用这个事件实现每次点击同一个选项都可以触发后台事件 需要注意下最…

同旺科技 USB 转 RS-485 适配器 -- 隔离型

内附链接 1、USB 转 RS-485 适配器 隔离版主要特性有: ● 支持USB 2.0/3.0接口,并兼容USB 1.1接口; ● 支持USB总线供电; ● 支持Windows系统驱动,包含WIN10 / WIN11 系统32 / 64位; ● 支持Windows …

电子学会C/C++编程等级考试2022年06月(三级)真题解析

C/C++等级考试(1~8级)全部真题・点这里 第1题:制作蛋糕 小A擅长制作香蕉蛋糕和巧克力蛋糕。制作一个香蕉蛋糕需要2个单位的香蕉,250个单位的面粉,75个单位的糖,100个单位的黄油。制作一个巧克力蛋糕需要75个单位的可可粉,200个单位的面粉,150个单位的糖,150个单位的黄…