A modern hybrid computer interface by Wilkins, J. M.
A 	MODERN HYBRID COIPUTER INTERFACE 
by 
Jeffrey Martin Wilkins
 
A 	 Thesis Submitted to the Faculty of the 
DEPARTMENT OF ELECTRICAL ENGINEERING 
In Partial Fulfillment of the Requirement 
for the Degree of 
MASTER OF SCIENCE 
In the Graduate College 
THE U14IVERSITY OF ARIZONA C ­
1970 	 L 9i _.70-fl'23 0 8 1 
(ACCESSIO BER) 
(NASA CR OR TMX OR AD NUM)(CATEGORY) 
https://ntrs.nasa.gov/search.jsp?R=19700018777 2020-03-23T19:32:54+00:00Z
ACKNOWLEDGMENTS 
The project described in this report is part of a continuing
 
hybrid analog-digital computer study directed by Professor G. A.
 
Korn. The LOCUST interface project was supported by the National
 
Aeronautics and Space Administration under NASA Grant. The writer
 
is also grateful to Drs. W. Fahey, G. Howard, and R.' Mattson for
 
their contribution of University facilities.
 
PREEDIG ~AG~BLANK NO!f 
TABLE OF CONTENTS
 
PagL 
LIST OF ILLUSTRATIONS...................................... v
 
LIST OF TABLES ........................................... vlia
 
ABSTRACT.................................................... ix
 
I: INTRODUCTION................................................ 1
 
I/0 Operation.......................................... 2
 
General Description of the Interface................ 2
 
II. DETAILED CIRCUIT DESCRIPTION................................ 5
 
Device Selector Operation ............................ 7
 
Flag Logic............................................. 12
 
ADC Data Transfer...................................... 14
 
MDAC Data Transfer..................................... 16
 
Control Register Data Transfer ...................... 19
 
Data Read-in Gates..................................... 19
 
DEC/?2CL Trunks ....................................... 21
 
Oscilloscope Trunks.................................... 21
 
Preset Counters....................................... 21
 
Overload Light Reset Logic.......................... 28
 
PDP-9 Internal Signals ................................ 30
 
Free IOT Pulses....................................... 30
 
III. PATCHBAY AND IOT INSTRUCTIONS............................... 32
 
Linkage Patching....................................... 33
 
Patchable Flags................................... 33
 
Analog to Digital Converters ................... 33
 
Multiplying Digital-to-Analog Converters ....... 33
 
Linkage Control Switches ....................... 38
 
Data Bus Read-ia Gates........................... 38
 
Six-Bit Control Register....................... 39
 
iv
 
v 
TABLE OF CONTENTS -- Continued
 
Page
 
Preset Counters..................................... 39
 
Oscilloscope Trunks................................. 39
 
Data Channel - Locust Digital Patchbay Trunks... 40
 
Overload Signal..................................... 40
 
PDP-9 Generated Signals.......................... 40
 
Free TOT Signals ................................. 40
 
Input/Output Transfer Instructions...................... 41
 
Patchable PI Flags............................... 41
 
Analog-to-Digital Converters....................... Al
 
Multiplying Digital-to-Analog Converters......... 42
 
Data-bus Read-in Gates.............................. 43
 
Six-Bit Control Register............................ 44
 
Preset Counters..................................... 44
 
Free TOT Signals.................................... 45
 
IV. APPLICATION.................................................... 48
 
Amplitude Distribution Measurement Example ............ 48
 
Statement of Problem..................................... 48
 
Method of Solution....................................... 49
 
Results................................................... 50
 
V. CONCLUSIONS.................................................... 58
 
REFERENCES..................................................... 59
 
LIST OF ILLUSTRATIONS
 
Figure Page
 
1. Block Diagram of the Interface ............................. 4
 
2a. MECL/DEC Converter....................................... 6
 
I. DEC/MECL Converter....................................... 6
 
3. DEC Logic Layout......................................... 8
 
4. MECL Logic Layout and Card Placement..................... 9
 
5. Counter Logic Layout........................................ 10
 
6. Logic Symbols................................................ 11
 
7. Flag Logic................................................... 13
 
S. ADC Logic........... . .................................... 15
 
9. MDAC Logic................................................... 18
 
10. Control Register Logic...................................... 20
 
lla. Read-in Gate Trunks......................................... 22
 
b. DEC/MECL Trunks.............................................. 22
 
12. Preset Counter Timing Diagram............................... 23
 
13. Preset Counter Control Signals.............................. 24
 
14. AC Bit Trunks for Preset Counter........................... 25
 
15. Preset Counter Logic........................................ 26
 
16. Overload Light Logic........................................ 29
 
17. Interface Patching in the LOCUST digital Patchbay ........ 34
 
18. Interface Patching in the Data-channel Patchbay.......... 35
 
vi
 
vil
 
LIST OF ILLMSTRATIONS -- Continued
 
Figure Page
 
19. A/D Converter Patching ................................ 36
 
20. MDAC Patching ......................................... 37
 
21. Flow Chart for Amplitude-distribution Example ......... 51
 
22. Analog Patching for Amplitude Distribution Problem.... 55
 
23. Amplitude Distribution of Square Wave................. 56
 
24. Amplitude Distribution of Sine Wave................... 56
 
25. Amplitude Distribution of Triangle Wave ............... 57
 
26. Amplitude Distribution of Gaussian Noise.............. 57
 
LIST OF TABLES 
Table ?age 
1 IOT Instructions........................................... 46 
2 HISTOGRAM.................................................. 52 
viii
 
ABSTRACT 
This paper discusses the hybrid linkage system which
 
interfaces the LOCUST high speed iterative differential analyzer
 
and the PDP-9 digital computer to form a hybrid computing system. 
The interface comprises four analog-to-digital converters and
 
four multiplying digital to analog converters for data transfer
 
between computers. A control register, read-in gates and patchable 
flags provide digital control functions in the linkage. PDP-9
 
loaded counters and PDP-9 timing signals also add flexibility to the 
interface. Patching instructions and input/output transfer
 
instructions which control the interface are discussed. An amplitude
 
distribution example utilizing the interface demonstrates a type of
 
problem that may be handled with the linkage. 
ix 
CHAPTER I
 
INTRODUCTION
 
The LOCUST-PDP-9 interface was designed and constructed in the 
University of Arizona's Computer Science Research Laboratory. The 
purpose of this hybrid linkage is to enable the LOCUST high-speed 
analog computer and the PDP-9 digital computer each to perform the 
functions they are best able to perform while maintaining an
 
interaction that makes the combination much more powerful than either
 
machine working alone. The high-speed differential-equation solving
 
ability of the analog computer is maintained and the accuracy,
 
memory, and decision making ability of the digital computer are added.
 
LOCUST (LOw CoST) is a high-speed solid-state interative
 
differential analyzer capable of operating at iteration rates as high
 
as 4000 analog computer runs per second as well as in real time
 
(Conant, 1968). It employs flexible digital control logic as well as
 
patchable free logic. Provision was made at the time of LOCUST's
 
construction for the addition of control logic driven from a digital
 
computer. All of the digital logic in LOCUST is MECL emitter-coupled
 
integrated circuit logic, chosen for its low noise.
 
The Digital Equipment Corporation PDP-9 programmed data
 
processing system is a general purpose computer, incorporating diode­
transistor negative logic throughout. It is a single-address, fixed­
word-length (18 bits), parallel binary computer. The PDP-9 has a 
1 
2
 
1 p sec complete cycle time. (PDP-9 User Handbook, Digital
 
Equipment Corporation, 1968).
 
I/0 Operation
 
The basic PDP-9 I/0 facilities utilized for the LOCUST-PDP-9
 
interface include;
 
1. 	An I/0 bus system which chain links all the device
 
controls for all peripheral devices to the central
 
processor unit.
 
2. 	A program interrupt control.
 
3. 	An I/0 status read provision.
 
4. 	A conditional skip-on-device-status sense line
 
provision.
 
The I/0 bus consists of command lines and bidirectional data
 
lines for use in accomplishing program-controlled transfers; plus
 
the 	program interrupt control, the I/0 status read, and conditional
 
skip-on-device-status provisions. Detailed information on the PDP-9
 
I/0 	system is contained in the PDP-9 User Handbook (Digital
 
Equipment Corporation, January, 1968).
 
Under construction is a data-channel interface for block
 
transfers to and from the PDP-9 memory.
 
General Description of the Interface
 
The two essential functions of the interface are: data transfer
 
between computers and control of the analog computer by the digital
 
3 
computer. The primary data-transfer devices are four analog-to­
digital converters (ADCs) and four multiplying digital-to-analog
 
converters (INDACs). The remaining data transfer devices are 6 data
 
read-in gates and a 6-bit control register. The read-in gates and
 
the control register enable the operator to transfer discrete logic
 
levels to and from the PDP-9 accumulator (AC) under program control.
 
Control functions are generated both by the PDP-9 and LOCUST. At the
 
present time, there are two patchable flags in LOCUST which are
 
connected to the Program Interrupt (PI) and Skip Request (SKIP) lines 
of the PDP-9, with provision made for four more. Programmable IOT 
pulses gated by a device selector are brought out in LOCUST as well 
as other useful PDP-9 generated signals; 10 SYNC, T0 RUN, POTER CLEAR, 
and ENABLE. Two 10-bit binary counters located in LOCUST serve as 
"alarm clocks" preset by the digital computer; each counter can count
 
patchable LOCUST-generated pulses and generate timing and sampling
 
signals. A block diagram of the interface is shown in Fig. 1. The
 
level converters (MECL/DEC, DEC/NECL) indicated in the figure are
 
discussed in Chapter II.
 
PDP- 9 BUFFER DEVICE LOCUS T 
REGISTER REGISTER 
ANALOG PB 
A MDAC0 
1-4 - o MDAC3 
A C O - MDAC4 
AD P0I
 
AC RUN0 T-EA CTADC ADC's 2
 
-4 oA D AcD 3REA 0 0 
ADC(SEN S E)RA 0-S KIP RQ 1 5 I -- --SK I P - - - - I C J >l - - FL A G S
 
D T CASWITCH SWP
NN L TCH 
PI 10 I1 -mINTERRUPT oMECL/DEC OPATCHABLESYNCI., -- CONVERTER j FLAGS 
SD LINES -IDEVICE SELECTOR CLOCK 
IOP LINES PDP-9 CLOCK+ PDP-9 INTERNAL
10 RUN - --IINTERNAL CONTROL SIGNALS
 
POWER CL
10 SYNC SIGNALS 0 
OFFER OUTPUT OTO 
REGISTER 
I I ME C L /D E CR ESB -,

COUNTERS-
A C 0-9 oOO O M E E RS o GATE S 
AC 05I"TRUNKS 
DATA CHANNEL PATCHDAY
 
Fig. 1 B lock{ Diagrajm or Lho InLerfare 
-CHAPTER II 
DETAILED CIRCUIT DESCRIPTION
 
The LOCUST/PDP-9 interface comprises essentially two sections. 
One section contains DEC logic (0 v, -3 v logic levels) and is 
located in three DEC Type 1943 mounting panels attached to a standard
 
19-inch rack cabinet, which makes up the left hand bay of the LOCUST
 
machine. The other section contains MECL II current mode logic
 
(-.75 v, -1.5 v logic levels) and is located on printed-circuit cards
 
which plug into the back of the LOCUST digital patchbay (LDPB).
 
Conversion of logic levels is made by NECL/DEC (Goltz, 1968) and
 
DEC/NECL converters on standard DEC cards that plug into the Type 1943
 
mounting panels (Fig. 2). All signals passing between the DEC portion 
of the logic and the MECL portion of the logic do so at IECL levels
 
via twisted pairs. A twisted pair is driven by the complementary 
outputs of any MECL device; each pair is terminated by an MC1020 line
 
receiver with a 100 ohm shunt resistor. The resulting low-impedance
 
line assures high noise immunity. The 14ECL/DEC converters also serve
 
as line receivers, making an MC1020 unnecessary. MECL II was chosen
 
for use in LOCUST because of its inherent low noise stemming from its
 
balanced-current, nonsaturating operation.
 
With the use of the MECL trunking scheme it is possible to
 
drive line lengths limited only by series resistance, propagation
 
5 
-56v -15v -25v 
92.2 K 
COMPLEMENTARYC5 75K IN4009 
tNECIL INPUTS 
_____ 
_ 91OA-L DEC OUTPUT 
6513 
(a) 
510j - 1 COMPLEMENTARY 
DEC INPUT -CIOZ4 MECL OUTPUTS 
(0, 3v) 5 10 (-75v,-i 5v) 
rtVA_ 
O0K 15v 
.OO1FfpS 
(b) 
I.ALL RESISTORS ARE I/2W 10% 
Fig. 2 (a) HECL/DEC Converter
 
(b) DEC/ECL Converter 
7 
delay, and common-mode noise. The twisted pairs used in the
 
LOCUST-PDP-9 interface are eight feet long.
 
The location of the DEC logic is shown in Fig. 3. The
 
location of a logic card is identified by a letter(row) and a
 
number(column). The pins are lettered. The MECL logic is located on
 
three plug-in cards lettered A, B, and C and two counter cards
 
lettered D and E mounted in brackets behind the LOCUST digital
 
patchbay. The individual integrated circuits are numbered as are the
 
pins. The MECL logic layout for cards A, B, and C and the card
 
placement in the patchbay is shown in Fig. 4. The counter logic
 
layout is shown in Fig. 5. The logic symbols used throughout the
 
interface diagrams are shown in Fig. 6.
 
All of the DEC flip flops used in the interface use DCD gates,
 
except for the simpler set-reset flip flops used in the flag logic.
 
if the input level of a DCD gate is at ground at least 400 nsec prior
 
to a -3 v to 0 v transition at the pulse input, the flip flop will
 
trigger.
 
Device Selector Operation
 
Device Selectors (See Fig. 7) decode the device-address bits
 
of each IOT instruction word and gate (IOP/IOT) pulses to effect
 
desired data transfers, skip tests, or other device operations. In
 
the LOCUST / PDP-9 interface, a single device selector is used for
 
both an ADC and an HDAC. Device-selector TOT pulses are gated with
 
subdevice bits from the PDP-9 to provide the necessary pulses.
 
R202 K5 KL Ki K 
R202 R202 14 K7- MKD 
o R203 
RII3 
R203 
R603 
R202 
R202 
K6 
R202 
M/D 
D/M 
M/D 
M/D 
R113 R13 R202 R202 D/M M/D 
o 
WIO3A 
WIO3A 
W1032 
WIO3B 
W640 
R203 
R203 
R60 
R123 
R202 
R203 
R203 
R123 
D/M 
D/M 
D/M 
R200 
M/D 
D/M 
D/M 
R200 
W640 R123 R603 R200 
o 
RII3 
WIO3A 
SECONDARY 
RIO? 
WrO3B 
SECONDARY 
R603 
Rill 
R603 
RIO7 
Rt-I 
r:: 
a, 
2 
2_ 
-
SECONDARYBus 
50__W 00 
I-PRIMARY 
SUs 
PRIMARYPus 
Rll3 
W1O3A 
SECONDARYBUS 
W5O0 
PRIMARY
Bus 
PRIMARYReu_ 
RI07 
W103B 
R2020 
R202 
R202 
R203 
R205 
R203 
R202 
R202 
R202 
R200 
R123 
- W640 RIO? R203 R113 
a 
R603 
R203 
R203 
R123 
R123 
RI23 
WIO3A 
WIOA 
R603 
WIO3B 
W103B 
W640 
R203 R123 R203 R113 
RI3 R203 R203 R123 
K16 
R202 
R202 
R202 
K12 
{ 
I 
I 
R202 
R202 
R202 
R203 
R203 
R202 
0R202 
RI23 
R123 
R202 
KI5 
SK4 
KI3 
K1I 
K 
K9 
I 
R 
R123 
R200 
R202 
R200 
R202 
R603 
RIO7 
m g L MEi L LL 
Fig. 3 DEC Logic Layout 
VIEW FROM 
SIDE 
GROUND PLANE 
OF CARDS 
tIC1024P 
WM MC10Z4PW10,Oop F M I O 4 
F IACIa4P 
IC104P IOPF.5C]022, 
110F614M P 
-h O24P 
01024?LI01024P-I02I 
111 MC1024P 
lIO 20P 
fI01P20? 
M01P [jj1 
1-0 
, --
34-
p MCIO2OP 
F1 LI 
,t101020P 
CARD B 
M0IO2OP ,,10C024P 
L] [ 
MC1O24P 
II II II I 
25 54 CARD C REAR VIEW 
OF LDPB 
34A-
CARD A 
A fLC Idoi L, 
MOLOIOP riOI~O 
MIOIO 
!,013P - MOIOIaP 
H] 
mIIOIZP M01004 
VIEW FROM GROUND PLANE SIDE 
Fig. 5 Counter Logic Layout 
OR-NOR GATE PULSE CONVERTER 
FLIP FLOP WITH 
DCD GATES 
75v -Ov 
NAND GATE 
-15V M/-3v 
LEVEL CONVERTER 
W1 03 
alaOv 
INVERTER 
-3v -
LEVEL CONVERTER 
75v 
I 5v 
DEVICE 
SELECTOR 
LINE RECEIVER 
R 603 -OTHER 
PULSE AMPLIFIER 
F4 6 Logic Syi,,oW, 
AS 
SYMBOLS 
MARKED 
12
 
Flag Logic 
There are presently four ADC flags and two patchable flags in 
the interface. The ADCs have a status indicator output, which is at 
ground if the converter is busy and at -3 v when a conversion is 
corplete. This output is used to set and reset a DLC R200 flip flop, 
which serves as the "flag". This flag may also be cleared by the ADC
 
read pulse and the PDP-9 POWER CLEAR signal. The patchable flag
 
inputs from the LDPB are trunked to the DEC logic and converted to
 
DEC levels by MCL/DEC converters. The converter outputs set and
 
reset their respective flag flip flops. These flags may also be
 
cleared by a programmable lOT pulse and 0 POWER CLEAR. A representa­
tive section of flag logic is shown in Fig. 7.
 
The ADC status indicator goes to -3 v when a conversion is
 
complete. This signal is inverted to provide a positive going pulse
 
at the diode input of an R603 pulse amplifier. The output of the
 
pulse amplifier is a positive going 100 nsec pulse which sets the
 
flag (flip flop) to a -3 v. A read IOT pulse is gated with 10 POWER
 
CLEAR and inverted to provide a positive going pulse to the diode
 
input of a pulse amplifier connected to the reset input of the flag.
 
A DCD gate on the same pulse amplifier is enabled with a ground input
 
and pulsed with the device status indicator to reset the flag. here­
after, the word "flag" means the output of the respective R200 flip
 
flop.
 
STATR E23 - R2--AC"US,INC O 

T D -- _ -'---IR200 IF ADCfl 
ADC"I READ OT DD 2 
FREE FLAG 
19 Al E51 F-1" R603 
5- E H 20_F_ FREEFREE 
FLAG*I CLEAR lOT Rl N ERO LG' 
T
 
Iu POWER CLEAR 
Fig. 7 Fla, logic 
14 
ADC Data Transfer
 
The four-channel analog-to-digital converter was designed and
 
built by John R. Goltz. It is an 11 -bit two's-complement converter
 
with parallel binary output. Conversion time is between 50 and 270
 
psec. Detailed information on the ADC is contained in ACL Memo '-o.
 
147 (Goltz, 1968). Unless otherwise noted, all signals discussed in
 
this section refer to Fig. 8.
 
When an A/D conversion is completed, a flag is raised which
 
is connected through a gate to the PI line of the IC bus. When the
 
PDP-9 receives a PI signal, it immediately begins looking for the
 
source of the interrupt. The PDP-9 interrupt-service routine issues
 
a series of IOT pulses which are gated with the flags of peripheral
 
devices to the SKIP line. When the raised flag is tested and a skip
 
request is granted, the PDP-9 then executes a service subroutine
 
corresponding to that specific flag. This subroutine reads the
 
converter by gating the converter output onto the 1O bus with an TOT
 
pulse. This same read IOT pulse is connected to the READ REQUEST line
 
and is also used to clear the converter flag. The READ REQUEST tells
 
the PDP-9 to read the data that is on the 10 bus into the AC. Upon
 
completion of the service subroutine, the PDP-9 returns to the main
 
program. Detailed information on programming the PDP-9 input-output
 
system is contained in the PDP-9 User Handbook (Digital Equipment
 
Corporation, January, 1968). There are four identical sections of ADC
 
H ATUREAD STATUS DR125 

ADC ' FLAG
 
S D FCiFS4 
SUB DEVICE M Ct5 
R 
P 
BIT 
5 
R 
R1 
R12 
D12 
N 
10 BUSS 
io BUS50 
i p 2T 
10 
u O BUS9 
0 BF 
DiO 
AF 
ION 
~ 
BIT 0 
BIT 2I 
S R123 
R? 
H BUSIO 
Fig. 8 ADC Logic 
16 
logic, hence only one section is shown in Fig. 8. The number in
 
parentheses in the W103 device selector block is the device address
 
octal code.
 
The ADC converter flag is connected through an inverter to the
 
PI line. A negative going IOTi pulse from a device selection is gated
 
with negative subdevice bit 0 to provide a positive 100 nsec pulse at
 
the input of the pulse converter. The pulse converter is wired to
 
provide a 1 psec negative pulse at the input of the R123 bus gate.
 
The other input of this nand gate is connected to the converter flag.
 
Hence when the flag is a -3 v and a negative test pulse appears, a
 
ground level is placed on the Skip Request line for 1 psec. A
 
negative going IOT2 pulse is gated with negative subdevice bit 0 to
 
provide a positive 100 nsec pulse at the input of pulse converter
 
W640. The negative 1 psec pulse output of the W640 is inverted twice
 
to provide a negative read pulse with the proper drive at the input
 
of the R123 bus gates. The ADC data (negative assertion) is
 
- connected to the other inputs of the bus gates and is gated onto the 
T0 data lines as a ground level when the read pulse appears. The
 
read pulse is also inverted through another gate and connected to the
 
READ REQUEST line.
 
MDAC Data Transfer
 
The 12-bit two's complement MDACs were developed as a
 
master's thesis by Don C. Eddington (Eddington, 1969). There are
 
four double-buffered MACs in the LOCUST/PDP-9 interface. 
17
 
The interface logic for an MDAC consists of a buffer
 
register and a device register. Double buffering permits
 
simultaneous updating of digital inputs to all MDACs. The buffer is
 
first cleared and then loaded with the accumulator contents by a
 
PDP-9 lOT instruction. The buffer-to-device-register jam transfer
 
can be effected either by a PDP-9 instruction or by patching a ILCL
 
"1" to a D/A TRANS input in the LOCUST digital patchbay. The use of
 
a jam transfer to load the device register eliminates the undesired
 
transient that would occur at the MDAC output if the device register
 
were cleared prior to each transfer from the buffer register.
 
There are four identical sections of NIAC logic; for clarity, 
only one section is shown in Fig. 9. The buffer register, made up of 
R203 flip flops, is fed data from the 10 data lines through WS00 
emitter followers. The buffer is cleared with IOT1 (gated with PDP-9 
subdevice bit 1), a positive-going 100 nsec pulse at the "clear" input 
of the flip flops. Data from the emitter followers is connected to the 
level inputs of DCD gates, and the strobe pulse is provided by iOT2
 
also gated with sub-device bit 1; the strobe signal is power amplified
 
by an R603 pulse amplifier. The R603 provides a positive-going 100 nsec
 
pulse when the positive transition of the gated TOT pulse occurs. Thus,
 
when the data (ground assertion) and the strobe pulse occur at the DCD
 
gates, the buffer is loaded.
 
Complementary outputs of the buffer-register flip flops are
 
connected to level inputs on corresponding flip flops in the device
 
register. The pulse inputs of the DCD gates on the R202 flip flops
 
BI 0 I 2 3 4 
DAC 
5 
INPUTS 
6 7 8 9 10 BITlJ 
j 
R202 
C 
T 
fR202 
07 
R202 
D7 
R202 
D7 
R202 
C6 
T 
R202 
06 
di 
R202 
D 
T 
R202 
D6 
J 
R202 
T 
R202 
C 
U 
R202 
05 
T 
R202 
55D  
D 
F 
203 
ol 
u 
R20 
-cii 
VODL 
L S 
E 
T 
NP0 
F 
R203 
CIO 
V 
E 
DEXL 
m 
R203 
CIOca 
L 
NVUP 
S 
R203 
CIO 
D EK 
R203 
C9 
L 
E 
M U V 
L 
-
DLKE 
SF 
GB0 CS 
PUV 
E 
D L 
M L 
R203 
0 
V P 
S T 
203 
8 
U HO lPrm <V J H D P N K V U R J H D PH KN IS O K V LI R 
E H K P $ U E H K m P 
W500 
018 
D 
W500 
018 
F 
W50 
Gi 
j 
W500 
GI8 
L 
W500 
GI8 
W500 
GiG 
R 
W50 
C18 
T 
W0 
OLCI 
D 
SO 
F 
W00 
I 
J 
WSO 
I18 
W50 
N 
10 Bus0 I 2 3 4 5 6 7 8 9 10 IO Bus I I 
SUB DEVICE 
BIT I 
W103 
014 
-R0-XR 
a 
AF H"C5-11 
,1 
AM R115K 
R 
P/ C15,I T 
v 
1 
i p R603 
C12 
-
AN 
B8 F4).E F 2o8.S 
Fig. 9 Ilh.& Logitc 
19
 
are driven with a positive-going pulse from a pulse amplifier. The
 
positive transition at the pulse amplifier input is provided, after
 
inversion, by either a transfer signal from the LOCUST digital
 
patchbay (a NECL/DEC converter output) or IOT4 gated with subdevice
 
bit 1. The IIDAC analog switches are connected to the "" outputs
 
of the R202 flip flops, i.e. -3 v assertion corresponds to an FET
 
switch closure.
 
Control Register Data Transfer
 
The six-bit double-buffered control-register logic is similar
 
to the MDAC logic (Fig. 10). The buffer register is cleared by a gated
 
IOTI pulse. The data is read into the buffer from W500 emitter
 
followers using a gated 10T2 with the proper drive to provide the pulse 
input to DCD gates. The data is jam transferred into the output 
register by a gated 10T4 pulse from a pulse amplifier. 10 POWER CLEAR 
clears the output register when the computer is first started. The 
10 POWER CLEAR signal is issued when the 10 RESET switch is depressed 
on the PDP-9 operating console. The output of the control register is 
converted to MECL levels and trunked to the LOCUST digital patchbay. 
Data Read in Gates
 
The read-in gate inputs are ME"L gate inputs in the LOCUST
 
digital patchbay. The signals are trunked to the DEC logic bay,
 
converted to DEC levels and brought out in the data-channel patchbay
 
(DCPB). There, the outputs are patched into R123 bus gates and data
 
is strobed onto the 10 bus with 1OT2 from a W103 device selector. A
 
BITB
SUBB CR BITO BIT I 00 
DEVIE BIT2 BIT3 BIT4 
0 
BIT5 
0 
AF 
WiO3 
M 
-
CL 
5 
4 
4M71020 
6 
M 
3 
E141020 
1 2 
S R 
II 
MCIOoZ° 
2813 
U T 
8 
I0 4 
MooOZO 5 McJo2o 
9 5 610E K J 1 L 3 M01020 2 M 
FOAD/M D/M DIM D/M D/M DIM 
E28 E28 E28 E27 E27 E27 
FSN 
R63R202 
B29 
H 
A31 
o, L F E 
P 
S 
R202 
N V R UP 
V 
H 
R202 
8331 
D L FX E N 
FH 
S 
R202 
1331 
VNRUIP 0 
H 
R202 
A32 
LF KCE 
N 
s 
R202 
A32 
VyR 
R603 Ri3R203 
828 A30 
R203 
S T 
R203 
A383 30 
E 
R20 
F L M 
R203 
30B0 
S 
R203 
T 
T P 
POWER5 
AR U r 50 SOW0 50 50W0 
IO BUS 0 
Fig. i0 Control clegist 
2 
I ,gic 
5 4 JO BUS 5 
21 
read request must also be made with 1OT2. This is accomplished by
 
patching in the DCPB. The read-in gate trunks are shown in Fig. hla.
 
l>aintenance drawings for the gate and device-selector logic are
 
contained in the report on the data channel interface CSRL Memo. 215
 
(University of Arizona, 1969).
 
DEC/MECL Trunks 
The wiring for four trunks from the data channel patchbay to
 
the LOCUST digital patchbay is shown in Fig. llb. DEC levels are
 
converted to MECL levels and trunked via twisted pairs.
 
Oscilloscope Trunks
 
Digital drivers using the standard MECL trunking scheme are
 
also used to provide oscilloscope inputs from the LOCUST digital
 
patchbay.
 
Preset Counters
 
Two ten-bit binary counters located in the rack cabinet
 
behind the LDPB are loaded from the PDP-9 upon command. Each MCL
 
counter is a down counter, which is first cleared and then loaded with
 
the complement of one less than the number of pulses to be counted.
 
The counters count LOCUST pulses and issue "S" and "SD" timing pulses 
used mainly to operate track hold pairs (Korn and Korn, 1964). A 
timing diagram is shown in Fig. 12. Discussion of the counter logic 
refers to Figs. 13, 14 and 15. The two counters are identical except
 
for their operating IOT instructions.
 
22 
LDPB DCPB 
6 R 
9U5 
8 F 
2 0 2 M.104 M/D D o 2 
AS F28 
E30 0 
6 2 
5 0 11 MC1024 
A5 
M/D 
F28 
H Q 
TI F 25 
(a) 
LDPB DCPB 
T35 1 
I CI)':1 
3114 
l o,C 
F M28 
T 5 
3 M 
525 
LL9 T 
T3F0 II D/M NH 
52 
(a)
 
Fig. 11 (a) Read-in Gate Trunks (b) DEC/NEOL Trunks 
23 
INPUT 
PULSES 
-1 
S - -64Ts 
SD S64Ti 
Ts max 
Tsomax 
< 
< 
1024Ti 
08BTi 
Fig. 12 Preset Counter Timing Diagram
 
SUB 
SUB 
DEVICE 0 
DEVICE I--
A26 AM 
B26E29 
(5__A 
0 
M 
R 
A2 
A 
1 F R 
SKIP 
E F A 
E29 -1 
13 
1 
BDr,
BI 
10 
COT 
OACTRCLEARCTR 2 
A28 ,,FI.13tC 
HK 
R 13_ 
A2 1SKIP 
S: 1E 
,ET E2!9/I 
e C-
FREE FLAG42 
OT 
9/!" '-- K -
MC1020 
B lO4 
LOAD CTR I 
CLEAR CTR 2 
4 E 29 M01o2o 
Fig. 13 Prus,t Counter Co-.,trol S1,, ,Is 
IoBUSo DW0 
C18 
JE F D/ME25E E 13 B41401020 I 
pW0 H 
018 
--D-
E25 K 
84> 
9 000 
10 
21 
JW0K N D/ M 
Ei! 
L I B3 
2 MC1020 
LW 00 I 
CaE25 
D/, IM R 
S: 
53 
1.10102 
4 
N 
018 
SOO v DIM 
E25 
T 
U 
88B34 
S1000 
5 C18 
R~~M,2 
: 
W50S-0I 
P26 E 
S 
1400 
1 
6- T~ UH 
018! 
'50DM 
P26 
26 
2 1400 3 
_ W500E 
DF8 
N. D/ 
P26 
L 
M 
5 
6 
3-00 4 
8 W500 H 
DIGD 
p D/M 
P26 S 
28 
13 012 
8 
8 
9. WSOOK v DI'm 
DIG26 
Fig. 14 AC Bit Trunks for 
T 
Preset 
83 
>-.112 
Counter 
10 
AC 
BIT0 s C01 8 2 O 
I0 -3 ] 1 2 D13 
I IG1 MC90 0 
21 12D312 D1 DI 
7 - 12 1 9 
5 6 
II 
4 DaA l T1 
Fig. 15 Preset Counter Logic 
27 
Output of the data line emitter followers, AC 0 - 9, il
 
converted to MECL levels and trunked to plug-in card B in the LOCCST 
digital patchbay. The data lines are brought to the counter ca.. 
with ribbon cable. The clear 1OT is obtained by gating IOTI from a 
device selector with a subdevice bit. The load IOT is IOT2 gated 
with the same subdevice bit. Both counters use the same device 
selector. The different counters are selected with subdevice bits. 
IOT pulses are converted to IECL levels and brought to the counter 
card in the same manner as the data lines. The input, output, and
 
delayed output lines are run from the counter card to card B with
 
coaxial cable. Card B has direct connections to the digital
 
patchbay.
 
The IOTI pulse converted into a 100 nsec MECL "l" is used to 
reset (clear) the MC1013 J-K flip flops which make up the counter. 
A negative 100 nsec MECL "0" set pulse is gated with negative 
assertion data (a "I" in the AC is read out as a MECL "0" to the 
counter) to provide "l's at the NOR output of the respective MC1010 
set gates. The Q outputs of the counting flip flops are connected 
to the clock Cd input of the following flip flop. G d is obtained by 
tying a J and K input together; 1C1013 flip flops change state when 
a positive transition occurs at a Cd input. The input to the first 
counting flip flop is through a MC1004 OR gate to limit pickup which
 
arises due to the short coaxial cable connection. The counter begins
 
counting when input pulses appear. Patching must be done in the LDPB
 
to prevent counting until desired.
 
28 
The "S" pulse is obtained by gating the Q outputs of the four 
most significant bits of the counter with an MC004 OR gate. These 
outputs all go to "0" 64 counts before all the Q outputs are "0"s. 
When the counter is full (Qoutputs all "0") the next pulse causes all 
the outputs to go to 'ls. This causes a positive transition at a 
and K input of the MC1013 flip flop used to generate "S ". ThisD 
flip flop was previously set to a "" (Q output) when the counter was 
cleared. The positive transition at the J-K input causes the output 
to go to a "0". The K input remains at a "1" while the J input goes 
to a "0" 32 input pulses later and back to a "1" 32 pulses after that. 
When the K input is a "" and a positive transition occurs at the J 
input the flip flop output goes to a "l" until another positive 
transition occurs simultaneously at a S-K input. Before that happens, 
the counter would usually be reloaded and another counting run begun.
 
Overload Light Reset Logic
 
A transistor switch was designed to provide power to the
 
LOCUST overload lights. Since the lights latch on with SCRs when an
 
overload occurs (Conant, 1968) it is only necessary to remove power
 
from the latching circuit for 100 psec to turn the SCRs off. The
 
switching circuit is shown in Fig. 16. The control input (reset) to
 
the switch is provided by either a patched negative transition in the
 
LDPB or from the LOCUST mode-control switches.
 
A detector circuit is used to provide a YI4CL output whenever
 
an overload occurs, i.e.,when an SCR anode voltage goes to 1 v. This
 
MODE CONTROL 
INPUT 
a 
i 
+15v 
68K 
1 0 
+28v 
LDPB ( PATCHBAY RESET INPUT) IIK K 1 : 20 ( 
LDPK,w 
5o 2K [O CC---
OV 
I ALL RESISTORS ARENOTEDO I/2W,iO/o UNLESS OTHERWISE 
2K -TLIGHTS 
IO 
I 
Fig. 36 overload Ltght ulic 
30
 
occurs during an overload or when the transistor switch is off. The
 
detector circuit is also shown in Fig. 16.
 
An overload output in the LDPB indicates with a MCL "1
 
level whenever an overload occurs. The anode voltage detector output
 
is gated with the reset input, and the result is used to set an
 
MC1013 flip flop. The flip flop is reset with the overload reset
 
input. The flip flop output in the LOCUST digital patchbay may be
 
patched to one of the free flags to notify the PDP-9 of a LOCUST
 
overload.
 
The MC1024 gates are in a single IC located on a card above
 
the LDPB. All other logic is located on a card mounted behind the
 
overload lights above the analog patchbay. There is only a single IC
 
for each type of logic device used. The twisted pair connected to the
 
NCI013 flip flop goes to the DEC logic where it connects with a
 
twisted pair in the main trunk cable. This occurs on the output of
 
D/M E26(S,R). 
PDP-9 Internal Signals 
The PDP-9 internal signals, 10 RUN, ENABLE, 10 SYNC, and 10 
POWER CLEAR, are converted to MECL levels and trunked to the LOCUST
 
digital patchbay using the standard MECL trunking scheme.
 
Free IOT Pulses
 
The IOT pulses from a device selector are gated with subdevice
 
bit 1 and converted to 1 wsec pulses using W640 pulse converters. They
 
31 
are converted to MECL levels and trunked to the LOCUST digital 
patchbay. The wiring for this logic is not shown. 
CHAPTER-III
 
PATCHBAY AND TOT INSTRUCTIONS
 
This section describes the operation of the LOCUST/PDP-9
 
interface. The linkage terminations in the LOCUST digital patchbay
 
and data-channel patchbay are discussed, and the associated PDP-9
 
input/output transfer instructions are given.
 
Patchbay points for the hybrid linkage are grouped in three
 
columns in the LOCUST digital patchbay as follows:
 
1. 	ADC control inputs
 
2. 	DAC buffer-to-device transfer signals
 
3. 	Patchable flags
 
4. 	Data-bus read-in gates (used mainly to transmit
 
status logic signal)
 
5. 	Six bit control register (receive digital control
 
signals)
 
6. 	PDP-9 preset counters (used mainly as "alarm clocks")
 
7. 	Oscilloscope trunks for digital signals
 
8. 	Control signal trunks for data-channel interface
 
9. 	Overload signal
 
10. 	 PDP-9 generated signals (clocks)
 
11. 	 lOT timing and logic signals from the PDP-9 
32 
Interface terminations in the LOCUST digital patehbay are shonm in
 
Fig. 17. Interface terminations in the data-channel patchbay are
 
shown in Fig. 18.
 
Linkage Patching
 
Patchable Flags
 
This group contains two flip flops connected to the I/O bus 
PI and Skip Request lines. A flag is UP when a MECL "I" is applied 
to its input in the LOCUST digital patchbay. Both flags may be 
tested with IOT instructions. They may be cleared by the CAF (clear 
all flags) command, the I/O POWER CLEAR signal, by the flag input 
going to a "0", or a programmable IOT pulse. The patchable flags 
can be used to interrupt the PDP-9 for conditions such as amplifier 
overload or a level change at a comparator output. 
Analog-to-Digital Converters
 
The analog patchbay points for the converters are located to
 
the left of the oscilloscope inputs. Proper patching is indicated in
 
Fig. 19. Each ADC requires a LOCUST analog integrator/track-hold unit
 
used for voltage-to-time conversion and two digital control signals
 
from the digital patchbay, as shown. The analog input is patched to a
 
TRACK input. Thus, the ADC performs its own sampling operation at the
 
time the digital control signal goes to a "1".
 
Multiplying Digital-to-Analog Converters
 
Proper patching for a multiplying digital-to-analog converter
 
is indicated in Fig. 20. Each MDAC requires an operational amplifier
 
34 
LOCUST DIGITAL. PATCHBAY 
0 OVERLOAD RESET 
20 
30 
FFLO FREE FLAGS) 
FFL I 
4c) 
50 
60 
SPARE 
SPARE 
SPARE 
70 
a 0 
SPARE 
R G 0 
90 
IO 
RG*i 
RG2 
READ INl 
GATES 
110 
120 
130 
140 
ISO 
160 
RG3 
RG4 
RG5 
SPARE 
SPARE 
SPARE 
17O D/A TRANS I D/A TRANSFER 
180 D/A TRANS 2 INPUTS 
A/D CONTROL 
A/D 
I0 
20 
CONTROL 
REGISTER 
0 CR 0 
0 CRI 
"50 
200 
2Il 
220 
D/A TRANS 3 
b/A TRANS 4 
SPARE 
SPARE 
30 
4 
0 
0 
CR2 
CR3 
230 
240 
SPARE 
SPARE 
TRUNK I 0 0 CR4 250 SPARE 
TRUNKZ 
TRUNK 3 
TRUNK 4 
0 
0 
0 
0 
0j 
0 
CR5 
IN 
S 
PRESET 
COUNTERS 
260 
270 
"00 
lOT I 
lOT 2 
IOT4 
FPEE lOT's 
AND CLOCK 
SIGNALS 
DIGITAL DRIVER I 0 0 Sd 290 PWR CLR 
DIGITAL DRIVUR 2 
DIGITAL DRIVER3 
DIGITAL DRIVER4 
0 
0 
0 
z0 
0 
0 
IN 
8 
Sd 
300 
320 
I SYNC 
t19O RUN 
ENABLE 
Fig. 17 Interface Patching in the LOCUST Dgital Patchbay 
35 
0 
o I/O LINES 
0 
I 'o 
420 
50 
6 
70 
D 90 
zo 
z 
-[0O 
(9 
12 
zo 1 % 
DEC/MECL- ~TRNS 10Z I 4 
i II 
3 40 1 1% 
Fig.~~~~~~ 
0reat0 0 
nth 
D 7 
[4ItraePthnaacanl ha 
36 
AID CONVERTER INPUT
 
D 9 IF 
0 0 .IM0 
AID) 1 ( Q0 Q j 
Is 
,A/D O 0---
0 QOO 
A/04 GOk. 0Q O 
ASSOCIATED ANALOG PATCHFIELDS 
DIGITAL. COUIMAND o0QINPUT 
15 71-0/f0 oQ 
Q5ICCo0 
O' 3Q 'OQ , 
0" 0 _0 ,0
0I 
ASSOCIATED DIGITAL PATCIILDS 
Fig. 19 A/D Converter Patching
 
37 
INPUT 
0 
DA / MU 
GQ 
0 
TO "G"OF 
'AN AMPLIFIER 
-X xQ o0' TO OUTPUT-"-"OF THE 
AMPLiFIER 
Fig. 20 MDAC Patching 
38 
without feedback. The MDAC buffer-to-device transfer inputs are
 
located in the digital patchbay. A positive transition of at least
 
400 nsec applied to one of these inputs causes the transfer of the
 
corresponding MDAC buffer register to its device register. These
 
individual transfers can also be made under program control by the
 
PDP-9.
 
Linkage Control Switches
 
The PI, SKIP, and ADC FLAGS toggle switches are located
 
on the front panel containing the data-channel patchbay. The
 
Program Interrupt switch connects all flags in LOCUST to the
 
PDP-9 (PI) Program Interrupt line. The Skip switch connects LOCUST
 
sense signals to the Skip Request line. The ADC FLAGS switch
 
connects the ADC flags to the interface logic. For most interface
 
operations all three switches would be ON. When operating LOCUST
 
independently of the PDP-9, the PI and SKIP switches should be off
 
to eliminate spurious signals on the interrupt and skip request
 
lines.
 
Data-bus Read-in Gates
 
This group consists of inputs to 6 read-in gates which
 
transfer data into the AC upon command. These inputs output as DEC
 
levels in the data channel patchbay, where they must be patched to the
 
desired accumulator lines. A MECL "1' in the LOCUST digital patchbay
 
is read into the AC as a "I". To use the read-in gates patching
 
39 
must be done in the LOCUST digital patchbay and in the data-channel
 
patchbay, and the proper 1OT signal must be given. The read-in gates
 
are used for reading logic or "discrete" information such as analog
 
computer states, and patchbay logic level into the PDP-9.
 
Six-bit Control Register 
This double-buffered register is loaded with AC bits 0-5. A 
"1" in the AC is outputed as a MECL "1" in the LOCUST digital 
patchbay upon proper lOT command. The I/0 POWER CLEAR signal clears 
the control register. 
The control register allows the PDP-9, among other things,
 
to control LOCUST'S mode. By patching between the control register
 
output and the external mode control inputs in the LDPB, the INITIAL
 
RESET, COMPUTE, or SINGLE RUN states of LOCUST may be selected. Mode 
control of individual integrators and control of patchbay flip flops
 
may also be exercised.
 
Preset Counters
 
Two ten-bit counters located in LOCUST are loaded by the
 
PDP-9. Each counter has an input, an output (S), and a delayed
 
output (SD) connection in the patchbay. AC bits 0-9 are loaded into
 
the counters upon proper command. A timing diagram is shown in
 
Fig. 12.
 
Oscilloscope Trunks
 
These trunks input in the LDPB and output with BNC connectors
 
near the oscilloscope in LOCUST. The trunks are non-inverting.
 
40 
Data-Channel-LOCUST Digital Patchbay Trunks
 
The inputs to these trunks are located in the data-channel 
patchbay. The ouputs, in the LOCUST digital patchbay, give a 
MECL "1" when the DEC input level is ground. 
Overload Signal
 
The overload output remains at a "1" as long as any of the 
LOCUST amplifiers is overloaded. This output may be connected to
 
a patchable flag to notify the PDP-9 of any overload condition.
 
PDP-9 Generated Signals
 
This group consists of four PDP-9 internal signals available 
on the I/0 bus; I/0 POWER CLEAR, I/0 SYNC, I/0 RUN, and ENABLE. The 
I/O RUN signal is present only if both I/0 cables are plugged in. 
Free 10T Signals 
This group consists of the outputs of a special WI03 device 
selector. The positive going lOT1, 1OT2, and'IOT4 signals are
 
available in the LOCUST digital patchbay. These pulses may be used
 
for many purposes, such as setting or resetting flip flops,
 
initiating single runs, or clearing counters. Another use would
 
be the resetting of LOCUST's overload lights.
 
41 
Input/Output Transfer Instructions 
This section defines the machine instructions and mnemonics
 
which operate the ADCs, MDACs, and other devices which make up the
 
LOCUST-PDP-9 interface. All linkage commands are defined here. A
 
summary of linkage instructions is presented in Tablet at the end of
 
this section.
 
Patchable PI Flags 
Two flag inputs are located in the linkage section of the 
LOCUST digital patchbay. A NECL "" patched to either input causes 
a program interrupt. The PDP-9 uses a chain of skip instructions to 
determine the cause of the interrupt. When the interrupting device
 
has been determined a service subroutine is executed. The patchable
 
flags are tested by skip instructions.
 
NEMONIC OCTAL CODE OPERATION EXECUTED
 
LSFI 701541 The next instruction is skipped
 
if Free Flag #1 is set.
 
LSF2 701521 The next instruction is skipped
 
if Free Flag #2 is set.
 
LCFl 703444 Clear Free Flag #1
 
LCF2 703544 Clear Free Flag #2
 
Analog-to-Digital Converters
 
The ADC flags are tested with PDP-9 skip instructions. The
 
converter data is read into the AC and the device flag cleared with
 
an IOT2 instruction.
 
42 
MNEMONIC OCTAL CODE OPERATION EXECUTED 
LADIS 703441 The nekt PDP-9 instruction is skipped 
if ADC #1 flag is set. 
LADiR 703452 Clear the AC and load AC 0-10 with 
the contents of ADC #1 register. 
Clear ADC #1 flag. 
LAD2S 703541 The next PDP-9 instruction is 
skipped if ADC #2 flag is set. 
LAD2R 703552 Clear the AC and load AC 0-10 with 
the contents of ADC #2 register. 
Clear ADC #2 flag. 
LAD3S 703641 The next PDP-9 instruction is skipped 
if ADC #3 flag is set. 
LAD3R 703652 Clear the AC and load AC 0-10 with 
the contents of ADC #3 register. 
Clear ADC #3 flag. 
LAD4S 703741 The next PDP-9 instruction is skipped 
if ADC #4 flag is set. 
LAD4R 703752 Clear the AC and load AC 0-10 
with the contents of ADC #4 
register. Clear ADC #4 flag. 
Multiplying Digital to Analog Converters
 
Data on the I/0 bus data lines is strobed into MDAC buffer
 
registers by the following instructions.
 
IMEMONIC OCTAL CODE OPERATION EXECUTED
 
LDA1C 703421 Clear MDAC #1 buffer register.
 
LDAIL 703422 Load MDAC #1 buffer register with
 
AC 0-11.
 
LDA2C 703521 Clear MDAC #2 buffer register.
 
LDA2L 703522 	 Load MDAC #2 buffer register
 
with AC 0-11.
 
43
 
MEMONIC OCTAL CODE 
LDA3C 703621 
LDA3L 703622 
LDA4C 703721 
LDA4L 703722 
OPERATION EXECUTED
 
Clear MDAC 13 buffer register.
 
Load MDAC #3 buffer register
 
with AC 0-11.
 
Clear MDAC #4 buffer register.
 
Load ADAC #4 buffer register
 
with AC 0-i.
 
Data in a buffer register is jam-transferred into its device 
register by either an lOT instruction or by a MECL "1" patched into 
the proper D/A TRANS input in the LOCUST digital patchbay. The 
following instructions are used in buffer-to-device register 
transfers. 
MNEMONIC OCTAL CODE 
LDAIX 703424 
LDA2X 703524 

LDA3X 703624 

LDA4X 703724 

I 

Data-bus Read-in Gates
 
OPERATION EXECUTED
 
Transfer the contents of
 
L4DAC #1 buffer to device register.
 
Transfer the contents of
 
MDAC #2 buffer to device register.
 
Transfer the contents of
 
MDAC #3 buffer to device register.
 
Transfer the contents of
 
MDAC #4 buffer to device register.
 
The six read-in gate inputs in the LOCUST digital patchbay
 
have DEC outputs in the data channel patchbay. These outputs must 
be connected to DEC gate inputs corresponding to the desired
 
accumulator bits. A read request must also be patched. The data
 
44 
is read into the AC when the proper lOT instruction is given. A "1"
 
patched in the LOCUST digital patchbay is transferred into the AC as
 
a 2'11. 
IMEMONIC OCTAL CODE 	 OPERATION EXECUTED
 
LTR1 702212 	 Clear the AC and load AC bits
 
selected in data channel patchbay
 
with logic levels patched to
 
read-in gates.
 
Six-bit Control Register
 
Data from AC 0-5 is transferred to the control register
 
buffer and then jam-transferred to the output register. A "l" 
in the AC is a MECL "l" at the proper output in the LDPB. The output 
register may be cleared with I/O POWER CLEAR. The following TOT
 
instructions are used for the control register.
 
MNEMONIC OCTAL CODE OPERATION EXECUTED
 
LCRC 701641 Clear buffer register.
 
LCRL 701642 Load buffer with AC 0-5.
 
SLCRX 701644 	 Jam-transfer buffer contents
 
into output register.
 
.Preset Counters
 
The 10-bit preset binary counters are used to count LOCUST­
generated pulses and issue two control pulses. The counter is
 
loaded with the complement of one less than the number of pulses to 
be counted. The "S" output pulse is 64 input pulse widths wide and 
is a negative MECL pulse, whose positive transition occurs at the
 
45 
end of a counting run (See Fig. 12). The "SD " pulse is the same 
width as the "S" pulse but its positive transition occurs 64 input 
pulse widths after the end of a counting run. The counters are 
loaded from the PDP-9 and start counting as soon as input pulses 
occur. For "S " to be issued the input pulses must continue to 
D 
occur for at least 64 pulses after the "S" pulse has been issued. 
There are two preset counters in LOCUST that are loaded from the 
PDP-9. The following instructions are used. 
MNEMONIC OCTAL CODE OPERATION EXECUTED 
LCN1C 701542 Clear counter #1 
LCNlL 701544 Load AC 0-9 into counter #1 
LCN2C 701522 Clear counter #2 
LCN2L 701524 Load AC 0-9 into counter #2 
Free lOT Signals
 
Three pulses are available from the PDP-9 which are outputed 
in the LDPB. The following instructions are used. 
MNEMONIC OCTAL CODE OPERATION EXECUTED 
LPI 701621 A 1 psec pulse is generated at 
event time 1.
 
LP2 701622 A 1 )sec pulse is generated at
 
event time 2.
 
LP4 701624 A 1 psec pulse is generated at
 
event time 3.
 
46 
TABLE 1 
TOT INSTRUCTIONS 
MNEMONIC OCTAL CODE OPERATION EXECUTED 
LADIS 703441 Skip if ADC #1 flag is set. 
LADIR 703452 Read ADC #1 and clear flag. 
LAD2S 703541 Skip if ADC #2 flag is set. 
LAD2R 703552 Read ADC #2 and clear flag. 
LA3S 703641 Skip if ADC #3 flag is set. 
LAD3R 703652 Read ADC #3 and clear flag. 
LAD4S 703741 Skip if ADC #4 flag is set. 
LAD4R 703752 Read ADC #4 and clear flag. 
LDA1C 703421 Clear MDAC #1 buffer register. 
LDA1L 703422 Load MDAC #1 buffer register. 
LDAlX 703424 Load MDAC #1 device register. 
LDA2C 703521 Clear MDAC #2 buffer register. 
LDA2L 703522 Load MDAC #2 buffer register. 
LDA2X 703524 Load MDAC #2 device register. 
,LDA3C 703621 Clear MDAC #3 buffer register. 
LDA3L 703622 Load MAC #3 buffer register. 
LDA3X 703624 Load MDAC #3 device register. 
LDA4C 703721 Clear MDAC #4 buffer register. 
LDA4L 703722 Load MDAC #4 buffer register. 
LDA4X 703724 Load MDAC #4 device register. 
47 
TABLE I continued
 
MNEMONIC OCTAL CODE OPERATION EXECUTED 
LSFI 701541 Skip if Free Flag #1 is set. 
LCF1 703444 Clear Free Flag #i. 
LSF2 701521 Skip if Free Flag #2 is set. 
LCF2 703544 Clear Free Flag #2. 
LCNIC 701542 Clear counter #1. 
LCNlL 701544 Load counter #1. 
LCN2C 701522 Clear counter #2. 
LCN2L 701524 Load counter #2. 
LCRC 701641 Clear control register buffer. 
LCRL 701642 Load control register buffer. 
LCRX 701644 Load control register output register. 
LPI, 701621 Issue IOTI. 
LP2 701622 Issue 1OT2. 
LP4 701624 Issue 1OT4. 
LTRl 702212 Read LOCUST read-in gates. 
CHAPTER-IV
 
APPLICATION
 
The LOCUST / PDP-9 interface operation was demonstrated using
 
a program written by Emmett Pearse O'Grady (O'Grady, 1969). This
 
section is based on his dissertation and serves only to demonstrate
 
hardware operations, not a novel program.
 
Amplitude Distribution Measurement Example
 
In many hybrid-computer applications we compute statistics
 
of a random process (Korn, 1966). Averaging, correlation'studies,
 
and amplitude distribution analysis are typical examples. This section 
describes a program used to study the amplitude distribution of a 
voltage waveform available on the analog-computer patchbay. Our 
solution illustrates the use and programming of the program interrupt
 
facility and demonstrates an interesting real-time display technique
 
made possible by the program interrupt.
 
Statement of Problem
 
The problem can be stated as follows: given a voltage x(t) 
on the analog-computer patchbay with amplitude in the range jx(t)j < 10 
volts, compute and display the amplitude distribution of x(t). The 
amplitude distribution curve is a histogram with equal-width class
 
intervals which represent the voltage range -10 volts < x < 10 volts.
 
48 
49 
A suitably scaled amplitude distribution curve is an estimate of the
 
probability density function of x(t).
 
Method of Solution
 
This problem involves both computing and displaying the
 
amplitude distribution curve. The curve is computed in the form of
 
a histogram with 4008,equal-width class intervals; the column heights
 
are stored in an array (4008 memory locations) labeled HISTO. The
 
histogram is computed as follows:
 
1. 	An analog-computer track/hold circuit samples
 
x(t),and holds it for A/D conversion.
 
2. 	The sampled voltage is converted to digital form
 
and read into AC 0-10, using the program interrupt
 
facility. The eight most significant bits
 
establish the class interval within which the
 
sample falls and, when added to the address of
 
the first memory location in the array HISTO,
 
specify the address of the memory location holding 
the column height of that class interval. 
3. 	The column height specified by the sample's class
 
interval is incremented and step (1)is repeated.
 
The sampling process is repeated until the number of samples falling 
in any one interval equals 3777P the largest number that can be 
displayed by the MDACs. The curve is displayed with the aid of two 
NDACs as an X-Y oscilloscope plot. The X-NDAC output voltage sweeps 
through 4008 states corresponding to the class intervals; the Y-NDAC 
50 
output voltage is proportional to the number of events falling
 
within each interval. The X and Y UDACs are updated simultaneously.
 
A large percentage of the time required to compute the
 
histogram is taken up by A/D conversions during which the digital
 
computer is idle. By taking advantage of the PDP-9 program
 
interrupt facility, our program uses this idle time to provide a
 
dynamic display of the histogram as it builds up. The main program
 
,is a display routine which provides a complete display of the
 
histogram approximately every 6.5 msec. This program is interrupted
 
whenever the A/D converter completes a conversion, approximately
 
every 100 Psec depending on ADC word length. Word length should be 
8-bits or longer for best display. The total number of samples 
required depends on the amplitude distribution under study. 
Figure 21 presents a flow chart of the solution procedure
 
Table 2 lists the PDP-9 program, and Fig. 22 illustrates analog­
computer patching.
 
Results
 
The method of solution described above was evaluated by
 
obtaining amplitude-distribution curves for a square wave, a sine
 
wave, a triangle wave, and for Gaussian noise. Figures 23 to 26
 
,present typical curves obtained in each case; these curves agree in
 
form with expected results.
 
51 
MAIN PROGRA: INTERRUPT ROUTINE 
DISPLAY ROUTINE 
INTERrUPT 
INITIALIZATION SAVE AC
 
READ SAMPLE 
INITIATE FIRST VALUE X FRON
 
A/D CONVERSION THE ADC
 
X = ADDRESS OF
 
CLASS INTERVPL 
INCREMENT Y, 
TIE NUM-BER IN 
ILOCATION X
 
DISPLAY X AND
 
RELATED Y;

INCREMENT X 
VYESNO 
NO -4 NO 
INITIATE 
A/D CONVERSION
 
RESTORE AC; 
RETURN TO 
MAIN PROGRA!N 
Fig. 21 Flow Chart for Amplitude-distribution Example
 
52 
TABLE 2 PISTOGRAN
 
/TI-{q PROGRAM IS USED TO GENERATE A 
/HIqTOGRM. DATA IS OBTAINED FROM THE 
/ADC USING THE PROGRAM INTERRUPT FACI­
/LITY THE PROGRAM IS A MODIFICATION 
/OF THE PROGRAM IN 0 GRADY'S THESIS
 
ITO RUN ON LOCUST.
 
/
 
RESTR NOP 	 /ALLOWS RESTART.
 
/ 
/INITIALIZATION ROUTINE 
/ 
SETUP CAL 0 /SET UP HANDLER TO 
16 /SERVICE ADC#1 THRU 
7034AI1 /PROGRAM INTERRUPT. 
A2 DFLG 
DBK 
LAC (JMP TAGI) /ALLOWS RESTART TO
 
DAC RESTR /JMP AROUND SETUP.
 /
 
TAGI LAC (400000 /CLEAR,LOAD,AND
 
7016A7 	 /TRANSFER CONTROL 
/REGISTER BIT 0 
/TO PLACE A I IN 
/EXT. CP TO START
 
/COMPUTE PERIOD.
 
/
 
793452 	 /CLEAR ADC#I FLAG. 
/
 
LAC (DZM HISTO) /CLEAR THE ARRAY
 
DAC CLEAR /LABELED "HISTO."
 
LAW -400
 
DAC COUNT#
 
CLEAR XX
 
q71 CLEAR
 
IqZ COUNT
 
JMP CLEAR
/
 
ION 	 /TURN PION.
 /
 
/DISPLAY ROUTINE
 
/
 
BEGIN DZM X# /PREPARE FOR 
LAC (LAC HISTO)/DISPLAY OF BIRST 
DAC YLOC /COLUMN OF HISTOG. 
YLOC XX /GET VALUE OF Y. 
793623 /L-04D Y (MDAC#2) 
/BUFFER REGISTER. 
ISZ YLOC /COMPUTE NEXT YLOC. 
53 
LAC X 

703723 

70372A 

70362A 

TAD INCRX 
qAD XMAX 
JMP BEGIN 
DAC X 

imp YLOC 

/ 
/INTERRUPT ROUTINE
/ 
A2DFLG fAC SAVEAC# 

703452 
XOR SIGN 

CLL 
LRS 12 

TAD (HISTO) 
DAC TEMP 

LAC* TEMP
 
TAD I NCRY 
DAC* TEMP
 
SAD YMAX 

JMP .+7
 
LAC* (9) 
1)AC RETURN# 
LAC SAVEAC 
ION 
DB R 
JMPt RETURN 
LAC (0 

701647 

iMP .-10 

/ 
/CONSTANTS/ 
HISTO .BLOCK 400 

TABLE 2 continued
 
/GET VALUE OF X.
 
/LOAD X (MDAC#3)
 
/PUFFER REGISTER. 
/TRANSFER X. 
/TRANSFER Y.
 
/COMPUTE NEXT X. 
/CHECK FOR X(MAX).
 
/RFTT4ALIZE
 
/STORE NEXT X.
 
/START DISPLAY OF
 
/NEXT COLUMN OF
 
/HISTOGRAM.
 
/SAVE AC.
 
/READ ADC#1.
 
/ORDER THE COLUMNS
 
/(- TO +).
 
/DETERMINE "HICH
 
/COLUMN F HISTOG. 
/TO INCREMENT. 
/INCREMENT IT. 
/CHECK FOR OVERFLOW 
/GET RETURN LOG.
 
/RESTORE AC.
 
/TURN PI BACKON.
 
/RETURN TO MAIN PGM
 
/CLEAR, LOAD, AND
 
/TRANSFER .0 THRU
 
/CONT. PEG. BIT 0 
/TO BE COMPLEMENTED
 
/ANO USED TO PUT
 
/LOCUST IN INITIAL
 
/RESET (EXT.IR) . 
/RESERVE 400(OCTAL)
 
/LOCATIONS FOR
 
54 
TABLE 2 continued 
TFMP 
INC Y 
YMaX 
TNCRX 
XMAX 
SIGN 
0 
100 
377700 
1 0 
AOVVVO 
.40000 
.END RESTR 
55 
x(t) 
TO ADC 
+ 10 V TO SCOPE 
M[DAC 1 Y INPUT
 
FROM 
DEVICE
 
REGISTERS
 
+ 10 v_ 
 M 2TO SCOPE
 
v
-
10 
Fig. 22 Analog Patching for Amplitude Distribution Problem 
56 
"
 Vertical scale: 2 volts/cm N 
Horizontal scale: I volt/cm 
Fig. 23 Amplitude Distribution of Square Wave a 
iv-

Vertical scale: 2 volts/cm
 
Horizontal scale: 1 volt/cm
 
Fig. 24 Amplitude Distribution of Sine Wave
 
57 
I
 
Vertical scale: 2 volts/cm A,
 
Horizontal scale: 1 volt/cm
 
Fig. 25 Amplitude Distribution of Triangle Wave
 
t 
-t 
Vertical scale: 2 volts/cm
 
Horizontal scale: 1 volt/cm
 
Fig. 26 Amplitude Distribution of Gaussian Noise
 
CILAPTER V 
CONCLUSIONS
 
The design and test of the LOCUST/PDP-9 interface was coirpleted 
with satisfying results. An application problem was run which demon­
strated some of the data transfer and control capability of the inter­
face. Noise measurements were made and it was found that the noise
 
level in the analog patchbay, measured at the output of an unused
 
amplifier, was not significantly increased by the addition of the
 
interface. The peak noise level remains less than 5 mv.
 
It has thus been shown that it is possible to interconnect a
 
digital computer with a high ambient noise level to a machine that
 
uses fast integrated circuit logic operating with small logic level
 
swing in a low noise environment. This is encouraging and suggests
 
new opportunities of system additions to the PDP-9. Already a float­
ing point arithmetic unit, built with MECL II, is being designed for
 
the PDP-9.
 
In the process of designing and building an interface many
 
desirable additional features become apparent. A faster analog-to­
digital converter would be a welcome addition to the interface. Auto­
matic Priority Interrupt (API) would also make the interface more 
powerful. A data channel interface, presently being built, will trans­
fer data directly to and from the core memory of the PDP-9. This will
 
greatly increase data transfer speed and save programming effort and
 
storage. Future users will recognize needs and solutions to improve
 
this hybrid combination.
 
58 
REFERENCES 
Conant, B.K. "The Design of a New Solid State Electronic Iterative
 
Differential Analyzer Making Maximum Use of Integrated
 
Circuits," Ph.D. Dissertation, Department of Electrical
 
Engineering, University of Arizona, 1968.
 
Eddington, D.C. "The Design of a Multiplying Digital-to-Analog
 
Converter for Wideband Hybrid Computation," M.S. Thesis,
 
Department of Electrical Engineering, University of Arizona,
 
1969.
 
Coltz, J.R. "An Economical Analog-to-Digital Converter System for
 
Hybrid Computation," ACL Memo No. 147, University of
 
Arizona, May, 1968.
 
Korn, G.A. Random-Process Simulation and Measurements, McGraw-Hill
 
Book Company, New York, 1966.
 
Korn, G.A., and T.M. Korn. Electronic Analog and Hybrid Computers,
 
McGraw-Hill Book Company, New York, 1964.
 
Logic Handbook. Digital Equipment Corporation, Maynard, Massachusetts,
 
1968.
 
O'Grady, E.P. "Design, Test, and Application of a Hybrid Computer
 
Interface," Ph.D. Dissertation, Department of Electrical
 
Engineering, 1969.
 
PDP-9 Interface Manual, Digital Equipment Corporation, Maynard,
 
Massachusetts, 1968.
 
PDP-9 User Handbook. Digital Equipment Corporation, Maynard,
 
Massachusetts, 1968.
 
University of Arizona, Department of Electrical Engineering, CSRL
 
Memo No. 215, 1969.
 
59
 
