Digital signal processor and processing method for GPS receivers by Thomas, Jr., Jess B.
United States Patent [191 [11] Patent Number: 4,821,294 
Thomas, Jr. [45] Date of Patent: Apr. 11, 1989 
[54] DIGITAL SIGNAL PROCESSOR AND 
PROCESSING METHOD FOR GPS 
RECEIVERS 
[75] Inventor: Jess B. Thomas, Jr., La Canada, 
Calif. 
[73] Assignee: California Institute of Technology, 
Pasadena, Calif. 
[21] Appl. No.: 71,121 
[22] Filed: Jul. 8, 1987 
[51] Int. (3 .4  ............................................... H04B 7/01 
[52] US. C1. ...................................... 375/96; 342/352; 
375/1; 375/97 
[58] Field of Search ....................... 375/1, 96, 97, 115; 
342/352, 357, 358; 364/459,728; 370/104, 
455/12, 13 
1561 References Cited 
U.S. PATENT DOCUMENTS 
4,112,372 9/1978 Holmes et al. .......................... 375/1 
4,361,891 11/1980 Lobenstein et al. .................... 375/1 
4,494,238 1/1985 Groth, Jr. ............................... 375/1 
4,530,103 7/1985 Mosley, Jr. et al. .................... 375/1 
4,633,426 12/1986 Venier ................................... 375/96 
4,701,934 10/1987 Jasper ...................................... 375/1 
Primary Examiner-Benedict V. Safourek 
Attorney, Agent, or Firm-Leonard Tachner 
[571 ABSTRACT 
A digital signal processor and processing method there- 
SAMPLE CLOCK 
for for use in receivers of the NAVSTAFVGLOBAL 
POSITIONING SYSTEM (GPS) employs a digital 
carrier down-converter, digital code correlator and 
digital tracking processor. The digital carrier down- 
converter and code correlator consists of an all-digital, 
minimum bit implementation that utilizes digital chip 
and phase advancers, providing exceptional control and 
accuracy in feedback phase and in feedback delay. 
Roundoff and commensurability errors can be reduced 
to extremely small values (e.g., less than 100 nanochips 
and 100 nanocycles roundoff errors and 0.1 millichip 
and 1 millicycle commensurability errors). The digital 
tracking processor bases the fast feedback for phase and 
for group delay in the C/A, Pi, and, P2 channels on the 
L1 C/A carrier phase thereby maintaining lock at lower 
signal-to-noise ratios, reducing errors in feedback de- 
lays, reducing the frequency of cycle slips and in some 
cases obviating the need for quadrature processing in 
the P channels. Simple and reliable methods are em- 
ployed for data bit synchronization, data bit removal 
and cycle counting. Improved precision in averaged 
output delay values is provided by carrier-aided data- 
compression techniques. The signal processor employs 
purely digital operations in the sense that exactly the 
same carrier phase and group delay measurements are 
obtained, to the last decimal place, every time the same 
sampled data (Le., exactly the same bits) are processed. 
26 Claims, 12 Drawing Sheets 
I In w
CORRELATION COEFFICIENTS 
COMPLEXSUM] I Q  3’ > a 4
u 
0 
e 
Y 
P NO N QUADRATURE 
I 
2 
? 
N I-BIT LAGS 
I 
T P  INITIALIZES FIRST CHIP 
I 
TP INITIALIZES C, AC 
(50/sac) (50/ssc) 
https://ntrs.nasa.gov/search.jsp?R=20080012359 2019-08-30T03:56:14+00:00Z
U.S. Patent Apr. 11,1989 
z 
W I  
3 W  
I n 1 7---- 
Sheet I of 12 4,821,294 
I 
K 
w 
n 
0 
a 
0 
I n  
I 
I 
I 
I 
21 D 
II : 
I 
I 
I 
I 
I 
!, 
U.S. Patent Apr. 11,1989 Sheet 2 of 12 4,821,294 
I HIGH-SPEED DIGITAL HARDWARE 
I -  
I /sec I rc/a 
I/sec 
L";I' '7- 
EXTRACT 
L1 C/A 
DATA BIT 
COEFFICIENT 
OVER ONE 
COMPUTE 
RES1 D UAL 
CIA DELAY 
I 
rc/o $1 ..I, $f I 
I POLYNOMIAL 1 
I/sec 
47~1 '@P 
I/sec 
I 
-1 
CORRECT P 
SIGN { ~~~~~~~ 
50/sec FOR DATA 
BIT SIGN 
SIGN- 
CORRECTED 
SUMS I I/sec 
COMPUTE 
TOTAL P 
DELAY AND 
PHASE 
FKSTO C/A 
DELAY AND 
PHASE OVER 
LI OR L2 P OUTPUT 
TRACKING I PROCESSOR 
LI C/A OUTPUT 
DELAY AND 
PHASE OVER 
FIG. 2 
US. Patent Apr. 11,1989 Sheet 3 of 12 4,821,294 
> 
UaSa Patent Apr. 11,1989 Sheet 4 of 12 4,821,294 
T 
I 
I 
Q-a w 
z i t  
I 
V 8
v) 
I 
0 
I- 
0 
0 
- 
9 
m 
t m 
a 
a I- 
0 
a 
G 
-I 
W 
0 
W 
m 
I 
CL 
- 
a 
US. Patent Apr. 11,1989 
- I  
Sheet 5 of 12 4,821,294 
o + + + + + + o o - - - - - -  SINE 
I 1 0 0 4  12TH VALUE BINARY 
POINT 
I loo* 12TH VALUE 
LS B (24) 1 
r - 24 BIT FRACTIONAL- PHASE REGISTER 
V 
1 1 0 0 0 1 1 1 0 1 0 0 1 0  1 0 1  
A 
I 0 1 I + I + 1 + + + + o o - - - - - -  
f l  
- 1  
COSINE 
FUNCTION 
1/8 CYCLE 
1m- 
FIG. 6 
SINE 
0 
\ 
COSINE +Ih r. +I 
- 1  
- 
I I 
I I PHASE, CYCLES 0.5 1.0 
- 
>FIG. 5 
W 
U 
a 
a 
U I 
-I 
U t 
(3 n 
n 
W 
W 
P cn 
I 
I 
I 
W cn 
pe 
3 
R 
I 
-l 
12 
8 
2 
W n. 
v) 
U.S. Patent Apr. 11,1989 Sheet 6 of 12 4,821,294 
FEEDBACK COMPUTATIONS: 
COMPUTE MODEL PHASE, 
PHASE RATE, DElAY AND 
DELAY RATE. SET REGIS. 
TERS FOR DIGITAL HARD- 
FRAC[C~+,(c)], INITIAL FRKTDNAL CHIP, C-CHIPS 
A C:+l, CHIP RATE, C-CHIP/C-BIT 
" 
A~:++C~,CARRIER PHASE RATE, CYCLEIC-BIT WARE (SEE NEXT FIG.) 
FRPL: [$r+,(c)], INITIAL CARRIER PHASE, FRACTIONALCYCLE 1 
INCREMENT START TIME 
tn+l=tn+0.02 sec 1 
+n+i1 A t, 50/sec 1 
FIG. 7a 
US. Patent Apr. 11,1989 
$F+(t) POLYNOMIAL kk QUADRATIC ' 
PHASE OVER 1 FITTO PHASE OVER N SUMS FIT TO 
Et, Xt  2 
> Xt3.Zt4 
@, xt4, ct2@ > ONE SECOND SECONDS 
Sheet 7 of 12 4,821,294 
0 L ( t  1 
, '=ImGER 
I/N-SEC 
1 > 
1 > 
25 DATA BITS > DATA BITS 
FROM 2N 2 N WORDS INTO ONE 
WORD WORDS PER N SEC 
. 
V 
DELAY: 
rCia =?'(C)+AT,.~ - r ~ / ~  ALIGN Tc/a(t 
t AND 
TIMETAG: I /s FOR 
POLYNOMIAL FIT TO DELAY t=INTEGER S y  
OVER N 
SECONDS 
TIME TAG 
CORRECT 
QUADRATIC 
I/N-SEC I /s 
++& TERMS 50 2 
L 
' \ L  
TO P PROCESSING 
rc/a I 
At = HARDWARE SUM LENGTH 
I 
PROCESSING 
FIG. 7 b  
U.S. ’atent Apr. 11,1989 
I 
Sheet 8 of 12 
!G 
i? 
Qz 
A i L P 0 a3 u LL - 
4,821,294 
UmSm Patent Apr. 11,1989 Sheet 9 of 12 4,821,294 
a 
U.S. Patent Apr. 11,1989 Sheet 10 of 12 4,S21,294 
: FRAc P-CHIPS [c;+l(P)l 9 F F Z -  TIONAL 
CHIP REGISTER 
XlA, X2A 
X1B x2B INITIALIZE 
P-CODE-GENERATOR < , JI, 52 . 50/s REGISTERS INTEGER 
. "!+I CHIP RATE, P-CHIP/P-BIT 
- 50/s '1 
PART 
SEPARATE MODEL 
CHIP INTO 
INTEGER AND 
FRACTIONAL 
PARTS 
, "&cp,, CARRIER PHASE RATE, CYCLES /P-BIT 
' 50/s 'I 
. mAC[@?+1(p11 INITIAL CARRIER PHASE, FRACTIONAL PART, CYCLES 
' 50/s 2 
#,"+I (PI 
FROM C/A 
5O/sec 
ZI= c D& 
I&Q,p n 
(pRoMpTi 
50/sec n 
'-CHANNEL 
[ION n 
:OEFFICI - 
:NTS 
Db 0; 
:ORRELA- x$m= z@;(P) 1 SUMS I/sec 1 
c 
A@P 
I I/sec \ /
RESIDUAL PHASE: 
FIG. 9a  
W.S. Patent Apr. 11,1989 Sheet 11 of 12 4,821,294 
FROMCA:T I FROMC/A: 
rdf Ilk= ! OR 2 MEASUREDDELAY: k ALIGN TIME TAG k l& t  ) POLYNOMIAL k 
AND CORRECT FIT TO PHASE t = INTEGER SEC 
TERM SECONDS 
I/sec ' I/N-sec I-+ TPg?;mlp)+~Tp FOR QUADRATIC I/sec ' OVER N 
FIG. 9 b  
f p =  10.23 Mht 
fLI = 154*10.23 Mht 
fL2=120*10.23 Mhz 
U.S. Patent Apr. 11,1989 
W 
l& 
z o  
W J  
Sheet 12 of 12 4,821,294 
A 
4 z i  
L-J 
K 
W 
I- 
W w 
"- 
a 
k 
m 
% 
\ 
I 
0 a 
4,821,294 
1 
DIGITAL SIGNAL PROCESSOR AND 
PROCESSING METHOD FOR GPS RECEIVERS 
BACKGROUND OF THE INVENTION 
1. Description 
The invention described herein was made in the per- 
formance of work under a NASA contract, and is sub- 
ject to the provisions of Public Law 96-517 (35 USC 
202) in which the Contractor has elected to retain title. 
2. Field of the Invention 
The present invention relates generally to receivers 
for the Global Positioning System and more specifi- 
cally, to an all-digital GPS signal processor having a 
unique digital tracking processor as well as to a digital 
processing method carried out therein. 
PRIOR ART 
The NAVSTAR/GLOBAL POSITIONING SYS- 
TEM (GPS) will provide extremely accurate three-di- 
mensional position and velocity information to users 
anywhere in the world. The position determinations are 
based on the measurement of the transit time of R F  
signals from a number of satellites selected from a total 
constellation of 18. The signals are modulated with two 
codes: P, which provides for precision measurement of 
transit time; and C/A which provides for crude mea- 
surement of same and for easy lock-on to the desired 
signal. The satellites employ a shaped-beam antenna 
that radiates to a 0-dBic ground antenna near-uniform 
power of at least -163 dBW for the L1 P code and 
-160 dBW for the L1 C/A code. The corresponding 
Lfpower level carrying only the P code is at least - 166 
dBW. 
At least four satellites are required for navigation 
purposes. The visible satellites offering the best geome- 
try can be selected either manually or automatically by 
receivers using ephemeris information transmitted by 
the satellites. Ranges to the observed satellites are deter- 
mined by scaling the signal transit time by the speed of 
light. The transmitted message contains ephemeris pa- 
rameters that enable the user to calculate the position of 
each satellite at the time of transmission of the signal. 
The measurement of range to the satellites made by 
the user with an imprecise clock, is sometimes called 
“Pseudo-range” because it contains a bias of fixed mag- 
nitude in each range estimate due to the clock error. In 
this description, pseudorange will also be referred to as 
group delay. 
The GPS user measures the apparent (pseudo-range) 
transit time by measuring the delay or time shift be- 
tween the pseudorange noise (PRN) code generated in 
the space vehicle and the identical code sequence gener- 
ated by the user receiver, with each synchronized with 
its own clock. The receiver code is shifted until maxi- 
mum correlation is achieved between the two codes; the 
time magnitude of the shaft is the receiver’s measure of 
delay (pseudo-range). 
The navigation signal transmitted from the space 
vehicles consists of two RJ? frequencies, L1 at 1575.42 
MHz and L2 at 1227.6 MHz. The L1 signal is modulated 
with both the P and the C/A pseudo-random noise 
codes in phase quadrature. The Lzsignal is modulated 
with the P code. Both the L1 and L2 signals are also 
continuously modulated with the navigation data-bit 
stream at 50 bps. The functions of the codes are two- 
fold: (a) identification of space vehicles, as the code 
patterns are unique to each space vehicle and are 
matched with like codes generated in the user receiver; 
and (2) the measurement of the navigation signal transit 
time by measuring the phase shift required to match the 
codes. The P code is a long precision code operating at 
5 10.23 Mbps and is difficult to acquire. The C/A (clear 
access) code is a short code, readily acquired, but oper- 
ating at 1.023 Mbps, which provides a more coarse 
measurement of delay. The C/A code is a normally 
acquired first and a transfer is made to the P code. It is 
10 possible, however, for users with precision clocks pre- 
cisely synchronized with GPS time and the approxi- 
mate knowledge of their position (10,OOO ft-20,000 ft) to 
bypass the C/A code and acquire the P code directly. 
The P code generated in each space vehicle is a pseu- 
l5 do-random noise chip sequence of seven days in length. 
In order for the ground receiver to lock onto the P 
code, it must know approximately what time-slice in the 
seven-day code to search. At typical receiver search 
rates, on the order of 50 bits per second, the time re- 
2o quired to search as much as one second of the seven-day 
P code would require many hours. It is therefore neces- 
sary to resort to the C/A code for initial code match 
and lock-on when good a priori information on receiver 
position, clock offsets and satellite position is not avail- 
The C/A code is a pseudo-random noise chip stream 
unique in pattern to each space vehicle that repeats 
every millisecond. It is relatively easy for a receiver to 
3o match and lock onto the C/A code because the search 
is limited to the time interval of one millisecond and the 
chip rate is only one-tenth that of the P code. The P 
code frequency affords the degree of accuracy required 
for the measurement of signal transit time that the C/A 
The navigation message contains the data that the 
user’s receiver requires to perform the operations and 
computations for successful navigation with the GPS. 
The data include information on the status of the space 
40 vehicle; the time synchronization information for the 
transfer from the C/A to the P code; and the parameters 
for computing the clock correction, the ephemeris of 
the space vehicle and the corrections for delays in the 
propagation of the signal through the atmosphere. In 
45 addition, it contains almanac information that defines 
the approximate ephemerides and status of all the other 
space vehicles, which is required for use in signal acqui- 
sitions. The data format also includes provisions for 
special messages. 
SUMMARY OF THE INVENTION 
There components have been combined in the pres- 
ent invention to produce an all-digital GPS signal pro- 
cessor with outstanding accuracy, high dynamic track- 
55 ing, versatile integration times, lower loss-of-lock signal 
strengths and infrequent cycle slips. The three compo- 
nents are: Digital chip advancer; carrier down-con- 
verter and code correlator; and digital tracking proces- 
sor. 
A highly accurate, all digital correlator and down 
converter for GPS receivers permits roundoff and com- 
mensurability errors to be reduced to extremely small 
values. The use of digital chip and phase advancers 
provides outstanding control and accuracy in phase and 
65 feedback. Flexibility is provided by the feature of arbi- 
trary start time and integration length. A minimum bit 
design requires a minimum number of logical elements, 
thereby reducing size, power and cost. 
25 able. 
35 code frequency could not. 
50 
60 
4.82 1,294 
3 
The invention combines the features of all-digital 
implementation with C/A phase-driven fast feedback 
loops for all phases and delays, thereby providing high 
accuracy, high dynamics, loss of lock at lower signal 
strengths and infrequent carrier cycle slips. Simple 
techniques for cycle counting, data-bit extraction and 
data-bit synchronization eliminate the need for involved 
circuitry and/or software found in existing receivers. 
Flexibility is provided in selecting feedback interval and 
output averaging interval. 
A pseudorandom code sequence is generated by sim- 
ple digital logic that incorporates the effects of time, 
delay and delay rate. For each integration interval, both 
chip and chip rate are initialized to a small fraction of a 
chip, for example, to the order of 10-7, thereby making 
feedback control and delay extraction highly accurate 
and flexible. Appropriate selection of sample rate rela- 
tive to chip rate, reduces commensurability errors to 
extremely small levels. 
The digital code generator is initialized each correla- 
tion interval on the basis of the initial integer chip sup- 
plied on the basis of feedback by other hardware or 
software. The fractional chip register is initialized with 
the associated fractional chip supplied by the feedback. 
The fractional chip register is then digitally incre- 
mented for every subsequent sample point by the chip 
change due to both time and delay rate. Whenever the 
fractional chip register overflows as the result of an 
increment, another chip has been reached and a pulse is 
sent to the code generator which responds with the next 
code sign. 
OBJECTS OF THE INVENTION 
It is an object of the present invention to provide a 
compact, highly accurate, yet simple and versatile car- 
rier down-converter and code correlator for a GPS 
receiver, with highly flexible control of phase and de- 
lay. 
It is another object of the present invention to pro- 
5 
10 
15 
20 
25 
30 
35 
vide a reliable, compact, highiy accurate, high dyn&ic 40 
GPS tracking processor with the simplest possible cir- 
cuitry and logic, with loss of lock at lowest possible 
signal strengths and with extremely infrequent cycle 
slips. 
It is still another object of the present invention to 
accurately and simply generate a delayed pseudoran- 
dom code sequence with a high degree of control in a 
purely digital fashion primarily for use in GPS signal 
processing. . 
It is still another object of the present invention to 
provide a high-accuracy, high dynamic GPS baseband 
processor with variable integration times, low loss-of- 
lock signal strengths and extremely infrequent carrier 
cycle slips. 
It is still another object of the present invention to 
provide a GPS digital signal processor in which all fast 
feedback loops for phase and delay are driven by C/A 
L1 phase, with an additional slow feedback correction 
for P-LI phase, for P-L2 phase and for all delays. 
It is still another object of the present invention to 
provide a method of processing GPS signals in a purely 
digital manner. 
BRIEF DESCRIPTION OF THE DRAWINGS 
The aforementioned objects and advantages of the 
present invention as well as additional objects and ad- 
vantages thereof will be more fully understood herein- 
after as a result of a detailed description of a preferred 
- 
45 
50 
55 
60 
65 
4 
embodiment when taken in conjunction with the fol- 
lowing drawings in which: 
FIG. 1 is a simplified block diagram of a GPS re- 
ceiver employing the digital processor of the present 
invention; 
FIG. 2 is a functional block diagram of the signal 
processing in the tracking processor of the present in- 
vention; 
FIG. 3 is a functional block diagram of the signal 
processing in the high speed digital processor of the 
present invention; 
FIG. 4 is a simplified representation of the digital 
baseband processor of the invention; 
FIG. 5 is a graphical representation of the quadrature 
three-level sinsoids used in the down-converter phase 
logic of the invention; 
FIG. 6 is a schematic illustration of digital operations 
that produce three-level down-conversion phasers; 
FIGS. 7a and 7b are flow charts of C/A channel 
signal processing in the tracking processor of the inven- 
tion; 
FIGS. 8s and 8b, are flow charts of the feedback loop 
for the C/A channel in the tracking processor of the 
invention; 
FIGS. 9a and 9b, are flow charts of the P channel 
signal processing in the tracking processor of the inven- 
tion; and 
FIG. 10 is a block diagram of a chip advancer used in 
the present invention for generating a pseudorandom 
code sequence. 
DETAILED DESCRIPTION OF A PREFERRED 
EMBODIMENT 
To illustrate the use of the digital signal processor in 
the context of a complete receiver, reference is first 
made to FIG. 1 which represents a top level block 
diagram of a GPS receiver of the present invention. It is 
assumed that antenna, front end, and frequency subsys- 
tems are all designed and implemented in a manner that 
provides the necessary baseband signals to the baseband 
processor. Using fixed-frequency L.O.’s, the frontend 
hardware downconverts the GPS signals from R F  to 
baseband, where the signals are low pass filtered and 
digitally sampled. Three digitally sampled signals are 
supplied: The PI and P2 signals (e.g. each at 15.374 
Ms/sec) and the C/A signal (e.g. at 1.5374 Ms/sec). The 
three signal processing paths followed by these three 
signals will be referred to as channels herein. Two im- 
portant aspects of the frequency subsystem are sampling 
frequency and L.O. offset frequencies. The sampling 
frequency must be highly incommensurate with the 
fundamental chip rate (e.g. 15.374 MHz vs. 10.23 MHz) 
so that discrete sampling errors will be negligible. For 
earth-fixed receivers, the frequency offset of the L.O.’s 
should be of the order of 10 kHz so that carrier down- 
conversion in the baseband processor will work with 
good accuracy. 
The signals of all visible GPS satellites are simulta- 
neously received by an “omni-directional” antenna and 
are therefore all embedded in the baseband signal. In the 
digital baseband processor, a separate digital signal 
processor is provided to extract the signals for each 
satellite. In FIG. 1, the microprocesso; “board” and the 
digital processing “board” comprise the digital signal 
processor. A host microprocessor coordinates the digi- 
tal signal processors and collects the output data. The 
digital signal processor consists of two major compo- 
nents: The tracking processor and the high-speed digital 
4.82 1.294 
5 
processor. FIGS. 2 and 3 show functional block dia- 
grams of these two components and indicate their com- 
bination. 
Even though this illustration shows each digital sig- 
nal processor reducing the signal from only one satel- 
lite, more than one satellite could be processed by a 
digital signal processor by programming its micro- 
processor to time-multiplex its digital hardware be- 
tween satellites. 
Besides the usual advantages of reliability and com- 
pactness characterizing digital design, numerous advan- 
tages are provided by the present design of the baseband 
processor. By way of example, the following is a listing 
of such advantages: 
(a) The total errors caused by the baseband processor 
are very small for delay and phase (less than 0.1 
millichip and 1 millicycle, respectively); 
(b) High dynamics (up to 100 g’s) can be tracked with 
high accuracy; 
(c) Signal strengths at which loss of lock occurs are 3 
to 6 db lower than other receivers, given nominal 
GPS phase I specs for C/A and Pz power level; 
(d) The rate of occurrence for cycle slips is extremely 
low for all channels; 
(e) The design requires no special circuitry to do 
data-bit synch, data-bit extraction and cycle count- 
(f) Selectable fast feedback interval (2, 4, 5, 10, 20 
msec) provides valuable flexibility in making tra- 
deoffs between dynamics and SNR; 
(g) Selectable output-point spacing (1, 2, 3, . . . 300 
sec) satisfies the requirements of a wide range of 
users. (If necessary, spacings between 20 and lo00 
msec could also be included in the design). Subse- 
quent data reduction is simplified for the user by 
forcing output timetags to fall on integer seconds 
that are synchronized to GPS time; 
(h) Sample rate and carrier frequency offsets can be 
set within a wide range of values; 
(i) Start time and length of each correlation interval 
can be set by the microprocessor, providing great 
flexibility in operation, including multiplexing be- 
tween satellites; 
6) System noise errors in C/A and P delays are re- 
duced by a factor of about 1.5 by an improved data 
compression scheme; 
(k) Tracking errors in phase and delay are reduced in 
high dynamic applications by better use of feed- 
back error. 
ing; 
ALL DIGITAL CARRIER DOWN-CONVERTER 
AND CODE CORRELATOR 
As illustrated in FIG. 4, the digital baseband proces- 
sor consists of two major components: A high-speed 
digital processor (i.e., the correlator and down con- 
verter) and a tracking processor. Control information 
sent by the tracking processor consists of the start time, 
sum interval length, initial phase and phase rate and 
initial delay and delay rate. Based on this input, the 
high-speed digital hardware accepts input data sampled 
at 1.5-2 MHz for the C/A channel and 15-20 MHz for 
the P channel and counter-rotates the carrier, cross- 
correlates with the pseudorandom code, and accumu- 
lates the result over a nominal 20 millisecond interval. 
All high-speed components are clocked by the P or 
C/A sample clock. The resulting correlation sums, 
sometimes referred to as correlation coefficients, are 
collected by the tracking processor and reduced to 
6 
extract measured phase, delay and data-bits. The track- 
ing processor analyzes these phase and delay values and 
averages them to obtain feedback values to drive the 
digital hardware and averages them over longer time 
5 intervals in order to reduce the output data rate. 
A functional block diagram of the high-speed digital 
processor is shown in FIG. 3. As indicated, the major 
steps in high-speed processing of the digitized baseband 
signal are carrier downconversion, code cross-correla- 
10 tion and correlation accumulation. This process pro- 
duces a complex correlation coefficient for each of N 
lags. FIG. 3 is valid for both the C/A channel and the 
P channels and is shown for non-quadrature sampling. 
In principle, quadrature processing could be accom- 
15 plished by replicating for the quadrature channel the 
counter-rotation mixer, the code mixer and the accumu- 
lators, while sharing the phase and code generators. At 
the input, the band-limited baseband signal is digitized 
to two levels (+, -) or three levels (+, 0, -), with a 
20 Nyquist sample rate of 1.5 to 2.1 MHz for C/A or 15 to 
21 MHz for P, depending on the specific hardware 
implementation. The system described herein has a 
sample rate of 15.374 MHz for P and 1.5374 MHz for 
C/A and two-level sampling for all channels. 
After sampling, the signal is counter-rotated (down- 
converted) by means of a complex multiply with a 
three-level (+, 0, -) phaser generated in the high- 
speed hardware on the basis of feedback. Although start 
time and sum interval can be arbitrarily set, the sum 
30 interval will be specified as “20 msec” with the under- 
standing that this value refers to a nominal GPS sum 
interval of about 19 msec that has been synchronized 
with data-bit edges by the tracking processor. The 
tracking processor can easily synchronize a sum inter- 
35 val with data-bit edges by setting the start time of the 
interval to an integer times 20 msec plus the most recent 
measured C/A group delay. The approach totally elimi- 
nates the data-bit-synch circuitry found in most receiv- 
ers. Over the sum interval, counter-rotation phase is 
40 approximated by a linear function whose initial value 
and rate are set every sum interval by the feedback 
loop. The initial value is supplied in the form of an 
integer equal to the starting fractional phase multiplied 
by 224. The phase rate is supplied in the form of an 
45 integer equal to phase rate in cycles/bit multiplied by 
224. For each new sample point, the phase advancer 
increments phase by adding the phase rate register. As 
phase is updated, integer cycles that appear as overflow 
are discarded because integer cycles have no effect on 
To generate the counter-rotation phaser, the four 
most significant bits of the phase register are extracted 
to drive digital logic designed to produce the quadra- 
ture three-level sinusoids shown in FIG. 5. A schematic 
55 illustration of that digital logic is shown in FIG. 6. 
Multiplication of the sampled input signal with this 
quantized phaser results in a three-level product (+, 0, 
-). After counter-rotation, the signal is power divided 
into N paths and each path is multiplied by a lagged 
In order to generate the code values, the high-speed 
hardware is supplied register values to set the initial 
(integer) chip, the initial fractional chip, and the chip 
rate. As implied, the chip model, like the phase model, 
65 is approximated by a linear function of time over the 
sum interval. The chip model depends on both the 
model delay (extrapolated by the tracking processor) 
and change of chip with the passage of time (i.e., chip/- 
25 
50 computation of sinusoids. 
60 code value. 
432 1,294 
7 8 
bit= 10.23 MHz/p-sample rate). In the illustrated em- rate. For example, maximum allowed acceleration can 
bodiment, the fractional chip register and the chip rate be increased by as much as a factor of 16 by decreasing 
register for the C/A channel are passed as integers the integration time from 20 milliseconds to 5 millisec- 
equal to the fractional chip and chip rate (in chip/bit) onds. The flexibility in start time and integration length 
times 224, respectively. For the P channel, the multiplier 5 allows the controlling hardware or software to easily 
is 228. To initialize the first (integer) chip, two register synchronize the sum interval with data-bit transitions. 
values must be derived and supplied to the C/A code Multiplexing systems that switch the correlator be- 
generator and six for the P code generator. tween satellites are readily accommodated by this de- 
For each new sample, the chip advancer increments sign since all parameters can be reset for each integra- 
the fractional chip register. When a given increment 10 tion interval for each satellite. Fundamental chip rates 
results in a transition to a new chip, the chip register other than the 10.23 MHz setting for GPS can be easily 
overflows and sends a pulse to advance the code gener- accommodated by properly setting the chip rate regis- 
ator to a new chip. The output of the code generator is ter. A similar statement can be made for baseband car- 
a two-level signal (+or -), representing the code sign. rier frequency, which can possess a range of frequen- 
If a pulse requesting a new chip is not received for a 15 cies. 
given sample, the lase code sign will persist for that Another flexible feature of this design is the sample 
sample, The output of the code generator is passed into rate. The design itself does not restrict the rate range of 
a tapped N-bit delay line whose multiple outputs are the sample clock. Limits on sample rate will be set by 
multiplied branch-by-branch by the complex output of the speed range of the specific hardware implementa- 
carrier counter-rotator. The complex three-level output 20 tion. 
of each of these products is then accumulated over a “19 Even though the basic design would apply to any 
millisecond” interval. (A 1 or 2 msec deadtime is left in number of levels per sample, the minimum bit design 
order to avoid data-bit edges and to allow deadtime has been illustrated in FIG. 3. In this design, there is a 
operations). At the end of the sum interval, the contents voltage signal-to-noise ratio (SNR) loss of 4% due to 
of the accumulators are passed to the tracking processor 25 three-level quantization of the down-conversion sinus- 
and then set to zero for the next “20 millisecond” inter- oids and a 20% loss due to two-level sampling of the 
Val. baseband signal. For the other option, three-level sam- 
As indicated in the lower right-hand corner of FIG. pling of the baseband signal, there is approximately a 
3, the high-speed hardware is started and stopped by 10% loss. If these small losses in SNR are acceptable in 
high-speed control logic that is supplied with a sum 30 a given application, one can implement the minimum-bit 
length in the form of P-sample bits and with a start time design and arrive at a digital logic with a minimum 
in the form of an integer-second part (in seconds) and a number of logical elements, thereby greatly reducing 
fractional-second part (in p-sample bits). When the sys- size, power consumption, and cost of the integrated 
tem time, which is driven by the p-sample clock (e.g., circuit chip($ fabricated to carry out these operations. 
15.374 MHz), equals the start time registers, the start 35 The capability of processing two-level samples is very 
line is raised to activate the high-speed digital hard- valuable for another reason in applications that can 
ware. Deactivation occurs when the register containing spare the loss in SNR. Both the sampling circuitry and 
the sum length counts to zero. the front-end hardware become much simpler, because 
Because all operations, including carrier down-con- sampling circuitry becomes a chipper and sign test and 
version, are digital, phase and delay can be tracked and 40 the front-end hardware requires little or no automatic 
measured with extremely small errors. Given 24-bit gain control. 
chip and phase advancers, for example, roundoff errors The design can also be used for quadrature process- 
are less than 100 nanochips and 100 nanocycles. Com- ing even though FIG. 3 illustrates a single nonquadra- 
mensurability errors, on the other hand, depend on the ture channel. To process complex signals, the opera- 
specific value of sample rate relative to baseband carrier 45 tions in FIG. 3 are applied separately to each quadra- 
frequency and to chip rate (with both offset by doppler ture channel in parallel hardware channels. Both quad- 
effects). By properly selecting sample rate, commensu- rature channels can be serviced by the same circuitry 
rability errors can be reduced to very low levels. For for generating delay code and counter-rotation phasers. 
example, given and ground-based GPS receiver and a At the end of an integration interval, subsequent pro- 
P-sample rate of 15.374 MHz, the worst-case commen- 50 cessing combines the complex sums with appropriate 
surability errors are 0.13 millichip and 1 millicycle. In signs for the real and imaginary parts. 
practice, actual errors are far less than these small val- 
ues since changing doppler will smear over the quanti- 
zation spacing in less than a second. For comparison, 
the worst-case error for the highly commensurate Sam- 55 
ple rate of 20.46 MHz is 0.5 chip in delay, which will 
smear out in about 15 seconds due to doppler for a 
ground-based receiver. Finally, the “sum-note” error in 
carrier down-conversion will average down to a milli- 
cycle or less over a 20 millisecond integration if the 60 
carrier frequency is more than 4 kHz at baseband. Such 
an offset is accomplished by setting the total mixing 
frequency in the down-conversion from R F  to a value 
at least 4 kHz less than the minimum doppler-shifted 
carrier frequency. 
Great flexibility in control is provided by the fact that 
this design is driven by supplied values for start time, 
integration length, phase, phase rate, delay and delay 
DIGITAL GPS TRACKING PROCESSOR 
A. Top Level Funcational Description 
A top level block diagram of the tracking processor is 
shown in FIG. 2, including the interface with the high- 
speed hardware. The figure shows the C/A channel and 
one P channel with the understanding that the P chan- 
nel would represent either PI or P2. 
The following discussion will refer to the fast feed- 
back interval as the “20 msec” interval even through, in 
principle, the interval could be 1, 2,4, 5, 10 or 20 milli- 
seconds. For a setting less than 20 milliseconds, logic is 
included that takes into account the fact that the same 
65 data-bit is measured more than once and reduces the 
multiple measurements into one per 20 milliseconds. 
The input to the C/A processing, the C/A correla- 
tion coefficients, are analyzed every 20 milliseconds to 
4.821.294 ‘ 
I -  
9 
extract Llcarrier phase. This phase is used to extrapo- 
late ahead in time to produce fast (20 msec) feedback 
values for all delays and for the P-L1 and P-L2 phases. 
To obtain the data-bit for each 20 msec interval, only 
the correlation output for the prompt delay of the C/A 
channel is tested. Delay feedback based on C/A phase is 
so accurate over short time intervals that the C/A cor- 
relation coefficients can be summed for each lag over 
one second. Lag dependence of these sums is used to 
extract residual delay which is then used in two ways. 
First, it is used as a slow (one second) feedback correc- 
tion to the fast (50 seconds) phase-extrapolated delay 
feedback. This correction accounts for slow drifts of 
group delay relative to phase delay, drifts mainly due to 
ionosphere effects. Second, residual delay is combined 
with averaged model (feedback) delay to produce a 
total measured delay each second. Once per second, this 
total delay is used to readjust the data-bit synchroniza- 
tion of the “20 msec” start time that activates the digital 
hardware. The 20 msec phase values for the C/A chan- 
nel are fit with a quadratic time function over each 
one-second interval to produce one “average” phase 
value per second. Both the one-second phase values and 
the one-second delay values are then subjected to a 
polynomial fit over an N second interval to produce one 
phase and one delay value every N seconds. These tit 
values, along with 50*N data-bits, are the primary out- 
put of the C/A channel. 
In parallel with the C/A processing, the two P chan- 
nels are also reduced, as symbolized by the one P chan- 
nel in FIG. 2. As indicated above, the fast feedback for 
both delay and phase for the P channels is based on C/A 
L1 phase. Once each 20 milliseconds, phase and delay 
extrapolated in this manner are used to calculate quanti- 
ties needed to initialize the digital hardware: Initial chip 
(integer and fractional parts), chip rate, phase (frac- 
tional part), and phase rate. The P-channel correlation 
coefficients produced by the digital hardware and 
summed over one second. A sign correction based on 
the data-bit sign from the C/A channel is applied to the 
P output as needed. The application of this sign correc- 
tion expands the ambiguity range of P1 and P2 phase 
from 180 to 360 degrees, provided the C/A channel 
does not slip half cycles. After a one second sum is 
completed, an algorithm based on early/promptAate 
amplitudes extracts residual delay while an arc tangent 
operation based on the in-phase and quadrature compo- 
nents for the prompt lag extracts residual phase. These 
residual delay and residual phase values are both fed 
back once per second to correct the fast feedback values 
predicted by C/A L1 phase. This slow feedback correc- 
tion accounts for slow drifts of P delay and P phase 
relative to the values based on C/A L1 phase. Residual 
delay and residual phase are combined with averaged 
model delay and averaged model phase, respectively, to 
obtain total measured P delay and P phase. As in the 
C/A channel, the one-second values are fit with a poly- 
nomial time function to produce one phase and one 
delay value every N seconds. 
In real-time systems, the time at execution becomes 
an important consideration. In the feedback process, 
some operations must be performed during the dead- 
time between 20 msec intervals if information from the 
most recent interval (n) is to be incorporated in the 
feedback for the next interval (n+1). Since the dead- 
time interval should be made as small as possible in 
order to minimize lost data, the number of deadtime 
operations should be minimized. In order of sensitivity 
- I - -  
10 
to feedback promptness, the feedback quantities are 
phase, phase rate, delay, delay rate. Of these four, only 
feedback phase has to be based on the last feedback 
interval. The other three can be set up on the basis of 
5 earlier intervals (e.g. n- 1, n-2). Thus as indicated in 
the figures that follow, only phase is updated during the 
deadtime interval. The other feedback values are up- 
dated during a 20 msec sum interval in parallel with 
high-speed digital operations. This compromise, which 
10 is of negligible consequence in performance and accu- 
racy, relaxes timing constraints in the design of the 
feedback operations. 
B. The C/A Channel 
A block diagram of signal processing operations for 
15 the C/A channel is presented in FIGS. 7a and 76, while 
the associated feedback operations are shown in FIGS. 
Sa and 8b. The signal processing operations will be 
explained first. 
In each of FIGS. 7,s and 9, the function boxes repre- 
20 sentative of certain processing operations provide an 
indication of the timing nature of such operations. This 
indication is in the form of a small square in this upper 
right-hand corner of the function box. A blank square 
identifies operations that take place during the deadtime 
25 between 20 msec hardware sums. A square having an 
“x” identifies 20 msec operations taking place concur- 
rently with hardware operations during a 20 msec sum. 
A square with a “+” identifies background multitasked 
“one second” operations. 
30 (1) C/A SIGNAL PROCESSING 
Every 20 milliseconds during the deadtime between 
20 msec intervals, the tracking processor collects the 
correlation coefficients produced by the high-speed 
digital hardware and supplies new phase, chip, and start 
35 time information for the next 20 msec interval. The start 
time is precalculated during the preceding 20 msec 
interval by incrementing the start time variable by 20 
milliseconds. In addition, once per second, an adjust- 
ment is made on the basis of measured delay in order to 
40 maintain data-bit synchronization. For ground-based 
receivers, data-bit synch can be maintained to better 
than 5 microseconds. 
Processing follows three major routes: Carrier phase 
processing, data-bit extraction, and group delay pro- 
45 cessing. Along the phase route, the prompt in-phase and 
quadrature, components are combined during the dead- 
time between 20 msec intervals to extract residual 
phase. If feedback (model) phase is accurate to better 
than 0.25 cycle with respect to all errors (e.g. system 
50 noise, acceleration, oscillator instability), then a two- 
quadrant arctangent will yield a value for residual phase 
with the correct 4 cycle ambiguity. Also estimated 
during the deadtime is the total measured phase, which 
is equal to the residual phase plus the model phase pre- 
55 viously supplied for that 20 msec interval. The time tag 
for this phase value is the 20 msec start time plus 4 of the 
“19 msec” sum interval. 
This method for computing measured phase is unlike 
conventional phase lock loops, which take feedback 
60 phase as measured phase. By doing so, such loops ig- 
nore the most recent error signal (residual phase), 
which represents the offset of the most recent feedback 
phase relative to true phase. Therefore, in high dynamic 
applications where tracking errors are substantial, the 
65 conventional approach does not fully utilize this valu- 
able information. 
The resulting phase value is used to drive the feed- 
back loop (to be described below). In addition, the 20 
4,821,294 
11 12 
msec phase values are subjected to a quadratic fit over from the same fit, the second correction removes the 
a one second interval with the reference time centered bias in delay caused by the quadratic term (delay rate 
on an integer-second point. This fit provides values for rate). By removing non-linear effects in this manner, 
phase, phase rate, phase rate rate once per second. The one avoids fitting a separate quadratic to the delay val- 
phase rate and phase rate rate are used to make correc- 5 ues over one second. Not only does this approach sim- 
tions to the other observables as explained below. plify processing for group delay, but it results in a 
The last step in processing phase is to compress data smaller system noise error in group delay (by a factor of 
volume further, by fitting the one second values with a about 1.5) by avoiding correlation between the solve- 
polynomial time function over N seconds, which leads for parameters of ro and ?, in the quadratic fit. 
to one output Phase value each N s ~ o n d s .  The refer- 10 Another option exists for removing time variations of 
ence time (i.e. time tag) in each fit iS placed on an ink- group delay Over each 6‘one second” interval, an option 
ger second value that is an integer multiple of N set- that is more exact but requires more operations at the 20 
onds. If point positioning has been carried out to find Msec level. First, the total C/A carrier phase measured 
the offset between receiver clock and GPS time, a time for a given 20 mSeC interval is converted to phase delay 
shift equal to that offset is applied in the fit so that the 15 by removing the L.O. offset term. F~~ each 20 mSec 
output timetag will refer to GPS time. interval, the resulting phase delay is subtracted from the 
As shown in the second path Of signal processing, the model (feedback) value for C/A, PI, and P2 group de- 
datahit extracted testing the sign Of the Prompt lays. The resulting differences, which are essentially 
inphase components Of the (The ex- 
tracted sign is actually the sign relative to the first data- 20 age Over the 
bit. The overall sign for all data-bits is unknown at this 
point and must be determined in subsequent data-bit 
analysis)* As data-bits are they are ‘Om- 
pressed into words with 25 data-bits per 32-bit word. 
in the output data set. 
In the third path of C/A processing, group delay 
extraction, the correlation coefficients are summed over 
one second in order to reduce computation time and 
increase SNR. as indicated in FIG. 74 early, late, and 30 pertains to the given 
prompt amplitudes are summed using a compromise 
algorithm that is extremely simple computationa~~y~ If 
time independent, are then subjected to a straight aver- 
the 
Same 20 mSec values for phase delay are subjected 
to a second” interval with 
the reference time centered on the integer second. The 
estimated phase emerging from this fit represents 
delay for each of the three channels is then obtained by 
adding this estimated phase, the “one second” residual 
phase and the aforementioned averaged difference that 
The timetag for these 
observables is the reference time mentioned above. 
Since this approach also avoids solving for i’ usinn the 
second” interval. 
fit Over the 
This leads to 2*N data-bit words per N-sec phase point 25 phase delay at the reference time. Total measured group 
the magnitude of the in-phase component is larger than 
the magnitude of the quadrature components (which is 
typical), then the in-phase magnitude is summed. Other- 
wise the quadrature magnitude is summed. as the corre- 
lation coefficients are summed, the model delays and 
the start times are also summed. 
Relative to the optimal processing in high dynamic 
cases, this compromise can cost as much as root-2 in 
voltage SNR in the sums, but is becomes the optimal 
approach, a coherent sum of the in-phase component, 
for low dynamic cases (e.g. <2 g’s for 20 msec feed- 
back). A coherent sum is particularly desirable in low 
SNR tracking. The root-2 loss in high dynamic cases 
does not weaken tracking lock since lock depends on 
C/A phase, but precision of measured delay is reduced 
by root-2. Simplicity of the algorithm, its optimality 
under low dynamics and its respectable performance 
under high dynamics make the algorithm an attractive 
choice for the one second averages. Another option is 
to perform a noncoherent sum of the RSS of the in- 
phase and quadrature components. This option is more 
complicated computationally, is suboptimal for low- 
SNR, low-dynamic cases but is better for high dynamic 
cases with adequate SNR. 
Once per second, the sums are analyzed to calculate 
residual delay and average model delay by means of the 
formulas in FIG. 7a The resulting residual delay is sent 
to the feedback portion of the code as a slow delay 
feedback. Residual delay is also combined with average 
model delay to obtain total measured C/A group delay. 
The timetag for this delay is the average start time plus 
f of the “19 msec” sum interval. This delay observable 
now requires two corrections. Based on the phase rate 
from the one second fit to C/A phase, the first correc- 
tion shifts the timetag from the average timetag to the 
integer-second timetag t. Based on the phase rate rate 
- 
delay observables, it also avoids the- correlation be- 
tween r and i‘ and provides a system noise error in delay 
35 that is 1.5 times better that that provided by the separate 
quadratic fit to each type of delay observable. 
The last step in processing delay is to compress data 
volume further by‘fitting the one second values with a 
polynomial time function over N seconds, which leads 
40 to one output delay value each N seconds. The refer- 
ence time (Le. timetag) and fit interval in each fit con- 
form with the C/A phase fit described above. 
(2) THE C/A FEEDBACK LOOP 
As illustrated in FIGS. 8a and 86, the feedback loop 
45 for the C/A channel consists of the following steps: 
During the deadtime between 20 msec intervals, carrier 
phase measured for the (n- 1)‘th 20 msec interval (the 
last interval completed) is subtracted from the measured 
phase for the interval just completed, the n’th interval, 
50 to obtain an estimate for the most recent phase change 
per 20 milliseconds. To predict phase for the center of 
the next 20 msec interval, the (n+ 1)‘th interval, this 
phase change is added to the center phase of the n’th 
interval. Another correction, not shown in FIGS. 8a 
55 and 86, is applied to this extrapolated center phase value 
to shift it by f interval to the start of the (n+ 1)’th inter- 
val. To set the phase register for the digital hardware, 
the fractional part of the extrapolated start phase is 
extracted and multiplied by 224. 
Numerous other algorithms for projecting phase can 
be devised. For example, instead of intervals (n, n- l), 
phase change could be estimated from one of the fol- 
lowing pairs: (n, n-2)k, (n-1, n-2), (n-1, n-3). 
These combinations would work better for low SNR, 
65 but could not handle as high an acceleration. Another 
extrapolation option is to implement a conventional 
second order phase lock loop in which residual phases 
are used in a calculation of the next phase rate, and 
60 
4,82 1,294 
13 14 
feedback phase is made a continuous piecewise linear tional load. The long integration time is possible due to 
function. the accurate short-term feedback derived from C/A L1 
The 20 msec phase change estimated above is also phase. 
used to generate the phase rate register for the digital Along the phase route, the in-phase and quadrature 
hardware, except that the previous phase change, the 5 components of the prompt lag are summed after a sign 
(n- I)’th, is used rather than the n’th. This approxima- correction based on the data-bit sign extracted for the 
tion allows operations to be performed concurrently same 20 msec interval from the prompt lag of the C/A 
with digital hardware operations rather than during the channel. Model phase is summed along with the corre- 
deadtime between 20 mSec intervals. Phase change Per lation coefficients. Each second, the sums are collected 
bit is calculated by dividing the 20 mSec quantity by the 10 and the sum registers are set equal to zero in preparation 
number Of bits per 20 milliseconds. The integer value for the next one second sum. (In applications with high 
Passed to the digital hardware equal to the Phase accelerations or extremely rapid ionosphere changes, it 
change per bit (in cycles per bit) times 224. might be necessary to sum the P channels along the 
and feedback chip estimation. First, the precalculated 15 order to make a rapid correction to the fast feed- 
phase change is converted to phase back for phase. For example, a 200 msec sum would still 
The precalculated phase change is also used in delay phase route for a period shorter than one second in 
change by 
removing the effect of the L o  offset ( k  12320 Hz for average down system noise by a factor of three but 
L1) and then dividing by the number (1540) ofL1 cycles 
per ‘IA chip. This approximate change ‘s then 
and the 
would track phase with five times the ‘‘loop band- 
width” associated with the one second feedback). 
used to determine for the next 20 msec interval both the 20 Residual phase is extracted with an arctangent opera- change per bit. The 
delay change per bit is estimated by simply dividing by tion based on the in-phase and quadrature components. Due to the data-bit sign correction, a four-quadrant the number of bits per 20 milliseconds. To obtain the arctangent can be with - to + 12 cycle change per this change per bit is range. Average model phase is computed as the straight 
subtracted from the chip change per bit due to the pas- 25 average of the 50 model phases in the one second inter- 
sage of time (i.e. 1.023 MHz/c-sample rate). The result 
is then multiplied by 224 to produce the integer value 
that the digital hardware expects for the chip rate. 
To estimate phase delay at the center of the next 20 
Val. 
As shown in FIG. 9b. residual phase is added each 
second to a phase offset variable that keeps track of the 
mSec interval (n+ I), the delay change/20 mSec calcu- 30 Offset and ’low drift Of 
lated above is added to the phase delay for the present 
phase to ‘IA phase. 
it might be necessary to (In Of high 
20 mSec interval (n). The CIA group delay for the next 
interval is then obtained by adding a slowly varying 
delay offset to the phase delay. once each 
second (once per 50 feedbacks), this delay offset is sub- 35 ‘1 and ’2 
divide the slow feedback correction to P phase by 3.0 in 
order to damp oscillations caused by overcorrection of 
acceleration effects). Separate offsets are tracked for the 
The use Of Offset phase in feedback 
jetted to a slow feedback adjustment in the form of the 
residual delay from C/A group delay procasing. This 
will be discussed below. Total measured phase is com- 
puted as the sum of residual phase and averaged model 
adjustment corrects for the slow drift of group delay Phase. The timetag for the phase observable is the aver- 
relative to phase delay (typically <2 cm/sec). Next, age timetag computed in the C/A channel. To align this 
based on the precalculated start time ofthe next 20 mSec timetag with the integer-second timetag at the center of 
interval, the model rate the one second interval, a correction based on the “one 
(1.023 MHz) times the start time minus the model group second” phase rate from the C/A L1 channel must be 
delay. Not shown in FIGS. Sa and 8b is an adjustment applied. In addition, a correction based on the phase 
needed to shift the model chip from the center to the rate rate obtained from C/A Li is applied to remove the 
start of the 20 msec interval. This shift is equal to the 45 bias caused by the quadratic term. For L2, both of these 
chip rate estimated above times $ the “19 msec” sum COrrections must be scaled by RF frequency. 
interval. The resulting model chip is separated into After these corrections, the phase values are fit with 
integer and fractional parts. The fractional part is multi- a PolYnomial Over N seconds to Produce one Phase 
plied by 224 to obtain the integer value sent to the digital observable each N seconds. The fit interval length and 
hardware as the initial value in the chip advancer. The 50 timetag conform with the C/A L1 observable. 
integer part is used to obtain (by table lookup) the g l  Along the delay Processing Path, the correlation co- 
and g2 registers needed to initialize the first (integer) efficients for the early, Prompt, and late lags are accu- 
chip sign supplied by the digital hardware. Accurate mulated over one second, as are the associated model 
data-bit synchronization in the start times keeps the delays. The algorithm, for summing P amplitudes is the 
table lookup range small and near the beginning of the 55 same as the one used for C/A. Each second, the one 
full 0-1022 range of possible starting chips (calculated second sums are collected to compute the residual delay 
modulo 1023). according to the formula in FIG. 9a. The resulting 
C. P CHANNEL PROCESSING residual delay is added to a delay offset variable that 
A block diagram summarizing post-correlation pro- keeps track of the offset and slow drift of P group delay 
cessing for a P channel (either PI or P2) is shown in 60 relative to C/A phase delay. This delay offset is used in 
FIGS. 9a and 9b. Signal processing will be described the feedback loop, as discussed below. Total measured 
first followed by feedback operations. group delay is computed as the sum of the residual 
(1) P SIGNAL PROCESSING delay and the average model delay. Two corrections 
After collecting the P channel correlation coeffici- are then applied to this delay in a manner analogous to 
ents, the signal processing follows two paths: One path 65 the C/A delay, except that the phase to delay conver- 
extracts phase while the other extracts delay. In both sion number is 154 rather than 1540. As it did for C/A 
cases, the correlation coefficients are accumulated for delay, this approach reduces system noise error in P 
one second to collect statistics and reduce the computa- group delay by a factor of about 1.5. After these correc- 
is set equal to the 
4,821.294 
15 
tions, P delay is fit over N seconds in the same manner 
as the other observables. 
(2) P FEEDBACK OPERATIONS 
In the P feedback loop, the first step is to estimate fast 
feedback phase at the center of the next interval, the 
(n+l)‘th, by first scaling the C/A feedback phase by 
RF frequency and then adding the offset phase that 
accounts for offset and slow drift of P phase relative to 
C/A L1 phase. These operations are, in effect, carried 
out during the deadtime interval between 20 msec inter- 
vals. Not shown in FIGS. 9a and 96 is a correction to 
shift the center phase to start-time phase, as with C/A 
phase. The fractional-cycle part of the resulting phase is 
then multiplied by 224 to obtain the integer value needed 
to initialize the phase advancer of the digital hardware. 
Phase rate feedback for P is obtained by scaling the 
C/A phase change per bit according to R F  frequency 
and then scaling according to bit size. The resulting 
phase rate is then multiplied by 224 to obtain the integer 
value needed to initialize the phase rate register in the 20 
phase advancer in the digital hardware. 
Estimation of P chip rate feedback is very simple 
since the C/A chip rate is the same as the P chip rate 
(i.e. P-chip/P-bit = C-chip/C-bit). To obtain the integer 
value needed to set the rate portion of the P chip ad- 25 
vancer in the digital hardware, however, the chip rate is 
multiplied by 228 rather than 224. 
Estimation of the model chip feedback is preceded by 
the estimation of model group delay for P at the center 
of the next, the (n+ l)’th, 20 msec interval. That model 30 
group delay is computed by multiplying the C/A phase 
delay for the (n+ 1)’th interval by 10 to account for chip 
size and then adding the aforementioned delay offset 
(Pi or P2) that accounts for the offset of P group delay 
from C/A phase delay. Model chip feedback, the pro- 35 
jected chip value at the start of the (n+ 1)’th interval is 
computed by multiplying the P chip rate by the start 
time and subtracting the model group delay. Not shown 
in FIGS. 9a and 96 is a correction based on total chip 
rate that shifts from the center of the interval to the start 40 
time. The resulting chip value is separated into integer 
and fractional parts. From the integer part are derived 
seven register values that initialize the P code generator 
so that it will produce the correct initial chip sign. The 
fractional-chip part is multiplied by 228 to obtain the 45 
integer value that sets the fractional-chip portion of the 
chip advancer in the digital hardware. 
(3) OTHER EMBODIMENTS 
A number of variations of the above processing 
scheme can be devised. In some applications, it may be 50 
desirable to drop the C/A channel after acquisition and 
base fast feedback for delay and phase for the PI and P2 
channels on PI carrier phase. Block diagrams for this 
implementation would be identical to those presented 
above except for several minor changes in scaling and 55 
variables. First, all C/A identifiers would be replaced 
by “PI” in FIGS. 7 , s  and 9. Scaling changes include the 
following: 1540 becomes 154 in FIG. 86, the two X10 
conversion factors for phase delay and delay rate in 
FIG. 96 would be eliminated, and Fs would be ten times 60 
larger. In FIG. 96, only K=2 would be employed. In 
FIG. Sa, 6 numbers would be passed to initialize the 
code generator for PI. 
Another variation is to have each channel operate 
independently, with a separate fast feedback for carrier 65 
phase for each channel and with the fast feedback for 
delay for each channel based on carrier phase for that 
channel. The block diagram for this option would be 
16 
equivalent to FIGS. 7 and 8, with channel identifiers set 
to C/A, Pi or P2, depending on the given channel. The 
scale factor 1540 would become 1540, 154 or 120 for 
C/A, Pi and P2, respectively. The sample rate f3 would 
be increased by a factor of ten for the P channels. The 
delay used to offset the start time could be the group 
delay from any one of the channels. Again, for the P 
channel, the feedback would supply 6 numbers to ini- 
tialize the code generator register. 
D. ADVANTAGES 
The digital tracking processor described above pos- 
sesses many features that distinguish it from other track- 
ing approaches. Besides the obvious advantages of com- 
pactness, reliability and accuracy provided by the all- 
digital aspect of the processor, there are numerous other 
advantages provided by the following distinctive design 
features. 
The most distinctive feature of the tracking processor 
is the feedback approach: C/A phase drives all fast 
feedback loops. Several important advantages are 
gained by this approach. the C/A channel is the stron- 
gest channel (see PRIOR ART discussion) so that the P 
channels will lose lock at much lower SNR than for 
separate P feedback loops. Because of the one second 
integration time for the P channels, those channels are 
strengthened by a factor of 50 in power SNR relative to 
the standard 20 msec integration time, which is more 
than the difference in power between C/A and P2, even 
if C/A is quadrature and P2 is not. Thus, as signal 
strength decreases, loss of lock for the P2 channel will 
be determined by C/A lock, which provides a 6 db 
improvement (for nominal phase I power levels) over 
the common approach using separate 20 msec feedback 
loops for all channels. 
Another benefit of this approach is that system-noise 
errors in feedback for P carrier phases and for C/A and 
P group delays are reduced. For all feedback delays, the 
system noise error is reduced by a factor of 7 relative to 
20 msec delay-locked loops since the slow delay feed- 
back is averaged over one second and since the C/A 
phase projection introduces virtually no system noise 
error in delay. Besides providing much more stable 
loops, this greatly reduces delay feedback error which, 
in turn, greatly reduces the error due to nonlinearity in 
or miscalibration of loop response. With this approach, 
loop response errors can be reduced to less than 0.1 
millichip (0.3 cm for P). 
System noise error in P feedback phase is reduced by 
a factor approximately equal to the ratio of system-noise 
error in C/A phase to system-noise error in P phase. 
(The error contributed by P system noise via the slow 
feedback loop is relatively small due to the one second 
average). For P2, this ratio is 4 based on power specifi- 
cations for GPS phase I. Another root-2 relative im- 
provement is realized if C/A is quadrature and P is not. 
Smaller system-noise feedback errors in feedback phase 
reduce the probability of cycle slips and make it possible 
to add more coherently the P correlation coefficients 
over a one second interval. 
Another benefit of C/A-based feedback is that, for 
some applications, quadrature implementation would 
not be needed for the P channels. With C/A feedback, 
signal lock for the P channels would not be improved 
by adding the P-quadrature component even though the 
final output P-phase and P-delay precision would be 
improved by root - 2. Applications that demand good 
lock but that do not require ultimate precision would 
4,821,294 . 
17 
implement quadrature only on C/A. Avoidance of 
quadrature implementation on the P channels would 
substantially reduce the complexity and cost of both 
frontend and baseband hardware. 
Tests and theory indicate that high accelerations can 
be reliably tracked by this feedback technique. For the 
C/A channel, accelerations as high as 10,30 and 100 g’s 
can be tracked with feedback intervals of 20, 10 and 5 
msec, respectively. 
Data-bit extraction consists of a simple sign check on 
the C/A prompt in-phase components. The data-bit 
circuitry found in some other receiver designs is 
avoided. 
The data-bit sign extracted from the C/A channel is 
used to remove the data-bit sign from both of the P 
channels. Provided the C/A sign is correct, this correc- 
tion procedure expands the phase ambiguity range for 
the P channels from 180 to 360 degrees, thereby greatly 
reducing the possibility of cycle slips for those channels. 
Given the higher SNR of the C/A channel, this proce- 
dure is much more reliable than removal of the P-chan- 
ne1 sign on the basis of the P-channel alone. 
The simple and reliable computational method used 
to enforce data-bit synchronization aligns the 20 msec 
sum with the data-bit edges with accuracies better than 
5 microseconds for ground-based receivers. The more 
complicated circuitry and software used for data-bit 
synchronization in other receivers are avoided. 
The simple technique used for cycle counting has 
proven to be extremely reliable. Carrier cycle counting 
is implicitly carried out when phase is accurately pro- 
jected ahead to the next interval. That is, model phase 
“keeps track” of the integer cycles while residual phase 
(Le. the feedback error after its measurement) provides 
the small fractional cycles correction. This approach 
for cycle counting avoids the special cycle count cir- 
cuitry found in some receiver designs. For this process 
to work, projected phase for the C/A channel must be 
in error by no more than 90 degrees, which is a condi- 
tion readily met for wide ranges of SNR and dynamics. 
For the P channels, projected phase must be in error by 
no more than 180 degrees. As in other respects, cycle 
counting for the P channels depends on the solid perfor- 
mance of the C/A channel, since the C/A cycle count 
is scaled to the other channels. Deviations between L1 
phase and L2 phase caused by the ionosphere are typi- 
cally a very small fraction of a cycle over one second 
and are therefore easily tracked by the slow feedback 
~ O O D  without causing cvcle slim. 
18 
the chip advancer, the external hardware or software 
can control a code sequence that starts at a fraction of a 
given chip and advances at the selected chip rate. In a 
GPS receiver, the initial chip value (integer plus frac- 
5 tional parts) would be based on start time and feedback 
delay, while chip rate would be equal to the sum of the 
delay rate and the fundamental chip rate divided by the 
sample rate. The chip advancer is activated and deacti- 
vated by a “start” line. Over a correlation interval, the 
As illustrated in FIG. 10 for a C/A code generator, 
the chip advancer is initialized by external hardware or 
software that supplies an initial fractional chip value in 
the form of an integer equal to fractional chip times 2N 
15 and a chip rate in the form of a integer equal to chip rate 
(in chips/bit) times 2N, where N is the number of bits in 
the fractional chip register. Simultaneously, the external 
device also initializes the code generator registers so 
that is will produce the correct code sign for the first 
20 sample point. When processing is started, the chip ad- 
vancer is closed by the sampling clock (e.g.. C/A-sam- 
ple clock). For each new sample point, the chip ad- 
vancer adds the rate register to the fractional chip regis- 
ter. When the fractional chip register overflows indicat- 
25 ing a transition to a new chip, a pulse is sent to advance 
the code generator to a new chip. That pulse triggers 
enable logic that lets the concurrent sampling clock 
edge advance the code generator to the next chip. If the 
code generator does not receive a new-chip advance for 
30 a given sample point, the previous code sign persists for 
that sample. If the sample rate is selected so that it is 
highly incommensurate with the fundamental chip rate, 
the integrated error due to discrete sampling of the 
model code sequence can be reduced to negligible lev- 
35 els after integration over a fairly short time interval. For 
example, for a P sample rate of 15.374 MHz, the com- 
mensurability ratio becomes: 
10 model delay consists of a linear time function. 
15374000/1023oooO=7687/5115 
40 
when the common factors are cancelled. One can 
readily show that, after 7687 samples (0.5 msec), the 
placement of a sample point relative to nearest chip 
edges begins to repeat so that the integrated error due to 
45 discrete sampling becomes 1/7687 after 0.5 millisec- 
onds. In other words, if a chip sequence were shifted in 
time while the time positions of the sample points re- 
mained fixed, an entire sequence of 7687 sample point 
signs would not change until the magnitude of the shift 
Valuable flexibilit; is- proviied by allowing a choice 50 reached 1/7687 chip.-In this case, delay could not be 
(1, 2, 4, 5 ,  10 or 20 msec) of fast feedback intervals. measured any more accurately than 1/7687 chip (0.4 cm 
Based on dynamics/SNR tradeoffs, the user can select for a P chip). This error is actually the worst case-error 
the optimal feedback interval. incurred in the case of zero doppler. In practice, even 
By providing a wide choice (1, 2, 3, . . . 300 sec) of this small error will be made much smaller by the 
time separations for output data points, the tracking 55 smearing caused by changing doppler. For example, 
processor can satisfy a wide range of users. Subsequent given the typical R F  doppler rate of 0.7 Hz/sec for 
data reduction is simplified for the user by providing ground-based GPS receivers, the quantization error of 
timetags on integer seconds accurately synchronized to 1/7687 will be traversed in only 0.24 seconds due to 
GPS time. continuous chip shifting caused by changing doppler. 
If necessary, C/A phase data could be output at an 60 Doppler smearing of this magnitude will reduce the 
even faster rate, say every fast feedback interval (e.g. quantization error by more than a factor of ten for a one 
every 2 0  msec). By shortening the sum interval for the second integration interval. In selecting a sample rate, it 
slow feedback, the other observables could be output is advisable to choose a value that is sufficiently re- 
much more frequently, for example, every 200 msec. moved from highly commensurate ratios (e.g., 2/1, 3 / 2 ,  
65 etc.) so that doppler can not change the chip rate to a 
value highly commensurate with the sample rate. CHIP ADVANCER 
By supplying the proper initial integer chip to initial- An important advantage of the chip advancer is that 
ize the code generator, fractional chip and chip rate for starting chip value, including fractional chip, can be 
4,821,294 
19 20 
exactly set every sum interval. Thus, measured delay nal GPS power specifications. Furthermore, the pre- 
will be corrupted by roundoff errors at the level of FN ferred embodiment of the defined GPS system is char- 
or less, which is less than 100 nanochips for a 24-bit chip acterized by certain implementation parameters dis- 
advancer. Buildup of roundoff error due to roundoff in closed herein; however the advantageous features of the 
the rate register can be eliminated by computing the 5 invention may be derived in other signal processing 
total roundoff accumulation, and offsetting the initial applications using different parameters. Accordingly, 
delay to compensate. Further, the flexibility of accu- all such modifications and additions are deemed to be 
rately resetting chip and chip rate for each correlation within the scope of the invention which is to be limited 
interval iS very Useful in many applications, for exam- only by the claims appended hereto. 
ple, those involving multiplexing schemes. The flexibil- 10 I claim: 
ity in start time and sum interval is very useful in align- 1. A digital signal processor for use in a Global Posi- 
ing correlation interval with data-bit boundaries. tioning System (GPS) receiver, the receiver of the type 
It will now be understood that what has been dis- receiving a code-modulated signal, providing a digi- 
closed herein comprises a unique digital Signal Proces- tized signal from said code-modulated signal, generat- sor and signal processing method for GPS receivers 15 ing model delays, generating a model code sequence 
correlator, a digital tracking processor and a digital ing model code values are closely aligned in time with 
chip advancer. The digital carrier down-converter and the received code sequence, and generating model car- 
implementation that utilizes digital chip and phase ad- 20 for accurately measuring the code group delay 
phase and in feedback. Roundoff and commensurability 
nanochips and 100 nanocycles roundoff errors and 0.13 
millichip and 1 millicycle commensurability errors). 25 
Minimum bit design reduces the number of logic ele- 
ments thereby reducing cost, size and power consump- 
tion of electronics. The digital tracking processor bases 
L1 C/A carrier phase thereby maintaining lock at lower 30 
signal-to-noise ratios, reducing errors in feedback phase 
delay and in some cases obviating quadrature signal 
processing implementation on the P channels. The chip 
advancer is a digital pseudorandom code sequence gen- 
correlation interval thereby improving feedback con- 
trol and delay measurement accuracy. The invention 
combines the features of all-digital implementation with 
delays to provide high accuracy, high dynamics, loss of 40 fast feedback for code group by 
lock at lower signal strengths and infrequency carrier using accumulated products at selected intervals. 
cycle slips. Simple techniques for data-bit extraction, 3. A digital signal processor for use in a Global Posi- 
data-bit synchronization and cycle counting eliminate tioning System (GPS) receiver, the receiver of the type 
the need for involved circuitry and/or software found receiving at least two code-modulated signals, provid- 
in existing receivers. Flexibility is provided in selecting 45 ing digitized signals from said code-modulated signals, 
feedback interval and output averaging interval. generating model delays, generating model code se- 
Those having skill in the relevant arts, will now as a quences that are time offset by the model delays so that 
result of the applicant's teaching herein, perceive vari- the resulting model code values are closely aligned in 
ous modifications and additions which may be made to time with the received code sequences, and generating 
the invention. By way of example, the CIA phase-lock- 50 model carrier phases that are closely matched to re- 
loop of the present invention could be switched to a ceived carrier Phases, for accurately measuring the 
conventional narrow-band phase-lock-loop in the case code group delay and carrier phase of each code- 
of low SNR to allow tracking of received signals with modulated signal; the processor comprising: 
lower signal-to-noise ratios. Furthermore, implements- means for generating counter-rotation sinusoids from 
tion of quadrature signal processing may be carried out 55 model phases; 
in similar parallel implementations with certain corn- means for counter-rotating the carrier phases of the 
mon functions integrated. Furthermore, instead of bas- digitized signals with said counter-rotation sinus- 
ing all fast feedback on C/A L1 carrier phase, the C/A oids; 
channel could be dropped after acquisition and all fast means for multiplying the counter-rotated signals 
feedback could be based on P-L1 carrier phase. Data-bit 60 with the model code values and accumulating the 
synchronization could be based upon the most recent multiplication products over respective selected 
value for Pi group delay and removal of the P2 data-bit time intervals; 
sign would be based on the data-bit sign obtained from means for processing the accumulated products to 
the Pi channel. This approach of basing control on the obtain model phases and model delays; and 
Pi carrier phase would be preferable in military applica- 65 means for modifying model carrier phase to obtain 
tions but would lose lock at a signal level 3-dB worse fast feedback models for code group delays. 
than for the C/A-driven approach but 3-dB better than 4. The digital signal processor recited in claim 3 fur- 
for separate phase-lock loops for Pi and P:! given nomi- 
employing a digital carrier down-converter and code that is time offset by the model delays so that the result- 
code correlator provides an alldigital, minimum bit 
vancerS providing and accuracy in 
rier phases that are closely matched to received carrier 
and carrier phase of the code-modulated signal; the 
are reduced to (i*e*9 means for generating counter-rotation sinusoids frorn 
processor comprising: 
model phases; 
for counter-rotating the carrier phase of the 
digitized signal with said counter-rotation sinus- 
oids; 
the the multi- 
plication produces over respective selected time 
intervals; 
products to 
obtain model phase and model delay; and 
fast feedback models for code group delays. 
all fast carrier and group delay fedback on the for the counter-rotated with 
'Ode values and 
for processing the 
erator in which chip and chip rate a e  reset each code 35 for modifying carrier phase to Obtain 
2. The digital signal processor recited in claim 1 fur- 
ther comprising: 
C/A phase-driven fast feedback loops for all phases and means for applying slow feedback corrections to the 
ther comprising: 
4.82 1,294 
21 
means for applying slow feedback corrections to the 
fast feedback models, for code group delays, by 
using accumulated products at selected intervals. 
5. A digital signal processor for use in a Global Posi- 
tioning System (GPS) receiver, the receiver of the type 
receiving at least two code-modulated signals, provid- 
ing digitized signals from said code-modulated signals, 
generating model delays, generating model code se- 
quences that are time offset by the model delays so that 
the resulting model code values are closely aligned in 
time with the received code sequences, and generating 
model carrier phases that are closely matched to re- 
ceived carrier phases, for accurately measuring the 
code group delay and carrier phase of each code- 
modulated signal; the processor comprising: 
means for generating counter-rotation sinusoids from 
model phases; 
means for counter-rotating the carrier phases of the 
digitized signals with said counter-rotation sinus- 
oids; 
means for multiplying the counter-rotated signals 
with the model code values and accumulating the 
multiplication products over respective selected 
time intervals; 
means for processing the accumulated products to 
obtain model phases and model delays; and 
means for modifying the model carrier phase of one 
of said code-modulated signals to obtain a fast feed- 
back model for the carrier phase of another such 
code-modulated signal. 
6. A digital signal processor for use in a Global Posi- 
tioning System (GPS) receiver, the receiver of the type 
receiving a code-modulated signal, providing a digi- 
tized signal from said code-modulated signal, generat- 
ing model delays, generating a model code sequence 
that is time offset by the model delays so that the result- 
ing model code values are closely aligned in time with 
the received code sequence, and generating model car- 
rier phases that are closely matched to received carrier 
phase, for accurately measuring the code group delay 
and carrier phase of the code-modulated signal; the 
processor comprising: 
means for generating counter-rotation sinusoids from 
model phases; 
means for counter-rotating the carrier phase of the 
digitized signal with said counter-rotation sinus- 
oids; 
means for multiplying the counter-rotated signal with 
the model code values and accumulating the multi- 
plication products over respective selected time 
intervals; 
means for processing the accumulated products to 
obtain model phase and model delay; and 
means for averaging measured code group delays 
over a selected short averaging interval by using 
concurrently measured values for carrier phase to 
remove the averaged effects of time variations of 
the code group delays over said interval. 
7. A digital signal processor for use in a Global Posi- 
tioning System (GPS) receiver, the receiver of the type 
receiving at least two code-modulated signals, provid- 
ing digitized signals from said code-modulated signals, 
generating model delays, generating model code se- 
quences that are time offset by the model delays so that 
the resulting model code values are closely aligned in 
time with the received code sequences, and generating 
model carrier phases that are closely matched to re- 
ceived carrier phases, for accurately measuring the 
22 
code group delay and carrier phase of each code- 
modulated signal; the processor comprising: 
means for generating counter-rotation sinusoids from 
model phases; 
means for counter-rotating the carrier phases of the 
digitized signals with said counter-rotation sinus- 
oids; 
means for multiplying the counter-rotated signals 
with the model code values and accumulating the 
multiplication products over respective selected 
time intervals; 
means for processing the accumulated products to 
obtain model phases and model delays; and 
means for averaging measured code group delays 
over a selected short averaging interval and using 
concurrently measured values for carrier phase to 
remove the averaged effects of time variations of 
the code group delays over said interval. 
8. A digital signal processor for use in a Global Posi- 
2o tioning System (GPS) receiver, the receiver of the type 
receiving a code-modulated signal, providing a digi- 
tized signal from said code-modulated signal, generat- 
ing model delays, generating a model code sequence 
that is time offset by the model delays so that the result- 
25 ing model code values are closely aligned in time with 
the received code sequence, and generating model car- 
rier phase that are closely matched to received carrier 
phase, for accurately measuring the code group delay 
3o and carrier phase of the code-modulated signal; the 
processor comprising: 
means for generating counter-rotation sinusoids from 
model phases; 
means for counter-rotating the carrier phase of the 
digitized signal with said counter-rotation sinus- 
oids; 
means for multiplying the counter-rotated signal with 
the model code values and accumulating the multi- 
plication products over respective selected time 
means for processing the accumulated products to 
obtain model phase and model delay; and 
means for extracting measured carrier phase for a 
code-modulated signal by extracting residual phase 
from the accumulated products and then adding 
said residual phase to the model phase for the inter- 
val. 
9. A digital signal processor for use in a Global Posi- 
tioning system (GPS) receiver, the receiver of the type 
50 receiving a code-modulated signal, providing a digi- 
tized signal from said code-modulated signal, generat- 
ing model delays, generating a model code sequence 
that is time offset by the model delays so that the result- 
ing model code values are closely aligned in time with 
55 the received code sequence, and generating model car- 
rier phases that are closely matched to received carrier 
phase, for accurately measuring the code group delay 
and carrier phase of the code-modulated signal; the 
processor comprising: 
means for generating counter-rotation sinusoids from 
model phases; 
means for counter-rotating the carrier phase of the 
digitized signal with said counter-rotation sinus- 
oids; 
means for multiplying the counter-rotated signal with 
the model code values and accumulating the multi- 
plication products over respective selected time 
intervals; 
5 
10 
l5 
35 
40 intervals; 
45 
60 
65 
23 
4,821,294 
means for processing the accumulated products to 
obtain model phase and model delay; and 
means for extracting measured code group delay for 
a code-modulated signal by extracting residual 
delay from the accumulated products and then 
adding said residual delay to the model delay for 
the interval. 
10. A digital signal processor for use in a Global 
Positioning System (GPS) receiver, the receiver of the 
type receiving at least two code-modulated signals, 
providing digitized signals from said code-modulated 
signals, generating model delays, generating model 
code sequences that are time offset by the model delays 
so that the resulting mode code values are closely 
aligned in time with the received code sequence, and 
generating model carrier phases that are closely 
matched to received carrier phase, for accurately mea- 
suring the code group delay and carrier phase of each 
code-modulated signal; the processor comprising: 
means for generating counter-rotation sinusoids from 
model phases; 
means for counter-rotating the carrier phase of the 
digitized signals with said counter-rotation sinus- 
oids; 
means for multiplying the counter-rotated signals 
with the model code values and accumulating the 
multiplication products over respective selected 
time intervals; 
means for processing the accumulated products to 
obtain model phases and model delays; 
said receiver also receiving a data signal superim- 
posed upon said code-modulated signals, said pro- 
cessor further comprising means for testing the 
logic sign of the accumulated products for extract- 
ing a data bit sign therefrom for a data-bit interval; 
and 
means for removing the data-bit signal from one 
code-modulated signal based upon the data-bit sign 
extracted from another code-modulated signal. 
24 
tion interval start time with a previously measured 
code group delay. 
12. A digital signal processor for use in a Global 
Positioning System (GPS) receiver, the receiver of the 
5 type receiving a code-modulated signal, providing a 
digitized signal from said code-modulated signal, gener- 
ating model delays, generating a model code sequence 
that is time offset by the model delays so that the result- 
ing model code values are closely aligned in time with 
10 the received code sequence, and generating model car- 
rier phase that are closely matched to received carrier 
phase for accurately measuring the code group delay 
and carrier phase of each code-modulated signal; the 
processor comprising: 
means for generating counter-rotation sinusoids from 
model phases; 
means for counter-rotating the carrier phase of the 
digitized signal with said counter-rotation sinus- 
oids; 
means for multiplying the counter-rotated signal with 
the model code values and accumulating the multi- 
plication products over respective selected time 
intervals; 
means for processing the accumulated products to 
obtain model phase and model delay; and 
means for estimating model carrier phase over a fu- 
ture time interval by two-point linear extrapolation 
of measured phase from prior time intervals. 
13. A digital signal processor for use in a Global 
Positioning System (GPS) receiver, the receiver of the 
type receiving at least two code-modulated signals, 
providing digitized signals from said code-modulated 
signals, generating model delays, generating model 
35 code sequences that are time offset by t he model delays 
so that the resulting mode code values are closely 
aligned in time with the received code sequences, and 
generating model carrier phases that are closely 
matched to received carrier bhases. for accuratelv mea- 
l5 
2o 
25 
3o 
11. A digital signal processor for use in a-Globa1 @ suring the code group delay and carrier phase of each 
means for generating counter-rotation sinusoids from 
model phases; 
means for comter-rotating the carrier Phases of the 
digitized Signals with said COUnter-rOtatiOn sinus- 
oids; 
means for multiplying the counter-rotated signals 
with the model code values and accumulating the 
multiplication products over respective selected 
time intervals; 
means for processing the accumulated products to 
obtain model phases and model delays; and 
means for averaging measured carrier phase values of 
one code-modulated signal over a selected short 
averaging interval by using concurrently measured 
values of carrier phase of another code-modulated 
signal to remove the averaged effects of time varia- 
tion in said one carrier phase over said interval. 
14. A method of digitally processing signals in a 
60 Global Positioning System (GPS) receiver, the receiver 
of the type receiving a code-modulated signal, provid- 
ing a digitized signal from said code-modulated signal, 
generating model delays, generating a model code se- 
quence that is time offset by the model delays so that the 
65 resulting model code values are closely aligned n time 
with the received code sequence, and generating model 
carrier phases that are closely matched to received 
carrier phase, for accurately measuring the code group 
Positioning System (GPS) receiver, the receiver of the 
type receiving a mde-modulated signal, providing a 
digitized signal from said code-modulated signal, gener- 
ating model delays, generating a model code sequence 
that is time offset by the model delays SO that the result- 45 
ing model code values are closely aligned in time with 
the received code sequence, and generating model car- 
rier phases that are closely matched to received carrier 
phase, for accurately measuring the code group delay 
and carrier phase of each code-modulated signal; the 50 
processor comprising: 
means for generating counter-rotation sinusoids from 
model phases; 
means for counter-rotating the carrier phase of the 
digitized signal with said counter-rotation sinus- 55 
oids; 
means for multiplying the counter-rotated signal with 
the model code values and accumulating the multi- 
plication products over respective selected time 
intervals; 
means for processing the accumulated products to 
obtain model phase and model delay; 
said receiver also receiving a data signal having de- 
fined data-bit intervals and being superimposed 
upon said code-modulated signal; and 
said digital processor further comprising means for 
synchronizing the product accumulation intervals 
with the data-bit intervals by offsetting accumula- 
code-modulated signal; the Processor comP*sing: 
25 
4,821,294 
26 
delay and carrier phase of the code-modulated signal; processing the accumulated products to obtain model 
the method comprising the steps of phases and model delays; and 
generating counter-rotation sinusoids from model modifying the model carrier phase of one of said 
phases; code-modulated signals to obtain a fast feedback 
counter-rotating the carrier phase of the digitized 5 model for the carrier phase of another such code- 
signals with said counter-rotation sinusoids; modulated signal. 
multiplying the counter-rotated signals with the 19. A method of digitally processing signals in a 
model code values and accumulating the multipli- Global Positioning system (GPS) receiver, the receiver 
cation products over respective selected time inter- of the type receiving a code-modulated signal, provid- 
vals; 10 ing a digitized signal from said code-modulated signal, 
processing the accumulated products to obtain model generating model delays, generating a model code se- 
phase and model delay; and quence that is time offset by the model delays so that the 
modifying model carrier phase to obtain fast feedback resulting model code values are closely aligned in time 
models for code groups delays. with the received code sequence, and generating model 
15. The method of digitally processing signals recited 15 carrier phases that are closely matched to received 
in claim 14 further comprising the step of applying slow carrier phase, for accurately measuring the code group 
feedback corrections to the fast feedback models, for delay and carrier phase of the code-modulated signal; 
code group delay, by using accumulated products at the method comprising the steps of: 
selected intervals. generating counter-rotation sinusoids from model 
phases; 
Global Positioning System (GPS) receiver, the receiver counter-rotating the carrier phase of the digitized 
of the type receiving at least two code-modulated sig- signals with said counter-rotation sinusoids; 
nals, providing digitized signals from said code- multiplying the counter-rotated signals with the 
modulated signals, generating model delays, generating model code values and accumulating the multipli- 
model code sequences that are time offset by the model 25 cation products over respective selected time inter- 
delays so that the resulting model code values are vals; 
closely aligned in time with the received code sequen- processing the accumulated products to obtain model 
ces, and generating model carrier phases that are phase and model delay; and 
closely matched to received carrier phases, for accu- averaging measured code group delays over a se- 
rately measuring the code group delay and carrier phase 30 lected short averaging interval by using concur- 
of each code-modulated signal; the method comprising rently measured values for carrier phase to remove 
the steps of: the averaged effects of time variations of the code 
generating counter-rotation sinusoids from model group delays over said interval. 
phases; 20. A method of digitally processing signals in a 
counter-rotating the carrier phases of the digitized 35 Global Positioning System (GPS) receiver, the receiver 
signals with said counter rotation sinusoids; of the type receiving at least two code-modulated sig- 
multiplying the counter rotated signals with the nals, providing digitized signals from said code- 
model code values and accumulating the multipli- modulated signals, generated model delays, generating 
cation products over respective time intervals; model code sequences that are time offset by the model 
processing the accumulated products to obtain model 40 delays so that the resulting model code values are 
phases and model delays; and closely aligned in time with the received code sequen- 
modifying model carrier phase to obtain fast feedback ces, and generating model carrier phases that are 
models for code group delays. closely matched to received carrier phases, for accu- 
17. The method of digitally processing signals recited rately measuring the code group delay and carrier phase 
in claim 16 further comprising the step of applying slow 45 of each code-modulated signal; the method comprising 
feedback corrections to the fast feedback models, for the steps of: 
code group delay, by using accumulated products at generating counter-rotation sinusoids from model 
selected intervals. phases; 
18. A method of digitally processing signals in a counter-rotating the carrier phases of the digitized 
Global Positioning System (GPS) receiver, the receiver 50 
of the type receiving at least two code-modulated sig- multiplying the counter rotated signals with the 
nals, providing digitized signals from said code- model code values and accumulating the multipli- 
modulated signals, generating model delays, generating cation products over respective time intervals; 
model code sequences that are time offset by the model processing the accumulated products to obtain model 
delays so that the resulting mode code values are 55 phases and model delays; and 
closely aligned in time with the received code sequen- averaging measured code group delays over a se- 
ces, and generating model carrier phases that are lected short averaging interval and using concur- 
closely matched to received carrier phases, for accu- rently measured values for carrier phase to remove 
rately measuring the code group delay and carrier phase the averaged effects of time variations of the code 
of each code-modulated signal; the method comprising 60 group delays over said interval. 
the steps of: 21. A method of digitally processing signals in a 
generating counter-rotation sinusoids from model Global Positioning System (GPS) receiver, the receiver 
phases; of the type receiving a code-modulated signal, provid- 
counter-rotating the carrier phases of the digitized ing a digitized signal from said code-modulated signal, 
signals with said counter-rotation sinusoids; 65 generating model delays, generating a model code se- 
multiplying the counter-rotated signals with the quence that is time offset by the model delays so that the 
model code values and accumulating the multipli- resulting model code values are closely aligned in time 
cation products over respective time intervals; with the received code sequence, and generating model 
16. A method of digitally processing signals in a 20 
signals with said counter rotation sinusoids; 
4,821: 
27 
carrier phases that are closely matched to received 
carrier phase, for accurately measuring the code group 
delay and carrier phase of the code-modulated signal; 
the method comprising the steps of: 
generating counter-rotation sinusoids from model 5 
phases; 
counter-rotating the carrier phase of the digitized 
signals with said counter-rotation sinusoids; 
multiplying the counter-rotated signals with the 
model code values and accumulating the multipli- 10 
cation products over respective selected time inter- 
processing the accumulated products to obtain model 
phase and model delay; and 
extracting measured carrier phase for a code- 15 
modulated signal by extracting residual phase from 
the accumulated products and then adding said 
residual phase to the model phase for the interval. 
22. A method of digitally processing signals in a 
Global Positioning System (GPS) receiver, the receiver 20 
of the type receiving a code-modulated signal, provid- 
ing a digitized signal from said code-modulated signal, 
generating model delays, generating a model code se- 
quence that is time offset by the model delays so that the 
resulting model code values are closely aligned in time 25 
with the received code sequence, and generating model 
carrier phases that are closely matched to received 
carrier phase, for accurately measuring the code group 
delay and carrier phase of the code-modulated signal; 
the method comprising the steps of: 
generating counter-rotation sinusoids from model 
phases; 
counter-rotating the carrier phase of the digitized 
signals with said counter-rotation sinusoids; 
multiplying the counter-rotated signals with the 35 
model code values and accumulating the multipli- 
cation products over respective selected time inter- 
vals; 
processing the accumulated products to obtain model 
extracting measured code group delay for a code- 
modulated signal by extracting residual delay from 
the accumulated products and then adding said 
residual delay to the model delay for the interval. 
23. A method of digitally processing signals in a 45 
Global Positioning System (GPS) receiver, the receiver 
of the type receiving at least two code-modulated sig- 
nals, providing digitized signals from said code- 
modulated signals, generating model delays, generating 
model code sequences that are time offset by the model 50 
delays so that the resulting model code values are 
closely aligned in time with the received code sequen- 
ces, and generating model carrier phases that are 
closely matched to received carrier phases, for accu- 
vals; 
30 
phase and model delay; and 40 
,294 
28 
accumulated products for extracting a data bit sign 
therefrom for a data bit interval; and 
removing the data bit sign from one code-modulated 
signal based upon the data bit sign extracted from 
another code-modulated signal. 
24. A method of digitally processing signals in a 
Global Positioning System (GPS) receiver, the receiver 
of the type receiving a code-modulated signal, provid- 
ing a digitized signal from said code-modulated signal, 
generating model delays, generating a model code se- 
quence that is time offset by the model delays so that the 
resulting model code values are closely aligned in time 
with the received code sequence, and generating model 
carrier phases that are closely matched to received 
carrier phase, for accurately measuring the code group 
delay and carrier phase of the code-modulated signal; 
the method comprising the steps of: 
generating counter-rotation sinusoids from model 
phases; 
counter-rotating the carrier phase of the digitized 
signals with said counter-rotation sinusoids; 
multiplying the counter-rotated signals with the 
model code values and accumulating the multipli- 
cation products over respective selected time inter- 
vals; 
processing the accumulated products to obtain model 
phase and model delay; 
receiving a data signal having defined data-bit inter- 
vals and being superimposed upon said code- 
modulated signal; and 
synchronizing the product accumulation intervals 
with the data-bit intervals by offsetting accumula- 
tion interval start time with a previously measured 
code group delay. 
25. A method of digitally processing signals in a 
Global Positioning System (GPS) receiver, the receiver 
of the type receiving a code-modulated signal, provid- 
ing a digitized signal from said code-modulated signal, 
generating model delays, generating a model code se- 
quence that is time offset by the model delays so that the 
resulting model code values are closely aligned in time 
with the received code sequence, and generating model 
carrier phases that are closely matched to received 
carrier phase, for accurately measuring the code group 
delay and carrier phase of the code-modulated signal; 
the method comprising the steps of: 
generating counter-rotation sinusoids from model 
phases; 
counter-rotating the carrier phase of the digitized 
signals with said counter-rotation sinusoids; 
multiplying the counter-rotated signals with the 
model code values and accumulating the multipli- 
cation products over respective selected time inter- 
vals; 
rately measuring the code group delay and carrier phase 55 processing the accumulated products to obtain model 
of each code-modulated signal; the method comprising phase and model delay; and 
the steps of: estimating model carrier phase over a future time 
generating counter-rotation sinusoids from model interval by two-point linear extrapolation of mea- 
phases; sured phase from prior time intervals. 
counter-rotating the carrier phases of the digitized 60 26. A method of digitally processing signals in a 
signals with said counter rotation sinusoids; Global Positioning System (GPS) receiver, the receiver 
multiplying the counter rotated signals with the of the type receiving at least two code-modulated sig- 
model code values and accumulating the multipli- nals, providing digitized signals from said code- 
cation products over respective time intervals; modulated signals, generating model delays, generating 
processing the accumulated products to obtain model 65 model code sequences that are time offset by the model 
phases and model delays; delays so that the resulting model code values are 
receiving a data signal superimposed upon said code- closely aligned in time with the received code sequen- 
modulated signals, testing the logic sign of the ces, and generating model carrier phases that are 
29 
4,821,294 
multiplying the counter rotated signals with the 
model code values and accumulating the multipli- 
cation products over respective time intervals; 
processing the accumulated products to obtain model 
phases and model delays: and 
closely matched to received carrier phases, for accu- 
rately measuring the code group delay and carrier phase 
of each code-modulated signal; the method comprising 
the steps of: averaging measured cairier phase values of one 
codemodulated signal over a selected short averag- 
ing interval by using concurrently measured values generating counter-rotation sinusoids from model 
phases; ofcarrier ph&e of another code-modulated signal 
to remove the averaged effects of time variation in 
said one carrier Dhase over said interval. 
10 counter-rotating the carrier phases of the digitized 
signals with said counter rotation sinusoids; * * * * *  
15 
20 
25 
30 
35 
40 
45 
50 
55 
60 
65 
