COMPUTER, GUN DIRECTION M18 (FADAC) APPLICATIONS MANUAL
by
THOMAS J. PRICE

Distribution of this document is unlimited.


MAY 1967

# UNITED STATES ARMY FRANKFORD ARSENAL PHILADELPHIA, PA. 

[^0]
## COMPUTER, GUN DIRECTION M18 (FADAC)

 APPLICATIONS MANUALby

Thomas J. Price

Distribution of this document is unlimited.

Fire Coritrol Development and Engineering Laboratories FRANKFORD ARSENAL
Philadelphia, Pa. 19137
May 1967


#### Abstract

This FADAC Applications Manual is a summary document which provides information required by system engineers for integrating the M18 (FADAC) with peripheral devices and equipment.

Brief introductory descriptions of the M18 characteristics and command structure are provided; whereas the input-output capabilities are discussed in detail and related logic terms are fully defined.

Descriptions of Interfacing with representative input-output devices are provided to indicate the M18 input-output operations. A brief discussion of system development programs that utilize the M18 are also provided, as examples, to further delineate the inherent input-output flexibility of the M18 for systems integration.


## TABLE OF CONTENTS

Page
ABSTRACT ..... ii
I. INTRODUCTION ..... 1
A. General ..... 1
B. Purpose and Scope ..... 1
C. Manual Organization ..... 1
II. COMPUTER CHARACTERISTICS ..... 2
A. General. ..... 2
B. Functional Description ..... 5
C. Command Structure ..... 18
III. CONTROL PANEL ..... 35
A. General ..... 35
B. Functional Description ..... 37
Operating Controls and Indicators ..... 37
C. Control Panel Interfacing ..... 41

1. Power Control ..... 41
2. Set-Up Buttons. ..... 41
3. Keyboard ..... 44
4. Mechanical Reader ..... 44
5. Input Matrix ..... 50
6. NIXIE Readout ..... 53

## TABLE OF CONTENTS (Cont'd)

Page
IV. EXTERNAL INPUT-OUTPUT INTERFACE DESCRIPTION ..... 61
A. General ..... 61
B. Detailed Input Description ..... 63

1. Input Terms to GDC, M18 ..... 63
2. Input Circuitry. ..... 69
a. Input Datalines ..... 69
b. Strobe ..... 69
c. PS1 Pulse Stretcher. ..... 71
d. Neon Drivers ..... 71
e. Discrete Input (F) Lines ..... 77
C. Detailed Output Description ..... 78
3. Output Terms ..... 78
4. Output Circuitry ..... 78
a. Output Datalines ..... 78
b. Strobe - Feedback ..... 83
c. Remote Error Reset ..... 85
d. Teletype Output. ..... 87
e. Amplifiers and Inverters ..... 87
V. TYPICAL INPUT-OUTPUT DEVICES ..... 88
A. Memory Loading Unit (MLU) ..... 88
B. Digitronics Perforated Tape Reader ..... 94
C. CTC Typewriter ..... 99
D. Teletypewriter ..... 101
E. LP-2-150 Paper Tape Punch ..... 101

## TABLE OF CONTENTS (Cont'd)

Page
V. (Cont'd)
F. Magnetic Tape Bulk Memory ..... 102
G. FADAC to FADAC . ..... 104
VI. SPECIALIZED APPLICATIONS ..... 104
A. General ..... 104
B. Automatic Calibration - Laboratory Evaluation Unit (Auto-Cal) ..... 108

1. Buffer Translator ..... 108
2. Computer Input Interface ..... 110
3. Remote Program Addressing ..... 111
C. MAIDS MARK III ..... 111
4. Input-Output Buffer (IOB) ..... 114
5. Computer Measurement Timing ..... 118
6. External Device Integration . ..... 118
DOCUMENTATION LISTING ..... 120
LIST OF ILLUSTRATIONS
Figure Title
1 Computer, Gun Direction M18 (FADAC) ..... 3
2 Computer Block Diagram ..... 6
3 Memory Contents ..... 7
4 Computer Word Format ..... 8

## LIST OF ILLUSTRATIONS (Cont'd)

Figure Title Page
5 Numeric Input Codes ..... 12
6 Alpha-numeric Teletype Code ..... 14
7 Alpha-numeric FIELDATA Code ..... 15
8 Control Panel - Detail View ..... 36
9
Control Panel Functions and Connector Assignments ..... 37
10
Pl Interface Schematic ..... 42
11
"Operation" Switches, Computer Interface ..... 43
12
P2 Interface Schematic ..... 45
13
Keyboard Functional Diagram ..... 46
14
Keyboard Timing Sequence ..... 47
15
Mechanical Reader Functional Description ..... 4816
Mechanical Reader Timing Sequence ..... 49
17
P5 Interface Schematic ..... 51
18
Input Matrix Schematic ..... 52
19
P6 Interface Schematic ..... 54
20 NIXIE Display Block Diagram ..... 55
21
NIXIE Anode Driver Schematic ..... 56
22 NIXIE Cathode Driver Schematic ..... 56
23 NIXIE Readout Schematic. ..... 57
24 NIXIE Display Arrangement ..... 59

## LIST OF ILLUSTRATIONS (Cont'd)

Figure Title Page
25
Cathode Driver (CD) and Anode Driver (AD) Connections to NIXIE Display ..... 60
26
Input Amplifier ..... 61
27 Output Amplifier ..... 62
28 Inverter ..... 62
29 Schematic of Input Connector, J17 ..... 67
30 Input Line Timing ..... 69
31
Inputting to FADAC ..... 70
32 Steady State Strobe ..... 72
33
Mechanical Contact Strobe ..... 73
34 FIELDATA Strobe Timing ..... 74
35
PS1, PS2 Pulse Stretcher. ..... 75
36
Neon Drivers ..... 76
37
FADAC Bit Positions ..... 78
38
Schematic of Output Connector, J 10 ..... 81
39 FADAC Output Timing ..... 83
40 FADAC to Output Device Feedback. ..... 84
41 FIELDATA Strobe Feedback ..... 85
42 Steady State Feedback ..... 86
43
Switch Contact Feedback ..... 86

## LIST OF ILLUSTRATIONS (Cont'd)

Figure
44 Reset Button Interface . . . . . . . . . . 87
45 Teletype Output Waveform . . . . . . . . . 88
46
47 Memory Loading Unit (MLU) to FADAC Signals 90

48 MLU Timing . . . . . . . . . . . . . . . . 92
49
50 FADAC to Digitronics Reader Cabling 96

## 51

55 Tape Tub
56 FADAC - Tape Tube Interface ..... 105
57 FADAC to FADAC, FADAC Strobe ..... 106
58 FADAC to FADAC, FIELDATA Strobe ..... 107
59 Auto-Cal Systems Concept ..... 109
60 Remote Program Addressing ..... 112
61 Auto-Cal Information and Control Lines ..... 113
62 MAIDS MARK III ..... 115

## Title

## Page

87Memory Loading Unit (MLU) ..... 89
Digitronics Tape Reader ..... 95
Digitronic Tape Reader . ..... 97
SDR Simulator ..... 98
Functional Diagram of FIELDATA Printer ..... 100
"Mite" Teletypewriter ..... 102

103
Tape Tub ..... 103
IOB Block Diagram ..... 116

## I. INTRODUCTION

## A. General

The Computer, Gun Direction M18 (Field Artillery Digital Automatic Computer, FADAC) is a general purpose transistorized digital computer designed for field use. The M18 (FADAC) was designed primarily to compute firing data for artillery weapons from data inputs defining target location, weapon location, and prevailing conditions of equipment, material, and weather. The control panel has been human engineered for efficient and easily learned operator control. The markings on the control panel are those associated with the artillery weapon problem but with little or no change can be readily adapted to a wide range of applications. An input-output interface is also provided which permits the computer to commenicate with or control many types of devices.

The primary design requirements make it ideally suited for many real time applications.

## B. Purpose and Scope

The purpose of this manual is to present the technical information required by the System's Engineer for application of the FADAC, as well as the interface and function data to permit the most efficient integration of the computer into a contemplated system configuration.

The primary characteristics of the computer are listed and a brief explanation of the computer instructions is also provided. For a complete description of the programming aspects of the computer, the programming manual, FCDD-361, Volume IV, Revision I, is available.

## C. Manual Organization

This manual contains six major sections. The first section is an introduction to the M18 (FADAC) computer and also explains the purpose of this manual. Section II is directed to the M18 computer characteristics including command structure and computer operations. Section III
describes the Control Panel and detailed interfacing of the Control Panel to the main frame. Section IV is a detailed input-output inter face description of the M18 computer. Section V contains a brief description of some presently used devices providing input-output with the M18 computer. Section VI describes the M18 as it is systems configured and indicates the related input-output characteristics.

## II. COMPUTER CHARACTERISTICS

## A. General

The Computer, Gun Direction, M18 (FADAC) is shown in figure 1. Major controls and location of external connectors are shown. A brief summary of general computer characteristics is presented below:

GENERAL CHARACTERISTICS
Size: 24 inches by 14 inches by 34 inches
Weight: Approximately 210 pounds
Power: Three-phase, 4 -wire, 400 hz system; 120/208 volts, approximately 750 watts

Temperature: $-25^{\circ} \mathrm{F}$ to $125^{\circ} \mathrm{F}$ (external ambient at sea level); with rear cover installed, to $-40^{\circ} \mathrm{F}$. Automatic temperature protection is provided.

Commands: One command per word; each command contains both address of operant and address of next command.

Numbers: Straight binary for internal operations; automatic conversion to other codes for input-output; two's complement notation for negative numbers.



Word Length: Thirty-two binary digits; sign bit and 31 binary digits for absolute numerical value.

Memory Type: Magnetic Disc, 6000 rpm nominal speed of rotation. Automatic frequency and voltage protection is provided.

Storage Capacity: Sixty-four channels of 128 words each ( 8192 words) in main memory. Also provided are two 16 -word high-speed loops for rapid access, five 1 -word registers for arithmetic operations and control, and one 2 -word register for output displayinformation storage. All channels and loops have one read and one write head except the 16 -word loops which have an additional read head.

Pulse Repetition Rate: Nominal pulse repetition rate, 460 kilopulses per second.

Internal Information Flow: Serial by bit, parallel by function, allowing 12, 800 one-word execute (add, subtract, etc.) operations per second. Multiplication and division require 18 -word execute cycles.

Input: Inputs to the computer are from the manual keyboard or the mechanical tape reader on the control panel. External sources may load the computer. Typically:

1. Mechanical keyboard or mechanical reader to 30 cps .
2. Numeric devices to 600 cps .
3. Alphanumeric devices to 4000 cps .

Inputs may use 5-channel code for teletype operation or 8 -channel code for FIELDATA operation.

Output: Primary output is to the visual display (NIXIE). Signals are provided for operating external printers, magnetic tape units, and other FIELDATA or teletype equipment. Output information is in 5 -level
teletype, 2 -wire teletype, or FIELDATA codes as required. Output rate is approximately 4000 for alphanumeric and 600 for numeric.

Additional Features of the Computer:
Parity check on information transfers. Verify indicator (located on tape reader) on input in program fill mode. Gating for external support equipment to permit logic failure isolation to single printed circuit board. Marginal test circuit for preventive maintenance. Voltage transient warning indicators. Temperature warning indicators. High speed (2 bits-at-a-time) multiplication, division, and shifts. Self-checking for overflow. Standardized printed circuit boards to minimize logistic problems.

## B. Functional Description

1. General

A block diagram of the logical organization of the computer is shown in figure 2. The largest single part of the computer is the control and arithmetic logic which through means of the control panel and/or external input devices establishes various modes of reading instruction or informatior words from memory, performing all the various instructions listed in Section II, C, writing into memory and communicating with the control panel and external devices.

## 2. Summary of Functional Characteristics

2.1 Computer Word Formats and Storage Capacity - Information stored in memory contains no inherent distinction between numerical data and computer instructions. Memory outputs are interpreted in accordance with the state of computer logic elements classified as mode controls. Various word formats have been developed to relieve the operator of as many time-consuming number conversions as possible.


Figure 2. Computer Block Diagram
2.1.1 Memory Capacity - Information is stored in the computer memory in binary code - 32 bits per information word. In addition, 3 bits are used for synchronization and one bit for parity information, giving a total of 36 bits per machine word. The capacity of the memory is given in figure 3, including the storage capacity of registers normally required to perform program functions.


Figure 3. Memory Contents
2.1.2 Number Formats - In addition to the normal binary representation of numbers, other number formats are available for use by external devices.
2.1.2.1 Binary Representation - Information used by the computer as an operand is interpreted as a signed, 31 -bit, binary coded word with a fixed binary point located between the sign bit and most significant digit. Positive numbers have a zero sign bit and negative numbers a one sign bit. Negative numbers are stored and interpreted in two's complement form. Binary representation is shown in figure 4 (b) that indicates 31 bits allocated for the numerical value and the 32 nd bit for the sign designation.
sanvwhoo
NEXT INSTRUCTION

(a)

NUMERICAL QUANTITIES
NUMBER
BINARY
REPRESENTATION
OCTAL
REPRESENTATION

| 7 | 1615 | 14 | 13 | 1 | 2 | 11 | 10 | 9 | 3 | 7 | 6 | 5 | 4 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

5 ALPHA NUMERIC
CHARACTERS $(a / n-5)$ CHARACTERS ( $\mathrm{a} / \mathrm{n}-6$ ) 4 8BIT CHARACTERS (a4)

## $\underbrace{\text { Figure 4. Computer Word Format }}_{\text {(c) }}$


#### Abstract

2.1.2.2 Octal Number Representation - Each group of three binary digits, beginning with the three least significant digits of the word, are interpreted as a number to the base eight. The sign and most significant digit are grouped together and interpreted as a number to the base four. Octal representation is shown in figure 4 (b).


2.1.2.3 Alpha-numeric Representation - Certain input and output operations require recognition of mixed alphabetic and numeric symbols. Alpha-numeric information requires sufficient bits for nonambigous representation of each symbol (figure 4 (c)).

### 2.2 Instruction Word Format

2.2.1 Instruction Words - Computer words containing program information are interpreted by the computer as instructions when properly sequenced. If required by the program, certain portions of instruction words may be treated as operands. Instruction words contain an operation code, an operand address, and the address of the next sequential instruction. Instruction word composition is shown in figure 4 (a).

### 2.2.2 Octal Instruction Representation - Information con-

 tained in an instruction word may be interpreted as a sequence of numbers to the base eight as defined above. Octal instruction representation is shown in figure 4 (a).2.2.3 Quasi-Octal Representation - In the instruction word the octal digits overlap logical portions of the word; which makes it inconvenient to write an instruction word in true octal form. For this reason, instructions are usually written in quasi-octal form. Octal digits that overlap instruction word subunits are split into two quasioctal digits. After the program is written, adjacent quasi-octal digits are summed for the final form of the program. Quasi-octal representation is shown in figure 4 (a).
2.3 Memory Disk - The memory disk consists of functional bands, or channels each with read and write heads.
2.3.1 Sector Track - The Sector track is permanently recorded, and has external connections only to the read head. Its purpose is to notify the control unit which sector is about to pass under the read heads of the other channels. The main memory read heads are all at the same effective sector location.
2.3.2 Main Memory - There are 64 main memory channels and are numbered evenly from 000 through $136_{8}$ and $30 U_{8}$ through $336_{8}$. Words or sectors of each channel are numbered in consecutive octal numbers from 000 to 177 inclusive.
2.3.3 Short Loops - A, L, N, D, R, and $Q$ are short recircling loops. Each bit is sensed by the read head and rewritten by the write head. Each word is shifted, bit-by-bit, through the loop. The loop information remains the same unless changed by some arithmetic or control operation. A, L, and N are 1-word loops whose contents are rewritten each word time. $D$ is a 2 -word loop, and $R$ and $Q$ are 16 -word storage loops. Rand $Q$ each have a secondary read head located in the middle of the loop. This head is not involved in the recirculation process.
2.3.4 Short Loop Addressing - The rapid access loops $R$ and $Q$ may have sector address 000 to 177 , but only the last four bits are recognized. The channel address of $R$ is $142 ; Q$ is 152. Registers $A, L$, and $N$ are all addressable. The program may store into and read out of them or they may be used as temporary storage for operands and instructions when not required by the program operations. The sector number has no significance when addressing $A, L$, or $N$. because they are one word loops. The display register is a 2 -word loop in channel 160. The right word is addressed by odd sector numbers and even sector numbers refer to the left word; where the relative position of each word is defined with respect to the Control Panel display.

### 2.4 Input

2.4.1 Initial Program Fill - The normal form of input for loading a program into memory, is the octal mode. Information is. loaded in octal Teletype or FIELDATA code. The basic form of the program is as follows:
a. The memory location of incoming words is specified with five octal characters (channel and sector) followed by a "LOCATION" code. The channel and sector are read into A. The "LOCATION" code transfers these bits to the $L$ register. A new location may be specified at any point in the program.
b. The program and constants are entered in octal digits; 11. characters per word; and each word followed by an "ENTER" code. The "ENTER" code stores the contents of $A$ in the location
contained in $L$, and then increases $L$ by one. In this way, incoming words are stored in sequential location, unless a new location is entered.
c. During octal fill, control is dependent upon the input lines and not the computer itself. If it is desired to proceed directly from input to computing, the last characters should be five characters specifying the start address, followed by a "LOCATION" code and a "COMPUTE" code. The five characters load into A; the "LOCATION" code transfers $A$ to $L$; then the "COMPUTE" code begins computation at the address specified in $L$ when the computer is put in the "RUN" mode.

### 2.4.2 Cornputer Initiated Inputs

2.4.2.1 Octal Fill - Using the input commands, the computer will:
a. Accept FIELDATA or Teletype characters as listed in figure 5.
b. Convert FIELDATA and Teletype cores listed in figure 5, and additionally the blank tape code, to a four-bit code. This conversion is accomplished by the code conversion information written on the Sector channel.
c. Interpret the four-bit code dorived from $b$ as one of the following:

1. An octal character, and insert it into the $A$ register.
2. A "FILL" code, and initiate "FILL" mode.
3. A "VERIFY" code, and initiate "VERIFY" mode.
4. A "LOCATION" and transfer the contents of A to the L register.
5. An "ENTER" code, and will transfer the contents of A to memory if in the "FILL" mode or will compare the contents of A to memory if in the "VERIFY" mode.

| Teletype Meaning |  | fadac Meaning |  |  | Fieldata Meaning |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Charecter | Tape Code | Octal Mode | $\begin{array}{r} \text { BCD } \\ \text { Mode } \end{array}$ | Binary Conversion | Tape Code | Character |
| 0, P | 01101 | 0 | 0 | 0000 | 00110000 | 0 |
| 1, Q | 11101 | 1 | 1 | 0001 | 10110001 | 1 |
| 2, W | 11001 | 2 | 2 | 0010 | 10110010 | 2 |
| 3, E | 10000 | 3 | 3 | 0011 | 00110011 | 3 |
| 4, R | 01010 | 4 | 4 | 0100 | 10110100 | 4 |
| 5, 1 | 00001 | 5 | 5 | 0101 | 00110101 | 5 |
| 6, Y | 10101 | 6 | 6 | 0110 | 00110110 | 6 |
| 7, U | 11100 | 7 | 7 | 0111 | 10110111 | 7 |
| 8, I | 01100 | Halt | 8 | 1000 | 10111000 | 8 |
| 9, 0 | 00011 | Compute | 9 | 1001 | 00111001 | 9 |
| $(+)^{n}, 2$ | 10001 | Fill | + | 1010 | 00100010 | + |
| -, 1 | 11000 | Verify | - | 1011 | 00100001 | - |
| ., M | 00111 | Location | . | 1100 | 10111101 | - |
| 1, x | 10111 | Clear | Cleat | 1101 | 11011101 | x |
| Car. Ret | 00010 | Enter | Enter | 1110 | 01000100 | Car. Ret |
| Blank | 00000 | Blank | Blant | 1111 | 00000000 | Blank |

NOTE: The above codes are employed in numeric input-output in the $B C D$ and octal modes.

Figure 5. Numeric Input Codes
6. A "HALT" code, and will go to the "MANUAL HALT" mode.
7. A "COMPUTE" code, and will initiate the "COMPUTE" mode if the computer is in the "PROGRAM HALT" mode.
2.4.2.2 Decimal Fill - Using the input commands, the computer will:
a. Accept and convert up to 16 binary-coded decimal characters, and will store them by character in $A$ and $N$ on input.
b. While in "DECIMAL FILL BY WORD", convert and store 8 characters per work in $A$ and store the contents of $A$ in memory after each 8 characters.
2.4.2.3 Alpha-numeric Fill - Using the input commands and the codes listed in figures 6 and 7 for "Alpha-numeric-5" and "Alpha-numeric-6", the computer will:
a. Accept up to 10 characters and will store them by character in A and N while in "Alpha-numeric-5 Fill" by character.
b. Store 5 characters per word in A and store the contents of $A$ in memory after each 5 characters while in "Alpha-numeric5 Fill" by word.
c. Accept up to 12 characters and will store them by character in A and N while in "Alpha-numeric-6 Fill" by character.
d. Store 6 characters per word in $A$ and store the contents of A in memory by word, after each 6 characters while in "Alpha-numeric-6 Fill By Word".

### 2.5 Output

2.5.1 NIXIE Display - The NIXIE tubes on the Control Panel are activated by the command "INITIATE DISPLAY". The contents of $D_{0}$ and $D_{1}$ are displayed as binary-coded decimal numbers. In order to cisplay binary numbers, the program must convert them to decimal, store the eight most significant decimal digits in $\mathrm{D}_{1}$, and


Figure 6. Alpha-numeric Teletype Code

| FIELDATA |  | $\begin{array}{\|l\|l\|} \hline \\ 0 \\ 3 \\ 0 \\ 0 \end{array}$ | FADAC | FIELDATA |  | 苞 | FADAC |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { Tape }{ }^{\text {l Code }} \\ \text { PCllDDDD } \\ \hline \end{gathered}$ | Upper Case |  |  | $\begin{aligned} & 2 \\ & \text { Tape Code } \\ & \text { PCllDDDD } \\ & \hline \end{aligned}$ | Upper Case |  | Binary Code |
| 11000000 | Master Sp | 2 | 000000 | 10100000 | ) |  | 100000 |
| 01000001 | Upper case | 2 | 000001 | 00100001 | - |  | 100001 |
| 01000010 | Lower case | $\%$ | 000010 | 00100010 | + |  | 100010 |
| 11000011 | Tab | $\bigcirc$ | 000011 | 10100011 | < |  | 100011 |
| 01000100 | Car. ret | $<$ | 000100 | 00100100 | $=$ |  | 100100 |
| 11000101 | Space | $\Delta$ | 000101 | 10100101 | $\rangle$ |  | 100101 |
| 11000110 | A | A | 000110 | 10100110 | - |  | 100110 |
| 01000111 | B | B | 000111 | 00100111 | \$ |  | 100111 |
| 01001000 | C | C | 001000 | 00101000 | * |  | 101000 |
| 11001001 | D | D | 001001 | 10101001 | ( |  | 101001 |
| 11001010 | E | E | 001010 | 10101010 | 11 |  | 101010 |
| 01001011 | $F$ | F | 001011 | 00101011 | : |  | 101011 |
| 11001100 | G | G | 001100 | 10101100 | ? |  | 101100 |
| 01001101 | H | H | 001101 | 00101101 | ! |  | 101101 |
| 01001110 | I | I | 001110 | 00101110 |  |  | 101110 |
| 11001111 | J | J | 001111 | 10101111 | Stop $\Theta$ |  | 101111 |
| 01010000 | K | K | 010000 | 00110000 |  | 0 | 110000 |
| 11010001 | L | L | 010001 | 10110001 |  | 1 | 110001 |
| 11010010 | M | M | 010010 | 10110010 |  | 2 | 110010 |
| 01010011 | N | N | 010011 | 00110011 |  | 3 | 110011 |
| 11010100 | 0 | 0 | 010100 | 10110100 |  | 4 | 110100 |
| 01010101 | P | P | 010101 | 00110101 |  | 5 | 110101 |
| 01010110 | Q | Q | 010110 | 00110110 |  | 6 | 110110 |
| 11010111 | R | R | 010111 | 10110111 |  | 7 | 110111 |
| 11011000 | S | S | 011000 | 10111000 |  | 8 | 111000 |
| 01011001 | T | T | 011001 | 00111001 |  | 9 | 111001 |
| 01011010 | U | U | 011010 | 00111010 |  | 1 | 111010 |
| 11011011 | V | V | 011011 | 10111011 |  | ; | 111011 |
| 01011100 | W | W | 011100 | 00111100 |  | 1 | 111100 |
| 11011101 | X | X | 011101 | 10111101 |  | . | 111101 |
| 11011110 | Y | $\mathbf{Y}$ | 011110 | 10111110 | Special |  | 111110 |
| 01011111 | 2 | Z | 0111111 | 00111111 | Back space |  | 111111 |

87654321

NOTE: Paper tape Fieldata codes are shown. Magnetic Tape Fieldata codes can be obtained $b y$ inverting parity bit (8) in column 1 and control bit (7) in column 2.

Figure 7. Alpha-numeric FIELDATA Code
the seven least significant decimal digits in $D_{0}$. The sign must be examined, and + or - code (four bits) stored in the four least significant bits of $\mathrm{D}_{0}$.

Once the "DISPLAY" mode is entered it will continue until the order is given to "HALT DISPLAY". Computation may proceed during display.
2.5.2 Octal Output - Using the Octal output commands the computer will:
a. Convert the octal characters in $A$ and $N$ to their FIELDATA or Teletype equivalent via the Sector track conversion table, and generate a carriage return after every eleventh character while in "OCTAL OUTPUT BY CHARACTER".
b. Continually load $A$ and $N$ with the words from main memory to be transmitted and proceed as per "OCTAL OUTPUT BY CHARACTER" while "OCTAL OUTPUT BY WORD".
2.5.3 Decimal Output - Using the output commands the computer will:
a. Convert the decimal characters in $A$ and $N$ to their FIELDATA or Teletype equivalents via the Sector track conversion table, while in "DECIMAL OUTPUT BY WORD".
b. Continually load $A$ and $N$ with the words from main memory to be transmitted and proceed as per "DECIMAL OUTPUT BY CHARACTER", while in 'DECIMAL OUTPUT BY WORD".
2.5.3.1 Alpha-numeric Output - Using the output commands the computer will:
a. Send up to four 8-bit characters from A while in "ALPHA-NUMERIC-4 OUTPUT". In "ALPHA-NUMERIC-4 OUTPUT" the output line D800 will be the inverse of the appropriate bit stored in the computer word being outputted.
b. Continually load $A$ and $N$ with the words from main memory to be transmitted, and send 5 characters per word while in "ALPHA-NUMERIC-5 OUTPUT BY WORD".

# c. Send 6 characters per word from $A$ and $N$ while in "ALPHA-NUMERIC-6 OUTPUT BY CHARACTER". 

d. Continually load A and N with the words in main memory to be transmitted and proceed as per "ALPHA-NUMERIC-6 OUTPUT BY CHARACTER" while in "ALPHA-NUMERIC-6 OUTPUT BY WORD".


#### Abstract

2.5.3.2 Two-wire Teletype Output - The Teletype oscillator provides a pre iision time reference for computer 2 -wire, 5-level (serial) Teletype output. Machine logic is such that a character of information may be transmitted if that information already exists in an applicable register of the computer in teletype code.


### 2.5.3.2.1 Format - A start pulse is defined as minus 3

 volts and a stop pulse as 0 volts. A start pulse of 1 unit time precedes information pulses. The start pulse is followed by 5 units of information, and terminated by a stop pulse. The stop pulse must be at least 1. 42 units. A unit of time is defined as 22 milliseconds $\pm 5$ percent. The stop pulse cannot be less than 1.42 units; and, since a unit cannot be divided, two units of time are used as the stop pulse ( 44 milliseconds).2.5.3.2.2 Operation - The output signal from the Teletype oscillator is called the F32 line (or term). F32 is referred to as the sampling line. Sampling occurs by the X -special command "READ SWITCH MATRIX". The X-special command causes the 32nd bit in the A-register to become one or zero, depending on the state of the sampling line. Upon a command such as "TRANSFER ON POSITIVE", if the F 32 line has baen setting true for 11 milliseconds, the A-register has been receiving a one in the sigic position (32nd bit) indicating a negative number. Assume next that F32 goes false and a zero replaces the one in the sign bit of the word. With the advent of the zero, the "TRANSFER ON POSITIVE" command causes the output driver to transmit a true signal ( -3 volts), which is the start pulse. During output of the start pulse, F32 again goes true. A delay occurs until the F32 line again goes false, at which time the second bit of the character is sent out. The process continues through the remaining bits of the character, after which the stop pulse is sent out, permitting a new character to be transmitted.
2.6 Input-Output Terms - The terms associated with the input-output connectors are described in detail in a subsequent section, Section IV, B, of this manual.

## C. Command Structure

For a complete description of the programming aspects of the computer, refer to FCDD-361, Volume IV, Revision 1, Gun Direction Computer XM18 (FADAC) Programming Manual.

A brief explanation and summary of computer operations is presented below:

## Operation Commands

HALT, HLT:
Execution word times:
Execution:

INITIATE DISPLAY
MODE, IDM:
Execution word tines:
Execution:

HALT DISPIAY
MODE, HDM:
Execution word times:
Execution:

HALT COMPUT: LIGHT
HCL:
Execution word times:
Execution:
$36, \mathrm{C}=120$
1
Computation is halted. Flag bit and operand address are ignored by this command.

$$
36, C=164
$$

1
Visual display activated until a HALT DISPLAY command is received. Sixteen binary-coded decimal (BCD) digits at a time are displayed from the 2 -word $D$ register. Computations can proceed while in this display mode. Flag bit and operand address are ignored by this command.
$36, C=166$
1
Visual display mode halted. Flag bit and operand address are ignored.

36, $C=124$
1
The compute light will be turned off with the computation mode unaffected.

INITIATE COMPUTE LIGHT ICL:
Execution word times: Execution:

DISCRETE INPUT TO
ACCUMULATOR, DIA:
Execution word times:
Execution:

## A Register Bits

1

2-7
8
9-13
14-30
32

36, $C=126$
1
The compute light will be turned on. Computation mode will be unaffected.
$36, \mathrm{C}=040$
1
Information on 32 discrete input
lines are input into the $A$ register, enabling program to sample various input signals in A register. Currently these are as follows: (flag bit and operand address are ignored).

Contents
Signal that both column and row matrix buttons have been depressed Matrix Code Control Panel button 1 or 2 depressed Control Panel button A, B, C, D, or E depressed
Spare bits for external inputs Two-wire Teletype timing signal for programming


| Count | To | Function |
| :--- | :--- | :--- |
| OPLO | - | Idle |
| OPL1 | Output plug |  |
| OPL2 | Output plug |  |
| OPL3 | Output plug |  |
| OPL4 | Input plug |  |
| OPL5 | Input plug |  |
| OPL6 | Input plug | No Solution Light |
| OPL7 |  |  |

## Control Commands

TABLE SEARCH EQUALITY, EQS:
Execution word times:
Executions:

## 64

2 minimum
Starting with $i=0$, the contents of the A register are compared with those in memory location ( $m+1$ ) in bit positions as indicated by a mask appearing in the $L$ register. This mask must have been stored in the $I$ register by the program. It directs which bits of the $A$ register and memory should be compared. Whenever a 1 appears in the $L$ register, the corresponding bits in $A$ and ( $m+i$ ) will be checked. If in the designated bit positions the contents of the $A$ register are found to be equal to the contents of ( $m+i$ ), the ensuing word in memory ( $m+i+1$ ) is put into the A register. At this time, if the flag bit of the command is a 1 , the contents of the A register will be transferred to the $L$ register. If the flag bit is $a \quad 0$, the contents of the $L$ register remain unaltered. If the contents of the $A$ register, in the designated bit positions are not equal to the contents of ( $m+i$ ), then $i$ is increased by one and the comparison continues if the end of a channel has not been reached. If the end of the channel has been reached, the operation is terminated.

GREATER THAN OR
EQUAL SEARCH, GES:
Execution word times:
Execution:

## Arithmetic Commands

ADD, ADD m:
Execution word times:
Execution:

## 66

2 minimum
Starting with $i=0$, the contents of the A register and memory location ( $m+i$ ) are compared in bit positions as directed by a mask appearing in the L register. This mask must have been stored in the $L$ register by the program. It informs the computer of the bits of the A register and ( $m+i$ ) that should be compared. Whenever a 1 appears in the L register, the corresponding bits in $A$ and ( $m+i$ ) will be checked. If in the designated bit positions ( $m+i$ ) (A), then the ensuing word ( $m+i+1$ ) is put into the A register. At this time if the flag bit of the command is a 1 , the contents of the A register are transferred to the $L$ register. If the flag bit is 0 , the contents of the $L$ register remain unaltered. If in the designated bit positions the contents of the A register are not less than or equal to the contents of $(m+i)$, then $i$ is increased by one and the comparison continues if the end of the channel has not been reached. If the end of the channel has been reached, the operation is terminated.

SUBTRACT, SUB m:
Execution word times: Execution:

MULTIPLY, MPY m:
Execution word times:
Execution:

DIVIDE, DIV m:
Execution word times:
Execution:

The word location $m$ is subtracted from the A register, the difference appearing in the A register. Overflow can occur and, unless followed by a TRANSFER ON OVERFLOW command, will cause the computer to halt and indi申 te an error. A flag bit of 0 leaves contents of $N$ register unaltered.

## 20

18
The contents of memory location $m$ are multiplied by the contents of the $A$ register. The product appears in the $A$ and $L$ registers unrounded. The most significant 31 bits and sign are in the A register. The least significant 31 bits are in the $L$ register. Because the number in the $L$ register is the least significant part of the total product, it does not have a sign associated with it. The most significant bit of the 31 bits of the least significant part of the product appears in the sign position of the $L$ register. The least significant bit position of the $L$ register always contains a 0 after multiplication which is not considered a part of the product. The contents of location $m$ are stored in the $N$ register. The flag bit is ignored by this instruction.

## 30

18
The 62-bit number appearing in the $A$ and $L$ registers is divided by the contents of location $m$. The most significant bit of the portion of the dividend that appears in the $L$ register is in the sign position. If the flag bit is 0 , then the A register will contain the rounded quotient and the $L$ register will contain the unrounded quotient and the L register will contain a remainder with the same sign as the divisor. This remainder satisfies the relation: Divisor x Quotient + Remainder = Dividend. The contents of location $m$ are put in the $N$ register.

## Semiarithmetic Commands

 ACCUMUATOR RIGHTCYCLE, ARC S:
Execution word times:
Execution:

ACCUMULATOR RIGHT
SHIFT, ARS S:
Execution word times:
Execution:

ACCUMULATOR LEFT
CYCLE, ALC S:
Execution word times:
Execution:

Overflow can occur if the absolute value of the contents of the $A$ register is equal to or exceeds the absolute value of the contents of $m$. In case of overflow, the computer will halt with an error signal unless the command is followed by a TRANSFER ON OVERFLOW command.

76, $\mathrm{C}=00$
$1 / 2(1+S+\cos 2 \pi S / 2)$
The sector address portion of this command does not refer to a location in memory, but indicates the number of binary positions the word in the $A$ register is to be cycled. On execution of this command, the contents of the $A$ register are shifted right the number of binary positions designated by $S$. The bits shifted off the right end of the $A$ register appear at the left end of the register in the same sequence being shifted in through the sign bit. The flag bit must be a 0 .

76, $\mathrm{C}=02$
$1 / 2(1+S+\cos 2 \pi S / 2)$
The sector address portion of this command does not refer to a location in memory, but indicates the number of binary positions the word in the $A$ register is to be shifted. On execution of this command, the contents of the $A$ register are shifted right the number of binary places designated by S. The sign is spread in the left-hand bits, while bits shifted beyond the right-hand limits of the $A$ register are lost. The flag bit must be a 0 .

76, $\mathrm{C}=04$
$1 / 2(1+S+\cos 2 \pi S / 2)$
The sector address portion of this command does not refer to a location in memory, but indicates the number of binary positions the word in the A register is to be cycled. On execution of this command, the contents of the $A$ register are shifted left, through the sign bit, the number of binary places

ACCUMULATOR LEFT
SHIFT, ALS S:
Execution word times:
Execution:

LONG RIGHT CYCLE
LRC S:
Execution word times:
Execution:
indicated by $S$. The bits shifted off the left end of the register are shifted in at the right end in the same sequence. The flag bit of 1 indicates that the computer should check for overflow.

76, $\mathrm{C}=06$
$1 / 2(1+S+\cos 2 \pi S / 2)$
The sector address portion of this command does not refer to a location memory, but indicates the number of binary positions the word in the $A$ register is to be shifted. On execution of this command, the contents of the $A$ register are shifted left, through the sign bit, the number of binary places designated by $S$. Positions left vacant, as the contents in the $A$ register are shifted left, are filled with zeros. Any bits shifted beyond the sign position of the $A$ register are lost. It is possible to have an overflow with this command.

A flag bit of 1 indicates that the computer should check for overflow. When the flag bit is 0 , overflow is ignored.

76, $\mathrm{C}=20$
$1 / 2(1+S+\cos 2 \pi S / 2)$
The sector address portion of this command designates the number of binary places the information is to be cycled. Upon execution of this command, the contents of the $A$ and $L$ registers are shifted off the right end of the $A$ register through its sign bit position. The bits shifted off the right end of the $L$ register are shifted into the $A$ register through its sign bit position. The flag bit must be 0 .

LONG RIGHT SHIFT, LRS S:
Execution word times: Execution:

LONG LEFT CYCLE, LLC, S:
Execution word times:
Execution:

LONG LEFT SHIFT,
LLS S:
Execution word times:
Execution:

76, $\mathrm{C}=22$
$1 / 2(1+S+\cos 2 \pi S / 2)$
The sector address portion of this command designates the number of binary places the information is to be shifted. Upon execution of this command, the contents of both the $A$ and $L$ registers are shitted right the number of binary places designated by $S$. The bits shifted off the right end of the $A$ register are shifted into the $L$ register through its sign bit position. The bits shifted off the right end of the $L$ register are lost. The sign of the $A$ register is spread. The flag bit must be a 0 .

76, $\mathrm{C}=24$
$1 / 2(1+S+\cos 2 \pi S / 2)$
The sector address portion of this command designates the number of binary places the information is to be cycled. Upon execution of this command, the contents of the $A$ and $L$ registers are shifted left the number of binary places indicated by S. The bits shifted left through the sign of the $A$ register are shifted into the right end of the $L$ register. Bits shifted through the sign bit of the $L$ register are shifted into the right end of the A register. The flag bit is ignored for this command.
$76, \mathrm{C}=26$
$1 / 2(1+S+\cos 2 \pi S / 2)$
The sector address portion of this command designates the number of binary places the information is to be shifted. Upon execution of this command, the contents of both the $A$ and $L$ registers are shifted left the number of binary places designated by $S$. The bits shifted through the sign bit of the $L$ register are shifted into the right-hand end of the $A$ register. The right-hand bits of the $L$ register vacated by the shifting process are filling with zeros. Bits shifted off the left-hand end of the $A$ register are lost. It is possible to have overflow with this command. A flag bit of 1 indicates the computer should check for overflow.

## Control Transfer

TRANSFER ON
PLUS, TPL:
Execution word times: Execution:

TRANSFER ON OVERiTOW, TOV m:
Execution word times: Execution:

TRANSFER UNCON-
DITIONALLY, TRA m:
Execution word times:
Execution:

TRANSFER ON ZERO, TZE m:
Execution word times:
Execution:

10
1
Control is transferred to the instruction found in location $m$ if the contents of the A register are greater than or equal to zero. If the contents of the A register are negative, the address of the next instruction to be executed is obtained from the NEXT INSTRUCTION address of the command. If the transfer is executed, a flag bit of 1 will put the instruction into the $N$ register. A flag bit of 0 leaves the contents of the N register unaltered.

## 16

1
Control is transferred to the instruction found in location $m$ when an overflow has occurred as a result of the previous instruction. If no overflow has occurred, control will proceed to the next instruction. If the transfer is executed, a flag bi+ of 1 will put the instruction into the $N$ register. A flag bit of 0 leaves the $N$ register unaltered.

14
1
Control is transferred to the instruction found in location $m$. A flag bit of 1 will put the transfer instruction into the $N$ register. A flag bit of 0 leaves the N register unaltered.

## 12

1
Control is transferred to the instruction found in location $m$ if the contents of the A register are equal to zero. If the contents of the A register are not equal to zero, the transfer will not be executed, and the next instruction will come from the location specified by the NEXT INSTRUCTION address portion of the command. If the transfer is executed, a flag bit of 1 will put the instruction into the $N$ register. A flag bit of 0 leaves the $N$ register unaltered.

## Information Transfer

CLEAR AND ADD, CLA m:

24
1
The contents of location $m$ are transferred to the A register. Location $m$ can refer to any addressable location. A flag bit of 1 transfers the previous contents of the A register into the $L$ register. If the flag bit is 0 , the contents of the $L$ register remain unaltered.

26
1
The negative of the contents of memory location $m$ are transferred to the $A$ register. Location m can refer to any addressable location. A flag bit of 1 transfers the previous contents of the A register into the $L$ register. If the flag bit is 0 , the contents of the $L$ register remain unaltered.

50
1
The contents of the A register are put (stored) in location $m$. If the flag bit is 1 , this word will be put into the N register as well as into location m . If the flag bit is o, the previous contents of the $N$ register remain unaltered. Location $m$ can refer to any addressable location except when $m=A$, L , or N registers, then no storage takes place.

## 52

1
The contents of the $L$ register are put (stored) in location $m$. If the flag bit is $l$, the word will be put into the N register as well as into location m. If the flag bit is 0 , the previous contents of the $N$ register remain unaltered. Location $m$ can refer to any addressable location except when $m+A, L$, or $N$ registers, then no storage takes place.

STORE N, STN m:
Execution word times:
Execution:

STORE D, STD m:
Execution word times:
Execution:

STORE R, STR m:
Execution word times:
Execution:

40
1
The contents of the $N$ register are put (stored) in location m. Location m can refer to any addressable location except when $m=A, L$, or $N$ registers, then no storage takes place. The flag bit is ignored.

The contents of sector $i$ of the 2 -word D register are put into location $m$, where $i=0$ if $m$ is even and $i=1$ if $m$ is odd. If the flag bit is 1 , this word will be put into the N register as well as into location $m$. If the flag bit is 0 , the previous contents of the $N$ register remain unaltered. Location $m$ can refer to any addressable location except when $m=A, L$, or $N$, then no storage takes place.

62
18
The contents of the 16 words of the $R$ loop are transferred into main memory starting at location $m$. The last four bits of $m$ will determine the sector of $R$ from which the first word is being stored. The contents of the $D$ register are altered. The flag bit is ignored.

36, $\mathrm{C}=172$
1
a. If the contents of the A register are negative and the flag bit is zero, the complement of the contents of the $L$ register is sent to $A$, and $L$ is unchanged. b. If the contents of the A register are negative and the flag bit is one, the complement of the contents of $L$ is sent to $A$, and the original $\mathrm{cc}^{-1}$ :nts of $A$ are sent to $L$.
c. If the contents of the A register are positive, $A$ and $L$ are unchanged regardless of the value of the flag bit.
d. The sign of the original contents of the $L$ register in no way affects $a, b$, and $c$ above.

REPLACE A ON MINUS
FROM N, RMN
Execution Word Time:
Execution:

ZERO L, ZEL:
Execution word times:
Execution:
$36, C=174$
1
a. If the contents of the $A$ register are negative and the flag bit is zero, the complement of the contents of the $N$ register is sent to $A$. The $L$ and $N$ register: are unchanged.
b. If the contents of the A register are negative and the flag bit is one, the complement of the contents of the $N$ register is sent to $A$, the original contents of $A$ are sent to $L$, and $N$ is unchanged.
c. If the contents of the A register are positive, $\mathrm{A}, \mathrm{L}$ and N are unchanged. d. The sign of the original contents of the $N$ register in no way affects $a, b$, and $c$ above.
$36, C=162$
1
The $L$ register is cleared to zero. The flag bit and the operand sector are ignored by this command.

## 34

The contents of the $A$ register are replaced by the logical AND of the contents of m . This command works in the following manner: when both the bit in memory and the bit in the A register are 1 , a 1 will appear in the same bit position in the A register at the end of the execution. When either the bit in memory or the bit in the A register is 0 , a 0 will appear in that bit position of the $A$ register upon execution of this command. The flag bit is ignored by this command.

70
1 if $m$ refers to $R$ or $Q$; otherwise 3 The right address of the word in location $m$ is replaced by the right address of the word in the A register ( 13 bits). The modified contents of $m$ are put in the $N$ recister. The $m$ can refer to any addressable location except $A$ and $L$. The flag bit is ignored for this operation.

STORAGE PROGRAM
ADDRESS, STP m:
Execution word times:
Execution:

## 60

1 if $m$ refers to $R$ or $Q$, otherwise 3 . The left address of the word in location m , is replaced by the left address of the word in the A register ( 13 bits). The modified contents of $m$ are put in the $N$ register. The m can refer to any addressable location except \& and $L$. The flag bit is ignored for thi: operation.

LOAD Q or LOAD R
LDQ $m$ or LDR* $m$ :
72
Execution word times:
Execution:
16
The contents of 16 consecutive words of
memory starting with location $m$ are transferred to one of the rapid access loops. The specific loop, i.e., R or $Q$, is determined by the flag bit. A flag bit of 1 indicates the $R$ loop, while a flag bit of 0 indicates the $Q$ loop. Each word is transferred into $R$ or $Q$ in the sector in which the last four bits agree with the sector of these loops.

Input-Output Commands
READ NUMERIC, RDN:
Execution:

## 54

The program is allowed to select the keyboard, mechanical reader, or an external device. The form of input (octal or BCD) is designated by the most significant bit of the right channel number. The input device is selected by the next two bits of the channel number.

In Numeric Input mode, the computer will accept certain Fieldata or Teletype characters, convert these characters to a 4bit code and then, depending on the mode (Octal or BCD) and perhaps the character (if in Octal mode), will process these four bits as shown in the following descriptions.

In Octal Input mode, the acceptable characters are the octal digits 0 through 7 and the control characters for LOCATION, ENTER, FILL, VERIFY, HALT, and COMPUTE. All other characters are ignored. The computer will interpret a VERIFY code and
initiate the Verify mode, as well as interpret a FILL code and initiate the Fill mode. Upon receipt of an octal digit, the computer will shift left the corresponding three bits into the least significant end of the A register. Upon receipt of a location code, the contents of the $A$ register are transferred to the $L$ register, thus setting up the initial location where the following information is to be stored or where computation is to start. Upon receipt of an ENTER code, information in the A register will be transferred to (if in FILL) or compared with the contents of (if in VERIFY) the memory location specified by the contents of the $L$ register. The location designation will then be increased by one. A HALT code will send the computer into the Program Halt mode.

In the BCD Input mode the acceptable characters are the decimal digits 0 through 9 and the symbols (+), (-), (.), (clear), (enter), and (blank). All other characters are ignored.

Upon receipt of an acceptable character, the computer will shift left the corresponding four bits into the least significant end of the A register.

In the $B C D$ Input mode the amount of data to be accepted is determined by a choice of block size and the number of blocks. A flag bit of 0 indicates the block is a character. A flag bit of 1 indicates the block is a word. In the BCD mode, a word is made up of eight characters. The number of blocks is indicated by the 10 least significant bits of the command.

If the computer is still in the Input mode after a word is assembled, the resulting word is transferred to the N register.

In addition, if the flag bit is 1 , then the word just transferred to the $N$ register is also transferred to the location specified by the 13 least significant bits of the $L$ register, and this location designation will then be increased by one.

After the specified number of blocks have been accepted (and stored in memory if the flag bit is 1 ), the computer will return to COMPUTE and execute the next command in its program sequence.

READ ALPHA-NUMERIC

RDA:
Execution:

## 56

The program is allowed to select the keyboard, mechanical reader, or an external device. The form of the input (either five or six characters per word) is designated by the most significant bit of the right channel number. The input device is selected by the next two bits of the channel number.

In the Alpha-numeric Input mode, the computer will accept all Fieldata and Teletype characters. The computer will shift left these characters directly (without conversion)into the six least significant bit positions of the $A$ register. The amount of data to be accepted is determined by a choice of block size and the number of blocks. A flag bit of 0 indicates the block is a character. A flag bit of 1 indicates the block is a word. In the Alpha-numericFive mode, a word is made up of five characters.

In the Alpha-numeric-Six mode, a word is made up of six characters. The number of blocks to be accepted is indicated by the 10 least significant bits of the command.

If the computer is still in the Input mode after a word is assembled, the resulting word is transferred into the $N$ register. In addition, if the flag bit is 1 , the word just transferred to ine $N$ register is also transferred to the location specified by the 13 least significant bits of the $L$ register, and the location designation will then be increased by one.

WRITE NUMERIC, WRN:
Execution:

After the specified number of blocks has been accepted (and stored in memory if the flag bit is 1 ), the computer will return to COMPUTE and execute the next command in its program sequence.

44
The most significant channel bit of this command designates whether the form is octal or BCD. The next two channel bits designate whether the output should be in Teletype or Fieldata code.

In Numeric Output mode the computer will shift left an octal or BCD character out of the most significant end of the $A$ register, convert this character to the proper Fieldata or Teletype code, then put it on the output lines.

The amount of data to be transmitted is determined by a choice of block size and the number of blocks. A flag bit of 0 indicates the block is a character. A flag bit of 1 indicates the block is a word. In the Octal mode, a word is made up of 11 octal characters plus i "enter" character. In the BCD mode, a word is made up of eight BCD characters. The number of blocks to be transmitted is indicated by the 10 least significant bits of the command. If the computer is still in the Output mode, after a word has been transmitted, then the word in the N register is transferred to the A register. In addition, if the flag bit is 1 , the contents of the location specified by the 13 least significant bits of the $L$ register are transferred into the $N$ register, and the location designation will then be increased by one.

At the start of the operation, if the flag bit is 1 , the computer will simulate two words transmitted, thus initializing the $A$ and $N$ registers with the first two words to be transmitted.

After the specified number of blocks have been transmitted, the computer will return to COMPUTE and execute the next command in its program sequence.

WRITE ALPHA-NUMERIC, WRA:
Execution:

## 46

The most significant channel bit of this command designates whether the form of the output is five or six characters per word.

In Alpha-numeric Output mode, the computer will shift left a 6 -bit Fieldata or Teletype sharacter out of the most significant end of the A register and put it directly on the output lines (without any conversion).

The amount of data to be transmitted is determined by a choice of block size and the number of blocks. A flag bit of 0 indicates the block is a character.

A flag bit of 1 indicates the block is a word. In the Alphanumeric-Six mode a word is made up of six characters. The number of blocks to be transmitted is indicated by the least significant bits of the command.

If the computer is still in the Output mode after a word has been transmitted, then the word in the N register is transferred to the A register. In addition, if the flag bit is 1 , the contents of the location specified by the 13 least significant bits of the $L$ register are transferred to the N register, and the location designation will then be increased by one.

At the start of the operation, if the flag bit is 1 , the computer will simulate two words transmitted, thus initializing the $A$ and $N$ registers with the first two words to be transmitted.


#### Abstract

After the specified number of blocks has been transmitted, the computer will return to COMPUTE and execute the next command in its program sequence.

Alphanumeric-5 Output by character is refered to as "Alphanumeric-4". This Command is used to output arbitrary predetermined 8 bit characters. Each character is formed from eight bits shifted left to the eight most significant positions of the A register. Each character is placed directly on the output lines except that the most significant bit will be inverted. Thus four characters may be packed into each computer word, and a maximum of eight characters (contents of $A$ and $N$ ) may be outputted per instruction. Both $A$ and $N$ must be pre-stored before executing this instruction.


## III. CONTROL PANEL

## A. General Description

The Computer Control Panel is shown pictorially in figure 8. It provides not only the basic operating controls, but also the man-machine interface for both Input and Output of data.

The control panel is divided into five basic functional areas as follows:

1. Controls and Indicators
2. Keyboard Input Device
3. Mechanical Tape Reader
4. Matrix Input Device
5. NIXIE Display

Figure 8. Control Panel - Detail View

Electrically the connection between the control panel and the computer is provided by four cables. No mechanical attachment of the panel to the computer main frame is mandatory, although cable lengths and air flow in the computer must be considered in the system application where this separation is contemplated.

## B. Functional Description

Figure 9 is a block diagram of the major functional elements of the Control Panel, and in addition, shows the connector assignments.

To Computer Main Frame


Figure 9. Control Panel Functions and Connector Assignments

## Operating Controls and Indicators

The following is a summary of the functions of the operating controls and indicators of the FADAC.
a. PWR ON, PWR OFF (switch) - In the ON position, this switch actuates the power control circuits in the computer, energizing
in the proper sequence, the power supplies, blowers, and memory. In the OFF position, the computer is de-energized. While not actually a part of the control panel, a three pole circuit breaker is provided on the computer main frame, right side, for the control of the primary 400 cycle, 3 phase power.
b. PWR READY (Indicator) - This neon indicator lights after a delay suitable for insuring that the memory is fully operational. The light remains in its $O N$ condition until the computer power is turned OFF. When the computer is $\mathrm{p}^{-}$aced into a marginal test condition, this indicator blinks until the Normal mode is restored. (See below for Marginal Test Mode explanation.)
c. TRANSIENT (Indicator) - Normally ON, this neon indicator blinks when a line transient has occurred, or when the input voltage exceeds High or Low tolerances. If the blinking light cannot be reset with the RESET button, the input voltage is approaching a High or Low voltage kick-out condition.
d. TEMP (Indicator) - Normally ON, this neon indicator blinks when the internal temperature of the machine is approaching marginal operation. The computer may be usually used, however, until the temperature kick-out actually occurs. Any system application of the computer must insure that the control panel and computer filters are accessable for cleaning and are provided with unimpeded air flow. Additionally, a cutout switch is provided on the rear of the computer to de-energize one of the internal blowers for cold temperature operation. This feature is also used as maintenance tool to determine if proper blower operation is present when a temperature warning occurs.
e. PARITY (Indicator) - Normally ON, this neon indicato: blinks when a parity error is detected either when reading from memory or in reading from an input device in FIELDATA or other parity sensitive codes.
f. ERROR (Indicator) - Normally ON, this neon indicator blinks when an overflow has occurred in computation.
g. NO SOLUTION (Indicator) - Normally ON, this neon indicator blinks when a NO SOLUTION LIGHT (NSL) command has been executed. The indicator must be programmed both ON and OFF, for example, to indicate an insoluble problem or that an incorrect procedure has been employed.
h. COMPUTE (Indicator) - Normally OFF, this neon indicator lights du ing the periods when the computer is in a computing state. It may alwo be turned ON and OFF under program control with the execution of an INITIATE COMPUTE MODE (ICM) or HALT COMPUTE MODE (HCM) instruction. Thus, the light can be kept off while the computer is in a compute mode. This function is usually reserved for periods when the computer is either self-testing the memory aritlmetic loop registers or scanning the discrete input lines for evidence of an input from an external device.
i. IN/OUT (Indicator) - Normally OFF, this neon indicator lights when information is being transferred to or from an external device, keyboard, or mechanical reader. It is automatically controlled by the execution of any computer input or output comr.and.
j. KEYBOARD (Indicator) - Normally OFF, this neon indicator lights when the computer calls for information from the keyboard. The light is automatically controlled by the execution of a computer keyboard input command.
k. TIME METER - A running time meter is provided on the control panel to display total elapsed operation time of the computer.

1. MARGINAL TEST (Switch) - While not actually a physical part of the control panel, a five position switch is provided on the left side of the computer main frame. Normally OFF, this switch controls four different combinations of marginal voltages. When the switch is placed in any one of the marginal test positions the PWR READY neon indicator will flicker. This marginal test feature has been provided as a maintenance tool.
m. RESET (Switch) - This switch, when momentarily depressed, resets the computer to the program or manual halt mode from the compute or In/Out modes, or when a parity or overflow error has occurred. It is also used to reset the Temperature warning or Transient neon indicators.
n. INPUT MATRIX - The matrix consists of 64 indicating windows arranged in an $8 \times 8$ array. The switches used to select a specific input window, corresponding to an assigned input parameter, are of the latching type and are located in the left-hand row (lettered

A through H) and in the bottom row (numbered 1 through 8). Selection of a given window sets binary information into programming bit positions 25 through 30, (where bit position 31 is the LSB), which may be sampled by the DIA command. In addition to the $8 \times 8$ matrix, there are several auxilliary switches as described below:
(1) Five switches on the right hand bank (lettered A through E) which set binary information into bit positions 19 through 23, which can be sampled by the DIA command.
(2) Two switches on the right hand bank (numbered 1 and 2) which set binary information into bit position 24 , which can be sampled by the DIA command.
o. MECHANICAL TAPE READER - The mechanical tape reader is used for entering data into FADAC. The input code is either $5-l e v e l$ teletype code or 8 -level FIELDATA paper tape alpha-numeric code. The tape reader is controlled internally under program control. The running speed of the tape reader is approximately 10 characters per second.
p. KEYBOARD - The computer keyboard is used for manual input of information. It contains keys for the digits 0 through 9, one key each for " +" and " - ", and three control keys (Clear, ".", and Enter). The SAMPLE MATRIX (SM) switch acts as a transfer of control to location 000000 . The RECALL switch located on the upper left side of the keyboard is a similar set-up switch whose activation transfers control to location 000003 . The complete complement of set-up switches is described below in Table I.

## Table I. OPERATION SWITCHES

|  | Address |  |
| :--- | :---: | :---: |
| Operation Switch | Channel | Sector |
| SAMPLE MATRIX | 000 | 000 |
| TEST | 000 | 001 |
| SET UP | 000 | 002 |
| RECALL | 000 | 003 |
| SEND | 000 | 004 |
| COMPUTE | 000 | 005 |
| TRIG | 000 | 006 |
| RECEIVE | 000 | 007 |

q. OPERATION SWITCHES - If the computer has been set into the program halt state either hy the program, or activation of the RESET switch, the set-up buttons operate as a transfer of control to the addresses as indicated in Table I.
r. NIXIE DISPLAY - The NIXIE Display is a programmed visual display in which output information, converted into BCD characters is stored in the 2 -word $D$ loop, and visually displayed. This display consists of 17 NIXIE tubes and 16 neon lamps used for decimal point indication.

## C. Control Panel Interfacing

The control panel interface with the Main Computer consists of 4 cannon connectors P1, P2, P5, P6 and a wiring harness connecting the power on-off switch, night lights, running time meter, set up buttons, reset button, neon NIXIES, input matrix, keyboard and mechanical reader to these connectors as indicated in figure 9.

## 1. Power Control

A schematic of the Pl interface with the set-up buttons, reset button, night lights, power on-off switch, neons and running time meter is shown in figure 10. This plug mates with J20 on the main computer chassis. The power on-off switch is shown with a -6 volts and power GND feeding back into POFF and N2 respectively in the ON position. In the OFF position, these are removed and a ground is placed on the power OFF input. The inputs to the night light are approximately 7 volts AC for each, and the input to the time meter is 120 volts AC, from the computer, after the main power relay is held on.

## 2. Set-Up Buttons

The set-up buttons are energized with a -10 volts from the computer main chassis and supply a -10V "ON" signal (or an open "OFF') to SU1, SU2, SU4, SU5, SU6, SU7 in the "ON" positions and to SUl', SU2', SU4', SU5', SU6', SU7' in the 'OFF" conditions. Along with the SU0, SUO', SU3, and SU3' signals from the keyboard these signals are connected to the following matrix circuit in the main computer chassis (figure 11).



Figure 11. "Operation" Switches Computer Interface

## 3. Keyboard

A schematic of the P 2 interface which is wired to the keyboard and mechanical reader is shown in figure 12. The plug mates with J 21 on the main computer chassis. A schematic of the manual keyboard with the interface circuits in the main computer chassis to which it mates is shown in figure 13. This is a representation of a mechanical keyboard.

When the enable line is energized and a key is depressed, the solenoid is energized, allowing the appropriate information lines for that key to be energized. A cycle of information, strobe, and strobe' pulses results as shown in figure 14.

An electrical interlock is arranged such that only one such cycle will result as long as the key is depressed even if the enable line is de-energized and then energized again. A mechanical interlock is also incorporated so that one and only one key can be depressed at a time. The SM (SUO) and the RECALL (SU3) portion of the keyboard have been previously described.

## 4. Mechanical Reader

A schematic of the Mechanical Reader circuitry is shown in figure 15, along with the types of paper tape used. Schematic representation is also made of the circuit interface existing in the computer main chassis.

The enable signal (MGROS) energizes the solenoid when a tape is inserted (MRL) and excessive tension is not present (tight tape). A sprocket wheel inserted in the sprocket holes of the tape rotates the tape and creates the cycle of pulses shown in figure 16. The information contacts are closed mechanically by spring loaded fingers when a hole exists in tape. The computer de-energizes the enable line upon receipt of the RCC contact or TC signal and cannot energize again until several word times after the $B$ contact or TC' goes true again. A cycle of information, strobe, and strobe' pulses is shown in figure 16.

The computer can accept the maxin um free running rate of the mechanical reader, during a manually initiated continuous reading cycle, which is 20 to 35 lines per second. However, under program control where other programmiñ is accomplished between readings the speeds may be much slower.


Figure 12. P2 Interface Schematic


Figure 13. Keyboard Functional Diagram


Figure 14. Keyboard Timing Sequence


Figure 15. Mechanical Reader Functional Description


Figure 16. Mechanical Reader Timing Sequence

The manually initiated fill mode is applicable to both the Keyboard and Mechanical Reader. In each case the computer is forced into manual halt by GPRC' $(-10 \mathrm{~V})$ and GPHC' $(+6 \mathrm{~V})$ on the input plug J17. For the Keyboard input the RECEIVE button on the computer is first depressed then -10 V is momentarily placed on FBPR (FILL button) on the input plug $\mathrm{J} 1 \%$. This places the computer in the Keyboard input mode. Only the octal format by word is accepted in this mode. For the Mechanical Reader, the RECALL button is first depressed and the -10 V is momentarily placed on FBPR. This places the computer in the mechanical reader input mode. Again the octal format by word is the only one accepted, however, either TT or FIELDATA code is applicable by leaving MRTT open for Teletype and grounding MRTT for FIELDATA input.

In the FIELDATA input mode only the FIELDATA paper tape code format is accepted by the Mechanical Reader. Additional information related to the Manually initiated fill mode is contained in Section IV.

The wiring schematic of the P5 interface showing connections to the NIXIES and the Input Matrix is shown in figure 17, and indicates the computer interface with which these contacts mate in the computer. A schematic of the Input Matrix is shown in figure 18.

## 5. Input Matrix

The Matrix input device serves to input particular combinations of bits into the A-register upon use of the DIA (Discrete Input into Accumulator) command.

The device has a column of 8 push-buttons ( $A$ to $H$ ) and a row of 8 push-buttons ( 1 to 8). In addition, there are 5 push-buttons labeled A through $E$, norrally referred to as the battery buttons and 2 pushbuttons labeled 1 and 2, normally referred to as the weapon type buttons. The $8 \times 8$ push button arrangement provides information to the computer of the 64 different combinations of bits designated F2 through F7.

An Fl bit is used to indicate that a push button is depressed in both the row and the column. The five battery buttons supply infor mation to the computer of the bits F9, F10, F11, F12, F13 and are normally used to associate with a particular battery in the artillery


Figure 17. P5 Interface Schematic

Figure 18. Input Matrix Schematic
problem. The two push buttons labeled 1 and 2 supply the $F 8$ bit either on or off to the computer and are used in the artillery problem to associate with a particular weapon type.

The $8 \times 8$ push button array has a removable template which designates by a light the associated programmed function of each of the 64 positions. The template is easily changed and a new one may be designed for any particular application or program. The information bits supplied by the matrix to the computer, F1 through F13, are sampled by the DIA command and placed in the A-register from which they can be interpreted for the particular function the computer is to perform.

The bit designations Fl through F13 are hardware designations and differ from those in the programming manual. Flhere refers to the least significant bit of the word which occurs at Tl time whereas in the programming manual this bit is given the F3l designation. The assigning of bit locations as applied to programming positions versus hardware positions is further defined in Section IV, Paragraph B. 2.f.

## 6. NIXIE Readout

The wiring schematic of P6 for the NIXIE indicators on the control panel is shown in figure 19.

Of the eighteen NIXIES shown in figure 20, one NIXIE serves as the Battery indicator. The seventeen remaining NIXIES represent 16 decimal digits of information from the " $D$ " register, with the "SIGN" and "CHARGE" sharing a NIXIE. The cathode driver is the same as for the Battery NIXIES and is shown in figure 22. The anode driver is shown in figure 21.

Four anode drivers, each energizing four NIXIES, are cycled each $1 / 4$ revolution of the memory disk. This rate provides the effect of flicker free lighting of the full NIXIE complement.

A readout schematic is shown in figure 23, and display arrangement in figure 24. A functional wire listing is described in figure 25.


Figure 19. P6 Interface Schematic

Figure 20. NIXIF, Display Block Diagram


Figure 21. NIXIE Anode Driver


Figure 22. NIXIE Cathode Driver



Figure 23. NIXIE Readout Schematic



| NLxie | Code Bit |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 0 | 1 |
| 2 | 0 | 0 | 1 | 0 |
| 3 | 0 | 0 | 1 | 1 |
| 4 | 0 | 1 | 0 | 0 |
| 5 | 0 | 1 | 0 | 1 |
| 6 | 0 | 1 | 1 | 0 |
| 7 | 0 | 1 | 1 | 1 |
| 8 | 1 | 0 | 0 | 0 |
| 9 | 1 | 0 | 0 | 1 |
| + | 1 | 0 | 1 | 0 |
| - | 1 | 0 | 1 | 1 |
| 0 | 1 | 1 | 0 | 0 |
| B1ank | 1 | 1 | 1 | 1 |

Figure 24. NIXIE Display Arrangement

| PIV | FUNCTION | PIN | FUNCTION | PIN | FUNCTION |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Spare | 1 | Spare | 1 | CD input | Dec. Pt. |
| 2 | Spare | 2 | Spare | 2 | Spare |  |
| 3 | Spare | 3 | Spare | 3 | CD input | 1 |
| 4 | $C D$ input $C$ | 4 | Spare | 4 | CD input | 2 |
| 5 | CD input B | 5 | Spare | 5 | CD input | 3 |
| 6 | Spare | 6 | CD input - | 5 | CD input | 4 |
| 7 | CD input E | 7 | Spare | 7 | CD input | 5 |
| 8 | Spare | 8 | CD input + | 8 | CD input | 6 |
| 9 | Spare | 9 | Spare | 9 | AD input |  |
| 10 | Spare | 10 | Spare | 10 | Spare |  |
| 11 | AD input | 11 | AD input | 11 | AD input |  |
| 12 | CD input D | 12 | Spare | 12 | CD input | 0 |
| 13 | Spare | 13 | Spare | 13 | CD input | 9 |
| 14 | CD input A | 14 | Spare | 14 | CD input | 8 |
| 15 | Spare | 15 | Spare | 15 | CD input | 7 |
| Jl B | Y NIXIE | J2 | IXIE | $\begin{aligned} & \text { J3 THRU J18 } \\ & \text { NUMERICAL NIXIE } \end{aligned}$ |  |  |

Figure 25. Cathode Driver (CD) and Anode Driver (AD) Connections to NIXIE Display

The information is read from the two word $D$ loop 16 bits at a time shifted into $D_{1}$ through $D_{8}$ and $D A_{1}$ through $D A_{8}$. When the shift is complete, the anode driver is enabled and the 4 NIXIES light up with a cathode selected by a matrix from the 16 bits. When the sign is ON, the charge NIXIE is OFF and when a charge digit is energized, the sign is OFF.

## IV. EXTERNAL INPUT-OUTPUT INTERFACE DESCRIPTION

## A. General

Interfacing to the FADAC can be established for a variety of peripheral devices by the proper connections to the computer. The Input-Output interface is accommodated by an Input connector, J17, and an Output connector, J10. Both of these connectors are mounted on the computer main frame as indicated in figure 1 , and in figure 2.

When an Input signal is described as "TRUE", "ON", or a "l", it is defined as a signal of $-3 V \pm 1 \mathrm{~V}$, into 150 ohms. An Input logic term of "FALSE", "OFF", or a " 0 ", it is defined as OV $\pm 1 \mathrm{~V}$ into 150 ohms. An Output term of "TRUE", "ON", or a " 0 " is defined as a signal of -6V through 150 ohms. An Output term of "FALSE", "OFF", or a " 0 " is defined as -6 V through 100 k ohms. These are the normal logic signal levels utilized unless otherwise specified. Figure 26 schematically illustrates an Input amplifier, an Output amplifier is schematically shown in figure 27.


Figure 26. Input Driver


Figure 27. Output Driver

Communication, in addition to data lines, between the Input device and the M18 computer is also accommodated by J17. Therefore, even though J 17 is used primarily for inputting, there are several output signals available from J 17 to provide effective Input device interfacing. On the same premise, communication, in addition to data lines, between the output device and the M18 computer is also provided by J10. This requires that the primarily outputting J 10 receives several input signals to provide effective M18 to Output device interfacing.

Figure 28 is a schematic presentation of Inverters that are of a type common to both Input and Output operations.


Figure 28. Inverter

## B. Detailed Input Description

1. Input Terms to GDC, M18

Connector J17 is a Bendix-Scintilla Type PTOOSE-24-61S(005), that is mounted on the left side of the computer main frame and requires a similar plug type connector for mating. J 17 is provided for interconnecting the computer with peripheral input devices. The signals on J 17 are listed in Table II, that reveals that most of the lines connected to J 17 are input lines.

A schematic presentation of J 17 is shown in figure 29.

Table II. DESCRIPTION OF TERMS ON JI7

Term

## Description

IIG
I2G
13G
I4G Data Input Lines to GDC M18 in 8-level Alpha-numeric or I5G 5-level Teletype.
I6G
I7G
18G
TG An input to GDC M18. This term is used for strobing of the Input Data Lines IIG through I8G. This term can be configured in alternate ways and is further described in paragraph IV, B. 2.b.

TG' Refer to TG.
TGO' Inverted T'G'. From an output driver.
TEIP An output from GDC M18. This term is used in conjunction with information input. TEIP is the inverse of the TG signal.

MTF An input to M18. With the MTF line open, the M18 is in the "INPUT" mode; ground, in the "VERIFY" mode.

Table II. (Cont'd)

Term
IFS Determine parity to be sensed. If open, input data is odd parity tested; if ground, input is even parity tested.

FBIO An output from GDC M18, to an input device. This term is normally false. FBIO goes true when the M18 is in the mode to sample the information on the input lines. This signal returns to the false state when TEI' goes true. Maximum information to and from M18 is dependent on the type of information transferred. Maximum rates are:

4000 characters per second in a/n 6 mode
3500 characters per second in a/n 5 mode 500 characters per second in Octal or Decimal mode.

RGO This output signal goes true when FADAC is in an "INPUT EXTERNAL DEVICE" condition.

RHO Inverse of RGO. When FADAC goes out of the RGO mode, output term RHO goes true.

RDYO Inverted FBIO, gated with "INPUT EXTERNAL DEVICE". This output term comes true only when FADAC is in the "INPUT EXTERNAL DEVICE" mode.

PEO Parity error output. When "TRUE" a parity error has occurred.

OPL4 Discrete output lines. OPL4 is activated by operation Code OPL5 3710, OPL5 by 3712, OPL6 by 3714. Only one OPL ray be OPL6 selected at one time. Selected OPL will be turned off by subsequent selection of another OPL, or by the DOF (3700) command. The OPL lines output Drivers are schematically presented in figure 27.

GPRC' An input to M18. This term is conjunction with the GPHC' controls the "RUN-HALT" mode of the computer. With an open circuit, the computer is in the "RUN" mode; with $-10.0 \pm 1 \mathrm{~V}$ applied, the computer is in "HALT" mode.

## Table II. (Cont'd)

Term
Description
GPHC' An input to M18. This term in conjunction with GPRC' controls the "RUN-HALT" mode of the computer. With an open circuit, the computer is in the "RUN" mode; with $+6 \pm 1 \mathrm{~V}$ applied, the computer is in the "HALT" mode.

FBPR An input to M18. Initiates Octal input when computer is in manual Halt mode. Normally false (clamped to $0.0 \pm 5 \mathrm{~V}$ ) FBPR is $-10.0 \pm 1 \mathrm{~V}$ when true.

F25I Inputs to GDC M18. These terms are sampled into the "A" F26I register under program control. A one-to-one correspondence F27I exists between the $F$ subscripts and the corresponding bit poF28I sitions of the "A" register. The programming bit position F29I notation versus hardware notation is described in Section IV. F30I B.2.f.

F25 Outputs from the F25I through F30I input amplifiers.
F26
F27
F28
F29
F30
GND PWR Power Ground.
GND CH Chassis Ground.
-35V -35V Supply.
+35 Vl These voltages energize the appropriate write switches allow+35 V 2 ing the computer to write into "COLD" storage and, therefore, +35 V 3 all 8,192 words of memory.*
$1432+143$ volt zener - regulated supply.
-3V -3V regulated supply.

[^1]
## Table II. (Cont'd)

Term
PSIA An input FIELDATA Strobe ( $1-2$ microseconds) on PS1A will PSIB develop a 6 microsecond output pulse on PSIB.

NE10 Neon Driver Outputs. NE10 will go from a +100 to +120 volt NE11. level to a level between 0.0 V to -0.6 volts when computer is in a "FILL" mode. NE1l will go from a +100 to +120 volt level to a level between 0.0 V to -0.6 volts when the computer is in a "VERIFY" mode.

F14 Inputs to GDC, M18. Refer to term description of F25 through F15 F30. These inputs are to diode gates where the true state is F16 $\quad-6$ volts or open and the false state is ground $\pm 1 V$.
F17
F18
CTTI An Input to GDC M18. When computer is in the 'HALT" mode, a true signal indicates read Octal Teletype; and a false signal indicates read Octal FIELDATA. When computer is in the "RUN" mode a true signal indicates that no parity tests are to be performed on Input data.
MRTT Input to GDC, M18. When open the Mechanical Reader will read Teletype, when grounded Mechanical Reader will read FIELDATA, even parity. The terms IFS and CTTI have no affect on the mechanical reader.
*The memory of FADAC is divided into two portions; working and permanent, "HOT" and "COLD" respectively.

In the FADAC it is possible to have three different sizes of working storage. They are:

| Size | Address |
| :---: | :---: |
| Channels | 70.76 |
| 12 Channels | $50-76$ |
| 16 Channels | $40-76$ |

The size of working storage to be used is determined by the position of a switch within the computer. Electrically this switch controls the +35 V to energize memory write amplifier circuits.

To gain access to this switch, the cover must be removed from the computer. Thus the operator will not normally have access to this switch. This in turn preventing inadvertent destruction of permanent memory contents.


Figure 29. Input Connector, J17 (Part 1)

Figure 29. Input Connector, J17 (Part 2)

## 2. Input Circuitry

a. Input Data Lines - The input information to the M18 computer is accepted on the "I'" lines. These lines, Il through I8, are applied to eight corresponding input drivers. A schematic presentation of these drivers is shown in figure 26.
b. Strobe - The normal strobe for data input on IIG through I8G is TG. The information and strobe pulses are similar to those in figure 30. FBIO is not required unless operating at or above the maximum input rate. Figure 31 shows a typical input wiring configuration.


Figure 30. Input Line Timing


Figure 31. Inputting to FADAC

Other input devices can be accepted by the M18 computer as long as the "ON-OFF" voltage conditions and the rate of the input strobing action is compatible with the computer interface. Only one device at a time can be accepted by the computer and external switching must be provided to select the device applicable at that time. The external device strobe input to the M18 computer may be of the method described or one of the foliowing two methods may be employed: A steady state strobe by connecting one strobe line to TG with TEIP (the inverted TG signal) shorted back to TR' as figure 32. Where the strobe and strobe' consists of an on-off contact with inherent contact "BOUNCE" the connection should be that as shown in figure 33 to compensate for the "BOUNCE".
c. PSI Pulse Stretcher - The normal strobe for input data must be a minimum of 6 microseconds as characterized by TG. In the event that a shorter time duration strobe is to be employed, such as the 2 microsec ond FIELDATA strobe, this strobe must be expanded. PSI may be utilized to condition and expand this strobe to the required 6 microseconds.

A short strobe applied to the PSIA (pin DD) will trigger a 6 microsecond monostable multivibrator in the M18. The output of this multivibrator appears at PS1B (pin EE). Connection of this PS1B output to TG will then provide a compatible strobe for the input data, with the timing relationship as indicated in figure 34.

The trigger and multivibrator circuit of PS1 is displayed schematically in figure 35.
d. Neon Drivers - The M18 computer contains two types of neon drivers. Type 1 of figure 36 is the driver employed for the following neon indicators:
(1) Compute, NE1
(2.) In-Out, NE2
(3) Pwr Ready, NE4
(4) Fill, NE10
(5) Verify, NE11


Figure 32. Steady State Strobe


Figure 33. Mechanical Contact Strobe
data (I)
LINES

Figure 34. FIELDATA Strobe Timing

Figure 35. PS1, PS2 Pulse Stretcher


NEON DRIVER, TYPE 2

Figure 36. Neon Drivers

Two type 1 neon drivers are available at J17, pins FF and GG, NE10 and NE11, respectively.

The type 2 neon driver of figure 36, is employed for the following neon indicators:
(1) Transient, NE
(2) Temperature, NE
(3) No Solution, NE
(4) Parity, NE
(5) Overflow, NE
e. Discrete Input (F) Lines - The information bits supplied by the Input Matrix, Section III, Paragraph 8-5, and the discrete input lines on J 17 are sampled by the DIA command for placement into the "A" register. In this case the designation Fl through F13 from the Input Matrix, and F14 through F18, F25 through F30 of J17 are "HARDWARE" bit positions.

It must be noted that these hardware deaignations differ from those of the "PROGRAMMING" notations.

Fl in hardware refers to the least significant bit of the word which occurs at Tl time whereas in the programming manual this bit is defined as F31.

A correlation between programming and hardware notation is presented in figure 37. The definition of a given bit position must therefore be qualified as to whether it is a program or a hardware reference.

F25I through F30I are applied to input drivers as indicated in figure 26.

## 



## PROGRAM BIT POSITIONS

Figure 37. FADAC Bit Positions

## C. Detailed Output Description

1. Output Terms

Output connector, J10, is a Bendix-Scintilla Connector PTOOSE-22-555Y(005) mornted on the right side of the computer main frame and requires a similar connector for mating. J 10 is provided for interconnecting the M18 computer with peripheral output devices.

The signals on J10 are listed in Table III, indicating that most of the lines connected to J 10 are output lines.

A schematic presentation of J 10 is shown in figure 38.

## 2. Output Circuitry

a. Output Data Lines - The output information from the M18 computer is provided on the eight ' D ' lines. These eight lines, D100 through D800, are supplied by eight corresponding output amplifiers as shown in figure 27. The output timing is displayed in figure 39.

## Table III. DESCRIPTION OF TERMS ON Jl0

Term

D100
D200
D300
D400
D500
D600
D700
D800
AMTO Output from M18. This normally false term is true during a/n 5, a/n 4, and Decimal output modes.

IMTO Output from M18. This normally false term is true during Octal and a/n 6 output and $a / n 6$ input modes.

FBOO This M18 output term indicates when information is present on the output lines: D100 through D800.

STBO $\quad 1$ to 2 microsecond output pulse indicating when information is present on output lines, D100 through D800.

OPLl Discrete Output Lines. OPLl is activated by operation code OPL2
OPL3

FTF

EER This "ERROR RESET" input signal clears the error light and resets the computer. Computer is put into a "HALT" mode.

ESU Activation of this Input term while computer is in program halt mode will cause the transfer of control to the "RECEIVE" button lozation (Channel 00, Sector 007).

OPE Activation of this input term causes all the " $D$ " output lines to assume "O" state. True state is -6 volts or open, false state is ground $\pm 1$ volt.

Table III. (Cont'd)
Term
Description
OFS An input to M18 that determines computer output parity. If grounded, output data is "EVEN" parity*; if open, output data is "ODD" parity.

TFAI Inputs to M18. These terms are feedback signals from some TFAO' external device. These terms for strobing output data can be TI BO' configured in alternate methods as described in paragraph TFBO C. 2 of Section IV.

TEOP An M18 output term that is the inverse of TFBO'. This term is used in conjunction with information output.

F191 Inputs to GDC, M18. These terms are sampled into the "A" F20I register under program control. A one-to-one correspondence F211 exists between the $F$ subscripts and the corresponding bit po-
F221 sitions of the "A" register. The programming bit position
F23I versus the hardware notation is described in paragraph IV.
F24I B.2.f.
F19 Outputs from the F19I through F24I input amplifiers.
F20
F21
F22
F23
F24
PS2A At the time that Input PS2A goes to ground, output PS2B will
PS2B go to -3V from its normal ground level for a period of 6 microseconds. A schematic of this "PULSE STRETCHER" is presented in figure 35.

EER20 M18 Output Signals used primarily in FALT Testing.
ESU20
CLKD The internal clock or strobe (inverted clock) is available on STRD the Output Plug as CKLD and STRD respectively.

[^2]



Figure 38.
IMTO
FBOO
STBO
OPL1
OPL2
OPL3
FTF'
EER
EER20
ESU
ESU20


Figure 39. FADAC Output Timing
b. Strobe-Feedback - Alternate strobe-feedback methods may be employed when outputting data from the M18 computer to an external device. Figure 40 displays a FADAC to external output device transfer utilizing TFBO as the feedback signal.

In the situation of employing the standard FIELDATA Ready, it is necessary to invert the signal while meeting the FADAC 6 microsec ond minimum requirement. Figure 41 indicates the connections, and further portrays the use of the internal pulse stretcher figure 35 , for an effective method of feedback.


Figure 40. FADAC to Output Device Feedback


In the event of steady state feedback the method displayed in figure 42 may be employed.

Where switch contacts that possess inherent "BOUNCE" are to be employed the technique displayed in figure 43 may be applied.
c. Remote Error Reset - The remote error reset signal (EER) will reset the computer and clear the error light. The computer resets to the "HALT" mode.

The remote reset signal is gated into the computer reset line (ER) as indicated by figure 44.


Figure 42. Steady State Feedback


Figure 43. Switch Contact Feedback


Figure 44. Reset Button Interface
d. Teletype Output - There is an internal teletype oscillator that will provide a precision time reference for a computer two-wire, five-level, 60 wpm , serial type output. This oscillator employs a unijunction transistor oscillator in conjunction with a bistable flip-flop. The oscillator output is shown in figure 45.

The F 32 hardware bit line is connected to this 45.45 character/second ( 60 word per minute) oscillator and is used to sense this frequency which is a standard teletype frequency. By then sampling this term and outputting on a discrete output (OPL) line, a wire teletype output is produced.
e. Input Amplifiers and Inverters - The input Amplifiers and Inverters at J 10 are schematically presented in figure 26, Input Amplifier, and in figure 28, Inverter.


Figure 45. Teletype Output Waveform
V. TYPICAL INPUT-OUTPUT DEVICES

A number of peripheral items are serving as input-output devices with the M18 computer.

The descriptions of the following devices are presented as representative examples of interfacing with the M18 computer.

## A. Memory Loading Unit (MLU)

The photoelectric reader Signal Data Reproducer, SDR AN/GSQ64, more commonly referred to as the $M L U$, is an Input device primarily used to load programs into memory, and is pictorially displayed in figure 46.


Figure 46. Memory Loading Unit (MLU)
-Figure 47 displays the interconnections between the MLU and the computer input plug, J 17.

For this memory loading operation the manually initiated Fill mode is employed. In this mode, the computer is forced into a Manual Halt mode by a -10 volts on the GPRC' input and $a+6$ volts on the GPHC' input. Then by momentarily placing -10 volts on the FBPR input, the computer switches to the input mode, the Reader Go output (RGO) is energized and the computer accepts information from the MLU. The NE10 output is energized to light a "FILL" neon.


Figure 47. Memory Loading Unit (MLU) to FADAC Signals (Part 1)


Figure 47. Memory Loading Unit (MLU) to FADAC (Part 2)

The information on the "I" lines is "STROBED" into the computer by the inputs on the TG and TR' lines, as indicated in figure 48. The TG line in this application is turned on when the reader starts and remains on until the reader halts. When the strobe' pulse, TR' goes false, the computer advances to a "SAMPLE INFORMATION" state and will not leave this state until the TR' goes true again when it will go into a "PROCESSING" state. The information is only accepted in the "OCTAL BY WORD" format for this mode of operation. The codes may be either Teletype or FIELDATA and are shown in figure 6 and 7 of Section II. The "OCTAL BY WORD" format is a standard format for loading memory locations.


TG is turned on Steady when Photoreader is Inputting

Figure 48. MLU Timing

Separate individual characters can be used to put the computer into the "VERIFY", "FILL" or "HALT" modes. A "CLEAR" code is available to clear any information inputted since the last "ENTER". When the computer is allowed to switch into the run mode from manual halt, by removing the -10 volts from GPRC' and the +6 volts from GPHC', a "COMPUTE" code can be used for transferring to the instruction in the "I" register.

Whether the Teletype or FIELDATA code is to be interpreted depends on the CTTI input. With a -3 volts connected to CT'TI, the Teletype code applies. With CTTI left open, the FIELDA TA code applies. The IFS input term determines the parity test to be performed, odd or even. In this instance the IFS is grounded to allow the FIELDATA paper-tape format to be accepted from the MLU.

The compriter, after sampling the information, enters a "PROCESSING" state which in the Octal or BCD input modes can consume as high as 19 words times of 83 microseconds each or a total of 1577 microseconds. When f:nished "PROCESSING", the completer switches to a "WAIT FOR STROBE" state and remains there until TR', as described above, goes false again. The total "PROCESSING" time then determines the sampling rate, which for "WORST CASE" operation should be limited to 600 characters per second for Octal or BCD mojes of Input.

When the computer switches to the Halt mode by reading a "HALT" code, being reset by the Reset Button, or generating a parity error on input, the "READER HALT" (RHO) output is energized thereby halting the reader. The MLU will stop within three characters.

The +35 V is used to energize +35 V 1 , +35 V 2 , and +35 V 3 which energizes the appropriate write switches allowing the compriter to write into "COLD STORAGE" and, therefore, all 8, 192 words of memory.

The Photo-Reader can also be used under program control. In this mode of operation, the comprater remains in the "RUN" condition by leaving the GPRC' and GPHC' inputs open. The FBPR input can also be ignored since its application is only in the "HALT" condition. The comprater can now by command (see programming manual) read in information in either Teletype or FIELDATA codes in the Octal, BCD,
or Alpha-numeric formats shown in figures 5, 6, and 7 of Section II. The information would still be read in synchronously at the Photoelectric Reader rate and be strobed in the same manner as described above. However, when the computer is reading either Teletype or FIELDATA alpha-numeric codes, the "PROCESSING" time between strobes is reduced to a maximum of 3 words at $83 \mathrm{usec} /$ word. For satisfactory "WORST CASE" the maximum rate of input is then approximately 4000 characters/second. However, the MLU speed is limited to approximately 600 cps .

The MRTT input is used for the mechanical reader on the control panel. When open, it allows the mechanical reader to read the Teletype code and when grounded, the FIELDATA code applies.

The manually initiated Fill mode is applicable to both the Keyboard and Mechanical Reader, and was described in Section III. B.

## B. Digitronics Perforated Tape Reader

The Digitronics Model B3000 bidirectional perforated tape reader is designed to read 8 channel perforated tape at speeds up th 1000 characters per second, and is easily configured for FIELDATA compatibility. Figure 49 fictorially displays the Digitronics Tape Reader.

The Digitronics Tape Reader when functioning as a Memory Loading Unit (MLU) must be complemented by a unit that will provide control over the M18 computer and the tape reader.

Figure 50 indicates the cabling between J17 and the M18 compater, the tape reader and the unit providing control that is indicated as the SDR simulator. The connections and related terms between the various units is displayed in figure 51. A schematic presentation of the SDR simulator is shown in figure 52.

When functioning as an On-Line Bulk Storage Unit the Digitronics Reader may be caused to "READ" and "STOP" under the control of a computer stored program.

This can be accomplished by one of two signals. The RDYO term applied to the start circuitry of the Digitronics Tape Reader will step the reader character by character. Using the RGO term will permit


Figure 49. Digitronics Tape Reader
Copyright by Digitronics Inc.
Fermission to reproduce is granted
to U.S. Army. Franiford Arsenal


Figure 50. FADAU to Digitronic Reader Cabling

| CONNECTOR | SIGNAL | TO CONNECTOR |
| :---: | :---: | :---: |
| J17 |  | PB (SDR Simulator) |
| A | -3V1 | A |
| B | -3v | B |
| cc | -3v | C |
| u | Gnd | N |
| W | Chassis Gnd | R |
| X | +35V | T |
| NN | CTT | V |
| Y | $+35 \mathrm{~V}_{1}$ | Y |
| 2 | $+35 \mathrm{~V}_{2}$ | 2 |
| AA | $+35 \mathrm{~V}_{3}$ | a |
| BB | +145V | b |
| d | GPRC | d |
| e | GPHC ${ }^{\text { }}$ | e |
| f | FBPR | f |
| FF | NE11 | g |
| GG | NE12 | h |
| J17 | FADAC Signal/Fieldata Signal | To Digitronics Fieldata/Connector |
| J | 16G/I2 (data) | A |
| L | 18G/P (data) | B |
| DD | PS 1 //Strobe | E |
|  | PS1B |  |
| M Jumper | TG |  |
|  | TEIP |  |
| S 〕Jumper | TR ${ }^{\text {T }}$ |  |
| Y | RDYO/Ready | F |
| E | 12G/D1 (data) | J |
| F | 13G/D2 (data) | K |
| H | I5G/Il (data) | L |
| D | ILG/DO (data) | M |
| $u$ | Gnd Pwr/Ground | T +coax shield |
| w | Gnd Ch/Chassis Ground | Overall shield |
| K | I7G/C | V |
| G | I4G/D3 (data) | W |

Figure 51. Digitronic Tape Reader Connections


Figure 52. SDR Simulator
continuous reading at slew speed. I order to be FADAC compatible the tape drive was modified so that slew speed would permit an acceptable character rate.

## C. CTC Typewriter

A FIELDATA Page-Paper Tape Printer developed by Connecticut Technical Corporation, commonly referred to as the CTC Typewriter, has been operating as both an Input and an Output device with the M18 computer.

The CTC is a keyboard operated device with an integral FIELDATA compatible Paper Tape Reader and Perforator, capable of producing hard copy and transmitting to and receiving from FIELDATA lines using the FIELDATA alpha-numeric code. A functional block diagram of the FIELDATA printer is displayed in figure 53.

The integration of the CTC for inputting and outputting with the M18 are easily accomplished objectives. The CTC as an input transmitting device is connected to input connector J17 of the M18. Data is inputted on the eight " $I$ " lines, RDYO is used as the controlling signal. An additional requirement is placed on this interface in that the timing signal from the CTC is the short duration FIELDATA strobe. The M18 internal PSIA pulse stretcher is utilized to condition this signal and effective interfacing is attained.

When the CTC is to function as a receiving device, it is connected to output connector J10 of the M18. The eight " $D$ " lines transfer data to the CTC, STBO functions as the control. For comp!ete compatibility with the M18, the CTC ready signal requires inversion. Considering the proximity and availability of PS2, this pulse stretcher was employed. In this instance PS2 was used for the required inversion and not primarily for pulse expansion.

The CTC to M18 interface may be expanded and configured so as to allow the M18 to exercise additional control over the Input-Output operations.

An example of this, a method presently in use, is the utilization of the OPL lines to the CTC under cornputer program control.

Figure 53. Functional Block Diagram of FIELDATA Printer

The CTC is connected to both the Input and Output connectors, J17 and J10. The OPL lines are connected in addition to the previously described data lines and control signals. The CTC is normally in the transmitting mode. When a predetermined OPL line goes true, under program control, this line causes the CTC to go the "RECEIVE" mode to accept data from the M18.

In order to be receptive to this external control signal, OPL, minor modification is required in the CTC.

## D. Teletypewriter

A Teleprinter Corporation "Mite" teletypewriter has been employed as an M18 computer output device.

The "Mite" has continuous duty speeds of $60,75,100$, and 125 wpm based on the serial transmission of a five level baudot code. The change of speed is accomplished by the change of a "Mite" internal gear.

The M18 computer can two-wire serially output in one of two ways to the 'Mite".

One method is the use of the M18 internal teletype oscillator that can be directed to an OPL line. This was described in Section IV, C.2.d. This requires that the appropriate gear be installed in the "Mite" in order to be rate compatible.

A second and more often used method is to program the OPL lines and to use program delay techniques in order to provide the proper timing rate between the "Mite" and the M18 computer.

The "Mite" is pictorially displayed in figure 54, and is shown morunted in a special shockmornted case.

## E. LP-2-150 Paper Tape Punch

A Model LP-2-150 Soroban perforator has proven to be an effective output device for use with the M18 compater with appropriate LP2 modifications.


Figure 54. "Mite" Teletypewriter

The LP2 will record asynchronous data at any rate up to the full speed of 150 characters per second. Input 5 to 8 bit codes are accepted by the LP-2-150.

The M18 to LP2 interface utilizes the FBOO as the strobe, and TFBO as feedback. TEOP is connected to TFAI'. The total interface is reflected in figure 39.

## F. Magnetic Tape Bulk Memory

A magnetic tape bulk memory, Tape Tub, is shown in figure 55. This Tape Tub has been utilized as an auxiliary on-line bulk memory device for the M18 computer. This Tape Tub has ample storage capacity to maintain, on-line, 20 computer disc loads of information consisting of 163,840 FADAC words of information in four interchangeable tape cartridges.

Reading or recording in the Tape Tub, under computer control, may be started at any one of 32 addressable locations and terminated at any character time. Parity checking by character is performed in both read and record modes. AMTO true, an Alpha 4 condition, identifies data on the " $D$ " lines as an address. IMTO true, an Alpha 5 condition, defines the " $D$ " lines data as information.


Tape Tub

Figure 55.

A presentation of FADAC-Tape Tub interfacing with pertinent logic terms is shown in figure 56.

## G. FADAC to FADAC

To further indicate the input-output characteristics of the M18 computer, FADAC to FADAC data transferring can be accomplished by an appropriate interface.

This operation also offers alternatives in the application of strobes. One method, shown in figure 57, is a FADAC to FADAC communication link that utilizes the FADAC strobe signal. A second FADAC to FADAC interface configuration is illustrated in figure 58. In this second method the FIELDATA Ready-Strobe is employed and strobe signal conditioning by PSI and PS2 is required.

## VI. SPECIALIZED APPLICATIONS

## A. General

The previously emphasized inherent flexibility of the Input-Output capabilities of the M18 compater allow it to operate with a variety of peripheral equipment. Equipment of special design is easily adapted for connection to the M18 computer.

A number of system development programs have advocated the integration of the M18 for their particular needs. These objectives included integrating multiple and varied kinds of peripheral devices with the M18 such that they operate in an asynchronous and multiplexed mode with respect to each other and with the M18.

The following examples relate to the technical approach for system integration to further delineate the inherent input-output flexibility of the M18.

FADAC
Tape Tr :


Figure 56. FADAC - Tape Tub Interface


Figure 57. FADAC to FADAC, FADAC Strobe


Figure 58. FADAC to FADAC, Fieldata Strobe

## B. Automatic Calibration-Laboratory Evaluation Unit (Auto-Cal)

The Auto-Cal is a development program to advance accuracy and flexibility at the Field calibration level.

This objective is to be accomplished by automatically calculating, through computer control, all electrical parameters in terms of three basic parameters - Voltage, Resistance, and Time.

By employing a series of indirect measurements, self-checks and cross calibrations, the equipment then becomes a self-contained selfcalibrating measurement system which can also be used as a separate calibration device. Figure 59 is a block diagram of the Auto-Cal Systems concept.

This developed equipment, in addition to employing conventional techniques, has incorporated devices to provide a high degree of technical compliance to total input-output requirements.

## 1. Buffer-Translater (BT)

A Buffer-Translater (BT) is used to provide general communication between the computer and the measurement system. The computer directs the BT to 'make the connection', change the scale, initiate measurement cycle, etc.

Basically, the BT is a binary to decimal converter in that it accepts binary information in the form of eight (8) parallel bits at its input, decodes it and causes a change of state on one its discrete output lines. Considering that there are 256 combinations in a set of eight (8) binary bits, the BT has 256 related discrete output lines. For convenience, the output lines have been divided into sixteen (16) groups of sixteen (16) units each.

Functionally the computer by way of the Alpha-4 command will set up the eight bits on the Input lines of the BT, then issue a strobe signal. (The strobe signal indicates that data present on the output lines is to be acted upon.) Upon receipt of the strobe, the $B T$ will decode the information, cause the addressed output line to change state and then generates a feedback signal to the computer indicating that the requested action has taken place. Upon receipt of the feedback the process may be repeated.


Figure 59. Aut:oCal Systems Concept

The output lines from the computer are designated as D800 through D100. At the BT these lines are redesignated so that D800 through D500 will address the group 0 through 15, and D400 through D100 will address the unit 0 through 15. For example, if the following codes appeared on D800 through D100 (left to right) the indicated group and unit would change state.

| "D" Lines | Group | Unit |
| :---: | :---: | :---: |
| 00000010 | 0 | 2 |
| 01011010 | 5 | 10 |
| 11100001 | 11 | 1 |
| 00011111 | 1 | 15 |

The one exception is the all 0 's code (Group 0 -Unit 0 ) wherein all groups and units will be set to the " 0 " state.

During the fabrication and integration of this unit a "one-step" feature was incorporated. This caused the feedback signal to the computer to be put under manual control so that the computer will "hang-up" with the " $D$ " lines and strobe active. A manual feedback is provided so that output operations of the computer may be "one-stepped". In addition, through the use of corresponding indicators on a front panel display, a check on the validity of incoming codes may be performed.

## 2. Computer Input Interfare (CII)

The computer input interface (CII) is a $4 \times 16$ switching matrix designed to present one of four segments from the measurement and calibration components to the computer. The CII provides for the multiplexing of the input devices under control of the Buffer Translator.

These segments are sampled by the computer using the DIA (Discrete Input to the Accumulator) command. This permits the sampling of seventeen (17) input lines ("F" lines) with a single instruction at any rate up to 60 C imples per second.

The CII also provides the necessary logic level conversion and impedance matching.
3. Remote Program Addressing

The Remote Program Addressing is accomplished by switching hardware physically external to the computer, but functionally in parallel with the M18 front panel Matrix. This permits a degree of control over the computer from some remote loc ation. Figure 60 schematically shows the front panel switching that characterizes the Remote Program Addressing operation.

These switches are moanted on the Auto-Cal Console control panel and labeled with the appropriate operation to be performed.

Depressing one of these encoding switches will generate a combination of signals that are applied to the M18 "F" lines. An important characteristic of these switches is that there is a mechanical delay in the closure of the segment that provides the strobe signal to the computer. This insures that the switch combination closures are firm before strobing into the M18. The delayed strobe activates the ESU term.

The ESU term in turn transfers computer control to the "RECEIVE" memory location which contains an input program to sample the " $F$ " lines. The input program samples the " $F$ " lines into the " $A$ " register by a DIA command and then shifts these " $F$ " lines contents in " A " to the bit positions normally influenced by the Sample Matrix switches.

The Remote Program Addressing function is then interpreted by the computer in essentially the same manner as a Matrix operation.

As an example of reconfiguring, duplicate "COMPUTER RESET" buttons are employed to generate the EER term, so that from two different locations this control function can be exercised.

The number of information and control lines between the various portions of the Auto-Cal system is displayed in figure 61.

## C. MAIDS MARK III

The MAIDS MARK III is a development program to provide a system of test equipment for accurately diagnosing Tank-Automotive material. This system functions in an automatic mode and removes from

To FADAC M18


Figure 60. Remote Program Addressing


Figure 61. Auto-Cai Information and Control Lines
the diagnosis many judgment factors which of necessity depend on highly skilled personnel.

From a functional viewpoint, the MAIDS MARK III system is divided into four major subsystems and a functional block diagram is shown in figure 62.

The M18 is employed as the computer controller subsystem. The following description is directed to the M18 interface considerations and related peripheral equipment.

## 1. Input-Output Buffer (IOB)

The Input-Output Buffer (IOB) enables an M18 computer to control a variable and flexible number of external selection mojules provides up to 24 sets of form "C" relay contacts for switching. The IOB operates in conjunction with a stored program in the M18 to provide a coordination center for control and information transfer to and from the various external modules by FADAC.

In this particular application, MAIDS MARK III, the IOB connects a FADAC to a bulk storage unit (Magnetic tape), a printer and to a vast number of display, measurement, stimuli, and switching devices. This system is shown in a simplified form in figure 63. In this instance the FADAC to IOB interface is divided into four different categories based on signal destination. They are the IOB control signals, Tape Tub signals, Measurements Inputs, and Teletype signals, as described below:

## a. IOB Control Signals

The operations to be configured by the IOB are determined by 24 programming bits and an 8 bit external module address supplied by FADAC. This data is supplied by FADAC, via an "alphanumeric 6 by word output", and transferred to the IOB coincident with a discrete output line, OPL4.

In practice a sequence of OPL commands are employed. Initially a DOF is used to clear the OPL lines. Following this an OPL5 is used essentially as a reset signal to the IOB in the event that there is an error remaining from a previous operation. Then the OPL4, in conjunction with the alpha-numeric characters is used to set up the impending operation.


Figure 62. MAIDS MARK III


## b. Tape Tub Signals

The Tape Tub functions under the control of OPLl and OPL2. The OPLl is primarily a tape turn-on signal as well as defining the information on the " $D$ " lines for cartridge and track selection.

OPL2 indicates information on the " $D$ " lines that determine whether a read or write operation is to be performed and further provides the block address.

The efficiency of the Tape Tub-to-FADAC data transfer operation was improved by the use of the CTTI signal term.

In a normal mode of data transferring the Tape Tub performs a parity test that is done redundantly by the FADAC. Upon a parity error generation, the Tape Tub will provide an indication (F25l True) whereas the FADAC will indicate an error and Halts.

As indicated in Section IV, Table II, the CTTI term will prohibit parity testing by FADAC when in a "RUN" mode. Therefore, by employing the CTTI term, parity tests of transferred data will still be performed, by the Tape Tub, but the compater operations are not halted.

In this manner a transient parity error can be overcome by a repeat cycle of data transferring without halting operations.

Repetitive parity test failures after several cycles indicates a firmly established error condition requiring remedial action.

## c. Measurement Signals

All measurement inputs to the M18 will be entered as a set of 17 bits over 17 discrete inputs available on the FADAC InputOutput connectors, J17 and J10.

F30 can only be used when a "START MEASUREMENT" signal is being transmitted, since it is time shared with the IOB.

The significance of these 17 discrete inputs will vary from time to time, according to which of the measurement devices have been energized by the selection process. Furthermore, the selected $\checkmark$
measurement device will not transmit any return signals until after it receives a "START MEASUREMENT" command from the IOB. Prior to this time, the "ERROR" signal that is generated within the IOB is the only signal connected to any of the discrete input lines. This enables the FADAC program to sample and "RESET" the "ERROR" signal after all the module programming has been completed and to insure proper set-up conditions before issuing the "MEASURE" discrete output command.

## d. Teletype Signals

OPL3 is used for teletype output of data.

## 2. Computer Measurement Tirring

Transducers are an integral part of the MAIDS MARK III system and their generated signals require Analog to Digital conversion for computer processing.

A common multiplexed "A" to " $D$ " converter is employed and is under FADAC control. As an indication of real time control a TOA', M18 available output term, when "AND" gated with OPL6 can be used to trigger the transfer of measurements from the " $A$ " to " $D$ " converter to the computer.

TOA' is internally synchronized and is available at the end of each FADAC word. In order to input data to the M18 at least two word times are required; optimized as a DIA command followed by a store in memory command. By toggling a complementing Flip-Flop with TOA' the developed Flip-Flop signal is then in synchronism with FADAC at a two word rate.

This Flip-Flop developed signal available every two word times is then used as a "START MEASURE" signal under control of OPL6. This operation permits the maximum transfer rate of data to the computer at a known fixed time.

## 3. External Device Integration

In the primary FADAC concept specific "F" lines were used initially as identification lines. These lines served to indicate to the computer what specific devices were connected and on-line under program control.

As more devices become available for M18 computer adaptation, greater care must be taken when integrating a number of these components into a system configuration.

A case in point is that the MLU applies a "PRESENT" signal to F30. The IOB also utilizes $F 30$ as a return "ERROR" signal to FADAC. If precautions were not taken when using both the MLU and the IOB an :mbiguous condition would arise. Merely the presence of the MIU with its "PRESENT" signal applied to F30 could be erroneously interpreted as an IOB "ERROR" signal that is also applied to F30.

## DOCUMENTATION LISTING

TM9-1220-221- Computer, Gun Direction, M18

10
20/1
20/2
34/1
34/6
34/7
50

Operators Manual
Organization Maintenance Manual
Composite Test Program Printout
Field Maintenance Manual
Wire List (Terms)
Wire List (Components)
Depot Maintenance Manual

Reproducer, Signal Data AN/GSQ-64
12
Operators and Organizational Maintenance Manual Field and Depot Maintenance Manual

Notes on Development Type Material
FCDD-361 Volume IV Revised - Programming Manual

Memorandum Report
M66-5-1
Automatic Test Equipment, MAIDS MARK III AMCMS Code 4440.25.0029

Technical Study of the Army Calibration Program OMS 2340.1470000. 01

Final Engineering Report
Magnetic Tape Memory System
Contract DA-04-495-AMC-23(X) Phase I
Input Output Buffer, System Desc. Vol 1
Contract DA-36-038-AMC-1175(A)

## DOCUMENTATION LISTING (Coat'd)

## Final Engineering Report (Cont'd)

Paper Tape-Page Printer, Instruction Manual Reference Spec. TR-AD-20-62
Contract DA-36-039-00961(E)
Paper Tape Reader Section of the Fieldata Systems Design Reference Notebook USAEPG Contract No. DA-36-039-AMC-00954(Y)

FIRE CON TROL DEVELOPMENT AND ENGINEERIN FRANKFORD ARSENAL

LABS. Unclassified

Philadelphia, Pa. 19137 - ATTN: SMUFA-L3300
D. REPORT TITLE

COMPUTER, GUN DIRECTION M18 (FADAC) APPLICATIONS MANUAL


## . ADEThact

71. This FADAC Applications Manual is a summary document which provides informa tion required by system engineers for integrating the M18 (FADAC) with peripheral devices and equipment.

Brief introductory descriptions of the M18 characteristics and command structure are provided; whereas the input-output capabilities are discussed in detail and related logic terms are fully defined.

Descriptions of Interfacing with representative input-output devices are provided to indicate the M18 input-output operations. A brief discussion of system development programs that utilize the M18 are also provided, as examples, to further delineate the inherent input-output flexibility of the M18 for systems integration.

| Socurity Claseilication |
| :--- |
| Kev wonos |
| Computer - FADAC |
| Input and Output Devices |
| Auxiliary Memory |
| FADAC Command Instruction |


[^0]:    Reproduced by the
    CLEARINGHOUSE
    for Federal Scientific \& Technical
    Information Springfield $V_{a} 22151$

[^1]:    *See end of table.

[^2]:    *With FADAC to FADAC type output command only.

