The present invention relates to the field of navigation methods using a Kalman filter.
A Kalman filter is a recursive estimator of data included in a state vector and evolving over time.
Such a filter is commonly used in a context of navigation of a mobile carrier device in space. In this case, the state vector contains dynamic data of the carrier device (for example: position, speed, acceleration, etc.). This method works by successive iterations, each iteration taking as input the state vector produced by the previous iteration.
Each iteration comprises two fundamental steps: a prediction step (also called propagation step), and an update step (also called readjustment step in some applications).
The update step is based on observations provided by sensors.
In particular, it has been proposed to use a GPS receiver as such a sensor. In this case, the Kalman filter uses as observations data originating from positioning signals emitted by different satellites, then received by the GPS receiver.
A signal emitted by one of the satellites can be reflected on an obstacle before reaching the carrier device (as indicated by the dotted arrow represented in
However, such a multi-path phenomenon introduces errors into the data used as observations by the Kalman filter. These errors affect the accuracy of the update performed by the Kalman filter to switch from an a priori state vector to an a posteriori state vector.
One aim of the invention is to estimate the navigation state of a carrier device based on data emanating from satellites, in a way that is more robust to errors.
For this purpose, it is proposed, according to a first aspect, a method for navigating a carrier device using a Kalman filter estimating a navigation state of the carrier device, the method comprising steps of:
The method according to the first aspect can also comprise the following optional characteristics, taken alone or combined together when this is technically possible.
Preferably, the kinematic data associated with the satellite is a pseudo-distance between the carrier device and the satellite.
Preferably, the measured delta range is not used by the Kalman filter to update the navigation state of the carrier device.
Preferably, the method further comprises the steps of:
Preferably, the test on the second innovation associated with the satellite, or even the calculation of the second innovation, is implemented only on condition that the test result produced by the test on the delta range innovation indicates that the positioning signal did not follow a multi-path.
Preferably, the delta range innovation test comprises steps of:
Preferably, the generation of the estimated delta range comprises steps of:
Preferably, the Kalman filter implements a tight inertial/satellite hybridization.
There is also proposed, according to a second aspect, a computer program product comprising program code instructions for the execution of the steps of the method according to the first aspect, when this program is executed by a computer.
There is also proposed, according to a third aspect, a navigation system comprising:
Other characteristics, aims and advantages of the invention will emerge from the following description, which is purely illustrative and not limiting, and which must be read in relation to the appended drawings in which:
In all the figures, similar elements bear identical references.
Navigation System
Referring to
The carrier device is can be of any type: it can be a land vehicle, a ship or an aircraft.
The receiver 2 is adapted to receive and process positioning signals previously emitted by satellites 3 organized in a constellation (GPS, GALILEO, etc.). The receiver 2 is known per se.
The receiver 2 typically comprises at least one antenna for receiving the signals, and a chain for processing these signals operating in three phases: an acquisition phase, a code error tracking phase (DLL), and a phase error tracking phase (PLL). This processing chain comprises in particular a loop filter and uses a replica signal which is correlated to the received signal. The processing unit 4 is configured to implement a carrier device navigation method using a Kalman filter.
The processing unit 4 comprises for this purpose at least one processor configured to execute a program comprising code instructions for the implementation of the navigation method.
The navigation system further comprises an inertial measurement unit 6 configured to provide inertial data from the carrier device to the processing unit 4. The inertial measurement unit 6 is conventional: it comprises gyrometers and accelerometers (typically three of each type).
Discussion on the Form of the Signals Received and the Notions of Delta Range and Pseudo-Distance
A signal received by the receiver 2 is a C/A signal intended for civilians on the frequency band L1=1575.42 MHz. Each signal is encoded by a PRN code, and includes a sample of information. More particularly, these different components of the signal are characterized as follows.
The PRN code is defined by a code length of 1,023 bits (chips), at a frequency of 1.023 Mcps, and each bit modulated by a rectangular waveform. The duration of a PRN code is therefore 1 ms. This period is denoted TR.
The information bits are periodic and modulated by a rectangular waveform.
The form of the signal as emitted by a satellite is as follows:
s(t)=A*d(t)*c(t)*cos(2πfL1t)
With:
The corresponding signal received by the receiver 2 is as follows:
sR(t)=A*d(t−τ)*c(t−τ)*cos(2πfL1t+φ)
With:
In order to calculate the distance between the receiving antenna and the satellite 3, the delay must be estimated. This delay estimation is often done on the PRN code. However, this delay characterizes the path of the wave but is also affected by multiple errors such as ionospheric errors, tropospheric errors, multi-paths, measurement errors, clock drifts or even thermal noise. Thus, the distances resulting from the calculation of these delays are real distances added to multiple errors and are thus called “pseudo-distances”.
A pseudo-distance can be determined using the PRN component of the signal or using the phase of the signal. In the present disclosure:
The receiver 2 is thus configured to produce the pseudo-distance between the carrier device and the satellite 3 of one of the two types mentioned above, based on the signal it receives from this satellite 3, typically the code pseudo-distance.
Furthermore, in a manner known per se, a “delta range” between the carrier device and a satellite is a data closely linked to the Doppler frequency of a positioning signal received by the receiver 2 and emanating from the satellite 3 in question. In reality, a delta range is comparable to a phase pseudo-distance.
The following equations are indeed obtained:
ID(t)=∫t0tfd(u)du
DR(t)=ID(t)−ID(t−ΔT)
DR(t)=∫t-ΔTtfd(u)du
In the equations above, fd is the Doppler frequency of the signal received by the receiver 2, ID designates the known notion of “integrated Doppler”, and ΔT is a period of observation of the delta ranges. Moreover, to is the time of the beginning of the phase tracking.
There is also a relation between a delta range and the distance between the carrier device and the satellite 3 in question, since:
Where ρ(t)=|possat(t)−posant(t)| is the distance between the satellite 3 and the antenna at the time t and where λ is the wavelength of the signal received by the receiver 2.
General Principle of a Kalman Filter
Referring to
Each iteration comprises two fundamental steps: a prediction step (also called propagation step), and an update step (also called readjustment step in some applications).
The prediction step transforms a state vector X(k/k) into an a priori state vector X(k+1/k) by using a transition model which models the movement of the carrier device between the time k and the time k+1.
Also associated with the state vector X(k/k) is a covariance matrix P(k/k). This covariance matrix can be seen as representative of an uncertainty on the estimation constituted by the state vector X(k/k). The prediction step also transforms the covariance matrix P(k/k) into a covariance matrix P(k+1/k), based on the transition model.
The update step transforms the a priori state vector X(k+1/k) into an a posteriori state vector X(k+1/k+1) based on external measurements which are called “observations”, and by combining these observations with an observation model that models the noise to which these observations are subject. During the update step, the covariance matrix P(k+1/k) is transformed into a covariance matrix P(k+1/k). The observations provide additional information, thus improving the estimation constituted by the a priori data X(k+1/k) and P(k+1/k). This is how the a posteriori state X(k+1/k+1) can also be more trusted. This can be seen graphically by a “decrease of P” between the a priori state and the a posteriori state.
The temporal behavior of the actual state vector and its observation is modeled by the following linear equations:
With:
In this case then, the a priori and a posteriori states described previously are obtained thanks to the following relations:
Prediction:
{circumflex over (X)}k+1|k=Fk·{circumflex over (X)}k|k+Gk·Uk
Pk+1|k=Fk·Pk|k·FkT+Qk
Kalman Gain:
Kk+1=Pk+1|k·Hk+1T*(Hk+1·Pk+1|k·Hk+1T+Rk+1)−1
Updates:
{circumflex over (X)}k+1|k+1={circumflex over (X)}k+1|k+Kk+1*(Yk+1−Hk+1·{circumflex over (X)}k+1|k)
Pk+1|k+1=Pk+1|k−Kk+1*(Hk+1·Pk+1|k)
With: {circumflex over (X)}k the estimated state vector.
Most of the time, the system cannot be modeled by linear equations. In this case then, the traditional Kalman filter cannot be applied. An Extended Kalman Filter (or EKF) is then used. In this case, the Extended Kalman Filter method proposes to bring the system back to the case of the traditional Kalman filter by linearizing and discretizing the equations near the estimated solution.
Configuration of the Kalman Filter Used in the Navigation System
The navigation state estimated by the Kalman filter used by the system 1 is a vector calculated at times tK (navigation filter processing times) comprising the following data:
Furthermore, the Kalman filter of the system 1 uses as observations at a time tK at least two different data for each satellite of the constellation: a “delta range” between the carrier device and the satellite 3, and another kinematic data associated with the satellite 3. These observation data are often dated from a time different from tK. The observation dating time is denoted tr. It is the radio-navigation data receiving time.
In the following, one embodiment is described in more detail in which this other kinematic data is a pseudo-distance between the carrier device and the satellite 3 in question.
The data processed as observations by a conventional Kalman filter are used to update the a priori state vector that is to say to produce an a posteriori state vector taking into account such observations.
Unconventionally, a pseudo-distance between the carrier device and a satellite, having been measured by the receiver 2, is not always used by the Kalman filter of the system 1 to update the a priori state vector. It will be seen that this use for the update is conditional on the result of an innovation test involving a delta range between the carrier device and the same satellite, also measured by the receiver 2.
Another (optional) specificity of the Kalman filter used by the system 1 is that the delta range measured by the receiver 2 between the carrier device and a given satellite is not used to implement such an update. The role of the delta range is then limited to conditioning the use of the pseudo-distance in the update.
The Kalman filter is further configured to implement a tight satellite/inertial coupling. In other words, the Kalman filter uses not only data emanating from the receiver 2, and particularly pseudo-distances, but also inertial data provided by the inertial measurement unit 6. These inertial data mainly allow maintaining the navigation which will be readjusted by the observations.
Navigation Method Implemented Using the Kalman Filter
Referring to
The processing unit 4 generates an estimated delta range between the carrier device and the satellite 3 at the time tK, from the content of the a priori state vector associated with the time tK (step 102). Without loss of generality, it is assumed in the following that the navigation filter is synchronous with the radio-navigation data. The navigation dating times tK are therefore considered equal to the observation data receiving times tr.
Considering the estimated position of the satellite at the signal emission time {circumflex over (r)}sat(te), the estimated delta range is calculated as follows:
Δt is here the duration between two Kalman cycles (two readjustments).
It is noted here that certain terms intervening in the calculation of the estimated delta range relate to past data associated with the time spent tr−ΔT.
To obtain these past data, the state vector associated with the time tr is the subject of an inverse prediction by the Kalman filter, so as to obtain a state vector in the past at the time tr−ΔT.
Using the equations of a Kalman filter, the prediction equation is written:
{circumflex over (X)}k+1|k=Φk·{circumflex over (X)}k|k
The matrix Φk is noted the transition matrix. Thus, in order to switch from a state {circumflex over (X)}k+1|k to a state {circumflex over (X)}k|k, the inverse prediction is performed by a multiplication by the inverse transition matrix Φk−1:
{circumflex over (X)}k|k=Φk−1·{circumflex over (X)}k+1|k
The processing unit 4 also obtains a delta range measured between the carrier device and the satellite 3 at the time t (step 104). The measured delta range is provided by the receiver 2, which determines this measurement, according to a known method, based on the positioning signal received by the receiver 2 and emanating from the satellite in question. The receiver 2 is based in particular on the phase of the received signal to determine this measured delta range.
The processing unit 4 also obtains during step 104 a pseudo-distance measured between the carrier device and the satellite 3 at the time tr. The measured pseudo-distance is provided by the receiver 2, which determines this measurement, according to a known method, based on the positioning signal received by the receiver 2 and emanating from the satellite in question.
At this stage, the a priori state vector has not yet been updated by the Kalman filter, and two observations have been obtained for a given satellite and for a time tr: a delta range between the carrier device and the satellite 3, and a pseudo-distance between the carrier device and the satellite 3.
Before performing this update, the following steps are implemented by the processing unit 4. The components of the observation matrix H are determined by the processing unit 4 by calculating the Jacobian matrix of the following term:
Zpinno(tr)=DRmes(tr)−DRest(tr)
A delta range innovation associated with the satellite 3 is then calculated by the processing unit 4 (step 106). This innovation is calculated as follows, using the a priori state vector dX, the observation matrix H and the previous term Zpinno(tr):
Inno=Zpinno(tr)−H(tr)*dX(tr)
Covinno=H*P*HT+R
A covariance of the delta range innovation associated with the same satellite as the “Inno” data is also calculated by the processing unit 4. The covariance of the innovation is calculated as follows:
Covinno=H*P*HT+R
with H being the observation matrix, P the state covariance matrix and R the observation error covariance.
The processing unit 4 implements a test on the “Inno” delta range innovation, in order to find out whether the signal received from the associated satellite has undergone a multi-path (step 108).
The test on the innovation 108 comprises the calculation by the processing unit 4 of a term being or dependent on a deviation between the “Inno” delta range innovation, and the associated covariance of the delta range innovation Covinno.
The term obtained is compared to a predefined threshold.
The processing unit 4 generates during the test step 108 a test result indicating whether the received satellite signal from which the measured delta range originates has or has not undergone a multi-path.
If the term is above the predefined threshold, this means that the innovation is not consistent with the associated covariance. The test result generated by the processing unit 4 is then positive, in the sense that this test result indicates that the received signal from which the measured delta range originates has undergone a multi-path.
In this first case, the pseudo-distance measured for the same satellite is not used as an observation by the Kalman filter to update the navigation state of the carrier device, during the update step.
If, on the contrary, the term is not greater than the predefined threshold, it is considered that the innovation is consistent with the associated covariance. The test result generated by the processing unit is then negative, in the sense that this test result indicates that the received signal from which the measured delta range originates has not undergone a multi-path.
In this second case, the processing unit calculates a second innovation associated with the satellite, relating to the measured pseudo-distance (step 110).
The processing unit then implements a test on the second innovation (step 112), following the same logic as the on described for the test on the delta range innovation (except that work is made here on pseudo-distances). This test on the second innovation produces a second test result indicating a level of likelihood of the measured pseudo-distance. This test forms part of the known operation of the Kalman filtering techniques.
If the second result indicates that the pseudo-distance is likely, then the measured pseudo-distance is used as an observation by the Kalman filter to update the navigation state of the carrier device, during the update step (step 114). Otherwise, the pseudo-distance is not used in this way (as in the case where the test result on the delta range innovation indicates a multi-path).
Ultimately, two conditions must be satisfied for a pseudo-distance measured for a satellite 3 to be used by the Kalman filter as an observation to update an a priori state vector: the first condition results from the test 108 on the delta range innovation achieved for the satellite 3, and the second condition results from the test 112 on the innovation relating to the pseudo-distance itself associated with the same satellite 3.
It is moreover advantageous to implement the test 112 on the innovation relating to the pseudo-distance only if the test result on the delta range innovation proves to be negative, for the purpose of computational savings.
It should be noted that steps 100 to 114 are repeated for signals emanating from different satellites. For example, let's consider the situation where N satellites are tracked. N pseudo-distances and N delta ranges are measured, N delta range innovations are calculated, each being tested.
The method described above may be subject to other variants. The pseudo-distance between the carrier device and a satellite, whose use is conditioned during the update step, can be replaced by another kinematic data associated with the satellite.
Number | Date | Country | Kind |
---|---|---|---|
2001716 | Feb 2020 | FR | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/FR2021/050301 | 2/19/2021 | WO |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2021/165626 | 8/26/2021 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
20080082266 | Bye | Apr 2008 | A1 |
20110084878 | Riley et al. | Apr 2011 | A1 |
20120265440 | Morgan | Oct 2012 | A1 |
20180095159 | Barrau | Apr 2018 | A1 |
Number | Date | Country |
---|---|---|
110226108 | Sep 2019 | CN |
3 107 588 | Jan 2022 | FR |
Entry |
---|
French Search Report for French Application No. 2001716, dated Nov. 3, 2020. |
International Search Report for International Application No. PCT/FR2021/050301, dated May 12, 2021. |
Manickam et al., “Using Tactical and MEMS Grade INS to Protect Against GNSS Spoofing in Automotive Applications”, Proceedings of the 29th International Technical Meeting of the Ion Satellite Division, ION GNSS+ 2016 Portal Oregon Sep. 12-16, 2016 pp. 2991-3001. |
Yeh et al., “Using Delta Range for Fault Detection/Exclusion on GPS Positioning”, Asian Journal of Control, vol. 14. No. 4, Jul. 2012 (published online Oct. 28, 2011), pp. 936-946. |
Zhu et al., “Demonstration of Integrity Protection for Multi-Constellation Carrier Phase Solution using RANSAC-based FDE”, Proceedings of the 2019 International Technical Meeting, ION ITM 2019, Reston, Virginia, Jan. 28-31, 2019, pp. 744-761. |
Number | Date | Country | |
---|---|---|---|
20230094700 A1 | Mar 2023 | US |