This disclosure relates to wireless code synchronization, including wireless code synchronization for global navigation satellite systems (GNSS).
Typical digital communication systems involve using a transmitter to send a bit stream to a receiver. The bit stream contains digital information that the receiver decodes and makes use of. In some communications systems, the digital information is extracted by first converting the analog representation of the bit stream to digital samples. Each sample represents the signal at the time of sampling. Because of noise and other effects, signal transitions may not be cleanly represented.
Such digital communication can be used in different systems, such as a Global Navigation Satellite System (GNSS). GNSS is a satellite system that involves a network of satellites in space. Each satellite wirelessly transmits coded signals at precise intervals. A receiver analyzes the signal information to determine position, velocity, and time estimates. The GNSS signal is used for various applications such as to determine the geographic location of a user's receiver anywhere in the world. Using the information in the transmitted signal, the receiver on or near the earth's surface can calculate the exact position of the transmitting satellite and the distance (from the transmission time delay) between the satellite and the receiver. For accurate operation of a system based on receipt of GNSS signals, the transmitting satellite and the receiver are time synchronized.
GNSS are especially sensitive because the GNSS signals are communicated between satellites above the earth's atmosphere and receivers on the earth's surface. In addition, the signals transmitted to the receiver are generated by the transmitter and therefore synchronized to the time base in the transmitter. Thus, the signals are not synchronized to the receiver's time base, and therefore the location of bit transitions in the receiver's time base cannot be assumed.
The discussion below makes reference to the accompanying drawings which show, by way of illustration, specific embodiments, described in this document. Other embodiments may be utilized and structural changes may be made without departing from the scope of the present document. Further, embodiments are described in context of a Global Navigation Satellite System (GNSS), however the features described in the embodiments may be applicable to other areas of digital communication using spread spectrum signals, such as wireless communications using Code Division Multiple Access (CDMA). The embodiments may be beneficial for accurate and computationally efficient code phase synchronization of spread spectrum signals, such as GNSS signals, in the presence of frequency uncertainty. For example, the techniques presented may be used during the synchronization of secondary codes such as those present in modern GNSS constellations like Beidou and Galileo. Since the code phase synchronization described is computationally efficient, less processing power within system is needed in association with receipt of communications, and can therefore be allocated to other functionality. In the example of GNSS, if, for example, the GNSS is being implemented with application specific integrated circuits on one or more microchips, the communication portion of the GNSS may not only have lower computational needs, but also consume less of the resources of the microchip(s).
The transmitter 110 may transmit the signal 150 at a fixed rate. The transmitter 110 may also transmit the signal 150 arbitrarily based on a triggering event, such as receipt of an instruction to transmit data. The transmitter 150 may be a satellite, or at a satellite, such as a Global Position Satellite (GPS), in which case the transmitter 110 may transmit the signal 150 continuously at a given rate. Alternatively, the signal 150 may be transmitted by a pseudolite, or a pseudo-satellite, such as a ground-based signal transmission system. The transmitter 110 may be stationary, or moving when transmitting the signal 150.
The transmitter 110, such as a satellite, may be designed to transmit the wireless signal 150, as a spread-spectrum radio signal. The examples described further use a satellite in the role of the transmitter 110, however the transmitter may be any other transmitting devices such as a wireless signal tower or a repeating station that may repeat a received signal. The satellite may include a modulator that uses Phase-shift keying (PSK) as a digital modulation scheme to convey the data 180 by changing, or modulating, the phase of a carrier wave. PSK uses a finite number of phases, each assigned a unique pattern of binary digits. Usually, each phase encodes an equal number of bits. Each pattern of bits forms a symbol that is represented by the particular phase. A demodulator, such as the receiver 120, determines the phase of the received signal and maps it back to the symbol it represents, thus recovering the original data. The receiver 120 may be designed specifically for the symbol-set used by the modulator. Thus, the wireless signal 150 may have at least three parts, or components described later. In addition to the three components, examples of the wireless signal 150 may include other components that benefit from embodiments described.
The wireless signal 150 may have a data 180 portion. The data 180 may contain information necessary for the navigation, such as time and ephemeris data of the satellite. The data 180, may be a binary-coded message containing values that are herein referred to as “+A” and “−A.” The message may be transmitted at a low frequency rate and may provide the navigation information. The value of +A can be 1 and the value of −A can be −1 or 0. The carrier wave may be modulated by the date portion 180 during transmission of the signal 150.
The signal 150 may further have a primary code 160. The primary code 160 may be a ranging code containing a relatively long known sequence of values that are herein referred to as “+B” and “−B.” The value of +B can be a value of 1 and −B can be a value of −1. The transmitter 110 may modulate the carrier wave using the primary code. The primary code 160 may be specific to the satellite and transmitted at higher rate than the data 180. The primary code 160, also called pseudo-random noise (PRN) code, allows precise ranging so that multiple satellites, or transmitters, can broadcast signals at the same frequencies, which can be deciphered using CDMA technology. Typically, the values of the PRN codes are called ‘chips’ instead of ‘bits’, to emphasize that they do not carry information, unlike bits of data 180.
The wireless signal 150 may further include a secondary code 170, which may also be a PRN code. The secondary code 170 is, as indicated by its name, a second code, which multiplies the primary code 160 to form a longer code (called tiered code). The chipping rate of the secondary code 170 is, typically, lower than that of the primary code 160. The values of the secondary code may also be referred to as ‘chips’, since they do not carry data. In
The receiver 120 may search for the presence of signals, such as the signal 150, that travel through space, and try to synchronize with the signals identified from a corresponding transmitter. For example, a GNSS receiver may be a radio navigation user device that identifies and synchronizes with satellite transmitting GNSS signals, so as to demodulate and extract the measurements and navigation information in the received GNSS signals. Since the signal 150 is phase shifted, the receiver 120 may reconstruct the carrier wave 220 and extract the codes and navigation data 180 from the received signal 150. The receiver 120 is designed to be able to determine a shift in the phase of the received signal 150 relative to the transmitted signal. In addition, the receiver 120 may detect and determine the phase offset in the presence of a frequency uncertainty. In another example, the receiver 120 may additionally, or alternatively determine a frequency offset in the received signal 150 relative to the transmitted signal. The phase offset and the frequency offset may be used to synchronize the wireless signal receiver with the transmitter 110.
The receiver 120 may further include an antenna 310, a front end 320, an oscillator 350, a baseband processing unit 370, and an application processing unit 380. The antenna 310 may receive the signal 150 as an analog radio frequency signal. The received signal 150 may be input to the front end 320. The analog signal may be down-converted, filtered, and digitized in the front end section 320. The front end 320 may include a down converter 322, an amplifier unit 324 and an analog to digital converter (ADC) 328 for the operations. The components of the front end 320 may be provided a clock signal from the oscillator 350, which functions as a local clock source of the receiver 120. The front end 320 generates a baseband representation of the signal 150 in a desired spectrum, such as an intermediate frequency (IF) spectrum, containing real and complex components, namely I (In-Phase) and Q (Quadrature) components, in baseband. The baseband representation may be forwarded to the baseband processing unit 370.
The baseband processing unit 370 is responsible for the signal processing tasks to be performed on the digital signal. The baseband processing unit may also be responsible for determining code delay and carrier phase and frequency measurements in order to obtain the data 180 in the received signal 150. Accordingly, the baseband processing unit 370 may have to identify a starting point and/or endpoint of the components of the received wireless signal 150. Although, the primary code 160 and secondary code 170 may have values that are known to the receiver 120, the codes may be continuously repeated during the transmission. The received wireless signal 150 may also have shifted in phase and/or frequency, relative to the originally transmitted wireless signal due to several factors. For example, Doppler effect (relative movement of the receiver with respect to the transmitter), environmental effects, interference with other signals, and other such factors may introduce a delay, or an offset which may, in turn, cause the received wireless signal 150 to be shifted relative to the transmitted signal. Further, the oscillator 350, or clock source may not be precisely synchronous with a clock source used by the transmitter 110, which may cause a phase offset between the received signal and generated local signals.
Once the baseband processing unit 370 determines the offsets, contents of the signal 150, may be forwarded on to the application processing unit 380. The application processing unit 380 may use the data 180 to provide navigation related information to a user, or to another system or device in communication with the receiver 120. For example, the data 180 may be used to provide a geographic location of the receiver 120, which may be displayed to the user via a display unit. Alternatively, or in addition, the geographic location may be transmitted to a separate system, or device, such as a server computer that may use the geographic location information to provide related information to the user. For example, the server computer may provide points of interest in the vicinity of the geographic location of the receiver 120. Various other applications of the navigation information contained within the data 180 are possible.
Therefore, the receiver 120, such as a GNSS receiver, using the baseband processing unit 370, may perform a synchronization operation, which may be part of a signal acquisition operation.
The baseband processing unit 370, using the primary code correlator 375, may correlate the incoming signal 150, in the baseband form provided by the front end 320, with a replica of the expected signal to extract the primary code 160. The local signal generator 372 may generate the replicas of the expected signal. The locally generated expected signal may include similar components as described with reference to
As part of the synchronization operation, the secondary code correlator 377 may determine offsets associated with the received secondary code 170. The secondary code 170 may be associated with one or both of a frequency offset and a code offset. A ‘frequency offset’ refers to the frequency difference between the received secondary code 150 and a locally generated expected secondary code. ‘Code offset’ or ‘phase offset’ refers to the degree of time synchronization between the received secondary code 170 and the locally generated secondary code.
Therefore, the synchronization may further involve the search for signal energy over a multitude of hypothesized secondary code offsets, and a multitude of hypothesized frequency offsets applicable to the secondary code 170. This is typically visualized as a 2 dimensional search, with one dimension being frequency offset and the other dimension being code offset. Traditional approaches to secondary code synchronization in the presence of large frequency uncertainty involve computation of the energy associated with coherently and non-coherently integrated versions of the prompt correlator, or the primary code correlator output. The energy can be calculated over a two dimensional grid of secondary code phase offset and frequency offset hypotheses. The secondary code phase/frequency offset pair which results in the highest energy form the basis of estimates for secondary code phase and frequency offset, respectively. A full two-dimensional search over both secondary code phase as well as frequency offset may potentially be associated with excessive computational complexity. In addition, unless some additional processing is carried out, the quality of the frequency estimate is limited by the frequency hypothesis bin spacing. Also, secondary code phase estimation is degraded at frequency offsets relatively far from the nearest frequency bin hypotheses (for example, half way between adjacent frequency bin hypotheses).
However, the receiver 120 may determine the code offset and the frequency offset by a search over a single dimension, such as the secondary code offsets, thus determining the offsets in a more computationally efficient manner. The receiver 120 may achieve the efficiency by searching for secondary code phase offset in the secondary code chip transition domain. Compared to conventional techniques, the disclosed techniques described throughout this document and employed by the example receiver 120 may provide more accurate and resource-efficient secondary code phase synchronization and frequency estimation of signals, such as GNSS signals, in the presence of frequency uncertainty.
The primary code correlator 375 output at a kth received Coarse Acquisition (C/A) epoch comprises of signal and noise component:
yk=sk+nk k∈Z+ (1)
where Z+ is the set of non-negative integers, sk is the signal and nk is the noise component.
The signal component may be further expressed as:
where A, ω, and θ are the signal amplitude, frequency (in radians per C/A epoch), and phase, respectively. In addition, TC/A and Tb are the C/A epoch interval and bit interval, respectively, while N is the number of C/A epochs spanning a bit interval. Lastly, bm is the mth transmitted BPSK symbol, pk is the kth sample of a secondary code chip modulated sequence of duration Tb, and φ is the bit phase offset.
The noise component, of Equation 1 may be further expressed as:
nkCN(0, σ2) σ2=E[|nk−E[nk]|2]=E[|nk|2]
Modeled as a realization of an independent, identically distributed (IID) sequence of circularly complex normal random variables of zero mean and variance δ2, where E[•] denotes statistical expectation.
Given, the above mathematical expressions, determining the phase offset of the output of the primary code correlator 375 involves estimating the secondary codephase offset φ, given a length-K sequence {yk}k=0K−1.
A traditional two-dimensional search grid over N hypothesized secondary code phase offsets and Q hypothesized frequency offsets may be expressed as:
Assuming that the received samples span an integer number of bits/secondary code repetitions: K=PN where P is an integer greater than one. Therefore, a merit function, that expresses the search that needs to be performed to determine the code phase offset, of the traditional two-dimensional approach, is:
The arguments, {circumflex over (φ)}, {circumflex over (ω)}, which jointly maximize the merit function are deemed as the detected secondary code phase offset and estimated frequency offset, which is mathematically expressed as:
The receiver 120 may detect and determine the code phase offset and estimated frequency offset in a more efficient manner by searching a single dimension, unlike the two dimensional search expressed in the merit function of equation 5. The receiver 120 may determine the code phase offset and the estimated frequency offset by operating in the secondary code chip transition domain via complex conjugate products of the prompt correlator outputs coherently integrated to the C/A epoch. The complex conjugate product may be correlated against delayed versions of an appropriately defined reference sequence corresponding to the expected conjugate products in the absence of noise and frequency errors. Alternatively, delayed versions of the complex conjugate product may be correlated against an appropriately defined reference sequence corresponding to the expected conjugate products in the absence of noise and frequency errors. The complex conjugate products and/or the reference secondary code sequence may be delayed using delays that correspond to the different secondary code phase hypotheses. The correlation results are either a constructive or destructive summing according to the sign of corresponding chip transitions. The correlations may also be referred to as cross-correlations.
A magnitude of the resulting correlations may be computed. The magnitude may be the absolute value of the final chip transition domain correlation operation. The delay corresponding to the correlation with the largest magnitude may be used to estimate the secondary code phase offset. The phase associated with the correlation with largest magnitude may be used to estimate the frequency offset. Based on the identified cross-correlation, a one dimensional search over secondary code phase offsets may provide the code phase offset and the frequency offset of the secondary code. Moreover, frequency estimates may be generated with minimal additional computation, and with accuracy.
lk=yk+1y*k k∈{0, 1, . . . , K−2} (6)
where, (.)* denotes complex conjugation.
Alternatively, in cases where a residual frequency offset is small, the real parts of the prompt correlator outputs may be integrated to the C/A as shown in equation 6A.
lk=Re{yk+1y*k} k∈{0, 1, . . . , K−2} (6A)
Further, the receiver 120 may compute one or more reference secondary signal sequences (408). A reference secondary code sequence may be an N element lag-one secondary code chip product sequence. An example reference secondary code dk, may be expressed as:
dk=c(k+1)mod NC*k k∈{0, 1, . . . , N−1}. (7)
The generated reference signals may be correlated with delayed versions of the complex conjugate product (410, 414). For example, based on different hypotheses of the code phase offsets {circumflex over (φ)}, correlations of the generated reference signals and the delayed versions of the complex conjugates may be computed. A single dimensional merit function, representative of the operation may be expressed as:
Alternatively, the hypothesized code phase offsets may be used to generate delayed versions of the reference code sequences represented by dk (480), and the merit function may involve correlations of the delayed versions of the reference secondary code sequence and the complex conjugate products of the prompt correlator outputs coherently integrated to the primary code epoch (484). For lag-one products, value of p in 404 may be 1. However, the receiver may form the merit function based on some combination of lag-p conjugate products, where p≧1.
A magnitude of the resulting correlations may be computed. The correlation with maximum magnitude may be identified (440). The delay associated with the maximum magnitude correlation may be used to determine the phase offset. For example, the associated delay may be output as the secondary code phase offset (460). The detected secondary code phase offset {circumflex over (φ)}, may then be expressed as
and, the frequency offset {circumflex over (ω)}, may be estimated with essentially no additional computation based on the resulting correlations. For example, the frequency offset may be computed as the arctangent of the correlation with the maximum amplitude:
{circumflex over (ω)}=∠(V{circumflex over (φ)}). (10)
Alternatively, or in addition, the frequency offset may be calculated based on a weighted combination of multiple high peaks to estimate the frequency at those delays. For example, a subset of the resulting correlations may be selected to calculate the frequency offset. The subset may include a predetermined number of correlations. The correlations selected in the subset may be based on a predetermined magnitude threshold. For example, correlations above the predetermined magnitude threshold may be selected as the subset for determining the frequency offset. Alternatively, or in addition, other criteria to select the subset of correlations may be used.
In an example, the receiver 120 may excise the complex conjugate products straddling bit-boundaries by using a variation of the merit function, such as:
The excising may avoid impact of data bit transitions at the true secondary code phase offset.
Thus, the receiver 120 may detect and determine the code phase offset and the frequency offset based on the complex conjugate product sequence and the one or more reference secondary code sequences, using a single dimension search.
The methods, devices, and logic described above may be implemented in circuitry in many different ways and in many different combinations of hardware, or both hardware and software. For example, all or parts of the system may include circuitry that includes a controller, a microprocessor, and/or an application specific integrated circuit (ASIC), or circuitry may be implemented with discrete logic or components, or a combination of other types of analog or digital circuits, combined on a single integrated circuit or distributed among multiple integrated circuits. All or part of the logic described above may be implemented as instructions for execution by circuitry that may include a processor, controller, or other processing device and may be stored in circuitry that includes a tangible or non-transitory machine-readable or computer-readable medium such as flash memory, random access memory (RAM) or read only memory (ROM), erasable programmable read only memory (EPROM) or other machine-readable medium such as a compact disc read only memory (CDROM), or magnetic or optical disk. Thus, a product, such as a computer program product, may be circuitry that includes a storage medium and computer readable instructions stored on the medium, which when executed in an endpoint, computer system, or other device, cause the device to perform operations according to any of the description above.
The circuitry may further include or access instructions for execution by the circuitry. The instructions may be stored in a tangible storage medium that is other than a transitory signal, such as a flash memory, a Random Access Memory (RAM), a Read Only Memory (ROM), an Erasable Programmable Read Only Memory (EPROM); or on a magnetic or optical disc, such as a Compact Disc Read Only Memory (CDROM), Hard Disk Drive (HDD), or other magnetic or optical disk; or in or on another machine-readable medium. A product, such as a computer program product, may include a storage medium and instructions stored in or on the medium, and the instructions when executed by the circuitry in a device may cause the device to implement any of the processing described above or illustrated in the drawings.
The implementations may be circuitry distributed among multiple system components, such as among multiple processors and memories, optionally including multiple distributed processing systems. Parameters, databases, and other data structures may be separately stored and managed, may be incorporated into a single memory or database, may be logically and physically organized in many different ways, and may be implemented in many different ways, including as data structures such as linked lists, hash tables, arrays, records, objects, or implicit storage mechanisms. Programs may be parts (e.g., subroutines) of a single program, separate programs, distributed across several memories and processors, or implemented in many different ways, such as in a library, such as a shared library (e.g., a Dynamic Link Library (DLL)). The DLL, for example, may store instructions that perform any of the processing described above or illustrated in the drawings, when executed by the circuitry.
Various implementations have been specifically described. However, many other implementations are also possible.
This application claims priority to provisional application Ser. No. 61/975,309, filed Apr. 4, 2014, which is incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
20070245206 | Martin et al. | Oct 2007 | A1 |
20090196329 | Legate et al. | Aug 2009 | A1 |
20100061427 | Lopez-Risueno et al. | Mar 2010 | A1 |
20100142593 | Schmid | Jun 2010 | A1 |
20110261805 | Landry et al. | Oct 2011 | A1 |
20130257652 | Mattos | Oct 2013 | A1 |
Entry |
---|
Choi, Z.Y., Lee, Y.H., “Frame Synchronization in the Presence of Frequency Offset,” pp. 1-4, IEEE Transactions on Communications, vol. 50, No. 7, Jul. 2002, © 2002 IEEE. |
Macabiau, C., Ries, L., Bastide, F., Issler, J-L., GPS L5 Receiver Implementation Issues, pp. 153-164, Proceedings of the 16th International Technical Meeting of the Satellite Division of the Institute of Navigation (ION GPS/GNSS 2003), Portland, OR, Sep. 9-12, 2003. |
Tahir, M., LoPresti, L., “Performance Analysis of Pre-correlation Differential Acquisition Scheme,” pp. 1-8, Satellite Navigation Technologies and European Workshop on GNSS Signals and Signal Processing (NAVITEC), 2012 6th ESA Workshop on, Dec. 5-7, 2012 © 2012 IEEE. |
Number | Date | Country | |
---|---|---|---|
20150288416 A1 | Oct 2015 | US |
Number | Date | Country | |
---|---|---|---|
61975309 | Apr 2014 | US |