The present application claims priority to French Application No. 13 51423 which has a filing date of Feb. 20, 2013.
This invention relates in general to the field of satellite positioning systems such as the GPS (Global Positioning System) system and the Galileo system. It is more particularly applicable to the satellite signal acquisition phase using a GPS receiver.
Conventionally, a GPS receiver determines its position by measuring the time-of-flight of signals received from a plurality of satellites (in principle at least four). The receiver uses a so-called C/A (Coarse Acquisition) channel on which the satellite emits a spectrally spread navigation message using a pseudo random sequence (called the spreading sequence) with good auto-correlation and inter-correlation properties (using PRN sequences used by other satellites), to estimate the time-of-flight of a GPS signal emitted by a satellite.
The good self-correlation properties of spreading sequences optimise the probability of detecting a signal in the presence of noise, while the good inter-correlation properties of these sequences enable the different satellites to share a single transmission band using a code distribution multiple access (CDMA).
The first task of a GPS receiver is to detect visible satellites. To achieve this, the receiver attempts to detect the spreading code of the satellite for which it wants to test the presence, and possibly to synchronise itself relative to this signal. This first task is called the GPS signal acquisition step.
Many methods of acquisition of the GPS signal are known in the state of art, they form part of the problem of multi-user detection in CDMA systems. In particular, the articles by A. Polydoros et al. entitled “A unified approach to serial search spread spectrum code acquisition” Part I: A general theory & Part II: a matched filter receiver, published in IEEE Trans. on. Comm., Vol. 32, No. 5, 1984 and the article by F. Principe et al. entitled “Rapid acquisition of Gold codes and related sequences using iterative message passing on redundant graphical models” published in Proc. MILCOM '06, 2006.
These acquisition methods are usually based on a correlation of the signal received by the receiver with the spreading code of the satellite to be tested.
However, the acquisition method described in the article by F. Principe mentioned above cannot provide a sufficiently low missed detection probability and false alarm probability at a low signal-to-noise ratio (SNR). The missed detection probability is the probability of not synchronising with a satellite spread sequence when the spread sequence is actually received by the receiver. The false alarm probability is the probability of synchronising with a spreading sequence that is not received by the receiver. At low signal-to-noise ratios, the false alarm probability is the probability of detecting a spread sequence in noise.
Furthermore, acquisition methods by correlation require that the different possible spreading codes should be tested one by one, which requires a long acquisition time in a series configuration, and high complexity in a parallel configuration.
The article by K. M. Chugg entitled “A new approach to rapid PN code acquisition using iterative message passing techniques” published in IEEE Journal on Selected Areas in Communications, Vol. 21, No. 5, May 2005, pp. 884-897 describes a method of acquiring a spread signal by means of a maximum length sequence using an iterative message passing decoding technique.
The purpose of this invention is to disclose a method of acquiring a satellite signal, particularly a GPS signal, capable of detecting a spreading sequence with a low missed detection probability, even at a low signal-to-noise ratio.
One other purpose of this invention is to disclose a method of acquiring a satellite signal with a low false alarm probability, even at a low signal-to-noise ratio.
Another purpose of this invention is to disclose a method of acquiring a satellite signal with a better compromise between acquisition time and complexity than in prior art.
This invention is defined by a method of acquiring a satellite signal by a receiver, said signal being spread by a Gold sequence at a chip frequency, said Gold sequence being obtained as the sum of a first M-sequence generated using a first shift register and a second M-sequence generated using a second shift register, said second M-sequence identifying one satellite among a plurality of satellites, said method comprising the following steps:
(a) the signal received in base band is sampled at the chip frequency starting from a determined time to provide a sequence of first samples;
(b) the sequence of said first samples is multiplied chip by chip by said first M-sequence to provide a sequence of second samples;
(c) the sequence of second samples is decoded using an iterative message passing decoding to supply an estimate of the content of the second shift register at said determined time;
(d) the content of the second shift register thus estimated is compared with a plurality of possible contents of the second shift register for the different satellites of said plurality, and if the comparison is successful for an identified satellite, the receiver is synchronised with said identified satellite at the determined time.
If the content of the second shift register thus estimated does not correspond to any of said possible contents, the determined time is incremented by one chip and steps (a) to (d) are iterated.
According to a first embodiment, the content of the second shift register is advantageously estimated by making hard decisions about the first r decoded value supplied by iterative message passing decoding, where r is the number of positions in the first/second shift register.
Iterative message passing decoding in step (c) preferably uses the parity matrix:
in which gr=1 and g0, . . . , gr-1 are the coefficients of the polynomial generating the second M-sequence.
The second M-sequence is advantageously obtained by summating the contents in two positions αi, βi of the second shift register, where i is an index identifying the satellite among said plurality of satellites, the possible contents of the second shift register for the different satellites being given by vectors:
Aiinit=(Gyα
where Ayinit is a vector giving the content of the second shift register at a reference time, and Gy is the state change matrix of the second shift register.
According to a second embodiment, the sequence of second samples is permuted using a permutation relation φ(k)=dk+h mod(N) where k is the rank of the sample, d is a decimation factor, h is an offset value and N is the length of the first M-sequence, switching being done before step (c);
step (c) provides a sequence of decoded values;
the sequence of decoded values is permuted using the permutation relation inverse to said permutation relation to provide a sequence of switched values;
the content of the second shift register is estimated by taking hard decisions on the first r values of the sequence of permuted values, where r is the number of positions in the first/second shift register.
Advantageously, the iterative message passing decoding in step (c) uses the parity matrix:
in which gr=1 and g0, . . . , gr-1 are the coefficients of the polynomial generating the first M-sequence.
In one variant of the first and second embodiments, it is checked that the receiver is properly synchronised with said identified satellite by:
(e) multiplying the sequence of said first samples, chip by chip, by the second M-sequence associated with said identified satellite to provide a sequence of third samples;
(f) decoding the sequence of third samples using an iterative message passing decoding to provide an estimate of the content of the first shift register at said determined time.
If the content of the first shift register thus estimated does not correspond to the initial content of the first register, the determined time is incremented by one chip and steps (a) to (f) are iterated.
Preferably, the content of the first shift register is estimated by taking hard decisions on the first r decoded values provided by the iterative message passing decoding, where r is the number of positions in the first/second shift register.
Advantageously, the iterative message passing decoding in step (f) uses the parity matrix
in which gr=1 and g0, . . . , gr-1 are the coefficients of the polynomial generating the first M-sequence.
According to one advantageous embodiment, the iterative message passing decoding in step (c) and the iterative message passing decoding in step (f) both use a “Min-Sum” type algorithm.
Other features and advantages of the invention will become clear after reading the preferred embodiments of the invention with reference to the appended figures among which:
We will start by summarising how the C/A coarse synchronisation signal is emitted by a satellite in a positioning system such as the GPS system or the Galileo system.
The signal emitted by a satellite on the C/A channel can be expressed in the form:
where i=1, . . . , 32 is the index of the satellite, d(l) is the lth BPSK symbol in the navigation message, k is a time index, ci(k) is the kth chip of the spread code associated with the satellite i, N is the length of the spread code (in practice N=1023 for the GPS system) and L is the number of BPSK symbols in the navigation message. For the GPS system, each d(l) symbol lasts for 20 ms, namely 20 repetition periods of the spreading code, the chip frequency (or chip rate) being 1.023 MHz.
The satellite signal received by the receiver on the C/A channel can then be written as follows, in base band:
where I is the maximum number of satellites (I=32 in the GPS system), ρi is the attenuation coefficient of the signal on the link between the satellite i and the receiver, assumed to be constant during the time of the message, ΔFi is the shift of the carrier frequency (mainly due to the Doppler shift) and θi is the phase of the signal from the satellite i (assumed to be constant), and finally w(k) is a noise sample assumed to be additive white Gaussian noise (AWGN) with variance σ2.
The spreading sequences ci of the different satellites i=1, . . . , I are Gold sequences, each Gold sequence being constructed from a sum of two maximum length sequences also called M-sequences. It will be remembered that an M-sequence is a periodic series of values produced by a linear feedback shift register (LFSR) that explores all values that can be produced by the shift register. Any linear combination of two M-sequences with the same degree r (in other words generated by generating polynomials with the same degree) does not necessarily give a Gold sequence; a pair of M-sequences for which the sum gives a Gold sequence is called a pair of preferred sequences.
Each spreading sequences ci in the C/A channel is constructed from a pair of preferred M-sequences, x and y. More precisely:
ci(k)=x(k)+y(k−τi) (3)
where τi is a delay expressed as a number of chip periods specific to satellite i.
The x and y M-sequences are generated from the generating polynomials:
gx(D)=D10+D3+1
gy(D)=D10+D9+D8+D3+D2+1 (4)
respectively.
It will be remembered that an LFSR sequence generated by a generating polynomial
with degree r is obtained from a shift register with r memory positions (referred to more simply as positions in the following) and r connectors, looped back on itself as shown in
An M-sequence is defined uniquely by its generating polynomial, the content of the shift register at the initial time giving its original value. An M-sequence generated by a generating polynomial (primitive) with degree r is periodic and its length is N=2r−1.
The M-sequences x and y are generated by initialising the positions of their corresponding shift registers to 1, namely x(0)=x(1)= . . . =x(9)=1 and y(0)=y(1)= . . . =y(9)=1.
The delayed sequence yi defined by yi(k)=y(k−τi) is advantageously obtained using the “add and shift” property of M-sequences. More precisely, the delays τi are chosen such that the sequence yi can be generated from the sum of the contents in two positions αi and βi of the shift register generating the sequence y namely:
yi(k)=aα
where aα
The generator 310 of the M-sequence x can be seen in the top part, and the generator 320 of the M-sequence y can be seen in the bottom part. The two generators 310 and 320 use shift registers looped back on themselves. For each generator, the connectors of the shift register correspond to the monomials of the corresponding generating polynomial. The phase selector 330 selectively summates some positions of the shift register of 320. These positions αi and βi are chosen using the table in
The sum of M-sequences X and yi in 350 gives the Gold sequence ci, in other words the spreading sequence for satellite i.
The first step is to consider synchronisation of the receiver relative to a GPS signal from a satellite i.
The receiver samples the received satellite signal at the chip frequency, after demodulation to base band.
At each time q, the receiver forms a vector in 410, composed of M successive signal samples thus received, namely rq(k)=r(k+q), k=0, . . . , M−1, where M=N+1 is the period of the M-sequence (M=1024 in the GPS system).
The receiver then tests whether or not it is well synchronised with M-sequence X. To achieve this, it assumes that it is synchronised with this sequence and makes a chip by chip multiplication of the received signal with M-sequence X, in step 420, namely:
{tilde over (r)}q(k)=rq(k)X(k) (6)
where X(k)=1−2x(k) is the bipolar representation (BPSK) of M-sequence X.
This operation eliminates M-sequence x from the received signal:
{tilde over (r)}q(k)=ρiYi(k)+{tilde over (w)}(k) (7)
where Yi(k)=1−2 yi(k) is the bipolar representation of M-sequence yi and {tilde over (w)}(k) contains all noise sources.
It is deduced from expression (7) that vector {tilde over (r)}q(k), k=0, . . . , M−1 is a noisy observation of M consecutive chips in sequence. yi
An iterative message passing decoding is done in step 430 (also called a belief propagation decoding) of word {tilde over (r)}q(k) k=0, . . . , M−1. The operation that associates the content (at time q) of the shift register of an M-sequence generator with the M-sequence itself may be considered as being cyclic linear coding with efficiency r/2′−1 (the size of the register word is r while the size of the M-sequence is N=2′−1).
In general, if an M-sequence z defined by a generating polynomial
is considered, there is the parity constraint:
in which gr=1 has been defined. The parity matrix of the code is the matrix with size (M−r)×M:
Decoding is then done in the same way as for message passing decoding between variable nodes (variables yi(k)) and constraint nodes (parity constraints given by the rows in the parity matrix H where the coefficients are the coefficients of the polynomial gy(D)).
A description of the message passing decoding method has been given in the article by F. R. Kschichang et al. entitled “Factor graphs and the Sum-Product algorithm” published in IEEE Trans. on Information Theory, Vol. 47, No. 2, February 2001. A simpler but sub-optimal version of this algorithm was proposed by V. Savin in the article entitled “Self-corrected Min-Sum decoding of LDPC codes” published in Proc. of Intl Symposium on Information Theory (ISIT 2008), Toronto, July 2008.
Regardless of what version is used, decoding of the word {tilde over (r)}q(k), k=0, . . . , M−1 (or only part of this word because it has very high redundancy) provides a vector {tilde over (Y)}iq(k), k=0, . . . , M−r−1 (the index q has been added to emphasise that this vector was obtained assuming that the sequence was synchronised at time q), from which only the first r values giving the content of the register at the initial time q, as a result of hard decisions, are used. The values {tilde over (Y)}iq(k) are logarithmic likelihood ratios (LLR) and therefore the content of the shift register at time q is given as follows:
Aiq(k)=sgn({tilde over (Y)}iq),k=0, . . . ,r−1 (10)
where sgn(•) is the sign function associating the value +1 to all positive values and the value −1 to all negative values.
The vector Aiq(k), k=0, . . . , r−1 is compared with the I=32 possible initialisation words of the shift register of sequence yi, denoted Aiinit, i=1, . . . , I, in step 440.
These initialisation words are deduced from the initialisation word Ayinit=(1 . . . 1)T of the shift register of sequence y. It should be remembered that according to expression (5):
yi(k)=y(k+αi)+y(k+βi) (11)
which can be translated into matrix form as:
Ai=(Gyα
where Ai and Ay are the word contained in the shift register of sequence yi and the word contained in the shift register of sequence y respectively, Gy is the state transposition matrix, in other words the matrix relating content vectors of the shift register at successive times, namely:
Ay(k+1)=GyAy(k) (13)
The state transposition matrix Gy is given as follows:
where the coefficients g0y, . . . , gr-1y are the coefficients of the polynomial generating the sequence y. If the relation (12) is applied at the time of initialisation, we obtain particularly:
Aiinit=(Gyα
The vectors Aiinit can then be calculated in advance to avoid slowing the acquisition.
If there is an index i0 such that:
Aiq=Ai
it will be considered that the receiver is synchronised with the GPS signal of satellite i0 and the acquisition method terminates at 490. By default, the acquisition method continues by incrementing q in 445, in other words starting from the next sample and returning to step 410.
Steps 510 to 545 are identical to steps 420 to 445 and therefore they will not be described.
The variant in
This verification phase is based on the following principle: if the detected sequence yi
More precisely, the received signal rq(k)=r(k+q), k=0, . . . , M−1 is multiplied in step 550 with the Yi
{hacek over (r)}q(k)=rq(k)Yi
This operation eliminates sequence yi
{hacek over (r)}q(k)=X(k)+{hacek over (w)}(k) (18)
where X(k)=1−2x(k), k=0, . . . , M−1 is the bipolar representation of M-sequence and {hacek over (w)}(k) contains all noise sources.
It will be understood that step 550 is “symmetric” to step 520.
Since the vector {hacek over (r)}q(k), k=0, . . . , M−1 is a noisy observation of M consecutive chips of M-sequence X, iterative decoding is done in step 560 using a message passing algorithm of the “Sum-Product” or “Min-Sum” type. For example, if a Min-Sum algorithm was used for decoding {tilde over (r)}q(k), k=0, . . . , M−1 in step 530, the algorithm type will advantageously be used to decode {hacek over (r)}q(k), k=0, . . . , M−1. The constraints are given by the rows in the matrix H in which the coefficients are those of the generating polynomial gx(D).
Regardless of the type of algorithm, decoding of the word {hacek over (r)}q(k), k=0, . . . , M−1 (or only part of this word because it has very high redundancy) provides a vector {hacek over (X)}q(k), k=0, . . . , M−r−1 (the index q was added to emphasise that this vector was obtained assuming that the sequence was synchronised at time q) from which only the first r values giving the content of the register at the initial time q by means of hard decisions, are used. The values {hacek over (X)}q(k) are logarithmic likelihood ratios (LLR) and therefore the content of the shift register at time q is given as follows:
Aq(k)=sgn({hacek over (X)}q(k)),k=0, . . . ,r−1 (19)
In step 570, it is verified if the vector Aq is equal to the initialisation vector of M-sequence x, in other words if Aq(k)=1, k=0, . . . , r−1.
If this is the case, in other words if the verification is positive, it is concluded that the receiver is well synchronised with the GPS signal from satellite i0. The acquisition method then terminates at 590.
On the other hand, if this is not the case, synchronisation with the GPS signal from satellite i0 is invalidated. The acquisition method continues by incrementing q at 575, in other words from the next sample and returning to step 510.
The false alarm probability for this variant is equal to Pfa2 where Pfa is the false alarm probability obtained with the acquisition method (without verification) in
This embodiment takes advantage of the fact that two M-sequences on the same Galois body GF(2r) are related by a decimation relation. Thus, if u and v are two M-sequences generated by primitive polynomials with degree r, we obtain:
u(k)=v(dk+h) (20)
where d is a decimation factor and h is a constant dependent on the initial content of the registers of M-sequences u and v.
For a preferred pair of sequences x, y, the decimation factor will be equal to d=2e+1 with the condition gcd(2e+1, 2r−1)=1.
For generating polynomials gx and gy given in (4), r=10, it can then be demonstrated that e=6 and hence d=65 and considering the register initialisation words for sequences x, y:
y(k)=x(65k+27300) (21)
If we define a sequence xi by xi(k)=x(k−65τi), we obtain:
yi(k)=xi(65k+27300) (22)
The relation between sequence yi and sequence xi is independent of the index i, in other words it remains valid regardless of which satellite is used.
Once again, we will start by considering the synchronisation of the receiver relative to a satellite signal.
The receiver samples the received signal at the chip frequency after demodulation in base band and forms the vector rq(k)=r(k+q) k=0, . . . , M−1 at each time q in 610, composed of M successive samples of the received signal.
A chip by chip multiplication of the received signal is made in step 620 with M-sequence x to obtain the reprocessed samples {tilde over (r)}q(k), k=0, . . . , M−1 as defined in relation (6).
The M reprocessed samples are switched in step 630 using the following switching relation:
φ(k)=dk+h mod(N) (23)
In other words for the generating polynomials gx and gy given in (4):
φ(k)=65k+27300 mod(1023) (23′)
The sequence vq obtained by switching these samples is formed:
vq(φ(k))={tilde over (r)}q(k),k=0, . . . ,M−1 (24)
It will be noted that this switching is independent of which satellite i is being considered.
According to one variant not shown, LM rather than M samples rq (k) are obtained in 610, and after chip by chip multiplication in 620, the sequence vq is obtained by coherent summation on L blocks using sequence x (it will be remembered that this sequence is repeated at intervals M):
In all cases, iterative message passing decoding of word vq(k), k=0, . . . , M−1 is then performed in step 640. This word actually represents a noisy observation of the xi(k), k=0, . . . , M−1 sequence. Iterative decoding is done using the parity matrix H (according to expression (9), in which the coefficients g0, . . . , gr are the coefficients of the polynomial gx(D)).
A sequence of logarithmic likelihood ratios (LLRs) denoted {hacek over (X)}iq(k), k=0, . . . , M−1 is obtained at the end of iterative decoding.
Inverse switching of the samples {hacek over (X)}iq(k), k=0, . . . , M−1, is done in step 650 to obtain the logarithmic likelihood ratios:
{hacek over (Y)}iq(k)={hacek over (X)}iq(φ(k)) (25)
The content of the shift register of sequence yi at time q, is obtained in step 660, namely:
{hacek over (A)}iq(k)=sgn({hacek over (Y)}iq(k)),k=0, . . . ,r−1 (26)
and the vector {hacek over (A)}iq of components {hacek over (A)}iq(k), k=0, . . . , r−1, is compared with the initialisation vectors of the different sequences yi, i=1, . . . , I, in other words with the vectors Aiinit previously calculated using the expression (15).
If there is an index i0 in 670 such that:
{hacek over (A)}iq=Ai
it is considered that the receiver is synchronised with the GPS signal from satellite i0 and the acquisition method terminates in 690. Otherwise, the acquisition method continues by incrementing q at 675, in other words starting from the next sample and returning to step 610.
This second embodiment can also be broken down according to a variant shown in
As already mentioned in the description of the first embodiment, this verification phase very much reduces the false alarm probability and is particularly advantageous when iterative decoding of vq(k), k=0, . . . , M−1 is done according to the “Min-Sum” algorithm.
Steps 710 to 775 are identical to steps 610 to 675 and therefore they will not be described here. Only the verification phase will be described:
In step 780, the received signal rq(k)=r(k+q), k=0, . . . , M−1 is multiplied by the sequence Yi
Iterative decoding is done in step 783 using a message passing algorithm of the “Sum-Product” or “Min-Sum type. For example, if a Min-Sum algorithm was used for decoding of vq(k), k=0, . . . , M−1 in step 740, the algorithm type will advantageously be used for decoding of {hacek over (r)}q(k), k=0, . . . , M−1. The constraints are given by the rows in the matrix H in which the coefficients in this case are the coefficients of the generating polynomial gx(D).
Whatever algorithm type is used, decoding provides a vector {hacek over (X)}q(k) k=0, . . . , M−1, from which only the first r components giving the content of the register at the initial time q by means of hard decisions, are used. Let Aq be the vector composed of the first r components in question.
In step 785, it will be verified if the vector Aq is equal to the initialisation vector of M-sequence x, in other words if Aq(k)=1, k=0, . . . , r−1.
If it is, in other words if the verification is positive, it will be concluded that the receiver is well synchronised with the GPS signal from satellite i0. The acquisition method then terminates at 790.
On the other hand if this is not the case, synchronisation with the GPS signal from satellite i0 is invalidated. The acquisition method continues by incrementing q at 787, in other words starting from the next sample, and returning to step 710.
In previous embodiments, the receiver determines if it is synchronised with the GPS signal of the C/A channel for a given satellite i0 at a given time. In practice, the C/A channel comprises signals from a plurality of satellites with index i0, . . . , iQ-1 where Q is the number of satellites visible to the receiver. The acquisition method presented above determines the satellite i0 with the highest signal-to-noise ratio at the receiver. Once this first signal has been acquired, the signal received from satellite i0, can be determined in base band:
that can then be subtracted from the received signal in base band (expression (2)).
is an estimate of the complex attenuation coefficient on the channel between the satellite and the receiver (for example obtained by means of pilot symbols) and is the offset frequency estimated by the receiver. xi
The acquisition of the second satellite can then be continued starting from signal r(k)−{circumflex over (r)}i
Number | Date | Country | Kind |
---|---|---|---|
13 51423 | Feb 2013 | FR | national |
Number | Name | Date | Kind |
---|---|---|---|
8873605 | Bouvier des Noes | Oct 2014 | B2 |
20070147483 | Tang | Jun 2007 | A1 |
20080215269 | Chugg et al. | Sep 2008 | A1 |
20080224926 | Curry et al. | Sep 2008 | A1 |
20100310009 | Lakkis | Dec 2010 | A1 |
Entry |
---|
French Preliminary Search Report issued Nov. 22, 2013 in French Application 13 51423, filed on Feb. 20, 2013 (with English translation of category of cited documents). |
Keith M. Chugg et al. “A New Approach to Rapid PN Code Acquisition Using Iterative Message Passing Techniques”, IEEE Journal on Selected Areas in Communications, vol. 23, No. 5, 2005, 14 pages. |
Liu Jingye et al. “GPS C/A code signal simulation based on MATLAB”, 2011 International Conference on Instrumentation, Measurement, Computer, Communication and Control, 3 pages. |
European Search Report issued May 6, 2014, in European Patent Application No. 14 15 5621 with English translation of category of cited documents. |
Andreas Polydoros, et al., “A Unified approach to Serial Search Spread-Spectrum Code acquisition” PartI: A general theory & Part II: A Matched-Filter Receiver, IEEE Transactions on. Communications, vol. 32, No. 5, May 1984, pp. 542-549 and 550-560. |
Fabio Principe, et al., “Rapid Acquisition of Gold Codes and Related Sequences Using Iterative Message Passing on Redundant Graphical Models” Proc. MILCOM '06, 2006, pp. 1-7. |
Frank R. Kschischang, et al., “Factor Graphs and the Sum-Product Algorithm”, IEEE Transactions on Information Theory, vol. 47, No. 2, Feb. 2001, pp. 498-519. |
Valentin Savin, “Self-Corrected Min-Sum decoding of LDPC codes”, Proc. of Int'l Symposium on Information Theory (ISIT 2008), Toronto, Jul. 2008, pp. 1-5. |
Number | Date | Country | |
---|---|---|---|
20140233610 A1 | Aug 2014 | US |