Programming Training Manual CONTROL DATA 1604 COMPUTER | Record of Revisions | | | | | | |---------------------|----------------------------------------------------|--|--|--|--| | REVISION | NOTES | | | | | | A | Minor corrections only; does not obsolete previous | | | | | | (11-1-61) | editions. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Address comments concerning this manual to: Control Data Corporation Technical Publications Department 4201 North Lexington Avenue St. Paul, Minnesota 55112 or use Comment Sheet located in the back of this manual. # PREFACE This manual applies to the 1604-C in all respects. It is applicable to the 1604-A and 1604-B except for some details in Input/Output. # TABLE OF CONTENTS | | Page | |------------------------------------------|------| | Chapter I PRELIMINARY INFORMATION | 1-1 | | Introduction | 1-1 | | Basic Peripheral Equipment | 1-1 | | Optional Peripheral Equipment | 1-2 | | Summary of Characteristics | 1-2 | | Internal Storage | 1-3 | | Address System | 1-4 | | 1604 Program Step | 1-4 | | 1604 Instruction Word | 1-5 | | Operational Registers | 1-7 | | Secondary Registers | 1-10 | | CDC 1604 Basic Instruction List | 1-12 | | Review Tcst (Chapter I) | 1-14 | | Chapter II FIRST GROUP OF INSTRUCTIONS | 2-1 | | First Instructions | 2-1 | | A Right Shift | 2-1 | | A Left Shift | 2-1 | | Q Right Shift | 2-2 | | Q Left Shift | 2-2 | | Load A | 2-6 | | Load Q | 2-6 | | Store A | 2-6 | | Store Q | 2-6 | | Add | 2-11 | | Subtract | 2-11 | | A Jump | 2-11 | | Q Jump | 2-11 | | Review Test (Chapter II) | 2-18 | | Chapter III SECOND GROUP OF INSTRUCTIONS | 3-1 | | Second Group of Instructions | 3-1 | | Long Right Shift | 3-1 | | Long Left Shift | 3-1 | | Enter A | 3-2 | | Enter Q | 3-3 | | Load A | 3-3 | | Load Q | 3-3 | | Increase A | 3-10 | | Multiply Integer | 3-11 | | Divide Integer | 3-12 | | Selective Jump | 3-16 | | Substitute Address (Upper) | 3-16 | | Substitute Address (Lower) | 3-18 | | Review Test (Chapter III) | 3-21 | | Chapter IV | THIRD GROUP OF INSTRUCTIONS | 4-1 | |----------------------|------------------------------|--------------| | Third Grou | p of Instructions | 4-1 | | Storage | Skip | 4-1<br>4-1 | | Storage | Shift | 4-2 | | Index S | kip | 4-2 | | Index J | | 4-3 | | Load Lo | | 4-7 | | Add Log | | 4-7 | | | t Logical | 4-7 | | Store L | | 4-7 | | Enter I | | 4-12 | | | o Nothing) | 4-12 | | Increase | | 4-12 | | | dex (Upper) | 4-12 | | | dex (Lower) | 4-13 | | | ndex (Upper) | 4-13 | | | ndex (Lower) | 4-13 | | Review Test ( | (Chapter IV) | 4-17 | | Chapter V | FOURTH GROUP OF INSTRUCTIONS | 5-1 | | | | 5-1 | | Fourth Grou | p of Instructions | 5 <b>-</b> 1 | | Multiply | Fractional | 5-1 | | | ractional | 5-2 | | Selectiv | | 5-3 | | Selectiv | | 5-4 | | Selectiv | | <b>5-</b> 5 | | | e Complement | 5-5 | | | e Substitute | <b>5-</b> 5 | | Equality<br>Threshol | | 5-11 | | Masked E | | 5-13 | | Masked T | | 5-13 | | Replace A | | 5-14 | | Replace S | | 5-21 | | Replace A | | <b>5-</b> 21 | | | Subtract One | 5-21 | | Review Test ( | | 5-21 | | 1002 ( | Shapter V) | 5-26 | | Chapter VI F | TIFTH GROUP OF INSTRUCTIONS | 6-1 | | Rifth Carr | of Inghmedian | | | Floating Poi | of Instructions | 6-1 | | Floating Pol | | 6-1 | | Floating | | 6-5 | | Floating | | <b>6-</b> 5 | | Floating | | 6-5 | | Scale A | DIAIGE | 6-6 | | Scale AQ | | 6-7 | | peare MY | | 6-8 | | Cha | PTET VII SIXTH GROUP OF INSTRUCTIONS | 7-1 | |-----|-----------------------------------------------------------------------------------------------------|---------------------------------| | S | ixth Group of Instructions External Function Input Transfer Output Transfer External Function Codes | 7-1<br>7-3<br>7-6<br>7-7<br>7-9 | | | APPENDIXES | | | Α. | Results of Exercises | A-1 | | В. | Review Test Answers | B-1 | | c. | 1604 Assembly Program | C-1 | | D. | Load and Dump Routines | D-1 | | Ε. | Trace Program | E-1 | | F. | Program for Duplicating Punched Tape | F-1 | | G. | Program for Adding One Record to File | G-1 | #### CHAPTER I #### PRELIMINARY INFORMATION #### INTRODUCTION The 1604 is a general-purpose, parallel, digital computer designed for large scale scientific problems or for large-volume data processing. It features the following general characteristics: - 1. Equipment is low-power, solid-state throughout. - 2. Physical size is such that it can be used in a semi-permanent office environment. - 3. Several of the peripheral equipments can communicate directly with computer storage through independent access-channels. This permits reading and writing on magnetic tapes without external buffering devices. - 4. Internal storage contains two magnetic core units operating together to form a single storage system of 1.6 million bits capacity; storage cycle time is 6.4 microseconds. - 5. Real time inputs and outputs may be processed with peak rates up to 15 million bits per second. - 6. Fixed and floating binary point arithmetic operations are possible with an average instruction time of 10 microseconds and a basic addition time of 1.2 microseconds. - 7. The full use of index registers along with the regular instruction repertoire makes it possible to use almost 500 types of instructions in programming. # Basic Peripheral Equipment - a. Magnetic Tape provides the principal input-output medium. Recording on tape is in IBM coded or binary format. One magnetic tape cabinet is provided with the basic unit. Additional cabinets are available optionally. - b. Paper Tape equipment consists of a Control Data 350 Reader and a Teletype BRPE Punch. c. Typewriter monitoring information, with keyboard entry, is provided by a modified IBM typewriter. # Optional Peripheral Equipment a. A Model 1605 Adaptor converts character information from IBM equipments to 48 bit words. This adaptor communicates directly with 1604 storage through a separate input-output channel. This makes possible the use of the following additional peripheral equipments: IBM 714 Card Reader IBM 722 Card Punch IBM 717 Line Printer IBM 727 Magnetic Tape Transports ## Summary of Characteristics General Type -Word Length -Storage -Storage Cycle Time -Instruction Type -Index Registers -Average Instruction Time -Arithmetic Operations -Pasic Add Time -Circuits -Clock -Buffered Communication Channels -Buffer Processing Time -Block Transfer Channels -Block Transfer Time -Power -Minimum Floor Space - Parallel 48 Bits 32,768 words, two phase core 6.4 microseconds Single address (two per word) Six 10 microseconds Fixed & floating binary point 1.2 microseconds Transistor-diode, direct-coupled Two phase, 5 mc rate Six 48-bit channels 16 microseconds per word Two 48-bit channels 3.2 microseconds per word 4KW (central computer) 400 sq. ft. ### Internal Storage The storage section contains two independent magnetic core storage units each with a capacity of 16,384 words of data 48 bits in length. These units operate together during execution of a program and can be considered as one 32,768 word storage system. FIG. 1 indicates the cores. FIG. 1 ## Two Magnetic Core Units Each 16,384 Words All odd storage addresses reference one of the above units; all even storage addresses reference the other unit. Each unit has a storage cycle time of 6.4 microseconds. Actually the cycles of the two units overlap one another in the execution of a program. For example, if a person thinks of a storage reference consisting of a "read" and "write" time; while one reference is engaged in "writing" the next instruction can be using up the "read" time (see FIG.2). This results in an effective cycle time considerably less than the nominal 6.4 microseconds. FIG. 2 Overlap of two Storage References #### Address System The model 1604 is a single-address computer. This means that each instruction can contain but one address. As previously mentioned, even addresses make one of the core units (16,384 locations) available; odd addresses make the other unit (16,384 locations) available. Thus a total of 32,768 locations are available for addresses. Since 15 bits are set aside for address designation, the total address range (in octal) is # 00000 to 7777 In this range, addresses 00000, 00002, 00004 - - - 77776 (even) refer to one storage unit; whereas addresses 00001, 00003, 00005 - - - 77777 (odd) refer to the other storage unit. # Even Addresses Odd Addresses 00000 00002 00004 00005 00001 00003 00005 → Storage Unit 2 77776 77777 Certain storage locations in the memory are used for control and reference functions. These storage locations may be addressed as operands as well as being addressed implicitly by certain control functions. The address assignments for these functions are listed below and will be explained in detail later. | Special Address | Function or Purpose | |-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00000<br>00001<br>00002<br>00003<br>00004<br>00005<br>00006 | Real Time Clock (1/60 <sup>th</sup> of a second steps) Channel 1 control Channel 2 control Channel 3 control Channel 4 control Channel 5 control Channel 6 control Interrupt program (exit-entrance) | # 1604 Program Step Each program step is a 40-bit word in storage which usually contains two single-address instructions. Each instruction is made up of 24 bits. If a program step contains a single instruction it is necessary that the other instruction be a "do nothing" instruction. This "do-nothing" instruction will be referred to in this manual as the "PASS INSTRUCTION". It has a special code and is described in detail in Chapter IV. The two instructions in a program step can be considered as logically separate entities in a program sequence. As a practical matter in programming coding, however, the pair is an entity similar to a two-address instruction. The two single address instructions are not separable in the sense that one may not be executed without the other. FIG. 3 indicates the possibilities of the general composition of a program step. | 24 Bits<br>Upper Instruction | 24 Bits Lower Instruction | |------------------------------|---------------------------| | 24 Bits | 24 Bits | | Upper Instruction | With the Pass Code | | 24 Bits | 24 Bits | | With the Pass Code | Lower Instruction | FIG. 3 Possible Word Formats ## 1604 Instruction Each instruction is a 24-bit quantity specifying a certain operational entity in the execution of a stored program. The instruction format is shown below in FIG. 4. #### Function Code FIG. 4 Binary and Octal Formats of a Typical 1604 Instruction Examining FIG. 4, it can be seen that a 1604 instruction contains 24 bits or 8 octal digits. Of this total, 9 bits or 3 octal digits make up the complete FUNCTION CODE. Actually, the operation code (first 6 bits) determines the specific instruction but there are eight different variations of most instructions, dependent upon the index designator. For this reason, it is probably better for the programmer to think of the complete FUNCTION CODE as containing both an operation code and an index designator (b). The two operation codes which are not used (00 and 77) are not valid codes but can be used as fault designators which will stop computation and indicate malfunction when interpreted as operation codes. Since index registers play such an important part in programming the 1604, it is necessary to define some of their general characteristics at this time. Six index registers are available for address modification of the base execution address. These index registers are numbered 1 through 6 and are selected by the corresponding octal number (1 through 6) placed in the index designator of the instruction. These index registers perform two different types of functions in the 1604 as defined below. - 1. As address modifiers, the content of the designated index register is added to the base execution address before the computer interprets the specific instruction. (Addition is modulus 215 minus one, one's complement) - 2. As jump conditioners. For programming facility, let us assume the operation code of 6 bits is separated from the index designator by an octal reference point as shown below. 06.0 Each one of these contains the same operation code (06) but a different index 06.1 designator. Each index designator 06.2 designates a different functional operation 06.3 of the basic code (06). For this reason it 06.4 is customary to think of these as eight 06.5 variations of the same instruction or simply 06.6 as eight different instructions. 06.7 The operation code of six bits specifies the general character of the operation to be performed by the instruction. The index designator of three bits completes the function code so that the computer carries out a specific operational procedure. Of the possible 64 operation codes (six bits can hold 64 different codes), the 1604 uses 62 for general instructions. Since there are eight possible index designators (three bits can hold eight different codes 0 to 7), there are approximately 500 (8 x 62) different variations available. It is important to note that regardless of the particular function they may serve, the use of index registers involves the contents of the index register which is designated except in the case of instructions 22, 23, 74, 75, and 76. In addition to the codes I through 6, the index designator can also indicate 0 or 7. A zero index designation indicates that no index register is involved. (Exception: In some instructions, a designation of 0 may refer to a certain condition being fulfilled before a jump occurs.) An index designation of 7 will indicate that indirect addressing is to be used except in an instruction where the index designation defines a necessary condition for a jump and in the external function sense condition. (Indirect addressing is a means for expanding the reference capabilities of the instruction execution address. In indirect addressing, the instruction execution address specifies a storage location in which is located the operand address.) Of particular significance to programmers with respect to the use of index registers is the fact that when the contents of the index register is added to the execution address, the addition is performed in a ones complement accumulator, modulus 215 minus one. Use of index registers along with indirect addressing (for index 7) will be explained in detail for the individual instructions. ## Operational Registers The operational registers of the 1604 computer are defined as those registers which are capable of storing data from one instruction to another; the contents of those registers are displayed on the control console. These registers do not have special addresses (as is necessary in two or three address logic) but are referenced implicitly by the execution of the different instructions. However, it is important that the programmer know of these registers and of their functional use in the instructions. Altogether ten different internal registers are available for auxiliary functions. Two of these are arithmetic registers, six are index registers, and two perform control functions. The ten are listed and described below: | Arithmetic<br>Registers | A Register 48 bits Q Register 48 bits | |-------------------------|--------------------------------------------------------------------------------------------| | | Index 1 15 bits Index 2 15 bits Index 3 15 bits | | | Index 2 15 bits | | Index | Index 3 15 bits | | Registers | 7 Index 4 15 bits | | | Index 5 15 bits | | | Index 5 15 bits Index 6 15 bits | | Control Registers | Program Control Register (U <sup>1</sup> upper)24 bits Program Address Register (P)15 bits | The A register, or accumulator, operates as a 48-bit subtractive accumulator during most of the arithmetic operations. Normal arithmetic operations are performed modulus (2<sup>48</sup>-1). This register also has shifting capabilities which are explained under "shifting". The Q register assists the A register in performing the more extensive arithmetic operations. For example, multiply, divide, and floating point instructions involve both the A and Q registers. The Q register serves as a "mask" during the logical operations and it also has shifting capabilities which are explained under "Shifting". On some instructions the A and Q registers operate as one large register. For example, it is possible to shift A and Q as one register of 96 bits. Six index registers are available for modification of execution addresses. In program loops, two approaches are possible in using these index registers for looping: - The contents of an index register may be advanced each pass through a loop and the exit is initiated when the contents of the index register attain a given threshold. - 2. The contents of an index register may be preset to a certain amount and then reduced by one count each pass through the program loop until an exit is initiated upon the index register contents reading zero. The two control registers are used to control the internal sequencing of instructions. The Program Control Register ( $\mathbf{U}^1$ ) holds the current instruction and interprets this instruction so that the proper execution can begin. The Program Address Register (P) holds the storage location of the current program step during the interpretation and execution of an instruction contained in that program step. Upon completion of a step in the program, the program address is advanced one count to specify the location of the next step. FIG. 5 indicates the functional aspects of the U and P registers. FIG. 5 Sequencing of P and U #### Secondary Registers In addition to the operational registers there is a group of twelve registers, not displayed on the control console, which also perform a vital function in machine operation. These are the secondary registers. Ordinarily they may be thought of as transfer registers, acting as intermediate storage for computer instructions or operands as they are manipulated during the execution of an instruction. The twelve registers include | Auxiliary program control register U <sup>2</sup> | • | • | • | • | 15 | bits | |---------------------------------------------------|----|---|---|---|----|------| | Storage address register S <sup>1</sup> | • | • | • | • | 14 | bits | | Storage address register S <sup>2</sup> | • | • | • | • | 14 | bits | | Storage restoration register z1 | • | • | • | • | 48 | bits | | Storage restoration register $z^2$ | • | • | • | • | 48 | bits | | Address buffer register R | • | • | • | • | 15 | bits | | Exchange register X | • | • | • | • | 48 | bits | | Function register 00 | • | • | • | • | 15 | bits | | Output (four provided) registers 01,2; | 3, | 4 | • | • | 48 | bits | The auxiliary program control register, U<sup>2</sup>, is an accumulator used in the modification of the execution address of the current instruction by the addition of the contents of an index register. The even and odd 16,384 word memory units each has a storage address register, $S^1$ and $S^2$ respectively. These registers receive addresses of instructions from the address register, P, and addresses of operands from $U^2$ . Each even and odd memory unit also has a storage restoration register, $Z^1$ and $Z^2$ respectively, which holds the 48-bit word which is to be written in a given storage location. The R register acts as an exchange register for transmissions involving the index registers. It is used for advancing or reducing the count in a given index register. During several instructions it is used to count repetitive operations. Floating-point instructions use R in performing arithmetic operations on the exponent or characteristic. The X register is an exchange and auxiliary arithmetic register. All input and output data pass through the X register. The external function register, $0^0$ , is used for exchanging control information with imput-output equipment. Four output registers, $0^1$ , $0^2$ , $0^3$ , and $0^4$ , are provided. $0^1$ , $0^2$ and $0^3$ are used for output buffer operations where the data are transmitted at the speed of the input-output equipment. Output register $0^4$ handles all high-speed output transfer operations where the data are transferred at the internal speed of the computer. CONTROL DATA MODEL 1604 BASIC INSTRUCTION LIST (omitting the eight possible variations of each instruction due to index designations 0 through 7) | ZRO | 00 | (not used) | SST | 40 | Selective Set | |----------------------------------------------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ARS | | A Right Shift | SCL | 41 | Selective Clear | | QRS | | Q Right Shift | SCM | 42 | Selective Complement | | LRS | | Long Right Shift | SSU | 43 | Selective Substitute | | ENQ | | Enter Q | LDL | 44 | Load Logical | | ALS | | A Left Shift | ADL | 45 | Add Logical | | QLS | | Q Left Shift | SBL | 46 | Subtract Logical | | LLS | | Long Left Shift | STL | 47 | Store Logical | | | • | | | | _ | | ENA | 10 | Enter A | ENI | 50 | Enter Index | | INA | | Increase A | INI | 51 | Increase Index | | LDA | | Load A | LIU | 52 | Load Index (upper) | | LAC | | Load A, Complement | LIL | 53 | Load Index (lower) | | ADD | | AĞU | ISK | 54 | Index Skip | | SUB | | Subtract | IJP | 55 | Index Jump | | | | Load Q | SIU | 56 | Store Index (upper) | | LQC | | Load Q, Complement | SIL | 57 | Store Index (lower) | | _,, | -• | _ | | | | | STA | 20 | Store A | SAU | 60 | Substitute Address (upper) | | STQ | | Store Q | SAL | 61 | Substitute Address (lower) | | | 41 | | | | | | | | • | INT | 62 | Input Transfer | | AJP | 22 | A Jump | | 62<br>63 | Input Transfer<br>Output Transfer | | AJP<br>QJP | 22<br>23 | A Jump<br>Q Jump | INT | | | | AJP<br>QJP<br>MUI | 22<br>23<br>24 | A Jump | INT<br>OUT | 63 | Output Transfer | | AJP<br>QJP<br>MUI<br>DVI | 22<br>23<br>24<br>25 | A Jump<br>Q Jump<br>Multiply Integer<br>Divide Integer | INT<br>OUT<br>EQS<br>THS | 63<br>64 | Output Transfer<br>Equality Search | | AJP<br>QJP<br>MUI | 22<br>23<br>24<br>25<br>26 | A Jump<br>Q Jump<br>Multiply Integer | INT<br>OUT<br>EQS<br>THS | 63<br>64<br>65 | Output Transfer<br>Equality Search<br>Threshold Search | | AJP<br>QJP<br>MUI<br>DVI<br>MUF | 22<br>23<br>24<br>25<br>26 | A Jump<br>Q Jump<br>Multiply Integer<br>Divide Integer<br>Multiply Fractional | INT<br>OUT<br>EQS<br>THS<br>MEQ | 63<br>64<br>65<br>66 | Output Transfer Equality Search Threshold Search Masked Equality | | AJP<br>QJP<br>MUI<br>DVI<br>MUF | 22<br>23<br>24<br>25<br>26<br>27 | A Jump<br>Q Jump<br>Multiply Integer<br>Divide Integer<br>Multiply Fractional | INT<br>OUT<br>EQS<br>THS<br>MEQ | 63<br>64<br>65<br>66<br>67 | Output Transfer Equality Search Threshold Search Masked Equality Masked Threshold Replace Add | | AJP<br>QJP<br>MUI<br>DVI<br>MUF<br>DVF | 22<br>23<br>24<br>25<br>26<br>27 | A Jump Q Jump Multiply Integer Divide Integer Multiply Fractional Divide Fractional | OUT<br>EQS<br>THS<br>MEQ<br>MTH | 63<br>64<br>65<br>66<br>67<br>70<br>71 | Output Transfer Equality Search Threshold Search Masked Equality Masked Threshold Replace Add Replace Subtract | | AJP<br>QJP<br>MUI<br>DVI<br>MUF<br>DVF | 22<br>23<br>24<br>25<br>26<br>27<br>30<br>31 | A Jump Q Jump Multiply Integer Divide Integer Multiply Fractional Divide Fractional Floating Add | INT<br>OUT<br>EQS<br>THS<br>MEQ<br>MTH | 63<br>64<br>65<br>66<br>67 | Output Transfer Equality Search Threshold Search Masked Equality Masked Threshold Replace Add Replace Subtract Replace Add One | | AJP<br>QJP<br>MUI<br>DVI<br>MUF<br>DVF<br>FAD<br>FSB<br>FMU | 22<br>23<br>24<br>25<br>26<br>27<br>30<br>31 | A Jump Q Jump Multiply Integer Divide Integer Multiply Fractional Divide Fractional Floating Add Floating Subtract | INT<br>OUT<br>EQS<br>THS<br>MEQ<br>MTH<br>RAD<br>RSB | 63<br>64<br>65<br>66<br>67<br>70<br>71<br>72<br>73 | Output Transfer Equality Search Threshold Search Masked Equality Masked Threshold Replace Add Replace Subtract Replace Add One Replace Subtract One | | AJP<br>QJP<br>MUI<br>DVI<br>MUF<br>DVF<br>FAD<br>FSB<br>FMU<br>FDV | 22<br>23<br>24<br>25<br>26<br>27<br>30<br>31<br>32 | A Jump Q Jump Multiply Integer Divide Integer Multiply Fractional Divide Fractional Floating Add Floating Subtract Floating Multiply | INT OUT EQS THS MEQ MTH RAD RSB RAO | 63<br>64<br>65<br>66<br>67<br>70<br>71<br>72<br>73<br>74 | Output Transfer Equality Search Threshold Search Masked Equality Masked Threshold Replace Add Replace Subtract Replace Add One Replace Subtract One External Function | | AJP<br>QJP<br>MUI<br>DVI<br>MUF<br>DVF<br>FAD<br>FSB<br>FMU<br>FDV<br>SCA | 22<br>23<br>24<br>25<br>26<br>27<br>30<br>31<br>32<br>33 | A Jump Q Jump Multiply Integer Divide Integer Multiply Fractional Divide Fractional Floating Add Floating Subtract Floating Multiply Floating Divide | INT OUT EQS THS MEQ MTH RAD RSB RAO RSO | 63<br>64<br>65<br>66<br>67<br>70<br>71<br>72<br>73<br>74<br>75 | Output Transfer Equality Search Threshold Search Masked Equality Masked Threshold Replace Add Replace Subtract Replace Subtract Replace Subtract One External Function Selective Jump | | AJP<br>QJP<br>MUI<br>DVI<br>MUF<br>DVF<br>FAD<br>FSB<br>FMU<br>FDV<br>SCA<br>SCQ | 22<br>23<br>24<br>25<br>26<br>27<br>30<br>31<br>32<br>33<br>34 | A Jump Q Jump Multiply Integer Divide Integer Multiply Fractional Divide Fractional Floating Add Floating Subtract Floating Multiply Floating Divide Scale A | INT OUT EQS THS MEQ MTH RAD RSB RAO RSO EXF | 63<br>64<br>65<br>66<br>67<br>70<br>71<br>72<br>73<br>74<br>75<br>76 | Output Transfer Equality Search Threshold Search Masked Equality Masked Threshold Replace Add Replace Subtract Replace Add One Replace Subtract One External Function Selective Jump Selective Stop | | AJP<br>QJP<br>MUI<br>DVI<br>MUF<br>DVF<br>FAD<br>FSB<br>FMU<br>FDV<br>SCA<br>SCQ | 22<br>23<br>24<br>25<br>26<br>27<br>30<br>31<br>32<br>33<br>34<br>35<br>36 | A Jump Q Jump Multiply Integer Divide Integer Multiply Fractional Divide Fractional Floating Add Floating Subtract Floating Multiply Floating Divide Scale A Scale AQ | INT OUT EQS THS MEQ MTH RAD RSB RAO RSO EXF SLJ | 63<br>64<br>65<br>66<br>67<br>70<br>71<br>72<br>73<br>74<br>75 | Output Transfer Equality Search Threshold Search Masked Equality Masked Threshold Replace Add Replace Subtract Replace Subtract Replace Subtract One External Function Selective Jump | Instructions are probably easier to learn if a few at one time are mastered along with an opportunity to use these in various short examples. This manual will follow this philosophy in the pages which follow. In addition, all floating-point instructions will be described under the chapter dealing with this topic (see Chapter on Floating Point). It is also important to note that instructions will be presented with mnemonic codes as well as numeric codes. The mnemonic codes are for the convenience of the programmer and grast be converted to the numeric codes when the final draft of a program is written. Following each set of instructions, examples and exercises are presented and at the end of each chapter a general review test in presented. Solutions to these exercises and tests are present in the appendixes. # CHAPTER I Review Test The following questions review the preliminary information presented in this chapter. Write the answers in the space provided and then check your solutions with those presented in Appendix B. | | y bits does each internal storage location | | |------------------|-----------------------------------------------------------------|-----------------| | | the total number of internal storage lo | | | The mod | el 1604 computer is a two-address machine | e. (True-False | | What is | the total range of addresses available | for programmin | | Sketch<br>number | a 1604 instruction, showing the importan of bits for each part. | t parts and the | | | of pits for each part. | | | | | | | Describ | | a steps. | | Describ | e or sketch the possible types of progra | a steps. | | Describ | e or sketch the possible types of progra | a steps. | | Tastruc compute | e or sketch the possible types of progra | r input to the | | 10. | How many index registers are available? | |-----|-----------------------------------------------------------------------------------------------------------------------------| | 11. | Name two operational registers other than the index registers. | | 12. | Which register holds the address only of the current instruction? | | 13. | Which register holds the current instruction? | | 14. | Which registers have shifting capabilities? | | 15. | Are floating-point instructions available? (Yes or No) | | 16. | Without considering the variations possible through index register designations, how many basic instructions are available? | | 17. | What is the approximate minimum floor space required for the standard 1604 installation? | | 18. | What are the standard input-output peripheral equipments used by the computer? | | | | | 19. | Since the computer contains transistors instead of electronic tubes, the power requirements are less. (True-False) | | 20. | In some instructions it is possible to operate on 96 bits as though they made up the contents of one register. (True-False) | #### CHAPTER II # FIRST GROUP OF INSTRUCTIONS FIRST INSTRUCTIONS (With Mnemonic and Numeric Codes) (where "b" represents the index designator which can be any number 0 through 7) | A RIGHT SHIFT A LEFT SHIFT Q RIGHT SHIFT Q LEFT SHIFT LOAD A LOAD Q | (ALS.b)<br>(QRS.b) | (01.b)<br>(05.b)<br>(02.b)<br>(06.b)<br>(12.b)<br>(16.b) | STORE A STORE Q ADD SUBTRACT A JUMP Q JUMP | (STA.b)<br>(STO.b)<br>(ADD.b)<br>(SUB.b)<br>(AJP.b)<br>(OJP.b) | (20.b)<br>(21.b)<br>(14.b)<br>(15.b)<br>(22.b)<br>(23.b) | |---------------------------------------------------------------------|--------------------|----------------------------------------------------------|--------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------| |---------------------------------------------------------------------|--------------------|----------------------------------------------------------|--------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------| The first four instructions are SHIFT instructions. These are not the only shift instructions - others will be described later. On the 1604 both end-around and end-off shifts are available. The term end-around indicates a shift in one direction (left on 1604) with bits coming out of one end of the register (left end) and being carried around to the other end (right) of the same register. No bits are discarded in an end-around shift. End-off shifts are shifts in one direction (right on 1604) with the bits being discarded as they come off one end (right) of the register. On the 1604 computer LEFT SHIFTS are end-around; RIGHT SHIFTS are end-off. # A RIGHT (ARSb) (01.b) (where b may be 0 through 7) This instruction shifts the contents of the A register to the right the prescribed number of bit positions indicated by the sum of the execution address and the contents of the index register designated. The sign bit is extended (repeated) as the bits shift right. The lowest order bits are discarded as they are shifted out of the register. Shift counts greater than 127 (decimal) are treated as shift faults which may be sensed by the external function instruction. Shift faults do not stop the computer. # A LEFT (ALSb) (05.b) (where b may be 0 through 7) This instruction shifts the contents of the A register circularly end-around to the left the prescribed number of bit positions indicated by the sum of the execution address and the contents of the index register designated. The lowest order bit positions, being vacated, are filled by the highest order bits as the shifting proceeds. No bits are discarded; those shifting out of the left end of the register are carried around to the right end. Shift counts greater than 127 (decimal) are shift faults which may be sensed by the external function instruction. # Q RIGHT (QRSb) (02.b) (where b may be 0 through 7) This instruction shifts the contents of the Q register "end-off" to the right the prescribed number of bit positions indicated by the sum of the execution address and the contents of the index register designated. The sign bit is extended (to the right) as the bits shift right. Low order bits being shifted out of the register are discarded. A maximum shift count of 127 (decimal) results in a shift fault which may be sensed by the external function instruction. # Q LEFT (QLSb) (06.b) (where b may be 0 through 7) This instruction shifts the contents of the Q register circularly "end-around" to the left the prescribed number of bit positions indicated by the sum of the execution address and the contents of the index register designated. The lowest order bit positions (being vacated) are filled with the higher order bits as the shifting proceeds. No bits are discarded - those shifting out of the left end of the register are carried around to the right end. Shift counts greater than 127 (decimal) cause a shift fault which may be sensed by the external function instruction. The following examples should facilitate learning these four shift instructions. (Each student is advised to work out the examples and check the given solutions.) EXAMPLE I. Assume the A register contains the octal quantity shown below. Show the instruction and the final octal contents of the A register after shifting 27<sub>10</sub> bit positions to the right. Explanation: A shift of 27 bit positions is equivalent to 9 octal places since 3 shifts (3 bits) equals 1 octal position. Since right shifts are "end-off", the 9 low order octal digits are discarded and the sign bits (in this case zeros) are extended. Also note that the index register designated in the above instruction is zero. Any combination of execution address and contents of index register whose sum is 33 (octal) would be correct. For example, an alternative solution to the above instruction might be 0 1 6 0 0 0 3 1 where Index Register 6 contains 0 0 0 0 2. EXAMPLE 2. Assume a programmer wants to shift the initial contents of the Q register (given below in binary form) right $40_{10}$ bit positions without discarding any of the given bits. Show the instruction needed and the final contents of the Q register after shifting. #### Given: Explanation: Since no bits are to be discarded, a left shift instruction is required. However, the programmer wishes to shift right. Fortunately, for every desired right end-around shift there is an equivalent left end-around shift. The rule is to subtract the desired right shifts from 48 and the result is the equivalent number of left shifts. In this case 48-40=8. Then a left end-around of $8_{10}$ bit position gives the desires result. (3 decimal = 10 octal) EXAMPLE 3. A programmer wishes to shift the contents of the Q register 17<sub>10</sub> bit positions left, end-around, and then shift the resulting Q register contents 3 places right, end-off. Show the program step in octal to do this. Explanation: The left shift instruction is programmed on the left side of the word since the left shift is desired first. The right shift instruction then follows on the right side of the word. Seventeen (decimal) = 21 (octal). Also note that other combinations could be used if the index designations are not zero. For example, an alternative solution might appear as: EXAMPLE 4. A count is being generated in index register 5. At certain times within the program it is necessary to shift both the Q and A register left by the count in this index register. Show the program step which will do this. Explanation: Since the number of bit positions to be shifted is contained in index register 5, the index designator above becomes 5 and the execution address portion is zero. Thus the sum of the execution address and the contents of the index register is equivalent to the contents of the index register. The following exercises are provided for practice on the four shift instructions presented on the previous pages. Work out the required solutions and check the answers against those shown in Appendix A. The number of correct answers will indicate the approximate mastery of these instructions by cross checking the Rating Table below. # Rating Table 1 If you have 4 or 5 correct answers . . . . . . Excellent If you have 3 correct answers . . . . . . . . . . . . Good If you have 1 or 2 correct answers . . . . . . . . . . . Fair (Review) If you have 0 correct answers . . . . . . . . . . . . Poor (Restart) #### EXERCISE 1. - a. Write a 1604 instruction to shift Q $14_{10}$ bit positions right. - b. The A register contains 0 0 0 0 2 1 7 0 0 0 0 0 1 1 0 0. After shifting $\Lambda$ left end-around 22<sub>10</sub> bit positions, what will A contain? (Show answer in octal format.) - c. Write a program step which will first shift Q right 7 bits and then shift the new result in Q left by 12<sub>10</sub> bit positions. - d. Write a 1604 instruction to shift A right by 5 bits without discarding any bits. - e. Would a right end off shift of 6 bits equal a left end-around shift of 42<sub>10</sub> bit positions? Explain. With a single address computer transferring data from one storage location to another is usually accomplished by loading a particular register and storing the contents of this register somewhere else. The next four instructions indicate the basic transfer instructions on the model 1604 computer. More powerful transfer instructions will be presented later. LOAD A (LDA.b) (12.b) (where b may be 0 through 7) This instruction replaces the A register contents with an operand whose location is specified by the sum of the execution address and the contents of the designated index register. A storage reference is made to obtain the 48-bit quantity at the location indicated by the sum of the execution address, and the contents of the designated index register. A is cleared, the 48-bit quantity is then loaded into the A register. The memory location remains unchanged. LOAD Q (LDQ.b) (16.b) (where b may by 0 through 7) This instruction replaces the Q register contents with an operand whose location is specified by the sum of the execution address and the contents of the designated index register. A storage reference is made to obtain the 48-bit quantity indicated by the sum of the execution address and the contents of the designated index register. Q is cleared, the 48-bit quantity is then loaded into the Q register. The memory location remains unchanged. STORE A (STA.b) (20.b) (where b may be 0 through 7) This instruction stores the contents of the A register at the storage location specified by the sum of the execution address and the contents of the designated index register. The A register contents are not modified by this instruction - that is, A still holds its initial contents upon the completion of the instruction. STORE Q (STO.b) (21.b) (where b may be 0 through 7) This instruction stores the contents of the Q register at the storage location specified by the sum of the execution address and the contents of the designated index register. The Q register contents are not modified by this instruction - that is, Q still holds its initial contents upon the completion of the instruction. The following examples should facilitate learning these basic transfer instructions. (Each student is advised to work out the examples and check the given solutions.) EXAMPLE 5. Assume zeros are contained at storage location 17012. Show the program step which will load these zeros into the A and Q registers. Explanation: In each instruction above, the computer will reference the storage (17012) given in the execution address and load the contents of 17012 into the A or Q register depending upon the Code 12 or 16. Note that the index designators are zeros above. This is not a necessary condition. An index designation other than zero is satisfactory if the contents of the designated index register plus the execution address equals 17012 above. For example, 12 3 17000 is equivalent to the left instruction above if the contents of index register 3 are 00012. EXAMPLE 6. At storage location 00017 is the constant 1. The programmer desires to transfer this constant to storage location 00200. He does not want to disturb the present contents of the A register. Show the program step which will do this. Explanation: The upper instruction loads the contents of 00017 into the Q register. The lower instruction then stores the contents of Q (which now contains the contents of 00017) into 00200, completing the transfer. Note the index designators are both zero. This is not a necessary condition. For example, if index register 6 contains 00200, the lower instruction above could be: EXAMPLE 7. An address is being generated in index register 4. Another address is being generated at index register 1. A programmer wants to store the contents of the generated address of index register 4 in the generated address of index register 1. He does not want to disturb the A register while doing this. Show the program step required. Explanation: Since A is not to be disturbed, the Q register instructions are used. The upper instruction loads Q with the contents of the generated address of index register 4. The lower instruction then stores the contents of Q into the generated address which is the contents of index register 1. Did the contents of index registers 4 and 1 change because of this program step? What did change? The following exercises are provided for practice on the four basic transfer instructions presented in this chapter. Work out the solutions and check the answers against those in Appendix A. The following Table indicates your approximate progress in learning to program these instructions. # Rating Table 2 #### EXERCISES 2. - a. Given, index register 3 contains 00005. What will the instruction, 12300010 accomplish? - b. Write a program step which will transfer the contents of storage location 01000 to location 01001 without disturbing the A register. - c. Index register 2 contains 77767. What will instruction 20200020 accomplish? - d. What is the difference in effect upon the initial contents of A or Q when LOAD and STORE instructions are programmed? The last four instructions of this chapter include two arithmetic and two jumps. The arithmetics are the basic ADD and SUBTRACT instructions. The jumps are the A-JUMP and Q-JUMP instructions. Several other instructions similar to both these types are available in the 1604 instruction repertoire. These will be presented in later chapters. ### ADD (ADDb) (14.b) (where b may be any number 0 through 7) This instruction adds a 48-bit operand to the previous contents of the A register. A storage reference is made to obtain the 48 bit quantity at the location specified by the sum of the execution address and the contents of the designated index register. The operand at this location is then added to the previous contents of the A register. An overflow fault results when the sum of two quantities exceeds the capacity of A. #### SUBTRACT (SUBb) (15.b) (where b may be any number 0 through 7) This instruction subtracts a 48-bit operand from the previous contents of the A register. A storage reference is made to obtain the 48-bit quantity at the location specified by the sum of the execution address and the contents of the designated index register. The operand at this location is then subtracted from the previous contents of the A register. An overflow fault results when the difference of two quantities exceeds the capacity of A. #### A-JUMP (AJPb) (22.b) (where b may be any number 0 through 7) This is the first instruction, to this point, in which the index registers are not used to modify the execution address. In this instruction, the 3-bit index register designator specifies the particular condition of the A register which will cause a jump in the program address. The conditions for the different possible index designations are as follows: #### If Index register designation is: - O Jump will occur if content of A is zero - 1 Jump will occur if content of A is not zero - 2 Jump will occur if content of A is positive - 3 Jump will occur if content of A is negative - 4 Return Jump will occur if content of A is zero - 5 Return Jump will occur if content of A is not zero - 6 Return Jump will occur if content of A is positive - 7 Return Jump will occur if content of A is negative #### Q-JUMP (QJPb) (23.b) (where b may be any number 0 through 7) This is the same as the A-Jump except the jump occurs if the Q register is in a certain condition. The index register designator specifies the condition which will cause the jump. The various index designations with the corresponding conditions are listed below: ## If the Index register designation is: - O Jump occurs if Q register content is zero - 1 Jump occurs if Q register content is not zero - 2 Jump occurs if Q register content is positive - 3 Jump occurs if Q register content is negative - 4 Return Jump occurs if Q register content is zero - 5 Return Jump occurs if Q register content is not zero - 6 Return Jump occurs if Q register content is positive - 7 Return Jump occurs if Q register content is negative Before trying examples of these last four instructions, some of the general characteristics of jump instructions should be considered. A jump instruction causes the termination of a current program sequence and the initiation of a new sequence at a different location in storage. The program address register (P) provides the continuity between program steps. This register always contains the storage location of the program step currently being executed. Normally, the address in this register is increased by one count at the end of each program step in order to indicate to the machine the location of the next step. When a jump instruction is given, the program address register is cleared, and a new address is entered from the jump instruction. In all jump instructions the base execution address specifies the beginning address of the new program sequence. Some of the jump instructions are conditional upon a register containing a specific value or upon the position of an operator key on the console. If the criterion is satisfied, the jump takes place to the location specified by the execution address. If the criterion is not satisfied, the program proceeds in its regular sequential order to the next instruction. A jump instruction may appear in either position in a program step. If the jump instruction appears in the first (upper) part of the program step, and the jump is taken, the second (lower) part of that program step is never executed. If the jump instruction appears in the second (lower) part of the program step, the first (upper) part of that step is executed in the normal manner. Return Jumps are different from normal jumps in that provision is made to "return" to the location following the place where the return jump was initiated. This operation is important in programming since one often wishes to exit from the main program to some routine and then return to continue the main program. In all such situations there must be some way for the computer to "remember" where the Return Jump originated. On the 1604, a return jump begins a new program sequence at the second (lower) part of the program step to which the jump is made; that is, the jump is always to the lower part of the program step specified in the Return Jump instruction. At the same time the base execution address in the upper part of this same program step is replaced with the address of the location of the return jump instruction plus one. This allows the new program sequence to return to the step following the return jump instruction and resume the original program at a later time. FIG. 6 indicates the return jump sequence. FIG. 6 Return Jump Operation The following examples are provided to afford practice on the last four instructions of this Chapter (Add, Subtract, A-Jump, and Q-Jump). (Each student is advised to work out the examples and check the given solutions.) EXAMPLE 8. Assume the initial contents of the A register are 000 00000 021 00600. A programmer wishes to add the contents of storage location 00200 to the contents of A. Show the instruction required if (a) no index register is to be used (b) if index register 3 (which holds 00171) is to be used. (a) (b) Instruction required ADD 0 0 0 2 0 0 required ADD 3 0 0 0 0 7 Explanation: (a) One uses the ADD instruction (code 14.x) with the index designation equal to zero. This adds the contents of the location specified by the execution address (00200) to the A register as the problem required. - (b) If an index register is used the contents of this designated index register is added to the base execution address and this sum specifies the location of the operand which is to be added to the A register. In this case since the sum must be 00200, and since index register 3 contains 00171, it is necessary to make the execution address be 00007. (00007 + 00171 = 00200 .) - EXAMPLE 9. Assume the A register contains 203 00600 060 00400. Assume address 00300 contains 000 00000 020 00300. After the completion of instruction 150 00300 show the contents of (a) the A register (b) storage location 00300. - (a) The given instruction subtracts the contents of 00300 from the initial contents of the A register as shown below: (b) Final contents of 00300 is 000 00000 020 00300. Explanation: (a) The A register is changed during the execution of the instruction since the arithmetic process (subtraction) takes place and the result (the difference) is left there. (b) The subtraction does not change the quantity being subtracted from the A register. Thus the final contents of address 00300 is the same as its initial contents. EXAMPLE 10. A programmer is generating a quantity in the Q register. At program step 00100, he wants to test the contents of Q for two conditions: (1) if the content of Q is zero, he wishes to jump to step 00600, and (2) if the content of Q is negative, he wishes to jump to step 00700. Show the instructions required to do this. Instructions required (00100) QJP 0 0 0 6 0 0 QJP 3 0 0 7 0 0 Explanation: Since he is testing Q, he uses the Q-Jump. In the upper instruction above, Q is tested for zero by placing a zero in the index designator position. If Q contains zero, the jump will go to address 00600. If Q does not contain zero, the lower instruction above will be executed. The lower instruction has a 3 in the index designator position. This causes a jump to address 00700 if the content of Q is negative. If neither condition above is satisfied, instructions of the next step (00101) are executed. EXAMPLE 11. A random number is being generated in the A register. Each time a random negative number is generated, a jump is made to a subroutine starting at subroutine step 00300 and exiting at subroutine step 00304. Upon exit, a return is made to the main program. Assuming the test of the contents of A is made at main program step 01000, show or explain the following: - (a) Test instruction at step 01000. - (b) What happens at sub-routine step 00300? - (c) What happens at sub-routine step 00304? (c) (00304) = Last instruction of sub-routine SLJ 0 00300 Unconditional jump to the starting step of the sub-routine here Explanation: (a) Index designator, 7, in the A-Jump tells the computer there is to be a Return Jump if A content is negative. The jump goes to the lower instruction of the entrance step of the sub-routine. - (b) The Return Jump automatically stores the contents of the "Program Address Register plus one" (01001 in this example) in the execution address portion of the upper instruction of the subroutine entrance step. - (c) The exit step of the subroutine should contain an unconditional jump to the upper instruction of the entrance step. It is important to note at this time that all return jumps on the 1604 are not conditional upon the contents of the A or Q register. An unconditional return jump is available and will be explained in a later chapter. The following exercises are provided for practice on the last four instructions presented in this chapter. Work out the solutions and check your results with those in Appendix A. The following table indicates your approximate progress in learning to program these four instructions. ## Rating Table 3 #### EXERCISES 3. - a. Write an instruction which will add the contents of storage location 00030 to the contents of the A register. - b. Unite program steps which will develop the result "G" in the Λ register, where G = (Λ reg.) (B) (C) + (D) + (E). Λοσυπε B = contents of 00041, C = contents of 00042, D = contents of 00043, and E = contents of 00044. - c. A programmer wishes to jump to address 00050 only if the contents of both A and Q are zero. Can he use the A-Jump and Q-Jump in the same program step? Explain your answer. - d. An address is generated and stored in index register 5. One wants to add the contents of this generated address to the contents of Λ. The Λ register is then tested for zero and if it is not zero, a jump occurs to program step 00105. Unite one program step, of two instructions, which will accomplish this. - e. Explain what will occur if the following instruction is referenced at step 00304 and the contents of the A register are positive. Upper Instruction | Lower Instruction (003C4) = AJP 6 0 0 0 1 0 ## CHAPTER II ## REVIEW TEST The following questions review the twelve instructions presented in this chapter. Write answers in the space provided after each question. Solutions are given in Appendix B. | | All shif | fts on the 1604 are end-off shifts. (True-Fals | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------| | Where does the shifting on the 1604 actually take pl Is it possible to shift 200 (decimal) bit positions one instruction 1604? (Yes or No) The index designator is not significant with the shi instruction. (True-False) If the index designator is 3, you add 3 to the execuaddress before interpreting the instruction. (True-Storage address 00300 contains 0000000000000777. | | | | Is it possible to shift 200 (decimal) bit positions one instruction 1604? (Yes or No) The index designator is not significant with the shi instruction. (True-False) If the index designator is 3, you add 3 to the execuaddress before interpreting the instruction. (True-Storege address 00300 contains 00000000000000777. | | | | The index designator is not significant with the shi instruction. (True-False) If the index designator is 3, you add 3 to the execuseddress before interpreting the instruction. (True-Storege address 00300 contains 0000000000000777. | Where do | es the shifting on the 1604 actually take pla | | Instruction. (True-False) If the index designator is 3, you add 3 to the execuaddress before interpreting the instruction. (True-Storege address 00300 contains 0000000000000777. | - | , , , , , , , , , , , , , , , , , , , | | sign address before interpreting the instruction. (True- | | | | | | | | positions with the QRS.O instruction. (Q Right.) A storing the shifted result of Q back in 00300, show contents of 00300. | programm<br>position<br>storing | er shifts the contents of 00300 right 6 bit<br>s with the QRS.O instruction. (Q Right.) Aft<br>the shifted result of Q back in 00300, show the | | 10. | Using the instructions of this chapter show two methods to transfer the contents of 00050 to the contents of 01000. (Use one program step for each mathod.) | |-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | 11. | Why is there a STORE Q instruction as well as a STORE A instruction when each perform essentially the same function? | | 12. | Index register 4 contains 00006. Address 00100 contains 0000000000000001. Address 00007 contains all zeros. If the LOAD A with index designation 4 is given LDA 4 00072 show the final contents of A below. | | 13. | The instruction "STORE Q" with index designation 6 is given (STQ.6). The execution address portion of the instruction is zero. In other words, the instruction is 21 6 00000 (Code for "STORE Q" is 21.) Where will the contents of Q be stored when this instruction is executed? | | 14. | If an index register is designated in the ADD instruction, the contents of the designated index register are added to the previous contents of the A register. (True-False) | 15. Translate the following flow diagram into 1604 program steps starting with step 00100 below. 16. Translate the following flow diagram into 1604 program steps starting with step 00100 below. (00100) = (00101) = ## CHAPTER III #### SECOND GROUP OF INSTRUCTIONS SECOND INSTRUCTIONS (with Mnemonic and Numeric Codes) (where b represents the index designator and may be 0 through 7). | LONG RIGHT SHIFT<br>LONG LEFT SHIFT | (LRS.b) (03.b) (LLS.b) (07.b) | MULTIPLY INTEGER | (INA.b)(11.b)<br>(MUI.b)(24.b) | |-------------------------------------|----------------------------------|--------------------------------------------------------|--------------------------------| | ENTER A ENTER Q | (ENA.b) (10.b)<br>(ENQ.b) (04.b) | SELECTIVE JUMP | (DVI.b)(25.b)<br>(SLJ.b)(75.b) | | LOAD A, COMP. | (LAC.b) (13.b)<br>(LQC.b) (17.b) | SUBSTITUTE ADDRESS(UPPER)<br>SUBSTITUTE ADDRESS (LOWER | (SAL.b)(61.b) | Of the first six instructions, two are shift instructions and four are transfer instructions. Since basic shift and transfer instructions were given in detail in Chapter II, it is reasonable to assume that these six instructions can be easily learned in one unit. LONG RIGHT SHIFT (LRS.b)(03.b)(where b may be any number 0 through 7) This instruction shifts the contents of the A and Q registers to the right as one 96-bit register. The A register is treated as the leftmost 48 bits and the Q register as the rightmost 48 bits. The number of bit positions to be shifted is specified by the sum of the execution address and the contents of the designated The sign bit of the A register is extended as index register. The lowest order bits of the A register the shift is performed. shift into the highest order bit positions of the Q register as The lowest order bits of the Q register the shift is performed. are discarded as they are shifted out of the right end of the Q register. Shift counts greater than 127 (decimal) are treated as shift faults and produce an indication which may be sensed by the external function instruction. LONG LEFT SHIFT (LLS.b) (07.b) (where b may be 0 through 7) This instruction shifts the contents of A and Q registers circularly end-cround to the left as one 96-bit register. The number of bit positions shifted is specified by the sum of the execution address and the contents of the designated index register. The leftmost bits of the Q register shift into the rightmost bit positions of the A register as the shifting is performed. The bits coming off the left-end of the A register circulate end-around to the rightmost bit positions of the Q registers as the shifting is performed. Shift counts greater than 127 (decimal) are treated as shift faults and produce an indication which may be sensed by the external function instruction. ## ENTER A (ENA.b) (10.b) (where b may be 0 through 7) This instruction enters the sum of the execution address portion of the instruction and the contents of the designated index register into the A register. The A register is cleared first, and the sum of the execution address and content of the designated index register is then entered into the cleared A register as a 15 bit quantity including sign (total 15 bits). The highest order bit (or sign bit) is then duplicated in the remaining (33) higher order bits of the A register. The sketch below in FIG. 7 indicates the process. FIG. 7 Execution of ENTER A instruction # ENTER Q (ENQ.b) (04.b) (where b may be 0 through 7) This is the same as the ENTER A instruction except the Q register is used. The sum of the execution address portion of the instruction and the content of the designated index register is entered into the Q register as a 15 bit quantity including sign (total 15 bits). The highest order bit (sign bit) is then duplicated in the remaining higher order bits of the Q register. FIG. 7 indicates the process except the Q register is used in place of A. # LOAD A, COMP (LAC)(13.b) (where b may be 0 through 7) This instruction replaces the A register contents by the complement of a 48-bit operand whose location is specified by the sum of the execution address and the contents of the designated index register. After the 48-bit operand is located it is complemented and entered into the A register. A zero index designation (no index register is used) results in the 48-bit operand being found at the location specified by the execution address portion of the instruction. # LOAD Q, COMP (LQC) (17.b) (where b may be 0 through 7) This is the same as LOAD A, COMP except the Q register is used. Then the content of the Q register is replaced by the complement of a 48-bit quantity whose location is specified by the sum of the execution address and the contents of the designated index register. A zero index designation (no index register is used) results in the 48-bit operand being found at the location specified by the execution address portion of the instruction. The following examples should facilitate learning the previous six instructions. (Each student is advised to work out the given examples and check the given solutions.) EXAMPLE 12. Assume the A and Q registers contain the quantities given below. A programmer wants to shift both these quantities right 39<sub>10</sub> bit positions as though both made up one 96-bit register. Show the instruction used, and the final contents of A and Q after the shift is performed. Explanation: Since one wants to shift 39 decimal bit positions, this is equivalent to a chift of 13 octal digits (since 3 bit positions equal one octal place). Since the shift is RIGHT (end-off), there are 13 octal digits discarded as they shift off the right end of Q. Also 13 low order octal digits of A go into the high order positions of Q. The sign bits (zeros) in A are extended to make the octal digits in A. EXAMPLE 13. Assume the Q register contains a generated number. The programmer desires to double this number by shifting Q left one bit position. However, if there is a significant bit next to the sign bit, a left shift of one will "overflow" the Q register and change the sign of the number. For example, if 01101110111 > 1 is contained in Q, a shift of one left would give 1101110111 \( \rightarrow 10\), which has changed the sign from plus to minus by the "overflow". In order to eliminate this possibility, he decides to shift A and Q as one register. Show the instructions required. (Hint: the A register must be filled with bits all of which are the same as the sign bit of the initial contents of Q.) #### (00203) = Continue program Explanation: The first instruction tests the contents of Q for plus or minus. If plus, jump to (00202), where zeros are entered into A by 10 0 00000 and then A and Q are shifted left by 1 as though they made up one 96-bit register. If the jump at 00200 did not occur, then Q is negative and all ones are entered into A by 10 0 77777, and the AQ shift then takes place. (There are several alternative approaches which can be used to do the above.) EXAMPLE 14. A count has been generated in index register 3. The progresser wants to know if this count is equal to the amount in the Q register. Show instructions which could be used. Explanation: The contents of Q are first stored at some address (in this case 00100). Then the "EITHER A" instruction with index designation 3 and emocration address 00000, places in A, the contents of index register 3 plus the quantity shown in the execution address. (Contents of index reg. 3+ 00000 = contents of index register 3.) In the next step, the contents of 00100 (which now equal contents of Q) are subtracted from A (which now equals the contents of index reg. 3). The last instruction jumps to same address if the result of the subtraction is zero. If the jump occurs, one knows the contents of Q and index register 3 are equivalent. (Alternative solutions are possible here.) EXAMPLE 15. Assume one wants to load the absolute magnitude of the quantity located at address 00030 into the A and Q registers. Show the instructions required. Hint: a test must first be made of the quantity in 00030 to see if it is positive or negative. If negative, it must be complemented before loading it into A and Q. Explanation: After the test for sign, a jump to 00045 occurs if the contents of 00030 are negative, and the contents of 00030 are complemented and loaded into A and Q. If jump does not occur then the contents of 00030 (already in A) are positive and need only be loaded into Q. (Alternative solutions are possible.) The following exercises are provided for practice on the first six instructions of this chapter. Work out the given problems and check your answers with the solutions given in Appendix A. The number of correct answers will indicate your approximate progress by checking the Rating Table below: # Rating Table 4 #### EXERCISES 4 - a. Assume Q contains a positive 3, and A contains negative 7. As one 96-bit register shift A and Q right 4 bit positions. Show the instruction and the final contents of A and Q. - b. Assume Q contains all ones and A contains all zeros. As one 96-bit register shift A and Q left 24<sub>10</sub> bit positions. Show the instruction and the final contents of A and Q. - c. Assume index register 5 contains 01326. Assume storage address 01111 contains 000000000007562. Show the final contents of register A after completion of each of the following instructions. (ENA.5) 1 1 0 5 0 0 0 0 0 (Both instructions contain the "ENA.5) "ENTER A" code) (ENA.5) (2) 105 00100 - d. Mark the following True or False. - 1. The same instruction cannot shift A and Q in two different directions. - 2. Usually a left shift of both A and Q of one bit position is equivalent to multiplying the 96 bits in AQ by 2. - 3. EMTER A and LOAD A instructions will do the same thing if the same execution addresses and index designators are used in each instruction. - 4. LOAD Q COMP instruction will always load Q with a positive quantity. - Assume register 00200 contains 000000000007777. Show the final contents of Q after each of the following instructions: e. - 04000200 - (Enter Q code) (Load Q COMP code) 17000200 2 - 16000200 (Load Q code) The last six instructions of this chapter are probably best learned by dividing them into two groups. The first group contains three arithmetic instructions to be added to the ADD and SUBTRACT instructions of the last chapter. INCREASE A(IIIA.b) (11.b) (b may be 0 through 7) This instruction cold to A the cum of the contents of the designated index register and the execution address itself. The execution address is treated as a 15-bit quantity including sign (15 bits total). The addition is performed as if the execution address were a 48-bit quantity with the higher order bits copies of the sign bit. If everflows occur, the condition may be sensed by the external function instruction. The following sketch illustrates this instruction. See FIG. 8 FIG. 8 Execution of Increase A Instruction # MULTIPLY INTEGER (MUI.b) (24.b) (b may be 0 through 7) This instruction forms a 96-bit product from two 48-bit operands. The multiplier must be loaded into the A register prior to the execution of this instruction. The sum of the contents of the designated index register and the execution address specifies the location of the multiplicand. The resulting product is contained in the QA register as a 96-bit quantity where least significant bits are in A. FIG. 9 indicates the execution of this instruction. (a) If no index register is used (b) If index register is used Assume Index Register 5 = 00022 Assume (00100) = 0 < > 07Assume (00122) = 0 < > 012 Assume (A) = Instruction 0 ← > 03 2 4 5 0 0 1 0 0 Assume (A) = 0000000000000003 Assume (00100) = 0000000000000007 (MUI.0) (code for multiply) Instruction $\rightarrow$ 2 4 0 0 0 1 0 0 Multiplicand is found in 00100. Product is 3 x 7 = $21_{10}$ = $25_{8}$ Final contents of Q Register A Register 0 > 0 0 > 025 Sign of Product Multiplicand is found in 00122 (since 00100 + 00022 = 00122.) Product is 3 x 12 (octal) = 36 octal 96-Bit Product 96-Bit Product FIG. 9 The Multiply Integer Instruction ## DIVIDE INTEGER (DVI.b)(25.b)(b may be 0 through 7) This instruction divides a 96-bit integer dividend by a 48-bit integer divisor. The 96-bit dividend must be formed in the QA register, with the least significant bits in A, prior to the execution of this instruction. The 48-bit divisor is read from the storage location specified by the sum of the designated index register contents and the execution address. The quotient is formed in the A register. The remainder is left in the Q register at the end of the operation. The remainder and the initial dividend will have the same algebraic sign. The following examples are provided to afford better understanding of the three instructions previously defined. EXAMPLE 16. Each time a program reaches step 00050, the A register is to be increased by the amount in index register 2, and the sum is to be stored in storage address 00400. Show this program step. Explanation: The first instruction increases the contents of the A register by the sum of the contents of the designated index register (2 in this case) and the amount specified in the execution address. Since the amount in execution address is zero, the A register is increased by the contents of index register 2. The second instruction stores A in storage address 00400. ### EXAMPLE 17. Assume (A) = 00000000000011 Assume (00025) = 000000000000047 After the following instruction (MULTIPLY) is executed, show the final contents of $\Lambda$ , Q, and storage address 00025. (MUI.0) Instruction 240 00025 Contents of 00025 (multiplicand) is multiplied by contents of A (multiplier) and the 96-bit product is developed in the Q and A registers as thour. Storage address (00025) will still contain $0 \leftarrow > 047$ after completion of the multiply. Explanation: (See description above) EXAMPLE 18. One wishes to divide 2<sup>49</sup> by 15. Show the steps required. Assume high order bits of 2<sup>49</sup> are in storage address 00010 and 15 is in storage address 00011. The first instruction loads 000000000000000 into Q. The second instruction loads zeros into A. The third instruction divides by 15 in address 00011. After the divide the quotient will be in A and the remainder will be in Q. The following exercises are provided for practice on the three instructions just described. Solve the given problems and check your answers with the solutions presented in Appendix A. The number of correct answers will indicate your approximate progress by checking the Rating Table below: # Rating Table 5 #### EXERCISES 5. - a. Assume index register 6 contains 00017 and the Λ register contains 7777777777777770135. The following "INCREASE A" instruction is given (11 6 00761). Show the contents of the Λ register after execution of this instruction. - b. One wants to multiply the contents of storage location 00050 (the multiplicand) by the contents of index register 2 (the multiplier). Show the program step required to do this. - c. Mark the following as True or False: - 1. The multiply does not affect the magnitude of the multiplier in A. In other words, the multiplier has the same value after the multiply has been executed. - 2. Before the multiply instruction is referenced, it is necessary to LOAD the multiplier into the A register with a previous instruction. - 3. The product of two 48-bit quantities may "overflow" the 96-bit product possible in the QA register. - d. Assume the Q register contains 000000000000000. The A register contains 00000000000000. Assume storage location 00100 contains 0000000000000. The DIVIDE instruction 25 0 00100 is given. Show the final contents of the A register, the Q register, and storage location 00100. Resulted 5 med 1 cells 100 infraued. e. Show program step which will "INCREASE A" by the contents of index registers 2 and the contents of the storage location whose address is given by the contents of index register 5. The last three instructions to be described in this chapter include one instruction which is a SELECTIVE JUMP and can be used as the basis for an "unconditional jump". The other two are useful in modifying or substituting new execution addresses in the lower or upper instructions of a program step. SELECTIVE JUMP (SLJ.b)(75.b)(where b may be 0 through 7) This instruction causes a jump determined by specific settings of operator keys on the console of the computer. These keys are "selected" before the program starts and determine whether or not the jump will occur when the program reaches the location of the SELECTIVE JUMP instruction. The index register designator specifies which jump key is set. Thus, on this instruction, the index registers are not used. The following index designations indicate the following conditions: | Index Designation | Condition | |----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0<br>1<br>2<br>3<br>4<br>5 | Jump Unconditionally (no key setting) Jump if jump key 1 is set Jump if jump key 2 is set Jump if jump key 3 is set Return Jump unconditionally (no key setting) Return Jump if jump key 1 is set Return Jump if jump key 2 is set Return Jump if jump key 3 is set Return Jump if jump key 3 is set | SUBSTITUTE ADDRESS (UPPER) (SAU.b)(60.b)(where b may be 0 through 7) This instruction replaces the execution address portion of the left or upper instruction of a word, whose location is specified by the sum of the execution address and the contents of the designated index register, by the lowest order, 15 bits of the A register contents. The remaining bits of the designated word in storage are not modified by this operation. This instruction effectively inserts an address in the first instruction at the designated storage location. FIG. 10 indicates the process. Final Contents of 00037 FIG. 10 The Substitute Upper Instruction SUBSTITUTE ADDRESS (LOWER) (SAL.b) (61.b) (where b may be 0 through 7) This instruction performs the same as SUBSTITUTE ADDRESS (UPPER) see FIG. 10, except the instruction inserts an address in the lower instruction of the word whose location is specified by the sum of the execution address and the contents of the designated index register. The following examples should facilitate learning these three last instructions of this chapter. (Each student is advised to work out the given examples and check the given solutions.) EXAMPLE 19. When a certain program reaches step 00046 the first time, the program jumps to location 00200 where an output routine using magnetic tape is processed. The second time the program is run and location 00046 is reached, the program wants to go on in sequence with 00047 which is an output routine on punched cards. Show the instruction at 00046 and explain how it would take care of these conditions. Required $Some\ other$ Instruction (00046) = $SLJ\ 1\ 0\ 0\ 2\ 0\ 0$ instruction Explanation: The instruction is the SELECTIVE JUMP with index designation 1. The first time, Jump Key 1 on the console would be set and the program would jump to the output routine using magnetic tape. If the second time, Jump Key 1 was not set on the console, and the program would continue with the step at 00047. EXAMPLE 20. At location 00600, on the left side, is a "dummy" ENTER Q instruction. This dummy instruction is ENQ 0 xxxxx. Before the computer reaches this location, the program will enter an amount for the xxxxx of this instruction. Assume the amount to be entered is being generated in storage location 00300. At step 00577, the substitution is to take place. Show program step 00577. Required Program Step (00577) = LDA 0 0 0 3 0 0 SAU 0 0 0 6 0 0 Explanation: The first instruction above LOADS A with the contents of register 00300. Thus A now contains 000000000000ssss (where sssss is some quantity). The second instruction tells the machine to SUBSTITUTE INTO THE LEFT INSTRUCTION OF 00600 the 15 low order bits of A. Thus sssss goes into the positions held by xxxxx and the left instruction at 00600 becomes (00600) = ENQ 0 sssss Some Other Instruction EXAMPLE 21. Storage location 00040 contains two generated instructions. Interchange the execution address portions of each of these instructions. Show program steps starting with 00100 which will do this. | (00100) | LDA O | 00040 | SAU 0 | 00040 | |---------|-------|-------|-------|-------| | | | | | | | (00101) | ARS 0 | 00030 | SAL 0 | 00040 | Explanation: LOAD contents of 00040 into A. Substitute low order 15 bits in A (execution address of lower instruction) into upper instruction execution address. Then shift original content of 00040 (which is still in A) right 2410 bit-positions. Then substitute 15 low order bits of A (now the execution address of original left instruction) into right instruction execution address. This completes the interchange. The following exercises are provided to afford practice on the last three instructions of this chapter. Work out the solutions and check results with those in appendix A. The following table indicates your approximate progress in learning to program these three instructions. ## Rating Table 6 If you have 4 or 5 correct answers . . . . . Excellent If you have 3 correct answers . . . . . . . . . Good If you have less than 3 correct answers . . . . Review ### EXERCISES 6. - a. At location 00020, it is desired to jump to a subroutine starting at step 00072. This subroutine exits at 00105 back to the main program, continuing at 00021. Show the Return Jump at 00020, the first instruction at 00072 and the exit instruction at 00105. - b. Assume 00022 contains 1 2 3 0 0 1 0 0 0 6 4 0 0 2 0 0. Assume 00023 contains 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1. Show the steps, starting at 00112 which will modify (00022) to 1 2 3 0 0 0 0 1 0 6 4 0 1 0 0 0 using only the given locations above along with A and O. - c. Assume index register 5 contains a generated number. If this number is positive, store it in the last 5 octal digit positions of location 00047 and then jump to step 00700 if jump Key 2 is set. If it is negative add to it the contents of address 00100 and jump to step 00700. (Start steps at location 00417.) - d. Increase the contents of address 00003 by the contents of index register 3 and if Jump Key 3 is set on the console, jump to program step 30. Write the program steps to do this starting at location 00050. - e. Study the following sketch. 00200 Steps between points R and T perform TASK G. Steps between points T and Y perform TASK H. A programmer wishes to be able to do the following at different times. - 1. Do TASK G and TASK H - 2. Skip TASK G, Do TASK H - 3. Do TASK G, Skip TASK H - 4. Skip both TASKS Write two instructions, one at Point R and one at Point T which will enable all four of these to be done at different times in a program. ### CHAPTER III #### REVIEW TEST The following questions review the twelve instructions presented in this chapter. Write answers in the space provided after each question. Solutions are given in Appendix B. | 1. | The AQ register is really two separate registers. A and Q are treated as one register on certain instructions (True-Ealse) | |----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2. | The fact that chifts greater than 127 <sub>10</sub> are treated as shift faults, stops one from shifting the AQ register the equivalent of 200 <sub>10</sub> positions. (True-False) | | 3. | The "ENTER A" and "ENTER Q" instructions always lead to 15 bits being entered into A or Q and the generation of 33 other sign bits which correspond to the left most bit of the 15 bits which are entered. (True-False) | | 4. | Assume index register 3 contains 77777. If "ENTER A" instruction 1 0 3 0 0 0 0 1 is given, what quantity will be entered into the A register? | | 5 | Assume legation (0100 contains 000000000000000000000000000000000000 | - Assume location 00100 contains 000000000000003. Show the contents of the Q register after the LOAD Q COMP instruction (LQC. 0) - 6. One wants to increase the contents of the A register by the amount contained in index register 4. Show an instruction which will do this. - 7. Is there any difference in the final result between "INCREASE A" and "ADD" instructions if the execution address portions are each zero and the same index designation is used in each. In other words, is INA 2 0 0 0 0 the same as ADD 2 0 0 0 0? (Yes or No) 8. Where is the multiplier located when the "Integer Multiply" instruction is executed? Where is the multiplicand. Where is the product after the execution of the instruction? | (Multiplier) | | |----------------------------------------|----------------------------------------| | • | ************************************** | | (Multiplicand) | | | (Froduct) | | | \" " " " " " " " " " " " " " " " " " " | | - 9. If the dividend is 5 and the divisor is -3, what will the following registers contain after the DIVIDE INTEGER instruction is executed? - A Register Q Register - 10. Show program steps which will accomplish the following flow diagram. (Start with stop 00300.) - 11. Write program steps starting with step 00200 which will divide the sum of the A and Q register contents by the difference obtained by subtracting the contents of Q from the contents of A. - 12. An approximation to the function G can be found by the formula: $$G = 1 - \frac{X}{2}$$ Assume X is a whole number stored in index register 3. Write program steps starting with step 00100 which will compute G and store it in storage location 00077. #### CHAPTER IV ## THIRD GROUP OF INSTRUCTIONS THIRD INSTRUCTIONS (with Mnemonic and Numeric Codes) (where b refers to index register designation). | STORAGE SKIP | (SSK.b)(36.b) | ENTER INDEX | (EIII.b)(50.b) | |------------------|---------------|-------------------|----------------| | STORAGE SHIFT | (SSH.b)(37.b) | PASS | (EUI.0)(50.0) | | INDEX SKIP | (ICK.b)(54.b) | INCREASE INDEX | (五江.b)(51.b) | | INDEK JUMP | (IJP.b)(55.b) | LOAD INDEX UPPER | (LIU.b)(52.b) | | LOAD LOGICAL | (101.b)(44.b) | LOAD INDEX LOUIR | (LIL.b)(53.b) | | ADD LOGICAL | (ADL.b)(45.b) | STORE INDEX UPPER | (SIU.b)(56.b) | | SUBTRACT LOGICAL | (EBL.b)(46.b) | Store index lower | (SIL.b)(57.b) | | SIONM LOGICAL | (STL.b)(47.b) | | | The third group of instructions are fifteen in number. These are probably best learned by dividing them into groups containing four, four, and seven instructions, respectively. The first three instructions are similar in that they may be thought of as "two address" jumps. These are limited to use in the first position of a program step. The second position in the program step is normally occupied by an unconditional jump instruction. This pair of instructions then operates as a two address jump instruction. The first address of the storage skip and storage shift instructions in this program step specifies the storage location of the operand required in the jump decision. The second address specifies the destination of the jump if taken. Other combinations will be obvious to the programmer as he learns the instructions. STORAGE SKIP (SSK.b)(36.b) (where b may be 0 through 7) (1) This instruction senses the sign bit of the quantity in the location designated by the sum of the execution address and the contents of the designated index register. If the designated quantity is negative, the next instruction is skipped. If the designated quantity is positive, the next instruction is executed. FIG. 11 indicates the process. (h) | No Index Register is Essignated | If Indox Register 2 is Essignated | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------| | Assume 00100 contains 0—— 01157 Assume following program step | Let index reg. 2 contain 00000<br>Let storage location 00007 compain<br>77012<br>Assume following program stop | | (00040) 36 0 00100 75 0 00052 Cremend at 00100 (0+00100=00100) is positive. The next instruction (75 0 00052) is executed. This is an unconditional jump to step 00062. | (60040) 36 2 00003 75 0 05000. Cperand at 60037 (60005:00 50037) is negative. The next instruction is skipped and program continues at (00041). | FIG. 11 One use of Two-Address Jump It is important to note that the second position need not be an unconditional jump. Thus if a single instruction is to be executed, or not executed, as a result of the sensing operation, then such an instruction may be used in the second position with the sensing instruction in the first position. Examples following these descriptions indicate these possibilities. # STORAGE SHIFT (SSH.b)(37.b) (b may be 0 through 7) This instruction senses the sign bit of the quantity in the storage location specified by the sum of the execution address and the contents of the designated index register. If the designated quantity is negative, the next instruction is skipped. If the designated quantity is positive, the next instruction is executed. In either case the quantity in storage is shifted circularly, end-around, left one bit position. The initial contents of A and Q are not disturbed by this shifting process. # INDEX SKIP (ISK.b)(54.b) (where b may be 0 through 7) This instruction compares the quantity in the designated index register with the base execution address. If the two are equal, then the designated index register is cleared and the next instruction in the program is skipped. If the quantity in the designated index register is not equal to the base execution address, then the quantity in the index register is increased one count and the next instruction in the program is executed. The flow diagram in FIG. 12 indicates the process. (Note the special situation when the designated index register is zero.) Index Skip Instruction \*\*It is important to remember that the two-way sensing instructions occupy the first position (upper instruction) in the program step. In case they are used in the second position (Lower instruction) the skip will not take place which provides the two-way possibilities. The fourth and last instruction in this group is the INDEX JUMP. It is similar to the INDEX SKIP instruction just described. INDEX JUMP (IJP.b)(55.b) (where b may be 0 through 7) This instruction examines the quantity in the designated index register. If this quantity is not zero, it is reduced by one count and a jump is executed to the base execution address. If this quantity is zero, then the jump is not executed and the present program sequence is continued. (Note in this instruction an index designation of zero would have little use unless it was changed during the program. A zero designation would simply have the same effect as if the contents of the index register were zero.) The following examples should facilitate learning the previous four instructions. (Each student is advised to work out the given examples and to check the given solutions.) EXAMPLE 22. A quantity is generated in storage location 00023. If this quantity is positive, jump to program step 00077. If negative, the program is to continue in sequence. Show a program step which will do this. (Use location 00100 for program step.) (00101) = Continue Program Explanation: The first instruction checks the sign of the operand at the location specified by the sum of the designated index register (0) and the execution address (00023). If this operand (at 00023) is positive, the next instruction (750 00077) is executed, which is an unconditional jump to step 00077. If the operand (at 00023) is negative, the jump instruction (750 00077) is skipped and the program continues in sequence at step 00101. EXAMPLE 23. If the quantity contained at storage location 00200 is positive, it is desired to add it to the contents of the A register and continue in sequence. If it is negative, it is desired to continue in sequence to step 00031. Write program step 00030 which will do this $$(00030) = SSK 0 0 0 2 0 0 ADD 0 0 0 2 0 0$$ (00031) = Continue Program Explanation: The first instruction does a "STORAGE SKIP" on contents of storage location 00200 (specified by sum of execution address and contents of designated index register). If contents of 00200 are positive, the next instruction (140 00200) will ADD the contents of 00200 to the A register and continue to (00031). If the contents of 00200 are negative, the ADD instruction is skipped and the program continues. (Note: This is an example showing the use of a "possible two-address jump" without using an unconditional jump following the sensing instruction.) EXAMPLE 24. Assume storage location 01000 contains 25 25 25 25 25 25 25 25 (octal). At step 00300 in a program it is desired to use the "STORAGE SHIFT" instruction with index designation zero and execution address 01000. (See below) The program reference step 00300 several times. Explain what will happen in terms of the jumps shown. ## Answer and Explanation: Each time the Storage Shift instruction is executed, the contents of 01000 will shift left one bit position. Since 01000 contains alternate zeros and ones (in bits), the following will take place: First time: The jump to 00600 will occur Second time: Instruction C and jump to 00400 will occur (Succeeding times: Repeat the above in same order) EXAMPLE 25. Assume index register 6 contains all zeros (00000 in octal). A programmer wants to use this index register as the counter (K) indicated below in the flow chart. Show the program step for dotted area below | Program | | | | | | | | | | | | | | | |-----------------|-----|---|---|---|---|---|---|-----|---|---|---|---|---|---| | Step Required - | LSK | 6 | 0 | 0 | 0 | 3 | 1 | SLJ | 0 | 0 | 0 | 1 | 0 | 0 | ### Continue steps in sequence Explanation: The first instruction is the "INDEX SKIP". This compares the contents of the designated index register (6) with the execution address amount (in this case $25_{10} = 31_8$ ). If not equal, the contents of index register 6 are increased by 1 and the next instruction, 7 5 0 0 0 1 0 0, (Unconditional jump to 00100) takes place. Each time the program loops through here the same sequence of events takes place until the contents of index register 6 equals $25_{10}$ and then the jump instruction is skipped and the program continues in sequence. (See Example 47 for another instance of index skip.) EXAMPLE 26. Assume index register 3 contains 00007. A program contains a loop which involves a jump to location 00112 seven times during the program. The eighth time the program is to continue in sequence. Show a program step at (00061) which will provide the looping. (use INDEX JUMP instruction.) | (00061) | = | IJP 3 0 0 1 1 2 | Continue Progrem | |---------|---|-----------------|------------------| Explanation: Caly one instruction is required. The INDEX JUMP above checks the contents of index register 3 for zero. If not zero, it reduces the contents by one and jumps to the step specified in the execution address portion (00112 in this case). This continues 7 times until index register contents are reduced to zero. At this time (eighth time) the jump is not taken but the next instruction is executed. The following exercises are provided for practice on the first four instructions of this chapter. Work out the given problems and check your solutions with those given in Appendix A. The number of correct answers will indicate your approximate progress by checking the Rating Table below: ## Rating Table 7 | If | you | have 4 | correct answers | Excellent | |----|-----|--------|--------------------|-----------------| | Ιf | you | have 3 | correct answers | Good | | Ιf | you | have 2 | correct answers | Fair | | Ιf | you | have 0 | -1 correct answers | Complete Review | ## EXERCISE 7 - a. When program step 00032 is reached, the contents of storage location 09050 are to be tested for sign. If positive, the jump is to go to step 00110. If negative, a jump is to be made to 00200. Using the STORAGE SKIP instruction, show program step 00032. - b. Explain what happens if a conditional jump with jump key 2 not set, follows the STORAGE SKIP instruction as shown below: | Storage Skip | | | | | | | Conditional Jump | | | | | | ) | | |--------------|-----|---|---|---|---|---|------------------|-----|---|---|---|---|---|---| | (00052) = | SSK | 0 | 0 | 0 | 1 | 0 | 0 | SLJ | 2 | 0 | 0 | 2 | 0 | 0 | - c. In storage location 00040 there is an octal digit (0 through 7). The programmer wants to determine if the digit is odd or even by use of the STORAGE SHIFT instruction. Write program steps that would do this. (Hint: First shift the right-most bit of the octal digit to the left-most bit position and then use the STORAGE SHIFT instruction.) - d. In a certain program, if the contents of index register 5 equal the number 100<sub>10</sub>, the program jumps to step 00200. If the contents of index register 5 do not equal 100<sub>10</sub>, the program jumps to step 00050. Write instructions which will do this, using the INDEX SKIP instruction. The second four instructions of this chapter include those instructions known as "logical instructions". These are the instructions generally used in programming situations that extract or mask portions of words. LOAD LOGICAL (LDL.b)(44.b)(where b may be 0 through 7) This instruction loads the A register with the bit-by-bit logical product of the Q register contents and the quantity in storage located by the sum of the execution address and the contents of the designated index register. This logical product utilizes the following rules: 1 X 0 = 0 0 X 1 = 0 0 X 0 = 0 1 X 1 = 1 ADD LOGICAL (ADL.b)(45.b)(where b may be 0 through 7) This instruction adds to the contents of the A register, the logical product of the Q register contents and the quantity in storage whose location is given by the sum of the execution address and the contents of the designated index register. This a normal add for the selected bits of the operand, the non-selected bits of the operand being interpreted as zeros. SUBTRACT LOGICAL (SBL.b)(46.b)(where b may be 0 through 7) This instruction subtracts from the contents of the A register the logical product of the Q register contents and the quantity in storage whose location is specified by the sum of the execution address and the contents of the designated index register. This is a normal subtraction for the celected bits of the operand, the non-selected bits of the operand interpreted as zeros. STORE LOGICAL (STL.b)(47.b)(where b may be 0 through 7) This instruction stores the logical product of the A register and Q register contents at the storage location which specified by the sum of the execution address and the contents of the designated index register. Neither the A nor the Q register initial contents are modified by this instruction. It is important to note that in the first three instructions, involving the logical products, the "extractor" can be placed in either the Q register or in the operand at the specified storage location. In the STORE LOGICAL instruction, the "extractor" may be either in the Q register or the A register. The following examples should facilitate learning the previous four instructions. (Each student is advised to work out the given examples and to check the given solutions.) EXAMPLE 27. It is desired to examine the right-most nine bits of the contents of storage location 00017. The extractor is placed into Q and the LOAD LOGICAL instruction is executed. Show the instruction, the contents of Q, and the contents of the A register after the execution of the instruction. This loads A with logical product of Q and contents of 00017 Explanation: The logical product of contents of Q and contents of 00017 will give the right nine bits of the contents of 00017. These nine bits (which make 3 octal digits) are loaded into the A register. EXAMPLE 28. Storage location 00100 contains eight six-bit codes. Each code designates the number of times the Q register contents are to be shifted. The A register contains the "dummy" SHIFT Q LEFT instruction as the lower, and an unconditional jump to 00200 as the upper instruction. (7 5 0 0 0 2 0 0 0 6 0 0 0 0 0 0). It is desired to pick off the right six-bit code in address 00100, add this code to the dummy shift in A, and send the result to some other step in sequence. Show the program steps to do this, starting with step 00010. (Nint: save the initial contents of Q while using Q to extract six bits from 00100.) | | | | \ | |---------|-----|---------------------------------------------------|--------------------------------------------------------------------------------------------| | A | = | SLJ 0 00200 | ALS 0 00000 | | | | Store Q in 00050 | Load Q with Extractor | | (00010) | = [ | STO 0 0 0 0 5 0 Add Logical Produ to Dummy in A | LDQ 0 0 0 0 6 2 ct Shift A Left 24 <sub>10</sub> bit positions to put Dummy in left part. | | (00011) | = [ | ADL 0 0 0 1 0 0 Store Dummy at Step 00013 | ALS 0 0 0 0 3 0 Reload 0 with saved initial contents | | (00012) | = [ | STA 0 0 0 0 1 3 | LDQ 0 0 0 5 0 | | | | | Unconditional Jump | | (00013) | = [ | ALS 0 0 0 X X | SLJ 0 00200 | Find anation: Q is first saved. Then the extractor is loaded into Q. Fintractor here is in 00062 and should equal 00000000000077). The third instruction adds the right six code-bits of (00100) to the dummy shift instruction in A. This is then shifted left $24_{10}$ positions to put the instruction on the upper portion of the word. The word is then sent to step 00013. The Q register is re-loaded with its initial contents. EXAMPLE 29. Assume storage location 00055 contains 000000000000 X X X (where X, X, X, are generated octal digits). It is desired to store 0000000000000 X X 20 in storage location 00056. Show the program steps, starting at 00477 which will do this. (Assume extractor is in 00100 and show this extractor.) Load Q with Extractor Load A with contents of 00055 (X X X) 1 2 3 | (00477) = | | <b>A</b> 0 | 0 0 | 0 5 5 | |-----------|-------------------------------------------|------------|-----|----------------| | | Subtract Logical Product from X X X 1 2 3 | | | Store in 00056 | | (00500) = | SEL 0 0 0 0 5 5 ST. | A O | 0 0 | 0 566 | where extractor in storage location 00100 is 000000000000007 Explanation: The extractor, which will pick off X, is loaded into the Q register. The quantity X, X, X is then loaded into the A register. At step 00500, the SUBTRACT LOGICAL instruction subtracts from A (X1X2X3) the logical product (X1) which results from the logical multiply of the contents of 00055 by the extractor in Q. This leaves X X 0 in A and this is stored in storage location 00056. EXAMPLE 30. Assume A contains 16 octal digits which are unknown to the programmer. It is desired to pick off the left-most octal digit and store it at location 00312. Show how this can be done with the STORE LOGICAL instruction. (Hint: first load Q with the correct extractor - show this extractor.) | | Load Q with<br>Extractor | Store Logical Product of A and Q at 00312 | |-----|--------------------------|-------------------------------------------| | (c) | LDQ 0 0 0 0 1 4 | STL 0 0 0 3 1 2 | where extractor at 00014 is 700000000000000 Explanation: Since the left-most digit is desired, the extractor contains three one bits (octal 7) in the left-most octal position. This extractor is first placed in Q. The STORE LOGICAL instruction then stores the logical product of the 16 octal digits in A and the extractor in Q at location 00312. At the end of the operation, 00312 will contain X000000000000000, where X is the left-most octal digit. If this is desired to be in the far right position, the appropriate shift must be executed. What shift would be needed? The following exercises are provided for practice on the previous four instruction of this chapter. Work out the given problems and check your solutions with those presented in Appendix A. The number of correct answers will indicate your approximate progress by checking the Rating Table below: ### Rating Table 8 | If you have 4 correct answers | Excellent | |--------------------------------------|-----------------| | If you have 3 correct answers | Good | | If you have 2 correct answers | Fair | | If you have 0 or 1 correct answers . | Complete Review | #### EXERCISES 8 - a. Storage location 01012 contains eight 6-bit characters as shown: (01012) K K K K K K K K K 1 2 3 4 5 6 7 8 The left most bit of each character contains parity data. If there is a 1 in any one of these eight positions, the whole word is to be cleared. Write program steps which will make the test and clear out the word if necessary. Show any extractors used. - b. At program step 00111 the following ADD LOGICAL and STORE A instructions are given as shown. Assuming the A register contains 12000000000000, the Q register contains 007000000000000, and index register 3 contains 00111, show the final contents of the A register after completing step 00111. - c. Write program steps which will reduce the quantity in storage location 00712 by the sum of the left-most and right-most octal digits of that quantity. - d. Answer the following questions: - 1. Can a logical product equal the extractor? - 2. Can a logical product exceed in magnitude both of the factors? Explain. - If the content of either A or O is positive, is it possible for the LOGICAL STORE instruction to store a negative quantity? Explain. The last seven instructions in this chapter are held together by a common bond. Each deals with an index register in some relationship. For this reason, these instructions can probably be learned as a group. # ENTER INDEX (ENI.b) (50.b) (where b may be 1 through 7) This instruction replaces the contents of the designated index register with the value of the base execution address. No storage reference is made in this instruction. Thus if index register 3 contains 00007 and instruction "5 0 3 0 1 1 1 1" is given, then 01111 will replace 00007 in index register 3. (Note: in this instruction "b" cannot be zero - it has a special meaning when used in this particular instruction - see below.) ### PASS (Do Nothing) (ENI.0) (50.0) This is a special code of the last instruction. When 5 0 0 is used as the first 3 octal digits in an instruction the machine knows that this portion of the step is not used - that is, it is to be passed by. The program thus proceeds to the next instruction. This PASS can be used in either half of a program step. ## INCREASE INDEX(INI.b)(5Lb)(where b may be 0 through 7) This instruction adds the value of the base execution address to the contents of the designated index register. (A zero index designation has little meaning here but if used the contents of the index register are considered to be zero by the computer.) # LOAD INDEX(UPPER)(LIU.b) (52.b)(where b may be 0 through 7) This instruction replaces the contents of the designated index register with the upper address of the word in the storage whose location is given by the base execution address. This instruction thus extracts the address from the upper instruction of a word at a designated storage location and enters this value into a particular index register. A zero index register designation has no meaning here and should not be used. If used, the machine uses up some time in referencing storage and then continues with the next instruction. This is not a fault. ### LOAD INDEX (lower) (LIL.b) (53.b) (b may be 1 through 7) This is similar to the previous instruction except the contents of the designated index register is replaced by the lower address of the word in the storage whose location is given by the base execution address. A zero index register designation has no meaning and should not be used. If used, it will skip to the next instruction but time is wasted by the machine making storage references involved. No fault will occur. # STORE INDEX (upper) (SIU.b) (56.b) (b may be 0 through 7) This instruction stores the contents of the designated index register in the address portion of the upper instruction of the word whose location is given by the base execution address. The other bits at the specified storage location are not modified. A zero index register designation has no meaning, but if used, zeros are inserted in the address portion of the upper instruction of the word whose location is specified by the base execution address and the other bits are not modified by the insertion. # STORE INDEX (lower) (SIL.b) (57.b) (where b may be 0 through 7) This instruction is similar to the previous instruction except the contents of the designated index register are stored in the address portion of the lower instruction of the word whose location is specified by the base execution address. A zero index register designation has little meaning, but if used, zeros are inserted into the address portion of the lower instruction of the word whose location is specified by the base execution address. Regardless, the other bits at the specified storage location are not modified by the insertion. The following examples should facilitate learning the previous seven instructions (six and the PASS code). Each student is advised to work out the given examples and to check the given solutions. EXAMPLE 31. At step 00021 the programmer wants to clear index registers 1 and 2. Show the program step with the necessary instructions. (00021) = ENI 1 0 0 0 0 0 ENI 2 0 0 0 0 0 Explanation: Each instruction is the ENTER INDEX. The value in each execution address portion of each instruction is entered into the designated index register. Since the value is zero in each case, index registers 1 and 2 will contain zeros after the above step is performed. EXAMPLE 32. At program step 00172, it is desired to increase the quantity in index register 5 by $10_{10}$ and decrease the quantity in index register 2 by $10_{10}$ . Show program step 00172, (00172) = INI 5 0 0 0 1 2 INI 2 7 7 7 6 5 Explanation: Two INCREASE INDEX instructions are required. The first instruction adds $10_1$ (which is 00012 in octal) to the contents of index register 5. The second instruction adds negative $10_{10}$ (which is 77765 in octal) to the contents of index register 2. The addition of negative $10_{10}$ is the equivalent of subtracting a positive $10_{10}$ . EXAMPLE 33. Write program steps for the following flow diagram (Start at step 00100) Explanation: After the test on the contents of A, the"LOAD INDEX (upper)" or the "LOAD INDEX (lower)" instructions place the address portions of the instructions of 01101 in the respective index registers. Note the use of the PASS instruction at Step 00101. EXAMPLE 34. When the program reaches step 00362, it is desired to shift the A register contents left and the Q register contents right. The number of left shifts is to be determined by the contents of index register 4 and the number of right shifts by the contents of index register 5. This is done by the following two program steps. Store contents of index Store contents of register 4 in upper address of 00362 address of 00362 (00361) SIU 4 0 0 3 6 2 SIL 5 0 0 3 6 2 A Left shift Q Right shift Is it possible to accomplish the same thing by using program step 00362 only above? Show step 00362 QRS 0 0 0 0 0 0 00000 (00362) | ALS 0 Although the following exercises are provided for practice on the last seven instructions of this chapter, some general review is also provided on using the instructions up to this point. Check your solutions with those given in Appendix A. The number of correct answers will indicate your approximate progress by checking the Rating Table below: ### Rating Table 9 If you have 5 correct answers . . . . . . . . Excellent If you have 3 or 4 correct answers . . . . . . . . Good If you have 2 correct answers . . . . . . . . . . . Some Review If you have 0-1 correct answers . . . . . . . . . . . . Complete Review #### EXERCISES 9 - a. A trucking concern charges a flat rate plus a zone rate. Zone rates are stored in index registers 1 through 4. Minimum distances have no zone rate. Assuming the flat rate is stored in index register 6, write steps for the total charge to a company which required service for 1 minimum distance, and 1 distance for each of the zones 1 through 4 (total of 5 distances). (Try to do this by using "STORE INDEX" and "INCREASE INDEX" instruction.) - b. Write program steps which will count the number of index registers, 1 through 6, which contain negative quantities. (Start with step 00154.) - c. Write program steps which will modify the upper instruction of step 00026 by adding an octal digit (0-7) which is contained in index register 2 to the operation code bits (left 3 octal digits) of the instruction. - d. Write program steps, which will increase the contents of index register 6 by the sum of the contents of index register 4 and the contents of Q. - e. A subroutine consisting of 42<sub>10</sub> steps is coded with consecutive addresses starting with 00000. A programmer vants to store these 42<sub>10</sub> steps at consecutive locations starting with 00377. Use is made of index register 3 to do this. Explain or show how it can be done. ### CHAPTER IV ### REVIEW TEST The following questions review the fifteen instructions presented in this chapter. Write answers in the spaces provided after each question. Solutions are given in Appendix B. | 1. | The "two-way jump" instructions such as STORAGE SKIP, STORAGE SHIFT, and INDEX SKIP should be used as which instruction in a program step? (Upper or lower) | |----|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2. | The STORAGE SKIP instruction senses the sign bit of a quantity in a specified storage location. If it is plus, what action is taken? | | 3. | What is the main difference between the STORAGE SKIP and STORAGE SHIFT instructions? | | 4. | If the content of index register 3 is 00001, and the INDEX SKIP instruction 5 4 3 0 0 0 0 1 is executed, what will occur? | | 5. | Assume the content of index register 4 is 00002. If the INDEX JUMP instruction 5 5 4 0 0 1 0 0 is given, how many times will a jump to 00100 take place? | | 6. | In trying to extract bits from a word, name three places where the extractor may be stored. | | 7. | Show the rules of multiplication which govern a logical product. | | 8. | If one wishes to save the bits in a word, he should store zeros in the corresponding positions of the extractor. (True-False) | | 9. | Most of the logical instructions destroy the original contents of the A and Q registers. (True-False) | |-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 10. | If one wanted to extract the four right-most bits of a word, what would the extractor be? | | 11. | Can the logical product be zero? (Yes or No) | | 12. | Show the PASS instruction. | | 13. | The PASS instruction can not be used in the second or lower position of a program step (True-False) | | 14. | The ENTER INDEX instruction and the INCREASE INDEX instruction make use of the value specified by the execution address rather than referencing a storage location. (True-False) | | 15. | Write program steps which will find the sum of the octal digits contained in index register 5 and deliver the sum to index | register 3. #### CHAPTER V #### FOURTH GROUP OF INSTRUCTIONS FOURTH INSTRUCTIONS (with Mnemonic and Numeric Codes) | MULTIPLY FRACTIONAL | (MUF.b)(26.b) | EQUALITY SEARCH | (EQS)(64.b) | |---------------------|-----------------|------------------|----------------| | DIVIDE FRACTIONAL | (DVF.b)(27.b) | THRESHOLD SEARCH | (THS)(65.b) | | SELECTIVE STOP | (SLS.b)(76.b) | MASKED EQUALITY | (MEQ)(66.b) | | | | MASKED THRESHOLD | (MTH)(67.b) | | SELECTIVE SET | (SST.b)(40.b) | REPLACE ADD | (RAD)(70.b) | | SELECTIVE CLEAR | (SCL.b)(41.b) | REPLACE SUBTRACT | (RSB)(71.b) | | SELECTIVE COMPLEMEN | T (SCM.b)(42.b) | REPLACE ADD ONE | (RAO)(72.b) | | SELECTIVE SUBSTITUT | E (SSU.b)(43.b) | REPLACE SUBTRACT | ONE(RSO)(73.b) | The first three of the above are similar to other instructions which have previously been described. However, they involve unique features which make them different to program. MULTIPLY FRACTIONAL (MUF)(26.b)(where b may be 0 through 7) This instruction forms a 96-bit product from two 48-bit operands. All quantities in this operation are treated as fractions with the binary point immediately to the right of the sign bit. (The sign bit here is the single left-most bit of the register.) The multiplier must be loaded into the A register prior to the execution of the instruction. The multiplicand is read from the storage location specified by the sum of the execution address and the contents of the designated index register. The product is formed in the AQ register and the multiplier is discarded in the multiplication process. The following examples indicate the process. Multiply 1/8 by 1/4 The product in the AQ register will then be: 96 possible bits The correct answer then will be 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 (in octal) Product in AQ will be: Expressed in octal the product is 05000000000000000 DIVIDE FRACTIONAL (DVF) (27.b) (where b may be 0 through 7) This instruction divides a 95-bit dividend by a 48-bit divisor. All quantities involved in this operation are treated as fractions with the binary point immediately to the right of the left-most bit (eign bit). The 55-bit dividend must be loaded into the AQ register prior to the encustion of this instruction. The 48-bit divident is read from the storage hosation specified by the sum of the execution eddress and the contents of the designated index register. At the end of the epocation, the quotient is left in the A register and the remainder to left in the Q register. (Note this is just the reverse of the bivible INTEGER.) The quotient and remainder bear the same algebraic sign. Example Divide 1/8 by 1/4 Assume AQ contains 0.0010 <--->0 = 1/8 Assume storage location 00100 contains 0.010 <--->0 = 1/4 DIVIEZ INSTRUCTION EVF O GOLGO The quotient in A will be $0.10 < \longrightarrow 0 = 1/2$ and the remainder in Q is zero. Expressed in octal the quotient is 20000000000000000 # SELECTIVE STOP (SLS)(76.b)(where b may be 0 through 7) This instruction causes the program to stop on specified conditions of operator lever keys on the console. This is similar to the SELECTIVE JUMP settings discussed previously. The index registers are not used for address modification in this instruction. The three-bit index designator specifies which stop key is sampled in determining the stop decision. A jump to the base execution address occurs regardless of the stop decision as shown below: | IF JUDEX DESECRATION IS | COMPUTER ACTION IF CORRECT<br>STOP KIY IS SET | COMPUTER ACTION UPON<br>RESTART OR IF STOP KEY<br>IS NOT SET | |-------------------------|-----------------------------------------------|--------------------------------------------------------------| | 0 | Stops unconditionally | Jump to Execution address | | 1 | Stops if stop key 1 is set | Jump to Execution address | | 2 | Stops if stop key 2 is set | Jump to Execution address | | 3 | Stops 12 stop key 3 is set | Jump to Execution address | | 4, | Stops unconditionally | Return jump to Execution address | | 5 | Scops if stop key 1 is set | Return jump to Execution address | | 6 | Stops if stop key 2 is set | Return jump to Execution address | | 7 | Stops if stop key 3 is set | Return jump to Execution address | ### SELECTIVE SET (SST)(40.b)(where b may be 0 through 7) This instruction sets individual bits in the A register to "one" where there are corresponding ones in the word at the storage location address specified by the sum of the execution address and the contents of the designated index register. This is a bit-by-bit function and does not involve normal addition. FIG. 13 indicates the procedure: (b) (a) IF INDEX REGISTER IS IF NO INDEX REGISTER DESIGNATED IS DESIGNATED Instruction Instruction 4 0 3 0 0 1 5 0 in Octal 4 0 0 0 0 1 5 0 in Octal Assume (A) = $1 \ 1 \ 1 \ 1 \ 0 < >0000 | Assume index$ register 3 = 00005Sum of execution address and Assume $(00150) = 000000 \Leftrightarrow 0111$ contents of index register 3 is 0 0 1 5 5 The three one bits in (00150) will set the corresponding bits Operand is found at in A to ones, so that (A) assume $(00155) = 0 \longrightarrow 01110000$ becomes 1 <-->10000000 Assume (A) = $(A) = 1 \ 1 \ 1 \ 1 \ 1 \ 0 \longrightarrow 0 \ 1 \ 1 \ 1$ The three one bits in (00155) will cet one bits into corresponding positions in A <del>---></del>11110000 (A) becomes 1← FIG. 13 Setting one bits in A Register # SELECTIVE CLEAR (SCL)(41.b)(where b may be 0 through 7) This instruction clears individual bits of the A register where there are ones in corresponding bit-positions in the quantity in storage whose location is specified by the sum of the execution address and the contents of the designated index register. FIG. 13 indicates the same procedure except zeros are set in (A) instead of ones. # SELECTIVE COMPLEMENT (SCM)(42.b)(where b may be 0 through 7) This is the same as the SELECTIVE SET instruction except this instruction complements individual bits in the A register where there are ones in corresponding bit positions in the quantity in storage specified by the sum of the execution address and the designated index register. FIG. 13 can also be used to indicate the process, except the ones in the control quantity complement the corresponding ones in A. # SELECTIVE SUBSTITUTE (SSU)(43.b)(where b may be 0 through 7) This instruction substitutes portions of an operand into the A register using the Q register as a mask. This action may be considered in two stcps. First individual bits in A are cleared where there are corresponding ones in the Q register. Second, these same (cleared) individual bits in A are replaced with the corresponding bit values from the storage location specified by the sum of the execution address and the contents of the designated index register. The following examples should facilitate learning the previous seven instructions. (Each student is advised to work out the examples and to check the given solutions.) EXAMPLE 35. Assume storage location (00111) contains the fraction, 1 2 3 3 0 0 0 0 0 0 0 0 0 0 0 0. A programmer wants to square this quantity, store the result in storage location (00112), and stop. Urite program steps to do this and show the contents of storage location (00112) and the AQ register after the MULTIPLY FRACTIONAL is executed. | | Load Multiplier in A | Fractional Multiply | |---------|----------------------|---------------------| | (00050) | LDA 0 0 0 1 1 1 | MUF 0 0 0 1 1 1 | | | Store A in 00112 | Unconditional Stop | | (00051) | STA 0 0 0 1 1 2 | SLS 0 00200 | The product in the AQ register will then be 0000110110010011101100100 0 which is expressed in octal as 0331166200000000 EXAMPLE 36. It is desired to use the DIVIDE FRACTIONAL instruction to divide 324 (octal) by 51 (octal). Assume the divisor (51) is stored at address (00042). Assume (324) is stored at address (00040). Show the program steps, the format in which the 324 and 51 should be stored, and the final contents of the A and Q registers after the DIVIDE. Final Contents of A The Quotient Final Contents of Q The Remainder 2 4 5 3 5 5 2 1 1 2 7 3 2 4 2 2 EXAMPLE 37. The first time a program reaches step 01005, the program is to jump to step 00200. The second time when step 01005 is reached the program is to step. Explain how this could be accomplished using a SELECTIVE STOP instruction. Explanation: There are several ways this might be done. A SELECTIVE STOP with index designation 1 could be used and the stop key 1 selected in the console. When the program reached step 01005 the computer would stop but by depressing the START button it could jump to 00200. The second time it would also STOP. Another method might be to use the SELECTIVE STOP with a designation, but a different stop key setting, for example, 76 2 00200 with stop key 1 is set. The first time, there would be no step and the program would jump to 00200. Before reaching stop 01005 the second time a modification of 01005 (7 6 2 0 0 2 0 0) to 7 6 1 0 0 2 0 0 could be made and this time the STOP would occur. Explain what will occur if program steps (00050) and (00051) are given and stop key 3 is the only key setting on the console. (00050) = | SLS 1 00100 | SIS 2 00200 (00051) = | SLS 3 00300 | SLS 0 00100 EXAMPLE 38. Assume the A register contains eight 6-bit characters. If the content of Q is positive, it is desired to set the left-most bit of each of the eight characters to one. If the content of Q is negative, the left-most bit of each of the eight characters is to be set to zero. If the sign of the contents of address 00011 is used to set the ones and zeros, show the program steps and the contents of address 00011. Set bits in (A) corresponding to one bits in 00011 to zeros Test 0 for positive SCL 0 (00050) =0001 00052 Jump Exit Pass 0 0 0 0 ENI 0 (00051) =SLJ 00 0 0 5 3 Set bits in (A) Pass to ones 00000 00011 ENI O SST 0 (in bits) Contents of address 00011 100000 100000 100000..... etc. (In octal) 4 0 4 0 4 0 4 0 4 0 4 0 4 0 4 0 Explanation: First Q is tested for positive content with Q-JUMP. If positive, jump occurs to 00052 where "ones" are set in A by the pattern in address 00011. If Q is negative, jump does not occur, and "zeros" are set in A by pattern in 00011. Note "exit" jump needed in step 00051. Why? EXAMPLE 39. The numeric code for the Q-Jump with zero index designation is 2 3 0. The numerical code for the A-Jump with zero index designation on 2 2 0. At step 00117 in a program the Q JUMP, "2 3 0 0 0 1 5 0", is given, followed by a PASS instruction. On the second time through this step, change the Q-Jump to the A-Jump " 2 2 0 0 0 1 5 0". The third time, it is to be returned to its original form, etc. Each time through this step, it is desired to alternate between a Q-Jump and an A-Jump. Assume the necessary modification is done at step 00150 by using the SELECTIVE COMPLEMENT instruction. Show this instruction and the contents of the storage address containing the necessary "change pattern". | | Load (A) with step 00117 | Complement bits in A by pattern of ones in address 00200 (see below) | 00200 | |-----------|--------------------------|----------------------------------------------------------------------|-------| | (00150) = | LDA 0 0 0 1 1 7 | SCH 0 0 0 2 0 0 | | | (00151) = | STA 0 0 0 1 1 7 | Next Instruction | | Q-Jump Pass Explanation: First 230 00150 500 00000 is LOADED into A. "SELECTIVE COMPLEMENT" then changes the 230 part of instruction to 220. The next time it will be reset to 230, etc. Then A is stored in 00017. EXAMPLE 40. Assume storage location 00100 contains the following: 140 00600 200 00300 It is desired to change this to the following: 142 00600 200 00426 To do this, patterns are set up in Q and address 00050. The "SELECTIVE SUBSTITUTE" instruction used. Show the steps necessary and the contents of Q and address 00050. | Load Pattern into | | Load In | structions | to be modified | | |-------------------|-------|-----------|------------|----------------|---| | (00022) = | LDQ 0 | 0 0 0 5 1 | LDA O | 0 0 1 0 0 | ] | Selective Substitute Store Modified Instructions $$(00023) = \begin{bmatrix} SSU & 0 & 0 & 0 & 5 & 0 \\ STA & 0 & 0 & 0 & 1 & 0 & 0 \end{bmatrix}$$ Contents of 00051 = contents of Q = 00700000 00000777 Contents of 00050 ------> 00200000 00000426 Explanation: The pattern of sevens in Q clears the corresponding octal digits in the A register. The octal digits in 00050 then replace these corresponding cleared positions in A. The modified instruction is then returned to 00100 by "STORING A". The following exercises are provided for practice on the first seven instructions of this chapter. Some general review may also be included in the exercises. Check your solutions with these given in Appendix A. The number of correct answers will indicate your approximate progress by checking the Rating Table below: ### Rating Table 10 #### EXERCISES 10. - a. Storage address 00025 contains a tax rate whose range is between 1.5% and 2.5%. A company has found that 37.5% (stored in address 00026) of this tax rate is a good barometer of business trend in general. The procedure is to calculate this barometer, round it to three digits and subtract the result from 1. Program this, starting at step 00050 and using the given address contents above. - b. Starting at storage address 00011, there are 16<sub>10</sub> quantities stored. Each negative quantity is to have its right-most 3 bits replaced by one bits. Each positive quantity is to have its right-most 3 bits replaced by zero bits. Show program steps starting at step 00200 to do this. Show contents of all addresses used as constants. - c. Program the following flow chart: - d. Write a program which will count the non-significant octal zeros contained in storage location 00100. - e. Starting at step 00300 show a program which will exchange the contents of index register 4 with the right-most 15 bits contained in storage location 00100. The next four instructions are similar in that they are search instructions and they are extensions of the "two address jump" instructions. These instructions are also limited to use in the upper position of program steps. The lower position in such a program step is normally an unconditional jump instruction. Thus the first address (in the upper instruction) specified the location of the operands required in the jump decision; whereas, the second address (in the lower instruction) specifies the destination of the jump if taken. If these search instructions are used in the second position of program steps, no skip will take place which removes most of the power of the instruction. EQUALITY SEARCH (EQS)(64.b)(where b may be 0 through 7) This instruction searches a list of operands beginning at the search address specified by the sum of the execution address and the contents of the designated index register minus one and continuing back toward the execution address until an operand is found that is equal in value to the contents of the A register or until the operand at the execution address has been searched. Before each operand is searched, the search address is reduced one count at a time (by reducing the index register contents) until the equality is found or the base execution address is reached. If an operand is found that is equal to the contents of the A register, the search is terminated and the next instruction is skipped. If no operand in the list is equal to the contents of the A register, then the next instruction is executed. It is important to note that if an index register designation of zero is used, the search will only be made on one operand - - that is the operand located at the base execution address. Usually the instruction which follows the search instruction is a jump. When the search criterion is met, this instruction is skipped. The programmer often desires to know the address of the register containing the value which equals the contents of the A register. This is easily accomplished by adding the reduced count in the designated index register to the base execution address. The following flow chart of the SEARCH procedure is outlined in FIG. 14. This should further indicate the procedures followed by the computer while executing this type of an instruction. Also note that one stores the exact number for the number of searches to be made since the preliminary reduction made by the machine adjusts for this. Execution of a Search Instruction ### THRESHOLD SEARCH (THS)(65.b)(where b may be 0 through 7) This instruction is similar to the EQUALITY SEARCH except it searches a list of operands for one which is greater than the value in the A register. If an operand is found which is greater than the value in the A register, the search is terminated and the next instruction is skipped. If no operand in the list is greater than the value in the A register, the mext instruction is executed. The search begins at the address specified by the sum of the execution address and the contents of the designated index register minus one and continues back toward the execution address value. Refore each storage address is searched, the contents of the index register is reduced one count. If a zero index register designation is used, then the computer searches just one address, viz., the one whose location is given by the execution address part of the instruction. FIG. 14 indicates the cearch process with everything being the same except the comparison is made to see if any operand is greater than the value in the A register rather than for equality. Also note that the programmer stores the exact number of searches he desires in an index register since the preliminary reduction takes care of the necessary adjustments. # MASKED EQUALITY (IEQ)(66.b)(where b may be 0 through 7) This instruction searches a list of operands starting at the location specified by the sum of the execution address and the contents of the designated index register. If an operand is found such that the logical product of the operand and the contents of the Q register is equal to the contents of the A register, the search is terminated and the next instruction is If no operand in the list means this requirement, the next instruction is executed. As in the case of the previous two search instructions, the search begins at the location specified by the sum of the execution address and the contents of the designated index register minus one and continues backward through consecutive storage location toward the execution address Eafore each search is made, the contents of the index register is reduced by one count. The search continues until on operand satisfying the requirement is met, or until the operand in the base execution address has been searched. A zero index designation infers that no index register is being used and as a result only one storage location is searched, viz., the one located at the base execution address. FIG. 14 can be used to trace this instruction using the criterion "MASKED EQUALITY" instead of the "EQUALITY" criterion shown therein. ## MASKED THRESHOLD (MTH)(67.b)(whole is may be 0 through 7) This instruction is the same as the MASKED EQUALITY instruction except the search is made on the criterion of trying to find an operand such that the logical product of the operand and the contents of the Q register is greater than the contents of the A register. If such an epended is found, the search is ended and the next instruction is ekipped. If no such operand is found the next instruction is executed. The carch begins at the location specified by the sum of the execusion address and the contents of the designated index register minus one and continues backward through consecutive storage location whose addresses are above the base execution address. Defore each address is searched, the contents of the designated indem register is reduced one count until the contents become zero (this will be the situation when the base execution address has been reached and searched). A zero index designation will result in just one stored location being searched - that one designated by the base execution address. FIG. 14 can be used as indicative of the process followed except the MASKED THRESHOLD criterion should be substituted for the EQUALITY criterion shown therein. The following examples should facilitate learning the four previous search instructions. (Each student is advised to work out the given examples and to check the given solutions.) EXAMPLE 41. There are 100<sub>10</sub> constants stored in consecutive locations starting at address 00100. Show steps starting at 00011 needed to count the number of zero quantities in these addresses. Enter zeros into index register 2 Pass (00011) =ENI 2 00000 00000 ENI O Enter zeros into A Enter 100<sub>10</sub> into index register 3 (00012) =ENA O 0 0 0 0 ENI 3 00144 Equality Search This jump will occur if equality is not found, it will be skipped if equality is found (00013) =EQS 3 00100 SLJ 0 00017 Increase index Index jump index register 3 is register 2 by examined for zero. If not zero, one count reduce index register 3 by 1, (00014) =INI 2 00001 00016 Jump to 00016 Pass Jump to exit (00015) =ENI O 00000 SLJ 0 00017 Increase Index register Continue search 3 by one count at (00013) (00016) =INI 3 00001 SLJ 0 0001 (00017) = Exit. When exit is reached the count of the number of zeros will be in Index Register 2. Explanation: Zeros are first put into index register 2 which is used as a counter for the number of zero quantities found. The number of storage locations to be searched is entered into index register 3. (Note this is 144 in octal since $100_{10} = 144_8$ .) At step 00013, the EQUALITY SEARCH instruction is given. The next instruction (75 000017) will be executed as long as no equality is found. Thus if all 100 addresses do not contain zero, a jump to 00017 will be made. If a zero is found, this jump is skipped and at step 00014, the contents of index register 2 (the counter) is increased by 1. The INDEX JUMP instruction is then used to examine the contents of index register 3 for zero (which would mean all 100 locations had been searched before a zero was found). If the contents of index register 3 are not zero, the INDEX JUMP instruction reduces it by 1. Thus it is necessary to add 1 to the register before jumping back to continue the search. For this reason, the instruction at step 00016 is used to increase the index register 3 by 1. EXAMPLE 42. A programmer desires to search 5010 storage addresses starting with address 00200 to find the first one of these addresses containing the quantity 7. He wants to know the address of the first one of these locations which contains a 7. Show program steps starting at 00100. | | Enter 7 into (A) | Enter 50 <sub>10</sub> into<br>Index Register 6 | |-----------|--------------------------------------|-------------------------------------------------| | (00100) = | ENA 0 00007 | ENI 6 0 0 0 6 2 | | · | | If no address contains 7, jump to exit | | (00101) = | EQS 6 0 0 2 0 0 | SLJ 0 00103 | | | Enter A with 200 + (B <sup>6</sup> ) | Store Result<br>in 00050 | | (00102) = | ENA 6 00200 | STA 0 00050 | Explanation: First 7 is put into A and $50_{10} = 62_8$ is put into index register 6. The search instruction is then executed. When the first address containing 7 is found, step 00102 is executed. At this time the sum of the contents of index register 6 and the execution address (00200) of the SEARCH instruction will give the address of the first location containing a 7. The ENTER A INSTRUCTION, of step 00102, puts the sum of 200 and the contents of index register 6 into the accumulator and from here it is stored in location 00050. EXAMPLE 43. There are $1000_{10}$ tax accounts stored in consecutive storage locations starting at 00126. Write program steps, starting at 00010 which will transfer those accounts greater than $9450_{10}$ into consecutive addresses starting at location 03000. | | Enter 1000 <sub>10</sub> into index register 4 | Pass | |-----------|----------------------------------------------------|--------------------------------------------------------------------------------------------| | (00010) = | ENI 4 0 1 7 5 0 | ENI 0 00000 | | | Enter 9450 <sub>10</sub> into the A register | Pass | | (00011) = | ENA 0 2 2 3 5 2 | ENI 0 00000 | | | Threshold Search | If no accounts are found that are greater than $9450_{10}$ , jump to exit at step $00017$ | | (00012) = | THS 4 0 0 1 2 6 | SLJ 0 00017 | | | Pass | Pass | | | Enter A with 126 + (B <sup>4</sup> ) | Substitute generated "address" into the address portion of upper instruction at step 00014 | | (00013) = | ENA 4 0 0 1 2 6 | SAU 0 0 0 0 1 4 | | | Load A with contents of address (xxxxx) | Store at locations starting at 03000 | | (00014) = | LDA 0 (x x x x x) | STA 0 (0 3 0 0 0 ) | | | Load previous programstep into A register | Increase A by 1 - which modifies storage location (03000) of previous step | | (00015) = | LDA 0 0 0 0 1 4 | INA 0 0 0 0 0 1 | | | Modified step sent<br>back to original<br>location | Jump back to start search again | | (00016) = | STA 0 0 0 0 1 4 | SLJ 0 0 0 0 1 2 | | | | | Explanation: After finding the addresses of the locations containing quantities greater than 9450<sub>10</sub>, the contents of these addresses must then be transferred to addresses starting at 03000. This is the reason for the right instruction at 00013 and step 00014. Another method, referred to as Indirect Addressing, is an alternative to perform this operation. Indirect addressing is described in the "Operational and Technical Characteristics" manual. EXAMPLE 44. Starting at location 00500 there are 500<sub>10</sub> quantities stored in consecutive addresses. The right-most bit of each of these quantities is reserved for parity data. If any one of these contain a parity designation of 1, the 500<sub>10</sub> addresses are to be cleared. Show program steps starting at 00071. | (00071) = [ | Enter extractor in Q register ENQ 0 0 0 0 0 1 | Enter comparator in A register ENA 0 0001 | |-------------|-----------------------------------------------------|----------------------------------------------------------------------------------------| | | Enter search number into index register | Enter 500 <sub>10</sub> into index register 3 for a counter for index jump (see 00076) | | (00072) = | ENI 2 0 0 7 6 4 | ENI 3 0 0 7 6 3 | | | Start Masked<br>Equality Search | If no parity is found in all of<br>the locations jump to exit at<br>(00077) | | (00073) = | MEQ 2 0 0 5 0 0 | SLJ 0 00077 | | | Enter zeros in a register | Clear address register contents starting at (00500) | | (00074) = [ | ENA 0 00000 | STA 0 (0 0 5 0 0) | | _ | Load previous step<br>into A register | Increase A by 1 which increases storage designation of lower instruction of step 00074 | | (00075) = | LDA 0 0 0 0 7 4 | INA 0 00001 | | | Store modified step<br>back in original<br>location | Index jump based upon contents of index register 3 | | (00076) = [ | STA 0 0 0 0 7 4 | IJP 3 00074 | Explanation: The extractor entered into Q picks off the right-most bit (parity designation in this example) and compares it with contents of the A register. If equality is found (indicating an address contains parity 1) step 00074 is taken. Steps 00074 and 00075 clear the addresses starting at 00500. The INDEX JUMP at (00076) controls the number of times (500) the clearing takes place. Note that program step 00075 modifies the previous program step by adding a 1 to it. There is a "neater" method of modifying by using an index register. For example, step 00074 could have been LDA 0 00000 STA 5 00500 where index register 5 contains zero initially. Then this index register can be increased by 1 before looping back. Write the above program to include this method. EXAMPLE 45. 60 consecutive locations starting at address 00100 contain either eight alphabetic characters of 6 bits each, or eight numeric characters of 6 bits each. The formats for numerical and alphabetic characters are shown below: (where symbol "x" may be a 0 or 1). Each numeric character is of the form 00xxxx (6 bits) Each alphabetic character is of the form 01xxxx (6 bits) Numerical and alphabetic characters will not appear in the same storage address. Show program steps which will store in address 00200 the address of the first alphabetic location found. | | _ | Enter extractor into Q Register | Enter zeros into<br>A register | |-------|-----|-------------------------------------------------------|---------------------------------------------------------------------------------------| | (c) | = [ | ENQ 0 0 0 0 2 0 | ENA 0 0 0 0 0 0 | | | | Enter search count 60 <sub>10</sub> , into index regi | ster 5 Pass | | (c+1) | = [ | ENI 5 0 0 0 7 4 | ENI 0 00000 | | | | Start Masked<br>Threshold Search | If no locations contain alphabetic characters jump to exit at (c+5) | | (c+2) | = | MTH 5 0 0 1 0 0 | SLJ 0 (c+5) | | | | register 5 into A<br>register | dex Increase contents of A by 100<br>to get address of first alpha-<br>betic location | | (c+3) | = | ENA 5 0 0 0 0 0 | INA 0 0 0 1 0 0 | | | | Store address in (00200) | Pass | | (c+4) | = | STA 0 0 0 2 0 0 | ENI 0 00000 | (c+5) = Continue Program The following exercises are provided for practice on the four SEARCH instructions just described. Some general review is also included in these exercises. Check your solutions with these given in Appendix A. The number of correct answers will indicate your approximate progress by checking the Rating Table below: ### Rating Table 11 | If you have | 4 correct | answers . | | | • | | Excellent | |-------------|-----------|-----------|--|--|---|--|-----------| | If you have | | | | | | | | | If you have | | | | | | | | | If you have | | | | | | | | #### EXERCISES 11 - (a) 50<sub>10</sub> consecutive addresses starting with 00100 contain accounts "C", 50<sub>10</sub> consecutive addresses starting with 00200 contain accounts "D". If any of accounts "C" equal accounts "D" store a 1 in register 00032 and stop. Write program steps for this, starting at step 00400. - (b) Use SEARCH instructions to do the following: if the contents of address 00200 is greater than the contents of address 00201, jump to step 00400; if the contents of address 00200 equals the contents of address 00201, jump to step 00500. - (c) Given the following portion of a program. Explain what this is attempting to do. | (00050) | ENI 6 | 0 0 1 4 4 | ENA 6 | 00000 | |---------|-------|-----------|-------|-----------| | (00051) | THS 6 | 0 0 1 0 0 | SLJ 0 | 00060 | | (00052) | ENQ 0 | 0 0 0 0 0 | STQ 0 | 0 0 5 0 0 | (d) Explain what would occur in the following two separate program steps. (Treat each program step as a separate occurrence.) | I. | (00700) | MTH 3 | 0 0 0 5 0 | SLJ 0 | 00700 | |-----|---------|-------|-----------|-------|-----------| | II. | (00105) | LDA O | 0 0 0 5 0 | EQS 3 | 0 0 2 0 0 | The last four instructions of this chapter are the REPLACE ADD and REPLACE SUBTRACT instructions. In programming one is often concerned with modifying an instruction and replacing it in its original location. The sist he primary function performed by these instructions. They are described below. REPLACE ADD (RAD)(70.b)(where b may be 0 through 7) This instruction replaces the quantity whose location is given by the sum of the execution address and the contents of the designated index register, by its original value plus the contents of the A register. The resultant sum is also left in the A register. REPLACE SUBTRACT (RSB)(71.b)(where b may be 0 through 7) This is the same as the previous instruction except the process is subtraction. This instruction replaces the quantity whose location is given by the sum of the execution address and the contents of the designated index register, by its original value minus the contents of the A register. The resultant difference is also left in the A register. REPLACE ADD ONE (RAO) (72.b)(where b may be 0 through 7) REPLACE SUBTRACT ONE (RSO) (73.b)(where b may be 0 through 7) The following examples should facilitate learning the REPLACE instructions, which have just been described. Check each example by working through to your solution and then comparing it with the given solution. EXAMPLES 46-47. Add the contents of $100_{10}$ consecutive addresses starting at 00300 to the contents of the $100_{10}$ consecutive addresses starting at 00500 and store the sums in $100_{10}$ consecutive addresses starting at 01000. Program this starting at step 00011 by two methods (46) without USING INDEX REGISTERS FOR MODIFICATION AND (47), USING INDEX REGISTERS FOR MODIFICATIONS. ### EXAMPLE 46. | (00011) | = | Enter 99 <sub>10</sub> into index register 3 for counter Pass ENI 3 0 0 1 4 3 ENI 0 0 0 0 0 0 | |---------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | Load A with contents of address (00300) Add contents of (00500) | | (00012) | = | LDA 0 (0 0 3 0 0) ADD 0 (0 0 5 0 0) | | | | Pass Store in (01000) | | (00013) | = | ENI 0 0 0 0 0 0 STA 0 (0 1 0 0 0) | | (00014) | = | Add 1 to contents of 00012 of step 00013 and replace and replace. (This modified RAO 0 0 0 1 3 RAO 0 0 0 0 1 2 the (00600) above.) Add contents of 00050 Store in 00012. (This to contents of A will modify the (00300) above) | | (00015) | = | ADD 0 0 0 5 0 STA 0 0 0 0 1 2 | | | | Index Jump back Where (00050) = to 00012 for 99 times 00000001 00000000 | | (00016) | = | IJP 3 0 0 0 1 2 Program continues | Note: The only use of an index register was as a counter and not to modify. Location (00050) = 0000000100000000 EXAMPLE 47. (Same as previous example except using index register to modify instructions.) Enter zero into index register 4 Pass Store in location | (00011) ENI | 4 | 0 | 0 | 0 | 0 | 0 | ENI | 0 | 0 | 0 | 0 | 0 | 0 | |-------------|---|---|---|---|---|---|-----|---|---|---|---|---|---| Load A with contents Add the contents of the address of "00500 + contents located by the sum of 00300 and index register 4" contents of index register 4 (00012) LDA 4 0 0 5 0 0 ADD 4 0 0 3 0 0 given by (01000) + Pass contents index register 4 (00013) STA 4 0 1 0 0 0 ENI 0 0 0 0 0 0 Explanation: Index register 4 contains a zero to start. This means that 00100, 00300, and 01000 will be used as the location of the operands in steps 00012 and 00013 the first loop through. However, step 00014 (INDEX SKIP) checks the contents of index register 4 against the execution address part of the instruction (99 $_{10}$ ) and if not equal adds 1 to index register 4 and takes the next instruction (JUMP). The second loop through, 00101, 00301, and 01001 will be used as the location of the operands in steps 00012 and 00013 since index register 4 now has a 1 in it, etc., until the INDEX SKIP at step 00014 sees the index register 4 contains 99 $_{10}$ and skips the jump. (Why is 99 $_{10}$ instead of 100 $_{10}$ used?) EXAMPLE 48. Examine the contents of the A register for sign. If positive, increase the contents of 00100 by 1 and decrease the contents of 00101 by 1 and then jump to step 00250. If negative program a selective stop with a restart at 00200. (Start the program steps at 00200.) If (A) is negative Replace Add 1 to jump to step contents of 00100 00202 (00200) AJP 3 0 0 2 0 2 RAO 0 0 0 1 0 0 Replace Subtract 1 Jump to step to contents of 00101 00250 (00201) RSO 0 0 0 1 0 1 SLJ 0 0 0 2 5 0 Stop with restart Pass at step 00200 (00202) SLS 1 0 0 2 0 0 ENI 0 0 0 0 0 0 (Where stop key 1 is set on the computer console) Explanation: The REPLACE ADD ONE and the REPLACE SUBTRACT ONE instructions are used when the content of A is positive. Other steps above are self-explanatory. EXAMPLE 49. It is desired to add to the contents of address 00050 the contents of consecutive addresses 00060 to 00067 inclusive. The total sum is then to be stored in index register 3. Show the program steps starting at 00712 to do this. | | Enter zero into index register 6 | Pass | |---------|------------------------------------------|--------------------------------| | (00712) | ENI 6 00000 | ENI 0 00000 | | | Load "A" with (06060) + index register 6 | (00050) ÷ (A) (00050) | | (00713) | LDA 6 00060 | RAD 0 0 0 5 0 | | | Index Skip checks index register 6 | Jump to 00713 | | (00714) | ISK 6 00007 | SLJ 0 0 0 7 1 3 | | | Store sum in "A" | Load sum into index register 3 | | (00715) | STA 0 0 0 1 0 0 | LIL 3 0 0 1 0 0 | Explanation: Index register 6 is first loaded with a zero. The A register is then loaded with the contents of the location whose address is the sum of 00060 and the contents of index register 6. Thus the first time, contents of address"00060 + 0" = "contents of 00060" goes to A; the next time, contents of "00060 + 1" = "contents of 00061" goes to A, etc. Then a REPLACE ADD instruction replaces the contents of 00050 by the sum of A and the contents of 00050. Each time the contents of 00050 are replaced by the sum of its current contents and the contents of the address then in A. This continues until contents of index register 6 are equal to 00007 in INDEX SKIP instruction at step (00714). Then at step (00715) the current sum (still in A) is entered into index register 3. If the sum exceeded 15 bits, the total in index 3 would not be correct. Assume that the total didn't exceed 15 bits. Although the following exercises are provided for practice on the REPLACE instructions, some general review is included on the instructions presented up to this point. Check your solutions with these given in Appendix A. The number of correct answers will indicate your approximate progress by checking the Rating Table below: ## Rating Table 12 #### EXERCISES 12 - (a) There are 100<sub>10</sub> positive quantities stored in consecutive locations starting at address 00201. Find the largest of these and store it at address 00077. Start program at step 03001. - (b) A company uses the following formula to compute "Withholding Tax". (Gross Weekly Pay \$13 (Number of Dependents)x18% = Tax. Program the tax computation starting at step 00101. Assume: Gross Weekly Pay is stored in address 00022=xxx,xx Number of dependents stored in address 00024 = x. Constant 18 is stored in address 00025 = 18. Constant 13 is stored in address 00027 = 13. Tax (rounded to nearest cent) stored in 00030 = xx,xx - (c) The third octal digit from the right end of each of 100 consecutive registers starting at 00312 contains a code of one octal digit. Write a program to determine the number of codes which are greater than 3. Start program at step 00011 and store result in address 01000. - (d) Write a program starting at step 00312 which will interchange the first and last of the 16 octal digits stored in each of 300<sub>10</sub> consecutive addresses starting at address 02000. - (e) Each of 50<sub>10</sub> consecutive registers starting at 00011 contain 2 separate positive numerical quantities, each of 24 bits. Write a program starting at step 01000 which will compare the two quantities in each and order them so that the larger of the two quantities will always be stored in the left 24 bits of each address. #### CHAPTER V #### REVIEW TEST The following questions review the fifteen instructions presented in this chapter. Write answers in the spaces provided after each question. Solutions are given in Appendix B. - 1. The MULTIPLY FRACTIONAL is similar to the MULTIPLY INTEGER in that the multiplier must be loaded into the Q register prior to execution of the instruction. (True-False) - 2. Where is the product formed in the MULTIPLY FRACTIONAL instruction? (What Registers?) - 4. What is the largest positive fractional quantity which can be stored directly in its absolute form without scaling and be used by the MULTIPLY FRACTIONAL to get a correct result? - 5. In the DIVIDE FRACTIONAL instruction, the dividend must be loaded into the AQ register prior to execution of the instruction. (True-False) - 6. In the DIVIDE INTEGER instruction, the quotient is left in Q and the remainder of the division process is left in the A register. In the DIVIDE FRACTIONAL, the quotient and remainder are left in the same locations. (True-False) - 7. The SELECTIVE STOP instruction, with stop key 3 set on the console, will not stop the computer program unless the index designation of 3 is used in the instruction word. (True-False) | whose address is 00100. Show the instruction which will be used. | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Using the same conditions given in 8, show the instruction which will set zeros in A instead of ones. | | If the EQUALITY SEARCH instruction is given with an index register designation of zero, what will occur? | | What kind of an instruction generally follows a SEARCH instruction? | | What happens when the SEARCH condition is satisfied? | | What happens if the SEARCH condition is not satisfied? | | After a SEARCH, if one wants to find the address of the location which met the search condition, what must be done? | | Name or explain the four types of SEARCH instructions possible with the 1604. | | | | Show the instruction which can be used to find if any of the contents of 50 <sub>10</sub> consecutive addresses starting at address 00062 exceed the contents of the A register. Use index register 5 to hold the search count. Show the instruction and the contents of index register 5. Instruction: Contents of: Index register 5: | | | | REPLACE | A1. | י טו | ıns | | uc<br>— | <u> </u> | on<br>— | | | | | | | | | ··· | · • • • • • • • • • • • • • • • • • • • | <u> </u> | · | |----------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|---------------------------------------------|---------------------------------------------|---------------------------------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Given A | z | . ( | ) ( | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 7 | | | | (00100) | = | • ( | ) ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 6 | | | | | | | | | | | d | (0( | 010 | 00) | а | £t | eı | : € | ex e | e <b>c</b> 1 | ution o | f the | REPLA | | | | | 0 | 0 | 1 ( | Э ( | ) | | | | | | | | | | | | | | A Regist | er | | | | | | | | | | | | | | | | | | | | (00100) | | | | | | | | · | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | and 00 | | | | | 0 | 0 | 1 ( | ) ( | ) | | | | | | | | | | | | | | A Regist | er | | | | | | | | | | | | | | | | | | | | (00100) | | | | | | | | | | | | | | | | | | | | | | (00100) Show cor SUBTRACT (RS 7 1 A Regist (00100) Using the after ex (RA 7 2 | (00100) = Show conte SUBTRACT i (RSB) 7 1 0 A Register (00100) Using the after exec (RAO) 7 2 0 | (00100) = ( Show contents SUBTRACT inst (RSB) 7 1 0 A Register (00100) Using the conafter execution (RAO) 7 2 0 | (00100) = 0 0 Show contents of SUBTRACT instruments of CRSB) 7 1 0 0 A Register (00100) Using the conditator execution (RAO) 7 2 0 0 | (00100) = 0 0 0 Show contents of SUBTRACT instruct (RSB) 7 1 0 0 0 A Register | (00100) = 0 0 0 0 Show contents of A SUBTRACT instruction (RSB) 7 1 0 0 0 1 0 A Register (00100) Using the conditions after execution of (RAO) 7 2 0 0 0 1 0 | (00100) = 0 0 0 0 0 0 Show contents of A and SUBTRACT instruction: (RSB) 7 1 0 0 0 1 0 0 A Register (00100) Using the conditions (after execution of the (RAO) 7 2 0 0 0 1 0 0 | (00100) = 0 0 0 0 0 0 0 Show contents of A and SUBTRACT instruction: (RSB) 7 1 0 0 0 1 0 0 A Register (00100) Using the conditions give after execution of the 10 (RAO) 7 2 0 0 0 1 0 0 | (00100) = 0 0 0 0 0 0 0 0 Show contents of A and (00 SUBTRACT instruction: (RSB) 7 1 0 0 0 1 0 0 A Register (00100) Using the conditions given after execution of the REI (RAO) 7 2 0 0 0 1 0 0 | (00100) = 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | (00100) = 0 0 0 0 0 0 0 0 0 0 0 0 Show contents of A and (00100) SUBTRACT instruction: (RSB) 7 1 0 0 0 1 0 0 A Register (00100) Using the conditions given in after execution of the REPLACE (RAO) 7 2 0 0 0 1 0 0 | (00100) = 0 0 0 0 0 0 0 0 0 0 0 0 Show contents of A and (00100) a SUBTRACT instruction: (RSB) 7 1 0 0 0 1 0 0 A Register (00100) Using the conditions given in 18 after execution of the REPLACE A (RAO) 7 2 0 0 0 1 0 0 | (00100) = 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | (00100) = 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | (00100) = 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | (00100) = 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | (00100) = 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | (RSB) 7 1 0 0 0 1 0 0 A Register (00100) Using the conditions given in 18, show contents after execution of the REPLACE ADD ONE instruction (RAO) 7 2 0 0 0 1 0 0 | (00100) = 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 6 Show contents of A and (00100) after execution of the SUBTRACT instruction: (RSB) 7 1 0 0 0 1 0 0 A Register (00100) Using the conditions given in 18, show contents of A after execution of the REPLACE ADD ONE instruction: (RAO) 7 2 0 0 0 1 0 0 | #### CHAPTER VI ## FIFTH GROUP OF INSTRUCTIONS FIFTH GROUP OF INSTRUCTIONS (with Mnemonic and Numeric Codes) (where b refers to index register designation) | FLOATING ADD | (FAD) | (30.b) | SCALE A | (SCA) | (34.b) | |------------------|---------|--------|----------|-------|--------| | FLOATING SUBTRAC | T (FSB) | (31.b) | SCALE AQ | (SCQ) | (35.b) | | FLOATING MULTIPL | Y (FMU) | (32.b) | | | | | FLOATING DIVIDE | (FDV) | (33.b) | | | | The first four of these instructions are related to the 1604 floating-point format. The last two instructions will probably be used frequently to "pack" and "unpack" to or from floating-point format. To understand these instructions thoroughly it becomes necessary to know the floating-point format of words. The first part of this chapter is devoted to this subject. Words packed in floating-point format make it possible to add, subtract, multiply, and divide, and have the computer automatically position the binary point between the integral and functional parts of the results. This feature removes the necessity of the programmer having to continually scale and rescale as the problem progresses. In order for the computer to do this, it is necessary for all numbers to be expressed in a particular format (floating-point format) before the floating-point instructions are executed. This means that if floating-point instructions are to be used with many factors, a conversion routine (from binary to floating-point) will probably be used on the input parameters. Likewise, after the results are determined (in floating-point format), an output conversion routine (from floating-point to binary) will probably be used. The 1604 floating point format is shown in FIG. 15. FIG. 15 1604 Floating Point Format Within the machine floating point numbers are represented in a form similar to that used in "scientific" notation, that is, a coefficient, or fraction, multiplied by a number raised to a power. Since the machine uses binary numbers only, the numbers are multiplied by powers of 2. In the 48-bit machine word the fraction is in the lower 36 bit positions. The exponent in the next upper 11 bit positions and the 48th bit position is the sign of the fraction. | 48 | 47 37 | 36 1 | |----|----------|----------| | S | Exponent | Fraction | In order to represent positive and negative exponents, the exponent is biased by (A) 10 000 000 $000_2$ (2000<sub>8</sub>) if positive, and by (B) 01 111 111 111<sub>2</sub> (1777<sub>8</sub>) if negative. 2000<sub>8</sub> as an exponent means $2^0$ . | (A) | 2001<br>2002 | | (B) | 1776<br>1775 | | |-----|--------------|--------|-----|--------------|------------| | | 2003 | | | 1774 | <b>-</b> 3 | | | _ | | | - | | | | - | | | - | | | | - | | | - | | | | 3776 | +1776 | | 0001 | -1776 | | | | +17778 | | 0000 | -17778 | The range of floating point numbers in the machine is $F*2^{1777}_8$ to $F*2^{-1777}_8$ ( $F*2^{1023}$ to $F*2^{-1023}$ ) = ( $K*10^{309}$ to $K*10^{-309}$ ) The number $10.001_2$ would be represented in the machine in floating point form as $2002\ 420000000000_8$ . This means the fractional part, converted to binary, $.1000100 - 0_2$ is to be multiplied by $2^2$ , or the binary point is to be moved two places to the right; $10.00100 - 0_2$ . To convert a number from decimal to machine floating binary, first convert the number to binary, then move the binary point to the left of the highest order non-zero binary digit keeping account of the number of places. 1. Convert $10.5625_{10}$ to machine floating binary: $$(A) \cdot 10_{10} = 1010_{-2}$$ 2. Convert .12510 to machine floating point binary: .125 $$\frac{2}{0.250}$$ .0 The machine exponent is 1775<sub>8</sub> $\frac{2}{0.500}$ .00 The fraction as octal is .400000000008 $\frac{2}{1.000}$ .001 The floating point machine word is 17754000000000008 .125<sub>10</sub> = .001<sub>2</sub> = .1\*2<sup>-2</sup> In the machine a negative number, both for fixed point and floating point, is represented as the complement of the positive number. -.125, then, would equal 602377777777778 and 10.5625 in floating point is 20045220000000008 -10.5625, then, would equal 57732557777777778 Arithmetic performed by the computer with operands packed in the floating-point format follows the normal algebraic rules. In addition and subtraction the terms are expressed with like exponents; the coefficients are then added or subtracted to obtain the coefficient of the answer, its exponent being the exponent of the terms. The product of two floating-point operands is a quantity whose coefficient is the product of the coefficients of the terms, and whose exponent is the sum of the operand exponents. Similarly, a floating-point quotient is a quantity whose coefficient is the quotient of the dividend coefficient divided by the divisor coefficient, with an exponent which is the difference of the exponents of the terms. The computer performs floating-point arithmetic by separating the exponents from the coefficients and performing the necessary operations on the two portions independently. The results of the two independent actions are assembled to obtain the final answer. Before the final result is assembled the computer inspects the fraction to determine if it is properly expressed for assembly. The most-significant bit of the fraction must be a "l", if not it is shifted until a "l" appears in this position, the exponent is adjusted to maintain the magnitude of the entire quantity. This operation is the "normalize" routine. Since the result of a floating-point instruction is expressed within the limits of the A register, the residue of the computation in Q must be inspected to determine if it is great enough to cause the fraction to be increased by one when expressed to the nearest 2° position. This is the "round" routine. Both normalize and round are performed automatically during the course of the execution of a floating point instruction. Returning to the six instructions at the start of the chapter, let us examine how these use the floating point formats. FLOATING ADD (FAD) (30.b) (where b may be 0 through 7) This instruction forms the sum of two 48-bit quantities which are packed in floating-point format. An operand is read from the storage location specified by the sum of the execution address and the contents of the designated index register and is added to the previous contents of the A register. The result is normalized and rounded in the A register at the end of the operation. The Q register contains the residue from the rounding operation at the end of the sequence. FLOATING SUBTRACT (FSB)(31.b)(where b may be 0 through 7) This instruction subtracts an operand in floating-point format from the previous contents of the A register, also in floating-point format. The operand is read from the storage location specified by the sum of the execution address and the contents of the designated index register. The result is normalized and rounded in the A register. The residue from the rounding operation is left in the Q register at the end of the sequence. FLOATING MULTIPLY (FMU) (32.b)(where b may be 0 through 7) This instruction forms the product of an operand in floating-point format with the previous contents of the A register, also in floating-point format. The operand is read from the storage location specified by the sum of the execution address and the contents of the designated index register. The result is normalized and rounded in A. The residue from the rounding operation is left in the Q register at the end of the sequence. FLOATING DIVIDE (FDV)(33.b)(where b may be 0 through 7) This instruction forms the quotient of two 48-bit quantities in fleating-point formst. The dividend must be loaded into the A register prior to the execution of this instruction. The divisor is read from the storage location specified by the sum of the execution address and the contents of the designated index register. The quotient is normalized and rounded in the A register at the end of the operation. The residue from the rounding operation is left in the Q register at the end of the operation. The following example indicates how the floating-point add functions: Example: Add 568 and 1228 in floating point. $56_8 = .101 \ 110. \quad (Exponent = + 6)$ floating-point format = 0 10 000 000 110.101 110€ >0 octal floating-point format for $56_8$ is, 2006.560000000000 $122_{2} \approx 00.1010010$ . (Exponent = +7) floating-point format is 0 10 000 000 111.1010010 >0 octal floating-point format for 1228 is, 2007.510000000000 Assume the first of these numbers (56<sub>8</sub>) is in the A register, and the second (122<sub>8</sub>) is in memory location 00100. The following instruction is given: FAD 0 00100 The following addition, normalizing, and rounding takes place: Since the exponents are different, one fraction must be shifted to make the exponents equivalent, before the fractional parts of the two floating-point words are added. The general procedure in this regard is to shift the smaller number right by difference of the two exponents. In the example, the two exponents (2006 and 2007) are compared and subtracted. The difference is 1. The number with the smaller exponent is then shifted right 1 bit. This is shown below: $56_8 = 2006.560000000000$ $122_8 = 2007.510000000000$ $2007 - 2006 \approx 1$ = difference in exponents, the larger exponent is stored (in this example, 2007 is stored). Shift the number of the smaller exponent right 1 bit. The number of too smaller exponent is .560000000000 (in octal) Shift right 1, gives .27000000000 (in octal) .270000000000 Adding the too number .510000000000 Octal sum of 2 fractional number is 1.00000000000 This sum must be normalized, which theoretically means moving the binary point to the left of the most-significant "1". In the example it is necessary to move the binary point one place to the left which means the stored exponent (2007) must be increased by 1, the number of shifts required. Shifted octal sum is .400000000000 And adding 1 to the stored exponent gives: 2007+1 = 2010 The sum is then rounded by inspecting the bit immediately to the right of the 36 bits of significance in the sum. If there is a "l" the 36th bit is changed; otherwise, the rounding has no effect. In the example, the rounding does not change the sum. (In machine rounding provision must be made for the case when rounding might possibly develop a carry all the way through the number.) The final result in A is 2010.40000000000 Check: $$56_8 + 122_8 = 200_8 = 2^8 \text{ (.48)} = 128_{10}$$ The preceding example indicates the large number of internal sequences required to execute a floating-point instruction. Although the machine process is more complex, the example indicates some of the problems the machine must solve in order to carry through a floating-point instruction. The last two instructions of this chapter are explained with the floating-point instructions since they involve scaling and they enable the programmer to simulate the normalizing process which takes place automatically in the floating-point processes. SCALE A (SCA) (34.b) (where b may be 0 through 7) This instruction shifts the quantity in the A register circularly to the left until the most-significant "1" is immediately to the right of the sign bit. The base execution address is reduced by the number of bit positions shifted. The shift is terminated if the base execution address becomes zero before the normalizing is completed. In any event, the reduced base execution address is then entered into the designated index register. SCALE AQ (SCQ) (35.b) (where b may be 0 through 7) This instruction shifts the quantity in the AQ register circularly to the left until the most-significant "I" is immediately to the right of the sign bit. The base execution address is reduced by the number of bit positions shifted. The shift is terminated if the base execution address becomes zero before the normalizing operation is completed. In any event, the reduced execution address is then entered into the designated index register. Either of these instructions can be used to indicate the scaling of numbers or results of arithmetic processes. Each instruction is so executed that the number of shifts to normalize is left in the designated index register. As shown in later examples this quantity is used to determine the exponent of a floating-point number. As an example of the use of one of these instructions, the SCALE A instruction is used to indicate the scaling of the number in the following example. Example: The quantity 4028 is in storage location 00100. Normalize and show the contents of the designated index register after the quantity is normalized. Given: Storage location 00100 contains: After loading this into A, the SCALE A instruction is executed. Instructions are: LDA 0 00100 SCA 3 00057 The SCALE A instruction shifts A left, and reduces the execution address (00057) by 1 on each left shift. The shift is terminated if the execution address becomes zero before the normalizing is completed. The reduced execution address is then entered into the designated index register (3 above). In the example, there will be 38 10 shifts required to put the contents of 00100 in normalized form as shown below: 38 bits 010 000 001 00 <--> 0 (normalized) Since $38_{10}$ shifts were required, the execution address (0057<sub>8</sub>) is reduced by $38_{10}^{2} = 46_{8}^{2} = 000578 - 00046_{8}^{2} = 00011_{8}^{2}$ . This reduced amount is submatically entered into the index register 3. Thus at the end of the execution, index register 3 contains: It should be noted that this reduced amount is exactly equivalent to the true floating-point exponent of the base 2. $$4028 = .100 000 010.$$ 9 shifts Thus $$402_8 - 2^9 (0.402_8)$$ The above example indicates a method which can be used by the programmer to pack binary numbers into the floating-point format. This chapter is concluded with an example "packing grutine" for positive whole numbers with positive exponents. The following routine packs a positive oldary whole number with a positive exponent in floating-point format and leaves it in Q. | | | | | | | | Load tirst word into A . | |----------|-----|-------|--------------------|----------------------------|---------------------------------|---------------------|-----------------------------------------------------------------------| | <b>*</b> | LDA | 0 | SL | AJP | 3 | NEG . | if negative, jump. | | 25 | SCA | 1 | *2057 | ALS | C | i | Normalize, then shift left 1. (see note below) | | <b>E</b> | STA | O | r | ENA | 1 | 0 | Store normalized number, enter floating point exponent into A. | | æ | LDQ | 0 | T | LRS | 0 | 14: | Load normalized number into Q, shift to floating point position in O. | | | E | = SCA | = SCA 1<br>= STA 0 | = SCA 1 *2057<br>= STA O T | = SCA 1 *2057 ALS = STA 0 T ENA | = SCA 1 *2057 ALS 0 | = SCA 1 *2057 ALS 0 1 = STA 0 T ENA 1 0 | \*Note by using 2057 in the execution address part of the SCALE A instruction, the sign of the exponent is contained along with the exponent after the normalizing has taken place. Thus in the above example, if the normalizing involved 50g shifts, then ## EXERCISES 13. - Change the following to 180% floating-point format - (1) - -15610 (2) - (3) (4) 0,45<sup>00</sup> - Change the following floating-point numbers to octal b. equivalents - (1) 2010,612000000000 - (2) 2772, 31777777777 - c. Assume SI contains a number which can be expressed in 1604 floating-point format as a positive number with positive exponent. Write a program which will 'pack this' number in 1604 floating-point format. ## CHAPTER VII #### SIXTH GROUP OF INSTRUCTIONS A description of the input-output section is a prerequisite to a discussion of Group Six instructions. Communication of data between the computer and external equipment is carried out in either of two modes of operation. The first and most frequently used method is buffering. The most important feature of buffer communication is that individual words are exchanged independently from the main computer program. Once the main program prepares for and initiates a buffer operation, no further main-program attention is required. Computation continues and is suspended for brief periods whenever individual words are taken from or entered into the storage section of the computer. The second method of communication is the high-speed transfer, used in exchanging data between computers or other special external equipment. Transfer communication is accomplished under main program control, and thus computation may not continue independently during the transfer of words, as was the case for buffering. For this reason, the transfer instructions are used only with equipment capable of handling data at a very rapid rate. There are six 48-bit channels for use in buffering. Channels 1, 3, and 5 are for input, while channels 2, 4, and 6 are for output. The high-speed transfer uses channel 7 for both input and output. The external equipment at the 1604 console (reader, punch, and typewriter) are connected to buffer channels 1 and 2. Channels 3, 4, 5, and 6 may provide connection to a 1604 magnetic tape system and to the 1605 adaptor and thereby to several external IBM equipments or other peripheral devices. Buffer operations involve the manipulation of blocks of data, where a block may range from one word to several thousand. The size of a block is determined by specifying the initial and terminal storage address + 1 which is to be used. Each buffer channel operates asynchronous with the computer program and the other channels. All channels are treated with equal priority by a scanner which sweeps sequentially through all buffer controls every 3.2 microseconds. If a channel requires processing, the scanner stops while the word is transferred and then resumes scanning to the next channel. In the event that all channels should simultaneously request action the last would be processed in a maximum of 240 microseconds. This time limits the rate of communications to a 5 KC word rate per channel if all channels are used simultaneously. The detail sequencing of a buffer operation is coordinated by a special buffer control section in the central computer. control utilizes a special address in storage for each communication channel. These special addresses (00001 - 00006) contain the current storage address for buffering data and a terminal address for stopping the transfer at the end of the block of data. Only the upper and lower address portions of these special storage locations are treated as significant by the buffer control. The terminal address, which is one greater than the address of the last word transferred, must be entered in the lower address position of the control word prior to the initiation of the buffer action. This entry may be made by either a substitute lower address (61) or by a simple store instruction since the quantity appears in the lowest 15 bits of the word in storage. The storage address of the first word in the block to be buffered is entered into the appropriate control word by the external function instruction (74) which initiates the buffer operation. This address is entered much like a substitute upper address instruction (60) and does not alter the other bits in the control word. Each word transferred during a buffer operation requires the execution of three storage references. The first reference reads the appropriate control word from the special storage address and extracts from the upper address position from the current storage location for the word data being buffered. The address is then used for the second storage reference which transfers the data to (or from) the central storage unit. A third reference is then made to replace in the upper address position the current buffer address with its initial value plus one. The current and terminal addresses are compared and if they are equal the buffer operation is terminated. The status of a buffer operation may be monitored by the computer program during the buffer operation. This is accomplished by a normal reference to the appropriate control word and a comparison of the current buffer address with the terminal address. The buffer operation is completed when the current address is equal to the terminal address. SIXTH GROUP OF INSTRUCTIONS (With Mnemonic and Numeric Codes)(where "b" represents the index designator which can be of any number 0 through 7) EXTERNAL FUNCTION (EXF.b) (74.b) INPUT TRANSFER (INT.b) (62.b) OUTPUT TRANSFER (OUT.b) (63.b) These instructions are used to transfer information into the computer from some external equipment or out of the computer to some external equipment. The first instruction is a buffer instruction and is used with most of the input-output equipment. The last two instructions utilize a special communication channel and are provided primarily to facilitate the high-speed transfer of information between the memories of two or more 1604 computers or other similar data transfer requirement. ## EXTERNAL FUNCTION (EXF.b)(74.b)(where b may be 0 through 7) This instruction has eight sub-instructions which are used to control the transfer of information between the computer and input-output equipments. The index registers are not used for address modification in this instruction. The index designator is used to specify which one of the eight sub-instructions is to be performed. The sub-instructions and the operation performed by each are: - 74.0 Select external equipment - 74.1 Activate communication channel one - 74.2 Activate communication channel two - 74.3 Activate communication channel three - 74.4 Activate communication channel four - 74.5 Activate communication channel five - 74.6 Activate communication channel six - 74.7 Sense external condition Execution of a 74.1 through 74.6 sub-instruction initiates the buffering of a block of data between the computer and a previously selected external equipment. The base execution address of such an instruction designates the starting address in computer storage. Thus, if the current instruction is 74 2 05000, an output buffer is initiated on channel 2. The first word to be sent out is taken from address 05000. During the execution of 74.2, the initial address for the buffer, in this example 05000, is stored at the upper address position of storage address 00002, the terminal address plus one having previously been entered into the lower address position at 00002. Thus if 100 (octal) words are to be buffered out, beginning at address 05000, then the terminal address is 05100. This address quantity, 05100, was entered in the lower position at 00002 by a 61 instruction that has been executed prior to the 74.2. As a result the last word to be buffered is taken from address 05077. A 74.0, or external select instruction, provides for transmitting control information or codes to the control section of an external equipment. Such codes cause the equipment to prepare for the transfer of data to or from the computer. The computer may sense the status of the external equipment by means of the 74.7 external sense instruction. For both the 74.0 and the 74.7 instructions the base execution address is used to specify the channel, equipment, and condition. The interpretation of the various digits of the execution address for a 74.0 or 74.7 instruction is shown in Figure 16. The upper three bits are interpreted in the computer to determine the channel that is to receive the remaining 12 bits. The latter bits are called the "external select" code for 74.0 and the "external sense" code for 74.7. The various select and sense codes used with external equipment appear at the end of this chapter. Figure 16. Interpretation of Octal Digits in External Function Instruction The case of a 74.0 or 74.7 instruction when the upper octal digit of the execution address is 0, is a special one. This involves no communication with external equipment, but instead provides for examining computer fault conditions. An example of 74.0 external select instruction is the following #### 74 0 11200 Execution of this instruction sends the code 1200 (the lower four octal digits of the execution address) to the equipment connected to channel 1 at the 1604 console. The code 1200 selects the paper tape reader which is connected to channel 1. As a result, the reader is prepared to begin operation as soon as a 74.1 instruction (activate communication channel 1) is executed. The 74.7 instruction, which senses a computer fault or a condition in an external equipment, is always used as the upper instruction. This follows from the fact that the lower instruction is skipped on the basis of the results of sensing the presence or absence of the specified condition. For each specified condition two sense codes are provided. They are identical except for the lowest digit. The code with an even digit in the lowest position senses the presence of the condition, that is, a positive response results when the condition does not exist. The code with an odd digit in the lowest position senses the absence of the condition and a positive response results. In either case a positive response causes the next, that is, the lower, instruction to be skipped. A typical use of the 74.7 instruction is in sensing whether a tape unit in the 1604 magnetic tape system is ready to read. The instruction format is as follows #### 74 7 32010 Execution of this instruction sends the code 20j0 to tape unit j of the 1604 tape system. If this tape unit is ready to read, a positive response is returned to the computer. As a result, the next, that is, the lower, instruction is skipped. If the tape unit is not ready to read, a negative response is sent back and the computer executes the lower instruction. An alternative method for sensing the same condition uses the following format: ## 74 7 32011 The difference in the lowest digit means that if tape unit j is ready to read, a positive response is sent back. If it is not ready a negative response is sent to the computer. The 74.7 instruction with an even sense code is quite typically used with a jump as the lower instruction. The jump would enter a routine for handling the specified condition. The jump instruction is skipped unless the condition sensed by the 74.7 is present. Such a use of an even external sense code and a jump as the lower instruction is convenient for cases where several conditions are to be sensed in a successive manner. The 74.7 with an add sense code affords another option which is useful in other circumstances. The individual external equipments interpret the equipment selection digit in an external function. Each equipment recognizes its own code. The remaining nine bits of the external control cable are then sampled by the selected external device. The external equipment is continually monitoring these control lines. No resume signal is sent back to the computer indicating receipt of the information. However, an external sense code causes the equipment to produce a responding signal on the sense return line when the condition specified by the code is present. INPUT TRANSFER (INT.b)(62.b)(where b may be 0 through 7) This instruction transfers a block of data from an external equipment into the central computer storage. This transfer utilizes a special communication channel of 48 lines and is intended for a very rapid transfer of data between the memories of two or more 1604 computers or other similar data transfer situations. The number of words transferred is specified by the contents of the designated index register. The words are stored in consecutive locations beginning at the location specified by the base execution address. The first word received is stored at the last address. For each word transferred the designated index register is reduced by one. Thus the index register is cleared at the end of the transfer. If the index code is zero, one word is transferred. If the contents of the designated index register are zero, no transfer takes place. # OUTPUT TRANSFER (OUT.b)(63.b)(where b may be 0 through 7) This instruction transfers a block of data from the central computer storage to an external equipment. This transfer utilizes a special communication channel of 48 lines and is intended for very rapid transfer of data between the memories of two or more 1604 computers or other similar data transfer The number of words transferred is specified by the situations. The words are content of the designated index register. located in a consecutive list beginning at the location specified The first word transferred out by the base execution address. For each word transferred is obtained from the last address. the designated index register is reduced by one. index register is cleared at the end of the transfer. If the contents index code is zero, one word is transferred. of the designated index register are zero, no transfer takes place. #### EXAMPLE Write a program which will load 100 (octal) words from paper tape and store it in consecutive addresses beginning at address 200. Assume that words are to be loaded in the assembly mode. Begin program at address 00050. (The external select and sense codes used with 74.0 and 74.7 sub-instructions appear at the end of the chapter.) | 00050 | 74 7 11220 | <b>75000</b> 050 | |-------|------------|------------------| | 00051 | 10 0 00300 | 20000001 | | 00052 | 74 7 11201 | 76000052 | | 00053 | 74 0 11200 | 74100200 | | 00054 | 74 7 11220 | 75000054 | | 00055 | 76 0 00050 | 00000000 | #### EXPLANATION. If this is a routine in the middle of a program, then at the time the routine is to be executed some piece of input-output equipment on channel 1 may be receiving information; so the first program step tests channel 1 to ensure that information is not being buffered at this time. If information is being buffered an unconditional jump back to the sense instruction is executed, and this step will be repeated until all the information has been buffered. When this happens, the lower portion of step 00050 is skipped and step 00051 is executed. This step loads A with the last address plus one at which the information will be stored, and the lower instruction of step 00051 stores this address in the lower portion of address 00001. Step 00052 then senses the paper tape reader to ensure that the reader is in the assembly mode. If it is not, the lower portion of Step 00052 is executed, which is an unconditional stop so that the operator may throw the switch which will put the reader in the assembly mode. If the reader is already in the assembly mode the stop instruction is skipped and step 00053 is executed. The upper portion of step 00055 selects the paper tape reader. The lower portion then selects the channel by means of the index designator and the first address at which to store the incoming information by means of the base execution address. These are all the steps that are necessary to activate the buffer. One could now do computation or set up a buffer on a different channel. However, in this case we chose to simply load in the words and stop the computer. Since the buffering action will cease if the computer is stopped, we must test to determine when all 100 (octal) words have been loaded. This is accomplished by the same method as explained in the beginning of this example. Once the end of the buffer has been sensed, the program executes step 00055 which stops the computer. #### EXAMPLE Using the high speed transfer instruction, write the step for transferring 50 (octal) words from an external equipment to memory. Store the last word at address 00300. Where will the first word be stored? 01000 50 1 00050 62 1 00300 #### EXPLANATION ١ Index register one is loaded with the number of words to be transferred. The first word will be stored in the address which is the sum of the base execution address of the input transfer instructions and the content of the designated index register. However, since the index register is reduced one before this transfer takes place, the first word will be stored at address 00347, the next word at 00346, etc. The last word will be transferred when the index register one equals zero so that it will be stored at address 00300. #### USE OF 74.7 INSTRUCTION The 74.7 external function instruction may be used in either the upper or lower positions. When used in the upper position, a 74.7 is a skip instruction. That is, the lower instruction is skipped if the condition given by the EF code is present, but the lower instruction is executed if the condition given by the EF code is not present. In the first case, the 74.7 "exits" to the next pair of instructions. In the second case, the 74.7 "half exits" to the lower instruction. When the 74.7 is used in the lower position, it is not a skip instruction. Instead the 74.7 is simply executed repeatedly until the condition given by the EF code occurs. At this time the 74.7 exits to the next pair of instructions. Until the condition given by the EF code is present, the 74.7 simply half exits to repeat itself. A 74.7 in the lower position is therefore a means of awaiting the occurrence of a specified condition. Throughout the attached list of sense codes, the term "exit" and "half exit" are used with the meaning indicated above. An exit is performed if the stated condition is present; if not present, a half exit is performed. Any lxxxx select code clears all previous selections on channel 1. Likewise, any 2xxxx select code clears all previous selections on channel 2. #### EXTERNAL FUNCTION CODES The attached lists present external function codes for the following: | CODE | CONDITION | |-------|-----------| | 0xxxx | Internal | | 1xxxx | Channel 1 | | 2xxxx | Channel 2 | #### Internal Select 0x010 - Select interrupt on channel 1 inactive 0x011 - Remove selection 0x020 - Select interrupt on channel 2 inactive 0x021 - Remove selection 0x030 - Select interrupt on channel 3 inactive 0x031 - Remove selection 0x040 - Select interrupt on channel 4 inactive 0x041 - Remove selection 0x050 - Select interrupt on channel 5 inactive 0x051 - Remove selection 0x060 - Select interrupt on channel 6 inactive 0x061 - Remove selection 0x07x - Clear arithmetic faults. 0x100 - Select interrupt on arithmetic fault 0x101 - Remove selection Olxxx - Start clock 02xxx - Stop clock Internal Sense 0x010 - Channel 1 active 0x011 - Channel 1 inactive 0x020 - Channel 2 active 0x021 - Channel 2 inactive 0x030 - Channel 3 active 0x031 - Channel 3 inactive 0x040 - Channel 4 active 0x041 - Channel 4 inactive 0x050 - Channel 5 active 0x051 - Channel 5 inactive 0x060 - Channel 6 active 0x061 - Channel 6 inactive 0x110 - Divide fault 0x111 - No divide fault 0x120 - Shift fault 0x121 - No shift fault 0x130 - Overflow fault 0x131 - No overflow fault 0x140 - Exponent fault 0x141 - No exponent fault Channel 1 Select 1110x - Keyboard entry 1114x - Keyboard entry and interrupt on carriage return 1120x - PT reader 1121x - PT reader and end-of-tape indicator 1122x - PT reader and interrupt on end-of-tape Channel 2 Select 2110x - Print assembly mode 2111x - Print character mode 2120x - Punch assembly mode 2121x - Punch character mode 2124x - Turn punch motor off Channel 1 Sense 11100 - Keyboard carriage return 11101 - No keyboard carriage return 11140 - Keyboard lower case 11141 - Keyboard upper case 11200 - PT reader, end-of-tape 11201 - PT reader, no end-of-tape 11210 - PT reader, assembly mode 11211 - PT reader, character mode Channel 2 Sense 212x0 - Punch, end-of-tape 212x1 - Punch, no end-of-tape ## APPENDIX A ## RESULTS OF EXERCISES EXERCISES I (solutions) a. QRS 0 00016 Alternative Solution: An Index designation other than zero may be used if the octal sum of the contents of the designated index register and the execution address equals the desired shift count. - b. 00000220 00000436 - QRS 0 00007 QLS 0 00014 (See alternative solution above) - d. ALS 0 00053 (See alternative solution above) since no bits are to be discarded, one must use equivalent left shift. (48 - 5 = 43 decimal shifts required.) e. No. Since the end-off shift discards some bits, the two results can not be the same. #### EXERCISES 2 (solutions) a. This is the LOAD A instruction. Since index register 3 is designated, the instruction will load the contents of address 00015 (00010 + 00005) into the A register. This address is the sum of the execution address (00010) and the contents of index register 3 (00005). | 1 | | | | | |----|-------|-------|-------|-------| | b. | LDQ 0 | 01000 | STQ 0 | 01001 | The upper instruction loads the contents of address 01000 into Q. The lower instruction then stores the contents of Q at location 01001. (Alternative solutions are possible by using index registers whose contents added to the contents of other execution addresses would give the execution addresses above.) Since the A register was not to be disturbed, the Q instructions were used. c. The instruction given STA 2 0 0 0 2 0 stores the contents of the A register in a location equivalent to the sum of the execution address (00020, above) and the contents of the designated index register (2). Since index register 2 contains 77767, and execution address is 00020, the location of the operand is equal to the sum below. | address (00020) | | 00020 | |----------------------------------|---|-------| | contents of index register 2 | | 77767 | | one's complement with end-around | 1 | 00007 | | carry in this | | 1 | | case, to give | | 00010 | Therefore the given instruction will store the contents of the A register in address 00010. d. When LOAD instructions are given, the initial contents of A or Q are destroyed since this register is cleared before the LOAD operation is executed. When STORE instructions are given, the initial contents of A or Q are not disturbed by the execution of the instruction. # EXERCISES 3 (solutions) a. ADD 0 0 0 0 3 0 | b. | (K) = | SUB 0 | 0 0 0 4 1 | SUB 0 | 0 0 0 4 2 | |----|---------|-------|-----------|-------|-----------| | | (K+1) = | ADD 0 | 0 0 0 4 3 | ADD 0 | 0 0 0 4 4 | | c. | Yes. | | | | | | | 00100 | AJP l | 00101 | QJP 0 | 0 0 0 5 0 | e. The upper instruction is a Return Jump since the index designator 6 calls for a Return Jump if A contents are positive. The location of the Return Jump instruction (00304) is increased by 1 (to 00305) and this goes to the execution address portion of the upper instruction at step 00010. A jump then occurs to the lower instruction of step 00010. ## EXERCISES 4 (solutions) a. INITIAL CONTENTS of A and Q were given as: | Ъ. | INITIAL | CONTENTS | of | A | and | 0 | were | given | as: | |----|---------|----------|----|---|-----|---|------|-------|-----| |----|---------|----------|----|---|-----|---|------|-------|-----| Final Contents of A and Q A Register 000000007777777 Q Register 7777777700000000 - c. Given: Index Register 5 contains 0 1 3 2 6 Address 01111 contains 000000000007562 - 1. ENA 5 0 0 0 0 0 0 After this ENTER A instruction, the contents of A will be: 0 0 0 0 0 0 0 0 0 0 0 0 1 3 2 6 2. ENA 5 0 0 1 0 0 After this ENTER A instruction, the contents of A will be: 0000000000001426 - d. 1. TRUE (Two instructions would be needed) - 2. TRUE (Unless overflow takes place) - 3. FALSE (One uses contents of execution address, other uses execution address as operand) - 4. FALSE (It can just as well send a negative to Q) - - 2. After 1 7 0 0 0 2 0 0 Q will contain: 77777777770000 - 3. After 1 6 0 0 0 2 0 0 Q will contain: 0000000000007777 ## EXERCISES 5. (solutions) "Increase A" by this amount 7 7 7 7 7 7 7 7 7 7 7 7 7 7 0 1 3 5 Contents of A will be 7 7 7 7 7 7 7 7 7 7 7 1 1 3 5 b. (00100) ENA 2 0 0 0 0 0 MUI 0 0 0 0 5 0 Code for Enter A Code for Integer Multiply First enter contents of index register 2 into A (the multiplier). Then multiply using contents of 00050 as multiplicand. - c. 1. False (Final content of A is part of the product.) - 2. True (Otherwise one would not know the multiplier) - 3. False (Product of two 48 bit factors cannot overflow 96 bits) - d. The dividend is contained in Q and A and is given: The given instruction divides the contents of 00100 into this. Address 00100 contains 0 0 0 0 0 0 0 0 0 0 0 0 0 3. After the divide, the following quantities will be left in the A and $\hat{Q}$ registers and address 00100. e. (00040) = | INA 2 | 0 0 0 0 0 | ADD 5 | 0 0 0 0 0 The first instruction "increases A" by the contents of index register 2. The second instruction adds to A the contents of the address located at index register 5. Note the execution addresses above are each zero which reduces each instruction to a function of the contents of the index registers involved. However, INCREASE A uses the contents of the index register as the operand; whereas, ADD uses the contents of the index register as the address of the operand. ## EXERCISES 6. (solutions) a. (00020) = SLJ 4 0 0 0 7 2 Some other instruction (00072) = SLJ 0 First Instr. of Sub-Routine (00105) = Last Instr. of Sub- SLJ 0 0 0 0 7 2 Routine Explanation: The SELECTIVE JUMP with index designation 4 is an Unconditional Return Jump which stores contents of Program Address Register plus one (00021) in the upper instruction at 00072 and the jump goes to the lower instruction at 00072. The exit at 00105 jumps back to 00072 whence another jump goes back to 00021. b. (00112) = LDA 0 0 0 0 2 3 SAU 0 0 0 0 2 2 (00113) = ALS 0 0 0 0 1 1 SAL 0 0 0 0 2 2 The first instruction LOADS A with 000000000000001. The second instruction SUBSTITUTES the low order 15 bits of A (00001) into the execution address portion of the upper side of 00022. Then A is shifted left nine places to become 000000000001000. Again the low order 15 bits of A (01000) are SUBSTITUTED into the address portion of the lower side of 00022. Contents of Index Register 5 are first sent to A. The A register is tested for positive contents. If positive jump goes to 00421; if not to 00420. At 00420 contents of 00100 are added to A and jump goes to 00700. At (00421), the contents of A are stored at 00047 and jump goes to 00700 if Jump Key 2 is set. If neither key is set, it will perform TASK G and TASK H. If Jump Key lis set and Jump Key 2 not set, it will skip TASK G and do TASK H. If Jump Key 1 is not set and Jump Key 2 is set, it will do TASK G and skip TASK H. If Jump Key 1 is set and Jump Key 2 is set, it will skip both tasks. ## EXERCISES 7. (solutions) $$(00033) = SLJ 0 0 0 2 0 0 Some Other Instr.$$ ### b. Given Jump Key 2 not set The first instruction tests the contents of 00100 for sign. If negative, the next instruction (7 5 2 0 0 2 0 0) is skipped. If positive, the next instruction is interpreted but since Jump Key 2 is not set, the jump will not occur to 00200. Therefore, in either case the instruction 7 5 2 0 0 2 0 0 is skipped until. Jump Key 2 is set on the console. The STORAGE SHIFT at step (00015) tests the sign of the last bit of the unknown digit. If positive (even in this case) the next instruction jumps to 00200. If negative (odd in this case) the instruction at 00016 is the next step to be performed. The first instruction tests the contents of index register 5 against the number in the execution address $(100_{10})$ . If not equal, the jump to 00050 occurs. If equal, the next instruction is skipped and the jump to 00200 occurs. THIS PAGE HAS BEEN DELETED. ## EXERCISES 8 (solutions) Load A with logical Load Q with product of Q and contents a. extractor of 01012 (c) LDQ 0 0 0 0 5 4 LDL 0 0 1 0 1 2 Jump if content Enter zeros into A of A is zero register (c+1) =AJP 0 (c+k) ENA 0 00000 Store the zeros in A in 01012 0 1 0 1 2 (c+2) =STA 0 (Alternative solutions are possible) Extractor at 00054 40 40 40 40 40 40 40 Ъ. (A) 1 2 0 0 0 0 0 0 0 0 0 0 0 0 0 Given: 4 5 3 0 0 0 0 0 2 0 0 0 1 0 0 (00111) =0 0 7 0 0 0 0 0 0 0 0 0 0 0 0 (Q) Index Reg. 3 00111 **->** |1 2 3 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Final Contents of A - Explanation: The given instruction at (00111) forms a logical product of the operand located at the sum of the execution address (00000) and the contents of index register 3 (00111), and the contents of Q. Thus the logical product formation takes place between contents of Q and contents of 00111. This gives the result 0030000000000. When this is added to A, the final result is obtained. The second instruction in the step does not affect the contents of A - it stores A at 00100. c. Given (00712) contains X X X X . . . . . $x_{16}$ where each X is an octal digit of 3 bits. The problem is to reduce this quantity by the sum of $x_1$ and $x_{16}$ . - d. (1) Yes. - (2) No. A bit-by-bit product cannot exceed the number of bits in each of the factors. - (3) No. Since the positive factor will generate a positive bit in sign of product regardless of other factor. # EXERCISES 9. (solutions) a. Given: Zone rates in index registers 1 through 4. Flat rate in index register 6. | | Store index | Store index | | | |-----------|-----------------------|-------------------|--|--| | | register l | register 2 | | | | (00100) = | SIL 1 0 0 1 0 2 | SIU 2 0 0 1 0 3 | | | | | | | | | | | Store index | Store index | | | | | register 3 | register 4 | | | | (00101) = | SIL 3 00103 | SIU 4 0 0 1 0 4 1 | | | | | | | | | | | Store index | Enter index | | | | | register 6 | register 5 | | | | (00102) = | SIL 6 00104 | ENI 5 (0 0 0 0 0) | | | | , | | | | | | | Increase index | Increase index | | | | | register 5 | register 5 | | | | (00103) = | INI 5 (0 0 0 0 0) | INI 5 (0 0 0 0 0) | | | | | | | | | | | Increase index | Increase index | | | | | register 5 register 5 | | | | | (00104) = | INI 5 (0 0 0 0 0) | INI 5 (0 0 0 0 0) | | | | • | | | | | | | | | | | | | | | | | | (00105) = | Continue Program | | | | | | | | | | Explanation: The first five instructions store the contents of index register 1, 2, 3, 4, and 6, respectively, in consecutive instructions starting with the lower instruction of step 0 0 1 0 2. The next instruction enters index register 5 with the contents of index register 1. The last four instructions increase the contents of register 5 by the contents of index registers 2, 3, 4, and 6, respectively. The desired rate is then found in index register 5. b. c. Clear A | 0 0 | 0 0 | ENI O | 0 0 0 0 0 | |-------|-----------------------------------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------| | 0 0 | 0 0 | QJP 7 | 0 0 1 6 4 | | 0 0 0 | 0 0 | QJP 7 | 00164 | | 0 0 0 | 0 0 | QJP 7 | 0 0 1 6 4 | | 0 0 0 | 0 0 | QJP 7 | 00164 | | 0 0 0 | 0 0 | QJP 7 | 00164 | | 0 0 | 0 0 | | 00164 | | | | | 00000 | | | | | 0 0 0 0 1 | | ~ ~ | | | | | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O O O O O QJP 7 | Explanation: The A-register is cleared to use as a counter. The contents of each index register are entered into the Q-register. Q is then tested to see if it contains a negative number. negative, a return jump is made to a subroutine which adds one to the A-register (counter). After all index registers have been tested, the A-register will contain the number of negative index registers. The first instruction enters the contents of index Explanation: register 2 into (A). (A) now appears as: These octal digits come from index register 2 (A) is now shifted left 13 (octal) or 39<sub>10</sub> bit positions. (A) now contains 0 0 X 0 0 0 0 0 0 0 0 0 0 0 0 The contents of (00026) are then added to A which modifies the upper instruction by adding the digit (X) to the operation code bits (left nine bits) of the upper instruction. The result is then stored in 00026. Enter Index Register Increases (A) by d. 6 in (A) contents of Index Register 4 (c) 00000 ENA 6 INA 4 00000 Store (Q) in Add contents of 00050 (which=Q) 00050 to contents of (A) Register (c+1) =STQ 0 00050 ADD 0 0 0 0 5 0 Loads Index Register 6 with Store (A) at 00050 Lower 5 Octal Digits of (00050) (c+2) =STA 0 00050 LIL 6 0 0 0 5 0 Explanation: The first instruction enters contents of index register 6 into the A register. The second instruction INCREASES A by the contents of index register 4. The contents of Q are sent to (00050). Then (00050) is added to A. (A) now contains the sum of index register 6 and 4 and the contents of Q. This sum is stored in 00050. Address 00050 now contains: The last instruction, LOAD INDEX LOWER, loads index register 6 with the LOWER order 15 bits (5 octal digits) of 00050. e. (00600) ENI 3 0 0 0 5 1 ENI 0 0 0 0 0 0 0 (00601) LDA 3 0 0 0 0 0 STA 3 0 0 3 7 7 (00602) IJP 3 0 0 6 0 1 Continue program Explanation: First index register 3 is set to total number of steps minus one. Then the subroutine is transferred to the new location, starting with the last step and ending with the first. Alternative Solution for problem of Exercise 9e. | | register 3 contains register 2 contains | 0 0 3 7 7<br>0 0 0 0 0 | |-----------|------------------------------------------|---------------------------------------| | | Store index register<br>2 in upper 00601 | Store index register 3 in lower 00601 | | (00600) = | SIU 2 0 0 6 0 1 | SIL 3 0 0 6 0 1 | | | Dummy Load | Dummy Store | | (00601) = | LDA 0 (0 0 0 0 0) | STA 0 (0 0 0 0 0) | | | Index Skip | Pass | | (00602) = | ISK 2 0 0 0 5 1 | ENI 0 00000 | | | Index Skip | Unconditional Jump Back to (00600) | | (00603) = | ISK 3 0 0 4 5 0 | SLJ 0 0 0 6 0 0 | Two index registers are used and are each increased by one in the INDEX SKIP instructions in (00602) and (00603). Also note the PASS following the first INDEX SKIP. This works here since the record INDEX SKIP instruction at (00603) acts as the true barometer as to when to exit. Otherwise the PASS at (00602) would not be able to be used. Why can't the second INDEX SKIP INSTRUCTION be moved into the right side of 00602 and eliminate the PASS 2 # EXERCISES 10 (solutions) a. Assume contents of (00025) = XXX000000000000 (Note 37.5% is equivalent to 0.3 in octal) which is $140 \longleftrightarrow 0$ in fractional format | (00050) | LDA O | 00026 | MUF 0 00025 | |---------|-------|-----------|-------------| | (00051) | LRS 0 | 0 0 0 4 6 | STA 0 00100 | | (00052) | ENA O | 0 0 0 0 1 | SUB 0 00100 | | (00053) | STA 0 | 00100 | Continue | Explanation: First the multiplier is entered into the A-register. Then the Multiply Fractional is performed. The result is shifted so that it is in the lower part of A and rounding off is performed if it is necessary. b. Mask (00070) = 0.0000000000000007 | Start | (00200) | ENI 1 | 0 | 0 0 | 1 | 7 | ENI O | 0 0 | 0 | 0 | 0 | |-------|---------|---------|------|------|----|---|-------|-----|---|---|---| | | (00201) | LDA 1 | 0 | 0 0 | 1 | 1 | АЈР 2 | 0 0 | 2 | 0 | 3 | | | (00202) | SST 0 | 0 | 0 0 | 7 | 0 | SLJ 0 | 0 0 | 2 | 0 | 4 | | • | (00203) | SCL 0 | 0 | 0 0 | 7 | 0 | ENI O | 0 0 | 0 | 0 | 0 | | | (00204) | STA 1 | 0 ( | 0 0 | 1 | 1 | IJP 1 | 0 0 | 2 | 0 | 1 | | | (00205) | Continu | e pi | rogi | an | 1 | | | | | | Explanation: Each quantity to be tested is entered into the A-register and tested to see whether it is positive. If the quantity is positive, a jump is made to step 00203 where the lower three bits of the quantity are cleared. If the quantity is negative, the lower three bits are set at step 00202. In either case, the quantity is stored at its original location and an index jump is made to test the next quantity. | c. | Load Q with extractor in 00070 | L(Q) (00014)<br>to A register | |-----------|------------------------------------|-----------------------------------------| | (00100) = | LDQ 0 0 0 0 7 0 | LDL 0 00014 | | | Store 15 bits in 00071 | Shift 15 bits in A to leftmost position | | (00101) = | STA 0 0 0 0 7 1 | ALS 0 00041 | | | | | | | Jump if A is positive | Complement upper 15 bits of A | | (00102) = | AJP 2 0 0 1 0 3 | SCM 0 0 0 0 7 3 | | | | | | | Shift 15 bits to original position | Add contents of index register 3 to A | | (00103) = | ALS 0 0 0 0 1 7 | INA 3 0 0 0 0 0 | | | | | | | Store A | Enter index register 3 | | (00104) = | STA 0 0 0 0 72 | LIL 3 0 0 0 7 2 | | | | | | | Stop | | | (00105) = | SLS 0 0 0 1 0 0 | | Extractor in 00070 is 00000000077777 For complementing 00073 is 7777700000000000 <u>Explanation:</u> The steps above contain descriptions of the functions performed. | (00050) | ENI 1 0 0 0 0 0 | ENA 0 00000 | Clear index; clear A | |---------|-----------------|-------------|---------------------------------------------------| | (00051) | LDQ 0 0 0 1 0 0 | ENI 0 00000 | (00100) → Q; Pass | | (00052) | LLS 0 0 0 0 0 3 | AJP 1 00055 | One digit $\longrightarrow$ A; jump if A $\neq$ 0 | | (00053) | ISK 1 0 0 0 1 7 | SLJ 0 00052 | Skip if all digits tested; jump | | (00054) | ENI 1 0 0 0 2 0 | ENI 0 00000 | Enter 16 <sub>10</sub> into ind. reg. 1; pass | | (00055) | Exit | | | Count will be in index register 1 Explanation: Index register 1 and the A-register are cleared. The number to be tested is entered into the Q register. One octal digit is shifted into A. If A is not zero, a jump is made to the exit. If A is zero, this is a non-significant zero, so the count is increased by one and a jump is made to shift the next octal digit into A and test it. If the number to be tested contained sixteen zeros, index register 1 would be cleared to zero. That is why, at step 00054, index register 1 is set to 208. e. Enter Contents of Replace Contents of Ind. Reg. 4 Ind. Reg. 4 into (A) by 15 Rightmost bits of 00100 (00300) = ENA 4 0 0 0 0 0 LIL 4 0 0 1 0 0 Substitute Low Order 15 Bits in (A) into Rightmost 15 Bits of 00100 (00301) = SAL 0 0 0 1 0 0 Explanation: Although the above program is short, there are one or two critical conditions which must be satisfied. First, in order to exchange parts of two addresses one part must be sent somewhere else before the exchange begins. In this case the contents of index register 4 are first sent to the A- register. To transfer the contents ## e. (Continued) of A to the contents of 00100 without disturbing the other bits requires an instruction similar to the SUBSTITUTE ADDRESS instruction above (SAL 0 0 0 1 0 0). Note that a "STORE A" instruction cannot be used since it would erase the other bits in 00100. The "LOAD INDEX LOWER" instruction above (LIL 4 0 0 1 0 0) replaces the contents of index register 4 by the 15 rightmost bits of the contents of 00100. ## EXERCISES 11 Given the following: ``` 00100 002001 00101 Contain 5010 Contain 5010 00201 Accounts Accounts "C" ııDıı 00161 00261 If any of Accounts "C" = Accounts "D", put a 1 in (00032) Enter 50<sub>10</sub> into Load Contents of (00100) Index Reg. 3 into A Register (00400) ENT 3 0 0 0 6 2 LDA 0 (0\ 0\ 1\ 0\ 0) Equality Search If Account "C" in "A" Does not equal Starting at 00200 any Account in "D", Jump to (00404). (00401) EOS 3 0 0 2 0 0 SLJ 0 00404 Enter 1 into Store Q in Reg. 00032 Q kegister (This puts a 1 there) (00402) ENQ 0 0 0 0 0 1 STQ 0 0 0 0 3 2 STOP PASS (00403) SLS 0 0 0 4 0 0 ENI 0 00000 Increase "A" by I. Put Stop 00400 increases the Account "C" into A Register storage location Reference by 1. (00404) LDA 0 0 0 4 0 0 INA 0 00001 Store "A" in 00400. Subtract Contents This modified the step of (00050) from "A" (00405) STA 0 0 0 4 0 0 SUB 0 00050 Storage address 00050 contains, 503 00062 120 00162. This will be the quantity tested, in "A", when all accounts are searched. Jump Back to 00400 if "A" is not zero (00406) 0 0 4 0 0 Continue Program AJP 1 ``` b. Put Contents of (00201) into "A" Reg. Pass (c) 0 0 0 0 1 ENI C 00000 Threshold Search, if (00200) > (A) →(c+2) Jump to (c+3), if (00200) is not greater than (A) (c+1)THS 0 0 0 2 0 0 SLJ 0 Jump to (00400). Since (00200) > (00201)Pass (c+2)SLI 0 00400 ENT 0 0 0 0 0 0 Equality Search, if (00209) = (A)(c+v) Jump to some location (c±3) = EQS 0 0 0 2 9 9 Jump Exit for program following the condition that Jump to (00500), Since (00200) is less than (00200) = (A) = (00201)Pass (00201) SEJ 0 0 0 5 0 0 ENI 0 0 0 0 0 0 Explanation: Since SMARCH instructions must appear in the upper instruction of a program step, the first two pass instructions above are needed. Also note that the index register designators in the SEARCH instructions above are zero. This will result in the contents of one address being compared to the contents of the A register. - c. The portion of the program given is attempting to accomplish the following: - 1. The number $100_{10}$ is ENTERED into index register 6. - 2. The contents of index register 6 (100 $_{ m 10}$ ) is put into "A" - 3. A Threshold Search is made of 10010 consecutive storage locations starting with the contents of storage locations 00100 to see if any of these 100 storage locations contain quantities greater than 10010 (which is in "A"). - 4. If none of the 100 storage locations contain quantities greater than 100, a jump soes to step 00060. If a storage location is found whose content is greater than 100 (In A), then at step 00052, zeros are entered into Q and then into storage location 00500. In surmary, this program is trying to determine if any of the 100 consecutive storage locations starting at address 00100 contain quantities greater than 100; and if so, to store a zero in storage location 00500. d. Part I. Given (00700)= MTH 3 0 0 0 5 0 SLJ 0 0 0 7 0 0 Here is a MASKED THRESHOLD SEARCH followed by a jump to the same address containing the search instructions. As long as the logical product of (Q) and the contents of the storage locations starting at address 00050 is greater than the contents of "A", this jump is skipped; however, if the criterion is not met, then this jump back to the search is made. If the jump instruction is reached, the search is complete and the index register contains zero. This step (2 instructions) would be endlessly repeated, but no search would take place in the first half. The danger lies in the fact that if the criterion is not met, a non-terminating loop is formed. Part II. Given (00105) = LDA 0 0 0 0 5 0 EQS 3 0 0 2 0 0 Here the EQUALITY SEARCH is programmed in the lower instruction of a program step. When this happens, the next instruction is never skipped and in effect one would always go to the next step at 00106 regardless of the equality criterion being met. The only way one would know whether the criterion was met would be to look at the contents of index register 3. If index register 3 contains a zero, the criterion was not met; if index register 3 contains any number other than zero, the criterion was met. EXERCISES 12. | (a) | | Set index | Pass | |-----|-----------|-----------------------|------------------| | (4) | (03001) = | ENI 3 0 0 1 4 3 | ENI 0 00000 | | | | One word to A | Pass | | | (03002) = | LDA 3 00201 | ENI 0 00000 | | | | Ship if (M) > (A) | Jump if (A)> (M) | | | (03003) = | THS 3 00201 | SLJ 0 0 3 0 0 5 | | | | Jump to test new (A) | Pass | | | (03004) = | SLJ 0 0 3 0 0 2 | ENI 0 00000 | | | _ | Store greatest quant: | ity Stop | | | (03005) = | STA 0 0 0 0 7 7 | SLS 0 0 3 0 0 1 | Explanation: The first step sets an index equal to one less than the total number of quantities to be examined. At 03002 the last quantity in the list is entered into the A register. At 03003 the remainder of the list is searched to determine if there is a quantity greater than the quantity in the A-register. If such a quantity is found, a jump is made to 03002 where the greater quantity is entered into the A-register. The search is then resumed at the point where it found the greater quantity. When the entire list has been exhausted, a jump is made to 03005. At this time, A contains the greatest quantity in the list and this quantity is stored at 00077. Gross Pay - \$13 (No. of Deps.) 18% = Tax Assuming Gross Pay stored at 00022, No. of Deps. stored at 00024, Constant 18 stored at 00025, Constant 13 stored at 00027, and TAX to be stored at 00030. Multiply by 13. No. of Deps. → A Product XXX. (Max.) in "A" as Multiplier 00027 (00101) =LDA 0 00024 MUI 0 Shift Product (00020) =Store Product 2 Octals XXX.00 (Max.) STA 0 0 0 0 2 0 (00102) =ALS 0 00006 Gross Pay - \$13 (No. of Deps) $\longrightarrow$ (A) Gross Pay --->(A) SUB 0 0 0 0 2 0 0 0 0 2 2 (00103) =LDA 0 Store Difference Constant 18 to A as Multiplier 0 0 0 2 5 (00104) =LDQ 0 STA 0 0 0 0 2 1 Multiply 0 0 0 2 1 (00105) =MUI 0 LRS 0 0 0 0 0 6 Round off if necessary 0 0 0 0 1 (00106) =QJP 2 00107 INA 0 Store result (00107) =STA 0 0 0 0 3 0 (c) Enter $100_{10}$ into Enter Zeros into Ind. Reg. 5 Ind. Reg. 3 (00011) -EM1 5 0000 ENI 3 00144 Enter Extract Enter Code Comparator Pattern in Q in-A Reg. (00012) =ENQ 0 00700 00300 ENA O Masked Threshold Jump to 00016 (00013) =MIH 3 0 0 3 1 2 SLJ 0 00016 Add 1 to contents of Pass 00100 and Replace (00014) = RAO 00 0 1 0 0 ENI O 00000 Where initial contents of (00100) = counter = $(00015) = \boxed{ 1 \text{ Mdex Skip} \\ 1 \text{ SK 5} 0 0 1 4 3}$ Jump Back to (00012) SLJ 0 0 0 0 1 2 (00016) =Continue Program Explanation: A critical point in the above program is the use of the "REPLACE ADD ONE" instruction at step 00014. Keep in mind that this instruction destroys the original contents of A (in this case the comparator). Thus the jump back must go to step 00012 where the comparator is entered into A. If some other plan is used for the counter then it may be possible to jump back to step 00013 instead of 00012. (Perhaps you used some other method of running a counter.) Explanation: The number is shifted around to interchange the first and last octal digits without regard for what is happening to the other fourteen octal digits. After the first and last octal digits have been interchanged, the other fourteen octal digits are set between and the altered number is stored at its original position. Index register 2 is reduced by one in the lower instruction at step 00316, so that the next number will be interchanged when the jump is made. (e) Given: each location is made up of the following format: | 24 Bits | 24 Bits | |----------------|-----------------| | First Quantity | Second Quantity | Compare and order two quantities in each of 50 addresses. Index register 6 into Q Register (01000) =00000 LDQ 0 0 0 5 0 Enter Zero into (where 00050 contains 0 0 0 0 0 0 0 0 7 7 7 7 7 7 7 7 (this extracts the SECOND QUANTITY OF EACH ADDRESS) Pass Load Extract Pattern Load Q with Log. Prod. Shift A Left 24 Bits of Q and Each Address (01001) = LDL 6 0001100030 ALS Subtract Constants If "A" is Negative Jump of each Address to (01005) $(01002) = \boxed{SUB 6} \quad 0.0011$ АЈР 3 0 1 0 0 5 Load "A" with Contents Shift "A" left 24 bits of each Address LDA 6 0 0 0 1 1 (01003) =0 00030 ALS Store in Original Address (01004) =STA 6 0 0 0 1 1 ENI 00000 Index Skip (01005) =ISK 6 00061 0 0 1 0 0 1 (01006) =Continue Program The A JUMP test at step 01002 determines if the second quantity is larger than the first. If so, they are reversed in steps 01003 and 01004. The INDEX SKIP instruction at (01005) acts as a count of the $50_{10}$ times. ``` EXERCISE 13 ``` ``` (1) 31_8 = 0.11001, (in binary) а. Must shift 5 places to binary reference point. Exponent is + 5 floating-point = 010 000 000 101. 110 010 0 \leftarrow > 0 (in binary) 5 . 620 000 000 000 (in octal) 0 floating-point = 2 0 (2) - 156<sub>10</sub> (Negative number, plus exponent) (Treat as a positive number, complement the result) 156_{10} = 234_{8} = 010\ 011\ 100_{\bullet} (in binary) Must shift 8 places; exponent is 8 floating-point = 010 000 001 000. 100 111 0 \leftarrow \rightarrow 0 (in binary) 1 0 . 470 000 000 000 (in octal) floating-point = 2 0 Complement to ) 5767.307 777 777 777 (in octal) obtain the final) result (3) 0.4_{g} = .100 (in binary) (binary point is in the right position - no shifts are required; exponent is zero.) floating-point = 010 000 000 000. 100 0 \leftarrow \rightarrow 0 (in binary) 0 . 400 000 000 000 (in octal) floating-point = 2 - 0.0028 (Negative number, negative exponent) (Treat as plus number, negative exponent, and complement the final result.) +0.002_8 = .000 000 010 must shift 7 places, exponent is -7 floating-point = 001 111 111 000. 100 ← → 0 (in binary) floating-point = 1 7 7 0 . 400 000 000 000 (in octal) Complement to obtain ) = 6007. 377 777 777 (in octal) the final result ``` ## b. (1) 2 010. 612 000 000 000 Sign of Biased Fractional Number Exponent Number Sign of number is + Exponent (unbiased) is 8 To find number, shift point 8 places right 110 00101 = 011 000 101 = 305 Number is 305<sub>8</sub> ## (2) 5772.317 777 777 777 Sign of Number Sign of Number Sign of Number Sign of Number Sign of Number Sign of number is - Since sign of number is minus, complement the whole form. 2005.460 000 000 000 (complemented) 010 000 000 101.100 110 0 > 0 Biased Number Exponent The unbiased exponent is +5. Therefore, shift 5 places right in the number. 100 110 0 Number is -23 (c+4) = Long left shift $36_{10}$ places puts number in floating-point format in A. ### APPENDIX B ## SOLUTIONS TO THE CHAPTER REVIEW TESTS This appendix provides the key to the review tests which are found at the end of the first five chapters of the preliminary instruction manual. Alternative solutions are presented in some instances where program routines are asked for, indicating that oftentimes there is no hard and fast approach to programming situations. ## CHAPTER I - 1. Core - 2. 48 - 3. 32,768<sub>10</sub> - 4. False - 5. 00000 77777 - 6. | Operation<br>Code | Index<br>Designator | Address | | |-------------------|---------------------|---------|--| | 12 | 1 | 01000 | | | 6 bits | 3 bits | 15 bits | | 7. | Instruction | Instruction | |-------------|-------------| | Instruction | Pass | | Pass | Instruction | - 8. True (unless there is an assembly routine which permits decimal notation) - 9. False - 10. - 11. Accumulator and Q Register - 12. Program Address Register (P) - 13. Program Control Register (u) - 14. Accumulator and Q Register - 15. Yes - 16. 62 - 17. 400 sq. ft. - 18. (1) Magnetic tape units - (2) Paper tape reader - (3) Paper tape punch - (4) Typewriter - 19. True - 20. True #### CHAPTER II - 1. Some of the rightmost bits are lost - 2. False - 3. The sign bit is extended to the right in the register - 4. Accumulator or Q Register - 5. Yes, and a shift fault will be set - 6. False - 7. False - 8. 000000000000007 - 9. 000000000000007 10. - (1) LDA 0 00050 STA 0 01000 - or - (2) LDQ 0 00050 STQ 0 01000 - 11. It is an advantage to be able to transfer through Q without disturbing (A), and it saves an instruction if it is desired to store a quantity already in Q. - 12. 0000000000000001 - 13. At the address contained in index register 6 - 14. False 15. | 00100 | = | LDQ | 0 | 00016 | LDA | 0 | 00017 | |-------|----|-----|---|-------|-----|---|-------| | 00101 | =1 | QJB | 1 | 00102 | STQ | 0 | 00500 | | 00102 | == | AJP | 1 | 00103 | STA | 0 | 00501 | | 00103 | = | STQ | 0 | 00700 | ADD | 0 | 00700 | 16. (00011) = constants (00005) 00010 $(Q) \longrightarrow A$ 0 STQ 00010 LDA 00100 Add $T_1$ , return jump if negative 01000 7 00012 AJP ADD 00101 Store (A) in $S_1$ STA 00010 00400 00102 STA and at 00010 Add 1 to $S_1$ 00011 00102 ADD 0 LDA 00103 Store ( $S_1$ ) +1 back in $S_1$ 00101 0 00102 LDA STA 00104 Add 1 to 00101 0 00101 STAADD 0 00011 00105 Add 1 to counter 0 00007 ADD 00006 00106 LDA Test counter for 00005 00006 SUB STA 00107 equality to 10010 Jump if $(A) \neq 0$ , 00000 SLS AJP00111 00110 stop 00101 Load 00010 into LDA 00010 AJP 00111 A, jump to 00101 00101 Continue Program AJP 00112 J ### CHAPTER III 1. True 2. False 3. True 0000000000000000 (because the arithmetic is one's complement) 4. 5. 777777777777777 00000 6. INA 4 7. No 8. Multiplier - A register Multiplicand - storage address Product - QA register A register - 77777777777776 Q register - 0000000000000002 9. 10. (00300) LDA 00007 INA 00000 (00301) AJP 00304 00050 LDQ 00200 (00302) DVI 00100 STQ 01000 00060 ENI SLJ 0 SLJ STA (00303) (00304) 00000 01000 ### CHAPTER IV - 1. Upper - The next instruction is executed. - 3. The contents of the memory location are not changed by the storage skip, they are shifted left one place by the storage shift. - 4. Index register 3 is cleared and the next instruction is skipped - 5. Twice - 6. Memory, Accumulator or Q register - 7. $0 \times 0 = 0$ $0 \times 1 = 0$ $1 \times 0 = 0$ $1 \times 1 = 1$ - 8. False - 9. False (A yes, but Q no) - 10. 000000000000017 - 11. Yes - 12. ENI 0 00000 - 13. False - 14. True - 15. | (00104) | = | LDA 1 00100 INI 1 00001 | Place first digit in A, and a l in index register l | |--------------------|-------|----------------------------------------|----------------------------------------------------------------------------------| | (00105) | = | ENI 0 00000 ADD 1 00100 | Add first two digits | | (00106) | = | ISK 1 00004 SLJ 0 00105 | Add 3 remain-<br>ing digits | | (00107) | = | STA 0 00050 LIL 3 00050 | Store sum in 00050 and index register 3 | | (an alter | rnati | ve solution) | <b>7</b> | | (00100) | = | ENI 1 00004 ENQ 5 00000 | Enter 4 into index register 1 and (index register 5) into Q | | (00101) | = | LDL 0 00201 ADD 0 00200 | Load last digit<br>into A, add<br>(00200) | | (00102) | = | STA 0 00200 QRS 0 00003 | Store (A), Shift right 3 | | (00103) | = | IJP 1 00101 LIL 3 00200 | Jump to 101, reduce index reg. 1, when ind. reg. 1 = 0, load sum into ind. reg.3 | | (00200)<br>(00201) | = | 00000000000000000000000000000000000000 | | #### CHAPTER V - 1. False - 2. A and Q - 3. 0.100 --- 011 - 4. $0.111 \longrightarrow 111 \text{ or } .377 \longrightarrow 77_8$ - 5. True - 6. False - 7. False (either 3 or 7 will stop the computer) - 8. SST 0 00100 - 9. SCL 0 00100 - 10. One storage location will be searched the one whose address is the execution address - 11. An unconditional jump - 12. The next instruction is skipped - 13. The next instruction is executed - 14. The execution address of the search instruction is added to the contents of the index register referenced by the search instruction - 15. Equality Search Threshold Search Masked Equality Search Masked Threshold Search - 16. Instruction: THS 5 00062 Contents of index register 5: 00062 - 17. The Add instruction stores its sum in A, the Replace Add does this but also stores the sum in memory. - 18. A register: 7777777777776 (00100): 77777777777776 - 19. A register: 000000000000007 (00100) : 0000000000000007 - 20. (00100) = ENI 1 01747 ENI 0 00000 int Enter 1747 (1000 10) into index reg. 10) Load contents of last address into A, store at address3 greater (00102) = IJP 1 00101 | Continue Program | Repeat 1000 times (an alternative solution) $(00100) = \begin{bmatrix} \text{ENI} & 1 & 77777 & \text{ENI} & 2 & 01747 \end{bmatrix}$ Enter negative zero into $B_1$ . Enter $1000_{10}$ -1 into $B_2$ (00101) = LDA 1 02150 STA 1 02153 Load contents of last address into A, store at address 3 greater $(00102) = \boxed{\text{INI} 1 77776} \boxed{\text{IJP} 2 00101}$ Subtract 1 from ind. reg. 1, jump to 00101 repeat 1000 times #### APPENDIX C # 1604 ASSEMBLY ROUTINE (JUNE 1959) #### GENERAL DESCRIPTION The assembly routine will convert a program from a special symbolic shorthand notation to a fully-encoded program suitable for loading into the computer. In this shorthand notation, each instruction or constant is represented by one entry. An entry is one line of information, as typed on a Flexowriter or punched onto one card. Certain pseudo-instructions can also be represented by certain entries. Pseudo-instructions are used to specify a starting address, to insert constants, to reserve space, to include special remarks, to assign addresses to alpha-numeric location symbols, to call for the assembly of certain subroutines from a special magnetic library tape, or to end the assembly. Each entry consists of one to four terms, followed by remarks. Each term consists of one or more consecutive characters, followed by one or more spaces or tabs (Flexowriter tabulator functions.). The remarks consist of anything following the last term. The arrangement and nomenclature of terms and the remarks for each entry are as follows: Tag, operation code, b-term, m-term, remarks. For certain types of entries, some of these terms are not required. The remarks are always optional. The operation code term is always required. The tag term is used to assign an alpha-numeric location symbol to an instruction or constant. This permits execution addresses in the program to be represented symbolically. A location symbol consists of a letter, followed by letters or digits, to a maximum of eight characters. The operation code term can be either a three-letter mnemonic code, or two digits corresponding to the octal operation code portion of the desired instruction. The b-term, used to represent the b-designator for instructions, can be either a single digit (0-7) or the letter "N" to represent indirect addressing. "N" is equivalent to b = 7. The m-term is a value in either absolute or symbolic representation. For instruction entries, the m-term represents the m-portion, or base execution address, of the instruction. For example, an instruction is represented by a tag (optional), a threeletter operation code, a single-character b-term, and an m-term representing a base execution address. A portion of a program encoded in this manner will appear as follows: | Tag | Operation <u>Code</u> | B-term | M-term | Remarks | |-------|-----------------------|--------|----------|---------------------| | LOOP | ADD | 0 | CONSTANT | Add Constant | | | SUB | 6 | LIST+7 | Subtract next value | | INDEX | IJP | 6 | LOOP | Index B6 | | | SLS | 0 | EXIT | Stop, jump to exit | The symbol LOOP appearing in the m-term of the IJP instruction thus specifies an indexed jump to the ADD instruction. The terms CONSTANT, LIST, and EXIT refer to other locations specified in a similar manner, elsewhere in the program. In the SUB instruction, the value following the symbol LIST modifies it, so that the base execution address portion of the instruction is equal to the numerical location equivalent of LIST, plus seven. A typical pseudo-instruction entry is that for the Origin Address function. To start a program at address 70000, the Origin pseudo-instruction would precede the first instruction entry, as follows: | | Operation | | | | |--------|-----------|--------|--------|----------------| | Tag | Code | B-term | M-term | Remarks | | (none) | ORG | (none) | 70000 | Start at 70000 | The use of the symbolic codes and locations not only simplifies the writing of a program, but also facilitates debugging, allows rapid reencoding for different ranges of addresses, and provides the programmer with a clearer understanding of what a program is accomplishing than could be had by examination of an entirely numerical copy of the program. Also the pseudo-instructions used with the assembly permit many programming short cuts to be made. A simplified flow diagram of the program is shown in Figure 17. Instructions are entered on consecutive lines of a worksheet. These entries along with remarks the programmer may have entered to the right of any entry are either typed on a Flexowriter to punch a paper tape, or punched onto 80-column cards (one line per card). The cards or paper tape entries are first converted to successive binary-coded-decimal records on magnetic tape, and the resulting tape is used as the input medium for the "assemble" portion of the assembly program. The "assemble" routine will normally require two executions, or "passes". The first pass examines the input magnetic tape to determine the assignment of all location symbols. The assignments are stored in a directory capable of holding assignments for 2048 location symbols. The second pass, made with the same input tape, performs the translation from the symbolic-encoded form to the numeric form and records both forms along with the original remarks. Both passes check for certain errors and record these errors on a printed sheet via the monitor typewriter. If a simple arrangement rule is followed, the routine can function as a one-pass assembler. The rule is that each location symbol must be defined by using it as a tag before it is used in an m-term. If the operator is attempting to write for one-pass but has ignored this rule, the assemble routine will sense the error and stop for a change to the two-pass mode. The output is on magnetic tape, which can be converted to paper tape punched in Flexowriter code, converted to line-printer copy, or loaded into the computer memory. Examples of a symbolic-encoded program and the resulting output are given in Tables I and II. The rules for using the instructions, pseudo-instructions, tags, and remarks are given below. Figure 17 SIMPLIFIED FLOW DIAGRAM Assembly Program C-4 # DESCRIPTION OF ENTRIES - a. REMARKS ONLY If it is desired to enter a line of remarks only on the copy, an operation code REM is followed by a maximum of 80 characters. For all other types of entries, remarks are limited to 48 characters. - b. EQUIVALENCE To assign a location symbol to the first location of a group of working storages, or to equate two location symbols, a tag consisting of a location symbol (letter followed by letters and digits, up to eight characters) is followed by the operation code EQU, and an m-term address. The address can be an all-numeric octal value denoted by a value consisting of a maximum of five digits; an all-numeric decimal value denoted by appending "D" to the value term; or regional address, consisting of a location symbol followed by a + or and a value of one to five digits, with a "D" appended if the modifying value is to be interpreted as decimal. - c. ORIGIN ADDRESS To start a sequence of instructions at a particular location, an operation code ORG is followed by a regional or numeric mterm address similar to that used to the right of the EQU operation code. - d. INSTRUCTION For an instruction, the tag term is optional, but, when used, assigns a location symbol to theinstruction location. A location symbol tag can only appear to the left of an instruction that is to be assembled into the upper half of a word. The b-designator may be a digit (0 through 7) or the letter "N", which is equivalent to 7 and denotes "indirect". The m-term can consist of a numerical or regional address similar to that used after the EQU code. An additional feature is that the region symbol portion of this term can also consist of a slash (/), to denote the location of the current word. Thus, to jump to a location two greater than the current location, the operation code, b, and m-terms are as follows: SLJ 0 /+2. e. DECIMAL VALUE - To insert a decimal constant into a location, the operation code DEC is used. A tag consisting of a location symbol is optional. The m-term consists of a sign (+, -, or blank), a value of up to 14 decimal digits, a decimal scaling consisting of a "D" followed by a sign (+ or -) and one or more decimal digits, and a binary scaling consisting of a "B" followed by a sign (+ or -) and one or more decimal digits. If the value contains a decimal point (period) in any position, the constant is packed into floating point form. If no decimal point is present, an integral constant will result. Both the decimal and binary scalings are optional. - f. OCTAL VALUE To insert an octal constant, the operation code OCT is used. A tag consisting of a regional symbol is optional. The m-term consists of a sign (+, -, or blank) and up to 16 octal digits. - g. BINARY-CODED-DECIMAL INSERTION To insert binary-coded-decimal characters into a word, the BCD operation code is used. A region symbol tag is optional. The m-term consists of a slash (/) and the next eight characters, including spaces. - h. FLEXOWRITER CODE INSERTION To insert Flexowriter codes into a word, the FLX operation code is used. A region symbol tag is optimal. The m-term consists of a slash (/) and eight characters, including spaces. - i. LIBRARY SUBROUTINE ASSEMBLY To insert an entire library subroutine into the program, the title of the subroutine (stored on the library tape) is used as a tag. This is followed by the operation code term LIB, and an m-term representing a regional or absolute starting address for the subroutine. The starting address is similar to the m-term used for an instruction. - j. RESERVE BLOCK STARTING WITH SYMBOL To reserve a block of consecutive addresses and assign a location symbol to the first location of the block, a location symbol tag term is followed by the operation code BSS and an m-term consisting of a maximum of five digits, appended by "D" if the value is to be interpreted as decimal, or no "D" if the value is octal. The m-term specifies the number of locations to be reserved. - k. RESERVE BLOCK, END WITH SYMBOL If it is desired to reserve a block as described above, except that a location symbol is to be assigned to the last location of the block, a location symbol tag is followed by BES, and an m-term similar to that used for BSS. - 1. END ASSEMBLY To end the assembly program during either pass, the last entry must consist of the operation code END. ### FORMAT RULES Each entry is interpreted as the information on a punched card or one line of Flexowriter copy. If Flexowriter tape is to be used, a blank line (produced by a carriage return not preceded by any visible symbols) is ignored by the assembly program. The assembly program detects terms by means of their separation of spaces, with the number of terms that are detected depending upon the type of entry. Anything appearing to the right of the last term is interpreted as remarks. The only input format requirement is that each term (except the m-term for FLX or BCD) consist of successive characters, and that the left-most character of the tag term, if present, must be in the extreme left position of the input: i.e., column 1 on a punched card, or the left margin for Flexowriter input. Any number of spaces may separate the terms. Non-significant digits of a value may be omitted. In an all-numeric term of positive value, the + sign may also be omitted. All of these features are included to eliminate the tedious writing of redundant symbols on the input copy, and to make the reproduction onto the cards or tape as simple as possible. During encoding, the programmer must realize that each instruction occupies one-half of a word, and each operand occupies an entire word. Because some instructions such as Load Index Lower refer to a specific half of a word, and because the addition of a constant n to an address increments the address by n locations (not by n instructions), it is necessary that the programmer pair his instructions; i.e., he must know, for each instruction, whether it is to be assembled into the upper or lower half of a computer word, and must include pass instructions (ENI with b = 0) or blanks. The detailed format rules for each type of entry are given in Table III and its accompanying notes. ## TABLE I # ASSEMBLER INPUT FORMAT # REM -- TRANSFER 6SIN3X TO Y, FOR 3 X-VALUES | YSTOR | • | | Assign Y storage | |--------|-------|-----------|--------------------------------| | | ORG | | Start at address 500 | | COMP | ENI 1 | 0 | Start of computation, clear B1 | | | ENA O | 0 | Clear A | | LOOP | LDQ 1 | XSTOR | X-Storage to Q | | | MUI 0 | CONST | Multiply by 3 | | | LLS 0 | 60 | Shift product to A | | | SLJ 4 | SINE | Return jump to sine | | | LRS O | 60 | Sine to Q | | | ENA O | 0 | Clear A | | | MUI 0 | CONST+1 | Multiply by six | | | STQ 1 | YSTOR | Store Product | | | ISK 1 | 2 | Index B <sup>1</sup> toward 2 | | | SLJ 0 | LOOP | Jump to obtain next X | | | SLS 0 | COMP | Stop | | | 0 0 | 0 | Blank | | XSTOR | DEC | +1247D+1 | Value 12470 dec. | | | DEC | -79825 | Value -78825 dec. | | | DEC | +52891B+1 | Value +105782 dec. | | CONST | OCT | 3 | Value 3 | | | OCT | 6 | Value 6 | | TEMP | BSS | 3 | Reserve 3 locations | | SINE77 | LIB | 1 | Load Sine Routine No. 77 here | | | END | | End Assembly | #### TABLE II #### ASSEMBLER OUTPUT FORMAT ### REM -- TRANSFER 6SIN3X TO Y, FOR 3 X-VALUES | | | YSTOR | | 6000 | | |-------|--------------|---------|---------|-----------|--------------------------------| | | | | | 500 | START AT ADDRESS 500 | | 00500 | 50 1 00000 | COMP | ENI : | | START OF COMPUTATION, CLEAR B1 | | | 10 0 00000 | | ENA ( | | | | 00501 | 16 1 00600 | | | | X-STORAGE TO Q | | | 24 0 00100 | | | CONST | MULTIPLY BY 3 | | 00502 | 07 0 00060 | | | | SHIFT PRODUCT TO A | | | 75 4 00514 | | | | RETURN JUMP TO SINE | | 00503 | 03 0 00060 | | | | SINE TO Q | | | 10 0 00000 | | ENA C | 0 0 | CLEAR A<br>MULTIPLY BY SIX | | 00504 | 24 0 00101 | | MUI ( | CONST+1 | MULTIPLY BY SIX | | | 21 1 00604 | | | YSTOR | STORE PRODUCT | | 00505 | 54 1 00002 | | | | INDEX B1 TOWARD 2 | | | | | | | JUMP TO OBTAIN NEXT X | | 00506 | | | | COMP | | | | 00 0 00000 | | 0 0 | 0 | BLANK<br>VALUE 12470 DEC. | | 00507 | 00 0 00000 | XSTOR | DEC | +1247D+1 | VALUE 12470 DEC. | | | 00 0 30266 | | | | | | 00510 | 77 7 77777 | | DEC | -79825 | VALUE -79825 DEC. | | | 77 5 44056 | | | | | | 00511 | 00 0 00000 | | DEC | +52891B+1 | VALUE +105782 DEC. | | | 00 3 16526 | | | | | | 00512 | 00 0 00000 | CONST | OCT | 3 | VALUE 3 | | | 00 0 00003 | | | | | | 00513 | 00 0 00000 | | OCT | 6 | VALUE 6 | | | 00 0 00006 | | | | | | 00514 | 00 0 00000 | TEMP | BSS | 3 | RESERVE 3 LOCATIONS | | | 00 0 00000 | | | | | | 00517 | 75 0 77777 | SIN77 | LIB | / | LOAD SINE ROUTINE NO. 77 HERE | | | 50 6 00007 | | | | | | | • | | | | | | | • | | | | | | | (etc., to en | nd of s | ine r | outine) | | | | • | | | | | | 01026 | 12 0 01000 | | | | | | 01020 | 75 0 00514 | | | | | | | 75 0 00514 | | <b></b> | | | END ASSEMBLY END TABLE III Detailed Format Rules (See Accompanying Notes) | Function | Tag | Op. Code | B-term | M-term | Remarks | |----------------------------------------|--------|----------|--------|---------|---------| | Remarks<br>only | | REM | | | Note 13 | | Symbol<br>Equivalence | Note l | EQU | | Note 7 | Note 14 | | Origin<br>Address | | ORG | | 7 | Note 14 | | Instruction | Note 2 | Note 5 | Note 6 | Note 7 | Note 14 | | Decimal<br>Value | Note 3 | DEC | | Note 8 | Note 14 | | Octal<br>Value | Note 3 | ост | | Note 9 | Note 14 | | BCD<br>Characters | Note 3 | BCD | | Note 10 | Note 14 | | Flexowriter<br>Characters | Note 3 | FLX | | Note 11 | Note 14 | | Library<br>Assembly | Note 4 | LIB | | Note 7 | Note 14 | | Reserve<br>Block, Start<br>with Symbol | Note 3 | BSS | | Note 12 | Note 14 | | Reserve<br>Block, End | | 200 | | | | | with Symbol | Note 3 | BES | | Note 12 | Note 14 | | End Assembly | | END | | | Note 14 | - Note 1: The tag must be present, and must be a location symbol (a letter followed by letters or digits, to a maximum of eight characters). - Note 2: The tag is optional, but if present, must be a location symbol and must be located only to the left of an instruction that is to occupy the upper-half position of a word. - Note 3: The tag is optional, but, if present, must be a location symbol. - Note 4: The tag specifies the title of a library routine. The title, which must agree with that recorded in the first word of the library routine on the tape, must consist of one to eight characters. - Note 5: For instructions, the operation code may be either the threeletter mnemonic symbol, or the two-octal-digit operation code. - Note 6: The b-designator may be either a single octal digit (0 through 7), or the letter "N", to denote indirect addressing. The letter "N" is equivalent to 7. - Note 7: The m-term may be either an absolute octal address (one to five octal digits), an absolute decimal address (one to five digits followed by a D), or a symbolic relative address consisting of a location symbol, a sign (+ or -), and a modifying value. The modifying value may be octal, or decimal digits followed by a D. Also, for instructions on library assembly, the location symbol can be a slash mark (/) and a modifying value, with "/" denoting "this location". - Note 8: The m-term for a decimal constant must consist of a sign (+, -, or blank) followed by a maximum of 14 digits. A decimal scaling consisting of a D followed by a sign (+ or -) and a decimal value, and a binary scaling consisting of a B followed by a sign (+ or and a decimal value are both optional. If a decimal point appears in the value, or to the right of the value, the value is packed into floating point form. - Note 9: The value for an octal constant must consist of a sign (+, -, or blank) followed by a maximum of 16 octal digits. - Note 10: To insert binary-coded-decimal characters, the value must consist of a slash (/) followed by eight characters, including spaces. - Note 11: To insert Flexowriter characters, the value must consist of a slash (/) followed by eight characters, including spaces, shift up, and shift down. If the program input is via punched cards or the output is via the line printer, certain characters are not permissible. - Note 12: The value for a block reserve must consist of a + sign or blank, followed by a maximum of five digits and a "D" if the value is decimal. If the "D" is not present, the value is interpreted as octal. - Note 13: Remarks for the REM code may consist of a maximum of 80 characters, including spaces. - Note 14: Remarks for all codes except REM may consist of a maximum of 48 characters, including spaces. TABLE IV SUMMARY OF OPERATION CODES FOR 1604 ASSEMBLER ## A. INSTRUCTION OPERATION CODES Note: Use Either Mnemonic or Two-Digit Code | Digits | Mnemonic | | |--------|-------------|----------------------------------| | 00 | ZRO | Zeros in Operation Code Position | | 01 | ARS | A Right Shift | | 02 | QRS | Q Right Shift | | 03 | LRS | Long (AQ) Right Shift | | 04 | ENQ | Enter Q | | 05 | AĽS | A Left Shift | | 06 | $\Omega LS$ | Q Left Shift | | 07 | LLS | Long (AQ) Left Shift | | 10 | ENA | Enter A | | 11 | INA | Increase A | | 12 | LDA | Load A | | 13 | LAC | Load A, Complement | | 14 | ADD | Add | | 15 | SUB | Subtract | | 16 | LDQ | Load Q | | 17 | LQC | Load Q, Complement | | 20 | STA | Store A | | 21 | STQ | Store Q | | 22 | AJP | A Jump | | 23 | QJP | Q Jump | | 24 | MUI | Multiply Integer | | 25 | DVI | Divide Integer | | 26 | MUF | Multiply Fractional | | 27 | DVF | Divide Fractional | | 30 | FAD | Floating Add | | 31 . | FSB | Floating Subtract | | 32 | FMU | Floating Multiply | | 33 | FDV | Floating Divide | | 34 | SCA | Scale A | | 35 | SCQ | Scale AQ | | 36 | SSK | Storage Skip | | 37 | SSH | Storage Shift | | 40 | SST | Selective Set | | 41 | SCL | Selective Clear | | 42 | SCM | Selective Complement | | 43 | SSU | Selective Substitute | | 44 | LDL | Load Logical | ## INSTRUCTION OPERATION CODES (Continued) | 45 | $\mathtt{ADL}$ | Add Logical | |------------|----------------|-----------------------------------| | 46 | SBL | Subtract Logical | | 47 | STL | Store Logical | | 50 | ENI | Enter Index | | 51 | INI | Increase Index | | 52 | LIU | Load Index, Upper | | 53 | LIL | Load Index, Lower | | 5 <b>4</b> | ISK | Index Skip | | 55 | IJP | Index Jump | | 56 | SIU | Store Index, Upper | | 5 <b>7</b> | SIL | Store Index, Lower | | 60 | SAU | Substitute Address, Upper | | 61 | SAL | Substitute Address, Lower | | 62 | INT | Input Transfer | | 63 | OUT | Output Transfer | | 64 | EQS | Equality Search | | 65 | THS | Threshold Search | | 66 | MEQ | Masked Equality | | 67 | MTH | Masked Threshold | | 70 | RAD | Replace Add | | 71 | RSB | Replace Subtract | | 72 | RAO | Replace Add One | | 73 | RSO | Replace Subtract One | | 74 | EXF | External Function | | 75 | SLJ | Selective Jump | | 76 | SLS | Selective Stop | | 77 | SEV | Sevens in Operation Code Position | | | | | #### B. PSEUDO-OPERATION CODES | REM | Enter Remarks Only | |-----|-------------------------------------------| | EQU | Equate or Define Location Symbol | | ORG | Set Origin Address | | DEC | Insert Decimal Constant | | OCT | Insert Octal Constant | | BCD | Insert Eight BCD Characters | | FLX | Insert Eight Flexowriter Characters | | LIB | Insert Library Routine | | BSS | Reserve Block, Start with Location Symbol | | BES | Reserve Block, End with Location Symbol | | END | End Assembly | TABLE V BCD CODES USED FOR ASSEMBLER | Character | Code | Character | Code | |-----------|------|---------------|------| | 0 | 12 | 0 | 46 | | 1 | 01 | p | 47 | | 2 | 02 | Q | 50 | | 3 | 03 | R | 51 | | 4 | 04 | S | 22 | | 5 | 05 | T | 23 | | 6 | 06 | Ŭ | 24 | | 7 | 07 | v | 25 | | 8 | 10 | w | 26 | | 9 | 11 | x | 27 | | Α | 61 | Y | 30 | | В | 62 | Z | 31 | | С | 63 | 3 | 13 | | D | 64 | | | | E | 65 | - | 40 | | F | 66 | \$ | 53 | | G | 67 | * | 54 | | H | 70 | + | 60 | | I | 71 | • | 73 | | J | 41 | ) | 74 | | K | 42 | blank (space) | 20 | | L | 43 | / | 21 | | M | 44 | , | 33 | | N | 45 | . ( | 34 | Note: In the event that these do not agree with the codes used at a particular installation, the assembly routine can be modified easily, as these codes are all contained in a compact "code list" in the routine. #### APPENDIX D #### LOAD AND DUMP ROUTINES #### FLEX LOAD The Flex Load routine will read a paper tape prepared in flexcode, translate it into binary, and load it into the core memory of the computer. For each memory location to be loaded, the paper tape must contain the address of the memory location and the information which is to be loaded into that location. The address must be preceded by a carriage return. The routine will accept paper tapes which contain a check sum (output of Flex Dump routine). To load paper tapes prepared on the Flexowriter, set Selective Jump Key 1. (It is assumed that tapes prepared on the Flexowriter will not contain a check sum.) The Flex Load routine will accept tapes prepared in two different formats: - 1. Carriage return, address, tab, upper instruction, remarks (optional), carriage return, tab, lower instruction, remarks (optional). - 2. Carriage return, address, upper instruction, lower instruction, remarks (optional). If a tape prepared in format 2 is to be loaded, set Selective Jump Key 2. In either format the spacing within the instruction may be variable. The last information to be entered into the computer should be followed by a carriage return and an end code. When the routine recognizes this end code, the check sum punched on the paper tape is compared with the check sum computed while the paper tape is being loaded. If these are the same, a jump to the beginning of the Flex Load routine is made and the computer stops. If they are not the same, the typewriter types 'check sum error', a jump is made to the beginning of the Flex Load routine, and the computer stops. #### FLEX DUMP The Flex Dump routine punches, in flexcode, a paper tape of the contents of a specified area of core memory. The area is specified by placing the first address of the area in index register 6 and the last address of the area in index register 5. These addresses are inclusive. If it is desired to suppress punching the contents of those addresses containing zero, Selective Jump Key 1 should be set. A check sum of the contents of the locations being dumped is computed and punched on the tape. This check sum is preceded and followed by carriage returns. Each address of the specified area is punched, followed by the contents of that address and a carriage return. When an address ending with seven is punched, the contents of that address are followed by two carriage returns. After the carriage return following the contents of the last address to be dumped, an end code is punched. This end code will be recognized by the Flex Load routine if this tape is used as an input tape. #### Format sample: 76 5 43210 01 2 34567 (check sum) 01000 75 1 01101 20 0 01076 01001 10 0 01200 14 3 02000 #### BIOCTAL LOAD The bioctal load routine is used to load a bioctally-punched paper tape into the computer via the paper tape reader. The format required on the paper tape is the same as the output format of the Bioctal Dump routine. The addresses to be loaded appear first on the tape, followed by a check sum of the information to be loaded. The information to be loaded into those addresses then follows. A check sum is computed as the information from the paper tape is loaded into the computer. After the tape has been loaded, the computed check sum is compared with the punched check sum to see if they are the same. If they are the same, this is a reliable indication that the information has been loaded correctly. A difference in check sums indicates that the information has not been correctly loaded into the computer. In the latter case, the typewriter will type'check sum error'. In either case, the computer stops at the beginning of the bloctal load routine. The reader assembly mode of operation is used in this routine, necessitating the presence of a seventh level hole every eighth frame. #### BIOCTAL DUMP The Bioctal Dump routine punches a bioctally-coded paper tape of the contents of a specified area of core memory. This area is specified by entering the first address into index register 6 and the last address into index register 5. Each location of memory dumped occupies eight frames of paper tape (six bits per frame) and a seventh level hole is punched in the first frame of each group of eight frames. This seventh level hole is used for control in loading tapes. The beginning and ending addresses of the area of core memory being dumped are first punched on the tape. This makes the tape suitable for reloading into the computer by use of the Bioctal Load routine. Following the area being dumped, a check sum of the contents of that area is punched. The actual contents of each storage location being dumped are then punched on the tape in consecutive order. This routine also punches leader at the beginning and end of the punched area. There are no seventh level holes in the leader. Bioctal dump of addresses 01200 through 01202, containing the following: (01200) 75 4 01400 50 0 00000 (01201) 57 3 01000 56 4 01100 (01202) 75 4 01500 50 0 00000 #### TAPE CONTROLLED LOAD The Tape Controlled Load routine will load a paper tape into any area of core memory, providing the tape has been prepared in the correct format. It is impossible to load a tape in the same area in which the Tape Controlled Load routine is located, but the routine itself checks for this condition. The desired starting address is entered into index register 6. Tapes to be loaded using this routine should be coded starting at address 00000. However, instead of typing the address on the tape, as is done for the Flex Load routine, a control digit precedes the information to be loaded into each address. This control digit is interpreted by the routine as an address modifier, so that when a tape is loaded starting at a base address (index register 6) the base address is added to each execution address which requires modification. Addresses are loaded consecutively starting with the base address, so there must be information on the tape for each address and it must be in consecutive order. The paper tape must be coded in flexcode. It may be prepared on the Flexowriter or by using the Tape Controlled Dump routine. The control digits used are 0, 1, 2, 3, 4, and 7. The meanings of these digits are as follows: - 0. do not modify - 1. modify the upper address of this word - 2. modify the lower address of this word - 3. modify both addresses of this word - 4. check sum (not to be loaded into computer) - 7. end of tape, stop #### Example of tape format: - 1. 75 4 00066 50 0 00045 - 3. 55 1 00011 16 0 00122 - 0. 10 0 00045 50 1 00000 - 3. 20 1 00114 75 4 00075 - 2. 54 1 00004 75 0 00014 - 4. 56 7 00267 30 5 00302 - 7. Using the above tape and setting index register 6 to 76400, the contents of addresses 76400 - 76404, after the tape has been loaded, will be: ``` (76400) 75 4 76466 50 0 00045 (76401) 55 1 76411 16 0 76522 (76402) 10 0 00045 50 1 00000 (76403) 20 1 76514 75 4 76475 (76404) 54 1 00004 75 0 76414 ``` #### TAPE CONTROLLED DUMP The Tape Controlled Dump routine will punch on paper tape the contents of a specified area of core memory in a format which may be used as input for the Tape Controlled Load routine. Each execution address of each memory location in the specified area is examined to see whether it falls between the first and last address being dumped (inclusive). If neither address is in this area, the contents are punched on the paper tape preceded by a control digit of zero. This control digit indicates to the Tape Controlled Load routine that this word should be loaded as it is, without modification. If either address falls within the area being dumped, the word is further examined to see if either of the function codes is one which uses the execution address as an operand, in which case the half word in which that function code occurs is not modified. If it is found that only the upper address of a word should be modified, the control digit for that word is a one; if only the lower address should be modified, the control digit is a two; and if both addresses should be modified, the control digit is a three. The first address of the area being dumped is subtracted from those addresses which should be modified before they are punched on the paper tape. A check sum of the area being dumped is computed. This sum is punched at the end of the tape, preceded by a control digit of four. The four indicates to the Tape Controlled Load routine that the word following should not be loaded into the next location but should be used to compare with the check sum computed during the loading process. The last entry on the tape, following the check sum, is a control digit of seven, which is merely a signal to stop. Each control digit is preceded by a carriage return. An extra carriage return is punched after every eight words. \*01, 02, 03, 04, 05, 06, 07, 10, 11, 34, 35, 50, 51, 54, 74, 0, 74.7. #### TYPE TEXT Type Text is a subroutine which may be used to type out error indications or other information for the benefit of the operator. The subroutine is entered by a return jump. Flexcode for the information to be typed should be stored, eight codes per storage location, in consecutive addresses immediately following the address in which the return jump is located. The order in which the flexcode is sent to the typewriter is from left to right. A 77 code should be stored following the flexcode for the last character to be typed. Any number of locations may be used for storage of flexcode. The Type Text subroutine modifies its own exit each time it uses one storage location packed with flexcode. In this way, when the 77 code is reached, control is returned to the main routine at the address following the one in which the 77 code is stored. #### APPENDIX E #### TRACE PROGRAM #### GENERAL The TRACE program monitors the execution of any other program by indicating the instruction location and the contents of A and Q, after execution of each instruction. Indication is primarily by means of a paper tape punched in Flexowriter code, but a printed copy can also be made at any time at the monitor typewriter, so that the progress of the monitored program can be observed. A number of options are available, so that the program can be made to (1) either punch, or print and punch; (2) indicate either all instructions, or only those lying within certain pre-selected ranges; (3) indicate either the location and contents of A and Q, or just the location; and (4) either perform the functions described above, or indicate only locations of all executed jumps and their destinations. To accomplish this, the TRACE program is first set up by loading the starting address of the program-to-be-monitored, along with the desired ranges of locations to be traced, into a "directory." When the TRACE program is started, it extracts each instruction from the monitored program, enters it into a special "test block," executes it, and punches or prints certain indicators, in accordance with parameters in the directory. Also, if any of the input/output channels are activated by an instruction of the monitored program, printing or punching ceases until all previously activated channels are deactivated; this feature prevents interference with the use of the input/output equipment by the trace program, and thus permits the use of TRACE on any type of program, providing the monitored program does not destroy any of the addresses within TRACE. #### DIRECTORY The directory is punched on paper tape in Flexowriter code, in a format which is the same as that used for Flex-load. An example is shown in Table V 1. The first word of the directory, to be loaded into address 77600, contains a "mode designator" and a starting address equal to the initial location of the program to be monitored. Succeeding words contain ranges, with the lower-value address in the left half, and the higher, in the right half. The directory is terminated by choosing the rightmost address of the next word equal to zero. A maximum of 200 (octal) words can be used in the directory. #### OPERATING INSTRUCTIONS After TRACE and the program to be-monitored are loaded, load the directory via the Flex-load routine. Set the program address counter to 72000, and select the jump keys in accordance with the program being monitored. ## TABLE VI TYPICAL DIRECTORY | 77600 | 77 | 7 | 00000 | 00 | 0 | 01000 | Designator Starting Address | |-------|----|---|-------|----|---|-------|-----------------------------| | 77601 | 00 | 0 | 01000 | 00 | 0 | 01377 | Range | | 77602 | 00 | 0 | 01600 | 00 | 0 | 01607 | Range | | 77603 | 00 | 0 | 01614 | 00 | 0 | 01614 | Range | | 77604 | 00 | 0 | 02010 | 00 | 0 | 02014 | Range | | 77605 | 00 | 0 | 00000 | 00 | 0 | 00000 | End of Directory | Note: In word 77600, the left-most three octal digits (8<sup>15</sup>, 8<sup>14</sup>, 8<sup>13</sup>) control the mode, and are selected as follows: Digit $8^{15} = 0$ : Punches instruction location and contents of A and Q. $\neq$ 0 : Punches only jump sources and destinations. Digit $8^{14} = 0$ : Punches for each instruction. ≠ 0 : Punches only for instructions within ranges specified by directory. Digit $8^{13} = 0$ : Punches $\neq 0$ : Prints and punches. #### APPENDIX F # Program for Duplicating Punched Tape The operator places a tape in the reader with first punched data frame less than 20 (octal) frames ahead of the reading station. The program reads each group of 20 consecutive frames, and reproduces these on the high speed punch. As soon as 20 consecutive blank frames (trailer) have been punched, program stops. | Prog | ram | |------|-----| |------|-----| | (60000) | = | EXF<br>ENI | ე<br>6 | 11211<br>60120 | Select and turn on punch motor<br>Set terminating address in B <sup>6</sup> | |---------|----------|-------------|--------|----------------|----------------------------------------------------------------------------------------------------| | (60001) | æ | SIL<br>SIL | 6<br>6 | 00001<br>00002 | Store Term. Address in lower (00001, Store Term. Address in lower (00002) | | (60002) | 2 | EXF<br>SLS | 7<br>0 | 11211<br>00000 | Sense presence of char. mode; if not present, stop. | | (60003) | <b>3</b> | EXF<br>EXF | 0<br>1 | 11200<br>60100 | Select Reader Activate read, starting at 60100 | | (60004) | = | LIU<br>Pass | 6 | 00001 | Put machine count of words read from 00001 (upper) into B6 | | (60005) | 28 | ISK | 6 | 60120 | If (B <sup>6</sup> ) Terminating Address, skip If (B <sup>6</sup> ) Terminating Address, take N.I. | | | | SLJ | 0 | 60004 | Jump to test step again. | | (60006) | • | EXF<br>EXF | 0<br>2 | 11200<br>60100 | Select punch in character mode<br>Activate punch starting from (00100) | | (60007) | *** | LIU<br>Pass | 6 | 00002 | Put machine count of words punched from upper (00002) in B <sup>6</sup> | | (60010 | * | ISK | 6 | 60120 | If (B <sup>6</sup> ) =Terminal Address, skip If (B <sup>6</sup> ) +Terminal Address, take N. I | | | | SLJ | 0 | 60007 | Jump to test step again | | (60011) | • | ENI<br>Pass | 6 | 00000 | Clear B <sup>6</sup> | | (60012) | - | LDA | 6 | 60100 | Send word to A | | | | AJP | 1 | 60000 | If first word = 0, go back for more data | | (60013) | 3 | ISK | 6 | 00017 | If $(B^6) = 17$ , skip, (all last words were | | | | SLJ | 0 | 60012 | If $(B^6) \neq 17$ , take N. I. zeros) | | (60014) | = | | 0 | 60000 | STOP | | | | 0 | 0 | (6000 | | #### APPENDIX G #### Program for Adding One Record to File This program adds one record to the end of magnetic tape 1. It is assumed the end of data on tape is marked by an end-of-file mark. The program advances the tape past the end of file mark, backs up two records, advances one record and then writes the additional record from memory 60000-60177, and then writes a new end-of-file mark. The reason for backing up two after reading end-of-file, then advancing by one, is so that writing shall follow a forward movement. If writing follows a back-up, especially over an end-of-file mark, the spacing between records will not be constant. | (50000) = EXF SLJ 7 32010 Is mag. tape 1 ready to read? If not ready, wait. (50001) = ENI 6 00003 Temp +1 Ste B to temp. address 1 00007 Store term address in lower (0003) (50002) = EXF 0 32010 EXF 3 Temp Read one word to memory - tape moves one block. (50003) = EXF 7 32010 Sense if ready to read again If not ready, wait. (50004) = EXF 7 32012 Sense if end-of-file read If not end-of-file - read again. (50005) = EXF 7 32011 Move back one record (50006) = EXF 7 32010 Sense, if ready to read If not ready, wait. (50007) = EXF 7 32011 Move back one record. (50010) = EXF 7 32011 Sense, if ready to read If not ready, wait. (50011) = EXF 7 32011 Sense, if ready to read If not ready, wait. (50012) = EXF 0 32010 Sense, if ready to read If not ready, wait. (50012) = EXF 0 32010 Sense, if ready to read If not ready, wait. (50013) = EXF 7 42012 Sense end-of-file on tape 1 EXF 3 Temp Activate read (50014) = EXF 7 42012 Sense end-of-file on tape 1 If not ready, wait. (50014) = EXF 0 42012 Sense end-of-file on tape 1 If not ready, wait. (50015) = EXF 0 42010 Select Write Write activate | program | ı | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------------|---|--------------|---------------------------------------| | SLJ | (50000) | = EXF | 7 | 32010 | Is mag. tape 1 ready to read? | | SIL 6 00003 Store term address in lower (0003) | , | | 0 | 50000 | If not ready, wait. | | SIL 6 00003 Store term address in lower (0003) | (50001) | = FNI | 6 | Temp + 1 | Set B <sup>6</sup> to temp. address 1 | | (50002) = EXF | (30001) | | | <del>-</del> | | | EXF 3 Temp Read one word to memory - tape moves one block. (50003) = EXF 7 32010 Sense if ready to read again If not ready, wait. (50004) = EXF 7 32012 Sense if end-of-file read SLJ 0 50001 If not end-of-file - read again. (50005) = EXF 0 32011 Move back one record (50006) = EXF 7 32010 Sense, if ready to read If not ready, wait. (50007) = EXF 0 32011 Move back one record. (50010) = EXF 7 32011 Sense, if ready to read If not ready, wait. (50010) = EXF 7 32011 Sense, if ready to read If not ready, wait. (50011) = ENI 6 Temp+1 Set B to Term Address Store term. add. in 00003. (50012) = EXF 0 32010 Select mag. tape 1 EXF 3 Temp Activate read (50013) = EXF 7 42012 Sense end-of-file on tape 1 SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B to term address SIL 6 00004 Enter term. add. in 000004. | | | · | | , | | moves one block. | (50002) | = EXF | 0 | 32010 | Select Mag. Tape 1 to read | | (50003) = EXF | | EXF | 3 | Temp | _ | | SLJ | | | | | moves one block. | | SLJ | (50003) | = EXF | 7 | 32010 | Sense if ready to read again | | SLJ | (, | | | 50003 | If not ready, wait. | | SLJ | | | | | | | (50005) = EXF Pass (50006) = EXF 7 32010 Sense, if ready to read If not ready, wait. (50007) = EXF 0 32011 Move back one record. (50010) = EXF 7 32011 Sense, if ready to read If not ready, wait. (50011) = EXF 7 32011 Sense, if ready to read If not ready, wait. (50011) = ENI 6 Temp+1 Set B <sup>6</sup> to Term Address SIL 6 00003 Store term. add. in 00003. (50012) = EXF 0 32010 Select mag. tape 1 Activate read (50013) = EXF 7 42012 Sense end-of-file on tape 1 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | (50004) | = EXF | 7 | 32012 | | | Pass (50006) = EXF | | SLJ | 0 | 50001 | If not end-of-file - read again. | | Pass (50006) = EXF | | | | | | | (50006) = EXF 7 32010 Sense, if ready to read If not ready, wait. (50007) = EXF 0 32011 Move back one record. (50010) = EXF 7 32011 Sense, if ready to read If not ready, wait. (50011) = ENI 6 Temp+1 Set B <sup>6</sup> to Term Address SIL 6 00003 Store term. add. in 00003. (50012) = EXF 0 32010 Select mag. tape 1 Activate read (50013) = EXF 7 42012 Sense end-of-file on tape 1 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | (50005) | = EXF | 0 | 32011 | Move back one record | | SLJ 0 50006 If not ready, wait. (50007) = EXF 0 32011 Move back one record. (50010) = EXF 7 32011 Sense, if ready to read If not ready, wait. (50011) = ENI 6 Temp+1 Set B <sup>6</sup> to Term Address SIL 6 00003 Store term. add. in 00003. (50012) = EXF 0 32010 Select mag. tape 1 EXF 3 Temp Activate read (50013) = EXF 7 42012 Sense end-of-file on tape 1 SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. | | Pass | | | | | SLJ 0 50006 If not ready, wait. (50007) = EXF 0 32011 Move back one record. (50010) = EXF 7 32011 Sense, if ready to read If not ready, wait. (50011) = ENI 6 Temp+1 Set B <sup>6</sup> to Term Address SIL 6 00003 Store term. add. in 00003. (50012) = EXF 0 32010 Select mag. tape 1 EXF 3 Temp Activate read (50013) = EXF 7 42012 Sense end-of-file on tape 1 SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. | | | _ | 22010 | | | (50007) = EXF | (50006) | | | | • | | Pass (50010) = EXF | | SLJ | U | 50006 | not ready, wait. | | Pass (50010) = EXF | (50007) | - FVF | 0 | 32011 | Move back one record. | | (50010) = EXF 7 32011 Sense, if ready to read SLJ 0 50010 If not ready, wait. (50011) = ENI 6 Temp+1 Set B <sup>6</sup> to Term Address SIL 6 00003 Store term. add. in 00003. (50012) = EXF 0 32010 Select mag. tape 1 Activate read (50013) = EXF 7 42012 Sense end-of-file on tape 1 SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | (30001) | | U | 32011 | Move buck one recert. | | SLJ 0 50010 If not ready, wait. (50011) = ENI 6 Temp+1 Set B <sup>6</sup> to Term Address SIL 6 00003 Store term. add. in 00003. (50012) = EXF 0 32010 Select mag. tape 1 EXF 3 Temp Activate read (50013) = EXF 7 42012 Sense end-of-file on tape 1 SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | | rass | | | | | SLJ 0 50010 If not ready, wait. (50011) = ENI 6 Temp+1 Set B <sup>6</sup> to Term Address SIL 6 00003 Store term. add. in 00003. (50012) = EXF 0 32010 Select mag. tape 1 EXF 3 Temp Activate read (50013) = EXF 7 42012 Sense end-of-file on tape 1 SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | (50010) | = EXF | 7 | 32011 | Sense, if ready to read | | (50011) = ENI 6 Temp+1 Set B <sup>6</sup> to Term Address SIL 6 00003 Store term. add. in 00003. (50012) = EXF 0 32010 Select mag. tape 1 EXF 3 Temp Activate read (50013) = EXF 7 42012 Sense end-of-file on tape 1 SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. | (30010) | | | 50010 | | | SIL 6 00003 Store term. add. in 00003. (50012) = EXF 0 32010 Select mag. tape 1 EXF 3 Temp Activate read (50013) = EXF 7 42012 Sense end-of-file on tape 1 SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | | | | | | | (50012) = EXF | (50011) | = ENI | 6 | Temp+l | Set B <sup>6</sup> to Term Address | | EXF 3 Temp Activate read (50013) = EXF 7 42012 Sense end-of-file on tape 1 SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | • | SIL | 6 | 00003 | Store term. add. in 00003. | | EXF 3 Temp Activate read (50013) = EXF 7 42012 Sense end-of-file on tape 1 SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | | | | | | | (50013) = EXF 7 42012 Sense end-of-file on tape 1 SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | (50012) | = EXF | 0 | 32010 | - | | SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | | $\mathtt{EXF}$ | 3 | Temp | Activate read | | SLJ 0 50013 If not ready, wait. (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | | | _ | | | | (50014) = ENI 6 Rec+200 Set B <sup>6</sup> to term address SIL 6 00004 Enter term, add, in 00004. (50015) = EXF 0 42010 Select Write | (50013) | | | | _ | | SIL 6 00004 Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | | SLJ | 0 | 50013 | If not ready, wait. | | SIL 6 00004 Enter term. add. in 00004. (50015) = EXF 0 42010 Select Write | 45001.4 | - 5311 | 4 | D a a ± 200 | Sat R6 to term address | | (50015) = EXF 0 42010 Select Write | (50014) | | | | | | | | SIL | O | 00004 | Enter term, add, in cook. | | | (50015) | = FXF | 0 | 42010 | Select Write | | | (30013) | | | | | | (50016) = EXF 7 42012 Sense end of write indicator | | | | | Some and of write indicator | | (30010) | (20016) | | | | | | | | SLJ | _ | | · | | (50017) = EXF 0 42016 Write end-of-file mark on tape | (50017) | | 0 | 42016 | Write end-of-file mark on tape | | Pass Pass | | Pass | | | | | (50020) = | EXF | 7 | 42012 | Skip if ready | |-----------|-------------|--------|----------------|-----------------------------| | | SLJ | 0 | 50020 | Wait | | (50021) = | EXF<br>Pass | 0 | 32015 | Rewind | | (50022) = | EXF<br>SLJ | 7<br>0 | 32010<br>50022 | Sense end of rewind<br>Wait | | (50023) = | SLS<br>0 | 0 | 50000<br>0 | Stop | #### COMMENT SHEET # CONTROL DATA 1604 COMPUTER Programming Training Manual Pub. No. 60001500 | FROM | NAME: | | | | | | | | |--------|--------|---------------------------------------------------------------------------------|--|--|--|--|--|--| | | BUSINE | SS : | | | | | | | | | | | | | | | | | | COMMEN | NTS: | (DESCRIBE ERRORS, SUGGESTED ADDITION OR DELETION AND INCLUDE PAGE NUMBER, ETC.) | | | | | | | STAPLE FOLD FOLD FOLD STAPLE MINNEAPOLIS, MINN. FIRST CLASS PERMIT NO. 8241 BUSINESS REPLY MAIL NO POSTAGE STAMP NECESSARY IF MAILED IN U.S.A. POSTAGE WILL BE PAID BY CONTROL DATA CORPORATION 8100 34TH AVENUE SOUTH MINNEAPOLIS 20, MINNESOTA ATTN: TECHNICAL PUBLICATIONS DEPT. COMPUTER DIVISION PLANT TWO FOLD STAPLE CUT ALONG LINE