今日看点

电子罗盘的算法以及倾斜补偿算法

发表于话题:罗盘的使用方法入门
发布时间:2021-05-11

电子罗盘的算法以及倾斜补偿算法

基础扫盲1·地磁场2.矢量的叉积和点乘以及数据归一化2.1矢量的叉积2.2矢量的点乘2.3归一化算法1.利用旋转矩阵推导倾斜补偿公式2.利用使用矢量计算方法补偿倾斜

这两天在研究电子罗盘的算法,看了若干代码和文章后,终于弄明白了。就此文章总结一下。

基础扫盲

1·地磁场

 地球的磁场像一个条形磁铁。磁场方向是地磁南极指向地磁北极。在南北地磁点处的磁场和当地的水平面垂直,在赤道处的磁场和当地的水平面平行,所以在北半球地磁场方向向北倾斜指向地面。
 用来衡量磁感应强度的大小的单位是Tesla或者Gauss(1 T= 10000 G)。随着地理位置的不同,通常地磁场的强度是0.4-0.6Gauss。需要特别注意的是,地磁北极和地理的北极并不重合,通常相差11度左右的夹角。

 地磁场是一个矢量,对于一个固定的地点来说,这个矢量可以分解为两个与当地水平面平行的分量Hx和Hy与一个和当地水平面垂直的分量Hz。
如果保持电子罗盘(地磁传感器,本文章验证使用的是LSM303传感器,该传感器集成了加速度传感器和地磁传感器)和当地的水平面平行,则地磁传感器的三个轴就和这三个分量对应起来。
对于水平方向的两个分量来说,他们的矢量和总是指向地磁北的。罗盘中的航向角(Azimuth)就是当前方向和地磁北的夹角。在电子罗盘水平的情况下,只需要磁力计水平方向的两个轴(X轴和Y轴)的检测数据就可以用反正切函数arctan()求出(结果是弧度),当罗盘水平旋转时,航向角在0~360度之间变化。

2.矢量的叉积和点乘以及数据归一化

2.1矢量的叉积

 两个向量的叉乘,又叫向量积、外积、叉积,叉乘的运算结果是一个向量而不是一个标量。并且两个向量的叉积与这两个向量组成的坐标平面垂直。

对于向量a和向量b:

a和b的叉乘公式为:

其中:

根据i、j、k间关系,有:

叉乘几何意义
在三维几何中,向量a和向量b的叉乘结果是一个向量,更为熟知的叫法是法向量,该向量垂直于a和b向量构成的平面。

在3D图像学中,叉乘的概念非常有用,可以通过两个向量的叉乘,生成第三个垂直于a,b的法向量,从而构建X、Y、Z坐标系。如下图所示:
在二维空间中,叉乘还有另外一个几何意义就是:aXb等于由向量a和向量b构成的平行四边形的面积。、

2.2矢量的点乘

 向量的点乘,也叫向量的内积、数量积,对两个向量执行点乘运算,就是对这两个向量对应位一一相乘之后求和的操作,点乘的结果是一个标量。

点乘公式
对于向量a和向量b:

a和b的点积公式为:

在进行点乘计算时,要求一维向量a和向量b的行列数相同。

点乘几何意义
点乘的几何意义是可以用来表征或计算两个向量之间的夹角,以及在b向量在a向量方向上的投影,有公式:

2.3归一化

 向量归一化法有两种形式,一种是把数变为(0,1)之间的小数,一种是把有量纲表达式变为无量纲表达式。主要是为了数据处理方便提出来的,把数据映射到0~1范围之内处理,更加便捷快速。数据归一化的方法主要有线性函数法、对数函数法、反余切函数。
 对加速度计和磁力计的值进行归一化可以去掉其量纲,使它们可以放在一起计算。

算法

 在前文提到在地磁传感器水平放置的情况下可以由x轴和y轴的值通过arctan()函数计算出来。但是在实际使用中,地磁传感器并不是水平放置的,这个倾斜的夹角就会影响航向角的精度。这时候就要运用几何学去做倾斜补偿了。

1.利用旋转矩阵推导倾斜补偿公式

 电子罗盘的倾斜姿态可以通过三轴加速度传感器检测出,测出三个轴上重力加速度的分量,在通过计算可以得出Pitchg(俯仰角)和Roll(横滚角)。

 设在罗盘的翻滚角为γ\gamma,俯仰角为ϕ\phi,航向角为ψ\psi时,三轴地磁传感器的测量输出M(γ,ϕ,ψ)=[Mx  My  Mz]TM(\gamma,\phi,\psi)=[Mx \;My\;Mz ]^T;设罗盘水平放置时具有相同角的三轴地磁传感器的输出为M(0,0,ψ)=[MHz  MHy  MHz]TM(0,0,\psi)=[M_{Hz}\;M_{Hy}\;M_{Hz}]^T根据罗盘实际姿态和水平面的关系,可得
{M(γ,ϕ,ψ)=Rϕ Rγ M(0,0,ψ)M(0,0,ψ)=Rγ−1 Rϕ−1 M(γ,ϕ,ψ)(1) \begin{cases} M_{(\gamma,\phi,\psi)}=R_\phi\,R_\gamma\,M_{(0,0,\psi)} \\ M_{(0,0,\psi)}=R_\gamma^{-1}\,R_\phi^{-1}\,M_{(\gamma,\phi,\psi)} \end{cases} \text {(1)}
 其中Rϕ,RγR_\phi,R_\gamma分别为翻滚角γ\gamma和俯仰角ϕ\phi的旋转矩阵:

Rγ=[1000cosγsinγ0−sinγcosγ](2) R_\gamma= \begin{bmatrix} 1 & 0&0\\ 0 & cos\gamma & sin\gamma\\ 0 & -sin\gamma & cos\gamma\\ \end{bmatrix} \text {(2)}
Rϕ=[cosϕ0−sinϕ010sinϕ0cosγ](3) R_\phi= \begin{bmatrix}cos\phi & 0 & -sin\phi\\ 0 & 1 & 0\\ sin\phi & 0 & cos\gamma\\ \end{bmatrix} \text {(3)}
将式(2)式(3)带入式(1)得
{MHx=Mxcosϕ+MzsinϕMHy=Mxsinγsinϕ+Mycosγ−Mzsinγcosϕ(4) \begin{cases} M_{Hx}=M_xcos\phi+M_zsin\phi \\ M_{Hy}= M_xsin\gamma sin\phi+M_ycos\gamma-M_zsin\gamma cos\phi \end{cases} \text {(4)}
将式(4)带入反正切函数即可得到补偿后的航向角

附上手推公式过程

代码实现

2.利用使用矢量计算方法补偿倾斜

 利用地理(重力和地磁)矢量的方向不变的和可以任意平移的特点计算航向角可以直接忽略倾斜影响。本节内容全是作者的理解,若有不正确的地方欢迎指正。这个算法是arduino的一个库里面的,此算法厉害的地方是它对传感器的安装方式不是严格的。

矢量计算航向算法描述:利用加速度传感器读数确定向下的重力向量和地磁传感器确定的地磁向量的叉积可以得到指向东的向量。东向量和重力量的叉积是北向量(右手法则)。向东和向北的向量构成了水平面平面的基础。机体(电子罗盘)向量被投影到水平平面(点乘),在利用反正切函数即可求出航向角。这段文字里除了机体向量外,其他向量都是地理向量方向不变。

代码实现

关于入参from,这个和传感器安装的位置有关,比如地磁传感器的x轴与地磁场的x轴相反则入参为{-1,0,1}。其他安装方式以此类推。
至此本文完结。

标签组:[电子罗盘] [矢量运算] [地磁] [向量叉乘] [矢量数据] [平行向量

本文来源:https://www.kandian5.com/articles/9024.html

相关阅读

《临江仙》热播 杨谨睿二搭曾舜晞“超级加辈”

由爱奇艺出品,欢娱影视联合出品,智磊、国浩执导,白鹿、曾舜晞、领衔主演,的恨爱反转仙侠剧《临江仙》正在爱奇艺独播。该剧自开播热度就一路飙升,剧情也在随着播出在爱恨交织的纠葛里,摒弃了 &ldquo...

2025-06-13

《淬火年代》定档06.17 热血青年攻坚制造业自主创新之路

《淬火年代》改编自阿耐小说《艰难的制造》,由正午阳光出品,明大程编剧,李雪、赵烁执导,侯鸿亮担任总制片人,赵子煜担任制片人,张新成、宋祖儿领衔主演,王彦霖、任程伟、张月、何雨虹、刘奕铁、王影璐共同主演...

2025-06-13

韩警方逮捕试图入侵田柾国住宅的30多岁中国女性

据韩媒报道表示,首尔龙山警察局以涉嫌入侵住宅未遂的嫌疑逮捕了现行犯,30多岁的中国女性A某。据悉,A某于韩国时间昨晚11时20分左右来到位于首尔龙山区的防弹少年团成员田柾国的住宅,数次按大门的密码,...

2025-06-13

ZICO支援“挚友”都暻秀,参与其正规主打曲制作

12日据独家报道,ZICO参与了将于7月7日发行的都暻秀首张正规专辑《BLISS》的主打曲《SING ALONG!》的作曲及制作。据悉,两人从很久以前就积累了深厚的友谊,他们的缘分通过此次合作延续了...

2025-06-13

金秀贤首尔豪宅遭扣押 被广告主索赔30亿韩元

据韩媒报道,金秀贤12日再度传出遭广告主申请不动产假扣押,索赔金额高达30亿韩元(约1590万元)。对此,金秀贤的法律代理人表示,“广告主方面提出损害赔偿要求,并对(金秀贤持有的)位于首...

2025-06-13

ENHYPEN时隔约两年将在日本推出全新单曲《宵 -YOI-》

13日上午,ENHYPEN通过官方SNS宣布,日本第四张单曲《宵 -YOI-》将于7月29日正式发售。同时公开的Logo预告视频中,繁星闪烁的夜空中回荡着心跳声营造出梦幻氛围,更加激发了粉丝们对新曲...

2025-06-13

【韩娱看点】Netflix将调整韩国演员高片酬 限制最高上限

一直主导韩国电视剧制作费上涨的Netflix,近日开始着手调整演员的出演酬劳。根据业界消息,Netflix最近将演员出演酬劳的上限设定为每集最多4亿韩元。虽然这仍然是不小的金额,但Netflix的方...

2025-06-13

【韩娱看点】节目上闻私密部位气味?陆星材19禁表演被骂翻,韩网直呼:太恶心!

歌手兼演员的韩国艺人陆星材最近主演的SBS惊悚奇幻古装剧《鬼宫》正在热播,这也是他首次挑战古装史剧,首集便取得9.2%的高收视率,高于前两档作品《我的完美秘书》、《宝物岛》的开播收视率,成为截至当时...

2025-06-13

践土会盟:晋文公霸业巅峰与春秋秩序的重构

践土会盟是春秋时期晋文公重耳主持的一次具有里程碑意义的诸侯盟会。公元前632年,晋国在城濮之战中击败楚国后,联合齐、宋、鲁、蔡、郑、卫、莒等国,于践土(今河南原阳西南)举行会盟。此次盟会不仅确立了晋国...

2025-06-13

薄姬:从魏豹宠妾到汉室太皇太后的传奇人生

在中国古代宫廷史上,薄姬(前223年—前155年)的命运堪称一部跌宕起伏的史诗。这位出身卑微的私生女,历经秦末乱世、楚汉相争、吕后专权,最终以汉文帝生母的身份登上权力巅峰,其人生轨迹不仅折射出汉初政治...

2025-06-13