Next Article in Journal
A High Sensitivity FBG Strain Sensor Based on Flexible Hinge
Previous Article in Journal
Internet-of-Things and Information Fusion: Trust Perspective Survey
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

IMU-Based Automated Vehicle Slip Angle and Attitude Estimation Aided by Vehicle Dynamics †

School of Automotive Studies, Tongji University, Shanghai 201804, China
*
Authors to whom correspondence should be addressed.
This paper is an extended version of our paper: “Automated vehicle attitude and lateral velocity estimation using a 6-D IMU aided by vehicle dynamics” published in the Proceedings of the 2018 IEEE Intelligent Vehicles Symposium (IV), Changshu, China, 26–30 June 2018.
Sensors 2019, 19(8), 1930; https://doi.org/10.3390/s19081930
Submission received: 23 March 2019 / Revised: 18 April 2019 / Accepted: 22 April 2019 / Published: 24 April 2019
(This article belongs to the Section Intelligent Sensors)

Abstract

:
The slip angle and attitude are vital for automated driving. In this paper, a systematic inertial measurement unit (IMU)-based vehicle slip angle and attitude estimation method aided by vehicle dynamics is proposed. This method can estimate the slip angle and attitude simultaneously and autonomously. With accurate attitude, the slip angle can be estimated precisely even though the vehicle dynamic model (VDM)-based velocity estimator diverges for a short time. First, the longitudinal velocity, pitch angle, lateral velocity, and roll angle were estimated by two estimators based on VDM considering the lever arm between the IMU and rotation center. When this information was in high fidelity, it was applied to aid the IMU-based slip angle and attitude estimators to eliminate the accumulated error correctly. Since there is a time delay in detecting the abnormal estimation results from VDM-based estimators during critical steering, a novel delay estimation and prediction structure was proposed to avoid the outlier feedback from vehicle dynamics estimators for the IMU-based slip angle and attitude estimators. Finally, the proposed estimation method was validated under large lateral excitation experimental tests including double lane change (DLC) and slalom maneuvers.

1. Introduction

Automated driving technology has attracted much attention recently [1]. Implementing high-level automated driving technology in on-road vehicles needs to address many cutting-edge issues. Among them, accurate sideslip angle and attitude are highly significant [2]. For example, image processing and feature recognition could be aided by the external pitch and roll angle of the vehicle body [3]. Also, sideslip angle and attitude are prerequisites for determining vehicle location [4]. From the perspective of vehicle dynamics control, slip angle, which has been researched for more than 20 years, is the basis for vehicle steering behavior control [5,6].
Unfortunately, commercial devices such as the RT3000 from OxTS [7] or the S-Motion from Kistler [8], which can measure vehicle slip angle and attitude, are too expensive to be used for commercial vehicles and are usually used only for experimental measurement purposes. The RT3000 is a GNSS/INS integration system which can estimate the vehicle velocity in navigation coordinates. Then the slip angle can be estimated by projecting the vehicle velocity in navigation coordinates onto the vehicle body coordinates. The S-Motion is an optical sensor to measure the slip angle. A more feasible way is to use an estimation technique by fusing information from different sensors of an intelligent vehicle. Usually, these sensors include lidars, radars, cameras, inertial measurement units (IMUs) and Global Navigation Satellite System (GNSS) receivers. Integrating the angular rate and acceleration sensor with attitude and velocity is one approach. However, angular rate and acceleration sensors are contaminated by unstable bias and long-term accumulated error when an automotive grade micro-electro-mechanical system (MEMS) IMU is used [9]. Thus, integrating a MEMS IMU to estimate slip angle and attitude should be done with the aid of other sensors such as a GNSS or cameras [10,11]. However, there are also some drawbacks when using IMUs with sensors like GNSS or cameras. The GNSS signal may be weak and easily blocked or suffer from multipath effects in city canyons. Cameras have high requirements for suitable light conditions. In dynamic situations such as emergency steering maneuvers, it is difficult to track the features all the time. In addition, delay and low sample rate issues emerge when low-cost GNSS and cameras are used. Much attention is required when implementing GNSS and cameras to estimate slip angle and attitude [12]. Besides GNSS and cameras, there are other standard sensors such as steering wheel angle and onboard angular speed sensors and wheel speed sensors. These sensors could be input to vehicle dynamics observers for slip angle estimation [6,13]. Using the estimated slip angle, the acceleration part due to translation movement could be removed and the residual part due to gravity could be used to calculate attitude [14]. However, in critical maneuvers, the performance of VDM–based observers would degrade due to model discrepancy.
In Ref. [15], we proposed the elementary idea that, under normal driving conditions, the vehicle dynamic model (VDM)-based estimators for velocity and attitude could assist the IMU-based velocity and attitude estimators to remove the accumulated errors. In this paper, we improved the VDM-based estimators in lateral and longitudinal directions considering the lever arm between the IMU and the vehicle body rotation center. Besides, we further optimized the feedback mechanism for velocity and attitude and a systematic IMU-based vehicle slip angle and attitude estimation method aided by vehicle dynamics is proposed. The main contributions of this paper are summarized as follows:
  • A novel and autonomous estimation method for slip angle and attitude without aids from external information such as GNSS or lane lines is proposed. The IMU-based slip angle and attitude estimator only needs assistance from VDM-based velocity and attitude estimators. Distinguished from many of the state of the art of slip angle estimation methods, which only consider horizontal motion, to further improve the estimation precision, especially in critical driving conditions, movement, including rotation and translation of the vehicle body in three dimensions, is considered. Simultaneous estimation of attitude and velocity keep the IMU-based estimator in a good state to prepare for open loop integration mode, when the vehicle enters critical driving conditions. An accurate attitude guarantees that the acceleration generated by gravity with changing attitude can be removed correctly. Then even when feedback from the VDM-based estimator is cut off, the estimation results of slip angle and attitude are still accurate for a short time.
  • The proposed VDM-based estimator for attitude and velocity could eliminate the accumulated error of IMU-based slip angle and attitude estimation in normal driving conditions. Without accumulated error, the IMU-based slip angle and attitude estimation results have higher precision than the VDM-based estimators.
  • A delayed estimator and predictor structure is proposed to deal with the time delay in detecting abnormal estimation results from VDM-based estimators. The delayed estimator and predictor structure avoids outlier feedback from the VDM-based estimators for IMU-based slip angle and attitude estimators.
The remainder of this paper is organized as follows: Section 2 introduces the state of the art. Section 3 explains the design procedure for the estimation method. Section 4 shows the experimental results. Finally, this paper is concluded in Section 5.

2. Related Work

Extensive work has been done to estimate slip angle and vehicle attitude. In this section, we provide a brief review of the state of the art. Attitude estimation methods can be divided into IMU-based and integration methods. Slip angle estimation methods can be divided into vehicle kinematic model (VKM)-based and VDM-based methods.

2.1. Attitude Estimation

The attitude can be represented by Euler angle, quaternion and direct cosine matrix [9]. In essence, they are similar ways of representing the attitude. The triaxial gyroscope was used to estimate attitude in direct cosine matrix and quaternion representation forms [16]. As discussed before, only a high-performance and high-cost gyroscope such as a ring-laser or fiber-optic gyroscope can generate accurate attitude estimation results in a relatively short time. Long-term integration without assistance from other sensors inevitably leads to huge accumulation error. Some studies have used the gravity part due to attitude from a triaxial accelerometer to calculate the pitch and roll angle to aid the gyroscope [9,17]. The main challenge in abstracting the attitude information from an accelerometer is variable acceleration due to translation movement. Threshold methods in Ref. [18] and fuzzy logic and adaptive methods in Ref. [19] were adopted to handle the translation movement problem.
Other sensors could be used to give accessible measurement of attitude. A magnetometer can measure the direction of the sensor, but it is easily disturbed by surrounding magnetic materials [20]. Also, the pitch angle and roll angle are usually small and the signal-to-noise ratio is very low for magnetometers. Integrating GNSS for attitude estimation has been widely researched [10,21]; the main challenge is that the GNSS signal could be blocked by trees or high buildings, which limits its performance [22]. In recent years, cameras have been used to estimate vehicle attitude through computer vision [23]. Another limitation of GNSS and cameras is that their measurements are usually delayed and sampled at a low rate, which could cause extra measurement errors if the delay and low sample problems are not addressed [12].

2.2. Slip Angle Estimation

VKM–based methods use the kinematic relationship among sensors such as IMU, GNSS, or cameras to estimate slip angle. In Ref. [24], a direct integrator was used to estimate slip angle based on the basic relationship of sideslip angle and lateral acceleration. In Ref. [14], a six-degree-of-freedom (DOF) IMU was used to address the coupling problem between velocity and angular rate, and then a Luenberger-like observer was proposed to estimate the slip angle. In Ref. [25], an IMU combined with GNSS was chosen to estimate the sensor bias and slip angle. In Ref. [26], a camera was innovatively introduced to estimate the optical flow, and then the slip angle could be estimated. However, the accuracy of those kinds of observers depends on the output accuracy of the sensors. For example, sensors such as IMUs suffer from bias error, temperature drift, and random noise when measuring longitudinal and lateral acceleration and yaw rate. Besides, in critical situations, the accelerometer measurements contain the gravity component due to large roll angle and pitch angle [9]. More effort should be made to remove bias, noise, and the gravity part when integrating sensors. Otherwise huge estimation drift may arise after long-term integration.
Besides those kinds of methods, the basic principle for VDM–based methods is to use somea measurable input signal, such as the steering wheel angle, driving torque, or braking torque exerted on the actuators, to drive a virtual vehicle dynamic model to generate lateral velocity. Then the measurable output of the actual vehicle, such as yaw rate and lateral acceleration, are used as feedback to correct the virtual slip angle, i.e., the estimated slip angle. Since different vehicle models, tire models, or estimation methods could be adopted to address different problems when estimating sideslip angle, many methods have arisen [6,13]. For example, in Ref. [24], a three-DOF vehicle model and magic formula tire model were used to describe the vehicle and tire dynamics. Then an unscented Kalman filter (UKF) was applied to estimate the sideslip angle. In Ref. [13], a variable structured extended Kalman filter (EKF) method was designed to estimate the sideslip angle based on a two-track vehicle model with three-DOF and magic formula tire model. Considering road friction, a high-gain observer was introduced to estimate the sideslip angle with small calculation load based on a single-track vehicle model [27]. However, the sideslip angle was hard to estimate due to the nonlinear and uncertain vehicle and tire dynamics [28]. The accuracy of those kinds of observers relies on the accuracy of the vehicle dynamic model. Model discrepancies will result in estimation errors. Some researchers have combined the kinematic model and dynamic model based methods to make full use of the merits of each one [6,11,29].

3. Methods

The holistic structure of the proposed estimation method in this paper is shown in Figure 1. The proposed estimation architecture is divided into two parts: the delayed estimator and the predictor. The delayed estimator contains two parts: the two IMU-based estimators, used to estimate velocity and attitude respectively, and the two VDM-based estimators, used to estimate longitudinal velocity and pitch angle and lateral velocity and roll angle respectively. In normal driving condition which can be determined by the Flag F _ v y _ VD and Flag F _ v x _ VD , the feedback as measurement in Kalman filter from the VDM-based velocity and attitude estimators can remove the accumulated error of the IMU-based velocity and attitude estimators. In critical driving conditions such as fast steering or hard braking, the precision of the VDM-based estimation method is reduced significantly due to the model discrepancy. At this time, the IMU-based estimator should be insulated from the VDM-based estimator. However, the time delay needs to be detected to determine when to start the insulation, since the determination can only be made after the critical driving condition occurs. Therefore, those estimators are delayed to allow synchronization. In other words, those estimators are for estimating x ^ τ ( t ) at t τ moment. Then the predictor fuses the x ^ τ ( t ) and presents input u ( t ) to predict the current x ^ ( t ) .

3.1. Vehicle-Dynamics-Model-Based Velocity Estimator

This section shows the estimation methods of lateral velocity, roll angle, longitudinal velocity, and pitch angle by vehicle dynamics.

3.1.1. Vehicle Kinematic Model

The kinematic model of the center of rotation is described by Equation (1):
[ a x _ k i n e a y _ k i n e a z _ k i n e ] = [ v ˙ x v ˙ y v ˙ z ] + [ φ ˙ θ ˙ ψ ˙ ] × [ v x v y v z ]
where v x , v y , and v z are longitudinal, lateral, and vertical velocity in vehicle body coordinates; a x _ k i n e , a y _ k i n e , and a z _ k i n e are kinematic acceleration of the vehicle body; and φ ˙ , θ ˙ , and ψ ˙ are roll, pitch, and yaw angular velocity, respectively. However, due to the suspension, implementing the IMU at the rotation center is not possible, since there is a lever arm between the IMU and the rotation center. The lever arm will influence the measurement in the accelerometer when the vehicle body rotates. The lever arm should be estimated and then the convective acceleration should be removed from the acceleration. The convective acceleration is computed by Equation (2):
[ a x _ compen a y _ compen a z _ compen ] = [ φ ¨ θ ¨ ψ ¨ ] × [ L offset _ x L offset _ y L offset _ z ] + [ φ ˙ θ ˙ ψ ˙ ] × ( [ φ ˙ θ ˙ ψ ˙ ] × [ L offset _ x L offset _ y L offset _ z ] )
where a x _ compen , a y _ compen , and a z _ compen are the compensated acceleration and L offset _ x , L offset _ y , and L offset _ z are the lever arms in the x, y, and z directions, respectively; and φ ¨ , θ ¨ , and ψ ¨ are the roll, pitch, and yaw angular acceleration, respectively.
Then we have the acceleration of the center of rotation of the body as Equation (3), where [ a x s a y s a z s ] T is the output of the accelerometer in x, y, and z directions, respectively:
[ a x b a y b a z b ] = [ a x s a y s a z s ] [ a x _ compen a y _ compen a z _ compen ]
Gravity will also contribute to the measurement in the accelerometer due to roll and pitch variation. The acceleration in body coordinate [ a x b a y b a z b ] T is given by Equation (4):
[ a x b a y b a z b ] = [ a x _ k i n e a y _ k i n e a z _ k i n e ] + [ g sin θ g sin φ cos θ g cos φ cos θ ]
where g is gravity. The velocity [ v ^ x _ VD v ^ y _ VD v ^ z _ VD ] T and kinematic acceleration [ v ^ ˙ x _ VD v ^ ˙ y _ VD v ^ ˙ z _ VD ] T could also be estimated from the vehicle dynamics (Equations (5), (9), (10), (25), and (26)). Based on this motivation, we can separate out the gravity component from the accelerometer to estimate the roll and pitch angles through Equation (6) to aid the IMU-based attitude estimator:
[ a x k i n e a y k i n e a z k i n e ] = [ v ^ ˙ x _ VD v ^ ˙ y _ VD v ^ ˙ z _ VD ] + [ φ ˙ s θ ˙ s ψ ˙ s ] × [ v ^ x _ VD v ^ y _ VD v ^ z _ VD ]
where [ φ ˙ s θ ˙ s ψ ˙ s ] T is the angular velocity output from the gyroscope in the x, y, and z directions, respectively.
[ a x b g a y b g a z b g ] = [ a x b a y b a z b ] [ a x k i n e a y k i n e a z k i n e ] [ a x _ compen a y _ compen a z _ compen ] = [ g sin θ g sin φ cos θ g cos φ cos θ ]
where the subscript of bg means the acceleration due to gravity in body coordinate. With the gravity component in acceleration, the roll angle φ VD and pitch angle θ VD can be computed as Equation (7):
[ θ ^ VD φ ^ VD ] = [ arcsin ( a x b g g ) arcsin ( a y b g g cos θ m _ d e l a y ) ]

3.1.2. Longitudinal Velocity and Its Acceleration Estimation

There is much research about longitudinal velocity estimation based on vehicle dynamics and wheel dynamics. In this part, the wheel speed from the driven wheel is used to estimate the longitudinal velocity and longitudinal acceleration. In normal driving conditions, this wheel speed is accurate as the real longitudinal velocity, while in braking conditions, if the braking force is large, the wheel speed may diverge due to the tire slip. Thanks to the IMU-based attitude and velocity estimators, in strong braking conditions, the feedback from vehicle dynamics is cut off and the longitudinal velocity can be estimated with relatively high precision.
• Longitudinal velocity estimation
The wheel model is shown in Figure 2. ω is rotation speed of the wheel and r is tire radius. The longitudinal velocity v ^ x _ VD can be estimated from the wheel speed of the driven wheel as Equation (9):
{ v ^ x _ r l = ω r l r r l + ψ ˙ s 2 b r v ^ x _ r r = ω r r r r r ψ ˙ s 2 b r
v ^ x _ VD = v ^ x _ r l + v ^ x _ r r 2
The subscripts rl and rr mean rear left and rear right, ω is the wheel speed, r is the tire radius, and b r is the rear wheel base.
• Kinematic longitudinal acceleration estimation
With the estimated longitudinal velocity, we can estimate the kinematic longitudinal acceleration to estimate the pitch angle. We assume that the longitudinal velocity can be described by a fourth-order Taylor series at t moment. Then, we have:
{ v x _ VD ( t + t ) = v x _ VD ( t ) + t v ˙ x _ VD ( t ) + 1 2 ! t 2 v ¨ x _ VD ( t ) + 1 3 ! t 3 v x _ VD ( t ) + O + w 1 v ˙ x _ VD ( t + t ) = v ˙ x _ VD ( t ) + t v ¨ x _ VD ( t ) + 1 2 ! t 2 v x _ VD ( t ) + O + w 2 v ¨ x _ VD ( t + t ) = v ¨ x _ VD ( t ) + t v x _ VD ( t ) + O + w 3 v x _ VD ( t + t ) = v x _ VD ( t ) + w 4
where v ˙ x _ VD , v ¨ x _ VD , and v x _ VD are the first-order, second-order, and third-order derivatives of longitudinal speed; w 1 ~ w 4 are Gaussian white noise; t is the time step; and O is the high-order term, which is ignored.
Remarks: Since the longitudinal acceleration is controlled by the driver, there would not be very high-order dynamics in the longitudinal velocity, and we make this assumption about the longitudinal velocity.
Then, we have the discrete form of Equation (10). The system equation is given by Equation (11) and the measurement equation is given by Equation (12), where η means the measurement noise:
[ v x _ VD ( k + 1 ) v ˙ x _ VD ( k + 1 ) v ¨ x _ VD ( k + 1 ) v x _ VD ( k + 1 ) ] = [ 1 t 1 2 ! t 2 1 3 ! t 3 0 1 t 1 2 ! t 2 0 0 1 t 0 0 0 1 ] [ v x _ VD ( k ) v ˙ x _ VD ( k ) v ¨ x _ VD ( k ) v x _ VD ( k ) ] + [ w 1 w 2 w 3 w 4 ]
v x _ VD = [ 1 0 0 0 ] [ v x _ VD ( k ) v ˙ x _ VD ( k ) v ¨ x _ VD ( k ) v x _ VD ( k ) ] + η
With different driving conditions such as passing deceleration strips or slipping, the noise in the wheel speed sensor changes a lot. The measurement noise covariance of wheel speed sensor output should be adapted with different driving conditions, which would enhance the dynamic performance of the filter. Then, the innovation adaptive estimation (IAE)-based Kalman filter mentioned in Section 3.1.3 is applied to estimate the longitudinal acceleration.
• Feedback flag for IMU-based estimator
When a vehicle brakes hard, the tires will slip and the accuracy of the longitudinal velocity will drop fast. At this time, we need to detect this moment and insulate the feedback from the VDM-based longitudinal velocity estimator to the IMU-based longitudinal velocity estimator. Here, we design some feasible rules to set up the feedback flag for the IMU-based estimator.
Define a x _ dev as:
a x _ dev = | v ˙ x _ VD ( a x s a x _ C o m p e n + g sin θ ^ ) |
The mechanism of the feedback flag for the IMU-based longitudinal velocity and pitch angle estimator is shown in Figure 3. When the acceleration is smaller than a threshold value, Flag v x _ VD is set up to detect the hard braking operation. When the expectation and variance of a x _ dev are larger than the threshold value, Flag v x _ VD is set up. a x s _ Thresh , a x _ Thresh , a x _ EThresh , and a x _ VarThresh are the threshold values that need to be tuned in the application.
Essentially, the longitudinal velocity and pitch angle estimated from vehicle dynamics help to remove the accumulated error of the IMU-based estimator. Under normal driving conditions, the tire slip is very small, which means Equation (9) has high precision. This accurate longitudinal velocity and pitch angle is enough to remove the accumulated error. Thus, the threshold value in Figure 3 could be set strictly to detect abnormal values of the longitudinal velocity and pitch angle estimated from vehicle dynamics.
Since this mechanism is only effective when the tires have already slipped, if we use this flag to cut off the feedback to the IMU-based longitudinal velocity and attitude estimators, the IMU-based longitudinal velocity and attitude estimators have already been injected with polluted longitudinal velocity and pitch angle. In other words, this flag is too late to cut off the feedback, or there is a delay in the flag. Therefore, in order to synchronize, we delay the IMU-based estimator. As for the flag, we set up a new flag as Equation (14):
Flag F _ v x _ VD = Flag τ v x _ VD Flag v x _ VD
where Flag τ v x _ VD is delayed by τ from Flag v x _ VD .
This operation would guarantee the exact time to cut off the feedback, and we could use the longitudinal velocity and pitch angle from the vehicle dynamics estimator to assist the IMU-based attitude and longitudinal velocity estimator safely. In the end, the IMU-based estimator would output the delayed state.

3.1.3. Estimation Algorithm

In order to eliminate the random noise of the process model and measurement model, an IAE-based Kalman filter is proposed to estimate the velocity and attenuate the influence of the measurement outlier from the VDM-based estimator. The basic Kalman filter process is shown in Figure 4, where subscript k means the k moment, k | k 1 means prediction of k moment from k−1 moment, k | k means prediction after correction at time k, A is the system matrix, x ^ is the state, P is the state error covariance, Q is the covariance of the system noise, Γ is the input matrix of the input noise, d t is the sample time, C is the measurement matrix, R is the covariance of measurement, G is the Kalman gain, and z is the measurement.
Since the noise of the measurement is usually time-varying, the noise covariance changes with different driving conditions. Therefore, the noise covariance should be adapted online to enhance the performance of the estimator. The innovation of the basic Kalman filter is given by Equation (15):
d k z k C k x ^ k | k 1
The expectation of the innovation at k moment is given by Equation (16):
E ( d k d k T ) = E ( ( z k C k x ^ k | k 1 ) ( z k C k x ^ k | k 1 ) T ) = E ( ( C k ( x k | k x ^ k | k 1 ) + η ) ( C k ( x k | k x ^ k | k 1 ) + η ) T ) = E ( C k ( x k | k x ^ k | k 1 ) ( x k | k x ^ k | k 1 ) T C k T ) + E ( η η T ) = C k P k | k 1 C k T + R k
E ( d k d k T ) can be computed through a short window [30]. Then the covariance of measurement noise is estimated by Equation (17):
R ^ k = E ( d k d k T ) C k P k | k 1 C k T = 1 n i = 1 n d k i d k i T C k P k | k 1 C k T
In order to reduce the calculation, we use the recursive form to compute R ^ k , given by Equation (18):
R ^ k = i = 1 k ( d i d i T C i P i | i 1 C i T ) = 1 k [ ( i = 1 k 1 d i d i T C i P i | i 1 C i T ) + ( d k d k T C k P k | k 1 C k T ) ] = 1 k [ ( k 1 ) R ^ k 1 + ( d k d k T C k P k | k 1 C k T ) ] = k 1 k R ^ k 1 + 1 k ( d k d k T C k P k | k 1 C k T )
In order to improve the dynamic performance of the estimation for R ^ k , we involve a fading factor to forget part of the historical measurement. The fading factor b is between 0 and 1; then, we have the fading coefficient α k :
α k = α k 1 α k 1 + b
The recursive form of the estimation for R ^ k is given by Equation (20):
R ^ k = ( 1 α k ) R ^ k 1 + α k ( d k d k T C k P k | k 1 C k T )
In addition, since there is subtraction operation for ( d k d k T C k P k | k 1 C k T ) , when d k and P k | k 1 are mismatched, the sign of ( d k d k T C k P k | k 1 C k T ) may be negative, leading to the loss of positive certainty of R ^ k , which would cause abnormity of the filter. Therefore, we add a limitation for every element of R ^ k for stability of the Kalman filter. For the i-th measurement, define χ k i as Equation (21):
χ k i = ( d k i ) 2 C k i P k | k 1 i C k i T
Then R ^ k i can be calculated as Equation (22):
R ^ k i = { ( 1 α k ) R ^ k 1 i + α k R ^ min i χ k i < R ^ min i R ^ max i χ k i > R ^ max i ( 1 α k ) R ^ k 1 i + α k χ k i R ^ min i χ k i R ^ max i
In the following section, we will also use the IAE-based Kalman filter to estimate attitude and velocity by fusing vehicle dynamics and IMU information.

3.1.4. Lateral Velocity and Its Acceleration Estimation

As stated in the introduction, there is a lot of research about lateral velocity estimation based on vehicle dynamics [6,13]. In this section, a linear two-DOF single-track vehicle model is used to estimate the sideslip angle and lateral acceleration in normal driving conditions to remove the accumulated error of the IMU-based lateral velocity and attitude estimator.
• Lateral velocity estimation
In Figure 5, β is slip angle, α f is tire slip angle of front axle and α r is tire slip angle of rear axle. The dynamics of the linear 2DOF single-track vehicle model shown in Figure 5 is illustrated by Equation (23) [31]:
[ β ˙ ψ ¨ ] = [ a 11 a 12 a 21 a 22 ] A [ β ψ ˙ ] + [ b 11 b 21 ] B δ f
β = v y v x
where C f is front axle equivalent cornering stiffness, C r is rear axle equivalent cornering stiffness, m is vehicle mass, l f is distance from the front axle to the center of gravity (COG), l r is distance from the rear axle to the COG, I z is the vehicle yaw moment of inertia, δ f is the steering angle of the front wheel, β is the sideslip angle, A = [ C f + C r m v x C f l f C r l r m v x 2 1 C f l f C r l r I z C f l f 2 + C r l r 2 I z ] , and B = [ C f m v x C f l f I z ] .
Since we can obtain the yaw rate from the IMU, with that we can use the Kalman filter method shown in Figure 4 to estimate the sideslip angle.
With the estimated sideslip angle, the lateral velocity can be estimated by Equation (25):
v y _ VD = β v x
• Kinematic lateral acceleration estimation
After updating the measurement of the sideslip angle estimation with the Kalman filter, we can also calculate the derivative of the sideslip angle based on the state equation:
β ^ ˙ k | k = C f + C r m v x β ^ k | k + ( C f l f C r l r m v x 2 1 ) ψ ˙ C f m v x δ f
In addition, the derivative of the lateral velocity is:
v ^ ˙ y _ VD = β ^ ˙ k | k v x
• Feedback flag for IMU-based estimator
The design principle for the feedback flag for lateral velocity and roll angle is the same as that for longitudinal velocity. In the linear region of the tire, the linear tire model and 2DOF single-track vehicle model are well matched. With that, it is feasible to estimate the sideslip angle with high precision. As long as an accurate estimated sideslip angle is used, the accumulated error in the IMU-based lateral velocity and attitude estimator can be removed.
We define γ dev , v y _ dev , and a y _ dev , which are the yaw rate deviation, lateral velocity deviation, and lateral kinematic acceleration deviation, respectively, as Equations (28)–(30). γ ^ d can be estimated from the linear 2DOF single-track vehicle model, as Equation (31).
γ dev = | γ ^ d ψ ˙ s |
v y _ dev = | v ^ y _ VD v ^ y |
a y _ dev = | v ^ ˙ y _ VD ( a y s v ^ x ψ ˙ g sin φ ^ cos θ ^ ) |
γ ^ d = v x / ( l f + l r ) 1 + m ( l f + l r ) 2 ( l f C r l r C f ) v x 2 δ f
The mechanism of the feedback flag for the IMU-based lateral velocity and roll angle estimator is shown in Figure 6. When the lateral acceleration is larger than a threshold value, Flag v y _ VD is set up to detect the critical steering operation. When the expectation and variance of v y _ dev , γ dev are larger than the threshold value, Flag v y _ VD is set up. In addition, the steering wheel angle and speed are also used to detect the critical steering operation. a y s _ Thresh , v y _ Thresh , v y _ EThresh , v y _ VarThresh , γ Thresh , γ E _ Thresh , γ Var Thresh , δ f _ Thresh , and δ ˙ f _ Thresh are the threshold values that need to be tuned in application. The subscript of ’Thresh’ means threshold.
Like the longitudinal velocity estimation, only under normal driving conditions can the accumulated error in the IMU-based lateral velocity and roll angle estimator be removed. Thus, the threshold value in Figure 6 could be set strictly to detect abnormal values of the lateral velocity and roll angle estimated from vehicle dynamics.
Since this mechanism is only effective when the vehicle has already side-slipped, if we use this flag to cut off the feedback, the IMU-based lateral velocity and roll angle estimator have already been injected with polluted lateral velocity and roll angle. In other words, this flag is too late to cut off the feedback or there is a delay in the flag. Therefore, in order to synchronize, we delay the IMU-based estimator. As for the flag, we set up a new flag as Equation (32):
Flag F _ v y _ VD = Flag τ v y _ VD Flag v y _ VD
where Flag τ v y _ VD is delayed by τ from Flag v y _ VD .
This operation would guarantee the exact time to cut off the feedback, and we could use the lateral velocity and roll angle from the vehicle dynamics estimator to assist the IMU-based attitude and lateral velocity estimator safely. In the end, like the longitudinal velocity part, the IMU-based estimator would output the delayed state.

3.2. IMU-Based Attitude Estimation

In this section, based on the triaxle angular rate and the attitude estimated from the vehicle dynamics, we design the attitude estimator using the IAE- based Kalman filter.

3.2.1. Gyroscope Sensor Model

We analyzed the gyroscope and acceleration sensor by the Allan variance method to determine the error composition in the IMU sensor [32]. The gyroscope or accelerometer measurement is composed of a real value, a constant bias term b 0 , a random walk bias term b 1 , and a wideband noise term w . A first-order Markov model can be used to show the random walk bias. τ is the time constant and w b is the wideband noise. Besides, due to the earth’s rotation, the gyroscope would also sense the angular speed [ φ ˙ e θ ˙ e ψ ˙ e ] T , and this part should be removed to estimate attitude. The gyroscope model is given by Equations (33) and (34):
{ φ ˙ s = φ ˙ r + b φ 0 + b φ 1 + φ ˙ e + w φ θ ˙ s = θ ˙ r + b θ 0 + b θ 1 + θ ˙ e + w θ ψ ˙ s = ψ ˙ r + b ψ 0 + b ψ 1 + ψ ˙ e + w ψ
{ b ˙ φ 1 = 1 τ φ 1 b φ 1 + w b φ 1 b ˙ θ 1 = 1 τ θ 1 b θ 1 + w b θ 1 b ˙ ψ 1 = 1 τ ψ 1 b ψ 1 + w b ψ 1
where the subscript s means the measurement of the sensor, the subscript r means the real measurement, and the superscript · means the derivative of the variable:
[ φ ˙ e θ ˙ e ψ ˙ e ] = [ cos ψ cos θ sin ψ cos φ + cos ψ sin θ sin φ sin ψ sin φ + cos ψ sin θ cos φ sin ψ cos θ cos ψ cos φ + sin ψ sin θ sin φ cos ψ sin φ + sin ψ sin θ cos φ sin θ cos θ sin φ cos θ cos φ ] T [ 0 ω i e cos L ω i e sin L ]
[ φ ˙ e θ ˙ e ψ ˙ e ] = [ cos ψ sin ψ 0 sin ψ cos ψ 0 0 0 1 ] [ 0 ω i e cos L ω i e sin L ]
where ω i e is the rotation speed of the Earth and L is the latitude of the vehicle. Equation (35) shows how to compute the angular speed in vehicle coordinates.

3.2.2. Attitude Dynamics

Since the simple form of Euler angle, in this paper, we chose the Euler angle as the representation of attitude. In Euler angle representation, we can involve the sensor bias in the state variable directly without further transformation compared with quaternion representation. The rotation sequence is Z-Y-X. Rotating about each axle, we have yaw, pitch, and roll angle, respectively. Then the dynamics of the Euler angle are given by Equation (37):
[ φ ˙ θ ˙ ψ ˙ ] = [ 1 sin φ tan θ cos φ tan θ 0 cos φ sin φ 0 sin φ / cos θ cos φ / cos θ ] [ φ ˙ r θ ˙ r ψ ˙ r ]

3.2.3. Attitude Estimator

For the attitude estimation, we applied the IAE-based Kalman filter. The state variable we used here contains [ φ θ ψ b φ 1 b θ 1 b ψ 1 ] T and the measurement variable is [ φ m θ m ψ m ] . The attitude dynamics can be described by Equation (38):
x ˙ ( t ) = f ( x ( t ) ) + Γ ( x ( t ) ) ξ ( t )
where x ( t ) = [ φ θ ψ b φ 1 b θ 1 b ψ 1 ] T , ξ ( t ) = [ w φ w θ w ψ w b φ 1 w b θ 1 w b ψ 1 ] T , f ( x ( t ) ) = [ φ ˙ s ( b φ 0 + b φ 1 ) + sin φ tan θ ( θ ˙ s ( b θ 0 + b θ 1 ) + cos φ tan θ ( ψ ˙ s ( b ψ 0 + b ψ 1 ) ) cos φ ( θ ˙ s ( b θ 0 + b θ 1 ) ) sin φ ( ψ ˙ s ( b ψ 0 + b ψ 1 ) ) sin φ / cos θ ( θ ˙ s ( b θ 0 + b θ 1 ) ) + cos φ / cos θ ( ψ ˙ s ( b ψ 0 + b ψ 1 ) ) 1 τ φ 1 b φ 1 1 τ θ 1 b θ 1 1 τ ψ 1 b ψ 1 ] , and Γ ( x ( t ) ) = [ 1 sin φ tan θ cos φ tan θ 0 0 0 0 cos φ sin φ 0 0 0 0 sin φ / cos θ cos φ / cos θ 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 ] .
The model in Equation (38) is a nonlinear system, the EKF should be adopted [13]. The first step of the EKF is to compute the predicted state by Equation (39):
x k | k 1 f ( x ^ k ) t + x ^ k
Then in order to compute the state transition matrix, the system should be linearized. After the linearization given by Equation (40), the rest procedures of the EKF and KF are the same. The IAE-based Kalman filter is also implemented:
x ˙ k f ( x ^ k ) + f ( x ^ k ) x ^ k ( x k x ^ k ) = f ( x ^ k ) x ^ k x k + [ f ( x ^ k ) f ( x ^ k ) x ^ k x ^ k ]
The system matrix is given by Equation (41):
A = f ( x ) x = [ A 11 A 12 A 21 A 22 ]
where:
A 11 = [ cos φ tan θ ( θ ˙ s b θ 1 ) sin φ tan θ ( ψ ˙ s b ψ 1 ) sin φ cos 2 θ ( θ ˙ s b θ 1 ) + cos φ cos 2 θ ( ψ ˙ s b ψ 1 ) 0 sin φ ( θ ˙ s b θ 1 ) cos φ ( ψ ˙ s b ψ 1 ) 0 0 cos φ cos θ ( θ ˙ s b θ 1 ) sin φ cos θ ( ψ ˙ s b ψ 1 ) sin φ sin θ cos 2 θ ( θ ˙ s b θ 1 ) + cos φ sin θ cos 2 θ ( ψ ˙ s b ψ 1 ) 0 ] , and A 12 = [ 1 sin φ tan θ cos φ tan θ 0 cos φ sin φ 0 sin φ / cos θ cos φ / cos θ ] , A 21 = [ 0 0 0 0 0 0 0 0 0 ] , A 22 = [ 1 τ φ 1 0 0 0 1 τ θ 1 0 0 0 1 τ ψ 1 ] .
The measurement equation is
[ φ ^ VD θ ^ VD ψ ^ GNSS ] = [ 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 ] [ φ θ ψ b φ 1 b θ 1 b ψ 1 ] + η
where ψ ^ GNSS is the heading angle from the GNSS receiver.
Then, with system matrix Equation (38) and measurement Equation (42), the IAE-based Kalman filter is used to estimate the attitude.
Remarks: As stated before, under critical driving conditions, the roll and pitch angles estimated from the vehicle dynamics lose fidelity and Flag F _ v x _ VD and Flag F _ v y _ VD are set. At this time, the feedback term should be cut off and the IMU-based attitude estimator turns to open loop integration mode.

3.3. IMU-Based Velocity Estimation

In this section, based on the triaxle accelerometer and the velocity estimated from the vehicle dynamics, we design the velocity estimator using the IAE-based Kalman filter.

3.3.1. Accelerometer Sensor Model

Similar to the gyroscope sensor model, the accelerometer sensor model is given by Equations (43) and (44):
{ a x s = a x r + b x 0 + b x 1 + w a x a y s = a y r + b y 0 + b y 1 + w a y a z s = a z r + b z 0 + b z 1 + w a z
{ b ˙ x 1 = 1 τ x 1 b x 1 + w b x 1 b ˙ y 1 = 1 τ y 1 b y 1 + w b y 1 b ˙ z 1 = 1 τ z 1 b z 1 + w b z 1

3.3.2. Velocity Dynamics

The dynamics of velocity in the vehicle body frame are given by Equation (45):
[ v ˙ x v ˙ y v ˙ z ] = [ a x r a y r a z r ] [ 0 ψ ˙ r θ ˙ r ψ ˙ r 0 φ ˙ r θ ˙ r φ ˙ r 0 ] [ v x v y v z ] [ g sin θ g sin φ cos θ g cos φ cos θ ]

3.3.3. Velocity Estimator

Since the vertical velocity is usually small under normal driving conditions, referring to the first-order Markov model, a damping term 1 τ d a m p v z is involved in the dynamics of vertical velocity in case of divergence. Therefore, the dynamics of velocity are changed to Equation (46):
[ v ˙ x v ˙ y v ˙ z b ˙ x 1 b ˙ y 1 b ˙ z 1 ] = [ 0 ψ ˙ s θ ˙ s 1 0 0 ψ ˙ s 0 φ ˙ s 0 1 0 θ ˙ s φ ˙ s 1 τ d a m p 0 0 1 0 0 0 1 τ x 1 0 0 0 0 0 0 1 τ y 1 0 0 0 0 0 0 1 τ z 1 ] [ v x v y v z b x 1 b y 1 b z 1 ] + [ 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 ] [ ( a x s b x 0 ) + g sin θ ^ ( a y s b y 0 ) g sin φ ^ cos θ ^ ( a z s b z 0 ) g cos φ ^ cos θ ^ 0 0 0 ] + [ 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 ] [ w a x w a y w a z w b x 1 w b y 1 w b z 1 ]
where the state variable is x = [ v x v y v z b x 1 b y 1 b z 1 ] T , input is [ ( a x s b x 0 ) + g sin θ ^ ( a y s b y 0 ) g sin φ ^ cos θ ^ ( a z s b z 0 ) g cos φ ^ cos θ ^ 0 0 0 ] T , and noise is [ w a x w a y w a z w b x 1 w b y 1 w b z 1 ] T .
The measurement is given by Equation (47):
[ v x _ VD v y _ VD ] = [ 1 0 0 0 0 0 0 1 0 0 0 0 ] [ v x v y v z b x 1 b y 1 b z 1 ] + η
Then, with system matrix Equation (46) and measurement Equation (47), the IAE-based Kalman filter is used to estimate the velocity.
As stated before, under critical driving conditions, the longitudinal and lateral velocity estimated from the vehicle dynamics lose fidelity and Flag F _ v x _ VD and Flag F _ v y _ VD are set. At this time, the feedback term should be cut off and the IMU-based velocity estimator turns to open loop integration mode.

3.4. Attitude and Velocity Predictor

From Section 3.2, there is a time delay in Flag v x _ VD and Flag v y _ VD , which are the indicators to insulate the IMU-based estimator from abnormal feedback from the VDM-based estimator. Therefore, we propose Flag F _ v x _ VD and Flag F _ v y _ VD to extend the time scale. When the IMU-based estimator is delayed to t τ moment, Flag F _ v x _ VD and Flag F _ v y _ VD precede the delayed estimator to set up when the vehicle is under critical maneuvers, then a predictor is adopted to move the estimator at t τ to t moment. This process is shown in Figure 7.
At t moment, the systems from Section 3.2, Section 3.3 and Section 3.4 for the estimator design can be abstracted by Equation (48), and the corresponding estimator is designed for estimation x ^ τ ( t ) for t τ moment.
x ˙ ( t τ ) = f ( x ( t τ ) , u ( t τ ) ) + w ( t τ ) z ( t τ ) = h ( x ( t τ ) ) + η ( t τ )
x ^ τ ( t ) is the estimated result for t τ moment at t moment. In real-time application, we should reserve a buffer to store the sensor data from t τ to t for the predictor.
With x ^ τ ( t ) (refer to Ref. [33]), a predictor is designed to predict x ^ ( t ) based on the present u(t) and system model. The predictor is described by Equations (49) and (50):
δ ˙ ( t ) = f ( x ^ τ ( t ) + δ ( t ) δ ( t τ ) , u ( t ) ) , t τ
x ^ ( t ) = x ^ τ ( t ) + δ ( t ) δ ( t τ ) , t τ
where the dynamics of δ ( t ) are the same as the corresponding system in Equation (48) and are driven by x ^ τ ( t ) and u ( t ) with δ ( t ) , x ^ ( t ) predicted by Equation (50).
Within this delayed observer and predictor structure, the estimation error of the predictor is stable, and the proof of estimation error stability of the predictor is shown in Appendix A.

4. Results and Discussion

This section shows the experimental implementation and results.

4.1. Experimental Implementation

Figure 8 and Figure 9 show the details of hardware implementation for this paper. The Novatel 718D receiver records the trajectory of the vehicle in 10 Hz and the ADIS 16495 provides the acceleration and angular speed and its increment in 100 Hz. The steering wheel angle, steering wheel angular speed, and wheel speed are acquired from the On-Board Diagnostics (OBD) port in the test vehicle in 50 Hz. The reference attitude, including roll angle, pitch angle, and velocity in longitudinal and lateral directions, are measured by the Kistler S-Motion in 50 Hz. All information is collected by the NI CompactRIO 9082 through a CAN bus and the data acquisition system is programmed by Labview 2013. MatLab/Simulink 2012a running on the computer is used to run the proposed method offline in 100 Hz.

4.2. Expeimental Results

Double lane change (DLC) and slalom maneuvers under large lateral excitation were performed to validate the proposed estimation method. Large lateral excitation means lateral acceleration between 6 and 8 m/s2.

4.2.1. DLC Maneuver

Figure 10 shows the test results of the proposed method with the DLC maneuver. In the legend, late means lateral and longi means longitudinal; Delayed means the estimated result of x ^ τ ( t ) , Predicted means the estimation result of x ^ ( t ) at the present moment, S-Motion is the measurement result from the Kistler S-Motion, and VD is the estimation result from the VDM-based estimator. Longi Delayed and Longi in the flag figure mean Flag F _ v x _ VD and Flag v x _ VD , respectively. Late Delayed and Late in the flag figure mean Flag F _ v y _ VD and Flag v y _ VD , respectively. ‘deg’ means degree.

4.2.2. Slalom Maneuver

Figure 11 shows the test results of the proposed method with the slalom maneuver.

4.3. Discussion

Figure 10 and Figure 11 show the DLC and slalom maneuver test results. Figure 10a and Figure 11a show the vehicle trajectory. In those two maneuvers, the vehicle was driven violently with the steering wheel angular speed over 500°/s. The peak lateral acceleration reached 8 m/s2, which is nearly the road friction limit. Because the attitude from VDM-based estimators was very noise, which would affect the expression of the test results, the cyan line was only given in Figure 10f,g. In Figure 11, some of the important results were given compared with Figure 10. Table 1 and Table 2 show the absolute estimation errors in each maneuver. As for roll angle and slip angle, we select four peak points to compute the absolute estimation errors and averaged error. As for the pitch angle and longitudinal velocity, we randomly select four points to compute the absolute estimation errors and averaged error because under critical steering conditions, the dynamics in longitudinal direction is small. Table 3 and Table 4 show the root mean square errors in each maneuver.
During the dramatic steering process, the vehicle body rotated fast with peak roll angle over 5°. Aided by the VDM-based estimator in normal driving conditions, the IMU-based attitude estimator could maintain a good state with roll angle estimation error smaller than 0.1° even without aid for a short time during the dramatic steering. The estimation error for pitch angle was below 0.5° in the total test process. The IAE-based Kalman filter for attitude estimation eliminated large noise, as shown by the green curves in Figure 10f,g. This is significant for the application from the control perspective. On the other hand, since the main error source of IMU-based estimator is the bias error, this accumulated error will not grow fast and in order to obtain the smooth estimation result, usually we set the noise covariance as a large initial value to reduce the weight of the measurement from VDM-based attitude estimators. Also the R ^ min i in Equation (22) is set as large value. From Figure 10f, we see that the cyan line which is the roll angle estimation result as the feedback for the IMU-based attitude estimation result was very noise. Thanks to the large noise covariance, the red line follows the cyan line smoothly in the partial enlarged detail of roll angle in Figure 10g. The convergence time is near 2 s from 0.82° to 0.8° from 104 s to 106 s. The averaged estimation error of roll angle was smaller than 0.1° and the RMS error of roll angle was smaller than 0.15°. The averaged estimation error of pitch angle was smaller than 0.2° and the RMS error of pitch angle was smaller than 0.2°.
In normal driving conditions, the precise longitudinal and lateral velocity from the VDM-based estimator can be used as feedback to correct the IMU-based velocity estimator. This correction would remove the accumulated error in the IMU-based velocity estimator. From Figure 10j,k and Figure 11e, the velocity estimated by the proposed method can follow the velocity from the VDM-based estimator smoothly and without accumulated error. When the driver steered fast, the feedback to the lateral velocity was cut off if the flag in Figure 10i and Figure 11e was set. Then the slip angle shown in Figure 10k and Figure 11e was integrated in open loop integration mode. Thanks to the accurate attitude estimation result compensating the gravity component, the slip angle did not diverge over a short time. The maximum slip angle estimation error was less than 0.25° and the estimation precision reached 90%, which was much higher than that of the VDM-based estimator. This proved the idea in this paper that the VDM-based estimator would contribute bad information if we still injected it into the IMU-based estimator. Compared with lateral velocity, the precision of longitudinal velocity was higher because the tire slip ratio in the longitudinal direction was small, and it was over 95%. From Table 1 and Table 3, the averaged estimation error of longitudinal velocity was smaller than 0.1 m/s and the RMS error of longitudinal velocity was also smaller than 0.1 m/s from Table 2 and Table 4. The averaged estimation error of slip angle was smaller than 0.25° and the RMS error of slip angle was smaller than 0.1°, which was better than the slip angle from VDM-based estimator.
The novel feedback strategy in Section 3.2.2 and Section 3.2.3 can generally detect critical driving conditions. Since the rules were established on the assumption that the vehicle had already entered into the critical situation, the detecting flag introduced a time delay to cut off the feedback. We proposed Equations (14) and (32) to extend the time domain of the critical driving condition as the blue and cyan curves shown in Figure 10i and Figure 11e, and in the meantime, we delayed all input and output to realize synchronization for a short time to make the flag setting precede the critical condition. Then we used the predictors to move the past state x ^ τ ( t ) to the current time, as shown by the predicted curves in Figure 10f–k and Figure 11b–e, compared with the delayed curves. This moving process would not involve large estimation error in the current state, and this proof is theoretically made in Appendix A.

5. Conclusions

In this paper, a novel and autonomous IMU-based vehicle slip angle and attitude estimation method aided by vehicle dynamics and GNSS is proposed. Three main conclusions can be drawn:
  • Better performance has been gained by fusing VDM-based estimators and IMU-based estimators for slip angle and attitude than each of them. On the one hand, under normal driving conditions, assistance from VDM-based estimators can eliminate the accumulated error for the IMU–based slip angle and attitude estimation by the Kalman filter considering the lever arm between the IMU and rotation center. On the other hand, under critical driving conditions, without the accumulated error, the IMU-based slip angle and attitude estimation results have higher precision than the VDM-based estimator results.
  • The simultaneous estimation of attitude and velocity keeps the IMU-based estimators in a good state to prepare for the open loop integration mode when the vehicle enters critical driving conditions. An accurate attitude guarantees that the acceleration generated by gravity with changing attitude can be removed correctly. Then, even when the feedback from the VDM-based estimators is cut off, the estimation results of slip angle and attitude are still accurate for a short time.
  • The delayed estimator and predictor structure can avoid outlier feedback from VDM-based velocity and attitude estimators for IMU-based slip angle and attitude estimators with rejecting the time delay in detecting abnormal estimation results from VDM-based estimators. Also, the estimation error of the delayed estimator and predictor structure has been proved convergence theoretically.
In this paper, the aiding information for IMU-based estimators is obtained from estimators based on vehicle dynamics. In future work, our team will seek more accurate estimators based on vehicle dynamics to extend the aid to relatively critical driving conditions considering the nonlinear characteristics and uncertainty of the vehicle model. Also, when the IMU-based estimators enter the open loop integration mode under critical conditions, we will involve some external information from GNSS to correct the accumulated error. Last but not least, we will implement this method online on an embedded processor such as a DSP 28335.

Author Contributions

Conceptualization, L.X. and X.X.; Funding acquisition, L.X.; Investigation, X.X., W.L.; Methodology, X.X. and X.L.; Hardware, H.S.; Validation, X.X., W.L., Y.L., L.G., Y.H., and H.S.; Resources, L.X. and W.L.; Supervision, X.L. and Z.Y.; Writing—original draft, X.X.; Writing—review and editing, X.X. and W.L.

Funding

This research is supported by the National Key Research and Development Program of China (grant no. 2016YFB0100901) and Shanghai Scientific Research Project (grant no. 16DZ1100700).

Conflicts of Interest

The authors declare no conflict of interest.

Appendix A

Assumption:
  • The estimation error of x ^ τ ( t ) is bounded.
  • The system is Lipschitz with respect to x, which means there exists a positive constant L R such that | f ( x 1 , u ) f ( x 2 , u ) | L | x 1 x 2 | for any x 1 R and x 2 R and any u , where | | means Euclidean norm on R n .
  • The delayed time τ is smaller than 1 L and there exists σ such that:
    L e σ τ 1 σ 1
Proof:
Define the estimation error e ( t ) x ^ ( t ) x ( t ) , and when t τ , we also have:
x ( t ) = x ( t τ ) + t τ t f ( x ( s ) , u ( s ) ) d s
x ^ ( t ) = x ^ ( t τ ) + t τ t f ( x ^ ( s ) , u ( s ) ) d s = x ^ τ ( t ) + t τ t f ( x ^ ( s ) , u ( s ) ) d s
The initial state satisfies Equation (A4):
x ( t ) | [ 0 , τ ] = x ^ ( t ) | [ 0 , τ ] x ^ ( τ ) + δ ( τ ) δ ( 0 )
Subtract Equation (A2) from (A3) and then multiply the result by e σ t , we have:
e σ t | x ^ ( t ) x ( t ) | e σ t ( | x ^ τ ( t ) x ( t τ ) | + t τ t | f ( x ^ ( s ) , u ( s ) ) f ( x ( s ) , u ( s ) ) | d s )
With Inequality (A1), we have:
e σ t | x ^ ( t ) x ( t ) | e σ t ( | x ^ τ ( t ) x ( t τ ) | + L t τ t | x ^ ( s ) x ( s ) | d s )
On the other hand, we get
t τ t | x ^ τ ( s ) x ( s ) | d s = t τ t e σ ( s s ) | x ^ τ ( s ) x ( s ) | d s sup t τ s t ( e σ s | x ^ ( s ) x ( s ) | ) t τ t e σ s d s
However:
t τ t e σ s d s = e σ t e σ τ 1 σ
Therefore, we have:
sup t τ s t ( e σ s | x ^ τ ( s ) x ( s ) | ) t τ t e σ s d s = e σ t e σ τ 1 σ sup t τ s t ( e σ s | x ^ ( s ) x ( s ) | )
With Inequality (A5) and Equation (A9) and e σ t 1 , we will get:
e σ t | x ^ ( t ) x ( t ) | e σ t | x ^ τ ( t ) x ( t τ ) | + L e σ τ 1 σ sup t τ s t ( e σ s | x ^ ( s ) x ( s ) | )
When t τ , taking the supremum over t, we will get:
sup τ s t ( e σ s | x ^ ( s ) x ( s ) | ) sup τ s t ( e σ s | x ^ τ ( s ) x ( s τ ) | ) + L e σ τ 1 σ sup 0 s t ( e σ s | x ^ ( s ) x ( s ) | )
Then two cases should be made to analyze the supremum.
(a) The supremum falls in [ 0 , τ ] .
If Equation (A12) is satisfied, then Inequality (A11) becomes Inequality (A13):
sup 0 s t ( e σ s | x ^ ( s ) x ( s ) | ) = sup 0 s τ ( e σ s | x ^ ( s ) x ( s ) | )
sup τ s t ( e σ s | x ^ ( s ) x ( s ) | ) σ σ L ( e σ τ 1 ) sup τ s t ( e σ s | x ^ τ ( s ) x ( s τ ) | ) + sup 0 s τ ( e σ s | x ^ ( s ) x ( s ) | )
(b) The supremum falls in [ τ , t ] .
If Equation (A14) is satisfied, then we also have Inequality (A13):
sup 0 s t ( e σ s | x ^ ( s ) x ( s ) | ) = sup τ s t ( e σ s | x ^ ( s ) x ( s ) | )
According to Inequality (A13) and combined with e σ t | x ^ ( t ) x ( t ) | sup τ s t ( e σ s | x ^ ( s ) x ( s ) | ) , multiplying e σ t by Equation (A12), we have:
| x ^ ( t ) x ( t ) | e σ t sup τ s t ( e σ s | x ^ ( s ) x ( s ) | ) σ σ L ( e σ τ 1 ) sup τ s t ( e σ ( s t ) | x ^ τ ( s ) x ( s τ ) | ) + e σ t sup 0 s τ ( e σ s | x ^ ( s ) x ( s ) | )
Therefore, we get that the estimation error converges to an upper bound given by Inequality (A16):
| e ( t ) | σ σ L ( e σ τ 1 ) sup τ s t ( e σ ( s t ) e ( s τ ) ) + e σ t sup 0 s τ ( e σ s e ( s ) )
From Inequality (A16), the first part on the right side is related to τ and the second part is related to the initial estimation error. There is an attenuation term e σ t in the second part, therefore the second part would converge to zero over time.
In addition, with Equation (A16) we can draw three conclusions: if the estimation error of x ^ τ ( t ) is bounded, then e ( t ) is bounded; if the estimation error of x ^ τ ( t ) is asymptotically convergent, then e ( t ) is asymptotically convergent; if the estimation error of x ^ τ ( t ) is exponentially convergent, then e ( t ) is exponentially convergent.
(i) e ( t ) is bounded.
If the estimation error of x ^ τ ( t ) is smaller than δ 0 0 and t τ , from Inequality (A16), it is easy to derive Inequality (A17) with respect to any t τ :
| e ( t ) | σ σ L ( e σ τ 1 ) δ 0 + δ 1
(ii) e ( t ) is asymptotically convergent.
If the estimation error of x ^ τ ( t ) satisfies lim t e ( t τ ) = 0 , then for any ς r 0 , there exists T r such that, for any t T r , we have e ( t τ ) ς r . Thus for any t T r , from Inequality (A16), we have Inequality (A18):
| e ( t ) | σ σ L ( e σ τ 1 ) ς r sup τ s t ( e σ ( s t ) ) + e σ t sup 0 s τ ( e σ s e ( s ) ) σ σ L ( e σ τ 1 ) ς r + e σ t sup 0 s τ ( e σ s e ( s ) )
With specified ς 0 , we can always find ς r small enough and T large enough such that
σ σ L ( e σ τ 1 ) ς r + e σ T sup 0 s τ ( e σ s e ( s ) )
Therefore, for any t max ( T , T r ) , we have | e ( t ) | ς , which means Equation (A20) holds:
lim t e ( t ) = 0
(iii) e ( t ) is exponentially convergent.
If the estimation error of x ^ τ ( t ) is exponentially convergent, there exist positive κ and χ such that:
e ( t τ ) κ | x ^ τ ( τ ) x ( 0 ) | e χ t
Then the first part on the right side of Inequality (A16) satisfies Inequality (A22):
sup τ s t ( e σ ( s t ) e ( s τ ) ) κ | x ^ τ ( τ ) x ( 0 ) | e ( χ + σ ) t sup τ s t ( e σ s ) κ | x ^ τ ( τ ) x ( 0 ) | e χ t
Substituting Inequality (A21) into Inequality (A16), we have:
| e ( t ) | σ σ L ( e σ τ 1 ) κ | x ^ τ ( τ ) x ( 0 ) | e χ t + e σ t sup 0 s τ ( e σ s e ( s ) ) κ ¯ e χ ¯ t
where χ ¯ = min ( σ , χ ) and κ ¯ = σ σ L ( e σ τ 1 ) κ | x ^ τ ( τ ) x ( 0 ) | e ( χ ¯ χ ) τ + sup 0 s τ ( e σ s e ( s ) ) e ( ( χ ¯ σ ) τ ) .
Thus, if there is a convergent estimation error in x ^ τ ( t ) , the estimation error of x ^ ( t ) is also convergent.

References

  1. Lv, C.; Hu, X.; Sangiovanni-Vincentelli, A.; Li, Y.; Martinez, C.M.; Cao, D. Driving-style-based co-design optimization of an automated electric vehicle: A cyber-physical system approach. IEEE Trans. Ind. Electron. 2018, 66, 2965–2975. [Google Scholar] [CrossRef]
  2. Woo, R.; Yang, E.J.; Seo, D.W. A fuzzy-innovation-based adaptive kalman filter for enhanced Vehicle positioning in dense urban environments. Sensors 2019, 19, 1142. [Google Scholar] [CrossRef] [PubMed]
  3. Xing, Y.; Lv, C.; Wang, H.; Cao, D.; Velenis, E. Dynamic integration and online evaluation of vision-based lane detection algorithms. IET Intell. Transp. Syst. 2019, 13, 55–62. [Google Scholar] [CrossRef]
  4. Han, J.; Heo, O.; Park, M.; Kee, S.; Sunwoo, M. Vehicle distance estimation using a mono-camera for FCW/AEB systems. Int. J. Automot. Technol. 2016, 17, 483–491. [Google Scholar] [CrossRef]
  5. Cheng, S.; Li, L.; Chen, J. Fusion algorithm design based on adaptive SCKF and integral correction for side-slip angle observation. IEEE Trans. Ind. Electron. 2017, 65, 5754–5763. [Google Scholar] [CrossRef]
  6. Chen, J.; Song, J.; Li, L.; Gang, J.; Ran, X.; Cai, Y. UKF-based adaptive variable structure observer for vehicle sideslip with dynamic correction. IET Control Theory Appl. 2016, 10, 1641–1652. [Google Scholar] [CrossRef]
  7. RT3000. Available online: https://www.oxts.com/products/rt3000 (accessed on 5 April 2019).
  8. Correvit S-Motion: 2-Axis Optical Sensors. Available online: https://www.kistler.com/en/product/type-csmota/?application=13 (accessed on 5 April 2019).
  9. Ahmed, H.; Tahir, M. Accurate attitude estimation of a moving land vehicle using low-cost MEMS IMU sensors. IEEE Intell. Transp. Syst. 2017, 18, 1723–1739. [Google Scholar] [CrossRef]
  10. Wu, Z.; Yao, M.; Ma, H.; Jia, W. Improving accuracy of the vehicle attitude estimation for low-cost INS/GPS integration aided by the GPS-measured course angle. IEEE Intell. Transp. Syst. 2013, 14, 553–564. [Google Scholar] [CrossRef]
  11. Wang, Y.; Nguyen, M.B.; Fujimoto, H.; Hori, Y. Multirate estimation and control of body slip angle for electric vehicles based on onboard vision system. IEEE Trans. Ind. Electron. 2014, 61, 1133–1143. [Google Scholar] [CrossRef]
  12. Yoon, J.H.; Peng, H. A cost-effective sideslip estimation method using velocity measurements from two GPS receivers. IEEE Trans. Veh. Technol. 2014, 63, 2589–2599. [Google Scholar] [CrossRef]
  13. Li, L.; Jia, G.; Ran, X.; Song, J.; Wu, K. A variable structure extended Kalman filter for vehicle sideslip angle estimation on a low friction road. Veh. Syst. Dyn. 2014, 52, 280–308. [Google Scholar] [CrossRef]
  14. Oh, J.J.; Choi, B.S. Vehicle velocity observer design using 6-D IMU and multiple-observer approach. IEEE Trans. Intell. Transp. Syst. 2012, 13, 1865–1879. [Google Scholar] [CrossRef]
  15. Xia, X.; Xiong, L.; Liu, W.; Yu, Z. Automated vehicle attitude and lateral velocity estimation using a 6-D IMU aided by vehicle dynamics. In Proceedings of the 2018 IEEE Intelligent Vehicles Symposium, Changshu, China, 26–30 June 2018. [Google Scholar]
  16. Savage, P.G. Strapdown inertial navigation integration algorithm design Part 1: Attitude algorithms. J. Guid. Control Dyn. 1998, 21, 19–28. [Google Scholar] [CrossRef]
  17. Zhu, R.; Sun, D.; Zhou, Z.; Wang, D. A linear fusion algorithm for attitude determination using low cost MEMS-based sensors. Measurement 2007, 40, 322–328. [Google Scholar] [CrossRef]
  18. Rehbinder, H.; Hu, X. Drift-free attitude estimation for accelerated rigid bodies. Automatica 2004, 40, 653–659. [Google Scholar] [CrossRef] [Green Version]
  19. 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. [Google Scholar] [CrossRef]
  20. Yoon, J.H.; Peng, H. Robust vehicle sideslip angle estimation through a disturbance rejection filter that integrates a magnetometer with GPS. IEEE Trans. Intell. Transp. Syst. 2014, 15, 191–204. [Google Scholar] [CrossRef]
  21. Liu, Y.; Fan, X.; Lv, C.; Wu, J.; Li, L.; Ding, D. An innovative information fusion method with adaptive Kalman filter for integrated INS/GPS navigation of autonomous vehicles. Mech. Syst. Signal Process. 2017, 100, 605–616. [Google Scholar] [CrossRef]
  22. Hansen, J.M.; Fossen, T.I.; Johansen, T.A. Nonlinear observer design for GNSS-aided inertial navigation systems with time-delayed GNSS measurements. Control Eng. Pract. 2017, 60, 39–50. [Google Scholar] [CrossRef]
  23. Zhao, S.; Zhang, H.; Fan, Y. Attitude estimation method for flight vehicles based on computer vision. J. Beijing Univ. Aeronaut. Astronaut. 2006, 32, 885. [Google Scholar]
  24. Chung, T.; Yi, K. Design and evaluation of side slip angle-based vehicle stability control scheme on a virtual test track. IEEE Trans. Control Syst. Technol. 2006, 14, 224–234. [Google Scholar] [CrossRef]
  25. Bevly, D.M.; Ryu, J.; Gerdes, J.C. Integrating INS sensors with GPS measurements for continuous estimation of vehicle sideslip, roll, and tire cornering stiffness. IEEE Trans. Intell. Transp. Syst. 2006, 7, 483–493. [Google Scholar] [CrossRef]
  26. Matsui, T.; Suganuma, N.; Fujiwara, N. Measurement of vehicle sideslip angle using stereovision. Trans. Jpn. Soc. Mech. Eng. C 2005, 71, 3202–3207. [Google Scholar] [CrossRef]
  27. Gao, X.; Yu, Z.; Wiedemann, J. Sideslip angle estimation based on input–output linearisation with tire–road friction adaptation. Veh. Syst. Dyn. 2010, 48, 217–234. [Google Scholar] [CrossRef]
  28. Leung, K.T.; Whidnorne, J.F.; Purdy, D.; Dunpyer, A. A review of ground vehicle dynamic state estimations utilising GPS/INS. Veh. Syst. Dyn. 2011, 49, 29–58. [Google Scholar] [CrossRef]
  29. Piyabongkarn, D.; Rajamani, R.; Grogg, J.A.; Lew, J.Y. Development and experimental evaluation of a slip angle estimator for vehicle stability control. IEEE Trans. Control Syst. Technol. 2009, 17, 78–88. [Google Scholar] [CrossRef]
  30. Ding, W.; Wang, J.; Rizos, C.; Rizos, C. Improving adaptive Kalman estimation in GPS/INS integration. J. Navig. 2007, 60, 517. [Google Scholar] [CrossRef]
  31. Xia, X.; Xiong, L.; Hou, Y.; Teng, G.; Yu, Z. Vehicle stability control based on driver’s emergency alignment intention recognition. Int. J. Automot. Technol. 2017, 18, 993–1006. [Google Scholar]
  32. Vaccaro, R.J.; Zaki, A.S. Statistical modeling of rate gyros. IEEE Trans. Instrum. Meas. 2012, 61, 673–684. [Google Scholar] [CrossRef]
  33. Khosravian, A.; Trumpf, J.; Mahony, R. State estimation for nonlinear systems with delayed output measurements. In Proceedings of the 54th IEEE Conference on Decision & Control, Osaka, Japan, 15–18 December 2015. [Google Scholar]
Figure 1. Overview of proposed slip angle and attitude estimation architecture. IMU, inertial measurement unit.
Figure 1. Overview of proposed slip angle and attitude estimation architecture. IMU, inertial measurement unit.
Sensors 19 01930 g001
Figure 2. Wheel model.
Figure 2. Wheel model.
Sensors 19 01930 g002
Figure 3. Feedback mechanism for longitudinal velocity and pitch angle estimator. a x _ dev is the deviation between VDM-based and fused longitudinal acceleration; E means expectation; Var means variance for a short time; || means operation.
Figure 3. Feedback mechanism for longitudinal velocity and pitch angle estimator. a x _ dev is the deviation between VDM-based and fused longitudinal acceleration; E means expectation; Var means variance for a short time; || means operation.
Sensors 19 01930 g003
Figure 4. Kalman filter process.
Figure 4. Kalman filter process.
Sensors 19 01930 g004
Figure 5. Single-track vehicle model.
Figure 5. Single-track vehicle model.
Sensors 19 01930 g005
Figure 6. Feedback mechanism for lateral velocity and roll angle.
Figure 6. Feedback mechanism for lateral velocity and roll angle.
Sensors 19 01930 g006
Figure 7. Delayed observer and predictor structure.
Figure 7. Delayed observer and predictor structure.
Sensors 19 01930 g007
Figure 8. Hardware layout.
Figure 8. Hardware layout.
Sensors 19 01930 g008
Figure 9. Hardware implementation: (a) test vehicle and part of equipment; (b) GNSS receiver and IMU.
Figure 9. Hardware implementation: (a) test vehicle and part of equipment; (b) GNSS receiver and IMU.
Sensors 19 01930 g009
Figure 10. Test results in double lane change (DLC) maneuver: (a) trajectory; (b) acceleration; (c) angular speed; (d) steering wheel angle; (e) steering wheel angular speed; (f) roll angle; (g) partial enlarged detail of roll angle; (h) pitch angle; (i) flat; (j) longitudinal velocity; (k) slip angle.
Figure 10. Test results in double lane change (DLC) maneuver: (a) trajectory; (b) acceleration; (c) angular speed; (d) steering wheel angle; (e) steering wheel angular speed; (f) roll angle; (g) partial enlarged detail of roll angle; (h) pitch angle; (i) flat; (j) longitudinal velocity; (k) slip angle.
Sensors 19 01930 g010aSensors 19 01930 g010bSensors 19 01930 g010cSensors 19 01930 g010d
Figure 11. Test results in slalom maneuver: (a) trajectory; (b) roll angle; (c) pitch angle; (d) flag; (e) slip angle.
Figure 11. Test results in slalom maneuver: (a) trajectory; (b) roll angle; (c) pitch angle; (d) flag; (e) slip angle.
Sensors 19 01930 g011aSensors 19 01930 g011b
Table 1. Absolute estimation errors during critical steering in DLC maneuver. “Ave” means averaged estimation error. “P” means point.
Table 1. Absolute estimation errors during critical steering in DLC maneuver. “Ave” means averaged estimation error. “P” means point.
Proposed MethodVehicle Dynamics
P1P2P3P4AveP1P2P3P4Ave
Roll angle (deg)0.050.040.020.10.05
Pitch angle (deg)0.050.260.20.250.19
Longi velocity (m/s)0.110.020.060.150.090.050.080.010.020.04
Slip angle (deg)0.010.210.150.020.100.910.650.420.450.61
Table 2. Absolute estimation errors during critical steering in slalom maneuver.
Table 2. Absolute estimation errors during critical steering in slalom maneuver.
Proposed MethodVehicle Dynamics
P1P2P3P4AveP1P2P3P4Ave
Roll angle (deg)0.090.010.020.070.05
Pitch angle (deg)0.050.140.090.430.18
Longi velocity (m/s)0.080.020.040.130.070.040.070.070.030.05
Slip angle (deg)0.50.050.250.140.241.480.580.510.170.69
Table 3. Root mean square (RMS) of estimation errors in DLC maneuver.
Table 3. Root mean square (RMS) of estimation errors in DLC maneuver.
Proposed MethodVehicle Dynamics
Roll angle (deg)0.114
Pitch angle (deg)0.168
Longi velocity (m/s)0.0540.032
Slip angle (deg)0.0690.176
Table 4. RMS of estimation errors in slalom maneuver.
Table 4. RMS of estimation errors in slalom maneuver.
Proposed MethodVehicle Dynamics
Roll angle (deg)0.089
Pitch angle (deg)0.181
Longi velocity (m/s)0.050.03
Slip angle (deg)0.1000.291

Share and Cite

MDPI and ACS Style

Xiong, L.; Xia, X.; Lu, Y.; Liu, W.; Gao, L.; Song, S.; Han, Y.; Yu, Z. IMU-Based Automated Vehicle Slip Angle and Attitude Estimation Aided by Vehicle Dynamics. Sensors 2019, 19, 1930. https://doi.org/10.3390/s19081930

AMA Style

Xiong L, Xia X, Lu Y, Liu W, Gao L, Song S, Han Y, Yu Z. IMU-Based Automated Vehicle Slip Angle and Attitude Estimation Aided by Vehicle Dynamics. Sensors. 2019; 19(8):1930. https://doi.org/10.3390/s19081930

Chicago/Turabian Style

Xiong, Lu, Xin Xia, Yishi Lu, Wei Liu, Letian Gao, Shunhui Song, Yanqun Han, and Zhuoping Yu. 2019. "IMU-Based Automated Vehicle Slip Angle and Attitude Estimation Aided by Vehicle Dynamics" Sensors 19, no. 8: 1930. https://doi.org/10.3390/s19081930

APA Style

Xiong, L., Xia, X., Lu, Y., Liu, W., Gao, L., Song, S., Han, Y., & Yu, Z. (2019). IMU-Based Automated Vehicle Slip Angle and Attitude Estimation Aided by Vehicle Dynamics. Sensors, 19(8), 1930. https://doi.org/10.3390/s19081930

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop