Skip to main content
Sensors (Basel, Switzerland) logoLink to Sensors (Basel, Switzerland)
. 2018 Sep 27;18(10):3251. doi: 10.3390/s18103251

An Improved Yaw Estimation Algorithm for Land Vehicles Using MARG Sensors

Gang Shi 1,2,3, Xisheng Li 1,4,*, Zhengfu Jiang 1
PMCID: PMC6210731  PMID: 30262763

Abstract

This paper presents a linear Kalman filter for yaw estimation of land vehicles using magnetic angular rate and gravity (MARG) sensors. A gyroscope measurement update depending on the vehicle status and constraining yaw estimation is introduced. To determine the vehicle status, the correlations between outputs from different sensors are analyzed based on the vehicle kinematic model and Coriolis theorem, and a vehicle status marker is constructed. In addition, a two-step measurement update method is designed. The method treats the magnetometer measurement update separately after the other updates and eliminates its impact on attitude estimation. The performances of the proposed algorithm are tested in experiments and the results show that: the introduced measurement update is an effective supplement to the magnetometer measurement update in magnetically disturbed environments; the two-step measurement update method makes attitude estimation immune to errors induced by magnetometer measurement update, and the proposed algorithm provides more reliable yaw estimation for land vehicles than the conventional algorithm.

Keywords: attitude estimation, Kalman filter, land vehicle, magnetic angular rate and gravity (MARG) sensor, quaternion, yaw estimation

1. Introduction

As a set of Euler angles, the yaw, pitch, and roll represent the orientation of a body frame with respect to a reference frame. The pitch and roll are also referred to as attitude. Yaw and attitude estimation are widely used in vehicular technologies including driver assistance [1,2,3], vehicle safety [4,5], etc. In recent years, magnetic angular rate and gravity (MARG) sensors [6] are widely used in orientation estimation. A MARG sensor consists of a triaxis magnetometer, a triaxis gyroscope, and a triaxis accelerometer. Reasonable installation and calibration make it acceptable to assume that the sensor frames are aligned with the body frame. Hence, a MARG sensor can measure the geomagnetic field, angular rate of the body frame, and the gravity resolved in the body frame in undisturbed environments.

In order to obtain an orientation estimation of the body frame, we can integrate the gyroscope output based on an initial value, but the result will drift away with time because of gyroscope measurement errors [7]. Alternatively, we can solve the Wahba problem [8] using magnetometer and accelerometer outputs, but the sensor outputs are apt to be interfered by motion accelerations and magnetic disturbances [9,10]. Therefore, to make the most of the information from MARG sensors and obtain robust orientation estimation, many fusion algorithms have been studied. These algorithms can be classified into two categories: one is based on complementary filters, which realize the fusion in frequency domain [11,12,13], and the other is based on Kalman filters, which employ a stochastic approach [14,15,16]. Kalman filter based algorithms consist of two basic processing, i.e., time propagation and measurement update. In time propagation, the gyroscope output is used to predict the orientation and the result is called a priori estimation; in measurement update, the magnetometer and accelerometer outputs are used to correct the a priori estimation and the result is called a posteriori estimation.

This paper studies on the yaw estimation of land vehicles using MARG sensors and Kalman filter. Our work is based on the orientation estimation because the yaw can be extracted from orientation estimation; at the same time, we focus on special problems in yaw estimation.

Many algorithms of orientation estimation have been studied. They are different in terms of the state vector, filter structure, etc., but they are the same at one point, i.e., the magnetometer output is used to correct the yaw estimation. In fact, the correction of yaw estimation is implemented only by magnetometer measurement update because the accelerometer output only provides attitude information. Hence, one problem in yaw estimation is that it is vulnerable to magnetic disturbances. Magnetic disturbances include hard iron effects, soft iron effects, and environmental magnetic disturbances [17]. The hard and soft iron effects can be compensated through magnetometer calibration, but the environmental magnetic disturbances cannot be effectively compensated because of their nondeterminacy [18,19,20]. In the following, the “magnetic disturbances” refers specifically to the environmental magnetic disturbances.

Methods to handle magnetic disturbances have been proposed. A measurement vector selection scheme based on norm comparison was designed in [7]. Costanzi et al. [21] scaled down the gain associated with the magnetometer output when two particular angular constraints are violated. Wu et al. [22] did not use the magnetometer output if its norm was too big or too small. Tong et al. [23] developed a hidden Markov Model to identify the measurement disturbances and then adjust the noise covariance adaptively. Feng et al. [24] proposed a two-step correction scheme, in which the magnetometer output is used to correct the estimated direction of the magnetic field, but if the difference between the norm of the sensor output and the reference value is greater than a threshold, the correction will not be executed. In fact, the above methods apply a same strategy, i.e., detecting magnetic disturbances according to some feature, e.g., the norm, of the measured magnetic field, and reducing the measurement update weight in real time when disturbances happen. The drawback of this strategy is that the magnetometer measurement update cannot provide effective and timely correction for the yaw estimation if magnetic disturbances last for a long time. In addition, Sabatini [25] proposed an extended Kalman Filter, which compensated magnetic disturbances by including them in the state vector. The filter models magnetic disturbances by a first-order Gauss-Markov vector random process with independent components, and assume the motion acceleration is approximately zero. In fact, the actual magnetic disturbances can hardly be modelled effectively, and the assumption about the motion acceleration is not suitable for land vehicles.

Another problem in yaw estimation is its impact on attitude estimation. In some fusion algorithms, the magnetometer output is also used to correct the attitude estimation, and thus induce estimation errors caused by magnetic disturbances. To address this problem, some algorithms restrict the use of the magnetometer output to yaw estimation. In [9,10], orientation quaternion is obtained through multiplication of a series of decoupled quaternion factors, and the result can be used as the measurement for a Kalman filter with a two-layer structure [9]. Suh [26] proposed a two-step measurement update for an indirect Kalman filter, where the magnetometer measurement update only affected the yaw estimation. Afterwards, Suh et al. [27] proposed a new measurement equation for the indirect Kalman filter, which can greatly reduce the impact of the magnetometer measurement update on attitude estimation and is easier to implement than the two-step measurement update algorithm.

Obviously, both of the mentioned problems are due to magnetic disturbances. This paper aims to enhance the ability of the yaw estimation to deal with magnetic disturbances. One basic idea of this paper is that use not only the information from the sensors, but also the characters of vehicles motion to improve yaw estimation. We think motion characters can provide some independent information, which can be used as supplement to the sensors information. We note that the yaw of a vehicle running along a straight road remains basically unchanged, and this character can be utilized to improve the yaw estimation as a supplement to the magnetometer measurement update. To achieve this, it should be known whether a vehicle is running straight. A straightforward way to determine the vehicle status is comparing the gyroscope output against some preset parameters, but the gyroscope output suffers from various measurement errors and vehicle bumps. Considering the turning motion cause changes of MARG outputs, we can determine the vehicle status by analyzing the correlation between outputs from different sensors. In addition, we can reform the measurement update process of a direct Kalman filter using the condition proved in [26] and thus make the attitude estimation immune to magnetic disturbances. In fact, more accurate attitude estimation is also helpful to improve the yaw estimation because they are coupled in the time propagation. Motivated by above discussion, we propose an improved yaw estimation algorithm, and the main contributions of this paper are as follows:

  • (1)

    A new measurement update robust to magnetic disturbances is introduced, and its weight can be adjusted according to the vehicle status. The correlation coefficients between outputs from a MARG sensor are analyzed based on the vehicle kinematic model and Coriolis theorem, and a vehicle status marker is constructed.

  • (2)

    A new two-step measurement update method is designed. The method implements measurement updates in two successive steps, and make a special processing of the magnetometer measurement update to eliminate its impact on attitude estimation.

In this paper, we construct a yaw estimation algorithm using a typical linear Kalman filter to implement basic quaternion estimation and applying the conventional strategy of reducing the measurement weight to deal with magnetic disturbances. This algorithm is referred to as conventional algorithm. Then, the conventional algorithm is improved with the new measurement update and the new two-step measurement update method. Finally, the performances of the improved algorithm are evaluated through comparing its results against that of the conventional algorithm in experiments. The rest of this paper is organized as follows: Section 2 describes a conventional yaw estimation algorithm. Section 3 details the improved algorithm. Section 4 provides the experiment results and discussion. Finally, the work is concluded in Section 5.

2. Conventional Algorithm

2.1. Preliminaries

Because of not suffering from the gimbal lock, low dimension, and offering a linear formulation of the orientation dynamics [9], quaternion is widely used for orientation representation. Any orientation of a body frame with respect to a reference frame can be represented by a unit quaternion q defined as:

q=[q0q1q2q3]T=[cosα2exsinα2eysinα2ezsinα2]T  (1)

where q0 is the scalar part; [q1q2q3]T is the vector part; α is the rotation angle; [exeyez]T is the unit vector that represents the rotation axis. In quaternion estimation algorithms, the gyroscope output is used to depict the quaternion dynamics; therefore, the gyroscope bias is an important factor that affects the estimation accuracy.

In this section, we describe a Kalman filter-based yaw estimation algorithm with the unit quaternion and gyroscope bias as states. This algorithm, referred to as conventional algorithm, provides the basement and benchmark for the improved algorithm presented in the next section. The conventional algorithm is based on a typical linear Kalman filter presented in [16]. In addition, adaptive measurement weights are applied to deal with measurement disturbances, and the yaw is computed with the quaternion estimation.

The detailed derivations of the system model are presented in [16]; for conciseness, we only list the results and give necessary explanations in this section. Note that we use a different quaternion definition from that in [16] (The scalar part is the first component of a quaternion, whereas in [16], the scalar part is the last component); therefore, we rewrite the concerned equations accordingly, which will not affect the performances of the algorithm.

In this paper, the reference frame is the East, North, Up frame; the body frame is the Right, Forward, Above frame; the sensor frame is assumed aligned with the body frame; the ZXY sequence of Euler angles is chosen, and the yaw, pitch, and roll are respectively z-axis rotation angle, x-axis rotation angle, and y-axis rotation angle. For a clear writing, we define some notations that will be used throughout this paper as follows.

Vectors: x is the state vector; b is the gyroscope bias; mr and gr are respectively the geomagnetic filed and the gravity resolved in the reference frame; m, ω, and a are respectively the output of magnetometer, gyroscope, and accelerometer.

Matrices: Crb is the rotation matrix from the reference frame to the body frame; 0 and I are respectively null matrices and identity matrices, and their subscripts indicate dimensions, for example, the dimensions of 03×4, 03, and I4 are respectively 3 × 4, 3 × 3, and 4 × 4; [v×] is the skew-symmetric matrix of vector v.

Subscripts: x, y, and z denote respectively the x-axis, y-axis, and z-axis component of a vector; k denotes the time step.

2.2. System Model

The state vector, composed of the unit quaternion and gyroscope bias, is defined as:

x=[qTbT]T  (2)

Based on the well-known quaternion dynamics model and state augmentation, the process equation is written as:

xk+1=Ψkxk+Γknk  (3a)

where:

Ψk=[Φ(θk)Δt2Ξk03×4I3]  (3b)
Φ(θk)=exp(12[0θkTθk[θk×]])  (3c)
θk=ωkΔt  (3d)
Ξk=[qv,kT[qv,k×]+q0,kI3]  (3e)
Γk=[12Ξk12Ξk04×30303I3]  (3f)

In (3), Ψk is the transition matrix; Γk is the process noise input matrix; Δt is the sample interval; qv is the vector part of the quaternion state, and nk is the gyroscope noise with covariance matrix diag(σω2,σω2,σω2).

The linear pseudo-measurement equation of the accelerometer is:

04×1=Ha,k+1xk+112Ξk+1δak+1  (4a)

where:

Ha,k+1=[[0da,k+1Tda,k+1[sa,k+1×]]04×3]  (4b)
sa,k+1=12(ak+1+gr)  (4c)
da,k+1=12(ak+1gr)  (4d)
δak+1=ak+1Crbgr  (4e)

In (4), Ha,k+1 is the measurement matrix, and 12Ξk+1δak+1 is the measurement noise. The covariance matrix of δak+1 is σa2I3.

Similarly, the linear pseudo-measurement equation of the magnetometer is:

04×1=Hm,k+1xk+112Ξk+1δmk+1  (5a)

where:

Hm,k+1=[[0dm,k+1Tdm,k+1[sm,k+1×]]04×3]  (5b)
sm,k+1=12(mk+1+mr)  (5c)
dm,k+1=12(mk+1mr)  (5d)
δmk+1=mk+1Crbmr  (5e)

In (5), Hm,k+1 is the measurement matrix, and 12Ξk+1δmk+1 is the measurement noise. The covariance matrix of δmk+1 is σm2I3.

From (4) and (5), the overall measurement equation can be written as:

08×1=Hk+1xk+112diag(Ξk+1,Ξk+1)[δak+1Tδmk+1T]T  (6a)

where:

Hk+1=[Ha,k+1Hm,k+1]  (6b)

The noise covariance matrices of the process and measurement equations are written as:

cov(Γknk)=Qk  (7)
cov(12Ξk+1δak+1)=ρa,k+1Ra,k+1  (8)
cov(12Ξk+1δmk+1)=ρm,k+1Rm,k+1  (9)

where ρa and ρm are adaptive weight coefficients, which can be adjusted in real time. The computation formulas for Qk, Ra,k+1, and Rm,k+1 can be found in [16]. From (8) and (9), the noise covariance matrix of (6a) can be written as:

Rk+1=diag(ρa,k+1Ra,k+1,ρm,k+1Rm,k+1)  (10)

2.3. Adaptive Fusion Algorithm Based on Kalman Filter

Filter Initialization: Set initial values for state vector estimation x^, i.e., q^ and b^, and error covariance matrix P.

Time Propagation: The process model, gyroscope output and posteriori estimation (or the initial estimation) at step k is used to compute the priori estimation at step k + 1 by:

x^k+1/k=Ψkx^k  (11a)
Pk+1/k=ΨkPkΨkT+Qk  (11b)

Measurement weight adjustment: To deal with motion accelerations and magnetic disturbances, the weight coefficients ρa and ρm are adjust in real time according to the disturbance intensity, which is equivalent to adjust the measurement weight. The adjusting expressions are:

ρa,k+1=exp(λa|ak+1gr|/gr)  (12)
ρm,k+1=exp(λm|mk+1mr|/mr)  (13)

where the relative distances between the norms of measured vectors (ak+1, mk+1) and reference vectors (gr, mr) are used to represent the disturbance intensity, and the exponential functions are used to map the disturbance intensity to weight coefficients. The function of the parameters λa and λm is to adjust the mapping relations. If the weight coefficient should be more sensitive to the disturbance intensity, the corresponding parameter should be increased, otherwise, it should be reduced. The values used for λa and λm can be determined experimentally. The exponential function instead of a linear function is applied because the former can reduce the measurement weight more quickly when the relative distance increases [28].

Measurement Update: The measurement model, magnetometer and accelerometer outputs and the priori estimation at step k + 1 is used to compute the posteriori estimation at step k + 1 by:

Kk+1=Pk+1/kHk+1T(Hk+1Pk+1/kHk+1T+Rk+1)1  (14a)
x^k+1=x^k+1/kKk+1Hk+1x^k+1/k  (14b)
Pk+1=(I7Kk+1Hk+1)Pk+1/k  (14c)

Unit Constraint: To preserve the unit-norm property of the quaternion estimation, the updated quaternion is normalized by:

q¯k+1=q^k+1/q^k+1  (15)

2.4. Yaw Computation

The rotation matrix from the reference frame to the body frame can be represented as a function of either Euler angles or a unit quaternion, and the expressions are respectively:

Crb(ψ,ϕ,γ)=[cγcψ+sγsψsϕcγsψ+sγcψsϕsγcϕsψcϕcϕcψsϕsγcψcγsψsϕsγsψcγcψsϕcγcϕ]  (16)
Crb(q)=[q02+q12q22q322(q1q3+q0q3)2(q1q3q0q2)2(q1q2q0q3)q02q12+q22q322(q2q3+q0q1)2(q1q3+q0q2)2(q2q3q0q1)q02q12q22+q32]  (17)

where ψ, ϕ, and γ are respectively the yaw, pitch, and roll; s and c denote sine and cosine function, respectively.

Using the first two elements of the second row of C(q), denoted as C21 and C22 respectively, and defining the range of the yaw as (−180°, 180°], we obtain the following formulas for yaw computation:

ψ^={arctan(C21/C22)C22>0arctan(C21/C22)+180C22<0,C21>0arctan(C21/C22)180C22<0,C21<0  (18)

3. Improved Algorithm

In this section, we keep the time propagation step of the conventional algorithm unchanged, and improve its measurement update step in two ways. Firstly, to improve the accuracy of the yaw estimation in the presence of magnetic disturbances, a measurement equation of the gyroscope bias is derived and its weight can be adjusted according to the vehicle status. Secondly, we design a two-step measurement update method to eliminate the impact of the magnetometer measurement update on the attitude estimation.

3.1. New Measurement Equation and Its Adaptive Weight

The gyroscope output can be written as:

ω=ωb+b+n1  (19a)

and its z-axis component is:

ωz=ωbz+bz+n1z  (19b)

where ωb is the angular rate resolved in the body frame, and n1 is a white Gaussian noise vector. When vehicles are running straight, ωbz can be regarded as zero and (19b) can be rewritten as:

bz=Hωx+n1z  (20a)

where:

Hω=[01×61]  (20b)

Equation (20a) is a new measurement equation named as gyroscope measurement, and its characters are as follows. Firstly, it only updates the gyroscope bias estimation in measurement update, but it will affect the quaternion estimation in time propagation through (11); specifically speaking, it will constrain the yaw estimation from changing by correcting the z-axis angular rate to zero. Secondly, it is immune to magnetic disturbances because the latter cannot impact the gyroscope output. Thirdly, the gyroscope measurement only hold true in running straight status, in other words, its validity depends on the vehicle status.

Note that, the yaw is computed using quaternion estimation, and all the gyroscope bias components can impact the quaternion propagation. But, in the fusion algorithm, the quaternion estimation is not only based on propagation, but also on measurement update. The yaw derivative [12] can be written as:

ψ˙=sinγcosϕωbxcosγcosϕωbz  (21)

Obviously, the yaw derivative is related to pitch, roll, ωbx, and ωbz. In the fusion algorithm, the estimation of pitch and roll will be corrected by the accelerometer measurement (in the form of correcting quaternion), which is immune to magnetic disturbances. The two-step measurement update method which will be introduced in Section 3.2 makes pitch and roll estimation immune to the errors induced by magnetometer measurement update. In addition, generally speaking, the pitch and roll are small for land vehicles, hence the absolute value of the coefficient of ωbz is greater than that of ωbx. Therefore, the z-axis bias component is of more importance, especially in magnetically disturbed environments. Equation (21) is based on Euler angles, but it should be noted that both quaternion and Euler angles are representation of orientation, and orientation obeys a unique dynamic rule. In other words, the quaternion propagation models is different from that of Euler angles, but when they are used to represent a same orientation parameter, for example yaw, the parameter obeys a same dynamic rule no matter what representation is used.

The above characteristics suggest that the gyroscope measurement can be used to correct the yaw estimation in the presence of magnetic disturbances when vehicle is running straight. In practice, a vehicle cannot always run on a straight road, and even on a straight road the yaw may fluctuate. In order to employ this measurement correctly, we define the covariance of the measurement noise n1z as ρωσω2, where ρω, similar to ρa and ρm, works as a adaptive weight coefficient that can be adjusted in real time. Obviously, the adjusting principle should be that the higher the extent of running straight is, the smaller the ρω is.

Now, the problem is how to determine the extent of running straight. To address this problem, we analyze the correlations between different sensor outputs. The accelerometer output can be written as:

a=amCrbgr+n2  (22)

where am is the motion acceleration, and n2 is a noise vector. According to the vehicle kinematic model [29], am is given by:

am=v˙b+ωb×vb  (23)

where vb is the velocity of the vehicle in the body frame.

The reference fame and body frame are shown in Figure 1. For a land vehicle, the running direction can be arbitrary in reference frame, but in the body frame, which is attached to the vehicle, its running direction is always forward, although the forward direction may change in reference frame. The “forward direction” is the y direction in the body frame defined in this paper. Dissanayake et al. [30] have pointed out that, when the vehicle does not jump off the ground and does not slide on the ground, velocity of the vehicle in the plane perpendicular to the forward direction is zero, hence vbx and vbz can be assumed as zero. Using this assumption and substituting (16) and (23) into (22), we simplify the x-axis component of (22) as:

ax=vbyωbzgsγcϕ+n2x  (24)

Figure 1.

Figure 1

Reference frame orxryrzr and body frame obxbybzb.

In practical situation, the assumption is somewhat violated due to the presence of side slip during cornering and vibrations caused by the engine and suspension system [30]. When the assumption is violated, the side slips and vibrations will cause corresponding accelerations, but these accelerations can be regarded as noise and a part of n2x in (24).

The magnetic field resolved in the body frame, denoted as mb, can be written as:

mb=Crb(mr+dr)  (25)

where dr is the magnetic disturbances resolved in the reference frame. According to the Coriolis theorem, the change rate of mb in body frame can be written as:

m˙b=Crb(m˙r+d˙r)ωb×mb  (26)

Because m˙r=0, the x-axis and y-axis components of m˙b can be written as:

m˙bx=Cr1bd˙r+ωbzmbyωbymbz  (27a)
m˙by=Cr2bd˙rωbzmbx+ωbxmbz  (27b)

where Cr1b and Cr2b denote the first row and second row of Crb respectively. We rewrite (27) as:

m˙bx/mby=ωbz+Cr1bd˙r/mbyωbymbz/mby  (28a)
m˙by/mbx=ωbzCr2bd˙r/mbx+ωbxmbz/mbx  (28b)

When the angle between the road plane and the horizontal plane remains constant and the vehicle do not vibrate, ωby and ωbx are zero. In practice, the angle between the two planes may change, however, in general, the rate of change will be small, and the duration of the vehicle attitude change is also very short. Hence, the corresponding ωby and ωbx will be small and close to zero for most of the time. In the case of vibration, which can be caused by bumps or ditches, ωby and ωbx may have large absolute value, but they will oscillate with high frequency. Hence, regarding the last item of the right side as noise and using the magnetometer output and difference to approximate the left side of (28), we obtain:

(mx,kmx,k1)/(my,kΔt)=ωbz+Cr1bd˙r/mby+n3  (29a)
(my,kmy,k1)/(mx,kΔt)=ωbzCr2bd˙r/mbx+n4  (29b)

where n3 and n4 are noises. Because my,k and mx,k may be equal or close to zero and thus cause numerical instability, we define Δm as:

Δmk={(mx,kmx,k1)/(my,kΔt)|my,k|>|mx,k|(my,kmy,k1)/(mx,kΔt)|my,k||mx,k|  (30)

Equations (19b) and (24) show that the correlation between ωz and ax will be low if ωbz is stable; otherwise, the correlation will be high. Equations (19b), (29), and (30) show that ωz and Δm have similar relationships; more importantly, dr will not affect the correlation between ωz and Δm if it is constant and will not affect the correlation markedly except for an abrupt changing. Hence, the correlation between ωz and Δm is robust to magnetic disturbances.

Considering ωbz is stable in running straight status and unstable in turning status, we construct a vehicle status marker c, whose expression is:

c=max(0,12cor(ωz,N,ΔmN)12cor(ωz,N,ax,N))  (31)

where cor() estimates the correlation coefficient using the samples of the sensor outputs, and subscript N denotes the N points samples from kN+1 to k. In fact, in running straight status, MARG sensor outputs are stable except for uncorrelated noises; whereas in turning status, the outputs change, and the output from different sensor is correlative because their changes are caused by the same reason i.e., the vehicle is turning. The rationale of (31) is that use estimated correlation coefficients to distinguish status. In (31), the weighted sum combine the two correlation coefficient to make full use of the correlation between different sensors, and the second term of the sum is minus because ωz is negatively correlated to ax when ωbz is changing. Considering the sum is theoretically nonnegative, we set c to zero when correlation coefficient estimation errors result in a negative sum. Similar to ρa and ρm, the adjusting expression for ρω is:

ρω,k+1=exp(λωc)  (32)

where λω is a coefficient that transforms the status marker to a proper range.

3.2. Two-Step Measurement Update Method

This part presents the two-step measurement update method, and the concerned parameters of the first and second update step are respectively denoted by subscript f and s in the following.

First Step: The accelerometer and gyroscope measurement updates are implemented in this step. The measurement matrix and noise covariance matrix are respectively:

Hf,k+1=[Ha,k+1Hω]  (33)
Rf,k+1=diag(ρa,k+1Ra,k+1,ρω,k+1σω2)  (34)

The update expressions are:

Kf,k+1=Pk+1/kHf,k+1T(Hf,k+1Pk+1/kHf,k+1T+Rf,k+1)1  (35a)
x^f,k+1=x^k+1/k+Kf,k+1(Zf,k+1Hf,k+1x^k+1/k)  (35b)
Pf,k+1=(I7Kf,k+1Hf,k+1)Pk+1/k  (35c)

where:

Zf,k+1=[04×1ωz,k+1]  (35d)

Second Step: In this step, the magnetometer measurement update is implemented and the ultimate quaternion estimation is computed. The measurement matrix and noise covariance matrix are respectively:

Hs,k+1=Hm,k+1  (36)
Rs,k+1=ρm,k+1Rm,k+1  (37)

The update expressions are:

Ks,k+1=Pf,k+1Hs,k+1T(Hs,k+1Pf,k+1Hs,k+1T+Rs,k+1)1  (38a)
x^s,k+1=x^f,k+1Ks,k+1Hs,k+1x^f,k+1  (38b)
Ps,k+1=(I7Ks,k+1Hs,k+1)Pf,k+1  (38c)

Extracting quaternion part of x^f,k+1 and x^s,k+1, we obtain q^f,k+1 and q^s,k+1. Define qσ as:

qσ=q^f,k+1*q^s,k+1  (39)

where q^f,k+1* is the conjugate quaternion of q^f,k+1 and the symbol is the quaternion multiplication operator. The conjugate quaternion of a unit quaternion represents the inverse rotation and a sequence of rotations can be represented by quaternion multiplication; therefore, qσ can be viewed as the correction quaternion induced by the magnetometer measurement update. In theory, qσ should only correct the yaw estimation; however, it also modify the attitude estimation in practice. The corresponding rotation matrix equation to Equation (39) can be written as:

C(q^s,k+1)=C(qσ)C(q^f,k+1)  (40)

The condition for C(q^s,k+1) and C(q^f,k+1) to share a same attitude [26] is:

qσv×C(q^f,k+1)3=03×1  (41)

where qσv is the vector part of qσ and C(q^f,k+1)3 is the third column of C(q^f,k+1). The geometric meaning of (41) is that the rotation axis of qσ should be parallel to the z-axis of the reference frame. Based on this condition and (1), a new correction quaternion q^σ is defined as:

q^σ=[cos(α)sin(α)C(q^f,k+1)3T]T  (42a)

where:

α=arccos(qσ,0)eC(q^f,k+1)3  (42b)
e=qσv/sin(arccos(qσ,0))  (42c)

Note that q^σ is actually the projection of qσ on the direction depicted by C(q^f,k+1)3, and this treatment makes q^σ satisfy (41). Finally, the ultimate quaternion estimation is computed by:

q^k+1=q^f,k+1q^σ  (43)

3.3. Complete Improved Yaw Estimation Algorithm

Adding the adaptive gyroscope measurement update to the conventional algorithm and adopting the two-step measurement update method, we obtain the improved algorithm shown in Figure 2. Note that the improved algorithm preserves the linearity and all its measurement updates have an adaptive weight.

Figure 2.

Figure 2

Improved yaw estimation algorithm.

4. Experiments

In this section, we evaluate the performances of the improved algorithm experimentally. The real data from a MARG sensor mounted on a test vehicle are processed by the conventional and improved algorithm, respectively. Then, we analyze the performances of the vehicle status marker, gyroscope measurement update, two-step measurement update method, and yaw estimation by comparing the results of the improved algorithm against that of the conventional algorithm and reference values.

4.1. Experimental Setup and Parameters

The test vehicle and experimental devices are shown in Figure 3. A Motion Tracker MTi-28A53G35 (Xsens, Enschede, The Netherlands) [31] was used as the MARG sensor. The Global Position System (GPS) unit (Unicoremm, Beijing, China) provided reference values of longitude, latitude, and forward velocity. 3-axis gyro module STIM210 (Sensonor AS, Horten, Norway) was used as the attitude and heading reference system (AHRS), which provided reference values of the yaw and attitude. The initial value of the AHRS was computed with the static accelerometer and magnetometer outputs [32]. The laptop (Lenovo, Beijing, China) supplied power for the MARG sensor, GPS unit, and the AHRS, and logged data from them at 100Hz. The GPS unit, MARG sensor, and AHRS were mounted on the test vehicle with the sensor and AHRS frames aligned with the vehicle body frame. In experiments, the vehicle was driven along test trajectories, which consisted of straight lines, corners with different angles and a circular line, involving a full range of yaw. Note that the magnetic sensor had been calibrated inline according to the sensor manual [20]; hence, we assumed that the impact of the hard and soft iron effects had been eliminated.

Figure 3.

Figure 3

Experimental setup. (a) Test vehicle. (b) Experimental devices.

We analyzed the MARG sensor output in static condition, and set the noise parameters as follows: σm=0.0015, σω=0.0056 rad/s, σa=0.008 m/s2. We found the proper values for λm, λω, and λa by trial and error, and set them to 20, 15, and 50 respectively. The estimation of q0 was computed with the initial outputs of the magnetometer and accelerometer; the estimation of b0 was set to the gyroscope output before the vehicle was started, and P0=100I7. The initial values of Q, Ra, and Rm were computed with q0 and P0 [16].

4.2. Experimental Results and Discussion

4.2.1. Vehicle Status Marker

To analyze the experimental results more clearly, we intercepted a piece of the MARG sensor outputs corresponding to a segment of the test trajectories. Using these data, we computed the status marker c and the adaptive weight coefficient ρω, which are shown in Figure 4. In Figure 4a, the reference yaw indicates that the vehicle undergone a turning (about 90°) between 70 s and 80 s, and mainly run straight with small fluctuation of yaw in other times. Corresponding to the reference yaw, c increases markedly between 70 s and 80 s; and oscillates with small values in other times. One key to computing c effectively is to select a proper N, because too many sample points will cause severely lagged weight adjustment, whereas too few sample points will reduce the computation accuracy. In the experiments, we set N=1/Δt.

Figure 4.

Figure 4

Adaptive weight coefficient based on the vehicle status. (a) Reference yaw and c. Because the reference yaw and c have different value range, two vertical axes are used for clarity with the right one corresponding to c. (b) ρm and ρω. The magnetometer output norm is also plotted to show the relationship between magnetic disturbances and ρm, and, similar to (a), two vertical axes are used with the right one corresponding to m. To obtain a proper vertical axe limit and thus the trends of curves can be showed clearly, the maximum value of the weight coefficients is set to 100.

4.2.2. Gyroscope Measurement Update

We processed the sensor outputs using the conventional and improved algorithm, respectively, and the yaw estimation results are shown in Figure 5. The results demonstrate that the improved algorithm has better estimation accuracy, and the reasons may be analyzed as follows. In the conventional algorithm, the magnetometer measurement update corrects the yaw estimation from drifting, but the measurement weight will be adjusted down in the presence of magnetic disturbances (Figure 4b shows obvious differences between the norm of magnetometer output and one from about 15 s to 50 s implying the presence of magnetic disturbances). As a result, the correction effect attenuates and thus the yaw estimation drifts. In contrast, the gyroscope measurement update provides another correction in the improved algorithm, and more importantly, the correction can hardly be attenuated by magnetic disturbances as analyzed in Section 3. The adaptive weight coefficients shown in Figure 4b verify the function of the gyroscope measurement update: ρω is much lower than ρm in the presence of magnetic disturbances. In fact, ρω represent the validity of the gyroscope measurement, which is not affected by magnetic disturbances. Hence, the gyroscope measurement can be used in magnetically disturbed environments. The real-time adjusting ρω is critical for the gyroscope measurement to work effectively. Figure 5 also shows the yaw estimation result when ρω is set to constant 1. The result demonstrates that the constant ρω causes erroneous correction from the gyroscope measurement when the vehicle is turning, and hence results in significant estimation errors.

Figure 5.

Figure 5

Yaw estimation.

The gyroscope bias estimation results are shown in Figure 6. We estimated the reference value of bz by calculating the mean value of the gyroscope output in a not-moving interval, and the result was 0.00058 rad/s. Obviously, the bz estimation is updated more effectively in the improved algorithm, which is verified by its better yaw estimation accuracy.

Figure 6.

Figure 6

Gyroscope bias estimation. (a) Conventional algorithm. (b) Improved algorithm.

In Section 3.1, we draw a conclusion based on Equation (21) that bz estimation is more important than bx and by estimation in the fusion algorithm. To verify this conclusion based on experimental data, we constructed a conventional adaptive fusion algorithm using quaternion as state variables, and using Equation (6) as measurement equation. Note that, in this algorithm, the gyroscope bias is not estimated and compensated, and hence it will always impact the quaternion propagation. To examine the impact of the gyroscope bias, we added a constant bias on the reference angular rate provided by the AHRS and used the biased value to realize the quaternion propagation in the fusion algorithm.

We used this algorithm to estimate yaw for three times, and the constant bias were respectively set to [b, 0, 0], [0, b, 0], and [0, 0, b]. The results were denoted as bx, by, and bz respectively. Note that, in this process, all the parameters of the algorithm are same except for the constant bias. The root mean square (RMS) errors of the yaw estimation corresponding to different b are listed in Table 1. Obviously, bz has a more significant impact on yaw estimation.

Table 1.

RMS errors of the yaw estimation corresponding to different b.

Result b = 0.005 rad/s b = 0.01 rad/s b = 0.015 rad/s
bx 6.8° 7.6° 7.9°
by 7.1° 8.3° 9.1°
bz 11.2° 19.4° 29.0°

It should be noted that the gyroscope measurement updates only provide a “partial” correction, in other words, they cannot provide absolute yaw information but that the yaw is unchanged to some extent, and the “extent” is indicated by the adaptive weight. Therefore, it is reasonable to employ the gyroscope measurement updates in combination with the magnetometer measurement updates. In addition, the gyroscope measurement updates only work effectively in running straight status. In practice, turning status is inevitable, but the duration of turning is relatively short, and running along a straight road is a more usual status for most land vehicles.

In practice, a running vehicle cannot avoid bumps and ditches, which will cause oscillations of ax, ωx, and ωy. We assume these oscillations as part of the noise items in Equations (24) and (29) respectively, and construct the vehicle status marker c based on the correlations between different sensor outputs. To evaluate these noise assumptions, we analyzed a piece of the sensor outputs corresponding to a straight road with some bumps and ditches. The raw signals of ax, ωx, and ωy are shown in Figure 7 and Figure 8, respectively. The term c computed by Equation (31) is shown in Figure 9.

Figure 7.

Figure 7

ax in bumps and ditches experiment.

Figure 8.

Figure 8

ωx and ωy in bumps and ditches experiment.

Figure 9.

Figure 9

c in bumps and ditches experiment.

The vehicle met a bump or ditch at about 7 s, 19 s, 27 s, 45 s, and 58 s. Obviously, the bumps and ditches cause oscillations of the sensor outputs. Figure 9 demonstrate that the bumps and ditches do not affect c significantly, which displays small values and is consistent with the running straight status.

4.2.3. Two-Step Measurement Update Method

In the experiments, the test road is basically level except for some speed breaks. To evaluate the performances of the two-step measurement update method, we computed attitudes using the quaternion [33] from the first step update, the conventional algorithm and the improved algorithm respectively, and the results are shown in Figure 10. Obviously, the improved algorithm and the first step update have the same attitude estimation, which verify that the second step update do not modify the attitude estimation. In addition, the attitude estimation of the improved algorithm is more consistent with the reference values than the conventional algorithm. The comparison demonstrates that the two-step measurement update method eliminates the attitude estimation errors induced by the magnetometer measurement update. Besides magnetic disturbances, the magnetometer measurement error can also cause attitude estimation errors. For example, the attitude estimation of the conventional algorithm change incorrectly during the turning of the vehicle (70–80 s), and similar phenomena can be found in other turning processes, which, we think, is due to the dynamic errors of the magnetometer.

Figure 10.

Figure 10

Attitude estimation. (a) Pitch estimation. (b) Roll estimation.

It should be noted that modifications of the attitude estimation made by magnetometer measurement update essentially arise from the disagreements between the accelerometer and magnetometer outputs, which can also be caused by non-gravitational acceleration and accelerometer measurement errors. The improved algorithm prevents the magnetometer output from modifying the attitude estimation because firstly the gravity resolved in the body frame can provide sufficient attitude information, and secondly the accelerometer output is assumed more reliable than the magnetometer output in magnetically disturbed environments as has been accepted and verified in many applications.

4.2.4. Yaw Estimation

We tested two trajectories, which are referred to as A and B. MARG sensor outputs corresponding to the trajectories were processed. To show the performances of the yaw estimation intuitively, we used dead reckoning [29] to reproduce the test trajectories based on the yaw estimations and the vehicle velocity data provided by the GPS unit. The results are shown in Figure 11, where the reference trajectories recorded by the GPS unit is also plotted. Clearly, the reproduced trajectories from the improved algorithm are closer to the reference than that from the conventional algorithm.

Figure 11.

Figure 11

Dead reckoning results. The circle represents the start point, and the square represents the end point. (a) Trajectory A. (b) Trajectory B.

The root mean square (RMS) errors of the improved algorithm in trajectory A and B are respectively 1.8° and 2.9°. The reason the improved algorithm performed better in A is, as pointed out earlier, the gyroscope measurement only work effectively in running straight status. A was approximately rectangular and has longer straight roads, whereas B consisted of more turning road with different angles and curvature. Obviously, A was more suitable for the gyroscope measurement to take effect. It should be noted that vehicle status cannot affect the work of the two-step measurement update method, which is also helpful for the yaw estimation.

The RMS errors of the yaw and attitude estimation are listed in Table 2. In addition, we used the Kalman filter with vector selection [7] and the complementary filter with varying gains [21], referred to as VSKF and VGCF respectively, to process the experiment data, and the RMS errors are also listed in Table 2. Clearly, the improved algorithm performed best in the yaw and attitude estimation. In fact, as pointed out in the introduction, the VSKF and VGCF essentially use the same strategy as the conventional algorithm to handle magnetic disturbances: reducing the confidence in the magnetometer measurements, which will result in poor correction for the yaw estimation. Whereas the improved algorithm not only reduce the confidence in the disturbed measurements but also introduce new measurements based on vehicle status, which provide supplemental information for the yaw estimation. In addition, the two-step measurement update method eliminates the impacts of magnetometer errors and magnetic disturbances on attitude estimation, which is also helpful for the yaw estimation.

Table 2.

RMS errors of the yaw and attitude estimation.

Algorithm Yaw (°) Pitch (°) Roll (°)
VSKF 4.9 4.0 3.1
VGCF 5.6 3.5 3.3
Conventional 5.2 3.7 2.9
Improved 2.1 1.8 1.6

Note that the better yaw estimation accuracy of the improved algorithm is due to its enhanced ability to deal with magnetic disturbances; and it will have the same level of yaw estimation accuracy as the conventional algorithm in magnetically homogeneous environments.

5. Conclusions

An improved yaw estimation algorithm for land vehicle using a MARG sensor was proposed in this paper. Under running straight assumption, we derived the gyroscope measurement equation, which update the gyroscope bias and thus constrain the yaw estimation from changing. The validity of the gyroscope measurement depends on the vehicle status; to determine the vehicle status, we analyzed the correlations between different sensors based on the vehicle kinematic model and Coriolis theorem, and constructed a vehicle status marker used to adjust the weight of the gyroscope measurement. In addition, we designed a two-step measurement update method, which implements the magnetometer measurement update separately and eliminates its impact on attitude estimation. Adopting the gyroscope measurement update and the two-step measurement update method, we improved the conventional yaw estimation algorithm. The improved algorithm was tested in experiments and compared against the conventional algorithm. Based on the experiment results, the performances and characters of the improved algorithm were discussed and the conclusion is as follows. The gyroscope measurement update is an effective supplement to the magnetometer measurement update in magnetically disturbed environments; the two-step measurement update methods make attitude estimation immune to the errors induced by magnetometer measurement update; and the improved algorithm provides more reliable yaw estimation for land vehicles than the conventional algorithm. Finally, it should be noted that the vehicle status marker is based on statistic characteristics between different sensors, which make it robust to disturbances, but on the other hand, insensitive to the varying status. The improvements of its real-time performance and ability to detect the turning status with small angular rates will be the topics of further work.

Author Contributions

Conceptualization, G.S. and X.L.; Methodology, G.S.; Software, G.S.; Validation, X.L. and G.S.; Formal Analysis, G.S.; Investigation, G.S. and Z.J.; Resources, X.L.; Data Curation, G.S. and Z.J.; Writing—Original Draft Preparation, G.S.; Writing—Review & Editing, G.S.; Visualization, G.S.; Supervision, X.L.; Project Administration, X.L.; Funding Acquisition, X.L.

Funding

This research was funded by National Natural Science Foundation of China, grant number [61273082].

Conflicts of Interest

The authors declare no conflict of interest.

References

  • 1.Vahidi A., Eskandarian A. Research advances in intelligent collision avoidance and adaptive cruise control. IEEE Trans. Intell. Transp. Syst. 2003;4:143–153. doi: 10.1109/TITS.2003.821292. [DOI] [Google Scholar]
  • 2.McCall J., Trivedi M.M. Video-based lane estimation and tracking for driver assistance: Survey, system, and evaluation. IEEE Trans. Intell. Transp. Syst. 2006;7:20–37. doi: 10.1109/TITS.2006.869595. [DOI] [Google Scholar]
  • 3.Wada M., Yoon K.S., Hashimoto H. Development of advanced parking assistance system. IEEE Trans. Ind. Electron. 2003;50:4–17. doi: 10.1109/TIE.2002.807690. [DOI] [Google Scholar]
  • 4.Fernandez Llorca D., Milanes V., Parra Alonso I., Gavilan M., Garcia Daza I., Perez J., Sotelo M.Á. Autonomous pedestrian collision avoidance using a fuzzy steering controller. IEEE Trans. Intell. Transp. Syst. 2011;12:390–401. doi: 10.1109/TITS.2010.2091272. [DOI] [Google Scholar]
  • 5.Yim S., Jeon K., Yi K. An investigation into vehicle rollover prevention by coordinated control of active anti-roll bar and electronic stability program. Int. J. Control Autom. Syst. 2012;10:275–287. doi: 10.1007/s12555-012-0208-9. [DOI] [Google Scholar]
  • 6.Masuya K., Sugihara T. A nonlinear complementary filter for attitude estimation with dynamics compensation of MARG sensor; Proceedings of the IEEE International Conference on Advanced Intelligent Mechatronics (AIM); Banff, AB, Canada. 12–15 July 2016; pp. 976–981. [Google Scholar]
  • 7.Zhang Z.Q., Meng X.L., Wu J.K. Quaternion-Based Kalman filter with vector selection for accurate orientation tracking. IEEE Trans. Instrum. Meas. 2012;61:2817–2824. doi: 10.1109/TIM.2012.2196397. [DOI] [Google Scholar]
  • 8.Wahba G. A least squares estimate of satellite attitude. SIAM Rev. 1965;7:409. doi: 10.1137/1007077. [DOI] [Google Scholar]
  • 9.Valenti R.G., Dryanovski I., Xiao J. A linear Kalman filter for MARG orientation estimation using the algebraic quaternion algorithm. IEEE Trans. Instrum. Meas. 2016;65:467–481. doi: 10.1109/TIM.2015.2498998. [DOI] [Google Scholar]
  • 10.Yun X., Bachmann E.R., McGhee R.B. A simplified quaternion-based algorithm for orientation estimation from earth gravity and magnetic field measurements. IEEE Trans. Instrum. Meas. 2008;57:638–650. doi: 10.1109/tim.2007.911646. [DOI] [Google Scholar]
  • 11.Mahony R., Hamel T., Pflimlin J.M. Nonlinear complementary filters on the special orthogonal group. IEEE Trans. Autom. Control. 2008;53:1203–1218. doi: 10.1109/TAC.2008.923738. [DOI] [Google Scholar]
  • 12.Yoo T.S., Hong S.K., Yoon H.M., Park S. Gain-scheduled complementary filter design for a MEMS based attitude and heading reference system. Sensors. 2011;11:3816–3830. doi: 10.3390/s110403816. [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 13.Madgwick S.O.H., Harrison A.J.L., Vaidyanathan R. Estimation of IMU and MARG orientation using a gradient descent algorithm; Proceedings of the IEEE International Conference on Rehabilitation Robotics; Zurich, Switzerland. 27 June–1 July 2011; pp. 1–7. [DOI] [PubMed] [Google Scholar]
  • 14.Markley F.L. Attitude error representations for Kalman filtering. J. Guid. Control Dynam. 2003;26:311–317. doi: 10.2514/2.5048. [DOI] [Google Scholar]
  • 15.Crassidis J., Markley F.L. Unscented filtering for spacecraft attitude estimation. J. Guid. Control Dyn. 2003;26:536–542. doi: 10.2514/2.5102. [DOI] [Google Scholar]
  • 16.Choukroun D., Bar-Itzhack I.Y., Oshman Y. Novel quaternion Kalman filter. IEEE Trans. Aerosp. Electron. Syst. 2006;42:174–190. doi: 10.1109/TAES.2006.1603413. [DOI] [Google Scholar]
  • 17.Kok M., Schön T.B. Magnetometer calibration using inertial sensors. IEEE Sens. J. 2016;14:5679–5689. doi: 10.1109/JSEN.2016.2569160. [DOI] [Google Scholar]
  • 18.Shi G., Li X.S., Li X.F., Liu Y.X., Kang R.Q., Shu X.Y. Equivalent two-step algorithm for the calibration of three-axis magnetic sensor in heading measurement system. Chin. J. Sci. Instrum. 2017;38:402–407. [Google Scholar]
  • 19.Vasconcelos J.F., Elkaim G., Silvestre C., Oliveira P., Cardeira B. Geometric approach to strapdown magnetometer calibration in sensor frame. IEEE Trans. Aerosp. Electron. Syst. 2011;47:1293–1306. doi: 10.1109/TAES.2011.5751259. [DOI] [Google Scholar]
  • 20.Magnetic Field Mapper Documentation. Xsens Technologies B.V.; Enschede, The Netherlands: 2013. [Google Scholar]
  • 21.Costanzi R., Fanelli F., Monni N., Ridolfi A., Allotta B. An attitude estimation algorithm for mobile robots under unknown magnetic disturbances. IEEE/ASME Trans. Mechatron. 2016;21:1900–1911. doi: 10.1109/TMECH.2016.2559941. [DOI] [Google Scholar]
  • 22.Wu J., Zhou Z.B., Chen J.J. Fast complementary filter for attitude estimation using low-cost MARG sensors. IEEE Sens. J. 2016;16:6997–7007. doi: 10.1109/JSEN.2016.2589660. [DOI] [Google Scholar]
  • 23.Tong X., Li Z.F., Han G.W. Adaptive EKF based on HMM recognizer for attitude estimation using MEMS MARG sensors. IEEE Sens. J. 2018;18:3299–3310. doi: 10.1109/JSEN.2017.2787578. [DOI] [Google Scholar]
  • 24.Feng K., Li J., Zhang X., Shen C., Bi Y., Zheng T., Liu J. A new quaternion-based Kalman Filter for real-time attitude estimation using the two-step geometrically-intuitive correction algorithm. Sensors. 2017;17:2146. doi: 10.3390/s17092146. [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 25.Sabatini A.M. Kalman-Filter-based orientation determination using inertial/magnetic sensors: Observability analysis and performance evaluation. Sensors. 2011;11:9182–9206. doi: 10.3390/s111009182. [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 26.Suh Y.S. Orientation estimation using a quaternion-based indirect Kalman filter with adaptive estimation of external acceleration. IEEE Trans. Instrum. Meas. 2010;59:3296–3305. doi: 10.1109/TIM.2010.2047157. [DOI] [Google Scholar]
  • 27.Suh Y.S., Ro Y.S., Kang H.J. Quaternion-based indirect Kalman filter discarding pitch and roll information contained in magnetic sensors. IEEE Trans. Instrum. Meas. 2012;61:1786–1792. doi: 10.1109/TIM.2011.2181910. [DOI] [Google Scholar]
  • 28.Sun S., Meng X., Ji L., Wu J., Wong W.C. Adaptive sensor data fusion in motion capture; Proceedings of the 13th International Conference on Information Fusion; Edinburgh, UK. 26–29 July 2010. [Google Scholar]
  • 29.Ahmed H., Tahir M. Accurate attitude estimation of a moving land vehicle using low-cost MEMS IMU sensors. IEEE Trans. Intell. Transp. Syst. 2017;18:1723–1739. doi: 10.1109/TITS.2016.2627536. [DOI] [Google Scholar]
  • 30.Dissanayake G., Sukkarieh S., Nebot E., Durrant-Whyte H. The aiding of a low-cost strapdown inertial measurement unit using vehicle model constraints for land vehicle applications. IEEE Trans. Robot. Autom. 2001;17:731–747. doi: 10.1109/70.964672. [DOI] [Google Scholar]
  • 31.MTi and MTx User Manual and Technical Documentation. Xsens Technologies B.V.; Enschede, The Netherlands: 2013. [Google Scholar]
  • 32.Jurman D., Jankovec M., Kamnik R., Topič M. Calibration and data fusion solution for the miniature attitude and heading reference system. Sens. Actuator A-Phys. 2007;138:411–420. doi: 10.1016/j.sna.2007.05.008. [DOI] [Google Scholar]
  • 33.Qin Y.Y. Inertial Navigation. 2nd ed. Science Press; Beijing, China: 2014. pp. 251–252. [Google Scholar]

Articles from Sensors (Basel, Switzerland) are provided here courtesy of Multidisciplinary Digital Publishing Institute (MDPI)

RESOURCES