# **Digital GPS Signal Generator for L1 Band**

Kota Solomon Raju, Y. Pratap and P. Bhanu Prasad

#### Central Electronics Engineering Research Institute (CEERI) / Council of Scientific and Industrial Research (CSIR) Pilani-333031, India

solomon@ceeri.ernet.in, pratap.sost.iiit@gmail.com, bhanu@ceeri.ernet.in

#### ABSTRACT

This paper deals with the generation of GPS signals using FPGA based Xilinx System Generator 9.2. We have considered L1 frequency band as it is mainly used for commercial, civil aviation and other purposes. Once the GPS signals are generated in the simulated laboratory environment we can test the proper working of multichannel GPS receiver which is an extension of this project. After we obtain accurate laboratory results, we can go for real GPS signals. The board that has been used for the hardware implementation is Lyrtech SFF-SDR board, which is having three functional layers. The bottom layer is the digital signal-processing layer, middle layer is the ADAC MASTER III layer and the upper layer is RF layer having a transmission and receiving capacity of 1 GHz. This will lead to the development of indigenous digital GPS signal generator using reconfiguration.

#### **KEY WORDS**

GPS, FPGA, multichannel, SFF-SDR, ADAC MASTER III, RF, reconfiguration.

#### **1. INTRODUCTION**

GPS stands for Global Positioning System and it was started in the year 1973 by the US department of defense. It was made commercial for civil aviation in the early 1990's. GPS is a satellite based navigation system, which is used to find the position of an object across the earth by giving its coordinates. Currently GPS consists of 32 satellites of which 24 are for working and the rest eight are kept spare to replace any of these 24 satellites in case of malfunction or damage to them. These 24 satellites revolve around the earth surface in six predetermined orbits each orbit having four satellites. The satellites are not placed equidistant in a given orbit. Each orbit makes an angle of 60° with the equator of the earth so as to complete total 360°. The orbital radius is 26560 km and time taken for one complete revolution is 11 hrs 57 mins and 57.26 secs [1]. In this paper, implementation of digital GPS signal generator using Xilinx system generator 9.2 has been dealt. First the GPS signal has been explained followed by each and every component of GPS signal. Then each component has been built using Xilinx system generator 9.2 and tested and finally complete GPS signal generator has been built and tested on hardware using Lyrtech SFF-SDR board.

## 2. GPS SIGNAL

GPS signals are modulated signals, which are transmitted by the GPS satellites in the UHF band of 500 MHz to 3 GHz over two frequencies, i.e. L1 and L2 driven by a common clock of 10.23 MHz. The frequencies for the L1 and L2 are as shown below [1]:

| $L1 = 1575.42 \text{ MHz} = 154 \times 10.23 \text{ MHz}$ | (1) |
|-----------------------------------------------------------|-----|
|-----------------------------------------------------------|-----|

$$L2 = 1227.60 \text{ MHz} = 120 \times 10.23 \text{ MHz}$$
 (2)

The GPS signals are a combination of three main parts namely the carrier frequency, navigation data and the spreading sequence namely the C/A code and P code. The carrier frequencies for the L1 and L2 band are stated above. The navigation data is the main component that has to be actually transmitted because it contains information about the satellite orbits [2]. The C/A code stands for coarse acquisition, which is useful in detecting from which satellite the signal is coming and P code is used to track the signals once the signals have been acquired. The signal structure for a particular GPS satellite 'k' is given as [2]:

$$S^{k}(t) = \sqrt{2Pc} \left( C^{k}(t) \phi D^{k}(t) \right) \cos(2\pi f L_{1} t) + \sqrt{2P_{PL1}} \left( P^{k}(t) \phi D^{k}(t) \right) \sin(2\pi f L_{1} t) + \sqrt{2P_{PL2}} \left( P^{k}(t) \phi D^{k}(t) \right) \sin(2\pi f L_{2} t)$$
(3)

Here we can observe that the GPS satellite signal is a combination of various power levels of its different components. We can see the power levels for both L1 and L2 and also navigation data which is to be transmitted is shown as  $D^k$ . The power levels for the components are shown in the table below [1].

|    | Р        | C/A      |
|----|----------|----------|
| L1 | -133 dBm | -130 dBm |
| L2 | -136 dBm | -136 dBm |

**Table 1. Power Level of GPS Signals** 

Binary Phase Shift Keying (BPSK) modulation has been used for the signal propagation. The main reason for going for BPSK modulation, when other modulation techniques are available, is that the transmitter and receiver are much easier to build and the demodulator is able to withstand highest level of noise before it starts giving error [3]. The Doppler frequency for the carrier frequency is about 4.9 KHz and that for C/A code is 3.2 Hz. Doppler frequency is the change in the observed frequency of a source due to the relative motion between the source and the receiver [4].

#### **3. GPS SIGNAL AND BPSK MODULATION FOR L1 FREQUENCY**

The pictorial representation of GPS signal structure is shown below [5]:





Fig. 1. GPS Signal Structure

The above picture shows the various components of GPS signal for L1 band. First component is the carrier frequency having 1575.42 MHz driven by a common frequency of 10.23 MHz. The C/A code is having a frequency of 1.023MHz and it repeats itself every 1 ms [2].

$$t = \frac{1023}{1.023 \times 10^6} = 1 \, ms \tag{4}$$

1023 is the number of chips in the C/A code which tells us about the phase. The P code is having a frequency of 10.23 MHz and it repeats itself every GPS week, which starts around midnight of Saturday or Sunday. The third component is the navigation data which contains all the information about the satellite orbits and pseudo range from which satellite position and finally user position can be found out by using triangulation method. It has a data rate of 50 bps. In order for a modulated signal to propagate, all the signal components should be an integral multiple of a frequency which is clearly shown here, as 1575.42, 1.023 and 10.23 are integral multiples of 1.023. The effect of BPSK modulation is as shown below [2]:



Fig. 2. Effect of BPSK Modulation on Carrier Signal

The above figure shows the effect of BPSK modulation on the carrier signal. First the C/A code and Navigation data signals are XORed by using modulo-2 operation. The resultant signal is multiplied with the carrier signal. It can be observed wherever there is a change in the XORed signal, a 180° phase shift occurs in the final signal.

### 4. C/A CODE GENERATOR FOR GPS SATELLITES

The main purpose of a coarse acquisition (C/A) code is to find, at the GPS receiver side, from which satellite the signal is coming. Each satellite transmits a C/A code, which is unique for that satellite. The pictorial representation of C/A code generator is as shown below [1]:



Fig. 3. C/A code Generator for Satellite 31

C/A code generator for satellite 31 consists of two linear feedback shift registers (LFSRs) each consisting of ten unit cells or delay units, which are initialized to a value of 1 which indicates the phase. LFSR generates a maximal length sequence of  $N=2^n-1$  elements, where n=10. These two LFSRs are based on the GPS polynomials given as:

$$G1 = 1 + x^3 + x^{10} \tag{5}$$

$$G2 = 1 + x^{2} + x^{3} + x^{6} + x^{8} + x^{9} + x^{10}$$
(6)

The powers of the above polynomials indicate the tapping or the delays at that particular unit cell in the LFSRs. The tappings in each LFSR are XORed and the output is given as feedback to the first unit cell. These LFSRs are driven by a common clock of 1.023 MHz. In order to find out the signal from a particular satellite, phase selector is used. Different satellites have different phase selectors which show the delay in the C/A code generation for each satellite. This further helps in identifying the satellite signals. The different phase selectors for all the GPS satellites are shown as below [1]:

| Satellite ID | GPS PRN<br>Signal | Code Phase selection | Code Delay<br>Chips |  |  |  |
|--------------|-------------------|----------------------|---------------------|--|--|--|
| Number       | Number            |                      | 1                   |  |  |  |
| 1            | 1                 | $2 \oplus 6$         | 5                   |  |  |  |
| 2            | 2                 | 3 🕀 7                | 6                   |  |  |  |
| 3            | 3                 | 4 🕀 8                | 7                   |  |  |  |
| 4            | 4                 | 5 🕀 9                | 8                   |  |  |  |
| 5            | 5                 | 1                    | 17                  |  |  |  |
| 6            | 6                 | 2   ① 10             | 18                  |  |  |  |
| 7            | 7                 | 1 🕀 8                | 139                 |  |  |  |
| 8            | 8                 | $2 \oplus 9$         | 140                 |  |  |  |
| 9            | 9                 | 3 🕀 10               | 141                 |  |  |  |
| 10           | 10                | 2 ⊕ 3                | 251                 |  |  |  |
| 11           | 11                | 3 🕀 4                | 252                 |  |  |  |
| 12           | 12                | $5 \oplus 6$         | 254                 |  |  |  |
| 13           | 13                | $6 \oplus 7$         | 255                 |  |  |  |
| 14           | 14                | 7 🕀 8                | 256                 |  |  |  |
| 15           | 15                | 8 🕀 9                | 257                 |  |  |  |
| 16           | 16                | 9 <b>⊕</b> 10        | 258                 |  |  |  |
| 17           | 17                | 1 \oplus 4           | 469                 |  |  |  |
| 18           | 18                | 2 🕀 5                | 470                 |  |  |  |
| 19           | 19                | 3                    | 471                 |  |  |  |

Table 2. C/A Code Phase Assignment

| 20 | 20 | 4 🕀 7         | 472 |
|----|----|---------------|-----|
| 21 | 21 | 5 🕀 8         | 473 |
| 22 | 22 | $6 \oplus 9$  | 474 |
| 23 | 23 | 1 \oplus 3    | 509 |
| 24 | 24 | $4 \oplus 6$  | 512 |
| 25 | 25 | 5 🕀 7         | 513 |
| 26 | 26 | $6 \oplus 8$  | 514 |
| 27 | 27 | $7 \oplus 9$  | 515 |
| 28 | 28 | 8             | 516 |
| 28 | 28 | $1 \oplus 6$  | 859 |
| 30 | 30 | 2 🕀 7         | 860 |
| 31 | 31 | 3 🕀 8         | 861 |
| 32 | 32 | $4 \oplus 9$  | 862 |
| -  | 33 | 5 <b>⊕</b> 10 | 863 |
| -  | 34 | 4 ⊕ 10        | 950 |
| -  | 35 | 1 🕀 7         | 947 |
| -  | 36 | 2 🕀 8         | 948 |
| -  | 37 | 4 ⊕10         | 950 |

Signal & Image Processing : An International Journal (SIPIJ) Vol.3, No.6, December 2012

| The C/A   | code | generator | model | developed | using | Xilinx | System | Generator | 9.2 | is | as | shown | in |
|-----------|------|-----------|-------|-----------|-------|--------|--------|-----------|-----|----|----|-------|----|
| figure 4. |      |           |       |           |       |        |        |           |     |    |    |       |    |



Fig. 4. C/A Code Generator for Satellite 31

Here we have used Xilinx block sets to develop the model for the satellite 31. For each LFSR we have taken 10-memory unit or delay unit blocks from the Xilinx block sets. Each of these blocks is initialized to a binary value of 1 which denotes the initial phase. As can be seen, these blocks are driven by a clock of 1.023 MHz. These two linear feedback shift registers are designed based upon the two polynomials G1 and G2 explained earlier. The tappings in the figure 4 indicate the delay which are XORed and given as feedback to the first memory unit of the respective LFSR.

We have also developed a model for coarse acquisition (C/A) codes for all the satellites as can be seen in figure 5. This model is partly based on the sub model developed by Dick Benson in his complete GPS receiver model [6]. In this model, phase selectors of all the satellites are multiplexed so that we can handle C/A codes from any given satellite at a given instant of time. As can be seen, VPSS (video processing sub system) block of TMS320DM6446SoC (Davinci processor) is used. This block is very important for hardware implementation of any model as it helps in hardware interface of the FPGA(Xilinx) blocks with the DSP on the hardware.



Fig. 5. C/A Code Generator for all the Satellites

## 5. P CODE

The P code, as already mentioned, is used to track the satellite signals once the GPS receiver acquires them. The P code is generated by using four linear feedback shift registers which are paired. These LFSRs can be denoted as X1A, X1B, X2A, and X2B. One PRN (pseudorandom noise) sequence has 15345000 chips and a period of 1.5 seconds, the other has 15345037 chips, and the difference is 37 chips [1]. P code repeats itself every GPS week starting around midnight of Saturday/Sunday. The LFSRs are based on the equations given by the GPS society as below [7]:

$$X1A = 1 + x^{6} + x^{8} + x^{11} + x^{12}$$
(7)  

$$X1B = 1 + x^{1} + x^{2} + x^{5} + x^{8} + x^{9} + x^{10} + x^{11} + x^{12}$$
(8)  

$$X2A = 1 + x^{1} + x^{3} + x^{4} + x^{5} + x^{7} + x^{8} + x^{9} + x^{10} + x^{11} + x^{12}$$
(9)  

$$X2B = 1 + x^{2} + x^{3} + x^{4} + x^{8} + x^{9} + x^{12}$$
(10)

As in the case of C/A code the powers in the equations indicate the tappings to the memory unit cells. These are XORed and given as feedback to the first unit cell of each LFSR. The model developed for P code using system generator 9.2 is shown below in figure 6.



Fig. 6. P Code Generator

The unit cells or the memory units in the LFSRs are initialized to the values given by the GPS society and are given below:

X1A is initialized at *000100100100* and X1B is initialized at *010101010100*. X2A is initialized at *100100100101* and X2B is initialized at *010101010100*.

# 6. NAVIGATION DATA

The basic structure of a navigation data is shown in fig. 7. [1].



Fig. 7. Navigation Data Structure

Navigation data is transmitted in the L1 frequency at a bit rate of 50 bps. It repeats itself every 20 ms. So the time taken for transition of one navigation bit is equivalent to the time of transition of 20 C/A codes, since one C/A code is transmitted every 1 ms. The basic unit in a navigation data is the frame which consists of 1500 bits. Each frame is divided into 5 sub frames of 300 bits each. Each sub frame can be divided into 10 words of 30 bits each. The time for transmission of one sub frame is 6 secs and in a frame first 3 sub frames repeat themselves and the rest two sub frames have same structure but different data (25 different versions). So the time for transmission of one entire navigation message is 5\*6\*25 i.e. 750 secs or twelve and half minutes.

The sub frame 1 consists of satellite clock and health data. It tells us at what time the signals is transmitted from the satellite and also whether the data is correct or not. Sub frame 2 and 3 contain information about satellite ephemeris data i.e. it gives us information about the satellite orbits that are used for finding satellite positions. Sub frames 4 and 5 contain almanac data i.e. ephemeris and clock data with reduced precision.

# 7. GPS SIGNAL GENERATOR MODEL USING XILINX



The model developed for complete GPS signal generator is shown figure 8.

Fig. 8. GPS Signal Generator

The various components of GPS signal are shown in fig. 8. Here the C/A code and the navigation data are XORed using modulo-2 operation. We can generate the navigation data by using a free running counter or a count limited one. We can also use a pulse generator for generating the

navigation data. Navigation data is having a bit rate of 50 bps. The result is XORed with P code. Finally BPSK modulation is done between this resultant signal and the carrier frequency which is having a frequency of 1575.42 MHz. The resultant final GPS signal is sent to the hardware by VPSS (video processing sub system).

## 8. HARDWARE AND SOFTWARES USED

The implementation is done using Lyrtech SFF-SDR board[8]. It is conceived and designed to be used for developing software defined radios. The board is composed of three layers: digital processing, ADAC MASTER III and RF module. The digital processing module has Virtex-4 SX35 FPGA and a TMS320DM6446SoC to implement custom IP and acceleration functions with varying requirements from one protocol to another supported on the same hardware. The ADAC Master III layer has an inbuilt ADC and DAC. ADC is having resolution of 14 bit and sampling frequency of 125 MSPS while DAC is having a resolution of 16 bits and a sampling frequency of 500 MSPS. The RF layer is having a transmission capacity of 1 GHz. The board is as shown in figure 9.



Fig. 9. Lyrtech SFF-SDR board

The software packages used are Matlab 2007a, Xilinx ISE 9.2, System Generator 9.2 and ADP 3.2.0 by Lyrtech.

# 9. RESULTS AND FUTURE WORK

Generation of carrier frequency:

Figure 10 shows the generation of the carrier frequency 1575.42 MHz for L1 band. We have taken a common clock of 10.23 MHz for generating this frequency. On this carrier frequency navigation data and C/A code are modulated by using the BPSK modulation.



Signal & Image Processing : An International Journal (SIPIJ) Vol.3, No.6, December 2012



Generation of C/A (Gold)code:

Here we have generated the Gold code or the C/A code for the satellite 31. The phase selector used for this operation is a modulo-2 combination of  $3^{rd}$  and  $8^{th}$  unit cells of second Linear Feedback Shift Register.



Fig. 11. PRN (Gold) Code

Generation of GPS Signal:



Figure 12 shows the final GPS signal obtained.

Fig. 12. GPS Signal

Currently the results are being checked for their authentication on the hardware. Once completed, real time GPS signals will be considered for further implementation of GPS receiver.

#### **10. CONCLUSION**

An implementation of Digital GPS signal generator for L1 band using Lyrtech SFF-SDR board and other utilities is described. This implementation will lead to the development of indigenous GPS signal generator.

#### ACKNOWLEDGEMENT

The work reported in this paper is part funded by CSIR under Supra Institutional Project (SIP 21) of CEERI. We would like to thank Dr. Chandra Shekhar, Director, CSIR-CEERI, Pilani, India and Mr. Satish Mohanty Ph.D. Student, BITS, Pilani, India.

#### REFERENCES

- [1] James Bao-Yen Tsui,"Fundamentals of Global Positioning System Receivers", 2nd edition, Wiley-Interscience, pp. 24, 31, 69, 70, 74, 77 and 79; 2005.
- [2] Kai Borre, Akos, Nicolaj, Rinder, Jensen, "A Software Defined GPS and Galileo Receiver", Birkhauser, pp.17, 19 and 21; 2007.
- [3] BPSK Modulation[Online]: Available at: http://en.wikipedia.org/wiki/Phase-shift\_keying
- [4] Doppler Effect[Online] Available at: http://www.usna.edu/Users/physics/ejtuchol/Chapter19.pdf
- [5] Thiam Hock Tan, Global Positioning System Signal Simulation, University of Queensland, Australia, 2003.
- [6] Dick Benson, "The Design and Implementation of a GPS Receiver Channel", DSP magazine, pp.52, Oct. 2005.
- [7] Navstar GPS Space Segment/Navigation User Interfaces, ARINC Engineering Services, LLC, CA, USA, March 7, 2006.
- [8] User's guide on Lyrtech Small Form Factor SDR Evaluation Module/Development Platform, October 2008.