# USER HANDBOOK DIGITAL EQUIPMENT CORPORATION . MAYNARD, MASSACHUSETTS # PDP-9 USER HANDBOOK JANUARY 1968 ## CONTENTS | Chapter | | Page | |---------|---------------------------------------------|--------------| | 1 | SYSTEM INTRODUCTION | 1-1 | | | Characteristics | 1-1 | | | Design | 1-5 | | | Configurations | 1-5 | | 2 | SOFTWARE SYSTEM | 2-1 | | | PDP-9 BASIC Software | 2-1 | | | FORTRAN II | 2-1 | | | Symbolic Assembler | 2-2 | | | Dynamic Debugging Technique | 2-3 | | | Symbolic Tape Editor | 2-3 | | | PDP-9 ADVANCED Software | 2-4 | | | Paper Tape (or Card) System | 2-4 | | | Device-Independent System | 2-4 | | | System Components | 2-5 | | | FORTRAN IV | 2-5 | | | Macro Assembler (MACRO-9) | 2-6 | | | Debugging System (DDT-9) | 2-6 | | | Symbolic Editor | 2-7 | | | Peripheral Interchange Program (PIP-9) | 2-8 | | | Linking Loader | 2 <b>-</b> 8 | | | Input/Output Programming System (IOPS) | 2-9 | | | Input/Output Monitor | 2-9 | | | Keyboard Monitor (KM-9) | 2-9 | | | Expansion of PDP-9 ADVANCED Software System | 2-10 | | | Maindec Diagnostic Programs | 2-11 | | 3 | SYSTEM ORGANIZATION | 3-1 | | | Central Processor Unit | 3-1 | | | Core Memory | 3-3 | | | Input/Output Facilities | 3-4 | | | Program Controlled Transfers | 3 <b>-</b> 5 | | | Conditional Skip on Device Status | 3-6 | | | Input/Output Read Status | 3-6 | | Chapter | | Page | |----------|---------------------------------------------------------|------| | 3 (cont) | Program Interrupt | 3-6 | | | Data Channels | 3-7 | | | Direct Memory Access Channel | 3-8 | | | Add-to-Memory Capability | 3-8 | | | Options | 3-9 | | | Extended Arithmetic Element, Type KE09A | 3-9 | | | Memory Extension Control, Type KG09A | 3-9 | | | Additional Core Memory | 3-10 | | | Memory Parity, Type MP09 | 3-10 | | | Power Failure Protection, Type KP09A | 3-10 | | | Memory Protection Option, Type KX09A | 3-11 | | | Automatic Priority Interrupt, Type KF09A | 3-15 | | 4 | PERIPHERALS | 4-1 | | | Standard Input/Output Equipment | 4-1 | | | Teletype Model 33 KSR and Control | 4-1 | | | Perforated Tape Reader | 4-3 | | | Perforated Tape Punch | 4-6 | | | Optional Peripherals | 4-7 | | | Card Reader and Control, Type CR01E | 4-7 | | | Card Reader and Control, Type CR02B | 4-11 | | | Automatic Line Printer, Type 647 | 4-14 | | | Incremental Plotter and Control, Type 350 | 4-19 | | | Oscilloscope Display, Type 34H | 4-20 | | | Precision CRT Display, Type 30D | 4-21 | | | Precision Incremental Display, Type 340C | 4-22 | | | Photomultiplier Light Pen, Type 370 | 4-24 | | | Analog-to-Digital Converter and Multiplexer, Type AF01B | 4-24 | | | General Purpose Analog-to-Digital Converter, Type 138E | 4-27 | | | Multiplexer Control, Type 139E | 4-28 | | | Digital-to-Analog Converter, Type AA01A | 4-30 | | | Multi-station Teletype Control, Type LT09A | 4-31 | | | Relay Buffer, Type DR09A | 4-31 | | | Interprocessor Buffers DB99A and DB98A | 4-32 | | <u>Chapter</u> | | Page | |----------------|-----------------------------------------------|---------------| | | PDP-9/PDP-7 Interprocessor Buffer, Type DB97A | 4-34 | | | Data Communication System Type DP09A | 4-35 | | 5 | AUXILIARY STORAGE SYSTEMS | 5-1 | | | DECtape System | 5-1 | | | DECtape Format | 5-1 | | | DECtape Transport, Type TU55 | 5-4 | | | DECtape Control, Type TC02 | 5-5 | | | Command and Status Bit Configuration | 5-7 | | | DECtape System Programming Information | 5 <b>-</b> 8 | | | DECtape Programming Examples | 5 <b>-</b> 13 | | | DECtape Summary | 5-21 | | | Magnetic Tape Control, Type TC59 | 5 <b>-2</b> 4 | | | Magnetic Tape Functions | 5-26 | | | 9-Track Operation | 5-28 | | | Status or Error Conditions | 5-29 | | | Command Register Contents | 5-32 | | | Magnetic Tape Function Summary | 5 <b>-</b> 33 | | | Magnetic Tape Transport, Type TU20 | 5-35 | | | Magnetic Tape Transport, Type TU20A | 5-36 | | | DISK System, Type RB09 | 5-41 | | | Operation | 5-42 | | | Control Registers | 5 <b>-</b> 46 | | | Status Register | 5 <b>-4</b> 7 | | | Write Protect Feature | 5-47 | | | Maintenance Segment | 5 <b>-4</b> 8 | | | Control Panel | 5-48 | | 6 | ADDRESSING | 6-1 | | | Direct Addressing | 6-1 | | | Indirect Addressing | 6-2 | | | Autoindexing | 6-2 | | | Extend Mode Addressing | 6-5 | | | Reserved Addresses | 6 <b>-</b> 7 | | Chapter | | Page | |---------|-------------------------------------|----------------------| | 7 | instructions | 7-1 | | | Memory Reference Instruction Format | 7-1 | | | Augmented Instruction Format | 7-2 | | | Memory Reference Instructions | 7-2 | | | Load the Accumulator | 7-3 | | | Deposit the Accumulator | 7-3 | | | Deposit Zero in Memory | 7-4 | | | Add (1s Complement) | 7-4 | | | Add (2s Complement) | 7-4 | | | Boolean AND | 7-5 | | | Boolean Exclusive OR | <b>7-</b> 5 | | | Skip if AC Differs | 7-6 | | | Increment and Skip if Zero | 7-6 | | | Unconditional Jump | 7-6 | | | Jump to Subroutine | 7-7 | | | Call (jump to) Subroutine | 7-7 | | | Execute the Instruction at Y | 7-7 | | | Operate Instructions | 7-8 | | | No Operation | 7-10 | | | Complement Accumulator | 7 <b>-</b> 10 | | | Complement Link | 7-10 | | | Inclusive OR ACCUMULATOR Switches | 7-10 | | | Rotate AC and Link Left | 7-11 | | | Rotate AC and Link Right | 7-11 | | | Halt Program | 7-12 | | | Skip on Minus Accumulator | 7-12 | | | Skip on Zero Accumulator | 7-12 | | | Skip on Non-zero Link | <i>7</i> -12 | | | Unconditional Skip | <b>7-</b> 13 | | | Skip on Positive Accumulator | 7-13 | | | Skip on Non-zero Accumulator | <i>7</i> <b>-</b> 13 | | | Skip on Zero Link | <i>7</i> -13 | | | Rotate AC and Link Two Left | 7-14 | | Chapter | | Page | |----------|----------------------------------------|----------------------| | 7 (cont) | Rotate AC and Link Two Right | <i>7</i> -14 | | | Clear the Link | 7-14 | | | Set the Link | <i>7</i> <b>-</b> 15 | | | Clear Link, Then Rotate AC and L Left | <i>7</i> <b>-</b> 15 | | | Clear Link, Then Rotate AC and L Right | 7-15 | | | Clear the Accumulator | 7-16 | | | Clear and Complement Accumulator | <i>7</i> –16 | | | Load AC from ACCUMULATOR Switches | 7-16 | | | Get the Link | 7-16 | | | Load AC with "n" | 7 <b>-</b> 17 | | | Input/Output Transfer Instructions | 7-1 <i>7</i> | | | Clear All Flags | <i>7</i> –19 | | | EAE Instructions | 7-20 | | | Inclusive OR SC with AC | 7-24 | | | Inclusive OR MQ with AC | 7-24 | | | Complement MQ | 7-25 | | | Load AC from MQ | 7-25 | | | Load AC from SC | 7-25 | | | Clear MQ | <b>7-2</b> 5 | | | Load AC with Absolute Value to AC | 7-26 | | | Get Sign and Magnitude of AC | 7-26 | | | Load MQ | 7-26 | | | Basic EAE Instruction | 7-27 | | | Long Right Shift | 7-28 | | | Long Right Shift, Signed | 7 <b>-</b> 28 | | | Long Left Shift | 7-29 | | | Long Left Shift, Signed | 7-29 | | | Accumulator Left´Shift | 7-30 | | | Accumulator Left Shift, Signed | <i>7</i> –30 | | | Normalize | 7-31 | | | Normalize, Signed | 7-33 | | | Multiply (unsigned) | 7-34 | | Chapter | | Page | |----------|-----------------------------------------|---------------| | 7 (cont) | Multiply, Signed | <b>7-</b> 35 | | | Divide (unsigned) | 7 <b>-</b> 36 | | | Divide, Signed | <b>7-</b> 37 | | | Integer Divide (unsigned) | 7-39 | | | Integer Divide, Signed | <b>7-4</b> 0 | | | Fraction Divide (unsigned) | 7-42 | | | Fraction Divide, Signed | 7-43 | | 8 | DATA FORMATS AND ARITHMETIC INFORMATION | 8-1 | | | Signed Data Notations | 8-1 | | | Sign and Magnitude Notations | 8-1 | | | Complement Notations | 8-1 | | | Data Words | 8-3 | | | Data Word Formats | 8-3 | | | Magnitudes of Data Words | 8-5 | | | Basic Software Floating-Point Formats | 8-6 | | | Scaling for Fixed-Point Arithmetic | 8-7 | | | Addition and Subtraction | 8-7 | | | Multiplication | 8-8 | | | Division | 8-8 | | | Scaling on a Binary Computer | 8-8 | | | Overflow | 8-9 | | | Programming Techniques for Scaling | 8-10 | | | Analysis | 8-11 | | | Addition Scaling | 8-11 | | | Multiplication Scaling | 8-13 | | | Division Scaling | 8-14 | | | Fixed-Point Addition | 8-14 | | | Fixed-Point Subtraction | 8-14 | | 9 | INPUT/OUTPUT CONSIDERATIONS | 9-1 | | | Program Controlled Transfers | 9-2 | | | Input/Output Read Status Facility | 9-4 | | | Input/Output Skip Facility | 9-6 | | <u>Chapter</u> | | Page | |----------------|------------------------------------|-------------------| | 9 (cont) | Program Interrupt Control | 9-6 | | | Automatic Priority Interrupt | 9-10 | | | Priority Level | 9-11 | | | Channels | 9-11 | | | API IOT Instructions | 9-12 | | | Dynamic Priority Reallocation | 9 <del>-</del> 15 | | | Programming Examples | 9-16 | | | Data Channel Transfers | 9-17 | | | Add-to-Memory Capability | 9-20 | | | Real Time Clock | 9-20 | | | Direct Memory Access Channel | 9-21 | | 10 | CONTROLS AND INDICATORS | 10-1 | | | Marginal Check Panel | 10-7 | | 11 | INTRODUCTION TO INTERFACING | 11-1 | | | Circuit Modules for Interfacing | 11-1 | | | Logic Symbols | 11-2 | | | I/O Communications | 11-2 | | 12 | THE I/O BUS | 12-1 | | | Physical Description | 12-1 | | | I/O Power | 12-2 | | | Interface Signals | 12-2 | | | Data Lines | 12-2 | | | Output Control Signals | 12-2 | | | Device Selection Levels | 12-4 | | | I/O Run | 12-5 | | | Input Control Levels | 12-5 | | | Multiplexed Control Lines | 12-6 | | | Address Lines | 12-6 | | | Driving Address and Data Lines | 12-7 | | | I/O Bus Interface Summary | 12-7 | | 13 | PROGRAM CONTROLLED TRANSFERS | 13-1 | | | Input/Output Transfer Instructions | 13-2 | | Chapter | | Page | |-----------|-------------------------------------------------------|-------| | 13 (cont) | Reading a Device Buffer into the AC | 13-6 | | | Loading a Device Buffer from the AC | 13-7 | | | I/O Skip Facility | 13-9 | | • | Status Word Facility | 13-10 | | | Program Interrupt (PI) Facility | 13-10 | | | Automatic Priority Interrupt (API), Type KF09A | 13-11 | | 14 | DATA CHANNEL | 14-1 | | | Latency | 14-2 | | | Device Interface Hardware | 14-2 | | | Initial Sequence of Data in Transfer (To Computer) | 14-5 | | | Initial Sequence of Data Out Transfer (From Computer) | 14-6 | | | Expansion to Eight Devices | 14-6 | | | Signal Definitions | 14-7 | | | Add-to-Memory Capabilities | 14-8 | | | Standard Core Register Assignment | 14-9 | | 15 | DIRECT MEMORY ACCESS CHANNEL | 15-1 | | | Memory Provisions for DMA | 15-1 | | | Adapter-Multiplexer, Type DM09A | 15-4 | | 16 | INSTALLATION PLANNING | 16-1 | | | Physical Configuration | 16-1 | | | Placement of Options | 16-7 | | | Environmental Requirements | 16-10 | | | Power Requirements | 16-10 | | | Cabling Requirements | 16-10 | | | Adding Special Interfaces | 16-11 | | Appendix | | | | 1 | Instruction summary | A1-1 | | 2 | PDP-9 I/O CODES | A2-1 | | 3 | SCALES OF NOTATION | A3-1 | ## ILLUSTRATIONS | Figure | | Page | |--------------|---------------------------------------------------------------------------------|---------------| | 1-1 | Basic PDP-9 | 1-5 | | 1-2 | Expanded PDP-9 System Configuration, Block Diagram | 1-6 | | 3-1 | Central Processor-Major Register Organization | 3-1 | | 4-1 | Perforated Tape Formats | 4-4 | | 5-1 | DECtape Format | 5-2 | | 5-2 | RM09, Interface and Block Diagram | 5-40 | | 5-3 | RM09 Drum, Track Layout | 5-40 | | 5-4 | Type RB09 Disk System Interfaced to PDP-9 via DMA MPXR, Type DM09A, and I/O Bus | 5 <b>-</b> 42 | | 5-5 | Format for Track and Segment Addresses | 5-44 | | 7-1 | Memory Reference Instruction Format | 7-1 | | 7-2 | Augmented Instruction Format | 7-2 | | 7-3 | Operate Instructions | 7-9 | | 7-4 | LAW Instruction | 7-17 | | 7 <b>-</b> 5 | IOT Instruction Format | 7-18 | | 7-6 | IOT Instruction Timing | 7-19 | | 7-7 | EAE Instruction Formats | 7-20 | | 7-8 | EAE Microinstructions | 7-23 | | 8-1 | Data Word Formats | 8-4 | | 8-2 | Floating Point Formats | 8-6 | | 9-1 | IORS Word-Status Bit Assignment | 9-4 | | 9-2 | Program Interrupt, JMS Instruction, or CAL Instruction Storage Word Format | 9-8 | | 10-1 | Control Console | 10-1 | | 10-2 | Marginal Check Panel | 10-7 | | 12-1 | I/O Bus Connections | 12-1 | | 12-2 | I/O Bus Interface | 12-3 | | 12-3 | Interface Connectors and Pins | 12-7 | | 13-1 | PDP-9 IOT Instruction Format | 13-2 | | 13-2 | IOT Timing Diagram | 13-4 | | 13-3 | IOT Pulse Waveforms | 13-4 | | 13-4 | Device Selector Configuration | 13-6 | | 13-5 | Loading the AC from a Device Buffer | 13-7 | # ILLUSTRATIONS (continued) | Figure | | Page | |---------|------------------------------------------------------------------------------|-------| | 13-6 | I/O Signals from Buffer to I/O Bus | 13-7 | | 13-7 | Loading a Device Buffer from AC | 13-8 | | 13-8 | I/O Signals from I/O Bus to Buffer | 13-8 | | 13-9 | Device Flag Hardware | 13-9 | | 13-10 | Program Interrupt Storage Word | 13-11 | | 13-11 | W104: PDP-9 I/O Bus Multiplexer | 13-13 | | 13-12 | Device on the Automatic Priority Interrupt | 13-14 | | 13-13 | Connections for Trap Addresses Between 100 <sub>8</sub> and 137 <sub>8</sub> | 13-15 | | 13-14 | Gating Flip-Flop Register onto I/O Address Lines | 13-15 | | 13-15 | Single Device with Multiple Flags | 13-16 | | 14-1 | Data Channel Configuration | 14-4 | | 14-2 | Type W104 Bus Multiplexer | 14-4 | | 14-3 | DCH In Transfer (To Computer) | 14-5 | | 14-4 | DCH Out Transfer (From Computer) | 14-6 | | 14-5 | DCH Timing | 14-8 | | 15-1 | DM09A Option Block Diagram | 15-3 | | 15-2 | DMA Synchronization Cycle, Timing Diagram | 15-6 | | 15-3 | DMA Data Transfer CyclesTiming Diagrams | 15-7 | | 16-1 | Basic PDP-9 Cabinet Specifications | 16-2 | | 16-2(A) | Basic PDP-9 (Front) | 16-3 | | 16-2(B) | Basic PDP-9 (Rear) (Back Door Removed) | 16-4 | | 16-3 | PDP-9 With Extra Memories (Front) | 16-5 | | 16-4 | 19-inch Cabinet Specifications | 16-6 | | 16-5 | PDP-9 With DECtape | 16-7 | | 16-6 | Cabinet Configurations | 16-8 | | 16-7(A) | Basic PDP-9 With DECtape | 16-9 | | 16-7(B) | Memory Expansion and DECtape Expansion | 16-9 | | 16-7(C) | Typical PDP-9 System | 16-10 | | 16-8 | Cabinet Configurations | 16-12 | # TABLES | <u>Table</u> | | Page | |--------------|---------------------------------------------------------------|---------------| | 4-1 | Card Reader CR01E Controls and Indicators | 4-9 | | 4-2 | Card Reader CR01E IOT Instructions | 4-10 | | 4-3 | Card Reader CR02B IOT Instructions | 4-12 | | 4-4 | Console Lights, Buttons, and Switches | 4-13 | | 4-5 | Line Printer Controls and Indicators | 4-16 | | 4-6 | Line Printer Type 647E | 4-18 | | 4-7 | Incremental Plotter and Control Instructions | 4-20 | | 4-8 | Oscilloscope and Precision Display Instructions | 4-21 | | 4-9 | Precision Incremental Display Instructions | 4-23 | | 4-10 | A/D Converter Characteristics | 4-25 | | 4-11 | AF01B A/D Converter and Multiplexer IOT Instructions | 4-26 | | 4-12 | General Purpose A-to-D Converter Characteristics | 4-27 | | 5-1 | TC02 Control IOT Instructions | 5-6 | | 5-2 | TC59 Control IOT Instructions | 5-24 | | 5-3 | Disk Format and Timing Specifications | 5-41 | | 7-1 | EAE Operation Times | 7-27 | | 7-2 | EAE Microinstructions | 7-45 | | 9-1 | Status Bits Associated With The SPI Instruction | 9-13 | | 9-2 | Control Bits Associated With ISA Instruction | 9 <b>-</b> 14 | | 9-3 | Status Bits Associated With ISA Instruction | 9-14 | | 10-1 | Operator Console Controls and Indicators | 10-2 | | 10-2 | Marginal Check Panel Controls and Indicators | 10-8 | | 11-1 | Data Transfer Rates | 11-3 | | 12-1 | I/O Bus Interface Chart | 12-8 | | 13-1 | Assigned PDP-9 IOT Device Selection Codes | 13-3 | | 13-2 | Channel and Priority Assignments | 13-12 | | 16-1 | PDP-9, Extra Memory, Free-Standing Options and Their Controls | 16-13 | | 16-2 | Wired-In Options | 16-14 | | 16-3 | Hardware and Logic Options for 19–Inch Cabinets | 16-15 | Programmed Data Processor-9 # CHAPTER 1 SYSTEM INTRODUCTION The PDP-9<sup>®</sup> programmed data processing system is a general purpose computer, incorporating FLIP CHIP hybrid integrated circuits throughout. The PDP-9 features: High performance at low cost Demonstrated reliability Simple input/output interfacing Extensive software Flexible, high capacity, input/output provisions coupled with a complete line of peripheral equipment allow system planning to satisfy a variety of applications. PDP-9 can be easily configured to perform equally well the role of central data processing facility, control element, or satellite processor. The ease with which its modular hardware and software adapt to the requirements of data acquisition, process control, and on-line processing in real-time environments makes it the ideal small scale system for scientific and industrial use. The PDP-9 system is a single address, fixed word length (18 bits), parallel binary computer. The minimum system configuration (see frontispiece) has 8192 words of core memory storage; paper tape input at 300 cps and output at 50 cps; console teleprinter keyboard input and printer output at 10 cps; and a real-time clock. The system readily interfaces to optional peripherals such as punched card equipment, line printers, magnetic tape transports, analog-to-digital converters, digital-to-analog converters, CRT displays, data communication equipment, and magnetic drum and disc systems. Equipment of special design is easily adapted for interfacing to the PDP-9. The FLIP CHIP module line offers proven reliability plus simple, inexpensive fabrication of compatible interface controls for special equipment, or for the special-purpose equipment itself. Peripherals can be interfaced to the system as processing requirements expand, without modification of the central processor. #### **CHARACTERISTICS** Complete cycle time of 1 usec for the random access, ferrite core memory. Real-time clock generates a clock pulse every 16.7 msec (every 20 msec for 50 Hz systems) to increment a time counter stored in system memory. The counter initiates a program interrupt when a programmed preset time interval is completed. The clock can be enabled or disabled under program control. PDP is a registered trademark of the Digital Equipment Corporation. True direct addressing is provided for all 8192 18-bit word locations in the basic core memory module configuration or any memory module appended to the system. The system allows indirect addressing up to the memory expansion limit of 32,768 locations. Core memory is expanded in increments of 8192 words. Memory parity can be optionally included. With the parity option, memory cycle time is approximately 1.2 µsec. System software expands to make efficient use of all available core memory storage. Power failure protection can be optionally implemented to protect against data loss due to internal power interruptions. With this option, the PDP-9 is unaffected by power interruptions of less than 25 msec duration. In the event of a longer interruption, the option can save the active register contents and automatically restart the interrupted program at a specified address when power is restored. Without the "power failure protection" option, power interruptions of 10 msec duration, or longer, may result in loss of active register contents and memory contents. <u>Automatic readin</u> is provided of binary-coded programs from paper tape via the paper tape reader. A user-initiated and hardware-implemented control transfers 18-bit words (three tape lines) from tape to a block of sequentially addressed core memory locations, and executes the instruction defined by the last word without further user intervention. <u>A built-in test program</u>, user-initiated and hardware-implemented, circulates a self-incrementing count through all central processor registers for the purpose of validating both their operation and the internal transfer paths. The user can monitor and verify register operation by observing the respective register display on the control console. All input/output transfers are executed in parallel bytes up to 18 bits in length. The system's I/O facilities can service data transfer rates up to one million bytes per second. Bidirectional input/output bus is provided for program controlled data/command transmissions between the central processor and up to 256 external devices. All program controlled I/O transfers pass through the central processor's accumulator (AC), the 18-bit primary arithmetic register. Memory referencing instructions convey data between the AC and system core memory. IOT (input/output transfer) instructions select appropriate devices and effect the data transfer between the AC and information registers in the devices. Four buffered data channels allow fast, non-overlapping data transmission between system core memory and four devices interfaced to the I/O bus. Data channel transfers occur via the memory buffer (MB) register in the central processor and do not disturb the contents of other major registers in the processor. Thus, a data channel transfer suspends rather than interrupts execution of the program in progress. The maximum transfer capacity of the data channel facility is between 250,000 and 333,333 words per second, depending on the mix of input and output transfers (each output transfer steals four machine cycles; each input transfer steals three cycles). Provisions are made in system memory for word counter registers and current address registers unique to each data channel. The data channel facility can be expanded for multiplexed servicing of up to four additional devices. <u>Direct memory access channel</u> (DMA) bypasses the central processor, allowing direct, cycle stealing, data transmission between core memory locations and external devices via a separate entry port to system memory module(s). DMA transfers have priority over all other system actions. An optional multiplexer/adapter will interface to and allocate priority of service among up to three devices. Program interrupt control frees the program in progress from the necessity of monitoring the status of peripheral devices. The program continues until a device signals a request for service. A subroutine, entered automatically upon the processor's granting of the interrupt request, stores the interrupted program's status, determines the device making the request, and transfers control to the appropriate service subroutine. At completion of the device servicing, the interrupted program is restored to control. The program interrupt control facility is suitable for those peripheral devices having low data rates. Multilevel automatic priority interrupt option (API) affords immediate access to device handling and data handling subroutines on a ranked priority basis. Of the eight priority levels added by this option the four higher levels are assigned to device use, and the lower four are assigned to software use. The priority levels are fully nested; i.e., a higher priority request can interrupt in-process servicing of a lower priority. The restoration of an interrupted service subroutine does not require additional programming considerations. Likewise, the return to an interrupted main program segment is easily implemented. The granting of priority interrupt requests, at completion of the current instruction, is rated above program and program interrupt activity and below data channel or direct memory access channel activity, or real-time clock counting. The API system has 32 channels of which 28 are allocated to external device interrupting (hardware priority levels) and 4 are allocated to programmed interrupting (software priority levels). A channel assignment defines the core memory location of the unique entry to an interrupt subroutine. Device channels function independently of priority; up to eight device channels may be assigned to the same priority level. Device channels also may be multiplexed without limit, in which case the channel address defines the entry to a search routine rather than unique entry to one routine. Additional provisions include dynamic reallocation of device priority level assignments (device control must be designed with logic circuits to accomplish reassignment) and programmed raising of the active interrupt to a priority level higher than the normal assignment, when the situation requires exclusion of interrupt requests at specific priority levels. The API is program enabled or disabled. Specific devices can be inhibited from interrupting by appropriate control inputs to their interfaces. The basic machine has fixed-point hardware capability and floating-point software capability for performing binary arithmetic in 1s and 2s complement notations. Floating-point software offers choice of 6 or 9 decimal digit precision. The program library supplied includes extensive repertoire of multi- and single-precision subroutines. Add or subtract (complementary addition) is performed in 2 µsec with fetch of operand from effectively addressed core memory location. Overflow indication is furnished for 1s complement addition where absolute value of algebraic summed result exceeds capacity of the accumulator (2<sup>17</sup> – 1). Algorithms for 2s complement addition and subtraction treat overflow from accumulator as a carry into a 1-bit register called the "link". Extended arithmetic element option offers fast, flexible, hardware execution of the following as signed or unsigned functions: Shifting the contents of the primary arithmetic registers (AC or MQ), right or left, in 2 to $17 \mu sec$ . Normalizing the quantity in the primary arithmetic registers; i.e., shifting the contents left to remove leading binary 0s for the purpose of preserving as many significant bits as possible. Time required is 2 to $17 \, \mu sec$ . Multiplication in 3 to 11 µsec. Division, including integer and fractional, in 3 to 12 $\mu$ sec. Divide overflow indication is furnished when division would produce quotient exceeding $2^{17}$ – 1 magnitude. #### **DESIGN** The compactness of the PDP-9 affords maximum computing facility in a minimum of space; its modular construction provides for ease of system growth to meet future processing requirements—external devices and additional core memory append with minimum effort and no effect on the central processor. (Section 4, Interface, presents complete details on interfacing special purpose or user-designed external devices to the PDP-9 input/output facilities.) PDP-9 is completely self-contained, and does not require special air conditioning or humidity control. Internal power supplies generate all required operating voltages from a single input source of 115-volt, 60-Hz single-phase power. Systems can be supplied to operate with 50 Hz power at a variety of voltage levels. #### CONFIGURATIONS The basic PDP-9 configuration (figure 1-1) consists of the following. - 1. Central processor with integrated control console, work shelf and chair. - 2. Core memory stack of 8192 18-bit words. Includes interface connection for direct memory access of memory locations by high data rate peripherals. - 3. Three peripheral devices: a 300 character/second paper tape reader; a 50 character/second paper tape punch; and an input/output teleprinter, Teletype Model KSR 33. (Teletype Model KSR 35 can be optionally supplied and is recommended for applications where extreme use is to be made of the teleprinter's output function.) - 4. Real-time clock. - 5. Input/output facilities: I/O bus, four data channels, direct memory access channel, program interrupt control, I/O status word provision, and conditional skip on external device status. Figure 1-1 Basic PDP-9 ## The PDP-9 expands into a variety of configurations by: Increasing system core memory from the basic-supplied 8192 words up to 32,768 words in increments of 8192 words. Memory parity may be optionally added. Adding peripheral equipment selected from the PDP-9 line, or interfacing the system to special purpose or user-designed equipment. Interfacing a basic or expanded PDP-9 to a data processing complex. Incorporating central processor options to increase the system's computing and data handling power. Figure 1-2 illustrates a typical expanded PDP-9 system. Figure 1-2 Expanded PDP-9 System Configuration, Block Diagram # CHAPTER 2 SOFTWARE SYSTEMS PDP-9 offers two complete software systems, PDP-9 BASIC and PDP-9 ADVANCED, plus an extensive library of arithmetic subroutines, utility programs, and maintainence and diagnostic routines. PDP-9 BASIC software functions in a paper tape input/output environment (i.e., source and object forms of programs reside on paper tape) with its field-tested components running in stand-alone fashion to provide the user with powerful single-job capabilities. PDP-9 ADVANCED software is an all-new package of systems and utility programs, combining the latest concepts in device-independent programming with the power of FORTRAN IV and a macro assembler. PDP-9 ADVANCED software will be available July 1967 in the following two compatible versions: Under control of a simple input/output monitor for basic PDP-9s with paper tape input/output or card input. This version will greatly expand the single-job capabilities available with PDP-9 BASIC software. In a more sophisticated monitor environment for all PDP-9s with some form of auxiliary bulk storage (DECtape, magnetic tape, disc, or drum). This latter version will permit device-independent programming under control of a keyboard monitor and a sophisticated input/output programming system. #### PDP-9 BASIC SOFTWARE PDP-9 BASIC software includes a FORTRAN II Compiler, Symbolic Assembler, Dynamic Debugging Technique (DDT) program, and Symbolic Tape Editor. All are designed to operate as stand-alone systems in a paper tape input/output environment. PDP-9 BASIC software is fully documented in PDP-9 BASIC Software Systems (DEC-9B-GSAA-D). #### FORTRAN II The PDP-9 FORTRAN II compiler is designed to operate on an 8,192-word system with Teletype, paper tape reader, and punch (the minimum standard PDP-9 system). FORTRAN II object programs may utilize additional available memory to store dimensioned arrays and COMMON data, and can list on line printers. The principal components of the FORTRAN II system are: - Compiler - FORTRAN Assembler - Object-Time System - Library, including routines for input/output, 6-decimal-digit arithmetic, and 9-decimal-digit arithmetic - Linking Loader The compiler accepts input in the FORTRAN II language and produces output in an intermediate language acceptable to the FORTRAN assembler. The assembler accepts the compiler output and produces a binary relocatable version of the program plus a binary version of the linking loader. Approximately 4000<sub>10</sub> locations are available for program and data storage. When ready to execute a program, the user loads the main program and any subprograms required, followed by any standard functions available in the subroutine library. After the total program has been entered in core, the object-time system is loaded and the program is executed. The object-time system includes an interpretive system for floating-point arithmetic, a translator for format statements, routines such as fixed-to-floating-point conversion, and the input/output routines. The object-time system occupies approximately 4000<sub>10</sub> locations and must be in memory while a FORTRAN II program is being executed. Among the important features of the PDP-9 FORTRAN II system are: - The ability to intermix symbolic assembly language coding with FORTRAN statements. - Floating-point constants with either 6- or 9-decimal-digit accuracy (selectable). - Fixed-point constants with values up to ± 131,071. - Mixed mode expressions. - Arrays of up to four dimensions and subscripting to any level. - FUNCTION and SUBROUTINE statements. #### Symbolic Assembler The PDP-9 Symbolic Assembler, in one pass, translates symbolic source programs into binary object programs. Although designed to operate on a minimum PDP-9 configuration, it can assemble PDP-9 programs for any size PDP-9 system. PDP-9 symbolic level coding allows the programmer to simplify the coding task using mnemonic codes for the instructions and symbolic names for addresses or locations. Pseudo-operation codes are available to give commands to the assembler causing it to set aside data areas, change state, or produce fixed sequences of instructions. In the assembly phase, the source program is read line by line and converted to proper binary format. Mnemonic codes are translated to their binary equivalent, and symbolic addresses are replaced by actual addresses. At the end of the assembly phase, any undefined symbols encountered are reported to the operator. #### Dynamic Debugging Technique The Dynamic Debugging Technique (DDT) program for the PDP-9 is a versatile tool for program check-out and modification. Occupying the upper 2000<sub>8</sub> locations in core memory, it allows an operator to load a program and run all or selected portions of it under strict supervision. With DDT, breakpoints may be inserted or deleted, registers may be examined and altered, patches may be inserted and punched out in a form acceptable to the loader, and printouts may be obtained at critical junctures. By loading and utilizing the object program's symbol table, DDT may employ symbolic references to all locations, instructions, and variables. Control of DDT and program examination and modification are obtained via the Teletype keyboard and paper tape punch. Simple commands are available to allow the operator to insert a break-point at any location, specify the number of iterations to be accomplished before it halts the program, and start the program at any point. Other commands allow the operator to "open" or examine any location, alter it if he wishes, "close" the register, remove the breakpoint, and punch out loadable binary tapes. These patch tapes eliminate the necessity of correcting symbolic tapes and reassembling. #### Symbolic Tape Editor The Symbolic Tape Editor is designed to facilitate the preparation and correction of symbolic source tapes. The editor reads sections of symbolic tape into memory and makes them available for examination, correction, and punch-out. Corrections, new text, and commands to the Editor program are made via the Teletype keyboard. Tape input and output may be specified to be in either ASCII or FIODEC code. The information to be edited is stored in a text buffer which occupies all of memory not utilized by the Editor program; in an 8,192-word PDP-9 the buffer will hold approximately 16,000 characters. Symbolic programs are punched on paper tape in blocks separated by form-feed holes; each block may have as many lines as the programmer desires. Editor commands are available to read a block into core, examine one or more lines, list the entire buffer, clear the buffer, append new text to the end of the buffer, delete or replace lines, and punch out all or any portion of the buffer. Combination commands are available to facilitate tape duplication. New tapes may be created by clearing the buffer, appending new text to the empty buffer, and punching out the buffer on tape. #### PDP-9 ADVANCED SOFTWARE PDP-9 ADVANCED software is an all-new completely relocatable software package combining sophisticated programming features with flexibility and ease of use. Available to PDP-9 users in July, 1967, this new package includes a FORTRAN IV compiler, a macro assembler, an on-line debugging system, a symbolic editor, a peripheral interchange program, a linking loader, an input/output programming system, and a monitor. Two versions of the PDP-9 ADVANCED software system will be made available: a simple input/output monitor system with paper tape input/output and the option of punched card input facilities for basic PDP-9 users. The system will also include a more sophisticated monitor-based, device-independent system for PDP-9s with one or more forms of auxiliary bulk storage (magnetic tape, DECtape, disc, or drum). Both systems will be compatible. #### Paper Tape (or Card) System Basic or extended-memory PDP-9 systems without auxiliary bulk storage use the FORTRAN IV compiler, macro assembler (MACRO-9), debugging system (DDT-9), Symbolic Editor, Peripheral Interchange Program (PIP-9), and Linking Loader under the control of the Input/Output Monitor. Only paper tape input/output or card input is provided. All systems programs have full features, are completely relocatable, and handle or produce relocatable code. Maximum utilization will be made of optional central processor features, such as the Extended Arithmetic Element and Automatic Priority Interrupt, when they are available. #### Device-Independent System The inclusion of bulk storage in a PDP-9 will allow the use of the keyboard monitor-based, device-independent version of PDP-9 ADVANCED software. The minimum bulk storage requirements are: - 2 DECtape transports (TU55) and control (TC02), or - 2 IBM-compatible transports (TU 20 or equivalent) and control (TC59), or - 1 disc system and control With the addition of one of these forms of bulk storage to a PDP-9 system, the Keyboard Monitor (KM-9), and the Input/Output Programming System (IOPS) can be used to automatically store, retrieve, load and execute PDP-9 programs. With this device-independent version of PDP-9 ADVANCED software, the user can call his system programs from any bulk storage device (designated the system device), compile or assemble from any input device to any proper output device, and (optionally) obtain listings on any printing device or magnetic tape. By using the keyboard monitor to change the system and object program device assignment tables, the operator may designate at load time which devices shall serve as system device, object program storage, and data input and output devices. The linking loader, with access to the input/output programming system, automatically loads the input/output programs required by the device assignment tables. #### System Components The component packages of the new PDP-9 ADVANCED software system are described briefly below. More complete descriptions will be found in the individual language specification or operator's manual for each program. #### FORTRAN IV The PDP-9 FORTRAN IV compiler is a two-pass system which accepts statements written in the FORTRAN language and produces relocatable object code capable of being loaded by the linking loader program. It is fully compatible with USA FORTRAN IV, as defined in the USA Standard X3.9-1966, with the exception of the following few features which were modified to allow the compiler to operate in 8,192 words of core storage: - 1. Complex arithmetic will not be available. - 2. Adjustable array dimensions will not be allowed. - 3. Blank COMMON will be treated as named COMMON. - 4. The implied DO feature will be deleted from the DATA statement. This FORTRAN IV compiler operates with the PDP-9 program interrupt facility enabled and generates real-time programs that both operate with the program interrupt enabled and can work in conjunction with assembly language programs that recognize and service real-time devices. Subroutines written in either FORTRAN IV or the Macro Assembler language can be loaded with and called by FORTRAN IV main programs. Comprehensive source language diagnostics are produced during compilation; a symbol table is generated for use in on-line debugging. #### Macro Assembler (MACRO-9) With the Macro Assembler, PDP-9 users are able to utilize highly sophisticated macro generating and calling facilities within the context of a symbolic assembler. Among the more prominent features of MACRO-9 are: - 1. The ability to define and call nested and recursive macros. - 2. Conditional assembly based on the computational results of symbols or expressions. - 3. Repeat functions. - 4. A variety of fixed- and floating-point symbolic formats for constants. - 5. Boolean manipulation. - 6. Optional octal and symbolic listings. - 7. Three forms of radix control (binary, octal, decimal) and two text modes (ASCII and 6-bit trimmed ASCII). - 8. Global symbols for easy linking of separately assembled programs. - 9. Choice of output format: relocatable, absolute binary (checksummed); full binary (unchecksummed), capable of being loaded via the READ IN key (console). - 10. Ability to call input/output system macros which expand into IOPS calling sequences. #### Debugging System (DDT-9) DDT-9 adds the flexibility of relocatability and real-time operation to the capabilities of PDP-9 BASIC DDT. With it, the user may load and operate his program in a real-time environment while maintaining strict control over running of each section. DDT-9 allows the operator to insert and delete break-points, examine and change registers, patch programs, and search for specific constants or word formats. The DDT break-point features allows for the insertion and simultaneous use of up to four break-points, and any one or all of these break-points may be removed with a single keyboard command. The search facility allows the operator to specify a search through any part, or all of an object program with printout of the locations of all registers that are equal (or unequal) to a specified constant. This search feature also works for portions of words as modified by a mask. With DDT-9, registers may be examined and modified in either instruction format or octal code, and addresses may be specified in symbolic relative, octal relative, or octal absolute. Patches may be inserted in either source language or octal. #### Symbolic Editor The Symbolic Editor of the PDP-9 ADVANCED software system provides the ability to read symbolic text from any input device (paper tape reader, card reader, disc, drum, DECtape, magnetic tape, etc.), to examine and correct it, and to write it on any output device. It can also be used to create new symbolic programs. The Editor operates on lines of symbolic text, delimited by carriage return (C/R) characters and organized into blocks or pages. These lines can be read into a buffer, selectively examined, deleted, or modified, and written out. New text may be substituted, inserted, or appended. Among the types of commands available to the operator through the Symbolic Editor are: #### 1. Input Operations - a. Read a page of text. - b. Read n lines of text. - c. Skip a page of text. - d. Skip n lines of text. #### 2. Examination Operations - a. Print the entire buffer. - b. Print n pages. - c. Print lines n through m. - d. Print line n. - e. Print the entire buffer without comments. - f. Print lines n through m without comments. - g. Print line n without comments. - h. Search for and print the next location symbol. - Back up and print the previous line. #### 3. Editing Operations - a. Delete line n. - Delete lines n through m. - c. Append text. - d. Insert text before line n. - e. Change line n. - f. Change lines n through m. - g. Read the next n lines and insert them after line m in the buffer. - h. Erase the buffer. - i. Move a line. #### 4. Output Operations - a. Output the entire buffer. - b. Output line n. - c. Output lines n through m. - d. Punch a form feed. Several commands which combine input and output commands are also available to the user. With these, the buffer may be cleared and a new page automatically read in after the output of an edited page, or one or more pages may be read and punched in one operation (for duplication of sections of a symbolic tape). #### Peripheral Interchange Program (PIP-9) The primary function of PIP-9 is to facilitate the manipulation and transfer of data files from any input device to any output device. It can be used to update file descriptions, delete, insert, or combine files, perform code conversions, rewind tapes, and retrieve storage space that is no longer required by a file device. #### Linking Loader The Linking Loader has the task of loading any PDP-9 FORTRAN IV or MACRO-9 object program which exists in relocatable or absolute format. Among its tasks are loading and relocation of programs, loading of called subroutines, retrieval and loading of implied subroutines and IOPS routines, and loading and relocation of the necessary symbol tables. #### Input/Output Programming System (IOPS) IOPS provides a standardized programming interface to all input/output devices in a PDP-9 system. Symbolic input/output unit assignments allow users' programs to select I/O devices specified symbolically to the macro assembler or the FORTRAN IV compiler. IOPS consists of a modular collection of relocatable input/output and utility subroutines which transmit data to and from peripheral devices and make data readily available for processing. IOPS data and file handling routines include device independence for all systems programs. Specifically, IOPS provides the user with three levels of I/O programs. - 1. Device handling providing the basic subroutines to allow the user to operate a device, doing code conversion where required. - 2. Data handling providing the data buffering and internal line and character transmission facilities. - 3. File handling providing for the manipulation of named files on the system level. IOPS completely eliminates the need for the programmer to program the standard peripheral devices. The programmer is no longer concerned with input/output problems such as timing, overlap, and the differences in the characteristics of peripheral devices. This permits him to concentrate on his primary task, the processing of data inside the computer. IOPS is coded on a modular basis to allow addition of new devices and modifications to the handling of current devices. It requires considerably less effort to modify an IOPS subprogram then to revise individual input/output sections to fit a new configuration. By the use of IOPS, programs can be changed more rapidly to fit the expanding configurations. #### Input/Output Monitor The simple input/output monitor includes the device assignment tables and input/output routines necessary for programs being run on PDP-9s without bulk storage. The function of the monitor is to handle all input and output for system programs or users' programs so that the programmer need not be concerned with device or data manipulation routines. Normally only paper tape input/output or card input is allowed by the input/output monitor. #### Keyboard Monitor (KM-9) The Keyboard Monitor allows convenient single job processing through commands to the console teleprinter. Its primary functions are: to allow the user direct and immediate access to system user programs stored on bulk storage devices; to faciliatate the creation and storage of new programs by the user; and to allow input/output device-independent programming with "load-time" specification of peripherals. KM-9 consists of a bootstrap loader, a keyboard listener program, a monitor command decoder, IOPS routines, an error diagnostic program, and device assignment tables (DATs). The bootstrap loader always resides in upper memory and is responsible for loading the monitor into lower memory. Return calls from system or user programs cause restoration of control to the Monitor. The keyboard listener (KLIST) accepts input commands from the teletype and handles Monitor initialization and bookkeeping. The Monitor command decoder (MCD) recognizes requests for system programs and loads the system loader to bring in the requested program. In response to keyboard commands, it also manipulates the device assignment tables to provide the device-independent programming features. The Monitor IOPS include data handling subroutines, and device handlers and interrupt service routines for the Teletype keyboard and printer. The routines for the system device will also be present with the Keyboard Monitor, but all other IOPS routines will be stored on the system device until required by object programs. The Monitor also contains device assignment tables. The purpose of the DATs is to relate logical I/O units to the actual hardware devices. Each input or output reference within a system or user program refers to a position in a device assignment table. This table, in turn, contains a device assignment for each table entry that may be used. Since the contents of the tables can be altered by commands to the Keyboard Monitor, actual I/O devices may be changed without altering the program references to these devices. #### Expansion of PDP-9 Advanced Software System The above-mentioned features of the PDP-9 ADVANCED software system will all be ready for release in July, 1967. Included in the initial system design, but not scheduled for completion until a later date are: - Time-shared use of the PDP-9 by a protected priority foreground program and an unprotected system or user background program. This feature will utilize a background/foreground monitor and will require 16,384 words of core, bulk storage, and the memory protection option. - Batch processing from any peripheral device, including the ability to accept monitor commands from any system input device. Although these features will not be available with the initial versions of PDP-9 ADVANCED software, all necessary provisions have been made for them in the system programs. #### MAINDEC DIAGNOSTIC PROGRAMS MAINDEC diagnostic programs are provided for locating hardware malfunctions within the processor, memory, and I/O equipment. These programs are designed to make troubleshooting fast and straightforward by selectively exercising every circuit in the machine. Instructions and procedures for loading, operating, and interpreting the results of diagnostic tests are written in clear, simple language, so that beginning maintenance technicians can use them easily. Detailed error messages are printed out to tell the technician exactly which instruction, or bit configuration, has failed. Error codes direct the troubleshooter to specific modules when a fault condition is detected. The program consists of two parts: the Basic Processor Test and the Extended Processor Test. The Basic Test incrementally checks the entire instruction repertoire, performing 1500 unique tests, and in each case, halts with specific instructions for the troubleshooter. If the Basic Test fails to detect the trouble, the Extended Test uses random number techniques to test the logic for many combinations of data manipulation and addressing problems, runs memory test patterns, performs system tests on I/O devices and controls, and many other tests. A valuable tool for check-out and troubleshooting, MAINDEC diagnostics contribute to the high productivity of the PDP-9 by minimizing downtime. # CHAPTER 3 SYSTEM ORGANIZATION The major functional components of the PDP-9 system are the central processor, core memory, and input/output facilities. This chapter discusses these components and the options offered for each. #### CENTRAL PROCESSOR UNIT Figure 3-1 illustrates the internal organization of the PDP-9 central processor. Employing a transfer bus system, data is jam-transferred between registers at DC levels to minimize timing problems (level logic is used instead of pulse logic in the central processor). All active registers use simple circuit designs (no logical delays). Figure 3-1 Central Processor-Major Register Organization Control Elements (not illustrated) that govern the gating of information transfers include: <u>Instruction Register (IR)</u> - The IR accepts the five most significant bits of each instruction word fetched from memory. The four most significant bits constitute the operation code and, when decoded, indicate the entry point to the control memory microinstruction sequence necessary to effect system response. The fifth bit signals when the fetched instruction indicates indirect addressing. Control Memory (CM) - The CM stores all sequences of internal microinstructions required to fetch and execute a program's instructions, to effect operation of the data channels, and to respond to operator commands initiated at the control console. It is a very fast, read-only, magnetic-core storage unit, prewired with the sequences. <u>Control Register (CR)</u> - The CR delivers gate control signals to the transfer busses and to the active registers. The register supplies new address information to the CM based on conditions sensed. Major registers in the processor are: Adder (ADR) - The 19-bit ADR functions as a fast adder for arithmetic operations, and as the transfer path for all inter-register transfers and shift operations. It also increments the PC and MB registers, as required. Entry to the ADR is via the A bus and/or the B bus, under control of CR-developed gating control levels. The ADR operates at a 5 mc rate to provide an interregister transfer time of 200 nsec. Accumulator (AC) – The AC, an 18-bit register, retains the result of arithmetic/logical operations for the interim between instructions. The AC can be cleared and complemented. Its contents can be rotated right or left with the link. The contents of the memory buffer register can be added to the contents of the AC with the result left in the AC. The contents of both registers can be combined by the logical operations AND and exclusive OR, the result remaining in the AC. The inclusive OR can be formed between the AC and the Data switches on the operator console and the result left in the AC. For all program controlled transfers, information is transferred between core memory and an external device through the accumulator. <u>Link (L)</u> - This 1-bit register is used to extend the arithmetic capability of the accumulator. In 1s complement arithmetic, the link is an overflow indicator; in 2s complement arithmetic, it logically extends the AC to 19 bits and functions as a carry register. The program can check overflow into the link from the accumulator to greatly simplify and speed up single and multiple precision arithmetic routines. The link can be cleared and complemented and its state sensed independent of the AC. It is included with the AC in rotate operations and in logical shifts. <u>Arithmetic Register (AR)</u> - The AR functions with the AC to perform arithmetic and logical operations. It is not accessible to the programmer. Its operation is a function of the microinstruction sequences in the CM. Multiplier-Quotient Register (MQ) - The optionally implemented extended arithmetic element (EAE) adds the logic of the MQ to the basic PDP-9. The MQ is 18 bits long and holds the multiplier during multiplying instructions and receives the low-order 18 bits of the resulting product. During division operations it holds the low-order 18 bits of the dividend and, at the completion of the divide instruction, it contains the quotient. It can also be used as an extension of the AC for 36-bit shift operations and for data normalizing operations. <u>Program Counter (PC)</u> - The PC determines the program sequence; that is, the order in which instructions are performed. This 13-bit register contains the address of the memory cell from which the next instruction is to be taken. Addition of the memory extension control option expands the PC to 15 bits for the addressing of up to 32,768 locations. Memory Buffer Register (MB) - All information transferred into or out of core memory passes through the 18-bit MB. Information is read from a memory cell into the MB and rewritten into the cell in one cycle time. Instructions and data are brought from core memory into the MB for processing. The MB serves also as a buffer for information transferred between core memory and an external device in data channel transfers. #### CORE MEMORY The PDP-9 core memory utilizes a new design concept for speed, compactness, and reliability; it operates with a complete cycle time of 1.0 µsec. Each 8,192-word core memory module contains a core stack, sense amplifiers, drivers, and a memory address (MA) register. The MA sets up the memory location (address) to be used for data retrieval or storage. System core memory can be expanded from the basic 8,192 words up to 32,768 words in 8,192-word increments. Such expansion requires implementation of the optional Memory Extension Control, Type KG09A to extend the PDP-9 addressing capability. Each PDP-9 memory module has a two-port capability for data entry and retrieval. One port, connecting to the memory bus, services the processor. The other port allows a peripheral device direct and immediate access to memory for fast data transfers via a direct memory access (DMA) bus. A device request for DMA service has priority over a processor request. The latter is deferred until DMA operation terminates. The optional Multiplexer Adapter, Type DM09A permits concurrent servicing of up to three DMA peripherals and assigns each a fixed priority. #### INPUT/OUTPUT FACILITIES The following text briefly describes the input/output facilities provided with the PDP-9 in its minimum (basic) configuration. Detailed descriptions concerning the operation and use of these facilities are presented in chapter 9, Input/Output Operations. #### Basic PDP-9 I/O facilities include: - 1. A I/O bus system which chain links all the device controls for all peripheral devices to the central processor unit (CPU). - 2. A data channel control governing concurrent (non-overlapping) operation of four data channels. - 3. A direct memory access (DMA) channel offering true, cycle-stealing access to system memory locations. - 4. A program interrupt control. - 5. An I/O status-read provision. - 6. A conditional skip-on-device-status provision. The PDP-9 apportions I/O control between the CPU and the various device controls interfaced to the I/O facilities. The complexity of any device control is thus a function of the type of device and of the facilities which it must make use of to accomplish its system purpose. This scheme has several benefits for the user. - 1. It negates the need for expensive I/O processors or controllers. - 2. The structure of the I/O system can be expanded or reconfigured at anytime without modification of the CPU. - 3. User-designed or special purpose equipment can be easily interfaced to the PDP-9 through the inexpensive fabrication of the required device control units. Peripheral equipment may either be asynchronous with no timed transfer rates or synchronous with a timed-transfer rate. Devices such as the CRT displays, teleprinter-keyboard, and the line printer can operate at any speed up to the maximum without loss of efficiency. These asynchronous devices remain on and ready to accept data; they do not turn themselves off between transfers. Devices such as magnetic tape, DECtape, the serial drum, and card equipment are timed-transfer devices and must operate at or near their maximum speeds to be efficient. The I/O bus consists of command lines and bidirectional data lines for use in accomplishing program-controlled transfers or data channel transfers; plus the use of the program interrupt control, the I/O status-read and conditional skip-on-device-status provisions, and the Automatic Priority Interrupt system option Type KF09A, if implemented. The program-controlled mode functions with single word or byte (up to 18 bits, parallel) transfers made under control of programmed instructions. The data channel mode permits block transfers at high speed without interruption of the program in progress. The DMA channel is a separate I/O data path, permitting direct access to system memory locations for high data rate devices such as magnetic drum and disc systems. This facility enables the transfer of data at rates up to one million words or bytes per second. It operates on a true cycle-stealing basis. All I/O data transfers function within the precedence of the following priority structure. - 1. Direct memory access channel requests (highest priority) - 2. Data channel requests - 3. Real time clock counting (clock is considered to be an I/O device). - 4. Priority interrupts, 8 levels (optional) - 5. Program interrupts - 6. Main program in progress (lowest priority) A higher priority request for service interrupts any in-process service of a lower priority at the end of the current instruction, or, in the case of the DMA channel, at the end of the current memory cycle. Program interrupts and priority interrupts require that the main program transfer control to specific service subroutines. These routines restore control to the program at completion of the service interval. Computer-granted breaks satisfy data channel requests; i.e., program execution is delayed but not disturbed while the data channel transfers information between memory and the requesting device via the MB. ### **Program Controlled Transfers** Program controlled transfers are made by IOT (input/output transfer) instructions contained in the main program or in service subroutines. These instructions are microcoded to effect response only for a particular device. The microcoding includes issuing a unique device selection code and appropriate processor-generated pulses to initiate the specified operation. All program controlled transfers are executed through the accumulator (AC) in parallel bytes up to 18 bits in length. For an "out" transfer, the program reads a data word from memory into the AC. A subsequent IOT instruction places the data on the bus, selects the device, and causes it to enter the word in its data buffer register. For an "in" transfer, the process reverses. An IOT instruction selects the device and causes the contents of its data buffer to be gated onto the I/O bus. In turn, the word is strobed into the AC and read, by the program, into memory. ### Conditional Skip on Device Status The PDP-9 order code has in its IOT family a group of instructions for testing the status of peripherals. An instruction of this type directs the processor to either skip or proceed to the next instruction as a result of the test. The feature can be thought of as programmed decision making. For example, a program accepting typed input from the console teleprinter might make use of the following sequence in a "teleprinter" service subroutine. ``` : KSF /SKIP NEXT IF CHARACTER IN BUFFER JMP .-1 /RECHECK KEYBOARD BUFFER KRB /READ BUFFER INTO AC : ``` Although simple to implement, I/O servicing of this form adds to a program's "overhead" as the subroutine remains in the two-instruction loop until the skipping condition is satisfied. ### Input/Output Read Status The input/output read status facility provides for programmed interrogation of external device status. Upon execution of an IORS (input/output read status) instruction, the states of those device flags (done, busy, not ready, etc.) interfaced to the facility by the I/O bus are transferred to specific assigned bit positions of the AC. The program may check for specific flag conditions or the user may view the flag states as selectively displayed in indicators on the control console. For bit assignments, see Figure 9-1. ### Program Interrupt The program interrupt (PI) facility offers a more efficient method of I/O servicing. The computer continues with execution of a program until a previously selected peripheral signals that it is ready. At that time, the program in process interrupts and transfers control to a service subroutine. When completed, the subroutine restores the computer to the status prior to the interrupt, allowing the interrupted program segment to continue. Where multiple peripherals are connected to the PI, a search routine with device status testing (skipping) instructions must be added to determine which device initiated the interrupt request. This routine transfers control to the appropriate I/O service subroutine. The PI is itself considered an I/O device in that a program or subroutine thereof can include instructions for enabling or disabling the facility. When disabled, the PI ignores all services requests. Such requests normally remain on-line, however, and are answered when the PI is again enabled. The PI is automatically disabled when an interrupt request is honored. The interrupt-accessed subroutine is responsible for reactivating the facility. ### Data Channels The four data channels included in the basic PDP-9 I/O facilities employ the I/O bus system for block data transfers between core memory and high data rate peripherals such as DECtape and standard magnetic tape transports. The data channel control can concurrently service up to four devices, and can be expanded to service up to eight devices. The priority of service is established by the hardware interface. Data channel requests for service are answered upon completion of the instruction currently being executed by the computer. An in-process data channel transfer cannot be interrupted by a data channel request of lower priority, but it can be interrupted by a direct memory access channel request for service at completion of the current machine cycle. An interrupted data channel transfer continues with completion of the DMA channel action. On-line data channel requests for service are answered in turn on the basis of their priority relationship. Each data channel functions with processor-granted breaks to interleave its transfers with execution of the program in progress. These transfers occur via the MB and do not disturb the contents of other active registers in the processor (AC, PC, etc.). Data is read into memory in three machine cycles and out of memory in four cycles (the additional cycle allows I/O bus settling and the setting of control gates prior to the strobing of the data word into the device's buffer register). The block transfer is initiated by an IOT (input/output transfer) instruction following initialization of a word count register and a current address register, both held in sequential memory locations for each data channel (30, 31<sub>8</sub> for data channel 0; 32, 33 for 1; 34, 35 for 2; and 36, 37 for 3). The word count register is initialized to minus the number of words to be transferred plus one. The current address register is initialized to the starting address minus one of the sequential block of memory locations which are to deliver data to or receive data from the peripheral device. When the data channel request is granted by the processor, the device transmits the address of its data channel word count register. During the first cycle, the contents of this register are incremented by one and then the effective address of the current address register is established. In the second cycle, the contents of the current address register are incremented by one to establish the effective address of the memory location delivering or receiving the data word. During the third cycle, or fourth cycle in the case of out transfers, the actual data transfer occurs. The device continues to request service until it receives an indication that the block transfer has been completed. At that time, it can initiate a program interrupt to access a subroutine for the re-initialization of the data channel's word count and current address registers. Because the block transfers are automatic in nature, the programmer need only concern himself with providing the appropriate subroutine or subroutines to initialize the data channels as required by the program's use of the data channel connected peripheral. ### Direct Memory Access Channel The direct memory access (DMA) facility bypasses the computer to provide a data path between system core memory and high-speed peripherals (up to three devices can be concurrently serviced by the addition of an optional multiplexer which establishes a priority relationship for the devices). The DMA channel functions on a "cycle stealing" basis; i.e., a device request for service defers execution of the main program or an I/O transfer operation in process for one memory cycle, during which time a word is transferred to or from core memory. Execution resumes upon completion of the transfer cycle. The DMA channel accesses memory through its own entry port to each memory module. DMA-interfaced devices are also interfaced to the I/O bus for programmed initialization of the data transfer parameters. ## Add-to-Memory Capability This capability permits incrementing the contents of an externally specified memory location in one memory cycle, or adding the contents of an external register to the contents of a memory word in four memory cycles. A device on the DCH system can request these actions by signaling on appropriate lines of the I/O bus. These features were originally included in the extra-cost KH09A option. The increment capability (MB+1) is commonly used when data in histogram form is desired (such as pulse height analysis data). After each data point is developed by external hardware, it is placed on the address lines (thereby specifying a memory location) and an Increment MB request is made. An I/O OVFLO pulse is returned to the device if the increment causes the specified word to go to zero. The request for an increment cycle is honored after completion of the current instruction. If successive increments are requested, one instruction of the current program will be executed between each increment break. The add-to-memory capability is used in signal averaging where on successive scans through an independent variable (such as time), the data from the dependent variable (such as voltage) is added into that already collected. Data placed on the data lines is added to the contents of the location specified by the data channel current address counter. A DATA OVFLO pulse is returned to the device if the sum exceeds $2^{18}$ -1. The request for an add-to-memory operation is honored after completion of the current instruction. If successive requests are made, they will be honored back-to-back, every four memory cycles. ### **OPTIONS** Incorporation of the following options expands the data processing capabilities of the basic PDP-9 system, provides increased efficiency for input/output operations, and simplifies the programming and execution of arithmetic operations. ### Extended Arithmetic Element, Type KE09A The extended arithmetic element facilitates high-speed multiplication, division, shifting, normalizing, and register manipulation. Installation of the EAE adds an 18-bit multiplier quotient register (MQ) to the computer as well as a 6-bit step counter register (SC). The contents of the MQ are displayed by the REGISTER indicators on the operator's console when the REGISTER DISPLAY control is in the MQ position. The option and the basic computer cycle operate asynchronously, permitting computations to be performed in the minimum possible time. Further, the EAE instructions are microcoded so that several operations can be performed by one instruction to simplify arithmetic programming. Average multiplication time is 11 µsec; average division time is 12 µsec. The PDP-9 program library offers a complete package of single- and multi-precision routines for use with this option. EAE instructions are described in chapter 7, Instructions. ## Memory Extension Control, Type KG09A The memory extension control allows expansion of PDP-9 core memory from 8,192 to 32,768 words in increments of 8,192 words. The option includes a 2-bit extended program counter, a 2-bit extended memory address register, and an extend mode control. Locations outside the current 8,192-word field are accessed by indirect addressing while in the extend mode. In this mode, bits 3-17 in the effective address of an indirectly addressed instruction specify the memory bank number (bits 3 and 4) and the memory address (bits 5-17). If not in the extend mode, bits 3 and 4 of the effective address are ignored and the bank number is taken from the extended program counter. Instructions for the option are discussed in chapter 6 under Extend Mode Addressing. The state (i.e., on or off) of the mode is automatically saved in the event of a program interrupt, or CAL or JMS instruction (refer to chapter 6 under "reserved addresses", page 6-7). A program interrupt disables the extend mode. The saved state can be automatically restored by the instruction sequence of DBR followed immediately by JMP I, where the address for the latter instruction is 00000, 00020, or Y for, respectively, a program interrupt, CAL, or JMS (Y refers to the address previously specified by the JMS instruction). ### Additional Core Memory Up to three 8,192-word core memory modules, Type MM09A, MM09B, and MM09C respectively, may be added to a PDP-9 for expansion of random-access storage up to 32,768 18-bit words. The memory extension control Type KG09A is required. ### Memory Parity, Type MP09 The option adds a 19th bit to each of the words in a 8,192-word core memory module. These bits retain the parity indication for their associated words. Parity is generated when a word is entered in memory and checked when the word is read out of its memory location. Detection of a parity error can initiate a program interrupt or halt execution of the program, as the programmer selects (refer to chapter 10, Controls and Indicators). Systems with memory parity have a 1.2 µsec memory cycle time. The IOT instructions associated with memory parity are as follows: | Octal Code | Mnemonic | Function | |------------|----------|---------------------------------------| | 702701 | SPE | Skip on parity error | | 702702 | CPE | Clear parity error | | 702704 | | Force wrong parity (maintenance only) | Memory Parity must be built into the basic PDP-9. It is not available as a field-installed option. ### Power Failure Protection, Type KP09A The basic PDP-9 is not affected by power interruptions of less than 10 msec duration. Active registers in the processor (AC, AR, PC, etc.) will lose their contents for interrupts of longer duration but memory is not disturbed. The power failure protection option extends the period of nonaffect by power interruption to 25 msec. In addition, the option provides for the saving of active register contents in the event of longer power interrupts and the automatic restart of the system when power is restored. The restart feature is switch-selected by the operator to be enabled or disabled. When enabled, the program in progress resumes execution at location 00000. The system must be operating with the program interrupt facility enabled to sense the option's initiation of a program interrupt to save the register contents at the time of the line power failure. The option adds the following instruction: Octal Code Operation 703201 Skip next instruction if power-low flag is set. ### Memory Protection Option Type KX09A The memory protection feature establishes a foreground/background environment for PDP-9 processing activity by specifying the boundary between protected (lower) and unprotected (upper) regions of system core memory. Allocation of memory locations (in increments of 1024 words) to the protected region is dynamic and program controlled. A Boundary Register, added by the option, stores the location of the upper limit of the protected region. It is loaded from bits 3–7 of the AC by a MPLS instruction. The KX09A monitors the instruction about to be executed, and transfers control to a monitor program (should the instruction be in the category of "illegal instructions") before the instruction is executed. If a program tries to reference a nonexistent memory bank, the KX09A, if it has been enabled, transfers control to the monitor program. The memory protect (or user mode) may be enabled either by programmed instruction, or by placing the PRTCT switch on the console UP, and pressing the START key. When enabled, the option will trap the following: IOT Input/Output CAF Clear All Flags XCT of XCT Chained Execute Instructions HLT Halt OAS/LAS Load AC From Data Switches References to nonexistent memory References to locations below the boundary limit Trapping causes the execution of an effective JMS instruction after the machine cycle that attempts to violate. The address referenced by the effective JMS instruction will be location absolute 20 if the program interrupt facility is disabled, or location absolute 0 if the program interrupt facility is enabled. The Violation Flag is set. The NonExistent Memory Flag is also set if the violation was caused by a program or DCH reference to nonexistent memory. A DMA reference to nonexistent memory is not detected by the KX09A. User mode is disabled in the following ways: I/O Reset Key The detection of a violation CAL Instruction (which never causes a violation) A Program Interrupt An API Interrupt If user mode is enabled when an API break starts, and the API Channel Address contains a HLT, OAS, or IOT – rather than the normal JMS – that instruction will be inhibited, user mode will be disabled in the normal fashion and no violation will be detected. If user mode is disabled when a reference to nonexistent memory is made, the NonExistent Memory Flag is set, no trap occurs, and the program continues after a one microsecond pause. If a reference to non-existent memory occurs when user mode is enabled, the Violation Flag is also set and the trap occurs. HLT, OAS and IOT instructions are totally inhibited when the memory protect option is enabled. If the HLT or OAS is combined with any other operate group instruction (micro-programming), the other parts of the operate group instruction are executed before the trap. (The exception is SKP which is not executed - see Example 2.) The second XCT in a chain of XCT instructions is trapped before execution. The state of the protect mode (a "1" for user mode) is stored in bit 2 — the storage word by those operations that save the state of the machine (CAL, JMS, PI). The stored PC will contain one more than the location of the violating instruction, except for JMP to a protected area. In this case, the stored PC will contain the Protected address. The sole operator control is the PRTCT switch, which has an indicator above it. This indicator lights when in user mode. The PRTCT switch is used in conjunction with the START key to establish the proper mode at the beginning of program execution. If the switch is UP, then the program is started in user mode. The switch has no further effect. The IO RESET key clears the boundary register, Violation and NonExistent Memory Flags, and user mode (i.e., memory protect is turned off). The option adds the following instructions to the PDP-9. | Mnemonic | Octal Code | Function | |----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MPSNE | 701741 | Skip on NonExistent Memory Flag. The NonExistent Memory Flag is set whenever the processor attempts to reference a nonexistent area of core. For a 32K machine, the flag would never get set. | | MPSK | 701701 | Skip on Violation Flag. The Memory Protect Violation Flag will be set whenever the execution of an instruction has violated the provision of memory protection (see above). | | MPEU | 701742 | Enter user (protect) mode. Memory protect mode will be entered at the end of the next instruction that is not an IOT. | | MPCV | 701702 | Clear Violation Flag. | | MPCNE | 701744 | Clear NonExistent Memory Flag. | | MPLD | 701704 | Load the memory protection boundary register with the contents of AC3—7. The boundary register will store the number of 1024 word blocks to be protected. | Associated with the option are the following additional indicators, as shown below, mounted above the marginal check panel. | PRVN: | Lights when Violation flag is raised. | |-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | NEXM: | Lights when Nonexistent Memory flag is raised. | | USMD: | Lights to indicate that the memory protect mode (user mode) has been entered. Logically identical to the light above the PRTCT switch on the console. | | BR 3<br>through<br>BR 7 | Indicate the upper limit (in 1K increments of the protected region.) | ### Examples ### Example 1 | 76 | | |-----|--------------| | 77 | Main Program | | 100 | XCT 200 | | 200 | XCT 247 | | 247 | LAC 250 | Should the main program reach location 100 with the user mode ON, the second XCT at location 200 will violate, and control will transfer to location 20 (assuming program interrupt facility is off). The contents of the PC (101) together with the state of the link, Extend Mode and User Mode will be stored in location 20, and the next instruction taken from location 21. ### Example 2 | 76<br>77 | Main Program | | |----------|--------------|--| | 100 | XCT 200 | | | 200 | HLT SKP | | Here, the HLT will cause the violation, (one XCT is allowed). The SKP will be ignored and the PC will be stored as 101. ### Example 3 | 76 | | |-----|--------------| | 77 | Main Program | | 100 | XCT 200 | | 200 | HLT CLA | Same as Example 2 except the AC will be cleared before the trap occurs. ### Example 4 Assume boundary to be at address 2000, protection is for register 0 through 1777. | 400 | 3000 | |------|-----------| | 3000 | TAD I 400 | This is legal, although address 400 (which is below the boundary) has been referenced, because the final reference is above the boundary. #### Example 5 Boundary again at address 2000 400 1000 3000 TAD I 400 This will be trapped, as address 1000 was the final reference, and address 1000 is below the boundary. ### Automatic Priority Interrupt, Type KF09A The automatic priority interrupt (API) system adds eight additional levels of programming priority to the PDP-9. The upper four levels are assigned to devices and are initiated by flags (interrupt requests) from these attached devices. The lower four levels are assigned to the programming system and are initiated by software requests. The priority network insures that high data rate or critical devices will always interrupt slower device service routines while holding still lower priority interrupt requests off line until they can be serviced. The API identifies the source of the interrupt directly, eliminating the need for a service routine to flag search. The key elements in an interface to the API are priority level and channel. Each I/O device interfaced to the API is assigned to one of the four device priority levels so as to maximize performance of the I/O system. The channel assignment of every device and software request is fixed and cannot be changed. Each of the 32 channels has a corresponding channel address in core memory. This address contains a JMS instruction to the service subroutine. The execution of 1 out of 32 unique JMS instructions is the API's method of directly identifying which source caused the interrupt. The API operates in the following manner. An I/O device requests service by transmitting an interrupt request signal to the processor on a line corresponding to its specific, preassigned priority level. If this priority level is higher than the priority of the device which requested the currently active program segment, an interrupt is granted to the new device. Upon receipt of the grant signal, the device transmits its channel-address back to the processor. The processor executes the instruction in the specified memory address; this is always a JMS to the device service subroutine. The new priority level is remembered and no further servicing of this or lower priority levels is permitted until the device service subroutine is exited. The hardware insures that simultaneous requests by multiple devices are handled in the proper priority sequence. If interrupt requests occur at different priority levels, the highest priority request will be serviced first. If multiple interrupt requests occur at the same priority level, the device closest on the bus to the processor will be serviced first. The entire API system may be enabled or disabled with a single instruction; however, many devices provide facility to separately connect and disconnect their flags from the interrupt. The chief advantage of this API system lies in the proper use of the software levels. In the real-time environment, it is necessary to maintain data input/output flow, but it is not possible to perform long, complex calculations at priority levels which shut out these data transfers. With the API, a high priority data input routine which recognizes the need for the complex calculation can call for it with a software level interrupt. Since the calculation is performed at a lower priority than the data handling, the latter can go on undisturbed. Further, there is no need to interface the data collection routine with the lowest priority (background) program which may run independently of the real-time system. Refer to chapter 9 for descriptions of the API instructions and the programming considerations. # CHAPTER 4 PERIPHERALS This chapter describes both the standard peripherals and the optional peripherals offered with PDP-9. Information regarding the instruction word format and the coding of the IOT (input/output transfer) instructions can be found in chapter 7 under IOT Instructions. ## STANDARD INPUT/OUTPUT EQUIPMENT Standard input/output equipment supplied with each PDP-9 system consists of a Teletype and control, perforated tape reader and control, and a perforated tape punch and control. ### Teletype Model 33 KSR and Control The Teletype Model 33 KSR (keyboard send receive) can be used to type in or print out information at a rate of up to ten characters per second. Signals transferred between the 33 KSR and the keyboard printer control logic are standard serial, 11-unit code Teletype signals. The signals consist of marks and spaces which correspond to idle and bias current in the Teletype and zeros and ones in the control and computer. The start mark and subsequent eight character bits are represented by single units of time duration followed by a two-unit stop space. Each of the 64 printing characters and 32 control characters are represented by an 8-bit standard ASCII code. The Teletype eight-level character code is listed in the appendix 2. As the teleprinter input and output functions are logically separate, the programmer can consider the printer and keyboard as individual devices. The console teletype interface is half duplex. The keyboard and teleprinter device flags are interfaced to the I/O skip facility, the program interrupt control, and to bits 3 and 4, respectively, of the IORS (input/output read status) word. (Refer to chapter 9, I/O Operations, for a discussion on use of the IORS word.) The state of these bits can be seen in the REGISTER indicators when the machine is in the stop condition and the REGISTER DISPLAY control is in the STATUS position. ## Keyboard The keyboard control contains a 8-bit buffer which assembles and holds the code for the last character struck on the keyboard. The keyboard flag becomes a 1 to signify that a character has been assembled and is ready for transfer to the accumulator. This flag may be cleared by command. The keyboard instructions are: | Mnemonic<br>Symbol | Octal<br>Code | Operation Executed | |--------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | KSF | 700301 | Skip if the keyboard flag is set to 1. If the flag is a 0, the next instruction is executed. If it is 1, the next instruction is skipped. The flag is set only when a character has been completely assembled by the buffer. | | KRB | 700312 | Read the keyboard buffer. The content of the buffer is placed in bits 10–17 of the cleared AC and the keyboard flag is cleared. Bits 0–9 of the AC remain cleared. | ### Teleprinter The teleprinter control contains an 8-bit buffer which receives a character code from AC bits 10 through 17. The buffer receives the 8-bit code from the AC in parallel and transmits it to the teleprinter serially. When the function called for by the 8-bit code has been executed, the teleprinter flag is set to 1. This flag is connected to the computer program interrupt and input/output skip facility. It is cleared by programmed command. The instructions for the teleprinter are: | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TSF | 700401 | Skip the next instruction if the teleprinter flag is set to 1. | | TCF | 700402 | Clear the teleprinter flag. | | TLS | 700406 | Load printer buffer. The content of AC bits 10–17 are placed in the buffer. The flag is cleared before transmission takes place and is set when the character has been printed. | A TLS instruction should not be executed until a TSF instruction verifies that the teleprinter flag is set. The teleprinter requires 110.04 msec to complete the action called for by an entered character code (print a character, line feed, carriage return, etc.). The teleprinter flag is again set at the end of this interval. The time between teleprinter flags is available to the program. NOTE: The keyboard has priority over the teleprinter; i.e., if a key is struck while the teleprinter buffer is transmitting a character code to the Teletype, the character code relating to the struck key will be entered in the keyboard buffer and the keyboard flag will be set to initiate a program interrupt. The disruption of the teleprinter function will garble the character code being sent to the Teletype from the teleprinter buffer. The Teletype action defined by this garbled code is unpredictable. Thus, one character of output data is lost. ### Perforated Tape Reader The perforated tape reader and its associated control are designed and manufactured by the Digital Equipment Corporation. The reader functions with a stepping motor and feed-hole drive to photo-electrically sense 8-channel paper tape at the rate of 300 characters per second. The control requests reader motion, transfers data from the reader to the reader buffer register, and signals the computer when the buffer has assembled data for input to the computer. In order to maintain maximum reader speed (300 cps), a new select IOT must be issued within 1.67 msec. Data may be read from tape in either alphanumeric or binary modes, as determined by IOT select instructions. In the alphanumeric mode (figure 4-1a), each select instruction causes one line of tape, consisting of eight bits, to be read and placed right justified in the 18-bit buffer register. In the binary mode (figure 4-1b), each select instruction causes three lines of tape to be read. Six bits of each tape line read are assembled in the buffer to form one 18-bit computer word. The seventh bit of a tape line is ignored. A line is not read, however, unless the eighth bit is punched. A "reader buffer" instruction transfers the contents of the reader buffer to the computer's accumulator. Reader facilities include a right-hand bin for supply of the tape being read, a left-hand bin for receiving the tape, and a feed-through control to complete passage of the tape into the receiving bin following the readin operation. A snap-action tape retainer on the reader platform allows simple tape loading. Primary power is made available to the reader when the computer POWER control is set to ON. All operations of the reader are under program control. The tape reader device flag is interfaced to the I/O skip facility, the program interrupt control, and to bit 1 of the IORS (input/output read status) word. The tape-reader-no-tape flag\* is interfaced to bit 8 of the IORS word. (Refer to chapter 9, I/O Operations, for a discussion on use of the IORS word.) The state of these status bits can be seen in the REGISTER indicators when the machine is the stop condition and the REGISTER DISPLAY control is in the STATUS position. <sup>\*</sup>Note: all program tapes should be provided with trailers (i.e., sections of feed-hole only punched tape) since the reader may not halt immediately upon detection of a no-tape indication. Reading of a non-trailered tape will result in the entry of invalid data as the reader indexes beyond the end of tape point. A no-tape condition, in addition to setting the tape-reader-no-tape flag, sets the reader flag to initiate a program interrupt. ## a. Tape Format and Reader Buffer Register Bit Assignments in Alphanumeric Mode ## b. Tape Format and Reader Buffer Register Bit Assignments In Binary Mode Figure 4-1 Perforated Tape Formats <sup>\*</sup>Note: In hardware readin mode, channel 7 must be punched in line 3 of last data word or read will not stop (refer to chapter 10 for description of the READ IN key). <u>Tape Reader IOT Instructions</u> - Observe the following sequence for instructions required to effect the transfer from paper tape to the AC. - 1. Select the mode and clear the buffer.\* - 2. Wait for reader flag (indicates that buffer has been loaded). - 3. Transfer buffer contents to the AC. | Mnemonic<br>Symbol | Octal<br>Code | Operation Executed | |--------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RSF | 700101 | Skip the next instruction if reader flag is a 1. | | RCF | 700102 | Read reader buffer. Clear reader flag, then inclusively OR contents of reader buffer into the AC. RB V AC $\rightarrow$ AC | | RRB | 700112 | Read reader buffer. Clear reader flag. Clear AC and then transfer contents of reader buffer to AC. $RB \rightarrow AC$ | | RSA | 700104 | Select reader in alphanumeric mode. One 8-bit character is read and placed in the reader buffer (right justified). The reader flag is cleared before the character is read. When transmission is complete, the flag is set to 1. | | RSB | 700144 | Select reader in binary mode. Three 6-bit characters are read and assembled in the reader buffer. The flag is cleared during assembly and set when character assembly is completed. | ### Tape Reader Use In loading tape for readin, observe the following practices: - 1. Raise the tape retainer and load the tape into the right-hand bin with channel one (figure 4-1) toward the rear. Place several folds of the tape leader in the left-hand bin and position the tape on the platform with the feed holes engaged by teeth of the drive gear. Snap the retainer down. - 2. Momentarily depress the tape feed control. This action corrects any misalignment of the tape with respect to the drive teeth, and it clears the reader out-of-tape flag. - 3. Set the address switches (numbered 3–17 on the console) to the starting address for the readin and depress the I/O Reset key and then the READ IN key to initiate reading of the tape. <sup>\*</sup>Note: A programmed check of tape presence (i.e., not a no-tape condition) may precede this sequence (refer to IORS discussion in chapter 9). ### Perforated Tape Punch The perforated tape punch unit, packaged on the same chassis as the tape reader, consists of a solid-state control and a mechanical punch mechanism. It perforates paper tape at the rate of 50 characters per second. When the punch is selected by an IOT instruction, data in the accumulator is transferred to the punch buffer and then without further instruction punched in the tape. A magazine for unpunched tape and a box for tape chad are located internally. Both are accessible when the reader-punch drawer is pulled forward on its slides. Power for the punch motor is available when the computer POWER control is in the ON position. The motor runs only when the punch has been selected, however. Operation of the punch is by programmed instructions. An out-of-tape switch, on the punch mechanism and through which the unpunched tape passes, closes to inhibit punch operation when approximately one inch of tape is left. The paper tape punch device flag is interfaced to the I/O skip facility, the program interrupt control, and to bit 2 of the IORS (input/output read status) word. The tape-punch-no-tape flag\* is interfaced to bit 9 of the IORS word. (Refer to chapter 9, I/O Operations, for a discussion on use of the IORS word.) The state of these status bits can be seen in the REGISTER indicators when the machine is in the stop condition and the REGISTER DISPLAY control is in the STATUS position. Information is handled by the punch in either alphanumeric or binary modes. In the alphanumeric mode each select instruction causes one line of tape, consisting of eight bits to be punched. Each hole punched in a tape channel corresponds to a binary 1 in the appropriate bit of the punch buffer. A feed hole is punched for each command, even if the buffer contains all zeros. The correlation between tape channels and accumulator bits shown in figure 4-1a applies to the tape punch in alphanumeric mode. In the binary mode each select instruction causes one line of tape, consisting of eight bits, to be punched. Holes are punched in channels 6 through 1 as a function of binary ones in bits 12 through 17 of the accumulator, respectively. Channel 8 is always punched and channel 7 is normally not punched, thereby conforming to standard binary tape information format. <sup>\*</sup>Note: The tape-punch-no-tape condition will not initiate a program interrupt. ### Tape Punch IOT Instructions | Mnemonic<br>Symbol | Octal<br>Code | Operation Executed | |--------------------|---------------|--------------------------------------------------------------------------------------------------------------------------| | PSF | 700201 | Skip the next instruction if the punch flag is set to 1. | | PCF | 700202 | Clear the punch flag. | | PSA | 700204 | Punch a line of tape in alphanumeric mode. The punch flag is immediately cleared and then set when punching is complete. | | PSB | 700244 | Punch a line of tape in binary mode. The punch flag is im-<br>mediately cleared and then set when punching is complete. | NOTE: The following microcoded instruction causes the punching of just a feed hole. PSA + 10 700214 Clear AC and punch a feed hole. ### Use of Paper Tape Punch The paper tape punch is operated by programmed instructions. The functions of the buttons located on the punch enclosure are included here for user convenience. <u>FEED Button</u> - while the button is depressed, the punch produces feed hole only punched tape for tape leader or trailer purposes. Out-of-Tape Button - this button functionally inhibits program use of the punch by simulating the out-of-tape condition for the punch. Since punch I/O routines normally verify that the punch out-of-tape flag is not set before selecting the device, this simulation permits the user to replenish the tape magazine when its contents have been exhausted, splice the new tape to the existing tape (the FEED button can be used to produce whatever length of feed hole tape is necessary), and then deactivate the out-of-tape flag at his convenience. Without this provision, the punch could be program operated the instant that the out-of-tape switch on the punch mechanism opened as the new tape was fed in. ### OPTIONAL PERIPHERALS ### Card Reader and Control Type CR01E This device reads standard 12-row, 80-column punched cards at a nominal rate of 100 cards per minute. The cards are read by columns, beginning with column 1. One select instruction starts the card moving past the read station. Once a card is in motion, all 80 columns are read. A punched hole is interpreted as a one and no hole as a zero. Column information is read in either alphanumeric or binary modes. In the alphanumeric mode holes (bits) in a column are interpreted as a Hollerith character code (see appendix 2). These bits are translated into a 6-bit card reader code for the character which is read by the read data instruction. In the binary mode the 12 bits of each column are accepted directly as a 12 - bit binary number and are transferred into AC bits 6 through 17, where row 9 is represented in AC 17. In alphanumeric mode, each column is encoded as follows: - a. Rows 1-9 four-bit BCD set (low order). - b. Rows 12, 11, 0 are encoded into two high-order bits as follows: The most significant bit is the inclusive OR of row 12-zone and row 11-zone. The second most significant bit is the inclusive OR of row 12-zone and row 0-zone. The resultant code is IBM compatible tape BCD, provided blank column (code 00) and 0 punch (code 20) are interchanged by the program. ### Card Reader Operation Holes in a card column are sensed by mechanical star wheels in the reader. With the power ON/OFF switch in the ON postion and the AUTO/MANUAL switch in the AUTO position, the CR01E reader is under program control. To read cards under program control, it is necessary to have a card positioned at the read station. The REG (register) switch is used to feed the first card from the hopper to the read station after which card input is under program control. The function of controls and indicators on this card reader is described in table 4-1. TABLE 4-1 CARD READER CROIE CONTROLS AND INDICATORS | Control or Indicator | Function | |-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ON/OFF switch | This switch controls the application of primary power to the reader. When the power is applied, the reader is ready to respond to operation of the other keys or computer command signals. | | AUTO/MAN switch | In the manual position this switch mechanically disables the automatic card feed mechanism. In the auto position card reading under program control is enabled. | | REG switch | The register switch on a reader is used to manually feed the first card to the read station. | | SKIP switch | This key is not connected on the CR01E and has no effect on equipment operation. | | CARD RELEASE pushbutton | When pressed, this pushbutton (adjacent to the read station) releases a card currently in the read station. | | READY indicator | This indicator lights when cards are present in the card hopper. | ### Programming Three flags are associated with the CR01E card reader: data ready, card done, and reader not ready. The data ready and card done flags are interfaced to the interrupt facility (normally the program interrupt control). The states of the three flags can be sensed by skip instructions. Data Ready - when a column of data is ready to be transferred to the AC, the data ready flag is set. A read data IOT instruction must be issued within 1.5 msec of the setting of the data ready flag to prevent loss of the data. <u>Card Done</u> - when the end of a card is sensed, the card done flag is set. A new select IOT instruction must be issued within 25 msec if the reader is to operate at maximum speed. This provision may be used in place of column counting, or combined with column counting, to check data loss. Reader Not Ready - the reader not ready flag is set and may be sensed under the following conditions: Power off Card not in read station Hardware failure The reader not ready flag cannot be cleared by program control; manual intervention is required. When the flag is set, the select IOT is ignored. The reader remains ready between consecutive cards; it normally becomes not ready after reading of the last card. The logical program sequence fro reading cards is: - 1. Check reader ready (RCSR). - 2. Select the mode of reading; the select instruction also moves a new card into position at the read station. - 3. Respond to the setting of the data ready flag (or card done flag). This may be done by permitting either flag to interrupt the computer program or by program looping on the status of the flag. - 4. Read the data called for by the select instruction. The data ready flag is cleared as the data is read. - 5. After final card is read, clear the card done flag (RCLD). The CR01E Card Reader does not perform a validity or registration check of column data. A validity check may be programmed, however, to occur in the interval of 1.5 msec between data flag settings as column data are read into the buffer. For example, it is possible to read a column in alphanumeric mode, deposit the column data in memory, and then read the same column in the binary mode for comparison with a table of valid codes residing in memory. TABLE 4-2 CARD READER CROIL IOT INSTRUCTIONS | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|------------------------------------------------------------------------------------------------| | RCSF | 706701 | Skip (the next instruction in sequence) on data ready flag. | | RCSD | 706721 | Skip on card done flag. | | RCSR | 706741 | Skip on reader ready.* | | | 706702 | Clear data flag, and inclusively OR column into AC <sub>12-17</sub> in alphanumeric mode. | | RCRA | 706712 | Clear AC; clear data ready flag and read column into AC <sub>12-17</sub> in alphanumeric mode. | | | 706742 | Clear data ready flag, and inclusively OR column into AC <sub>6-17</sub> in binary mode. | <sup>\*</sup>The skip is enabled if the reader not ready flag is not set. If the reader is not ready (not ready flag is set), neither selection nor skip occurs. TABLE 4-2 CARD READER CR01E IOT INSTRUCTIONS (continued) | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | | |--------------------|---------------|-----------------------------------------------------------------------------------------|--| | RCRB | 706752 | Clear AC; clear data ready flag and read column into AC <sub>6–17</sub> in binary mode. | | | RCSE | 706704 | Select card reader and initiate card motion if reader is ready; clear card done flag. | | | RCLD | 706724 | Clear card done flag. | | Card reader IOT instructions can be microcoded (i.e., combined to form one instruction word). For example: | 706713 | Skip on data ready flag; clear AC and read column in alphanumeric mode. | |--------|------------------------------------------------------------------------------------| | 706753 | Skip on data ready flag; clear AC and read column in binary mode. | | 706725 | Skip on card done flag and clear card done flag. | | 706745 | Skip on reader ready and select reader. | | 706765 | Skip if both card done and reader ready conditions are present, and select reader. | Refer to chapter 7, Instructions, for a discussion of the microcoding capability of PDP-9 IOT instructions. ## Card Reader and Control Type CR02B ### Overall Description The CR02B Card Reader reads 80 column, 12-row punched cards at rates up to 200 cards per minute. A select instruction starts a card moving past the read station. Information is transferred into a 12-bit register, one column at a time, and a column flag is set. Upon sensing the column flag, the computer reads the data register into the AC, under program control. Once a card is selected, all 80 columns must be read. The card may be selected in either of two modes. In the binary mode, information is transferred into the data register directly as 12 rows of information. In the alphanumeric mode, the 12 rows of information are encoded into Hollerith card code and transferred into the data register as a 6-bit code. #### Operation The read sequence is started by the issuance of a select command. Once the command to select a card is given, the card reader reads all columns in sequence. To read a column, the program must respond to a column ready flag and read the data buffer with a read buffer command. The read buffer command must be given within 2.0 msec after the column flag is set or the data will be incorrect. The read buffer command clears the column flag. Once a card is selected, a new select instruction can be used to change the mode from alpha to binary or vice versa. If the change is from binary to alphanumeric or if a select alphanumeric command is given when the card is already selected in alphanumeric, the column data is reread into the data buffer. This reread must occur within 200 usec of the column flag to guarantee accuracy. There are four flags associated with the CR02B Card Reader. These flags are the column flag, card done flag, end-of-file flag, and the not ready flag. The card done and column flags are connected to the program interrupt and may be individually tested by skip instructions. The column flag indicates column data is in the data register ready to read. The column flag is set by data available and is cleared by the read column register command. The card done flag is set when a card is completely read, and is cleared by either of the select commands. The end-of-file (EOF) level is set by the EOF button on the reader or the hopper empty condition and is cleared by the hopper full condition or the EOF button. The EOF button is an on-off, push-push button. The EOF level may be skip tested. It is used to indicate to the program that the last card of the current deck in the reader has been read. The not ready level indicates that the card reader is in the not ready condition. This may be caused by a read check, feed check, or by the start button not having been depressed. The not ready condition may be tested with a skip instruction. TABLE 4-3 CARD READER CRO2B IOT INSTRUCTIONS | Mnemonic<br>Symbol | Octal<br>Code | Operation Executed | |--------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CRSF | 706701 | Skip if column flag is set | | CRSD | 706721 | Skip if card done flag is set | | DRSD | 706741 | Skip if reader is ready | | CREF | 706761 | Skip if EOF flag is set | | | 706702 | Inclusive or buffer to the AC and clear column flag | | CRRB | 706712 | Clear the AC, inclusive or buffer into the AC, clear column flag | | CRSA | 706704 | Select alphanumeric mode. A card is selected and the alphanumeric mode is set. If card is already selected when this command is given, a data reread will occur. | TABLE 4-3 CARD READER CR02B IOT INSTRUCTIONS (continued) | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|--------------------------------------------------------------------| | CRCD | 706724 | Clear card done flag | | CRSB | 706744 | Select binary mode. A card is selected and the binary mode is set. | ### **DATA FORMATS** Binary **ALPHA** (The Hollerith character code is given in the Appendix, page A2-6.) ### Operator Control and Status TABLE 4-4 CONSOLE LIGHTS, BUTTONS, AND SWITCHES | Light | Color | Meaning | |------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NOT READY | white | On whenever the reader is unavailable to the computer. Turned on by STOP button, empty hopper, full stacker, malfunction (read check, feed check, or validity check when the VALIDITY ON switch is activated), or a poweron sequence. Turned off by pressing the START button. | | READ CHECK | red | Turned on by the failure in the read circuitry. Turned off by pressing the RESET button. | | FEED CHECK | red | Turned on when a card fails to reach the read station in the prescribed time. Turned off by pressing RESET. Reader motors stop when this light comes on. | TABLE 4-4 CONSOLE LIGHTS, BUTTONS, AND SWITCHES (continued) | Light | Color | Meaning | |------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | VALIDITY CHECK | red | Turned on when VALIDITY ON switch is activated and an invalid punch combination is read in the alphanumeric mode. Turned off by pressing RESET. | | Button or Switch | | Meaning | | POWER ON | | Turns power on to reader and control logic. Button lights green when power is on. NOT READY light also comes on. | | POWER OFF | | Turns power off to reader. | | START | | Turns off NOT READY light and places reader in the ready condition if the check lights are off. | | STOP | | Turns on the NOT READY light and places the reader in the not ready condition. If the reader is in operation when this button is pressed, the reader stops when the current card runs out to the stacker. | | RESET | | Turns off the three red check lights (READ CHECK, FEED CHECK, and VALIDITY CHECK). Does not place the reader in the ready condition; does not turn off the NOT READY light. | | end of file | | Signals an end-of-file condition to the computer when this button is pressed and the hopper is empty. Has no effect if the hopper is not empty. The button lights white when an end-of-file condition is present. The light is extinguished when cards are placed in the hopper. | | VALIDITY ON | | When this switch is on, validity check errors stop<br>the reader (see VALIDITY CHECK light above).<br>When off, validity check errors do not stop the<br>reader. Alternately pressing the button turns the<br>switch on and off. When on, the button lights<br>yellow. | ## Automatic Line Printer Type 647 The Type 647 Automatic Line Printer prints text in lines of up to 120 characters at a maximum rate of 300 lines per minute for the 647D or 600 lines per minute for the 647E. Printing is performed by solenoid-actuated hammers. The typeface is engraved on the surface of the continuously rotating drum. A 64-character set is provided. Models are available with up to 160 columns and a printing rate of 1000 lines per minute. Information is transferred from computer to printer through a printer interface, which contains a core buffer in which a line to be printed is assembled character by character. Each character is represented by a 6-bit binary code. When a print cycle is initiated, the core buffer is scanned each time a row on the drum comes up to the print station. As the characters are printed, the corresponding core buffer positions are cleared so that at the completion of the print cycle the buffer is clear and ready for the next line. A print cycle is initiated by a command from the program. Depending on the distribution and number of different characters in the line to be printed, a print cycle may take from about 48 to 180 milliseconds, not including vertical spacing of the paper. Vertical movement of the paper is under control of a punched format tape. Eight program-selectable channels determine the amount of vertical spacing by sensing the punches in the tape. Spacing may be performed at the completion of a print cycle. The paper and tape then move until a hole in the tape is sensed. The table below shoes the increments punched on the standard format tape. The user may also create his own formats for which a special punch is available. | AC Bits<br>15-17 | Tape<br><u>Channel</u> | Spacing Increment | |------------------|------------------------|----------------------------| | 0 | 2 | Every line | | 1 | 3 | Every 2nd line | | 2 | 4 | Every 3rd line | | 3 | 5 | Every 6th line | | 4 | 6 | Every 11th line (1/6 page) | | 5 | 7 | Every 22nd line (1/3 page) | | 6 | 8 | Every 33rd line (1/2 page) | | 7 | 1 | Top of next form | Note that spacing is referenced from the top of the form. A space of one line requires 9 milliseconds. Longer skips vary in time, the first taking 9 msec and 2 to 3 msec for every line thereafter. The spacing increments assume a page format of 66 lines. ### Operating Controls and Indicators With the exception of the main power switch and certain test pushbuttons, all of the operating controls are located on two panels. The main panel is at the left on the front of the printer; the auxiliary panel is at the rear on the same side of the machine. The function of line printer controls and indicators is specified in table 4-5. TABLE 4-5 LINE PRINTER CONTROLS AND INDICATORS | Control or Indicator | Function | |----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TRACTOR INDEX | Used for aligning the forms with the format tape when new paper is loaded. This pushbutton works only when the printer is off-line. | | PAPER LOW ALERT | This red indicator lights when the end of the paper is about to pass through the drag devices below the printer yoke. An alarm signal is sent to the computer at the same time. | | NO PAPER | When the end of the paper has passed out of the forms tractors, this indicator lights red, and an alarm signal is sent to the computer. | | YOKE OPEN | When the printer yoke is open, this red indicator lights. An interlock prevents all but the TOP OF FORM and TRACTOR INDEX controls from operating. | | ALARM STATUS | Whenever an alarm signal is generated, this red indicator lights. | | ON, OFF | These pushbuttons control application of primary power to the functioning parts of the printer. The main power switch must be turned on for these switches to function. The rest of the controls operate only after ON has been pressed. | | START | Places the printer on-line; it is then ready to receive information and print it. | | STOP | Takes the printer off-line as soon as the buffer is clear. If<br>there is information in the buffer, the printer remains on-line<br>until after the next clear buffer instruction or the completion<br>of the next print cycle. When the printer goes off-line, an<br>alarm signal is sent to the computer. | | TEST PRINT | This pushbutton is used for maintenance at the printer and is not used in normal operation. | | TOP OF FORM | Moves the paper to the top of the next page. This pushbutton works only when the printer is off-line. | In addition to the above paper low alert, no paper, and yoke open alarms, an alarm can be generated by a failure in any part of the printer; such a failure automatically takes the printer off-line. ### Programming A line to be printed is assembled in the printer buffer character by character from left to right. When the line is complete, a program command initiates the print cycle. When the cycle is finished, the paper may or may not be spaced vertically. Suppressing vertical movement makes underscoring and overbarring possible. When spacing is performed, the printer buffer becomes available approximately 4 milliseconds before the paper comes to a stop. The program may begin assembling the next line during this time. Three loading instructions allow the program to transfer one, two, or three characters at a time from the AC to the printer buffer. If more than one character is transferred, the characters in the most significant bits of the AC are transferred before characters in less significant bits. The buffer loading instructions perform the inclusive OR transfer of the contents of the AC and the current positions of the printer buffer. Thus, the buffer must be clear before a new line is loaded. Clearing is done automatically during the print cycle; an instruction is provided for initializing the interface and clearing the buffer before starting to print. The capacity of the printer buffer is 120 characters. The program must keep track of the number of characters transferred; if more than 120 are sent, the done flag is not set. Two flags are associated with the Type 647: done and error. The done flag is set at completion of an IOT-initiated function. The error flag is set when an alarm signal occurs and can be reset only when the alarm condition is removed. The done flag is connected to the program interrupt control. Both the done flag and the error flag may be sensed by skip instructions. The logical sequence for use of the line printer is as follows: - 1. Check the error flag (LSEF). - 2. Clear the printing buffer (LPCB)\*. - 3. Load the printing buffer (and the spacing buffer, if required)\*. - 4. Print the contents of the printing buffer (since the printing buffer is automatically cleared\*, step 2 may be omitted from the sequence after an initial print cycle has been executed). The instructions listed in table 4-6 are added with the Type 647 Automatic Line Printer. <sup>\*</sup>The program must wait for the done flag setting before issuing a new command to the line printer. TABLE 4-6 LINE PRINTER TYPE 647E | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LSDF | 706501 | Skip if the DONE flag is set. | | LPCB | 706502 | Clear the DONE flag, clear control print buffer, enable DONE interrupt, initiate a clear sequence in the hue printer. Set the DONE flag when the clear sequence is finished. | | *LPDI | 706504 | Disable DONE flag interrupt. | | | 706522 | Clear DONE flag. | | | 706542 | Clear DONE flag. | | | 706562 | Clear DONE flag. | | LPL2 | 706526 | Load printing buffer with two characters; clear DONE flag; the contents of AC 6-11 and AC 12-17 are transferred to the printing buffer as 6-bit bytes in that order. The DONE flag will be set when the load sequence is finished. | | LPPS | 706646 | Print and Space. This instruction accomplishes the combined actions of LPPB and LPLS instructions. The DONE flag is cleared; the contents of AC 15-17 are transferred to the spacing buffer; the contents of the printing buffer are printed; the paper is spaced vertically; the printing and spacing buffers are cleared; the DONE flag is set upon completion. | | *LPEI | 706664 | The DONE flag interrupt is enabled. | | LPLD | 706546 | Load the printing buffer with three characters. The DONE flag is cleared; the contents of AC 0-5, 6-11, and 12-17 are transferred as 6-bit bytes into the printing buffer in that order. The DONE flag is set at the completion of the load sequence. | | LPL1 | 706566 | Load the printing buffer with one character; clear DONE flag; the contents of AC 12-17 are transferred as a 6-bit byte into the printing buffer. The DONE flag is set at the completion of the load sequence. | | LPEF | 706601 | Skip if the ERROR flag is set. | | LPCF | 706602<br>706622<br>706642<br>706662 | Clear DONE flag. Clear DONE flag. Clear DONE flag. Clear DONE flag. | <sup>\*</sup>These instructions have been added to the Line Printer command set to allow enabling and disabling of the interrupt. Since power clear returns the system to the interrupt enabled condition programs generated for the PDP-7 line printer (647B), which does not have these instructions, will run correctly. TABLE 4-6 LINE PRINTER TYPE 647E (continued) | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LPPB | 706606 | Select printer and initiate printing. The DONE flag is cleared; the contents of the printing buffer are printed; the printing buffer is cleared; the DONE flag is set when the printing sequence is completed. | | LPLS | 706626 | Load spacing buffer and space; the DONE flag is cleared; the contents of AC 15-17 are transferred into the spacing buffer; the paper is spaced vertically according to the format selected; the spacing buffer is cleared; the DONE flag is set. | ### Incremental Plotter and Control Type 350 A California Computer Products Digital Incremental Recorder can be operated with a DEC Type 350 Increment Plotter Control. Characteristics of the available models are: | CCP<br>Model | Step<br>Size<br>(inches) | Speed<br>(steps/minute) | Paper<br>Width<br>(inches) | |--------------|--------------------------|-------------------------|----------------------------| | 563 | 0.01 or | 12,000 or | 31 | | | 0.005 | 18,000 | | | 565 | 0.01 or | 18,000 | 12 | | | 0.005 | <u>.</u> | | The principles of operation are the same for each of the models. Bidirectional rotary step motors are employed for both the X and Y axes. Recording is produced by movement of a pen relative to the surface of the graph paper, with each instruction causing an incremental step. X-axis deflection is produced by motion of the drum; Y-axis deflection, by motion of the pen carriage. Instructions are used to raise and lower the pen from the surface of the paper. Each incremental step can be in any one of eight directions through appropriate combinations of the X and Y axis instructions. All recording (discrete points, continuous curves, or symbols) is accomplished by the incremental stepping action of the paper drum and pen carriage. Front panel controls permit single-step or continuous-step manual operation of the drum and carriage, and manual control of the pen solenoid. The recorder and control are connected to the program interrupt and I/O skip facilities. The instructions for this equipment are listed in table 4-7. TABLE 4-7 INCREMENTAL PLOTTER AND CONTROL INSTRUCTIONS | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|-----------------------------------------------| | PLSF | 702401 | Skip if plotter flag is a 1. | | PLCF | 702402 | Clear plotter flag. | | PLPU | 702404 | Plotter pen up. Raise pen off of paper. | | PLPR | 702421 | Plotter pen right. | | PLDU | 702422 | Plotter drum (paper) upward. | | PLDD | 702424 | Plotter drum (paper) downward. | | PLPL | 702441 | Plotter pen left. | | PLUD | 702442 | Plotter drum (paper) upward. (same as 702422) | | PLPD | 702444 | Plotter pen down. Lower pen on to paper. | Program sequence must assume that the pen location is known at the start of a routine since there is no means of specifying an absolute pen location in an incremental plotter. Pen location can be preset by the manual controls on the recorder. During a subroutine, the computer can track the location of the pen on the paper by counting the instructions that increment position of the pen and the drum. ### Oscilloscope Display Type 34H Type 34H is a two-axis digital-to-analog converter and an intensifying circuit, which provides the deflection and intensify signals needed to plot data on an oscilloscope. Coordinate data is loaded into an X buffer (XB) or a Y buffer (YB) from bits 8 through 17 of the accumulator. The binary data in these buffers is converted to a -10 to 0 volt analog deflection signal. The 30-volt, 10-microsecond intensify signal is connected to the grid of the oscilloscope CRT. Points can be plotted at approximately a 30-kilocycle rate. The IOT instructions for this display are identical to those for the Precision CRT Display Type 30D, described under the following heading, with the exception of the DLB command. The 34H has a 2-bit brightness register (BR), the contents of which specify the degree of brightness for the point being displayed. The following indicates the intensity scale. | BR Contents | Intensity Level | | |-------------|-----------------|--| | 0 | no display | | | 1 | dimmest | | | 2 | average | | | 3 | brightest | | The instruction 700704 loads the BR with the contents of AC bits 16 and 17. ### Precision CRT Display Type 30D The Type 30D displays points on the face of a cathode ray tube. Each point is located by its X- and Y-coordinates in a square array whose origin is in the lower left corner of the CRT screen. The array contains 1024 points on a side and measures 9-1/4 by 9-1/4 inches square. The X- and Y-coordinates each have a 10-bit buffer which is loaded from bits 8-17 of the AC. In addition, there is a 3-bit brightness register (BR) which is loaded from bits 15-17 of the AC. The content of this buffer specifies the brightness of the point being displayed as designated on the following scale. The five brightest intensities are easily visible in a normally lighted room; the dimmest can be seen in a darkened room. | BR Contents | Intensity Level | |-------------|-----------------| | 3 | brightest | | 2 | J | | 1 | | | 0 | average | | 7 | | | 6 | | | 5 | | | 4 | dimmest | The X- and Y-coordinate buffers (XB and YB) are loaded separately. Each may be loaded without intensifying the CRT. The usual procedure is to load one buffer, then load the second buffer and select in one instruction. The Type 30D requires 50 microseconds to display a point. No flag is associated with this operation. The IOT instructions for the Type 30D display are listed in table 4-8. TABLE 4-8 OSCILLOSCOPE AND PRECISION DISPLAY INSTRUCTIONS | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|-------------------------------------------------------------------------------------| | DXL | 700506 | Load the X-coordinate buffer from AC <sub>8-17</sub> . $AC_{8-17} \Rightarrow XB$ . | | DXS | 700546 | Load the X-coordinate buffer and display the point specified by the XB and YB. | | DYL | 700606 | Load the Y-coordinate buffer from AC <sub>8-17</sub> . $AC_{8-17} \Rightarrow YB$ . | TABLE 4-8 OSCILLOSCOPE AND PRECISION DISPLAY INSTRUCTIONS (continued) | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------| | DYS | 700646 | Load the Y-coordinate buffer and display the point specified by the XB and YB. | | DXC | 700502 | Clear the X-coordinate buffer. | | DYC | 700602 | Clear the Y-coordinate buffer. | | DLB | 700706 | Load the brightness register from bits 15-17 of the AC.<br>Note: This instruction clears the display flag associated<br>with the light pen. | | DSF | 700501 | Skip if display (light pen) flag is a 1. | | DCF | 700702 | Clear display (light pen) flag. | ### PRECISION INCREMENTAL DISPLAY TYPE 340C The Type 340C Precision Incremental Display is designed to permit rapid plotting of adjacent points, as in vectors and geometric figures. Adjacent points are plotted at a rate of 1.5 microseconds per point. Point locations are specified on a 9-3/8 inch square raster by any of the 1024 X and 1024 Y coordinate addresses. The origin is at the lower left corner of the raster. Plotting information is taken from sequential locations of core memory. Five word formats are used to display data in one of four modes. The location of the first word of the data is specified by the contents of bits 5–17 of the AC. The five word formats are as follows: <u>Parameter Word</u> Specifies the mode of display of the next word in sequence, the scale and intensity of the display, and status of the light pen. <u>Point Mode Word</u> Specifies an X- or Y-coordinate, light pen status, and the mode of the following word. Used for displaying random (non-sequential) points. Random points are displayed at the slower rate of 35 microseconds per point. Vector Mode Word Specifies the magnitude and direction of the X- and Y-components of a vector. An escape bit determines whether or not the following word will be a parameter word. <u>Vector Continue Mode Word</u> As in the vector mode, this format specifies magnitude and direction of components, but the vector is continued until the edge of the grid is encountered. Increment Mode Word From a currently displayed point, this word specifies the direction in which the next adjacent point is to be displayed. Four increments are specified by a single word. Instructions added to the computer with the Type 340C are designated in table 4-9. TABLE 4-9 PRECISION INCREMENTAL DISPLAY INSTRUCTIONS | Mnemonic<br>Symbol | Octal<br>Code | Operation Executed | |--------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IDLA | 700606 | Load address and select. The content of bits 5-17 of the AC are placed in the display address counter (DAC) and the display is started. | | IDVE | 700501 | Skip on vertical edge violation. If the top or bottom edge of the grid is encountered (except in vector continue mode), the display stops and an interrupt occurs if the PIC is enabled. | | IDHE | 701001 | Skip on horizontal edge violation. If the right or left edge of the grid is encountered (except in vector continue mode), the display stops and an interrupt occurs if the PIC is enabled. | | IDSI | 700601 | Skip on stop interrupt. This flag is connected to the program interrupt. | | IDSP | 700701 | Skip if light pen flag is set. When the photomultiplier light pen senses a displayed point, the pen flag is set. The flag is connected to the program interrupt. | | IDRS | 700504 | Continue display. After a light pen interrupt, this command causes the display to resume at the point indicated by the content of the DAC. | | IDRD | 700614 | Restart display. After a stop code interrupt, this command causes the display to resume at the point indicated by the content of the DAC. | | IDRA | 700512 | Read display address. Transfers the address in the DAC to AC bits 5-17. | | IDRC | 700712 | Read X and Y coordinates. The content of bits 0-8 of the XB is transferred into AC0-8 and the content of bits 0-8 of the YB is transferred into AC9-17. | | IDSC | 701012 | Read address save register (ASR). Transfer contents of ASR into AC bits 5-17. | | IDCF | 700704 | Clear display control. All flags and interrupts are cleared. | A complete programming manual for the 340C display is available as DECUS No. 7-13. Type 342 Character Generator - This device plots standard ASCII code characters on a 35-dot matrix in one of four sizes on the Type 340C Display. Average plotting time is 35 µsec per character. Two 64-character sets are available. <u>Type 343 Monitor Display</u> - This display is used for remote observation of data displayed on the Type 340C Display. ### Photomultiplier Light Pen Type 370 The high-speed light pen is a photosensitive device which senses displayed points on the face of the CRT. The Type 370 uses a fiber optic light pipe and photomultiplier system, which gives the pen a response time approximately five times faster than that of a photodiode. If the pen is held in front of a point displayed on the face of the CRT, it transmits a signal which sets the display flag to 1. The Type 370 is equipped with a mechanical shutter which prevents the sensing of unwanted information while positioning the pen. Variable fields of view are obtained by means of a series of interchangeable tips with fixed apertures. The IOT instructions for the light pen are listed with the display option instruction lists. ## Analog-to-Digital Converter and Multiplexer Type AF01B The General Purpose Multiplexed A/D Converter Type AF01B is used with PDP-9 computer to multiplex up to 64 analog signals and to convert the signals to binary numbers. It replaces the older Type 138E/139E system. ### A/D Converter The A/D converter is a general-purpose successive-approximation type with the following characteristics: Accuracy See table 4-10 (includes all linearity and temperature errors). Conversion Time: See table 4-10. Aperture: Same as Conversion time without AH02 Sample and Hold option. Converter Recovery Time: None. Analog Input: Voltage range 0 to -10v standard. (See table for amplifier or sample and hold options.) Loading $\pm 1 \mu a$ and 125 pf for standard input. The word-length switch selects the following A/D Converter Characteristics: TABLE 4-10 A/D CONVERTER CHARACTERISTICS | <br>Word Length<br>(No. of bits) | Max Switching<br>Point Error* | Conversion Time<br>(µsec) | | |----------------------------------|-------------------------------|---------------------------|--| | 6 | ±1.6% | 9.0 | | | 7 | ±0.8% | 10.4 | | | 8 | ±0.4% | 12.0 | | | 9 | ±0.2% | 13.5 | | | 10 | ±0.1% | 18.0 | | | 11 | ±0.05% | 25.0 | | | 12 | $\pm 0.025\%$ | 35.0 | | <sup>\*</sup> $\pm 1/2$ LSB for quantizing error. Provision is made for using the Type A400 Sample and Hold Amplifier (AH02 option) between the multiplexer output and A/D converter input to reduce the effective aperture to less than 150 nsec. The Type A400 may also be used to scale the signal input to accept $\pm 10v$ , $\pm 5v$ , or 0 to $\pm 10v$ . The Type A200 amplifier (AH03 option) may be substituted for the Type A400 to accomplish the same signal scaling without reducing the effective aperture. Both the AH02 and AH03 options may be used to obtain high input impedance and small aperture. All power is contained in the Type AF01 for the amplifier and/or sample and hold options. Five convenience switches are mounted on the control indicator panel: a power switch to control the AC power to the Type AF01 System, an ADC pushbutton switch to initiate a conversion manually; a CLR pushbutton switch to set the multiplexer address to channel 0 manually; an index pushbutton to increment the multiplexer address manually; and a rotary word-length switch to select the word length, conversion accuracy, and conversion time. The control indicator panel also contains twelve indicators to display the contents of the ADC buffer, six indicators to display the current multiplexer address, and a power off-on indicator. #### Multiplexer Switches The multiplexer can include from 1 to 16 Type A121 Switch Modules. Each module contains four single-pole, high speed, insulated gate FET switches with appropriate gating. The Type A121 Switches are arranged as a 64-channel group of series-switch single-pole switches with a separate continuous ground wire for each signal input. The switched signal input wire and the continuous ground for each channel are run as twisted pairs to the input connectors mounted on the rear panel. The continuous grounds for all channels are terminated at the high quality ground of the AFO1B System. # Specifications (Measured at input connector) | Input signal (max) | ±10v | |-----------------------------------------------|----------| | Input current (max) | 1.0 ma | | "On" offset voltage | 0 | | "On" resistance (max) | 450 ohms | | "Off" leakage (max) | 10 na | | Turn-on delay | 150 nsec | | Turn-off delay | 250 nsec | | Settling time to 1-LSB (source $Z \le 1$ ohm) | ≤ 2 µsec | # Operation The Type AF01B System may be operated in either the random or sequential address modes. In the random address mode, the control routes the analog signal from any selected channel to the A/D converter input. In the sequential address mode, the multiplexer control advances its channel address by one each time an index command is received. After indexing through the maximum number of channels implemented, the address is returned to 0. The multiplexer switch settling time is preset within the control to initiate the conversion process automatically after a channel has been selected in either the random or sequential address mode. Two separate A/D Convert I/O Transfer Commands may also initiate one or more conversions on a currently selected channel. Conversion times listed in the word-length table are increased by 2 µsec when multiplexer channels are switched to allow for settling times of the analog signal at the multiplexer output. (This time is increased by 5 µsec when AHO3 is used.) Each successive conversion on a selected channel requires only the time shown in table 4-10. TABLE 4-11 AFOIB A/D CONVERTER AND MULTIPLEXER IOT INSTRUCTIONS | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADSF | 701301 | Skip if converter flag is set. This flag is connected to the program interrupt. | | ADSC | 701304 | Select and convert. The converter flag is cleared and a conversion of an incoming voltage is initiated. When the conversion is complete, the converter flag is set. | | ADRB | 701312 | Read converter buffer. Places the content of the buffer in<br>the AC, left adjusted. The remaining AC bits are cleared.<br>The converter flag is cleared. | TABLE 4-11 AF01B A/D CONVERTER AND MULTIPLEXER IOT INSTRUCTIONS (continued) | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|--------------------------------------------------------------------------------------------------------------------| | ADSM | 701103 | Select MX channel. The content of AC <sub>12-17</sub> are placed in the MAR. | | ADIM | 701201 | Increment channel address. The content of the MAR is incremented by 1. Channel 0 follows channel 77 <sub>8</sub> . | | ADRM | 701212 | Read MAR into AC <sub>12-17</sub> . | # General Purpose Analog-To-Digital Converter Type 138E The Type 138E is a successive approximation converter that measures a 0 to 10 volt analog input signal and provides a binary output indication of the amplitude of the input signal. Output indication accuracy is a function of the conversion times and is determined by a switch on the front panel. Each of the seven rotary switch positions establishes an output word length, conversion accuracy, and conversion time for operation of the converter. Overall conversion error equals switching point error plus a quantization error of $\pm 1/2$ the digital value of the least significant bit (LSB). Converter characteristics selected for each switch position are specified in table 4–12. TABLE 4-12 GENERAL PURPOSE A-TO-D CONVERTER CHARACTERISTICS | Word Length<br>(In Bits) | Maximum Switching Point Error* | Conversion Time<br>(In µsec) | | |--------------------------|--------------------------------|------------------------------|--| | 6 | ±1.6% | 9.0 | | | 7 | ±0.8% | 10.5 | | | 8 | ±0.4% | 12.0 | | | 9 | ±0.2% | 13.5 | | | 10 | ±0.1% | 17 <b>.</b> 0 | | | 11 | ±0.05% | 25.0 | | | 12 | ±0.025% | 35.0 | | <sup>\*</sup> $\pm 1/2$ LSB for quantizing error. The converter circuits are constructed entirely of FLIP CHIP modules. Both the Type 138E Converter and the Type 139E Multiplex Control (implemented to 24 input channels) circuits can be contained in one standard 64-connector module mounting panel. The instructions for the Type 138E converter are: | Mnemonic<br>Symbol | Octal<br>Code | Operation <u>Executed</u> | |--------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADSF | 701301 | Skip if converter flag is set. This flag is connnected to the program interrupt. | | ADSC | 701304 | Select and convert. The converter flag is cleared and a conversion of an incoming voltage is initiated. When the conversion is complete, the converter flag is set. | | ADRB | 701312 | Read converter buffer. Places the content of the buffer in<br>the AC, left adjusted. The remaining AC bits are cleared.<br>The converter flag is cleared. | # Converter Specifications Monotonicity: Guaranteed for all settings Aperture Time: Same as conversion time Converter Recovery Time: None Analog Input: 0 to -10 volts is standard. Bipolar or specific amplitude range input can be accommodated on special request. If a different voltage range is desired, it is recommended that an amplifier be used at the source, since this will also provide a low driving impedance and reduce the possibilities of noise pickup between the source and the converter. <u>Input Loading</u>: $\pm 1$ microampere and 125 picofarads for the standard 0 to -10 volt input. <u>Digital Output</u>: A signed 6- to 12-bit binary number in 2's complement notation. A 0 volt input yields a digital output number of 4000<sub>8</sub>; a -5 volt input produces 0000<sub>8</sub>; and a -10 volt input gives an output of 3777<sub>8</sub>. Unsigned and 1's complement outputs are available on special order. Binary ones are represented by DEC standard negative logic level signals (-3 volts) and binary zeros are represented by DEC standard ground logic level signals. Controls: Binary readout indicators and a seven position rotary switch for selecting word length and converter accuracy are provided on the front panel. # Multiplexer Control Type 139E The Type 139E is intended for use with the Type 138E system in applications where the PDP-9 must process sampled analog data from multiple sources at high speeds. Under program control the multiplexer can select from 2 to 64 analog input signal channels for connection to the input of an analog-to-digital converter. Channel selection is provided by Type A100 Series Multiplex Switch FLIP CHIP modules. These module types each have slightly different timing, impedance, and power characteristics so that multiplexers can be built for wide differences in application by selecting the appropriate module type. Each module contains two independent, floating, transistor switches letting the user select any multiple of two channels to a maximum of 64. In the individual address mode, the Type 139E routes the analog data from any program-selected channel to the converter input. In the sequential address mode, the multiplexer advances the channel address by one each time it receives an incrementing command, returning to channel zero after scanning the last channel. Sequenced operations can be short-cycled when the number of channels in use is less than the maximum available. A 6-bit multiplexer address register (MAR) specifies a channel number from 0-77<sub>8</sub>. A channel address may be chosen in one of two ways. It can be specified by the content of bits 12-17 of the AC by incrementing the content of the MAR. The following IOT instructions are used: | Mnemonic<br>Symbol | Octal<br><u>Code</u> | Operation Executed | |--------------------|----------------------|--------------------------------------------------------------------------------------------------------------------| | ADSM | 701103 | Select MX channel. The content of $AC_{12-17}$ are placed in the MAR. | | ADIM | 701 201 | Increment channel address. The content of the MAR is incremented by 1. Channel 0 follows channel 77 <sub>8</sub> . | | ADRM | 701212 | Read MAR into AC <sub>12-17</sub> . | # Multiplexer Specifications Indicators: Six binary indicators on the front panel give visual indication of the selected channel. Multiplexer Switching Time: The time required to switch from one channel to any program-specified channel, or to select the next adjacent channel when the content of the MAR is incremented is 2.5 microseconds. This time is measured from when either a select or increment command is received. Multiplex Channel Input: Six signal lines accept DEC standard logic levels of 0 and -3 volts, with 0 volts for assertion. A pulse or level change clears and strobes the channel data lines to load the MAR. The input accepts DEC standard 70-nanosecond or 400-nanosecond positive pulses (referenced to -3 volts). Readin occurs at the positive transition of the pulse and should not occur until 400 nanoseconds after the channel address lines have settled. Increment Channel Input: The increment MAR input accepts standard DEC 70-nanosecond or 400-nanosecond positive pulses (referenced to -3 volts). ## Digital-to-Analog Converter Type AA01A This general purpose digital-to-analog converter converts 12-bit binary computer output numbers to analog voltages. The basic option consists of three channels, each containing a 12-bit digital buffer register and a digital-to-analog converter. Digital input to all three buffer registers is provided in common by one 12-bit input channel which interfaces to the PDP-9 I/O bus. Appropriate precision voltage reference supplies are provided for the converters. One IOT instruction simultaneously selects a channel and transfers a binary number into the selected buffer register. Each converter operates continuously on the contents of its associated buffer register to produce an analog output voltage. The analog output voltage of a standard converter is from ground to -9.9976 volts (other voltage ranges are available). All inputs to the converter are assumed to be 12 bits in length with negative numbers represented in 2s complement notation. An input of $4000_8$ yields an analog output of ground potential; an input of $0000_8$ yields an output of -5 volts; and an input of $1777_8$ yields an output of -10 volts minus the analog value of the least significant bit of the input. Output accuracy is $\pm 0.0125\%$ of full scale; resolution is 0.025% of full scale value. Response time, measured directly at the converter output, is 3 microseconds for a full-scale step change to 1 least significant bit accuracy. Maximum buffer register loading rate is 2 MHz. Type AA01A Converters can be specified in a variety of basic configurations: with from one to three channels, with or without output operational amplifiers, and with internally or externally supplied reference voltages. Converters can be also supplied with two buffer registers per each channel. This provision permits program control to load the outer buffer register of each channel with an appropriate binary number and then effect a simultaneous transfer of these contents into the inner buffer registers for simultaneous conversion to a summed analog voltage. A typical instruction for the AA01A is: | Mnemonic | Octal Code | <u>Function</u> | |----------|------------|---------------------------------------------------------------------------------------------------------------------| | DALI | 705501 | Load digital-to-analog converter 1. The contents of the AC are entered in the digital buffer register of channel 1. | The variety of possible configurations makes it necessary that the user, or interface designer, define the appropriate instructions and append them to the symbol table of the Symbolic Assembler of the BASIC Software system. # Multi-station Teletype Control Type LT09A Addition of the LT09A option to the PDP-9 expands the machine's Teletype facility to accommodate several Teletype units (KSRs and ASRs may be used interchangeably). Operation of the LT09A facility is in full-duplex mode. Each Teletype line added contains logical elements which are functionally identical to those of the control for the standard unit. Instructions and programming considerations are, therefore, similar to those of the standard unit. The following device selection codes have been assigned for four lines of LT09A equipment. | Line | <u>Teleprinter</u> | Keyboard | |------|--------------------|----------| | 1 | 40 | 41 | | 2 | 42 | 43 | | 3 | 44 | 45 | | 4 | 46 | 47 | Instruction mnemonics for the Teletype units must be defined by the user and appended to the PDP-9 BASIC Symbolic Assembler. Typically, the mnemonics are derived by suffixing "LT" and the line number to the mnemonics for the standard unit. For example, the instruction KSF (skip on keyboard flag) could be represented by KSFLT2 for an instruction to "skip on keyboard flag of line 2." # Relay Buffer Type DR09A The Type DR09A is a computer output device that allows data in the computer to control external electrical equipment through relays. The relay buffer consists of an 18-bit flip-flop register, an 18-bit relay register, filters to reduce noise due to contact bounce, and a patchboard. Under program control the flip-flop register can be set to correspond to the content of the accumulator and can be cleared. The commands for the relay buffer are as follows: | Mnemonic<br>Symbol | Octal<br>Code | Operation <u>Executed</u> | |--------------------|----------------|------------------------------------------------------------------------------------------------| | ORC | <i>7</i> 02101 | Clear output relay buffer flip-flop register. | | ORS | 702104 | Set output relay buffer flip-flop register to correspond with the contents of the accumulator. | #### Interprocessor Buffers DB99A and DB98A ## Overall Description The DB99A and DB98A are bidirectional interprocessor data buffers which operate through the data channel facilities or with programmed data transfers. The DB99A will buffer two PDP-9s together, and the DB98A will buffer one PDP-9 and one PDP-8. Data may be transferred through the accumulator or data channel, or both simultaneously in full duplex operation. Accumulator word transfer rates as high as 100 kc and data channel rates as high as 110 kc may be achieved. # General Performance There are two basic paths of data flow in the DB99, and DB98. One path is from accumulator to accumulator using programmed data transfers and the other path is memory to memory utilizing the data channel facilities of both machines. A single register at each interface is used for both types of data transfer and the inputs to these registers are multiplexed. <u>Programmed Transfers</u> - Programmed transfers of data occur between the accumulators of the computers involved. This mode of data transfer is used primarily for transmission of control parameters while the data channel system is simultaneously handling a full duplex (bidirectional) data transfer; however, the programmed data transfer system can also be used as the primary data transmission method. The supervisory overhead of operating this system will be significantly higher, however, and the transfer rates will be slightly lower. Data Channel Transfers - Data channel transfers can occur between computers in simultaneous full duplex fashion. The standard channel facilities are utilized (three cycle Data Break on the PDP-8; DCH on the PDP-9). The access of data to be transmitted and the storage of data received is supervised by the hardware. Each interface has two data channels, one for data transmission and one for data reception. Each data channel is assigned two memory locations to contain the word count and address registers for the channel. The transmit channel is assigned locations 22 and 23 and the receive channel is assigned locations 24 and 25. # PDP-9 IOT Instructions for DB99A | Octal | Mnemonic | Operation | |--------|----------|-----------------------------------------------------| | 702201 | PBNF | Skip if no interrupting flag of this device is set. | | 702202 | - | Inclusive or command status register into the AC. | PDP-9 IOT Instructions for DB99A (cont) | Octal | Mnemonic | Operation | |-----------------|----------|--------------------------------------------------------------------------------------------------------------------------------| | 702212 | PBRS | Read command status register into the AC. | | 702204 | PBXS | Exclusive or the contents of the AC into the command status register. | | 702221 | PBNB | Skip if data register not busy. | | 702222 | - | Clear data register if data register not busy. | | 702224 | - | Or the AC to data register if data register not busy and set, the transmit flag and not busy level and clear the receive flag. | | 702241 | PBTF | Skip if transmit flag is set. | | 702242 | | Inclusive or data register into the AC, set receive flag and clear transmit flag if the transmit flag is set. | | 70 <b>22</b> 52 | PBRD | Read data register into the AC, set receive flag and clear transmit flag if the transmit flag is set. | # Useful PDP-9 Microinstructions | Octal | Mnemonic | Operation | |--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------| | 702227 | PBTL | Skip and load data register from the AC, and set transmit flag, and receive flag, if all data register not busy. | | 702253 | PBRL | Skip if transmit flag is set and read data register into the AC and set receive flag and clear transmit flag, all if transmit flag is set. | | 702226 | PBLD | Clear and load data register from the AC if the not busy level is set. | # PDP-8 IOT Instructions for DB98A | Octal | Mnemonic | Operation | |-------|----------|----------------------------------------------------------------------------------------------------------| | 6601 | PBNF | Skip if no interrupting flag of this device is set. | | 6602 | PBRS | Or command status register into the AC. | | *6604 | PBXS | Exclusive or the contents of the AC (into the command status register). | | 6611 | PBNB | Skip if data register not busy. | | 6612 | PBTF | Skip if transmit flag is set. | | 6615 | PBLD | Load data register from the AC set transmit flag, and clear receive flag. All if data register not busy. | | 6616 | PBRD | Skip if transmit flag is set, read data register into the AC set receive flag and clear transmit flag. | <sup>\*</sup>If the AC=0 when this command is given the not busy flag will be set to the not busy condition, the CS register will be unchanged. Bit Correspondence - The bit correspondence for data words in the DB98A is given below: | PDP-9 Bit | 0 1 2 | 3 4 5 | 6 7 8 | 9 10 11 | 12 13 14 | 15 16 17 | |-----------|-------|-------|-------|---------|----------|----------| | PDP-8 Bit | | | 0 1 2 | 3 4 5 | 6 7 8 | 9 10 11 | # Command-Status Register Configuration | PDP-8 | PDP-9 | | |--------------------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BIT | BIT | MEANING | | 11 | 17 | Transmit flag | | 10 | 16 | Receive flag | | 9 | 15 | Transmit word count overflow flag | | 8 | 14 | Receive word count overflow flag | | 7 | 13 | Enable not busy flag interrupt | | 6 | 12 | Enable transmit and receive flag interrupts | | 5 | 11 | Enable data channel overflow interrupts | | 4 | 10 | Enable receive data channel | | 3 | 9 | Select transmit data channel | | Not in<br>PDP-8 CS<br>register | 8 | Not busy flag. This flag may be manipulated by the XOR to CS instruction, but it may not be read into the AC. Power clear returns this flag to the one (not busy) state. | | 2 | Not in PDP-9<br>CS register | Address extension bit 3 | | 1 | Not in PDP-9<br>CS register | Address extension bit 2 | | 0 | Not in PDP-9<br>CS register | Address extension bit 1 | In the PDP-8 an XOR to CS instruction with the AC set to 0 will cause the not busy flag to be set to the not busy state. The CS register will remain unchanged. Power clear also sets the not busy state. # PDP-9/PDP-7 Interprocessor Buffer Type DB97A Controls and buffers the flow of information between one PDP-9 and one PDP-7, using the program controlled transfer facility of each processor. # Data Communication System Type DP09A (DP01B) # General The Bit Synchronous Data Communication System Type DP09A provides interface facilities between a PDP-9 and a bit serial communication device such as a Type 201 or 301 Data Set (Bell System). Characters are transferred between the PDP-9 accumulator and the DP09A under program control. The DP09A serializes the characters for transmission, and assembles the serial stream into characters for reception. Operation is full duplex. Both the receive and transmit sections are double-buffered to permit one full character transmission time for loading or reading the DP09A. A character may be 6, 7, 8, or 9-bits long. Character length is determined by a series of jumpers on a 50-pin cannon connector; an appropriate connector for each character length is provided. # Idle/Active The DP09A is in the idle state until made active either by the PDP-9 transmitting a sync character to the DP09A or the DP09A receiving a sync character from the Data Set. The sync characters are: | Character Length (N) | | Sync C | haracter | |----------------------|---------|--------|----------------------------------------------| | 6 | 010 | 110 | | | 7 | 0 010 | 110 | | | 8 | 10 010 | 110 | | | 9 | X10 010 | 110 | (X not used in sync character determination) | The DP09A will return to the inactive (idle) state if - - 1. While transmitting, idle mode is disabled and no character has been transferred to the DP09A from the computer within Nt µsec of the Transmit flag being set. (N is the number of bits/character, t is the time to transmit a bit on the line. Nt is therefore the time to transmit a full character on the communication line.) - 2. While receiving, the clear receive active (CRA) command is issued, or if no character is received from the communication line for 1.5 bit times. Idle mode is a feature of the DP09A which permits retaining the communication system in an active (and synchronous) state when no new characters are available. When idle mode is enabled, the last character continues to be transmitted until such time that a new character is ready. The Transmit flag continues to be raised at the end of each character transmission. Idle mode is enabled by the SIM instruction and disabled by the CIM instruction. # Flags The DP09A communicates with the computer through a series of flags. Any one of the flags can cause a program interrupt or API break (if present) to location 62 at priority level 2. Transmit Flag: Set when the DP09A is ready to receive a character from the computer for transmission. Tested by STF instruction, skip of flag NOT set. Cleared by CTF instruction. Receive Flag: Set when the DP09A is ready to transfer a character to the computer Tested by SRF instruction, skip if flag NOT set. Cleared by RRB instruction. Receive End Flag: Set when no bit is received from sending device within 1.5t (t is the normal inter-bit spacing, the reciprocal of the baud rate). Tested by SEF instruction, skip if flag NOT set. Cleared by CEF instruction. Ring Flag: Set when a remote communications device calls up the DP09A and is ready to transmit. Only causes an interrupt if Ring Enable is set (see instruction list). Tested by SRI instruction, skip if flag NOT set. Cleared by CRF instruction. The following flag cannot cause an interrupt: Data Set Ready Flag: Set when the local Data Set is ready for operation. Tested by SSR instructions, skip if flag IS set. Cleared only when Data Set becomes unavailable. # IOT Commands Following are the IOT Commands for the Bit Synchronous Data Communication System Type DP09A. If bit 14 of any of these commands is a 1, the AC will be cleared at event time 1 of the IOT. | STF | 704501 | Skip on Transmit Flag This command causes the program flow to skip the next instruction if | |-----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | the transmit flag is NOT set. | | TAC | 704201 | Transmit a Character This command transfers the contents of the accumulator (6, 7, 8, or 9-bits right justified) into the transmit character buffer. If the transmit logic is not active, the character will only be transmitted if it is a sync character. | | CTF | 704202 | Clear Transmit Flag This command clears the transmit flag. It also causes the program flow to skip the next instruction if the transmit interface is active. Thus, the micro-programmed instruction TAC CTF (704203) loads the next character, clears the transmit flag, and tests the DP09A to be sure that transmit is still active. | | CIM | 704204 | Clear Idle Mode This command disables the idle mode. | | SIM | 704504 | Set Idle Mode This command enables the idle mode. | | SRF | 704501 | Skip on Receive Flag This command causes the program flow to skip the next instruction if the Receive flag is NOT set. | | RRB | 704502 | Read Receive Buffer This command causes the contents of the receive buffer (6, 7, 8, or 9-bits right end justified) to be read into the accumulator. It also clears the Receive flag. | | SEF | 704601 | Skip on Receive End Flag This command causes the program flow to skip the next instruction if the "Receive End Flag" is NOT set. | | CEF | 704602 | Clear End Flag | |-----|--------|----------------------------------------------------------------------| | | | This command clears the Receive End flag. | | SRE | 704604 | Set Ring Enable | | | | This command causes the Ring Enable gate to be turned on. When | | | | the Ring Enable gate is turned on, the Ring flag can cause a program | | | | interrupt. | | CRE | 705004 | Clear Ring Enable | | | | This command causes the Ring Enable gate to be turned off. | | SRI | 704701 | Skip on Ring Indicator | | | | This command causes the program flow to skip the next instruction | | | | if the Ring flag is NOT set. | | CRF | 704702 | Clear Ring Flag | | | | This command clears the Ring flag. | | STR | 704704 | Set Terminal Ready | | | | This command causes the Terminal Ready gate to be turned on. This | | | | gate indicates to the communication media that the equipment is | | | | ready to receive data from the serial line. | | CTR | 705002 | Clear Terminal Ready | | | | This command turns the Terminal Ready gate off. | | SSR | 705001 | Skip on Data Set Ready | | | | This command causes the program flow to skip the next instruction | | | | if the communication facility is in a ready condition. | | CRA | 705402 | Clear Receive Active | | | | This command takes the interface (637) out of the receive active | | | | state. No further characters will be received until a sync character | | | | is detected. | # CHAPTER 5 AUXILIARY STORAGE SYSTEMS PDP-9 presently includes in its line of standard peripherals the following auxiliary storage systems: DECtape systems, industry standard magnetic tape systems, and a serial magnetic drum system. #### **DECTAPE SYSTEM** The DECtape system, a standard option for the PDP-9, serves as a magnetic tape data storage facility. The system, consisting of TU55 DECtape transports and TC02 DECtape controls, stores information at fixed positions on magnetic tape as in magnetic disc or drum storage devices, rather than at unknown or variable positions as is the case in conventional magnetic tape systems. This feature allows replacement of blocks of data on tape in a ordered fashion without disturbing other previously recorded information. In particular, during the writing of information on tape, the system reads format (mark) and timing information from the tape and uses this information to determine the exact position at which to record the information to be written. Similarly, in reading, the same mark and timing information is used to locate data to be played back from the tape. This system has a number of features to improve its reliability and make it exceptionally useful for program updating and program editing applications. These features are: phase or polarity sensed recording on redundant tracks, bidirectional reading and writing, and a simple mechanical mechanism utilizing aerodynamically lubricated tape guiding (the tape floats on air and does not touch any metal surfaces). # **DECtape** Format DECtape utilizes a 10-track read/write head. Tracks are arranged in five nonadjacent redundant channels: a timing channel, a mark channel, and three information channels (figure 5-1). Redundant recording of each character bit on nonadjacent tracks materially reduces bit drop out and minimizes the effect of skew. Series connection of corresponding track heads within a channel and the use of Manchester phase recording techniques, rather than amplitude sensing techniques, virtually eliminate dropouts. The timing and mark channels control the timing of operations within the control unit and establish the format of data contained on the information channels. The timing and mark channels are recorded prior to all normal data reading and writing on the information channels. The timing of operations performed by the tape drive and some control functions are determined by the information on the timing Track Allocation Showing Redundantly Paired Tracks Basic Six Line Tape Unit Control and Data Word Assignments Figure 5-1 DECtape Format DECtape Mark Track Format Figure 5–1 DECtape Format (continued) channel. Therefore, wide variations in the speed of tape motion do not affect system performance. Information read from the mark channel is used during reading and writing data, to indicate the beginning and end of data blocks and to determine the functions performed by the system in each control mode. During normal data reading, the control assembles 18-bit computer length words from six successive lines read from the information channels of the tape. During normal data writing, the control disassembles 18-bit words and distributes the bits so they are recorded on six successive lines on the information channels. A mark channel error check circuit assures that one of the permissible marks is read in every six lines on the tape. A tape contains a series of data blocks that can be of any length which is an even number of 18-bit words. Block length is determined by information on the mark channel. Usually a uniform block length (256<sub>10</sub> for the PDP-9) is established over the entire length of a reel of tape by a program which writes mark and timing information at specific locations. The ability to write variable-length blocks is useful for certain data formats. For example, small blocks containing index or tag information can be alternated with large blocks of data. The maximum number of blocks addressable is 4096. Between the blocks of data are areas called interblock zones, consisting of control words. These words are used for cueing the TC02 control, and for block by block parity checking. Block numbers normally occur on tape in sequence from 0 to N-1, where N is the number of blocks. The total length of tape is equivalent to 884,736 data lines per tape which can be divided into any number of blocks up to 4096 by prerecording of the mark track. However, 576<sub>10</sub> blocks of 256<sub>10</sub> words are considered to be standard format for a PDP-9 DECtape. ## DECtape Transport Type TU55 The TU55 is a bidirectional magnetic-tape transport consisting of a read/write head for recording and playback of information on five channels of the tape. Connections from the read/write head are made directly to the TC02 control which contains the read and write amplifiers. The logic circuits of the TU55 control tape movement in either direction over the read/write head. Tape drive motor control is exercised completely through the use of solid state switching circuits to provide fast reliable operation. These switching circuits containsilicon controlled rectifiers which are controlled by normal DEC diode and transistor logic circuits. These circuits control the torque of the two motors which transport the tape across the head according to the established function of the device, i.e., go, stop, forward, or reverse. In normal tape movement, full torque is applied to the forward or leading motor and a reduced torque is applied to the reverse or trailing motor to keep proper tension on the tape. Since tape motion is bidirectional, each motor serves as either the leading or trailing drive for the tape, depending upon the forward or reverse control status of the TU55. A positive stop is achieved by an electromagnetic brake mounted on each motor shaft. When a stop command is given, the trailing motor brake latches to stop tape motion. Enough torque is then applied to the leading motor to take up slack in the tape. Tape movement can be controlled by commands originating in the computer and applied to the TU55 through the TC02 DECtape Control, or can be controlled by commands generated by manual operation of rocker switches on the front panel of the transport. Manual control is used to mount new reels of tape on the transport, or as a quick maintenance check for proper operation of the control logic in moving the tape. # **DECtape Control Type TC02** A maximum of eight TU55 DECtape transports may be connected to one TC02. Of the four data channels available, DECtape is assigned to channel 0 (i.e., core memory locations 30 and 31). C(30) = Word Count (in 2s complement form) - WC C(31) = Current Address Register - CA Data transfers may take place to or from only one transport at any given time at a rate of one word every 200 µsec (1 block of 256<sub>10</sub> words every 53 msec), after the desired block has been found (see DECtape summary for complete timing information). Since the CA is incremented before the data transfer (except in search where the CA is not incremented), the initial contents should be set to the desired initial address minus one. The WC is also incremented before each transfer and must be set to the 2s complement of the desired number of data transfer. In this way, the word transfer which causes the word count overflow is the last transfer to take place. The number of IOTs required for the TC02 is minimized by the scheme of transferring all necessary DECtape control data (i.e., unit, function, mode, direction, etc.) from the AC to the control using one set of IOTs (refer to table 5-1). Similarly all status information (i.e., all above information plus status bits, error flags, etc.) can be read into the AC from the control unit via a second set of IOTs. A 6-bit parity check character is computed (the XOR of the reverse parity check character and every 6 bits of every data word) and recorded by the DECtape control for every block of data recorded during the WRITE DATA function. It is used for automatic parity checking during the READ DATA function. TABLE 5-1 TC02 CONTROL IOT INSTRUCTIONS | Mnemonic | Octal Code | Description | |----------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DTCA | 707541 | Clear status register A. The DECtape control and error flags are undisturbed (DTF and EF). | | DTRA | 707552 | Read status register A. The AC is cleared and the content of status register A is ORed into the accumulator. | | DTXA | 707544 | XOR status register A. The exclusive OR of the content of bits 0 through 9 of the accumulator and status A is loaded into status register A, and bits 10 and 11 of the accumulator are sampled to control clearing of the error and DECtape flags, respectively. Any time this command is given with AC bits 0-4 set to 1, the select delay of 120 msec will be incurred. | | DTLA | 707545 | Load status register A. Combines action of DTCA and DTXA to load ACO-9 into status register A. Bits 10 and 11 control clearing of error and DECtape flags, respectively. | | DTEF | 707561 | Skip on error flag. The state of the error flag (EF) is sampled. If it is set to 1 the content of the PC is incremented by one to skip the next sequential instruction. | | DTRB | 707572 | Read status B. The AC is cleared and the content of status B is ORed into the accumulator. | | DTDF | 707601 | Skip on DECtape flag. The state of the DECtape flag (DTF) is sampled. If it is set to a 1, the content of the PC is incremented by one to skip the next sequential instruction. | # Command and Status Bit Configuration ## Status Register A (Command Bits) # Status Register B (Flag and Error Status Bits) | Bit | | Assignment | |------|------------------|------------| | 0 | Error Flag | | | 1 | Mark Track Error | | | 2 | End of Tape | | | 3 | Select Error | | | 4 | Parity Error | | | 5 | Timing Error | | | 6-10 | Unused | | | 11 | DECtape Flag | | All 10 command bits (0 to 9) of status register A may be sensed, set or changed via IOTs. Bits 10 and 11 of the AC are not retained by status A, but enable or disable the clearing of the DECtape and ERROR flags. The bits in status register B may be sensed and cleared by IOTs. To issue a DECtape command, the command bits 0-9 of status register A are set as desired by bits 0-9 of the AC with bits 10 and 11 set to 0. Bit 11 of register B is set when a DTF occurs and must be cleared before the next DTF to avoid a timing error. When any error occurs, bit 0 of register B and the corresponding bits 1-5 will be set depending on the error. This bit must be cleared to avoid further interrupts on the same condition. All error flags (i.e., status register B) are cleared by issuing a DTXA instruction with AC bit 10 set to 0. # **DECtape System Programming Information** # Control Functions The seven functions available with the TC02 and their octal numbers as specified by the bits 6-8 of the AC are as follows: | <u>Function</u> | Octal No. | |-------------------------------------------|-----------| | MOVE | 0 | | SEARCH | 1 | | READ DATA | 2 | | READ ALL | 3 | | WRITE DATA | 4 | | WRITE ALL | 5 | | WRITE TIMING and MARK TRACK | 6 | | Unused at present (select error if given) | 7 | All functions take place in either direction and in either normal mode (NM) or continuous mode (CM). NM differs from CM only in the fact that the DECtape flag (DTF) occurs at more frequent intervals in NM. The DTF settings which occur in NM are eliminated in the CM until word count overflow (WC) has occurred. MOVE - The MOVE function simply sets the selected unit in motion (forward/reverse). NM and CM have no meaning and are ignored in this function alone. When the tape enters either end zone\* (i.e., beginning of tape (BOT) and end of tape (EOT)), and the unit in question is selected: - 1. the error flag (EF) is set. - 2. the EOT bit (bit 2 of status register B) is set. - 3. an interrupt occurs\*\* A program check on the forward/reverse motion bit (AC bit 3) of the status register will determine whether EOT or BOT occurred. However, if the unit is deselected, the tape runs off the reel with no <sup>\*</sup>If either end zone is entered during turn around or during stopping of tape, the EOT bit is not set and no interrupt occurs. <sup>\*\*</sup>All references to the occurrence of interrupts assume both: <sup>1.</sup> The program interrupt is on. <sup>2.</sup> The DTF and EF have been enabled to the program interrupt or API (i.e., bit 9 of status register A is set to a 1). If either of these is not true, flags are raised and status bits are set (and may be sensed and/or cleared), but no interrupt occurs. flags raised and no interrupt. In order to stop a selected unit at any time, the GO bit (AC bit 4) must be set to 0.\* Once a unit is deselected, status information pertaining to that unit is no longer accessible unless it was saved by the program prior to deselection. SEARCH - The search function provides the capability of random access of data blocks on DECtape. This function is used to locate the number of the block to or from which data transfer will occur. In normal mode at each block mark until EOT occurs, the DTF is raised and an interrupt occurs. The block number is automatically transferred by the hardware into the memory location specified by the CA. The CA must have been set previously by the program but the contents are not incremented. The WC is incremented at each DTF; the program must clear the DTF bit in the status register and check the block number until the desired one is found. In continuous mode, the WC is set to the 2s complement of the number of blocks to skip. At each block mark, the block number is read into the memory location specified by the CA which is not incremented. The DTF is raised only at the block mark at which the WC overflows. At that time, an interrupt occurs. Continuous mode provides a virtually automatic DECtape search. READ DATA - READ DATA is used to transfer blocks of data into core memory with the transfer controlled by the standard tape format. The standard block length is 256 18-bit words. For this and all following functions, the CA register initially must be set to (the transfer memory location - 1) because the CA register is incremented just before each word transfer. The WC register is also incremented prior to each word transfer so must be set to the 2s complement of the number of words to be transferred prior to the transfer. Data may be transferred in forward or reverse. Any number of words equal to or less than 1 block may be transferred in NM. The DTF is raised and an interrupt occurs at the end of each block. The DTF must be cleared before the beginning of the next block (i.e., 1.7 msec) to avoid an erroneous timing error, (see summary). When partial blocks are transferred data transmission end with WC overflow (i.e., the word which causes the WC overflow is the last one transferred). However, the remainder of the block is read and parity checked before the DTF and interrupt occur. Tape motion continues until the GO bit is reset to 0 by the program. If the GO bit is not reset to a 0 or a new function specified before the end of the next block, a timing error will occur. READ DATA in NM is intended primarily for single, 256-word, block transfers. If any other number of words is to be transferred, it is advantageous to use CM. However, if the programmer chooses to use NM <sup>\*</sup> When setting the GO bit to 0, the forward/reverse motion bit and unit selection bits should not be changed from their current status. The hardware accepts the change in the TC02 (i.e., status A bit 3 changes from its former state) without error indication, but does not pass this change on to the transport. Programming confusion can result. for any other number of words, the program must check for WC overflow at each interrupt since there is no other way to determine when to stop the tape or change to another function. When the WC overflow occurs, it is essential that the function be changed or the GO bit set to 0. Otherwise transfer begins again (the IOT to clear the DTF implicitly specifies the same function again) at the next block (or next word for the ALL functions) since WC = $000000_{8}$ is valid. Any number of words may be transferred in CM. However, the DTF and an interrupt occur only once after a WC overflow and an end of block. The comments concerning tape continuation apply in CM as well as NM. READ ALL - The READ ALL function allows information to be read from an unusually formatted tape essentially reading all data channels recorded on DECtape regardless of the mark track value. During the READ ALL function the DECtape control does not distinguish between different marks recorded on the mark track-except to check for mark track errors (MKTK). In normal mode (NM), the DTF is raised and causes an interrupt at the end of each 18-bit word transfer. Data transfer stops after WC overflow, but tape motion continues until the GO bit is set to 0 or a new function is specified (in both NM and CM). If the DTF is not cleared after each word transfer, a timing error occurs at the end of the next word (i.e., 200 µsec later). For continuous mode, the DTF is raised and causes an interrupt at WC overflow only. If this interrupt is ignored no more data transfers occur but tape motion continues to EOT. WRITE DATA - The write enable switch on the TU55 must be in write enable position for all WRITE functions. All the details of the READ DATA function description apply with the following exceptions. In normal mode, the DTF is set to a 1 at the end of each block. If WCO did not occur in the block just ended and a new function is specified, the next block will be written (provided the DTF has been cleared). If WC overflow did occur in the block just ended and no new function is specified, the tape continues to move but the writers are disabled. In both CM and NM, when partial blocks are written, data transfer from core to DECtape stops at WC overflow. 000000s are written in the remaining data words of the block and the parity check character is computed over the entire block and recorded. In continuous mode, the DTF is set at the end of the block in which WC overflow occurred. Therefore, if no new function is specified, the tape continues to move but the writers are disabled. WRITE ALL - All the details of the READ ALL function description apply. The WRITE ALL function is used to write an unusual format (such as block numbers on DECtape after timing and mark tracks have been recorded). The word which causes WC overflow is the last one written in NM or CM. The tape continues to move but the writers are disabled. NOTE: Change of function must be delayed for 90 $\mu$ sec to insure recording of last word. Alternative method: set WC to 1 greater than desired number of word transfers and change function within 40 $\mu$ sec after WCO. WRITE TIMING and MARK TRACK - This function and only this function may be performed with the selector switch on write timing and mark track (WRTM) on the maintenance control panel. Whereas the timing track is actually hardware recorded during execution of this function, the mark track is generated and recorded by program. The value written in the mark track is determined by bits 0, 3, 6, 9, 12, and 15 of the 18-bit word being written (i.e., the same bits assigned to channel 1). CM may be conveniently used for this function since the hardware WC provides an automatic counter and interrupt at WC overflow only; in NM, the DTF and interrupt occur at every word until WC overflow. In NM, after WC overflow, if the GO bit or DECtape flag are not cleared, a timing error occurs and no more data is recorded. After WC overflow in CM, if the GO bit is not set to 0, zeros are written on down tape. ## Enable the Interrupt Feature The enable-to-the-interrupt feature allows the program to remove DECtape from the program interrupt line (even if the interrupt is ON). This is primarily of value in the automatic priortiy interrupt system. When command bit 9 in the status register is set to a 1, the TC02 is connected to the interrupt system. If this bit is 0, the DTF in the TC02 cannot cause an interrupt even if the interrupt facility in the PDP-9 is ON. Similarly, any of the five error conditions will cause an interrupt if bit 9 is set to 1 in the status register but cannot cause a program interrupt if bit 9 is a 0. Whether this bit is set or not does not influence the setting of status bits 0-5 of the status register B upon receipt of an error flag (EF) or DTF. Similarly, the result of the I/O skip instruction is independent of the condition of this bit. #### Error Conditions Five types of errors can be detected in the use of DECtape: Timing Error Parity Error Select Error End of Tape Mark Track Error For all errors the EF is raised, a bit is set in the status register and an interrupt occurs (if the enable-to-interrupt bit has been set). The DTEF instruction skips on the inclusive OR of those error bits; hence, each status bit must be checked to determine the kind of error. For all but the parity error, the selected transport is stopped and the EF is raised at the time of error detection. No DTF occurs. For a parity error, the GO bit remains 1 (i.e., motion continues) and the EF is raised simultaneously with the DTF in NM. Only 1 interrupt occurs; hence the program must check the EF. A parity error in CM raises the EF at the end of the block in which the parity occurs causing an interrupt (if enabled). If no program action is taken, e.g., stop transport or reverse and re-read, data transfer continues and the DTF is raised and causes an interrupt at WC overflow and end of final block read. <u>Timing Error</u> - A timing error (program malfunction) is a 'data miss' or program failure to clear the DTF status bit. A timing error occurs also if the program switches to READ or WRITE DATA function while the DECtape is currently passing over a data area on tape. <u>Parity Error</u> - A parity error occurs only during the READ DATA function for a hardware computed parity check character (PCC) failure. Select Error\* - A select error will result under any of the following conditions: - 1. Selection of zero or > 1 unit. - 2. Attempt to write on DECtape transport with WRITE ENABLE/WRITE LOCK switch in the WRITE LOCK position. - 3. Attempt to select unit for any function with DECtape transport REMOTE/OFF/LOCAL switch in the OFF or LOCAL (off-line) position. - 4. Attempt to write timing and mark tracks with the DECtape controls switch in any position other than write timing and mark track. - 5. Attempt to perform any function other than write timing and mark tracks with the DECtape control switch in the write timing and mark track position. - 6. Attempt to perform any function other than read all with DECtape control switch in the read mark track position. - 7. Attempt to execute unused function (7). <sup>\*</sup>No-tape or tape-run-off-reel conditions are not detectable. End of Tape - An EOT error occurs when the DECtape enters either end zone with the GO bit = 1 and the forward/reverse direction bit set to continue in the same direction. In NM and CM data transfer stops at the last legitimate block, the EF is raised, the tape transport stops and an error interrupt occurs. Mark Track Error - A mark track error occurs when the DECtape control fails to recognize a legitimate mark on the mark track. The error may occur in all but the move or write timing and mark track functions. In both CM and NM, the EF is raised, the tape transport stops and an interrupt occurs. ## DECtape Programming Examples Illustrated below are a few examples of possible ways to code DECtape functions on the PDP-9. Some are intended to illustrate the obvious capabilities of DECtape. Others demonstrate some of the more obscure features. Assumed as part of the hardware configuration is the API option. The examples are written in PDP-9 Basic Symbolic Assembler language. ## Auto-Search The following combined use of NM and CM provides a virtually automatic DECtape search for a desired block number with a minimum (2) of interrupts. - 1. Search forward in NM to find next block number. - 2. Compute difference between this and the desired block number. - 3. Set WC=2s complement of this difference. - 4. Switch to search in CM. The next interrupt will be at the desired block number. ## /AUTO-SEARCH EXAMPLE BEGIN, LAC (CBLK /CBLK=TEMP STORAGE **DAC 31** /CA - DECTAPE **DZM 30** /INSURE NO WC OVERFLOW LAC (JMP SEARCH DAC SWITCH LAC (321600 SEARCH DECTAPE UNIT 3, IN FORWARD /DIRECTION, NM, GO (1), FLAGS ENABLED **DTLA /LOAD STATUS REGISTER** JMS DECTAP DECTAPE=API CHANNEL 44 Y/ | <b>V</b> / | - | | |------------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------| | DECTAP, | 0 | /INTERRUPT SERVICE ROUTINE | | | DAC ACSAV<br>DTEF | /SKIP: EF | | | SKP<br>JMP DECER<br>DTDF | /SERVICE DECTAPE ERROR TO BE WRITTEN BY USER<br>/SKIP ON DTF - REQUIRED ONLY IF OTHER<br>/DEVICES ON SAME API CHANNEL | | SWITCH, | SKP<br>JMP SEARCH | OR JMP REDE | | | • | | | Z/ | | | | SEARCH, | LAC CBLK<br>AND (007777 | CURRENT BLOCK NUMBER | | | SAD RBLK<br>JMP RBLKS<br>CLC<br>TAD CBLK<br>DAC TEMP | /DESIRED BLOCK NUMBER /SERVICE CORRECT BLOCK /COMPUTE BLOCK NUMBER /DIFFERENCE AND DIRECTION /OF SEARCH | | | CLC<br>TAD RBLK<br>CMA<br>ADD TEMP<br>SMA | /53 MS ARE AVAILABLE TO<br>/SWITCH FROM SEARCH NM<br>/TO SEARCH CM | | | JMP REV DAC 30 LAC (010000* DTXA | /REVERSE DIRECTION /WC=2'S COMP OF DIFFERENCE /CM /XOR STATUS →AC AND /LOAD STATUS REGISTER /NEXT INTERRUPT WILL BE | | | LAC ACSAV | /DESIRED BLOCK NUMBER | | | JMP I DECTAP | /EXIT | | | | | # Read Data (Continuous Mode) Assuming correct block number has been found, the following illustrates a possible way to code a data transfer function in continuous mode. One interrupt will occur at the end of the transfer. This example continues from and relies on the preceding example. # /READ DATA EXAMPLE RBLKS, CLC /LOAD AC WITH -1 TAD ADDR /SET CA=ADDRESS-1 DAC 31 <sup>\*</sup>If the program were to clear and then load status register A, the control would cause the select delay of 120 msec. However, by simply setting the bit to a 1 in the AC for the corresponding status register bit, the change is made but no select delay occurs. ``` CLC /SET WC=2'S COMPLEMENT /OF # OF WORDS TO TRANSFER TAD WDCNT /AND LOAD STATUS REGISTER CMA DAC 30 LAC (003000 /READ DATA, FORWARD, GO, CM, SELRD, /FLAGS ENABLED, UNIT 3 DTXA LAC (JMP REDE RESET INTERRUPT CHAIN DAC SWITCH /JMP LAC ACSAV /DEBREAK DBR JMP I DECTAP /EXIT ADDR, ADDRES Ν WDCNT, ``` # Read Data (Normal Mode) Normal mode provides a convenient tool for double buffering or processing large amounts of data on a block-by-block basis for economic use of core storage. It also allows for transfer of non-contiguous blocks of data into contiguous locations or vice versa. This example also continues from and relies upon the SEARCH example. # /DOUBLE BUFFER EXAMPLE | A/ | CI C | /CONTINUES FROM SEARCH EXAMPLE | |--------------------|-----------------------------------|---------------------------------------------------| | RBLKS, | CLC<br>TAD WDCNT<br>CMA<br>DAC 30 | /WC=2'S COMPLEMENT OF<br>/1# OF WORDS TO TRANSFER | | RESET1,<br>RESET2, | LAC (BUF1<br>DAC ADDR<br>CLC | | | | TAD ADDR<br>DAC 31 | /CA = ADDRESS -1 | | | LAC (013000 | /LOAD STATUS REGISTER: | | | DTXA | /READ DATA, FORWARD, GO, NM | | | LAC (JMP REDE | /FLAGS ENABLED, UNIT 3 | | | DAC SWITCH | RESET INTERRUPT CHAIN JMP | | | • | | | | | | | | LAC ACSAV<br>DBR | | | | JMP I DECTAP | /EXIT | | REDE, | LAC 30 | CHECK WC OVERFLOW | | • | SMA | , | | | JMP STOP | /STOP DECTAPE | | | LAC (BUF2 | /NO OVERFLOW | | | SAD ADDR | RESET ADDR TO | | | JMP RESET1 | /SWITCH BUFFER | | | JMP RESET2 | | STOP, LAC (020000 DTXA /SET GO = 0, CLEAR DTF AND EF /LOAD STATUS REGISTER Bootstrap Loading Technique The data channel facility and the design of CM allow for linked loading of data from DECtape where the first two DECtape data words determine the core location and amount of data which follows. Note that the following technique will work only for a data channel device whose CA and WC registers are in core memory locations. The address into which data is loaded is specified by CA. Thus is the CA points to the WC-1, the first word transferred specifies the number of words to be transferred. After the first data word transfer, the CA points to itself and the second word transferred specifies where the following data is to be loaded. No program interrupts, timing or computation is required to locate the data. Only the TC02 and DCH features are used. Problem: Load x data words beginning at DECtape block 4 of unit 3 into core locations M to M+X-1, assuming tape has been positioned at block 4. **/BOOTSTRAP EXAMPLE** DZM 30 LAC (27 DAC 31 LAC IOTD DTLA • /TO INSURE NO WC OVERFLOW /TO BEGIN LOADING AT REGISTER 30 /CA /IOT DATA /LOAD STATUS REGISTER IOTD, 332400 /READ ON UNIT #3, CM, FORWARD, GO (1) WITH INTERRUPT ENABLED The following represents the format of the data on the tape starting at block 4. WORD 0→ CORE LOC 30 WORD 1→ CORE LOC 31 Where X is an integral multiple of 256. ## Writing and Reading in Opposite Directions As mentioned earlier, it is possible (though non-trivial) to read data from a DECtape in the opposite direction from which the data was written via program manipulation. A re-ordering of both the entire block and individual words is required, however. - a. Block Re-ordering: A block of words $x_1 \rightarrow x_n$ recorded in one direction is loaded into core as $x_n \rightarrow x_1$ when read in the opposite direction. - b. Word Unscrambling: Data read in backwards comes into core memory locations from the TC02 in the following 18-bit format: Bits: T5 T6 T7 T2 T3 T4 9 T0 TT 6 7 8 3 4 5 0 T 2 In bit positions: NOTE: If data is to be re-ordered on the fly, the routine is limited to 140 $\mu$ sec since the word transfer rate = 200 $\mu$ sec (±30%). The probability of such a routine <u>not</u> working is very high if interrupts from other devices are encountered. The following subroutines may be used for re-ordering the block of words and unscrambling each individual word. ``` /SUBROUTINE TO REORDER A DECTAPE BLOCK OF N WORDS WHERE N=EVEN NUMBER /USES SUBROUTINE UNSCR TO UNSCRAMBLE INDIVIDUAL WORDS. ENTRANCE /PARAMETERS: BUFFER LOCATIONS - HIGH AND LOW, HIGH LOC = C(DTHAD) /LOW LOC = C(DTLAD) 23 DECIMAL REGISTERS, 37 µSEC FOR EVERY 2 WORDS OR /24.2 MS FOR REORDERING AND UNSCRAMBLING 256 DECIMAL WORDS. ``` ``` DTORD, DTBEG, LAC I DTLAD /SAVE LOWEST UNSCRAMBLED DAC DTTAM /WORD OF BLOCK LAC I DTHAD /UNSCRAMBLE HIGH WORD JMS UNSCR /UNSCRAMBLE 1 WORD SUBR DAC I DTLAD STORE IN FREE LOW LOC LAC DTTAM /UNSCRAMBLE LOW WORD JMS UNSCR DAC I DTHAD STORE IN FREE HIGH LOC ISZ DTLAD /INCREMENT LOW ADDRESS LAC DTLAD /WHEN DTLAD+1 = DTHAD REORDERING IS COMPLETE SAD DTHAD DTEXIT, JMP I DTORD /EXIT CLC TAD DTHAD /DECREMENT HIGH ADDRESS DAC DTHAD JMP DTBEG /UNSCRAMBLE NEXT SET OF 2 DTLAD, 0 /LOW, HIGH BLOCK ADDRESSES DTHAD, 0 DTTAM, 0 /TEMPORARY STORAGE ``` ``` /UNSCR, 53 DECIMAL REGISTERS, 76 µSEC SUBROUTINE TO UNSCRAMBLE ONE 18-BIT /DECTAPE WORD IN AC. RESULT IN AC UNSCR, RETURN ADDRESS CMA /COMPLEMENT DZM UNT /INITIALIZE INTERMED. RESULT REG RALVCLL RTL DAC UNTI /ARG. TEMPORARY STORAGE AND (007000 /BITS 6,7,8 XOR UNT ASSEMBLE BITS IN DAC UNT /INTERMED. RESULT REGISTER LAC UNT1 RESUME CYCLING RAL DAC UNTI /BITS 15,16,17 AND (000007 XOR UNT DAC UNT LAC UNTI ``` ``` RAL RTL RTL DAC UNTI /BITS 3,4,5 AND (070000 XOR UNT DAC UNT LAC UNTI RAL DAC UNTI /BITS 12,13,14 AND (000070 XOR UNT DAC UNT LAC UNT1 RAL RTL RTL DAC UNTI /BITS 0,1,2 AND (700000 XOR UNT DAC UNT LAC UNTI RAL DAC UNTI /BITS 9,10,11 AND (000700 XOR UNT JMP I UNSCR /EXIT WITH AC = RESULT UNT, /INTERMED. RESULT OF UNSCRAMBLING UNTI, 0 /ARG TEMP. STOR. ``` # Miscellaneous Information Scatter Read/Gather Write - By program manipulation in CM, it is possible to scatter read or gather write on DECtape. A separate programmed WC must be maintained and incremented as the hardware increments its WC. When program WC overflows, the CA may be reset to the beginning of another core area. With a 200 µsec word transfer rate, (±30%) there is ample time to reset the CA. Note that this function is impossible if other interrupts are likely to occur. Modification of Individual Data Words - This technique should not be used. Data Transfer--Upper Bound Protection - The WC controls all data transfers. After WC overflow, no more data transfers take place. Thus, to protect memory when reading a block of unknown length, the WC is set to the 2s complement of the difference between the initial address where data is transferred and the upper bound. Similar action prevents writing beyond a predetermined point on tape when transferring an unknown number of words from core. <u>Special Formats on Tape</u> - The user is cautioned to always specify an even number of words in his special format. If he does not, the control will indicate parity errors where none exists. Programming Note: When a turn-around command is issued (i.e., complement the direction bit while the GO bit remains set to 1), the tape may not be up to speed when the point at which the command was issued is passed (in the new direction). The tape will be up to speed one standard 256 word block length after the turn-around point. Therefore, to find a block in the opposite direction it is sufficient to delay the turn around one block as shown in the following example: NOTES: 1.) CONSIDER HEAD FIXED WITH TAPE MOVING PAST IT 2.) 31-R-R REVERSE BLOCK # (ie RECOGNIZED ONLY IN REV.) 3.) 31-F-F FORWARD BLOCK# (ie RECOGNIZED ONLY IN FWD.) TO FIND BLOCK 32 FORWARD! 1.) SEARCH REVERSE TO BLOCK 30 2.) TURN AROUND AND SEARCH FORWARD FOR BLOCK 32 BLOCK 31 MAY BE FOUND BUT BLOCK 32 IS GUARANTEED TO BE FOUND. With this turn around specification finding blocks next to the end zones requires special handling. Block 0 forward may be found if the tape is backed into the end zone twice before turning around. To prevent this special end zone handling, a new formatting program must be written which provides one block length of inter-block zone marks (no-op marks) so that program can bounce off the end zone and find block 0 (if the tape has the new format on it). The end zone problem is also solved for either format by not using the block next to the end zones (block 0, 1101). When using non-standard format tape (i.e., not $1102_8$ blocks of $400_8$ words) a length of tape equal to one 18 bit, $256_{10}$ ( $400_8$ ) word block must pass the head before the turn around command is issued. This is approximately five inches of tape. However, when calculating the required delay for a non-standard format tape it should be computed in equivalent standard block lengths. Example: Turn around delay calculation for blocks of 9410 words. 256 words/block x 1 block delay = 2.7 block delay required 92 words block # DECtape Summary # DECtape Function Summary | Function | Normal Mode (NM) | Continuous Mode (CM) | |----------------------------------|------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------| | 0. Move | DTF: No Interrupt<br>CA: Ignored<br>WC: Ignored | Same as NM | | 1. Search | DTF: Interrupt at each block mark CA: Not incremented WC: Incremented at each block mark | DTF: Interrupt at block mark where WC overflows CA: Not incremented WC: Incremented at each block mark | | 2. Read Data | DTF: Interrupt at end of each block CA: Incremented at each word transfer WC: Incremented at each word transfer | DTF: Interrupt at WC overflow and end of block CA: Incremented at each word transfer WC: Incremented at each word transfer | | 3. Read All | DTF: Interrupt at each word transfer CA: Incremented at each word transfer WC: Incremented at each word transfer | DTF: Interrupt at WC overflow CA: Incremented at each word transfer WC: Incremented at each word transfer | | 4. Write Data | Same as 2. Read Data | | | 5. Write All | Same as 3. Read All | | | 6. Write Timing<br>& Mark Tracks | Same as 3. Read All | | | 7. Unused* | | | <sup>\*</sup>If used by mistake, the control gives a Select Error (SE). # DECtape Error Summary | Function | Normal Mode (NM) | Continuous Mode (CM) | |-------------------------------|---------------------------------------------------------|---------------------------------------------------------------------| | Move | Select Error<br>EOT | Select Error<br>EOT | | Search | Select Error<br>EOT<br>Timing Error<br>MK TRK Error | Select Error<br>EOT<br>Timing Error<br>MK TRK Error | | Read Data | Select Error EOT Timing Error Parity Error MK TRK Error | Select Error<br>EOT<br>Timing Error<br>Parity Error<br>MK TRK Error | | Read All | Select Error<br>EOT<br>Timing Error<br>MK TRK Error | Select Error<br>EOT<br>Timing Error<br>MK TRK Error | | Write Data | Select Error<br>EOT<br>Timing Error<br>MK TRK Error | Select Error<br>EOT<br>Timing Error<br>MK TRK Error | | Write All | Select Error<br>EOT<br>Timing Error<br>MK TRK Error | Select Error<br>EOT<br>Timing Error<br>MK TRK Error | | Write Timing<br>& Mark Tracks | Select Error<br>Timing Error | Select Error<br>Timing Error | # DECtape Timing Data on Standard Format (Certified) Tape | Operation | Time | |-----------------------------------------------------------------|---------------------------------| | Time to answer data channel request | Up to 66 µsec* | | Word Transfer Rate | 1 18-bit word every 200 µsec* | | Block Transfer Rate | 1 256 word block every 53 msec* | | Start Time | 375 msec (±20%) | | Stop Time | 375 msec (±20%) | | Turn Around Time (see programming note on page 5-20) | 375 msec (±20%) | | Search → Read Data Function change for present block | Up to 400 µsec* | | Search → Write Data Function change for present block | Up to 400 µsec* | | Read → Search Function change for next block number | Up to 1000 µsec* | | Write → Search Function change for next block number | Up to 1000 µsec* | | DTF to beginning of next data block | 1.7 msec* | | DTF Occurrence: Move: NM, CM | Never | | Search: NM<br>Read Data: NM<br>Write Data: NM | Every 53 msec* | | Search: CM | (WC) X53 msec* | | Read Data: CM<br>Write Data: CM | (# blocks) X53 msec* | | Read All: NM<br>Write All: NM<br>Write Timing & Mark Tracks: NM | Every 200 µsec* | | Read All: CM<br>Write All: CM<br>Write Timing & Mark Tracks: CM | (WC) X200 µsec* | <sup>\*(±30%)</sup> ### MAGNETIC TAPE CONTROL, TYPE TC59 The Type TC59 will control the operation of a maximum of eight digital magnetic tape transports manufactured by Digital Equipment Corporation. The Type TU59 interfaces to and uses the PDP-9 data channel (DCH) facility to execute data transfers between system core memory and magnetic tape. Transfers are governed by the in-memory word counter (WC) and current address (CA) register associated with the assigned data channel (memory locations 32 and 338). Since the CA is incremented before each data transfer, its initial contents should be set to the desired initial address minus one. The WC is also incremented before each transfer and must be set to the 2's complement of the desired number of data words to be transferred. In this way the word transfer which causes the word count to overflow (WC becomes zero) is the last transfer to take place. The number of IOT instructions required for the Type TC59 is minimized by transferring all necessary control data (i.e., unit number, function, mode, direction, etc.) from the PDP-9 accumulator (AC) to the control using IOT instructions. (Refer to Table 5-2.) Similarly, all status information (i.e., status bits, error flags, etc.) can be read into the AC from the control unit by IOT instructions. During normal data reading, the control assembles 18-bit length computer words from successive frames read from the information channels of the tape. During normal data writing the control disassembles 18-bit words and distributes the bits so they are recorded on successive frames of the information channels. The control provides for selection of four recording densities: 200, 556, 800, and 800/9-channel. TABLE 5-2 TC59 CONTROL IOT INSTRUCTIONS | Mnemonic | Octal Code | Description | |----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MTSF | 707341 | Skip on error flag or magnetic tape flag. The status of the error flag (EF) and the magnetic tape flag (MTF) are sampled. If either or both are set to 1, the contents of the PC are incremented by one to skip the next sequential instruction. | | MTCR | 707321 | Skip on tape control ready (TCR). If the tape control is ready to receive a command, the contents of the PC are incremented by one to skip the next sequential instruction. | | MTTR | 707301 | Skip on tape transport ready (TTR). The next sequential instruction is skipped if the tape transport is ready. | | MTAF | 707322 | Clear the status and command registers, and the EF and MTF if tape control ready. If tape control not ready, clear MTF and EF flags only. | | | 707302 | Inclusively OR the contents of the command register into bits 0–11 of the AC. | TABLE 5-2 TC59 CONTROL IOT INSTRUCTIONS (continued) | Mnemonic | Octal Code | Description | |----------|------------|---------------------------------------------------------------------------------------------------------------------------| | MTCM | 707324 | Inclusively OR the contents of AC bits 0-5, 9-11 into the command register; jam transfer bits 6, 7, 8 (command function). | | MTLC | 707326 | Load the contents of AC bits 0-11 into the command register. | | | 707342 | Inclusively OR the contents of the status register into bits 0-11 of the AC. | | MTRS | 707352 | Read the contents of the status register into bits 0-11 of the AC. | | MTRC | 707312 | Read the contents of the command register into bits 0-11 of the AC. | | MTGO | 707304 | Set "go" bit to execute command in the command register if command is legal. | Although any number of tapes may be simultaneously rewinding, data transfer may take place to or from only one transport at any given time. In this context, data transfer includes these functions: read or write data, write EOF (end of file), read/compare and space. When any of these functions are in process, the tape control is in the "not ready" condition. A transport is said to be "not ready" when tape is in motion, when transport power is off, or when it is off line. Data transmission may take place in either parity mode, odd-binary or even-BCD. When reading a record in which the number of characters is not a multiple of the number of characters per word, the final characters come into memory left-justified. Ten bits in the magnetic tape status register retain error and tape status information. Some error types are combinations, such as lateral and longitudinal parity errors (parity checks occur after both reading and writing of data), or have a combined meaning, such as illegal command, to allow for the maximal use of the available bits. The magnetic tape status register reflects the state of the currently selected tape unit. Interrupts may occur only for the selected unit. Therefore, other units which may be rewinding, for example, will not interrupt when done. A special feature of this control is the "Write Extended Inter-Record Gap" capability. This occurs on a write operation when Command Register bit 5 is set. The effect is to cause a 3 inch inter-record gap to be produced before the record is written. The bit is automatically cleared when the writing begins. This is very useful for creating a 3 inch gap of blank tape over areas where tape performance is marginal. #### Magnetic Tape Functions For all functions listed below, upon completion of the data operation (after the end-of-record character passes the read head), the MTF (magnetic tape flag) is set, an interrupt occurs (if enabled), and errors are checked. ### No Operation A NO OP command defines no function in the command register. A MTGO instruction with NO OP will cause an illegal command error (set EF). # Space There are two commands for spacing records, space forward and space reverse. The number of records to be spaced (2's complement) is loaded into the WC. CA need not be set. MTF (magnetic tape flag) is set, and an interrupt occurs at WC overflow, EOF (end of file), or EOT (end of tape), whichever occurs first. When issuing a space command, both the density and parity bits must be set to the density and parity in which the records were originally written. Load Point or Beginning of Tape (BOT) detection during a backspace terminates the function with the BOT bit set. If a space reverse command is given when a transport is at BOT, the command is ignored, the illegal command error and BOT bits are set, and an interrupt occurs. #### Read Data Records may be read into memory only in the forward mode. Both CA and WC must be set: CA, to the initial core address minus one; WC, to the 2's complement of the number of words to be read. Both density and parity bits must be set. If WC is set to less than the actual record length, only the desired number of words are transferred into memory. If WC is greater than or equal to the actual record length, the entire record is read into memory. In either case, both parity checks are performed, the MTF is set, and an interrupt occurs when the end-of-record mark passes the read head. If either lateral or longitudinal parity errors or bad tape have been detected, or an incorrect record length error occurs (WC not equal to the number of words in the record), the appropriate status bits are set. An interrupt occurs only when the MTF is set. To continue reading without stopping tape motion, MTAF (clear MTF) and MTGO instructions must be executed. If the MTGO command is not given before the shutdown delay terminates, the transport will stop. #### Write Data Data may be written on magnetic tape in the forward direction only. For the write data function, the CA and WC registers and density and parity bits must be set. Write data is controlled by the WC, such that when the WC overflows, data transfer stops, and the EOR (end of record) character and IRG (interrecord gap) are written. The MTF is set after the EOR has passed the read head. To continue writing, a MTGO command must be issued before the shutdown delay terminates. If any errors occur, the EF will be set when the MTF is set. #### Write EOF The write EOF command transfers a single character (17<sub>8</sub>) record to magnetic tape and follows it with EOR character. CA and WC are ignored for write EOF. The density bits must be set, and the command register parity bit should be set to even (BCD) parity. If it is set to odd parity, the control will automatically change it to even. When the EOF marker is written, the MTF is set and an interrupt occurs. The tape transport stops, and the EOF status bit is set, confirming the writing of EOF. If odd parity is required after a write EOF, it must be specifically requested through the MTLC command. # Read/Compare The read/compare function compares tape data with core memory data. It can be useful for searching and positioning a magnetic tape to a specific record, such as a label or leader, whose content is known in core memory, or to check a record just written. Read/compare occurs in the forward direction only; CA and WC must be set. If there is a comparison failure, incrementing of the CA ceases, and the read/compare error bit is set in the status register. Tape motion continues to the end of the record; the MTF is then set and an interrupt occurs. If there has been a read/compare error, examination of the CA reveals the word that failed to compare. #### Rewind The high-speed rewind command does not require setting of the CA or WC. Density and parity settings are also ignored. The rewind command rewinds the tape to loadpoint (BOT) and stops. Another unit may be selected after the command is issued and the rewind is in process. MTF is set, and an interrupt occurs (if the unit is selected) when the unit is ready to accept a new command. The selected unit's status can be read to determine or verify that rewind is in progress. ### Continued Operation - 1. To continue operating in the same mode, the MTGO instruction is given before tape motion stops. The order of commands required for continued operation is as follows. - a. MTCM, if the command is to be changed. - b. MTAF (will only clear MTF and EF flags since tape control will be in a Not Ready state). - c. MTGO (if LCM requested an illegal condition, the EF will be set at this time). - 2. To change modes of operation, either in the same or opposite direction, the MTCM command is given to change the mode and a MTGO command is given to request the continued operation of the drive. If a change in direction is ordered, the transport will stop, pause, and automatically start up again. - 3. If the write function is being performed, the only forward change in command that can be given is write EOF. - 4. If no MTGO instruction is given, the transport will shut down in the inter-record gap. NOTE: No flags will be set when the control becomes ready or the transport becomes ready, except if the rewind command is present in the command register and the selected drive reaches BOT and is ready for a new command.) 5. If a write (odd parity) command is changed to write EOF, the parity is automatically changed to even. NOTE: Even parity will remain in the command register unless changed by a new command instruction, MTLC, which clears and loads the entire command register.) # 9-Track Operation Nine- and seven-track transports may be intermixed on the Type TC59 control. When a transport is selected, it automatically sets the control for proper operation with its number of tracks. Control of nine-track operation is identical to seven-track except as noted below. #### Write A word in memory is written on tape with the format shown below. X = these bits are ignored #### Read A word is read into memory from tape with the format shown below. #### Read/Compare A direct comparison of the characters on tape is made with those in memory. The parity bits are ignored, as are bits 0 and 1 of each memory word. # Core Dump Mode This mode is used only with nine-track transports. It is entered by setting bit 4 of the command register. Core dump mode permits the dumping of complete memory words in the form of three six-bit characters. The format is as follows. | | Character 1 | | Character 2 | | Cł | Character 3 | | | |--------|-------------|---|-------------|---|----|-------------|---|----| | Bits ( | ) | _ | 5 | 6 | _ | 12 | _ | 18 | This is accomplished by only utilizing seven of the nine tracks on the tape. Tape written in core dump mode must be read (read/compare) in the same mode. These operations are the same as for a seven-track transport. #### Status or Error Conditions Twelve bits in the magnetic tape status register indicate status or error conditions. They are set by the control and cleared by the program. The magnetic tape status register bits are as follows. | Bit* | Function (when set) | Bit* | Function (when set) | |------|----------------------------------------|------|-----------------------------------------| | 0 | Error flag (EF) | 7 | Read/compare error | | 1 | Tape rewinding | 8 | Record length incorrect | | 2 | Beginning of tape (BOT) | | WC = 0 (long)<br>WC ≠ 0 (short) | | 3 | Illegal command | 9 | Data request late | | 4 | Parity error (lateral or longitudinal) | 10 | Bad tape | | 5 | End of file (EOF) | 11 | Magnetic tape flag (MTF)<br>or job done | | 6 | End of tape (EOT) | | or lop dotte | <sup>\*</sup>The register bits are equivalent in position to the AC bits (i.e., $SR_0 = AC_0$ etc.) # MTF (SR11) The MTF flag is set under the following conditions. - 1. Whenever the tape control has completed an operation (after the EOR mark passes the read head). - 2. When the selected transport becomes ready following a normal rewind function. These functions will also set the EF if any errors are present. This flag sets bit 11 in the AC if an IORS instruction is issued. #### EOF (SR5) End-of-file (EOF) is sensed and may be encountered for those functions which come under the heading of read status function, i.e., space, read data, or read/compare and write EOF. When EOF is encountered, the tape control sets EOF = 1. MTF is also set; hence, an interrupt\* occurs and the EOF status bit may be checked. #### EOT (SR6) and BOT (SR2) End-of-tape (EOT) detection occurs during any forward command when the EOT reflective strip is sensed. When EOT is sensed, the EOT bit is set, but the function continues to completion. At this time the MTF is set (and EF is set), and an interrupt occurs. Beginning-of-tape (BOT) detection status bit occurs only when the beginning-of-tape reflective strip is read on the transport that is selected. <sup>\*</sup>All references to interrupts assume the tape flags have been enabled to the interrupt (command register bit 9 = 1) and that the unit is selected. When BOT detection occurs, and the unit is in reverse, the function terminates. If a tape unit is at load point when a reverse command is given, an illegal command error bit is set, causing an EF with BOT set. An interrupt then occurs. #### Illegal Command Error (SR3) The illegal command error bit is set under the following conditions. - 1. A command is issued to the tape control with the control not ready. - 2. A MTGO command is issued to a tape unit which is not ready, and the tape control is ready. - 3. Any command which the tape control, although ready, cannot perform, for example. - a. Write with write lock condition - b. Nine-channel tape and incorrect density - c. BOT and space reverse # Parity (SR4) Longitudinal and lateral parity checks will occur in both reading and writing. The parity bit is set for either lateral or longitudinal parity failure. A function is not interrupted, however, until MTF is set. Maintenance panel indicators are available to determine which type of parity error occurred. #### Read/Compare Error (SR7) When read/compare function is underway, SR7 is set to 1 for a read/compare error (see earlier section on read/compare for further details). #### Bad Tape (SR10) A bad tape error indicates detection of a bad spot on the tape. Bad tape is defined as three or more consecutive missing characters followed by data, within the period defined by the read shutdown delay. The error bit is set by the tape control when this occurs. MTF and interrupt do not occur until the end of the record in which the error was detected. # Tape Rewinding (SR1) When a rewind command has been issued to a tape unit and the function is underway, the tape rewinding bit is set in the control. This is a transport status bit, and any selected transport which is in a high-speed rewind will cause this bit to be set. # Record Length Incorrect (SR8) During a read or read/compare, this bit is set when the WC overflow differs from the number of words in the record. The EF flag is set. # Data Request Late (SR9) This bit can be set whenever data transmission is in progress. When the data flag causes a break cycle, the data must be transmitted before a write pulse or a read pulse occurs. If it does not, this error will occur, and data transmission will cease. The EF flag and bit 9 of the status register are set when the MTF is set. # Error Flag (SRO) The error flag (EF) is set whenever any error status bit is present at the time that MTF is set. When an illegal command is given, however, the EF is set and the MTF is not set. This flag (as well as MTF) sets bit 11 in the AC if an IORS is issued. | Unit | Se | ection | |------|----|--------| |------|----|--------| Density Selection | | Unit | Selectio | n Bits | Density | Density | Bits | |------|------|----------|--------|----------------------|---------|------| | Unit | 0 | 1 | 2 | 200 bpi | 0 | 0 | | 0 | 0 | 0 | 0 | 556 bpi | 0 | 1 | | 1 | 0 | 0 | 1 | 800 bpi | 1 | 0 | | 2 | 0 | 1 | 0 | 800 bpi<br>9 channel | 1 | 1 | | 3 | 0 | 1 | 1 | , didiliot | · | • | | 4 | 1 | 0 | 0 | | | | | 5 | 1 | 0 | 1 | | | | | 6 | 1 | 1 | 0 | | | | | 7 | 1 | 1 | 1 | | | | # Command Selection | Command | | Bits | | |---------------|---|------|---| | | 6 | 7 | 8 | | NO OP | 0 | 0 | 0 | | Rewind | 0 | 0 | 1 | | Read | 0 | 1 | 0 | | Read/Compare | 0 | 1 | 1 | | Write | 1 | 0 | 0 | | Write EOF | 1 | 0 | 1 | | Space Forward | 1 | 1 | 1 | | Space Reverse | 1 | 1 | 1 | # Magnetic Tape Function Summary LEGEND: CA = Current Address Register = 32<sub>8</sub> WC = Word Count Register = 33<sub>8</sub> F = Forward R = Reverse DS = Density Setting PR = Parity Setting EN = Enable Interrupt | Function | Characteristics | Status or Error Types | |---------------|-------------------------------------------------------------------------------------------------------------|---------------------------------------------------------| | NO OP | CA: Ignored<br>WC: Ignored<br>DS: Ignored<br>PR: Ignored<br>EN: Ignored | Illegal<br>BOT<br>Tape Rewinding | | SPACE FORWARD | CA: Ignored WC: 2's complement of number of records to skip DS: Must be set PR: Must be set EN: Must be set | Illegal<br>EOF<br>Parity<br>Bad Tape<br>MTF, BOT<br>EOT | | SPACE REVERSE | CA: Ignored WC: 2's complement of number of records to skip DS: Must be set PR: Must be set EN: Must be set | Illegal<br>EOF<br>Parity<br>Bad Tape<br>BOT<br>MTF | | Function | Characteristics | Status or Error Types | |--------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------| | READ DATA | CA: Core Address - 1 WC: 2's complement of number of words to be transferred DS: Must be set PR: Must be set EN: Must be set | Illegal EOF Parity Bad Tape MTF EOT Request Late Record Length Incorrect | | WRITE DATA | CA: Core Address - 1 WC: 2's complement of number of words to be transferred DS: Must be set PR: Must be set EN: Must be set | Illegal<br>EOT<br>Parity<br>MTF<br>Bad Tape<br>Data Request Late | | WRITE EOF | CA: Ignored WC: Ignored DS: Must be set PR: Must be set EN: Must be set | Illegal<br>EOF<br>Parity<br>MTF<br>Bad Tape<br>Data Request Late | | READ/COMPARE | CA: Core Address - 1 WC: 2's complement of number of words to be transferred DS: Must be set PR: Must be set EN: Must be set | Illegal EOF Read/Compare Error Bad Tape MTF EOT Data Late Record Length Incorrect | | REWIND | CA: Ignored WC: Ignored DS: Ignored PR: Ignored EN: Must be set | Illegal<br>Tape Rewinding<br>MTF<br>BOT | # MAGNETIC TAPE TRANSPORT, TYPE TU20 (7-CHANNEL) The Type TU20 is a digital magnetic tape transport designed to be compatible with the Type TC59 Magnetic Tape Control. The transport operates at a speed of 45 in./sec and has three selectable densities: 200, 556, and 800 bpi. The maximum transfer rate is 36,000 six-bit characters per second. Standard seven-channel IBM-compatible tape format is used. The specifications for the unit are as follows. <u>Format</u> - NRZ1. Six data bits plus one parity bit. End and loadpoint sensing compatible with IBM 729 I-VI. <u>Tape</u> – Width of 0.5 in. Length of 2400 ft (1.5 mil.). Reels are 10.5 in., IBM-compatible with file protect (write lock) ring. $\underline{\text{Heads}}$ - Write-read gap of 0.300 in. Dynamic and static skew is less than 14 $\mu sec.$ <u>Tape Specifications</u> - 45 ips speed. Start time is less than 5 msec. Rewind time for 2400 ft. is less than 3 min. Start distance is 0.080 in. (+0.035, -0.025 in.). Stop time is less than 1.5 msec. Stop distance is 0.045 in. (±0.015 in.). Density - 200, 556, and 800 bpi. Maximum transfer rate is 36 kHz. <u>Transport Mechanism</u> - Pinch roller drive; vacuum column tension. Controls - ON/OFF, ON LINE, OFF LINE, FORWARD, REVERSE, REWIND, LOAD, RESET. <u>Physical Specifications</u> - Width of 22-1/4 in., depth of 27-1/6 in., height of 69-1/8 in., weight - 600 lb. Read (Read/Compare) Shutdown Delay - 3.6 msec. Write Shutdown Delay - approximately 4.5 msec. # MAGNETIC TAPE TRANSPORT, TYPE TU20A (9-CHANNEL) The Type TU20A is a digital magnetic tape transport designed to be compatible with the Type TC59 Magnetic Tape Control. The transport operates at a speed of 45 in./sec and has three selectable densities: 200, 556, and 800 bpi. The maximum transfer rate is 36,000 eight-bit characters per second. Standard nine-channel IBM-compatible tape format is used. The specifications for the unit are as follows. <u>Format</u> - NRZI. Eight data bits plus one parity bit. End and loadpoint sensing compatible with IBM. <u>Tape</u> - Width of 0.5 in. Length of 2400 ft (1.5 mil.), Reels are 10.5 in., IBM-compatible, with file protect (write lock) ring. Heads - Write-read gap of 0.150 in. Dynamic and static skew is less than 14 µsec. <u>Tape Specifications</u> - 45 ips speed. Start time is less than 5 msec. Rewind time for 2400 ft. is less than 3 min. Start distance is 0.080 in. (+0.035, -0.025 in.). Stop time is less than 1.5 msec. Stop distance is 0.045 in. (±0.015 in.). Density - 200, 556, and 800 bpi. Maximum transfer rate is 36 kHz. Transport Mechanism - Pinch roller drive; vacuum column tension. Controls - ON/OFF, ON LINE, OFF LINE, FORWARD, REVERSE, REWIND, LOAD, RESET. <u>Physical Specifications</u> - Width of 22-1/4 in., depth of 27-1/6 in., height of 69-1/8 in. weight - 600 lb. Read (Read/Compare) Shutdown Delay - 3.6 msec. Write Shutdown Delay - approximately 4.5 msec. #### SERIAL DRUM SYSTEM TYPE RM09 The RM09 Serial Drum system is available in three storage sizes: 32,768, 65,536, and 131,072 19-bit words. Information is stored and transferred in blocks of 256 18-bit words. Each drum word contains 18 information bits and 1 parity bit. Computation continues during block transfers. Timing specifications are as shown below. | Timing Specifications | 60 cps | <u>50 cps</u> | |---------------------------------|------------------|------------------| | Average Access Time | 8.65 msec | 10.38 msec | | Worst Case Access Time | 17.3 msec | 20.76 msec | | Transfer Rate | 30.0 K words/sec | 25.0 K words/sec | | Transfer Time | 33.3 µsec/word | 40.0 µsec/word | | Block Transfer Time (256 words) | 8.65 msec | 10.38 msec | The drum is interfaced to the PDP-9 via the DMA multiplexer (Type DM09A) attached to the Direct Memory Access channel. The DMA interface allows true cycle-stealing transfers. The RM09 interface connections are shown in figure 5-2. A transfer begins when the continuously rotating drum reaches the index mark, 1.7 microseconds before the beginning of the data track (word 0, bit 0). There are two gaps separating the two data blocks on each track. One gap is 300 µsec, the other gap is 50 µsec, see figure 5–3. Track switching for continuous operation is done during the 300 µsec gap; sector switching, within the track, can be done during either gap time. Because the selection of a read-write head requires 200 microseconds stabilization time, a new track must be specified during the first 100 microseconds of the 300 microsecond interval for continuous transferring. If selected tracks are consecutive, uninterrupted transferring may be programmed merely by specifying continuation, since the block number and core memory location are automatically incremented. The continuation command can be given at any time during the 300-microsecond interval. The drum flag (transfer done flag) is set to 1 upon completion of a block transfer, causing a program interrupt. The flag is cleared either by a Clear Flag instruction (DRCF) or automatically when one of two transfer instructions (DRBLK, DRCONT) is given. The drum flag is associated with bit 17 of the I/O read status word. An error flag, which should be checked at the completion of each block transfer, indicates either of the following conditions: - 1. That a parity error has been detected after read-in from drum to core. - 2. That the DMA request signal from the drum was not answered within the 33.3 microsecond period. This condition can occur if other devices with higher priority are connected to the DMA channel multiplexer. In reading from the drum, this means that a data word is incorrect in core memory. In writing on the drum, some word has not been received from the computer. #### Drum Registers <u>Drum Core Location Counter (DCL)</u>, a 16-bit register which addresses the next core location to or from which a word is to be transferred. As a word is transferred, DCL is incremented by one. <u>Drum Track Address Register (DTR)</u>, a 9-bit register which addresses the drum track (or block) which is currently transferring data. At the completion of a successful block transfer (error flag is 0) DTR is incremented by one. <u>Drum Final Buffer (DFB)</u>, an 18-bit register under control of the DMA control which is a buffer between the memory buffer register and the drum serial buffer. During writing on the drum, the DFB holds the next word. During reading from the drum, transfers to memory are under control of the data interrupt. <u>Drum Serial Buffer (DSB)</u>, an 18-bit register which is a serial-to-parallel converter during drum reading, and a parallel-to-serial converter during drum writing. Information is read from the drum into DSB serially and transferred to DFB in parallel. During drum writing, a word is read from DFB into DSB and written serially around the drum. #### Drum Instructions | Mnemonic | <u>Octal</u> | Operation | |----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DRLCRD | 706006 | Load the drum core location counter with the core memory location information in accumulator bits 2 through 17. Prepare to <u>read</u> one block of information from the drum into the specified core location. | | DRLCWR | 706046 | Load the drum core location counter with the core memory location information in accumulator bits 2 through 17. Prepare to <u>write</u> one block of information into the drum from the specified core location. | | DRLBLK | 706106 | Load the drum track address register with the con-<br>tents of accumulator bits 9 through 17. Clear the<br>drum flag, clear the error flag, and begin a trans- | |--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | fer (reading or writing). | | DRCONT | 706204 | Clear the drum flag, clear the error flag, and begin a transfer. | | DRCF | 706102 | Clear the drum flag and error flag. | | DRSF | 706101 | Skip if the drum flag is a I. (The block transfer is complete.) | | DRSOK | 706201 | Skip if the error flag is not a 1. | # Physical Specifications Dimensions: 23-1/2 inches wide, 27-1/16 inches deep, 69-1/8 inches high Service Clearances: 8-3/4 inches in front, 14-7/8 inches in back Weight: 550 pounds Power Required: 115 volts and 60 cycles or 240 volts and 50 cycles (customer must specify which), single phase, 8-ampere starting current, 5-amperes running current for 115 volt unit Power Dissipation: 450 watts Temperature: 32-105 degrees F operating range, 4 degrees F/minute maximum rate of change, 20 degrees F maximum allowable instantaneous change. Toggle switches on a panel at the back of the machine allow local/remote power control, field lockout of groups of 8 consecutive tracks to prevent writing over valid information accidentally, and control of the clock to allow ease of maintenance. Each of the 32 field lockout switches controls a group of 4,096 words (16 sectors). Figure 5-2 RM09 Drum, Interface and Block Diagram Figure 5-3 RM09 Drum, Track Layout #### DISK SYSTEM TYPE RB09 The PDP-9 Type RB09, Disk System provides a high-capacity, fast-access bulk storage facility for use with PDP-9 general purpose computer systems. The RB09 uses both sides of a single 26-in. disk and features an individual read/write head per track to eliminate track searching and head positioning and minimize access times. A "flying head" design is employed to insure reliability by eliminating all contact between the disk surface and the heads. TABLE 5-3 DISK FORMAT AND TIMING SPECIFICATIONS | Format | | |--------------------------------------------|----------------------| | Storage capacity (18-bit words) | 1,024,000 | | Words per segment | 6410 | | Segments per track | 8010* | | Number of tracks | 20010 | | Timing Specifications (50 or 60 cycle) | | | | | | Average access time | 17 msec. | | Average access time Worst case access time | 17 msec.<br>34 msec. | | • | | <sup>\*</sup>Plus one segment for maintenance. The Type RB09 Disk System connects to the PDP-9 computer via the Type DM09A Direct Memory Access Channel Multiplexer Adapter, as well as the I/O bus (see figure 5-4). The DMA multiplexer interface allows the RB09 to transfer directly to or from the PDP-9 memory, operating on a true cycle-stealing basis for maximum throughput, while permitting the PDP-9 central processor to continue processing a separate program. The highest priority channel of the Type DM09A Multiplexer is reserved for the disk system to insure that no information is lost during data transfers. The I/O bus is also interfaced to the control of the disk system to allow commands to be sent to the control and status information to be read back by programmed transfers. The control may interrupt the PDP-9 to signify the completion of a transfer operation or the presence of an error condition; these interrupts may be interfaced to either the standard program interrupt system or the optional Type KF09A Automatic Priority Interrupt (API). When the disk system is connected to the API, it is assigned a fixed channel address of 47<sub>8</sub> and a priority level = 1\*. <sup>\*</sup>Although the API channel address is fixed, the priority level may be changed to accommodate the user. Figure 5-4 Type RB09 Disk System Interfaced to PDP-9 via DMA MPXR, Type DM09A, and I/O Bus. # Operation The disk is organized into 200<sub>10</sub> tracks, 100<sub>10</sub> per side, with 80<sub>10</sub> segments of 64<sub>10</sub> words each per track. Transfers are made under the control of a word count register (WC), track address (TA) and segment address (SA) registers, and a memory address counter (MAC). Although all read and write transfers must begin with the first word of a segment, the word count register will allow the transfer of any number of words between 1 and 32,768. Maximum recording efficiency can be achieved if the number of words specified by the word count is an integral number of segments, i.e., 64 words (one segment), 192 words (three segments), 384 words (six segments), etc. If a write transfer of a non-integral number of segments is specified, the balance of the locations in the last segment will be written as zeros. Internally (between the disk and its control) all information is handled as 6-bit characters. During a WRITE operation, a 6-bit register generates a parity character derived by sequentially XORing all characters written in a segment. This parity character is recorded at the end of the segment. On READ operations, the parity character is created in the same way and compared with the one on the disk. If an inequality is found, the PARITY ERROR flag is set. #### Disk Control Instructions | Mnemonic | Octal | Operation | |----------|--------|--------------------------------------------------------------------------------------------------------------| | DSCF | 707101 | Clear flags; bits 0-5 of the disk control status register are set = 0. | | DSLD | 707104 | Clear and load TA and SA from AC. Information should be in BCD form. | | DSRD | 707112 | Clear AC, read TA and SA into AC. | | DSSF | 707121 | Skip on flags (ERROR FLAG OR DONE FLAG). | | DSLW | 707124 | Clear and load WC from AC. AC should contain 2s complement of the desired number of words to be transferred. | | DSRS | 707132 | Read Status Register into AC. | | DSCS | 707141 | Clear Status Register. | | DSLM | 707142 | Clear and load MAC from AC. | | DSLS | 707144 | Load Status Register from AC; bits 6, 7, and 8 are loaded into register by logical XOR. | #### Programming In order to initialize a transfer to or from the disk, the computer must: - 1. Specify word count (DSLW) - 2. Set the MAC to the initial core location for data transfer (DSLM). - 3. Load the track address and segment address registers (DSLD). - 4. Specify the operation status (DSLS), i.e., READ or WRITE, ENABLE or DISABLE program interrupt, and set BUSY bit. The DSLS instruction also initializes the search for the desired segment and starts the data transfer, so it must not be issued before the other initialization commands have been issued. Upon completion of the data transfer, the DONE flag is set, causing a program interrupt (if enabled). If the last data segment of a track, segment 79<sub>10</sub>, is read or written before the transfer operation has been completed, the control automatically increments the track address, allowing the transfer to continue to or from segment 0 of the next track. Since the maintenance segment is written after segment $79_{10}$ ' lapse time approximately equal to one segment's transfer time (400 $\mu sec$ ) occurs between the transfer of segment $79_{10}$ and segment 0 of the next track. However, transfers to or from consecutively-numbered segments on different tracks cannot be accomplished without allowing a full revolution of the disk (34 msec), since a new track address and segment address must be specified to the control to switch tracks. # Addressing Initial track and segment addresses are specified to the control as 4-bit BCD characters (see figure 5-5). Track addresses greater than 199<sub>10</sub> and segment addresses greater than 79<sub>10</sub> will cause the ILLEGAL ADDRESS (IA) FLAG to be set. Addresses which are not in legitimate BCD format will also cause the IA FLAG to be set. Figure 5-5 Format for Track and Segment Addresses ## **Errors** Several error conditions will cause a program interrupt, provided the INTERRUPT ENABLE (IN EN) bit in the status register is set. The following error conditions have been assigned bit locations within the status register: Bit 0: Error Flag (EF) This flag is the OR of all of the following error conditions. #### Bit 1: Parity Error (PE) An inequality between an XOR of a 6-bit character string within one segment (calculated during READ operation) compared with the 6-bit parity character previously recorded for the respective segment will set bit 1. ## Bit 2: Illegal Address (IA) The IA Flag is set upon detection of one of the following conditions: - a. If the track and/or segment address registers (TA and SA) are loaded with invalid BCD numbers, either forbidden states or numbers greater than 199<sub>10</sub> or 79<sub>10</sub> respectively, and/or - b. If an attempt is made to address a protected track during write functions while in the write protect mode (see below). #### Bit 3: Timing Error (TE) This flag is set if a data break is requested before the granting or servicing of the previous data break. Detection of this error will stop the transfer at the end of the current segment. Any data transferred is considered invalid. #### Bit 4: Disk Not Ready (NR) The disk initiates a READY level to the control provided the following conditions are met: a. Correct disk speed (RPM): The READY level will not be asserted until the disk attains the correct RPM to sustain head flying position. Power failure that results in lower disk RPM will set the NR flag. b. Correct air pressure: Air pressure is utilized to lower the READ/WRITE heads to the required flying position over the disk. Improper pressures will result in the setting of the NR flag. c. Correct cooling level: Insufficient cooling within the disk cabinet will also set the NR flag. If the READY level is not asserted when the disk system is sent a transfer command, the transfer will be aborted and the NR flag will be set. Upon starting the disk, the READY level will be negated until all the proper conditions are met. The READY level, which originates within the disk cabinet is connected to an indicator on the front of the disk cabinet. This indicator will be lit as long as the disk is NOT READY, and extinguished upon a READY condition. One of the features of the disk design is the ability to detect a situation whereby a flying head might come in contact with the disk surface. This is a safety feature that will set the NOT READY flag when a temporary contact has occurred (e.g., a dust particle on the disk). If the disk remains NOT READY as the result of a "touch" the user should be aware of the potentially hazardous condition which exists. When the NOT READY light is the result of a "touch", the red light on the maintenance panel inside the disk cabinet will light. In the unlikely event that this happens, DO NOT immediately attempt to refly the heads by hitting the TOUCH RESET button or by turning power on and off the unit. The proper procedure is described in the disk technical manual. # Control Registers # Memory Address Counter (MAC) A 15-bit register initially loaded with the PDP-9 core memory address to or from which data transfers will start. The MAC is incremented after each word transfer. ## Word Count (WC) A 16-bit register initially loaded with the 2s complement of the number of words to be transferred. The WC is incremented every time a data break is being requested from the computer, before the word transfer. Upon the transmission of the last word, the register will be zero, a WORD COUNT OVERFLOW level (WCOF) will be asserted and further transfers will be halted. ### Track Address (TA) and Segment Address (SA) A 17-bit register initially loaded with the track and segment addresses to or from which transfers will begin. If, after the last transfer from segment 79<sub>10</sub> has been completed, the word counter (WC) is not equal to zero, the track address register will automatically increment, and transfer will continue. #### Segment Address Counter (SAC) An 8-bit register used to keep track of the current location within a segment. It is incremented prior to the beginning of operations to or from the addressed segment. The contents of this register, along with the current address, may be read into the accumulator via a DSRD instruction. #### Data Buffer (DB) An 18-bit register used to buffer data words from or to the PDP-9 through the DMA Multiplexer Adapter. #### Character Data Buffer (CDB) An 18-bit register used to buffer the data between the disk and the data buffer (DB). This register divides the 18-bit word into three 6-bit characters recorded or read from the disk. Data to the disk is taken from bits 0-5 of the CDB. During a READ operation, data is read from the disk to bits 12-17. Subsequent shifting of this register during either operation allows all three characters to be either read or written. ### Parity Generator (PG) A 6-bit register used to generate the parity character during a WRITE operation by XORing the data in bits 0-5 of the CDB. At the end of each segment, the parity character generated is recorded on the disk. During a READ operation, the PG register recalculates the XOR of the string of data characters read in from the disk. #### Status Register A 9-bit register containing all necessary disk system status information. Information is displayed on the disk control panel as shown below: In actual operation, after initialization the control searches the disk for the addressed segment, and the BUSY bit is set. At the completion of a transfer (WCOF level asserted), the DONE flag is set. A transfer may always be inhibited by resetting the BUSY flag, with operation halting at the end of the current segment. Information is loaded into the status register from the accumulator by a DSLS instruction. The BUSY, R/W, and IN EN flags are loaded by an XOR operation. All error flags may be raised by the program (for help in maintenance diagnostics). When issuing this instruction, bits 15, 16, and 17 of the accumulator should be zero. #### Write Protect Feature The disk control panel contains a switch register that protects against the writing of selected tracks on the disk. To incorporate the write protect feature, the switch marked WRITE PROTECT is raised. Protection is available in bands of ten tracks. Thus, for example, to protect tracks 0 to 9, switches marked WRITE PROTECT and 0-9 are set. If the first 40 tracks are to be protected, then the 4 switches marked 0-9, 10-19, 20-29, and 30-39 are set. If the first 100 or more tracks are to be protected, the switches marked 0 to 90 and above 100 are set. If, for example, switch 30-39 is set alone, then tracks 30 to 39 only are protected. If an attempt is made to address the protected tracks, the IA flag is set, resulting in a program interrupt (provided the INTERRUPT ENABLE flag is SET). Further transfers will be inhibited since the IA flag will reset the BUSY flag. If during a transfer, a track is incremented so as to enter a protected zone, then the IA flag will be set and no operation will take place on the protected track. ### Maintenance Segment To allow the operator to verify selection and transfer of data from every track without disturbing the information already stored, a maintenance segment is located on each track. It is located just before segment 0 and is designated segment $80_{10}$ . To access this segment, the maintenance switch on the disk control panel is set. The desired track is addressed as usual. However, now a BCD code of $80_{10}$ may be loaded into the SA register with a DSLD instruction. With the maintenance switch up, access cannot be made to any other segment, and when the switch is in the normal position, access cannot be made to the maintenance segment. If an attempt is made to address an invalid segment, the IA flag will be set. #### Control Panel A panel, located behind the cabinet front covers, contains light indicators for all registers plus indicators for 12 control flip-flops, and the 2 API flags located within the W104 module (API RQ and API EN). In addition to the above indicators, the panel contains 13 switches associated with the write protect feature, a maintenance switch (MAIN/NORMAL), and a switch to disable the interrupt labeled NOT READY. # CHAPTER 6 ADDRESSING PDP-9 can directly address up to 8192 locations (a location consists of an 18-bit word register) and indirectly address up to 32,768 locations in system core memory. Locations are addressed, octally, as 00000 through 77777 with the following allocations per separate memory modules, or banks. Memory bank 0 - 00000 through 17777 Memory bank 1 - 20000 through 37777 Memory bank 2 - 40000 through 57777 Memory bank 3 - 60000 through 77777 Bank 0 is included with the basic PDP-9 configuration; other banks are appended with expansion of the system. PDP-9 also offers autoindexing and extend mode addressing. Eight explicitly addressed locations (10-17) in the basic memory module provide efficient indexed addressing of up to 32,768 memory locations. An indirect reference to these locations increments the existing contents by one and takes the result as the effective address for the operand. Extend mode addressing, implemented by the optional memory extension control, sets up the required parameters for addressing across the memory module boundaries of an expanded PDP-9 system. #### DIRECT ADDRESSING The instruction word format for PDP-9 memory reference instructions includes an operation code field of four bits, an indirect address indicator field of one bit, and a 13-bit address field, as follows. For direct addressing, the indirect address indicator (bit 4) is 0. In this case, the machine action defined by the operation code field considers the contents of the address field as being the "effective" address for the instruction. This address specifies a location for direct retrieval, entering, or modification of the contents. For example, the directly addressed instruction **LAC 100** directs the central processor unit (CPU) to load its accumulator register (AC) with the 18-bit contents of memory location 100. The 13-bit address field allows direct addressing of any location of the 8192-word basic memory module. ### INDIRECT ADDRESSING For indirect addressing, the indirect address indicator (bit 4) is 1. In this case, the contents of the address field reflect not the effective address but the address of the location at which the effective address is expressed. For example, the indirectly addressed instruction **LAC I 100** (where I is the PDP-9 symbolic representation for indirect addressing) directs the CPU to load the AC, not with the contents of location 100, but the contents of the location that is addressed by the contents of location 100. If location 100 contained 000077, the instruction **LAC** 100 would cause the quantity 000077 to be loaded into the AC. The instruction LAC I 100 however, would not enter 000077 in the AC but the contents of location 00077 (considering the address field limitation of 15 bits for addressing up to 32,768 locations). Indirect addressing adds one machine cycle to an instruction's execution time. During this interval, execution is deferred while the effective address is established. An instruction can have only one level of indirect addressing. # **AUTOINDEXING** Eight locations, 00010 through 00017, of memory bank 0 serve as autoindex registers. Indirect addressing of an autoindex register causes its contents to be automatically incremented by one and then taken as the effective address for the instruction. Thus, addressing of sequential memory locations can be easily achieved by loading an autoindex register with the initial address minus one, and then indirectly addressing the autoindex register until the required operation is completed. The incrementation of an autoindex register's contents does not add to the instruction execution time. Autoindexing occurs only upon an indirect address reference of an autoindex register. When directly addressed, an autoindex register functions in the same manner as all other memory locations. Assume that four memory locations are initialized as follows: | Location | Contents | |----------|----------| | 0010 | 100 | | 0040 | 050 | | 100 | 040 | | 101 | 041 | The following four instructions to load the accumulator illustrate, by comparison, direct, indirect, and autoindexed addressing. | . LAC | | 100 | Places the number 40 into the AC. | |-------|---|-----|-------------------------------------------| | LAC | I | 100 | Places the number 50 into the AC. | | LAC | | 010 | Places the number 100 into the AC. | | LAC | I | 010 | By autoindexing, the contents of location | | | | | 10 become 101; then the number 41 is | | | | | placed into the AC. | Autoindexing can be used to process a block of numbers without the need for address arithmetic. The following three examples demonstrate typical programming techniques (the mnemonics refer to PDP-9 instructions of the memory referencing and augmented classes. Refer to chapter 7, Instructions, for descriptions of their actions). | Example 1: | Sum a series of numbers; | $Y = \sum_{i=1}^{N} X_{i}$ | |-------------|--------------------------|---------------------------------------| | 10/<br>100/ | FIRST -1 | /FIRST WORD'S LOCATION -1 | | COUNT, | -N+1 | /NUMBER OF ITERATIONS (2s COMPLEMENT) | | ENTRY, | CLA:CLL | /CLEAR AC AND LINK | | LOOP, | ADD I 10 | /PARTIAL SUM | | | isz count | /test for completion | | | JMP LOOP | /MORE IN TABLE, GO BACK | | | HALT | /SUM IN AC | Example 2: $$Ci = Ai + Bi$$ ; $i = 1, 2, ...N$ Three autoindexing locations are used to simplify the addressing. ``` 10/ L(A) - 1 /(THE FIRST LOCATION OF THE A ARRAY) -1 11/ L(B) - 1 /(THE FIRST LOCATION OF THE B ARRAY) -1 12/ L(C) -1 /(THE FIRST LOCATION OF THE C ARRAY) -1 100/ COUNT, -N+1 /(NUMBER OF ITERATIONS (2s COMPLEMENT) BEGIN, CLA!CLL CLEAR AC AND LINK LOOP, LAC I 10 GET ADDEND ADD I 11 /FORM SUM DAC I 12 /STORE SUM ISZ COUNT TEST FOR COMPLETION JMP LOOP /MORE IN TABLE, GO BACK HALT ``` Example 3: $C_i = C_i + K$ ; i = 1, 2, ...N This example demonstrates the modification of a list of numbers by adding a constant to each of them. In this case, the autoindexing memory register contains an instruction rather than just an address. | 10/<br>100/ | DAC FIRST -1 | /DEPOSIT INTO (FIRST LOCATION IN TABLE)—1 | |-------------|--------------|-----------------------------------------------| | COUNT, | - N + 1 | /TWOS COMPLEMENT OF NUMBER OF WORDS /IN TABLE | | CONST/, K | | /THE CONSTANT | | GO, | CLA!CLL | /CLEAR AC AND LINK | | LOOP, | LAC I 10 | /PICK UP INITIAL VALUE FROM TABLE | | | ADD CONST | /ADD CONSTANT | | | XCT 10 | REPLACE IN TABLE | | | isz count | /TEST FOR COMPLETION | | | JMP LOOP | /MORE IN TABLE, GO BACK | | | HALT | | All indirectly addressed reference to locations 10-17 refer to the absolute locations of memory bank0, regardless of the memory bank location of the instruction making the reference or the condition of the extend mode. A directly addressed reference to one of these locations refers to the absolute location, only if the instruction making the reference is also present in a location of memory bank 0. If the instruction is located in any bank other than memory bank 0, the direct reference is made to the relative location of that memory bank. Thus, the use of the instruction to load autoindex register 10 with a specified contents for indexing purposes would be effective only if the loading instruction is in memory bank 0 after the program was loaded. Users instead are advised to adhere to the following procedure for loading autoindex registers from any memory bank other than 0. The extend mode must be enabled. This indirect loading sequence accomplishes the loading regardless of the memory bank storage of the DAC I A instruction. #### EXTEND MODE ADDRESSING Addition of the optional memory extension control, Type KG09A, required for expansion of PDP-9 core memory (up to 32,768 words in banks of 8192 words), implements the extend mode for addressing any memory location in the expanded system. The mode is enabled and disabled by programmed instructions, and it can be entered through use of the EXD switch on the control console (refer to Operator's Guide, chapter 10). The memory extension control adds the following four instructions to the PDP-9 order code. | Mnemonic | Octal Code | Operation | |----------|------------|------------------------------------------------| | SEM | 707701 | Skip next instruction if extend mode is active | | EEM | 707702 | Enter extend mode | | LEM | 707704 | Leave extend mode | | ERIR | 707742 | Enter extend mode interrupt restore | Execution of the EEM instruction enables the extend mode, and LEM disables the mode. If the mode is enabled, execution of the SEM instruction causes the PC to be incremented by one to effect a skip of the next instruction in sequence. While the extend mode is disabled, all instructions to be executed during this interim, and their operands, must be stored in the same memory bank, and this bank will be addressed by the Extended Program Counter (EPC). The EPC consists of standard 13-bit PC and the 2-bit extension, added by the option to the high-order end. With the exception of the PI and API traps to bank 0, it is impossible to access any instruction or operand from other memory banks with the extend mode disabled. Regardless of the extend mode status, however, an instruction in another bank can always indirectly address auto-index registers (locations 10 through 17) of bank 0 to make use of that facility. When the extend mode is disabled, the auto-index register is used as an address pointer to the memory bank from which the reference was made (i.e., the 2-bit extension of the PC is unchanged and only 13 bits of address in the auto register are taken). To load the contents of an auto-index register from any memory bank except 0, the extend mode must be enabled. Program interrupts and API interrupts trap to their proper locations in bank 0. In trapping to location 00000 of bank 0, a program interrupt stores the existing status of the extend mode (on or off) and then disables the mode. Through use of the DBR (debreak and restore) instruction, the interrupt-accessed subroutine can restore the mode to its interrupted state at the end of the routine. (For a description of the DBR instruction, refer to the API discussion in Chapter 9.) An API request transfers program control to the appropriate channel entry in memory (always in bank 0). The instruction present at the channel location should be a JMS IY, which stores the EPC and the status of the extend mode. (The JMS should be indirect to permit relocation to any bank.) The mode status is not disturbed. While the extend mode is enabled (the normal state), any location in the memory system may be indirectly addressed through extension of the effective address from the normal 13 bits (bits 5 through 17) to 15 bits (bits 3 through 17). Bits 3 and 4 indicate the memory bank that is to be addressed, and bits 5 through 17 address a location in that bank. The PC extension indicates by its contents which of the memory banks is currently addressed by the PC. Because the extension cannot count, the PC functions as a modulo 8192 counter and therefore does not increment across memory bank boundaries (e.g., the location addressed after 17777 is 00000, not 20000). To effect a change in memory banks, the program must include a jump instruction with indirect address (JMP IY, or JMS IY if the exit point is to be preserved for subsequent return). Execution of this instruction enters a 15-bit address in the extended program counter to select the new memory bank and the starting location in this bank. When extend mode is enabled an effective address for an indirectly addressed location must be a 15-bit address. This requirement prohibits the use of an instruction word (such as LAW Y) as an indirect address when the extend mode is enabled. Note that execution of a CAL instruction results in the addressing of location 20 of memory bank 0, when the extend mode is enabled; and location 20 (relative) of the currently addressed memory bank, when the extend mode is disabled. XCT instruction always function as if the referenced instructions were fetched. Thus, XCT I reference of a skip instruction in another memory bank effects a skip of the instruction immediately following the XCT I instruction, if the skipping condition is satisfied (i.e., the EPC is incremented by one). Similarly, XCT I reference of a JMS or CAL instruction in another memory bank effects the appropriate storing of the EPC contents, which in turn represent the address of the location following the XCT I instructions and not the location following the referenced instruction. #### RESERVED ADDRESSES Programs prepared for the PDP-9 should not make use of locations addressed 00000 through 00077 for data or instruction storage as they are reserved for the following purposes. | Address | Purpose | |---------|-------------------------------------------------------------------------------------------------------------------------------------| | 0 | Stores the contents of the extended PC, link, extend mode status, and memory protection status during a program interrupt. | | 1 | Stores the first instruction to be executed following a program interrupt. | | 2-6 | Reserved for PDP-9 system programs. | | 7 | Stores real-time clock count. | | 10-17 | Autoindex registers. | | 20 | Stores the contents of the extended PC, link, extend mode status, and memory protection status upon execution of a CAL instruction. | | 21 | Stores the first instruction to be executed following a CAL instruction. | | 22-27 | Reserved for PDP-9 system programs. | | 30-37 | Four pairs of word counter-current address registers for use with data channels 0, 1, 2, and 3. | | 40-77 | Store unique entry instructions for each of $32_{10}^{}$ automatic priority interrupt channels. | # CHAPTER 7 INSTRUCTIONS The PDP-9 instruction set is subdivided into two groups: those which address system core memory and those which do not. An instruction of the former group addresses, either directly or indirectly, a location in memory for the purpose of retrieving, entering, or modifying the contents. These instructions are known as "memory referencing" instructions. The instructions which do not address memory are known as "augmented" instructions in that the entire 18-bit instruction word serves as an expanded operation code to specify a specific action or actions to be executed. The augmented instruction group has three subclasses: operate (which provides for skip, rotate, clear, complement, etc. operations involving the accumulator and/or the link register); IOT (input/output transfer of data, status, and command information between the central processor and peripheral devices); and EAE (optional extended arithmetic element implementation of hardware multiply, divide, shift, normalize, etc.). # MEMORY REFERENCE INSTRUCTION FORMAT The memory reference instruction word (figure 7-1) consists of three parts: operation code, indirect address bit, and address. The operation code, bits 0 through 3, indicates which one of PDP-9's 13 memory reference instructions is specified. The indirect address bit indicates whether the 13-bit address (bits 5 through 17) is to be taken as the direct address (bit 4 is 0) or indirect address (bit 4 is 1). If direct addressing is indicated, the addressed memory location is taken to contain the required operand. If indirect addressing is called for, the contents of the addressed memory location are taken not as the operand but the address at which the operand is located. In either case, the address specifying the memory location that contains the operand is taken as the "effective address" for the instruction. Figure 7-1 Memory Reference Instruction Format #### AUGMENTED INSTRUCTION FORMAT The augmented instruction word (figure 7-2) has two parts: an operation code and an instruction code. The operation code, bits 0 through 3, denotes the type of instruction specified by the instruction code. Operation codes for the three types are: 70<sub>8</sub> for input/out transfer (IOT), 74<sub>8</sub> for operate, and 64<sub>8</sub> for the optional extend arithmetic element (EAE). The instruction code, bits 4 through 17, specifies the action to be executed. An important and useful feature of the PDP-9 augmented instruction is its microprogramming capability. Multiple instruction codes having the same operation code can be combined to form one instruction word. Execution of all the microprogrammed functions occurs during the time allocated to the type of instruction (operate instructions require one machine cycle, IOTs require four cycles, and EAEs require two cycles plus a variable time interval to complete their functions). Thus, microprogramming decreases program running time, lessens the number of instruction words required, and simplifies programming efforts. Figure 7-2 Augmented Instruction Format #### MEMORY REFERENCE INSTRUCTIONS The following information applies to each memory reference instruction. - 1. Instruction time is expressed in machine cycle units, where one cycle equals $1.0~\mu sec.$ - 2. An instruction with indirect addressing (bit 4 is 1) requires one additional machine cycle. PDP-9 memory referencing instructions can take only one level of indirect addressing; i.e., the indirectly addressed memory location must contain the address of the operand. 3. The term "effective address" applies to the address that specifies the memory location containing the operand for the instruction. 4. Numerical memory location addresses are expressed octally. 5. Subscript notations identify specific bit positions of the respectively identified register or location. Numerical subscripts are expressed decimally. 6. Except for the CAL instruction, all memory referencing instructions must include the address (direct or indirect) of an operand. The CAL instruction takes the hardware-fixed address of 20; it ignores the address field in the instruction word. 7. In the symbolic representations for the JMP, JMS, and CAL instructions, the quotation marks enclosing "Y", or "21" for CAL, indicate that Y, or 21, rather than their contents, enters the PC, as shown. # Load the Accumulator LAC Mnemonic: LAC Octal Code: 20 Time: 2 cycles Operation: The contents of the effectively addressed memory register, Y, are read into the AC. The contents of Y are unchanged; the previous contents of the AC are lost. Symbolic: $Y \longrightarrow AC$ # Deposit the Accumulator DAC Mnemonic: DAC Octal Code: 04 Time: 2 cycles Operation: The contents of the AC are deposited (written) in the effectively addressed memory register, Y. The contents of the AC are unchanged; the previous contents of Y are lost. Symbolic: AC → Y DZM ## Deposit Zero in Memory Mnemonic: DZM Octal Code: 14 Time: 2 cycles Operation: An all-zeros data word is deposited (written) in the effectively addressed memory register, Y. The previous contents of Y are lost; the contents of the AC are unchanged. Symbolic: $0 \longrightarrow Y$ ## Add (1s Complement) ADD Mnemonic: ADD Octal Code: 30 Time: 2 cycles Operation: The contents of the effectively addressed memory register, Y, are added to the contents of the AC, following the rules of 1s complement arithmetic (end around carry). The result is left in the AC. An arithmetic overflow sets the link to the binary 1 state. The contents of Y are unchanged; the previous contents of the AC are lost. The previous content of the link is lost. Overflow occurs if the magnitude (absolute) of the algebraic sum of the operands exceeds $2^{17}$ -1; i.e., if the operands were of like sign and the result is signed differently, overflow has occured to set the link. Over flow cannot occur if the operands are of different sign. Symbolic: Y + AC → AC L V Overflow → # Add (2s Complement) TAD Mnemonic: TAD Octal Code: 34 Time: 2 cycles Operation: The contents of the effectively addressed memory register, Y, are added to the contents of the AC, following the rules of 2s complement arithmetic.\* The result is left in the AC. An arithmetic carry from AC<sub>0</sub> complements the link. The contents of Y are unchanged; the previous contents of the AC are lost. Symbolic: $Y + (L,AC) \longrightarrow (L,AC)$ <sup>\*</sup> Refer to chapter 8 for discussion of 1s and 2s complement notations and arithmetic. Boolean AND Mnemonic: AND Octal Code: 50 Time: 2 cycles Operation: The contents of the effectively addressed memory register, Y, are logically ANDed with the contents of the AC on a bit-by-bit basis. The result is left in the AC. If corresponding Y and AC bits are in the 1 state, the AC bit remains a 1; otherwise the AC bit is cleared to the 0 state. The contents of Y are unchanged; the previous contents of the AC are lost. Symbolic: $Y \land AC \longrightarrow AC$ | AND | | A | c <sub>i</sub> | | |-----|---|---|----------------|--| | | 0 | 1 | | | | ı | 0 | 0 | 0 | | | Υ, | 1 | 0 | 1 | | | 1 | | | | | | | | | | | Boolean Exclusive OR **XOR** AND Mnemonic: XOR Octal Code: 24 Time: 2 cycles Operation: The contents of the effectively addressed memory register, Y, are exclusively ORed with the contents of the AC on a bit-by-bit basis. The result is left in the AC. If corresponding Y and AC bits are in the same binary state (i.e., 1 or 0), the AC bit is cleared to the 0 state. If the corresponding bits differ in their states, the AC bit is set to the 1 state. The contents of Y are unchanged; the previous contents of the AC are lost. Symbolic: Y ¥ AC → AC | Exclusive O | A | ci | | |-------------|---|----|---| | | | 0 | 1 | | | 0 | 0 | 1 | | Yi | 1 | 1 | 0 | # Skip if AC Differs SAD Mnemonic: SAD Octal Code: 54 Time: 2 cycles Operation: The contents of the effectively addressed memory register, Y, are compared with the contents of the AC. If they differ, the PC is incremented by one to effect skipping the next instruction. If they are the same binary quantity, the next instruction is executed. The contents of Y and the contents of the AC are unchanged. Symbolic: If $Y \neq AC$ , $PC + 1 \longrightarrow PC$ # Increment and Skip if Zero ISZ Mnemonic: ISZ Octal Code: 44 Time: 2 cycles Operation: The contents of the effectively addressed memory register, Y, are incremented by one (in 2s complement arithmetic) and tested. If Y now contains an all-zero word, the PC is incremented by one to effect skipping the next instruction. If the contents of Y, after being incremented, are other than zero, the next instruction is executed. The previous contents of Y are lost; the contents of the AC are unchanged. Symbolic: If $$Y + 1 = 0$$ , $PC + 1 \longrightarrow PC$ $Y + 1 \longrightarrow Y$ . # Unconditional Jump JMP Mnemonic: JMP Octal Code: 60 Time: 1 cycle Operation: The next instruction is read from the contents of the effectively addressed memory register, Y, thereby breaking the existing program sequence and starting a new sequence from Y. The previous contents of the PC are lost as the effective address enters the PC. The contents of the AC are unchanged. Symbolic: "Y" (bits 5-17) → PC Mnemonic: JMS Octal Code: 10 Time: 2 cycles Operation: The contents of the PC and of the link, and the status (on or off) of the extend mode and of the memory protect mode are deposited in the effectively addressed memory register, Y. The next instruction is read from the contents of memory register Y + 1, breaking the previous program sequence and starting a new sequence from Y + 1. The contents of the AC are unchanged. Symbolic: $$L \longrightarrow Y_0$$ $EM \longrightarrow Y_1$ $MP \longrightarrow Y_2$ $PC \longrightarrow Y_{3-17}$ "Y" + 1 (bits 5-17) $\longrightarrow PC$ Mnemonic: CAL Octal Code: 00 Time: 2 cycles Operation: The CAL instruction is the equivalent of a JMS 20 instruction. The contents of the PC and of the link, and the status (on or off) of the extend memory mode and of the memory protect mode are deposited in memory register 20. The next instruction is read from the contents of memory register 21, breaking the previous program sequence and starting a new sequence from 21. The contents of the AC are unchanged. If the API option is present and enabled, priority level 4 will be activated after the execution of a CAL instruction. Symbolic: L $$\longrightarrow$$ 20<sub>0</sub> EM $\longrightarrow$ 20<sub>1</sub> MP $\longrightarrow$ 20<sub>2</sub> PC $\longrightarrow$ 20<sub>3-17</sub> "21" $\longrightarrow$ PC Execute the Instruction at Y XCT Mnemonic: XCT Octal Code: 40 Time: 1 cycle plus time of instruction at Y Operation: The computer executes the instruction located at the effectively addressed memory register, Y. The contents of the PC are unchanged unless Y contains a JMS, CAL, JMP, or skip instruction, each of which changes the contents of the PC to alter the program sequence. XCT could be thought of as a single-instruction subroutine causing a quasi-jump to Y, execution of the instruction specified there, and return to the program sequence (i.e., execution of the instruction following XCT) if the instruction at Y has not changed the PC. Symbolic: Y → IR #### OPERATE INSTRUCTIONS Operate instructions (operation code of 74<sub>8</sub>) are used to sense and/or alter the contents of the AC and link. Typical functions are: conditional or unconditional skips and complementing, setting, clearing, or rotating the contents of the two registers jointly or independently. A HLT instruction is included. Operates are fetched and executed in one machine cycle, the actions being specified by the microprogramming of the instruction code. Each of the 14 bits can effect an unique response; hence, they are "microinstructions" to the computer. The important feature of the operate class is its microprogramming capability where two or three microinstructions can be combined to form one instruction word and, therefore, be executed during one cycle. Those microinstructions that logically conflict and occur in the same event time should not be microprogrammed. Figure 7-3 illustrates the sequential event times and the microinstructions associated with each (the instructions are indicated by their mnemonics). The nature of rotate operations precludes the microprogramming of other microinstructions during the same event times. When noninverted skip actions are microprogrammed (bit 8 is 0), the conditions to be met are inclusively ORed. For example: if SZA (740200) and SNL (740400) are combined (740600), the skip takes place if either or both conditions are present (contents of the AC are 0, the content of the link is not 0). When invertedskip actions are microprogrammed (bit 8 is 1), the skip occurs only if the AND of the conditions is met. For example: when SNA (741200) and SZL (741400) are specified in a microprogrammed instruction (741600), the skip occurs only if both conditions are present (the contents of the AC are other than 0, the content of the link is 0). #### Programming Note: The PDP-9 Symbolic Assembler accepts either HLT or XX (see figure 7-3) as a valid mnemonic for the operate class instruction to stop program execution. The latter facilitates visual scanning of a program listing to determine the occurrence of program halts. Operation Code = 74<sub>8</sub> | , | ,c. ao. | | 8 | | | | | | Bit 7 | 7 = 0 | | | | |---|---------|-----|------------|------------|-----|-----|-----|------|-------|-------|-----|------|------------| | | CLA | CLL | Additional | 0 = OR of | SNL | | SMA | HLT | RAR | RAL | OAS | CAAI | $CM\Delta$ | | | | | Rotate | 1 = AND of | SZL | SNA | SPA | 1161 | RTR | RTL | ) | CML | CMA | | | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | Bit 7 | 7 = 1 | 15 | 16 | 17 | | | 1 | 10 - | ۱, ۵ | 10 11 | | | Event | | |-------------------|-----|------|------|-------|-------|---------------|----------|---------------------| | , | 0 2 | 3 5 | 6 8 | 9 11 | 12 14 | <b>1</b> 5 17 | Time | - | | OPR | 7 | 4 | 0 | 0 | 0 | 0 | _ | | | CMA | 7 | 4 | 0 | 0 | 0 | 1 | 3 | No other operation | | CML | 7 | 4 | 0 | 0 | 0 | 2 | 3 | may take place at | | OAS | 7 | 4 | 0 | 0 | 0 | 4. | 3 | the same event time | | RAL | 7 | 4 | 0 | 0 | 1 | 0 | 3 | as rotates. | | RAR | 7 | 4 | 0 | 0 | 2 | 0 | 3 | RAR, RAL may not be | | HLT XX | 7 | 4 | 0 | 0 | 4 | 0 | <u>.</u> | combined with: | | SMA | 7 | 4 | 0 | 1 | 0 | 0 | 1 | OAS, CML, CMA. | | SZA | 7 | 4 | 0 | 2 | 0 | 0 | 1 | | | SNL<br>SML | 7 | 4 | 0 | 4 | 0 | 0 | 1 | RTR,RTL may not be | | SKP | 7 | 4 | 1 | 0 | 0 | 0 | 1 | combined with: | | SPA | 7 | 4 | 1 | 1 | 0 | 0 | 1 | CLA,CLL,OAS, | | SNA | 7 | 4 | 1 | 2 | 0 | 0 | 1 | CML, CMA. | | SZL<br>SPL | 7 | 4 | 1 | 4 | 0 | 0 | 1 | | | RTL | 7 | 4 | 2 | 0 | 1 | 0 | 2,3 | | | RTR | 7 | 4 | 2 | 0 | 2 | 0 | 2,3 | | | CLL | 7 | 4 | 4 | 0 | 0 | 0 | 2 | | | (CLL-CML) STL CCL | 7 | 4 | 4 | 0 | 0 | 2 | 2,3 | | | (CLL-RAL) RCL | 7 | 4 | 4 | 0 | 1 | 0 | 2,3 | | | (CLL-RAR) RCR | 7 | 4 | 4 | 0 | 2 | 0 | 2,3 | | | CLA | 7 | 5 | 0 | 0 | 0 | 0 | 2 | | | (CLA-CMA) CLC | 7 | 5 | 0 | 0 | 0 | 1 | 2,3 | | | (CLA-OAS) LAS LAT | 7 | 5 | 0 | 0 | 0 | 4 | 2,3 | | | (CLA-RAL) GLK | 7 | 5 | 0 | 0 | Ī | 0 | 2,3 | | Figure 7-3 Operate Instructions ## No Operation NOP Mnemonic: NOP Octal Code: 740000 Time: 1 cycle Operation: The program delays for one cycle before the next instruction is fetched. As a "do nothing" cycle, NOP can be used to synchronize program timing to peripheral timing by delaying execution of an instruction until the appropriate time. Symbolic: Not applicable ## Complement Accumulator CMA Mnemonic: CMA Octal Code: 740001 Time: 1 cycle Operation: Each bit of the AC is set or cleared to the inverse of its current state. The previous contents of the AC are lost. Symbolic: $\overline{AC} \longrightarrow AC$ ## Complement Link CML Mnemonic: CML Octal Code: 740002 Time: 1 cycle Operation: The link is set or cleared to the inverse of its current state. Its previous content is lost. Symbolic: Ū → L #### Inclusive OR ACCUMULATOR Switches OAS Mnemonic: OAS Octal Code: 740004 Time: 1 cycle Operation: The word set up by manual positioning of the ACCUMULATOR switches is inclusively ORed with the contents of the AC on a bit-by-bit basis. The result is left in the AC. If corresponding AC and AC switch bits are in the binary 0 state, the AC bit remains 0. If either or both of the corresponding bits are in the binary 1 state, the AC bit is set to 1. The previous contents of the AC are lost. The switch settings are not affected. Symbolic: AC V AC Switch — AC ## Rotate AC and Link Left RAL Mnemonic: RAL Octal Code: 740010 Time: 1 cycle Operation: The contents of the AC and the link are rotated one bit position to the left with $AC_0$ entering the link and the link entering $AC_{17}$ . Symbolic: $$AC_{i} \longrightarrow AC_{i-1; i=1,17}$$ $$AC_{0} \longrightarrow L$$ $$L \longrightarrow AC_{17}$$ # Rotate AC and Link Right RAR Mnemonic: RAR Octal Code: 740020 Time: 1 cycle Operation: The contents of the AC and the link are rotated one bit position to the right with AC $_{17}$ entering the link and the link entering AC $_{0}$ . Symbolic: $$AC_{i} \longrightarrow AC_{i+1; i=0,16}$$ $AC_{17} \longrightarrow L$ $L \longrightarrow AC_{0}$ ## Halt Program **HLT** Mnemonic: HLT (see programming note, page 7-8) Octal Code: 740040 Time: 1 cycle Operation: Program execution stops at completion of the current machine cycle. The PGRM STOP indicator is lighted. Symbolic: 0 → RUN flip-flop ## Skip on Minus Accumulator SMA Mnemonic: SMA Octal Code: 740100 Time: 1 cycle Operation: Test the contents of the sign bit, $AC_0$ , of the data word in the AC. If the bit is in the binary I state, the contents of the PC are incremented by one to effect skipping the next instruction. If $AC_0$ is found to be in the 0 state, the next instruction is executed. The contents of the AC are unchanged. Symbolic: If $AC_0 = 1$ , $PC + 1 \longrightarrow PC$ # Skip on Zero Accumulator SZA Mnemonic: SZA Octal Code: 740200 Time: 1 cycle Operation: Test the contents of the word in the AC. If all bits are binary 0s, the quantity is taken to be zero (2s complement notation), and the contents of the PC are incremented by one to effect skipping the next instruction. If any bit is in the binary 1 state, the next instruction is executed. The contents of the AC are unchanged. Symbolic: If AC = 0, PC + 1 --- PC ### Skip on Non-zero Link SNL Mnemonic: SNL Octal Code: 740400 Time: 1 cycle Operation: Test the content of the link. If the link is in the binary 1 state, the contents of the PC are incremented by one to effect skipping the next instruction. If the link has a binary 0, the next instruction is executed. The content of the link is unchanged. Symbolic: If L = 1, $PC + 1 \longrightarrow PC$ ## Unconditional Skip SKP Mnemonic: SKP Octal Code: 741000 Time: 1 cycle Operation: The contents of the PC are incremented by one to effect an unconditional skip of the next instruction. Symbolic: PC + 1 ----> PC ## Skip on Positive Accumulator SPA Mnemonic: SPA Octal Code: 741100 Time: 1 cycle Operation: Test the contents of the sign bit, AC, for a data word in the AC. If the bit is in the binary O state, the quantity in the AC is taken to be positive. Therefore, the contents of the PC are incremented by one to effect skipping the next instruction. If the bit is found to be in the binary 1 state, the next instruction is executed. The contents of the AC are unchanged. Symbolic: If $AC_0 = 0$ , $PC + 1 \longrightarrow PC$ ## Skip on Non-zero Accumulator SNA Mnemonic: SNA Octal Code: 741200 Time: 1 cycle Operation: Test the contents of the data word in the AC. If any bit is in the binary 1 state, the quantity is taken to be unequal to zero (2s complement notation only), and the contents of the PC are incremented by one to effect skipping of the next instruction. If all bits are found to be in the 0 state, the quantity is considered to be zero and the next instruction is executed. The contents of the AC are unchanged. Symbolic: If $AC \neq 0$ , $PC + 1 \longrightarrow PC$ ### Skip on Zero Link SZL Mnemonic: SZL Octal Code: 741400 Time: 1 cycle Operation: Test the contents of the link. If the link is in the binary 0 state, the contents of the PC are incremented by one to effect skipping the next instruction. If the link has a binary 1, the next instruction is executed. The content of the link is unchanged. Symbolic: If L = 0, $PC + 1 \longrightarrow PC$ #### Rotate AC and Link Two Left RTL Mnemonic: RTL Octal Code: 742010 Time: 1 cycle Operation: The contents of the AC and the link are rotated two bit positions to the left with $AC_0$ entering $AC_{17}$ , $AC_1$ entering the link, and the link entering $AC_{16}$ . Symbolic: $$AC_{i} \longrightarrow AC_{i-2; i} = 2,17$$ $L \longrightarrow AC_{16}$ $AC_{0} \longrightarrow AC_{17}$ $AC_{1} \longrightarrow L$ ## Rotate AC and Link Two Right RTR Mnemonic: RTR Octal Code: 742020 Time: 1 cycle Operation: The contents of the AC and the link are rotated two bit positions to the right with the link entering $AC_{17}$ , $AC_{17}$ entering $AC_{07}$ , and $AC_{16}$ entering the link. Symbolic: $AC_{j} \longrightarrow AC_{j+2; j=0,15}$ $C_{j} \longrightarrow AC_{1}$ $AC_{17} \longrightarrow AC_{0}$ $AC_{16} \longrightarrow L$ # Clear the Link CLL Mnemonic: CLL Octal Code: 744000 Time: 1 cycle Operation: The content of the link is cleared to the binary 0 state. Symbolic: 0 → L STL Mnemonic: STL Octal Code: 744002 Time: 1 cycle Operation: A microcoded instruction equivalent to CLL+CML. The link is first cleared to contain a binary 0; it is then complemented to contain a binary 1. Symbolic: 1 → L # Clear Link, Then Rotate AC and L Left **RCL** Mnemonic: RCL Octal Code: 744010 Time: 1 cycle Operation: A microcoded instruction equivalent to CLL+RAL. The link is first cleared to the binary 0 state; then the contents of the AC and the link are rotated one bit position to the left. Symbolic: $$AC_{i} \longrightarrow AC_{i-1;i=1,17}$$ $$AC_{0} \longrightarrow L$$ $$0 \longrightarrow AC_{17}$$ # Clear Link, Then Rotate AC and L Right **RCR** Mnemonic: RCR Octal Code: 744020 Time: 1 cycle Operation: A microcoded instruction equivalent to CLL+RAR. The link is first cleared to the binary 0 state; then the contents of the AC and the link are rotated one bit position to the right. Symbolic: $$AC_{i} \longrightarrow AC_{i+1;i=0,16}$$ $$AC_{17} \longrightarrow C_{0}$$ $$AC_{0} \longrightarrow AC_{0}$$ ## Clear the Accumulator CLA Mnemonic: CLA Octal Code: 750000 Time: 1 cycle Operation: Each bit of the AC is cleared to the binary 0 state. The previous contents are lost. Symbolic: 0 → AC ## Clear and Complement Accumulator CLC Mnemonic: CLC Octal Code: 750001 Time: 1 cycle Operation: A microcoded instruction equivalent to CLL+CMA. Each bit of the AC is cleared to the binary 0 state. Then each bit is set to the binary 1 state. The previous contents of the AC are lost. Symbolic: 777777 → AC ## Load AC from ACCUMULATOR Switches LAS Mnemonic: LAS Octal Code: 750004 Time: 1 cycle Operation: A microcoded instruction equivalent to CLA + OAS. Each bit of the AC is cleared to the binary 0 state. Then the word set up by manual positioning of the ACCUMULATOR switches is entered in the AC. The previous contents of the AC are lost. The switch settings are not affected. Symbolic: ACS → AC ## Get the Link **GLK** Mnemonic: GLK Octal Code: 750010 Time: 1 cycle Operation: A microcoded instruction equivalent to CLA + RAL. Each bit of the AC is cleared to the binary 0 state. Then the contents of the AC and the link are rotated one bit position left with the link contents entering AC<sub>17</sub>. The previous contents of the AC are lost. Symbolic: L → AC<sub>17</sub> 0 —▶ AC<sub>0-16</sub> Mnemonic: LAW Octal Code: 760000 + n Time: 1 cycle Operation: A single-cycle instruction that loads itself into the AC for the purpose of generating a number, n, of the range $0 \le n \le 17777_8$ . Following the fetch, the computer enters the contents of the MB (the LAW instruction word) in the AC. The previous contents of the AC are lost. Symbolic: MB → AC Some applications of the LAW instruction (figure 7-4) are: - 1. Loading an address for use in establishing indirect operand addressing (if extend mode off). - 2. Loading alphanumeric character codes in the AC for use with peripherals. - 3. Initializing word counters and/or current address registers. - 4. Presetting the real-time clock counter. Although the entire LAW instruction word is contained in the AC, only bits 5 through 17 can be employed to formulate the required quantity. Bits 0 through 4 serve as the operation code of the instruction. Figure 7-4 LAW Instruction PROGRAMMING NOTE: The PDP-9 Symbolic Assembler includes in its permanent symbol table the code for the mnemonic LAM (load minus accumulator). This code is equivalent to LAW 17777<sub>8</sub>. To generate a negative (1s complement) number in the AC, the user need only program a LAM-n instruction. After execution of the instruction, the quantity, n, will be present in 1s complement form in the AC. # INPUT/OUTPUT TRANSFER INSTRUCTIONS Input/output transfer (IOT) instructions initiate transmission of signals via the I/O bus to control peripheral devices, sense their status, and effect information transfers between them and the processor. A PDP-9 IOT instruction contains the following information (figure 7-5). - 1. An operation code of $70_{g}$ . - 2. An 8-bit device selection code to discriminate among up to 256 peripheral devices (selection logic in a device's I/O bus interface responds only to its preassigned code). In normal practice, bits 6 through 11 perform the primary device discrimination among up to 64 devices with bits 12 and 13 coded to select an operational mode or subdevice. - 3. A command code (bits 14 through 17) capable of being microprogrammed to clear the AC and issue up to three pulses via the I/O bus. Figure 7-5 IOT Instruction Format The four machine cycles required to execute an IOT instruction consist of the IOT fetch from core memory (memory is not accessed thereafter until completion of the IOT), and three sequential cycles of 1.0 µsec duration each, designated event times 1, 2, and 3 (figure 7-6). Bits 14 and 17 can be coded to initiate clearing of the AC and generation of an IOP1 pulse respectively, during event time 1. Bits 16 and 15 can be coded to initiate generation of IOP2 and IOP4 pulses during event times 2 and 3, respectively. IOT skip instructions are microprogrammed to produce an IOP1 pulse for testing a device status flag. IOP2 pulses are normally used to effect programmed transfers of information from a device to the processor. Because the AC serves as the data register for both "in" and "out" transfers, the "clear AC" microinstruction (bit 14) is usually microprogrammed with the IOP2 microinstruction; this combination effects clearing the AC during event time 1 prior to the IOP2 strobe of information into the AC during event time 2. IOP4 pulses are normally used to effect programmed transfers of information from the AC to a selected device. These conventions do not, however, preclude use of the IOP pulses to effect other external functions if the following restrictions are observed. #### The usual use of IOPs is: - IOP1 normally used in an I/O skip instruction to test a device flag. May be used as a command pulse but not to initiate either a "load of" or a "read from" a device. - IOP2 usually used to transfer data from the device to the computer, or to clear a device's information register. May not be used to determine a "skip" condition. - IOP4 usually used to transfer data from the computer to the device. May not be used to determine a "skip" condition. Figure 7-6 IOT Instruction Timing #### Programming Note: Execution of an IOT instruction and the next instruction in sequence cannot be interrupted; i.e., the PDP-9 will not grant an interrupt request until the instruction following an IOT (and which is not an IOT itself) has completed its function. This IOT (703302) is implemented on all PDP-9's. Its purpose is to clear the flags of any device that can call for I/O interrupt service. When the CAF instruction is issued, a pulse goes out on the I/O PWR CLR line of the I/O bus. Customer-installed equipment should also make use of this pulse for flags and registers which should be cleared for system initiation. (This pulse is also issued at power-on time and when the I/O RESET key is depressed.) #### EAE INSTRUCTIONS The extended arithmetic element option adds the hardware necessary to implement the EAE instructions. This class of instructions, identified by an operation code of 64<sub>8</sub>, performs high-speed data manipulation and multiply-divide operations as specified by microprogramming of individual instructions. Figure 7-7 illustrate the microinstruction capabilities for, respectively, register setup, data shift, normalize, multiply, and divide. ## a. EAE Setup Microinstructions ## b. EAE Shift Microinstructions Figure 7-7 EAE Instruction Formats #### c. EAE Normalize Microinstructions #### d. EAE Multiplication Microinstructions ### e. EAE Division Microinstructions Figure 7-7 EAE Instruction formats (continued) The time required to execute an EAE instruction is a function of the operation and/or the shift, or step, count specified by microprogramming (see table 7-2). In general, the following considerations apply to the different types of EAE operations. - 1. All setup instructions require two machine cycles (2.0 µsec). - 2. Long register shift instructions require a time equal to 2.0 µsec plus 0.4 µsec per "n" bit-position shifts, quantized up to next whole time integer. This count is specified by the addition of n (octal) to the instruction code. For example: the input of the symbolic instruction LLS+14 to the PDP-9 assembler would result in an instruction code that specified a long left shift of the AC and MQ (taken as a 36-bit register) 12<sub>10</sub> bit positions to the left. This instruction would require 8.0 µsec. - 3. The ALS and ALSS instruction, respectively, AC left shift and AC left shift signed, also require the specification of "n". - 4. The normalizing instructions, NORM and NORMS, require an execution time equal to 2.0 µsec plus 0.4 µsec per number of bit positions shifted to normalize ( $AC_0 \neq AC_1$ ) quantity. These instructions are microprogrammed to set the six-bit step count to $44_8$ ( $36_{10}$ ). Hence, $-44+n_8$ (the step count is entered in 2s complement notation at execution) equals the biased scale factor of a normalized quantity. - 5. Multiply instructions are microprogrammed to set the step count to 22<sub>8</sub> (18<sub>10</sub>), representing the multiplication of one 18-bit quantity (sign bit and 17 magnitude bits for signed quantities) by another to produce a 36-bit product. The execution time is 11.0 µsec. Where such precision is not required, the microprogrammed step count can be decreased by subtracting the appropriate number "n" (octal) from the instruction code. The product is always left justified in the AC, MQ. If "-n" is appended to a multiply instruction, the "n" low order bits in the long register are meaningless. - 6. Divide instructions are microprogrammed to set the step count to $23_8$ (19<sub>10</sub>), representing division of a 36-bit dividend (actual or implied) by an 18-bit divisor. The execution time is 12.0 µsec. Where such precision is not required, the microprogrammed step count can be decreased by subtracting the appropriate number "n" (octal) from the instruction code. For example, the symbolic instruction DIV-12 would result in a right-justified quotient with the most significant bit in $MQ_9$ . The execution time is decreased in correspondence to the decrease in the step count. Figure 7–8 and Table 7–2, which follows the discussions describing the EAE instructions, illustrate the micro-instructions of the EAE instructions. Should an existing instruction not suffice, the programmer may combine the appropriate microinstructions to achieve the required result. Figure 7-8 EAE Microinstructions #### **EAE** Setup ## Inclusive OR SC with AC OSC Mnemonic: OSC Octal Code: 640001 Time: 2 cycles Operation: The contents of the AC are inclusively ORed with the 6-bit contents of the step counter (SC) on a bit-by-bit basis. The result is left in AC<sub>12-17</sub>. If corresponding SC and AC bits are in the binary 0 state, the AC bit is cleared to 0. If either of the corresponding bits is in the binary 1 state, the AC bit is set to 1. The previous contents of the AC are lost. The contents of the SC are unchanged. Symbolic: SC V AC → AC | | | S | c <sub>i</sub> | | |-----------------|---|---|----------------|--| | Inclusive OR | | 0 | 1 | | | | 0 | 0 | 1 | | | AC <sub>i</sub> | 1 | 1 | 1 | | ## Inclusive OR MQ with AC OMQ Mnemonic: OMQ Octal Code: 640002 Time: 2 cycles Operation: The contents of the MQ are inclusively ORed with the contents of the AC on a bit-by-bit basis. The result is left in the AC. If corresponding MQ and AC bits are in the binary 0 state, the AC bit is cleared to 0. If either of the corresponding bits is in the binary 1 state, the AC bit is set to 1. The previous contents of the AC are lost. The contents of the MQ are unchanged. Symbolic: MQ V AC → AC ## Complement MQ CMQ Mnemonic: CMQ Octal Code: 640004 Time: 2 cycles Operation: Each bit of the MQ is set or cleared to the inverse of its current state. The previous contents of the MQ are lost. Symbolic: $\overline{MQ} \longrightarrow MQ$ ## Load AC from MQ **LACQ** Mnemonic: LACQ Octal Code: 641002 Time: 2 cycles Operation: This microcoded instruction clears each bit of the AC to 0 and then enters the contents of the MQ in the AC. The previous contents of the AC are lost. The contents of the MQ are unchanged. Symbolic: MQ → AC ## Load AC from SC **LACS** Mnemonics: LACS Octal Code: 641001 Time: 2 cycles Operation: This microcoded instruction clears each bit of the AC to 0 and then enters the contents of the SC in $AC_{12-17}$ . The previous contents of the AC are lost. The contents of the SC are unchanged. Symbolic: SC → AC #### Clear MQ CLQ Mnemonics: CLQ Octal Code: 650000 Time: 2 cycles Operation: Each bit of the MQ is cleared to 0. The previous contents of the MQ are lost. Symbolic: 0 → MQ ## Load AC with Absolute Value to AC ABS Mnemonic: ABS Octal Code: 644000 Time: 2 cycles Operation: A microcoded instruction which complements the contents of the AC (1s complement notation) if the contents of $AC_{\Omega}$ are 1. Symbolic: If $AC_0 = 1$ , $\overline{AC} \longrightarrow AC$ ## Get Sign and Magnitude of AC **GSM** Mnemonic: GSM Octal Code: 664000 Time: 2 cycles Operation: A microcoded instruction which enters the contents of $AC_0$ in the link, and then complements the contents of the AC (1s complement notation) if $AC_0$ is a 1. The previous content of the link is lost. Symbolic: $AC_0 \longrightarrow L$ If $AC_0 = 1$ , $\overline{AC} \longrightarrow AC$ Load MQ LMQ Mnemonic: LMQ Octal Code: 652000 Time: 2 cycles Operation: A microcoded instruction which clears each bit of the MQ to 0 and then enters the contents of the AC in the MQ. The previous contents of the MQ are lost. The contents of the AC are unchanged. Symbolic: AC → MQ ## Basic EAE Instruction Mnemonic: EAE+n Octal Code: 640000 Time: 2 cycles Operation: The addition of "n" (octal) to the EAE mnemonic converts the basic instruction into a micro-coded instruction to accomplish a setup, shift, or arithmetic operation not already in the instruction repertoire. Refer to table 6-3 for descriptions of the functional use of the individual bits of an EAE instruction. The sole restriction for the development of "n" is that the microcoded operations must not occur during the same event time if they logically conflict. Symbolic: not applicable TABLE 7-1 EAE OPERATION TIMES | Bit Positions<br>Shifted | Multiply or<br>Divide, Unsigned | Multiply or<br>Divide, Signed* | All Shifts or<br>Normalize | |--------------------------|---------------------------------|--------------------------------|----------------------------| | 0 | 3 cycles | 5 cycles | 2 cycles | | 1,2,3 | 5 cycles | 7 cycles | 4 cycles | | 4,5,6 | 6 cycles | 8 cycles | 5 cycles | | 7,8,9 | 7 cycles | 9 cycles | 6 cycles | | 10,11,12 | 9 cycles | 11 cycles | 8 cycles | | 13, 14, 15 | 10 cycles | 12 cycles | 9 cycles | | 16, 17, 18 | 11 cycles | 13 cycles | 10 cycles | | 19,20,21 | 12 cycles (divide) | 14 cycles (divide) | 11 cycles | | 22,23,24 | • | • | 12 cycles | | 25,26,27 | | | 14 cycles | | 28,29,30 | | | 15 cycles | | 31,32,33 | | | 16 cycles | | 34,35,36 | | | 17 cycles | <sup>\*</sup>Signed multiply producing a positive signed product requires the number of cycles equivalent to unsigned multiply. Signed divide producing a negative signed quotient with positive signed remainder, if any, requires the number of cycles equivalent to unsigned divide. ## Long Right Shift **LRS** Mnemonic: LRS n Octal Code: (640500)+n Time: see table Operation: The AC and the MQ function as a 36-bit register to permit serial shifting of their contents "n" bit positions to the right, "n" being specified by the contents of the six low order bits of the instruction word. Shifting halts when the contents of the step counter, initialized to the 2s complement of "n", reach zero. For each shift step, the contents of AC<sub>17</sub> enter MQ<sub>0</sub> and the contents shifted out of MQ<sub>17</sub> are lost. The contents of the link, usually initialized to zero, remains unchanged and enters AC<sub>0</sub> at each step to replace the contents of vacated bits. Symbolic: $$(AC-MQ)_{j}$$ $\longrightarrow$ $(AC-MQ)_{j+n}$ , $j = 0$ , $35-n$ $(AC-MQ)_{j}$ $\longrightarrow$ Lost; $j = 36-n$ , $35$ $L$ $\longrightarrow$ $(AC-MQ)_{j}$ ; $j = 0$ , $n-1$ $0$ $\longrightarrow$ SC ## Long Right Shift, Signed LRSS n Mnemonic: LRSS n Octal Code: (660500) +n Time: see table Operation: The content of $AC_0$ is entered in the link. Then, the AC and the MQ function as a 36-bit register to permit serial shifting of their contents "n" bit positions to the right, "n" being specified by the contents of the six low order bits of the instruction word. Shifting halts when the contents of the step counter, initialized to the 2s complement of "n", reach zero. For each shift step, the contents of $AC_{17}$ enter $AC_0$ and the contents shifted out of $AC_{17}$ are lost. The content of the link remains unchanged and enters $AC_0$ at each step to replace the contents of vacated bits. Symbolic: $$AC_0 \longrightarrow L$$ $(AC-MQ)_i \longrightarrow (AC-MQ)_{i+n}; i = 0, 35-n$ $(AC-MQ)_i \longrightarrow Lost; i = 36-n, 35$ $L \longrightarrow (AC-MQ)_i; i = 0, n-1$ $0 \longrightarrow SC$ Mnemonic: LLS n Octal Code: (640600) +n Time: see table Operation: The AC and the MQ function as a 36-bit register to permit serial shifting of their contents "n" bit positions to the left, "n" being specified by the contents of the six low order bits of the instruction word. Shifting halts when the contents of the step counter, initialized to the 2s complement of "n", reach zero. For each shift step, the contents of $MQ_0$ enter $AC_{17}$ and the contents shifted out of $AC_0$ are lost. The content of the link, usually initialized to zero, remains unchanged and enters $MQ_{17}$ at each step to replace the contents of vacated bits. Symbolic: $$(AC-MQ)_{i}$$ $\longrightarrow$ $(AC-MQ)_{i-n}$ ; $i = n$ , 35 $(AC-MQ)_{i}$ $\longrightarrow$ Lost; $i = 0$ , $n-1$ $L$ $\longrightarrow$ $(AC-MQ)_{i}$ ; $i = 36-n$ , 35 Long Left Shift, Signed LLSS n Mnemonic: LLSS n Octal Code: (660600) +n Time: see table Operation: The content of $AC_0$ is entered in the link. Then, the AC and MQ function as a serial 36-bit register to permit serial shifting of their contents "n" bit positions to the left, "n" being specified by the contents of the six low order bits of the instruction word. Shifting halts when the contents of the step counter, initialized to the 2s complement of "n", reach zero. For each shift step, the contents of $MQ_0$ enter $AC_{17}$ and the contents shifted out of $AC_0$ are lost. The content of the link remains unchanged and enters $MQ_{17}$ at each step to replace the contents of vacated bits. Symbolic: $$AC_0 \longrightarrow L$$ $(AC-MQ)_i \longrightarrow (AC-MQ)_{j-n}; j = n, 35$ $(AC-MQ)_i \longrightarrow Lost; j = 0, n-1$ $L \longrightarrow (AC-MQ)_i; j = 36-n, 35$ $0 \longrightarrow SC$ #### Accumulator Left Shift ALS n Mnemonic: ALS n Octal Code: (640700) +n Time: see table Operation: The contents of the AC are shifted "n" bit positions to the left, "n" being specified by the contents of the six low order bits of the instruction word. Shifting halts when the contents of the step counter, initialized to the 2s complement of "n", reach zero. For each shift step, the content of the link, usually initialized to zero, enters AC<sub>17</sub> to replace the contents of vacated bits. The contents shifted out of AC<sub>0</sub> are lost. Symbolic: $$AC_{j-n}$$ ; $j = n$ , 17 $AC_{j-n}$ ; $j = n$ , 17 $AC_{j-n}$ ; $j = 0$ , $n-1$ $AC_{j}$ ; $j = 18-n$ , 17 $O \longrightarrow SC$ # Accumulator Left Shift, Signed ALSS n Mnemonic: ALSS n Octal Code: (660700) +n Time: see table Operation: The content of $AC_0$ enters the link. Then, the contents of the AC are shifted "n" bit positions to the left, "n" being specified by the contents of the six low order bits of the instruction word. Shifting halts when the contents of the step counter, initialized to the 2s complement of "n", reach zero. For each shift step, the content of the link remains unchanged and enters $AC_{17}$ to replace the contents of vacated bits The contents shifted out of $AC_0$ are lost. Symbolic: $$AC_0 \longrightarrow L$$ $AC_i \longrightarrow AC_{i-n}$ ; $i = n, 17$ $AC_i \longrightarrow Lost$ ; $i = 0, n-1$ $L \longrightarrow AC_i$ ; $i = 18-n, 17$ $0 \longrightarrow SC$ Normalize NORM Mnemonic: NORM Octal Code: 640444 Time: see table Operation: The contents of the AC and the MQ are shifted left (i.e., leading zeros are shifted out) with the AC and MQ functioning as a serial 36-bit register until: Either the content of AC<sub>0</sub> does not agree with the content of AC<sub>1</sub>; i.e., the bits differ in their binary states. $\overline{OR}$ the contents of the step counter reach zero. This six-bit counter is initialized to the 2s complement of 44<sub>8</sub> (36<sub>10</sub> steps). The contents of the six low order bits of the NORM instruction word specify the step count. For each shift step, the contents of $\overline{MQ}_0$ enter $\overline{AC}_{17}$ and the contents shifted out of $\overline{AC}_0$ are lost. The content of the link, usually initialized to zero, enters $\overline{MQ}_{17}$ to replace the contents of vacated bits. If shifting halts because $\overline{AC}_0$ does not equal $\overline{AC}_1$ , the contents of the step counter reflect the number of steps executed to reach the condition. The counter's contents (2s complement of the step count plus the steps executed) are accessible through use of the OSC or LACS instruction. Symbolic: $n = number of steps required to normalize = <math>36_{10}$ maximum $$(AC-MQ)_{i}$$ $\longrightarrow$ $(AC-MQ)_{i-n}$ ; $i = n$ , 35 $(AC-MQ)_{i}$ $\longrightarrow$ Lost; $i = 0$ , $n-1$ L $\longrightarrow$ $(AC-MQ)_{i}$ ; $i = 36-n$ , 35 $(-44_8 + n)$ $\longrightarrow$ SC #### Programming Note: Although a NORM or NORMS (normalize, signed) instruction cannot be interrupted by a program or automatic priority interrupt request, the intent of its execution can be interrupted before completion; i.e., the central processor can grant an interrupt request after the normalization of a quantity but before the quantity and its representative step count have been completely extracted from the EAE registers and processed. Hence, if interrupt-accessed subroutines are to make use of the EAE, the following instruction sequences can be included to preserve the register contents during the interrupt and to restore them in the EAE at completion of the interrupt service. /SAVE EAE REGISTERS DURING INTERRUPT JMS SUBENTR SUBENTR, DAC ACSAVE LACQ DAC MQSAVE LASC /MOVE MQ TO AC /MOVE MQ CONTENTS /MOVE STEP COUNT TO AC | DAC SCSAVE | /SAVE STEP COUNT | |---------------|----------------------------| | • | | | • | | | • | | | LAC SCSAVE | | | XOR (77 | COMPLEMENT STEP COUNT | | TAD (640402 | DEVELOP PSUEDO NORM | | AND (640477 | DELETE POSSIBLE STEP COUNT | | | /OVERFLOW | | DAC.+1 | /PLACE NORM IN SEQUENCE | | HLT* | STEP COUNT TO SC | | LAC MQSAVE | , | | LMQ | /LOAD MQ | | LAC ACSAVE | /LOAD AC | | DBR | RESTORE PC, LINK, ETC. | | JMP I SUBENTR | • | Restoration of the step count to the step counter requires that the 2s complemented quantity, taken from the SC at the time of interrupt, be complemented and then combined with the psuedo NORM instruction. The step count at this point is one less than the actual value produced by the previous normalization. Execution of the NORM instruction, however, transfers the 2s complemented step count to the SC and in shifting the AC and the MQ left one bit position (the 6404XX present in the AC shifts to become 501XXX) adds the necessary one to the SC to produce the correctly restored step count. The DBR instruction (which precedes the JMP I subroutine termination) primes the computer for restoration of the interrupted program. Such restoration occurs during the JMP I instruction. During this time, the PC and the Link are restored to the contents existing at the time of the interrupt, and the options of memory protection and extended memory, if in the system, are restored to their status (on or off) at the time of interrupt. The DBR instruction is fully described in chapter 8 under the discussion of the optional multilevel automatic priority interrupt system. DBR is a basic machine instruction. <sup>\*</sup> Good programming practice dictates that instructions to be developed at "run" time be represented by HLT instructions in the source program. If the development does not occur, the HLT will facilitate debugging of the program. Mnemonic: NORMS Octal Code: 660444 Time: see table Operation: The contents of AC<sub>0</sub> enter the link. Then, the contents of the AC and the MQ are shifted left (i.e., leading zeros are shifted out) with the AC and MQ functioning as a serial 36-bit register until: Either the contents of $AC_0$ do not agree with the contents of $AC_1$ ; i.e., the bits differ in their binary states. Or the contents of the step counter reach zero. This counter is initialized to the 2s complement of $44_8$ ( $36_{10}$ steps). The contents of the six low order bits of the NORMS instruction word specify the step count. For each shift step, the content of $MQ_0$ enters $AC_{17}$ and the content shifted out of $AC_0$ are lost. The content of the link enters $MQ_{17}$ to replace the contents of vacated bits. If shifting halts because $AC_0$ does not equal $AC_1$ , the contents of the step counter reflect the number of steps executed to reach the condition. The counter's contents (2s complement of the step count plus the steps executed) are accessible through use of the OSC or LACS instruction. Symbolic: $$AC_0 \longrightarrow L$$ $n = \text{number of steps required to normalize} = 36$ $(AC-MQ)_i \longrightarrow (AC-MQ)_{j-n}; j = n, 35$ $(AC-MQ)_i \longrightarrow Lost; j = 0, n-1$ $L \longrightarrow (AC-MQ)_i; j = 36=n, 35$ $(-44_8 + n \longrightarrow) SC$ #### Programming Note: Refer to the note below the description of the NORM instruction for restoration of the step counter contents following an interrupt. ## Multiply (unsigned) MUL Mnemonic: MUL Octal Code: 653122 Time: 11 cycles Operation: Multiply the contents of memory register Y (the multiplicand) by the contents of the MQ (the multiplier), and place the resulting 36-bit product in the AC and the MQ with the more significant half appearing in the AC. The address of Y is taken to be sequential to the address of the MUL instruction word. Prior to this instruction, the contents of the link must be zero and the multiplier must be entered in the AC. During the setup phase of MUL, the multiplier is transferred to the MQ, the AC is cleared to zero, and the step counter is initialized to the 2s complement of 22<sub>8</sub> (18<sub>10</sub> steps); the six low order bits of the instruction word specify the step count. The arithmetic phase, executed as multiplication of one unsigned quantity by another (18 bits, binary point of no consequence), halts when the step counter counts up to zero. The content of the link remains zero. The contents of Y are unchanged. The program resumes at the next instruction (memory register Y + 1). Data Structure: $C = A \cdot B$ #### Pre-execution #### Instruction Sequence: | Register | Contents | |----------|------------------| | Y - 2 | LAC Multiplier | | Y - 1 | MUL | | Υ | Multiplicand | | Y + 1 | Next Instruction | Mnemonic: MULS Octal Code: (657122) Time: 13 cycles (11 cycles for positive signed product) Operation: Multiply the contents of memory register Y (the multiplicand) by the contents of the MQ (the multiplier), and place the signed product in the AC and MQ with the sign notation and more significant portion in the AC. Bits AC<sub>0</sub> and AC<sub>1</sub> each receive the sign of the product; the remaining AC and MQ bits represent the magnitude of the product in 1s complement form. The address of Y is taken to be sequential to the address of the MULS instruction word. The contents of Y are taken to be the absolute value of the multiplicand; the contents of the link are taken to be the original sign of the multiplicand (MULS assumes previous execution of an EAE GSM instruction, q.v.). Just prior to this MULS instruction, the multiplier must be entered in the AC. During the setup phase of the MULS instruction the multiplier is transferred to the MQ and 1s complemented if negative, the AC is cleared to zero, and the step counter is initialized to the 2s complement of 22<sub>8</sub> (18<sub>10</sub> steps); the six low order bits of the MULS instruction word specify the step count. The arithmetic phase, executed as multiplication of one signed quantity by another (sign bit plus 17 magnitude bits, binary point position of no consequence), halts when the step counter counts up to zero. The link is cleared to zero. The contents of Y are unchanged. The program resumes at the next instruction (memory register Y + 1). Data Structure: $C = |A| \cdot B$ Pre-execution \*original sign of A Post Execution S = L + Sign B ### Instruction Sequence: | Register | Contents | |----------|-------------------------------------------------| | Y - 5 | LAC Multiplicand | | Y - 4 | GSM (take absolute value and save sign in link) | | Y - 3 | DAC Y | | Y - 2 | LAC Multiplier | | Y - 1 | MULS | | Υ | Multiplicand (absolute value) | | Y + 1 | Next Instruction | Divide (unsigned) DIV Mnemonic: DIV Octal Code: (640323) Time: 12 cycles Operation: Divide the contents of the AC and the MQ (an unsigned 36-bit dividend) by the contents of memory register Y (the divisor). The resulting quotient appears in the MQ; the remainder is in the AC. The address of Y is taken to be sequential to the address of the DIV instruction word. Prior to this, the contents of the link must be zero, and the dividend must be entered in the AC and MQ (LAC least significant half, LMQ, LAC most significant half). If the divisor is not greater than the AC portion of the dividend, divide overflow occurs (magnitude of quotient exceeds the 18-bit capacity of the MQ), and the link is set to one to signal the overflow condition; data in the AC and the MQ are of no value. A valid division halts when the step counter, initialized to the 2s complement of 23<sub>8</sub> (19<sub>10</sub> steps), counts up to zero (the six low order bits of the DIV instruction word specify the step count). The contents of the Y are unchanged. The program resumes at the next instruction (memory register Y + 1). Symbolic: If $$Y \le AC$$ , $1 \longrightarrow L$ If $Y > AC$ , $0 \longrightarrow SC$ (AC, MQ)/Y $\longrightarrow MQ$ (quotient), AC (remainder) $0 \longrightarrow L$ PC + 2 $\longrightarrow PC$ Mnemonic: MULS Octal Code: (657122) Time: 13 cycles (11 cycles for positive signed product) Operation: Multiply the contents of memory register Y (the multiplicand) by the contents of the MQ (the multiplier), and place the signed product in the AC and MQ with the sign notation and more significant portion in the AC. Bits AC<sub>0</sub> and AC<sub>1</sub> each receive the sign of the product; the remaining AC and MQ bits represent the magnitude of the product in 1s complement form. The address of Y is taken to be sequential to the address of the MULS instruction word. The contents of Y are taken to be the absolute value of the multiplicand; the contents of the link are taken to be the original sign of the multiplicand (MULS assumes previous execution of an EAE GSM instruction, q.v.). Just prior to this MULS instruction, the multiplier must be entered in the AC. During the setup phase of the MULS instruction the multiplier is transferred to the MQ and 1s complemented if negative, the AC is cleared to zero, and the step counter is initialized to the 2s complement of 22<sub>8</sub> (18<sub>10</sub> steps); the six low order bits of the MULS instruction word specify the step count. The arithmetic phase, executed as multiplication of one signed quantity by another (sign bit plus 17 magnitude bits, binary point position of no consequence), halts when the step counter counts up to zero. The link is cleared to zero. The contents of Y are unchanged. The program resumes at the next instruction (memory register Y + 1). Data Structure: $C = |A| \cdot B$ Pre-execution \*original sign of A Post Execution $S = L \rightarrow Sign B$ ### Instruction Sequence: | Register | Contents | |----------|-------------------------------------------------| | Y - 5 | LAC Multiplicand | | Y - 4 | GSM (take absolute value and save sign in link) | | Y - 3 | DAC Y | | Y - 2 | LAC Multiplier | | Y - 1 | MULS | | Υ | Multiplicand (absolute value) | | Y + 1 | Next Instruction | Divide (unsigned) DIV Mnemonic: DIV Octal Code: (640323) Time: 12 cycles Operation: Divide the contents of the AC and the MQ (an unsigned 36-bit dividend) by the contents of memory register Y (the divisor). The resulting quotient appears in the MQ; the remainder is in the AC. The address of Y is taken to be sequential to the address of the DIV instruction word. Prior to this, the contents of the link must be zero, and the dividend must be entered in the AC and MQ (LAC least significant half, LMQ, LAC most significant half). If the divisor is not greater than the AC portion of the dividend, divide overflow occurs (magnitude of quotient exceeds the 18-bit capacity of the MQ), and the link is set to one to signal the overflow condition; data in the AC and the MQ are of no value. A valid division halts when the step counter, initialized to the 2s complement of 23<sub>8</sub> (19<sub>10</sub> steps), counts up to zero (the six low order bits of the DIV instruction word specify the step count). The contents of the Y are unchanged. The program resumes at the next instruction (memory register Y + 1). Symbolic: If $$Y \le AC$$ , $1 \longrightarrow L$ If $Y > AC$ , $0 \longrightarrow SC$ (AC, MQ)/Y $\longrightarrow$ MQ (quotient), AC (remainder) $0 \longrightarrow L$ PC + 2 $\longrightarrow$ PC #### Instruction Sequence: | Register | | |----------|---------------------------------------| | Y - 4 | LAC Dividend (least significant half) | | Y - 3 | LMQ | | Y - 2 | LAC Dividend (most significant half) | | Y - 1 | DIV | | Υ | Divisor | | Y + 1 | Next instruction | Divide, Signed DIVS Mnemonic: DIVS Octal Code: (644323) Time: 14 cycles (13 cycles for negative signed quotient with positive signed remainder) Operation: Divide the contents of the AC and MQ (a 36-bit signed dividend with the sign in bits $AC_0$ and $AC_1$ and the remaining 34 bits devoted to magnitude) by the contents of memory register Y (the divisor). The resulting quotient appears in the MQ with the algebraically determined sign in bit $MQ_0$ and the magnitude (1s complement) in bits $MQ_{1-17}$ . The remainder is in the AC with bit $AC_0$ containing the sign of the dividend and bits $AC_{1-17}$ containing the magnitude (1s complement). The address of Y is taken to be sequential to the address of the DIVS instruction word. The contents of Y are taken to be the absolute value of the divisor; the contents of the link are taken to be the original sign of the divisor (DIVS assumes previous execution of an EAE GSM instruction, q.v.). Prior to this DIVS instruction, the dividend must be entered in the AC and MQ (LAC of least significant half, LMQ, and LAC of most significant half). The MQ portion of a negative dividend is 1s complemented prior to the division. If the divisor is not greater than the AC portion of the dividend, divide overflow occurs (magnitude of the quotient exceeds the 17-bit plus sign capacity of the MQ), and the link is set to one to signal the overflow condition; data in the AC and the MQ are of no value. A valid division halts when the step counter, initialized to the 2s complement of 23<sub>8</sub> (19<sub>10</sub> steps), counts up to zero (the six low order bits of the DIVS instruction word specify the step count). The content of the link is cleared to zero. The contents of Y are unchanged. The program resumes at the next instruction (memory register Y + 1). AC, MQ meaningless (S=Sign A) 0 (overflow) L 1 $(S=Sign A \lor L)$ Υ B 17 35 #### Instruction Sequence: | Register | Contents | | | |--------------|---------------------------------------|--|--| | Y - 7 | LAC Divisor | | | | Y - 6 | GSM | | | | Y <b>-</b> 5 | DAC Divisor in Y | | | | Y - 4 | LAC Dividend (lease significant half) | | | | Y - 3 | LMQ | | | | Y - 2 | LAC Dividend (most significant half) | | | | Y - 1 | IDIV | | | | Υ | Divisor (absolute value) | | | | Y + 1 | Next Instruction | | | Integer Divide (unsigned) IDIV Mnemonic: IDIV Octal Code: 653323 Time: 12 cycles Operation: Divide the contents of the AC and the MQ (AC is zero, MQ contains an 18-bit integer dividend) by the contents of memory register Y (the divisor). The resulting quotient appears in the MQ; the remainder is in the AC. The address of Y is taken to be sequential to the address of the IDIV instruction word. Prior to this instruction, the contents of the link must be zero, and the dividend must be entered in the AC (the setup phase of IDIV transfers the dividend to the MQ and clears the AC). Division overflow occurs only if division by zero is attempted, i.e., the quotient's magnitude will not exceed the 17 bit plus sign capacity of the MQ. The division halts when the step counter, initialized to the 2s complement of $23_8$ ( $19_{10}$ steps), counts up to zero (the six low order bits of the IDIV instruction word specify the step count). The content of the link is cleared to zero. The contents of Y are unchanged. The program resumes at the next instruction (memory register Y + 1). Integer Divide, Signed **IDIVS** Mnemonic: IDIVS Octal Code: 657323 Time: 14 cycles (13 cycles for negative signed quotient with positive signed remainder) Operation: Divide the contents of the AC and the MQ (AC is zero, MQ contains a signed integer dividend) by the contents of memory register Y (the divisor). The resulting quotient appears in the MQ with the algebraically determined sign in bit MQ<sub>0</sub> and the magnitude (1s complement) in bits MQ<sub>1-17</sub>. The remainder is in the AC with bit AC<sub>0</sub> containing the sign of the dividend and bits AC<sub>1-17</sub> containing the magnitude (1s complement). The address of Y is taken to be sequential to the address of the IDIVS instruction word. The contents of Y are taken to be the absolute value of the divisor; the contents of the link are taken to be the original sign of the divisor (IDIVS assumes previous execution of an EAE GSM instruction, q.v.). Prior to this IDIVS instruction, the dividend must be entered in the AC (the setup phase of IDIVS transfers the dividend to the MQ, clears the AC, and 1s complements the MQ if the dividend is negative). Divide overflow occurs only if division by zero is attempted; i.e., the quotient's magnitude will not exceed the 17-bit plus sign capacity of the MQ. The division halts when the step counter, initialized to the 2s complement of $23_8$ (19<sub>10</sub> steps), counts up to zero (the six low order bits of the IDIVS instruction word specify the step count). The contents of the link are cleared to zero. The contents of Y are unchanged. The program resumes at the next instruction (memory register Y + 1). Symbolic: 0 → SC MQ/Y → MQ (quotient), AC (remainder) 0 ---> L PC + 2 → PC Data Structure: A = |B|Q + r Pre-execution <sup>\*</sup>original sign of B Post Execution If Y = 0 (overflow) Instruction Sequence: | Register | Contents | |----------|-----------------------------------| | Y - 5 | LAC Divisor | | Y - 4 | GSM | | Y - 3 | DAC Divisor (absolute value) in Y | | Y - 2 | LAC Dividend | | Y - 1 | IDIVS | | Υ | Divisor (absolute value) | | Y + 1 | Next Instruction | Mnemonic: FRDIV Octal Code: 650323 Time: 12 cycles Operation: Divide the contents of the AC and the MQ (AC contains an 18-bit fractional dividend, MQ is zeroed at setup) by the contents of memory register Y (the divisor). The binary point is assumed at the left of AC<sub>0</sub>. The quotient appears in the MQ; the remainder is in the AC. The address of Y is taken to be sequential to the address of the FRDIV instruction word. Prior to this instruction, the contents of the link must be zero, and the dividend must be entered in the AC (the setup phase of FRDIV clears the MQ). If the divisor is not greater than the dividend, divide overflow occurs (magnitude of quotient exceeds the 18-bit capacity of the MQ), and the link is set to one to signal the overflow condition; data in the AC and the MQ are of no value. A valid division halts when the step counter, initialized to 23<sub>8</sub> (19<sub>10</sub> steps), counts up to zero (the six low order bits of the FRDIV instruction word specify the step count). The contents of the link remain zero. The contents of Y are unchanged. The program resumes at the next instruction (memory register Y + 1). Data Structure: A = BQ + r Pre-execution Post Execution (no overflow) (overflow) ### Instruction Sequence: | Register | Contents | |----------|------------------| | Y - 2 | LAC Dividend | | Y - 1 | FRDIV | | Υ | Divisor | | Y + 1 | Next Instruction | # Fraction Divide, Signed **FRDIVS** Mnemonic: FRDIVS Octal Code: 654323 Time: 14 cycles (13 cycles for negative signed quotient with positive signed remainder) Operation: Divide the contents of the AC and the MQ (AC contains a signed fractional dividend, MQ is zeroed at setup) by the contents of memory register Y (the divisor). The binary point is assumed between $AC_0$ and $AC_1$ . The resulting quotient appears in the MQ with the algebraically determined sign in bit $MQ_0$ and the magnitude (1s complement) in bits $MQ_{1-17}$ . The remainder is in the AC with bit $AC_0$ containing the original sign of the dividend and bits $AC_{1-17}$ containing the magnitude (1s complement). The address of Y is taken to be sequential to the address of the FRDIVS instruction word. The contents of Y are taken to be the absolute value of the divisor; the contents of the link are taken to be the original sign of the divisor (FRDIVS assumes previous execution of an EAE GSM instruction, q.v.). Prior to this FRDIVS instruction, the dividend must be entered in the AC (the setup phase of FRDIVS clears the MQ and 1s complements the dividend, if negative, prior to the division). If the divisor is not greater than the dividend, divide overflow occurs (magnitude of the quotient exceeds the 18-bit capacity of the MQ) and the link is set to one to signal the overflow condition. Data in the AC and the MQ are of no value. A valid division halts when the step counter, initialized to the 2s complement of $23_8$ ( $19_{10}$ steps), counts up to zero (the six low order bits of the FRDIVS instruction word specify the step count). The contents of the link are cleared to zero. The contents of Y are unchanged. The program resumes at the next instruction (memory register Y + 1). Symbolic: If $$Y \le |AC|$$ , $1 \longrightarrow L$ (divide overflow) If $Y > AC$ , $0 \longrightarrow SC$ $AC/Y \longrightarrow MQ$ (quotient), $AC$ (remainder) $0 \longrightarrow L$ $PC + 2 \longrightarrow PC$ Data Structure: A = |B|Q + r Pre-execution \*original sign of B Post Execution (no overflow) Instruction Sequence: | Register | Contents | |----------|-----------------------------------| | Y - 5 | LAC Divisor | | Y - 4 | GSM | | Y - 3 | DAC Divisor (absolute value) in Y | | Y - 2 | LAC Dividend | | Y - 1 | FRDIVS | | Υ | Divisor (absolute value) | | Y + 1 | Next Instruction | TABLE 7-2 EAE MICROINSTRUCTIONS | Bit<br>Positions | Binary<br>Code | Function | |------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | 1 | Enter the content of AC <sub>0</sub> in the link for signed operations. | | 5 | 1 | Clear the MQ. | | 6 | 1 | Read the content of $AC_0$ into the EAE AC sign register prior to carrying out a signed multiply and divide operation. | | 6,7 | 10 | Take the absolute value of the AC. Takes place after the content of $AC_0$ is read into the EAE AC sign register. | | 7 | 1 | Inclusive OR the AC with the MQ and read into MQ. | | 8 | 1 | Clear the AC. | | 9, 10, 11 | 000 | Setup. Accompanies code in bits 15, 16, and 17. | | 9, 10, 11 | 001 | Multiply. Causes the number in the MQ to be multiplied by the number in the memory location following this instruction. If the EAE AC sign register is 1, the MQ is complemented prior to multiplication. The exclusive OR of the EAE AC sign and the link is entered in the EAE sign register. | | | | The product is in the AC and MQ, with the lowest order bit in MQ bit 17. At completion of this instruction the link is cleared and if the EAE sign is 1, the AC and MQ are complemented. | | 9, 10, 11 | 010 | Unused operation code. | | 9, 10, 11 | 011 | Divide. Causes the 36-bit number in the AC and MQ to be divided by the 18-bit number in the memory register following the instruction. If the EAE AC sign is 1, the MQ is complemented prior to starting the division. The exclusive OR of AC <sub>0</sub> and the link is placed in the EAE sign register. The AC portion of the dividend must be less than the divisor or divide overflow occurs. In such cases, the link is set and divide does not occur. Otherwise, the link is cleared. At completion of this instruction, if the EAE sign was a 1, the MQ is complemented. Thus, the remainder has the sign of the dividend. | TABLE 7-2 EAE MICROINSTRUCTIONS (continued) | Bit<br>Positions | Binary<br>Code | Function | |------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 9, 10, 11 | 101 | Long right shift. Causes the AC and MQ to be shifted right together as a 36-bit register the number of times specified in the instruction. On each step the link fills AC bit 0, AC bit 17 fills MQ bit 0, and MQ bit 17 is lost. The link remains unchanged. | | 9, 10, 11 | 110 | Long left shift. Causes the AC and MQ to be shifted left together the number of times specified in the instruction. On each step, MQ bit 17 is filled by the link; the link remains unchanged. MQ bit 0 fills AC bit 17, and AC bit 0 is lost. | | 9, 10, 11 | 100 | Normalize. Causes the AC and MQ to be shifted left together until the step count is equaled or AC bit $0 \neq$ AC bit 1. MQ bit 17 is filled by the link; the link is not changed. The step count of this instruction is normally 44 (octal). When the step counter is read into the AC, it contains the number of shifts minus the initial shift count as a 2s complement 6-bit number. | | 9, 10, 11 | 111 | Accumulator left shift. Causes the AC to be shifted left<br>the number of times specified in the shift count. AC<br>bit 17 is filled by the link, but the link is unchanged. | | 12-17 | | Specify the step count for all EAE commands (9–11) except the setup command. | | 15 | 1 | On the setup command only, causes the MQ to be complemented. | | 16 | 1 | On the setup command only, causes the MQ to be inclusively ORed with the AC and the result placed in AC. | | 17 | 1 | On the setup command only, causes the AC to be inclusively ORed with the SC and the results placed in AC bits 12-17. | #### **CHAPTER 8** #### DATA FORMATS AND ARITHMETIC INFORMATION This chapter defines the possible formats for PDP-9 data words, and presents information basic to the accomplishment of arithmetic operations by the PDP-9. The information presented includes: explanations of the three possible notations for signed data (sign and magnitude, 1s complement, and 2s complement); a discussion of scaling considerations for fixed-point arithmetic; and descriptions of the addition and subtraction processes. The multiply and divide processes are presented in the "Mathematical Subroutines" section of the PDP-9 BASIC Software Reference Manual, DEC-9B-GSAA-D. This reference source also includes descriptions of single-and multi-precision arithmetic, plus use of the Basic Software floating-point arithmetic system. Subroutines in the PDP-9 arithmetic library take full advantage of the computing power of the Extended Arithmetic Element (EAE) when this option is included in a PDP-9 system. ### SIGNED DATA NOTATIONS The PDP-9 uses three notations to represent signed data. They are: sign and magnitude, 1s complement, and 2s complement. In each, bit 0, or the most significant bit of a single- or multi-precision data word, serves as the sign indicator: a 0 for a positive quantity, a 1 for a negative quantity. #### Sign and Magnitude Notation In the sign and magnitude notation, quantities of equal magnitude but opposite in sign differ only in the content of the sign indicator bit; i.e., the positive number will contain a 0 in bit 0, and the negative number will contain a 1 in bit 0. For example: Observe that conversion of a positive number to a negative number, and vice versa, requires only the sign bit be complemented; the magnitude bits are not affected. #### Complement Notations In both complement notations (1s and 2s), the sign indicator (bit 0) is 0 for positive quantities and 1 for negative quantities. The 1s complement of a quantity is equivalent to the logical complement of its magnitude and sign; i.e., all binary 1s are replaced by 0s and all binary 0s are replaced by 1s. The 2s complement of a quantity is equivalent to its 1s complement, plus the addition of one to the lowest order, or least significant, bit. Positive quantities in either notation have identical representations. For example: +15<sub>10</sub> is represented in a PDP-9 data word as in either 1s or 2s complement notation. The 1s complement of $-15_{10}$ is represented by The 2s complement of $-15_{10}$ appears as A quantity of zero has two representations in 1s complement notation: and The 2s complement notation has one representation for zero: Minus zero in 2s complement notation likewise appears in binary form as since complementing each bit and then adding one to the low order bit results in the propagation of an arithmetic carry through the entire word, as follows: is complemented to be with plus one The binary 1 carried out of the sign bit "overflows" the 18-bit capacity of the PDP-9 word. Since two identical representations of 0 would be ambiguous to the computer, convention has adopted one representation of 0 in 2s complement notation, namely +0. Typical PDP-9 instruction sequences for forming the 2s complement of any number are: | LAC Y | CLC | |--------|-------| | CMA | TAD Y | | TAD (1 | CMA | | DAC Y | DAC Y | The TAD (2s complement add) instruction must be used rather than the ADD (1s complement add) instruction as ADD permits an end-around carry into the low order bit. The following list indicates the representations in 1s and 2s complement notations of a range of numbers from +5 to -5; a five-bit word is used for simplicity. | Number 1s Complement | | 2s Complement | |----------------------|-------|----------------| | +5 | 00101 | 00101 | | +4 | 00100 | 00100 | | +3 | 00011 | 00011 | | +2 | 01000 | 00010 | | +1 | 00001 | 00001 | | +0 | 00000 | 00000 | | -0 | 11111 | Not considered | | -1 | 11110 | 11111 | | <b>-2</b> | 11101 | 11110 | | -2<br>-3 | 11100 | 11101 | | -4 | 11011 | 11100 | | <b>-</b> 5 | 11010 | 11011 | #### DATA WORDS The PDP-9 hardware and Basic Software capabilities include add, subtract, multiply, divide, etc., of data in single- and multi-precision formats. For signed data words, bit 0 serves as the sign indicator, with a 0 for a positive quantity, and a 1 for a negative quantity. #### Data Word Formats A signed single-precision data word includes a sign bit and 17 magnitude bits (figure 8-1a). A signed double-precision data word consists of two computer words for a total of 36 bits (figure 8-1b). The first word contains the sign bit and the 17 most significant bits; the second word contains the 18 least significant bits. The words are normally stored in consecutively addressed core memory locations for ease of programming. a. Single-Precision Data b. Double-Precision Data Figure 8-1 Data Word Formats ### Magnitudes of Data Words For 1s complement signed and sign-and-magnitude notations, the permissible magnitude of any quantity, X, is in the range of: $$-(2^{n-1}-1) \le X \le 2^{n-1}-1$$ where n is the number of bits allocated to the storage of data in a data word. For a single-precision data word (sign bit and 17 data bits), this relationship becomes: $$-(2^{17} -1) < X \le 2^{17} -1$$ or $$-131 \ 071_{10} \le X \le +131 \ 071_{10}$$ For 2s complement signed notation, the permissible magnitude of any quantity, X, is in the range of: $$-2^{n-1} \le X \le 2^{n-1}-1$$ where n is again the number of bits allocated to the storage of data. A single-precision data word has the range: $$-2^{17} \le X < 2^{17}-1$$ or $$-131 \ 072_{10} \le X \le +131 \ 071_{10}$$ The position of the decimal point is implied in the above ranges. #### Basic Software Floating-Point Formats Floating-point representation of a binary number consists of two parts: the exponent and the mantissa. The mantissa is a fraction with the binary point assumed to be positioned between the sign bit and the most significant data bit. The mantissa is always stored in a normalized state; i.e., leading 0s are eliminated from the binary representation so that the high order bit is always a 1. The exponent as stored represents the power of 2 by which the mantissa is multiplied to obtain the number's value for use in computation. The PDP-9 floating-point software system offers two modes for storage of floating-point numbers: three-word mode and two-word mode. The three-word mode requires three memory locations for storage of a floating-point binary number (figure 8-2a). The exponent, a signed 17-bit integer in 2s complement notation, occupies the first word, or memory location. The mantissa, a 35-bit quantity in sign and magnitude notation, is stored in the second and third words. The sign of the mantissa is stored in the high-order bit of the second word. The two-word mode requires two memory locations for storage of a floating-point binary number, (figure 8-2b). The exponent, an eight-bit integer in 2s complement notation, and its sign occupy the nine high-order bits of the first word. The mantissa, a 26-bit quantity in sign and magnitude notation, is stored in the nine low-order bits of the first word and in the 17 low-order bits of the second word. The sign of the mantissa is stored in the high-order bit of the second word. Figure 8-2 Floating Point Formats # SCALING FOR FIXED-POINT ARITHMETIC In the programming of arithmetic operations on a fixed-point computer, the position of the scale point (i.e., the binary point in a binary number) must be kept track of by the programmer. Once numbers have been entered in the computer, there is no hardware or movable machine point to represent the scale points. The scale point exists only in the mind of the programmer, and only by keeping track of its imaginary position is he able to correctly interpret the machine's calculated results. The fundamental properties of scaled numbers can be simply explained by considering a hypothetical decimal machine capable of manipulating numbers consisting of a sign and five decimal digits. As in real computers, this machine acts as if there were a scale point between the sign and the leftmost decimal digit. It is called the <u>machine point</u>. Thus, every number processed by the computer can be thought of as a signed decimal fraction. However, the programmer is free to assign a decimal point at any position in the number. For example, the above number could represent + 123.45 if the scale point were thought of as being three places to the right of the machine point. In that case the number would be written $+_{\Lambda}$ 12345 D3, where D3 indicates that the decimal point is three places to the right of the machine point. In other words, D3 is the decimal scale factor. Other numbers with different scale factors can have the same representation in the machine. Examples: $$+_{\Lambda} 12345 D2 = +12.345$$ $+_{\Lambda} 12345 D4 = +1234.5$ $+_{\Lambda} 12345 D0 = +.12345$ The scale factor need not be restricted by the size of the machine word. Numbers in the hypothetical computer can be assigned scale factors that exceed five, or the scale factors can even be negative. Examples: $$+_{\Lambda} 12345 D7 = +1234500.$$ $+_{\Lambda} 12345 D-4 = +.000012345$ Of course, these are merely programmer's representations; the machine number is always restricted to a sign and five digits. # Addition and Subtraction In addition and subtraction, the scale factors of the numbers to be combined must be identical. Thus, $+_{\Lambda}42204$ D3 added to $+_{\Lambda}23332$ D3 gives a sum of $+_{\Lambda}65536$ D3 (422.04 + 233.32 = 655.36). This rule has the same basis as in ordinary arithmetic. If the scale factors differ, one number must be shifted until the scale points are aligned. The number $+_{\Lambda}$ 14271 D1 is brought into the accumulator and shifted right two decimal places before addition or subtraction. The scale point changes when the number shifts. Notice that if the number of the higher scale factor had been shifted left instead, its two most significant digits would have been lost and the resulting sum would have been seriously in error. ### Multiplication When two numbers are multiplied together, the scale factor of the product is the algebraic <u>sum</u> of the scale factors of the multiplier and multiplicand. Example: $$(+\ 00200\ D3)\ \times\ (+\ 06000\ D2) = +\ 0001200000\ D5$$ , or 12 Normally the most significant part of the product is in the AC and the least significant part is in the MQ. Thus, the product in the above example would appear in the computer with the machine point between the sign and leftmost digit in the AC. The machine point for the least significant portion of the product is ignored. It is important to remember that the two decimal numbers, $+_{\Lambda}00200$ and $+_{\Lambda}06000$ , when multiplied in the computer will result in the machine product of $+_{\Lambda}0001200000$ regardless of the positions of the scale points in the multiplier and multiplicand. The scale points must be kept track of by the programmer. Thus fractions, as well as integers, can be multiplied in exactly the same way. Examples: $$+_{\Lambda}20000 \text{ D5} \times +_{\Lambda}00060 \text{ D3} = +_{\Lambda}0001200000 \text{ D8} (+20,000 \times +.6 = +12,000)$$ $+_{\Lambda}00200 \text{ D0} \times +_{\Lambda}06000 \text{ D0} = +_{\Lambda}0001200000 \text{ D0} (+.002 \times +.06 = +.00012)$ $+_{\Lambda}00200 \text{ D-2} \times +_{\Lambda}60000 \text{ D-4} = +_{\Lambda}0012000000 \text{ D-6} (+.00002 \times +.00006 = +.0000000012)$ # Division The remarks above for multiplication apply to division, with the following exception. The scale point of the result is the algebraic difference of the scale points of the operands. ### SCALING ON A BINARY COMPUTER The fundamental properties of scaled numbers in a computer as outlined previously can now be applied to the binary and octal numbering systems as used in a fixed-point, binary computer. The decimal scale factor becomes the binary scale factor and is indicated by a B in front of the scale factor. The machine point is still positioned between the sign and the leftmost digit, but in this case the sign is a binary digit. In a 18-bit computer such as the PDP-9, the leftmost bit is the sign bit and there are 17 bits for the number. Because the number system used by the machine is now different from that customarily used by the programmer, conversion is a new consideration. The programmer may be dealing with decimal or octal numbers, but because the machine is binary, the scale factors must be determined from the binary equivalents. As will be explained below, a scaling analysis is performed on each problem so that the binary scale factors chosen result in the most efficient use of the 18-bit word. Having selected the appropriate scale factor for a given number, it is expressed in decimal or octal form followed by the binary scale factor. For example, the combination 975 B10 means that the decimal number 975, when converted to binary form, has a binary point ten places to the right of the machine point. The decimal number 975 B10 can be converted to binary to appear in the machine as follows: (decimal) 975.0 B10 (octal) 1717.0 B10 (binary) 1111001111.0 B10 Shift binary point left 10-bit positions .11110011110 Add sign bit and trailing 0 bits s 0.11 110 011 110 000 000 machine point binary point In octal, the machine word is 363600 Negative numbers may be expressed in either the 1s complement notation or the 2s complement notation. For example, consider the octal number: -3.2 B6 As a positive number, 3.2 B6 would be stored in the computer as 5 0.00 001 101 000 000 000 Machine Binary Point Point As a negative number, it would be stored as: 111 110 010 111 111 111 (Is complement) M B or 1,11 110 0,11 000 000 000 (2s complement) M B #### **OVERFLOW** Suppose we are working with signed quantities and we add the numbers: | Decimal Value | Binary Representation | Octal Equivalent | |---------------|--------------------------------------------|-----------------------| | 18 B5<br>5 B5 | 010 010 000 000 000 000<br>000 101 000 000 | 220000 B5<br>50000 B5 | | 23 B5 | 0,10 111 000 000 000 000 | 270000 B5 | Notice that there was no carry to the left of the first machine position (i.e., into the sign bit). However, if we try to add the numbers: | Decimal Value | Binary Representation | Octal Equivalent | |---------------|--------------------------------------|------------------| | 28 B5 | s <sub>011</sub> 100 000 000 000 000 | 340000 B5 | | <u>5 B5</u> | <sup>s</sup> 000 101 000 000 000 000 | 50000 B5 | | 33 B5 | s100 001 000 000 000 000 | 410000 B5 | The result as given in the machine would be erroneous because the magnitude portion of the AC is not large enough to hold the sum. This situation is described as overflow. Overflow is something which must be avoided in all normal circumstances. To accomplish this, the programmer working with fixed-point data must have some knowledge of the magnitude of the numbers in the program and, accordingly, must locate each number at such a scale that overflow cannot occur even in the "worst case." In this connection, the concept of "minimum binary scale" is helpful. At a binary scale of 5, the largest positive integer that can be contained is $2^5$ -1 which in decimal is 31. The programmer may not always be successful in his attempts to arrange numbers so that overflow will not occur. If a programmer suspects that overflow may occur as a result of an addition or division, he should follow such an operation by a program sequence that would correct the error or at least indicate that such an overflow took place. The proper location of the binary point and the avoidance of overflow, at best, takes some effort on the part of the programmer. # PROGRAMMING TECHNIQUES FOR SCALING One technique used in scaling is to express numbers in a symbolic form that would clearly imply the position of the binary point. The general form is: $$X2^{-q} = X^{-1}$$ where: X is the value of the number. $2^q$ is the factor such that q is the smallest integer that makes $2^q$ greater than the maximum value of X. q corresponds to the minimum binary scale factor which was previously discussed. X' is the scaled form of X (i.e., X is X' with the binary point q places to the right of the machine point). A scaling analysis should be performed on each problem to insure maximum accuracy (i.e., the most efficient use of the binary word so that there are no leading insignificant bits). At the same time, the programmer must insure that there will be no loss of the most significant bits by overflow at any step in the calculation. These are the two bounds within which the programmer must keep the numbers as they are stored and manipulated in the machine. # Analysis In the programming of any given problem or equation, there are three steps prior to the actual coding which should be taken to insure maximum accuracy and to prevent error due to overflow. Step 1: Determine the limits of the values of all numbers to be used in the problem (maximum and minimum). Step 2: Determine the scale factors and set up the relationships between the true numbers and the scaled fractions. Step 3: Substitute the scaled quantities into the original equation and cancel where possible. The scale factors that do not cancel specify the number of required shift operations. If the scale factor of a term is negative, the number must be shifted <u>right</u> before manipulation is performed. If the scale factor is positive, the number must be shifted left if it is to be stored at minimum binary scale. # Addition Scaling As emphasized before, quantities to be added (or subtracted) must have the same scale factors. However, in order to prevent an overflow in the summing process, it is not enough to scale the final sum according to its limit. Generally the program must be scaled by the largest limit which applies to any element in the sum or partial sum generated during the summing process. #### Example 1 Program the operation specified by: $$A = \sum_{i=1}^{n} a_{i}$$ where $a_i \leq K$ for $i=1,2,3,\ldots$ n. The maximum value of A is $\leq K \cdot_n$ , that is, the maximum value of the sum is obtained by multiplying the upper limit of any element in the list to be summed by the number of elements in the list. ### 1. Statement Solve the above problem for n = 10 and K = 100.0. ### 2. Analysis Step 1: $$a_i \le 100.0$$ for $i = 1, 2, 3, ...$ 10 Therefore, $A \le K \cdot n = 100.0 \cdot 10 = 1000$ Step 2: $A = 2^{10} \cdot A'$ $a_i = 2^7 \cdot a_i'$ Step 3: $2^{10} A' = 2^7 a_1' + 2^7 a_2' + ... + 2^7 a_{10}'$ $A' = 2^{-3} a_1' + 2^{-3} a_2' + ... + 2^{-3} a_{10}'$ # 3. Machine Instruction Coding Assume that the ten values of the numbers are stored in consecutive locations starting at location A1 as a. B7 and that the sum is stored in A. | ADD UP, | DZM A | /INITIALIZE | |---------|------------------------|-----------------------------------------| | | LAM -12+1<br>DAC CNTR | /INITIALIZE COUNTER FOR NUMBER OF TERMS | | | LAC (A1-1<br>DAC AUT 1 | /INITIALIZE AUTOINDEX REGISTER | | LOOP, | LAC I AUT 1<br>CLL | /PICK UP TERM | | | LRS 3<br>TAD A | /SHIFT RIGHT | | | DAC A | | | | ISZ CNTR<br>JMP LOOP | | | | JMP DONE | /EXIT, SUMMATION COMPLETED | | A1, | ~ | /al | | | ~ | /a2 | | | ~ | /a3 | | | | • | | | | • | | | | • | ### Programming Note: If the numbers were signed, the instruction sequence of CLL and LRS 3 would be replaced by LRSS 3. ### Multiplication Scaling When multiplication is performed by the PDP-9, the product of two "n" bit numbers is one "2n" bit number. Usually the high-order portion is left in the AC and the low-order portion is stored in the MQ.\* The fundamental rule, again, is: Scale factor of multiplier + scale factor of multiplicant = scale factor of product. #### 1. Statement Program the multiplication operation: $$x = a.b$$ #### 2. Analysis Step 1: $$a < 400.0$$ $b < 1000.0$ Therefore $x < 400,000$ . Step 2: $a = 2^9 a'$ $b = 2^{10} b'$ $x = 2^{17} x'$ Step 3: $2^{17} x' = 2^9 a' \cdot 2^{10} b'$ $x' = 2^2 a' \cdot b'$ ### 3. Machine Instruction Coding Assume that the values of a and b are stored in locations A and B. Assume that they are scaled B9 and B10, respectively. NOTE: This example assumes use of the EAE. After the multiplication, the shift brings two more significant bits into the high-order portion of the product. Knowing the maximum value of y more definitely (i.e., if a and b could never be maximum at the same time) would allow for even more accuracy. In this example, the limit of y was not known so it was assumed to be 400,000 as calculated in Step 1 of the analysis. <sup>\*</sup> MQ if the EAE option is present; otherwise a memory location. # Division Scaling When division is performed in digital computers, the dividend is a "2n" bit word and the divisor is an "n" bit word. Remember that in division the 18-bit divisor word <u>must</u> be greater in magnitude than the 18 high-order bits of the dividend for division to occur without overflow. Therefore, the programmer should scale the values so that division <u>will</u> occur with maximum dividend and minimum divisor. For example, if both dividend and divisor are stored at minimum binary scale, the dividend should be shifted one position to the right by a double-shift subroutine prior to division to insure that overflow does not take place. ### FIXED-POINT ADDITION Fixed-point addition of a number contained in a core memory location, to a number contained in the accumulator, is performed directly through use of the ADD (Is complement add) instruction, or the TAD (2s complement add) instruction. This assumes the binary points have been aligned through scaling of the quantities and both numbers are properly represented in the appropriate complement notation. Addition can be performed without regard for the signs of the numbers. However, like signed numbers must be scaled to prevent the possibility of overflow. # FIXED-POINT SUBTRACTION Subtraction in the PDP-9 is performed by complementary addition; i.e., the subtrahend is converted to its appropriate complement notation and then added to the minuend. As in addition, the binary points of both numbers must be aligned through the provisions of scaling, and both must be represented in the same complement notation. Subtraction can be performed without regard for the signs of the numbers. Assuming that two numbers are both stored in memory locations, typical routines to find the value of A-B follow: | | 1s Complement | | 2s Complement | |-----------------------|--------------------------------------------------|---------------------------------|-------------------------------------------------------------------------| | LAC B<br>CMA<br>ADD A | /LOAD SUBTRAHEND<br>/FORM 1S COMPLEMENT<br>/-B+A | LAC B<br>CMA<br>TAD (1<br>TAD A | /LOAD SUBTRAHEND<br>/FORM 1S COMPLEMENT<br>/FORM 2S COMPLEMENT<br>/-B+A | Both routines end with the result in the accumulator. #### CHAPTER 9 #### INPUT/OUTPUT CONSIDERATIONS This chapter discusses the operation of and the programming techniques for the basic PDP-9 input/output facilities, the real time clock, and the Type KF09A Automatic Priority Interrupt and the Type KH09A Add-to-Memory options. The basic facilities include: provisions for executing program controlled (single word) transfers and data channel (block) transfers via the I/O bus; the program interrupt control; the I/O skip facility; the I/O read status facility; and the direct memory access (DMA) channel for true cycle-stealing access of core memory locations. The PDP-9 offers three modes for executing I/O data transfers: - 1. Program controlled transfers.\* - 2. Data channel transfers. - 3. Direct memory access channel transfers. Program controlled transfers occur as the result of IOT (input/output transfer) instruction execution. These instructions, contained in the body of a main program or in appropriate subroutines, are microcoded to effect response of a specific device interfaced to the I/O bus system. The microcoding includes the issuing of a unique device selection code and appropriate processor-generated pulses to initiate device operations, such as taking data from the bus or placing data on the bus or clearing device flags. All program controlled transfers are executed through the accumulator in parallel bytes up to 18 bits in length. The data channel facility provides for relatively high speed transfers of data in blocks between peripherals (DECtape, magnetic tape, etc.) and system core memory. The transfers are controlled by word counter registers and current address registers contained in a memory bank. Four pairs of these registers are provided to control non-overlapping data channel transfers to or from up to four devices. A data channel transfer request "breaks" program control at completion of the current instruction\*\* and suspends execution of the program in progress until the current word transfer is completed (three machine cycles for input to memory, four cycles for output to device). Successive breaks are granted to either the active device or another data channel device provided the request for service is made prior to completion <sup>\*</sup>In truth, all I/O transfers are made by program control. The differentiation made throughout this hand-book refers to the relative degree of control; i.e., the program controlled transfer mode requires the execution of IOT instructions to effect the transfer of each data word, while the channel modes require only that the program initialize the parameters (word count, starting address, etc.) of the block transfer. <sup>\*\*</sup> An IOT or XCT instruction prohibits interruption of the instruction immediately following it; i.e., the break is not granted until completion of the instruction following the current IOT or XCT instruction. of the current channel transfer action. The maximum transfer rate for the facility is between 250,000 and 333,333 words per second, depending on the mix of input and output transfers. The data channel facility is expandable to service up to eight devices. The DMA channel is a separate I/O data path, permitting direct access to system memory locations for high data rate devices, such as magnetic drum and disc systems. This facility enables the transfer of data at rates up to one million words per second. It operates on a true cycle-stealing basis. All I/O data transfers function within the precedence of the following priority structure. - 1. Direct memory access (DMA) channel requests (highest priority). - 2. Data channel (DCH) requests. - 3. Real-time clock counting. - 4. Automatic priority interrupts (API), 8 levels (optional). - 5. Program interrupts (PI). - 6. Main program in progress (lowest priority). A higher priority request for service interrupts any in-process service of a lower priority at the end of the current instruction, or, in the case of the DMA channel, at the end of the current memory cycle. Program interrupts and priority interrupts require that the main program transfer control to specific service subroutines. These routines must be programmed to restore control to the interrupted program at completion of the service interval. Computer-granted breaks satisfy data channel requests; i.e., program execution is delayed but not disturbed while the data channel transfers information between memory and the requesting device via the MB. ### PROGRAM CONTROLLED TRANSFERS The majority of I/O transfers occur under control of the program, taking advantage of the control elements present in the computer and in device controls interfaced to the I/O bus. Programmed transfers require more computer and actual time than do data channel and direct memory access transfers. The simplicity and inherent lower cost of the device controls, however, coupled with the high speed of the computer relative to the operational speed of most peripheral devices offset this time discrepancy. All program controlled transfers take place through the accumulator (AC) in bytes up to 18 bits in length. In transfers within the central processor and between the processor and core memory, data are processed as 18-bit words, the sole addressable unit in the PDP-9. For bytes of less than 18 bits, unused bits in the data word normally remain zeroed. Programming techniques of masking and shifting the contents of words may be used to pack and unpack bytes for the purpose of reducing core memory storage requirements. The following program sequence represents a single output transfer to a device: The LAC instruction reads the data word from its effectively addressed core memory location into the AC. The program then issues the IOT skip instruction to test the readiness of the selected device. It remains in the two-instruction loop completed by the JMP return instruction until the selected device indicates its readiness to accept the data by returning a signal via the I/O skip line to the processor. At that time, the IOT write instruction places the data on the I/O bus data lines, selects the device, and causes it to generate an internal command which strobes the bus data into its information register. Each IOT instruction is microcoded to issue both unique device selection code and appropriate commands to effect the required device action (refer to chapter 7, page 7-17, for a description of the IOT instruction format; refer to chapters 4 and 5 for description of IOT instructions for peripheral devices offered in the PDP-9 line). For a simple input transfer, the following sequence is typical: Again, the program issues the IOT skip instruction to test the readiness of the selected device and remains in the two-instruction loop completed by the JMP return instruction until the device signals that it is ready to send data to the processor. At that time, the IOT read instruction selects the device and causes it to generate internal commands which strobe the data onto the I/O bus data lines and send a read request signal to the processor. The processor then inclusively ORs the bussed data into the AC. The DAC instruction deposits the data word in the effectively addressed core memory location. It is normal practice in input transfers to have the IOT read instruction microcoded to effect clearing of the AC prior to the entry of the data sent by the device. The rate at which programmed transfers can be made is a function of the characteristics of the devices and the program's use of them. The IOT instruction capability of the PDP-9 allows programmed control of up to 256 devices and the generation of up to three unique commands per each of the 256 possible device selection codes. Devices requiring more than three internal commands are simply assigned additional device selection codes. # INPUT/OUTPUT READ STATUS FACILITY Execution of the IOT instruction IORS (octal code 700314) enters the states of device flags (bipolar signals, i.e., 0 or 1) in specific bits of the AC. The state of a specific flag or group of flags can be quickly determined by programmed checks of the AC contents. Figure 9–1 shows the bit positions associated with the commonly interfaced flags. The IORS word can contain up to 18 flag bits. Those bits not used are zeroed. The presence of a flag is indicated by a 1 state in the corresponding AC bit. Switching the REGISTER DISPLAY control (console) to the STATUS position simulates execution of the IORS instruction with the processor in the "program stop" condition. The contents of the IORS word (i.e., the states of the device flags) are displayed in the REGISTER indicators (console) at this time. Figure 9-1 IORS Word-Status Bit Assignment The functions of the device flags normally interfaced to the IORS facility are as follows: <u>Program Interrupt</u> - a 1 bit indicates that the program interrupt control is enabled. A 0 bit indicates that it is disabled. The program interrupt control is automatically disabled upon the grant of a program interrupt request. Tape Reader - a 1 bit indicates that the reader was previously selected and has assembled a character in its buffer for transfer to the AC upon execution of a "read buffer" IOT instruction. This flag is also interfaced to the program interrupt control to request program interruption when the flag goes to the 1 state. <u>Tape Punch</u> - a 1 bit indicates that the paper tape punch has punched a line of tape relating to the contents of the AC at the time of selection. The flag is also interfaced to the program interrupt control to request program interruption when the flag goes to the 1 state. Teletype Keyboard - a 1 bit indicates that the keyboard buffer has assembled a character code relating to a struck key. The flag is cleared when the assembled code is read into the AC by an IOT instruction. The flag is also interfaced to the program interrupt control to request program interruption when the flag goes to the 1 state. Teletype Printer - a 1 bit indicates that the teleprinter is ready to accept a character code from the AC. The flag is cleared when the teleprinter buffer is loaded and it remains so until the action called by the code has been executed. The flag is then again set to 1. The flag is also interfaced to the program interrupt control to request program interruption when the flag goes to the 1 state. <u>Light Pen</u> – a 1 bit indicates that the Type 370 Light Pen has detected the presence of illumination, normally a CRT-displayed point. The pen is equipped with a manually operated shutter which should be opened only when the pen is positioned on the face of the CRT display. The flag is also interfaced to the program interrupt control to request program interruption when the flag goes to the 1 state. Real Time Clock Overflow - a 1 bit indicates that the real time clock counter (stored in memory location 00007 of bank 0) has overflowed; i.e., the initialized clock count (in 2s complement form) has been incremented to zero. The flag is also interfaced to the program interrupt control to request program interruption when the flag goes to the 1 state. Real Time Clock Enabled - a 1 bit indicates that the real time clock is enabled and incrementing the contents of location 00007 by one at the rate of 60 times per second (or 50 times per second for 50 Hz powered PDP-9 systems). A 0 bit indicates that the real time clock is disabled. The flag is not interfaced to the program interrupt control. Tape Reader No Tape - a 1 bit indicates that the paper tape reader has detected a no-tape condition and halted. In the case of a tape break, since the break may be skewed, approximately 12 lines of previously read tape should be considered as invalid data upon detection of the no-tape flag going to a 1. Although this flag is not interfaced to the program interrupt control, it does force the tape reader flag to go to the 1 state and hence request program interruption for the no-tape condition. A program may make use of the no tape flag by executing an IORS instruction and testing the AC contents prior to each selection of the reader. An alternative method calls for a program interrupt accessed subroutine to execute the IORS instruction and check the states of the tape-reader and tape-reader-no-tape flags to determine which flag initiated the interruption. While the no-tape flag is a 1, the tape reader will not respond to IOT selection; i.e., the reader is inhibited from reading tape lines. Momentarily depressing the FEED button on the tape reader after loading a tape for readin clears the no-tape flag. <u>Tape Punch No Tape</u> - a 1 bit indicates that the supply of unpunched tape in the internal magazine has been exhausted save for approximately one inch. This length is adequate for the punching of several characters; it may be used also for splicing purposes. This flag does not request a program interruption. Users who desire to make use of this flag must include an execution of the IORS instruction and a test of the AC contents prior to each selection of the paper tape punch. <u>DECtape</u> - a 1 bit indicates that the DECtape flag and/or the error flag (both contained in the TC02 DECtape control unit) are set. This flag is interfaced to the program interrupt control to request program interruption when the flag goes to the 1 state. The function of the DECtape and error flags are discussed in the description of the TC02 control (refer to chapter 5). # INPUT/OUTPUT SKIP FACILITY The input/output skip (IOS) facility, as previously shown in the program controlled transfer description, permits IOT instruction testing of those device flags interfaced to it. Such an instruction issues an unique device selection code and then tests the state of the respective device flag. If the flag is in the skip state (normally, the set state), the processor is directed to increment the contents of the PC by one and thus skip the next instruction in sequence. If the flag is found to be not set, the next instruction in sequence is executed. The skip conditions for the various pheripherals offered with the PDP-9 are presented in the IOT instruction descriptions for these devices (refer to chapters 4 and 5). ### PROGRAM INTERRUPT CONTROL The program interrupt (PI) facility, when enabled by the program, relieves the main program of the need for repeated flag checks by allowing the ready status of I/O device flags to automatically cause a program interrupt. The program interrupt (PI) control is enabled or disabled by programmed instructions. The following IOT instructions provide for control of this facility: | Mnemonic | Octal Code | <u>Function</u> | | |----------|------------|-----------------|--| | ION | 700042 | Enable the PI. | | | IOF | 700002 | Disable the PI. | | The PI is automatically disabled when an interrupt is granted or when the I/O RESET key (console) is depressed. The PI is temporarily inhibited while the automatic priority interrupt system is processing an priority interrupt request. The PIE indicator (console) is lighted while the PI is enabled. A program interrupt is granted at completion of the current instruction (IOT and XCT instructions are an exception)\* provided that the PI is enabled and no I/O action of a higher priority is in progress. At the grant of the interrupt, the program in progress "traps" to memory location 00000. This location stores the following data (see figure 9-2 for the storage format): - 1. The content of the Link register. - 2. The contents of the 13-bit PC (or the 15-bit extended PC, if the Type KG09A Memory Extension Control has been included in the system due to memory expansion). - 3. The state of the extend mode (on or off) if the KG09A option is present. - 4. The state of the memory protection mode (on or off) if the Type KX09A Memory protection option is present. If the options are not present, the respective bit positions of location 00000 remain zeroed. Following the storage action, the extend mode and the memory protection modes are turned off, and the instruction stored in location 00001 is executed. This instruction is an enter extend mode (EEM) instruction (see page 6-5) that re-enables the extend mode. Immediately thereafter, the instruction in location 00002 is executed. This instruction is a JMP I (indirect address to allow addressing of any memory bank, \*\* hence core memory address 00001 must determine which device requested an interrupt. The interrupt routine interfaced to the PI will service that device. Where multiple devices are interfaced to the PI, the subroutine accessed by the JMP I instruction must execute a flag search to determine which device initiated the interrupt request. Although the PI is not priority oriented (i.e., the interrupt request line accepts the inclusive OR of all device request flags), the order in which the search routine tests the device flags does establish a priority sequence of service. Several factors must be considered in the use of the PI. First, although the PI does automatically save the Link, the PC, etc. to facilitate restoration of the interrupted program at completion of interrupt service, it does not provide for the saving of the contents of other active registers. Thus, interrupt-accessed service subroutines should begin with instructions to temporarily preserve the contents of any registers that may be used by the subroutines. <sup>\*</sup>An IOT or XCT instruction prohibits interruption of the sequence of it and the instruction immediately following it. $<sup>\</sup>star\star$ Both actions (the EEM and JMP I instruction execution) assume the presence of expanded memory and enabled API. Figure 9-2 Program Interrupt, JMS Instruction, or CAL Instruction Storage Word Format\* Secondly, the PI must not be enabled by execution of the ION instruction until the exit from the subroutine. If this precaution is not observed, a second interrupt request could be granted before the current subroutine is completed. The resultant overwriting of location 00000 when the latter request traps to this location will destroy the previously saved data and, hence, prevent restoration of the interrupted main program. Normally, interrupt requests made during current service of an interrupt remain on-line and are answered when the current interrupt service terminates provided the delay does exceed device limitations. The third and final factor requires that interrupt-accessed subroutines terminate with the following instruction sequence: | LAC ACSAV | /RESTORE AC | |-----------|---------------------------------| | ION | /TURNS ON PI | | D BR | /PRIMES SYSTEM TO RESTORE L, PC | | | /SAVED MODES AT JMP I TIME | | JMP I 0 | /RESTORES SYSTEM TO STATUS AT | | | /TIME OF INTERRUPT | The DBR (debreak and restore) instruction (octal code 703344) is an IOT instruction which sets up the system to restore the Link, PC, extend mode, and memory protection mode to their status at the time of the program interruption; DBR must immediately precede the JMP I instruction. The DBR instruction is fully described in the discussion of the automatic priority interrupt system (page 9–12), but is implemented on all PDP-9s. <sup>\*</sup>PI interrupt turns off extend mode and memory protection mode. API interrupt and execution of CAL instruction turns memory protection mode off; extend mode is not affected. If only one device is connected to the PI facility, program control can be transferred directly to a routine that services the device when an interrupt occurs. This operation occurs as follows: | Tag | Address | Instruction | Remarks | |-----|---------|-------------|-----------------------------------------| | | 01000 | • | /MAIN PROGRAM | | | 01001 | • | /MAIN PROGRAM CONTINUES | | | 01002 | • | /INTERRUPT REQUEST OCCURS | | | | | INTERRUPT OCCURS | | | 00000 | | /PROGRAM COUNT, ETC ARE STORED IN 00000 | | | 00001* | JMP SR | /ENTER SERVICE ROUTINE | | SR, | 02000 | • | SERVICE SUBROUTINE FOR INTERRUPTING | | | | • | /DEVICE | | | 03001 | ION | TURN ON INTERRUPT | | | 03002 | D BR | | | | 03003 | JMP I 0000 | /return to main program | | | 01003 | • | /MAIN PROGRAM CONTINUES | | | 01004 | • | | In most PDP-9 systems numerous devices are connected to the PI facility, so the routine beginning in core memory address 00001 must determine which device requested an interrupt. The interrupt routine determines the device requiring service by checking the flags of all equipment connected to the PI and transfers program control to a service routine for the first device encountered that has its flag in the state required to request a program interrupt. In other words, when program interrupt requests can originate in numerous devices, each device flag connected to the PI should also be connected to the IOS. The following program example illustrates how the program interrupt routine can determine which device is requesting service (this routine assumes expanded memory and active API): | Tag | Address | Instruction | Remarks | |-------|----------------------------------------------------|--------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FLGCK | 01000<br>01001<br>01002<br>00000<br>00001<br>00002 | EEM JMP I 00003 IOT 3401 JMP SR 34 IOT 4401 JMP SR 44 IOT 5401 JMP SR 54 | /MAIN PROGRAM /MAIN PROGRAM CONTINUES /INTERRUPT REQUEST OCCURS INTERRUPT OCCURS /STORE PC, LINK, ETC. /ENTER EXTEND MODE /ENTER ROUTINE /SKIP IF DEVICE 34 IS REQUESTING /ENTER SERVICE ROUTINE 34 /SKIP IF DEVICE 44 IS REQUESTING /ENTER SERVICE ROUTINE 44 /SKIP IF DEVICE 54 IS REQUESTING /ENTER SERVICE ROUTINE 54 | | | | | | <sup>\*</sup> This routine illustrates PI programming for a PDP-9 system without expanded memory and API. ### AUTOMATIC PRIORITY INTERRUPT The API option, Type KF09A, adds eight additional levels of programming priority to the PDP-9. The upper four levels are assigned to I/O devices and are initiated by flags (interrupt requests) from these attached devices. The lower four levels are assigned to the programming system and are initiated by software requests. The priority network insures that high data rate or critical devices assigned to high priority levels will always interrupt slower device service routines while holding still lower priority interrupt requests off line until they can be serviced. The API also identifies the cause of the interrupt directly, eliminating the need for the service routines to flag search. The key elements in the API are priority level and channel. Each I/O device in a PDP-9 system is assigned to one of the 4 hardware API priority levels or to the program interrupt facility so as to maximize performance of the entire I/O system. The channel assignment (API provides for 32) of every device is fixed and cannot be changed. The API operates in the following manner. An I/O device requests service by transmitting an interrupt request signal to the processor on a line corresponding to its specific, preassigned priority level. If this priority level is higher than the priority of the device which requested a currently active program segment, an interrupt is granted to the new device. Upon receipt of the grant signal, the device transmits its channel address back to the processor. The processor executes the instruction in the specified memory address; this is always a JMS (or JMS I)\* to the device service subroutine. The new priority level is remembered and no further acceptance of requests on this or lower priority levels is permitted until the device service subroutine is exited. The hardware insures that simultaneous requests by multiple devices are handled in the proper priority sequence. If interrupt requests occur at different priority levels, the highest priority request will be serviced first. If multiple interrupt requests occur at the same priority level, the device closest on the bus to the processor will be serviced first. The entire API system may be enabled or disabled with a single instruction, however, many devices provide facility to separately connect and disconnect their flags from the interrupt. The major advantage of this API system lies in the proper use of the software levels. In the real-time environment, it is necessary to maintain data input/output flow, but it is not possible to perform long, complex calculations at priority levels which shut out these data transfers. With the API, a high <sup>\*</sup>The indirect address permits access of a subroutine stored in a memory bank other than bank 0 (see page 6-5). priority data input routine which recognizes the need for the complex calculation can call for it with a software level interrupt. Since the calculation is performed at a lower priority than the data handling, the latter can go on undisturbed. Further, there is no need to interface the data collection routine with the lowest priority (background) program which may run independently of the real-time system. Since the priority juggling is handled by the hardware it is quite efficient. ### Priority Level At any time, the computer is actually executing instructions from one and only one program segment. However, if the program segment being executed is the result of an interrupt (due to a peripheral device flag), then both the interrupted program and the interrupt service program can both be thought of as concurrently active. Such is the case in the basic PDP-9 when the normal program interrupt facility (PI) is used. The API options add 8 additional priority levels above the two available (PI and main program) in the basic computer. Thus, a total of 10 levels of priority exist. Priority levels 0-3 are for hardware; levels 4-7 for software. Level 0 is the highest priority. Each peripheral device attempts to interrupt at a specific priority level. If there are no active programs at that or higher priority levels, the program segment in progress will be interrupted, return information stored, and the new device service routine entered. If there is a higher priority level program active, the device request is ignored until the higher priority program segment terminates. The high priority levels then go inactive and the requesting device is serviced. A.CAL instruction causes priority level 4 to be activated after the CAL instruction is executed. A break to level 4 will occur after all higher priority level requests are honored. #### Channels Each peripheral device is assigned to a channel independent of its priority level. The channel assignment of a device defines a device service subroutine entry point in the following manner: When an interrupt is granted to a device, the device transmits an address to the computer that is simply related to its channel number. (Channel address = $40_8$ + channel number.) The assigned priority level flipflop is turned on and the instruction at the channel address is executed. This is always a JMS to the device service subroutine. There are $32_{10}$ channels numbered 0-37<sub>8</sub> with corresponding core addresses of 40-77. Four channels (40-43) are used for software priority levels, leaving 28 for device use. Each of the four hardware priority levels is multiplexed such that up to eight devices (channels) may use it. It is not possible to enable or disable an individual channel. Rather, the more sophisticated I/O devices connected to the interrupt will have the ability to enable or disable themselves from their interrupt lines. Simple devices such as the reader, punch, etc., will clear their flags to disconnect, just as they disconnect from the program interrupt. # **API IOT Instructions** The following instructions are supplied with the API option. Note that although the DBR (debreak and restore) instruction appears in this listing, it is a basic machine instructions; hence, DBR may be used in PI-entered subroutines (refer to page 9-8) as well in API-entered subroutines. | Mnemonic | Octal Code | <u>Function</u> | |----------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SPI | 705501 | Skip on priorities inactive. The next instruction is skipped if any AC bit is set and the corresponding API condition is true (see table 9-1). | | ISA | 705504 | Initiate selected activity. The API activity specified by a set bit in the AC is initiated (see table 9-2). | | DBK | 703304 | Debreak. This instruction is used to release the highest active priority level. Its use is to return a subroutine's priority to the normal assignment after the requirement for an interim ISA-initiated raising of priority has been satisfied. DBK should not be used to terminate a subroutine as it does not provide for restoration of the PC, Link, etc. | | D BR | 703344 | Debreak and restore. In addition to releasing the active priority level, this instruction primes the PDP-9 to restore the Link, the PC (or EPC), the extend mode, and the memory protect mode to their status at the time of interruption. The actual restoration occurs at the execution of the JMP I instruction exiting the subroutine. DBR must immediately precede the JMP I instruction. Where DBR is used in subroutines not entered by API action, the debreak operation has no significance. | | RPL | 705512 | The priority levels are read into the AC according to the bit usage shown in table 9-3. AC bits 2-9 indicate the | presence of devices requesting service on levels 0-7. AC bits 10-17 indicate those priority levels that are active. (A level becomes active if service at this level has commenced, or if a raise priority level instruction (ISA) has been executed initiating activity on a higher level.) Programming note: normally, the SPI and ISA instructions are combined (microcoded) to first test that the program segment currently in progress is not already at the requested priority level and then if not, to initiate a raising of priority to the requested level. Hence, if a program segment cannot raise its priority, the segment must be already at the requested level or higher. The ISA instruction cannot be used to lower the priority level of an active program segment. The hardware will not recognize the priority change. TABLE 9-1 STATUS BITS ASSOCIATED WITH THE SPI INSTRUCTION | AC Bit Function | | |-----------------|--------------------------------------------------------------| | 0 | API enable (system is presently enabled if 1, disabled if 0) | | 1 | Unused | | 2 | Unused | | 3 | Unused | | 4 | Unused | | 5 | Unused | | 6 | Unused | | 7 | Unused | | 8 | Unused | | 9 | Unused | | 10 | Priority level 0 inactive, hardware* | | 11 | Priority level 0 and 1 inactive, hardware | | 12 | Priority level 0–2 inactive, hardware | | 13 | Priority level 0–3 inactive, hardware | | 14 | Priority level 0-4 inactive, software | | 15 | Priority level 0-5 inactive, software | | 16 | Priority level 0-6 inactive, software | | 17 | Priority level 0-7 inactive, software** | <sup>\*</sup>Highest priority. <sup>\*\*</sup>Lowest priority. TABLE 9-2 CONTROL BITS ASSOCIATED WITH ISA INSTRUCTION | AC Bit | Function | | | | |--------|------------------------------------------------------------------------------------|--|--|--| | 0 | API enable (enable API system if bit is a 1, disable system if bit is a 0). | | | | | 1 | AC BIT | | | | | 2 | For paper tape reader $\frac{1}{0}\frac{2}{0}$ Reader priority level $\frac{1}{2}$ | | | | | | 0 1 1<br>1 0 0 | | | | | | 1 1 Remove PTR from API | | | | | 3 | Unused | | | | | 4 | Unused | | | | | 5 | Unused | | | | | 6 | Request interrupt at priority level 4 | | | | | 7 | Request interrupt at priority level 5 | | | | | 8 | Request interrupt at priority level 6 | | | | | 9 | Request interrupt at priority level 7 | | | | | 10 | Raise priority to priority level 0 | | | | | 11 | Raise priority to priority level 1 | | | | | 12 | Raise priority to priority level 2 | | | | | 13 | Raise priority to priority level 3 | | | | | 14 | Raise priority to priority level 4 | | | | | 15 | Raise priority to priority level 5 | | | | | 16 | Raise priority to priority level 6 | | | | | 17 | Raise priority to priority level 7 | | | | TABLE 9-3 STATUS BITS ASSOCIATED WITH THE RPL INSTRUCTIONS | AC Bit | Function | | |--------|-----------------------------------------------|--| | 0 | Unused | | | 1 | Unused | | | 2 | Device requesting service on priority level 0 | | | 3 | Device requesting service on priority level 1 | | | 4 | Device requesting service on priority level 2 | | | 5 | Device requesting service on priority level 3 | | | 6 | Device requesting service on priority level 4 | | | 7 | Device requesting service on priority level 5 | | TABLE 9-3 STATUS BITS ASSOCIATED WITH THE RPL INSTRUCTIONS (continued) | AC Bit | Function | | |--------|-----------------------------------------------|--| | 8 | Device requesting service on priority level 6 | | | 9 | Device requesting service on priority level 7 | | | 10 | Priority level 0 active | | | 11 | Priority level 1 active | | | 12 | Priority level 2 active | | | 13 | Priority level 3 active | | | 14 | Priority level 4 active | | | 15 | Priority level 5 active | | | 16 | Priority level 6 active | | | 17 | Priority level 7 active | | #### Dynamic Priority Reallocation In order to most efficiently service real time devices, the hardware includes provision for dynamic priority reallocation. There are three distinct methods. - 1. <u>Device dependent</u> Since channel and priority level are independent, a device <u>may</u> be designed to interrupt at any of several priority levels without grossly affecting programming. In a control application, the device could raise its priority (under program control) when, for example, the data rate increased. In this case the device would make use of more than one device priority level. - 2. Program generated service requests The program may generate interrupt requests on any of the four software priority levels. If the priority level of the request is below an active priority level, the request will (eventually) be serviced when the higher priority active levels are dismissed. If the priority level of the request is above all active levels, the request will be serviced immediately. The instruction (JMS) in the software priority level channel will be executed, storing the current program counter and entering a new program segment. - 3. <u>Programmed priority changes</u> In order for an interruptable program to change parameters in an interrupt service subroutine, the priority interrupt system is normally turned off while the changes are effected. Unfortunately, all interrupts are shut out during this time including those that indicate machine errors or are vital to control real time processes. Thus, the API has been designed so that a program segment may raise its priority only high enough to shut out those devices whose service routines require changes. The method of raising priority and lowering it requires minimum possible time. By issuing the ISA instruction with the proper bits set in the accumulator the priority of the currently active program segment is raised. No instruction in a channel is executed. The program merely continues on at its higher priority level. To restore the program segment to its original priority level, a DBK instruction is issued. For example: a priority 2 routine is entering data in memory locations A through A + 10; but, based on a calculation made by a priority 6 routine, it becomes necessary to move the data to memory locations B through B + 20. The changes in the routine at level 2 must be completed, without interruption, once they are started. This is possible by the level 6 program raising itself to level 2 (devices on the same or lower priority may not interrupt), completing the change, and debreaking back to level 6. #### Programming Examples # <u>Input 10 Words from A/D Converter</u> A service routine INAD has been written to input 10 words to a FORTRAN array for later processing. The core location of the A/D channel contains a JMS INAD. The basic components of INAD are: | INAD, | 0 | /ENTRY POINT | |-------|------------|----------------------------------------| | | DAC SAVAC | /SAVE AC | | | IOT | /READ A/D BUFFER | | | • | STORE IN ARRAY | | | • | /TEST FOR LAST WORD - IF YES, INITIATE | | | | SOFTWARE INTERRUPT TO ACCESS DATA | | | | /FORMATTING SUBROUTINE | | • | IOT | /ELSE, START NEXT CONVERSION | | | LAC SAVAC | /RESTORE AC | | | D BR | /DEBREAK AND RESTORE | | | JMP I INAD | /RETURN | The program segment to start the conversion would look as follows: ``` /INITIALIZE INAD IOT /SELECT CONVERTER FOR FIRST CONVERSION /CONTINUE WITH PROGRAM ``` If INAD were active, one could instruct it to input an additional 10 words with the following segment: ``` LAC ( ) /CONTROL WORD ISA /RAISE PRIORITY TO /LOCK OUT INAD /CHANGE INAD /PARAMETERS DBK /RESTORE PRIORITY TO ORIGINAL LEVEL ``` #### Simulation of Hardware Interrupt A hardware interrupt may be simulated by LAC ( ) /CONTROL WORD ISA /RAISE TO HARDWARE PRIORITY JMS INAD /ENTER INAD #### Use of Software Levels The organization of a program on 5-levels might be as follows (in order of decreasing priority). Interrupt level 0 - highest priority alarm conditions, computer or process malfunction Interrupt level 1 - control process A/D-D/A, sense and control input/output routines Interrupt level 3 - Teletype I/O routines for operator interface, operator can inquire or demand changes as required. Interrupt level 4 - FORTRAN subroutines to calculate process control input/output (Software) data. Direct digital control routines. Main Program - lowest priority-operator interface programming, requested readouts, etc. #### Queueing High priority/high data rate/short access routines cannot perform complex calculations based on unusual conditions without holding off further data inputs. To perform the calculations, the high priority program segment must initiate a lower priority (interruptable) segment to perform the calculation. Since, in general, many data handling routines will be requesting calculations, there will have to be a queue of calculation jobs waiting to be performed at the software level. Each data handling routine must add its job to the appropriate queue and issue an interrupt request (ISA instruction) at the corresponding software priority level. #### DATA CHANNEL TRANSFERS The data channel control offers a relatively high speed data path (via the I/O bus) for the transfer of data in blocks between core memory and high data rate devices, such as DECtape and standard magnetic tape transports. The data channel control can service up to four devices with expansion provisions for servicing up to four additional devices. The priority of service is established by the order in which the devices are interfaced to the facility. Device requests for data channel transfer action are honored at completion of the current instruction, provided that such completion is interruptable; i.e., the current instruction cannot be an IOT instruction or a XCT instruction. Each type prohibits interruption of the instruction sequence until the instruction which immediately follows the current instruction (and which is not itself an IOT or XCT instruction) completes its execution. A data channel request made during the current instruction has priority over an API or PI request made during the same interval. An in-process data channel transfer cannot be interrupted, but it can be suspended while a DMA channel device steals cycles to effect its transfer action. A suspended data channel transfer continues without loss of function at completion of the DMA channel action. Device requests for data channel transfer action which occur during an in-process data channel transfer wil be honored at completion of the current channel operation on the basis of their priority relationship; i.e., a higher priority device will be serviced immediately while the lower priority device or devices wait for service. A data channel device functions with processor-granted program breaks to interleave its data transfers with execution of the program in progress. These breaks suspend rather than interrupt the program's execution. The transfer are made via the MB and do not disturb the contents of other active registers in the processor (AC, PC, etc.). Data is read into memory in three machine cycles and out of memory in four cycles (the additional cycle allows I/O bus settling and the setting of control gates prior to the strobing of the data into the device's buffer register). The maximum data rate capacity of the data channel control lies between 250,000 and 333,333 words per second, depending on the mix of input and output transfers. Each data channel device is associated with a unique pair of memory locations which function as a word counter (WC) register and a current address (CA) register for controlling data transfers made to and from the device. These registers must be initialized by the program prior to the device request for data transfer action. The register (memory location) assignments for the four standard data channels are as follows: | Data Channel | WC (octal) | <u>CA (octal)</u> | |--------------|------------|-------------------| | 0 | 30 | 31 | | I | 32 | 33 | | 2 | 34 | 35 | | 3 | 36 | 37 | PDP-9 systems programs presently provide for the assignment of DECtape to data channel 0 and the assignment of standard magnetic tape to channel 1 (refer to chapter 5 for discussions of these devices). The WC register (whose memory address must be even and the lower numerical quantity of the data channel pair) is initialized to contain the number of words to be transferred; this number must be entered in 2s complement notation, as the WC counts up towards zero and indicates by the all-zero condition that the transfer has been completed. The CA register is initialized to contain the starting address minus one of the sequential block of memory locations which are to deliver data or receive data from the device. When the processor honors a data channel request, the respective device transmits the address of its assigned WC register. During the first cycle of the channel transfer, the contents of the WC are incremented by one and the address of the CA register is established. In the second cycle, the contents of the CA are incremented by one to establish the effective address of the memory location delivering or receiving the data word. During the third cycle, or fourth cycle in the case of out transfers, the actual data transfer occurs. The device normally continues to request data channel service until the WC overflows (goes to all-zeros), indicating that the intialized number of data words will have been transferred at the completion of the current data channel action. A signal sent to the device at this time may be used to initiate API or PI access of a subroutine for the purpose of again initializing the channel's WC and CA registers.\* Because the block transfers are primarily automatic in nature, the programmer need only concern himself with providing the appropriate subroutines to initialize the data channel WC and CA registers and to initiate the device request for data channel service. Since Data Channel requests are only honored at completion of instructions, the type of instruction in progress determines the waiting time until the interrupt is granted. The following considerations apply. - 1. The IOT instruction and subsequent instruction are noninterruptable. The interrupt request will be honored at the completion of the instruction which follows the IOT. - 2. The EAE instructions delay interruption until they complete. This may be as long as $17\,\mu\text{sec}$ . - 3. The XCT instruction is noninterruptable. The interrupt request will be honored at the completion of the instruction referenced by the XCT. - 4. Lower priority channel-interfaced devices wait for the completion of data transfers on the requesting higher priority channel. Hence, if four requests come up simultaneously, the lowest priority device may wait 12 µsec. <sup>\*</sup>The "overflow" signal normally shuts down the device to prevent further transfer requests until WC and CA are re-initialized. Long XCT chains on sequential IOT instructions can lock out channel requests for indeterminate periods of times. These should be avoided in programs operating devices requiring fast response to their requests. EAE instructions requiring more than $12 \,\mu sec$ are uncommon but possible. Unfortunately, requests tend to stack up during these waiting periods so that lower priority devices may wait even longer. #### ADD-TO-MEMORY CAPABILITY When the Increment MB capability is used, the device data register is gated to the address lines using the ENA(1) level generated by a W104 module (see figure 14-2). A break is initiated in the usual manner by the W104 module. The ENA(1) level from this module should be used, through an inverter, to ground the INC MB control line. The overflow pulse I/O OVFLO should be gated with ENB(1) to produce a control pulse for the device indicating that a location has been incremented to zero. A device utilizing the add-to-memory capability is connected to the DCH in the normal manner. The word count memory location is specified by the device and gated to the address lines by the W104 module. The data to be added is gated onto the I/O data bus in the usual fashion (see figure 14-3) with IOP2 during the CA cycle. ENB(1) is used to request both READ RQ and WRITE RQ. If there is an add overflow, a pulse, ADD OVFLO, (200 nano, -3v) comes back on I/O bus line A3E. If desired, the sum may be gated into an external register with IOP4 during the DATA cycle. #### REAL TIME CLOCK The real time clock produces clock pulses at the rate of one every 16.7 msec (or every 20 msec for 50 Hz-powered systems). While the facility is enabled, each such pulse occurrence initiates a request for a program "break" at the completion of the current instruction. At the grant of the break, the contents of the clock counter register (memory location 00007) are incremented by one. This register is program initialized to contain the 2s complement of the desired number of clock pulses. Clock breaks continue to be requested until the register overflows (i.e., reaches the all-zeros condition). At this time, the clock flag is set to initiate interruption of the program in progress (see IORS Status Word, page 9-5). The clock flag is interfaced to the program interrupt control and to the API system if the latter is included in the PDP-9. The real time clock facility's incrementing of the clock register functions like a one cycle data channel transfer; i.e., at the break, the contents of 00007 are extracted, incremented and then rewritten in the same location, all within one cycle. Hence, the restrictions of "current instruction" apply here also (see page 9-17). The following IOT instructions are provided for use with the clock: | Mnemonic | Octal Code | <u>Function</u> | |----------|------------|----------------------------------------------------------------------------------------------------------| | CLON | 700044 | Clock on. The real-time clock's incrementing of location 00007 is enabled and the clock flag is cleared. | | CLOF | 700004 | Clock off. The clock's incrementing of location 00007 is disabled and the clock flag is cleared. | | CLSF | 700001 | Skip on clock flag. The next instruction is skipped if the clock flag is set. | The CLK switch (console) must be in the down position to permit programmed control of the facility. In the up position, the facility remains disabled. Depressing the I/O RESET key (console) disables the facility and clears the clock flag. While the facility is enabled, requests for clock breaks have priority of acceptance over API and PI requests. The first clock break may occur at any time up to 17 msec after the facility has been enabled. Subsequent breaks occur at the clock rate (60 or 50 times per second). ### DIRECT MEMORY ACCESS CHANNEL The direct memory access (DMA) channel permits channel-interfaced devices to directly access system memory locations for the purpose of entering or retrieving data. DMA channel devices effect their data transfers by stealing memory cycles from the central processor unit (CPU). A DMA request for access to memory always has priority over a CPU request. The maximum data transfer rate for the DMA channel is one million words per second. While the CPU is cycling without accessing memory (as in the execution of EAE arithmetic, EAE data shifting, or IOT instructions following their fetch from memory), DMA and CPU operations overlap; i.e., no time is lost to the CPU by DMA requests for access to memory. Where the operations do not overlap, the CPU operation is suspended until the DMA channel frees memory. The design of the PDP-9 system prohibits more than one memory bank of an expanded system from being active at any one time. The Type DM09A Adapter-Multiplexer, offered as a standard PDP-9 option, is a compatible high-speed interface by which up to three devices may be multiplexed to the DMA channel. Although users may design and fabricate an interface for say one device, the relative low cost and the additional benefit of DMA channel expansion at any time are strong recommendations for inclusion of the DM09A in a PDP-9 system. (The DM09A option is described on page 15-4). The RM09 Magnetic Drum system, described in chapter 5, page 5-37, is an example of a DMA device. # CHAPTER 10 CONTROLS AND INDICATORS The PDP-9 operator console, an integral part of the main computer frame, includes a work shelf and a control console (see figure 10-1) equipped with keys, switches, and indicators for operator control and monitoring of system operation ("key" in this context refers to a toggle switch). Typical console uses are: Manual entry of instruction and/or data; start/stop/continue control of program execution. Stepping through a program sequence by instruction or by machine cycle for debugging or maintenance purposes. Visual examination of register contents and/or of system status. Figure 10-1 Control Console Table 10-1 details the functional use of items on the control console. Indicators on the panel show the existing binary states of specific register bits and control flip-flops by being lighted for binary 1s and being extinguished for binary 0s. The operator console can be electrically locked by a control on the marginal-check panel to prevent undesired alteration of the program in progress. While the console is locked, operation of any key, switch, etc., will not affect the system. TABLE 10-1 OPERATOR CONSOLE CONTROLS AND INDICATORS | Name | Function | | | |--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | START key | Three positions: off (center), operate (down, spring-loaded return), and continuous operate (up, latches). Depressing START starts program execution at the location specified by the ADDRESS switches. The continuous operate position is used for maintenance purposes. | | | | I/O RESET key | Two positions: off (center) and operate (down, spring-loaded return). Depressing key generates the CAF (clear all flags) instruction to clear all I/O device flags, clears the AC, MQ, and the link, turns off the real-time clock, program interrupt facility, and API system and disables the memory protection and extended memory modes. | | | | PROGRAM STOP key | Two positions: off (center) and operate (down, spring-loaded return). Operate halts program execution at completion of the current instruction. | | | | CONTINUE key | Three positions: off (center), operate (down, spring-loaded return), and continuous operate (up, latches). Depressing CONTINUE resumes program execution from the point at which it stopped. The continuous operate position facilitates use of the REPT (repeat) function for the single instruction and single step provisions. | | | | EXAMINE-EXAMINE NEXT key | Three positions: off (center), EXAMINE (up, spring-loaded return), EXAMINE NEXT (down, spring-loaded return). Raising key to EXAMINE transfers the contents of the memory location specified by the ADDRESS switches from memory to the MB. After the transfer, the contents of the ADDRESS switches appear in the AR as the address of the memory location examined. Depressing key to EXAMINE NEXT increments the contents of the AR by one and transfers the contents of the newly addressed memory location from memory to the MB. EXAMINE NEXT facilitates monitoring of sequential memory locations as the ADDRESS switches need only be set to the lowest memory location. The use of EXAMINE transfers the contents of this location to the MB and enters the lowest order address in the AR. Thereafter, use of EXAMINE NEXT step advances the addresses through the sequential memory locations. | | | Name **Function** DEPOSIT-DEPOSIT NEXT key Three positions: off (center), DEPOSIT (up, spring-loaded return), and DEPOSIT NEXT (down, spring-loaded return). Raising key deposits the contents of the ACCUMULATOR switches in the memory location specified by the ADDRESS switches. After the transfer, the contents of the ADDRESS switches appear in the AR as the address of the memory location in which the data was entered. Depressing key, increments by one the AR contents, and deposits the contents of the ACCUMULATOR switches in the memory location specified by the new address. DEPOSIT NEXT facilitates the entering of data and/or instruction words in sequential memory locations as the ADDRESS switches need only be set to the lowest order address. The DEPOSIT function deposits the first ACCUMULATOR switch word in this location and transfers the address to the AR. Thereafter, the DEPOSIT NEXT function step advances the addresses through the sequential memory locations. READ IN key Two positions: off (center) and operate (down, spring-loaded return). Depress key to initiate readin of paper tape punched in binary code (each set of three 6-bit lines read from tape forms one 18-bit computer word). Storage of words read in begins at the memory location specified by the ADDRESS switches. At the completion of tape readin, the computer reads the last word from core memory and executes it. Read in occurs at the selected repeat speed (see REPT SPEED). REPT (repeat) SPEED control With REPT switch and CONTINUE both up, the control establishes one of five speeds at which single-step or single-instruction operations repeat without operator intervention. The repeating speeds range from approximately 40 µsec (position 1) to 0.8 sec (position 5). REGISTER DISPLAY control and REGISTER indicators Twelve-position switch: Each position interrogates a specific register and displays its contents in the REGISTER indicators. REGISTER indicators display the contents of selected register only when machine TABLE 10-1 OPERATOR CONSOLE CONTROLS AND INDICATORS (continued) | Name | | Function | |--------------------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | REGISTER DISPLAY control and REGISTER indicators (continued) | | . Moving selection switch while program is running has The functions of the positions are as follows: | | | RDR | Display contents of the paper tape reader information buffer. | | | TTI | Display contents of the teleprinter keyboard information buffer. | | | STATUS | Display status of flags for I/O devices connected to status reading facility of I/O system (see figure 9-1 for standard status bit assignments). | | | API | Display activity of automatic priority interrupt system's four device-oriented priority levels. | | | DPY | Display 34 display x, y buffers. The x buffer is displayed in the nine most significant REGISTER indicators; the Y buffer is displayed in the nine least significant indicators. The least significant bit of each buffer is not displayed. | | | IO ADDR | Display 15-bit address word present on address lines of I/O bus for data channel and API operation. | | | IO BUS | Display 18-bit data word present on data lines of $\rm I/O$ bus for program controlled and data channel data transfers. | | | AC | Display contents of the AC. | | | AR | Display contents of the AR. | | | PC | Display contents of the PC and status bits as stored during this instruction. | | | MQ | Display contents of the MQ. | | | EAE | Display contents of the step counter. | | POWER ON-OFF switch | | application of primary power to the computer and to external hose power inputs are interfaced to it. | TABLE 10-1 OPERATOR CONSOLE CONTROLS AND INDICATORS (continued) | Name | Function | |--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ₹ PRTCT switch and indicator | The up position causes the memory protection mode to be entered by operation of the START key. In either position, the mode may be enabled or disabled by program control. While the console is locked, the switch is electrically in the down position, regardless of its actual position. The indicator is lit while the mode is in effect. (Memory protection is a system option.) | | EXD switch and indicator | The up position causes the extend mode of addressing to be entered by operation of the START key. In either position, the mode may be is enabled or disabled by program control. While the console is locked, the switch is electrically in the down position, regardless of its actual position. The indicator remains lit while the mode is in effect. (Extend mode is a system option.) | | CLK switch and indicator | The up position disables the real-time clock facility. The down position allows program control to enable or disable the clock. The indicator remains lit while the clock is enabled. While the console is locked, the switch is electrically in the down position, regardless of its actual position. | | SING STEP indicator and switch | The indicator lights when the associated switch is up. This enables the single-step mode which halts program execution at each machine cycle. Repetitive depressing of the CONTINUE key, while the mode is enabled, steps the program through the sequence one cycle at a time. When the console is locked, this switch is disabled. | | SING INST indicator and switch | The indicator lights when the associated switch is up. This enables the single instruction mode which halts program execution at completion of each instruction. Repetitive depressing of the CONTINU key, while the mode is enabled, steps the program through its sequence one instruction at a time. When the console is locked, this switch is disabled. | TABLE 10-1 OPERATOR CONSOLE CONTROLS AND INDICATORS (continued) | Name | Function | | |-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | REPT indicator and switch | The indicator lights when the associated switch is up. This enables the repeat function. This function causes operations initiated by actuation of CONTINUE, EXAMINE NEXT, or DEPOSIT NEXT keys to repeat while the key remains in an operate position. The REPT SPEED control establishes the rate of repetition. | | | ⊯ERROR switch and indicator | Placing the switch in the up position causes the computer to stop on a memory parity error. The down position of the switch enables an interrupt on memory parity error. The indicator lights to show detection of a parity error. The computer will not stop on error when the console is locked. (Memory parity is a system option.) | | | ADDRESS switches (3-17) | Establish a 15-bit core memory address to be entered in the PC by operation of the START key, or in the AR by operation of the EXAMINE or DEPOSIT key. Switch is placed up for a 1 bit and down for a 0 bit. The 13 switches to the right (5-17) set up the address of a location within the standard 8192-word memory block. The two switches to the left (3 and 4) are for extended memory addressing of locations, in up to three other 8192-word memory blocks of the system. | | | ACCUMULATOR switches | Establish an 18-bit data or instruction word to be read into memory by DEPOSIT or DEPOSIT NEXT operation, or to be entered in the AC by a programmed LAS (load ACCUMULATOR switches) instruction. Up position of the switch is a binary 1; down position is a binary 0. | | | PRGM STOP indicator | Lights when the "run" flip-flop has been cleared to stop program execution. | | | INSTRUCTION indicators | The five indicators reveal the contents of the IR, being lit for 1 bits and extinguished for 0 bits, to show the operation code of the instruction just executed or in progress, and indirect address occurrence. | | | DATA indicator | Lights to indicate that data channel activity is in progress; i.e., data is being transferred between core memory and a data channel I/O device via the I/O bus. | | TABLE 10-1 OPERATOR CONSOLE CONTROLS AND INDICATORS (continued) | Name | Function | | |--------------------------|---------------------------------------------------------------------|--| | PS ACTIVE indicators | Each indicator, relating to one of the API system's eight priority | | | | levels, individually lights to show the priority program interrupt | | | | request currently being serviced. The upper set of indicators shows | | | | activity resulting from device-initiated requests; the lower set of | | | | indicators show activity resulting from program-initiated requests. | | | | The priority levels for each set decrease in rank from left to the | | | | right with any device request having higher priority than any pro- | | | | gram request. | | | PIE indicator | Lights when the PI system has been enabled by program control. | | | LINK indicator | Shows the content of the link register. | | | MEMORY BUFFER indicators | Shows the contents of the MB register. | | | | | | # MARGINAL CHECK PANEL The marginal check panel (figure 10-2) is concealed behind the red hinged panel on the front of the central processor. Table 10-2 details the functions of the panel-mounted controls and indicators. Figure 10-2 Marginal Check Panel | Name | Function | | |----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Elapsed time meter | Indicates, to the nearest tenth of an hour, the cumulative number of hours in which the system has been in the "power on" state. Meter counts from 00000.0 to 99999.9. | | | Five-position switch | LOCK - electrically locks the control console. With the console in the locked condition, operation of any console control cannot affect the program in progress. | | | | NORMAL - Control console is not locked; all controls may be use | | | | MAINTENANCE – With the switch in this position and the REPT switch (control console) in the up position, the built-in maintenance test program circulates a self-incrementing count through all active CPU registers to verify both their operation and the international transfer paths. The program proceeds at the rate selected by the REPT SPEED control (control console). | | | | EXAMINE – simulates the "examine" function. With the switch in this position and the REPT switch (control console) in the up position, the CPU responds as if the EXAMINE key (control consowas being actuated at the rate selected by the REPT SPEED control (control console). With the REPT switch in the down (inoperative) position, each movement of the selector switch to position EXAMINE simulates an actuation of the EXAMINE key. | | | | DEPOSIT - Simulates the "deposit" function. With the switch in this position and the REPT switch (control console) in the up position, the CPU responds as if the DEPOSIT key was being actuated at the rate selected by the REPT SPEED control (control console). With the REPT switch in the down (inoperative) position each movement of the selector switch to position DEPOSIT simulates an actuation of the DEPOSIT key. | | | /oltmeter | Indicates the selected voltage output of the marginal check power supply. The center of the scale relates to the reference voltage selected, either +10 or -15 volts dc. Movement of the pointer to | | TABLE 10-2 MARGINAL CHECK PANEL CONTROLS AND INDICATORS (continued) | Name | Function | |-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Voltmeter (continued) | the right indicates an increase in magnitude for the marginal check voltage. Movement to the left indicates a decrease in magnitude for the marginal check voltage. | | Selector switch | Three positions: Center - off +10 MC - selects the +10-volt output of the marginal check power supply. -15 MC - selects the -15-volt output of the marginal check power supply. | | Adjustment knob | Establishes the marginal check voltage level of the selected output | # CHAPTER 11 INTRODUCTION TO INTERFACING PDP-9 offers a complete line of standard peripheral equipment and compatible interface controls. Selections from this line may be appended to a PDP-9 system at any time without modification of the central processor unit. Where applications require that the system operate special purpose equipment or user-designed external devices, the PDP-9 I/O control scheme affords simple and economical implementation of the necessary interfacing. This section contains information of interest to the interface designer. It describes the PDP-9 I/O facilities and defines the requirements for interfacing a device to them. The information presented includes: definitions of signal characteristics; timing relationships; and, where appropriate, schematic representations of typical interfaces configured from Digital's line of inexpensive FLIP CHIP hybrid integrated circuit modules. The PDP-9 is designed to be compatible with the 2 mHz, R series FLIP CHIP modules. Complete descriptions of all standard FLIP CHIP modules, compatible power supplies, and hardware (mounting panels, cables, etc.) can be found in the "Digital Logic Handbook", sent free of charge upon request to any of the Corporation's regional offices. Items are readily available for low cost fabrication of external devices and/or special interface controls. Customers are invited to consult Digital System and Application Engineering personnel for assistance in the design of devices and interface controls. Their knowledge of data processing disciplines and their applied experience in answering industrial and scientific needs offer fast resolution of data handling problems. Digital Equipment Corporation makes no representation that the interconnection of its circuit modules in the manner described herein will not infringe on existing or future patent rights. Nor do the descriptions contained herein imply the granting of license to use, manufacture, or sell equipment constructed in accordance therewith. #### CIRCUIT MODULES FOR INTERFACING The following FLIP CHIP circuit modules are typical of those recommended for use in fabricating device interfaces compatible with the PDP-9 I/O facilities. Their input, output, and power requirements are as specified in the "Digital Logic Handbook." | R107 R123 Diode Gate R200 R201 R201 R202 Flip-Flop R202 R203 Flip-Flop, Dual R204 R205 Flip-Flop, Quadruple R205 Flip-Flop, Dual Device Selector W500 High Impedance Follower W640 Pulse Amplifier Inverter | Type Number | Function Name | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------------------| | R200 R201 R202 R202 R203 R1ip-Flop, Dual R204 R204 R1ip-Flop, Triple R205 R1ip-Flop, Quadruple R205 Flip-Flop, Dual W103 Device Selector W500 High Impedance Follower W640 Pulse Amplifier | R107 | Inverter | | R201 R202 Flip-Flop R203 Flip-Flop, Dual R204 R204 Flip-Flop, Quadruple R205 Flip-Flop, Dual W103 Device Selector W500 W640 Pulse Amplifier | R123 | Diode Gate | | R202 R203 R204 R204 R205 Flip-Flop, Dual Flip-Flop, Quadruple Flip-Flop, Dual W103 Device Selector W500 High Impedance Follower W640 Pulse Amplifier | R200 | Flip-Flop | | R203 R204 R205 R1ip-Flop, Triple R205 Flip-Flop, Quadruple Flip-Flop, Dual Device Selector W500 High Impedance Follower W640 Pulse Amplifier | R201 | Flip-Flop | | R204 R205 Flip-Flop, Quadruple R205 Flip-Flop, Dual W103 Device Selector W500 High Impedance Follower W640 Pulse Amplifier | R202 | Flip-Flop, Dual | | R205 Flip-Flop, Dual W103 Device Selector W500 High Impedance Follower W640 Pulse Amplifier | R203 | Flip-Flop, Triple | | W103 Device Selector W500 High Impedance Follower W640 Pulse Amplifier | R204 | Flip-Flop, Quadruple | | W500 High Impedance Follower W640 Pulse Amplifier | R205 | Flip-Flop, Dual | | W640 Pulse Amplifier | W103 | Device Selector | | nior | W500 | High Impedance Follower | | B105 Inverter | W640 | Pulse Amplifier | | | B105 | Inverter | # LOGIC SYMBOLS The symbols used to indicate logic circuits and signals in the schematic illustrations included in this section are defined below. | Symbol | Represents | |---------------|----------------------------------| | | Negative or negative-going pulse | | <del></del> > | Positive or positive-going pulse | | | Negative level | | <del></del> | Positive level | | <del></del> | Direction of flow | | • | 15v load resistor clamped at -3v | # I/O COMMUNICATIONS The PDP-9 offers facilities for communicating with external devices by program control, data channel, and direct memory access (DMA). Devices using program controlled and data channel facilities interface to the I/O bus cables. DMA devices are interfaced to system memory module(s) via separate cables. Program controlled transfers may make use of direct, program interrupt (PI) or automatic priority interrupt (API) access of subroutines. The data rates, the latency times (i.e., the time which a device must wait before its request for service is answered), and the representative degrees of efficiency for the PDP-9 modes of I/O service are presented in table 11-1. The "direct" mode refers to program controlled transfers made to or from a single device without interruption by other I/O facilities. TABLE 11-1 DATA TRANSFER RATES | Mode | Data Rate<br>(maximum/typical) | Latency<br>(maximum/typical) | Efficiency | |--------|--------------------------------|---------------------------------------------------|--------------| | Direct | 100 kHz | | 10 % | | PI | 25 kHz/1 kHz | 45 µsec for one device; 100+µsec for two devices/ | 2 % | | API | 35 kHz/10 kHz | 30 µsec/50 µsec<br>(average per channel) | 3 % | | DCH | 250 kHz/50 kHz | 20 μsec/5 μsec | <b>2</b> 5 % | | DMA | l mHz | 2 μsec | 100 % | Chapter 12 describes the total I/O bus system interface. Subsequent chapters describe the interface requirements for use of the program controlled transfer mode (including use of the program interrupt control, input/output skip facility, input/output read status facility, and the automatic priority interrupt option), the data channel transfer mode, and the direct memory access (DMA) channel mode. # CHAPTER 12 THE I/O BUS The PDP-9 I/O bus consists of cables which chain link all I/O device controls to a common interface point at the central processor (figure 12-1). Each device control must have input and output connector provisions to receive the bus and pass it on to the next device. (DMA interfaced devices will have additional and independent DMA bus cabling, connecting the devices to the DMA channel interface at the system core memory banks.) The bus is the major I/O communication path for a PDP-9 configuration. It provides signal lines for command and data transmissions arising from programmed transfers, data channel transfers, and operation of the multilevel automatic priority interrupt, program interrupt, I/O status read, and I/O skip facilities. Figure 12-1 I/O Bus Connections #### PHYSICAL DESCRIPTION Two cables of 36 wire pairs each comprise the I/O bus cables. The ground sides of all pairs are commoned at the connectors. Female connector ends are used in device controls; male connectors are on both ends of the bus cables. The female connector is the DEC Type H800, available in the DEC Type 1943 (FLIP CHIP) Mounting Panel. The connector may be purchased separately. Two such connectors are needed for each device, one to bring in the I/O bus and one to send it out to the next device. Each such female connector receives the two male connectors of the two I/O bus cables. Each I/O bus cable is a DEC Type BC09 cable assembly; completed cables may be purchased. The connectors have a special locking provision which insures against accidental removal and, if properly strain relieved at each end, may be conveniently run between free standing cabinets. In free standing cabinet devices, the I/O connectors are located at the left (when viewed from wiring side) end of the lowest 1943 Mounting Panel. The "input" bus connector is to the left of the output connector. In devices requiring only a few mounting panels, the "input" bus connector is located at the lower left corner, the "output" connector at the upper left-hand corner. # I/O POWER The device <u>input</u> I/O bus cable connector must be supplied with -15 volts on each pin B. A total of 600 ma is required. The output cable connector need not be supplied with power. #### INTERFACE SIGNALS The following describes the function of all I/O bus signal lines linking the central processor with the external I/O devices. Electrical characteristics and line terminating requirements are included. Figure 12-2 illustrates the interface. Maximum total length of the I/O bus is 50 feet (15.24 meters). #### Data Lines Eighteen data lines constitute the bidirectional facility for transferring data in bytes up to 18 bits in length between the central processor and all I/O devices. Transfers are made on a dc basis with the processor or device allowing bus settling time before data on the lines is strobed into the receiving register. The data lines convey transfers between the AC and a selected device information buffer register for programmed transfers; they convey data between the MB and a selected device buffer register for data channel operation. The bidirectional characteristic requires that the device use unclamped collectors for data transmission to the processor. Emitter followers must be used in a device for data reception to avoid loading the bus on a dc basis. The data lines are terminated in the central processor by 15-ma clamped loads. #### **Output Control Signals** Seven output control signals are generated within the processor to effect specific functions in a selected device. The signals are bus driven at the CPU-I/O interface. <u>I/O Power Clear</u> - issued by power turn-on warm-up, by occurrence of a CAF instruction (mnemonic for clear all I/O flags), and by actuation of the I/O RESET key on the control console. The signal resets all flip-flops storing device-to-processor flag indications (e.g., ready, done, busy). It is developed as a 400 nsec, nominal width, negative-going pulse. Figure 12-2 I/O Bus Interface I/O Sync – issued every memory cycle. The signal may be used to synchronize I/O device control timing to execution of the program in progress. The signal is developed as a 400 nsec, nominal width, negativegoing pulse. IOP1, IOP2, IOP4 - microprogrammable signals to effect IOT instruction-specified operation within a selected I/O device. Processor automatically generates IOP2 and IOP4 for, respectively, data channel input and output transfers. Although they may be used for any control function, the common uses of the IOPs are: IOP1 - normally used in an I/O skip instruction to test a device flag. It may be used as a command pulse, but it cannot be used to initiate loading of or reading from a device buffer register. IOP2 - usually used to effect transfer of data from a selected device to the processor, or to clear a device register. It may not be used to determine a skip condition. IOP4 - usually used to effect transfer of data from the processor to a selected device register. It may not be used to determine a skip condition or to effect transfer of data from a selected device to the processor. The IOP signal occur as 1 µsec, nominal width, negative-going pulses. Read Status – issued by execution of the IORS instruction (mnemonic for input/output read status). Loads the AC with an 18-bit word containing device flag indications for devices interfaced to read status facility. The signal occurs as a 1 µsec, nominal width, negative-going pulse. The signal also occurs when the REGISTER DISPLAY switch (console) is placed in the STATUS position and the processor is stopped. Overflow – issued during the first cycle of a data channel transfer if the contents (2s complement) of the word counter assigned to the currently active data channel device become zero when incremented. This indicates that the program specified number of words will have been transferred at completion of the data channel transfer in progress. It is normally used to turn off the respective device, preventing further data channel action by that device until a service subroutine reinitializes the channel word counter and current address registers, and the program turns on the device request flag. The overflow signal may also be used to initiate a program interrupt through the program interrupt or automatic priority interrupt facilities for access to the initializing subroutine. The signal occurs as a 400 nsec, nominal width, negative-going pulse. # Device Selection Levels Detection of the current instruction as being an IOT causes the bit pattern placed in MB<sub>6-13</sub> at the fetch of the instruction to be bus driven and sent via eight bus lines to Type W103 Device Selection modules, contained in the control logic for each device. These eight levels form a 6-bit device selection code, DSO - DS5 (relating to MB<sub>6-11</sub>) and a subdevice or mode select code extension, SDO and SD1 (relating to MB<sub>12-13</sub>). Assertion, or binary 1, is defined as a -3v. Negation, or binary 0, is defined as ground level. Each W103 is configured for response to only one of the 64 possible DS codes. Cooperating pairs of W103s permit unique response to any of the 256 DS-plus-SD codes. Each selection code configured in a device permits the internal generation of up to three associated commands through the W103 ANDing of IOPs and the device selection code. # I/O RUN The I/O run signal is available at the interface for use as the interface designer requires. This bus driven level switches to the -3v level and remains there while the "run" flip-flop in the CPU is set. A ground level indicates that the "run" flip-flop has been cleared. #### Input Control Levels Six input control level signals arrive at the I/O control section in the central processor. These levels are at ground for assertion and at -3v for negation. Each signal line is terminated in the processor with a 15 ma clamped load. The line must be driven from the unclamped collector of a saturated transistor whose emitter is grounded. The individual functions of the input control levels are: Skip Request – the return of this level to the processor indicates that an IOT instruction test for a skip condition in a selected device has been satisfied (e.g., a test of ready status). The PC is subsequently incremented by one to effect a skip of the next instruction of the program in progress. Program Interrupt Request - a device delivers this level to request interruption of the program in progress. The program traps to location 00000 when no I/O transfer action of higher priority is in progress. The instruction resident in location 00001 is fetched and executed. This instruction is usually a JMP to a subroutine which determines through a search process ("skip chain") the device making the program interrupt request. Access is then made of the appropriate service subroutine. Up to 64 devices may be interfaced to the program interrupt request line. The limiting factor is solely the program overhead incurred in the search for the requesting device. Read Request - this level requests that the processor execute a read transfer of device-offered data word. Write Request - this level requests that the processor execute a data channel write transfer of a data word into the selected device's information register. Who a $\underline{\mathsf{MB}}$ Increment - this level requests that the processor increment by one the contents of the memory location addressed by the 15-bit address on the I/O bus address lines. The provision is available when the Type KH09A Add-to-Memory option is included. Current Address Inhibit - this is a special signal line required by devices which automatically search for records, etc. Typical are DECtape and magnetic tape. The presence of the level inhibits normal incrementing of the device-assigned current address register during a data channel transfer. #### Multiplexed Control Lines Fifteen control lines, constituting five multiplexed subsets of three lines each, provide processor-device control information paths for the multiplexed data channel and the four priority levels on which the automatic priority interrupt option processes device channel requests for service. The functions of the lines in the subsets are as follows: Request - a device transmits a service request to the processor via the appropriate request line. Each request line is terminated in the processor by a 15-ma clamped load. The line must be driven to ground for assertion by an unclamped collector of a saturated transistor whose emitter is grounded. Grant - the processor indicates a grant of the service request by driving the associated grant line negative. All grant lines are buffered by bus driver modules in the processor. Enable – the enable signal controls the priority order for answering service requests of devices interfaced to the data channel control or to one of the API's 28 device channels. Each API channel may be uniquely assigned to one device for fast access of the appropriate service subroutine, or interfaced to any number of devices. The latter case requires a search subroutine to determine the requesting device. Priority for a channel (data or API) is allocated in descending order from the device nearest the processor I/O bus interface. Occurrence of an enable signal permits service of the requesting device with the highest channel priority and inhibits all lower priority devices from making requests during the interval of service. A bus driver module in the processor buffers each enable line. ### Address Lines Fifteen lines, of which only the least significant six are normally used, constitute an input bus for the devices which must deliver address data to the processor. The lines are terminated in the processor by 15-ma clamped loads. Each line must be driven to ground for assertion by an unclamped collector of a saturated transistor whose emitter is grounded. There are two uses for the address bus: - 1. When a device interfaced to the multilevel, automatic priority interrupt option receives a processor grant of its interrupt request, it delivers to the processor a hardware-defined address, relating to its API channel assignment. This channel address indicates the unique entry point to the device's service subroutine. The instruction resident in the addressed memory location is always a JMS (or JMS I or XCT of a JMS), offering fast access to the appropriate service routine. - 2. When a data channel device receives a processor grant of its transfer request, it delivers to the processor a hardware-defined address, relating to the memory location of the assigned channel word counter register. ### Driving Address and Data Lines Connection to the Address Lines and Data Lines is made by AND gates without clamp loads. Each gate must be capable of driving 30 mils at ground. Suggested gates include the S123 and the R111. The R111 requires a 2 mil clamp load tied to its input mode to deliver the required current. # I/O BUS INTERFACE SUMMARY The following summarizes the I/O bus interface at the processor. Figure 12-3 illustrates the key for determining the connector and associated pin for each bus line. Provision is made for two I/O bus connections at the computer; I/O block #1, and I/O block #2. Figure 12-3 Interface Connectors and Pins #### Reference Symbols: CO - Collector Output, no clamped load, normally Type R111 or S123. Can drive a 30-ma load at ground. 0-ma load at -3v. BD - Bus Driven output. Can drive 25-ma load at ground, 7-ma load at -3v. TABLE 12-1 I/O BUS INTERFACE CHART | I/O Block #1 | I/O Block #2 | Туре | Assertion | Signal Name | |--------------|--------------|------|---------------------------------------------------|--------------| | A25D | A29D | СО | $\diamond$ | I/O BUS 00 | | A25E | A29E | CO | $\Diamond$ | I/O BUS 01 | | A25H | A29H | CO | $\Diamond$ | I/O BUS 02 | | A25K | A29K | CO | <b>Ö</b> | I/O BUS 03 | | A25M | A29M | CO | $\Diamond$ | I/O BUS 04 | | A25P | A29P | co | $\Diamond$ | I/O BUS 05 | | A25S | A29S | co | $\Diamond$ | I/O BUS 06 | | A25T | A29T | co | $\Diamond$ | I/O BUS 07 | | A25V | A29V | CO | <b>\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\</b> | I/O BUS 08 | | A26D | A30D | BD | • | I/O SYNC | | A26E | A30E | BD | | IOP 1 | | A26H | A30H | BD | • | IOP 2 | | A26K | A30K | BD | • | IOP 4 | | A26M | A30M | CO | $\Diamond$ | SKIP RQ | | A26P | A30P | CO | | PROG INT RQ | | A26S | A30S | CO | $\Diamond$ | READ RQ | | A26T | A30T | BD | • • • • • • • • • • • • • • • • • • • | RD STATUS | | A26V | A30V | BD | • | I/O PWR CLR | | A27D | A31D | BD | • | I/O RUN (1) | | A27E | A31E | _ | | ADD OVFLO | | A27H | A31 H | BD | • | I/O OVFLO | | A27K | A31 K | CO | $\Diamond$ | I/O ADDR 03 | | A27M | A31M | CO | $\Diamond$ | I/O ADDR 04 | | A27P | A31P | CO | $\Diamond$ | I/O ADDR 05 | | A27S | A31 S | CO | $\Diamond$ | 1/O ADDR 06 | | A27T | A31T | CO | • | I/O ADDR 07 | | A27V | A31V | СО | <b>\langle</b> | I/O ADDR 08 | | A28D | A32D | CO | ♦ | WRITE RQ | | A28E | A32E | CO | $\Diamond$ | INC MB | | A28H | A32H | CO | $\Diamond$ | +1 → CA INH | | A28K | A32K | CO | $\Diamond$ | API 0 RQ | | A28M | A32M | BD | • | API 0 GR (1) | | A28P | A32P | BD | • | API 0 EN | | A28S | A32S | CO | $\Diamond$ | API 1 RQ | | A28T | A32T | BD | <ul><li>♦</li><li>♦</li><li>♦</li><li>♦</li></ul> | API 1 GR (1) | | A28V | A32V | BD | • | API 1 EN | | B25D | <b>B2</b> 9D | CO | $\Diamond$ | I/O BUS 09 | | B25E | B29E | CO | $\Diamond$ | Í/O BUS 10 | | B25H | B29H | CO | $\Diamond$ | I/O BUS 11 | | B25K | B29K | CO | $\Diamond$ | I/O BUS 12 | | B25M | B29M | CO | $\Diamond$ | I/O BUS 13 | | B25P | B29P | CO | $\Diamond$ | I/O BUS 14 | | B25S | B29S | CO | $\Diamond$ | I/O BUS 15 | | B25T | B29T | CO | <b>\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\</b> | I/O BUS 16 | | B25V | B29V | CO | $\Diamond$ | I/O BUS 17 | TABLE 12-1 I/O BUS INTERFACE CHART (Continued) | I/O Block #1 | I/O Block #2 | Туре | Assertion | Signal Name | |--------------|--------------|------|-------------------------------------------------------------|--------------| | B26D | B30D | BD | • | DS 0 | | B26E | B30E | BD | • | DS 1 | | B26H | B30H | BD | • | DS 2 | | B26K | B30K | BD | • | D\$ 3 | | B26M | B30M | BD | • | DS 4 | | B26P | B30P | BD | • | DS 5 | | B26S | B30S | - | | SPARE | | B26T | B30T | BD | • | SD 0 | | B26V | B30∨ | BD | • | SD 1 | | B27D | B31 D | СО | $\Diamond$ | I/O ADDR 09 | | B27E | B31 E | CO | <b>\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\</b> | Í/O ADDR 10 | | B27H | B31 H | CO | $\Diamond$ | I/O ADDR 11 | | B27K | B31 K | CO | $\Diamond$ | I/O ADDR 12 | | B27M | B31M | CO | $\Diamond$ | I/O ADDR 13 | | B27P | B31P | CO | $\Diamond$ | I/O ADDR 14 | | B27S | B31 S | CO | $\Diamond$ | I/O ADDR 15 | | B27T | B31T | CO | $\Diamond$ | I/O ADDR 16 | | B27V | B31V | CO | $\Diamond$ | I/O ADDR 17 | | B28D | B32D | со | $\Diamond$ | API 2 RQ | | B28E | B32E | BD | • | API 2 GR (1) | | B28H | B32H | BD | • | API 2 EN | | B28K | B32K | CO | $\Diamond$ | API 3 RQ | | B28M | B32M | BD | • | API 3 GR (1) | | B28P | B32P | BD | <ul><li>♦</li><li>♦</li><li>♦</li><li>♦</li><li>♦</li></ul> | API 3 EN | | B28S | B32S | CO | $\Diamond$ | DCH RQ | | B28T | B32T | BD | • | DCH GR (1) | | B28V | B32V | BD | • | DCH EN | NOTE: All pins C, F, J, L, N, R, U, should be connected together and wired into the ground mesh of the device. # CHAPTER 13 PROGRAM CONTROLLED TRANSFERS The majority of I/O transfers occur under control of the program, taking advantage of control elements present both in the computer and in the device controls interfacing to the I/O bus. Program-controlled transfers require more computer and actual time than data channel and direct memory access transfers, but the simplicity and inherent lower cost of the device controls coupled with the high speed of the computer relative to the operational speed of most peripheral devices offset this extra cost in time. All programmed I/O transfers take place through the accumulator (AC) in bytes up to 18 bits in length. In transfers within the central processor, and between the processor and core memory, data are processed as 18-bit words, the sole addressable unit in the PDP-9. For bytes of less than 18 bits, unused bits in the data word normally remain zeroed. Programming techniques of masking and shifting the contents of words are also used to pack and unpack bytes of less then 18 bits, to reduce core memory storage requirements. The rate of programmed transfers is a function of the device characteristics and the program manipulation required for each data byte transferred. The IOT instruction capability of the PDP-9 allows programmed control of up to 256 devices, as well as the generation of up to three unique commands for each of the 256 possible device selection codes. Devices requiring more than three internal commands are assigned additional device selection codes. The bussed system of input/output data transfers imposes the following requirements on peripheral equipment using the programmed data transfer facility: - 1. The ability of each device to sample the select code generated by the computer during IOT instructions and, when selected, to be capable of producing sequential command pulses in accordance with computer-generated IOP pulses. Circuits performing these functions in peripheral devices are called device selectors (DS). A single double-sized module, the W103, provides all of these functions. - 2. Each device receiving output data from the computer must contain gating circuits at the input of a receiving register capable of strobing the data on the I/O bus into the register when triggered by a command pulse from the DS. Such gates are called device input gates. - 3. Each device supplying input data to the computer must contain gating circuits at the output of the transmitting register capable of strobing the information from the output register to the I/O bus, and furnishing a read request signal level to the computer when triggered by a command pulse from the DS. Such gates are called device output gates. - 4. Each device must contain a busy/done flag (flip-flop) and gating circuits that can output a signal to the computer input/output skip bus upon command from the DS. The flag is set to indicate that the device is ready to transfer another byte of information. # INPUT/OUTPUT TRANSFER INSTRUCTIONS Input/output transfer (IOT) instructions initiate transmission of signals through the I/O bus to control peripheral devices, sense their status, by means of the I/O skip facility, and effect programmed transfers between them and the processor. A PDP-9 IOT instruction has the format shown in figure 13-1. \* 10P4 IS ASSIGNED TO THIS BIT BECAUSE OF ITS BINARY RELATIONSHIP TO THE OTHER 10P BITS. THERE IS NO 10P3. Figure 13-1 PDP-9 IOT Instruction Format The PDP-9 IOT instruction has the following characteristics: - 1. An operation code of $70_8$ . - 2. An 8-bit device selection code to discriminate among up to 256 peripheral devices (selection logic in a device's I/O bus interface responds only to its preassigned code). In normal practice, bits 6 through 11 perform the primary device discrimination among up to 64 devices, with bits 12 and 13 coded to select an operational mode or subdevice. Table 13-1 indicates the device selection codes assigned to standard PDP-9 device and facilities. Codes not so used are available for assignment to user-designed interfaces or special-purpose equipment. | | | | -0 | <u></u> | | | | |--------------------------------------------------|-------------------------------------------------------------------|-------------------------------------------|--------------------------------------------------------|--------------------------------------------------|------------------------------------------------|------------------------------------------|-----------------------------------------------| | 70 | 71 Disc<br>RB09 | 72 | 73 Tape Control<br>TC59 | 74 Tape Control<br>TC59 | 75 DECtape<br>Control<br>TC02 | 76 DECtape<br>Control<br>TC02 | 77 Memory<br>Extension<br>KG09A | | 60 Drum<br>RM09 | 61 Drum<br>RM09 | 62 Drum<br>RM09 | 63 | 64 | 65 Automatic<br>Line Printer<br>Type 647 | 66 Automatic<br>Line Printer<br>Type 647 | 67 Card Reader<br>Type CR01E<br>or Type CR02B | | 50 | 51 | 52 | 53 | 54 | 55 Automatic<br>Priority<br>Interrupt<br>KF09A | 56 | 57 | | 40 LT09A<br>Line 1<br>Teleprinter | 41 LT09A<br>Line 1<br>Keyboard | 42 LT09A<br>Line 2<br>Teleprinter | 43 LT09A<br>Line 2<br>Keyboard | 44 LT09A<br>Line 3<br>Teleprinter | 45 LT09A<br>Line 3<br>Keyboard | 46 LT09A<br>Line 4<br>Teleprinter | 47 LT09A<br>Line 4<br>Keyboard | | 30 | 31 | 32 | 33 I 33 KSR Skip<br>2 Clear All<br>Flags<br>4 DBR, DBR | 34 | 35 | 36 | 37 | | 20 Memory<br>Increment<br>KH09A | 21 Relay Buffer<br>DR09A | 22 | 23 | 24 Incremental<br>Plotter<br>Control<br>Type 350 | 25 | 26 | 27 Memory<br>Parity<br>MP09 | | 10 Symbol<br>Generator<br>Type 33 | 11 Analog-to-<br>Digital or<br>Digital-to-<br>Analog<br>Converter | 12 A/D or<br>D/A<br>Converter | 13 A/D<br>Converter | 4 | 15 | 92 | 17 Memory<br>Protection<br>KX09A | | 00 1 RT Clock<br>2 Prog. Interrupt<br>4 RT Clock | 01 Standard<br>Perforated –<br>Tape Reader | 02 Standard<br>Perforated -<br>Tape Punch | 03 1 Keyboard<br>2 Keyboard<br>4 IORS | 04 Teleprinter | 05 Displays<br>Types 34F,<br>30D, or 340 | 06 Displays | 07 Display<br>and<br>Light Pen | Table 13-1 Assigned PDP-9 IOT Device Selection Codes 3. A command code (bits 14 through 17) capable of being microprogrammed to clear the AC, and issue up to three pulses through the I/O bus. Any IOT instruction may be microcoded to produce more than one IOP pulse by setting one, two, or three bits of bits 15–17 of the instruction word to a 1. The resulting device IOT pulses appear in the time sequences defined by the IOT timing diagram (see figures 13–2 and 13–3). Figure 13-2 IOT Timing Diagram Figure 13-3 IOT Pulse Waveforms The MB bits corresponding to the device selection levels are buffered by B213 Bus Drivers. Bus driver outputs are labeled $DS_0$ - $DS_5$ (device selector), with the following correspondence: | MB <sub>6</sub> | DS <sub>0</sub> | |------------------|-----------------| | MB <sub>7</sub> | DS | | MB <sub>8</sub> | $DS_2$ | | MB <sub>9</sub> | DS <sub>3</sub> | | MB <sub>10</sub> | DS <sub>4</sub> | | MB11 | DS <sub>5</sub> | MB bits 12 and 13 are also bus driven, and available at the interface as sub-device bits (SD). These are labeled: | MB <sub>12</sub> | SD <sub>0</sub> | |------------------|-----------------| | MB <sub>13</sub> | SD <sub>1</sub> | Each peripheral device contains <u>at least</u> one Device Selector module W103. This module produces specific device IOT pulses upon receipt of a unique 6-bit device selection code (device number) and the IOP pulses. For example the instruction: #### 703401 applies 34<sub>8</sub> to the I/O bus device selection lines. The device selector module in device no. 34 responds and, at IOP1 time, issues IOT 3401. The device number of any W103 is determined by clipping out diodes from the board. (See figure 13-4.) The usual use of the three IOPs is given below. IOT Pulse 1 - normally used in an I/O skip instruction to test a device flag. May be used as a command pulse, but not to initiate either a "load" or "read" from a device. IOT Pulse 2 – usually used to transfer data from the device to the computer, or to clear a register. May not be used to determine a "skip" condition. IOT Pulse 4 - usually used to transfer data from the computer to the device. May <u>not</u> be used to determine a "skip" condition or to effect transfer of data from a selected device to the processor. ### Reading a Device Buffer into the AC The reading of a device buffer into the computer is accomplished in the following manner: - 1. IOT pulse 2 is generated in the device selector module, and used to trigger a W640 Pulse Amplifier (which must be in each input device) jumpered to produce 1-µsec pulses. - 2. This 1-usec pulse is used to gate the device data buffer onto the I/O data bus. - 3. Simultaneously a read request positive pulse is generated (by an R111 or S123) on the read request line. - 4. The central processor receives the request signal and allows time for the data bus to settle completely. - 5. The I/O Bus is strobed into the AC. Figure 13-4 Device Selector Configuration Figure 13-5 Loading the AC from a Device Buffer \*The output of the W640 ought to be a 1- $\mu$ sec pulse, which is regarded by the I/O bus system as a level. Either pulse or level notation may be used, provided this definition is kept in mind. Since the I/O bus is ORed into the AC (figure 13-5), the read IOT instruction is usually microprogrammed to clear the AC prior to reading (i.e., MB14=1). I/O waveforms are shown on figure 13-6. Figure 13-6 I/O Signals from Buffer to I/O Bus ## Loading a Device Buffer from the AC The loading of a device buffer from the AC (figure 13-7 and 13-8), is <u>usually</u> accomplished by, but not restricted to, the following two steps. The first IOT clears the device buffer, and the second IOT ORs the contents of the AC into the cleared buffer. For such a transfer, the details are as follows: 1. Prior to the end of the first cycle the AC is placed onto the I/O bus. Note that in any output transfer, IOPI must <u>not</u> be used to transfer the AC to an external register. - 2. IOT2 is generated in the Device Selector module W103, and transmitted to all "clear" inputs of the flip-flops in the device buffer. - 3. IOT4 is generated in the W103 and applied to the DCD input gates of the device buffer. Note that the input DCD gates for each bit in each outure device must be buffered from the I/O bus by Emitter Followers W500. Figure 13-7 Loading a Device Buffer from AC Figure 13-8 I/O Signals from I/O Bus to Buffer #### I/O SKIP FACILITY When IOT pulse 1 is used in a I/O skip instruction (example CLSF = IOT 0001 = 700001), it is gated with the device flag flip-flop through a diode gate and returned to the computer on the I/O skip request bus line. A positive pulse, 1 µsec wide, is returned to the processor, if the tested flag is a binary 1. The skip flip-flop in the processor is set, and the instruction following the IOT instruction in the program sequence is not executed -- it is skipped. The 15 ma to -15v load for the skip bus line is located at its termination in the processor. The signal on the skip line is sampled 600 nsec after IOP1 is is sued. An R111 without a clamped load or a S123 Diode Gate must be used in the device. The sensing of a device flag (figure 13-9) is accomplished in the following manner: - 1. IOT pulse 1 is generated in the device selector module. - 2. This pulse is gated with the 1 output of the device flip-flop (i.e., flag) through a diode gate (unclamped R111 or S123) tied to the "I/O skip line". - 3. If (and only if) the sensed flag is in the 1 state, a 1-4 sec pulse is returned to the central processor via this I/O skip line. - 4. This pulse sets the I/O skip flip-flop in the processor. In this instance, the instruction following the IOT instruction is not executed. Figure 13-9 Device Flag Hardware #### STATUS WORD FACILITY The IOT instruction IORS (=IOT 0314 = 700314) loads the accumulator with a word comprised of various device flags and control flip-flops. External devices, having status bits assigned, use the read status level to gate the device flag onto the corresponding I/O bus bit line. (Bits 15, 16, and 17 have been reserved for special customer devices.) The status word is readable at the console when the register function switch is in the STATUS position. Figure 9-1 illustrates the AC bit positions associated with the standard IORS assignments. ### PROGRAM INTERRUPT (PI) FACILITY When computer time is at a premium, it is advantageous for the computer to perform other tasks rather than wait for some peripheral device to complete its operation. The program interrupt facility allows the program to ignore the peripheral device until it signals completion of operation. At that signal, the computer program can enter a subroutine to service the device. In case several devices are connected to the PI, a chain of I/O skip instructions and JMPs are issued by the program to determine which device caused the interrupt. If the computer is servicing an API initiated interrupt, a PI request is not granted until all the API channels are dismissed. Figure 13-9 shows the device hardware required for the program interrupt facility. The device flag is connected to the program interrupt request line by a Type R111 or S123 Diode Gate (unused input left floating). This request line is terminated in a 15-ma clamped load in the computer I/O frame. Interrupts occur only when the program interrupt facility is enabled. IOT instructions associated with the PI are: IOF = IOT 0002 = 700002 turn off PI ION = IOT 0042 = 700042 turn on PI When an interrupt is recognized, the computer stops execution of the main program. The 15-bit address of the next main program instruction and certain flags are stored in memory address 00000. The word is stored as shown on figure 13-10. Figure 13-10 Program Interrupt Storage Word # AUTOMATIC PRIORITY INTERRUPT, Type KF09A In real-time computer systems such as the PDP-9, a small number of peripheral devices with relatively few timing problems or priority considerations can be handled quite easily by the standard program interrupt facility without a significant loss in central processor efficiency. However, if the number of peripherals is large, with a hierarchy of priorities, or the desired data rate is over 50,000 words per second, significant economies in central processor overhead time can be achieved by the use of a multi-channel automatic priority interrupt system. The Type KF09A Automatic Priority Interrupt (API) option for the PDP-9 provides the necessary hardware to handle a multiplicity of input/output devices with a minimum of programming effort and a maximum of efficiency. Its priority interrupt structure permits high data rate devices to interrupt the service routines of slower devices with a minimum of system overhead. The API also permits the device service routines to be entered directly from hardware-generated entry points, eliminating the need for time-consuming flag searching to determine the identity of the device causing the interrupt. The Type KF09A provides thirty-two channels, or unique entry points for device service routines, and eight levels of priority. The four highest priority levels are for device service requests, and interrupts on these levels are initiated by hardware service requests (i.e., device flags). The four lower priority levels are assigned to the processor for software routines; activities on these levels are always initiated by program requests, and four channels (or service routine entry points) are reserved for these priority levels. Each device interfaced to the Automatic Priority Interrupt system must specify its "trap address" or unique entry point to its service routine. Locations $40_8-77_8$ are reserved as these service routine entry points, and "trap addresses" and channel numbers are related as follows: $$(TRAP ADDRESS)_8 = (CHANNEL NUMBER)_8 + (40)_8$$ Locations $40_8 - 77_8$ should contain JMS or JMS I instructions to provide linkage to the actual service routines. Table 13-2 shows the relationship between channel number and trap address, the channel assignments for standard PDP-9 I/O devices, and their suggested priority levels. All devices listed in Table 13-2 are connected to the API as shown, if the API option is purchased. The channel number-assignments should remain fixed for software compatibilty, but priority levels may be changed at the user's option. TABLE 13-2 CHANNEL AND PRIORITY ASSIGNMENTS | Channel<br>Number<br>Octal | Trap<br>Address | Standard Device | Suggested<br>Priority<br>Level | IO ADDR<br>Bits 12-17 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>20<br>21<br>22<br>23<br>24<br>25<br>26<br>27<br>30<br>31<br>32<br>33<br>34<br>35 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>50<br>51<br>52<br>53<br>54<br>55<br>56<br>57<br>60<br>61<br>62<br>63<br>64<br>65<br>66<br>67<br>70<br>71<br>72<br>73<br>74<br>75 | Software channel 0 Software channel 1 Software channel 2 Software channel 3 DECtape (TC02) Magtape (TC59) Drum (RM09) Disk Papertape Reader Clock Overflow Power Fail (KP09) Parity (MP09) Light Pen (34H) Card Readers (CR01E, CR02A) Line Printer (647) A/D (AF01) DB99A/DB98A Data Link to System 360 Data Phone (DP09A) Reserved for Systems Device | 4<br>5<br>6<br>7<br>1<br>1<br>1<br>2<br>3<br>0<br>0<br>0<br>2<br>2<br>2<br>2<br>0<br>3<br>3<br>3<br>2 | 100 000 100 001 100 010 100 011 100 100 100 101 100 110 100 111 101 000 101 001 101 101 101 110 101 111 110 000 110 001 110 010 110 011 110 110 110 110 110 110 110 110 111 110 110 110 111 110 111 110 111 110 111 110 111 111 111 000 111 011 111 111 111 000 111 011 111 111 111 000 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 111 | | 36<br>37 | 7 <b>6</b><br>77 | • | | 111 110<br>111 111 | Devices are interfaced to the API in the same manner as they would be to the Program Interrupt (PI) facility for all signals except the device flag. For API devices, the device flag is tied to one of the API levels on the I/O bus through a W104 module in the device interface. (Device flags tied to an API level should not be tied to the PI also.) The W104 module is used to establish priority among devices tied to the same priority level; it also gates the trap address (channel number) onto the I/O Address (IO ADDR) lines at the appropriate time and sends a Clear Flag (CR FLG) pulse to the device to clear its device flag. Figure 13-11 shows the W104 module and its pin connections. Figure 13-11 W104: PDP-9 I/O Bus Multiplexer As Table 13-2 shows, there need not be any fixed relationship between channel number and priority level (except for the four software priority levels). The priority interrupt level of a device may be chosen by the user; it is determined by the set of lines to which the user interfaces. The I/O bus contains twelve lines unique to the API; these include an API RQ (request), API GR (1) (grant), and API EN (enable) line for each of the four levels. Since these control lines are part of the standard I/O bus and pass through all devices, it is relatively easy to change a device's priority by disconnecting from one set of lines and attaching it to another. Because of the time delay encountered in propagating signals through a W104 module, no more than eight devices should be interfaced to one priority level. Figure 13-12 shows an example of four devices tied to the API (only API-related lines are shown). In this example, the following relationship exists between device number and priority level. | Device | Priority Level | |--------|----------------| | Α | 3 | | В | 2 | | С | 0 | | D | 2 | Figure 13-12 Devices on the Automatic Priority Interrupt If all four devices request service simultaneously, they are serviced in the following order: C, B, D, and A. Although B and D are on the same priority level, device B is serviced before D because it is closer to the computer on the I/O bus. Each W104 module contains six address selection lines (pins AJ, AK, AL, AN, AS, AU). These lines are normally connected to the IO ADDR lines of the I/O bus to form the trap address. For standard API devices, pin AJ is connected to line 12 (40<sub>8</sub>) and pins AK-AU from the channel number. In some cases, trap addresses above $77_8$ may be used, although standard PDP-9 peripherals should be restricted to $40_8$ - $77_8$ . Figure 13-13 shows the possible connections for trap addresses between $100_8$ and $137_8$ . Figure 13–13 Connections for Trap Addresses Between $100_8$ and $137_8$ If a single device is required to generate a number of different addresses on the basis of a single flag, the W104 can be used to gate the address from a flip-flop register onto the IO ADDR lines. Figure 13-14 shows an example of this situation. Figure 13-14 Gating Flip-Flop Register onto I/O Address Lines Figure 13–15 shows the case of a single device with multiple flags, any one of which can cause a trap to a unique address. In this case, the different flags are all tied into the same request line. They may be tested individually by IOT instructions (I/O SKIP), so they should also be tied to the I/O SKIP line. They are also cleared individually, as shown. The flags are also connected to the ENA (1) line (as shown) to assure that the ENA flip-flop will be cleared when all of the flags are cleared, regardless of whether or not the API break is granted. Figure 13-15 Single Device with Multiple Flags # CHAPTER 14 DATA CHANNEL The PDP-9 data channel, multiplexed to permit interfaced service to four peripheral devices, provides a relatively high-speed interface to the core memory along the I/O bus. Requests for data from I/O devices are honored by the channel at the completion of the instruction in progress at the time the grant signal is issued. The channel is controlled by word count and address registers held in core memory; each request updates these registers, and transfers the data between the memory and the device. Each of the four devices has a unique pair of (sequential) core memory registers associated with it. (The system software assumes that these are registers 30–37<sub>8</sub>.) These registers must be initialized by the program, before the peripheral device may begin transferring data through the channel. The first (word count) register, of lower numerical value, must be even, and is initialized to contain the 2's complement of the number of words to be transmitted. The second (address) register is initialized to contain 1 less than the first address of the data word block. These registers may be examined at the end of channel operation to check for final address, if, for example, the device indicates that a short record was read. Peripheral devices normally issue a program interrupt (API) request at the completion of the transfer when the word count register has counted up to 0. The maximum transfer capacity of the channel is between 250,000 and 333,000 words per second, depending on the mix of input and output rates. Each input transfer steals three processor cycles; each output transfer steals four processor cycles. The latency time (maximum wait before service is granted after a request is made) may be as high as 30 µsec under adverse conditions (see latency section). Special care is necessary, however, when designing software for devices whose channel usage is greater than 50,000 words per second. Priority among I/O devices making simultaneous requests is determined by their physical placement on the I/O bus, with devices closer to the processor having priority over devices further away. The establishment of priority requires that each device quickly propagate an enable signal to the next device on the bus, and a special module, the W104 Bus Multiplexer, has been designed for this purpose. #### **LATENCY** Since data channel requests are only honored between instructions, the type of instruction in progress determines the waiting time until the interrupt is granted. The following considerations apply: - 1. The IOT instruction is noninterruptible. The interrupt request is honored at the completion of the instruction which follows the IOT. - 2. The EAE instructions delay interruption until they complete, which may be as long as $17 \, \mu sec$ . - 3. The XCT instruction is noninterruptible. The interrupt request is honored at the completion of the instruction referenced by the XCT. - 4. Lower priority devices wait for the completion of data transfers on the requesting higher priority channel. Hence, if four requests come up simultaneously, the lowest may wait 12 µsec, and indefinitely if a higher priority device is taking successive breaks. Long XCT chains on sequential IOT instructions can lock out channel requests for indeterminate periods of times. These are to be avoided in programs operating devices requiring short latency. EAE instructions requiring more than 12 µsec are uncommon, but possible. Unfortunately, requests tend to stack up during these waiting periods, so that lower priority devices must wait even longer. I/O system design must insure that the latency time requirement of each peripheral is satisfied. #### DEVICE INTERFACE HARDWARE Each device connected to the data channel must have the interface hardware outlined below. The first four requirements are essentially the same as those met by devices connected to the program interrupt. They insure that the device hardware may also be checked by maintenance routines using special IOT instructions. Requirements 5, 6, and 7 are met by the Type W104 Bus Multiplexer module, strongly recommended for use in the interface. Basic connection are shown on figure 14–1. The W104 is shown on figure 14–2. 1. Each device must have the ability to decode the 6-bit selection code transmitted by the processor on the device selection lines. When selected, the device must be capable of producing internal command pulses in response to IOP pulses transmitted on the bus. The module performing such functions in the peripheral device is called the device selector. Furthermore, the device must have the ability to force selection of the device selector, regardless of the address on the selection lines. The Type W103 Device Selector module possesses this property. - 2. Each device receiving output data from the computer must contain gating circuits at the input of the receiving register capable of strobing the I/O bus information into the register when triggered by a command pulse from the device selector. In addition, the device must supply a write request level to the channel during the period wherein it is selected. - 3. Each device supplying input data to the computer must include gating circuits at the output of the transmitting register capable of gating this register onto the I/O bus, when triggered by a command pulse from the device selector. In addition, the device must supply a read request level to the channel while it is selected. - 4. Each device must contain a request flag (flip-flop), which is set whenever the device is ready to receive (or transmit) another word of information. This flag is normally cleared when the transfer is complete. - 5. The device data flag is used to request a break through a synchronizing flip-flop, which drives the request line (DCH RQ). The device data flag must be cleared when the break is granted (DCH GR). - 6. Each device must be capable of propagating the enable signal (DCH EN) to the next device to establish priority of devices along the bus in case of simultaneous requests. The next device must be enabled if the current device is enabled, and is not itself requesting. - 7. Each device must contain the gating circuits necessary to transmit the core memory address of the word count register assigned to the device. The address is transmitted by the selected device upon receipt of the grant signal (DCH GR) from the channel. - 8. Each device must contain an "active" flip-flop which controls whether or not the device periodically requests data transfers through the channel. This flip-flop is normally turned on by the program with an IOT instruction, and off by the IO OVFLO signal transmitted to devices by the channel. Figure 14-1 Data Channel Configuration Figure 14-2 Type W104 Bus Multiplexer # INITIAL SEQUENCE OF DATA IN TRANSFER (TO COMPUTER) The device flag is raised asynchronously by some state change in the I/O device control or associated mechanical hardware. This flag is synchronized by the W104 Multiplexer, which requests a data channel interrupt through the DCH RQ line. If more than one device on the channel is requesting, the multiplexer insures that the lower priority device is shut out by driving its enable (DCH EN) input line to ground (disabled state). This request is recognized by the processor and, at the end of the current instruction, control is relinquished to the channel hardware. The channel hardware begins operation by identifying the device requesting service. This is performed by issuing a grant signal (DCH GR) to all connected devices. Upon receipt of the grant signal, the device which supplied the DCH RQ transmits the core memory address of its word count register along the I/O address lines. The specified register is read from memory, incremented, and rewritten. If, in this word count updating procedure, the count reaches 0, an I/O overflow signal is sent to all devices. The device hardware interprets the overflow signal as a shut down command. No further transfers are made until the device is re-initialized by the programmer. After incrementing the word count register, the channel reads the next sequential word from memory. This is taken as the current address register, which is incremented and rewritten into memory. The updated value is used to specify the location into (from) which the data is to be transferred. ## Operations Unique to Reading (Refer to Figure 14-3) If the read request (RD RQ) signal is present, and the write request (WR RQ) signal is not present, the transfer is taken as an into-computer data transfer. At the beginning of the second (current address) cycle, IOP2 is issued. At this time the device is expected to gate its data onto the I/O bus for subsequent readin by the channel. At the end of the second cycle, the data is read into the AR register. The third cycle stores the data word in the memory. This ends the sequence, and the channel relinquishes control to the processor. Figure 14-3 DCH In Transfer (To Computer) ### INITIAL SEQUENCE OF DATA OUT TRANSFER (FROM COMPUTER) This is the same as described in the previous In-transfer section. ### Operations Unique to Writing (Refer to Figure 14-4) If the write request signal is present, and the read request signal is not present, the transfer is taken as an out-of-computer data transfer. During the middle of the third (data) cycle, the channel places the requested data onto the I/O bus for subsequent readin by the device. The data remains available until the middle of the fourth cycle. At the beginning of the fourth cycle, IOP4 is issued instructing the device to clear its buffer, and to gate the data on the bus into its receiving register. DCD gates must be used. The sequence then ends, and the channel relinquishes control to the processor. Figure 14-4 DCH Out Transfer (From Computer) #### EXPANSION TO EIGHT DEVICES The number of devices connected to the channel is limited only by the maximum combined transfer rate capability and the propagation delay per device of the enable signal (DCH EN). Approximately 600 nsec are available between I/O SYNC and DCH GR, wherein the enable signal may propagate through the four multiplexers. This is always possible with maximum permissible I/O bus cable length and use of the Type W104 Bus Multiplexer module in each device. If cable lengths are kept to a minimum, it may be possible to attach more devices to the multiplexer. The limit with extremely short cabling and use of the W104 Bus Multiplexer is eight devices. ### SIGNAL DEFINITIONS See chapter 12 for details of I/O connector, as well as figure 14-5 for DCH timing. DCH RQ The request signal from the device to the channel indicating that the device requires service. The line must be driven by a saturated transistor whose emitter is grounded. A 15-ma load to -15v terminates the line at the processor. DCH EN A bus driven signal which establishes priority along the device. Each device must supply a noninverting bus driver with a total transition time of 100 nsec into 5 feet of bus cable. DCH GR A bus driven signal emanating in the processor which instructs the selected de- vice to transmit its address back to the processor. Maximum load is eight Type W104 Bus Multiplexer modules or equivalent. RD RQ The request signal from the device to the channel indicating that the device wishes the transfer to be in the "in" direction. The line must be driven by a saturated transistor whose emitter is grounded (R111 or S123). A 15-ma load to -15v terminates the line at the processor. WR RQ As RD RQ except specifies "out" direction. I/O ADDR Fifteen lines, of which only the least significant six are normally used. The de- vice transmits the address of the core memory register specifying word count along these lines. Loading is the same as RD RQ. I/O DATA Eighteen lines of bidirectional data transfer between the channel and the device. Loading is the same as RD RQ. Receiving registers in output devices must buffer the incoming lines with W500 Emitter Follower modules. +1 → CA INH A special signal line used by devices which automatically search. The presence of the +1 →CA INH signal inhibits the normal incrementing of the current address word driving the second cycle. Load is the same as RD RQ. MEM INC Load is the same as RD RQ. I/O OVFLO A pulse originating in the channel logic which indicates the transfer of the speci- fied number of data words has been completed. It is transmitted during the first cycle if the word count register increments to zero. Figure 14-5 DCH Timing #### ADD-TO-MEMORY CAPABILITIES With the add-to-memory capability, certain facilities are available. These include add-to-memory instructions, specified by sending both RD RQ and WR RQ, and memory increment, specified by sending a signal on the MEM INC line. The add-to-memory operation is a combination of reading and writing. The data transmitted by the device is added to the word read from memory and re-written into memory. The sum is transmitted back along the I/O bus. Four cycles are required. Since the sum is re-transmitted to the device at IOP4 time, the device may detect overflow. The memory increment operation is the first cycle only of a channel transfer. The word specified on the I/O address lines is incremented. An overflow signal (IO OVFLO) is transmitted to the device if the data word is incremented to 0. Maximum rate is 250,000 increments per second, but this may be unattainable if long instructions are encountered. (Refer to the section on latency.) # STANDARD CORE REGISTER ASSIGNMENT | Device | Word Count | Initial Address | |------------------------|------------|-----------------| | DECtape | 30 | 31 | | Magtape | 32 | 33 | | Interprocessor Buffers | 34 | 35 | | Not presently assigned | 36 | 37 | # CHAPTER 15 DIRECT MEMORY ACCESS CHANNEL The direct memory access (DMA) channel permits channel-interfaced devices to directly access system memory locations for the purpose of entering or retrieving data. DMA channel devices effect their data transfers by stealing memory cycles from the central processor unit (CPU). A DMA request for access to memory always has priority over a CPU request. The maximum data transfer rate for the DMA channel is one million words per second. While the CPU is cycling without accessing memory (as in the execution of EAE arithmetic, EAE data shifting, or IOT instructions following the fetch of such instructions from memory), DMA and CPU operations overlap; i.e., no time is lost to the CPU by DMA requests for access to memory. Where the operations do not overlap, the CPU operation is suspended until the DMA channel frees memory. The design of the PDP-9 system prohibits more than one memory bank of an expanded system from being active at any one time. The Type DM09A Adapter-Multiplexer, offered as a standard PDP-9 option, is a compatible high-speed interface by which up to three devices may be multiplexed to the DMA channel. Although users may design and fabricate an interface for say one device, the relative low cost and the additional benefit of DMA channel expansion at any time are strong recommendations for inclusion of the DM09A in a PDP-9 system. (The DM09A option is described on page 15-4.) ## MEMORY PROVISIONS FOR DMA Each memory bank of an PDP-9 system contains an input multiplexer which permits both the CPU and a DMA channel device to gain access to memory locations. This multiplexer includes a synchronizer and priority system to assure that a device request for memory access will be granted if the CPU and the device simultaneously request a memory cycle. The CPU's memory buffer (MB) register outputs (conveying addresses and data) are bussed from memory bank to memory bank where they enter one port of the memory input mixer. The channel interface MB outputs are similarly bussed to each memory bank and enter a second port of the mixer. The sense amplifier outputs from the memory banks are also bussed together and drive both the CPU and the channel interface. The input mixer gates are strobed into the memory address (MA) register at the beginning of the read-half-cycle and are connected to the memory drivers during the write-half-cycle. An external device interface must provide data during the write-half of a normal read/restore memory cycle. Approximately 200 nsec are available to receive and return the sense amplifier signals during a typical read/restore memory cycle. The following signals constitute the DMA interface to the PDP-9 memory system. They consist of signals supplied by memory and signals which must be supplied by the appropriate channel control (DM09A or equivalent, see figure 15-1). AM RQ Signal level sent by channel control to request a memory cycle. Ground level for assertion, -3v otherwise. AM SYNC (1) B Signal level returned to channel control by memory, signifying acceptance of cycle request. At ground level for assertion, -3v otherwise. Clock Clock pulse train of 120 nsec, negative-going pulses. Sent by memory to synchronize internal operation of channel control to system timing. The time between pulses is the same as the processor cycle time. AM GRANT 120-nsec, negative-going pulse sent by memory to channel control. Normally, the pulse is used to place device-supplied address word on channel control data lines for input to memory MA register. It may also be used to stop the transmission of the data word of the previous DMA transfer if successive requests are being made. AM STROBE 120-nsec, negative-going pulse sent by memory to channel control. Normally, pulse is used to place lines for input to previously addressed memory location. It may also be used to terminate the transmission of the address via the channel control data lines. AM DATA 18 data lines convey device-supplied address and data words from channel control to memory. -3v for 0 bit, ground for 1 bit. Channel control must bus drive these lines to ensure signal integrity at memory. Sense amplifiers 18 data lines convey data word from previously addressed memory location to channel control. 320 nsec negative-going pulses from the memory sense amplifiers. Negative pulse (-3v) indicates 1 bit; ground for 0 bit. Figure 15-1 DM09A Option Block Diagram Five cable assemblies are required for an I/O interface to the DMA. Flexprint cable (19 conductor) is suggested. The cable length must be limited to ten feet. #### **DMA Cables** | Computer | Device | <u>Use</u> | |----------|----------------------------|-------------------| | W033] | | SA bits 0 - 8 | | W033] | [W033 | SA bits 9 - 17 | | W033] | [W033 | Control Signals | | W031] | <b></b> [G <i>7</i> 95 | MA/MB bits 0 - 8 | | W031] | <del></del> [G <i>7</i> 95 | MA/MB bits 9 - 17 | #### ADAPTER-MULTIPLEXER, TYPE DM09A The DM09A Adapter-multiplexer is a convenient interface through which up to three devices may gain access to memory locations via the DMA channel. The option satisfies the interface requirements of the channel, establishes a relatively simple interface for the devices, and allocates priority of service among the devices. The DM09A is designed to transfer data to memory at high speed (1 µsec transfer time) and to devices at either of two speeds, depending upon the operational characteristics of their interface logic circuits. Devices having 10 mHz logic should request the fast (1 µsec) transfer rate; devices having lower speed logic will operate at the slow (3 µsec) transfer rate, (devices interfaced to the PDP-7, the PDP-9's predecessor, are typical of the latter category). The slow speed applies only to the DM09A and the affected device. Regardless of the transfer mode and direction, the DMA channel steals only one memory cycle per each data transfer. Figure 15-1 is a simple block diagram of the DM09A, showing the major elements of the option and the interface signal lines to the memory bank(s) and to the devices. Device signals supplied to the DM09A have the following characteristics: | CHX BK RQ | -3v tor assertion, otherwise at ground | |-------------|-----------------------------------------------------------------------------| | CHX RQ IN | -3v for device-to-memory transfer, ground for memory-to-device transfer | | CHX DATA | -3v for 1 bit, ground for 0 bit | | CHX ADDR | -3v for 1 bit, ground for 0 bit | | CHX FAST RQ | -3v for slow mode transfer (to device only), ground for fast mode transfer. | Signals supplied by the DM09A to interfaced devices have the following characteristics: CHX ADDR ACCEPTED 320-nsec negative-going pulse. Occurrence signifies that device-supplied address has been strobed into memory system MA register. CHX DATA READY 320-nsec negative-going pulse. Occurrence signifies that data is present in AM register for entry into device buffer register. Pulse may be used to strobe the data in. CHX DATA ACCEPTED 320-nsec negative-going pulse. Occurrence signifies that device-supplied data word has been strobed into addressed memory location. CHX FAST CLEAR 320-nsec negative-going pulse. Occurs when DM09A is synchronized to memory. It should be used to clear device request. This pulse is generated for fast mode transfers only. BUFFERED DATA 18 data lines supply data word read from device- addressed memory location in memory-to-device DMA transfer. -3v for 1 bit, ground for 0 bit. The following discussion and the timing diagrams (figures 15-2 and 15-3) serve to illustrate the operation of the DM09A and the manner in which devices must function to make use of the DMA channel. A device can be initialized by program-controlled transfers to indicate the direction of data transfer, the number of words to be transferred, and the address of the initial memory location which is to deliver or receive the first data word. A device flag can then be set to place -3v on the associated break request line (CHX BK RQ). If the DM09A is not currently active, the break request initiates the transition of the adapter-multiplexer request (AM RQ) to ground to request a memory cycle. The return of a ground level on the AM SYNC (DM09A synchronizing) line signifies that the memory system has accepted the DMA request for a cycle. Synchronization of DMA requests occurs at the beginning of the memory cycle preceding the cycle in which the data transfer is to take place. Thus, the maximum waiting time for the DMA channel is 2 µsec where the first µsec is the interval in which the device flag and the AM RQ can come up and the second µsec is devoted to synchronizing the DMA. The synchronizing action also blocks processor access of memory to assure DMA priority access. In a fast mode transfer, following the AM SYNC signal, the DM09A generates the CHX FAST CLEAR signal to clear the device flag and thus the CHX BK RQ line. This action affords another device or the active device the opportunity to anticipate completion of the data transfer and initiate another break request for successive data transfers if the respective device is capable of a 1 µsec data transfer rate. In the case of output (to device) transfers at the slow rate, the CHX ADDR ACCEPTED signal (described below) serves to clear the device flag. Successive requests are not permitted for slow mode transfers; i.e., an active device or other DMA device must wait at least one memory cycle following a slow mode request before another slow mode request will be honored. Figure 15-2 DMA Synchronization Cycle, Timing Diagram The device-supplied address (and data word, if request is for a device-to-memory transfer) must be present on the CHX ADDR and CHX DATA lines at the time of the break request. The trailing edge of AM GRANT generates AM IN to place the address in the AM register and, thus, on-line for entry into Figure 15-3 DM09 Data Transfer Cycles Timing Diagrams the memory address (MA) register of the PDP-9 memory system. Shortly thereafter, the DM09A generates the CHX ADDR ACCEPTED signal which tells the device that the address has been entered in memory. The device may use this signal to clear its address register or to setup the next address if successive requests are to be made. For a slow mode device, the CHX ADDR ACCEPTED signal occurs at an opportune time to clear the device request flag. The AM STROBE signal occurs midway into the cycle, or 500-520 nsec after the start of the transfer. If the CHX RQ IN line is at -3v (signifying a device-to-memory transfer), AM STROBE generates AM IN to enter the device-supplied data word in the AM register and, thus, on-line for entry into the addressed memory location. If CHX RQ IN is at ground potential (signifying a memory-to-device transfer), data present on the sense amplifier output lines are gated through the data multiplexer to the AM register. For a device-to-memory transfer, AM STROBE enters the contents of the AM register in the memory location previously addressed by the device address word. The DM09A then generates the CHX DATA ACCEPTED signal which signifies to the device that its data word has been entered in memory. CHX DATA ACCEPTED is generated only when a data transfer is made from the device to memory. The device may use this signal to clear its data buffer in preparation for a successive DMA transfer. For a memory-to-device transfer, AM STROBE causes the DM09A to generate the CHX DATA READY signal, which tells the device that a data word is present on the buffered data lines at the output of the AM register. The device must read this data into a buffer register within 300 nsec. The CLK line supplies buffered clock pulses to the DM09A for the purpose of synchronizing its internal operations to those of the memory system. In the fast mode, if a device flag (either that of a currently active device or another DMA device) initiates a CHX BK RQ after AM SYNC time but prior to AM GRANT time, successive DMA breaks will be granted. Cables interfacing devices to the DM09A must not exceed 50 feet in length. Cable assemblies with Type G795 Cable Connector termination are recommended for signal lines carrying levels. Type W031 Cable Connectors should terminate pulse carrying lines. # CHAPTER 16 INSTALLATION PLANNING This chapter describes the physical dimensions of a basic PDP-9 and expander cabinets. Power requirements, heat produced, and the physical sizes of options are detailed in tables 16-1 through 16-3. Several typical configurations are shown. #### PHYSICAL CONFIGURATION The basic PDP-9 is housed in a single cabinet, 32-1/2 in. wide (with end panels), 27-3/4 in. deep, and 69-1/2 in. high. The operator's table projects forward 22 in. and a rear clearance of 31 in. is needed for access to the logic. Physical dimensions of the basic PDP-9 are shown in figure 16-1. The PDP-9 is painted black, with grey end panels, and has a red accent panel on the front. The rear door also contains a red accent stripe. A black chair is supplied with the PDP-9. In the basic PDP-9 cabinet, the paper tape reader/punch and operator's console are mounted on the front, while most of the logic is mounted on the rear door. In the center of the front is an operator's console, with the standard paper tape reader/punch unit mounted above and a table mounted below. The power supplies are underneath the table. Behind the red accent door, to the left of the paper tape reader/punch, is the marginal check panel, the maintenance panel, and the console lock switch. Above the paper tape reader/punch unit, space is reserved for the Type DM09A Direct Memory Access Channel Multiplexer Adapter option and the Type ME09A Option Panel which contains the wiring for the Type KG09A Memory Extension Control, the Type KX09A Memory Protection Option, and the Type MP09A and MP09B Memory Parity Options. Figure 16-2(A) shows the front of the PDP-9 cabinet. Most of the PDP-9 logic is contained on the rear door (see figure 16-2(B)). The logic is contained on three wire-wrapped frames, self-contained, with fans, fuses, and marginal check switches. The top frame contains a 8192-word memory wing, the center frame is the central processor, while the bottom frame contains the I/O logic. These three frames are bolted together to form a solid door, and connections are made from frame to frame with ribbon cables. Hold-down bars are available as an option. Cooling is accomplished by the fans built into the frames. Air is sucked in through vents in the rear door, blown past the logic by the fans, and exits through vents in the top of the cabinet. Several options are wired into the frames of the basic PDP-9 for easy implementation. The central processor frame contains the logic for the Extended Arithmetic Element, Type KE09A. The I/O frame Figure 16-1 Basic PDP-9 Cabinet Specifications Figure 16-2(A) Basic PDP-9 (Front) Figure 16-2(B) Basic PDP-9 (Rear) (Back Door Removed) has the Automatic Priority Interrupt, Type KF09A, the Power Failure Protection Option, Type KP09A, and the Oscilloscope Display Control, Type 34H, already wired in. Space is reserved in the basic cabinet for the Type DM09A and Type ME09A (KG09A, KX09A, MP09A, MP09B) options to keep them as close as possible to the central processor logic. Memory is expanded by adding the Memory Extension Control, Type KG09A (housed in the Type ME09A option above the paper tape reader/punch), and extra memory wings. The Memory Modules, Type MM09A (first additional 8192 words), MM09B (second additional 8K), and MM09C (third additional 8K), are housed in a second 32-in. cabinet to the left (facing the system) of the basic PDP-9. This is shown in figure 16-3. The cabinet contains room for all three additional memory modules on the front door, while power supplies are mounted in the rear. The rear door of this additional 32-in. cabinet also contains a red stripe, but the front door is solid black. Other options are added to the PDP-9 by attaching standard 19-in. cabinets to the right of the basic cabinet (facing it). The dimensions of these cabinets are shown in figure 16-4. Connections to these options are made from the PDP-9 I/O logic via I/O Bus Cables, Type BC09A. Figure 16-5 shows a one-bay expansion of a PDP-9 with the addition of a DECtape Control, Type TC02, and four (4) DECtape Transports, Type TU55. Several options, including the Type RM09 drums, the Type RC09 disk, the Type 30D, 34DC, and 339 displays, and the Type TU20 and TU20A tape transports, are composed, in part, of free-standing units. These are housed in one or more 19-in. cabinets and are interfaced to the PDP-9 via 25 ft cables. Figure 16-3 PDP-9 With Extra Memories (Front) Figure 16-4 19 Inch Cabinet Specifications BASIC PDP-9 Figure 16-5 PDP-9 With DECtape #### PLACEMENT OF OPTIONS PDP-9 systems are assembled according to the following guide-lines\*: - Cabinets are numbered 0 through n (or 1 through n, if no extra memory is required), with the numbers always running from left to right (figure 16-6), and the central processor cabinet is always designated no. 1. Bays 0 and 1 are 31-in. cabinets, and 2 through n are 19-in. cabinets. All cabinets except no. 1 have their logic mounted on the front. The 19-in. cabinets can hold eleven standard 5-1/2-in. mounting panels of logic; these are lettered A through K. The bottom panel space cannot be utilized. - The options listed below are wired in and require no additional space. - Extended Arithmetic Element, Type KE09A - Automatic Priority Interrupt, Type KF09A <sup>\*</sup>Customers may request deviations from these procedures at extra cost. Figure 16-6 Cabinet Configurations - c. Power Failure Detection Option, Type KP09A - d. Oscilloscope Display Control, Type 34H - 3. Several options requiring additional logic will also be housed in bay no. 1, in 19-in. mounting panels, above the paper tape reader/punch unit. - a. The Direct Memory Access Channel Multiplexer Adapter, Type DM09A, fits into the top two panel spaces. - b. The Memory Extension Control, Type KG09A, the Memory Protection Option, Type KX09A, and the Memory Parity Options, Type MP09A and MP09B, are wired into one pair of panels (Type ME09A) which fit in the two spaces immediately above the reader/punch unit. - 4. All extra memory modules are housed in bay no. 0. <u>No other options</u> are permitted in this cabinet. The first Extra Memory Module, Type MM09A, fits into the center (front) of this bay, with the second one, type MM09B, above and the third, Type MM09C, below. - 5. All cabinet-mounted input/output options and interfaces to free-standing options are housed in bays no. 2 through n, with the following priorities governing proximity to the central processor. - a. DECtape - b. All other standard DEC options - c. Special systems built by DEC - d. Special systems (or the cabinets for them) built by customers. - 6. DECtape, when included in the system, will occupy bay no. 2 and, if necessary, bay no. 3. Even if the DECtape does not completely fill bay no. 2, no other options will be permitted in the bay with it. This allows room for expansion of the DECtape system. If bay no. 3 is also used for DECtape, the bottom three panels (I through K) are available for other options (figures 16-7(A) and 16-7(B)). | | RESERVED<br>FOR<br>DM09A | TU55#4 | |-----|-----------------------------------|------------| | | RESERVED<br>FOR<br>MEØ9A * | TU55#3 | | | PAPER TAPE<br>READER AND<br>PUNCH | TU55# 2 | | OPE | RATOR'S CONSOLE | TU55#1 | | | TABLE | 4 | | | | TC02 | | | | | | | | $\nearrow$ | | | RESERVED<br>FOR<br>DMØ9A | TU55#4 | TU55#8 | |-------|-----------------------------------|----------|------------------| | ммøэв | MEØ9A*<br>(KGØ9A) | TU55#3 | TU55# 7 | | | PAPER TAPE<br>READER AND<br>PUNCH | TU55#2 | TU55# 6 | | MMØ9A | OPERATOR'S CONSOLE | TU55#1 | TU55#5 | | | TABLE | <b>•</b> | 1 | | | | TCO2 | AVAILABLE<br>FOR | | ммø9с | | | OTHER - | | | | $\times$ | >< | <sup>\*</sup>MEØ9A IS TWO-PANEL OPTION CONTAINING WIRING FOR KGØ9A, KXØ9A, MPØ9A AND MPØ9B OPTIONS. Figure 16–7(A) Basic PDP–9 with DECtape Figure 16-7(B) Memory Expansion and DECtape Expansion - 7. Oscilloscope displays are mounted at the top of the cabinet closest to the central processor after DECtape (see figure 16-7(C)). - 8. Analog-to-digital converters and output relay buffers are mounted as near to the top of the cabinets as possible. - 9. Interfaces to large-screen CRTs, card readers, line printers, and interprocessor buffers will be mounted as low as possible to shorten the length of external cables going out of the bottom of the cabinet. - 10. Magnetic Tape Controls, Type TC59, will be mounted at the <u>bottom</u> of the cabinet and as far to the right as possible (figure 16-7(C)). Figure 16-7(C) Typical PDP-9 System #### ENVIRONMENTAL REQUIREMENTS PDP-9 systems operate satisfactorily under ordinary conditions of humidity, shock, and vibration. They are tested in the plant between $50^{\circ}$ and $122^{\circ}$ F. The best operating temperatures, however, are between $70^{\circ}$ and $85^{\circ}$ F and a humidity between 30 and 80% are recommended. If room air conditioning is planned, consult tables 16-1 through 16-3 for heat outputs of the system components. #### POWER REQUIREMENTS The PDP-9 requires a source of 115v, 60 Hz, single-phase power. Upon order, all equipment can be factory-wired for 50 Hz at 115, 230, or 250v. The power source must maintain the nominal voltage to $\pm 10\%$ and the frequency to $\pm 0.5$ Hz. The electrical characteristics of individual components are given in tables 16-1 through 16-3. #### CABLING REQUIREMENTS Most PDP-9 systems will require 115v, 30 amp, Hubbel Twistlock flush receptacles (or their equivalent) to mate with equipment power cables. Exceptionally large PDP-9 systems may require 50 amp sources. If in doubt, consult tables 16-1 through 16-3 or your DEC representative. All free-standing cabinets (drums, disks, magnetic tape transports, card readers, line printers, etc.) require independent 115v (or equivalent) receptacles. Power on/off, however, will be under control of the PDP-9 console switch. Cables are connected to cabinets through drop panels in the cabinet bottoms. Sub-flooring is not necessary because the cabinets are elevated sufficiently by feet or casters to allow clearance for the cables. #### ADDING SPECIAL INTERFACES Special interfaces may be constructed by using compatible FLIP CHIP modules and mounting hardware (see Digital Logic Handbook, C-105, for details). A choice of cabinets is available for use with PDP-9 systems. All hold standard FLIP CHIP mounting hardware (19-in. panels) and are available with or without end panels. Rotary fans are contained in the bottom, and power supplies may be purchased for mounting on the rear plenum doors. The available cabinet options are illustrated in figure 16-8. A brief description of each is as follows. CAB-1B: French doors front and rear; without indicator panel. CAB-9A: single full doors front and rear; without indicator panel. CAB-9B: single full doors front and rear; with indicator panel. CAB-9C: black snap-on covers front, full single door rear; without indicator panel. CAB-9D: black snap-on covers front, full single door rear; with indicator panel. All special interfaces should be designed to interface to the PDP-9 I/O bus by using I/O bus cables, Type BC09A. Figure 16-8 Cabinet Configurations TABLE 16-1 PDP-9, EXTRA MEMORY, FREE-STANDING OPTIONS AND THEIR CONTROLS | | Cabi | Cabinet Dimensions | nsions | | : | Service<br>Clearance | oe<br>10 Ce | Height of | AC Current | ent | Heat | Power | Cable | | |----------------------------------------------------------------|-----------------|--------------------------------|---------------------------|---------------------|-------------|---------------------------|-------------|-----------------------------|-------------------|-----------------|-------------------------|---------------------------------------|----------------|------------------------------------------------| | Name | Height<br>(in.) | Width<br>(in.) | th<br>ble) | Options<br>Required | Weight (Ib) | Front Rear<br>(in.) (in.) | 1 | Interface<br>(19 in. logic) | Nominal<br>(amps) | Surge<br>(amps) | Dissipation<br>(btu/hr) | Dissipation Dissipation (btu/hr) (kw) | Length | Comments | | Standard PDP-9 | 8/1-69 | 33 | 53 | 1 | 006 | Chair<br>Space | 8 | ļ | 17 | 뚕 | | | | | | Extra Memory,<br>Type MM09A/B/C | 8/1-69 | 33 | 27-1/16 | KG09A | 400-800 | 8 | 30 | See KG09A | | | <b>4</b> 21/8K | 0.134/8K | | Bay can hold up to<br>three 8K memory<br>wings | | Magnetic Tape Transports,<br>Type TU20 and TU20A | 8/1-69 | 22-1/4 | 69-1/8 22-1/4 27-1/16 | TC59 | 400 | 19 | 61 | See TC59 | ω | 12 | 2300 | 0.62 | 10 ft | Op.Temp. 55-100°F<br>Humidity 25-95% | | Block Transfer Drum,<br>Type RM09 | 8/1-69 | 22-1/4 | 69-1/8 22-1/4 27-1/16 | DW09A | 200 | 19 | 19 | 5-1/4 | 5 | <b>∞</b> | 1540 | 0.45 | 15 ft | | | Disk System, Type RB09 | 48-1/2 | 20 | 45-1/2 | DM09A | 400 | 20 | 20 | 36-3/4 | 10+ | 30↓ | | 0.81 | 25 ft | Operating temper- | | 100 cpm Card Reader,<br>Type CR01E | 8-1/4 | 8-1/4 19-3/8 10-3/8 | 10-3/8 | 1 | 25 | 1 | 1 | 5-1/4 | 0.5 | 1.0 | 306 | 60.0 | 10 ft | ature 60-95°F | | 200 cpm Card Reader,<br>Type CR02B | 92 | 8 | 17 | DA09A* | 200 | 1 | 9-2/8 | ! | 1.3 | 7.0 | 495 | 0.15 | 10 ft | | | Line Printer, Type 647 | 52-57 | 56 | 30-1/4 | DA09A* | 1350 | 24 | 26 | ; | 13 | ļ | 2700 | 1.56 | 10 ft | | | Incremental Plotter,<br>Calcomp Model 563<br>Calcomp Model 565 | 9-3/4 | 39-3/8 14-3/4<br>18 14-3/4 | 14-3/4 | 350<br>350 | 53 | 1 1 | | See 350<br>Control | 1.12 | 3.2 | 425<br>580 | 0.125<br>0.17 | 10 ft<br>10 ft | | | Precision CRT, Type 30D | 8/1-69 | 69-1/8 22-1/4 | 51 | DA09A* | 350 | 6 | 38 | 5-1/4 | œ | œ | 3140 | 6.0 | 25 ft | | | Precision Incremental CRT<br>Display, Type 340C | 69-1/8 42 | 42 | 51 | DM09A<br>DM09A* | 200 | 61 | 38 | ; | 15 | 20 | 2900 | 1.73 | 25 ft | | | Programmed Buffered<br>Display, Type 339 | 69-1/8 42 | 42 | 51 | DM09A | 200 | 61 | 3% | ; | 01 | ł | 2700 | 9.8 | 15 ft | | | Slave Display, Type 343 | 8/1-69 | 69-1/8 22-1/4 | 51 | 1 | 350 | 6 | 36 | 1 | 9 | 2 | 2350 | 69.0 | 25 ft | | | Data Communications<br>System, Type 680 | ) (See 680 | (See 680 Handbook) | | DB98A | 1 | ł | } | See<br>DB98A | ŀ | ł | ; | ! | 12 ft | | | Empty Cabinet | 8/1-69 | 22-1/4 | 69-1/8 22-1/4 27-1/16 | ŀ | 901 | 61 | 16 | 1 | ; | i | 1 | 1 | 12 ft | | \*No charge for required options marked with an asterisk (\*). †60 cycle: 3 wire 115/230 or 120/208 (normal) 50 cycle: 2 wire 220 (normal), 230, 240 available TABLE 16-2 WIRED-IN OPTIONS | Name | Included in | AC Currer<br>Nominal | t (amps)<br>Surge | Heat Dissipation<br>(btu/hr) | Power Dissipation<br>(kw) | |---------------------------------------------|--------------------|----------------------|-------------------|------------------------------|---------------------------| | Extended Arithmetic<br>Element, Type KE09A | PDP-9<br>CPU | | | 108 | 0.032 | | Automatic Priority<br>Interrupt, Type KF09A | PDP-9<br>I/O Logic | | | 61 | 0.018 | | Power Failure Detection,<br>Type KP09A | PDP-9<br>I/O Logic | Include | d in | 69 | 0.021 | | Oscilloscope Display<br>Control, Type 34H | PDP-9<br>I/O Logic | Basic Pl<br>Power S | | 408 | 0.012 | | Memory Extension<br>Control, Type KG09A | ME09A | | | 94 | 0.030 | | Memory Parity Option,<br>Type MP09A/B | ME09A | | | 138 | 0.044 | | Memory Protection<br>Option, Type KX09A | ME09A | J | | 25 | 0.008 | | Character Generator,<br>Type VC38 | 339 | | | | | | Search Logic, Type VF38 | 339 | Included | in 339 | | | | Zoom Logic, Type VZ38 | 339 | | | | | | Slave Mode, Type VS38 | 339 | | | | | TABLE 16-3 HARDWARE AND LOGIC OPTIONS FOR 19-INCH CABINETS | Name | Logic<br>Height<br>(in.) | Number of<br>Mounting<br>Panels | Options<br>Required | Approx<br>Weight<br>(1b) | AC Current (amps) Nominal Surge | r (amps)<br>Surge | Heat<br>Dissipation<br>(btu/hr) | Power<br>Dissipation<br>(kw) | Comments | |----------------------------------------------------|--------------------------|---------------------------------|---------------------|--------------------------|---------------------------------|-------------------|---------------------------------|------------------------------|-----------------| | Parity-Extension-Protection<br>Chassis, Type ME09A | 10-1/2 | 2 | ; | 25 | | | | | | | DMA MPXR, Type DM09A | 10-1/2 | 2 | - | | 0.58 | 1.0 | 226 | 0.067 | | | I/O Bus Adapter, Type DA09A | 10-1/2 | 2 | ! | | 0.44 | 8.0 | 156 | 0.046 | | | IPB, Type DB99A | 10-1/2 | 2 | } | | 0.39 | 0.72 | 133 | 0.042 | | | IPB, Type DB98A<br>PDP-9 End `<br>PDP-8 End | 10-1/2 | 2 2 | 111 | | 0.39 | 0.72 | 133 | 0.042 | | | IPB, Type DB97A<br>PDP-9 End<br>PDP-7 End | 5-1/4 | | 1 1 | 13 | 0.29 | 0.54 | 86 | 0.031 | | | Output Relay Buffer, Type DR09A | 5-1/4 | - | } | | 0.47 | 98.0 | 170 | 0.050 | | | DECtape Control, Type TC02 | 15-3/4 | က | ł | 38 | 09.0 | 1.0 | 207 | 0.058 | | | DECtape Transport, Type TU55 | 10-1/2 | 2 | TC02 | 35 | 0.5 | 3.0 | 410 | 0.170 | | | Magnetic Tape Control,<br>Type TC59 | 21 | 4 | 1 | 20 | 2.0 | 5.0 | 1000 | 0.23 | | | Incremental Plotter Control,<br>Type 350 | 10-1/2 | 7 | ŀ | 25 | | | | | | | Teletype Control, Type LT09A | 10-1/2 | 2 | 1 | 25 | | | 47 | 0.014 | | | Line Unit, Type LT09B | ŀ | 1 | LT09A | | 0.13 | 0.24 | 1 | ŀ | | | Character Sync Data Comm.<br>System, Type 636 | 10-1/2 | 7 | 1 | 25 | 0.185 | 0.34 | 89 | 0.020 | | | Bit Sync Data Comm. System,<br>Type 637 | 10-1/2 | 5 | ; | 25 | 0.27 | 0.50 | 100 | 0.029 | | | Symbol Generator, Type 33 | 5-1/4 | - | 30D | | | | | | In 30D Cabinet | | Character Generator, Type 342 | 5-1/4 | - | 340C | | | | | | In 340C Cabinet | TABLE 16-3 HARDWARE AND LOGIC OPTIONS FOR 19-INCH CABINETS (continued) | Name | Logic<br>Height | Number of<br>Mounting | Options | Approx<br>Weight | AC Current (amps) | nt (amps) | Heat<br>Dissipation | Power<br>Dissipation | | |---------------------------------------------------------------------------------------|-----------------|-----------------------|-------------|------------------|-------------------|-----------|---------------------|----------------------|-------------------------| | | (in.) | Panels | Required | (JP) | Nominal | Surge | (btu/hr) | (kw) | Comments | | Tektronix Scope, RM503 or<br>RM564 | 7 | 2 | 34 H | | | | | | | | Analog-to-Digital Converter,<br>Type 138E | 10-1/2 | 2 | DA09A | | 0.165 | 0.33 | 612 | 0.018 | | | Multiplexer Control, Type 139E | Included | Included with 138E | | | 0.175 | 0.255 | 585 | 0.019 | | | Multiplexer Expansion,<br>Type AA03B | 5-1/4 | _ | 139E | | | | | | | | ADC/Multiplexer, Type AF01B | 8-3/4 | 2 | 1 | 90 | 0.5 | | 189 | 0.055 | | | ADC/MPXR, Type AF02B | | | | | | | | | | | 128 Channels | 19-1/4 | 4 | 1 | 70 | 0.75 | 1.5 | 270 | 0.080 | | | 256 Channels | 19-1/4 | 4 | ; | 20 | 0.75 | 1.5 | 270 | 0.080 | | | 512 Channels | 29-3/4 | <b>9</b> 0 | 1 | 75 | 0.1 | 2 5 | 380 | 0.110 | | | 1024 Channeis | 40-1/4 | ×ο | <b>!</b> | 28 | c | ກ | 070 | 0.1/5 | | | ADC/MPXR, Type AF03B<br>64 Channels | 19-1/4 | 4 | 1 | 09 | 1.50 | ო | 970 | 0.175 | | | 128 Channels | 24-1/2 | 5 | ; | 70 | 1.75 | 3.2 | 069 | 0.200 | | | 256 Channels | 40-1/4 | ∞ ; | ; | 8 9 | 2.5 | 5 | 750 | 0.280 | | | 512 Channels<br>1024 Channels | 56<br>103-1/4 | 50 | ! ! | 150 | 0.0 | 20 | 1564<br>3900 | 0.450 | | | IDVM/Scanner, Type AF04B | | | | | | | | | | | 200 Channels | 24 | Separate | ; | 220 | 4.0 | 8.8 | 1564 | 0.460 | Weights include cabinet | | 400 Channels | 정 : | Cabinet | ! | 240 | 4.5 | 8.6 | 1756 | 0.517 | | | oud Channels | 44 1 | _<br>_ | ł | 097 | ე.<br>ე. ( | = : | 1950 | 0.5/5 | | | 800 Channels<br>1000 Channels | ¥ | Separate<br>Cabinet | | 300 | 6.0 | 13.2 | 2100<br>2350 | 0.69<br>0.69 | | | DAC Controller, Type AA058 | 8-3/4 | 2 | 1 | 90 | 0.5 | -: | 306 | 0.0 | | | DAC Controller Extension,<br>Type AA07B | 8-3/4 | 7 | AA05B | 30 | 0.5 | Ξ. | 306 | 0.09 | | | DAC Converters, Type AA01A | 5-1/4 | | DA09A | 9.5 | 0.27 | 0.59 | 105 | 0.031 | | | NOTES: 1943 mounting panel wired and with power end plate. But without modules. 7 lb. | ed and with | power end ple | ote, but wi | thout mode | ules. 7 lb. | | | | | 1943 mounting panel wired and with power end plate, but without modules, 7 lb. 1943 mounting panel complete with 64 modules and wired with power end plate, 13 lb. Each module 0.0936 lb or approximately 1/10 lb. # APPENDIX 1 INSTRUCTION SUMMARY #### MEMORY REFERENCE INSTRUCTIONS | Mnemonic<br>Symbol | Octal<br>Code | Machine<br>Cycles | Operation Executed | |--------------------|---------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | CAL | 00 | 2 | Call subroutine. The address portion of this instruction is ignored. The action is identical to JMS 20. | | DAC Y | 04 | 2 | Deposit AC. The content of the AC is deposited in the memory cell at location Y. | | JWS Y | 10 | 2 | Jump to subroutine. The content of the PC and the content of the L are deposited in memory cell Y. The next instruction is taken from cell $Y + 1$ . | | DZM Y | 14 | 2 | Deposit zero in memory. Zero is deposited in memory cell Y. | | LAC Y | 20 | 2 | Load AC. The content of Y is loaded into the AC. | | XOR Y | 24 | 2 | Exclusive OR. The exclusive OR is performed between the content of Y and the content of the AC, with the result left in the AC. | | ADD Y | 30 | 2 | Add (1's complement). The content of Y is added to the content of the AC in 1's complement arithmetic and the result is left in the AC. | | TAD Y | 34 | 2 | Two's complement add. The content of Y is added to the content of the AC in 2's complement arithmetic and the result is left in the AC. | | XCT Y | 40 | 1+ | Execute. The instruction in memory cell Y is executed. | | ISZ Y | 44 | 2 | Increment and skip if zero. The content of Y is incremented by one in 2's complement arithmetic. If the result is zero, the next instruction is skipped. | | AND Y | 50 | 2 | AND. The logical operation AND is performed between the content of Y and the content of the AC with the result left in the AC. | ## MEMORY REFERENCE INSTRUCTIONS (continued) | Mnemonic<br>Symbol | Octal<br>Code | Machine<br>Cycles | Operation<br>Executed | |--------------------|---------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | SAD Y | 54 | 2 | Skip if AC is different from Y. The content of Y is compared with the content of the AC. If the numbers are different, the next instruction is skipped. | | JMP Y | 60 | 1 | Jump to Y. The next instruction to be executed is taken from memory cell Y. | #### EAE INSTRUCTION LIST | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------| | EAE | 640000 | Basic EAE command. No operation. | | LRS | 640500 | Long right shift. | | LRSS | 660500 | Long right shift, signed (AC sign = link). | | LLS | 640600 | Long left shift. | | LLSS | 660600 | Long left shift, signed (AC sign = L). | | ALS | 640700 | Accumulator left shift. | | ALSS | 660700 | Accumulator left shift, signed (AC sign = $L$ ). | | NORM | 640444 | Normalize, unsigned. Maximum shift is 44 <sub>8</sub> . | | NORMS | 660444 | Normalize, signed (AC sign = L). | | MUL | 653122 | Multiply, unsigned. The number in the AC is multiplied by the number in the next core memory address. | | MULS | 657122 | Multiply, signed. The number in the AC is multi-<br>plied by the number in the next core memory address. | | DIV | 640323 | Divide, unsigned. The 36-bit content of both the AC and MQ is divided by the number in the next core memory location. | | DIVS | 644323 | Divide, signed. The content of both the AC and MQ as a 1's complement signed number is divided by the number in the next core memory location. | # EAE INSTRUCTION LIST (continued) | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------| | IDIV | 653323 | Integer divide, unsigned. Divide the number in the AC as an 18-bit unsigned integer by the number in the next core memory location. | | IDIVS | 657323 | Integer divide, signed. Same as IDIV but the content of the AC is a 17-bit signed number. | | FRDIV | 650323 | Fraction divide, unsigned. Divide the 18-bit fraction in the AC by the 18-bit fraction in the number in the next core memory location. | | FRDIVS | 654323 | Fraction divide, signed. Same as FRDIV, but the content of the AC is a 17-bit signed number. | | LACQ | 641002 | Replace the content of the AC with the content of the $\ensuremath{MQ}$ . | | LACS | 641001 | Replace the content of the AC with the content of the ${\sf SC}$ . | | CLQ | 650000 | Clear MQ. | | ABS | 644000 | Place absolute value of AC in the AC. | | GSM | 664000 | Get sign and magnitude. Places AC sign in the link and takes the absolute value of AC. | | OSC | 640001 | Inclusive OR the SC into the AC. | | OMQ | 640002 | Inclusive OR AC with MQ and place results in AC. | | CMQ | 640004 | Complement the MQ. | | LMQ | 652000 | Load MQ. | | | INPUT/ | OUTPUT TRANSFER INSTRUCTIONS | | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | | | | Program Interrupt | | IOF | 700002 | Interrupt off. Disable the PIC. | | ION | 700042 | Interrupt on. Enable the PIC. | | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|------------------|---------------------------------------------------------------------------------------------------| | | | Real Time Clock | | CLSF | 700001 | Skip the next instruction if the clock flag is set to 1. | | CLOF | 700004 | Clear the clock flag and disable the clock. | | CLON | 700044 | Clear the clock flag and enable the clock. | | | | Perforated Tape Reader | | RSF | 700101 | Skip if reader is a 1. | | RCF | 700102 | Clear reader flag, then inclusively OR the content of reader buffer into the AC. | | RRB | 700112 | Read reader buffer. Clear reader flag and AC, and then transfer content of reader buffer into AC. | | RSA | 700104 | Select reader in alphanumeric mode. One 8-bit character is read into the reader buffer. | | RSB | 700144 | Select reader in binary mode. Three 6-bit characters are read into the reader buffer. | | | | Perforated Tape Punch | | PSF | 700201 | Skip if the punch flag is set to 1. | | PCF | 700202 | Clear the punch flag. | | PSA or<br>PLS | 700204<br>700206 | Punch a line of tape in alphanumeric mode. | | PSB | 700244 | Punch a line of tape in binary mode. | | | | I/O Equipment | | IORS | 700314 | Input/output read status. The content of given flags replace the content of the assigned AC bits. | | TTS | 703301 | Test Teletype and skip if KSR 33 is connected to computer. | | CAF | 703302 | Clear all flags. | | SKP7 | 703341 | Skip if processor is a PDP-7 or PDP-9 | | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | Teletype Keyboard | | KSF | 700301 | Skip if the keyboard flag is set to 1. | | KRB | 700312 | Read the keyboard buffer. The content of the buffer is placed in AC10–17 and the keyboard flag is cleared. | | | | Teletype Teleprinter | | TSF | 700401 | Skip if the teleprinter flag is set. | | TCF | 700402 | Clear the teleprinter flag. | | TLS | 700406 | Load teleprinter buffer. The content of AC10-17 is placed in the buffer and printed. The flag is cleared before transmission takes place and is set when the character has been printed. | | | Types 30 and | 1 34 Oscilloscope and Precision CRT Displays | | DXC | 700502 | Clear the X-coordinate buffer. | | DYC | 700602 | Clear the Y-coordinate buffer. | | DXL | 700506 | Load the X-coordinate buffer from AC8-17. | | DYL | 700606 | Load the Y-coordinate buffer from AC8-17. | | DXS | 700546 | Load the X-coordinate buffer and display the point specified by the XB and YB. | | DYS | 700646 | Load the Y-coordinate buffer and display the point specified by the XB and YB. | | DSF | 700501 | Skip if display flag = 1. | | DCF | 700702 | Clear display flag. | | DLB | 700706 | Load the brightness register from AC15-17. (for Type 30) | | | 700704 | Load the brightness register from AC16-17. (for Type 34) | | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------| | | Туре | 340C Precision Incremental Display | | IDVE | 700501 | Skip on vertical edge violation. | | IDSI | 700601 | Skip on stop interrupt. | | IDSP | 700701 | Skip if light pen flag is set. | | IDHE | 701001 | Skip on horizontal edge violation. | | IDRS | 700504 | Continue display. After a light pen interrupt, this command causes the display to resume at the point indicated by the content of the DAC. | | IDRA | 700512 | Read display address. Transfers the address in the DAC to AC5-17. | | IDLA | 700606 | Load address and select. The content of AC5-17 are placed in the DAC and the display is started. | | IDRD | 700614 | Restart display. After a stop code interrupt, this command causes the display to resume at the point indicated by the content of the DAC. | | IDCF | 700704 | Clear display control. All flags and interrupts are cleared. | | IDRC | 700712 | Read X and Y coordinates. The contents of bits XB0-8 is transferred into AC0-8 and the content of YB0-8 is transferred into AC9-17. | | IDSC | 701012 | Read address save register (ASR). Transfer contents of ASR into AC bits 5–17. | | | | Type 33 Symbol Generator | | GCL | 700641 | Clear done flag (also done by GPL or GPR). | | GSF | 701001 | Skip on done. | | GPL | 701002 | Generator plot left. | | GLF | 701004 | Load format (bit 15 for space, bits 16 and 17 for size). | | GPR | 701042 | Generator plot right. | | GSP | 701044 | Plot a space. | | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|-----------------|--------------------------------------------------------------------------------------------------------------------| | | Type AF01B A | nalog-to-Digital Converter and Multiplexer | | ADSM | 701103 | Select MX channel. The content of AC12–17 is placed in MAR. | | ADIM | 701201 | Increment channel address. The content of the MAR is incremented by 1. Channel 0 follows channel $77_8$ . | | ADRM | 701212 | Read MAR into AC12-17. | | ADSF | 701301 | Skip if converter flag is set. | | ADSC | 701304 | Select and convert. The converter flag is cleared and a conversion is initiated. | | ADRB | 701312 | Read converter buffer. Places the content of the buffer into the AC. | | | <u>Type 139</u> | E General Purpose Multiplexer Control | | ADSM | 701103 | Select MX channel. The content of AC12–17 is placed in the MAR. | | ADIM | 701201 | Increment channel address. The content of the MAR is incremented by 1. Channel 0 follows channel 77 <sub>8</sub> . | | ADRM | 701212 | Read MAR into AC <sub>12-17</sub> . | | | Туре | 138E Analog-to-Digital Converters | | ADSF | 701301 | Skip if converter flag is set. | | ĄDSC | 701304 | Select and convert. The converter flag is cleared and a conversion is initiated. | | ADRB | 701312 | Read converter buffer. Places the content of the buffer in the AC. | | | | Type DR09A Relay Buffer | | ORC | 702101 | Clear output relay buffer flip-flop reigster. | | ORS | 702104 | Set output relay buffer flip-flop register to correspond with the contents of the accumulator. | | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | | | | | | | | |--------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | | Type 350 Incremental Plotter and Control | | | | | | | | | | PLSF | 702401 | Skip if plotter flag is a 1. | | | | | | | | | PLCF | 702402 | Clear plotter flag. | | | | | | | | | PLPU | 702404 | Plotter pen up. Raise pen off of paper. | | | | | | | | | PLPR | 702421 | Plotter pen right. | | | | | | | | | PLDU | 702422 | Plotter drum (paper) upward. | | | | | | | | | PLDD | 702424 | Plotter drum (paper) downward. | | | | | | | | | PLPL | 702441 | Plotter pen left. | | | | | | | | | PLUD | 702442 | Plotter drum (paper) upward. | | | | | | | | | PLPD | 702444 | Plotter pen down. Lower pen on to paper. | | | | | | | | | | Туре | KF09A Automatic Priority Interrupt | | | | | | | | | SPI | 705501 | Skip on priorities inactive. | | | | | | | | | ISA | 705504 | Initiate selected activity. | | | | | | | | | DBK | 703304 | Debreak. | | | | | | | | | DBR | 703344 | Debreak and restore. | | | | | | | | | | | Type RM09A Serial Drum | | | | | | | | | DRLCRD | 706006 | Load counter and read. Places the content of AC2-17 in the DCL and prepares the drum system for reading a block for reading a block into core memory. | | | | | | | | | DRLCWR | 706046 | Load counter and write. Loads the DCL from AC2-17 and prepares the drum system for writing a block to be received from core memory. | | | | | | | | | DRSF | 706101 | Skip if drum transfer flag is set. | | | | | | | | | DRCF | 706102 | Clear drum transfer and error flags. | | | | | | | | | DRLBLK | 706106 | Load sector and select. Places the content of AC9–17 in the DTR, clears both drum flags, and initiates the block transfer. | | | | | | | | | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | Type RM09A Serial Drum (continued) | | DRSOK | 706201 | Skip if drum error flag is not set. | | DRCONT | 706204 | Continue select. Clears the flags and initiates a transfer as specified by the content of the DCL and DTR. | | | | Type 647 Line Printer | | LSDF | 706501 | Skip if the DONE flag is set. | | LPCB | 706502 | Clear the DONE flag, clear control print buffer, enable DONE interrupt, initiate a clear sequence in the hue printer, set the DONE flag when the clear sequence is finished. | | *LPD1 | 706504 | Disable DONE flag interrupt. | | | 706522 | Clear DONE flag. | | | 706542 | Clear DONE flag. | | | 706562 | Clear DONE flag. | | LPL2 | 706526 | Load printing buffer with two characters; clear DONE FLAG: THE CONTENTS OF AC6-11 and AC12-17 are transferred to the printing buffer as 6-bit bytes in that order. The DONE flag will be set when the load sequence is finished. | | LPLD | 706546 | Load the printing buffer with three characters. The DONE flag is cleared; the contents of AC 0-5, 6-11, and 12-17 are transferred as 6-bit bytes into the printing buffer in that order. The DONE flag is set at the completion of the load sequence. | | LPL1 | 706566 | Load the printing buffer with one character; clear DONE flag; the contents of AC12-17 are transferred as a 6-bit byte into the printing buffer. The DONE flag is set at the completion of the load sequence. | | LPEF | 706601 | Skip if the ERROR flag is set. | <sup>\*</sup>These instructions have been added to the Line Printer command set to allow enabling and disabling of the interrupt. Since power clear returns the system to the interrupt enabled condition programs generated for the PDP-7 line printer (647B), which does not have these instructions, will run correctly. | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LPCF | 706602 | Clear DONE flag. | | | 706622 | Clear DONE flag. | | | 706642 | Clear DONE flag. | | | 706662 | Clear DONE flag. | | LPPB | 706606 | Select printer and initiate printing. The DONE flag is cleared; the contents of the printing buffer are printed; the printing buffer is cleared; the DONE flag is set when the printing sequence is completed. | | LPLS | 706626 | Load spacing buffer and space; the DONE flag is cleared; the contents of AC15-17 are transferred into the spacing buffer; the paper is spaced vertically according to the format selected; the spacing buffer is cleared; the DONE flag is set. | | LPPS | 706646 | Print and space. This instruction accomplishes the combined actions of LPPB and LPLS instructions. The DONE flag is cleared; the contents of AC15-17 are transferred to the spacing buffer; the contents of the printing buffer are printed; the paper is spaced vertically; the printing and spacing buffers are cleared; the DONE flag is set upon completion. | | * LPEI | 706664 | The DONE flag interrupt is enabled. | | | | Type CR01E Card Reader | | RCSF | 706701 | Skip (the next instruction in sequence) on data ready flag. | | RCSD | 706721 | Skip on card done flag. | | RCSR | 706741 | Skip on reader ready. | | | 706702 | Clear data flag, and inclusively OR column into AC12-17 in alphanumeric mode. | | RCRA | 706712 | Clear AC; clear data ready flag and read column AC12-17 in alphanumeric mode. | | | 706742 | Clear data ready flag, and inclusively OR column into AC6–17 in binary mode. | <sup>\*</sup>These instructions have been added to the Line Printer command set to allow enabling and disabling of the interrupt. Since power clear returns the system to the interrupt enabled condition programs generated for the PDP-7 line printer (647B), which does not have these instructions, will run correctly. | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | | | | | | |--------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | | Тур | e CR01E Card Reader (continued) | | | | | | | RCRB | 706752 | Clear AC; clear data ready flag and read column into AC6-17 in binary mode. | | | | | | | RCSE | 706704 | Select card reader and initiate card motion if reader is ready; clear card done flag. | | | | | | | RCLD | 706724 | Clear card done flag. | | | | | | | | | Type CR02B Card Reader | | | | | | | CRSB | 706744 | Select and read a card in binary mode. A card is started through the reader and 80 columns are read as 12-bit numbers. The card done flag is cleared. | | | | | | | CRSA | 706704 | Select and read a card in alphanumeric mode. A card is started through the reader and 80 columns are read in 6-bit BCL codes. | | | | | | | CRRB | 706712 | Read the card reader buffer into AC bits 6-17. The column flag is cleared. | | | | | | | CRSF | 706701 | Skip on column data ready flag. | | | | | | | CRSD | 706721 | Skip on card done flag. | | | | | | | CRSR | 706741 | Skip on reader ready condition. | | | | | | | CREF | 706761 | Skip on reader EOF flag. | | | | | | | CRCD | 706724 | Clear done flag. | | | | | | | | Туре | TC59 Tape Control IOT Instructions | | | | | | | MTSF | 707301 | Skip on error flag or magnetic tape flag (EF and MTF). | | | | | | | MTCR | 707321 | Skip on tape control ready (TCR). | | | | | | | MTTR | 707341 | Skip on tape transport ready (TTR). | | | | | | | MTAF | 707322 | Clear status and command registers and EF and MTF. | | | | | | | | 707324 | Inclusively OR content of AC <sub>0-11</sub> into command register. | | | | | | | MTLC | 707326 | Load content of AC <sub>0-11</sub> into command register. | | | | | | | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|----------------------------------------------------------------------| | | Type TC59 | Tape Control IOT Instructions (continued) | | MTCC | 707356 | Terminate write continuous mode. | | | 707342 | Inclusively OR content of status register into AC <sub>0-11</sub> . | | MTRS | 707352 | Read content of status register into AC <sub>0-11</sub> . | | | 707302 | Inclusively OR content of command register into AC <sub>0-11</sub> . | | MTRC | 707312 | Read command register into AC <sub>0-11</sub> . | | MTGO | 707304 | Set "go" bit to execute command in command register. | | | TC0 | 2 DECtape Control IOT Instructions | | DTCA | 707541 | Clear status register A. | | DTRA | 707552 | Read status register A. | | DTXA | 707544 | XOR status register A. | | DTLA | 707545 | Load status register A. | | DTEF | 707561 | Skip on error flag. | | DTRB | 707572 | Read status B. | | DTDF | 707601 | Skip on DECtape flag. | | | K | G09A Memory Extension Control | | SEM | 707701 | Skip if in extend mode. | | EEM | 707702 | Enter extend mode. | | LEM | 707704 | Leave extend mode. | | | | KX09A Memory Protection | | MPSNE | 701741 | Skip on NonExistent Memory Flag | | MPSK | 701701 | Skip on Violation Flag | | MPEV | 701742 | Enter Protect Mode | | MPCV | 701702 | Clear Violation Flag | | Mnemonic<br>Symbol | Octal<br>Code | Operation<br>Executed | |--------------------|---------------|-----------------------------------------------| | | | KX09A Memory Protection (continued) | | MPCNE | 701744 | Clear NonExistent Memory Flag | | MPLD | 701704 | Load boundary register from AC <sub>3-7</sub> | | | | KP09A Power Failure Protection | | | 703201 | Skip if Power–Low Flag is set | #### OPERATE INSTRUCTIONS | Mnemonic<br>Symbol | Octal<br>Code | Event<br>Time | Operation<br>Executed | |--------------------|---------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | OPR or<br>NOP | 740000 | | Operate group or no operation. Causes a 1-cycle program delay. | | CMA | 740001 | 3 | Complement accumulator. Each bit of the AC is complemented. | | CML | 740002 | 3 | Complement link. | | OAS | 740004 | 3 | Inclusive OR ACCUMULATOR switches. The word set into the ACCUMULATOR switches is OR combined with the content of the AC, the result remains in the AC. | | RAL | 740010 | 3 | Rotate accumulator left. The content of the AC and L are rotated one position to the left. | | RAR | 740020 | 2 | Rotate accumulator right. The content of the AC and L are rotated one position to the right. | | HLT | 740040 | | Halt. The program is stopped at the conclusion of the cycle. | | SMA | 740100 | 1 | Skip on minus accumulator. If the content of the AC is negative (2's complement) number the next instruction is skipped. | | SZA | 740200 | 1 | Skip on zero accumulator. If the content of the AC equals zero (2's complement), the next instruction is skipped. | | SNL | 740400 | 1 | Skip on non-zero link. If the L contains a 1, the next instruction is skipped. | # OPERATE INSTRUCTIONS (continued) | Mnemonic<br>Symbol | Octal<br>Code | Event<br>Time | Operation<br>Executed | |--------------------|---------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------| | SKP | 741000 | 1 | Skip. The next instruction is unconditionally skipped. | | SPA | 741100 | 1 | Skip on positive accumulator. If the content of the AC is zero (2's complement) or a positive number, the next instruction is skipped. | | SNA | 741200 | 1 | Skip on non-zero accumulator. If the content of the AC is not zero (2's complement), the next instruction is skipped. | | SZL | 741400 | 1 | Skip on zero link. If the L contains a 0, the next instruction is skipped. | | RTL | 742010 | 2,3 | Rotate two left. The content of the AC and the L are rotated two positions to the left. | | RTR | 742020 | 2,3 | Rotate two right. The content of the AC and the L are rotated two positions to the right. | | CLL | 744000 | 2 | Clear link. The L is cleared. | | STL | 744002 | 2,3 | Set link. The L is set to 1. | | RCL | 744010 | 2,3 | Clear link, then rotate left. The L is cleared, then the L and AC are rotated one position left. | | RCR | 744020 | 2,3 | Clear link, then rotate right. The L is cleared, then the L and AC are rotated one position right. | | CLA | 750000 | 2 | Clear accumulator. Each bit of the AC is cleared. | | CLC | 750001 | 2,3 | Clear and complement accumulator. Each bit of the AC is set to contain a 1. | | LAS | 750004 | 2,3 | Load accumulator from switches. The word set into the ACCUMULATOR switches is loaded into the AC. | | GLK | 750010 | 2,3 | Get link. The content of L is set into AC17. | | LAW N | 76XXXX | | Load the AC with 76XXXX. | APPENDIX 2 PDP-9 I/O CODES ## MODEL 33, 35 ASR/KSR TELETYPE CODE (ASCII) IN OCTAL FORM | Character | 8 <b>-</b> Bit Code<br>(in Octal) | Character | 8-Bit Code<br>(in Octal) | | |-----------|-----------------------------------|-----------------------|--------------------------|--| | Α | 301 | ! | 241 | | | В | 302 | н | 242 | | | С | 303 | # | 243 | | | D | 304 | \$ | 244 | | | Е | 305 | % | <b>24</b> 5 | | | F | 306 | & | 246 | | | G | 307 | 1 | 247 | | | Н | 310 | ( | 250 | | | I | 311 | ) | 251 | | | J | 312 | * | 252 | | | K . | 313 | + | 253 | | | L | 314 | , | 254 | | | М | 315 | - | <b>2</b> 55 | | | N · | 316 | • | 256 | | | 0 | 317 | / | 257 | | | Р | 320 | : | 272 | | | Q | 321 | ; | 273 | | | R | 322 | < | 274 | | | S | 323 | = | 275 | | | T | 324 | > | 276 | | | U | 325 | ? | 277 | | | V | 326 | @ | 300 | | | W | 327 | [ | 333 | | | X | 330 | / | 334 | | | Υ | 331 | ] | 335 | | | Z | 332 | † | 336 | | | 0 | 260 | <b>→</b> | 337 | | | 1 | 261 | Leader/Trailer | 200* | | | 2 | 262 | Line-Feed | 212* | | | 3 | 263 | Carriage-Return | 215 | | | 4 | 264 | Space | 240 | | | 5 | 265 | Rub-out | 377* | | | 6 | 266 | Blank | 000* | | | 7 | 267 | ALT Mode | 375 | | | 8 | 270 | * Ignored by the oper | ating system | | | 9 | 271 | | | | \* OBTAINED WITH SHIFT KEY ## TELETYPE CODE COMPARISON | Character<br>Name | Flexowriter<br>FIODEC Code | 28 KSR<br>Baudot Code | 33 or 35 KSR<br>ASCII Code | |--------------------|----------------------------|-----------------------|----------------------------| | | 0-9 | 0-9 | 0-9 | | | a-z | A-Z | A-Z | | | A-Z | \$A-\$Z | A-Z | | period | • | • | • | | | , | , | , | | minus sign | _ | _ | - | | | / | | | | center dot, period | : | : | : | | center dot, comma | <i>;</i> | ; | ; | | | ( | ( | ( | | | ) | ) | ) | | | + | & | + | | | † | <u>!</u> | † | | multiply | × | # | * | | | 1 | \$" | 11 | | | | <b>\$</b> ' | t | | | = | \$: | = | | <del></del> | 1 | \$( | <u> </u> | | | <u>l</u> | \$) | | | | < | \$-<br>* 0 | < | | | > | \$& | <u>&gt;</u> | | | ~<br>∩ | \$? | | | | | <b>\$</b> , | %<br>! | | | <u>V</u> | \$/<br>\$# | | | | <b>∧</b> | · | <b>&amp;</b><br>@ | | vertical stroke | I | \$;<br>\$! | <u>w</u> | | underbar | | ) i | | | underbar<br>center | <del>-</del> | \$. | ⊅<br>none | | center<br>overbar | •<br>_ | φ.<br>1 | none<br># | | O V CI DUI | stop code | none | form feed | | | ) | ) | ) ↓ | | | tab≝ | bell | tab | LINE PRINTER ASCII CODE IN OCTAL FORM | Character | 6-Bit Trimmed<br>Code<br>(in octal) | Character | 6-Bit Trimmed<br>Code<br>(in octal) | | | |-----------|-------------------------------------|-----------|-------------------------------------|--|--| | A | 01 | 6 | 66 | | | | В | 02 | 7 | 67 | | | | С | 03 | 8 | 70 | | | | D | 04 | 9 | <i>7</i> 1 | | | | E | 05 | ! | 41 | | | | F | 06 | II | 42 | | | | G | 07 | # | 43 | | | | H | 10 | \$ | 44 | | | | I | 11 | % | 45 | | | | J | 12 | & | 46 | | | | K | 13 | 1 | 47 | | | | L | 14 | ( | 50 | | | | M | 15 | ) | 51 | | | | Ν | 16 | * | 52 | | | | 0 | 17 | + | 53 | | | | Р | 20 | , | 54 | | | | Q | 21 | - | 55 | | | | R | 22 | • | 56 | | | | S | 23 | / | 57 | | | | T | 24 | ; | 72 | | | | U | 25 | ; | 73 | | | | V | 26 | < | 74 | | | | W | 27 | = | 75 | | | | X | 30 | > | 76 | | | | Υ | 31 | ? | 77 | | | | Z | 32 | @ | 00 | | | | 0 | 60 | Ī | 33 | | | | 1 | 61 | \ | 34 | | | | | 62 | ]` | 35 | | | | 2<br>3 | 63 | <b>†</b> | 36 | | | | 4 | 64 | <b>4</b> | 37 | | | | 5 | 65 | Space | 40 | | | TYPE CROIE CARD READER, INTERNAL ALPHANUMERIC CODES | 12110 | ZONE | | | | | | | | | | | | |----------|----------|-------|-------|----------|------------|------|----------|-----|-----|----------|-----|------| | 1-9 | No | Punch | | | 0 | | | 11 | | | 12 | | | | Internal | 029 | 026 | Internal | 029 | 026 | Internal | 029 | 026 | Internal | 029 | 026 | | No Punch | 00* | Blank | Blank | 20* | 0 | 0 | 40 | _ | - | 60 | & | +[&] | | Ī | 01 | ī | 1 | 21 | / | / | 41 | J | J | 61 | Α | Α | | 2 | 02 | 2 | 2 | 22 | S | S | 42 | K | К | 62 | В | В | | 3 | 03 | 3 | 3 | 23 | T | T | 43 | L | L | 63 | С | С | | 4 | 04 | 4 | 4 | 24 | U | U | 44 | Μ | М | 64 | D | D | | 5 | 05 | 5 | 5 | 25 | ٧ | ٧ | 45 | Z | Z | 65 | E | E | | 6 | 06 | 6 | 6 | 26 | W | W | 46 | 0 | 0 | 66 | F | F | | 7 | 07 | 7 | 7 | 27 | X | Х | 47 | Р | Р | 67 | G | G | | 8 | 10 | 8 | 8 | 30 | Υ | Υ | 50 | Q | Q | 70 | Н | Н | | 9 | 11 | 9 | 9 | 31 | Z | Z | 51 | R | R | 71 | I | I | | 8-2 | 12 | : | | 32 | <b>+</b> † | | 52 | ! | | 72 | ¢ | | | 8-3 | 13 | # | = [#] | 33 | , | , | 53 | \$ | \$ | 73 | • | · | | 8-4 | 14 | @ | ' [@] | 34 | % | ([%] | 54 | * | * | 74 | < | )[□] | | 8-5 | 15 | 1 | | 35 | | | 55 | ) | | 75 | ( | | | 8-6 | 16 | = | | 36 | > | | 56 | ; | | 76 | + | | | 8-7 | 17 | 11 | | 37 | ? | | 57 | ٦ | | 77 | - | | <sup>\*</sup> A blank column appears as code 00 and a 0-zone punch (alone) appears as 20. To transform this to IBM compatible tape BCD, a programmed reversal of these two codes must take place. <sup>+</sup> Non-printing character. TYPE CR02B CARD READER CODE (HOLLERITH) IN OCTAL FORM | Character | Octal<br>Code | Character | Octal<br>Code | Character | Octal<br>Code | Character | Octal<br>Code | |-----------|---------------|-----------|---------------|-----------|---------------|-----------|---------------| | A | 61 | М | 44 | Υ | 30 | + | 60 | | В | 62 | N | 45 | Ž | 31 | _ | 40 | | С | 63 | 0 | 46 | 0 | 12 | / | 21 | | D | 64 | Р | 47 | l ī | 01 | = | 13 | | Ε | 65 | Q | 50 | 2 | 02 | , | 33 | | F | 66 | R | 51 | 3 | 03 | \$ | 53 | | G | 67 | S | 22 | 4 | 04 | | 73 | | Н | 70 | T | 23 | 5 | 05 | 1 | 14 | | I | <i>7</i> 1 | U | 24 | 6 | 06 | ( | 34 | | J | 41 | V | 25 | 7 | 0 <i>7</i> | * | 54 | | K | 42 | l w | 26 | 8 | 10 | ) | 74 | | L | 43 | X | 27 | 9 | 11 | <b>_</b> | | | | | | | | | blank | 00 | TYPE CRO2B CARD READER CODE (HOLLERITH) IN BINARY FORM | | High order bits | | | | | | | |-------------------|-----------------|-------|----|-------|--|--|--| | Low order<br>bits | 00 | 01 | 10 | 11 | | | | | 0000 | | blank | _ | + [&] | | | | | 0001 | 1 | / | J | Α | | | | | 0010 | 2 | S | K | В | | | | | 0011 | 3 | T | L | С | | | | | 0100 | 4 | U | M | D | | | | | 0101 | 5 | V | Ν | E | | | | | 0110 | 6 | W | 0 | F | | | | | 0111 | 7 | X | Р | G | | | | | 1000 | 8 | Υ | Q | Н | | | | | 1001 | 9 | Z | R | I | | | | | 1010 | 0 | | | | | | | | 1011 | = [ # ] | , | \$ | | | | | | 1100 | '[@] | ([%] | * | )[□] | | | | HOLLERITH CARD CODE - TYPE 26 PUNCH | | | Zone | | | |----------|---------|--------|----|------| | digit | no zone | 12 | 11 | 0 | | no punch | blank | + [ &] | _ | 0 | | i | 1 | Α | J | / | | 2 | 2 | В | K | S | | 3 | 3 | С | Ĺ | T | | 4 | 4 | D | M | U | | 5 | 5 | E | Ν | V | | 6 | 6 | F | 0 | W | | 7 | 7 | G | Р | X | | 8 | 8 | Н | Q | Υ | | 9 | 9 | I | R | Z | | 8-3 | = [ #] | • | \$ | , | | 8-4 | '[@] | )[□] | * | ([%] | HOLLERITH CARD CODE - TYPE 29 PUNCH | | | Zone | | | |----------|----------|------|----|---------------| | digit | no zone | 12 | 11 | 0 | | no punch | blank | & | _ | 0 | | 1 | 1 | Α | J | / | | 2 | 2 | В | K | S | | 3 | 3 | С | L | T | | 4 | 4 | D | M | U | | 5 | 5 | E | Ν | V | | 6 | 6 | F | 0 | W | | 7 | <b>7</b> | G | Р | X | | 8 | 8 | Н | Q | Υ | | 9 | 9 | I | R | Z | | 8-2 | : | ¢ | Į. | | | 8-3 | # | • | \$ | , | | 8-4 | @ | < | * | <b>,</b><br>% | | 8-5 | 1 | ( | ) | | | 8-6 | = | + | ; | ⋝ | | 8-7 | II | 1 | • | ? | #### APPENDIX 3 #### SCALES OF NOTATION | 2X IN DECIMAL | | | | | | | | | | |-------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | x | 2 <sup>x</sup> x | 2× | x 2 <sup>x</sup> | | | | | | | | 0.001<br>0.002<br>0.003<br>0.004<br>0.005<br>0.006<br>0.007<br>0.008<br>0.009 | 1.00138 72557 11335 0.02 1.00208 16050 79633 0.03 1.00277 64359 01078 0.04 1.00347 17485 09503 0.05 1.00416 75432 38973 0.06 1.00486 38204 23785 0.07 1.00556 05803 98468 0.08 | .00695 55500 56719<br>.01395 94797 90029<br>.02101 21257 07193<br>.02811 38266 56067<br>.03526 49238 41377<br>.04246 57608 41121<br>.04971 66836 23067<br>.05701 80405 61380<br>.06437 01824 53360 | 0.1 1.07177 34625 36293<br>0.2 1.14869 83549 97035<br>0.3 1.23114 44133 44916<br>0.4 1.31950 79107 72894<br>0.5 1.41421 35623 73095<br>0.6 1.51571 65665 10398<br>0.7 1.62450 47927 12471<br>0.8 1.74110 11265 92248<br>0.9 1.86606 59830 73615 | | | | | | | | | 10 <sup>±n</sup> | IN OCTAL | | | | | | | | | 10^ | n 10-^ | 10° | n 10 <sup>-</sup> | | | | | | | | | 0 1.000 000 000 000 000 000 00<br>1 0.063 146 314 631 463 146 31<br>2 0.005 075 341 217 270 243 66<br>3 0.000 406 111 564 570 651 77<br>4 0.000 032 155 613 530 704 15 | 112 402 762 000<br>1 351 035 564 000<br>16 432 451 210 000<br>221 411 634 520 000<br>2 657 142 036 440 000 | 11 0.000 000 000 000 537 657 77 | | | | | | | | 46 113 200<br>575 360 400 | 5 0.000 002 476 132 610 706 64<br>6 0.000 000 206 157 364 055 37<br>7 0.000 000 015 327 745 152 75<br>8 0.000 000 001 257 143 561 06<br>9 0.000 000 000 104 560 276 41 | 34 327 724 461 500 000<br>434 157 115 760 200 000<br>5 432 127 413 542 400 000<br>7 405 553 164 731 000 000 | 16 0.000 000 000 000 000 001 63<br>17 0.000 000 000 000 000 000 14 | | | | | | | | | n log <sub>10</sub> 2, n l | g 2 10 IN DECIMAL | | | | | | | | | n | n log <sub>10</sub> 2 n log <sub>2</sub> 10 | n nlo | g <sub>10</sub> 2 n log <sub>2</sub> 10 | | | | | | | | 1<br>2<br>3<br>4<br>5 | 0.30102 99957 3.32192 80949 0.60205 99913 6.64385 61898 0.90308 99870 9.96578 42847 1.20411 99827 13.28771 23795 1.50514 99783 16.60964 04744 | 7 2.1072<br>8 2.4082<br>9 2.7092 | 7 99740 19.93156 85693<br>0 99696 23.25349 66642<br>3 99653 26.57542 47591<br>6 99610 29.89735 28540<br>9 99566 33.21928 09489 | | | | | | | #### ADDITION AND MULTIPLICATION TABLES | Addition | | Multiplication | |----------|--------------|-----------------------------------------------------------------------------------------------| | | Binary Scale | | | 0+1= | | $0 \times 1 = \begin{matrix} 0 \times 0 = 0 \\ 1 \times 0 = 0 \\ 1 \times 1 = 1 \end{matrix}$ | #### Octal Scale | 0 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 1 | 02 | 03 | 04 | 05 | 06 | 07 | |---|----|----|----|----|----|----|----|---|----|----|----|----|----|----| | 1 | 02 | 03 | 04 | 05 | 06 | 07 | 10 | 2 | 04 | 06 | 10 | 12 | 14 | 16 | | 2 | 03 | 04 | 05 | 06 | 07 | 10 | 11 | 3 | 06 | 11 | 14 | 17 | 22 | 25 | | 3 | 04 | 05 | 06 | 07 | 10 | 11 | 12 | 4 | 10 | 14 | 20 | 24 | 30 | 34 | | 4 | 05 | 06 | 07 | 10 | 11 | 12 | 13 | 5 | 12 | 17 | 24 | 31 | 36 | 43 | | 5 | 06 | 07 | 10 | 11 | 12 | 13 | 14 | 6 | 14 | 22 | 30 | 36 | 44 | 52 | | 6 | 07 | 10 | 11 | 12 | 13 | 14 | 15 | | 16 | | | | | | | 7 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | | • | | | | | | # MATHEMATICAL CONSTANTS IN OCTAL SCALE | $\pi = 3.11037$ | 552421 | e = 2.55760 | 521305 <sub>6</sub> | γ = | 0.44742 | 147707 | |------------------------|---------|-------------------------------|---------------------|---------------------|-----------|---------| | $\pi^{-1} = 0.24276$ | 301556 | $e^{-1} = 0.27426$ | 530661: | In γ = - | - 0.43127 | 233602 | | $\sqrt{\pi} = 1.61337$ | 611067: | $\sqrt{e} = 1.51411$ | 230704 | $\log_2 \gamma = -$ | 0.62573 | 030645 | | $\ln \pi = 1.11206$ | 404435 | log <sub>10</sub> e = 0.33626 | 754251 | <b>√2</b> = | 1.32404 | 746320, | | $\log_2 \pi = 1.51544$ | 1632238 | log₂ e = 1.34252 | 166245 | In 2 = | 0.54271 | 027760: | | $\sqrt{10} = 3.12305$ | 407267 | log <sub>2</sub> 10 = 3.24464 | 741136 <sub>8</sub> | In 10 = | 2.23273 | 067355 | #### **POWERS OF TWO** ``` 2<sup>n</sup> 2 1 1.0 1 0.5 2 0.25 8 0.125 3 0.062 5 16 0.031 25 32 5 64 6 0.015 625 128 0.007 812 5 256 8 0.003 906 25 0.001 953 125 512 1 024 10 0.000 976 562 5 2 048 0.000 488 281 25 11 4 096 0.000 244 140 625 12 8 192 0.000 122 070 312 5 13 16 384 0.000 061 035 156 25 14 32 768 15 0.000 030 517 578 125 65 536 16 0.000 015 258 789 062 5 __131_072 17 0.000 007 629 394 531 25 262 144 18 0.000 003 814 697 265 625 0.000 001 907 348 632 812 5 524 288 19 1 048 576 0.000 000 953 674 316 406 25 20 2 097 152 21 0.000 000 476 837 158 203 125 4 194 304 22 0.000 000 238 418 579 101 562 5 8 388 608 0.000 000 119 209 289 550 781 25 16 777 216 24 0.000 000 059 604 644 775 390 625 33 554 432 25 0.000 000 029 802 322 387 695 312 5 67 108 864 26 0.000 000 014 901 161 193 847 656 25 134 217 728 0.000 000 007 450 580 596 923 828 125 27 0.000 000 003 725 290 298 461 914 062 5 268 435 456 28 536 870 912 29 0.000 000 001 862 645 149 230 957 031 25 1 073 741 824 0.000 000 000 931 322 574 615 478 515 625 2 147 483 648 31 0.000 000 000 465 661 287 307 739 257 812 5 4 294 967 296 0.000 000 000 232 830 643 653 869 628 906 25 32 8 589 934 592 0.000 000 000 116 415 321 826 934 814 453 125 33 17 179 869 184 0.000 000 000 058 207 660 913 467 407 226 562 5 34 34 359 738 368 35 0.000 000 000 029 103 830 456 733 703 613 281 25 68 719 476 736 36 0.000 000 000 014 551 915 228 366 851 806 640 625 137 438 953 472 0.000 000 000 007 275 957 614 183 425 903 320 312 5 274 877 906 944 0.000 000 000 003 637 978 807 091 712 951 660 156 25 549 755 813 888 0.000 000 000 001 818 989 403 545 856 475 830 078 125 39 1 099 511 627 776 0.000 000 000 000 909 494 701 772 928 237 915 039 062 5 40 2 199 023 255 552 0.000 000 000 000 454 747 350 886 464 118 957 519 531 25 41 4 398 046 511 104 42 0.000 000 000 000 227 373 675 443 232 059 478 759 765 625 8 796 093 022 208 0.000 000 000 000 113 686 837 721 616 029 739 379 882 812 5 43 17 592 186 044 416 0.000 000 000 000 056 843 418 860 808 014 869 689 941 406 25 35 184 372 088 832 0.000 000 000 000 028 421 709 430 404 007 434 844 970 703 125 70 368 744 177 664 0.000 000 000 000 014 210 854 715 202 003 717 422 485 351 562 5 140 737 488 355 328 0.000 000 000 000 007 105 427 357 601 001 858 711 242 675 781 25 47 281 474 976 710 656 0.000 000 000 000 003 552 713 678 800 500 929 355 621 337 890 625 48 562 949 953 421 312 49 0.000 000 000 000 001 776 356 839 400 250 464 677 810 668 945 312 5 1 125 899 906 842 624 0.000 000 000 000 000 888 178 419 700 125 232 338 905 334 472 656 25 0.000 000 000 000 000 444 089 209 850 062 616 169 452 667 236 328 125 2 251 799 813 685 248 4 503 599 627 370 496 0.000 000 000 000 000 222 044 604 925 031 308 084 726 333 618 164 062 5 9 007 199 254 740 992 0.000 000 000 000 000 111 022 302 462 515 654 042 363 166 809 082 031 25 53 18 014 398 509 481 984 54 0.000 000 000 000 000 055 511 151 231 257 827 021 181 583 404 541 015 625 36 028 797 018 963 968 0.000 000 000 000 000 027 755 575 615 628 913 510 590 791 702 270 5u7 812 5 55 72 057 594 037 927 936 0.000 000 000 000 000 013 877 787 807 814 456 755 295 395 851 135 253 906 25 144 115 188 075 855 872 57 0.000 000 000 000 000 006 938 893 903 907 228 377 647 697 925 567 626 953 125 288 230 376 151 711 744 0.000 000 000 000 000 003 469 446 951 953 614 188 823 848 962 783 813 476 562 5 576 460 752 303 423 488 0.000 000 000 000 000 001 734 723 475 976 807 094 411 924 481 391 906 738 281 25 1 152 921 504 606 846 976 0.000 000 000 000 000 000 867 361 737 988 403 547 205 962 240 695 953 369 140 625 60 0.000 000 000 000 000 000 433 680 868 994 201 773 602 981 120 347 976 684 570 312 5 2 305 843 009 213 693 952 61 4 611 686 018 427 387 904 0.000 000 000 000 000 000 216 840 434 497 100 886 801 490 560 173 988 342 285 156 25 62 9 223 372 036 854 775 808 0.000 000 000 000 000 000 108 420 217 248 550 443 400 745 280 086 994 171 142 578 125 18 446 744 073 709 551 616 0.000\ 000\ 000\ 000\ 000\ 000\ 0054\ 210\ 108\ 624\ 275\ 221\ 700\ 372\ 640\ 043\ 497\ 085\ 571\ 289\ 062\ 5 0.000\ 000\ 000\ 000\ 000\ 000\ 000\ 027\ 105\ 054\ 312\ 137\ 610\ 850\ 186\ 320\ 021\ 748\ 542\ 785\ 644\ 531\ 25 36 893 488 147 419 103 232 73 786 976 294 838 206 464 0.000 000 000 000 000 000 013 552 527 156 C68 805 425 093 160 010 874 271 392 822 265 625 66 147 573 952 589 676 412 928 67 0.000 000 000 000 000 000 006 776 263 578 034 402 712 546 580 005 437 135 696 411 132 812 5 0.000 000 000 000 000 000 003 388 131 789 017 201 356 273 290 002 718 567 848 205 566 406 25 295 147 905 179 352 825 856 68 590 295 810 358 705 651 712 0.000 000 000 000 000 000 001 694 065 894 508 600 678 136 645 001 359 283 924 102 783 203 125 69 1 180 591 620 717 411 303 424 70 0.000 000 000 000 000 000 000 847 032 947 254 300 339 068 322 500 679 641 962 051 391 601 562 5 2 361 183 241 434 822 606 848 71 0.000 000 000 000 000 000 000 423 516 473 627 150 169 534 161 250 339 820 981 025 695 800 781 25 4 722 366 482 869 645 213 696 0.000 000 000 000 000 000 000 211 758 236 813 575 084 767 080 625 169 910 490 512 847 900 390 625 ``` ## OCTAL-DECIMAL INTEGER CONVERSION TABLE | 0000 | 0000 | |---------|-----------| | to | to | | 9777 | 0511 | | (Octal) | (Decimal) | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |------|--------------|--------------|------|------|------|------|------|------| | 0000 | 0000 | 0001 | 0002 | 0003 | 0004 | 0005 | 0006 | 0007 | | 0010 | 0008 | 0009 | 0010 | 0011 | 0012 | 0013 | 0014 | 0015 | | 0020 | 0016 | 0017 | 0018 | 0019 | 0020 | 0021 | 0022 | 0023 | | 0030 | 0024 | 0025 | 0026 | 0027 | 0028 | 0029 | 0030 | 0031 | | 0040 | 0032 | 0033 | 0034 | 0035 | 0036 | 0037 | 0038 | 0039 | | 0050 | 0040 | 0041 | 0042 | 0043 | 0044 | 0045 | 0046 | 0047 | | 0060 | 0048 | 0049 | 0050 | 0051 | 0052 | 0053 | 0054 | 0055 | | 0070 | 0056 | 0057 | 0058 | 0059 | 0060 | 0061 | 0062 | 0063 | | | 1 | | | | | | | | | 0100 | 0064 | 0065 | 0066 | 0067 | 0068 | 0069 | 0070 | 0071 | | 0110 | 0072 | 0073 | 0074 | 0075 | 0076 | 0077 | 0078 | 0079 | | 0120 | 0080 | 0081 | 0082 | 0083 | 0084 | 0085 | 0086 | 0087 | | 0130 | 0088 | 0089 | 0090 | 0091 | 0092 | 0093 | 0094 | 0095 | | 0140 | 0096 | 0097 | 0098 | 0099 | 0100 | 0101 | 0102 | 0103 | | 0150 | 0104 | 0105 | 0106 | 0107 | 0108 | 0109 | 0110 | 0111 | | 0160 | 0112 | 0113 | 0114 | 0115 | 0116 | 0117 | 0118 | 0119 | | 0170 | 0120 | 0121 | 0122 | 0123 | 0124 | 0125 | 0126 | 0127 | | 0200 | 0120 | 0110 | | | | | | | | 0200 | 0128 | 0129 | 0130 | 0131 | 0132 | 0133 | 0134 | 0135 | | 0210 | 0136 | 0137 | 0138 | 0139 | 0140 | 0141 | 0142 | 0143 | | 0230 | 0152 | 0145 | 0146 | 0147 | 0148 | 0149 | 0150 | 0151 | | 0230 | | 0153 | 0154 | 0155 | 0156 | 0157 | 0158 | 0159 | | 0250 | 0160<br>0168 | 0161<br>0169 | 0162 | 0163 | 0164 | 0165 | 0166 | 0167 | | 0250 | 0176 | 0169 | 0170 | 0171 | 0172 | 0173 | 0174 | 0175 | | 0270 | 0176 | 0185 | 0178 | 0179 | 0180 | 0181 | 0182 | 0183 | | 0210 | 0104 | 0193 | 0186 | 0187 | 0188 | 0189 | 0190 | 0191 | | 0300 | 0192 | 0193 | 0194 | 0195 | 0196 | 0197 | 0198 | 0199 | | 0310 | 0200 | 0201 | 0202 | 0203 | 0204 | 0205 | 0206 | 0207 | | 0320 | 0208 | 0209 | 0210 | 0211 | 0212 | 0213 | 0214 | 0215 | | 0330 | 0216 | 0217 | 0218 | 0219 | 0220 | 0221 | 0222 | 0223 | | 0340 | 0224 | 0225 | 0226 | 0227 | 0228 | 0229 | 0230 | 0231 | | 0350 | 0232 | 0233 | 0234 | 0235 | 0236 | 0237 | 0238 | 0239 | | 0360 | 0240 | 0241 | 0242 | 0243 | 0244 | 0245 | 0246 | 0247 | | 0370 | 0248 | 0249 | 0250 | 0251 | 0252 | 0253 | 0254 | 0255 | | | | | - | | | | | | | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |------|-------|-----|------|------|------|------|------|------|--------------| | 040 | 0 0 | 256 | 0257 | 0258 | 0259 | 0260 | 0261 | 0262 | 0263 | | 041 | 0 0 | 264 | 0265 | 0266 | 0267 | 0268 | 0269 | 0270 | 0271 | | 042 | 0 0 | 272 | 0273 | 0274 | 0275 | 0276 | 0277 | 0278 | 0279 | | 043 | 0 0 | 280 | 0281 | 0282 | 0283 | 0284 | 0285 | 0286 | 0287 | | 044 | 0 0 | 288 | 0289 | 0290 | 0291 | 0292 | 0293 | 0294 | 0295 | | 045 | 0 0 | 296 | 0297 | 0298 | 0299 | 0300 | 0301 | 0302 | 0303 | | 046 | 0 0 | 304 | 0305 | 0306 | 0307 | 0308 | 0309 | 0310 | 0311 | | 047 | ᅇ | 312 | 0313 | 0314 | 0315 | 0316 | 0317 | 0318 | 0319 | | 050 | | 320 | 0321 | 0322 | 0323 | 0324 | 0325 | 0326 | 0327 | | 051 | - 1 - | 328 | 0329 | 0330 | 0331 | 0332 | 0333 | 0334 | 0335 | | 052 | | 336 | 0337 | 0338 | 0339 | 0340 | 0341 | 0342 | 0343 | | 053 | | 344 | 0345 | 0346 | 0347 | 0348 | 0349 | 0350 | 0351 | | 0540 | . , - | 352 | 0353 | 0354 | 0355 | 0356 | 0357 | 0358 | 0359 | | 0550 | | 360 | 0361 | 0362 | 0363 | 0364 | 0365 | 0366 | 0367 | | 0560 | | 368 | 0369 | 0370 | 0371 | 0372 | 0373 | 0374 | 0375 | | 0570 | 0: | 376 | 0377 | 0378 | 0379 | 0380 | 0381 | 0382 | 0383 | | 0600 | 0: | 384 | 0385 | 0386 | 0387 | 0388 | 0389 | 0390 | 0391 | | 0610 | 0: | 392 | 0393 | 0394 | 0395 | 0396 | 0397 | 0398 | 0399 | | 0620 | | 100 | 0401 | 0402 | 0403 | 0404 | 0405 | 0406 | 0407 | | 0630 | 04 | 801 | 0409 | 0410 | 0411 | 0412 | 0413 | 0414 | 0415 | | 0640 | | 116 | 0417 | 0418 | 0419 | 0420 | 0421 | 0422 | 0423 | | 0650 | | 24 | 0425 | 0426 | 0427 | 0428 | 0429 | 0430 | 0431 | | 0660 | | 132 | 0433 | 0434 | 0435 | 0436 | 0437 | 0438 | 0439 | | 0670 | 04 | 140 | 0441 | 0442 | 0443 | 0444 | 0445 | 0446 | 0447 | | 0700 | 1 - ' | 48 | 0449 | 0450 | 0451 | 0452 | 0453 | 0454 | 0455 | | 0710 | | 56 | 0457 | 0458 | 0459 | 0460 | 0461 | 0462 | 0463 | | 0720 | | 64 | 0465 | 0466 | 0467 | 0468 | 0469 | 0470 | 0471 | | 0730 | | 72 | 0473 | 0474 | 0475 | 0476 | 0477 | 0478 | 0479 | | 0740 | | 80 | 0481 | 0482 | 0483 | 0484 | 0485 | 0486 | 0487 | | 0750 | | 88 | 0489 | 0490 | 0491 | 0492 | 0493 | 0494 | 0495 | | 0760 | | 96 | 0497 | 0498 | 0499 | 0500 | 0501 | 0502 | 050 <b>3</b> | | 0770 | 05 | 04 | 0505 | 0506 | 0507 | 0508 | 0509 | 0510 | 0511 | 1000 | 0512 to to 1777 | 1023 (Octal) (Decimal) | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |------|------|------|------|------|------|------|------|------| | 1000 | 0512 | 0513 | 0514 | 0515 | 0516 | 0517 | 0518 | 0519 | | 1010 | 0520 | 0521 | 0522 | 0523 | 0524 | 0525 | 0526 | 0527 | | 1020 | 0528 | 0529 | 0530 | 0531 | 0532 | 0533 | 0534 | 0535 | | 1030 | 0536 | 0537 | 0538 | 0539 | 0540 | 0541 | 0542 | 0543 | | 1040 | 0544 | 0545 | 0546 | 0547 | 0548 | 0549 | 0550 | 0551 | | 1050 | 0552 | 0553 | 0554 | 0555 | 0556 | 0557 | 0558 | 0559 | | 1060 | 0560 | 0561 | 0562 | 0563 | 0564 | 0565 | 0566 | 0567 | | 1070 | 0568 | 0569 | 0570 | 0571 | 0572 | 0573 | 0574 | 0575 | | 1100 | 0576 | 0577 | 0578 | 0579 | 0580 | 0581 | 0582 | 0583 | | 1110 | 0584 | 0585 | 0586 | 0587 | 0588 | 0589 | 0590 | 0591 | | 1120 | 0592 | 0593 | 0594 | 0595 | 0596 | 0597 | 0598 | 0599 | | 1130 | 0600 | 0601 | 0602 | 0603 | 0604 | 0605 | 0606 | 0607 | | 1140 | 0608 | 0609 | 0610 | 0611 | 0612 | 0613 | 0614 | 0615 | | 1150 | 0616 | 0617 | 0618 | 0619 | 0620 | 0621 | 0622 | 0623 | | 1160 | 0624 | 0625 | 0626 | 0627 | 0628 | 0629 | 0630 | 0631 | | 1170 | 0632 | 0633 | 0634 | 0635 | 0636 | 0637 | 0638 | 0639 | | 1200 | 0640 | 0641 | 0642 | 0643 | 0644 | 0645 | 0646 | 0647 | | 1210 | 0648 | 0649 | 0650 | 0651 | 0652 | 0653 | 0654 | 0655 | | 1220 | 0656 | 0657 | 0658 | 0659 | 0660 | 0661 | 0662 | 0663 | | 1230 | 0664 | 0665 | 0666 | 0667 | 0668 | 0669 | 0670 | 0671 | | 1240 | 0672 | 0673 | 0674 | 0675 | 0676 | 0677 | 0678 | 0679 | | 1250 | 0680 | 0681 | 0682 | 0683 | 0684 | 0685 | 0686 | 0687 | | 1260 | 0688 | 0689 | 0690 | 0691 | 0692 | 0693 | 0694 | 0695 | | 1270 | 0696 | 0697 | 0698 | 0699 | 0700 | 0701 | 0702 | 0703 | | 1300 | 0704 | 0705 | 0706 | 0707 | 0708 | 0709 | 0710 | 0711 | | 1310 | 0712 | 0713 | 0714 | 0715 | 0716 | 0717 | 0718 | 0719 | | 1320 | 0720 | 0721 | 0722 | 0723 | 0724 | 0725 | 0726 | 0727 | | 1330 | 0728 | 0729 | 0730 | 0731 | 0732 | 0733 | 0734 | 0735 | | 1340 | 0736 | 0737 | 0738 | 0739 | 0740 | 0741 | 0742 | 0743 | | 1350 | 0744 | 0745 | 0746 | 0747 | 0748 | 0749 | 0750 | 0751 | | 1360 | 0752 | 0753 | 0754 | 0755 | 0756 | 0757 | 0758 | 0759 | | 1370 | 0760 | 0761 | 0762 | 0763 | 0764 | 0765 | 0766 | 0767 | | 1410 | | | | | | | | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|------|------|------|------|------|------|-------| | 1410 | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | 1420 0784 0785 0786 0787 0788 0789 0790 079 1430 0792 0793 0794 0795 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0797 0798 0799 0820 0814 0814 0814 0814 0814 0814 0814 0814 0814 0815 0820 0829 0830 083 1083 1083 1083 1083 1083 1083 1083 1083 1083 1083 1083 1083 1083 1083 | 1400 | 0768 | 0769 | 0770 | 0771 | 0772 | 0773 | 0774 | 0775 | | 1430 0792 0793 0794 0795 0796 0797 0798 079 1443 0800 0801 0802 0803 0804 0805 0806 0801 1450 0808 0809 0810 0811 0811 0813 0814 081 1460 0816 0817 0818 0819 0820 0821 0822 082 1470 0824 0825 0826 0827 0828 0829 0830 083 1500 0832 0833 0834 0835 0836 0837 0838 083 1510 0840 0841 0842 0843 0844 0845 0846 084 1520 0848 0849 0850 0851 0852 0853 0854 085 1530 0856 0857 0858 0859 0860 0861 0862 086 1540 0864 0865 0866 | 1410 | 0776 | 0777 | 0778 | 0779 | 0780 | 0781 | 0782 | 0783 | | 1440 0800 0801 0802 0803 0804 0805 0806 080 1450 0808 0809 0810 0811 0812 0813 0814 081 1460 0816 0817 0818 0819 0820 0821 0822 082 1470 0824 0825 0826 0827 0828 0829 0830 083 1500 0832 0833 0834 0835 0836 0837 0838 083 1510 0840 0841 0842 0843 0844 0845 0846 0846 0846 0846 0846 0846 0846 0846 0846 0846 0846 0846 0862 086 0866 0867 0868 0869 0870 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 | 1420 | 0784 | 0785 | 0786 | 0787 | 0788 | 0789 | 0790 | 0791 | | 1450 0808 0809 0810 0811 0812 0813 0814 081 1460 0816 0817 0818 0819 0820 0821 0822 082 1470 0824 0825 0826 0827 0828 0829 0830 083 1500 0832 0833 0834 0835 0836 0837 0838 083 1510 0840 0841 0842 0843 0844 0845 0846 0846 0846 0846 0846 0846 0846 0846 0846 0846 0846 0846 0846 0867 0868 0869 0870 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 087 088 0889 | 1430 | 0792 | 0793 | 0794 | 0795 | 0796 | 0797 | 0798 | 0799 | | 1460 0816 0817 0818 0819 0820 0821 0822 082 1470 0824 0825 0826 0827 0828 0829 0830 083 1500 0832 0833 0834 0835 0836 0837 0838 083 1510 0840 0841 0842 0843 0844 0845 0846 084 1520 0848 0849 0850 0851 0852 0853 0854 085 1530 0856 0857 0858 0859 0860 0861 0862 086 1540 0864 0865 0866 0867 0868 0869 0870 087 1550 0872 0873 0874 0875 0876 0877 0878 087 1560 0880 0881 0882 0883 0884 0885 0886 0881 1570 0886 0889 0890 | 1440 | 0800 | 0801 | 0802 | 0803 | 0804 | 0805 | 0806 | 0807 | | 1470 0824 0825 0826 0827 0828 0829 0830 083 1500 0832 0833 0834 0835 0836 0837 0838 083 1510 0840 0841 0842 0843 0844 0845 0846 084 1520 0848 0849 0850 0851 0852 0853 0854 085 1530 0856 0857 0858 0859 0860 0861 0862 0867 1550 0872 0873 0874 0875 0876 0877 0878 0871 1560 0880 0881 0882 0883 0884 0885 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0888 1570 0888 0889 0899 0900 0901 0992 <td< td=""><td>1450</td><td>0808</td><td>0809</td><td>0810</td><td>0811</td><td>0812</td><td>0813</td><td>0814</td><td>0815</td></td<> | 1450 | 0808 | 0809 | 0810 | 0811 | 0812 | 0813 | 0814 | 0815 | | 1500 0832 0833 0834 0835 0836 0837 0838 083 1510 0840 0841 0842 0843 0844 0845 0846 084 1520 0848 0849 0850 0851 0852 0853 0854 085 1530 0856 0857 0858 0859 0860 0861 0862 086 1540 0864 0865 0866 0867 0868 0869 0870 087 1550 0872 0873 0874 0875 0876 0877 0878 087 1560 0880 0881 0882 0883 0884 0885 0886 088 1570 0888 0889 0890 0891 0892 0893 0894 089 1600 0896 0897 0898 0899 0900 0901 0902 0903 1610 0904 0905 0906 0907 0908 0909 0910 0911 1620 0912 0913 0914 0915 0916 0917 0918 0919 1630 0920 0921 0922 0923 0924 0925 0926 0927 1640 0928 0929 0930 0931 0932 0933 0934 0935 1650 0936 0937 0938 0939 0940 0941 0942 0943 1660 0944 0945 0946 0947 0948 0949 0950 0951 1670 0952 0953 0954 0955 0956 0957 0958 0959 1700 0960 0961 0962 0963 0964 0965 0966 0967 1710 0968 0969 0970 0971 0972 0973 0974 0975 1720 0976 0977 0978 0979 0980 0981 0982 0983 | 1460 | 0816 | 0817 | 0818 | 0819 | 0820 | 0821 | 0822 | 0823 | | 1510 0840 0841 0842 0843 0844 0845 0846 084 1520 0848 0849 0850 0851 0852 0853 0854 085 1530 0856 0857 0858 0859 0860 0861 0862 086 1540 0864 0865 0867 0868 0869 0870 087 087 0877 0878 0877 0878 0877 0878 0877 0878 0877 0878 0887 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0889 0890 0990 0991 | 1470 | 0824 | 0825 | 0826 | 0827 | 0828 | 0829 | 0830 | 0831 | | 1510 0840 0841 0842 0843 0844 0845 0846 084 1520 0848 0849 0850 0851 0852 0853 0854 085 1530 0856 0857 0858 0859 0860 0861 0862 086 1540 0864 0865 0867 0868 0869 0870 087 087 0877 0878 0877 0878 0877 0878 0877 0878 0877 0878 0887 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0886 0889 0890 0990 0991 | 1500 | 0832 | 0833 | 0834 | 0835 | 0836 | 0837 | กลรล | 10839 | | 1520 0848 0849 0850 0851 0852 0853 0854 085 1530 0856 0857 0858 0859 0860 0861 0862 086 1550 0864 0865 0866 0867 0868 0869 0870 087 0872 0873 0874 0875 0876 0877 0878 0877 1560 0880 0881 0882 0883 0884 0885 0886 0881 1570 0888 0889 0890 0891 0892 0893 0894 0891 1600 0896 0897 0898 0899 0900 0901 0902 0903 1610 0904 0905 0906 0907 0908 0909 0910 0911 1620 0912 0913 0914 0915 0916 0917 0918 0919 1630 0920 0921 0922 0923 0924 0925 0926 0927 1640 0928 0929 0930 0931 0932 0933 0934 0935 1650 0936 0937 0938 0939 0940 0941 0942 0943 1660 0944 0945 0946 0947 0948 0949 0950 0951 1670 0952 0953 0954 0955 0956 0957 0958 0959 1700 0960 0961 0962 0963 0964 0955 0966 0967 1710 0968 0969 0970 0971 0972 0973 0974 0975 1720 0976 0977 0978 0979 0980 0981 0982 0983 | | 1 | | | | | | | 0847 | | 1530 0856 0857 0858 0859 0860 0861 0862 086 1540 0864 0865 0866 0867 0868 0869 0870 0871 1550 0872 0873 0874 0875 0876 0877 0878 0871 1560 0880 0881 0882 0883 0884 0885 0886 0886 0886 0881 1570 0888 0889 0890 0891 0892 0893 0894 0891 1600 0896 0897 0898 0899 0900 0901 0902 0903 1610 0904 0905 0906 0907 0908 0909 0910 0911 1620 0912 0913 0914 0915 0916 0917 0918 0919 1630 0920 0921 0922 0923 0924 0925 0926 0927 1650 0936< | | | | | | | | | 0855 | | 1540 0864 0865 0866 0867 0868 0869 0870 087 1550 0872 0873 0874 0875 0876 0877 0878 087 1560 0880 0881 0882 0883 0884 0885 0886 088 1570 0888 0889 0890 0891 0892 0893 0894 089 1600 0896 0897 0898 0899 0900 0901 0902 0903 1610 0904 0905 0906 0907 0908 0909 0910 0911 0912 0913 0914 0915 0916 0917 0918 0919 0910 0911 0918 0919 0910 0911 0918 0919 0926 0926 0927 0926 0925 0926 0927 0926 0925 0926 0927 0926 0925 0926 0927 0926 0927 0926 | | | | | | | | | | | 1550 0872 0873 0874 0875 0876 0877 0878 0871 1560 0880 0881 0882 0883 0884 0885 0886 0885 1570 0888 0889 0890 0891 0892 0893 0894 0895 1600 0896 0897 0898 0899 0900 0901 0902 0903 1610 0904 0905 0906 0907 0908 0909 0910 0911 0912 0913 0914 0915 0916 0917 0918 0919 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 0910 0911 | | | | | | | | | | | 1560 0880 0881 0882 0883 0884 0885 0886 088 1570 0888 0889 0890 0891 0892 0893 0894 0891 1600 0896 0897 0898 0899 0900 0901 0902 0903 1610 0904 0905 0906 0907 0908 0909 0910 0911 1620 0912 0913 0914 0915 0916 0917 0918 0918 1630 0920 0921 0922 0923 0924 0925 0926 0927 1650 0928 0929 0930 0931 0932 0933 0934 0942 0942 0942 0942 0942 0942 0942 0942 0942 0943 1660 0944 0945 0946 0947 0948 0949 0950 0951 1670 0952 0953 0954 0955 0956 | | | | | | | | | 0879 | | 1570 0888 0889 0890 0891 0892 0893 0894 0893 1600 0896 0897 0898 0899 0900 0901 0902 0903 1610 0904 0905 0906 0907 0908 0909 0910 0911 1620 0912 0913 0914 0915 0916 0917 0918 0919 1630 0920 0921 0922 0923 0924 0925 0926 0927 1640 0928 0929 0930 0931 0932 0933 0934 0935 1650 0936 0937 0938 0939 0940 0941 0942 0943 1660 0944 0945 0946 0947 0948 0949 0950 0951 1670 0952 0953 0954 0955 0956 0957 0958 0959 1700 0960 0961 0962 0963 0964 0965 0966 0967 1710 0968 0969 0970 0971 0972 0973 0974 0975 1720 0976 0977 0978 0979 0980 0981 0982 0983 | | | | | | | | | 0887 | | 1600 0896 0897 0898 0899 0900 0901 0902 0903 1610 0904 0905 0906 0907 0908 0909 0910 0911 1620 0912 0913 0914 0915 0916 0917 0918 0919 1630 0920 0921 0922 0923 0924 0925 0926 0927 1640 0928 0929 0930 0931 0932 0933 0934 0935 1650 0936 0937 0938 0939 0940 0941 0942 0943 1660 0944 0945 0946 0947 0948 0949 0950 0951 1670 0952 0953 0954 0955 0956 0957 0958 0959 1700 0960 0961 0962 0963 0964 0965 0966 0967 1710 0968 0969 0970 0971 0972 0973 0974 0975 1720 0976 0977 0978 0979 0980 0981 0982 0983 | | | | | | | | | 0895 | | 1610 0904 0905 0906 0907 0908 0909 0910 0911 1620 0912 0913 0914 0915 0916 0917 0918 0919 1630 0920 0921 0922 0923 0924 0925 0926 0927 1640 0928 0929 0930 0931 0932 0933 0934 0935 1650 0936 0937 0938 0939 0940 0941 0942 0943 1660 0944 0945 0946 0947 0948 0949 0950 0951 1670 0952 0953 0954 0955 0956 0957 0958 0959 1700 0960 0961 0962 0963 0964 0965 0966 0967 1710 0968 0969 0970 0971 0972 0973 0974 0975 1720 0976 0977 0978 0979 0980 0981 0982 0983 | | • • • • • | • | | | | | | | | 1620 0912 0913 0914 0915 0916 0917 0918 0918 1630 0920 0921 0922 0923 0924 0925 0926 0927 1640 0928 0929 0930 0931 0932 0933 0934 0933 0934 0934 0942 0943 1660 0944 0945 0946 0947 0948 0949 0950 0951 1670 0952 0953 0954 0955 0956 0957 0958 0959 1700 0960 0961 0962 0963 0964 0965 0966 0967 1710 0968 0969 0970 0971 0972 0973 0974 0975 1720 0976 0977 0978 0979 0980 0981 0982 0983 | 1600 | 0896 | 0897 | 0898 | 0899 | 0900 | 0901 | 0902 | 0903 | | 1630 0920 0921 0922 0923 0924 0925 0926 0927 1640 0928 0929 0930 0931 0932 0933 0934 0935 1650 0936 0937 0938 0939 0940 0941 0942 0943 1660 0944 0945 0946 0947 0948 0949 0950 0951 1670 0952 0953 0954 0955 0956 0957 0958 0959 1700 0960 0961 0962 0963 0964 0965 0966 0967 1710 0968 0969 0970 0971 0972 0973 0974 0975 1720 0976 0977 0978 0979 0980 0981 0982 0983 | 1610 | 0904 | 0905 | 0906 | 0907 | 0908 | 0909 | 0910 | 0911 | | 1640 0928 0929 0930 0931 0932 0933 0934 0935 1650 0936 0937 0938 0939 0940 0941 0942 0943 1660 0944 0945 0946 0947 0948 0949 0950 0951 1670 0952 0953 0954 0955 0956 0957 0958 0959 1700 0960 0961 0962 0963 0964 0965 0966 0967 1710 0968 0969 0970 0971 0972 0973 0974 0975 1720 0976 0977 0978 0979 0980 0981 0982 0983 | 1620 | 0912 | 0913 | 0914 | 0915 | 0916 | 0917 | 0918 | 0919 | | 1650 0936 0937 0938 0939 0940 0941 0942 0943 1660 0944 0945 0946 0947 0948 0949 0950 0951 1670 0952 0953 0954 0955 0956 0957 0958 0959 1700 0960 0961 0962 0963 0964 0965 0966 0967 1710 0968 0969 0970 0971 0972 0973 0974 0975 1720 0976 0977 0978 0979 0980 0981 0982 0983 | 1630 | 0920 | 0921 | 0922 | 0923 | 0924 | 0925 | 0926 | 0927 | | 1660 0944 0945 0946 0947 0948 0949 0950 0951 1670 0952 0953 0954 0955 0956 0957 0958 0959 1700 0960 0961 0962 0963 0964 0965 0966 0967 1710 0968 0969 0970 0971 0972 0973 0974 0975 1720 0976 0977 0978 0979 0980 0981 0982 0983 | 1640 | 0928 | 0929 | 0930 | 0931 | 0932 | 0933 | 0934 | 0935 | | 1670 0952 0953 0954 0955 0956 0957 0958 0959<br>1700 0960 0961 0962 0963 0964 0965 0966 0967<br>1710 0968 0969 0970 0971 0972 0973 0974 0975<br>1720 0976 0977 0978 0979 0980 0981 0982 0983 | 1650 | 0936 | 0937 | 0938 | 0939 | 0940 | 0941 | 0942 | 0943 | | 1700 0960 0961 0962 0963 0964 0965 0966 0967 1710 0968 0969 0970 0971 0972 0973 0974 0975 1720 0976 0977 0978 0979 0980 0981 0982 0983 | | 0944 | 0945 | 0946 | | 0948 | 0949 | 0950 | 0951 | | 1710 0968 0969 0970 0971 0972 0973 0974 0975<br>1720 0976 0977 0978 0979 0980 0981 0982 0983 | 1670 | 0952 | 0953 | 0954 | 0955 | 0956 | 0957 | 0958 | 0959 | | 1710 0968 0969 0970 0971 0972 0973 0974 0975<br>1720 0976 0977 0978 0979 0980 0981 0982 0983 | 1700 | 0960 | 0961 | 0962 | 0963 | 0964 | 0965 | 0066 | 0067 | | 1720 0976 0977 0978 0979 0980 0981 0982 0983 | | | | | | | | | | | 1000 0002 0003 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0999 | | 1000 1000 | | | | | | | | | 1007 | | 1760 1008 1009 1010 1011 1012 1013 1014 1015 | | | | | | | | | | | 1000 | 1770 | 1016 | 1017 | | | | | | 1023 | # OCTAL-DECIMAL INTEGER CONVERSION TABLE (continued) | | | | | | | | | | 1 | | | | | | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------| | | 0 | 1 | 2 | 3 | 4 | | 6 | 7 | | | 0 | 1 | | 3 | | 5 | 6 | 7 | | | | 2010 | 1032 | 1033 | 1034 | 1027<br>1035 | 1036 | 1037 | 1038 | 1039 | | | | | | 1283<br>1291 | | | | 1287<br>1295 | 2000<br>to | 1024<br>Io | | | | | | 1043<br>1051 | | | | | | | | | | 1299<br>1307 | | | | | 2777 | 1535 | | 2040 | 1056 | 1057 | 1058 | 1059<br>1067 | 1060 | 1061 | 1062 | 1063 | | 2440 | 1312 | 1313 | 1314 | 1315 | 1316 | 1317 | 1318 | 1319 | (Octal) | (Decimal) | | 2060 | 1072 | 1073 | 1074 | 1075 | 1076 | 1077 | 1078 | 1079 | | 2460 | 1328 | 1329 | 1330 | 1323<br>1331 | 1332 | 1333 | 1334 | 1335 | 04-1 | Decimal | | | | | | 1083 | | | | | | 2470 | 1336 | 1337 | 1338 | 1339 | 1340 | 1341 | 1342 | 1343 | | - 4096 | | | | | | 1091<br>1099 | | | | | | | | | | 1347<br>1355 | | | | | | - 8192<br>- 12288 | | 2120 | 1104 | 1105 | 1106 | 1107<br>1115 | 1108 | 1109 | 1110 | 1111 | | 2520 | 1360 | 1361 | 1362 | 1363 | 1364 | 1365 | 1366 | 1367 | 40000 | - 16384 | | 2140 | 1120 | 1121 | 1122 | 1123 | 1124 | 1125 | 1126 | 1127 | | 2540 | 1376 | 1377 | 1378 | 1371<br>1379 | 1380 | 1381 | 1382 | 1383 | 60000 | - 20480<br>- 24576 | | 2160 | 1136 | 1137 | 1138 | 1131<br>1139 | 1140 | 1141 | 1142 | 1143 | | | | | | 1387<br>1395 | | | | | 70000 | - 28672 | | 2170 | 1144. | 1145 | 1146 | 1147 | 1148 | 1149 | 1150 | 1151 | | | | | | 1403 | | | | | | | | | | | | 1155<br>1163 | | | | | | | | | | 1411 | | | | | | | | 2220 | 1168 | 1169 | 1170 | 1171 | 1172 | 1173 | 1174 | 1175 | | 2620 | 1424 | 1425 | 1426 | 1419<br>1427 | 1428 | 1429 | 1430 | 1431 | | | | | | | | 1179<br>1187 | | | | | | | | | | 1435<br>1443 | | | | | | | | | | | | 1195<br>1203 | | | | | | 2650 | 1448 | 1449 | 1450 | 1451<br>1459 | 1452 | 1453 | 1454 | 1455 | | | | | | | | 1211 | | | | | | | | | | 1467 | | | | | | | | 2300 | 1216 | 1217 | 1218 | 1219 | 1220 | 1221 | 1222 | 1223 | | | | | | 1475 | | | | | | | | | | | | 1227<br>1235 | | | | | | | | | | 1483<br>1491 | | | | | | | | | | | | 1243<br>1251 | | | | | | 2730 | 1496 | 1497 | 1498 | 1499 | 1500 | 1501 | 1502 | 1503 | | | | 2350 | 1256 | 1257 | 1258 | 1259 | 1260 | 1261 | 1262 | 1263 | | 2750 | 1512 | 1513 | 1514 | 1507<br>1515 | 1516 | 1517 | 1518 | 1519 | | | | 2360<br>2370 | 1272 | 1273 | 1274 | 1275 | 1276 | 1269 | 1270 | 1271 | | 2760<br>2770 | 1520<br>1528 | 1521<br>1529 | 1522<br>1530 | 1523<br>1531 | 1524<br>1532 | 1525<br>1533 | 1526<br>1534 | 1527<br>1535 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | <u></u> | | | | | | | | | | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | | | | 1536 | 1537 | 1538 | 1539 | 1540 | 1541 | 1542 | 1543 | | 3400 | 1792 | 1793 | 1794 | 1795 | 1796 | 1797 | 1798 | 1799 | 3000 | 1536 | | 3010<br>3020 | 1536<br>1544<br>1552 | 1537<br>1545<br>1553 | 1538<br>1546<br>1554 | 1539<br>1547<br>1555 | 1540<br>1548<br>1556 | 1541<br>1549<br>1557 | 1542<br>1550<br>1558 | 1543<br>1551<br>1559 | | 3410<br>3420 | 1792<br>1800<br>1808 | 1793<br>1801<br>1809 | 1794<br>1802<br>1810 | 1795<br>1803<br>1811 | 1796<br>1804<br>1812 | 1797<br>1805<br>1813 | 1798<br>1806<br>1814 | 1799<br>1807<br>1815 | 3000<br>to<br>3777 | 1536<br>to<br>2047 | | 3010<br>3020<br>3030<br>3040 | 1536<br>1544<br>1552<br>1560<br>1568 | 1537<br>1545<br>1553<br>1561<br>1569 | 1538<br>1546<br>1554<br>1562<br>1570 | 1539<br>1547<br>1555<br>1563<br>1571 | 1540<br>1548<br>1556<br>1564<br>1572 | 1541<br>1549<br>1557<br>1565<br>1573 | 1542<br>1550<br>1558<br>1566<br>1574 | 1543<br>1551<br>1559<br>1567<br>1575 | | 3410<br>3420<br>3430<br>3440 | 1792<br>1800<br>1808<br>1816<br>1824 | 1793<br>1801<br>1809<br>1817<br>1825 | 1794<br>1802<br>1810<br>1818<br>1826 | 1795<br>1803<br>1811<br>1819<br>1827 | 1796<br>1804<br>1812<br>1820<br>1828 | 1797<br>1805<br>1813<br>1821<br>1829 | 1798<br>1806<br>1814<br>1822<br>1830 | 1799<br>1807<br>1815<br>1823<br>1831 | to | to | | 3010<br>3020<br>3030<br>3040<br>3050 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578 | 1539<br>1547<br>1555<br>1563<br>1571<br>1579 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583 | | 3410<br>3420<br>3430<br>3440<br>3450 | 1792<br>1800<br>1808<br>1816<br>1824<br>1832 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586 | 1539<br>1547<br>1555<br>1563<br>1571 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3460 | 1792<br>1800<br>1808<br>1816<br>1824<br>1832<br>1840 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842 | 1795<br>1803<br>1811<br>1819<br>1827 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3070 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594 | 1539<br>1547<br>1555<br>1563<br>1571<br>1579<br>1587<br>1595 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1598 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1599 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3460<br>3470 | 1792<br>1800<br>1808<br>1816<br>1824<br>1832<br>1840<br>1848 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842<br>1850 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3070<br>3110<br>3120 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1610<br>1618 | 1539<br>1547<br>1555<br>1563<br>1571<br>1579<br>1587<br>1595<br>1603<br>1611<br>1619 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1621 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1598<br>1606<br>1614<br>1622 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1599<br>1607<br>1615<br>1623 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3460<br>3470<br>3500<br>3510<br>3520 | 1792<br>1800<br>1808<br>1816<br>1824<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1863<br>1871<br>1879 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3070<br>3110<br>3120<br>3130 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1625 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1610<br>1618<br>1626 | 1539<br>1547<br>1555<br>1563<br>1571<br>1579<br>1587<br>1595<br>1603<br>1611<br>1619<br>1627 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612<br>1620<br>1628 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1621<br>1629 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1598<br>1606<br>1614<br>1622<br>1630 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1599<br>1607<br>1615<br>1623<br>1631 | - 1 | 3410<br>3420<br>3430<br>3440<br>3450<br>3460<br>3470<br>3500<br>3510<br>3520<br>3530 | 1792<br>1800<br>1808<br>1816<br>1824<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872<br>1880 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873<br>1881 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1882 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1875<br>1883 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1884 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1870<br>1878<br>1886 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1863<br>1871<br>1879 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3070<br>3110<br>3120<br>3130<br>3140<br>3150 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616<br>1624<br>1632 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1625<br>1633<br>1641 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1610<br>1618<br>1626<br>1634<br>1642 | 1539<br>1547<br>1555<br>1563<br>1571<br>1579<br>1587<br>1595<br>1603<br>1611<br>1619<br>1627<br>1635<br>1643 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612<br>1620<br>1628<br>1636<br>1644 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1621<br>1629<br>1637<br>1645 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1598<br>1606<br>1614<br>1622<br>1630<br>1638<br>1646 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1599<br>1607<br>1615<br>1623<br>1631<br>1639<br>1647 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3460<br>3470<br>3500<br>3510<br>3520<br>3530<br>3540<br>3550 | 1792<br>1800<br>1808<br>1816<br>1824<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872<br>1880<br>1888<br>1896 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873<br>1881<br>1889 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1882<br>1890<br>1898 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1875<br>1883<br>1891<br>1899 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1884<br>1892 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853<br>1861<br>1869<br>1877<br>1885<br>1893 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1870<br>1878<br>1886<br>1894 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1863<br>1871<br>1879<br>1887<br>1895 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3070<br>3110<br>3120<br>3130<br>3140<br>3150<br>3160 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616<br>1624<br>1632<br>1640<br>1648 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1625<br>1633<br>1641<br>1649 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1618<br>1626<br>1634<br>1642<br>1650 | 1539<br>1547<br>1555<br>1563<br>1571<br>1579<br>1587<br>1595<br>1603<br>1611<br>1619<br>1627<br>1635 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612<br>1620<br>1628<br>1636<br>1644<br>1652 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1621<br>1629<br>1637<br>1645<br>1653 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1598<br>1606<br>1614<br>1622<br>1630<br>1638<br>1646<br>1654 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1599<br>1607<br>1615<br>1623<br>1631<br>1639<br>1647<br>1655 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3460<br>3470<br>3500<br>3510<br>3520<br>3530<br>3540<br>3550<br>3560 | 1792<br>1800<br>1808<br>1816<br>1824<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872<br>1880<br>1888<br>1896 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873<br>1881<br>1889<br>1897 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1882<br>1890<br>1898 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1875<br>1883<br>1891 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1884<br>1892<br>1900<br>1908 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853<br>1861<br>1869<br>1877<br>1885<br>1893<br>1901 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1878<br>1886<br>1894<br>1902 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1863<br>1871<br>1879<br>1887<br>1895<br>1903 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3070<br>31100<br>3120<br>3130<br>3140<br>3150<br>3160<br>3170 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616<br>1624<br>1632<br>1640<br>1648<br>1656 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1625<br>1633<br>1641<br>1649<br>1657 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1618<br>1626<br>1634<br>1642<br>1650<br>1658 | 1539<br>1547<br>1555<br>1563<br>1571<br>1579<br>1587<br>1603<br>1611<br>1619<br>1627<br>1635<br>1643<br>1651<br>1659 | 1540<br>1548<br>1556<br>1564<br>1572<br>1588<br>1596<br>1604<br>1612<br>1628<br>1636<br>1644<br>1652<br>1660 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1629<br>1637<br>1645<br>1653<br>1661 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1598<br>1606<br>1614<br>1622<br>1630<br>1638<br>1646<br>1654<br>1662 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1599<br>1607<br>1615<br>1623<br>1631<br>1639<br>1647<br>1655<br>1663 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3460<br>3510<br>3520<br>3530<br>3540<br>3550<br>3560<br>3570<br>3600 | 1792<br>1800<br>1808<br>1816<br>1824<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872<br>1880<br>1888<br>1896<br>1904<br>1912 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873<br>1881<br>1889<br>1897<br>1905<br>1913 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1882<br>1890<br>1898<br>1906<br>1914 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1875<br>1883<br>1891<br>1899<br>1907<br>1915 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1884<br>1892<br>1900<br>1908<br>1916 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853<br>1861<br>1869<br>1877<br>1885<br>1893<br>1901<br>1909<br>1917 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1870<br>1878<br>1886<br>1894<br>1902<br>1910<br>1918 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1863<br>1871<br>1879<br>1887<br>1995<br>1903<br>1911<br>1919 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3100<br>3110<br>3120<br>3130<br>3140<br>3150<br>3170 | 1536<br>1544<br>1552<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616<br>1624<br>1632<br>1640<br>1648<br>1656 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1625<br>1633<br>1641<br>1657 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1610<br>1618<br>1626<br>1634<br>1645<br>1650<br>1658 | 1539<br>1547<br>1555<br>1563<br>1571<br>1579<br>1587<br>1695<br>1603<br>1611<br>1619<br>1627<br>1635<br>1643<br>1643<br>1659 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612<br>1620<br>1628<br>1636<br>1644<br>1652<br>1660 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1621<br>1629<br>1637<br>1645<br>1665<br>1661 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1598<br>1606<br>1614<br>1622<br>1630<br>1638<br>1646<br>1654<br>1662 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1599<br>1607<br>1615<br>1623<br>1631<br>1639<br>1647<br>1655<br>1663 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3460<br>3510<br>3520<br>3530<br>3540<br>3550<br>3560<br>3570<br>3600<br>3610 | 1792<br>1800<br>1808<br>1816<br>1824<br>1840<br>1848<br>1856<br>1864<br>1872<br>1880<br>1888<br>1896<br>1904<br>1912 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873<br>1881<br>1889<br>1897<br>1905<br>1913 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1898<br>1906<br>1914 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1875<br>1883<br>1891<br>1907<br>1915 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1884<br>1892<br>1900<br>1908<br>1916 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853<br>1861<br>1869<br>1877<br>1885<br>1893<br>1901<br>1909<br>1917 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1870<br>1878<br>1886<br>1894<br>1902<br>1910<br>1918 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1871<br>1879<br>1887<br>1987<br>1995<br>1911<br>1919 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3110<br>3120<br>3130<br>3140<br>3150<br>3170<br>3200<br>3210<br>3220<br>3230 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616<br>1624<br>1632<br>1640<br>1648<br>1656 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1633<br>1641<br>1649<br>1657 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1610<br>1618<br>1626<br>1634<br>1642<br>1650<br>1658 | 1539<br>1547<br>1553<br>1571<br>1579<br>1587<br>1595<br>1603<br>1611<br>1619<br>1643<br>1651<br>1659<br>1667<br>1673<br>1683<br>1691 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612<br>1620<br>1628<br>1636<br>1644<br>1652<br>1660 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1621<br>1629<br>1637<br>1645<br>1653<br>1661 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1598<br>1606<br>1614<br>1622<br>1630<br>1638<br>1646<br>1654<br>1662 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1599<br>1607<br>1615<br>1623<br>1631<br>1639<br>1647<br>1655<br>1663 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3460<br>3510<br>3510<br>3520<br>3530<br>3540<br>3550<br>3560<br>3570<br>3610<br>3620<br>3630 | 1792<br>1800<br>1808<br>1816<br>1824<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872<br>1880<br>1888<br>1896<br>1904<br>1912 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873<br>1881<br>1889<br>1897<br>1905<br>1913 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1898<br>1906<br>1914<br>1922<br>1930<br>1930<br>1946 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1875<br>1883<br>1891<br>1997<br>1915 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1900<br>1908<br>1916 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853<br>1861<br>1869<br>1877<br>1885<br>1893<br>1901<br>1917<br>1925<br>1933<br>1941<br>1949 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1870<br>1878<br>1986<br>1991<br>1918<br>1926<br>1934<br>1942<br>1950 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1863<br>1871<br>1879<br>1887<br>1993<br>1911<br>1919 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3110<br>3120<br>3130<br>3140<br>3150<br>3160<br>3170<br>3220<br>3230<br>3230<br>3250 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616<br>1624<br>1632<br>1640<br>1648<br>1656 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1625<br>1633<br>1641<br>1649<br>1657<br>1665<br>1673<br>1681<br>1689<br>1697<br>1705 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1618<br>1624<br>1650<br>1658<br>1666<br>1674<br>1682<br>1698<br>1698<br>1706 | 1539<br>1547<br>1553<br>1563<br>1571<br>1579<br>1587<br>1695<br>1603<br>1611<br>1619<br>1625<br>1643<br>1651<br>1659<br>1667<br>1675<br>1683<br>1691<br>1699<br>1707 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612<br>1620<br>1628<br>1636<br>1644<br>1652<br>1660<br>1668<br>1676<br>1684<br>1696<br>1700 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1621<br>1621<br>1637<br>1645<br>1653<br>1661<br>1669<br>1677<br>1685<br>1693<br>1709 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1698<br>1606<br>1614<br>1622<br>1630<br>1638<br>1646<br>1654<br>1662<br>1670<br>1678<br>1686<br>1696<br>1700<br>1710 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1599<br>1607<br>1615<br>1623<br>1631<br>1639<br>1647<br>1655<br>1663 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3460<br>3510<br>3510<br>3520<br>3530<br>3540<br>3550<br>3610<br>3620<br>3630<br>3640<br>3650 | 1792<br>1800<br>1808<br>1816<br>1816<br>1824<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872<br>1880<br>1904<br>1912<br>1920<br>1928<br>1936<br>1944<br>1952<br>1960 | 1793<br>1801<br>1809<br>1807<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873<br>1881<br>1989<br>1995<br>1913<br>1921<br>1929<br>1937<br>1945<br>1953<br>1961 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1890<br>1898<br>1906<br>1914<br>1922<br>1930<br>1938<br>1946<br>1954<br>1954 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1875<br>1883<br>1891<br>1997<br>1915 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1892<br>1900<br>1908<br>1916 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853<br>1861<br>1869<br>1877<br>1885<br>1991<br>1909<br>1917<br>1925<br>1933<br>1941<br>1949<br>1957<br>1965 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1870<br>1878<br>1992<br>1910<br>1918<br>1926<br>1934<br>1942<br>1958<br>1958 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1863<br>1871<br>1879<br>1887<br>1993<br>1911<br>1919 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3110<br>3120<br>3130<br>3140<br>3150<br>3170<br>3220<br>3230<br>3240<br>3250<br>3260 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616<br>1624<br>1632<br>1640<br>1648<br>1656<br>1664<br>1672<br>1688<br>1696<br>1704<br>1712 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1625<br>1633<br>1641<br>1649<br>1657<br>1665<br>1673<br>1689<br>1697<br>1705 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1610<br>1618<br>1626<br>1634<br>1642<br>1658<br>1666<br>1674<br>1682<br>1690<br>1698<br>1706 | 1539<br>1547<br>1555<br>1563<br>1571<br>1579<br>1587<br>1603<br>1611<br>1619<br>1625<br>1643<br>1651<br>1659 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612<br>1620<br>1628<br>1636<br>1644<br>1652<br>1660<br>1668<br>1676<br>1684<br>1692<br>1700<br>1708 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1621<br>1629<br>1637<br>1645<br>1663<br>1661<br>1669<br>1677<br>1685<br>1693<br>1709 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1598<br>1606<br>1614<br>1622<br>1630<br>1638<br>1646<br>1652<br>1670<br>1678<br>1686<br>1694<br>1702<br>1718 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1599<br>1607<br>1615<br>1623<br>1631<br>1639<br>1647<br>1655<br>1663<br>1671<br>1679<br>1687<br>1695<br>1703<br>1711 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3500<br>3510<br>3520<br>3530<br>3540<br>3550<br>3600<br>3610<br>3620<br>3630<br>3630<br>3630<br>3660 | 1792<br>1800<br>1808<br>1806<br>1816<br>1816<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872<br>1880<br>1904<br>1912<br>1920<br>1928<br>1936<br>1944<br>1952<br>1946<br>1958 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873<br>1881<br>1989<br>1995<br>1913<br>1921<br>1929<br>1937<br>1945<br>1959 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1892<br>1990<br>1914<br>1922<br>1930<br>1938<br>1946<br>1954<br>1952 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1875<br>1883<br>1891<br>1907<br>1915<br>1923<br>1931<br>1939<br>1947<br>1955<br>1963<br>1971 | 1796<br>1804<br>1812<br>1820<br>1820<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1892<br>1900<br>1908<br>1916<br>1924<br>1932<br>1940<br>1948<br>1956<br>1964<br>1972 | 1797<br>1805<br>1813<br>1821<br>1821<br>1829<br>1837<br>1845<br>1853<br>1861<br>1869<br>1877<br>1885<br>1991<br>1909<br>1917<br>1925<br>1933<br>1941<br>1949<br>1957 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1870<br>1878<br>1992<br>1910<br>1918<br>1926<br>1950<br>1950<br>1950<br>1950 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1871<br>1879<br>1887<br>1993<br>1911<br>1919<br>1927<br>1935<br>1943<br>1951<br>1959<br>1967<br>1975 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3110<br>3120<br>3130<br>3140<br>3150<br>3210<br>3220<br>3230<br>3240<br>3250<br>3270 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>16164<br>1632<br>1640<br>1648<br>1656<br>1664<br>1672<br>1688<br>1696<br>1704<br>1712 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1625<br>1633<br>1641<br>1649<br>1657<br>1665<br>1673<br>1689<br>1697<br>1705<br>1713<br>1721 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1610<br>1618<br>1642<br>1650<br>1658<br>1666<br>1674<br>1682<br>1690<br>1698<br>1706<br>1714<br>1722 | 1539<br>1547<br>1555<br>1563<br>1571<br>1579<br>1587<br>1603<br>1611<br>1619<br>1635<br>1643<br>1651<br>1659<br>1667<br>1675<br>1683<br>1691<br>1699<br>1707<br>1715<br>1723 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612<br>1620<br>1628<br>1636<br>1644<br>1652<br>1660<br>1668<br>1676<br>1688<br>1676<br>1692<br>1700<br>1708<br>1716<br>1724 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1621<br>1621<br>1645<br>1653<br>1661<br>1669<br>1677<br>1685<br>1693<br>1701<br>1709<br>1717 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1698<br>1606<br>1614<br>1622<br>1630<br>1638<br>1646<br>1654<br>1662<br>1670<br>1678<br>1686<br>1694<br>1702<br>1710<br>1718<br>1726 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1699<br>1607<br>1615<br>1623<br>1631<br>1639<br>1647<br>1655<br>1663<br>1671<br>1679<br>1687<br>1703<br>1711<br>1719<br>1727 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3500<br>3510<br>3530<br>3530<br>3540<br>3550<br>3570<br>3600<br>3610<br>3620<br>3630<br>3640<br>3650<br>3660<br>3670 | 1792<br>1800<br>1808<br>1816<br>1824<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872<br>1994<br>1912<br>1920<br>1928<br>1936<br>1944<br>1952<br>1960<br>1968 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873<br>1899<br>1905<br>1913<br>1921<br>1929<br>1939<br>1945<br>1953<br>1961<br>1969<br>1977 | 1794<br>1802<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1996<br>1914<br>1922<br>1930<br>1946<br>1954<br>1954<br>1956<br>1970<br>1978 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1875<br>1883<br>1891<br>1899<br>1907<br>1915<br>1923<br>1931<br>1939<br>1947<br>1955<br>1963<br>1971 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1990<br>1908<br>1916<br>1944<br>1948<br>1956<br>1964<br>1972<br>1980 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853<br>1861<br>1869<br>1877<br>1893<br>1901<br>1917<br>1925<br>1933<br>1941<br>1957<br>1965<br>1973<br>1981 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1870<br>1910<br>1918<br>1926<br>1934<br>1942<br>1958<br>1958<br>1958<br>1958<br>1958 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1863<br>1871<br>1879<br>1887<br>1993<br>1911<br>1919<br>1927<br>1935<br>1943<br>1951<br>1959<br>1967<br>1975<br>1983 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3110<br>3120<br>3130<br>3140<br>3150<br>3160<br>3210<br>3220<br>3230<br>3240<br>3250<br>3250<br>3260<br>3270 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616<br>1624<br>1632<br>1640<br>1648<br>1656<br>1664<br>1672<br>1680<br>1680<br>1696<br>1704<br>1712<br>1720 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1625<br>1633<br>1641<br>1649<br>1657<br>1665<br>1673<br>1681<br>1689<br>1705<br>1713<br>1721 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1618<br>1624<br>1650<br>1658<br>1666<br>1674<br>1682<br>1690<br>1698<br>1706<br>1714<br>1722 | 1539<br>1547<br>1553<br>1563<br>1571<br>1579<br>1587<br>1695<br>1603<br>1611<br>1619<br>1627<br>1635<br>1643<br>1651<br>1659<br>1667<br>1675<br>1683<br>1699<br>1707<br>1715<br>1723 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612<br>1620<br>1628<br>1636<br>1644<br>1652<br>1660<br>1668<br>1676<br>1684<br>1700<br>1708<br>1716<br>1724 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1621<br>1621<br>1621<br>1637<br>1645<br>1653<br>1661<br>1669<br>1677<br>1685<br>1693<br>1701<br>1709<br>1717<br>1725 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1598<br>1606<br>1614<br>1622<br>1630<br>1638<br>1646<br>1662<br>1670<br>1678<br>1686<br>1694<br>1702<br>1710<br>1718<br>1726 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1599<br>1607<br>1615<br>1623<br>1631<br>1639<br>1647<br>1655<br>1663<br>1671<br>1679<br>1687<br>1695<br>1703<br>1711<br>1719<br>1727 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3460<br>3510<br>3520<br>3530<br>3530<br>3530<br>3630<br>3610<br>3620<br>3630<br>3630<br>3630<br>3630<br>3630<br>3630<br>363 | 1792<br>1800<br>1808<br>1816<br>1816<br>1824<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872<br>1880<br>1904<br>1912<br>1920<br>1928<br>1936<br>1952<br>1952<br>1952<br>1958<br>1976 | 1793<br>1801<br>1809<br>1807<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873<br>1881<br>1989<br>1995<br>1913<br>1921<br>1929<br>1937<br>1945<br>1953<br>1969<br>1977 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1892<br>1990<br>1914<br>1922<br>1930<br>1946<br>1954<br>1954<br>1958<br>1978 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1875<br>1883<br>1891<br>1907<br>1915<br>1923<br>1931<br>1939<br>1947<br>1955<br>1971<br>1979 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1892<br>1900<br>1908<br>1916<br>1924<br>1932<br>1940<br>1948<br>1956<br>1956<br>1956<br>1958 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853<br>1861<br>1869<br>1877<br>1885<br>1991<br>1909<br>1917<br>1925<br>1933<br>1941<br>1949<br>1957<br>1965<br>1973<br>1981 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1870<br>1878<br>1990<br>1918<br>1926<br>1934<br>1942<br>1958<br>1958<br>1958<br>1958 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1863<br>1871<br>1879<br>1887<br>1991<br>1919<br>1927<br>1935<br>1943<br>1951<br>1951<br>1951<br>1953<br>1967<br>1975<br>1983 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3110<br>3120<br>3131<br>3140<br>3150<br>3210<br>3220<br>3230<br>3240<br>3250<br>3260<br>3270<br>3300<br>3310<br>3310<br>3320<br>3330 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616<br>1624<br>1632<br>1640<br>1648<br>1656<br>1664<br>1704<br>1712<br>1720<br>1728<br>1736<br>1744<br>1752 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1633<br>1641<br>1649<br>1657<br>1665<br>1673<br>1689<br>1705<br>1713<br>1721<br>1729<br>1737<br>1745<br>1753 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1610<br>1618<br>162<br>1634<br>1642<br>1650<br>1658<br>1666<br>1674<br>1688<br>1706<br>1714<br>1722<br>1730<br>1738<br>1746<br>1754 | 1539<br>1547<br>15563<br>1571<br>1579<br>1587<br>1695<br>1603<br>1611<br>1619<br>1667<br>1635<br>1643<br>1651<br>1659<br>1667<br>1675<br>1707<br>1715<br>1723<br>1731<br>1731<br>1731<br>1731<br>1735 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612<br>1620<br>1628<br>1636<br>1644<br>1652<br>1660<br>1708<br>1716<br>1724<br>1732<br>1740<br>1748<br>17724 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1621<br>1629<br>1637<br>1645<br>1653<br>1661<br>1669<br>1701<br>1709<br>1717<br>1725<br>1733<br>1741<br>1749<br>1757 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1698<br>1606<br>1614<br>1622<br>1630<br>1638<br>1646<br>1654<br>1662<br>1670<br>1678<br>1686<br>1694<br>1702<br>1710<br>1718<br>1726<br>1734<br>1742<br>1758 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1699<br>1607<br>1615<br>1623<br>1631<br>1639<br>1647<br>1655<br>1663<br>1671<br>1679<br>1687<br>1711<br>1719<br>1727 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3500<br>3510<br>3520<br>3530<br>3540<br>3550<br>3570<br>3600<br>3610<br>3620<br>3630<br>3640<br>3650<br>3670<br>3700<br>3710<br>3720<br>3720<br>3720<br>3720 | 1792<br>1800<br>1808<br>1816<br>1816<br>1824<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872<br>1920<br>1928<br>1920<br>1928<br>1936<br>1944<br>1952<br>1960<br>1960<br>1976 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1863<br>1891<br>1905<br>1913<br>1921<br>1929<br>1929<br>1945<br>1953<br>1961<br>1961<br>1967<br>1977 | 1794<br>1802<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1898<br>1906<br>1914<br>1922<br>1930<br>1930<br>1954<br>1962<br>1978<br>1978 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1873<br>1891<br>1997<br>1915<br>1923<br>1931<br>1931<br>1935<br>1947<br>1955<br>1963<br>1971<br>1979 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1990<br>1908<br>1916<br>1924<br>1932<br>1948<br>1956<br>1964<br>1972<br>1980 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853<br>1861<br>1869<br>1977<br>1995<br>1917<br>1925<br>1933<br>1991<br>1949<br>1957<br>1965<br>1973<br>1981 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1870<br>1910<br>1918<br>1926<br>1934<br>1942<br>1950<br>1958<br>1966<br>1974<br>1982 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1863<br>1871<br>1879<br>1887<br>1993<br>1911<br>1919<br>1927<br>1935<br>1943<br>1951<br>1959<br>1967<br>1975<br>1983<br>1991<br>1999<br>1997<br>2007 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3110<br>3120<br>3130<br>3140<br>3150<br>3220<br>3220<br>3220<br>3240<br>3250<br>3260<br>3270<br>3310<br>3310<br>3310<br>3350<br>3350 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616<br>1622<br>1640<br>1648<br>1656<br>1664<br>1672<br>1680<br>1680<br>1704<br>1712<br>1720<br>1728<br>1736<br>1744<br>1752<br>1760<br>1768 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1623<br>1641<br>1649<br>1657<br>1665<br>1673<br>1681<br>1681<br>1705<br>1713<br>1721<br>1729<br>1737<br>1745<br>1753<br>1761<br>1769 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1610<br>1618<br>1624<br>1650<br>1658<br>1666<br>1674<br>1682<br>1698<br>1706<br>1714<br>1722<br>1730<br>1738<br>1746<br>1754<br>1762<br>1770 | 1539<br>1547<br>1557<br>1563<br>1571<br>1579<br>1587<br>1603<br>1611<br>1619<br>1667<br>1635<br>1643<br>1651<br>1659<br>1667<br>1675<br>1683<br>1691<br>1707<br>1715<br>1723<br>1731<br>1739<br>1747<br>1753<br>1763<br>1771 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612<br>1620<br>1628<br>1636<br>1644<br>1652<br>1660<br>1668<br>1676<br>1684<br>1692<br>1700<br>1708<br>1716<br>1724<br>1732<br>1740<br>1748<br>1756<br>1764<br>1772 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1621<br>1621<br>1637<br>1645<br>1653<br>1661<br>1669<br>1677<br>1685<br>1691<br>1709<br>1717<br>1725 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1590<br>1598<br>1606<br>1614<br>1622<br>1638<br>1646<br>1638<br>1646<br>1654<br>1670<br>1718<br>1726<br>1710<br>1718<br>1726<br>1734<br>1742<br>1750<br>1758<br>1768<br>1768<br>1774 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1607<br>1615<br>1623<br>1631<br>1639<br>1647<br>1655<br>1663<br>1671<br>1679<br>1687<br>1695<br>1703<br>1711<br>1719<br>1727 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3510<br>3520<br>3530<br>3530<br>3550<br>3550<br>3570<br>3600<br>3610<br>3620<br>3630<br>3640<br>3650<br>3670<br>3710<br>3710<br>3710<br>3710 | 1792<br>1800<br>1808<br>1816<br>1824<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872<br>1920<br>1928<br>1936<br>1936<br>1944<br>1952<br>1960<br>1968<br>1976 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873<br>1995<br>1913<br>1921<br>1929<br>1937<br>1945<br>1953<br>1961<br>1977<br>1985<br>1993<br>2001<br>2009<br>2017 | 1794<br>1802<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1996<br>1914<br>1922<br>1930<br>1938<br>1946<br>1954<br>1962<br>1978<br>1986<br>1994<br>2002<br>2010<br>2018 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1875<br>1883<br>1891<br>1997<br>1915<br>1923<br>1931<br>1931<br>1935<br>1947<br>1955<br>1963<br>1971<br>1979 | 1796<br>1804<br>1812<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1990<br>1908<br>1916<br>1948<br>1956<br>1948<br>1956<br>1948<br>1958<br>1990<br>1988<br>1990<br>1988<br>1990<br>1988<br>1990<br>1988<br>1990<br>1988<br>1990<br>1988<br>1990<br>1988<br>1990<br>1988<br>1990<br>1988<br>1990<br>1990 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853<br>1861<br>1869<br>1877<br>1999<br>1917<br>1925<br>1933<br>1941<br>1949<br>1957<br>1965<br>1973<br>2005<br>2013<br>2021 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1870<br>1910<br>1918<br>1926<br>1934<br>1942<br>1958<br>1958<br>1966<br>1974<br>1982<br>2006<br>1998 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1863<br>1871<br>1879<br>1887<br>1993<br>1911<br>1919<br>1927<br>1935<br>1943<br>1951<br>1959<br>1967<br>1975<br>1983<br>1991<br>1999<br>2007<br>2007<br>2015<br>2015<br>2015 | 10<br>3777 | to<br>2047 | | 3010<br>3020<br>3030<br>3040<br>3050<br>3060<br>3110<br>3120<br>3131<br>3140<br>3150<br>3210<br>3220<br>3230<br>3240<br>3250<br>3260<br>3270<br>3300<br>3310<br>3310<br>3320<br>3330 | 1536<br>1544<br>1552<br>1560<br>1568<br>1576<br>1584<br>1592<br>1600<br>1608<br>1616<br>1612<br>1632<br>1640<br>1648<br>1656<br>1648<br>1656<br>1704<br>1712<br>1720<br>1728<br>1736<br>1744<br>1752<br>1768<br>1768<br>1776 | 1537<br>1545<br>1553<br>1561<br>1569<br>1577<br>1585<br>1593<br>1601<br>1609<br>1617<br>1625<br>1633<br>1641<br>1649<br>1657<br>1705<br>1713<br>1721<br>1729<br>1737<br>1745<br>1753<br>1761<br>1777 | 1538<br>1546<br>1554<br>1562<br>1570<br>1578<br>1586<br>1594<br>1602<br>1618<br>1626<br>1634<br>1642<br>1650<br>1658<br>1714<br>1722<br>1730<br>1738<br>1746<br>1754<br>1754<br>1778 | 1539<br>1547<br>1555<br>1563<br>1571<br>1579<br>1587<br>1595<br>1603<br>1611<br>1612<br>1627<br>1635<br>1643<br>1651<br>1667<br>1675<br>1683<br>1691<br>1707<br>1715<br>1723<br>1731<br>1739<br>1747<br>1755<br>1763<br>1771 | 1540<br>1548<br>1556<br>1564<br>1572<br>1580<br>1588<br>1596<br>1604<br>1612<br>1628<br>1636<br>1644<br>1652<br>1668<br>1670<br>1700<br>1708<br>1716<br>1724<br>1732<br>1740<br>1748<br>1756<br>1764<br>1774 | 1541<br>1549<br>1557<br>1565<br>1573<br>1581<br>1589<br>1597<br>1605<br>1613<br>1629<br>1637<br>1645<br>1663<br>1701<br>1709<br>1717<br>1725<br>1733<br>1741<br>1749<br>1757<br>1773<br>1781 | 1542<br>1550<br>1558<br>1566<br>1574<br>1582<br>1598<br>1606<br>1614<br>1622<br>1630<br>1638<br>1646<br>1654<br>1678<br>1686<br>1694<br>1702<br>1718<br>1726<br>1734<br>1742<br>1750<br>1758<br>1766<br>1774<br>1782 | 1543<br>1551<br>1559<br>1567<br>1575<br>1583<br>1591<br>1697<br>1615<br>1623<br>1631<br>1639<br>1647<br>1655<br>1663<br>1703<br>1711<br>1719<br>1727<br>1735<br>1743<br>1751<br>1759<br>1767<br>1775 | | 3410<br>3420<br>3430<br>3440<br>3450<br>3510<br>3510<br>3520<br>3530<br>3530<br>3530<br>3610<br>3620<br>3630<br>3660<br>3670<br>3770<br>3770<br>3770<br>3770<br>377 | 1792<br>1800<br>1808<br>1808<br>1816<br>1816<br>1824<br>1832<br>1840<br>1848<br>1856<br>1864<br>1872<br>1980<br>1994<br>1912<br>1920<br>1928<br>1936<br>1952<br>1952<br>1952<br>1952<br>1958<br>1976 | 1793<br>1801<br>1809<br>1817<br>1825<br>1833<br>1841<br>1849<br>1857<br>1865<br>1873<br>1881<br>1989<br>1995<br>1913<br>1921<br>1929<br>1937<br>1945<br>1953<br>1961<br>1969<br>1977 | 1794<br>1802<br>1810<br>1818<br>1826<br>1834<br>1842<br>1850<br>1858<br>1866<br>1874<br>1892<br>1930<br>1944<br>1922<br>1930<br>1945<br>1954<br>1954<br>1954<br>1962<br>1978 | 1795<br>1803<br>1811<br>1819<br>1827<br>1835<br>1843<br>1851<br>1859<br>1867<br>1873<br>1891<br>1997<br>1915<br>1923<br>1931<br>1931<br>1935<br>1947<br>1955<br>1963<br>1971<br>1979 | 1796<br>1804<br>1812<br>1820<br>1820<br>1828<br>1836<br>1844<br>1852<br>1860<br>1868<br>1876<br>1892<br>1990<br>1998<br>1916<br>1940<br>1948<br>1956<br>1956<br>1956<br>1956<br>1950<br>1988<br>1996<br>2004<br>2012<br>2020<br>2028<br>2028<br>2028<br>2028<br>2028 | 1797<br>1805<br>1813<br>1821<br>1829<br>1837<br>1845<br>1853<br>1861<br>1869<br>1909<br>1917<br>1925<br>1931<br>1949<br>1957<br>1965<br>1973<br>1981 | 1798<br>1806<br>1814<br>1822<br>1830<br>1838<br>1846<br>1854<br>1862<br>1870<br>1910<br>1918<br>1926<br>1934<br>1942<br>1950<br>1958<br>1966<br>1974<br>1982<br>2006<br>2014<br>2022<br>2038 | 1799<br>1807<br>1815<br>1823<br>1831<br>1839<br>1847<br>1855<br>1863<br>1871<br>1879<br>1887<br>1995<br>1993<br>1911<br>1919<br>1927<br>1935<br>1943<br>1951<br>1959<br>1967<br>1975<br>1975<br>1975<br>1975<br>1975<br>1983 | 10<br>3777 | to<br>2047 | # OCTAL-DECIMAL INTEGER CONVERSION TABLE (continued) 4000 2048 to to 4777 2559 (Octal) (Decimal) | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |-------|------|------|------|--------------|--------------|--------------|--------------|------| | 4000 | 2048 | 2049 | 2050 | 2051 | 2052 | 2053 | 2054 | 2055 | | 4010 | 2056 | 2057 | 2058 | 2059 | 2060 | 2061 | 2062 | 2063 | | 4020 | 2064 | 2065 | 2066 | 2067 | 2068 | 2069 | 2070 | 2071 | | 4030 | 2072 | 2073 | 2074 | 2075 | 2076 | 2077 | 2078 | | | 4040 | 2080 | 2081 | 2082 | 2083 | 2084 | 2085 | 2086 | 2087 | | 4050 | 2088 | 2089 | 2090 | 2091 | 2092 | 2093 | 2094 | 2095 | | 4060 | 2096 | 2097 | 2098 | 2099 | 2100 | 2101 | 2102 | 2103 | | 4070 | 2104 | 2105 | 2106 | 2107 | 2108 | 2109 | 2110 | 2111 | | 4100 | 2112 | 2113 | 2114 | 0115 | 0110 | | | | | 4110 | 2112 | 2113 | 2114 | 2115 | 2116 | 2117 | 2118 | 2119 | | 4120 | 2120 | 2121 | 2130 | 2123<br>2131 | 2124 | 2125 | 2126 | 2127 | | 4130 | 2136 | 2129 | 2130 | | 2132 | 2133 | 2134 | 2135 | | 4140 | 2144 | 2145 | 2146 | 2139<br>2147 | 2140<br>2148 | 2141 | 2142 | 2143 | | 4150 | 2152 | 2153 | 2154 | 2155 | 2156 | 2149 | 2150 | 2151 | | 4160 | 2160 | 2161 | 2162 | 2163 | 2164 | 2157<br>2165 | 2158<br>2166 | 2159 | | 4170 | 2168 | 2169 | 2170 | 2171 | 2172 | 2173 | 2174 | 2167 | | | 2100 | 2103 | 2110 | 2111 | 2112 | 2113 | 21/4 | 2175 | | 4200 | 2176 | 2177 | 2178 | 2179 | 2180 | 2181 | 2182 | 2183 | | 4210 | 2184 | 2185 | 2186 | 2187 | 2188 | 2189 | 2190 | 2191 | | 4220 | 2192 | 2193 | 2194 | 2195 | 2196 | 2197 | 2198 | 2199 | | 4230 | 2200 | 2201 | 2202 | 2203 | 2204 | 2205 | 2206 | 2207 | | 4240 | 2208 | 2209 | 2210 | 2211 | 2212 | 2213 | 2214 | 2215 | | 4250 | 2216 | 2217 | 2218 | 2219 | 2220 | 2221 | 2222 | 2223 | | 4260 | 2224 | 2225 | 2226 | 2227 | 2228 | 2229 | 2230 | 2231 | | .4270 | 2232 | 2233 | 2234 | 2235 | 2236 | 2237 | 2238 | 2239 | | 4300 | 2240 | 2241 | 2242 | 2243 | 2244 | 2245 | 2246 | 2247 | | 4310 | 2248 | | 2250 | 2251 | 2252 | 2253 | 2254 | 2255 | | 4320 | 2256 | | 2258 | 2259 | 2260 | 2261 | 2262 | 2263 | | | 2264 | | 2266 | 2267 | 2268 | 2269 | 2270 | 2271 | | | 2272 | | | 2275 | 2276 | 2277 | 2278 | 2279 | | | 2280 | | 2282 | 2283 | | 2285. | 2286 | 2287 | | | 2288 | | | 2291 | 2292 | 2293 | 2294 | 2295 | | 4370 | 2296 | | | 2299 | | 2301 | 2302 | 2303 | | | | | | | | | | 2000 | | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |-----|--------|------|------|------|--------------|------|------|------|------| | | 4400 | 2304 | 2305 | 2306 | 2307 | 2308 | 2309 | 2310 | 2311 | | | 4410 | 2312 | 2313 | 2314 | 2315 | 2316 | 2317 | 2318 | 2319 | | | 4420 | 2320 | 2321 | 2322 | 2323 | 2324 | 2325 | 2326 | 2327 | | | 4430 | | | 2330 | 2331 | 2332 | 2333 | 2334 | 2335 | | | 4440 | | | 2338 | | 2340 | 2341 | 2342 | 2343 | | 1 | 4450 | | | 2346 | | | 2349 | 2350 | 2351 | | 1 | 4460 | | | 2354 | 2355 | | 2357 | 2358 | 2359 | | 1 | 4470 | 2360 | 2361 | 2362 | 2363 | 2364 | 2365 | 2366 | 2367 | | - | 4500 | 2368 | 2369 | 2370 | 2371 | 2372 | 2373 | 2374 | 2375 | | 1 | 4510 | 2376 | 2377 | 2378 | 2379 | 2380 | 2381 | 2382 | 2383 | | ı | 4520 | 2384 | 2385 | 2386 | 2387 | 2388 | 2389 | 2390 | 2391 | | 1 | 4530 | 2392 | 2393 | 2394 | 2395 | 2396 | 2397 | 2398 | 2399 | | | 4540 | 2400 | 2401 | 2402 | 2403 | 2404 | 2405 | 2406 | 2407 | | - 1 | 4550 | 2408 | 2409 | 2410 | 2411 | 2412 | 2413 | 2414 | 2415 | | - 1 | 4560 | 2416 | 2417 | 2418 | 2419 | 2420 | 2421 | 2422 | 2423 | | Ì | 4570 | 2424 | 2425 | 2426 | 2427 | 2428 | 2429 | 2430 | 2431 | | 1 | 4600 | 2432 | 2433 | 2434 | 2435 | 2436 | 2437 | 2438 | 2439 | | ŀ | 4610 | 2440 | 2441 | 2442 | 2443 | 2444 | 2445 | 2446 | 2447 | | ŀ | 4620 | 2448 | 2449 | 2450 | 2451 | 2452 | 2453 | 2454 | 2455 | | ŀ | 4630 | 2456 | 2457 | 2458 | 2459 | 2460 | 2461 | 2462 | 2463 | | 1 | 4640 | 2464 | 2465 | 2466 | 2467 | 2468 | 2469 | 2470 | 2471 | | | 4650 | 2472 | 2473 | 2474 | 2475 | 2476 | 2477 | 2478 | 2479 | | | 1660 | 2480 | 2481 | 2482 | 2483 | 2484 | 2485 | 2486 | 2487 | | ľ | 1670 | 2488 | 2489 | 2490 | 2491 | 2492 | 2493 | 2494 | 2495 | | 1 | 1700 | 2496 | 2497 | 2498 | 2499 | 2500 | 2501 | 2502 | 2503 | | 14 | 1710 | 2504 | 2505 | 2506 | 2507 | | 2509 | 2510 | 2511 | | 1 | 720 | 2512 | 2513 | 2514 | 2515 | | 2517 | | 2519 | | | 1730 j | 2520 | 2521 | 2522 | 2523 | | 2525 | | 2527 | | | 1740 | 2528 | 2529 | 2530 | 2531 | | 2533 | | 2535 | | | 750 | 2536 | | | 2539 | | 2541 | | 2543 | | | 760 | 2544 | 2545 | 2546 | 2547 | | 2549 | _ | 2551 | | ٤ | 770 | 2552 | 2553 | 2554 | <b>25</b> 55 | | 2557 | | 2559 | 5000 | 2560 to to 5777 | 3071 (Octol) (Decimal) | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |------|------|----------------------|------|------|------|------|------|------| | 5000 | 2560 | 2561 | 2562 | 2563 | 2564 | 2565 | 2566 | 2567 | | 5010 | 2568 | 2569 | 2570 | 2571 | 2572 | 2573 | | 2575 | | 5020 | 2576 | 2577 | 2578 | 2579 | 2580 | 2581 | 2582 | 2583 | | 5030 | 2584 | 2585 | 2586 | 2587 | 2588 | 2589 | 2590 | 2591 | | 5040 | 2592 | 2593 | 2594 | 2595 | 2596 | 2597 | 2598 | 2599 | | 5050 | 2600 | 2601 | 2602 | 2603 | 2604 | 2605 | 2606 | 2607 | | 5060 | 2608 | 2609 | 2610 | 2611 | 2612 | 2613 | 2614 | 2615 | | 5070 | 2616 | 2617 | 2618 | 2619 | 2620 | 2621 | 2622 | 2623 | | 5100 | 2624 | 2625 | 2626 | 2627 | 2628 | 2629 | 2630 | 2631 | | 5110 | 2632 | 2633 | 2634 | 2635 | 2636 | 2637 | 2638 | 2639 | | 5120 | 2640 | 2641 | 2642 | 2643 | 2644 | 2645 | 2646 | 2647 | | 5130 | 2648 | 2649 | 2650 | 2651 | 2652 | 2653 | 2654 | 2655 | | 5140 | 2656 | 2657 | 2658 | 2659 | 2660 | 2661 | 2662 | 2663 | | 5150 | 2664 | 2665 | 2666 | 2667 | 2668 | 2669 | 2670 | 2671 | | 5160 | 2672 | 2673 | 2674 | 2675 | 2676 | 2677 | 2678 | 2679 | | 5170 | 2680 | 2681 | 2682 | 2683 | 2684 | 2685 | 2686 | 2687 | | 5200 | 2688 | 2689 | 2690 | 2691 | 2692 | 2693 | 2694 | 2695 | | 5210 | 2696 | 2697 | 2698 | 2699 | 2700 | 2701 | 2702 | 2703 | | 5220 | 2704 | 2705 | 2706 | 2707 | 2708 | 2709 | 2710 | 2711 | | 5230 | 2712 | 2713 | 2714 | 2715 | 2716 | 2717 | 2718 | 2719 | | 5240 | 2720 | 2721 | 2722 | 2723 | 2724 | 2725 | 2726 | 2727 | | 5250 | 2728 | 2729 | 2730 | 2731 | 2732 | 2733 | 2734 | 2735 | | 5260 | 2736 | 2737 | 2738 | 2739 | 2740 | 2741 | 2742 | 2743 | | 5270 | 2744 | 2745 | 2746 | 2747 | 2748 | 2749 | 2750 | 2751 | | 5300 | 2752 | <b>2</b> 75 <b>3</b> | 2754 | 2755 | 2756 | 2757 | 2758 | 2759 | | | 2760 | 2761 | 2762 | 2763 | 2764 | 2765 | 2766 | 2767 | | 5320 | 2768 | 2769 | 2770 | 2771 | 2772 | 2773 | 2774 | 2775 | | 5330 | 2776 | 2777 | 2778 | 2779 | 2780 | 2781 | 2782 | 2783 | | 5340 | 2784 | 2785 | 2786 | 2787 | 2788 | 2789 | 2790 | 2791 | | 5350 | 2792 | 2793 | 2794 | 2795 | 2796 | 2797 | 2798 | 2799 | | | 2800 | 2801 | 2802 | 2803 | 2804 | 2805 | 2806 | 2807 | | 5370 | 2808 | 2809 | 2810 | 2811 | 2812 | 2813 | 2814 | 2815 | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |---------------|------|------|-------|------|------|------|------|------| | 5400 | 2816 | 2817 | 2818 | 2819 | 2820 | 2821 | 2822 | 2823 | | 5410 | 2824 | 2825 | 2826 | 2827 | 2828 | | | | | 5420 | 2832 | 2833 | 2834 | 2835 | 2836 | 2837 | | | | 5430 | 2840 | 2841 | 2842 | 2843 | 2844 | 2845 | | | | 5440 | 2848 | | 2850 | 2851 | 2852 | 2853 | | | | 5450 | 2856 | 2857 | 2858 | 2859 | 2860 | 2861 | | | | 5460 | 2864 | 2865 | 2866 | 2867 | 2868 | 2869 | | | | 5470 | 2872 | 2873 | 2874 | 2875 | 2876 | 2877 | | | | 5500 | 2880 | 2881 | 2882 | 2883 | 2884 | 2885 | 2886 | 2887 | | 5510 | 2888 | 2889 | 2890 | 2891 | 2892 | 2893 | 2894 | 2895 | | 5520 | 2896 | 2897 | 2898 | 2899 | 2900 | 2901 | 2902 | 2903 | | 55 <b>3</b> 0 | 2904 | 2905 | -2906 | 2907 | 2908 | 2909 | 2910 | 2911 | | 5540 | 2912 | 2913 | 2914 | 2915 | 2916 | 2917 | 2918 | 2919 | | 5550 | 2920 | 2921 | 2922 | 2923 | 2924 | 2925 | 2926 | 2927 | | 5560 | 2928 | 2929 | 2930 | 2931 | 2932 | 2933 | 2934 | 2935 | | 5570 | 2936 | 2937 | 2938 | 2939 | 2940 | 2941 | 2942 | 2943 | | 5600 | 2944 | 2945 | 2946 | 2947 | 2948 | 2949 | 2950 | 2951 | | 5610 | 2952 | 2953 | 2954 | 2955 | 2956 | 2957 | 2958 | 2959 | | 5620 | 2960 | 2961 | 2962 | 2963 | 2964 | 2965 | 2966 | 2967 | | 5630 | 2968 | 2969 | 2970 | 2971 | 2972 | 2973 | 2974 | 2975 | | 5640 | 2976 | 2977 | 2978 | 2979 | 2980 | 2981 | 2982 | 2983 | | 5650 | 2984 | 2985 | 2986 | 2987 | 2988 | 2989 | 2990 | 2991 | | 5660 | 2992 | 2993 | 2994 | 2995 | 2996 | 2997 | 2998 | 2999 | | 5670 | 3000 | 3001 | 3002 | 3003 | 3004 | 3005 | 3006 | 3007 | | 5700 | 3008 | 3009 | 3010 | 3011 | 3012 | 3013 | 3014 | 3015 | | 5710 | 3016 | 3017 | 8108 | 3019 | 3020 | 3021 | 3022 | 3023 | | 5720 | 3024 | 3025 | 3026 | 3027 | 3028 | 3029 | 3030 | 3031 | | 5730 | 3032 | 3033 | 3034 | 3035 | 3036 | 3037 | 3038 | 3039 | | 5740 | 3040 | 3041 | 3042 | 3043 | 3044 | 3045 | 3046 | 3047 | | 5750 | 3048 | 3049 | 3050 | 3051 | 3052 | 3053 | 3054 | 3055 | | 5760 | 3056 | 3057 | 3058 | 3059 | 3060 | 3061 | 3062 | 3063 | | 5770 | 3064 | 3065 | 3066 | 3067 | 3068 | 3069 | 3070 | 3071 | # OCTAL-DECIMAL INTEGER CONVERSION TABLE (continued) | | | | | | | | | | , | | | | | | | | | | 1 | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------|--------------------| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | | | | | 3072 | | | | | 3077 | | | | | 3328 | | 3330 | | | | 3334 | | | 6000 | 3072 | | | 3080 | | | 3063<br>3091 | | 3085<br>3093 | 3086<br>3094 | | | 6410<br>6420 | | | | | | | 3342<br>3350 | | | 10<br>6777 | 10<br>3583 | | | 3096 | | | 3099 | | | | | | 6430 | | | | | | | 3358<br>3366 | | | | (Decimal) | | | 3104 | | | | | | | | | 6440<br>6450 | 3368 | 3369 | 3370 | 3371 | 3372 | 3373 | 3374 | 3375 | | | | | | 3120<br>3128 | | | | | | | | | 6460<br>6470 | | | | | | | 3382<br>3390 | | | Octal | Decimal | | İ | 1 | | | | | | | | | | | | | | | | | | | | - 4096<br>- 8192 | | | 3136 | | | | | | | | | 6500<br>6510 | | | | | | | 3398<br>3406 | | | 30000 | - 12288 | | 6120 | 3152 | 3153 | 3154 | 3155 | 3156 | 3157 | 3158 | 3159 | | 6520 | 3408 | 3409 | 3410 | 3411 | 3412 | 3413 | 3414 | 3415 | | | - 16384<br>- 20480 | | | 3160<br>3168 | | | | | | | | | 6530<br>6540 | 1 | | | | | | 3422<br>3430 | | | 60000 | - 24576 | | | 3176<br>3184 | | | | | | | | | 6550<br>6560 | | | | | | | 3438<br>3446 | | | 70000 | - 28672 | | | 3192 | | | | | | | | 1 | 6570 | , | | | | | | 3454 | | | | | | 6200 | 3200 | 3201 | 3202 | 3203 | 3204 | 3205 | 3206 | 3207 | | 6600 | 3456 | 3457 | 3458 | 3459 | 3460 | 3461 | 3462 | 3463 | | | | | | 3208 | 3209 | 3210 | 3211 | 3212 | 3213 | 3214 | 3215 | | 6610 | 3464 | 3465 | 3466 | 3467 | 3468 | 3469 | 3470 | 3471 | | | | | 6230 | 3216<br>3224 | | | 3219 | | 3221<br>3229 | 3222 | | | 6620<br>6630 | | 3481 | | | | | 3478<br>3486 | | | | | | | 3232<br>3240 | | | 3235<br>3243 | | 3237<br>3245 | | | | 6640<br>6650 | | 3489<br>3497 | | | | | 3494<br>3502 | | | | | | 6260 | | | | 3251 | | | | | 1 | 6660 | | | | | | | 3510 | | | | | | 6270 | 3256 | 3257 | 3258 | 3259 | 3260 | 3261 | 3262 | 3263 | | 6670 | 3512 | 3513 | 3514 | 3515 | 3516 | 3517 | 3518 | 3519 | | | | | 6300 | 1 | | | 3267 | | 3269 | | | - 1 | 6700 | 3520 | | | | | | 3526 | | | | | | | 3272<br>3280 | | | 3275<br>3283 | | 3277<br>3285 | 3278<br>3286 | | | 1 | 3528<br>35 <b>36</b> | | 3530<br>3538 | | | | 3534<br>3542 | | | | | | | 3288 | | | | 3292 | 3293 | 3294 | 3295 | | 6730 | 3544 | | 3546 | | | | 3550<br>3558 | | | | | | | 3296<br>3304 | | | 3299<br>3307 | 3300<br>3308 | | 3302<br>3310 | | | - 1 | 3552<br>3560 | | | | | | 3566 | | | | | | | 3312<br>3320 | | | 3315<br>3323 | | | | | | | | | | | | | 3574<br>3582 | | | | | | 100.0 | ,0000 | | | 0020 | 0021 | | | | L | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ſ | | | | | | | | | | ſ | | 1 | - | | | - | | ٠, | | | | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | ۲ | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | | | | | 3584 | 3585 | 3586 | 3587 | 3588 | 3589 | 3590 | 3591 | | | 3840 | 3841 | 3842 | 3843 | 3844 | 3845 | 6<br>3846<br>3854 | 3847 | | 7000<br>to | 3584 | | 7010 | 3584<br>3592<br>3600 | 3585<br>3593<br>3601 | 3586<br>3594<br>3602 | 3587<br>3595<br>3603 | 3588<br>3596<br>3604 | 3589<br>3597<br>3605 | 3590<br>3598<br>3606 | 3591<br>3599<br>3607 | | 7410<br>7420 | 3840<br>3848<br>3856 | 3841<br>3849<br>3857 | 3842<br>3850<br>3858 | 3843<br>3851<br>3859 | 3844<br>3852<br>3860 | 3845<br>3853<br>3861 | 3846<br>3854<br>3862 | 3847<br>3855<br>3863 | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030 | 3584<br>3592<br>3600<br>3608 | 3585<br>3593<br>3601<br>3609 | 3586<br>3594<br>3602<br>3610 | 3587<br>3595<br>3603<br>3611 | 3588<br>3596<br>3604<br>3612 | 3589<br>3597<br>3605<br>3613 | 3590<br>3598<br>3606 | 3591<br>3599<br>3607<br>3615 | | 7410<br>7420 | 3840<br>3848 | 3841<br>3849<br>3857<br>3865 | 3842<br>3850<br>3858<br>3866 | 3843<br>3851<br>3859<br>3867 | 3844<br>3852<br>3860<br>3868 | 3845<br>3853<br>3861 | 3846<br>3854<br>3862<br>3870 | 3847<br>3855<br>3863 | | 10<br>7777 | 10 | | 7010<br>7020<br>7030<br>7040<br>7050 | 3584<br>3592<br>3600<br>3608<br>3616<br>3624 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625 | 3586<br>3594<br>3602<br>3610<br>3618<br>3626 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629 | 3590<br>3598<br>3606<br>3614<br>3622<br>3630 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631 | | 7410<br>7420<br>7430<br>7440<br>7450 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883 | 3844<br>3852<br>3860<br>3868<br>3876<br>3884 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885 | 3846<br>3854<br>3862<br>3870<br>3878<br>3886 | 3847<br>3855<br>3863<br>3871<br>3879<br>3887 | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060 | 3584<br>3592<br>3600<br>3608<br>3616<br>3624<br>3632 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633 | 3586<br>3594<br>3602<br>3610<br>3618<br>3626<br>3634 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627<br>3635 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628<br>3636 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637 | 3590<br>3598<br>3606<br>3614<br>3622<br>3630 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639 | | 7410<br>7420<br>7430<br>7440 | 3840<br>3848<br>3856<br>3864<br>3872 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883 | 3844<br>3852<br>3860<br>3868<br>3876<br>3884<br>3892 | 3845<br>3853<br>3861<br>3869<br>3877 | 3846<br>3854<br>3862<br>3870<br>3878<br>3886<br>3894 | 3847<br>3855<br>3863<br>3871<br>3879 | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070 | 3584<br>3592<br>3600<br>3608<br>3616<br>3624<br>3632<br>3640 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633<br>3641 | 3586<br>3594<br>3602<br>3610<br>3618<br>3626<br>3634<br>3642 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628<br>3636<br>3644 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645 | 3590<br>3598<br>3606<br>3614<br>3622<br>3630<br>3638<br>3646 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647 | | 7410<br>7420<br>7430<br>7440<br>7450<br>7460<br>7470 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3896 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3897 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890<br>3898 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3899 | 3844<br>3852<br>3860<br>3868<br>3876<br>3884<br>3892<br>3900 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901 | 3846<br>3854<br>3862<br>3870<br>3878<br>3886<br>3894 | 3847<br>3855<br>3863<br>3871<br>3879<br>3887<br>3895<br>3903 | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7100<br>7110 | 3584<br>3592<br>3600<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633<br>3641<br>3649<br>3657 | 3586<br>3594<br>3602<br>3610<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661 | 3590<br>3598<br>3606<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3662 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663 | | 7410<br>7420<br>7430<br>7440<br>7450<br>7460<br>7470<br>7500<br>7510 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3896 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3897<br>3905<br>3913 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890<br>3898 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3899<br>3907<br>3915 | 3844<br>3852<br>3860<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917 | 3846<br>3854<br>3862<br>3870<br>3878<br>3886<br>3894<br>3902<br>3910<br>3918 | 3847,<br>3855<br>3863<br>3871<br>3879<br>3887<br>3895<br>3903<br>3911<br>3919 | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7100<br>7110<br>7120<br>7130 | 3584<br>3592<br>3600<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656<br>3664<br>3672 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633<br>3641<br>3649<br>3657<br>3665<br>3673 | 3586<br>3594<br>3602<br>3610<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658<br>3666<br>3674 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659<br>3667<br>3675 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660<br>3668<br>3676 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3669<br>3677 | 3590<br>3598<br>3606<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3662<br>3670<br>3678 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663<br>3671<br>3679 | | 7410<br>7420<br>7430<br>7440<br>7450<br>7460<br>7470<br>7500<br>7510<br>7520<br>7530 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3896<br>3904<br>3912<br>3920<br>3928 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3897<br>3905<br>3913<br>3921<br>3929 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890<br>3898<br>3906<br>3914<br>3922<br>3930 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3899<br>3907<br>3915<br>3923<br>3931 | 3844<br>3852<br>3860<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916<br>3924<br>3932 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3925<br>3933 | 3846<br>3854<br>3862<br>3870<br>3878<br>3886<br>3894<br>3902<br>3910<br>3918<br>3926<br>3934 | 3847<br>3855<br>3863<br>3871<br>3879<br>3887<br>3895<br>3903<br>3911<br>3919<br>3927<br>3935 | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7100<br>7110<br>7120<br>7130<br>7140 | 3584<br>3592<br>3600<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656<br>3664<br>3672<br>3680 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633<br>3641<br>3649<br>3657<br>3665<br>3673<br>3681 | 3586<br>3594<br>3602<br>3610<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658<br>3666<br>3674<br>3682 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659<br>3667<br>3675<br>3683 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660<br>3668<br>3676<br>3684 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3669<br>3677<br>3685 | 3590<br>3598<br>3606<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3662<br>3670<br>3678<br>3686 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663<br>3671<br>3679<br>3687 | | 7410<br>7420<br>7430<br>7440<br>7450<br>7460<br>7470<br>7500<br>7510<br>7520<br>7530<br>7540 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3896<br>3904<br>3912<br>3920<br>3928<br>3936 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3897<br>3905<br>3913<br>3921<br>3929<br>3937 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890<br>3898<br>3906<br>3914<br>3922<br>3930<br>3938 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3899<br>3907<br>3915<br>3923<br>3931<br>3939 | 3844<br>3852<br>3860<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916<br>3924<br>3932<br>3940 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3925<br>3933<br>3941 | 3846<br>3854<br>3862<br>3870<br>3878<br>3886<br>3894<br>3902<br>3910<br>3918<br>3926<br>3934<br>3942 | 3847,<br>3855,<br>3863,<br>3871,<br>3879,<br>3887,<br>3895,<br>3903,<br>3911,<br>3919,<br>3927,<br>3935,<br>3943, | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7110<br>7110<br>7120<br>7130<br>7140<br>7150<br>7160 | 3584<br>3592<br>3600<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656<br>3664<br>3672<br>3688<br>3698 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633<br>3641<br>3649<br>3657<br>3665<br>3673<br>3681<br>3689<br>3697 | 3586<br>3594<br>3602<br>3610<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658<br>3666<br>3674<br>3682<br>3690<br>3698 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659<br>3667<br>3675<br>3683<br>3691<br>3699 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660<br>3668<br>3676<br>3684<br>3692<br>3700 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3669<br>3677<br>3685<br>3693<br>3701 | 3590<br>3598<br>3606<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3670<br>3678<br>3686<br>3694<br>3702 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663<br>3671<br>3679<br>3687<br>3695<br>3703 | | 7410<br>7420<br>7430<br>7440<br>7450<br>7460<br>7500<br>7510<br>7520<br>7530<br>7540<br>7550<br>7560 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3896<br>3904<br>3912<br>3920<br>3928<br>3936<br>3944<br>3952 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3897<br>3905<br>3913<br>3921<br>3929<br>3937<br>3945<br>3953 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890<br>3898<br>3906<br>3914<br>3922<br>3930<br>3938<br>3946<br>3954 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3899<br>3907<br>3915<br>3923<br>3931<br>3939<br>3947<br>3955 | 3844<br>3852<br>3860<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916<br>3924<br>3932<br>3940<br>3948<br>3956 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3925<br>3933<br>3941<br>3949<br>3957 | 3846<br>3854<br>3862<br>3870<br>3878<br>3886<br>3894<br>3902<br>3910<br>3918<br>3926<br>3934<br>3942<br>3950<br>3958 | 3847,<br>3855<br>3863<br>3871<br>3879<br>3887<br>3995<br>3903<br>3911<br>3919<br>3927<br>3935<br>3943<br>3951<br>3959 | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7110<br>7110<br>7120<br>7130<br>7140<br>7150<br>7160 | 3584<br>3592<br>3600<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656<br>3664<br>3672<br>3680<br>3688 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633<br>3641<br>3649<br>3657<br>3665<br>3673<br>3681<br>3689<br>3697 | 3586<br>3594<br>3602<br>3610<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658<br>3666<br>3674<br>3682<br>3690<br>3698 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659<br>3667<br>3675<br>3683<br>3691<br>3699 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660<br>3668<br>3676<br>3684<br>3692<br>3700 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3669<br>3677<br>3685<br>3693<br>3701 | 3590<br>3598<br>3606<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3670<br>3678<br>3686<br>3694<br>3702 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663<br>3671<br>3679<br>3687<br>3695<br>3703 | | 7410<br>7420<br>7430<br>7440<br>7450<br>7460<br>7500<br>7510<br>7520<br>7530<br>7540<br>7550<br>7560 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3896<br>3904<br>3912<br>3920<br>3928<br>3936<br>3944<br>3952 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3897<br>3905<br>3913<br>3921<br>3929<br>3937<br>3945<br>3953 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890<br>3898<br>3906<br>3914<br>3922<br>3930<br>3938<br>3946<br>3954 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3899<br>3907<br>3915<br>3923<br>3931<br>3939<br>3947<br>3955 | 3844<br>3852<br>3860<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916<br>3924<br>3932<br>3940<br>3948<br>3956 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3925<br>3933<br>3941<br>3949<br>3957 | 3846<br>3854<br>3862<br>3870<br>3878<br>3886<br>3894<br>3902<br>3910<br>3918<br>3926<br>3934<br>3942<br>3950 | 3847,<br>3855<br>3863<br>3871<br>3879<br>3887<br>3995<br>3903<br>3911<br>3919<br>3927<br>3935<br>3943<br>3951<br>3959 | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7050<br>7070<br>7100<br>7110<br>7120<br>7130<br>7140<br>7150<br>7160<br>7170 | 3584<br>3592<br>3600<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656<br>3664<br>3672<br>3680<br>3688<br>3704 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633<br>3641<br>3649<br>3657<br>3665<br>3673<br>3681<br>3689<br>3705<br>3713 | 3586<br>3594<br>3602<br>3618<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658<br>3674<br>3682<br>3690<br>3698<br>3706 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659<br>3667<br>3675<br>3683<br>3691<br>3699<br>3707 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660<br>3668<br>3676<br>3684<br>3692<br>3700<br>3708 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3669<br>3677<br>3685<br>3693<br>3701<br>3709 | 3590<br>3598<br>3606<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3662<br>3670<br>3678<br>3686<br>3694<br>3702<br>3710 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663<br>3671<br>3679<br>3687<br>3695<br>3703<br>3711 | | 7410<br>7420<br>7430<br>7440<br>7450<br>7460<br>7500<br>7510<br>7520<br>7550<br>7550<br>7550<br>7570 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3896<br>3904<br>3912<br>3920<br>3928<br>3936<br>3944<br>3952<br>3960 | 3841<br>3849<br>3857<br>3867<br>3873<br>3881<br>3889<br>3897<br>3905<br>3913<br>3921<br>3929<br>3937<br>3945<br>3953<br>3961<br>3969 | 3842<br>3850<br>3858<br>3874<br>3882<br>3890<br>3898<br>3906<br>3914<br>3922<br>3930<br>3938<br>3946<br>3952<br>3952 | 3843<br>3851<br>3859<br>3875<br>3883<br>3891<br>3899<br>3907<br>3915<br>3923<br>3931<br>3939<br>3947<br>3955<br>3963 | 3844<br>3852<br>3860<br>3866<br>3876<br>3892<br>3900<br>3908<br>3916<br>3924<br>3932<br>3940<br>3948<br>3956<br>3964 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3925<br>3933<br>3941<br>3949<br>3957<br>3965 | 3846<br>3854<br>3862<br>3878<br>3878<br>3886<br>3894<br>3902<br>3918<br>3926<br>3934<br>3942<br>3950<br>3958<br>3966 | 3847,<br>3855,<br>3863,<br>3871,<br>3879,<br>3887,<br>3895,<br>3903,<br>3911,<br>3919,<br>3927,<br>3935,<br>3943,<br>3951,<br>3959,<br>3967,<br>3975, | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7110<br>7120<br>7130<br>7150<br>7160<br>7170 | 3584<br>3592<br>3600<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656<br>3664<br>3672<br>3680<br>3688<br>3704 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633<br>3641<br>3649<br>3657<br>3665<br>3673<br>3681<br>3689<br>3697<br>3705 | 3586<br>3594<br>3602<br>3618<br>3618<br>3626<br>3634<br>3642<br>3658<br>3658<br>3658<br>3674<br>3682<br>3690<br>3698<br>3706 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659<br>3667<br>3683<br>3691<br>3699<br>3707 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660<br>3688<br>3688<br>3684<br>3692<br>3700<br>3708 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3669<br>3667<br>3685<br>3693<br>3701<br>3709 | 3590<br>3598<br>3608<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3662<br>3670<br>3686<br>3694<br>3702<br>3710 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663<br>3671<br>3687<br>3687<br>3695<br>3703<br>3711 | | 7410<br>7420<br>7430<br>7440<br>7450<br>7460<br>7510<br>7520<br>7530<br>7540<br>7550<br>7550<br>7570 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3896<br>3904<br>3912<br>3920<br>3928<br>3936<br>3944<br>3952<br>3960 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3897<br>3905<br>3913<br>3921<br>3929<br>3937<br>3945<br>3953<br>3961 | 3842<br>3850<br>3858<br>3864<br>3874<br>3882<br>3890<br>3898<br>3906<br>3914<br>3922<br>3930<br>3938<br>3946<br>3954<br>3962 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3899<br>3907<br>3915<br>3923<br>3931<br>3939<br>3947<br>3955<br>3963 | 3844<br>3852<br>3860<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916<br>3924<br>3932<br>3940<br>3948<br>3956<br>3964 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3925<br>3933<br>3941<br>3949<br>3957<br>3965 | 3846<br>3854<br>3862<br>3870<br>3878<br>3886<br>3894<br>3902<br>3918<br>3926<br>3934<br>3942<br>3950<br>3958<br>3966 | 3847,<br>3855<br>3863<br>3871<br>3879<br>3887<br>3895<br>3903<br>3911<br>3919<br>3927<br>3935<br>3943<br>3951<br>3959<br>3967 | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7100<br>7110<br>7120<br>7130<br>7140<br>7150<br>7160<br>7170<br>7200<br>7220<br>7230 | 3584<br>3592<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>36564<br>3672<br>3680<br>3704<br>3712<br>3728<br>3738 | 3585<br>3593<br>3609<br>3617<br>3625<br>3633<br>3641<br>3649<br>3657<br>3665<br>3673<br>3681<br>3689<br>3713<br>3721<br>3721<br>3723 | 3586<br>3594<br>3610<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658<br>3666<br>3674<br>3682<br>3698<br>3706<br>3714<br>3723<br>3738 | 3587<br>3597<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3657<br>3667<br>3667<br>3683<br>3691<br>3699<br>3707<br>3715<br>3723<br>3731<br>3739 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628<br>3634<br>3652<br>3668<br>3676<br>3684<br>3692<br>3708<br>3716<br>3723<br>3716<br>3732<br>3740 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3669<br>3677<br>3685<br>3693<br>3701<br>3709 | 3590<br>3598<br>3606<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3670<br>3678<br>3686<br>3694<br>3710<br>3718<br>3718<br>3734<br>3742 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663<br>3671<br>3679<br>3687<br>3695<br>3703<br>3711 | | 7410<br>7420<br>7430<br>7440<br>7440<br>7450<br>7470<br>7500<br>7510<br>7520<br>7530<br>7540<br>7550<br>7570<br>7660<br>7610<br>7620<br>7630 | 3840<br>3848<br>3856<br>3862<br>3880<br>3888<br>3596<br>3912<br>3920<br>3928<br>3936<br>3934<br>3952<br>3960 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3897<br>3905<br>3913<br>3921<br>3929<br>3937<br>3953<br>3961<br>3969<br>3977<br>3985<br>3993 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890<br>3898<br>3906<br>3914<br>3922<br>3930<br>3938<br>3954<br>3954<br>3954<br>3962 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3899<br>3907<br>3915<br>3923<br>3931<br>3939<br>3947<br>3955<br>3963 | 3844<br>3852<br>3866<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916<br>3924<br>3932<br>3940<br>3956<br>3964<br>3972<br>3988<br>3988<br>3996 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3925<br>3933<br>3949<br>3957<br>3965<br>3973<br>3989<br>3997 | 3846<br>3854<br>3862<br>3878<br>3878<br>3886<br>3894<br>3902<br>3918<br>3926<br>3934<br>3942<br>3950<br>3958<br>3966<br>3974<br>3999<br>3998 | 3847,<br>3855,<br>3863,<br>3871,<br>3879,<br>3887,<br>3895,<br>3903,<br>3911,<br>3919,<br>3927,<br>3935,<br>3941,<br>3959,<br>3967,<br>3975,<br>3983,<br>3991,<br>3999, | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7100<br>7110<br>7120<br>7130<br>7140<br>7150<br>7170<br>7200<br>7210<br>7220<br>7230<br>7250 | 3584<br>3592<br>3600<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656<br>3667<br>3687<br>3680<br>3704<br>3712<br>3720<br>3728<br>3728<br>3738 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633<br>3641<br>3649<br>3657<br>3665<br>3665<br>3689<br>3705<br>3713<br>3721<br>3729<br>3729<br>3775<br>3775<br>3775 | 3586<br>3594<br>3602<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658<br>3658<br>3674<br>3682<br>3690<br>3714<br>3722<br>3730<br>3714<br>3730<br>3746<br>3754 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659<br>36675<br>3683<br>3691<br>3699<br>3707<br>3715<br>3723<br>3731<br>3731<br>3747<br>3755 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660<br>3686<br>3676<br>3700<br>3708<br>3716<br>3724<br>3732<br>3748<br>3756 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3669<br>3701<br>3709<br>3717<br>3725<br>3733<br>3741<br>3749<br>3757 | 3590<br>3598<br>3608<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3662<br>3670<br>3678<br>3686<br>3694<br>3702<br>3710<br>3718<br>3726<br>3734<br>3734<br>3750<br>3758 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663<br>3671<br>3679<br>3687<br>3695<br>3703<br>3711<br>3719<br>3727<br>3735<br>3743<br>3751 | | 7410<br>7420<br>7430<br>7430<br>7450<br>7460<br>7470<br>7500<br>7510<br>7520<br>7530<br>7540<br>7550<br>7560<br>7570<br>7610<br>7620<br>7620<br>7630<br>7640 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3996<br>3912<br>3920<br>3920<br>3936<br>3944<br>3952<br>3960<br>3968<br>3976<br>3984<br>3996<br>4000<br>4008 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3997<br>3905<br>3913<br>3921<br>3921<br>3937<br>3945<br>3953<br>3961<br>3969<br>3977<br>3985<br>3993<br>4001<br>4009 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3898<br>3906<br>3914<br>3922<br>3938<br>3946<br>3954<br>3954<br>3962<br>3978<br>3986<br>3996 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3907<br>3915<br>3923<br>3939<br>3947<br>3955<br>3963<br>3971<br>3979<br>3987<br>4003<br>4011 | 3844<br>3852<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916<br>3924<br>3940<br>3948<br>3956<br>3964<br>3972<br>3980<br>3980<br>3980<br>3980<br>4004<br>4012 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3925<br>3933<br>3941<br>3949<br>3957<br>3965<br>3973<br>4005<br>4013 | 3846<br>3854<br>3852<br>3870<br>3878<br>3886<br>3894<br>3902<br>3918<br>3923<br>3950<br>3958<br>3956<br>3974<br>3982<br>3990<br>3998<br>4006<br>4014 | 3847,<br>3855,<br>3863,<br>3871,<br>3879,<br>3887,<br>3895,<br>3903,<br>3911,<br>3919,<br>3927,<br>3951,<br>3959,<br>3967,<br>3975,<br>3983,<br>3991,<br>3991,<br>3991,<br>3991,<br>3991, | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7110<br>7120<br>7130<br>7150<br>7160<br>7170<br>7200<br>7210<br>7220<br>7230<br>7240<br>7260 | 3584<br>3592<br>3608<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656<br>3664<br>3672<br>3688<br>3696<br>3704<br>3712<br>3720<br>3728<br>3736<br>3744<br>3742<br>3752 | 3585<br>3593<br>3609<br>3617<br>3625<br>3633<br>3641<br>3649<br>3657<br>3665<br>3673<br>3775<br>3775<br>3773<br>3775<br>3775 | 3586<br>3594<br>3610<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658<br>3666<br>3674<br>3682<br>3690<br>3698<br>3706<br>3714<br>3722<br>3730<br>3738<br>3743<br>3743<br>3754 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659<br>3667<br>3673<br>3683<br>3691<br>3699<br>3707<br>3715<br>3723<br>3731<br>3739<br>3747<br>3747<br>3755<br>3763 | 3588<br>3596<br>3604<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660<br>3688<br>3678<br>3692<br>3700<br>3708<br>3716<br>3724<br>3732<br>3740<br>3745<br>3756<br>3756 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3669<br>3675<br>3685<br>3693<br>3701<br>3709<br>3717<br>3725<br>3733<br>3741<br>3745<br>3747<br>3745 | 3590<br>3598<br>3608<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3662<br>3670<br>3782<br>3792<br>3710<br>3718<br>3726<br>3734<br>3742<br>3758<br>3758<br>3766 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663<br>3671<br>3695<br>3703<br>3711<br>3719<br>3727<br>3735<br>3743<br>3751<br>3759<br>3767 | | 7410<br>7420<br>7430<br>7440<br>7440<br>7450<br>7450<br>7750<br>7750<br>7750<br>775 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3912<br>3920<br>3928<br>3936<br>3944<br>3952<br>3960<br>3968<br>3976<br>3984<br>3992<br>4000<br>4016 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3905<br>3913<br>3921<br>3923<br>3945<br>3953<br>3961<br>3969<br>3977<br>3985<br>3993<br>4001<br>4009<br>4017 | 3842<br>3850<br>3856<br>3874<br>3882<br>3890<br>39914<br>3922<br>3930<br>3938<br>3946<br>3954<br>3954<br>3962<br>3978<br>3986<br>3994<br>4002<br>4010 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3997<br>3915<br>3923<br>3937<br>3937<br>3955<br>3963<br>3971<br>3979<br>3987<br>3995<br>4003<br>4011<br>4019 | 3844<br>3852<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916<br>3924<br>3932<br>3940<br>3948<br>3956<br>3964<br>3972<br>3988<br>3996<br>4004<br>4012<br>4020 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3925<br>3933<br>3941<br>3949<br>3957<br>3965<br>3973<br>3981<br>3989<br>3997<br>4005<br>4013<br>4021 | 3846<br>3854<br>3867<br>3878<br>3878<br>3886<br>3894<br>3902<br>3918<br>3926<br>3934<br>3950<br>3958<br>3958<br>3966<br>3974<br>3982<br>3990<br>3998<br>4006<br>4014<br>1022 | 3847,<br>3855,<br>3863,<br>3871,<br>3879,<br>3887,<br>3895,<br>3903,<br>3911,<br>3919,<br>3927,<br>3943,<br>3951,<br>3959,<br>3967,<br>3975,<br>3983,<br>3991,<br>3999,<br>4007,<br>4015,<br>4023, | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7100<br>7110<br>7130<br>7140<br>7150<br>7170<br>7200<br>7210<br>7220<br>7230<br>7240<br>7250<br>7270 | 3584<br>3592<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656<br>3672<br>3680<br>3688<br>3704<br>3712<br>3728<br>3738<br>3736<br>3744<br>3752<br>3768 | 3585<br>3593<br>3699<br>3617<br>3625<br>3633<br>3641<br>3649<br>3657<br>3665<br>3665<br>3713<br>3769<br>3775<br>3775<br>3775<br>3775<br>3775<br>3775 | 3586<br>3594<br>3610<br>3618<br>3626<br>3634<br>3642<br>3650<br>3656<br>3674<br>3682<br>3690<br>3714<br>3723<br>3738<br>3746<br>3754<br>3754<br>3770 | 3587<br>3597<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3657<br>3675<br>3683<br>3691<br>3699<br>3707<br>3715<br>3723<br>3739<br>3747<br>3755<br>3763<br>3771 | 3588<br>3596<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3668<br>3676<br>3684<br>3692<br>3700<br>3716<br>3723<br>3740<br>3748<br>3756<br>3772 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3677<br>3685<br>3693<br>3701<br>3709<br>3717<br>3723<br>3741<br>3749<br>3757<br>3763<br>3773 | 3590<br>3598<br>3606<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3670<br>3678<br>3686<br>3694<br>3702<br>3710<br>3718<br>3724<br>3734<br>3742<br>3750<br>3758<br>3758<br>3774 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3633<br>3647<br>3655<br>3663<br>3671<br>3679<br>3687<br>3703<br>3719<br>3725<br>3743<br>3751<br>3759<br>3767<br>3775 | | 7410<br>7420<br>7430<br>7440<br>7450<br>7460<br>7470<br>7500<br>7510<br>7520<br>7530<br>7540<br>7550<br>7660<br>7660<br>7660<br>7660<br>7670<br>7680<br>7680<br>768 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3896<br>3912<br>3928<br>3936<br>3944<br>3952<br>3960<br>3968<br>3976<br>3988<br>3976<br>3984<br>4000<br>4008<br>4016<br>4024 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3905<br>3913<br>3929<br>3937<br>3945<br>3953<br>3961<br>3969<br>3977<br>3985<br>3993<br>4001<br>4009<br>4017<br>4025 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890<br>3914<br>3922<br>3930<br>3938<br>3946<br>3954<br>3962<br>3970<br>3978<br>3978<br>3970<br>4010<br>4010<br>4010 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3997<br>3915<br>3923<br>3931<br>3939<br>3947<br>3955<br>3963<br>3971<br>3979<br>4003<br>4011<br>4019<br>4027 | 3844<br>3852<br>3866<br>3868<br>3876<br>3884<br>3892<br>3900<br>3916<br>3932<br>3940<br>3948<br>3956<br>3964<br>3972<br>3980<br>3996<br>4004<br>4012<br>4020<br>4028 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3991<br>3901<br>3909<br>3917<br>3925<br>3933<br>3941<br>3949<br>3957<br>3965<br>3973<br>3981<br>3997<br>4005<br>4013<br>4021<br>4029 | 3846<br>3854<br>3862<br>3870<br>3878<br>3886<br>3894<br>3902<br>3918<br>3918<br>3934<br>3942<br>3950<br>3958<br>3966<br>3974<br>3982<br>3998<br>4006<br>4014<br>1022<br>4030 | 3847<br>3853<br>3863<br>3871<br>3879<br>3887<br>3903<br>3911<br>3919<br>3927<br>3935<br>3943<br>3951<br>3959<br>3967<br>3975<br>3983<br>3999<br>4007<br>4015<br>4023<br>4031 | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7100<br>7110<br>7120<br>7140<br>7150<br>7160<br>7170<br>7200<br>7210<br>7220<br>7230<br>7240<br>7250<br>7260<br>7270 | 3584<br>3592<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656<br>36672<br>3680<br>3688<br>3704<br>3712<br>3720<br>3728<br>3738<br>3736<br>3744<br>3752<br>3760<br>3768 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633<br>3641<br>3657<br>3665<br>3665<br>3665<br>3705<br>3713<br>3721<br>3721<br>3723<br>3737<br>3745<br>3753<br>3775<br>3761<br>3769 | 3586<br>3594<br>3610<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658<br>3674<br>3682<br>3690<br>3796<br>3714<br>3722<br>3730<br>3738<br>3746<br>3754<br>3754<br>3770 | 3587<br>3597<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659<br>3675<br>3683<br>3691<br>3699<br>3707<br>3715<br>3723<br>3731<br>3739<br>3747<br>3755<br>3763<br>3771 | 3588<br>3596<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660<br>3684<br>3676<br>3700<br>3708<br>3716<br>3724<br>3732<br>3740<br>3748<br>3756<br>3764<br>3772 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3685<br>3693<br>3701<br>3709<br>3717<br>3725<br>3733<br>3741<br>3749<br>3757<br>3765<br>3773 | 3590<br>3598<br>3606<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3670<br>3678<br>3686<br>3694<br>3702<br>3710<br>3718<br>3724<br>3734<br>3742<br>3750<br>3758<br>3758<br>3774 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663<br>3671<br>3695<br>3703<br>3711<br>3719<br>3727<br>3735<br>3743<br>3751<br>3759<br>3767<br>3775 | | 7410<br>7420<br>7440<br>7450<br>7460<br>7470<br>7500<br>7510<br>7520<br>7530<br>7550<br>7550<br>7660<br>7610<br>7620<br>7640<br>7650<br>7660<br>7670<br>7670<br>7770 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3912<br>3920<br>3928<br>3936<br>3944<br>3952<br>3960<br>3968<br>3976<br>3984<br>4000<br>4008<br>4016<br>4024 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3905<br>3913<br>3921<br>3923<br>3937<br>3945<br>3953<br>3961<br>3969<br>3977<br>3985<br>4001<br>4009<br>4017<br>4025<br>4033 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890<br>3914<br>3923<br>3930<br>3938<br>3946<br>3954<br>3954<br>3978<br>3986<br>4002<br>4010<br>4018<br>4026 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3907<br>3915<br>3923<br>3931<br>3939<br>3947<br>3955<br>3963<br>3971<br>3979<br>3987<br>4003<br>4011<br>4019<br>4027 | 3844<br>3856<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916<br>3924<br>3948<br>3956<br>3964<br>3972<br>3980<br>3980<br>3980<br>4004<br>4012<br>4020<br>4028 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3923<br>3933<br>3941<br>3949<br>3957<br>3965<br>3973<br>3981<br>3981<br>4005<br>4013<br>4021<br>4029 | 3846<br>3854<br>3867<br>3878<br>3878<br>3886<br>3894<br>3902<br>3918<br>3926<br>3934<br>3950<br>3958<br>3958<br>3966<br>3974<br>3982<br>3990<br>3998<br>4006<br>4014<br>1022 | 3847,<br>3855,<br>3863,<br>3871,<br>3879,<br>3887,<br>3895,<br>3903,<br>3911,<br>3919,<br>3927,<br>3935,<br>3951,<br>3959,<br>3967,<br>3975,<br>3983,<br>3991,<br>3991,<br>3991,<br>4007,<br>4015,<br>4023,<br>4031,<br>4039, | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7110<br>7120<br>7130<br>7150<br>7160<br>7170<br>7200<br>7210<br>7220<br>7230<br>7240<br>7250<br>7260<br>7270 | 3584<br>3592<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656<br>3664<br>3676<br>3688<br>3696<br>3704<br>3712<br>3720<br>3728<br>3736<br>3744<br>3752<br>3760<br>3768<br>3776<br>3776 | 3585<br>3593<br>3601<br>3617<br>3625<br>3633<br>3641<br>3649<br>3657<br>3665<br>3665<br>3765<br>3775<br>3775<br>3775<br>3775 | 3586<br>3594<br>3610<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658<br>3666<br>3682<br>3690<br>3698<br>3706<br>3714<br>3722<br>3730<br>3738<br>3745<br>3754<br>3754<br>3770 | 3587<br>3595<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659<br>3667<br>3683<br>3691<br>3699<br>3707<br>3715<br>3723<br>3731<br>3739<br>3747<br>3755<br>3763<br>3771 | 3588<br>3596<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660<br>3688<br>3684<br>3692<br>3700<br>3708<br>3716<br>3724<br>3732<br>3749<br>3748<br>3756<br>3748<br>3772 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3669<br>3701<br>3709<br>3717<br>3725<br>3733<br>3741<br>3749<br>3757<br>3745<br>3747<br>3757<br>3749<br>3757<br>3785<br>3773 | 3590<br>3598<br>3698<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3662<br>3670<br>3686<br>3694<br>3702<br>3710<br>3718<br>3726<br>3734<br>3742<br>3750<br>3758<br>3758<br>3758<br>3774 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663<br>3671<br>3687<br>3695<br>3703<br>3711<br>3719<br>3727<br>3743<br>3759<br>3759<br>3759<br>3767<br>3799 | | 7410<br>7420<br>7430<br>7440<br>7450<br>7460<br>7470<br>7520<br>7530<br>7530<br>7530<br>7550<br>7660<br>7610<br>7620<br>7630<br>7640<br>7650<br>7650<br>7650<br>77700<br>77700 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3912<br>3920<br>3928<br>3920<br>3928<br>3936<br>3944<br>3952<br>3960<br>3968<br>3976<br>3984<br>3992<br>4000<br>4016<br>4024<br>4040<br>4048 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3995<br>3913<br>3921<br>3923<br>3945<br>3953<br>3961<br>3969<br>3977<br>3985<br>3993<br>4001<br>4009<br>4017<br>4025<br>4033<br>4041<br>4049 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890<br>39914<br>3922<br>3930<br>3938<br>3946<br>3954<br>3954<br>3962<br>3978<br>3986<br>4002<br>4010<br>4018<br>4026 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3997<br>3915<br>3923<br>3937<br>3937<br>3955<br>3963<br>3971<br>3979<br>3987<br>3995<br>4003<br>4011<br>4019<br>4027 | 3844<br>3852<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916<br>3924<br>3932<br>3940<br>3948<br>3956<br>3964<br>4012<br>4020<br>4028<br>4036<br>4044<br>4052 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3925<br>3931<br>3949<br>3957<br>3965<br>3973<br>3981<br>3989<br>3997<br>4005<br>4013<br>4021<br>4029 | 3846<br>3854<br>3867<br>3878<br>3878<br>3886<br>3894<br>3902<br>3918<br>3926<br>3934<br>3950<br>3958<br>3958<br>3966<br>3974<br>3982<br>3990<br>3998<br>4006<br>4014<br>1022<br>4030 | 3847,<br>3855,<br>3863,<br>3871,<br>3879,<br>3887,<br>3895,<br>3903,<br>3911,<br>3919,<br>3927,<br>3943,<br>3951,<br>3959,<br>3967,<br>3975,<br>3983,<br>3991,<br>3999,<br>4007,<br>4015,<br>4023,<br>4031,<br>4039,<br>4047,<br>4055, | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7100<br>7110<br>7120<br>7140<br>7150<br>7160<br>7170<br>7200<br>7210<br>7220<br>7230<br>7240<br>7250<br>7260<br>7270<br>7310<br>7330<br>7330<br>7340 | 3584<br>3592<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>3656<br>3672<br>3680<br>3688<br>3704<br>3712<br>3720<br>3720<br>3736<br>3736<br>3736<br>3736<br>3736<br>3736<br>3736<br>373 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633<br>3641<br>3667<br>3665<br>3665<br>3665<br>3713<br>3721<br>3775<br>3775<br>3775<br>3775<br>3775<br>3775<br>3775<br>377 | 3586<br>3594<br>3610<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658<br>3674<br>3682<br>3690<br>3798<br>3706<br>3714<br>3722<br>3738<br>3738<br>3746<br>3754<br>3754<br>3770<br>3778<br>3786<br>3798 | 3587<br>3597<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659<br>3675<br>3683<br>3691<br>3699<br>3707<br>3715<br>3723<br>3737<br>3737<br>3747<br>3755<br>3763<br>3771<br>3779<br>3787<br>3787<br>3787<br>3787<br>3787<br>3787<br>3787 | 3588<br>3596<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660<br>3676<br>3684<br>3692<br>3700<br>3708<br>3716<br>3724<br>3740<br>3748<br>3756<br>3772<br>3780<br>3788<br>3798<br>3798 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3677<br>3685<br>3693<br>3701<br>3709<br>3717<br>3725<br>3773<br>3741<br>3749<br>3757<br>3765<br>3773<br>3781<br>3789<br>3789<br>3789<br>3781<br>3789<br>3789<br>3781<br>3789<br>3781<br>3789<br>3781<br>3789<br>3781<br>3789<br>3781<br>3789<br>3781<br>3789<br>3781<br>3789<br>3781<br>3789<br>3781<br>3789<br>3781<br>3789<br>3781<br>3789<br>3781<br>3781<br>3781<br>3781<br>3781<br>3781<br>3781<br>3781 | 3590<br>3598<br>3698<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3662<br>3670<br>3678<br>3686<br>3694<br>3702<br>3710<br>3718<br>3726<br>3734<br>3726<br>3734<br>3750<br>3758<br>3758<br>3768<br>3774 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3631<br>3647<br>3655<br>3663<br>3671<br>3679<br>3687<br>3695<br>3703<br>3719<br>3727<br>3735<br>3743<br>3751<br>3759<br>3767<br>3775 | | 7410 7420 7430 7440 7450 7460 7470 7500 7510 7520 7530 7540 7550 7660 7670 7680 7760 77600 7770 77700 77710 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3996<br>3912<br>3920<br>3928<br>3936<br>3944<br>3952<br>3960<br>3968<br>3976<br>3984<br>4000<br>4008<br>4016<br>4024<br>4032<br>4040<br>4048<br>4056<br>4056<br>4056 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3905<br>3913<br>3929<br>3937<br>3945<br>3953<br>3961<br>3969<br>3977<br>3985<br>4001<br>4009<br>4017<br>4025<br>4033<br>4041<br>4049<br>4057<br>4065 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890<br>3914<br>3923<br>3930<br>3938<br>3946<br>3954<br>3978<br>3978<br>3978<br>4002<br>4010<br>4018<br>4026<br>4034<br>4042<br>4058<br>4058<br>4066 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3997<br>3915<br>3921<br>3939<br>3947<br>3955<br>3963<br>3971<br>3979<br>4003<br>4011<br>4019<br>4027<br>4035<br>4043<br>4051<br>4059<br>4067 | 3844<br>3852<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916<br>3923<br>3940<br>3948<br>3956<br>3964<br>3972<br>3980<br>3980<br>4004<br>4012<br>4020<br>4028<br>4036<br>4044<br>4052<br>4060<br>4068 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3923<br>3933<br>3941<br>3949<br>3957<br>3965<br>3973<br>3981<br>4021<br>4029<br>4037<br>4045<br>4053<br>4061<br>4069 | 3846<br>3854<br>3854<br>3870<br>3878<br>3886<br>3894<br>3902<br>3910<br>3918<br>3923<br>3950<br>3958<br>3956<br>3974<br>3982<br>3998<br>4006<br>4014<br>1022<br>4030<br>4038<br>4046<br>4054<br>4052<br>4070 | 3847<br>3855<br>3863<br>3871<br>3879<br>3887<br>3895<br>3903<br>3911<br>3919<br>3927<br>3935<br>3943<br>3951<br>3959<br>3967<br>3975<br>3983<br>3991<br>4007<br>4015<br>4023<br>4031<br>4039<br>4047<br>4053<br>4063<br>4071 | | 10<br>7777 | 10<br>4095 | | 7010<br>7020<br>7030<br>7040<br>7050<br>7060<br>7070<br>7110<br>7120<br>7130<br>7140<br>7150<br>7170<br>7220<br>7230<br>7240<br>7250<br>7250<br>7270<br>7300<br>7310<br>7320<br>7330<br>7340<br>7350 | 3584<br>3592<br>3608<br>3616<br>3624<br>3632<br>3640<br>3648<br>36564<br>3672<br>3680<br>3788<br>3794<br>3712<br>3728<br>3736<br>3744<br>3752<br>3768<br>3776<br>3776<br>3776<br>3776<br>3776<br>3776 | 3585<br>3593<br>3601<br>3609<br>3617<br>3625<br>3633<br>3641<br>3657<br>3665<br>3665<br>3665<br>3665<br>3705<br>3713<br>3721<br>3729<br>3775<br>3775<br>3775<br>3775<br>3775<br>3775<br>3775<br>377 | 3586<br>3594<br>3610<br>3618<br>3626<br>3634<br>3642<br>3650<br>3658<br>3658<br>3674<br>3682<br>3690<br>3794<br>3722<br>3730<br>3714<br>3722<br>3730<br>3746<br>3754<br>3754<br>3754<br>3762<br>3770<br>3778<br>3786<br>3794<br>3818 | 3587<br>3593<br>3603<br>3611<br>3619<br>3627<br>3635<br>3643<br>3651<br>3659<br>36675<br>3683<br>3691<br>3699<br>3707<br>3715<br>3723<br>3731<br>3731<br>3747<br>3755<br>3763<br>3771<br>3779<br>3787<br>3787<br>3787<br>3787<br>3787<br>3787<br>3787 | 3588<br>3596<br>3612<br>3620<br>3628<br>3636<br>3644<br>3652<br>3660<br>3684<br>3678<br>3700<br>3708<br>3716<br>3724<br>3732<br>3748<br>3756<br>3764<br>3772<br>3780<br>3788<br>3796<br>3804<br>3812<br>3812<br>3820 | 3589<br>3597<br>3605<br>3613<br>3621<br>3629<br>3637<br>3645<br>3653<br>3661<br>3667<br>3685<br>3693<br>3701<br>3709<br>3717<br>3725<br>3733<br>3749<br>3757<br>3765<br>3773<br>3781<br>3789<br>3797<br>3805<br>3797<br>3805<br>3813<br>3821 | 3590<br>3598<br>3696<br>3614<br>3622<br>3630<br>3638<br>3646<br>3654<br>3670<br>3678<br>3686<br>3694<br>3702<br>3718<br>3732<br>3710<br>3718<br>3750<br>3750<br>3756<br>3774<br>3782<br>3774 | 3591<br>3599<br>3607<br>3615<br>3623<br>3631<br>3639<br>3647<br>3655<br>3663<br>3679<br>3687<br>3695<br>3703<br>3711<br>3719<br>3727<br>3735<br>3743<br>3751<br>3759<br>3767<br>3775<br>3783<br>3791<br>3799<br>3815<br>3823 | | 7410 7420 7440 7450 7460 7470 7500 7510 7520 7520 7550 7660 7670 7680 7670 7680 7770 7770 777 | 3840<br>3848<br>3856<br>3864<br>3872<br>3880<br>3888<br>3912<br>3920<br>3920<br>3920<br>3920<br>3920<br>3936<br>3944<br>3952<br>3960<br>3968<br>3976<br>3984<br>4090<br>4008<br>4016<br>4024<br>4048<br>4054<br>4054<br>4054<br>4054<br>4054<br>4054<br>405 | 3841<br>3849<br>3857<br>3865<br>3873<br>3881<br>3889<br>3905<br>3913<br>3921<br>3937<br>3945<br>3953<br>3961<br>3969<br>3977<br>3985<br>3993<br>4001<br>4009<br>4017<br>4025<br>4033<br>4041<br>4049<br>4057<br>4065<br>4073 | 3842<br>3850<br>3858<br>3866<br>3874<br>3882<br>3890<br>3914<br>3922<br>3938<br>3946<br>3954<br>3954<br>3962<br>3978<br>3986<br>3978<br>4002<br>4010<br>4018<br>4026<br>4034<br>4042<br>4050<br>4050<br>4056<br>4074 | 3843<br>3851<br>3859<br>3867<br>3875<br>3883<br>3891<br>3907<br>3915<br>3923<br>3937<br>3947<br>3955<br>3963<br>3971<br>3979<br>3987<br>4003<br>4011<br>4019<br>4027<br>4035<br>4043<br>4051<br>4057<br>4075 | 3844<br>3852<br>3868<br>3876<br>3884<br>3892<br>3900<br>3908<br>3916<br>3924<br>3940<br>3948<br>3956<br>3964<br>3972<br>3980<br>3980<br>4004<br>4012<br>4020<br>4028<br>4036<br>4044<br>4052<br>4068<br>4076 | 3845<br>3853<br>3861<br>3869<br>3877<br>3885<br>3893<br>3901<br>3909<br>3917<br>3923<br>3935<br>3941<br>3949<br>3957<br>3985<br>3981<br>3989<br>4005<br>4013<br>4021<br>4029<br>4037<br>4045<br>4053<br>4061<br>4069<br>4077 | 3846<br>3854<br>3854<br>3870<br>3878<br>3886<br>3894<br>3910<br>3918<br>3923<br>3934<br>3942<br>3950<br>3958<br>3974<br>3982<br>4006<br>4014<br>1022<br>4030<br>4038<br>4046<br>4054<br>4062 | 3847<br>3855<br>3863<br>3871<br>3879<br>3887<br>3895<br>3903<br>3911<br>3919<br>3927<br>3935<br>3951<br>3959<br>3967<br>3975<br>3983<br>3991<br>3999<br>4007<br>4015<br>4023<br>4031<br>4039<br>4047<br>4055<br>4063<br>4071<br>4079 | | 10<br>7777 | 10<br>4095 | #### OCTAL-DECIMAL FRACTION CONVERSION TABLE | OCTAL | DEC. | OCTAL | DEC. | OCTAL | DEC. | OCTAL | DEC. | |-------|--------------------|----------|------------------|-------------|----------|-------|----------| | .000 | .000000 | . 100 | . 125000 | . 200 | . 250000 | . 300 | .375000 | | .001 | .001953 | . 101 | . 126953 | .201 | . 251953 | .301 | . 376953 | | .002 | . ð0390 <b>6</b> | . 102 | . 128906 | . 202 | , 253906 | . 302 | .378906 | | .003 | .005859 | . 103 | . 130859 | . 203 | . 255859 | . 303 | . 380859 | | .004 | .007812 | . 104 | . 132812 | . 204 | . 257812 | . 304 | .382812 | | .005 | . 009765 | . 105 | . 134765 | . 205 | . 259765 | . 305 | .384765 | | .006 | .011718 | . 106 | . 136718 | . 206 | . 261718 | . 306 | .386718 | | .007 | .013671 | . 107 | . 138671 | . 207 | . 263671 | .307 | .388671 | | .010 | .015625 | .110 | . 140625 | .210 | . 265625 | .310 | . 390625 | | .011 | .017578 | .111 | . 142578 | ,211 | . 267578 | .311 | . 392578 | | .012 | .019531 | .112 | . 144531 | .212 | . 269531 | .312 | .394531 | | .013 | .021484 | .113 | . 146484 | .213 | . 271484 | .313 | . 396484 | | .014 | .023437 | , 114 | . 148437 | . 214 | . 273437 | .314 | .398437 | | .015 | .025390 | . 115 | . 150390 | ,215 | . 275390 | .315 | .400390 | | .016 | .027343 | . 116 | . 152343 | .216 | . 277343 | .316 | .402343 | | .017 | .029296 | . 117 | . 154296 | .217 | . 279296 | .317 | .404296 | | . 020 | .031250 | . 120 | . 156250 | , 220 | , 281250 | .320 | .406250 | | .021 | .033203 | . 121 | , 158203 | . 221 | . 283203 | .321 | .408203 | | .021 | .035156 | . 122 | .160156 | . 222 | . 285156 | . 322 | .410156 | | .022 | .037109 | . 123 | . 162109 | .223 | .287109 | . 323 | .412109 | | .023 | .039062 | . 124 | . 164062 | .224 | . 289062 | .324 | . 414062 | | .024 | .033002 | . 125 | . 166015 | . 225 | .291015 | .325 | .416015 | | .026 | .042968 | . 126 | . 167968 | . 226 | .292968 | .326 | .417968 | | .027 | .044921 | . 127 | . 169921 | .227 | . 294921 | .327 | .419921 | | | | .130 | . 171875 | . 230 | . 296875 | .330 | . 421875 | | .030 | .046875 | . 131 | .173828 | ,231 | . 298828 | .331 | . 423828 | | .031 | .048828<br>.050781 | . 132 | . 175781 | . 232 | .300781 | 332 | . 425781 | | .032 | - | . 133 | . 177734 | 233 | .302734 | ,333 | . 427734 | | . 033 | . 052734 | . 134 | . 179687 | . 234 | .304687 | .334 | ,429687 | | . 034 | . 054687 | | . 181640 | . 235 | .306640 | .335 | .431640 | | .035 | .056640 | . 135 | . 183593 | . 236 | .308593 | .336 | , 433593 | | . 036 | .058593 | • | | . 237 | .310546 | .337 | . 435546 | | .037 | .060546 | . 137 | . 185546 | I . | | .340 | . 437500 | | .040 | .062500 | . 140 | . 187500 | . 240 | .312500 | .340 | .439453 | | .041 | . 064453 | . 141 | . 189453 | .241 | .314453 | .342 | .441406 | | .042 | .066406 | . 142 | . 191406 | . 242 | .316406 | • | | | .043 | .068359 | . 143 | . 193359 | . 243 | .318359 | .343 | .443359 | | .044 | .070312 | . 144 | . 195312 | . 244 | .320312 | .344 | .445312 | | . 045 | .072265 | . 145 | . 197265 | . 245 | . 322265 | .345 | .447265 | | .046 | .074218 | . 146 | . 199218 | .246 | .324218 | .346 | .449218 | | .047 | .076171 | . 147 | .201171 | . 247 | . 326171 | .347 | .451171 | | . 050 | .078125 | . 150 | . 203125 | . 250 | . 328125 | . 350 | .453125 | | .051 | .080078 | . 151 | . 205078 | . 251 | . 330078 | . 351 | . 455078 | | .052 | .082031 | . 152 | .207031 | . 252 | . 332031 | . 352 | .457031 | | . 053 | .083984 | . 153 | . 208984 | . 253 | . 333984 | . 353 | . 458984 | | . 054 | . 085937 | . 154 | .210937 | . 254 | . 335937 | . 354 | . 460937 | | .055 | .087890 | . 155 | .212890 | . 255 | . 337890 | . 355 | .462890 | | . 056 | .089843 | . 156 | . 214843 | . 256 | . 339843 | .356 | .464843 | | . 057 | .091796 | . 157 | .216796 | . 257 | .341796 | .357 | . 466796 | | .060 | .093750 | . 160 | .218750 | . 260 | .343750 | .360 | .468750 | | .061 | .095703 | . 161 | . 220703 | . 261 | .345703 | .361 | . 470703 | | .062 | .097656 | . 162 | . 222656 | . 262 | .347656 | .362 | . 472656 | | .063 | . 099609 | . 163 | . 224609 | . 263 | . 349609 | . 363 | .474609 | | .064 | . 101562 | : 164 | . 226562 | . 264 | .351562 | . 364 | . 476562 | | .065 | . 103515 | . 165 | . 22851 <b>5</b> | . 265 | . 353515 | .365 | .478515 | | .066 | . 105468 | . 166 | .230468 | . 266 | . 355468 | .366 | .480468 | | .067 | . 107421 | . 167 | . 232421 | . 267 | .357421 | .367 | .482421 | | .070 | . 109375 | . 170 | , 234375 | . 270 | . 359375 | .370 | .484375 | | .071 | . 111328 | . 171 | .236328 | .271 | .361328 | .371 | .486328 | | .072 | . 113281 | .172 | .238281 | . 272 | .363281 | .372 | .488281 | | .073 | . 115234 | .173 | . 240234 | .273 | . 365234 | .373 | .490234 | | .074 | . 117187 | . 174 | .242187 | . 274 | .367187 | .374 | .492187 | | .075 | . 119140 | . 175 | .244140 | . 275 | .369140 | .375 | .494140 | | .076 | . 121093 | . 176 | .246093 | . 276 | .371093 | .376 | .496093 | | .077 | . 123046 | .177 | . 248046 | .277 | .373046 | .377 | .498046 | | | • | | | | | 1 | | | İ | | 1 | | | | 1 | | | | | <u> </u> | | <del></del> | | | | # OCTAL-DECIMAL FRACTION CONVERSION TABLE (continued) | .000000 .000000 .000100 .000244 .000200 .000488 .000001 .000003 .00101 .000247 .000201 .000492 .000002 .000001 .000103 .000101 .000255 .000203 .000499 .000004 .00015 .000255 .000203 .000499 .000004 .00015 .000105 .000259 .000204 .000503 .000009 .000105 .000105 .000259 .000205 .000507 .000000 .000019 .000105 .000267 .000205 .000205 .000507 .000000 .000008 .000105 .000267 .000206 .000511 .000007 .000022 .000107 .000270 .000207 .000514 .000010 .000010 .000274 .000210 .000518 .000011 .000010 .000274 .000210 .000518 .000011 .000011 .000030 .000110 .000274 .000211 .000528 .000011 .000011 .000030 .000110 .000274 .000211 .000522 .000107 .000011 .000030 .000110 .000278 .000211 .000522 .000012 .000013 .000111 .00013 .000286 .000213 .000530 .000111 .000030 .000111 .000033 .000115 .000288 .000213 .000530 .000016 .000289 .000115 .000289 .000213 .000530 .000016 .000287 .000115 .000289 .000213 .000534 .000115 .000289 .000215 .000537 .000115 .000287 .000216 .000541 .000053 .000115 .000287 .000216 .000541 .000545 .000116 .000297 .000216 .000541 .000545 .000117 .000301 .000217 .000545 .000021 .000064 .000121 .000300 .000221 .000545 .000021 .000064 .000121 .000300 .000221 .000545 .000022 .000068 .000122 .000305 .000220 .000549 .000021 .000064 .000121 .000300 .000221 .000555 .000022 .000068 .000122 .000312 .000221 .000555 .000022 .000668 .000122 .000312 .000224 .000556 .000022 .000668 .000122 .000312 .000224 .000556 .000022 .000668 .000122 .000312 .000324 .000224 .000566 .000025 .000026 .000027 .000130 .00033 .000126 .00033 .000126 .00033 .000126 .00033 .000126 .00033 .000126 .00033 .000227 .000566 .000031 .00033 .000126 .00033 .000127 .000331 .000227 .000569 .000031 .00033 .000120 .00033 .000121 .000583 .000221 .000580 .000022 .000666 .000131 .000339 .000221 .000580 .000022 .000666 .000131 .000339 .000221 .000580 .000660 .000125 .000131 .000339 .000221 .000580 .000666 .000131 .000339 .000221 .000666 .000667 .000144 .000167 .000184 .000167 .000184 .000167 .000167 .000167 .000167 .000167 .000167 .000167 .000167 .000167 .000167 .000 | | | OCTAL | DEC. | OCTAL | DEC. | OCTAL | DEC. | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------|---------|-----------------------------------------|----------|-----------------------------------------|------------------|----------| | 0000002 0000017 0001012 0000255 000203 000049 000003 000011 000103 000255 000203 000499 000004 000015 .000104 000259 .000205 .000507 000005 .000019 .000105 .000267 .000206 .000511 .000007 .000028 .000107 .000270 .000227 .000514 .000011 .000038 .000111 .000274 .000211 .000522 .000011 .000034 .000111 .000228 .000212 .000522 .000013 .000141 .000113 .000286 .000213 .000534 .000014 .000115 .000289 .000213 .000534 .000015 .000233 .000115 .000289 .000213 .000534 .000016 .000053 .000116 .000297 .000211 .000537 .000021 .000053 .000117 .000305 .000221 .000541 .000022 .000064 | 000000 | .000000 | .000100 | .000244 | .000200 | .000488 | .000300 | . 000732 | | | 000001 | . 000003 | .000101 | .000247 | .000201 | .000492 | .000301 | . 000736 | | 000004 000015 000104 000259 000205 000207 000507 000006 000019 000105 000263 000205 000507 000006 0000107 000207 000206 000511 0000010 0000010 000277 000207 000207 000514 000010 000010 000011 000274 000210 000518 000011 000011 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000013 000111 000278 000211 000528 000011 000012 000013 000014 000113 000286 000213 000536 000014 000015 000015 000223 000214 000534 000014 000015 000028 000214 000534 000016 000005 000016 000053 000116 000297 000216 000541 000016 000005 000011 000029 000217 000545 0000021 000006 000001 000002 000006 000012 000030 000221 000545 0000022 000064 000121 000308 000221 000558 000022 000055 000022 000064 000121 000038 000221 000558 000022 000055 000022 000068 000012 0000316 000223 000560 000024 000556 000024 000056 000024 000056 000024 000056 000025 000034 000025 000056 000025 000038 000025 000545 000025 000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 0000057 | 000002 | .000007 | .000102 | .000251 | .000202 | .000495 | .000302 | . 000740 | | 000005 000019 000105 000283 000205 000507 000006 000006 000022 000106 000287 000206 000511 000006 000026 000011 000207 000210 000511 000011 000034 000011 000274 000210 000512 000011 000034 000111 000278 000211 000522 000012 000038 000112 000282 000212 000522 000012 000038 000112 000282 000212 000534 000013 000015 000041 000038 000114 000289 000214 000534 000015 000005 000015 000057 000115 000287 000215 000537 000016 000053 000116 000227 000216 000541 000017 000007 000017 000007 000017 000007 000017 000007 000017 000007 000017 000007 000017 000007 000017 000007 000017 000007 000017 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 0000007 000007 000007 000007 000007 000007 000007 0000007 000007 000007 000007 000007 000007 000007 0000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 0000007 000007 000007 000007 000007 000007 000007 0000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 000007 00000 | 000003 | .000011 | .000103 | .000255 | .000203 | .000499 | .000303 | .000743 | | .000005 .000019 .000105 .000267 .000205 .000507 .000006 .000022 .000106 .000267 .000206 .000514 .000010 .000030 .000110 .000274 .000210 .000513 .000011 .000033 .000111 .000278 .000211 .000282 .000012 .000033 .000112 .000282 .000212 .000526 .000014 .000113 .000282 .000213 .000534 .000015 .000048 .000115 .000283 .000214 .000534 .000016 .000053 .000116 .000297 .000215 .000531 .000017 .000057 .000117 .000305 .000221 .000545 .000021 .000068 .000122 .000312 .000221 .000553 .000022 .000068 .000123 .000312 .000221 .000553 .000022 .000068 .00123 .000312 .000221 .000556 .000022 | 00004 | .000015 | .000104 | .000259 | .000204 | . 000503 | .000304 | .000747 | | 0000006 000022 000106 000267 000206 000511 0000007 000007 000011 000011 000010 000011 000028 000110 000274 000210 000518 000011 000012 000012 000028 000112 000282 000212 000526 000013 000014 000113 000286 000213 000530 000014 000114 000028 000213 000530 000015 000008 000115 000287 000215 000530 000015 000038 000115 000287 000216 000531 000016 000053 000116 000287 000216 000531 000016 0000057 000117 000030 000217 000541 00000000000000000000000000000000000 | 000005 | .000019 | .000105 | .000263 | B . | | .000305 | .000751 | | 0000017 000028 000107 000274 000210 000514 0000101 0000011 0000278 000011 000028 000011 000028 000011 000028 000212 000028 000011 000028 000212 000028 000011 000028 000013 000033 000014 000013 000028 000213 000053 000015 000029 000015 000053 000015 0000297 000215 000537 000016 000015 000005 000016 0000297 000215 000537 000017 000057 000116 0000297 000217 000545 000017 000057 000117 000057 000117 000057 000117 000051 0000217 000545 000020 000022 000068 000122 000030 000221 000553 000012 000022 000068 000122 000030 000222 000556 000022 000068 000122 0000312 000222 000556 000022 000002 000022 000002 000024 000076 000124 000326 000222 000564 000025 000002 000002 000002 000002 000002 000002 000002 000002 000002 000002 0000000 000125 000032 000025 000564 000000000 0000000 000000 000000 | 000006 | .000022 | .000106 | .000267 | | • | .000306 | . 000755 | | | 000007 | .000026 | .000107 | | 1 | | .000307 | . 000759 | | | 000010 | . 000030 | | | l . | | .000310 | .000762 | | 000012 .000038 .000112 .000282 .000212 .000526 000013 .000041 .000113 .000289 .000213 .000530 000015 .000049 .000116 .000289 .000215 .000537 000016 .000053 .000116 .000297 .000215 .000541 000017 .000057 .000117 .000301 .000220 .000545 000021 .000064 .000121 .000308 .000221 .000553 000022 .000068 .00122 .000312 .000222 .000556 000022 .000068 .00122 .000318 .000223 .000560 000024 .000172 .000124 .000324 .000225 .000560 000025 .000080 .000125 .000324 .000225 .000560 000027 .000083 .00126 .000328 .000225 .000576 000020 .000083 .000127 .000331 .000230 .000577 000031 <td></td> <td>•</td> <td>1 -</td> <td>-</td> <td></td> <td></td> <td>.000310</td> <td>.000766</td> | | • | 1 - | - | | | .000310 | .000766 | | 000013 | | • | | • | | • | | - | | 000014 .000045 .000114 .000289 .000214 .00034 000015 .000049 .000115 .000233 .000215 .000531 000017 .000057 .000116 .000297 .000211 .000541 000017 .000061 .000120 .000305 .000220 .000549 000021 .000064 .000121 .000308 .000221 .000553 000022 .000068 .000122 .000312 .000222 .000560 000023 .000072 .000123 .000316 .000223 .000560 000024 .000076 .00124 .000320 .000225 .000564 000025 .000080 .000127 .000331 .000225 .000572 000027 .000087 .000127 .000331 .000227 .000572 000030 .000091 .000130 .000335 .000231 .000579 000031 .000095 .000131 .000339 .000231 .000587 000032 <td></td> <td></td> <td>1</td> <td>• • • • • • • • • • • • • • • • • • • •</td> <td></td> <td></td> <td>.000312</td> <td>. 000770</td> | | | 1 | • • • • • • • • • • • • • • • • • • • • | | | .000312 | . 000770 | | 000015 .000049 .000115 .000293 .000215 .00037 000016 .000053 .000116 .000227 .000216 .000541 000017 .000301 .000217 .000345 .000220 .000545 000021 .000064 .000121 .000308 .000221 .000553 000022 .000068 .000122 .000312 .000222 .000556 000023 .000072 .000123 .000312 .000223 .000560 000024 .000124 .000320 .000224 .000564 000025 .000080 .000125 .000324 .000225 .000588 000027 .000187 .000127 .00031 .000277 .000576 000030 .00091 .000130 .000331 .000227 .000576 000031 .000095 .000131 .000333 .000231 .000583 000032 .000999 .000133 .000344 .000233 .000581 000034 .000106 <td></td> <td>•</td> <td>1</td> <td>-</td> <td></td> <td></td> <td>.000313</td> <td>. 000774</td> | | • | 1 | - | | | .000313 | . 000774 | | 000016 .00053 .000116 .000297 .000218 .000341 000017 .000057 .000117 .000305 .000217 .000545 000021 .000064 .000121 .000308 .000221 .000553 000022 .000068 .000122 .000312 .000222 .000556 000023 .000072 .000123 .000321 .000560 000024 .000076 .000124 .000320 .000225 .000560 000025 .000080 .000125 .000324 .000225 .000583 000026 .000087 .000127 .000331 .000227 .000576 000031 .000087 .000127 .000331 .000227 .000576 000031 .000091 .000131 .000339 .000231 .000583 000033 .000092 .000132 .000339 .000231 .000587 000034 .000106 .000134 .000339 .000231 .000581 000035 .000114 </td <td></td> <td></td> <td>1</td> <td>•</td> <td></td> <td></td> <td>.000314</td> <td>.000778</td> | | | 1 | • | | | .000314 | .000778 | | 000017 .000057 .000117 .000301 .000217 .000545 000020 .000061 .000120 .000305 .000220 .000543 000021 .000084 .000121 .000308 .000221 .000553 000022 .000068 .000122 .000312 .000223 .000556 000024 .000076 .000124 .000320 .000223 .000564 000025 .000080 .000127 .000324 .000225 .000568 000026 .000083 .000127 .00031 .000227 .000576 000037 .000127 .00031 .000225 .000576 000030 .000091 .000130 .000331 .000230 .000579 000031 .000093 .000131 .000335 .000231 .000587 000032 .000199 .000132 .000347 .000233 .000587 000032 .000102 .000133 .000347 .000233 .000589 000033 .000114 <td></td> <td>-</td> <td>1</td> <td></td> <td>1</td> <td></td> <td>.000315</td> <td>.000782</td> | | - | 1 | | 1 | | .000315 | .000782 | | 000020 .000061 .000120 .000305 .000220 .000549 000021 .000064 .000121 .000308 .000221 .000553 000022 .000068 .000122 .000312 .00022 .000556 000023 .000072 .000124 .000320 .000224 .000560 000024 .000080 .000125 .000324 .000225 .000568 000027 .000083 .000126 .000328 .000225 .000572 000030 .000131 .000335 .000230 .000579 000031 .000991 .000131 .000335 .000231 .000587 000032 .000095 .000131 .000343 .000232 .000587 000033 .000102 .000133 .000347 .000233 .000591 000034 .00106 .000134 .000350 .000234 .000591 000035 .000110 .000135 .000354 .000235 .000592 000036 .000110 <td></td> <td></td> <td>1</td> <td>-</td> <td></td> <td></td> <td>.000316</td> <td>.000785</td> | | | 1 | - | | | .000316 | .000785 | | 000021 .000064 .000121 .000308 .000221 .000553 000022 .000068 .000122 .000312 .000223 .000560 000023 .000072 .000124 .000320 .000223 .000560 000024 .000086 .000124 .000324 .000225 .000564 000025 .000083 .000127 .000324 .000225 .000572 000027 .000087 .000127 .000331 .000227 .000572 000031 .000931 .000131 .000339 .000231 .000583 000032 .000099 .00132 .000343 .000231 .000583 000033 .000102 .000133 .000347 .000233 .000595 000034 .000160 .000134 .000350 .000234 .000595 000035 .000110 .000135 .000354 .000233 .000602 000037 .00018 .000356 .000235 .000598 000037 .00018 <td></td> <td></td> <td></td> <td>.000301</td> <td>.000217</td> <td>.000545</td> <td>.000317</td> <td>.000789</td> | | | | .000301 | .000217 | .000545 | .000317 | .000789 | | 0000022 .000068 .000122 .000312 .000222 .000556 000023 .000072 .000123 .000316 .000223 .000560 000024 .000076 .000124 .000324 .000224 .000564 000025 .000080 .000125 .000328 .000226 .000576 000027 .000087 .000127 .000331 .000227 .000576 000030 .000091 .000130 .000335 .000230 .000579 000031 .000099 .000131 .000339 .000231 .000587 000032 .000199 .000132 .000343 .000232 .000587 000033 .000106 .000134 .000350 .000234 .000595 000034 .000110 .000135 .000354 .000235 .000598 000035 .000114 .000136 .000358 .000236 .000602 000037 .000118 .000137 .000368 .000236 .000602 000040 | | • | .000120 | .000305 | .000220 | .000549 | .000320 | .000793 | | 000023 .000072 .000123 .000316 .000223 .000560 000024 .000076 .000124 .000320 .000224 .000564 000025 .000080 .000126 .000324 .000226 .000568 000026 .000083 .000127 .00031 .00027 .000572 000021 .000081 .000127 .000331 .000227 .000576 000031 .000091 .000130 .000339 .000231 .000583 000032 .000099 .00132 .000347 .000233 .000581 000033 .000106 .000134 .000336 .000234 .000581 000034 .000116 .000134 .000350 .000234 .000585 000035 .000110 .000135 .000356 .000234 .000585 000036 .000114 .000135 .000356 .000237 .000606 000037 .000118 .000137 .000368 .000236 .000606 000041 <td>00021</td> <td>.000064</td> <td>.000121</td> <td>.000308</td> <td>.000221</td> <td>.000553</td> <td>.000321</td> <td>. 000797</td> | 00021 | .000064 | .000121 | .000308 | .000221 | .000553 | .000321 | . 000797 | | 000024 .00076 .000124 .000320 .000224 .000564 000025 .000080 .000125 .000324 .000225 .000588 000026 .000083 .000127 .000331 .000227 .000576 000031 .000091 .000130 .000335 .000230 .000587 000031 .000095 .000131 .000339 .000231 .000583 000032 .000099 .000132 .000343 .000232 .000587 000033 .000106 .00133 .000347 .000233 .000591 000034 .000106 .00134 .000350 .000234 .000595 000035 .000110 .000135 .000354 .000235 .000598 000036 .000114 .000136 .000358 .000236 .000602 000040 .000122 .000140 .000366 .000240 .000610 000041 .000125 .000141 .000377 .000141 .000141 .000141 .000 | 00022 | | .000122 | .000312 | .000222 | .000556 | .000322 | .000801 | | 000024 .000076 .000124 .000320 .000224 .000564 000025 .000080 .000125 .000324 .000225 .000572 000026 .000087 .000127 .000331 .000227 .000576 000030 .000095 .000130 .000335 .000230 .000579 000031 .000095 .000131 .000339 .000231 .000583 000032 .000099 .000132 .000343 .000232 .000587 000033 .000106 .000134 .000350 .000234 .000595 000033 .000110 .000135 .000354 .000235 .000595 000034 .000114 .000135 .000354 .000235 .000598 000037 .000118 .000137 .000362 .000235 .000598 000040 .000122 .000140 .000362 .000237 .000606 000041 .000125 .000141 .000377 .000614 .000614 000042< | 00023 | .000072 | .000123 | .000316 | .000223 | .000560 | . 000323 | . 000805 | | 000025 .000080 .000125 .000324 .000225 .000588 000026 .000083 .000126 .000328 .000226 .000572 000027 .000187 .000331 .000227 .000578 000031 .000095 .000131 .000339 .000231 .000583 000032 .000199 .000132 .000343 .000232 .000587 000033 .000102 .00133 .000347 .000233 .000581 000034 .000106 .00134 .000356 .000235 .000598 000035 .000114 .000136 .000354 .000235 .000598 000036 .000114 .000136 .000388 .000236 .000602 000037 .000118 .000137 .000388 .000236 .000602 000041 .000122 .000140 .000366 .000240 .000610 000041 .000123 .000141 .000377 .000241 .000614 000042 .000133 <td>00024</td> <td>.000076</td> <td>.000124</td> <td>.000320</td> <td>.000224</td> <td></td> <td>.000324</td> <td>.000808</td> | 00024 | .000076 | .000124 | .000320 | .000224 | | .000324 | .000808 | | 000026 .000083 .000126 .000328 .000226 .000572 0000027 .000087 .000127 .000331 .000227 .000576 000030 .000091 .000130 .000335 .000230 .000579 000031 .000095 .000131 .000339 .000232 .000583 000032 .000108 .000133 .000344 .000232 .000587 000034 .000106 .000134 .000356 .000235 .000581 000035 .000110 .000135 .000354 .000235 .00058 000036 .000114 .000135 .000358 .000236 .000602 000040 .000122 .000140 .000366 .000240 .000610 000041 .000125 .000141 .000377 .000241 .000617 000043 .000133 .000141 .000373 .000241 .000617 000044 .000125 .000141 .000373 .000241 .000617 000044< | 00025 | .000080 | .000125 | .000324 | . 000225 | . 000568 | .000325 | .000812 | | 000027 .000087 .000127 .000331 .000227 .000576 000030 .00091 .000130 .000335 .000230 .000579 000031 .000095 .000131 .000339 .000232 .000583 000032 .000199 .000132 .000343 .000232 .000587 000033 .000102 .000134 .000356 .000234 .000595 000034 .000106 .000134 .000356 .000235 .000598 000035 .000114 .000136 .000358 .000235 .000602 000036 .000114 .000136 .000388 .000237 .000602 000040 .000122 .000140 .000366 .000240 .000610 000041 .000122 .000141 .000373 .000241 .000614 000042 .000123 .000142 .000373 .000244 .000617 000043 .000133 .000143 .000377 .000243 .000625 000044 </td <td>00026</td> <td>.000083</td> <td></td> <td>-</td> <td></td> <td></td> <td>.000326</td> <td>.000816</td> | 00026 | .000083 | | - | | | .000326 | .000816 | | 000030 .00091 .000130 .000335 .000230 .000579 000031 .000095 .00131 .000339 .000231 .000587 000032 .000099 .000132 .000343 .000232 .000587 000033 .000102 .000133 .000347 .000233 .000595 000034 .000110 .000135 .000354 .000235 .000598 000036 .000114 .000136 .000354 .000235 .000602 000037 .000118 .000137 .000362 .000236 .006602 000041 .000122 .000140 .000368 .000240 .000610 000041 .000125 .000141 .000377 .000241 .000614 000042 .000129 .000142 .000377 .000243 .000617 000043 .000137 .000143 .000377 .000244 .000625 000044 .000137 .000144 .000389 .000245 .000625 000044 <td></td> <td></td> <td>1</td> <td></td> <td></td> <td></td> <td>.000327</td> <td>.000820</td> | | | 1 | | | | .000327 | .000820 | | 0000031 .000095 .000131 .000339 .000231 .000583 0000032 .0001099 .000132 .000343 .000232 .000587 0000033 .000106 .000134 .000350 .000234 .000595 000034 .000110 .000135 .000354 .000235 .000598 0000037 .000114 .000136 .000388 .000236 .000602 000037 .000118 .000137 .000386 .000237 .000606 000040 .000122 .000140 .000386 .000240 .000610 000041 .000125 .000141 .000370 .000241 .000614 000042 .000129 .000142 .000373 .000242 .000617 000043 .000137 .000143 .000377 .000244 .000621 000044 .000137 .000144 .000381 .000244 .000625 000045 .000141 .000145 .000389 .000246 .000629 00 | | • | 1 - | | ł . | | .000327 | .000823 | | 0000032 .000099 .000132 .000343 .000232 .000587 0000033 .000102 .000133 .000347 .000233 .000595 000034 .000110 .000134 .000350 .000234 .000595 000035 .000110 .000135 .000354 .000235 .000598 000036 .000114 .000136 .000358 .000237 .000602 000040 .000122 .000140 .000362 .000240 .000610 000041 .000125 .000141 .000370 .000241 .000614 000042 .000129 .000143 .000377 .000243 .000621 000043 .000133 .000143 .000377 .000244 .000625 000044 .000137 .000144 .000381 .000244 .000625 000044 .000141 .000385 .000246 .000633 000047 .000148 .000147 .000389 .000246 .000637 000050 .00015 | | - | | • | 1 | - | _ | | | 0000033 .000102 .000133 .000347 .000233 .000591 000034 .000106 .000134 .000350 .000234 .000595 000035 .000114 .000135 .000358 .000235 .000598 000036 .000114 .000136 .000358 .000236 .000602 000041 .000122 .000140 .000368 .000240 .000610 000041 .000125 .000141 .000373 .000241 .000614 000042 .000129 .000142 .000373 .000241 .000617 000043 .000137 .000143 .000373 .000244 .000621 000044 .000137 .000144 .000381 .000244 .000625 000045 .000141 .000145 .000385 .000245 .000629 000046 .000141 .000146 .000389 .000244 .000633 000047 .000148 .000150 .000386 .000250 .000640 000051 | | | 1 | - | • | | .000331 | .000827 | | 000034 .000106 .000134 .000350 .000234 .000595 000035 .000110 .000135 .000354 .000235 .000602 000036 .000114 .000137 .000368 .000237 .000606 000040 .000122 .000140 .000368 .000240 .000610 000041 .000125 .000141 .000370 .000241 .000614 000042 .000129 .000142 .000373 .000242 .000617 000043 .000133 .000143 .000377 .000243 .000621 000044 .000137 .000143 .000373 .000244 .000625 000045 .000141 .000145 .000385 .000244 .000625 000045 .000141 .000145 .000389 .000246 .000633 000040 .000152 .000150 .000399 .000247 .000640 000051 .000152 .000150 .000400 .000251 .000644 000052< | | - | 1 - | • | | | .000332 | .000831 | | 000035 .000110 .000135 .000384 .000235 .000598 000036 .000114 .000136 .000388 .000236 .000602 000037 .000118 .000137 .000362 .000237 .00066 000040 .000122 .000141 .000370 .000241 .000610 000041 .000129 .000141 .000377 .000242 .000617 000043 .000133 .000143 .000377 .000243 .000621 000044 .000137 .000144 .000185 .000245 .000625 000045 .000141 .000145 .000385 .000245 .000629 000046 .000141 .000146 .000389 .000246 .000633 000050 .000152 .000150 .000396 .000250 .000640 000051 .000156 .000151 .000400 .000251 .000644 000052 .000160 .000152 .000404 .000255 .000648 000055 </td <td></td> <td></td> <td></td> <td>-</td> <td>_</td> <td></td> <td>.000333</td> <td>.000835</td> | | | | - | _ | | .000333 | .000835 | | 000036 .000114 .000136 .00038 .000336 .000602 000037 .000118 .000137 .000362 .000237 .000606 000040 .000122 .000140 .000366 .000240 .000610 000041 .000125 .000141 .000373 .000242 .000617 000043 .000133 .000144 .000381 .000244 .000625 000044 .000137 .000144 .000385 .000245 .000629 000046 .000141 .000146 .000385 .000246 .000633 000047 .000148 .000147 .000389 .000246 .000637 000050 .000152 .000150 .000386 .000250 .000640 000051 .000156 .000151 .000400 .000251 .000648 000052 .000166 .000153 .000408 .000252 .000648 000053 .000167 .000153 .000408 .000252 .000656 000054 </td <td></td> <td></td> <td>i</td> <td>•</td> <td></td> <td></td> <td>.000334</td> <td>. 000839</td> | | | i | • | | | .000334 | . 000839 | | 0000037 .000118 .000137 .000362 .000237 .000606 000040 .000122 .000140 .000366 .000240 .000610 000041 .000125 .000141 .000373 .000241 .000617 000042 .000133 .000143 .000377 .000243 .000621 000044 .000137 .000144 .000381 .000244 .000625 000045 .000141 .000145 .000385 .000245 .000629 000046 .000144 .000146 .000389 .000246 .000633 000047 .000148 .000147 .000396 .000250 .000640 000051 .000152 .000150 .000396 .000251 .000644 000052 .000160 .000152 .000400 .000251 .000644 000052 .000160 .000153 .000408 .000253 .000652 000053 .000167 .000154 .000411 .000255 .000659 000056 | | | | | 1 | | . 000335 | . 000843 | | 000040 .000122 .000140 .000366 .000240 .000610 000041 .000125 .000141 .000370 .000241 .000614 000042 .000133 .000142 .000373 .000242 .000621 000044 .000137 .000144 .000381 .000244 .000625 000045 .000141 .000145 .000385 .000245 .000629 000046 .000144 .000146 .000389 .000246 .000633 000047 .000148 .000147 .000392 .000247 .000637 000050 .000152 .000150 .000396 .000250 .000644 000051 .000156 .000151 .000400 .000251 .000644 000052 .000160 .000152 .000404 .000252 .000648 000053 .000164 .000153 .000408 .000253 .000652 000054 .000167 .000154 .000411 .000255 .000656 000055< | | | | | 1 | - | . 000336 | .000846 | | 000041 .000125 .000141 .000370 .000241 .000614 000042 .000129 .000142 .000373 .000242 .00617 000043 .000133 .000144 .000381 .000244 .00625 000044 .000141 .000145 .000385 .000245 .00629 000046 .000141 .000146 .000389 .000246 .00633 000047 .000148 .000147 .000392 .000247 .00637 000050 .000152 .000150 .000396 .000250 .00640 000051 .000156 .000151 .000400 .000251 .00644 000052 .000160 .000152 .000404 .000252 .00648 000053 .000164 .000153 .000408 .000253 .00652 000054 .000167 .000153 .000408 .000253 .00652 000055 .000167 .000154 .000411 .000255 .000659 000056 | | | .000137 | . 000362 | .000237 | .000606 | . 000337 | .000850 | | 000042 .000129 .000142 .000373 .000242 .000617 000043 .000133 .000143 .000377 .000243 .000621 000044 .000137 .000144 .000381 .000244 .000629 000045 .000141 .000145 .000385 .000245 .000629 000047 .000148 .000147 .000392 .000247 .000637 000050 .000152 .000150 .000396 .000250 .000640 000051 .000156 .000151 .000400 .000251 .000644 000052 .000160 .000153 .000404 .000253 .000652 000053 .000164 .000153 .000408 .000253 .000652 000054 .000167 .000154 .000411 .000254 .000656 000055 .000171 .000155 .000415 .000255 .000659 000056 .000175 .000156 .000419 .000256 .000667 000057< | 00040 | .000122 | .000140 | .000366 | .000240 | .000610 | .000340 | .000854 | | 0000043 .000133 .000143 .000377 .000243 .000621 000044 .000137 .000144 .000381 .000244 .000625 000046 .000141 .000145 .000385 .000245 .000629 000047 .000148 .000147 .000399 .000247 .000637 000050 .000152 .000150 .000396 .000250 .000640 000051 .000156 .000151 .000400 .000251 .000644 000052 .000160 .000152 .000404 .000252 .000648 000053 .000164 .000153 .000408 .000253 .000652 000054 .000167 .000154 .000411 .000254 .000656 000055 .000171 .000155 .000415 .000255 .000659 000055 .000171 .000156 .000419 .000256 .000667 000060 .000179 .000157 .000423 .000257 .000667 000061 | 00041 | .000125 | .000141 | .000370 | .000241 | .000614 | .000341 | .000858 | | 000044 .000137 .000144 .000381 .000244 .000625 000045 .000141 .000145 .000385 .000245 .000629 000046 .000144 .000146 .000389 .000246 .000637 000050 .000152 .000150 .000396 .000250 .000640 000051 .000156 .000151 .000400 .000251 .000644 000052 .000160 .000152 .000404 .000252 .000648 000053 .000164 .000153 .000408 .000253 .000652 000054 .000167 .000154 .000411 .000254 .000656 000055 .000171 .000155 .000415 .000255 .000663 000057 .000179 .000157 .000423 .000255 .000667 000060 .000183 .000160 .000427 .000260 .000671 000061 .000186 .000161 .000431 .000261 .000675 000062< | 00042 | .000129 | .000142 | .000373 | .000242 | .000617 | .000342 | .000862 | | 000045 .000141 .000145 .000385 .000245 .000629 000046 .000144 .000146 .000389 .000246 .000633 000047 .000152 .000150 .000396 .000250 .000640 000051 .000158 .000151 .000400 .000251 .000644 000052 .000160 .000152 .000404 .000252 .000648 000053 .000164 .000153 .000408 .000253 .000652 000054 .000167 .000154 .000411 .000254 .000656 000055 .000171 .000155 .000415 .000255 .000659 000055 .000171 .000156 .000419 .000255 .000669 000057 .000179 .000157 .000423 .000257 .000667 000060 .000183 .000160 .000427 .000260 .000671 000061 .000186 .000161 .000431 .000261 .000675 000062< | 00043 | .000133 | .000143 | .000377 | .000243 | .000621 | .000343 | .000865 | | 000045 .000141 .000145 .000385 .000245 .000629 000046 .000144 .000146 .000389 .000246 .000633 000047 .000182 .000150 .000396 .000250 .000640 000051 .000156 .000151 .000400 .000251 .000644 000052 .000160 .000152 .000404 .000252 .000648 000053 .000164 .000153 .000408 .000253 .000652 000054 .000167 .000154 .000411 .000253 .000656 000055 .000171 .000155 .000415 .000255 .000659 000056 .000173 .000156 .000419 .000255 .000663 000057 .000179 .000157 .000423 .000257 .000667 000060 .000183 .000160 .000427 .000260 .000671 000061 .000186 .000161 .000431 .000261 .000679 000062< | 00044 | .000137 | .000144 | .000381 | .000244 | . 000625 | .000344 | .000869 | | 000046 .000144 .000146 .000389 .000246 .000633 000047 .000148 .000147 .000392 .000247 .000637 000050 .000152 .000150 .000396 .000250 .000640 000051 .000158 .000151 .000400 .000251 .000644 000052 .000160 .000153 .000408 .000253 .000652 000053 .000164 .000153 .000408 .000253 .000652 000054 .000167 .000154 .000411 .000254 .000656 000055 .000171 .000155 .000415 .000255 .000659 000056 .000175 .000156 .000419 .000256 .000663 000057 .000179 .000157 .000423 .000257 .000667 000060 .000183 .000160 .000427 .000260 .000675 000061 .000186 .000161 .000434 .000262 .000679 000062< | 00045 | .000141 | .000145 | .000385 | - | | .000345 | .000873 | | 000047 .000148 .000147 .000392 .000247 .000637 000050 .000152 .000150 .000396 .000250 .000640 000051 .000156 .000151 .000400 .000251 .000644 000052 .000160 .000152 .000404 .000252 .000648 000053 .000164 .000153 .000408 .000253 .000652 000054 .000167 .000154 .000411 .000254 .000656 000055 .000171 .000155 .000415 .000255 .000659 000056 .000175 .000156 .000419 .000256 .000663 000057 .000179 .000157 .000423 .000256 .000667 000060 .000183 .000160 .000427 .000260 .000675 000061 .000186 .000161 .000431 .000262 .000679 000062 .000190 .000162 .000438 .000263 .000682 000064< | 00046 | .000144 | | . 000389 | | | .000346 | .000877 | | 000050 .000152 .000150 .000396 .000250 .000640 000051 .000156 .000151 .000400 .000251 .000644 000052 .000160 .000152 .000404 .000252 .000648 000053 .000164 .000153 .000408 .000253 .000652 000054 .000167 .000154 .000411 .000254 .000656 000055 .000171 .000155 .000415 .000255 .000659 000058 .000175 .000156 .000419 .000256 .000663 000057 .000179 .000157 .000427 .000260 .000671 000060 .000183 .000160 .00427 .000260 .000671 000061 .000186 .000161 .000431 .000261 .000675 000062 .000190 .000162 .000434 .000262 .000679 000063 .000194 .000163 .000438 .000263 .000682 000064 </td <td>00047</td> <td>.000148</td> <td></td> <td></td> <td></td> <td></td> <td>.000347</td> <td>.000881</td> | 00047 | .000148 | | | | | .000347 | .000881 | | 000051 .000156 .000151 .000400 .000251 .000644 000052 .000160 .000152 .000404 .000252 .000648 000053 .000164 .000153 .000408 .000253 .000652 000054 .000167 .000155 .000411 .000254 .000656 000055 .000171 .000155 .000415 .000255 .000659 000056 .000175 .000156 .000419 .000256 .000663 000057 .000179 .000157 .000423 .000257 .000667 000060 .000183 .000160 .000427 .000260 .00671 000061 .000186 .000161 .000431 .000261 .000675 000062 .000190 .000162 .000434 .000262 .000679 000063 .000194 .000163 .000438 .000263 .000682 000064 .000198 .000164 .000442 .000264 .000686 000065 </td <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> | | | | | | | | | | 000052 .000160 .000152 .000404 .000252 .000648 000053 .000164 .000153 .000408 .000253 .000652 000054 .000167 .000154 .000411 .000254 .000656 000055 .000171 .000155 .000415 .000255 .000669 000056 .000175 .000156 .000419 .000256 .000663 000057 .000179 .000157 .000423 .000257 .000667 000060 .000183 .000160 .000427 .000260 .000675 000061 .000186 .000161 .000431 .000261 .000675 000062 .000190 .000162 .000434 .000263 .000682 000063 .000194 .000163 .000438 .000263 .000682 000064 .000198 .000164 .000442 .000264 .000686 000065 .000202 .000165 .000450 .000266 .000699 000066< | | | I | - | | • | .000350 | .000885 | | 000053 .000164 .000153 .000408 .000253 .000652 000054 .000167 .000154 .000411 .000254 .000656 000055 .000171 .000155 .000415 .000255 .000659 000056 .000175 .000156 .000419 .000256 .000663 000057 .000179 .000157 .000423 .000257 .000667 000060 .000183 .000160 .000427 .000260 .000671 000061 .000186 .000161 .000431 .000261 .000675 000062 .000190 .000162 .000434 .000262 .000679 000063 .000194 .000163 .000438 .000263 .000682 000064 .000198 .000164 .000442 .000264 .000686 000065 .000202 .000165 .000446 .000265 .000690 000066 .000205 .000166 .000453 .000267 .000698 000070< | | | | - | _ | | .000351 | .000888 | | 000054 .000167 .000154 .000411 .000254 .000656 000055 .000171 .000155 .000415 .000255 .000659 000056 .000175 .000156 .000419 .000256 .00063 000057 .000179 .000157 .000423 .000257 .000667 000060 .000183 .000160 .000427 .000260 .000671 000061 .000186 .000161 .000431 .000261 .000675 000062 .000190 .000162 .000434 .000262 .000679 000063 .000194 .000163 .000438 .000263 .000682 000064 .000198 .000164 .000442 .000264 .000686 000065 .000202 .000165 .000446 .000265 .000690 000066 .000205 .000166 .000453 .000266 .000694 000070 .000213 .000170 .000457 .000270 .000701 000071 </td <td></td> <td>•</td> <td></td> <td></td> <td>-</td> <td>• • • • • • • • • • • • • • • • • • • •</td> <td>.000352</td> <td>.000892</td> | | • | | | - | • • • • • • • • • • • • • • • • • • • • | .000352 | .000892 | | 000055 .000171 .000155 .000415 .000255 .000659 000056 .000175 .000156 .000419 .000256 .000663 000057 .000179 .000157 .000423 .000257 .000667 000060 .000183 .000160 .000427 .000260 .000671 000061 .000186 .000161 .000431 .000261 .000675 000062 .000190 .000162 .000434 .000262 .000679 000063 .000194 .000163 .000438 .000263 .000682 000064 .000198 .000164 .000442 .000264 .000686 000065 .000202 .000165 .000446 .000265 .000690 000066 .000205 .000166 .000450 .000266 .000694 000070 .000213 .000170 .000457 .000270 .000701 00071 .000217 .000171 .000465 .000272 .000709 .00072 </td <td></td> <td></td> <td>-</td> <td>-</td> <td></td> <td></td> <td>. 000353</td> <td>.000896</td> | | | - | - | | | . 000353 | .000896 | | 000056 .000175 .000156 .000419 .000256 .000663 000057 .000179 .000157 .000423 .000257 .000667 000060 .000183 .000160 .000427 .000260 .000671 000061 .000186 .000161 .000431 .000261 .000675 000062 .000190 .000162 .000434 .000262 .000679 000063 .000194 .000163 .000438 .000263 .000682 000064 .000198 .000164 .000442 .000264 .000686 000065 .000202 .000165 .000446 .000265 .000690 000066 .000205 .000166 .000450 .000266 .000694 000070 .000213 .000170 .000457 .000270 .000701 00071 .000217 .000171 .000465 .000272 .000709 .00072 .000225 .000172 .000465 .000272 .000709 .00072 </td <td></td> <td></td> <td>i .</td> <td>-</td> <td></td> <td></td> <td>.000354</td> <td>.000900</td> | | | i . | - | | | .000354 | .000900 | | 000057 .000179 .000157 .000423 .000257 .000667 000060 .000183 .000160 .000427 .000260 .000671 000061 .000186 .000161 .000431 .000261 .000675 000062 .000190 .000162 .000434 .000262 .000679 000063 .000194 .000163 .000438 .000263 .000682 000064 .000198 .000164 .000442 .000264 .000686 000065 .000202 .000165 .000446 .000265 .000690 000066 .000205 .000166 .000450 .000266 .000694 00007 .000209 .000167 .000453 .000267 .00698 00070 .000213 .000170 .000457 .000270 .000701 .00071 .000217 .000171 .000461 .000271 .000705 .00072 .000221 .000172 .000465 .000272 .000709 .00073 <td></td> <td></td> <td>B .</td> <td>•</td> <td></td> <td></td> <td>.000355</td> <td>.000904</td> | | | B . | • | | | .000355 | .000904 | | 000060 .000183 .000160 .000427 .000260 .000671 000061 .000186 .000161 .000431 .000261 .000675 000062 .000190 .000162 .000434 .000262 .000679 000063 .000194 .000163 .000438 .000263 .000682 000064 .000198 .000164 .000442 .000264 .000686 000065 .000202 .000165 .000446 .000265 .000690 000066 .000205 .000166 .000450 .000266 .000694 00007 .000209 .000167 .000453 .000267 .000698 00070 .000213 .000170 .000457 .000270 .000701 00071 .000217 .000171 .000461 .000271 .000705 00072 .000221 .000172 .000465 .000272 .000709 00073 .000255 .000173 .000469 .000273 .000713 | | | | | | · · · · · · · · · · · · · · · · · · · | . 000356 | .000907 | | 00061 .000186 .000181 .000431 .000261 .000675 00062 .000190 .000162 .000434 .000262 .000679 00063 .000194 .000163 .000438 .000263 .000682 00064 .000198 .000164 .000442 .000264 .000686 00055 .000202 .000165 .000450 .000265 .000690 00066 .000205 .000166 .000450 .000266 .000694 00067 .000209 .000167 .000453 .000267 .000698 00070 .000213 .000170 .000457 .000270 .000701 00071 .000217 .000171 .000461 .000271 .000705 00072 .000221 .000172 .000465 .000272 .000709 00073 .000225 .000173 .000469 .000273 .000713 | | | .000157 | . 000423 | .000257 | . 000667 | .0003 <i>6</i> 7 | .000911 | | 00062 .000190 .000162 .000434 .000262 .000679 00063 .000194 .000163 .000438 .000263 .000682 00064 .000198 .000164 .000442 .000264 .000686 00065 .000202 .000165 .000446 .000265 .000690 00066 .000205 .000166 .000450 .000266 .000694 00067 .000209 .000167 .000453 .000267 .000698 00070 .000213 .000170 .000457 .000270 .000701 00071 .000217 .000171 .000461 .000271 .000705 00072 .000221 .000172 .000465 .000272 .000709 00073 .000255 .000173 .000469 .000273 .000713 | | | .000160 | . 000427 | .000260 | ,000671 | .000360 | .000915 | | 000062 .000190 .000162 .000434 .000262 .000679 00063 .000194 .000163 .000438 .000263 .000682 00064 .000198 .000164 .000442 .000264 .000686 000565 .000202 .000165 .000450 .000265 .000690 00066 .000205 .000166 .000450 .000266 .000694 00067 .000209 .000167 .000453 .000267 .000698 00070 .000213 .000170 .000457 .000270 .000701 00071 .000217 .000171 .000461 .000271 .000705 00072 .000221 .000172 .000465 .000272 .000709 00073 .000255 .000173 .000469 .000273 .000713 | 00061 | .000186 | .000161 | .000431 | .000261 | . 000675 | .000361 | .000919 | | 00063 .000194 .000163 .000438 .000263 .000682 00064 .000198 .000164 .000442 .000264 .000686 00065 .000202 .000165 .000446 .000265 .000690 00066 .000205 .000166 .000450 .000266 .000694 00067 .000209 .000167 .000453 .000267 .000698 00070 .000213 .000170 .000457 .000270 .000701 00071 .000217 .000171 .000461 .000271 .000705 00072 .000221 .000172 .000465 .000272 .000709 00073 .000225 .000173 .000469 .000273 .000713 | 00062 | .000190 | .000162 | .000434 | | | .000362 | .000923 | | 00064 .000198 .000164 .000442 .000264 .000866 00065 .000202 .000165 .000446 .000265 .000690 00066 .000205 .000166 .000450 .000266 .000694 00070 .000209 .000170 .000453 .000267 .000698 00070 .000213 .000170 .000457 .000270 .000701 00071 .000217 .000171 .000461 .000271 .000705 00072 .000221 .000172 .000465 .000272 .000709 00073 .000225 .000173 .000469 .000273 .000713 | 00063 | .000194 | .000163 | .000438 | | · 1 | .000363 | .000926 | | 00065 .000202 .000165 .000446 .000265 .000690 00066 .000205 .000166 .000450 .000266 .000694 00067 .000209 .000167 .000453 .000267 .000698 00070 .000213 .000170 .000457 .000270 .000701 00071 .000217 .000171 .000461 .000271 .000705 00072 .000221 .000172 .000465 .000272 .000709 00073 .000225 .000173 .000469 .000273 .000713 | 00064 | .000198 | | | | | .000364 | ,000930 | | 00066 .000205 .000166 .000450 .000266 .000694 00067 .000209 .000167 .000453 .000267 .000698 00070 .000213 .000170 .000457 .000270 .000701 00071 .000217 .000171 .000461 .000271 .000705 00072 .000221 .000172 .000465 .000272 .000709 00073 .000225 .000173 .000469 .000273 .000713 | | | | - | | | . 000365 | .000934 | | 00067 .000209 .000167 .000453 .000267 .000698 00070 .000213 .000170 .000457 .000270 .000701 00071 .000217 .000171 .000461 .000271 .000705 00072 .000221 .000172 .000465 .000272 .000709 00073 .000255 .000173 .000469 .000273 .000713 | | | | | | | .000366 | .000938 | | 00070 .000213 .000170 .000457 .000270 .000701 00071 .000217 .000171 .000461 .000271 .000705 00072 .000221 .000172 .000465 .000272 .000709 00073 .000225 .000173 .000469 .000273 .000713 | | | | | | | . 000367 | .000942 | | 00071 .000217 .000171 .000461 .000271 .000705 00072 .000221 .000172 .000465 .000272 .000709 00073 .000225 .000173 .000469 .000273 .000713 | | | | | | | .000370 | .000946 | | 00072 .000221 .000172 .000465 .000272 .000709 00073 .000225 .000173 .000469 .000273 .000713 | | | 1 | | - | - 1 | | • | | 00073 .000225 .000173 .000469 .000273 .000713 | | | | · | | | .000371 | .000949 | | | | | - | | - | 1 | .000372 | .000953 | | | | | - | - | | | .000373 | .000957 | | 00074 .000228 .000174 .000473 .000274 .000717 | | | | | | L. | .000374 | .000961 | | 00075 .000232 .000175 .000476 .000275 .000720 | - | | | • | | | . 000375 | .000965 | | 00076 .000236 .000176 .000480 .000276 .000724 | | | | 1 | | | .000376 | .000968 | | 000077 .000240 .000177 .000484 .000277 .000728 | 10077 | .000240 | .000177 | .000484 | .000277 | .000728 | .000377 | .000972 | # OCTAL-DECIMAL FRACTION CONVERSION TABLE (continued) | OCTAL | DEC. | OCTAL | DEC. | OCTAL | DEC. | OCTAL | DEC. | |--------------------|----------|----------|---------|----------|----------|---------|----------| | .000400 | .000976 | .000500 | .001220 | .000600 | .001464 | .000700 | .001708 | | .000401 | .000980 | .000501 | .001224 | .000601 | .001468 | .000701 | .001712 | | .000402 | .000984 | .000502 | .001228 | .000602 | .001472 | .000702 | .001716 | | .000403 | .000988 | .000503 | .001232 | .000603 | .001476 | .000703 | .001720 | | .000404 | .000991 | .000504 | .001235 | .000604 | .001480 | .000704 | .001724 | | .000405 | .000995 | .000505 | .001239 | . 000605 | .001483 | .000705 | .001728 | | .000406 | .000999 | .000506 | .001243 | .000606 | .001487 | .000706 | | | | | 1 | | | | | .001731 | | .000407 | .001003 | .000507 | .001247 | .000607 | .001491 | .000707 | .001735 | | .000410 | .001007 | .000510 | .001251 | .000610 | .001495 | .000710 | .001739 | | .000411 | .001010 | .000511 | .001255 | .000611 | .001499 | .000711 | .001743 | | .000412 | .001014 | .000512 | .001258 | .000612 | .001502 | .000712 | .001747 | | .000413 | .001018 | .000513 | .001262 | .000613 | .001506 | .000713 | .001750 | | .000414 | .001022 | .000514 | .001266 | .000614 | .001510 | .000714 | .001754 | | .000415 | .001026 | .000515 | .001270 | . 000615 | .001514 | .000715 | .001758 | | .000416 | .001029 | .000516 | .001274 | .000616 | .001518 | .000716 | .001762 | | | | | | 1 | | 1 | | | .000417 | .001033 | .000517 | .001277 | .000617 | .001522 | .000717 | .001766 | | .000420 | . 001037 | .000520 | .001281 | .000620 | .001525 | .000720 | .001770 | | .000421 | .001041 | .000521 | .001285 | .000621 | .001529 | .000721 | .001773 | | .000422 | .001045 | .000522 | .001289 | .000622 | .001533 | .000722 | .001777 | | .000423 | .001049 | .000523 | .001293 | .000623 | .001537 | .000723 | .001781 | | .000424 | .001052 | .000524 | .001296 | .000624 | .001541 | .000724 | .001785 | | | • | 1 | | 1 | | 1 | | | .000425 | .001056 | .000525 | .001300 | .000625 | .001544 | .000725 | .001789 | | .000426 | .001060 | .000526 | .001304 | .000626 | .001548 | .000726 | .001792 | | .000427 | .001064 | .000527 | .001308 | .000627 | .001552 | .000727 | .001796 | | .000430 | .001068 | .000530 | .001312 | .000630 | .001556 | .000730 | .001800 | | .000431 | .001071 | .000531 | .001316 | .000631 | .001560 | .000731 | .001804 | | .000432 | .001075 | .000532 | .001319 | .000632 | .001564 | .000732 | .001808 | | .000433 | .001079 | .000533 | .001323 | .000633 | .001567 | .000733 | .001811 | | .000434 | .001083 | .000534 | .001327 | .000634 | .001571 | .000734 | .001815 | | .000435 | | i . | | | | i i | | | • | .001087 | . 000535 | .001331 | .000635 | .001575 | .000735 | .001819 | | .000436 | .001091 | . 000536 | .001335 | .000636 | .001579 | .000736 | .001823 | | .000437 | .001094 | .000537 | .001338 | .000637 | .001583 | .000737 | .001827 | | .000440 | .001098 | .000540 | .001342 | .000640 | .001586 | .000740 | .001831 | | .000441 | .001102 | .000541 | .001346 | .000641 | .001590 | .000741 | .001834 | | .000442 | .001106 | .000542 | .001350 | .000642 | .001594 | .000742 | .001838 | | .000443 | .001110 | .000543 | .001354 | . 000643 | .001598 | .000743 | .001842 | | .000444 | .001113 | .000544 | .001358 | .000644 | .001602 | .000744 | .001846 | | .000445 | | .000545 | .001361 | .000645 | .001605 | .000745 | .001850 | | | .001117 | 1 | | l | | 1 | | | .000446 | .001121 | .000546 | .001365 | .000646 | .001609 | .000746 | .001853 | | .000447 | . 001125 | .000547 | .001369 | .000647 | .001613 | .000747 | .001857 | | .000450 | .001129 | .000550 | .001373 | . 000650 | .001617 | .000750 | .001861 | | .000451 | .001132 | .000551 | .001377 | .000651 | .001621 | .000751 | .001865 | | .000452 | .001136 | .000552 | .001380 | .000652 | .001625 | .000752 | .001869 | | .000453 | .001140 | . 000553 | .001384 | . 000653 | .001628 | .000753 | .001873 | | .000454 | .001144 | .000554 | .001388 | .000654 | .001632 | .000754 | .001876 | | | - | | | | .001632 | .000755 | .001880 | | .000455 | .001148 | .000555 | .001392 | .000655 | | | | | .000456 | .001152 | .000556 | .001396 | .000656 | .001640 | .000756 | .001884 | | .000457 | .001155 | .000557 | .001399 | .000657 | .001644 | .000757 | .001888 | | .000460 | .001159 | .000560 | .001403 | .000660 | .001647 | .000760 | .001892 | | .000461 | .001163 | .000561 | .001407 | .000661 | .001651 | .000761 | .001895 | | .000462 | .001167 | .000562 | .001411 | . 000662 | .001655 | .000762 | .001899 | | .000463 | .001171 | .000563 | .001415 | . 000663 | .001659 | .000763 | .001903 | | .000464 | .001174 | .000564 | .001419 | 000664 | .001663 | .000764 | .001907 | | .000465 | .001178 | .000565 | .001422 | .000665 | .001667 | .000785 | .001911 | | .000466 | .001178 | .000566 | .001426 | .000666 | .001670 | .000766 | .001914 | | | | 1 | | 1 | | 1 | | | .000467 | .001186 | .000567 | .001430 | . 000667 | .001674 | .000767 | .001918 | | .000470 | .001190 | .000570 | .001434 | . 000670 | .001678 | .000770 | .001922 | | .000471 | .001194 | .000571 | .001438 | .000671 | .001682 | .000771 | .001926 | | .000472 | .001197 | .000572 | .001441 | .000672 | .001686 | .000772 | .001930 | | .000473 | .001201 | .000573 | .001445 | .000673 | .001689 | .000773 | .001934 | | .000474 | .001205 | .000574 | .001449 | .000674 | .001693 | .000774 | .001937 | | .000475 | .001209 | .000575 | .001453 | .000675 | .001697 | .000775 | .001941 | | | .001209 | 1 | | | | | | | | . VUIZIA | .000576 | .001457 | .000676 | . 001701 | .000776 | .001945 | | .000476<br>.000477 | .001216 | .000577 | .001461 | .000677 | .001705 | .000777 | . 001949 |