The attitude and heading reference system (AHRS) used in aircraft vehicles is typically based on a complementary filtering algorithm. The AHRS typically uses Gravity vector matching to estimate the attitude of the aircraft. However, unless aided by other systems, such as air-data systems or the global positioning system (GPS), current AHRS implementations are not able to efficiently compensate for vehicle acceleration, which acts as a parasite value in a specific force measurement.
An attitude and heading reference system (AHRS) for a vehicle is provided along with methods for mitigating vehicle acceleration effects in the AHRS. The AHRS comprises an inertial measurement unit configured to generate inertial measurements from at least one accelerometer and at least one gyroscope, a heading source configured to generate heading measurements, and an adaptive statistical filter configured to mitigate the impact of vehicle acceleration effects on attitude and heading.
Features of the present invention will become apparent to those skilled in the art from the following description with reference to the drawings. Understanding that the drawings depict only typical embodiments and are not therefore to be considered limiting in scope, the invention will be described with additional specificity and detail through the use of the accompanying drawings, in which:
In the following detailed description, embodiments are described in sufficient detail to enable those skilled in the art to practice the invention. It is to be understood that other embodiments may be utilized without departing from the scope of the invention. The following detailed description is, therefore, not to be taken in a limiting sense.
Methods for mitigating vehicle acceleration effects in an attitude and heading reference system (AHRS) for a vehicle are described herein. A proper modeling of vehicle acceleration is needed to achieve a reasonable accuracy for the AHRS. An adaptive statistical filtering technique, such as an extended Kalman filter (EKF), comprises an algorithm that provides a probabilistic description of estimated quantities, and is used to estimate the vehicle acceleration, where a proper vehicle acceleration model is to be defined. Due to different dynamic conditions a suitable unified vehicle acceleration model is hard to identify. Thus, an adaptive method is deployed instead to properly deal with an instant vehicle dynamics.
An algorithmic method to model the underlying aircraft vehicle acceleration as an error source is provided. Two embodiments of adapting a vehicle acceleration model are described herein to mitigate the parasite influence of vehicle acceleration. The present methods adapt a vehicle acceleration model based on measured and estimated variables. These techniques significantly increase a reachable accuracy, effectively remove the common mode failure of complementary filter based AHRS in dynamic conditions, and are able to provide statistics of the estimation errors.
In addition to AHRS, the present methods can be applied to Air Data aided (AD) AHRS, GPS-aided AHRS, and the like.
Further details of the present methods are described hereafter in the following sections and with reference to the drawings.
The AHRS obtains inertial data from an inertial measurement unit (IMU), which generally includes a three-axis gyroscope and a three-axis accelerometer. Properties of the gyroscope and accelerometer sensor errors can be predicted based on sensor models.
A gyroscope sensor model can be defined by the following equation:
{tilde over (ω)}IBB=ωIBB+(bgyrB,constB+bgyrB,dynB)+wgyrB (1)
where {tilde over (ω)}IBB is the measured quantity of the angular rate of body frame with respect to inertial frame expressed in the body frame outputted by the gyroscope; ωIBB is the true angular rate; bgyrB,constB is the gyroscope constant bias in the body frame; bgyrB,dynB is the gyroscope dynamic bias in the body frame; wgyrB is the gyroscope white noise in the body frame; and N(0, σgyr2) is the normal (Gaussian) distribution with zero mean and variance equal to σgyr.
The total gyroscope bias in the body frame (bgyrBB) corresponds to the sum of the gyroscope constant and dynamic bias (bgyrB,constB+bgyrB,dynB), and (within an error state EKF implementation scheme) can be modeled such as first-order Gauss-Markov (GM) process using the following equation:
δ{dot over (b)}gyrBB=−1/τgyrδbgyrBB+wGMgyrBB
w
GMgyrB
B
˜N(0,σGMgyrB2 (2)
where δ{dot over (b)}gyrBB is the time derivative of the error of the estimate of the gyroscope bias, τgyr is the time constant of the GM process used to model the gyroscope bias, wGMgyrBB is the gyroscope bias estimation error.
An accelerometer sensor model can be defined by the following equation:
{tilde over (f)}
B
=a
B
−g
B+(baccB,constB+baccB,dynB)+waccB
w
acc
B
˜N(0,σacc2) (3)
where {tilde over (f)}B is the measured quantity of the specific force in the body frame outputted by the accelerometer; aB is the true body frame (vehicle) acceleration; gB is the gravity field vector in the body frame; baccB,constB is the accelerometer constant bias in the body frame; baccB,dynB is the accelerometer dynamic bias in the body frame; and waccB is the accelerometer white noise in the body frame. The total accelerometer bias in the body frame (baccBB) corresponds to the sum of the accelerometer constant and dynamic bias (baccB,const+baccB,dynB), and (within an error state EKF implementation scheme) can be modeled such as GM process using the following equation:
δ{dot over (b)}accBB=−1/τaccδbaccBB+wGMaccBB
w
GMaccB
B
˜N(0,σGMaccB2) (4)
where δ{dot over (b)}accBB is the time derivative of the error of the estimate of the accelerometer bias, τacc is the time constant of the GM process used to model the accelerometer bias, wGMaccBB is the driving noise of the GM process used to model the accelerometer bias, and δbaccBB is the accelerometer bias estimation error.
The AHRS obtains or calculates heading data from a sensor such as magnetometer. While a magnetometer sensor model can be used to predict magnetometer sensor errors properties, assumes to be calibrated such the model can be replaced by simplified heading aiding based on the following equations:
δ{tilde over (ψ)}=(−tan θ cos ψ)εNx+(−tan θ sin ψ)εNy−εNz−wψN
w
ψ
N
˜N(0,σψ2) (5)
where δ{tilde over (ψ)} is heading measurement residual (constructed as a difference between estimated and measured heading), εN is the attitude error resolved in the navigation frame, and wψN is a white noise of heading aiding. Heading aiding can be taken from any heading source.
The AHRS takes into account earth and transport rates (ETR) in producing attitude and heading data. The ETR is expressed in the navigation frame and can be modeled by a single GM process, with parameters of the GM process being estimated via a stochastic analysis.
The physical relationship of ETR is expressed by the following equations:
ωNBB=ωIBB−ωINB (6)
ωINB=ωIEB+ωENB (7)
where ωNBB is the angular rate of the body frame with respect to navigation frame expressed in body frame, ωINB is the angular rate of the navigation frame with respect to the inertial frame expressed in body frame, ωIEB is the earth rate expressed in body frame, and ωENB is the transport rate expressed in body frame.
The ETR, ωGM,INN, can be modeled such as a single GM process using the following equation:
δ{dot over (ω)}GM,INN=−1/τGM,INδωGM,INN+wGM,IN
w
GM,IN
N
˜N(0,σGM,IN2) (8)
where δ{dot over (ω)}GM,INN is the time derivative of the error of the estimate of the ETR GM process, τGM,IN is the time constant of the GM process used to model the ETR, wGM,INN is the driving noise of the GM process, and δωGM,INN is the earth and transport rates estimate error.
The AHRS also takes into account vehicle acceleration in producing attitude and heading data. The physical relationship of the vehicle acceleration can be according to (3) expressed as follows:
{tilde over (f)}
B
=f
B
+b
accB
B
+w
acc
B
=a
B
−C
N
B
g
N
+b
accB
B
+w
acc
B (9)
where {tilde over (f)}B is the measured quantity of specific force (accelerometer output), fB is the true specific force, baccBB is the true total accelerometer bias in the body frame, waccB is the accelerometer white noise in the body frame, aB is the true vehicle acceleration, CNB is the true direction cosine matrix performing the transformation of a vector coordinated in the navigation frame to the body frame, and gN is the true Gravity field vector in navigation frame. The vehicle acceleration, which is significant source of attitude error if unknown and not accounted for, can be (within an error state EKF implementation scheme) modeled such as GM process using the following equation:
δ{dot over (α)}B=−1/τacclerationδαB+wGMaccelerationB
w
GMacceleration
B
˜N(0,σGMacceleration2) (10)
where δ{dot over (a)}B is time derivative of the error of the estimate of the GM process used to model the (so-called external) vehicle acceleration, τacceleration is the time constant of the GM process, δaB is error estimate of the vehicle acceleration, and wGMaccelerationB is driving noise of the GM process.
The presented approach provides a way to quantify steady-state standard deviation (STD) of the vehicle acceleration GM process (σsteadyState,GMacceleration) and to make it proportional to the vehicle acceleration:
σsteadyState,GMacceleration2=σsteadyState,acceleration2+α2 (11)
with a lower boundary defined as:
σsteadyState,GMacceleration2=func1(σsteadyState,accelerometer2) (12)
and an upper boundary defined as:
σsteadyState,GMacceleration2=func2(aB) (13)
The lower boundary is due to accelerometer bias, and is used to set-up a steady-state STD minimum value. Overbounding is used to compensate for different dynamics of vehicle acceleration and accelerometer bias. A solution is provided by using an overbounding factor, η, as follows: ησsteadyState,accelerometer2. The upper boundary is due to vehicle acceleration, and is employed to avoid using an estimated acceleration to define the property of its own model (GM process), as well as to cope with a lack of information about the source axis of the vehicle acceleration. A solution is provided by using a norm of the “synthetic” vehicle acceleration, which is a combination of the measured and estimated quantities and is defined as follows:
α=∥{tilde over ({circumflex over (a)})}B∥=∥{tilde over (f)}B+ĈNBĝN−{circumflex over (b)}accBB∥ (14)
where upper script {circumflex over (•)} represents estimated parameters.
Use of the lower and upper boundaries results in the following relationship:
σsteadyState,GMacceleration2=(ησsteadyState,accelerometer)2+α2 (15)
An upper boundary error analysis can be performed based on the following equation:
The terms δbaccBB, waccB, ĈNBwgravN in equation (16) are assumed to have a negligible effect on the resulting acceleration estimate.
In a first technique, a first upper boundary computation algorithm computes the norm of the corresponding vector sum, and employs the overbounding factor, η, as indicated in the following equations:
α=∥{tilde over (â)}B∥≈∥{tilde over (f)}B+ĈNBĝN−{circumflex over (b)}accBB∥ (17)
σsteadyState,GMacceleration2=(ησStationary,accelerometer)2+α2 (18)
The first technique has the advantage of being a straightforward computation, with almost no computational overhead, and provides a conservative approach in most situations. This technique is based on the norm of the acceleration and affects all axes regardless of the source axis of the acceleration. The minimum value of the steady-state STD is governed by the overbounding factor, η. The first technique is described in further detail hereafter.
In a second technique, a second upper boundary computation algorithm computes the norm of the corresponding vector sum, and performs computations based on the attitude error scanning based on the following equations:
α=maxi{∥{tilde over (f)}B+{ĈNB(i)}ĝN−{circumflex over (b)}accBB∥;ĈNB(i)=f({circumflex over (φ)}j,{circumflex over (θ)}k)} (19)
{circumflex over (φ)}jε[−Δσ{circumflex over (φ)}+{circumflex over (φ)};{circumflex over (φ)}+Δσ{circumflex over (φ)}];Δσ{circumflex over (φ)}=Nσ{circumflex over (φ)} (20)
{circumflex over (θ)}kε[−Δσ{circumflex over (θ)}+{circumflex over (θ)};{circumflex over (θ)}+Δσ{circumflex over (θ)}];Δσ{circumflex over (θ)}=Nσ{circumflex over (θ)} (21)
σsteadyState,GMacceleration2=α2 (22)
where {tilde over (f)}B is a measured specific force in the body frame, {circumflex over (b)}accBB is the estimated accelerometer bias, ĈNBĝN represents the estimated gravity vector in the body frame, {circumflex over (φ)}j is the estimated roll angle, {circumflex over (θ)}k is the estimated pitch angle, σ{circumflex over (φ)} is the standard deviation of the estimated roll angle, and σ{circumflex over (θ)} is the standard deviation of the estimated pitch angle. The standard deviations of the roll angle and pitch angle estimates are provided by the extended Kalman filter. It should be noted that Δσ{circumflex over (φ)}=Nσ{circumflex over (φ)} and Δσ{circumflex over (θ)}=Nσ{circumflex over (θ)}, where N represents a scale factor which governs the size of the interval in order to perform more conservative (large N) or less conservative (small N) attitude error scanning. The second technique provides a conservative approach as compared to the first technique, and is based on the maximum of the norm of the acceleration. The method affects all axes regardless of the source axis of the acceleration, and solves the situation where the acceleration model does not overbound the true instantaneous acceleration. The second technique is described in further detail hereafter.
A measured quantity of specific force ({tilde over (f)}B) output from accelerometer 114 is sent to a mixer 118, which also receives an estimated accelerometer bias signal ({circumflex over (b)}accBB) output from an accelerometer bias accumulator 120. An output signal ({tilde over (f)}B−{circumflex over (b)}accBB) from mixer 118 is sent to a mixer 122, which also receives an estimated gravity vector signal expressed in body frame (ĈNBĝN) output from a gravity vector block 124.
A vehicle acceleration upper boundary computation module 125 receives the output signal from mixer 122. The vehicle acceleration upper boundary computation module 125 includes algorithms that provide mitigation for vehicle acceleration, and are described in further detail hereafter. The vehicle acceleration upper boundary computation module 125 generates power spectral density (PSD) data of the GM process (ΣGMacceleration2) that is sent to an error-state EKF 126 for further processing.
A vehicle acceleration accumulator 127 outputs an estimated vehicle acceleration signal (âB) to a mixer 128, which also receives the estimated accelerometer bias signal ({circumflex over (b)}accBB) from accelerometer bias accumulator 120. The estimated accelerometer bias is summed with the estimated vehicle acceleration in mixer 128, which outputs this sum (âB+{circumflex over (b)}accBB) to a mixer 129, which also receives the measured quantity of specific force output from accelerometer 114. The mixer 129 subtracts the measured quantity of specific force from the sum output by mixer 128, and outputs the result (âB+{circumflex over (b)}accBB−{tilde over (f)}B), which is in the body frame, to a transformation block 130. The transformation block 130 also receives an estimated direction cosine matrix (ĈNB) signal output from an attitude and heading integration module 144, which is described further hereafter.
In transformation block 130, an estimated direction cosine matrix (ĈNB) is created as a transposition of the ĈNB matrix (i.e., ĈNB=(ĈNB)T). The result from mixer 129 is transformed by multiplying with the estimated direction cosine matrix ĈNB, which performs the transformation from the body frame to the navigation frame. An output signal (ĈNB(âB+{circumflex over (b)}accBB−{tilde over (f)}B)) from transformation block 130 is sent to a mixer 131, which also receives an estimated gravity vector in the navigation frame (ĝN) from gravity vector block 124. The estimated gravity vector is subtracted in mixer 131, resulting in specific force measurement residuals in the navigation frame (δ{tilde over (f)}N), which are sent to the error-state EKF 126 for further processing.
A measured quantity of the angular rate ({tilde over (ω)}IBB) output from gyroscope 112 is sent to a mixer 134, which also receives a gyroscope bias signal ({circumflex over (b)}gyrBB) output from a gyroscope bias accumulator 136. An output signal from mixer 134 is sent to a mixer 138, which also receives an estimated ETR signal ({circumflex over (ω)}INB) output from a transformation block 140, where {circumflex over (ω)}=INB=ĈNB{circumflex over (ω)}INN. An Earth and Transport Rates accumulator 142 sends an output signal to transformation block 140.
A measured heading ({tilde over (ψ)}) output from heading unit 116 is sent to a mixer 146, which also receives an estimated heading ({circumflex over (ψ)}) from attitude and heading integration module 144. In mixer 146, the estimated heading is subtracted from the measured heading, resulting in heading measurement residuals (δ{tilde over (ψ)}), which are sent to the error-state EKF 126 for further processing.
The error-state EKF 126 generates and outputs various estimation error signals, including an estimated vehicle acceleration error signal (δaB) that is sent to the vehicle acceleration accumulator 127; an estimated accelerometer bias error signal (δbaccBB) that is sent to the accelerometer bias accumulator 120; a gyroscope bias errors signal (δbgyrBB) that is sent to the gyroscope bias accumulator 136; an ETR errors signal (δωGM,INN) that is sent to the ETR accumulator 142; and an attitude errors signal (εN) that is sent to the attitude and heading integration module 144.
The attitude and heading integration module 144 receives an output signal from mixer 138 and performs direction cosine matrix-based or quaternion-based integration. The attitude and heading integration module 144 receives also the attitude errors signal (δN) from the error-state EKF 126 to correct the direction cosine matrix. The attitude and heading integration module 144 sends the estimated direction cosine matrix (ĈNB) to transformation blocks 130 and 140 and to gravity vector block 124. The attitude and heading integration module 144 is configured to generate attitude and heading outputs 150 that are used by a vehicle navigation system.
The algorithm 200 then computes the steady-state STD of the vehicle acceleration GM process (block 230) using equation (18).
The algorithm 200 next computes PSD of the vehicle acceleration GM process driving noise (block 240) using the equation:
where ΣGMacceleration2 represents adapted quantity of PSD and is used for construction of process noise covariance matrix. Thereafter, an error-state EKF step is performed at 260.
The algorithm 300 then computes the steady-state STD of the vehicle acceleration GM process (block 330) using equation (18).
The algorithm 300 next computes the vehicle acceleration GM process driving noise PSD (block 340) using equation (23), where ΣGMacceleration2 represents adapted quantity of PSD and is used for construction of a process noise covariance matrix. Thereafter, an extended Kalman filter (EKF) step is performed at 360.
An exemplary process model that can be employed in algorithm 400 is defined by the following equations:
where process noise covariance matrix
where Σ2 are the power spectral densities of respective parameters.
An exemplary measurement model that can be employed in algorithms 400 is defined by the following equations:
where measurement covariance matrix
where εN is the attitude error vector, δbgyrBB is the gyroscope bias error vector, δaB is the vehicle acceleration error vector, δωGM,INN is the earth and transport rate error vector, δbaccBB is the accelerometer bias error vector, δ{tilde over (f)}N is the specific force error vector, δ{tilde over (ψ)} is the heading error, and T is the transformation matrix which transforms rotation vector to Euler angles and can be expressed as:
As shown in
A computer or processor used in the present system and method can be implemented using software, firmware, hardware, or any appropriate combination thereof, as known to one of skill in the art. These may be supplemented by, or incorporated in, specially-designed application-specific integrated circuits (ASICs) or field programmable gate arrays (FPGAs). The computer or processor can also include functions with software programs, firmware, or other computer readable instructions for carrying out various process tasks, calculations, and control functions used in the present method and system.
The present methods can be implemented by computer executable instructions, such as program modules or components, which are executed by at least one processor. Generally, program modules include routines, programs, objects, data components, data structures, algorithms, and the like, which perform particular tasks or implement particular abstract data types.
Instructions for carrying out the various process tasks, calculations, and generation of other data used in the operation of the methods described herein can be implemented in software, firmware, or other computer- or processor-readable instructions. These instructions are typically stored on any appropriate computer program product that includes a computer readable medium used for storage of computer readable instructions or data structures. Such a computer readable medium can be any available media that can be accessed by a general purpose or special purpose computer or processor, or any programmable logic device.
Suitable processor-readable media may include storage or memory media such as magnetic or optical media. For example, storage or memory media may include conventional hard disks, compact disks, DVDs, Blu-ray discs, or other optical storage disks; volatile or non-volatile media such as Random Access Memory (RAM); Read Only Memory (ROM), Electrically Erasable Programmable ROM (EEPROM), flash memory, and the like; or any other media that can be used to carry or store desired program code in the form of computer executable instructions or data structures.
Example 1 includes an attitude and heading reference system (AHRS) for a vehicle, the AHRS comprising an inertial measurement unit (IMU) configured to generate inertial measurements from at least one accelerometer and at least one gyroscope; a heading source configured to generate heading measurements; and an adaptive statistical filter configured to mitigate the impact of vehicle acceleration effects on attitude and heading.
Example 2 includes the AHRS of Example 1, wherein the adaptive statistical filter is configured to estimate an attitude and heading of the vehicle; model and estimate deployed sensor errors and other sources of errors; and model, adapt, and estimate vehicle acceleration.
Example 3 includes the AHRS of Example 2, wherein the modeled vehicle acceleration is adapted based on measured variables and estimated variables using one or more adaptation algorithms.
Example 4 includes the AHRS of Example 3, wherein the one or more adaptation algorithms are configured to detect vehicle acceleration; compute a synthetic acceleration; compute a vehicle acceleration upper boundary; and transform the vehicle acceleration upper boundary onto parameters for the modeled vehicle acceleration.
Example 5 includes the AHRS of any of Examples 1-4, wherein the adaptive statistical filter comprises an algorithm providing a probabilistic description of estimated quantities.
Example 6 includes the AHRS of any of Examples 1-4, wherein the adaptive statistical filter comprises an extended Kalman filter.
Example 7 includes the AHRS of any of Examples 1-6, further comprising an upper boundary computation module that includes a first vehicle acceleration adaptation algorithm configured to: provide a vehicle acceleration model based on measured variables and estimated variables; compute a vehicle acceleration upper boundary (α) based on a synthetic acceleration ({tilde over (â)}B) as:
α=∥{tilde over ({circumflex over (a)})}B∥=∥{tilde over (f)}B+ĈNBĝN−{circumflex over (b)}accBB∥
where {tilde over (f)}B is the measured specific force signal output from the accelerometer, ĈNB ĝN is the estimated gravity vector signal, and {circumflex over (b)}accBB is the estimated accelerometer bias signal; compute a steady-state standard deviation (σsteadyState,GMacceleration) of a vehicle acceleration first-order GM process as:
σsteadyState,GMacceleration2=(ησsteadyState,accelerometer)2+α2
where η is an overbounding factor; compute a power spectral density of the vehicle acceleration GM process driving noise as:
where τacceleration is a time constant of the GM process; construct a process noise covariance matrix by use of the power spectral density; and send results of the process noise covariance matrix construction to the adaptive statistical filter.
Example 8 includes the AHRS of any of Examples 1-6, further comprising an upper boundary computation module that includes a second vehicle acceleration adaptation algorithm configured to: provide a vehicle acceleration model based on measured variables and estimated variables; compute a vehicle acceleration upper boundary (α) based on a synthetic acceleration ({tilde over (â)}B) as:
where {tilde over (f)}B is a measured specific force in the body frame, {circumflex over (b)}accBB is the estimated accelerometer bias, ĈNBĝN represents the estimated gravity vector in the body frame, {circumflex over (φ)}j is the estimated roll angle, {circumflex over (θ)}k is the estimated pitch angle, σ{circumflex over (φ)} is the standard deviation of the estimated roll angle, σ{circumflex over (θ)} is the standard deviation of the estimated pitch angle, wherein the standard deviations of the roll angle and pitch angle estimates are provided by the adaptive statistical filter, and for Δσ{circumflex over (φ)}=Nσ{circumflex over (φ)} and Δσ{circumflex over (θ)}=Nσ{circumflex over (θ)}, the N represents a scale factor which governs the size of an interval in order to perform more conservative (larger N) or less conservative (smaller N) attitude error scanning; compute a steady-state standard deviation or (σsteadyState,GMacceleration) of a vehicle acceleration first-order GM process as:
σsteadyState,GMacceleration2=(ησsteadyState,accelerometer)2+α2
where η is an overbounding factor; compute a power spectral density of the vehicle acceleration GM process driving noise as:
where τacceleration is a time constant of the GM process; construct a process noise covariance matrix by use of the power spectral density; and send results of the process noise covariance matrix construction to the adaptive statistical filter.
Example 9 includes the AHRS of any of Examples 1-8, wherein the IMU comprises a three-axis accelerometer and a three-axis gyroscope.
Example 10 includes a method for mitigating vehicle acceleration effects in an attitude and heading reference system, the method comprising: obtaining inertial data from an inertial measurement unit (IMU) that includes at least one accelerometer and at least one gyroscope; computing a heading based on heading-related measurements; determining models of sensors and other sources of errors; identifying vehicle acceleration and computing a vehicle acceleration upper boundary based on measured variables; and performing a computation of an adaptive statistical filter configured to estimate attitude and heading while adaptively mitigating the impact of vehicle acceleration effects on the estimate by use of the vehicle acceleration upper boundary.
Example 11 includes the method of Example 10, wherein the adaptive statistical filter comprises an algorithm providing a probabilistic description of estimated quantities.
Example 12 includes the method of Example 10, wherein the adaptive statistical filter comprises an extended Kalman filter.
Example 13 includes the method of any of Examples 10-12, wherein the upper boundary computation is performed by a first vehicle acceleration adaptation algorithm comprising: providing a vehicle acceleration model based on measured variables and estimated variables; computing a vehicle acceleration upper boundary (α) based on a synthetic acceleration ({tilde over (â)}B) as:
α=∥{tilde over ({circumflex over (a)})}B∥≈∥{tilde over (f)}B+ĈNBĝN−{circumflex over (b)}accBB∥
where {tilde over (f)}B is a measured specific force signal output from the accelerometer, ĈNBĝN is the estimated gravity vector signal, and {circumflex over (b)}accBB is an estimated accelerometer bias signal; computing a steady-state standard deviation (σsteadyState,GMacceleration) of a vehicle acceleration first-order Gauss-Markov process as:
σsteadyState,GMacceleration2=(ησsteadyState,accelerometer)2+α2
where η is an overbounding factor; computing a power spectral density of the vehicle acceleration GM process driving noise as:
where τacceleration is a time constant of the GM process; constructing a process noise covariance matrix by use of the power spectral density; and sending results of the process noise covariance matrix construction to the adaptive statistical filter.
Example 14 includes the method of any of Examples 10-12, wherein the upper boundary computation is performed by a second vehicle acceleration adaptation algorithm comprising: providing a vehicle acceleration model based on measured variables and estimated variables; computing a vehicle acceleration upper boundary (α) based on a synthetic acceleration ({tilde over (â)}B) as:
where {tilde over (f)}B is a measured specific force in the body frame, {circumflex over (b)}accBB is the estimated accelerometer bias, ĈNBĝN represents the estimated gravity vector in the body frame, {circumflex over (φ)}j is the estimated roll angle, {circumflex over (θ)}k is the estimated pitch angle, σ{circumflex over (φ)} is the standard deviation of the estimated roll angle, σ{circumflex over (θ)} is the standard deviation of the estimated pitch angle, wherein the standard deviations of the roll angle and pitch angle estimates are provided by the adaptive statistical filter, and for Δσ{circumflex over (φ)}=Nσ{circumflex over (φ)} and Δσ{circumflex over (θ)}=Nσ{circumflex over (θ)}, the N represents a scale factor which governs the size of an interval in order to perform more conservative (larger/V) or less conservative (smaller/V) attitude error scanning; computing a steady-state standard deviation or (σsteadyState,GMacceleration) of a vehicle acceleration first-order GM process as:
σsteadyState,GMacceleration2=(ησsteadyState,accelerometer)2+α2
where η is an overbounding factor; computing a power spectral density of the vehicle acceleration GM process driving noise as:
where τacceleration is a time constant of the GM process; constructing a process noise covariance matrix by use of the power spectral density; and sending results of the process noise covariance matrix construction to the adaptive statistical filter.
Example 15 includes the method of any of Examples 10-14, wherein the IMU comprises a three-axis accelerometer and a three-axis gyroscope.
Example 16 includes a computer program product comprising a non-transitory computer readable medium having instructions stored thereon executable by a processer to perform a method for mitigating vehicle acceleration effects in an attitude and heading reference system (AHRS), the method comprising: obtaining inertial data from an inertial measurement unit that includes at least one accelerometer and at least one gyroscope; computing a heading based on heading-related measurements; determining models of sensors and other sources of errors; identifying vehicle acceleration and computing a vehicle acceleration upper boundary based on measured variables; and performing a computation of an adaptive statistical filter configured to estimate the attitude and heading while adaptively mitigating the impact of vehicle acceleration effects on the estimate by use of the vehicle acceleration upper boundary.
Example 17 includes the computer program product of Example 16, wherein the upper boundary computation is performed by a first algorithm that generates the vehicle acceleration mitigation data, the first algorithm comprising: providing a vehicle acceleration model based on measured variables and estimated variables; computing a vehicle acceleration upper boundary (α) based on a synthetic acceleration ({tilde over (â)}B) as:
α=∥{tilde over ({circumflex over (a)})}B∥≈∥{tilde over (f)}B+ĈNBĝN−{circumflex over (b)}accBB∥
where {tilde over (f)}B is a measured specific force signal output from the accelerometer, ĈNBĝN is an estimated gravity vector signal, and {circumflex over (b)}accB is an estimated accelerometer bias signal; computing a steady-state standard deviation (σsteadyState,GMacceleration) of a vehicle acceleration first-order GM process as:
σsteadyState,GMacceleration2=(ησsteadyState,accelerometer)2+α2
where η is an overbounding factor; computing a power spectral density of the vehicle acceleration GM process driving noise as:
where τacceleration is a time constant of the GM process; constructing a process noise covariance matrix by use of the power spectral density; and sending results of the process noise covariance matrix construction to the adaptive statistical filter.
Example 18 includes the computer program product of Example 16, wherein the upper boundary computation is performed by a second algorithm that generates the vehicle acceleration mitigation data, the second algorithm comprising: providing a vehicle acceleration model based on measured variables and estimated variables; computing a vehicle acceleration upper boundary (α) based on a synthetic acceleration ({tilde over (â)}B) as:
where {tilde over (f)}B is a measured specific force in the body frame, {circumflex over (b)}accBB is the estimated accelerometer bias, ĈNBĝN represents the estimated gravity vector in the body frame, {circumflex over (φ)}j is the estimated roll angle, {circumflex over (θ)}k is the estimated pitch angle, σ
σsteadyState,GMacceleration2=(ησsteadyState,accelerometer)2+α2
where η is an overbounding factor; computing a power spectral density of the vehicle acceleration GM process driving noise as:
where τacceleration is a time constant of the GM process; constructing a process noise covariance matrix by use of the power spectral density; and sending results of the process noise covariance matrix construction to the adaptive statistical filter.
The present invention may be embodied in other specific forms without departing from its essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. The scope of the invention is therefore indicated by the appended claims rather than by the foregoing description. All changes that come within the meaning and range of equivalency of the claims are to be embraced within their scope.
This invention was made with Government support under Government Contract Number 2014TA0303067 awarded by the Technological Agency of the Czech Republic. The Government has certain rights in the invention.