Skip to main content
Sensors (Basel, Switzerland) logoLink to Sensors (Basel, Switzerland)
. 2020 Nov 25;20(23):6731. doi: 10.3390/s20236731

A Kalman Filter for Nonlinear Attitude Estimation Using Time Variable Matrices and Quaternions

Álvaro Deibe 1,*, José Augusto Antón Nacimiento 2, Jesús Cardenal 2, Fernando López Peña 1,3
PMCID: PMC7728053  PMID: 33255620

Abstract

The nonlinear problem of sensing the attitude of a solid body is solved by a novel implementation of the Kalman Filter. This implementation combines the use of quaternions to represent attitudes, time-varying matrices to model the dynamic behavior of the process and a particular state vector. This vector was explicitly created from measurable physical quantities, which can be estimated from the filter input and output. The specifically designed arrangement of these three elements and the way they are combined allow the proposed attitude estimator to be formulated following a classical Kalman Filter approach. The result is a novel estimator that preserves the simplicity of the original Kalman formulation and avoids the explicit calculation of Jacobian matrices in each iteration or the evaluation of augmented state vectors.

Keywords: Kalman Filter, attitude estimation, IMU, AHRS, quaternions

1. Introduction

Inertial sensors (in particular, accelerometers and gyroscopes) are among the most common types of devices used for estimating the orientation of a solid body. Ideally, the orientation of a body can be calculated by integrating over time the signal from a three-axis gyroscope. However, the inherent bias and drift of the sensor introduce errors that increase throughout the integration process. This problem is more serious for low-cost Microelectromechanical System (MEMS) gyroscopes, which are more prone to drift and bias than larger and more expensive gyroscopes [1].

Magnetic sensors are also commonly used to measure the Earth’s local magnetic field. Combining inertial and magnetic sensors provides redundant information about the attitude of the body, including, but not limited to, information about two vectors that correspond to the Earth’s magnetic and gravitational fields (H and G in Figure 1). Several methods have been proposed to solve the estimation of the orientation of a body from two known vectors (for reviews, see [2,3]).

Figure 1.

Figure 1

Earth reference system.

The Earth’s magnetic field vector, although variable with time, altitude, latitude and longitude, can be considered invariable in nearby surroundings. Thus, the Earth’s magnetic field measurement can be used to reduce the drift that many Inertial Measurement Unit (IMU) present around the vertical axis. The device resulting from the addition of a triaxial magnetometer to an IMU is usually known as a Magnetic, Angular Rate and Gravity (MARG) sensor. Under certain circumstances, it is possible to make a non-drifting attitude estimator based on a MARG sensor. A unit combining a MARG sensor with the electronics running the estimation algorithm is commonly called Attitude and Heading Reference System (AHRS). In modern outdoor applications, they are often combined with GNSS measurements, as in [4].

Most AHRSs have severe constraints concerning their size, weight and energy consumption and have limited computational power [5]. The estimators implemented in these systems need to be designed to comply with these restrictions. This is the case of the present approach, which achieves simplicity and low computational cost through the use of quaternions, variable time matrices and a particular state vector construct. The main goal is that, when estimating the attitude, nonlinear transformations due to rotations and changes of reference system can be written as matrix–vector products compatible with the original KF formulation. Some approaches for attitude estimation based on Linear Kalman Filter have been adopted by other authors, e.g. Ligorio and Sabatini [6].

As with quaternions, the use in KF of specific state vectors and time-varying matrices is not new. For example, Zhu and Zhou [2] used a state vector produced by accelerometer and magnetometer measurements. Gebre-Egziabher et al. [3] made use of a time-varying Kalman Filter implementation for gyro-free quaternion-based attitude determination. The main contribution of the current proposal is the use and combination of the chosen state-vector, quaternions and time-varying matrices.

2. Background

2.1. Orientation and Quaternions

Quaternions can be used to perform changes in attitude or system of reference through simple scalar addition and multiplication operations. This property allows writing these changes as matrix–vector products, which turns out to be essential for the particular formulation of the present method.

In addition, quaternions display some favorable characteristics: they do not present gimbal-locks and they produce a uniform approximation of attitude representation. Moreover, quaternion-based algorithms do not need to compute trigonometric functions. This characteristic highly reduces their computational cost, and it has been widely used in orientation algorithms, not only those based on KF as in [7] but also in others, such as complementary filters [8]. That is also taken advantage of in the present approach, although it is not an essential factor in its operation.

Appendix A contains a brief explanation of basic quaternion notation as it is used throughout this work.

2.2. Kalman Attitude Estimation

Kalman Filters (KF) are one of the most commonly used tools to solve the attitude estimation problem. This is probably because the KF approach can make use of every piece of information available to solve the problem, i.e., the dynamic model of the system, sensors data and the probabilistic footprint both of sensor signals and algorithm numerical behavior. Besides, the original KF turns out to be optimal and numerically efficient [9].

A discrete-time process can be described by the equations:

xk=Φkxk1+Buk1+wk1 (1)
zk=Hkxk+vk (2)

Equation (1) is a stochastic difference equation that models the discrete-time process and serves to estimate the state vector x. Equation (2) describes the relationship between x and the measurement vector z. Vectors w and v are random variables that represent, respectively, process and measurement noise. They are assumed to be white, uncorrelated and having normal probability distributions:

pw=N0,Q, pv=N0,R (3)

Matrix Bk in Equation (1) is used to relate external actions uk1 to the state vector. However, in the present work, uk is always considered void, thus Bkuk1 is not present.

The original KF formulation [9] begins with a prediction or time update stage, which can be formulated as:

x^k=Φkx^k1Pk=ΦkPk1ΦkT+Qk (4)

followed by a correction or measurement update stage:

Kk=PkHkTHkPkHkT+Rk1x^k=x^k+KkzkHkx^kPk=IKkHkPk (5)

Since the system model is quite often nonlinear, different modifications to the KF algorithm have been proposed to handle nonlinearities. These modifications usually cause KF to lose its optimality and, to some extent, its simplicity and efficiency. The Extended Kalman Filter (EKF) and Sigma Point Kalman Filter (SPKF) family are among the most common of these KF modifications.

The original KF algorithm [9] recursively estimates process state vector xk at any iteration k from its previous value, xk1, following a prediction–correction scheme. On the other hand, the EKF algorithm uses nonlinear functions f(xki,uk) and h(xk) instead of matrices.

Although being very similar to KF, some facts make EKF different. First, as f and h are not linear, EKF no longer meets the KF optimality conditions. Second, the use of these nonlinear functions may compromise the algorithm convergence. Third, it is assumed that xk is a Gaussian random variable (GRV), but, when evaluated by nonlinear functions f and h, it loses its GRV condition. Furthermore, at each step of the iteration, both Jacobian matrices used in the process and the nonlinear functions f and h must be evaluated. All these make the EKF computationally more expensive than the KF.

One possible way to overcome the problem of not preserving the GRV condition of x is by making use of a sample of characteristic points in the state space. These points are known as Sigma Points. Different methods have been proposed to sample representative sigma point sets, which result in new non-derivative Kalman Filters: the Unscented Kalman Filters (UKF) [10], the Central Difference Kalman Filters (CDF) [11] or the Divided Difference Filter (DDF) [12], among others. All these filters have been grouped into the Sigma-Point Kalman Filter (SPKF) family [13].

One of the main ideas behind SPKF is to increase the state vector x, of size L, by including process noises, making it grow to a size of 2L+1. This augmented vector is sampled 2L+1 times, to produce the sigma points. Then, these sigma points are propagated through the nonlinear equations of the process. This methodology eliminates the propagation of GRVs through the nonlinear functions present in the process, avoiding the costly computation of EKF Jacobian Matrices. However, sampling sigma points and propagating them through these nonlinear functions is also computationally expensive. This results in a suboptimal algorithm that is more complex than the original KF.

The proposed algorithm avoids these drawbacks by dealing with these nonlinearities in a simple and innovative way, as shown in the following section.

The purpose of what is presented in the rest of this document is to describe the bare filter and show its intrinsic behavior. Therefore, while possible, no acceleration restrictions are imposed, and no data from other sensors are provided. Under these conditions, the acceleration or attitude is expected to drift over time. This drift can be seen in Section 4, where the experimental results are discussed.

3. Proposed Filter Algorithm

A preliminary version of the attitude estimation algorithm described in this section is sketched in [14]. The algorithm follows the original KF approach [9], thus it is formulated as in Equations (4) and (5).

In the present case, the two stages represented by these equations are preceded by an initial stage to evaluate the matrices Φk and Hk and followed by a final normalization stage, which guarantees that the orientation quaternion remains unit, as will be explained later.

Two reference systems are used: the body reference system, attached to the tracked body, and the Earth reference system. The latter has its z axis (ez) pointing towards the Earth center, the x axis (ex) oriented towards the magnetic north and the y axis (ey) towards the magnetic east, as shown in Figure 1.

The main components of the estimator are described in the following.

3.1. State Vector

The state vector xk has been chosen to allow writing prediction and correction stages as matrix–vector products. This allows maintaining the original KF formulation. It is composed of measurable physical magnitudes: accelerations, orientation and angular velocities. For time step k, it can be written as:

exk=eakeqkbvr,kT (6)

where

  • eak=axayazT is the acceleration vector expressed in Earth coordinates. It takes into account external accelerations due to changes in velocity. This approach differs from most MARG attitude estimators based on Kalman Filter [15], where the average value of external accelerations is usually set to zero.

  • eqk=q1q2q3q4T is a unit quaternion representing body orientation expressed in earth coordinates. It is used here to change between body and Earth reference systems (see Appendix A). The last stage of the filter algorithm includes the necessary corrections to enforce that this quaternion remains unitary.

  • bvr,k=vxvyvzT is the vectorial part of the rotation quaternion bqr=ω0,bvr at time step k. This quaternion represents the orientation change in body coordinates. It should be noted that ω0, the scalar part of bqr is not needed, provided that this quaternion remains unitary.

As shown below, matrices Φk and Hk in Equations (4) and (5) include vectors that need to be reoriented or expressed in a different base. However, the state vector includes information on orientation and rotation in quaternion eqk and vector bvr,k, respectively. Therefore, these changes in orientation, or base changes, occur directly when the state vector is multiplied by any of these matrices.

3.2. Measurement Vector

Vector zk is the measurement vector. It contains information obtained from the sensors at time k, expressed in the local (body) reference system:

zk=bakbmkbωkT (7)

where bak are the measurements of the linear accelerations, obtained from a triaxial accelerometer; bmk contains the measurements of the Earth’s magnetic field along the three orthogonal axes of the body reference system; and bωk are the three angular velocity measurements obtained from a triaxial rate-gyro.

In the remainder of this section, the subscript k is omitted for convenience, as long as this cannot lead to misinterpretation.

3.3. The Process Model

Matrix Φ in Equation (4) is built as block diagonal, and it is used to perform the prediction stage:

Φ=diag(Φ11 Φ22 Φ33) (8)

Each block in Φ has a counterpart in the state vector:

  • Acceleration: In the prediction phase, it is assumed that acceleration remains constant (there is no direct measure of external forces), which leads to:
    Φ11=I3×3  eak+1eak (9)
  • Orientation quaternion: In the prediction phase, it is also assumed that the angular velocity remains constant, so the orientation using relation Equation (A10) in Appendix A changes accordingly:
    Φ22 · eq =eq ω0bvr=ω0 · I44+Ω · eq  (10)
    Thus, the block Φ22 of the transition matrix takes the following form:
    Φ22=ω0I44+Ω  eqk+1 Φ22 · eqk (11)
    where matrix Ω depends on the rotation vector bvr (Equation (A12) in Appendix A).
  • Rotation quaternion: As the angular velocity is assumed to be constant, the rotation quaternion remains invariant. Thus, Φ33 becomes:
    Φ33=I3×3  bvr,k+1bvr,k (12)

It is important to note that, given the way that the transition matrix Φ has been built, it fits into the structure of a linear KF. The fact that Φ is a time variable matrix, combined with the use of quaternions and the described state vector, is what allows handling a nonlinear problem using a linear scheme.

3.4. Covariance Matrices

Because Φ is block diagonal, the process noise covariance matrix is also block diagonal:

Q=diag(Qa Qq Qr) (13)

The blocks in Q correspond to acceleration ea, orientation quaternion eqk and rotation quaternion bvr (see Appendix B).

3.5. The Observation Model

Matrix H is used to relate the sensors measurement vector to the state vector through product z=H · x:

babmbω=H11H1200H22000H33 · eaeqbvr (14)

Matrices H11 and H12 depend on the orientation bq (see Appendix C). The gravity vector g · ez and the acceleration vector ea are expressed in the inertial reference frame. By performing a change of basis on Equation (A4), the accelerometer measurement vector can be constructed as:

0ba=eq 0eaeq g · eq 0ezeq (15)

Gravity, g, is measured at the beginning of each test and is assumed to be constant throughout the experiment. Using Equation (A10) in Appendix A, Equation (15) can be expressed as the product of a (3×3) matrix by a vector, in the first case, and as a (3×4) matrix by a quaternion, in the second:

ba=H11 · ea+H12 · eq  (16)

Matrix H22 (see Appendix C) is used to perform the estimation of the magnetometer output. This estimation can be expressed as:

bm=h · eq sinα 0ex+cosα 0ezeq (17)

where α is the angle between the local magnetic and gravity fields and h is the magnetic field modulus. Both are measured at the beginning of each experiment and assumed to remain constant. This equation can be expressed as a matrix by quaternion product:

bm=H22 · eq (18)

Matrix H33 performs a prediction on the rate-gyro readings as a function of the rotation velocity according to bω=H33bvr. In this case, both vectors are expressed in the local reference frame, so quaternion eq is not needed. Using Equation (A8) in Appendix A, matrix H33 can be written as:

H33=2ΔtI3×3 (19)

The primary purpose of this work is to show the viability of the bare estimator. That is why typical errors of the sensors such as drift of the rate-gyros have been considered negligible. However, the estimator can be modified to deal with these issues. Matrix H33 can be reformulated such that it can model the drift of rate-gyros. In addition, after incorporating the temperature measurement to the state vector, matrix H could be modified to deal with the temperature drift of all of the sensors.

As it happens with Φ, block matrices Hij are time variable.

4. Experimental Results

As discussed in previous sections, the proposed new filter formulation is simpler and computationally less demanding than other common KF implementations for nonlinear estimation. This feature will be of interest in many implementations, particularly those related to AHRS. The next step is to verify the operation of this filter in some test applications. Therefore, in this section, the results of numerical and real test cases are discussed. The objective is to empirically compare the proposed filter with other KFs, in terms of effectiveness, precision and accuracy.

The numerical test case presents a simulated double pendulum maneuver in which there are very sudden changes in body orientation. The result is obtained numerically, and the consequent accelerations, angular velocities and magnetic vectors are calculated and taken as ground truth, both directly and after adding an amount of 3D white noise similar to the one characterizing MARG sensors. Even though the actual movement is two dimensional, no constraints are imposed on the virtual sensors. They perform their measurements as if the bodies were free to move in full 3D. In this situation, some accumulative drift is expected, driving the estimated maneuver out of its plane.

The second test case consists of a real maneuver tracking of a solid, instrumented with real MARG sensors. The proposed attitude estimator is fed with measurement data taken from these sensors. The estimated orientation obtained with this filter is qualitatively compared to the real one and also to the estimations obtained with other published filters.

4.1. Double Pendulum

A double compound pendulum (Figure 2) is considered. Both links are revolute joints as a planar motion is modeled. Its inertial reference system is located on the Earth’s surface, having x, y and z axes pointing north, east and down, respectively. The pendulum is assumed to be ideal, without friction or any other cause that could dissipate energy and evolves freely in a vertical plane under the action of gravity. The local reference system is chosen so that it is aligned with the inertial one when the mechanism is at rest in stable dynamic equilibrium, i.e., having both bars aligned and pointing down.

Figure 2.

Figure 2

Reference systems for the double pendulum case study.

Considering φ1 and φ2 as generalized coordinates, the Lagrange equations lead to the following second-order system of ordinary differential equations (ODE).

m1L12+I1+4m2L122m2L1L2cosφ1φ22m2L1L2cosφ1φ2m2L22+I2φ¨1φ¨2=2m2L1L2φ˙22sinφ1φ2m1+2m2gL1sinφ12m2L1L2φ˙12sinφ1φ2m2gL2sinφ2 (20)

where g is the acceleration of gravity; m1, I1 and L1 are, respectively, the mass, inertia moment and semi-length of bar 1; and m2, I2 and L2 are the mass, inertia moment and semi-length of bar 2.

This ODE system is solved numerically with enough precision to be considered as ground truth. This makes it also possible to generate a set of synthetic measurements supposedly taken by a set of virtual MARG sensors located at the mass center of the bar labeled 2 in Figure 2. These virtual measurements of acceleration, angular velocity and magnetic field are inputs to the filter. The resulting orientation estimation is compared then to the ground truth to provide evidence on the proposed filter fitness.

The masses and semi-lengths of pendulum elements 1 and 2 are set to be equal to unity (L1=L2=1 m, m1=m2=1 kg). The multibody system evolves from an initial still position, with both bars placed horizontally. The simulation provides a set of values of φ1, φ2, φ˙1 and φ˙2 for the first 10 s of the simulated pendulum motion. From these values, the measured values acquired by the virtual MARG sensors are calculated without error (except computational round-off).

This section presents the results of two instances of the experiment. In the first one, clean virtual measurements are used directly, while, in the second one, Gaussian white noise is added to these measurements. This added noise has zero mean and a variance characteristic of each type of triaxial sensor making up the MARG: accelerometer, rate-gyro and magnetometer (see Table 1). These values have been previously obtained experimentally [14] for a particular MARG sensor.

Table 1.

Sensor variance characterization.

Sensor [Units] Without Noise With Noise
Rate-gyro [rad2/s2] 1 × 1016 3.6 × 103
Accelerometer [m2/s4] 1 × 1016 2 × 104
Magnetometer [G2] 1 × 1016 1 × 106

Both instances of the experiment have been performed in two different ways. The first run takes place in the xz-plane. This plane contains the gravity and magnetic field vectors, thus virtual sensors attached to bar 2 do not have any input out of this plane (see Figure 2). In the second run, the planar movement of double pendulum takes place in the yz-plane, which does not contain the magnetic field vector, so that virtual magnetometers perceive inputs with non-zero values in the three axes.

Although the proposed filter uses quaternion algebra, for clarity, Euler’s parameters ϕ, θ and ψ are used to present the results. These parameters correspond to rotations around the ex, ey and ez axes. The angle φ2 that defines the orientation of the second bar coincides with Euler’s θ parameter in the first case, while it coincides with the ϕ parameter in the second. In the test variants where sensor noise is added, since this noise is 3D, all sensors produce non-zero outputs on their three axes.

Figure 3 summarizes the results when the simulation is carried out in the xz-plane. It includes a comparison between the Euler’s parameters obtained as ground truth and those provided by the proposed estimator, without (left column) and with added noise (right column). Figure 3c,d represents values of angle φ2 corresponding to the true motion. The differences between ground truth (red line) and estimated values (blue line) of the angle φ2 are so small that both lines are superimposed in these two figures. The rest of the subfigures present the out-of-plane perceived movement. As this should be null, the ground truth remains equal to zero. However, as expected, the estimator produces non-zero outputs here. Nevertheless, these outputs remain within very contained values, in the order of 1×104 deg without noise and 1×101 deg with added noise.

Figure 3.

Figure 3

Simulation of the dynamics of the double pendulum on the xz-plane: Euler parameters calculated by numerical integration (red line) and estimated using the proposed filter when virtual sensor data have no noise (left) and when they have noise (right).

Table 2 summarizes the differences between angular estimation and ground truth in all test cases. As can be seen, the mean value of these differences is always close to zero. Besides, the variance of errors in the estimation of angle φ2 rotated by bar 2 is in the order of 1×101 deg.

Table 2.

Mean and RMS values of differences (deg) between expected and estimated angles.

Plane Difference Without Noise With Noise
(deg) Mean RMS Mean RMS
ϕϵ 2.8 × 105 1.3 × 105 −9.6 × 103 0.12
xz φ2e  θϵ −4.4 × 102 1.6 × 101 −4.4 × 102 0.16
ψϵ 2.7 × 105 1.4 × 105 −2.5 × 102 0.14
φ2e  ϕϵ 2.0 × 102 7.1 × 102 −3.2 × 102 0.15
yz θϵ 8.1 × 104 1.0 × 101 −2.7 × 102 0.12
ψϵ 5.0 × 103 1.0 × 101 −2.2 × 102 0.14

Gaussian noise appears to have a noticeable effect regarding the fake off-plane displacements produced by the estimator:

  • In the noiseless case, there are differences between estimations in the xz-plane and the yz-plane. While the mean error can be considered negligible in both cases, it is closer to zero by two orders of magnitude when there are no out-of-plane measurements (xz-plane case).

  • In the with noise case, the average of deviations between the expected and estimated values is approximately zero, while the standard deviation is of the same order of magnitude in both simulations (about a tenth of a degree).

Henceforth, it can be gathered that estimation errors that lead to out-of–plane movements are small oscillations that do not represent a continuous drift in any direction. For this reason, it can be concluded that the proposed orientation estimator behaves precisely and stably in this synthetic test.

4.2. Consecutive Decoupled Turn on Each Axis

The second test presents a true maneuver. The purpose of this example is to exhibit the ability of the proposed filter to track a real body movement and check its ability to follow a known maneuver quickly and stably.

In this experiment, a solid box is subjected to some independent and sequential turning maneuvers. It is instrumented with a MARG sensor that allows measuring acceleration, angular velocities and magnetic field over time. For this purpose, an AHRS device manufactured by Redshift Labs Pty Ltd. (formerly CH Robotics LLC) was selected [16]. Its core is an InvenSense MPU-9150, which includes a set of triaxial sensors (rate-gyro, accelerometer and compass).

The instrumented body is initially oriented so that the local and global reference frames coincide. As shown in Figure 4, each turning maneuver consists of a turn of π/2 rad, followed by a turn of π rad and a final turn of π/2 rad that returns the body to its initial orientation. The complete experiment includes rotations around each of the axes of the frame of reference.

Figure 4.

Figure 4

Schematic representation of turn maneuver in one axis.

Each maneuver is separated from the next by a period of 5 s at rest and is performed at a speed of 1 s per turn. All movements are performed by hand and, consequently, the accuracy of both the rotated angle and timing is not guaranteed. However, during the idle periods, with values of ±π/2 rad, the box is lying on a flat horizontal surface and backed by a fixed vertical dihedral. Therefore, these idle intervals can be used as a reference. Similar orientation tests were performed by Farhangian and Landry [17] for probing an intermittent calibration technique of an EKF-based attitude determination algorithm.

The MARG raw datasets were collected during the maneuver and used to feed the proposed filter and two other orientation estimators: a proprietary EKF embedded in the AHRS microcontroller [16] and a filter based on a gradient descent algorithm proposed by Madgwick et al. [18,19]. A qualitative comparison between these three filters is shown in Figure 5.

Figure 5.

Figure 5

Turn around each axis: estimated angle (deg) vs. time (s).

Figure 5a–c presents the results of the estimated solid body orientation over time as computed by the embedded EKF, gradient descent and proposed filters. Each graph represents the estimated turned angle on each axis and includes two zoomed details at idle states in π/2 and π/2.

In terms of promptness, stability and precision, it can be seen that the proposed estimator performs well. Figure 5, and especially Figure 5b, shows a rotational bias drift. This drift is the result of not having imposed any restrictions on acceleration. As indicated above, this type of correction has been avoided to allow a better view of the bare filter behavior.

A priori, the algorithm embedded into the AHRS should perform better than the gradient descent and the proposed estimator. First, the proprietary EKF operates at a frequency rate of 500 Hz (there is no information about its inner data acquisition frequency rate, which could be higher) while input data rate for both the proposed and the gradient descent estimators is of 50 Hz. Second, the embedded EKF has been factory tuned with an unpublished sensor characterization. Therefore, it has not been possible to include it in the other two algorithms. This lack of sensor characterization is more evident when performing a turn maneuver around the z axis because, in this case, the rate-gyro that measures angular velocity on this axis has less precision than the other two [16].

None of the three shown estimators is the best performer in every scenario, as can be seen from the six insets in Figure 5. However, it is noteworthy that, in some circumstances, such as in the second inset of Figure 5a, the proposed algorithm performs better than the proprietary, factory-tuned EKF. Besides, it is feasible to improve the behavior of the proposed estimator by making adjustments and fine-tuning it.

5. Conclusions

This work presents a new formulation and the corresponding algorithm for a Kalman Filter that is used to estimate the attitude of a rigid body when the input data come from MARG sensors.

The starting point for developing this algorithm is the original formulation of the Kalman Filter. The characterization of the rigid body orientation in space is achieved by a construction that uses quaternions instead of Euler angles. Two quaternions are used, one for orientation and another for rotational speed. A specific state vector made up of these two quaternions plus the acceleration vector allows expressing equations containing trigonometric functions as simple matrix by vector products. These matrices are time variable and allow modeling the nonlinear dynamic behavior of the process as a succession of linear steps within the KF.

For the execution of the resulting time variable Kalman Filter (TVKF), it is not necessary to calculate trigonometric functions, obtain Jacobians, or perform any type of complex mathematical operation. In addition since it is derived from the original KF formulation, the drawbacks of other nonlinear approaches such EKF or SPKF are avoided. Instead, in the current approach, the coefficients of the TVKF filter matrices are calculated at each time step by using simple algebraic operations. As a consequence, the filter seems to be well suited to be used in the code embedded in MARG sensors, given their limited computational resources.

This work intends to present this TVKF and show how it behaves. For the latter purpose, the results of two sets of tests are presented and discussed. For the first set, the simulated movement of a composite pendulum is used. This allows the numerical solution to the equations that govern this movement to be used as the fundamental truth. In the second set, a real case is considered. Here, the results obtained by the presented TVKF are compared to those obtained with two Kalman Filters: one is the commercial KF incorporated in the MARG sensor that was used and the other was obtained from the literature.

Acknowledgments

We wish to acknowledge the support received from the Galician Research Center CITIC, funded by Xunta de Galicia and the European Union (European Regional Development Fund—Galicia 2014-2020 Program), by grant ED431G 2019/01.

Abbreviations

The following abbreviations are used in this manuscript:

AHRS Attitude and Heading Reference System
CDF Central Difference Filter
DDF Divided Difference Filter
EKF Extended Kalman Filter
GRV Gaussian Random Variable
IMU Inertial Measurement Unit
KF Kalman Filter
MARG Magnetic, Angular Rate, and Gravity
MEMS Micro Electro Mechanical Sensor
ODE Ordinary Differential Equation
SPKF Sigma–Point Kalman Filter
TVKF Time Variable Kalman Filter
UKF Unscented Kalman Filter
VLKF Variable Linear Kalman Filter

Appendix A. Quaternion Notation

The following is a brief explanation of basic quaternion notation and expressions as they are used throughout this paper. In the quaternion

q =q0 q1 q2 q3T=w sTT (A1)

the first component, q0, is the scalar part, while the next three, q1,q2 and q3, constitute the vector part, s.

Any unit quaternion can be used to represent a rotation, thus unit quaternion q can also be expressed as

eq =cosφ2   sinφ2 · evTT (A2)

where φ is the rotated angle and v is a unit vector defining the axis around which rotation takes place. The left superscript e denotes the Earth reference system, while the left superscript b denotes the body reference system. The rotated angle φ should fall within the interval [π, π) so that the scalar part is always positive.

Quaternion eq can be used to rotate the axes of the inertial reference system (Earth) to align them to the body reference system. Thus, eq also represents the change of basis between these two reference systems. Thus, the components of any vector u in both reference systems are related as follows [20]:

0eu=eq 0bueq (A3)
0bu=eq0eueq (A4)

where ⊗ and * denote quaternion product and conjugate, respectively. This relations can also be expressed as matrix–vector products [21]:

eu=beCeq  · bu (A5)
bu=ebCeq  · eu (A6)

Orientation Quaternion Derivative

A detailed description of the quaternion orientation derivative can be found in [22]. The derivative of orientation quaternion eq  is given by the following expression:

ddteq =limΔt01Δteq bqr eq (A7)

Assuming there was an orientation change in Δt, bqr (evaluated in the body reference system, as indicated by the left “b” superscript) represents the rotation of orientation quaternion eq in this time step. As Δt0, rotated angle δφ could be considered small enough to approximate bqr as:

bqr =cosδφ2sinδφ2 · v1Δt2 bω (A8)

where bω is the angular velocity measured in the body reference system. Introducing Equation (A8) into (A7) leads to:

ddt eq =12 eq 0bω (A9)

Using the relationships

q 0ω=Ωω · q =Ξq · ω (A10)

Equation (A9) can be re-written in matrix form as follows:

ddt eq =12 Ωbω · eq (A11)

where matrices Ω(ω) and Ξ(q) are:

Ω(ω)=0ω1ω2ω3ω10ω3ω2ω2ω30ω1ω3ω2ω10,    Ξ(q)=q1q2q3q0q3q2q3q0q1q2q1q0 (A12)

The quaternion product is not commutative. However, product q (0 ω)T in Equation (A9) can be written as a matrix×vector product using the Ω or Ξ matrices.

Appendix B. Covariance Matrices

The parameterization of the covariance matrices, in the cases of acceleration ea and rotation quaternion bvr, uses two parameters whose values need to be adjusted:

Qa,k=σa2 · I3×3 (A13)
Qr,k=σr2 · I3×3 (A14)

In the case of orientation quaternion (eqk), the covariance matrix can also be expressed in terms of rate-gyros variances. The measurements taken by the rate-gyros (obviating at this time the bias drift) can be modeled as:

bω=ω˘+vg   Σg=EvgvgT=σg2 I3×3 (A15)

where ω˘ is the true angular velocity and bω is the angular velocity as measured by the rate-gyros. Vector vg is the part of the measurement noise given in Equation (A2) that is due to the rate-gyros, which has zero mean and a covariance matrix Σg.

Using this notation, replacing bω by ω˘ in Equation (A9) and using the relation given in Equation (A10), the process noise due to the orientation quaternion wq is given by:

wq,k=Δt2Ξ(eqk) · vg,k (A16)

Finally, the process noise covariance matrix Qq,k can be written as follows [23,24]:

Qq,k=Δt42 Ξeqk Σg ΞeqkT=Δt42 σg2 trPq,kI4×4Pq,k (A17)

where Pq,k is the error covariance matrix of the quaternion component of the state vector.

Appendix C. Matrix H Expression

Submatrices H11, H12 and H22 in matrix H (Equation (14) in Section 3.5) can be written as follows:

H11=12q22+q322q0q3+q1q22q1q3q0q22q1q2q0q312q12+q322q0q1+q2q32q0q2+q1q32q2q3q0q112q12+q22 (A18)
H12=g  q2q3q0q1q1q0q3q2q0q1q2q3 (A19)
H22=h sinαq0q1q2q3q3q2q1q0q2q3q0q1+cosαq2q3q0q1q1q0q3q2q0q1q2q3 (A20)

where q0, q1, q2 and q3 are the components of quaternion eq, g represents gravity, α is the angle between the local magnetic and gravity fields and h is the magnetic field modulus [14].

Author Contributions

The corresponding author is Á.D. Some basic aspects of the attitude estimation algorithm described in this article have been presented in his PhD Thesis, supervised by J.C.; J.A.A.N. was the main developer of the simulator framework and F.L.P. was in charge of coordinating the paper editing. All authors equally contributed to further development of the base algorithm, as it is being presented in this article, programming the algorithm and designing the experiments. All authors have read and agreed to the published version of the manuscript.

Funding

This research was funded by Ministerio de Ciencia, Innovación y Universidades of Spain and FEDER (grant RTI2018-101114-B-I00) and by Xunta de Galicia and FEDER (grant ED431C 2017/12).

Conflicts of Interest

The authors declare no conflict of interest.

Footnotes

Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

References

  • 1.Hiller T., Pentek Z., Liewald J., Buhmann A., Roth H. Origins and Mechanisms of Bias Instability Noise in a Three-Axis Mode-Matched MEMS Gyroscope. J. Microelectromech. Syst. 2019;28:586–596. doi: 10.1109/JMEMS.2019.2921607. [DOI] [Google Scholar]
  • 2.Zhu R., Zhou Z. A real-time articulated human motion tracking using tri-axis inertial/magnetic sensors package. IEEE Trans. Neural Syst. Rehabil. Eng. 2004;12:295–302. doi: 10.1109/TNSRE.2004.827825. [DOI] [PubMed] [Google Scholar]
  • 3.Gebre-Egziabher D., Elkaim G.H., Powell J.D., Parkinson B.W. A gyro-free quaternion-based attitude determination system suitable for implementation using low cost sensors; Proceedings of Position Location and Navigation Symposium (Cat. No.00CH37062); San Diego, CA, USA. 13–16 March 2000; pp. 185–192. [DOI] [Google Scholar]
  • 4.Feng X., Zhang T., Lin T., Tang H., Niu X. Implementation and Performance of a Deeply-Coupled GNSS Receiver with Low-Cost MEMS Inertial Sensors for Vehicle Urban Navigation. Sensors. 2020;20:3397. doi: 10.3390/s20123397. [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 5.Alandry B., Latorre L., Mailly F., Nouet P. A Fully Integrated Inertial Measurement Unit: Application to Attitude and Heading Determination. IEEE Sens. J. 2011;11:2552–2560. doi: 10.1109/JSEN.2011.2170161. [DOI] [Google Scholar]
  • 6.Ligorio G., Sabatini A.M. A linear Kalman Filtering-based approach for 3D orientation estimation from Magnetic/Inertial sensors; Proceedings of the 2015 IEEE International Conference on Multisensor Fusion and Integration for Intelligent Systems (MFI); San Diego, CA, USA. 14–16 September 2015; pp. 77–82. [Google Scholar]
  • 7.Sabatini A. Quaternion-Based Extended Kalman Filter for Determining Orientation by Inertial and Magnetic Sensing. IEEE Trans. Biomed. Eng. 2006;53:1346–1356. doi: 10.1109/TBME.2006.875664. [DOI] [PubMed] [Google Scholar]
  • 8.Del Rosario M.B., Lovell N.H., Redmond S.J. Quaternion-Based Complementary Filter for Attitude Determination of a Smartphone. IEEE Sens. J. 2016;16:6008–6017. doi: 10.1109/JSEN.2016.2574124. [DOI] [Google Scholar]
  • 9.Kalman R.E. A New Approach to Linear Filtering and Prediction Problems. Trans. ASME J. Basic Eng. 1960;82:35–45. doi: 10.1115/1.3662552. [DOI] [Google Scholar]
  • 10.Menegaz H.M.T., Ishihara J.Y., Borges G.A., Vargas A.N. A Systematization of the Unscented Kalman Filter Theory. IEEE Trans. Autom. Control. 2015;60:2583–2598. doi: 10.1109/TAC.2015.2404511. [DOI] [Google Scholar]
  • 11.Ito K., Xiong K. Gaussian Filter for Nonlinear Filtering Problems. IEEE Trans. Autom. Control. 2000;45:910–927. doi: 10.1109/9.855552. [DOI] [Google Scholar]
  • 12.Nørgaard M., Poulsen N.K., Ravn O. New developments in state estimation for nonlinear systems. Automatica. 2000;36:1627–1638. doi: 10.1016/S0005-1098(00)00089-3. [DOI] [Google Scholar]
  • 13.Merwe R., Wan E., Julier S. Sigma-Point Kalman Filters for Nonlinear Estimation and Sensor-Fusion–Applications to Integrated Navigation; Proceedings of the AIAA Guidance, Navigation and Control Conference; Providence, RI, USA. 16–19 August 2004; [DOI] [Google Scholar]
  • 14.Deibe A. Ph.D. Thesis. Universidade da Coru na; A Coruna, Spain: 2010. Desarrollo de una Metodología Experimental Para el Estudio de Estrategias de Control en Vehículos Automóviles, Development of an Experimental Methodology for the Study of Control Strategies in Motor Vehicles. [Google Scholar]
  • 15.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]
  • 16.CH Robotics LLC UM7 Datasheet. [(accessed on 18 November 2020)]; Available online: http://www.chrobotics.com/docs/UM7Datasheet.pdf.
  • 17.Farhangian F., Landry R. Accuracy Improvement of Attitude Determination Systems Using EKF-Based Error Prediction Filter and PI Controller. Sensors. 2020;20:4055. doi: 10.3390/s20144055. [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 18.Madgwick S. An efficient orientation filter for inertial and inertial/magnetic sensor arrays. Rep. x-io Univ. Bristol (UK) 2010;25:113–118. [Google Scholar]
  • 19.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 (ICORR); Zurich, Switzerland. 29 June–1 July 2011; pp. 1–7. [DOI] [PubMed] [Google Scholar]
  • 20.Shuster M.D. A survey of attitude representations. Navigation. 1993;8:439–517. [Google Scholar]
  • 21.Trawny N., Roumeliotis S.I. Technical Report. Department of Computer Science and Engineering, University of Minnesota; Minneapolis, MN, USA: 2005. Indirect Kalman filter for 3D attitude estimation. [Google Scholar]
  • 22.Kuipers J.B. Quaternions and Rotation Sequences: A Primer with Applications to Orbits, Aerospace, and Virtual Reality. Princeton University Press; Princeton, NJ, USA: 1999. [Google Scholar]
  • 23.Sabatini A.M. Estimating three-dimensional orientation of human body parts by inertial/magnetic sensing. Sensors. 2011;11:1489–1525. doi: 10.3390/s110201489. [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 24.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]

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

RESOURCES