A MANUAL

FOR

THE RICE INSTITUTE COMPUTER

September 1, 1958
# TABLE OF CONTENTS

<table>
<thead>
<tr>
<th>Section</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>I. Computer Organization</td>
<td>1</td>
</tr>
<tr>
<td>II. Octal Notation</td>
<td>6</td>
</tr>
<tr>
<td>III. Numerical Word Structure</td>
<td>9</td>
</tr>
<tr>
<td>IV. Addressing System</td>
<td>12</td>
</tr>
<tr>
<td>V. Instruction Word Structure</td>
<td>16</td>
</tr>
<tr>
<td>1. Field 1</td>
<td>18</td>
</tr>
<tr>
<td>2. Field 4</td>
<td>20</td>
</tr>
<tr>
<td>3. Field 2</td>
<td>23</td>
</tr>
<tr>
<td>4. Field 3</td>
<td>44</td>
</tr>
<tr>
<td>VI. Examples of Single Instructions</td>
<td>46</td>
</tr>
<tr>
<td>VII. Indicators</td>
<td>52</td>
</tr>
<tr>
<td>VIII. Tagging, Trapping, and Repeat</td>
<td>57</td>
</tr>
<tr>
<td>IX. Electrostatic Storage or Memory</td>
<td>61</td>
</tr>
<tr>
<td>X. Arithmetic Unit</td>
<td>64</td>
</tr>
<tr>
<td>XI. Control Unit</td>
<td>69</td>
</tr>
<tr>
<td>XII. Complement Arithmetic</td>
<td>76</td>
</tr>
<tr>
<td>XIII. Printer Output</td>
<td>79</td>
</tr>
<tr>
<td>XIV. Punched Paper Tape</td>
<td>88</td>
</tr>
<tr>
<td>XV. Fixed Point Arithmetic</td>
<td>92</td>
</tr>
<tr>
<td>XVI. Binary Point Location and Floating Point Arithmetic</td>
<td>100</td>
</tr>
<tr>
<td>Index</td>
<td>111</td>
</tr>
</tbody>
</table>

Appendix 1: Electronics of the Computer

I. Arithmetic Unit

Appendix 2: A Symbolic Assembly Program

Appendix 3: A Sample Routine
Figure I. Functional parts of the digital computer and their relationships. The arrows represent information flow.
I.

COMPUTER ORGANIZATION

The modern digital computer consists of five distinct groups of equipment which perform the following functions:

(1) input
(2) memory or storage
(3) arithmetic
(4) control
(5) output

Figure I is a block diagram of these units showing the relationships among them.

The input section consists of a photoelectric reader which takes information from punched paper tape and places it in memory and an electric typewriter which can be used to type information into the arithmetic and control sections. The arithmetic unit is always an intermediate in the flow of input information to memory. The information in question may be anything which can be stored in memory: numbers, instructions, or alphabetical and numerical comments.

The memory is an information-holding device composed of electrostatic storage tubes. One memory contains 56 storage tubes and is subdivided into distinct units called words. The memory is needed to record numbers and hold instructions. Thus, each word may be a number, an instruction, or a coded comment. Each memory unit is capable of recording up to 8,192 words, and the computer in its final form will have 4 memory units.
The memory may be thought of as $N$ little boxes or locations where numbers or instructions can be located. Each of the locations is given an identification number from 8 to $N$ (the numbers 0 to 7 are reserved for a purpose to be explained later). The label of a location is called its address (synonyms: cell, location, box). Note that the address 1371 does not mean that we can find the number 1371 stored there - except by accident; the address is purely a label or identifying number.

A memory location can hold only one word at a time, and placing a word in a location automatically destroys whatever was there previously. It is possible to read a number out of memory without destroying or removing it. A detailed description of the word and the memory unit is given in the section on electrostatic memory.

The arithmetic section does what its name implies. In addition to the basic arithmetic operations, this unit can shift numbers right and left and assist in certain operations which make it possible for the computer to make decisions. If we use the analogy of a desk calculator, this section corresponds to the upper, lower and middle dials plus the wheels and gears that actually do the calculation. A detailed description is given in the section under the heading of arithmetic unit.

Register is a term commonly used in connection with these various units. It denotes a device for temporarily storing a
piece of information while or until it is used. A register corresponds quite closely to the dials on a desk calculator. Not only numbers but also instructions may be stored in a register.

The whole computer is controlled by a certain set of specified permissible operations, and no two such operations can occur simultaneously. The permissible operations may be executed in any desired sequence. It is up to the user to specify the sequence of operations or, as it is commonly called, the program. Each permissible operation can be specified in a concise coded form called an order (synonym: instruction). For a problem to be solved on a computer, it must be broken down into a series of precise steps and this sequence is coded and usually stored in memory as ordinary numbers. The correspondence between the set of permissible operations and the set of numbers which specify them is called the order code and is described in the section on instructions.

The control section of the machine has the function of accepting orders one by one and of interpreting or decoding these instructions and then sending signals to the other units telling them what to do. The control unit is equivalent to the operation buttons which are pushed on a desk calculator. The control section is described in detail in another section.

The output units are an automatic punch for paper tape
and a fast line printer. The printer can print up to 600 lines per minute - each line containing up to 108 characters. Information may also be permanently recorded (or written) on magnetic tape.

**SUMMARY of MACHINE CHARACTERISTICS:**

The Rice Institute Computer is a megacycle computer (i.e., a basic pulse time of about 1 microsecond) with a speed that is appropriate to:

1. memory access time for reading of 10 microseconds
2. memory access time for writing of 20 microseconds
3. an addition time of 4 microseconds
4. an average multiplication time of 120 microseconds.

The machine is asynchronous, binary and parallel in operation and will have a random access memory of 32,000 words.
II.

OCTAL NOTATION

Binary numbers are very well adapted to representation by electronic circuits. Since each digit can have only two different values, zero or one, the digits of a binary number can be put into one-to-one correspondence with the electrical conditions of off-on, open-closed, non-conducting-conducting, etc. We pay for this simplicity (i.e., small amount of information per digit) by needing more digits to represent a given amount of total information than if we had used a larger number base. For example, a decimal number with N significant figures is equivalent to a binary number with $N \ln 10 / \ln 2 = N/0.30103 = 3.321 N$ digits. For example, the standard numerical word in the Rice Computer will have between 40 and 47 significant binary places. This is equivalent to about 12 to 14 decimal places.

The problem of conversion between base two and base ten is actually simple but need not concern the reader at the moment. The process will be carried out essentially automatically by the computer by means of subroutines, so that the average machine user will supply decimal input data and the computer will deliver decimal final results.

In order to discuss the instruction word and numerical word structure of the computer, we must use the full 54 bit binary machine words. It is very inconvenient to write out
such words in full and it is equally inconvenient to type them into a typewriter-tape punch. As a shorthand, we shall introduce "octal" notation. The binary number is divided into triads (groups of three bits). Instead of writing each triad in full, we shall write instead an integer between zero and seven inclusive:

<table>
<thead>
<tr>
<th>binary</th>
<th>octal</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>0</td>
</tr>
<tr>
<td>001</td>
<td>1</td>
</tr>
<tr>
<td>010</td>
<td>2</td>
</tr>
<tr>
<td>011</td>
<td>3</td>
</tr>
<tr>
<td>100</td>
<td>4</td>
</tr>
<tr>
<td>101</td>
<td>5</td>
</tr>
<tr>
<td>110</td>
<td>6</td>
</tr>
<tr>
<td>111</td>
<td>7</td>
</tr>
</tbody>
</table>

Each triad is thought of as an octal integer, and the digit written is the usual symbol for this integer. The reader is advised to memorize as soon as possible this conversion table. This conversion is of course very easy in either direction. The resulting shorthand number is actually the equivalent of the binary number written to base eight, i.e., an octal number. A 54 bit machine word becomes an 18 octal digit number, much more manageable in length. We shall use expressions such as "the second octal figure" and "the second triad" essentially synonymously. In the computer we shall have triads; on paper or at the typewriter punch we shall use octal figures.

As an example, 000101011001010100111 is equivalent to 000, 101, 011, 001, 010, 100, 111 is equivalent to 0531247.
The octal form is obviously much easier to write and to absorb at a glance.

In referring to an octal or binary number we read it from left to right. For example, "the first octal figure" refers to the figure furthest to the left (0 in the above example); "the second octal figure" or "the second triad" in the number above is 5.
III.

NUMERICAL WORD STRUCTURE

The standard word of 54 bits is divided into four fields. Bit 1 represents the sign of the exponent (0 means +, 1 means -). Bits 2 through 6 represent the magnitude of the exponent. The exponent is an integer between -31 and +31 (-11111 and +11111 in binary). The base $2^8 = 256$ is understood (see figure below). Bit 7 represents the sign of the mantissa (which is the magnitude of the fractional part of the number). Bits 8 through 54 are used for the mantissa. The binary point is understood to lie between bits 7 and 8, at the beginning of the mantissa.

```
   1   2       3     4     5     6
   7   8     9    10    11    12
   13   14   15   16   17   18

+ exponent  + point  mantissa
```

(number) = (256)\(^\pm\) (exp) (\(\pm\) mantissa)

The mantissa represents a number between zero (all 47 bits zero) and 1 - 2\(^{-47}\) (all 47 bits unity), with an attached sign. The exponent represents an additional factor of (256)\(^\pm\)(exp). The range of non-zero numbers we can represent is from (256\(^{-31}\)) (2\(^{-47}\)) to (256\(^{31}\)) (1 - 2\(^{-47}\)) or from about 10\(^{-89}\) to 10\(^{74}\).

In fixed point arithmetical operations the first six bits (sign of exp and exp) are ignored. They will usually be written
as zeros. The arithmetic is performed on the mantissa only. Such a number can only lie in the range between -(1 - 2^{-47}) and +(1 - 2^{-47}).

In floating point arithmetical operations the exponent and its sign are used, thus greatly extending the number range. A detailed description of how the machine performs floating point arithmetic is given in the section entitled "Floating Point Arithmetic."

Examples:

<table>
<thead>
<tr>
<th>octal</th>
<th>binary</th>
</tr>
</thead>
<tbody>
<tr>
<td>02715</td>
<td>000,010,111,001,101 ...</td>
</tr>
<tr>
<td>12345</td>
<td>001,010,011,100,101 ...</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>octal machine number</th>
<th>value</th>
</tr>
</thead>
<tbody>
<tr>
<td>000000 .......</td>
<td>zero</td>
</tr>
<tr>
<td>002000 .......</td>
<td>1/2</td>
</tr>
<tr>
<td>001000</td>
<td>1/4</td>
</tr>
<tr>
<td>000400</td>
<td>1/8</td>
</tr>
<tr>
<td>000200</td>
<td>1/16</td>
</tr>
<tr>
<td>003400</td>
<td>7/8</td>
</tr>
<tr>
<td>007400</td>
<td>-7/8</td>
</tr>
<tr>
<td>023400</td>
<td>(7/8) (256)^2</td>
</tr>
<tr>
<td>027400</td>
<td>(-7/8) (256)^2</td>
</tr>
<tr>
<td>423400</td>
<td>(7/8) (256)^{-2}</td>
</tr>
<tr>
<td>427400</td>
<td>(-7/8) (256)^{-2}</td>
</tr>
</tbody>
</table>
Note that a 4 added to the first triad (octal digit) makes the exponent negative; a 4 added to the third triad makes the mantissa negative.

The question probably occurs to the reader: Why do we use the large base 256 rather than the more obvious value of 2? The choice of base depends upon consideration of a number of factors (the number range desired, the minimum and maximum mantissa accuracy desired, the details of the shifting technique used in standardization of numbers, the proportion of arithmetical combinations that may be expected to require a final standardization etc.). Our choice appears to be about optimum. We lose very little as compared with base two; we gain a great deal, particularly in that floating point operations will be carried out (on the average) very nearly as fast as fixed point operations.
IV.

ADDRESSING SYSTEM

The Rice Computer will have eight full length (54 bit or 18 triad) registers (the A series), eight address or indexing (16 bit or 5 triad plus one sign bit) registers (the B series), eight special purpose (15 or 16 bit) registers, and an electrostatic memory of \(2^{15} \cdot 16\) or 32,752 full length words. The A and B series are jointly known as F registers. The special purpose and F registers are fast registers, having an access time of the order of one microsecond. The electrostatic memory addresses have an access time of about ten microseconds. The A series and the special purpose registers, together with the electrostatic series are known as M addresses.

The execution of every instruction by the computer involves (1) procuring two operands, one from an F address and one from an M address, (2) some arithmetical or logical work on these two operands, and (3) the storage of some result at an F address or a modification of the contents of some B register.
### A SERIES

<table>
<thead>
<tr>
<th>address</th>
<th>abbreviation</th>
<th>full name</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>zero or null register</td>
</tr>
<tr>
<td>1</td>
<td>U*</td>
<td>universal*</td>
</tr>
<tr>
<td>2</td>
<td>R</td>
<td>remainder</td>
</tr>
<tr>
<td>3</td>
<td>S</td>
<td>storage</td>
</tr>
<tr>
<td>4</td>
<td>T₄</td>
<td>temporary store 4</td>
</tr>
<tr>
<td>5</td>
<td>T₅</td>
<td>temporary store 5</td>
</tr>
<tr>
<td>6</td>
<td>T₆</td>
<td>temporary store 6</td>
</tr>
<tr>
<td>7</td>
<td>T₇</td>
<td>temporary store 7</td>
</tr>
</tbody>
</table>

*Note: The U register plays a special role in arithmetic operations and has 55 bits - the extra bit is called an overflow bit and its use will be explained in the detailed description of arithmetic operations. This overflow bit is always set to 0 when a number is sent to U.*

### B SERIES

<table>
<thead>
<tr>
<th>address</th>
<th>abbreviation</th>
<th>full name</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CC</td>
<td>control counter</td>
</tr>
<tr>
<td>1</td>
<td>B₁</td>
<td>B register 1</td>
</tr>
<tr>
<td>2</td>
<td>B₂</td>
<td>&quot; 2</td>
</tr>
<tr>
<td>3</td>
<td>B₃</td>
<td>&quot; 3</td>
</tr>
<tr>
<td>4</td>
<td>B₄</td>
<td>&quot; 4</td>
</tr>
<tr>
<td>5</td>
<td>B₅</td>
<td>&quot; 5</td>
</tr>
<tr>
<td>6</td>
<td>B₆</td>
<td>&quot; 6</td>
</tr>
<tr>
<td>7</td>
<td>PFL</td>
<td>pathfinder</td>
</tr>
</tbody>
</table>
M addresses range from 0 to 77777 (octal) (i.e., 0 to 32767 decimally), with 0 to 7 being from the A series and 10 to 77767 being true electrostatic memory addresses and 77770 to 77777 being the addresses of a class of special registers.

Register 0 does not actually exist. By definition it always contains zeros. The uses of address 0 will appear later. U and S (and sometimes R) are used to hold the operands of arithmetical or logical operations. After an operation, U and R hold the result. T₄ through T₇ are used to temporarily store words.

CC holds the address of the next instruction word to be fetched to the instruction register (see discussion of instruction register in section on control unit). B₁ through B₆ contain address increments to be used in certain logical manipulations of instructions. PFl is set to the current reading of CC immediately before a transfer or skip is executed.
### SPECIAL PURPOSE REGISTERS

<table>
<thead>
<tr>
<th>address</th>
<th>abbreviation</th>
<th>name</th>
<th>description</th>
</tr>
</thead>
<tbody>
<tr>
<td>77770</td>
<td>PF2</td>
<td>pathfinder 2</td>
<td>PF1→PF2 before transfer or skip executed</td>
</tr>
<tr>
<td>77771</td>
<td>SL</td>
<td>sense light register</td>
<td>holds sense light information</td>
</tr>
<tr>
<td>77772</td>
<td>X</td>
<td>increment or index register</td>
<td>adds special purpose increments to B series registers</td>
</tr>
<tr>
<td>77773</td>
<td>ML</td>
<td>mode light register</td>
<td>holds mode light information</td>
</tr>
<tr>
<td>77774</td>
<td></td>
<td></td>
<td>reserved for future use</td>
</tr>
<tr>
<td>77775</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>77776</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>77777</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

PF2 and X are 16 bit registers (5 triads plus sign); the use of the X register is described in the discussion of field 3 operations. SL and ML are 15 bit registers and are described fully in the section on indicators.
V.

INSTRUCTION WORD STRUCTURE

All instruction words are divided into four major fields.

These fields are further subdivided as follows:

<table>
<thead>
<tr>
<th>field</th>
<th>triad</th>
<th>name</th>
<th>use</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>1</td>
<td>IF</td>
<td>inflection on F</td>
</tr>
<tr>
<td></td>
<td>2</td>
<td>F</td>
<td>F address</td>
</tr>
<tr>
<td></td>
<td>3</td>
<td>C</td>
<td>class</td>
</tr>
<tr>
<td></td>
<td>4</td>
<td>Op1</td>
<td></td>
</tr>
<tr>
<td></td>
<td>5</td>
<td>Op2</td>
<td></td>
</tr>
<tr>
<td></td>
<td>6</td>
<td>Op3</td>
<td>4 operation triads</td>
</tr>
<tr>
<td></td>
<td>7</td>
<td>Op4</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>8</td>
<td>ISt</td>
<td>inflection on store</td>
</tr>
<tr>
<td></td>
<td>9</td>
<td>St</td>
<td>store address</td>
</tr>
<tr>
<td></td>
<td>10</td>
<td>IM</td>
<td>inflection on M</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td>IA: 1 bit</td>
<td>indirect address bit</td>
</tr>
<tr>
<td></td>
<td>12</td>
<td>BM: 8 bits</td>
<td>B modification of M</td>
</tr>
<tr>
<td>3</td>
<td>13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>14</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>15</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>16</td>
<td>M</td>
<td>memory address</td>
</tr>
<tr>
<td></td>
<td>17</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>18</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
An instruction word is decoded and interpreted by the computer in the I register. We shall first take an overall view of the results of this decoding, then return later to a detailed view of each section.

(1) The computer consults CC and fetches the contents of the indicated address to the I register. CC is advanced by 1.

(2) Field 1 (2 triads, IF and F) is decoded. Consequence: a word in an F address (generally a numerical word) is sent to U.

(3) Field 4 (9 triads, IM, IA, BM, M) is decoded. Consequence: a word is sent to S and an address (possibly new) is left in position M of I.

(4) Field 2 (5 triads, C, Op1, Op2, Op3, Op4) is decoded. Consequence: in general, arithmetical or logical work is done using the contents of U and S and/or the final address M (which have been set up by the two preceding steps). If the operation is arithmetical, the primary answer will be found in U and the secondary answer (if there is one) in R.

(5) Field 3 (2 triads, ISt, St) is decoded. Consequence: the contents of either U or R is sent to an F address or certain changes may be made in the contents of one of the B registers.

(6) Return to step (1).
We shall use from now on the convention that an address symbol in parentheses means the contents of that address location; the address symbol alone means the numerical value of that address. For example:

\[(M) \text{ represents the 54 bit word located at } M\]
\[M \text{ represents a 15 bit numerical address}\]
\[(B_4) \text{ represents a 15 bit number and sign stored in } B_4\]

**SUMMARY:**

The common features of every instruction, without exception, are:

1. a number $\rightarrow U$
2. an address $\rightarrow M$ in $I$
3. a number $\rightarrow S$

The instruction may then operate with any or all of these three results.

1. Field 1

The two triads of field 1 (IF,F) determine the F address of a word which is brought to U and the modification of its sign. F is a fast address. Bit 1 of IF determines whether we mean an A or a B address, a zero for A and a 1 for B. The contents of this address are fetched to U. Bits 2 and 3 of IF determine a sign modification according to the scheme:
00 means + (no sign change)
01 " - (change sign)
10 " || (absolute value)
11 " -|| (negative of absolute value)

For convenient reference we quote again a table of F addresses:

<table>
<thead>
<tr>
<th>A</th>
<th>B</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>U</td>
</tr>
<tr>
<td>2</td>
<td>R</td>
</tr>
<tr>
<td>3</td>
<td>S</td>
</tr>
<tr>
<td>4</td>
<td>T₄</td>
</tr>
<tr>
<td>5</td>
<td>T₅</td>
</tr>
<tr>
<td>6</td>
<td>T₆</td>
</tr>
<tr>
<td>7</td>
<td>T₇</td>
</tr>
</tbody>
</table>

Examples of field 1:

00 means zero → U clear
01 " (U) → U no change
40 " (CC) → U
05 " (T₅) → U
15 " -(T₅) → U
Examples of field 1 (continued):

\[ 25 \quad \text{means} \quad |(T_5)| \rightarrow U \]

\[ 35 \quad " \quad -|(T_5)| \rightarrow U \]

\[ 45 \quad " \quad (B_5) \rightarrow U \]

Whenever an integer from any \( B \) register is sent to a 54 bit register (for example, \( U \)), the 15 bit magnitude is written in the right hand end of the register and the sign bit of the \( B \) register is sent to the sign bit of the long register. All remaining bits of the register are cleared to zero. When using operations of this sort it is convenient to regard this number as an integer (either positive or negative).

2. Field 4

<table>
<thead>
<tr>
<th>IM bits</th>
<th>IA</th>
<th>BM bits</th>
<th>M triads</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PFI</td>
<td>B_6</td>
<td>B_5</td>
<td>B_4 B_3 B_2 B_1 CC</td>
</tr>
</tbody>
</table>

The nine triads of field 4 (IM, IA, BM, M) determine what word is brought to the S register and the final address residing in the I register. M is a 5 triad octal address. 000000 through 00007 refer to A addresses; 00010 through 77767 refer to electrostatic memory addresses; and 77770 through 77777 refer to the special purpose registers. BM consists of
8 bits. Counting from right to left, they refer to the 8 B addresses: CC, B₁ through B₆, and PFI. The M address as written will be modified by the sum of the contents of the B registers referred to. A zero means ignore, a 1 means use. For example:

<table>
<thead>
<tr>
<th>BM</th>
<th>meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>01 001 010</td>
<td>add (B₁) + (B₃) + (B₆) to M</td>
</tr>
<tr>
<td>10 000 000</td>
<td>add (PFI) to M</td>
</tr>
<tr>
<td>00 000 001</td>
<td>add (CC) to M</td>
</tr>
<tr>
<td>00 000 101</td>
<td>add (CC) + (B₂) to M</td>
</tr>
</tbody>
</table>

Field 4 is decoded according to the following sequence.

(1) BM is decoded and a new M is formed in I

\[ M + (B₁) \rightarrow M \]

(M is incremented by the contents of all of the B registers referred to in BM.)

(2) Test IA bit

if 0, go to step 3
if 1, form new IA, BM, M in I
[last 24 bits of (M)→I]
then return to step 1

(3) Test bit 1 of IM

if 0, (M)→S
if 1, M→S (last 15 bits of S, all others cleared to zero)

(4) Test bits 2, 3 of IM and modify the sign of (S) as
follows:

00 means + (no sign change)
01 " - (change sign)
10 " || (absolute value)
11 " -|| (negative absolute value)

Examples:

0 000 00000 zero → S
0 000 00005 (T5) → S
1 000 00077 -(77) → S i.e., the contents of location 77 goes to S
4 002 00000 (B1) → S
0 001 00005 (((CC) + 5) → S i.e., the word 5 later in the code
past the current reading of CC
0 002 00005 ((B1) + 5) → S
0 026 00005 ((B4) + (B2) + (B1) + 5) → S
4 000 00077 ...00077 → S
3 002 00077 - |((B1) + 77)| → S
0 402 00077 ((B1) + 77) → I (last 8 octal digits) followed by a reinterpretation of I.

At the end of this sequence some word will have been sent to S, with or without sign modification. This word may have come from the original M address (no 1's in BM). It may have come from M incremented by any or all of the B registers.
(note the possibilities and flexibility in the fact that the B series includes CC, PFl, and the regular B indexing registers, singly or in combination). It may have come from an address (with B modification) looked up in memory (IA bit 1). This procedure may be repeated indefinitely. Finally, we have a choice of obtaining either the contents of the final M address or the address itself, with or without sign modification in either case.

Most operations will work with the contents of U (set up by field 1) and the contents of S. Some operations, however, ignore (S) and use the final M. Examples: shifts of U and/or R, set or increment B from address, and transfers. In these cases, a 10 microsecond memory fetch time can be saved by writing a 1 in bit 1 of IM. These operations can be controlled by M. They can also be controlled by the M portion of (M) by use of the IA bit.

3. Field 2

The five triads of field 2 determine what arithmetical or logical operation takes place. C is decoded first and determines the class of the operation:

<table>
<thead>
<tr>
<th>C</th>
<th>class</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>control: compare, skip, or transfer</td>
</tr>
<tr>
<td>1</td>
<td>arithmetic</td>
</tr>
<tr>
<td>2</td>
<td>store, substitute, set tag</td>
</tr>
</tbody>
</table>
C  class
3  not used - reserved for future use
4  B register modify, set sense, shift
5  logical arithmetic
6  input-output
7  special functions

Class 0 - Control: Compare, Skip, or Transfer

This is a very flexible family of conditional transfers. Op2, Op3, and Op4 are used to specify a set of zero, one, two, or three tests. The inverse of every test is possible. Bit 1 of Op1 specifies whether we mean a favorable outcome for the whole test to be (0) a favorable outcome from any one test, (1) a favorable outcome from all tests. Bits 2 and 3 of Op1 give the action to be taken on favorable outcome, i.e., some special adjustment of CC.
class 0 operations

0) any  00) halt & tr  0) normal  00) no test  0) normal  00) no test  0) normal  00) no test
1) all  01) transfer   1) inverse  01) man +  1) inverse  01) man zero  1) inverse  01) tag 1
       10) skip by 1     10) man    10) man even   10) tag 2
       11) skip by (X)   11) exp     11) sense    11) tag 3
                          light test

man denotes mantissa  ↑ denotes overflow indicator
The first bit of Op2, Op3, and Op4 indicates whether we mean the normal form or the inverse form of the indicated test.

The various tests are applied to:

1. special indicators (e.g., overflow, tag, etc.)
2. (U) - (S) (floating point subtraction)
3. sense register

In case (2), the exponents of (U) and (S) are tested. If they are both zero, effectively a fixed point subtraction is carried out, and both (U) and (S) are left unchanged. If both exponents are not zero, a floating point subtraction is carried out, and (U) and (S) are possibly changed by shifting and normalizing procedures. In either case, the quantity (U) - (S) is not available after the test.

In a transfer order M denotes the address to which one is transferring; thus the number in S is not used. If Op1 = 0, 1, 4, or 5, zero → S before the test and we test (U) - 0 = (U). In view of this, one can also say that the computer has two classes of control orders:

1. test (U) and/or indicators and then transfer to M
2. compare (U) with (S), test indicators and then skip by 1 or (X)

If no tests are specified (i.e., an ignore test in Op2, 3, and 4), the function specified in Op1 will be executed unconditionally. Op1:

0) on any test successful, halt; transfer to M when start button is pressed
1) on any test successful, M → (CC) (transfer)
2) " " " " " " " " , (CC) + 1 → (CC) (skip)
3) on any test successful, \((CC) + (X) \rightarrow (CC)\) (relative transfer)

4) on all tests successful, halt; transfer to M when start button is pressed

5) " " " " , \(M \rightarrow (CC)\)

6) " " " " , \((CC) + 1 \rightarrow (CC)\)

7) " " " " , \((CC) + (X) \rightarrow (CC)\)

Op2:

0) ignore Op2

1) mantissa positive?

2) mantissa overflow?

3) exponent overflow?

4) ignore Op2

5) mantissa negative?

6) no mantissa overflow?

7) no exponent overflow?

Op3:

0) ignore Op3

1) mantissa zero?

2) mantissa lower bit zero? (equivalent to "mantissa even"?)

3) sense lights designated by 1's in M on?

4) ignore Op3

5) mantissa nonzero?

6) mantissa lower bit one? (equivalent to "mantissa odd")?

7) sense lights designated by 1's in M off?
Op4:

0) ignore Op4
1) tag indicator 1 on?
2) tag indicator 2 on?
3) tag indicator 3 on?
4) tag indicators all off?
5) tag indicator 1 off?
6) tag indicator 2 off?
7) tag indicator 3 off?

(4 is not the true inverse of 0 but appears to be too useful to leave out.)

Class 1 - Arithmetic

At the present, only Op2 is used. Op1, Op3, and Op4 will be ignored and may be written as zeros. (U) and (S) are combined as follows:

<table>
<thead>
<tr>
<th>Op2</th>
<th>operation</th>
</tr>
</thead>
<tbody>
<tr>
<td>0)</td>
<td>fixed point addition</td>
</tr>
<tr>
<td>1)</td>
<td>fixed point subtraction</td>
</tr>
<tr>
<td>2)</td>
<td>fixed point multiplication</td>
</tr>
<tr>
<td>3)</td>
<td>fixed point division</td>
</tr>
<tr>
<td>4)</td>
<td>floating addition</td>
</tr>
<tr>
<td>5)</td>
<td>floating subtraction</td>
</tr>
<tr>
<td>6)</td>
<td>floating multiplication</td>
</tr>
<tr>
<td>7)</td>
<td>floating division</td>
</tr>
</tbody>
</table>
That is, bit 1 determines fixed or floating arithmetic while 2 and 3 determine +, -, x, ÷. In addition and subtraction, (U) + (S)→U. In multiplication, the most significant 47 bits of the mantissa of (U) x (S) go to U, with the remaining 47 bits going to R. The exponent and sign of mantissa of R are set to agree with U. The mantissa of R is merely the continuation of the mantissa of U. Division is exactly the reverse of multiplication. (U), with the mantissa of R being understood as the continuation of the mantissa of U, is divided by (S). The exponent and sign of (R) is ignored. The quotient appears in U and the remainder in R.

In fixed point addition, the exponent part of S is simply transferred to U, replacing the previous exponent. Thus, a fixed point addition with field $\mathbf{1} = 0, 0$ is a load (or fetch) command. However, a logical "or" with field $\mathbf{1}=0,0$ is the usual load order.

**Class 2 - Store or Substitute, Set Tag**

**Op1:**

0) store (U)→M

1) substitute part of (U)→M

2) add to memory: (U) + (S)→M

3) substitute to memory: part of [(U) + (S)]→M (unless a 1 has been used in bit 1 of IM, (S) will have come from M)

**Op2:** not used

**Op3:** this triad is interpreted only for substitute orders (1 or
0) substitute the M triads of (U), i.e., last 5 triads into S and store (S)→M; note that the former contents of M are in S if correct IM is used.

1) substitute right half (27 bits) of (U)→M
2) substitute left half (27 bits) of (U)→M

Op4: this triad may adjust the tag at address M

0) set tag to no tag
1) set tag to tag 1
2) set tag to tag 2
3) set tag to tag 3
4), 5), 6), 7) ignore tag (do not change tag)

We can store (U), substitute from (U), or add (U) to memory and at the same time clear, adjust, or ignore the tag condition at M. One note of caution about the substitute order is needed. The order actually substitutes part of U into S and then stores (S) at M. In order to be a true substitute in memory order, one must be sure that bit 1 of IM is zero (i.e., (M) must first come to S).

We also note that the overflow bit in U cannot be transferred to memory since it exists only in U.
**Class 3 - Not Used**

**Class 4 - B Register Arithmetic, Shift, Set Sense and Mode Lights**

The operations of this class are all controlled by the final 15 bit integer \( M \) in \( I \). The original \( M \) is used as a number or control symbol unless \( IA = 1 \). The particular operation is specified by the triad in Op1 as follows:

**Op1:**

0) increment \((B_1)\) by \( M \), i.e., \((B_1) + M \rightarrow B_1\)

1) arithmetic shift of \( U/R \) by \( M \) places

2) set sense lights designated by 1's in \( M \)

3) logical bit count of \( R \) for \( M \) places

4) set \((B_1)\) to \( M \), i.e., \( M \rightarrow B_1\)

5) logical shift of \( U/R \) by \( M \) places

6) set mode lights designated by 1's in \( M \)

7) not used

With \( Op1 = 0 \) or 4, \( Op2 \) designates which B register is to be set to \( M \) or incremented by \( M \), as follows:

**Op2:**

0) \( B_0 \equiv CC \)  

1) \( B_1 \)

2) \( B_2 \)

3) \( B_3 \)

4) \( B_4 \)

5) \( B_5 \)

6) \( B_6 \)

7) \( B_7 \equiv PFl \)
Shifting: a short discussion of shifting in the Rice Computer will help clarify this set of instructions.

Consider a shifting register (e.g., U or R). This register may be considered to have a "donor" and an "acceptor" stage for bits. For example, when U shifts right, \( \rightarrow \), the right hand stage is the "donor" and the left hand stage is the "acceptor".

The shifts fall into two major classifications: (1) arithmetic and (2) logical. In the arithmetic class, the left hand bit of U is the overflow bit just to the left of the mantissa and the right hand bit is bit number 54; the left hand bit of R is bit number 8 (the highest order bit in the mantissa) and the right hand bit of R is again number 54. In the logical shifts, the entire word for both U and R is used, that is, the exponent sign, exponent, sign, and mantissa (the overflow bit in U being ignored). Thus for the logical shifts, the left hand bit is the exponent sign and the right hand bit is bit number 54.

\[
\begin{array}{c|c}
\text{Arithmetic} & \text{Logical} \\
\hline
\begin{array}{c|c}
\text{Mantissa} & \text{Mantissa} \\
0v & \hline
\end{array} & \\
\begin{array}{c|c|c}
\text{Exp} & \text{Mantissa} & \text{Exp} & \text{Mantissa} \\
+ & + & + & + \\
\end{array} \\
\end{array}
\]

Each register (U or R) may be shifted right or left \( m \) (mod \( 2^7 \)) times, taking into its "acceptor" stage either zeros or the spill from the "donor" of the other register. The
number of bits entering the acceptor stage is equal to \( M(\text{mod } 2^7) \), that is, the number of positions shifted.

The pattern of shifts is specified by the triads Op3 and Op4, with Op3 determining the behavior of the U register and Op4 that of the R register in the following manner:

<table>
<thead>
<tr>
<th>Bit 1</th>
<th>Bit 2</th>
<th>Bit 3</th>
<th>Bit 1</th>
<th>Bit 2</th>
<th>Bit 3</th>
</tr>
</thead>
<tbody>
<tr>
<td>into U</td>
<td>U left</td>
<td>U right</td>
<td>into R</td>
<td>R left</td>
<td>R right</td>
</tr>
<tr>
<td>&quot;acceptor&quot;</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0)zeros</td>
<td>0 times</td>
<td>0 times</td>
<td>0)zeros</td>
<td>0 times</td>
<td>0 times</td>
</tr>
<tr>
<td>1)spill from R</td>
<td>M times</td>
<td>M times</td>
<td>1)spill from U</td>
<td>M times</td>
<td>M times</td>
</tr>
</tbody>
</table>

The pattern of shifts can also be pictured in the following way:

<table>
<thead>
<tr>
<th>Op3</th>
<th>Op4</th>
<th>U</th>
<th>R</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
All shifts are controlled by the 15 bit integer $M$ in the instruction register, modulo 128.

The procedure for logical bit count is as follows:

(1) $U$ and $S$ are cleared to zero.

(2) The shift pattern specified by $Op3$ and $Op4$ is executed with the spill out of the low end of $R$ going to the lowest order stage of the adder. Thus the bits are added one at a time (with each shift) to $U$. By convention we use 0, 1 for the $Op3, Op4$ code in the bit count.

The set sense lights and set mode lights instructions
examine the 15 bits in M. The operation on the lights corresponding to 1's in M is designated by Op3 as follows:

Op3:

0) turn off lights corresponding to 1's in M
1) turn on lights corresponding to 1's in M

Lights corresponding to zeros in M are not affected.

Class 5 - Logical

Only Op1 and Op2 are used, (U) and (S) are combined by a logical operation.

0) + 00) and A* address
1) - 01) or for extract

10) sym.diff.
11) extract
These operations will work on all 54 bits. The first bit enables us to negate (one's complement) the final result. In "and", "or", and "symmetric difference" corresponding bits in U and S are compared and the usual logical result placed in U. Extract is more complicated and involves three words. Below we give the combination tables for "and", "or", and sym. diff. and their negations:

Op1:

<table>
<thead>
<tr>
<th></th>
<th>0) and</th>
<th>4) neg and</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0 0 0</td>
<td>0 1 1</td>
</tr>
<tr>
<td>1</td>
<td>0 1 1</td>
<td>1 1 0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>1) or</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0 1</td>
</tr>
<tr>
<td>1</td>
<td>1 1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>5) neg or</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0 1 0</td>
</tr>
<tr>
<td>1</td>
<td>1 0 0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>2) sym diff</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0 1</td>
</tr>
<tr>
<td>1</td>
<td>1 0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>6) sym sum</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0 1 0</td>
</tr>
<tr>
<td>1</td>
<td>1 0 1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>3) extract</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th></th>
<th>7) neg extract</th>
</tr>
</thead>
</table>

The extract order is outlined by:

(A*) thru (M) into (F)→U

The contents of an address A* (set up in Op2) is extracted through the contents of S as a mask (this word is set up by
memory address M and inflections) into (F), set up as usual by field 1. The sequence of operations is as follows:

(1) (F) → U (from field 1)

(2) (M) or M → S (from field 4)

(3) (S) → R

(4) (A*) → S

(5) The bits of (S) corresponding to 1's in (R) are substituted into U; the remaining bits of U are unchanged.

The operation neg extract merely forms the 1's complement of this final result in U.

Class 6 - Input-Output

The Rice Computer will have the following auxiliary input-output equipment:

(1) one optical paper tape reader

(2) one fast line printer

(3) one console typewriter

(4) one paper tape punch

(5) several magnetic tape units (Provision will be made in the vocabulary to be able to add an arbitrary number of units in the future. Initially there will be two units.)

Of these five pieces of equipment, the magnetic tape units will have the most complicated and versatile order code.
For a complete understanding, the reader should read the sections in this manual devoted to the detailed description of each unit. However, for the purpose of following the description of this class of orders the following brief outline will suffice.

The paper tape used is seven hole tape (i.e., the optical reader may read seven bits at a time). The information in six positions (a hexad) is transferred to and from the machine. The seventh position is used for the purpose of control and is not read into the memory. A punch in the seventh position means that the corresponding hexad is not to be read into the machine but is to be interpreted as a control on reading (e.g., delete or ignore, end of word, end of tape).

Paper tape will be prepared on an electric typewriter punch which will punch one hexad at a time.

The optical reader may be used to read (1) a whole tape at a time (terminated by an "end-of-tape" control punch) or (2) one to nine hexads at a time (as specified by the coder). The first choice may also be initiated by a load switch on the control console.
The line printer will have 64 characters. These will include the numbers from 0 through 9, mathematical symbols, lower case letters a through f, upper case letters A through Z, and special symbols. In addition, there will be provisions for format control by means of a control tape on the printer itself.

The console typewriter can be used to type octal (i.e., binary) information into the instruction register and into the S register. In addition, the console typewriter can be used to obtain the octal contents of any of the F registers (both A series and B series). This can be accomplished by means of a stored instruction or keys on the typewriter. There will be one key for each register. When a given key is struck, the contents of the corresponding register will be typed in octal.

The paper tape punch can be ordered to punch one to nine hexads at a time or special control punches.

The contents of the memory can be recorded (i.e., written) on magnetic tapes in blocks of arbitrary length. These blocks can be grouped in files.

The triad, Op1, will be used to designate the unit or units selected and their functions. The remaining triads, Op2-Op4, then are used to designate various inflections and details. Op1:

0) paper tape control (either read or punch)
1) type [(M) -> console typewriter in octal]
2) print left
3) print right
4) select and position magnetic tape unit M
5) write "end-of-file" mark
6) copy (computer → magnetic tape)
7) read (magnetic tape → computer)

The detailed description of each function is as follows.

Op2:

This triad specifies the various options on the "read paper tape" and "punch paper tape" order.

\[ \begin{array}{ccc}
<table>
<thead>
<tr>
<th>Bit 1</th>
<th>Bit 2</th>
<th>Bit 3</th>
</tr>
</thead>
<tbody>
<tr>
<td>0)</td>
<td>read</td>
<td>punch hexads</td>
</tr>
<tr>
<td>1)</td>
<td>punch</td>
<td>punch hexads</td>
</tr>
</tbody>
</table>
\]

Description of read and punch paper tape orders:

In the read \{hexad\}_\text{mode} the following sequence is executed:

\[
(F \rightarrow U \quad \{ \text{usual decoding of fields 1 and 4} \})
\]

\[
(M \text{ or } M \rightarrow S)
\]
(1) shift U left $\left\{ \frac{6}{3} \right\}$ places [logical shift]

No

(2) \{hexad\} under optical reader $\rightarrow$ U (triads 17-18)

OV

(3) test exponent overflow

(4) store (U); (U) $\rightarrow$ M

(5) decode field 3, then proceed to next instruction

In the punch \{hexad\} mode, the following sequence is executed:

(F) $\rightarrow$ U

(M) or M $\rightarrow$ S

\(\text{from fields 1 and 4}\)

(1) S $\rightarrow$ R

(2) shift UR left $\left\{ \frac{6}{3} \right\}$ places [long logical shift]

No

(3) \{hexad\} in lower order part of U $\rightarrow$ punch +

OV

\(\text{0} \rightarrow 7\text{th hole}\)

\(\text{1} \rightarrow 7\text{th hole}\)

OV

(4) test exponent overflow

(5) proceed

Bit 2 of Op2 refers only to the punch orders.

Op3:

This triad controls the various output formats of the line printer on the print order.
Op3

<table>
<thead>
<tr>
<th>Bit 1</th>
<th>Bit 2</th>
<th>Bit 3</th>
</tr>
</thead>
<tbody>
<tr>
<td>0) space</td>
<td>1 line</td>
<td>(00)</td>
</tr>
<tr>
<td>1) no space</td>
<td>1/2 line</td>
<td>(01)</td>
</tr>
<tr>
<td></td>
<td>#1 on printer format</td>
<td>(10)</td>
</tr>
<tr>
<td></td>
<td>#2 on printer format</td>
<td>(11)</td>
</tr>
</tbody>
</table>

The orders and specifications about magnetic tapes in the following discussion should be regarded as those tentatively proposed. Corrections and additions to this section will be available as soon as the final organization is decided upon.

Op4:

The positioning of the magnetic tape unit selected is controlled by this triad. Various options are available for moving the tape to obtain a desired block or file.

Op4

<table>
<thead>
<tr>
<th>Bit 1</th>
<th>Bit 2</th>
<th>Bit 3</th>
</tr>
</thead>
<tbody>
<tr>
<td>0) forward</td>
<td>ignore</td>
<td>(00)</td>
</tr>
<tr>
<td>1) backward</td>
<td>1 block</td>
<td>(01)</td>
</tr>
<tr>
<td></td>
<td>1 file</td>
<td>(10)</td>
</tr>
<tr>
<td></td>
<td>end of tape</td>
<td>(11)</td>
</tr>
</tbody>
</table>
The copy command copies the word from the S register onto magnetic tape. If successive copy commands are given within a basic magnetic tape time unit, successive words will be written onto tape. If this sequence of copy commands is interrupted, an end of block gap will occur. In addition to forming blocks in this manner, one can write an "end of file" mark on the tape and thus obtain a means of grouping blocks.

The magnetic tape may be moved forward or backward a block or a file at a time. It may also be moved to the end of the tape, thus a backward to end of tape command is effectively a "rewind."

The magnetic tape read instruction will bring (or transfer) one block at a time from magnetic tape into memory, the first word being placed in location M and with successive words in the block going to M + 1, M + 2, etc.

Class 7 - Special Functions

We plan initially to have the square root ( \( \sqrt{U} \rightarrow U \)) and eventually a number of other special functions, depending upon the need for such functions and the feasibility of building the necessary circuits.
4. Field 3

The two triads of field 3 (ISt, St) offer an additional flexibility to each instruction by allowing the coder to obtain "free" (i.e., without an additional order or access time) one of four convenient manipulations. The decoding of this field is independent of the operation code and all four choices are available with all possible orders. St is a fast address (see discussion of addresses). Bit 1 of ISt determines whether we mean an A or a B address. Bits 2 and 3 of ISt specify one of the four permissible manipulations, namely, store (U) in a fast register, store (R) in a fast register, advance B_i by 1, or advance B_i by the contents of X, the increment register.

<table>
<thead>
<tr>
<th>ISt</th>
<th>St</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

- 0) A  00) store U  F
- 1) B  01) store R  address
  - 10) (B_i)+1→B_i
  - 11) (B_i)+(X)→B_i

For the third and fourth choices (advancing a B register) a B address must be specified (i.e., bit 1 in ISt must be 1). If
field 3 is left blank (all zeros), this section will be ignored and the computer will then fetch the next instruction.

Examples of field 3:

<table>
<thead>
<tr>
<th>octal code</th>
<th>meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>ignore</td>
</tr>
<tr>
<td>34</td>
<td>meaningless - do not use</td>
</tr>
<tr>
<td>13</td>
<td>(U) → S</td>
</tr>
<tr>
<td>14</td>
<td>(R) → T₄</td>
</tr>
<tr>
<td>64</td>
<td>(B₄) + 1 → B₄</td>
</tr>
<tr>
<td>73</td>
<td>(B₃) + (X) → B₃</td>
</tr>
<tr>
<td>40</td>
<td>(U)₁₄-₁₈ → CC (an effective transfer)</td>
</tr>
</tbody>
</table>

Whenever the last 15 bits of a long register (e.g., U) are sent to a B register, the mantissa sign of the 54 bit register is also examined. If the sign is plus, the 15 bits are transferred without any change. If the sign is negative, the 2's complement of the 15 bits is placed in the B register (i.e., the number in U₁₄-₁₈ plus the sign is transferred to B).
VI.
EXAMPLES OF SINGLE INSTRUCTIONS

In order to illustrate the procedure of microprogramming instructions (that is, composing a single instruction) in machine language, the following arbitrary list of instructions is presented.

The instructions are grouped according to class. The numerical code in octal is first given for each order. The octal digits are arranged according to the following pattern:

<table>
<thead>
<tr>
<th>field 1</th>
<th>field 2</th>
<th>field 3</th>
<th>field 4</th>
</tr>
</thead>
<tbody>
<tr>
<td>XX</td>
<td>XXXX</td>
<td>XX</td>
<td>XXXX XXXX</td>
</tr>
<tr>
<td>IF, F</td>
<td>class &amp;</td>
<td>Op</td>
<td>IM, BM M</td>
</tr>
</tbody>
</table>

Below each numerical pattern is a symbolic description of what the order will accomplish. The reader is strongly advised to check the numbers against the previous outline of the order code and to try to compose a few instructions. After a few attempts, one will realize how easy it is to memorize the various field codes to compose orders.

Class 0

00 00000 00 0000 00000

Stop. A class 0 (control) order, halt and transfer variety which is unconditional; S and U are cleared, CC is set to zero.
Transfer to location 6122 if mantissa overflow indicator is on; U is unchanged and \((U) \rightarrow T_6; 6122 \rightarrow S\).

Jump forward 15 instructions. U is unchanged and the address \((CC) + 15 \rightarrow S\), thus saving a memory access time.

Skip CC by 1 when \(-(B_1) + 7 > 0\) (positive, non-zero)

Skip CC by \((X)\) when \(+ (B_2) - 7 - (B_1)\) is positive or even. In any case, advance \(B_1\) by 1.

This order can be used to search consecutive memory locations starting at 555 until a number larger algebraically than the one in \(T_4\) is found or tag 1 is reached (the end of the table). This is accomplished by assuming that \(X\) contains -1 (i.e., the two's complement of 1). As a note of caution we recommend that such an order be in the \(T\) registers or that the repeat mode be used. Otherwise the chance of a read-around error may become appreciable.
Class 1

00 10000 00 0000 12345

0 → U and (12345) → S; fixed point (U) + (S) → (U) with exponent of (S) → exponent of (U). Hence, (12345) → U.

04 10600 04 0002 12345

(T_4) x (12345 + (B_1)) → U (floating point) then (U) → T_4

41 10200 53 4004 00000

(B_1) x [(B_2) + 0] → U. R (fixed point)

(R)_{14-18} → B_3 i.e., [(B_1) x (B_3)] (mod 2^{15}) → B_3

Note that since we consider the numbers in B registers as integers, they are sent to the lower bits of U and S and the product is formed in the lower order 30 bits of R.

Class 2

01 20000 00 0000 12345

(U) → 12345 (clearing tag to zero)

07 21023 00 0002 12345

Bits 28-54 of (T_7) → bits 28-54 in location [12345 + (B_1)] with a tag 3.

03 20000 61 0002 12345

(S) → U

(12345 + (B_1)) → S

then (U) → 12345 + (B_1) and (B_1) + 1 → B_1
Together with the repeat mode, this can be used to shift a block of numbers in storage.

Class 4

44 44400 07 4002 12345

(B₄) → U → T₇ (i.e., (B₄) is saved in T₇)

12345 + (B₁) → B₄

In the same instruction 12345 + (B₁) → S, thus the new number in B₄ is also available in S.

01 40400 00 4400 12345

(B₄) + (12345)₁₄₋₁₈ → B₄

We assume that location 12345 only contains a non-zero number in the M section (triads 14-18), that is, with no modifications. This is a means of incrementing B with a number in memory.

01 45056 00 4000 00066

This instruction inverts the order of the bits in U and sends the results to R and at the same time inverts the order of the bits in R, sending the result to U.

22 46010 73 4000 50000

-(R) → U

Turn on sense lights 1 and 3

then increment B₃ by (X), i.e., (B₃) + (X) → B₃
Class 5

01 55000 00 0002 12345

(U) "or" \(12345 \div (B_1)\), then complement result.

06 53700 00 0000 12345

\((T_7)\) through \((12345)\) into \((T_6)\), result \(\rightarrow U\)

For example, consider the initial bits:

\[
\begin{align*}
T_7 & \quad 1 
1 
0 
0 
1 
\quad - 
- 
- 
- \\
12345 & \quad 0 
1 
1 
0 
0 
\quad - 
- 
- 
- \\
T_6 & \quad 0 
0 
1 
1 
1 
\quad - 
- 
- 
- \\
result & \quad 1 
1 
0 
1 
1 
\quad - 
- 
- 
- 
\end{align*}
\]

Class 6

10 60000 61 4002 01000

Read one hexad from paper tape to location \(1000 \div (B_1)\).
The hexad is located in the lower order 6 bits; all other bits are zero except the exponent sign which is negative. In addition, \((B_1) + 1 \rightarrow B_1\). If the repeat mode is used in conjunction with this order, a series of hexads can be read into a block of storage. The repeat mode light is turned off by a special control punch.

02 60100 61 4002 01000

We assume that \(R\) contains a one in bit 54 and zeros elsewhere. This order then reads 18 triads or a word from tape into memory location \(1000 \div (B_1)\). Then \((B_1) + 1 \rightarrow B_1\).
10  60600  00  0002  12345

Punch the exponent plus sign of location 12345 + (B1)
onto paper tape and punch control hole.
VII

INDICATORS

The Rice Computer will have available a number of indicators useful in determining the logical control of the problems.

Overflow and Tag Indicators

These indicators are either on or off and can be tested by means of a class 0 test instruction. Transfer of control can be effected by such instructions on either the "on" or the "off" status of the indicator. Whenever an indicator is turned on, it remains on until it is tested. When it is tested, it is turned off regardless of its prior condition. The reader is advised to study the numerical word structure before reading this section.

<table>
<thead>
<tr>
<th>abbreviation</th>
<th>full name</th>
</tr>
</thead>
<tbody>
<tr>
<td>MAN ↑ or MANOV</td>
<td>U register mantissa overflow</td>
</tr>
<tr>
<td>EXP ↑ or EXPOV</td>
<td>U register exponent overflow</td>
</tr>
<tr>
<td>tag 1</td>
<td>tag indicator # 1</td>
</tr>
<tr>
<td>tag 2</td>
<td>&quot; &quot; # 2</td>
</tr>
<tr>
<td>tag 3</td>
<td>&quot; &quot; # 3</td>
</tr>
</tbody>
</table>

The status of these indicators is displayed on the console in the form of small neon lights.
Mantissa Overflow Indicator

This indicator is turned on when a 1 is carried past the binary point of the U register into the overflow bit. The actual carry is placed in overflow bit in the U register. This can be the result of the execution of a fixed point arithmetic or an arithmetic shift command. An example is a carry resulting from an algebraic addition. The indicator can be turned off by testing it.

Exponent Overflow Indicator

This indicator is turned on when a 1 is carried past the first bit of the exponent of the U register (i.e., bit 2 in U). This can be the result of the execution of a floating point arithmetic order or a logical shift left.

Tag Indicators

When a word from memory enters the arithmetic unit through the central distributor, the two tag bits are noted according to the following code:

<table>
<thead>
<tr>
<th>Code</th>
<th>Tag</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>no tag</td>
</tr>
<tr>
<td>01</td>
<td>tag 1</td>
</tr>
<tr>
<td>10</td>
<td>tag 2</td>
</tr>
<tr>
<td>11</td>
<td>tag 3</td>
</tr>
</tbody>
</table>

If the number in memory is tagged, the corresponding tag indicator is turned on. Note that the two tag bits exist
only in memory and are not transferred to the arithmetic unit. For a discussion of the uses of tags the reader should refer to the section entitled, "Tagging and Trapping."

Sense Light Register

The sense lights are numbered 1 through 15 and are available to the coder for general use, e.g., control of printing, sequencing of orders, transfers of control, visual indication of certain phases of a calculation, and so forth.

The lights are located on the console with a switch below each light. The lights themselves correspond to the bits in the sense light register (location 77771). When a given bit position has a one in it, the corresponding light is on. The switch below each light may be (1) in a neutral position (the sense indicator is then under internal control); (2) depressed momentarily to turn on the given sense light; (3) locked in the down position which sets the sense indicator to "one" as long as the switch is down; or (4) locked in an "off" position. When a switch is in the neutral position, the sense light may be turned on or off by a set sense instruction. The status of any sense light or group of sense lights may be tested at any time. The test does not affect the status of these indicators.
Mode Light Register

The mode lights are numbered one through 15 and correspond with machine operation modes one through fifteen. Modes one through six have been assigned as noted below; the remainder are reserved for assignment to be made at a later time as need dictates.

Mode lights are essentially sense lights which control and indicate the status (in use or not in use) of their corresponding machine modes of operation. The lights are located on the console with a switch below each light. The lights themselves correspond to the bits in the mode light register (location 77773). When a given bit position has a 1 in it, the corresponding light is on, indicating that the mode is in use. The switches associated with the lights are used in exactly the same manner as those associated with the sense lights (see the previous section).

<table>
<thead>
<tr>
<th>mode light</th>
<th>control specification</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>ignore error stop mode</td>
</tr>
<tr>
<td>2</td>
<td>repeat mode</td>
</tr>
<tr>
<td>3</td>
<td>trapping mode</td>
</tr>
<tr>
<td>4</td>
<td>significance mode</td>
</tr>
<tr>
<td>5</td>
<td>round mode</td>
</tr>
<tr>
<td>6-15</td>
<td>reserved for future assignment</td>
</tr>
</tbody>
</table>
When mode light one is on, the machine ignores all automatic error stops (e.g., improper division). When mode light 2 is on, the "fetch and advance CC" operation is omitted and the computer will repeat the current order. When mode light 3 is on, the machine will operate in the trapping mode (see the section on tagging and trapping). When mode light 4 is on, the machine will perform floating point arithmetic in the significance mode (see section on floating point arithmetic). When mode light 5 is on, the high order bit of R is added into the low order end of U after floating point additions and subtractions and after all multiplications.
VIII.

TAGGING, TRAPPING, AND REPEAT

The numerical word and instruction word in the Rice Computer is 54 bits in length. However, in memory each word has two additional bits called tag bits which allow the coder to tag a word with one of three possible labels. This concept offers many novel features and possibilities in coding.

Tagging

When a number enters the arithmetic unit from a word in memory that has been labeled, it is said to be a tagged number. According to whether the tag bits are 01, 10, or 11, one of three indicators is turned on (if it is already on, there is no additional effect). This indicator may be tested, and a conditional transfer of control may be affected by the result of this test.

In cycles or loops which use a series of numbers stored in memory, it is possible to tag the last number and end the cycle or loop by testing for this tag. In two or three dimensional network problems where moving boundaries occur, it is possible to tag certain functions at the boundary points and follow their progress more conveniently. Examples of the use of tagging may be found in the section on coding examples.
Trapping

When a location in memory which has been tagged contains an instruction, it is said to have a trap tag (there is no real difference between a tag and a trap tag in memory; the nomenclature depends on whether the coder regards the word in memory as a number or an instruction).

When an instruction with a trap tag enters the instruction register and mode light number 3 (see section on indicators) is off, the instruction is interpreted as if it had no tag.

When the same instruction enters the instruction register with mode light number 3 on, the instruction is first executed and then an unconditional transfer takes place according to the following rules.

<table>
<thead>
<tr>
<th>trap transfers</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>tag 1</td>
<td>transfer control to location 9, octal 11</td>
</tr>
<tr>
<td>tag 2</td>
<td>transfer control to location 17, octal 21</td>
</tr>
<tr>
<td>tag 3</td>
<td>transfer control to location 33, octal 41</td>
</tr>
</tbody>
</table>

This mode will be used primarily in checking out programs when selected diagnostic codes will be located in memory starting at location 9, 17, and 33, respectively. Note that the contents of PF1 → PF2 and (CC) → PF1 before every transfer, including trap transfers.
Repeat Mode

As the individual instructions in an order code become more complex and flexible the need for some method of repeating a single instruction becomes increasingly important. While the order code of the Rice Computer does not justify an elaborate repeat instruction, it is of sufficient complexity to make a simple repetition mechanism desirable. Thus the repeat mode of operation has been introduced.

When mode light 2 is off, the computer fetches orders sequentially from memory and advances CC by 1. When mode light 2 is turned on, the computer executes one more "fetch and advance CC" step and then omits this step until mode light 2 is turned off. This, in effect, repeats the instruction following a set mode light 2 order. Mode light 2 is automatically turned off upon one of the following conditions:

1. any of the tag indicators on - a "tag indicator on" condition always overrules mode light 2 and keeps it turned off
2. a successful execution of a transfer or skip - usually this will be a conditional transfer or skip order that is being repeated
3. an "end of tape" control punch on paper tape

The utility of this type of repeat is illustrated in the coding examples. In conjunction with the flexible type of control
instructions available it allows the coder to construct several types of "search" commands in which a section of the memory is searched for a number satisfying a certain condition.
IX.

ELECTROSTATIC STORAGE OR MEMORY

The Rice Institute Computer will have a random access electrostatic storage. This storage section will consist of 4 independent memory units, each capable of storing up to 8,192 words. [Note: this may be changed to 4,096 words for greater reliability if necessary.]

The basic unit in this memory is a barrier grid storage tube which is pictured schematically in the following drawing:

![Diagram of barrier grid storage tube]

Information may be stored in the form of a charged spot on the front (left in the above diagram) surface of the mica disk. This is used as a binary element. For example, a plus charge at +25 volts potential relative to the metallic backplate may be interpreted as the digit "0" and a minus charge at -25 volts potential relative to the backplate may be interpreted as the digit "1".

61
The spot may be "written" or "read" by focusing an electron beam (produced by the electron gun) at the given position in conjunction with appropriate manipulations of the backplate voltage. The detailed electronic explanation of both reading and writing may be found in the technical sections on this subject. For the purposes of this discussion it is sufficient to think of the charged spot together with the backplate as a small condenser which may be charged (writing mode) or discharged (reading mode) by a beam of electrons striking the given spot. The position at which the electron beam hits the mica surface is governed by the voltage on the deflection plates. Thus there is a one to one correspondence between the voltage on the deflection plates and the position of the spot. The storage tube being used has a mica surface 2 inches in diameter and can store up to 8,192 distinct spots without any appreciable overlap.

The 8,192 spots in a given storage tube correspond to one binary position of all the words in memory. For example, each of the spots in Tube No. 5 is the fifth bit of each of the 8,192 words in this memory unit. Thus we see that for a 54 bit word we must use 54 storage tubes in each memory. In addition, each memory contains two extra tubes for tagging purposes (see section on tagging), one tube for a parity check bit (see section on error detection and checking), and a monitor tube on which the pattern of "ones" and "zeros" in any tube can be visually displayed.
In reading or writing a word in memory the computer must accept a numerical location number, convert it by means of a digital to analogue device into a set of deflection voltages and apply this to the deflection plates of all 58 tubes. The electron beam is then at the same position in all tubes and the information is transferred in parallel (i.e., all the bits in a word are read or written simultaneously).

Due to the actual physical spread of the electron beam the continuous process of reading and writing tends to destroy the overall information on the mica surface (see discussion of read-around error in the technical sections). Thus each memory unit is engaged in a regeneration process in which each spot is read and clearly rewritten. Regeneration is always interrupted when it is necessary to read or write a number. The entire pattern can be regenerated in about 50 milliseconds and as a general safety rule one should not try to read one particular word more than 1000 times within one continuous 50 millisecond period.
S register 54 bits  T registers 54 bits (4)

![Diagram of arithmetic unit](image)

U register 54 bits  R register 54 bits

plus exp overflow bit, Q

and mantissa overflow bit, OV

**Figure 2:** Block diagram of the arithmetic unit. Arrows represent, schematically, permissible paths for the flow of information excluding shifting. A detailed explanation of the parts of each register and the terms exp, mantissa, etc. can be found in the description of the numerical word structure. "Static" indicates a permanent (or static) connection. Thus the subtracter always contains the difference of the current (U) and (S)
X.

ARITHMETIC UNIT

The arithmetic unit accomplishes all arithmetic functions and has, in addition, facilities for temporary (or erasable) storage. The execution time for each function will vary from function to function and from operand to operand depending upon the number of zero bits in the operand.

The arithmetic unit is built around an information distributing device called "the central distributor," or CD. CD is not a register since it cannot store information but is only used to transfer information between registers and to and from the other units in the machine. Figure 2 is a block diagram of the arithmetic unit and is an expansion of part of the general diagram in Figure 1. The various registers are listed below and a paragraph description of each register and its function is given:

<table>
<thead>
<tr>
<th>abbreviation</th>
<th>name</th>
</tr>
</thead>
<tbody>
<tr>
<td>U</td>
<td>universal register</td>
</tr>
<tr>
<td>R</td>
<td>remainder register</td>
</tr>
<tr>
<td>S</td>
<td>subtrahend or storage register</td>
</tr>
<tr>
<td>T_4</td>
<td>temporary store No. 4</td>
</tr>
<tr>
<td>T_5</td>
<td>temporary store No. 5</td>
</tr>
<tr>
<td>T_6</td>
<td>temporary store No. 6</td>
</tr>
<tr>
<td>T_7</td>
<td>temporary store No. 7</td>
</tr>
</tbody>
</table>
Universal Register

The U register is involved in every arithmetic and logical arithmetic operation. Before subtraction it contains the minuend (note that the Rice Computer uses a subtractor rather than an adder), before the multiplication the multiplicand, and before division it contains the higher order part of the dividend. At the end of each operation the principal result is found in U. In subtraction U contains the difference, in multiplication it holds the higher order part of the product, and after division the quotient also appears in U.

Remainder Register

The R register is used partly as an intermediate in some operations and as a storage for secondary results of a calculation. The multiplier is placed in R before the execution of a multiplication instruction. This is done automatically by the computer. The lower order part of the dividend before a division is found in R. After multiplication R contains the less significant half of the product and after a division the absolute value of the remainder appears in the mantissa of R, with the sign of the dividend. In fixed point addition or subtraction R plays no role, but in floating point addition it is used (see section on floating point arithmetic). R is also used in certain logical orders (see extract order in the order code).
Subtrahend or Storage Register

Numbers coming from electrostatic memory or the control unit first appear in S before each operation. Before subtraction S contains the subtrahend, before multiplication S holds the multiplier (which is subsequently transferred to R), and before division the divisor is found in S. The contents of S after a general operation will usually be some complicated intermediate and as such will seldom be used.

Temporary Storage Registers

The computer will also have four fast registers used primarily for storing intermediate or temporary results. These are non-shifting registers and will be designated by $T_4$ to $T_7$. Instructions may be stored in these registers and will be fetched at the proper time by the control unit.

Subtractor

U and S are connected statically to the subtracter and the quantity $(U) - (S)$ is available at the output of the subtracter. This output may then be gated into U. An addition is performed by first complementing the sign of S. In actual practice (U) and (S) may be complemented during the process of subtraction for electronic reasons. This will only concern the coder when he is interested in the contents of S after an operation. Most computers in the past have used an adder instead of subtractor,
and common terminology or jargon has been the word "adder" since the result available to the coder in this case was the sum of (S) and (U).

Complementing

Both U and S have the facilities to form the 1's complement of their contents (i.e., each "$0\rightarrow 1$" and each "$1\rightarrow 0$"). The 1's complement of U may be obtained using the logical arithmetic orders. The 1's complement of S is often formed as an intermediate step in an arithmetical calculation. This is one of the reasons why (S) is generally not useful after an operation.

Shifting

Registers U, R, and S are all shifting registers and may be shifted both right and left. On any arithmetic shift order the machine automatically uses the optimum number of shifts of 8 plus shifts of 1. The logical shifts are carried out one bit at a time. U and R may be treated as a double length register and shifted together both in arithmetic operations and in logical operations.
Figure 3: Block diagram of the control registers and the relationships among them. The solid arrows represent permissible transfers of information. The dashed arrows represent static connections to the adder. Switch 1 is a 2-fold position electronic switch and switch 2 is an 8-fold position electronic switch. In this manner one of two registers may be connected to the upper side of the adder while one of 8 registers may be connected to the lower side. The B-adder also acts as a central distributor for the control section.
XI.

CONTROL UNIT

The machine's control unit has the task of accepting orders one by one into the I register and of causing the machine to carry out the operations specified according to the order in the I register. All address modification also takes place in this unit. Normally orders are obeyed by the control unit in the sequence in which they are stored in the memory. Sometimes, however, this sequence is broken and the control unit starts over at some new position in the memory. This is called a transfer of control. If control is transferred a few locations back in the memory, the machine will repeat the operations specified by the intervening orders. It is possible to cause this repetition to occur any number of times. The machine also has special facilities for the repetition of a single instruction (see section on indicators).

The occurrence of cycles and conditional transfers of control are some of the things that complicate the programming of a calculation and at the same time make the computer of practical use. If each order in the memory were to be carried out only once, the Rice Computer would get through them all in about 3 to 4 seconds (even if the memory contained nothing but orders). In actual practice, calculations vary in duration from a few minutes to many hours.
Because of the importance and the difficulty of programming this type of cyclic control, emphasis has been placed on special facilities in the control section to help the coder. This tends to make the description of the control section of this machine fairly involved. However, the prospective coder is advised to master these additional features since they make possible most of the interesting calculations and will greatly shorten his time spent in coding.

The control unit is centered around a B-adder. This plays the part of a central distributor for the control section. The last 15 bits of the instruction register or the X register can be connected to one side of this adder and one of 8 other registers described below can be connected to the other side of the adder. The adder output may then be gated (i.e., transferred) to any of these control registers, the arithmetic central distributor, or the memory. Figure 3 is a block diagram of the control registers and their interrelations. The various registers are listed below, and a brief description of each one is given:

<table>
<thead>
<tr>
<th>abbreviation</th>
<th>name</th>
</tr>
</thead>
<tbody>
<tr>
<td>I</td>
<td>instruction register</td>
</tr>
<tr>
<td>CC</td>
<td>control counter (or location register)</td>
</tr>
<tr>
<td>$B_1$</td>
<td>B register 1</td>
</tr>
<tr>
<td>$B_2$</td>
<td>B register 2</td>
</tr>
<tr>
<td>Abbreviation</td>
<td>Name</td>
</tr>
<tr>
<td>--------------</td>
<td>-----------------------</td>
</tr>
<tr>
<td>B₃</td>
<td>B register 3</td>
</tr>
<tr>
<td>B₄</td>
<td>B register 4</td>
</tr>
<tr>
<td>B₅</td>
<td>B register 5</td>
</tr>
<tr>
<td>B₆</td>
<td>B register 6</td>
</tr>
<tr>
<td>PFl</td>
<td>pathfinder 1</td>
</tr>
<tr>
<td>PF₂</td>
<td>pathfinder 2</td>
</tr>
<tr>
<td>SL</td>
<td>sense light register</td>
</tr>
<tr>
<td>ML</td>
<td>mode light register</td>
</tr>
<tr>
<td>X</td>
<td>increment register</td>
</tr>
</tbody>
</table>

**Instruction Register**

When an instruction is brought from memory into the control unit, it is placed in the instruction register where it is decoded. The instruction register is a full length 54 bit word. The last 15 binary digits (bits 40-54) specify an address or location number. It is this number that is subject to modification.

**Control Counter or Location Register**

This register with a capacity of 16 bits (15 numerical bits and one overflow bit) determines the location in memory from which the next instruction is taken. Whenever a new instruction is brought into the instruction register from memory, the CC (control counter) is advanced by 1. However, during the execution of a transfer or skip, the contents of CC may be changed to any number in the address range. When acting in the
capacity just described, the remaining bit plays no role. However, the control counter may also act as a B register (described below) and then the overflow bit indicates whether or not it represents a negative integer (see section on complement arithmetic).

B Registers

The Rice Computer has six B registers each containing 16 bits. One of the primary uses of B registers arises from their ability to modify the instruction address. When a given B register is appropriately specified (this is explained in the detailed discussion of the order code), the instruction is executed as if its address had contained the stated address plus the contents of the specified B register. The actual addition is carried out in the B-adder and only the right hand 15 bits are effective in this addition. The result of the addition is also placed in M, the address section of I.

The remaining bit (bit position 1) has the following interpretation:

"0" means the number in B register is a true integer

"1" means the number in B register is the two's complement of an integer

In the latter case, the addition of the two's complement is equivalent to a subtraction of the integer (see section entitled "Complement Arithmetic").
When a number is transferred from a full length register in the arithmetic unit (which contains sign and magnitude) to a B register, its sign is examined. If the sign is zero (+), the number is just transferred and the overflow bit in B is set to zero. If the sign is one (-), the two's complement of the number is transferred to the B register and the overflow bit is set to one. Of course only the last 15 bits of the full length register are transferred.

When a number is read out of a B register into the arithmetic unit, its overflow bit is examined. If it is zero, the contents of the B register are placed in the last 15 bits of the specified arithmetic register and all other bits (including sign) are set to zero. If the overflow bit is one, the two's complement of the B register is placed in bits 40-54 of the arithmetic register, the sign is set to minus, and all other bits are set to zero.

Pathfinder Register 1

Whenever a transfer or skip is about to be executed, the contents of CC are placed into the pathfinder register. The PFl register may also be used as a B register.

Pathfinder Register 2

Whenever a transfer or skip is about to be executed, the contents of PFl (before the above modification) are placed into
PF2. PF2 may not be used as a B register. Its address is \((77770)_{8}\).

**Sense Light Register**

The sense light register is a 15 bit register with address \((77771)_{8}\). The uses of the sense light register are outlined in the section entitled "Indicators."

**Mode Light Register**

The mode light register is a 15 bit register with the address \((77773)_{8}\). Its uses are outlined in the section entitled "Indicators."

**Increment Register**

The X or increment register is a 16 bit register with address \((77772)_{8}\). The contents of this register may be added to the contents of any of the B series registers, with the sum being placed back into the B register.

**B-Adder**

As mentioned earlier, the B-adder controls the transfer of information and carries out the address modification specified. It is purely an adder and has not complementing facilities, and thus, the complement system of numbers must be used. The reader is referred to the discussion on complement arithmetic.
XII.

COMPLEMENT ARITHMETIC

The Rice Computer will have a set of B registers for effective address modification. In this modification the contents of a B register are added to the address or location number specified in the order. This is accomplished by using complement arithmetic (as opposed to a sign and magnitude system used in the ordinary arithmetic). The following description for a three bit number is intended to clarify the principal features of this type of arithmetic. The reader can easily extend these principles to the 15 bit numbers used in the machine. Consider as an example the following:

```
  1  2  3  4
```

overflow    point
bit

The location of the fixed binary point is to the right of the 4th position. Thus we consider only integers. Bits 2, 3, and 4 comprise the number (e.g., 101 represents the integer 5). Bit 1 is an overflow bit (equals 0 for an integer) and is closely related to the sign of the number. Before explaining this relation we have the following definitions:

(1) The one's complement of a binary number is defined as that number which results by replacing each 1 in
a number by a 0 and each 0 by a 1. For example, the one's complement of 0101 would be 1010. Note that the sum of a binary number and its one's complement is a binary number composed of all ones (0101 + 1010 = 1111).

(2) The two's complement of a binary number is defined as the one's complement of a number increased by 1. For example the two's complement of 0101 is 1011. If the two's complement of a number \( X \) is added to a number \( Y \), the result is equivalent to a subtraction \( Y - X \). For example:

\[
\begin{align*}
Y &= 0101 = 5 \\
X &= 0010 = 2 \\
\overline{X} &= 1110 \\
Y + \overline{X} &= 0011 = 3
\end{align*}
\]

where all resulting carries to the position past bit 1 will be lost.

From the above discussion we see that we can represent a positive integer by the binary number with a zero in the overflow position and a negative integer by its two's complement. A one in the overflow position thus means a negative number.

This method of representing positive and negative numbers is completely analogous to the common type of desk calculator in which a negative number is represented by its 10's complement.
The overflow position is never used as part of the number; it just indicates whether the group of binary bits is a positive number (bit $1 = 0$) or whether the group of binary bits represents the two's complement of a number (bit $1 = 1$).

Further examples:

$$Y = 0011 = 3$$
$$X = 0111 = 7$$
$$\overline{X} = 1001 = -7$$
$$Y + \overline{X} = 1100 = -4$$

Whenever an integer is transferred from the arithmetic unit (where it is represented by a sign and magnitude) to the control unit, the sign is examined. If it is $+$, the integer is transferred as is and the overflow position in the control register is set to 0. If the sign is $-$, the two's complement of the integer is sent to the B series register with a 1 in the overflow position.
XIII.

PRINTER OUTPUT

When paper tape is read into the memory, the only requirement is that the information gets into memory in convenient form. The format on the paper tape is not of great importance. However, the printer output must not only satisfy the peculiarities of the machine but must also produce an easily readable report.

This requirement is partially met by having 64 different symbols available on the printer and a format control tape on the printer.

Available Symbols

The printer will have 64 symbols which may be used in any way the coder desires. The 64 symbols may be put into a one to one correspondence with the 64 binary numbers which a hexad (six binary bits) is capable of representing. For convenience and uniformity of notation the correspondence given in the following table has been adopted. The order of symbols is also the order in which they occur on the printer type wheel. The binary code only refers to the position of the symbol on the print wheel, and it is not in general the binary code that is used on punched paper tape.
<table>
<thead>
<tr>
<th>symbol</th>
<th>octal code</th>
<th>binary code</th>
<th>comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>00</td>
<td>00 0000</td>
<td>ordinary</td>
</tr>
<tr>
<td>1</td>
<td>01</td>
<td>00 0001</td>
<td>decimal numbers</td>
</tr>
<tr>
<td>2</td>
<td>02</td>
<td>00 0010</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>03</td>
<td>00 0011</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>04</td>
<td>00 0100</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>05</td>
<td>00 0101</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>06</td>
<td>00 0110</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>07</td>
<td>00 0111</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>10</td>
<td>00 1000</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>11</td>
<td>00 1001</td>
<td></td>
</tr>
<tr>
<td>a</td>
<td>12</td>
<td>00 1010</td>
<td></td>
</tr>
<tr>
<td>b</td>
<td>13</td>
<td>00 1011</td>
<td></td>
</tr>
<tr>
<td>c</td>
<td>14</td>
<td>00 1100</td>
<td></td>
</tr>
<tr>
<td>d</td>
<td>15</td>
<td>00 1101</td>
<td></td>
</tr>
<tr>
<td>e</td>
<td>16</td>
<td>00 1110</td>
<td></td>
</tr>
<tr>
<td>f</td>
<td>17</td>
<td>00 1111</td>
<td></td>
</tr>
<tr>
<td>+</td>
<td>20</td>
<td>01 0000</td>
<td></td>
</tr>
<tr>
<td>-</td>
<td>21</td>
<td>01 0001</td>
<td></td>
</tr>
<tr>
<td>/</td>
<td>22</td>
<td>01 0010</td>
<td></td>
</tr>
</tbody>
</table>
| .      | 23         | 01 0011    | plotting symbols:
<p>| .      | 24         | 01 0100    | each symbol is    |
| x      | 25         | 01 0101    | duplicated so that|
| x      | 26         | 01 0110    | graphs may be     |</p>
<table>
<thead>
<tr>
<th>symbol</th>
<th>octal code</th>
<th>binary code</th>
<th>comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>Δ</td>
<td>27</td>
<td>01 0111</td>
<td>plotted to 1/2</td>
</tr>
<tr>
<td>Δ</td>
<td>30</td>
<td>01 1000</td>
<td>a character width</td>
</tr>
<tr>
<td>*</td>
<td>31</td>
<td>01 1001</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>32</td>
<td>01 1010</td>
</tr>
<tr>
<td>(</td>
<td>33</td>
<td>01 1011</td>
<td></td>
</tr>
<tr>
<td>)</td>
<td>34</td>
<td>01 1100</td>
<td></td>
</tr>
<tr>
<td>×</td>
<td>35</td>
<td>01 1101</td>
<td>multiplication symbol</td>
</tr>
<tr>
<td>=</td>
<td>36</td>
<td>01 1110</td>
<td></td>
</tr>
<tr>
<td>,</td>
<td>37</td>
<td>01 1111</td>
<td></td>
</tr>
<tr>
<td>A</td>
<td>40</td>
<td>10 0000</td>
<td>full alphabet in</td>
</tr>
<tr>
<td>B</td>
<td>41</td>
<td>10 0001</td>
<td>upper case type</td>
</tr>
<tr>
<td>C</td>
<td>42</td>
<td>10 0010</td>
<td></td>
</tr>
<tr>
<td>D</td>
<td>43</td>
<td>10 0011</td>
<td></td>
</tr>
<tr>
<td>E</td>
<td>44</td>
<td>10 0100</td>
<td></td>
</tr>
<tr>
<td>F</td>
<td>45</td>
<td>10 0101</td>
<td></td>
</tr>
<tr>
<td>G</td>
<td>46</td>
<td>10 0110</td>
<td></td>
</tr>
<tr>
<td>H</td>
<td>47</td>
<td>10 0111</td>
<td></td>
</tr>
<tr>
<td>I</td>
<td>50</td>
<td>10 1000</td>
<td></td>
</tr>
<tr>
<td>J</td>
<td>51</td>
<td>10 1001</td>
<td></td>
</tr>
<tr>
<td>K</td>
<td>52</td>
<td>10 1010</td>
<td></td>
</tr>
<tr>
<td>L</td>
<td>53</td>
<td>10 1011</td>
<td></td>
</tr>
<tr>
<td>M</td>
<td>54</td>
<td>10 1100</td>
<td></td>
</tr>
<tr>
<td>N</td>
<td>55</td>
<td>10 1101</td>
<td></td>
</tr>
<tr>
<td>O</td>
<td>56</td>
<td>10 1110</td>
<td></td>
</tr>
<tr>
<td>symbol</td>
<td>octal code</td>
<td>binary code</td>
<td>comments</td>
</tr>
<tr>
<td>--------</td>
<td>-----------</td>
<td>-------------</td>
<td>------------------------</td>
</tr>
<tr>
<td>P</td>
<td>57</td>
<td>10 1111</td>
<td></td>
</tr>
<tr>
<td>Q</td>
<td>60</td>
<td>11 0000</td>
<td></td>
</tr>
<tr>
<td>R</td>
<td>61</td>
<td>11 0001</td>
<td></td>
</tr>
<tr>
<td>S</td>
<td>62</td>
<td>11 0010</td>
<td></td>
</tr>
<tr>
<td>T</td>
<td>63</td>
<td>11 0011</td>
<td></td>
</tr>
<tr>
<td>U</td>
<td>64</td>
<td>11 0100</td>
<td></td>
</tr>
<tr>
<td>V</td>
<td>65</td>
<td>11 0101</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>66</td>
<td>11 0110</td>
<td></td>
</tr>
<tr>
<td>X</td>
<td>67</td>
<td>11 0111</td>
<td></td>
</tr>
<tr>
<td>Y</td>
<td>70</td>
<td>11 1000</td>
<td></td>
</tr>
<tr>
<td>Z</td>
<td>71</td>
<td>11 1001</td>
<td></td>
</tr>
<tr>
<td>&lt;</td>
<td>72</td>
<td>11 1010</td>
<td>less than sign</td>
</tr>
<tr>
<td>&lt;=</td>
<td>73</td>
<td>11 1011</td>
<td>less than or equal</td>
</tr>
<tr>
<td>↑</td>
<td>74</td>
<td>11 1100</td>
<td>exponent symbol</td>
</tr>
<tr>
<td>←</td>
<td>75</td>
<td>11 1101</td>
<td></td>
</tr>
<tr>
<td>→</td>
<td>76</td>
<td>11 1110</td>
<td></td>
</tr>
<tr>
<td>↓</td>
<td>77</td>
<td>11 1111</td>
<td>subscript symbol</td>
</tr>
</tbody>
</table>

The printer can print up to 108 characters on each line but only 54 at a time. The left hand 54 positions are handled in parallel by a single "PRINT LEFT" command, while the right hand 54 positions are controlled by the "PRINT RIGHT" instruction. Thus to print one full line we must use the sequence:

(1) "print left--do not space" followed by "print right"
or

(2) "print right--do not space" followed by "print left"

Each print order is executed in 0.1 second. Thus one can print up to 600 half lines per minute or 300 full lines per minute.

In discussing the print format, which is identical for both print orders, it is helpful to consider a layout chart as illustrated in Figure 4. This chart has a square for each position on the paper where a symbol can be printed. Charts of this sort are useful in planning the programming of the output. This layout may be done for each line individually or once for the entire output if a standard format is used for all the lines.

To print one half line (either left or right half) on the printer the coder must reserve 64 consecutive words in memory, this block being called a "print-matrix." The execution of one print order will include consideration of each of the 64 words of the print-matrix beginning with (M), these corresponding respectively to the symbols on the printer type wheel in the order listed above; each symbol will be printed in the columns which correspond to those bits of its word in the print-matrix that contain 1's. In Figure 5 is given schematically the print-matrix which will produce the left half of line 1 shown on the layout chart of Figure 4. Note that a new print-matrix must be constructed for every half line of print.
With the convention of 64 word print-matrices the maximum printing speed of 600 half lines per minute can not be attained for a number of consecutive lines because the actual printing will consume 0.1 second and the paper advance will in addition consume another 0.1 second. If all of the symbols required for one printed line are included in, say, the first 10, 24, or 56 symbols as listed, the print-matrix may be just 10, 24, or 56 words long, respectively. The last word of the matrix must then be indicated with a tag 3. In such a case, the print order will include consideration of consecutive words in memory until a tag 3 is reached; then the paper will be advanced as specified in the order. If the print-matrix consists of 54 or fewer words, the spacing will not consume an extra 0.1 second but will be accomplished within the 0.1 second period required to print the half line. Thus printing will be done at the rate of 600 half lines per minute only if the print orders which include spacing refer to print-matrices of 54 or fewer words and if the time necessary for the formation of matrices does not have to be considered.

In a "print right" or "print left" instruction the coder specifies the address of the first word of the print-matrix and whether or not the printer should space (i.e., advance the paper) after printing. Various choices of the paper advance are available. Only one symbol should be specified for a given column
in a single print-matrix. For example, in the sample given in Figure 5 a one in bit 32 of word 5 and a one in bit 32 of word 35 should not be given. In general, only the first symbol specified will be printed, but it is possible that the second symbol will be printed over the first; the actual output in such an instance is difficult to predict.

In actual practice the formation of the print-matrix will be accomplished by a set of subroutines. Subroutines will be available for the common types of tables in fixed and floating point numbers. The coder will be able to select a subroutine for his purposes (e.g., a routine that will print five columns of ten digit numbers in standard floating point form) including a limited number of alphabetical routines that will print specified column headings, etc.
<table>
<thead>
<tr>
<th>column</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>----</th>
<th>5354</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>----</th>
<th>525354</th>
</tr>
</thead>
<tbody>
<tr>
<td>line</td>
<td>1</td>
<td>2</td>
<td>3</td>
<td>4</td>
<td>5</td>
<td>6</td>
<td>7</td>
<td>8</td>
<td>9</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td></td>
<td>ATM</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>DENSITY OF</td>
<td>---</td>
<td></td>
<td>ATM</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td>T (DEG • K) t</td>
<td>---</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td>270 • 0</td>
<td>71</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>270 • 5</td>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td>271 • 0</td>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td>271 • 5</td>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 4: Example of a print layout chart.
| symbol | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | ... | 54 |
|--------|---|---|---|---|---|---|---|---|---|----|----|     |    |
| O      | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |    |    |     | 0  |
|        |   |   |   |   |   |   |   |   |   |    |    |     | | 0 |
|        | C | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |    |    |     | | C |
|        |   |   |   |   |   |   |   |   |   |    |    |     | |   |
|        | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |    |    |     | | C |
| D      |   |   |   |   |   |   |   |   |   |    |    |     | | | |
| E      | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |    |    |     | | 0 |
| F      |   |   |   |   |   |   |   |   |   |    |    |     | | | |
| I      | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |    |    |     | | C |
|        |   |   |   |   |   |   |   |   |   |    |    |     | | | |
| N      | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |    |    |     | | 0 |
| O      |   |   |   |   |   |   |   |   |   |    |    |     | | | |
| S      | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |    |    |     | | 0 |
| T      |   |   |   |   |   |   |   |   |   |    |    |     | | C |
| Y      | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |    |    |     | | 0 |

Figure 5: Schematic drawing of print-matrix for left half of line 1 in Figure 4.
XIV.

PUNCHED PAPER TAPE

The initial input to the computer will be 7-hole punched paper tape which will be read by a photoelectric reader. The diagram below illustrates the terms used in discussing punched paper tape:

![Diagram of punched paper tape]

The positions are located across the width of the tape and are places where data holes can be punched. A frame is a column whose location along the length of the tape is defined by the feed hole.

The computer reads positions 1-6 in a frame sensing a hole as a 1 and a blank as a zero. If position 7 is blank, the information in 1-6 enters the U register. If position 7 is punched, the information in 1-6 is not entered into the computer proper. Thus, a hole in position 7 is effectively a delete mark. However, there are a few combinations of punches (all of
which have the 7th hole) which act as control punches. They are **not** read into the U register but may affect the control of the reading process. A table of control punches may be found at the end of this section.

The tape is prepared by a "Flexowriter" combination typewriter and punch, whose keyboard layout is illustrated in Figure 6. Every key on the central keyboard will type a character on the paper in the typewriter and at the same time if the "punch on" control key is down, a six bit code will be punched into positions 1-6 on the paper tape frame under the typewriter punch. A table giving the binary code for each key can be found below. Many of the control keys (upper case, lower case, carriage return, tab, etc.) will not only carry out their designated function, but will also punch a six bit code into the paper tape. Depressing the "7th hole also" key by itself will not have any visible effect, but if this key is down and another key is struck, the corresponding six bit code plus a hole in position 7 will be punched. Several special control keys (tape feed, code delete, stop code and space) automatically punch the 7th position since this information need never be read by the computer proper. Note that the upper case and lower case symbols on a given key have the **same** binary code. The computer can only distinguish the two symbols by noting whether or not the symbol is preceded by an "upper case" or "lower case" punch.
A punched paper tape may be read by the Flexowriter which will type the characters specified and if desired punch a duplicate tape. All punches and operations may be duplicated in this manner except "code delete" and "stop code." "Code delete" punches will be ignored and "stop code" punches will stop the automatic action of the typewriter. A 7th position hole will be duplicated but will not affect the typing of the machine. The back space key will simply back space the carriage and paper tape one position but will not punch the tape.

<table>
<thead>
<tr>
<th>key</th>
<th>code</th>
<th>key</th>
<th>code</th>
</tr>
</thead>
<tbody>
<tr>
<td>L-case</td>
<td>U-case</td>
<td>L-case</td>
<td>U-case</td>
</tr>
<tr>
<td>a</td>
<td>A</td>
<td>0100 000</td>
<td>w</td>
</tr>
<tr>
<td>b</td>
<td>B</td>
<td>0100 001</td>
<td>x</td>
</tr>
<tr>
<td>c</td>
<td>C</td>
<td>0100 010</td>
<td>y</td>
</tr>
<tr>
<td>d</td>
<td>D</td>
<td>0100 011</td>
<td>z</td>
</tr>
<tr>
<td>e</td>
<td>E</td>
<td>0100 100</td>
<td>0</td>
</tr>
<tr>
<td>f</td>
<td>F</td>
<td>0100 101</td>
<td>1</td>
</tr>
<tr>
<td>g</td>
<td>G</td>
<td>0100 110</td>
<td>2</td>
</tr>
<tr>
<td>h</td>
<td>H</td>
<td>0100 111</td>
<td>3</td>
</tr>
<tr>
<td>i</td>
<td>I</td>
<td>0101 000</td>
<td>4</td>
</tr>
<tr>
<td>j</td>
<td>J</td>
<td>0101 001</td>
<td>5</td>
</tr>
<tr>
<td>k</td>
<td>K</td>
<td>0101 010</td>
<td>6</td>
</tr>
<tr>
<td>l</td>
<td>L</td>
<td>0101 011</td>
<td>7</td>
</tr>
</tbody>
</table>
Figure 6: Keyboard Layout - Flexowriter Model - FL
<table>
<thead>
<tr>
<th>key</th>
<th>code</th>
<th>key</th>
<th>code</th>
</tr>
</thead>
<tbody>
<tr>
<td>L-case</td>
<td>U-case</td>
<td>7654</td>
<td>321</td>
</tr>
<tr>
<td>m</td>
<td>M</td>
<td>0101</td>
<td>100</td>
</tr>
<tr>
<td>n</td>
<td>N</td>
<td>0101</td>
<td>101</td>
</tr>
<tr>
<td>o</td>
<td>O</td>
<td>0101</td>
<td>110</td>
</tr>
<tr>
<td>p</td>
<td>P</td>
<td>0101</td>
<td>111</td>
</tr>
<tr>
<td>q</td>
<td>Q</td>
<td>0110</td>
<td>000</td>
</tr>
<tr>
<td>r</td>
<td>R</td>
<td>0110</td>
<td>001</td>
</tr>
<tr>
<td>s</td>
<td>S</td>
<td>0110</td>
<td>010</td>
</tr>
<tr>
<td>t</td>
<td>T</td>
<td>0110</td>
<td>011</td>
</tr>
<tr>
<td>u</td>
<td>U</td>
<td>0110</td>
<td>100</td>
</tr>
<tr>
<td>v</td>
<td>V</td>
<td>0110</td>
<td>101</td>
</tr>
</tbody>
</table>

- upper case: 0001 011
- lower case: 0001 100
- tab: 0010 010
- tape feed: 1011 000

control punches

"stop code" - turns off repeat mode light
7th hole - frame is not read into U
XV.

FIXED POINT ARITHMETIC

For a complete understanding of coding, it is necessary to have a fairly thorough grasp of how the computer handles arithmetic. For the purpose of illustration we will consider here a 4 bit mantissa and 2 bit exponent number. The reader may easily extend this to a larger number of bits. Of course, for fixed point work the exponent is ignored.

Fixed Point Add or Subtract

The basic unit for arithmetic is the adder which we may picture in the following schematic example where the number +.1001 is in S and +.0101 in U:

```
  1 2 3 | 4 5 6 7 8 l
  + EXP + MANTISSA
  0 0 0 0 1 0 0 1 0

  S REGISTER
  1 1 1 1 0 1 1 0 1

  complement

  adder
  +1 carry in

  U REGISTER
  + EXP + MANTISSA
  0 0 0 0 0 1 0 1 0

  R register
  + EXP + MANTISSA
  1 2 3 4 5 6 7 8
```
We note that:

(1) Both S and U contain a stage at the lower end called $l$. This stage is used in the addition but is not part of the register and does not take part in the shifting.

(2) U has an overflow bit, OV, that contains the result of overflow to the left of bit 5 but is not connected to the adder.

(3) The complement of (S) is connected to one side of the adder, not (S) proper. Thus the output of the adder is related to the difference (U) - (S). That is in our example we write (ignoring the exponents)

\[
\begin{array}{ccccccc}
4 & 5 & 6 & 7 & 8 & \downarrow \\
S & - & 0 & 1 & 0 & 0 & 1 & 0 \\
SC & 1 & 0 & 1 & 1 & 0 & 1 \\
U & 0 & 0 & 1 & 0 & 1 & 0 \\
\text{adder output} & 1 & 1 & 0 & 1 & 1 & 1
\end{array}
\]

(4) The lower stage, $l$, always has a + 1 carry in, i.e., + 1 is always added to $l$. Thus the complete situation in our example is -

\[
\begin{array}{cccccccc}
\text{sign} & \text{mantissa} & & & & & & \\
4 & 5 & 6 & 7 & 8 & \downarrow & \\
S & - & 0 & 1 & 0 & 0 & 1 & 0 \\
SC & 1 & 0 & 1 & 1 & 0 & 1 \\
U & 0 & 0 & 1 & 0 & 1 & 0 \\
\text{carry in} & 0 & 0 & 0 & 0 & 0 & 1 \\
\text{adder output} & 1 & 1 & 1 & 0 & 0 & 0
\end{array}
\]

Note: adder output is not (U)-(S) at this point.
The rules for subtraction are as follows:

```plaintext
          \[ \text{case I} \]  \quad \begin{align*}
          \text{sign } U &= \text{sign } S \\
          \text{mant } U > \text{mant } S &\quad \text{mant } U < \text{mant } S
          \end{align*}
```

\[ \text{IA} \quad \rightarrow \quad \text{IB} \]

```
(1) adder output \rightarrow U \\
(2) sign U \rightarrow U \\
(3) sign U \rightarrow U \\
(4) \quad \text{overflow } \rightarrow \text{OV past bit 5}
```

Case IA is distinguished electronically by the fact that it always gives an overflow to the left of bit 5 while case IB never gives this overflow.

Case I is distinguished from case II by examining the adder output at the sign stage (position 4). This is zero for I and one for II.

The rules for addition are the same as those for subtraction supplemented by the addition of \( a + 1 \) to the sign bit (bit 4) in the adder.

The reader is strongly advised to check these rules with a few examples, say,

\[
(U) - (S)
\]

(1) \((9) - (5) = ?\)  \quad (4) \text{ If the result of a subtraction is zero, what sign does the result have?}
(2) \((-5) - (-9) = ?\)
(3) \((-5) - (9) = ?\)
Fixed Point Multiplication (using a true adder)

Suppose the number $+1001$ (multiplicand) is to be multiplied by $-0101$ (multiplier) [i.e., $9/16$ times $-5/16$]:

(1) Initial configuration

```
S
1 0 1 0 1
```

Rearranged configuration

```
S
0 0 1 0 0 1
```

```
U
0 1 0 0 1
```

```
R
1 0 0 0 0 0 1 0 1 0 1
```

that is $(S)\rightarrow R$, $(U)\rightarrow S$, $0\rightarrow U$

```
sign OV
```

```
sign U + sign S\rightarrow sign U
```

in rearrangement

(2) The multiplicand is added into the $U$ if bit 8 in $R$ is 1, otherwise nothing occurs.

```
S
0 0 1 0 0 1
```

```
U
1 0 1 0 0 1
```

```
R
1 0 1 0 1 0 1
```

```
sign OV
```

(3) The entire contents of $[UR]$ (i.e., mantissa of $U$ plus the mantissa of $R$) is shifted right one place; the overflow bit in $U$ is considered part of $U$.

```
S
0 0 1 0 0 1
```

```
U
1 0 0 1 0 0 1 1 0 1 0 0
```

```
sign OV
```

95
(4) Step Number (2) is repeated (in our example no addition takes place).

(5) Step Number (3) is repeated.

\[
\begin{array}{c|c|c|c|c|c|c|c|c}
S & 0 & 0 & 1 & 0 & 0 & 1 \\
\hline
U & 1 & 0 & 0 & 0 & 1 & 0 \\
\hline
R & 1 & 0 & 1 & 0 & 1 & 0 & 1 \\
\hline
\text{sign} & \text{OV} & \\
\end{array}
\]

(6) Step Number (2) is repeated.

(7) Step Number (3) is repeated.

(8) Step Number (2) is repeated.

(9) Step Number (3) is repeated.

The process "add and shift" has now been carried out four times (the number of bits in mantissa). The result is

\[
\begin{array}{c|c|c|c|c|c|c|c|c}
S & 0 & 0 & 1 & 0 & 0 & 1 \\
\hline
U & 1 & 0 & 0 & 0 & 1 & 0 \\
\hline
R & 1 & 1 & 1 & 0 & 1 & 0 & 1 \\
\hline
\text{sign} & \text{OV} & \\
\end{array}
\]

The multiplication is now complete and the product is in \(|UR|\) and is \(-\left(\frac{1}{8} + \frac{1}{32} + \frac{1}{64} + \frac{1}{256}\right) = -\frac{45}{256} \)

Fixed Point Division

If multiplication is effected by using each bit of the multiplier in an adding-and-shifting routine, division is accomplished by building up the quotient one digit at a time in a subtracting-and-shifting system.
The dividend is in the UR double length register. If, as is usually the case, the dividend at hand is only single length, it is put in U, and R is cleared to zero. This is accomplished at the option of the coder and is not automatic in every division order (i.e., if something is left in R, it will be considered as part of the dividend). The divisor is in S. Consider a dividend + 0101 and a divisor + 1001 (i.e., \( \frac{5}{16} \div \frac{9}{16} \)).

(1) The picture is:

\[
\begin{array}{c}
S \\
0 \ 1 \ 0 \ 0 \ 1 \\
\hline
U \\
0 \ 0 \ 1 \ 0 \ 1 \\
R \\
0 \ 0 \ 0 \ 0 \ 0
\end{array}
\]

\(\text{sign overflow bit (OV bit)}\)

(2) The divisor is compared with (U). If mant S > mant U, the division will continue. If not (i.e., mant S < mant U), the machine will come to an error stop (or if sense light 12 is on, it will continue to the next instruction).

Sign R = sign U + sign S. Then the sign U \(\rightarrow\) sign S.

(3) The contents of \(\text{UR}\) including overflow position are shifted left one place.

\[
\begin{array}{c}
S \\
0 \ 1 \ 0 \ 0 \ 1 \\
\hline
U \\
0 \ 0 \ 1 \ 0 \ 1 \ 0 \\
R \\
0 \ 0 \ 0 \ 0 \ 0 \ 0
\end{array}
\]
(4) The output of the subtracter is examined. If the result has the same sign as U, a one is put into the last bit (#8) of R and (U) - (S) → U. If not, nothing happens.

\[
\begin{array}{c|cccc}
S & 0 & 1 & 0 & 0 & 1 \\
\hline
U & 0 & 0 & 0 & 0 & 1 \\
R & 0 & 0 & 0 & 0 & 1 \\
\end{array}
\]

(5) The (|UR|) are shifted one place left (note that a 1 in bit 5 goes into the overflow bit and takes part in the subsequent arithmetic operation).

\[
\begin{array}{c|cccc}
S & 0 & 1 & 0 & 0 & 1 \\
\hline
U & 0 & 0 & 1 & 0 & 0 \\
R & 0 & 0 & 0 & 1 & 0 \\
\end{array}
\]

(6) The output of the subtracter is tested. Step (4) is repeated.

\[
\begin{array}{c|cccc}
S & 0 & 1 & 0 & 0 & 1 \\
\hline
U & 0 & 0 & 1 & 0 & 0 \\
R & 0 & 0 & 0 & 1 & 0 \\
\end{array}
\]

The process is continued. The final picture (after 4 shift and subtract steps) is:

\[
\begin{array}{c|cccc}
S & 0 & 1 & 0 & 0 & 1 \\
\hline
U & 0 & 1 & 0 & 0 & 0 \\
R & 0 & 1 & 0 & 0 & 0 \\
\end{array}
\]
The quotient is now in R and the remainder in U. (The answer is \( \frac{5}{9} = \frac{1}{2} + \frac{1/32}{9/16} \).)

(7) U and R are interchanged and the quotient then resides in U while the remainder is in R.
XVI.

BINARY POINT LOCATION AND FLOATING POINT ARITHMETIC

In programming fixed point calculations one of the major problems is decimal or binary point location. This problem is particularly difficult if, during a calculation, the number of required significant bits approaches the bit length of the mantissa. Various devices are used to assist in planning, but it should be emphasized that these methods are primarily methods of how to think about the numbers in memory.

Binary Point Location

The simplest method is to fix the binary point at some arbitrary place in the middle of the word or at either end. For example, suppose we locate the binary point between the ninth and tenth bit in the mantissa of our word (that is, between bits number 15 and 16 in the word).

```
+ EXP  +  1 2 3 4 5 6 7 8 9 10 11 12 - - - - 47
```

This would be the form in which all data and constants are entered into the problem and in which all answers and intermediate results appear. Note that no data or results may be larger than $2^{10} - 1 = 1024$ or smaller than $2^{-38} = 0.000 000 000 002$.

Since in this system all numbers in memory have the same decimal point, addition and subtraction can be carried out
without any preliminaries. If overflow were to occur, the sum would be larger than $2^{10} - 1$ and in this system nothing could be done. It is up to the coder to look at his problem and choose a location for his binary point such that all data and results of calculations will be less than the largest number possible.

In multiplication we have two numbers each of which has 38 places to the right of the point. By the usual rules the product (in U and R combined) will have $38 + 38 = 76$ places to the right of the point. These 76 places include the 47 places in R and 29 places in U. Thus in the result the binary point can be placed (in thought) between the 18th and 19th bits in the mantissa (i.e., bits number 24 and 25 in the entire word). It is necessary to shift the combined mantissae of U and R left nine places after each multiplication to re-establish the proper binary point. Again any overflow is an error in this system.

In division there will be as many places to the right of the point in the quotient as the difference of the number of places in the fractional part of the dividend and the number in the divisor. Note that the dividend includes U and R. Thus to get 38 to the right of the point in the quotient (with 38 to the right in the divisor) we must arrange to have 76 in the dividend. The dividend is thus shifted right nine places before each division. This is almost the reverse of multiplication.

It is important to note that the actual electronic processes of add, multiply, etc., are independent of the choice
of the binary point. The machine does not have a binary point built in and it is entirely up to the coder to keep track of the point.

If we think of the binary point as being to the left of position 1 in the mantissa, the numbers all have 47 places to the right of the point. By examination of the above discussion one can see that in this case no shifting is required in multiplication and division. For this reason many people regard this location of the point as the natural one and emphasize that the computer only uses fractions as input data and only yields results in the form of fractions.

A slightly more general procedure would be to keep track of the binary point with the following rules. (One must always check for overflow and improper division.)

1) In addition or subtraction, the binary point location of both numbers must be the same.

2) In multiplication, the product has as many places to the right of the point as the sum of the number of places to the right of the point in the multiplier and multiplicand.

3) In division, the number of places to the right of the point in the quotient is the difference of the number of places to the right of the point in the divisor and the number of places to the right in the divisor.
Note: The location of the point in the dividend and in the product is in respect to the U and R registers combined, whereas all other quantities are regarded as single length numbers.

Floating Point Representation

At best the problem of keeping track of the binary point is time-consuming and annoying. At times it is extremely difficult to plan adequately, since it involves predicting the sizes of all numbers in the calculation. A system is needed that will indicate where the binary point is and instruct the machine to take account of this in doing operations on numbers. Such a system is a floating point system.

The basic idea is to write all numbers as a binary fraction times a scaling factor. Thus, if \( x \) is the actual number and \( \bar{x} \) is the fraction in memory, we have the scale factor equation:

\[
x = s\bar{x}
\]

The object is to store the scaling factor in memory along with the fractional part \( \bar{x} \).

In usual scientific applications, \( s \) is restricted to be a power of 10, but in a binary machine \( s \) is usually restricted to be a power of 2:

\[
x = 2^q \bar{x}
\]

and \( q \) is the quantity stored in memory together with \( \bar{x} \). The
exponent q in this scheme is the same as the number of places to
the left of the binary point. In such a procedure we think of
all numbers in memory as having a binary point fixed at the left
end of the word. If a number is shifted, the binary point does
not move but rather the scale factor changes. This is obviously
merely a change in viewpoint. The "lining up" of the binary
point by shifting in the fixed point procedure is replaced by a
"matching" of exponents, again by shifting, in the floating point
procedure.

The disadvantages of such a system should also be men-
tioned:

(1) The number of bits used to hold the exponent in
memory decreases the number of significant figures
that can be carried in a number.

(2) The process of matching exponents (i.e., lining up
the binary points) of two numbers before addition
or subtraction is time-consuming.

(3) The problem of whether to restrict the operations to
completely normalized numbers (i.e., numbers between
1/2 and 1) or not is introduced.

(4) The possibility of floating point overflow and under-
flow must be considered.

(5) Conventions to avoid time-consuming shifts must be
adopted.
It is not necessary to use a power of 2 as the scaling factor. Suppose we consider:

\[ s = (2^p)^q \]

where \( q \) is the variable exponent and \( p \) is a fixed integer. This form is chosen so that there will be a simple relation between shifting and the exponent \( q \). Using such a scale factor is often referred to as using the number base \( 2^p \). In many ways this is convenient but it is important to remember that the machine is still a binary computer.

With this choice of \( s \), we need a smaller range in \( q \) for a given range in \( s \) than in the previous system. Since only shifts of \( p \) bits at a time can be recorded, the fractional part of the number can vary over a wider range. In fact, if we maintain the least possible number of leading zeros in all the fractional parts (this is called normalized or standardized numbers) up to \( p-1 \) leading zeros can still occur.

\[ 2^{-p} \leq \bar{x} < 1 \]

A large \( p \) means a greater possible range in \( s \) (which is of course the major object of a floating point system), faster arithmetic (since matching of exponents by shifting is less frequent and fewer shifts are needed in general), but a smaller possible number of significant figures (since \( p-1 \) leading zeros will almost certainly occur during the calculation).

As a compromise \( p = 8 \) has been chosen for the Rice Computer. As usual such a choice also introduces new complications
which will be discussed below. Thus we have:

\[ x = (2^8)^q \bar{x} = (256)^q \bar{x} \]

\[-1 < \bar{x} < 1; \quad 1 > |\bar{x}| \geq 1/256\]

\[-31 \leq q \leq 31\]

Normalization (or Standardization)

A floating point number is said to be in normal or standard form if the fractional part of the number, \(\bar{x}\), has no more than 7 leading zeros. Note that this does not mean that the remaining 40 bits in the mantissa are significant. It may well be that none of the 40 bits are significant. The zero presents a special problem. A normalized or standard zero is a number whose mantissa is zero (i.e., all 47 bits zero) and whose exponent is -31.

In the process of normalization a number is shifted left eight bits at a time (with a corresponding decrease in the exponent by one with each shift) until it is in standard form. In some cases the U and R registers are combined and this is noted in the description of the floating point arithmetic.

Normal Mode for Floating Point Arithmetic

When mode light 4 is zero (i.e., off), the machine will carry out floating point calculations according to the following scheme:
(A) Floating Add

The sequence of steps is described in detail.

(1) R is cleared
(2) exponent of U \rightarrow \text{exponent } R
(3) EXP U - EXP S \rightarrow EXP U \text{ (algebraic difference of exponents)}
(4) if EXP U is zero, go to step (8)
    if EXP U > +6, EXP R \rightarrow \text{EXP } U, \text{ then go to step (10b)}
    if EXP U < -6, (S) \rightarrow U, \text{ go to step (10b)}

\[
0 < \text{EXP } U \leq +6 \\
-6 \leq \text{EXP } U < 0
\]

(5a) \( +1 \rightarrow \text{EXP } S \) \hspace{1cm} (5b) \( \text{EXP } S \rightarrow \text{EXP } R \)
    \( +1 \rightarrow \text{EXP } S \)

(6a) shift S right
     EXP U - EXP S \rightarrow \text{EXP } U
(6b) shift U right
     EXP U + EXP S \rightarrow \text{EXP } U

(7a) if EXP U is zero, go to step (8)
    if EXP U \neq 0, go back to step (6a)
    if EXP U \neq 0, go to step (6b)

(7b) if EXP U = 0, go to step (8)

(8) EXP R \rightarrow \text{EXP } U

(9) fixed point addition of mantissa S + mantissa U
    mantissa overflow
    no mantissa overflow

(10a) shift U right
(10b) if leading 8 bits \neq 0, go to step (13)

(11a) EXP U + 1 \rightarrow \text{EXP } U
(11b) if leading 8 bits = 0, shift U left, \( \text{EXP } U \rightarrow \text{EXP } U \) go to step (10b)

(12) go to next instruction
All shifts in floating point addition are shifts of 8 bits at a time and only U is shifted (i.e., mantissa of R = 0 after operation).

(B) Floating Multiply

(1) \((S) \rightarrow R, (U) \rightarrow S, 0 \rightarrow U\)

(2) The sum of \(S_e\) and \(U_e\) is placed in the exponent of \(U\).

(3) A fixed point multiplication is carried out. The sign of \(U\) is the algebraic sign of the product.

(4) If the mantissa of \(U\) is less than 1/256, the number in \(U\) and \(R\) combined is normalized.

(C) Floating Divide

(1) The sign of \(R\) is made equal to the algebraic sign of the quotient.

(2) If the mantissa of \(U\) is zero, the computer proceeds to the next instruction.

(3) If the magnitude of the fraction in \(U\) is greater than that in \(S\), \(U\) and \(R\) combined are shifted right by 8 places (again with an addition of 1 to the exponent).

(4) The exponent of \(U\) minus the exponent of \(S\) is placed in the exponent of \(R\).

(5) \((U)\) is divided by \((S)\). The quotient is in \(R\) and the remainder in \(U\).
(6) U and R are interchanged so that the quotient ends up in U and the remainder in R.

Significant Mode for Floating Point Arithmetic

When mode light 4 is on, the machine will carry out floating point calculations according to the following scheme:

(A) Floating Add

Same as in the normal mode except that steps (10b) and (11b) are omitted.

(B) Floating Multiply

(1) Both numbers in U and S are normalized (say, a shifts of 8 left are needed to normalize S and b shifts of 8 bits left are needed to normalize U). The larger number of shifts is noted (i.e., the max \( a, b \) is stored).

(2) Floating point multiplication is carried out in the normal mode.

(3) The product in U and R combined is shifted right (8 bits at a time) \( c \) times, where \( c = \max (a, b) \) stored above.

(C) Floating Divide

(1) The numbers in UR and S are normalized. Again the maximum number of shifts needed in either number is noted (i.e., \( c = \max (a, b) \) is stored).
(2) Floating point division is carried out in the normal mode.

(3) The quotient in $U$ alone is shifted right (8 bits at a time) $c$ times. Bits shifted out of $U$ are lost. The remainder in $R$ is unaffected.

The exponents are always adjusted automatically in the shifts described above.

**Exponent Underflow**

If the exponent of any result underflows, that is, if $U_e < -31$ would be the result of a calculation, then $(U)$ is set equal to a standard zero.

**Floating Zero**

In floating add one must be cautious in adding a zero. If the zero has a larger exponent than the other addend, significance can be lost just due to the shifting involved in matching exponents. The standard zero in floating point work contains a zero mantissa and a $-31$ exponent.
INDEX

A
A series registers, 12,13,14, 18,19,20,44
Adder (see Subtractor)
"And" instruction, 36
Arithmetic, fixed point, 9,28, 92-99
Arithmetic, floating point, 10, 28,100-110
Arithmetic instructions, 23,28- 29
Arithmetic section, 3-4,64-68, 78

B
B-adder, 69,71,73,75
B modification (BM) bits, 20-21
B register arithmetic instructions, 24,31
B series registers, 12,13,14, 17,18,19,20,21,31,44,69,71- 72,73-74,75,76

C
Central distributor, 64-65,69, 71
Class (C) triad, 23-24
Compare instructions, 23,26
Complement arithmetic, 76-78
Complementing, 68
Control instructions, 23,24-28
Control counter (CC), 14,17,58, 71,72,74
Control punches, 89,91
Control section, 4,69-75

E
Electrostatic storage (see Memory)
Exponent overflow, 27,52,53
Exponent underflow, 110
Extract instruction, 36

F
F registers, 12,17,18,19
Fast address (F) triad, 18-19
Fast registers, 12,44
Fetch order, 29
Field 1, 16,17,18-20
Field 2 (Op field), 16,17,23-44
Field 3, 16,17,44-45
Field 4, 16,17,20-23
Flexowriter, 89-91

I
Ignore error stop mode, 55-56
Increment (X) register, 15,44, 69,71,72,75
Indicators, 52-56
Indirect addressing (IA) bit, 21,22,31
Inflection on F (IF) triad, 18- 19
Inflection on M (IM) bits, 21, 22
Inflection on store (IST)triad, 44
Input-output instructions, 24, 37-43
Instruction, execution of, 12, 17
Instruction (I) register, 17, 21,31,34,69-70,71,72,73
Instruction word structure, 16- 45

L
Layout charts, 83,86
Line printer, 5,37,39,41-42,79- 87
Logical arithmetic instructions, 24,35-37
Logical bit count, 31,34

M
M addresses, 12,14
M triads, 20,21,22,26,30,31,34, 35
Magnetic tape, 5,37,39,42-43
Mantissa overflow, 27,52-53
Memory, 2-3,5,61-63,69,71
Mode light (ML) register, 15, 55-56,69,72,75
Monitor tube, 62
N
Normal mode, 106-109
Numerical word structure, 9-11

O
Octal notation, 6-8
Optical tape reader (see Paper Tape Reader)
"Or" instruction, 36

P
Paper tape, 38, 59, 88-91
Paper tape punch, 4, 37, 39
Paper tape reader, 2, 37, 38, 88
Parity check, 62
Pathfinder 1 (PF1), 14, 58, 72, 74
Pathfinder 2 (PF2), 15, 58, 72, 74-75
Print-matrix, 83-85, 87
Printer output, 79-87

R
Read around error, 63
Remainder (R) register, 14, 17, 26, 29, 30, 31-34, 36-37, 44, 64-66, 68, 95-99, 101, 103, 107-110
Repeat mode, 55-56, 59
Round mode, 55-56

S
Sense light (SL) register, 15, 27, 54, 69, 72, 75
Set mode instructions, 31, 34-35
Set sense instructions, 24, 31, 34-35
Set tag instructions, 23, 30
Shift instructions, 24, 31-34, 68
Significance mode, 55-56, 109-110
Skip instructions, 23, 26
Special functions instructions, 24, 43
Special purpose registers, 12, 14, 15, 20
Square root, 43
Storage (S) register, 14, 17, 20, 21-22, 26, 29, 30, 36-37, 42, 64-65, 67, 68, 92-99, 107-109
Store instructions, 23, 29-30
Store (St) triad, 44
Substitute instructions, 23, 29-30
Subtractor, 64, 67, 92-99
Subrahend register (see Storage Register)
Symmetric difference instruction, 36

T
Tagging, tag indicators, 28, 30, 52, 53-54, 57, 59, 62, 84
Temporary store (T) registers, 14, 64-65, 78
Transfer instructions, 23, 59, 70
Trapping mode, 55-56, 58
Typewriter, console, 2, 37, 39

U
Universal (U) register, 13, 14, 17, 18, 22, 29, 31-34, 36-37, 44, 52, 53, 64-66, 67, 68, 92-99, 101, 103, 107-110

X
X register (see Increment Register)

Z
Zero, floating, 110
Zero register, 14
Zero, standard, 106, 110
APPENDIX 1

ELECTRONICS OF THE COMPUTER
NOTE: 1 THE STAGE IS CONSIDERED TO BE IN THE "1" STATE WITH ELEMENTS 1, 2 & 3 CONDUCTING
2 RESISTOR VALUES ARE THE SAME AS THE LOS ALAMOS COMPUTER, MANIAC II

FIGURE I BASIC FLIP-FLOP CIRCUIT ARITHMETIC UNIT
I.

ARITHMETIC UNIT

The arithmetic unit consists of seven registers, an adder, and gates (such as the "central dispatcher") for setting or transferring the contents of registers. Three of the registers (R, S, and U) are used in arithmetic manipulations and may be shifted left or right. The other four are a set of "T" registers which are used for temporary storage. The registers and adder are static circuits, i.e., voltages can have stable d.c. values in the absence of gating signals.

Basic Circuitry

Flip-Flop

The basic element of each register is a "flip-flop" circuit, often called a "bistable multivibrator," "binary," or "Eccles-Jordan circuit," Figure 1. This circuit is symmetrical in d.c. operation with conduction either through the right hand triode (defined as a "1" condition) or conduction through the left hand triode (defined as a "0" condition). The state of the flip-flop (FF) circuit is measured at the grid of the right hand triode, which drives the grid of a cathode follower to provide a low impedance decoupled output. Thus the state "1" is identified with zero volts output, the state "0" corresponds to about -20 volts output. By this definition, the COMPLEMENT
of the state of the FF can be measured at the grid of the left hand triode. In the U, R, and S registers the above method is used to read the state of the FF; the T registers are read in the plate circuit.

Since in arithmetic operations the number is 54 bits in length, each register has 54 flip-flops, each with provisions for reading its state and with provisions for setting its state. The latter is discussed in the following section.

**Gating In**

To store a bit in the FF requires the capability to set it to either a 1 or a 0 condition. Two gating schemes commonly used are the double-sided and the single-sided gates.

In the double-sided gating scheme the left hand triode is cut off to set in a 1 (by lowering its grid or the opposite plate), and the right hand tube is similarly cut off to set in a 0. This requires two gates: one capable of setting in 0's, the other to set in 1's. Thus for setting a number into a register from any of N different sources, there are required 2N gate connections to the register.

An alternative technique is to clear the entire register to 0, then set to 1 all those stages that are to have a 1 gated in. This still requires two gates, but one of them is common for all gating operations. Thus for transferring a number into a register from any of N different sources there are required N + 1 gate connections.
FIGURE 2 AN ASYMMETRIC SINGLE-SIDED GATE

FIGURE 3 GATE CIRCUIT FOR THIS COMPUTER
For a large number of gates, roughly half can be saved by using single-sided operation rather than double. However, there is a possible disadvantage if extra time is involved by first setting the FF to 0 before gating in the 1's. This can be avoided by setting in the 0's and 1's simultaneously, provided that the setting in of a 1 overrides the setting in of a 0. Here this is accomplished by driving the same grid with opposing signals that are at two different impedance levels.

One possible circuit arrangement is the asymmetrical setting system shown in Figure 2: when clearing the FF stage to 0, the left triode grid is pulled up by the current, I, when switched by a positive pulse applied at A. When setting the FF stage to 1, the same grid is driven negative by a voltage pulse at B. Since in each case the left hand grid is being set to its proper value, no speed-up capacitor is needed from the opposite plate.

Accurate registration is not essential. It is required only:

(1) that pulse "A" be large enough to set the FF to 0 during the pulse duration;

(2) that pulse "B" go negative enough and last long enough to set the FF to 1; and

(3) that when the "B" pulse exists, it end after the "A" pulse.
FIGURE 4  A CIRCUIT FOR MULTIPLE INPUT GATES

FIGURE 5  A BETTER CIRCUIT FOR MULTIPLE INPUT GATES
A satisfactory approximation, which saves one diode per stage and some d.c. power, is the circuit in Figure 3. The "A" pulse need not start at -20 V, but a voltage sufficient to keep the left triode cut off. For the circuit pictured, -15 V is used.

It is possible to have several B inputs: see Figures 4 and 5. For the circuit of Figure 4 the back leakage current of the diodes in parallel may load the high-impedance grid circuit. The configuration of Figure 5 has the parallel diodes shunted by the low impedance of a conducting diode "d." The quiescent voltage of the "B" lines is about +5 volts, enough to prevent noise and "hash" on the lines from setting a 1 into the FF. During a 0 state when the left triode is caught on grid current, the barely-conducting diode "b" does not divert much of the grid current. (Diode "b" has a high impedance at the voltage level of \( E_{\text{grid}} - E_{\text{diode "d"}} \).)

The FF stage then has the appearance of Figure 5. The 18 mmf capacitor flattens the response of the crossover divider. Whereas the grid of the left triode is limited by the voltage at "A" to a swing from 0 to -15 V, the grid of the right triode will move between 0 and -20 volts. This grid is connected to a cathode follower for a decoupled low impedance output.

**Gating Out**

The usual output from a register is dynamic; a 1 output
FIGURE 6  THE DYNAMIC OUTPUT CIRCUIT FOR REGISTERS U, S AND R
is a pulse on the secondary of a pulse transformer whose primary is in the plate of a 6197 pentode amplifier, see Figure 6. The pentode can be driven on from cut-off by a READ pulse when the FF is in a 1 state so a pulse or no pulse indicates, respectively, 1 or 0.

The AND gate for the 1 state and the READ pulse uses a delay line, as shown in Figure 6. The 15-volt positive READ pulse applied to the shield of the delay line either turns on the pentode or does not, depending upon the voltage of the FF-controlled cathode follower.

The delay line is used only in those registers where temporary storage is required by some gating operations: gates such as shifts and complements, which erase the information being used to control the gating. If the state of the FF is changed, the right end of the delay line is independent of that change for .4 microsecond.

The damping winding has a damping resistor and a diode whose polarity allows damping only after the pulse, during the back-kick. Sometimes this winding is used for additional purposes in COMPLEMENT and EXTRACT operations.
"CLEAR", "READ", AND "COMPLEMENT" GATE PULSES ARE SIMULTANEOUS

FIGURE 7  COMPLEMENT GATE CIRCUIT
Special Circuitry

Complement

Two of the registers to be discussed, S and U, have provision for replacing the number in the register by its complement: replacing each 1 by a 0 and conversely. This scheme requires the 3 coincident pulses shown on the schematic, Figure 7. At the delay line shield there is applied a positive pulse to "READ" the contents of the register. Simultaneously, there is a positive pulse at the FF grid to "CLEAR" the register to zero, and a negative "COMPLEMENT" gate is applied to the damping bus bar.

If the number that was in the register was zero, the initial condition on each end of the delay line was -20 volts. Thus the READ pulse of +15 volts does not turn on the pentode driver, thus no voltage is developed at the transformer secondary, and the negative COMPLEMENT gate sets a 1 into the FF (overriding the CLEAR pulse).

If the number that was in the register was 1, the initial condition at the right end of the delay line is about +2 volts and will remain at +2 volts for .4 microseconds although the register was CLEARED to zero. Thus the READ pulse of +15 volts drives the grid positive, turning on the pentode hard. So at the secondary there is developed across the damping diode an output of approximately +35 volts, which inhibits the COMPLEMENT
"CLEAR"

"READ"

"COMPLEMENT"

SECONDARY VOLTAGE (FOR "1" STORED)

DIODE VOLTAGE PLUS "COMPLEMENT" (FOR "1" STORED)

FOR A ZERO STORED THE COMPLEMENT GATE SETS THE STATE TO 1

ACROSS DAMPING DIODE

FOR A "1" STORED THE DIODE VOLTAGE INHIBITS THE COMPLEMENT WAVEFORM AND THE STAGE "CLEARS" TO ZERO

FIGURE 8 VOLTAGE WAVEFORMS IN THE COMPLEMENT CIRCUIT
pulse in the manner indicated in Figure 8. Thus a 1 condition has caused a positive output which overrides the would-be input gate, resulting in the 0 condition which was just previously set by the CLEAR pulse.

For proper operation, this circuit requires that the overriding output pulse be well shaped: it must be greater in amplitude and duration than the COMPLEMENT pulse, and it must have no negative undershoot. The diode across this winding performs the dual purpose of damping the undershoot and shaping the override pulse for the complement gate.

Extract

The EXTRACT gate is used in applications where it is desirable to select or to replace a portion of the number. The operation performed is that of gating \( (S) \rightarrow U \) when the corresponding bit in \( R \) holds a 1; otherwise, \( (U) \rightarrow U \).

The circuitry uses two inputs to \( U \) (two of the multiple input gates described previously); one input is determined by \( S \) AND \( R \), the other results from \( U \) INHIBITED BY \( R \).

The first input uses a winding on the \( S \) pulse transformer in series with a similar winding on the \( R \) transformer, as an input to \( U \). The other end of this double winding is returned to a bus held at about plus 25 volts. Thus a 1 in \( S \) AND a 1 in \( R \) is required to set a 1 in \( U \). Otherwise that bit in \( U \) is cleared to 0 by the CLEAR gate.
The second input uses a clockwise 2-turn winding on the U transformer in series with a counterclockwise 5-turn winding on the R transformer. Thus a pulse from U will set a 1 back into U unless R also has a 1, in which case the positive pulse from R will INHIBIT the pulse from U. Since the pulse from R must be large and must have no undershoot, the voltage on the R damping diode is used in a manner similar to the COMPLEMENT operation described in the preceding section.

Arithmetic Unit

U Register

Since the U register is utilized in all arithmetic operations, it has several possible inputs. Input signals can be sent from the adder, either directly or shifted left one stage or shifted right one stage; two extract inputs are available so that a bit can be gated into U from either U or S, depending upon the state of the corresponding bit in R; or a number from a variety of places can be gated into U via the central distributor. Or U itself can be gated back into U, shifted 1 or 8 places left or right; or the complement of U can be gated into U.

Each input to U is a negative pulse through a diode, as described earlier in this manual. Each input is derived from two turns of a pulse transformer, wound in a (clockwise) direction
so as to pulse negative from a reference voltage bus. An input
is gated in from any particular location only when the voltage
of the corresponding reference bus is pulsed from its usual +25
volts down to about +5 volts in coincidence with the negative
20-volt pulse from the pulse transformer.

The secondary windings of the pulse transformer (outputs
from U) include a complement winding, an extract winding, an
output to the central dispatcher, and the four shift windings.

In addition to the pulse outputs from U there is a static
output connection to the adder.

As shown by the Schematic C-1052, the static output
to the adder is from a cathode follower (V-2B) whose input
alternates from stage to stage between the two grids of the
flip-flop: on even-numbered stages the cathode follower is
connected to read the number stored in the flip-flop, i.e.,
zero volts indicates a 1; on odd stages the cathode follower
reads the complement of the stored number, i.e., zero volts
indicates a 0. The purpose of alternating the connections is
to minimize the carry time, discussed in the subsequent adder
section. The supply voltage of minus 50 volts for this cathode
follower is for protection of the adder diode in case the tube
V-2 is pulled out.
S Register

The S register (see Schematic C-1037) looks very much like the U register: the basic flip-flop circuit with a pulse tube output and with a static output to the adder. It is also similar with circuitry for complementing, shifting left or right 1 or 8 stages, and for gating into or from the central dispatcher.

However, the extract function uses merely a 2-turn winding on the output transformer of S (to accomplish $(S) \rightarrow U$ if $R$ is 1). Also the output to the adder alternates opposite to U, such that the complement of S is added to U and vice versa. This is discussed in greater detail in the adder section.

R Register

The R register (see Schematic C-1022) is similar to the U and S registers: the same basic flip-flop circuit with pulse tube output and diode OR inputs. It can be shifted left or right in a similar manner as they, and can be gated into or from the central dispatcher.

This register is unlike U or S in having no connection to the adder and in having no COMPLEMENT gate. The damping winding, used as the complement gate INHIBITOR in S and U, is used to INHIBIT $(U) \rightarrow U$ in the EXTRACT function. A separate winding on the transformer, in series with the EXTRACT winding on S, is for the function: $(S) \rightarrow U$ when $R$ is 1.
T Registers

These registers are similar to the other arithmetic registers U, S, and R only in the basic flip-flop circuit and in the diode OR input circuitry. They are not used in arithmetic operations, therefore do not have temporary (delay line) storage or gates for shifting or complementing. They are used merely for fast-access storage of four words; their only inputs and outputs are via the central dispatcher.

As shown by Schematic C-1067, the supply voltages for the T flip-flops are 150 volts more negative than the other registers. The plate supply is at ground potential for the convenience of the output gate: a 22 K resistor and a pair of diodes. The CLAMP voltage, connection 15, is at ground potential; the READ bus, connection 11 or 13, is ordinarily at ground except when a 15-volt positive pulse is applied to the proper bus to read a particular one of the T's. The read operation is as follows.

If the T register is in a 0 state, defined as conduction in the right hand triode of the FF, the CLAMP diode conducts about 2 milliamperes and its cathode is at ground potential regardless of whether a positive READ pulse is applied. Thus the central dispatcher pentode remains cut off. If the FF is in a 1 state, the right hand triode is cut off and thus does not pull current down through the CLAMP diode as above. Current
flow for this state is through the READ diode. A 15-volt positive pulse to its cathode allows the grid of the central dispatcher to be driven well into saturation by the current through the 22 K resistor from +150 volts. Thus the central dispatcher is turned on by a 1 AND a READ pulse.

Central Dispatcher

The central dispatcher, or distributor, serves as the output tube for the T registers. As its name implies, it also serves as the route by which information is gated from one part of the computer to another. The savings in components can be illustrated by the following example: if there are $N$ locations which need to be connected to one another by both input and output gates, there will be required $2N(N-1)$ gate circuits. If instead each location is connected only to a central distributor by input and output, almost the same flexibility results from $2N$ gate circuits. This is an appreciable simplification, particularly if $N$ is large. Although not all number locations need to be connected to one another, use of the distributor makes possible a more flexible arrangement than otherwise would be feasible. The equivalent $N$ (for the above example) is 10 or so for this computer.

In addition to inputs from $T_1$ through $T_4$, inputs come to the distributor from several other locations via the central dispatcher bus. These locations include U, S, and R in the
FIGURE 9 KIRCHHOFF ADDERS USING SWITCHES
arithmetic unit, the address adder in the control unit, and the memory. Each of these inputs is a positive pulse from a transformer secondary, gated onto the dispatcher bus by pulsing a reference bus—the usual gating technique at register outputs.

Each output from the central dispatcher requires a secondary on the pulse transformer. Thus 7 secondaries are required for the arithmetic unit and one each for the instruction register, memory, and high-speed line printer.

To gate from one location to another via the central distributor requires 3 coincident pulses. For example, to gate from R to $T_1$, there must be a READ (R) pulse, a pulse to gate the output of R to the dispatcher bus, and a pulse to the central distributor to gate its output into $T_1$.

**Adder**

The adder circuitry is based on a combination of two common techniques: the Kirchhoff adder and the diode switch.

As illustration of the principle, consider Figure 9 in which the diodes are represented as switches. In discrete steps these switches control the conductance from the summing point to the minus supply, thereby controlling the potential of the summing point to determine whether the vacuum tube is conducting or cut off. By choosing different values for resistors $R$ and $R_1$, the tube may be made to cut off for any condition of 1, 2, or all three switches closed. An advantage of using
### States of Diodes

<table>
<thead>
<tr>
<th>State</th>
<th>Conducting</th>
<th>Open</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>$a_1 a_2$</td>
<td>$b_1 b_2$</td>
</tr>
<tr>
<td>B</td>
<td>$a_1 b_1 b_2$</td>
<td>$a_2$</td>
</tr>
<tr>
<td>C</td>
<td>$b_1 b_2$</td>
<td>$a_1 a_2$</td>
</tr>
</tbody>
</table>

- $e_1 = e_2 = 0$ : Only Point*1 is stable
- $e_1 = 0, e_2 = -E$ : Only Point*1 is stable
- $-e_1 = e_2 = -E$ : Only Point*2 is stable

---

**Figure 10** A Kirchhoff Adder Using Diode Switches
this technique is that several milliamperes of current are readily switched in, charging to a new voltage the stray capacitance at the summing point.

The triode used in the adder, the 5965, has only about 5 volts grid swing between cutoff and saturation. For this small region of operation it is a convenient and valid approximation to represent the switches as controlling currents of \( \frac{150}{R} \) or \( \frac{150}{R_1} \) rather than impedances.

An example of the performance of a circuit of this type is shown in Figure 10. Diodes are assumed to be ideal; for simplicity only two adder elements are shown. The graph shown is the characteristic, output current versus output voltage, which might be obtained by supplying an external current source and measuring the resulting voltage. Conditions for the characteristics are: both inputs at zero; \( e_1 \) at zero and \( e_2 \) at \(-E\); and both inputs at \(-E\) (merely the first characteristic shifted in voltage). Since usual circuit operation has the output point connected to ground only through a few micro-micro-farads of stray capacitance, the only stable value of d.c. output current is zero. For the values of current \( \frac{I}{2} < i < I \), the output remains at \( e_0 = 0 \) for either or both inputs at zero volts. The operating point for both inputs at \(-E\) volts is \( e_0 = -E \). By changing the value of the bias current \( I \), this sample circuit can be made to switch operating points for only one input of \(-E\),
or for three or more inputs of -E. This is equivalent to moving the characteristic up or down relative to the origin. The size of the increment of current on either side of the operating point determines the rate of charge of stray capacitance, thus the speed of changing from one operating point to another.

As a review of the purpose of the adder, note that each adder stage has 3 inputs: the S register, the U register, and the carry from the previous adder stage. Each stage has 2 outputs: the digit output and the carry output. These must be, respectively, in the states 0, 1, 0, 1 and 0, 0, 1, 1 for 0, 1, 2, or 3 input 1's. This is apparent from the binary equivalents of numbers 0 through 3.

The carry circuit, see Schematic C-1082, has 9 ma bias current and 6 ma at each input. Input voltages, at either zero volts or -15, are from cathode followers which can supply several milliamperes. If either 2 or 3 inputs are at -15 volts, the output junction is at -15 volts. If 2(or 3) inputs go to zero volts, the output junction is driven up to zero potential by 3(or 6) milliamperes. If there is 20 mmf of stray capacitance, it can be charged through the 15-volt transition by 3 ma in 0.1 microsecond. Slight inequalities in voltages, diodes, or resistors may cause unequal distribution of currents, but the switching should not be affected. (Actually, if there are
3 different values of input voltage, the output will correspond to the middle potential.)

Thus the carry circuit has the required response 0, 0, 1, 1 for 0, 1, 2, or 3 input 1's, respectively.

The digit circuit, as indicated by the schematic, has input currents of 2 ma with only 1 ma of bias current. Thus, a single input 1 will cause a change of voltage at the output. For two input 1 conditions the output from the carry circuit switches 4 ma additional bias into the digit circuit, resulting in another 0 output from the digit adder. For three input 1's, the 6 ma input current exceeds the now 5 ma bias to cause an output 1 condition. Thus the digit output has the required 0, 1, 0, 1 for inputs of 0, 1, 2, or 3 1's.

To reduce the "carry" time (since the carry may propagate through several stages) there are 3 circuit considerations: the higher values of switching current described above; only one inversion; and a cathode catch on the adder inverter.

The attenuation in the adder requires voltage amplification in the carry circuit because a particular carry may propagate through several stages. Since a single amplification is more desirable than two, because of the delay, an inversion occurs in every stage: at the input to odd-numbered stages, as shown in the schematic, Drawing C-1082, a 1 corresponds to -15 volts and a 0 corresponds to zero volts; at the carry output
(thus at the input to even-numbered stages) a 1 corresponds to zero volts and a 0 to -15 volts due to the inversion; and at the digit output a 1 always is indicated by zero volts (and a 0 by -15 volts) so that a READ pulse at the delay line shield will turn on the pulse tube. Thus, the output of the digit adder requires inversion only in odd stages. The inputs to odd-numbered stages come from S and the complement of U; inputs to even stages come from U and the complement of S; the whole effect is thus subtraction of the number in S from the number in U.

The time for carry propagation is reduced also by the diode latches on the cathode of the carry inverter. When the grid of the inverter is at zero volts, the cathode conducts through the upper diode. When the adder switches states to -15 volts output, the tube is cut off quickly by the initial 5-volt swing because its cathode is held temporarily at its potential by the cathode capacitor. For the static condition of -15 volts at the grid of the inverter, the tube is cut off because its cathode is caught at -7 volts by the lower diode. As the input is switched toward zero volts, the tube begins to conduct more quickly than if it were grounded. Since the cathode is held temporarily at -7 volts, the initial portion of the transient turns on the tube and thereby switches the output. As the input transient continues to rise, reaching zero
volts, the cathode potential follows until caught by conduction of the upper diode.

The output circuit from the digit portion of the adder register, as indicated in Schematic C-1082, is the same type as registers U, R, and S. The output pulse from the adder can go only to the U register, but can be shifted left or right one stage.

A static output is available through a diode on the same cathode that drives the delay line. This output is used in a logical OR to detect multiple zeros, as described elsewhere in this manual.
SAMPLE ROUTINE

The following matrix routine, written in the machine language of the Rice Computer, is intended to illustrate some of the coding features outlined in the manual. The resultant matrix, as described, could be obtained in a number of different ways; the techniques used are not intended to minimize running time or storage space. In fact, more orders have been introduced than are needed in order to illustrate certain features of the order code.

The write-up is similar to that which would be on hand for the use of the coder at the computer site. The five octal triads of the address (M) field are represented symbolically when they refer to an address rather than a number, and each order is assigned a symbolic location in memory.

MATRIX ADD OR SUBTRACT SUBROUTINE

**Purpose:** To add a matrix B to a matrix A or to subtract B from A, where both A and B are of size m x n and their elements are floating point numbers.

**Method:** Before entering this routine, the elements of each matrix must be located sequentially in memory either by rows or by columns; the elements of the resultant matrix C are stored in the same way.
Usage:

Range: \((256^{-31})(2^{-47}) \leq \text{element of matrix } C \leq (256^{31})(1-2^{-47})\)

Calling sequence:

<table>
<thead>
<tr>
<th>location</th>
<th>F1</th>
<th>F2</th>
<th>F3</th>
<th>F4</th>
<th>comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>a</td>
<td>00</td>
<td>01000</td>
<td>00</td>
<td>4000 MASOO</td>
<td>transfer to MAS</td>
</tr>
<tr>
<td>a+1</td>
<td>00</td>
<td>00000</td>
<td>00</td>
<td>00000 ← A →</td>
<td></td>
</tr>
<tr>
<td>a+2</td>
<td>00</td>
<td>00000</td>
<td>00</td>
<td>00000 ← B →</td>
<td></td>
</tr>
<tr>
<td>a+3</td>
<td>00</td>
<td>00000</td>
<td>00</td>
<td>00000 ← C →</td>
<td></td>
</tr>
<tr>
<td>a+4</td>
<td>00</td>
<td>00000</td>
<td>00</td>
<td>00000 ← S →</td>
<td></td>
</tr>
<tr>
<td>a+5</td>
<td>00</td>
<td>00000</td>
<td>00</td>
<td>00000 ← m →</td>
<td></td>
</tr>
<tr>
<td>a+6</td>
<td>00</td>
<td>00000</td>
<td>00</td>
<td>00000 ← n →</td>
<td></td>
</tr>
<tr>
<td>a+7</td>
<td>--</td>
<td>-----</td>
<td>--</td>
<td>-----</td>
<td>error return</td>
</tr>
<tr>
<td>a+8</td>
<td>--</td>
<td>-----</td>
<td>--</td>
<td>-----</td>
<td>normal return</td>
</tr>
</tbody>
</table>

where

\(A = \text{location in memory of first element of matrix } A.\)
\(B = \text{location in memory of first element of matrix } B.\)
\(C = \text{location in memory of first element of matrix } C.\)
\(S = \begin{align*}
0 & \text{ to add } B \text{ to } A, \\
1 & \text{ to subtract } B \text{ from } A.
\end{align*}\)
\(m = \text{number of rows in matrices.}\)
\(n = \text{number of columns in matrices.}\)

Note: Exit is made to error return if the sum of two elements exceeds the given range, at which time the sequence number of this element is immediately available in the U register.

\(B_1, B_2, B_3, B_4, B_5, \text{ and } B_6 \) are restored to their original status upon the normal return.

The T registers, \(T_4, T_5, T_6, \) and \(T_7 \) are used in this routine.
<table>
<thead>
<tr>
<th>Location</th>
<th>F1</th>
<th>F2</th>
<th>F3</th>
<th>F4</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>MAS00</td>
<td>41</td>
<td>21000</td>
<td>00</td>
<td>4000</td>
<td>MAS24, store B₁</td>
</tr>
<tr>
<td>MAS01</td>
<td>42</td>
<td>21000</td>
<td>00</td>
<td>4000</td>
<td>MAS25, store B₂</td>
</tr>
<tr>
<td>MAS02</td>
<td>47</td>
<td>44100</td>
<td>42</td>
<td>4000</td>
<td>0 → B₁; PFL → B₂</td>
</tr>
<tr>
<td>MAS03</td>
<td>00</td>
<td>51000</td>
<td>00</td>
<td>0004</td>
<td>00000, fetch A</td>
</tr>
<tr>
<td>MAS04</td>
<td>01</td>
<td>10000</td>
<td>04</td>
<td>0000</td>
<td>MAS27, insert BM; store in T₄</td>
</tr>
<tr>
<td>MAS05</td>
<td>00</td>
<td>51000</td>
<td>00</td>
<td>0004</td>
<td>00001, fetch B</td>
</tr>
<tr>
<td>MAS06</td>
<td>01</td>
<td>10000</td>
<td>05</td>
<td>0000</td>
<td>MAS27, insert BM; store in T₅</td>
</tr>
<tr>
<td>MAS07</td>
<td>00</td>
<td>51000</td>
<td>00</td>
<td>0004</td>
<td>00002, fetch C</td>
</tr>
<tr>
<td>MAS08</td>
<td>01</td>
<td>10000</td>
<td>06</td>
<td>0000</td>
<td>MAS28, insert BM; store in T₆</td>
</tr>
<tr>
<td>MAS09</td>
<td>00</td>
<td>51000</td>
<td>00</td>
<td>0004</td>
<td>00004, fetch M</td>
</tr>
<tr>
<td>MAS10</td>
<td>01</td>
<td>10200</td>
<td>17</td>
<td>0004</td>
<td>00005, m x n → T₇</td>
</tr>
<tr>
<td>MAS11</td>
<td>00</td>
<td>51000</td>
<td>00</td>
<td>0004</td>
<td>00003, fetch S</td>
</tr>
<tr>
<td>MAS12</td>
<td>01</td>
<td>06060</td>
<td>00</td>
<td>4000</td>
<td>00000, if odd, skip by one</td>
</tr>
<tr>
<td>MAS13</td>
<td>00</td>
<td>51000</td>
<td>60</td>
<td>0000</td>
<td>MAS29, if even, fetch add oper.; skip</td>
</tr>
<tr>
<td>MAS14</td>
<td>00</td>
<td>51000</td>
<td>00</td>
<td>0000</td>
<td>MAS30, if odd, fetch sub operation</td>
</tr>
<tr>
<td>MAS15</td>
<td>01</td>
<td>20000</td>
<td>00</td>
<td>4000</td>
<td>MAS18, store in operation step</td>
</tr>
<tr>
<td>MAS16</td>
<td>00</td>
<td>01300</td>
<td>00</td>
<td>4000</td>
<td>MAS17, turn off exp overflow indic.</td>
</tr>
<tr>
<td>MAS17</td>
<td>00</td>
<td>51000</td>
<td>00</td>
<td>4400</td>
<td>00004, fetch element of matrix A</td>
</tr>
<tr>
<td>MAS18</td>
<td>00</td>
<td>00000</td>
<td>00</td>
<td>0000</td>
<td>00000, add or sub element of matrix B</td>
</tr>
<tr>
<td>MAS19</td>
<td>01</td>
<td>20000</td>
<td>00</td>
<td>4400</td>
<td>00006, store as element of matrix C</td>
</tr>
<tr>
<td>MAS20</td>
<td>00</td>
<td>02700</td>
<td>61</td>
<td>4000</td>
<td>00000, if no overflow, skip; step B₁</td>
</tr>
<tr>
<td>MAS21</td>
<td>41</td>
<td>01000</td>
<td>00</td>
<td>4004</td>
<td>00006, B₁ → U; transfer to error ret.</td>
</tr>
<tr>
<td>MAS22</td>
<td>41</td>
<td>02050</td>
<td>00</td>
<td>0000</td>
<td>00007, if B₁ = mxn, skip by one</td>
</tr>
<tr>
<td>MAS23</td>
<td>00</td>
<td>01000</td>
<td>00</td>
<td>4000</td>
<td>00017, loop back</td>
</tr>
<tr>
<td>MAS24</td>
<td>00</td>
<td>44100</td>
<td>00</td>
<td>4000</td>
<td>00000, restore B₁</td>
</tr>
<tr>
<td>MAS25</td>
<td>42</td>
<td>44200</td>
<td>47</td>
<td>4000</td>
<td>00000, B₂ → PFL; restore B₂</td>
</tr>
<tr>
<td>MAS26</td>
<td>00</td>
<td>01000</td>
<td>00</td>
<td>4200</td>
<td>00007, transfer to normal return</td>
</tr>
<tr>
<td>MAS27</td>
<td>00</td>
<td>00000</td>
<td>00</td>
<td>0002</td>
<td>00000, add operation</td>
</tr>
<tr>
<td>MAS28</td>
<td>00</td>
<td>00000</td>
<td>00</td>
<td>4002</td>
<td>00000, sub operation</td>
</tr>
<tr>
<td>MAS29</td>
<td>01</td>
<td>10400</td>
<td>00</td>
<td>4400</td>
<td>00005, add operation</td>
</tr>
<tr>
<td>MAS30</td>
<td>01</td>
<td>10500</td>
<td>00</td>
<td>4400</td>
<td>00005, sub operation</td>
</tr>
</tbody>
</table>
The reader is strongly urged to undertake the exercise of rewriting the foregoing program reducing the number of instructions necessary to accomplish the same task.