Digital Signal Processor for Laser Doppler Anemometer Systems by Salsman, Lloyd Neal
A Din IT AL SIQN/iL PhOC :~SSOR FOH LASE:H 
DOFPLFR ANEMO)JIJ'I R SY~:l'T'EME3 
l~·., -., 
LLOYD NE!\L SALSMAN 
tr 
Bachelor of Science 
Oklahoma State Utdversity 
Stillwater, Oklahoma 
1972 
Submitted to the Faculty of the 
Graduate College of thB 
Oklahoma State University 
in partial fulfillment of 
the requirements for 
the Degree of 
YIASTEH OF SCL::NCE 
Dece,nber>, 1973 
A DIGIT.AL SIGNAL PROCESSOR POR LASER 
DOPPLER ANEMOMETER SYSTEMS 
Thesis Approved: 
FeJL~nl~V~ I 







APR 10 1974 
PREFACE 
This study was undertaken at the request of the staff 
involved with making fluid measurements at the Basic Fluid 
Dynamics Laboratory. The objective was to automate the 
gathering of velocity measurements taken with the Laser 
Doppler Anelj1ometer (LDA). Prior to the construction of · 
the signal processor, all measurements were made by visual 
scrutiny of the anemometer waveforms •. It is with this in 
mind that I acknowledge and appreciBte the time and effort 
expended by Dr. W. G. Tiederman, Dr. D. K. McLaughlin, and 
Dr. Michael Reischman for their pioneer efforts in this 
area. 
Construction costs of the processor were borne by the 
School of Mechanical and Aerospace Engineering an.a the 
School of Electrical Engineering at OSU. Facilities for 
the construction of the processor were made available to 
me at the Mechanical and A:erospace.Engineering Labs. 
I would like to·thank Tom Goins at Texas Instruments 
Supply Company for his aid in procuring hardware for me; 
William Adcox, Michael Karpuk, and Maurice Colpitts for 
their assistance in constructing the processor. Professor 
P.A. Mccollum, my adviser, who should take a large part of 
the blame for my-interest in computers, provided the coun-
sel and assistance I needed to complete the project. 
iii 
I also wish to thank my grandmother, Mrs. Herman 
Dittmer who typed this manuscript in its entirety. 
iv 
TABLE OF CONTENTS 
Chapter 
I. INTRODUCTION . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 
1. Investigation of Laser Doppler 
Signal Processing ••••••••...•...• 
1.1 The Problem of Signal 
Processing •••••••••••.•. 
2. Laser Doppler Anemometer ........... . 
2.1 Basis Laser Anemometer 
Configuration ••••••.••.••. 
2.2 Continuous Wave •••.••.••.•.• 
2.3 Individual Realization, •••. 
II. DOPPLER SIGNAL PROCESSORS FOR THE LDA ••.•••• 
1. Major Difficulties ••••.••..•.•••.•.• 
1.1 Doppler Dropout ••••••••.••• 
1.2 Frequency Variations of 
Doppler Bursts ••••••••.•• 
2. Two Methods of Doppler Signal 
Processing •••.•..•....... 
2.1 The "TRACKER" Method •.•.... 
2 • 2 The II COUNTER" Met hod •••••.• 
III. A SEQUENTIAL PHASE COMPARISON METHOD ••....•. 
1. Detecting Doppler Dropout ••••.•..... 
1.1 Sequential Phase Comparison. 
1.2 Sequential Comparison 
Under Tolerance ••••••.... 
2. Associated Measurement Equipment ••.. 
2.1 Doppler Signal Source .••... 
2.2 Sequential Phase Comparator. 
2 o3 Period Counter .•........... 
IV. IMPLEMENTING THE SEQUENTIAL PHASE COMPARISON 
1. Doppler Perr'od Count ............... . 
1.1 Period Oscillator and Counter 
Cha in ................... . 





























l ,~ c 
Chapter 
2. Effecting the Comparison under 
'rolerance .................. ~ ....... . 
2 .1 The Normalized Error 
Formula .................... . 
2.2 The Comparison Algoritum ••••.• 
2.3 Numerical Example Using the 
Comparison Algorithm ••.•..•• 






at us • • • • • . • • . • • . • • • . . . • . . . • • . • • . . • • • 1 7 
3.1 Verification of the Measure-
ment . • . . . . . . . . . . . . . . . . . . . . . . 17 
V. DESIGN OF THE SEQUENTIAL PHASE COMPARISON 18 
I. Processor Architecture • • • • • • • • • • • • . • • • 18 
1.1 Requirements of .the Comparator. 18 
1.2 Advantages of a Digital System. 19 
1.3 Function of the Comparator • • • • 19 
2. Microprocessor Controlled Computers • • . 21 
2.1 Introduction to Microprocess-
ors . . . . . . . . . . . . . . . . . . . . . . . . . 21 
2.2 Characteristics of a Micropro-
cessor ..................... . 
3. The Read Only Storage (ROS) Assembly •• 
3.1 A Control Store Management 
Technique .................. . 
3.2 Determinint the Geometry of ROS 
3.3 Monophase or Polyphase Execu-
tion ..... -... ·· ....... ·· ...... . 
3.4 Parallel vs. Serial Fetching •• 
. 3~·5 Application of Encoded Fields •• 
3.6 Branching •••••••••••.•.••.•••. 
3.7 Interruption Handling ••••••••• 
3.8 Manual Intervention •••••.•...• 
4. The Arithmetic/Logic Unit (ALU) •••.••• 











of the ALU • • • • • • • • . • . • • • . . • • 32 
4.2 The Counters and Counter 
Controls (C) •••••..•. •.••••. 33 
4.3 The Multiplexer.(MPLX) •••··••• 3344 4.4 The Register Files (RF) ••••••• 
4.5 The Arithmetic/Logic Processor 
(ALP) •• • •••• •............... 34 
4.6 The Shift Register (SR) and 
Shift Control • • • • • • • • • • • • • • • 38 
4.7 Status and Control Triggers 
(.ST.A.T) • • • • • • . • • • • • • • • • • • • • • • 38 
S. Display Control and Interface Control • 39 1 
5 .1 The Display Control ( OC) • • • . . . 39r 
5.2 The Interface Control (IC) •••• 39 
. 6. Programming Characteristics • • • • • • • • • • . uo0. 6.1 ROS Instruction Word Format •.• 4 
6.2 Multiplexer Control Field (MFLX) 40 
6.3 Register File Control Field (RF) 40 
vi 
Chapter . I 
6\14. Arithmetic/Logic Processor 
Control Field (ALP) ••.•..... 




Field ( crrL ) ; ••••••.••.•...•. 
The Shift Control Field (SR) •• 
The Status and Control Trigger 
Field (STAT) .•.••.••.......• 
The ROS Control Field (ROS) ••• 
VI. CONSTRUCTION OF' THE SEQUENTIAL COMPARATOR •• 
L. Selection of a Logic: Family,v ••••.••.. 
1.1 Speed, ....................... . 
1.2 Noise ....................... . 
1.3 Commercially Available Functions 
1.L Transistor-Transistor Logic 
(TTL or TZL) •••...•.••.•••.. 
2. Physical Layout •.••...........•...... 
2.1 General Requirements .••.•••.•• 
2 .2 The Gate ..................... . 
2 .3 The Po'wer Supply Bays (Bay 1) 
and Bay 5 ) ....... · · · · · · · · · · · 
2.~ R08 Storage Bays (Bay 2 and 
. Bay 3) •••••••••..•••••..•..• 
2.5 The Processor Bay (Bay 4) ..... 
3. Power Supply Sequencing and Control •• 
3 .1 Power Sequencing .•...••..••••. 
3,2 Emergency Power Off •••••••..•. 
4. Logic Bay Assembly •.......•..•..•... 
4.1 Wiring ...................... ,II;. 
4.2 BAY W:ire Listing ............ .. 
5. Logic Card Assembly ••••...•......•..• 
5.1 Preparation of Circuit Boards . 
5.2 Logic Card Wire Listing •.•.••. 




























VII. THE MICROPROGRAM •• , .........•••••....••• '. . . 56 
1. Design of the Program ••••••..•...••. 
2.1 Preliminary Program Design 
Steps ...................... . 
2. Alteration of the Microprogram .••••• 
2.1 Modification of the Diode 
Matrix ..................... . 
2o2 The Programmable ROM ••.•.•..•. 
VI II • OPERA TI ON AND TEST ING •••• • •••••••• • · · · · · .•• 
1. Operation of the Engineering Console 
Cori.trols ......................... . 
1.1 General Control Functions •.... 
1.2 How to Start the Microprocessor 
~.3 How to Change the Tolerance 












a.ti Malfunction Dete,~tion, ••...... 
2. Test Apparatus and Procedure •.••..... 




Trains . . . . . . . . . . . . . . . . . . . . . . 6:2 
2 .2 Connection of Equipment • • • • • • • 62 
IX. COJIJ;CLUSION • • • • • • • • • • • • • • . . • • . • . • • . . • . . • • • • . . 61-1 
1. Summary ••.•.••...•.................. 
1.1 The Laser Anemometer Date ;,.:~ 
Processor Problem •...•..• ~ •. 
1.2 Possible Extensions .•...•.... 




LIST OF FIGURES 
Figure 
1. Do'ppler Signals with Dropout •••••••••••••.••••••• 
2. LOA Data Acquisition System •••••••.•••••••••.••• 






Block Diagram of a Computer 
ROS Instruction Word Format 
. . . . . . . . . . . . . . . . . . . . . . 
. . . . . . . . . . . . . . . . . . . . . . 
ROS Block Diagram ••••••••••••••••••..••••••••••• 
ALU Block Diagram ••••••••••••••••••••••••••••••• 
ALU Control Block· Diagram •••.•••.•••••••••••••••• 
9. Gate Layout ••••..•.•..•.................•........ 















1. Investigation of Laser Doppler 
Anemometer Signal Processing 
1.1 The Problem of Signal Processing 
The Laser Doppler Anemometer system, which will be 
described, produces a burst of pulses. These pulses in-
dicate.the velocity of particles in the fluid. Unfortunate-
ly, a simple examination of these pulses is not possible. 
A variety of factors contrive to suppress or alter the 
pulses. This alteration of the pulse train renders veloc-
ity measurement difficult. Since the acquisition rate is 
usually high, rejection of altered pul.ses would help correct 
the measurement problem. A method for detecting and reject-
ing altered pulse trains was the object of this investigat-
iono Using this method, a device for processing these 
pulse trains was designed and puilt. 
The first part of this work involves the method for 
s:lgnal processing. The last part describes the design and 
construction of the signal processor. 
1 
2 
2. La~~r Doppler Anemometer 
2.1 Basic Laser Anemometer Confi ·guration 
A laser doppler anemometer (LDA) is a device which 
measures particle velocities in a fluid using scattered 
laser light (see Asher (1)). The particle velocities, 
that would be measured using the LDA, may be used to meas-
ure some characteristics of the host fluid flow. Several 
advantages may be realized using the LDA over conventional 
fluid velocity measurement apparatus. As with every meas-
urement scheme some complications arise. One solution to 
a complication of the LDA is the topic of this thesis. 
2.2 Continuous Wave 
One configuration of LDA uses a high concentration of 
particles such that light is almost continuously scattered. 
This light is processed by the LDA and, as one might e.xpec1;. 
a continuous doppler signal is the result. This condition 
is necessary for the operation of the "TRACKER" doppler 
signal processor. 
2.3 Individual Realization 
Individual realization LDA use a low particle concen-
tration such that only one particle rnay be scattering llg,ht 
at any particular time. The configuration ia the same as 
the continuous wave system except for the particle density. 
CHAPTER II 
DOPPLER SIGNAL PROCESSORS FOR THE LDA 
1. Major Difficulties 
1.1 Doppler Dropout 
One of the difficulties of both the individual realiz-
ation and the.continuous system is "doppler dropout". This 
term applies to a condition when a pulse is interfered with 
and one or more of the cycles has been cancelled out. (see 
Figure 1). Although this definition lends itself best to 
individual realization it can also be applied to continuous 
wave (continuous wave systems also include the loss of all 
signal as a doppler dropout). 
1 o2 -Frequ13ncy Variations of Doppler 
Bursts 
Turbulent fluid flows are commonly measured using the 
LDA and, since wide fluctuations in fluid velocity are 
expected, one might also expect the doppler frequency to 
vary also. This frequency variation is another difficulty 
in processing the LDA signal. Continuous wave LDA process-
ers must be able to follow these variations with high 
acquisition speed and a minimum frequency overshoot. 
3-
2. Two Methods of Doppler Signal 
Processing 
,?:,,J,c T.he !!TRACKER" Method 
This method lends itself well to continuous wave LDA 
since it requires a continuous doppler signal (see Smid 
(10)). Two variations in the hardware exist, one uses a 
II frequency locked loop" the other, a "phase locked loop". 
The frequency locked loop has the advantage of being able 
to use heterodyning to lower the doppler signal and use 
this frequency directly in the loop. The phase locked 
loop requires additional hardware but uses much the same 
heterodyne technique. 
4 
The limiting factor of both systems seems to be their 
ability to track turbulent fluid.flows. At least one in-
vestigation is being conducted to measure this character-
istic. 
This method is an application of analog electronics 
in a system that has found various application. This 
application seems to fall short because the reference os-
cillator in the loop cannot "sJ_ew:!. or change frequency 
fast enough to acquire and hold a turbulent flow's doppler 
signal. A loss of signal proves catastrophic to this 
scheme. 
2 .2 The II COUNTER" Method 
This method lends itself well to individual realizat-
ion LDA. Several different schemes have been used here 
5 
-l:1 ti. ti l~ -cs l,., ·l:.,7 -lv -1:., 
1 I I I 
l 
I I I I I 
"'- O<opp-e.& 'Pv..\cs.e 
1'(;000" 
'''BPc-i:>" I .1 
Figure 1. Doppler Signals with Dropout 
but they all function similarly. A count of some reference 
oscillator is started when the leading edge of the doppler 
signal is detected (see Asher(l)). This count is carried 
on for a number of different cycle times (i.e., one counter 
may count 5 cycles, another 3), The various counters are 
then compared to determine if any cycles were lost by any 
counter. At least two methods of effecting this compariscn 
are documented (ie'e Asher (1)). If a mi.smatch occurs, then 
the period measurement is discarded. 
This is the category of processors that has been used 
as the basis for the proposed doppler signal processor. 
CHAPTER III 
A SEQUENTIAL .PHASE COMPARISON METHOD 
lo Detecting Doppler Dropout 
1.1 Sequential Phase Comparison 
If the doppler signal was continuously monitored and 
a period count made for each pulse as it arrives, a method 
for the co~parison of two previous pe~iods might be used to 
lo-0ate a doppler dropouto As each low to high transition 
of the doppler signal occurs, a count of the period would 
be completed and a new ~eriod count startedo As the new 
period count is taken, the old period count would be saved 
and compared to the period count made just before. If a 
match occurs, then the new count will replace the oldest 
period cou~t and a comparison will be made with "the old 
count. If this process is repeated continuously then any 
missing cycle will be detected shortly after the last per-
iod is accumulated (ioeo, when the next pulse arrives)o 
Three good pulses (or two cycles) are required to establish 
a "good" pulse trainc The absence of pulses will be a 
special condition which is treated as a "bad" pulse traino 
This sliding comparison allows the use of smaller 
capacity period counters and a coarser period or reference 
8 
oscillator. When a dropout occurs, the difference in period 
counts should be large (at leas·b 50%), and easily disting-
ishable. 
1.2 Sequential Comparison Under 
Tolerance 
Occasionally a pulse may be distorted in phase and 
appear outside the expected area. That is, the pulse is 
present but occurs earlier or later than previous pulses 
indicate. To reduc6 this problem a comparison can be made 
using a fixed tolerance ~alue. The tolerance value is ap-
plied during the comparison and allows the period to be 
above or below the expected value by a fixed percent. Any 
period count not within the bounds would cause the measure-
ment to be discarded. The actual deviation measured this 
way might be used to indicate particle akewing within the 
LDA probe. 
2. Associated Measurement Equipment 
2.1 Do~pler Signal Source 
This is the output of the LDA system as shown :ln Fig-
ure (3). Before the comparator can analyze this signal it 
must be processed by a Schmitt trigger. After the doppler 
has been converted in a pulse train, it is ready to be 
scrutin5.zec1 by the comparator. 
2.2 Sequential Phase Comparator 
The comparator gates the doppler signal to the period 
9 
counter. If the comparator finds a doppler dropout, a high 
frequency burst is used to dump the counter and the counter 
is then ready to receive a new pulse train from the compar-
ator. 
2.3 Period Counter 
This counter is external to the comparator. The 
counter outputs the period or average period of the doppler 
burst. This instrument may be more precise than the period 
counters used for the comparison. Output from this counter 
will be recorded as the doppler period· from which the 
velocities will be calculated. 
I Pl\l\T 
I 1 








_ ........ GEfJ. 
I 
Figure 2. LDA Data Acquisition System 
10 
11 
Figure 3. Doppler Burst and Sen.mitt Trigger 
CHAPTER IV 
IMPLEMENTING THE SEQUENTIAL PHASE 
COMPARISON 
1. Doppler Period Count 
lol Period Oscillator and Counter Chain 
The Doppler period count is made by one of two binary 
counter chains. These counters have a comm.on frequency 
standard; which is used as the "clock". This clock, refer-
enced as the 11 period oscillator'' (PO), is an external input 
that may be adjusted to provide optimum resolution for a 
given frequency range. The period oscillator controls the 
low frequency cutoff point and aff~cts the resolution at 
high frequency. 
As each pulse arrives, the current counter is stopped, 
the alternate counter is cleared, and the period oscillator 
is supplied to the alternate counter; the alternate counter 
is now designated the current counter. This process is re-
peated for each pulse. 
1 o2 .. · Counter Overflow and Notification 
Section 
If a period count exceeds the counter capacity, an 
l~ 
lJ 
error condition exists which must be reported to the com-
parator. The first overflow condition will notify the 
comparator of the error; all consecutive overflows will be 
ignored. As each period count is made, the processor is 
notified of the need for a comparison. After each compar-
ison, the processor becomes dormant. 
2. Effecting the Comparison TJnder 
...... Tolerance 
2.1 The Normalized Error Formula 
To perform the comparison under tolerance, it is con-
venient to use the normalized error formula defined: 
A-B _ t -r - A )B and A> 0 
This formula is the basis for the comparison algorithm 
used by the processor. 
2 .. 2 The Comparison Algorithm. 
The comparison algorithm is the procedure which is 
routinely followed by the processor as it examines the 
{l) 
period counts. The normalized error formula has been re-
arranged to be more amenable to hardware implementation. 
Four cases are possible and must be dealt with by the 
processor: 
CASE, I CA or CB overflow 
Action: Comparison ALWAYS FAILS, 
CASE II CA= CB 
Action: Comparison ALWAYS PASSES, 
CASE III CA) CB O<t~ 1 
substituting in (2) 
CA-CB< t O<t~ 1 
CA 
rearranging (2): 
CA -(1/t) (CA-CB))O 
CASE IV CA <CB 
or 
s~bstituting in (1): 
CB CB CA< t O < t ~ 1 
Rearranging (4) 
CB - ( 1/t) ( CB - CA)> 0 








CA = positive integer period counter va 1 ve ("A" counter{' 
,-CB ·=c-posi tive integer period counter valve (" B" counter) 
t = fractional normalized error 
Case I detects the overflow error condition and always fails 
the pulse train. Case II removes the t=O condition or zen:, 
error since it would require a "capacity shift" to be pre-
sented if it was allowed to enter case III or IV. Case III 
illustrates the manipulation of the normalized error form-
ula to arrive at a comparison condition formula (3). This 
arrangement, (3), may be thought of as weighting the numer-
ator and comparing it directly with the denominator. Case 
IV illustrates the opposite of Case III. Relation (6) is 
presented to id~ntify a common term: 
! ( CA - CB) (?) 
which is use~ to advantage by ths processor. 
2 .J Numer_ica1 Example Using the 
Com~ar:ison Algorithm ' 
The signifigance of the comparison method can be 
demonstrated by an example comparison 
Suppose that "A" counter contained the period count, 
five, and that the "B" counter contained the period count, 
three. 
Since CA is greater than CB, case III used: 
substi tutlng in (2): 
5 - 3 = 2 s-·- ~ 
16 
It is required to determine if CA and CB are within 50% of 
each other. The value of "t" then is .5. 
substituting in (3): 
5 - ( 1/ . 5 ) ( 5 - 3 ) > o 
or 
5 - 4>0 
Since one is greater than zero, the value of CA and CB 
satisfy the comparison condition and meet the tolerance 
bound of 50% (i.e., 4.01L <:: 50%). However, had the toler-
ance value been 25%, then: 
substituting in (3): 
5- ( 1/. 2 5) ( 5 - 3 ) > o 
or 
5-8 >O 
which is false and does not satisfy the comparison condit-
ion. This result implies that CA and CB are not within 
25% of each other as, indeed, they are not (i.e." 25%<40%)o 
17 
3. Control of the Measurement Apparatus 
3.1 Verification of the Meaurement 
An external period averaging counter can be used to 
record the pulse period by averaging several pulse periods. 
Once a measurement has been initiated, it must be verified 
for the entire averaging cycle. This is, all periods 
counted by phe period counter must be verified by the pro-
cessor before it can be recorded as a representative meas-
urement. 
The verification process consists of the requirements 
for the pulses applied to the period averaging counter. The 
first requirement is that no pulses are supplied to the 
counter until valid periods are detected; that is, the "GO" 
signal is coincident with the Doppler pulses. The second 
requirement is that all periods being averaged must be 
averaging cycle, the measurement must be discarded. 
Some observations may be in order at this point, if it 
was not necessary to allow the averaging counter to accumm-
late an invalid count and if the counter could be rapidly 
reset, the maximum data acquisition rate could be improved. 
CHAPTER V 
DESIGN OF THE SEQUENTIAL 
PHASE COMPARATOR 
I. Processor Architecture 
1.1 Requirements of the C_ompar-
ator 
In the previous chapter, a method for performing a 
comparison under tolerance was outlined. It is now requir-· 
ed to design a device whlch will perform this comparison. 
The convenience of handling the period measurements digit-
ally is probably the best reason for choosing a digital 
framework for the design. Analog techniques could be used 
but they would require additional conversions which might 
be quite lengthly and not very accurate. Expected fluctu-
ations in frequency (velocity) would make scaling difficult 
for an analog system. 
The comparator must be able to react rapidly and 
accurately over a wide range of frequencies and should not 
require a long time to do its work. Since the period 
counts are maintained digitally, a direct utilization of 
these values would be preferred. The measurement instru-
ments and the data recording equipment are all digitally 
controlled. Different measurement situations may require 
18 
19 
different comparison criteria and the comparator should be 
flexible enough to accept minor changes. 
1.2 Advantages of a Digital System 
The digital framework has several convenient features 
which tend to make an analog system undesirable. Standard 
digital components are now available in the speed range re-
quired to cover the specified frequency range. The digital· 
comparison time is independent of the period values being 
examined {i.e., the comparison time is constant). An ana-
log comparison might take quite some time depending upon 
conversion speeds and settling time). The digital system 
could operate on the numerical period counts directly with-
out conversion; the analog system must convert. Storage of 
the period count values might also prove difficult with 
analog storage devices. 
Of course, particular care has been exercised to pro-
duce a comparison method which is particularly amenable to 
digital implementation. An analog approach has not been 
excluded from consideration; however, a digital solution 
seems a more reasonable approach. 
lo3 Functions of the Comparator 
The comparator must respond to two significant inputs. 
It must perform a comparison operation for each pulse re-
ceived and, for each overflow condition, must clear previous,., 
period counter values (automatically signaling a "bad" 
20 
measurement). These inputs are presented to the comparator 
by a two level interrupt system. 
The highest level of interruption is used for a hard-
ware or firmware malfunction. Hardware is used to design-
ate a circuitry malfunction of the host processor while 
1 
firmware is used to designate a program malfunction (reasons 
for this nomenclature will be stated later). This inter-
rupt is permanent in nature and causes further processing 
to cease, pending some form of manual intervention. 
The second level of interruption is used to request a 
comparison operation {or an overflow condition). This in-
terrupt should only occur while the processor is dormanto 
If an interrupt occurs while the processor is active, a 
level one interrupt may be signaled (this feature is opt-
:tonal). rrhis cond:i.tion is termed an "overrun". An over-
run implies that data pulses were arriving at a rate 
greater than the processor's comparison rate. 
The second level interrupt may also signal the over-
flow condition. A flag must be tested to determine if an 
overflow has occurred. If so, special processing can be 
performed. 
The result of the comparison condenses to the setting 
of a flag to indicate the current condition of the pulse 
periods. If the previous compare was good a "Gorr flag is 
1 
Pirmware · rGfGr's to the functions provided by the micro-
program, (i.e., control signals generated by the microcodei 
21 
displayed; if the previous compare was bad an nABORT" flag 
is displayed. 
2. Microprocessor Controlled Computers 
2.1 Introduction to Microprocessors 
The concept of a microprocessor was first introduced 
by M. V. Wilkes. Several variations of his idea have been 
made and applied to many modern pieces of computing equip-
ment. Probably the most notable use has been in "compat-
ible architecture" computer families, (e g., the IBM System 
360 series). The flexibility, the economy, and the service-
ability of a microprocessor usually outweigh its disadvant-
ages. Speed is the primary sacrifice when using a micro-
processor. 
A simple microprocessor might be thought of as the 
control and data manipulating unit of a computer. Using 
Figure 4 as a guide, a computer may be considered as a 
collection of various u~its. The input is used to acquire 
information to be processed or stored. The storage unit is 
used to retain information that has been or is to be pro-
cessed. The output unit is used to disseminate information 
that has been processed. The arithmetic and logic unit 
(ALU) is used to perform data manipulation. The control 
unit is used to coordinate the functions of all other units 
in a logical manner to accomplish the current task. The 
bus is used to distribute information among all the units. 
-22 













Figure 4.. Block Diagram of A Computer 
23 
The indicated area is the microprocessor when the con-
trol and ALU can be separated and the control signals can be 
said to be generated by a "stored program". The "stored 
program" concept is probably the most important feature of 
modern computers. This "stored program" or microprogram can 
be used to tailor the functioning of its associate units. 
Alteration of the microprogram can cause a single processor 
to be adaptable to many different applications. An example 
of this flexibility is emulation of computer systems. Emulau-
ion of a computer system by microprogramming can be effected 
by causing the host computer to respond to the emulated com-
puter's instruction set. The necessary changes to the host 
computer might require only a change in the microprogram. 
2.2 Characteristics of a Microprocessor 
The function of the control unit is the generation of 
control signals. All units respond to these control signals 
including the control unit. The content of the microin-
struction word is dependent upon the hardware that is to be 
controlled. Often separate fields are assigned specific 
functions. All register controls may be from one field; all 
bus controls from another. Some microprocessors execute 
microinstructions sequentially and accomplish decisions by 
skipping instructions. Another technique includes the base 
address of the next instruction in a field within the micro-
instruction. The latter technique allows multiple altern-
n..ttves at a cost of only one instruction. Accessing the 
24 
and "patching" or inserting instructions in the execution 
sequence is relatively easy. 
As the microprogram is executed, control s;tgnals are 
distributed to the units of the computer. Control signals 
are also transmitted to the control unit by the other units 
which may be used to alter the execution of the micropro-
gramo These signals may be used to effect a "branch" with-
in the microprogram or alter some function ordered by the 
microprogram. 
If access is allowed to the microprogram, then modifi-
cation of the computer's architecture would be relatively 
simple. 
3. The Read Only Storage (ROS) Assembly 
3.1 A Control Store Management 
Technique 
The microprogram must be stored in some medium. Some 
media are field modifiable, others are not. The problem of 
maintaining a continuous control signal (used for functions 
spanning more than one instruction) is usually resolved by 
storing the instruction word while the next instruction is 
being fetched. As with most conventional memory systems, an 
address decoder is used to select a single instruction word 
from the memory. The memory organization for this particu-
lar system is two dimensional. As a word is selected by an 
address decoder, the bits which are stored in memory are 
transferred to the bit lines. All bit lines are "OR 1 ed" 
and are furnished as input to the bit buffer inverters. 
This arrangement implies that only one word at a time is 
selected. The bit buffer inverters are connected to bit 
25 
latches. At the end of each fetch cycle, a sample pulse 
is applied to the bit latches, changing the output of the 
latches to reflect the contents of the new word. 
This method allows continuous signals to be generated 
by including a bit in each word corresponding to the reap,lir-,, 
ed signal. If each word contains the sp,ecified bit, a con-
tinuous signal will be produced. The bit latches furnish 
the control signals. 
The addresses are generated by an address field con-
bined with an address modifier or from manual entry switch-
es. The basic components of the control store section are 
the bit latches (RL), the word drivers (RD), the diode mat-
rix store (RM), and the sequencer (RS). This section of 
the microprocessor is independent of the others. This was 
planned so that different memory media could be used later. 
As soon as the microprogram was proven, a read only memory 
(ROM) could be cut to replace this temporary read only 
storage (ROS) unit. The ROM would contain the same bit 
structures ( microlin s tru ct ioris) that were represented by 
diodes in the ROS unit. ROM bits are programmed by burn-
ing out fused links, transistors, or diodes. Once these 
adjustments have been made, it is not possible to alter 
the stored bitso 
26 
Since easy modification of the microprogram is requir-
ed, a diode matrix seemed the best storage media. A diode 
matrix of conveni~nt size was constructed for the micropro-
cessoro The contents of the memory is changed bJ inserting 
or removing diodes along the word line. The most signifig-
ant loss with this arrangement is speed. The physical size 
and the pulse response of the diode matrix cause an access 
time of less than 200 microseconds (measured) to be diffi-
cult (using a particular board material and diode). This 
loss was negligible when compared to the difficulties of 
other memory types. 
3o2 Determining the Geometry of ROS 
The "Geometry" of ROS refers to the number of control 
signals versus the number of instructions. The optimum 
arrangement would be to find the minimum area of a rectangle 
whose sides were proportional to the number of instructions 
and the number of control signals. Restrictions on the 
size of each parameter must also be considered. As the 
number of instructions increase, the microprogram execution 
time increases. As the number of control signals increase, 
the base cycle time increases as does the ALU 1 s complexity 
(ioeo, each instruction takes longer to completely execute). 
The optimum arrangement depeqds on the maximum allowable 
program execution time and the number of control signals 
required. 
The geometry of the phase comparator ROS was fixed by 
27 
the available hardware. This required that the micropro~ 
gram be fitted into a memory 30 x 36 {i.e., 30 instructions 
of 36 control signals each). The control lines were select-· 
ed and assigned along with bits for parity error detection 
from the 36 bits available. The microprogram was written 
in such a manner as to incorporate as many common logic 
paths as possible to cons~rve space. 
The resulting ROS unit has a generous number of con-
trol signals available. This feature helps reduce the size 
of the microprogram (i.e., the original comparison micro-
program's longest path was 13 instructions with a total 
storage requirement of 24 instructions). 
3.3 Monophase or Polyphase Execution 
Monophase execution (or vertical microprogramming) re-
fers to a single simulta:neous setting of all control 
signals as each microinstruction is fetched and executed. 
Polyphaae execution (or horizontal microprogramming) :refers 
to sequential execution of a single microinstruction over 
a definite time span. Execution of microinstructions in 
polyphase mode may be combinationally sychronized or syn-
chronouso 
Both modes have advantages but the implementation of 
the comparator probably does not require the complexity 
introduced by the polyphase mode. Normally the number of 
instructions required by the strict application of the 
monophase mode would be prohibitive; however, by introduc:ing 
delays at several critical points within the ALU, the 
monophase mode works well and is simply constructed. 
3.4 Parallel vs. Serial Fetching 
28 
The method used to determine the next ROS address to 
be accessed can be important. If it is possible to 11 pre-
FETCH" the next microinstruction before it is needed, then 
considerable "overhead" time can be overlapped with the 
microinstruction execution time. 
Parallel fetch implies that the next microinstruction 
address can be predicted (to some extent); a fetch is 
ordered for the particular address while the current micro-
instruction is being executed. If the predicted address is 
incorrect (as in the case of a "branch"), then additional 
time must be allowed to fetch the count instruction. 
Serial fetch implies that no "pre-FETCH" occurs and a 
"FETCH" cycle is required after each microinstruction is 
executed. Obviously, this is a simple minded approach and 
is wasteful of microprogram execution time. 
The fetch technique used by the comparator micropro-
cessor is a combination of both parallel and serial fetch-
ing. This technique was a parallel fetch during an early 
microinstruction fetch cycle. The microinstruction execu-
tion time is allowed to extend into this fetch time. If 
the microinstruction being executed is a branch, then the 
address modification (see "Branching11 ) takes place early in 
the executive sequence and the correct microinstruction is 
29 
fetched and executed. The longest computation time sets 
the instruction cycle time which includes the fetch cycle. 
An import·ant feature to note is the ROS base address for 
the next instruction to be executed is included, as a fieJd/ 
in each microinstruction word (ROSA). 
3o5 Application of Encoded Fields 
Most of the bits in a microinstruction specify a 
single control signal. A large number of signals, there-
fore, requires a large number of bits in the microinstruct-
ion word. Some signals may be mutually exclusive or 
logically exclusive. For example, if seven different 
signals were to be individually tested, a bit would be re-
quired for each signal using direct coding; but using an 
encoded field only three bits would be required. 
An extension of this philosophy could be carried into 
11 field modification"; that is, a control bit could change 
the interpretation of a specific field. This technique is 
used by the arithmetic/logic processor (ALP) and mode (M) 
fieldso 
Most fields in the microinstruction format are encod-
ed o This encoding scheme was specified by the charac'ter-
istics of the controlled logic within the ALU. The status 
and control trigger field (STAT) has 16 possible functions 
implemented with 4 bits. 
Encoded fields must be decoded and the decoding oper-

























REGISTER FILE CONTROL 
ARITHMETIC/LOGIC CONTROL 
CONTROL STATUS 
SHIFT REGISTER CONTROL 
STATUS AND CONTROL TRIGGERS 
ROS ADDRESS 
Figur·e 5. ROS Instruction Word Format 
31 
inst;ruction word. Wlth the physical limitation imposed by 
the 30 x 36 ROS, this tradeoff see~s justified. 
3.6 Branching 
Each microinstruction has a fie~d containing the ROS 
base address of the pext microinstruction to be executed. 
This field allows random access to the ROS unit and makes 
insertion of mic~oinstructions ("patching") easy. One 
reason for using the diode matrix was the ease of modifi-
cation and repair. 
The ROS base address field is also used to implement 
the ''branch" function. This allows the execution sequence 
to be altered by a decision arrived at by the microprogram. 
To branch to another ROS instruction, an address must be 
placed in the ROS base address field. A condition which 
sets the address modifier (AM) flag must be tested. If 
the condition is present, then the next odd ROS address 
is fetched and executed. If the condition is absent, then 
the even ROS address is used. If an odd ROS base address 
i,s the condition testing instruction, a branch to this 
address is assumed. 
3.7 Interruption Handling 
Interruptions are handled by the ROS sequencer (RS). 
First level interruptions are assobiated with processor 
errors and require manual intervention to reset. These 
errors include data overrun, ROS parity, and a miscellan-
32 
eous control error. Second level interruptions are expect-
ed while the microprocessor is dormant. These interruptiais 
include the counter service request (a comparison or spill 
check is required) and the shift complete signal. Both 
conditions are the result of previous microinstruction 
execution and cause no errors. 
The second level interrupts cause the "run ring latch" 
to be closed and execqtion to proceed until~· microprogram 
request is received for asynchronous service or a first 
level interrupt occurs. 
3 08 Maniial Intervention 
Manual control of the "run ring latch", the source of 
the ROS address, the ROS address, the ROS oscillator (Roscoi 
and the tolerance value factor is allowed. The first four 
items are interpreted by the ROS sequencer (RS). They 
allow, respectively, the ability to immediately halt micro-
program execution, to specify that the ROS address in the 
ROS address keys is to be used, the ROS address, the fetch/ 
work cycle clock, and the multiplication factor for the ALU 
(interpreted by ALU input control (AI)i No other communic-
ation by the operator with the microprocessor is allowedo 
Lt o The Ari throe tic/Logic Unit (ALU) 
4ol Function and Characteristics of the ALU 
The ALU performs the manipulation of data under con-
trol of the microprogram. The ALU communicates with the 
33 
ROS sequencer (RS) to perform branching and other functions. 
All data paths and processors and under direct microinstruc-
tion boundaries; this is a feature of the ROS control store 
just described. The ALU was assembled as four 4-bit pro-
cessors logically connected as a single 16-bit processor. 
All four processors (AL) are interchangeable. 
Of the thirty-six control lines all but nine are used 
to control the ALU. Most of these control lines are encod-
ed. Decoding is provided on each card to minimize card 
interconnections. Two "bookend" cards process signals en-
taring and leaving the processor: the ALU input control 
(AI) and the ALU output control (AO). The four remaining 
cards are the ALU processors (AL). Each AL card contains: 
two 4-bit counters, two 8 to 4-bit multiplexers, two 4x4-
bit register files, a 4-bit ALU processor, and a 4-bit shift 
register (see Figures {6,7,8)). 
4o2 The Counters and Counter 
Con~rol '( C) , 
Two 16-bit counters are supplied to accumulate the 
period count. These counters are alternately assigned as 
new data pulses arrive. The currently assigned counter is 
indicated by a flag (CC). The CC flag is used with the 
!TAT function, LOAD, to store the idle counter in the ap-
propriate register file (RF). If either counter overflows, 
a flag (SPILL) is set. This flag may be saved and inter-
rogated by the microprogram. Once an overflow is signaled, 
consecutive overflows are ignored. The reference frequency, 
34 
. 
PO, applied to the counters is an external signal input. 
4.3 The Multiplexer (MPLX) 
The multiplexers (MPLX) are used to det~rmine the data 
source for the register files (RF). Two sources are possible! 
the counter (C) or the shift register (SR). Two 32 to 16 
bit multiplexers.are· supplied, one for each side of the ALP. 
These multiplexers are controlled by tw.o common control 
lines. These lines allow selection of the data source and 
disabling the entire multiplexer. 
4.4 The Register Files (RFJ 
The register files (RF) are used for local data stor-
age. The counter values or shift register output may be 
stored here. The register files output only to the ALP. 
Two 4xl6-bit register files are provided, one for each side 
of the ALP. Twelve control lines are required to control 
the regis~er files. Each side of the register file requir-
es two READ ADDRESS bits, two WRITE ADDRESS bits, one READ 
ENABLE, and one WRITE ENABLE. Simultaneous access is allCM-
ed to the register file ports. The STAT function, LOAD, 
modifies the WRITE ENABLE signal to the appropiate side of 
the register file to store the idle counter. 
4o5 The Arithmetic/Logic Processor (ALP) 
The ALP is used to process data. Sixteen arithmetic 
operations and sixteen logical operations are possible. Two 




' ......... <( 
~ \- V1 'V er ~ f 0 i <[ (l.. 11- CY _I f. 0- ~ 0::: (/) <( lJ) (Y -- <( 
' . ' I ' ' 
I I I 



















><. 0::: () 
ij LU I ~i U) ~ G 0 ·;,, 0 (Y ct ,. •, Ci.. Cl LL 
u 
&b -
Figure 6. ROS Block Diagram 
36 
~ 
0 p:) 0 
a: r 11 ot 


























































register file. One sixteen bit word is applied by the ALP 
to the shift register. "ALUOUT" and "A = B" outputs are 
available and their status may be stored by the micropro-
gram (SAVE). Six control signals are required by the ALP: 
a four bit function code, a one bit modifier, and a CARRYIN 
bit. The function field depends upon the one bit modifier 
(MODE). This modifier selects arithmetic or logical funct-
ions. "A = B" is a special output which may be used for 
exact comparison. 
4,6 The Shift Register (SR) and Shift 
··-' -Control·--
The SR is used to accomplish the left shift. The SR 
receives and stores the sixteen bit word from the ALP out-
puts. The output word of the SR may be routed to the RF 
for storage via the MPLX •. The shift out bit of the SR may 
be monitored, under microprogram control, for both a one or 
7.oro shift out. Either condition may be interrogated by the 
microprogram. Two control bits and one STAT function are 
required by the SR. 
The number of left shifts is determined by the binary 
number stored in the tolerance factor keys (TOLSWT). The 
shift occurs by command of the mlcroprogram. The micropro-
gram execution is suspended until the shift is complete. 
~nterrogation of the shiftout flags may be done at this tirne. 
4.7 Status and Control Triggers (STAT) 
The STAT box consists of a 4-bit decoder which 
39 
generates miscellaneous control functions. Functions per-
formed by these control signals are: no operation, stopping 
ROS instruction execution, branch condition testing, status 
monitoring, and address modification generation. One four 
bit field is required to generate the sixteen control 
functions. The status preservation bit ts used by this 
unit also. 
5. Display Control and Interface 
Control System 
5.1 The Display Control {DC) 
The DC buffers the output lines that are to be display-
ed· at the engineering console. These output lines include 
the ROS address register (ROSAR), the verify latch (ABORT), 
and the validity latch (PGTV). A lamp test function is 
available as a wire jumper on the card. 
5.2 The Interface Control (IC) 
The IC card is used to verify the current reading on the 
external period averaging counter. The value displayed by 
the counter is verified by an indicator on the engineering 
console. Input to the external counter is prepared by the 
tc; only good pulses wtll be transmitted. If good pulses 
have been sent when a bad pulse arrives, a µigh frequency 
burst is sent to the counter to force an early display. The 
validity control line is available to control external re-
cording devices. 
40 
6. Programming Characteristics 
6.1 ROS Instruction Word Format 
Using Figure 5 as a guide, the various control fields 
are diagrammed. The 36-bit instruction word is quasiparall-
el fetched and executed in monophase. Most fields are en-
coded. -Thirty instruction words are available on six diode 
matrix cards. The matrix is capable of field modification 
with standard tools, 
6,2 Multiplexer Co~trol Field (MPLX) 
This 2-bit field controls both ).2 to 16 multiplexers. 
MPLXSEL is used to select the counter or the shift register 
as the data source. MPLXSTRB causes the multiplexer to be 
disabled (outputs assume low state). 
6,3 Register File Control Field (RF) 
Two 6-bit groups define this field. One 6-bit group 
is associated with the "A" side of the ALP; the other group 
is associated with the "B'' side of the ALP. RA-RFXX and 
RB-RFXX are 2-bit binary register read addresses for the 
II A It and II Blf register files, respectively. WA-RFXX and 
WB-RFXX are 2-bit binary register write addresses for the 
n A" and "B11 register files, respectively. RA-RFEN and 
RB-RFEN are 1-bit enable lines for the read function. 
WA-RFEN and WB-RFEN are 1-bit enable lines for the write 
function. Simultaneous read and write functions may be 
41 
performed by the register file. The special STAT function, 
LOAD, requires WA-RFEN to be in the disabled state. 
Control 
The ALP field consists of six bits, four bits define 
the desired function, one bit defines the mode, and one bit 
controls the lowest order carry bit. The 4-bit function 
field (FUNX) defines two different sets of operation depe:r.rl-
ing upon the field modifier bit (MODE). Arithmetic or log-
ical operation may be selected by the MODE control line. 
The carry control bit ( CARRYIN) introduc.es the carryin at 
the least significant bit of the ALP. The CARRYIN control 
line is used in performing arithmetic computations. 
6.5 The Status Retention Control Field 
(CTL-} 
The CTL is a si~gle bit field used to cause informa-
tion to be retained by the processor for consequent inter-
rogation. This control line is referenced SAVE. SAVE 
causes these status conditions to be sampled and held; the 
ALP A=B and ALUOUT signals, and the CTRSPILL signal. The 
shift register most significant bit is monitored under con-
trol of the SAVE control line and the SHIFT control line. 
Two shift conditions are monitored. If a "zero" is ever 
shifted into the most significant bit, a flag will be set 
(-SRO). If "one 11 is ever shifted in to the significant bit, 
a different flag is set {+SRO).. These two conditions allow 
for the detection of register overflow during a shift oper-
at ion. 
6.6 The Shift Control Field (SR) 
The SR field consists of two bits. One control bit 
allows information to be loaded, broadside, into the regis-
ter. The other control bit causes a predetermined number 
of le.rt shifts to take place. 
The SRSET control line is used after the shift regist-
er has been cleared (by STAT function, SRCLR) to cause 
information to be loaded in parallel from the AL? output 
port. This information, once loaded, is immediately avail-
able to the SR port of the multiplexer. 
The SRSHFT control line is used to cause the micropro-
gram execution to be suspended, the tolerance factor value 
to be loaded into the shift counter, the specified number 
of pulses (left shifts) to be delivered to the shift regis-
ter clock inputs, and any significant value spilled from 
the shift in complete (all shift pulses delivered) the 
microprogram execution continues with the next instruction, 
This asynchronous shift technique was used to allow the 
shift to take place at a speed greater than that of the 
microprogram fetch and execution cycle. 
6.7 The Status and Control Trigger 
Field (STAT) 
The STAT field is a 4-bit binary encoded field. This 
field produces sixteen control signals. Each signal is 
~.: 
refer:enced by a name of the form, STATx, where "x11 is a 
hexadecimal number representing the code which generates 
this control signa 1 (e.g., a STAT field of '' 011011 would 
generate 11 STAT6 11 ). These control signals may be further 
processed before being distributed. The STAT field con-
43 
trols the branching and execution functions of the ROS se-
quencer (RS). The special control signals for the register 
files (RF) and the shift register (SR) are also generated 
here. Finally the verify latch which reflects the result 
of the compare is controlled by two STAT functions~ Three 
STAT functions are spares. 
STATO (NOOP) is a no-operation. This function is used 
when none of the special control signals are requlred. This 
function has no effect on the processor. 
STATl (CLKl) causes the microprogram execution to be 
suspended pending a second level interruption by the count-
er control (C). All other second level interruptions will 
be ignored. 
STAT2 (CLK2) causes the microprogram execution to be 
suspended pending completion of a SHIFT operationo All the 
second level interruptions will be ignored (Overrun detect-
ion is optional). 
STAT3 (CLKJ) is used to halt the microprogram for errcr 
diagnosis. This function is basically a maintenance feat-
ure and should not be used in normal microprogra~s. 
STAT4 (STATA) is used to test the ALP "A=B" condition. 
If the "A=B" condition is satisfied, the address modifier 
44 
(AM) is set and a branch occurs. 
STAT.5 ( STATE) is used to test the ALP II ALUOUT 11 bit. If 
"ALUOUT" bit is a logic "l", the address modifier ( AM) is 
set and a branch occurs. 
STAT6 ( ST ATC) tests for the C II SPILL" condition. If a 
counter "SPILL" has occured, the address modifier (AM) is 
set and a branch occurs. 
STAT7 (STATO) tests the shift register most signifi-
cant bit monitor for a logic "111 shifted out. If th is 
monitor latch is set, it indicates that a positive number 
was being left shifted and significance was lost during the 
shift. This condito~ causes the address modifier (AM) to 
be set and a branch occurs. 
STAT8 (GO) sets the verify latch to the "GO" state. 
This indicates that the last comparison result was within 
the tolerance bound. 
STAT9 (ABORT) sets the verify latch to the "ABORT" 
state. This indicates that the last comparison result was 
outside the tolerance bound. 
STATA (LOAD) examines the current counter latch (CC) 
and enables the register file (RF) bank ("A" or "B") cor-
responding to the idle counter. This function stores the 
value of the idle counter in appropriate register file (RF) 
bank. 
STATE (CLEAR) sets the data stored in the shift regis-
ter to all zeroes. This function is required before SRSET 
can be issued. 
45 
STATC (STATE) tests the shift register most signifig-
ant bit monitor for a logic "O" shifted out, If this 
monitor latch is set, it indicates to.at a negative number 
was being left shifted and significance was lost during the 
shift, This condition causes the address modifier (AM) to . 
be set and a branch occurs. 
Since the STAT field is encoded, all functions des-
cribed above are mutually exclusive. STAT4, STAT5, STAT6, 
STAT7, and STATC test values prepared by the SAVE control 
signal. 
6.8 The ROS Control Field (ROS) 
The ROS field contains 5-bit base address for the next 
instruction to be executed, The phrase "base address" is 
used as a reminder that, in case of a branch, the instruct-
ion that will be fetched and executed will be the next odd 
addressed instruction, The address modifier (AM) bit and 
the ROSA4 address bit are II OR I ed1' to effect the branch, 
1.1 Speed 
CHAPTER VI 
CONSTRUCrION OF THE SEQUENTIAL 
:PHASE COMPARATOR 
:t.· ._§e_lec'tion of a Logic Family 
The velocity requirem~nts helped fix the m~ximum spee~ 
at which the processor needed to perform. This informat-
ion also influenced the selection of the 16-bit word length. 
Estimates of the ROS speed combined with a maximum number 
of .twenty instruction steps allowed a frequency of l.25MHz 
to be used as the ROS cycle frequency. This placed the 
maximum pulse frequency at 50KHz. After the processor was 
constructed the maximum pulse frequency was approximately 
lOOKHz. This increase was attributed to the reduction of 
instruction steps. 
1.2 Noise 
The equipment for the processor is in a high electri-
cal noise environment. The construction materials used 
were not intended for high speed logic circuits. These two 
reasons indicate the need for a logic family that is re-
latively insensitive to noise on its inputs or power supply. 
46 
47 
Transistor-Transistor Logic (TTL or T2L) has excellent 
noise rejection specifications. MOS Logic has an even higi-
er noise immunity because of the higher voltage logic 
levels &vailable. 
l!_3 Commercially Available Functions 
The size and construction time for the unit was reduc-
ed by the use of Medium Scale Integration (MSI) logic 
devices. Thus the number of "packages" of logic circuits 
was reduced. This reduction in size made construction eas-
ier by reducing the number of connections needed. 
Transistor-Transistor Logic 
TTL was chosen because of its superior speed, noise 
immunity, and the availability of complex functions. Pro-
pogation delays in single gate structures are typically 
less than 15ns. Counters and shift registers operate at 
maximum clock rates of 20 MHz to 35 MHz· The input noise 
band is typically 2 volts with o.8 volts to groqnd and 2.8 
volts to supply margins. Several hundred different functicns 
. . 
are available in the logic family.in addition to the com-
. mon Small Scale Integration (SSI) units. 
This logic family enjoys the support of the entire 
semiconductor industry and, therefore, its existence is 
guaranteed for some time. 
48 
2. Physical Layout 
2.1 General Requirements 
Maintenance considerations required that each inte-
grated circuit (IC) to individually replaceable. Each 
logical unit of the processor should be as redundant as 
possible to facilitate error location within each unit. 
Standard inputs should be adopted to assist in forming in-
terchangable units. Physical size should be kept to a 
minimum;in 'no circumstance should the wiring board dimen-
sions exceed twenty inches on the diagonal (see TTL noise 
specifications). Expense was to be spared as much as 
possible. 
2.2 The Gate 
Surplus equipment was salvaged for a swing-out gate 
with five removable bays. These bays contain seventeen 
clrcµit board edge connector sockets each. Two of the 
bays contain a vertical support and three circuit board 
edge connector sockets. These two bays also have doors. 
The two bays were designated BAY 1 and BAY 5. BAY 1 and 
BAY 5 were used for power supply enclosures. The three 
remaining bays; BAY 2, BAY 3, and BAY 4, were used to 
house the processor logic. The entire gate was mounted on 
hinges in the back of a steel cabinet. The steel cabinet 
contains the tangential blower, power sup·ply connectors, 




Ros - Errs1.8~3S' 
Si=& uE'NeEJ< 
BAY3 





(Y),::, .rtJ ?ow I:'~ 
Figure 9. Gate Layout 
49 
2.~ The Power Supply Bays (Bay 1 
an Bay S 
BAY 1 occupies the top position in the gate. A+ 24 
volt DC power supply is contained here with the relays used 
for sequencing the other power supplies in the processor. 
The manual controls for applying system power are connected 
here. Access to the power supply is available thru the 
front door panel. 
BAY 5 contains the +10 volt DC power supply used for 
operating,the logic of the processor. The main line con-~·-
tactor is located in this bay also. BAY 5 occupies the 
lowest position in the gate and is immediately above the 
tangential blower. Access to the power supply is gained 
through the front panel door. Access to the contactor is 
gained from the rear of the gate. 
2 •4- ROS Storage Bays ( BAY 2 and BAY 3). 
BAYS 2 and 3 contain all the associated logic for the 
ROS memory and its controls. BAY 3 also contains the dis-
play controlso BAY 2 and BAY 3 have identical card com-
plements except: BAY 2 contains the ROS sequencer (RS) and 
BAY 3 contains the display control (DC) and ROS oscillator 
(ROSCO). One +5v DC power supply (PSI}, two ROS latch (RL} 
cards, three ROS matrix (RM) cards and two ROS driver cards 
(RD) may be found in each bay. Cards of the same type are 
completely interchangeable (e.g., EL 1's with RL's, RD 1 s with 
RD 1 s}. The ROS matrix (RM) storage cards, of course, can-
not be interchanged. BAY 2 contains all instruction 
51 
addresses and ROS bits 18-35. BAY 3 contains all instruct-
ion addresses and ROS bits 00-17. A dual ground rail is 
located at the to, and bottom of each bay. These rails are 
used to terminate the ground line carried by the twisted 
pair leads which interconnect the logic bays. 
2.5 The Processor Bay (Bay 4) 
BAY 4 contains the arithmetic/logic unit and its assoc-
iated support equipment. BAY 4 has a dual +5 volt DC power 
supply instead of the single units in Bays 2 and 3. One 
dual +5 volt DC power supply card (PS2), one ALU input con-
trol card (AI), four arithmetic/logic processor cards (AL), 
one ALU output control card (AO), and one interface control 
card (IX) are contained in BAY4. The 4 AL cards are com-
pletely interchangeable 4-bit processors. The dual ground 
.} rail is also available on BAY4. 
3o Power Supply Sequencing and Control 
)ol Power Sequencing 
The power supplies are applied in a specific sequenceo 
This procedure is followed to minimize the instantaneous 
load on the BAY5 power supply. A large fluctuation in the 
BAY5 voltage could cause loss of regulation on the individ-
ual bay voltage regulators. This condition could result in 
circuit damage. A six pushbutton switch is used to manual-
ly sequence the power supplies .. An indication is given.at 
the switch of a power supply or sequence malfunction. 
52 
3.2 Emergency Power Off 
This feature is used to remove all power from the 
system in the event of a catastrophy. AT-handle switch is 
located on the front panel for this purpose. Operation of 
this switch requires a manual sequencer reset to resume 
operation (i.e., further operation of the switch will be 
ineffective). 
Li. Logic Bay Assembly 
4.1 Wiring 
The edge connector sockets are mounted in each bay. 
Connections are made by a pin which is inserted into the 
back of the socket. The pin is retained by a spring clip. 
In this manner the bay sockets may be interconnected by a 
single wire jumper terminated at each end by a pin. Two 
connections may be made on each of the thirty-six edge 
connector lands. 
Connections between bays require some type of shield. 
Coaxial line terminated with pins is used for distribution 
of the clock signals and the Doppler pulse input. Other 
interconnections are made using twisted pair. One wire 
(blue) carries the signal; the other (white) is terminated 
at one end (usually the driving point) on the bay ground 
rail and insulated at the other end. The bay interconnect-
ion wires are held close.to the gate frame by the diode and 
socket assembly boards. 
53 
~. BAY Wire Listing 
Construction of the bay wiring was done using a list of 
computer generated instructtons. Information found on the 
schematic is encoded by hand into a computer readable for-
mat. This information is processed by the computer and one 
of the results is a list of wiring instructions. The list 
is used by the technician to construct the back plane bay 
assembly. 
The wire list is also used to compile a signal name 
directory and clock circuit loading conditions. The back 
plane wiring was verified by continuity tests performed 
with special test point cards and the wire list. 
5. Logic Card Assembly 
5.1 Preparation of Circuit Boards 
As stated before, the hardware was salvaged from sur-
plus parts. The circuit boards required for the logic 
cards were obtained by removing the old components from the 
circuit board, removing the pull-out handle, protecting t~e 
edge connector lands, and using copper etchant to remove 
the old printed circuit. The circuit boards were sanded 
smooth and the protective coating on the edge connector 
bands removed. 
The circuit boards were drilled, according to a card 
• layout drawing, to accommodate the IC sockets. A visual 
inspection for foreign material or out-of-line holes was 
\ 
54 
made. Contact cement was used to secure the IC sockets to 
the circuit board. The Wire Wrap 9 pins were then cleaned 
to remove excess cement. The edge connecting lands were 
suppJiad with a length of #24AWG solid wire to be used as 
·. e 
a W:tre Wrap connector. A continuity check was perform-
ed on the connector assembly. 
5.2 Logic Card Wire Listing 
A computer generated set of instructions wa·s used to 
perform the wir.ing of the logic card information from the .. 
· schematic diagram encoded by hand and processed by a com-
puter program. One output of this "WIRE LIST" program is 
the wiring instructions. The wire list allows the constru-
ction.of different boards to become routine. A continfuitY., 
check is performed on the logic card after it has been wir-
ed. 
A signal name directory is also produced by the pro-
gram. This information can be useful in error diagnosis. 
5.3 Function Tests 
After all logic cards were assembled, functional 
tests were made to determine if various sections of the 
unit were operational. The shift register was loaded and 
shifted manually. The counters were alternated and incre-
mented. The runninr.; latches and shift counters were tested. 
These tests were performed using the Hewlett-Packard IC 
Logic Trouble-shooting Kit (50l5T). A "logic clip", which 
55 
displays the status of all pins of a digital IC, is includ-
ed as well as a logic probe and pulser. This --equipment 
allowed individual function tests to be made independently 
of the other logic. 
CHAPTER VII 
':CHE MICROPROGRAM 
1. Design of the Program 
1.1 Prelimi~ary Program Design S~eps 
A prose description of the functions to be implemented 
by the microprogram was made. Using the description as a 
guide, a sequential chart was made of these functions as 
they were to be performed. This chart was reworked to in-
clude all possible common processing steps. The need to 
conserve instruction storage is great. After this initial 
optimiz,ation attempt, a flowchart was prepared from the se-
quence chart. 
The flowchart was constructed on a one instruction to 
one function block basis. These function blocks were 
broken down further to reflect the actual control signals 
gener~ted. This second series of flowcharts have an ident-
l'i":ical number of function blocks which correspond to each 
· field of the microinstruction. The STAT field function 
•l 
block is broken down into yet a third series of flowcharts 
representing the effect of each function. All flowcharts 
are cross-referenced such that the exact function of any 
microinstruction or field may be quickly determined. A 
56 
57 
computer progr.am, OSFLOW was used to generate the flow-
!P 
charts. 
2. Alteration of the Microprogram 
2.1 Modification of the Diode Matrix 
\· ! 
\: 
Replacement of the six diode matrix cards (RM) allows 
the complete removal of the microprogram. Modifications 
to the microprogram should be made after following the de-
sign procedures just mentioned. Using the ROS instruction 
word format and the flowchart listings, diodes may be ,in-
serted or removed from the matrix. A diode in a particular 
word and bit position indicates a logic 11 1"; the absence 
of a diode is a logic "011 • 
Since each instruction word contains the ROS base 
address of the next instruction to be executed (except 
branches), "patching11 the microprogram can be done quite 
easily. "Patching" refers to the insertion or deletion of 
microcode. Microinstructions may be added or deleted with-
out altering more than one existing instruction. 
Great care should be exercised in the modification 
of the microprogram. Any changes should be carefully 
nthought out" and extensively 11 desk checked" before any 
modifications are undertaken. 
58 
2.2 The Programmable ROM 
The next step in the evolution of ROS would be to 
integrate the control store into a small group of ICs. Con-
sideration of this step has.been made and, if the increased 
speed and decreased bulk is warranted, the modification 
should be incorporated. Currently available field program-
mable ROMs can be used with the existing microinstruction 
format. 
CHAP'IIER VIIL ... 
OPERATION AND TESTING 
1. Operation of the Engineering 
Console Controls 
1.1 General Control Functions 
The processor should require little manual intervention 
since the successful operation of the processor is highly 
time dependent. For this reason the manual controls are 
few and they are limited in scope. The orientation of the 
controls is toward maintenance and malfunction diagnosis. 
The initial reset of the processor is all that need concern 
the operator. 
The power distribution section of the console is used 
to turn the processor power supplies on and off. An Emerg-
ency Power Off (EPO) T-handle switch removes all power fran 
the processor in the event of a catastrophe. A six push-
button back-lighted switch is used to perform manual power 
sequencing. If the unit is successfully powered on, all 
indicators will be white. Activation ot any supply will 
cause the tangential blower to be engaged. The blower wfll 
remain on until all supplies are off and the "blower off" 




Five ROS address keys (ROSAK) are avail·able on the 
front panel. They are inactive unless enabled by another 
front panel control. These keys serve as an alternate 
source for the ROS address register ( ROSAR). This function: 
is to allow access to ROS at any address. 
The ROS enable (ROSEN) key is used to select the ROSA 
field or the ROSAK for the next fetch address. The ROSEN 
key disables the address modifier (AM) t~1s eliminating any 
unwanted branches. 
The single step (SS) key is used to select the ROS 
oscillator (ROSCO) or the manual pushbutton (MANPB) as the 
source for the ROS clock which controls the instruction 
fetch. The SS key may be used with the ROSEN key to "loop" 
on a particular ROS address (repeatedly fetch). 
The manual pushbutton (MANPB) key is used with the SS 
key to manually control execution of the microprogram. This 
feature is strictly a maintenance aid.· 
The stop (STOP) key causes execution of the micropro-
gram to be immediat~ly terminated. This key has' only main-
tenance functions. 
Four tolerance keys (TOLSWT) are available to the 
operator to set the tolerance factor. These·· ., .. ·.-,~·:.•-
keys should only be adjusted· with the ROSAK set to zero and 
ROSEN key down. 
61 
1.2 How to Start the Microprocessor 
The microprogram address that contains the special 
STAT function (CLKI)' is indicated on the microprogram flow-
chart. The microprogram execution should begin at this 
point. 
First, set the ROSEN key down, then put the ROS ad-
dress for the first microprogram in the ROSAK. Set the SS 
key down then up. With no pulses being received the ROS 
address display (ROSAD) should retain the starting address 
(exclusive of the "SPILL" condition). For the provided 
comparison microprogram, the starting address is zero. Act-
tivating the SS key while processing will cause the process-
or to temporarily halt. 
1.3 How to Change the Tolerance Factor 
Place the processor in the halt state by setting the 
SS key. Set the TOLSWT to the desired value. Restart the 
microprogram as described. 
lo4 Malfunction Detection 
If the processor should halt for any reason, always 
note the contents of the ROSAD. Armed with this informat-
ion, use of the flowchart will usually indicate the section 
that is malfunctioning. 
2. Test Apparatus and Procedure 
2.1 Generation of Variable Pulse Trains 
A test pulse train can be generated with a serial 
word generator (similar to Hewlett-Packard 8006A). The 
62 
tolerance and missing pulse detection system can be easily 
checked usirig a word generator and a dual trace occillos-
cope. Switches, corresponding to bits within the word, 
can be set to simulate good, bad, and marginal pulse , 
trains. 
Modifications to the microprogram can be tested by 
sending double pulse bursts manually with the "SPILL" de-
tector disabled. This allows the processor to be "walked 
through" the new microprogram. 
2.2 Connection of Test Equipment 
·, 
As shown in Figure 10, the word generator replaces 
the Schmitt Trigger and the oscilloscope is used to moni-
tor the word generator output (return to zero format) and 
the llGO" latch output. A storage oscilloscope, triggered 
by the word generator sync output, could be used for con-
venient single burst displays. 
63 
0 
'D lA 4L TR. A-Ct 
OstI.Lt.ose.o PE 
WOR'D Ge.l\lFRA-,oR 1 
to" t S::cG.N AL 
'PL.A.L-SE:-
'PRoce:ssoR. 




1.1 The I:,aser Anemometer Date 
Processor Problem 
The problem of missing pulse de.tection was investig-
ated and a device constructed to process measurement 
information. Various constraints made an analog solution 
infeasible. The experimental nature of the proposed design 
required extreme flexibility. For these reasons a micro-
programmed digital processor was chosen as the framework 
for the design. 
Construction of the processor was accomplished using 
the TTL family logic and Wire Wrap 0 techniques. Salvaged 
surplus equipment was used for the circuit boards and 
frameso A wire list generating program was developed and 
used to make reports. These reports were used to wire the 
processor and perform cert~in tests and checkout procedure. 
The completed processor, with its comparison micro-
program, was tested using the serial word generator and a 
dual trace oscilloscopeo Further operational testing of 
the processor is being carried out by the Basic Fluid 
Dynamics Laboratory at the OSU Mechanical and Aerospace_, 
64 
Engineering Laboratory. Preliminary test results show 
agreement with those measurements taken by hand. 
1.2 Possible Extensions 
6.5 
The large number of tolerance factors available allow 
a technique to be used to increase the effective upper fre-
quency of the processor. Assume that the maximum 11 native 11 
mode frequency is lOOkHz and that the tolerance should be 
25%. If we have a sufficient number of pulses in the burst, 
then a digital division may be used to lower the input fre-
quency. At the same time, if the tolerance divided by the 
same amount, the effect will be to raise the upper frequen-
cy. This arrangement can be used to extend the same r~nge 
beyond the native mode limit. 
The commercial TTL logic used could be replaced by the 
Schottky TTL or emitter coupled logic (ECL). Either of 
these logic families is capable of extending the frequency 
range of the processor. Using programmable ROMs also 
would increase the processor speed. 
Program modifications can be made without great diffi-
culty. Experiments with different comparison schemes might 
prove helpful. 
BIBLIOGRAPHY 
(1) Asher, J. A. "Laser Doppler Velocimeter System 
Development and Testing". General Electric 
Technical Information Series, Report No. 
72CHD295. Schenectady: General Electric,1972. 
(2) Clark, Christopher R. Designing Logic Systems 
Using State Machines. New York: McGraw-Hill, 
1973. 
( 3) Dollhoff, Terry L. "Microprogrammed Control for 
Small Computers". Computer Design, Vol. 12, 
No. 5 (1973), pp. 91-97. . 
(4) Flynn, M. J., and R. F. Rosin, "Microprogramrning: 
An Introduction and A Viewpoint". IEEE Trans-
actions on Computers", Vol. C-20, No.7. 
IEEE, (19;1). 
(5) Henderson, J. T. "Write a Fortran Wire-Listing 
Program". Electronic Design, Vol. 21, No. 11 
{1973), pp. 140-142. 
(6) House, David L. "Micro Level Architecture in 
Minicomputer Design". Computer Design, Vol. 
12, No. 10 ( 1973), pp. 75'='86. ----
(7) Husson, Samir s. Microprogramming, ~rineiples 
and PrBctices, Englewood Cliffs: Prentice-
Ifail-;-1'970. 
(8) Lewis, Donald R., and W. Ralph Siena. "Micropro-
cessor or Random Logic?" Electronic Design, 
Vol. 21, No. 18 (1973), pp. 166-110. 
( 9) Redfleld, S. R. "A Study in Microprogrammed Pro-
cessors: A Medium Sized Microprogrammed Pro-
cessor." IEEE Transactions on Computers, Vol. 
c-20, No.-r;-IEEE, (1971}. ~ 
(10) Smid, R. W. 11 1:t"'requency Tracking System". 
(Paper presented to LDA workshop, Oklahoma 
State University, 1973). 
66 
VITA 
Lloyd Neal Salsman 
Candidate for the Degree of 
Master of Science 
Thesis: A DIGITAL SIGNAL PROCESSOR FOR LASER DOP.PLER 
ANEMOMETER SYSTEMS 
Major Field: Electrical Engineering 
Biographical: 
Personal Data: Born in El Reno, Oklahoma, October 
15, 1949, the son of Mro and Mrs. Norbert No 
Salsman. 
Education: Graduated from El Reno Highschool, El Ren~ 
Oklahoma, in May, 1967; received Bachelor of 
Science degree in Electrical Engineering from 
Oklahoma State University in 1972; completed re-
quirements for Master of Science degree at Okla-
homa State University in December, 1973. 
Professional Experience: System Programmer at Okla-
homa State University Computer Center, 1968-1973. 
Professional Organizations: Member ot· Eta Kappa Nu; 
member of IEEE. 
