1. Introduction
Attitude and heading estimation are two of the most important and interesting fields in the areas of navigation, autonomous vehicles, image stabilization, and object detection and tracking, just to cite a few. In this regard, the angular orientation of a rigid body in space is often referred to as attitude. An attitude and heading reference system (AHRS) is a combination of instruments that can estimate the rigid body’s attitude accurately.
Microelectromechanical system (MEMS) inertial sensors have become widely available in recent years, and this is because of their small size and low cost. In addition, because the inertial sensor measurements are obtained at high sampling rates, they have wide usage in the field of attitude and heading estimation. However, the estimations that are achieved by inertial sensors are accurate on a short time scale, but for longer time scales suffer from integration drift. To overcome this problem, inertial sensors are usually combined with additional sensors, such as magnetometers.
Typically, the term inertial sensors are used to refer to the package which has a three-axis gyroscope and a three-axis accelerometer, and the package of these sensors is usually denoted as inertial measurement units (IMUs). Outstanding features of the IMUs are their low-cost, small size, and low power consumption. Therefore, IMUs can be widely used in any environment, such as indoor and outdoor applications. The sensor’s angular velocity, which denotes the rate of change of the sensor’s orientation, is measured with the gyroscope, and the external specific force acting on the sensor is also measured with the accelerometer. It should be noted that the accelerometer measurement contains the sensor’s acceleration and the earth’s gravity. It is clear that by integrating the gyroscope measurements one can achieve the orientation of the sensor, and by two times integration of the accelerometer measurements the pose of the sensor is achieved. The process of integrating the measurements from the gyroscope and accelerometer to obtain orientation and position information is often called dead-reckoning. However, in practice, many factors, such as sensor noise and bias, scale factor, sensor calibration, temperature, and alignment error, affect the accuracy and the performance of the IMUs. One of the IMU’s advantages consists of its application for image stabilization (
Figure 1). Therefore, installing an IMU, equipped with a magnetometer on a camera, will allow the detection of its current orientation after exposure to external forces, removing the disturbances caused by them.
Common probabilistic methods for estimating an IMU’s orientation mostly rely on the ability to update the current orientation estimate using data provided by the IMU. For example, extended Kalman filtering (EKF) is one of the well-known algorithms widely applied in applications with the goal of state estimation. The EKF algorithm estimates unknown states using observations over time, which results in accurate orientation estimation. This filter can work in real-time and is designed for situations where the system’s dynamic is nonlinear.
Many works developed in the field of orientation estimation have used IMU measurements by considering sensor fusion algorithms, commonly based on Kalman filtering algorithms. Alandry et al. [
1] used a five-axis IMU to reach proper orientation. Kulakova et al. [
2] used an IMU, magnetometer, and the Global Navigation Satellite System (GNSS) to estimate orientation in addition to the position of an aerial vehicle. Other authors, such as Farhangian and Landry [
3], used an IMU and magnetometer for their calibration technique for AHRS. Moreover, the authors applied an extended Kalman filter and PI controller. For the attitude estimation of a smartphone, Vertzberger and Klein [
4] applied a two-stage adaptive complementary filter. Ludwig [
5] aimed to determine accurate orientation estimation by using a genetic algorithm to tune the extended Kalman filter. Vitali and McGinnis [
6] introduced a novel error-state Kalman filter to reach the proper orientation of an IMU. In another work, Bruschetta et al. [
7] estimated the attitude of a motorcycle with a velocity-aided extended Kalman filter. Park et al. [
8] estimated the orientation of a smartphone using a low-cost IMU by considering the magnetic disturbance effect. Jeon et al. [
9] applied an IMU and a visually served paired system in a Kalman filtering framework to monitor high-speed structural movement. Jurman et al. [
10] developed an algorithm for the calibration and alignment of an IMU with a magnetometer, which is employed for AHRS.
Auysakul et al. [
11] used an IMU to estimate motion with the goal of video stabilization. Hence, the authors applied a Kalman filter to smooth the trajectory by eliminating the undesired motions. Munguía and Grau [
12] developed an AHRS algorithm and used a direct configuration of EKF. That is, they used kinematic and error models to derive their extended Kalman filter algorithm. Setoodeh et al. [
13] used three strapdown gyros to estimate attitude based on an EKF algorithm. In their work, the dynamic response of the inertial system is obtained without drift. For reaching the altitude, translational velocity, and orientation of a micro aerial vehicle, Zhong and Chirarattananon [
14] used IMU in addition to monocular camera measurements. For the sensor fusion algorithm, they applied an iterated extended Kalman filter. Li and Wang [
15] proposed an adaptive Kalman filter by utilizing linear models. They used a low-cost IMU equipped with a magnetometer to improve dynamic and computational efficiency. In another work, Deibe et al. [
16] obviate the nonlinear behavior of attitude estimation by combining quaternions, state vector, and time-varying matrices. They also applied a classical Kalman filter approach in their algorithm.
One of the important issues in the orientation estimation is its parametrization, and in this article, unit quaternions were used for this goal. A unit quaternion uses a four-dimensional demonstration of the orientation and has an important advantage compared to the rotation matrix, where quaternions do not have any singularities. Young-Soo Suh [
17] used a quaternion-based indirect Kalman filter for orientation estimation with an IMU, including a magnetometer for yaw angle estimation. For coping with uncertainty in attitude estimation in an IMU, Youn and Gadsden [
18] presented a quaternion-based Kalman filter. Yong Ko et al. [
19] used depth measurements and EKF for attitude estimation. So, they applied a quaternion-based representation instead of the usual Euler angle one.
One of the key roles of using magnetometers in addition to IMUs is an accurate estimation of yaw angle. However, in most applications, the presence of ferromagnetic material in the vicinity of sensors made some disturbances in magnetometers. Roetenberg et al. [
20] used an IMU with a magnetometer for orientation estimation of human body segments with a complementary Kalman filter. Again, Navidi and Landry [
21] used a low-cost IMU with a magnetometer for orientation estimation by a complementary adaptive Kalman filter. In this work, the authors proposed an initialization method which, because of the nonlinear nature of the system, is one important step in attitude and heading determination. For improving the efficiency of orientation estimation, Fan et al. [
22] considered the effect of magnetic disturbances in their work, which includes two parts, the first one is stationary state detection, and the second part is magnetic disturbance severity determination.
To have a good estimation regarding the position of rigid bodies, in addition to using IMUs, another sensor is usually necessary. Therefore, most researchers to have an accurate pose estimation use image cameras. Ligorio and Sabatini [
23] used an IMU, a magnetometer, and camera system measurements. In principle, they used those sensors for fusion with two EKF for pose estimation of the moving camera. Alatise and Hancke [
24] fused the measurements from a three-axis gyroscope, three-axis accelerometer, and a vision system to estimate the accurate position of a mobile robot. As in many works, an extended Kalman filter algorithm was used.
When IMUs are used in motion measurements, interesting advantages can be achieved, such as size reduction, low cost, and low power consumption. However, efficient and robust algorithms become necessary for acceptable performance. In this regard, for long-term pose and orientation estimation, the drift of IMUs results in significant accumulated errors. As a result, to improve the system performance, it is necessary to develop proper stochastic IMU error models and apply random noise minimization techniques. For instance, when an AHRS is used in applications with significant acceleration, attitude errors result, or the presence of ferromagnetic materials in the surrounding environment leads to errors in heading estimation.
The focus of this study was on the signal processing aspects of orientation estimation and on obtaining unbiased angular velocity, linear acceleration, and magnetic field using an inertial sensor and magnetometer. By now, many works have been developed related to orientation estimation with sensor fusion algorithms, which mostly use IMUs and Kalman filtering algorithms, but to the authors’ knowledge, the effect of gyroscope and accelerometer biases, as well as the effect of magnetometer bias in addition to ferromagnetic materials and magnetic disturbances at the same time, were not considered in released works. Therefore, to achieve optimized orientation and accurate unbiased angular velocity, linear acceleration, and magnetic field, an extended Kalman filtering (EKF) with 21 states was used. This includes three states for Euler angles, which demonstrate the orientation (pitch, roll, and yaw angles), nine states of unbiased angular velocity, linear acceleration, and unbiased and disturbance compensated magnetic field, and nine states of gyroscope, accelerometer, and magnetic field biases (each of them in
x,
y, and
z directions). In addition, a two-step EKF algorithm was developed which uses the covariance inflation (CI) effect in the second step of the algorithm to optimize the results. Another important contribution of this article is the use of fast Fourier transform (FFT) diagrams to show the reduction of the power of noise. These kinds of diagrams are widely used for the investigation of the systems with nonlinear behaviors [
25,
26,
27] and represent a novel way to show the noise reduction effect after applying the Kalman filtering algorithm in such systems. In addition, because the nonlinear systems are highly sensitive to correct initial conditions, at the end of the article, the effects of wrong initial conditions even in very small values are discussed.
This article consists of the following sections.
Section 2 introduces quaternion-based EKF and magnetometers added to an IMU sensor.
Section 3 describes the system configuration, and
Section 4, presents the extended Kalman filtering (EKF) algorithm. In
Section 5, the performance of the proposed method results is shown and discussed based on experimental tests. Finally, conclusions are given, and possible future research is suggested in
Section 6.
2. Related Works
In order to achieve a reliable and accurate orientation estimation, it is common to use two or more different sensors. Therefore, using IMUs with magnetometers is usual, but they are characterized by uncertainties. Therefore, many studies have been developed to address these uncertainties and suggest robust sensor fusion algorithms. Thus, an efficient sensor fusion algorithm should include some features, e.g., offline calibration of IMU and magnetometer, online estimation of gyroscope, accelerometer, and magnetometer biases, adaptive strategies for surrounding ferromagnetic disturbances, and proper algorithm implementation for orientation estimation to reach accurate roll, pitch, and yaw angles.
In this study, the system input was obtained from a 6-DOF IMU plus Magnetometer device, which includes a three-axis gyroscope, a three-axis accelerometer, and a three-axis magnetometer. Moreover, for orientation, a quaternion-based extended Kalman filter (EKF) was developed.
Nazarahari and Rouhani [
28] performed an experimental comparison among sensor fusion algorithms, such as various Kalman filters. These researchers published another article [
29] which provides a survey of the state-of-the-art sensor fusion algorithms (SFAs) for orientation estimation. Additionally, Bancroft and Lachapelle [
30] developed three SFA which mostly apply in pedestrian navigation. Feng et al. [
31] combined IMU and Ultrawideband through an extended Kalman filter and unscented Kalman filter (UKF) for indoor positioning. Chang et al. [
32] used the Global Positioning System (GPS) for position and IMU for velocity information. In fact, they fused that information with an indirect Kalman filter to reach accurate attitude estimation. Narasimhappa et al. [
33] proposed a three-segment algorithm to evaluate the adaptive scale factor and applied their algorithm to control the drift error and random noise with a Sage-Husa adaptive Kalman filter. For attitude estimation, the algorithm developed by Yan et al. [
34] detects external acceleration and then adjusts the noise variance of EKF to compensate for external acceleration. Benzerrouk and Nebylov [
35] used IMU and ultrawideband in a direct Kalman filtering approach to pedestrian navigation. Liu et al. [
36] proposed an extended Kalman filtering framework for displacement and its uncertainties estimation with an IMU. Poulose et al. [
37] used smartphone sensors for investigating five SFAs in terms of root mean square error and cumulative distribution functions, where most of the used algorithms are based on Kalman filtering. Wang et al. [
38] developed a two-stage Kalman filter for object tracking, which uses a learning-based adaptive unscented Kalman filter for reducing the position estimation error. Again, in the area of applying learning methods, Kuzdeuov et al. [
39] used a deep neural network in combination with an EKF for pose estimation. Potokar et al. [
40] used doppler velocity log and IMU sensors in their developed algorithm and named it as: Invariant Extended Kalman filter.
Numerous works considered the magnetometers for reaching accurate orientation estimation. However, in many of them, the lack of considering the effect of ferromagnetic materials in the vicinity of a magnetometer is obvious. Actually, ferromagnetic materials or other magnetic fields near the sensors disturb the local earth magnetic field which can be measured with magnetometers.
Sabet et al. [
41] considered the gyroscope bias and magnetic disturbances effect by using a low-cost IMU and EKF for orientation estimation. Evren et al. [
42] introduced a master–slave Kalman filter, which includes an EKF and an Φ-algorithm with an IMU and a magnetometer to reach Euler angles, velocity, and acceleration. Zhao and Wang [
43] used ultrasonic, IMU, and magnetometer sensors for orientation and displacement estimation. In their work, an EKF uses ultrasonic sensor data for position estimation and uses magnetometer and IMU data for orientation estimation. Tong et al. [
44] developed an algorithm that uses a multiplicative extended Kalman filter and a Markov model for attitude estimation. So, the authors used an IMU with a magnetometer for this aim. Feng et al. [
45] developed a linear Kalman filter by consideration of magnetic distortion effects for orientation estimation. Liu et al. [
46] also used a 9-DOF device, including an IMU and a magnetometer, to estimate the orientation and applied an adaptive complementary filter for orientation estimation, which used an EKF for fusing prior information. Fan et al. [
47] investigated the effects of magnetic disturbances on orientation estimation. Moreover, they developed four SFAs that contain gradient descent, explicit complementary, dual-linear Kalman, and EKF.
5. Results and Discussion
In this section, the results of extended Kalman filtering after applying its algorithm to the IMU’s outputs are presented and discussed. It should be noted that the desired algorithm was implemented using the MATLAB platform.
As aforementioned, all the experiments were conducted with a 9-DOF IMU, which includes a three-axis gyroscope, a three-axis accelerometer, and a three-axis magnetometer. The used IMU model was the BNO055 unit (Bosch Sensortec, Reutlingen, Germany) (
Figure 6).
In order to discuss the results of using extended Kalman filtering in IMU, two series of IMU outputs were investigated. One bunch is for the stationary IMU, which means the IMU is located on a table without any movement, and the second bunch is for the moving IMU where it is moved in random directions, and the data are collected as input for the developed EKF algorithm.
The frequency of the used IMU is 100 Hz. Then, the time interval between the samples was 0.01 s. First, the results for the stationary IMU are presented.
In
Figure 7, one can see the estimated orientation in degree for pitch, roll, and yaw angles. As is clear, the estimated orientation shows that the IMU is in a stationary situation, which confirms that the developed algorithm works properly. As aforementioned, one of the important issues in orientation estimation is estimating yaw angle, because accelerometers cannot detect rotations about the vertical axis. Therefore, magnetometers that are sensitive to the earth’s magnetic field are added to IMUs to correct the gyroscope’s drift in this direction. The result of using the magnetometer is clear from the shown estimated yaw angle.
In
Figure 8, the width of the unbiased graphs is less than the width of the raw graphs. Moreover, the bias compensation is well visible. In this figure, the biased raw angular velocities, against unbiased ones for all samples and for the simulation period, are depicted. One of the main goals of this article is to eliminate the bias of sensors. Therefore, these graphs show that the bias of the gyroscope is compensated properly.
From
Figure 8, which depicts the angular velocities in
x and
z directions, it is clear that the width of the graph in the unbiased figures is less than the biased one which shows the reduction in noise’s power, and this is demonstrated in the FFT diagrams clearly.
Figure 8b,d depict the unbiased angular velocities in the time domain. It should be noted that in each second, 100 samples were read from IMU, and all of them were used in the EKF algorithm. However, in these two figures, aiming at simplicity, just the last results in each second are represented.
The same comparison was made regarding the linear acceleration of IMU. Therefore, the output of the accelerometer, which is the sum of the linear acceleration, earth’s gravity, and bias, were passed through the extended Kalman filter’s algorithm, and after reducing the earth’s gravity constant and eliminating the bias magnitude, linear acceleration was obtained as shown in
Figure 9.
In
Figure 9, the biased and filtered unbiased linear acceleration of stationary IMU can be observed. Because the IMU is fixed and does not have any movement, the IMU should show approximately zero acceleration in the three axes. However, there is some difference between raw data and filtered data and the main reason for this is the accelerometer’s bias or offset. However, after sensor fusion in the EKF algorithm, the bias magnitude is considerably eliminated.
Considering both the accelerometer bias and the compensation of its effect by a proper algorithm has a significant effect on both the orientation and pose estimation. In addition to correcting the gyroscope’s drift for orientation estimation, the accelerometer is used for position estimation by two-time integration. The main objective of this study was orientation estimation, but in future studies, pose estimation will be considered and accelerometer bias compensation will be effective.
Now is the time to discuss the earth’s magnetic field which is measured with the magnetometer, and the goal was to investigate the effect of EKF’s algorithm on it in order to remove the caused magnetic disturbances.
Figure 10 depicts the comparison between biased, and unbiased magnetic fields in
direction. As it is clear from this figure, the value of magnetic disturbances was eliminated, and the designed algorithm successfully eliminated the effect of ferromagnetic materials in the vicinity of the magnetometer. In the experimental environment, due to the presence of ferromagnetic materials such as iron and the presence of electrical wires, magnetic disturbance occurs and affects the results. The unbiased magnetic field compensated the sum of the mentioned disturbances as well as the magnetometer’s bias effects, and this is the cause for the difference between the two graphs. In addition, regarding the location of the experiment (Porto city, Portugal) where the earth’s magnetic field is almost 53°, the unbiased magnetic field that compensates for the effects of the magnetic disturbance can be recognizable from the graph.
As already mentioned, to realize the effect of extended Kalman filters on the power of noise, it is convenient to use FFT diagrams. In
Figure 11, the FFT diagrams are shown for one direction of each angular velocity, linear acceleration, and magnetic field, respectively, to show how much of the noise’s power is reduced after the adopted sensor fusion strategy. In addition to the FFT diagrams, histograms are used to better clarify the issue of noise reduction.
As depicted in the FFT diagrams and histograms of
Figure 11, the filter reduced the noise flow, especially in the high frequencies, i.e., by increasing the frequency, noise-cancelling phenomena increased. For instance, the mean of the noise power in the gyroscope was reduced by 25 dB, in the accelerometer reduced by 45 dB, and in the magnetometer, the noise flow decreased by 5 dB. Therefore, one can confirm the noise cancelation phenomenon successfully achieved by the developed extended Kalman filter. Another interesting thing that can be realized from the FFT diagrams and histograms is that the mean magnitude of the noise’s power is constant, and this exactly satisfies the assumption made regarding noise, which was considered white noise. Moreover, it can be seen from the histograms that the measurement noise resembles a Gaussian curve. One contribution of this study was the application of FFT diagrams and histograms to illustrate the reduction in noise power. In fact, plotting these kinds of graphs, especially frequency domain diagrams, represents a good method for investigating the effect of the developed filter on noise reduction.
The following results are for moving IMU, and first, the orientation estimation is discussed.
The obtained orientation estimation for moving IMU can be seen in
Figure 12, where
Figure 12a is for whole samples and
Figure 12b concerns the estimated orientation from the final point of each sampling rate. The obtained angular velocity estimation is shown in
Figure 13.
Figure 13 shows the biased raw angular velocities against unbiased filtered ones for moving IMU. One can see in this figure that the filter worked properly because filtered graphs follow the raw graphs, but the bias and noise were successfully eliminated. For an easier interpretation,
Figure 14 presents the angular velocities separately.
In
Figure 14, the filtered plot followed the raw plot properly. However, the noise was reduced dramatically, and the bias was eliminated. One point in Kalman filtering is that this filter cannot follow the abrupt and very fast variations, so its estimations of these situations are very sensibly. However, for example, in
Figure 14a, an abrupt change in the angular velocity happened around the 34th second (3400th sample). Yet, the implemented filter was able to estimate it properly (
Figure 14b).
Figure 15 shows the results regarding linear acceleration, which confirms the good performance achieved by the developed filter.
Again, the bias compensated graphs in
Figure 15 followed the path of linear acceleration properly and eliminated the bias effect. In addition, the noise was reduced dramatically, as could be observed by FFT diagrams.
The same results were extracted for the magnetometer, and one could observe the estimated magnitudes against the raw one,
Figure 16. Again, the fine performance of the developed EKF can be confirmed from the shown plots.
One important point in the Kalman filtering is that in the algorithm, the n’th iteration uses the n-1′th iteration’s result, i.e., the n-1′th iteration contains the effects of the first iteration until n-1′th iterations. As a result, by going forward in the simulation, the results are usually more reliable when compared to the prior ones. However, one of the frequent situations is divergence, which did not occur in the present study. Moreover, variance reduction leads to an increase in the precision of the estimation, and if the noise is Gaussian, the proper Kalman filter minimizes the mean square error of the estimation. The reduction in variance magnitude after filtering is revealed in the moving accelerometer and magnetometer graphs,
Figure 15b and
Figure 16a, respectively.
Another contribution of this study is the consideration of gyroscope, accelerometer, and magnetometer biases in the real-time algorithm, in addition to magnetic disturbance effects, simultaneously. Hence, the obtained angular velocities, linear accelerations, and magnetic fields are biasedly compensated for both the stationary and moving IMU. In addition, in all the depicted figures, the scale is considered equal to the better visualization of the extended Kalman filter’s performance.
Now, for discussing the noise cancellation in the moving IMU, the FFT diagrams shown in
Figure 17 can be used.
Again, the noise flow was reduced in high frequencies by 10 dB for the gyroscope output. The reduction in noise power for the accelerometer was about 30 dB, and for the magnetometer was almost 5 dB. An interesting observation from the FFT plots built for magnetometers was that the filter eliminated the high-power noises in frequencies that have it. For instance, in about 9, 32, and 42 Hz frequencies, the filter eliminated high power noises very well.
Finally, the used IMU can release two types of data: raw and filtered data. For the discussion of the developed algorithm, the raw data was used to demonstrate the performance of the developed extended Kalman filter. Because the IMU does not provide estimated orientation in its unfiltered mode, i.e., raw measurements, to have a comparison and a benchmark for the developed algorithm, now, the orientation of fusion IMU with the algorithm’s estimated in the stationary mode of IMU is compared for the same conditions,
Figure 18. Moreover, the error of estimation angles is depicted using large-scale plots, and, therefore, one can realize that the average error is almost equal to 0.2 degrees.
An important factor in the systems with nonlinearity is their high sensitivity to initial conditions. In other words, by changing the initial condition even in very small values, the final result will change dramatically. For instance, in
Figure 19, one can observe that, although the magnitude of initial orientation has changed a little, the results changed significantly. Particularly, after changing the magnitude of initial quaternions for the stationary IMU case, the results of estimated orientation, linear acceleration, and magnetic field tend to diverge, as it can be found from the shown graphs. In these graphs, the initial quaternion value was changed from proper magnitude values:
to the wrong manipulated values:
.
Here, the orientation estimation, in addition to estimated unbiased angular velocities, linear accelerations, and magnetic fields, was demonstrated for two bunches of IMU data. First, the results were shown for stationary IMU and depicted for a simulation time of 100 s. Then, the results were also presented for moving IMU and a simulation time of 50 s. For evaluation of the developed algorithm, the estimated roll and pitch angles were compared against the filtered ones, and the good performance of the developed EKF’s algorithm can be confirmed. In addition, orientation for the station and moving IMU cases were estimated properly. For instance, in the stationary IMU, the biased angular velocities and linear accelerations were not around the 0 (zero), but this error in the measurements was successfully compensated by the developed algorithm, and the bias was eliminated significantly.
It should be noted that both the integration of a slowly time-varying bias and integration of noise originates from integration drift. Moreover, because the sensor’s bias is different for different axes, this integration drift does not have the same values for all axes. A reduction in the power of noise can be seen in the width of
Figure 8 and
Figure 9, as well as the FFT diagrams and histograms shown in
Figure 11, and
Figure 17 shows this reduction clearly. Moreover, the FFT diagrams demonstrated the mean magnitude of the noise power, which means that the assumption about white noise consideration is true.
For the moving IMU case, the path of angular velocities, linear acceleration, and magnetic fields followed properly after filtering, but the noise and bias were eliminated efficiently. Finally, the effect of changing the initial condition in a wrong manner was investigated and this shows the inherent nonlinearity of the system.