Data compression/error correction digital test system. Appendix 2:  Theory of operation by unknown
CONTRACT NAS 9-104
FINAL REPORT
(N NSA-CR- 11560 6) DATA COMPRESSION/ERROR
CORRECTION DIGITAL TEST SYSTEM. APPENDIX
THEORY OF OPERATION Final Report
(Radiation, Inc.) Jan. 1972 163 p CSCL
N172-2523 1
2:
09B G3/8, 
Unclas
3130 1
8 A%GATA COM; PRESMODi/
ERROOR COORRECTG1IH
DIGITAL TEST $S$TEM
APPEEBIX 2 /
OF aPT FM R EA " Ot n T A
OFFICE OF PRIME RESPONSIBILITY
JANUARY 1972
.
4 Si
dy,.>-|
A RADIATION
!-0 Systems Division
iL- P IMELBOURNE, FLORtDA 32901p r ~ Y^ . Z,,!RlcINTFTYPP Crn 'f,-,n TI(CN
f
LL
I
_,0
In
co
I I No ....  -)
F
ffr
/z 1;S1 
https://ntrs.nasa.gov/search.jsp?R=19720017581 2020-03-11T18:12:33+00:00Z
CONTRACT NAS 9-10441
FINAL REPORT
DATA COMPL~ES$SHg.I/
ERMOE CURRECTCU7
DIGITAL TEST SYSTEI
APPERWIIX 2
THEJANUARY 1O ORA972
JANUARY 1972
K-,
u-
IOO
',O
TABLE OF CONTENTS
Title
INTRODUCTION .................
System Block Diagram Description ......
DETAIL TRANSMITTER DESCRIPTION . . .
A2-2.1
A2-2.2
A2-2.3
A2-2.4
A2-2.5
A2-2.6
A2-2.7
A2-2.7.1
A2-2.7.2
A2-2.8
A2-2.8.1
A2-2.9
A2-2.10
A2-2.11
A2-2.12
A2-2.12.1
A2-2.12.2
A2-2.12.3
A2-2.12.4
A2-2.13
A2-2.13.1
A2-2.14
A2-2.15
Filter - FL1 .. ... . .......................... ..... . 5
Video Amplitude Shaper - A3 A2 A2 .................... ..... .. . . 5
Analog-to-Digital Converter - A1 ................. 11...... 
Sync Separator - A3A2A1 ................... .......... 12
Reducer - A3A1A3 .......................... ..... 12
Statistical Encoder - A3A5 ... ................................... 19
Transmit Rate Buffer Subsystem - A3A1A4 ................. ....... . 26
Rate Buffer... ... ................................... 26
Detail Operation ............................................ 26
Rate Adaptive Tolerance Generator - A3A1A1. .. ............ 29
Detailed Description ........................................... 29
Voice Encoder - A3A3A4 ............................ 31
Information Rate Timing - A3A2A6 ..................... ... 33
Sample Rate Clock - A3A2A6(A7) ...................... .......... . 35
Time Division Multiplexer - A3A2A1 ..................... 37
Format . ...................................... 37
Frame Rate Counter ......................................... . 40
Data Source .................................... ... ..... . 40
Multiplexing Operation ....................................... . 41
Convolution Encoder - A3A3A3 ............................. 41
Detail Description. ................................ ....... . 42
Noise Generator - A3A3A2 ........................... 44
Output Buffer Amplifier - A3A3A1 ............ ... . .. . . . . . 44
DETAIL RECEIVER DESCRIPTION ................
Bit Sync-Signal Conditioner - Preprocessor - A1I(A2) . .. .
Quadraphase Data Combiner - A9A2 . . . .. .........
Viterbi (Maximum Likelihood) Decoder.............
Review of Decoding Process ....................
General Functional Organization of the Decoder ......
Block Diagram Description ........ . . . . ....
Fano Decoder- A8A1A9 (A13-A22) . ...... . . . . ...
Theory of Operation . .........................
45
....... .45
....... .. 49
....... 50
.... ... .. 50
....... ... 53
. . . . . . . 56
.. .. . .. 97
....... .. 97
Paragraph
A2-1.0
A2-1.1
A2-2.0
Page
2
2
5
A2-3.0
A2-3.1
A2-3.2
A2-3.3
A2-3.3.1
A2-3.3.2
A2-3.3.3
A2-3.4
A2-3.4.1
.................
I
i
TABLE OF CONTENTS (Continued)
Title
Group Synchronizer and Demultiplexer - A8A1A2 .............
Group Sync Policy .................................
Group Synchronizer Block Diagram ......................
Receiver Rate Buffer (A8AlAl, A8A1A8, and A8A1All) .........
Receiver Buffer Operation ..................... ......
Buffer Synchronization ...............................
TV Data Reconstructor - A8A1A7 ........................
Statistical Decoder - 2A8A6A1 & 2.......................
TV Sync Generator - A8A1A1 0 . .........................
Digital-to-Analog Converter - A8A1A5 and A8A1A7. ..........
Video Amplitude Shaper (Expander) - A8A1A6 ................
Voice Demodulator - A8A1A3 ..........................
Timing Generator - A8A1A4 . ...........................
Bit Comparators - A8A9A1 ............................
ii
Paragraph
A2-3.5
A2-3.5.1
A2-3.5.2
A2-3.6
A2-3.6.1
A2-3.6.2
A2-3.7
A2-3.8
A2-3.9
A2-3.10
A2-3.11
A2-3.12
A2-3.13
A2-3.14
Page
134
134
134 
136
136
139
140
143
146
146
146
154
155
157
40
APPENDIX 2
THEORY OF OPERATION
1
A2-1.0 INTRODUCTION
This volume consists of three major sections: a system block diagram description, a
description of the units of the Transmitter, and a description of the units of the Receiver.
A2-1.1 System Block Diagram Description
An overall block diagram of the DC/EC Digital System Test is shown in Drawing
528769. The system is divided into two major units, the Transmitter and the Receiver. In opera-
tion, the Transmitter and Receiver are connected only by a real or simulated transmission link.
The system inputs consist of: 1) Standard format TV video, 2) Two channels of analog voice and
3) One serial PCM bit stream.
Considering first the TV channel, the analog video is supplied from a TV camera
in synchronism with the sync separator and routed to the Input Filter. The Sync Separator gener-
ates the sync and blanking pulses for the video and produces digital sync words. The unit also
produces control signals to the Data Reducer to prevent unnecessary signal processing and trans-
mission during sync and blanking times. The Amplitude Shaping unit processes the analog video
so that it may be efficiently sampled and quantized by the Analog to Digital Converter. The
digital words from the converter are supplied to the Data Reducer. This unit processes the data
to eliminate samples which are unnecessary to the later reconstruction process. These nonredun-
dant samples are fed to the Rate Buffer to allow conversion from their nonuniform rate of occur-
rence to a uniform transmission rate. Different picture areas contain different numbers of non-
redundant samples, so the input rate to the buffer varies. Since the average input and output
rates of the buffer must be equal, it is necessary to provide feedback control of the Data Reducer
by the Rate Buffer, to avoid uncontrolled overflow or underflow of the Buffer.
An alternate method of reducing the number of transmitted bits per picture may be
selected by utilizing the Statistical Encoder. This technique transmits a variable number of bits
for code words representing the difference between adjacent A/D samples. The length of the
transmitted code words is preprogrammed as a function of the frequency of occurrence of the
input differences. Differences which occur most often are presented by the shortest length code
words while differences which occur least often are represented by the longest code words. As
the code words are generated they are stored in the Rate Buffer prior to transmission.
The Rate Buffer output forms one input to the Multiplexer, which combines this
signal with the other three signals. Two of these other signals are from the two Delta Modulators,
which convert the analog voice input signals into efficient digital form. The third input is a
serial PCM telemetry signal. A sync pattern is also multiplexed with the data to allow synchroni-
zation of the receiving equipment. The digital voice and TV data are synchronized with the
PCM to allow simple time division multiplexing of the signals to a single bit stream at the output
of the multiplexer. The multiplexer output is fed to the Channel Encoder (Convolution Encoder)
which inserts redundancy into the bit stream in a form which allows the receiver to efficiently
correct transmission errors due to noise. The final bit stream is fed to the Output Buffer Amplifier,
which provides flexible gain and offset for interface with a variety of modulators or simulators.
2
7 6 5
II TIMING I
CTRANSMITTER) L " 5
IA3A2A6/7 
I23923/S51
- ~~2 - T~7?~7~- IA' - 528751,/?,) ,__ -, 
123930 y
528738 I I
FROM
DEMODULATOR C
2A.
tNol \c3xxx - ASSS-._i , ?
I . 52l~~~~~~~~~~~
ff roI
I I
.I I
ERROR
COUNT E R
MI
8l 7 6 
FOOLDOUT FFME t
D
C
--b
B
A
It I I
I
I
I I
I I8 7 I6 5
ERAML -. -3
1 A3A3A2
123955
I A3A3A3
123966
_ 528734
GENERAL
PURPOSE
OUTPUT TO
MODULATOR ,
LOGIC
OUTPUT
e aDt - /A ASt
- 'aD1.0RNASC
TRANSMITTER 123914
RECEIVER 123915
.2A841AIO
I/z392z9
r 7z937
G YNE CR
G ENEP. TOI~
NE ASSY USED ONT
APPU)CATION
4
PMIT STE FI fE r ts MD S $A7 S=
Comlimu TDOml s PM./P IT STOC SIE
IRWfifi THRiUS I WI Pt LS I- 1
I 'I3tO1 S MRl SIM.STOS L
UXCIC STLWtS no I'l muD
GllEnmmrlSTIC. PU RA I IC J U1 tS
ELIC riULL PSI ELIC lC DSAL 5 ] PER tFTlSil1t. 1$16 1 TWWIOP E I G'A11R SSR
W1HI' me3w Ica ['I it 011,PL""
ELE$ROIO:C O:ALtl A 11a'S "S" a
f11CTR CAk AND [UCTInC REFERENCECESi-hAllCSS Ki LSLSW Ir
WELDI5U: STibOIS PEP ls "2s1a
UNLESS OTHERWISE SPECIFIED
DIMENSIONS ARE IN INCHES
AND INCLUDE APPLIED FINISH
TOLERANCES
aS PCt 0R3 ) NJCL E.3 s_. _ - . -.
3
.4 : AS'
.ALI ,2#89BJ./2,899
.s'3/oz2aSJ/oa3
2 T1
' SYNC
EXER
C
B
TV OUTPUT
VC'-E CHANNEL ':I
OUTPUT
ENGRG DEW
2
A
1
3
,2
This amplifier also contains provision for mixing noise with the signal to allow link simulation
at baseband frequencies. A wideband noise generator with adjustable level is provided. In
addition to data, a clock at the transmitted bit rate is provided for use in external equipment.
Directing attention to the receiver section, the input signal is applied to the Bit
Synchronizer, which synchronizes a bit rate clock to the input and filters the data with a matched
filter. The output of the bit detector filter is sampled (by the derived bit rate clock) and quan-
tized to three bit resolution. In the case of Quadriphase signals a second Bit Synchronizer is
provided. The output of the two Bit Synchronizers are combined in the Quadriphase Multiplexer.
The combined signal, andclock, are fed to the Decoders which operate on the signal to correct
transmission errors and reconvert the signal to the form existing at the Encoder input. The
Decoders contain circuitry to establish decoding sync, and to resolve demodulator polarity
ambiguities. Two Convolution Decoders are provided. One, a parallel processing device
implements the Viterbi algorithm and the other, a sequential device, implements the Fano algo-
rithm. The Decoder output is applied to the Group Synchronizer, which locates the sync pattern
inserted at the transmitter and synchronizes the demultiplexer.
The Demultiplexer now separates the signal into four individual channels (and
deletes the sync pattern). The PCM is outputted directly, while the two voice channels are
reconstructed to analog form in the Voice Demodulators and outputted.
The TV channel words are fed at a uniform rate to the Rate Buffer, and are out-
putted from the buffer as required by the Reconstructor or the Statistical Decoder. TV sync
paiterns are recognized and used to synchronize the TV Sync generator, which regenerates the
standard TV sync signals. The TV video and sync are converted to analog form in the Digital to
Analog Converter. The signal is then shaped in the Amplitude Shaping unit to remove the effect
of the shaping performed at the transmitter. The final output is standard TV waveform similar
to that at the input of the transmitter.
Two bit comparators are provided to monitor the bit error rate at both the input and
output of the Convolution Decoders. These units compare the delayed transmitted data or its
equivalent to the corresponding receiver data, and generate error pulses. A Counter counts these
errors over an adjustable time period and decimally displays the bit error count.
4
DETAIL TRANSMITTER DESCRIPTION
The following sections describe the individual units of the Transmitter in more
detail.
A2-2.1 Filter - FL1
The filter is a bandpass filter, manufactured by Krohn-Hite Corporation, Model
#3103R. A list of the primary specifications are provided below:
1. Frequency Range: Low-cutoff frequency independently adjustable from 10 Hz
to 1 MHz in five bands. High-cutoff frequency independently adjustable from
30 Hz to 3 MHz in five bands.
2. Frequency Dials: Separate low-cutoff and high-cutoff dials.
3. Bandwidth: Continuously variable within the cutoff frequency limits of
10 Hz to 3 MHz.
4. Attenuation Slope: Nominal 24 dB per octave.
5. Frequency Response: Standard response is a 4th order Butterworth, maximally
flat. A RESPONSE switch on rear of chassis converts to simple RC response
optimum for transient-free performance.
6. Maximum Input Amplitude: 3 volts rms, decreasing to 2.5 volts at 3 MHz.
7. Maximum Output Amplitude: See 6.
8. Maximum Output Current: 10 ma rms.
9. Connectors: Front panel and rear of chassis, one BNC connector for INPUT
and for OUTPUT.
A2-2.2 Video Amplitude Shaper - A3 A2 A2
The Transmitter Video Amplitude Shaping Network (Drawing 528730) accepts the
composite video input from the system input filter. It amplifies this signal linearly or nonlinearly
and provides an output amplitude of 0 to +5 volts to drive the A/D converter. The transfer func-
tion of this amplifier is piece wise linear and has up to 3 line segments. The slopes of the line
segments are individually adjustable by means of a plug-in resistor module located on the video
amplitude shaping board.
5
A2-2 .0
The Video Processing Channel consists of amplifiers ARI, AR2, AR3, and AR4 and
their associated circuitry. The DC restorer is composed of comparator U1, transistors Q2 and Q3,
transformer T1, diodes CR7, CR8, CR10 and CR9 and summing amplifier AR5. Transister Q1,
amplifier AR6 and reference diode CR5 form the necessary circuit to establish a precision voltage
to reference the break point of the linear segments. Variable resistor R20 establishes the clamping
level of the DC restorer, resistor R27 establishes the bias current for diodes CR2 and CR3 and.
variable resistors R 11 and R14 establish the break points.
Amplifier AR1 is used to drive AR2 and the DC restorer circuit: The input video
from AR1 isamplified by AR2 (X5) and shaped by amplifier AR3. AR4 is used to drive the 50
ohm input of the A/D converter.
Amplifier AR3 and its associated circuitry perform the shaping function of the input
video. The two break points are determined by the resistive combinations of R13, R14, R35, and
R12, Rll, R34. The circuit is designed tooperate on a positive going signal with diode CR1
removing all negative going signals. Thus, using the level adjustment (R20) the incoming signal
can be clamped such that only the sync pulse is removed. A brief review of operational ampli-
fier fundamentals is presented to help clarify the discussion of the shaping network.
The gain of an operational amplifier is expressed as:
Rf
R in 2 .'~ ,
Ii eofut
eout Rf
G= =; R.
e. R.in in
The gain equation is an approximation, but it is reasonably accurate for low frequencies, and
provided the amplifier has a large open loop gain. Other approximations to be used in the
following discussion are:
1= 12
andthe summing point for I11 and 12 is ground. Therefore, let's consider the following circuit:
6
~- R4
+V2 ;ARf
14
:I CR1I~~~~~~~~~~~~~~~r I f i AII R1 A i a3 -
F lein '" out
JiI 3 - R3I3
* jv~~~~i
_
For this discussion the break occurs on a positive going signal, as does the actual shaper Figure
3.3-2. The diode CR1 is biased on for 0 volts in. The bias current is determined by V2 and R4.
Resistor R3 and V1 are adjusted to sink 12 and 11 plus establish the break point. Since there is a
drop across a forward biased diode, amplifier A2 will have to supply enough current for ein = 0,
such that 11 R1 is equal to the diode drop. Therefore, for ein =eout = 0 volts. The following
conditions exist:
If = 0
V214 = 12 = V2
13 = 11 + 12
l .6
R1
As ein is increased in the positive direction 12 decreases and If = 14 = 12. In this way an output
voltage is generated such that
e
out
If =
Rf
This will continue until 11 = 13 and 14 = If at which time the diode is back biased and a further
increase in ei will cause no further change in output voltage.
7
With CR1 biased on, point A will be at a potential of approximately 0.6 volt below
ground and this point will remain at the potential until the conduction of the diode is cut off by
back bias. If we assume the above statement is true, then the diode can be considered as a con-
stant voltage source with an internal resistance and the gain can be expressed as:
G = eout Rf
ein R1 + Rd
where Rd is the dynamic resistance of the diode.
The above gain equation is sufficient for a reasonable approximation of the gain
of the circuit while the diode is forward biased and a more detailed analysis will not be presented.
Therefore, with R1 determined by the required gain, the break point can be deter-
mined as follows:
ein = ebreak when 11 =13 and 12= 0
Thus:
einb= lb [ R1 + R3] - V1
IbR3 =einb + V1 - IbRi
assume that for 12 = 0:
einb= IdR1
then:
einb + V1 - IbRIR3 =
einb
R1
R3 - R1
enb ,
8
Using the equations just derived, the circuit parameters for the three line segments shown below
can be calculated:
~4S~~~~~~~
There are four different transfer functions provided. These are:
1 . Linear, eout = ein (Function A).
2. A transfer function where segment #1 has a greater slope than the slope
of the equal perceptibility curve (Function B). SI z10, S2z1 and S3~ 1/3.
3. A transfer function where segment #1 has a slope that is less than the slope of
the equal perceptibility curve (Function C). SI z4 S2-1 and S3 1/3.
4. A two segment transfer function selected to complement the camera nonlinearity,
SI2 , S2, -0 .8.
From Drawing 528730 the components that determine the different slopes are con-
tained on plug-ins and are: R9, RIO,' R1l, R12, R13, and R14. Variable resistors R27, R34, and
R35 are used for the initial setup and for periodic alignments.
It should be understood that the following equations for the break points and slopes
are approximations and the actual desired parameters were determined or confirmed empirically.
9
For Function A:
R16 = 1
Si- R9
where:
4
R10 = 00oo
Rll = oo
R12 = 
R13= a
R14 = oo
For Functions B and C:
Assume diode resistance Rd ,z 40 ohms
Ra _ (R9) (R12 + Rd)
R9 + R12 + Rd)
Rb = (Ra) (R13 + Rd)
Rb (Ra +R13 + Rd)
then:
R16
Sl =R-Rb
R16
S2 - R
_ R16S3 -R9
3.3 R16
-bl = R14 + R35
3.3 R16
eb2 = Rll +R34
(Slope of Segment No. 1)
(Slope of Segment No. 2)
(Slope of Segment No. 3)
(Voltage for break point No. 1)
(Voltage for break point No. 2)
10
The diode bridge comprised of diodes CR7, 8, 10, and 9 is turned on during the
composite sync time. This allows the capacitor C20 to be charged to a positive level equal to the
peak voltage of the sync pulse contained in the video signal. The voltage is positive because
the video signal has been inverted by AR1. Utilizing Amplifier AR5, this positive voltage is
compared with a negative voltage determined by the position of R20. Thus, the delta voltage is
added to the video waveform by AR2. In this manner, the sync pulse is clamped to a voltage
level determined by R20. Comparator U1 shapes the sync pulse and transistors Q2 and Q3 supply
the necessary current to drive fhe transformer T1 to turn the diode bridge on'and off.
The resistive network, comprised of R37 and R40, establishes a voltage level(1.65 volts) for the comparator to reference the input syncwith and change levels if the sync pulse
is of greateramplitude than the reference level. Resistors R30 and R36cause the comparator to have
hysteresis effect, thus preventing oscillation when the comparator changes state.
Zener diode CR5 establishes a voltage reference for Amplifier AR6 and the current
drive Q1. This voltage reference is used to set the levels for the line segment break points.
A2-2.3 Analog-to-Digital Converter - Al
The Analog-to-Digital Converter is manufactured by Inter-Computer Electronics,
Inc., Model IAD-1206. A list of the primary specifications are provided below. For this appli-
cation, the sample and hold has been bypassed to allow operation at variable sampling rates.
1 . Input Voltage
2. Input Impedance
3. Conversion Rate
4. Overall Accuracy
5. Linearity
6. Digital Output
7. Convert Complete Pulse
0 to 5 volt full scale
50 ohms nominal
6 bit binary conversion at ten megahertz rate
from internal clock
+1% of FS +1/2 least significant bit
+1 least significant bit
Parallel output straight binary. Logic one "1 "is
2.4 (full load) to 5 volts (unloaded). Logic
zero (0) is 0 volts +0.5 volt. TTL compatible
drive capability.
Pulse is a logic "one" 20 nanoseconds wide that
will be available 20 nanoseconds after conver-
sion is completed.
11
8. External Convert For synchronous drive from an external signal
Command source, pulse should be greater than 4 volts
with a minimum width of 20 nanoseconds and
a maximum width of 50 nanoseconds. Rise
time 10 nanoseconds. Fall I time 10 nano-
seconds. Nominal input impedance 50 ohmss.
Conversion triggerable from an external source
at rates from DC to 10 megahertz.
9. Environmental Temperature 0° to 500 C
10. Power 115 VAC +10% 60 Hz
45 watts
A2-2.4 Sync Separator - A3A2A1
The function of the sync separator is to generate a composite TV synchronization
signal to synchronize the TV camera to the system timing. The Sync Separator also provides
a blanking signal to control the operation of the Reducer.
A block diagram of the Sync Separator is shown in Figure A2-2.4. The timing is
derived from a one Megahertz reference signal from the Sample Rate timing circuitry. This
signal is frequency multiplied by a phase lock multiplier to produce a 9 Megahertz signal
which is coherent with the sample rate. This 9 Megahertz is used by the Horizontal Counter and
Decodes to produce a twice horizontal rate signal, a "begin horizontal blanking" signal, and
the horizontally related components of the composite sync signal. Horizontal blanking is gene-
rated by a separate counter, from the 9 Megahertz and the "begin horizontal" signal. In a simi-
lar manner, the vertically related timing signals are produced from the twice horizontal rate by
the Vertical Counter, Decodes and the.Vertical Blanking Counter. The Composite TV Sync
Logic combines the various horizontal and vertical timing signals to produce the output Com-
posite TV Sync Signal.
A2-2.5 Reducer - A3A1A3
There are two redundancy reduction techniques implemented in the reducer. These
are the Zero-Order-Predictor (ZOP) and the Zero-Order-lnterpolator (ZOI). The reducer sub-
system will process the 6 bit A/D parallel output at a rate (1 to 9 MHz) selected from a thumb-
wheel on the front panel. The reducer tolerance will be a four bit number that can be selected
as a fixed value or rate-adaptive. In the rate-adaptive tolerance mode, tolerance is controlled
by the transmission buffer fill rate.
12
(SHEET 1 & 2)
1 MHz PHASE LOCK MHz HOR
X9 FREQ - _ CC
REF FROM MULTIPLIER & D
SAMPLE RATE .
TIMING (SHEET 5)
HORI
~J-. BLAI'
COL
(SHEET 3)
SHEET NUMBERS ARE
REFERENCED TO
DRAWINGS 528735
(SHEET 3)
SYNC TO CAMERA
86185-3
Figure A2-2.4. Sync Separator
13
(SHEET 3)
Flexibility of parameter choice is supplied by allowing transmission of a 6 bit
sample and 4 bit time tag, a 5 bit sample and-5 bit time tag, or a 4 bit sample and 6 bit time
tag. These combinations restrict the transmitted nonredundant word to 10 bits allowing simplifi-
cation of the multiplexing scheme. When 4 bit timing is selected, the 6 bit nonredundant
samples chosen by the reducer are transmitted as is. A choice of 5 bit timing causes the first
5 MSB of the nonredundant sample to be combined with the time word for buffer insertion. This
is accomplished by gating the MSB of the 5 bit time count into the position normally occupied
by the LSB of the 6 bit samples. The 6 bit time word, in a similar manner, combines the first
4 MSB of the nonredundant sample with the 6 bit time for buffer insertion. In this case gating
on the first'wo MSB of the time count is required. Gating is controlled by the sample/time
word size selection on the front panel.
Both reduction algorithms require arithmetic operations and various storage elements
to perform a reduction operation. Due to the high speed required (9 MHz sample rate) it was
necessary to limit a reduction operation to an arithmetic operation (add or subtract) followed by a
comparison. The reducer is therefore constructed to perform these operations in such a manner
that both reduction techniques use the same circuitry and associated storage elements with only
minor changes in register gating (ZOP - ZOI switch in Figure A2-2.5-1)required to differentiate
between ZOI and ZOP modes.
In the ZOI Mode, reducer logic operation satisfies the criteria for redundancy
removal shown in Figure A2-2.5-2, a flow diagram of ZOI/ZOP operation, and Figure A2-2.5-3,
an illustration of ZOI reduction and reconstruction. ZOI operation is accomplished in Figure
A2-2.5.1 when the ZOI/ZOP switch is in the ZOI state. This allows AD1 to be gated to U when
necessary and AD3 to be gated to L when necessary. As shown, the occurrence of a nonredundant
sample requires that a new tolerance corridor be established by drawing horizontal lines (U and L)
through the limits of the tolerance range placed around the nonredundant sample. This is accom-
plished by gating AD1 into U and AD3 into L after a nonredundant sample is chosen. If a toler-
ance range (AD1 and AD3) corridor placed around a subsequent sample (Pn) overlaps the previous
corridor (comparisons made in adders 4-7), Pn is considered redundant and is discarded and tn
(the time tag) is incremented by one in preparation for the next sample check. Each successive
redundant sample modifies the corridor extended to the next sample. The new corridor consists of
that part of the previous corridor which is overlapped by the tolerance range placed about the
redundant sample. In other words, the upper range, either AD1 or U, and the lower range,
either AD3 or L, forming the most restrictive corridor are saved. If the tolerance range placed
about a subsequent sample does not overlap the corridor extended to the sample, this sample is
considered nonredundant, and the mid-point of the previous corridor, (U+L)/2, is transmitted
along with a time tag tn showing the number of times (U+L)/2 must be repeated in the recon-
structor. If no nonredundant sample occurs for 14 sample periods (4 bit time), 30 sample periods
(5 bit time), or 62 sample periods (6 bit time), the present sample being checked is considered
nonredundant.
In the ZO.P mode, reducer operation satisfies the redundancy removal criteria shown
in Figure A2-2.5-2 with the ZOI/ZOP switches in the ZOP state, and Figure A2-2.5-4, an
illustration of ZOP reduction and reconstruction. The basic ZOP operation sets tolerance ranges
about a nonredundant sample and then checks successive samples to determine if they are within
the corridor formed by the ranges mentioned above. When a sample falls outside this corridor it
14
E
a
C,
0)
a
0
u
0
coI
8
c~
Crm
Itm
CNl
!
`0
L..
a)
U-
15
* -L- PIC
IMP
S 5
I-2
"AP
NoSTOP
J~~~~~
R gs 1l Ir
P. ,
Fg ure A-.5. Ru 2 w og
ro P
Figure A2-2.5-2. Reducer Flow Diagram
16
Lu
LLJ t
5 : <
F-'
D Z z
F- D <
LU ~ZWzF- -LLJ WZ
Z :D
,~ 
I oa
tn
VX
0C
* <:
kn V)
L-I
... I--
CLZ
`5z
Z Z
< 0K CY-
0 z
We 0
oz
0 z
' -
LuJ
0
5-:
17
e'J
-J
(NJ
II
(2
I NCN
-J
Qo
C'(Ni
(NI
CN
(N
0
0-OS
0)
ui
U
z
.<
ui
-a
0
I--
II
FII 1I I
ilJ
z>
0
.-
0
a
Z
u-I
z
CZ
w
0
z
LU
Jr~
u-i0
Lii
I-
z
II
It
II
CY)
N
·- .2 VL!t
V)
_) u-
CN L
-= ;
-z
'0 Z
u-I
__ _
F-
co
N
(I
-i
.-P
0-8
c
_C
0
u
-o
-a
a)u
o
c
-o
c
-s!
0
N
C'q
U')
eN
cii0)
LL-
0
o
U-
z0
0
0
to
(1)
(Nj
I
I
-J
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~-..J
w n . _
LU
aj
1 0- ( c
n o~~~~~~~4~
I1 .1_
Ln OU
_U I-- .,
u-i C 1
_n .
i~~~~~~~~~~~~~~~-
zZ>~~~ DZ 
. Z
-Uz0 0 < O_I-- 1~ *'-
4 * I I
I~ ~ - I. Ij0
I 'I _ ,
'..,L "ni A.-
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{L.J
I.- u-i i- -Z ~Zo CL ~~~~~~~~~( ~-i cIA ~ ~  ~~~~~~~~C
* <L
18 0
"' z Z uj z
cz~O 00 Lu J
OZ ' .~~ ZN
Cl- LL- ~ ~ ~ ~ ~ ~ - u-
,, > 0Z Zco 0
~-0 z0 ,,
00 4~~~~~~)
~~~~~~~~~~~~~~~~'00
to
-'4-
I I~~~~~~~~~~~~~ I.I-
--I
0L
18
_J
z
0
-+ #s
I
I
I
I ,
I
I
I
I
I
is considered nonredundant and the previous- nonredundant sample that formed the corridor is
transmitted along with the time tag. ZOP operation in the test set accomplishes the same
result but in a different manner. In order to simplify sequencing and control, ZOP reduction
occurs by performing exactly the same operations as in ZOI except Pn instead of AD1 and
AD3 will be gated into both U and L after every nonredundant sample decision (see Figures.
A2-2.5-1 and A2-2.5-2 with the ZOI/ZOP switch in the ZOP state). A tolerance range is
placed around successive samples (AD1 and AD3) forming a corridor which is compared to the
previous corridor formed by U and L, where both are equal to the starting rKonredundant sample.
This check. is identical to placing the tolerance range about the starting sample. Pn is considered
redundant if the corridors overlap (U and L inside the new corridor), but U and L are not updated
by AD1 and AD3 due to the gating of the ZOI/ZOP switch. If the AD1 and AD3 corridor does
not overlap the U-L corridor (Po), Pn is considered nonredundant, and the previous nonredundant
sample (U+L)/2 is transmitted along with a time tag showing the number of times itshould be
repeated in the reconstructor. The sample size-time size choice is identical to ZOI operation.
During TV blanking, when sync information is present in the TV signal, the reducer
'eceives a blanking signal from the sync separator causing the present reduction process to be
completed by forcing Pn to be nonredundant and then suspending reducer operation until the
blanking pulse is removed. During blanking the only data placed in the transmitter buffer is a
special sync code which tells the reconstructor what type of TV sync should occur (horizontal or
vertical) at that point in the signal and a buffer sync word which is not presently used. The
particular sync word is determined by the type of blanking that is present. When the transmitter
buffer is ready to accept data it signals the reducer to insert the proper TV sync word and operates
the loading process with its own clock. After TV sync loading is completed the buffer sync word
is loaded into memory. The words for horizontal and vertical sync information are made up of a
6 bit zero "time tag" to distinguish them from TV video data and a4 bit amplitude. This format
makes the sync words independent of sample-time word size.
Buffer underflow during TV data processing results in a signal being sent to the
reducer forcing it to consider the present sample being processed as nonredundant and inserting
it into the buffer. A special operation mode occurs at the resumption of reducer operation after
blanking. In order to eliminate the transmission of incorrect data at the beginning of each
active TV scan a flip-flop is used to detect the first sample of a TV scan. The normal reducer
operation will be bypassed and the U and L registers will be set up with the proper data depending
on the reducer mode. Subsequent samples will be processed in the normal manner.
A2-2.6 Statistical Encoder - A3A5
The Statistical Encoder/Decoder system transmits information dependent upon the
statistical nature of the sequential data words and the rate of channel activity (encoder memory
usage).
19
Basically the Encoder generates code words that indicate the value difference
(delta) in subsequent data words. These codes are chosen to reduce the total amount of data
bits transferred across the PCM link.
The data to be encoded is a six bit binary word equal to the intensity of the TV
picture at a point in time. The data is positive true with zero data indicating black.
Sample Rate and Data Rate are selected at the front panel and are chosen depend-
ent upon the picture complexity so that the Transmitter memory does not overflow and for the
desired picture quality as determined by Sample Rate.
To maintain a constant serial data flow, automatic quantization varies the rate of
memory fill by adjusting the number of significant data bits within a range of 4 to 6 bits. These
quantization levels, referred to as QL, are automatic submodes and will be detailed in the block
diagram description.
The following detailed description of the Statistical Encoder is referenced to the
Encoder Block Diagram (Figure A2-2.6-1) and to the Logic Diagrams 531022 and 531023.
Video data from the A/D is provided to the Encoder in the form of a six bit binary
data word each Sample Rate time. This video data word is adjusted for quantization at the Select
Gate. Quantization Level (QL) 6 enables all 6 bits. QL5 shift selects the 5 MSB bits down one
bit to the 5 LSB outputs and provides a filler '1' bit in location 6. QL4 shift selects the 4 MSB
bits down 2 bits and provides '1' filler bits in locations 5 and 6. This shifting of data will reduce
the number of video levels transmitted but maintains the moresignificant picture data. An oppo-
site QL operation in the Statistical Decoder restores the proper bit location.
The Input Holding Register and Register B hold two subsequent data words which
shift at Transfer time. The data in these two registers is subtracted from one another with the
resultant answer as the difference or Delta of the two words. This Delta is updated each Sample
time. The Delta is stored as a six bit word and sign, which is presented to the Code Word Select
generator.
The Code Word selector compares the Delta word and selects the next code to be
generated. The various codes available are:
Delta 0 provides no change in information
Delta +1 provides increase of 1 bit
Delta +2 provides increase of 2 bits
Delta +3 provides increase of 3 bits
Delta -1 provides decrease of 1 bit
Delta -2 provides decrease of 2 bits
Delta -3 provides decrease of 3 bits
Remainder transmits four MSB bits as new data.
20
E
a
1..
-Y
0
o
-0
e)
-o
0
CN
UIII
.0
I-LIn
CrJ
e~4
ii
21
/
The Word Selector is inhibited during TV Sync and Blanking time and is controlled
to some extent when the memory is nearly empty by forcing all Remainder codes during this time,
which provides the maximum memory fill rate.
The output of the Code Word Selector is buffered and provided to the Word and
Length Patch Selectors. The code word and its bit length is variable by means of plug-in patch
modules. Only one code type is active at any one time and is patched to the Code Length and
Code Word Registers. These registers are enabled each Transfer time.
The Code Length register operates directly with the Shift Control to produce a
discrete amount of clock pulses after each Transfer time. Each Sample Rate produces a Transfer
pulse which in turn enables a Load pulse which initiates the Code Generation sequence. The
Load pulse loads the current code word information into the Code Length shift register. This
code word information is a single '1' bit placed into one of eight stages. All other stages are
cleared. The Load pulse also sets the Start flip-flop and inhibits the 50 MHz Clock until the
trailing end of the Load pulse. At the end of the Load pulse the clock is released to shift the
register until the '1' bit reaches the start flip-flop to turn off the clock. This permits generation
of one to eight clock pulses depending on the Code Word length.
The Shift Control also contains buffer drivers to provide clocks to the Code Word
and Output Registers.
The Code Word register is loaded at the same time as the Code Length register but
with data information instead of length information. This data is programmable by means of
plug-in patch modules or may be actual data in the case of Remainder or Absolute Value code
words. The Code Word register is shifted from the Shift Control clock to produce a code data
word each Sample Rate.
The Output Shift Register accumulates Data Code Words from the Code Word
Register until it has thirty bits of data. At this time, it parallel transfers the thirty bit word
into a memory buffer register. The Output Shift register is shifted from the Shift Control clock
which is a burst of one to eight clock pulses at a 50 MHz rate.
Parallel transfer of the 30 bit word is accomplished by setting bit 0 of the register
to a '1' bit. When this tag bit arrives at the end of the register, it creates a "Load Memory
Buffer" pulse to the Memory Interface Buffer. This Load Buffer pulse also clears the Output Shift
register and sets the tag bit 0 for the next 30 bit word.
The Memory Interface Buffer (see Figure A2-2.6-2) receives the 30 bit word and
sets the Load 30 flip-flop to request a memory Write access of the Memory Control Circuitry.
The Memory Interface Buffer provides statistical data to the Data Select gates of the Memory
Interface. The other input is ZOP/I data and is selected by a front panel mode select switch.
Buffer Drivers are used-to interface the 30 bit data word with the memory input.
22
- il
ro~~~~~~~w lho 
X, a - E
1~~~~~~~~~~~~~~~~~1
I I u
i~~~~~~~~~~~~~~~~~~~~~~~~C
4~ ~~~~C
Z ,
C~~~o
0
a'. 'a-I-I-~~~~
~~~~' 'a ~   ~ ~ ~ ~ ~ ~ ~~o
!I~~ 
23
TV Sync signals are provided from the Transmitter Timing and are synchronized to
the Encoder Timing using the Transfer rate signal.
At sample rates of 1, 2, 3 and 4 MHz, Encoder Timing is controlled by Sample
Rate which is synchronized to the 50 MHz oscillator and creates a 'Ready Load' and a 'Transfer'
timing pulses using a Shift Register. At 5 MHz Sample Rate, to avoid synchronization problems,
the sample rate is generated by dividing the 50 MHz oscillator by 10, and routing this 5 MHz to
the sample rate circuitry for use in the Statistical Mode only. 
TV Synchronization begins at the start of the Vertical Blanking time. The TV Sync
signals received are Vertical and Horizontal Blanking signals. These blanking signals are used to
inhibit the generation of code data words for the duration of Blanking.
At the end of Vertical Blank-ing, the Timing and Control section starts a shift regi-
ster at Transfer rate. This shift register controls the generation of four code words used to control
the Decoder start time. The first word is a 30 bit Time Code Word generated in four segments.
This code is a fixed pattern of
000001000000010000000100000001
The next three code words are eight bits each and are the Vertical Sync code, Buffer Word and
the Absolute Value word.
The Vertical Sync code is used by the Decoder to start the decoding process. The
Buffer word is a spare 8-bit word of all zeros. The Absolute Value word is comprised of two bits
of Quantization Level information indicating level 4, 5, 6 to be used for the current horizontal
line only. The remaining six bits are a real data value used by the Decoder as a video level
starting point.
Horizontal Synchronization occurs at the end of Horizontal Blanking and generates
three 8-bit code words which are the Horizontal Sync code, Buffer word, and Absolute Value
word identical to those of the Vertical Sync time wi th the exception of the bit code of the
Horizontal Sync word.
The Operation of the Timing and Control is as follows: The T & C receives four
timing signals, 1) A 50 MHz clock, 1) Sample Rate, 3) Horizontal Sync (blanking), 4) Vertical
Sync (blanking).
As each Sample Rate is received, it is synchronized to the 50 MHz internal clock
and placed in a shift register to generate two timing pulses, the Ready Load and the Transfer.
The Ready Load is used to setup and strobe the T & C logic and to generate the Load Command to
the code generator. The Transfer pulse occurs immediately after the Ready Load and causes the
transfer of data in the various parallel registers to update for the next sample rate time. These
two pulses operate continuously at the Sample Rate.
24
Vertical and Horizontal Sync signals inhibit the generation of code words for the
duration of either signal (that is, the blanking time). This is accomplished by a second shift
register which synchronously inhibits Load pulses following the first Load pulse after the start of
blanking. Upon the end of blanking, either Horizontal or Vertical, the Load pulses are enabled
to start the next video line. The first words of the Video line are the Time Word and sync words
in the case of Vertical sync or just the three sync words in the case of Horizontal sync. The-
remainder of the line generates a code data word for each sample rate until blanking occurs.
Automatic Quantization avoids uncontrolled overflow or underflow of the Trans-
mitter Buffer. Since the Code Word is variable length, one bit to eight bits, the 30 bit word
rate out of the Encoder to the buffer varies. The average input and output of the buffer must be
equal and therefore it is necessary to provide feedback control of the encoder.
The Quantization is controlled by the Rate Buffer and is readjusted each Horizontal
Word time. The Buffer fill rate is determined by an Up/Down Counter which contains the current
fill rate at the end of each Horizontal I ine. This rate may be positive or negative since the
counter is preset to 128. The resultant count is compared to two fixed numbers each of which
may be one of two values selected by the Memory fill function.
The two numbers are compared against the Rate Buffer counter and fixes the QL of
the next line at one of three values depending whether the rate is positive, negative, or average.
The three QL values are 4, 5, and 6. The Video resolution is reduced from 6 to 5 or 4 bits as
the QL goes to 5 or 4. A low rate selects QL6, an average rate selects QL5, and a high posi-
tive rate selects QL4 to reduce the rate of Buffer fill.
Once the Quantization level has been selected for the next horizontal line, the
QL shifts the input Video data down zero, one, or two bits creating a six, five, or four bit
resolution. The lower the resolution, the fewer large picture value changes take place and
more 'no change' or one to three bit changes occur. This transfers the work load from 8-bit
Remainder codes to one-bit Delta zero and three-bit Delta one codes which cause a lower fill
rate.
The shifting of the Video data words to 5 or 4 bits is compensated for in the Decoder
by storing the current QL value of the Absolute Value word and reverse shifting the reconstructed
Video data word to produce a six-bit output of the Decoder.
The Transmitter Buffer memory has a buffer empty signal (four words left) which
forces the Code Word Selector to produce a series of eight-bit Remainder code words to generate
a positive fill function to keep the memory from becoming empty. This may happen at any time
during the code generation time.
25
Transmit Rate Buffer Subsystem - A3A1A4
A2-2.7.1 Rate Buffer
The transmit rate buffer accepts data from the data compressor or statistical encoder,
assembles it into 30-bit words, and writes the assembled word into memory. It reads 30-bit words
and sends them to the multiplexer when required. The buffer subsystem also formats the input TV
and buffer synchronization words and calculates the buffer sync word. Blanking fill words are
inserted into the multiplexer when required.
A2-2.7.2 Detail Operation
The Transmitter Rate Buffer is a 512-word, 30-bit per word high speed memory.
This buffer is based on analysis which shows that a larger buffer does not improve system perform-
ance.
TV video has active periods of a specific time duration (active portion of a line)
and completely inactive periods also with a specific time duration (blanking). During active
periods, data is going into and out of the buffer' thus, buffer fill may increase or decrease. Since
only buffer output occurs during blanking, buffer fill will decrease at a rate determined by the
transmission rate while horizontal or vertical blanking occurs. Due to the distributed nature of
horizontal blanking in a field, buffer fill during a field will roughly resemble a sawtooth wave-
form at line rate, superimposed on a larger sawtooth at field Fare.
TV frame activity changes slowly enough that a sequence of many fields will have
approximately equal activity. If significant increase in buffer fill occurs over a complete field
(including blanking), any feasible size buffer would overflow before the activity could be
expected to decrease. For example, assume that data activity does not change significantly over
100 fields (about 1.7 seconds); the net buffer fill per field can only be 1/100 of the total buffer
size. Even for a 3,000-word buffer, this is only 30 words per field. At a transmission rate of
9 megabits there are 15,000 10-bit words per field (9 x 106 bits/sec x 1/60 sec/field/10 bits/
word). Thus, the extra 30 words per field are a small fraction (0.2 percent) of the total words,
and would not significantly improve the picture. Therefore, the buffer may as well be sized so
that it can be emptied during vertical blanking. Fora vertical blanking time of 1250 psec anda
maximum transmission rate of 9 x 106 bits/sec or 0.9 x 106 words/sec, the maximum buffer size
required in the DC/EC Test System is 1250 (0.9 x 106) = 1125 words. The buffer size provided
is 512(3) = 1536 words. Lower transmission rates have a smaller buffer requirement.
The transmit rate buffer consists of the random access memory and the buffer control
logic shown in Figure A2-2.7.2.
The transmit buffer has two sources of input data. Consider first the reception of
data from the Reducer. The 10 data lines from that source are updated each sample time. When
the data present represents a nonredundant sample, a signal (Flag XX) is sent to the timing and
26
A2-2.7
Frn duar
1) Data 2) Flag
Frac Statistical
Encoder
Peg.
30 bitso M ultiplexer
Figure A2-2.7.2. Transmitter Rate Buffer Block Diagram
27
control (T&C); there it is gated to one of six 10-bit sections in two 30-bit buffers and causes
the selected section to accept the data. The same signal then updates a Mod-6 counter in the
T&C and qualifies the selection of the next 10-bit section.
The Mod-6 counter is decoded so that when one of the 30-bit buffers is filled, a
write request is generated. Coincidentally, unless a prior request is still pending, the data in
the filled 30-bit buffer is transferred to the 30-bit input buffer. Under worst-case conditions,
4 of the 6 available 10-bit sections will be filled before a transfer can be made to the 30-bit
input buffer. This happens when: 
1. The reducer finds nonredundant samples in 8 adjacent sample periods, and
2. The sample rate is 9 MHz, and
3. The write request decoded from the Mod-6 counter occurs at the beginning
of a memory read cycle.
Data from the 30-bit input buffer is routed to the statistical decoder logic where
it is qualified by a mode selection switch before being gated to the memory.
When the T&C recognizes the write request, the mode line to the memory is set
low and a cycle initiate command (MRQ) issued. (Requests for memory service are handled on
a priority basis so that if read and write requests occur coincidentally, the write request will
be serviced first.) Once the write cycle is completed, the T&C increments the write address
counter by 1 count.
If the Statistical Encoder unit is selected, operation is as follows. 30 bits of data
are supplied to the memory inputs through a set of gates. Write requests decoded from the
Mod-6 counter are inhibited and in their place write requests from the encoder are serviced.
Thirty bits from the encoder require more than 3 sample periods to accumulate and the highest
encoder sample rate is 5 MHz; so, input buffering at the transmit buffer is unnecessary.
Output service can now be considered. Data readout of the memory is in
response to link demands. 30 bits are made available to the demultiplexer (demux). When the
first 10 of these are accepted from the 30-bit output buffer, the remaining 20 to be used are
transferred from the output buffer to the 20-bit buffer.
The demux signals its acceptance of the first 10 bits when it sends a read request
(TV3) to the T&C. While the demux uses the remaining 20 bits, the T&C services the request
and loads a new 30-bit word into the output buffer. When the read cycle finishes, the read
address counter is incremented by 1 count.
Bits 1 through 10 of the output buffer are decoded in an "and" gate to provide a
test point. In the ZOI/ZOP mode the point should sense vertical sync.
Next, consider generation of special words such as buffer sync and TV sync. At
the beginning of a horizontal line blanking period, the T&C will command the reducer to output
28
a horizontal sync word. If one of the two sections of a 30-bit buffer are filled with samples,
the T&C will enter a TV sync word in each remaining section and store the data. In the next
30-bit buffer's first two sections, the T&C will enter a TV sync word and then a buffer sync
word. This format was selected so that each TV line is represented by some whole number of
memory words, and so that the buffer sync word is always located in the middle slot next to a
TV sync word. The buffer synchronization scheme utilized in the Receiver buffer does not
require this formatting procedure, but no attempt was made to remove the generating logic from
the transmit buffer.
The buffer sync word, used in the statistical encoder, is calculated by subtracting
the address difference (write-read), from the maximum buffer size selected.
.--
At vertical blanking time the same sequence is used as at horizontal blanking time.
The important difference, however, is that the sequence is started at about 1 Psec before the
end of vertical blanking. -
Fill words are generated when the memory is empty and TV blanking time is
occurring. Generation is carried out in two ways. When the ZOI/ZOP mode is used, the T&C
commands the reducer to generate fillwords. These are then passed through memory in the normal
manner. In the statistical encoder mode, the T&C answers demux requests by loading fillwords
directly in the 30-bit output register.
A2-2.8 Rate Adaptive Tolerance Generator- A3A1A1
The tolerance generator produces a 4-bit tolerance that is a function of the actual
buffer fill rate and the desired fill rate. A minimum tolerance is switch selectable along with
the desired buffer fill rate. A fixed tolerance mode is provided that outputs a switch selectable
fixed tolerance to the data compressor.
A2-2.8.1 Detailed Description
The tolerance generator makes use of the average rate of buffer fill in determining
tolerance. This provides feedback to the data compressor as a control on buffer fill. This con-
trol is accomplished by increasing tolerance when the buffer fill rate increases and decreasing
tolerance as fill rate decreases. This control makes use of the general rule that increasing
tolerance decreases the average rate of occurrence of nonredundant samples thus decreasing
buffer fill rate. Figure A2-2.8.1 is a block diagram of the tolerance generator.
Two counters are used to determine the average rate of buffer fill, to compare
this rate to a desired fill rate, and to generate an error signal which is used to modify tolerance.
One counter, the NRS counter, starts from a preset negative bias obtained from 5 bias switches,
and counts the 10-bit words that are loaded into the transmitter buffer. The other 5-bit counter
counts the samples that are loaded into the data compressor. Every 32 input samples this last
counter interrogates the NRS counter and presets it to the selected bias and another counting
cycle begins. The value of the NRS counter when sampled is equal to the difference between
29
40
MULTIPLIER
CONSTANTS
TOLERANCE
SWITCHES
TOLERANCE MODE
SWITCH
Alou_
Figure A2-2.8.1. Tolerance Generator Block Diagram
30
BIAS FROM
5SWITCHES
the desired number of nonredundant samples (represented by the bias) and the actual number of
nonredundant samples that have occurred during 32 input sample times. In other words, the
counter sample is a measure of the difference between actual and desired buffer fill rates and
is a suitable error signal for the buffer fill rate control loop. The desired buffer fill rate can
be shown to be a function of the transmitted information rate and the input sample rate. The
bias is thus programmed as a function of these two parameters. o
The NRS counter value observed at the end of each 32 sample period is processed
by a binary multiplier. The switch selectable multiplication factors are 4, *2, 1, 1/2, and 1/4
and may be'selected independently for positive and negative NRS counter results. The resulting
number is used as a tolerance modifier (ATOL). ATOL is the error signal of the control loop.
If it is positive, the actual buffer fill rate is greater than the desired fill rate, and tolerance is
increased in an attempt to reduce the actual fill rate. Tolerance reduction results when the
actual fill rate is less than the desired value. This is accomplished by adding ATOL to the
previous tolerance which is stored in the 4-bit tolerance register.
The new tolerance is now compared with the minimum and maximum tolerance
values. Maximum tolerance is 15 due to 4-bit tolerance. Minimum tolerance, which is required
due to noise on the input A/D signal, is determined by4 tolerance switches. When the trans-
mitter buffer fills up, the nonredundant sample rate changes to the transmitted 10-bit word rate.
Since this rate may force the tolerance generator to reduce tolerance at a time when tolerance
should be large, the buffer full signal from the transmitter buffer is used to force tolerance to its
maximum value.
The 4 tolerance switches mentioned above are used to set fixed tolerance when the
tolerance generator is in the fixed tolerance mode. In this mode rate adaptive tolerance con-
tinues to be generated, but the tolerance switch values are gated into the tolerance register
instead of the adaptive tolerance.
A2-2.9 Voice Encoder - A3A3A4
The Voice Encoder digitizes an audio signal to a 20 K bit data stream. Analog
amplitude compression is available at the voice encoder input. The digitizing technique is high
information or variable slope delta modulation, a method which has been demonstrated to be
somewhat superior to other digitizing methods at low bit rates.
The voice compressor consists of an operational amplifier with a diode break
type nonlinear feedback circuit. When the voice input is 50 mV, the current in the feedback
network is low, and all the diodes are reverse biased. Thus, the equivalent feedback resistance
is about 32 K ohms, giving a small signal gain of 30 dB. As the input voltage increases to a
maximum of 5 V (60 dB over 50 mV) the diodes successively turn on, giving a small signal gain
of 0 dB at 5 V input. Thus, the output range is 30 dB for a 60 dB input range, giving a com-
pression ratio of 2:1. The voice compressor may be bypassed. In the bypass mode, the audio
input signal must be less than 5 V peak-to-peak maximum.
31
The Voice Encoder (Drawing 528729) contains a voice compressor, which com-
presses the normal 60 dB voice range into 30 dB, and a high information delta modulator, which
encodes the voice output into a digital data stream. Input impedance may be selected to be
600 or 50 ohms.
The high information delta modulator has a modulator and a demodulator. The
modulator encodes the voice information from the compressor into a serial data stream. The
demodulator generates a feedback signal which is used as an error indication in the modulator.
The audio is fed to one input of a comparator, and the demodulated signal from the
demodulator is fed to the other input. The comparator operates a transistor driver stage, and
is powered by +15 volts power regulated to +12 and -6 volts by zener diodes. When the incoming
voice signal is larger than the feedback signal, the transistor is switched on and the comparator
output is a logic zero. When the voice input is smaller than the demodulated feedback signal,
a one is generated.
The comparator output is sampled at a 20 kHz rate on the clock high going tran-
sition by a D flip-flop. The flip-flop output drives the input of a 2-bit shift register. Decoding
circuitry on the outputs of this shift register operates commands to a 4-bit shift left/shift right
(SLSR) register in accordance with the following table.
A follows B follows C
A ' B / C Shift Left
A ' B = C Shift Left
A = B C Hold
A= B C Shift Right
The low going transition of the clock strobes the shift left, shift right, and hold
commands into two flip-flops. One of these controls the "mode" input of the SLSR, which
determines the shift direction. The other flip-flop disables the clock to the SLSR for one bit
period when a hold command is present at its input.
The SLSR shifts ones in from the left and zeroes in from the right. Four "exclusive-
OR" gates on the SLSR outputs compare the outputs with the comparator output to generate a 5-bit
ones complement output code. The "exclusive-OR" gates and comparator output operate transis-
tor drivers. The comparator output, which is used as the sign bit, is buffered for the modulated
voice output.
The outputs of the transistor drivers go to a resistor network at the input of the
demodulator. The demodulator consists of an op amp integrator. The input network is designed
so that when the SLSR shifts right the output slope of the integrator is doubled. When the SLSR
shifts left the slope is halved. When the SLSR state is all zeroes, the normalized slope of the
32
integrator is +1 when the sign bit is a one, and -1 when the sign bit is a zero. Thus, as the
SLSR shifts right, slopes achieved will be 1, 2, 4, 8 and 16.
From the table, it is seen that if the previous three bits were identical, indicating
a large error between the voice signal and the demodulator output, the SLSR shifts right and the
demodulator slope is doubled to help the demodulator "catch up" to the voice input. If the '
demodulator "catches up" at a time when its slope is large, the sign bit changes, resulting in a
polarity reversal of the demodulator slope, and the slope is halved. For step inputs this results
in an underdamped characteristic, but for most audio signals, reproduction will be better than
with other voice encoding methods.
A2-2.10 Information Rate Timing - A3A2A6
The transmitter information rate timing circuit (Figure A2-2.10) generates clock
signals at frequencies of 1 through 9 MHz variable in steps of 1 MHz. Depending upon the coding
technique used, a clock (bit rate) of either two times or three times the information rate, syn-
chronous with the information rate, is also generated. Other clocks that are generated for use
elsewhere in the system are at frequencies of 18 MHz, 1 MHz, 50 kHz, and 20 kHz. The 18 MHz
clock is used in the transmitter rate buffer. The 1 MHz clock is used as a reference to generate
the sample rate clock and the coherent 9 MHz for the TV Sync Separator. The 50 kHz clock is
used in the multiplexer, while the 20 kHz clock is used by the voice encoders.
The transmitter information rate timing circuit has five digital clocks operating at
frequencies of 30 MHz, 36 MHz, 42 MHz, 48 MHz, and 54 MHz. These clocks are divided
down to the desired information rate, and two times or three times information rate frequencies
by means of a programmable counter circuit and appropriate switching circuitry. The positions
of the information rate code switches on the front panel are decoded to determine the mode of
operation of the information rate down counter circuitry. A presettable down counter further
reduces the information rate to 1 MHz. Additional down counters reduce the 1 MHz signal to
50 kHz and 20 kHz clocks. An 18 MHz clock is produced by dividing the 36 MHz clock
osci I lator output by two.
The outputs of these clocks are buffered by high speed Shottky logic gates and
go immediately into programmable divide-by-two or divide-by-three counters. The output of
the divide-by-two/divide-by-three counter is at 1/3 the frequency of the input signal when the
program line is a logic "1." The output is 1/2 the input frequency when the program line is a
logic "0." The clock frequencies are thus immediately divided by either two or three to obtain
frequencies which can be more easily handled by the clock switching circuitry. The switching
circuitry consists of five Shottky gates with enabling lines and an 8-input high speed gate.
The highest frequency that will be seen by the 8-input gate is 27 MHz. Folowing the clock
switching circuitry is a programmable divide-by-5 gate which may be used to obtain some
information rate frequencies. After the switchable divide-by-5 circuit, there are two more
divide-by-two/divide-by-three circuits, whose outputs go to the switching circuit. It is at the
33
0X2/X3
V IT 1/3 > DOWN CUUNTI
I.R. BCD-UNITARY OUTPUT OUTPUT 2R CK/X3
IN 4 DECODE / SELECT SE IR CLOCK
9 DECODELr~~~~~~" I.R. CLOCK
MH~~~~~~~. ~~~10 MHz CLOCK
-2 50 kHz
COUNTER CLOCK
4/ ~ RESENT__,q OiE/ DECODE -:5 20 kHz
COUNTER CLOCK 86185-6
Figure A2-2.10. Transmitter Information Rate Timing Block Diagram
34
output of these switching circuits that the information rate and two or three times the information
rate clocks are taken.
To illustrate the operations of the decoding circuitry and information rate down
counters, let us assume it is desired to obtain a 3 MHz information rate with a code 1/3. The
information rate switch on the front panel will be set to 3, and the code switch on the front
panel will be set to Viterbi 1/3. The VIT 1/3 input of the transmitter information rate timing
circuit will be a logic "0," and the IR 2 and IR 1 lines from the information rate switch will also
be at ground. The BCD to decimal decoder in the decoding circuitry will ilterpret the BCD
input from the information rate switch and its output in conjunction with the VIT 1/3 line will be
decoded to enable the proper circuitry to obtain an information rate of 3 MHz. The clock sig-
nals will all be divided by 3. The 54 MHz clock will be selected so that the input to the rest
of the down counting circuitry is at a frequency of 18 MHz. The divide-by-5 counter will not
be used, and thus the signal will go to the second divide-by-two/divide-by-three counter stage.
This counter stage will be set to divide-by-two to obtain a frequency of 9 MHz, and its output
will be selected to be the times 3 information rate clock. The final divide-by-two/divide-by-
three counter stage will be set to divide by three to obtain a 3 MHz signal. Its output will be
selected to be the information rate clock. In a like manner, any other required combination of
information rate and two or three times information rate can be generated from one of the clock
oscil lators.
An 18 MHz clock signal is generated for use in the transmitter rate buffer by
dividing the output of the 36 MHz clock oscillator by two. This is done by a flip-flop.
To generate the one MHz clock the BCD input from the information rate switch
on the front panel is applied to one set of inputs of a 4-bit adder. The other inputs are hardwired
to a count of 10. Since the BCD input from the information rate switch is inverted, the output
of the 4-bit adder will be 10 minus the information rate. This is applied to the data inputs of
a 4-bit synchronous decade counter. The carry output of the counter is connected back to the
load input by an inverter. Thus, when the counter reaches its full count, it will load 10 minus
the information rate into the counter. Since the counter is run from the information rate signal,
the signal at the carry output will be at a frequency equal to the information rate clock divided
by the information rate, or one MHz. When the information rate is set to 1 MHz, the
synchronous counter is disabled and the information rate is routed directly to the 1 MHz output.
To generate the 50 kHz and 20 kHz clock signals, the 1 MHz clock is first divided
by 10 by a decade counter. This generates a 100 kHz clock which is divided by two to obtain
the 50 kHz clock and by five to obtain the 20 kHz clock.
A2-2.11 Sample Rate Clock - A3A2A6(A7)
The transmitter sample rate circuitry (Figure A2-2.11) generates a programmable
clock from 1 to 9 MHz phase locked with the information rate clock.
35
SAMPLE
OUTPUT ,, RATE
BUFFER CLOCK,
OUT
86185-7
Figure A2-2.11. Transmitter Sample Rate Timing Block Diagram
36
1 MHz
IN
SAMPLE
RATE
IN
To generate the programmable 1-to 9 MHz clock output, a phase-lock loop is
employed which phase locks this clock output to the one MHz reference output of the information
rate timing circuits. The center frequency of the phase-lock loop is selected by the sample rate
selector switch on the front panel.
The one MHz reference signal is applied to a phase detector and is compared with
a one MHz feedback signal from the phase-lock loop. Phase lead, or lag, is detected and
filtered by a loop filter. The output of the loop filter drives a voltage-controlled oscillator.
For a sample rate of one MHz, the one MHz reference input is routed directly to the output.
The sample rate output frequency is divided down to one MHz by a presettable
synchronous down counter, and this signal is applied to the phase detector to be compared with
the reference input. The center frequency of the voltage-controlled oscillator is selected by
varying the dc offset of the loop filter output. This is accomplished by means of five relays,
each one of which switches a different offset voltage at the output of the loop filter. The relays
are selected by a decoding circuit.
The synchronous upcounter is preset to a count which is equal to 10 minus the
sample rate selected on the front panel switch. This number is derived by adding the inverse
of the sample rate in BCD to a fixed count of 10. This is accomplished using a 4-bit binary full
adder. The outputs of the binary full adder are applied to the data inputs of the synchronous
upcounter. When the upcounter reaches a full count, its carry output is routed to its load input
so that the number generated by the binary full adder is loaded into the counter on the next clock
pulse. Thus, instead of starting at 0, the counter will start at a number which is equal to 10
minus the inverse of the sample rate. Thus, the frequency of the output of the synchronous
upcounter will be equal to the sample rate clock divided by the sample rate, or one MHz.
A2-2.12 Time Division Multiplexer - A3A2A1
The function of the Time Division Multiplexer is to generate a serial stream of
continuous bits in the proper format and at the selected rate to the Channel Encoder.
The data from the audio sources, the PCM source and the TV data from the Rate
Buffer are time division multiplexed in a predetermined format sequence. A predetermined
sequence of 30 bits for frame synchronization is generated at the beginning of each frame in
order for the demultiplexer in the receiver to identify thestart of each frame. The multiplexer
(Figure A2-2.12) is designed such that the frame rate remains constant for different selections
of information bit rate. If, for example, the information bit rate is changed from 4 MHz to
8 MHz, the number of bits in the frame are doubled such that the frame rate does not change.
A2-2.12.1 Format
The format of the data frames is as follows (see Figure A2-2.12.1): The first
30 bits of the frame are devoted to the sync pattern. Bits 31 through 34 are for Audio 1 source.
37
SELECTED
Figure A2-2.12. Time Division Multiplexer
38
o,=
co 
I
0 ) 
0
04
0'
II ~~~~~~~~~O
is~~~ - 4 
... 
uJ >~ 
E0
Q ._ In ~~~~~~~~~~x
O 
°~
CJ
C s o 
CN
en
I- cm I
o hE
CV,~~~~~~~~~~~~~~~~~~~~~~~~*o o
LU~~~~~~~~~~~~~~( L.
z
tn
I-~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~.1
O
I-
39
Bits 35 through 38 for Audio 2 source. Bits 39 and 40 are fill bits. Bits 41 through 50 are for
the PCM source The remaining bits (150) are for TV data. Each data sample and associated
time tag occupies 10 bits. Thus, an information bit rate of 1 MHz has a frame length of 200 bits.
If the information bit rate was 2 MHz, the frame length would increase to 400 bits. The first
50 bits of the frame would remain the same as the 200 frame length case, but 200 bits of TV data
would be added to the frame length. This procedure continues and for the case of 9 MHz selected
information rate, the frame length would be 1800 bits. Thus, the frame rate remains constart
at 5 kHz for any selected bit rate.
A2-2.12.2 Frame Rate Counter
The overall timing for the multiplexer is derived from the information rate clock
and the selected information rate control. The information rate clock comes from the transmitter
clock subsystem and covers a range from 1-MHz to 9 MHz in 1 MHz increments. The selected
information rate control is four lines of BCD information from the front panel. Since the frame
rate remains at a constant 5 kHz for any selected information rate, the selected control repre-
sents the multiple of 200 bits in a frame. The frame rate counter consists of 3 decade counters
and a divide-by-2 counter. At the start of a frame the counters are reset and start from a count
of zero. The counter is incremented by the information rate clock. The third decade counter
is compared with the BCD number for the selected rate control and is allowed to increment
until the count equals the BCD number from the selection rate control. Thus, the third decade
counter is being reset at a rate equivalent to some multiple of 200 bits.
A2-2.12.3 Data Source
There are four sources of data which comprise the Time Division Multiplex format:
a. Sync Pattern
The sync pattern 3564622552 (octal) is inserted in each frame of the format.
These sync bits are hard-wired to the inputs of the multiplexing gates.
b. Audio Channels
The multiplexer interfaces with two sources of 20 kHz digital audio data. A
continuous 20 kHz clock is presented along with the audio data to the multi-
plexer. Since the frame rate is 5 kHz, four bits of audio data are generated
from two channels during each frame. A four-bit serial-to-parallel converter
is provided for each of the audio channels and the input data is shifted into
these registers at the constant rate of 20 kHz.
40
c. PCM Data
The multiplexer interfaces with a 50 kHz serial PCM channel. A continuous
50 kHz clock rate is also presented from the multiplexer to the external unit.
The 50 kHz clock shifts the PCM data into a 10-bit serial-to-parallel con-
verter, composed of 2 5-bit shift registers.
d. Rate Buffer Output
The multiplexer interfaces with the 30 parallel data bits of the output of the
rate buffer. The 30 bits are transferred into the multiplexer 10 parallel bits
at a time. After the last 10 bits are transferred into the multiplexer, the
multiplexer generates a reset pulse to the rate buffer which enables the rate
buffer to access the next memory location and provides the next 30-bit
word to the multiplexer.
A2-2.12.4 Multiplexing Operation
A three-stage counter provides a 0-7 count to the 10 MSI multiplexers. These
multiplexers decode the count and individually enable the data inputs. The counter is incre-
mented every 10 bits by the output of the first BCD counter in the Frame Counter. At the start
of the frame (with the 3-stage counter at zero) the first 10 bits of the sync pattern are trans-
ferred into the output register. A bit count of 9 is detected, disabling the serial operation of
the output register and enabling the parallel input of the next 10 bits of the sync word. The
serial data flow is uninterrupted due to the output flip-flop which holds the tenth bit during the
load time. Continuing in this manner, the third set of 10 bits from the sync pattern is generated,
followed by the PCM and audio data.
After the first 50 bits have been multiplexed, TV data will be inserted into the
bit stream in 10-bit groups for the balance of the frame. This occurs on counts 5, 6 and 7 of the
3-stage counter. The counter will recirculate on these three counts until the end of the frame,
at which time the state of the counter is stored in two D flip-flops. The 3-stage counter will
be reset and the frame counter will start at zero, stepping the 3-stage counter every 10 bits as
before. However, after the first 50 bits have been generated into the bit stream the 3-stage
counter will step to the count it was in at the end of the previous frame, thus preventing loss
of continuity in the TV data.
A2-2.13 Convolution Encoder- A3A3A3
The functions of this unit are as follows:
a. Accepts serial data and clock (to 9 MHz) from multiplexer.
b. Accepts 1/2 rate or 1/3 rate clock from timing generator.
41
c. Accepts Fano/Viterbi enable from control panel.
d. With Fano enable and 1/2 rate clock it generates systematic codes with
constraint length up to 40 and polynomial terms up to 40 (switch selectable)
at input data rates to 9 MHz (i.e., output to 18 MHz).
e. With Viterbi enable and 1/2 or 1/3 rate clock it will generate nonsystematic
codes with constraint length up to 6 and polynomial terms up to 6 (switch
selectable);
f. Independent polynomial programming is provided for Fano and Viterbi so
that rapid change between Fano and Viterbi decoders can be made.
A2-2.13.1 Detail Description
The Convolution Encoder (Block Diagram, Figure A2-2.13.1) consists of a 40-bit
shift register, one bank of 40 polynomial switches, three banks of 6 polynomial switches, one
40-bit modulo 2 adder, three 6-bit modulo 2 adders and an output selecting 4-bit shift register.
In operation, serial data is loaded at information bit rate into the 40-bit shift
register. Each stage of this register drives 2 input gates which are enabled by the polynomial
programming switches. These gate outputs are wired directly to the four independent modulo
2 adders. The modulo 2 adders outputs are identified as PF' PV P V and PV3
When Fano has been selected, the data bit and PF are parallel loaded into the
output shift register at information data bit rate and are positioned to output the data bit first
at rate 1/2.
When Viterbi has been selected, PV, PV2, and PV3 are parallel loaded into the
output register at information data bit rate and are positioned for output in that sequence at rate
1/2 or 1/3. (Note: Only PV1 and PV2 get shifted to the output stage when rate 1/2 is selected.)
Feedback connections are provided so that the 40-bit shift register can be operated
as a length 63 pseudonoise (PN) sequence generator, by the addition of a jumper wire.
42
Figure A2-2.13.1. Block Diagram Convolution Encoder
43
A
A2-2.14 Noise Generator - A3A3A2
The noise generator is to provide a random noise signal with programmable amplitude
which can be summed with the output signal in the Transmitter Output Buffer to simulate a noisy
data link.
The noise generator consists of a noise source and a programmable attenuator. The
noise source has a 25 MHz bandwidth and a 1 V rms output amplitude. The attenuator is variable
from 0 dB to 22.1 dB in 0.1 dB increments.
A2-2.15 Output Buffer Amplifier - A3A3A1
The transmitter output buffer sums data from the Convolution Coder and noise from
the Noise Generator to generate an output data stream consisting of data plus noise. The data
amplitude and the output signal dc offset are controlled by front panel settings.
The transmitter output buffer (Drawing 528732) consists of a wideband operational
amplifier with a gain control on the data input and a fixed gain on the noise input. The gain of
the data input is controlled by a "Raysistor" in parallel with a fixed resistor. The impedance of
the Raysistor varies inversely with the voltage across its input. This input voltage is controlled
by an op amp whose voltage is set by a front panel control. The effect of varying the front panel
gain pot is to vary the voltage across the Raysistor and so to reduce its impedance. When the
impedance of the Raysistor is low, the gain of the output buffer amplifier From the data input to
the data output is high. When the voltage across the Raysisiot is zero, as it would be when the
front panel pot is set to zero, the gain of the data input to the data output is fixed by the ratio
of the input resistor to the feedback resistor.
The output offset is controlled by another front panel pot which sums a current into
the summing junction of the wideband op amp through a resistor. The offset may be varied from
approximately +4 V to -4 V at the data output by means of this Front panel control.
44
DETAIL RECEIVER DESCRIPTION
The following sections describe the individual units of the Receiver.
A2-3.1 Bit Sync-Signal Conditioner - Preprocessor - AI1(A2)
In Figure A2-3. 1. the block diagram for a High Bit Rate signalconditioner, bit sync,
and preprocessor is given. The signal conditioner consists of the matched filter and the multilevel
decision unit. In the multilevel decision unit seven threshold detectors are used in conjunction
with coding logic to effect an eight-level or three-bit decision on the state of the matched filter
output at the end of a bit period. Timing is controlled by the clock coming from the bit sync.
In this application, the only-preprocessing required is baseline correction, (DC
Restoration). In the preprocessor the positive and negative peaks of the noisy PCM are measured
and used to effect baseline correction.
For bit synchronization the matched filter output is passed through a circuit which
generates a bit rate spectral component. This signal passes through a bit rate center frequency
bandpass filter. The output of the filter is the input to a phase-lock loop where a vco is locked
to the bit rate component.
Those items with an asterisk in the block diagram are the functions which must be
changed in order to change bit rates. These functions are all.contained in a bit rate plug-in
module.
For quadraphase operation a second BSSC system is employed. The data from the
two units are combined in the Quad Phase Data Combiner, described in Paragraph A2-3.2.
The BSSC system can also be operated at a bit rate other than that of the plug-in
employed by use of an external clock. A circuit is provided allowing the operator to select the
bit synchronizer lock or the external clock. Thus, in this mode only the bit detector or signal
conditioner is used. Since the matched filter is designed to maximize signal-to-noise ratio at a
specific bit rate, some performance degradation will result when the filter is used at another bit
rate. The predicted degradation for the 27 MB and 18 MB plug-ins for various bit rates is given
in the following.
45
A2-3.0
u -coU
0 CX
-J~~~~~~~C
0
'A
0
0
L-
c
He
c~
0)
L.
O
c
O
.-
Is
0
C:
0
c~
0
c~
Ul
0)
C~
A)
0
I-2
0).
27 MBit PlIug-In Installed
Rate (MHz) Degradation (dB)
0
0.52
1.09
_1.76
2.27
2.56
2.86
3.52
4.32
4.76
5.27
6.52
8.27
9.52
11.27
47
Trans. Bit
27
24
21
18
16
15
14
12
10
9
8
6
4
3
2
18 MHz Plug-In Installed
Trans. Bit Rate (MHz)
18
16
vt ~15
14
12
10
9
8
6
4
3
2
More details of the Bit Sync/Signal Conditioner
Maintenance Manual for this unit.
Degradation (dB)
0
.51
0.8
-- 1 .1
1.76
2.56
3.0
3.51
4.76
6.51
7.76
9.51
r are contained in the Operating and
48
Quadraphase Data Combiner - A9A2
The function oF this unit is to interface between the two parallel Bit Synchronizers
utilized in the quadraphase mode, and the serial input to the convolution decoders. To accom-
plish this, the following operations must be performed:
a. The clock from Bit Sync A must be frequency doubled to generate a serial clock
for the convolution decoders. 
b. The data from the two Bit Synchronizers must be combined or multiplexed into
a single serial (3 bits wide) data stream. --
c. Provision must be to correct for all possible states of demodulator lock-up.
A block diagram of the unit is shown in Figure A2-3.2. Clock from Bit Sync A is
frequency doubled in the Clock Rate Multiplier and routed to internal registers and the Clock
Selector. Data from the two Bit Syncs is buffered in Input Registers, combined in the Multiplexer,
and stored in the Intermediate Data Register. The output of this Register, together with the out-
put of the Data A Input Register is applied to the Output Selector. This Selector is controlled by
the Biphase/Quad Phase switch, which also selects between Bit Sync A clock, or the frequency
doubled clock.
The required operations for the ambiguity resolver can be understood from the
following table. Assume that data streams I and Q are transmitted. These may appear at Bit
Sync A and B outputs in any of the following forms, depending on the state in which the
Demodulator locks.
Case Bit Sync A Bit Sync B
1 I Q
2 Q T
3 I Q
4 Q I
Each data stream may appear at either Bit Sync, either invertedor noninverted.
Case 3 is the inverse of case 1, and case 4 is the inverse of state 2. These complete inversions
are handled after the data is multiplexed in the Decoders. Thus, only the switching between
sync cases 1 and 2, the order reassignment and inversion of one channel, is performed in the
Combiner. This switching is performed in response to signals generated by the active convolution
Decoder and processed by the Quad Phase Ambguity Correction Flip-Flop.
49
A2-3.2
Viterbi (Maximum Likelihood) Decoder
This section reviews briefly some aspects of convolution codes and maximum likeli-
hood decoding, discusses the general functional organization of Viterbi Decoders, and then
describes the specific hardware in the Test System.
A2-3.3.1 Review of Decoding Process
The encoder for a rate 1/m convolutional code of constraint length k can be modeled
as a finite state machine possessing 2 k-1 states. Transitions from a given state are always into
one of two possible states and transitions into a given state are always from one of two possible
states. The coder input determines which transition occurs and the transition uniquely determines
the m-bit coder output. In Figure A2-3.3.1-1 we show a rate 1/2, k = 3 encoder and the
associated finitestatemachine in Figure A2-3.3.1-2. Figure A2-3.3.1-3 is called a trellis dia-
gram and is an alternate representation of the finite state machine in which a new set of states
have been drawn for each possible time increment. The operation of the maximum likelihood
decoder is probably most easily understood in terms of the trellis diagram and proceeds in the
following manner.
Starting from a known state (normally the all zero state at the beginning of the
message) the decoder hypothesizes the two possible extensions and computes and stores a metric
proportional to the log of the probability that the actual received m-bit branch was received
given the hypothesized branch was transmitted. It then proceeds to the next received branch,
extends each of the two hypothesized branches along the two possible paths, computes ihe appro-
priate branch metrics and adds these to the previously stored values to produce 4 path metrics.
The decoder continues in this fashion until it has hypothesized 2 k- 1 paths and has computed
2 k- 1 path metrics. Thereafter, the decoder extends each hypothesized sequence along the two
possible paths, computes the new path metrics, compares the two path metrics incident at each
of the 2k - 1 states and for each state discards the path having the smallest metric. Thus, the
decoder is constantly maintaining 2 k- 1 hypothesized sequences and 2 k- 1 path metrics. At each
step in the decoding procedure the paths which are discarded are those paths which cannot
possibly end up being the maximum likelihood choice since all possible extensions of the retaining
paths will always possess larger path metrics.
In Viterbi's original paper the actual sequence was selected by terminating the code
word with a known set of k-1 information bits. Consequently, when each of the last k-1 branches
was processed at the decoder, the paths were only extended along the branch known to have been
sent and after k-1 iterations the set of 2 k- 1 sequences was reduced to one sequence. This pro-
cedure, although academically satisfying, was unhandy since it required one to maintain code
word synchronization and also resulted in code rates that were not the ratio of small whole num-
bers thus necessitating rather complicated rate conversions. It was subsequently recognized that
is was unnecessary to terminate the code and that equally good results could be obtained with
unterminated codes and a fixed decoding delay L on the order of 5 or 6 constraint lengths. The
newer procedure was to maintain only the most recent L bits of each hypothesized sequence. After
each new branch was received and the sequences updated, the sequence possessing the maximum
path metric was selected and the last bit in this sequence was outputted while the last bit in each
50
A2-3.3
aa
L.
0J
C'
:B
E
0
U
-c
0
0
w(A
E
0
I-
a-0
a
CM
u
0
(N
C.).__
co
C~
02)
U-
51
Information 
Sequence I _
Figure A2-3.3.1-1. k = 3, Rate 1/2 Convolutional Code
1
Channel
Sequence
Figure A2-3.3.1-2. State Diagram For k = 3, Rate 1/2 Convolutional Code
State 0
State 1
State 2
State 3
00 00 00 00
etc.
- - Time
Figure A2-3.3.1-3. Trellis Diagram for k = 3, Rate 1/2 Convolutional Code
52
f
of the other sequences was discarded. This procedure obviously causes a slight performance
degradation in that it only approaches the maximum likelihood case as L-oo. Finite storage is,
however, a physical necessity and the procedure has the very definite advantage that it avoids the
rate loss associated with periodic resynchronization as well as the problem of rate buffering the
code blocks and maintaining the required block synchronization. There are, however, cases in
which the use of terminated codes is advantageous particularly in short burst communication .
systems and certain TDMA applications. Even in these cases, however, one would almost always
decode the first portion of the received word with a constant decoding delay and only make use
of the code termination to decode the last few constraint lengths of data.
A2-3.3.2 General Functional Organization of the Decoder
A machine which implements the decoding process described in the previous section
needs to perform the following functions.
It accepts at the input a continuous sequence of n-bit binary numbers which represent
the successive outputs of the channel bit detector quantized to one of 2 n levels and delivers the
decoded information stream at the output. The machine itself consists of (1) a synchronizer which
provides both branch timing information to the decoder and determines the correct bit polarity if
this is required, (2) a branch metric computer which determines the appropriate branch metrics
for each received code branch, (3) a path metric updating, comparison and storage device, in
which the branch metrics are added to the previously stored path metrics, the appropriate com-
parisons made and the new path metrics stored, (4) a device for updating and storing the hypoth-
esized information sequences, and (5) an output decision device which provides the decoder
output and also provides information to the synchronizer. Each of these devices is discussed in
turn in the remainder of this section and the design tradeoffs are elaborated upon.
A2-3.3.2.1 Decoder Input
The decoder input is provided in the form of an n-bit binary number by the bit detec-
tor. The bit detector would normally consist of a matched filter (or suitable approximation) fol-
lowed by an A/D converter.
There are three interrelated parameters which need to be determined. These are
the number of quantization levels, the spacing between quantization levels, and the number of
bits that will be used to represent the branch metric. A particularly simple ad hoc scheme is to
use 3-bits (8-level quantization) with equally spaced levels, and a uniform 3-bit metric associated
with a single channel bit. That is, the metric would be allowed to take on the values 0 through
7 depending on how closely the received channel bit matched with the hypothesized channel bit.
Computer simulations have verified that with additive Gaussian noise this scheme works very well
and provides a level ofperformance that differs from that possible with extremely fine quantization
by only a few tenths of a dB. Computer simulations have also verified that the quantizing range
is not critical and that the probability of decoded bit error exhibits a broad minimum as a function
53
of the spacing between levels with a near optimum setting occurring when the highest slicing
level in the A/D converter is chosen to be 1/2 a quantization level below the expected value of
the received signal.
A2-3.3.2.2 Branch Synchronizer
The synchronizer is simply a device For inserting commas (detersmining the beginning
and ending of a branch) in the received bit stream and resolving bit polarity when required. The
operation of the synchronizer is straightforward and simply requires an indication that the input
sequence contains a much larger number of errors than normal. Several techniques are possible
and almost any way that one can get an error detecting indication will work. One method for
which there are many possible variations is to look at the rate at which the path metrics are
increasing. A second method and one that-is particularly simple to implement is to check the
oldest bit in each of the 2 k-1 hypothesized bit streams and determine whether or not all of the
bits are unanimous. In the absence of excessive channel noise, the number of nonunanimous
decisions is very small whereas with a bit slip or polarity inversion the effective channel noise
is sufficiently large that nonunanimous decisions will occur a large percentage of the time.
Consequently, one need only count the number of unanimous decisions that occur in some fixed
block length and compare the value with a threshold.
A2-3.3.2.3 Branch Metric Computer
For rate 1/m codes, 2m different branch metrics need to be computed each bit time.
If the uniform assignment method discussed previously is used, then the computation is relatively
straightforward. For example, if the convention is adopted that the binary number 000 corresponds
to a highly reliable received "0" and the numbers 001, 010, etc., indicate received zeroes with
decreasing reliability, then the branch metric computer simply inverts this number of obtain the
channel-bit metric associated with a hypothesized "0" or does nothing to it to obtain the channel-
bit metric associated with a hypothesized "1. " To compute the branch metric, it need only sum
the individual bit metrics that make up the branch.
A2-3.3.2.4 Path Metric Updating and Storage
In this portion of the system the received branch metrics are added to the previously
accumulated path metrics, the appropriate path metrics are compared, and the largest value in
each comparison is retained. Both this portion of the machine and the portion that stores the
hypothesized information sequences account for the greatest portion of the parts that are used so
it is in these two areas that the greatest care need be taken in design in order to avoid excessively
large part counts. A useful modularizing concept can be developed if we number the nodes in
the trellis diagram from0 to 2 k- 1 -1 starting with the uppermost node. In this case it is easily
verified that the two descendants of states j and j + 2 k-2 (0< j < 2 k- 2 ) will always be states 2j
and 2j + 1 where state 2j is always the "0" extension of j and j + 2 k- 2 and 2j + 1 is the "1"
extension. Thus, one may implement this portion of the decoder by repeated use of a module
54
which enables one to determine the four possible path metrics corresponding to extensions of
states j and j + 2 k-2, make the required comparison and restore the new path metrics for states
2j and 2j + 1. The repeated use of the module may be accomplished by time sharing For a very
low speed machine or by actual duplication of the module for very high speed. In between a
large number of serial and parallel combinations are possible and a detailed discussion of the
tradeoffs is beyond the scope of this section. In addition, the basic module itself may be imple-
mented using all parallel adds and compare operations or it may be done using a serial add followed
by a serial compare. A still different variation is to implement the module so that the new metric
for state 2j and 2j + 1 areformedsequentiallyusing thesamemodule. In theact'ual machine discussed
in the following section, we went somewhat beyond the "fully parallel" case and actually doubled
up on this module so that the add and compare operations could be done simultaneously to achieve
high speed operation.
The metric values themselves may be stored in a long serial register for very low
speed operation, or in some combination of serial and parallel storage at higher speeds. Here,
again, the number of combinations is very large and.the optimum choice will depend on the
specific application.
One further point needs elaboration, however, and that regards the size of the
metric registers. Fortunately, the difference between the smallest and largest metric can easily
be shown to be bounded by (k-1)M where M is the maximum value of the branch metric. For a
rate 1/2, k = 6 code using a 3-bit metric for each channel bit, the value of M is 14 and thus the
maximum difference is 70. Consequently, a 7-bit metric register is completely adequate although
for convenience and ease of rescaling one would probably use 8-bit registers.
A2-3.3.2.5 Storage and Updating of Hypothesized Information Sequences
The basic modular aspect of this portion of the decoder is identical to that of the
metric storage device discussed in the previous paragraph and in some cases the devices are com-
bined. In concept this device consists of 2 k- 1 registers capable of storing L bits each. Normally
one would reserve Fixed storage locations for the sequence associated with each state although
this is not necessary. The registers must be interconnected such that the contents of the registers
corresponding to states j and j + 2 k- 2 can be transferred to the registers corresponding to 2j and
2j + 1. Control must be such as to allow for all four possible ways of transferring the sequences.
In addition, a means must be provided for removing the oldest bit from each sequence during
the transfer operation and appending a new bit. The new bit is always the binary number corre-
sponding to whether the new sequence came from state j or state j + 2 k- 2 and will be zero if the
former is true and one if the latter is true. This bit does not correspond to the most recent bit
in the trellis but to the one k-1 branches back.
A2-3.3.2.6 Output Device
Several techniques are available For providing the decoder output. The best, of
course, is to select the sequence possessing the largest path metric and choosing the oldest bit
in this sequence. In a high speed fully parallel machine, however, this requires a considerable
amount of logic and may not be cost effective. In general, we expect all of the sequences will
55
I2
have "merged" by the time the decoding depth has been reached so that all paths in the trellis
collapse into a single path. In this case one could just as well choose an arbitrary sequence and
output the oldest bit. A method somewhat inbetween the two from a performance viewpoint is
to make a majority decision over all sequences. Many other combinations are obviously possible
but probably not practical. Obviously, some degradation takes place by using one of the sub-
optimum techniques, however, they may be overcome by extending the decoding length. If,.
for example, a decoding depth of say 18 is adequate to achieve a given probability oF error using
the maximum correlated sequence technique, then something on the order oF 25 will be required
using the "majority vote" technique and 30 using the arbitrary sequence technique. All manner of
trades are available and the right choice depends upon the logic line and implementation rate.
A2-3.3.3 Block Diagram Description
Figure A2-3.3.3-1 shows a detail block of the Viterbi Algorithm Decoder. Data
from the bit synchronizer via the Q-P Data Combiner is loaded into the branch synchronizer which
establishes branch sync. The branch synchronizer output is stored in input registers. Eight 3-bit
adders than calculate the incremental correlations. A group of registers called the SC registers
store the survivor path correlations. At each branch the survivor path correlations for 2k paths are
calculated. These are compared and 2 k- 1 paths are discarded. This is performed by the comparators
and SC selectors. The outputs of the comparators are fed to the register exchange logic (survivor
sequence registers) where 2 k- 1 survivor paths are stored. The decoder output is determined by
the most ancient bit stored in each survivor sequence. The output is determined by the logic
state of the bit which is in the majority.
This decoder is designed to handle codes up to constraint length, k = 6, with three-
bit quantization. Shorter constraint length codes are handled as special cases of k = 6 codes.
Additional details will be included in the detail discussion of the various sectionsof the decoder.
The discussion to follow will be for the implementation of a 3-bit quantized, rate
1/3, k = 6 decoder.
Reference may be made to the Viterbi Typical Timing Diagram (Figure A2-3.3.3-2).
56
I I-
I8
ID,.
i 
I - 4. - I
EI 1
te
I...II t I ~ ~~~~~~~1 l-'.1'::::: .. . ......... il
I oJiAn i EouiE'oI L ~-'(T . .,AROL.S ; P. ''
41N~ - Lt 1--0 
_ ~ ~~ 1CA-7,
AD INCLL-c * , 0.t ,$NS" . - , t-. .SAt7/I -- . - t. - .. R
-.- ~ ~ 1-_b iZI)e>v RK
T
D 9147 
CLE:. 7 _'7-OUZ ANCC! .O I
2
X
I
57
3 2 I
.1
OVTFVT
D
4
C
i-
B
4
I - I
-I7r,r
F-
j
I
D
TI
DQO, Ll 0 UTh ER i,,I Z
PAGES 58 THROUGH 80 INTENTIONALLY LEFT BLANK
58
INPUT DATA
BIT CLK ----
DATA LOADED
IN BRANCH SYNC
BRANCH CLK
DATA TRANSFERRED
TO INPUT REGISTER
DATA LOADED INTO
SC REGISTER
SS REGISTER
OUTPUT DATA
GR SYNC CLK 
Figure A2-3.3.3-2.
l J
Viterbi Typical Timing Diagram
81
1 I
86185-12
I I ! I I I I
I I I I I I
I I
I I
I i
A2-3.3.3.1 -Branch Synchronizer
The decoder receives data from the bit synchronizer at bit rate and stores the data in
the formatting register. The complete specification of a branch input consists of three 3-bit words
for rate 1/3. Each word is a 3-bit quantization of a bit in the received sequence. If branch.
synchronization has been established, the three words are assciated with a branch in the code tree.
The quantized data is represented by a sign and two magnitude'bits. A maximum one
is 111 and a'maximum zero is 011, a minimum one is 100 and a minimum zero is 000. However, the
Viterbi operates using a code ranging from a maximum zero of 000 to a maximum one of 111. This
conversion occurs in the formatting register. The formatting register is a temporary storage register
that receives3three-bit words and then transfers the 9 bits in parallel to the input register. This
data has five ways to be out of synchronization: 1) phase inversion, 2) one-bit slip, 3) one-bit
slip with phase inversion, 4) two-bit slip, 5) two-bit slip with phase inversion. For a rate 1/2
code the two-bit slip modes are not possible.
The branch synchronizing is accomplished by a trial and error process. With high
probability bits at various depths in the survivor sequences should be unanimous on the bit decision
if branch synchronization has been established. These depths are 16, 22, 27, and 32 for k = 3,
4, 5, and 6, respectively. These depths are switch selectable by switches located on the logic
panel.
The actual implementation uses two counters, one counts branch times and the other
counts nonunanimous bit decisions. The branch synchronizer has two modes of operation: 1)
search and 2) lock. When the branch synchronizer is in the search mode, it requires the threshold
to be exceeded by the nonunanimous bit counter before trying another branch position. The branch
synchronizer alternately phase inverts and slips a bit until sync has been established. The thresholds
are 60 and 30 For k = 5 or 6 and k = 3 or 4, respectively. If the threshold is not exceeded during
255-bit times, then the branch synchronizer is assumed to be in the lock mode. Once sync has
been established, the threshold must be exceeded twice before the branch synchronizer will try a
new branch position (refer to branch synchronizer flow diagram Figure A2-3.3.3.1i-1).
When the branch synchronizer goes to a new sync position, it generates a clock
inhibit for three branch times and it also generates a reset which clears all registers. The inhibit
allows the Viterbi time to update the incremental correlations before processing resumes. The
branch synchronizer slips a bit by generating a blanking pulse which inhibits the input clock to the
clock generator for one-bit time. Reference may be made to Branch Synchronizer Typical Timing
Diagram (Figure A2-3.3.3.1-2).
For rate 1/3 codes, if all odd-weight generators are used, the Viterbi cannot dis-
tinguish between the in sync mode and the mode with no bit slippage with phase inversion. That
is, theViterbi could output either true or complement data under these conditions.
82
r 
_8
v zj
; --Z
2 
YZr
E
aTo
.-0)
3
0
L-
a)-
N
C
io
0
.c
up
C
c
!
Ca
a..
L.
02)
U-
83
_i 
~~~~~~~~~~~~~~~~~BI T CLK ,,~~~
BIT CLK 
Ior
IL
CLOCK ENABLE
-L-----JI
BRANCH .L
CLOCK B I---I
86185-14
Figure A2-3.3.3.1-2. Branch Synchronizer Typical Timing Diagram
84
BLANKING
BRANCH
CLOCK A
OUT OF SYNC
DETECT
RESET
II
A2-3.3.3.2 Clock Generator
The clock generator receives the bit sync clock and divides its Frequency by 3 For
rate 1/3 or by 2 for rate 1/2. The clock generator also provides the necessary drive For the clock
lines. The code rate is selectable by a switch on the front control panel.
A2-3.3.3.3 Input Register 
The input register consists of three 3-bit registers containing the branch data. Phase
inversion For branch synchronization is performed at the inputs to the input register. Both true
and complement data are provided to the incremental correlation calculator. If a rate 1/2 code
or less than 3 levels of quantization is used, then bits of the register are not used. Both true and
complement outputsoftheseunusedbits are forced to a logical "1" so that they add equally to
all correlations. The selectionof the quantization is controlled by two switches located in the
logic.
A2-3.3.3.4 Calculation of Incremental Correlations
The firstrank of eight adders shown in Figure A2-3.3.3-1 are labeled 000, 001,
..., 111. These adders compute the approximate correlation between the received 3-bit branch
and the 8 possible branches (rate 1/3). The adder labeled 000 calculates the correlation between
the received 3-bit branch and the 000 branch. Similarly, the other adders are labeled by the
branch with which the received branch is being correlated.
The quantized outputs are represented by 3-bit numbers ranging from 000 to 111.
The 000 sample corresponds to the most negative quantized sample and 111 corresponds to the most
positive quantized sample ·
The adder labeled 111 calculates the correlation between the received branch and
the 111 branch. Note that the inputs to the adders are r1 , r2, and r3 . The values of r1 , r2 , and
r3 range From 000 to 111. If the received branch was 111, in the noise-free case all quantized
outputs would be their maximum positive value (111). Then the binary sum of r1 + r2 + r3 = 10101
or 2 110. If noise is present on the channel, the samples r1 , r2 , r3 may not be their Full positive
value, but would be smaller quantities ranging from 000 to 111. In the noisy case the correlation
may be less than 21 10
The adder labeled 000 calculates the correlation between the received branch and
the 000 branch. Note that the inputs to the adder are F1 , ir2 , and rF3, the one's complements of
r1, r2 , and r3 . The values of rf1 , r2 and F3 range from 000 to 111. If the received branch was
000, the noise-free case all quantized outputs would be their maximum negative value (000). Then
the binary sum of F1 + F2 + Fr3 = 10101 = 2110- If noise is present on the channel, the samples
r1 , r2 , r3 may not be their full negative value, but would be smaller quantities ranging From 000
to 111. In the noisy case the correlation may be less than 2110-
85
The other adders are labeled by the branch with which the received sequence is to
be correlated. Note that the inputs are arranged to accomplish the proper correlation.
The adders outputs are called incremental correlations. The outputs are binary
numbers between 0 and 211010'
The addition is performed in two branch times because of speed considerations. The
sum of the three numbers is performed by first adding rl and r2 , then storing the 4-bit partial sum
and r3 . In the next branch time, the 4-bit sum and r3 are added and stored. The two branch
times of delay do not cause difficulties in further processing.
A2-3.3.3.5 Rescale Control
In the Block Diagram, the blocks labeled SC are 8-bit registers in which the largest
survivor path correlations are stored. Sixty-four (64) of the largest survivor path correlations are
increasing monotonic functions of time, thus, an overflow problem exists. When the largest
survivor path has exceeded (12710), the constant (12810) is subtracted from the survivor correlation
6-bit times later. The survivor path correlations are all decreased by (12810) and are prevented
from overflowing the 8-bit SC registers. A 6-bit delay is necessary to ensure all SC registers have
exceeded 12710o
When the threshold (12710) has been exceeded, the input to the rescale control is
inhibited for 5-bit times so that the rescale control is not reactivated until the rescaling is com-
pleted. Reference may be made to the Rescale Loop Figure and Rescale timing chart (Figures
A2-3.3.3.5-1 and A2-3.3.3.5-2).
A2-3.3.3.6 The Patch Function
The patch function shown in the Block Diagram allows any generator polynomials to
be used for generation of the code. The 128 adders shown by the 64 SC registers may be grouped
by pairs that receive the same incremental correlation independent of the code. This means that
each of these 64 pairs of adders must receive one of the eight incremental correlations. The
generator polynomials for the code determines which of the incremental correlations is routed to
a pair of adders.
The patching for a code is accomplished by the use of plug-ins on a master board.
Each code has associated with it a set of 40 prewired plug-ins. A code is implemented by inserting
the plug-ins into the master board located on the logic chassis. The code can be changed by
changing the plug-ins. Electrically, the patch function is shown in Figure A2-3.3.3.6. The
vertical lines are incremental correlations of 5 bits each. Each of these correlations can go
to any combination of the 64 pairs of adders. These lines can be connected to only one vertical
line, i.e., they can be connected to only one incremental correlation.
86
INCREMENTAL
CORRELATIONS
-I
Figure A2-3.3.3.5-1. Rescale Loop
87
a
-
86185-16
Figure A2-3.3.3.5-2. Rescale Timing Chart
88
SAMPLE IN SAMPLE IN
BIT TIME RESCALE
REGISTER SC STORAGEREGISTER
1 #/1
2 #2 #1 128 <MAX < 148
3 #3 #2 128 < MAX < 169
4 #4 #3 128 < MAX < 190
5 #5 #4 128 < MAX < 211
6 #6 #5 128 < MAX < 232
7 #7 #6 128 < MAX < 253
8 #8 #7 O<MAX< 146
\ 5 5
INCREMENTAL CORRELATIONS
\ 5 \ 5 \5 \ 5
\ I \ I\ 
N 5 64 PAIRADDERS
AS s
---- -- 4-f r
---- 4- -,
- -
\5 ,\5\ i
I<-
I N V
PATCH FUNCTION
ZS OF
TO 8 PAIRS
TO 8 PAIRS
TO 8 PAIRS
TO 8 PAIRS
TO 8 PAIRS
TO 8 PAIRS
TO 8 PAIRS
TO 8 PAIRS
86185-17
Figure A2-3.3.3.6. Patch Function
89
\4
The above applies for rate 1/2 codes except that there are only four incremental
correlations. Each of the correlations will be present in two adders, thus distributing the loading
over two adders rather than one. 
The actual patching is accomplished by patching the MSB's of each incremental
correlation on common plug-ins. The remaining bits are patched identical to the MSB's.
The operations to be performed following the patch Function have an effect on the
limiting rate of the entire decoder. Rather than allow the patch Function delay to enter these
sensitive operations and impose a limitation on rate, a storage register is placed after the patch
function. 
Patching is the same For shorter constraint length codes.
The following are the codes For which patch plugs are being provided with the
system:
K = 6, R= 1/3
K = 5, R = 1/3
K = 4, R= 1/3
K = 6, R 1/2
K= 5, R= 1/2
K = 4, R = 1/2
K= 3, R= 1/2
111001, 111011, 101101
10101, 11111, 11011
1111, 1101, 1011
110101, 100011
11001, 10111
1101, 1111
101, 111
Refer to Appendix Al (Operation) For programming information.
90
Storage of Survivor Path Correlations
. ~K-iK It is necessary to store the running correlations for 2 survivor sequences.
This requires 2 K- 8-bit registers. It is then necessary to add the incremental correlations to
the 2 K- 1 survivor path correlations in such a way as to form 2 K sums. For each state in the state
diagram (there are 2 K- 1 of these) a survivor path correlation is stored. A new correlation is '
computed for each state given a one is received, and also for each state given a zero is received.
These 2K sums represent 2K sequences, hence it must be decided which of these 2K sequences
must be stored. This requires comparing two 8-bit numbers, determining the largest of the two
numbers, and restoring the largest survivor path correlations in the SC register. Additionally,
the results of the comparisons must be routed to register exchange gating. The maximum branch
rate at which the decoder can operate is limited by the time required for the addition, compari-
son, and storage.
In order to operate at higher branch rates, the configuration shown in the
Block Diagram is used. The survivor correlations corresponding to each of the 2 K-I states given
a one was received and the survivor correlations corresponding to each of the 2 K- 1 states given
a zero was received are stored in the SC register. The SC' registers store the correlation for the
survivor path in the X state given a one was received and the SCx registers store the correlation
for the survivor path in the X state given a zero was received.
During each bit time, multiple operations are performed in parallel. First,
out of the 2K paths whose correlations are stored in the SC registers, the 2K-1 survivor paths are
determined. In parallel, the 2 K paths each are added to their respective incremental correlations.
This yields 2K+1 sums. These sums are the correlations for the 2 K- 1 survivor paths given any of
the four possible two bit sequences are received. SCO contains the correlation for state 0 given
a zero was received. The sum formed by the adder above SCo is the correlation corresponding to
being in state zero, receiving a zero, and receiving another zero. The sum formed by the adder
below SCO is the correlation corresponding to being in state zero, receiving a zero, and then
receiving a one. SC'
o
contains the correlation for state 0 given a one was received. The sum
formed by the adder above SC'O is the correlation corresponding to being in state zero, receiving
a one, and then receiving a zero. The sum formed by the adder below SC'O is the correlation
corresponding to being in state zero, receiving a one, and then receiving another one. In
summary, we have for the zero state, the correlation with the received sequence, of the survivor
path terminating in the zero state when the survivor path is followed by a 00, 01, 10, 11
sequence of information bits.
A similar calculation is made for each of the other 2K - 1 states when the
survivor path is followed by 00, 01, 10, or 1 1 sequence of information bits. These 2K+± sums
are presented to the comparison logic which eliminates paths.
The virtue of this configuration is that rather than performing the addition and
comparison sequentially, we are performing the operations simultaneously. This allows a much
greater information rate through the decoder.
91
A2-3.3,3.7
When a shorter constraint length code is used, the SC registers will contain
more than one survivor correlation path for each state given a received bit. Thus for K = 5 two
SC will contain survivor correlation paths for each state.
One will be the maximum correlated path. The number of paths terminating in
a state will double for every decrease in the constraint length.
A2-3.3.3.8 ' Comparisons of Correlations and Elimination of Paths
There are 32 comparators which receive the contents of the SC registers.
Recall that the 64 SC registerscontain 2 numbers of each of the 32 survivor paths. The number
contained in the SCO register is the correlation for the survivor path terminating in state 0 given
a 0 bit was received. Since there are only 32 states, certain pairs of SC registers represent
correlations for paths terminating at the same state. The path with the largest correlation is
decided by comparing the two SC registers and the result is stored. The output of each compara-
tor is a signal which indicates whether the upper or lower input to the comparator was largest.
Meanwhile, the adders have formed 128 sums, 64 of these sums however, are
correlations for extensions of nonsurvivor paths which are discarded. The remaining 64 sums are
correlations for the 32 new survivor paths given a one was received and correlations for the
correlations for the 32 new survivor paths given a zero was received. These quantitites are stored
in the correct SC registers. The routing of these sums is by the selection logic, which is located
with the SC registers.
Suppose that a comparator has as its inputs the SC and SC'y, and both of
these paths terminate in state X. If SCy is greater than SC' , the sum out of the adder above
SCy is stored in SCx . The sum out of the adder below SC iys the correlation for the path
terminating in state X with a one as the next bit and is stored in SCx+ 1 . Conversely, if SC y is
greater than SCy, then the sum out of the adder above SC'y is the correlation for the path
terminating in state X with a zero as the next bit and is stored in SCx. The sum out of the adder
below SC'y is the correlation for the path terminating in state X with a one as the next bit and
is stored in SC'x+ 1 .
In summary, during each bit time the 64 paths whose correlations are stored
in the SC registers are compared in pairs (pairs which terminate in the same state) to determine
the survivor paths. Simultaneously, for each of the 64 paths whose correlations are stored in the
SC registers, the correlations for 128 one bit extensions of these paths are calculated. When the
32 surviving paths are determined, this information isused togate the correlations for the 64 one
bit extensions of these paths into the SC registers.
The important feature of this implementation is that an 8-bit addition and a
comparison of two 8-bit numbers are performed simultaneously rather than sequentially.
92
The SC registers are 8-bit registers whose contents are bounded by zero and
25510o. The inputs from thepatch function are numbers from 0 to 2110 depending on the value of
the incremental correlation. The sums produced by adders will lie between zero and 25510.
Since the SC register are always positive numbers, the comparison can be made
by adding the upper number and the one's complement of the lower number. The carry output.
from the adder determines whether the upper or lower SC register (of the pair feeding the compara-
tor) is the largest.
v~~~~~~~~~~~~~~~~~~~~~~~
The comparator output, in addition to comparing the correlations and
eliminating nonsurvivor paths, also indicates what the bit is in the survivor path. If the upper
SC register is the largest, then the survivor path contains a zero in the branch most recently
decided. If the lower SC register is the largest, then the survivor path contains a one in the
branch most recently decided.
A2-3.3.3.9 Register Exchange Logic
The register exchange logic consists of thirty two (32) survivor sequence
registers each 32 bits long. The loading of the survivor sequence registers are controlled by the
comparing of the survivor correlation registers. If SCo> SC'0 then a zero is loaded into the first
bit of SSO and the contents of SSO are loaded into SSO, but shifted by one bit. If SC0 < SC' 0
then a one is loaded into the first bit of SSO and the contents of SS16 are loaded into SSO, but
shifted by one bit. The remaining SS registers work similarly to SS0 . The inputs to the registers
are represented by the trellis diagram (Figure A2-3.3.3.9). The upper branch into a state occurs
when a zero is the result of the comparator. The lower branch into a state occurs when a one
is the result of the comparison.
There is a two bit delay between the comparison and the loading of the SS
registers. This delay is required because the comparators and SS registers are located in separate
logic drawers. One bit of delay is on each drawer to prevent the delay of the cabling from
limiting the speed of operation.
A2-3.3.3.10 Majority Bit Decision Logic
The majority bit decision logic receives bits from each SS register. These bits
correspond to various depths of the sequence. Eight different depths can be selected. They are
4, 8, 12, 16, 20, 24, 28, or 32. These are programmed by using switches located in the logic.
The majority bit decision logic sums the number of ones at the selected depth.
This summing process requiresfourbranch times. The decoder output is a logical one if the sum
is 16 or greater.
The decoder output is available to the group sync and front panel.
93
STATE STATE
0 0
1 I
2 2
3 3
4 4
5 ~~~~~~~~~~~~~~~5
6 6
7 7
8 8
9 9
10 10
11 "11
12 12
13 13
14 14
15 15
16 16
17 17
18 18
19 19
20 20
21 21
22 22
23 23
24 24
25 25
26 26
27 27
28 28
29 29
30 30
31 31
86185-18
Figure A2-3.3.3.9. Trellis Diagram
94
The delay through the Viterbi Decoder varies depending on decoding depth.
For rate 1/3 there is a fixed delay of 16 bits plus a variable delay of 0 to 28 bits in increments
of 4 bits. For rate 1/2 there is a fixed delay of 17 bits plus the variable delay.
Three binary weighted lines are sent to the Bit Comparator A for determining
the variable delay required in the comparator.
A2-3.3.3. 11 Variable Parameter Implementation
The Viterbi Algorithm Decoder has the feature that code parameters can very
simply be changed. These variable parameters allow testing of a wide variety of codes. This
paragraph discusses the implementation of these parameters.
The decoder is capable of handling codes with constraint length up to 6.
Functions are required to change for the various constraint lengths. These are the patching,
bandspread ratio, quantization, constraint length, and decoder output depth.
The generator polynomials for the codes are changed by replacing the patch
plugs. Any generator polynomial, maximum constraint length 6, can be implemented using the
patch plugs.
The threshold and check depth for the branch synchronizer must be changed
for the constraint lengths. Two switches in the logic will control the selection. The thresholds
are 60 for K = 5 or 6 and 30 for K = 3 or4. The check depths are 32 for K = 6, 27 for K = 5,
22 for K =4and 16 for K= 3.
An additional patch allows the constraint span to be varied. A digital network
is provided which will allow the inputs to the majority bit decision logic to come from any fourth
staged of the SS registers. The enabling is controlled by three switches located in the logic.
Decoder performance is a function of the decoder constraint span. The test set has the capability
of quantitively determining the effect.
The decoder is capable of handling one, two, or three bit quantization. The
only logic change required is to force the unused bits of the input register to add equally to all
incremental correlations. This is controlled by two switches located in the logic.
A front panel switch controls the bandspread ratio. For rate 1/3 codes, the
decoder is used as in the Block Diagram Figure 3.3-2. For rate 1/2 only two 3-bitwordsare received for
each branch. The output lines from the third 3-bitportion of the input registersarearranged so that
they add equally to all of the incremental correlations. This is performed logically, driven from
the front panel switch. From this point on, no logical modifications are required.
95
A2-3.3.3.12 Interface
The Viterbi receives data and clocks from the bit sync and outputs the MSB of
the data and the clocks to the Fano Decoder. The decoder outputs error corrected data to the
group synchronizer. A clock in phase with the output data is provided to the group synchronizer.
The Viterbi receives enables for the bandspread ratio from the front panel. It
outputs enables for variable decoder output depth. 
96
A2-3.4 Fano Decoder - A8A1A9 (Al13-A22)
The Fano Decoder performs the following functions:
a. Accepts serial data and clock (to 18 MHz) from bit
synchronizer for rate 1/2 systematic codes with constraint
length and polynomial terms to 40.
-b. Establishes polarity and branch synchronization on the
input serial data.
c. Provides polynomial setup to match the encoder.
d. Utilizing generated syndromes and the Fano Algorithm,
provides correction of the data bit stream.
e. Outputs corrected data and clock at rates up to 9 MHz.
A2-3.4.1 Theory of Operation
The paragraphs of Section A2-3.4.1 supply general information about codes as a
basis to understanding the Fano Decoder. Details about implementation follow in Section
A2-3.4.2.
A2-3.4.1.1 General Information
Consider the polynomial, I(x), to be a sequence of information bits coded by some
generator polynomial, G(x), to form the transmitted sequence, T(x). This is expressed by:
T(x) = G(x)l(x)
For example, let the binary number, 11010, represent the coefficients in the polynomial
l(x) = l x0 + 1 .x1 + 0x 2 + 1x 3 +0 x 4
and let binary number 11 represent the coefficients in:
G(x)= 1 + x. Then G(x) I(x) becomes:
(1 +x)(1 +x+x 3 ) = 1 + + x 3 + x + x 2 + x 4
=1x 2 +x+ 3 + x4 (x + x= 0)
97
Writing only the coefficients of T(x) as its binary representation gives:
T(x) = 101110
This product can be produced by feeding I(x) into a shift register and generating the Mod 2 sum,
T(x), with inputs to the Mod 2 adder corresponding to the terms of G(x).
I (x) >
.1- T (x)
Assume the register to contain zeros to begin with and that the bits 11010 shift through the regis-
ter MSB first. The output of the Mod 2 Adder will then be the sequence, T(x)= 101110, as can
be demonstrated by a step-by-step colculotion. Thus the configuration shown forms the desired
multiplier.
To apply any generator polynomial to I(x) one need only to shift I(x) through a
register and Mod 2 add the outputs of the appropriate stages. Stage zero (input stage) supplies to
the Adder the coefficient of the zero order bit; stage 1 (second from the left) supplies to the
Adder the coefficient of the 1st order bit; etc.
For example, if G(x) = 1 + x + x3 , connect the Mod 2 Adder as follows:
I (x) ->
T (x)
Now consider a configuration where G1 (x) = 1 and G2 (x) = 1 + x:
I (x) 
T1 (x)
T2 (x)
98
As information bits enter the register, pairs of transmit bits are generated. Assuming the register
to be in its initial state (a,0O in the first stage) one can construct a code tree of possible sequences
as follows. When a "0" enters the register transmit bits, T1 , T2 = 0,0 are generated; had a "1"
entered, one would have TI, T2 = 1, 1. These possible changes from the initial state form the
first branches:
00
Using these as starting points, the next branches can be formed. When T1 , T2 = 1,1 Ithe register
contains bits 10; shifting in a "O" results in T1 , T2 = 0,1; had a "i" entered, one would have
T1 , T2 = 1,0. The added branches extend the tree:
00
01
11 II10
Continuing this process, making the upper branch of any pair of branches represent T1 , T2 for a
zero entering the register adds to the tree as below:
00
99
Note that for a 5-bit sequence sent through the register, one obtains a 10-bit ouptut sequence.
The 5-bit input sequence can have 32 distinct values; the output 10 bits can have 1024 distinct
values. Now only 32 of the 1024 output code words correspond to the 32 possible input sequences;
the others being "unallowed." If the 32 possible output code words are plotted, each is different
from its neighbors in some number of bit positions. The important thing to note is the least separa-
tion between allowed code words and in particular the least separation of allowed code words
located in the top half of the tree from those in the bottom half of the tree.
For the tree above, the least separation is 3. As an illustration, select any code
word from the top half, e.g., 000000, and any code word from bottom half, e.g., 110100, and
Mod 2 add them: .
00 00 00
11 01 00
11 01 00
The two code words differ by three 1's or 3 digits.
Any other pair of code words from opposite halves of the tree will differ at least
as much. This difference is referred to as the hamming distance. The minimum hamming distance,
d, is related to the number of errors (erroneous digits) which can be corrected, t, by
d = 2t + 1.
That is, one could introduce a single error in any of the 6-bit allowed code words above and
still find the new unallowed sequence closer to the original code word than all other allowed
code words.
A decoder can now be discussed which essentially uses the code tree to correct
errors found in the transmitted sequence.
The decoder introduced here differs from the one implemented in the Test System
but will serve as a good basis for understanding it.
The description of the decoder's operation is mainly imparted by the use of three
examples. The first example supplies the most general information and serves to introduce a few
terms needed. The second example dwells on modes mentioned by the first. A third example is
given to illustrate more comprehensive operation. This example is an extension of the first one.
Finally, a flow chart is given which later becomes the basis of the decoder implemented in the
Test System.
Consider now the first example. Suppose a pair of transmitted bits, T1 , T2arrive at
the decoder. From the previously received pair, the decoder decides whether the new bits extend
100
the tree. If the bits were expected, they will be used to determine what future pairs are allow-
able, and in this way, the decoder moves one branch further into the tree. If the transmitted bitsdo
not form an extension to the code tree, the decoder may or may not move forward. When such a
situation occurs, two avenues are open. The decoder may decide to go forward by hypothesizing
a correction for the unexpected bits. This will allow the decoder to proceed one branch further
into the tree and allow it to examine another new pair of bits. The correction introduced may
have indeed been the right one, properly predicting the pair following the one containing errors,
and allowingjthe decoder to move on, processing new bits and continuing through the tree.
A second avenue open to the decoder when an unexpected pair arrives is to recall
a previously processed pair, assume it to be incorrect and hypothesize a correction. The correc-
tion here may be one which moves the decoder from an upper branch to a lower branch. In this
case, new allowable pairs are predicted, perhaps including the pair which originally appeared
in error.
Typically, the decoder may be operating at branch level 1. From the
00
00
01
01
11 _ 10E . , 1
10
I I I I I
I I a I I
Branch Level N 1 2 3 4
Received Bits 11 01 01 01
Transmitted Bits 11 01 11 01
illustration, note the pair 11 is received. This was the pair transmitted so the decoder is set to
move to branch level 2. At this point, bits 01 or 10 are expected; pair 01 is received. So,
again the decoder is set to move forward. At level 3, bits 00 or 11 are expected. The illustra-
tion shows pair 01 is received. At this time, the decoder must decide on one of the two possible
actions.
A correction of the error may be attempted. Suppose that when this is done, the
decoder always hypothesizes trying the upper branch first. Here then, the decoder would
change the 01 pair received at level 3 to 00. With this hypothesis, the decoder would expect
pair 00 or 11 at level 4. From the illustration, the pair actually received is 01. Thus a second
101
error would have to be assumed to continue orn this path. But let the decoder take the second
avenue of approach, and back up one branch level to 3. The pair 01 received at that level was
originally presumed to be 00. This time the decoder will try 11 as a corection. Now pair 01 or
10 is acceptable for level 4. Pair 01 is received. So, the decoder is on its way further into
the tree.
Some mechanism must exist in the decoder which tells it to choose to move through
an error or to back up. In the Test System Decoder, a number called the Metric Value controls
all movemenrt. When the pair of bits being examined would extend the tree, the number will be
incremented by one, and the decoder will always move forward. When the newly arrived pair
disagrees with the expected allowable pairs, the number may be decreased and the decoder
moved forward. This is the case where the decoder hypothesizes a correction. Whenever the
Metric becomes negative, however, a backward move is required.
In the illustration, suppose the Metric Value isA - 2 at N = 1, and suppose the
single errors have a weight of -A + 1, and double errors a weight of -2A + 1. The following
table shows the behavior of the Metric Value, both for a generalized case, and for the specific
case of A = 5. When the decoder moves from level 1 to level 2, pair 01 is expected and the
Metric Value changes to L2 =A - 1. Moving to level 3, the error is absorbed. A correction of
01 to 00 is assumed, and L3 = 0. A move is made to level 4. Since bits 00 or 11 are expected
and bits 01 are received, L4 = -A + 1. For the A = 5 case, L4 is negative. A required back-
ward move now resets the Metric to L3= 0; a single error is absorbed when a new correction
hypothesizes 01 at 3 should be 11. This correction leads the decoder to expect the pair 01 it
receives at level 4 and L4 increases to +1.
Next Add Actual
Tree Error Move to General Metric
Level Assumption Direction Metric Metric For A = 5
1 None Forward 1 A- 2 3
2 None Forward 1 A- 14
3 One Forward -A+1 0 0
4 One Backward -A+ 1 -A+ 1 -4
3 One Forward -(A + 1) 0 0
4 None Forward 1 1 1
Note how the Metric increases only slowly as the decoder processes pairs having
no errors and decreasessharply with errors. For A= 5, the Metric quickly decreases by -4 for
single errors and -2A + 1 or -9 for double errors.
102
c)
In the bit checking operation, it is important to keep a positive Metric value
relatively close to some threshold number, i.e., as progress is made through the tree and the
Metric value grows larger, it is important that a threshold value be updated along with the
Metric value so that discovery of certain error conditions requires the Metric drop below this
threshold and thus alert the decoder.
The Metric to threshold relationship can be satisfied by defining the threshold to
be zero and representing the Metric by using a counter which advances to some acceptable value
and then rolls over to start again. By choosing the rollover point to be small, almost any error
condition will require violation of the threshold if the effect of that condition were actually
added to the Metric.
Suppose the Metric counter contained LN_1 rather than LN. Then, for this
example, the Metric could be a simple Mod-5 up-down counter. By allowing the counter to
store LN-1, it never needs to assume negative values. When an error is found, the decision to
move forward just requires LN_1 to be greater than or equal to the error's weight.
Notice how this example was idealized to allow an easy correction of the error at
branch 3. L2 was large enough to absorb the error. A single backward move from level 4 and
switching from the upper to the lower path at level 3 was all that was required to make the
correction. Suppose L2 had been some value less than A - 1. With the Mod-5 counter suggested
as the tvetric accumulator and with the criteria that LN_1 be positive as the decoder proceeds
into the tree, progress would stop at level 3. This problem is discussed below.
At this point, consider a second example. A procedure called lowering the thresh-
old will be introduced. With this technique, the decoder, faced with an error situation impeding
all forward progress, adds an amount, A , to its Metric and reinitiates its search.
The term lower-the-threshold may sound misleading in the sense that the threshold
was earlier defined to be zero and this procedure suggests changing the definition. Actually,
threshold, T, remains zero with respect to the value in the Metric counter. When A is added to
the Metric Value, T, still zero, is then A further below the new Metric and in this sense lowered.
Threshold lowering here will be accomplished by changing the Mod-5 counter used
earlier. Assuming A = 5, the Mod-5 counter is a Mod-A counter; extending its length with
additional stages gives a Mod-A counter in series with a A counter. Lowering the threshold by
adding A then can be accomplished by incrementing the added counter by one count.
With the modification suggested for the Metric, the decoder will try to move for-
ward using only the Mod-A counter. As the decoder moves through error free branches the
Mod-A counter adjust increments toA- 1 and rolls over, updating the threshold as before and
effectively raising it. Only when hope for further forward progress is impaired does the decoder
use the newA counter.
103
Typically, the decoder may be operating at branch level 6. From the illustration
below, note pair 00 is received. Let L6 = 0, i.e., at level 6, the Mod-A counter contains
L5 = A - 1 and is ready to roll over.
00
00
@~~~~~~
00
_11
00
u.
00
I, @ & I I
N 6 7 8 9
Reoceived Bits 00 00 01 00
Transmitted Bits 00 00 00 00
Bits 00 are received at level 7. So, L7 = 1. Bits 01 at level 8 contain a single
error. Since the Metric counter at level 8 contains L7 = 1, the decoder is directed to back up.
A shift to level 7 follows. There the decoder assumes bits 00 received at this level are in error.
Changing this assumed error of 00 to 11 and moving forward along the lower path of 7 would
require the Metric to absorb -2 A +1. Since the Metric contains L6 = 0, a second reverse shift
would be ordered.
If no new mechanism was introduced here, the decoder would continue backing
and searching lower paths - a fruitless task. The Fano algorithm calls for a threshold lowering
when LN < T and when LN_2 < T. In this example L8 ( T but L6 = T; so, the reverse move to
level 7 should occur. This move requires searching the lower path and results in L7 being nega-
tive. Now, since the threshold was raised at level 6, L5 is negative and a lowering should
occur. This means L7 should be changed from its old value of 1 to a new value of 1 + A .
Further, the decoder must move forward along the upper path first used at level 7. Now the
decoder is able to move through the error at level 8 where L8 = 2, and then to level 9, etc.
In summary, note that the decoder keeps the threshold low enough to do a complete
search of paths. Almost any error condition will cause the decoder to back up and test a differ-
ent branch. When possibilities are exhausted, the threshold is lowered by A. This allows the
decoder to again initiate its search but, with the less sensitive threshold, the decoder will be
allowed to move a little further into the tree before discarding a selected path. The less sensi-
tive threshold thus allows the decoder to ignore the first error as a given path is checked.
104
The symbol IN is introduced here to distinguish between upper and lower paths at
level N. Since the upper path was arbitrarily selected for a first attempt through a branch in
the examples IN = 0 will mean use-upper-path. This concept will be modified later.
The examples used have a few limitations. For one, they ignore the case where'
N = 1 and where a reverse shift is not allowed. N = 1 signifies no older branches are available.
-As a second limitation, consider the possibility of the decoder moving forward on
a lower path after discarding the upper one. The decoder may be required to back up into such
a branch level and must not repeat searching the upper path. A new symbol, H, is introduced
here to alert the decoder to avoid the unnecessary step.
Consider now the third example. Referring to Table A2-3.4.1.1, the decoder tries
the upper path at branch 3, fails, tries the corresponding lower path, succeeds and proceeds to
branch 4. At branch 5 a disagreement is found which would cause the Metric to be negative; the
decoder backs up. At level 4 the lower path is tested. This test requires the Metric to be nega-
tive so the decoder again backs up. At level 3, both paths have been checked; H = 1. So,
again the decoder backs up. At level 2, the lower path is tested, etc.
Finally, in this case, the decoder reaches level 1 and, because this is the end of
the bit sequence available, the threshold is lowered and forward moves are made. Had the limi-
tation of N = 1 not caused a reversal, the condition, LN , LN_2 < T, eventually would have
and, as in this example, forward moves would have followed.
By step 17, the decoder has passed through two errors and is headed forward. If no
further errors are discovered, the Metric will build up to a value of 4 by step 19. At this point,
the threshold will be raised by just letting the Metric roll over to zero on step 20.
A flow chart of the Fano algorithm is given in Figure A2-3.4.1 .1.
105
00
01
10
II
II
II
II
II
I i I
I I I
III
I II
N:
Received:
Transmitted:
1 2 3 4 5
11 01 01 01 01
11 01 00 11 01
Table A2-3.4.1.1. Example of Fano Decoder Operation
Received Bits
Step N LN Bits Assured H IN Cment
0
0
0
1
0
0
1
1
1
1
0
0
0
0
back up
back up
back up
backup
back up
T-T - A
0 back up
1
0
.4
11
I
1
2
3
4
5
6
7
8
9
10
11
12
13
].4
15
16
17
2
3
4
3
4
5
4
3
2
1
1
2
3
4
5
4
5
4
0
-4
0
1
-3
-9
-6
-7
8
9
5
.1
-3
1
2
01
01
01
01
01
01
01
01
11
11
01
01
01
01
01
01
01
00
00
11
01
00
10
10
00
11
01
00
00
00
11
01
0
0
0
0
0
0
0 
1
0
0
0
0
0
0
0
0
0
106
III
86185-19
Figure A2-3.4.11. Fano Decoder Flow Chart
107
A2-3.4.1.2 Detail Description
A variation of the above described decoding technique can now be discussed.
This technique differs from the above in that bit pairs T1 , T2 are processed to form syndrome bits
and then the syndrome bits are used to make decisions about movement through the tree.
1 ~ ~As a first step, consider the relationship of errors to the data received. The
bits T (x) are coefficients of a polynomial; corresponding to each of these coefficients is a
coefficient to an error polynomial, El(x). Where a transmitted bit is changed, its corresponding
coefficient in the error polynomial is a one. Where a transmitted bit remains unchanged, its
corresponding coefficient bit in the error polynomial is a zero. The received bits then are the
Mod-2 sum of the E(x) and T(x) coefficients.
1 I The syndrome bits are polynomial coefficients generated when the Mod-2 sum,T (x) + E (x), is multiplied by the generator polynomial used by the transmitter and the resulting
bits Mod-2 added to the polynomial T2 (x) + E2 (x) as shown below.
E1 (x)
T1 (x)
T2 (x) S (x)
E2 (x)
Note that since
S(x) = [T (x) + E (x)] g (x) + [T (x) + E (x)]
1
T (x) = I(x),
and g (x)= (1 + x),
T (x)= (x)x) g (x) = I(x) (1 + x)
108
Then
S (x) =[I(x) + E I(x] (I + x) +[,(x) + x) + E 2(x)
= I(x) (I + x) + I(x) (I + x) + E(x) (I + x) + E (x)
In the Mod 2 arithmetic used here,
l(x) (I + x) + I(x) (I + x) = 0,
1 ~~~2
S(x) = E (x) (I + x) + E2(x), 
showing that the syndrome bits are independent of the data.
Writing E (x)=e1 +el x+ Ie2x ... and
01~~2
E2 (x)=e2+e 2x+ e 2 x ...
1 2 1 1 2S(x) = (e 0 + eo) +(eO +e 1 + e1 ) x
1 1 2 ) X2
+(ee + e2 )
2
=SO+SIx±2x +S ...
The coefficient of x0 here is the Mod-2 sum (e1 + e2) it corresponds to the x0 coefficients of
1 2 1 2 0 0T (x) and T (x). If e e0 = 1, then their Mod-2 sum of zero indicates an error in both bits
1 2 1 2 1
T , Te .f e= e0 = 0, their Mod-2 sum of zero indicates no errors. If the Mod-2 sum of e
12
and e0 is 1, a single error exists in bits To/ T o
1Note at this time that an error in bit T expressed by e0 = 1 is carried over
I I 0 
~~~~~~11into S1 . Similarly, an error, e = 1, in bitT1 carries over into S2, etc. If the generator
31polynomial has been 1 + + x , e0 would appear in So , S1 and S3; if the generator polynomial
1
had N terms, e0 would appear in each of the younger syndrome bits which corresponded to a
nonzero coefficient in the N term polynomial. This carryover of error coefficients into
1
neighboring sums has the effect of inverting them; e0 = 1 enters the Mod-2 sum
1 1 2
S1 = ee 1 +e1 x
and inverts S1
109
Using the properties mentioned thus far, the decoder examines the individual
syndrome bits and generates the coefficients of the polynomials, E
l
and E2 . The coefficients of
E are Mod-2 added to corresponding coefficients of the received polynomial (E1 + T1 ). This
then yields the transmitted polynomial T'1:
E + (E + T) = 
As a first step in the process, syndrom bit, SN, is examined. Coefficients EN and
PN of polynomials E1 and E2 are then hypothesized and shifted into holding registers. As this
shift occurs, the next syndrome bit, SN+1, is moved forward.
Just what is hypothesized depends on the state of SN and whether the given syn-
drome bit had been previously examined. Quite often the EN, PN pair hypothesized is incor-
rect; a reverse shift follows, and a second pair is hypothesized. This behavior parallels the
branch switching of Paragraph A2-3.4.1 .1. There an attempt was made to correct an error by
first trying the upper branch; when this failed, movement along the lower branch was attempted
if the Metric permitted.
The symbol, IN , used in Paragraph A2-3.4.1.1 is used here. IN will be set to
a one whenever a reverse move occurs. If IN = 0 when the decoder examines SN, the decoder
predicts the most probable EN, PN pair. That is, for SN, IN = 0, 0, the pair EN, PN = 0, 0 is
hypothesized rather than the less probable pair, EN, PN = 1, 1. For the case SN = 1, EN, PN=
1, 0 or 0, 1 are equally probable and 1, 0 is arbitrarily assigned the "more probable" status. So,
for SN, IN = 1, 0, pair EN, PN = 1, 0 is hypothesized.
The Metric here is the same as used earlier. When the decoder has SN, IN
0, 0, it hypothesizes no errors and increments the Metric by one. A forward move with SN, IN =
0, 1 requires hypothesizing two errors and debiting the Metric by -2A + 1. A hypothesis of
EN, PN = 1, 0 or 0, 1 requires debiting the Metric by -A + 1. Analogous to its behavior in
Paragraph A2-3.4.1.4, the decoder can move forward as long as LN_ 1 contained in the Metric
is equal to or greater than the error condition represented by SN, IN .
The same threshold lowering device is needed here that was used earlier. In
Paragraph A2-3.4.1.1, threshold lowering required the decoder to reinitiate its search with the
upper branch - disregarding IN; similarly, here the decoder must reinitiate its serarch with the
most probable pair, EN, PN = 0, 0 or 1, 0 depending on SN
Whenever the decoder hypothesizes EN = 1, it is implying the younger syndromes
are affected. In particular, the hypothesis implies those syndromes corresponding to the nonzero
terms of the generator polynomial have been inverted. Mod-2 adding the ploynomial to the
younger syndromes will invert them a second time and hence, restore them to their proper state.
Note, however, that a mistaken hypothesis and polynomial addition will wrongly invert the
younger syndromes and introduce more errors (syndrome "1 "s). Discovery of this mistake will
require a reverse shift, a new hypothesis, EN =0, and a second polynomial addition reversing
the effect of the first.
110
In the examples above, the generator function most often just contained two
terms or had a constraint length of 2. In the test set, the constraint length is 40. To implement
the Mod-2 addition required, a special 40 stage register is used. The register is constructed so
that the polynomial may be added in between forward or reverse shifts. When no corrections are
required, this unit (called the computation register) performs like an ordinary shift register..
The basic configuration relating the Computation Register (CR), Error Register
(ER) and Parity Register (PR) is slown in Figure A2-3.4.1.2-1. 
In the Forward Mode, Error bits, EN, and Parity bits, PN' are generated by
the control logic from the Syndrome bit, SN, and state flip-flops. Once the forward shift occurs,
EN and PN are loaded into the first stages of the ER and PR and become bits EN_1 and PN-1·
Coincidentally, SN is replaced by SN+1.
In the Reverse Mode, SN is regenerated by the control logic from bits EN-1
and PN-I' Once the reverse shift occurs, SN generated from EN_1 and PN_1 replaces the SN
present at the output of the CR. Coincidentally, EN_1 and PN-1 are replaced by EN_2 and
PN-2, respectively.
From the discussion given thusfar, EN_ 1 will be set to a one when
fSN IN )  (T -T - A) + SN * (T- T - A)] Fwd + EN_2 Rev= 1;
(where " is the logical AND and "+" is the logical OR)
PN-I will be set to a one when
IN * (T--+T-L) Fwd + PN-2 Rev= 1.
These two equations will now be used as a starting point in defining the
decoder control logic. The discussion below will cover the generation of (T-T - A), Fwd
Poly EN, Fwd and Rev.
The discussion of threshold lowering is covered in two parts; T--T - A is
found for clock period N during which it is used. Attention is then given to predicting T--T- A
a clock period early. This is done in steps. Each of the terms of the equation for TU-*T - A is
considered separately. Then, the predictions of the individual terms are combined to give the
expression predicting T -T - A .
111
aC.R. . . . E .R.'S+1 :sN '%-1 
CDNMIL LOGIC
*__ _ _-It- __
: iPN-2 ' · P.R.
Figure A2-3.4. 1 .2-1. Relation of Control Logic to Registers
112
The discussion of the product, Fwd Poly EN, is carried out in much the same
fashion, it too must be predicted a period early.
The Fwd and Rev terms are just written down for clock period N. Fwd and
Rev are the inverse of each other; so, only an expression for Fwd is given.
Lowering the threshold, according to the flow chart of Section 1, must occur
when LN_2, LN < T. In solving the problem of expressing these conditions,.consider first the
aspect LN-i < T -
The test system is designed such that when SN is present, LK-1 (not LN) is
contained in the Metric Counter. Whenever LN1 is zero, LN- 2 may be less than zero. Two
paths lead to LN_1 = 0; one is a path in which an error has been absorbed, i.e., LN_2 was
LA -1 or 2 A! - 1 and the decoder moved through some error condition at level N-2. Moving
through the error then dropped L from some value greater than LN_-1 to zero at LN~I1.
The second path to LN1 = 0 is the one where LN_2 is incremented up by one
from A -1 to zero (the Mod-A counter rol s over). This is the case where rollover indicates a
raising of the threshold and the case where LN_2<T.
The condition LN 2 <T then will be determined by data from the E and P
registers. When L shifted to value LN_ 1 = 0, bits EN_ 1 and PN-1 were determined. LN_2< T
if EN_1 = PN-1 = 0-
The second aspect to be considered in lowering the threshold is the condition
LN <T. LN < T if LN 1 = 0 and SN = 1. Asecond case occurs whenLN1 = 0 and IN = 1.
(LN<0 for this second case since the decoder, in moving forward from this point, must hypothesize
one error if SN = 1 or two errors for SN = 0; with LN_1 = 0, any error causes LN<T.)
These cases are shown in Figure A2-3.4.1.2-2.
Both above aspects neglect approaching the decision block, LN_2 :T, via the
H = 1 path. Neglecting this path is required. Recall that H = 1 implies the branch then present
has had both of its paths searched. This means that the decoder first searched the path corre-
sponding to IN = 0 and, second, proceeded forward on the path corresponding to I = 1.
Proceeding forward under this condition required the Metric absorb the effect of at least one error.
Backing into such a branch with LN_1 = 0 requires that LN_2 > LN .
One last item neglected above was the approach to T--T - A via the box
N:I. This approach will be referred to by the term Max. Rev.
Summarizing, the above gives:
T*-T - A = (LN 1 = 0) E N-1 N1 H(SN + I N ) + Max. Rev.
113
LN-1 T=O
0'
;S
LN-2 - L
N
Case where threshold should
be lowered.
LN-2\
L
N-1
\
- T=O
Case where LN_2 drops
(2 A -1) or (A -1) to
LN-1 = 0 when absorbing 1
or 2 errors at LN 2.
Figure A2-3.4.1 .2-2. Threshold Lowering
114
L
L
A d
A -
L
From the design point of view, it is important to form the product, T-T - A,
early in the clock period. Since the decoder operates at a clock rate of 20 MHz, little time is
available for product formation and distribution. In the test system, T---T - A is predicted a
period early so that it is available from flip-flop at the very beginning of the period requiring
its use. Qualification of this flip-flop is discussed below.
One of the terms of T- T - A that must be predicted is LN = 0. The
explanation below indicates that L will change to L = 0 under these conditions:
(L =A-1) - Fwd + (L- 1) · P 'N-1 Rev-N-i1 -
In the first case, if L = (A -1) and the decoder is set to move forward, L will
change by one count to L = 0. If no error was absorbed, the forward move will imply that the
threshold was raised in the process. In any case (L =A -1). Fwd will be followed by L = 0.
(The case (L = 2A -1) . SN · IN . Fwd is omitted since the threshold will never be lowered
immediately following this move.)
In the second case, more than (L = 1) . Rev is required to predict that L = 0
will follow. The decoder could move from L = 1backward to L = 0 or L =A or L = 2A.
Originally when the decoder moved forward to L = 1, the move may have been through 1 error,
2 errors or no errors; now that the decoder is moving backward the Metric must be restored to the
value it contained prior to the forward move to L = 1. To move from L = 1 backward to L = 0
requires that no errors were absorbed during the forward move to L = 1; this is signified by
N-1 N-1 0.
The product EN_1 · PN-1 of the equation for T -T-Acan be predicted from
the earlier equations given for EN_ 1 and PN-1 or a table can be constructed as follows:
SN IN EN-2 PN-2 Fwd Rev T--T -A ENA1 PN-
0 0 x x 1 0 x 0 0
0 x x x 1 0 1 0 0
0 1 x x 1 0 0 1 1
1 0 x x 1 0 x 1 ' 0
1 1 x x 1 0 0 0 1
x x 0 0 0 1 x 0 0
The table just reflects the equations for EN_1 and PN1 From it one can writeN-i -is Fro  it one can rite
115
EN-1 N-1 = (~NN+ s-N (T--T -A)) · Fwd
+EN 2 FN-2 Rev.
(T U-T - A) does not occur in adjacent clock periods; the pattern is one of lowering T, making
at least one move forward, violating the threshold (LN< T) and then backing and checking. So,
only terms
S .1 *Fwd+E . P *RevN | N Fwd + EN-2 .FN-2
are of any interest.
Next, consider predicting when SN = 1. In the forward mode, SN depends on
SN+1 , the younger syndrome bit, and whether SN+1 is to be changed by the Mod-2 addition of
the polynomial I term, Poly N+1 
Recall that when SN = 1, the decoder will try predicting EN = 1 and PN = 0.
This guess implies SN is affecting the younger syndrome bit and, when shifting EN and PN into
EN_1 and PN 1 flip-flops, the decoder must remove the effect of SN by Mod-2 adding the
generator polynomial bits to the younger syndrome bits. Hence,
SN = (SN+1 0 PolYN+1 * Fwd Poly Enable) * Fwd
In the reverse mode S is just the Mod-2 sum of EN 1 and PN -1
SN = (EN_1 E N P 1) . Rev.
At this point, consider consolidating the various terms. Requirements for
predicting H and IN are then easily added.
The best approach is to group terms into ones used in the forward mode and
those used in reverse.
[(LN_ 1 = 0) EN- I N-1 SN is predicted byFwd
(L = A'-1) · S N T N (S N+1 ·D PolyN+1 · Fwd PolyEN) · Fwd.
(LN 1 = 0) EN-1 PN-1 ' SN] , predicted byRev
[(L 1) EN-1 ' PN-1 E 'N-2 (EN-2 - 1 PN- ) Rev,
never happens.
116
So far, the expression predicting (LN_ 1 -= 0) ENN-1 . P-I ' SN has
been found. Next, consider predicting (LN_1 = 0) · EN- 1 ' FN-1 'IN
IN will be set whenever the decoder makes a reverse shift. So, (LN1 = )
EN1 . 1.IN will be predicted by the reverse terms of (LN- 1 = 0) * EN 1PN-1 EN-i ' PN-1 N
These are
[(L= 1) ·EN-1 - N-2 N-2 ' Rev
Finally, the two terms obtained thus far must be ANDed with the terms
predicting H. H will be predicted when PN-1 . Rev exists. PN-1 = 1 indicates a forward
move has been made with LN_1 = 1. ANDing PN-1 with Rev then indicates the decoder is
about to back into a branch level where both paths have been tried. H then will be predicted
by
Fwd +PN-1 Rev = .
Predicting Hf, therefore, adds nothing to the two terms already obtained. The flip-flop,
T -T - A, then is qualified by
[(L=A-1) SNI N (SN+ $ PolYN+ 1 * Fwd Poly EN] · Fwd
+ [(L = 1).El**N2 . Rev
[( ) E-N_ 1 N P-1 ' EN-2 PN-2] Rev
+ Max. Rev= 1.
At this point it seems appropriate to describe the details involved in controlling
addition of the generator polynomial. The problem has two basic aspects. First, on forward
moves where EN_1 is to be set to a one, the addition is required; this addition is performed to
remove effect of SN from younger syndromes. Second, on reverse moves where EN_1 (=1) is
about to be combined with PN-1 to reform a syndrome bit, the addition is required; this addition
is performed to cancel an earlier addition.
The last aspect depends only on EN 1. If EN 1 = 1 and a reverse shift
occurs, an addition must take place.
The first aspect is more complex. Addition should occur if EN 1 = 1 is
hypothesized and a forward move takes place. Recall from the expression for EN_1 that EN_ 1
will be set on forward when
(SN I N) * (T-PT -A) . Fwd + SN * (T - T - A) * Fwd = 1.
117
This expression should qualify the polynomial addition. Now since the product is needed early
in the clock period, a flip-flop output called Fwd Poly EN is ANDed with Fwd and used as the
qualifying signal. The prediction of the expression,
(S N IN) (F-T - A ) + SN * (T-T - A),
is used to qualify the Fwd Poly EN flip-flop; just how this is done is described below.
Suppose an addition on a forward move is called for; what this implies depends
on the move the decoder made in the clock period just prior to the one containing the addition.
If the decoder moved forward during the preceding clock period, IN =0 and
the expression
(SN IN) (TT - A) + SN ( T T -A)
becomes simply SN.
If the decoder moved backward during the preceding clock period, IN 1 and
expression above becomes
SN (DT- - ).
So, qualifying Fwd Poly EN amounts to predicting SN during forward moves
N~~~~~~~~~~~and SN D (T -T -A) during reverse moves.
Predicting S N = 1 was already done for flip-flop (T P T - A). The
expression used is:
[SN+ 1 · PolYN+ 1 * Fwd Poly EN] . Fwd = 1.
Predicting SN D (T--UT -A) can be done using two results from earlier
discussions.
First recall that on reverse shifts, T- T - A is predicted by
[(L = 1) EN-1 ' FN-1 ' EN-2 ' FN-2 ] Rev + Max Rev. = 1.
118
Recall also that on reverse shifts SN = 1 is predicted by
(EN_1 PN-1 ) Rev = 1.
Combining the above, SN ( (T-*T -A) can be predicted by the terms
4
(EN 1 PN1 ) · [(L = 1) EN-1 ' NN-1 N-2  Rev+
(EN 1 () PNI) * (Max Rev) . Rev +
(EN- 1 () PN- )· ' L= 1) · E'N 1 · N-1 ' 'EN-2 F-2] (MaxRev) Rev = 1.
ORing the forward and reverse terms obtained then gives the final expression required to
qualify the Fwd Poly EN flip-flop.
Next, consider the most basic of signals required in the decoder, Fwd and Rev.
The decoder moves each clock period; Fwd and Rev are just the inverse of each other.
When a forward move is to be made, LN >T. In the decoder LN-1 is actually used in
the test. LN will be greater than or equal to T if
(L > 2A-1) +(L > A- 1) - S N + ~T = 1N-1 N-1 N NN
In th decoder, the A counter has stages A2 through A2 . TheMod A counter has
stages MA2 through MA22 . A special flip-flop makes available a signal, :)/20. When
A = 5, 2 0/ 2 0 =7M-2 0 ; when A 6, 20/20 = MA20 . Using these symbols in the equation above
gives
(A23 A22 + A21 + A20 MA2 2 T0/20)+(A + MA2 T20 SN +N
SN IN = 1. 
The expression above gives LN > T. Fwd requires ANDing LN >T with H; H = 1 implies
the decoder should skip the then present branch and back up one step further.
The final expression can now be written as
A23 + A2 2 H + A21 H + A2 MA22 2/2 + A20 S.N
H+M 2 H + * S H = FHR+ MA2 .2/2 SN H*i S ±VT H =Fwd
119
Instead of generating these signals during the period they are used, Fwd and Rev
can be predicted a clock period earlier and appear at the output of a Flip-flop at the beginning
of the clock period they are needed. This eliminates a delay of an OR circuit used to generate
the expression above.
To obtain an expression used to qualify the Fwd/Rev flip-flop, consider the possible
transitions the decoder may make to a forward state. These are tabulated below. For brevity let
-S N + 1 (S POIYN+ 1 Fwd Poly EN;
Sp will represent the predicted syndrome bit wherever it is used in the following.
Possible Possible
Beginning State
State Predicted
S I Fwd S *FwdN *N *Fdp* S
SN IN **Fwd S Fwd
SN N S Fwd
S I Fwd S *FwdN N P Fwd
S I Fwd S Fwd
N N SN TN ~~~~~~~Fwd Fw
S IN Fwd S Fwd
N
N IN .Fwd S, * Fwd
- EN-~S 1 *Fwd T *Fwd Fw
S 1 *~~~~~~ ~~FwdS Fw
SN wP
E *Rev E P FwdN-1 N- 1 N N
E *Rev N N FwdN-1 N-i E F PS p Fwd
Note that transitions from states ENl PN-1 Rev and EN_-1 PN-1 Rev are accom-
panied by an increase in the Metric and by the setting of H to a 1. Hence, except when Max.
Rev is reached, no threshold lowering can occur and a second reverse move must follow the
presently scheduled reverse move.
Of all the possible transitions listed above, five dictate a forward move by the
decoder without immediate reference to the metric. Combining beginning and predicted states,
these five transitions are represented by:
120
N IN S P Fwd
S I * Sp* FwdSN IN P Fwd
S I *S Fwd
SN · 1-N *'Sp *Fwd
N N P
EN-1 N-1 Rev
The term Fwd in the first four combinations implies the metric will remain positive
for the given state of SN and IN . The term Sp says SN IN 1 for the state to which the
decoder is moving. So, the product, Sp Fwd = 1, in each of the four says a forward move
should follow the presently scheduled forward move.
The fifth combination will always be followed by a forward move with eN P = 1.PN N 1
The remaining five transitions require certain minimum metric values before the for-
ward state they predict can occur. Two of the five require the same metric conditions and can be
combined. These are the transitions beginning with the state SN IN Fwd or SN IN
Fwd and ending with state Sp Fwd. For these two cases the decoder must have as a metric
value:
A23 +A22A 2+ A? +A20 MA\2 2 A20 MA21 MA20 (A= 5) = 1
The metric counter's most significant stages, A23 and A22, are large enough to
absorb any of the errors that may occur for the transitions listed above. Hence, if predicted
H = 0, the presence of either A23 or A22 is sufficient to predict a forward move following the
presently scheduled move - be it forward or reverse. With this idea in mind, A\23 + A22 can be
left out of the expression given in the paragraph above and all other expressions where a minimum
metric value is required and included as a separate term in the overall expression used to qualify
the Fwd/Rev flip-flop.
Considering the ideas suggested so far, the Fwd/Rev flip-flop should be set when
Fwd . . 1~~~ ~~~~~~~~~ 0 2Sp Fwd + EN_ 1 PN-1 Rev +SN IN Sp (A2 + A2 + MA2 +
1 0 1 0 2 0 (\A= 5) MA2 MA2 )+S N Sp (A2 +A2 *MA2 + A2 MA2N P
0 1 S0 1 2 1MA20 (A =5)) Fwd+SN IN Sp (A21 A2 +A2 MA2 +A2N N P
MA21 MA2 (A = 5)) Fwd + EN- 1 P A2 Rev + (A23 + A2) 
HP= 1
121
whereli = PN-1 RevP N1
The above expression does not reflect the need of going forward when the threshold is
lowered. Note, too, that when the flip-flop generating T- T - A is set, the metric value used
inqualifying the Fwd/Rev flip-flop will not include the effect of the lowering. In the test set a
separate flip-flop is set coincidentally with the "T-T - A" flip-flop, or can be set when
qualified by (T- T - A) (Sp + SN); this separate flip-flop includes the effects of threshold'
lowering and is used to preset the Fwd/Ref flip-flop in the Fwd state for these cases.
The Fano control logic discussed thus far is implemented on drawing 528760,
sheets 1 through 4. Signals (+A - 1), (+2A - 1) and (-2A + 1) which appear on the drawings are
discussed in the overall explanation of the metric counter design which follows.
In the discussions above, much has been implied about the Metric counter; these
implications are integrated below in the description of the counter's overall design.
Most basically, the Metric counter, made up of the Mod-A and A counters, is an
up-down counter. Provisions are made to increment it by +1, +A - 1 and +2A - 1; it can be
decremented by -1, -A + 1 and -2A + 1.
The Mod-A portion of the Metric can only change by +1. So, only Fwd and Rev
are needed as qualifiers.
The A portion of the Metric counter can be changed by +A or ±2A. Increases of
+A or +2A in the A counter are always accompanied by a decrease of 1 in the Mod-A counter,
thus, causing the overall Metric value to change by +A - 1 or +2A - 1. Decreases of -A or
-2A in the A counter are similarly always accompanied by an increase of 1 in the Mod-A counter,
thus, causing the overall Metric value to change by -A + 1 or -2A + 1.
Changes to be made in the Metric Value are indicated by the following lines:
(+2A - 1), (+A - 1), (-2A + 1) and (-A + 1). These are conditional and their effect depends on
Fwd and Rev levels and on carrys or borrows generated by the Mod-A counter.
In general, the Metric control lines indicate certain decoder conditions.
1. (+2A - 1) indicates EN_ 1 = PN-1 = 1; in the6A counter (+2A - 1) is ANDed with
Rev.; should a reverse move occur, the Metric will be credited with a +2A - 1
lost during an earlier forward move.
2. (4A - 1) indicates EN._l)PN_1 = 1; here as above the signal is ANDed with
Rev.; should a reverse move occur, the metric will be credited with a +A- 1
lost during an earlier forward move.
122
EQLtDQUI £BAME I
.a_
51z791
S1I71/
OLJ* 4
BL.a 
(/ MA 22; ."
(W2 9ZOA414) I a'z4 -
Xk, I MA 20 fOAoZA ) FBF9S)Z
E t.1- 2>I \E N- 2 >?L St / 5~
N.t- Is 7,sa
81:4, _ .
8. ,7~ 6 5
7 i 6 5
D
C
B
A
II
I
P.
I
I8 7 I6 5
2 I
rF-- _- ____ A4
i~ - '... /,.A7 2 7 S'(09 48)
*L _4 40 _o? __ __
-…5 A-2
MVVV K fVcJ, P'~l EU! 1-$T[-
V tWlML TOL CEL S [MY TO STOC SIZES
IAWA(1lR; rStWaUR S PE 9ra
timtxbtkvOPt PEIR So
wSTEN Imnes PE: AAL .t SM JUREtlvlaMK KA tUViL STD.
1111.66
EUVWIX1 MD! ELECTRONI WZM11 DIR MS.
WLUCV'C "'GUM1 rE I 0V 0217
LtEIURCL LA' t ECflEJC a1L&IiCtDIA1 t DDa E ISNJ I221S
.Mi.. STIO's PER s t I/4I6
r QUANTITY REQUIRED 
UNHLSS OTHERWISE SP:CII:ED
DIMENSONS AR. IN INCHES
ANO INCLUDE APPLIED FNllSH
TOLf RANCES
m* C ,acl I ..c ISGuS I -
IJ,- 1[[
[M A l N, A iR
2
LIST OF MATERIALS OR PARTS LIST
RADIATI ON INCORPOFNC ATED
$US11DOT tOF HARRI:-tTERTTPE Ct1RPOPATI1H. DE'EOJRIE. FL~a.DA
FANC DECODER
(C NTITLEOG Ie)(C '2NTR CL OG IC)
D 91417
IcA- I
5z? 8 740
1
REV
O0
4 3
+5 D
C
B
4
A
I 2^A/A,;'9
123
i 1..-u
:-
_7
i- ..
T-b T-A > -B4 A L -
rJH'34 sml 3_ A 7
T., ,1311
- ,.- ., 
I I
I
IIJ
PI
1 '1_ . 7
AKS -'f Tn 
,~A FK .. Wa~' '2
KA -51/4f5il -
,.'0 XVI4 6P G
ZO~'t3 s J Jz
AZ 3A62''
,ZO I,1 ,1. CZ'
I~'; o¢ vg "~~%-
7 f...//Il Ejy.
T -- T- >
j u,- 596z *, ,
D
C
!
r --
I ' .gS 'I
B
"~~~~~~~ 16
~o," s,~ >-' ...
Sag7 A
I
I A22
L~~~~~
A 2 2 Q
L - _ - - -_ - - -_ - - -
A
I 7 1 6 I8
EOLQPOUTI ERAIME I
6 I'--," 5 
_ -4
154f4 a
Bec C 
kELI.QUT FRAME Z.
1 . a
FWO JG47 fSi
ILA
AlSO~~~~~~~~
AF13
_I't/ bow4fli
Pu a Z Al SM.'o
_W o Z &A/ tv
M4 > R#m/DD4&LS
Pd-j A4q
A639
1140) ~A,1/7 5A'/
AJ4
49 E .V DIIVE
LI 4/49 
U49A
AIG
AG4O ;71761 ).t
d44 44P SN
BL7 AIA2OI
ebK7 BI
-OKI,~~~~~~~~~~~-
* as ~3S 13 - A4o°
SN.4
.. ___ _  _ ___ _ _ J
'- - - -~~F- --- - - 1- '1
' U4t AA46 II [ ~~~~~~~~~~~~~~~~~~~~~~~~II
I
I IIII
;LC U ht° BI
_ _ _ __ _I _ _ _ _ __ _.o
_ _ _ _ _ CC3 ;
I (431
I C cq
I ~~~~C. IJ
I Cv.I)
I C~po
I CMI
I ~~ CaO
I CI
I-~~~C 
(cf c c
I
I
.1 +5
I 4-
t tei ec50~~~~~~~~~~~
l " I" I -i
,ajjt C0 I REV J
- -_ 
> uUi- D§a4 I
eff ism, s43 b
I'
0 SS 7St, 5-#5 
Alas _t - 65
jfiS?, go AO
~..tk W ) 1A~o
I '
!d/ S~~~~~~fi 797, SO 7 .I
r Ixf -- ~~~~~~US - fEs37f, )1$ ,- E G.3?
j ~2 7 $77, 53AlIEf77S, t/3A
j .4E /450 H ~/3~'- i~3 1
I~~~~~~~~~~~~~~~~~~~~~~~~~~~~
C~~~~~~~~~
5' A 7T 7, s#/
ft2 o a,? lb?3 042 R E t
|~~~~~~~~~~~~~~~~~~ V5 7; n7-s12|~~~ . J Ia1 2 "33Rv 5?SAt
C, I2 3 t- Rj063 I
+ S D51775t7, 3 7
I ~ ~~~~~~ > tJ5 7- ar |1
I'+ ~ * t 7t,5 7 F ' ,[r0 ) u~r ;C, I:4I z;
+5 C' CL'1
I J Jr5$ [ £'U/.~~~s3 ~ u
71
R ) , ;vi- ¢£'
, . , m o/ Sj ? 7Z-, -.q!
j~ .t> a,.,, I
L _ _ -_ _ _ _-A 21 j
I L......ITEM | PART OR | NOENCLTURE T CODbNO . IOEN,'IINO NO. DESCRIPTION IDENT
?W T IsI FMi r O Va EID t o IDEm
MWNMErat TWC'J SES I Yl to TTOCI SIMS
otwMlfmpd;' T'SJI Kit9Yxo
:I ILV/: izCP4 TPiE XA. PER ST95 EO C/t li ITYI
PEE S T h0J R~!3 I CSTD S
IIA 5EYIAX5 Pt. Yi. SlIPAZ
L],XIC STV CIS P EC ' g STJ l RS
W OLCT EE . KCO, R O R t S1g
CI ICU AID IC EU A!C =am KID u
003113ICIE~t RJ5IInIL 115 135 5 F /I 53ss z
9 5 1 0 4 1 S P K C S S R I IS O 0 A N D
| QUANTITY REOUIRED |
UNLESS OTNERfWlCE SPRC/nED
DIMENSIONS ARE IN INCHES
AND INCLUDE APPLIED FINISH
TOLERANCES
t eIC m tCI :~to,. fGLES
MA ! ti AR
. /;,t. ///;,/Z/
ON I I._ __, I I _
LIST OF MATERIALS OR PARTS LIST
RADIATION INCORPOFATED
SMI;0'ARY OF HARRISP.1INTERTTPE CORPORATION. ELBOUJRNE, FLORIDA
TrTLJE
= AtO DECODER
(- .'D AND REV DI1 T ; IP JTION)
I CODC OEM!
D | 91417| S28 7- 0
|ISNITT - 5 §
2 I 2A8 /,/91
124
-4
T2S! .. . _ -
D
C
B
A
I I ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~IY~~~~~~~~~~~~~~ * REVI SIONSI
-IT | __ GlS-lW |IA |
I
'N#
_jtJC;,-, I
II
EOLDOUT FRAME \
8
RL v Z --
.Uv7- VsDr, rw o
FW5 EE>--
T - T - e -
t131- / G !,!,I 5
r,, > t '
</3/_¢tw*^~~ I 
-F-r -A i5
I _
I' s' t ',- .. ,,.',..h..~! ..J., .! A~..,. -. X
~ ~r~',6
;S ¢ l, ,',- 
i t ' u 3 ? j; 
a a '
r4 s: 7
! , LC- ! ; / 
,,~~ ~~ ,, ,'!A, ~. .
<~~~~~~~~~ ~ . < A/~2 r rzJ 
, ~_; .. .;.~i_ I;s-4
t vi 's bs goXs .er ;ro.-~~~~~~~ .,
L~~~~~~~ _ j' os9 - c!;
,~~~~~~~ ~~~ ,' ,,-;J . . . . , _
8, - --- i I 6
7 6 5
C
B
F- .L-U P
V/I -
N
4'
"I 1
"*' 5 ?' t'__
i I - S _ '
tv~~~ Iu I 
I
I
8 7 6 5
FOLDOUT FRAME 
1 34
-- JFid lfi g*
t'3
_Clot., +5
T rA1 7 -7 --a
A/21 A64i 9 -52, 7,5 . /
4+ 5 ;3 -
T In 5
a a TAtA )! '
?N Ak b :
It 
I I? 
tR- I *, .S1, b 
I I~.I.I
t, I n A , _ .
- I '
' 5 -
1TE4 PART OR
~I~~ O IET O
_ I
i1 o S ASSY I SDO
APPUCATOS
PM TO nB FurE Or Bu[ RS ADT sr?? E; t
MMVER1ID TWU5I100 APPLY TO S'XK~ZE
iLYAICT' ;I TOL*;lUor PS ER ;:X.W
WOR A'"I5:Ir ,Or 9xwc f
OLFOOIOH 011)2 UFJR A11ZT B
!S0RE.50MNS KA0 4!1 S0012
to3iC 03110 AI5 FR :L srDTO 1
tIRLISIo 4Nl AN) ME1IVIUMN KA VAS
EuLCTRIA L 0 A uj0o II C 0111) nl FOB OI S
T11 IrN
C 1tFIC s01LS 1 0A RIOCTRICL PT)
EBUOTROhLO ,I A;IU KAB ULU1.00101
r roC :T C L AI 101 11 0 RIOfl OORII
DEOIZS rIONS Ril USAS RILI1.u
IOLMM SIVE151 FOER ARs ALT IB
4 I
I OUANTITY REOIJIRED I
UNLESS OTHERW'ISE SPECIFIED
DiMENSIONS ARE IN INCHES
AND ICLUOE APPLIED FINISH
TOLERANCES
_t _- Il * CK ._ ....... .;t
LIST OF MATERIl
1T'
FRAEDIATION INC/O OrfOFRATE D
SVB's-: .~ ^' F HIRS-14' LTER .''IE COR0P1'- TC', .: Z- .R:_ F IC .DI
TITLE
F :EC - =D
( :~~ .R- .w !, 9 . IG 1 :
. 9 4E 1D|91 41,7 _ 5-28 7GG
IC LE ..
A A- - -i '
14 - i~ ~ ~~ i ..1i 3 z
A
1 2ASA1.'A,'
125
2 I
-> A . K B
It
D
C
o I
01
C2 
r~l
0 I
m
n
0 !
*r
X;i
IT
iR
7tS
IA _
v _
At _ 
V- t. I 1 - _A...VVAV___
. -- : I 2
I -- -i
i II
I
A I
Z I
Z.
I
__I_ _ __ _ _ - _ _ _ _ __ _ _ _ __ _ _ r _ _ _ _ _ _ _ _ _ - _ _ _ - - -- _
- - - - - - - -- - - - - - - - L - - - - - - - - - - - - - -- - - - -- -- !
_I _ _ 
11
-1 -1--
t-
E.'") . I;_//',/7,
I I
| Ti E ET S- T
EOLDOUT FRAME |
8
5'.?j7r S. Ht
E ! T7 A N T 2 5
2 6
27
25
A 26
SF,75'xF/JeZ 7
52 1 5'? SNP &/t~t4 3 7) 4/i'
CNIT I'- )1C Nl' T I-, 4M31- el A VI -AH-7 4':3 4.J
,4/'E-47)J -,.,,
_14C
12 - A. z ,CC A4Z4 >4-A-4 e47 
I
I _=~
vZ~fy 
i=., I I I 5
7 a 5
D
C
B
- v- l Il II I
I 6 1 58 7
FOLDOUT FRAME 
1 3 2 IT I ~~~~~~I__ ________
~I ii. 
~
.RE.VISIONS
i LYRI DOSCRIPTSC ATK IAPPRORRO
Ii ?
'I TS 1
"I
IAS 1v# I
8 tA2 O
:1 tM4S 
43
~II 
'45 | 1451 I 4S|
U4 14' 1Z7 + 5
(.,V,)~, 8
.r BJ23 
t Rr I
.4 I7J8 -~;I A'/1 ~ 51 Z4~~~~
]\ sr2.8r .
i 435 ngf3
'l i I
-r
Os J1 ,
_ 3,I I?
i- 1 ,
4- 5
x/8
51,,,7- O
'2)3 5534 Ic~z II 4.
.IL ________I __ ____ __ 
__
D72d 1 l l g78 ~~~~~~~~B4;
L133A1 0Dl1 Y a <M2 P
{a35 ~ ~~~ 9S zi/uJ z 1s 
,. .
yKZ9 t~~~co yZ 
I I~~~~~~~---- ~~--IT-
12
--
M} t I
a40 Li D -1
- 30 49sK, S IC- AFZ4, , A A7-C--
_U148 E2 °' -
:i5- 
~
BLS :'-~ , I
F i-l 73t33~~~~~~u)a 
Ii I 34
I F~ - .e.a~ --  .. .... :- C
- L I 3 - -- Ii
~i' =~ l >LtO > rx
' t Aa < ,,1 
-- L_ II| te8 1 _.____ _
I _____- I I '~ D [ !| TIYINI ~,
C
3
< KLOK; B.1Rl.A N13
) , !e AKI e
~t43
fZf 75-7 ..IK
_ 
) A . t AeZS
I >LA> Lo^ E,
(A!3 DE Zo,
PUJ7L7AAU
-- ~~~~~--3-- ' ' ....-1 17n AISC A35t3 7 S 7 )~lsc*
,,u_~ {--J ("'s?*,)'40~. ,LI I '';? 
(Al? EE4eT > ~~~C$,M1ARE
I IJvT* 
tO'ENCLATU~t IF C
.E-SC> R£I -, N_
B
7-
RE I I;
V, 7N 4-r -SS | U-D / 
APPUCJ 4
t 4
*1
|PARTTO 3 EtEOF GU RS AND V" I WS
| M t [ R IAIL TOL[ECOS ALr.Y T0 STXI $12s
1IkUFA1T'U?.tiG TCLF"fS11 PtA 2II| ENYAN$H;! Pit IaEt E e,
|ASPE'ltAIOhS PElR Sil ITO ?
LOGIC $ST3.0' PtR K A' o, SD 6
I ~l 1 RUNOSff T5L SIDCIVSKRnOIvDrL-':IcR' At.) T)LFAItC''I PIP DSAS
hA4 5ic
I CTA.C t iO ElCit t.O1C D:AliAi PAI UrLs
I :4.1 Si
GI A)LHU $1# V o ELFO T It fiSL P4D
I LECTrNCL 2 t ¢ Ti; 25 
.
WS 302 17
ItOCtPTi A.ti Ea Pt1 2 A fftft11
| USh't 311TS P'-A :;1S T2lit'|,D SIMS nq W &?S#DSJ
W ULCSSGOT.EICRISC sF`ECI% 0c
IC!ENSIONS ARE IN -NC-ES
AND INCLUDE APPL'EDC FISI
TOLE tRANCE
I " I lc... _ .. cl> .:c
-
.
-
, t. -,
4 , .
I I i ~~~~~~~~~~i 
LIST OF MATERIALS OR PARTS LIST|FA.Z7.IATfION INCOIR OFIIATD
|u S2:I -> 01 AqlTR TYPE CO=-:I-:'T.:'. '- 7 _S . FL OR t, A
SxIE, CCDC-Ecrr h. | _iP
D 91417 8 7 C
I ,f . , _ .__________
i
126
4
D
1'
-SZ
'J4S
I I I t
1.Z
I ~ I _
N O tCLATU RIo i COGECOESC RIPTIOI |IDI
:-- --- -. 1  - - -;,~ L~11,1 I7r1 LES 0 o .rR1S co SPF`Z 
I
-7
E
I I
_
-j1 IEA,?-
PPULL-UP I Al),8 ALZ.
I ._,, .. r_:
=
r-- L
| QUANTITY REOUIRED I
2
'30
;28
FOLDOUT RAN'1- I
8
a'Bs A:. .9
5Z1757 9i 44i'M
037.$
6,31 SOL
,, 313 S)i3
"9%. '- A&II -.
r-.. . . ' - 1 it
I III
i I i
~i~ ~~~i I
_ S II
u4 1. 
I . i I
I iI
I I I
I I II I I
L I* " I|l j5.L_--t~~~~~~~~~~
S.~ w. 5t T 7i _ O 
S ,. ~ ,Hj~34 T-- - A
*'~"2. D * 3 &i 3 _,
i
Alq
.=.. - )Lz 9
I
kis I N ; -,-:
I X.oM: zF.-r.
I I i
7 a
D
5
C
B
I III I I
I
I
I
II
I
II
I
I
I
I
I
I
I
No°e : C.YsE. -XZ .t-50 is; ME' f IXC3
I I I7 58 6
u, S !.
tWf It
h QA 10
C. I,
dl, IN t3
F 05
1lb 3l
jt, 1
1bZ;2
iV, 3B
/.C. #. 
^.L *9
AG So
A 3%
BKq~
'
l./k '.'l
Bo D q0
B D to
tI F*-
C. I
C-I '440
5Lj7Ib#_S %02 . 9L 1 I1, 
t 5\N4f,5 *k 
C P.s
r. , At%trSit
t 3's
t~~~~ EM
F IFCI
VC\ Fe C 
FG q I
I':iq%
T .I..-I' '-'E'3
| -' FC t 3 
tF 3t
r, CO3
EcI3
I. L-
s
F:.
A" ik
X:~:LA~A a :
E r~
A..
. -, 
NE SSY USEOO 0
APPLICAIION
4
UNLESS OTH-IER'WISE SPEC:1i£D
PrItw~rFtter iA74U eEs ODIMENS10¼S ARE IN INCHES
DVWI(ILISt OLUt.ES AOI. TOSTOCKSIZES AND INCLUDE APPLIED FINISH
KAXSUFACIUNH TCEJ1 CES PER s MI M2 TOLERANCES
CFGiU.'.OLII? # FLI ¥,L ITO-! '-r 'L -
St^KWA TiiREAu s V~ ST' __9
rW'tTIGCC4S PER ML SS 12
O.tC 11T130LS 'l Vt StD Mg
O!Y':.t;i 3i) !L lc'J.%JoE; PEI nU
T14 $ 
EiTl1?CIL I0D fLCO;W% irCURPEIRUUSAS
III 15 66
CL- c ST&OLS F ELt.CTIAL NDO
ELC'LT'I~!C 0:;.I E US 6 r0 .147
ELU-,:':A, jvo WLr'ITN!C V&EtEW
CE:.CTi iO!l; ?'. LAS 32.3645
0ELD'611 0 SYMBOPS PE, JAI ILl5
3
4 2 1
_-r *
C E ',
C. ' 
-,t 3 ?
-r. T 13
0 ~~~~~~~F C_ 't 
F FT, 
V Y*
p1, e8
TR
IDS4 F.
ID S;
F A 4'
v:. Ib
C -1
Eb r~
E C~ S
- * t
CF~ #t
'eA 'S$
EA qS
E. 1D ,t
'EL:
ra, As
T LT
Da .0
1F 3
Fa. tO410 10
c... 6~;
C- Il
C .v;k
VA11
C V 14
ce F;
CC 
CoS'
!aG-;
D
C
B
It 
tSc- %%
tWI 35
A
2 I 2C F,1. i.
127
I ~ - S-:s
N#Tsj Sf7f7p s ,Lj. t oorEa< i
FRA.ME '~
3. (-2A+ 1) indicates SN IN · (TT - A) = 1; (-2A + 1) is ANDed with Fwd in
the A counter; should a forward move occur under this condition, the Metric will
be debited by -2A + 1 for passing through a double error, etc.
The control signals here then areanticipatory; they become effective if the forward or reverse move
they anticipate occurs.
The main Factor affecting the design here is the 20 MHz operating frequency. Using
the TI 74S series logic, qualification of the counter stages is limited to five and sometimes six
orders of logic; it is this limitation that suggests that the counter design give preferential treat-
ment to its Fwd and Rev control lines. Generation of the Fwd and Rev signals by the control cir-
cuitry requires two orders of logic. So, propagation of these signals through gates in the counter
should be kept to three orders or less. Now the generation of carrys and borrows propagated to
the \ counter from the Mod-A counter depend on Fwd and Rev. Using Fwd and reverse in gener-
ating the carrys and borrows would require propagating these signals through two more orders of
logic; the carrys and borrows then would be limited to one further order in the A counter. It is
this restriction which prompted the generation of conditional signals such as F carry, R carry, etc.
These conditional signals contain all the required terms except Fwd or Rev. They are then ANDed
in the A counter as required.
A final consideration in the design of the Metric is the entry of the threshold
changes.
When a threshold lowering occurs, the Metric will have value zero and Fwd will
be true. What value the Metric assumes on the forward move depends on the syndrome bit.
When SN = 0, the Metric must increment to 1 + A. Incrementing by +1 will occur
automatically in the Mod-A counter. A gate qualified by (T-.T - A) *SN enables the setting
of iA into the A counter.
When SN = 1, the Metric must increment to 1. This occurs automatically as above.
The Metric is implemented on drawing 528791, sheets 1 and 2.
A flow chart diagramming decoder activity is given in Figure A2-3.4.1.2-3.
The term Max. Rev. introduced earlier had been explained only briefly. The
details of its generation in the test set are given below. These details are given in context with
a broader description of the decoder's operation and refer to the block diagram of Figure
A2-3.4.1.3-4. So far, discussion has centered on decision making in generating the EN, PN
pairs. Now the attention shifts to handling the pairs generated.
As forward-progress is made through the tree, EN, PN pairs fill their respective
registers. The contents of the two registers are then transferred to 8 x 32-bit scratch pad
memories.
128
EOLDOUI ERAME 
'9~
4. 3s E 
t
Il
.D
r
C
,-
B
A
B l --- i 
7 a
5 TART
..
f ~~~~~~~~~~~~~~~~~~~~III I I
i
A
I
I
I
41
I
I I I8 7 6 5
,fio ,S
21
Miff TO BE nua or gun1s ANDSK rm
lal4l~'~ n0~ d ~$D1
EWl ~." A,~ RO CUEWC1S1131 mmII FIW1
SItll TIHGU S PUE VIL F I
i'0aLNHIPS Pm IRSMtIItCw OIIIADO P0 tI 070M0Kt1A00MM PER MLtS73D6
IIl1t .SIcIWG A" TEIWCS PE nAS
T14 III
wmazx^ Amo run~ Amm ?ao nAu~s
WcTO Srt FO R C1tM rot AILS
EZnfIC7 011(c31 rcA KArr anUT
mrutul An3 (LICC EUrfiED017C0103 PER ULMS Yu 104a
t Sam w5 ur At tA2 s
DOMENSIONS ARE IN INCHES
AND INCLUDE APFPLIEO FINISH
TOLfAtNCES
: _ : :N AEN . I
3
RADIATION INCORPFORFATED
SUBSOIARYY OF HARR;S.0TERIYPE CORPORATION, MELBOURNE, FLORIOA
'ANO DE ' :,ER
FLC W C- ARTT
SIZE COOL 10(1(1 1(0 REV
D..I ..91417 ,C-, ,q2-3 .v,.1.2-3 I
'~
SHEET
2 1
129
B
A
4
I
I
I
FOLDOUT FAhfv!l
0
SE RIAL INPJT DATA
C L DC K 4
_jSHI~FT RE G
SLtP/INV E FR T O BITS
LOG IC 
AND 
TI Ut NG
0 POL Y SW
DATA HOLDING
REG 32 BITS
4
FWD
A = 5,6
8 I 7I I I
7 3 3
D
C
B
A
I I ~~~~~~~~~~~~~~~~~~~~II
I
I I I4
8 I I7 6 1 5
PI, 2ni I i . -Ag~, I. Z
CORRECTION DATA
REG 32 BITS
BIT COUNTER
AND
SCRATCH PAD
CONTROL
+2A -I , +A -I,
-2a +I
USED ON 
tUT tO ff ORF f EU1M ITD SiTW EDTO
OUMM tiR TOU&M-M *flU TO 5100 SM
WARUOFgTO=C TOUXMM PU 5TT
wotlOt PER 9mu
STC" NTAS= u blST.4m
AMOETOM PID ER N.STD
LOGIC sMOUJ Pu MJL4TD4
DilRSIONMI; ITOi rClE IPR AT
TIA.I"
E[1TOALUS AM EULCT10NC DlIMtU PufflVT
TRlO-I
tCMR TSymm3 FOR tluCIWO WIR
TUCTIOl rxC va PR LSU n2u5
nICTtICAL MD 11ICMc1C FUOEffM
DITISAISTO Pffl V!S T30. 1E
TEITAIS 5051U TU PUM 11J51
rm 'Y PART OR
NO. rOEN'TIFYING NO.
CDIMENSIONS lARC IN INCHES
AND INCLUDE APPLIED TNISH
TOLERANCES
1 C ·t Iu Ai Re. £1i00
3
ADD: Ili1110100
(COUP. OF 12)
t SB
T C
2
I
D
A
,130
SERIAL
OUTPUT
DATA
CLOCK
4
F:ADIATION INCOFRPOf RATED
SJUBDIART OF HAPRIINTrERTYPE CRPOg:ATION. ME1BOJRNE, FLORIDA
-TT
FA N 0 DEC ) D -_- R
B .OC K D I A G pAM
I
In the reverse mode, EN, PN pairs are converted into syndrome bits. If this mode
prevails, the reformed syndromes move back through the computation register and delay register
and fill the syndrome register. There they are parallel transferred into the 8 x 32-bit syndrome(s)
scratch pad memory.
In the searching process, Max. Rev. will be set to a one when the decoder, in the
reverse mode, withdraws all bits available from the error and parity scratch pads. At this time, the
decoder will have reached branch N = 1 and threshold lowering will occur as,per the earlier flow
chart of Figure A2-3.4.1.
The process of adding bits to or removing bits from the scratch pads is dictated by the
scratch pad control logic. This circuitry consists mainly of two counters, two comparators and
some control flip-flops.
One counter called the bit counter uses Fwd., Rev. and the decoder clock to
detect when the parity and error shift registers have filled with 32 bits and are ready for a parallel
transfer to the scratch pads or when the registers, in the reverse mode, have empties and require
a parallel transfer from the scratch pads.
The bit counter has 8 stages; the first 5 count the bits shifted into the E and P
registers. The last 3 address the scratch pads. In the forward mode, one of the control flip-flops
is qualified by count XXX01111. This flip-flop then enables a transfer to the E and P scratch
pads on count XXX10000. In the reverse mode, one of the control flip-flops is qualified by
count XXX10001; this flip-flop then enables a transfer to the E and P registers on count
XXX 10000.
Use of the bit counter to effect loading the syndrome register is similar to the process
above. As mentioned earlier, a third scratch pad called the syndrome scratch pad provides storage
space for bits during the reverse mode. Once the decoder switches to the forward mode, the bits
stored in the S scratch pad are transferred back to the S register. When the scratch pad empties,
new syndromes from the plated wire buffer memory are loaded into the S register via the S buffer
register. To detect whether the S register should be loaded from the scratch pad or from the
buffer register, a reference counter and a comparator are used with the bit counter. To see how
this works, first note that in an error free situation, the E and P scratch pads are full and the
three most significant bits of the bit counter compare with the 3 bits of the reference counter.
Note also that, as the decoder continues forward, this comparison remains valid. Now, when an
error situation causes the decoder to reverse itself and causes a transfer from the scratch pads to
the E and P registers, the scratch pad address will decrement and no longer compare with the
reference counter. This compare or no-compare condition is then the factor determining whether
the S register is loaded from the S buffer register or the S scratch pad, respectively. In the logic,
a control flip-flop is qualified by bit count XXX01111 ANDed with Fwd. and compared so that,
in the forward mode, this flip-flop enables a transfer from the S buffer register to the S register
on bit count XXX10000, A different control flip-flop is qualified by bit count XXX0111 dotted
with a Fwd and compare to effect loading the S register from the S scratch pad on count
XXX 10000.
131
Loading of the S scratch pad is coincident with the transfer of data to the E and P
registers. The control flip-flop dedicated to loading the S scratch pad is qualified by XXX10001
ANDed with Rev.
From the simplified block diagram of Figure A2-3.4.1.2-5, one can note the
relationships of the scratch pad control logic and the manner in which Max. Rev. is detected,
A second comparator compares the address bits with the reference counter bits and detects when
the E and P scratch pads are about to empty. The comparator will indicate Max. Rev. when the
address count is one greater than the reference count. At this point, a word about the comparators
might be helpful. The comparators compare the 2's complement of one number with the l's com-
plement of the other. For instance, in generating the compare signal used two paragraphs above,
a comparator will qualify the compare flip-flop when the scratch pad address is one less than the
reference count. When this relationship exists, the l's complement of the reference count will
equal the 2's complement of the scratch pad address.
The logic of the two comparators is given as sheet 4 of the decoder control logic.
The logic for the control flip-flops and drivers is given on sheet 3, drawing 528759. The bit
counter logic is given on sheet 8 of drawing 528758.
132
j~ . ....._
'S
133
r" I --
i
to
I
I.
C>
-5
o
c
0u
_0
a
u
Ln
N
.
Ul)
I-
.L -
"NI
I4
t
Iz 
Group Synchronizer and Demultiplexer - A8A1A2
The group synchronizer accepts data and clock (information rate) from the decoders
and then identifies prime frames, words and bits. The incoming bit stream is converted from
serial to parallel and then presented to the correlator and demultiplexer. During the process of
identifying specific input patterns, the group sync also generates control signals for use elsewhere
in the system. In addition, the unit continuously selects data samples from the input data stream
and, as longas the data patterns are recognized, maintains the system in a sync lock condition.
A2-3.5.1 Group Sync Policy
The overall design specifications for the group synchronizer are listed below:
1. Bit Rate - 9 MHz max
2. Frame Length - Fixed from Transmitter Rate
3. Frame Sync Code - 30 Bits (Fixed Length)
4. Frame Sync Strategy - 2 Modes
a. Search - Fixed, 1 compare to Lock 0-4 Errors Selectable
b. Lock - Fixed, 1 no compare to Search 0-10 Errors Selectable
5. No Aperture Width - 1 Bit
6. Output Signals
a. Frame Lock Level
b. Parallel Data to Demux
A2-3.5.2 Group Synchronizer Block Diagram
The basic group synchronizer consists of a 30-bit shift register, a parallel digital
correlator, and timing and control logic. However, since the functional relationship between
any Group Sync and Demux is basic to their operation many of the functions serve both the
group sync and demultiplexer. Therefore, for the purpose of this discussion they will be con-
sidered as an integral unit (Figure A2-3.5.2).
134
A2-3.5
0N
0I-
0
135
0
I
o.
- U.
tAc!0 
v
0
o <
Uo
a-
z
ce
U
z
Lol
x
D
E
a)
v0
-o
C
0
U
c
Vs
0-
0
I
.a
0is
0
U0
co
CO
C~4
I)
04
.-
U-
The shift register consists of a 30-bit shift register wired for serial in/parallel out
operation. The register accepts serial data from the decision device and stores the last 30 bits
received. The output of each stage is presented as an input to the Parallel Digital Correlator.
Within the Parallel Digital Correlator, two processes take place. First a binary
number equal to the number of differences between the expected sync pattern and the contents
of the 30-bit register is obtained. This is accomplished by comparing the expected sync pattern
to the data in the shift register by using an exclusive "OR" circuit. Any differences in the
patterns will'be added and stored through five levels of addition. The fifth level of adders con-
tains the binary number of the differences in patterns. Thus, the second process takes place, the
difference between this binary number and the number of allowed errors is obtained. If the value
of the difference is less than or equal to the number of allowable errors, then correlation is
achieved.
Once correlation is achieved, the Group Synchronizer signals timing and control
that it is in sync. Previous to correlation the bit and word counters had been set to a specific
state. On correlation they are allowed to start counting. As long as the group sync is in lock
these counters in conjunction with timing and control will now merely output the last ten stages
of the 30-bit shift register to the appropriate destination. If for any reason the group sync loses
"lock" the processing of data is immediately terminated.
In addition to keeping track of bits and words, the Group Sync and Demux also
count each frame. The frame counter is used to maintain timing and also to ensure that syn-
chronization is maintained. It does this by signaling timing and control that a frame has elapsed.
This ensures that the group sync checks its synchronization once each frame. If the number of
errors in the pattern is less than or equal to the number of allowable errors (0-10) then the system
is maintained in "lock"; otherwise the processing of data is terminated, and sync search is
reinstated.
A2-3.6 Receiver Rate Buffer (A8A1A1, A8A1A8, and A8AlA11)
The receiver rate buffer accepts 20-bit TV data words from the demultiplexer,
detects vertical TV sync words, formats the TV synchronization and buffer synchronization words,
and writes assembled 30-bit words into the plated wire memory. Thirty-bit words are read out of
memory as a function of TV video reconstructor operation. The 30-bit words are disassembled
into 10-bit words and sent to the video reconstructor.
A2-3.6.1 Receiver Buffer Operation
The receiver rate buffer consists of a random access, 30 bit x 512 word, 200 nano-
second cycle time plated wire memory with associated input - output controls, buffer synchroniza-
tion logic, and input data formatting logic as shown in Figures A2-3.6.1-1.
136
Start Cmd.
(from sync Gen.)
Next-word-Request A- '
~~~~~~~~110 bit 1
register
Figure A2-3.6.1-1. Rate Buffer
137
Referring to Figure A2-3.6.1-1 ,- data from the time division demultiplexer passes
through a set of gates and is assembled into 30-bit words. Assembly aligns the data so that TV
sync and buffer sync words occupy the same bit positions at the receiver as they did at the
transmitter.
Once 30 bits of data are assembled, a write request is made to the timing and
control logic by the assembly logic and simultaneously bits 1-20 of the 30 bits are moved from the
30-bit assembly register into the-20-bit buffer. While the request awaits service by the Timing and
Control (T&C), new words can be loaded into bits 1-20 of the assembly register. By the time
these bit positions are filled T&C will have commanded the memory to accept the data at its
inputs. Data is removed from the memory on an as-needed bases, 10-bit words are transferred
from the 10-bit register.to the Reconstructor or to the Statistical Decoder depending on the mode
of operation. The operating unit issues a next-word-request, this pulse is gated through the
T&C to the 10-bit register where it loads in'a new word from the multiplexer. In the T&C the
same pulse increments a mod-6 counter so that the multiplexer will select the next word to be
accepted by 10-bit register,
The mod-6 counter is decoded to tell the T&C when one of the two 30-bit buffers
is empty. When such a situation is indicated the contents of the 30-bit register is transferred
into the empty 30-bit buffer. Under worst-case conditions, one of the 30-bit buffers will be
emptied and refilled by the contents of the 30-bit register, then before the 30-bit register can
receive new data from the memory, the second 30-bit buffer's data and the first 20-bits of the
first buffer's data may pass through the multiplexer. This case occurs when:
1. The ZOI/ZOP mode is selected and
2. Each of the time tags represents one sample count (at 9 MHz) and
3. The read request decoded from the mod-6 counter occurs at the
beginning of a memory write cycle.
The basic operation of the receiver buffer can be summarized as follows:
1. Write commands and read commands are decided on a priority
basis; if a write request and read request are received simultaneously,
the T&C will generate a read command.
2. The input section (consisting of the input OR gates, test generator,
assembly logic, assembly register and 20-bit buffer) formats data at
the memory input and creates write requests. The write request
generates a write command to the memory and the data is absorbed.
3. The output section (consisting of the 30-bit register, two 30-bit
buffers, the multiplexer and 10-bit register) unpacks the 30-bit
words for the requesting unit and smooths the data flow between
the memory and the requesting unit.
138
4. The control section consisting of the T&C, and write and read
address counters service the input and output sections. When
write commands are issued the T&C holds the memory mode line
low and generates a cycle initiate command (MRQ). At the
end of the write cycle the T&C updates the write address. When
read commands are issued, the T&C holds the memory mode line
high and generates a cycle initiate command (MRQ). At the end
of the read cycle the T&C updates the read address.
A test generator is provided in the receiver buffer as a checkout aid. The genera-
tor can:
1. Generate a black and white bar pattern (each of the eight bars
has a 6-bit time tag of 59) and
2. Generate a horizontal sync word at the end of the bar pattern and
3. Generate a buffer sync word following the horizontal sync word (each
of the buffer sync bits are controllable from test switches on panel
A1A14) and
4. Generate one or two lines of TV data per line read out of memory
(selection here is controllable by the test sequence repetition
switch on panel AlA14).
Note that the test generator was designed for use in the ZOP/ZOI mode only.
A2-3.6.2 Buffer Synchronization
The purpose of the Buffer synchronization operation is to assure the proper relation-
ship between the state of fill of the transmitter and receiver buffers. This can be accomplished by
controlling the overall delay through both buffers, since errors in buffer fullness relations appear
as time errors in the output data.
Buffer synchronization is established with the aid of the assumption that the trans-
mitter buffer is empty at the end of vertical blanking, a reasonable assumption since at that
time the buffer has just experienced a long period of unload operations, with no load operations.
At the end of vertical blanking, a vertical sync word is inserted at the transmitter.
Recognition of this word at the receiver causes the following events:
a. The TV Sync Generator is preset to the beginning of
vertical blanking.
139
b. The buffer read and write addresses are both set to zero
(i.e., the buffer is set to empty).
c. Buffer unload and TV reconstruction operations are
suspended until the end of a fixed time delay. For
convenience, this delay was selected as the vertical
blanking interval, and is generated by the TV Sync
Generator.
The effect of these operatiohs is to generate a fixed overall time delay. At a time
when the delay in the transmitter buffer is assumed to be zero, a delay in the receiver buffer
equal to the vertical blanking interval is generated by starting from an empty buffer and filling
it while inhibiting outputs during this time interval. At other times during the frame this delay
will be distributed between the transmitter and receiver buffers depending upon data activity,
but the overall delay will be the same, barring time tag errors.
The effective buffer size with this technique is equal to the amount of data trans-
mitted during the vertical blanking interval, and therefore varies with the transmitted information
rate. At the highest information rate this amount of information does not exceed the size of the
installed memory.
Note that this procedure also performs the TV synchronization operation.
A2-3.7 TV Data Reconstructor - A8A1A7
The TV data reconstructor obtains reduced TV data from the receiver rate buffer. This
information is in the form of a sample and the number of times the sample should be repeated
(zero order reconstruction) for both ZOI and ZOP reduction techniques. Thus, reconstructor
operation is independent of reducer mode. The received sample is presented to a D/A converter
for the required number of sample times producing a reconstructed analog video waveform.
Amplitude dither is combined with the received data sample prior to the D/A input to reduce
false contouring in the reconstructed TV picture.
Reconstruction operation is inhibited during TV blanking when TV sync is being
added to the output waveform. Normal reconstructor processing is also inhibited when the
receiver buffer becomes empty.
Reconstructor Operation
A block diagram of the TV data reconstructor is shown in Figure A2-3.7.
Reconstructor operation basically consists of outputting received nonredundant
samples to a D/A converter. The received sample is obtained from the 10-bit sample register
140
0-
O:: Ce v ~ ~~~~~~~~ y d4' '\ --
L - a- -LL 
- LL -
U Uc o:-
Of LLJ ~ ~~~~~~~~~~ LU LU I.-
Figure A2-3.7. TV Data Reconstruction Block Diagram
141
ICO.
'0
in the receiver rate buffer section. Gating controlled by a three position switch on the receiver
front panel determines how many of the 10 bits are sample information and how many are time
data. With the sample size switch in the 6-bit position, 6 of the 10 bits are loaded into the
6-bit reconstructor sample register; the 5-bit position loads 5 bits; the 4-bit position loads 4 bits.
The remaining bits in each case are loaded into the 6-bit reconstructor time (tn) down counter.
After sample and time loading is complete, the tn counter is decremented at the TV sample rate
which is selected on the front panel. During tn down counting the sample register 6-bit output
is presented to a D/A converter for conversion to a voltage level. When the'tn down count
reaches 1, The load enable flip-flop is qualified by detecting the 1 state with a NAND gate.
This detection is performed on the 5th MSB of the counter so that both 1 and 0 are detected
allowing the flip-flop to remain qualified for the counts of 1 and 0. The next sample clock
that decrements the tn counter to zero also strobes the load enable flip-flop causing its output
to change state. This allows the sample rate clock to load the sample register, load the down
counter, and begin the process in the receiver buffer that loads the next 10-bit word into the
10-bit register. If a time tag other than 1 or 0 is loaded into the tn down counter, the 1 and 0
detect gate turns off, allowing the load enable flip-flop to be cleared. No more loads are
allowed until a count of 1 has been reached. If the time tag that is loaded into the tn counter
is 1, the load enable flip-flop remains qualified and the next clock pulse that decrements the
counter to 0 begins another load cycle. In all I cases loading is completed before the next clock
pulse occurs.
Error-free transmission of data means zero time tags never occur in the received
video data. Only TV sync words and blanking fill words have zero time tags. When transmission
noise does cause errors in the received data, it is possible to obtain zero time tags in received
words that will not be recognized as "special" words. The reconstructor protects against the
reception of zero time data by detecting the zero state with a NAND gate and inhibiting any
further down counting until the zero state is removed by the next tn counter load. This causes
no change in normal operation since decrementing the counter to 0 begins a load process. If a
zero time tag is loaded, the 1 and 0 detect gate thinks it sees a 1 and the load enable flip-flop
remains qualified. The next clock pulse is not allowed to decrement the counter causing the
load flip-flop to think the counter has been decremented to zero and allowing the sample rate
clock to begin the next load process. In effect, the zero detect gate forces the counter to
treat a zero time tag like a 1 time tag.
The sample rate clock also strobes the 10-bit dither feedback shift register. Each
bit of the 1023 bit pseudo random sequence generated by this shift register is modulo 2 added to
a selected bit of the sample register. This addition takes place at the output of the 6-bit sample
register; therefore, the D/A converter receives a TV data sample plus amplitude dither. The bit
position for the modulo 2 addition is chosen by the sample size switch on the front control panel
of the receiver. Dither is not added to any bit if 6-bit samples are being processed. Five-bit
sample operation allows dither to be added to the LSB of the 6-bit register output. Dither is
added to the 5th MSB if 4-bit sample processing is taking place. The 1023-bit pseudo random
sequence is obtained from the 10-bit shift register by modulo 2 adding the output bit (10th bit) and
the 7th bit of the shift register and feeding this result to the shift register input. The zero state is
142
detected in the shift register, and this result is "OR'ed" with the feedback into bit number 1.
The zero detector provides protection against becoming locked in the zero state.
No special starting procedures are required for the TV data reconstructor. When
operation begins, the dither shift can begin in any state. The tn counter will decrement to 1
and begin loading procedures independent of its beginning state. Also the load enable flip-flop
will be set to the correct state by the first sample rate clock pulse. Some initial incorrect data
may be sent to the D/A converter, but the system will correct itself the first lime a count of
zero is reached in the tn counter.
Various external controls on reconstructor operation exist. When the receiver
buffer becomes empty, further unloading of the buffer is inhibited. The reconstructor continues
to operate on the nonredundant sample data in the two 30-bit buffers until buffer emptiness
indication disappears. In effect, the reconstructor never knows that the buffer is empty, for
its operation continues in a normal manner. Also, sample register and tn counter are inhibited
by the detection of TV sync in the 10-bit register in the receiver buffer subsystem. The Recon-
structor is restated by signals from the TV Sync Generator which occur at the end of vertical
and horizontal blanking.
A2-3.8 Statistical Decoder - 2A8A6A1 & 2
The Statistical Decoder accepts data from the Rate Buffer and Sample Rate pulses
from the Timing Generator, detects code words in the data, processes in accordance with these
code words and regenerated digital words representing the TV video. These output words are
transmitted to the Digital to Analog Converter.
A block diagram of the Decoder is shown in Figure A2-3.8. Data from the Rate
Buffer is loaded in parallel into the 10-bit P Register. The data is then serially shifted into the
Q Register. The P Register is automatically reloaded after the last data bit is shifted from it to
the Q Register. Meanwhile, a series of 0 pulses are generated by the 0 Generator, initiated by
a Sample Rate pulse from the Timing Generator. The a pulses and the data from the Q Register
are applied through the Code Patching to the Code Detect Logic. The Code Patching determines
the interpretation made by the Decoder of particular bit pattern received, and corresponds to the
code selection patching of the Statistical Encoder in the Transmitter. Detection of any code
halts the shifting of the P and Q Registers, thus aligning the data in the Q Register for the word
length being decoded. At the same time, the particular code detected is stored in the C' Regis-
ter, and subsequently transferred to the C Register. The detected code may require updating
the absolute value of the video, or adding a positive or negative delta to the previous value.
Consider first the case of updating the absolute value. Data from the Q Register, already prop-
erly word aligned, is transferred to the A' Register. This data is LSB justified by the QL Logic
so that deltas may be added in a fixed position independent of Quantization Level being proc-
essed. The current quantization level (4, 5 or 6 bits) is detected and stored in QL Logic. The
143
DATA FROM
RATE BUFFER
(PRE G00- PRE G07)
_
DECODER RESTART
FROM TV SYNC
GEN
CLOCK GEN
& CONT
(SH 7)
*NOTE - SHEET NUMBERS ARE
REFERENCE TO DWG 531024
86186.-22
DATA TO
D/A
Figure A2-3.8. Statistical Decoder
144
SAMPLE RATE
I!1
CLOCKS
LSB justified data is then stored in the A Register and subsequently transferred to the A" Register.
The output of this register forms one input to the B Register Input Selector, controlled by an out-
put from the C Register. For the case under discussion, the detected code in the C Register calls
for an update of the absolute value, so the data from the A" Register is selected for transfer to
the B Register. The data in the B Register has been LSB justified by the QL Logic, and must be
MSB justified for the Digital to Analog Converter. This operation is performed by the QL Justi-
fication Logic, controlled by QL signals from the QL Logic. 'The data is then buffered and sent
to the D/A Converter.
Consider now the case where a delta is to be added to the previous video values
stored in the B Register. In this case, the control line from the C Register to the B Register Input
Selector will be in the state selecting the ALU (Arithmetic Logic Unit), rather than the A"
Register as the B Register input. The code stored in the C Register is applied to the Delta Gen-
erator which produces the required delta in binary form, and stores it in the D Register. The
contents of the B and D Registers are algebraically added to produce the new value for storage in
the B Register.
The contents of the B and D Registers are monitored by the Video Overflow Logic,
and delta additions which would cause the B Register to overflow or underflow are prevented by
inhibiting updates of the B Register. Such overflow or underflow can occur as a result of link
errors, and causes large brightness errors on the TV screen.
Detection of either a horizontal or vertical TV sync code by the Code Detector
Logic indicates that the end of the current line (or frame) has been reached and initiates a special
sequence of events:
a. The next word, an unused 8-bit buffer word is discarded.
b. Six bits of absolute value are transferred to the B Register.
c. Two bits of Quantization Level value for the next line are decoded and
stored in the QL Logic.
d. Three data words are decoded, to fill the A', , A", C', C and D
Registers with valid data.
e. The Decoder halts until it receives the Restart signal from the TV
Sync Generator.
Following the restart, the normal processing operations described above are carried
out.
145
A2-3.9 TV Sync Generator - A8A1A10
The purpose of the 1TV Sync Generator is to generate TV blanking and synchronization
signals coherent with the reconstructed TV video from the TV Reconstructor or the Statistical
Decoder.
A block diagram of the Sync Generator is shown in Figure A2-3.9. Basic timing is
derived from a one Megahertz reference signal derived from the incoming information rate by the
Timing Generator. This signal is frequency multiplied to 9 MHz in a phase-lock multiplier to
provide a fine scale timing signal. This 9 MHz signal drives the Horizontal Counter and Decodes,
which produce horizontal blanking and synchronization signals, as well as a two times horizontal
signal. This increments the Vertical counter, which is decoded to produce vertically related
timing signals. The Blanking and Sync Logic accepts the horizontal and vertical signals and pro-
duces Composite Blanking, Composite TV sync, and restart signals to the Reconstructor and the
and the Statistical Decoder.
Synchronization of the TV timing to the input data is achieved by means of a Verti-
cal sync pulse from the Rate Buffer. As described earlier, this signal is generated by the recogni-
tion of a 30-bit synchronization word in the data. TheVertical Sync pulse sets the Vertical
Counter to a state corresponding to the start of vertical blanking.
A2-3.10 Digital-to-Analog Converter - A8A1A5 and A8A1A7
This unit converts the six-bit digital data from either the Reconstructor or the
Statistical Decoder into analog form. A block diagram is shown in Figure A2-3.10. Selector
Gates, controlled bytheZOP (I)/Stat switch route the selected data to the inputs of the D/A
Converter unit. The output of the Converter is applied to the Video Amplitude Shaper.
A2-3.11 Video Amplitude Shaper (Expander) - A8A1A6
The Receiver Video Amplitude Shaper (Drawing 528742) accepts video information
from the D/A Converter, and performs amplitude shaping complementary to that performed in
the transmitter. Also, the Shaper has to add the sync signal to the reconstructed video information.
The transfer function of the Receiver Video Amplitude Shaper is piecewise linear,
having up to 3 line segments. Each line segment has a greater slope than the previous one so that
small amplitude signals are amplified less than large amplitude signals. The transfer function is
normally complementary to that of the Transmitter Video Amplitude Shaping so that overall system
linearity is preserved. 
146
VERT SYNC FROM
RATE BUFFER
I1 MHz PHASE LOCK 9 MHz HORIZONTAL 2X HOR V
REF FROTIMING X9 FREQ COUNTER & CC
GENERATOR MULTIPLIER DECODES D
VERTICAL
DUNTER &
)ECODES I
BLANKING &
SYNC LOGIC
- COMPOSITE BLANKING
COMPOSITE SYNC
RECONSTRUCTOR START
STATISTICAL DECODER
RESTART
86185-23
Figure A2-3.9. TV Sync Generator
147
I I~
DATA
FROM STAT
VIDEO
TO SHAPER
(A8A 1A5)
(A8A1A3)
Figure A2-3. 10. Digital-to-Analog Converter
148
DATA
40
86185-24
The Video Processing Channel consists of amplifiers AR], AR2, AR3, and AR4 and
their associated circuitry. Transistor Q1, amplifier AR5 and reference diode CR5 form the neces-
sary circuit to establish a low output impedance, precision voltage source to which the break
points of the linear segments are referenced. Analog switch Si and reference diode CR5 form the
switch circuit which generates the sync signal. The sync signal is added to the video signal by
summing resistor R15. 
Amplifier ARI is used as a buffer to isolate the Compressed Video Signal from the
Shaping network. Amplifier A3-is used to sum in the sync signal and as a scaling amplifier
to scale the Butput amplitude of amplifier AR2. Amplifier AR4 is used to drive the output video
signal into a 75-ohm system.
Amplifier AR2 and its associated circuitry perform the shaping function on the video.
The two break points are determined by the resistive combination of R5, R6, R7, R8, R9, R10, R23,
and R24, where R5 and R26 set the bias current for the diodes CR1 and CR2, where R6, R8, and
R9 determine the slope of the line segments and where R24, RI0, R23, and R9 determine the
break points.
From Operational Amplifier fundamentals, the gain of an Operational Amplifier,
which determines the slope of a line segment, can be expressed as:
G =_RfR.in
From this expression, Rin must decrease in value as the video amplitude increase,
if the first segment of the piecewise linear tranfer function is to have a slope less than the second
segment. Consider the following circuit:
Rf
R1
J ~~~R2
'- -- ao -- I 
ein I3t X eout
+V1
149
If e. is 0 volts, then
in
1I 0
= 0
13
e out
= 14
d0
0 volts
For the above conditions, the diode is back biased by V1, hence, there is no diode
current flowing. As e. goes negative:
in
Rf
eout RI
Providing:
V2 > 0 volts
As e. gets more negative, a point will be reached where the drop across R3 will be equal to or
greater than V1 . At this point the diode will become forward biased and the output voltage will
be a function of R1, R2, and the diode resistance "Rd." Assume that:
13R 3 > V1
13 << Id3
then:
Id = 14
and
Rf
e - -
out RT
where
(RI1) (R2 + Rd)
T = R1 + R2 + Rd
Therefore, if RT is less than Rf, then the second segment will have a slope that is greater than the
first segment. This is the principle of operation that governs amplifier AR2 and its circuitry as it
expands the input video from the D/A Converter.
150
The 3-segment piecewise linear transfer Function is depicted by the following
ill ustration.
eb 2
ebl
4
: *t~~~~~1~
I!
go S2
I _ S
Si
Because there are four transfer functions associated with the transmitter, Four transfer
Functions will be required For the receiver. The slopes For the line segments of each are:
1. Linear S1 = S2 = S3 = I
2. Sl 1.
S2= 1
S =33
3. S1 = 1/4
51
S2= 1
S =33
4. S1 = 1/2
S2 = 1-1/4
Since the performance of the high speed operational amplifiers used is degraded if a gain of 1/10
is used, amplifier AR3 is used to scale the output of AR2 as follows:
151
Tota I = 1G2
where
Rf2
G1 = R. amplifier AR2
in2
Rf3
RG. amplifier AR302 
in3
then
Rf2 Rf3
GTotal R. R.
In2 i3
Thus, for a gain of 1/10, we could have:
1 1 1
G = 3-.76 x 2.66 10
In this way neither amplifier has to operate with a gain of 1/10. The scaling Factor for AR3 is
1/2.66. Therefore, the scaling factor for AR2 for the transfer function line segments are:
1. S = 2.66
2. S =1 3.76
S2 = 2.66
S = 8
3. S =1 1.5
S = 2.66
S3 = 8
4. S 1= 1.33
S2 = 3.99
152
The equations relating the circuit components to the slopes and break points are:
= RllS -1 R6
R 1 1
S =
RTi
Rll
3 RT2
where
(R6) (R8 + Rd)
RTi R6 + R 8 + Rd
(RT1) (R9 + Rd)
RT=RT2 + R R9 + RdTI
and
e V R8
bl 1 V (R2 7 + RT)
R9
eb2 = R10+R24
where
V1 = 4.95volts
R -(R23) (R37)
T R23+ R37
Since the expander sees the output oF the 0 to 5 volt D/A, the break points should be at:
1/2 5 2.5 volts
and
3/5 5 3volts
153
If one is to observe these break points at amplifier AR2 or AR3, then the break point voltage will
have to be scaled appropriately. For instance, if the waveform is observed at the output of AR3 for
the transfer function containing line segments of slopes:
S1 = 1/10
S2= 1
S=3 I2S 3
.3
the first break point would occur at:
eb l = (1-) 2.5 = .25 volts.
The second break point would occur at:
eb2 = .25+ AV (S2 )
when AV 3 V - 2.5V = .5 volts
Then eb2 = .25 + (.5) (1) = .75 volts
It should be understood that the above equations for the break points and slopes are approximations
and the actual desired parameters were determined or confirmed empirically.
A2-3.12 Voice Demodulator - A8A 1A3
The Voice Demodulator decodes a 20 Kbit serial data stream to reproduce an audio
signal. The decoding technique essentially duplicates the delta modulation encoding technique
used in the voice encoder. Amplitude expansion is used in the decoder to complement the ampli-
tude compression in the encoder.
The Voice Demodulator (Drawing 520745) contains a high information delta demod-
ulator, which converts a serial bit stream to an analog signal, and a voice expander, which
expands the 30 dB range of the incoming signal into the normal 60 dB audio range. The Voice
Demodulator reconstructs the original voice inputted to the Voice Encoder.
The high information delta demodulator operates similarly to the high information
delta modulator in the Voice Encoder. The Data Input is sampled and held by a D-type flip-flop
whose output is to a two stage shift register. Decoding circuitry on the shift register outputs
generates commands to a 4-bit Shift Left - ShiftRight(SLSR) register in accordance with the table
as follows:
154
(A follows B follows C)
Shift Register State SLSR Command
A /B / C Shift Left
A 'B =C Shift Left
A=B /C Hold
A B= C Shift Right
As in the Voice Encoder, the SLSR shifts ones in from the left and zeroes in from the right. Thus,
a shift right command will double the binary weight of the SLSR output and a shift left will half
it. The data stream is thus translated to this four bit (plus a sign bit) binary code identically to
the Voice Encoder. This output is then applied with proper weighting to the input of an integrator
to reproduce the analog signal. The integrator has a dc feedback path to prevent latchup due to
bias and offset currents.
The integrator output goes to the input of the voice expander (or directly out, switch
selectable). A nonlinear input resistance at the input to an op amp produces a transfer function
which is the inverse of the voice compressor transfer function, described in the Voice Encoder
detail operation. The original voice input signal is reproduced at the output of this amplifier.
A switch at the op amp output serves to switch the driving point impedance to provide equal
amplitude signals into either 50 ohms or 600 ohms.
A2-3.13 Timing Generator - A8A1A4
The receiver timing circuit shown in Figure A2-3.13 generates an information rate
clock synchronized with the Bit Synchronizer clock and a 1 to 9 MHz sample rate clock output,
which is selected by the front panel Sample Rate seledtor switch.
The receiver timing circuits accept the bit synchronizer output clock and the rate
line (i.e., Viterbi 1/3, Viterbi 1/2, or Fano) from the front panel switch. The bit sync clock is
divided by 3 if the code switch is set to 1/3, and it is divided by 2 if the code switch is set to
Viterbi 1/2 or Fano positions. The divide is accomplished by a programmable divide by two/divide
by three counter. The output of this counter is the information rate, and it is buffered and sent
out to the system. If the Group Sync input is selected from an external source, the external clock
becomes the information rate clock.
A one-megahertz signal is generated by dividing the information rate clock by the
information rate, and is used as a reference frequency to operate to phase-lock loop which gen-
erates the sample rate clock. A 4-bit adder has one set of inputs preset to a count of 10. The
other four inputs are operated with the BCD inverse of the information rate, which comes from the
front panel information rate switch. Thus, the output of this 4-bit adder is a number which is
155
v
U
do5
u U Y, eY *Z 
-Z
>- 0 -O 0 
.
^-- 00 *
u u
156
U-
N
ZZ
I-
> Z
>___
E0
m
.-0
-Y0
U
0
co
Cc
E
ULg
(g
.a_
0
CO
o1..
0)U-
._1
11-
I
equal to 10 minus the 10's complement of the information rate setting of the front panel switch.
The 4-bit synchronous up counter is operated by the information rate From the information rate down
counter circuit, and when this decade counter reaches a count of 9, its carry output is routed
bock to the load input, and the number generated by the 4-bit adder is loaded into the data inputs
of the counter. The counter thus acts as a divide by N counter, where N is the information
rate. Since it is clocked by the information rate, the output will thus be one-megahertz. When the
information rate switch is set to a one megahertz, this position is decoded and in this mode the
synchronous counter is bypassed so that the one-megahertz information rate is routed directly
to the reference input of the sarriple rate phase-lock loop. The one megahertz reference is also
routed to the TV Sync Generator for a timing reference.
The operation of the sample rate phase-lock loop in the receiver is identical to
the operation of the sample rate loop in the transmitter. For details on its operation, refer to
Paragraph A2-2. 11.
A2-3.14 Bit Comparators - A8A9A1
In order to perform tests and determine the bit error rate at the decoder inputs and
outputs, a pair of bit comparators are provided. Comparator A will be used to measure bit error
rates at the decoder inputs and at the Viterbi output. Comparator B will provide error measure-
ments at theFano output.
A block diagram of Comparator A is shown in Figure A2-3.14. This comparator
is used to measure bit error rates at the input to the decoder orat the Viterbi decoder output. The
former is accomplished by delaying the data at the output of the coder by an amount equal to
the delay that results From the transmission link and the bit synchronizer. The data can be
delayed by 1/2 bit increments up to a maximum of 7-1/2 bits. This is accomplished by selecting
either BIT RATE or BIT RATE to strobe an 8-bit shiFt register. For either 0 or 1/2-bit delay the
output of the First stage of the shift register is selected. For either 1 or 1-1/2-bits delay, the
output of the second stage of the shift register is selected and so Forth up to 7-1/2-bits delay.
At this point the data From the transmission link and the delayed data must line up
within 1/2 bit. To assure Further alignment they are each strobed through shift registers by the
complement of the clock that was used to strobe the shift register. This ensures that the two data
inputs to the comparator are aligned in time so that they can be compared accurately. The errors
out of the comparator are divided by two in a counter to provide pulses which can be reliably
counted.
In order to measure the bit error rate at the Viterbi output, the data at the input to
the coder is delayed by an amount equal to the combined delays of the coder, bit synchronizer
and the Viterbi decoder. This is accomplished by incorporating a Fixed delay prior to the pre-
viously mentioned 8-bit shift register, and a variable delay (0-28 bits in 4-bit increments) Follow-
ing the same register. The Fixed delay along with the 8-bit shift register (controlled from the Front
panel) compensates for the coder and bit synchronizer delays and the Viterbi Fixed delay. The
Following variable delay is controlled by lines from the Viterbi to match the Viterbi variable delay
with the decoding delay.
157
. .SELECTOR II CLOCKED ERROR
DELAY LOGIC CLOCK OUTPUT
THUMBWHEEL
(1/2 BI T) _j
COMPARATOR A
COMPARATOR B IN
I~~~~I
EXT REF SEL DFF
~~IN SW
CLOCK x.
I
IN /.vCLOCKED
DATA COMPARATOR
IN)
IERROR
_ 
~~O UT PUT
86165-26
Figure A2-3.14. BIT Comparators
158
The bit comparator is placed in the Viterbi mode or decoder input mode by the
"Viterbi Decoder Delay-In/Out" switch (S7) on the front panel.
Comparator B also, shown in Figure A2-3.14 is used For measuring the error rate at
the output of the Fano decoder. Since the Fano introduces a delay of several thousand bits, it
is not practical to delay the coder input signal to Form the reference. The simplify implementation
and to allow error rate measurements while transmitting TV data, the PCM channel is used for
these error rate measurements. At the transmitter (multiplexer) all l's or all,O'sare inserted in place
of the PCM input by means of a switch. At the receiver, a similar setting oF a switch is required
("1" or "0"). The information, either all l's or all 0's compared to the receiver switch to generate
the error count. An external reference can also be supplied. Note that errors are not divided by
two in this comparator, due to the lower design speed.
159
