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

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

基础扫盲

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 ( γ , ϕ , ψ ) = [ M x    M y    M z ] T M(\gamma,\phi,\psi)=[Mx \;My\;Mz ]^T M(γ,ϕ,ψ)=[MxMyMz]T;设罗盘水平放置时具有相同角的三轴地磁传感器的输出为 M ( 0 , 0 , ψ ) = [ M H z    M H y    M H z ] T M(0,0,\psi)=[M_{Hz}\;M_{Hy}\;M_{Hz}]^T M(0,0,ψ)=[MHzMHyMHz]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)} {M(γ,ϕ,ψ)=RϕRγM(0,0,ψ)M(0,0,ψ)=Rγ1Rϕ1M(γ,ϕ,ψ)(1)
 其中 R ϕ , R γ R_\phi,R_\gamma Rϕ,Rγ分别为翻滚角 γ \gamma γ和俯仰角 ϕ \phi ϕ的旋转矩阵:

R γ = [ 1 0 0 0 c o s γ s i n γ 0 − s i n γ c o s γ ] (2) R_\gamma= \begin{bmatrix} 1 & 0&0\\ 0 & cos\gamma & sin\gamma\\ 0 & -sin\gamma & cos\gamma\\ \end{bmatrix} \text {(2)} Rγ=1000cosγsinγ0sinγcosγ(2)
R ϕ = [ c o s ϕ 0 − s i n ϕ 0 1 0 s i n ϕ 0 c o s γ ] (3) R_\phi= \begin{bmatrix}cos\phi & 0 & -sin\phi\\ 0 & 1 & 0\\ sin\phi & 0 & cos\gamma\\ \end{bmatrix} \text {(3)} Rϕ=cosϕ0sinϕ010sinϕ0cosγ(3)
将式(2)式(3)带入式(1)得
{ M H x = M x c o s ϕ + M z s i n ϕ M H y = M x s i n γ s i n ϕ + M y c o s γ − M z s i n γ c o s ϕ (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)} {MHx=Mxcosϕ+MzsinϕMHy=Mxsinγsinϕ+MycosγMzsinγcosϕ(4)
将式(4)带入反正切函数即可得到补偿后的航向角
在这里插入图片描述
附上手推公式过程
在这里插入图片描述
代码实现
在这里插入图片描述

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

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

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

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

  • 11
    点赞
  • 57
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
STM32是一款广泛使用的微控制器系列,可以用来驱动电子罗盘电子罗盘是一种能够感知地球磁场并测量方向的装置。下面我将简要介绍一下如何使用STM32驱动电子罗盘。 首先,我们需要将电子罗盘连接到STM32的GPIO引脚上。通常,电子罗盘会有两个输出引脚,一个用于将数据传输给STM32的数据引脚,另一个用于触发数据读取的时钟引脚。我们需要将这两根引脚与STM32的相应引脚进行连接,以实现数据的传输和通信。 接下来,我们需要在STM32上编写相应的驱动程序来读取电子罗盘的数据。我们可以使用STM32提供的GPIO库函数来配置和控制引脚的状态和功能。在读取数据之前,我们需要初始化相关的GPIO引脚,并设置正确的参数,例如时钟频率和数据位宽等。然后,我们可以使用SPI或I2C等通信协议来与电子罗盘进行通信,通过读取和写入寄存器来获取所需的数据。 一旦我们成功读取了电子罗盘的数据,我们可以使用STM32的其他库函数和功能来处理和分析这些数据。例如,我们可以利用数学算法来计算方向角度或航向角度,并将其显示在适当的输出设备上,如LCD屏幕或串口终端。 总结起来,驱动电子罗盘需要连接电子罗盘到STM32的GPIO引脚,配置和控制引脚的操作,并使用适当的通信协议与电子罗盘进行数据交换。然后,我们可以使用STM32的库函数和算法来处理和显示电子罗盘的数据。希望以上的回答能够对你有所帮助!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值