# MASSACHUSETTS INSTITUTE OF TECHNOLOGY LINCOLN LABORATORY # TX-2 USERS HANDBOOK ALEXANDER VANDERBURGH, Jr. (Ed.) LINCOLN MANUAL NO. 45 JULY 1961 The work reported in this document was performed at Lincoln Laboratory, a center for research operated by Massachusetts Institute of Technology, with the joint support of the U.S. Army, Navy and Air Force under Air Force Contract AF 19(604)-7400. Note to TX-2 Users - The TX-2 Users Handbook will be printed in several installments - you now have the first. There will be seven chapters - they are listed below in order of (expected) appearance: Chapter 4 - In-Out System - Sections 46 and 74 (Mag. Tape and Plotter) to come later. " 7 - Charts " 6 - M4 Utility System " 5 - Lights and Buttons " 3 - Operation Code " 2 - Functional Description " 1 - Introduction Who knows? Your comments, criticisms, and (unfortunately,) corrections, are requested. A. Vanderburgh # TX-2 USERS HANDBOOK # CHAPTER 3 - OPERATION CODE ## TABLE OF CONTENTS | | | | Page | |-----|-----------|------------------------------------------------------|------| | 3-1 | BRIEF GUI | DE TO THE ABBREVIATIONS | 3-3 | | 3-2 | OP CODE D | ESCRIPTIONS - (For In Out, See Chapter 4.) | 3-5 | | | 3-2.1 | LOAD-STORE CLASS | 3-5 | | | | LDA, LDB, LDC, LDD, (LDE) - LOAD | 3-6 | | | | STA, STB, STC, STD, (STE) - STORE | 3-8 | | | | EXA - EXCHANGE · · · · · · · · · · · · · · · · · · · | 3-10 | | | 3-2.2 | INDEX REGISTER CLASS | 3-13 | | | | RSX - Reset Index | 3-14 | | | | DPX - Deposit Index | 3-16 | | | | EXX - Exchange Index | 3-18 | | | | AUX - Augment Index | 3-20 | | | | ADX - Add Index | 3-22 | | | | SKX - Skip on Index | 3-24 | | | | JPX - Jump on Positive Index | 3-26 | | | | JNX - Jump on Negative Index | 3-26 | | | 3-2.3 | JUMP-SKIP CLASS | 3-29 | | | | JMP - Jump (with variations) | 3-30 | | | | JPA - Jump on Positive Accumulator | 3-32 | | | | JNA - Jump on Negative Accumulator | 3-32 | | | | JOV - Jump on Overflow | 3-32 | | | | SKM - Skip on Bit | 3-34 | | | | SED - Skip if E Differs | 3-36 | | | 3-2.4 | SCALE, NORMALIZE CYCLE | 3-37 | | | | SCA, SCB, SAB - Scale | 3-38 | | | | NOA, NAB - Normalize | 3-40 | | | | CYA, CYB, CAB - Cycle | 3-42 | | | | | | | | | | Page | |-----|-----------|------------------------------------|------| | | 3-2.5 | LOGIC, INSERT, COMPLEMENT/PERMUTE | 3-45 | | | | ITA, UNA, DSA, ITE - Logic | 3-46 | | | | INS - Insert | 3-48 | | | | COM - Complement/Permute | 3-50 | | | 3-2.6 | CONFIGURATION MEMORY CLASS | 3-53 | | | | SPF, SPG - Specify | 3-54 | | | | FLF, FLG - File | 3-55 | | | 3-2.7 | ARITHMETIC CLASS | 3-57 | | | | ADD, SUB | 3-58 | | | | MUL | 3-60 | | | | DIV | 3-62 | | | | TLY | 3-65 | | 3-3 | OPERATION | CODE CHART (Wesley A. Clark) | 3-67 | | | 3-3.1 | NUMBER SYSTEMS | 3-68 | | | 3-3.2 | GLOSSARY OF TERMS | 3-68 | | | | OPERATION CODE CHART | 3-71 | | | 3-3-3 | NOTES ON THE CODING CHART | 3-73 | | 3-4 | CHAPTER 3 | INDEX (Alphabetical and Numerical) | 3-77 | ### 3-1 BRIEF GUIDE TO THE ABBREVIATIONS ``` X Memory Register "j" X [X,] Contents of X Memory Register j STUV memory address "T" (STUV memory is "S", "T", "U", and "V" memories) T T + [X,] T, Contents of STUV Memory Register T, [T,] F memory register \alpha Fa Contents of F memory register \alpha [F<sub>0</sub>] \alpha [T,] \left[ \mathbf{T}_{,j} \right] Configured as specified by \alpha Quarter Left Half Right Half S Sign of SE Sign Extended (i.e. "With Sign Extension") Is copied into (Goes into) ==> ``` ### Examples: The notation below is borrowed from the M4 Utility system. (See Chapter 6.) {w} Register Containing w \* Deferred address A,B,C,D,E The AE addresses: 377604, 377605, 377606, 377607, and 377610 # The current location - i.e. the location of the instruction being performed. # 3-2 Op Code Descriptions 3-2.1 LOAD, STORE, EXCHANGE LDA LDB LDC LDD LDE STA STB STC STD STE EXA August 1963 LOAD AE (24-27) LOAD E REGISTER (20) LDA, 24 LDA LDB, 25 24 LDC, 26 LDD, 27 LDE, 20 $$\alpha_{\text{LDA T}_{j}}$$ $\alpha_{\text{[T}_{j}]} => A$ LOAD means copy into the AE from STUV memory. STUV memory is not changed. Activity, Sign Extension, and permutation are used. ALL load instructions except LDE perform the standard $[T_{j}] => E$ . EXAMPLES: \*\*(Standard F memory - Chart 7-2) | | EXAMPLES: **(Scandard F memory - order 2) | | | | | | | |-----|-----------------------------------------------------------|--------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--| | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>DESCRIPTION | COMMENT | | | | | 1. | LDA T | T <sub>j</sub> | [T <sub>j</sub> ] ==> A [T <sub>j</sub> ] ==> E | Since all four quarters are active, subword form is immaterial. <sup>20</sup> LDA or <sup>30</sup> LDA would be equivalent. | | | | | 2. | <sup>1</sup> LDA T <sub>j</sub> | T <sub>j</sub> | R[T <sub>j</sub> ] ==> R(A) [T <sub>j</sub> ] ==> E | The left half of A is not changed. | | | | | 3. | ll <sub>LDA</sub> T <sub>j</sub> [F <sub>ll</sub> ] = 140 | T <sub>j</sub> | $R[T_{j}] ==> R(A)$ $SR[T_{j}] ==> L(A)$ $[T_{j}] ==> E$ | The 18 bit word from STUV is "expanded" to 36 bits through "sign extension." | | | | | 4. | <sup>2</sup> LDA T <sub>j</sub> | T <sub>j</sub> | $L[T_{j}] \Longrightarrow R(A)$ $[T_{j}] \Longrightarrow E$ | A "Right Half Load" -<br>the left half of A is<br>not affected. | | | | <sup>\*\*</sup>All examples apply directly to LDA, LDB, LDC, and LDD. LDE is essentially the same - only the final M to E copy is omitted. | LDA, | 24 | LDA | |------|----|-----| | LDB, | 25 | 24 | | LDC, | 26 | | | LDD, | 27 | | | LDE. | 20 | | | 5. | <sup>2</sup> LDA A | A (Before) A (After) | L[A] ==> R(A) [A] ==> E | The left half of A is unchanged. The right half becomes the same as the left. In a similar manner, <sup>22</sup> LDA A sets the left equal to the right. <sup>12</sup> LDA would clear the left half word through sign extension. | |----|-----------------------------------------------------------|--------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6. | 16 <sub>LDA</sub> T <sub>j</sub> [F <sub>16</sub> ] = 163 | T <sub>j</sub> | $q^{\mu}[T_{j}] ==> ql(A)$ $Sq^{\mu}[T_{j}] ==> q2,3,4(A)$ $[T_{j}] ==> E$ | The nine bit number in quarter 4 of T <sub>j</sub> is expanded to 36 bits in A. | | 7. | LDA {T <sub>k</sub> }* | (T <sub>k</sub> ) <sub>j</sub> | $R[(T_k)_j] ==> R(A)$ $[(T_k)_j] ==> E$ | This is double indexing. $ (\mathbf{T_k})_j \equiv \mathbf{T} + [\mathbf{X_k}] + [\mathbf{X_j}]. $ (It is not always faster because the defer cycle takes time also.) | $$\alpha_{\text{STA T}_{j}}$$ $\alpha_{\text{[A]}} => T_{j}$ STORE is a non-destructive copy from AE to STUV memory. With a partially active configuration it becomes a partial store. Subword form is meaningless - only active pathways are used. The E register is set from the memory word after the store operation (except for STE which does not change E). | EXAMI | EXAMPLES: **(Standard F Memory - Chart 7-2) | | | | | | | |-------|---------------------------------------------|--------------------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>DESCRIPTION | COMMENT | | | | | 1. | STA T | T <sub>j</sub> | [A] ==> T <sub>j</sub> ** | T <sub>j</sub> is set from A, A is not changed. Since all quarters are active, all are copied into T <sub>j</sub> . | | | | | 2. | <sup>1</sup> STA T <sub>j</sub> | T <sub>j</sub> | R[A] ==> R(T <sub>j</sub> ) ** | Since there is no sign extension, $^{11}$ STA would have the same affect. $[F_{11}] = 140$ | | | | | 3. | <sup>2</sup> STA I <sub>j</sub> | T <sub>j</sub> | R[A] ==> L(T;) ** | $^{12}$ STA would be exactly the same. $[F_{12}] = 142$ | | | | | 4. | <sup>2</sup> STA A | A A | R[A] ==> L(A) ** | This sets the left equal to the right (as does <sup>22</sup> LDA A). Since there is no sign extension on STA, <sup>12</sup> STA would do the same. | | | | | | | | | $[F_{22}] = 232$ | | | | <sup>\*\*</sup> After the store operation is complete, the new content of $\mathbb{T}_j$ is copied into $\mathbb{E}$ except for the STE instruction which does not change E. | 5. | <sup>5</sup> STA T <sub>j</sub><br>[F <sub>5</sub> ] = 762 | | <sup>Т</sup> ј<br>А | ql[A] ==> q3(T <sub>j</sub> ) ** | Quarter 1 is copied into quarter 3 of T <sub>j</sub> . The rest of T <sub>j</sub> is unchanged. | |----|------------------------------------------------------------|---------|---------------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------| | 6. | l <sub>STE</sub> T <sub>j</sub><br>(Store <u>E</u> ) | | T <sub>j</sub> | R[E] ==> L(T <sub>j</sub> ) | Stores in the right half only - useful for setting address sections - (For example, at start of subroutines entered via hJPQ). | | 7. | STA {T <sub>k</sub> }* | † † † † | (T <sub>k</sub> )j | [A] ==> (T <sub>k</sub> ) <sub>j</sub> ** | Double indexing - $(T_k)_j \equiv T + [X_k] + [X_j]$ | | α <sub>EXA</sub> T. | α[A] ==> T <sub>j</sub> | |---------------------|-------------------------| | EAA 1 | $\alpha_{[T_j]} => A$ | EXCHANGE A is a combination of STA and LDA. Sign extension, if any, occurs only in A and $\underline{\text{after}}$ the exchange of data. Subword form, Activity, and permutation are all used. The E register is set equal to the STUV memory word used. ### EXAMPLES: | LAAMI | EXAMPLES: | | | | | | | |-------|-----------------------------------------------------------|--------------------------|--------------------------------------------------------------|-------------------------------------------------------------|--|--|--| | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>DESCRIPTION | COMMENT | | | | | 1. | EXA T | T <sub>j</sub> | [T <sub>j</sub> ] ==> A [A] ==> T <sub>j</sub> | ** | | | | | 2. | <sup>1</sup> EXA T <sub>j</sub> | T <sub>j</sub> | $R[T_{j}] ==> R(A)$ $R[A] ==> R(T_{j})$ | ** | | | | | 3. | ll <sub>EXA</sub> T <sub>j</sub> [F <sub>11</sub> ] = 140 | T <sub>j</sub> | $SR[T_{j}] ==> L(A)$ $R[T_{j}] ==> R(A)$ $R[A] ==> R(T_{j})$ | Sign extension occurs in A, but not in T <sub>j</sub> . ** | | | | | 4. | <sup>2</sup> EXA T <sub>j</sub> | T <sub>j</sub> | $L[T_{j}] ==> R(A)$ $R[A] ==> L(T_{j})$ | ** | | | | <sup>\*\*</sup> The two copy operations that perform an exchange take place simultaneously. Remember also that E is changed - it is set equal to the final contents of the STUV memory word. | 5. | <sup>5</sup> EXA T <sub>j</sub><br>[F <sub>5</sub> ] = 762 | <sup>T</sup> j<br>A | q3[T <sub>j</sub> ] ==> q1A<br>q1[A] ==> q3(T <sub>j</sub> ) | ** | |----|------------------------------------------------------------|------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------| | 6. | <sup>2</sup> EXA A | A (Before) A (After) | R[A] ==> L(A) | When "A" is used as the address section, EXA has the same affect as STA. No exchange is made, and there is no sign extension | | 7. | EXA {T <sub>k</sub> }* | $(\mathbf{T}_{\mathbf{k}})_{\mathbf{j}}$ | $[(T_k)_j] ==> A$ $[A] ==> (T_k)_j$ | Double indexing: $(\mathbf{T}_{k})_{j} = \mathbf{T} + [\mathbf{X}_{k}] + [\mathbf{X}_{j}]$ | \*\* Supernumerary Mnemonics for SKX. | $\alpha_{RSX_j}$ T $\alpha_{[T]} => X_j$ | |------------------------------------------| |------------------------------------------| RESET is a non-destructive copy from STUV memory into X memory. Subword form, Activity, and Permutation are used. The E register is set equal to the STUV memory word used. (Usually "T", but see example 7.) EXAMPLES: (Standard Configurations - Chart 7-2) | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>EXPLANATION | COMMENT | |-----|--------------------------------------------------------------|--------------------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | 1. | <sup>l</sup> rsx <sub>j</sub> T | T X | R[T] ==> X <sub>j</sub> [T] ==>E | ORSX would do the same. | | 2. | <sup>2</sup> rsx <sub>j</sub> T | T X X J | L[T] ==> X <sub>j</sub> [T] ==> E | $^{12}$ RSX would do the same. $[F_{12}] = 142$ | | 3. | <sup>3</sup> RSX <sub>j</sub> T | T x <sub>j</sub> | ql[T] ==> R(X <sub>j</sub> ) | The right half of $X_j$ is set from $T$ . The left nine bits are not changed. | | 4. | 13 <sub>RSX</sub> T [F <sub>13</sub> ] = 160 | T X | $ql[T] ==> R(X_j)$ $Sql(T) ==> L(X_j)$ $[T] ==> E$ | Sign of quarter 1 of T is extended throughout the left half of $X_j$ . The right half is set as above. $^{33}RSX$ would do the same. $[F_{33}] = 320$ | | 5. | <sup>21</sup> RSX <sub>j</sub> T<br>[F <sub>21</sub> ] = 230 | T x <sub>j</sub> | [T] ==> E | Nothing happens (other than changing E). | | 6. | $\alpha_{\text{RSX}_{j}}$ T $[F_{\alpha}] = 030$ | T x <sub>j</sub> | Sq4(T) ==> X<br>j<br>[T] ==> E | This time X <sub>j</sub> is cleared because of sign extension. | |----|--------------------------------------------------|------------------|--------------------------------------|---------------------------------------------------------------------------------------------------------| | 7. | $RSX_j^* \{T_k\}$ | T <sub>k</sub> | $R[T_{k}] ==> X_{j}$ $[T_{k}] ==> E$ | With a deferred address, RSX is indexable. Note that E is set from $\mathbf{T}_{\mathbf{k}}$ this time. | | 8. | α <sub>RSX<sub>O</sub></sub> Τ | 10 10 10 10 E | [T] ==> E | Nothing happens because X register 0 cannot be changed. [X <sub>0</sub> ] = 0 permanently. | | α <sub>DPX</sub> , Τ | α[x <sub>j</sub> ] ⇒ T | |----------------------|------------------------| |----------------------|------------------------| DEPOSIT is a non-destructive copy from X memory into STUV memory. Activity and Permutation are used. The X memory word is expanded to a full 36 bit subword by extending bit 2.9 (the X register sign bit) but only active quarters are used. (The subword form is immaterial.) The E register is set equal to the STUV memory $\underline{\text{used}}$ . (Usually "T", but see examples 8 and 10.) | EXAME | EXAMPLES: (Standard F Memory - Chart 7-2) | | | | | | | |-------|----------------------------------------------|--------------------------|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>EXPLANATION | COMMENT | | | | | 1. | <sup>l</sup> dpx <sub>j</sub> T | † † x <sub>j</sub> | $\left[X_{j}\right]\Rightarrow R(T)$ | Only the right half of T is changed. | | | | | 2. | <sup>2</sup> dpx <sub>j</sub> T | T x <sub>j</sub> | $\left[X_{j}\right]\Rightarrow L(T)$ | Only the left half of T is changed. | | | | | 3. | DPX <sub>j</sub> T | † † † † x <sub>j</sub> | $\begin{bmatrix} X_{j} \end{bmatrix} \Rightarrow R(T)$ $SX_{j} \Rightarrow L(T)$ | All of T is used. Note that DPX <sub>O</sub> T (or DPX T) is a handy clear instruction. ( $\begin{bmatrix} X_O \end{bmatrix} \equiv +0$ and cannot be changed.) | | | | | 4. | 3 <sub>DPX</sub> , T | T x, | $R[X_j] \Rightarrow ql(T)$ | Only quarter l of T is changed. | | | | | 5. | 16 <sub>DPX</sub> T [F <sub>16</sub> ] = 163 | T x <sub>j</sub> | $\mathbb{R}\left[X_{j}\right] \Rightarrow q^{4}(\mathbb{T})$ | Only quarter 4 is changed for only one path is active. | | | | | <sup>17</sup> DPX <sub>j</sub> T [F <sub>17</sub> ] = 202 | x <sub>j</sub> | $SX_{j} \Longrightarrow R(T)$ $[X_{j}] \Longrightarrow L(T)$ | All of T is affected. | |-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 21 <sub>DPX</sub> T [F <sub>21</sub> ] = 230 | T X | $SX_j \Longrightarrow L(T)$ | Surprisingly enough, this does do something. (See example 5, RSX.) | | ldpx <sub>j</sub> {T <sub>k</sub> }* | T <sub>k</sub> | $\begin{bmatrix} \mathbf{X}_{\mathbf{j}} \end{bmatrix} \Longrightarrow \mathbf{T}_{\mathbf{k}}$ $\begin{bmatrix} \mathbf{T}_{\mathbf{k}} \end{bmatrix} \Longrightarrow \mathbf{E}$ | Deposit is indexable with deferred addressing. | | 33 <sub>DPX</sub> , T [F <sub>33</sub> ] = 320 | † † x <sub>j</sub> | $SX_{j} \Longrightarrow Q3(T)$ $[X_{j}] \Longrightarrow Q1(T)$ | Note that bit 2.9 of X is used even though quarter 2 is not active. | | DPX 377720 | † † † † x <sub>j</sub> | $\begin{bmatrix} X_{j} \end{bmatrix} \Longrightarrow R(E)$ $SX_{j} \Longrightarrow L(E)$ | V memory, except the A, B, C, D, and E registers can not be changed by any instruction. Note that E is set to "what-would-have-gone-into-T." | | | [F <sub>17</sub> ] = 202<br><sup>21</sup> DPX <sub>j</sub> T<br>[F <sub>21</sub> ] = 230<br><sup>1</sup> DPX <sub>j</sub> {T <sub>k</sub> }* | 17 <sub>DPX</sub> T [F <sub>17</sub> ] = 202 21 <sub>DPX</sub> T [F <sub>21</sub> ] = 230 1 <sub>DPX</sub> (T <sub>k</sub> )* 1 <sub>DPX</sub> (T <sub>k</sub> )* 1 <sub>DPX</sub> T [F <sub>33</sub> ] = 320 1 <sub>DPX</sub> 377720 1 <sub>DPX</sub> 377720 1 <sub>DPX</sub> T T T T T T T T T T T T T T T T T T T | $[F_{17}] = 202$ $[X_{j}] \Rightarrow L(T)$ | $$\begin{bmatrix} \alpha_{\text{EXX}} & \mathbf{T} \\ & \end{bmatrix} \stackrel{\alpha}{=} \mathbf{T}$$ $$\begin{bmatrix} \alpha_{\text{[T]}} & ==> \mathbf{T} \\ & \alpha_{\text{[T]}} & ==> \mathbf{X}_{\mathbf{j}} \end{bmatrix}$$ EXX is a combination of RSX and DPX. Except for sign extension, it does just what its name implies - i.e. it will interchange words between X memory and STUV memory. Subword Form, Activity, and Permutation are used. The E register is set equal to the STUV memory word used. | EXAMI | EXAMPLES: (Standard F Memory - Chart 7-2.) | | | | | | |-------|----------------------------------------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------|---------------------------------------|--|--| | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>EXPLANATION | COMMENT | | | | 1. | l <sub>EXX</sub> , T | T t t x j | R[T] ==> X<br>[X j] ==> R(T)<br>[T] ==> E | | | | | 2. | <sup>2</sup> EXX <sub>j</sub> T | T X J | L[T] ==> X;<br>[X, ] ==> L(T)<br>[T] ==> E | | | | | 3. | EXX <sub>j</sub> T | ************************************** | R[T] ==> X<br>[X] ==> R(T)<br>S(X) ==> L(T)<br>[T] ==> E | Note that left half of T is cleared. | | | | 4. | 3 <sub>EXX</sub> , T | T X X j | ql[T] ==> R(X <sub>j</sub> ) R[X <sub>j</sub> ] ==> ql(T) [T] ==> E | Nine bit exchange. | | | | 5. | 16 <sub>EXX</sub> T [F <sub>16</sub> ] = 163 | T X | $R[X_{j}] ==> q^{\downarrow}(T)$ $q^{\downarrow}[T] ==> R(X_{j})$ $Sq^{\downarrow}(T) ==> L(X_{j})$ $[T] ==> E$ | Sign is extended in X j but not in T. | | | | 6. | <sup>17</sup> EXX <sub>j</sub> T<br>[F <sub>17</sub> ] = 202 | x <sub>j</sub> | $\begin{bmatrix} X_{j} \end{bmatrix} ==> L(T)$ $L[T] ==> X_{j}$ $S(X_{j}) ==> R(T)$ $\begin{bmatrix} T \end{bmatrix} ==> E$ | Sign of X, is extended into the right half of T. | |-----|--------------------------------------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7. | <sup>21</sup> EXX <sub>j</sub> T [F <sub>21</sub> ] = 230 | T x <sub>j</sub> | $S(X_{j}) ==> L(T)$ $[T] ==> E$ | Same as <sup>21</sup> DPX <sub>j</sub> T. | | 8. | 1 <sub>EXX</sub> (T <sub>k</sub> )* | T <sub>k</sub> | $R[T_{k}] ==> X_{j}$ $[X_{j}] ==> R(T_{k})$ $[T_{k}] ==> E$ | EXX is indexable if a deferred address is used. | | 9. | <sup>33</sup> EXX <sub>j</sub> T<br>[F <sub>33</sub> ] = 320 | T X X Y | $Sql[T] ==> L(X_{j})$ $ql[T] ==> R(X_{j})$ $R[X_{j}] ==> ql(T)$ $S(X_{j}) ==> q3(T)$ $[T] ==> E$ | Note that bit 2.9 is used for sign extension (not 1.9). | | 10. | <sup>1</sup> EXX <sub>j</sub> 377720 | TSS X <sub>j</sub> | $R[377720] ==> X_{j}$ $[X_{j}] ==> R(E)$ $L[377720] ==> L(E)$ | Same as <sup>1</sup> RSX <sub>j</sub> 377720. (Tog-<br>gle registers must be changed<br>by hand. Note that E is set<br>to what would have gone into<br>T.) | | α <sub>AUX</sub> τ | $[X_j] + \alpha[T] ==>X_j$ | |--------------------|----------------------------| |--------------------|----------------------------| AUX forms an 18 bit ring sum in $X_j$ . There is no overflow detection. All of $X_j$ is affected. STUV memory is not affected. Activity and permutation are used. Sign extension applies to the operand taken from STUV memory. If quarters 1 and 2 are active, subword form is immaterial. If one quarter of the STUV memory operand is inactive (as in standard configuration #3, for example), +0 is used for that quarter. The E register is set equal to the STUV memory word. (This is "T" except when a deferred address is used. See example 6.) | EXAM | EXAMPLES: (Standard F Memory - Chart 7-2.) | | | | | | |------|--------------------------------------------------|--------------------------|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--|--| | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>EXPLANATION | COMMENT | | | | 1. | l <sub>AUX</sub> T | T X j | [X <sub>j</sub> ] + R[T] ==> X <sub>j</sub> [T] ==> E | Standard configurations #0, 11, 20, and 30 would do the same. $[F_{11} = 140 [F_{20}] = 200 [F_{30}] = 600$ | | | | 2. | <sup>2</sup> AUX <sub>j</sub> T | T X | [X <sub>j</sub> ] + L[T] ==> X <sub>j</sub> [T] ==> E | Standard configuration #12 would do the same. [F <sub>12</sub> ] = 142 | | | | 3. | 13 <sub>AUX</sub> T [F <sub>13</sub> ] = 160 | T X <sub>j</sub> | [X <sub>j</sub> ] + ql[T] <sub>SE</sub> ==> X <sub>j</sub> [T] ==> E | Standard configuration #33 would do the same (but NOT #3!) (See note on next page.) [F33] = 320 | | | | 4. | $\alpha_{\text{AUX}_{j}}$ T $[F_{\alpha}] = 220$ | T X | [X <sub>j</sub> ] + q2[T] <sub>SE</sub> ==> X <sub>j</sub> [T] ==> E | This has sign extension to the right. (There is no suitable standard configuration.) | | | | 5. | <sup>21</sup> AUX <sub>j</sub> T | T x <sub>j</sub> | [X <sub>j</sub> ] + (+0) ==> X <sub>j</sub> [T] ==> E | Register T is ignored, and X <sub>j</sub> is not changed. Except for E, this instruction is innocuous. | |----|--------------------------------------|------------------|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------| | 6. | laux <sub>j</sub> {T <sub>k</sub> }* | T <sub>k</sub> | $ [X_{j}] + R[T_{k}] ==> X_{j} $ $ [T_{k}] ==> E $ | Same as example 1, but indexed via a deferred address. | NOTE: E is cleared and then loaded as if by $\alpha_{LDE}$ . The sum of R[E] and [X] then goes into X (circuitously) and E is set equal to the STUV register used (ie.[T] or $[T_k]$ if a deferred address was used). X is always set. Note - If either quarter 1 or 2 is not part of an active subword, (as, for example, with standard configuration #3) one operand of the sum is not completely specified and +0 will be used as that part of the operand. | α <sub>ADX</sub> Τ | $[X_j] + \alpha[T] ==> T$ | |--------------------|---------------------------| |--------------------|---------------------------| ADX forms an 18 bit ring sum usually in STUV memory although only the active quarters are stored. There is no overflow detection. The operands are always 18 bit words - one from X memory the other from STUV memory. A configuration should be chosen such that the word from STUV memory has both quarters active, or is an extended 9 bit subword. If only one quarter is active, the inactive quarter of the operand is set to +0. Activity and Permutation are used. Only active quarters are stored, but sign extension applies to the operand taken from STUV memory. The E register is set equal to the STUV memory word used. (This is "T" except when a defer is involved. See example 6.) EXAMPLES: (Standard F Memory - Chart 7-2) | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>EXPLANATION | COMMENT | |-----|--------------------------------------------------------------|--------------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------| | 1. | <sup>1</sup> ADX <sub>j</sub> T | T x <sub>j</sub> | [X <sub>j</sub> ] + R[T] ==> RT [T] ==> E | Left half of T is not changed. The sum is standard 18 bit ring sum, also called "ones complement sum." | | 2. | <sup>2</sup> ADX <sub>j</sub> T | T x <sub>j</sub> | [X <sub>j</sub> ] + L[T] ==> LT [T] ==> E | Right half of T is not changed. | | 3. | <sup>13</sup> ADX <sub>j</sub> T<br>[F <sub>13</sub> ] = 160 | T x <sub>j</sub> | $[X_{j}] + ql[T]_{SE} ==> ql(T)$ $[T] ==> E$ | This gives a 9 bit ring sum. Configuration 33 would do the same, #3 would not. See note next page. The subword length should be 18 bits. | NOTE: In example 3, the 9 bit result is an honest 9 bit ring sum only when X contains an extended 9 bit word. (See RSX, example 4.) ADX cannot be used to add a 9 bit word to an 18 bit word. Use AUX. | 4. | $\alpha_{ADX_j}$ T $[F_{\alpha}] = 220$ | 1 | T | $[X_j] + q2[T]_{SE} ==> q2(T)$ $[T] ==> E$ | Essentially the same as example 3 except that the <u>left</u> half of X is significant. $[F_{\alpha}]$ illustrated is 220. There is no suitable standard configuration. | |----|----------------------------------------------|----|---------------------|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5. | 21 <sub>ADX</sub> T [F <sub>21</sub> ] = 230 | 11 | T<br>X <sub>j</sub> | [T] ==> E | "Nothing" is done here because quarters 1 and 2 are both inactive. | | 6. | ladx <sub>j</sub> {T <sub>k</sub> }* | | T <sub>k</sub> | $ [X_j] + R[T_k] ==> RT_k $ $ [T_k] ==> E $ | Same as example 1, but indexed via deferred indexing. | NOTE: E is cleared and then loaded as if by $^{\alpha}$ LDE. The sum of R[E] and [X $_{\rm j}$ ] then goes into E and an $^{\alpha}$ STE is performed. Inactive quarters of the STUV memory word therefore remain unchanged. If either quarter 1 or 2 is not part of an active subword (as, for example, with standard configuration #3), one operand of the sum is not fully specified and +0 is used to fill out the operand. α<sub>SKX</sub>, Τ SKX (or REX, or SEX) provides 32 combinations of setting, adding, comparing, skipping, flag raising, and dismissing - all relating to X memory and without changing the AE or the E register. (See examples below.) F memory is not used. The configuration syllable specifies the desired combination. (Examples 1 - 8 show the use of bits 4.6, 5, 4 and examples 10 - 12 illustrate bits 4.8 and 4.7.) "T", the address syllable, (or the final deferred address) is used as an OPERAND. ### EXAMPLES: | EXAMPLES: | | | | | | |-----------|---------------------------------|-----------------------------------------------|-------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | NO. | INSTRUCTION | MNEMONIC<br>ABBREVIATION<br>(See Chart 7-3) | ABBREVIATED<br>DESCRIPTION | COMMENT | | | 1. | <sup>O</sup> skx <sub>j</sub> T | SKX T<br>REX T<br>SEX T<br>(Set) | T ==> X <sub>j</sub> | "T" is the operand, not its location. The brackets []. were left out on purpose. | | | 2. | lskx <sub>j</sub> T | (Set negative) | -Т ==> X <sub>j</sub> | "Minus" T - i.e. its ones complement is used to set | | | 3. | <sup>2</sup> skx <sub>j</sub> T | INX <sub>j</sub> T<br>(Increase) | [X <sub>j</sub> ] + T ==> X <sub>j</sub> | If the sum is zero, it will be -0 (all ones) unless [X] was initially +0. | | | 4. | 3 <sub>SKX</sub> , T | DEX T (Decrease) | [X <sub>j</sub> ] + (-T) ==> X <sub>j</sub> | "-T" is added to $[X_j]$ . Zero is -0. It cannot be +0. | | | 5. | <sup>4</sup> skx <sub>j</sub> T | SXD <sub>j</sub> T<br>(Skip if X<br>differs.) | If [X <sub>j</sub> ] \( \) T Skip - (i.e. \( #+2 ==> P \) | Skip if $[X_j]$ differs from T. Note: $(+0) = (-0)$ and if $[X_j]$ is initially $(+0)$ , it is changed to $(-0)$ . | | | 6. | <sup>5</sup> skx <sub>j</sub> T | (Skip if X differs from negative.) | If [X <sub>j</sub> ] \( \neq -T\) Skip - (i.e. \( \#+2 ==> P \) | Skip if $[X_j]$ differs from<br>-T. Note: $(-0) = (+0)$ and<br>if $[X_j]$ is initially $(-0)$ ,<br>it is changed to $+0$ . | | | 7. | <sup>6</sup> skx <sub>j</sub> t | SXL, T<br>(Skip if X<br>is less.) | If [X <sub>j</sub> ] < T Skip - (i.e. #+2 ==> P) | Skip if [X <sub>j</sub> ] is less than T and if [X <sub>j</sub> ] -T does not overflow. (Skip range: T-377777 to T) Note: If [X <sub>j</sub> ] is initially (+0), it is changed to (-0). | | | | | | | 12 | |-----|-------------------------------------|-----------------------------------------------------------------------------------|------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8. | <sup>7</sup> skx <sub>j</sub> T | SXG <sub>j</sub> T<br>(Skip if X<br>is greater.) | <pre>If [X<sub>j</sub>] &gt; -T Skip i.e. #+2 ==&gt; P</pre> | Skip if [X <sub>j</sub> ] is greater than -T and if [X <sub>j</sub> ] + T does not overflow. (Skip range: -T to 377777-T) Note: If [X <sub>j</sub> ] is initially (-0), it is changed to (+0). | | 9. | skx <sub>j</sub> {T <sub>k</sub> }* | $\operatorname{rex}_{\mathtt{j}} \left\{ \mathtt{T}_{\mathtt{k}} \right\}^{m{*}}$ | $T+[X_k] \implies X_j$ | [X <sub>j</sub> ] is set equal to $T_k$ . e.g.<br>a) $SKX_j$ $\{O_k\}^* \equiv set X_j$<br>$from X_k$ .<br>b) $^1SKX_j$ $\{O_j\}^* \equiv Comple-ment X_j$ . | | 10. | lo <sub>skx</sub> , T | RXF, T<br>(Reset and<br>raise flag.) | T ==> X <sub>j</sub><br>1 ==> Flag <sub>j</sub> | For $j = 1$ to $37_8$ , RXF is the same as ${}^{\circ}$ SKX for there are no flags for these numbers. Note that flag zero <u>can</u> be raised. | | 11. | <sup>20</sup> SKX <sub>j</sub> T | RXD, T (Reset and Dismiss.) (See note 3) | T ==> X<br>j<br>DISMISS | See Chapter 4 for the ramifications of "DISMISS." If j = the current sequence number, "T" is nearly immaterial for the subsequent change of sequence will change Xj. | | 12. | 30 <sub>SKX</sub> , T | RFD, T<br>(Reset, Raise<br>flag, and Dis-<br>miss.) | T ==> X<br>l ==> Flag<br>DISMISS | This is used to change sequence number - often in the form - 30 SKX, #+1. It is ignored if j = current sequence number. | Notes: 1. "Skip" means "omit the next instruction." i.e. "Go to #+2." - 2. The configuration syllable is united with the rest of the instruction. It may be given redundantly. e.g. DEX is the same as $^3$ SKX or $^1$ INX or $^3$ DEX. - 3. The hold bit cancels DISMISS. (h $^{20}$ SKX is the same as SKX alone.) - 4. RXF cannot be used as a Jump. Index register "j" is indeed set, but it will not be copied into the P register, unless a change of sequence number occurs. (See Chapter 4.) <sup>n</sup>JPX<sub>j</sub> T JPX and JNX are "Loop-closing", "Index-sensing" jump instructions. Their operation is as follows: Note: - 1. If the sum is zero, it is -0. - 2. "n" is a signed integer: -17 to + 178. - 3. F Memory is not used. - 4. A deferred address determines where to jump to, but not if, and the second index register is not modified. EXAMPLES: 1. Straight Table Scan (100 register table located at "TABL.") b.) JNX $Start \rightarrow {}^{1}SKX_{j} 77$ $Loop \rightarrow LDA (TABL + 77)_{j}$ $h^{+1} JNX_{j} Loop$ This program scans the table "backward through the manuscript." (i.e., highest memory location first.) Note: X is initially set to + (n-1). This program scans "forward through the manuscript." (i.e., lowest memory location first.) Note: X, is initially set to - (n-1). # 2. To scan every nth table register a) START $$\rightarrow$$ REX<sub>j</sub> (TL - n) b) START $\rightarrow$ <sup>1</sup>REX<sub>j</sub> (TL - n) LDA<sub>j</sub> TABL + TL - n h<sup>-n</sup> JPX<sub>j</sub> #-1 These programs run for $(\frac{TL}{n})$ iterations if we assume that TL (Table Length) is an integer multiple of n. As written, they scan the first register of each block of n registers. To scan register "i" of each block, the LDA instruction could be written LDA (TABL + i) for example "a" (JPX) and LDA (TABL + i + TL - n) for example "b" (JNX). ### 3. Interlaced Table Scan Scope flicker can be reduced by an interlaced table scan. The fact that the change in $X_j$ is made <u>after</u> the jump decision causes a somewhat peculiar parameter configuration, but the program logic is essentially the same as above. For example, if "C" is the interlace, "TL" is the Table Length, and if "C" is not a factor of "TL," the program below scans the whole table with an interlace of C. (If "C" is a factor of TL, the program degenerates to example C.) If C = 3, and TL = 7, the table is scanned in the following order: 6, 3, 0, 4, 1, 5, 2, 6, 3, 0, etc. - NOTE: 1. "Zero" used as an address (as above) is always +0. - 2. M4 automatically puts a hold bit on JPX and JNX to cancel the automatic dismiss (see Chapter 4 and Chapter 6). - 3. The address of a deferred JNX or JPX is completely determined before the index register is changed. Therefore a $^{-1}$ JPX a a S would jump to S as defined by the original contents of $X_a$ if it jumps at all. 3-2.3 JUMP SKIP CLASS JMP JPA JNA JOV SKM SED August 1963 α<sub>JMP</sub> Τ<sub>j</sub> JMP is an unconditional transfer of control. It means go to T (or $T_j$ ) for the next set of instructions. The configuration syllable " $\alpha$ " does not refer to F memory but is used directly to provide 32 variations of JMP as illustrated below: EXAMPLES: (See #10.) | EXAMPLES: (See #10.) | | | | | |----------------------|---------------------------------|--------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------| | NO. | INSTRUCTION | SUPERNUMERARY<br>MNEMONIC | JUMPS<br>TO | COMMENT | | 1. | O <sub>JMP</sub> T <sub>j</sub> | JMP T | T | $X_{\mathbf{j}}$ is ignored. | | 2. | ljmp T <sub>j</sub> | BRC T,<br>(Branch) | Тj | Indexable Jump $\equiv$ BRANCH | | 3. | <sup>2</sup> JMP T <sub>j</sub> | JPS T;<br>(Jump and Save) | T | Jump and save return point (#+1) in the specified index register (X;). | | 4. | 3 <sub>JMP</sub> T <sub>j</sub> | BRS T <sub>j</sub> (Branch and Save) | <sup>T</sup> j | Branch and save. X, is used to evaluate the jump destination T, and is then reset to the return point (#+1). | | 5. | <sup>4</sup> JMP T <sub>j</sub> | - | Т | X, is ignored, #+1 is saved in R(E) | | 6. | <sup>5</sup> JMP T <sub>j</sub> | <sup>4</sup> BRC T <sub>j</sub> | Тj | Return point (#+1) is saved in R(E) | | 7. | 6 <sub>JMP</sub> T <sub>j</sub> | <sup>4</sup> JPS T <sub>j</sub> | Т | Return point ( $\#$ +1) is saved in R(E) and also in $X_j$ . | <sup>+</sup> In M4 terminology, the symbol "#" is an abbreviation for the location of the current instruction. (See Chapter 6.) | | TOTAL CONTRACTOR OF THE PARTY O | | | | |-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8. | 7 <sub>JMP</sub> T <sub>j</sub> | <sup>4</sup> brs T <sub>j</sub> | Тj | $X_j$ is used to determine the jump destination $T_j$ and is then reset to the return point (#+1). The return point is saved in $R(E)$ as well. | | 9. | 10 <sub>JMP</sub> T <sub>j</sub> | - | Т | The memory location of the last data reference is saved in L(E). (i.e. the contents of the Q register) | | 10. | <sup>14</sup> JMP T | JPQ I | Т | Jump, save "p" (i.e. #+1) and "q" (location of last data reference). This is the recommended jump, for the information saved is often of use in checkout. | | 11. | <sup>15</sup> JMP T <sub>j</sub> | BPQ I | Тj | This instruction is the same as JPQ except that the jump destination is indexed. | | 12. | <sup>16</sup> JMP T <sub>j</sub> | JES T | T | Jump, save in E, and in $X_j$ . | | 13. | 20 <sub>JMP</sub> T <sub>j</sub> | JPD T <sub>j</sub> | T | Jump, Dismiss. | | 14. | <sup>21</sup> JMP T <sub>j</sub> | BRD T | Tj | Branch, Dismiss. | | 15. | 22 <sub>JMP</sub> I <sub>j</sub> | JDS T | Т | Jump, Dismiss, Save in Xj. | | 16. | <sup>23</sup> JMP T <sub>j</sub> | BDS Tj | Тj | Branch, Dismiss, Save in X <sub>j</sub> . | | | | | | | Jump and save return point (#+1) in the specified index register ( $X_j$ ). NOTE: A superscript numeral can be used redundantly on supernumerary mnemonics. For example: $^{16}$ JMP $\equiv$ $^{16}$ JES $\equiv$ JES $\equiv$ $^{2}$ JPQ $\equiv$ $^{14}$ JPS etc. (M4 "unites" them into the word.) JPA - Jump on Positive Accumulator JNA - Jump on Negative Accumulator JOV - Jump on Overflow α<sub>JPA</sub> T<sub>j</sub> α<sub>JNA</sub> T<sub>j</sub> α<sub>JOV</sub> T<sub>j</sub> The conditional jumps go to $T_j$ if the conditions are satisfied by any active subword. Permutation is ignored. The return point (#+1) is saved in E if the jump takes place. The accumulator and overflow flip-flops are not changed. Note that these conditional jumps are indexable. ### EXAMPLES: ### #1. A Four-way Switch: JOV OF \*\* Goes to OF if overflow exists $(Z_{\downarrow} = 1)$ JNA N1 \*\* Goes to N1 if A is negative. JPA P1 \*\* Goes to P1 if A is positive. \*\* Continues if A is zero. ### #2. Overflow: $^{30} \text{JOV T}_{j}$ is equivalent to $^{37} \text{JOV T}_{j},$ for both configurations specify the same active subwords. If any of the four overflow flip-flops are set to 1, control will go to T<sub>i</sub>. The overflow indicators (Z<sub>4</sub>,Z<sub>3</sub>,Z<sub>2</sub>,Z<sub>1</sub>) are not cleared by JOV. Active subwords use the overflow indicator associated with the sign quarter, e.g. $Z_2$ is associated with the right half word, $Z_4$ with the left half word. ## #3. To Detect Minus Zero in an Index Register: (JNX, T or JPX, T will not jump on either + or - zero.) # #4. 18 Bit Zeros Again: "Skip-on-a-bit" uses a one bit operand. It has 32 variations - some with M4 Supernumerary Mnemonics. The basic variations are as follows: The bit in question is identified by its quarter number and bit number as diagrammed below: The meta bit is No. 10 (dec.). (SKM is the <u>only</u> instruction that can affect it.) The parity bit is No. 11 (dec.). The parity circuit is No. 12 (dec.). (Any quarter number will do for the parity and meta bits.) Bits and quarters are numbered from right to left and should be in subscript when used with SKM. (See chapter 6, page 6-7.) The bit designation goes in the "j bits" (3.6 - 3.1), as follows: SKM is therefore non-indexable except through deferred addressing. If a non-existent bit is selected, e.g. bit 0.0,1.0,2.0,3.0 for example, Unconditional Skips (SKU) and Rotate (CYR) will still work, but "makes" will do nothing, and conditional skips will not skip. # SUPERNUMERARY MNEMONICS (See Chart 7-3) MKC - 1SKM - Make complement MKZ - 2SKM - Make zero MKN - 3SKM - Make one SKU - 10 SKM - Skip unconditionally, (go to #+2) SUC - 11 SKM - Skip and complement SUZ - <sup>12</sup>SKM - Skip and make zero SUN - 13 SKM - Skip and make one SKZ - <sup>20</sup>SKM - Skip if bit =0 SZC - <sup>21</sup>SKM - Skip on zero and complement SZZ - <sup>22</sup>SKM - Skip on zero and make zero $SZN - {}^{23}SKM - Skip on zero and make one$ SKN - <sup>30</sup>SKM - Skip on one SNC - 31 SKM - Skip on one and complement $SNZ - \frac{32}{SKM} - Skip on one and make zero$ SNN - 33SKM - Skip on one and make one CYR - 4SKM - Cycle memory once to the right (rotate) MCR - 5SKM - Make complement and rotate MZR - 6SKM - Make zero and rotate MNR - 7SKM - Make one and rotate SNR - 34SKM - Skip on one and rotate SZR - 24SKM - Skip on zero and rotate SUR - 14SKM - Skip and rotate NOTE: "Skip" is first, "make" next, and "rotate" last. $^{4}$ SZZ $\equiv$ $^{26}$ SKM $\equiv$ Skip on zero, make zero, and then rotate. ### EXAMPLES: 1. To copy a bit: $$\begin{array}{c} \text{SKZ } \mathbb{Q}_{2\cdot3} \\ \text{SUN } \mathbb{T}_{1\cdot1} \\ \text{MKZ } \mathbb{T}_{1\cdot1} \end{array} \right\} \qquad \begin{array}{c} \text{Sets bit } \mathbb{T}_{1\cdot1} \\ \text{equal to} \\ \text{bit } \mathbb{Q}_{2\cdot3} \end{array}$$ 2. To clear n metabits starting at T $$\operatorname{Rex}_{\alpha}$$ (n-1) $\operatorname{MKZ}_{4.10}|_{\alpha}^{\mathrm{T}}$ \*\* i.e. $\operatorname{MKZ}_{4.10}^{\mathrm{T}}_{\alpha}$ }\* $\operatorname{^{-1}JPX}_{\alpha}$ #-1 | 1 881) 11 | α <sub>SED</sub> T <sub>j</sub> | Only P can<br>be changed. | |-----------|---------------------------------|---------------------------| |-----------|---------------------------------|---------------------------| SED compares all active quarters of E and $T_j$ according to the given permutation. If any difference exists the next instruction is skipped over. No registers other than P (the central Program Counter) can be changed. (E is not changed.) Subword Form is immaterial. EXAMPLES: (Standard F Memory - Chart 7-2.) | NO. | INSTRUCTION | DIAGRAM | COMMENT | |-----|---------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1. | SED T <sub>j</sub> | TE | #+2 ⇒ P if E differs from T,<br>#+1 => P if they are identical | | 2. | <sup>2</sup> sed T <sub>j</sub> | T <sub>j</sub> | The left half of $T_j$ is compared to the right half of $E$ . ( $^{12}SED$ is identical.) $[F_{12}] = 142$ . | | 3. | <sup>22</sup> sed e | E E | The right and left halves of E are compared. <sup>17</sup> SED E, <sup>2</sup> SED E, <sup>12</sup> SED E, or <sup>22</sup> SED E would have an identical result. | 3-2.4 SCALE, NORMALIZE, CYCLE SCA SCB SAB NOA NAB CYA CYB CAB 3-37 $$\alpha_{\text{SCA T}_{j}}$$ $\alpha_{[A] \times 2}^{\alpha_{[T_{j}]}} => A$ "SCALE" multiplies each active subword by "a power of 2," i.e. by $2^n$ where n is a signed integer specified in $T_j$ . Each active subword can be scaled a different amount. The D register is used to count the binary shifts. The details are as follows: - a) An $\alpha$ LDD $T_j$ is performed (with permutation and sign extension as called for). - b) Each active subword (of A or AB) is scaled according to its <u>sign quarter in D</u>, and these sign quarters are left set to -0. - c) If an overflow exists for an active subword, the proper result is recovered by complementing the sign digit after the first shift, and the indicator is cleared. This rule is used for all operands left (+), right (\_), and zero. Overflow can not affect SCB. Notice that SCALE amounts to shifting all the bits except the sign left or right and filling the vacant positions with copies of the sign bit (i.e. with ±0). SCALE senses overflow and corrects the sign bit if necessary. SCA and SAB always <u>clear</u> the overflow flip-flop - even if bits are lost off the left end. SCALE never sets the overflow flip-flop. EXAMPLES: (SCB is illustrated to avoid overflow complications.) | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>DESCRIPTION | COMMENT | |-----|--------------------------------------------|--------------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------| | 1. | SCB{-4,} | {-4,} | [B] $\times 2^{-\frac{1}{4}} ==> B$<br>$-0 ==> q^{\frac{1}{4}}(D)$<br>$q_{3,2,1}[T_{j}] ==> q_{3,2}(D)$ | {-4,} is a M4 convention<br>for A register with -4<br>in quarter 4. See Chap-<br>ter 6, page 6-7 and 6-10. | | 2. | <sup>30</sup> SCB {N}<br>N = 2775003000(8) | (N) | $q4[B] \times 2^2 ==> q4(B)$<br>$q3[B] \times 2^{-2} ==> q3(B)$<br>$q2[B] \times 2^3 ==> q2(B)$<br>-0 ==> D | Quarter 1 of B is not changed. The sign bits are never changed. Bits may be lost off either end without any alarm. | | 3. | <sup>2</sup> SCB (N)<br>N = 2775003000(8) | [N] | $R[B] \times 2^2 ==> R(B)$<br>-0 ==> q2(D)<br>775 ==> q1(D) | The <u>left</u> halves of B and D are not changed. Note that q4 of {N} specifies the argument of the scale operation. | Note: Scale can of course be indexed - e.g. SCA T, where the argument comes from T;. It is more common programming practice to use an RC word - e.g. SCA(-1,). ## 4. Overflow: (SCA and SAB) a) To "recover an overflow": LDA {200 000 000 000} ADD {200 000 000 000} SCA {-3,} \*\*-3, $\equiv$ 774 000 000 000. After the scale, Acc. will be 040 000 000 000 and $\rm Z_4$ will be "0". $\rm Z_3, Z_2, Z_1$ are not sensed nor changed. (Any negative argument will suffice.) b) Only active subwords are processed: LDA {200 300 400 100} 30 ADD {200 300 400 300} \*\*Acc. will be 400 600 001 400. \*\*All four Z flip-flops will be "l". <sup>21</sup>sca {774 774 774 774} \*\*Only L(A) is scaled. Acc. will become 040 060 001 400. $Z_4$ will become "0", $Z_3, Z_2, Z_1$ will remain "1". 1<sub>SCA</sub> {774 774 774 774} \*\*Only R(A) is changed. Acc. becomes 040 060 700 140 and $Z_2$ becomes "0". $Z_3$ and $Z_1$ are still "1". Note that $Z_4, Z_3, Z_2, Z_1$ are <u>overflow indicators</u>. They tell whether overflow has occurred. An overflow resulting from negative numbers (as in q2 above) is <u>not</u> treated any differently. ## 5. Subword forms for the AB register: | a) | "36" | S | А | | В | |----|-----------|--------------|------------------|---------------|---------------| | b) | "18 - 18" | S L(A) | L(B) | S R(A) | R(B) | | c) | "27-9" | s q432(A | .) | q432(B) | S ql(A) ql(B) | | a) | "9-9-9" | S q4(A) q4(E | s) s q3(A) q3(B) | S q2(A) q2(B) | S ql(A) ql(B) | Note that all of B is part of the subword. There is only one sign bit in an AB subword. $$\alpha_{\text{NOA T}_{j}} \qquad \alpha_{\text{[A] x 2}^{\text{nz}}} ==> A$$ $$\alpha_{\text{[T}_{j}]} - \text{nz} ==> \text{Sq(D)}$$ NORMALIZE scales just enough to remove leading zeros or to "recover" from OVERFLOW. It clears the active overflow indicators. The number of leading zeros (nz) is subtracted from the argument from $\mathbf{T}_{\mathbf{j}}$ ( $^{\alpha}[\mathbf{T}_{\mathbf{j}}]$ ) and this difference is left in the Sign Quarter of D. If an overflow condition exists at the start, "nz" is -1, the scale is one place to the right, and the sign is complemented - just as for SCA or SAB. If nz is zero, it is +0. (See Note 4 also.) NOA and NAB start with an $^{\alpha}$ LDD T<sub>j</sub>. "nz" is subtracted from the sign quarter(s) and the rest of D is not changed. The E register becomes a copy of T<sub>j</sub>. EXAMPLES: † (Assume that NO OVERFLOW exists.) | | EAAMPILED: (Assume that no overland extracts.) | | | | | | | |--------------------|------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | NO. INSTR | UCTION | DIAGRAM | ABBREVIATED<br>DESCRIPTION | COMMENTS | | | | | l. NOA | (0) | (+0) | [A] x 2 <sup>nz</sup> ==> A<br>-nz ==> q4(D)<br>+0 ==> q3,2,1(D) | "nz" is the number of leading "zeros" in the original contents of A. ("Zeros" can be positive zeros or negative zeros.) | | | | | 2. <sup>2</sup> NO | A{0} | {+0} | R[A] x 2 <sup>nz</sup> ==> R(A) -nz ==> q2(D) +0 ==> q1(D) | The left halves of A and D are not changed. "nz" is the number of "zero" in the original contents of the right half of A. Note that the result in D is a nine bit numeral. | | | | | 3. N = | OA{N} a,b,,c,d 7] = 202 | [N] | $R[A] \times 2^{ZR} ==> R(A)$ $a-ZR ==> q2(D)$ $b ==> q1(D)$ $L[A] \times 2^{ZL} ==> L(A)$ $c-ZL ==> q4(D)$ $d ==> q3(D)$ | "ZR" and "ZL" are the leading zeros of the right and left 18 bit words of A. {N} is a register containing a,b,c, and d in quarters 4,3,2, and 1. | | | | †† Brackets[] are used in the TX-2 M4 Assembly Program to indicate "Register Containing". See Chapter 6, page 6-10. ### 5 - A sample program → Evaluate V = xyz This product could have 105 significant bits (3 word lengths). One must resort to programmed arithmetic to get them all, but normalize can be used to get the 34 most significant bits. Consider the programs below. | T.T: +hon+ | Normalize: | |------------|-------------| | MICHORP | MOTIMATIZE. | | LDA | X | | | | | | |-----|---|--|--|--|--|--| | MUL | Y | | | | | | | MUL | Z | | | | | | | | | | | | | | This program puts the 35 left bits of the 105 bit product in A and essentially worthless numerals in B. The answer in A may be too small by 1 (in the 35th place). ### With Normalize: LDA X MUL Y NAB {0} STD T MUL Z SAB T With normalize, the product is given in AB, to 35+nz places from the sign. (It may low by 1 in the (35+nz)th place.) "nz", the number of zeros, is in T (in negative form). nz could be as much as 69 so the last SAB may not be desired. For example, if the NAB instruction above were replaced with NAB{34.,} the answer in AB can be considered a 71 bit integer. - NOTE: 1. NOA and NAB leave E set the same as the memory register used. - 2. If overflow exists, "nz" is -1 so [T,]+1 ==> Sq(D). - 3. NAB is essentially the same instruction using the double length word (AB) instead. (See page 3-39 "Subword forms for the AB register".) - 4. Normalize is an arithmetic instruction. The sign bit is not counted. "Leading zeros" will, of course, be plus or minus zeros - i.e., the same as the sign. α<sub>CYA</sub> Τ<sub>j</sub> CYCLE logically falls in a class with LDA and STA, for it is most easily considered as a bit shifting instruction and the sign bit has no special significance. Bits shifted off one end are inserted at the other. None are lost. However, since the practical details of its use are so similar to SCALE, it is usually grouped with SCALE and NORMALIZE. The use of the memory word is the same as SCALE. - a.) An $\alpha_{\text{LDD T}_j}$ is the first step. - b.) Each active subword is "cycled" or "rotated" according to its Sign Quarter in D and the sign quarter is left at -0. For cycle, the active subword has its ends connected and can be considered as a ring of bits. If the number of places equals the subword length, the instruction does not change the subword. You can therefore arrive at any new position by cycling either way the short way takes less computer time. The sign bit is handled no differently than the others and no bits are lost. - c.) Overflow is ignored. - d.) The E register becomes a copy of the memory register used. EXAMPLES: Assume [A] = 123 456 765 432(8) at the start | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>DESCRITPION | COMMENT | |-----|---------------------------------|--------------------------|------------------------------------------------------------------|---------------------------------------------------------------------------------------------| | 1. | CYA(+1,) | (+1,) | 247 135 753 064 ==> A<br>-0 ==> q4(D)<br>+0 ==> q3,2,1(D) | One 36 bit ring cycled once to the left. | | 2. | 30 <sub>CYA{N}</sub> N=1,1,,1,1 | D D | 246 ==> q4(A)<br>135 ==> q3(A)<br>753 ==> q2(A)<br>065 ==> q1(A) | The four quarters are cycled separately i.e. four nine-bit rings, each one bit to the left. | Assume $[A] = 123 456 765 432_{(8)}$ at the start. | | | (0) | | | |----|-------------------------|--------|-----------------------|---------------------------------------| | | | | | The left halves of | | | | {-3, } | | A and D are not | | | | | 276 543 ==> R(A) | changed. The right | | 3. | <sup>2</sup> CYA{-3, } | | | half of A (a ring | | | | D | -O ==> R(D) | of 18 bits) is cycled | | | | | | 3 places to the right. | | | | | | i.e. one octal place.) | | | | | | | | | | | 234 567 654 320 ==> A | The 72 bit ring -AB- | | | | | 000 000 000 001 ==> B | is cycled 3 bits, | | | DDV D | [N] | 000 000 000 001 ==> 1 | i.e. one octal place | | 4. | DPX B | | -O ==> q4(D) | to the left. | | 4. | CAB{+3,}<br>N=3,2,,5,-6 | * * * | +2 ==> q3(D) | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | | N=3,2,,,,=0 | D | +5 ==> q2(D) | | | | | | 1)> qz(D) | | | | | | -6 ==> ql(D) | | | | | | | | NOTES: 1. The E register becomes a copy of the memory word used. - 2. CYA, CYB, CAB are indexable, and, of course, deferred addressing can also be used. (Neither of these is common. Most users use RC words.) - 3. CAB uses the same word structure as SAB and NAB. # 3-2.5 LOGIC, INSERT, COMPLEMENT/PERMUTE ITA ITE UNA DSA INS COM August 1963 3-45 $$\alpha_{\text{ITA T}_{j}} \alpha_{\text{[T}_{j}]} \wedge [A] ==> A$$ For these instructions, the word is considered as a string of independent bits - each bit column is a separate entity. For ITA, UNA, and DSA, the argument $\alpha[T_j]$ , is all the active <u>subwords</u> - with sign extension if applicable. For these three, the E register is set, as usual, identical to the memory word used. For ITE, the operand is the active $\underline{quarters}$ only. There is no sign extension. The result, of course, goes into E and there is no final E register copy from memory. All these instructions are indexable and of course indirect addressing can be used. | Name | INTERSECT | UNITE | DISTINGUISH** | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Abbreviation | Abbreviation ITA | | DSA** | | | ITE | | | | Symbol | ^ | <b>v</b> | ⊗ | | Other Names | "AND" | Inclusive OR | Exclusive OR<br>Partial Add | | Logic<br>Diagram | $\alpha_{\left[\mathbf{T}_{j}\right]}$ $\alpha_{\left[\mathbf{A}\right]}$ | $\alpha_{[T_j]}$ $\alpha_{[A]}$ $\alpha_{[A]}$ | $\alpha_{\left[T_{j}\right]}$ $\alpha_{\left[A\right]}$ | | Typical<br>Use | Masking - e.g. if T contains 77 ITA T; clears all of A except for the last 6 bits. | Bit Setting, or clearing to minus zero - if T <sub>j</sub> contains 77, UNA T <sub>j</sub> sets the last 6 bits to 1 without changing the rest. | Bit Complementing - if T <sub>j</sub> contains 77 DSA T <sub>j</sub> complements the last 6 bits. | |----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------| | Special Example F <sub>30</sub> = 600 All quarters are active and independent. | 30 SAB {-9,-9,,-9,-9} ITA B If positive, A is cleared to +0. The original [A] goes into B. | 30 SAB (-9,-9,,-9,-9) UNA B If Negative, A is set to -0. The original [A] goes into B. | 30 SAB{-9,-9,,-9-9} DSA B The absolute value or magnitude or each quarter goes into A The original [A] goes into B. | \*\* Note: DSA affects both the C and D registers. The effect on D is equivalent to LDD T. The effect on C is equivalent to forming the carries and uniting them with the original contents of C. - i.e. ([A] $\blacktriangle$ [T $_j$ ]) $\blacktriangledown$ [C] ==> C. | - DT | THOMPHONTON | NONTEL CLUD A DEL ONI | ABBREVIATED DESCRIPTION | COMMENT | |------|-----------------------------------------------|--------------------------|---------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | No. | | CONFIGURATION<br>DIAGRAM | ABBREVLATED DESCRIPTION | COMMENT | | 1 | LUNA Tj | T <sub>j</sub> | $R[T_j] \cdot R[A] => R(A)$ $[T_j] => E$ | T <sub>j</sub> is unaffected.<br>The left half of A<br>is also unchanged. | | 2 | ll <sub>ITA</sub> T <sub>j</sub> | T <sub>j</sub> | $R [T_{j}] R [A] => R (A)$ $SR [T_{j}] L [A] => L (A)$ $[T_{j}] => E$ | T <sub>j</sub> is unaffected. Each bit of left half of A is "intersected" with bit 2.9 of T <sub>j</sub> -Hence, if R [T <sub>j</sub> ] is positive, L(A) <sup>j</sup> is cleared. | | 3 | llITE T <sub>j</sub> [F <sub>ll</sub> ] = 140 | T <sub>j</sub> | $R[T_j] \land R[A] \Rightarrow R(E)$ | T <sub>j</sub> is unaffected.<br>L(E) is unaffected.<br>There is no sign<br>extension on ITE. | | 4 | <sup>l</sup> DSA T <sub>j</sub> | T <sub>j</sub> | $R [T_{j}] $ | DSA affects registers A, C, D, and E. See note above. | Insert is a partial STA (store accumulator) instruction — only those bits marked by a l in the corresponding column of B are stored in $T_j$ . There is no sign extension, and [A] is not changed. If [B] is minus zero (all ones), INS is identical to STA. The E register is set to the final contents of the memory word used. EXAMPLES: (Standard F Memory - Chart 7-2) | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | MASK<br>(CONTENTS OF B) | COMMENTS** | |-----|---------------------------------|--------------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1. | INS T <sub>j</sub> | T <sub>j</sub> | -0 | [A] $\Rightarrow$ T <sub>j</sub> . INS is identical to STA when [B] = -0. | | 2. | INS T <sub>j</sub> | T <sub>j</sub> | 0,,777777 | $R[A] \Rightarrow T_j$ . This time it looks like a <sup>1</sup> STA $T_j$ , because of the mask. | | 3. | <sup>3</sup> INS T <sub>j</sub> | T <sub>j</sub> | 4,2,,3,1 | Bit 1.1 of A is copied into position 1.1 of T <sub>j</sub> . Quarters 2,3, and 4 are inactive. No other bits are changed. <sup>13</sup> INS T <sub>j</sub> would do the same. [F <sub>13</sub> ] = 160 | | 4. | <sup>6</sup> INS T <sub>j</sub> | T <sub>j</sub> | 4,2,,3,1 | Bit 1.1 of A is copied into position 4.1 of T <sub>j</sub> . Note that permutation has no effect on the use of B. <sup>16</sup> INS T <sub>j</sub> is identical. | <sup>\*\*</sup>In all cases, there is a final copy into E from the memory register used. t "Insert" is also given by ([A] $\mathbf{v}$ [ $\mathbf{B}$ ]) $\mathbf{A}$ ([B] $\mathbf{v}$ [ $\mathbf{T}_{\mathbf{j}}$ ] ). INS 55 | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | MASK (CONTENTS OF B) | COMMENTS** | |-----|-------------------------------------|--------------------------------|----------------------|---------------------------------------------------------------------------------| | 5. | <sup>3</sup> INS{T <sub>k</sub> }j* | (T <sub>k</sub> ) <sub>j</sub> | 4,5,,6,7 | $ql[A] \Rightarrow ql(T_k)_j$ . STA ··· would be equivalent. | | 6. | INS T <sub>j</sub> | T <sub>j</sub> | +0 | Since [B] = +0, nothing happens. | | 7. | <sup>2</sup> INS A | A (before) | 4,5,,0,7 | ql[A] => q3(A). Only<br>quarter 3 of A is<br>changed. (Because of<br>the mask.) | $$\alpha_{\text{COM}}$$ $T_j$ $\alpha_{[T_j]} \implies T_j$ $T_j$ is permuted. COM - Complement - performs two basic operations. The active subwords of $T_j$ are complemented (one's complement - all ones become zeros and vice versa) (with sign extension) and all quarters are permuted whether active or not. Note that if all quarters are <u>inactive</u>, COM <u>permutes</u> all quarters of $T_j$ without changing the data. FMT is another abbreviation - equivalent to COM. There are 4 basic steps: - 1. $[T_j] \Rightarrow E$ , permuted according to $\alpha$ . - 2. Sign extension occurs in active subwords. - 3. Active subwords are complemented. $(\alpha_{[E]} = \alpha_{[E]})$ - 4. $[E] \Rightarrow T_j$ straight no permutation. Note that, as usual, E is the same as $T_j$ at the end. EXAMPLES: (Standard F Memory - Chart 7-2) | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>DES <b>C</b> RIPTION | COMMENTS | |-----|--------------------------------------------------------------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------| | 1 | COM T <sub>j</sub> | T <sub>j</sub> (before) T <sub>j</sub> (after) | | All of T is complemented | | 2 | <sup>2</sup> com T <sub>j</sub> | (before) Tj (after) | $ \overline{L[T_{j}]} \Rightarrow R(T_{j}) $ $ R[T_{j}] \Rightarrow L(T_{j}) $ | The halves are reversed and the right half is complemented. | | 3 | <sup>16</sup> COM T <sub>j</sub><br>[F <sub>16</sub> ] = 163 | (before) Tj (after) | $\frac{\overline{q4[T_j]}}{\overline{q4[T_j]}} \Rightarrow q1(T_j)$ $\overline{Sq4[T_j]} \Rightarrow q2,3,4(Tj)$ | Quarters 2, 3, and 4 are set to the complemented sign extension. | | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>DESCRIPTION | COMMENTS | |-----|--------------------------------------------------------------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------| | 4 | $\alpha_{\text{COM}}$ T <sub>j</sub> $\alpha = 172$ (all inactive) | T <sub>j</sub> | $R[T_{j}] \Rightarrow L(T_{j})$ $L[T_{j}] \Rightarrow R(T_{j})$ (Simultaneously) | When all quarters are inactive, the data is not changed - it is merely permuted according to the given configuration. | | 5 | COM $\{T_k\}_j^*$ | T <sub>k</sub> ,j | $ \frac{\left[T_{k,j}\right]}{\left[T_{k,j}\right]} \Rightarrow T_{k,j} $ $ \frac{\left[T_{k,j}\right]}{\left[T_{k,j}\right]} \Rightarrow E $ | This has double index- ing. T <sub>k</sub> , j = T + [X <sub>k</sub> ] + [X <sub>j</sub> ] | Note: Since COM does not use any register other than $T_j$ , there may be some confusion as to the meaning of "Activity". In this chapter, quarters for which arrows are drawn are active. To be consistent with other instructions, one should say that the permutation comes first, complementing second, and sign extension last. If you use the phrase "Active Subwords of $T_j$ ", the order of the first two is immaterial since both operations can be considered to take place simultaneously. In any event, sign extension uses the complemented sign. # 3-2.6 CONFIGURATION MEMORY CLASS SPF SPG FLF FLG | c <sub>SPF</sub> T <sub>j</sub> | q 1 [T <sub>j</sub> ] | => | Fc | |---------------------------------|-----------------------------------------------------------------------------------------|----|-----------------------------------------------------------| | <sup>c</sup> spg T <sub>j</sub> | q 1 [T <sub>j</sub> ] q 2 [T <sub>j</sub> ] q 3 [T <sub>j</sub> ] q 4 [T <sub>j</sub> ] | => | F <sub>c</sub> +1<br>F <sub>c+2</sub><br>F <sub>c+3</sub> | "Specify" copies from STUV memory into F Memory. (STUV memory is not changed.) SPF sets only one F Memory word. SPG sets four. F Memory addresses are consecutive modulo $37_8$ - i.e., 0, 1, 2, ..., $36_8$ , $37_8$ ,0, 1, 2, etc. These instructions are indexable but not configurable. The E register is set, as usual, to the contents of the memory register used. ## EXAMPLES: | NO. | INSTRUCTION | DESCRIPTION | COMMENT | |-----|----------------------------------|----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------| | 1 | °SPF T <sub>j</sub> | | $F_{O}$ is permanently set to +0 and can not be changed. | | 2 | °SPG T <sub>j</sub> | q 2[T <sub>j</sub> ] => F <sub>1</sub> q 3[T <sub>j</sub> ] => F <sub>2</sub> q 4[T <sub>j</sub> ] => F <sub>3</sub> | Same as #1. | | 3 | <sup>37</sup> SPG T <sub>j</sub> | $q l[T_j] => F_{37}$ $q 3[T_j] => F_1$ $q 4[T_j] => F_2$ | Fois, of course, not changed. The Following Memory address "c" is normally given in OCTAL | | c <sub>FLF</sub> T <sub>j</sub> | $[F_c] \Rightarrow ql(T_j)$ | |---------------------------------|---------------------------------| | | $[F_c] \Rightarrow ql(T_j)$ | | C | $[F_{c+1}] \Rightarrow q2(T_j)$ | | <sup>c</sup> FLG T <sub>j</sub> | $[F_{c+2}] \Rightarrow q3(T_j)$ | | | $[F_{c+3}] \Rightarrow q4(T_j)$ | "File" copies from F Memory into STUV Memory. (F Memory is not changed.) File Form (FLF) copies a single 9 bit word, File Group copies four. They are indexable, but not configurable. The F Memory Addressing is modulo $37_8$ — i.e. "c" = 0, 1, 2, ... $36_8$ , $37_8$ , 0, 1, 2, ... etc. The E register is set as usual, to the contents of the memory word used. ## EXAMPLES: | NO. | INSTRUCTION | DESCRIPTION | COMMENT | |-----|----------------------------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | 1. | °FLF T <sub>j</sub> | +0 => ql(T;) | $F_{\odot}$ is permanently set to +0. | | 2. | °FLG T <sub>j</sub> | $0 \Rightarrow q1(T_{j})$ $[F_{1}] \Rightarrow q2(T_{j})$ $[F_{2}] \Rightarrow q3(T_{j})$ $[F_{3}] \Rightarrow q4(T_{j})$ | | | 3. | <sup>36</sup> FLG T <sub>j</sub> | $[F_{36}] \Rightarrow ql(T_{j})$ $[F_{37}] \Rightarrow q2(T_{j})$ $+0 \Rightarrow q3(T_{j})$ $[F_{1}] \Rightarrow q4(T_{j})$ | The F Memory address "c" is normally given in octal. | 3-2.7 ARITHMETIC CLASS ADD SUB MUL DIV TLY (TALLY) August 1963 ADD and SUBTRACT are straightforward one's complement (RINGED) arithmetic instructions. The use of configuration is similar to LDA. A zero result is negative except when both arguments are zero at the start -(+0) + (+0) = +0; +0 - (-0) = +0. There are four overflow indicators—a separate indicator for each active subword. The indicator is cleared before the arithmetic is done and is set to a one for either type of overflow—(too negative or too positive). (With one's complement arithmetic there is a sign reversal when overflow occurs. The scale instructions take this into account.) Sign extension occurs prior to the arithmetic. The D register is set as if an $\alpha$ LDD $\alpha$ were done. The C register is set to the carries from each column. (In the case of subtract, "c" contains the carries from adding the complement of $\alpha$ D The B register is unaffected. The E register is set, as usual, to the contents of the memory word used. EXAMPLES: (Standard F Memory - Chart 7-2) | TIME II | EMAPIFIED: (Standard Premoty - chart (-2) | | | | | |---------|-------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>DESCRIPTION | COMMENTS | | | 1 | ADD T | T <sub>j</sub> | | The expression $[A] \wedge [T_j] => C$ is equivalent to saying the "carries" of each bit column go into the corresponding bit column of $C \cdot Z_{\downarrow}$ is set if overflow occurs. | | | 2 | <sup>2</sup> ADD T <sub>j</sub> | T <sub>j</sub> | $R[A] + L[T_{j}] => R(A)$ $R[A] \wedge L[T_{j}] => R(C)$ $L[T_{j}] => R(D)$ $[T_{j}] => E$ | The left half of the A, C, and D registers is unchanged. Z <sub>2</sub> is set if overflow occurs. | | | 3 | SUB T <sub>j</sub> | T <sub>j</sub> | $\begin{bmatrix} A \end{bmatrix} - \begin{bmatrix} T_{j} \end{bmatrix} => A$ $\begin{bmatrix} A \end{bmatrix} $ | Z <sub>4</sub> is set if overflow occurs. | | | | | | | DOD (11) | |-----|---------------------------------------------------|--------------------------|-----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------| | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED DESCRIPTION | COMMENTS | | 14. | <sup>3</sup> LDA {277}<br><sup>3</sup> ADD {307} | T <sub>j</sub> | 606 => ql(A)<br>l => Z <sub>1</sub><br>207 => ql(C)<br>307 => ql(D)<br>307 => E | (277) is the M4 representation for "a register containing 277(8)". | | 5. | <sup>6</sup> LDA (510,0) <sup>6</sup> ADD (470,0) | T <sub>j</sub> | 201 => ql(A)<br>1 => Z <sub>1</sub><br>410 => ql(C)<br>470 => ql(D)<br>470,0 => E | {510,0} is the M4 representation for "A register containing 510(8) in quarter 4, and zero in the rest of the word." See Chapter 6. | Note: The four OVERFLOW indicators are associated with the subwords by Sign Quarter Number. See table below: | SUBWORD | OVERFLOW INDICATOR | |------------|---------------------------------------| | Quarter 4 | $z_{1}$ | | Quarter 3 | z <sub>3</sub> | | Quarter 2 | z <sub>2</sub> | | Quarter 1 | z <sub>l</sub> | | Left Half | $z_{\mu}$ | | Right Half | Z <sub>2</sub> | | Full Word | $z_{\mu}$ | | 27 - 9 | $\mathbf{Z}_{4}$ and $\mathbf{Z}_{1}$ | $$\alpha_{\text{MUL}} \quad T_{j} \quad \alpha_{[A]} \quad \times \quad \alpha_{[T_{j}]} => \quad \alpha_{(AB)}$$ "MUL" forms the double-length, ones-complement product of [A] and [ $T_j$ ] and stores it in A and B. The extra bit of B -- at the extreme right -- is set equal to the sign bit of the product, i.e., to $\pm$ 0. (Bit 1.1 of B = Bit 4.9 of A after MUL.) The use of configuration is similar to LDA and the relevant overflow indicator (corresponding to the active sign quarter) is cleared. No overflow can be generated. The active subwords of C are cleared to +O and D is set as if an $^{\alpha}$ LDD $^{\tau}$ had been done. The E register is, as usual, set to the contents of the memory word used. EXAMPLES: (Standard F Memory - Chart 7-2.) | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED DESCRIPTION | COMMENTS | |-----|----------------------------------------------|--------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | MUL Tj | T <sub>j</sub> | | "AB" is the double length register diagrammed above. It is also used with SAB, CAB, and DIV. Bit 1.1 of B is set to ± 0 depending on the sign of the product. | | 2 | <sup>3</sup> LDA {5}<br><sup>3</sup> MUL {4} | T <sub>j</sub> | 000 => q 1 (A)<br>050 => q 1 (B)<br>000 => q 1 (C)<br>004 => q 1 (D)<br>0 => Z <sub>1</sub> | With standard configuration 3, ql[AB] is an 18-bit register composed of quarter 1 of A and quarter 1 of B. The other quarters are not changed | | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>DESCRIPTION | COMMENTS | |-----|--------------------------------------------------------|--------------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------| | 3. | <sup>1</sup> LDA (-3)<br><sup>1</sup> MUL (-4) | T <sub>j</sub> | + 0 ==> R(A)<br>000030 ==> R(B)<br>+ 0 ==> R(C)<br>- 4 ==> R(D)<br>- 4 ==> E<br>0 ==> Z <sub>2</sub> | The left half words are not changed. | | 4. | LDA { 3}<br>MUL {-400} | T <sub>j</sub> | - 0 ==> A<br>- 3000 ==> B<br>+ 0 ==> C<br>- 400 ==> D<br>- 400 ==> E<br>0 ==> Z <sub>14</sub> | these of the sense | | 5. | <sup>2</sup> LDA {3 ,, 0}<br><sup>2</sup> MUL {4 ,, 0} | T <sub>j</sub> | + 0 ==> R(A)<br>000030 ==> R(B)<br>+ 0 ==> R(C)<br>+ 4 ==> R(D)<br>(+4,,0) ==> E<br>0 ==> Z <sub>2</sub> | Only the right half words are changed. | Note: When a 27-9 subword form is used, the Arithmetic Step Counter is set for the 27-bit word, if it is active. This results in too many steps for the 9-bit word if it is active also. (This is true for MUL, DIV, NOA, NAB, and TLY.) Normal use of this subword form is for floating numbers of the form $N = x \cdot 2^y$ (27 bits for "x," 9 for "y"). Since different operations are performed on the two syllables, both subwords will not be active at the same time. | a a | $\alpha_{[AB]} \div \alpha_{[T_j]}$ | ==> A | |-------|-------------------------------------|-------| | DIVTj | Remainder | ==> B | DIVIDE considers the contents of AB (except for the lowest order bit of B) as the numerator and the contents of T<sub>j</sub> as the denominator. (Note that it is compatible with MUL.) Configuration is similar to ADD, LDA, etc. The Quotient is stored in A with the appropriate algebraic sign. The remainder is stored in B with the same sign as the original numerator. (The sign of the remainder is at the left, as usual.) (SAB (+n) will bring strange bits into A for the remainder (in B) is not an extension of the quotient.) The relevant overflow indicator is cleared at the outset and an overflow will be generated if $\mid$ [A] $\mid$ exceeds or equals $\mid$ [T,] $\mid$ . - Note: 1. If $|[A]| < 2 \cdot |[T_j]|$ overflow, if any, is guaranteed recoverable via SCA $\{-n\}$ . SAB $\{-n\}$ will also recover the correct answer, but it will destroy the remainder. - 2. If both [AB] and $[T_j]$ are normalized (as per NAB and NOA), the condition above is met, and any overflow is recoverable. - On overflow, the sign of A is always the reverse of the proper algebraic sign. - 4. If overflow is not recoverable, both [A] and [B] are useless. - 5. $\frac{N}{+0} = \frac{-1}{N}$ , and Overflow is set. (This is true for any N.) - 6. $\frac{\mathbb{N}}{-0} = \mathbb{N}$ , and Overflow is set. (Also true for any N.) - 7. Divide clears C (as if by $\alpha_{LDC}$ {O} ) and sets D (as if by $\alpha_{LDD}$ T, - 8. The contents of the memory register go into E, as usual. - 9. See also note on page 3-61. | NO. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>DESCRIPTION | COMMENTS | |-----|---------------------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------| | 1. | DIV Tj | T <sub>j</sub> | [AB] $\div$ [T <sub>j</sub> ] => A Remainder => B + O => C [T <sub>j</sub> ] => D [T <sub>j</sub> ] => E | Overflow, if any, sets $Z_{l_{\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!$ | | 2. | l <sub>DIV</sub> T <sub>j</sub> | T <sub>j</sub> | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | Overflow sets $\mathbf{Z}_2$ . The left half of the arithmetic unit is unchanged. | | 3. | 3 <sub>LDA</sub> {000}<br>3 <sub>LDB</sub> {052}<br>3 <sub>DIV</sub> { 5) | T <sub>j</sub> | 004 => ql(A)<br>001 => ql(B)<br>000 => ql(C)<br>005 => ql(D)<br>005 => E<br>0 => Z <sub>1</sub> | The numerator is actually half of 000052 since the lowest order bit of B is not part of it. In decimal, we have 21 + 5 or 4 with a remainder of +1. | | 4. | 6 LDA { -0,}<br>6 LDB {725,}<br>6 DIV { -5,} | T <sub>j</sub> | +4 => q1(A)<br>-1 => q1(B)<br>+0 => q1(C)<br>-5 => q1(D)<br>(-5,) => E<br>0 => Z <sub>1</sub> | Note that [A] is minus zero. The numerator is therefore -21 (decimal). If [A] were +0, the numerator would be $\frac{+725}{2}$ (8) or 234 (decimal). | TLY (TALLY) loads A (as does LDA). Then the count of ones is added to the sign quarter of D. The rest of D is not affected. The sign digit is counted also if it is a "one". The E register is set, as usual, to $[T_j]$ . EXAMPLES: | | L TILLO . | | | | | |-----|-----------|-----------------------|--------------------------|--------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------| | NO | 0. | INSTRUCTION | CONFIGURATION<br>DIAGRAM | ABBREVIATED<br>DESCRIPTION | COMMENTS | | 1 | L. | TLY T | T <sub>j</sub> | $\begin{bmatrix} T_{j} \end{bmatrix} => A$ $n+q4[D] => q4D$ $\begin{bmatrix} T_{j} \end{bmatrix} => E$ | "n" is the number of ones in $[T_j]$ . The addition is regular 9-bit ring addition with no overflow detection. | | . 2 | 2. | TLY (+0) | (+0) | + 0 => A<br>+ 0 => E | The D register is not changed | | 3 | 3• | <sup>1</sup> TLY {-0} | (-0) | - 0 => R(A)<br>18+q2[D] => q2D<br>- 0 => E | The left half of A is not changed. Only the sign quarter (No. 2) of D is affected. | Note: When a 27-9 subword form is used, the Arithmetic Step Counter is set for the 27-bit word, if it is active. This results in too many steps for the 9-bit word if it is active also. (This is true for MUL, DIV, NOA, NAB, and TLY.) Normal use of this subword form is for floating numbers of the form $N = x \cdot 2^y$ (27 bits for "x," 9 for "y"). Since different operations are performed on the two syllables, both subwords will not be active at the same time. 3-3 OPERATION CODE CHART (Wesley A. Clark). # 3-3.1 Number Systems Let S be a binary number of length $\,\lambda$ 3 number ranges are commonly used: 1) Positive Integers (e.g., r, P, Q) 0 < S < $$2^{\lambda}$$ - 1 2) Signed Integers (e.g., $$X_j$$ ) $$-(2^{\lambda-1}-1) \leq S \leq +(2^{\lambda-1}-1)$$ 3) Signed Fractions (e.g., A in MUL, DIV) $$-(1-2^{-(\lambda-1)}) < S < +(1-2^{-(\lambda-1)})$$ $\frac{\text{Negative}}{\text{number.}} \ \frac{\text{number}}{\text{S}} \ \frac{\text{represented by "Ones Complement"}}{\text{of corresponding positive}} \ \frac{1 \to 0}{\text{S}} \ \frac{\overline{\text{S}}}{\text{Complement of S).}}$ Two representations of number zero $0 = 00 \dots 0$ $0 = 11 \dots 1$ $\lambda$ bits in length # Reduction Modulo µ For positive integer S $0 \le S < 2 \mu$ $$S \mod \mu = \begin{cases} S & \text{if } S < \mu \\ S - \mu & \text{if } S \ge \mu \end{cases}$$ Example: $6 \mod 7 = 6$ , $8 \mod 7 = 1$ # 3-3.2 Glossary of Terms $$(W_{ri}^*)$$ ' Leftmost (sign) quarter of permuted indexed memory operand | , | | | EXAMPLE 1 | EXAMPLE 2 | |---------------------|-------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------|-------------| | S, T | λ-bit binary numbers | S | 010 011 101 | 111 011 010 | | S | Complement of S (sign bit complemented) | S | 101 100 010 | 000 100 101 | | < S > | Inversion of S | < S > | 110 011 101 | 011 011 010 | | RS | Positive (counterclockwise; left) unit rotation of S | RS | 100 111 010 | 110 110 101 | | R <sup>-1</sup> S | Negative (clockwise; right) unit rotation of S | R <sup>-1</sup> S | 101 001 110 | 011 101 101 | | 2 x S | Unit positive scaling of S (S scaled up by one) | 2 x S | 000 111 010 | 110 110 101 | | 2 <sup>-1</sup> x S | Unit negative scaling of S (S scaled down by one) (scaling is rotation without change of sign bit) | 2 <sup>-1</sup> x S | 001 001 110 | 111 101 101 | | n(S) | Normalizer of S (S signed fraction) $\frac{1}{2} \leq 2^{n(S)} \times S < 1$ Note: $n(0) = n(0) = \lambda -1$ . (Used as 9-bit number.) | n(S) | 0 | 2 | | T(S) | Tally of S (number of ones in S) (used as 9-bit number.) | τ(S) | 5 | 6 | | | | T | 011 010 011 | 011 010 011 | | S A T | S and T for each bit b, b=1, 2, | S^ T | 010 010 001 | 011 010 010 | | SVT | S or T $ \begin{cases} 0, & 0-1, & 2, \\ \dots, & \lambda \end{cases} $ | SVT | 011 011 111 | 111 011 011 | | S Ø T | S or T but not both | S <b>⊗</b> T | 001 001 110 | 100 001 001 | | SOT | $λ$ -bit binary ring sum of S and T Note: $S \oplus S \equiv 0$ | • | 101 110 000 | 010 101 110 | | SOT | $\lambda$ -bit binary ring difference = $(\overline{\overline{S}} \oplus \overline{T})$ | SOT | 111 001 001 | 100 000 111 | Enclosed expression applies to $\underline{\text{each active quarter of operand}}$ Enclosed expression applies to each active subword of operand A blank box indicates that no change is made. | TIME | | | INSTRUCTION | | | - | | WOI IN | | 1,0, | - 1./ | 701 | A | BLANKS IN | C C | HANGE) | | Ε | | | | | | | | |-----------|------|-------------------------|--------------------|------------------------------------------|--------|--------|----------------|--------|------------|------|---------|----------|--------------------|--------------|-------------|---------------|------|------------|--|---|--|--|--|--|----| | OVER BASK | i | ABBAEV. | NAME | COMPITIONS | Po | Q | X, | Wa | Wa Wa* | Was | = Waexi | 2(1) | | ь | | D' | D | | | | | | | | | | 0 | 21 | SPF | SPECIFY GROUPE | | | | | | | | | | | | | | | _ | | | | | | | | | 1.2 | 31 | FLF | FILE FORM | | P.+1 | AGX; | | | | F. @ | | - | | | | | | 9 | | | | | | | | | 2.8 | 32 | FLG | FILE GROUP | | | | | | | Ge | | | | | | | | | | | | | | | | | | 24 | LDA | LOAD A | | | | | | | | | | Was | | | | | | | | | | | | | | 0 | 25 | LDB | LOAD B | | | | | | | | | | | Waii | Way: | | | | | | | | | | | | | 26 | LDC | LOAD D | | | | | | - | | | | | | Waj | | W. | | | | | | | | | | | 34 | STA | STORE A | | | | | | 1 | | A | | | | | | | | | | | | | | | | | 35 | STB | STORE B | | | | | | | | В | | | | | | | | | | | | | | | | 1.2 | 36 | STC | STORE C | | | | | | | | C | | | | | | | | | | | | | | | | | 37 | STD | STORE D | | | | | | - | | D | - | Was | | | | | | | | | | | | | | - 1 | 54 | EXA | EXCHANGE A | 3 | | | | | - | - | (BAA) | - | Was | | | | | | | | | | | | | | 2.4 | 55 | INS | INSERT | | | | | | | | V(BAWA) | | | | | | | | | | | | | | | | | 41 | ITA | INTERSECT A | | | | | | | | | | AA Win | | | | | | | | | | | | | | | 42 | UNA | UNITE A | | | | | | - | | | - | A V WAY | | (A A WA) VC | | | | | | | | | | | | 0 | 65 | ADD | MSTINGUISH A | | | | | | | | | | A & WAY | | AA WIN | | 1.7# | | | | | | | | | | | 77 | SUB | SUBTRACT | | | | | | | | | (5) | A & Way | | A ~ Whi | | Wis | | | | | | | | | | 1185 | 76 | MUL | MULTIPLY @ | | P+1 | v . | | | | | | 0 | A × | Was | 0 | | | | | | | | | | | | 55 37 16 | 75 | DIV | DIAIDE @ | <b>6</b> | 771 | rexi | | | | | | 6 | (AB/Was) QUOT. | (AB/WAJ)REM. | | | | | | | | | | | | | 14/1 | 60 | CYA | CYCLE A | | | | | | | | | 1 | 10(Wy)". A | | | | | • | | | | | | | | | 74/3 | - | CAB | CYCLE AB | | | | | | | | | | R(WY | )′.48 | | | | | | | | | | | | | v√x)′<9 | | | | | | | | | | | | - | * | *(W,*)'B | | | | | | | | | | | | | =>0 | 61 | CYB | CYCLE B | -/ | | | | | | | | - | 2(44) | 7 . B | | | | | | | | | | | | | | 70 | SCA | SCALE A | Z(A)=0 | | | | | - | | | | | | | | | | | | | | | | | | | | | | (M4) >0<br>Z(A)=1 | | | | | | | | | 2 (W) (A) | | | 0 | | | | | | | | | | | 7/3 | | | | (MG) 60 | | | | | | | | 0 | 2(W#)'+1 = (2-1-A) | | | | | | | | | | | | | | 14970 | 72 | SAB | SCALE AB | Z(A)=0 | | | | | | | | 1 | 2(M.) | * AB | | | (6) | | | | | | | | | | .,,, | | | Z(A) = 1 | | | | | | | | 1 | 2(M, ") | " (AB) | | | | | | | | | | | | | | | | | | (W4) >0 | | | | | | | | 1 | 2(M)+ | 1 x (2-1 AB) | | | W. | | | | | | | | | | - | 71 | SCB | SCALE B | (143)'40 | | | | | | | | $\vdash$ | 2 | 2(Ma), B | | | | | | | | | | | | | | | | | | | | | | | - | | - | -(A) | 5, 4, 8 | | | | | | | | | | | | | 7/3 | 64 | NOA | NORMALIZE A | Z(A)=0 | | | | | | - | | 1 | 2 m(A) A | | | (W*) '@ m(A) | | | | | | | | | | | | 66 M | | • | Z(A)-1 | | | | | | | | 0 | (2-1.A) | | | (W*)'81 | | | | | | | | | | | | | HAB | NORMALIZE AB | Z(A):6 | | | | | | | | | 2m(A | B) AB | | (W, ") " (AB) | | | | | | | | | | | | | | • | Z(A)=1 | | | | | | | | | (2-1 | AB | | (W.y") " 6 1 | | | | | | | | | | | 2962 | 74 | TLY | TALLY @ | | | | | | | | | | W,* | | | D' & * (win) | | | | | | | | | | | 10101- | | | | | | | 0 1 | | | | | | | | | | | | | | | | | | | | | | SKX SKIP ON (REX) INDEX | | | | | | | | | c<4 | P+1 | | 1 -1 | | | | | | | | | | | 4) | | 3,6 | 12 | | INDEX | × | | | | | 2 Xj⊕h | | | | | | | | | | | 4 | | | | | | | | | | | P+2 | | 3 XjOA | | | | | | | | | | | | | | | | | | | | | | | | | | | | 4-7 🕝 | | | | | $\vdash$ | | | | | | | | | | | | | | | 2.0 | 56 | | PERMUTE | a,=17 | | | | | - | W | | - | | | | | | <b>(4)</b> | | | | | | | | | 0 | 20 | LDE | LOAD E | | | | | | • | - WW | | $\vdash$ | | | | | | W.# | | | | | | | | | 1.2 | _ | STE | STORE E | | P+1 | 16X1 | | | - | | E. | + | | | | | | MAS | | | | | | | | | | | | INTERSECT E | | | | | | | | | | | | | | | EAWAS | | | | | | | | | 0 | | SED | SKIP IF | E = Way | | | | | | | | | | | | | | | | | | | | | | | | | | E DIFFERS | E # WA | P+2 | | | | | | | | | | | | | | | | | | | | | | 2.0 | 17 | SKM | SKIP - MAKE | • | 0 | 1 | | 0 | 1 | | | | | | | | | • | | | | | | | | | | | | | | | | | | | | | | | | | | | , | | | | | | | | | - | | | | - | - | | - | | | | - | | - | - | - | | - | | | | | | | | | | 0 | 11 | RSX | RESET X | | | | (W,*) | | - | - | | - | | - | - | - | | | | | | | | | | | 1.2 | 11 | DPX | DEPOSIT X | | | | (Wa) | | So(Xj)Xj | - | | - | | | - | | | | | | | | | | | | 1.2 | 14 | EXX | EXCHANGE X | | P+ I | 1 | (W*) | | So(Xy) Xj | 1 | | - | | | | | | • | | | | | | | | | .8 | 10 | AUX | AUGMENT X | | | | X @ (W.*), (12 | | 0 | 1 | | | | | | | | | | | | | | | | | 3.2 | 15 | ADX | ADD X | | | | | | X 6 (W.) 0 | | | | | | | | | | | | | | | | | | - | - | - | - | - | - | - | | | - | 1 | - | 1 | - | - | | - | - | - | | | | | | | | | | 06 | JPX | JUMP ON POSITIVE X | X; 40 | P+! | | (3) | - | | - | | - | | | | | | (F ) (F | | | | | | | | | 3.2 | - | 71.11 | | X; >0 | r | | ≤⊕Xj | | | | | | | | | | | (E41): (E | | | | | | | | | | 07 | JNX | JUMP ON NEGATIVE X | X <sub>i</sub> < 0<br>X <sub>i</sub> ≥ 0 | P+1 | | | | | - | | - | | | | | | P+ | | | | | | | | | | 46 | JPA | JUMP ON | A >0 | P+1 | | | | | | | - | | | | | | | | | | | | | | | | | | POSITIVE A | A > O | | | | | | | | | | | | | | 1. | | | | | | | | | 1.6 | 47 | JNA | JUMP ON | A < 0 | A & X; | | | | | | | | | | | | | P+ | | | | | | | | | | | | MEGATIVE A | ALO | P | | | | | | | | | | | | | | | | | | | | | | | 44 | JOY | JUMP ON | Z(A)= | | | | | | - | | - | | | | | | | | | | | | | | | | - | 7110 | OVERFLOW | Z(A)=1 | reXi | | | | - | - | - | - | | | | - | - | P+ | | | | | | | | | 1.2 | 05 | JMP<br>BRC | JUMP<br>BRANCH | c even | 16Xi | | (4) | | | | | 1 | | | | | | 19:0 | | | | | | | | | | 57 | - | | C odd | P | | | - | | - | | + | | | | | | | | | | | | | | | | | 1 130 | | | - | | - | - | - | - | - | - | | - | - | | | | | | | | | | | | 1.6 | 31 | | DATA | READY | P+1 | A SX; | | | | (3) | (3) | | | | | | | • | | | | | | | | 3-3.3 Notes on the coding chart - 1. In all expressions P+1, P+2, sums are reduced modulo $2^{18}$ . (777777 + 1) mod $2^{18}=0$ . - 2. For SPF and FLF only quarter one of $W_{rj}$ is used. SPG and FLG use all four quarters. F memory addressing is counted modulo $37_8$ (e.g., 36, 37, 0, 1 ...) - 3. If $r \oplus X_{j} = 377604$ (address of A reg.) then EXA has same effect as STA. - 4. Final value of $W_Q ==> (Q = r, r \oplus X_j)$ . - 5. ADD, SUB overflow conditions: If $$A \oplus W = A + W$$ Then $O ==> Z(A)$ If $$A \oplus W \neq A + W$$ Then $1 ==> Z(A)$ $$Z(A_{\downarrow_{1}2}) \equiv Z(A_{\downarrow_{2}}) \equiv Z(A_{\downarrow_{1}}) \equiv Z(A_{\downarrow_{1}}) = Z_{\downarrow_{1}}$$ $$Z(A_3) = Z_3$$ $$Z(A_{21}) \equiv Z(A_2) = Z_2$$ $$Z(A_1) = Z_1$$ 6. DIV Conditions: | | CONDITIONS | | Z(A) | А | В | |---|------------------------|--------------------------|------|-----------------------|-------------------| | | l / - | $ W_{r,j}^* > AB $ | 0 | QUOT | REM | | | W <sub>rj</sub> * ≠ 0 | W <sub>rj</sub> * < AB | 1 | JUNK | JUNK | | | | AB = 0 | | Ā | | | 1 | W <sub>rj</sub> * = 0 | AB ≠ 0 | Т | Ā ⊗ W <sub>rj</sub> * | R <sup>-1</sup> B | Sign of normal remainder = sign of dividend (AB). JUNK is recoverable if $|A| < 2 |W_{r,j}^*|$ . - 7. Exceptions in MUL, DIV, NOA, NAB, TLY: Expressions listed are not correct for quarter (subword) 1 of A, B, and D' if a 27, 9 subword is chosen, and if quarter 1 is active. - 8. CYCLE, SCALE, and NORMALIZE instructions begin, in effect, with $\overline{\text{LDD}}$ . - 9. $\underline{PMT}$ , $\underline{COM}$ consist of 3 consecutive steps: # 10. SKM variations: | j | Mr.q.b : selected bit | |-------------------------|------------------------------------| | q mod 4 b | Mr.q.lo(dec) = mr | | 3.6 3.5 3.4 3.3 3.2 3.1 | r.q.10(dec) r<br>Mr.q.11(dec) = pr | | q = quarter; b = bit | Mr.q.12(dec) = parity (Mr) | | | | CON | DITIC | ONS | | | ACTIONS | |------------|-----|-----|-------|-----|-----|--------|--------------------------| | FUNCTION | | | С | | | м | (SKIP, Then MAKE, | | | 4.8 | 4.7 | 4.6 | 4.5 | 4.4 | Mr.q.b | Then CYCLE) | | | 0 | 0 | - | - | - | - | P + 1 ==> P | | SKIP | 0 | 1 | - | - | - | - | P + 2 ==> P | | SKIP on | 1 | 0 | _ | _ | _ | 0 | P + 2 ==> P | | ZERO | _ | | | | | 1 | P + 1 ==> P | | SKIP on | 1 | 1 | _ | _ | _ | 0 | P + 1 ==> P | | ONE | _ | - | | | | 1 | P + 2 ==> P | | - | - | - | - | 0 | 0 | - | - | | COMPLEMENT | - | - | - | 0 | 1 | - | | | MAKE ZERO | - | - | - | 1 | 0 | - | 0 ==> M <sub>r.q.b</sub> | | MAKE ONE | - | - | - | 1 | 1 | - | 1 ==> M <sub>r.q.b</sub> | | - | - | - | 0 | - | - | - | - | | CYCLE | - | | 1 | - | - | | $R^{-1}W_{r} ==> W_{r}$ | - 11. $S_{G}(X_{j})$ is 18-bit number 00 ... 0 or 11 ... 1 according as sign bit of $X_{j}$ is 0 or 1. - 12. $\underline{ADX}$ , $\underline{AUX}$ consist of sequence of steps: 13. $\underline{c}$ is 18-bit signed integer expansion of c. (0 $\leq$ c $\leq$ 37; -17 $\leq$ $\underline{c}$ $\leq$ + 17) # 14. JMP, BRC variations: | | | | С | | | | |------------|----------|-----|-----|-----|-----|-------------------------------------| | FUNCTION | d<br>4.8 | 4.7 | 4.6 | 4.5 | 4.4 | ACTION | | JUMP | - | - | - | - | 0 | r ==> P | | BRANCH | - | - | - | - | 1 | r ⊕ X <sub>j</sub> ==> P | | - | - | - | - | 0 | - | - | | SAVE | - | - | - | 1 | - | P + 1 ==> X <sub>j</sub> | | - | - | - | 0 | - | - | - | | P + 1 => E | - | - | 1 | - | - | P + 1 ==> E <sub>21</sub> | | - | - | 0 | - | - | - | - | | Q ==> E | - | 1 | - | - | - | Q ==> E <sub>1+3</sub> | | - | 0 | - | - | - | - | - | | DISMISS | 1 | - | - | - | - | if $h = 0$ , $0 \Rightarrow \phi_L$ | # CHAPTER 3 # INDEX | | NUMERICAL ORDE | R | | ALPHABETICAL ORDE | R | |----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------| | CODE NO. | OPERATION | PAGE | OPERATION | CODE NO. | PAGE | | 45670124567012245670124567456761245667012456777777777777777777777777777777777777 | IOS JMP JPX JNX AUX RSX SKX EXX ADX DPX SKM LDE SPF SPG LDA LDB LDC LDD STE FLF FLG STA STB STC STD ITE ITA UNA SED JOV JPA JNA EXA INS COM TSD CYA CYB CAB NOA DSA NAB ADD SCA SCB SAB TLY DIV MUL SUB | 4-73-266 | ADD ADX AUX COM CAB CYA CYB DIV DPX DSA EXA EXX FLF FLG INS IOS ITA ITE JMP JNA JNX JOV JPA JPX LDA LDB LDC LDD LDE MUL NAB NOA RSX SAB SCA SCB SED SKM SKX SPF SPG STA STB STC STD STE SUB TSD TLY UNA | 67<br>15<br>10<br>62<br>60<br>61<br>71<br>65<br>64<br>14<br>31<br>32<br>5<br>4<br>4<br>40<br>5<br>47<br>7<br>45<br>66<br>64<br>11<br>22<br>34<br>33<br>36<br>7<br>7<br>7<br>7<br>42<br>42<br>22<br>22<br>27<br>66<br>64<br>11<br>22<br>34<br>33<br>33<br>37<br>37<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7 | 3-58 3-22 3-20 3-42 3-42 3-46 3-18 3-19 3-19 3-19 3-19 3-19 3-19 3-19 3-19 | # TX-2 USERS HANDBOOK CHAPTER 4 - IN-OUT SYSTEM ### TABLE OF CONTENTS | TNTF | | | |------|--|--| #### 4-2 TX-2 INOUT JARGON - 4-2.1 SEQUENCE SUBPROGRAM PROGRAM - 4-2.2 PLACEKEEPERS, PROGRAM COUNTERS, AND THE P REGISTER - 4-2.3 SELECT, CONNECT, TURN ON # 4-3 TX-2 INOUT CONTROL LANGUAGE - 4-3.1 CHANGE OF SEQUENCE NUMBER - 4-3.2 THE HOLD BIT - 4-3.3 START POINTS - 4-3.4 DROP OUT TEMPORARY AND PERMANENT - 4-3.5 THE "IOS" OPERATION "INOUT SELECT" - 4-3.6 THE REPORT BIT - 4-3.7 "TSD" TRANSFER DATA - 4-3.8 CONTROL LANGUAGE SUMMARY ## 4-4 NOTES ON CODING FOR INTERLEAVED OPERATION - 4-4.1 BRUTE FORCE - 4-4.2 HIGH LOW MEDIUM PRIORITY SUBPROGRAMS ## 4-5 UNIT BY UNIT DESCRIPTIONS - No. 41 INOUT ALARMS - No. 42 TRAPPING - No. 47 MISCELLANEOUS INPUTS - No. 50 DATRAC (SAMPLED ANALOG INPUT) - No. 51 XEROX PRINTER - No. 52 PETR (PHOTOELECTRIC PAPER TAPE READER) - No. 54 INTERVAL TIMER - No. 55 LIGHT PEN - No. 56, 60 DISPLAY - No. 61 RANDOM NUMBER GENERATOR - No. 63 PUNCH - No. (65, 66, 71, 72) LINCOLN WRITERS # CHAPTER 4 TX-2 IN-OUT SYSTEM ### 4-1 INTRODUCTION: TX-2 was designed for 33 "IN-OUT" devices (see chart 7-1). Each channel is identified by its "Sequence Number" - Zero for "STARTOVER" and 40-77<sub>(8)</sub> for "normal" channels. (Sequence Numbers are usually given in Octal.) The basic In-Out set includes: For Input: Photoelectric Paper Tape Reader Keyboard and Reader of Lincoln Writer Datrac Analog Sampler For Output: Xerox Printer High Speed Paper Tape Punch Printer and Punch of Lincoln Writer Display Scopes For Bulk Storage: Variable Speed Addressable Magnetic Tape (4 units, manually selected at first, about 2 million words per unit.) The subprograms associated with INOUT units can be written so that the waiting time for one unit is automatically used as computation time for others. Only one subprogram is in operation at any specific time, although the interleaved operation of several subprograms makes it possible for several INOUT units to be in operation simultaneously. In a typical program, a subprogram will continue to run until it must wait for its associated unit to complete a data transfer or until it is interrupted to allow a subprogram of higher priority to run. Each subprogram has a "placekeeper" to remember where it should resume operation and an indicator ("FLAG") to tell when it is ready to run again. Since it is likely that more than one subprogram will be ready (i.e., more than one Flag will be up,) at any given time, a priority system is provided and is adjustable (by rewiring the "Priority Plugboard"). Each INOUT channel has, therefore, a "Sequence Number" (40-77 octal) for identification, a placekeeper (the correspondingly numbered index register), and a one bit register - its "FLAG" for signaling. Channel number zero is a special case in that its "unit" is the STARTOVER and CODABO pushbuttons, its "placekeeper" is the Toggle Start Point Register (TSP), and its Priority is the highest and cannot be changed. (The pushbuttons - STARTOVER and CODABO - raise Flag #0. "CODABO" also clears alarms, presets all control flip-flops, lowers all other Flags, and starts the computer. "STARTOVER" does NO MORE than to raise Flag #0.) Sequence Numbers 76 and 77 have been reserved for non-INOUT purposes. Flags 76 and 77 must be raised and/or lowered by programmed instructions. With the standard priority plugboard, they have the <u>lowest</u> Priority position. (Sequence number 40 has the highest. The K register, a 6 bit FF register, holds the sequence number of the currently operating subprogram.) A hTSD using a non-INOUT Sequence No. will cycle memory one place to the left. ### 4-2 TX-2 INOUT JARGON ### 4-2.1 SEQUENCE - SUBPROGRAM - PROGRAM TX-2 is indeed a "Multiple Sequence" or "Multiple Subprogram" machine. This is to say that it can interleave subprograms - i.e., it can keep track of several interleaved program sequences. This does not say that it can run several interleaved independent programs. So much colusion and cooperation would be required to interleave unrelated <u>programs</u> that they should probably be done by the same person. One could then argue that the result would be better described as a multi-purpose program. The word "Sequence" is often used as a synonym for "Inout Channel". Sometimes it refers to "Sequence Number". (We often say "Sequence" 77 rather than "Sequence Number" 77). And it is used in the "normal" sense - i.e., "subprogram". ## 4-2.2 PLACEKEEPERS, PROGRAM COUNTERS, AND THE P REGISTER The placekeepers - all 33 of them counting #0, (the Toggle Start Point,) - are memory devices whose purpose is to remember where each subprogram is to resume operation when it gets a chance. Placekeepers 40-77(8) are index registers. Placekeeper "ZERO" is the Toggle Start Point register (TSP) (a row of toggle switches on the computer console). The <u>P register</u> is an 18 bit flip-flop control register that always holds either the location number of the current instruction or that of the next instruction. It corresponds to the "program counter" or "instruction counter" of other machines. Index Registers 40-77, the placekeepers, are often called the "program counters". Occasionally the P register is called "The program counter". # 4-2.3 SELECT, CONNECT, TURN ON To "connect", or "Turn on" an INOUT unit means to set the control flip-flop of the channel so that data can be transferred, and so that the INOUT unit has access to its Flag. The unit is said to be "connected to the computer". Each regular INOUT unit has a "C" flip-flop - and a corresponding console indicator - to show whether it is "connected" or not. The word "select" is often used as a synonym for "connect" but it is also more or less reserved for the day when two or more units must share the same channel. This will be true, for example, in the magnetic tape bulk storage system. ### 3 TX-2 INOUT CONTROL LANGUAGE TSD - "Transfer Data" and IOS - "INOUT SELECT" are the only INOUT operations. The channel used for data transfer depends on the "sequence number" in use rather than the unit connected, for many units may be connected, but only one subprogram is in operation at the time a given data transfer is initiated. Control of the interleaving - not strictly an INOUT function is done through: The hold bit(#4.9), a syllable of every instruction, Resetting placekeepers via X Memory operations, and Drop out - permanent or temporary. (See 4-3.4) ### 4-3.1 CHANGE OF SEQUENCE NUMBER A change of sequence number occurs whenever: - a) A high Priority INOUT channel takes over by "BREAKING" or interrupting a lower priority subprogram. - b) A subprogram drops out (either permanently, or to wait for its unit to get ready for another data transfer), and a lower priority subprogram takes over. If no other subprogram is ready, no change of sequence number occurs. The computer goes into "LIMBO", a condition where it repeatedly scans all the Flags until one is up. If the same old Flag (as indicated by the K register) comes up, no change of sequence occurs. When a change of sequence number occurs, several internal registers are affected: P Register Set from the new placekeeper. K Register $\Longrightarrow$ Set to the new sequence number. Note that the current placekeeper is changed $\underline{\text{only when}}$ the sequence number is changed. It can therefore be used as an ordinary index register $\underline{\text{while}}$ its subprogram is in operation. #### 4-3.2 THE HOLD BIT A typical INOUT subprogram is usually written so that it can be interrupted at any time by another subprogram of higher priority. To do this completely, one would have to refrain from using the Arithmetic Unit and the E register. Since this is too severe a restriction, the "hold syllable" or "hold bit" is provided. A hold bit insures that no "break" or interruption will occur following the completion of the held instruction. A break can occur before a "held TSD", but only when the INOUT unit is unable to handle the data transfer. (This is called "DISMISS and WAIT".) Since instructions using the E register must nearly always be held, the assembly program automatically inserts the hold syllable. (LDE, ITE, and JPX, JNX.) (JPX and JNX are included because their automatic dismiss is usually not wanted. The hold syllable cancels "dismiss" whether built in (as in TSD, JNX, JPX) or programmed (as in $^{20}$ SKX, $^{20}$ IOS, $^{20}$ JMP)). # 4-3.3 START POINTS To start a subprogram we need only set its placekeeper to the starting place and raise its Flag. If the computer is running, the subprogram will start as soon as it has highest priority among those that are ready. "Starting" is particularly easy for sequence number zero. Its placekeeper, "TSP", is set by hand. If the computer is running or in "LIMBO" the STARTOVER pushbutton will suffice. Flag zero will go up and a change of sequence number to #O will occur as soon as an instruction is performed that has no hold bit (or when a hTSD that can not be initiated is encountered). CODABO is used when the computer is not running, or when the user wants to stop all other subprograms and start subprogram #O only. A subprogram using sequence number zero has highest priority and therefore can not be interrupted. Sequence number zero is used primarily to start other subprograms. This amounts to setting placekeepers for the others and raising the Flags of those that should start. The following operations are used: For setting placekeepers: RSX, SKX - i.e., the instructions normally used to change the X Memory. For raising Flag "F": $^{10}$ SKX<sub>F</sub> or $_{10}$ SKX<sub>F</sub> 50 000 For permanent Drop Out: The dismiss bit (4.8) - a syllable of SKX, JMP, and IOS only. The built in Dismiss feature of TSD, JNX, and JPX can also be used for permanent drop out. Note that the single instruction " $^{30}$ SKX $_{\alpha}$ 101" (in sequence zero) would start the subprogram that is at 101 operating under sequence number " $^{\alpha}$ ". (Providing, of course, that $^{\alpha}$ is not zero.) In fact, the $^{30}$ SKX $_{\alpha}$ 101 will work from any sequence number other than $^{\alpha}$ . (It can not be made to look like "JMP 101".) ## 4-3.4 DROP OUT - PERMANENT AND TEMPORARY When a subprogram is finished, it can drop out permanently through the DISMISS syllable (bit 4.8) of IOS, SKX, or JMP. When TSD has <u>initiated</u> an output data transfer or when it has <u>completed</u> an input data transfer the built in dismiss will cause drop out if "hold" was not used. This drop out will be temporary - the INOUT unit will raise the Flag. For input units the Flag is raised when the next datum is ready (e.g., when the next key is pressed or the next line of tape comes up). For output units the Flag is raised when the data transfer is complete and the unit is ready for another (e.g., when the character has been printed, or the paper tape has been punched). Drop out always lowers the current Flag. It is considered "temporary" if the unit is about to <u>raise</u> the Flag and "permanent" if the Flag will be raised by another subprogram (or if the subprogram is finished for good). Temporary drop out can also occur when a TSD operation is not possible - i.e., when an output unit is still busy or when there is no datum available from an input unit (e.g., when the next line has not yet arrived). This form of temporary drop out is called "DISMISS and WAIT" and can <u>not</u> be prevented by using the "hold bit". In this case, the TSD that caused the drop out has not been done, the P register is not advanced, and the TSD is done when the subprogram resumes operation. ## 4-3.5 THE IOS OPERATION - "INOUT SELECT" The primary functions of IOS are "Connection" and "Disconnection" of INOUT units, and the specification of operating modes. Some units have several modes - for example, the user has the option of punching tape with or without a 7th hole on each line. IOS is also used for raising and lowering Flags and will eventually be used for selecting mag tape drives. The basic IOS operations are: IOS, 20 000 - Disconnect Unit "J" from the computer ${ m IOS}_{ m J}$ 3XXXX - Connect Unit J (if not already connected), and set to Mode XXXX IOS, 40 000 - Lower Flag J IOS, 50 000 - Raise Flag J IOS, 60 XXX - Select Unit XXX (Not used yet) IOS<sub>J</sub> 20 000, <u>Disconnect</u>, has no effect on interleaving except that a TSD that tries to initiate a data transfer will not be performed. (A "Dismiss and Wait" will occur - waiting for the unit to be ready to transfer the data. In most cases this amounts to a permanent drop out.) ${\rm IOS_J}$ 3XXXX, Connect, has one peculiarity. It will raise Flag J whenever: Unit J is an OUTPUT unit, and Unit J was not already connected. When a mode change takes much time, the unit involved will generate a raise flag signal to indicate that the change has been made, and no data transfer will be accepted during the intervening interval. (i.e., the "buffer is busy".) IOS<sub>J</sub> 40 000, LOWER FLAG J, is <u>not</u> equivalent to drop out if J is the current sequence number. The subprogram currently in operation will continue to run until it drops out or until it is interrupted by a unit of higher priority. If such a BREAK occurs, the interrupted subprogram will not resume operation, for Flag J is indeed lowered. If J is <u>not</u> the current sequence number, IOS<sub>J</sub> 40 000 prevents subprogram J from resuming operation until Flag J is raised somehow - (perhaps by unit J or by another subprogram). $IOS_J$ 50 000, (and $^{10}SKX_J$ ) will raise FLAG J, but as before, "J = current sequence" is a special case. Note that: Will change the P register and therefore be similar to a JMP if J is <u>not</u> the current sequence number. But if J <u>is</u> the current sequence number, no change of sequence number is ordered and the RAISE FLAG cancels the DISMISS. There is effectively no change. (Except that $^{30}$ SKX<sub>J</sub> Y will set X<sub>J</sub> to "Y" but this will be wiped out by the next change of sequence number.) The Flag of the <u>current sequence</u> is never used. Following each instruction that is <u>not held</u>, control scans the Flags having higher priority but goes no further. It does not consider the current Flag. If the instruction <u>was held</u> no scan is made at all. When a subprogram drops out, <u>all</u> the Flags are scanned until a raised Flag is found. When no Flags are up, and this scanning is taking place, the computer is in "LIMBO". As soon as a Flag is found, a change of Sequence Number (see 4-3.1) takes place and normal operation is resumed. ## 4-3.6 THE REPORT BIT A simple IOS has no effect on the E register. If bit 4.4 is set to 1, (a $^{1}\text{IOS}_{_{\text{J}}}$ O for example) the control flip-flops of the chosen unit are copied into E $^{1}\text{EOS}_{_{\text{J}}}$ O for example instruction is performed. Thus, if $^{1}\text{IOS}_{_{\text{J}}}$ 3XXXX is used, E will contain information on the state of affairs $^{1}\text{EOS}_{_{\text{T}}}$ the mode change. Unused portions of E are cleared. The standard report is as follows: Bit 3.1 to 3.6 - Sequence Number of Reporting Unit " 2.9 - Flag " 2.8 - Buffer Status - 1 = not busy 0 = busy " 2.7 - Maintenance " 2.6 - Connect " 2.5 - EIA - Equipment Inability Alarm " 2.4 - MISIND - Missed Data Indicator " 2.3 - 1.1 - Mode flip-flops - same as in the IOS 3XXXX for most units. " 3.7 - 4.9 - Special indicators - cleared if not used. With a few exceptions (41, 42, 55, 75) each INOUT unit has an INOUT Buffer Register (IOB) and a Status FF. STATUS = 1 means it is the computer's turn to use the buffer, STATUS = 0 means that the "BUFFER is BUSY" - i.e., the unit is working on an uncompleted data transfer. The buffers range in size from 6 to 24 bits. TSD - Transfer Data - means either "copy from IOB, to memory" or "copy memory to IOB," where k is the current sequence number (i.e., contents of the K register). Thus for input units, TSD completes the data transfer and for output units, TSD initiates the data transfer. (For input, the transfer is "unit-to-buffer," then "buffer-to-memory"(via TSD) and for output it is "memory-to-buffer" (via TSD), then "buffer-to-unit".) Except where TSD is used in ASSEMBLY mode, permutation and activity can be used in the normal manner. There is no sign extension - subword form is ignored. "Inactive" portions of an output buffer are filled with +0. The buffer is considered to be at the far right unless otherwise stated in the unit descriptions. TSD has two built-in DISMISS features. If the buffer is busy, the TSD can not be performed and drop out occurs whether a hold is used or not. This is called "dismiss and wait" and comes <u>before</u> the P register index point in the control cycle. (P is not advanced.) Once the TSD operation is done, the other built-in DISMISS occurs but this time "hold" <u>is</u> effective. Such a hold is used on input devices to insure use of the new datum as soon as possible and on output devices to utilize the processing time without changing the sequence number. It is possible in either case to use so much time that lower priority subprograms never have time to operate. If an INOUT unit is <u>not</u> connected, a TSD will find the buffer "busy" and "Dismiss and wait" will occur. If the unit is subsequently connected by another subprogram, the flag of the first will be raised and the TSD will be performed as soon as normal interleaving will allow. If a TSD is done using sequence number 0, 76, or 77, the specified memory word will be <u>cycled left once</u>. The configuration syllable is not used - the cycle is a full 36 bit operation. Unless a "hold" was used, the automatic dismiss syllable of TSD will take effect. (This is also true for sequence numbers for which there is no INOUT unit as yet.) Note that for sequence number 75 (Miscellaneous Outputs), TSD <u>does</u> <u>not</u> <u>cycle</u>. (It will still dismiss if not "held", however.) ## IOS O<sub>IOS<sub>J</sub></sub> O - Has no effect except to take time. (But note that <sup>1</sup>IOS is "Report".) O<sub>IOS<sub>T</sub></sub> 20000 - Disconnect Unit J OIOS<sub>J</sub> 3XXXX - Connect Unit J, Set Mode, Raise Flag J if Unit J was a disconnected Output Unit. $^{\rm O}$ IOS $_{ m J}$ 40000 - Lower Flag J - Not DISMISS, (i.e., will not cause drop out.) <sup>0</sup>IOS<sub>.T</sub> 50000 - Raise Flag J ## SKX $^{10}{\rm SKX}_{\rm J}$ N $\,$ - $\,$ Raise Flag J, Set ${\rm X}_{\rm J}$ to "N". $^{20}{\rm SKX_J}$ N - DISMISS, Set ${\rm X_J}$ to "N". $^{30}\text{SKX}_\text{J}$ N - Both of the above for J $\neq$ k. If J = k, there is no drop out. (k = current sequence number.) ## DISMISS Bit 4.8 for IOS, JMP, SKX (e.g., <sup>20</sup>SKX, <sup>20</sup>IOS) "Built in" as part of TSD, JNX, JPX (Otherwise not available.) # Change of Sequence Number Affects: Register E OLD # NEW # CONTENTS OF P Old Placekeeper — Contents of Register P Register K -- New Sequence Number Register P -- Contents of New Placekeeper X <sup>\*</sup> Register E is cleared before the report. Therefore, all un-used bits are zero. ## 4-4 NOTES ON CODING FOR INTERLEAVED OPERATION If a program uses but one unit there is no need to interleave any subprograms and the entire program can be performed using one sequence number. Even if two or more units are to be used, it is sometimes better to use them one after the other rather than simultaneously. If the above conditions are true, the only pitfall that may be overlooked is premature drop out. Careful use of the dismiss bit and built in dismiss features will prevent this error. Interleaved operation of subprograms requires sharing the following: Main Memory X Memory F Memory Arithmetic Element (A,B,C,D, and Overflow FF). (Listed in order of increasing difficulty) Main Memory and X Memory must usually be partitioned, except, of course where they are used for common data. The F Memory can usually be set at the start to some "Standard Configurations" and left unchanged. Two approaches to sharing TIME and AE are given below. # 4-4.1 BRUTE FORCE HOLDING Whenever the INOUT units involved are slow enough, or are not free-running (i.e., do not dictate timing) a brute force method may be used. (The Lincoln Writer Printer and the High Speed Punch are two such units.) The lower priority subprograms can use a hold bit on all instructions where a break is intolerable, (assuming a BREAK will change the Arithmetic Element). The only limit is that they can't hold on all instructions. The highest priority subprogram has no problem other than the fact that it must drop out now and then to give the others a chance. If it must wait for a lower unit it can do so by dropping out and relying on the other subprogram for restarting. Synchronization can be automatic only if the high priority loop contains a temporary drop out. The easiest way to obtain a temporary drop out is through regular and, if need be, dummy TSD operations (e.g., non-printing keys on the Typewriter, blank tape on the punch, etc.). Another method would be to use the Interval Timer (Unit #54). ## 4-4.2 HIGH-LOW-MEDIUM PRIORITY SUBPROGRAMS The Brute Force Holding method will not work if the timing of one unit requires that it receive attention soon after its Flag comes up. In many cases it is necessary to restrict holding to no more than three consecutive operations. Fortunately, the index memory operations can be used in place of the Arithmetic Element operations for many applications. This means that all but the lowest priority subprograms do not need the Arithmetic Element. The rules for this method are as follows: July 1961 4-11 For Lowest Priority Subprogram - The only one to use the Arithmetic Element. a) No more than "n" consecutive holds.\* (It should be possible to limit this lowest priority subprogram to holding only on JPX or JNX.) ("Consecutive", here refers to TIME, not storage.) For Medium Priority Subprograms - - a) No more than "n" consecutive holds.\* - b) No use of the Arithmetic Element For Highest Priority - - a) No use of the Arithmetic Element unless it is saved and restored. - b) "Hold" should be needed only on JNX, JPX, and TSD. In other places, it has no effect. When used on TSD, care should be taken to insure that some time remains for other units. <sup>\*&</sup>quot;n" the number of permissable consecutive "holds" is determined by the timing requirements of the highest priority subprogram. "n" = 3 is enough to allow considerable flexibility in the other subprograms. ## IN-OUT ALARMS ## DESCRIPTION: This "device" enables operation of an Alarm Subprogram whenever an IN-OUT alarm occurs. FLAG 41 is raised upon EIA (Equipment Inability) or MISAL (Missed Data) for any of the devices listed below. TSD is used to determine the type and source of the alarm. ## MODE SELECTION: | | Connects alarm circuitry to central computer. FLAG 41 will | |-------------------------|--------------------------------------------------------------| | IOS <sub>41</sub> 30000 | now be raised upon alarms. TSD will now report alarming | | | conditions. "MISAL" (Alarm) is suppressed. See Note 1 below. | ### TSD INSTRUCTION: #### BUFFER BIT ALLOCATIONS: | Bit | Corresponding<br>Octal Integer | In-Out<br>Alarm | |-----|--------------------------------|--------------------------| | 1.1 | 001 | MISAL - Datrac 50 | | 1.2 | 002 | MISAL - PETR 52 | | 1.3 | 004 | MISAL - Mag. Tape 46 | | 1.4 | 010 | EIA - Mag. Tape 46 | | 1.5 | 020 | EIA - Camera 60 | | 1.6 | 040 | EIA - Punch 63 | | 1.7 | 100 | EIA - Xerox 51 | | 1.8 | 200 | EIA - Lincoln Wtr. 65,66 | | 1.9 | 400 | EIA - Lincoln Wtr. 71,72 | - NOTE: 1. An unsupressed "MISAL" will stop the computer. The two forms of supression, program and manual, are independent both must be off to remove the supression. Programmed supression does not light the yellow console light, but the red light and gong still - 2. ETA "Equipment Inability Alarm" does not stop the computer but it may ring a buzzer or stop the unit involved. - 3. If an additional alarm is generated before the first has been cleared, TOB<sub>41</sub> will be set but FLAG 41 will not be raised. TSD can be used again to see if this has occurred. Note that an IOS 30000 following IOS 20000 will raise FLAGS 60, 63 and 51, but not FLAGS 50 or 52. FLAG 46 is a special case. TSD should be used before disconnecting the offending unit for it can not report conditions of units that are not connected. TRAP The TRAP circuits can be set to raise FLAG 42 (thereby starting a special subprogram) whenever a metabit is encountered in the operation of other subprograms. FLAG 42 can also be raised on change of sequence number or upon a signal from the TX-2 Sync System. The circuits can also set metabits. Since metabits can be encountered in 3 basic ways, there are several TRAP modes. See below. TSD is not used (but retains its cycle left and dismiss features). Combined modes are allowed. For example, IOS<sub>42</sub> 30007 will set to trap on all metabits encountered, whether by instruction, defer cycle, or operand. ## MODES (Programmed) (All Pushbuttons OFF.) | , | (TILL I ADIID AU OUTID OII.) | | |----------------------------------------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 105 <sub>42</sub> 20000<br>or<br>105 <sub>42</sub> 30000 | Clear | Clears Mode Selection | | 10542 30001 | Trap on Marked Instruction | FLAG 42 is raised before the end of the marked instruction. | | 105 <sub>42</sub> 30002 | Trap on Deferred Address | FLAG 42 is raised before the end of the instruction using a marked deferred address. | | IOS <sub>42</sub> 30004 | Trap on Operand | FLAG 42 is raised after a delay of one to several instructions, depending on overlap conditions. | | 105 <sub>42</sub> 30010 | Trap on Change Sequence | FLAG 42 is raised during change sequence cycle if new Place Keeper (index register) is marked (2.9 = 1). The "new" (marked) sequence number goes into quarter 3 of the E Register, and the "old" into quarter 4. There is no trap when leaving number 42. | The three "set metabits" modes below are partly manual in that the "set metabits" pushbutton switch on the console must be "ON". These modes do not raise FLAG 42. | IOS <sub>42</sub> 30100 | Set Metabits of Instructions | Sets metabit of all <u>instructions</u> performed. | |-------------------------|---------------------------------------|------------------------------------------------------------| | 105 <sub>42</sub> 30200 | Set Metabits of Deferred<br>Addresses | Sets metabit of all <u>deferred</u> <u>addresses</u> used. | | 10542 30400 | Set Metabits of Operands | Sets metabit of all operands used. | MANUAL MODE: (Trap on Sync System Signal) FLAG 42 can be raised by a signal from the Sync System. The requirements are: - 1. "Sync 1" and "Sync 2" pushbutton switches should be OFF. - 2. The "Sync to Trap" pushbutton switch should be "ON". While it is "ON" all other trapping modes are not effective. Setting modes still work. When "Sync to Trap" is turned "OFF", the original mode is reinstated. - 3. "Gate 1 to Sync Jacks" pushbutton switch should be ON. (This is located on the Sync System Panel.) #### MISCELLANEOUS INPUTS Nine one-bit independent input channels - each with a BCN jack and an ON-OFF toggle switch are provided. A standard TX-2 transition from -3V to ground will set the chosen buffer digit and raise FLAG 47. The buffer is cleared upon copying into memory via TSD. Two Schmidt Triggers with filters are provided on the panel itself, and a 3 channel pushbutton pulse generator is also available as a separate, movable unit. ## MODE SELECTION #### MANUAL CONTROLS: - Notes: 1. The input signal must be a "Standard TX-2 Transition" (i.e. from -3 volts to ground with a rise time less than 0.2 microseconds). - 2. The Schmidt triggers are completely independent of the rest of the circuitry and must be cabled to the channel desired. The input to the Schmidt trigger must be a smooth transition from ground to -3 volts. Since the normal open circuit voltage is about -3 volts, a sine wave of about 5 volts RMS, or an opening switch contact can be used. The filter should be used with the switch contact input or with any other noisy source. The Schmidt trigger inverts the input signal producing a standard TX-2 Inout Transition as its output. (The circuit switches at -0.9 volts going down and at about -2.2 volts going up. The rise and fall time is about 0.15 microseconds.) ## DATRAC - Analog to Digital Numerical Input The DATRAC is an analog to digital converter made by Epsco, Inc. It provides numerical samples of a continuous electric signal. A measurement or sample is started upon receipt of a "trigger pulse" from the computer or from an external source. (Such as the Interval Timer - See No. 54.) Pertinent parameters are as follows: (and see notes below.) Maximum Sampling Rate: 27 Kilocycles (37 usec per sample) Measuring Time (Trigger to Raise Flag): 22 usec. Nominal Input Signal: -1 volt to +1 volt (can be set to ±10 volt or ±100 volt behind the panel.) Output Signed 18 bit Ones Complement Fraction #### **OPERATIONS** | IOS <sub>50</sub> 30000 | CONNECT | IOS 30000 permits FLAG 50 to be raised and sends a trigger pulse to the datrac control panel, (where it may be switched to the DATRAC, or not as desired by the user.) | |------------------------------------------------------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TSD T <sub>j</sub> α OR <sup>α</sup> TSD T <sub>j</sub> | T <sub>j</sub> IOB <sub>so</sub> | TSD copies an 18 bit signed ones complement fraction into T, along permuted pathways if so specified. The reliable precision is, however, only 8 to 11 bits - (at the left end). There is no sign extension in T, TSD also sends a trigger to the DATRAC control panel (where it may be switched to the DATRAC or not as desired.) | - NOTE: 1. Do not trigger the Datrac more often than at 37 usec intervals. It is possible to damage the circuits. - 2. TSD copies the measurement taken at the time of the last trigger. - 3. A MISAL is created when a trigger arrives at the Datrac <u>before</u> the previous sample has been transferred to the computer via TSD. (See IN-OUT #41.) MANUAL CONTROLS: ## DATRAC Control Panel ## XEROX PRINTER The XEROX is an electrostatic, high speed (960 lines per minute) printer. It is basically a charactron display with automatic continuous xerographic recording. Through electronic compensation, the display area or frame is held "stationary" for about 45 milliseconds, and then moved down about 0.1 inch to catch up with the paper. The programmer must specify the x,y position as well as the code number for each character to be printed. #### **OPERATIONS** | IOS | 30000 | CONNECT | "Connect" turns on the xerographic recording apparatus and raises FLAC 51 when the equipment is ready. (Warm up time is about 5 seconds.) | |-------------------------------------------------------------|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IOS | 30010 | FRAME SYNC | If the unit is not connected, "Frame Sync" will "connect" it. FLAG 51 is raised at the start of the next Frame period. (Frame period is 45 milliseconds.) | | TSD T $_{j}$ $\parallel \alpha$ OR $^{\alpha}$ TSD T $_{j}$ | + 1 | T, | TSD causes one character to be printed. Since TSD takes about 750 usec, only 60 characters can be printed within one FRAME interval. See diagram below for Xerox buffer layout. | #### BUFFER LAYOUT X Position Y Position Character Code #### Notes: - 1. The "Frame Area" is a rectangle approximately 5 by 1 1/4 inches. - 2. The "Origin" is at the left end, centered vertically. - 3. The X position is given by a 9 bit positive integer. (000 to 777g) - 4. The Y position is given by a 6 bit ones-complement signed numeral. (-37 to +378) - 5. The First TSD starts the paper motion. The paper will continue to move until 15 seconds after the last TSD or until 15 seconds after the Xerox is disconnected via $\rm IOS_{51}20000$ . - 6. A TSD that must start up the paper drive is unpredictable due to noise generated by the paper mechanism. The safe procedure is to print one or two "blank" characters (e.g. code 100) and an extra Frame Sync (IOS<sub>51</sub>30010) to ensure that the paper is moving smoothly when the data is displayed. ## Numerical Parameters: Frame Interval - 45 milliseconds (approximately) Frame Reset Interval - 2 milliseconds Character Print Time - 750 microseconds Frame Size - 1 1/4 inches high by 5 inches wide Character Size - Nominally 3/32 high by 1/16 wide Paper Speed - 2 inches per second ## Calculated Parameters: Characters per line 60 Vertical deflection .02 inches per unit Horizontal deflection .01 inches per unit Frame spacing = .094 inches Lines per inch = 10.65 Suggested X increment - 8 units ## MANUAL CONTROLS ON OFF SWITCH Low paper buzzer alarm Note: "Low Paper" alarm causes an EIA indication and can raise FLAG 41 if IO alarm circuits are "connected". See IN-OUT Unit 41. # XEROX PRINTER CHARACTER CODES | A 154 β 122 (107) B 142 b 324 (034) C 351 (058)(071)(346) π 323 (033) D 352 p 024 E 313 (043) q 111 F 344 (054) t 112 G 302 (012) w 173 H 354 x 174 I 172 (157) y 163 J 144 x 164 K 143 x 110 (040) L 352 (047)(062)(317) B 311 (041) H 360 (058)(070)(348) y 333 (063) N 350 (358) y 333 (063) N 357 (358) y 333 (064) N 351 (042) λ 023 Q 160 (145) 1 001 R 351 (358) 2 002 S 322 (017)(032)(347) 5 020 (005) S 322 (017)(032)(347) 5 020 (005) | CHARACTER | OCTAL CODE | CHARACTER | OCTAL CODE | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------------|------------|---------------------| | C 361 (056)(071)(346) | A | 154 | 1 | 122 (107) | | C 361 (056)(071)(346) | В | 142 | h | 324 (034) | | D 352 E 313 (043) F 344 (054) G 302 (012) W 173 H 354 I 172 (157) J 144 K 143 L 352 (047)(062)(317) M 360 (058)(070)(348) N 370 (355) D 353 P 312 (042) Q 160 (148) R 371 (356) S 322 (017)(032)(307) T 153 U 362 (057)(072)(347) V 152 W 343 (052) Y 342 (052) Z 162 (147) A 132 (117) A 132 (117) A 132 (117) C 202 C 160 (148) C 200 (205) C 212 (206) C 221 (206) C 221 (206) C 221 (206) C 353 C 371 (356) C 370 (448)(460)(718) C 150 151 | C | 361 (056)(071)(346) | 16 | | | E 315 (045) | D | | p | | | F 344 (054) | E | 313 (043) | | | | G 302 (012) | | | | | | H 354 I 172 (157) J 144 K 143 L 332 (047)(062)(317) M 360 (055)(070)(345) N 370 (355) O 353 P 312 (042) Q 160 (145) R 371 (356) S 322 (017)(032)(307) T 153 U 362 (057)(072)(347) V 152 W 343 (053) X 161 (146) Y 342 (052) J 162 (147) A 132 (117) A 133 C 220 (205) A 132 (117) A 133 C 220 (206) C (PERIOD) 222 (207) A 340 (050) A 341 (051) T 350 C (CIRCLE) 714 (444) T 350 (445)(450)(715) T 70 (556) T 70 (556) T 150 T 150 T 150 T 150 T 150 T 151 T 153 T 154 T 164 T 164 T 164 T 164 T 164 T 164 T 165 T 163 T 164 T 164 T 164 T 164 T 164 T 165 T 165 T 165 T 165 T 165 T 161 T 163 T 163 T 164 T 164 T 164 T 164 T 164 T 165 T 165 T 164 T 164 T 164 T 164 T 164 T 164 T 165 T 165 T 164 T 164 T 164 T 164 T 164 T 164 T 165 T 165 T 166 T 167 | | | | | | I 172 (157) | | | | | | J 144 x 164 K 145 a 310 (040) L 332 (047)(062)(317) 8 311 (041) M 360 (055)(070)(345) γ 333 (063) N 370 (355) Δ 203 0 353 ϵ 334 (064) P 312 (042) λ 023 Q 160 (145) 1 001 R 371 (356) 2 002 S 322 (017)(032)(307) 3 003 T 153 4 004 U 362 (057)(072)(347) 5 020 (005) V 152 6 021 (006) W 343 (053) 7 022 (007) X 161 (146) 8 300 (010) Y 342 (052) 9 301 (011) Z 162 (147) 0 (ZER0) 000 A 132 (117) ? 202 4 133 (COMMA) 204 C 220 (205) 0 120 (105) | | | | | | K 143 | | | | | | L 332 (047)(062)(317) M 360 (085)(070)(345) N 370 (355) 0 353 0 353 0 12 (042) Q 160 (145) R 371 (356) S 322 (017)(032)(307) T 153 U 362 (057)(072)(347) V 152 M 343 (053) X 161 (146) Y 342 (052) Z 162 (147) A 132 (117) 4 133 < 220 (205) > 221 (206) • (PERIOD) 222 (207) + 351 - 372 (357) V 340 (050) I 350 (445)(460)(715) ∑ 703 (413) } 720 (415)(430)(705) F 150 - 570 (555) ( 140 = 114 / 131 (116) 8 311 (041) 8 311 (041) 9 333 (063) A 205 0 01 1 001 A 022 0 002 5 002 6 021 (006) 6 021 (006) 7 022 (007) 8 300 (010) 9 301 (011) 0 (ZERO) 000 120 (105) 121 (106) 120 (105) 121 (106) 120 (105) 121 (106) 121 (106) 122 (107) 123 (1446)(461)(716) 134 (1444) 135 (115) 141 (1444) 151 (116) 141 (1444) 151 (140 141 (1444) 151 (1556) 144 (141) 151 (115) 151 (115) | | | | | | H 360 (055)(070)(345) γ 333 (063) N 370 (355) Δ 203 0 353 ε 354 (064) P 312 (042) λ 023 Q 160 (145) 1 001 R 371 (356) 2 002 S 322 (017)(032)(307) 3 003 T 153 4 004 U 362 (057)(072)(347) 5 020 (005) V 152 6 021 (006) W 343 (053) 7 022 (007) X 161 (146) 8 300 (010) Y 342 (052) 9 301 (011) Y 342 (052) 9 301 (011) Y 342 (052) 9 301 (011) Y 342 (052) 9 301 (011) Y 202 120 (105) 120 (105) Y 343 (053) 7 022 (105) Y 343 (051) 120 (105) 121 (106) Y 343 (053) 7 373 | | | | | | N 370 (355) | | | | | | 0 353 | | | | | | P 312 (042) Q 160 (145) R 371 (356) S 322 (017)(032)(307) T 153 U 362 (057)(072)(347) V 152 W 343 (053) X 161 (146) Y 342 (052) Z 162 (147) A 153 C 200 A 153 C 200 A 153 C 200 C 100) A 152 (117) A 153 C 200 A 153 C 200 C 200 A 153 C 200 C 200 A 153 C 200 C 200 A 153 C 200 2 | | | | | | Q 160 (145) R 371 (356) S 322 (017)(032)(307) T 153 U 362 (057)(072)(347) V 152 W 343 (053) X 161 (146) Y 342 (052) Z 162 (147) A 132 (117) A 133 C 220 (205) C 221 (206) C (PERIOD) 222 (207) C 340 (050) C 340 (050) C 3413 C 363 (073) C 364 (345)(430)(705) C 370 (315) C 371 (356) C 371 (356) C 372 (357) C 373 (413) C 372 (415)(430)(705) C 371 (556) C 140 C 140 C 141 C 114 C 114 C 114 C 115 C 115 C 115 C 115 C 115 C 116 C 117 1 | | | | | | R 371 (356) S 322 (017)(032)(307) T 153 U 362 (057)(072)(347) V 152 W 343 (053) X 161 (146) Y 342 (052) Z 162 (147) A 133 C 220 (205) A 133 C 220 (205) C (COMMA) C 204 C 220 (206) C (PERIOD) C 222 (207) C 340 (050) C 363 (073) C 364 (074) C 364 (074) C 370 (445)(450)(705) C 150 C 140 C 140 C 141 | | | | | | S 322 (017)(032)(307) T 153 U 362 (057)(072)(347) V 152 W 343 (053) X 161 (146) Y 342 (052) Z 162 (147) 4 153 C 220 (205) D 221 (206) C (PERIOD) 222 (207) + 351 - 572 (357) V 340 (050) T 350 C (140) T 350 T 022 (007) S 300 (010) S 301 (011) C (2ERO) 000 A 152 (117) C (20MMA) 204 C (105) D 121 (106) X 113 C (CIRCLE) 714 (444) C 3572 T 363 (073) T 364 (074) T 363 (073) T 364 (074) T 371 (446)(461)(716) T 372 (415)(430)(705) T 150 T 151 T 154 T 157 (556) T 151 T 156 T 151 T 157 (556) T 151 T 152 T 153 (116) T 154 T 155 T 1556 T 151 T 156 T 151 T 157 (556) T 151 | | | | | | T 153 | | | | | | U 362 (057)(072)(347) V 152 W 343 (053) X 161 (146) Y 342 (052) Z 162 (147) A 133 C 220 (205) D 221 (206) C (PERIOD) D 222 (207) T 340 (050) T 363 (073) T 363 (073) T 372 (3413) T 372 (415)(430)(705) T 373 (446)(461)(716) T 370 (414) T 371 (116) T 371 (116) T 372 (115) T 373 (115) T 374 (115) T 374 (115) T 375 (1556) T 376 (115) T 377 (1556) T 377 (1556) T 377 (1556) T 377 (115) (1 | | | | | | V 152 6 021 (006) W 343 (053) 7 022 (007) X 161 (146) 8 300 (010) Y 342 (052) 9 301 (011) Z 162 (147) 0 (ZERO) 000 h 132 (117) ? 202 4 133 , (COMMA) 204 < | | | | | | W 343 (053) X 161 (146) Y 342 (052) Z 162 (147) A 133 (205) S 220 (205) S 221 (206) S (PERIOD) 222 (207) S 340 (050) S 340 (050) S 363 (073) S 363 (073) S 364 (074) S 364 (074) S 372 (445)(460)(715) S 703 (413) S 720 (415)(430)(705) S 731 (357) S 731 (357) S 732 (357) S 733 (357) S 734 (357) S 735 (357) S 736 (445)(460)(715) S 737 (445)(460)(715) S 738 (446)(461)(716) S 739 (415)(430)(705) S 740 (555) S 751 (556) (5 | | | | | | X 161 (146) Y 342 (052) Z 162 (147) h 132 (117) 4 133 C 220 (205) D 120 (105) D 121 (106) (PERIOD) 222 (207) H 351 D (CIRCLE) 714 (444) 351 D (CIRCLE) 714 (444) 363 (073) D 341 (051) D 341 (051) D 363 (073) D 364 (074) D 373 (445)(460)(715) D 703 (415)(430)(705) D 150 D 150 D 150 D 151 D 704 (414) D 705 (416)(431)(706) D 151 15 | | | | | | Y 342 (052) Z 162 (147) h 132 (117) 4 133 C 220 (205) D 121 (106) PERIOD) 222 (207) + 351 C 372 (357) V 340 (050) F 363 (073) 730 (445)(460)(715) 730 (415)(430)(705) 570 (555) ( 140 = 114 = 114 131 (116) 9 301 (011) 0 (ZERO) 000 120 (105) 121 (106) × 113 ○ (CIRCLE) 714 (444) → 373 → 373 → 374 → 374 (051) → 364 (074) → 371 (446)(461)(716) → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 → 151 | | | | | | Z 162 (147) | | | | | | # 132 (117) # 133 | | | | | | 4 153 , (COMMA) 204 < | | | | | | <pre></pre> | | | | | | > 221 (206) • (PERIOD) 222 (207) + 351 - 372 (357) × 340 (050) • 363 (073) 730 (445)(460)(715) ∑ 703 (413) } 720 (415)(430)(705) = 150 - 570 (555) ( 140 = 114 = 114 / 131 (116) > 121 (106) × 113 ○ (CIRCLE) 714 (444) * 364 (074) # 364 (074) # 364 (074) # 731 (446)(461)(716) ☐ 704 (414) ↑ 721 (416)(431)(706) * 150 - 151 - 570 (555) ( 140 = 114 = 130 (115) / 131 (116) | | | , (COMMA) | | | • (PERIOD) 222 (207) + 351 - 372 (357) × 340 (050) • 363 (073) 730 (445)(460)(715) ∑ 703 (413) } 720 (415)(430)(705) 570 (555) ( 140 = 114 = 114 131 (116) × 113 ○ (CIRCLE) 714 (444) 444) 714 (444) 714 (444) 715 (446)(461)(716) 715 (446)(461)(716) 715 (416)(431)(706) 715 (556) 716 (556) 717 (556) 718 (115) 719 (115) 710 (115) | | | n | | | + 351 | | | 2 | 121 (106) | | - 372 (357) v 340 (050) n 341 (051) s 363 (073) 730 (445)(460)(715) 731 (446)(461)(716) 731 (446)(461)(716) 732 (413) 704 (414) 720 (415)(430)(705) 721 (416)(431)(706) 721 (556) 140 151 131 (116) 131 (116) | • (PERIOD) | | | | | V 340 (050) A 341 (051) 1 363 (073) # 364 (074) 730 (445)(460)(715) 731 (446)(461)(716) ∑ 703 (413) □ 704 (414) } 720 (415)(430)(705) { 721 (416)(431)(706) 150 → 151 570 (555) - 571 (556) 140 141 131 (116) | + | | O (CIRCLE) | 714 (444) | | * 363 (073) # 364 (074) 730 (445)(460)(715) | - | | ~ | | | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | <b>v</b> | | ^ | | | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | | | | | | } 720 (415)(430)(705) { 721 (416)(431)(706) → 151 - 570 (555) - 571 (556) ( 140 - 114 = 114 - 130 (115) / 131 (116) * 102 | | | | | | 150 → 151 570 (555) − 571 (556) ( 140 ) 141 = 114 ≡ 130 (115) / 131 (116) * 102 | Σ | | | | | _ 570 (555) | } | | { | 721 (416)(431)(706) | | ( 140 ) 141<br>= 114 = 130 (115)<br>/ 131 (116) * 102 | - | | <u>-</u> | | | = 114 = 130 (115)<br>/ 131 (116) * 102 | - | | | 571 (556) | | / 131 (116) * 102 | ( | | ) | | | | | | | | | C 104 | | | | | | | U | 103 | c | 104 | Note: Bit 1.9 of the Xerox Character Code is a "size control bit". "1" means large, and "0" means small. The codes are given above with the "proper" size. #### PHOTOELECTRIC PAPER TAPE READER The PETR is a "free running", 400-2500 lines/sec., 7 channel paper tape reader. The seventh channel and the feed (or sprocket) holes are used for control, leaving a six bit data word per line. The tape must be loaded into the tape bin (manually or automatically) and is read as it is pulled past the photodiodes by the reeler. The speed therefore varies from rest to a maximum that depends on the size of the reel. The tape can not be stopped between lines. It takes about 100 lines (say a foot of tape) to come to a stop. ## OPERATIONS | 105 <sub>52</sub> 30000 | STOP TAPE<br>+ CONNECT | IOS <sub>52</sub> 30002, 30004, 30006 are equivalent. PETR is connected if not so already. | |-------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IOS <sub>52</sub> 30100 | READ NORMAL<br>(+ CONNECT) | Starts reeler and reads tape in NORMAL mode. (See TSD, below.) | | IOS <sub>52</sub> 30104 | LOAD BIN AND READ NORMAL (+ CONNECT) | Starts capstan drive in bin direction. Stops capstan when END MARK is detected (code 73 with no 7 <sup>th</sup> hole), and starts reeler to read tape in NORMAL mode as for "Read Normal" above. | | 108 <sub>52</sub> 30102 | READ ASSEMBLY OR READ SPLAYED (+ CONNECT) | Starts reeler and reads tape in ASSEMBLY Mode. (See TSD, below.) | | IOS <sub>52</sub> 30106 | LOAD BIN AND READ ASSEMBLY (+ CONNECT) | Starts capstan drive in bin direction. Stops capstan when END MARK ("73" with no 7th hole) is detected, and reverts to Read Assembly mode (30102) above. | ## TSD OPERATIONS ## MANUAL CONTROLS #### INTERVAL TIMER The INTERVAL TIMER is essentially a counter that passes every nth pulse of a pulse oscillator (the "End Carry Pulse"). The basic counting rate, timed interval, start time, and stop time are controllable. The output, a string of accurately spaced pulses, can be used to raise FLAG 54, and (or) to trigger an external device (such as the DATRAC for example). Control is partly manual, partly by program. ## OPERATIONS | 105 <sub>54</sub> 30000 | STOP COUNTER (and Connect)* | STOPS the counter and hence the output string. The count for the interval will now be reset repeatedly from the buffer (at the counting rate). (Counting rate is selected manually.) | |-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 108 <sub>54</sub> 30100 | START COUNTER (and Connect)* STARTS the counter. The pulse string will after one counted interval and will contin until it is stopped. In this mode, the st is available only at the "EC OUTPUT" jack the console. | | | 105 <sub>54</sub> 30200 | SET TO RAISE FLAG 54 (and Connect)* | CONNECTS output string to raise FLAG 54 at the end of each timed interval. This mode is used when the interval timer is to be started by hand or by an external trigger. | | 105 <sub>54</sub> 30300 | START and RAISE<br>FLAG (and Connect)* | This is a combination of the two operations just above. The first output pulse and raising of FLAG 54 come after one interval as specified by the Buffer. (The buffer can be set manually from toggles, or by a TSD in the program.) | <sup>\*</sup>All ${\rm IOS}_{\rm 5,4}$ 30000 instructions "connect" the unit if it is not already connected. - Notes: 1. The buffer is "busy" during "end carry time" i.e. when it is in use. For 10 kc., 100 kc., and "Ext. Osc." this is equivalent to the basic counting interval. For 1 mc., the buffer is "busy" during the last 16 counts. If the reset value is less than 16, the counter must be stopped before the buffer can be changed. - Any change in the buffer becomes effective only at the end of the current interval unless the change is made with the counter stopped. - 3. Manual control overrides program control. #### INTERVAL TIMER | 105 <sub>54</sub> 20000 | DISCONNECT | This instruction stops the RAISE FLAG signals but NOT the <u>Interval</u> <u>Timer</u> <u>itself</u> . | |---------------------------------------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TSD T <sub>f</sub> "\alpha oR \alpha TSD T <sub>f</sub> | JOR <sub>54</sub> | TSD copies an 18 bit numeral from T <sub>j</sub> to the IOB (In-Out Buffer). This is used as an 18 bit positive integer. It specifies the number of "counts" per timed interval. (The basic counting rate is manually selected.) Permutation and/or activity may be used. Any inactive portion of IOB is set to +0. | Note: The Standard TX-2 Inout pulse has a duration of about 0.4 microseconds and a rise-fall time less than 0.2 microseconds. ## LITE PEN The LITE PEN is a light sensitive device that looks somewhat like a pen. When "CONNECTED", it raises FLAG 55 whenever it "sees the light", presumably from the scope display (SEQUENCE NUMBER 60). ## **OPERATIONS** | 105 <sub>55</sub> 30000 | CONNECT | Allows unit to raise FLAG 55 | |-------------------------|------------|-------------------------------------------------------------------------------------------------------------| | 10S <sub>55</sub> 20000 | DISCONNECT | Prevents raise flag signals from unit. | | TSD T <sub>j</sub> | NOT USED | Same as for non-in-out SEQUENCE NUMBER (i.e., automatic dropout and cycle left $\mathbf{T}_{\mathbf{j}}$ ). | #### MANUAL CONTROLS: The pen itself contains a preamplifier with fixed gain or sensitivity. The sensitivity dial controls the gain of the main amplifier. The proper setting depends on the scope intensity and is usually set by trial and error. The toggle should be thrown toward the dial. NOTE: The light pen is sensitive only during the intensification period of Scope #60. It will not work properly with the second display scope (#56). #### SCOPE DISPLAY The "scope" is a cartesian coordinate, high speed (20 to 80 usec) display with 10 bit precision in (x, y), controllable intensity (4 levels), and a phosphor persistancy of about 2 seconds. Each point must be specified separately and the display must be repeated endlessly if it is to be viewed rather than photographed. A camera mount, several cameras, and a film index instruction are provided. The usable display area is 7 by 7 inches. ## OPERATIONS | 105 <sub>60</sub> 30000 | SELECT SCOPE<br>(CONNECT) | If the scope is <u>unselected</u> , FLAG 60 is raised. This instruction gives lowest intensity and a centered origin. See other IOS <sub>60</sub> 30000 type operations below. | |----------------------------------------------------------------------------------------------------------|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 105 <sub>60</sub> 30000<br>105 <sub>60</sub> 30010<br>105 <sub>60</sub> 30020<br>105 <sub>60</sub> 30030 | SELECT SCOPE and set INTENSITY | The scope "intensity" is controlled by the duration of the spot rather than beam intensity. 30000 - Low - 10 µsec. 30010 - Med. Low - 20 µsec. 30020 - Med. High - 40 µsec. 30030 - High - 80 µsec. | | 108 <sub>60</sub> 30000<br>108 <sub>60</sub> 30100<br>108 <sub>60</sub> 30200<br>108 <sub>60</sub> 30300 | SELECT SCOPE<br>and set<br>ORIGIN<br>LOCATION | The origin can be at the center, at the left or bottom edge, or at the lower left corner. 30000 - Center - 30100 - Bottom Center - 30200 - Left Center - 30300 - Lower Left Corner - 1 | | 108 <sub>60</sub> 30004 | INDEX FILM | The IOB is busy until the return signal comes back from the camera. The return signal also raises FLAG 60. | NOTE: The IOS 30004 (Index Film) instruction causes an "EIA" (Equipment Inability Alarm) when the film supply in the camera magazine is low. This raises flag 41 if unit 41 is connected, lights the "End of Film" light, and rings a buzzer. (See next page.) It does not stop the computer. The scope and camera can still be used until the film runs out completely. When there is no film at all, the return signal that frees the buffer is not generated, TSD operations find the buffer "busy", and "Dismiss and Wait" occurs. TSD copies from $T_j$ to the scope buffer. The 10 bit coordinates are interpreted as signed ones complement numerals. Therefore, there are two zeros - plus zero (all zeros) and minus zero (all ones). Moved origin modes are realized by automatic complementing of the appropriate sign bit. Thus $\pm 0 = -0$ in centered origin mode, and $0777_{(8)} = 1000_{(8)}$ in moved modes. Permutation and activity may be used. ### NOTES 1. In most cases it is easier to use 9 bit arithmetic. In 18 bit arithmetic, one can use "Fractions" and sense end carry by the SKM instruction, or one can use "integers" and sense overflow the same way. In the latter case, one must cycle or scale to the left so that the 10 bits will be in the buffer position. ## MANUAL CONTROLS On-Off Pushbuttons - Display power comes on after a 65 second delay. It is best for it to be brought on while the computer is stopped, for it often causes a spurious raise flag signal. For best resolution, it is necessary to wait about 20 minutes for the circuits to reach thermal equilibrium. Camera Inversion Switch - "Toward the wire" is "Normal". "Away", gives a vertically inverted display to compensate for the mirror inversion in the camera mount. ## -End of Film Light End of Film Acknowledgement Pushbutton This button will stop the alarm buzzer, but does not clear the EIA flip-flop. (See In-Out #41.) ${ m \underline{Manual\ Film\ Index}}$ - Moves the film one frame. #### RANDOM NUMBER GENERATOR The Random Number Generator assembles a 9 bit number "at random" from a radioactive Cesium Source. The average time required is 57.6 usec - minimum time 28.8 usec. ## OPERATIONS ## MANUAL CONTROLS On-Off Pushbuttons - There is a 60 second warm-up delay. Note: The Random Number Generator should be left OFF when not in use. Note: The meters should read about half scale. They are used for maintenance purposes only. The maintenance switch is inside the box above the control panel. #### PAPER TAPE PUNCH The PUNCH is the counterpart unit to the PETR. It is a line-by-line device and can be programmed to punch at speeds up to 180 lines per second. A TSD must be given for each line. Four modes are defined below. #### OPERATIONS | IOS <sub>63</sub> 30000 | NORMAL<br>NO 7 <sup>th</sup> | Sets to punch 6 channels - no 7 <sup>th</sup> hole (used for blank tape, end marks, and visual pattern punching.) | |-------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------| | IOS <sub>63</sub> 30004 | NORMAL<br>WITH 7 <sup>th</sup> | Sets for 6 channels with automatic 7 <sup>th</sup> hole punch on each line. (Used for tapes to be listed on off line Lincoln Writers.) | | 105 <sub>63</sub> 30002 | ASSEMBLY<br>NO 7 <sup>th</sup> | Sets for splayed punching - Six TSD instructions punchout a 36 bit computer word. | | 105 <sub>63</sub> 30006 | ASSEMBLY<br>WITH 7 <sup>th</sup> | Sets for splayed punching with automatic 7 <sup>th</sup> hole. Used primarily for Binary Output. | NOTE: All the above $IOS_{63}$ 30000 instructions "CONNECT" (SELECT) the punch and raise FLAG 63 if (and only if) the PUNCH was unconnected prior to the instruction. ## MANUAL CONTROLS: #### LINCOLN WRITER NOTE: Two Lincoln Writers can be ON LINE at once - "65, 66" or "71, 72" REFERENCE: Group Report 51-8 (6 October 1959) #### DESCRIPTION: The Lincoln Writer Input consists of a double keyboard with automatic case change and a Soroban mechanical tape reader. They are interlocked so that only one can be used at a time - the keyboard is inactive while the reader is running. The Output is an IBM electric typewriter and a Friden paper tape punch. Manual controls on the Lincoln Writer permit on-line or off-line use and seemingly both at once. The simplest connection for coding is "pure on-line" i.e., keyboard and reader connected to the computer alone - not to punch or writer. In this "pure on-line" mode, there are no timing considerations that can cause trouble. TSD operations can be written without regard to the elapsed time between them. The only complication that must be remembered is that "carriage return" resets the keyboard to "lower case" and "normal script" without transmitting any case or script code. Note also that a "carriage return" sent to the <u>writer</u> via TSD using Sequence # 66 or 72 will also affect the <u>KEYBOARD'S</u> automatic case memory in same manner. The Lincoln Writer input is <u>not</u> completely independent of its output! The situation becomes more complex when the keyboard is connected to writer and/or punch as well. These complex cases are to be discussed later in a supplement. Automatic case codes are generated whenever the user changes from one keyboard to another. The key will remain locked down until two TSD operations have been performed - the first to accept the case code and the second for the character itself. # TX-2 LINCOLN WRITER CODES | 00 | 0 = | 40 | Q a | |----|--------------------------------|----|----------------| | 01 | 1 ∑ | 41 | RΔ | | 02 | 2 | 42 | S P | | 03 | 3 | 43 | T 6 | | 04 | 4 / | 44 | U h | | 05 | 5 × | 45 | V > | | 06 | 6 # | 46 | W B | | 07 | 7 → | 47 | X ^ | | 10 | 8 < | 50 | Υλ | | 11 | 9 > | 51 | z ~ | | 12 | tion to hoping of the - stolla | 52 | ( { | | 13 | 0 🛮 | 53 | ) } | | 14 | READ IN | 54 | + = | | 15 | BEGIN | 55 | ( un detire) | | 16 | NO | 56 | | | 17 | YES | 57 | . * | | 20 | A # | 60 | CAR RETURN | | 21 | ВС | 61 | TAB | | 22 | C v | 62 | BACK SPACE | | 23 | D 4 | 63 | COLOR BLACK | | 24 | Εγ | 64 | SUPER | | 25 | F t | 65 | NORMAL | | 26 | G 10 | 66 | SUB | | 27 | H * | 67 | COLOR RED | | 30 | I 4 | 70 | SPACE | | 31 | J y | 71 | WORD EXAM | | 32 | K # | 72 | LINE FEED DOWN | | 33 | L ? | 73 | LINE FEED UP | | 34 | MU | 74 | LOWER CASE | | 35 | N n | 75 | UPPER CASE | | 36 | 0 1 | 76 | STOP | | 37 | P h | 77 | NULLIFY | | | | | | ### KEYBOARD #### OPERATIONS: #### MANUAL CONTROLS - 1. The <u>reader</u> must be started by hand via the "start reader" pushbutton. It will then read the line at the read station, advance one line, and wait for the datum to be accepted (presumably via TSD). The <u>keyboard</u> is inactivated while the reader is on. "STOP Reader" will re-activate the keyboard Maximum speed is 19 lines/sec and if the keyboard is connected to the computer alone, it can be programmed to run as slowly as desired. - 2. Other manual controls are more or less self-explanatory and are well covered in Group Report 51-8. - 3. Only the six bits (1.1 1.6) corresponding to the buffer are changed by TSD. ## TYPEWRITER OUTPUT ## **OPERATIONS** | IOS <sub>66</sub> 30000<br>(Unit 1)<br>IOS <sub>72</sub> 30000<br>(Unit 2) | SELECT<br>(CONNECT) | This operation selects the output of the Lincoln Writer - Typewriter and/or Punch. FLAG 66 (or 72) is raised if (and only if) the unit was unselected prior to the instruction. | |----------------------------------------------------------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TSD Τ <sub>j</sub> ∥α OR αTSD Τ <sub>j</sub> | T, 10B <sub>66</sub> | TSD copies 6 bits from T <sub>j</sub> to the Lincoln Writer, where it is printed and/or punched depending on manual controls. The Buffer remains busy until the printing or punching is over and at that time FLAG 66 (or 72) is | raised Permutation may be used and quarter one should be active. ## MANUAL CONTROL - 1. See Group Report 51-8 for details. - 2. "Computer Output" should be switched to "Punch" and/or "Writer". - NOTES: 1. Carriage Return (Code #60) not only returns the carriage and advances the paper, but it also resets the Lincoln Writer to Lowercase and Normal Script. The Keyboard case relay is changed too. (In this respect, the keyboard and writer are not independent devices.) - 2. Certain character codes (14,15,16,17,71,76,77) do not print. (They are labeled on the keyboard as "WORD EXAM", "READ IN", etc.) When such a code is sent to the WRITER, it is accepted, and takes about the same time as a regular character, but nothing is printed. ## MISCELLANEOUS OUTPUTS Nine one-bit computer controlled relay contacts with G.R. Terminals are provided. Channel No. 9 has an high speed output as well. The nine bit word can be shifted left (ring or open) under manual control at a 500 KC rate if only high speed output is required or at 500 cycles per second if the relay contacts are to be sensed. TSD is not used. (It will not cycle the memory word, but it will DISMISS if no "hold" is used, and it will change E as if it were a OLDE operation.) ## OPERATIONS | - | | | | |---|--------------------------|---------|----------------------------------------------------| | - | IOS <sub>75</sub> 30 000 | Clear | The nine output channels are set to correspond | | 1 | " 001 | SET 1.1 | to quarter 1 (the righthand nine bits) of the | | | " 002 | " 1.2 | instruction. IOS, 30000 therefore clears all | | 1 | " 004 | " 1.3 | nine - IOS <sub>75</sub> 30777 sets all nine. | | | " 010 | " 1.4 | THE SAME SAME | | | " 020 | " 1.5 | There is no raise flag indication. It may be | | | " 040 | " 1.6 | assumed that the relay has changed after 2 milli- | | | " 100 | " 1.7 | seconds. The high speed output "MOM-9" will change | | | " 200 | " 1.8 | before the instruction is over.* | | | " 400 | " 1.9 | | \*Note: Changing bit 1.9 from "1" to "0" produces a standard TX-2 IN-0UT transition (-3 V to ground) at "MOM-9". Going from "0" to "1" produces a similar transition from ground to -3. The rise-fall time for these transitions is less than 0.2 microseconds. MANUAL CONTROLS 2 of 2 ## RELAY CONTACTS C. P. Clare High Speed Relay - HGS - 1009 - Make before break. Up to 1/4 amp non-inductive load. Up to 1 amp reactive load with suppressor only. (Plug-in suppressors are available.) Cycle rate approximately 500 cycles - 2 millisec. period. ## SHIFT CONTROL - 1. Ring Shift Left - 2. Open End Shift Left (all nine, 1.9 is not a sign bit.) - 3. No shift ## SHIFT INPUT SELECTOR The shift rate is determined by the external shift input which may be a sinewave or a pulse train. The shift input selector is a toggle switch which should be thrown toward the source used - up for "SINE", down for "PULSE". ## SINE WAVE INPUT A 15V RMS sine wave is required (e.g. GR Oscillator 1304). Maximum rate 500 KC for High Speed ("MOM-9") output, 500 cycles for relay output. Each cycle produces a one bit shift if "SHIFT CONTROL" is in position 1 or 2. ## PULSE SHIFT INPUT A standard TX-2 Inout Transition (-3 to Gnd) is required. It gives a one bit shift if "SHIFT CONTROL" is in position 1 or 2. Maximum rate: 500 KC for High Speed Output (MOM-9), 500 cycles for relay output. "MOM-9" should NOT be used to trigger the shift, for it may not change bit 1.9 or 1.1. (It would shift the others reliably.) ## NOTE: The shift and pushbutton inputs are not interlocked and can interfere with programmed use. Miscellaneous inputs can be used to synchronize the program and the shift input in use. | | So | here | is | Chapter | 5 | _ | Lights | & | Buttons | | |--|----|------|----|---------|---|---|--------|---|---------|--| |--|----|------|----|---------|---|---|--------|---|---------|--| Many TX-2 users have asked for this chapter. Now that it is out, I hope it teaches them a lesson. The next installment will be a re-issue of the second part of Chapter 4 (IN-OUT). In the past two years, nearly <u>all</u> the IN-OUT units have been modified or replaced, and a few new ones have been added to the system. Please do not stand on one foot waiting for Chapters 1 and 2. There may be some delay there. A. Vanderburgh This technical documentary report is approved for distribution. Franklin C. Hudson, Deputy Chief Air Force Lincoln Laboratory Office # TX-2 HANDBOOK # CHAPTER 5 # LIGHTS AND BUTTONS # TABLE OF CONTENTS | 5-1 | Computer 1 | Room Layout | |-----|------------|---------------------------------------------------------| | | 5-1.1 | Frame Contents - Floor Plan (Fig. 5-1) 5-2 | | | 5-1.2 | Power On-Off Procedures (Fig. 5-2) 5-3 | | | 5-1.3 | Power Alarms - Breakers (Fig. 5-3) 5-3 | | | 5-1.4 | Air Conditioning | | 5-2 | Console In | ndicator Lights (Fig. 5-4)5-5 | | | 5-2.1 | Primary Indicators | | | | (A, B, C, D, E, K, P & N, Q & M, N, & X, FA & F) | | | 5-2.2 | Alarms (Fig. 5-5) | | | 5-2.3 | IN-OUT Indicators (Fig. 5-6) | | 5-3 | Console P | ushbuttons (Fig. 5-5) | | | 5-3.1 | Condition Buttons: (With Lights - "Out" is normal) 5-16 | | | | Suppress Memory - U, T, S | | | | No Overlap | | | | Stop Conditions | | | | Pasofa - (Preset and Start over from Alarm) | | | | Auto Start | | | | Low Speed Repeat | | | | Low Speed Pushbutton | | | | Remote TSP | | | | Suppress Chime | | | 5-3.2 | Action Buttons (Fig. 5-5) 5-18 | | | | Stop | | | | Preset | | | | Clear Alarms, Clear Real Time Clock | | | | Calaco (Clear Alarms and Continue) | | | | Codabo (Count Down and Blast Off) | | | 5-3.4 | Miscellaneous Console Items 5-20 | | | | Audio Control (Fig. 5-8) | | | | Knob Register - 377620 | | | | External Register - 377621 | | 5-4 | TX-2 Sync | System (Fig. 5-9) | | 5-5 | Miscellan | eous Conventions | | | 5-5.1 | Paper Tape Read-in Programs | | | 5-5.2 | Paper Tape Read-in Programs - Listings | | | 5-5.3 | Tape Preparation | Fig. 5-1, TX-2 Floor Plan - March 1963 # 5-1.1 Frame Contents - Floor Plan - F1 Console See Figure 5-3, 5-4, 5-5, 5-6, 5-7, 5-8, 5-9 - F2 Main Frame - B Arithmetic Element, and E Register - C Control, X Memory, P, Q, M, and N Registers - D Sequence Control, Thin Film Memory - E U and T Memories - F IN-OUT Switch - F3 S Memory Register Selection Circuits - F4 S Memory Stack - F5 S Memory Digit Plane Drivers and Sense Amplifiers - F6 TX-2 Mag Tape Drivers and Timing Track Writing Equipment - F7 IBM Tape Control, TX-2 Tape Control, Plotter Control, TX-2 Power - F8 Lincoln Writer Controls, $\alpha\beta$ Clock, Display Box, Misc. Inputs Box, Speech Filters - F9 Plugboards, Datrac, Interval Timer, Misc. Input, Misc. Output, Ampex Mag Tape #### 5-1.2 Power ON-OFF Procedures Fig. 5-2 - Power Panel (in the Power Room) #### Power On: Hold the button in until the warning horn stops. The computer will be "ready" in about 1 1/2 minutes. Run "clear memory" once or twice with parity alarms suppressed. Un-suppress the alarms. the computer should be ready for use. Log the time. (Fig. 5-3) Turn on the Lincoln Writer(s), and the IBM Tape Units. (They have their own power switches.) ## Power Off: Be sure TX-2 tape is at "MAT 0000", before pushing "OFF" button. Log the time. (Fig. 5-3) Turn off the Lincoln Writer(s), and IBM Tape Units. # 5-1.3 Power Alarms - Breakers Fig. 5-3 - Maintenance Console The circuit breakers are located at the top of each frame. When a breaker "lets go", a horn sounds and a light comes on at the breaker panel and at the power panel on the console. The accepted procedure is as follows: | Frame: | What to do: | If that fails: | |----------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------------| | S, T or U Memory: F2, 3, 4, or 5 | a) Dump Power b) Reset the breaker c) Bring Power On | Call for help. | | Computer Frames: | Reset Breaker | Call for help. | | IN-OUT Equipment | Reset Breaker | Call for help - Set Maintenance Switch on Breaker Panel and do not use failing unit. | In any event, log the incident stating the time it occurred, which breaker it was, and what was done. # 5-1.4 Air Conditioning There is a room temperature thermometer on the column at frame 9. It usually reads about 70°F. There are two thermometers for the S Memory Stack. One is behind the stack, the other is in the power room. The power room meters should read as follows: (They are to the left as you enter from the computer room.) | | NORMAL | CALL for HELP | DUMP POWER | |--------------|---------|---------------|------------| | Memory Stack | 60 - 70 | 72 or more | 75 or more | | "MIXED AIR" | 48 - 58 | 75 or more | 80 or more | Fig. 5-4, - Console Indicator Panel # 5-2.1 Primary Indicators The indicator lights for the central machine registers are arranged to be read easily in OCTAL by grouping the binary indicators in columns of 3 lights each. - The least significant bit at the bottom. For example: Filament bulbs are used and therefore vary in light output while the computer is running. (Note also that the bulbs will occasionally burn out and give an erroneous indication.) The table below summarizes the information given by the lights, ## Registers A, B, C, D, E, K These indicators always show the contents of the associated flip-flop registers. (K shows the sequence number last used. - See Chapter 4.) They are not affected by alarms or pushbuttons. The overflow indicators are just above A. #### PK Indicators ${}^{PK}_{\alpha}$ and ${}^{PK}_{\beta}$ are of interest for the most part to the Technicians. They show the ${}^{PK}_{1}$ ${}^{PK}_{2}$ , and ${}^{PK}_{3}$ timing levels. ${}^{PK}_{n}$ , ${}^{PK}_{cf}$ , and ${}^{PK}_{op}$ show the hold bit, configuration bits, and Operation Code of the instruction whose read out cycle is in progress. # QK Indicators $QK_{QC}$ and $QK_{\beta}$ show the QK timing levels. $QK_{cf}$ and $QK_{op}$ show the configuration read from F Memory and the last operation that required a data reference. $QK_{cf}$ is also used to remember the original Index Register Number on deferred address cycles. (The original Index Register is used last.) #### AK Indicators ${\rm AK}_{\alpha}$ and ${\rm AK}_{\beta}$ show the AK timing levels. (There is an indicator for each level. ${\rm AK}_{\rm cf}$ and ${\rm AK}_{\rm op}$ show the configuration (minus permutation) Operation Code of the last Arithmetic Operation. ## ASK - The Arithmetic Step Counter ASK is used to count steps for Arithmetic Operations such as Multiply, Tally, and Divide which are different for different word lengths. #### XWK - The X Memory Counter XWK sets the timing levels for the writing of the Index Registers. # CSK - The Change Sequence Counter CSK sets the timing levels for a Change of Sequence (CSK $^{>}$ $^{10}(octal)$ are the steps that indicates LIMBO.) #### Memory Indicators - Interlocks Most of these are not of interest to programmers. The $\text{PI}_1$ $\text{PI}_2$ , $\text{PI}_3$ , $\text{PI}_5$ , and DFA are of use in interpreting N (see page 5-10). $\text{PI}_2$ indicates a defer cycle is in progress. DFA indicates completion of a defer cycle. #### START-STOP Control - SPR, Start Point Register The left half of this indicator shows the start-stop interlocks and is of interest mainly to Technicians. The right half is the Start Point Register. It is set by the RESET, STARTOVER, and CODABO pushbuttons and is used to set the P register when a change to sequence zero is performed. (See PK2 in the table below.) #### Registers P and N P and N are the selector and buffer for readout of instructions from STUV Memory. P is also called the "Central Program Counter" and N the "Instruction Register". At the start of any instruction, they are, of course, compatible - P gives the address of the contents of N. As the instruction is performed, both are changed. The extent of such change depends on when, in the cycle, the computer was stopped. There are two indicators to help interpret P. Their use is given below: | Indicators | | | | |------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------|--| | "POD" | "P+1" | Contents of P | | | 0 | 0 | P gives the address of the last instruction read out of STUV Memory. (It may have been changed in N - see PK in table on page 5-9.) | | | 0 | 1 | P has been indexed, but not yet used for read out. It gives the address of the next instruction. | | | 1 | 0 | "PmoDified" - P has been changed radically and probably bears no relation to N. (As by a jump, skip, or sequence change.) | | | 1 | has all moured | This situation should not occur. Take a picture of it. | | The interpretation of the N register depends upon the type of operation being performed, and how far the computer has gone before stopping. Instructions require from one to five basic cycles. The first cycles for one instruction can be overlapped with the final cycles of the previous instruction and it is therefore possible for two cycles to be running at the same time. The stop system (stop button, sync system, and slow speed control) is synchronized so that once a cycle has started, it <u>must</u> proceed to completion. There are indicators that tell what cycle is next, but one must exercise ingenuity to determine which one has just finished. The basic cycles are abbreviated as follows: | PK <sub>1</sub><br>(PKAK) | - | Instruction Readout Cycle (Used by AOP instruction - Instruction Readout followed by Arithmetic Cycle) | |---------------------------|---|-------------------------------------------------------------------------------------------------------------------------------------| | PK <sub>2</sub> | - | Intermediate Address Cycle (Deferred Addressing) | | PK <sub>3</sub> | - | Final Address Cycle (Deferred Addressing) | | Q <sub>K</sub> | - | Data Reference Cycle | | QKAK | - | Data Reference followed by Arithmetic Operation Cycle. They are inseparable, but another QK could start before the AK part is over. | | CSK | - | Change Sequence Cycle. | In practice, their order of occurrence depends on the operations being performed and on overlap conditions. The table below shows the cycles for the three basic types of computer operations. | Туре | Op Code (See Chart 7-3) | | Cycles Required | |-------------|-------------------------|-----------------------|------------------------------------------------------------| | | 0 - 7 | (Jumps and IOS) | PK | | 1 | 44, 46, 4, | With deferred address | PK <sub>1</sub> , PK <sub>2</sub> , PK <sub>3</sub> | | 2 | 10 - 57<br>(but not | (Non AE, Non Jump) | PK <sub>l</sub> , QK | | 2 | 44, 46, 47) | With deferred address | PK <sub>1</sub> , PK <sub>2</sub> , PK <sub>3</sub> , QK | | Anna ada da | 62 | (AE operations) | PK <sub>l</sub> , QKAK | | 3 | 60 - 77 | With deferred address | PK <sub>1</sub> , PK <sub>2</sub> , PK <sub>3</sub> , QKAK | The CSK cycle can occur only at the end of an instruction - i.e., only after $PK_1$ , $PK_3$ , QK, or QKAK - never between $PK_1$ and $PK_2$ , nor between $PK_2$ and $PK_3$ . The effect of these cycles on N is as follows: | Cycle | Effect on N | |--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ATT AT BOXED TO BE | This is the initial instruction readout. N will contain the instruction located at the address indicated by P. | | PK <sub>1</sub> | EXCEPT when the operation is JNX or JPX (codes 6 and 7), for on these two operations the right half of N is used for the sign extended index increment (18 bits). | | Seggest<br>Arter | (BUT if the JNX or JPX is deferred, the increment is not added until PK3 so N is not changed during PK1. | | PK <sub>2</sub> | The intermediate deferred address cycle (PK <sub>2</sub> ) is always followed by PK <sub>3</sub> . The intermediate address is read out into N using Q as the selector. All 36 bits of N are changed, but the <u>initial</u> index register number was saved (in QKIR <sub>CF</sub> ) to be used last (in the PK <sub>3</sub> cycle). After a PK <sub>2</sub> cycle, N contains the contents of the memory register given by Q. Bit 2.9 of Q will be 1 due to the defer bit. | | PK <sub>3</sub> | The final deferred address cycle does not do a memory readout. It is known as the "Ultimate Cycle". DFA will be set to 1. N is further changed by adding in the index contents to get the final address. Then the original N <sub>j</sub> bits are restored and the instruction continues. The rest of N is cleared. | | QK | The QK cycle of all index memory operations and SKM (all op codes 10-17) clears the right half of N. For RSX, EXX, AUX, and ADX it is subsequently set from the right half of E which was in turn set from memory and may have sign extension. ADX puts the augend from memory there. The next PK cycle can not be overlapped with the QK cycle of these operations. | | QKAK | QKAK does not change N | | CSK | The change sequence cycle always changes N <sub>j</sub> to the old sequence number. If the new number is zero, the right half of N is set to the contents of SPR (Start Point Register). The rest of N is not changed by CSK. CSK must be followed by PK <sub>1</sub> . | "Control" does not really care about what has been done. It is interested only in what it is allowed to do. Once it has started a cycle, it goes merrily on to completion, but before starting one, it must get past a number of interlocks, one of which is the start-stop system. We can therefore tell what cycle is about to start and with that information, together with a program manuscript, the P register, and the P + 1 and POD indicators, we should be able to deduce where it stopped, and therefore what is in N. The conditions for starting are foretold by indicators PI<sub>1</sub>, PI<sub>2</sub>, PI<sub>3</sub>, PI<sub>5</sub>, and DFA as follows: | | "Interl | ock Indica | tors" | Ilimu fe | Next Cycle | Stopped | |----|-----------------|-----------------|-----------------|----------|-----------------|----------------------------| | PI | PI <sub>2</sub> | PI <sub>3</sub> | PI <sub>5</sub> | DFA | is | After | | 0 | 0 | 0 | 0 | X | PKl | ? | | 0 | 1 | 0 | 1 | 0 | PK <sub>2</sub> | PK <sub>1</sub> | | 0 | 1 | 0 | 0 | 0 | PK <sub>3</sub> | PK <sub>2</sub> | | 0 | 0 | 0 | 0 | 1 | PKl | PK <sub>3</sub> or QK, CSK | | 0 | 0 | 1 | 0 | Х | CSK | ? | | 1 | 0 | 0 | 0 | X | QK or QKAK | ? | Note: "X" means "It can be 0 or 1, it does not matter." "?" means "Any cycle but PK,". ### Registers Q and M Except for defer cycles, Q and M are the selector and buffer for data references to STUV memory. The memory references for deferred intermediate addresses use Q as the selector and $\underline{\mathbb{N}}$ as the buffer (Cycles $PK_2$ and $PK_3$ ). # Indicators N, and X The N $_{\rm j}$ lights are copies of the index tag bits of N (bits 3.6 - 3.1). The X register is the index memory buffer. N $_{\rm j}$ and X will always be compatible, for the X memory is read out even if it is not used. #### Registers FA and F FA and F are the selector (F Address) and buffer for the Configuration Memory. They are always compatible. Fig. 5-5, - Alarms, Conditions and Action Pushbuttons The top row of pushbutton indicators in Fig. 5-5 above is used for the ten TX-2 Alarms, two special indicators, and the Sync System (Section 5-4). All of the alarms except TSAL, USAL, and the "Mousetrap" can be suppressed by pushing the indicator. These pushbuttons have two lights each. The upper light indicates the alarm, the lower light shows that it is suppressed. Suppression of an alarm merely keeps it from stopping the computer. In the case of parity alarms, the suppression allows the computer to use the incorrect information and a new, presumably correct, parity is computed and stored. The light will always come on. The chime must be suppressed separately if not wanted. (See 5-3.1 for chime details.) "MISAL" - the Missed Information Alarm - can also raise flag 41 (In Out Alarms). See Chapter 4, Section 5. Detailed information on each alarm is given in the table below: | ALARM<br>NAME | CAUSE | HAPPENS DURING ** COMPUTER CYCLE | WHAT<br>TO DO | |---------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------| | MPAL | Parity Alarm on readout of data from STUV Memory into the M Register. Q gives the address of STUV Memory register. This alarm can not be programmed. | QK or<br>QKAK | Take a picture. Report failing bit and whether it was "dropped" or "picked up". (if you know what should have been read out.) Try again. | | NPAL | Parity Alarm on readout of instruction into N (location given by P), or on readout of deferred intermediate address into N (location given by Q). | PK <sub>1</sub><br>or<br>PK <sub>2</sub> | Take a picture. Report failing bit as "drop out" or "pick - up". Try again, alarm not programmable. | <sup>\*\*</sup> Because of overlap, another cycle may be running concurrently and the computer will continue until both are completed. | ALARM<br>NAME | CAUSE | HAPPENS DURING ** COMPUTER CYCLE | WHAT<br>TO DO | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | XPAL | Parity alarm on readout of index register into X. N <sub>j</sub> tells which index register. This alarm can not be programmed. | Any<br>Cycle | Take a picture. Report failing bit as "dropout" or "pickup" if you can. Try again. | | FPAL | Parity alarm on readout from F Memory (configuration) into the F register. FA tells which F memory register. | PK <sub>1</sub><br>QK<br>or QKAK | Take a picture. Report failing bit as "dropout" or "pickup". Try again. | | PSAL | P register is set to an illegal address. | PK <sub>1</sub> | Check your program, this alarm can be programmed. If machine malfunction is suspected, take a picture and try again. | | QSAL | Q register is set to an illegal address - either a data reference or a deferred address. Check chart on page 5-10. | PK <sub>2</sub> ,<br>QK, or<br>QKAK | Check your program. This alarm can be programmed and is not likely to be a machine malfunction. | | OCSAL | Operation Selection Alarm: An illegal instruction was readout into N. | PK <sub>1</sub> | Check the program. Take a picture. | | IOSAL | In Out Alarm: This happens on an IOS instruction. The selected device is either broken, on "maintenance", or non-existent. The IOS has had no affect, even if the alarm was suppressed. The N <sub>j</sub> indicators should tell what unit was selected. | PK <sub>1</sub> | Check the device you are selecting or the indicator panel. The in out device is probably on "maintenance". Unless there is a "hands off" sign, throw the maintenance switch down (i.e., not maintenance) and try again. | <sup>\*\*</sup> Because of overlap, another cycle may be running concurrently and the computer will continue until both are completed. | ALARM<br>NAME | CAUSE | HAPPENS DURING** COMPUTER CYCLE | WHAT<br>TO DO | |--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MISAL | Missed Information Alarm: This occurs when the program is too slow for the in-out device, and a new datum or output opportunity has come along before the last was used. MISAL is automatically suppressed if sequence 41 (in Out Alarms) is connected. | Any<br>Time | Probably program trouble. Can happen with PETR, TX-2 Mag Tape, A/D Converter, or IBM Mag Tape. Take a picture. | | TSAL | The T memory selection currents have not died out before a new register selection was demanded. (T memory is 200,000 to 207,777) | Any<br>Cycle<br>Except<br>CSK | Take a picture, report that it happened, and hope it will go away. It can not be programmed or suppressed. | | USAL | Same as TSAL, but for the U Memory. (210,000 - 217,777) | Any cycle except CSK | Same as for TSAL. | | Mouse-<br>trap | This is an extra alarm designed to trap any mouse that may be causing computer trouble. It will be set differently from time to time. As of now, it is set to catch a missed control pulse. | Any cycle | Same as for TSAL - USAL. | | The | following indicators are not true alarm | ns. | | | Priority Patch Indicator | A non-standard priority plug-<br>board is in use. (The standard<br>priority is consecutive numerical<br>orderlowest number having highest<br>priority.) | It doesn't happen - it exists. | Replace the standard plugboard at Frame 2, Bay D. | | Limbo | The computer is running, but all selected sequences are waiting for a flag. | It doesn't happen - it exists. | For most inter- leaved programs, the LIMBO light will be on, for some waiting time is almost unavoidable. If the program seems to have stopped completely, check the interleaving. | # 5-2.3 IN-OUT Indicators The IN-OUT indicators common to most units i.e., "Flag", "Connect", "Status", and "Maintenance" are on the main indicator panel - Fig. 5-4 and Fig. 5-6 (to the right). All sequence numbers have a FLAG, but some have no associated IN-OUT unit and hence no "Connect", "Status", or "Maintenance" indicators ("F", "C", "S", and "M"). The indicators are interpreted as follows: (see also Chapter 4) Fig. 5-6 IN-OUT Indicators | INDICATOR | MEANING | |-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | F - FLAG | The Flag is up - The associated program will be operated as soon as priority conditions allow. | | C - CONNECT | The Associated IN-OUT unit is "connected"; i.e., selected for use. | | S - STATUS | If STATUS = 1 ("ON"), a TSD can be performed. If STATUS = 0 ("OFF"), a TSD will have to wait, for the IN-OUT buffer is still busy processing the last datum. | | M - MAINTENANCE | If M = 1, the Maintenance Switch (at the unit) is up. A select instruction (IOS) will cause an IOSAL (IN-OUT Select Alarm). The unit can not be connected. | The IN-OUT Buffers and special indicators are on a separate panel shown on next page: (See Chapter 4 also). Fig. 5-7 - IN-OUT Buffers and Special Indicators Fig. 5-5, - Alarms, Conditions and Action Pushbuttons # 5-3.1 Condition Pushbuttons (Fig. 5-5) The center row of pushbuttons and some of the bottom row will change the mode of operation and will light up as an indication that the computer is not in its normal mode. The table below shows what they do: | NAME | FUNCTION | |----------------|------------------------------------------------------| | U Memory Off | These prevent the program from using the U, S, or | | T Memory Off | T memories. When the indicators are ON, a PSAL or | | S Memory Off | QSAL will be generated if an attempt is made to | | | use the suppressed memory. | | | Overlapped programs will run slower with "NO OVERLAP | | No Overlap | on, but the indicator lights - especially N - should | | | be easier to interpret. | | No Stop on CSK | | | No Stop on QK | The computer will not stop before the selected | | No Stop on PK | cycle(s). | | No Stop on PK1 | | | | "Preset and Start over from Alarm" and "Auto Start" | | | are usually used together. Auto Start alone is | | PASOFA | equivalent to pushing CALACO about a second after | | AUTO START | the alarm. PASOFA is equivalent to an automatic | | | CODABO after alarm. (Except that the alarm is not | | | cleared.) They are used primarily for maintenance | | | and computer repair. | | NAME | FUNCTION | |---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Low Speed Repeat | This circuit inserts a variable delay between the computer cycles. It operates in conjunction with the NO STOP buttons (i.e., it does not insert a delay before the selected cycle(s)). There can be no OVERIAP when this mode of operation is used. The inserted delay (and therefore the effective computer speed) is controlled by the right-hand switch-knob at the bottom left corner of the control panel (Fig. 5-5). (It is labeled L.S.R.) | | Low Speed Pushbutton | This circuit inserts a "STOP" before each computer cycle unless the "NO STOP" buttons are on. There can be no overlap. | | Hold on LSPB | "Hold on Low Speed Pushbutton" - In this mode, all instructions are treated as, if their hold bit were set. This allows step-by-step operation of a low priority program without any interruption due to a change of sequence. | | Remote TSP | There is a portable control panel that contains some of the condition and action buttons and another 18-switch toggle START register. It can be plugged in at Frames 9, 3, and 2, and also behind the console. (It contains condition buttons: Low Speed Repeat, Low Speed Pushbutton, Remote TSP, the Sync Stops; and action buttons: CODABO, PRESET, CALACO, and STOP. | | No Chime on SUPP ALMS No Chime on SUPP ALMS | SUPP means "not suppressed". The circuits were designed for two different chimes but only one tone is commercially available at present. These condition buttons have no other effect. | Fig. 5-5 - Alarms, Conditions and Action Pushbuttons There are six buttons that actually do something. Their use is outlined in the table below. No information registers (Memory or AE) are affected. There is no clear memory button. | BUTTON | FUNCTION | | | |---------------------------|-----------------------------------------------------------|--|--| | lear unertain solder | "Count Down and Blast Off" - CODABO is the most | | | | THE RESERVE OF THE PERSON | commonly used start button. It is roughly equivalent | | | | | to STOP, CLEAR ALARMS, PRESET, STARTOVER, and CALACO | | | | | in that order. Its effect is to clear all flags, preset | | | | | all interlocks, and start the computer at the memory | | | | CODABO | location given by the Toggleswitch Start Register (TSP) | | | | | or the remote TSP, if selected. There are 9 CODABO | | | | | buttons - 8 for the fixed addresses - 377710 to 377717 | | | | | and the ninth for the two toggle START registers (Console | | | | 0.0740 -200 10041 | and Remote). CODABO leaves the SPR (Start Point Register) | | | | | set to the chosen starting place. | | | | | | | | | | "STOP" is synchronized so that the computer will | | | | | complete the cycles it has started. Except for start- | | | | STOP | stop interlocks, no registers or indicators are directly | | | | | affected. | | | | BUTTON | FUNCTION | |-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CALACO | "Clear ALarms and COntinue" - CALACO merely resumes operation where it left off. If no flags are up, the computer will go into LIMBO. The combination of STOP and CALACO has no effect on a single sequence non-InOut program, but will probably upset IN-OUT and interleaved programs because of the timing. | | RESET | There are nine RESET buttons - eight of them load the SRP with the fixed addresses 377710 to 377717. The ninth loads SRP from the selected Toggle Start Register (Console or Remote). RESET has NO OTHER EFFECT. The SRP is, in effect, a partial placekeeper for sequence zero. If the program raises flag zero, sequence zero starts at the place indicated by SRP. SRP is not changed when sequence zero drops out as the other placekeepers are. It can be changed only by pushbuttons. | | STARTOVER | Nine STARTOVER buttons are available. They are equivalent to RESET plus a "Raise Flag Zero". STOP followed by STARTOVER will not do much, for STARTOVER does not start the computer. If the computer is running or in LIMBO, STARTOVER will be effective for Flag Zero has priority over all others no matter which priority plugboard is in use. STARTOVER followed by CALACO is similar to CODABO, but does not clear the Flags and interlocks. | | PRESET | There is but one PRESET button. Like RESET, it is seldom used by programmers. It clears all flags and In-Out "Connect" flip-flops, and sets all interlocks and indicators to their proper "PRESET" value. This button is interlocked so that it is ineffective unless the computer is stopped. | | Clear SUPP ALMS | Suppressed Alarms are handled by separate circuits and a pushbutton is supplied for each type. SUPP means "not suppressed". | | Clear Real Time<br>Clock<br>(Reg. 377630) | The Real Time Clock is indexed automatically every 10 microseconds. It will clear itself every 7.6 days or so if it is left alone. (The toggle switch to the right of the indicator turns the indicator lights off but has no effect on the Clock Register.) | ### Audio Controls Fig. 5-8 - Audio Controls For the convenience in trouble-shooting, to reassure users that the machine is running, and to further the progress of research, TX-2 has been made audible via two separate, independent, and identical Audio Systems. The Selector switches have ten positions, five of which are currently in use and wired as follows: - Quarter 1 of the X Register (Analog signal decoded from indicator Circuit.) - Quarter 2 of the X Register (Analog signal decoded from indicator Circuit.) - 3. Vertical Display Decoder (Sequence 60) - 4. Horizontal Display Decoder (Sequence 60) - 5. The Patch Panel at Frame 9. The inside knob of the selector switch is the main volume control. The microphone input is mixed in at all selector settings and has its own level control. #### Knob Register - (377620) Register 377620 - The Knob Register - also called the "Shaft Encoded" Register is located just below display #1. It is similar to a toggle register except that it is set by four knobs - one for each quarter. The metabit is a lighted pushbutton switch. (Eight revolutions cover the range 000-777.) # External Input Register - 377621) Register 377621 - The External Input Register - is a set of four plugs just to the right of the marginal check panel (Fig. 5-3). There exists a box with 37 pushbuttons intended for use with (or as) the external register. These pushbuttons are directly analogous to toggles except they must be held down if they are to stay a "1". (Unlike the keyboard, any number may be down together.) Note: Contact bounce is about the same as the toggle contact bounce - a delay of 10 ms allows a small safety factor. # Clock Register - (377630) Register 377630 is a 36-bit counter indexed every 10 microseconds by an external oscillator. It can be cleared by pushbutton (Fig. 5-5), but <u>not</u> by a programmed instruction (such as STA or DPX). Fig. 5-9 - TX-2 Sync System The Sync System produces an output signal when certain manually preselected conditions are met. - For example: - a) When (or if) the program gets to a prespecified memory location. (i.e., [P] = preset value) - b) When a certain memory register is used for data or deferred address. (i.e., [Q] = preset value) - c) When a certain operation is used. (i.e., [PK<sub>op</sub>] = preset value) - d) When a certain sequence number is used. Certain combinations are possible. The output can be switched to any or all of the following: | OUTPUT | SWITCH LOCATION | COMMENT | | | |----------------------------------|--------------------------------------|---------------------------------------------------------------------------|--|--| | Stop on SYAL #1 | Top Row Pushbuttons (Fig. 5-5) | There are two alarms and two condition selectors, | | | | Stop on SYAL #2 | Right next to SYAL 1 | but only one set of condition parameter switches. | | | | Signal to Sync<br>Jacks | On Sync Panel<br>(Fig 5-9 above) | Uses for scope sync during computer repair and maintenance. | | | | Raise Flag 42<br>(trap sequence) | Bottom Row Pushbuttons<br>(Fig. 5-5) | See Chapter 4 - Trap Sequence. This button over- rides other trap modes. | | | | Sync Stop to Arithmetic Element | Top Row Pushbuttons<br>(Fig. 5-5) | Used mainly for mainten-<br>ance to Stop AE operations<br>within a cycle. | | | Figure 5-9 shows the two SYNC SYSTEM panels. The lower panel contains the Sync Parameter Switches; the upper panel the Sync Condition Selecting Switches and the output-to-Sync jacks pushbutton switches. #### Parameter Switches There is but one set of switches for each parameter even though there are two sets of selectors. The parameter switches are laid out in four major rows: INSTRUCTION (PK , N) CHANGE SEQUENCE COUNTER, and INSTRUCTION LOCATION (CSK, P) DATA CYCLE (QK , Q) ARITHMETIC CYCLE (AK) Each parameter set is grouped, like the indicators (see Fig. 5-4, and Section 5-2.1) in columns of 3 for Octal interpretation. The least significant bit is at the bottom. #### Condition Selector Switches There are two SYnc stop ALarms (SYAL 1 and SYAL 2). These are controlled by two "GATES" (Gate 1 and Gate 2). The "GATES" are controlled by two sets of condition switches - 32 switches each. Either gate or both can supply output pulses to the sync jacks or stop circuits. (Only the alarm indicators are separate.) ALL the selected conditions must be met for the output to be generated. (The GATES are AND circuits.) The conditions available are described below: | CONDITION | COMMENT | | | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | PKα | See upper left corner - Fig. 5-9. ${\rm FK}_{\alpha}$ refers to the 32 possible time steps (levels) of the PK cycle counter and therefore determines when the sync signal will be generated. A setting of ${\rm ^{16}(oct)}$ is recommended, for it provides a definite time to stop, and is used by all instructions. ${\rm PK}_{\alpha}$ is recommended when any of the "P"-type conditions are used. | | | | PK <sub>op</sub> | This compares the PK parameter switch setting with the operation most recently read out of memory. (Bits 4.3 to 3.7) | | | | PK <sub>cf</sub> | This compares the configuration switch setting with the configuration bits most recently read out. (Bits 4.8 to 4.4) | | | | PKh | "h" refers to the hold bit of the instruction most recently read out. (Bit 4.9) | | | | CONDITION | COMMENT | |--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P | P refers, of course, to the P register. * The Parameter switches are in the second major row. | | QK <sub>Q</sub> | This condition allows selection of the time step when the sync pulse is generated. A setting of 2 is recommended. $QK_{\alpha}$ and $PK_{\alpha}$ should not be used concurrently unless a particular type of overlap condition is sought. | | QK <sub>Op</sub> | This set looks for a particular operation, just as does PK op , but only those instructions that require a data reference will ever get into QK op indicator lights are at the left - Fig. 5-4. They are sometimes helpful in debugging, for they tell what operation made the last data reference.) | | | Q is used for intermediate deferred addresses as well as data references, but these two can be separated somewhat via $QK_{\alpha}$ . With Q and $QK_{\alpha}$ selected, the sync output will occur only for data references since the PK counter is used for the defer cycles. | | N <sup>4</sup> .10 | The circuitry is able to detect <u>set</u> metabits on instructions but <u>not</u> zero metabits. If the parameter switch is down and the selector switch is up, no sync pulse can be generated for the gate in use. | | M <sup>4</sup> .10 | The data reference metabit (M <sup>4.10</sup> ) can be detected only when set (just as N <sup>4.10</sup> above). Note that it can be changed without a memory reference for it serves as the metabit of the A, B, C, D, and E registers. (i.e., MKC <sub>4.10</sub> A or MKC <sub>4.10</sub> B will change bit 4.10 of M. | | Ng | "N $_{\rm j}$ " refers to the "j" bits of the N register and hence to the index register in use, or to the bit selection of an SKM operation. | <sup>\*</sup> If the instruction that has been interrupted used a deferred address, CALACO will not continue the program until the third time it is used. (Since P is not changed until the last moment, a Sync Stop occurs during the intermediate cycle, and again during the "ultimate" cycle.) | CONDITION | COMMENT | |------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ad Pagister S wa | "AK $_{ m CC}$ " is the Arithmetic Instruction Time Level | | AND DESIGN SHEETS | counter. There is one switch for each level (it there- | | AKa | fore makes little sense to have more than one up). The | | u | recommended setting is OFF - it is mainly for maintenance use. | | Ave | "AK " is a 6-bit register that holds the most | | AK <sub>op</sub> | recent <u>arithmetic</u> operation (code values are all <u>above</u> 57). It is not changed until another arithmetic operation is performed. | | ASK | ASK is a 7-bit counter used for arithmetic operations that require repetitive steps - for example, multiply and divide. It clicks along during shifts and cycles, but is not used. | | X <sub>2.9</sub> | X <sub>2.9</sub> is the sign bit of the X memory buffer. It can be used, for example, to detect completion of a JNX or JPX loop. | | N <sub>2,1</sub> | $\mathrm{N}_{2,1}$ is the right half of the N register. It is especially useful for detecting a jump to a specified location. | | К | K holds the current sequence number. It is often useful in conjunction with CSK below. | | ) -creation or non- | CSK - The Change Sequence Counter - will remain zero until a change of sequence occurs. A setting of | | CSK | 10 ( $CSK_{4} = 1$ ) detects a change into LIMBO, a setting of l is recommended if K is used for the Old Sequence; a setting of 6 if K is to be set to the New Sequence. In either case, the CSK cycle will be completed before the computer stops. | | B, C, D,<br>F, MT, IOI | These letters refer to open cables at Bays B, C, F, of Frame 2, the Mag Tape Frames (F6, 7, 8), and Frame 9 (IOI). They are used by the maintenance technicians for | # 5-5 Miscellaneous Conventions 5-5.1 Paper Tape Read-in Programs - Plugboard Memory (377740 - 377777) contains three standard programs. They are as follows: | CODABO<br>POINT | NAME OF<br>PROGRAM | COMMENT | |-----------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 377770(8) | "Clear Memory" or "Smear Memory" | All of S,T, and U Memory is set to +0 in the Left Half word and each register's own location in the right. Metabits are not changed. This program proceeds automatically to 377750 - Set Standard Config - and then to 377760 - Read in Reader Leader. (See below.) | | 377750<br>(8) | Set Configuration | All of F Memory is set to the standard configurations and the program proceeds automatically to 377760 - Read in Reader Leader | | 377760(8) | Read In | This program reads the first 21 words from paper tape into registers 3 through 24 of S Memory, and then goes to register 3. All binary tapes start with the "Reader Leader", a block of 21 words that is the TX-2 Read in Program. The TX-2 Read-in program will read any standard binary block and check the sumcheck at the end. (If the check fails, the program tries again.) The meta-bit of each word being stored is cleared. See listings below. See Section 6-3.4, page 6-23 for Binary Format. | <sup>\*</sup> There are two plugboards: Plugboard "B" - registers 377740 to 377757, and Plugboard "A" - registers 377760 to 377777. "READER LEADER" # TX-2 Paper Tape Input Program [For Binary Format] | LOCATION | INSTRUCTION * | NUMERICA<br>(OCTA | | |----------|------------------------------------|-------------------|--------| | 0 | 0 | 000000 | 000000 | | 1 | 1 | 000000 | 000001 | | 2 | 2 | 000000 | 000002 | | 3 | 1 RSX 545 | 011154 | 000005 | | 4 | 36 JMP 54 20 | 360554 | 000020 | | 5 | h <sup>2</sup> RSX <sub>53</sub> 0 | 421153 | 000000 | | 6 | STE 11 | 013000 | 000011 | | 7 | 36 JMP 5417 | 360554 | 000017 | | 10 | ALDE O | 402000 | 000000 | | 11 | STE 5 3 4 | 003053 | 000034 | | 12 | h <sup>1</sup> JNX <sub>53</sub> 7 | 410753 | 000007 | | 13 | 36 JMP 5 4 20 | 360554 | 000020 | | 14 | hJPX <sub>56</sub> 377760 | 400656 | 377760 | | 15 | hJNX <sub>56</sub> 377760 | 400756 | 377760 | | 16 | 14 JPQ 27 | 140500 | 000027 | | 17 | MKZ <sub>4·12</sub> 400011 | 021712 | 400011 | | 20 | 1 RSX 573 | 011157 | 000003 | | 21 | ATSD 0 | 405700 | 000000 | | 22 | 36 JPX 57 <sup>21</sup> | 360657 | 000021 | | 23 | 1 AUX 5 6 0 | 011056 | 000000 | | 24 | h <sup>2</sup> AUX <sub>56</sub> 0 | 421056 | 000000 | | 25 | STE 16 | 013000 | 000016 | | 26 | 15BPQ <sub>54</sub> 0 | 150554 | 000000 | | 27 | 11055220000 | 010452 | 020000 | | | | | | <sup>\*</sup> Registers 0, 1, and 2 are not part of the Reader Leader itself, but are used as temporary storage. # PLUGBOARD PROGRAMS | LOCATION | INSTRUCTION | NUMERICAL FORM<br>(OCTAL) | |----------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 377740 | 760,342,,340,000 | 760342 340000 | | 377741 | 410,763,.762,761 | 410763 762761 | | 377742 | 160,142,,140,411 | 160142 140411 | | 377743 | 202,163,,162,161 | 202163 162161 | | 377744 | 732,232,,230,200 | 732232 230200 | | 377745 | 605,731,,730,733 | 605731 730733 | | 377746 | 320,670,,750,600 | 320670 750600 | | 377747 | 604,331,,330,333 | 604331 330333 | | 377750 | SPG 377740 | 002200 377740 | | 377751 | <sup>4</sup> SPG 377741 | 042200 377741 | | 377752 | <sup>10</sup> SPG 377742 | 102200 377742 | | 377753 | <sup>14</sup> SPG 377743 | | | 377754 | <sup>20</sup> SPG 377744 | 202200 377744 g | | 377755 | <sup>24</sup> SPG 377745 | 142200 377744 publication of the state th | | 377756 | <sup>30</sup> SPG 377746 | 302200 377746 | | 377757 | <sup>34</sup> SPG 377747 | 342200 377747 | | 377760 | 1 SKX 5 4 2 3 | 011254 000023 | | 377761 | REX <sub>52</sub> 377763 | 001252 377763 | | 377762 | 21 IOS <sub>52</sub> 30106 | 210452 030106 | | 377763 | REX <sub>53</sub> 5 | | | 377764 | hTSD <sub>54</sub> 26 | 405754 000026 g | | 377765 | h <sup>36</sup> JPX <sub>53</sub> 377764 | 001253 000005 pred 405754 000026 pred 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 | | 377766 | h <sup>1</sup> JNX 54 377763 | 410754 377763 | | 377767 | 14 JPQ 3 | 140500 000003 | | 377770 | REX 77207777 | 001277 207777 | | 377771 | DPX 7777776 | 001677 777776 | | 377772 | 14 JPQ 377773 | 140500 377773 | | 377773 | REX 777610 | 001200 777610 | | 377774 | h <sup>36</sup> JPX <sub>77</sub> 377771 | 760677 377771 | | 377775 | 30 SKN <sub>4.12</sub> 377744 | 301712 377744 | | 377776 | 77,,0 | 000077 000000 | | 377777 | <sup>14</sup> JPQ 377750 | 140500 377750 | | | | | <sup>\*</sup> The X Memory is not changed, but each register is "exercised" to remove possible XPAL alarms. # 5-5.3 Tape Preparation (See Group Report 51-8, dated 6 October 1959) \*\*TEST LDA GG. An abbreviated manuscript and associated tape is shown below: # TX-2 USERS HANDBOOK CHAPTER 6 - TX-2 UTILITY SYSTEM # TABLE OF CONTENTS #### 6-1 INTRODUCTION - TYPICAL USE OF M4 ASSEMBLY PROGRAM - 6-1.1 MANUSCRIPT, DIRECTIVE, LISTING - 6-1.2 META LANGUAGE - 6-1.3 MACRO INSTRUCTIONS #### 6-2 M4 PROGRAMMING LANGUAGE - 6-2.1 INSTRUCTION WORDS - 6-2.2 SYMEX DEFINITION TAGS EQUALITIES AUTOMATIC ASSIGNMENT - 6-2.3 RULES FOR SYMEX FORMATION - 6-2.4 NUMERICAL FORMAT USE OF COMMAS - 6-2.5 MEMORY LOCATION OF PROGRAM ORIGINS - 6-2.6 RC WORDS RC BLOCK - 6-2.7 WORD ASSEMBLY - 6-2.8 SPECIAL SYMBOLS #### 6-3 META-LANGUAGE FOR CONTROL OF M4 ASSEMBLY - 6-3.1 META-COMMAND FORMAT - 6-3.2 M4 OPERATION NAME, CLEAN, LW READ, RECONVERT, BINARY STORE, GOTO - 6-3.3 META-COMMANDS FOR MAKING CHANGES INSERT, DELETE, REPLACE, MOVE - 6-3.4 M4 OUTPUT LISTING, DIRECTIVE, ERRORS, PUNCH (BINARY TAPE) - 6-3.5 M4 FORMAT VARIATION DEC, OCT, T = CR, T = TAB, RC STORE, XXX - 6-3.6 USE OF SPECIAL KEYS - 6-3.7 MAGNETIC TAPE BULK STORAGE SAVE, READ, TAPE, CORE - 6-3.8 META-COMMAND SUMMARY # 6-4 MACRO INSTRUCTIONS - 6-4.1 MACRO DEFINITIONS META-COMMANDS "DEFINE" AND "EMD" - 6-4.2 THE MNEMONIC ABBREVIATION LINE OF A MACRO DEFINITION - 6-4.3 MACRO NAMES - 6-4.4 DUMMY PARAMETERS - 6-4.5 MACRO TERMINATORS - 6-4.6 THE DEFINING SUBPROGRAM - 6-4.7 USE OF MACRO INSTRUCTIONS # CHAPTER 6 TX-2 UTILITY SYSTEM # 6-1 INTRODUCTION - TYPICAL USE OF M4 ASSEMBLY PROGRAM The TX-2 Assembly Program "M4" is a conventional symbolic assembler, but has considerable flexibility and two types of special features - Meta-Language for control of the program, and Macro Instructions, a feature that gives M4 the essential characteristics of a compiler. The symbolic tags for address sections can be nearly any combination of letters, symbols, and numerals (with a few restrictions). Tags used for the configuration and index syllables are nearly as flexible. M4 will assign all tags that have not been assigned by the user. The program is designed for on-line keyboard input and control as well as paper tape input. After checkout has started, a program can be kept in symbolic form in magnetic tape bulk storage. Typical use of M4 begins with off-line tape preparation using a Lincoln Writer (See Group Report 51-8.). During debugging, the program can be preserved in symbolic and/or binary form on paper tape or in mag tape bulk storage as the user wishes. The symbolic form saved by the program is called a "DIRECTIVE" and is essentially the same as the original manuscript. Additions, insertions, relocation, rearrangement, and deletion are all handled by the M4 system - it is not necessary to retype the manuscript. In addition to DIRECTIVE output (via Xerox, Lincoln Writer, Paper Tape, or Magnetic Tape), one can also get a <u>LISTING</u> (via Xerox, Lincoln Writer, or Punch). A LISTING is a copy of the program in absolute as well as symbolic format (side-by-side). It includes an alphabetically ordered tag table and a FORMAT ERROR notice if any errors were found. A LISTING can be obtained on punched paper tape for off-line Lincoln Writer printout, but this tape is not acceptable as input. The binary form of the users program can be stored directly in the computer memory, punched in binary format on paper tape, or stored in magnetic tape bulk storage. When stored directly, either on mag tape or in memory, the M4 program area is protected and the storage may be incomplete. If a DIRECTIVE exists in core memory it too is protected. #### 6-1.1 MANUSCRIPT - DIRECTIVE - LISTING A "Manuscript" is any program prepared off-line. It may exist in printed, hand written, or punched tape form. A <u>DIRECTIVE</u> is the symbolic form created by M4. It may exist within M4 temporary storage, in magnetic tape bulk storage, or in printed or punched form. A <u>DIRECTIVE</u> closely resembles the manuscript. The following changes are worth noting: - 1.) Any corrections and/or insertions have been made. - 2.) All definitions and equalities are at the beginning. (Equalities may be anywhere on a manuscript.) - 3.) Redundancies such as extra spaces are removed. - 4.) Fractions are converted to the equivalent integer. The Numeral System is preserved. - 5.) A check sum is added at the end. A LISTING is a program output in absolute as well as symbolic format. The format is as follows: Tag Table (Alphabetical) Equalities Macro Definitions Format Errors Program (in symbolic and absolute) RC Words (unless the RC block location was specified within the program.) (The Tag Table, Errors, absolute program, and RC block are <u>not</u> part of a Directive.) #### 6-1.2 META-LANGUAGE The control of the M4 program is accomplished through the M4 Meta-Language instructions. All meta-language commands are to be preceded by (two hands). When used on a manuscript, meta-commands are obeyed on read-in and do not appear on the directive (Except for those like FRC, which is used to specify the location of the "RC Block" - (Register Containing).). The basic types of Meta-Language Commands are: Input Correction-making Output Mag Tape Format Macro Definition Direct Storage Single Pushbutton #### 6-1.3 MACRO INSTRUCTIONS A macro instruction is essentially a convenient flexible abbreviation for a similarly convenient and flexible subprogram. The user writes the subprogram once - with dummy parameters - as a "MACRO DEFINITION". Tags, and equalities used in the definition are kept separately and are not part of the program proper. When a macro instruction is used, only those parameters that are needed should be specified. The portions of the defining subprogram that refer to unspecified parameters are left out when the macro is converted. For this reason, and since the parameter of one macro can be the abbreviation for another, a different set of instructions will usually be compiled for each use. Some standard macro instructions will be built into the M4 system. When they are used on a manuscript, the definition will appear on the M4 Directive and Listing. Since Macro Instructions can be redefined, it will not be necessary to avoid using the standard names except to avoid confusion when reading a program later on. ### 6-2 M4 PROGRAMMING LANGUAGE #### 6-2.1 INSTRUCTION WORDS A TX-2 instruction word has 4 basic syllables and three special indicators as shown in the diagram below: The three indicators are preassigned symbols as follows: BIT 4.10 = meta bit (not part of binary tape format) BIT 4.9 h = hold bit To no hold bit (Needed because h is automatically included with LDE, ITE, JPX and JNX.) BIT 2.9 \* = defer bit They must be in normal script, and may appear anywhere in the word. The four basic syllables are as follows: - "c" "Configuration" syllable a 5 bit word (bits 4.4 4.8) used as the F memory address or as an extension of the instruction syllable (JMP, IOS, SKM, SKX). This syllable must be in <u>superscript</u> or preceded by | . It can be numerical or symbolic, but no spaces are allowed. For SKM, JMP, and SKX it is specified automatically by the supernumerary mnemonics. (See Table 7-3.) - "i" "Instruction" syllable a 6 bit word. This syllable is a normal script, 3 letter standard mnemonic abbreviation for the instruction. It is terminated by a space as well as the standard symex terminators. The mnemonic abbreviations include the configuration syllable as well for JMP, SKM, and SKX. (See Chart 7-3.) The instruction syllable may be specified numerically or with a normal symex but in these cases it is not terminated by a space. A regular symex terminator must be used. (See 6-2.2, rule #8.) - "j" "Index" syllable a 6 bit word used as the X memory address, i.e., the index register tag. (Except for SKM where it is used for bit designation.) The "j" syllable is normally in <u>subscript</u>. It may be a numeral or a symex, but no spaces are allowed. - "k" "Base Address" a 17 bit word. The base address may be symbolic or numerical and spaces may be used as part of a symex. It is given in normal script. Redundant spaces are removed upon conversion. It is not necessary to use the order shown above. Any ordering is allowed if the script and symex conventions are carefully used. For example: $$^{\alpha}$$ ADD $^{7}$ , or ADD $^{\alpha}$ T, or ADD $^{7}$ , $||$ $\alpha$ or $^{\alpha}$ T, ADD ## 6-2.2 SYMEX DEFINITION - TAGS - EQUALITIES - AUTOMATIC ASSIGNMENT A "Symex" is a symbolic expression. It is converted to a numeral by M4 when a program is stored, punched in binary format, or listed. A "TAG" is a symex used as a name for a place in a program. A tag is always terminated by an arrow ( $\rightarrow$ ), and is set to the numerical location of the word that it tags. A symex can be set equal to a numeral directly - e.g., "apple = 6", or to any 36 bit word. For example a symex may be set equal to an instruction. When such a symex is used as the instruction syllable in a normal word, it must be terminated by a symex terminator - not by "space" (Only Standard mnemonics are terminated by space.) A symex that is not used as a Tag nor defined by equal sign will be assigned by M4 according to its use within the program. See chart below: ### Unassigned Symexes: | Used to Specify: | Automatically Assigned as or to: | | |-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Configuration Only | Zero | | | Index Only | The lowest numerical index register value not already used. (Except Zero and no higher than 77.) | | | Configuration and Index | Zero | | | Address only | The numerical memory location of the next place in the RC words block. The contents of this RC word are set to zero. This provision is useful in assigning temporary storage. | | | Configuration and Address | Zero | | | Config., Index, and Address | Zero | | | Index and Address | Same as Index Only. | | | Origin (i.e., Memory Location of Block) | "N", where N is the numer of words in the program including the RC Block. | | A symex assigned by M4, or by equals sign may be redefined at any point in a program manuscript, and the <u>latest definition</u> will be used <u>throughout</u>. If the symex was initially assigned as a Tag - i.e., with an <u>arrow</u>, a re-definition will be recorded as a double definition error, and will be accepted, but not <u>corrected</u>. The only way to remove it from the directive is to use meta-language (REPLACE) and refer to it with a relative address based on a different tag. # 6-2.3 RULES FOR SYMEX FORMATION 1. A symex must contain at least one non-numerical character. 6-6 - 2. It may contain as many legal characters as desired. - 3. The single letters A, B, C, D and E are preassigned to the numerals 377604 377610. (i.e., the AE addresses.) - 4. The three letter mnemonic instruction abbreviations can not be used as symexes. - 5. The preassigned abbreviations and single letters can be used as part of a symex if they are not separately terminated. Note that <u>space bar</u> terminates op codes and single letter AE addresses but does not terminate other symexes. October 1961 - e.g. "ATYPE" or "TYPE A" are allowed. "A TYPE" is equivalent to "377604 + TYPE". "ADDY" is allowed "ADD Y" is not. (ADDY is a legitimate Symex ADD Y is a two syllable instruction.) - 6. The legitimate symbols are: 0 1 2 3 4 5 6 7 8 9 A through Z αβγΔελ i j k n p q t w x y z (NOT h) · (PERIOD) ' (APOSTROPHE) — □ O and Space Bar. 7. Compound Characters are allowed when the following restrictions are applied: Only one backspace. Two or three characters only. Space bar is allowed. Any sequence of characters is legal. (Except $\odot$ , $\ominus$ , $\ominus$ ) 8. The following symbols terminate symexes: r / x v A c ≡ ~ < > ∪ n , (COMMA) = → | # h + - ? SCRIPT CHANGES, TAB, CARRIAGE RETURN, COLOR CHANGES, LINE FEED UP, DOWN { } ) ( || \* ∑ #### 6-2.4 NUMERICAL FORMAT - USE OF COMMAS M4 will accept integers or fractions in Decimal or Octal. It will not accept mixed numbers, except as a SKM bit designation. The details are handled by the position of the period. See chart below: | Periods | Numeral Type | Example | Equivalent Octal Integer | | | | |------------|---------------------|---------|-------------------------------|-----|-----|-----| | None | Octal Integer | 431 | 000 | 000 | 000 | 431 | | Preceeding | Octal Fraction | .431 | 214 | 400 | 000 | 000 | | Following | Decimal Integer | 431. | 000 | 000 | 000 | 657 | | Both | Decimal Fraction | .431. | 156 | 254 | 020 | 303 | | Centered | SKM Bit Designation | 2.10 | 000 | 000 | 000 | 052 | | | | | (i.e., 10 1010 <sub>2</sub> ) | | | | Note: The SKM Designation is usually given in subscript and is, therefore, moved to bits 3.1 - 3.6. - Note: a) The meta-command \*\*DECIMAL reverses the meaning of a "following" period. \*\*\*OCTAL restores it to the above. - b) The two parts of an SKM Bit Designation are Decimal integers. - c) Numbers may be preceded by Plus (+) or Minus (-). For example: (Octal Integer 400 000 000 000 = 377 777 777 777.) - d) M4 converts fractions to Integer form for Directives. The Numeral System is preserved. Commas are used to specify separate subwords as follows: - a) The word is set to +0. (Any unspecified portions will therefore stay at +0.) - b) The word is assembled from left to right. - c) The numeral (or any other word) is converted to a 36 bit binary word. - d) This 36 bit word is inserted into Memory according to the comma chart. ## COMMA CHART | COMMAS BEFORE | COMMAS AFTER | CRAM DIAGRAM | EXAMPLE | | | | |---------------|---------------|--------------|---------|-----|-----|-----| | 0 | 0 | ++++ | 444 | 333 | 222 | 111 | | 0 | 1 | | 111 | - | - | - | | 0 | 2 | | 222 | 111 | - | - | | 0 | 3 | 111 | 333 | 222 | 111 | - | | 1 | 0 | | - | - | - | 111 | | SE BEALERAD : | MAT , INDEANS | 1/ | - | 222 | 111 | - | | 1 | 2 | | - | 111 | - | - | | 1 | 3 | + + + | 444 | 333 | 222 | - | | 2 | 0 | + + | TADERY | MIN | 222 | 111 | | 2 | 1 | 1 | - | - | 111 | - | | 2 | 2 | >>> | 222 | 111 | 444 | 333 | | 2 | 3 | 1 | mus be | 200 | 444 | 333 | | 3 | 0 | + | - | - | - | 111 | | 3 | 1 | - | 775 | - | - | 444 | | 3 | 2 | 1 | eces. | 444 | - | - | | 3 | 3 | 1 | uni. | - | 444 | 333 | For example: To specify 1/2 in each quarter, write To specify an instruction in the right half word as well as its normal position in the left, write #### 6-2.5 MEMORY LOCATION OF PROGRAM - ORIGINS The location of the first word of a block is to be specified in numerical or symex form and is terminated by a vertical bar. It may be on a line by itself, as it will be on DIRECTIVES, or it may preceed a normal word. The symex may be recursive - i.e., set equal to another symex. If the recursive symex is circular (i.e., eventually equal to itself,) or if it is undefined, the block will be located incorrectly, and no alarm is generated. (It will appear to be located a "n", where "n" is the number of words in the program, but the RC words are assigned as if it were located at zero.) If there is no origin (i.e. no vertical bar), the whole program is located (correctly) at 200 000(8). See the examples below. | HAG6 | HAG6=77 | |----------|-----------| | | LDA BOSY | | | STA HUPG | | 22 JAC→ | JPQ MOUSE | | | | | | | | HAG6+100 | | | | +413,,5 | | | -563,51 | | | | | 516 | LDE TOMM | | | STE JERRY | | H→ | JPQ HEHE | | | | If the origin is specified by a symex (as "HAG6" above), the block may be moved by redefining the symex via equal sign. If the origin was assigned numerically (e.g. 516 above) it can be changed by REPLACE, counting back from an honest tag. For example, to move the block at 516 to location 5516, the proper metacommand would be FFREPLACE H-3 5516 Note that the Origin itself counts as a full line. Since it is often more convenient to specify an operand directly rather than by its address, M4 interprets any word within brackets, e.g. {3456} as an operand by providing a register containing the bracketed word, and using its address wherever the same word is used within brackets. (Bracketed words are called "RC Words" from "Register Containing".) The "RC Block" is made up of RC words, i.e. bracketed expressions and temporary storage assigned to unassigned symexes used in address sections. It is located at the end of the last program block unless otherwise specified by meta language. Examples: SUB [10] "w" can be any 36 bit word. DICK→ LDE {GEORGE→ LDA T\_} Words within the RC Block may be Tagged. If such a word is changed via meta language, the change should be made where it is used (i.e. at "DICK") rather than inside the RC Block (i.e. at "GEORGE"). A change made within the RC Block will not appear on a subsequent DIRECTIVE. To be lasting, such a change should be made outside the block. FFREP DICK FFREP GEORGE LDA {GEORGE→ 3} GEORGE→3 \*\*PERMANENT \*\*TEMPORARY "RC Words" may contain other RC Words - i.e. the brackets may be "nested". For example: # LDA {LDE {-13}} The brackets must balance - there must be as many right hand brackets as there are left hand ones. #### 6-2.7 WORD ASSEMBLY The address syllable is formed first as a 36 bit integer using normal integer arithmetic. It may contain parentheses, the arithmetic symbols: $+ - \times /$ , and the logic symbols $\land$ ("and"), $\lor$ ("or"), $\bigodot$ ("exclusive or"). The symbols are interpreted from left to right. (i.e. not quite "normal" algebra) For example: $$4G + 5R/6$$ is interpreted as $\frac{4G + 5R}{6}$ $4G + (5R/6)$ is interpreted as $4G + \frac{5R}{6}$ Parenthetical expressions may be nested, but the parentheses must balance - i.e. there must be as many left parentheses as right. For example: $$(77 - (4G + (5R/6)))$$ The use of another symex is equivalent to using parentheses. e.g., $$4\text{G}$$ + $\alpha$ is interpreted as $4\text{G}$ + $\frac{5\text{R}}{6}$ if $\alpha$ = $5\text{R}/6$ The 36 bit address syllable is <u>united</u> (inclusive OR) with the others (configuration, operation, index). Extra syllables of the latter group are also <u>united</u> into the word. The one bit syllables are set last, "not hold" (\(\bar{h}\)) being the final one. ## 6-2.8 SPECIAL SYMBOLS - # "The current Location" The symbol "#" is a special symex which always is equal to the current location. Thus "JMP #" is a jump to itself, "JMP # + 1" is a "jump-to-the-next-register". If # is used within brackets, it refers to the RC BLOCK rather than the current address. - "Start of Comments" A double asterisk \*\* is used before comments or annotations. All symbols are legal in the comment section except \*\*XXX and }, and comments are saved and included in Listing and Directive Printouts. A carriage return terminates the comment section. A comment may be used within an RC word and another on the same line outside the bracket. - The notation $p \mid q$ T is equivalent to $p \mid q$ The $p \mid q$ must be in subscript. For example: $REX_{\alpha \mid \beta} TAGG$ is equivalent to $REX_{\alpha} \{TAGG_{\beta}\} *$ . - A carriage return immediately preceded by minus sign (-) will not terminate the line. This feature is needed because complex nested Macro-instructions often require more than one line of print. It can not be used for comments. ## 6-3 METALANGUAGE - FOR CONTROL OF M4 ASSEMBLY The M4 conversion - assembly process is designed for input and control from the key-board or from paper tape. Since keyboard use is more flexible and tape is faster, the normal procedure is to use both. "Metacommands" are instructions directed to the M4 program itself covering the following areas: Paper Tape Input Alterations M4 Output Direct Storage Format Variation Magnetic Tape Bulk Storage Macro Definition (Section 6-4) ## 6-3.1 METACOMMAND FORMAT Metacommands may require one line or several, and no address section, or as many as two. The address section refers to the "Directive" of a program and may specify one line, or a block of consecutive lines. Note that a line of a directive may correspond to several program words (c.f. MACRO, Section 6-4) or no program words at all (e.g., origins and comments). There are three formats for address sections: - The line at "AA". AA+n - The n<sup>th</sup> line after AA. AA-n - The n<sup>th</sup> line before AA. "AA" should be an honest tag (defined by an arrow), rather than a numeral or symex defined by equal sign. - 2. $AA \mid n$ n lines beginning with the line at AA $AA \pm q \mid n$ (or AA $\pm q$ ). - 3. AA $\rightarrow$ BB The block of lines from AA to BB including AA but not BB. (Or from AA $\pm$ q to BB $\pm$ p.) A typical metacommand is as follows: FFREP GEORGE+7 hSTE TI It will replace the line at "GEORGE + 7" with the word "hSTE TT". ## ► MOVE AA→BB GEORGE will move the block "AA to BB" to just before George. To reduce typing, the following conventions are allowed: - 1. # is equivalent to the end of the program. - 2. AA means "From before AA to the end". (Do not use this with DELETE.) - 3. -AA means "From the beginning up to AA". (Not including AA) - 4. The name of a metacommand can be abbreviated to just the first three letters. - 5. Tab is used to terminate syllables. ## 6-3.2 M4 OPERATION - NAME, CLEAN, LW READ, RECONVERT, STORE, GOTO There are two versions of the M4 program - "M4 from mag. tape" on the Golden Reel and "M4 from paper" on the White Reel. They are essentially identical except that the paper tape version will ignore all metacommands that use magnetic tape bulk storage. M4 is located at registers 160 000 - 174 010 (octal) and uses the rest of memory as temporary storage. 157 777 down towards zero is used for storage of your Directive. 174 000 - 200 000 is used for various tables. There are two CODABO start points: 160 000 - Fresh start, new program, M4 is reset completely, a New Name is required. 160 001 - Continue same old program. M4 is reset to OCTAL, and T = TAB. (see section 6-3.4) Upon read-in of either reel, M4 will type NAME and then will wait for the user to respond by typing his "M4 Name" on the keyboard. The situation is the same as that produced by the metacommand "NAME" described below: MAME DAD NAME is the metacommand used to identify the user. The users "name" is required by $M^{\downarrow}$ to identify output and to determine which part of the $M^{\downarrow}$ Magnetic Tape is to be used. All paper tape, and printed output is identified by the user's M4 initials and a 4 character word derived from the check sum of his directive. When "M4 from tape" is used, the users name determines which portion of Bulk Storage is available. Most individual users are assigned tape storage equivalent to one S memory. Groups of users may combine by using the same name, thereby extending their available bulk storage to several memories. Bulk storage is used in blocks of 200(8) words. See section 6-3.7 for further details. #### Note: - 1. M4 names are three characters long. - 2. The special name "FRE" is reserved for users who have no name. - 3. "NAME" does not clear M4. #### FCLEAN CLEAN (CL) restores M4 to its pristine state. It is equivalent to CODABO 160 000 except that CODABO 160 000 types NAME and waits for one, while CLEAN does not. #### FFLW READ LW READ (LW) (Special Key "Readin") switches M4 input from Keyboard to PETR. The PETR will be in its "Bin and Read" mode (IOS<sub>52</sub>30104). When stop code (76) is read by the PETR, M4 input is switched back to the keyboard. All Metacommands may be used on tape except \*\* READ and \*\* RECONVERT. #### FFRECONVERT RECONVERT (REC) expands the stored directive into free storage in a form similar to its printed or punched version. It then forms a new directive. The result is the same as punching a paper tape directive, cleaning M4, and reading in the new directive. All redundancies are removed, the RC Block is corrected, - the directive is shorter than before. When there is insufficient free storage, this command will produce QSAL and do nothing. #### BINARY STORE AA BINARY STORE (BIN), (Special Key "BEGIN") completes the conversion process and stores the program directly in memory. If an address "AA" is given, a "h JPQ AA" is performed with sequence number 70 selected. The user can therefore save the return point, run his program, and return to M4 automatically. "AA" must be within the program area. "BINARY STORE" does not destroy M4 or the directive. If a program is to be located within these areas of storage, a binary tape should be made - see section 6-3.4 under "PUNCH BINARY". ## ₩WGO TO "GO TO" executes an "h JPQ AA" with sequence 70 selected. It makes it possible to go to the user's program and return automatically to M4. The address "AA" must be within the program area. NOTE: M4 leaves STANDARD CONFIGURATIONS in F memory only when its use is terminated by GOTO or BIN. When the user starts his own program with CODABO F register #37 is not standard. OR FINSERT AA ONE LINE OR FENSERT AA FEND INSERT (INS) puts the new program lines just before "AA". When only one line is to be inserted or when the next line will be a metacommand from this group, the terminating command "END" is not needed. FFDELETE AA FFDELETE AA→BB FFDELETE AA n A n DELETE (DEL) removes a section of the directive. Symexes that were assigned within the removed area are now undefined. The RC words used only within the deleted area are not removed from the RC Block. If an Origin is removed, subsequent words are located relative to the Origin preceding the deleted area. FFREPLACE AA FFREPLACE AA→BB FFREPLACE AA|π REPLACE (REP) is a combination of DELETE and INSERT. It can remove an arbitrary number of lines and put a different arbitrary set in their place. Note that it deals with <a href="lines">lines</a> - not words. For example, to replace an instruction at a tagged location, one must be sure to replace the tag also, for the whole line is removed. If only one line is to be inserted, the new line can be typed on the same line as the REP instruction. If several are required they must go on succeeding lines and END (or another meta-command from this group) must be used as a terminator. See examples below. FFMOVE AA CC FFMOVE AA→BB CC FFMOVE AA n CC MOVE (AA to CC in this case) is a combination of delete and insert where nothing is lost. In the example below, a few "second thoughts" have been indicated in hand written form. \*\* SAMPLE PROGRAM For User's Hardback The correction tape for the above is shown below. A complete listing of the corrected program is given in the next section. | BL=1000 | | | | |-----------|--------------------------|-----------------|-------------| | 00PS=2000 | | | | | FFREP | TEST | TEST-SKZ3.1PR | | | FFREP | 0UT-1-0UT+1 | | | | C OMM→ | JPQ BL<br>30 SKX 66#+1 | | | | | 1056630000 | | | | OUT→ | TSD TABL | | | | | SKZ <sub>3 • 3</sub> IND | | | | | JPQ OOPS | | | | FFEND | | | | | FFREP | RE | RE→LDA {-1} | | | INS | TEST-1 **SAMPLE | PROGRAM FOR USE | RS HANDBOOK | Note: The symex "START" could not be used in the last metacommand because it is not an honest, arrow-defined tag. To insert before an origin, one must count back from an honest tag. | FFLIST<br>FFLIST | AA<br>AA→BB<br>AA n | LIST (LI) (Special Key - WORD EXAM) - List produces a "M4 Listing" via the Xerox Printer. | |-------------------------------|-----------------------|-------------------------------------------------------------------------------------------| | PPPLIST<br>PPPLIST<br>PPPLIST | AA<br>AA→BB<br>AA π | Plist produces a listing via Punched paper tape. | | FFTYPE<br>FFTYPE<br>FFTYPE | AA<br>AA→BB<br>AA]π | Type produces a listing via the Lincoln Writer. | A <u>LISTING</u> tells what M4 did with the Manuscript or Directive received. Macro instructions are given in expanded form. The program is given in OCTAL as well as symbolic and is usually preceded by various tables. The overall format is as follows: #### LISTING FORMAT SYMEX TABLE EQUALITIES TABLE MACRO DEFINITIONS ERRORS PROGRAM: SYMBOLIC ABSOLUTE RC BLOCK SUMCK Civen only when the first word of the Program is included in the area requested by the Metacommand. ABSOLUTE (Paper tape versions only.) The SYMEX TABLE is printed in octal, in three columns and is in alphabetical order (4 letters) as if there were but one page. Symexes with an asterisk were assigned by M4 because they were left unassigned on the manuscript, or because they were used within a Macro Definition. Symexes with a hand ( ) are MACRO names. Symexes used only within macros, and those defined by equals sign, are listed, but no equivalent numeral is given. The <u>EQUALITIES</u> <u>TABLE</u> is in one column in alphabetic order. (First Letter) Symexes with an asterisk are those assigned by M4. An equality definition can not be deleted but it will be replaced if repeated. The last definition is the one that is used, and such repetition does not constitute an error. ${ m \underline{MACRO}}$ ${ m \underline{DEFINITIONS}}$ are listed as defined originally. They can not be deleted or changed but they may be re-defined. The ERROR PRINTOUT is of two types - FORMAT ERROR and DOUBLE ASSIGNMENT. An error printout is given on the first listing only - it is not repeated on subsequent listings even though the error may still exist. A line containing a FORMAT ERROR is reprinted in the error printout and the error deleted from the Directive. (It therefore can not reoccur.) A DOUBLE ASSIGNMENT occurs when a symex is assigned both by equal sign and by arrow, or twice by arrow. The printout gives the location of the first assignment. The second assignment is used and can be found in the symex table. If both definitions were by arrow, the offending tag will appear in two places on the directive and on the listing, but only the last assignment will be used throughout the program and in the Symex table. To delete the first one, it is necessary to count from some other tag. If the second one was wrong, it can be deleted directly, and the first one will take over in subsequent Listings and Directives. The error printout format is shown by the examples below: DOUBLE DEFINITION | BADTAG \*\*FIRST LOCATION FORMAT ERROR | LOCATION \*\*BAD LINE Format Errors include such things as an attempt to define an op code (e.g. LDA = DAD 6), extra meta-commands (especially END), and improper symbols in MACRO DEFINITIONS. In meta-commands, the line is removed; in other cases, only the offending character is deleted. The <u>PROGRAM</u> is printed in symbolic form at the left, on two lines if necessary. The octal numeral form is given at the right with its octal memory location. The SUMCHECK occurs only on paper tape versions of Listings and Directives (Plist and Dir). It is given as a meta-command, e.g. \*\*SUM 436521 The sum is checked on M4 Read-in (\*\*LW READ) and if an error is found, the word "SUMCK" is printed on the Lincoln Writer. The user can proceed at his own risk, or he can try again. #### FFERRORS ERRORS will type the error block if there are less than 8, or if there are more, it will print them on the Xerox. Once this is done, the error block will not appear on subsequent listings. Example 1 Here is a listing of the program of the previous section - $\underline{\text{before}}$ the correction tape was used. | BL=000407 | RE=000404 | TABL=00 | 0412 | |-----------------------|-------------------|-----------------------|---------------| | OUT=000402 | RESET=000411 | TEST=00 | 0400 | | PR=000410 | | | | | START= 400 | | | | | START = 400 | | | | | | | | | | α= 1 | | | | | | | | | | FORMAT ERROR TEST | +1**COM→ | JPQ BL | | | | | | | | -, | | | | | START | | | | | TEST→ JB 0 | SKN 3.1 PR | 301761 | 000410 000400 | | | COM JPQ BL | 145700 | 000407 401 | | OUT→ | TSD TABL | 005701 | 000412 402 | | | MKN 3 · 1 PR | 031761 | 000410 403 | | RE→ | 3 · 1<br>LDA { o} | | 000406 404 | | 201 1201000 33210 | | Add to Various States | | | | STA RESET | 003400 | 000411 405 | | | | | | | | | | | | | 0 | 1000000 | 000000 406 | | BL→ | | 000000 | 000000 407 | | | | | | | PR→ | 0 | | 000000 000410 | | RESET→ | 0 | 000000 | 000000 411 | | TABL→ | 0 | 000000 | 000000 412 | | | | | | | | | | | | 218 000000 00000 | 0.77000 | | | | SUM SOCIAL CONTRACTOR | 037602 | | | | | | | | # Example 2 Here is a listing of the same example, made <u>after</u> the correction tape was used. Note that the error notice is always printed once, even if the error is corrected later on. If a listing is made <u>between</u> tapes, the error notice is not included on the second listing. | | OUT=000404 | | |--------------|----------------|-------------------------| | COMM=000401 | PR=000415 | TABL=000417 | | IND=000414 | RE=000410 | TEST=000400 | | | RESET=000416 | | | BL= 1000 | | | | | | | | 00PS= 2000 | | | | | | | | START= 400 | | | | | | | | α= 1 | | | | | | | | FORMAT ERROR | R TEST+1**COM→ | JPQ BL | | | | | | | **SAMPLE PRO | GRAM FOR USERS HANDBOOK | | START | | | | TEST- | SKZ 3.1 PR | 201761 000415 000400 | | C O M M→ | JPQ BL | 140500 001000 401 | | | 30 SKX 66#+1 | 301266 000403 402 | | | 105 66 30000 | 000466 030000 403 | | OUT→ | TSD TABL | 005701 000417 404 | | | SKZ 3.3 IND | 201763 000414 405 | | | JPQ OOPS | 140500 002000 406 | | | MKN 3.1 PR | 031761 000415 407 | | RE→ | LDA {-1} | 002400 000413 000410 | | | STA RESET | 003400 000416 411 | | | | | | | | | | | 0 | 000000 000000 412 | | | -1 | 777777 777776 413 | | IND→ | 0 | 000000 000000 414 | | PR→ | 0 | 000000 000000 415 | | RESET→ | 0 | 000000 000000 416 | | TABL→ | 0 | 000000 000000 417 | | | | | | | | | | SUM | 056632 | | | | | | | DIR | AA | |----------|-----------------------------------------| | PP DIR | AA→BB Directive via Punched paper tape. | | PP DIR | AA n | | | | | FF TD IR | AA | | TDIR | AA-BB Directive via Typewriter. | | TDIR | AA n | | | | | FF LD IR | AA | | FF LDIR | AA→BB Directive via Xerox. | | LDIR | AA n | | | | The format of a DIRECTIVE is as follows: EQUALITIES TABLE (No Asterisks or Hands) MACRO DEFINITIONS SYMBOLIC PROGRAM FF SUMCHECK 432170 (Looks like a Meta-command) There is no symex table, error table, octal program, or RC Word block. The sumcheck is a 6 digit octal number. If the tape has been damaged or spliced so that the sumcheck is wrong, $M^{\downarrow}$ will type "SUMCK" on the Lincoln Writer, and control of $M^{\downarrow}$ will return to the Keyboard. ## Partial Listings and Directives If no address section is given in the Listing and Directive type metacommands, the entire program is included in the output. In a partial Listing or Directive, the tables and macro definitions are included only if the first word of the program is included in the section indicated by the address given. # (Directive Before Corrections) START= 400 START TEST→ SKN 3.1 PR COM JPQ BL OUT→ TSD TABLα MKN 3.1 LDA { o} RE→ LDA { o} STA RESET FFSUM 011516 (Directive After Corrections) BL= 1000 00PS= 2000 START= 400 \*\*SAMPLE PROGRAM FOR USERS HANDBOOK START TEST→ SKZ 3.1 PR COMM→ JPQ BL 30 SKX 66#+1 10S 30000 TSD ΤΑΒLα OUT→ TSD TABL<sub>α</sub> SKZ IND MKN 3 · 1 PR LDA {-1} RE→ LDA {-1} STA RESET FFSUM 021762 PUNCH produces a punched paper tape in Binary Format. If an address is given, a JPQ AA goes into register 27<sub>(oct.)</sub>. If there is no given address, JPD 27 is used. Since the readin program ends with an IOS<sub>52</sub>20000 (DISCONNECT PETR) in register 26<sub>(oct.)</sub> the "AA" is essentially a starting address for the tape. AA must be within the program. Binary Tape Format is as shown below: \*There is, in general, one block per M4 Origin. The "Reader Leader" is the binary version of the Readin Program itself. The Readin Plugboard Program reads the reader leader into registers 0-26 (octal) and then jumps to register 3, the start of the readin program. The first word of a block tells where the block is to be located, and how many words are therein. The last word is an 18 bit check sum and an address telling the readin program where to go next. For all but the last block, this address will be "3", the start of the readin program. For the last block it will be 26 (oct.) Register 26 contains "IOS<sub>52</sub>20000" and 27 will be either JPQ AA (if AA is given) or <sup>14</sup>JPD 27 if no address was given. The readin program therefore will jump to the new program with sequence number 52 chosen, and with the PETR DISCONNECTED. If there is no given starting address, the readin program leaves the computer in LIMBO. $\underline{\text{Note:}}$ $\underline{\text{Metabits}}$ are not set by the readin program. They are $\underline{\text{cleared}}$ wherever the readin program stores new words. Note also: The special block for register 27 comes before the program on the tape. Program material that is to go in register 27 therefore supercedes this special block created by M4. 6-3.5 M4 FORMAT VARIATIONS - DEC, OCT, T=CR, T=TAB, RC STORE, XXX PPDECIMAL (PPDEC) PPOCTAL (PPOCT) All numerals in an M4 manuscript are considered to be of the same numeral system unless they are followed by a period (in which case, the other numeral system is used). DEC and OCT remain effective until changed and are not saved for inclusion in the Directive. M4 preserves Decimal Integers by reproducing them with a "following period". Octal is the "normal" mode - CLEAN or CODABO 160000 (Pushbutton) will reset the numeral interpretation to Octal. Note also that the right hand numeral in a SKM bit designation is always Decimal. FFT=CR When a table of constants is part of a manuscript, it may be easier to type it in several columns by "tabulation". "T=CR" allows this by making TAB a word terminator similar to Carriage Return (CR). In this mode, tabs can not be used within words. T=TAB returns M4 to normal. Note: These meta-commands are not included on a Directive. A table that was typed in several columns will be reproduced as one column on the Directive. FFRC STORE (FFRC) RC STORE means "Put the RC BLOCK here". The RC Block will be at the end of the program if this meta-command is not used. RC STORE can be inserted via FFINS and need not be deleted for M4 automatically deletes an existing RC STORE when a new one is inserted. ## FFXXX (or Special Key "NO") XXX has complete control. It wipes out all input information back to the previous carriage return and forward to the next CR (or tab if T=CR). It can be used on any line, anywhere even within a comment, but not after backspace. ## 6-3.6 USE OF SPECIAL KEYS The top row of keys on the Lincoln Writer has five special keys which have no machine function or associated character. They are extras, and can be used for any purpose. The M4 system uses them as abbreviations for certain meta-commands. These special keys terminate the line as far as M4 is concerned. If an address is to be used, it is to be typed first. The keys are assigned as follows: | WORD EXAM (71) | LIST | |----------------|-------------------------------------------------------| | YES (17) | MOST RECENT OF TYPE, TDIR, DIR, LIST, PLIST, OR LDIR. | | NO (16) | XXX (This works backwards only - It does not delete | | | forward.) | | BEGIN (15) | BIN (BINARY STORE) | | READ IN (14) | LW READ | | STOP (76) | The stop key means "stop". It is always active. If M4 | | | is printing too much, if it is "hung-up", or if it is | | | performing a function that is no longer wanted, the | | | stop key will return control to the keyboard and stop | | | whatever is going on. | # 6-3.7 MAGNETIC TAPE BULK STORAGE - SAVE, READ, TAPE, CORE The M4 Magnetic Tape Bulk Storage reel contains a copy of the M4 program itself (in Binary and Directive form, and with 3 Binary back-up copies), and working space about 30 times the size of S Memory. Working space is assigned in 200 word blocks, the average allotment being 1000 blocks - i.e. one S Memory. M4 does all the detailed tape coding. A standard tape format is used with an 18 bit check sum for error detecting. Tape malfunction is automatically reported on the typewriter - the report includes missed data detected by the alarm circuits (Sequence #41) as well as check sum errors. The users "M4 Name" is used to determine the proper working space, and M4 automatically protects the rest of the tape. The four Meta-commands listed below permit the user to store and retrieve his program or other material in Directive Format (Save-Read) or in straight Binary (Tape-Core). ## M4 Answers to Mag Tape Meta-Commands When M4 can not perform the given command because of programming limitations, it types NO in red on the Lincoln Writer, and it ignores the command. No data is transferred. When M4 can and does complete the given command, it tells the user which tape area was used, and the associated four character identification derived from the check-sum. The tape area is specified by the block number of the first block and the block number of the next free block. For example: 0100 - 0107 TY7J means that blocks 100 through 106 were used. "TY7J" is the identifying word. If there is a tape equipment malfunction while M4 is in operation, the words "TAPE ERROR" are printed in red on the Lincoln Writer followed by pertinent data. This print-out should be saved for the Tape Engineers, and the incident should be duly reported. FFSAVE 100-200 \*\*SAVE CURRENT DIRECTIVE If all is well, M4 stores the current directive on Mag tape beginning at the specified block number (100 in this case), and reports back via the typewriter the tape area used, and the four character identification. This will be the same identification as that used on Listings. Saving and retrieving a Directive on Magnetic tape does not "clean it up" the way it does when paper tape is used. The Directive comes back exactly as it was. To "clean it up", the meta-command "RECONVERT" should be used before SAVE. The second block number is protected. If the directive will not fit in the specified area, M4 types "NO" in red. If the second number is omitted, the remainder of the user's allotted working space is assumed to be available. If both numbers are omitted, address "zero" is assumed. If M4 types "NO", the command has been ignored. FFREAD 100 \*\*READ DIRECTIVE FROM MAG TAPE If the address given is the start of a Directive, "READ" will clean M4 and read in the Directive from tape. It will then type the tape location (i.e. first block and the one after the last block), and the four character identification. If the address given is not the start of a Directive, "READ" types "NO" in red and does not clean M4 nor read from tape. # TAPE - CORE (Binary Storage and Retrieval) TAPE and CORE deal with Binary (i.e. Absolutely Numerical) information and therefore require two address sections - one for the working space on tape and the other for core memory. (The word "to" is understood - i.e. it is $\underline{\text{TO}}$ $\underline{\text{TAPE}}$ and $\underline{\text{TO}}$ $\underline{\text{CORE}}$ .) Both address sections must be numerical and the tape æddress comes first. FFTAPE 200-300 (TAPE AREA) 0-17777 (MEMORY AREA, INCLUSIVE) TAPE copies from core to Tape. Working space on tape is used a block at a time - i.e. in 200<sub>(8)</sub> word sections. If the second tape block number is omitted, the rest of the user's allotted working space is assumed to be available. If the data from core will not fit, none of it is copied and M4 types "NO" in red. If it does fit, M4 types the first block number, the one after the last, and the four character identification derived from the check sum that is used on tape. The rest of a partially filled block is set to zero. The memory address is inclusive. FFCORE 100 (TAPE AREA) 0-17777 (MEMORY AREA, INCLUSIVE) CORE copies from tape to core until the specified core area is full. If all is well, M4 will type the usual message - i.e. tape area used, and four character identification word. If the meta-command asks for words beyond the user's allotted space, or if the M4 program itself is threatened, M4 types "NO" in red. (M4 is located at 160000 - 174010.) The identification word will be different if only part of a section is retrieved or if a program is stored in several pieces and retrieved by one command. ## 6-3.8 META-COMMAND SUMMARY # 6-4 MACRO INSTRUCTIONS A macro-instruction is an abbreviation for a <u>flexible subprogram</u> which is written by the <u>user</u> (as a Macro Definition) and is inserted into the program by M4 wherever the Macro Instruction is used. The subprogram is written in terms of dummy parameters and when it is copied by M4, only those portions that correspond to <u>specified</u> parameters are used. For example: ``` If the <u>definition</u> of "DO A,B,C,D" is DO A,B,C,D A B C D ``` And if the program is: FFEMD ``` 100 | LINE 1 \rightarrow DO | LDA T<sub>j</sub>, ADD TT, ADD BB, STA CC LINE 2 \rightarrow DO | LDB T<sub>\alpha</sub> DO | , 6 ``` Then M4 will produce: | 100 | | | | | | |---------|--------|--------|--------|-------------|-----| | LINE 1+ | DOLLDA | T, ADD | TT,ADD | BB, STA CC | | | | LDA T | | 002401 | 000112 0001 | 00 | | | ADD TT | | 006700 | 000113 | 01 | | | ADD TT | | 006700 | 000113 1 | 0 2 | | | ADD BB | | 006700 | 000110 1 | 03 | | | STA CC | | 003400 | 000111 1 | 04 | | LINE 2- | DOLDB | Ta | | | | | | LDB T | | 002502 | 000112 1 | 05 | | LINE 3→ | DO,6 | | | | | | | 6 | | 000000 | 000006 1 | 06 | | | 6 | | 000000 | 000006 1 | 07 | | | | | | | | # 6-4.1 Macro Definitions - Meta-commands "DEFINE" and "EMD" As shown by the example above, two meta-commands are used with Macro Definitions — DEFINE (DEF is enough) and FEMD (End of Macro Definition.) A macro definition has two parts — the abbreviation itself, and the defining subprogram. The Macro Definition must precede the use of a Macro instruction. ## 6-4.2 The Mnemonic Abbreviation Line of A Macro Definition A Macro Definition starts with the "Macro Name" and dummy parameters as follows: PPDEF DO A, B, C, D The "Macro Name" here is "DO", the "dummy parameters" are A,B,C and D, and commas were used as "Macro Terminators". A Macro Definition must be terminated by the Meta-command " \*FEMD" (End of Macro Definition). # 6-4.3 Macro Names There are two kinds: - a. Any Symex may be used as a Macro Name. It may be used alone, or followed by a terminator and parameters, (each of which is separated from the other by terminators). - b. A compound character may be used. It may consist of two or three superposed non-alpha-numeric characters e.g., or ≠ or ▶ . It may not be ∅, ⊕, or ⊖. (These are reserved for M4.) The characters may be typed in any order. A compound macro name is itself a terminator i.e. parameters may come before as well as after. For example: The Macro Name is + . ## 6-4.4 Dummy Parameters Dummy Parameters may be <u>any symex</u> (even three letter mnemonic codes and the single letters A, B, C, D and E). A Dummy Parameter may be included as a mnemonic aid and need not be used in the defining subprogram. Dummy Parameters must be separated by macro terminators. # 6-4.5 Macro Terminators The following symbols may be used. Other symbols may not be used. # 6-4.6 The Defining Subprogram The defining subprogram is written using the Dummy Parameters and must be terminated by FEMD (End of Macro Definition). Note the following rules and conventions. - Symexes defined by equal sign (=) or by arrow (→) within the macro definition are not part of the program proper and refer only to the macro subprogram. - 2. A symex that is not defined within the MACRO will refer to the main program and if it's not assigned there, it will be assigned automatically in the RC Block. (But only if the Macro is used in the program proper.) - 3. The single letter symexes A, B, C, D, E will refer to the AE unless they are used as Dummy Parameters. - 4. An instruction in a definition may use a parameter harmlessly so that it will be left out when the parameter is not used. One way to do this is as follows: LDA $$\alpha$$ T , + (DP) - (DP) ("DP" is the dummy parameter.) 5. A Dummy Parameter may not be used as a tag within the defining subprogram. (You can, of course, write JPQ DP, but not: 6. A line that uses two Dummy Parameters will be left out if either is left out when the macro is used. 7. A line that uses a dummy parameter may be kept in with that parameter equal to zero when the parameter is not used. This is done by using another symex that is set equal to the dummy in question. For example: LDA DUM1 +DUM2 can be written as: LDA DUM1 + G6 G6 = DUM2 ## 6-4.7 Use of Macro Instructions A macro may be used as a Pseudo Instruction by itself, or "nested" as a parameter of another macro. It may even be used as a parameter of itself. It may be an RC word. When used as an RC Word, it will use several registers of the RC Block and the location of the first of these will be the associated address. Consider the examples below. Example 1. A Macro used within brackets - i.e. as an "RC Word" | PPDEF | TBS a | |-------|-------------------------------------| | | α | | | α | | | α | | | α | | | α | | 100 | | | USE→ | LDA {TS→TBS o} **5 BLANK RC WORDS | | | LDA TOMM | | | STA TS+3 | The program is expanded as follows: | 100 | | | |-------|------------------|----------------------| | USE→ | LDA {TS→TBS o} | 002400 000103 000100 | | | LDA TOMM | 002400 000110 101 | | | STA TS+3 | 003400 000106 102 | | TS→ | TBS 0 | | | | 0 | 000000 000000 103 | | | 0 | 000000 000000 104 | | | 0 | 000000 000000 105 | | | 0 | 000000 000000 106 | | | 0 | 000000 000000 107 | | TOMM→ | 0 | 000000 000000 000110 | Example 2. A Macro used to generate a table of squares. If the manuscript is as follows: FFDEF SQ|A FFEMD 100 | NSQ= (#-TABL) × (#-TABL) TABL→ SQ | (SQ | (NSQ))) M4 will produce the program shown in the "Plisting" below. TABL=000100 000000 000061 107 NSQ= (#-TABL) × (#-TABL) DEF SQ|A FFEMD 100 SQ (SQ (SQ (NSQ))) TABL→ 000000 000000 000100 (NSQ) 000000 000001 101 (NSQ) 000000 000004 102 (NSQ) 000000 000011 103 (NSQ) 000000 000020 (NSQ) 104 0000000 000031 105 (NSQ) 000000 000044 106 (NSQ) -SUM 025015 (NSQ) Example 3. An open subroutine for index memory "integer" multiplication. The macro below finds the righthand 18 bits of the full product of two X Memory words ( $\alpha$ & $\beta$ ), provided that said product is no larger than 17 bits and sign. The product goes into X Register " $\alpha$ ", "TXX" is cleared, X Register " $\beta$ " is ruined, and the symexes "TXX" and "FX1" are "used up". (Since symex "S" is defined within the macro, it is not "used up".) | | TXX=000110 | USE=0001 | 00 | |-----------------|------------------------|----------|---------------| | FX1= 1 | | | | | | | | | | S= | | | | | ₽₽DEF | MULX, a×B | | | | | DPX TXX | | | | | | | | | . DO ECOON [EA] | EXXaTXX | | | | S→ | SZZ <sub>1·1</sub> TXX | | | | | INXalB | | | | | INXBB | | | | | RSX <sub>FX1</sub> TXX | | | | | JPX <sub>FX1</sub> S | | | | ##EMD | 177 | | | | | | | | | i | | | | | 100 | | | | | USE→ | MULX,1×2 | | | | | DPX TXX | | 000110 000100 | | | EXX TXX | 011401 | 000110 101 | | | SZZ 1.1 TXX | 261721 | 000110 102 | | | INX 1 2 | 021201 | 400107 103 | | | INX 2 2 | 021202 | 400107 104 | | | RSX FXI TXX | 001101 | 000110 105 | | | FX1 | | 000102 106 | | | JAX EXI 2 | 1 | | | | | | | | | | | | | | 2 | 000002 | 000000 107 | | TXX→ | 0 | 000000 | 000000 000110 | | | | | | | | | | | | T IAPRES TURBES | | | | | propriet SUM | 037643 | | | Example 4. An open subroutine for "exclusive or" using a compound macro name. In the macro below, the result goes into X Register " $\alpha$ ", TXX is set to $(\alpha)$ , $c(\beta)$ , and X Register " $\beta$ " is not changed. An underline was used in the macro name because the symbols $\odot$ , $\ominus$ , and $\oplus$ are not available as macro names. | | TXX=000106 | USE=000100 | |---------------|-------------------------------------|----------------------| | BILL= 1 | | | | T0MM= 2 | | | | <b>₽₽</b> DEF | α <u>⊗</u> β | | | | DPXBTXX | | | | h <sup>2</sup> DPX <sub>a</sub> TXX | | | | h17 COM E | | | | MITE TXX | | | | hRSX <sub>a</sub> E | | | | <sup>2</sup> AUX <sub>a</sub> E | | | FFEMD | | | | | | | | 100 | | | | USE→ | TOMM <u>©</u> BILL | | | | DPX BILL TXX | 011601 000106 000100 | | | h DPX TOMM TXX | 421602 000106 101 | | | h <sup>17</sup> COM E | 575600 377610 102 | | | hITE TXX | 404000 000106 103 | | | hRSX TOMM E | 401102 377610 104 | | | 2AUX TOMM E | 021002 377610 105 | | | | | | | | | | TXX→ | 0 | 000000 000000 106 | | | | | | | | | | FFSUM | 036551 | | # TX-2 USERS HANDBOOK CHAPTER 7 - VARIOUS TABLES #### TABLE OF CONTENTS - 7-1 IN-OUT SEQUENCE NUMBER ASSIGNMENTS - 7-2 STANDARD CONFIGURATIONS - 7-3 OPERATION CODE MNEMONICS - 7-4 META-COMMAND MNEMONICS - 7-5 XEROX CHARACTER CODES - 7-6 LINCOLN WRITER CHARACTER CODES - 7-7 M4 COMMA CHART - 7-8 AVERAGE DURATION OF INSTRUCTIONS # IN-OUT SEQUENCE ASSIGNMENTS FOR TX-2 | 00 | STARTOVER | | | |----|-----------------------|-----|-----------------------------| | 40 | | 60 | DISPLAY NO. 1 | | 41 | ALARM, IN-OUT | 61 | RANDOM NUMBER GENERATOR | | 42 | TRAP | 6 2 | PUNCH NO· 2 | | 43 | | 6 3 | PUNCH NO· 1 | | 44 | | 64 | | | 45 | IBM MAG TAPE | 65 | LINCOLN WRITER INPUT NO. 1 | | 46 | MAG TAPE BULK STORAGE | 66 | LINCOLN WRITER OUTPUT NO. 1 | | 47 | MISCELLANEOUS INPUTS | 67 | | | 50 | DATRAC | 70 | | | 51 | XEROX | 71 | LINCOLN WRITER INPUT NO· 2 | | 52 | PETR | 72 | LINCOLN WRITER OUTPUT NO· 2 | | 53 | | 73 | | | 54 | INTERVAL TIMER | 74 | PLOTTER | | 55 | LITE PEN | 75 | MISCELLANEOUS OUTPUTS | | 56 | DISPLAY NO· 2 | 76 | | | 57 | | 77 | | TABLE 7-2 STANDARD CONFIGURATION SET F | a | DESCRIPTOR α F | α | DESCRIPTOR 4 3 . 2 1 4 . 3 . 2 . 1 733 3 • 2 • 1 • 4 1 . 4 . 3 . 2 2 . 1 . 4 . 3 4 . 3 . 2 . 1 1 . 4 . 3 . 2 3 . 2 . 1 . 4 4 3 2 . 1 1 4 3 . 2 A · 3 · 2 · 1 4.3.2.1 | STANDARD PERMUTATIONS | | | | | | | | |-----------------------|----|-------------|-----|-----|---|----|---| | 1111 | XX | <b>&gt;</b> | 744 | X/X | * | ×I | * | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | TO: TX-2 Users FROM: Alex Vanderburgh The attached chart (7-2A) will be used by the new TX-2 Executive System, and its users. The old one (7-2) still applies to everyone else. Therefore, if you are not a member of the official farmyard (Hens, Chickens, Studs, etc) you need not worry at all. aly | TABLE 7-2A* | | | | | | | | |----------------------------|-----------------------|---------------|-------------|-----|-----------|-----------------------------------------|----------------------------| | STANDARD CONFIGURATION SET | | | | | | | | | α | F α | DESCRI | IPTOR | α | F α | DESCRI | PTOR | | 0 | 000 | 4 3 2 1 | 4 3 2 1 | 20 | 200 | 4 3 • 2 1 | 4 3 2 1 | | 1 | 340 | 4 3 • 2 1 | | 21 | 230 | 4 3 • 2 1 | | | 2 | 342 | 2 1 • 4 3 | <b>\</b> | 22 | 232 | 2 1 • 4 3 | | | 3 | 760 | 4 • 3 • 2 • 1 | 上 | 23 | 671 | 1 • 4 • 3 • 2 | | | 4 | 761 | 1 • 4 • 3 • 2 | 4 3 2 1 | 24 | 672 | 2 • 1 • 4 • 3 | 4 3 2 1 | | 5 | 762 | 2 • 1 • 4 • 3 | \] | 25 | 673 | 3 . 2 . 1 . 4 | 4 | | 6 | 763 | 3 • 2 • 1 • 4 | | 26 | 604 | 3 • 4 • 1 • 2 | XX | | 7 | 410 | 4 3 2 • 1 | | 27 | 605 | 1 • 2 • 3 • 4 | <b>**</b> | | 10 | 411 | 1 4 3 • 2 | 4 3 2 1 | 30 | 600 | 4 • 3 • 2 • 1 | 4 3 2 1 | | 11 | 140 | 4 3 2 1 | | 31 | 750 | 4 • 3 • 2 • 1 | 丄 | | 12 | 142 | 2 1 4 3 | | 32 | 730 | 4 • 3 • 2 • 1 | ل | | 13 | 160 | 4 3 2 1 | | 33 | 670 | 4 • 3 • 2 • 1 | 上 | | 14 | 161 | 1 4 3 2 | 4 3 2 1 | 34 | To be ass | signed by th | ne user | | 15 | 162 | 2 1 4 3 | | 35 | 11 11 | 11 11 | п | | 16 | 163 | 3 2 1 4 | | 36 | 11 11 | 11 11 | 11 11 | | 17 | 202 | 2 1 • 4 3 | <b>&gt;</b> | 37 | also used | signed by the last by Executional bit.) | ne user, but<br>ve System. | | | STANDARD PERMUTATIONS | | | | | | | | | 1X | X > | × /// | X > | X > 5 | $<$ $\times$ $_{6}$ | 1 × 1 | <sup>\*</sup>For use with the TX-2 Executive System Only. | N | Alababatical Order | Supernumerary Mnemonics | |--------------------------|--------------------------|---------------------------------------------------| | Numerical Order | Alphabetical Order | (1) JMP - OJMP | | 0 | ADD - 67<br>ADX - 15 | | | 1 2 | AUX - 10 | BRC - <sup>1</sup> JMP | | 2<br>3<br>4 - IOS | COM - 56 | JPS - <sup>2</sup> JMP | | 4 - IOS | CAB - 62 | BRS - <sup>3</sup> JMP | | 5 - JMP (1)<br>6 - JPX | CYA - 60<br>CYB - 61 | JPQ - <sup>14</sup> JMP | | 7 - JNX | DIV - 75 | BPQ - 15 JMP | | 10 - AUX | DPX - 16 | | | 11 - RSX | DSA - 65 | JES - 16 JMP | | 12 - SKX (2)<br>13 | EXA - 54<br>EXX - 14 | JPD - <sup>20</sup> JMP | | 14 - EXX | FLF - 31 | BRD - <sup>21</sup> JMP | | 15 - ADX | FLG - 32 | JDS - <sup>22</sup> JMP | | 16 - DPX | INS - 55<br>IOS - 4 | BDS - <sup>23</sup> JMP | | 17 - SKM (3)<br>20 - LDE | ITA - 41 | DDS - SIL | | 21 - SPF | ITE - 40 | (2) REX - SEX - OSKX | | 22 - SPG | JMP - 5 | INX - 2skx | | 23 | JNA - 47<br>JNX - 7 | | | 24 - LDA<br>25 - LDB | JOV - 44 | DEX - <sup>3</sup> SKX | | 26 - LDC | JPA - 46 | SXD - 4SKX | | 27 - LDD | JPX - 6 | SXL - <sup>6</sup> SKX | | 30 - STE | LDA - 24<br>LDB - 25 | sxg - <sup>7</sup> skx | | 31 - FLF<br>32 - FLG | LDC - 26 | RXF - <sup>10</sup> SKX | | 33 | LDD - 27 | | | 34 - STA | LDE - 20 | RXD - <sup>20</sup> SKX | | 35 - STB<br>36 - STC | MUL - 76<br>NAB - 66 | rfd - <sup>30</sup> skx | | 37 - STD | NOA - 64 | | | 40 - ITE | RSX - 11 | (3) SKM - OSKM | | 41 - ITA | SAB - 72 | MKC - <sup>1</sup> SKM | | 42 - UNA<br>43 - SED | SCA - 70<br>SCB - 71 | Make ≺MKZ - <sup>2</sup> SKM | | 44 - JOV | SED - 43 | MKM - 3 SKM | | 45 | SKM - 17 | MKN - <sup>3</sup> SKM<br>SKU - <sup>10</sup> SKM | | 46 - JPA | SKX - 12 | SKU - SKM | | 47 - JNA<br>50 | SPF - 21<br>SPG - 22 | Skip SUC -11SKM SUZ -12SKM | | 51 | STA - 34 | SUZ - IZSKM | | 52 | STB - 35 | SUN - 13 SKM | | 53<br>54 - EXA | STC - 36<br>STD - 37 | Ski - 20 SkM | | 55 - INS | STE - 30 | SKIP 21 | | 56 - COM | SUB - 77 | on SZC - SKM Zero SZZ - SKM | | 57 - TSD | TSD - 57 | | | 60 - CYA<br>61 - CYB | TLY - 74<br>UNA - 42 | SZN - <sup>23</sup> SKM | | 62 - CAB | | Skip SKN -30 SKM | | 63 | | on SNC -31SKM | | 64 - NOA | | One SNZ -32 SKM | | 65 - DSA<br>66 - NAB | | SNN -33SKM | | 67 - ADD | | | | 70 - SCA | | CYR - 4SKM | | 71 - SCB<br>72 - SAB | | MCR - 5skm | | 73 | | MZR - <sup>6</sup> SKM | | 74 - TLY | | Rotate MNR - 7SKM | | 75 - DIV | | SNR -34SKM | | 76 - MUL<br>77 - SUB | | SZR - SKM | | 11 - 202 | | | | | | SUR -14SKM | | | OPERATION CODE MNEMONICS | | # 7-4 META-COMMAND MNEMONICS | Clean | | BIN | - Binary Store | |------------|------------|-------|-------------------------------------| | LW Read | Input | CLEAN | - Clear M4 Directive Storage | | Reconvert | C Input | CORE | - Tape to Core | | Name | | DEC | - Decimal | | | | DEF | - Define | | Insert | | DEL | - Delete | | Delete | Changes | DEMO | - Demonstrate | | Replace | Citaliges | DIR | - Directive Punch | | Move | | END | - End of Multiple Word Meta-Command | | | | EMD | - End of Macro Definition | | List | | GOTO | - Go To User's Program | | Type | | INS | - Insert | | Plist | | LDIR | - List Directive on Xerox | | Directive | punch | LIST | - Print Listing on Xerox | | Tdir | Output | LW | - Lincoln Writer Read-in | | Ldir | | MOVE | - Move Program Block | | Binary Sto | ore | NAME | - Set User Identification | | Punch Bina | ry | OCT | - Octal | | Goto | | PLIST | - Punch Listing | | | | PUN | - Punch Binary | | Decimal | ) | RC | - RC Store | | Octal | | READ | - Read Directive from Tape | | T=CR | | REC | - Reconvert | | T=Tab | Format | REP | - Replace | | End | | SAVE | - Save Directive on Tape | | RC | | SUMCK | - Sum Check | | Sumck | | TAPE | - Core to Tape | | | | TDIR | - Type Directive | | Save | | TYPE | - Type Listing | | Read | Mag Tape | T=CR | - Tab equals Carriage Return | | Tape | riag tape | T=TAB | - Tab equals Tab. | | Core | | | | | | | | | | Define | Macro | | | | EMD | S Place to | | | | | | | | | Demo | | | | | | | | | ## XEROX PRINTER CHARACTER CODES | CHARACTER | OCTAL CODE | CHARACTER | OCTAL CODE | |------------|---------------------|------------|---------------------| | А | 154 | 1 | 122 (107) | | В | 142 | k | 324 (034) | | С | 361 (056)(071)(346) | n | 323 (033) | | D | 352 | p | 024 | | E | 313 (043) | q | 111 | | F | 344 (054) | t | 112 | | G | 302 (012) | 10 | 173 | | Н | 354 | × | 174 | | I | 172 (157) | y | 163 | | J | 144 | 2 | 164 | | K | 143 | α | 310 (040) | | L | 332 (047)(062)(317) | В | 311 (041) | | М | 360 (055)(070)(345) | γ | 333 (063) | | N | 370 (355) | Δ | 203 | | 0 | 353 | € | 334 (064) | | P | 312 (042) | λ | 023 | | Q | 160 (145) | 1 | 001 | | R | 371 (356) | 2 | 002 | | S | 322 (017)(032)(307) | 3 | 003 | | Т | 153 | 4 | 004 | | U | 362 (057)(072)(347) | 5 | 020 (005) | | ٧ | 152 | 6 | 021 (006) | | W | 3 4 3 (0 5 3) | 7 | 022 (007) | | X | 161 (146) | 8 | 300 (010) | | Υ | 342 (052) | 9 | 301 (011) | | Z | 162 (147) | 0 (ZERO) | 000 | | h | 132 (117) | ? | 202 | | 4 | 133 | , (COMMA) | 204 | | < | 220 (205) | n | 120 (105) | | > | 221 (206) | 2 | 121 (106) | | · (PERIOD) | 222 (207) | × | 113 | | + | 3 5 1 | O (CIRCLE) | 714 (444) | | - | 372 (357) | ~ | 373 | | <b>v</b> | 340 (050) | ۸ | 341 (051) | | • | 363 (073) | # | 364 (074) | | 1 | 730 (445)(460)(715) | | 731 (446)(461)(716) | | Σ | 703 (413) | | 704 (414) | | } | 720 (415)(430)(705) | { | 721 (416)(431)(706) | | - | 150 | <b>→</b> | 151 | | | 570 (555) | - | 571 (556) | | ( | 140 | ) | 141 | | = | 114 | = | 130 (115) | | / | 131 (116) | * | 102 | | U | 103 | С | 104 | | | | | | Note: Bit 1.9 of the Xerox Character Code is a "size control bit". "1" means large, and "O" means small. The codes are given above with the "proper" size. # TX-2 LINCOLN WRITER CODES | 00 | 0 10 | 40 | Qα | |-----|---------|----|----------------| | 01 | 1 ∑ | 41 | R A | | 02 | 2 | 42 | S # | | 03 | 3 | 43 | Т є | | 04 | 4 / | 44 | U h | | 05 | 5 × | 45 | V > | | 06 | 6 # | 46 | W B | | 07 | 7 → | 47 | X ^ | | 10 | 8 < | 50 | Υ λ | | 11 | 9 > | 51 | Z ~ | | 12 | _ | 52 | ( { | | 13 | 0 🛮 | 53 | ) } | | 14 | READ IN | 54 | + = | | 15 | BEGIN | 55 | - = | | 16 | NO | 56 | , ' | | 17 | YES | 57 | . * | | 20 | A n | 60 | CAR RETURN | | 21 | ВС | 61 | TAB | | 22 | CV | 62 | BACK SPACE | | 23 | D 9 | 63 | COLOR BLACK | | 24 | Εγ | 64 | SUPER | | 25 | F t | 65 | NORMAL | | 26 | G w | 66 | SUB | | 27 | H * | 67 | COLOR RED | | 30 | I 4 | 70 | SPACE | | 3 1 | Jу | 71 | WORD EXAM | | 32 | K z | 72 | LINE FEED DOWN | | 33 | L ? | 73 | LINE FEED UP | | 34 | МО | 74 | LOWER CASE | | 35 | N n | 75 | UPPER CASE | | 36 | 0 1 | 76 | STOP | | 37 | P & | 77 | NULLIFY | | COMMAS BEFORE | COMMAS AFTER | CRAM DIAGRAM | EXAMPLE | |---------------|--------------|--------------|-----------------| | | | | | | 0 | 0 | ++++ | 444 333 222 111 | | 0 | 1 | | 111 | | 0 | 2 | // | 222 111 | | 0 | 3 | 111 | 333 222 111 - | | | | * * * | 333 | | | | | | | 1 | 0 | + | 111 | | 1 | 1 | 11 | - 222 111 - | | 1 | 2 | | - 111 | | 1 | 3 | +11 | 444 333 222 - | | | | | | | | | 1.1 | 000 | | 2 | 0 | * * | 222 111 | | 2 | 1 | / | 111 - | | 2 | 2 | <b>&gt;</b> | 222 111 444 333 | | 2 | 3 | | 444 333 | | | | ** | | | 2 | 0 | 1 | 111 | | 3 | 0 | * | | | 3 | 1 | • | 444 | | 3 | 2 | 1 | - 444 | | 3 | 3 | 1 | 444 333 | #### 7-8 AVERAGE DURATION OF INSTRUCTIONS This duration chart was made by TX-2 by timing the duration of 8000 repetitions of each operation with various combinations of memories. The columns are labled as follows: P MEM - The memory used for the instructions. OP Code - The instruction being timed. Δ - The memory used for intermediate deferred address (if any). Q MEM - The memory used for final operand (if any). MMS - Average duration in microseconds. The abbreviations used within the columns are as follows: S - S memory T - T memory VFF - Flip-Flop part of V memory (A,B,C,etc.) VT - Toggle Memory The instructions are listed in numerical order (by op codes). | P MEM | OP CODE | Δ | Q MEM | MMS | |-------|---------|---|--------|--------| | S | AOP | | 167000 | 8 • 0 | | Т | AOP | | 167000 | 6 • 0 | | S | IOS | | 0 | 9 • 2 | | Т | IOS | | 0 | 7 • 2 | | S | JMP | | | 7 • 6 | | Т | JMP | | | 5 • 6 | | S | JPA | | | 8 • 0 | | Т | JPA | | | 6 • 0 | | S | JNA | | | 8 • 0 | | Т | JNA | | | 6 • 0 | | S | JOV | | | 8 . 0 | | Т | JOV | | | 6 • 0 | | S | JNX | | | 9 • 6 | | Т | JNX | | | 7 • 6 | | S | JPX | | | 9 • 6 | | Т | JPX | | | 7 • 6 | | S | SKX | | | 10.0 | | Т | SKX | | | 8 • 0 | | S | SKX | S | | 20 • 4 | | T | SKX | S | | 18 • 4 | | S | SKX | Т | | 18 • 4 | | Т | SKX | T | | 16 • 4 | | S | AUX | | S | 13 . 6 | | Т | AUX | | S | 11.6 | | S | AUX | | VFF | 12 . 4 | | T | AUX | | VFF | 10.4 | | S | AUX | | VT | 12.0 | | T | AUX | | VT | 10.0 | | S | AUX | | Т | 11 • 6 | | T | AUX | | Т | 9 • 6 | | S | RSX | | S | 12.8 | | Т | RSX | | S | 10.8 | | S | RSX | | Т | 10.8 | | T | RSX | | Т | 8 • 8 | | S | RSX | | VFF | 11.6 | | T | RSX | | VFF | 9 • 6 | | S | RSX | | VT | 11.2 | | T | RSX | | VT | 9 • 2 | | S | ADX | | S | 16.0 | | T | ADX | | S | 10.0 | | S | ADX | | Т | 10.0 | | T | ADX | | Т | 12.0 | | S | ADX | | VFF | 10 • 8 | | T | ADX | | VFF | 8 • 8 | | | | | | | | P MEM | OP CODE | Δ | Q MEM | MMS | |-------|---------|---|-------|--------| | S | ADX | | VT | 10 • 4 | | T | ADX | | VT | 8 • 4 | | S | DPX | | S | 14.0 | | T | DPX | | S | 7 • 6 | | S | DPX | | Т | 7 • 6 | | T | DPX | | Т | 10.0 | | S | DPX | | VFF | 8 • 4 | | T | DPX | | VFF | 6 • 4 | | S | DPX | | VT | 8 • 0 | | T | DPX | | VT | 6 • 0 | | S | EXX | | s | 14.0 | | T | EXX | | S | 11.2 | | S | EXX | | Т | 11.2 | | T | EXX | | Т | 10.0 | | S | EXX | | VFF | 11.6 | | T | EXX | | VFF | 9 • 6 | | S | EXX | | VT | 11.2 | | T | EXX | | VT | 9 • 2 | | S | SKM | | S | 14 . 8 | | T | SKM | | S | 9 • 6 | | S | SKM | | Т | 9 • 6 | | Т | SKM | | Т | 10.8 | | S | SKM | | VFF | 10 • 4 | | Т | SKM | | VFF | 8 • 4 | | S | SKM | | VT | 10.0 | | T | SKM | | VT | 8 • 0 | | S | SKM | S | S | 25 • 2 | | Т | SKM | S | S | 20 • 0 | | S | SKM | S | Т | 20 • 0 | | T | SKM | S | Т | 21 • 2 | | S | SKM | S | VFF | 20 • 8 | | Т | SKM | S | VFF | 18 - 8 | | S | SKM | S | VT | 20 • 4 | | T | SKM | S | VT | 18 • 4 | | S | SKM | Т | 5 | 23 • 2 | | T | SKM | Т | S | 18.0 | | S | SKM | Т | Т | 18 • 0 | | T | SKM | T | Т | 19 • 2 | | S | SKM | Т | VFF | 18 • 8 | | T | SKM | Т | VFF | 16 • 8 | | S | SKM | | 0 | 14.8 | | T | SKM | | 0 | 9 • 6 | | S | LDA | | S | 12 • 8 | | T | LDA | | S | 6 • 4 | | P MEM | OP CODE | Δ | Q MEM | MMS | |-------|---------|---|-------|--------| | S | LDA | | Т | 6 • 8 | | Т | LDA | | Т | 8 • 8 | | S | LDA | | VFF | 6 • 8 | | T | LDA | | VFF | 5 • 2 | | S | LDA | | VT | 6 • 8 | | T | LDA | | VT | 4 • 8 | | S | LDB | | S | 12.8 | | T | LDB | | s | 6 • 4 | | S | LDB | | Т | 6 • 8 | | Т | LDB | | Т | 8 • 8 | | S | LDB | | VFF | 6 • 8 | | T | LDB | | VFF | 5 • 2 | | S | LDB | | VT | 6 • 8 | | T | LDB | | VT | 4 • 8 | | S | LDC | | S | 12 • 8 | | T | LDC | | S | 6 • 4 | | S | LDC | | Т | 6 • 8 | | T | LDC | | Т | 8 • 8 | | S | LDC | | VFF | 6 • 8 | | T | LDC | | VFF | 5 • 2 | | S | LDC | | VT | 6 • 8 | | T | LDC | | VT | 4 • 8 | | S | LDD | | S | 12 • 8 | | T | LDD | | S | 6 • 4 | | S | LDD | | Т | 6 • 8 | | T | LDD | | Т | 8 • 8 | | S | LDD | | VFF | 6 * 8 | | T | LDD | | VFF | 5 • 2 | | S | LDD | | VT | 6 • 8 | | T | LDD | | VT | 4 • 8 | | S | LDE | | S | 12.8 | | Т | LDE | | S | 6 • 4 | | S | LDE | | T | 6 • 8 | | Т | LDE | | T | 8 • 8 | | S | LDE | | VFF | 6 • 8 | | Т | LDE | | VFF | 5 • 2 | | S | LDE | | VT | 6 • 8 | | T | LDE | | VT | 4 • 8 | | S | SPF | | S | 12.8 | | T | SPF | | S | 9 • 6 | | S | SPF | | T | 9 • 6 | | T | SPF | | T | 8 • 8 | | S | SPF | | VFF | 10 • 4 | | Т | SPF | | VFF | 8 • 4 | | P MEM | OP CODE | Δ | Q MEM | MMS | |--------|------------|---|----------|----------------| | | SPF | | VT | 10.0 | | S | SPF | | VT | 8.0 | | T<br>S | SPG | | S | 12.8 | | T | SPG | | S | 9 • 6 | | S | SPG | | Т | 9 • 6 | | T | SPG | | Т | 8 • 8 | | S | SPG | | VFF | 10 • 4 | | T | SPG | | VFF | 8 • 4 | | S | SPG | | VT | 10.0 | | T | SPG | | VT | 8 • 0 | | S | STA | | S | 14.0 | | Т | STA | | S | 7 • 6 | | S | STA | | Т | 6 • 8 | | Т | STA | | Т | 10.0 | | S | STA | | VFF | 6 • 8 | | T | STA | | VFF | 5 • 2 | | S | STA | | VT | 6 • 8 | | Т | STA | | VT | 4 • 8 | | S | STB | | S | 14.0 | | T | STB | | S | 7 • 6 | | S | STB | | Т | 6 • 8 | | T | STB | | Т | 10.0 | | S | STB | | VFF | 6 • 8 | | T | STB | | VFF | 5 • 2 | | S | STB | | VT | 6 • 8 | | Т | STB | | VT | 4 • 8 | | S | STC | | S | 14.0 | | T | STC | | \$ | 7 • 6 | | S | STC | | Ţ | 6 • 8 | | Т | STC | | T | 10.0 | | S | STC | | VFF | 6 • 8 | | T | STC | | VFF | 5 · 2<br>6 · 8 | | S | STC | | VT<br>VT | 4 • 8 | | T | STC | | S | 14.0 | | S | STD | | \$ | 7 • 6 | | T | STD<br>STD | | T | 6 • 8 | | S | | | т | 10.0 | | T | STD<br>STD | | VFF | 6 • 8 | | S | STD | | VFF | 5 • 2 | | T | STD | | VT | 6 • 8 | | S | STD | | VT | 4 • 8 | | T<br>S | STE | | S | 14.0 | | T | STE | | S | 7 • 6 | | | 316 | | | | | P MEM | OP CODE | Δ | Q MEM | MMS | |-------|---------|---|-------|-------| | S | STE | | Т | 6 • 8 | | Т | STE | | Т | 10.0 | | S | STE | | VFF | 6 • 8 | | T | STE | | VFF | 5 • 2 | | S | STE | | VT | 6 • 8 | | T | STE | | VT | 4 • 8 | | S | EXA | | S | 14.0 | | Т | EXA | | S | 7 • 6 | | S | EXA | | Т | 6 • 8 | | T | EXA | | Т | 10.0 | | S | EXA | | VFF | 6 . 8 | | T | EXA | | VFF | 5 • 2 | | S | EXA | | VT | 6 . 8 | | T | EXA | | VT | 4 . 8 | | S | ITA | | S | 12.8 | | T | ITA | | S | 6 • 4 | | S | ITA | | Т | 6 • 8 | | T | ITA | | Т | 8 • 8 | | S | ITA | | VFF | 6 • 8 | | Т | ITA | | VFF | 5 • 2 | | S | ITA | | VT | 6 • 8 | | T | ITA | | VT | 4 • 8 | | S | UNA | | S | 12.8 | | Т | UNA | | S | 6 • 4 | | S | UNA | | Т | 6 • 8 | | T | UNA | | Т | 8 • 8 | | S | UNA | | VFF | 6 • 8 | | T | UNA | | VFF | 5 • 2 | | S | UNA | | VT | 6 • 8 | | T | UNA | | VT | 4 . 8 | | S | DSA | | S | 12.8 | | T | DSA | | S | 6 • 4 | | S | DSA | | Т | 6 . 8 | | T | DSA | | Т | 8 • 8 | | S | DSA | | VFF | 6 • 8 | | Т | DSA | | VFF | 5 • 2 | | S | DSA | | VT | 6 • 8 | | T | DSA | | VT | 4 • 8 | | S | ITE | | S | 12.8 | | T | ITE | | S | 6 • 4 | | S | ITE | | T | 6 • 8 | | T | ITE | | T | 8 • 8 | | S | ITE | | VFF | 6 • 8 | | Т | ITE | | VFF | 5 • 2 | | P MEM | OP CODE | Δ Q | MEM | MMS | |--------|---------|-----|-----|--------| | S | ITE | | VT | 6 • 8 | | Т | ITE | | VT | 4 • 8 | | S | SED | | S | 12.8 | | T | SED | | S | 9 • 6 | | S | SED | | T | 9 • 6 | | T | SED | | Т | 8 • 8 | | S | SED | | VFF | 10 • 4 | | Т | SED | | VFF | 8 • 4 | | S | SED | | VT | 10.0 | | T | SED | | VT | 8 • 0 | | S | FLF | | S | 14.0 | | T | FLF | | S | 7 • 6 | | S | FLF | | Т | 6 • 8 | | T | FLF | | Т | 10.0 | | S | FLF | | VFF | 6 • 8 | | T | FLF | | VFF | 6 • 0 | | S | FLF | | VT | 6 • 8 | | T | FLF | | VT | 4 • 8 | | S | FLG | | S | 15.6 | | T | FLG | | S | 8 • 8 | | S | FLG | | Т | 8 • 4 | | T | FLG | | Т | 11.6 | | S | FLG | | VFF | 8 • 4 | | T | FLG | | VFF | 8 • 0 | | S | FLG | | VT | 8 • 4 | | Т | FLG | | VT | 6 • 8 | | S | TSD | | S | 14 • 4 | | T | TSD | | S | 8 • 8 | | S | TSD | | Т | 7 • 6 | | T | TSD | | Т | 10 • 4 | | S | TSD | | VFF | 7 • 6 | | T | TSD | | VFF | 8 • 8 | | S | TSD | | VT | 7 • 6 | | T | TSD | | VT | 8 • 8 | | S<br>T | INS | | S | 15.2 | | | INS | | S | 8 • 8 | | S | INS | | T | 6 • 8 | | T<br>S | INS | | T | 11.2 | | T | INS | | VFF | 6 • 8 | | S | INS | | VFF | 6 • 4 | | T | INS | | VT | 6 • 8 | | S | COM | | S | 6 • 0 | | T | COM | | S | 14.8 | | | CON | | 3 | 8 • 4 | | T COM T 10-8 T COM VFF 6-8 T COM VFF 6-8 T COM VFF 6-8 T COM VFF 6-8 T COM VT 6-8 T COM VT 6-8 T COM VT 6-8 T ADD S 12-8 S ADD T 6-8 T ADD S 12-8 S ADD T 6-8 T ADD VFF 6-8 T ADD VFF 6-8 T ADD VFF 6-8 T ADD VFF 6-8 S ADD VFF 6-8 S ADD VT 4-8 S SUB S 12-8 T SUB S 12-8 T SUB S 12-8 T SUB S 12-8 T SUB S 12-8 T SUB T 6-8 T SUB T 6-8 T SUB T 6-8 T SUB VFF 19-6 S SUB VT 4-8 S SUB VT 4-8 S SUB T 19-6 T MUL T 19-6 T MUL VFF 16-4 | P MEM | OP CODE | Δ | Q MEM | MMS | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-------|--------| | T COM VFF 6.8 S COM VFF 6.4 T COM VFF 6.4 T COM VT 6.0 S COM VT 6.0 S ADD S 12.0 T ADD S 12.0 T ADD T 6.8 S ADD T 6.8 S ADD T 6.8 S ADD VFF 6.4 S ADD VFF 6.6 T ADD VFF 6.6 T ADD VFF 6.6 T ADD VFF 6.6 T ADD VFF 6.6 T ADD VFF 6.6 T ADD VFF 6.6 S ADD VFF 6.6 T ADD VFF 6.6 S ADD VT 6.8 S SUB T 6.8 T SUB S 12.0 T 8.8 S SUB T 6.8 T SUB VFF VT 6.8 S SUB T 19.6 T MUL S 20.8 S MUL T 19.6 T MUL VFF 16.4 | S | СОМ | | Т | 6 • 8 | | S COM VFF 6 · 8 T COM VFF 6 · 8 S COM VT 6 · 8 T COM VT 6 · 9 T ADD S 6 · 4 S ADD T 6 · 9 T ADD T 6 · 9 T ADD VFF 5 · 6 S ADD VT 4 · 8 S SUB S 12 · 8 S SUB S 12 · 8 S SUB T 6 · 8 S SUB T 6 · 8 S SUB T 6 · 8 S SUB T 6 · 8 S SUB VFF 6 · 8 S SUB VFF 6 · 8 S SUB VFF 5 · 6 S MUL S 20 · 8 T MUL T 19 · 6 < | | | | | 10.8 | | T COM VFF 6-4 S COM VT 6-9 T COM VT 6-9 T COM VT 6-9 S ADD S 112-8 S ADD S 6-4 S ADD T 6-8 T ADD T 6-8 T ADD T 6-8 T ADD VFF 6-8 T ADD VFF 6-8 T ADD VFF 5-6 S ADD VT 4-8 S SUB S 12-9 T SUB S 6-4 S SUB T 6-8 T SUB T 6-8 T SUB VFF S SUB VFF 5-6 S SUB VFF 5-6 S SUB VT 6-8 T SUB VFF 19-6 T HUL S 20-8 T HUL T 19-6 T HUL VFF 16-4 T HUL VFF 16-4 T HUL VFF 16-4 T HUL VFF 16-4 T HUL VFF 16-6 T HUL VFF 16-6 T HUL VFF 16-6 T HUL VFF 16-6 T HUL VFF 16-6 T HUL VFF 16-6 T HUL T 11-6 | | | | | | | S COM VT 6 · 0 S ADD S 12 · 0 S ADD S 6 · 0 T ADD T 6 · 0 T ADD T 8 · 0 S ADD VFF 6 · 0 T ADD VFF 5 · 6 S ADD VT 4 · 0 S SUB S 12 · 0 T SUB S 6 · 4 S SUB T 6 · 8 T SUB VFF 6 · 8 S SUB VFF 5 · 6 BUB <t< td=""><td></td><td></td><td></td><td></td><td>6 • 4</td></t<> | | | | | 6 • 4 | | T COM S ADD S 12-8 ADD S 6-6 S ADD T ADD S 6-8 S ADD T 6-8 S ADD T 8-9 S ADD T 8-9 S ADD VFF 6-8 T ADD VFF 5-6 S ADD VT 4-8 S SUB S 12-8 T SUB S 12-8 S SUB T 6-8 T SUB S 5-6 S SUB T 6-8 T SUB S 5-6 S SUB T 6-8 T SUB S 5-6 S SUB T 6-8 T SUB S 7-6 S SUB T 8-8 S SUB VFF 6-8 T SUB VFF 6-8 T SUB VFF 5-6 S SUB VFF 5-6 S SUB VFF 5-6 S SUB T 19-6 T SUB S 20-8 T MUL T 19-6 T MUL VFF 16-4 T MUL VFF 16-4 T MUL VFF 16-4 T MUL VFF 16-4 T MUL VFF 16-4 T MUL VFF 16-4 T MUL VFF 16-6 T 11-6 1 | | | | | 6 • 8 | | S ADD S 6 - 4 S ADD T 6 - 9 T ADD T 8 - 8 S ADD VFF 6 - 8 T ADD VFF 5 - 6 S ADD VT 4 - 8 S SUB S 12 - 8 T SUB S 6 - 8 T SUB T 6 - 8 S SUB T 6 - 8 T SUB VFF 5 - 6 S SUB VT 4 - 8 S SUB VT 4 - 8 S SUB VT 4 - 8 S SUB VT 4 - 8 S SUB VT 4 - 8 S SUB VT 4 - 8 S MUL S 20 - 8 T MUL S 20 - 8 MUL T 19 - 6 S MUL VFF 19 - 6 MUL VFF 19 - 6 | | | | | 6 • 0 | | T ADD T 6 · 4 S ADD T 6 · 8 T ADD T 8 · 8 S ADD VFF 6 · 8 T ADD VT 6 · 8 S ADD VT 4 · 8 S SUB S 6 · 4 S SUB T 6 · 8 S SUB T 6 · 8 S SUB VFF 6 · 8 S SUB VFF 5 · 6 S SUB VT 4 · 8 S SUB VT 4 · 8 S SUB VT 4 · 8 S SUB VT 4 · 8 S MUL S 20 · 8 MUL S 20 · 8 MUL T 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 < | | ADD | | | 12.8 | | S ADD T 6 · 8 T ADD T 8 · 8 S ADD VFF 6 · 8 T ADD VT 6 · 8 S ADD VT 4 · 8 S SUB S 12 · 8 T SUB S 6 · 4 S SUB T 6 · 8 T SUB VFF 6 · 8 S SUB VFF 6 · 8 T SUB VFF 5 · 6 S SUB VT 4 · 8 S SUB VT 4 · 8 S SUB VT 4 · 8 S SUB VT 4 · 8 S MUL S 20 · 8 T MUL S 20 · 8 MUL T 19 · 6 S MUL T 19 · 6 T MUL VFF 10 · 6 T MUL VFF 10 · 6 T MUL VT | | ADD | | | 6 • 4 | | T ADD | | ADD | | Т | 6 • 8 | | T ADD VFF 5-6 S ADD VT 6-8 T ADD VT 4-8 S SUB S 12-8 T SUB S 6-4 S SUB T 6-8 T SUB T 6-8 S SUB T 6-8 S SUB VFF 5-6 S SUB VFF 5-6 S SUB VT 4-8 S SUB VT 4-8 S SUB VT 4-8 S SUB VT 4-8 S SUB VT 4-8 S SUB VT 4-8 S HUL S 20-8 T HUL S 20-8 T HUL T 19-6 T HUL VFF 19-6 S HUL VFF 19-6 S HUL VFF 19-6 T T 19-2 T HUL T 16-4 T 7-8 T HUL T 16-4 T 7-8 T HUL VFF 16-4 T 7-8 T HUL VFF 16-4 T 7-8 T HUL T 16-4 T 7-8 T HUL T 16-4 T 7-8 T HUL T 16-6 T HUL T 11-6 T HUL T 11-6 T HUL T 11-6 T HUL T 11-6 | | ADD | | Т | 8 • 8 | | S ADD VT 6 · 8 T ADD VT 4 · 8 S SUB S 12 · 8 T SUB S 6 · 4 S SUB T 6 · 8 T SUB VFF 6 · 8 T SUB VFF 5 · 6 S SUB VFF 5 · 6 S SUB VT 4 · 8 MUL T 19 · 6 T MUL VT 19 · 6 T MUL VT< | S | ADD | | VFF | 6 • 8 | | T ADD VT 4+8 S SUB S 6-4 S SUB T 6-8 S SUB T 8-8 S SUB VFF 6-8 S SUB VT 6-8 S SUB VT 4-8 MUL T 19-6 T MUL T 19-6 T MUL VT 19-6 T MUL VT 16-4 | T | ADD | | VFF | 5 • 6 | | S SUB S 6-4 S SUB T 6-8 T SUB T 8-8 S SUB VFF 6-8 S SUB VFF 5-6 S SUB VT 4-8 MUL S 20-8 S MUL VFF 19-6 T MUL VT 19-6 T MUL VT 19-6 T MUL VT 16-4 T MUL VFF 16-4 | S | ADD | | VT | 6 • 8 | | T SUB S 6 · 4 S SUB T 6 · 8 T SUB VFF 6 · 8 T SUB VFF 5 · 6 S SUB VT 4 · 8 S SUB VT 4 · 8 S SUB VT 4 · 8 S MUL S 20 · 8 T MUL T 19 · 6 T MUL T 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VT 19 · 6 T MUL VT 19 · 6 T MUL VT 19 · 6 T MUL VT 19 · 6 T MUL VT 19 · 6 T MUL VT 10 · 4 T MUL T 16 · 4 T MUL | T | ADD | | VT | 4 • 8 | | S SUB T 6 · 8 T SUB T 8 · 8 S SUB VFF 5 · 6 S SUB VT 6 · 8 T SUB VT 4 · 8 S SUB VT 4 · 8 S MUL S 20 · 8 T MUL T 19 · 6 T MUL T 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VT 19 · 6 T MUL VT 19 · 6 T MUL VT 19 · 6 T MUL VT 19 · 6 T MUL VT 10 · 6 T MUL VFF 16 · 4 T MUL <td>S</td> <td>SUB</td> <td></td> <td>s</td> <td>12.8</td> | S | SUB | | s | 12.8 | | T SUB T 8 · 8 S SUB VFF 6 · 8 T SUB VT 6 · 8 S SUB VT 4 · 8 S SUB VT 4 · 8 S MUL S 20 · 8 T MUL T 19 · 6 T MUL T 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VFF 19 · 6 T MUL VT 10 · 6 T MUL VFF 16 · 4 T MUL VFF 16 · 4 T MUL </td <td>T</td> <td>SUB</td> <td></td> <td>s</td> <td>6 • 4</td> | T | SUB | | s | 6 • 4 | | S SUB VFF 6 · 8 T SUB VT 6 · 8 S SUB VT 4 · 8 S SUB VT 4 · 8 S HUL S 20 · 8 T HUL T 19 · 6 T HUL T 19 · 6 T HUL VFF 19 · 6 T HUL VFF 19 · 6 T HUL VT FULL VT 19 · 6 T FULL VT 10 · 6 T FULL VT 10 · 6 T FULL VT 10 · 6 T FULL VT 10 · 6 T FU | S | SUB | | Т | 6 • 8 | | T SUB VFF 5.6 S SUB VT 6.8 T SUB VT 4.8 S MUL S 20.8 T MUL T 19.6 T MUL T 20.0 S MUL VFF 19.6 T MUL VFF 20.8 S MUL VT 19.6 T MUL VT 19.6 T MUL VT 19.6 T MUL VT 19.6 T 7MUL S 17.6 S 7MUL T 16.4 T 7MUL VFF 16.4 T 7MUL VFF 16.0 S 7MUL VT 16.0 S 7MUL VT 16.0 S 1MUL S 16.0 T MUL T 11.6 T MUL T 11.6 T MUL T 11.6 <td>T</td> <td>SUB</td> <td></td> <td>Т</td> <td>8 • 8</td> | T | SUB | | Т | 8 • 8 | | S SUB VT 6 · 8 T SUB VT 4 · 8 S MUL S 20 · 8 T MUL T 19 · 6 T MUL T 20 · 0 S MUL VFF 19 · 6 T MUL VFF 20 · 8 S MUL VT 19 · 6 T T 16 · 4 T MUL T 15 · 2 S 7 MUL T 16 · 4 T 7 MUL VT 16 · 4 T 7 MUL VT 16 · 0 S 1 MUL T 11 · 6 T 1 MUL T 11 · 6 T 1 | S | SUB | | VFF | 6 • 8 | | T SUB VT 4 · 8 S MUL S 20 · 8 T MUL T 19 · 6 T MUL VFF 19 · 6 T MUL VFF 20 · 8 S MUL VT 19 · 6 T MUL VT 19 · 6 T MUL VT 19 · 6 T MUL VT 19 · 6 T MUL VT 19 · 6 T MUL VT 16 · 4 T MUL T 16 · 4 T MUL T 16 · 4 T MUL VFF 16 · 0 S MUL VT 16 · 0 S MUL VT 16 · 0 T MUL S 16 · 0 T MUL S 14 · 4 S 1 MUL T 11 · 6 T MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL< | T | SUB | | VFF | 5 • 6 | | S 20.8 T MUL S 20.8 S MUL T 19.6 T MUL T 20.0 S MUL VFF 19.6 T MUL VT 19.6 T MUL VT 19.2 S 7MUL S 17.6 T 7MUL S 17.6 S 7MUL T 16.4 T 7MUL VFF 16.4 T 7MUL VFF 16.0 S 7MUL VT 16.4 T 7MUL VT 16.0 S 1MUL S 16.0 T 1MUL S 14.4 S 1MUL T 11.6 T 1MUL T 11.6 T 1MUL T 11.6 T 1MUL T 11.6 T 1MUL T 11.6 T 1MUL T 11.6 T< | S | SUB | | VT | 6 • 8 | | T MUL S 20.8 S MUL T 19.6 T MUL VFF 19.6 T MUL VFF 20.8 S MUL VT 19.6 T MUL VT 19.2 S 7 MUL S 17.6 T 7 MUL S 17.6 S 7 MUL T 16.4 T 7 MUL VFF 16.4 T 7 MUL VFF 16.0 S 7 MUL VT 16.0 S 7 MUL VT 16.0 S 1 MUL S 16.0 T 1 MUL S 14.4 S 1 MUL T 11.6 T 1 MUL T 11.6 T 1 MUL T 11.6 T 1 MUL T 12.0 S 1 MUL VFF 13.2 | T | SUB | | VT | 4 • 8 | | S MUL T 19·6 T MUL T 20·0 S MUL VFF 19·6 T MUL VT 19·6 T MUL VT 19·2 S 7 MUL S 17·6 T 7 MUL S 17·6 S 7 MUL T 16·4 T 7 MUL T 16·4 T 7 MUL VFF 16·0 S 7 MUL VT 16·4 T 7 MUL VT 16·0 S 1 MUL S 16·0 T 1 MUL S 14·4 S 1 MUL T 11·6 T <td>S</td> <td>MUL</td> <td></td> <td>S</td> <td>20 • 8</td> | S | MUL | | S | 20 • 8 | | T MUL T 20 · 0 S MUL VFF 19 · 6 T MUL VT 19 · 6 T MUL VT 19 · 2 S 7 MUL S 17 · 6 T 7 MUL S 17 · 6 S 7 MUL T 16 · 4 T 7 MUL T 15 · 2 S 7 MUL VFF 16 · 0 S 7 MUL VT 16 · 0 S 1 MUL VT 16 · 0 S 1 MUL S 14 · 4 S 1 MUL T 11 · 6 T 1 MUL T 11 · 6 T 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL T 12 · 0 | T | MUL | | S | 20 • 8 | | S MUL VFF 19 · 6 T MUL VT 19 · 6 T MUL VT 19 · 2 S 7 MUL S 17 · 6 T 7 MUL S 17 · 6 S 7 MUL T 16 · 4 T 7 MUL T 16 · 4 T 7 MUL VFF 16 · 0 S 7 MUL VT 16 · 0 S 1 MUL VT 16 · 0 T 1 MUL S 14 · 4 S 1 MUL T 11 · 6 T 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL VFF 13 · 2 | S | MUL | | Т | 19 • 6 | | T MUL VFF 20 · 8 S MUL VT 19 · 6 T MUL VT 19 · 2 S 7 MUL S 17 · 6 T 7 MUL T 16 · 4 T 7 MUL T 15 · 2 S 7 MUL VFF 16 · 4 T 7 MUL VT 16 · 4 T 7 MUL VT 16 · 0 S 7 MUL VT 16 · 0 T 1 MUL S 16 · 0 T 1 MUL S 14 · 4 S 1 MUL T 11 · 6 T 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL VFF 13 · 2 | T | MUL | | Т | 20 • 0 | | S MUL VT 19 · 6 T MUL VT 19 · 2 S 7 MUL S 17 · 6 T 7 MUL T 16 · 4 T 7 MUL T 15 · 2 S 7 MUL VFF 16 · 4 T 7 MUL VFF 16 · 0 S 7 MUL VT 16 · 0 S 1 MUL S 16 · 0 T 1 MUL S 14 · 4 S 1 MUL T 11 · 6 T 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL VFF 13 · 2 | S | MUL | | VFF | 19.6 | | T MUL S 17.6 S 7MUL S 17.6 T 7MUL S 17.6 S 7MUL T 16.4 T 7MUL T 15.2 S 7MUL VFF 16.4 T 7MUL VFF 16.0 S 7MUL VT 16.4 T 7MUL S 16.0 S 1MUL T 16.0 S 1MUL T 16.0 S 1MUL T 16.0 S 1MUL T 16.0 S 1MUL T 16.0 S 1MUL T 11.6 T 1MUL S 14.4 S 1MUL T 11.6 T 1MUL T 11.6 | T | MUL | | VFF | 20 • 8 | | S 7 MUL S 17.6 T 7 MUL S 17.6 S 7 MUL T 16.4 T 7 MUL T 15.2 S 7 MUL VFF 16.4 T 7 MUL VFF 16.0 S 7 MUL VT 16.0 S 7 MUL VT 16.0 S 1 MUL S 16.0 T 1 MUL S 16.0 T 1 MUL S 14.4 S 1 MUL T 11.6 T 1 MUL T 11.6 T 1 MUL T 11.6 | S | MUL | | VT | 19.6 | | T 7 MUL S 17 · 6 S 7 MUL T 16 · 4 T 7 MUL T 15 · 2 S 7 MUL VFF 16 · 4 T 7 MUL VFF 16 · 0 S 7 MUL VT 16 · 4 T 7 MUL S 16 · 0 S 1 MUL S 16 · 0 T 1 MUL S 16 · 0 T 1 MUL T 11 · 6 T 1 MUL T 11 · 6 T 1 MUL T 11 · 6 T 1 MUL T 12 · 0 S 1 MUL VFF 13 · 2 | T | | | VT | 19.2 | | S 7 MUL T 16 · 4 T 7 MUL T 15 · 2 S 7 MUL VFF 16 · 0 S 7 MUL VT 16 · 0 T 7 MUL VT 16 · 0 S 1 MUL S 16 · 0 T 1 MUL S 14 · 4 S 1 MUL T 11 · 6 T 1 MUL T 12 · 0 S 1 MUL T 12 · 0 S 1 MUL VFF 13 · 2 | S | MUL | | S | 17 • 6 | | T 7 MUL T 15.2 S 7 MUL VFF 16.4 T 7 MUL VFF 16.0 S 7 MUL VT 16.4 T 7 MUL VT 16.0 S 1 MUL S 16.0 T 1 MUL S 16.0 T 1 MUL T 11.6 T 1 MUL T 11.6 T 1 MUL T 12.0 S 1 MUL VFF 13.2 | T | MUL | | | 17 • 6 | | S 7 MUL VFF 16.4 T 7 MUL VFF 16.0 S 7 MUL VT 16.4 T 7 MUL VT 16.0 S 1 MUL S 16.0 T 1 MUL S 14.4 S 1 MUL T 11.6 T 1 MUL T 12.0 S 1 MUL VFF 13.2 | S | MUL | | Т | 16 • 4 | | T 7 MUL VFF 16.0 S 7 MUL VT 16.4 T 7 MUL VT 16.0 S 1 MUL S 16.0 T 1 MUL S 14.4 S 1 MUL T 11.6 T 1 MUL T 12.0 S 1 MUL VFF 13.2 | T | MUL | | | 15 • 2 | | S 7 MUL VT 16.4 T 7 MUL VT 16.0 S 1 MUL S 16.0 T 1 MUL S 14.4 S 1 MUL T 11.6 T 1 MUL T 12.0 S 1 MUL VFF 13.2 | S | MUL | | | 16 • 4 | | T 7 MUL VT 16.0 S 1 MUL S 16.0 T 1 MUL S 14.4 S 1 MUL T 11.6 T 1 MUL T 12.0 S 1 MUL VFF 13.2 | | MUL | | | 16.0 | | S | | MUL | | | 16 • 4 | | T | | MUL | | | 16.0 | | S | | MUL | | | | | T | | MUL | | | | | S MUL VFF 13.2 | | MUL | | | | | S | | MUL | | | | | T MUL VFF 12.8 | | MUL | | | | | | T | MUL | | VFF | 12.8 | | P MEM | OP CODE | Δ | Q MEM | MMS | |-------|---------|---|-------|--------| | s | 1 MUL | | VT | 13 • 2 | | T | 1 MUL | | VT | 12.8 | | S | 3 MUL | | S | 12.8 | | Т | 3 MUL | | S | 11.2 | | S | 3 MUL | | Т | 10.0 | | Т | 3 MUL | | Т | 8 • 8 | | S | 3 MUL | | VFF | 10.0 | | Т | 3 MUL | | VFF | 9 • 6 | | S | 3 MUL | | VT | 10.0 | | T | 3 MUL | | VT | 9 • 6 | | S | DIV | | S | 80.0 | | T | DIV | | S | 80.0 | | S | DIV | | Т | 77 • 2 | | T | DIV | | T | 77 • 6 | | S | DIV | | VFF | 78 • 8 | | T | DIV | | VFF | 78 • 4 | | S | DIV | | VT | 77 • 2 | | T | DIV | | VT | 78 • 4 | | S | DIV | | S | 60 . 8 | | Т | 7DIV | | S | 60 • 8 | | S | DIV | | T | 59 • 6 | | Т | DIV | | T | 60.0 | | S | DIV | | VFF | 59 • 6 | | T | DIV | | VFF | 60 • 8 | | S | DIV | | VT | 59 • 6 | | T | DIV | | VT | 59 • 2 | | S | DIV | | S | 43 • 2 | | T | DIV | | S | 43 • 2 | | S | DIV | | Т | 42.0 | | T | DIV | | Т | 40 . 8 | | S | DIV | | VFF | 42.0 | | T | DIV | | VFF | 41 • 6 | | S | DIV | | VT | 42.0 | | T | DIV | | VT | 41.6 | | S | 3 DIV | | S | 22 • 4 | | T | 3 DIV | | S | 22 • 4 | | S | 3 DIV | | Т | 19 • 6 | | T | 3 DIV | | Т | 20.0 | | S | 3 DIV | | VFF | 21.2 | | Т | 3 DIV | | VFF | 20 • 8 | | S | 3 DIV | | VT | 19.6 | | T | 3 DIV | | VT | 20 • 8 | | S | TLY | | S | 19 • 2 | | T | TLY | | S | 19 • 2 | | P MEM | OP CODE | Δ | Q MEM | MMS | | |-------|---------|---|-------|--------|---------| | S | TLY | | Т | 16 • 4 | | | Т | TLY | | Т | 16 • 8 | | | S | TLY | | VFF | 18.0 | | | T | TLY | | VFF | 17 • 6 | | | S | TLY | | VT | 18.0 | | | T | TLY | | VT | 17 • 6 | | | S | 7 TLY | | S | 16.0 | | | T | 7 TLY | | S | 16.0 | | | S | 7TLY | | T | 13 • 2 | | | Т | 7TLY | | Т | 13 • 6 | | | S | 7TLY | | VFF | 14.8 | | | T | 7 TLY | | VFF | 14.4 | | | S | 7TLY | | VT | 13 • 2 | | | T | 7TLY | | VT | 14.4 | | | S | 1TLY | | S | 12.8 | | | T | 1TLY | | S | 11.2 | | | S | 1TLY | | Т | 10.0 | | | T | 1TLY | | Т | 12.0 | | | S | 1TLY | | VFF | 10.0 | | | T | 1TLY | | VFF | 11.2 | | | S | 1TLY | | VT | 10.0 | | | T | 1TLY | | VT | 9 • 6 | | | S | 3 TLY | | S | 12.8 | | | T | 3 TLY | | S | 8 • 0 | | | S | 3 TLY | | T | 6 • 8 | | | T | 3 TLY | | Т | 8 • 8 | | | S | 3 TLY | | VFF | 6 • 8 | | | T | 3 TLY | | VFF | 8 • 0 | | | S | 3 TLY | | VT | 6 • 8 | | | T | 3 TLY | | VT | 8 • 0 | | | S | SCA | | S | 12.8 | 107 • 2 | | T | SCA | | S | 8 • 0 | 107 • 2 | | S | SCA | | Т | 6 • 8 | 104 • 4 | | T | SCA | | Т | 8 • 8 | 104 • 8 | | S | SCA | | VFF | 6 • 8 | | | T | SCA | | VFF | 8 • 0 | | | S | SCA | | VT | 6 • 8 | 106.0 | | T | SCA | | VT | 8 • 0 | 105 • 6 | | S | 7 SCA | | S | 12 • 8 | 107 • 2 | | Т | 7 SCA | | S | 8 • 0 | 107 • 2 | | S | 7 SCA | | T | 6 • 8 | 104.4 | | T | 7 SCA | | T | 8 • 8 | 104.8 | | S | 7 SCA | | VFF | 6 • 8 | | | T | 7 SCA | | VFF | 8 • 0 | | | P MEM | OP CODE | Δ | Q MEM | MMS | | |-------|---------|---|-------|-------|---------| | S | 7 SCA | | VT | 6 • 8 | 106.0 | | T | 7 SCA | | VT | 8.0 | 105 • 6 | | S | 1 SCA | | S | 12.8 | 107 • 2 | | T | 1 SCA | | S | 8.0 | 107 • 2 | | S | 1 SCA | | Т | 6 • 8 | 104.4 | | T | 1 SCA | | Т | 8 • 8 | 104.8 | | S | 1 SCA | | VFF | 6 • 8 | | | Т | 1 SCA | | VFF | 8.0 | | | S | 1 SCA | | VT | 6 • 8 | 106.0 | | Т | 1 SCA | | VT | 8 • 0 | 105.6 | | S | 3 SCA | | S | 12.8 | 107 • 2 | | Т | 3 SCA | | S | 8 • 0 | 107 • 2 | | S | 3 SCA | | Т | 6 • 8 | 104.4 | | T | 3 SCA | | Т | 8 • 8 | 104.8 | | S | 3 SCA | | VFF | 6 • 8 | | | T | 3 SCA | | VFF | 8 • 0 | | | S | 3 SCA | | VT | 6 • 8 | 106.0 | | T | 3 SCA | | VT | 8 • 0 | 105 • 6 | | S | SCB | | S | 12.8 | 107 • 2 | | T | SCB | | S | 8 • 0 | 107 • 2 | | S | SCB | | Т | 6 • 8 | 104 • 4 | | Т | SCB | | T. | 8 • 8 | 104.8 | | S | SCB | | VFF | 6 • 8 | 106.0 | | T | SCB | | VFF | 8 • 0 | 105 • 6 | | S | SCB | | VT | 6 • 8 | 106.0 | | Т | SCB | | VT | 8 • 0 | 105.6 | | S | SAB | | S | 12.8 | 107 • 2 | | T | SAB | | S | 8 • 0 | 107 • 2 | | S | SAB | | Т | 6 • 8 | 104 • 4 | | T | SAB | | Т | 8 • 8 | 104.8 | | S | SAB | | VFF | 6 • 8 | | | T | SAB | | VFF | 8 • 0 | | | S | SAB | | VT | 6 • 8 | 108.0 | | T | SAB | | VT | 8 • 0 | 105 • 6 | | S | 7 SAB | | S | 12.8 | 107 • 2 | | T | 7 SAB | | S | 8 • 0 | 107 • 2 | | S | 7 SAB | | Т | 6 • 8 | 104 • 4 | | T | 7 SAB | | Т | 8 • 8 | 104.8 | | S | 7 SAB | | VFF | 6 • 8 | | | T | 7 SAB | | VFF | 8 • 0 | | | S | 7 SAB | | VT | 6 • 8 | 106.0 | | T | 7 SAB | | VT | 8 • 0 | 105 • 6 | | S | 1 SAB | | S | 12.8 | 107 • 2 | | T | 1 SAB | | S | 8 • 0 | 107 • 2 | | | | | | | | | P MEM | OP CODE | Δ Q | MEM | MMS | | |-------|------------------|-----|-----|--------|---------| | S | 1 SAB | | Т | 6 • 8 | 104.4 | | T | 1 SAB | | Т | 8 • 8 | 104.8 | | S | 1 SAB | | VFF | 6 • 8 | | | T | 1 SAB | | VFF | 8 • 0 | | | S | 1 SAB | | VT | 6 • 8 | 106.0 | | T | 1 SAB | | VT | 8 • 0 | 105.6 | | S | 3 SAB | | S | 12.8 | 107 • 2 | | T | 3 SAB | | S | 8 • 0 | 107 - 2 | | S | 3 SAB | | Т | 6 • 8 | 104.4 | | T | 3 SAB | | Т | 8 • 8 | 104.8 | | s | 3 SAB | | VFF | 6 • 8 | | | T | 3 SAB | | VFF | 8 • 0 | | | S | 3 SAB | | VT | 6 * 8 | 106.0 | | T | 3 SAB | | VT | 8 • 0 | 105 • 6 | | S | СУВ | | S | 12.8 | 107 • 2 | | T | СҮВ | | S | 8 • 0 | 107 • 2 | | S | СҮВ | | Т | 6 • 8 | 104.4 | | T | СУВ | | Т | 8 • 8 | 104.8 | | s | СУВ | | VFF | 6 • 8 | 106.0 | | T | СУВ | | VFF | 8 • 0 | 105.0 | | S | СУВ | | VT | 6 • 8 | 106.0 | | T | СҮВ | | VT | 8 • 0 | 105 • 6 | | S | 7 CYB | | S | 12.8 | 107 • 2 | | T | 7 <sub>CYB</sub> | | S | 8 • 0 | 107 • 2 | | S | 7 CYB | | Т | 6 • 8 | 104 • 4 | | T | 7 CYB | | Т | 8 • 8 | 104 . 8 | | S | 7 CYB | | VFF | 6 • 8 | 106.0 | | Т | 7 CYB | | VFF | 8 • 0 | 105.6 | | S | 7 CYB | | VT | 6 • 8 | 106.0 | | Т | 7 CYB | | VT | 8 • 0 | 105 • 6 | | S | 1 CYB | | S | 12.8 | 107 • 2 | | Т | 1 CYB | | S | 8 • 0 | 107 . 2 | | S | 1 CYB | | T | 6 • 8 | 104 • 4 | | Т | 1 CYB | | Т | 8 • 8 | 104.8 | | S | 1 CYB | | VFF | 6 • 8 | 106 . 0 | | Т | 1 CYB | | VFF | 8 • 0 | 105 • 6 | | S | 1 CYB | | VT | 6 • 8 | 106.0 | | Т | 1 CYB | | VT | 8 • 0 | 105.6 | | S | 3 CYB | | S | 12 • 8 | 107 • 2 | | T | 3 CYB | | S | 8 • 0 | 107 • 2 | | S | 3 C Y B | | T | 6 • 8 | 104.4 | | Т | 3 CYB | | Т | 8 • 8 | 104.8 | | S | 3 CYB | | VFF | 6 • 8 | 106.0 | | Т | 3 CYB | | VFF | 8 • 0 | 105 • 6 | | | | | | | | | P MEM | OP CODE | Δ | Q MEM | MMS | | |-------|---------|---|-------|--------|---------| | S | 3 CYB | | VT | 6 • 8 | 106.0 | | T | 3 CYB | | VT | 8 • 0 | 105 • 6 | | S | CYA | | S | 12.8 | 107 • 2 | | T | CYA | | S | 8 • 0 | 107 • 2 | | s | CYA | | Т | 6 • 8 | 104.4 | | T | CYA | | Т | 8 • 8 | 104.8 | | s | CYA | | VFF | 6 • 8 | 38 • 2 | | T | CYA | | VFF | 8 • 0 | 38 • 8 | | s | CYA | | VT | 6 • 8 | 106.0 | | Т | CYA | | VT | 8 • 0 | 105.6 | | s | CAB | | s | 12.8 | 107 • 2 | | Т | CAB | | S | 8 • 0 | 107 • 2 | | S | CAB | | Т | 6 • 8 | 104.4 | | T | CAB | | Т | 8 • 8 | 104.8 | | S | CAB | | VFF | 6 • 8 | | | Т | CAB | | VFF | 8 • 0 | 38 . 8 | | S | CAB | | VT | 6 • 8 | 106.0 | | Т | CAB | | VT | 8 • 0 | 105.6 | | S | NOA | | S | 19 • 2 | 12 . 8 | | T | NOA | | S | 19 • 2 | 8 • 0 | | S | NOA | | T | 18 • 0 | 6 • 8 | | T | NOA | | T | 18 • 4 | 8 • 8 | | S | NOA | | VFF | 18.0 | 6 • 8 | | T | NOA | | VFF | 19 • 2 | 8 • 0 | | S | NOA | | VT | 18.0 | 6 • 8 | | T | NOA | | VT | 17 • 6 | 8 • 0 | | S | NAB | | S | 33 • 6 | 12.8 | | T | NAB | | S | 33 • 6 | 8 • 0 | | S | NAB | | T | 32 • 4 | 6 • 8 | | T | NAB | | Т | 32 • 8 | 8 • 8 | | S | NAB | | VFF | 32 • 4 | 6 • 8 | | T | NAB | | VFF | 33 • 6 | 8 • 0 | | S | NAB | | VT | 32 • 4 | 6 • 8 | | T | NAB | | VT | 32.0 | 8 • 0 |