TECHNICAL FIELD
The invention is related to a GNSS signal acquisition method based on FPGA step-by-step code phase refinement, and belongs to the technical field of satellite positioning and navigation.
BACKGROUND ART
The satellite positioning technology is widely used in daily production, life and military fields, and can provide all-weather real-time positioning, navigation and timing services. A satellite positioning system generally comprises three parts, space segment, ground segment and user reception equipment segment respectively. Among them, the user reception equipment is used to receive satellite signals, and to realize satellite positioning finally through acquisition, tracking, location computation and other processing of the signals. The purpose of acquisition and processing in the reception equipment is to identify all visible satellites, obtain the rough carrier frequency and code phase of the satellite signals, and provide initial values for the tracking loop, thus laying a basis for the realization of satellite positioning.
So far, user receivers realized by software have been very mature and can develop complex algorithms quickly with good flexibility. However, they are limited by the slow signal processing speed.
FPGA has abundant hardware resources and features parallel signal processing, fast computation speed, high flexibility and a short development cycle. Therefore, it is of great significance to study the implementation of receivers on FPGA.
In FPGA implementation of traditional acquisition algorithms, the amount of data to be processed is affected by the sampling rate of the satellite IF signals. A greater sampling rate is associated with a larger amount of data in unit time, which may result in too large a computation load and the hardware resources required exceeding the standard. Therefore, it is often necessary to carry out down-sampling treatment at the beginning of data processing. Down-sampling, however, will affect the correlation properties between the data and local codes, resulting in some errors in the output carrier frequency and code phase value, though it can reduce the computation load and the required resources. When too large errors occur, the subsequent tracking loop will become unable to be locked, making the acquisition results unusable.
Most of the existing methods used to reduce code phase errors are to reduce the search step size in the time domain after completion of frequency domain search for research, which spends a long time on acquisition and consumes a lot of resources.
DESCRIPTION OF THE INVENTION
To address the shortcomings of the existing technologies, the invention provides a GNSS signal acquisition method based on FPGA step-by-step code phase refinement.
The invention divides the acquisition process into two steps: coarse acquisition and fine acquisition. The coarse acquisition is used for parallel code phase search for down-sampling. After obtaining the code phase and carrier frequency of the coarse acquisition, the data of some points are obtained from the chip in front of the coarse acquisition code phase. After eliminating the influence of the carrier, the data is correlated with a part of local pseudo-random code to find the exact code phase corresponding to the maximum correlation value. This kind of step-by-step code phase refinement acquisition method can not only reduce the error of code phase, but also reuse the original acquisition module, thus reducing acquisition time and saving hardware resources.
Explanation of Terms
1. Frequency mixing: It refers to the process of mixing two signals of different frequencies to get a signal of the third frequency by using nonlinear operations. In the present invention, a multiplier is used to multiply the input signals modulated with cosine signals and the locally generated sine and cosine signals to achieve the purpose of frequency mixing.
2. Orthogonal mixing: It refers to the process of multiplying the input signals and the orthogonal sine and cosine signals for mixing.
The Technical Solution of the Invention Is As Follows
A GNSS signal acquisition method based on FPGA step-by-step code phase refinement, which runs in an acquisition system comprising a local oscillator, a down-sampling module, a Fourier transform module, a local pseudo-random code generator, an inverse Fourier transform module, and a controller. The local oscillator is used to generate orthogonal local sine and cosine carrier signals; the down-sampling module is used to down sample long signals with high sampling rate into short signals averagely; the Fourier transform module and inverse Fourier transform module are used to realize the corresponding mathematical operations; the local pseudo-random code generator is used to generate local pseudo-random codes for different satellites; and the controller is used to control the data acquisition, the down-sampling rate, and the acquisition of a part of the local pseudo-random code according to the results of the last acquisition. After the input signal is multiplied by the orthogonal two carrier signals generated by the local oscillator for mixing, the down-sampling module conducts down sampling for the two output signals. After down sampling, the two output signals will be used as real part and imaginary part input signals for the Fourier transform module respectively to obtain intermediate signal I through Fourier transform. At the same time, the local pseudo-random code generator generates a local pseudo-random code which will be input into the Fourier transform module after down sampling in the down-sampling module. Then, intermediate signal II is obtained after taking the conjugate of the signals output by the Fourier transform module. The intermediate signal I is then input into the inverse Fourier transform module for Fourier inverse transform after being multiplied by the intermediate signal II. After modulo operation and square operations, a correlation value will be output for acquisition judgment. The judgment result is then input into the controller for control of the next acquisition. The specific steps are as follows:
- A. coarse acquisition:
- 1) Take a N-point GNSS signal r(n) (sampling frequency: fs), and multiply it by the sine and cosine carrier signals sin(2πfcarry) and cos (2πfcarrygenerated by the local oscillator for frequency mixing respectively to get two data, respectively I and Q. The said N-point GNSS signal is a signal that contains a complete pseudo-random code period, while the said complete pseudo-random code period shall contain n chips. fs ≥ 2fI, where: f1 is the center frequency of the digital signal being processed; fcarry = f1 - |fDoppler| | + Δ • i, where fDoppler is the frequency offset caused by the Doppler effect, and is generally±10 KHz; Δ is the step size for carrier frequency search, which is user-defined and generally 500 Hz; and
- 2) Conduct M-point uniform down-sampling for the two data I and Q obtained from Step (1) , and use the results as real part and imaginary part respectively for M-point fast Fourier transform (FFT); M is an integer power of 2 and M < N;
- 3) Conduct M -point uniform down-sampling for the locally generated pseudo-random code (sampling frequency of fs), and take the conjugate of the result after the Fourier transform operation;
- 4) Multiply the fast Fourier transform (FFT) result from Step (2) by the conjugate result of the pseudo-random code from Step (3) to get Y(k), and then conduct M-point inverse fast Fourier transform (IFFT);
- 5) Perform modulus and square operations on the result from Step (4) to get the sequence of correlation values of the GNSS signal with the local carrier and the local pseudo-random code. Then find the maximum value Max and the secondary maximum SecondMax in the correlation value sequence. If Max ≥ 3 × Second_Max, the coarse acquisition can be judged as completed. Then, the frequency of the local carrier is just the carrier value of the coarse acquisition, and the position of the maximum value Max in the correlation value sequence is just the coarse acquisition code phase value. If so, continue with Step (6). Otherwise, return to Step (1); increase the i in Step (1) by 1, change the frequency of the orthogonal carrier signals generated by the local oscillator for the next frequency search.
- B. Fine acquisition:
- 6) Feedback the carrier value and the coarse acquisition code phase value obtained from the coarse acquisition in Step (5) to the controller; the controller controls the input of data by reading a N′-point (M ≤ N′ < N) part of the GNSS signal data from the chip in front of the coarse acquisition code phase value obtained from the coarse acquisition and multiply it by the carrier value obtained from the coarse acquisition for orthogonal mixing to eliminate the influence of the carrier and get the two data I1 and Q1;
- 7) Conduct M-point uniform down-sampling for the two data I1 and Q1 obtained from Step (6) under the control of the controller, and use the results as real part and imaginary part respectively for M-point fast Fourier transform (FFT);
- 8) After controlling the local pseudo-random code generator to sample at the frequency of fs, the controller takes a N′-point part of the pseudo-random code (the same long as that in Step (6)) for M-point uniform down-sampling and fast Fourier transform (FFT) operation, and then takes the conjugate;
- 9) Multiply the data after fast Fourier transform (FFT) from Step (7) by the conjugated data after fast Fourier transform (FFT) from Step (8) for inverse fast Fourier transform (IFFT) operation;
- 10) Perform modulus and square operations on the result from Step (9) to get the correlation values of the GNSS signal with the local carrier and the local pseudo-random code. Then find the position corresponding to the maximum correlation value. If the position differs from that of the last acquisition by less than one chip, the fine acquisition can be judged as effective. Then, the position corresponding to the maximum correlation value is just the code phase obtained by the fine acquisition. The fine acquisition ends when N′ = M is met. Otherwise, return to Step (6), and take the chip in front of the code phase of the fine acquisition as starting position of the next fine acquisition to continue with fine acquisition by reducing the data length.
According to a preferred embodiment of the invention, the said M-point uniform down-sampling comprises the steps as follows:
- The data of FFT operation must be an integer power of 2. When the amount of data of FFT operation is too large, the time required to complete the computation and the hardware resources consumed will become too large to bear, so the data generally need to be down-sampled.
- where: m refers to the number of original data points contained in each down-sampled data point, also known as down-sampling multiple;
- When m is an integer, add up every m data as a data point;
- When m is not an integer, the following relational expressions are satisfied, as shown in equation (I):
- Where: α and b are integers that are closest to the m respectively; x is the number of summation times for every α consecutive points; and y is the number of summation times for every b consecutive points. α-point summation and b-point summation are to be distributed evenly across the data to complete uniform down-sampling. In fine acquisition, the data length may be selected as an integer power of 2 to facilitate down-sampling while avoiding affecting the code phase refinement degree at the same time.
According to a preferred embodiment of the invention, the said controller is used to control the input of different lengths of data for each fine acquisition, which comprises steps as follows:
- A. The first fine acquisition: According to the coarse acquisition code phase value, IndexCA (0 < IndexCA < M) obtained by coarse acquisition, the fine acquisition begins to read Nʹ points of data from the position pos1 (pos1 = ceil(N/M) × IndexCA — ceil(N/n), where: ceil(.) is a function of rounding up to an integer and M ≤ N′ < N - pos1). The maximum correlation value in the first fine acquisition corresponds to the position of the code phase Index’CA obtained from the first fine acquisition;
- B. The second fine acquisition: According to the code phase value, IndexʹCA (0 < IndexʹCA < M), the second fine acquisition begins to read N″-point data from the position pos2 ( M ≤ N″ < Nʹ; pos2 = pos1+ ceil (Nʹ/M)× IndexʹCA - ceil(N/n));
- Repeat the above until N″-ʹ= M, namely refining to the highest accuracy.
According to a preferred embodiment of the invention, the said controller controls the M-point uniform down-sampling for different lengths of data in each fine acquisition process, which comprises steps as follows: The controller calculates the down-sampling multiples according to the number of points of the input data:
- C. The first fine acquisition uses a down-sampling multiple of N′/M= m′, and conducts M-point uniform down-sampling according to the value of m′;
- D. The second fine acquisition uses a down-sampling multiple of N″/M = m″, and conducts M-point uniform down-sampling according to the value of m″;
- Repeat the above until N″...ʹ= M, namely refining to the highest accuracy.
According to a preferred embodiment of the invention, the said controller is used to control the generation of different lengths of local pseudo-random codes in each fine acquisition, which comprises steps as follows: the controller controls the local pseudo-random code generator to generate a pseudo-random code at the sampling frequency of fs and then takes a part of the pseudo-random code with the same length as the input data size above for M-point uniform down-sampling.
According to a preferred embodiment of the invention, the M -point fast Fourier transform (FFT) formula is as shown in equation (II):
Where: k = 0,1,2, ..., M — 1; x(m) is a discrete sequence for which the FFT operation is to be performed; X(k) is the result of the discrete Fourier transform; and j is an imaginary unit.
According to a preferred embodiment of the invention, the M-point inverse fast Fourier transform (IFFT) formula is as shown in equation (III):
Where: m = 0,1,2 ..., M — 1; y(m) is the discrete sequence obtained by the inverse Fourier transform; and j is an imaginary unit.
The beneficial effects of the invention are as follows:
- 1. The invention proposes a GNSS signal acquisition method based on FPGA step-by-step code phase refinement, which can reduce the number of FFT operation points through down-sampling in the coarse acquisition process. As FFT operation points are proportional to the computation load, the acquisition time, and the required hardware resources, a reduced number of FFT points will greatly reduce the computation load of acquisition, save acquisition time, and reduce hardware resources.
- 2. The invention proposes a GNSS signal acquisition method based on FPGA step-by-step code phase refinement, which takes a part of the data and a part of the pseudo-random code for correlation operation in the fine acquisition process to reduce the computation load, and thus can improve the code phase accuracy compared to the coarse acquisition.
- 3. The invention proposes a GNSS signal acquisition method based on FPGA step-by-step code phase refinement, which can reuse the coarse acquisition operation module in the fine acquisition process without adding new hardware resource consumption.
BRIEF DESCRIPTION OF THE FIGURES
FIG. 1 is the functional block diagram of the GNSS signal acquisition method based on FPGA step-by-step code phase refinement in the invention.
FIG. 2 is the overall flow diagram of the GNSS signal acquisition method based on FPGA step-by-step code phase refinement in the invention.
DETAILED EMBODIMENTS
The invention is further described in combination with the attached figures and embodiments as follows, but is not limited to that.
Embodiment
A GNSS signal acquisition method based on FPGA step-by-step code phase refinement (as shown in FIG. 2), which runs in an acquisition system (as shown in FIG. 1) comprising a local oscillator, a down-sampling module, a Fourier transform module, a local pseudo-random code generator, an inverse Fourier transform module, and a controller. The local oscillator is used to generate orthogonal local sine and cosine carrier signals; the down-sampling module is used to down sample long signals with high sampling rate into short signals averagely; the Fourier transform module and inverse Fourier transform module are used to realize the corresponding mathematical operations; the local pseudo-random code generator is used to generate local pseudo-random codes for different satellites; and the controller is used to control the data acquisition, the down-sampling rate, and the acquisition of a part of the local pseudo-random code according to the results of the last acquisition. After the input signal is multiplied by the two orthogonal carrier signals generated by the local oscillator for mixing, the down-sampling module conducts down sampling for the two output signals respectively. After down sampling, the two output signals will be used as real part and imaginary part input signals for the Fourier transform module respectively to obtain intermediate signal I through Fourier transform. At the same time, the local pseudo-random code generator generates a local pseudo-random code which will be input into the Fourier transform module after down sampling in the down-sampling module. Then, intermediate signal II is obtained after taking the conjugate of the signal output by the Fourier transform module. The intermediate signal I is then input into the inverse Fourier transform module for Fourier inverse transform after being multiplied by the intermediate signal II. After modulus operation and square operation, a correlation value will be output for acquisition judgment. The judgment result is then input into the controller for control of the next acquisition. The embodiment takes the application of digital intermediate frequency signal processing in the GPS receiver as an example, which comprises steps are as follows:
- A. coarse acquisition:
- 1) Take a 16368-point GNSS signal r(n) (sampling frequency:fs = 16.3676 MHz), and multiply it by the sine and cosine carrier signals sin(2πfcarry) and cos (2πfcarry) generated by the local oscillator for frequency mixing respectively to get two data, respectively I and Q. fI is the center frequency of the digital signal being processed; fcarry = FI- |fDoppler| + Δ • i, where fDoppler is the frequency offset caused by the Doppler effect and is generally±10KHz; Δ is the step size for carrier frequency search, which is user-defined and generally500 Hz; and
- 2) Conduct 1024-point uniform down-sampling for the two data I and Q obtained from Step (1) , and use the results as real part and imaginary part respectively for 1024-point fast Fourier transform (FFT);
- 3) Conduct 1024-point uniform down-sampling for the locally generated pseudo-random code (C/A Code) with length of 16368 and sampling frequency of fs = 16.3676 MHz, and take the conjugate of the result after performing 1024-point Fourier transform operation;
- 4) Multiply the fast Fourier transform (FFT) result from Step (2) and the conjugate result of the pseudo-random code (C/A code) from Step (3) to get Y(k), and then conduct 1024-point inverse fast Fourier transform (IFFT);
- 5) Perform modulus and square operations on the result from Step (4) to get the sequence of correlation values of the GNSS signal with the local carrier and the local pseudo-random code. Then find the maximum value Max and the secondary maximum SecondMax in the correlation value sequence. If Max ≥ 3 × Second_Max, the coarse acquisition can be judged as completed. Then, the frequency of the local carrier is just the carrier value of the coarse acquisition fI, and the position of the maximum value Max in the correlation value sequence is just the coarse acquisition code phase value IndexCA(0 < IndexCA < 1024). If so, continue with Step (6). Otherwise, return to Step (1); increase the i in Step (1) by 1; change the frequency of the orthogonal carrier signal generated by the local oscillator for the next frequency search.
- The coarse acquisition process can reduce the number of FFT operation points through down-sampling. As FFT operation points are proportional to the computation load, the acquisition time, and the required hardware resources, a reduced number of FFT points will greatly reduce the computation load of acquisition, save acquisition time, and reduce hardware resources. Where the input signal sampling frequency fs = 16.3676 MHz and the signal length is 1 ms, FFT operations have to be done for a total of 16,368 points if without down-sampling treatment; while if down-sampled to 1024 points, FFT operations only need to be done for 1024 points, which can reduce the number of operation points by 15 times.
- B. fine acquisition:
- 6) Feedback the carrier value f and the coarse acquisition code phase value IndexCA obtained from the coarse acquisition in Step (5) to the controller; the controller controls the input of data by reading an 8192 — point part of the GNSS signal data from the chip position pos1(pos1 = 16 × IndexCA — 16) in front of the coarse acquisition code phase value obtained from the coarse acquisition and multiply it by the carrier value obtained from the coarse acquisition for orthogonal mixing to eliminate the influence of the carrier and get the two data I1 and Q1.
- 7) Conduct 1024-point uniform down-sampling for the two data I1 and Q1 obtained from Step (6) under the control of the controller, and use the results as real part and imaginary part respectively for 1024-point fast Fourier transform (FFT);
- 8) After controlling the local pseudo-random code generator to sample at the frequency of fs= 16.3676 MHz, the controller takes an 8192-point (the same long as that in Step (6)) part of the pseudo-random code (C/A code) for 1024-point uniform down-sampling and fast Fourier transform (FFT) operation, and then takes the conjugate of the result;
- 9) Multiply the data after fast Fourier transform (FFT) from Step (7) by the conjugated data after fast Fourier transform (FFT) from Step (8) for inverse fast Fourier transform (IFFT) operation;
- 10) Perform modulus and square operations on the result from Step (9) to get the correlation values of the GNSS signal with the local carrier and the local pseudo-random code. Then find the position corresponding to the maximum correlation value. If the position differs from that of the last acquisition by less than one chip, the fine acquisition can be judged as effective. Then, the position corresponding to the maximum correlation value is just the code phase obtained by the fine acquisition. The data length acquired at this time is 8192, which is still larger than 1024. Therefore, the obtained code phase value still has an error caused by down-sampling, and needs to be further refined.
- 11) Conduct the second fine acquisition. Feedback the code phase Index’CAobtained from the first acquisition in Step (10) to the controller, so that the controller can control the input of data by reading a 4096 — point part of the signal data from the chip position pos2 (pos2 = pos1 + 8 × lndex′CA — 16) in front of the code phase obtained from the coarse acquisition and multiply it by the carrier value obtained from the coarse acquisition for orthogonal mixing to eliminate the influence of the carriers and get the two data I and Q.
- 12) Conduct 1024-point uniform down-sampling for the two data I and Q obtained from Step (11) under the control of the controller, and use the results as real part and imaginary part respectively for 1024-point fast Fourier transform (FFT);
- 13) After controlling the local pseudo-random code generator to sample at the frequency of fs = 16.3676 MHz, the controller takes a 4096-point (the same long as that in Step (11)) part of the pseudo-random code (C/A code) for 1024-point uniform down-sampling and fast Fourier transform (FFT) operation, and then takes the conjugate of the result;
- 14) Multiply the data after FFT from Step (12) by the conjugated data after FFT from Step (13) for IFFT operation;
- 15) Perform modulus and square operations on the result from Step (14) to get the correlation values of the received data with the local carriers and the local pseudo-random code (C/A code). Then find the position corresponding to the maximum correlation value that meets the threshold requirement. As a code phase with a higher accuracy (IndexʺCA(0 < IndexʺCA < 1024)), the data length acquired at this time is 4096, which is still larger than 1024. Therefore, the obtained code phase value still has an error caused by down-sampling, and needs to be further refined.
- 16) Conduct the third fine acquisition. Feedback the code phase IndexʺCA obtained from the second acquisition in Step (15) to the controller, so that the controller can control the input of data by reading a 2048 — point part of the signal data from the chip position pos3 (pos3 = pos2 + 4 × IndexʺCA — 16) in front of the code phase obtained from the coarse acquisition and multiply it by the carrier value obtained from the coarse acquisition for orthogonal mixing to eliminate the influence of the carrier and get the two data I and Q.
- 17) Conduct 1024-point uniform down-sampling for the two data I and Q obtained from Step (16) under the control of the controller, and use the results as real part and imaginary part respectively for 1024-point fast Fourier transform (FFT);
- 18) After controlling the local pseudo-random code generator to sample at the frequency of f= 16.3676 MHz, the controller takes a 2048-point (the same long as that in Step (16)) part of the pseudo-random code (C/A code) for 1024-point uniform down-sampling and fast Fourier transform (FFT) operation, and then takes the conjugate of the result;
- 19) Multiply the data after FFT from Step (17) by the conjugated data after FFT from Step (18) for IFFT operation;
- 20) Perform modulus and square operations on the result from Step (19) to get the correlation values of the received data with the local carrier and the local pseudo-random code (C/A code). Then find the position corresponding to the maximum correlation value that meets the threshold requirement. As a code phase with a higher accuracy
- the data length acquired at this time is 2048, which is still larger than 1024. Therefore, the obtained code phase value still has an error caused by down-sampling, and needs to be further refined.
- 21) Conduct the forth fine acquisition. Feedback the code phase
- obtained from the third acquisition in Step (20) to the controller, so that the controller can control the input of data by reading a 1024 — point part of the data from the chip position pos4 (pos4 = pos3 + 2 ×
- — 16) in front of the code phase obtained from the coarse acquisition and multiply it by the carrier value obtained from the coarse acquisition for orthogonal mixing to eliminate the influence of the carrier and get the two data I and Q.
- 22) After controlling the local pseudo-random code generator to sample at the frequency of fs = 16.3676 MHz, the controller takes a 1024-point (the same long as that in Step (21)) part of the pseudo-random code (C/A code) for fast Fourier transform (FFT) operation, and then takes the conjugate of the result;
- 23) Multiply the data after FFT from Step (21) by the conjugated data after FFT from Step (22) for IFFT operation;
- 24) Perform modulus and square operations on the result from Step (23) to get the correlation values of the received data with the local carrier and the local pseudo-random code (C/A code). Then find the position corresponding to the maximum correlation value that meets the threshold requirement. As a code phase with a higher accuracy
- the data length acquired at this time is 1024, which is equal to the number of points for down-sampling. Therefore, the obtained code phase value has no error caused by down-sampling, and the fine acquisition is completed. The final result of the obtained code phase ispos5 = pos4 +
The fine acquisition process of the invention takes a part of the data and a part of the pseudo-random code for correlation operation, and thus can reduce the computational load and improve the code phase accuracy compared to the coarse acquisition. Similarly, when the sampling frequency of the input signal is fs = 16.3676 MHz and the signal length is 1 ms, the coarse acquisition process needs to down sample a complete data that contains 16368 points to 1024 points, and the code phase resolution is 16 × 1/fs. If the first fine acquisition takes 8196 points of the data, and down sample them to 1024 points, the code phase resolution will be 8 × 1/fs’ which improves the code phase accuracy by one time compared to that of the coarse acquisition. With the help of the second, third and other subsequent fine acquisitions, the code phase accuracy will increase with the decrease of the sampling number and the down-sampling multiple until the maximum code phase accuracy is reached, that is, the code phase resolution equals to 1/fs.
In this embodiment, the process of uniformly down sampling the 16,368 points in Steps (2) and (3) to 1024 points is as follows:
Solution:
Namely, summation of 15 consecutive points needs to be performed for16 times, while summation of 16 consecutive points needs to be performed 1008 times. In order to uniformly down sample the data, the 16 positions of summation of 15 consecutive points shall be uniformly distributed in the whole data segment. The specific positions are shown in Table 1:
TABLE 1
ith summation of 15 consecutive points
Position of the summation of 15 consecutive points
ith summation of 15 consecutive points
Position of the summation of 15 consecutive points
|
1
1008
9
9192
|
2
2031
10
10215
|
3
3054
11
11238
|
4
4077
12
12261
|
5
5100
13
13284
|
6
6123
14
14307
|
7
7146
15
15330
|
8
8169
16
16353
|
In this embodiment, 1024-point down-sampling is performed for the 8192 points of data in Steps (7) and (8) as follows: as
(8 is an integer), the sum of 8 consecutive data points can be directly taken as a data point after sampling.
Similarly, in this embodiment, 1024-point down-sampling is performed for the 4096 points of data in Steps (12) and (13) as follows: as
the sum of 4 consecutive data points can be directly taken as a data point after sampling.
Similarly, in this embodiment, 1024-point down-sampling is performed for the 2048 points of data in Steps (17) and (18) as follows: as
the sum of 2 consecutive data points can be directly taken as a data point after sampling.