基于加速度计与磁力计的姿态解算方法(加计补偿偏航)

2023-05-16

附上转载文章链接
加速度计实时输出机体坐标系下的三轴线加速度,磁力计实时输出机体坐标系下的三轴地磁强度,加速度计能解算出俯仰角与横滚角,由磁力计计算出航向角,两者相互配合可以解算三个姿态角信息。

1.计算roll和pitch
当多旋翼无人机在地理坐标系中静止时, 加速度计的量测输出为:
a n = [ 0 0 g ] T a_n = [0 \quad 0 \quad g]^T an=[00g]T
其中g 为重力加速度。

当多旋翼无人机处于任意姿态时,加速度计在机体坐标系中的测量输出为:
a b = [ a x a y a z ] T a_b=[a_x \quad a_y \quad a_z]^T ab=[axayaz]T

我们知道地理坐标系的速度可以通过旋转矩阵得到机体坐标系下的数据:
[ a x a y a z ] = C b n [ 0 0 g ] = [ c o s ψ c o s θ s i n ψ c o s θ − s i n θ c o s ψ s i n θ s i n γ − s i n ψ c o s γ s i n ψ s i n θ s i n γ + c o s ψ c o s γ c o s θ s i n γ c o s ψ s i n θ c o s γ + s i n ψ s i n γ s i n ψ s i n θ c o s γ − c o s ψ s i n γ c o s θ c o s γ ] [ 0 0 g ] = [ − g s i n θ g c o s θ s i n γ g c o s θ c o s γ ] \begin{bmatrix}a_x \\ a_y \\ a_z\end{bmatrix} = \textbf{C}_b^n \begin{bmatrix}0 \\ 0 \\ g\end{bmatrix} \\ =\begin{bmatrix} cosψcosθ & sinψcosθ & −sinθ \\ cosψsinθsinγ−sinψcosγ & sinψsinθsinγ+cosψcosγ & cosθsinγ \\ cosψsinθcosγ+sinψsinγ & sinψsinθcosγ−cosψsinγ & cosθcosγ \end{bmatrix} \begin{bmatrix}0 \\ 0 \\ g\end{bmatrix} \\ =\begin{bmatrix}−gsinθ \\ gcosθsinγ \\ gcosθcosγ\end{bmatrix} axayaz =Cbn 00g = cosψcosθcosψsinθsinγsinψcosγcosψsinθcosγ+sinψsinγsinψcosθsinψsinθsinγ+cosψcosγsinψsinθcosγcosψsinγsinθcosθsinγcosθcosγ 00g = gsinθgcosθsinγgcosθcosγ

所以:
θ = a r c s i n ( − a x g ) γ = a r c t a n ( a y a z ) θ=arcsin(-\frac{a_x}{g}) \\ γ=arctan(\frac{a_y}{a_z}) θ=arcsin(gax)γ=arctan(azay)
2.计算yaw
多旋翼无人机在地理坐标系( 导航坐标系) 下磁感应强度表示为:
m n = [ m x n m y n m z n ] T \textbf{m}_n=[m^n_x \quad m^n_y \quad m^n_z]^T mn=[mxnmynmzn]T
地磁场是一个矢量,对于一个固定的地点来说,这个矢量可以被分解为两个与当地水平面(即地理坐标系的xy平面)平行的分量和一个与当地水平面(即地理坐标系的xy平面)垂直的分量。

如果保持电子罗盘和当地的水平面平行,那么罗盘中磁力计的三个轴就和这三个分量对应起来,即罗盘水平状态下,测量的三个轴数据就是机体系下的地磁分量,因为此时罗盘所在的坐标系的x,y,z轴和机体系以及地理坐标系的指向是一致的。

对水平方向的两个分量来说,他们的矢量和总是指向磁北的,所以我们只需要水平的磁力分量即可算出传感器x轴与磁北的夹角:
ψ m = a r c t a n ( m y n m x n ) ψ_m=arctan(\frac{m_y^n}{ m^n_x}) ψm=arctan(mxnmyn)
如果我们认为磁北是0度,那我们就可以得到当前的偏航角。

但是我们不能保证当前的机体绝对水平,即机体系和地理坐标系的指向并不一致,所以我们需要把机体下的传感器数据转换到水平面(即地理坐标系下)。

怎么转换呢?当然是使用旋转矩阵啦。但是我们只需要旋转roll和pitch。

所以令旋转矩阵,yaw为0,即yaw不旋转。根据旋转顺序ZYX可得:
C b n ′ = [ c o s θ s i n θ s i n γ s i n θ c o s γ 0 c o s γ − s i n γ − s i n θ c o s θ s i n γ c o s θ c o s γ ] \textbf{C}^{n'}_{b}=\begin{bmatrix}cosθ & sinθsinγ & sinθcosγ \\ 0 & cosγ & −sinγ \\ −sinθ & cosθsinγ & cosθcosγ\end{bmatrix} Cbn= cosθ0sinθsinθsinγcosγcosθsinγsinθcosγsinγcosθcosγ
磁力计的输出是在机体坐标系下的磁感应强度,表示为:
m b = [ m x b m y b m z b ] T \textbf{m}_b=[m^b_x \quad m^b_y \quad m^b_z]^T mb=[mxbmybmzb]T
可知 m n m_n mn m b m_b mb关系式为:
m n = C b n ′ m b \textbf{m}_n=\textbf{C}^{n′}_b \textbf{m}_b mn=Cbnmb
带入已知条件可以得:
[ m x n m y n m z n ] = C b n ′ [ m x b m y b m z b ] = [ c o s θ s i n θ s i n γ s i n θ c o s γ 0 c o s γ − s i n γ − s i n θ c o s θ s i n γ c o s θ c o s γ ] [ m x b m y b m z b ] = [ m x b ∗ c o s θ + m y b ∗ s i n θ ∗ s i n γ + m z b ∗ s i n θ ∗ c o s γ m y b ∗ c o s γ − m z b ∗ s i n γ − m x b ∗ s i n θ − m y b ∗ s i n γ ∗ c o s θ + m z b ∗ c o s θ ∗ c o s γ ] = [ m x b ∗ c o s ( p i t c h ) + m y b ∗ s i n ( p i t c h ) ∗ s i n ( r o l l ) + m z b ∗ s i n ( p i t c h ) ∗ c o s ( r o l l ) m y b ∗ c o s ( r o l l ) − m z b ∗ s i n ( r o l l ) m x b ∗ s i n ( p i t c h ) − m y b ∗ s i n ( r o l l ) ∗ c o s ( p i t c h ) + m z b ∗ c o s ( p i t c h ) ∗ c o s ( r o l l ) ] \begin{bmatrix}m^n_x \\ m^n_y \\ m^n_z\end{bmatrix}=\textbf{C}^{n′}_b \begin{bmatrix}m^b_x \\ m^b_y \\ m^b_z\end{bmatrix}\\ =\begin{bmatrix}cosθ & sinθsinγ & sinθcosγ \\ 0 & cosγ & −sinγ \\−sinθ & cosθsinγ & cosθcosγ\end{bmatrix} \begin{bmatrix} m^b_x \\ m^b_y \\ m^b_z \end{bmatrix} \\ =\begin{bmatrix}m^b_x∗cosθ+m^b_y∗sinθ∗sinγ+m^b_z∗sinθ∗cosγ \\ m^b_y∗cosγ−m^b_z∗sinγ \\ −m^b_x∗sinθ−m^b_y∗sinγ∗cosθ+m^b_z∗cosθ∗cosγ \end{bmatrix} \\ =\begin{bmatrix}m^b_x∗cos(pitch)+m^b_y∗sin(pitch)∗sin(roll)+m^b_z∗sin(pitch)∗cos(roll) \\ m^b_y∗cos(roll)−m^b_z∗sin(roll) \\ m^b_x∗sin(pitch)−m^b_y∗sin(roll)∗cos(pitch)+m^b_z∗cos(pitch)∗cos(roll) \end{bmatrix} mxnmynmzn =Cbn mxbmybmzb = cosθ0sinθsinθsinγcosγcosθsinγsinθcosγsinγcosθcosγ mxbmybmzb = mxbcosθ+mybsinθsinγ+mzbsinθcosγmybcosγmzbsinγmxbsinθmybsinγcosθ+mzbcosθcosγ = mxbcos(pitch)+mybsin(pitch)sin(roll)+mzbsin(pitch)cos(roll)mybcos(roll)mzbsin(roll)mxbsin(pitch)mybsin(roll)cos(pitch)+mzbcos(pitch)cos(roll)

通过这个旋转,我们就把机体坐标系的数据,变成了地理坐标系下的数据,也就是机体水平的情况下,磁力计测量的数据值。

注意z轴的正负(原始数据是z轴朝上为正)
m x n = m x b c o s θ + m y b s i n θ s i n γ + m z b s i n θ c o s γ m^n_x=m^b_xcosθ+m^b_ysinθsinγ+m^b_zsinθcosγ mxn=mxbcosθ+mybsinθsinγ+mzbsinθcosγ
m y n = m y b c o s γ − m z b s i n γ m^n_y=m^b_ycosγ−m^b_zsinγ myn=mybcosγmzbsinγ

用同样的方法求得x轴与磁北的夹角:
ψ m = a r c t a n ( m y n m x n ) ψ_m=arctan(\frac{m^n_y}{m^n_x}) ψm=arctan(mxnmyn)
磁力计所解算的航向角是机体坐标x轴相对于磁北而言的,而真北与磁北之间存在一个磁偏角 Δ ψ Δψ Δψ

所以机体坐标纵轴相对于真北的航向角为:
ψ = ψ m + Δ ψ ψ=ψ_m+Δψ ψ=ψm+Δψ

这里有几个隐藏添加条件要注意:

1.我们使用的是zyx顺序旋转。

2.传感器x轴,对齐机体x轴;传感器y轴,对齐机体y轴时yaw为0度。

3.加计和陀螺仪的坐标系是完全重合的。

提问:计算出来的夹角是正还是负?

和机体坐标系有关,如果z轴朝下,那么机体的旋转正方向为顺时针,那么得到的偏航角就是负的。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

基于加速度计与磁力计的姿态解算方法(加计补偿偏航) 的相关文章

  • Verilog学习之路(1)— Quartus II 13.0下载安装和HelloWorld

    Verilog学习之路 xff08 1 xff09 Quartus II 13 0下载安装和HelloWorld 一 前言 Quartus II是Altera的FPGA设计工具 xff0c 二 安装包下载 百度云链接地址 xff1a htt
  • Verdi使用方法(1)— 打开user guide和加载波形

    Verdi使用方法 xff08 1 xff09 打开user guide和加载波形 一 在linux上快速打开user guide 在安装有Verdi的Linux服务器上输入如下命令即可快速的打开Verdi的user guide verdi
  • Verdi使用方法(2)— 高效对比两个波形

    Verdi使用方法 xff08 2 xff09 高效对比两个波形 一 打开第一个波形 直接使用如下命令打开一个波形 xff1a verdi tb1 fsdb 加载需要的信号 二 新建一个容器 点击 Window gt Dock to gt
  • C++ 实现 发送HTTP Get/Post请求

    1 简述 最近简单看了一下关于HTTP请求方面的知识 xff0c 之前一直用Qt来实现 xff0c 有专门HTTP请求的QNetworkAccessManager类来处理 xff0c 实现也比较简单 xff0c 这里主要讲解一下用C 43
  • Python学习之路(4)— 正则表达式(一)

    Python学习之路 xff08 4 xff09 正则表达式 一 一 前言 参考文章 xff1a 爬虫要讲武德 xff0c 你却用正则 一篇文章搞定正则表达式 xff01 参考视频 xff1a 硬核Python进阶篇 一小时掌握正则表达式
  • vs code 远程连接服务器(超详细,图文说明)

    工作中需要使用vs code远程连接服务器 xff0c 网上找了好多教程 xff0c 发现没有完善的说明 xff0c 对我这种小白来说真是耗时耗力 xff0c 完成连接后 xff0c 特地把搭建过程图文分享出来 1 安装完vs code后
  • Jetson TX2 --GPIO 库使用(点亮一个LED灯)

    项目介绍 Jetson GPIO Jetson TX2 J21有40个引脚 xff0c 类似于树莓派的40个引脚 xff0c 可以通过Jetson GPIO samples包中提供的python库控制输入输出 该库与Raspberry Pi
  • 机械键盘改热插拔

    所需原料 电烙铁 大概就十几块而已 我计算机系的 不常用 贵了浪费焊锡丝 大概20g就足够挥霍也就几块钱 松香 买的时候让卖家送一点 这个很便宜鸡心眼m1 3买大概250个把 每个按键需要两个 还有一种m1 0的是改灯的 当初买了一千个才十
  • ROS知识

    按规范学习 直接开始学习ROS文件目录结构 转载 https zhuanlan zhihu com p 139405796 常用操作 xff1a 启动测试和订阅服务和话题 小白先熟悉ROS和M300的操作 xff1a ubuntu18 04
  • Ubuntu18.04 ,安装opencv4.5.4

    背景 手眼标定时候 xff0c 需要用到opencv4的findChessboardCornersSB 所以需要下载opencv4 5 4 安装 Ubuntu 18 04 安装opencv4 2 0 遇到的问题 安装结束后 xff0c 出现
  • ubuntu播放文件需要MPEG-4 AAC解码器

    即可
  • 类模板成员函数定义问题

    span class token macro property span class token directive keyword include span span class token string 34 pch h 34 span
  • 视觉SLAM面试题汇总(三)

    北京某自动驾驶公司 xff1a 1 点云的聚类 xff1b 求法向量 xff1b 多个点集 xff0c 求点集的法向量 xff1b 2 LM算法里面lamda的作用 xff1b 3 KD Tree 4 描述子距离的匹配的方法 xff1f 除
  • ORB-SLAM2中关键知识点总结

    目录 1 ORB SLAM2的总体框架是怎样的 xff1f 2 ORB SLAM2是怎样完成初始化的 xff1f 3 ORB SLAM2是如何进行Tracking的 xff1f 4 ORB SLAM2是如何选取关键帧的 xff1f 5 OR
  • RS485知识点

    为什么RS485空闲时的电平要求大于 43 200mv 这不是很容易被接收端接收吗 xff1f a 其实 xff0c 如果RS485的AB线空闲电平如果小于 43 200mv xff0c 485芯片的输出不定 xff0c 有些芯片会输出高
  • 两种点云地面去除方法

    目录 1 基于角度分割的地面 非地面分割 1 1 PCL基本入门 1 1 1 在ROS项目中引入PCL库 1 2 编写节点进行Voxel Grid Filter 1 2 1 验证效果 1 3 点云地面过滤 1 3 1 点云剪裁和过滤 去除过
  • ROS面试题汇总

    1 ROS中订阅 xff08 Subscribe xff09 最新消息以及消息队列相关问题 机器人应用中难免会遇到运算起来很费时间的操作 xff0c 比如图像的特征提取 点云的匹配等等 有时候 xff0c 不可避免地 xff0c 我们需要在
  • VINS-Mono后端知识点汇总

    processImage xff1a 每帧都干了什么 谁是Featureanager xff1a 维护路标点与图像 后端干了啥 xff1a 详解因子图 xff08 视觉的因子图 IMU的因子图 因子图和Hessian矩阵的关系 xff09
  • VINS-Mono学习(二)——松耦合初始化

    初始化 xff1a 如何当好一个红娘 xff1f 图解SfM 视觉和IMU的羁绊 怎么知道发生了闭环 xff1f 位姿图优化与滑窗优化都为哪般 xff1f 闭环优化 xff1a 拉扯橡皮条 整体初始化流程如下 xff1a 1 SFM纯视觉估
  • VINS知识点汇总

    0 总体框架 包括5个部分 xff1a 数据预处理 初始化 后端非线性优化 闭环检测 位姿图优化 图片来自大佬博客 xff1a https blog csdn net try again later article details 1048

随机推荐

  • 语义SLAM综述

    1 摘要 SLAM技术在计算机视觉和机器人领域中占有重要低位 传统的SLAM框架采用了较强的静态世界假设 xff0c 便于分析 大多基于小区域静态环境 在大规模的动态环境下 xff0c 它们大多难以获得较好的性能 xff0c 系统的准确性
  • VINS-Mono学习(三)——基于滑动窗口的VIO紧耦合后端非线性优化

    nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp 初始化后 采用基于滑动窗口的紧耦合单目VIO进行状态估计 首先来看VINS Mono后端的整体思路 nbsp nbsp nbsp nbsp nbsp nbsp
  • VINS-Mono学习(五)——闭环优化4DoF

    这里再重写一边VINS开启的新线程 xff1a 前端图像跟踪后端非线性优化闭环检测闭环优化 闭环优化是跟在闭环检测之后步骤 首先回顾闭环检测的过程 xff1a 1 pose graph node cpp开启process闭环检测线程 xff
  • C语言预定义跟踪调试

    标准C语言预处理要求定义某些对象宏 xff0c 每个预定义宏的名称一两个下划线字符开头和结尾 xff0c 这些预定义宏不能被取消定义 xff08 undef xff09 或由编程人员重新定义 下面预定义宏表 xff0c 被我抄了下来 LIN
  • 链式存储

    1 特点 线性表的链式存储结构的特点是用一组任意的存储单元存储线性表的数据元素 xff0c 这组存储单元可以是连续的 xff0c 也可以是不连续的这就意味着 xff0c 这些数据元素可以存在内存未被占用的任意位置 2 结点是什么 在数据结构
  • ROS驱动包无法连接A2M7雷达解决办法

    我在使用A2M7雷达时 xff0c 波特率是256000 xff0c 之前驱动跑A2M6和A2M8雷达时 xff0c 波特率115200 xff0c 都可以使用 xff0c 现在跑M7就不行 xff0c 显示无法绑定到串口 xff0c 刚开
  • FreeRTOS prvTaskExitError 创建任务错误

    文件port c prvTaskExitError 任务退出错误 xff0c 一个可能在任务里面写了return xff0c 另一个可能任务切换退出问题 xff0c 入栈和出栈的时候出了问题 1 static void prvTaskExi
  • Ubuntu18.04下VSCode环境编写Linux相关驱动程序时出现未定义标识符问题

    Ubuntu18 04下VSCode环境编写Linux相关驱动程序时出现未定义标识符问题 编译Linux相关驱动程序时 xff0c 出现未定义标识符问题 但是ctrl 43 鼠标左键可以找到相关定义 这是因为没有加载对应Linux内核中头文
  • postman基础使用教程

    Postman教程大全 简书 推荐一款接口测试工具 xff01 POSTMAN xff01 简单来说 xff0c 四个词 xff0c 简单实用大方美观 xff01 Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插
  • Make、Makefile、CMake和CMakeLists

    一 Make 在 认识编译器和C C 43 43 编译 一文中介绍过 xff0c 一个 c cpp 文件从源文件到目标文件的过程叫做编译 xff0c 但是一个项目中不可能只存在一个文件 xff0c 这就涉及到多个文件的编译问题 xff0c
  • C++将类写在头文件中

    比如有个类ABC要在main cpp内使用 xff0c 创建两个文件 ABC h xff0c ABC cpp 把类的声明都写在h里面 xff0c 方法的实现写在cpp里面 xff0c 然后在main cpp内 include ABC h x
  • ubuntu搭建一个简单的http服务器

    使用ubuntu搭建一个简单的http服务器 安装apache2 1 sudo apt get update 2 sudo apt get install apache2 安装成功后 xff0c 再 etc apache2目录可见其配置文件
  • Postman操作基本教程

    一 xff1a 基本介绍 xff1a Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插件 Postman背景介绍 用户在开发或者调试网络程序或者是网页B S模式的程序的时候是需要一些方法来跟踪网页请求的 xff0
  • ROS中rosserial通讯协议初探

    ROS中rosserial通讯协议初探 串行的通讯 xff0c 我们用串口模拟下通讯图 官方 http wiki ros org rosserial rosserial 1概述 标准ROS序列化message的协议 xff0c 可以让一个字
  • 使用cmake交叉编译arm平台so

    使用cmake交叉编译arm平台so 众所周知 xff0c androidStudio可以编译apk及so 具体配置此处不一一介绍 xff0c 但对于需要经常编译不同项目的小编来说 xff0c 太过重量级了 xff0c 假如在编译系统下并没
  • Linux编译C文件

    熟悉了Windows平台下编译一个C 43 43 工程后 xff0c 你是否会提出这样一个问题 xff1a 在Linux平台下又如何编译一个C 43 43 工程呢 xff1f 希望本文能给正在学习或想学习Linux C 43 43 开发的你
  • stm32 esp8266 ota升级-qt bin文件处理工具

    stm32 esp8266 ota系列文章 xff1a stm32 esp8266 ota 快速搭建web服务器之docker安装openresty stm32 esp8266 ota升级 tcp模拟http stm32 esp8266 o
  • 04.Android调用C语言的方法

    为了在Android端调用底层的驱动程序 xff0c 我们需要在Android中调用C语言 直接新建一个Native C 43 43 工程 xff0c 然后按照这篇文章的方法 xff1a JNI与NDK简析 xff08 一 xff09 St
  • gazebo教程---使用gazebo插件

    一 添加传感器插件 xff08 1 xff09 在rrbot xacro中添加 lt link gt 和 lt joint gt xff0c 内容如下 xff1a lt joint name 61 span class token stri
  • 基于加速度计与磁力计的姿态解算方法(加计补偿偏航)

    附上转载文章链接 加速度计实时输出机体坐标系下的三轴线加速度 xff0c 磁力计实时输出机体坐标系下的三轴地磁强度 xff0c 加速度计能解算出俯仰角与横滚角 xff0c 由磁力计计算出航向角 xff0c 两者相互配合可以解算三个姿态角信息