RPC-4000 ## programming manual | ******************************* | ************************* | \$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$ | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | |---------------------------------|---------------------------|------------------------------------------------------------------------------|-----------------------------------------| | | | | | | | | | | | | | | | | | | | | | | ZHIEL. | TEMPORARY<br>EDITION | | | | | april | | | | WPY | 1960 | | | | | | | | i.ux | | | | ### FOREWORD THIS TEMPORARY EDITION OF THE RPC PROGRAMMING MANUAL IS BEING PUBLISHED TO PROVIDE MATERIAL RELATIVE TO THE COMMAND REPERTOIRE AND MODES OF OPERATION OF THE RPC-4000 FOR THOSE PERSONS WITH AN IMMEDIATE NEED FOR THIS INFORMATION. THE MANUAL, AS PRESENTED, IS INCOMPLETE, CONSISTING OF FOUR OF AN EVENTUAL SEVEN SECTIONS. THE COMPLETE MANUAL, TO BE PUBLISHED IN THE NEAR FUTURE, WILL CONTAIN SECTIONS ON PROGRAMMING TECHNIQUES, MANUAL CONTROLS AND I/O DEVICES, AND SUMMARY LISTS AND TABLES. ### AN INTRODUCTION TO COMPUTERS THE EMERGENCE OF BURE PELECTRONIC COMPUTER AS A MAJOR TOOL FOR BUSINESS AND INDUSTRY IS NOT SURPRISING WHEN SET IS CONSIDERED THAT A VERY LARGE PART OF TODAY'S TOTAL WORK EFFORT IS DEVOTED TO THE PROCESSING OF LENGTHY CALCULA-TIONS OR VAST AMOUNTS OF STATISTICAL DATA. MUCH OF THIS COMPUTATION IN-VOLVES WEART SOME REPETITION ALONG WITH THE NECESSITY TO EFFECTIVELY UTI-LIZE ASCONFUSING ARRAY OF INTERRELATED INFORMATION. IT IS JUST THIS SORT OF HOOB THAT CANDBE HANDLED BEST BY AN INTELLIGENTLY DIRECTED MACHINE. ONBY GANSTHE GOMPUTER PERFORM THE SE TASKS MANY TIMES FASTER, BUT WITH MUCH LESS DE MALLIE DE TY (THAN CANOTHE MHUMAN WORKER. JA) + 9 3 10 20 SPECKE BALLESPEE PROBLEMS. SINCE EARLIEST TIMES THE DEVELOPMENT OF COMPUTING ALDS HAS FOLLOWED TWO SEPERATE PATHS, DEPENDING UPON THE MEANS EMPLOYED TO RECOGNIZE AND TO RE-PRESENT INFORMATION WALUES. THOSE DEVICES WHICH OPERATE BY THE MEASURE-MENT POF CONTINUOUS PHYSICAL VARIABLES ARE KNOWN AS ANALOG DEVICES OR ANALOG COMPUTERS. A FUEL GAUGE IS A SIMPLE ANALOG DEVICE IN THAT THE DEFLECTION OF A POINTER IS ANALOGOUS TO THE QUANTITY OF FUEL IN A TANK. 古子,当为任民党国的相对主,魏禹建和世史的多兴有。节禄 THE OTHER TYPE OF COMPUTING AID, AND THAT WHICH DIRECTLY CONCERNS KNOWN AS A DIGITAL COMPUTER. IT IS CHARACTERIZED BY ITS REPRESENTATION OF VALUES, BOTH QUANTITATIVE AND SYMBOLIC, BY COUNTS OF DISCRETE DISCONTIN-UOUS PHYSICAL UNITS. THE ABACUS IS A SIMPLE DIGITAL DEVICE IN WHICH BEADS ARE USED TO REPRESENT THE COUNTING UNITS. A MORE COMPLEX AND MODERN, BUT STILL NON-AUTOMATIC DIGITAL DEVICE IS REPRESENTED BY THE DESK CALCULATOR. ### THE AUTOMATIC DIGITAL COMPUTER BECECSTIF, CONTAIN CERTAIN BASSO CORPAINED SOME 18,000 VACOURS THE ABACUS HAS SERVED MAN FOR THOUSANDS OF YEARS AS A SIMPLE STATIC STORAGE DEVICES TO HOLD THE PROGRESSIVE RESULTS OF LENGTHY CALCULATIONS. THE MODERN DESK CALCULATOR HAS TIN ADDITION TO A SIMILAR LIMITED STORAGE CAPACITY. THE ABILITY TO MECHANICALLY PERFORM CERTAIN BASIC ARTTHMETIC OPERATIONS SUCH AS ADDATION, DIVESTON, ETC. HOWEVER, BOTH OF THESE AIDS TO COMPUTA TION BEQUERE THE CONSTANT SERVICES OF THE HUMAN OPERATOR TO DIRECT EACH INDIVIDUAL HOPERATHON ANTHUS ATHE SPEED TOF THESE NON-AUTOMATIC DEVICES LIMETED TO STHE RAPTOTTY WITH WHICH THE OPERATOR CAN CONTROL THE IR ACTIONS. INFORDERS TO GRUNGSTON AUTOMATICALLY, A COMPUTER MUST BE SELF-SEQUENCING; THAT SES, JIT SMUST SHAVE "THE CCAPABILLTY" OF CONTROLLING THE "ORDER" IN WHICH THE STERS SOR AN CAUCUBATION ARE SPERFORMED, SET FERENCE TO A SERIES OF SIGNALS WHICH ARE STORED WITHIN ITSELF. WHEN AN ENGLISHMAN BY THE NAME OF CHARLES BABBAGE, WITH THE FINANCIAL BACKING OF THE BRITISH GOVERNMENT, BEGAN WORN ON WHAT HE CALLED A FULL SIZE "DIFFERENCE ENGINE". THIS MACHINE WAS DESIGNED FOR THE PURPOSE OF CALCULATING MATHEMATICAL TABLES SO AS TO RELIEVE THE HUMAN OPERATOR OF THIS ROUTINE FUNCTION. TEN YEARS LATER, AFTER AN EXPENDITURE OF 17,000 POUNDS, THE PROJECT WAS ABANDONED. IN 1833 HE ELABORATED UPON HIS INITIAL EFFORTS, TO DEVELOP THE CONCEPT OF A UNIVERSAL COMPUTER WHICH HE CALLED AN "ANALYTICAL ENGINE". IT WAS DESIGNED TO BE FULLY AUTOMATIC AND EXTERNALLY PROGRAMMED. IT INCORPORATED FACILITIES FOR INPUT/OUTPUT, ARITHMETIC OPERATIONS, INTERNAL STORAGE AND AUTOMATIC PROGRAM CONTROL. UNFORTUNATELY, THE STATE OF THE ENGINEERING ART WAS INSUFFICIENTLY ADVANCED TO PRODUCE A MACHINE OF SUCH MECHANICAL COMPLEXITY. ALTHOUGH A CONSIDERABLE AMOUNT OF MONEY AND EFFORT WERE EXPENDED. THE MACHINE WAS NEVER COMPLETED. I VATABLED. IT WAS NOT UNTIL THE YEAR 1944 THAT THE FIRST SUCH UNIVERSAL DIGITAL COM-TOWN OF THE THAT THE FIRST SUCH UNIVERSAL DIGITAL COM-TOWN OF THE THAT THE FIRST SUCH UNIVERSAL DIGITAL COM-TOWN OF THE THAT THE FIRST SUCH UNIVERSAL DIGITAL COM-TOWN OF THE FIRST COMPUTER SOME COMPARED WITH THE COMPUTERS IN SUSE TODAY. STHEOFIRST COMPUTER TO SUBSTITUTE ELECTRONIC CIRCULTRY FOR ELECTROMAGNETIC WAS THE ENIAC (ELECTRONIC NUMERICAL INTEGRATOR AND CALCULATOR), WHICH WAS USED PRIMARILY TO SOLVE BALLISTICS PROBLEMS. IT CONTAINED SOME 18,000 VACUUM TUBES IN ADDITION TO ABOUT 1500 ELECTROMECHANGE HELEYSAT VERSIONS BOOK THAT THE TOWN OF THE PROBLEMS. THE GROWTH RATE OF THE COMPUTER INDUSTRY FOLLOWING THE SE PHONEER SEFFORTS HAS BEEN TRULY FANTASTIC. DIGITAL COMPUTERS ARE BEING ENTRUSTED WITH TAMM EVER INCREASING SHARE OF THE ROUTINE REPETITIVE FUNCTIONS OF BUSINESS AND INDUSTRY. COMPUTERS ARE BEING PRODUCED IN A VARIETY OF TYPESTAND SIZED CLASSES DEPENDING ON THEIR INTENDED USE. OF PARTICULAR IMPORTANCE IS THE CLASS OF SMALL TO MEDIUM SIZE COMPUTERS BEING APPLIED TOOSUCH DIVERSES PROBEST LEMS AS PROCESS CONTROL. DATA REDUCTION FOR MANAGEMENT ANALYSISS, INVENTORY AND CONTROL AND SCIENTIFIC PROBLEM SOLVING. THEY ARE CHARACTERIZED BY MODERATEAU COST, EASE OF INSTALLATION AND MAINTENANCE, AND GREAT FLEXIBALITY INVENTORY APPLICATION TO A VARIETY OF TASKS. ### COMPUTER DESIGN CONSIDERATIONS AN AUTOMATIC DIGITAL COMPUTER MUST, OF NECESSITY, CONTAIN CERTAIN BASIC LOGICAL ELEMENTS. IT MUST, OF COURSE, HAVE THE ABILITY TO PERFORM AUNUMBERNT OF SIMPLE ARITHMETIC AND LOGICAL OPERATIONS. THE SOLUTION OF MOST MATHET OF AN AUTOMATICAL EQUATIONS, REGARDLESS OF COMPLEXITY GAMBE REDUCED TO ASSERIES OF A BASIC ARITHMETIC OPERATIONS, THUS, THE ABILITY TO ADD A SUBTRACT, YMULTIRLYHT AND DIVIDE IS SUFFICIENT TO PERFORM VIRTUALLY ANY MATHEMATICAL COMPUTATION OF THE SE OPERATIONS MUSTA HOWEVER, BET PERFORMED AND MATHEMATICAL COMPUTATION OF THE CIRCUITRY WHICH INTERPRETS OTHE ANSTRUCTION CODES, YBRINGS INTHE OPERATION OPERATION OF THE CIRCUITRY WHICH INTERPRETS OTHE ANSTRUCTION CODES, YBRINGS INTHE OPERATION OPERATION IN THE CIRCUITRY WHICH INTERPRETS OTHE ANSTRUCTION CODES, YBRINGS INTHE OPERATION OF THE CIRCUITRY WHICH INTERPRETS OTHE ANSTRUCTION CODES, YBRINGS INTHE OPERATION OF THE CIRCUITRY WHICH INTERPRETS OTHE ANSTRUCTION CODES, YBRINGS INTHE OPERATION OF THE COMPONITION OF THE CONTROL OF THE STEPPENTS OF THE ARITHMETIC ELEMENT. AND STRUCTURED OPERATION AND SOME THE ARITHMETIC ELEMENT OF IN ORDER THAT INFORMATION (BOTH INSTRUCTIONS AND OPERANDS) MAY BE SUPPLIED TO THE ARITHMETIC ELEMENT AT A RATE COMPARABLE TO ITS INHERENT PROCESSING SPEED, IT IS NECESSARY THAT THERE BE SOME FORM OF INTERNAL MEMORY ELEMENT. THIS ELEMENT IS GENERALLY USED TO STORE BOTH THE PROGRAM TO DIRECT THE PROCESSING OPERATION, AND THE DATA TO BE PROCESSED. IT MUST PROVIDE FOR RAPID ACCESS AND LOCATABILITY OF EACH PIECE OF INFORMATION ON A PROGRAM DEMAND BASIS. WITHOUT THE MEMORY ELEMENT, THE SPEED OF A COMPUTER WOULD BE RESTRICTED TO A MECHANICAL INSERTION RATE. PRIOR TO BEGINNING A PROCESSING OPERATION, AND OFTEN DURING THE COURSE OF AN OPERATION, INFORMATION FROM AN EXTERNAL SOURCE MUST BE ENTERED INTO THE COMPUTER'S MEMORY. CONSEQUENTLY, THERE IS REQUIRED AN INPUT ELEMENT TO ACCOMPLISH THIS LOADING OF DATA. CONVERSELY, AT THE COMPLETION OF, AND OFTEN DURING AN OPERATION, THE PRO-CESSED DATA MUST BE EXTERNALLY PRESENTED IN A USABLE AND UNDERSTANDABLE MANNER. THIS INTERNAL TO EXTERNAL TRANSFER OF DATA IS A FUNCTION OF THE OUTPUT ELEMENT. FINALLY, AND VITAL TO THE AUTOMATIC FUNCTIONING OF THE COMPUTER, THERE MUST BE A CONTROL ELEMENT TO COORDINATE THE ACTIVITIES OF THE OTHER FOUR ELEMENTS. IT IS RESPONSIBLE FOR THE PROPER SEQUENCING OF EACH ACTION WITHIN THE COMPUTER. IT IS THIS PRECISE SEQUENCING WHICH DETERMINES WHETHER A PIECE OF INFORMATION STORED IN MEMORY IS TO BE USED AS AN INSTRUCTION OR AS DATA TO BE PROCESSED. IT IS THE ONLY WAY IN WHICH THE COMPUTER CAN MAKE THIS DISTINCTION. DATA AND INSTRUCTIONS OCCUR INTERMIXED IN MEMORY, AND IN THE SAME FORM. IN FACT, THE IDENTICAL PIECE OF INFORMATION MAY BE USED IN BOTH WAYS IN DIFFERENT PARTS OF A PROGRAM. FURTHER, THIS CONTROL ELEMENT MUST ACTIVATE INPUT AND OUTPUT DEVICES. WHEN CALLED FOR, AND, IN GENERAL, DIRECT THE OVERALL PERFORMANCE OF A PROGRAM OR PROGRAM COMPLEX. FIGURE 1. LOGICAL DIAGRAM OF AUTOMATIC COMPUTER ### GLOSSARY OF COMPUTER TERMS - ACCESS TIME----THE TIME REQUIRED TO BRING A SELECTED WORD FROM STORAGE TO THE POINT AT WHICH IT IS TO BE USED OR PROCESSED. - ACCUMULATOR----THAT REGISTER, WITHIN THE ARITHMETIC ELEMENT, IN WHICH ARE FORMED THE RESULTS OF ARITHMETICAL AND LOGICAL OPERATIONS. - ADDRESS----- CHARACTER, OR STRING OF CHARACTERS, USED TO IDENTIFY A LOCATION WITHIN THE COMPUTER MEMORY. - ADDRESS----- A LABEL, USUALLY NUMERIC, WHICH IDENTIFIES A LOCATION IN (ABSOLUTE) MEMORY RELATIVE TO THE INITIAL MEMORY LOCATION. - ADDRESS-----A LABEL, CONSISTING OF ARBITRARILY CHOSEN SYMBOLS TO REPRE(SYMBOLIC) SENT A LOCATION WITHIN A PROGRAM ROUTINE WHICH IS INDEPENDENT OF THE LOCATION OF THE ROUTINE IN MEMORY OR ITS INITIAL LOCATION. - ALPHA-NUMERIC--A SYMBOL SYSTEM IN WHICH ARE INCLUDED ALPHABETIC, NUMERIC AND SPECIAL CHARACTERS. - ARITHMETIC----THAT PART OF A COMPUTER IN WHICH ARITHMETIC AND LOGICAL ELEMENT COMPUTATIONS AND DECISION MAKING FUNCTIONS ARE PERFORMED. - ASSEMBLER-----A Utility Program which assigns Absolute Address values for the values in a Symbolically Addressed Program Routine and sets up storage allocations for its various parts. - BASE-----IN A NUMBER SYSTEM EMPLOYING POSITIONAL NOTATION, THE BASE IS THE NUMBER OF COUNTS REQUIRED IN EACH POSITION TO CAUSE A CHANGE IN THE NEXT HIGHER POSITION. IT IS ALSO THE NUMBER OF DISCRETE NUMERIC CHARACTERS EMPLOYED IN THE SYSTEM. - BINARY-CODED---REPRESENTATION OF EACH DECIMAL CHARACTER IN A NUMBER BY A DECIMAL PATTERN OF BINARY DIGITS. - BIT------COMMON PROGRAMMING EXPRESSION FOR BINARY DIGIT. THE SMALL-EST MEANINGFUL UNIT OF INFORMATION IN THE COMPUTER. AN INDIVIDUAL BIT IS RESTRICTED TO THE VALUES "O" AND "I". - BLOCK-----A GROUP OF RELATED COMPUTER WORDS OR CHARACTERS PROCESSED OR TRANSFERRED AS A UNIT. - BOOTSTRAP-----A PROCEDURE FOR ENTERING A PROGRAM INTO THE COMPUTER. THE INITIAL FEW STEPS OF THE ROUTINE, NORMALLY ENTERED MANUALLY. ARE USED TO AUTOMATICALLY LOAD THE REMAINDER OF THE PROGRAM. - BUFFER-----AN INTERMEDIATE STORAGE DEVICE FOR COORDINATING THE TRANSFER OF INFORMATION FROM ONE PART OF THE COMPUTER TO ANOTHER. - COMMAND-----THE DIRECTIVE PORTION OF AN INSTRUCTION. THE SPECIFIED ACTION TO BE TAKEN BY THE COMPUTER. - COMPILER-----A UTILITY PROGRAM WHICH PRODUCES A MACHINE LANGUAGE PROGRAM FROM A PROGRAM WHICH IS CODED IN A PROBLEM ORIENTED LANGUAGE. THE CODING FORM OF THE PROGRAM TO BE COMPILED ORDINARILY WILL CLOSELY APPROXIMATE STANDARD ALGEBRAIC NOTATION. - COMPUTER-----AN ELECTRONIC DEVICE FOR THE AUTOMATIC CALCULATION OF SE(DIGITAL) QUENCES OF ARITHMETIC AND LOGICAL OPERATIONS. QUANTITIES AND VALUES ARE REPRESENTED BY PATTERNS OF BI-STABLE MAGNETIC OR ELECTRONIC INDICATORS. - CONSTANT----- VALUE WHICH IS NOT SUBJECT TO CHANGE DURING AN OPERATION. - CONTROL-----THAT PART OF A COMPUTER WHICH DIRECTS THE SEQUENCING AND ELEMENT TIMING OF ITS ACTIONS. - DATA-----THAT INFORMATION USED AS OPERANDS IN THE ARITHMETIC AND LO-GICAL OPERATIONS OF THE COMPUTER. - DATA REDUCTION-THE PROCESSING OF LARGE VOLUMES OF RAW DATA SO AS TO CON-DENSE AND SIMPLIFY IT TO A MORE MEANINGFUL PRESENTATION. - DEBUGGING----THE PROCESS OF ELIMINATING ERRORS FROM A PROGRAM BY INSPECTION OR MACHINE TESTING. - EXTRACT-----TO CLEAR SELECTED PORTIONS OF A WORD TO ZERO, LEAVING THE REMAINING PORTIONS INTACT. - FIELD------A DEFINED SPACE WITHIN A COMPUTER WORD OR INFORMATION FORMAT WHICH IS ASSIGNED TO HOLD A SPECIFIED TYPE OR CLASS OF INFORMATION. - FIXED POINT----THAT SYSTEM OF PROGRAMMING ARITHMETIC IN WHICH THE LOCATION OF THE DECIMAL OR BINARY POINT IN A COMPUTER WORD MUST BE CONTROLLED AND MANIPULATED BY THE PROGRAMMER. - FLOATING POINT-THAT SYSTEM OF PROGRAMMING ARITHMETIC IN WHICH THE LOCATION OF THE DECIMAL OR BINARY POINT IN A COMPUTER WORD IS AUTO-MATICALLY MANIPULATED AND CONTROLLED BY THE COMPUTER OR A PROGRAM ROUTINE. - HEAD-----THE ASSEMBLY FOR RECORDING OR READING ONE TRACK OF INFORMATION ON A MAGNETIZED SURFACE. - HEXADECIMAL --- The Positional number system using a Base of 16. A number system which employs 16 discrete numeric characters. - INDEX REGISTER-A REGISTER TO CONTAIN A QUANTITY WHICH MAY BE USED TO AUTO-MATICALLY INCREMENT THE ADDRESS PORTION OF AN INSTRUCTION. - INPUT-----INFORMATION ENTERED INTO A COMPUTER'S MEMORY FROM AN EXTER-NAL SOURCE. - INSTRUCTION---- A SET OR STRING OF CHARACTERS WHICH COMPLETELY SPECIFIES ONE ACTION TO BE TAKEN BY THE COMPUTER. - LOAD-----TO ENTER INFORMATION INTO THE COMPUTER FROM AN EXTERNAL SOURCE. ALSO, TO PLACE A VALUE INTO A REGISTER, SUCH AS THE INDEX REGISTER. - LOOP-----A PROGRAMMING TECHNIQUE IN WHICH A SEQUENCE OF INSTRUCTIONS IS REPEATED A SPECIFIED NUMBER OF TIMES BEFORE PROCEEDING WITH THE REMAINDER OF THE PROGRAM. - MAGNETIC DRUM--A ROTATING CYLINDRICAL DRUM USED FOR INFORMATION STORAGE. RECORDING IS IN THE FORM OF MAGNETIZED SPOTS ON THE SURFACE OF THE DRUM. - MEMORY-----THE WORKING STORAGE AREA OF A COMPUTER. GENERALLY, THE STORAGE DEVICE PERMITTING THE MOST RAPID ACCESS TO ITS DATA. IT IS FROM THIS STORAGE THAT INSTRUCTIONS ARE OBTAINED FOR EXECUTION. - MICROSECOND ---- ONE MILLIONTH OF A SECOND. - MILLISECOND----ONE THOUSANDTH OF A SECOND. - MNEMONIC-----A CODE FORM OF IDENTIFICATION DEVISED SO AS TO ASSIST IN THE REMEMBRANCE OF ITS MEANING. - OPERAND-----An ITEM of Information which is to be operated upon, or one which enters into an operation. - OPTIMIZE-----To code a Routine in such a way as to minimize the total Memory Access Time. - OUTPUT----INFORMATION TRANSFERRED FROM THE COMPUTER'S MEMORY TO AN EXTERNAL DEVICE. - OVERFLOW-----THE GENERATION, IN A COMPUTER REGISTER, OF A QUANTITY BEYOND THE CAPACITY OF THE REGISTER. - PARAMETER----AN ITEM WHICH MAY BE ASSIGNED ARBITRARY VALUES, DEPENDING UPON ITS USE IN A GIVEN ROUTINE. - PARITY BIT----AN EXTRA BINARY DIGIT ADDED TO AN ITEM OF INFORMATION FOR VALIDITY CHECKING PURPOSES. - PARITY CHECK---A METHOD OF VERIFYING THE ACCURACY OF A DATA TRANSFER BY COUNTING THE NUMBER OF "I" BITS IN THE TRANSFERRED ITEM, INCLUDING THE PARITY BIT. AN'ACCURATE TRANSFER IS INDICATED BY AN EVEN COUNT IN AN "EVEN PARITY" SYSTEM, OR BY AN ODD COUNT IN AN "SODD PARITY" SYSTEM. - PROGRAM-----A COMPLETE SEQUENCED SET OF COMPUTER INSTRUCTIONS DESIGNED TO CARRY OUT A DESIRED PROCESSING FUNCTION, OR SOLVE A DEFINED PROBLEM. - REGISTER----THE HARDWARE FOR STORING ONE COMPLETE COMPUTER WORD. - ROUTINE-----A SEQUENCED SET OF COMPUTER INSTRUCTIONS, PART OF A PROGRAM, FOR PERFORMING SOME WELL DEFINED FUNCTION. - SECTOR-----THE SPACE ON A STORAGE DRUM, MEASURED ALONG THE CIRCUMFER-ENCE, REQUIRED TO HOLD ONE COMPUTER WORD. - SUBROUTINE----A PROGRAM SUB-UNIT, USUALLY USED IN COMMON BY MORE THAN ONE (CLOSED) PROGRAM, WHICH IS ENTERED VIA A TRANSFER FROM THE MAIN PROGRAM. THE MAIN PROGRAM. - SUBROUTINE----A PROGRAM SUB-UNIT, NOT ENTERED VIA A TRANSFER, WHICH IS (OPEN) INCLUDED IN THE NORMAL SEQUENCE OF A PROGRAM. - TRACK-----THE PATH AROUND A STORAGE DRUM, TRACED OUT BY EACH HEAD OF THE DRUM ASSEMBLY. ALSO, THE INFORMATION STORED ON A GIVEN TRACK. - TRANSFER-----To move information from one storage area to another. To depart from the linear sequence of the Program Instructions by shifting control to another area of the Program. This shift is often conditional upon the results of a Program test of an indicator Word. (Conditional Transfer) - UTILITY-----A PROGRAM DESIGNED TO ASSIST IN THE FULL UTILIZATION OF THE PROGRAM Computer. Included in this class are Assembly Programs, Compilers, Input/Output Programs, etc. - WORD-----A SET OR STRING OF SYMBOLS WHICH OCCUPIES ONE COMPLETE STORAGE REGISTER IN THE COMPUTER. THIS WORD MAY BE TREATED AS AN INSTRUCTION OR AS A DATA WORD, DEPENDING UPON THE MANNER OF ITS OCCURRENCE IN A PROGRAM. ### 2 ### ARITHMETIC FOR PROGRAMMERS. THE CONCEPT OF NUMBER IS SO BASIC TO OUR EVERYDAY LIFE THAT THE AVERAGE PERSON RARELY HAS OCCASION TO REFLECT ON THE MANY MEANINGS OF NUMBER, OR ON THE MANY FORMS IN WHICH NUMBERS ARE EXPRESSED. HOWEVER, THE ADVENT OF THE ELECTRONIC COMPUTER HAS NECESSITATED A RECONSIDERATION OF NUMBER SYSTEMS, AND THEIR APPLICABILITY TO THE CONVEYANCE AND MANIPULATION OF INFORMATION THROUGH ELECTRONIC CIRCUITRY. Numbers are used, primarily, to denote quantity or amount. We use numbers to state how many pills are in a bottle, or how many pounds of coffee are in a bag, or how many miles between here and Tin Cup, Colorado. But there are other ways of using numbers. A number can also be used to represent one member of an ordered set of symbols. A house number, for example, serves to identify a particular house among a number of houses in its set. It further serves to locate that house with respect to these other houses. When a number is used for this dual purpose of location and identification, it is generally referred to as an address. Finally, a number which serves only to identify, but which has no quantitative or locational significance, is usually called a code number. ALL THREE OF THESE ASPECTS OF NUMBER---QUANTITY, ADDRESS AND IDENTITY---ARE VITAL TO THE DESIGN AND OPERATION OF A HIGH SPEED DIGITAL COMPUTER. HOW-EVER, THE PRESENT DISCUSSION WILL CONCERN ITSELF, PRIMARILY, WITH THE QUANTITATIVE ASPECT OF NUMBER. ### NUMBER SYSTEMS A Number System may be classified by the number of counting symbols it employs. This number is referred to as the base of the system. The Decimal System is a base-ten number System; that is, it uses the ten numeric characters, 0 thru 9. It is further characterized by its use of a positional notation. When counting, if one digit position progresses beyond 9, it adds a count in the position immediately to its left. Thus, 9 plus I becomes 10; 19 plus I becomes 20; 99 plus I becomes 100, etc. Each position in a decimal number represents an integral power of 10, so that in the number 456, the 4 represents 4 times 102; the 5 represents 5 times 101; and the 6 represents 6 times 100. Similarly, the decimal fraction .789 represents 7 times 10-1 plus 8 times 10-2 plus 9 times 10-3. OBVIOUSLY, WE ARE NOT RESTRICTED TO A BASE TEN SYSTEM OF NUMBERS. THE SAME NOTATIONAL STRUCTURE APPLIES EQUALLY WELL TO OTHER BASES. AND, IN FACT, IT HAS BEEN DETERMINED THAT TODAY'S ELECTRONIC DIGITAL COMPUTER FUNCTIONS MOST EFFICIENTLY USING A BINARY SYSTEM FOR ITS INTERNAL FUNCTIONS. THIS BASE-TWO SYSTEM FOLLOWS NATURALLY FROM THE FACT THAT THE COMPUTER CIRCUITRY IS MADE UP, IN LARGE PART, OF BI-STABLE DEVICES. ### THE BINARY SYSTEM THE BINARY SYSTEM IS, OF COURSE, A SYSTEM WHICH UTILIZES ONLY TWO NUMERIC CHARACTERS, O AND I. THE PRINCIPLES OF COUNTING AND ARITHMETIC ARE EXACTLY THE SAME AS FOR DECIMAL NUMBERS. COUNTING PROCEEDS IN THE ORDER, I, IO, II, IOO, IOI, IIO, III, IOOO, IOOI, ETC. WHEREAS, IN THE DECIMAL SYSTEM EVERY TENTH COUNT IN A DIGIT POSITION CAUSES A CHANGE IN THE NEXT POSITION TO ITS LEFT; IN THE BINARY SYSTEM EVERY SECOND COUNT STEPS THE NEXT HIGHER DIGIT POSITION. EACH SUCCESSIVE POSITION TO THE LEFT REPRESENTS THE NEXT HIGHER POWER OF TWO. THUS, THE BINARY NUMBER, IOIIO, IS EQUAL TO I TIMES 24 PLUS O TIMES 25 PLUS I TIMES 27 PLUS O TIMES 20. THIS IS EQUIVALENT TO THE DECIMAL NUMBER 22. Similarly, in a fractional Binary number, the positions to the right of the Binary point represent successive negative powers of two. Thus, the Binary fraction, .10110, represents 1 times $2^{-1}$ plus 0 times $2^{-2}$ plus 1 times $2^{-4}$ plus 0 times $2^{-5}$ . This is equivalent to the decimal, 1/2 plus 1/8 plus 1/16, or 1/16. IF WE WERE TO PERFORM ALL OUR MANUAL COMPUTATIONS IN BINARY ARITHMETIC, WE WOULD FIND THAT, ALTHOUGH THE INDIVIDUAL OPERATIONS ARE CHILDISHLY SIMPLE, WE WOULD SOON BE DROWNING IN A SEA OF 0°S AND 1°S. THE DECIMAL NUMBER, 999,999, IF REPRESENTED IN BINARY, REQUIRES 20 DIGITS. THE COMPUTER, ON THE OTHER HAND, FINDS IT MUCH EASTER TO HANDLE A LARGE NUMBER OF DIGIT POSITIONS THAN TO DEAL WITH MORE THAN TWO DIGIT VALUES. IN ORDER TO FACILITATE COMMUNICATION BETWEEN THE PROGRAMMER AND THE COMPUTER, IT IS DESIRABLE TO USE A NUMBER SYSTEM WHICH PROVIDES FOR BRIEF NUMERICAL NOTATION; AND ONE WHICH PERMITS EASY CONVERSION TO AND FROM THE BINARY SYSTEM. ### THE HEXADECIMAL SYSTEM IF WE LOOK CAREFULLY AT THE BINARY SYSTEM, WE NOTE THAT FOUR DIGIT POSITIONS ARE SUFFICIENT TO HOLD 16 NUMERICAL VALUES FROM 0 TO 15. THE RPC-4000 HAS A WORD LENGTH OF 32 BITS (BINARY DIGITS), SO THAT ONE WORD CAN BE DIVIDED EVENLY INTO EIGHT 4-BIT GROUPS. IF WE SELECT, FOR COMMUNICATION WITH THE COMPUTER, A NUMBER SYSTEM TO A BASE OF 16, WE CAN REPRESENT A FULL COMPUTER WORD WITH JUST EIGHT CHARACTERS, AND EACH CHARACTER WILL CORRESPOND EXACTLY WITH A UNIQUE PATTERN OF BINARY DIGITS. THIS BASE-SIXTEEN SYSTEM IS KNOWN AS A HEXADECIMAL SYSTEM. IT IS THE SYSTEM USED FOR ALL DIRECT COMMUNICATION WITH THE COMPUTER. THE TABLE OF HEXADECIMAL CHARACTERS AND THEIR DECIMAL AND BINARY EQUIVALENTS IS AS FOLLOWS: | HEXADECIMAL | <u>Dı</u> | ECIMAL | BINARY | |-------------|-----------|--------|--------| | 0 | ÷ . | 0 | 0000 | | | | 1 | 0001 | | 2 | | 2 | 0010 | | 3 | | 3 | 0011 | | 4 | | l4 | 0100 | | 5 | | 5 | 0101 | | 6 | | 6 | 0110 | | 7 | | 7 | 0111 | | 8 | | 8 | 1000 | | 9 | | 9 | 1001 | | Ä | | 10 | 1010 | | В | | 11 | 1011 | | Č | | 12 | 1100 | | n | | 13 | 1101 | | F | | 14 | 1110 | | F | | 15 | 1111 | ### BINARY CODED DECIMAL FREQUENTLY ENCOUNTERED IN DISCUSSIONS OF PROGRAMMING AND COMPUTERS IS ANOTHER, AND SOMEWHAT DIFFERENT, SYSTEM OF NUMBERS KNOWN AS BINARY CODED DECIMAL. THIS IS ACTUALLY A SYSTEM BUILT ON TWO BASES, 2 AND IO. BASE 2 IS USED IN THE BINARY REPRESENTATION OF EACH OF THE TEN NUMBERIC CHARACTERS, O THRU 9. NORMALLY, THE BINARY NUMBERS, 0000 THRU 1001 ARE USED, AND EACH 4-BIT GROUP SIGNIFIES ONE DECIMAL CHARACTER. THE POSITIONAL NOTATION USED IS THE SAME AS FOR DECIMAL NUMBERS IN THAT EACH SUCCESSIVE 4-BIT BINARY GROUP PROCEEDING TO THE LEFT OF THE UNITS POSITION REPRESENTS THE NEXT HIGHER POWER OF TEN. THUS THE DECIMAL NUMBER, 369, APPEARS IN BINARY CODED DECIMAL AS 0011 0110 1001. THE SAME NUMBER IN BINARY IS WRITTEN 101110001. THE USEFULNESS OF THIS NUMBER SYSTEM IS IN PROVIDING A CONVENIENT FORM IN WHICH TO PROCESS NUMERICAL DATA THROUGH THE INPUT/OUTPUT EQUIPMENT. ITS USE, HOWEVER, REQUIRES INPUT AND OUTPUT PROGRAM ROUTINES WHICH WILL MAKE THE CONVERSION TO AND FROM A TRUE BINARY REPRESENTATION. ### CONVERSION BETWEEN SYSTEMS IN WORKING WITH PROGRAMS AND COMPUTERS, IT FREQUENTLY BECOMES NECESSARY TO PERFORM A MANUAL CONVERSION FROM ONE NUMBER SYSTEM TO ANOTHER. THIS IS PARTICULARLY TRUE IN DEBUGGING, WHERE A WORD DISPLAYED ON THE SCOPE FACE MUST OFTEN BE VERIFIED AGAINST A SYMBOLICALLY WRITTEN PROGRAM WORD. CONVERSION OF A DECIMAL INTEGER INTO ITS BINARY OF HEXADECIMAL EQUIVALENT MAY BE ACCOMPLISHED BY A SYSTEM OF SUCCESSIVE DIVISIONS OF THE DECIMAL INTEGER BY THE BASE OF THE SYSTEM INTO WHICH WE ARE CONVERTING. FOR EXAMPLE, CONSIDER THE DECIMAL NUMBER, 229, IF WE DIVIDE BY THE HEXADECIMAL BASE, 16, WE GET 14, WITH A REMAINDER OF 5. THE 5 REPRESENTS THE LEAST SIGNIFICANT DIGIT OF THE HEXADECIMAL NUMBER WE ARE COMPUTING. IF WE NOW DIVIDE THE INTEGRAL QUOTIENT, 14, BY 16, WE GET 0, WITH A REMAINDER OF 14, THE 14, EXPRESSED HEXADECIMALLY BY THE CHARACTER, E, REPRESENTS THE MOST SIGNIFICANT DIGIT OF THE DESIRED NUMBER, SO THAT THE HEXADECIMAL EQUIVALENT OF 229 IS E5. TO AVOID CONFUSION WHEN WORKING WITH NUMBER CONVERSIONS, THE BASE OF A NUMBER IS USUALLY REPRESENTED BY A SUBSCRIPT, SO THAT THE ABOVE NUMBERS WOULD BE MORE CLEARLY EXPRESSED AS 22910 AND E516. LET'S CONSIDER ANOTHER EXAMPLE, THIS TIME SHOWING THE CONVERSION IN TABULAR FORM. THE DECIMAL INTEGER 1386 WOULD BE CONVERTED AS FOLLOWS: | DECIMAL<br>NUMBER | + | 16 = | QUOTIENT | WITH | REMA INDER | |-------------------|---|------|----------|------|-------------------------| | 138610 | | | 8610 | | (LEAST SIGNIGICANT) Al6 | | 8610 | | | 510 | | 616 | | 510 | | | 0 | | (MOST SIGNIFICANT) 516 | The Hexadecimal equivalent of 138610 is $56A_{16}$ . Note that the "A" in the above example is used as a Hexadecimal numeral, and is the equivalent of a Decimal 10. Decimal integers may be converted to Binary in exactly the same fashion. Conversion of $52_{10}$ to Binary proceeds as follows: | | DECIMAL<br>NUMBER | + 2 = | QUOTIENT | WITH | REMA I NDER | |-----|-------------------|-------|----------|------|---------------------| | | 52 <sub>10</sub> | | 2610 | | (LEAST SIGNIFICANT) | | | 2610 | | 1310 | | 02 | | | 1310 | | 610 | | l <sub>2</sub> | | | 610 | | 310 | | 0 <b>2</b> | | , N | 310 | | 110 | | 12 | | | 110 | | 010 | | (MOST SIGNIFICANT) | THE BINARY EQUIVALENT OF 5210 IS SHOWN TO BE 1101002. WITH A LITTLE PRACTICE, A BINARY NUMBER CAN BE READILY CONVERTED TO DECIMAL BY INSPECTION OR BY REFERRING TO A TABLE OF POWERS OF TWO. CONVERTING THE ABOVE BINARY value to Decimal is just a matter of adding $2^5$ (32), $2^4$ (16), and $2^2$ (4) to arrive at the value, $52_{10}$ . Fractional values may be similarly handled by using negative powers of two. Conversion of a Decimal fraction into Hexadecimal or Binary may be accomplished by a system of successive multiplications by the base into which we are converting. For example, consider the following conversion of .91210 into Hexadecimal: | DECIMAL<br>NUMBER X | 16 = PRODUCT | INTEGRAL<br>WITH CARRY | = | HEXADEC I MAL | |---------------------|--------------|------------------------|---|---------------| | .91210 | 14.59210 | 1410 | | E16 | | .59210 | 9.47210 | 910 | | 916 | | .47210 | 7.55210 | 710 | | 716 | | ETC. | | | | | In this process, the first integral carry represents the most significant digit of the Hexadecimal fraction, and the fraction, .912 $_{10}$ , converts to .E97 $_{16}$ , computed to 3 places. ### SCALING THE NUMBERS, .75210, 7.5210, 75.210, AND 75210 ARE IDENTICAL IN APPEARANCE EXCEPT FOR THE PLACEMENT OF AN INSIGNIFICANT LOOKING SYMBOL KNOWN AS A DECIMAL POINT. YET THE USE OF THIS SYMBOL CAN MAKE A HUGE DIFFERENCE IN THE MEANING OF THE NUMBER IN WHICH IT IS PLACED. WHEN WE WORK WITH NUMBERS IN THIS FASHION, WE ARBITRARILY PLACE THIS POINT IN SUCH A WAY AS TO ESTABLISH A DESIRED MAGNITUDE FOR THE NUMBER WE WISH TO REPRESENT. THE DIGITS TO THE LEFT OF THIS POINT REPRESENT INTEGRAL VALUES, AND THE DIGITS TO THE RIGHT REPRESENT FRACTIONAL VALUES. IN ORDER TO PERFORM VALID ARITHMETIC OPERATIONS WITH THESE NUMBERS, WE MUST NECESSARILY BE COGNIZANT OF THE LOCATION OF THE POINT IN ALL OUR OPERANDS. THE RPC-4000 COMPUTER WORD IS 32 BINARY DIGITS IN LENGTH. FOR A DATA WORD, THESE BITS PROVIDE FOR A SIGN BIT IN POSITION O, AND 31 MAGNITUDE BITS. THE PRINCIPLES OF SCALING, OUTLINED ABOVE WITH RESPECT TO DECIMAL ARITHMETIC, APPLY ALSO TO THE BINARY VALUES USED BY THE COMPUTER. THE BINARY POINT DOES NOT ACTUALLY EXIST WITHIN THE COMPUTER. IT EXISTS ONLY IN THE MIND OR ON THE PAPER OF THE PROGRAMMER. IT IS HIS RESPONSIBILITY TO CONTROL THE PLACEMENT OF VALUES IN THE COMPUTER WORD SO THAT THESE IMPLIED BINARY POINTS WILL FALL IN THE PROPER POSITIONS TO PRODUCE VALID ARITHMETIC RESULTS. THE BINARY POINT LOCATION BETWEEN BITS O AND | OF THE COMPUTER WORD, REFERRED TO AS THE MACHINE POINT, SERVES AS A REFERENCE POINT IN SPECIFYING THE SCALE FACTOR FOR A VALUE IN THE WORD. THE SYMBOL, "Q", HAS BEEN ESTABLISHED BY CONVENTION TO DENOTE THE PLACEMENT OF THE IMPLIED BINARY POINT WITH RESPECT TO THE MACHINE POINT. IF A VALUE IS ENTERED INTO THE COMPUTER AT A "Q" OF 5, THE BITS IN POSITIONS | THRU 5 REPRESENT THE INTEGRAL PORTION OF THE VALUE, AND THE BITS IN POSITIONS 6 THRU 31 REPRESENT THE FRACTIONAL PORTION. TO PERFORM A VALID ADDITION OR SUBTRACTION IN THE COMPUTER, THE BINARY POINTS MUST BE LINED UP THE SAME AS WE WOULD LINE UP THE POINTS IN PERFORMING THESE OPERATIONS WITH PENCIL AND PAPER. THAT IS, THE OPERANDS MUST BE STORED IN THE COMPUTER AT THE SAME "Q". A NUMBER AT A "Q" OF 12, ADDED TO ANOTHER NUMBER AT A "Q" OF 12, WILL PRODUCE A SUM WHICH IS ALSO AT A "Q" OF 12. IN MULTIPLICATION HOWEVER, THE POINTS NEED NOT BE LINED UP, BUT MAY BE AT ANY LOCATION WHICH WILL PRODUCE A PRODUCT AT THE REQUIRED "Q". THE "Q" OF THE PRODUCT OF A MULTIPLICATION IS THE SUM OF THE "Q" S" OF THE MULTIPLICAND AND THE MULTIPLIER. A NUMBER AT A "Q" OF 6, MULTIPLIED BY A NUMBER AT A "Q" OF 3, WILL PRODUCE A PRODUCT AT A "Q" OF 9. THE RULES FOR PERFORMING A DIVISION IN THE COMPUTER ARE EQUALLY SIMPLE, BUT REQUIRE ONE ADDITIONAL PRECAUTION ON THE PART OF THE PROGRAMMER. THE "Q" OF THE QUOTIENT IS DETERMINED BY SUBTRACTING THE "Q" OF THE DIVISOR FROM THE "Q" OF THE DIVIDEND. THE VALUE, 6, AT A "Q" OF 3, DIVIDED BY THE VALUE, 2, AT A "Q" OF 2, SHOULD PRODUCE A QUOTIENT, 3, AT A "Q" OF 1. BUT THE VALUE, 3, CAN NOT BE HELD AT A "Q" OF 1, SO THAT A CONDITION KNOWN AS A "DIVIDE CHECK!" OCCURS. THIS, OF COURSE, PRODUCES AN OVERFLOW OUT OF THE ACCUMULATOR WHICH WILL TURN ON AN INDICATOR, KNOWN AS THE BRANCH CONTROL. TO AVOID THIS SITUATION, THE PROGRAMMER MUST SCALE HIS OPERANDS SO THAT THE QUOTIENT WILL FIT IN THE ACCUMULATOR. IN THE ABOVE EXAMPLE, SHIFTING THE DIVIDEND, 6, TO A "Q" OF 4, AND THEN DIVIDING BY 2 AT A "Q" OF 2, WILL PRODUCE A QUOTIENT OF 3, AT A "Q" OF 2, WHICH CAN BE CONTAINED WITHOUT OVERFLOW. CONSIDERED FROM THE STANDPOINT OF THE COMPUTER WORD, ITSELF, AND DISREGARDING THE IMPLIED BINARY POINT LOCATION, THE DIVISOR MUST ALWAYS EXCEED THE DIVIDEND TO PERFORM A VALID DIVIDE OPERATION. THE MEANS FOR CONTROLLING THE SCALING OF VALUES IN THE COMPUTER ARE PROVIDED BY A SHIFT INSTRUCTION, WHICH PERMITS THE PROGRAMMER TO ADJUST THE "Q" OF ANY VALUE BY SHIFTING THE ACCUMULATOR CONTENTS RIGHT OR LEFT BY A PRESCRIBED NUMBER OF BIT POSITIONS. (SEE PAGE 38) IT IS IMPORTANT, IN CODING A PROGRAM, TO NOTE ON THE CODING SHEET THE "Q" VALUES IN ALL ARITHMETIC OPERATIONS. ## THE CENTRAL COMPUTER THE BASIC UNIT OF INFORMATION IN THE COMPUTER IS REFERRED TO AS A WORD. THE COMPUTER WORD IN THE RPC-4000 CONSISTS OF 32 BINARY DIGITS, COMMONLY CALLED "BITS". THIS 32 BIT PATTERN OF INFORMATION HAS A MEANING DEPENDENT UPON THE CONTEXT IN WHICH IT IS USED. THAT IS TO SAY, THAT THE SAME WORD FROM MEMORY MAY BE USED AS AN INSTRUCTION OR AS AN ARITHMETIC OPERAND, AND THIS USAGE IS DETERMINED BY THE MANNER IN WHICH THE PROGRAM IS WRITTEN. WHEN USED AS NUMERICAL DATA, A WORD IS CONSIDERED AS CONSISTING OF A SIGN BIT IN THE LEFT-MOST POSITION, FOLLOWED BY 31 MAGNITUDE BITS. FIGURE 2. RPC-4000 DATA WORD FORMAT WHEN USED AS AN INSTRUCTION, A WORD IS CONSIDERED AS CONSISTING OF A COM-MAND IN BITS O THRU 4, AN OPERAND OR AN OPERAND ADDRESS IN BITS 5 THRU 17, THE NEXT INSTRUCTION ADDRESS IN BITS 18 THRU 30, AND THE INDEX TAG IN BIT 31. | 0 | 5 TRACK | 11 12 SECTOR | 17 18 | TRACK | 24 25 SECTO | 30 31 | |---------|---------|--------------|-------|-------|-------------|-----------| | COMMAND | OP E | RAND ADDRESS | | NEXT | ADDRESS | X | | | | | | | | * A . 6 1 | | | | | | | | | FIGURE 3. RPC-4000 INSTRUCTION WORD FORMAT IN CERTAIN CASES IT IS CONVENIENT TO CONSIDER THE 32 BITS OF A WORD AS EIGHT HEXADECIMAL CHARACTERS. THIS IS PARTICULARLY TRUE IN ENTERING INFORMATION MANUALLY INTO THE COMPUTER OR IN ANALYZING CERTAIN COMPUTER OUTPUTS. FIGURE 4. RPC-4000 HEXADECIMAL WORD FORMAT ### THE MEMORY DRUM INFORMATION IS STORED IN THE RPC-4000 ON A MAGNETIC DRUM WHICH ROTATES AT THE RATE OF 3600 REVOLUTIONS PER MINUTE. THIS INFORMATION WILL CONSIST OF BOTH DATA WORDS AND INSTRUCTION WORDS. EACH INDIVIDUAL BIT OF EACH WORD STORED IN THE COMPUTER IS IN THE FORM OF A DISCRETE MAGNETIZED SPOT ON THE IRON OXIDE COATED DRUM SURFACE. EACH BIT CAN EXIST IN ONE OF TWO MAGNETIC STATES REPRESENTING THE BINARY VALUES, O (ZERO) AND I (ONE). ALL INFORMATION IN THE COMPUTER, INCLUDING ALL MEMORY REGISTERS AND ALL WORKING REGISTERS, IS REPRESENTED IN THIS MANNER. THE COMPUTER WORDS ARE ARRANGED IN PARALLEL BANDS AROUND THE DRUM, EACH BAND CONTAINING 64 WORD POSITIONS. ASSOCIATED WITH EACH OF THESE BANDS IS A MAGNETIC READ/WRITE HEAD (THOSE BANDS USED FOR DOUBLE ACCESS EACH HAVE TWO READ/WRITE HEADS). THE BAND OF INFORMATION TRACED OUT BY ANY GIVEN HEAD IS REFERRED TO AS A TRACK. EACH OF THE 64 WORD POSITIONS AROUND THE CIRCUMFERENCE OF THE DRUM IS REFERRED TO AS A SECTOR. THE RPC-4000 MEMORY CONSISTS OF 128 TRACKS (NUMBERED 000 THRU 127) AND 64 SECTORS (NUMBERED 00 THRU 63). HENCE, THE ECCATION OF ANY WORD IN MEMORY CAN BE SPECIFIED BY ITS TRACK AND SECTOR NUMBER. THIS NUMBER IS KNOWN AS THE ADDRESS OF THE WORD IN QUESTION. TRACKS 000 THRU 122 OF THE MAGNETIC DRUM ARE THE MAIN MEMORY STORAGE AREA FOR THE RPC-4000. EACH TRACK HAS 64 ASSOCIATED SECTORS, EACH OF WHICH CONTAINS ONE COMPUTER WORD. THE TOTAL STORAGE CAPACITY OF MAIN MEMORY IS 7872 WORDS. Any word in Main Memory may be referenced by specifying its track and sector position. Thus, 09843 refers to the word whose address is Track 098, Sector 43. MAXIMUM ACCESS TIME FOR A WORD IN MAIN MEMORY IS THE TIME REQUIRED FOR ONE COMPLETE DRUM REVOLUTION, OR APPROXIMATELY 17 MILLISECONDS. AVERAGE ACCESS TIME IS APPROXIMATELY 8.5 MILLISECONDS. FIGURE 5. RPC-4000 MAIN MEMORY STORAGE ### DUAL ACCESS TRACKS IN ADDITION TO THE MAIN MEMORY JUST DISCUSSED, THERE ARE TWO BANDS OF MEMORY STORAGE ON THE DRUM FOR WHICH DUAL ACCESS IS PROVIDED. EACH OF THESE BANDS HAS TWO READ/WRITE HEADS, ADDRESSED BY THEIR OWN INDIVIDUAL TRACK NUMBERS. THE HEADS ADDRESSED AS TRACK 123 AND TRACK 125 SHARE THE SAME STORAGE BAND. THE TRACK 125 HEAD IS DISPLACED SO AS TO BE 16 WORD TIMES LATER THAN THE TRACK 123 HEAD. THEREFORE, BOTH HEADS REFER TO THE SAME SET OF WORDS, AND THE WORD WHICH IS ADDRESSED BY 12301 IS THE SAME WORD AS THAT ADDRESSED BY 12517. LIKEWISE, THE HEADS ADDRESSED AS TRACK 124 AND TRACK 126 SHARE THE SAME SET OF WORD POSITIONS. IN THIS CASE, THE TRACK 126 HEAD IS DISPLACED SO AS TO BE 24 WORD TIMES LATER THAN THE TRACK 124 HEAD. THE WORD ADDRESSED BY 12401 IS THE SAME WORD AS THAT ADDRESSED BY 12625. RANDOM ACCESS TIME FOR A WORD FROM THE DUAL ACCESS STORAGE AREA IS THE SAME AS FOR A WORD FROM MAIN MEMORY. TOTAL DUAL ACCESS STORAGE CAPACITY IS \$\|28\|\text{words}\|. FIGURE 6. DUAL ACCESS STORAGE TRACKS ### THE RECIRCULATING LINE THERE ARE 8 ADDITIONAL WORDS OF MEMORY STORAGE ON THE DRUM IN WHAT IS KNOWN AS THE RECIRCULATING LINE. THE ASSOCIATED READ/WRITE HEAD IS REFERRED TO AS TRACK 127, AND THIS TRACK PROVIDES A SPECIAL FAST ACCESS STORAGE AREA. THE FAST ACCESS CAPABILITY DERIVES FROM THE FACT THAT THESE 8 WORDS ARE REPEATED 8 TIMES AROUND THE DRUM. THIS IS ACCOMPLISHED IN THE FOLLOWING MANNER. IN ADDITION TO, AND FLANKING THE NORMAL READ/WRITE HEAD ARE A SEPARATE READ HEAD AND WRITE HEAD. THE READ HEAD IS PLACED SO AS TO TRAIL THE WRITE HEAD BY 8 WORDS. THAT IS TO SAY, THAT A WORD POSITION ON THE DRUM WILL REACH THE WRITE HEAD 8 WORDS BEFORE REACHING THE READ HEAD. CONSEQUENTLY, AS EACH WORD IS READ BY THE READ HEAD, IT IS IMMEDIATELY WRITTEN BACK ON THE DRUM 8 WORD POSITIONS FARTHER ALONG ON THE DRUM. LIKEWISE, ANY NEW WORD VALUE WRITTEN ON THE DRUM BY THE NORMAL READ/WRITE HEAD WILL BE PICKED UP WHEN IT REACHES THE READ HEAD AND RECIRCULATED. SINCE EVERY EIGHTH WORD AROUND THE DRUM ON TRACK 127 IS IDENTICAL, SECTOR ADDRESSES WILL BE MODULO 8. THE ADDRESSES 12701, 12709 AND 12717 WILL ALL REFER TO THE SAME WORD INASMUCHAS THE SECTOR ADDRESSES DIFFER BY MULTIPLES OF 8. WITH 8 ACCESSES PROVIDED FOR EACH WORD EVERY DRUM REVOLUTION, MAXIMUM ACCESS TIME FOR THE RECIRCULATING LINE IS APPROXIMATELY 2 MILLISECONDS, WITH AN AVERAGE ACCESS TIME OF ABOUT I MILLISECOND. FIGURE 7. THE RECIRCULATING LINE ### THE SECTOR REFERENCE TIMING TRACK Although this track cannot be read directly or modified by the programmer, some explanation of its function may be helpful. The Sector Reference Timing Track contains the Sector Reference numbers 00 thru 63, which are permanently pre-recorded at the time of manufacture. The track has a read head only, which serves to locate, by reference to this Timing Track, any Sector Address on the drum which is called for in a program. DURING A COMPARE INSTRUCTION (CME or CMG) THE CONTENTS OF THIS TRACK ARE CONTINUALLY COPIED INTO BITS 25 THRU 30 OF THE INDEX REGISTER UNTIL A SUCCESSFUL COMPARISON IS FOUND, OR UNTIL COMPLETION OF THE INSTRUCTION, AT WHICH POINTS ANY FURTHER COPYING IS INHIBITED. CONSEQUENTLY, FOLLOWING A SUCCESSFUL COMPARISON, THE SECTOR ADDRESS OF THE MEMORY WORD WHICH COMPARES CAN BE DETERMINED BY SUBTRACTING I FROM THE TIMING TRACK VALUE IN THE INDEX REGISTER. ### THE WORKING REGISTERS A REGISTER MAY BE DESCRIBED AS THE HARDWARE FOR STORING A SINGLE COMPUTER WORD. THOSE REGISTERS WHICH ARE USED TO PERFORM THE VARIOUS ARITHMETIC AND CONTROL FUNCTIONS WITHIN THE COMPUTER ARE THE WORKING REGISTERS. THERE ARE FOUR SUCH REGISTERS IN THE RPC-4000, EACH IN THE FORM OF A RECIRCULATING LINE ON THE DRUM WITH A ONE WORD SPACING. THESE FOUR WORKING REGISTERS TOGETHER COMPRISE WHAT IS REFERRED TO AS THE COMPUTING CONTROL UNIT. AS SUCH, THEY EXECUTE ALL INTERNAL DATA PROCESSING, AND CONTROL INPUTS AND OUTPUTS TO AND FROM THE COMPUTER. THE REGISTERS ARE KNOWN INDIVIDUALLY AS: U-----UPPER ACCUMULATOR L----LOWER ACCUMULATOR C----COMMAND REGISTER X----INDEX REGISTER ### THE UPPER ACCUMULATOR GENERALLY SPEAKING, THE UPPER ACCUMULATOR IS THAT REGISTER IN THE COMPUTING CONTROL UNIT WHICH HOLDS THE COMPUTER WORD TO BE OPERATED UPON. AT THE COMPLETION OF AN ARITHMETIC OR LOGICAL OPERATION, IT WILL NORMALLY HOLD THE RESULT OF THE OPERATION. THE UPPER ACCUMULATOR IS THE PRIMARY WORKING REGISTER. IT CAN RECEIVE IN-FORMATION FROM, OR SEND INFORMATION TO ANY REGISTER IN MEMORY, AND ANY WORKING REGISTER EXCEPT THE COMMAND REGISTER. NORMALLY THESE ARE FULL WORD TRANSFERS. HOWEVER, INFORMATION MAY BE SHIFTED FROM THE UPPER TO THE LOWER ACCUMULATOR, OR FROM THE LOWER TO THE UPPER ACCUMULATOR ON A BIT-BY-BIT BASIS. FOR ANY ARITHMETIC OPERATION, THE CONTENTS OF THE UPPER ACCUMULATOR ARE CONSIDERED AS CONSISTING OF A SIGN BIT FOLLOWED BY 31 MAGNITUDE BITS AND THE OPERATION WILL BE PERFORMED ACCORDING TO THE NORMAL LAW OF SIGNS. FOLLOWING A MULTIPLY (MPY) INSTRUCTION, THE UPPER ACCUMULATOR WILL CONTAIN THE MOST SIGNIFICANT HALF OF THE DOUBLE WORD PRODUCT. BEFORE A DIVIDE (DIV) INSTRUCTION, THE UPPER ACCUMULATOR WILL CONTAIN THE MOST SIGNIFICANT HALF OF THE DOUBLE WORD DIVIDEND. ### THE LOWER ACCUMULATOR THE LOWER ACCUMULATOR MAY BE THOUGHT OF AS A SUPPLEMENT TO THE UPPER, PROVIDING AN ALTERNATE DATA HANDLING REGISTER, AND SERVING AS AN EXTENSION TO THE UPPER FOR BIT MANIPULATION AND EXTRA PRECISION ARITHMETIC. ITS CONTENTS MAY BE ADDED TO, SUBTRACTED FROM, AND TRANSFERRED DIRECT TO MEMORY, IN THE SAME WAY THAT THESE OPERATIONS ARE PERFORMED WITH THE UPPER. BEFORE A DIVIDE (DIV) INSTRUCTION, THE LOWER ACCUMULATOR WILL CONTAIN THE LEAST SIGNIFICANT HALF OF THE DIVIDEND. FOLLOWING A DIVIDE (DIV) OR A DIVIDE UPPER (DVU) INSTRUCTION, THE LOWER ACCUMULATOR CONTAINS THE REMAINDER. FOLLOWING A MULTIPLY (MPY) INSTRUCTION, THE LOWER ACCUMULATOR CONTAINS THE LEAST SIGNIFICANT HALF OF THE PRODUCT. WHEN COMBINED WITH THE UPPER ACCUMULATOR TO FORM A DOUBLE LENGTH WORD, BIT "O" OF THE LOWER ACCUMULATOR IS CONSIDERED AS A DATA BIT. OTHERWISE, IT IS CONSIDERED A SIGN BIT. THROUGH THE USE OF A MODIFIER BIT IN THE EXCHANGE (EXC) INSTRUCTION, THE LOWER ACCUMULATOR CAN BE SET TO EIGHT WORDS INSTEAD OF ONE. THESE EIGHT WORDS FUNCTION AS INDIVIDUAL ACCUMULATORS, BUT ARE SUBJECT TO CERTAIN RE-STRICTIONS IN THEIR USE. FOR FURTHER DISCUSSION OF THIS MODE, SEE PAGE 21. ### THE COMMAND REGISTER THE COMMAND REGISTER IS THAT REGISTER WHICH HOLDS AN INSTRUCTION WORD DUR-ING THE TIME THAT IT IS BEING INTERPRETED AND OPERATED BY THE COMPUTER. THE INSTRUCTION WORD CONSISTS OF FOUR LOGICAL PARTS OR FIELDS, EACH OF WHICH IS CONSIDERED WHEN AN INSTRUCTION IS PERFORMED: - I. THE COMMAND FIELD (BITS O THRU 4)---THIS FIELD IN THE COMMAND REGISTER WILL CONTAIN THE NUMERICAL CODE REPRESENTING THE OPERATION TO BE PERFORMED. IT SERVES ONLY TO IDENTIFY THE REQUIRED OPERATION AND HAS NO QUANTITATIVE SIGNIFICANCE. - THE DATA ADDRESS FIELD (BITS 5 THRU 17)---FOR MOST INSTRUCTIONS, THIS FIELD WILL CONTAIN A MEMORY ADDRESS SIGNIFYING THE LOCATION OF THE OPERAND. FOR SOME INSTRUCTIONS, THIS FIELD WILL CONTAIN A SET OF LOGICAL MODIFIERS WHICH SERVE TO FURTHER DEFINE THE OPERATION OF A BASIC COMMAND. AND FOR A FEW INSTRUCTIONS, THE CONTENTS OF THIS FIELD ARE USED AS THE OPERAND. - THE NEXT ADDRESS FIELD (BITS 18 THRU 30)---THIS FIELD WILL CONTAIN A MEMORY ADDRESS SIGNIFYING THE LOCATION OF THE INSTRUCTION WHICH IS TO OPERATE IMMEDIATELY FOLLOWING THE ONE CURRENTLY IN THE COMMAND REGISTER. THE ONLY EXCEPTION TO THIS IS THAT, UPON ENCOUNTERING AN ACTIVE TRANSFER INSTRUCTION, THE NEXT INSTRUCTION WILL BE TAKEN FROM THE ADDRESS SPECIFIED IN THE DATA ADDRESS FIELD. - 4. THE INDEX TAG FIELD (BIT 31)---A "I" BIT IN THIS FIELD WILL CAUSE THE COMPUTER TO APPLY INDEXING TO THE INSTRUCTION WHEN IT IS PLACED IN THE COMMAND REGISTER. THIS MEANS THAT THE DATA ADDRESS FIELD IS INCREMENTED BY THE CONTENTS OF BITS 5 THRU 17 OF THE INDEX REGISTER. IF THE INDEX TAG IS SET TO "O", INDEXING IS NOT APPLIED, AND THE DATA ADDRESS FIELD IN THE COMMAND REGISTER WILL BE IDENTICAL WITH THE CORRESPONDING INSTRUCTION IN MEMORY. ### THE INDEX REGISTER THE INDEX REGISTER PERFORMS SEVERAL IMPORTANT FUNCTIONS IN THE RPC-4000. ITS PRIMARY USE IS FOR ADDRESS MODIFICATION AND, FOR THIS PURPOSE, BITS 5 THRU I7 OF THE INDEX REGISTER SERVE TO HOLD A VALUE BY WHICH THE DATA ADDRESS FIELD OF AN INSTRUCTION MAY BE INCREMENTED. THIS INCREMENTAL VALUE MAY BE PLACED IN THE INDEX REGISTER BY MEANS OF A LOAD INDEX (LDX) INSTRUCTION, AND CAN BE USED BY INCLUDING AN INDEX TAG IN THE APPROPRIATE INSTRUCTION. BITS 18 THRU 24 OF THE INDEX REGISTER ARE USED TO HOLD THE REPEAT COUNT FOR ANY INSTRUCTION WHICH IS OPERATED IN THE REPEAT MODE. (SEE PAGE 22). THIS COUNT IS LOADED BY A LOAD COUNT (LDC) INSTRUCTION IMMEDIATELY PRECEDING THE INSTRUCTION TO BE REPEATED. BITS 25 THRU 30 OF THE INDEX REGISTER ARE USED IN CONJUNCTION WITH THE COMPARE MEMORY EQUAL (CME) AND THE COMPARE MEMORY GREATER (CMG) INSTRUCTIONS. At the BEGINNING OF A COMPARE INSTRUCTION, THE SECTOR REFERENCE TIMING TRACK IS COPIED INTO BITS 25 THRU 30 OF THE INDEX REGISTER. IF THE INSTRUCTION IS EXECUTED IN THE REPEAT MODE, THIS COPYING OCCURS PRIOR TO EACH ITERATION UNTIL A SUCCESSFUL COMPARISON IS MADE OR UNTIL THE SPECIFIED NUMBER OF REPEATS IS COMPLETED. IF AND WHEN A SUCCESSFUL COMPARISON OCCURS, ANY FURTHER COPYING OF THE TIMING TRACK IS INHIBITED. THE INDEX REGISTER WILL THEN CONTAIN A VALUE ONE SECTOR GREATER THAN THE SECTOR LOCATION OF THE MEMORY WORD WHICH COMPARED SUCCESSFULLY. IN ADDITION TO THE ABOVE FUNCTIONS, THE FULL WORD INDEX REGISTER MAY BE USED AS A RAPID ACCESS STORAGE LOCATION AND MAY BE EXCHANGED WITH THE UPPER ACCUMULATOR THROUGH THE USE OF THE EXCHANGE (EXC) INSTRUCTION. ### THE BRANCH CONTROL ALTHOUGH IT IS NOT A REGISTER, THERE IS ANOTHER INFORMATION HANDLING DEVICE WITHIN THE COMPUTER WHICH SHOULD BE MENTIONED HERE. THIS IS AN INTERNAL TOGGLE SWITCH CONSISTING OF ONLY ONE BIT AND KNOWN AS THE BRANCH CONTROL TOGGLE. IT IS AUTOMATICALLY TURNED ON WHEN AN OVERFLOW CONDITION OCCURS. IT MAY BE SET BY THE INSTRUCTIONS, SNS, CXE, CME, AND CMG. IT MAY BE SENSED BY THE INSTRUCTION, TBC (TRANSFER ON BRANCH CONTROL). ### PROGRAMMED OPERATING MODES THERE ARE CERTAIN MODIFICATIONS WHICH CAN BE MADE UNDER PROGRAM CONTROL, WHICH WILL ALTER THE NORMAL OPERATING PROCEDURES FOR THE CENTRAL COMPUTER. THEY ARE CONCERNED, FOR THE MOST PART, WITH THE PROCESSING OF MULTI-WORD BLOCKS OF INFORMATION OR TABLES OF ASSOCIATED DATA. THE FIRST OF THESE MODIFICATIONS PROVIDES THE ABILITY TO CHANGE THE FORM OF THE LOWER ACCUMULATOR FROM ONE WORD TO EIGHT INDIVIDUAL LOWER ACCUMULATORS. THE SECOND ENABLES AUTOMATIC REPETITION OF AN INSTRUCTION FOR A SELECTED NUMBER OF TIMES USING CONSECUTIVE STORAGE LOCATIONS. ### THE EIGHT WORD LOWER ACCUMULATOR THE LOWER ACCUMULATOR CAN BE SET TO EIGHT WORDS OR BACK TO ONE WORD BY MEANS OF TWO CONTROL BITS WHICH ARE A PART OF THE EXCHANGE (EXC) INSTRUCTION WORD. THE EFFECT OF SETTING THE LOWER TO EIGHT WORDS IS THAT, INSTEAD OF THE SAME VALUE BEING RECIRCULATED INTO ALL 64 WORD POSITIONS, THERE ARE EIGHT SEPARATE VALUES CONSIDERED, EACH OF WHICH IS RECIRCULATED INTO EIGHT WORD POSITIONS. IN THIS RESPECT, THE EIGHT WORD LOWER IS THE SAME FORMAT AS THE RECIRCULATING MEMORY LINE, TRACK 127. WHEN AN INSTRUCTION INVOLVING THE EIGHT WORD LOWER IS EXECUTED, THE ACCU-MULATOR WORD LOCATION USED WILL CORRESPOND TO THE SECTOR ADDRESS OF THE INSTRUCTION'S OPERAND. TO PUT IT ANOTHER WAY, IF WE LET LO, L1, L2,...L7 DESIGNATE THE EIGHT LOWER ACCUMULATORS, THEN AN INSTRUCTION WITH A DATA ADDRESS OF 10300 WOULD USE OR AFFECT L0, AS WOULD 10308, 10316, ETC. LIKEWISE, AN INSTRUCTION WITH A DATA ADDRESS OF 02703, WOULD USE OR AFFECT L3, AS WOULD 05403, 06711, 11819, ETC. IF OVERFLOW OCCURS IN A LOWER ACCUMULATOR WORD, IT HAS NO EFFECT ON THE OTHER SEVEN WORDS OF THE LOWER, NOR DOES IT AFFECT THE UPPER ACCUMULATOR. IT DOES. HOWEVER, TURN ON THE BRANCH CONTROL TOGGLE. THE EIGHT WORD LOWER ACCUMULATOR CAN BE USED WITH THE INPUT (INP) INSTRUCTION TO RECEIVE UP TO 64 4-BIT CHARACTERS OR 42 6-BIT CHARACTERS. INPUTS ENTER INTO THE LEAST SIGNIFICANT END OF LO, AND EACH SUCCEEDING CHARACTER CAUSES THE PRECEDING CHARACTERS TO BE SHIFTED LEFT UNTIL ALL EIGHT ACCUMULATORS ARE FILLED. IF THE NUMBER OF INPUT CHARACTERS EXCEEDS THE CAPACITY OF THE EIGHT WORD LOWER, CHARACTERS WILL BE LOST OUT OF THE MOST SIGNIFICANT END OF L7. ### THE AUTOMATIC REPEAT MODE THE EXECUTION PHASE OF AN INSTRUCTION OPERATED IN THIS MODE MAY BE EXTENDED TO ANY DESIRED NUMBER OF WORD TIMES, NOT TO EXCEED 128. A WORD TIME IS THAT TIME REQUIRED FOR ONE SECTOR OF THE DRUM TO PASS BENEATH THE READ/WRITE HEAD. IT IS APPROXIMATELY .25 MILLISECONDS. THUS, THE NUMBER OF REPETITIONS OF AN INSTRUCTION WILL BE A FUNCTION OF THE REPEAT COUNT AND THE WORD TIMES REQUIRED TO COMPLETE ONE EXECUTION. MOST INSTRUCTIONS REQUIRE ONLY ONE WORD TIME FOR COMMAND EXECUTION AND, THEREFORE, THE NUMBER OF REPETITIONS BEYOND THE INITIAL EXECUTION WILL BE EQUAL TO THE SPECIFIED REPEAT COUNT. THE REPEAT MODE IS INITIATED BY A LOAD COUNT (LDC) INSTRUCTION, WHICH PLACES THE REPEAT COUNT IN THE REPEAT CONTROL FIELD OF THE INDEX REGISTER (BITS 18 THRU 24). THE INSTRUCTION IMMEDIATELY FOLLOWING THE LDC INSTRUCTION WILL BE THE ONLY ONE AFFECTED. IT WILL BE PLACED IN THE COMMAND REGISTER AND, WHERE APPROPRIATE, THE DRUM WILL BE SEARCHED FOR ITS DATA ADDRESS AS IN NORMAL OPERATION. BUT ITS EXECUTION PHASE WILL BE CONTINUALLY REPEATED UNTIL THE REPEAT COUNT IN THE INDEX REGISTER RUNS OUT. FOR EACH REPETITION, THE DATA ADDRESS USED WILL BE THE ONE BENEATH THE HEAD AT THE TIME OF EXECUTION. WHEN THIS OPERATION CONTINUES BEYOND SECTOR 63, IT PROCEEDS WITH SECTOR 00, 01, ETC., OF THE SAME TRACK. TRACK SWITCHING IS NOT POSSIBLE DURING A REPEAT MODE OPERATION. THE REPEAT COUNT IN THE INDEX REGISTER DOES NOT DEFINE THE NUMBER OF REPETITIONS OF AN INSTRUCTION WHOSE EXECUTION PHASE REQUIRES MORE THAN ONE WORD TIME. THE NUMBER OF REPETITIONS IS DETERMINED BY DIVIDING THE NUMBER OF WORD TIMES IN THE EXTENDED EXECUTION PHASE BY THE WORD TIMES REQUIRED FOR ONE EXECUTION. IT SHOULD BE UNDERSTOOD THAT AN IMPROPER REPEAT COUNT SET BY THE LDC INSTRUCTION, CAN RESULT IN AN INCOMPLETE EXECUTION OF THE REPEATED INSTRUCTION. ANY INSTRUCTION EXCEPT LDC CAN BE OPERATED IN THE REPEAT MODE. HOWEVER, ITS USE WITH SOME INSTRUCTIONS LEADS TO RATHER UNPREDICTABLE RESULTS. ITS PRIMARY USE IS WITH THE ARITHMETIC INSTRUCTIONS FOR BLOCK PROCESSING OR BLOCK TRANSFERS, AND WITH THE COMPARE INSTRUCTIONS, CME AND CMG. FOR TABLE SEARCH. A SPECIAL CASE OCCURS WHEN A CONDITIONAL TRANSFER INSTRUCTION, TBC OR TMI, IS OPERATED IN THE REPEAT MODE. IF THE TRANSFER IS INACTIVE, NO ACTION IS TAKEN AND THE EXECUTION PHASE MERELY DELAYS PROCEEDING TO THE NEXT INSTRUCTION UNTIL THE REPEAT COUNT RUNS OUT. IF THE TRANSFER IS ACTIVE, THE NORMAL EXECUTION PHASE IS NEVER REACHED. CONSEQUENTLY, THE REPEAT COUNT REMAINS INTACT AND CAUSES THE REPETITION OF THE INSTRUCTION TO WHICH THE TRANSFER IS MADE. THIS IS THE ONLY INSTANCE IN WHICH THE REPEATED INSTRUCTION DOES NOT IMMEDIATELY FOLLOW THE LDC INSTRUCTION. ## THE INSTRUCTION LIST THE BASIC INSTRUCTIONS WHICH MAKE UP THE RPC-4000 INSTRUCTION LIST ARE DESCRIBED IN THE FOLLOWING PAGES. THESE ARE "MACHINE LANGUAGE" INSTRUCTIONS, EACH OF WHICH SPECIFIES A PARTICULAR ACTION TO BE TAKEN BY THE COMPUTER. PSEUDO-INSTRUCTIONS FOR COMMUNICATION WITH THE RUAR ASSEMBLY PROGRAM ARE NOT INCLUDED IN THIS SECTION. A DRAWING OF THE INSTRUCTION WORD FORMAT ACCOMPANIES EACH DESCRIPTION. THIS DRAWING CONTAINS THE NUMERICAL COMMAND CODE AND ILLUSTRATES THE FIELD ALLOCATION FOR EACH COMPONENT OF THE INSTRUCTION. THE MNEMONIC DESIGNATOR FOR EACH COMMAND IS SHOWN IN BOLD TYPE AT THE TOP OF EACH DESCRIPTION. IN MANY INSTANCES, DIAGRAMS HAVE BEEN INCLUDED TO SUPPORT AND CLARIFY THE TEXT EXPLANATIONS OF THE ACTIONS TAKEN BY THE INSTRUCTIONS. THESE DIAGRAMS INDICATE THE TRANSFER AND MODIFICATION OF THE CONTENTS OF THE VARIOUS REGISTERS WHICH ARE INVOLVED IN THE INSTRUCTION OPERATION. THE "MINIMUM TIME" REFERRED TO IN THESE PAGES INCLUDES THE MINIMUM TIME TO COMPLETE ALL FOUR PHASES OF THE OPERATION, FROM THE BEGINNING OF THE SEARCH FOR THE INSTRUCTION WORD TO THE BEGINNING OF THE SEARCH FOR THE NEXT INSTRUCTION WORD. HLT ### INSTRUCTION WORD FORMAT | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | |---------|---------|----------|---------|----------|-------| | 00 | 0 0 0 | (Any) | (Next A | ddress) | 0/1 | | 0 | 1 5 | 11 12 17 | 16 24 | 25 30 | 31 | THE COMPUTER WILL HALT WITH THE INSTRUCTION WORD IN THE COMMAND REGISTER. IF INDEXING IS SPECIFIED, IT SHOULD BE NOTED THAT ANY INDEX VALUE WHICH RESULTS IN A NON-ZERO VALUE IN THE D-TRACK FIELD WILL EFFECTIVELY PRODUCE A SNS INSTRUCTION. (SEE NEXT PAGE.) MINIMUM TIME-----4 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL----NOT AFFECTED REGISTERS AFFECTED--NONE ### INSTRUCTION WORD FORMAT | Cemmand | D-Track | D-Sector | N-Track | N-Sector | X-Tag | |---------|---------|----------|----------|----------|-------| | 00 | 1 → 127 | (Any) | (Next Ad | dress) | 0/1 | | 0 4 | 5 11 | 12 17 | 18 24 | 25 30 | 31 | THE INITIAL ACTION OF THE INSTRUCTION IS TO TURN OFF THE BRANCH CONTROL. This instruction will sense the condition of certain manual switches as related to the D-track value. If one or more D-track bits correspond to a depressed Sense Switch, or if D-track $\geq 64_{10}$ , the instruction will turn on the Branch Control. NOTE THAT ANY INDEX VALUE WHICH MODIFIES THE VALUE OF THE D-TRACK WILL ALTER THE LOGICAL CORRESPONDENCE OF THE D-TRACK BITS AND THE SENSE SWITCHES. MINIMUM TIME----- WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL ----- CONDITIONALLY SET "ON" REGISTERS AFFECTED --- NONE ### INSTRUCTION WORD FORMAT | Command | D-Track | D-Sector | N-Track | N-Sector 500 | X-Tag | |---------|---------|----------|---------|--------------|-------| | 01 | (Data | Value) | (Next | Address) | 0/1 | | 0 | 1 5 | 1 12 1 | 1 18 | 4 25 30 | 31 | The initial action of this instruction is to turn off the Branch Control. The Data Value in the instruction is then compared with bits $5 \longrightarrow 17$ of the index Register. If there is a one-to-one correspondence, the Branch Control is turned on. If not, the Branch Control remains off. IF INDEXING IS SPECIFIED IN THIS INSTRUCTION, A DATA VALUE OF ZERO WILL TURN ON THE BRANCH CONTROL, REGARDLESS OF THE INDEX VALUE. THIS OCCURS BECAUSE THE ZERO DATA VALUE, WHEN INDEXED, BECOMES IDENTICAL WITH THE INDEX VALUE. CONVERSELY, ANY DATA VALUE OTHER THAN ZERO WILL TURN OFF THE BRANCH CONTROL, REGARDLESS OF THE INDEX VALUE, INASMUCH AS ANY NON-ZERO VALUE, WHEN INDEXED, BECOMES GREATER THAN THE INDEX VALUE. MINIMUM TIME----- WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL-----CONDITIONALLY SET "ON" OR "OFF" REGISTERS AFFECTED --- NONE ### INSTRUCTION WORD FURMAT | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | |---------|----------|----------|----------|----------|-------| | 02 | (Data Ad | idress) | (Next Ad | dress) | 0/1 | | 0 4 | 5 11 | 12 17 | 18 24 | 25 30 | 31 | THE CONTENTS OF THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS WILL REPLACE THE CURRENT CONTENTS OF THE UPPER ACCUMULATOR. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME-----4 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL-----NOT AFFECTED REGISTERS AFFECTED---UPPER ACCUMULATOR # MEMORY REGISTER MEMORY REGISTER MEMORY REGISTER UPPER ACCUMULATOR WEMORY REGISTER UPPER ACCUMULATOR ### INSTRUCTION WORD FORMAT | Con | nmand | D-Tr | ack | D-Sector | | N-Track | | N-Sector | I | X-Tag | |-----|-------|------|----------|----------|----|---------|-------|----------|---|-------| | | 03 | | (Data Ad | dress) | | (Next | Addre | ess) | | 0/1 | | a | 4 | 5 | 11 | 12, | 17 | 18 | 24 25 | 3 | 0 | 31 | THE CONTENTS OF THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS WILL RE-PLACE THE CURRENT CONTENTS OF THE LOWER ACCUMULATOR. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME------ WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL-----NOT AFFECTED REGISTERS AFFECTED---LOWER ACCUMULATOR ### STORE ADDRESS FROM UPPER SAU ### INSTRUCTION WORD FORMAT | Cemmand | D-Track | D-Sector | N-Track | N-Sector | X-Tag | |---------|---------|----------|----------|------------------|-------| | 04 | (Data A | ddress) | (Next At | idr <b>e</b> ss) | 0/1 | | 0 4 | 5 | 12 | 18 24 | 25 30 | 31 | Stores bits $5 \longrightarrow 17$ of the Upper Accumulator into bits $5 \longrightarrow 17$ of the Memory Location specified by the Data Address, replacing the current contents of these bits. The remainder of the memory word is left unchanged. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME-----4 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL-----NOT AFFECTED REGISTERS AFFECTED --- SPECIFIED MEMORY LOCATION ### INITIAL CONTENTS ### FINAL CONTENTS ### INSTRUCTION WORD FORMAT | Command | D-Track | | D-Sector | | N-Track | | N-Sector | X-Tag | | | |---------|---------|----------------|----------|-----|----------------|-----|----------|-------|-----|----| | 05 | | (Data Address) | | | (Next Address) | | | | 0/1 | | | 0 | 4 5 | 14 | 12 | .17 | 18 | 2.4 | 25 | | 30 | 31 | STORES SELECTED BITS FROM THE LOWER ACCUMULATOR INTO THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS, AS MASKED BY THE UPPER ACCUMULATOR. WHERE THE UPPER ACCUMULATOR CONTAINS 1'S, STORES THE CORRESPONDING LOWER ACCUMULATOR BITS INTO THE MEMORY WORD. WHERE THE UPPER ACCUMULATOR CONTAINS 0'S, LEAVES THE CORRESPONDING MEMORY WORD BITS UNALTERED. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME-----4 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL-----NOT AFFECTED REGISTERS AFFECTED---SPECIFIED MEMORY LOCATION # MEMORY REGISTER MEMORY REGISTER Combined A&C UPPER ACCUMULATOR B LOWER ACCUMULATOR C C ### INSTRUCTION WORD FORMAT | Command D Track | | D-Sector | N-Track | N-Sector | X-Tag | |-----------------|----------|------------------|----------|----------|-------| | 06 | (Data Ad | idr <b>e</b> ss) | (Next Ac | ldress) | 0/1 | | 0 4 | 5 11 | 12 17 | 18 24 | 25 30 | 31 | Loads bits $18 \longrightarrow 24$ of the memory location specified by the Data Address into bits $18 \longrightarrow 24$ of the Index Register, replacing the current contents of these bits. The remainder of the Index Register is left unchanged. Causes the next instruction to be executed in the extended mode; that is, the instruction contained in the memory location specified by the Next Address will be repeated as many times as the number placed in bits $18 \longrightarrow 24$ of the index Register. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME-----4 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL----NOT AFFECTED REGISTERS AFFECTED---INDEX REGISTER ### INITIAL CONTENTS ### FINAL CONTENTS B = NUMBER OF TIMES FOLLOWING INSTRUCTION IS REPEATED LDX ### INSTRUCTION WORD FURMAT | Command | D-Track: | D-Sector | N-Track N-Sector | | | |---------|----------|----------|------------------|---------------------|--| | 07 | (Data V | alue) | (Next Address) | 0/1 | | | 7 4 | .5 | 12 | 24 25 30 | ∳. <b>j</b> i ′ ′ ′ | | LOADS THE DATA VALUE IN THE INSTRUCTION WORD INTO BITS $5 \longrightarrow 17$ of the Index Register, replacing the current contents of these bits. The remainder of the Index Register is left unchanged. THE DATA VALUE MAY BE MODIFIED BY INDEXING. THIS WILL SERVE TO INCREMENT THE INDEX VALUE BY THE NUMBER IN THE DATA VALUE FIELD. MINIMUM TIME----- WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL----NOT AFFECTED REGISTERS AFFECTED --- INDEX REGISTER ### INITIAL CONTENTS ### FINAL CONTENTS INPUT INP ### INSTRUCTION WORD FURMAT | Command | D-Track | D-Sector N-Track | | N-Sector | X-Tag | |---------|------------|------------------|---------|----------|-------| | 08 | 000 or 064 | | (Next A | idress) | 0/1 | | 0 4 | 5 | 12 17 | 18 24 | 25 30 | 31 | TERS INTO THE ACCUMULATOR. IF THE D-TRACK CONTAINS 064, READS 6-BIT CHARACTERS INTO THE ACCUMULATOR. No other address is permitted in the D-track IF THE LOWER ACCUMULATOR IS SET AT 1-WORD LENGTH, THE CHARACTERS WILL BE READ INTO THE DOUBLE LENGTH ACCUMULATOR (COMBINED UPPER AND LOWER). IF THE LOWER ACCUMULATOR IS SET AT 8-WORD LENGTH, THE CHARACTERS WILL BE READ INTO THE LOWER ACCUMULATOR ONLY. READ-IN BEGINS WITH THE LOW ORDER CHARACTER POSITION OF THE LOW ORDER ACCUMULATOR WORD AND, AS SUBSEQUENT CHARACTERS ARE READ IN, THE EXISTING ACCUMULATOR CONTENTS ARE SHIFTED LEFT ONE CHARACTER POSITION. THE D-TRACK VALUE MAY BE MODIFIED BY INDEXING. HOWEVER, CARE SHOULD BE TAKEN THAT THIS DOES NOT RESULT IN A VALUE OTHER THAN 000 OR 064. MINIMUM TIME-----DEPENDENT ON THE NUMBER OF CHARACTERS READ OVERFLOW-----NOT A FACTOR BRANCH CONTROL ----- NOT AFFECTED REGISTERS AFFECTED---UPPER AND/OR LOWER ACCUMULATORS | 1 | Command | | D-1 | Frack: | | D-Sector | N-Track | | N-Sector | | X-Tag | |---|---------|----|-----|--------|------|----------|---------|--------|----------|---|-------| | | 09 | 0+ | -2 | 0→15 | | (Any) | (Ne | ext Ac | idress) | | 0/1 | | | 0 4 | 6 | 7 | 8 1 | 1 12 | 17 | 18 | 24 | 25 30 | T | 31 | THIS INSTRUCTION PERFORMS ONE OR MORE OF THE FOLLOWING FUNCTIONS, IN ACCORDANCE WITH THE LOGICAL BIT PATTERN IN THE D-TRACK FIELD. IF BIT 6 = 1,-----SET THE LOWER ACCUMULATOR TO 1-WORD LENGTH. IF BIT 7 = 1,----SET THE LOWER ACCUMULATOR TO 8-WORD LENGTH. (THE ABOVE TWO FUNCTIONS ARE MUTUALLY EXCLUSIVE.) IF BIT 8 = 1,-----REPLACE THE CONTENTS OF THE UPPER ACCUMULATOR WITH THE CONTENTS OF THE INDEX REGISTER. IF BIT 9 = 1,-----REPLACE THE CONTENTS OF THE INDEX REGISTER WITH THE CONTENTS OF THE UPPER ACCUMULATOR. IF BIT 10 = 1,----REPLACE THE CONTENTS OF THE UPPER ACCUMULATOR WITH THE CONTENTS OF THE LOWER ACCUMULATOR. IF BIT | | = |,-----REPLACE THE CONTENTS OF THE LOWER ACCUMULATOR WITH THE CONTENTS OF THE UPPER ACCUMULATOR. (Any or all of the above exchanges may be executed with the same Instruction. If bits 8 and 10 are both set, the Upper Accumulator will receive the logical sum of the contents of the Index Register and the Lower Accumulator.) THE D-TRACK AND D-SECTOR VALUES MAY BE MODIFIED BY INDEXING. MINIMUM TIME----4 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL-----NOT AFFECTED REGISTERS AFFECTED --- INDEX REGISTER AND BOTH ACCUMULATORS | Command | D-Track | D-Track D-Sector N-Track | | | X-Tag | |---------|---------|--------------------------|----------|------------------|-------| | 10 | (Data A | dress) | (Next Ac | idr <b>e</b> ss) | 0/1 | | 0 4 | 5 11 | 12 17 | 18 24 | 25 30 | 31 | THE CONTENTS OF THE UPPER ACCUMULATOR ARE DIVIDED BY THE CONTENTS OF THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS. THE QUOTIENT IS LEFT IN THE UPPER ACCUMULATOR, AND THE REMAINDER IS LEFT IN THE LOWER ACCUMULATOR. THE REMAINDER IS ALWAYS A POSITIVE VALUE, REGARDLESS OF THE SIGN OF THE QUOTIENT, SO THAT THE DIVIDEND MINUS THE REMAINDER WILL ALWAYS EQUAL THE DIVISOR TIMES THE QUOTIENT. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME-----70 WORD TIMES OVERFLOW-----TURNS ON BRANCH CONTROL BRANCH CONTROL-----TURNED ON BY OVERFLOW REGISTERS AFFECTED---UPPER AND LOWER ACCUMULATOR DIV ### INSTRUCTION WORD FORMAT | Command | D-Track | D-Sector | M-Traci. | N-Sector | X-Tag | |---------|---------|----------|----------|--------------------|-------| | 11 | (Data A | dress) | (Next Ad | dress) + - egge du | 0/1 | | 0 4 | 5 11 | 12 17 | 18 24 | 25 30 | 31 | THE CONTENTS OF THE DOUBLE LENGTH ACCUMULATOR (COMBINED UPPER AND LOWER) ARE DIVIDED BY THE CONTENTS OF THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS. THE QUOTIENT IS LEFT IN THE UPPER ACCUMULATOR, AND THE REMAINDER IS LEFT IN THE LOWER ACCUMULATOR. THE REMAINDER IS ALWAYS A POSITIVE VALUE, REGARDLESS OF THE SIGN OF THE QUOTIENT, SO THAT THE DIVIDEND MINUS THE REMAINDER WILL ALWAYS EQUAL THE DIVISOR TIMES THE QUOTIENT. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME----- 70 WORD TIMES OVERFLOW-----TURNS ON BRANCH CONTROL BRANCH CONTROL-----TURNED ON BY OVERFLOW REGISTERS AFFECTED--UPPER AND LOWER ACCUMULATOR ## MEMORY REGISTER LOWER ACCUMULATOR + Remainder | I | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | | |---|---------|------------|---------------|----------|----------|-------|--| | | 12 | 000 on 001 | (Shift count) | (Next Ad | dress) | 0/1 | | | | 0 4 | 5 11 | 12 17 | 18 24 | 25 30 | 31 | | IF THE D-TRACK FIELD OF THE INSTRUCTION WORD CONTAINS 000, SHIFTS THE CONTENTS OF THE DOUBLE LENGTH ACCUMULATOR (COMBINED UPPER AND LOWER) TO THE RIGHT BY THE NUMBER OF BIT POSITIONS SPECIFIED IN THE SHIFT COUNT. BITS SHIFTED OUT OF THE LOW ORDER BIT POSITION ARE LOST. IF THE D-TRACK FIELD CONTAINS OO!, SHIFTS THE CONTENTS OF THE DOUBLE LENGTH ACCUMULATOR TO THE LEFT BY THE NUMBER OF BIT POSITIONS SPECIFIED IN THE SHIFT COUNT. IF OVERFLOW OCCURS, TURNS ON BRANCH CONTROL. BITS SHIFTED OUT OF THE SIGN POSITION ARE LOST. THE SHIFT COUNT AND/OR DIRECTION OF SHIFT MAY BE MODIFIED BY INDEXING. MINIMUM TIME----- WORD TIMES PLUS | FOR EACH BIT POSITION SHIFTED. OVERFLOW-----TURNS ON BRANCH CONTROL BRANCH CONTROL-----TURNED ON BY OVERFLOW REGISTERS AFFECTED---UPPER AND LOWER ACCUMULATORS ### RIGHT SHIFT | Г | Command | D-Track | D-Sector | M-Track | N-Sector | X-Tag | |---|---------|---------|----------|----------|----------|-------| | | 13 | | | (Next Ad | dress) | 0/1 | | 0 | 4 | 5 11 | 12 17 | 18 24 | 25 30 | 31 | THE VALUE CONTAINED IN THE DOUBLE LENGTH ACCUMULATOR (COMBINED UPPER AND LOWER) IS SHIFTED TO THE LEFT UNTIL IT IS IN NORMALIZED FORM; THAT IS, UNTIL BIT I CONTAINS THE FIRST SIGNIFICANT MAGNITUDE BIT. FOLLOWING THE SHIFT, THE LOWER ACCUMULATOR IS CLEARED TO ZERO, AND THE NUMBER OF BIT POSITIONS SHIFTED IS PLACED IN BITS 5-17 OF THE LOWER ACCUMULATOR. The Desector address must be zero INDEXING IS MEANINGLESS WITH THIS INSTRUCTION. MINIMUM TIME----- WORD TIMES PLUS I FOR EACH BIT POSITION SHIFTED OVERFLOW-----NOT A FACTOR BRANCH CONTROL-----NOT AFFECTED REGISTERS AFFECTED---UPPER AND LOWER ACCUMULATORS ### INITIAL CONTENTS ### COMBINED UPPER AND LOWER ACCUMULATOR ### FINAL CONTENTS | | UPPER ACCUMULATOR | <b>?</b> | |---|-------------------|----------| | S | Nermalized A | | | | | | | | LOWER ACCUMULATOR | } | | | Number of Shifts | 3 | | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | I | |---------|----------|----------|----------|----------|-------|---| | 14 | (Data Ad | dress) | (Next Ac | dress) | 0/1 | | | 0 4 | 5 11 | 12 17 | 18 24 | 25 30 | 31 | | THE CONTENTS OF THE UPPER ACCUMULATOR ARE MULTIPLIED BY THE CONTENTS OF THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS. THE RESULTING DOUBLE LENGTH PRODUCT IS HELD IN THE COMBINED UPPER AND LOWER ACCUMULATORS. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME-----70 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL ----- NOT AFFECTED REGISTERS AFFECTED---UPPER AND LOWER ACCUMULATORS # MEMORY REGISTER MEMORY REGISTER A UPPER ACCUMULATOR LOWER ACCUMULATOR FINAL CONTENTS MEMORY REGISTER A LOWER ACCUMULATOR | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | | |---------|------------|----------|----------|----------|-------|--| | 15 | 000 or 064 | | (Next Ac | idress) | 0/1 | | | 7 | 4 5 | 12 | 18 24 | 25 30 | 31 | | IF THE D-TRACK FIELD OF THE INSTRUCTION WORD CONTAINS 000, MULTIPLIES THE CONTENTS OF THE UPPER ACCUMULATOR BY $10_{10}$ , RETAINING THE PRODUCT IN THE UPPER ACCUMULATOR. IF THE D-TRACK FIELD OF THE INSTRUCTION WORD CONTAINS 064, MULTIPLIES THE CONTENTS OF THE LOWER ACCUMULATOR BY 1010, RETAINING THE PRODUCT IN THE LOWER ACCUMULATOR. THE D-TRACK VALUE MAY BE MODIFIED BY INDEXING. MINIMUM TIME-----4 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL ----- NOT AFFECTED REGISTERS AFFECTED---UPPER OR LOWER ACCUMULATOR ### PRINT FROM D-ADDRESS ### INSTRUCTION WORD FURMAT | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | |---------|---------|----------|----------|----------|-------| | 16 | 000 127 | (Any) | (Next Ac | dress) | 0/1 | | 0 4 | 5 ,11 | 12 17 | 18 24 | 25 30 | 31 | If the D-track field of the Instruction Word contains $000 \longrightarrow 063$ , prints the character it represents on the selected output device. IF THE D-TRACK FIELD CONTAINS 064 -> 127, SELECTS THE INPUT AND/OR OUTPUT DEVICES IT REPRESENTS. (SEE SELECTION TABLE BELOW) THE 1/0 Interlock will be turned on, preventing the execution of another print instruction until completion of the current one, if the D-sector field contains any sector other than the first optimum sector (instruction location + 2). If this sector is specified, the interlock will be bypassed. THE D-TRACK AND D-SECTOR VALUES MAY BE MODIFIED BY INDEXING. REGISTERS AFFECTED --- NONE ### INPUT/OUTPUT SELECTION CODES | D-TRACK | | |---------|---------------------------------------------| | 64 | READER INPUT | | 65 | READER INPUTPUNCH OUTPUT | | 66 | READER INPUTTYPEWRITER OUTPUT | | 67 | READER INPUTPUNCH AND TYPEWRITER OUTPUT | | 68 | TYPEWRITER INPUT | | 69 | TYPEWRITER INPUTPUNCH OUTPUT | | 70 | TYPEWRITER INPUTTYPEWRITER OUTPUT | | 71 | TYPEWRITER INPUTPUNCH AND TYPEWRITER OUTPUT | | 72 | PHOTO-READER, FORWARD AND SEARCH | ### INPUT/OUTPUT SELECTION CODES (CONTINUED) | 73 | PHOTO-READER, REVERSE AND SEARCH | |----------|----------------------------------| | 74 | PHOTO-READER, FORWARD | | 75 | PHOTO-READER, REVERSE | | 76-94 | AVAILABLE FOR ADDITIONAL UNITS | | 95 | MASTER RESET (RESET ALL UNITS) | | 96 | AVAILABLE | | 97 | PUNCH OUTPUT | | 98 | TYPEWRITER OUTPUT | | 99 | PUNCH AND TYPEWRITER OUTPUT | | 100 | AVAILABLE | | 101 | Punch output | | 102 | TYPEWRITER OUTPUT | | 103 | PUNCH AND TYPEWRITER OUTPUT | | 104, 105 | SEARCH MODE | | 106124 | AVAILABLE | | 125 | COPY MODE ON | | 126 | COPY MODE OFF | | 127 | RESET OUTPUT UNITS | | | | ### NOTES: - 1. SELECTION OF A NEW INPUT DEVICE AUTOMATICALLY RESETS THE PREVIOUS ONE. ONLY ONE INPUT DEVICE MAY BE IN THE SYSTEM AT A TIME. - 2. Any combination of output devices may be included in the system at one time. A reset command is necessary to drop an output device from the system. | 1 | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | ŀ | |---|------------|---------|----------|----------|----------|-------|----| | | . 17 | 000 127 | (Any) | (Next Ad | dress) | 0/1 | | | | <b>o</b> 4 | 5 | 12. 17 | 18 24 | 25 30 | 31 | ١, | IF THE D-TRACK FIELD OF THE INSTRUCTION WORD CONTAINS 000 -- 063, PRINTS THE CHARACTER REPRESENTED BY THE COMBINATION OF BITS 6 AND 7 FROM THE INSTRUCTION WORD FOLLOWED BY THE HIGH ORDER FOUR BITS OF THE UPPER ACCUMULATOR. If the D-track field contains $064 \longrightarrow 127$ , prints the character represented by the high order six bits of the Upper Accumulator. The 1/0 interlock will be turned on, preventing the execution of another print instruction until completion of the current one, if the D-sector field contains any sector other than the first optimum sector (instruction location + 2). If this sector is specified, the interlock will be bypassed. THE D-TRACK AND D-SECTOR VALUES MAY BE MODIFIED BY INDEXING. MINIMUM TIME-----4 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL----NOT AFFECTED REGISTERS AFFECTED---NONE | | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | |---|---------|---------|----------|----------|----------|-------| | | 18 | (Data A | dress) | (Next Ac | dress) | 0/1 | | 0 | 4 | 5 11 | 12 17 | 18 2.4 | 25 30 | 31 | PRODUCES, IN THE UPPER ACCUMULATOR, THE LOGICAL PRODUCT OF THE CONTENTS OF THE UPPER ACCUMULATOR AND THE CONTENTS OF THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS. THE RESULTANT PRODUCT WILL CONTAIN I'S IN ONLY THOSE BIT POSITIONS WHICH ARE SET TO I IN BOTH THE UPPER ACCUMULATOR AND THE MEMORY WORD. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME----- WORD TIMES OVERFLOW----NOT A FACTOR BRANCH CONTROL ----NOT AFFECTED REGISTERS AFFECTED --- UPPER ACCUMULATOR ### INITIAL CONTENTS ### FINAL CONTENTS | - | Command | D Track | D-Sector | N-Traci. | N-Sector | X-Tag | |---|---------|----------|----------|----------|------------------|-------| | | 19 | (Data Ac | ldress) | (Next Ad | ldr <b>e</b> ss) | 0/1 | | | 0 4 | 5. 11 | 12 | 18 24 | 25 30 | 31 | THE CONTENTS OF THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS ARE MERGED WITH THE CONTENTS OF THE LOWER ACCUMULATOR UNDER CONTROL OF THE UPPER ACCUMULATOR. IN THOSE BIT POSITIONS WHERE THE UPPER ACCUMULATOR CONTAINS 0'S, THE LOWER ACCUMULATOR IS RETAINED. IN THOSE BIT POSITIONS WHERE THE UPPER ACCUMULATOR CONTAINS 1'S, THE CONTENTS OF THE MEMORY WORD REPLACE THE CORRESPONDING CONTENTS OF THE LOWER ACCUMULATOR. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME-----4 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL----NOT AFFECTED REGISTERS AFFECTED---NONE ## MEMORY REGISTER | Command | D-Track | D-Sector | N-Track | N-Sector | X- | Tag | |---------|---------|----------|---------|----------|------|-----| | 20 | (Data / | (ddress) | (Next A | (ddress) | 0/ | /1 | | 0 4 | 5 | 1 12 | 16. 2 | 4 25 | 30 3 | 7 | PRIOR TO PERFORMING THE SPECIFIED COMPARISON, THE BRANCH CONTROL IS TURNED OFF, AND THE SECTOR REFERENCE TIMING TRACK IS COPIED INTO BITS $25 \longrightarrow 30$ of THE INDEX REGISTER. THIS WILL ALWAYS BE ONE SECTOR AHEAD OF THE DATA ADDRESS BEING COMPARED. SELECTED BITS OF THE UPPER ACCUMULATOR ARE THEN COMPARED WITH CORRESPONDING BITS IN THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS. ONLY THOSE BIT POSITIONS INDICATED BY I'S IN THE LOWER ACCUMULATOR MASK ARE COMPARED. IF THE SELECTED VALUES ARE IDENTICAL, THE BRANCH CONTROL IS TURNED ON TO INDICATE A SUCCESSFUL COMPARISON. IF THE INSTRUCTION IS BEING EXECUTED IN THE REPEAT MODE, THE SECTOR REFERENCE TIMING TRACK IS COPIED INTO BITS 25 -> 30 OF THE INDEX REGISTER BEFORE EACH COMPARISON UNTIL A SUCCESSFUL COMPARISON IS MADE OR UNTIL COMPLETION OF THE REPEAT FUNCTION. A SUCCESSFUL COMPARISON INHIBITS ANY FURTHER COPYING OF THE TIMING TRACK. THE MEMORY LOCATION CONTAINING THE VALUE WHICH COMPARES SUCCESSFULLY MAY THEN BE DETERMINED BY REFERENCE TO THE INDEX REGISTER. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME----- WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL-----CONDITIONALLY SET "ON" OR "OFF" REGISTERS AFFECTED---INDEX REGISTER | i | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | l | |---|---------|----------|----------|----------|----------|-------|---| | | 21 | (Data Ad | ldress) | (Next Ac | dress) | 0/1 | | | Į | 0 4 | 5 11 | 12 | 18 24 | 25 30 | 31 | | PRIOR TO PERFORMING THE SPECIFIED COMPARISON, THE BRANCH CONTROL IS TURNED OFF, AND THE SECTOR REFERENCE TIMING TRACK IS COPIED INTO BITS $25 \longrightarrow 30$ of THE INDEX REGISTER. THIS WILL ALWAYS BE ONE SECTOR AHEAD OF THE DATA ADDRESS BEING COMPARED. SELECTED BITS OF THE UPPER ACCUMULATOR ARE THEN COMPARED WITH CORRESPONDING BITS IN THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS. ONLY THOSE BIT POSITIONS INDICATED BY I'S IN THE LOWER ACCUMULATOR MASK ARE COMPARED. IF THE SELECTED VALUE IN MEMORY IS GREATER THAN, OR EQUAL TO THE SELECTED UPPER ACCUMULATOR VALUE, THE BRANCH CONTROL IS TURNED ON. IF THE INSTRUCTION IS BEING EXECUTED IN THE REPEAT MODE, THE SECTOR REFERENCE TIMING TRACK IS COPIED INTO BITS 25 -> 30 OF THE INDEX REGISTER BEFORE EACH COMPARISON UNTIL A MEMORY VALUE EQUAL TO, OR GREATER THAN THE ACCUMULATOR VALUE IS FOUND, OR UNTIL COMPLETION OF THE REPEAT FUNCTION. IF SUCHAVALUE IS FOUND, ANY FURTHER COPYING OF THE TIMING TRACK IS INHIBITED. THE MEMORY LOCATION WHICH CONTAINS THIS VALUE CAN THEN BE DETERMINED BY REFERENCE TO THE INDEX REGISTER. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME----- WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL-----CONDITIONALLY SET "ON" OR "OFF" REGISTERS AFFECTED --- INDEX REGISTER | Cemmand | D-Track | D-Sector | N-Track | N-Sector | X-Tag | |---------|----------|------------|----------|----------|-------| | 22 | (Transte | r Address) | (Next Ad | dress) | 0/1 | | 0 4 | 5 11 | 12 17 | 16 24 | 25 30 | 31 | IF THE UPPER ACCUMULATOR IS NEGATIVE (A III IN BIT POSITION ZERO), CONTROL IS TRANSFERRED TO THE INSTRUCTION SPECIFIED BY THE TRANSFER ADDRESS. IF THE VALUE IS POSITIVE, THE INSTRUCTION HAS NO EFFECT, AND THE NEXT INSTRUCTION IS THAT SPECIFIED IN THE NEXT ADDRESS FIELD. THE TRANSFER ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME----- WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL----NOT AFFECTED REGISTERS AFFECTED --- NONE | 1 | Command | D-Track | D-Sector | N-Traci. | H-Sector | X-Tag | | |---|---------|-----------|----------|----------|----------|-------|---| | | 23 | (Transier | Address) | (Next As | dréss) | 0/1 | | | 1 | 0 4 | 5. 11 | 12 17 | 16 24 | 25 30 | 31 | ı | IF THE BRANCH CONTROL IS ON, CONTROL IS TRANSFERRED TO THE INSTRUCTION SPECIFIED BY THE TRANSFER ADDRESS, AND THE BRANCH CONTROL IS TURNED OFF. IF THE BRANCH CONTROL IS OFF, THE INSTRUCTION HAS NO EFFECT, AND THE NEXT INSTRUCTION IS THAT SPECIFIED IN THE NEXT ADDRESS FIELD. THE TRANSFER ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME-----4 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL-----SET TO "OFF" REGISTERS AFFECTED---NQNE | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | l | |---------|---------|----------|---------|----------|-------|---| | 24 | (Data A | idress) | (Next A | idress) | 0/1 | | | 0 4 | 5 11 | 12 | 18 24 | 25 30 | 31 | | STORES THE CONTENTS OF THE UPPER ACCUMULATOR INTO THE MEMORY LOCATION SPE-CIFIED BY THE DATA ADDRESS, REPLACING ITS CURRENT CONTENTS. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME----- WORD TIMES OVERFLOW------NOT A FACTOR BRANCH CONTROL ---- NOT AFFECTED REGISTERS AFFECTED --- SPECIFIED MEMORY LOCATION | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | |---------|---------|------------------|----------|----------|-------| | 25 | (Data A | idr <b>e</b> ss) | (Next Ad | dress) | 0/1 | | 0 4 4 | 5 | 12 17 | 18 24 | 25 30 | 31 | STORES THE CONTENTS OF THE LOWER ACCUMULATOR INTO THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS, REPLACING ITS CURRENT CONTENTS. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME----- WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL----NOT AFFECTED REGISTERS AFFECTED --- SPECIFIED MEMORY LOCATION | | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | |---|---------|----------|----------|----------|----------|-------| | | 26 | (Data Ad | idress) | (Next Ad | dress) | 0/1 | | 1 | 0 4 | 5 11 | 12 17 | 18 24 | 25 30 | 31 | STORES THE CONTENTS OF THE UPPER ACCUMULATOR INTO THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS, REPLACING THE CURRENT CONTENTS. CLEARS THE UPPER ACCUMULATOR TO ZERO. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME----- 4 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL----NOT AFFECTED REGISTERS AFFECTED---SPECIFIED MEMORY LOCATION AND UPPER ACCUMULATOR | Comi | mand | D-Track | D-Sector | N-Track | N-Sector | X-Tag | |------|------|---------|----------|----------|----------|-------| | | 27 | (Data A | (ddress) | (Next Ad | dress) | 0/1 | | 0 | 4 | 5 | 1 12 17 | 18 24 | 25 30 | 31 | STORES THE CONTENTS OF THE LOWER ACCUMULATOR INTO THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS, REPLACING THE CURRENT CONTENTS. CLEARS THE LOWER ACCUMULATOR TO ZERO. THE DATA ADDRESS MAY BY MODIFIED BY INDEXING. MINIMUM TIME-----4 WORD TIMES OVERFLOW-----NOT A FACTOR BRANCH CONTROL-----NOT AFFECTED REGISTERS AFFECTED---SPECIFIED MEMORY LOCATION AND LOWER ACCUMULATOR | Command | D-Track | D-Sector | N-Track | N-Sector | A-13: | |---------|---------|-----------------|----------|-----------------|-------| | 28 | (Data A | dr <b>e</b> ss) | (Next Ac | dr <b>e</b> ss) | 0/: | | 0 4 | 5 | 12 17 | 18 94 | 25 30 | | ADDS THE CONTENTS OF THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS TO THE CONTENTS OF THE UPPER ACCUMULATOR. RETAINS THE SUM IN THE UPPER ACCUMULATOR. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME----- WORD TIMES OVERFLOW-----TURNS ON BRANCH CONTROL BRANCH CONTROL-----TURNED ON BY OVERFLOW REGISTERS AFFECTED---UPPER ACCUMULATOR ## MEMORY REGISTER MEMORY REGISTER MEMORY REGISTER MEMORY REGISTER UPPER ACCUMULATOR B A + B | Command | D-Track | D-Sector | N-Track | N-Sector | X-Tag | |---------|--------------|----------|----------|----------|-------| | 29 | (Data Addres | (8) | (Next Ad | dress) | 0/1 | | 0 4 | 5 11 12 | 17 18 | 24 | 25 30 | 31 | ADDS THE CONTENTS OF THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS TO THE CONTENTS OF THE LOWER ACCUMULATOR. RETAINS THE SUM IN THE LOWER ACCUMULATOR. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME-----4 WORD TIMES OVERFLOW-----TURNS ON BRANCH CONTROL BRANCH CONTROL-----TURNED ON BY OVERFLOW REGISTERS AFFECTED---LOWER ACCUMULATOR ## MEMORY REGISTER MEMORY REGISTER A LOWER ACCUMULATOR B A + B | | Command | | D-Track | | D-Sector | N-Track | N-Sector | X-Tag | |---|---------|-----|---------|-------------|-----------|---------|------------------|-------| | | 30 | | (1 | Data Addres | <b>s)</b> | (Next A | idr <b>és</b> s) | 0/1 | | 0 | ) | 4 5 | | 11 12 | Û | 10 | 25 30 | 31 | SUBTRACTS THE CONTENTS OF THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS FROM THE CONTENTS OF THE UPPER ACCUMULATOR. RETAINS THE DIFFERENCE IN THE UPPER ACCUMULATOR. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIME----- WORD TIMES OVERFLOW-----TURNS ON BRANCH CONTROL BRANCH CONTROL ----- TURNED ON BY OVERFLOW REGISTERS AFFECTED --- UPPER ACCUMULATOR | - | Cemmand | D-Track B-Sector N-Track N-Sector X- | Tag | |---|---------|---------------------------------------------------|-----| | I | 31 | (Data Address) (Next Address) 0/ | /1 | | | 0 4 | 5 11 12 12 12 13 13 18 13 13 24 25 13 13 13 13 13 | 1 | SUBTRACTS THE CONTENTS OF THE MEMORY LOCATION SPECIFIED BY THE DATA ADDRESS FROM THE CONTENTS OF THE LOWER ACCUMULATOR. RETAINS THE DIFFERENCE IN THE LOWER ACCUMULATOR. THE DATA ADDRESS MAY BE MODIFIED BY INDEXING. MINIMUM TIMET ----- WORD TIMES OVERFLOW-------TURNS ON BRANCH CONTROL BRANCH CONTROL ----- TURNED ON BY OVERFLOW REGISTERS AFFECTED -- LOWER ACCUMULATOR ## MEMORY REGISTER MEMORY REGISTER A LOWER ACCUMULATOR B B A ### April 1960 Edition - Page 34 If the D-track field of the INP instruction contains a value other than 000 or 064, the character which enters the Lower accumulator will be the logical product of the incoming tape character and the corresponding bits from the D-track field of the instruction word. - Page 39 The description of the SLC instruction should read as follows: The value contained in the double length accumulator (combined Upper and Lower) is shifted to the left until bit 1 contains the first significant magnitude bit, or until the sum of the D-sector value of the instruction word and the number of bit positions shifted equals 64. Following the shift, the Lower accumulator is cleared to zero, and the sum of the D-sector value and the number of shifts is placed in Lower accumulator bits 12 through 17, modulo 64. That is, a sum of 64 will appear in the Lower as zero. The Data address may be modified by indexing. Page 41 - The MPT instruction may cause an overflow out of the left end of the affected accumulator but this overflow will not turn on Branch Control. The addition of two diodes to the logic board can make this command function as a Shift Left, 20r3 bits in 4 word times. In this case The D-track value will be some other value than 000 of 064.