Signal Digitizer and Cross-Correlation Application Specific Integrated Circuit by Zelenin, Denis et al.
1111111111111111111inuuuuu
(12) United States Patent
Baranauskas et al.
(54) SIGNAL DIGITIZER AND
CROSS-CORRELATION APPLICATION
SPECIFIC INTEGRATED CIRCUIT
(71) Applicants: Pacific MicroCHIP Corp., Culver City,
CA (US); California Institute of
Technology, Pasadena, CA (US)
(72) Inventors: Dalius Baranauskas, Culver City, CA
(US); Gytis Baranauskas, Culver City,
CA (US); Denis Zelenin, Culver City,
CA (US); Pekka Kangaslahti, Culver
City, CA (US); Alan B. Tanner, Culver
City, CA (US); Boon H. Lim, Culver
City, CA (US)
(73) Assignees: PACIFIC MICROCHIP CORP.,
Culver City, CA (US); CALIFORNIA
INSTITUTE OF TECHNOLOGY,
Pasadena, CA (US)
(*) Notice: Subject to any disclaimer, the term of this
patent is extended or adjusted under 35
U.S.C. 154(b) by 337 days.
(21) Appl. No.: 14/505,428
(22) Filed: Oct. 2, 2014
(65) Prior Publication Data
US 2016/0099804 Al Apr. 7, 2016
(51) Int. Cl.
G06G 7/32 (2006.01)
H04L 7/04 (2006.01)
H04B 7/185 (2006.01)
H04B 7/08 (2006.01)
(52) U.S. Cl.
CPC ........... H04L 7/042 (2013.01); H04B 7/0848
(2013.01); H04B 7/185 (2013.01)
(58) Field of Classification Search
CPC ............ H04L 7/042; H04B 7/185; H04B 7/06
CONTROL I/O
(io) Patent No.: US 9,628,263 B2
(45) Date of Patent: Apr. 18, 2017
USPC .......................................................... 708/813
See application file for complete search history.
(56) References Cited
U.S. PATENT DOCUMENTS
4,097,801 A 6/1978 Freeman et al.
6,366,629 BI * 4/2002 Chen ..................... H04L 7/0029
348/21
6,861,978 132 3/2005 Lam
7,280,623 132 10/2007 Gupta et al.
7,532,663 132 5/2009 Lewis
(Continued)
OTHER PUBLICATIONS
International Application No. PCT/US2015/053601 filed Oct. 1,
2015, PCT International Search Report and the Written Opinion of
the International Searching Authority dated Jan. 19, 2016.
Primary Examiner Tan V. Mai
(74) Attorney, Agent, or Firm Blakely Sokoloff Taylor
& Zafman LLP
(57) ABSTRACT
According to one embodiment, a cross-correlator comprises
a plurality of analog front ends (AFEs), a cross-correlation
circuit and a data serializer. Each of the AFEs comprises a
variable gain amplifier (VGA) and a corresponding analog-
to-digital converter (ADC) in which the VGA receives and
modifies a unique analog signal associates with a measured
analog radio frequency (RF) signal and the ADC produces
digital data associated with the modified analog signal.
Communicatively coupled to the AFEs, the cross-correlation
circuit performs a cross-correlation operation on the digital
data produced from different measured analog RF signals.
The data serializer is communicatively coupled to the sum-
ming and cross-correlating matrix and continuously outputs
a prescribed amount of the correlated digital data.
/Of H701. (f2C SLFCLUCK INTERf.
REF CLOCKCENEF.ATCi~. 7-UNiRO
zxe
CLK_Z
704 '
FIRST
ANALCG 
_LK 3
RF COMPONENTS ed FROM H8L`S -iy
(FROM 4c^c^1 12 _i3.i) 6 7NI U IDI 'S i ZING
Vfik/ADC.)
ANALCG
RF COMPON=NTS E4 FP.ONI-ENDS
(ERCP4 R'r"F;Vc4t i.37J 64 x INPU' ICI1  1-7 NG
UGA/ADC)
12 Claims, 21 Drawing Sheets
C00S5-WRREL TOR
=u
'Uf✓frf ANU
O 
AE
CROS AI 
➢,
RREL 3NC - ?i
MP. RSh ~
Z4S?
https://ntrs.nasa.gov/search.jsp?R=20170004336 2019-08-29T22:59:05+00:00Z
US 9,628,263 B2
Page 2
(56) References Cited
U.S. PATENT DOCUMENTS
8,362,953 B2 1/2013 Srikantiah et al.
8,576,116 B2 11/2013 Matsuo
8,774,329 B2 7/2014 Kawaguchi
2 00 2/00 642 14 Al 5/2002 Hattori et al.
2010/0056083 Al* 3/2010 Kim ....................... H04B 17/21
455/115.1
2010/0067625 Al 3/2010 Sankabathula et al.
2012/0140858 Al 6/2012 Roh et al.
2014/0219320 Al 8/2014 Germain
* cited by examiner
U.S. Patent Apr. 18, 2017 Sheet 1 of 21 US 9,628,263 B2
140
Fl RS-
FREQUENCY 142
BAND
SECOND
FREQUENCY
BAND
144
DECEIVERS
133
110
122
RECEIVERS
132
")c) 
J
RECEIVERS
134
~- -_~ 12
FBI . l-1 
-SATELLITE
121
1
4
2
b CD
€
 
O
W
N
 C
O
N
V
E
R
T
E
R
 2
00
I
~
FI
LT
ER
]A
MP
LI
~I
ER
S
I
G
N
A
L
:
5
2
5
0
2
60
29
0
00
22
2
2
4
6
2
5
2
A
N
T
E
N
2
4
4
A
M
P
L^
Iyr
yFI
ER
MI
XE
nR
N
(
~
N
A
G
 Y
2
7
2
FI
LT
ER
A
M
P
L
I
F
I
E
R
Q
S
I
G
N
A
L
2
7
0
2
80
2
9
2
.
24
2
t.
~
L
O
C
A
L
0
O
S
C
I
L
L
A
T
O
R
*
~
{'f
2}
 2
4
0
R
E
CE
IV
ER
 1
32
U.S. Patent Apr. 18, 2017 Sheet 3 of 21 US 9,628,263 B2
134 ?24
C
R
O
S
S-
C
O
R
R
E
L
A
T
I
O
N
 
C
R
O
S
S
-
C
O
R
R
E
L
A
T
I
O
N
 
C
R
O
S
S-
C
O
R
R
E
L
A
T
I
O
N
 
C
R
O
S
S
-
C
O
P
R
E
L
A
T
I
O
N
 
~
S
Y
S
T
E
M
 3
55
 
S
Y
S
T
E
M
 3
50
 
S
Y
S
T
E
M
 3
4
5
 
S
Y
S
T
E
M
 3
40
I
_
_
_
_
_
_
_
_
_
_
.
~
_
 
1_
_
_
_
_
_
_
_
_
L
 _
_
 
I
_
_
_
_
_
_
_
_
_
_
 
_
_
_
_
_
_
_
_
~
 
_
 
I
_
_
_
.
~
 
V
I 
t 
1 
1
X
C
1
 
X
C
3
 
° 
i 
X
C
1
 
X
C
3
 
° 
r 
X.
cl
 
X
C
3
 
° 
i 
X
C
l 
X
C
3
 
°
6
4
X
6
4
 
64
X6
4 
i 
4
5
0
 
1 
64
X6
4 
64
X.
64
 
ja
 
6
4
X
6
4
 
64
X6
4 
i 
4
0
5
 
1 
64
X6
4 
64
X6
4 
j
X
C
2
 
X
C
4
 
° 
I 
X
C
2
 
X
C
4
 
° 
a 
X
C
2
 
X.
c=
1 
'
 
1 
X
C
2
 
X
C
4
 
1
6
4
X
6
4
 
64
X6
4 
j 
1 
64
X6
4 
64
X6
4 
j°
 
6
4
X
6
4
 
64
X6
4 
j 
I 
64
X6
4 
64
X5
4 
j
I 
t 
I 
1
-
-
-
-
-
-
r
'
-
1
 
'
 
-
-
-
-
-
-
-
-
 
-
1
 
'
 
-
 
1 
-
-
-
-
-
-
-
-
-
r
-
-
-
-
-
1 
4
1
5
 
—
 
—
 
1
4
6
0
 
s
 
/. 
"
S
CR
OS
S-
cO
RR
EL
AT
IO
PJ
 
.
;:
S
 
4
2
a
,
 
C
R
O
S
S
-
 C
O
R
R
E
L
A
T
I
O
N
S
U
B
S
Y
S
T
E
M
 3
.3
5  
r 
4
0
0
4
2
0
1P
1_
I[
12
, :
3]
 
NI
 '
i$
S
Y
S
T
E
M
 
N
_
 
)
 
M
2Q
[1
27
:3
~r
' 
4
6
5
F.
R.
 
X
C
l 
X
C
3
 
° 
A
R
M
1
 
12
7:
0
 I
 
X
C
1
 
X
C
3
 
°
a 
X
c
l
 
X
C
3
 
C
R
O
S
S
-
 
A
R
M
li
 
° 
I 
X
C
l 
X
C
3
 
° 
J
I 
~
 
~
 
~
 
t 
I 
1
6
4
X
6
4
 
64
X6
4 
I 
:
 
64
X6
4 
64
X.
64
 
,
 
64
X.
64
 
64
X6
4 
I C
O
R
R
E
L
A
T
I
O
N,
 
[1
27
:3
] 
; 
64
X6
4 
6
4
X
6
4
 
°
I 
CR
OS
S-
" 
I 
a 
S
Y
S
T
E
M
 
I
C
O
R
R
E
L
A
T
I
O
N
 
I 
X
C
2
 
X
C
4
 
° 
I 
X
C
2
 
X
C
4
 
° 
a 
X
C
2
 
XC
=1
 
~
^
-
-
 
3
4
0 
,
 
X
C
2
 
X
C
4
 
°
6
4
X
6
4
 
64
X6
4 
I 
S
Y
S
T
E
M
1
 
64
X6
4 
64
X6
4 
1
° 
6
4
X
6
4
 
64
X6
4 
I 
I 
64
X6
4 
64
X6
4 
I
I 
i
38
5 
1 
a 
1
4_
30
-
-
-
-
-
-
-
-
 
—
1
-
-
-
-
-
-
-
-
-
 
°
a
—
 
-
-
-
-
-
-
-
-
-
1 
-
 
-
-
-
-
-
-
-
-
-
-
1 
A
4
8
5
 
S
 
4
7
.
5
4
 
44
0 
5
 
S
 
.
.
.
.
.
.
.
.
.
.
.
 
S
 
4
3
5
 
C ►'
t
i
C
R
O
S
S
-
C
O
R
R
F
L
A
T
I
O
N
 
4
8
0
 
N
S
Y
S
T
E
M
 3
75
 
A
R
M
 3f
1.
12
7:
0 
A
R
M
3I
11
27
:3
I
_
_
_
_
_
~
_
_
_
 
I
_
_
_
_
_
_
_
_
_
 
_
_
1
_
_
_
_
_
_
_
_
_
_
_
 
I
_
m
_
_
_
_
_
_
_
_
_
_
I 
X
C
l 
X
C
3
 
° 
I 
X
c
l
 
x
C
3
 
°
a 
X
c
l
 
X
C
3
 
I 
I 
X
c
l
 
X
C
3
 
°
64
X6
4.
 
64
X6
4 
j 
1 
64
X6
4 
64
X6
4 
j 
a 
64
X.
64
 
64
X6
4 
j 
1 
64
X6
4 
64
X6
4 
j
S
 
I 
I 
1
X
C
2
 
X
C
4
 
° 
i 
X
C
2
 
X
C
4
 
°
i 
X
C
2
 
X
C
4
 
° 
i 
X
C
2
 
X
C
4
 
°
6
4
X
6
4
 
64
X6
4 
i 
4
5
5
 
t 
64
X6
4 
64
X6
4 
jl
 
6
4
X
6
4
 
64
X6
4 
j 
4
1
0
 
I 
64
X6
4 
6
4
X
6
4
 
j
C
R
O
S
S-
C
O
R
R
E
L
A
T
I
O
N
 
C
R
O
S
S
-
C
O
R
R
E
L
A
T
I
O
N
 
C
R
O
S
S
 -
C
O
R
R
w
L
A
T
I
O
N
 
0
0
S
Y
S
T
E
M
 3
55
 
S
Y
S
T
E
M
 3
73
 
SY
ST
E=
M 
37
0 
N W N
5
6
0
X
c
l 
6
4
S
P
`
°
 
6
4
X
C
3
(6
4X
64
)
(6
4X
64
)
CD
5E
30
`
~
S
P
5
2
0
3.
12
6
4
6
4
p
 f
~5
4
4 
f
 
y
A
R
M
21
(6
3:
0]
!
f
 
3
4
0
~
5
4
0
~
t.
~
o
`
5
5
0
-
-
-
-
5
1
7
 
S
P
 
`
 
A
R
M
 I
.1
[6
3:
0]
A
R
M
21
[1
27
:6
4]
°
s
P
`
~
 
S
P
`
 
S
P
 
5,
55
3
 
.
~
J2
30
4 
5
4
2
A
R
M
21
[1
27
;6
4]
5
4
6
0 n
6
4
3
1
4
X
C
2
 
6
4
5
P
°
°
 
6
4
X
C
4
(6
4X
64
)
(6
4X
64
)
5
1
0
`
~
a
P
5
30
~
5
6
5
A
R
M
11
[1
27
:0
] 
0
A
R
M
21
[1
27
:0
]
oN
o
N
3
0
0
3
1
0
s
U.S. Patent Apr. 18, 2017 Sheet 6 of 21 US 9,628,263 B2
632 640 640 640 640 640 540 640 640 620
12
r
5507
SQIt
F°.
Ir 
600
612
610 1
® @ 510 520 5300 ~
® S0Q
ASIC ASIC ASIC. ASIC FIC ASIC ASIC ASIC
PG .~SiC FSIC R]ASIC ASIC R]ASIC ASt54~
ASIC ASIC ASIC FASK
630
ASIC ASIC ASIC ASI
0
5
0
ASIC ASIC ASIC rASI]C ASIC ASIC ASIC H
CO~dI'KOLLLK
53-4
H[,ASI]C [ASI]C [ASI]C ~ ASICH[ASI]C ASIC 0
06(P Pq 
A 
ElicEli
ASIC 
ElsilcEjlc Ed Ed
f ux MOX6 90
U.S. Patent Apr. 18, 2017 Sheet 7 of 21
ll 0x0:00 OOO~oO':OOa~,la0~00'O~o~,6oO~oY,Y,:0000x:00 :Z!' ~OO~i~:OQ!D~'l3l.oiO~iGiOQ :Z!' ~OO~Q:OQOoa:000~Do0Y~fo4ti:00:O.i0~i00o4100 :ifo.f~fo~4ti:000. 0:0:0 .0000!DOi:0:00~' t~ZlOOiGi0:00Z!' O~IA. Oi:OQ ag o............................................................................. .........................................................................................oOn:aaooQa~sOa:aa:Oc;Qaoan:aaoo~a~►oOn:aa00,60':a .a0000m:oa .~1ous1om0:a .a00aom:aaD o s as a oaa a as o a as a a a
Oa 
aa001: 4 0a0Yfaaa0f~0aA0aa0000a00a0a0
s~~ n n n o ~ n wl
o0a;a:o.c oo4oao'n:o.a0000ao;o:aaoo0000 !
a oaoaos~~soaaa~oaooQ000~ao~ooa6aaoaoa 
.............................................................................................
ooaoa oaoaoaoa r,ao;ooaoaorlaaaoaoa
000 0000 000 ,000x0000, 000
000:00 :000000:00000000000, :000000:00
ao 
0
:
a
o
0
a0
0
 
00
a
00
aoao
0
o 
0
:o
0
ao aa 
0 
o 
0000
a. :a:a0oao :o 
...............................................................................................
US 9,628,263 B2
C
O
N
T
R
O
L
 1
/0
C
R
O
S
S
 C
O
R
R
E
L
A
T
O
R
7
0
2
70
1 
(1
7'
I>
La
VE
; 
50
0
C
L
O
C
K
SN
IE
RF
AC
E/
R
E
F
_
 C
L
O
C
K
G
E
N
E
R
A
T
O
R
C
L
K
_
l 
C
O
N
T
R
O
L
L
E
R
7Q
..
.
?1
13
0
CL
K 
4
N
C
L
K
-
2
C
7
0
4
X
85
 
70
6
I
~
J
F
I
R
ST
'
tR
aY
 i'
f
N
A
L
O
G
S
U
M
M
I
N
G
 A
N
D
 ~
 
A
E
6
4
F
R
O
N
T-
E
N
'
 
C`
Y
12
F.
; -
 
C
R
O
S
S
-
-
'
 
iA 
R
 
3
RF
 C
O'
~3
PC
JN
EP
3'
f5
~
C
O
R
R
E
L
A
T
I
N
G
 
A
 I
(F
RO
M 
R
E
CE
IV
ER
 1
33
)
ZI
N
G
DI
GI
TI
ZI
NG
D
I
M
A
T
R
I
X
 
A L
V
G
A
/A
DC
) 
4
74
-0
I
7
20
-
-
 
-
 
-
-
 
F.
.
~
 
Z
-
 
-
•
'
S
fD
E
fD
R
'
r
0
0
S
E
C
O
N
D
75
,:
)
O
A
N
A
L
O
G
R
F
C
O
M
P
O
N
E
N
T
S
 
6
4
F
R
O
N
T -
E
N
D
S
 
12
8
.
N
(F
RO
M 
R
E
CE
IV
ER
 1
32
)
116
4
 x
 I
N
P
U
T
I
~
DI
GI
TI
ZI
NG
V
G
A
/A
DC
)
;3
o
E
J
N
7
2
0
R
E
F
E
R
E
N
C
E
 
A
N
A
L
O
G
 
A
N
A
L
O
G
 
A
N
A
L
O
G
 
A
N
A
L
O
G
 
A
N
A
L
O
G
O
E
I
R
F
F
N
T
 
F
R
O
N
T
 E
N
 r
 
F
R
O
N
T
 E
N
 
Ff
2C
?3
T 
E
N
E
] 
FR
C?
3T
-E
NE
3 
•
 
•
 
•
 
F
R
O
N
T
-
E
N
G
S
O
U
R
C
E
C
L
K
-
-
2
 7
0
4
0,
 
8
4
0
8
1
0
FS
£ 0
0
A
N
A
L
O
G
 
I 
/
I
 
4
1
_
%
 
84
07
F
R
O
N
T
-
E
N
C
?
 
F-
TI
Nf-
]
A
N
A
L
O
G
F
R
O
N
T
-
E
N
D
RN
A.
t_
OG
F
R
O
N
T-
E
N
S
7
3
0
A
N
A
L
O
G
F
R
O
N
T
-
E
N
D
e
•
 
•
•
•
8
4
5
•
A
N
A
L
O
G
F
R
O
N
T
-
E
N
D
8
4
5
• • •
Mu
s
.
•
•
7
0
4
 
 
A
N
A
L
O
G
 F
R
O
N
T
-
E
N
D
C
L
K
 2
 
72
1/
73
1
9
 
9
3
0
J
O
 
. 
S
I
G
N
9
3
4
A
D
C
 
C
L
K
X
 C
C
A
N
A
L
O
G
 
9
2
0
 
2
S
I
G
N
A
L
 
2
 
M
A
G
N
I
T
U
D
E
V
G
A
 
9
5
0
9
0
0
~
 
9
6
0
A
G
E
9
4
0
0
A
D
C
 I
NP
€
(D
IF
FE
RE
NI
►
s
S
I
G
N
a
o
C
L
K
I  ---
 X
C
C
M
A
G
N
I
T
U
D
E
 
o t.
~
U.S. Patent Apr. 18, 2017 Sheet 12 of 21
OUTPUT[7]
OUTPUT [l] s
OUTPUT [01
1 1 1
INTERFACE
CONTROL. CON ROLLER
I/O (12C) 
'703 1 1 t
710 1 I 1
CLK_1 1 1 I
111
.. Mug
CNTL.
11t
CNT: CNTL I t 1
®
SECOND
3■■■ii■■■■~iiiiii~
HIGH-
SPEED
3iiittli
fiiiFfti
3iiitlli
US 9,628,263 B2
705 705 1 t t
1-1,704 I I F
 1 FI 
TQTHS—rE
1 1120 1 1
CLOCK -
GENERATOR 705 I 1 1
X00
;7(j7 
FIRST NICK -SPEED
REF CLK INTERFACE 1100
FIRST 704
AL AAA
1 1 t
CORREL.ATOR 500 1 1I
y 
1
Arrn2l[01
Arn12lf l]
Arm2l[ 63]
1160
7501
CLK_4
CNTL
1
2
2
12
2
12
2
12
2
i
1
37
2
1
36
2
F
R
O
M
 P
R
E
V
I
O
U
S
 T
O
T
H
 1
1
2
0a
-
j.
1
3
7
0
1
38
0
13
71
y
 
2
 
2
2o
, t
2
2
 ?
 
2
 0 
27
_.
1
1
2
00
 
1
37
4
1
32
0
10 
10
1
38
4
7.
37
3
7.
38
3
S
T
O
R
A
G
E
R
E
G
I
S
T
E
R
13
31
.
`
LK
 
0
C
L
K
S
H
I
F
T
 _
O
U
T
AO
C~
f~
1 
S
H
I
F
T
 O
U
T
R
S
T
 O
U
T
_
-
.
13
21
 
R
S
T
O
U
-
(' 
10
13
11
ho
ut
_0
L
O
U
T
C
L
K
 
ol
hc
~u
t
S
H
I
F
T
 O
U
T
-
-
1
12
31
L
U
T
 
ho
tf
t:
_2
R
S
T
_
O
U
T
 
12
30
0
1_.
'_3
.00
 
ho
ut
 3
2
1
32
2
A
R
M
1
31
4 
1
3
1
2
1
32
3 
1
36
0
1
3
1
0
1
3
1
3
1
3
2
2 10
2
 
2
 
2
 
13
S€
3
o
2
2
 
2
2
 
2
2
 ol
10 
10 
10
1
3
1
.
0
 1
35
4
13
51
 
J
 
1
36
4
X
1
 
1
35
2 
T
O
 N
E
X
T
 T
O
T
H
 1
1
0 +
-
1
35
3
1
36
2
1
3
6
3
Fl
ue
 1
3
„
o
„
13
81
1
3
4
0
R
I
P
P
L
E
C
O
U
N
T
E
R
13
41
~
 
`
 1
3
4
2
1
3
4
3
1
3
4
4
 
2'
'
13
61
 
„
0
„
1
i
ls
' B
IT
 F
RO
M
PR
EV
IO
US
 X
CC
14
21
31
 
14
20
2
14
10
1
CL
K 
0
 0
 
CL
K 
f
m
u
x
MU
X 
CL
K 
Q 
LO
UT
 
1 
D
 
1
FL
IP
-F
LO
P
12
31
 
O
 
Q 
12
3.
1
SH
IF
T—
OU
T 
SH
IF
T 
OU
T
0
m
U
x
14
31
1 
1 
14
30
2
14
00
.1
 
14
00
2
SH
IF
T—
OU
T 
Q1
01
2"
' B
IT
 F
RO
M
PR
EV
IO
US
 X
CC
.
14
10
2
C
L
K
 
Q
D
FL
IP
-F
LO
P
D
 
Q
0
m
u
x
1
Q[
1]
14
20
k
CL
K
0
0
0
12
31
 1
SH
IF
T 
O
U
T
14
00
k
13
41
k
T
4 
B
I
T
 F
R
O
M
PR
EV
IO
US
 X
CC
SH
IF
T—
OU
T 
Q[
k]
i
U.S. Patent
CLK
SHIFT OUT
RST_OUT 
7-1_
ARM T
21J
Apr. 18, 2017 Sheet 16 of 21 US 9,628,263 B2
1101, ICY, 1101~
15~; t7 1575
2 22
CLK ACCUM CLK RIPPLE
SHIFT OUT l52i SHIFT OUT COUNTER1541
RST--OUT 0GTORAGE RST._OUT
1511 REGISTER
VOUT O 1` 1 COAT
1_______
VOUT 
---
2 22
LUT VOUT --- 2 1.512
10-a VOUT---3 CLK ACCUM CLK RIPPLE
a— IV Olft
r1u. 15
SHIFT OUT 1522 SHIFT OUT COUNTER
— — IS42
RST_OUT STORAGE RST_OUT
REG;:S7ER
1532 COUT
22
CLK 4ACCUM CLK RIPPLE
SHIFT_ OUT COUNTERSHIFT--OUT 1543
RST_OI:T STOE3AC~E. RST_OUT
REGISTER
IS3 COU'T-
Y51.3 ? 22
C€_K ACCUM C€_K RIPPLE
-(_OUT" COUNTERSHIFT
RST_OUT STORAGE RST_OUT
REGISTER
1534 COUT
1550 ~ 3.5511
s
1
1576 1540
1
C
L
K
SH
IF
T -
O
U
T
R
S
T
_
QU
T
12
30
 
A
R
M
2
 ~
A
R
M
1
n
b
F
R
O
M
 P
R
E
V
I
O
U
S
 X
C
C
 
~
4
j
2
2
16
20
16
40
y ►s
C
L
K
 
10
C
L
K
00
a
o
SH
IF
T 
U
T
SH
IF
T 
O
U
T
n
~
-
O
U
T
RS
'f
~t
3U
'1
 
AC
{:
U1
"i
RS
'f
'~
t3
U'
1
RI
PP
LE
~
C
O
U
N
T
E
R
L
U
T
3
C
O
U
T
16
00
~
S
1
65
0
O
U
T
~
4
2
2
~
11
40
 6
3
 
T
O
 
N
E
X
T
 X
C
C
.
 ~
.
Ga
r
N 0
0
N W
A
R
M
2
17
:1
0
-
3
 
-
1 
1
 
3
17
50 3
Ax
'9
1 
-
1 1 3
16
00
M
E
M
M
M
M
m
p
p
0
0
w
w
w
o
m
W
E
E
M
E
m
m
m
o
a
l
17
20
I
N
P
U
T
 1
m
m
m
m
'
M
E
®
®
'
l
17
30
i
U.S. Patent Apr. 18, 2017 Sheet 19 of 21 US 9,628,263 B2
1i.t p
113063 1130b2. 113061 11301
Ain Q[0]
TOTV TOTV Tr Tv
• ®• TOPJ TOTV[631 ;:62] 1:61:3 [ [01
XCC
(03ti[0] 26 '~; 26
CELLS
ROW
26 :'6
Arm1[O] 2
.••
J-0200
hcut0 houtl hotA2 hout3 xC'C Xcc XCC
• t • xcc xcc26-Bli ( 26-f3r-' 26-B'I' 26-LIT (63:01 L62:01 [61:0j 1:0] [0:0~
Zb 26 26 26 21 26 26 26 26
s
r
114063,0
XCC CELLS ROW
TOTH[63] 114063,63 114062,63 114016:Arm1[63, 2
~.e
houtO huutl hout2 hout3 xcC xcc xcc xcc xcc
142063"-'l' 26-BTT 26-BIT 26-3:T 26-BIT [63:63; (62:63] [61:63; • • [1:6s~ [O:b3]
25 2626 26 21t26 26 2Et 26
114061,63 11` 010,03
1 1767:0 1
272x68
1&456
[3i:0]rn3 [31:0]m1 •a• [31:0]XCCo
NA NA Af"
2175:0 SERIALIZER
7:0
4x682%2
[vcut3[7j[vcm3[C][von_'3[5][voats[a3[vrut3[3;[yout3(z]['aout3[1][•so~lt3[0]1
63Ixcc063IXccfj63~Xcc063I(XCC]63IXC,,063'XO_063IXOCC63IX=C0
171 (6:I S1 (4? [31 1:21 (I:( [hl
®s•
[? iJ 0 0 0 Ci
n0[7, h0[6] h0[5] h0[4] h0[3] h0[2,
130[3.5] h0[14] h0[13] h0[12] h0[11] hU[10] h0[9] h0[8] rr3
4 TOT#
hO[23] h0[22] h0[21? h0[20] h0[19] h0[18] h0[17] h0[16] [E3]
0 11 0 0 0 0 h11 h0[24]
FIRST
-MATRIX
ROW
;SO
> ALL
U.S. Patent Apr. 18, 2017 Sheet 20 of 21 US 9,628,263 B2
rtzws
FIG. 19 DATA__LINE<7:0>
1
2
65
1.
23
2
US 9,628,263 B2
SIGNAL DIGITIZER AND
CROSS-CORRELATION APPLICATION
SPECIFIC INTEGRATED CIRCUIT
STATEMENT REGARDING FEDERALLY
SPONSORED RESEARCH AND
DEVELOPMENT
The invention described herein was made in the perfor-
mance of work under a NASA contract, and is subject to the
provisions of Public Law 96-517 (35 USC 202) in which the
Contractor has elected to retain title.
FIELD
Embodiments of the disclosure relate to the field of
electronic components. More specifically, one embodiment
of the disclosure relates to a signal digitizer and cross-
correlator that digitizes incoming analog signals and cross-
correlates the digitized signals through summing logic and a
cross-correlation matrix, where the cross-correlated results
are read out as serialized output data.
GENERAL BACKGROUND
Over the last decade or so, greater efforts have been made
to conduct more detailed geosynchronous satellite observa-
tions in efforts to understand the effects of global warming
as well as to assist in the prediction of weather and climate
changes that, in many situations, can save hundreds or
thousands of lives. In general, geosynchronous satellite
observations involve a measurement of different frequency
bands associated with microwave signals radiating from the
Earth. The data associated with these frequency bands
constitute weather and climate information. "Weather"
involves measurements of planetary conditions that are
highly dynamic and local in scale, such as precipitation or
humidity (e.g., an amount of water vapor in a selected
portion of the atmosphere), temperature, cloud formations,
or the like. "Climate" involves the measurement of planetary
conditions that are less dynamic and more global in scale,
such as ground temperature, salt content (salinity) in oceans,
or the like.
It is evident that the reliability and accuracy of weather
predictions and climate change monitoring are based, at
least in part, on an ability to obtain, store and transmit
weather and climate information for subsequent analysis.
Stated differently, an ability to obtain, store and subse-
quently transmit a greater amount of weather and climate
information improves the reliability and accuracy in the
reporting of these events.
According to a simplistic view, one may argue that, by
significantly increasing the amount of storage memory
deployed within a satellite, reliability and accuracy in
weather and climate predictions may be improved. How-
ever, satellites in space are constantly being bombarded by
charged particles that can induce changes in the data content
of semiconductor memories. This phenomenon is commonly
referred to as a "single event upset' or "SEU". Hence, the
deployment of greater and greater amounts of memory,
without a scheme for cross-correlating and compressing the
data, not only requires increased complexity in handling
SEUs, but also greatly increases the overall costs associated
with the satellite (e.g., increased metal shielding, increased
launch weight, increased memory costs, etc.) and may even
result in the transmission of less reliable data.
2
BRIEF DESCRIPTION OF THE DRAWINGS
Embodiments of the invention are illustrated by way of
example and not by way of limitation in the figures of the
5 accompanying drawings, in which like references indicate
similar elements and in which:
FIG. 1 is an exemplary block diagram of a communication
device deploying an embodiment of the invention.
FIG. 2 is an illustrative embodiment of a receiver
10 
deployed as part of the communication device of FIG. 1.
FIG. 3 is a general illustrative embodiment of propagation
paths of the IQ components of groups of receivers distrib-
uted to a plurality of cross-correlation systems.
FIG. 4 is a more detailed illustrative embodiment of the
propagation paths of the IQ components from the groups of
15 receivers distributed to the plurality of cross-correlation
systems of FIG. 3.
FIG. 5 is an illustrative embodiment of a first cross-
correlation system that receives RE components from first
and second sources.
20 FIG. 6A is an illustrative embodiment of a cross-sectional
view of a satellite data analysis system implementing the
cross-correlation systems of FIG. 4.
FIG. 6B is a planar view of a top surface of the printed
circuit board associated with the satellite data analysis
25 system of FIG. 6A.
FIG. 6C is a planar view of a bottom surface of the printed
circuit board associated with the satellite data analysis
system of FIG. 6A.
FIG. 7 is a first illustrative embodiment of a general
30 
architecture of a cross-correlator that is part of the cross-
correlation system of FIG. 5.
FIG. 8 is a clock distribution scheme for analog front-end
systems forming part of the cross-correlator of FIG. 7.
FIG. 9 is an illustrative embodiment of an AFE forming
part of the cross-correlator of FIG. 7 is shown.
35 FIG. 10 is an illustrative embodiment of an analog-to-
digital converter (ADC) is shown.
FIG. 11 is a second illustrative embodiment of the general
architecture of the cross-correlator that is part of the cross-
correlation system of FIG. 5.
40 FIG. 12 is a more detail illustration of the architecture of
the cross-correlator of FIG. 7 is shown.
FIG. 13 is an illustrative embodiment of a horizontal
totalizer forming part of the summing and cross-correlating
matrix of FIG. 7.
45 FIG. 14 is an illustrative embodiment of a ripple counter
being part of each horizontal totalizer, vertical totalizer and
cross-correlation cells forming the summing and cross-
correlating matrix of FIG. 7.
FIG. 15 is an illustrative embodiment of a vertical total-
50 
izer forming part of the summing and cross-correlating
matrix of FIG. 7.
FIG. 16 is an illustrative embodiment of a cross-correla-
tion cell forming part of the summing and cross-correlating
matrix of FIG. 7.
FIG. 17 is a look-up table utilized for the cross-correlation
55 cell of FIG. 16.
FIG. 18 is an exemplary embodiment of a data flow in
accordance with the illustrative embodiment of the cross-
correlator of FIG. 7.
FIG. 19 is an exemplary embodiment of test architecture
60 for testing a selected ADC is shown.
FIG. 20 is an exemplary embodiment of a cross-correlator
deploying binary implemented self-test (BIST) logic.
65
DETAILED DESCRIPTION
Various embodiments of the disclosure relate to a system,
electronic component and method for conducting a cross-
US 9,628,263 B2
3
correlation analysis of incoming data, where the cross-
correlated data is serialized and re-transmitted for further
processing. According to one embodiment of the disclosure,
the electronic component is implemented as part of a satel-
lite data analysis system, which is configured to measure 5
weather and/or climate information, such as temperature and
atmospheric water-vapor levels at different regions of the
Earth for example, from a geosynchronous orbit. For this
embodiment, the electronic component features an applica-
tion specific integrated circuit (ASIC) that, when operating io
in a first (Correlation) mode, provides input data sampled by
one or more satellite receivers by (i) digitalizing incoming
analog radio frequency (RF) components, (ii) summing of
digitized RF components, and/or (iii) cross-correlating the
RF digitized components to produce resultant data that 15
signifies the similarities and differences between observed
RF components. When operating in a second (Read-Out)
mode, the electronic component refrains from processing the
input data, but rather, reads out the resultant data from logic
in the ASIC. The resultant data may be serialized for reliable 20
transmission.
More specifically, according to a specific embodiment of
the disclosure, the electronic component features a signal
digitizer and cross-correlation ASIC that is adapted to (i)
digitize a plurality of analog signals (e.g., 128 analog 25
signals) at a prescribed frequency (e.g., one gigahertz "GHz"
samples per second with 2-bit accuracy), (ii) cross-correlate
a first subset of the plurality of the digitized signals (e.g. 64
digitized signals) from a first source synchronously with a
second subset of the plurality of digitized signals (e.g. other 30
64 digitized signals) from a second source, and (iii) serialize
and output the resultant, cross-correlated data through a
multi-bit bus (e.g., 8-bit bus). This ASIC solves a number of
disadvantages by achieving low-power usage and maintain-
ing a large amount of weather and/or climate information 35
(e.g., temperature and/or water vapor data) associated with
the analog signals that are sampled by different receivers of
the satellite, while compressing the weather and/or climate
information to an amount that can easily be transmitted back
to Earth for further processing. The cross-correlation 40
improves overall accuracy of the data by reducing both false
positive and false negative events.
According to one of the illustrative embodiments of the
disclosure, as illustrated in detail in FIG. 7, the signal
digitizer and cross-correlation ASIC comprises digitizing, 45
analog front-ends (AFEs) communicatively coupled to a
summing and cross-correlating matrix. Each of the analog
inputs directed to the ASIC from a distinct receiver are
provided to a corresponding AFE, which includes a VGA
(Variable Gain Amplifier) and ADC (Analog-to-Digital Con- 50
verter) with automated gain control loops as shown in FIG.
9. The AFE outputs two digitalized signals associated with
the RF component that collectively formulate a value (e.g.,
"00", "01", "10" or "11") and the number of occurrences of
these different values are cross-correlated through summing 55
and accumulation operations as described below and illus-
trated in FIGS. 13-17. The cross-correlated data can be used
to generate a brightness image of weather and/or climate
conditions (e.g., temperature and/or the water vapor content
in the atmosphere) using a Fourier-transform algorithm. 60
I. Terminology
In the following description, certain terminology is used
to describe aspects of the invention. For example, in certain
situations, the term "logic" is representative of hardware,
firmware and/or software that is configured to perform one 65
or more functions. As hardware, logic may include circuitry
having signal processing or storage functionality. Examples
_►,
of such circuitry may include, but is not limited or restricted
to the following: a video graphics array, a programmable
gate array, a microcontroller, circuitry within an application
specific integrated circuit, receiver, transmitter and/or trans-
ceiver circuitry, semiconductor memory, and/or combinato-
rial logic.
The term "interconnect" is a physical or logical commu-
nication path within a communication device, which is an
electronic device with data processing and/or network con-
nectivity such as, for example, a satellite, a server; a
computer, electronic weather instruments, or the like. For
instance, the communication path may be provided through
wired connections (e.g., electrical wiring, optical fiber,
cables, bus traces, etc.) and/or wireless connections (e.g., a
wireless channel using infrared, radio frequency "RF", or
other wireless signaling mechanism).
The term "computerized" generally represents that any
corresponding operations are conducted by hardware in
combination with software and/or firmware. Also, a
"sequence" of element generally relates a plurality of ele-
ments although, in some case, a sequence may be broadly
defined as including a single element.
Lastly, the terms "or" and "and/or" as used herein are to
be interpreted as inclusive or meaning any one or any
combination. Therefore, "A, B or C" or "A, B and/or C"
mean "any of the following: A; B; C; A and B; A and C; B
and C; A, B and C." An exception to this definition will
occur only when a combination of elements, functions, steps
or acts are in some way inherently mutually exclusive.
As this invention is susceptible to embodiments of many
different forms, it is intended that the present disclosure is to
be considered as an example of the principles of the inven-
tion and not intended to limit the invention to the specific
embodiments shown and described.
II. General Architecture
Referring to FIG. 1, an exemplary block diagram of a
communication device 100 deploying an embodiment of the
invention is shown. As shown, the communication device
100 is featured as a satellite placed in a geosynchronous
orbit around a celestial body 150 such as the Earth, although
it is contemplated that the digitizing and cross-correlating
logic described herein may be implemented in other types of
electronic devices. For this embodiment of the disclosure,
the satellite 100 comprises a chassis 110 and one or more
arms 120, referred to as "ann(s)" 120. In general, the arm(s)
120 operate to receive electromagnetic waves (e.g., radio
frequency "RF" signals) at a certain frequency as input and
convert each of these input signals into RF components that
are easier to process.
More specifically, as shown in FIG. 1, each of the arms
122-124 comprises a plurality of receivers 132-134 (e.g.,
128 receivers for each arm), which are configured to monitor
for one or more types of RF signals 140 within one or more
frequency bands, such as microwave signals for example.
The RF signals having different frequency bands can be used
to obtain information associated with different weather and
climate characteristics. For example, the receivers 132-134
may be configured to monitor RF signals 142 of a first
frequency band ranging from 180 gigahertz (GHz) to 190
GHz (e.g., 183 GHz) to capture image information associ-
ated with atmospheric water vapor. Additionally or in the
alternative, the receivers 132-134 may be configured to
monitor RF signals 144 of a second frequency band ranging
from 50-60 GHz to capture image information associated
with temperature of the Earth's ground surface. As yet
another alternative, although not shown, the receivers 132-
134 may be configured to monitor one or more RF signals
US 9,628,263 B2
5
of other frequency bands such as a third frequency band
ranging from 1-2 GHz to capture image information asso-
ciated with the salinity of a particular ocean or sea.
Referring now to FIG. 2, an illustrative embodiment of
the receiver 132 deployed as part of the arm 122 of FIG. 1
is shown. Herein, the receiver 132 at least partially operates
as a down-converter 200 that receives a RF signal of a
particular frequency range (e.g., RF signal 142), which
constitutes a sinusoid signal with angular modulation, and
decomposes the incoming RF signal 142 to produce corre-
sponding RF components, namely in-phase (I) and quadra-
ture (Q) components 290 and 292. These I and Q compo-
nents 290 and 292 are supplied to different cross-correlation
cells which conduct cross correlation operations as
described below.
More specifically, as illustrated in FIG. 2, the receiver 132
comprises an antenna 210, which is tuned to receive the RF
signal 142 and provide the signal to an amplifier 220. The
amplifier 220 increases a power level of the RF signal 142
and provides the amplified signal 222 to a mixer 230. The
mixer 230 combines the amplified signal 222 having a first
frequency (fl) within the particular frequency range with a
signal 242 having a second frequency (f2) from a local
oscillator 240 to produce one or more composite output
signals 244 such as a first composite signal 246 and a second
composite signal 248. The second frequency (f2) may be a
factor of the first frequency (fl), such as f2=x•fl, where x>0.
For this illustrative embodiment, fl is equal to one-half of f2
('/2 f2).
As shown, the first composite signal 246 is provided to a
first filter 250, which operates as a low-pass filter that (i)
attenuates a portion of the first composite signal 246 that has
a frequency higher than a first selected cutoff frequency and
(ii) passes the attenuated signaling 252 associated with the
first composite signal 246 that has a frequency lower than
the cutoff frequency to an amplifier 260. The amplifier 260
produces the in-phase (I) component 290. Similarly, the
second composite signal 248 is provided to a second filter
270, which also operates as a low-pass filter that attenuates
a portion of the second composite signal 248 that has a
frequency higher than a selected cutoff frequency, which
may be the same or different than the cutoff frequency
associated with the first filter 250. The second filter 270
further passes the attenuated signaling 272 associated with
the second composite signal 248 that has a frequency lower
than its cutoff frequency to the amplifier 280. The amplifier
280 produces the quadrature (Q) component 292. The IQ
components 290 and 292 are routed to different cross-
correlation ASICs as shown in FIG. 3.
Referring now to FIG. 3, a general illustrative embodi-
ment of the propagation paths of the IQ components of
groups of receivers 132-134 associated with arms 122-124 is
shown. According to this embodiment of the disclosure, a
first plurality of receivers 132 is deployed as part of the first
arm 122. Similarly, a second plurality of receivers 133 and
a third plurality of receivers 134 are deployed as part of the
second arm 123 and the third arm 124, respectively. In order
to enhance the accuracy of resultant image data, a number of
cross-correlation systems 340-395 are deployed within the
chassis 110 of the satellite 100 of FIG. 1 and are configured
to receive I or Q components from receivers 132-134
associated with different arms 122-124.
For instance, as a simple illustrative example throughout
the specification, cross-correlation analysis of I components
from receivers 132 of the first arm 122 (sometimes repre-
sented as "Arm1I[ ... ]") and I components from receivers
133 of the second arm 123 (sometimes represented as
T
"Arm2I[ ... ]") is described for clarity sake. Of course, it
is contemplated that multiple cross-correlation operations
may be conducted between (1) a subset of I or Q components
from a first selected receiver 132,133 or 134 and (2) a subset
5 of I or Q components from a second selected receiver 132,
133 or 134, which is different from the first selected receiver
132, 133 or 134.
According to this embodiment of the disclosure, the I
components 300 generated from a detected RF signal by
io receivers 132 from the first arm 122 are provided to a
cross-correlation system 340 that performs cross-correlation
with respect to I components 310 generated from a detected
RF signal by receivers 133 associated with the second arm
123. Similarly, the I components 300 generated by the
15 receivers 132 are provided to a cross-correlation system 345
that performs cross-correlation with respect to Q compo-
nents 315 associated with the second arm 123. In addition,
the I components 300 generated by the receivers 132 are
provided to a cross-correlation system 360 that performs
20 cross-correlation with respect to I components 320 associ-
ated with the third arm 124. Also, the I components 300
generated by the receivers 132 are provided to a cross-
correlation system 370 that performs cross-correlation with
respect to Q components 325 associated with the third arm
25 124.
As further shown in FIG. 3, the I components 310
generated from a detected RF signal by receivers 133 from
the second arm 123 are provided to a cross-correlation logic
350 that performs cross-correlation with respect to Q com-
30 ponents 305 associated with the first arm 122. In addition,
the I components 310 generated by the receivers 133 from
the second arm 123 are provided to (i) a cross-correlation
system 380 that performs cross-correlation with respect to I
components 320 associated with the third arm 124 and a
35 cross-correlation system 390 that performs cross-correlation
with respect to Q components 325 associated with the third
arm 124.
The I components 320 generated from a detected RF
signal by receivers 134 from the third arm 124 are provided
40 to a cross-correlation system 365 that performs cross-cor-
relation with respect to Q components 305 associated with
the first arm 122. In addition, the I components 320 gener-
ated by the receivers 134 from the third arm 124 are
provided to a cross-correlation system 385 that performs
45 cross-correlation with respect to Q components 315 associ-
ated with the second arm 123.
Lastly, the Q components 305 generated from a detected
RF signal by the receivers 132 from the first arm 122 are
provided to cross-correlation system 355 that performs
50 cross-correlation with respect to Q components 315 associ-
ated with the second arm 123. Similarly, the Q components
305 generated by the receivers 132 are provided to cross-
correlation system 375 that performs cross-correlation with
respect to Q components 325 associated with the third arm
55 124, and the Q components 315 generated by the receivers
133 are provided to a cross-correlation system 395 that
performs cross-correlation with respect to Q components
325 associated with the third arm 124.
Referring now to FIG. 4, a more detailed illustrative
60 embodiment of the propagation paths of the IQ components
from the receivers 132-134 between the cross-correlation
systems 340-395 of FIG. 3 is shown. Herein, the I compo-
nents (e.g., Arm1I[127:0]) 300 from the first receivers 132
are provided to a splitter 400 that routes the I components
65 300 to splitters 405 and 410. Splitter 405 routes the I
components 300 to both cross-correlation systems 340 and
345 while splitter 410 routes the I components 300 to both
US 9,628,263 B2
7
cross-correlation systems 360 and 370. The I components
310 (e.g., Arm2I[127:0]) from the second receivers 133 are
provided to a splitter 415, which routes the I components
310 to splitters 420 and 425. Splitter 420 routes the I
components 310 to both cross-correlation systems 340 and
380 while splitter 425 routes the I components 310 to both
cross-correlation systems 350 and 390. The I components
320 (e.g., Arm3I[127:0]) from the third receivers 134 are
provided to a splitter 430, which routes the I components
320 to splitters 435 and 440. Splitter 435 routes the I
components 320 to both cross-correlation systems 360 and
380 while splitter 440 routes the I components 320 to both
cross-correlation systems 365 and 385.
As further shown in FIG. 4, the Q components (e.g.,
Arm1Q[127:0]) 305 from the first receivers 132 are pro-
vided to a splitter 445 that routes the Q components 305 to
splitters 450 and 455. Splitter 450 routes the Q components
305 to both cross-correlation systems 350 and 355 while
splitter 455 routes the Q components 305 to both cross-
correlation systems 365 and 375. The Q components (e.g.,
Arm2Q[127:0]) 315 from the second receivers 133 are
provided to a splitter 460, which routes the Q components
315 to splitters 465 and 470. Splitter 465 routes the Q
components 315 to both cross-correlation systems 345 and
385 while splitter 470 routes the Q components 315 to both
cross-correlation systems 355 and 395. The Q components
(e.g., Arm3Q[127:0]) 325 from the third receivers 134 are
provided to a splitter 475, which routes the Q components
325 to splitters 480 and 485. Splitter 480 routes the Q
components 325 to both cross-correlation systems 370 and
390 while splitter 485 routes the Q components 325 to both
cross-correlation systems 375 and 395. Depending on the
number of receivers associated with each arm (e.g., 128
receivers) which causes the cross-correlation systems 345-
395 to have a sizing of 128x128, four cross-correlators (e.g.,
64x64 cross-correlators) are deployed for each cross-corre-
lation system 345-395, as illustrated in more detail in FIG.
5.
Referring to FIG. 5, an illustrative embodiment of the first
cross-correlation system 340 that receives I components 300
from the first arm 122 and I components 310 from the
second arm 123 is shown. Herein, the I components 300
comprise a first group 302 of I components 300, which is
represented as "Arm 11[63:01]" 302, and a second group 304
of I components 300 that is represented as "Arm1I[127:63]"
304. Also, the I components 310 comprise a first group 312
of I components 310, which is represented as "Arm2I[63:0]"
312, and a second group 314 of I components 310 that is
represented as "Arm2I[127:63]" 314.
As shown, the first cross-correlation system 340 com-
prises a first cross-correlator (XC1) 500, a second cross-
correlator (XC2) 510, a third cross-correlator (XC3) 520,
and a fourth cross-correlator (XC4) 530. According to one
embodiment of the disclosure, as represented in FIG. 7, each
of these cross-correlators (XC1 4) 500, 510, 520 and 530
may be implemented as an application specific integrated
circuit (ASIC), which includes a plurality of variable gain
amplifiers (VGAs) along with a corresponding plurality of
analog-to-digital converters (ADCs), a summing and cross-
correlating matrix, and a data serializer.
Arm1I[63:0] 302 is provided to a first internal splitter 550
via a first interconnect 540 while Arm1I[127:64] 304 is
provided to a second internal splitter 555 via a second
interconnect 542. Arm2I[63:0] 312 is provided to a third
internal splitter 560 via a third interconnect 544 while
Arm2I[127:64] 314 is provided to a fourth internal splitter
565 via a fourth interconnect 546. As a result, the first
8
cross-correlator 500 receives the Arm1I[63:0] 302 from the
first splitter 550 and Arm2I[63:0] 312 from the third splitter
560. Similarly, the second XCC 510 receives the
Arm1I[63:0] 302 from the first splitter 550 and
5 Arm2I[127:64] 314 from the fourth splitter 565; the third
XCC 520 receives the Arm1I[127:64] 304 from the second
splitter 555 and Arm2I[63:0] 312 from the third splitter 560;
and the fourth XCC 530 receives the Arm1I[127:64] 304
from the second splitter 555 and Arm2I[127:64] 314 from
io the fourth splitter 565.
Referring to FIG. 6A, an illustrative embodiment of a
cross-sectional view of a satellite data analysis system 600
implementing, at least in part, the cross-correlation systems
345-395 is shown. Herein, the analysis system 600 features
15 a printed circuit board 610 and a heat sink 620, which is
coupled to the printed circuit board 610 through mounting
fasteners 625 and is positioned over components mounted
on a top surface 612 of the printed circuit board 610. As a
result, the heat sink 620 receives and radiates heat produced
20 by the mounted components which may include, but is not
limited or restricted to processing logic 630 (e.g., field-
programmable gate array "FPGA" 632 and/or board con-
troller 634) and a plurality of cross-correlators 640.
As shown to FIG. 613, a planar view of the top surface 612
25 of the printed circuit board 610 associated with the analysis
system 600 of FIG. 6A is shown. Herein, the FPGA 632 and
the board controller 634 are mounted on the top surface 612
of the printed circuit board 610 and are communicatively
coupled to the plurality of cross-correlators 640. According
30 to one embodiment of the disclosure, the FPGA 632 is
responsible for performing post processing of cross-corre-
lated data produced by the cross-correlators 640. In contrast,
the board controller 634 is used to control and monitor
operations of the cross-correlators 640 as well as control
35 programming of the FPGA 632.
The plurality of cross-correlators 640 may be imple-
mented as ASICs with four of these cross-correlators 640
(e.g., the first cross-correlator 500, the second cross-corr-
elator 510, the third cross-correlator 520 and the fourth
40 cross-correlator 530) collectively forming a cross-correla-
tion system (e.g., first cross-correlation system 340) of FIG.
3. More specifically, each of the plurality of cross-correla-
tors 640 may be implemented as a 64x64 cross-correlator
ASIC. Hence, as shown, forty-eight (48) 64x64 cross-
45 correlator ASICs are deployed to handle cross-correlation
operations associated with 128-bit I and Q components from
receivers associated with arms 122-124 of FIG. 1.
Mounted on a bottom surface 614 of the printed circuit
board 610, as shown in FIG. 6A and/or FIG. 6C, one or more
50 power connectors 650 may be implemented to provide an
interface for a power supply, where the supplied power may
be adjusted through one or more direct current (DC) con-
verters (e.g., DC-to-DC converter 660 of FIG. 613) and/or
voltage regulators (e.g., Low-Dropout "LDO" converters
55 665 of FIG. 6C) mounted to the printed circuit board 610.
Additionally, a first input signal connector 670 may be
implemented in order to provide an interface for receipt of
in-phase and quadrature (I & Q) components from the
receivers 132-134 associated with arms 122-124 of FIG. 1
60 while a second input signal connector 675 may be imple-
mented to provide an interface for a reference clock (e.g. 1
GHz clock). Splitters 400-485 of FIG. 4 for routing IQ
components between cross-correlation systems 340-395 and
splitters 550-565 of FIG. 5 for routing IQ components
65 between the cross-correlators 500-530 within the first cross-
correlation system 340 may be mounted to the bottom
surface 614 of the printed circuit board 610.
US 9,628,263 B2
9
Referring now to FIG. 7, a first illustrative embodiment of
a general architecture of the first cross-correlator 500 of FIG.
5, which is one of the plurality of cross-correlators 640 of
FIG. 6, is shown. The first cross-correlator 500 comprises a
clock generator 700, an interface (e.g., hC slave) controller 5
710, a first plurality of analog front ends (AFEs) 720, a
second plurality of AFEs 730, a summing and cross-corre-
lating matrix 740 and a data serializer 750. Of course, it is
contemplated that the architecture of the first cross-correla-
tor 500 may be common for all of the plurality of cross- l0
correlators 640.
Herein, the clock generator 700 receives a reference clock
"REF_CLK" signal 702 and distributes secondary clock
signals 703-706, which are based on the REF _CLK signal, 15
to logic within the first cross-correlator 500 that requires
clocking. These secondary clock signals (CLK_1, CLK_2,
CLK_3, CLK_4) may have the same operating frequency as
REF_CLK signal 702 or may be a derivation of REF _CLK
signal 702. For instance, as shown in FIG. 7 where the 20
REF_CLK signal 702 is selected as a 1 GHz clock, the clock
generator 700 produces one or more clock signals (e.g.,
CLK_2 signal) 704 that is used by the first plurality of AFEs
720 and the second plurality of AFEs 730. More specifically,
the clock generator 700 may be configured to provide 25
synchronous, separate clock signals to the first plurality of
AFEs 720 and the second plurality of AFEs 730 through a
distributed interconnect scheme, where an illustrative
example of the distributed interconnect scheme 800 is
shown in FIG. 8. 30
Herein, as shown in FIG. 8, the interconnect scheme 800
is a tree-like distribution in which the CLK_2 signal 704 is
provided to a common feed interconnect 810, which is
coupled to a first primary feed interconnect 820 for the first
plurality of AFEs 720 and a second primary feed intercon- 35
nect 830 for the second plurality of AFEs 730. Drive circuits
840 and 845 are coupled to the primary feed interconnects
820 and 830 and secondary feed interconnects 850 and 855
associated with the AFEs 720 and 730 in efforts to maintain
synchronicity between the supply clock signals (e.g., 40
CLK_2 signal) to each of the first plurality of AFEs 720 and
the second plurality of AFEs 730.
Referring back to FIG. 7, the clock generator 700 pro-
duces a third clock (CLK_3) signal 705 that is used by the
summing and cross-correlating matrix 740 and a fourth 45
clock signal (CLK_4) 706 that is used by the data serializer
750. It is contemplated that the CLK_3 signal 705 and the
CLK_4 signal 706 may be generally set to the same fre-
quencies as CLK_2 signal 704 or perhaps even different
frequencies, provided that such frequencies are synchronous 50
to each other.
The first plurality of AFEs 720 are adapted to receive RF
components (e.g., I or Q components) generated by a first set
of receivers (e.g., receivers 132 of FIG. 1) while the second
plurality of AFEs 730 are adapted to receive RF components 55
(e.g., I or Q components) generated by a different (second)
set of receivers (e.g., receivers 133 of FIG. 1). According to
one embodiment of the disclosure, the first set of receivers
and the second set of receivers are located at different
sources (e.g., arms 122 and 123 of the satellite 100). Herein, 60
each of the AFEs 720/730 receives an incoming analog
signal (e.g., I component or a Q component) and produces
a pair of digital signals (binaries) that are provided to the
summing and cross-correlating matrix 740, where the digi-
tized outputs are cross-correlated and/or summed The cross- 65
correlated data includes information that may be used for
controlling brightness for image generation.
10
Referring to FIG. 9, an illustrative embodiment of an AFE
from the first plurality of AFEs 720 or the second plurality
ofAFEs 730 is shown. Herein, AFE 721/731 (e.g., one of the
first or second plurality of AFEs 720/730) features multi-
stage (e.g. 3-stage), variable gain amplifier (VGA) 900, an
analog-to-digital converter (ADC) 920, and an automatic
gain controller (AGC) 940. According to one embodiment of
the disclosure, the VGA 900 features a multi-stage VGA that
receives an analog signal (e.g., I or Q component from a
particular receiver) and produces differential outputs 910
and 912 that are provided to the ADC 920. A first differential
output 910 is digitized by the ADC 920, which is clocked by
a selected clock signal (e.g. CLK_2) 704, to produce digital
outputs 930, 932 and 934 as described below. The AGC 940
is responsible for controlling both the gain and offset 960 for
the VGA 900 based on feedback signaling 950 from the
ADC 920. The offset is controlled in case of misalignment
with a predetermined DC offset (e.g., zero or a prescribed
offset).
As shown in more detail in FIG. 10, an illustrative
embodiment of the ADC 920 is shown. Herein, the ADC 920
features a reference voltage source 1000, a plurality of
comparators 1010-1012 and data management logic 1020.
As shown, the comparators 1010-1012 receive the first
differential output 910 from the VGA 900 of FIG. 9 and
generate at least two digital outputs 930, 932 and 934 used
by the summing and cross-correlating matrix 740. More
specifically, the reference voltage source 1000 is responsible
for supplying a prescribed voltage 1030 operating as a
reference voltage to a first input of each of the plurality of
dynamic comparators 1010-1012 for comparison with a
voltage associated with the first differential output 910. The
first digital differential output 910 is based on the received
analog RF components (e.g., I component or Q component)
processed by the VGA 900 and is supplied to a second input
of each of the plurality of comparators 1010-1012. The
dynamic comparators 1010-1012 are clocked by the CLK_2
signal 704 (e.g., 1 GHz), and thus, are configured to provide
digital samples at a certain edge transition of the CLK_2
signal.
As shown, the comparators 1010-1012 provide the digital
samples 1040-1042 to the data management logic 1020,
which buffers and synchronizes the digital samples as digital
outputs 930, 932 and 934 from theADC 920. The first digital
output 930 is based on the digital sample 1040 produced by
comparator 1010. A second digital output 932 is based on
both the digital samples 1041-1042 from comparators 1011
and 1012, respectively. A third digital output 934 operates as
a clock to synchronize XCCs within the summing and
cross-correlating matrix 740 so that the cross-correlator cells
(XCCs) perform summing action when the digital outputs
are valid.
Referring now to FIG. 11, a second illustrative embodi-
ment of the architecture of the first cross-correlator 500 of
FIG. 5, which is one of the plurality of cross-correlators 640
of FIG. 6, is shown. The first cross-correlator 500 comprises
the clock generator 700; the (hC slave) interface controller
710; a first high-speed interface 1100 that comprises the first
plurality of AFEs 720 of FIG. 7; a second high-speed
interface 1110 that comprises the second plurality of AFEs
730 of FIG. 7; a first plurality of summing logic 1120 (also
referred to as the "horizontal totalizers" or "TOTHs") in
communication with the first high-speed interface 1100; a
second plurality of summing logic 1130 (also referred to as
the "vertical totalizers") in communication with the second
high-speed interface 1110; a cross-correlation matrix 1140
(e.g., 64x64 XCC matrix); the data serializer 750 operating,
US 9,628,263 B2
11
at least in part, as a multiplexer 1150 in communication with
the first plurality of horizontal totalizers 1120, the second
plurality of vertical totalizers 1130 and the cross-correlation
matrix 1140; and a plurality of drivers 1160 in communica-
tion with the data serializer 750.
The clock generator 700 receives the REF_CLK signal
702 and distributes the secondary clock signals to the
interface controller 710 (CLK_1 703), the first high-speed
interface 1100 (e.g., CLK_2 signal 704), the second high-
speed interface 1110 (e.g., CLK_2 signal 704), the horizon-
tal totalizers 1120 (e.g., CLK_2 signal 704), the vertical
totalizers 1130 (e.g., CLK_2 signal 704). Additionally, the
clock generator 700 distributes CLK_3 signal 705 to the
cross-correlation matrix 1140 and CLK_4 signal 706 to data
serializer 750. These secondary clock signals (CLK_1-
CLK_4) are synchronous with each other.
The first high-speed interface 1100 is responsible for
digitalizing the RE components (e.g., I or Q components)
produced by one set of receivers (e.g., the first set of
receivers associated with the first arm 122 of FIG. 1). More
specifically, the first high-speed interface 1100 features the
first plurality of AFEs 720, where each of the AFEs 720
receives an RE component (e.g., Arm2l[0] from a second
receiver 1330 of the second arm 123) configured with an
ADC to provide a two-bit digital output to a unique corre-
sponding horizontal totalizer of the horizontal totalizers
(TOTHs) 1120. Each horizontal totalizer is responsible for
maintaining a count for each type of detected pairing of
digital outputs as shown in FIGS. 13-14, where the count is
used for rendering the image as described below. The
operations of the first high-speed interface 1100 and the
horizontal totalizers 1120 may be controlled, at least in part,
by certain control (CNTL) signals from the interface con-
troller 710, as shown in more detail in FIG. 12.
Similarly, the second high-speed interface 1110 is respon-
sible for digitalizing the RE components (e.g., I or Q
components) produced by another set of receivers (e.g., the
second set of receivers associated with the second arm 123
of FIG. 1). More specifically, the second high-speed inter-
face 1110 features the second plurality of AFEs 730, where
each of the AFEs 730 uniquely corresponds to a vertical
totalizer of the vertical totalizers (TOTVs) 1130 and is
configured to receive an RE component (e.g., Armll[0] from
a first receiver 1320 of the first arm 122) and produce a
two-bit digital output to that corresponding vertical totalizer.
Each vertical totalizer is responsible for maintaining a count
of values associated with its corresponding digital outputs,
where the count is used for rendering the image as described
below. An illustrative example of a vertical totalizer 1130 is
shown in FIGS. 14-15. The operations of the second high-
speed interface 1110 and the vertical totalizers 1130 also
may be controlled, at least in part, by certain control (CNTL)
signals from the interface controller 710, as shown in more
detail in FIG. 12.
The cross-correlation matrix 1140 for the first cross-
correlator 500 is responsible for cross-correlating the digital
outputs associated with different combinations of receivers
from different sources. For instance, the cross-correlation
matrix 1140 features a plurality of cross-correlation cells
(XCCs), where each XCC uniquely performs a cross-corre-
lation operation on digital outputs from different receivers
associated with different sources. For instance, a first XCC
may be adapted to receive digital outputs from a first
receiver of a first arm (e.g., Arm1I[0]), which undergoes a
cross-correlation analysis with digital outputs from a sixty-
fourth receiver of a second arm (e.g., Arm2I[63]). The
cross-correlation analysis includes an operation of assigning
12
a resultant value that represents a degree of correlation
between signaling from different receivers associated with
different arms and stores the resultant values. For instance,
as an illustrative example, where a first digital output of each
5 of the Armll[0] and Arm2I [63] is active low ("0") and a
second digital output of each of the Armll[0] andArm2I[63]
is active high ("1"), the resultant value (e.g., "110") may
represent that there is a high degree of correlation between
the digital outputs at this time. Similarly, where the digital
10 outputs associated with Armll[0] is "00" and the digital
outputs associated with Arm2I[63] is "11", the resultant
value (e.g., "000") may represent that there is a low degree
of correlation between the digital outputs at this time. An
illustrative example of the first cross-correlation cell (XCC)
15 is shown in FIGS. 16-17.
Referring now to FIG. 12, a more detail illustration of the
architecture of the first cross-correlator 500 of FIG. 5, which
is one of the plurality of cross-correlators 640 of FIG. 6A,
is shown. At any point in time, the first cross-correlator 500
20 is configured to operate in one of a plurality of modes,
namely a first (Correlation) mode, a second (Read-Out)
mode or a third (Test) mode. During Correlation mode,
horizontal totalizers (TOTHs) 1120, the vertical totalizers
(TOTVs) 1130 and cross-correlation cells (XCCs) of the
25 cross-correlation matrix 1140 receive, process and store data
from the receivers. However, when placed into Read-Out
mode, the data serializer 750 of the cross-correlator 500
reads the stored data from the horizontal totalizers 1120, the
vertical totalizers 1130 and the XCCs of the cross-correla-
30 tion matrix 1140. At this time, the horizontal totalizers 1120,
the vertical totalizers 1130 and the XCCs of the cross-
correlation matrix 1140 do not process and store data from
the receivers. In Test mode, operability of different logic
within the first cross-correlator 500 may be monitored.
35 More specifically, the first cross-correlator 500 comprises
the interface controller 710, an analog subsystem 1200 that
includes the first and second plurality of AFEs 720 and 730
of FIG. 7 (not shown), the summing and cross-correlating
matrix 740, and the data serializer 750. The summing and
40 cross-correlating matrix 740 comprises (1) the horizontal
totalizers 1120, which include a plurality of horizontal
totalizers 112004120x, (where N>_7, N=63 for this illustra-
tive example) that monitor digitalized output from a subset
of receivers associated with a second arm (e.g., receivers
45 133043363 of arm 123); (2) the vertical totalizers 1130,
illustrated as a plurality of vertical totalizers 11300-1130M
(e.g., M>_7, M-63 for this illustrative example), which
monitor digitalized output from a subset of receivers asso-
ciated with a first arm (e.g., receivers 132043263 of arm
50 122); and (3) the cross-correlation matrix 1140, which
includes a plurality of cross-correlation cells (XCC) 11400,
o-1140M, which perform cross-correlation of the digitized
output (binary sign/magnitude values from the ADC) asso-
ciated with RE signal received by multiple receivers at
55 different sources (e.g., receivers 1330-13363 of arm 123 and
receivers 1320-13263 of arm 122). For instance, XCC
114062,1 performs a cross-correlation operation on digi-
talized outputs from arm 122 (e.g., ArmIl[62]) and arm 123
(e.g., ArmI2[1]).
60 Referring still to FIG. 12, the controller 710 comprises a
plurality of inputs, including Rst_In 1220, Clk_In 1221,
Clk_Read 1222, Read-Control 1223, Enable 1224, HalfPe-
riodMux 1225, Set-Time 1226 and Mode 1227.
Herein, the Rst_In 1220 is an input that, upon receipt of
65 an active signal (e.g., logic "I"), causes the controller 710 to
produce an active signal via Rst_Out output 1230 in order to
reset certain components within the cross-correlator 500. As
US 9,628,263 B2
13
an illustrative example, in response to receipt of an active
signal at Rst_In input 1220, the interface controller 710
resets the horizontal totalizers 112004120x, along with the
vertical totalizers 113004130M the cross-correlation cells
(XCC) 11400,0-1140M,1 and the data serializer 750.
One or more clock signals may be supplied to controller
710. Herein, a first input clock signal (CLK_1) 703 is
supplied to a Clk_In input 1221 and a second input clock
signal (CLK_RD1) operating as a prescribed frequency
(e.g., a 68 kilohertz "kHz" reference clock) may be supplied
to a Clk_Read input 1222. As an illustrative embodiment,
the CLK_1 signal has the same operating frequency as the
REF_CLK signal (e.g., a 1 GHz clock) and is supplied to the
controller 710 from an external source (e.g. clock generator
700 of FIG. 7). The CLK_RD1 signal has a substantially
lower operating frequency than CLK_1 and may be supplied
from another external source (e.g. the FPGA 632 of FIG. 613)
for use as a read readout. Although not shown herein, other
clocking signals based on the REF_CLK signal (e.g.,
CLK_2 and CLK_3 which may be identical clock signals)
are also supplied to each of the horizontal totalizers 11200-
112063 and the vertical totalizers 11300413063 as well as the
XCCs 1140,,,-114013,13 via Clk_Cell output 1234 and its
corresponding interconnect. The CLK_RD1 signal may be
applied to data serializer 750 via interconnect 1235.
The Read—Control 1223 is an input that, upon receipt of
an active signal (e.g., logic "1"), causes the controller 710,
to select a read clock signal for use in data readout from the
summing and cross-correlation matrix 740. The read clock
signal may include the CLK_RD1 signal received by
Clk_Read input 1222 or an internally generated read signal
(hereafter "CLK_RD2" signal), which is provided via Clk_
Cell output 1234 and via interconnect 1235. Upon selection
of use of the internally generated read signal via the Read_
Control input 1223, the clock speed of the CLK_RD2 signal
is controlled by the HalfPeriodMux 1225.
The HalfPeriodMux 1225 is an input that sets a register
within the controller 710 to adjust the clock speed of the
CLK_RD2 signal, when the CLK_RD2 signal is provided to
the data serializer 750 via interconnect 1235 and to the
analog subsystem 1200 for distribution to horizontal total-
izers 112004120631 the vertical totalizers 1130,413013 and
the XCCs 11400,0-114063,63 via Clk_Cell output 1234.
According to one embodiment of the disclosure, the input
value (e.g., 6-bit value) sets the half-period of a CLK_RD2
signal in nanoseconds, which is supplied to and controls the
read-out rate of the data serializer 750. Hence, multiple
read-out cycles may be needed before completion of the
shifting of stored data within the summing and cross-
correlating matrix 740 into the data serializer 750. The
shifting occurs to load data into the data serializer 750
starting at the first row of the summing and cross-correlating
matrix 740 (e.g., horizontal totalizer 112063 and XCC[63:
63]-XCC[63:0]) up to a last row of the summing and
cross-correlating matrix 740, namely the vertical totalizers
1130,
-113063-
The Enable input 1224 is an input that is adapted to
receive an Enable signal from the FPGA and/or controller
(not shown), and in response, activate components associ-
ated with the summing and cross-correlating matrix 740,
including the horizontal totalizers 112004120631 the vertical
totalizers 11300413063, and the XCCs 11400,0
-114063,63-
The Enable output and corresponding interconnects to the
above-noted components are not shown to retain clarity
respect with to other data and/or control paths as shown.
The Set—Time 1226 is an input configured to receive and
supply an input value to an internal register within the
14
controller 710 that sets the duration of the Correlation mode.
According to one embodiment of the disclosure, the input
value (e.g., 24-bit value) sets the duration in nanoseconds as
to how long the cross-correlator 500 operates in Correlation
5 mode before placement into Read-Out mode if an
XC_Ready output 1232 is set. The XC_Ready output 1232
is an output that indicates the correlation process is complete
and the data is ready to be read out. The output (Out) 1270
is provided to the FPGA 632 and/or board controller 634 and
io the control signal (Fpga_Ctrl) 1275 is sent to the FPGA 632
to cause the FPGA 632 to prepare for receipt of data.
The Mode 1227 is an input that sets the cross-correlator
500 into at least either Read-Out mode or Correlation mode.
During Read-Out mode, for each read cycle, data within the
15 horizontal totalizers 11200-112063, the vertical totalizers
11300-113063, the XCCs 11400,0-114063,63 is shifted down-
ward toward the data serializer 750 under control of Shift_
Out outputs 1231 from the controller 710. As data is
received from horizontal totalizer 112063 and XCCs
20 114063,0-114063,63, the data serializer 750 continuously out-
puts a prescribed amount of data (e.g., one byte) to FPGA
632 of FIG. 6B for storage and subsequent re-transmission
from the satellite. During Correlation mode, the plurality of
horizontal totalizers 11200-112063, the plurality of vertical
25 totalizers 11300-113063, and the plurality of XCCs 11400,0-
114063,63 are configured to receive data, process and store
data received from the receivers and processed by analog
subsystem 1200.
The analog subsystem 1200 receives clocking signals
30 from the controller 710. Internal logic within the analog
system (e.g., AFEs) utilizes the CLK_2 signal (e.g., 1 GHz).
However, through Sel_Clk input 1252, the controller 710
selects whether the analog subsystem 1200 outputs either (i)
the CLK_1 signal provided via Clk_Inl 1253 or (ii) a read
35 clock signal provided via Clk_In2 1254, namely CLK_RD1
4
or CLK_RD2, to logic forming the summing and correlating
matrix 70 via the Clk_Cell output 1234.
More specifically, when the cross-correlator 500 is oper-
ating in the Correlation mode, where data is being processed
4o and stored in the horizontal totalizers 11200-112063, the
vertical totalizers 11300
-113063, and the plurality of XCCs
11400,0
-114063,63, the controller 710 provides signaling to
Sel_Clk input 1252 to supply CLK_2 signal from Clk_Cell
1234. Alternatively, when the cross-correlator 500 is oper-
45 ating in the Read-Out mode or Test mode, the controller 710
provides signaling to Sel_Clk input 1252 to supply
CLK_RD1 or CLK_RD2 signal from Clk_Cell 1234. As
described above, in Read-Out mode, data stored in the
horizontal totalizers 11200-112063, the vertical totalizers
50 11300-113063, and the plurality of XCCs 11400,0-114063,63
are read out by the data serializer 750. In Test mode, testing
may be conducted on operability of certain totalizers or
XCCs as described below. The change in clock speed is due,
in large part, for power-savings.
55 The analog subsystem 1200 receives the RE components
(e.g., Arm1I[63:0]) from the receivers 1320-13263 associated
with the arm 122 of FIG. 1 via Arml inputs 1250 and RE
components (e.g., Arm2Q[63:0]) from the receivers 1330-
13363 associated with the arm 123 of FIG.1 via Arm2 inputs
60 1255. Of course, in lieu of receiving RE components from
the receivers 1320-13263 or 13264-132121 via Arml inputs
1250 and from the receivers 1330-13363 or 13364-133127 via
Arm2 inputs 1255, it is contemplated that RE components
from different combination of outputs from receivers may be
65 provided to Arml inputs 1250 and Arm2 inputs 1255. For
instance, it is contemplated that (1) RE components from
receiver 1340-13463 or receivers 13464-134127 may be
US 9,628,263 B2
15
received via Arml inputs 1250 and RF components from the
receivers 133043363 or receivers 133,,-133121 may be
received via Arm2 inputs 1255; (3) RF components from
receivers 134043463 or receivers 13414-134121 may be
received via Arml inputs 1250 and RF components from the 5
receivers 132043263 or receivers 13264132127 may be
received via Arm2 inputs 1255; or (3) RF components from
the receivers 132043263 or receivers 13264-132127 may be
received via Arml inputs 1250 and RF components from
receivers 134043463 or receivers 13464134127 may be io
received via Arm2 inputs 1255.
As shown, for illustrative purposes, the AFEs associated
with each RF component input produces two digital (binary)
outputs, which are supplied to corresponding horizontal
totalizers via Arm_h output 1260 and both corresponding 15
vertical totalizers and columns of XCC cells via Arm_v
output 1265. For instance, the digital outputs 1260 associ-
ated with Arm_h[i] (e.g., 0<_i<_63, namely Arm2I[i]) is
supplied to the ith horizontal totalizer (TOTH[i]) along with
a 
ith 
row of XCC cells associated with the cross-correlation 20
matrix 1140, namely XCC[63:i], XCC[62:i], . . . , and
XCC[O:i]. Similarly, in accordance with the illustrative
example, the digital outputs associated with Arm_v[j] (e.g.,
0:5j:563, namely Arm1I[j]) is supplied to a jth vertical total-
izer (TOTV[j]) along with a jth column of XCC cells 25
associated with the cross-correlation matrix 1140, namely
XCC[j:0], XCC[j:l], . . . , and XCC[j:63]. The clock
signaling from the Clk_Cell output 1234 is provided to and
synchronizes the horizontal totalizers 112004120631 the
vertical totalizers 11300413063 and the XCCs 1140,, - 30
114063,63•
Lastly, the data serializer 750 operates, at least in part, as
a multiplexer that receives a first collection of bits as input,
applies padding (as needed), and produces an output that is
lesser in size than the input. For instance, the data serializer 35
750 receives 1768 bits as input (e.g., 26 bits*68 parallel
input streams), applies padding to each of the 26 bits to
produce 32-bit results, and outputs multi-bit results 1270
(e.g., 8-bit results) in series from the data serializer 750. It
is contemplated that any output bit sizes may be used 40
without departing from the spirit of the invention. The
multi-bit results 1270 may be transmitted to a remote
destination and, through use of Fourier-transform
operation(s), is used to generate a brightness image of
weather and/or climate conditions (e.g., temperature and/or 45
the water vapor content in the atmosphere) that are repre-
sentative by the results 1270.
Besides operating as a multiplexer, the data serializer 750
comprises control logic that enables the cross-correlator to
operate in Test mode. For entering into Test mode and 50
controlling such functionality, the control logic features a
plurality of inputs for testing. These inputs include Data_
side 1241; Test_clk 1242; Test_addr 1243; Test_en 1244;
Test_clkdiv_en 1245; and Arm128 1246.
Arm128 1246 is an input that is adapted to receive and 55
pass test data to the data serializer 750 when a test enable
(Test_en) signal 1244 is set so as to enable the Test mode of
the data serializer 750. This provides an ability to read out
ADC binary data directly without processing to ensure that
the ADCs are working properly in digitizing the RF com- 60
ponents.
The Data—side 1241 is an input that enables data to be
manually fed into the Arm128 input 1246 in lieu of data
received from one or more ADC outputs.
The Test_clk 1242 is an input that is adapted to receive a 65
clock signal (CLK_XCC of FIG. 9) from a particular ADC.
As four (4) cross-correlators are included as part of the same
16
cross-correlation system (e.g., cross-correlation system 345)
and their clocking is synchronized, only 32 inputs are
provided as opposed to the 128 cross-correlators. The third
output 934 for an ADC of a particular cross-correlator within
each cross-correction system 340-395 is coupled to the
Test_clk 1242.
The Test_addr 1243 is an input that is adapted to receive
a test-address of one of the ADCs, which allows for a
selection of which of the 128 ADCs is to be read.
The Test_clkdiv_en 1245 is an input that is adapted for
use in slowing the Read clock signal selected for reading out
the ADCs data.
With respect to FIG. 13, an illustrative embodiment of a
horizontal totalizer (e.g., horizontal totalizer 1120„ where
a>_0) is shown. Herein, the horizontal totalizer 1120, com-
prises a look-up table (LUT) 1300 that is coupled to a
plurality of accumulators (Accum) 1320, which are oriented
in parallel and each coupled to a corresponding ripple
counter of the plurality of ripple counters 1340.
Herein, when the cross-correlator 500 is operating in
Correlation mode, namely the Shift output (Shift _ Out) 1231
of the controller 710 is set to a first state (e.g., logic HIGH
or "1") and a Reset output (Rst_Out) 1230 of the controller
710 is set to a second state (e.g., logic LOW or "0"), the
look-up table 1300 operates as a 2:4 decoder. In particular,
the look-up table 1300 receives two digital outputs 1310
from a corresponding ADC and, based on the values asso-
ciated with the digital outputs 1310 and at the end of each
clock cycle of the selected clocking signal (e.g. CLK_2),
produces an output that corresponds to the sum value of the
two digital outputs 1310. As an illustrative example, one of
its outputs (hout_0, hout_l, hour _2 & hout_3) 1311-1314
from the look-up table 1300 is activated to represent the
digital value. For instance, where a first digital (sign) output
is a "1" and a second digital (magnitude) output is a "0", the
hout_2 1313 is activated (e.g., logic "1") to represent and
count value of "2". Similarly, where a first digital (sign)
output is a "0" and a second digital (magnitude) output is a
"1", hout_1 1312 is activated (e.g., logic "1") to represent
and count value of "1".
The activation of an output signal is provided to a
corresponding accumulator 1321-1324 (e.g., accumulator
1321) that increases a count value maintained by its corre-
sponding internal storage register 1331-1334 (e.g., storage
register 1331). Once an overflow condition occurs in which
the count value now exceeds a storage capacity of the
storage register 1331, accumulator 1321 generates a carry
output (Cout) to a corresponding ripple counter 1341 and the
accumulator 1331 maintains the count value prior to the
overflow condition (e.g., "3" where the storage register 1331
is a 2-bit register). The ripple counters 1341-1344 provide a
greater amount of storage than provided by the accumulators
1321-1324.
When the cross-correlator 500 is operating in Read-Out
mode, namely the Shift output (Shift _Out) 1230 is set to the
second state (e.g., logic Low or "0") and a Reset output
(Rst_Out) 1230 of the controller 710 remains in the second
state (e.g., logic LOW or "0"), the accumulators 1320 and
ripple counters 1340 output their stored count values via
interconnects 1350 and 1360, respectively. More specifi-
cally, storage register 1331-1334 provide their stored values
via interconnects 1351-1354 to corresponding accumulators
associated with an adjacent horizontal totalizer (e.g., hori-
zontal totalizer "TOTH" 1120a+1). Ripple counters 1341-
1344 provide their stored values via interconnects 1361-
1364 to corresponding ripple counters associated with the
adjacent horizontal totalizer. However, for horizontal total-
US 9,628,263 B2
17
izer 112063, the stored values from storage register 1331-
1334 along with the stored values from the ripple counter
1341-1344 are provided to the data serializer 750 for pad-
ding and subsequent read out.
Additionally, the accumulators 1320 and ripple counters
1340 receive as input stored count values via interconnects
1370 and 1380, respectively. More specifically, for horizon-
tal totalizer 11200 (a-0), the storage register 1331-1334 and
D flip-flops of the ripple counters 1341-1344 are driven low
by logic "0" inputs via interconnects 1371-1374 and 1381-
1384, respectively. However, for other horizontal totalizers
1120, (e.g., horizontal totalizers 11201-112063, 1 <_a:563), the
storage register 1331-1334 receive stored values via inter-
connects 1371-1371 from corresponding accumulators of an
adjacent horizontal totalizer (TOTH) 1120a_1 (e.g., horizon-
tal totalizer 11200 ... or 112062). Similarly, ripple counters
1341-1344 receive stored values via interconnects 1381-
1384 from corresponding ripple counters associated with the
adjacent horizontal totalizer 1120,_1.
As shown in FIG. 14, in general, a counter is a device
which stores the number of times a particular event has
occurred, often in relationship to an input clock signal. Each
ripple counter (e.g., ripple counter 1341) is an asynchronous
counter that comprises a plurality of stages 14001-1400k
(K>1), where each stage 14001 .... or 1400, comprises a
flip-flop 14101 .... or 1410, (e.g., D flip-flops) along with
a first multiplexer 14201 ... , or 1420, having an output
coupled to a clock (CLK) input of the flip-flop 14101 ....
or 1410, and a second multiplexer 14301 .. , or 1430k
having an output coupled to a data input (D) input of the
flip-flop 14101 .... or 1410,. As shown, the first multiplexer
14201 associated with the first stage 14001 receives as input
a read clock signal (e.g., CLK_RD1 or CLK _RD2 signal)
and a Carry Out (Cout) signal by its corresponding accu-
mulator 1321 while the first multiplexer 14202 for the
subsequent stages 14002-1400, receive as input the read
clock signal and an inverted output of the preceding flip-flop
14101 .... or 1410,_1. A second multiplexer 14301-1430k
receives as input (i) a bit associated with a corresponding
flip-flop from a ripple counter within another totalizer or
XCC, and (ii) the inverted output of the flip-flop
14101 .... or 1410k.
Herein, when the cross-correlator 500 is operating in
Correlation mode, namely the Shift output (Shift _Out) 1231
of the controller 710 is set to a first state (e.g., logic HIGH
or "1"), a first flip-flop 14101 of the ripple counter 1341 is
clocked by the Carry Out (Cout) signal by its corresponding
accumulator 1321 and the subsequent flip-flops 14102-1410k
are clocked by the inverted output (Qinv) output of its
preceding flip-flop 14101-1410k_1. Hence, the flip-flops
14101-1410k are coupled in series and, in combination with
feedback from the inverted output, act to as binary counter
in order to count the number of Carry Outs from the
accumulator 1321 up to "k".
When the cross-correlator 500 is operating in Read-Out
mode, namely the Shift output (Shift_ Out) 1231 of the
controller 710 is set to the second state (e.g., logic LOW or
"0"), each flip-flop 14101, ... , or 1410k of the ripple counter
1341 is clocked by the read clock signal (e.g., CLK_RD1 or
CLK_RD2), and thus, the flip-flops 14101-1410k are not
coupled in series. Instead, the flip-flops 14101-1410k are
isolated from each other and operate independently. As
shown, the second multiplexer 14101-1410k receives as
input a bit associated with a corresponding flip-flop from a
ripple counter within another totalizer or XCC, which is
provided into the inputs of the flip-flops 14101-1410k while
the outputs (Q[0]-Q[K]) of each flip-flops 14101-1410k is
18
provided to a corresponding flip-flop of a ripple counter
associated with a neighboring totalizer or XCC in the
summing and correlating matrix or to the data serializer
when the totalizer or XCC is immediately adjacent to the
5 data serializer 750.
With respect to FIG. 15, an illustrative embodiment of a
vertical totalizer (e.g., vertical totalizer 11301) is shown.
Herein, the vertical totalizer 11201 comprises a look-up table
1500 that is coupled to a plurality of accumulators (Accum)
10 1520, which are oriented in series and each coupled to a
corresponding ripple counter of the plurality of ripple coun-
ters 1540.
Herein, when the cross-correlator 500 is operating in
15 Correlation mode, namely the Shift output (Shift _ Out) 1231
of the controller 710 is set to the first state (e.g., logic HIGH
or "1") and a Reset output (Rst_Out) 1230 of the controller
710 is set to the second state (e.g., logic LOW or "0"), the
look-up table 1500 operates as a 2:4 decoder. In particular,
20 the look-up table 1500 receives two digital outputs 1510
from a corresponding ADC and, based on the values asso-
ciated with the digital outputs 1510 and at the end of each
clock cycle (e.g., CLK is equivalent to CLK _2), produces an
output that corresponds to the sum value of the two digital
25 outputs 1510. As an illustrative example, one of its outputs
(vout_0, vout_1, vout_2 & vout_3) 1511-1514 from the
look-up table 1500 is activated to represent the digital value.
As described above, where a first digital (sign) output is a
"I" and a second digital (magnitude) output is a "0", the
30 vout_2 1513 is activated (e.g., logic "1") to represent and
count value of "2". Similarly, where a first digital (sign)
output is a "0" and a second digital (magnitude) output is a
"1", vout_1 1512 is activated (e.g., logic "1") to represent
and count value of "1".
35 The activation of an output signal is provided to a
corresponding accumulator 1521-1524 (e.g., accumulator
1521) that increases a count value maintained by its corre-
sponding internal storage register 1531-1534 (e.g., storage
register 1531). Once an overflow condition occurs in which
40 the count value now exceeds a storage capacity of the
storage register 1531, accumulator 1521 generates a carry
output (Cout) to a corresponding ripple counter 1541 and the
accumulator 1531 maintains the count value prior to the
overflow condition (e.g., "3" where the storage register 1531
45 is a 2-bit register). The ripple counters 1541-1544 provide a
greater amount of storage than provided by the accumulators
1521-1524.
When the cross-correlator 500 is operating in Read-Out
mode, namely the Shift output (Shift_ Out) 1230 is set to the
50 second state (e.g., logic Low or "0"), both the accumulators
1521-1524 and ripple counters 1541-1544 associated with
the vertical totalizer 11301 successively output their stored
count values serially, in some cases through other accumu-
lators or ripple counters in the same vertical totalizer (e.g.,
55 vertical totalizer 11301), until the values are output via
interconnects 1550 and 1560, respectively. Hence, both the
storage registers 1531-1534 and the ripple counters 1541-
1544 cascade their stored values serially until output to a
corresponding XCC (e.g., XCC[1:0] for vertical correlator
60 11301). Furthermore, based on this serial coupling, the
accumulators 1521-1524 and ripple counters 1541-1544 are
effectively reset as reset inputs "0" 1570 and 1575 are read
into accumulator 1521 and ripple counter 1541 at the start of
the Read-Out mode and these values cascade through the
65 serially coupled accumulators 1522-1524 and ripple coun-
ters 1542-1544 in subsequent read clock (e.g., CLK_RD1 or
CLK_RD2) cycles.
US 9,628,263 B2
19
Referring now to FIG. 16, an illustrative embodiment of
an architecture of a cross-correlation cell, such as XCC
114063,1 of FIG. 12, is shown. Herein, XCC 114063,1 com-
prises a look-up table 1600, an accumulator 1620 and a
ripple counter 1640. The accumulator 1620 and the ripple
counter 1640 operate in a manner similar to the accumula-
tors and ripple counters described above. However, the
look-up table 1600 operates in a different manner.
Herein, when the cross-correlator 500 is operating in
Correlation mode in which the Shift output (Shift _ Out) 1231
is set to a first state (e.g., logic HIGH or "1"), the look-up
table (LUT) 1600 operates to produce an output that pro-
vides a value representative of the correlation between the I
component (e.g., Arml[63]) from the first arm and the I
component (e.g., ArmI[l]) from a second arm.
As shown in FIG. 17, the look-up table 1600 includes
combinatorial logic that generally operates as a multiplier to
produce an output where a lower correlation value repre-
senting less correlation between the two inputs. For instance,
as shown in the operational flow 1700 of the look-up table,
where the digital outputs associated with an RF component
from an ith receiver associated with the second arm (e.g.,
Arm2[i] 1710) is represented by "01" (sign-0; mag 1) and
the digital outputs associated with an RF component from an
jth 
receiver associated with the first arm (e.g., ArmiU] 1720)
is represented by "11" (sign 1; mag—l), the look-up table
provides an output "000" 1730 which denotes wide diversity
between the two outputs. Conversely, where Arm2[i+l]
1710 is represented by "01" (sign-0; mag 1) andArmlU+l]
1750 is represented by "01" (sign-0; mag=1), the look-up
table 1600 provides an output "110" 1760 which denotes the
highest correlation between two digitalized RF components.
Referring back to FIG. 16, the output is provided to the
accumulator 1620 that maintains the value until one of three
conditions occurs. First, the accumulator 1620 reaches a
threshold count value, which causes the stored value within
the accumulator to be passed to the ripple counter 1640 via
output (Cout) 1650. Second, the accumulator 1620 receives
an inactive Shift signal, which causes the value of the
accumulator 1620 and its corresponding ripple counter 1640
to be shifted to a neighboring XCC or the data serializer.
Lastly, the accumulator receives a Reset output (Rst_Out)
signal 1230, normally in response to an external reset
condition, which resets the values set forth in the accumu-
lator 1620 and its corresponding ripple counter 1640.
Referring now to FIG. 18, an exemplary embodiment of
a data flow in accordance with the illustrative embodiment
of the cross-correlator 500 is shown. Herein, upon placing
the cross-correlator 500 into the Read—Out mode, during a
first read cycle, the data serializer 750 receives stored data
associated with a first row of the summing and correlating
matrix which, according to this embodiment of the disclo-
sure, includes four (4) 26-bit inputs (e.g., 2-bit stored
accumulator value, 22-bit ripple count value, 2-bits "0" pad)
from horizontal totalizer 112063 (represented as "h0[25-0],"
"hl[25-0]", etc.) and (64) 26-bit inputs (e.g., 4-bit stored
accumulator value, 22-bit ripple count value) from XCCs
114063,63-11400,63. Bit padding may be subsequently
applied prior to generating appropriately bit-size, correlated
data associated with measured RF signals.
Additionally, 26-bit inputs (e.g., 2-bit stored accumulator
value, 22-bit ripple count value, 2-bits "0" pad) are received
by XCCs 1140,,,-114063,1 from the vertical totalizers 11300-
113063. Also, 26-bit inputs (e.g., 4-bit stored accumulator
value, 22-bit ripple count value) are received by XCCs
11400,,+1-114063,1+1 (0:5R:562) from XCCs 11400,R-
114063,R. Lastly, four 26-bit inputs associated with the four
20
accumulator/ripple counter pairs within each horizontal
totalizer 11200-112062 transitions into corresponding accu-
mulator/ripple counter pairs of a neighboring horizontal
totalizer 11201-112063-
5 Referring now to FIG. 19, a test architecture is described
in which iterative digital outputs from a selected ADC are
read for subsequent output from the cross-correlation sys-
tem. The address of the selected ADC is provided through
Test_addr signaling 1243 provided to a control and deseri-
io alization logic 1900. In response to an "active" Test_ en
signal 1244 along with the Test_addr information 1243 from
the controller 710, the logic 1900 enables corresponding
switching logic 1910 to directly retrieve the two digital
outputs from the selected ADC (e.g., ADC 1920) without the
15 digital outputs traversing through the summing and cross-
correlating matrix 740. Multiple retrievals (e.g. four retriev-
als in 4 CLK_2 cycles) from the selected ADC 1920 may be
used to produce L-bits of data (e.g., L-bits being 8-bits for
four retrievals in 4 CLK_2 cycles) subsequently read from
20 some or all of a column of cross-correlation cells (XCCs)
1930 corresponding to ADC 1920. Another testing circuit is
shown in FIG. 20.
Referring now to FIG. 20, another exemplary embodi-
ment of the cross-correlator deploying binary implemented
25 self-test (BIST) logic is shown. For this embodiment, a
controller (BISTctrl) 2000 operating in cooperation with the
interface controller 710 through activation of the DoBIST
signal 2005 controls bit values from one or more pseudo-
random generators 2010 and 2015 implemented within the
3o analog subsystem 1200 to be manually fed into the cross-
correlation matrix (XCM)1140 via Arm_h 1260 and Arm_v
1265 outputs. The controller 2000 further controls control
logic (control_fsm) 2020, which controls the cycling of the
Shift—Out signal 1231, and thus, controls accumulation and
35 reading of the digitized bit values produced by the analog
subsystem 1200.
The interface controller 710 further activates a BIST
comparator 2040 pre-programmed with a prescribed pattern
of values to determine that the accumulated data received by
4o a BIST multiplexer 2030 via certain cross-correlation cells
(XCCs) corresponds to the prescribed pattern of values. If
so, the TestOK signal 2050 is set to identify to the interface
controller 710 that the XCCs are operating properly. Status
data 2055 is provided to the interface controller 710 for
45 subsequent forensics in the event that the testing is showing
an error in the XCCs.
In the foregoing description, the invention is described
with reference to specific exemplary embodiments thereof.
For instance, ASIC may be a digital signal processor that
50 includes the digitizer and cross-correlation circuitry on the
same chip. It will, however, be evident that various modi-
fications and changes may be made thereto without depart-
ing from the broader spirit and scope of the invention as set
forth in the appended claims.
55 What is claimed is:
1. A cross-correlator comprising:
a plurality of analog front ends, each of the plurality of
front ends comprises a variable gain amplifier that
receives and modifies a unique analog signal associates
60 with a measured analog radio frequency (RF) signal
and an analog-to-digital converter that produces digital
data associated with the modified analog signal;
a cross-correlation circuit communicatively coupled to
the plurality of analog front ends, the cross-correlation
65 circuit performs a cross-correlation operation on the
digital data produced from different measured analog
RF signals,
US 9,628,263 B2
21
wherein the cross-correlation circuit comprises
a plurality of first summing logic in communication
with a first plurality of analog front ends of the
plurality of analog front ends,
a plurality of second summing logic in communica- 5
tion with a second plurality of analog front ends of
the plurality of analog front ends, and
a cross-correlation matrix, wherein the cross-corre-
lation matrix comprises a plurality of cross-corre-
lation cells, each of the plurality of cross-correla-
tion cells uniquely performs a cross-correlation
operation on the digital data produced from dif-
ferent receivers associated with the different
sources, 15
wherein the plurality of first summing logic com-
prises a plurality of horizontal totalizers that are
communicatively coupled to a first plurality of
cross-correlation cells associated with the cross-
correlation matrix, each of the plurality of hori- 20
zontal totalizers includes a look-up table, a first
plurality of accumulators and a first plurality of
ripple counters, the first plurality of accumulators
are oriented in parallel and each coupled to a
corresponding ripple counter of the plurality of 25
ripple counters; and
a data serializer communicatively coupled to the summing
and cross-correlating matrix continuously outputs a
prescribed amount of the correlated digital data.
2. The cross-correlator of claim 1, wherein at least a first 30
cross-correlation cell of the plurality of cross-correlation
cells comprises a look-up table, an accumulator and a ripple
counter, the look-up table of the first cross-correlation cell
operates to produce an output representative of a correlation 35
between a first digital datum of the digital data that includes
an RF component from a first source and a second digital
datum of the digital data that includes an RF component
from a second source different than the first source.
3. The cross-correlator of claim 1, wherein the first 40
plurality of cross-correlation cells oriented as a first column
of the cross-correlation matrix.
4. The cross-correlator of claim 1, wherein the plurality of
second summing logic comprises a plurality of vertical
totalizers that are communicatively coupled to a second 45
plurality of cross-correlation cells associated with the cross-
correlation matrix, each of the plurality of vertical totalizers
includes a look-up table, a second plurality of accumulators
and a second plurality of ripple counters, the second plural-
ity of accumulators are oriented in series and each coupled 50
to a corresponding ripple counter of the plurality of ripple
counters.
5. The cross-correlator of claim 4, wherein the second
plurality of cross-correlation cells oriented as a first row of
the cross-correlation matrix. 55
6. The cross-correlator of claim 4, wherein each of the
first plurality of accumulators and the second plurality of
accumulators includes an adder with carry.
7. A cross-correlator comprising:
a plurality of analog front ends, each of the plurality of 60
front ends comprises a variable gain amplifier that
receives and modifies a unique analog signal associates
with a measured analog radio frequency (RF) signal
and an analog-to-digital converter that produces digital
data associated with the modified analog signal; 65
a cross-correlation circuit communicatively coupled to
the plurality of analog front ends, the cross-correlation
22
circuit performs a cross-correlation operation on the
digital data produced from different measured analog
RF signals,
wherein the cross-correlation circuit comprises
a plurality of first summing logic in communication
with a first plurality of analog front ends of the
plurality of analog front ends,
a plurality of second summing logic in communica-
tion with a second plurality of analog front ends of
the plurality of analog front ends, and
a cross-correlation matrix, wherein the cross-corre-
lation matrix comprises a plurality of cross-corre-
lation cells, each of the plurality of cross-correla-
tion cells uniquely performs a cross-correlation
operation on the digital data produced from dif-
ferent receivers associated with the different
sources,
wherein each cross-correlation cell of the cross-
correlation matrix detects a degree of correlation
between the digital data that is represented by a
resultant value and generates a count value repre-
senting a number of occurrences of the resultant
value when the cross-correlation matrix is oper-
ating in a first mode and reads out the count value
when the cross-correlation matrix is operating in a
second mode.
8. The cross-correlator of claim 7, wherein the count value
for each of a first plurality of cross-correlation cells of the
plurality of cross-correlation cells propagates the count
value through a second plurality of cross-correlation cells of
the plurality of cross-correlation cells when the cross-cor-
relation matrix is operating in the second mode.
9. The cross-correlator of claim 1, wherein the plurality of
analog front ends, the cross-correlation circuit and the data
serializer are implemented on a single integrated circuit
chip.
10. A cross-correlation system, comprising:
a plurality of cross-correlators, including at least a first
cross-correlator and a second cross-correlator;
a first interconnect coupled to the first cross-correlator, the
first interconnect to provide, as an input to the first
cross-correlator, a first component recovered from an
analog radio frequency (RF) signal detected and pro-
cessed by a first receiver; and
a second interconnect coupled to the first cross-correlator,
the second interconnect to provide, as an input to the
first cross-correlator, a second component recovered
from the analog RF signal detected and processed by a
second receiver different than the first receiver,
wherein the first cross-correlator comprises:
a plurality of analog front ends, each of the plurality of
front ends comprises a variable gain amplifier that
receives and modifies an analog signal associates with
a measured analog radio frequency (RF) signal and an
analog-to-digital converter that produces digital data
associated with the modified analog signal,
a cross-correlation circuit communicatively coupled to
the plurality of analog front ends, the cross-correlation
circuit performs a cross-correlation operation on the
digital data produced from different measured analog
RF signals, wherein the cross-correlation circuit of the
first cross-correlator comprises
a plurality of first summing logic in communication
with a first plurality of analog front ends of the
plurality of analog front ends,
US 9,628,263 B2
23
a plurality of second summing logic in communication
with a second plurality of analog front ends of the
plurality of analog front ends, and
a cross-correlation matrix, wherein the cross-correla-
tion matrix of the first cross-correlator comprises a
plurality of cross-correlation cells, each of the plu-
rality of cross-correlation cells uniquely performs a
cross-correlation operation on the digital data pro-
duced from different receivers associated with the
different sources,
wherein at least a first cross-correlation cell of the
plurality of cross-correlation cells of the first cross-
correlator comprises a look-up table, an accumulator
and a ripple counter, the look-up table of the first
cross-correlation cell operates to produce an output
representative of a correlation between a first digital
datum of the digital data that includes an RF com-
ponent from a first source and a second digital datum
of the digital data that includes an RF component
from a second source different than the first source,
wherein the plurality of first summing logic of the first
cross-correlator comprises a plurality of horizontal
totalizers that are communicatively coupled to a first
plurality of cross-correlation cells associated with
the cross-correlation matrix, each of the plurality of
horizontal totalizers includes a look-up table, a first
plurality of accumulators and a first plurality of
ripple counters, the first plurality of accumulators are
24
oriented in parallel and each coupled to a corre-
sponding ripple counter of the plurality of ripple
counters, and
a data serializer communicatively coupled to the summing
5 and cross-correlating matrix continuously outputs a
prescribed amount of the correlated digital data.
11. The cross-correlation system of claim 10, wherein the
first component is an I component associated with the analog
RF signal processed by the first receiver and the second
i0 
component is a Q component associated with the analog RF
signal processed by the second receiver.
12. The cross-correlation system of claim 10, wherein
the first plurality of cross-correlation cells oriented as a
15 
first column of the cross-correlation matrix,
the plurality of second summing logic of the first cross-
correlator comprises a plurality of vertical totalizers
that are communicatively coupled to a second plurality
of cross-correlation cells associated with the cross-
20 correlation matrix, each of the plurality of vertical
totalizers includes a look-up table, a second plurality of
accumulators and a second plurality of ripple counters,
the second plurality of accumulators are oriented in
series and each coupled to a corresponding ripple
25 
counter of the plurality of ripple counters, and
the second plurality of cross-correlation cells oriented as
a first row of the cross-correlation matrix.
