Soft Decision Analyzer and Method by Zucha, Joan P. et al.
1111111111111111111immn111111u~
(12) United States Patent
Steele et al.
(io) Patent No.: US 9,450,747 B1
(45) Date of Patent: Sep. 20, 2016
(54) SOFT DECISION ANALYZER AND METHOD (56) References Cited
(71) Applicant: The United States of America as
represented by the Administrator of
the National Aeronautics and Space
Administration, Washington, DC (US)
(72) Inventors: Glen E. Steele, Webster, TX (US);
Chatwin Lansdowne, Houston, TX
(US); Joan P. Zucha, Pearland, TX
(US); Adam M. Schlesinger, League
City, TX (US)
(73) Assignee: The United States of America as
represented by the Administrator of
the National Aeronautics and Space
Administration, Washington, DC (US)
(*) Notice: Subject to any disclaimer, the term of this
patent is extended or adjusted under 35
U.S.C. 154(b) by 0 days.
(21) Appl. No.: 14/861,458
(22) Filed: Sep. 22, 2015
Related U.S. Application Data
(62) Division of application No. 13/789,903, filed on Mar.
8, 2013, now Pat. No. 9,166,750.
(51) Int. Cl.
H04L 1/24 (2006.01)
H04L 7/00 (2006.01)
H04L 7/04 (2006.01)
H04L 1/00 (2006.01)
(52) U.S. Cl.
CPC ........... H04L 7/0087 (2013.01); H04L 1/0047
(2013.01); H04L 1/242 (2013.01); H04L 7/042
(2013.01)
(58) Field of Classification Search
CPC ..... H04L 1/242; H04L 7/042; H04L 1/0047;
H04L 7/0087
See application file for complete search history.
U.S. PATENT DOCUMENTS
6,373,910 B1 4/2002 Kingston et al.
6,647,056 B1 11/2003 Imaizumi et al.
6,802,037 B2 10/2004 Kim et al.
7,136,445 B2 11/2006 Houtman
7,296,216 B2 11/2007 Shen et al.
7,352,720 B2 4/2008 Chang et al.
7,716,561 B2 5/2010 Belogolovyi et al.
7,778,619 B2 * 8/2010 Bultan ................
7,831,895 B2 11/2010 Lin
2002/0122516 Al* 9/2002 Kilani .................
2003/0193914 Al * 10/2003 Lomp ................
2006/0165200 Al * 7/2006 Wagner ..............
2007/0079223 Al 4/2007 Mondin et al.
2007/0260772 Al 11/2007 Garmonov et al.
2008/0086670 Al 4/2008 Krouk et al.
2009/0207836 Al 8/2009 Kawasaki et al.
2010/0128661 Al 5/2010 Becker et al.
2010/0178057 Al 7/2010 Shieh
(Continued)
OTHER PUBLICATIONS
H03J 7/02
375/341
H04L 7/042
375/354
H04B 1/707
370/335
H04L 7/042
375/354
Lansdowne et al., Jitter-Induced Symbol Slip Rates in Next-Gen-
eration Ground Segment Receivers, AIAA Space Ops, Apr. 2010,
pp. 1-17, Huntsville, AL.
(Continued)
Primary Examiner Dac Ha
(74) Attorney, Agent, or Firm Kurt G. Hammerle
(57) ABSTRACT
A soft decision analyzer system is operable to interconnect
soft decision communication equipment and analyze the
operation thereof to detect symbol wise alignment between
a test data stream and a reference data stream in a variety of
operating conditions.
7 Claims, 15 Drawing Sheets
ftEFERF.NCF. 106
DgTA STREAM 113
100 105 f 
ATA 30URCE~
` ANALYZED ANDSCALED/
Y TEST DATA 
STREREAMM
BASE SAND
RF TRANSMrrrER PROCESSORS110 ~~ PERFORMANCE DATA
TEST DATA 112 
ALONG WITH DATA
RF CHANNEL 
STREAM ! 120 
STREAM
200
111
SDASIGNAL SASESAND
RF RECEIVER A CONDITIONING g SIGNAL
115 
116 
HARDWARE PROCESSOR
125----,117
126 A 
SDA g
1.40 
c FIRMWARE D 300
.130 
FPGA CARD
135
STATI- CAL DRIVERS
RESULTS
145 D 
141
...
HISTORICAL 
SD,4SOFTWARE 400
RECORD 
APPLICATION
150 
WORKSTATION OS
WORKSTATION
https://ntrs.nasa.gov/search.jsp?R=20160012000 2019-08-29T16:26:59+00:00Z
US 9,450,747 B1
Page 2
(56) References Cited OTHER PUBLICATIONS
U.S. PATENT DOCUMENTS Lansdowne et al., Measurement Techniques for Transmit Source
2010/0215056 At 8/2010 Ide et al. Clock Jitter for Weak Serial RF Links, IEEE, Mar. 1, 2010, pp. 1-5.
2010/0272150 AT* 10/2010 Kit ..................... H04B 1/71637
375/130 * cited by examiner
R
E
F
E
R
E
N
C
E
 ,
-
-
D:
1
 S
T
R
E
A
M
.
.
.
 
1
1
3
1 
D
A
T
A
 S
O
U
R
C
E
A
N
A
L
Y
Z
E
D
 
4
.
L
Y
Z
E
D
 A
N
D
 S
C
A
L
E
D
1
0
0
 
T
E
S
T
 D
A
T
A
 S
T
R
E
A
M
 
B
A
S
E
 E
A.
il
D 
~
T
 
~
3
T
~
T
S
i
v
I
I
T
I
I
✓
'
R
 /
 
! 
 
P
R
O
C
E
S
S
O
R
S
1.
10
3 
y-
 
P
E
R
F
O
R
M
A
N
C
E
 D
A
T
A
A
L
O
N
G
 W
rr
'I
f 
D
A
T
A
R
F
 t
:I
.1
A~
JN
EF
 
T
E
S
T
 i
JA
T'
F~
 
1 
S
T
R
E
A
M
11
-
 
-
-
-
-
-
-
-
-
-
-
 
S
T
R
E
A
M
 ~
 
1
2
0
 
~
-
 
-
 
-
 
2
0
0
 
~
11
1 
~
_
-
-
_
 
n~
SD
+~
 ~
3I
GN
AL
 
B
A
S
E
B
A
 D
 
N
R
F
 R
E
C
:
E
I
V
 R
 
-
-
-
-
-
-
-
 
C
O
N
D
I
T
I
O
N
I
N
G
 
~
 
f 
~
 
S
I
G
N
A
L
 
o
11
 
.
_
 
5 
1
H
A
R
D
W
A
R
E
 
P
R
O
C
1+
 S
S
O
R
 
~
1
 
—
 
11
'7
S
D
A
1
2
6
—
,
 C
F
I
R
M
W
A
R
E
 
`
D
1.
4 
_
13
01
 
,
 g 
F
P
GA
 C
A
R
D
 
~
13
5-
I
A
T
I
S
T
I
~
;
D
R
I
V
E
R
S
C.
.t
1I
, ~
 
s 
~
U
L
 
1
4
5
 
6
c
1
4
1
_
 
-
 
—
 
S
D
A
 S
O
 
T
U
X
A
R
E
 
4
0
0
H
I
S
T
O
R
I
C
A
L
 
6 
A
P
P
L
I
C
A
T
I
O
N
j
 
E 
r
R
E
C
O
R
D
g
_
.
.
-
-
-
-
-
-
-
-
-
 
-
-
s 
W
O
R
K
S
T
A
T
I
O
N
 O
S
#
W
O
R
K
S
T
A
T
I
O
N
 
~
F
I
G.
 1
 
~
3
0
0
 
15001 
~
 
~
"
 
l 
1
7
~
(
 
A
S'
~I
I~
CH
RO
NO
US
 T
E
S
T
 
6
`
 
 
A
N
A
L
Y
Z
E
D
 A
N
D
 S
C
A
L
E
1
4
1
A
N
D
 R
E
7
 DA
'~
''
d S
S
T
 
`
~
-
~
-
~
 
T
E
S
T
 
R
E
A
M
S
 
E 
S
T
 D
A
T
A
 S
T
R
E
A
M
 
C
B
 
6
0
11 
S
T
R
E
A
M
3
0
2
C
O
N
D
I
T
I
I
O
a
V
;
l
'
 G
(C
fC
 
NF
I4
a 
CO
N~
'T
G~
 
B
L
O
C
K
 
~
 
C
O
N
D
I
T
I
O
N
E
D
 I
N
P
U
T
 D
A
T
A
"
 
)
 
(C
C3
NF
 /C
I 
R
I
) 
L3
 
£ 
S
T
R
E
A
M
S
 ;~
 O
R
 A
N
A
L
Y
S
I
S
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
M
E
A
S
U
R
E
—
14
1 
O
F
 'S
'T
A:
T .
P 
°
1.
41
 
C
H
A
R
A
C
T
.
1
2
6
 
C
f
 I
~F
FI
G,
 
B
L
O
C
K
A
N
D
 
P
C
T
 B
U
S
 
T
I
M
I
N
G
 
C 
O~
'I
;I
C3
.
L
-
1
 
I
N
T
E
R
F
A
C
E
 I 
C
O
N
T
R
O
L
 
(C
ON
F/
 CT
R
T
 )
 
D
A
I
G
G
R
E
G
A
'
T
E
 
B
L
O
C
S
S
T
A
T
I
S
T
I
C
A
L
P
E
R
F
O
R
M
,
 
E
D
A
T
A
C
 
A
G
G
R
E
G
A
T
E
 S
T
A
T
I
S
T
I
C
A
L
P
E
R
F
f
 RN
dl
. 
D
A
T
r
S
3
0
3
F
I
G,
 
 
2
5
2
0
-
-
-
-
-
-
`
 
S
E
L
E
C
T
E
D
 R
ED
` 
A
B
 M
U
X
E
D
5
0
0
 
I 
R
E
F
'
 .A
.1
V1
J '
I`
 ,
S'
< 
&
 T
EE
ST
 D
A
T
A
 
T
E
S
T
 S
fi
KE
A 
T 
M
O
A
 
D
A
T
A
 S
T
R
E
A
M
S
'
 
S
T
R
E
A
M
S
 
~
1
1
6
- --
-
-
 
 
5
 1
T
'
R
CC
ES
 
T3
UT
,T
TI
'U
EK
TM
UL
FI
I.
EE
 R
E
F
 
# 
t
3
 M
U
X
E
D
C€
~N
I+
/L
;T
RL
 S
I
M
U
L
A
T
O
R
 
 
A
N
D
 ~
'
'
~
;S
'~
`I
~A
'~
f~
 
R
A
C
 
~
 
~
~
~
 
~
 
~
E
 
~
~
F
~
T
R
E
A
I
'
~
 
~
I
N
P
U
T
 
3 
~
 4
 ~ 
S
T
R
E
A
M
S
~
B
L
O
C
 
-B
L
O
C
K
 
~
 
5
3
2
1
4
1
 
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
5
1
0
n~
1 
D
 `
CO
NE
/C
 
D
 
C
O
N
k
~
/U
rR
 
SA
MI
'T
 E
 
R
E
F
 
H
 
N
5
 
1- 
 
T
E
S
T
 STREAMS------
o
540141 
 
 
54
1 
5
3
3
 
~
A
B
 M
U
X
E
D
 
I 
3 
S
C
A
L
E
D
 A
E
 M
U
~
s
 E
E
 
S
C
A
I
 _
 
&
A
B
S
C
A
 E
D
 T
E
S
T
C
F
 i 
T
E
S
T
 S
T
R
F
A
 
S
Y
N
T
H
.
 
E
S
I
 S
T
R
E
A
M
S
S
Y
N
C
 
D
A
T
A
 O
U
T
P
U
T
 
B
 
~
C
H
A
N
N
E
L
T
E
S
 
s
'
 
(S
 I D
O
)
 S
T
-RE
AM
,
~
-
 
-
-
-
-
-
-
-
-
-
-
-
-
14
1 
S
C
A
L
E
 
4
}
A
'
T
'
A
 
w
w 
1
1
7
B
L
O
C
K
 
o
u
r
P
L
i
 C
-
0
N
E
/C
TR
L 
D
 C
ON
F/
CT
RT
 
T<c
 t
x 
5
5
0
5
3
2
 
S
C
A
L
E
D
 A
B
 M
U
X
E
D
 T
E
S
T
 S
T
R
E
A
M
S
 I
N
P
U
T
 D
A
T
A
 S
`I
'R
EA
 M
 S
'
3
3
 
 
C 
A
B
 M
U
X
E
D
 R
E
F
 S
T
R
E
A
M
 
I
N
P
U
T
 
P
U
T
 D
A
T
A
 
E
H
 
S
A
M
P
L
E
D
 R
E
F
 
'
T I
i S
T
 S
 C`
R 
!
C
M
S
_
_
_
_
• 
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
 
-
 
v_
Y 
11
8
O
`
I
.
 3
J
C
O
R
R
,
 R
E
F
 D
A
T
A
 
6
5
0
 
6
3
1
 
6
0
0
 
~
C
L
O
C
K
 E
D
G
E
 B
A
S
E
D
CO
RD
. `
I E
S
T
 D
A
T
A
 
~
~
 
~
 
~
 
SL
IP
 P
E
R
F
OR
~v
a ----
-
-
-
-
-
-
-
-
-
-
-
S
C
A
L
E
D
 A
F3
 Ir
II
J.
"E
1~
 
TS
"I
 
A
T
 
P
 
C
O
R
R
,
 H
A
R
D
 D
E
C
I
S
I
O
N
B
I
T
 E
R
R
O
R
 P
E
R
F
O
R
M
.
vi
.
I 
ES
'I
 S
'T
`R
EA
MS
 
HI
SA
NA
LY
SI
S
6
2
 ~
 
-
-
 
-
 
~
S
Y
N
C
H
R
.
 I
N
P
U
T
 
B
L
O
C
K
 
~
 
D
A
T
A
 C
O
N
T
E
 
.
N r
 B
A
S
E
D
 
.
?
 
o
D
A
T
A
 S
T
R
E
A
M
S
 
SL
IP
 P
E
R
F
O
R
M
.
.
63
63
 
-
-
-
-
-
-
-
5
4
1
-
 
l 
65
1
R
r
 L
I;
IC
:T
I 
PI
 R
F
C
R
n
.
 
o
~
RT
C N
 L
 Ia
,N
&&
x 
-
I P
E
R
F
O
R
M
.
-
 
A
G
G
R
.
-
-
-
6
5
6
 
S
T
A
T
,
-
6
3
6
 
H
I
S
T
O
G
R
A
M
 S
T
A
T
I
S
T
I
C
A
L
 
L
 P
E
R
F
O
R
M
.
 D
A
T
A
 
;
P
E
R
T
 .
 
C
 
~
C
O
N
F
/
 CT
R
L
-
-
-
-
-
-
-
-
 
-
 
—
 
-
-
-
-
-
-
 
D
A
T
A
C
L
O
C
K
 E
D
G
E
 B
A
S
E
D
!
-
-D-
A~
TA
 
"
 -
-
-
 
~
'
-
 
.
.
.
 
SL
IT
 P
E
R
F
O
R
M
.
 
C
O
M
E
,
 
a 
~
C
L
O
C
K
 E
D
G
E
 B
A
S
E
D
-
-
-
0
3
1
 
E
V
E
N
T
 
o
SL
IP
 P
E
R
F
O
R
M
.
 
.
 
6
6
~
-
 
 
CL
J'
:'
~'
I'
EI
tit
T B
A
S
E
D
 
R
E
C
C
~
R
E
 
►
*
X.
. 
SL
ID
 P
E
R
F
O
R
N
C
 
I I
IS
 I 
G
 
-
~
.
D
A
T
A
 C
C
I
T
E
"
d
T
H
A
S
I
~
I
~
1
C
C
7
1
5
.
 
_
 
F;
47
EI
`T
T
SL
IP
 P
E
R
F
O
R
M
.
 
Z
E
S
T
 
6
2
2
-
-
-
C
C
 C
R
L
 .
 
i 
Ct~
Er 
G
E
N
E
R
A
L
 P
UR
PO
SE
 
R
E
C
O
R
D
,
 
,
_
 
C,
TR
~ 
BL
OC
K
B
L
O
C
 
E
X
T
E
R
N
A
L
 E
V
E
N
T
S
 
Q
A
:C
Q
62
22
 
C[
~I
~z
 ,/
CT
RI
,
—
 
 
RI
{,
A
C 
D
 
CO
NF
IC
TR
L
P
 
R#
+.
 
_
 
,
_
x
:
41
 
-
 
~
 
6
2
3
 
~
 
~
`
 
6
5
5 
~
6
6
0
 
_
 
-
 
14
1
6
6
2
 
4~6
F
I
G
,
 4
A
6
2
8
I
~
6
0
 
€
-
 
~
s
 .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
S
C
A
L
E
D
 A
}3
 Iti
 €
J~
F T
3 
T
E
S
T
 
6
0
5
 
6
1
0
 
6
1
1
 
6
1
 S
 
~
~
{~
 
~
T
E
S
T
 S
T
R
E
A
M
 S
YI
~T
~;
I~
:€
. 
ST
RE
E;
iU
€ 
~
`
 
fi 
~
 
~
 
~
'
 
6
2
1
I
N
P
U
T
 D
A
T
A
 S
T
R
E
A
M
S
 
r 
~
T
I
M
I
N
G
 
-
-
-
-
.
,
A
L
I
G
N
.
 
I I
an
 T
 
j C
`C
3R
I2
. 
S
I
N
G
L
E
C
O
R
R
.
B
U
F
F
E
R
 
 
BA
TA
 
R
E
F
 
WJ
N~
 
zl~
 sT
 
M
D
 
C
O
N
E
/
 
B
L
O
C
K
.
 
-
 
D
A
T
A
 
C
O
R
K
.
 
D
A
T
A
 
~
C
;
T
R
a
5
 
R
E
S
U
L
T
 
SI
B€
Y
1
1
8 
CO
RD
..
 
RA
NK
. 
AT
.i
ta
N—
B
A
T
 
AN
AL
- 
N
€
A
E
I
^
`
~
l
s
,
I
,
 
T.
.t
C'
K 
A
N
N
A
I
r
,
A
.
€
'
'
A
A
B
 M
U
X
E
D
 T
AE
 
D
Y
N
A
M
 
E
3
,10
 C
K
 
A
C
4/
 
B
L
O
C
S~
 N
t`
II
. 
S
T
R
E
A
3
T
 
S
T
R
E
A
M
 
A
L
I
G
N
.
 
CI
-I
AN
~ 
R
 
C 
T
 IL
T 
C.
ON
TE
N`
C 
N
C 
O
 I
Oi
T.
 
T
I
M
I
N
G
 
C
O
R
P
.
 
F
3A
SE
D 
N
 
o
E
TI'
~3P
T~ 
T
 
14
1 
-
~
,
~
 
D
Y
I
~
A
M
.
 
T 
fz
E 
t7
Y'
l`
 
66
.1
 
-
 
1 S
L
I
P
 P
E
R
F
.
 
~
D
A
T
A
 
-
 
C
O
N
d*
 /
 
A
L
€
G
N
.
 
D
A
T
A
 
~ 
L 
t7
1E
IF
S'
T'
RE
AM
S 
(:
 
5
3
 
I~
 
C~
 :
 R
T,
 
3 .
F~
TJ
FF
ER
 
-
 
—
 
L)
 C
T
R
L
F
O
R
 
B
L
O
C
K
 
6
1
2
 
-
 —
 
-
-
-
-
-
-
-
A
N
A
L
Y
S
I
S
 
5
3
3
 
_
 
1.
41
 
6
2
2
 
~
S
L
I
P
 A1
11
Cz
iST
't,
4Tt
 `'
T 
F
`
E
E
I
~
E
A
C
K
 
64
1 
~
S
A
M
P
L
E
D
 R
E
F
i 
T
E
S
T
 S
T
R
E
A
M
S
 
C
L
O
C
K
 E
D
G
E
 
6
3
1
 
61
1 
C
C
)R
R.
 
'
 
t!
i
T~
AS
EI
 
SL
IP
 
O
 
6
3
5
 
L
 
I~
.€
fI
+ 
C
O
 
R
.
 
C
66
.3
. -
-
 
C
L
O
C
k
 
.
~
^
~
IJ
A'
~ A
A
C
QO
 
;
T
A
C
T
,
,
H
A
R
D
R I
Q
I
E
I
 C
T
.
 
s
C~
aL
EI
3 
A
B
 3
+
I€
3x
ET
 
CC
)r
2I
t.
 
E
I
R
C
a
R
3
T
'
I
 
R
Lt
~C
x 
_
 
D
E
T
E
C
T
.
 
I 
1
4
 1
 
 
K
 
T
E
S
T
 S
 i R
EA
lt
(I
 S
Y~
€C
 
t 
C
m
 
~
[ 
1
E
S
 
P
 R
€
iO
R
2
Y
5
 
V
T
 D
i
1
A
 
«
S
A
 i
l
1
w
A
U
j
c
'
?
~
 
"
e 
C
 
S
7
 S
.
.
V
 C
 
P
R
F
•"
•
S
T
R
E
A
M
 
 
1
4
1
i
C
T
R
I
 7
O
 ~p+l B
 1~
kyli
t] X
E
D
 ~
R
l
i
 F
 
qN
 
{s
 I~
~1
{ 
~
 
NI
F
L
 
/f
 0~."; 
r
~
 1
 A
kT
4
~
f
 k
.
 
!
 ~
 
41
l•
5.
 5
~k
 
A
 
TS
.d
.r
d 
c
?
I
w
3
,
J
'
I
 R
~
f
 
~
`
$
E
l
—
,
6
3
 
53
2 
~
 
CO
 a 
r 
B
L
OC
S 
_
 
W 
_
 
~
-
C
T
R
L
 
R
U
N
 L
EN
C'
xT
_n
' 
D
 
\O
14
.1
 
P
E
R
F
O
R
M
,
 
,
O J
F
I
G
.
 4
B
R
E
F
.
D
A
T
A
I 
S
O
U
R
 
E
H
,
J
,
 L
,
N
 ,
 
.
.
.
.
F 
T
X
(S
QP
S 
)
E
L
 
RT
C 
CI
.I
.
R
X
 
A
 
C
H
,
Q 
CH
. 
-
~
S
E
L
F
I
G.
b
P
O
S
S
I
B
L
E
 T
E
S
T
 S
T
R
E
A
M
 
OF
F'
D
E
C
I
S
I
O
N
 S
I
G
N
 B
I
T
 P
O
L
A
R
I
T
Y
 
~
A
S
S
I
G
N
M
E
N
T
S
 F
O
R
 S
Q
P
 K
.
.
.
,
 
,
 
,
 
.
4.
1,
 
,
2
'
,
G
,
H
,
I
,
t
J
,
 
,
I
A
,
M
.
,
N
.
.
.
 1
 (
4
)
.
f
t
f
t
,
Z 1
T
A
T
 D
A
T
A
 
O
ST
RI
aA
1 
f
.
.
.
,
A
,
B
,
C
,
D
,
E
,
F
 G
,
H
,
I
,
J
,
K
,
L
,
M
,
N
.
.
.
j
 (1
)
s~
 
,
.
,
 
i,
a 
,
 
,
 
,
 
y 
,
 
,
A 
B,
C,
D,
E,
F,
G,
H,
 ,J
, 
,
L,
 z
,N
..
.~
E,
3.
,,
s,
. 
,
L
 ,
m
,-
N
 .
.
)
 (
J
)
I..
.
,
A
,
B
,
C
,
J
_
.
S
,
I
F
,
,
.
F
'
,
G
,
k
.
 ,
I
,
+
,
.
r
3.
E'
S.
,L
,M
,N
,.
,-
~
 
(4
).
R
E
F
.
 
C
H
.
D
D
A
T
A
.
F
 'I°
 
~ 
t,
..
,B
, 
,
D,
C,
F,
 „
H.
, 
,
J,_
 L
,
 ,
 
,
M.
..
1 (
5)
.
,
.
,
 
,
A,
D,
C 
F,
 ,
H,
G,
J,
I,
 ,
 
.
, 
,
 
.
.
.
 )
 ( 
)
S
E
L
 
R
F
 C
H
.
 
i
~
—
 
,
,
.
.
,
 
,
A
,
D
,
C
,
F
,
 
,
H
,
G
,
J
,
I
,
L
,
K
,
N
,
 
.
4a
, (
f)
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
#.
.,
,B
,.
f'
3.
,D
,C
y 
,
 
r
,
H
,
 
,
J
,
1
,
L
,
K
,
l
Y
x
M
.
.
.
)
 (
8
)
E
E 
S
T
R
E
A
M
S
E
L
F
I
G.
E
X
.
 O
F
 .3
-
B
I
T
S
O
F
T
 D
E
C
I
S
I
O
N
:
0
 I. 
I 
(S
TR
ON
GE
ST
 0
)
0
1
0
0
0
,
11
00
 (
W
E
A
K
E
S
T
 
K
E
S
T
0)
1
0
0
 (
W
E
A
K
E
S
T
 1)
1
01
1
1
0
1 
II
, (
T
R
O
N
C
E
S
 
1)
N
U
M
B
E
R
.
 O
F
O
C
C
U
R
A
N
C
I
S
O
 'F
T 
D
E
C
I
S
I
O
N
 D
I
S
T
R
I
B
U
T
I
O
N
 (
ID
EA
L)
il
l 
i 
34
 
0
0
0
 
0
 :L I
S
O
F
A
'
 D
E
C
I
S
I
O
N
 V
A
L
U
E
RE
IN
S
T
R
E
A
M
S
E
E
D
E
L
A
Y
1 
R
E
F
S'
I'
R F
 
4
C
L
O
C
K
T
E
S
T
 
PE
RI
OD
i-
--
--
--
--
--
--
--
--
--
-
S
T
R
E
A
M
S}
,t
.
1
2
 B
I
T
S
7
D
E
L
A
Y
I"
J}
aL
AY
`
B
E
L
A
Y
D
E
L
A
Y
Dl
i,
LA
Y
D
E
L
A
Y
D
E
L
A
Y
D
E
L
A
Y
I 
R
E
F
1 
R
E
F
'
 R
E
F
1 
R
E
F
l 
R
E
F
a 
I
 R
E
F
1 
R
E
F
I 
R
E
F
S
T
R
E
A
M
'
S
T
R
E
A
M
&
A-
m
S
T
R
E
A
M
S
T
R
E
A
M
S
T
R
E
A
M
S
C
R
E
A
M
SF
RE
Ai
Vi
C
L
O
C
K
:
C
L
O
C
K
C
L
O
C
K
 
~
C
L
O
C
K
 
O
C
 IC
'
C 
L
O
C
K
E 
C
L
O
C
K
C
i
CO
CK
3
C
L
O
C
K
£'
F 
f 
IU
I)
P
E
R
I
O
D
E
P
E
R
I
O
D
 € 
y
P
E
R
 O
O
P
E
R
I
O
D
P
E
R
I
O
D
~
 
,
 P
E
R
I
O
D
P
E
R
I
O
D
61
.0
+ 
OI
2 
C
O
R
 
CC
}I
L 
CO
IL
 
C 
O
R
 
z
 
C
O
R
 &
- 
C
O
R
 fp
s 
C'
O 
&
 
C
O
R
t 
C
O
€
 
X
C
.
.
R
q
R
2
XC
;C
}R
 
XC
C1
1 
x
C
O
R
C
O
R
 
x 
1 
X
C
O
R
C
O
R
P
R
I
O
R
 '1
 C3
 
ff 
E
L
I
'
 4
 
E
A
R
L
Y
 3
 
 
E
A
R
L
Y
 .
I 
E
A
R
L
Y
 O
 
IL
A'
I E
} 
1 
L
A
T
E
,
 
L
A
T
E
 
E
 
`
i E
T
I
N
S
 F
'O
i7
1,
 !
 
2
O
 
2
0
 
E 
2
0
 
1 
2
0
0
 
'
20
 
2
O
 
2
O
 
2
0
 
2
T
}3
E 
T
E
ST
" 
2
0
 
2
O
 
2
O
 
2
0
 
2
0
 
2
O
 
£}
 
`
 
2(}S 
T
 ID
EA
+!
 I
 
DI
 i'
S 
B
 T
S
 
j B
I
T
S 
i J
3
1
T
T
'
S
 
B
I
T
S
 
B
I
T
S
 
B
I
T
S 
B
I
T
S
 I
K
I
T
S 
B
I.
I. S
 
€
SI
TS
 
B
I
T
S
 
BI
'T
'S
 
B
I
T
S
 
I d
 S
 
BI
T`
S
A
L
R
E
A
D
Y
DELAYED\64 
C
Y
C
L
I
,
 
S
 
C
O
R
E
 4
 
GC
3k
"-
E`
3 
i 
CO
}7
,_
91
 
C
O
R
 E
O
 
CO
R_
_U
l 
C
O
j
,
2
 
Co
R,
_L
3 
C
O
R
_
L
4
y 
f
 #
~ 
1
1
 i7
 
w
 
t 
y 
~
yr ,
R
X
C
O
R
_
E
4
 
.
X
C
O
 
I;
S 
N
C
O
 
E
2
 
X
C
O
R
—
E
l
 
3{
CO
R-
E0
 
XC
UL
r,
,,
.W
 
X
C
O
R
 L
2
 
X
C 
O
R-
11
3 
K:
~~
id
5—
L4
 )
6
1
5
F
I
G
.
 8
~
I
~
T
E
S
,
 3'
_
 
€
 
S
E
 Q.
 w
a
l
I
 
S
L
I
C
E
 O
U
T
 
I
~
C 
C7
I2
RE
I 
A
 I
C 
°
R
E
P
/ T
E
S
T
 
T
H
E
 S
I
G
N
D
E
P
T
H
 
; 
P
R
O
D
.
 S
I
G
N
 
B
I
T
F
I
F
O 
W
/
 
D
E
L
A
Y
E
D
 
Y
E
D
 
DE
E:
C I
SI
O 
N
 
~
/
 P
R
O
G
R
A
M
,
 
R
E
F
/T
ES
T 
S7
, Q
. (
W
/
O
:
o
D
-
-
-
-
 
D
E
P
I
CH
 
P
R
O
D
U
C
T
 
S
I
G
N
 B
IT
)
° 
IG
N 
Br
l
i
A
.
GG
~
 
-
-
-
-
-
-
-
-
-
-
 
-
 
-
-
-
-
-
-
-
~
M
O
D
.
 T
E
§
;
r
 
D
E
L
A
Y
E
D
 '
 
o
SI
,I
CI
 O
U
T
 
z 
E
 '
I'
 i+
.?
yr
 
S
L
I
C
E
 I
 
S
E
Q
.
 W
I
T
H
 
! 
T
E
S
T
 
 
SO
FT
` 
N
T
D
T
 S
O
F
T
 
T
H
E
 S
IC
st
i 
; 
D
E
S
 I
SI
OI
 
SE
tC
. 
I
H
 
SI
GI
` 
}Z
EI
+/
pT
 
D
E
C
I
S
I
O
N
o
D
E
C
I
S
I
O
N
 S
EC
S.
 
~
 
Iii
.€T
 
Yc
ri
Cx
.€
IT
UD
I~
 
1'
IT
 
PI
2t
~D
. 
S
I
G
N
 
A
D
D
/"
 Z}
s3
' 
S
E
 Q,
 (~
hJ
/{
3 
O~
S
I
G
N
 B
I
0
T
E
S
T
 
T
E
S
T
 S
O
F
 1
 
R
E
P
/ / 
r 
DL
3E
IZ
 
€
 
.
S
E
Q.
 
D
E
C
I
S
I
O
N
T
E
S
T
 
c
S
I
G
N
S
E
Q
.
 
P
R
O
D
 
j 
I,
, 
~CORR.SCORE3IT 
€
GP
I:
 
BI
 I 
 
F
 
~
C
O
O
 
o
13
AC
K 
"
K
)
T
E
S
T
 S
C 
iIa
 
D
E
C
I
S
I
O
N
 S
E
Q,
 M
A
Gi
v 
A
D
D
E
R
 
CORR.------ C
R
E
S
U
L
T
S
 
S
C
O
R
E
}
L
F
L
y-
~
'
~
+
/
~
.
q
{
L
 
R
 
F/
`i
`E
ST
 P
R
O
D
U
C
T
 B
I
T
 
'
 p,
 y
-
~
7~
y 
•
-
~
7---
•*~~- 7
7- 
R.
E 
x
IS
 C
E 
R
 
S
E
S
.
f
E
C
I
7
I
3
~
 
-
-
-
-
 
.. 
A
D
D
/
 S
U
B
 
-
-
-
-
 
-
-
 
-
-
-
-
-
-
 e
V
1
F
I
G.
 9
C
S
I
 R
T
C
O
U
N
T
 C
O
N
S
E
C
L
n
I
V
E
 W
I
N
N
I
N
G
A~
C
O
R
R
.
 S
C
O
R
E
 R
E
S
U
L
T
S
 (
N
U
M
B
E
R
 O
F
 
~
C
O
N
S
E
C
U
T
I
V
E
 W
E
N
N
E
R
S
;
 ->
 N
C~
V)
0
 
N
O
W
 >
=
~
SL
IP
T~
RE
SI
~I
~
t.
~
0
Y
E
S
 
I 
c
~
Y
E
S
 
W
 E
N
N
I
N
G
=
C
O
R
 E
O
0
N
O
Y
E
S
 
W
I
N
N
I
N
G
=
 
N
O
 
S
T
 II
'
-
-
-
-
 
R
E
C
O
V
E
R
Y
X
C
O
R
„
E
O
 
P
R
O
C
E
S
S
O J
F
I
G
,
 1
0
U.S. Patent Sep. 20, 2016 Sheet 12 of 15 US 9,450,747 B1
DETECTION O A SLIP
,ADJUST THE RED` BUFFER THE REQa
NO, OF ELEMENTS TO BRING IT INTO
ALIGNMENT WITH THE BUFFERED
REF SYSTEM
(4 REF CLOC=K PERIODS)
INITIALIZE 'IyI:IE CORRELATION BLOCK
REF DEI..rAY CHAIN
(9 IREF CLOCK PERIODS)
INITIALIZE THE CORRELATORS
(SLIP—RECOVERY—CYCLES NUMBER
OF REF CLOCK PERIODS)
EN
0.
06
0,
05
0,
04
S
C
O
P
E
S
 0
.0
3
0.
02 m
C
O
R
R
.
O
N
 T
I
M
E
 C
O
R
R
.
O
N
 T
I
M
E
 C
O
R
R
.
(E
O)
 IS
(E
O)
 B
E
G
I
N
S
 T
O
(E
O)
 IS
 AGAIN`,7,II
TI
4F
ER
 /
-
-
D
E
C
L
I
N
E
D
U
E
 T
O
 S
IF
T'
T
H
E
 W
I
N
N
E
R
O
N
 T
I
M
E
 C
O
R
_
R
,
(E
O)
 IS
 N
O
 €
 
O
N
G
E
R
T
H
E
 W
I
N
N
E
R
.
.
.
.
.
.
-
-
-
-
-
-
 
-
-
-
O
U
T
P
U
T
 F
R
O
M
 L
l
€
D
R
O
P
S
 D
U
E
 T
O
 C
B
 
j
€
IN
IT
IA
L.
 D
U
R
I
N
G
 
I
T
H
E
 S
L
I
P
 R
E
C
O
V
E
R
Y
O
U
T
P
U
T
 F
R
O
M
 L
l
P
R
O
C
E
S
S
 
I
C
O
R
R
.
 R
I
S
E
S
 D
U
 a
t 
I
3
~
E
7 !
~
e I
9
l
1
I
O
 
4
5
 
3
1
3
3
 
1,
77
i 
22
2
1
 
26
.E
 
3
0
9
1
3
5
0
 
.
39
7 
4
4
1
 
48
t
R
X
 
S
L
I
P
S
A.
 B
I
T
 
S
E
R
E
 
S
L
I
P
 T
H
R
E
S
H
O
L
D
.
A
L
I
G
N
 M
O
D
U
L
E
D
E
C
L
A
R
E
S
 A
'
 L
I
P
P
R
O
C
E
S
S
(4
-x
9 -
SU
.P
-
R
E
C
O
V
E
R
Y
_
-
C
Y
C
L
E
S
)
S
E
 Q
,
 C
O
V
E
T
 (
E
A
C
H
 C
O
U
N
T
 I
S
 O
N
E
 R
E
D
`
 C
L
O
C
K
 C
Y
C
L
E
 I
D
U
R
A
T
I
O
N
)
F
I
G.
 1
2
Q
U
A
D
R
A
N
T
 H
O
N
E
 O
F
 X
C
O
R
 E
4
 T
H
R
U
 X
C
O
R
.
 L
4
 I
S 
W
I
N
N
I
N
G
W
I
N
N
I
N
G
 C
O
R
R
E
L
A
T
I
O
N
 I
S
 P
OS
IT
 n
r
F-
I-
Q+
Q
U
A
D
R
A
N
T
 II
I
J
I
B
E
 O
F
 C
O
R
-
E
4
 T
H
R
U
 C
O
R
-
L
4
 I
S 
W
I
N
N
I
N
G
W
I
N
N
I
N
G
 C
 O
R
R
E
L
A
T
I
O
N
L
 
I
S 
N
E
G
A
T
I
V
E
I-
Q-
Q
U
A
D
R
A
N
T
 1
O
N
E
 O
F
 C
OR
__
 E
4
 T
H
R
U
 C
O
R
-
L
4
 I
S 
W
I
N
N
I
N
G
'
x W
I
N
N
I
N
G
 C
O
R
R
E
L
A
T
I
O
N
 T
S 
POSITIVE1~QT
.
Q
U
A
D
R
A
N
T
I
V
O
N
E
 O
F
 X
C
C
]R
_E
4 `
T`
HR
U 
X
C
 O
R
-
L
4
 I
S 
W
I
N
N
I
N
G
W
I
N
N
I
N
G
 C
O
R
R
E
L
A
T
I
O
N
 I
S 
N
E
G
A
T
I
V
E
14
-Q
-
IG~
 
1
3
1
4
€
6
14
I.
8
1
4
2
8
 —
1
4
 0
L
~
D
E
C
I
 I
O
N
 I
N
P
U
T
P
 
P1
£I
 [
a
]
 1
_
M
.
_
_
 
-
-
-
-
-
-
-
-
 
-
 -
P
 
E
L
I
 1
1
E
 
E
M
 
F
-
 
P
1
 
Pi
k 
<
 
1
4
0
2
Ij 
_
 
1 
[ -
- 1
 
=
 <-
- 
14
€ 
4
 
-
ID
I'
H 
SH
IF
I'
ED
A
 
 
A
 
}
 ~
.
 
1.
40
/1
8
F
R
O
M
 
BI
T 
O
R
D
E
R
 
R
E
P
R
E
S
E
N
 N
T
'
J
O
N
a
 
r
y
w
.
 
D
A
T
A
 
R
 
1
 
C
O
N
E
"F,
 4'
S
I 
PO
L.
~R
IT
'Y
 
pL
 
~
 
O
N
E
 ~
 
C
O
M
P
L
E
'
 E
N
Y
-
-
-
-
-
-
-
-
-
_
-
-
-
-
-
-
 
-
D
E
C
I
S
I
O
N
 O
U
T
P
U
T
-
-
-
-
-
-
-
-
-
-
 
1
4
C
F
"
1
4
1
0
 
1
4
1
2
 
1
4
1
4
-
-
OF
FS
Er
yk
Fl
 
G
 O
F
F
S
E
T
 
S
C
A
L
E
 F
A
C
T
O
R
 
C
L
I
P
 T
O
 
R
E
P
R
E
S
E
N
T
A
T
I
O
N
r
 
/
y
/
 
B
Y
r
 O
R
D
E
I
 
1
4
 0
 
W
I
D
T
H
 
HI
.P
'I
'E
D 
P
 
~
1`
 
 
1
4
?
4
a 
3 
1
4
2
L
 
 
RIGHT16 
1
1
4
3
0
 
1
4
3
2
 
1
4
3
4
 
1
4
3
6
P
I
 1
 
o
 
P9
 
P
3
 `
P
 j
 
, 
~
 
3 
E~
 ]
 <
—
 1
4
3
8
e
 
-
 
1
4
4
0
F
I
G
.
 1
4
US 9,450,747 B1
SOFT DECISION ANALYZER AND METHOD
CROSS REFERENCE TO RELATED
APPLICATIONS
This is a divisional application of application Ser. No.
13/789,903, filed on Mar. 8, 2013.
STATEMENT OF GOVERNMENT INTEREST
The invention described herein was made in the perfor-
mance of work under a contract of the National Aeronautics
and Space Administration (NASA) and is subject to the
provisions of Section 305 of the National Aeronautics and
Space Act of 1958, Public Law 85-568(72 Star. 435; now
codified at 51 U.S.C. §20135). The invention described
herein was also made by employees of the United States
Government and may be manufactured and used by or for
the Government of the United States of America for gov-
ernmental purposes without the payment of any royalties
thereon or therefor.
FIELD OF THE INVENTION
The invention relates generally to soft decision analyzers
and, more particularly, to a soft decision analyzer and
method, which in one embodiment, may be utilized for
analyzing performance of forward error correction (FEC)
techniques and corresponding communication system
devices in real-time actual operating conditions and envi-
ronments.
SUMMARY OF THE INVENTION
In accordance with one embodiment of the present inven-
tion, a soft decision analyzer (SDA) is provided that is
operable for use with (1) Radio Frequency (RF) communi-
cation equipment such as a data source that produces a
reference data stream comprising data and clock, (2) an RE
transmitter that transmits the reference data stream to pro-
duce a transmitted data stream, (3) an RE receiver that
receives the transmitted data stream and produces a test data
stream that may comprise soft decision information and
clock, and (4) a baseband signal processor (BSP) operable to
detect the test data stream.
In another embodiment, an apparatus may comprise a
signal conditioner operable for connecting to the RE
receiver, the baseband signal processor, and the reference
data source. Furthermore, the apparatus may comprise a
correlator operable to detect symbol wise alignment of the
test data stream and/or produce a historical record relating to
the symbol wise alignment, and/or a configuration and
timing control operable to control operation of the signal
conditioner and the correlator. In another embodiment, the
signal conditioner can be operable for bridging electrical
differences between the RE receiver and the baseband signal
processor when the RE receiver and the baseband signal
processor are incompatible with each other.
In another embodiment, the soft decision analyzer may
further comprise a simulator operable to synthetically pro-
duce the test data stream and the reference data stream in a
plurality of different receiver modulation formats without
connection to the data source, the RE transmitter, and/or the
RE receiver. In yet another embodiment, the simulator is
operable to slip the simulated test data stream and the
reference data stream relative to one another in both forward
and reverse directions by a selectable number of symbols.
N
In yet another embodiment, the signal conditioner is
operable to format a plurality of different RE receiver
outputs into an internal soft decision analyzer conditioned
format, which comprises the test data stream and the refer-
5 ence data stream. The signal conditioner may further com-
prise an input scaler operable to accept soft decision data
expressed in a plurality of different mathematical represen-
tations for conversion to an internal soft decision analyzer
mathematical representation of soft decision data.
10 In another embodiment, the signal conditioner further
comprises an output scaler operable to convert the internal
soft decision analyzer mathematical representation of soft
decision data to a selectable mathematical format consistent
with that of different types of baseband signal processors. In
15 yet a further embodiment, the signal conditioner is under
control of the configuration and timing control and is
operable to remap inputs to account for cables with wiring
errors. In yet a further embodiment, at least a portion of the
signal conditioner and the correlator are implemented in
20 programmable hardware. A control interface is provided
which can be utilized for this purpose as well as others.
In yet another possible embodiment, the soft decision
analyzer is operable for use with a reference data stream that
is not limited to a predetermined sequence of data and
25 wherein the test data stream is suitable for detection by the
baseband signal processor when the baseband signal pro-
cessor employs a forward error correction (FEC) technique.
The invention may further comprise a simulated data source
being operable to produce signals representative of a plu-
3o rality of different types of RE receivers.
In another embodiment, a correlator which receives a
conditioned format or stream comprising the test data stream
and the reference data stream is operable for detecting
symbol wise alignment between the test data stream and the
35 reference stream and for producing an output for adjusting
the timing between the test data stream and the reference
data stream. The correlator may comprise a bank of indi-
vidual correlators that operate together. Also, the correlator
may compare respective outputs of the bank of correlators to
40 produce a winning correlation result for detecting the sym-
bol wise alignment.
In another embodiment, the soft decision analyzer may
comprise a slip alignment block that provides feedback for
adjusting a symbol wise timing between the test data stream
45 and the reference data stream. In one possible embodiment,
a statistical portion is operable to collect statistical data of
slips and rotations in the test data stream.
The soft decision analyzer may further comprise a slip
alignment block that produces slip statistical data and a
50 clock phase detector that produces clock edge-based slip
performance data. In one embodiment, a bit error detection
block receives the correlated reference data and the corre-
lated test data to produce hard decision bit error performance
data.
55 The soft decision analyzer may comprise a test stream
buffer and a reference stream buffer operable to provide a
first-in, first-out buffering action to isolate an output of the
stream buffer and an output of the reference stream buffer
from instantaneous data rate slipping between the test data
60 stream and the reference data stream. In this embodiment, at
least one of the test stream buffer and the reference stream
buffer is operable to bring the test stream and the reference
stream into symbol wise alignment.
In accordance with another embodiment, a method for
65 operating a soft decision analyzer is provided. The method
may comprise providing a signal conditioner operable for
connecting to a RE receiver, a baseband signal processor,
US 9,450,747 B1
3
and/or a data source. Furthermore, the method may comprise
detecting symbol wise alignment of a reference data stream
and producing a historical record relating to the symbol wise
alignment.
In another possible embodiment, the method may com-
prise providing a bridge between the RE receiver and the
baseband signal processor when the RE receiver and the
baseband signal processor are incompatible with each other.
The method may further comprise synthetically produc-
ing the test data stream and the reference data stream in a
plurality of different receiver modulation formats without
connection to the data source, the RE transmitter, and/or the
RE receiver.
In one embodiment, the method may comprise slipping
the test data stream and the reference data stream relative to
one another in both forward and reverse directions by a
selectable number of symbols.
In yet another embodiment, the method may comprise
providing a signal conditioner that is operable to format a
plurality of different RE receiver outputs into an internal soft
decision analyzer conditioned format, which comprises a
test data stream and a reference data stream. The method
may further comprise accepting soft decision data expressed
in a plurality of different mathematical representations for
conversion to an internal soft decision analyzer mathemati-
cal representation of the soft decision data.
In another embodiment, the method may comprise con-
verting the internal soft decision analyzer mathematical
representation of soft decision data to a selectable math-
ematical format consistent with that of different types of the
baseband signal processor. In a further embodiment, the
method may comprise remapping inputs to account for
cables with wiring errors. In yet a further embodiment, at
least a portion of the signal conditioner and the correlator are
implemented in programmable hardware.
In yet another embodiment, a method may comprise
providing a soft decision analyzer that is operable for use
with a reference data stream that is not limited to a prede-
termined sequence of data and wherein a test data stream is
suitable for detection by a baseband signal processor when
the baseband signal processor employs a forward error
correction technique. The method may further comprise
providing a simulated data source operable to produce
signals representative of a plurality of different types of RE
receivers.
In another embodiment, the method may comprise receiv-
ing a conditioned format or stream comprising the test data
stream and the reference data stream of the correlator and
detecting symbol wise alignment between the test data
stream and the reference stream. Other steps comprise
producing an output for adjusting the timing between the test
data stream and the reference data stream. The method may
comprise comparing respective outputs of a bank of corr-
elators to produce a winning correlation result for detecting
symbol wise alignment.
The method may further comprise adjusting a symbol
wise timing between the test data stream and the reference
data stream. In one possible embodiment, the method steps
include collecting statistical data of slips and rotations in the
test data stream.
In another embodiment, the method may comprise pro-
ducing slip statistical data and/or producing clock edge-
based slip performance data. The method may further com-
prise receiving the correlated reference data and the
correlated test data to produce hard decision bit error per-
formance data.
4
The method may further comprise providing a first-in,
first-out buffering action to isolate an output of the data
stream buffer and an output of the reference stream buffer
from instantaneous data rate slipping between the test data
5 stream and the reference data stream. At least one of the test
stream buffer and the reference stream buffer may be pro-
vided, in which each buffer is operable to bring the test
stream and the reference stream, respectively, into symbol
wise alignment. The method may also comprise detecting
10 
channel swapped conditions for quadrature phase shift
keyed (QPSK) systems and adjusting for the occurrence of
a QPSK channel swapped condition.
BRIEF DESCRIPTION OF THE DRAWINGS
15
A more complete understanding of the embodiments
described herein and many of the attendant advantages
thereto will be readily appreciated as the same becomes
20 better understood by reference to the following detailed
description when considered in conjunction with the accom-
panying drawings, wherein:
FIG. 1 is a flow diagram depicting top-level components
of a soft decision analyzer (SDA) in accord with one
25 possible embodiment of the present invention.
FIG. 2 is a top level diagram of the flow of data in
exemplary firmware of the soft decision analyzer.
FIG. 3 is a flow diagram of data within an input data
stream conditioning block of the SDA firmware represented
30 in FIG. 2.
FIG. 4A is a flow diagram of data within a measurement
of statistical characteristics block of the SDA firmware
represented in FIG. 2.
FIG. 4B is a companion flow diagram of data in the
35 
measurement of statistical characteristics block depicted in
FIG. 4A.
FIG. 5 is a diagram of possible TEST stream soft decision
data sign bit polarity assignments in a staggered quadrature
40 phase shift keyed (SQPSK) communication system in
accord with an embodiment described herein.
FIG. 6 is a diagram of possible TEST stream soft decision
data sign bit polarity assignments and channel swaps in a
quadrature phase shift key (QPSK) communication system
45 in accord with one possible embodiment described herein.
FIG. 7 is a histogram depicting soft decision data values
in accord with one possible embodiment described herein.
FIG. 8 is a block diagram of the correlator bank block
portion of the soft decision analyzer in accord with one
50 possible embodiment.
FIG. 9 is a block diagram of a single correlator in the
correlator bank block portion of the soft decision analyzer in
accord with one possible embodiment herein.
FIG. 10 is a diagram depicting the slip recovery process
55 of the firmware of the soft decision analyzer firmware in
accord with one possible embodiment described herein.
FIG. 11 is another diagram depicting the steps involved in
the slip recovery process of the firmware of the soft decision
analyzer in accord with another embodiment herein.
60 FIG. 12 is a diagram depicting representative output of the
firmware of the soft decision analyzer in accord with another
embodiment.
FIG. 13 is a diagram depicting a SQPSK rotational
constellation mapped to SDA correlators in accord with one
65 possible embodiment.
FIG. 14 is a schematic showing an interface utilized to
map test data soft decision signals to an internal SDA
US 9,450,747 B1
5
representation and to map the internal SDA representation to
the output representation in accord with an embodiment of
the invention.
The above general description and the following detailed
description are merely illustrative of the generic invention,
and additional modes, advantages, and particulars of this
invention will be readily suggested to those skilled in the art
without departing from the spirit and scope of the invention.
DETAILED DESCRIPTION OF EXEMPLARY
EMBODIMENTS
Detailed descriptions of exemplary embodiments are pro-
vided herein. It is to be understood, however, that the present
invention may be embodied in various forms. Therefore,
specific details disclosed herein are not to be interpreted as
limiting, but rather as a basis for the claims and as a
representative basis for teaching one skilled in the art to
employ the embodiments described herein in virtually any
appropriately detailed system, structure or manner.
Soft Decision Analyzer 100, also referred to herein as
"SDA", is a hardware, firmware, and software system which
provides the capabilities to perform real time closed loop
statistical analysis of the performance of single-channel or
dual-channel serial digital radio frequency (RF) communi-
cations systems for a variety of operating conditions. In at
least one embodiment described herein, "soft decision data"
is comprised of a digital sign bit and soft decision level bits
that provide an indication on how confident an RE receiver
categorized the digital sign bit as a "1" or a 11011.
Turning now to the drawings, and more particularly FIG.
1, a schematic diagram of a system comprising a soft
decision analyzer is shown in accord with one possible
embodiment of the present invention. Soft Decision Ana-
lyzer 100 is used in testing and development of soft deci-
sion-based communications systems and can be used in a
variety of useful configurations. FIG. 1 depicts a top level
illustration of components of SDA 100 in relation to exem-
plary external devices which SDA 100 is intended to test.
The representative external devices of a RE communications
system comprise Data Source 105, RE transmitter 110, RE
receiver 115 and baseband signal processor (BSP) 120,
shown in FIG. 1 in a general configuration as the devices
under test, or "DUT", and in its relation to components of
SDA 100.
Alternative configurations are available depending on
whether the test activities are focused solely on RE receiver
115, focused solely on BSP 120, or focused on the combined
interaction between RE receiver 115 and BSP 120. RE
transmitter 110, RE channel 111, and RE receiver 115 are
usually a common source of signal quality issues like
inter-symbol interference and cross-channel interference.
Furthermore, SDA 100 is not limited to soft decision com-
munication systems, as there are alternative configurations
wherein SDA 100 may prove useful, such as with hard
decision devices under test.
As shown in FIG. 1, data source 105 supplies a reference
data stream 106 with content suitably composed for inter-
pretation by BSP 120. Reference data stream 106 may be
hereinafter also referred to as the "REF data stream", "REF
stream", "REF sequence" or simply "REF" depending on
context. Reference data stream 106 is comprised of both data
and clock digital signals. Identical copies of REF Stream
106 are routed to both RE transmitter 110 and a signal
conditioning hardware 200. RE transmitter 110 transmits
REF data stream 106 to RE receiver 115 via RE channel 111.
RE receiver 115 also recovers TEST data stream 112, which
T
is related to REF data stream 106, but may include signifi-
cant alterations in characteristics and content due to data
corruption caused by characteristics of RE channel 111 and
performance of RE receiver 115. Test data stream 112 may
5 include digital soft decision data comprising a plurality of
symbols including a sign bit and magnitude. Like REF data
stream 106, TEST data stream includes associated digital
clock signals. Hereinafter, test data stream 112 may also be
referred to as "TEST data stream", "TEST stream". "TEST
io sequence" or simply "TEST" depending on the context. The
data streams are not limited to any particular sequence of
data, such as repeating or canned data streams.
FIG. 7 illustrates a soft decision data plot in a histogram
format based on a fixed number of soft decision samples. In
15 our example, a three bit soft decision binary value as
expressed in a sign magnitude format has the form of
"SMM", where "S" is the sign bit and "MM" is the mag-
nitude. The higher the soft decision magnitude, the greater
the perceived confidence the receiver assigned to the sign bit
20 of a TEST symbol. Depending on the sign convention, the
plot may then also be further away from the center of the
graph. Accordingly, output from a receiver under test in a
soft decision system distinguishes between a symbol iden-
tified as a zero with a high degree of confidence and a zero
25 so identified with a low degree of confidence. Similarly, a
receiver in a soft decision system distinguishes between a
symbol identified as a one identified with a high degree of
confidence and a one with a low degree of confidence.
When discussing SDA 100, one should understand TEST
so data stream 112 is a degraded, time delayed version of REF
data stream 106. As discussed hereinbefore, TEST stream
112 and REF streams 106 are typically derived from com-
ponents configured as shown in FIG. 1. Sources that con-
tribute to the delay between the REF and TEST streams
35 include the processing time for RE transmitter 110, process-
ing time for RE receiver 115, and time for RE channel 111
to transmit data between transmitter and receiver. Degrada-
tion of TEST data stream 112 is primarily related to channel
conditions and the way internal electronics of receiver 115
40 interact with channel conditions. Receivers can make errors
when creating TEST data stream 112 of soft decision data.
Typically the errors are due to receiver 115 coping with RE
channel conditions. An error in this context is defined as
when the sign bit of the soft decision TEST stream is not
45 contextually in agreement with the associated hard decision
sign bit of REF stream 106.
The need for electrical signal conversion between elec-
trically incompatible receivers and baseband signal proces-
sors is driven by early investigations of communications
50 systems. Early conceptualization and early testing can sig-
nificantly assist in reduced nonrecurring costs of systems
derived from pre-existing equipment designs. Signal condi-
tioning hardware 200 provides for several aspects of inter-
facing such incompatible devices under test and allows for
55 preliminary investigations of combinations of receiver 115
and/or baseband signal processor 120 without expending the
cost to develop a completed system.
The evaluation of the two streams of data against one
another is meaningful when the two streams align in time
6o and have an understood polarity relationship regarding the
sign bit. Several factors affect the timing relationship
between the two streams. First, test data stream 112 and
reference data stream 106 follow different physical data
paths and subsequently arrive at SDA 100 with an arbitrary
65 timing relationship, i.e., they are asynchronous. Second, the
timing between the two streams changes based on the
motion of RE transmitter 110 relative to receiver 115. Third,
US 9,450,747 B1
7
the bit sync process of receiver 115 can make mistakes and
insert additional symbols or delete symbols in TEST data
stream 112, typically due to low signal to noise conditions
at the input of receiver 115 under test.
The insertion or deletion of symbols by receiver 115 is 5
known as a "slip." The fourth factor that affects stream
alignment is related to jitter performance of all the elements
that lead up to SDA 100. For example, the digital clocks
within the transmitter 110 are not the same as the digital
clock in receiver 115 and will drift relative to one another. l0
Even receivers that coherently lock their internal clock to a
transmitter's carrier frequency have tracking loops that will
on average keep the clock rates the same. However, instan-
taneously the phases between the transmitted and received 15
streams can vary by significant fractions of a symbol period
that can affect the timing relationship between the TEST and
REF streams as seen by any equipment downstream of
receiver 115, i.e. signal conditioning hardware 200 or BSP
120. 20
In one embodiment, signal conditioning hardware 200 is
a system of one or more printed circuit boards (PCBs) that
work together to bridge potentially incompatible digital
electronic interface families between all potential devices
under test to SDA 100. Thus, signal conditioning hardware 25
200 can provide for the adaptation of incompatible digital
electronic formats and can provide a means to interface RE
receiver 115 with baseband signal processor 120 even if
their digital logic interfaces are incompatible. In addition,
signal conditioning hardware 200 provides a single digital 30
interface family to and from field programmable gate array
(FPGA) input/output (I/O) pins hosted on FPGA card 130 As
discussed in more detail hereinafter, the signal conditioning
hardware 200 buffers and copies input TEST data stream
112, REF data stream 106, and analyzed and scaled test data 35
stream 113, as well as miscellaneous signals used to expose
internal operation of SDA firmware 300 at test points
suitable for monitoring by additional equipment often used
in testing communication systems, such as oscilloscopes and
logic analyzers. 40
Complicating the determination of stream alignment
between TEST data stream 112 and reference data stream
106 are issues related to receiver 115 assignment of sign bit
polarity to TEST data stream 112, which is an issue for both
staggered quadrature phase shift keying (SQPSK) and 45
quadrature phase shift keying (QPSK) type receivers. When
either of these receivers locks to its respective carrier,
receiver 115 makes a polarity sense assignment to the soft
decision sign bit. Additionally, in a QPSK system, receiver
115 makes a channel assignment. 50
Referring now to FIGS. 5 and 6, possible outcomes for the
above described sign bit polarity and channel assignments
are depicted. FIG. 5 depicts all possible test stream soft
decision sign bit polarity assignments for a staggered
quadrature phase shift keyed, or SQPSK, receiver. In 55
Example (1), all soft decision sign bit polarity matches REF
stream. Thus, all soft decision sign bits in the multiplexed
TEST stream are the same polarity sense as the REF stream.
The second example illustrates the situation where the
polarity sense of the I Channel soft decision sign bits is 60
inverted. Therefore, every other soft decision sign bit is
inverted in the multiplexed TEST stream. The third example
illustrates the situation where the polarity sense of the Q
Channel soft decision sign bits is inverted. Thus, every other
soft decision sign bit, opposite of Example (2) above, is 65
inverted in the multiplexed TEST stream. Finally, the fourth
example depicts all soft decision sign bits as inverted. Thus,
8
all polarity senses of the soft decision sign bits of the
multiplexed TEST stream are inverted to that of the REF
stream in Example (4).
Turning now to FIG. 6, a number of possible test stream
soft decision sign bit polarity assignments and channel
swaps for a quadrature phase shift keyed, or QPSK, receiver
is shown. Example (1) illustrates the situation of no channel
swapping or inverted polarity, i.e., the soft decision sign bit
polarity matches the REF stream. Thus, all soft decision sign
bits in the multiplexed TEST stream have the same polarity
sense as that of the REF stream. The second example
represents no channel swapping, but the polarity sense of the
I Channel soft decision sign bits is inverted. This situation
means every other soft decision sign bit is inverted in the
multiplexed TEST stream. The third example represents a
TEST stream with no channel swapping, but the polarity
sense of the Q Channel soft decision sign bits is inverted.
Thus, every other soft decision sign bit, opposite of Example
(2) above, is inverted in the multiplexed TEST stream. The
fourth example also contains no channel swapping. How-
ever, all soft decision sign bits are inverted. Therefore, all
polarity senses of the soft decision sign bits of the multi-
plexed TEST stream are inverted to that of the REF stream
in Example (4).
Still referring to FIG. 6, Example (5) depicts the situation
where the soft decision sign bit polarity matches the REF
sequence, but channel swapping has occurred. Thus, all soft
decision sign bits in the multiplexed TEST stream have the
same polarity sense to that of the REF stream. The sixth
example depicts inverted I channel soft decision sign bits
polarity sense and channel swapping. Thus, every other soft
decision sign bit is inverted in the multiplexed TEST stream.
Example (7) illustrates the situation where the polarity sense
of the Q Channel soft decision sign bits is inverted and
channel swapping has taken place. Thus, every other soft
decision sign bit, with respect to the preceding Example (6),
is inverted in the multiplexed TEST stream. The final
example illustrates channel swapping, as well as all soft
decision sign bits being inverted. Therefore, all polarity
senses of the soft decision sign bits of the multiplexed TEST
stream are inverted to that of the REF stream in Example (8).
After receiver 115 locks to the transmitted carrier fre-
quency and makes the initial assignment of polarity sense of
the soft decision sign bit data and the channel assignment,
perturbations to internal carrier tracking algorithms of
receiver 115, generally due to low signal to noise conditions
at the input of the receiver under test, can cause receiver 115
to spontaneously alter sign bit data polarity assignment or
assignment of channel data of TEST data stream 112, such
as in the case of a QPSK receiver. Such spontaneous
reassignments are known as "constellation rotations" or
simply "rotations." SDA 100 provides the capacity to adjust
for these dynamic rotations and channel swap phenomenon
during routine operation.
Referring again to FIG. 1, SDA firmware 300 represents
a digital design that is hosted within a commercially avail-
able (i.e., vendor-provided) field programmable gate array
(FPGA) card 130. Data path A 116, data path B 117, data
path C and data path D of FIGS. 1 and 2 depict the
interaction and flow of data between hardware 200, firmware
300, and software 400 segments of SDA system 100. In FIG.
2, a Peripheral Component Interconnect (PCI) bus interface
302 is depicted to show the design of SDA 100 in this
embodiment. The purpose of PCI Bus Interface 302 is to
manage the flow of information between SDA software 400
US 9,450,747 B1
I
and SDA firmware 300, although other embodiments could
use a number of differing technologies to provide an equiva-
lent interface.
As given in the embodiment of FIG. 2, characteristics of
SDA firmware 300 are shown implemented within the
blocks depicted in FIG. 2 and include input data stream
conditioning block 500, configuration and timing control
block 303, and correlation and measurement of statistical
characteristics block 600. The vendor-provided PCI bus
interface 302 is an optional portion of this embodiment of
SDA 100. In an alternative embodiment, functions expressed
in the firmware 300 of SDA 100 could be performed by a
specific vendor's FPGA or a specific vendor-purchased
FPGA card, thus permitting the vendor provided PCI bus
interface 302 to be removed from SDA 100. The function of
vendor purchased FPGA card 130 is to host focused devel-
opment of SDA firmware 300 design and to facilitate
operation with hosting workstation 125 of FIG. 1. Commer-
cially available vendor provided FPGA card 130 facilitates
exchange of data between SDA firmware 300 and SDA
software application 400 as depicted by data path C and data
path D. Drivers are also provided as indicated at block 135.
Data path C also represents an aggregate of statistical
performance data 126 determined by an analysis function of
SDA firmware 300 and is used to drive further software
analysis, provide information to software graphical displays,
and provide status information regarding internal operation
of SDA firmware 300. Data path D 141 also represents an
aggregate flow of signals 141 under control of SDA software
application 400 used to configure and control operation of
SDA firmware 300. The configuration and control aggregate
141 of data path D is discussed in further detail below.
Input data stream conditioning block 500 processes the
asynchronous TEST data stream 112 and REF data stream
106, or data path A 116, to a digital format, which includes
timing characteristics. Further, this digital format is com-
patible with the statistical analysis performed by the corre-
lation and measurement of statistical characteristics block
600 and to a format compatible with use of the data by data
path B 117 and data path E 119. In this embodiment,
asynchronous TEST data stream represents up to 12 bits of
soft decision data that can be delivered to SDA 100 based on
a variety of different timing and signaling schemes associ-
ated with binary phase shift keying (BPSK), quadrature
phase shift keying (QPSK) or staggered QPSK (SQPSK)
modulation for both data path A 116 and data path B 117.
Data path B 117 represents processed, analyzed and
scaled test data stream 113 sent to signal conditioning
hardware 200 where it is electrically converted to signals
compatible with the input format of baseband signal pro-
cessor 120. In addition, data path B 117 comprises a number
of miscellaneous signals used to expose internal operation of
SDA firmware 300 to test points suitable for monitoring with
oscilloscopes and logic analyzers.
Turning now to FIG. 3, elements associated with possible
embodiments of input data stream conditioning block 500
are illustrated. Input data stream conditioning block 500 can
provide SDA 100 with a number of well integrated capa-
bilities when working with a soft decision data stream in a
single piece of test equipment. In one embodiment, input
data stream conditioning block 500 can bridge between
incompatible receiver 115 and baseband processor 120
equipment combinations in a testing environment. In one
embodiment, block 500 can apply synthetic RE channel soft
decision characteristics to digital data source 105 for evalu-
ating performance of baseband signal processor 120 without
use of RE receiver 115. Input data stream conditioning block
10
500 can also be used to format a multitude of different
receiver output formats, such as BPSK, QPSK and SQPSK
discussed hereinbefore, into a conditioned single unified
format or conditioned stream 118 for statistical analysis by
5 correlation and measurement of statistical characteristics
block 600 (see FIG. 413).
Continuing with FIG. 3, in one embodiment simulated
data source or "simulator" 510 is a resource internal to SDA
100 utilized to provide a simulated TEST data stream and
io simulated REF data stream 511. Simulator 510 can be used
to supply an internally generated source of simulated TEST
stream data and REF stream data that exercises a majority of
SDA 100 features without having to configure SDA 100 with
external test elements. Via configuration of data path D 141,
15 simulator 510 generates many different formats of test data
simulating the attachment of BPSK, QPSK or SQPSK type
RE receivers. Thus, SDA 100 may be operated without data
source 105, RE transmitter 110, RE receiver 115 or baseband
signal processor 120 as shown in FIG. 1. This block can be
20 used via data path D 141 to slip the simulated REF and
TEST streams relative to one another in both forward or
reverse directions a selectable or an arbitrary number of
symbols and is used as one method to demonstrate and
verify the ability of SDA 100 to track receiver induced
25 symbol slips. In conjunction with synthetic channel and
scale block 540, means are provided to develop associated
SDA firmware 300 and SDA software 400 without SDA 100
being configured in a complete test configuration.
Process raw input block 520 can provide three functions
30 for operation of the present embodiment. First, block 520
synchronizes both the real asynchronous TEST and REF
data streams, or data path A, and the simulated asynchronous
TEST and REF data streams, data path B, to the SDA's
internal system clock. In doing so, protection is provided
35 against metastability conditions that would interfere with the
remainder of SDA firmware 300. The second function is to
provide a means via data path D 141 to select either the
simulated data streams 511 or data streams from a device
under test, data path A 116, to a multiplex AB streams block
4o 530 via data path 521. Finally, process raw input block 520
provides the ability to correct for data inversions present on
any soft decision bits, clocks and flags associated with TEST
data streams 112 and REF data streams 106 at an electrical
signaling level.
45 Multiplex AB streams block 530 can perform two func-
tions. Block 530 converts both REF stream 106 and TEST
stream 112 from specific timing formats associated with
BPSK, QPSK or SQPSK data sources to a format compat-
ible with the internal timing format of SDA 100. This
50 functionality makes it possible to pass TEST stream soft
decision data 531 and REF stream soft decision data 532 to
other firmware blocks that perform statistical analysis on the
stream data regardless of the originating data source. Spe-
cifically, this block allows SDA 100 to accommodate RE
55 receivers 115 that utilize BPSK, QPSK or SQPSK modula-
tion. The second function block 530 provides is to acquire
and direct a sampled copy of the REF and TEST data
streams 533 to a clock phase detector block 630. Clock
phase detector block 630 provides one of the two methods
60 SDA 100 utilizes to track receiver symbol slip performance.
Synthetic channel and scale block 540 can provide three
functions: (1) input scaling; (2) output scaling; and (3)
synthetic channel substitution. These functions of block 540
allow SDA 100 to cope with dynamically changing devices
65 under test, which is typical of a prototyping environment.
These functions also handle errors and incompatibilities in
signaling between devices under test because all devices
US 9,450,747 B1
11
have some technical issues. Block 540 also serves as a
translator to allow for the interface and testing of normally
incompatible combinations of RE receiver 115 and baseband
signal processor 120. Block 540 primarily deals with the
mathematical representation of the soft decision data and 5
does not concern itself with external timing issues present at
the inputs and outputs of SDA 100. Digital clock and timing
issues are handled by multiplex AB streams block 530 and
scale and sync test data output block 550.
Input scaling by block 540 allows for SDA 100 to io
interface its internal soft decision data paths with any
arbitrary mapping provided by receiver 115 without re-
cabling the setup of the device(s) under test. Block 540 thus
allows for SDA 100 to be flexible in its ability to cope with
receivers and their associated cabling that may have wiring 15
errors. The ability of SDA 100 to remap soft decision digital
inputs provides a means for rapidly remapping the errant
soft decision bits to a useable interpretation and for imme-
diately continuing the testing instead of waiting for a lengthy
time to correct for errors of this nature. In addition, the input 20
scaling function provides a means for SDA 100 to accept
soft decision data expressed in a mathematical two's
complement, one's complement, sign magnitude or other
variations to the internal mathematical representation of
SDA 100. Converting the TEST Stream 112 soft decision's 25
mathematical representation to an internally consistent
mathematical representation of SDA 100 facilitates the
further analysis by other elements. Input scaling can be
accomplished by configuration via data path D 141 and is
under the control of SDA software application 400. 30
Output scaling maps the internal mathematical represen-
tation of the TEST stream soft decision data 531, performed
by the SDA 100, back to a mathematical format consistent
with the logic technology of baseband signal processor 120.
Typical mathematical representations of the soft decision 35
data expected by baseband signal processors 120 are as a
one's complement, a two's complement, or a sign magnitude
digital value. Thus, the combined use of input scaling and
output scaling within SDA 100 allows for bringing normally
incompatible combinations of RE receiver and baseband 40
signal processor together for testing. For example, RE
receiver 115 with a soft decision width of 6 bits and with soft
decision values expressed in a one's complement format can
be made compatible with a baseband signal processor 120
having a soft decision width of 12 bits with soft decision 45
values expressed in a sign magnitude. Output scaling can
also be utilized to rapidly, arbitrarily map soft decision
digital outputs to a baseband signal processor without
changing the physical test configuration. Output scaling can
be accomplished by a configuration utilizing data path D 141 50
under the control of SDA software application 400.
Synthetic channel substitution provides a way to alter
TEST stream soft decision data 531 characteristics to base-
band signal processor 120. A primary function is to provide
a way to simulate differing RE channel 111 conditions as a 55
soft decision symbol error generator to quickly test baseband
signal processor 120 without actually having to utilize an RE
transmitter/receiver pair. In addition, the soft decision syn-
thetic channel substitution provides a means to test and
verify, in a repeatable way, internal analysis elements that 60
are a part of SDA 100. In one embodiment, all synthetic
channel substitution can be accomplished by configuration
via data path D 141 under the control of SDA software
application 400.
Scale and sync test data output block 550 provides a 65
means to convert a scaled TEST data stream 541 with
internal timing of SDA 100 to data path B 117 having digital
12
timing characteristics as if it were originating from a BPSK,
QPSK or SQPSK receiver. Block 550 selectively mimics the
digital timing characteristics of a BPSK, QPSK or SQPSK
receiver as directed via SDA software 400 through data path
D 141. Block 550 along with multiplex AB streams block
530 provides a way to match the digital timing associated
with TEST data streams 112 even for a normally incompat-
ible combination of RE receiver 115 and BSP 120. For
example, a RE receiver 115 that utilizes a BPSK modulation
scheme can be paired with a BSP 120 that is designed to
interface to a QPSK receiver.
Referring now to FIGS. 4A and 413, firmware elements of
the measurement of statistical characteristics block 600 are
depicted. Block 600 aligns TEST stream 112 and REF data
stream 106 through a process of soft decision correlation
analysis and feedback. In addition, once TEST and REF data
streams are aligned, block 600 categorizes and collects
statistical information regarding the behavior of the primary
device under test. The resultant collection of statistical
information is passed to SDA software 400 via data path C
126, where it is further processed and logged as published
statistical results 140 along with an accompanying historical
record 145 of detectable events as shown in FIG. 1.
A SLIP detection, tracking and alignment feedback and
control loop 628 of block 600 can be comprised of the
following elements: a TEST stream timing alignment buffer
block 605; a REF stream timing dynamic alignment buffer
block 625; a correlator bank block 610; a correlator analysis
block 615; a slip alignment analysis block 620; and a slip
alignment feedback 626 data path. The feedback and control
loop 628 that is formed by these elements drives "symbol
wise alignment" of TEST stream 112 and REF data stream
106 by dynamically adjusting the depth of the buffering
provided by the REF stream timing dynamic alignment
buffer block 625. As used herein. "symbol wise alignment"
refers to the measurable condition of a timing alignment
between the TEST stream 112 and the REF stream 106.
However, once such "symbol wise alignment" is measured,
the term symbol wise alignment may also be used herein to
refer to the act of bringing the timing of the TEST stream
112 and the REF stream 106 into alignment or "synchroni-
zation" with one another. In one embodiment, for every
symbol that makes up the REF Stream 106, slip alignment
analysis block 620 continuously monitors for an alternative
depth of the REF stream timing dynamic alignment buffer
block 625 that would bring the symbols of REF Stream 106
of into better agreement with the symbols of TEST Stream
112. Once TEST Stream 112 and REF Stream 106 are
"synchronized", i.e., in "symbol wise alignment", they are
designated as being correlated with one another. Details
concerning elements that make up this feedback and control
loop 628 are discussed in greater detail hereinafter.
TEST stream timing alignment buffer block 605 and REF
stream timing dynamic alignment buffer block 625 together
provide an adjustable depth buffer that can be configured via
data path D 141. The timing alignment buffer blocks per-
form a first-in, first-out (FIFO) buffering action that can
accommodate both jitter in the timing of TEST Stream 112
due to receiver symbol synchronizer performance and data
rate changes that may be due to Doppler shifts should some
of the elements in the RE path be in sufficient motion to alter
the average data rate of TEST Stream 112, thereby avoiding
discontinuities in data flow. Overall, the TEST and REF data
streams will maintain the same average data rate. However,
during receiver slips, the instantaneous data rates between
the REF and TEST stream jump. FIFO action isolates the
US 9,450,747 B1
13
remaining firmware from the timing inconsistencies intro-
duced by slips of receiver 115.
The REF stream timing dynamic alignment buffer block
625 works alongside TEST stream timing alignment buffer
block 605 to bring TEST and REF symbol streams into
agreement and essentially functions as a dynamically adjust-
able, depth FIFO buffer. One of the purposes of the REF
stream timing dynamic alignment buffer block 625 is to
account for differences in latency between the data trans-
mitted directly from data source 105 to SDA 100 versus data
from data source 105 which passes through the RE trans-
mitter 110 and receiver 115 to SDA 100.
Once correlation has been achieved between TEST stream
112 and the REF stream 106, changes to the alignment due
to receiver symbol slips are accounted for in REF stream
timing dynamic alignment buffer block 625 by either
increasing or decreasing the depth of the FIFO of block 625
by the number of symbols indicated by slip alignment
feedback 626. Similar to other firmware blocks described
herein, the overarching behavior of REF stream timing
dynamic alignment buffer block 625 is controlled via data
path D 141 by SDA software application 400.
In order to understand the system of multiple correlators
of correlator bank block 610, it is first useful to understand
the individual behavior of a single soft decision correlator as
implemented within SDA 100. Thereafter, the description of
the system of soft decision correlators will follow with a
discussion of correlator bank block 610. As a part of the
discussion, note the assumption that the data content of REF
stream 106 is sufficiently random to support operation of
SDA 100.
As discussed herein, a soft decision correlation process
provides a measure of how well REF stream 106 and TEST
stream 112 match. The process itself combines the hard
decision REF stream 106 and the soft decision TEST stream
112 into a sequence of soft decision correlation scores. For
every REF and TEST symbol pair ingested by a single soft
decision correlator, the soft decision correlation process
generates a single soft decision correlation score. The mag-
nitude of the score indicates how well the sequences match.
High absolute values indicate a higher degree of correlation
between the streams, i.e. the sign bits between the streams
are related to one another. Absolute values of correlation
scores that are closer to zero indicate a low degree of
correlation, i.e., the sign bits between the streams are
random in relationship to one another. When REF stream
106 and TEST stream 112 are correlated, the sign of the
correlation score indicates whether the polarity sense of REF
stream 106 matches the polarity sense of TEST stream 112
or in the alternative, whether they are exactly opposite.
To examine exactly what SDA 100 is doing during the
correlation process, a review of the equations powering the
process will be discussed. Equation I represents a probabil-
ity weighted sum-of-products correlation technique and
describes implementation of the soft decision correlation
process of SDA 100. In Equation 1, TEST data stream 112
is represented by a sequence t(n). Similarly, REF stream 106
is represented by the sequence r(n). The sequence c(n)
represents the sequence of correlation scores generated by
the correlation process. The value N is the window over
which the correlation process is evaluated and is represented
by the "correlation depth parameter" in the design of SDA
100. Reference is made to the following correlator equation
as COR:
14
N-1 Equation 1 (Eql)
c(n) _ Y. t(n - k)r(n - k)
k=0
Given the sequence of three bit soft decision data t(n)
shown below (decisions are expressed in sign/magnitude
convention where the "+" and "-" indicates the status of the
sign bit), an example calculation of the soft decision corre-
10 lation score is performed. For purposes of the example, let
the correlation depth be set to 5 (N=5). This depth is an
atypically small correlation window, but it will reduce the
amount of math in the example for easier understanding. In
15 the following example, the TEST sequence is time aligned
with the REF sequence.
+0, for n < 0
20 
nn) 
- 
1+2, +1, -3, +3, -1, +2, +0, -0, -2, +3, -2, ... }, for n>- 0
+0, for n < 0
r(n) 
_ { 1+1, +1, -1, +1, -1, +1, +1, -1, -1, +1, -1, ... }, for n >- 0
c(0) _ (+2 + 1) + (+0 * +0) + (+0 +0) + (+0 +0) + (+0 +0)
25 c(1)=(+1 + 1) + (+2* +1) + (+0 +0)+(+0 +0)+(+0 +0)
c(2) _ (-3 * -1) + (+1 * +1) + (+2 * +1) + (+0 * +0) + (+0 * +0)
c(3) _ (+3 * + 1) + (-3 * -1) + (+1 * +1) + (+2 * +1) + (+0 * +0)
30 
c(4) _ (-1 * -1) + (+3 * +1) + (-3 * -1) + (+1 * +1) + (+2 * +1)
c(5) _ (+2 * +1) + (-1 * -1) + (+3 * +1) + (-3 * -1) + (+1 * +1)
Thus,
+0 for n < 0
35 c(n) - { {+2, +3, +6, +9,'+ 9, +9, ... 1, for n >- 0.
For every c(n) that is evaluated, there are N multiplicative
and N additive operations. One way of stating this result is
40 c(n) comprises of a sum of product terms. The (+0*+0)
product terms get pushed out of the correlation depth
window starting with the c(0) summation. It can also be seen
that until the nth value is as great as the correlation depth (N),
the correlator produces results similar to the situation where
45 the correlation depth is less than what is specified. Starting
with c(0), the effective correlation depth is 1. For c(1), the
effective correlation depth is 2. This result continues until
c(4), where the effective correlation depth is finally 5
product terms, as specified. Thus, if one were making
5o decisions based on the correlation results and some type of
statistical average, the contribution due to a specific set of
product terms from the REF and TEST sequence for (n<N-
1) has greater significance when compared to the situation
when (n>-N-1). SDA 100 handles this situation by refraining
55 from making decisions regarding the correlation scores until
all the correlators involved have reached their specified
operational depth (n2N-I). This behavior of waiting to
"recharge" the correlators before using their resultant scores
is controlled by a SLIP-RECOVERY _CYCLE parameter of
60 SDA 100. Typically, the SLIP_RECOVERY_CYCLE is set
to the same value as the correlation depth parameter
(COR_DEPTH).
Another significant point of interest illustrated by the
example above is that when the REF and TEST sequences
65 are aligned in time, each of the product terms will contribute
toward a positive sum for the correlation score. Any given
product term in the correlation sum is the product of the REF
US 9,450,747 B1
15
sign bit and the TEST sign bit weighted by the TEST's soft
decision value. Thus, it is possible to distinguish a situation
wherein the streams are in alignment, but weighted with low
TEST sequence soft decision values, representing a low
level of confidence in the soft decision, from the situation
wherein the streams are in alignment and the TEST sequence
soft decision values are high, which represents a high level
of confidence in the soft decision.
The following example below illustrates the anti-correla-
tion situation regarding data polarity. Using the same values
from the first example but with opposite polarity assigned to
the REF sequence sign bits, each of the product terms
contribute towards a negative sum for the correlation score.
Notice the magnitudes for the correlation scores are the
same for both the first and second examples. Thus, for
aligned data streams a single correlation process can detect
information regarding the polarity relationship between the
REF and TEST sequences based on the sign of the correla-
tion results. In both cases, the magnitude or absolute value
of the correlation score provides an indication of how
strongly the two sequences are in agreement.
+0, for n < 0
r(n) 
= { {+2, +1, -3, +3, -1, +2, +0, -0, -2, +3, -2, ... }, for n >- 0
+0, for n < 0
r(n) 
_ {-1, -1, +1, -1, +1, -1, -1, +1, +1, -1, +1, ... }, for n >- 0
c(0) _ (+2 . -1) + (+0 * +0) + (+0 * +0) + (+0 * +0) + (+0 * +0)
c(1) _ (+1 * -1) + (+2 * -1) + (+0 * +0) + (+0 * +0) + (+0 * +0)
c(2) _ (-3 * +1) + (+1 * -1) + (+2 * -1) + (+0 * +0) + (+0 * +0)
c(3) _ (+3 * -1) + (-3 * +1) + (+1 *-1)+ (+2 * -1) + (+0 * +0)
c(4) _ (-1 * +1) + (+3 * -1) + (-3 * +1) + (+1 * -1) + (+2 * -1)
c(5) _ (+2 * -1) + (-1 *+1) + (+3 * -1) + (-3 *+1) + (+1 * -1)
Thus,
+0, for n < 0
c(n) 
_ {-2, -3, -6, -9, -9, -9, ... }, for n >- 0.
Next, the case where TEST data stream 112 and REF data
stream 106 are not in alignment is considered. Since by
definition the sequence of the reference sign bits are sufli-
ciently random to support an RE communications system, if
the REF and TEST sequences are not time aligned there will
be on average an equal number of product terms in the
calculation of correlation score sum of products that are
positive and negative. On average the number of positive
product terms matches the average number of negative
product terms and the overall magnitude for the correlation
scores summation remains low. The following example
illustrates this situation by using the same values from the
original example with a modification to the REF sequence's
values such that roughly on average there is an equal number
of REF and TEST sequence values that agree and that
disagree in sign bit polarity.
+0, for n < 0
r(n) {+2, +1, -3, +3, -1, +2, +0, -0, -2, +3, -2, ... }, for n >- 0
+0, for n < 0
r(n) 
_ {+1, -1, -1, -1, -1, -1, +1, -1, -1, -1, +1, ... }, for n >- 0
16
-continued
c(0) _ (+2 + 1) + (+0 * +0) + (+0 * +0) + (+0 * +0) + (+0 * +0)
c(1) _ (+1 -1) + (+2 +1) + (+0 +0) + (+0 +0) + (+0 +0)
5 c(2)=(-3-1)+(+1 -1)+(+2 +1)+(+0 +0)+(+0 +0)
c(3) _ (+3 * -1) + (-3 * -1) + (+1 * -1) + (+2 * +1) + (+0 * +0)
c(4)=(-1*-1)+(+3*-1)+(-3*-1)+(+1*-1)+(+2*+1)
10 
c(5)=(+2-1)+(-1-1)+(+3-1)+(-3-1)+(+1-1)
Thus,
+0, for n < 0
c(n) 
_ { 1+2, +1, +4, +1, +2, -2, ... }, for n >- 0.
15
In an alternate embodiment, an additional correlator con-
figuration may be used. The configuration is a variation of
the correlation process described by Equation I and can be
used for accommodating cases where the receiver may
20 invert the sign for every other soft decision value that is a
part of the TEST stream sequence. Referring back to FIGS.
5 and 6, a situation can arise wherein a SQPSK receiver or
a QPSK receiver locks to the transmitted signal in such a
25 way as one of the two channels has different soft decision
sign bit polarity assigned and the two channels provided by
the SQPSK receiver are not being used independently from
one another, i.e., the two channels are multiplexed into a
single stream. Regardless of whether TEST stream sequence
30 112 contains values with all positive sign polarity sense, all
inverted sign sense, every other soft decision sign sense
inverted, or alternatively the "other every other" sign sense
inverted, SDA 100 tracks the timing alignment between REF
stream 106 and TEST stream 112. For the first two cases, all
35 sign bits with the positive polarity sense or all sign bits with
a negative sign polarity sense are tracked by correlators
described by Equation 1. These types of correlators may be
termed as "COW" herein.
The term "XCOR" is used to describe the correlator
40 described by Equation 2. For an XCOR correlator, the bit
sense assignments of the product terms is dithered by the
(-I)k term and will cause the magnitude of the correlation
scores to grow large and positive (correlation) when every
other sign bit from the sequence of TEST data stream 112 is
45 flipped and large and negative when the "other every other"
sign bit is flipped (anti-correlation). Like the COR correla-
tor, if the sign bits between TEST stream 112 and REF
stream 106 have a random relationship, the magnitude
produced by the XCOR correlator remains relatively low on
50 average, as indicated by the expression:
N-1 Equation 2 (Eq2)
c(n) _ Y' (-1)k t(n - k)r(n - k).
k=0
55
In summary, the COR and XCOR type correlators make
it possible to determine if a given sequence relationship
between the TEST and REF sequence are aligned or
60 unaligned. In addition, when the streams are aligned, the
correlators produce polarity information regarding the way
the receiver has assigned the polarity of the TEST stream's
soft decision sign bit in relation to the REF stream's sign bit.
Given these characteristics of a single correlator, a system of
65 correlators operating concurrently can provide more insight
into the alignment relationship between TEST stream 112
and REF stream 106.
US 9,450,747 B1
17
Correlator bank block 610 performs a soft decision cor-
relation operation with multiple versions of the REF Stream
106 (with each version of the REF stream 106 being in a
differing symbol alignment with TEST Stream 112 using the
COR and XCOR correlators described above). Each of these
independent correlation operations, by having differing sym-
bol alignment, offer the possibility of detecting a slipped
symbol in TEST Stream 112 as a result of receiver 115
slipping during data transmission. In addition, since SDA
100 can accommodate QPSK and SQPSK receivers, there is
the possibility that TEST Stream 112 will be received with
every symbol oriented in a positive logic sense, every
symbol oriented in a negative logic sense, every other
symbol oriented in a negative logic sense and finally, the
other every other symbol oriented in a negative logic sense.
In order to detect these alternating symbol logic conditions,
REF Stream 106 is also correlated against a version of TEST
Stream 112 with all possible logical sense inversions. Thus,
one output of correlator bank block 610 is to provide
multiple correlation results 612, one of which will be higher
in magnitude than all the others, signifying that it closely
matches the various aligned and logic sense versions of REF
stream 106, for input to the correlator analysis block 615.
Individually a single COR or XCOR correlator only tells
if the sequences being processed are time aligned or not time
aligned. An individual correlator reveals no information
regarding the amount or direction to shift the REF sequence
relative to the TEST sequence if they are not time aligned.
To determine the amount and direction of shift, SDA 100
employs a system of soft decision correlators running con-
currently.
Results from correlator bank 610 are used to determine
when and how far to shift TEST sequence 112 so as to bring
REF stream 106 into a time aligned relationship, also
referred to herein as "synchronized" or "symbol wise align-
ment", between TEST sequence 112 and REF stream 106.
FIG. 8 depicts a system of correlators 610 that operate
concurrently to yield information regarding the timing rela-
tionship between TEST stream 112 and REF stream 106.
The correlator bank block 610 is operable to detect "symbol
wise alignment", which in at least one embodiment also
refers to the measurable condition related to the degree of
timing alignment between the TEST stream 112 and the REF
stream 106. The term "symbol wise alignment" may also be
used to refer to the bringing of the timing of the TEST
stream 112 and the REF stream 106 into an exact time
aligned relationship, i.e., an exact one-to-one symbol wise
alignment with one another or "synchronization." Accord-
ingly, the correlator bank block 610 may be utilized for
detecting and measuring "near" symbol wise alignment, the
measurement of which depends on the number of correlators
utilized in the correlator bank block 610. For example, with
effectively nine correlators in the bank block 610 of FIG. 8,
a measurement of near symbol wise alignment for asynchro-
nous data streams might comprise a measurement of differ-
ence from exact one-to-one alignment of from one to eight
symbols. Of course, the correlator bank block 610 is also
operable to detect an exact one-to-one symbol wise align-
ment wherein each TEST stream 112 symbol and each REF
stream 106 symbol is exactly aligned in time with each other
(i.e., synchronized). Ultimately, results from correlator bank
block 610 are processed by modules downstream to make
adjustments to the timing relationship between TEST stream
112 and REF stream 106 after detection of "near symbol
wise alignment" rather than "exact one-to-one symbol wise
alignment" between the two streams is detected. The focus
of correlator bank block 610 is to produce a set of raw
18
correlation score results that can be used by downstream
modules to drive timing alignment corrections between the
two streams, thereby tracking slips that occur during opera-
tion of SDA 100.
5 Each of the nine correlator blocks depicted in FIG. 8
contain both a COR type correlator and a XCOR type
correlator. In one embodiment, 18 correlators run concur-
rently in SDA 100 in different time windows. In an alternate
embodiment, a greater number of correlators could run, and
io in yet another embodiment, a number less than 18 correla-
tors could run simultaneously. In FIG. 8, the nine different
correlator blocks feed different timed versions of the REF
sequence, and the TEST sequence has already been delayed
by 4 units. The correlators along with their specific delayed
15 version of the REF sequence are named for the timing
relationship they are configured to detect. For example,
"COR—E4" is configured to detect the situation where the
REF sequence is four samples ahead ("E" for early) in the
sequence progression. The correlators devoted to the detec-
20 tion of aligned relationship are indicated by "COR_EO" and
"XCOR_EO". Any correlators configured to detect situations
where the REF sequence lags the TEST sequence are
signified with a "Ll" through "L4" designation ("L" for
lagging).
25 The specified depth of the correlation process directly
affects the amount of processing required for each of the
correlators, both COR and XCOR correlators, and can
permissibly range from 5 to 1024 by the COR_DEPTH
parameter for the design of SDA 100. Utilizing the brute
30 force approach for when the correlation depth is set to 1024,
together with equation 1 and 2, implies there are 1024
multiplications and 1024 additions required for the COR
correlator and 1,536 multiplications and 1024 additions for
the XCOR correlator required for every REF clock period.
35 Granted, the multiplications are fairly trivial because all the
product terms involve multiplication by +1 or —1. Since
Correlator Bank 610 is made up of 9 individual COR/XCOR
pairs, the actual requirement for Correlator Bank 610 is 9
times that of an individual COR/XCOR pair. This compu-
40 tation comprises 23,040 multiplications and 18,432 addi-
tions per REF stream clock period. Thus, if SDA 100 is
operating at a data rate of 50 Mbps, an amount of compu-
tations equivalent to a maximum of 1.152 E+12 multiplica-
tions per second combined with a maximum of 921.6 E+9
45 additions per second is performed in order to produce 18
twenty bit vectors in correlator bank block 610 which are
passed to the next step in the process: correlator analysis
block 615 ("RANK").
Even though much of the processing is being performed
50 in hardware, over 1.152E+12 operations per second is a
significant number of computations. The amount of opera-
tions required explains why the internal representation of the
TEST sequence's soft decision values was selected to be in
a sign magnitude format it is due to the sheer numbers of
55 multiplications that involve +1 and —1—consequently side-
stepping lots of two's complement operations. Attempting to
make this number of two's complement conversions can be
expensive and difficult to achieve efficiently.
Returning now to FIGS. 4A and 4B again, changes to the
6o data due to perturbations in the demodulation of receiver 115
are known as "constellation rotations." When receiver 115
experiences a slip or rotation, the correlator that was previ-
ously generating the highest value, indicating it best
matched the data content of TEST stream 112, will diminish
65 and a new correlator will increase to become the highest
value. Correlation results 612 is produced by each of the
correlators in the bank for every symbol of REF stream 106
US 9,450,747 B1
19
and TEST stream 112 that is evaluated. Characteristics of the
correlation operation are driven by SDA Software 400 via
data path D 141 and can be used to markedly change the data
depths of the individual correlators, thus allowing SDA 100
to be tuned to a wide variety of testing objectives.
Correlator analysis block 615 performs a rapid sort in
SDA firmware 300 of all the multiple correlator results
provided by correlator bank block 610 in order to identify a
single specific winning correlator, i.e. the correlator with the
highest value. This sorting process occurs for each REF/
TEST symbol stream combination that is evaluated. The
single winning correlator result 616 is passed to slip align-
ment analysis block 620.
The process for construction of the correlation score of
SDA 100 is illustrated in more detail in FIG. 9. As viewed
on this sheet, the REF and TEST stream sequences enter on
the left side of FIG. 9 and the resultant correlation score
sequence exits to the right. First, the process slices the sign
bit out of test stream sequence 106 to be used in the
calculation of a product term A. TEST sign bit and REF sign
bit are then multiplied (Label B) and the results (REF/TEST
Product) used in two different places. The first use of the
REF/TEST Product is to slice it back together into TEST
stream's magnitude sequence C. The newly formed TEST
sequence with REF/TEST product sign bit is stored in FIFO
buffer D that has a programmable depth feature. The pro-
grammable depth essentially controls the amount of delay
from when the data enters and leaves FIFO D. The second
use of the REF/TEST Product is to store the Product Terms
Sum E, similar to the calculation of the correlation score
described hereinbefore.
REF/TEST product determines if the new product term is
added or subtracted (Label F) from the ongoing calculation
stored in the correlation score register (Label I). The adder
at Label F adds or subtracts the introduction of new product
terms with the Correlation Feedback sequence (Label K).
The correlation feedback sequence represents the previous
correlation score summation minus the product terms (out-
puts from the FIFO) that are rolling out of the correlation
score summation window. Inverter G ensures that when a
product term is added at Step F to the correlation score, after
the FIFO delay, that same product term is subtracted from
the correlation score by Subtractor H. The net effect is the
calculation of the correlation score sequence without all the
redundant calculations required to implement the brute force
implementation of Equations 1 and 2.
Utilizing the concepts illustrated in FIG. 9 drops the
computational requirements of SDA 100 considerably in
comparison to the brute force method. When the correlation
depth is set to 1024, the design concept illustrated in FIG. 9
implies 1 multiplication and 2 additions required for the
COR correlator and 2 multiplications and 2 additions for the
XCOR correlator, both on a per REF clock period basis.
Thus, for a COR/XCOR pair there are 3 multiplications and
4 additions per REF clock period basis. Because of the
storage provided by the FIFO, it is not necessary to recal-
culate all the intermediate product terms for each correlation
score sequence value. Thus, the actual depth of the corre-
lation has no bearing on the number of multiplications or
additions for each correlation score sequence element (un-
like the brute force method).
However, similar to the brute force calculation, there
remains the need to multiply the individual COR/XCOR pair
combination's requirements by 9 to determine the require-
ments for the entire correlation bank. That computation
would be 27 multiplications and 36 additions per COR/
XCOR pair on a REF stream clock basis. If SDA 100 is
20
operating at a maximum certified data rate of 50 Mbps, there
are an equivalent of a maximum of 1.35E9 multiplications
per second and a maximum of LSE9 additions per second in
order to produce 1S twenty bit vectors in correlator bank
5 610, which are passed to the next step in the process,
correlator analysis block 615 (RANK).
In summary, using the brute force approach to implement
the correlation score sequence maximally requires roughly
2.07E+12 operations. Using the approach of SDA 100 as
io outlined in FIG. 9 maximally requires 3.15E+9 operations.
Thus the process of SDA 100 for calculating the correlation
score sequence represents a savings of three orders of
magnitude over the amount of effort expended for the brute
force approach.
15 The next step in the process is to reduce the 1S concur-
rently generated 20 bit correlation vectors into a single
winning correlation score. This step of reduction takes place
in a RANKING module (RANK for short) of SDA 100.
Basically, SDA 100 performs a hardware equivalent of a
20 multistage sort to identify the single correlator that has the
highest correlation magnitude score. This sorting process
takes place once for every REF sequence element processed
(i.e., once every REF clock period). In addition to the 1S
sorted correlation vectors, correlator analysis block 615
25 introduces a faux correlation that can be used to squelch
correlator magnitude results from correlator bank block 610
that fall below a specified threshold
(COR_QUAL_THRESHOLD). Winning correlations
whose magnitude is less than the quality threshold value are
30 suppressed from counting towards the criteria used to
declare a detected slip. If one has no desire to squelch low
magnitude correlation results, the COR_QUAL_THRESH-
OLD parameter may be set to zero.
Even though each correlator can have up to 219 possible
35 different magnitude values, there are circumstances that
happen frequently enough wherein the issue of a magnitude
tie between the different correlators should be taken into
account. Several factors influence this "tie" issue. The
factors include correlation depth, TEST Stream soft decision
40 width, and the signal to noise ratio (SNR) at the input of the
receiver. During development of SDA 100, it was noticed
that the occurrences of ties, which initially did not seem all
that relevant, ended up being statistically significant. For
example, in situations where the receiver presents a small
45 number of soft decision bits, the correlation depth is shallow
and the SNR is strong (i.e. the TEST stream soft decision
magnitudes tend to be similar), the correlation scores exhibit
less variation, thus enhancing the probability of a tie.
Another situation that can arise where the resolution of the
50 tie becomes relevant is when SDA 100 is used to evaluate a
QPSK system and the receiver experiences a channel swap
event. At each stage in the sort process and in the event of
a correlation score magnitude tie, the mechanics of the sort
tend to favor the results of one correlator over another.
55 Selecting which correlator is compared to another correlator
turns out to be useful in minimizing the effects of this tie
phenomenon.
The first stage comparisons evaluate the COR correlation
scores against the XCOR correlation scores for a given
60 COR/XCOR pair, with a tie resolving in favor of the COR
results. In this initial stage, SDA 100 minimizes the effects
of the tie priority bias by comparing the results from a
COR/XCOR pair because both the COR and XCOR in the
pair experience the exact same REF and TEST data stream
65 data. For example, COR _El is initially compared to
XCOR—El. Since the COR/XCOR pair are fed the same
delayed version of the REF sequence and TEST sequence,
US 9,450,747 B1
21
this step minimizes the chance for ambiguous results (i.e. a
correlation score magnitude tie). Half the sign bits involved
in the calculation of the correlation score summation will by
definition result in correlation product terms that decrease
the correlation score results for either the COR or XCOR in
a given CORACOR pair. The result depends on the polarity
assignment made by the receiver to the TEST stream's soft
decision sign bit. More specifically, if the receiver has
assigned TEST stream soft decision sign bit polarity to
quadrants I and III (Examples (1) and (4) of FIG. 5) or
quadrants 11 and IV (Examples (2) and (3) of FIG. 5). In
order for a tie to result at stage 1 of the sort process (where
the bias would assert), exactly every other TEST stream's
sign bit would also have to be in error (a low probability as
long as the correlation depth is sufficient). Thus, at this first
stage, it would take a strange coincidence for a CORACOR
pair to generate a tie, minimizing the effect of the bias.
In this embodiment, the on time correlators, COR_EO and
XCOR_E0, have priority over all the other correlators in the
resolution of a tie. The reasoning behind this approach is that
if there is a chance the on time correlations are still valid, it
may not be desirable to signal the potential of slip to
downstream SDA modules. In one embodiment, a priority
can be given to a correlator when there is a tie in correlation
score magnitudes. Subsequent stages of the sort process
favor correlators closer to the ideal alignment over correla-
tors further from the ideal alignment (EO). For example,
XCOR_L2 is favored in the event of a tie over COR_E3
because XCOR_L2 is closer to the ideal on time correlator
and requires a smaller correction. In the event there is a tie
for the subsequent stages, SDA 100 favors the correlators
associated with the smallest correction. Favoring large slips
over small slips could potentially introduce unstable
response in the alignment correction process, especially in
the case of dealing with QPSK channel swapped conditions.
Winning results from correlator analysis block 615 are
finally passed to slip alignment analysis block 620 that is
responsible for adjusting the timing relationship between
REF stream 106 and TEST stream 112 and for accumulating
statistical information regarding slips and rotations. Corr-
elator analysis block 615 passes several pieces of informa-
tion regarding the winning correlator to slip alignment
analysis block 620. Block 615 identifies which correlator
produced the winning score. Then block 615 passes the
magnitude of the winning score and the sign of the winning
score. A winning correlator is identified for every REF
sequence value that is passed to correlator analysis block
615 from upstream, which is usually once every REF clock
period.
Slip alignment analysis block 620 performs trending
analysis upon the sequence of winning correlation results in
order to determine if the receiver has experienced a data slip
or constellation rotation. If a change over the previous
winning correlator persists for a number of symbol cycles
specified by SDA software 400, slip alignment analysis
block 620 declares a slip or rotation. Upon detection of a
slip, slip alignment analysis block 620 issues feedback via
block 626 to buffer block 625, which in turn is used to
control the alignment of REF stream 106 and TEST stream
112, thus bringing the respective streams back into align-
ment. In addition, block 620 statistically tracks the magni-
tude and direction of slips and the number of rotations and
provides this data 622 as part of the aggregate of statistical
information 126 to SDA Software 400.
Slip alignment analysis block 620 processes the output
from correlator analysis block 615 and is primarily respon-
sible for driving the buffer depth relationship that controls
OW
the timing alignment between the TEST data stream 112 and
REF stream 106. In addition, block 620 is the module that
begins the collection of statistical data regarding the perfor-
mance of the receiver under test. Slip alignment analysis
5 block 620 also tracks the slips and rotations and the rela-
tionship of their feedback to the stream buffers.
Correlator analysis block 615 only resolves correlator
magnitude tie situations associated with a single REF
sequence clock period (resolving ties that happen within the
io same REF cycle clock period). A tie situation can also arise
when examining consecutive REF sequence clock periods,
thereby requiring SDA 100 to resolve the issue across
multiple consecutive REF cycle clock periods. Generally, in
the event of a tie between two winning magnitudes, SDA
15 100 favors the correlator that was associated with the first
occurrence of winning magnitude. The rationale behind this
approach is that when a tie occurs, there is no way to know
which correlator really deserves to win, because a tie is
ambiguous. In one embodiment, the approach is essentially
20 to do nothing until there is clear evidence on which to base
a corrective alignment action. There is an exception to this
approach of preferring the first occurrence. The exception is
when there is a tie between either of the on time correlators
(COR_EO or XCOR_EO) and any of the other correlators
25 (E4-El and Ll-L4). In this circumstance, the tie is resolved
in favor of the on time correlators.
The next step taken by slip alignment analysis block 620
is to make a determination whether there has been a real slip
in between REF stream sequence 106 and TEST stream
30 sequence 112. The declaration of a slip is made when there
have been a number of consecutive winning correlation
magnitude scores from the same correlator that are not one
of the on time correlators (EO). This contest for determining
if there has been a slip is illustrated by the flow diagram of
35 FIG. 10. The number of required consecutive winning
correlation magnitude scores is controlled by the
SLIP _THRESHOLD parameter. If one of the on time cor-
relators (EO) is the winner of this consecutive count process,
then no action is required to realign the buffer relationship
4o between the REF and TEST streams. However, if one of the
other correlators (E4-El or Ll-L4) wins this consecutive
count contest, a slip is declared and SDA 100 begins its slip
recovery process.
Finite state machines within slip alignment analysis block
45 620 drive the buffer re-alignment process after the detection
of a slip. A flow diagram illustrating this process of slip
recovery together with the associated delays is shown in
FIG. 11. In one embodiment, the first step that slip alignment
analysis block 620 takes after detecting a slip is the step of
5o adjusting the depth of the buffer used to control the timing
of REF stream data. The specific winning correlator that
won the consecutive count contest drives the direction in
which the REF buffer should be adjusted along with the
magnitude of the buffer adjustment. SDA 100 only deals
55 with one slip at a time but the slip can range anywhere from
one to four REF stream symbols in either the forward or
reverse direction relative to the TEST stream. When SDA
100 detects a slip, a slip recovery process begins realigning
the buffers and re-initializing all the correlators. Upon exit
60 of the slip recovery process, if there has been another slip,
SDA 100 will detect it as soon as the associated slipped
correlator wins the consecutive count contest. During the
slip recovery process, other parts of SDA 100 continue to
function (for example the clock phase detectors) without
65 altering their behavior.
Slip recovery is a multi-step process and is illustrated by
the flow diagram shown in FIG. 11. The first step in the slip
US 9,450,747 B1
23
recovery is to adjust the buffer relationship between REF
stream 106 and TEST stream 112. This adjustment is made
during the course of four REF clock bit periods. In one
embodiment, four REF clock bit periods are utilized even if
SDA 100 only needs to make a one symbol correction. The 5
second step is to initialize the chain of delayed REF values
within correlator block 610, which for this embodiment
takes nine REF clock bit periods. The next step is to
initialize (recharge) the contents of the correlators. The
number of REF clock cycles necessary to initialize the io
correlators is specified by the SLIP_RECOVERY_CYCLES
parameter. As previously explained herein, this parameter is
typically set to the same value as the correlation depth. After
correlator bank 610 is recharged with new data to the depth
specified by the COR_DEPTH parameter, slip alignment 15
analysis block 620 exits the slip recovery process and
resumes the search for slips.
The slip detection and recovery processes limit SDA 100
from detecting slip events that are closely spaced in time. To
calculate the minimum spacing of slip events that SDA 100 20
can detect in seconds, sum the SLIP _THRESHOLD and
SLIP_RECOVERY_CYCLES parameters, add 13 cycles (4
cycles for buffer relationship adjustment and 9 cycles for
re-initialization of the REF delay chain) and multiply the
combined sum by the REF clock period and take the ceiling 25
of the result. For example, using a COR_DEPTH=128,
SLIP_THRESHOLD=50, SLIP-RECOVERY-CYCL S
-128, and a REF Clock rate of 2 Mbps, the minimum spacing
between slip events that SDA 100 can detect is 96 µs.
Clock phase detector block 630 provides an alternative 30
method to detect receiver slips over the method of correlat-
ing the data content of the REF and TEST symbol streams.
It provides insight into the receiver's behavior independent
of data content and instead relies on a direct comparison of
clock edges present in TEST data stream against clock edges 35
present in the REF Stream 106. This alternative method is
useful in characterizing performance of a RE receiver's bit
sync tracking circuitry and provides a means to determine if
portions of the receiver are working properly regardless of
whether the receiver presents TEST Stream 112 data cor- 40
rectly. The direct comparison of the clock edges produces a
more agile detection of slip conditions than the data corre-
lation method used by SDA 100 embodied by correlator
bank block 610 and associated slip alignment feedback and
control loop 628. Such capability especially proves useful in 45
measuring statistical performance of receiver acquisition
when an RE receiver first starts the process of acquiring an
RE signal. This feature is utilized in acquisition testing.
Block 630 also provides clock edge based phase slip per-
formance information 631 as part of the aggregate of sta- 50
tistical information 126 to SDA software 400.
The performance of a receiver is affected by the length of
consecutive symbols that are ones or zeros. Thus, there
exists a need to measure the run length characteristics of
REF stream data 106 provided by data source 105. TEST 55
stream run length analysis block 635 measures run lengths
and publishes run length performance results 636 to statis-
tical histogram analysis block 650. Statistical histogram
analysis block 650 accumulates individual run length events
into a histogram format. The individual breakdown of the 60
run length data events as provided by TEST stream run
length analysis block 635 is suitable for interpretation in the
context of BPSK, QPSK and SQPSK communication sys-
tems.
In addition, TEST stream run length analysis block 635 65
also provides a means to trigger external test equipment
upon the detection of run length events that exceed a
24
threshold as configured by SDA software application 400 via
data path D 141. A run length trigger threshold signal 665 is
one of many selectable internal SDA signals that may be
directed to signal conditioning hardware 200 for buffering
and potential monitoring by external test equipment such as
logic analyzers or oscilloscopes.
The bit error detector block 640 provides a hard decision
bit error measurement on the correlated REF symbol stream
611 and correlated TEST symbol stream 621. Block 640 is
capable of performing long bit error rate tests (BERT) that
extend over multiple days, compiling up to 10E13 symbols
of data. Block 640 automatically applies proper adjustment
to symbol polarity based on the quadrant of operation as
determined by SLIP alignment analysis block 620 for BPSK,
QPSK and SQPSK-based receivers. Block 640 also tracks
TEST stream 112 errors for the one or zero symbols sepa-
rately, as well as separately tracking the number of symbols
in the REF stream that are ones and zeros. Statistical
imbalances for TEST stream 112 in the frequency between
symbols that are one errors and symbols that are zero errors
can expose problems with receiver performance. Statistical
imbalances for REF stream 106 in the number of symbols
that are ones and symbols that are zeros provide a measure
of suitability of data source 105 to provide data to a TEST
configuration. If desired, bit error detector block 640 does
not process symbols during the period where slip alignment
analysis block 620 is making adjustments to the alignment
of TEST and REF Stream symbol alignment. Instead, in one
embodiment, block 640 resumes its accumulation of BERT
data once the two data streams 106 and 112 have been
brought back into alignment. During the accumulation of
BERT data, block 620 tracks whether there has been a slip
or rotation during a TEST interval. The bit error rate test
(BERT) is used to control the sampling interval for the
accumulation of statistical data by the historical event
recorder block 655. Thus, BERT can be correlated with slip
rates and constellation rotation rates. Block 640 supplies bit
error rate analysis information as part of correlated hard
decision bit error performance data 641 and as part of the
aggregate of statistical information 126 to SDA software
application 400.
The primary function of statistical histogram analysis
block 650 is to provide a means to statistically process
millions of soft decision symbols data in a way that is useful
in the analysis of communications systems. Block 650
operates in several configurations as commanded by SDA
software application 400 via data path D 141. Statistical
histogram analysis block 650 is responsible for processing
the synchronized and scaled, but uncorrelated, TEST stream
soft decision data 541 as it is supplied by the output of
synthetic channel and scale block 540. This mode of opera-
tion for statistical histogram analysis block 650 is known as
the RAW mode. During initial setup of SDA 100 in a test
configuration with devices under test, viewing the soft
decision data as first interpreted by process raw input block
520 may be of interest because there are lots of opportunities
for issues when connecting the numerous digital signals
between the receiver 115 and SDA 100.
Selective application of functions performed by the pro-
cess raw input block 520 and the synthetic channel and scale
block 540 can be used to detect and correct issues related to
the physical interface between the digital systems. The
applications include detection and correction of the soft
decision bits that have been mis-wired, detection and cor-
rection of data polarity issues for individual soft decision
bits, identification and mitigation of stuck soft decision bits,
US 9,450,747 B1
and the mapping between different mathematical formats
used to express the value of soft decision symbol data. When
statistical histogram analysis block 650 is operating in the
RAW mode, it publishes the resultant histogram perfor-
mance data 651 to SDA Software application 400 as a part
of the aggregate of statistical performance data 126.
A second mode of operation of SDA 100 and block 650,
referred to as CORRELATED mode, provides a means to
sort TEST stream soft decision data 531 and 541 based on
correlated REF Stream symbol data into different histogram
categories. This mode of operation produces useful results
when SDA 100 has achieved the "correlation-locked" con-
dition. Correlation-locked occurs when the REF stream 106
symbols and TEST stream 112 symbols are synchronized in
time with one another and is declared by SLIP alignment
analysis block 620. The ability of histogram analysis block
650 to sort TEST soft decision symbols based on the
correlated REF symbol values into different category histo-
grams allows SDA 100 to characterize performance attri-
butes of RE receiver 115 under test for a given RE link
condition. The performance attributes include, but are not
limited to: receiver perceived signal to noise ratio, receiver
perceived signal level, low density parity check (LDPC)
combining ratio, transition interference, inter-symbol inter-
ference, inter-channel interference, decision threshold
imbalance and channel imbalance. When statistical histo-
gram analysis block 650 is operating in the CORRELATED
mode, block 650 can be used to publish the resultant
statistical histogram performance data 651 to SDA software
application 400 as a part of the aggregate of statistical
performance data 126.
Historical event recorder block 655 provides a means for
SDA firmware 300 to log the occurrence of significant SDA
events to SDA software application 400 where events are
documented into historical records 145. Individual events of
interest as determined by SLIP alignment analysis block 620
and clock phase detector block 630 are gathered into com-
bined event record 656 and passed to SDA software 400 as
a part of the aggregate of statistical performance data 126 via
data path C. In addition, historical event recorder block 655
has a number of general purpose external inputs 623 that
allow historical record 145 to make note of the occurrence
of external events. This function provides a means to mark
in the sequence of historical records the occurrence of any
external events independent of SDA 100. One example of
this type of occurrence is the event of performing an antenna
switch. This function enables SDA 100 to assist the filtering
of historical record 145 so as to locate relevant events of
interest when developing and testing a communication sys-
tem.
Acquisition test coordinator block 660 is used when
statistically determining the time required for receiver 115 to
lock to RE signal 111. Block 660 automates acquisition
testing by controlling various SDA firmware components
via data path R. The automated control of these components
by acquisition/control data 661 via data path R is somewhat
redundant with the control exerted on the same firmware
components by SDA software 400 via data path D 141. The
separate control data 661 is exerted in a cooperative fashion
with the control exerted by software 400 because, in this
embodiment, SDA software 400 is not fast enough by itself
to control features during acquisition testing. Control of the
acquisition test coordinator block 660 is managed by con-
figuration/control data 141 via data path D. Acquisition test
results 662 are aggregated into the statistical performance
test data 126 communicated to SDA Software 400 via data
path C.
26
FIG. 12 shows a diagram of the graphical output of
correlator bank block 610 for understanding the different
parts to the slip tracking process of SDA 100. The traces that
are depicted are the output from a logic analyzer that was
5 used to monitor the output of correlator bank block 610. In
this example, not all the correlators have their outputs
depicted in the diagram (given that the logic analyzer ran out
of inputs to hook up). However, enough inputs were con-
nected to monitor the outputs of a little more than half of the
io correlators. Notice that at sequence count 1, there are many
outputs of correlator bank block 610 which are approxi-
mately at or below a value of 0.01. These values represent
the correlators that are not time aligned with the TEST
stream and hence the output is relatively low. The single
15 output of the on time correlator clearly stands out from all
the other correlator scores because at this point it is being fed
TEST and REF sequence data that is time aligned.
Sometime around sequence count 80, the receiver 115
experiences a one bit slip. Immediately upon the slip, the
20 magnitude of the on time correlator begins to decline and the
magnitude of the LI correlator begins to increase. At
approximately sequence count 140, the magnitudes for the
two higher scoring correlators cross. The LI correlator is
now the winning correlator and, as shown, its consecutive
25 winning streak persists. Because the streak persists for the
number of REF clock cycles specified by the
SLIP_THRESHOLD parameter, the state machines in slip
alignment analysis block 620 declare a detected slip and
begin the slip recovery process (at around sequence count
so 200). Initially during the slip recovery process, all the
correlators are initialized to zero, resulting in the precipitous
drop for the output of the LI correlator. However, shortly
after the initialization we can see the on time correlator is
again gaining in strength because the correction applied to
35 the timing relationship was correct.
During the slip tracking process, slip alignment analysis
block 620 collects statistical information regarding the
occurrence of slips and rotations for the system under test.
The statistical information regarding the occurrence of slips
4o and rotations 622 is provided to SDA software 400 for
reporting performance of the device under test to the user
interface and for recording to a journal file for later post test
analysis. Results from slip alignment analysis block 620 are
provided to other SDA modules (not shown) that determine
45 if SDA 100 is tracking the timing alignment of the REF
stream to the TEST stream (i.e., the COR_LOCK param-
eter). Additionally, slip alignment analysis block 620 pro-
vides receiver constellation assignments to the hard decision
bit error detector block 640 of SDA 100. Thus, the hard
5o decision bit error block 640 can run continuously, even in
the event of a slip or constellation rotation. In one embodi-
ment, the constellation assignment is provided to the histo-
gram module and allows the histogram module to categorize
the receiver's TEST stream soft decision symbols into eight
55 different histogram categories. The statistical information
captured by these eight different categories provides insight
into the soft decision performance of receiver 115.
Turning to FIG. 13, a diagram shows the possible data
polarity operating environment of a receiver. Once the
6o receiver assigns a polarity sense to the soft decision sign bit
of TEST stream 112, it becomes possible to describe the
receiver as operating in one of four quadrants. As discussed
before, SQPSK and QPSK systems have four quadrants of
operation that fall into their "constellation". Determination
65 of whether the receiver has altered its assignment of polarity
sense of the soft decision sign bit is made by categorizing
whether the winning correlation results comes from the
US 9,450,747 B1
WA
COR_E4 through COR_L4 group of correlators or
XCOR_E4 through XCOR_L4 group of correlators. Similar
to the detection of a slip, changes to the winning group of
correlators or changes to the sign of the winning score sign
that persist for SLIP_THRESHOLD number of REF clock
periods indicate the occurrence of a constellation rotation.
Note that rotations due to shifts between the COR_EO
correlator and XCOR_EO correlator do not initiate the slip
recovery process as depicted in FIG. 10, but will register as
a constellation rotation. Constellation changes accompanied
by slips will induce the slip recovery process resulting in
SDA 100 simultaneously correcting for both the rotation and
the slip. FIG. 13 depicts the associated winning correlator
groups and polarity of the correlation score with the asso-
ciated constellation quadrant. The interpretation relics on an
intended mapping of the receiver's I channel stream data to
the physical TDI_A port of SDA 100 and the receiver's Q
channel stream data to the physical TDI_B port of SDA 100.
SDA 100 uses a look-up table technique to map the "test"
data soft decision signals to the internal representation and
to map the internal representation to the output representa-
tion. This process means that an arbitrary relationship
between the input format and the output format can be
constructed. But complete flexibility is also unmanageable;
a user cannot be expected to supply each individual entry in
the table. Therefore, a simple interactive control interface is
needed that provides the user with flexibility for most
situations. Such control interface is shown in FIG. 14.
The scale table generator for SDA 100 is managed by the
user from control interface 1400. One significant advantage
of interface 1400 is the ability to avoid having to prepare
new cables, which can be time consuming. Interface 1400
applies a sequence of transform operations which are cal-
culated as shown left to right, top to bottom. In practice,
the user will find it is more manageable to describe the soft
decision input by working through the interface backward:
Representation, Bit Order, Data Polarity, Shifting, Width,
and then the details of flipping or reordering individual bits
when necessary. The soft decision input and the soft decision
output sections of interface 1400 can be utilized to connect
electrically incompatible RE receivers and baseband signal
processors.
The control can be adapted to any bus width, but in one
embodiment of implementation. SDA 100 uses a hardware
bus width of 12 bits. An external signal can be connected to
any of these hardware signal input pins as indicated gener-
ally at 1402. The first element of the input control allows any
physical signal pin to be selected into any position, or any
pin to be overwritten with a constant "1" or constant "0".
This control enables pins to be swapped, duplicated, shifted,
or overwritten. For example, during setup it is useful to
verify wiring by setting all inputs to "0" and checking
connections one at a time. Duplicating can be useful to
create copies of a signal line to split out to test equipment.
Duplicating and overwriting can be used to harden the
decisions. Using this control element to change bit order, or
shift bits, is unnecessary when other control elements are
provided.
The second element allows the signal polarity at any bit
position to be inverted as indicated generally at 1404. We
have seen for example a receiver that provides a number
format expressed as one's complement but with an inverted
most significant bit (MSB). Also, with differential signaling,
a simple wiring inconsistency that causes a signal inversion
is not uncommon.
The third control element as indicated at 1406 selects the
width (i.e., how many bit positions are present) of the
28
externally connected signal bus. Widths of 1, 3, 5, 6, 7, 8,
and 12 have been seen. This control element is used with the
fourth and fifth control elements, as indicated at 1408 and
1410, to select the bits from either end of the bus or out of
5 the middle.
The sixth control element, as indicated at 1412, allows the
entire bus signal polarity to be described as true or inverted.
Some designers use inverse logic.
The seventh control element, as indicated at 1414, allows
10 the bit order to be selected left-to-right or right-to-left, which
means that if the busses are connected in the wrong sequen-
tial order, the condition can be corrected with the click of a
button.
15 The eighth control element selects the number represen-
tation, as indicated at 1416, either sign-magnitude or one's
complement. Two's complement does not sometimes make
sense in the context of a communication system because one
of the mappings (0) has an ambiguous polarity. However,
20 two's complement can be formed using available control
elements.
At this point in the translation, the decisions are repre-
sented numerically. Additional control elements are used to
describe the translation to make for the output. The first
25 control element (not shown) allows an offset to be applied.
This element is simply a floating-point number that is added
to the decisions. This compensation can be used, for
example, to move the bin centers for Two's complement. It
can also be used to compensate a bias in the decision
30 threshold (taken to be zero).
The second element, as indicated at 1418, is also an offset,
but is added to the decision magnitudes without shifting the
decision threshold. Thus a magnitude offset, as indicated at
35 1420, of +2 would map a decision of +3 to +5, and —3 to —5,
whereas a simple offset of +2 would map a decision of +3
to +5 and —3 to —1. The magnitude offset can be used to
adjust the certainty in the decisions.
The third element is a floating point scale factor as
40 indicated at 1422. This element is a simple multiplier that
rescales the average amplitude of all the decisions, as
processors often assume a particular average amplitude. The
third element is also useful when connecting two busses of
different widths.
45 The fourth control element of soft decision output, as
indicated at 1424, clips the decisions to a specified number
of bits. This clipping could be less than the width of the bus,
and can be used to harden the decisions without disturbing
any of the physical bus connections.
50 The fifth control element, as indicated at 1426, selects the
output number representation, the sixth, as indicated at
1428, the output bit order. The seventh control element,
indicated at 1430, selects the output signal polarity.
The next soft decision output elements select specific
55 physical output pins. The eighth control element, as indi-
cated at 1432, selects the output bus width (which again
results in clipping). The outputs can also be collectively
selected ("slid") to specific positions at either end of the bus
as indicated at control elements 1434 and 1436.
60 Output signal lines, as indicated at 1438, can be over-
written or re-ordered temporarily or as required. Also,
individual output signal lines can be inverted as indicated at
1440.
During an output-stage connectivity check, an example of
65 one useful method comprises the steps of setting the output
scale factor to zero (resulting in an all-zeros output) and then
toggling each of the individual output signal polarities in
US 9,450,747 B1
29
turn so as to verify the integrity of connections. Accordingly,
SDA 100 is able to calculate and update tables in real-time
as the user makes changes.
The foregoing description of the embodiments of the
invention has been presented for purposes of illustration and
description only. It is not intended to be exhaustive or to
limit the invention to the precise form disclosed; and obvi-
ously many modifications and variations are possible in light
of the above teaching. Such modifications and variations
that may be apparent to a person skilled in the art are
intended to be included within the scope of this invention as
defined by the accompanying claims. In the claims, means-
plus-function and step-plus-function clauses are intended to
cover the structures or acts described herein as performing
the recited function and not only structural equivalents, but
also equivalent structures. Thus, while a nail and a screw
may not be structural equivalents in that a nail employs a
cylindrical surface to secure wooden parts together, whereas
a screw employs a helical surface, in the environment of
fastening wooden parts, a nail and a screw may be equiva-
lent structures.
What is claimed is:
1. A system to analyze a soft decision of a communication
system comprising at least one of a data source, a transmit-
ter, a receiver, and a baseband signal processor, comprising:
a scaling module built into programmable hardware oper-
able for receiving a reference data stream from said
data source and a test data stream from said receiver,
whereby said test data stream and said reference data
stream each is assigned a numerical value based on a
polarity and each bit of said test data stream is assigned
a value indicative of the level of confidence in the soft
decision; and
30
a correlator bank built into said programmable hardware
operable to analyze symbol wise alignment of said
reference data stream against said test data stream, said
correlator bank being configured to produce a correla-
5 for signal dependent on said symbol wise alignment.
2. The system of claim 1, further comprising a simulator
built into said programmable hardware operable to simulate
said test data stream and said reference data stream without
using said transmitter, said receiver, or said data source.
10 
3. The system of claim 2, wherein the simulator simulates
communication equipment comprising a soft decision trans-
mitter, a soft decision receiver, and a reference data source,
and wherein the simulator comprises a signal generator
operable to produce a synthetic soft decision test data stream
and a synthetic reference data stream, said signal generator
15 being operable to produce signals representative of a plu-
rality of different modulation types of soft decision receiv-
ers.
4. The system of claim 3, wherein said signal generator is
implemented in said programmable hardware.
20 5. The system of claim 3, wherein said signal generator is
operable to slip said synthetic soft decision test data stream
and said synthetic reference data stream with respect to each
other.
6. The system of claim 5, wherein said signal generator is
25 operable to slip said synthetic soft decision test data stream
and said synthetic reference data stream with respect to each
other in both forward and reverse directions by a selectable
number of symbols.
7. The system of claim 3, further comprising a control
30 module operable for controlling said signal generator to
selectively produce simulated errors in said synthetic soft
decision test data stream.
