【SLAM学习】罗德里格斯公式推导详细过程

2023-10-07 19:40

本文主要是介绍【SLAM学习】罗德里格斯公式推导详细过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目前,在进实验室之前自己学习SLAM,用的是高翔博士所著的《视觉SLAM十四讲》,其中涉及到罗德里格斯公式,这里讲自己的推导过程记录如下。

罗德里格斯公式如下:
在这里插入图片描述
上述公式是在视觉SLAM中常用的公式,可以讲旋转角变换为旋转矩阵,其中R为旋转矩阵,θ为绕轴旋转的角度,n为旋转轴方向的单位向量。

下面给出推导过程:
在这里插入图片描述
这是一个证明的辅助示意图(比较粗糙,不要见怪),大致是利用了向量的分解以及一些叉乘的知识。

证明

因为我们的最终目的是要的到旋转矩阵R,而所用到R的地方就是vrot =Rv,我们就要尽可能的用v来表示vrot
vrot = v + v//
vrot = a + b + v//
然后我们就把 a,b,v// 分别用 v 来表示就好了。
首先是 v//,从简单到难嘛,很容易看出来
v// = (v·nn
解释一下,v·n是一个内积,也就是向量vn上的投影,是一个数,然后再数乘n,变成一个方向和n相同,大小为v·n的向量,也就是v//.

然后是b,也不难看出
b = cosθ·v
这又是怎么得出来的呢,下面给出简单的推导。
b 应该是长度为 vrot 的膜乘-cosθ,方向与 v 相反,那么
b = ||vrot⊥||·(-cosθ)·(-v⊥n
这里注意cosθ是负的,继续推导,由于||vrot⊥||与||v||相等,
b = ||v||·cosθ·v⊥n
b = cosθ·v

最后是a,先给出a的结果
a = sinθ · n × v
b 的推导一样,a 的长度是 ||vrot⊥||·sinθ,方向是 n×v⊥n,那么
a = ||vrot⊥||·sinθ·n×v⊥n
又因为上面提到的||vrot⊥||与||v||相等,所以
a = ||v||·sinθ·n×v⊥n
a = sinθ·n×v
但是,由于我们最终要表现得形式是 vrotv 之间的,所以把上述a的表示变成由v表示,注意到,n× v 是膜为||n||·||v||·sin90° = ||n||·||v||,方向为n×v的向量,而 n × v 同样也是,所以直接替换
a = sinθ · n × v

到此为止,就把所有的向量用与 v 有关的向量来表示了,目前的推导公式已经变成了如下样子:

vrot = sinθ·n×v + cosθ·v + (v·nn

然而,此时还并没有转换为 vrot = Rv的形式,下面就要把所有的 v 的系数转化为矩阵。

首先第一项,可以直接利用叉乘进行转化,如果你看过《视觉SLAM十四讲》就对这个肯定不陌生,可以转化为 sinθ·n^·v
其中,n^大概就是左边矩阵的这个样子,这是规定好的,可以算一下,这样算出来和直接叉乘的结果一致,图中的 k 即为我所说的 n。
在这里插入图片描述

然后第二项,v = v - v//
所以原式 = cosθ·(v - (v·nn),就转化为了对第三项进行变换

最后是第三项,由数乘的交换律,(v·nn = n·(v·n),然后由于v·n = nT·v,所以原式转化为n·nT·v,前半部分转化为矩阵。

综上所述,最终可得(剩下的自己顺着写就出来了)
在这里插入图片描述
如有问题,欢迎留言~~~

这篇关于【SLAM学习】罗德里格斯公式推导详细过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/160013

相关文章

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Java Kafka消费者实现过程

《JavaKafka消费者实现过程》Kafka消费者通过KafkaConsumer类实现,核心机制包括偏移量管理、消费者组协调、批量拉取消息及多线程处理,手动提交offset确保数据可靠性,自动提交... 目录基础KafkaConsumer类分析关键代码与核心算法2.1 订阅与分区分配2.2 拉取消息2.3

Java中HashMap的用法详细介绍

《Java中HashMap的用法详细介绍》JavaHashMap是一种高效的数据结构,用于存储键值对,它是基于哈希表实现的,提供快速的插入、删除和查找操作,:本文主要介绍Java中HashMap... 目录一.HashMap1.基本概念2.底层数据结构:3.HashCode和equals方法为什么重写Has

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

AOP编程的基本概念与idea编辑器的配合体验过程

《AOP编程的基本概念与idea编辑器的配合体验过程》文章简要介绍了AOP基础概念,包括Before/Around通知、PointCut切入点、Advice通知体、JoinPoint连接点等,说明它们... 目录BeforeAroundAdvise — 通知PointCut — 切入点Acpect — 切面

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程