June 12, 1959 HG Kolsky Original Boot personal Copy

# **PRODUCT PLANNING**

Jechnical Report

DATE\_June 12, 1959\_\_\_\_

NUMBER P-17

The STRETCH Virtual Memory Concept and Timing Simulation Program

AUTHOR \_\_\_\_ John Cocke\* and Harwood G. Kolsky

LOCATION Poughkeepsie

\*(Present location: IBM Research, Poughkeepsie)

This report is company confidential

# TABLE OF CONTENTS

|     |             |                                                                                 | Page          |
|-----|-------------|---------------------------------------------------------------------------------|---------------|
| I.  | Introductio | on                                                                              | 1             |
| п.  | General De  | escription of the System                                                        | 1-4           |
| ш.  | Detailed D  | escription of Virtual Memory Operation                                          | 5-24          |
|     | А.          | General Conditions to be Considered                                             | 5             |
|     | в.          | Definitions                                                                     | 5-9           |
|     | C.          | Logic of the Virtual Memory                                                     | 9-24          |
| IV. | Description | n of Timing Simulation Program                                                  | 24-28         |
|     | Α.          | General Considerations                                                          | 24-25         |
|     | в.          | Logic of the Simulator                                                          | 26-28         |
| v.  | Some Resu   | lts of the Simulation Studies                                                   | 29-60         |
|     | Α.          | General Description                                                             | 29-32         |
|     | в.          | Test Problems Used                                                              | 32-33         |
|     | c.          | Results of Simple Parameter Studies                                             | 33-48         |
|     | D.          | The Effect of the Half-Microsecond Instruction Memory<br>on STRETCH Performance | <b>4</b> 8-55 |
|     | E.          | A Study of Branching on Arithmetic Results in STRETCH                           | 56-60         |
| VI  | APPENDIX    | C: Details of Timing Simulation Program SIM-2                                   | 61-80         |

# TABLE OF FIGURES

۴.

ł

٩.,

|           | Title                                                      | Page |
|-----------|------------------------------------------------------------|------|
| Figure 1  | Schematic of STRETCH Computer                              | 2    |
| Figure 2  | Contents of a Virtual Memory Level                         | 6    |
| Figure 3  | Virtual Memory Interlocks                                  | 8    |
| Figure 4  | Instruction Fetch Procedure                                | 10   |
| Figure 5  | Indexing Procedure                                         | 11   |
| Figure 6  | Procedure for Placing Instructions into the Virtual Memory | 13   |
| Figure 6A | Logical Conditions for Bring Type Operations               | 14   |
| Figure 6B | Logical Conditions for Store Type Operations               | 16   |
| Figure 6C | Logical Conditions for Immediate Type Operations           | 18   |
| Figure 7  | Data Fetch Procedure                                       | 19   |
| Figure 8  | Data Store Procedure                                       | 20   |
| Figure 9  | Procedure for Placing Data into Virtual Memory             | 21   |
| Figure 10 | Procedure for Removing Instruction from Virtual Memory     | 23   |
| Figure 11 | SIM-2 Simplified Flow Diagram                              | 28   |
| Figure 12 | Listing of Simulator Print-Out                             | 30   |
| Figure 13 | Listing of Simulator Summary Print-Out                     | 31   |
| Figure 14 | Computer Speed vs. no. Levels of Virtual Memory            | 36   |
| Figure 15 | Computer Speed vs. no. of Main Memory Boxes                | 38   |
| Figure 16 | Computer Speed vs. Indexing Arithmetic Time                | 39   |
| Figure 17 | Computer Speed vs. Average Arithmetic Time                 | 40   |
| Figure 18 | Computer Speed vs. Instruction Memory Cycle Time           | 42   |
| Figure 19 | Arithmetic Unit Efficiency vs. Average Arithmetic Time     | 43   |
| Figure 20 | Computing Speed vs. I/O Word Rate                          | 45   |
| Figure 21 | Computing Speed vs. Number of Memory Units 1               | 46   |
| Figure 22 | Computing Speed V <sup>8</sup> , Number of Memory Units 2  | 47   |

#### I. INTRODUCTION

Early in the planning of the STRETCH computer it was seen that by using the latest solid state components in sophisticated circuits that it would be possible to increase the speed of floating point arithmetic by almost two orders of magnitude over that in existing computers. However, there seemed to be no possibility of developing on the same time-scale economically feasible large memories with more than a factor of ten or perhaps twenty increase in speed. As a result, the proposed system appeared to be in danger of being seriously memoryaccess limited.

Moreover, as the speed of the floating point operations increases, a larger and larger percentage of the computer's time is spent on "parasitic operations", i.e., operations whose only function is program control and data selection. It was obvious that a radically new machine organization was necessary in order to capitalize upon the possibilities opened up by the high arithmetic speeds in the presence of relatively slow memories.

At this time, the possibility of a "look-ahead" device was suggested in which an independent indexing arithmetic unit would prepare the effective addresses of instructions and initiate memory references to a multiplicity of memory boxes. The data thus fetched would be held in high speed buffer registers until needed by the arithmetic unit. This device would serve two desirable purposes; (1) some of the parasitic operations would be done in parallel and thus not delay the principal calculations, and (2) several memory boxes could be running simultaneously, giving the effect of higher memory speed.

#### II. GENERAL DESCRIPTION OF THE SYSTEM

The major logically-independent blocks of the STRETCH computer are shown in Figure 1. Each of the units pictured may be considered as operating asynchronously. That is, each does its tasks as fast as possible independently of the others. In theory, each box could have its own clocking circuits and still operate properly. In practice, for economy's sake they are all timed by the same master oscillator, but this does not destroy their logical independence. The bus control unit serves as a routing agent between the memories and the various data processing units. If two or more units make a request simultaneously the control unit assigns priorities in the following order: (1) High speed Exchange, (2) Basic Exchange, (3) Virtual Memory, and (4) Indexing Arithmetic Unit.

The Indexing Arithmetic Unit fetches instructions, performs all necessary indexing operations and sends the instructions to be executed to the Virtual Memory.

1

The Virtual Memory fetches and receives the data required by the instruction and holds this data until the arithmetic unit is ready for it. The Virtual Memory also performs all store operations. It holds the data generated by the Arithmetic Unit or Indexing Arithmetic Unit until the memory to which the data must be sent is available. Thus the Virtual Memory acts not only as a'look-ahead" for instructions to be fed to the arithmetic unit, but also acts as a 'look-behind" storage buffer.

#### FIGURE 1



#### SCHEMATIC OF SIGMA COMPUTER

The actual design of such a "look-ahead" device posed a number of logical problems, particularly in connection with conditional branches. In colaboration with John Griffith, a device was proposed later named "virtual memory", which answered these logical problems and served as guide for the actual organization of STRETCH.

However, a machine organization of this complexity requires a detailed timing analysis in order to determine the value of adding hardware in the form of the "virtual memory". This is especially true since the sole function of the "virtual memory" is to increase machine speed, by increasing the efficiency of other devices. It was also felt that the timing analysis could not be made on the basis of a few trivial examples (e.g. matrix multiply). Machine performance obtained in this fashion can be extremely deceptive. Since a detailed timing analysis of a computer of this complexity is extremely tedious to carry out by hand, it became clear that if the job were to be done, it would be necessary to simulate the proposed machine on another computer. This prompted us to write the simulation program described below.

With the above general organization in mind, let us discuss some of the logical problems posed by such a system. The first problem is a result of the very concept which enables us to obtain such great benefits from the stored program computer--the ability to treat instructions as data. In a system such as we have proposed there is a large amount of simultaneous operation. For example, the indexing arithmetic unit may be busy preparing an instruction before previous instructions have been completed or even started by the arithmetic unit. One of these previous instructions may modify the instruction which is presently being indexed. The virtual memory must recognize this situation and allow the intervening instructions to be completed before doing the modified instruction.

A similar problem exists with respect to ordinary data. In order to operate several memories simultaneously, it is necessary to start obtaining data from these memories before the preceding operations have been completed. Yet, one of these operations may be a store into one of the data locations. The virtual memory must make provisions to insure that each instruction obtains the most up-to-date data as implied by the order of the program. One of the novel features of the STRETCH computer is its elaborate interrupt system. Under this system whenever some unexpected occurrence arises, the program will be interrupted and control will pass to a special routine which is designed to take care of the case in question, then return control to the original program. In this situation the virtual memory must have provisions to retain enough information so that when an interrupt occurs we can resume the computation exactly where we left off. It must be able to recognize which of the changes that have been made in advance are not desired and should be obliterated and which are exact solutions that must be restored.

Another special case arises when a conditional branch on arithmetic results occurs. Here we will not know which of the two branches we should have taken until the preceeding instruction is executed. In the case the wrong path has been selected, the virtual memory must be prepared to drop the intermediate results which have been computed and pick up the correct branch in a way very similar to that of an interrupt.

Summing up all these logical problems, we may state that the fundamental rule for the Virtual Memory is that it must make the asynchronous and non-sequential computer give results identical to those which would be obtained by performing the program one instruction at a time in the order in which they are written.

Since our original work on the virtual memory and simulation in 1957-58, a large number of detailed changes have been made in the actual hardware design of STRETCH. These necessitated several modifications in the Simulation program to estimate their effect on the overall system performance. In this report we are omitting many of these changes for expository reasons since our purpose is to describe the virtual memory and timing simulation concepts not to describe the STRETCH hardware exactly. The result is that the system described below imbodies a more general system than that found in the Simulator which in turn is more general than that found in the actual computer.

-4-

#### III. DETAILED DESCRIPTION OF VIRTUAL MEMORY OPERATION

#### A. General Conditions to be Considered

The conditions which occur in the following situations must be considered in some detail:

- 1. The fetching of instructions by the Indexing Arithmetic Unit.
- 2. The indexing of instructions and modification of Index registers.
- 3. The loading of the Virtual Memory and the setting of its conditions by the IAU.
- 4. The action of the Virtual Memory in fetching data.
- 5. The action of the Virtual Memory in storing data.
- 6. The communication between the Virtual Memory and the main arithmetic unit.
- 7. Special situations such as conditional branching on arithmetic results, etc.

#### **B.** Definitions

Some of the terms we will use are defined as follows:

#### 1. Operations

Operations are considered to be of three types:

- (1) Bring or fetch type All instructions requiring data to be transmitted from external memory to the Virtual Memory
- (2) Store Type Instructions requiring the transmission of data from the Virtual Memory to external memory or index memory.
  - (Note: We consider all indexing instructions to be of the Store Type, although the store may be to either external memory or index memory.)
- (3) Immediate Type All operations not requiring data transmission.

- 2. Virtual Memory Quantities
  - Virtual Memory A number of Virtual Memory (or lookahead) levels (numbered 0 to N-1).
  - (2) Level of Virtual Memory A collection of registers and control bits. The contents of the jth level is shown in Figure 2.

| <br>Ij                                                                                                          | OPj | S <sub>j</sub><br>Bit | B <sub>j</sub><br>Bit | F <sub>j</sub><br>Bit <sup>j</sup> | FAj | OK j<br>Bit j                                                                                                  | ${}^{C}_{Bit}$        | Dj                     | DA j |  |
|-----------------------------------------------------------------------------------------------------------------|-----|-----------------------|-----------------------|------------------------------------|-----|----------------------------------------------------------------------------------------------------------------|-----------------------|------------------------|------|--|
| And a passion of the second |     |                       |                       |                                    |     | Construction of the owner of the | CALIFORNIA CONTRACTOR | factor indemnities the |      |  |

Figure 2 Contents of a Virtual Memory Level

- (3) Instruction Address Register (I<sub>j</sub>) Contains the address of the instruction currently in the jth level.
- (4) Operation Code Register (OP<sub>j</sub>) Contains the operation to be performed by the arithmetic unit.
- (5) Store Bit (S<sub>j</sub>) A one bit trigger which indicates the level contains a Store type instruction.
- (6) Bring Bit (B<sub>j</sub>) A one bit trigger which indicates the level contains a fetch type instruction for which the data access has not been started.
- (7) Forwarding Bit (F<sub>j</sub>) A one bit trigger which indicates that the jth level must transmit data to another level.
- (8) Forwarding Address (FA<sub>j</sub>) A register which contains the number of the level to which the data must be sent if F<sub>j</sub> is set.
- (9) O.K. Bit (OK<sub>j</sub>) A trigger which when set indicates that the correct data for the instruction to be executed is present in the jth Data Field.
- (10) Data Field  $(D_j)$  A register which contains the operand data for the instruction.

- (11) Data Address  $(DA_j)$  The operand data address (already indexed by the IAU) for  $D_j$ .
- (12) Compare Bit  $(C_j)$  A trigger which if not set indicates the address in DA<sub>j</sub> should not be included in any address comparisons being made.

#### 3. Counters

The Virtual Memory is controlled by a set of counters which countmod (N), where N is the number of Virtual Memory levels.

- (1) Counter one (C1) Indicates the level into which the next instruction may be placed.
- (2) Counter two (C<sub>2</sub>) Indicates the level from which the next bring type instruction may be initiated.
- (3) Counter three (C3) Indicates the level from which the next store type instruction may be initiated.
- (4) Counter four (C<sub>4</sub>) Indicates the level from which the arithmetic unit will get its next operation and data.

#### 4. Interlocks

The above counters must be interlocked in the following manner to assure proper sequential operation of the computer (see figure 3):

- Interlock one (I1): C1 = C3 + N Prevents the IAU from placing the next operation into the level indicated by C1 because an unexecuted store is still in the level.
- (2) Interlock two  $(I_2)$ :  $C_1 = C_3$  Prevents a store from being initiated from the level indicated by C<sub>3</sub> because the store has already been done.
- (3) Interlock three (I3): C1 = C2 Similar to I2, prevents a fetch from being initiated.
- (4) Interlock four(I4):  $C_1 = C_4$  Prevents the arithmetic unit from executing an old instruction.



Interlocks I4 and I5 are as shown, the other interlocks are done in a similar manner.

# Figure 3. Virtual Memory Interlocks

(5) Interlock five  $(I_5)$ :  $C_1 = C_4 + N$  Prevents the IAU from placing the next instruction into the level indicated by  $C_1$  because the instruction there has not been executed yet.

#### C. Logic of the Virtual Memory

#### 1. General

There are two basic precepts which must be kept in mind to understand the operation of the Virtual Memory:

- (1) The OK bit  $(O_j)$  being set in the j th level indicates that the contents of  $D_j$  is the correct data called for by  $DA_j$ . All operations will be performed only under this condition and logical decisions will be made in such a manner as to make sure this is the case.
- (2) Addresses can be compared by the IAU with every  $DA_j$  address simultaneously.  $DA_j$  is not used for any level which does not have its  $C_j$  bit set. If a comparison exists between a new  $DA_j$  being placed in the Virtual Memory and an old  $DA_k$ , the compare bit  $C_k$  is turned off and the address of level j is placed in FA<sub>k</sub>. This insures a unique meaning for the comparison. If this were not done, another instruction address  $DA_e$  might compare against two levels and thus cause an ambiguity.

#### 2. Instruction Fetch Logic

Figure 4 is a flow diagram of the IAU Instruction Fetch Procedure. The logic is as follows: If the IAU is ready to fetch another instruction, it compares the instruction address with all the  $DA_j$ 's of Virtual Memory. If there is no comparison, the instruction fetch is initiated. If there is a comparison the IAU must take its instruction from the Virtual Memory provided the OK bit is set, otherwise, it must wait until the OK bit is set.

Note: This procedure prevents the logical difficulty mentioned earlier which would occur if the Virtual Memory contained a store order into the instruction presently being fetched.

For Example: a STORE Address a+2 a+1 LOAD M, i a+2 ADD N, i a+3 ----

The store to a + 2 must be done in sequence or the old value N would be used for the address instead of the quantity being set by a.



3

Figure 4, Instruction Fetch Procedure



Figure 5, Indexing Procedure

#### 3. Indexing Logic

Figure 5 shows the flow for instruction indexing. After determining that an instruction is ready to be indexed, the IAU tests whether or not the index value is available. If it is, the indexing operation is started, if not the memory reference is started and the IAU waits until the data returns before proceeding. If the index-fetch has not been started, the IAU compares the index address against all the data addresses in Virtual Memory. If none compare, the index value is fetched normally. If one does compare, the index fetch is held up until the OK bit is set for the data. This value from the Virtual Memory is then used for indexing the instruction.

## 4. Logic of Putting Instructions in the Virtual Memory

- (1) Figures 6, 6A, 6B, 6C represent the logical flow for putting instructions into the Virtual Memory. If the indexing arithmetic unit has an instruction prepared for the Virtual Memory, it may transmit the instruction into the Virtual Memory if interlocks one and five do not forbid it. These interlocks prohibit a new instruction from destroying an old one which has not been executed as yet, whether an arithmetic operation (I5) or an unexecuted store (I1). The handling of the instructions vary depending on whether they are of the bring type, store type, or immediate type.
- (2) The bring type, as described in Figure 6A, proceeds as follows: If the effective data address of the instruction compares with the DA address in some level, the instruction, its op code, and effective data address are loaded into the level marked by  $C_1$ . The compare bit for level  $C_1$  is set to one while the compare bit for the compared-with level is set to zero. If the O.K. bit in this compared-with level is set, meaning that the data located there is correct, the data is transmitted directly to the  $C_1$  level and its O.K. bit is also set. If the O.K. bit is not set, we must tag the compared-with level of  $C_1$  into its Forwarding address, the bring bit for level  $C_1$  is also set to zero since no further data fetch is required.

If the effective data address does not compare with any Virtual Memory level, the instruction is put directly into level  $C_1$ , its OK. bit is set to zero, and its bring bit is set to one, indicating that a fetch must be started.



Figure 6, Procedure for placing Instructions into the Virtual Memory

-13-





(3) Figure 6B shows the Store type procedure. If the effective address of the instruction does not compare with the DA address in some level, the instruction is placed into the level marked by  $C_1$ . The store bit is set to one indicating that a store will be required. The level's bring bit and forwarding bit are set to zero, its compare bit is set to one. If on the other hand the addresses do compare, the same procedure is followed but in addition, the compare bit in the level compared-with is set to zero so that future comparisons will not use it.

The OK bit has not yet been set. It is set to one if the operation is an index store and set to zero if it is an ordinary store. For the ordinary store it is clear that the OK bit should be zero since the data must come from the arithmetic unit after the preceeding instruction is executed.

As was mentioned in the definition on page 5, we treat all indexing instructions as store type and place the new value of the indexed quantity into the Virtual Memory. This is done because the Indexing Arithmetic Unit is going ahead of the normal order of instruction execution and an interruption may occur before this indexing instruction should have been done. In this case, the old value of the index is still in the index register. On the other hand the Indexing Arithmetic Unit compares with the Virtual Memory and extracts the most recent value of the index for indexing succeeding instructions. The OK bit is set to one since the appropriate data is in the above level. Both the new and old index values must be carried along to give logically correct conditions in the case of an interrupt.

A situation very similar to interrupt occurs in branches on arithmetic results where the Indexing Arithmetic Unit "guesses" which branch will be taken and proceeds with fetching and processing the instructions on this branch subject to being wiped out if the guess proved to be wrong. (See the discussion on "Wrong way Branches" below.)



Figure 6B, Logical Conditions for Store Type Operations

(4) Immediate Type instructions are the simplest type because they essentially carry their data with them. Figure 6C shows the logic in this case. The instruction is placed in the Virtual Memory level marked by  $C_1$ . The address field of the instruction is placed in the data field of  $C_1$ . The OK bit is set to one indicating the data is present. The bring and store bits are both set to zero. The compare bit is set to zero since the DA address field has no meaning for immediate type ops. (The data address of the last instruction which occupied this level still remains in DA so it has no relation to the present D field.)

#### 5. Logic of Data Fetching

See Figure 7: When an instruction of the bring type has been placed in the Virtual Memory, the data required by the instruction in general will not be present (unless a comparison exists as was described above) and thus the data must be obtained from core storage. The fetch cannot be started if interlock I<sub>3</sub> holds which means all the fetches corresponding to the instructions presently in the Virtual Memory have been started. If a fetch is possible, the bring bit at level  $C_2$  indicates whether or not a fetch is necessary. If necessary the fetch may be started if the memory bus and memory unit corresponding to the data address are not already being used. When the fetch is started, the bring bit for level C<sub>2</sub> is set to zero. The counter C<sub>2</sub> is then stepped forward to the next level.

## 6. Logic of Data Storing

Figure 8 shows the Data Store logic, which is very similar to that for data fetching just described. The only significant difference is that the O.K. bit must be set before the operation can be started.

#### 7. Logic for Placing Data into the Virtual Memory

In Figure 9, we see the logical conditions which must be satisfied by the data returning from Memory addressed to the Virtual Memory. The return address which was supplied when the fetch was started selects the level into which the data will be placed. The O.K. bit is then set to one indicating that the proper data is in the level. The operation is complete at this point unless

From Figure 6

In the  $C_1$  level: Put the instruction address in IA, put the op code in OP, Put the data address into D (Note this) Set O.K. bit to one Set forwarding bit, the bring bit and and store bit to zero. Set the compare bit to zero (Note)

return to top of Figure 6

Figure 6C, Logical Conditions for Immediate Type Operations





Figure 8, Data Store Procedure



# Figure 9, Procedure for Placing Data into Virtual Memory

the Forwarding bit is set. In this case, the data must be forwarded to the level designated by the Forwarding address. This procedure continues from level to level as long as the data continues to arrive into a level whose Forwarding bit is set. This procedure automatically supplies all operands present having identical data addresses with the proper data without additional memory references.

8.

## Logic of Removing Instructions from the Virtual Memory

Observing Figure 10, we notice that as the arithmetic unit completes an instruction it checks to see if the next instruction in the Virtual Memory is ready to be executed (indicated by interlock I4). Note: The operation may be an unconditional branch, a conditional branch, or an index type store as well as a normal bring or store type instruction involving the accumulator. Figure 10 shows only the cases which involve the universal accumulator. The index and unconditional branches and the index store operations are merely ignored at this point. They are carried along only to provide the data for recovery in the event an interrupt occurs. The execution of the conditional branches on arithmetic results are described in the next section.

If the next instruction marked by counter C4 is ready, it is fed into the arithmetic unit. If it is a store type, the data is gated from the accumulator into the data field of level C4, and the OK bit is set to one. If the Forwarding bit of the level is set, a forwarding procedure in this case is essential for the proper logical operation of the computer, whereas in the bring case it is a time-saver only.

If the instruction is not a store type, the arithmetic unit must hold up until the O.K. bit for the level is set. When the O.K. bit is set, the instruction is gated into the arithmetic unit and executed.

### 9. Logic of Interrupt Procedure

If for any cause an interrupt (or trap) from a special condition occurs, the instruction which is being executed in the arithmetic unit is completed. However, the next instruction is not executed in spite of the fact all the data preparation for it may have been completed. The address in the IA (instruction address) field will serve as the value to reset the instruction counter if it is desired.



# Figure 10, Procedure for Removing Instructions from Virtual Memory

The Vitual Memory is initialized, i.e., set to the starting conditions of an interrupt, with the exception that all store orders which have already received data from the accumulators must be executed first. Note: If the interrupt is of such a nature that the normal flow of instructions is not resumed, the procedure of storing the modified values of the index registers in the Virtual Memory gives logically correct results, i.e., the same as if the interrupt had occurred before the indexing took place.

#### IV. DESCRIPTION OF TIMING SIMULATION PROGRAM

#### A. General Considerations

During the logical design of STRETCH it was necessary to prove the value of the Virtual Memory concept and to assist in the selection of optimum values of various system design parameters. Examples of such parameters are: The number of memory boxes, interlace and allocation of memory addresses, and numbers of Virtual Memory levels. Also of interest were trade-off factors for speeds of indexing arithmetic unit, arithmetic unit, memories, etc.

In November 1957 the Timing Simulator (SIM-2) described here was written for the IBM 704. This program attempted to answer such questions quantitatively by simulating the time-wise operation of STRETCH on typical test programs coded in STRETCH language.

The basic logic of the 704 program follows the principles just described in the preceeding section for the Virtual Memory. It should be stressed that the Simulator is a Timing Simulator and does not execute the instructions in an arithmetic sense. It traces the time-wise progress of the instructions through the components of the computer observing all the interlocks and time delays necessary for correct representation of the behavior of the machine.

One of the fundamental concepts in the STRETCH design is that of <u>asynchronous</u> operation of the components. This means that there are a large number of logical steps being executed at any one time in the computer, each of them proceeding at its own rate. To simulate this flow of many parallel continuous operations, we have broken the continuous time variable into finite time steps. The basic time step is taken as 0.1 microsecond in the Simulator. Several reasons prompted us to select this time interval. Some are relatively simple, such as the desire to have the results come out in microseconds and decimal fractions thereof. Taking a coarse time interval makes a given problem run faster on the Simulator since the running time is almost inversely proportional to the time step being used.

More fundamentally, the "natural" internal time scales of the computer are represented on one hand by the cycle time of the main memories (2 microsec) and on the other hand by the time required for signals to traverse one logical level in the circuits (5 to 20 millimicroseconds). The external time scale of the computer, as given by the I/O devices, is in the order of milliseconds for start up time and tens of microseconds for data flow rates.

Most internal macro logical processes require 0.1 microseconds or more since they usually require at least 10 logical levels. These represent the scale of quantities we wished to study in this simulator. Other scales could have been chosen. For example, one could write a program which followed the operation of every logical "and" and "or" circuit in the computer. (In fact, the authors have written such a program for a small experimental study.) The simulation program is simpler on this scale but the specification of a computer such as STRETCH would be an enormous task-- equivalent to laying out the whole circuit design. Another difficulty, would be that changing a gross parameter such as the multiply time might require the changing of thousands of "and" and "or" blocks in the circuit specification.

By taking 0.1 microsec as our quantum of time, we are automatically setting the scale of the smallest circuit entities which we will consider as being those which accomplish complete functions in a 0.1 microsec or few multiples thereof. Thus by using this philosophy, and considering many of the components of the computer as "black boxes", we greatly simplify the details which must be considered without introducing serious timing inaccuracies.

Our experience has indicated that more information was gained by making a large number of fast parameter studies using different configurations and programs that could have been obtained by a very slow, detailed simulation of a few runs with more precision per run. Even so our time scale is too fine to make serious Input-Output applications studies. These would require a simpler Simulator having at least a factor of 10 coarser basic time interval.

#### B. Logic of the Simulator

In the asynchronous organization of STRETCH there can be many major components operating at any one time. To achieve this parallel effect in the Simulator we essentially "hold time still" and scan the entire machine representation at each time step. Although every major block of the program is traversed at each time step, if there is no activity required in a given block, only a few tests need be made by the code.

If in this process it is determined that a given logical unit should do an operation, the time interval required for the operation is obtained from a table of constants. The speed of the various logical units can thus be changed parametrically by changing the values in the tables. A constant obtained from the tables is inserted into a memory location called the time counter for that unit. At each time step the program reduces this counter by one until it reaches zero. Thus the fact that the counter is non-zero can be used to indicate that the particular logical unit is busy and not available to service other requests. When the counter is zero the unit can consider a new input.

In addition to the time counters many of the logical blocks contain other conditions or interlocks which effect the operation of the block. These conditions are stored in the program and tested before action is undertaken. As an example, the 'O.K. bit" described in the previous section is stored as a "one" or "zero" in a memory location associated with each Virtual Memory level (called LAU6, i in the program, where i is the Virtual Memory level). The "O.K." bit indicates that the data in the level is the correct value for the operation. In the program the "OK bit" is set by storing a one in location LAU6, i.

Each logical unit when it completes its operation may have data available to start another unit. The other unit may be notified that the data is available in two possible ways. Either (1) The subroutine corresponding to the receiving logical unit searches all possible inputs to determine if any of them has data for it, or (2) the sending unit sets logical constants within the receiving unit which indicate that the data is available. For example, the "O.K. bit" is set for a given level by the memory in-bus subroutine. While on the other hand, the arithmetic unit subroutine tests the O.K. bit to determine whether or not data is available for it. The simplified Flow Diagram in Figure 11, indicates the order in which the subroutines for the various logical units are executed at each time step. Using the types of techniques just described above, the logical subroutines simulate the action of the components of the computer such as the Virtual Memory, arithmetic Unit,etc.

The details of the Simulator are described by Tables 1 through 4 and in the detailed flow diagrams at the end of this report. These flow diagrams can be corrolated in the obvious way with those given in the section which describes the Virtual Memory. The Simulator also contains several other subroutines which do such things as initialize the program at the beginning of a run, set up the timing diagrams and summarize the results of the run. (see discussion in the Result Section).

The STRETCH instructions being simulated are read into the 704 from tape as required. The instructions are put on tape from cards at the beginning of a run. (The input quantities read in for each operation are listed in Table I, column 1.) It is interesting to note that since the Simulator simulates timing only, not the arithmetic or indexing functions, the sequence of instructions to be executed must be furnished as a "string" with all loops unwound. However, to make the computer behave as it actually would, the loops must be furnished with "wrong way" paths given for the cases where the computer would take such paths. Also one must furnish <u>more</u> than enough information along such paths since it is difficult to predict in advance how far the computer will get down the wrong path before it is called back.

Parameters are changed from one run to another by use of control cards. The control cards are set up in such a way that any number of parameters may be changed between runs.

Results are given either as detailed timing charts or as summary listings for each problem. The usual procedure has been to print only summary results while making a series of parameter studies. At the end of each run the new control card or cards are read in, the problem tape is rewound, and the Simulator reruns the problem with the new constants.



15 Summarize and print

Figure 11. SIM - 2 Simplified Flow Diagram

#### V. SOME RESULTS OF THE SIMULATION STUDIES

#### A. General Description

#### 1. Introduction

During 1958 a number of reports were written giving results of runs made with the SIM-2 program. We will not attempt to record here all of the results thus presented because many of them were superseded by later reports or were concerned with specific problems in the design of STRETCH. The results quoted here were chosen for their general interest as parametric studies and are not intended to represent STRETCH as it is actually designed.

#### 2. Output Listings of Simulator

Figures 12 and 13 show examples of the type of output listings given by the Simulator. Figure 12 is a piece of a long timing chart with each line of printing representing 0.1 microsecond of time. The columns represent the various components of the computer. On the left and right are timing counts subdividing each microsecond. On the far right are conflict indicators ("C" on the charts) and waiting indicators, "W" which indicate when interlocks prevent operations from proceeding.

The 2nd column, II, gives the number of the instruction being indexed. The 4th column, AU, gives the number of the instruction using the arithmetic unit. The next four columns represent the instructions using the memory buses. The columns labeled X-,F-, and M- represent the index, fast, and main memories. A string of "X's" in the columns represents the cycle time of the memory. The number indicates the instruction using the memory and number of times which it is repeated gives the read-out time of the memory. The columns L- indicate which instruction is located in the Virtual Memory levels. The other columns are for details in analysis and need not be considered here.

Figure 13 gives an example of a series of summary listings. Each set of numbers represents a total problem run. The quantities listed are given in Tables III and IV. As was mentioned earlier, for most of the runs made in the Simulator studies, only summary runs were made.

# -30A-Figure 12 Listing of Simulator Print-Out

PROJECT 7000 SIMULATOR '2 COCKE + KOLSKY NOV 57

|                                                 | T 7000 SIMULATOR 42 COCKE + KOLSKY NOV 57                     | <b>.</b>                                                                                                            | * LO #5 M/S M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ······                      |
|-------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| $\begin{array}{c} 1 \\ 1 \\ 2 \\ 1 \end{array}$ | IS AU IF IM OF OM X1 X2 F1 F2 F3 F4 M1 M2 M3 M4 M5 M6 M7 M8 U | LI LZ LJ L4 LJ LO L                                                                                                 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 2 1                         |
| 3 1<br>4 1                                      |                                                               |                                                                                                                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1 2                         |
| 5 1                                             | 1                                                             |                                                                                                                     | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 2 4<br>1 5                  |
| <u>6 1</u><br>7 1                               | <u>1X</u><br>3 1X                                             | <br>20 - Maria (1947) - Maria Maria (1947) - Maria (194 | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <u>6</u><br>2 7             |
| 8 <u>1</u><br>91                                | <u> </u>                                                      |                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | $\frac{1}{1}$ $\frac{8}{9}$ |
| $\frac{0}{1}$                                   | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$         | nen a men sekara kan sekara kan sekara kan sekara kan sekara sekara sekara sekara sekara kan sekara kan sekara      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 2 10                        |
| $\frac{1}{2}$ $\frac{1}{3}$ $\frac{1}{1}$       | 3X                                                            | 999 1 1993 9 1999 19 19 1 19 19 19 19 19 19 19 19                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1 1 2                       |
| 4 1                                             | 3 X<br>1 3 X                                                  |                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 23<br>14                    |
| 5 1<br>5 1                                      | 1                                                             | <b>Man a a Balance a san an a</b>                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 5                           |
| 71                                              | 4                                                             | n i na haf man ann an                                                                 | and the set of the second set of the second s | 2017                        |
| 2                                               | 1                                                             | 1                                                                                                                   | ·····                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <u>8</u><br>2 9             |
| 2                                               | <u>2</u><br>4 1 X                                             | 1                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | $\frac{1}{1}$               |
| 3                                               | 1                                                             | <u>1</u><br>21                                                                                                      | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | $\frac{2}{1}$ $\frac{2}{3}$ |
| 3                                               | 2<br>4 2 5 X                                                  | 2 '1                                                                                                                | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 4                           |
|                                                 | <u>1</u> 5                                                    | 2 1 2 1                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 25<br><u>16</u>             |
| 4                                               | 1 5X<br>2 5X                                                  | 3 2 1<br>3 2 1                                                                                                      | ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 7<br>28                     |
| 4                                               | 2 3 X 5X<br>4 5X                                              | 3 2 1<br>3 2 1                                                                                                      | ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1 9                         |
|                                                 | 1 5 X<br>1 5 X                                                | 3 2 1                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 2 1                         |
|                                                 | 1                                                             | 4     3     2       4     3     2                                                                                   | 747                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3                           |
|                                                 | $\begin{array}{cccccccccccccccccccccccccccccccccccc$          | <u>4 3 2 1</u><br>4 3 2 1                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 24<br>15                    |
| ····· E ·····                                   | 2 7X 4X<br>4 7X 4X                                            | $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | . 6<br>. 7                  |
| 6                                               | 1 7X 4X<br>1 7X 4X                                            | <u>4 3 2 1</u><br><u>4 3 2 5</u>                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1 8                         |
| 6                                               | <u>2 7 × 4X</u>                                               | 4 3 2 5                                                                                                             | 5<br>5 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 9<br>2 10                   |
|                                                 | 14X                                                           | 4 3 2 5<br>4 3 2 5                                                                                                  | 5 1<br>5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1 1                         |
|                                                 | 1 5 4X<br>2 4 5 X                                             | 4 3 6 5<br>4 3 6 5                                                                                                  | 9 2<br>9 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 2 2                         |
| 7                                               | 2 4 X 5X<br>4 9 X 5X                                          | 4 3 6 5<br>4 3 6 5                                                                                                  | 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 5                           |
| 8                                               | 1 4 9 X 5X                                                    | 4 3 6 5                                                                                                             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1 7                         |
| 8                                               | 2 9X X 5X                                                     | 4 7 6 5                                                                                                             | 7 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 8<br>2<br>9<br>1 10         |
| 8                                               | 2 X 9X X 5X<br>2 9X X 5X                                      | 4 7 6 5                                                                                                             | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1 10                        |
|                                                 | <u>4 9 7 X X 5X</u><br>1 9 5 7 X X X                          | <u>4 7 6 5</u><br>4 7 6 5                                                                                           | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 2 2<br>1 3                  |
|                                                 | 1 5 X X 7X                                                    | 8 7 6 5<br>8 7 6 5                                                                                                  | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 4                           |
| 9 2                                             | 2 <u>5</u> X 7X                                               | 8 7 6 5                                                                                                             | 11 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | l 6                         |
|                                                 | <u>1 5 11 X 7X</u>                                            | 8 7 6 5<br>8 7 6 5                                                                                                  | 11 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                             |
| 10 $10$ $2$                                     | <u>2 5 11X X 7X</u>                                           | 8769<br>8769                                                                                                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | . 9<br>10                   |
| 10 2                                            | <u>2 7 11X X X</u>                                            | 8769<br>8769                                                                                                        | <b>2</b><br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2                           |
| 10 4                                            | 4 6 7 X 11X X X                                               | 8769                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 3                           |
|                                                 | 1 7 11 X X                                                    | 8 7 10 9                                                                                                            | 2<br>13 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                             |
| 5 :                                             | 1 7 ×                                                         | 8 7 10 9                                                                                                            | 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 6                           |

Figure 12 Listing Of Simulator Print-Out

| 7 11 1                                                                                                          |                       |                         | ×            | 8 7                   |                 |          |               | CW<br>CW   |
|-----------------------------------------------------------------------------------------------------------------|-----------------------|-------------------------|--------------|-----------------------|-----------------|----------|---------------|------------|
| 8 11 2                                                                                                          |                       |                         | <u> </u>     | 8 7                   |                 |          |               |            |
| 9 11 2                                                                                                          | X                     | 13X                     | X            |                       | 10 9<br>10 9    |          | 2 10          |            |
| 10 11 2                                                                                                         |                       | 13X                     | X            |                       | $\frac{10}{10}$ |          | 1 1           | W          |
| 1 11 4                                                                                                          |                       | 13X<br>13X              | x            | 8 7                   |                 |          | ÷ 2           | CW         |
| $\frac{2}{3}$ 12 1                                                                                              | 13 8                  | X                       |              | 8 11                  |                 |          | 2 3           |            |
|                                                                                                                 |                       | x                       | . ^          | 8 11                  | 10 9            |          |               | CW         |
| $-\frac{4}{5}$ 12 4                                                                                             | 1.5 6                 | ^                       | 8X           |                       |                 | <u> </u> |               | S CW       |
| 6 1                                                                                                             | •                     |                         | 8X           | 8 11                  |                 |          |               | S CW       |
| 7 13 1                                                                                                          | 10                    |                         | 8X           |                       | 10 9            |          |               | CW         |
| .8 13 1                                                                                                         | ••                    |                         | 10X 8X       | 8 11                  |                 |          | . 8           | CW         |
| 9-13 1                                                                                                          | 15                    |                         | 10X 8X       | 8 11                  | 10 9            |          | 2 9           | CW         |
| 10 13 1                                                                                                         | 15                    |                         | 10X 8X       | 8 11                  | 10 9            |          |               | ) CW       |
| 1 13 1                                                                                                          | 1!                    | 5X                      | 10X 8X       | 8 11                  | 10 9            |          |               | . CW       |
| 2 13 1                                                                                                          |                       | 5X                      | 10X 8X       | 8 11                  |                 |          |               | CW         |
| 3 1 3 1                                                                                                         |                       | 5X                      | 10X X        | 8 11                  | 10              | 2        |               | B CW       |
| 4 13 1                                                                                                          |                       | 5X                      | 10X X        | 8 1.1                 |                 | 2        |               | r CW       |
| 5 1 3 1                                                                                                         |                       | X                       | 10X X        | 8 11                  |                 | 9        |               | 5 C<br>5 C |
| 6 13                                                                                                            | 8 15 10               | <u>X</u>                | <u> </u>     |                       |                 | <u>9</u> |               |            |
|                                                                                                                 | 2 8 10                | 1                       |              | 12 11<br>12 11        | 10 1            | 9        | 2 8           |            |
| 8 13                                                                                                            | <u>28 X</u>           |                         | <u> </u>     | $\frac{12}{12}$ 11    |                 | 9        | 1 9           | <u>, с</u> |
|                                                                                                                 | 2 8                   |                         | X X X X      | $12 11 \\ 12 11$      |                 | 9        |               |            |
|                                                                                                                 | <u>48</u><br>18       |                         | <u> </u>     | $\frac{12}{12}$ 11    |                 | 9        |               |            |
| $1 \\ 2 \\ 14 $                                                                                                 |                       |                         |              | 12 11                 |                 | 9 11     | īź            |            |
|                                                                                                                 | 1 9 X                 |                         | XX           |                       |                 | 9 11     | 3             | 3          |
|                                                                                                                 | 1 11                  |                         | x x          | 12 11                 | 10 1            | 3 13     | 2 4           | ÷          |
|                                                                                                                 | 2 10 11               | ****                    | X            | 12 11                 |                 |          | 1 5           | 5          |
|                                                                                                                 | 2 10 X                |                         | X11X         | 12 11                 |                 |          |               |            |
|                                                                                                                 | 2 13                  |                         | X11X         | 12 11                 |                 |          | 2 7           |            |
|                                                                                                                 | 4 13                  |                         | <u>11X</u>   |                       | 10 1            |          | 1 8           |            |
|                                                                                                                 | 1                     | 13X                     | 11X          | 12 11<br>12 11        | 10 1            | 3        | 2 10          |            |
| 10 15                                                                                                           | <u>.</u>              | <u>13X</u>              | <u>11X</u>   |                       |                 |          | $\frac{2}{1}$ |            |
|                                                                                                                 | 2                     | 13X<br>13X              | 11X<br>11X   | $12 11 \\ 12 11$      | 14 1            |          |               | 2 W        |
|                                                                                                                 | 4 17 14               | 13×                     | 11X          | $\frac{12}{12}$ 11    |                 |          |               | 3 W        |
|                                                                                                                 | 1 11 17 14            | 13X                     | x            | 12 11                 |                 |          |               | 4 W        |
| the second s  | <u>1</u> 11           | 17X 13X                 | 14X X        |                       | 14 1            |          | 2             | 5 W        |
|                                                                                                                 | 1                     | 17X 13X                 | 14X X        | 12 11                 | 14 1            | 3        |               | 5          |
|                                                                                                                 | 1 11 13               | 17X X                   | 14X X        | 12 15                 | 14 1            | 3        |               | 7.         |
| 8 16                                                                                                            | 2 11 13               | 17X X                   | 14X X        | 12 15                 |                 |          |               | 3          |
| 9 16                                                                                                            | 2 11 17 X             | X X                     | 14X X        | 12 15                 | 14 1            | 3        |               | 9          |
| 10 16                                                                                                           | 2 11 17               | <u> </u>                | 14X X        | 12 15                 |                 |          | 1 10          |            |
| 1 16                                                                                                            | 3 11 X                | X                       | 14X X        | 12 15<br>12 15        | 14 1            | 3        | 2             | 1<br>2     |
| 2 16                                                                                                            | 3 11                  | <u> </u>                | 14X X<br>X X | 12 15                 | $\frac{14}{14}$ | 3        | 1 2           | 3 W        |
| 3 16                                                                                                            | 4 14<br>1 12 14 X     | X                       | x x          | 12 15                 |                 |          |               | 4          |
|                                                                                                                 | <u>1 12 14 ^</u><br>1 | X                       | <del></del>  | 16 15                 |                 |          |               | 5          |
|                                                                                                                 | 2 13                  | ×                       | x            | 16 15                 |                 | 3 19     |               | 6          |
| 7 17                                                                                                            | 2 13 X                | X                       | X            | 16 15                 | 14 1            | 3 19     |               | 7          |
| 8-17                                                                                                            | 2 19                  | X                       | <u>×</u>     | 16 15                 |                 |          |               | 3          |
| 9 17                                                                                                            | 314 19 X              |                         | X            | 16 15                 | 14 1            | 3        |               | 9          |
|                                                                                                                 |                       | 9X                      | <u>×</u>     | 16 15                 | 14 1            | 3        | 10            |            |
|                                                                                                                 |                       | 9X                      | X            | 16 15                 |                 |          |               | 1<br>2     |
| the second se |                       | 9X                      | <u> </u>     | <u>16 15</u><br>16 15 |                 |          |               | <u> </u>   |
|                                                                                                                 | 1 14 1<br>2 14 19     | 9X<br>X                 | x            | 16 15                 |                 |          |               | 4          |
|                                                                                                                 | 2 19                  | <u>×</u>                | <u></u>      | 16 15                 |                 |          | 1 !           | 5 W        |
|                                                                                                                 | <u>4 15 X</u>         |                         |              | 16 15                 |                 |          |               | 6          |
|                                                                                                                 | 1                     |                         |              | 16 15                 | 14 1            | 7        |               | 7          |
|                                                                                                                 | ī 16 X                |                         |              | 16 15                 | 18 1            | 7 21 18  |               | 8          |
| 9 19                                                                                                            | 2                     |                         |              | 16 15                 | 18 1            | 7 21 18  |               | 9          |
|                                                                                                                 | <u>2 17 21 18 X</u>   |                         |              | 16 15                 |                 |          | 2 10          |            |
|                                                                                                                 | 4 21 18               | <b>A1</b> V <b>A</b> 2V |              | 16 15                 |                 |          |               | 1 W<br>2 W |
| 2                                                                                                               |                       | 21X 18X                 |              | 16 15<br>16 19        |                 |          |               | 2 W<br>3 W |
|                                                                                                                 | 1                     | 21X 18X<br>21X 18X      |              | 16 19                 | 18 1            |          |               | 4 W        |
| <u>4 20</u><br>5 20                                                                                             | 4                     | 21X 18X                 |              | 16 19                 |                 |          |               | 5 W        |
| 6                                                                                                               | 1 21 19               | X 18X                   |              | 16 19                 | 18 1            | 7        | 2             | 6 W        |
| 7                                                                                                               | 1 21 19               | X 18X                   |              | 20 19                 | 18 1            | 7 23     | 1             | 7 W        |
|                                                                                                                 | · · · ·               |                         |              |                       |                 |          |               |            |

-30C-Figure 12 Listing of Simulator Print-Out

| 4                    |                                 |                   |                           |                                   |                       |                             |
|----------------------|---------------------------------|-------------------|---------------------------|-----------------------------------|-----------------------|-----------------------------|
| <b>∽ 8</b>           | 1                               |                   | 18X19X                    | 20 19 18 17                       | 23                    | 8 W                         |
| 9 21                 | 1 23                            |                   | 18X19X                    | 20 19 18 17                       |                       | 2 9 W                       |
| <u>10 21</u><br>1 21 | <u>2 18 23</u><br>2 18          | 2.3X              | <u>X19X</u><br>X19X       | <u>20 19 18 17</u><br>20 19 18 17 |                       | <u>1 10 W</u>               |
|                      | 4                               | 23X               | x19x                      | 20 19 18 17                       |                       | 2 2                         |
| 3                    | 1 18                            | 23X               | X19X                      | 20 19 18 17                       |                       | 1 3                         |
|                      | <u>1 18</u><br>2 23             | 23X<br>X          | <u>X19X</u><br>X19X       | <u>20 19 18 21</u><br>20 19 18 21 | 21                    | 4<br>2 5 W                  |
|                      | 2 23 19                         | x <u> </u>        | XX                        | 20 19 18 21                       | 21                    | 1 6 W                       |
| 7 22<br>8 22         | 2 19<br>4 ' 21                  |                   | × ×<br>× ×                | 20 19 18 21                       | 21                    | 7 W                         |
|                      | <u>4</u> ' <u>21</u><br>1 19 21 |                   | <u> </u>                  | <u>20 19 18 21</u><br>20 19 18 21 |                       | <u>28</u><br>19             |
| 10 23                | 1 19                            | ······            | X X21X                    | 20 19 22 21                       | 25 22                 | 10                          |
| 1 23                 | 2 19                            |                   | X X21X<br>X21X            | 20 19 22 21<br>20 19 22 21        | 25 22                 | 2 <u>1</u><br>1 2           |
|                      | 1 19                            |                   | X21X                      | 20 19 22 21                       | <u>25 22</u><br>25 22 | 3                           |
|                      | 1 19 25 22                      |                   | X21X                      | 20 23 22 21                       |                       | 2 4                         |
|                      | 2 25 22<br>2 20                 | X 25X             | X21X<br>X21X22X           | 20 23 22 21<br>20 23 22 21        |                       | 1 5 W                       |
| 7 24                 |                                 | X 25X             | X21X22X                   | 20 23 22 21                       |                       | 2 7 W                       |
| 8 24                 | 2 21                            | 25X               | <u> </u>                  | 20 23 22 21                       |                       | 1 8 W                       |
| 9 24<br>10'          | 4 21<br>1 25                    | 25X<br>X          | X22X<br>X22X              | 20 23 22 21<br>20 23 22 21        |                       | 9 W<br>2 10                 |
| 1                    | 1 21 25                         | ×                 | X22X                      | 24 23 22 21                       | 27 24                 | 1 1                         |
|                      | <u>1 21</u><br>1 27 24          |                   | X22X                      | 24 23 22 21                       | 27 24                 | 2                           |
|                      | 27 24<br>2 22 27 24             |                   | X22X<br>X X               | 24 23 22 21<br>24 23 22 21        |                       | 2 3 W<br>1 4 W              |
| 5.25                 | 2 22                            | X 27X             | 24X X X                   | 24 23 22 21                       |                       | 5 W                         |
| <u>6 25</u><br>7 25  | 2 4 22                          | 27X<br>27X        | <u>24X X X</u><br>24X X X | <u>24 23 22 21</u><br>24 23 22 21 |                       | 2 6                         |
| 8                    | 1 22                            | 27X               |                           | 24 23 22 21                       | 1                     | 8                           |
| 9 26                 | 1 22 27                         | X                 | 24X X X                   | 24 23 22 25                       |                       | 2 9                         |
|                      | 2 22 27                         | <u>x</u>          | <u>24X X</u><br>24X X     | 24 23 22 25<br>24 23 22 25        | 25                    | $\frac{1 \ 10}{1}$          |
| 2 26                 | 2 22 25                         |                   | 24X X                     | 24 23 22 25                       |                       | 2 2                         |
| 3 26                 | 4 24 25                         | v                 | X X X                     | 24 23 22 25                       | 1                     | 1 3 W                       |
| 4 5 27               | <u>1 23 24</u><br>1             | x                 | <u>X 25X X</u><br>X 25X X | <u>24 23 22 25</u><br>24 23 26 25 | 29 26                 | <u>4</u><br>2 5             |
| 6 27                 | 2 24                            |                   | X 25X                     | 24 23 26 25                       | 29 26                 | 16                          |
| 7 27<br>8 27         | 2 24<br>2 29 26                 | x                 | X 25X<br>X 25X            | 24 23 26 25<br>24 23 26 25        | 29 26                 | 7<br>28W                    |
| 9 27                 | <u>4 29 26</u>                  |                   | <u> </u>                  | 24 23 26 25                       |                       | <u>2 8 W</u><br>1 9 W       |
|                      | 1                               | 29X               | X26X25X                   | 24 23 26 25                       |                       | 10 W                        |
|                      | 1<br>2 25                       | 29X<br>29X        | X26X25X<br>X26X X         | 24 27 26 25<br>24 27 26 25        | 27<br>27              | 2 1 W<br>1 2 W              |
| 3 28                 | 4 25                            | 29X               | X26X X                    | 24 27 26 25                       | 27                    | 3 W                         |
|                      | <u>1 29 27</u><br>1 25 29 27    | ×<br>×            | <u>X26X X</u><br>26X X    | 24 27 26 25<br>28 27 26 25        | 31                    | <u>24</u><br>15             |
| ۴6                   | 1 25                            | ^                 | 26X X<br>26X X27X         | 28 27 26 25                       | 31                    | 6                           |
|                      | 1 25 31                         |                   | 26X X27X                  | 28 27 26 25                       |                       | 2 7                         |
|                      | <u>2 25 26 31</u><br>4 25 26    | 31X               | X X27X<br>X X27X          | <u>28 27 26 25</u><br>28 27 26 25 |                       | <u>1 8</u><br>9             |
| 10                   | 1 25                            | 31X               | X X27X                    | 28 <b>27 26 25</b>                |                       | 2 10                        |
|                      | 1<br>2 26                       | 31X<br>31X        | X X27X<br>X X27X          | 28 27 26 29<br>28 27 26 29        |                       | 1 1 2                       |
| 3 30                 | 4 26 31                         | X 21X             | X X27X<br>X X27X          | 28 27 26 29                       |                       | 2 3                         |
| 4                    | 1 26 31 27                      | <u>X</u>          | X X                       | 28 27 26 29                       |                       | 1 4                         |
| 5<br>6 31            |                                 | x                 | X X<br>X X                | 28 27 30 29<br>28 27 30 29        | 33<br>33              | 5<br>2 6                    |
| 7 31                 | 2 26                            |                   | X X                       | 28 27 30 29                       | 33                    | $\frac{1}{1}$ $\frac{1}{7}$ |
|                      | 4<br>1 27 33                    |                   | <u> </u>                  | 28 27 30 29                       | 33                    | 8                           |
|                      | 1 27 33                         | x                 | X X X                     | 28 27 30 29<br>28 31 30 29        |                       | 29<br>110                   |
| 1 32                 | 2 27                            | 33X               | X                         | 28 31 30 29                       |                       | 1                           |
|                      | <u>4 27</u><br>1 27             | <u>33X</u><br>33X | X                         | <u>28 31 30 29</u><br>28 31 30 29 |                       | <u>22</u><br>13             |
| 4                    | 1 27                            | 33X               | X                         | 28 31 30 29                       | 35                    | 4                           |
| 5                    | 1 33<br>1 28 23                 | X                 | X                         | 28 31 30 29                       | 35                    | 2 5                         |

# -30D-Figure 12 Listing of Simulator Print-Out

|                                        | 1 30                        |                             |                                                                                                                 | 32 31 30 29                       | 35                                                                                                             | 7                   |                   |
|----------------------------------------|-----------------------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------|---------------------|-------------------|
| 7 8 33                                 | 1 35                        |                             |                                                                                                                 | 32 31 30 29                       | 37                                                                                                             | 7<br><u>28W</u>     |                   |
| 9 33<br>10 33                          | 2 29 35                     | X<br>35X                    |                                                                                                                 | 32 31 30 29<br>32 31 30 29        |                                                                                                                | 1 9<br>10           |                   |
| 1 1                                    | 1 30                        | 35X                         | ala algori dependente en un del transportation agricaga e un star a construction e anno e e del adde accordente | 32 31 30 29                       | 447 FLP - 1744 - 111 - 147 - 174 - 174 - 174 - 174 - 174 - 174 - 174 - 174 - 174 - 174 - 174 - 174 - 174 - 174 | 2 1                 |                   |
| 2 34                                   | 1 30                        | <u>X 35X</u><br>35X         |                                                                                                                 | <u>32 31 30 33</u><br>32 31 30 33 |                                                                                                                | 1 2                 |                   |
| 4 34 4                                 | 4 31 55                     | X                           |                                                                                                                 | 32 31 30 33                       |                                                                                                                | 2 4                 |                   |
|                                        | 1 31 35<br>1 31             | ×                           |                                                                                                                 | 32 31 30 33<br>32 31 34 33        | 37                                                                                                             | 1 5 6               |                   |
|                                        | 1 31                        | <u></u>                     |                                                                                                                 | 32 31 34 33                       | 37                                                                                                             | 2 7                 |                   |
|                                        | 2 31 •                      |                             |                                                                                                                 | <u>32 31 34 33</u><br>32 31 34 33 | <u> </u>                                                                                                       | 1 8                 |                   |
|                                        | 1 31 37                     |                             |                                                                                                                 | 32 31 34 33                       |                                                                                                                | 2 10                |                   |
|                                        | 1 31 37<br>2 31             | 37X                         |                                                                                                                 | 32 35 34 33<br>32 35 34 33        |                                                                                                                | 1 1 2               |                   |
| 3 3,6                                  | 4 31                        | 37X                         | an 1988 an an 1998 finde agus a tha tha tha tha an 1984 an an 1897 an 1997 a tha an 1997 a tha tha tha tha tha  | 32 35 34 33                       |                                                                                                                | 2 3                 |                   |
|                                        | <u>1 31</u><br>1 31         | <u>37X</u><br>37X           |                                                                                                                 | <u>32 35 34 33</u><br>32 35 34 33 | 39                                                                                                             | <u>1 (4</u><br>5    |                   |
|                                        | 1 31                        | X                           |                                                                                                                 | 32 35 34 33                       | 39                                                                                                             | 2 6 W               |                   |
|                                        | 1 32 37                     | X X                         | ,                                                                                                               | 32 35 34 33                       | 39                                                                                                             | 1 7                 |                   |
| 8 9 37                                 | 1 33 39                     | X                           |                                                                                                                 | <u>36 35 34 33</u><br>36 35 34 33 | 39                                                                                                             | 2 9                 |                   |
| 10 37                                  | 2 33 39                     |                             |                                                                                                                 | 36 35 34 33                       |                                                                                                                | 1 10                |                   |
|                                        | 4.<br>1 34                  | 39X<br>39X                  |                                                                                                                 | 36 35 34 33<br>36 35 34 33        |                                                                                                                | 1<br>2 2            |                   |
| 3 38                                   | 1 34                        | 39X                         | anna a' marana a manada marana ay an da maga <u>manada marana</u> parta a aka a aka a marana a marana ang       | 36 35 34 37                       |                                                                                                                | 1 3                 |                   |
| 4 38                                   | 2 34 4 34 39                | 39X<br>X                    |                                                                                                                 | <u>36 35 34 37</u><br>36 35 34 37 |                                                                                                                | 2 5                 |                   |
| 6                                      | 1 34 39                     | X                           | a de gran per alembra de la compañía de la compañía de la defenda de la com alla de la de la compañía de la com | 36 35 34 37                       |                                                                                                                | 1 6                 |                   |
| 7<br>8 39                              | 1 34<br>1 34                | X                           |                                                                                                                 | 36 35 38 37<br>36 35 38 37        | 41                                                                                                             | 2 8                 |                   |
| 9 39                                   |                             |                             |                                                                                                                 | 36 35 38 37                       | 41                                                                                                             | 1 9                 |                   |
|                                        |                             |                             |                                                                                                                 |                                   |                                                                                                                |                     |                   |
|                                        | _                           |                             |                                                                                                                 |                                   |                                                                                                                |                     |                   |
| <u> </u>                               | 2<br>4 59 63                | X                           | <u> </u>                                                                                                        | 57 60 59 58<br>57 60 59 58        | 63                                                                                                             | <u>8</u><br>2 9     |                   |
| 10                                     | 1 63                        |                             | X                                                                                                               | 57 60 59 58                       |                                                                                                                | 1 10                |                   |
| 1 62 2 62                              |                             | X 63X<br>63X                | ×                                                                                                               | 61 60 59 58<br>61 60 59 58        |                                                                                                                | 2 2                 |                   |
| 3 62                                   | 2 61                        | 63X                         | X                                                                                                               | 61 60 59 58                       |                                                                                                                | 1 3 W               |                   |
| The second second second second second | 4 63                        | <u>63X</u>                  | <u> </u>                                                                                                        | 61 60 59 58<br>C 60 59 58         |                                                                                                                | <u>4 W</u><br>2 5 W |                   |
| 6                                      | 1 63                        | <u> </u>                    | X                                                                                                               | <u>61 60 59 62</u>                | 98                                                                                                             | 1 6                 |                   |
|                                        | 1<br>1 62 98                |                             | ×                                                                                                               | 61 60 59 62<br>61 60 59 62        | 98                                                                                                             | 7<br>28W            |                   |
| 9 63 2                                 | 2 98                        |                             | x                                                                                                               | 61 60 59 62                       |                                                                                                                | 1 9 W               |                   |
|                                        | 2.                          | <u> </u>                    | X                                                                                                               | <u>61 60 59 62</u><br>61 60 59 62 |                                                                                                                | 10 W<br>2 1 W       |                   |
| 1.63                                   | <u>i</u>                    | <u>98X</u>                  | <b>^</b>                                                                                                        | 61 60 59 62                       |                                                                                                                | 1 2 W               |                   |
| 3 64 1                                 |                             | X 98X<br>X                  |                                                                                                                 | 61 60 63 62<br>61 60 63 62        |                                                                                                                | 3<br>2 4            |                   |
| 5 64 2                                 | 2 63 98                     | X X                         |                                                                                                                 | 61,60 63 62                       |                                                                                                                | 1 5 W               |                   |
| 6 64 7 64                              | 2                           |                             |                                                                                                                 | 61 60 63 62<br>61 60 63 62        |                                                                                                                | 6 W<br>2 7 W        |                   |
| 8                                      | 1                           |                             |                                                                                                                 | 61 60 63 62                       |                                                                                                                | 1 8 W               |                   |
|                                        | 1                           | x                           |                                                                                                                 | 61 64 63 62<br>61 64 63 62        |                                                                                                                | 9<br>2 10           |                   |
| 1 98                                   | 4 64                        | · X                         |                                                                                                                 | 61 64 63 62                       |                                                                                                                | 1 1 W               |                   |
| 2 3                                    | 1                           |                             |                                                                                                                 | <u>61 64 63 62</u><br>98 64 63 62 |                                                                                                                | 2 W<br>2 3          |                   |
| 4                                      | 1                           | ,                           |                                                                                                                 | 98 64 63 62                       |                                                                                                                | 1 4                 |                   |
| 5                                      | 1 98                        |                             |                                                                                                                 | 98 64 63 62                       |                                                                                                                | 5                   |                   |
| PROJECT                                | 700C SIMULATOR              | -2 COCKE + KOLSKY M         | NOV 57                                                                                                          |                                   |                                                                                                                |                     |                   |
| LA FM M                                | M IR IS IA ID               | MB FB FD DT X1 X2           | MD F1 F2 F3 M1 M                                                                                                | M3 15 14 13 12 11 10              | 9876                                                                                                           | 5432                | 1 XM0             |
| 4 2 4                                  | 4 2 2 2 2                   | 2 2 2 2 1                   | 244681                                                                                                          | 20 50 18 20 18 12 8               | 6 4 2 1 1                                                                                                      | 0 5 4 2             | 1 :               |
|                                        | AU IAU ADLA<br>454 349 3310 | LAF WI WM DLA<br>535 28 266 | <b>187</b> 6                                                                                                    | 5 4 3 2<br>535 335 64             | 1 0<br>36 29                                                                                                   | 1BF IBM<br>144 76   | 08F 081<br>144 86 |
| IS 4                                   | 3 2 1                       | M12 M11 M10 M               |                                                                                                                 | 16 M5 M4 M3                       | M2 M1                                                                                                          | MMC FMC             | MBC FBC           |
| 141                                    | 9 250 590                   | 7                           | 132 276                                                                                                         | 276 180                           | 212 219                                                                                                        | 191 .               | 12 :              |
|                                        |                             |                             |                                                                                                                 |                                   |                                                                                                                |                     |                   |

# Figure 13

## Listing of Simulator Summary Print-Out

. .

. .

PROJECT 7000 SIMULATOR +2 COCKE + KOLSKY NOV 57

5

, **,** '

|           | LA FM      | 4 2            |                     | 2            | MB FB       | 2               | 2           | 82         | F1 F2 |                    | 17 20              | 15 14<br>50 27 | 20 30     | 17 8             |             | 7 6                | <u>5</u> 4<br>10 5 | - <del>3</del> - <del>2</del><br>4 - 2 | 1         | 291         |
|-----------|------------|----------------|---------------------|--------------|-------------|-----------------|-------------|------------|-------|--------------------|--------------------|----------------|-----------|------------------|-------------|--------------------|--------------------|----------------------------------------|-----------|-------------|
| 13.P      | 2296       | AU<br>6 3      | 250                 | ADLA<br>2929 | 439         | <u>WI</u><br>50 | 154         | LA 8       | /     |                    |                    | 439            | 241       | 179              | 89          | <del>0</del><br>50 | 1 4                |                                        | 1 4       | - ORM<br>62 |
|           | 15 4       | 3.             | 2                   | 1            | M12         | M11             | M10         | M9         | M8    | . M7               | -                  | .M5            | M4        | . 143            | M2          | M1                 | - MMC              | FMC                                    | MAC       | FRC         |
|           | 12         | 34             | 375                 | 486          |             |                 |             |            | 95    | 2                  | 2                  | 130            |           | -                | 154         | 159                | 82                 |                                        | 1         |             |
|           |            |                |                     |              |             |                 |             |            |       |                    |                    |                |           |                  |             |                    |                    |                                        |           |             |
|           |            |                |                     |              |             |                 |             |            |       |                    |                    | 0.4            |           |                  | 1           |                    |                    | •• •                                   |           |             |
|           |            |                | T                   | =1.0         |             |                 |             |            |       |                    |                    | Y              |           | r                | <b>P</b>    | . •                |                    |                                        |           |             |
|           | LA FM      |                | 15 14               |              | MB FB       |                 |             |            | F1 F2 | F3 M1              | M2 M3              | 15 14          | 13 12     | 11 10            | 9 8         | 7 6                | 5 4                | 3 2                                    | 1         |             |
| 70.5      | 4 2        | 4 2<br>AU      | 4 4<br>1 AU         | ADLA         | 2 2_<br>LAF | 2<br>W1         |             | 8 2        | -4-4  | <u>6.</u> 8<br>6   | <u>-17 20</u><br>5 | 50 27          | 20 30     | <u>U</u> 28      |             | 6 1                | 10 5<br>IRF        | 4 7<br>18M                             | 1         | 268<br>08M  |
| 9010      | TT<br>2362 | 586            | 289                 | 2784         | 4 2         | 70              | 160         | ALA: 0     | '     | 0                  | 2                  | . 4 2 .        | -         | -                |             | 70.                | -1-1-              | 54                                     | 11        | . 60        |
|           | 15 4       | 3              | 2                   | 1            | M12         | M11             | M10         | M9         | M8    | M7                 | M6                 | M5             | M4        | M3               | M2          | M1                 | MMC                | FMC                                    | MRC       | FBC         |
|           | 99         | 44             | 4 3                 | 452          |             |                 |             |            |       | 194                | 194                | 127:           |           |                  | 149         | 154                | 68                 |                                        | • 1       |             |
|           | LA FM      | MM             | -15 IA              | 10           | MB FB       | FD              |             | 12 MD      | F1 F2 | F3 M1              | M2 M3              | 15 14          | 13.12     | 11 10            | 9 8         | 7 6                | 5 4                | 32                                     | 1         |             |
| 15        | 4 2        | 4 2            |                     |              | 2-2         |                 |             | 8 2        |       |                    |                    | 50 (1          |           |                  |             | 6 1                | 10 5               | 4 2                                    | 1         | 453         |
| J         | TT         | AU             | IAU                 | ADLA         | LAF         | WI              |             | LA         |       |                    |                    | 4              | 3         | 2                | 1           | 0                  | IRF                | IRM                                    | OPF       | ORM         |
|           | 2076       | 143            | 328                 | 1833         | 163         | -239            | 414         |            |       |                    |                    | 163            | 191       | 29               | 187         | 248                | 115                | 61                                     | 115       | 69          |
|           | 15 4       | <u>3</u><br>38 | 482                 | . 1          | M12_        | M11             | M10         | M9         | M8    | <u>M7</u> _<br>221 | M6.<br>221         | M5<br>144      | M4        | M3               | . M2<br>170 | M1<br>176          | - MMC<br>91        | EWC                                    | MRC<br>2  | FRC<br>5    |
|           | 115        | 30             | 402                 | 505          |             |                 |             |            | 1 9   | 221                | /21                | 144            |           | <u> </u>         | 170         | 178                |                    |                                        | 2         | 7           |
|           | LA FM      |                | 15 1A               |              | MB FB       |                 |             |            |       |                    |                    | 15 14          |           |                  |             | 76                 | 54                 | 32                                     | 1         |             |
|           | , 4 2      |                |                     | . –          | 2 2         | 2               | 2           |            | 4 4   |                    |                    |                |           | 6 8              | _(3) 4.     |                    | 10 5               | - 4 2                                  | 1         | -433        |
| 80.2      | TT<br>2073 | AU<br>287      | 1 A U<br>3 2 9      | ADLA<br>1883 | LAF<br>172  | W!<br>198       | WM 1<br>311 | DLA 8      | 7     | 6                  | 5                  | 4              | 3<br>185  | 2 236            | 1<br>163    | 0                  | 18F                | 18M                                    | 085       | M90 -       |
|           | 15 4       |                | 2                   | 1005         | M12         | M11             | M10         | MQ         | MR    | M7                 | M6                 | -172<br>M5     | 105<br>M4 | 2.30<br>M3       | M2          | M1                 | MMC                | FMC                                    | MRC       | FRC         |
|           | 113        | 42_            |                     | 381          |             |                 |             |            | 1.6   | 221                | 221                | 144            |           |                  |             | -176               | 41                 |                                        | - 2       | - 5         |
|           |            |                |                     |              |             | -               |             | <b>VA</b>  |       |                    |                    |                |           |                  |             |                    |                    |                                        |           |             |
|           | LA FM      |                | <u>IS</u> IA<br>4 4 |              | MB FB       | 2               |             | 8 2        |       |                    |                    | 15.14          |           |                  |             | 7.6                | 10 5               | 3 2                                    | 1.        | 259         |
| 100       | TT         | ĀU             | TAU                 | ADLA         | LAF         | ŴI              |             |            | 7     | . 6.               | 5                  |                | 3         | U <sub>2</sub> ° | · · · · ·   |                    | - IRF-             | TRM                                    | ORF       | - ORM       |
|           | 2371       | 575            | 288                 | 2768         | 397         |                 | 169         |            |       |                    |                    | 397            | 226       | 196              | 1 5         | 73                 | 1 1                | 53                                     | 11        | 60          |
|           | 15 4       | 3              | 2                   | . 1          | M12_        | M11             | M10         | M9 -       |       | <u>M7</u>          | M6                 | -              | M4        | M3               | M2          | M1 .               | MMC                | FMC                                    | MAC       | FBC         |
|           | 99         | 37             | 4 7                 | 456          |             |                 |             |            | 92    | 194                | 194                | 126            |           |                  | 149         | 154                | 69                 |                                        | 1         |             |
|           | LA FM      | MM             | IS IA               | ID           | MB FB       | FD              | DT X1       | X2 MD      | F1 F2 | F3 M1              | M2 M3              | 15 1A          | 13 12     | 11 10            | 9 8         | 7 6                | 5.4                | 3 2                                    | 1         |             |
| ,3.       | 4 2        |                | 4 4                 | 2            | 2 2         | 2               | 2           | 8 2        | 4 4   | 68                 | 17_20              | 50 36          | 20 30     | (24) 8           | 12 4        | 6 - 1              | -10 5              | 4 2                                    | 1         | 235         |
|           | TT         | AU             |                     | ADLA         | LAF         | .W I            |             | DLA 8      | 7     | 6                  | 5                  | 4              |           |                  |             | 0                  | IBE                | IRM                                    | ORF       | OPM         |
|           | 2647       | 660            | 258                 | 3020<br>1    | 5 6<br>M12  | 49<br>M11       | 125<br>M10  | M9         | MB    | M7                 | M6                 |                | M4        | . 170.<br>M3     | 83<br>M2    | -49<br>M1          | 90<br>MMC          | 48<br>FMC                              | 90<br>MBC | 54<br>FRC   |
|           | 89         | ź4             | 366                 | 519          | 112         |                 | M10         | 14.2       |       | 173                | -                  |                |           |                  | -133.       |                    | 64                 | r mc                                   | · 1       |             |
|           |            |                |                     |              |             |                 |             |            |       |                    |                    |                | _         |                  |             |                    | _                  |                                        | -         |             |
| _,4       | LA FM      |                | 15 14               |              | MB FB       |                 |             |            |       |                    |                    |                |           |                  | 9 8         | 76                 |                    | . 3 2                                  | 1         |             |
| <u>ځې</u> | -42<br>TT  | 4 2<br>AU      |                     | ADLA         | 2- 2<br>LAF | 2<br>W I        |             | 82<br>DLA8 | 4 4   | 68                 | 17 ZO              | 50 45          | 20 30     | 60,8             | 15 4        | 6 1                | 10 5               | 4 2<br>IBM                             | 1<br>08F  | 216<br>ORM  |
|           | 2998       | 711            | 227                 | 3147         | 566         | 47              | 95          | ULN O      |       |                    |                    | 566            | 178       | 140              | 67          | 47                 | 80                 | 42                                     | 80        | 48          |
|           | 15 4       | 3              | 2                   | 1            | M12         | M11             | MIO         | M9         | M8    | M7                 | M6                 | M5             | M4        | M3               | M2          | _ M1               | MMC.               | FMC                                    | MRC       | FRC         |
|           | 78         | 45             | 310                 | 565          |             |                 |             |            | 73    | 153                | 153                | 1              |           | -                | 118         | 122                | 52                 |                                        | 1         |             |

-31-

The detailed timing charts for most problems would be about 50 feet long for each run. Since over a 1000 cases have been run, it is clear that only a few cases could be printed in full detail. Nevertheless, the detailed timing charts were essential for two reasons: (1) Debugging the program with all its hundreds of conditional branches would have been a staggering task without the detailed listings, and (2) determining the causes of some of the anamolous summary results required that one examine the listings in detail. Also the authors found that studying the listings enabled them to get a "feel" for the flow of information which was necessary to locate bottlenecks in the processing speed.

#### B. Test Problems Used.

1

Five of the test problems used most frequently are described below. Other test problems were used for specific studies but since the results were similar for all problems of a given type, we gradually discontinued using them. The following were originally selected as being typical of different classes of problems. A brief description of each is repeated here for completeness.

- Mesh Problem Part of an hydrodynamics problem from Los Alamos. It contains a more or less "average" mixture of instructions for scientific problems: 85% Floating Point instructions, 14% index modification instructions, and 1% VFL. It is usually arithmetic unit limited.
- Monte Carlo Branching Problem Part of an actual Monte Carlo neutron diffusion code. It represents a chain of logical decisions with very little arithmetic in between. It contains 47% Floating Point, 15% index modification instructions, and 36% branches of the indicator and unconditional types. It is largely instruction-access limited.
- 3. <u>Reactor Problem</u> The inner loop of a neutron diffusion problem from Westinghouse. It consists of 90% Floating Point arithmetic (39% of which are multiplys) and 10% index modification instructions. It is almost entirely arithmetic unit limited.

- 4. Computer Test Problem The evaluation of a polynominal using computed indices. It was prepared by I. Ziller to compare various computers. It has 71% Floating Point, 10% index modification, 6% VFL and 13% indicator branches. It is usually arithmetic unit limited but not for all configurations.
- 5. Simultaneous Equations The inner loop of a matrix inversion routine 67% Floating Point and 33% index modification. Arithmetic and logic are about equally important. It is limited both by arithmetic and instruction-access speeds.

#### C. Results of Simple Parameter Studies

1. General

When the Simulator Program was first completed in late 1957, we undertook a series of studies in which the main parameters describing the STRETCH system were varied one or two at a time in order to get a measure for the importance of different effects. During this phase we spent much time studying the detailed print outs described above to determine the exact cause of some of the anomolous effects.

After this we began to specialize the studies towards answering specific questions in the STRETCH design and made more use of the Summary listings. Two of these studies are described in the following sections. In the present section the major part of the material is taken from the first parameter studies. The graphs reproduced below are in terms of an arbitrary speed scale in which one of the first problems studied (The Mesh Calc.) was taken as 100.

The table below summarizes the major effects studied. The individual items are discussed in the following subsections.

| Description                         | Mesh   | Calc.    | Мо    | nte Carlo |
|-------------------------------------|--------|----------|-------|-----------|
|                                     | Speed  | % Change | Speed | % Change  |
| 1. Standard Design                  | 100    | 0        | 45.   | 0         |
| 2. A.U. Times Doubled               | 73     | -27%     | 43.   | - 4%      |
| 3. I.A.U. Times Doubled             | 67.    | -33%     | 26    | -42%      |
| 4. Both AU and IAU doubled          | 60.    | -40%     | 24.   | -46.%     |
| 5. 2.0 us Instr. Memory             | 98.    | - 2%     | 35.   | -22%      |
| 6. Combining Instr. and Data in 4 M | AM 82. | -16%     | 32    | -29%      |
| 7. Combining Instr. and Data in 6 M | AM 86. | -14%     | 33    | -27.%     |
| 8. 2 Levels of Virtual Memory       | 89.    | -11%     | 38    | -15.%     |
| 9. 6 Levels of Virtual Memory       | 106.   | + 6%     | 46.   | + 3.%     |

#### Examples of STRETCH Timing Simulator Results

2. Standard Values of Parameters

The combination of constants which was taken as the standard reference values for the original parameter studies is as follows:

| a. | Machi | ne Components:                 |           |
|----|-------|--------------------------------|-----------|
|    | 1.    | Levels of Virtual Memory       | 4         |
|    | 2.    | Number of Instruction Memories | 2         |
|    | 3.    | Number of Main (data) Memories | 4         |
| b. | Compu | iter Speeds:                   |           |
|    | 1.    | Indexing Time*                 | 0.6 usec  |
|    | 2.    | Arithmetic Unit Times          |           |
|    |       | Floating Add                   | 0.6 usec  |
|    |       | Floating Multiply              | 1.2 usec  |
|    |       | Floating Divide                | 1.8 usec  |
|    |       | Fetch                          | 0.2 usec  |
|    | •     | usual 6-6-3-1 average          | 0.64 usec |

\*This is total time to index one order, includes instruction decoding, index fetch, index addition, and storing modified address.

c. Memory Speeds:

1.

| Fast (Instr.) Memory Times |          |
|----------------------------|----------|
| Read out time              | 0.4 usec |
| End Signal Time            | 0.4 usec |
| Memory cycle time*         | 0.6 usec |

\*(The actual effective cycle time is 0.9 usec, since the bus clocking permitted successive references to the same memory box only in multiples of 0.3 usec and the memory box must be free at the time of the reference not just finishing.)

| 2. | Main (Data) Memory Times |          |
|----|--------------------------|----------|
|    | Read out time            | 0.8 usec |
|    | End Signal Time          | 1.7 usec |
|    | Memory cycle time*       | 2.0 usec |

\*(The effective cycle is 2.1 us for same reason as above).

| 3. | Index Core Memory Times |          |
|----|-------------------------|----------|
|    | Read out time           | 0.4 usec |
|    | Memory cycle time       | 0.8 usec |

The index cores are assumed tied directly to the IAU, so these figures include bus times.

#### 4. Bus Speeds

- a. Buses to and from Instruction and Data memories 0.2 usec slot (either read or write) available every 0.3 usec.
- b. Decode and switching time in central control unit 0.2 usec to 0.4 usec (depending on bus slots available.)

Note: A separate bus system to instruction and Data memories is assumed, but not necessary.

In addition there is usually a 0.1 usec delay between the completion of any function and the beginning of the next one by the unit, or in the transfer from one register to another.

#### 3. Speed vs Number of Levels of Virtual Memory

Figure 14 shows the effect on computer performance of varying the number of levels of Virtual Memory. Curves for the Monte Carlo and Mesh Calculations with two sets of arithmetic and indexing arithmetic speeds are shown. The AU times given are the 6-6-3-1 averages mentioned above.

A number of interesting results are apparent from these curves:

- (1) There is a tremendous gain to be had in going to the Vitual Memory organization. The point for "0 levels" means that the arithmetic unit is tied directly to the instruction preparation unit, although simple Indexing-Execution overlap is still possible.
- (2) The gain in performance goes up very rapidly for the first two levels then rises more slowly for the rest of the range.
- (3) A large number of levels does the Monte Carlo problem less good than the Mesh problem because constant branching in the former spoils the flow of instructions. Notice that the curve for the Monte Carlo problem actually decreases slightly beyond six levels. This phenomenom is a result of memory conflicts caused by extraneous memory references started by the computer running ahead on the wrong-way paths of branches.
- (4) The computer performance on a given problem is clearly less for slower arithmetic speeds. However, it is important to note that the sensitivity of the performance is also less for slower arithmetic speeds. The Virtual Memory improves the performance in either case, but it is not a substitute for a fast arithmetic unit.



#### 4. Speed vs Number of Main Memory Units

Figure 15 shows how internal computer performance varies with the total number of memory units for a particular problem. The entire calculation is assumed to be contained in memory for all cases. The speed gain from overlapping memories is quite apparent from the graphs.

The speed differential between having and not having instructions separated from data arises from delays in instruction fetches caused by the memory units being busy with data. The size of this effect varies from problem to problem, being less pronounced for problems which are arithmetic limited and more for logical problems.

Since memory units for STRETCH are attachable only in pairs after the first and are interlaced only in powers of two, some of the points on the graph do not represent physically attainable combinations, e.g., 5 memories all interlaced. (The simulation program has no such restrictions.)

The "X's" on the graph show the effect of replacing the 0.6 usec instruction memories by a pair of 2.0 usec memories. The resulting performance change is small for the Mesh Problem, which is arithmetic limited, but large for the instruction-fetch limited Monte Carlo problem.

#### 5. Speed vs Arithmetic Unit and Indexing Arithmetic Unit Times

Although everyone realizes the importance of arithmetic speed on overall computer performance, it was not until the Simulator results became available that the true importance of the indexing arithmetic speeds was recognized. Figures 16 and 17 show a two parameter family of curves giving the computer speed as a function of the AU and IAU times.

Figure 17 in which the arithmetic time is the abscissa shows an interesting "saturation" effect where the computer performance is independent of AU speed below some critical value. Thus it makes no sense to strain AU speeds if the IAU is not improved to match. The curves in Figure 16 show the same effect i.e., the IAU speed serves as a "ceiling" on performance beyond which the AU speed cannot pass.

SIGMA COMPUTER SPEED

vs. Number of Main

Memory Boxes

4 levels LA

0.6 µs IAU time

0.64 µs AU time



-38-





The Monte Carlo problem is much less sensitive to arithmetic speed than is the Mesh problem. Their roles are reversed for the indexing arithmetic speed since the indexing arithmetic unit controls the rate of instruction preparation and the Monte Carlo problem is instruction-access limited.

#### 6. Speed vs Instruction Memory Speed and Instruction Buffering

Figure 18 shows the effect on overall performance of the instruction memory cycle time. The most striking result shown is the reduction in speed of the Mesh Problem with the removal of the indexing arithmetic unit instruction buffer.

Not only as the speed of the problem cut almost by a factor of two, but it clearly assumes the behavior of an instruction-access-limited problem instead of a compute-limited problem. This instruction buffer (called  $Y_2$  in STRETCH) really serves as a 2 level Virtual Memory for the indexing arithmetic unit and gives many of the same advantages to instruction preparation which the regular Virtual Memory does to data preparation.

For more detail concerning instruction memory speed see the section on the Half microsecond memory below.

#### 7. Arithmetic Unit Efficiency

One fallacy which is frequently quoted is that the goal of improved computer organization is to increase the arithmetic unit efficiency. Actually there are two reasons why this is not the goal in itself. The first is that arithmetic efficiency depends strongly on the mixture of arithmetic and logic in a given problem so that a general purpose computer cannot hope to give equally high percentage utility to all.

The second reason is apparent in Figure 19 which shows that the best way to increase the arithmetic unit efficiency is to slow down the arithmetic unit!

The real goal of improved organization is maximum overall computer performance for minimum cost. One will tend to increase the arithmetic unit speed as long as its percent efficiency is reasonable for a variety of problems. One will stop this process when the overall performance gain no longer matches the increase in hardware and complexity. Thus the arithmetic unit efficiency is a by-product of this design process not the prime variable.



-42-

Figure 18

SIGMA ARITHMETIC UNIT EFFICIENCY



(EXECUTION TIME FOR "AVERAGE" FLOATING OPERATION)

#### 8. Speed vs Concurrent Input-Output Activity

Because of the relative time scales of I/O activity and the CPU processing speeds the Simulator cannot take in account the availability or non-availability of data from I/O on the program being run. However, we can observe the effect on the computation of the I/O devices operating at different rates simultaneously with computing.

Using the STRETCH control word philosophy it is possible to have a number of input-output units operating at the same time the Central Processing Unit is running. The Basic Exchange can reach a peak rate of 1 word every 10 microseconds. The high speed disk normally operates at 1 word every 4 microseconds. Since the mechanical devices take priority over the CPU in addressing memory, the computation slows down because of memorybusy conflicts.

Figure 20 shows an example of how internal computing speed is slowed as the I/O word rates are varied continuously. At the theoretical "choke off" the I/O devices take all the memory cycles available and stop the calculation. Notice that this condition can never arise for any I/O rates presently attainable.

#### 9. Speed vs Number of Memory Units with and without High Speed Disk Running

Because there are fewer memory cycles available when there are fewer memory units, the High Speed disk unit will cause a larger percentage slow-down for a smaller STRETCH system. Figures 21 and 22 show this effect for two typical problems--one which is normally arithmetic limited and one which is instructionfetch limited. The former is less sensitive to such interference mainly because the Virtual Memory has more of an averaging effect on its data memory references.

The following table shows the approximate quantitative reduction in internal computing speed caused by the disk running at the same time, using the speed without I/O as 100% for each configuration.

| Number of Memories | For Monte Carlo Problem | For Reactor Problem |
|--------------------|-------------------------|---------------------|
| 6                  | - 5%                    | - 2%                |
| 4                  | -15%                    | - 4%                |
| 2                  | -24%                    | -22%                |
| 1                  | -55%                    | -55%                |

SIGMA INTERNAL COMPUTING SPEED Percentage Reduction in Speed caused by Input-Output devices referencing memory at different rates while the calculation is proceeding.







-46-





The user of a small STRETCH system is thus penalized three times compared to a large system user: (1) The top speed of his system is reduced by the loss of memory overlap, (2) He has a larger I/O penalty when it is run concurrently with the computation, and (3) the smaller amount of data which he can hold in the memory at one time increases the amount of I/O activity he needs to do the job.

Looking at it more positively, the user who in the past purchased larger memories for his 704 obtained only the benefits of the third effect, while a STRETCH user also gets a "bonus" of the first two as he expands his system.

## D. The Effect of the Half-Microsecond Instruction Memory on STRETCH Performance

1. Introduction:

During July and August of 1958 a series of Timing Simulator runs were made to evaluate the status of the SIGMA and HARVEST computers. One parameter studied was the speed of the instruction memory. Several runs were also made in which there was no separate instruction memory but instructions and data were stored in the same boxes.

The results of these runs proved to be quite important in evaluating the importance of the half-microsecond memory to the STRETCH program. The following analysis is taken from Project 7000 File Memo which was published at that time.

2. Advantages and Disadvantages of the Half-Microsecond Memory:

A. The primary advantage of the half-microsecond memory is, of course, its speed. This speed is beneficial in the following two cases:

- Programs can be instruction access limited either because they consist of a series of short operations, or because they contain many branch orders. If the halfmicrosecond memory is used for instructions it will help reduce the limitation by furnishing the instructions at a faster rate.
- (2) In programs which are <u>data-access limited</u>, putting the data in the faster memory will cut down the time required for fetching the data. VFL operations with short fields are in this category. These are of particular importance for HARVEST applications.

In both of the above cases it is the speed of the memory compared to the arithmetic speed which is the important ratio--the faster the arithmetic speed the faster the memory required to service it properly.

B. The main disadvantage of the half-microsecond memory is its size. Each memory box contains only one-sixteenth as many words as a comparable two microsecond memory box. This decreased size certainly must result in reduced performance because more time will be spent reallocating programs. Unfortunately this reduction cannot be evaluated quantitatively by simulation since it depends on the nature of the future problems, and on the nature of future methods of scheduling machine use.

There is another advantage in larger memories which is even harder to evaluate and that is the removal of programming restrictions which exist when programs must be cut to fit a small memory.

#### 3. Simulator Input Data:

The test problems were run with most of the recent design changes simulated, including the 0.8 microsecond I-Box repetition rate and the 0.2 microsecond bus slots. The arithmetic speeds used for the runs were:

|                   | STANDARD | SIGMA  | HARVEST |
|-------------------|----------|--------|---------|
| Load, Store       | 0.2 us   | 0.4 us | 0.4 us  |
| Floating Add      | 0.6      | 1.0    | 1.0     |
| Floating Multiply | 1.2      | 2.5    | 7.5     |
| Floating Divide   | 1.8      | 7.0    | 7.5     |
| 6-6-3-1 average   | 0.64     | 1.43   | 2.40    |

The average times listed on the last line are used for convenience of plotting only. These arithmetic speeds are not intended to represent present STRETCH values.

4. Results:

Results of some of the runs are given in Table V. A short summary of the pertinant results are given in Table VI.

Straight averages of the percentage losses do not tell the whole story. There are abrupt changes in behavior for some of the problems from one case to another. Upon examination, the reason in each case was due to the problem becoming instructionaccess limited where it had previously been arithmetic limited. Each problem crosses over under different circumstances because of its own particular combination of instructions.

Table VI also lists the programs which seem to be instruction-access limited for each memory and arithmetic speed configuration.

The phenomena which has been observed so many times before, still holds here --- the higher the machines overall performance, the more sensitive it becomes to each individual component's performance. Thus, all of the problems are prone to become instruction-access limited at STANDARD speeds, where only the faithful Monte Carlo code is limited at HARVEST speeds.

The magnitude of the losses must be considered as well as the pattern. Clearly the memory interferences caused by not having a separate instruction memory is as large or larger than the speed of the memory. The average percentages are given in table VII.

Rough Estimate of the Effect of Having a Larger Instruction 5. Memory on Computer Speed:

As was mentioned in section 1, the favorable speed advantage gained by having a larger instruction memory is hard to assess quantitatively. The following is intended to be a rough order-of-magnitude estimate only.

In a given time T, assumed to be long enough to do several problems, the computer will divide its activities between the time spent on useful calculation and the time spent on swapping codes in and out of instruction memory. We may write

 $T = n t_{c} + n R_{tc} = ntc (1 + R)$ 

where n = the number of useful instructions executed

R - the ratio of the number of words swapped per useful instruction executed. (R should be much less than 1)  $t_c$  = average time per calculation executed.

(For simplicity the time for swapping an instruction is taken the same as  $t_c$ .)

The speed of the computer, S, is proportional to n/T, the number of useful operations per unit time. So we may write the ratios of the speeds of two systems as:

$$\frac{S_2}{S_1} = \frac{n_2}{n_1} = \frac{tcl (1 + R_1)}{tc2 (1 + R_2)}$$

The  $tc_1/tc_2$  factor is the regular speed-up caused by the faster memory. The term involving the R's is the new factor resulting from the effect of swapping codes. As a guess, we can take R as being inversely proportional to the memory size, so that

$$R_1 = R_2 - \frac{N_2}{N_1}$$

also since the R's are both much less than 1, we may write

$$\frac{S_2}{S_1} = \frac{tc_1}{tc_2} \times (1 + R_2 \frac{N_2}{N_1} - R_2)$$

In the present case, consider a 10% computer speed differential on tc's between the half and two-microsecond memories, which differ in size by a 1 to 16 ratio. We can ask what value of  $R_2$  will be necessary to make the half microsecond memory result in an increase in speed over the two microsecond memory. The answer is approximately:

$$R_2 \leq 0.1$$

ł

That is, each instruction in the half microsecond memory must be used at least 10 times in an average program before it is replaced in order that the half microsecond memory show a net increase in speed over the larger, slower 2 us memory.

Very roughly speaking, each instruction must be used at least once for each percent loss in speed under the configurations tested here to break even. It seems likely that this condition will be easily satisfied in practice, so that the faster memory will indeed result in a faster computer even though part of its advantage is lost. The other factor mentioned which favors larger memories is the effect of being able to write less complicated codes when they need not be cut to size. One can express this factor as a (1 + f) term times the speed of the computer to gives its effective speed. This speed gain is because the machine has to do a fraction f fewer instructions to accomplish the same job with a larger memory as it would take with the smaller. Since this fraction is so strongly a function of the problem involved, one can only guess what it will be as an average for all SIGMA problems. It should be in the 0 to 10% range, however.

- 6. Conclusions:
  - (a) Whether a problem is instruction-access limited or not is the main property which determines its behavior under changes in instruction memory.
  - (b) The property of being instruction-access limited depends considerably on the individual sequence of instructions in a problem itself, and on the relative speeds of the arithmetic unit and the instruction memory.
  - (c) The higher the performance of the computer, the more sensitive is its speed to changes in instruction memory configuration. At the SIGMA speeds, replacing the two 0.6 us memory boxes by two 2.0 us memories results in an average of 2.5% loss in performance in the cases tested.
  - (d) At SIGMA speeds, intermixing data and instructions causes an average loss of 3.9% in performance over having a separate 2.0 us instruction memory. This is because conflicts between data and instructions delay instruction accesses. Note that this is larger than the effect of memory speed itself.
  - (e) The speed gains from having a faster memory are reduced somewhat by the fact that it is smaller and more time must be spent swapping codes. This seems to be a small effect timewise, however.

The effective performance increase possible because bigger programs may be put into the larger memory at once is hard to assess. It is probably also in the 1 to 10% area.

TABLE Y

Computer Performance as functions of Memory Configurations and Arithmetic Unit Speeds.

| OF TEST PROBLEMS        |   | -        |
|-------------------------|---|----------|
| (times                  |   | 4 Speeds |
| OF TEST PROBLEMS (times |   | 0        |
| OF TEST                 |   |          |
| OF TEST                 | ł | ŝ        |
| OF TEST                 |   | Σ        |
| OF TEST                 | İ |          |
| OF TEST                 | 2 | 3        |
| OF TEST                 | 2 | 5        |
| OF TEST                 |   | T<br>T   |
| SPEED OF                |   | I FUI    |
| SPEED O                 | ſ | -        |
| SPEED                   | ( | Ċ        |
|                         |   | ったちたい    |

tergete respiration come retrain and and

'n

|                            |                                                                                                                                                |        |                                              |                        |              |                                 | 4                                                                                                               |       | '                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------|------------------------|--------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| Configuration              | Mesh                                                                                                                                           | sh     | Monte Carlo                                  | rlo                    | Reactor      | H                               | Computer<br>Test                                                                                                | er    | Simultaneous<br>Fanations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | aneous |
| Instruction Memories Speed | Speed                                                                                                                                          | %      | Speed                                        | %                      | Speed        | ₽2                              | Speed                                                                                                           | %     | Speed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | %      |
| STANDARD                   |                                                                                                                                                |        |                                              |                        |              |                                 |                                                                                                                 |       | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |
|                            | 8.5.9                                                                                                                                          | 0      | 45.5                                         | 0                      | 122.4        | 0                               | 89.5                                                                                                            | 0     | 48.7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0      |
| 2. 2 2.0 us Mems.          | 82.9                                                                                                                                           | - 3, 5 | 41.2                                         | -9.5                   | 121.3        | -0.9                            | 87.6                                                                                                            | -2.1  | 47.5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | -2.5   |
| 3. No. Instr. Mem.         | 747                                                                                                                                            | -13, 1 | 36.3                                         | -20.2                  | 97.5         | -20.3                           | 73. 2                                                                                                           | -18.3 | 45.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | -7.4   |
| SIGMA                      | a ayasındı kalamında yak kan<br>Marina yakında |        |                                              | ung gale i ur faighter |              | e anti-las - a caracterizati il | a tradition of the second s |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |
|                            | 59. 2                                                                                                                                          | 0      | 41.9                                         | 0                      | 75.9         | 0                               | <b>58.</b> I                                                                                                    | 0     | 45.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0      |
| 2. 2 2.0 us Mems.          | 59.0                                                                                                                                           | -0.4   | 38.2                                         | 8.<br>8.               | 75.7         | -0.3                            | 57.9                                                                                                            | -0.4  | 43.8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | -2.8   |
| 3. No. Instr. Mem.         | 55.2                                                                                                                                           | -6, 8  | 35.4                                         | -15.4                  | 75.6         | -0.4                            | 55.0                                                                                                            | -5.3  | 43.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | -4.2   |
| HARVEST                    |                                                                                                                                                |        | n and go |                        |              |                                 |                                                                                                                 |       | 1997 - 1997 - 1997 - 1996 - 1996 - 1996 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 19 |        |
| 1. 2 0.6 us Mems.          | 39.3                                                                                                                                           | 0      |                                              | 0                      | 38.0         | 0                               | 40.8                                                                                                            | 0     | 31.7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0      |
| 2. 2 2.2 us Mems.          | 39.2                                                                                                                                           | -0.2   | 35.6                                         | -8.2                   | 37.9         | -0.1                            | 40.7                                                                                                            | -0.3  | 31.6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | -0.4   |
| 3. No. Instr. Mem.         | 37.5                                                                                                                                           | -4.6   | 33.8                                         | -12.9                  | 37.9         | -0.2                            | 40.7                                                                                                            | -0.3  | 31.3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | -1.2   |
|                            |                                                                                                                                                |        |                                              |                        | €.dg=g_=d ¥X |                                 | erikato y ket fel e <b>nge</b>                                                                                  |       | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |

Each has 4 0.6 microsecond total cycle instruction memory 2.0 microsecond total cycle data memories

#### TABLE VI

. .

Summary of Results: Average Computer speed changes caused by Instruction memory speeds and Arithmetic Speeds, straight averages for all five test problems.

| ST | ANDARD AU Speeds                                | Average Percent Decrea |     | ms*wh<br>acces        |     |            |
|----|-------------------------------------------------|------------------------|-----|-----------------------|-----|------------|
| 2. | 21/2us Mems.<br>22us Mems<br>No. Instr. Mem.    | 0<br>-3.7%<br>-15.9%   | (1) | (2)<br>(2)<br>(2) (3) | • • | (5)<br>(5) |
|    | MA AU Speeds                                    |                        |     |                       |     |            |
| 2. | 2 1/2 us mems<br>2 2 us Mems<br>No. Instr. Mem. | 0<br>-2.5%<br>~6.4%    | (1) | (2)<br>(2)<br>(2)     | (4) | (5)<br>(5) |
| HA | RVEST AU Speeds                                 |                        |     |                       |     |            |
|    | 21/2 us Mems.<br>22 us Mems.<br>No. Instr. Mem. | 0<br>-1.8%<br>-3.8%    | (1) | (2)<br>(2)<br>(2)     |     |            |

\*The Problem numbers are those given in Section VB.

## TABLE VII

Average Percentage Losses for all problems.

|                                                                                 | _ <u>A</u> | rithmetic Speeds |         |
|---------------------------------------------------------------------------------|------------|------------------|---------|
| •                                                                               | STANDARD   | SIGMA            | HARVEST |
| Ave loss caused by<br>replacing 0.6 us Instr.<br>Memory by 2.0 us Mem-<br>ory.  | -3、7%      | - 2.5%           | -1.8%   |
| Average additional loss<br>caused by having no sep-<br>arate Instr. Memory.     | -12,2%     | -39%             | - 2, 0% |
| Maximum loss caused<br>by replacing 0.6 us<br>Instr. Memory by 2.0<br>us Memory | -9.5%      | -8 - 8/%         | -8.2%   |
| Max. additional loss<br>caused by having no<br>separate Instr. Mem-<br>ory.     | -19.5%     | -6.6%            | -4.7%   |

#### E. A Study of Branching on Arithmetic Results in STRETCH

#### 1. Introduction:

The asynchronous organization of STRETCH allows many of the components of the Computer System to be operating at the same time on different jobs and thus by overlapping greatly increases the overall efficiency of the system.

Unfortunately this organization also has its drawbacks. In particular, one of the curses of the non-sequential preparation and execution of instructions is that if there is a Branch in the problem code it spoils the smooth flow of instructions to the Indexing Arithmetic Unit. Any branch in a program will cause some delay, but the ones which hurt the most are the branches on arithmetic results which cannot be detected by the Indexing Arithmetic Unit in advance.

2. Ways in Which Arithmetic Result Branches can be Handled:

There are two fundamental ways in which branches on Arithmetic Unit results can be handled by the computer:

- (1) The computer can stop the flow of instructions until the Arithmetic Unit has completed the preceeding operation so that the result is known, then fetch the next correct instruction. This places a delay on every AU result Branch whether taken or not.
- (2) The computer can "guess" which way the branch is going to go before it is taken and proceed with fetching and preparing the instructions along one path with the understanding that if the guess was wrong, these instructions must be discarded and the correct path taken instead.

Under the second alternative there are four possible ways in which the guessing can be made. The branches in question are indicator branches on the Arithmetic Unit result indicators. These operations have a modifier which allows the branch to be taken either if the specified indicator is on or off. Since one can guess that the indicator is on or off for each, the four combinations are:

| Case | Name  | Operation            | Guess          | Assumed Result of Operation |
|------|-------|----------------------|----------------|-----------------------------|
| I    | NN-FF | Ind Branch on<br>off | Ind on<br>off  | branch<br>branch            |
| ш    | NF-FN | Ind Branch on<br>off | Ind off<br>on  | no branch<br>no branch      |
| III  | NN-FN | Ind Branch on<br>off | Ind on<br>on   | branch<br>no branch         |
| IV   | NF-FF | Ind Branch on<br>off | Ind off<br>off | no branch<br>branch         |

3. Simulation Results:

-2

To study the effects of wrong-way branches on the SIGMA Timing Simulator, the Monte Carlo Branching Code was chosen as the guinea pig. The code was rewritten so that every arithmetic result branch was a wrong guess and again so that every one was guessed correctly. (Note that neither of these extremes is actually possible in a program with branches unless they are essentially unconditional.)

Several runs were made varying the instruction memory speed and the AU and IAU times. The regular (NF-FN) case had two wrong branches out of thirteen encountered in one loop of the program which consists of fifty-nine operations executed per loop.

By examining the timing charts drawn by the Simulator for many of the individual branches, the average time delays listed in Table VIII were derived.

| assumed   | Guessed    | For 0.6 us Instr. Mem.   | For 2.0 us Instr. Mem. |
|-----------|------------|--------------------------|------------------------|
| no branch | right      | 0 us                     | 0 us                   |
| no branch | wrong      | 2.5 us                   | 3.2 us                 |
| branch    | right      | 1.5 us                   | 3.2 us                 |
| branch    | wrong      | 3.7 us                   | 4.8 us                 |
| For       | "Standard" | Times (AU = 0.64 us, IAU | = 0.6 us)              |

Table VIII: Average Time Delay per Individual Branch

If one takes the actual times to complete the problem in each case and divides the total delay by the number of wrongway branches, one obtains the times listed in Table IX. The approximate delay due to the memory interferences, etc., caused by starting the processing of the wrong instructions, can be estimated by comparing the times in Table VIII with those in Table IX. These interference times are listed in Table IX.

#### Table IX. Average Time Delay in Total Problem per Wrong-way Branch

| For "Standard Times" (AU=0.64 us, IAU=0.6 us)   | 0.6us Instr.<br>memory.<br>2.9 us | 0.2 Instr<br>memory:<br>3.5 us |
|-------------------------------------------------|-----------------------------------|--------------------------------|
| For "Recommended Times" (AU-1.09 us, IAU=0.9 us | s 3.6 us                          | 4.3 us                         |
| Extra Delay due to memory Interferences         | 0.5 us                            | 1.0 us                         |

Presumably if one holds up on every branch (Case O) the time loss will be about that of assuming no Branch and guessing wrong. (line 2 in Table VIII). If one guesses according to one of the four other cases, the time loss will depend on (1) the percentage of branches which are Br-ons, (2) the percentage of Br-ons which are actually taken, and (3) the percentage of Br-offs which are actually taken.

The calculation will be delayed by each branch taken even when they are guessed correctly, however, since we are interested in examining the additional time lost due to guessing wrong or holding up, the delays due to correct branching should be removed. The following times in Table X may be used to compute actual combinations of branches.

Table X: Average Time Delay per Branch

| Computer<br>Guessed | Should Have<br>Guessed | 0.6 us Instr.<br>Memory | 2.0 us Instr.<br>Memory |
|---------------------|------------------------|-------------------------|-------------------------|
| Hold up             | no branch              | 2. 2 us                 | 1.6 us                  |
| Hold up             | branch                 | 2.5 us                  | 3. 2 us                 |
| no branch           | no branch              | 0 us                    | 0 us                    |
| no branch           | branch                 | 3.0 us                  | 4. 2 us                 |
| Branch              | branch                 | 0 us                    | 0 us                    |
| Branch              | no branch              | 2.7 us                  | 2.6 us                  |

The temptation in evaluating the individual cases is to assume 50% for all the combinations and essentially average the time losses. Actually, by examining a few problems superficially, we have found that considerably fewer than half the arithmetic result branches encountered in a code are actually taken. About 20% seem to be more typical. This seems to be due to the tendency of coders to think of the branches as being exceptional cases. They normally write the main flow of the code continuously and the exceptions elsewhere.

There seems to be a tendency to link indicators turning on with exception cases. In time this would result in fewer Brons being taken and more Br-offs being taken. These generalizations are admittedly uncertain mainly because very few relevant statistics are available.

There is also a "feedback" in such statistics because the way in which the machine guesses the branches will influence future programmers to write their codes to take advantage of the speed gain, so that the statistics of the future will be biased in favor of the system chosen now!

Table XI compares the five cases for several assumed values of percentages. The last two lines are my guesses as to the averages to be expected.

Table XI: Average Time Delays per Branch for the Different Cases

| %      | %         | %        |          |         |         |          |         |
|--------|-----------|----------|----------|---------|---------|----------|---------|
| Br-ons | Br-ons    | Br-offs  | Case 0   | Case I  | Case II | Case III | Case IV |
|        | taken     | taken    | Hold-up  | NN-FF   | NF-FN   | NN-FN    | NF-FF   |
| fo     | r 0.6 us. | Instruc  | tion Men | nory    |         |          |         |
| 50%    | 50%       | 50%      | 2.35 us  | 1.30 us | 1.45 us | 1.38 us  | 1.38 us |
| 50%    | 20%       | 20%      | 2.26     | 2.14    | 0.54    | 1.33     | 1.42 us |
| 80%    | 20%       | 80%      | 2.30     | 1.69    | 0.89    | 1.19     | 0.47    |
| for    | 2.0 us I  | nstructi | on Memo  | ry      |         |          |         |
| 50%    | 50%       | 50%      | 2.40 us  | 1.00 us | 1.80 us | 1.40 us  | 1.40 us |
| 50%    | 20%       | 20%      | 1.92     | 1.96    | 0.36    | 1.16     | 1.64    |
| 80%    | 20%       | 80%      | 2.11     | 1.45    | 0.84    | 2.22     | 0.10    |

4. Conclusions:

 (1) The performance variation in a problem with a lot of arithmetic data branching can vary by approximately # 15% depending on the way in which the branches are handled.

- (2) Holding-up on every branch seems to be less desirable than any of the guessing procedures.
- (3) It is very unlikely that one ever get fewer than 15% or more than 85% wrong-way branches regardless of his procedure.
- (4) It seems possible to get a fairly low loss by picking Case IV, provided the percentages on the last line of Table IX really are correct. However, if the percentages should be different, Case IV is much more sensitive to them than Case II.
- (5) To be really effective Case IV needs the existance of the indicators ≥ 0, ≤ 0 to make the distinction between off and on precise. At present one must code "Br-on ≤ 0", as "Br-off > 0," so that the equating of "on" to "exceptional case" is spoiled somewhat.
- (6) The highest performance would be obtained if each branch had an extra "guess bit" which would permit the programmer to specify which way he estimates each branch will most likely go. This seems to be impossible in the present format schemes. It also would place a considerable extra burden on the programmer for the gains promised.
- 5. Recommendations Finally Presented as a Result of the Simulator Runs

Case II (NF-FN) should be adopted as the guessing scheme. This means that for any branch for which the IAU cannot compute the correct outcome, it should guess that the branch is not taken and proceed with the processing of the next instruction.

Case II was chosen over case IV because:

Ē

- 1) Its time loss is low (at least second best)
- 2) It does not require special controls for deciding whether to assume a branch is taken or not
- 3) It does not require that new indicators be defined.
- 4) It should not confuse the programmer with complicated rules of coding the way Case IV might.

VI. APPENDIX: Details of Timing Simulation Program SIM-2

The following pages give detailed symbol definitions and flow diagrams for the SIM-2 code. The diagrams accurately represented the code at the time they were drawn. There have been some additions to the program since then, particularly in the I/O simulation section, but they do not change the main logic of the flow.

The simplified flow diagram, Figure 11, shows the major sections of the program. The following pages elaborate upon this figure. The logic of the Virtual Memory operation is described in Section III. The logical diagrams given there have direct counterparts in the flow diagrams which follow.

ł

~

### -62-

## STRETCH Timing Simulator Program SIM-2 List of Quantities Used in Flow Diagram

## Table 1

## Quantities Concerning Instructions fed through Simulator

. . . .

|                               |                | Look-        |                   |                      |                                       |                                                                    |
|-------------------------------|----------------|--------------|-------------------|----------------------|---------------------------------------|--------------------------------------------------------------------|
|                               | Instr.         | ahead        | Look-             | Instr.               | Arith.                                | Indexing                                                           |
|                               | Input          | Ready        | ahead             | Fetch                | Unit                                  | Arithmetic                                                         |
|                               |                | Reg.         | levels            |                      |                                       | Unit                                                               |
| Instr. Number                 | 111            | LR3          | LAU8              | IMRS                 | IPl                                   | ng ng mang ng pang kanalakan ng pang ng pang ng pang pang pang pan |
|                               |                |              |                   | IRUM                 | NRAU1                                 | (111)                                                              |
| Op. Code<br>Instr. Location   | 112<br>113     | LRI          | LAU2<br>LAUI      | ICAN<br>ICR1<br>ICR2 | NRAU2                                 | (IST = "STATE")                                                    |
| #I Index Addr.                | 114            |              |                   | 10104                |                                       | IRO                                                                |
| #II Index Addr.               | 115            |              |                   |                      |                                       | IRO                                                                |
| Data Address                  | 116            | LR2          | LAU3              | IBUG2                |                                       | IRO                                                                |
| Special Desig.                | 117            |              |                   |                      |                                       |                                                                    |
| Return Tag                    | 118            |              |                   |                      |                                       |                                                                    |
| Sp. Sp. Desig.                | 119            |              |                   |                      |                                       |                                                                    |
| Compare Bit<br>Forward Addr.  |                |              | LAU4<br>LAU5      |                      |                                       |                                                                    |
| O.K. Bit                      |                |              | LAU6              |                      |                                       | IRO1 (Fetch)                                                       |
| Forward Bit                   |                |              | LAU7              |                      |                                       | IRI (Return)                                                       |
| Mem. Bring Bit                |                |              | LAU9              |                      |                                       |                                                                    |
| Unit Clock                    |                | ,            |                   | ***                  | JAUT                                  | INS                                                                |
|                               |                |              |                   |                      |                                       | ú                                                                  |
|                               | Main o         |              | Central           | Bus to               | Bus                                   | <b>T</b>                                                           |
|                               | Instr.<br>Mem. | Core<br>Mem. | Control<br>Decode | Mem.                 | From<br>Mem.                          | Exchanges                                                          |
|                               |                |              | 200000            |                      |                                       |                                                                    |
| Instr. Number                 | IMM 2          | IXM4         | IBDI (or 6)       | JF1                  | NF1                                   | (90,91,92,93)                                                      |
| Return Addr.                  | IMMI           | IXM2         | IBD (or 5)        | JF                   | NF                                    | 32                                                                 |
| Bring Bit                     | IMM3           |              | IBD2(or 7)        | JF2                  |                                       | l or O                                                             |
| Read out Clock                | IMM4           |              |                   |                      |                                       |                                                                    |
| End Sig.Clock<br>Mem.Cy.Clock | IMM5<br>IMM6   |              | IBD4(or 9)        | JF4                  | NF2                                   | CLC                                                                |
| Mem. Res. Bit                 | IMM0<br>IMM7   |              | IBD4(01.4)        | JT #                 | NE 2                                  | CLC                                                                |
| Mem. Box No.                  | 1101101 .      |              | IBD3(or 8)        | JF3                  |                                       | IOM                                                                |
|                               |                |              |                   | JF-fast              | NF-Fast                               |                                                                    |
|                               |                |              |                   | memory               | · · · · · · · · · · · · · · · · · · · |                                                                    |
|                               |                |              |                   |                      | NM=main                               |                                                                    |
|                               |                |              |                   | memory               | memory                                |                                                                    |

-63-

List of Symbols

## TABLE II

## Control and Tally Quantities

## 1. Look-Ahead Symbols:

.

-114 14

| NCTRA | Instruction Fetch Counter       |
|-------|---------------------------------|
| NCTRB | Data Fetch Counter              |
| NCTRC | Data Store Counter              |
| NSTOB | Store Bit (an unexecuted Store) |
| NLH   | Number of Look-Ahead levels     |
| NBFR  | Modular value of NCTRC          |

## 2. Conflict Counters, and Tallys:

| CTT   | Total Time Tally                             |
|-------|----------------------------------------------|
| CAU   | Arithmetic Unit Tally                        |
| CIAU  | Indexing Arithmetic Unit Tally               |
| CADLA | Average depth of Look-Ahead Tally            |
| CLAF  | Look-Ahead Full Tally                        |
| CWI   | Arithmetic Unit Waiting on Instruction Tally |
| CWM   | Arithmetic Unit Waiting on Data Tally        |
| CDLA  | Look-Ahead level use Tally                   |
| CIF   | In-Bus from Fast Memory Tally                |
| CIM   | In-Bus from Main Memory Tally                |
| COF   | Out Bus (Read) to Memory Tally               |
| СОМ   | Out Bus (Write) to Memory Tally              |
| CIST  | Index State Tally                            |
| CIMM  | Memory use Tallys                            |
| CMMC  | Main Memory Conflict Tally                   |
| CFMC  | Fast Memory Conflict Tally                   |
| CXMC  | Index Memory Conflict Tally                  |

## 3. Miscellaneous Symbols:

| MARK             | Time Counter for Listing           |
|------------------|------------------------------------|
| BIB              | Break-in Bit on Wrong-Way Branches |
| SKIP             | Signal to "Run-Dry" at End         |
| TALLY            | Count of Number of Executed Ops.   |
| A, B, AD, THINK  | Temporary Locations                |
| IDR, IDW, LDA    | Pseudo-op Controls, etc.           |
| LASCB            | Look-Ahead, Self Compare Bit       |
| PBIT, CBIT, PHD  | B                                  |
| TBIT, WBIT       | Controls for Printing              |
| IB               | Block for Input from Control Cards |
| IP, RP, SIP, SSP | Various Printing Blocks            |
|                  |                                    |

# List of Symbols

## Table III

# Input Constants Appearing on Summary Listing

| Symbol<br>on<br>Listing | Name<br>in<br>Code | Description                       |  |  |
|-------------------------|--------------------|-----------------------------------|--|--|
| LA                      | NLH                | No. levels of look-ahead          |  |  |
| FM                      | NUFM               | No. of fast memory boxes          |  |  |
| MM                      | NUMM               | No. of main memory boxes          |  |  |
| IR                      | INX-4              | Index reset IAU State 4           |  |  |
| IS                      | INX-3              | Index store-1 IAU State 3         |  |  |
| IA                      | INX-2              | Index add-1 IAU State 2           |  |  |
| ID                      | INX-1              | Index Decode IAU State 1          |  |  |
|                         | INX                | (not used)                        |  |  |
| MB                      | NMBT               | Main (or write) bus time          |  |  |
| FB                      | NFBT               | Fast (or read) bus time           |  |  |
| $\mathbf{FD}$           | IDMT               | Fast Memory bus decode time (CCU) |  |  |
| HM                      | IDMT+1             | Hamming check time                |  |  |
| HE                      | IDMT+2             | High Speed Exchange word rate     |  |  |
| <b>X</b> 1              | IDMT+3             | Index Memory read-out time        |  |  |
| X2                      | IDMT+4             | Index Memory cycle time           |  |  |
| MD                      | IDMT+5             | Main Memory bus decode time (CCU) |  |  |
| Fl                      | MFT 1              | Fast Memory read-out time         |  |  |
| F2                      | MFT 2              | Fast Memory end signal time       |  |  |
| F3                      | MFT 3              | Fast Memory Total cycle time      |  |  |
| М1                      | MMT 1              | Main Memory read-out time         |  |  |
| M2                      | MMT 2              | Main Memory end signal time       |  |  |
| M3                      | MMT 3              | Main Memory Total cycle time      |  |  |
| 15                      | JT-15              | Op. Code 15 Square Root           |  |  |
| 14                      | JT-14              | 14 Divide                         |  |  |
| 13                      | JT-13              | 13                                |  |  |
| 12                      | JT-12              | 12 Cumulative Multiply            |  |  |
| 11                      | JT-11              | 11 Multiply                       |  |  |
| 10                      | JT-10              | 10                                |  |  |
| 9                       | JT-9               | 9 Add                             |  |  |
| 8                       | JT-8               | 8                                 |  |  |
| 7                       | JT-7               | 7 Load                            |  |  |
| 6                       | JT-6               | 6                                 |  |  |
| 5                       | JT-5               | 5                                 |  |  |
| 4                       | JT-4               | 4 Immediate Ops.                  |  |  |
| 3                       | JT-3               | 3 Immediate Ops.                  |  |  |
| 2                       | JT-2               | 2 Immediate Ops.                  |  |  |
| 1                       | JT-1               | l Immediate Ops.                  |  |  |
| LE                      | ĴT                 | Low Speed Exchange word rate      |  |  |

~~

#### List of Symbols

#### Table IV

## Output Results on Summary Listing

| Symbol<br>on<br>Listing                                                                                        | Name<br>in<br>Code            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------------------------------------------------------------------------------------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XMC<br>TT<br>AU<br>IAU<br>ADLA<br>LAF<br>WI<br>WM<br>DLA-<br>IBF<br>IBM<br>RB<br>WB<br>IS-<br>M-<br>MMC<br>FMC | (CXMC)<br>CTT<br>(CAU)<br>IST | Index Memory Conflicts (in % of total time)<br>Total Time of problem (XXX. X microseconds)<br>Arithmetic Unit busy (in % of TT<br>Indexing Arithmetic Unit busy<br>Average depth of look-ahead<br>Look-ahead full<br>Arithmetic Unit waiting on instructions<br>Arithmetic Unit waiting on data<br>% Time Look-ahead has depth specified<br>In bus from fast Memory busy<br>In bus from Main Memory busy<br>Read bus to Memory busy<br>Write bus to Memory busy<br>Time spent in Indexing State specified<br>Time Memory Box specified is busy<br>(M12 to M5 are Main Memories, M4 to M1 are Instr. Mems.<br>Main Memory conflicts<br>Fast Memory conflicts |
| WBC<br>RBC                                                                                                     |                               | Write bus conflicts<br>Read bus conflicts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

• •

- Op codes: (1) 1 thru 4 Immediate (1 = wrong-way branch)
  - (2) 5 thru 34 bring type (See Table III)
  - (3) 35 indexing type
  - (4) 36 to 97 store type
  - (5) Instruction No. 98 Stop in AU and Tr to Summary

Return Addresses: (1) 20 = IAU data

- (2) 21 Instruction fetch

  - (3) 1,2,3,...8 = Look-ahead levels
  - (4) 32 = Exchange

page 1



-66-



HGK Marll;58 Rev





**‡**:0

<u>=0</u>→A51

ICR1 > ICR2

150

IMR5

J≠0

A49

00+

+0

ICR1+1-> ICR2

ICAN-2

L

A417

A45

Step up IC

Test if Instr. fetch

is possible

. .

- SIM-2 Flow Diagram
  - (6) Read in Instrs. from Tape.
  - (7) Move Instrs, down in Memory.
  - (8) Wipe out 4 start over on wrong-way Br

HG K Mar 12, **58** 



-69-



HGK Alar 13,58



-71-

## page 7

SIM-2 Flow Diagram (15) In-bus Fast Mem. (6) In-bus Main Mem.



Ŕ

ŀ







3

HGK Mar 13,'se



HGK AMT 13:58

j,

į.



HGK Mar 1+,'58



-76-

...

## HGK Mar 14, 158

page 11



-77-

HGK Mar H,58

page 12

page 13



HGK Nor 1t, '58



HGK Mar 14, 58

