CN104898681A - 一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法 - Google Patents

一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法 Download PDF

Info

Publication number
CN104898681A
CN104898681A CN201510221435.3A CN201510221435A CN104898681A CN 104898681 A CN104898681 A CN 104898681A CN 201510221435 A CN201510221435 A CN 201510221435A CN 104898681 A CN104898681 A CN 104898681A
Authority
CN
China
Prior art keywords
omega
attitude
hypercomplex number
quadrotor
sign
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201510221435.3A
Other languages
English (en)
Other versions
CN104898681B (zh
Inventor
张丹
叶孝璐
肖紫阳
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Zhejiang University of Technology ZJUT
Original Assignee
Zhejiang University of Technology ZJUT
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Zhejiang University of Technology ZJUT filed Critical Zhejiang University of Technology ZJUT
Priority to CN201510221435.3A priority Critical patent/CN104898681B/zh
Publication of CN104898681A publication Critical patent/CN104898681A/zh
Application granted granted Critical
Publication of CN104898681B publication Critical patent/CN104898681B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Abstract

一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法,包括以下步骤:1)根据三阶近似毕卡四元数来进行姿态解算,避免了陀螺仪的积分累积误差,降低了噪声的微分放大;2)将解算得到的姿态角进行卡尔曼滤波,有效消除了四旋翼飞行器机体振动引起的传感器测量误差,得到更准确的姿态角。本发明所设计姿态解算方法能够对小型四旋翼飞行器进行精确的姿态估计。

Description

一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法
技术领域
本发明应用于四旋翼飞行器姿态控制领域,涉及到四旋翼飞行器姿态控制问题,尤其是如何避免陀螺仪的积分累积误差,消除四旋翼飞行器机体振动引起的传感器测量误差,实现一种有效的实时控制方法。
背景技术
四旋翼飞行器是四桨非共轴多旋翼飞行器的简称。作为非共轴多旋翼飞行器的代表,与固定翼无人机相比,具有结构简单、体积小、隐蔽性强、载荷高、可垂直起降、定点悬停和低速飞行等优势,能执行各种危险的特殊任务,比如航拍、灾害现场监视与求援、低空侦探与检测等,在民用领域和军事领域均体现出极高的研究和应用价值。四旋翼飞行器是无人机飞行器领域中的一个热点研究课题,随着纳米级低雷诺数空气动力学与MEMS技术的深入研究,四旋翼飞行器在近些年得到了快速的发展。
四旋翼飞行器虽然结构简单,但其是一个多变量、强耦合的非线性系统,且机体与外界和自身的干扰十分敏感,使得飞行器姿态估计和控制系统的设计变得十分困难。四旋翼飞行器4个旋桨高速运转时,相互作用产生的气流十分复杂,以至机体产生高频振颤,而这种高频干扰会引入到惯导系统的传感器输出中。
本发明主要考虑如何有效地进行四旋翼飞行器的姿态获取并避免惯导传感器输出中的高频噪声。通常姿态获取的算法常用的有欧拉角法、方向余弦法、四元数法等。欧拉角法解算过程中包含大量的三角运算,计算量很大,并且在俯仰角接近90时方程会出现退化现象,不适用于全姿态的姿态角解算。方向余弦法能进行全姿态获取,但计算量大,实时计算困难。四元数法计算量小、实用,但无法避免陀螺仪累积的积分误差问题。
发明内容
为了克服上述提到的现有姿态获取方法的局限性,本发明提出三阶近似毕卡四元数算法进行姿态获取。将三阶近似毕卡四元数与卡尔曼滤波相结合,避免了陀螺仪的积分累积误差,有效消除了四旋翼飞行器机体振动引起的传感器测量误差。
本发明解决其技术问题所采用的技术方案:
一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法,包括以下步骤:
步骤1)为了验证算法的可行性,首先建立一个飞行器实验平台,所述平台的硬件系统以3个STM32F103VET6控制芯片为核心划分为三大部分。
第一部分是主控制器和惯性导航系统的电路设计。主控芯片釆用的是STM32,进行姿态获取和姿态控制。惯性导航系统是采集飞行器机体的运动状态信息作为控制系统控制的重要信息依据。惯性导航平台的反馈精度直接影响到控制系统的控制精度。本项目的惯性导航系统由6轴运动处理组件MPU6050、电子罗盘HMC5883和气压计MS5611组成。
第二部分是以STM32控制芯片,用OV7620数字摄像头做图像信息采集和四旋翼飞行器飞行数据处理的信息处理部分,与第一部分的芯片用USART接口进行通信,与第三部分用蓝牙模块进行通信。
第三部分是用STM32设计UC/OSII嵌入式系统下位机,使用蓝牙与四旋翼飞行器进行通信,用作人机交互以及图像数据传输的中间站,能够完成飞行器各个状态之间的切换以及数据的接收显示。
步骤2)数据的预处理,具体方案如下:
在飞行器的姿态控制中,姿态数据通常由传感器获取,但是单个传感器获取的信息往往不精确。因此,在进行姿态估计之前,需要对传感器的原始数据进行预处理,以下主要简述3部分:加速度计校准及滤波、陀螺仪静态偏置的计算(陀螺仪零偏)以及磁力计的偏心矫正及滤波。
(1)加速度计校准及滤波
由于加速度传感器的测量值必然存在误差,因此,有必要在使用前对其进行校准,使用时对其进行滤波。这里使用均值滤波及滑动平均滤波的方式对加速度计的测量信息进行处理。
(2)陀螺仪零偏计算
陀螺仪存在静态偏置即零偏,因此在每一次系统初始化时需要对其零偏进行计算并在之后的计算中除去零偏。先将陀螺仪静置,连续读取200次陀螺仪的测量值进行均值滤波,并将其作为陀螺仪的零偏。
(3)磁力计偏心矫正及倾斜补偿
理论上,磁力计的三个轴的测量值范围是对称的,即在空间中呈球体分布。然而,由于传感器的误差以及外界磁场的干扰,本文所得到的磁力计测量值是一个中心不在原点的椭球体,因此需要对其测量值进行偏心校正。基本步骤为:
a.将磁力计水平旋转360度计算其X轴与Y轴最大值与最小值,由此计算修正增益XS与YS,修正偏置Xb与Yb
这里以X轴为基准,令XS=1。
Y s = ( X max - X min ) ( Y max - Y min ) - - - ( 15 )
X b = X s [ 1 2 ( X max - X min ) - X max ] Y b = Y s [ 1 2 ( Y max - Y min ) - Y max ]
b.Xin、Yin和Zin为磁力计的测量输出值,通过修正增益与修正偏置计算磁力计的修正值Xout和Yout
X out = X s × X in + X b Y out = Y s × Y in + Y b - - - ( 17 )
c.同样以X轴为基准,对Z轴进行矫正,最终得到三个轴的修正值Xout、Yout和Zout
X out = X s × X in + X b Y out = Y s × Y in + Y b Z out = Z s × Z in + Z b - - - ( 18 )
步骤3)设计基于毕卡四元数的四旋翼飞行器姿态获取,过程包括:
设由四旋翼的机体轴确定的坐标系为b,地面坐标系为n,则由b系到n系的坐标矩阵称为四旋翼的姿态矩阵,θ、γ、分别为飞机的俯仰、横滚、偏航角,加速度计输出的原始值为速度的增量即abx、aby、abz,陀螺仪计输出为角增量即gbx、gby、gbz,磁力计mbx、mby、mbz
(1)欧拉角初始化
(2)四元数初始值的确定及规范化处理
四旋翼飞行器的四元数的初始值Q(0)由捷联系统的初值状态对准确定。设初始对准的姿态阵为可由式(1)中求得的公式计算得出初始姿态角求得。
C b 0 n = c 11 c 12 c 13 c 21 c 22 c 23 c 31 c 32 c 33 - - - ( 2 )
其中,c11、c12、c13、c21、c22、c23、c31、c32、c33分别为
则四旋翼飞行器的四元数的初始值为:
Q ( 0 ) = q 0 + q 1 i → + q 2 j → + q 3 k → - - - ( 4 )
其中,q0、q1、q2、q3的数值和符号可按下式(5)和(6)确定。
| q 1 | = 1 2 1 + c 11 - c 22 - c 33 | q 2 | = 1 2 1 - c 11 + c 22 - c 33 | q 3 | = 1 2 1 - c 11 - c 22 - c 33 | q 0 | = 1 2 1 + c 11 + c 22 + c 33 - - - ( 5 )
sign ( q 1 ) = sign ( q 0 ) [ sign ( c 32 - c 23 ) ] sign ( q 2 ) = sign ( q 0 ) [ sign ( c 13 - c 31 ) ] sign ( q 3 ) = sign ( q 0 ) [ sign ( c 21 - c 12 ) ] - - - ( 6 )
上式中,sign(q0)可任选,因为四元数表征刚体从初始位置到最终位置的一次性等效旋转,并不反应从初始位置到最终位置的中间过程。
(3)四元数和姿态角的换算
四旋翼飞行器的四元数矢量式为
Q ( t k ) = q 0 + q 1 i → + q 2 j → + q 3 k → - - - ( 7 )
四元数可确定出由四旋翼机体坐标b系到地面坐标n系的变换坐标矩阵
C b n = 1 - 2 ( q 2 2 + q 3 2 ) 2 ( q 1 q 2 - q 0 q 3 ) 2 ( q 1 q 3 + q 0 q 2 ) 2 ( q 1 q 2 + q 0 q 3 ) 1 - 2 ( q 1 2 + q 3 2 ) 2 ( q 2 q 3 - q 0 q 1 ) 2 ( q 1 q 3 - q 0 q 2 ) 2 ( q 2 q 3 + q 0 q 1 ) 1 - 2 ( q 1 2 + q 2 2 ) - - - ( 8 )
由变换坐标矩阵可得四旋翼飞行器的姿态角为
(4)更新四元数
在捷联式惯性导航系统中,陀螺仪的输出值一般是等时间采样周期内的角增量,为了避免积分的累积误差、降低噪声的微分放大,本文直接采用角增量来确定四元数,即毕卡四元数算法。
dQ ( t k + 1 ) dt = 1 2 Q ( t k ) ⊗ ω ( t k ) = 1 2 M ′ ( ω ( t k ) ) Q ( t k ) - - - ( 10 )
其中, ω ( t k ) = ω x ω y ω z , 表示四元数乘法,其等效的换算矩阵为
M ′ ( ω ( t k ) ) = 0 - ω x - ω y - ω z ω x 0 ω z - ω y ω y - ω z 0 ω x ω z ω y - ω x 0
求解式(10)的微分方程可得
Q ( t k + 1 ) = e 1 2 ∫ t k t k + 1 M ′ ( ω ( t k ) ) dt Q ( t k ) - - - ( 11 )
进一步,
Q ( t k + 1 ) = e 1 2 ΔΘdt Q ( t k ) - - - ( 12 )
其中, ΔΘ = 0 - g bx - g by - g bz g bx 0 g bz - g by g by - g bz 0 g bx g bz g by - g bx 0 .
对式(17)进行泰勒级数展开可得
Q ( t k + 1 ) = [ I + 1 2 ΔΘ 1 ! + ( 1 2 ΔΘ ) 2 2 ! + . . . ] Q ( t k ) - - - ( 13 )
考虑到算法的精度和控制芯片的运算量,本文取三阶近似毕卡四元数算法,四元数求解如下:
Q ( t k + 1 ) = = [ I ( 1 - Δθ 2 8 ) + ( 1 2 - Δθ 2 48 ) ΔΘ ] Q ( t k ) - - - ( 14 )
其中,Δθ2=gbx 2+gby 2+gbz 2
步骤4)中还包括卡尔曼滤波,根据步骤3)中以上的姿态获取,可通过加速计和陀螺仪得到的姿态角,进而基于卡尔曼进行数据融合得到最终输出的姿态角。
作为优选的另一种方案:所述的步骤3)中还包括实时四旋翼飞行器监测控制台,姿态获取和数据融合的结果将在四旋翼飞行器监测控制台中显示。
与现有技术相比,本发明的优点在于:
(1)基于三阶近似毕卡四元数来进行姿态获取,避免了陀螺仪的积分累积误差,降低了噪声的微分放大。
(2)将解算得到的姿态角进行卡尔曼滤波,有效消除了四旋翼飞行器机体振动引起的传感器测量误差,得到更准确的姿态角。
附图说明
图1为本发明的四旋翼飞行器的硬件系统构成图。
图2为本发明的四旋翼飞行器姿态获取流程图
具体实施方式
为了使本发明的技术方案、设计思路能更加清晰,下面结合附图再进行详尽的描述。
一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法,包括以下步骤:
步骤1)为了验证算法的可行性,首先建立一个飞行器实验平台,所述平台的硬件系统以3个STM32F103VET6控制芯片为核心划分为三大部分。
第一部分是主控制器和惯性导航系统的电路设计。主控芯片釆用的是STM32,进行姿态获取和姿态控制。惯性导航系统是采集飞行器机体的运动状态信息作为控制系统控制的重要信息依据。惯性导航平台的反馈精度直接影响到控制系统的控制精度。本项目的惯性导航系统由6轴运动处理组件MPU6050、电子罗盘HMC5883和气压计MS5611组成。
第二部分是以STM32控制芯片,用OV7620数字摄像头做图像信息采集和四旋翼飞行器飞行数据处理的信息处理部分,与第一部分的芯片用USART接口进行通信,与第三部分用蓝牙模块进行通信。
第三部分是用STM32设计UC/OSII嵌入式系统下位机,使用蓝牙与四旋翼飞行器进行通信,用作人机交互以及图像数据传输的中间站,能够完成飞行器各个状态之间的切换以及数据的接收显示。
步骤2)数据的预处理,具体方案如下:
在飞行器的姿态控制中,姿态数据通常由传感器获取,但是单个传感器获取的信息往往不精确。因此,在进行姿态估计之前,需要对传感器的原始数据进行预处理,以下主要简述3部分:加速度计校准及滤波、陀螺仪静态偏置的计算(陀螺仪零偏)以及磁力计的偏心矫正及滤波。
(1)加速度计校准及滤波
由于加速度传感器的测量值必然存在误差,因此,有必要在使用前对其进行校准,使用时对其进行滤波。这里使用均值滤波及滑动平均滤波的方式对加速度计的测量信息进行处理。
(2)陀螺仪零偏计算
陀螺仪存在静态偏置即零偏,因此在每一次系统初始化时需要对其零偏进行计算并在之后的计算中除去零偏。先将陀螺仪静置,连续读取200次陀螺仪的测量值进行均值滤波,并将其作为陀螺仪的零偏。
(3)磁力计偏心矫正及倾斜补偿
理论上,磁力计的三个轴的测量值范围是对称的,即在空间中呈球体分布。然而,由于传感器的误差以及外界磁场的干扰,本文所得到的磁力计测量值是一个中心不在原点的椭球体,因此需要对其测量值进行偏心校正。基本步骤为:
a.将磁力计水平旋转360度计算其X轴与Y轴最大值与最小值,由此计算修正增益XS与YS,修正偏置Xb与Yb
这里以X轴为基准,令XS=1。
Y s = ( X max - X min ) ( Y max - Y min ) - - - ( 15 )
X b = X s [ 1 2 ( X max - X min ) - X max ] Y b = Y s [ 1 2 ( Y max - Y min ) - Y max ]
b.Xin、Yin和Zin为磁力计的测量输出值,通过修正增益与修正偏置计算磁力计的修正值Xout和Yout
X out = X s × X in + X b Y out = Y s × Y in + Y b - - - ( 17 )
c.同样以X轴为基准,对Z轴进行矫正,最终得到三个轴的修正值Xout、Yout和Zout
X out = X s × X in + X b Y out = Y s × Y in + Y b Z out = Z s × Z in + Z b - - - ( 18 )
步骤3)设计基于毕卡四元数的四旋翼飞行器姿态获取,过程包括:
设由四旋翼的机体轴确定的坐标系为b,地面坐标系为n,则由b系到n系的坐标矩阵称为四旋翼的姿态矩阵,θ、γ、分别为飞机的俯仰、横滚、偏航角,加速度计输出的原始值为速度的增量即abx、aby、abz,陀螺仪计输出为角增量即gbx、gby、gbz,磁力计mbx、mby、mbz
(1)欧拉角初始化
(2)四元数初始值的确定及规范化处理
四旋翼飞行器的四元数的初始值Q(0)由捷联系统的初值状态对准确定。设初始对准的姿态阵为可由式(1)中求得的公式计算得出初始姿态角求得。
C b 0 n = c 11 c 12 c 13 c 21 c 22 c 23 c 31 c 32 c 33 - - - ( 2 )
其中,c11、c12、c13、c21、c22、c23、c31、c32、c33分别为
则四旋翼飞行器的四元数的初始值为:
Q ( 0 ) = q 0 + q 1 i → + q 2 j → + q 3 k → - - - ( 4 )
其中,q0、q1、q2、q3的数值和符号可按下式(5)和(6)确定。
| q 1 | = 1 2 1 + c 11 - c 22 - c 33 | q 2 | = 1 2 1 - c 11 + c 22 - c 33 | q 3 | = 1 2 1 - c 11 - c 22 - c 33 | q 0 | = 1 2 1 + c 11 + c 22 + c 33 - - - ( 5 )
sign ( q 1 ) = sign ( q 0 ) [ sign ( c 32 - c 23 ) ] sign ( q 2 ) = sign ( q 0 ) [ sign ( c 13 - c 31 ) ] sign ( q 3 ) = sign ( q 0 ) [ sign ( c 21 - c 12 ) ] - - - ( 6 )
上式中,sign(q0)可任选,因为四元数表征刚体从初始位置到最终位置的一次性等效旋转,并不反应从初始位置到最终位置的中间过程。
(3)四元数和姿态角的换算
四旋翼飞行器的四元数矢量式为
Q ( t k ) = q 0 + q 1 i → + q 2 j → + q 3 k → - - - ( 7 )
四元数可确定出由四旋翼机体坐标b系到地面坐标n系的变换坐标矩阵
C b n = 1 - 2 ( q 2 2 + q 3 2 ) 2 ( q 1 q 2 - q 0 q 3 ) 2 ( q 1 q 3 + q 0 q 2 ) 2 ( q 1 q 2 + q 0 q 3 ) 1 - 2 ( q 1 2 + q 3 2 ) 2 ( q 2 q 3 - q 0 q 1 ) 2 ( q 1 q 3 - q 0 q 2 ) 2 ( q 2 q 3 + q 0 q 1 ) 1 - 2 ( q 1 2 + q 2 2 ) - - - ( 8 )
由变换坐标矩阵可得四旋翼飞行器的姿态角为
(4)更新四元数
在捷联式惯性导航系统中,陀螺仪的输出值一般是等时间采样周期内的角增量,为了避免积分的累积误差、降低噪声的微分放大,本文直接采用角增量来确定四元数,即毕卡四元数算法。
dQ ( t k + 1 ) dt = 1 2 Q ( t k ) ⊗ ω ( t k ) = 1 2 M ′ ( ω ( t k ) ) Q ( t k ) - - - ( 10 )
其中, ω ( t k ) = ω x ω y ω z , 表示四元数乘法,其等效的换算矩阵为
M ′ ( ω ( t k ) ) = 0 - ω x - ω y - ω z ω x 0 ω z - ω y ω y - ω z 0 ω x ω z ω y - ω x 0
求解式(10)的微分方程可得
Q ( t k + 1 ) = e 1 2 ∫ t k t k + 1 M ′ ( ω ( t k ) ) dt Q ( t k ) - - - ( 11 )
进一步,
Q ( t k + 1 ) = e 1 2 ΔΘdt Q ( t k ) - - - ( 12 )
其中, ΔΘ = 0 - g bx - g by - g bz g bx 0 g bz - g by g by - g bz 0 g bx g bz g by - g bx 0 .
对式(17)进行泰勒级数展开可得
Q ( t k + 1 ) = [ I + 1 2 ΔΘ 1 ! + ( 1 2 ΔΘ ) 2 2 ! + . . . ] Q ( t k ) - - - ( 13 )
考虑到算法的精度和控制芯片的运算量,本文取三阶近似毕卡四元数算法,四元数求解如下:
Q ( t k + 1 ) = = [ I ( 1 - Δθ 2 8 ) + ( 1 2 - Δθ 2 48 ) ΔΘ ] Q ( t k ) - - - ( 14 )
其中,Δθ2=gbx 2+gby 2+gbz 2
步骤4)中还包括卡尔曼滤波,根据步骤3)中以上的姿态获取,可通过加速计和陀螺仪得到的姿态角,进而基于卡尔曼进行数据融合得到最终输出的姿态角。
参照图1和图2一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法,所述方法包括:
如图1所示为四旋翼飞行器的硬件系统构成图。本平台的硬件系统以3个STM32F103VET6控制芯片为核心划分为三大部分。第一部分是主控制器和惯性导航系统的电路设计。主控芯片釆用的是STM32,进行姿态获取和姿态控制。惯性导航系统是采集飞行器机体的运动状态信息作为控制系统控制的重要信息依据。惯性导航平台的反馈精度直接影响到控制系统的控制精度。本项目的惯性导航系统由6轴运动处理组件MPU6050、电子罗盘HMC5883和气压计MS5611组成。第二部分是以STM32控制芯片,用OV7620数字摄像头做图像信息采集和四旋翼飞行器飞行数据处理的信息处理部分,与第一部分的芯片用USART接口进行通信,与第三部分用蓝牙模块进行通信。第三部分是用STM32设计UC/OSII嵌入式系统下位机,使用蓝牙模块与四旋翼飞行器进行通信,用作人机交互以及图像数据传输的中间站,能够完成飞行器各个状态之间的切换以及数据的接收显示。
如图2为本发明的四旋翼飞行器姿态获取流程图。其中包括了传感器数据预处理、欧拉角初始化、四元数初始化、更新四元数、四元数规范化、姿态角更新以及卡尔曼滤波姿态估计,清晰地展示了算法的执行流程。

Claims (1)

1.一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法,包括以下步骤:
步骤1)为了验证算法的可行性,首先建立一个飞行器实验平台;将飞行器实验平台的硬件系统以3个STM32F103VET6控制芯片为核心划分为三大部分;
第一部分是主控制器和惯性导航系统的电路设计;主控芯片釆用的是STM32,进行姿态获取和姿态控制;惯性导航系统是采集飞行器机体的运动状态信息作为控制系统控制的重要信息依据;惯性导航平台的反馈精度直接影响到控制系统的控制精度;惯性导航系统由6轴运动处理组件MPU6050、电子罗盘HMC5883和气压计MS5611组成;
第二部分是以STM32控制芯片,用OV7620数字摄像头做图像信息采集和四旋翼飞行器飞行数据处理的信息处理部分,与第一部分的芯片用USART接口进行通信,与第三部分用蓝牙模块进行通信;
第三部分是用STM32设计UC/OSII嵌入式系统下位机,使用蓝牙模块与四旋翼飞行器进行通信,用作人机交互以及图像数据传输的中间站,能够完成飞行器各个状态之间的切换以及数据的接收显示;
步骤2)数据的预处理,具体方案如下:
在飞行器的姿态控制中,姿态数据通常由传感器获取,但是单个传感器获取的信息往往不精确;因此,在进行姿态估计之前,需要对传感器的原始数据进行预处理:加速度计校准及滤波、陀螺仪静态偏置的计算(陀螺仪零偏)以及磁力计的偏心矫正及滤波;
(21)加速度计校准及滤波
由于加速度传感器的测量值必然存在误差,因此,有必要在使用前对其进行校准,使用时对其进行滤波;这里使用均值滤波及滑动平均滤波的方式对加速度计的测量信息进行处理;
(22)陀螺仪零偏计算
陀螺仪存在静态偏置即零偏,因此在每一次系统初始化时需要对其零偏进行计算并在之后的计算中除去零偏;先将陀螺仪静置,连续读取200次陀螺仪的测量值进行均值滤波,并将其作为陀螺仪的零偏;
(23)磁力计偏心矫正及倾斜补偿
理论上,磁力计的三个轴的测量值范围是对称的,即在空间中呈球体分布;然而,由于传感器的误差以及外界磁场的干扰,本文所得到的磁力计测量值是一个中心不在原点的椭球体,因此需要对其测量值进行偏心校正;基本步骤为:
a.将磁力计水平旋转360度计算其X轴与Y轴最大值与最小值,由此计算修正增益XS与YS,修正偏置Xb与Yb
这里以X轴为基准,令XS=1;
Y s = ( X max - X min ) ( Y max - Y min ) - - - ( 15 )
X b = X s [ 1 2 ( X max - X min ) - X max ] Y b = Y s [ 1 2 ( Y max - Y min ) - Y max ] - - - ( 16 )
b.Xin、Yin和Zin为磁力计的测量输出值,通过修正增益与修正偏置计算磁力计的修正值Xout和Yout
X out = X s × X in + X b Y out = Y s × Y in + Y b - - - ( 17 )
c.同样以X轴为基准,对Z轴进行矫正,最终得到三个轴的修正值Xout、Yout和Zout
X out = X s × X in + X b Y out = Y s × Y in + Y b Z out = Z s × Z in + Z b - - - ( 18 )
步骤3)设计基于毕卡四元数的四旋翼飞行器姿态获取,过程包括:
设由四旋翼的机体轴确定的坐标系为b,地面坐标系为n,则由b系到n系的坐标矩阵称为四旋翼的姿态矩阵,θ、γ、分别为飞机的俯仰、横滚、偏航角,加速度计输出的原始值为速度的增量即abx、aby、abz,陀螺仪计输出的原始值为角增量即gbx、gby、gbz,磁力计mbx、mby、mbz
(31)欧拉角初始化
(32)四元数初始值的确定及规范化处理
四旋翼飞行器的四元数的初始值Q(0)由捷联系统的初值状态对准确定;设初始对准的姿态阵为可由式(1)中求得的公式计算得出初始姿态角求得;
C b 0 n = c 11 c 12 c 13 c 21 c 22 c 23 c 31 c 32 c 33 - - - ( 2 )
其中,c11、c12、c13、c21、c22、c23、c31、c32、c33分别为
则四旋翼飞行器的四元数的初始值为:
Q ( 0 ) = q 0 + q 1 i → + q 2 j → + q 3 k → - - - ( 4 )
其中,q0、q1、q2、q3的数值和符号可按下式(5)和(6)确定;
| q 1 | = 1 2 1 + c 11 - c 22 - c 33 | q 2 | = 1 2 1 - c 11 + c 22 - c 33 | q 3 | = 1 2 1 - c 11 - c 22 - c 33 | q 0 | = 1 2 1 + c 11 + c 22 + c 33 - - - ( 5 )
sign ( q 1 ) = sign ( q 0 ) [ sign ( c 32 - c 23 ) ] sign ( q 2 ) = sign ( q 0 ) [ sign ( c 13 - c 31 ) ] sign ( q 3 ) = sign ( q 0 ) [ sign ( c 21 - c 12 ) ] - - - ( 6 )
上式中,sign(q0)可任选,因为四元数表征刚体从初始位置到最终位置的一次性等效旋转,并不反应从初始位置到最终位置的中间过程;
(33)四元数和姿态角的换算
四旋翼飞行器的四元数矢量式为
Q ( t k ) = q 0 + q 1 i → + q 2 j → + q 3 k → - - - ( 7 )
四元数可确定出由四旋翼机体坐标b系到地面坐标n系的变换坐标矩阵
C b n = 1 - 2 ( q 2 2 + q 3 2 ) 2 ( q 1 q 2 - q 0 q 3 ) 2 ( q 1 q 3 + q 0 q 2 ) 2 ( q 1 q 2 + q 0 q 3 ) 1 - 2 ( q 1 2 + q 3 2 ) 2 ( q 2 q 3 - q 0 q 1 ) 2 ( q 1 q 3 - q 0 q 2 ) 2 ( q 2 q 3 + q 0 q 1 ) 1 - 2 ( q 1 2 + q 2 2 ) - - - ( 8 )
由变换坐标矩阵可得四旋翼飞行器的姿态角为
(34)更新四元数
在捷联式惯性导航系统中,陀螺仪的输出值一般是等时间采样周期内的角增量,为了避免积分的累积误差、降低噪声的微分放大,本文直接采用角增量来确定四元数;即毕卡四元数算法;
dQ ( t k + 1 ) dt = 1 2 Q ( t k ) ⊗ ω ( t k ) = 1 2 M ′ ( ω ( t k ) ) Q ( t k ) - - - ( 10 )
其中, ω ( t k ) = ω x ω y ω z , 表示四元数乘法,其等效的换算矩阵为
M ′ ( ω ( t k ) ) = 0 - ω x - ω y - ω z ω x 0 ω z - ω y ω y - ω z 0 ω x ω z ω y - ω x 0
求解式(10)的微分方程可得
Q ( t k + 1 ) = e 1 2 ∫ t k t k + 1 M ′ ( ω ( t k ) ) dt Q ( t k ) - - - ( 11 )
进一步,
Q ( t k + 1 ) = e 1 2 ΔΘdt Q ( t k ) - - - ( 12 )
其中, ΔΘ = 0 - g bx - g by - g bz g bx 0 g bz - g by g by - g bz 0 g bx g bz g by - g bx 0 ;
对式(17)进行泰勒级数展开可得
Q ( t k + 1 ) = [ I + 1 2 ΔΘ 1 ! + ( 1 2 ΔΘ ) 2 2 ! + . . . ] Q ( t k ) - - - ( 13 )
考虑到算法的精度和控制芯片的运算量,取三阶近似毕卡四元数算法,四元数求解如下:
Q ( t k + 1 ) = = [ I ( 1 - Δθ 2 8 ) + ( 1 2 - Δθ 2 48 ) ΔΘ ] Q ( t k ) - - - ( 14 )
其中,Δθ2=gbx 2+gby 2+gbz 2
(4)卡尔曼滤波,根据步骤3)中以上的姿态获取,可通过加速计和陀螺仪得到的姿态角,进而基于卡尔曼进行数据融合得到最终输出的姿态角。
CN201510221435.3A 2015-05-04 2015-05-04 一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法 Active CN104898681B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201510221435.3A CN104898681B (zh) 2015-05-04 2015-05-04 一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201510221435.3A CN104898681B (zh) 2015-05-04 2015-05-04 一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法

Publications (2)

Publication Number Publication Date
CN104898681A true CN104898681A (zh) 2015-09-09
CN104898681B CN104898681B (zh) 2017-07-28

Family

ID=54031391

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201510221435.3A Active CN104898681B (zh) 2015-05-04 2015-05-04 一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法

Country Status (1)

Country Link
CN (1) CN104898681B (zh)

Cited By (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105259750A (zh) * 2015-10-27 2016-01-20 四川豪斯特电子技术有限责任公司 一种四旋翼飞行器保持机体平衡的方法
CN105352487A (zh) * 2015-10-13 2016-02-24 上海华测导航技术股份有限公司 一种姿态测量系统的精度校准方法
CN105651285A (zh) * 2016-01-07 2016-06-08 北京电子工程总体研究所 一种基于四元数的跨象限姿态角的计算方法
CN105806364A (zh) * 2016-03-10 2016-07-27 太原理工大学 一种矿用回转钻机测斜仪探管的校准方法
CN105890598A (zh) * 2016-04-08 2016-08-24 武汉科技大学 共轭梯度与扩展卡尔曼滤波结合的四旋翼姿态解算方法
CN106249745A (zh) * 2016-07-07 2016-12-21 苏州大学 四轴无人机的控制方法
CN106444809A (zh) * 2016-10-12 2017-02-22 湖南绿野航空科技有限公司 一种无人机飞行控制器
CN106500693A (zh) * 2016-12-07 2017-03-15 中国电子科技集团公司第五十四研究所 一种基于自适应扩展卡尔曼滤波的ahrs算法
CN106774378A (zh) * 2017-03-01 2017-05-31 杭州谷航科技有限公司 一种无人机飞行控制及定位方法
CN107203215A (zh) * 2017-05-04 2017-09-26 西北工业大学 一种手势及语音控制四旋翼飞行器方法
CN107272717A (zh) * 2017-06-06 2017-10-20 袁兵 基于滑动平均滤波的四轴无人机控制方法
CN107368087A (zh) * 2016-05-13 2017-11-21 威海明达创新科技有限公司 微型四轴飞行器及其控制方法
CN107635064A (zh) * 2017-08-29 2018-01-26 哈尔滨工业大学深圳研究生院 一种支持ros的无人机手机app控制方法
CN107907129A (zh) * 2017-09-26 2018-04-13 广州新维感信息技术有限公司 Vr手柄姿态初始算法、vr手柄及存储介质
CN108398128A (zh) * 2018-01-22 2018-08-14 北京大学深圳研究生院 一种姿态角的融合解算方法和装置
CN108463782A (zh) * 2015-11-24 2018-08-28 维纳缇有限公司 估计用于控制操作机器的控制设备的姿态的方法
CN108489485A (zh) * 2018-03-20 2018-09-04 西北工业大学 一种无误差的捷联惯导数值更新方法
CN109521785A (zh) * 2018-12-29 2019-03-26 西安电子科技大学 一种随身拍智能旋翼飞行器系统
CN110031020A (zh) * 2019-03-28 2019-07-19 广州英卓电子科技有限公司 一种平面磁场校正方法及其装置
CN110928324A (zh) * 2019-12-30 2020-03-27 北京润科通用技术有限公司 无人机飞行参数采集设备及其校准方法
CN112858960A (zh) * 2021-02-28 2021-05-28 哈尔滨工业大学 一种飞机尾杆振动引起的磁干扰的补偿方法及装置
CN114763994A (zh) * 2021-05-06 2022-07-19 苏州精源创智能科技有限公司 一种应用于扫地机器人的惯性姿态导航系统
CN117250854A (zh) * 2023-11-17 2023-12-19 北京中星时代科技有限公司 控制参数设计引入积分系数的飞行姿态控制方法

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2472225A2 (en) * 2010-12-22 2012-07-04 Custom Sensors & Technologies, Inc. Method and system for initial quaternion and attitude estimation
EP2495530A1 (fr) * 2011-03-03 2012-09-05 Thales Procédé et système de détermination de l'attitude d'un aéronef par mesures accélérométriques multi-axes
JP5061264B1 (ja) * 2012-03-23 2012-10-31 国立大学法人 千葉大学 小型姿勢センサ
CN103365296A (zh) * 2013-06-29 2013-10-23 天津大学 一种四旋翼无人飞行器非线性输出反馈飞行控制方法
CN103575299A (zh) * 2013-11-13 2014-02-12 北京理工大学 利用外观测信息的双轴旋转惯导系统对准及误差修正方法
CN104006787A (zh) * 2014-05-01 2014-08-27 哈尔滨工业大学 空间飞行器姿态运动模拟平台高精度姿态确定方法
CN104133379A (zh) * 2014-08-15 2014-11-05 哈尔滨工业大学 四旋翼飞行器仿真方法
CN104567871A (zh) * 2015-01-12 2015-04-29 哈尔滨工程大学 一种基于地磁梯度张量的四元数卡尔曼滤波姿态估计方法

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2472225A2 (en) * 2010-12-22 2012-07-04 Custom Sensors & Technologies, Inc. Method and system for initial quaternion and attitude estimation
EP2495530A1 (fr) * 2011-03-03 2012-09-05 Thales Procédé et système de détermination de l'attitude d'un aéronef par mesures accélérométriques multi-axes
JP5061264B1 (ja) * 2012-03-23 2012-10-31 国立大学法人 千葉大学 小型姿勢センサ
CN103365296A (zh) * 2013-06-29 2013-10-23 天津大学 一种四旋翼无人飞行器非线性输出反馈飞行控制方法
CN103575299A (zh) * 2013-11-13 2014-02-12 北京理工大学 利用外观测信息的双轴旋转惯导系统对准及误差修正方法
CN104006787A (zh) * 2014-05-01 2014-08-27 哈尔滨工业大学 空间飞行器姿态运动模拟平台高精度姿态确定方法
CN104133379A (zh) * 2014-08-15 2014-11-05 哈尔滨工业大学 四旋翼飞行器仿真方法
CN104567871A (zh) * 2015-01-12 2015-04-29 哈尔滨工程大学 一种基于地磁梯度张量的四元数卡尔曼滤波姿态估计方法

Cited By (36)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105352487A (zh) * 2015-10-13 2016-02-24 上海华测导航技术股份有限公司 一种姿态测量系统的精度校准方法
CN105259750A (zh) * 2015-10-27 2016-01-20 四川豪斯特电子技术有限责任公司 一种四旋翼飞行器保持机体平衡的方法
CN108463782B (zh) * 2015-11-24 2021-11-30 维纳缇有限公司 估计用于控制操作机器的控制设备的姿态的方法
CN108463782A (zh) * 2015-11-24 2018-08-28 维纳缇有限公司 估计用于控制操作机器的控制设备的姿态的方法
CN105651285A (zh) * 2016-01-07 2016-06-08 北京电子工程总体研究所 一种基于四元数的跨象限姿态角的计算方法
CN105651285B (zh) * 2016-01-07 2018-08-10 北京电子工程总体研究所 一种基于四元数的跨象限姿态角的计算方法
CN105806364A (zh) * 2016-03-10 2016-07-27 太原理工大学 一种矿用回转钻机测斜仪探管的校准方法
CN105890598A (zh) * 2016-04-08 2016-08-24 武汉科技大学 共轭梯度与扩展卡尔曼滤波结合的四旋翼姿态解算方法
CN105890598B (zh) * 2016-04-08 2019-04-09 武汉科技大学 共轭梯度与扩展卡尔曼滤波结合的四旋翼姿态解算方法
CN107368087A (zh) * 2016-05-13 2017-11-21 威海明达创新科技有限公司 微型四轴飞行器及其控制方法
CN106249745A (zh) * 2016-07-07 2016-12-21 苏州大学 四轴无人机的控制方法
CN106444809B (zh) * 2016-10-12 2024-04-16 湖南绿野航空科技有限公司 一种无人机飞行控制器
CN106444809A (zh) * 2016-10-12 2017-02-22 湖南绿野航空科技有限公司 一种无人机飞行控制器
CN106500693A (zh) * 2016-12-07 2017-03-15 中国电子科技集团公司第五十四研究所 一种基于自适应扩展卡尔曼滤波的ahrs算法
CN106500693B (zh) * 2016-12-07 2019-06-28 中国电子科技集团公司第五十四研究所 一种基于自适应扩展卡尔曼滤波的ahrs算法
CN106774378B (zh) * 2017-03-01 2019-08-09 杭州谷航科技有限公司 一种无人机飞行控制及定位方法
CN106774378A (zh) * 2017-03-01 2017-05-31 杭州谷航科技有限公司 一种无人机飞行控制及定位方法
CN107203215A (zh) * 2017-05-04 2017-09-26 西北工业大学 一种手势及语音控制四旋翼飞行器方法
CN107272717A (zh) * 2017-06-06 2017-10-20 袁兵 基于滑动平均滤波的四轴无人机控制方法
CN107635064A (zh) * 2017-08-29 2018-01-26 哈尔滨工业大学深圳研究生院 一种支持ros的无人机手机app控制方法
CN107635064B (zh) * 2017-08-29 2020-07-17 哈尔滨工业大学深圳研究生院 一种支持ros的无人机手机app控制方法
CN107907129A (zh) * 2017-09-26 2018-04-13 广州新维感信息技术有限公司 Vr手柄姿态初始算法、vr手柄及存储介质
CN108398128B (zh) * 2018-01-22 2021-08-24 北京大学深圳研究生院 一种姿态角的融合解算方法和装置
CN108398128A (zh) * 2018-01-22 2018-08-14 北京大学深圳研究生院 一种姿态角的融合解算方法和装置
CN108489485A (zh) * 2018-03-20 2018-09-04 西北工业大学 一种无误差的捷联惯导数值更新方法
CN109521785B (zh) * 2018-12-29 2021-07-27 西安电子科技大学 一种随身拍智能旋翼飞行器系统
CN109521785A (zh) * 2018-12-29 2019-03-26 西安电子科技大学 一种随身拍智能旋翼飞行器系统
CN110031020A (zh) * 2019-03-28 2019-07-19 广州英卓电子科技有限公司 一种平面磁场校正方法及其装置
CN110928324A (zh) * 2019-12-30 2020-03-27 北京润科通用技术有限公司 无人机飞行参数采集设备及其校准方法
CN110928324B (zh) * 2019-12-30 2023-07-14 北京润科通用技术有限公司 无人机飞行参数采集设备及其校准方法
CN112858960A (zh) * 2021-02-28 2021-05-28 哈尔滨工业大学 一种飞机尾杆振动引起的磁干扰的补偿方法及装置
CN112858960B (zh) * 2021-02-28 2022-07-22 哈尔滨工业大学 一种飞机尾杆振动引起的磁干扰的补偿方法及装置
CN114763994A (zh) * 2021-05-06 2022-07-19 苏州精源创智能科技有限公司 一种应用于扫地机器人的惯性姿态导航系统
CN114763994B (zh) * 2021-05-06 2024-01-30 苏州精源创智能科技有限公司 一种应用于扫地机器人的惯性姿态导航系统
CN117250854B (zh) * 2023-11-17 2024-02-02 北京中星时代科技有限公司 控制参数设计引入积分系数的飞行姿态控制方法
CN117250854A (zh) * 2023-11-17 2023-12-19 北京中星时代科技有限公司 控制参数设计引入积分系数的飞行姿态控制方法

Also Published As

Publication number Publication date
CN104898681B (zh) 2017-07-28

Similar Documents

Publication Publication Date Title
CN104898681A (zh) 一种采用三阶近似毕卡四元数的四旋翼飞行器姿态获取方法
CN111426318B (zh) 基于四元数-扩展卡尔曼滤波的低成本ahrs航向角补偿方法
CN102879793B (zh) 超小型gps/ins/磁强计/气压计组合导航系统
CN102980577B (zh) 一种微型捷联航姿系统及其工作方法
Chang et al. Indirect Kalman filtering based attitude estimation for low-cost attitude and heading reference systems
CN101726295B (zh) 考虑加速度补偿和基于无迹卡尔曼滤波的惯性位姿跟踪方法
CN102252676B (zh) 运动姿态数据获取、人体运动姿态追踪方法及相关设备
CN105136145A (zh) 一种基于卡尔曼滤波的四旋翼无人机姿态数据融合的方法
CN103196448A (zh) 一种机载分布式惯性测姿系统及其传递对准方法
CN101706284B (zh) 提高船用光纤陀螺捷联惯导系统定位精度的方法
CN112146655B (zh) 一种BeiDou/SINS紧组合导航系统弹性模型设计方法
CN110017837B (zh) 一种姿态抗磁干扰的组合导航方法
CN202974288U (zh) 一种微型捷联航姿系统
RU2633034C2 (ru) Компенсация задержки
CN103712598B (zh) 一种小型无人机姿态确定方法
CN108318038A (zh) 一种四元数高斯粒子滤波移动机器人姿态解算方法
CN104374388A (zh) 一种基于偏振光传感器的航姿测定方法
CN102937450B (zh) 一种基于陀螺测量信息的相对姿态确定方法
CN111189442B (zh) 基于cepf的无人机多源导航信息状态预测方法
CN104181573A (zh) 北斗惯导深组合导航微系统
CN109764870B (zh) 基于变换估计量建模方案的载体初始航向估算方法
CN102087110A (zh) 微型水下运动体自主姿态检测装置及方法
CN103697878A (zh) 一种单陀螺单加速度计旋转调制寻北方法
CN103900566A (zh) 一种消除地球自转角速度对旋转调制型捷联惯导系统精度影响的方法
CN111207734B (zh) 一种基于ekf的无人机组合导航方法

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
EE01 Entry into force of recordation of patent licensing contract
EE01 Entry into force of recordation of patent licensing contract

Application publication date: 20150909

Assignee: Wuzhou yingri Information Technology Co.,Ltd.

Assignor: JIANG University OF TECHNOLOGY

Contract record no.: X2023980054148

Denomination of invention: A method for obtaining the attitude of quadcopter aircraft using third-order approximate Picard quaternion

Granted publication date: 20170728

License type: Common License

Record date: 20231226