GEOG 862
GPS and GNSS for Geospatial Professionals

Code Correlation

Code Correlation: Showing Time Shift for Correlation
Code Correlation
Source: GPS for Land Surveyors

Strictly speaking, a pseudorange observable is based on a time shift. This time shift can be symbolized by , d tau, and is the time elapsed between the instant a GPS signal leaves a satellite and the instant it arrives at a receiver. The concept can be illustrated by the process of setting a watch from a time signal heard over a telephone.

Propagation Delay

Imagine that a recorded voice said, “The time at the tone is 3 hours and 59 minutes.” If a watch was set at the instant the tone was heard, the watch would be wrong. Supposing that the moment the tone was broadcast was indeed 3 hours and 59 minutes, the moment the tone is heard must be a bit later. It is later because it includes the time it took the tone to travel through the telephone lines from the point of broadcast to the point of reception. This elapsed time would be approximately equal to the length of the circuitry traveled by the tone divided by the speed of the electricity, which is the same as the speed of all electromagnetic energy, including light and radio signals. In fact, it is possible to imagine measuring the actual length of that circuitry by doing the division.

In GPS, that elapsed time is known as the propagation delay and it is used to measure length. The measurement is accomplished by a combination of codes. The idea is somewhat similar to the strategy used in EDMs. But where an EDM generates an internal replica of its modulated carrier wave to correlate with the signal it receives by reflection, a pseudorange is measured by a GPS receiver using a replica of a portion of the code that is modulated onto the carrier wave. The GPS receiver generates this replica itself and it is used to compare with the code that is coming in from the satellite.

Code Correlation

To conceptualize the process, one can imagine two codes generated at precisely the same time and identical in every regard: one in the satellite and one in the receiver. The satellite sends its code to the receiver but, on its arrival, the codes do not line up even though they are identical. They do not correlate, that is until the replica code in the receiver is time shifted a little bit. Once that is done, the receiver generated replica code fits the received satellite code. It is this time shift that reveals the propagation delay. The propagation delay is the time it took the signal to make the trip from the satellite to the receiver, dτ. It is the same idea described above as the time it took the tone to travel through the telephone lines, except the GPS code is traveling through space and atmosphere. Once the time shift of the replica code is accomplished, the two codes match perfectly and the time the satellite signal spends in transit has been measured, well, almost. It would be wonderful if that time shift could simply be divided by the speed of light and yield the true distance between the satellite and the receiver at that instant, and it is close. But there are physical limitations on the process that prevent such a perfect relationship.


As mentioned earlier, the almanac information from the NAV message of the first satellite a GPS receiver acquires tells it which satellites can be expected to come into view. With this information, the receiver can load up pieces of the C/A codes for each of those satellites. Then the receiver tries to line up the replica C/A codes with the signals it is actually receiving from the satellites. The time required for correlation to occur is influenced by the presence and quality of the information in the almanac. Actually lining up the code from the satellite with the replica in the GPS receiver is called autocorrelation, and depends on the transformation of code chips into code states. The formula used to derive code states (+1 and -1) from code chips (0 and 1) is:

code state = 1-2x

where x is the code chip value. For example, a normal code state is +1, and corresponds to a code chip value of 0. A mirror code state is -1, and corresponds to a code chip value of 1. The function of these code states can be illustrated by asking three questions: First, if a tracking loop of code states generated in a receiver does not match code states received from the satellite, how does the receiver know? In that case, for example, the sum of the products of each of the receiver’s 10 code states, with each of the code states from the satellite, when divided by 10, does not equal 1. Second, what does the receiver do when the code states in the receiver do not match the code states received from the satellite? It shifts the frequency of its search a little bit from the center of the L1 1575.42 MHZ. This is done to accommodate the inevitable Doppler shift of the incoming signal since the satellite is always either moving toward or away from the receiver. The receiver also shifts its piece of code in time. These iterative small shifts in both time and frequency continue until the receiver code states do in fact match the signal from the satellite. Third, how does the receiver know when a tracking loop of replica code states does match code states from the satellite? In the case illustrated in the image, the sum of the products of each code state of the receiver’s replica 10, with each of the 10 from the satellite, divided by 10, is exactly 1. In the image, before the code from the satellite and the replica from the receiver are matched, the sum of the products of the code states is not 1. Following the correlation of the two codes, the sum of the code states is exactly 1, and the receiver’s replica code fits the code from the satellite like a key fits a lock.

We see in the image of how the pseudorange, the PRN Code, functions, and some similarities to what we discussed with the EDM. You see here that in the red the satellite signal coming down as a square wave in code states; minus 1 and plus 1. In the receiver, there's a replica of a portion of that code, a portion of the C/A Code just as was the case with an EDM holding a replica back home to compare to the incoming signal In this case, the signal is coming directly down from the satellite and is received at the GPS receiver. The GPS receiver has this piece of replica code that can function something like a key in a lock. It tries to match that piece of code to the code coming in from the satellite. The attempt is evaluated by simple multiplication. A minus 1 times a minus 1 is a plus 1. You can see this little calculation here. Then 10 of these individual multiplications are divided by 10. In the first instance at the upper tier the result is 0.4. It is not 1.

However, in the next instance, the piece of code is slid over a bit and tried again. The calculation yields exactly 1 this time. When the result is exactly 1 there is correlation. There's a time shift here. You notice how the blue square wave can be shifted over, and there it is in the lower tier. It is shifted over and it matches. The key fits in the lock and the receiver knows that it is correlated to the incoming signal.

The interesting thing about this is that that time shift for correlation gives the receiver the amount of time. This time is approximately the amount of elapsed time that it took the signal to come from the satellite to the receiver. Obviously, if the receiver knows the elapsed time and it knows the frequency of the signal, it then knows the distance (the range) between itself and the satellite.

This is how the pseudorange works. This is the way that the distance is derived by solving the time that it took the signal to come from the satellite to the receiver. The receiver then generates that replica code and it shifts it until it fits into the received code. The time it took the signal to make the trip to the receiver is about that amount of shift and, therefore, this is the solution. However, if this were the whole story, we'd be done, and of course, it isn't the whole story.