Methods for attitude and heading reference system to mitigate vehicle acceleration effects

Information

  • Patent Grant
  • 9709405
  • Patent Number
    9,709,405
  • Date Filed
    Monday, November 23, 2015
    9 years ago
  • Date Issued
    Tuesday, July 18, 2017
    7 years ago
Abstract
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.
Description
BACKGROUND

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.


SUMMARY

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.





DESCRIPTION OF THE DRAWINGS

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:



FIG. 1 is a block diagram of the software architecture for a pure inertial AHRS, according to an exemplary embodiment;



FIG. 2 is a flow diagram for a vehicle acceleration upper boundary computation method, according to a first method;



FIG. 3 is a flow diagram for a vehicle acceleration upper boundary computation method, according to a second method; and



FIG. 4 is a flow diagram for a method of operating a pure inertial AHRS with a vehicle acceleration mitigation algorithm, according to one embodiment.





DETAILED DESCRIPTION

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.


Sensor Errors


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 (ω)}IBBIBB+(bgyrB,constB+bgyrB,dynB)+wgyrB wgyrB˜N(0, σgyr2)  (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 σgyr2.


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:











δ







b
.


gyr





B

B


=



-

1

τ
gyr




δ






b

gyr





B

B


+

w
GMgyrB
B










w
GMgyrB
B



N


(

0
,

σ
GMgyrB
2


)







(
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=aB−gB+(baccB,constB+baccB,dynB)+waccB waccB˜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,constB+baccB,dynB), and (within an error state EKF implementation scheme) can be modeled such as GM process using the following equation:











δ







b
.

accB
B


=



-

1

τ
acc




δ






b
accB
B


+

w
GMaccB
B










w
GMaccB
B

~

N


(

0
,

σ
GMaccB
2


)







(
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.


Earth and Transport Rates


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:

ψNBBIBB−ωINB  (6)
ωINBIEBENB  (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:











δ







ω
.


GM
,
IN

N


=



-

1

τ

GM
,
IN





δ






ω

GM
,
IN

N


+

w

GM
,
IN

N










w

GM
,
IN

N

~

N


(

0
,

σ

GM
,
IN

2


)







(
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.


Vehicle Acceleration


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=fB+baccBB+waccB=aB−CNBgN+baccBB+waccB  (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:











δ







a
.

B


=



-

1

τ
acceleration




δ






a
B


+

w
GMacceleration
B










w
GMacceleration
B

~

N


(

0
,

σ
GMacceleration
2


)







(
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,GMacceleration22steadyState,acceleration2  (11)

with a lower boundary defined as:

σsteadyState,GMacceleration2=func1steadyState,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 (â)}B∥=∥{tilde over (f)}BNBĝ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)22  (15)

An upper boundary error analysis can be performed based on the following equation:

α=func(aB)=∥{tilde over (â)}B∥=∥{tilde over (f)}BNBĝN−{circumflex over (b)}accBB∥=
=∥aB+CNBN×]gN−δbaccBB+waccBNBwgravN∥  (16)

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:

α=∥custom characterB∥≈∥{tilde over (f)}BNBĝN−{circumflex over (b)}accBB∥  (17)
σsteadyState,GMacceleration2=(ησStationary,accelerometer)22  (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,GMacceleration22  (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.



FIG. 1 is a block diagram of the software architecture for a pure inertial AHRS 100, according to one embodiment. The AHRS 100 obtains inertial data from an inertial measurement unit (IMU) 110, which can include a 3-axis gyroscope 112 and a 3-axis accelerometer 114. In addition AHRS 100 obtains heading data from a heading source unit 116, such as a magnetometer. The AHRS 100 generally includes various functional modules as described 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 (ĈBN) is created as a transposition of the ĈNB matrix (i.e., ĈBN=(ĈNB)T). The result from mixer 129 is transformed by multiplying with the estimated direction cosine matrix ĈBN, which performs the transformation from the body frame to the navigation frame. An output signal (ĈBNB+{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 (ω)}INBNB{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 (6aB) 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 (ĈBN) 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.



FIG. 2 is a flow diagram for a vehicle acceleration adaptation algorithm according to a first embodiment, which can be employed by vehicle acceleration upper boundary computation module 125. At a time for filtration 210, algorithm 200 computes the upper boundary (alpha, α) based on the “synthetic acceleration” (custom characterB) (block 220) using equation (17).


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:












GMacceleration

2



=

2



σ

steadyState
·
GMacceleration

2


τ
acceleration








(
23
)








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.



FIG. 3 is a flow diagram for a vehicle acceleration adaptation algorithm 300 according to a second embodiment, which can be employed by vehicle acceleration upper boundary computation module 125. At a time for filtration 310, algorithm 300 computes the upper boundary (alpha) based on the “synthetic acceleration” (block 320) using the equations (19), (20), (21) and (22).


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:










[





ɛ
.

N






δ







b
.

gyrB
B







δ







a
.

B







δ







ω
.


GM
,
IN

N







δ







b
.

accB
B





]

=




[








-

[



ω
^

IN
N

×

]





+


C
^

B
N





0

3
×
3





I
3




0

3
×
3







0

3
×
3






-
1

/

τ
gyr





0

3
×
3





0

3
×
3





0

3
×
3







0

3
×
3





0

3
×
3






-
1

/

τ
acceleration





0

3
×
3





0

3
×
3







0

3
×
3





0

3
×
3





0

3
×
3






-
1

/

τ

GM
,
IN






0

3
×
3







0

3
×
3





0

3
×
3





0

3
×
3





0

3
×
3






-
1

/

τ
acc









]






[








ɛ
N






δ






b
gyrB
B







δ






a
B







δ






ω

GM
,
IN

N







δ






b
accB
B





]

+


[








I
3




-


C
^

B
N





0

3
×
3





0

3
×
3





0

3
×
3





0

3
×
3







0

3
×
3





0

3
×
3





I
3




0

3
×
3





0

3
×
3





0

3
×
3







0

3
×
3





0

3
×
3





0

3
×
3





I
3




0

3
×
3





0

3
×
3







0

3
×
3





0

3
×
3





0

3
×
3





0

3
×
3





I
3




0

3
×
3







0

3
×
3





0

3
×
3





0

3
×
3





0

3
×
3





0

3
×
3





I
3




]





[








w
IN
N






w
gyr
B






w
GMgyrB
B






w
GMacceleration
B






w

GM
,
IN

N






w
GMacc
B








]











(
24
)








where process noise covariance matrix (Q) is defined by:









Q
=

[





σ
IN
2

+



C
^

B
N



σ
gyr
2




C
^

N
B






0

3
×
3





0

3
×
3





0

3
×
3





0

3
×
3







0

3
×
3







GMgyrB

2




0

3
×
3





0

3
×
3





0

3
×
3







0

3
×
3





0

3
×
3







GMacceleration

2




0

3
×
3





0

3
×
3







0

3
×
3





0

3
×
3





0

3
×
3








GM
,
IN


2




0

3
×
3







0

3
×
3





0

3
×
3





0

3
×
3





0

3
×
3







GMaccB

2




]





(
25
)








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:










[








δ







f
^

N







δ






ψ
~





]

=



[




[


g
N

×

]




0

3
×
3






C
^

B
N




0

1
×
3





+


C
^

B
N







T


(

3
,
:

)





0

1
×
3





0

1
×
3





0

1
×
3





0

1
×
3





]

[








ɛ
N






δ






b

gyr





B

B







δ






a
B







σ






ω

GN
,
IN

N







δ






b
accB
B





]

+




[








-


C
^

B
N





-

I
3





0

3
×
3







0

1
×
3





0

1
×
3





-
1




]



[




w
sf
B






w
grav
N






w
ψ
N




]








(
26
)








where measurement covariance matrix









R
=

[







C
^

B
N



σ
acc
2




C
^

N
B


+



grav

2





0

3
×
1







0

1
×
3





σ
ψ
2




]





(
27
)








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:









T
=

[




-


cos





ψ


cos





θ






-


sin





ψ


cos





θ





0





sin





ψ





-
cos






ψ



0






-
tan






θ





cos





ψ





-
tan






θsin





ψ




-
1




]





(
28
)








FIG. 4 is a flow diagram for a method 400 operating a pure inertial AHRS with a vehicle acceleration mitigation algorithm, according to one embodiment. The method 400 begins with obtaining sensor measurements (block 410) from an IMU. A determination is then made whether initialization/alignment has been performed (block 412). If not, method 400 performs the initialization/alignment (block 414), and sensor measurements are again obtained at block 410. When the determination is made that the initialization/alignment has been performed at block 412, attitude correction and integration is performed (block 422). A vehicle acceleration adaptation algorithm is then performed (block 432), such as algorithm 200 of FIG. 2, or algorithm 300 of FIG. 3.


As shown in FIG. 4, a process noise covariance matrix construction is then performed (block 434), and the results are sent to the error-state extended Kalman Filter (block 436) for processing. The method 400 then determines whether to exit (block 440). If the determination is made not to exit at block 440, then method 400 returns to block 410 to obtain additional sensor measurements, and the above steps are repeated. When the determination to exit is made at block 440, method 400 comes to an end.


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 Embodiments


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 (custom characterB) as:

α=∥custom characterB∥=∥{tilde over (f)}BNBĝ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)22

where η is an overbounding factor; compute a power spectral density of the vehicle acceleration GM process driving noise as:









GMacceleration

2



=

2







σ

steadyState
,
GMacceleration

2


τ
acceleration









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 (custom characterB) as:






α
=


max
i



{






f
~

B

+


{



C
^

N
B



(
i
)


}




g
^

N


-


b
^

accB
B




;




C
^

N
B



(
i
)


=

f


(



ϕ
^

j

,


θ
^

k


)




}











ϕ
^

j



[




-
Δ







σ

ϕ
^



+

ϕ
^


;


ϕ
^

+

Δσ

ϕ
^




]


;


Δσ

ϕ
^


=

N






σ

ϕ
^













θ
^

k



[



-

Δσ

θ
^



+

θ
^


;


θ
^

+

Δσ

θ
^




]


;


Δσ

θ
^


=

N






σ

θ
^









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 (θ)} 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 (σsteadyState,GMacceleration) of a vehicle acceleration first-order GM process as:

σsteadyState,GMacceleration2=(ησsteadyState,accelerometer)22

where η is an overbounding factor; compute a power spectral density of the vehicle acceleration GM process driving noise as:









GMacceleration

2



=

2







σ

steadyState
,
GMacceleration

2


τ
acceleration









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:

α=∥custom characterB∥≈∥{tilde over (f)}BNBĝ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)22

where η is an overbounding factor; computing a power spectral density of the vehicle acceleration GM process driving noise as:









GMacceleration

2



=

2







σ

steadyState
,
GMacceleration

2


τ
acceleration









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:






α
=


max
i



{






f
~

B

+


{



C
^

N
B



(
i
)


}




g
^

N


-


b
^

accB
B




;




C
^

N
B



(
i
)


=

f


(



ϕ
^

j

,


θ
^

k


)




}











ϕ
^

j



[




-
Δ







σ

ϕ
^



+

ϕ
^


;


ϕ
^

+

Δσ

ϕ
^




]


;


Δσ

ϕ
^


=

N






σ

ϕ
^













θ
^

k



[



-

Δσ

θ
^



+

θ
^


;


θ
^

+

Δσ

θ
^




]


;


Δσ

θ
^


=

N






σ

θ
^









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; computing a steady-state standard deviation (σsteadyState,GMacceleration) of a vehicle acceleration first-order GM process as:

σsteadyState,GMacceleration2=(ησsteadyState,accelerometer)22

where η is an overbounding factor; computing a power spectral density of the vehicle acceleration GM process driving noise as:









GMacceleration

2



=

2







σ

steadyState
,
GMacceleration

2


τ
acceleration









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:

α=∥custom characterB∥≈∥{tilde over (f)}BNBĝ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)}accBB 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)22

where η is an overbounding factor; computing a power spectral density of the vehicle acceleration GM process driving noise as:









GMacceleration

2



=

2







σ

steadyState
,
GMacceleration

2


τ
acceleration









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 (custom characterB) as:






α
=


max
i



{






f
~

B

+


{



C
^

N
B



(
i
)


}




g
^

N


-


b
^

accB
B




;




C
^

N
B



(
i
)


=

f


(



ϕ
^

j

,


θ
^

k


)




}











ϕ
^

j



[




-
Δ







σ

ϕ
^



+

ϕ
^


;


ϕ
^

+

Δσ

ϕ
^




]


;


Δσ

ϕ
^


=

N






σ

ϕ
^













θ
^

k



[



-

Δσ

θ
^



+

θ
^


;


θ
^

+

Δσ

θ
^




]


;


Δσ

θ
^


=

N






σ

θ
^








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, 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; computing a steady-state standard deviation (σsteadyState,GMacceleration) of a vehicle acceleration first-order GM process as:

σsteadyState,GMacceleration2=(ησsteadyState,accelerometer)22

where η is an overbounding factor; computing a power spectral density of the vehicle acceleration GM process driving noise as:









GMacceleration

2



=

2







σ

steadyState
,
GMacceleration

2


τ
acceleration









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.

Claims
  • 1. An attitude and heading reference system (AHRS) for a vehicle, the AHRS comprising: an inertial measurement unit (IMU) onboard the vehicle and configured to generate inertial measurements comprising angular rate and acceleration measurements of the vehicle;a heading source onboard the vehicle and configured to generate heading measurements of the vehicle; anda processor including an adaptive statistical filter onboard the vehicle and in operative communication with the IMU and the heading source, wherein the processor utilizes the adaptive statistical filter to mitigate the impact of vehicle acceleration effects on attitude and heading during operation of the vehicle, wherein the processor is configured to: estimate an attitude and heading of the vehicle;model and estimate IMU errors and heading source errors; andmodel, adapt, and estimate vehicle acceleration using an adaptation algorithm configured to: detect acceleration of the vehicle;compute a synthetic acceleration;compute a vehicle acceleration upper boundary; andtransform the vehicle acceleration upper boundary onto parameters for the modeled vehicle acceleration; andmitigate the impact of vehicle acceleration effects on the attitude and heading estimate during operation of the vehicle using the vehicle acceleration upper boundary.
  • 2. The AHRS of claim 1, wherein the adaptive statistical filter comprises an algorithm providing a probabilistic description of estimated quantities.
  • 3. The AHRS of claim 2, wherein the adaptive statistical filter comprises an extended Kalman filter.
  • 4. The AHRS of claim 2, 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 (B) as: α=∥B∥≈∥{tilde over (f)}B+ĈNBĝN−{circumflex over (b)}accBB∥
  • 5. The AHRS of claim 2, 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:
  • 6. The AHRS of claim 1, wherein the IMU comprises a three-axis accelerometer and a three-axis gyroscope.
  • 7. The AHRS of claim 1, wherein the vehicle is an aircraft.
  • 8. The AHRS of claim 1, wherein the heading source comprises a magnetometer.
  • 9. 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 (IMU) onboard a vehicle, the inertial data comprising angular rate and acceleration measurements of the vehicle;obtaining heading measurements of the vehicle from a heading source onboard the vehicle; andperforming computations utilizing an adaptive statistical filter in a processor onboard the vehicle, the processor in operative communication with the IMU and the heading source, the computations comprising: estimating an attitude and heading of the vehicle;modeling and estimating IMU errors and heading source errors;modeling and estimating vehicle acceleration using an adaptation algorithm comprising: detecting acceleration of the vehicle;computing a synthetic acceleration;computing a vehicle acceleration upper boundary; andtransforming the vehicle acceleration upper boundary onto parameters for the modeled vehicle acceleration; andmitigating the impact of vehicle acceleration effects on the attitude and heading estimate during operation of the vehicle using the vehicle acceleration upper boundary.
  • 10. The method of claim 9, wherein the adaptive statistical filter comprises an algorithm providing a probabilistic description of estimated quantities.
  • 11. The method of claim 10, 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 (B) as: α=∥B∥≈∥{tilde over (f)}B+ĈNBĝN−{circumflex over (b)}accBB∥
  • 12. The method of claim 10, 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 (B) as:
  • 13. The method of claim 9, wherein the adaptive statistical filter comprises an extended Kalman filter.
  • 14. The method of claim 9, wherein the IMU comprises a three-axis accelerometer and a three-axis gyroscope.
  • 15. The method of claim 9, wherein the vehicle is an aircraft.
  • 16. The method of claim 9, wherein the heading source comprises a magnetometer.
  • 17. 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 (IMU) onboard a vehicle, the inertial data comprising angular rate and acceleration measurements of the vehicle;obtaining heading measurements of the vehicle from a heading source onboard the vehicle; andperforming computations utilizing an adaptive statistical filter in a processor onboard the vehicle, the processor in operative communication with the IMU and the heading source, the computations comprising: estimating an attitude and heading of the vehicle;modeling and estimating IMU errors and heading source errors;modeling and estimating vehicle acceleration using an adaptation algorithm comprising: detecting acceleration of the vehicle;computing a synthetic acceleration;computing a vehicle acceleration upper boundary; andtransforming the vehicle acceleration upper boundary onto parameters for the modeled vehicle acceleration; andmitigating the impact of vehicle acceleration effects on the attitude and heading estimate during operation of the vehicle using the vehicle acceleration upper boundary.
  • 18. The computer program product of claim 17, 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 (B) as: α=∥B∥≈∥{tilde over (f)}B+ĈNBĝN−{circumflex over (b)}accBB∥
  • 19. The computer program product of claim 17, 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 (B) as:
Government Interests

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.

US Referenced Citations (11)
Number Name Date Kind
6697736 Lin Feb 2004 B2
7239975 Coleman Jul 2007 B2
7526402 Tanenhaus et al. Apr 2009 B2
7548835 Lin Jun 2009 B2
7587277 Wells Sep 2009 B1
7643939 Zeng et al. Jan 2010 B2
20030149528 Lin Aug 2003 A1
20050240347 Yang Oct 2005 A1
20060265120 Coleman Nov 2006 A1
20080071480 Lin Mar 2008 A1
20160047675 Tanenhaus Feb 2016 A1
Non-Patent Literature Citations (5)
Entry
Kang et. al., “Improvement of Attitude Estimation Using Hidden Markov Model Classification”, American Institute of Aeronautics and Astronautics, 2010, pp. 1-9.
Leccadito, Matthew, “A Kalman Filter Based Attitude Heading Reference System Using a Low Cost Inertial Measurement Unit”, Aug. 2013, pp. 1-96, Publisher: Virginia Commonwealth University, Published in: Richmond, Virginia.
Marins et al., “An Extended Kalman Filter for Quaternion-Based Orientation Estimation Using MARG Sensors”, International Conference on Intelligent Robots and Systems, Oct. 29, 2001, pp. 2003-2011, Publisher: IEEE, Published in: Maui, Hawaii.
Sabatini, “Variable-State-Dimension Kalman-Based Filter for Orientation Determination Using Inertial and Magnetic Sensors”, Sensors, Jun. 25, 2012, pp. 8492-8506.
European Patent Office, “Extended European Search Report from EP Application No. 16190016.2 mailed Apr. 3, 2017”, From Foreign Counterpart of U.S. Appl. No. 14/949,437, Apr. 3, 2017, pp. 1-8, Published in: EP.
Related Publications (1)
Number Date Country
20170146347 A1 May 2017 US