Galileo Signal (GPS and Galileo Receiver) Part 3

Message Structure

This section outlines the Galileo message structure.

Frames and Pages

The message is composed of frames, see Figure 3.8. The frame is composed of several subframes, and each subframe again is composed of several pages. The page is the basic structure for the navigation message and contains the following fields:

- a synchronization word (SW),

- a data field,

- a cyclic redundancy check (CRC) bits for error detection, and

- tail bits for the forward error correction (FEC) encoder containing all zeros. CRC and data encoding are used to provide better signal and data integrity. For L1 OS the synchronization word is a fixed 10-bit sequence. All data are encoded using the following bit and byte ordering:

- for numbering, the most significant bit/byte is numbered as bit/byte 0,

- for bit/byte ordering, the most significant bit/byte is transmitted first.

In Figure 3.9 the most significant bit is placed left, the less significant bit is placed to the right, the most significant items at the top, and the less significant items at the bottom.

Cyclic Redundancy Check

The CRC algorithm accepts a binary data frame, corresponding to a polynomial M , and appends a checksum of r bits, corresponding to a polynomial C.

Ordering principle for data.


FIGURE 3.9. Ordering principle for data.

The concatenation of the input frame and the checksum then corresponds to the polynomialtmp2D520_thumb[2][2]since multiplying bytmp2D521_thumb[2][2]corresponds to shifting the input frame r bits to the left. The algorithm chooses the checksum C such that T is divisible by a predefined polynomial P of degree r, called the generator polynomial.

The algorithm dividestmp2D522_thumb[2][2]by P and sets the checksum equal to the binary vector corresponding to the remainder. That is, iftmp2D523_thumb[2][2]. where R is a polynomial of degree less than r, then C = R and the checksum is the binary vector corresponding to R. If necessary, the algorithm preceds zeros to the checksum so that it has length r. The MATLAB CRC generator does the following:

1. Left-shift the input frame by r bits and divide the corresponding polynomial by P.

2. Set the checksum equal to the binary vector of length r corresponding to the remainder from step 1.

3. Append the checksum to the input data frame. The result is the output frame.

The CRC algorithm uses binary vectors to represent binary polynomials, in descending order of powers. For example, the vectortmp2D524_thumb[2][2]represents the polynomialtmp2D525_thumb[2][2]

Example 3.1 Suppose the input frame istmp2D526_thumb[2][2]corresponding to the polynomialtmp2D527_thumb[2][2]and the generator polynomial istmp2D528_thumb[2][2]

tmp2D529_thumb[2][2]of degree r = 3. By polynomial divisiontmp2D530_thumb[2][2] Remember that any binary number added to itself in a modulo-2 field yields zero. The remainder is R = x so that the checksum is then Note that an extra 0 is added on the left to make the checksum have length 3.

Forward Error Correction and Block Interleaving

The starting point is a digital information source (transmitter) that sends a data sequence comprising k bits of data to an encoder. Employing forward error-correction coding, the encoder inserts redundant bits, thereby outputting a longer sequence of n code bits called a codeword. At the receiving end, codewords are used by a suitable decoder to extract the original data sequence.

 Viterbi convolutional coding scheme.

FIGURE 3.10. Viterbi convolutional coding scheme.

In general, codes are designated with the notation (n, k) according to the number of n output code bits and k input data bits. The ratio k/n is called the rate of the code and is a measure of the fraction of information contained in each code bit.

Figure 3.10 describes the Viterbi convolutional coding scheme used for Galileo. The Viterbi convolutional coding of all data channels is characterized by the following values: coding rate = 1 /2, constraint length 7, generator polynomials

tmp2D545_thumb[2][2]and encoding sequencetmp2D546_thumb[2][2]and thentmp2D547_thumb[2][2] That is, there are taps at seven points along the encoder shift register, and it generates two encoded channel symbols for each input data bit. Note thattmp2D548_thumb[2][2] (octal) is 001111001 in binary andtmp2D549_thumb[2][2](octal) is 001011011 in binary.

We observe that fortmp2D550_thumb[2][2]the taps 1, 4, 5, 6, and 7, numbered from right to left, are connected to modulo-2 adders and for G2 the taps 1, 2, 4, 5, and 7 are connected to modulo-2 adders. The error-correcting power is related to the constraint length, increasing with longer lengths of shift register.

After the Viterbi convolutional encoding block follows an interleaving procedure. The purpose of interleaving is to increase the efficiency of the convolutional coding by spreading the burst errors in order to improve the correction capacity of the specific convolutional decoding algorithm applied in the receiver.

Normally interleaving is implemented by using a two-dimensional buffer array. The data enter the buffer array row by row and are then read out column by column. The result of the interleaving process is ideal if a burst of errors in the communication channel after de-interleaving becomes spaced single-symbol errors, which are easier to correct than consecutive ones.

Example 3.2 Below we illustrate how an input data stream is read, column by column, into an array and then read out, row by row, to achieve the bit interleaving operation:

- Data input

tmp2D557_thumb[2][2]

- Interleaving array

tmp2D558_thumb[2][2]

TABLE 3.2. Galileo ephemeris parameters

Parameter

No. of Bits

Scale Factor

Unit

tmp2D-559

32

tmp2D-560

semicircle

tmp2D-561

16

tmp2D-562

semicircle/s

tmp2D-563

32

tmp2D-564

dimensionless

tmp2D-565

32

tmp2D-566

mi/2

tmp2D-567

32

tmp2D-568

semicircle

tmp2D-569

32

tmp2D-570

semicircle

tmp2D-571

32

tmp2D-572

semicircle

tmp2D-573

24

tmp2D-574

semicircle/s

tmp2D-575

14

tmp2D-576

semicircle/s

tmp2D-577

16

tmp2D-578

radian

tmp2D-579

16

tmp2D-580

radian

tmp2D-581

16

tmp2D-582

m

tmp2D-583

16

tmp2D-584

m

tmp2D-585

16

tmp2D-586

radian

tmp2D-587

16

tmp2D-588

radian

tmp2D-589

14

tmp2D-590

s

tmp2D-591

9

tmp2D-592

- Interleaved data output for transmission

tmp2D593_thumb[2][2]

This block interleaving has interleaving depth 4. In this simple example three consecutive errors in the transmitted data, let us saytmp2D594_thumb[2][2]are translated into three isolated, single errors in the de-interleaved data.

Message Contents

The freely accessible navigation message on L1 OS contains all parameters necessary to compute the position of a Galileo satellite, clock correction parameters, parameters for conversion of Galileo System Time (GST) to UTC and GPS Time (GPST), and service parameters including an almanac.

A Galileo ephemeris contains 17 parameters as defined in Table 3.2. The unit semicircle is converted to radian by multiplication withtmp2D596_thumb[2][2]

A Galileo ephemeris is valid for four hours. Every three hours a new ephemeris is uploaded. Hence an overlap of one hour occurs. And four ephemerides cover a 12-hour orbit prediction.

The geocentric coordinatestmp2D598_thumb[2][2]of satellite k (the superscript k denotes satellite k, and not the power k) at timetmp2D599_thumb[2][2]are given astmp2D602_thumb[2][2]

For a definition of the parameterstmp2D603_thumb[2][2]see Figure 8.5. The quantities

tmp2D604_thumb[2][2]are evaluated for t according to the following procedure:

tmp2D607_thumb[2][2]

As usual the mean Earth rotation rate is denotedtmp2D608_thumb[2][2]This algorithm is similar to the one for GPS and is coded as the M-file satpos. The function computes the position of any Galileo satellite at any time. It is fundamental to every position calculation.

Next post:

Previous post: