The present invention generally relates to the decoding field. It is applicable in particular to the acquisition phase of a satellite signal by a GPS (Global Positioning System) receiver or by a receiver from the Galileo system.
A GPS receiver conventionally determines its position by measuring the times of flight of signals received from a plurality of satellites (theoretically at least four of them). To assess the time of flight of a GPS signal emitted from a satellite, the receiver uses a so-called coarse acquisition channel (C/A channel) on which the satellite emits a navigation message spectrally spread by means of a pseudo-random sequence (called a spreading sequence) having good auto-correlation as well as inter-correlation properties (with the PRN sequences used by the other satellites).
The good auto-correlation properties of the spreading sequences enable a signal detection probability to be optimized in the presence of noise whereas the good inter-correlation properties of these sequences enable the different satellites to share a same transmission band by means of a code division multiple access (CDMA).
The first task of a GPS receiver is to detect the satellite in visibility. To do this, the receiver attempts to detect the spreading code of the satellite the presence of which it desires to test and, if applicable, is synchronised with respect to this signal. This first task is called a step of acquiring the GPS signal.
Numerous methods for acquiring the GPS signal are known from the state of the art. They relate to the multi-user detection issue in CDMA systems. These acquisition methods are generally based on a correlation of the signal received by the receiver with the spreading code of the satellite to be tested. An exemplary method of acquisition by correlation with the spreading code is described in the article 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.
A more recent acquisition method has been described in the article of 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. This method is based on an iterative message passing decoding (IMPA) in a Tanner graph representing the parity requirements imposed to the code.
However, the latter acquisition method does not enable sufficiently low missed detection probability and false alarm probability levels to be obtained at a low signal-to-noise ratio (SNR). By missed detection probability, it is meant the probability not to be synchronized with a spreading sequence of a satellite whereas which is actually received by the receiver. By false alarm probability, it is meant the probability to be synchronized with a spreading sequence which is not received by the receiver.
Patent application FR 1351423 provides an acquisition method by an IMPA decoding enabling substantially lower missed detection probability and false alarm probability levels to be obtained. However, this method is relatively complex given that it carries out a series decoding. According to this method, indeed, the decoder is assumed to be synchronized with the code and attempts a first decoding. In case of failure, the decoder is assumed to be synchronized with the following moment and so on. Each decoding attempt has to be made in a very short time span so as to fulfil the acquisition time requirements.
The purpose of the present invention is to provide a method for acquiring a Gold sequence, in particular a Gold sequence emitted from a satellite or a GPS or Galileo system, which enables shorter acquisition times to be obtained and with a complexity lower than in prior art.
The present invention is defined by a method for acquiring a Gold sequence spreading a signal at a chip rate, said Gold sequence being obtained as a sum of a first M-sequence and a second M-sequence, the first M-sequence being generated by a first generator polynomial and the second M-sequence being generated by a second generator polynomial, the first and second generator polynomials being of the same degree and the weight of the second generator polynomial being higher than the weight of the first generator polynomial, the method comprising:
(a) a step of receiving and sampling at the chip rate said signal to obtain a plurality of samples representative of successive elements of said Gold sequence;
(b) a first step of message passing decoding in a first bipartite graph between first variable nodes representing the successive elements of the Gold sequence and first control nodes, each control node being bi-univocally associated with a variable representative of an element of the second M-sequence, the edges of the bipartite graph being determined by the coefficients of the first generator polynomial;
(c) a step of decimating the variables representative of successive elements of the second M-sequence using a predetermined decimation factor to obtain second variables representative of elements of a third M-sequence, the third sequence being of the same length as the second sequence and being generated by a third generator polynomial having a minimum weight;
(d) a second step of message passing decoding in a second bipartite graph between said second variable nodes and second control nodes, the edges of the second bipartite graph being determined by the coefficients of the third generator polynomial.
A plurality of first steps of message passing decoding can be carried out before carrying out said decimation step.
Advantageously, after the second step of message passing decoding, a reverse operation to that of the decimation step is carried out to update said variables representative of the successive elements of the second sequence.
A plurality of second steps of message passing decoding can also be carried out before carrying out a reverse operation to that of the decimation step.
Steps (b), (c), (d) can be iterated until a predetermined stopping criterion is fulfilled. When this stopping criterion is fulfilled, the generation moment of said Gold sequence is determined based on the values of the first variables representative of the elements of the Gold sequence and the variables representative of the successive elements of the second sequence.
Further characteristics and advantages of the invention will appear upon reading preferential embodiments of the invention made with reference to the appended figures among which:
It is reminded that a signal emitted by a satellite of a positioning system as the GPS system or Galileo system is obtained by spectrally spreading a navigation message, the spreading code being specific to the satellite in question. Each symbol of the message lasts a plurality of repetition periods of the spreading code. Thus, for the GPS system, each symbol lasts 20 ms, that is 20 repetition periods of the spreading code, the chip rate being 1,023 MHz.
The spreading sequences ci of the different satellites i=1, . . . , 1 are Gold sequences, each Gold sequence being built from a sum of two sequences having a maximum length, also called M-sequences. It is reminded that an M-sequence is a periodical series of values which is produced by a linear feedback shift register (LFSR) which explores all the values that can be produced by the shift register. Any linear combination of two M-sequences having the same degree r (that is generated by generator polynomials having the same degree) does not necessarily yield a Gold sequence: a pair of M-sequences the sum of which yields a Gold sequence is called a pair of preferential sequences.
The spreading sequences ci are each built from a pair of preferential M-sequences, x and y. More precisely:
ci(k)=x(k)+y(k−τi) (1)
where τi is a delay, expressed in number of chip periods, specific to the satellite i.
In the case of the GPS system, the M-sequences x and y are respectively generated from the generator polynomials:
gx(D)=D10+D3+1
gy(D)=D10+D9+D6+D3+D2+1 (2)
It is reminded that an LFSR sequence generated by a generator polynomial
having a degree r, with gr=g0=1 is obtained by a shift register having r memory positions (more simply called positions hereinafter) and r samples, looped back on itself, as represented in
An M-sequence is univocally defined by its generator polynomial, the content of the shift register at the initial moment giving its value at the origin. An M-sequence generated by a (primitive) generator polynomial having a degree r is periodical and of a length K=2r−1. The M-sequences x and y are generated by setting the positions of their respective shift registers to 1, that is x(0)=x(1)= . . . =x(9)=1 and y(0)=y(1)= . . . =y(9)=1.
It can be shown that the Gold sequence ci is also an M-sequence having a length 22r′−1 and a generator polynomial gc(D)=gx(D)gy(D).
The delayed sequence defined by yi(k)=y(k−τ) is advantageously obtained using the “add and shift” property of the M-sequences. More precisely, the delays τi are selected such that the sequence yi can be generated from the sum of the contents at two positions αi and βi of the shift register generating the sequence y, that is:
yi(k)=aα
where αα
It has been represented in
In the upper part, the generator 310 of the M-sequence x is distinguished and in the lower part, the generator 320 of the M-sequence y is distinguished. Both generators 310 and 320 use shift registers looped back on themselves. For each generator, the samples of the shift register correspond to the monomials of the corresponding generator polynomial. The phase selector 330 selectively sums some positions of the shift register 320. The choice of these positions αi and βi is carried out according to the table of
The sum of the M-sequences x and yi in 350 yields the Gold sequence ci, in other words the spreading sequence relating to the satellite i.
In what follows, the synchronization of a receiver with respect to a signal of a satellite i will be considered, in other words the acquisition of a satellite signal emitted by the satellite i.
The receiver samples at the chip rate the satellite signal received, after translation in baseband.
The receiver forms a sequence of N successive samples of the signal thus received, where N>2r. These N successive samples consist of flexible values, for example Log Likelihood Ratios (LLR) and will be noted r(0), . . . , r(N−1) in what follows.
The samples r(k), k=0, . . . , N−1, can be expressed in the form:
r(k)={tilde over (x)}(k){tilde over (y)}(k−τi)+w(k) (4)
where {tilde over (x)}(k)=1-2x(k) and {tilde over (y)}(k)=1-2y(k) are the BPSK versions of the bits x(k) and y(k).
The sequences x et y, respectively fulfil the parity equations:
the sums herein relating to bits and being thus modulo 2 calculated.
In a similar way, the Gold sequence ci formed by the M-sequences x and yi fulfils the parity relationship:
Given that ci(k)=x(k)+yi(k),
In view of the aforesaid “add-and-shift” property of the M-sequences, there is an integer θi such that:
In view of (7) and (8), there is the parity equation:
It is understood from the expressions (5-2) and (9) that the sequences ci(k) and yi(k) can be decoded together using two cascade message passing decoders, as represented in
The first decoder is based on a first bipartite graph comprising N first variable nodes, 410, and N−r first control nodes, 420. The first variable nodes are set with the values of the samples r(0), . . . , r(N−1) and the first control nodes correspond to the parity equations (9). The edges of the first bipartite graph are determined by the coefficients of the generator polynomial gx and, more precisely, by the elements of the parity matrix having the size (N−r)×N:
each first control node corresponding to a row of the parity matrix Hx.
A second variable node is bi-univocally associated with each of the first control nodes 420. More precisely, a second variable node yi(k+θi) is associated with each first control node k=0, . . . , N−r−1, corresponding to the parity equation (9-2).
The second decoder is based on a second bipartite graph comprising N−r second variable nodes, 430, and N−2r second control nodes, 440. The second variable nodes are set at null values of LLR (absence of a priori information) and the second control nodes correspond to the parity equations (5-2). The edges of the second bipartite graph are determined by the coefficients of the generator polynomial gy and, more precisely, by the elements of the parity matrix having the size (N−2r)×(N−r):
each second control node corresponding to a row of the parity matrix Hy.
The first message passing decoder enables a first estimation of the variables ci(k), k=0, . . . , N−1 and yi(k+θi), k=0, . . . , N−r−1 to be obtained. The second message passing decoder then enables the first estimation of the variables yi(k+θi), k=0, . . . , N−r−1 to be refined using requirements imposed by the control nodes 540. This refined second estimation is then used in the first decoder to refine the first estimation of the variables ci(k), k=0, . . . , N−1 and yi(k+θi), k=0, . . . , N−r−1. The decoding process is thus continued until a stopping criterion is fulfilled, for example after a predetermined number of iterations or when the LLR absolute values of the variables ci(k), k=0, . . . , N−1 are higher than a predetermined threshold. Other stopping criteria can be contemplated by those skilled in the art without departing from the scope of the present invention.
Passing from the first to the second decoder can be carried out every L1≧1 iterations of the first decoder. In a similar way, passing from the second to the first decoder can be carried out every L2≧1 iterations of the second decoder. It is reminded that an iteration of a message passing decoder comprises a first message transfer from the variable nodes to the control nodes via the bipartite graph and a second message transfer in the reverse direction.
It is assumed as previously that the Gold sequence ci to be acquired is the sum of a first M-sequence x with a generator polynomial gx and a second M-sequence yi with a generator polynomial gy. It will be assumed that both generator polynomials gx and gy are of the same degree and that the weight of the polynomial gy is higher than the weight of the polynomial gx. It is reminded that the weight of a polynomial is the sum of the coefficients of the monomials located in this polynomial. Thus, the respective weights of the polynomials gx and gy defined in (2) are respectively 3 and 7.
It is known that two M-sequences having the same size, that is whose generator polynomials have the same degree, are related by a decimation relationship. In other words, for two M-sequences z1 and z2 having the respective generator polynomials gz1 and gz2, of the same degree r, there is a decimation factor η21 and an offset μ21K such that:
z2(k)=z1(η21k+μ21) (12)
where, of course, the values of k and η21k are taken modulo K=2r−1.
For the same reason, there is a decimation factor η12 and an offset η12<K such that:
zi(k)=z2(η12k+μ12) (13)
the decimation factors η21 and η12 fulfilling:
η21η12=1 modulo K (14)
and besides, the offset μ21 and μ12 fulfilling:
η12μ21+μ12=0 modulo K (15-1)
and
η12μ12+μ21=0 modulo K (15-2)
If the M-sequence yi with the generator polynomial gy is considered, there is a polynomial gu of the same degree r, and of a lower weight, generating an M-sequence u such that:
u(k)=yi(Φi(k)) (16)
with Φi(k)=ηk+μi where i is a decimation factor and pi is an offset depending on θi.
Resorting to a generator polynomial gu of a minimum weight in lieu of a generator polynomial gy results in a bipartite graph of the second decoder having little or no short circles, which speeds up decoding convergence and reduces the error rate.
More precisely,
Unlike
The edges of the second bipartite graph of the second message passing decoder are determined by the coefficients of the generator polynomial having the minimum weight gu and more precisely by the elements of the parity matrix with the size (N−2r)×(N−r):
This parity matrix has the advantage of being more sparse (sparse matrix) than the parity matrix Hy and, consequently, the cycles of the second bipartite graph of the second decoder are longer.
It will be noted that the second decoder is separated from the first decoder by a decimation module 533. This module carries out a decimation Φi(k)=ηk+μi when the sequence yi is switched to the sequence u, in other words when an iteration of the first decoder is switched to an iteration of the second decoder. Conversely, this module carries out an operation in the reverse direction, that is a decimation Φi−1(k)=η′k+μi′ when the sequence u is switched to the sequence yi, in other words when an iteration of the second decoder is switched to an iteration of the first decoder. In order to allow this decimation operation to switch from the sequence u to the sequence yi and conversely, the number of samples of these sequences must be greater than or equal to K=2r−1, in other words the number N of samples of the signal received must be such that N≧2r+r−1. Preferably, N=2r+r−1 can be chosen.
In the case of a satellite reception, the decoding can be repeated for each satellite i. When the decoding converges, the sequences ci(k) and yi(k+θi) are obtained. Then, it is possible to deduce where it is in the M-sequences yi(k+θi) and x(k), in other words the generation moment of the Gold sequence, and to be synchronized with respect to the same.
In 610, the probability of acquiring the Gold sequence obtained using the method illustrated in
The generator polynomials used were the following ones:
g(D)=D10+D3+1
gy(D)=D10+D9+D8+D6+D3+D2+1
gr(D)=D30+D19+D18+D16+D11+D8+D5+D2+1
gn(D)=gx(D)
and the decimation function was Φ(k)=65k+27300.
It is noted that the acquiring method of
Number | Date | Country | Kind |
---|---|---|---|
14 58115 | Aug 2014 | FR | national |
Number | Name | Date | Kind |
---|---|---|---|
20050084112 | Kim | Apr 2005 | A1 |
20080215269 | Chugg et al. | Sep 2008 | A1 |
20080224926 | Curry | Sep 2008 | A1 |
20100122143 | Lee | May 2010 | A1 |
20140233610 | Bouvier Des Noes et al. | Aug 2014 | A1 |
Number | Date | Country |
---|---|---|
102332932 | Jan 2014 | CN |
3 002 388 | Aug 2014 | FR |
Entry |
---|
French Preliminary Search Report issued May 19, 2015 in French Application 14 58115, filed on Aug. 29, 2014 ( with English Translation of Categories of Cited Documents). |
Andreas Polydoros et al. “A Unified Approach to Serial Search Spread-Spectrum Code Acquisition—Part I: General Theory, Part II: A Matched-Filter Receiver”, IEEE Transactions on Communications, vol. Com-32, No. 5, 1984, 18 pages. |
Fabio Principe et al. “Rapid Acquisition of Gold Codes and Related Sequences Using Iterative Message Passing on Redundant Graphical Models”, MILCOM 2006, XP055189450, 2006, 7 pages. |
Wei Wang et al. “FPGA Implementation of Rapid PN Code Acquisition Using Iterative Message Passing Algorithms”, IEEE Aerospace and Electronic Systems Magazine, vol. 29, No. 6, 2014, 11 pages. |
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. |
Number | Date | Country | |
---|---|---|---|
20160061961 A1 | Mar 2016 | US |