The embodiments of the present invention are broadly concerned with devices and methods for signal processing. These devices and methods are believed to be particularly useful in environments where high-sensitivity performance is required, for example for use with low-power spread-spectrum signals. More particularly, the embodiments are believed to be useful in systems employing orthogonal code multiplexing systems such as code division multiple access (CDMA) or similar methods, and/or for positioning systems, such as Global Navigation Satellite Systems (GNSS) such as the Global Positioning System or Galileo. In particular, embodiments of the present invention are useful in maximizing the performance of resources available in signal processing receivers to achieve the fastest signal acquisition times at the at lowest power, complexity and cost of production.
In one particular example, there is current interest in the ability to process low-power GPS signals that might occur in difficult environments, such as inside buildings. Signals in such environments typically have a total power of less than or equal to −145 dBmW and more usually −150 dBmW to −160 dBmW.
One particular challenge with regard to low-power GPS signals is the acquisition time, or the time required to recognize and be able to track a satellite signal. The signal received at a GPS receiver is a composite of the desired GPS satellite signal, other GPS satellite signals, radiation in the same frequency range, as well as noise from a variety of sources. The initial task of the GPS receiver is thus to try to separate the GPS signal of the desired satellite from all other components of the received signal.
GPS signals are spread-spectrum signals carrying a pseudorandom noise code (PN code) particular to the transmitting satellite. The PN codes for civilian use are repeated every 1 millisecond (ms). The typical acquisition method involves “finding” this PN code in the received signal, which is done by correlating a known copy of the PN code against the received signal. The process of correlation includes a multiplication step, where the received signal is multiplied by the known copy of the particular PN code, and an integration (or “accumulation”) step, where the product of the received signal and the particular PN code are integrated over the code phase. If the known PN code is correctly aligned with a received signal carrying the same PN code, a high integration value (or “peak”) will result.
There are several difficulties to be overcome, the primary two of which are a determination of the code phase and a determination of the signal frequency. The code phase refers to the starting and ending points in time of the PN code carried by the received signal. Since the receiver has at best only imprecise knowledge of the present GPS time, of its own location and the location of the transmitting satellite, it can not determine when the PN code will begin or end by its local clock. In other words, the receiver does not know where in time the 1 ms boundary of the repeating PN code is. If the receiver has no information that would allow it to estimate where the code phase begins, it must do a full code phase search. This typically involves performing a correlation, shifting the known PN code relative to the received signal by a fraction of a code chip, and correlating again. This process can be repeated or performed in parallel until the known PN code has been shifted by 1 ms.
The second problem is a determination of the frequency. Although satellites broadcast at a known frequency, they also move relative to the receiver, thus inducing a Doppler shift. This Doppler shift at times is sufficient to prevent acquisition of the signal. It is thus necessary to search not only different code phases, but also different frequencies if the receiver has no way to estimate the Doppler shift.
Furthermore, in low signal power environments, it is often necessary to perform the integration step of correlation over a long period of time. This period is usually several milliseconds for coherent integration, and may be up to twenty milliseconds. Longer integration can be performed incoherently, and incoherent integration times on the order of seconds are not uncommon.
To perform such operations over many code phases, many frequency domains, and long integration periods, signal processing devices often employ a large number of parallel correlation units, employing a brute force technique aptly named “massive correlation”. Depending on the number of correlators, acceptable acquisition times can sometimes be achieved even under low signal power conditions. The term “tap” is generally used to mean the physical circuit element that can perform a single correlation operation between the incoming signal and the replica code with a certain frequency and code offset. Taps are generally organized into units called “channels” which are used to perform correlation over a selected code/frequency space.
As an example of massive correlation, a “hot start” with a GPS receiver may be considered, wherein the receiver has an estimate of its location and the present time or where there an estimate of time available through assistance data. Under such conditions, the search space can be equal to the full PN code space (1023 chips for civilian use) and some hundreds of hertz (Hz) in the frequency domain (for example, +/−150 Hz. The search range of a single tap might be, for example, ½ chip in the code space and +/−1/(3 T) in the frequency space (where T is the coherent integration time and 2/(3T) is called frequency bin). Thus, to cover the entire search space a set of around 16 thousands taps is needed.
Many GPS receivers implement even higher numbers of taps and can search more than one satellite in parallel. Other receivers use fewer taps, but must serialize the search of the single satellite into several steps. A “massive correlator” receiver is normally used to mean a receiver that has at least the potential to search for the whole code uncertainty (i.e. at least 2046 physical taps) in parallel for one satellite. The search in the frequency domain can be performed using post correlation Fast Fourier Transform (FFT), which is more efficient, or using physical taps, which is quite inefficient especially for high frequency uncertainties.
In general, more correlation resources mean higher production costs and more power consumption. Fewer correlation resources result in lower costs, but also result in longer acquisition times. It is thus desirable to maximize the performance of the correlation resources available to achieve the fastest acquisition times at the at lowest power, complexity and cost of production.
One aspect of the present invention relates to providing signal processing devices that efficiently use correlation resources.
It is a further aspect of the invention to provide signal processing methods for efficiently using correlation resources.
Another aspect of the invention relates to providing signal processing methods to efficiently use channel memory.
Yet another aspect of the invention relates to providing a signal processing method comprising performing a pre-detection stage and performing at least one distillation stage.
It is a further aspect of the invention to provide a signal processing method comprising performing a pre-detection stage and performing multiple distillation stages.
It is a further aspect of the invention to provide a signal processing method comprising performing at least one pre-detection stage, at least one intermediate stage and at least one distillation stage using channels normally reserved for signal tracking.
Another aspect of the invention relates to providing a signal processing receiver comprising a number of independent channels for use in confirming correlation peaks identified in at least one pre-detection stage.
A further aspect of the invention relates to providing a signal processing receiver comprising a correlation engine, further comprising a plurality of taps and a plurality of independent taps forming independent channels, the correlation engine operatively connected to a digital signal processing core, the digital signal processing core executing instructions that compare at least one output of the correlation engine to a predetermined threshold corresponding to a probability of detection after a number of integration intervals to identify at least two candidate peaks, the instructions further configured to direct at least two independent channels to confirm at least two candidate peaks.
Another aspect of the present invention is a signal processing receiver with at least one channel that has the capability to release taps that do not meet a certain probability of being aligned with the signal, that is, when the accumulation value of the tap drops below a certain level. If a tap or group of taps is released, it can be used for other purposes such as the acquisition, confirmation or tracking of another signal, or can simply be shut down to avoid wasting resources. In this way the at least one channel integrates predetection and distillation stages in non coherent integration and is able to release taps at the end of each integration interval.
In the drawings:
Preferred embodiments of the invention have circuitry elements or the software equivalents thereof for performing correlation. Such elements, when broken down into abstracted, individual units, may be referred to as “taps”. A schematic diagram of a single tap is shown in
The tap shown in
Despreader 3 has two inputs, one being from wipeoff circuit 2, the originating from code replicator 4. The code replicator generates the known PN code for the particular satellite being searched. These codes can be generated by methods known in the art for civilian access to GPS satellites. The code generation may be serial (one chip after another) or parallel (more than one code chip at one time), or a combination thereof, depending on the correlation method in use. Typically one code replicator will be shared by more than one tap.
The output of code replicator 4 can be phase shifted by, for example, shifter 5, which is shown here in z-transformation form. Since a single code replicator may be shared by many taps, it is necessary to phase-shift the code so that different taps can correlate the known PN code to different signal positions.
Despreader 3 effectively multiplies the known, phase-shifted PN code generated by code replicator 4 with the signal originating from carrier wipeoff circuit 2. This is not only a necessary step in correlation, but also has the effect of dispreading the signal, if the known PN code is correctly aligned with the signal in the tap of concern.
After despreading at despreader 3, the signal is input into coherent accumulator 6, which effectively integrates the received signal. The integration is coherent because the sign of the received signal is included in the integration. The result of the coherent integration over a particular time period is then input to a non-coherent integrator 7, which sums the results without regard to sign, as an absolute value or square, for example.
During correlation of a signal, a correlation peak, or a high integration result is sought. The search for very low power signals requires long integration times, for example, 1 to 3 seconds, until a recognizable correlation peak appears. This corresponds to the sum of hundreds of coherent integrations, depending on the length of the interval chosen for coherent integration.
As a result of noise however, several correlation peaks will be found. GPS receivers generally deal with this situation by performing integration for long periods of time, until one signal emerges as the signal having the highest correlation value.
Embodiments of the invention comprise the decomposition of the search phase into a series of stages. Each stage implements a selection algorithm of the taps with the highest probability to be aligned with the signal. The first stage includes the performance of a signal search in the entire search space of a satellite signal, or in a subset of it. The search space is defined by the signal code and frequency uncertainties. At the end of this stage, the best candidates are selected with one of the methods described below. The second stage performs a further selection on the candidates identified in the first stage, applying similar principles to those used to select candidates in the first stage. Other stages can follow. The process may be configured to stop whenever the last stage is capable of producing a number of candidates equal or less than the number of tracking channels available in the receiver. A channel performing the first stage will be called “skimming” channel. A channel performing the second stage or any other following stage will be called “distiller” or “distillation” channel. The benefits of this approach as compared to the to the approach commonly implemented by GPS receivers will be explained hereinafter.
The vertical axis is a logarithmic plot labeled “Rank”, and represents a statistical quantity. It is here necessary to consider a large number of theoretical trial correlations, each operating on the same incoming signal with the same root mean squared noise power level, but where the noise is not correlated between trials. When trial is carried out, the integration value of the tap aligned with the signal can be compared to the integration values for all other taps, which are not aligned with signals, but may nonetheless have high values. If all values are arranged in a set, called E, and sorted, from highest value (at position 1) to lowest value, each tap can be assigned a “rank” corresponding to its position in the set E. Such a set E can be constructed for each integration interval, and for each trial. Each set E will look like a list of unique (non-repeating) numbers, the numbers ranging from 1 to 16368 and corresponding to each tap.
If a particular tap and particular integration interval are chosen, another set G can be constructed which contains the rank for that tap after the particular integration interval in each trial. If the tap in question is the tap aligned with the signal, the values (ranks) in the set G will approach the value 1 for increasing numbers of integration intervals. That is, the process of correlation “sorts out” the signal from the noise.
A scalar representation of the set G can be chosen as the supremum of the set. A supremum is a number a that satisfies the relationship a≧m for all m which are elements of L, where L is a set of numbers. The lowest supremum of G is thus the upper bound of G, or the lowest rank that is still greater than or equal to all of the individual ranks in G. One can further define an X % supremum to mean a number a that satisfies the relationship a≧m for X % of all m which are elements of L. For example, a 90% supremum satisfies the relationship above for 9 out of 10 elements of a set L. The lowest supremum or upper bound is then equivalent to the 100% supremum. For example, if L is the set of ten rankings {1, 1, 2, 1, 1, 5, 1, 1, 7, 4}, the lowest supremum or upper bound is seven while the 90% supremum is five.
After a low number of integration periods and a low-power signal, the tap aligned with the signal will still have an integration value which is dominated by the noise component of the signal and essentially random. The set G for the tap aligned with the signal at this stage will have a large number of different ranks between 1 and 16368. The upper bound of G can not be expected to be significantly lower than that for sets G of taps not aligned with the signal. As integration progresses, however, the set G of the tap aligned with the signal will be populated with more and more ranks closer to 1. This will decrease the upper bound of the set.
The vertical axis of the graph in
Practically, the graph in
After the integration has been carried out over 180 intervals, the receiver will transfer the candidate with the 90% supremum in the set G equal to one to a confirmation and tracking stage. The confirmation stage is performed with a smaller number of “independent” taps. Independent taps are taps which are able to operate at an arbitrary code phase and in an arbitrary frequency bin. Independent taps thus allow the receiver to take the code phase and frequency bin from the tap producing the highest correlation value, and track the signal, regardless of the code phase and frequency of the signal.
It is possible, however, to greatly increase the efficiency of this process. To illustrate the inefficiencies, the graph in
The graph in
The graph may be calculated in the following manner. After any number of integration periods N, the tap aligned with the signal will have a X % supremum of M. That is, the taps with X % suprema from M to 1 are still needed to sort the aligned signal out from the non-aligned signal. The remaining taps are wasted. The percentage of usefully employed taps at X % confidence is thus ((total number of taps−X % supremum)/(total number of taps))×100%. The graph in
The receiver can be provided an estimate of the confidence level of a particular ranking at a particular carrier to noise level, integration value and number of integration periods through statistical analysis. The results of the non-coherent accumulation Y can be modeled as a stochastic variable with a χ2 (chi-squared) distribution (in case no signal is present) and a non-central χ2 in case a signal is present.
where Ii and Qi are the result of the ith correlation of the incoming IT in phase signal and QT quadrature phase signal with a pseudorandom replica code for a dwell time period T.
To completely define the two distributions we need two parameters well know to those skilled in the art: the degree of freedom (δ) and the non-centrality parameter (λ). In both cases the degree of freedom is set, for present purposes, at two times the number of accumulations. Given the carrier to noise ratio of the signal, the non-centrality parameter of the non-central χ2 is computed as shown in the following paragraphs.
Let σn be the noise floor:
σn=RMS(IT)|T=1 ms=RMS(QT)|T=1 ms (2)
where IT and QT are the result of the correlation of the incoming IT in phase signal and QT quadrature phase signal with a pseudorandom replica code for a dwell time period T (T=1 ms in this example). The above formula applies when the input signal is made of pure noise.
Let now T be the coherent integration interval. T can range between 1 and 20 ms, but at very low signal levels i.e. −150 to −160 dBmW 16 ms is the typical value. The amplitude A of the correlation function after the coherent integration interval T is then:
where C/N0 is the Carrier to Noise ratio. Here the term correlation is used not to refer to the act of correlating a received signal with a known signal, but rather the statistical correlation function. The non-centrality parameter, normalized with the noise power is given by:
The non-central distribution given the signal C/N0 and the number of non-coherent accumulations nacc model the statistics of the accumulation result Y, which is the sum of the squares of Ii and Qi. The actual accumulation of powers is not particularly efficient to implement in receiver hardware. Instead, the signal envelope
is often accumulated. Numerical simulations have shown that all the results that are valid for the sum of powers are applicable also to the sum of envelopes. Substituting we get:
PSignal is the probability that for a given accumulated value Y, Y is the result of a signal whose Carrier to Noise ratio is C/N0. PNoise is likewise the probability that for a given the accumulated value Y, Y results from noise.
Defined is also the cumulative probability function, that is
PSignal(Y>τ) is the probability that the accumulated value Y is greater than a particular threshold τ, whenever Y is the result of a non-coherent accumulation of signal plus noise with a ratio C/N0. PNoise(Y>τ) is the probability that given the accumulated value Y is greater than τ, whenever Y is only noise (no signal). The following formula is based on the above statistic and is used to compute the number of accumulations nacc required to the tap aligned with the signal to accumulate a value that with a confidence equal to ρconfidence has a rank equal to ρ.
Once an estimate of the number of wasted channels is available to the receiver, it becomes possible to implement a more efficient scheme using multiple distiller and pre-detection stages.
The potential for the use of a pre-detection stage is clear from the examples depicted in the graphs of
Correspondingly, after 135 integration intervals, 10 highest peaks can be identified, among which there is a 90% chance of finding the tap aligned with the signal. If 10 independent channels for confirmation are available, the vast majority of correlation resources can be saved after only 135 integration intervals. After 90 integration intervals, 100 highest peaks can be identified, among which there is a 90% chance of finding the tap aligned with the signal. If 100 independent channels for confirmation are available, the vast majority of correlation resources can be saved after only 90 integration intervals (i.e. the whole mass of resources 16368 taps will be used only for half the time as compared to the common massive correlation approach). Once the candidates have been released to the smaller distiller channel, the massive correlation channel can be used for the pre-detection stage of another signal. The hierarchical structure pre-detection/distiller allows one to introduce a certain degree of parallelism through a sort of pipelining and the optimization of resource usage.
The advantage of this technique in terms of Time to First Fix, one of the key performance parameter of a GPS receiver, can be easily quantified. In particular the time needed to acquire the first satellite is greatly reduced. Given the signal level, the probability of detection at a certain signal level and the code frequency uncertainty, the exemplary architecture (e.g. with a 100 candidates ) can be as much as twice as fast as compared with a classical massive correlation approach (Oust one candidate). The added complexity is in the distiller engine, but as far as the memory consumption (i.e. chip size and cost) of the latter is concerned, typically only about 1/20 of the memory will be required by the pre-detection channel.
The previous examples illustrate a single distiller phase. It is also anticipated, however, that multiple distillation phases can be implemented that will improve the efficiency of the embodiments of the present invention. Care should be taken at the design stage to ensure that the correct desired probability of detection results when multiple distillation stages are used.
The use of a large number of distillation phases would result in a quasi-continuous process (or discrete process with very fine steps) that is optimal in terms of the immediate release of unneeded channel resources. When the overall design is considered, however, other factors in design such as component complexity and power consumption may make such a quasi-continuous process suboptimal.
It is believed that channel resources in current GPS receivers can be re-tasked to implement the embodiments of the invention. This will generally be possible through the reallocation of at least a certain number of independent taps, otherwise dedicated to tracking, to the process of distillation of a number of correlation peaks identified after a pre-detection stage and one or more distillation stages.
At very low signal levels the acquisition engines are generally designed to work with quite low probability of detection. It can be demonstrated that the lower the probability of detection the higher the efficiency of the proposed method. As an example for the use of a pre-detection stage with a low detection threshold, the graph in
The computation of the threshold T for a given number of accumulations nacc proceeds as follows:
PSignal(Y>τ)>PD (9)
The threshold T is the maximum value that satisfies the inequality below
[1−X2(τ,λ(nacc),2nacc)]>PD (10)
The non-centrality parameter as a function of the number of non-coherent integration samples is given by:
The graph in
The graph in
As far as the candidate selection criterion is concerned two methods are exemplary. The first method is similar to the one applied for the pre-detection channel: at the end of a fixed period of non-coherent accumulation the candidates with the highest accumulation values are selected. The difference is that this time the comparison of the accumulated values against the threshold is not applied. The second consists in a real-time evaluation of the probability of the candidate tap to be a signal based on the Bayes formula. The method proceed as follows:
Let PSig(n) be the probability (i.e. the degree of confidence) of signal presence at the channel tap. At step 0, the process has no guess as to whether the tap in question is aligned with the signal, and PSig(0)=0.5
After the first non-coherent accumulation period we update our degree of confidence:
where PD is the probability that the measurement υ is generated by a channel where there is signal, while PFa is the probability that the measurement is generated by a channel where there is no signal. After a certain number of steps the candidates with the highest probability are selected. This latter method in general promotes the best performance.
The measurement event can be the result of a comparison with a threshold, or the value of the measurement itself. In the first case, PD is given by the Bernoulli trial:
In the second case the probability is given by a non-central chi-square distribution probability density function (X2)
PD(υ)=Xλ,σ,dof2(υ2) (14)
As far as the PFA is concerned, if the measurement event is the result of the comparison wrt a threshold then PFA is given by the Bernoulli trial probability function.
In the second case the probability is given by a central chi square distribution probability density function:
PFA(υ)=χλ=0,σ,dof2(υ2) (16)
For all the above probability υ is the power accumulated in the last coherent accumulation period T.
An optimal distiller will proceed until its list of candidates is reduced to a number that would fit in a third stage distiller or that is comparable with the number of tracking channels. In general the distiller's primary function is not the confirmation of a signal. An optimal distiller should not alter the overall probability of detection. The probability of detection is, in fact, the product of the probability of detection of the stages that go from the pre-detection to the final confirmation. As long as the pre-detection stage normally starts with a low probability the following should be much higher.
Correlation engine 61, after receiving the signal over inputs not shown in
Division of pre-detection channel 71 into distillation channels 72 or the division of distiller channels 72 into further distiller channels 73 does not necessarily indicate the addition of further physical channels, but rather shows the division of the correlation into smaller sub-correlations that require fewer resources. In fact, it is possible simply to release the unneeded portions of each channel at each stage of the correlation process. It should also be clear to a person of skill in the art that a large number of distillation stages can be employed, each successive stage operating with a smaller amount of resources, until finally acceptable correlation results 74 are obtained.
It will be apparent that in this way a large number of candidate peaks can be identified and distilled, and that multiple distillation stages can be implemented, saving significant resources as described above. Furthermore, it will be apparent to those of skill in the art that the specific examples contained herein can be applied to a wide variety of practical cases according to the specific design and needs of the particular application.
The present application claims benefit of priority to U.S. Provisional Application Ser. No. 60/752,032, filed Dec. 21, 2005, the entire contents of which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5293170 | Lorenz et al. | Mar 1994 | A |
5600670 | Turney | Feb 1997 | A |
5610984 | Lennen | Mar 1997 | A |
5852630 | Langberg et al. | Dec 1998 | A |
5901171 | Kohli et al. | May 1999 | A |
5952960 | Lennen | Sep 1999 | A |
6175848 | Riley | Jan 2001 | B1 |
6195041 | Gardner et al. | Feb 2001 | B1 |
6208291 | Krasner | Mar 2001 | B1 |
6298083 | Westcott et al. | Oct 2001 | B1 |
6304216 | Gronemeyer | Oct 2001 | B1 |
6324227 | Kang et al. | Nov 2001 | B1 |
6393046 | Kohli et al. | May 2002 | B1 |
6400753 | Kohli et al. | Jun 2002 | B1 |
6496145 | Gronemeyer | Dec 2002 | B2 |
6522682 | Kohli et al. | Feb 2003 | B1 |
6577271 | Gronemeyer | Jun 2003 | B1 |
6606346 | Abraham et al. | Aug 2003 | B2 |
6618670 | Chansarkar | Sep 2003 | B1 |
6636178 | Gronemeyer | Oct 2003 | B2 |
6683923 | Butts, Jr. | Jan 2004 | B1 |
6704348 | Abraham et al. | Mar 2004 | B2 |
6748015 | Kohli et al. | Jun 2004 | B2 |
6760363 | Bettaieb | Jul 2004 | B1 |
6788735 | Kohli et al. | Sep 2004 | B2 |
6804290 | King et al. | Oct 2004 | B1 |
6831911 | Sridharan et al. | Dec 2004 | B1 |
6850557 | Gronemeyer | Feb 2005 | B1 |
6891499 | Dooley et al. | May 2005 | B2 |
6933886 | Sahai et al. | Aug 2005 | B1 |
6934322 | King et al. | Aug 2005 | B2 |
7127351 | Norman et al. | Oct 2006 | B2 |
20020015456 | Norman et al. | Feb 2002 | A1 |
20040247019 | McDonough et al. | Dec 2004 | A1 |
20050129146 | Akopian et al. | Jun 2005 | A1 |
Number | Date | Country |
---|---|---|
WO 03030391 | Apr 2003 | WO |
Number | Date | Country | |
---|---|---|---|
20070183487 A1 | Aug 2007 | US |
Number | Date | Country | |
---|---|---|---|
60752032 | Dec 2005 | US |