Microcomputer control of machines

Information

  • Patent Grant
  • 4829419
  • Patent Number
    4,829,419
  • Date Filed
    Wednesday, December 14, 1977
    47 years ago
  • Date Issued
    Tuesday, May 9, 1989
    35 years ago
  • Inventors
  • Examiners
    • Ruggiero; Joseph
    Agents
    • Hyatt; Gilbert P.
Abstract
A microcomputer system is provided that facilitates system interaction with a machine. System architecture provides for processing machine inputs and generating machine outputs under microcomputer program control to enhance capability and flexibility and to reduce special purpose interface circuitry. Use of a microcomputer having an integrated circuit read only memory for program storage, an integrated circuit RAM or scratch pad memory for alterable operand storage, and integrated circuit logic enhances cost, performance, reliability, and other considerations.
Description

BACKGROUND OF THE INVENTION
1. Field of the Invention
This invention relates to electronic data processing systems and more particularly to machine control systems.
2. History of the Prior Art
Interaction with a machine in prior art systems is typically performed with special purpose interface logic, even if a computer is available in the system. The computer is typically protected from direct real time interaction with special purpose circuits which receive inputs and generate outputs in real time to relieve the computer of interface tasks that were considered not suited to computer capability.
A further discussion of the prior art is set forth in parent application Ser. No. 101,881 as-amended at page 1 line 29 to page 3 line 29; which discussion is herein incorporated by reference.
SUMMARY OF THE INVENTION
A computer systems architecture is provided where a microcomputer is used for direct interaction with a machine to enhance communication and to reduce special purpose interface circuitry. In a preferred embodiment, the microcomputer monitors machine inputs and interprets the machine information under program control thereby reducing machine interface circuits and the microcomputer packs and outputs machine control information under program control thereby reducing machine control interface circuits.
A computer architecture is provided that can be fully implemented with integrated circuits. An integrated circuit ROM is used for program storage and an integrated circuit scratch pad memory is used for alterable storage of operands. This invention considers that a fully integrated circuit computer may require non-volatile and electrically alterable capability such as provided with prior art core memories. Integrated circuit memories having both non-volatile and alterable capability did not exist at the effective filing date of the instant application. Therefore, a combination of memories is used to overcome the limitations of existing memories. An integrated circuit ROM is used to provide non-volatile storage capability, but the ROM is not able to provide alterable capability. Therefore, an integrated circuit alterable memory is used to provide alterable storage capability even though the storage is volatile. A computer architecture is provided for accessing instructions stored in ROM for processing operands stored in alterable scratch pad memory to utilize the advantages of both memory types and to compensate for the disadvantages of both memory types.
A further summary of the present invention is set forth in parent application Ser. No. 101,881 as-amended at page 4 line 2 to page 6 line 13; which summary is herein incorporated by reference.





BRIEF DESCRIPTION OF THE DRAWINGS
A better understanding of the invention may be had from a consideration of the following detailed description, taken in conjunction with the accompanying drawings, in which:
FIG. 1 is a block diagram representation of a numerical control system in accordance with the invention;
FIG. 2 shows a control panel and display panel making up part of the numerical control system of FIG. 1 comprising FIG. 2A showing a front view of the control panel and display panel, FIG. 2B showing a partly broken away front view of the control and display panel, FIG. 2C showing the interrelation between the control panel and display panel and the data processing system, and FIG. 2D showing the data processor dependent arrangement for refreshing the numeric displays;
FIG. 3 is a block diagram representation of a servo drive shown in FIG. 1;
FIG. 4 is a block diagram representation of the data processor shown in FIG. 1;
FIG. 5 comprising FIGS. 5A and 5B is a micro-operation flow chart for the data processor shown in FIG. 4;
FIG. 6 comprising FIGS. 6A and 6B is a schematic and block diagram representation of the A logic circuit board;
FIG. 7 is a schematic and block diagram representation of the B logic circuit board;
FIG. 8 is a schematic and block diagram representation of the C logic circuit board;
FIG. 9 is a schematic and block diagram representation of the D logic circuit board;
FIG. 10 is a schematic and block diagram representation of the K logic circuit board;
FIG. 11 is a schematic and block diagram representation of the W logic circuit board;
FIG. 12 is a schematic and block diagram representation of the SPM circuit board;
FIG. 13 is a schematic and block diagram representation of the 1FA-1 circuit board;
FIG. 14 is a schematic and block diagram representation of the IFA-2 circuit board and tape reader input arrangement comprising FIGS. 14A and 14B showing the IFA-2 circuit board arrangement, FIG. 14C showing a tape reader input arrangement, FIG. 14D showing tape reader waveforms, FIG. 14E showing a data processor program flow diagram for processing tape reader input signals, and FIG. 14F showing a logical mechanization for processing tape reader input signals;
FIG. 15 is a schematic and block diagram representation of the IFA-3 circuit board comprising FIG. 15A showing the complete IFA-3 circuit board and FIG. 15B showing the control panel signal processing circuits on the IFA-3 circuit board;
FIG. 16 comprising FIGS. 16A and 16B is a schematic and block diagram representation of the servo common board circuit board;
FIG. 17 comprising FIGS. 17A and 17B is a schematic and block diagram representation of the servo channel board circuit board;
FIG. 18 is a schematic and block diagram representation of an error detector shown generally in FIG. 17A;
FIG. 19 is a schematic and block diagram representation of a digital tachometer shown generally in FIG. 17A; and
FIG.20 illustrates the manner in which the separate sheets of drawings of FIGS. 5A and 5B, FIGS. 6A and 6B, FIGS. 14A and 14B, FIGS. 16A and 16B, and FIGS. 17A and 17B are combined for form FIGS. 5, 6, 14, 16 and 17 respectively.





DETAILED DESCRIPTION
Introduction
A computer system in accordance with the present invention is represented in block diagram form in FIG. 1 as a numerical control system 10, including an electronic data processor 12, arranged in accordance with the invention. The specific example referred to here and described hereafter relates to a three-axis controlled milling machine, but it will readily be appreciated that systems in accordance with the invention may be applied to a wide variety of tasks including communication, process control, processing of business data and other control operations such as photo-optical pattern generators and multi-turret machines.
In accordance with the basic concepts of a factored electronics system, the numerical control system (FIG. 1) provides an illustration of this factoring process. The data processor is used in conjunction with the various extremities of the system where some of these extremities are elemental extremities. The data processor has a distributed characteristic, where the raw instruction signals comprised of micro operation and operand address signals are communicated in intrinsic signal form to the interface assembly which is physically distributed and set apart from the data processor 12 and the various extremities that communicate with the data processor through this input-output structure.
The data processor 12 is shown by way of this example to be used in conjunction with a core memory 30. The basic architecture of this data processor will permit an integrated circuit memory, such as a read-only memory (ROM), or a random-access memory (RAM) or flip-flop type memory to be substituted for the core memory 30 to provide a completely integrated circuit computer which might be called a monolithic computer. This monolithic data processor can be implemented on a single integrated circuit chip which can include a read only memory, an alterable memory, and program execution circuitry on the same chip.
The architecture of the computer is oriented towards a factored computer system to permit the data processor to operate in close conjunction with the extremities for this factored computer system. The special organization and instruction repertoire aid in implementing this factored computer system.
The control panel operates with the data processor in a mutually interdependent fashion to yield interactive capability for operator functions.
The photoelectric tape reader 16 is an extremity that inputs part programs to define the part to be cut by the milling machine 24. The real-time non-adapted signal from 19 intrinsic to the tape reader 16 includes not only data but tape reader characteristics caused by photo-optical, electro-mechanical, and electric effects that are inherent to the tape reader, described in the referenced application A Method And Apparatus For Processing The Digital Output Of An Input Means Ser. No. 879,293 filed on Nov. 24, 1969. The data processor accepts these instrinsic signal forms directly from the tape reader and derives the required data from the ambiguity and errors present in this intrinsic signal form.
The milling machine 24 is an extremity of the system which can be implemented as an elemental extremity in conjunction with the data processor. Direct control of the various machine functions, such as storing the tool positions, compensating for tool characteristics, and controlling a turret motor for tool selection reduce the machine interface that is often implemented with relay logic and other such "magnetics". The machine axes pickoffs in the square-wave servo loop can be used directly by the data processor to derive position, velocity and acceleration information pertaining to the motion of machine axes.
The axes servos 20, 21, and 22 are a typical example of elemental extremities. The communication between the data processor and the axes servos is in a signal form wherein the whole number aspect is intrinsic to the data processor and wherein the square-wave aspect is intrinsic to the axes servos. This intrinsic signal form simplifies the communication interface between the data processor and the axes servos and relieves limitations previously imposed on servos for numerically controlled machines.
The operative dispersion associated with this factored computer system is typified by the multi-axes contouring capability of the system. The data processor performs the contouring computations in whole number form intrinsic to the data processor and generates the resultant whole number commands for the axes servos. The operative dispersion provides extremely high levels of performance with a significant reduction in hardware and a reduction in the computational burden placed on the data processor. The intrinsic signal forms of the servos have a whole-number square-wave characteristic that is acceptable to the data processor in a non-adapted form to provide interactive communication between the data processor and the axes servos to provide adaptive control capability with this elemental extremity. The axes servos illustrate an elemental extremity that can yield a high level of economy and versatility with a reduced burden on the data processor together with the additional capability of adaptive control.
The present invention more particularly incorporates the normal computer functions of controlling, performing mathematical computations, and storing data into a physically distributed, operatively dispersed system providing concurrent internal control of coation with associated extremities.
The substantially direct communication between the computer and the extremities permits the reduction or elimination of interface logic and interface controllers required in prior art systems.
Specific data processor features include an adaptive memory control power interrupt technique preventing detrimental system operation and a memory protect technique creating inalterable fields in an electrically alterable memory. Functional modifiers permit shortened program instructions without sacrifice of program capability or flexibility.
One technical area in which systems in accordance with the invention have particlular advantage is in the control of multi-axis machine tools and the control of photo-optical plotters to provide output products. Other areas of particular advantage include the processing of communications and business data, for instance, payroll processing and inventory control. In all of these applications the system can receive rudimentary data in real-time intrinsic signal form from an elemental extremity such as an axis servo, process the nonadapted intrinsic signals, and provide data to the system. The system in turn commands an output device in a signal form which may be readily usable by or intrinsic to the output device, such as a servo system. Use of the physical distribution and operative dispersion of the system in conjunction with processor-dependent elemental extremities operating in nonadapted language modes permit great versatility to be attained with low manufacturing cost. Furthermore, orientation of the system to a different class of tasks involves no significant redesign, but primarily involves changes in the data processor program.
A general-purpose data processor in accordance with this invention may include multiple data and program registers, a random access memory and a scratch pad memory, and nonbuffered, directly coupled input-output lines connected to elemental input-output devices. These elements perform basic or prime functions and are physically distributed at different locations in the system, with operative dispersion making them functionally available throughout the system. This system comprises a numerical control machine, e.g., for three axis controlled milling machine, and closely integrates the operator and other input and output operations into the numerical control tasks. Minimal structure input-output extremities in this particular example comprise an elemental tape reader 16 and operator panels 14 and 18, servos 20, 21, and 22 for independent tool axis control and a passive data display 18. The data processor in real time concurrently monitors these extremities, pre-processes the external manifestations into machine-adaptable or intrinsic data, and generates extremity intrinsic or extremity-adapted extrinsic commands. The data processor concurrently operates under program control to perform the other aspects of the task, including carrying out complex computations for tool path control, generating servo commands for each of the controlled axes, sequencing through the program, providing other machine controls and generating graphical and printed output data if needed.
Part program inputs are provided by a photoelectric punched tape reader having Model No. RRS0304RA, manufactured by Remex Electronics. The manual for this tape reader is TRM-902U and is incorporated herein by reference.
Data and program storage is provided by a core memory 30 which may be commercially available memory having Part No. 909838-A01, manufactured by Electronic Memories, Inc. Electronic Memories Inc. drawings 909811-909819 and 910792 show this memory in detail and are incorporated herein by reference. This is an 8-bit 4096 word core memory which is primarily devoted to program storage. Remaining portions may be used for data storage if desired. In this application, the core memory 30 (CM) may be replaced by a read-only memory (ROM) such as a MOS FET read-only memory sold commecially by General Instruments Corporation of Hicksville, N.Y. or a flip-flop memory.
In a typical, very generalized example of the operation of the system of FIG. 1 for control of a milling machine 24, the data processor 12 accepts part program data from the tape reader 16 and operator inputs from the control panel 14 to commence the computation of servo commands. As the reader 16 and panel 14 are operated, the processor 12 is under program control to monitor the operative states of these devices and pre-processes the rudimentary data itself. Concurrently, and also under program control, the display panel 18 is activated by exciting the passive elements to form desired characters at a flicker-free rate. These time-related monitoring and pre-processing subtask functions concerned with the extremities continue to be carried out as needed as the processor 12 enters into its computational and processing operations concerned with its main task, that of executing the part program in real time. Thereafter, command data is translated into servo commands for the individual servos 20, 21, and 22, in intrinsic servo signal form. Feedback signals in the intrinsic servo format are likewise returned to the processor 12, pre-processed for conversion into the processor base language and utilized in further computations.
Programming of computers is a well-known art and is described in detail in the prior art literature such as PROGRAMMING: AN INTRODUCTION TO COMPUTER LANGUAGES AND TECHNIQUES by Ward Douglas Maurer for Holden Day Inc. (1968); PROGRAMMING FOR DIGITAL COMPUTERS by Joachim Jeenel for McGraw Hill (1959); FUNDAMENTALS OF FLOWCHARTING by Thomas J. Schriber for John Wily and Sons (1969); and ELEMENTS OF COMPUTER PROGRAMMING by Swallow and Price for Holt, Rinehart, and Winston (1965); incorporated herein by reference. The programs to provide data processor operations described hereinafter will be obvious to those skilled in the programming art from the descriptions of these desired operations. Further, coding of programs for use with the particular computer described herein will be obvious to those skilled in the programming art from the description of computer instructions provided hereinafter.
There are profound differences between systems thus arranged and operated and systems of the prior art. In the physical and operational sense, the data processor 12 is a much greater portion of the whole, and the associated units 14, 16, 18, 20, 21 and 22 are extremities of the processor 12. These extremities, which may not be independent in terms of control, are largely directly coupled to the processor 12. Each elemental extremity has certain characteristic relationships to the system, although other differences necessarily exist. Each relies essentially upon the operatively dispersed program capabilities of the processor 12. Each further effectively relies upon the processor 12 for pre-processing of the nonadapted signal forms for interpretation of signals and meaningful time-related data transfer. In this respect, digital buffering, conversion, and signal conditioning operations ordinarily provided by interface logic circuits are also avoided. Furthermore, the processor 12 itself need not be tailored in configuration to cooperate with predetermined interface formats and requirements. In a further respect, the data processor presents data or accepts data in real time from/to system extremities in intrinsic signal forms such that the processor itself can effect the significance of such terms.
Elimination of physical identities are representative of what is herein termed physical distribution, where the processor 12 can be distributed throughout the preponderance of the task-performing system. Yet, by virtue of the operational dispersion of the system and other prime functions, this task-performing system may readily be modified, with a minimum of hardware changes to perform another task. Such change entails the essential modification of the system program, and also modification of the subtask programs and their relation to the task-pertinent program. It should be appreciated that the operative dispersion of the system encompasses and eliminates much of the interface circuitry that is redundant when used in conjunction with a data processor.
For the performance of many tasks, as in the numerical control field, systems in accordance with the invention can utilize a relatively small-scale computer without overloading. Concurrent performance of the subtasks does not in the usual instance result in excessive demands on the processor. To the contrary for numerical control systems, the general-purpose computational capability of the system hereafter described can generally be utilized to perform many functions such as contouring functions.
The data processor 12 is organized to operate in a manner somewhat similar to presently known stored program digital computers. The fundamental theory and technology of such presently known systems are described in Chapter 11 of Digital Computer Design Fundamentals, Yaohan Chu, McGraw-Hill Book Co., Inc. (New York, 1962) incorporated herein by reference.
The data processor 12 is organized to process 8-bit words with most working and storage registers having a 16-bit capacity permitting the storage of two words. Serial transfer of data is used throughout the data processor 12 to minimize the logic and interconnections required.
The data processor 12 includes a 12-bit memory address register (M Register) which defines a memory location being accessed in the main memory 30. A memory data register (D-Register) defines an operand location such as in the scratch pad memory and input/output (I/O) channels. Thirty-two Scratch Pad Memory (SPM) Registers provide convenient intermediate storage, independent of the main memory. A three-bit counter divides the execution of program instructions into word times and a four-bit counter subdivides the word times into bit times, the basic operating intervals.
The data processor operates by executing programmed instructions received from the main memory. When an instruction is received, control logic causes the data processor to progress through a matrix of micro operations, the exact path varying with the instruction being executed. Each micro operation occurs during one of the eight possible word times, 0 thru 7, and performs a micro operation portion of the instruction being executed. Upon completion of the FZ micro operation, the data processor recycles through the matrix including flow diagram paths LIQ and P89; or LIQ, P89, and Y7; or LIQ, FAJ, FAL, FAM, FAN, and FAO; or LIQ, P89, Y7, FAK, FAL, FAM, FAN, and FAO as shown in FIG. 5B to begin execution of the next instruction.
The following description of the system, as will be evident to those skilled in the art, comprises a complete definition of a preferred embodiment in accordance with the invention. In order to simplify the description and drawings, extensive use has been made of logical equations, which per se are definitive of detailed circuit elements and interconnections for a specific system, in accordance with modern integrated circuit techniques and is well known to those skilled in the art. In order to simplify the description, extensive and orderly reference is made to principal micro operations, both in the form of the states of major subsystems at particular points in time during these micro operations as well as in the form of the sequences and purposes of each micro operation. The totality of these principal micro operations completely define the operation of this processor system.
It will also be recognized by those skilled in the art that the description of details of structure and operation of a general-purpose computer system is of necessity extended and complex. For convenience and ease of understanding the following description commences with those units most apparent to and used by an operator.
CONTROL PANEL AND DISPLAY PANEL
A control system for an electronic data processing system minimizes hardwiring and specialized components and circuits and provides bidirectional communication between a data processor within the data processing system and an operator via intermediary binary digital input and output words. A separate aspect is the provision of a master control panel configuration including means for receiving input and output elements having generalized identities, in conjunction with encoder and decoder means interposed in the circuitry and reducing the interconnections between the panel and the data processing system. The control system converts the status of selector switches and momentary switches to signals representing an intermediary input word. The data processor processes and interprets the signals representing the input word and generates appropriate system responses. The data processor also generates and processes intermediary output words having a selected format for controlling lamp displays and segmented elements generating numeric displays. Consequently, the panel and system have relatively few interconnections but the use of generalized terms permits input positions and output displays to have varying and selectable meanings, as determined by the data processing system itself. The interactive control system includes decoders and drivers which illuminate displays in response to the output words. Circuitry is reduced by using a single numeric display register to control illumination of several numeric displays by sequentially illuminating the numeric displays at a flicker-free rate. Each numeric display is excited at a rate of 30 cycles per second, requiring the contents of the numeric display register to be changed at a cyclic rate of 240 cycles per second.
Interactive control systems in accordance with the invention provide bidirectional communication between an operator and a data processing system via intermediary binary digital words. The interactive control system is an elemental extremity of the data processing system, providing unprocessed rudimentary data for a data processor and receiving preprocessed data for control of display illumination from the data processor. This elemental control system is dependent on processor coaction for performance of the task of interactive communication with an operator. The data processor operates under the control of a selected stored program to interpret input words and produce an appropriate system response, and provide output words having an appropriate format.
An elemental panel for use in systems of the type disclosed herein are processor dependent structures having means for receiving panel elements and having circuit conductors for coupling elements, and having electronic means in the conductive paths for signal processing. By this arrangement, uncommitted elements can be added or changed and the significance of given panel positions can be determined at processor option under program control without being previously committed through wired operation. The outputs of operator controllable selector switches and momentary switches are transformed to binary codes for greater efficiency. The coded outputs from the momentary switches may be gated to latches which hold the information until samples by the data processor. Appropriate interlocks and interlock overrides may be used to control the effect of continuous depression of a momentary switch. The binary coded outputs of each selector switch and the combined momentary switch are combined to form a single intermediary input word with each binary coded output occupying a different portion of the word. The word is then sampled and interpreted by the data processor.
A display panel is composed of both lamp displays and numeric displays. Each lamp display driver is connected to a different bit of a lamp display register such that when that bit stores a binary "1" or is "set" the lamp display is lighted. The data processor provides an output word to the lamp display register comprising packed discrete lamp control bits to cause appropriate lamp displays to be lighted.
The numeric display elements may be segmented tubes, Nixie tubes, or similar devices displaying a selected character. A single numeric character display register is used to control all of the numeric displays. Output words are transferred to the numeric display register at a rapid periodic rate. One portion of these words contains a tube (element) select code identifying a particular element and a second part of the word contains a code identifying the character to be displayed. Appropriate decoding logic responsive to the numeric display register causes the appropriate segment drivers of the selected numeric display tube to be activated to display the output character. Each numeric display is then driven in turn to display a selected character. In order to refresh the numeric display at a flicker-free rate of 30 times per second, the processor places a new word in the numeric register at a cyclic rate of 30 times the number of numeric word displays desired each second. Assuming 8 numeric displays, the rate would be 240 times per second and would consume only a small part of the operating time of a modern high speed data processor.
The reduction of direct wiring connections between the interactive control system and the data processing system not only reduces manufacturing costs but provides tremendous versatility for changing system tasks to which the data processing system may be committed. Panel elements are not committed by wired connection to system circuits but are committed under program control of the data processor, providing generalized elements whose significance may be readily changed through changes in the task defining program. System controls and outputs can be varied by merely adding or deleting switches and displays and by changing associated captions in the interactive control system. Corresponding changes in data processor responses are accomplished by making appropriate changes in the stored program.
This invention provides an interactive control system establishing bidirectional communication between an operator and a data processing system. All control and data information passing between an operator and the system passes through an electronic data processor via the medium of intermediary binary digital words.
As shown in FIGS. 1 and 2C an electronic data processing system 10 includes an electronic data processor 12 and an interactive control system 780. In general, the electronic data processing system may be any such system but the full advantages of this invention are best realized when used in conjunction with a system which has been committed or dedicated to a specific task or family or tasks, such as numerical control, payroll, accounting, or inventory control. It will be assumed herein, however, that the electronic data processing system 10 is committed to the task of numerical control of a milling machine.
The interactive control system 780 (FIG. 2C) includes a control panel 13 as well as gates 624 and latches 620 which are physically located on available space of a printed circuit board within the electronic data processor 12 but functionally operate as part of the interactive control system 780.
As shown in FIG. 2B a master panel board 818 supports components and circuits, including a display portion 118 of the control system. The panel board 818 may be a printed circuit board having conventional spaced apart apertures or receptacles 36 (FIG. 2B) on the front side into which selector switches and momentary switches may be inserted. Printed circuit wiring to each of the element positions and a minimal amount of electronic circuitry is mounted on the back of the panel board 818 to facilitate error free communication with the data processor. By placing this circuitry in close proximity to the switches and displays, signal lines are held to a minimum length, thereby minimizing costs and errors.
The elemental nature of system subsystems and the related data processor coaction under program control may be utilized to simplify system setup procedures, thereby minimizing setup time as well as errors. One of the major problems that every user of sophisticated control equipment has is that of familiarizing a new operator with the complex maze of switches, lights and other controls. This is particularly important to a company which has a high turnover of personnel. Even experienced operators, on occasion will neglect to set a switch properly or overlook a procedure which could have a disastrous result.
This control panel provides a means for interactivity between the data processor and an operator. Included in this interactivity is a unique feature which permits the data processor to "lead the operator by the hand" through various operations and procedures the operator must perform for proper machine operation.
For this purpose, an operator's manual may be used in conjunction with the numeric displays on the control panel and a special program in the data processor. The operator's manual is divided into several sections, each pertaining to a particular mode of machine operation. The parameter switch would be set to a specified position defining an interactive system initialization condition. This condition would cause the data processor to sense system conditions and respond under selected program control by causing the numeric displays to display a code number identifying a section in the operator's manual. The operator would look up the number in the operator's manual to identify the machine condition or status and the next step of the procedure to place the system into its desired mode. As each procedural step is taken, a new code number appears, showing whether the last step was properly performed until the system can be started. This permits a totally inexperienced operator to sequentially perform the entire system set up or initialization.
As illustrated in FIG. 2, the control panel 14 and the display panel 18 are mounted in a signal rectangular plane with the display panel 18 occupying the upper portion of the plane and the control panel 14 occupying the lower portion of the plane. The lefthand portion of the display panel 18 is occupied by status indicator lamp displays 33 such as the Cycle On indicator lamp 34 and an error indicator lamp 35. These lamp displays provide feedback to the operator by indicating system modes and conditions. All status indicator lamp displays 33 are enhanced with a special filter to suppress glare and provide an easy to read, aesthetically pleasing presentation. Displays and legends that are not illuminated are obscured beind the filter, simplifying rapid appraisal of system conditions and eliminating the need to mentally separate illuminated displays from non-illuminated but visible displays. Included within the status indicator lamp displays 33 are a bank of troubleshooting lamps such as an error indication lamp 35, which are normally obscured behind the filter, but become flashing displays if a malfunction or error should occur. The righthand portion of the display panel 18 is composed of eight numeric displays 38 which may be used to identify the magnitude of system parameters.
DISPLAY PANEL
As described more fully in copending application "Interactive Control System", Ser. No. 101,449, filed Dec. 28, 1970 by Lee et al, and incorporated herein by reference, each lamp display 33 is driven by a well known lamp driver circuit which is controlled by one bit in a lamp display register. The lamp display register stores an intermediary output word output from the data processor 12 which defines the status of the lamp displays 33. In contrast, the numeric displays 38 are driven sequentially in accordance with an intermediary output word stored in a numeric display register.
The display system may be considered to have physical distribution, operative dispersion, and operates with intrinsic signal forms in accordance with the invention. The operative dispersion of the system permits the elemental processor dependent display panel to operate in conjunction with other elements performing prime functions to accomplish a subtask, the communication of information with an operator.
Each numeric display lamp 38 is excited at a 30 cycle per secondflicker free rate under program control in accordance with information contained within a numeric display register. Since the numeric display register controls the excitation of all eight numeric display tubes 38, its content must change at a cyclic rate of 8.times.30=240 times per second. When an intermediary output word is clocked into the numeric display register, the first three bits select the one of eight lamps to be driven. The remaining bits within the numeric display register select the segments within the driven numeric display which are to be excited. This arrangement affords high versatility with reduced hardware. The operation of each numeric display is under program control and only one numeric display register is needed to drive all eight numeric displays.
The data processor also generates preprocessed intermediary output words having selected formats and transfers them from the A-Register to a numeric display register 798 and a lamp display register 700 through I/O Channel-5 702 and I/O Channel-6 704, respectively. These channels provide bidirectional communication of intermediary output words with the A-Register, permitting previously output words to be returned to the A-Register to check for errors occurring during transmission. The interpretation and processing of intermediary words takes place within the data processor.
The displays include both lamp displays 33 and numeric displays 38. As shown in FIG. 2B both the lamp displays 33 and the numeric displays 38 are mounted on the display subpanel board 814 which is in turn mounted on the mother panel board 818. The lamp displays may be conventional bayonet type lamps and the display subpanel board 18 contains a batch fabricated block of lamp spockets which receive the lamps. These lamp sockets provide the multiple functions of mounting, electrical connection and heat sink. Each lamp may be selectively connected to ground either directly or through a flasher bus. The lamp displays are enhanced with a special filter to suppress glare and provide an easy to read, aesthetically pleasing presentation. Displays and legends that are not illuminated are obscured beind the filter, simplifying rapid appraisal of system conditions and eliminating the need to mentally separate illuminated displays from non-illuminated but visible displays.
The numeric display elements are conventional 9 segment displays capable of displaying all numerical characters and some alphabetic characters. However, the interactive control system has sufficient data capacity to accommodate 13 segment tubes capable of displaying all numeric and alphabetic characters if desired. The eight numeric display elements of this embodiment are mounted horizontally on the display subpanel board 818.
Coupled to the lamp displays 33 are lamp drivers 710 which are coupled to the lamp display register 700. With the exception of a few lamp drivers 710 which are hard-wired to respond to special functions such as over temperature, P/S error, Power on and input hold, each lamp driver responds to a selected bit of an intermediary binary digital output word stored in the lamp display register 700.
As shown in greater detail in FIG. 2D, the implementation of the 8 numeric display elements 38 is considerably more complex than that used for the lamp displays. Because each numeric display element 1008 requires multi-bit control signals a cyclic technique is used to drive all eight numeric display elements 1008 from a single numeric display register 798, thereby greatly reducing the amount of circuitry required. To accomplish this the eight numeric display elements are sequentially excited at a flicker-free 30 cps rate. In order to excite each numeric display element 1008 at a rate of 30 cps the contents of the numeric display register must change at a cyclic rate of 240 cps.
The numeric display functions are performed in the data processor 12 under program control and include the numeric display counter 718, the update control, the refresh control, and the data registers. These functions are not physically identifiable, but are implemented under program control of the data processor. The display parameter is converted from a binary to a BCD code, then modified for the special segment code requirements of the numeric display tube. The tube identification code is packed into the word, which is output to the numeric display register in the interactive control system.
In order to excite one of the numeric display elements 1008 the data processor 12 utilizes the count of the numeric display counter 718 implemented under program control, for example, binary 3 indicating that the third numeric display element 1014 is to be excited, to access a location in the memory 30 storing information to excite the third numeric display with the proper character. This information is transferred from the memory 30 to a least significant portion of the A-Register 108 where it is joined by the binary count from the numeric display counter parameter (3) stored in memory in the most significant portion to form the intermediary digital output word.
This output word is transferred from the A-Register 108 through I/O Channel-5 702 to the numeric display register 798. As the word is output the numeric display counter is incremented so that the fourth numeric display element will be excited next. In addition to providing intermediary output words to the numeric display register at a rate of 240 cps, the data processor also updates the locations in the memory 30 which store the information determining the character to be displayed by each numeric display element. This updating occurs at a cyclic rate of 16 cps or twice per second for each memory location. This is about as fast as the eye of the operator can follow changes in the characters displayed by the numeric display elements 1008.
The contents of the three numeric display select bits in the most significant portion of the numeric display register 798 are communicated by three pairs of lines, each pair representing the Q and Q outputs from a flip-flop, to a decoder 716. The decoder activates one of eight select drivers 719, the third select driver in this instance. Simultaneously, nine segment drivers 721 are selectively excited according to the character information stored in the least significant portion of the word in the numeric display register 798, each driver being responsive to a different bit. In some circumstances, it may be desirable to convert the character information to a binary code, thereby reducing the number of bits required to define a character, but necessitating the use of a decoder between the numeric display register 798 and the segment driver 721. However, such a coded technique is not used in this application.
The segment drivers 721 present drive signals forming the stored character to the appropriate segments of all eight numeric display elements 1008. However, only the third numeric display element 1014, which receives a select signal from the select drivers 719, displays the selected character.
CONTROL PANEL
The control panel, which is also described in coepending application Interactive Control System, Ser. No. 101,449, filed Dec. 28, 1970 by Lee et al, has three selector switches and a plurality of momentary switches as shown in FIG. 2. The three selector switches, a Mode switch 40, a Jog switch 41 and a Parameter switch 42, are multiple position rotary switches. The Mode selector switch 40 defines one of the six operating modes of the system, the Jog switch 41 defines the machine displacement for each jog command executed when in the jog mode, and the Parameter switch 42 defines the parameter to be displayed on the numeric displays 38 and, when in the keyboard mode, defines the address of the parameter to be entered through the keyboard. The remaining switches are momentary switches which maintain contact only so long as they are held down. The Mode selector switch 40 defines the major operating conditions of the system which are: (1) Search, (2) Index, (3) Continuous, (4) Block, (5) Jog, and (6) Keyboard. The Search position of the Mode selector switch permits an operator to identify a desired part program block of commands from a punched tape or from a self-contained parts program memory such as the core member 30, and then initiate an automatic search for that block of commands. A sequence number, which is used to identify the selected block of commands, is entered through a keyboard 44 made up of momentary switches. The number which is entered through the keyboard 44 is displayed on the numeric displays 38 to permit the operator to verify the number which has been entered.
The control panel embodiment shown in FIG. 2A, FIG. 2B, FIG. 2C, FIG. 2D FIG. 15A, and FIG. 15B is discussed din detail in related application Single Chip Integrated Circuit Microcomputer Architecture Ser. No. 860,253 filed on Dec. 14, 1977 by Gilbert P. Hyatt at page 37 line 29 to page 54 line 31 therein, which is herein incorporated by reference.
TAPE READER
Punched tape readers are used extensively to load programs into digital computers and to program many types of special purpose digital equipment, such as numerical controls for machine tools. In a typical photoelectric punched tape reader, the tape is luminated as it passes by the read head assembly and photosensors on the opposite side of the tape optically detect the holes in the tape. As the tape is moved past the read head assembly, the tape characters are sequentially read into the digital equipment, where each tape character is available in parallel form on a number (e.g. eight) of data lines. A sprocket hole (e.g. mechanical, optical, magnetic) is available on the tape, which is normally used to strobe the tape character into the digital equipment. Thus, data is available from the tape in a bit parallel, character serial form, where the bits pertaining to each tape character are available simultaneously and the tape characters are available sequentially.
The tape reader embodiment shown in FIG. 14C, FIG. 14D, FIG. 14E, and FIG. 14F is discussed in detail in related application INTELLIGENT TAPE READER Ser. No. 860,251 filed on Dec. 14, 1977 by Gilbert P. Hyatt at page 59 to page 83 therein, which is herein incorporated by reference.
SERVOS
The servos 20, 21 and 22 may be identical and are described with reference to the servo 20 only. As shown in block diagram form in FIG. 3 and in schematic form in FIG. 17, the servo 20 is able to attain the accuracy of digital control by operating with squarewave or digital signals. A squarewave reference signal 70 is provided with respect to which the phase of the encoded signals are measured. The data processor produces a digital position signal 71 which indicates a commanded servo position. The signal 71 is a completely digital whole word signal produced under program control and having a characteristic defined as an intrinsic signal form. The reference signal 70 and digital position information signal 71 are applied to a digital detector 74 which produces pulse width position difference command signals 75. The reference signal 70 is applied to a rotor of a resolver 78 which is mechanically linked to a machine tool 80 which is being controlled. The stator of the resolver then produces a signal, the phase of which depends upon the position of the rotor as controlled by the machine tool 80. The stator signal passes to an adding, shaping and amplifying circuit 82 which produces a position defining squarewave feedback signal 83 indicating the actual position of the machine tool 80. The position feedback signal is passed to comparator circuits 86 along with the position command signal 75. The comparator circuits 86 produce plus or minus pulse width squarewave signals 87 with the duration of the positive portion of the signals indicating the difference between the commanded position and the actual position. A digital-to-amplitude converter 88 converts this signal to a servo control error signal 89 which is presented to one side of a summing resistor 90A.
The digital-to-amplitude converters 88 and 96 (FIGS. 3 and 17) accept pulse width modulated signals 87 and 94, respectively, and provide analog voltages 89 and 97, respectively, proportional to the cuty cycle or width of the input pulses. These converters 88 and 96 are well known to those skilled in the art and may be configured with an analog switch controlled by the pulse width input signal to gate charge into a filter network for the time that the signal is true. The filter network averages this signal with respect to time to provide the analog voltage.
By comparing the half cycle period of the position feedback signal 83 with the half cycle period of the reference signal 70, a digital tachometer 92 produces plus or minus squarewave signals 94 with the duration of the positive portion of the signal indicating velocity. This signal passes to a digital-to-amplitude conveter 96 which produces a velocity feedback signal 97 which is connected to summing resistor 90B. The junction of the summing resistors 90A and 90B is connected to a power amplifier 98 which drives a servo motor 99 to control the position of the machine tool 80. By using this squarewave technique, the servo 20 incorporates the combined accuracy of digital and analog signals with the simplicity of analog signals and is typical of an Elemental Extremity with Intrinsic Signal Form implementation.
DATA PROCESSOR
As shown in FIG. 1, the data processor 12 receives data from the various input sources, performs calculations or otherwise manipulates data in accordance with the input information and outputs processed information to control the milling machine 24 through servos 20, 21, and 22 and auxiliary control signals 26. The data processor is built from series SN7400 integrated circuits manufactured by Texas Instruments, Inc. which are located on a series of printed circuit boards. These printed circuit boards plug into a motherboard which provides necessary interconnections between the terminals of the printed circuit boards.
The architecture of the data processor 12 lends itself to a fully integrated circuit computer mainframe where all of the logic may be implemented with integrated circuits in a conventional manner and additionally includes an integrated circuit scratch pad memory (SPM). Further, this data processor 12 has the architecture to use an integrated circuit read-only memory (ROM) in place of or in addition to a core memory such as for the main memory 30 providing a data processor with the digital portion constructed wholly of integrated circuit components.
In a somewhat simplified block diagram, the data processor 12 is shown in FIG. 4 as control logic 102 interconnecting registers, timers and communication channels. Common signal definitions are provided to permit those knowledgeable in the art to identify the various connections between boards.
The basic timing functions of the data processor 12 are performed by a word timer 104 (FIG. 4) and W.sub.0 -W.sub.2 (FIG. 11) and a bit timer 106 (FIG. 4) and B.sub.0 -B.sub.3 (FIG. 7). The fundamental synchronization of the central processor 12 is provided by an 8 MHz clock signal (FIG. 7) which is included as part of the control logic 102. The synchronizing clock signal is an asymmetric squarewave, the positive portion of which is designated P.sub.3 and the negative portion of which is designated P.sub.3. The asymmetrical character of the clock signal permits a longer clock period for stabilization of propogation delays without sacrifice of processing speed. The word timer 104 (FIG. 4) and W.sub.0 -W.sub.3 (FIG. 11) is a three-bit counter W.sub.0 -W.sub.2 (FIG. 11) with associated decode logic. It counts from 0 to 7 as the data processor cycles through the micro operations during the performance of an instruction with each micro operation being performed in a different word time. The associated decode logic provides eight output lines, each being true during one of the eight different counting states of the word timer 104 (FIG. 4) and W.sub.0 -W.sub.2 (FIG. 11). These output signals are used by the control logic 102 (FIG. 4) including logic gates 230 (FIG. 11) for sequencing the data processor through the micro operations associated with an instruction. The bit timer 106 (FIG. 4) and B.sub.0 -B.sub.3 (FIG. 7) is a four-bit binary counter B.sub.0 -B.sub.3 (FIG. 7) with associated decode logic. The bit timer 106 (FIG. 4) and B.sub.0 -B.sub.3 (FIG. 7) counts down from 15 thru 0 and consequently the associated decode logic 166 (FIG. 7) has 16 output lines B.sub.0 -B.sub.15 (FIG. 7), each going true during a different one of the 16 possible counts of the bit timer 106 (FIG. 4) and B.sub.0 -B.sub.3 (FIG. 7). The bit timer 106 (FIG. 4) and B.sub.0 -B.sub.3 (FIG. 7) provides sequencing and timing within a given micro operation or word time.
An accumulator (A-register) 108 (FIG. 4) and 130 (FIG. 6A) is the basic arithmetic register and is used as the repository of the results of arithmetic and logical operations. It is also the source and destination of the input/output (I/O) parameters. The A-register 108 (FIG. 4) and 130 (FIG. 6A) is a 16-bit serial in serial out shift register. Associated with the A-register 108 (FIG. 4) and 130 (FIG. 6A) is a serial full adder 132 (FIG. 6A) which in FIG. 4 is included within the control logic 102.
A scratch pad memory (SPM) 110 (FIGS. 4 and 12) provides storage for intermediate parameters such as computational results, return addresses, indexes and other pertinent information. The SPM 110 (FIGS. 4 and 12) provides rapid internal storage without the need for transferring data to the main memory 30. It is a group of 32 16-bit serial in, serial out registers which are divided into two pages with 16 registers 234 (FIG. 12) on each page. Paging is accomplished by toggling the I.sub.1 flip-flop (FIG. 13) which is automatically set to page 0 when the power is turned on. When the SPM 110 (FIGS. 4 and 12) is set to page 0, the data processor acts as if page 1 did not exist; and similarly, when the SPM is set to page 1, the data processor acts as if page 0 did not exist. All of the SPM registers can be used for the storage of information, but some of them are primarily associated with specific functions to increase the efficiency of the data processor. The SPM.sub.0 register is automatically assumed and need not be programmed in conjunction with the TX instruction. The SPM.sub.2 register is used for the return address associated with the execution of transfer-type instructions. In addition, the SPM.sub.2 register is used as the intermediate register for operands obtained from the constant memory portion of the main memory. The first eight SPM registers can be used for index or TX instructions in addition to scratch pad operations.
A memory address register (M-register) 112 (FIGS. 4 and 6B) holds the 12-bit address of M.sub.0 Q-M.sub.9 Q, M.sub.10 Q (FIG. 6B) of an eight-bit byte to be accessed from the program memory. The M-register 112 (FIGS. 4 and 6B) is a 12-bit shift register having the capacity to address up to 4,096 different memory locations. It has a serial input M.sub.11 D (FIG. 6B) and both serial and parallel outputs M.sub.0 Q-M.sub.9 Q, M.sub.10 Q and M.sub.11 Q (FIG. 6B). Associated with the M-register 112 (FIG. 4 and 6B) but represented as being within the control logic 102 is a serial full adder 139 (FIG. 6A) which increments the M-register 112 (FIGS. 4 and 6B) to access sequential instructions or, as applicable, the next two bytes of in-line instructions. The M-register 112 (FIGS. 4 and 6B) is incremented by two for a TX instruction when the condition for that transfer is not met, resulting in a skip of two bytes. The M-register 112 (FIGS. 4 and 6B) is incremented by three for a skip on-discrete (SD) instruction. The M-register 112 (FIGS. 4 and 6B) is exchanged with the SPM.sub.2 register for transfer-type instructions and exchanged with a data address register (D-register) 114 (FIG. 4) and 186 (FIG. 9) to access operands from the main memory. The M-register 112 (FIGS. 4 and 6B) is also exchanged with the SPM.sub.2 register at the start of an ST instruction which causes the contents of the A-register 108 (FIG. 4) and 130 (FIG. 6A) to be stored in the main memory when implemented with a core memory.
The data address register (D-register) 114 (FIG. 4) and 186 (FIG. 9) is a 12-bit shift register 186 (FIG. 9) that usually contains an operand address and is used to select: (a) SPM register, (b) I/O channel, and (c) number of shifts, depending upon the type of instruction being executed. The D-register 114 (FIG. 4) and 186 (FIG. 9) has a serial input D.sub.11 (FIG. 9) and serial output D.sub.0 Q (FIG. 9), with the eight least significant bits D.sub.0 Q-D.sub.7 Q (FIG. 9) having parallel outputs in addition.
A C-register 116 (FIG. 4) is composed of six flip-flops designated C.sub.3, C.sub.2, C.sub.1, C.sub.0, K.sub.11, and K.sub.10 (FIG. 8) which store the six most significant bits of an eight-bit instruction byte obtained from program memory. The flip-flops C.sub.3 through K.sub.10 store the instruction bits designated I.sub.7, I.sub.6 (included in the P111 signal), I.sub.5, I.sub.4, I.sub.3 and I.sub.2, respectively as received from the main memory interface lines (I). These instruction bits are held by the C-register 116 (FIGS. 4 and 8) during the performance of an instruction to control the sequence of micro operations executed during the performance of the instruction.
An element designated K-register 118 (FIGS. 4 and 10) is a group of miscellaneous flip-flops for various functions. The K.sub.0, K.sub.1 and K.sub.2 flip-flops (FIG. 10) are used to control sequencing through the micro operations. The K.sub.1 flip-flop is also used to store the sign of the operand in the A-register 108 (FIG. 4) and 130 (FIG. 6A) and the sign of a decremented number during a TX instruction. The K.sub.2 flip-flop is also used to extend the A-register during a shift left operation where the K.sub.2 register acts as the A.sub.-1 stage of the A-register. The K.sub.3, K.sub.4, and K.sub.5 flip-flops (FIG. 10) may be grouped together and designated the KA-register and may be used to store the address of the index. The KA-register is also used as an extension of the A-register during a shift left operation with K.sub.3 as the A.sub.-1 stage, K.sub.4 as the A.sub.-3 stage, and K.sub.5 as the A.sub.-4 stage of the A-register 108 (FIG. 4) and 130 (FIG. 6A). The K.sub.7 flip-flop 138 (FIG. 6A) is used as a carry flip-flop in conjunction with the A-register 108 (FIG. 4) and 130 (FIG. 6A) full adder 132 (FIG. 6A). It is also used in the FK micro operation in the transfer of the D-register 114 (FIG. 4) and 186 (FIG. 9) contents to the M-register 112 (FIGS. 4 and 6B) as a shift left operation to multiply the D-register word address by two to obtain the M-register byte address. The K.sub.8 flip-flop 140 (FIG. 6A) is used as a carry flip-flop in conjunction with the M-register full adder 139 (FIG. 6A). As previously described, the K.sub.10 and K.sub.11 flip-flops 182 and 180 (FIG. 8) form the two least significant bits of the C-register 116 (FIGS. 4 and 8).
An element designated L-register 120 (FIG. 4) is, like the K-register 118 (FIGS. 4 and 10), a group of miscellaneous flip-flops performing control functions. The most significant is the L.sub.1 flip-flop 210 (FIG. 10) which controls turn-on and turn-off of the data processor.
Input/output (I/O) channels 122 (FIGS. 4 and 13) include whole number and discrete channels. The whole number channels connect the A-register 108 (FIG. 4) and 130 (FIG. 6A) with the various entities and extremities. The whole number I/O channels 122 (FIGs. 4 and 13) are arranged in pairs so that as the output from the least significant bit (A.sub.0 Q) (FIGS. 6A and 13) of the A-register 108 (FIG. 4) and 130 (FIG. 6A) shifts information to an output channel (OW) with a corresponding input channel (IW) simultaneously shifting information into the A-register 108 (FIG. 4) and 130 (FIG. 6A) through the input to the most significant bit (A.sub.15 D) (FIG. 6A).
A data path 124 provides two-way communication between the data processor and the main memory. This path carries the main memory address stored in the M-register and transfers operands to or from the main memory.
MICRO-OPERATIONS
The operation of the data processor in carrying out an instruction can best be understood by examining the microoperation flow chart shown in FIG. 5. The small rectangles represent micro-operations in accordance with the letter designation therein and the diamonds represent alternative conditions. If the condition or function contained within a diamond is true, the path designated 1 is taken. Otherwise, the path designated 0 is taken. The micro-operations are arranged in parallel rows according to the word time in which they occur. For instance, the FA, FB and FC micro-operations occur in word time WO, while the row of micro-operations beginning with FD and FK occur during the W1 word time. Each micro-operation consists of one or more bit times to define the number of clock pulses used to execute that micro-operation. The word and bit times are presented with the following description of each micro-operation and summarized in Table V. The circled numbers are provided as references for ease of understanding and discussion.
During the execution of a program instruction, the data processor begins at point 1 at the top center of FIG. 5. The first branch condition is
Y3=C.sub.3 Q.multidot.C.sub.2 Q.multidot.C.sub.1 Q.multidot.C.sub.0 Q.multidot.K.sub.11 Q.multidot.K.sub.10 Q.multidot.I.sub.1 .multidot.I.sub.0
which represents the operation code for a TX instruction. If this term is true, the FC micro-operation is performed; if not true, a second control condition is tested. If flip-flop K.sub.1 is in the 0 state, the FA micro-operation is executed and if it is in the 1 state, the FB micro-operation is executed. In similar fashion, a series of micro-operations are executed in accordance with the programmed instruction until the micro-operation FZ is completed. At this point the power-interrupt flip-flop L.sub.1 determines whether or not the execution of programmed instructions continues to reference point 1. If the L.sub.1 flip-flop is in the 1 state indicating an interrupt, a series of micro-operations is entered which place the return address in SPM.sub.2 and loads the interrupt routine address into the M-register. If the L.sub.1 flip-flop is in the 0 state indicating a non-interrupt condition, the processor returns to point 1 and begins the execution of another program instruction unless an X5 signal indicates that there is an external interrupt. If there is an external interrupt, the data processor ignores it, returning to point 1 unless the interrupt override flip-flop L.sub.3 is true and the flip-flop K.sub.1 is in the false state.
Each micro-operation will now be described in detail including the logical equations (summarized in Table III) which determines whether a micro-operation is true or false, the word time in which it occurs (summarized in Table V), the bit times in each micro-operation (summarized in Table V), a brief written description of the micro-operation, and a shorthand notation of what functional operations are performed by each micro-operation. In describing the micro-operations and throughout this application, a flip-flop or register bit designation followed by a Q indicates an output. If there is no bar over the term, the true or 1 state of the output is indicated; and if there is a bar over the term, the 0 or false state of the output is indicated. Similarly, a flip-flop or register bit designation followed by a D, T. J, or K indicates the input to the designated flip-flop and the flip-flop synchronizing clock pulse input is designated "clock". For instance, the term L.sub.1 T indicates the toggle input to the L.sub.1 flip-flop while the term A.sub.0 Q indicates a 0 or false output from the A.sub.0 bit of the A-register which is the least significant bit. In addition, the following commonly used symbols will be used throughout this application:
______________________________________Symbol Description of Symbol______________________________________( ) Parentheses denote contents of a register.[ ] Square brackets denote a portion of a register, the contents of which has a functional dependence upon a register. Thus I[D] means instruction part of the D-Register. Op[D] means operation part of D-Register. Ad[M] means address part of M-Register. Sn[A] and Mg[A] means sign and magnitude parts of A-Register, respectively.M<A> This symbol denotes a location of a memory word addressed by the A-Register.(M<A>) This symbol denotes the contents of a memory word addressed by the A-Register..fwdarw. Denotes transfer of a word from one register to another. Thus, (A).fwdarw.M means that the contents of the A-Register is transferred to the M-Register. (A).fwdarw.PM<M> means that the contents of the A-Register is transferred to the program memory location addressed by the M-Register.+ This symbol represents a logical-OR operation.. This symbol represents a logical-AND operation.: Colon following a variable (representing a state or the command) denotes the occurrence of the subsequent statement when the value of the variable is 1PM Program (main) memory which may be a core memory or an ROM.SPM Scratch pad memory.______________________________________
A detailed description of each micro-operation follows.
FA=W0.multidot.K.sub.1 Q.multidot.(B15 .multidot.Y3+K.sub.2 Q) The FA micro-operation occurs in the WO word time and has a length of 16 bit times. It is used for all instructions that are not preceded by an index byte nor are TX (decrement and transfer) instructions. The following operations take place during this micro-operation:
(M)+1.fwdarw.M at B11 thru B0 The address in the M-Register is incremented by 1 in the last 12 bit times to eliminate a race, if a ROM is used, with the scanout of the instruction bits (I.sub.i) from the memory instruction register into the D-Register.
Ad[I].fwdarw.D at B15 thru B11
If dynamic MOS-FET type integrated circuits are used, they are refreshed by recirculation at bit times B15 thru B0.
Sn[A].multidot.C.sub.3 Q.fwdarw.K.sub.1 at B0 The A-Register is recirculated to refresh it if MOS-FET type integrated circuits are used and to make the sign bit, which is the most significant bit, available to K.sub.1 in case C.sub.3 Q is true.
0.fwdarw.K.sub.3,K.sub.4,K.sub.5 at B0
0.fwdarw.K.sub.8 at B0 This is the M carry flip-flop which is used to increment the address in the M-Register during this micro-operation and it is reset at B0.
FB=W0.multidot.K.sub.1 Q.multidot.(B15.multidot.Y3+K.sub.2 Q) The FB micro-operation occurs during the W0 word time and has a duration of 16 bit times. It is used for all instructions preceded by an index byte with the exception of the TX (decrement and transfer) instruction. The following operations take place during this micro-operation:
(M)+1.fwdarw.M at B11 thru B0 The address stored in the M-Register is incremented during the last 12 bit times to eliminate a race, if a ROM is used, with the scanout of the contents of the memory instruction register (I) into the D-Register.
Ad[I]+(SPM<K.sub.3,K.sub.4,K.sub.5 >).fwdarw.D at B15 thru B0 This operation clocks the index which was stored in the designated SPM-Register, causing it to be added to the instruction operand address. The sum is loaded into the D-Register.
C.sub.3 Q: Sn[A].fwdarw.K.sub.1 at B0 The A-Register is recirculated to refresh if dynamic MOS-FET type integrated circuits are used and to clock the sign bit of the A-Register, which is the most significant bit, into the K.sub.1 flip-flop.
0.fwdarw.K.sub.3,K.sub.4 at B0
Y2.fwdarw.K.sub.5 at B0 The K.sub.3, K.sub.4 and K.sub.5 flip-flops hold the address of the selected SPM-Register during this micro-operation and are reset at the end. The Y terms are defined in Table II.
0.fwdarw.K.sub.7 at B0 This is the A carry flip-flop which is not used during this micro-operation.
0.fwdarw.K.sub.8 at B0 This is the M carry flip-flop which is used to increment the address stored in the M-Register and is reset at B0.
FC=W0.multidot.(B15.multidot.C.sub.3 Q.multidot.C.sub.2 Q.multidot.C.sub.1 Q.multidot.C.sub.0 Q.multidot.K.sub.11 Q.multidot.K.sub.10 Q.multidot.I.sub.1 I.sub.0 +K.sub.2 Q) The FC micro-operation occurs during the W0 word time and has a duration of 16 bit times. It is used for all TX (decrement and transfer) instructions. The operations executed during this micro-operation are as follows:
(M)+1.fwdarw.M at B11 thru B0 The address in the M-Register is incremented in the last 12 bit times to eliminate a race, if a ROM is used, with the scanout of the instruction bits (I.sub.i) from the memory instruction register into the D-Register.
Ad[I].fwdarw.D at B15 thru B11 The address portion of the memory instruction register (I) is scanned into the D-Register during the last six bit times.
The SPM-Registers are circulated to refresh them if dynamic MOS-FET type integrated circuits are used.
0.fwdarw.K.sub.3,K.sub.4,K.sub.5 at B0 These flip-flops hold the address of the index register during this micro-operation and are reset at B0.
0.fwdarw.K.sub.7 at B0 This is the A-Register carry flip-flop and is reset at B0.
0.fwdarw.K.sub.8 at B0 This is the M-Register carry flip-flop and is reset at B0.
FD=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.W1 The FD micro-operation occurs at word time 1 and has a duration of 12 bit times. It is used for a core memory ST (store) instruction. The operations executed during this micro-operation are as follows:
(SPM<2>).sub.lsb .fwdarw.M at B11 thru B0 The 12 least significant bits of the SPM-2 Register are clocked into the M-Register as these two registers are interchanged.
(M).fwdarw.SPM<2> at B11 thru B0 The contents of the M-Register is clocked into the 12 most significant bit positions of the SPM-2 Register as part of the interchange of these two registers.
(A).sub.lsh .fwdarw.A.sub.msh at B11 thru B4
(A).sub.lsh .fwdarw.D.sub.msb at B11 thru B4
(A).sub.msh .fwdarw.A.sub.lsh at B11 thru B4 During the first eight bit times the A-Register is half circulated, moving the most significant half (msh) to the least significant half (lsh) and the least significant half to the most significant half. At the same time, the contents of the least significant half of the A-Register are transferred to the eight most significant bit positions (msb) of the D-Register.
0,0,0,0.fwdarw.D at B3 thru B0 During the last four bit times, the operand stored in the most significant bit positions of the D-Register are shifted into the least significant bit positions and four zeros are shifted into the D-Register.
FE=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.W2 The FE micro-operation occurs during the W2 word time and has a duration of eight bit times. It is used for a core memory ST (store) instruction. The operations executed within this micro-operation are as follows:
(D).sub.lsb .fwdarw.PM<M> at B7 thru B0
Write Strobe at B7 This write strobe at the beginning of the micro-operation permits the eight least significant bits of the D-Register to be clocked into the memory as they are clocked out of the D-Register.
O.fwdarw.SPM<2> at B7 thru B4 The contents of the M-Register transferred to the most significant bit positions during the FD micro-operation are shifted into the 12 least significant bit positions.
FF=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.W3 The FF micro-operation occurs during the W3 word time and has a duration of 1 bit time. It is used to fill out the word times and no operations take place during this micro-operation.
FG=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.W4 The FG micro-operation occurs during the W4 word time and has a duration of 12 bit times. It is used with a core memory ST (store) instruction and loads the second operand byte into the D-Register while incrementing the M-Register to address the main memory location where the second byte is to be stored. The operations performed within this micro-operation are as follows:
(M)+1.fwdarw.M at B11 thru B0
(A).sub.lsh .fwdarw.A.sub.msh at B11 thru B4 This completes the recirculation of the A-Register begun in the FD micro-operation.
(A).sub.lsh .fwdarw.D.sub.msb at B11 thru B4 As recirculation of the A-Register is completed, the second byte of the operand is recirculated and shifted into the most significant bit positions of the D-Register.
0.fwdarw.D at B3 thru B0 The second byte of the operand is shifted into the eight least significant bit positions and zeros are shifted into the most significant bit positions of the D-Register.
0.fwdarw.K.sub.8 at B0 This is the M carry flip-flop which is reset after the M-Register is incremented.
FH=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.W5 The FH micro-operation occurs during the W5 word time and has a duration of eight bit times. It is a continuation of a core memory ST (store) instruction and places the second byte of the operand into core memory. The operations executed during this micro-operation are as follows:
Write Strobe at B7
(D).sub.lsb .fwdarw.PM<M> at B7 thru B0 Following a Write Strobe, the second byte of the operand is shifted from the D-Register into the location in core memory addressed by the M-Register.
FI=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.W6 The FI micro-operation occurs during the W6 word time and has a duration of eight bit times. It is used to fill out the eight word times of a core memory ST (store) instruction cycle and no functions are executed.
FJ=C.sub.3 Q.multidot.C.sub.2 Q.multidot.(K.sub.4 Q+K.sub.5 Q).multidot.W7 The FJ micro-operation occurs during the W7 word time and has a duration of 12 bit times. This micro-operation sets the necessary control flip-flops to cause the FY or FAP micro-operations to be executed next. The functions executed are:
0001.fwdarw.D.sub.3 D.sub.2 D.sub.1 D.sub.0 at B12 thru B0 This makes Y6 true so that the proper branch will be followed after point 7 on the micro-operation flow chart, FIG. 5.
1.fwdarw.C.sub.2 at B0 This sets the C.sub.3, C.sub.2 flip-flops to the 0, 1 state causing the proper micro-operation flow path to be followed after point 7 on the micro-operation flow chart, FIG. 5.
0.fwdarw.K.sub.1,K.sub.2,K.sub.3,K.sub.4,K.sub.5 at B0
0,0,1.fwdarw.W.sub.2,W.sub.1,W.sub.0 at B0 The word timer is set to word time 1 to cause the next micro-operations executed to be the FAP and FY micro-operations which follow.
FK=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.(B11.multidot.Y1+K.sub.3 Q).multidot.FAI.multidot.Wl The FK micro-operation occurs in the W1 word time and has a duration of 12 bit times. It is used exclusively for the instructions that obtain the operand or transfer address from program memory. This micro-operation is used during the DP, BP, XP, and AP instructions that obtain the operand from the constant memory portion of the program memory. This micro-operation is used to place the operand word address, multiplied by two to provide the operand byte address, in the M-Register and to preserve the next instruction-address in the D-Register. The operations which are executed are as follows:
(D).fwdarw.K.sub.7 at B11 thru B0
(K.sub.7).fwdarw.M at B11 thru B0
(M).fwdarw.D at B11 thru B7 The effect of these three transfers is to exchange the contents of the D- and M-Registers. By shifting the contents of the D-Register indirectly through the K.sub.7 flip-flop to the M-Register, the contents of the M-Register is shifted 1 bit to the left (multiplied by 2) and the most significant bit is stored in the K.sub.7 flip-flop at the end of this micro-operation. This multiplication by 2 converts a word address to a byte address.
FL=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.(B11.multidot.Y1+K.sub.3 Q).multidot.W1 The FL micro-operation occurs in word time 1 and has a duration of 1 bit time. It sets selected flip-flops to control subsequent micro-operations. The operations executed are:
0.fwdarw.K.sub.1 at B0
1.fwdarw.K.sub.3 at B0
Y4.fwdarw.K.sub.4 at B0
FM=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.K.sub.1 Q.multidot.W2 The FM micro-operation occurs at word time 2 and has a duration of 8 bit times. It is used to access a first of the two bytes for the instructions that use the FK or FL micro-operations. The operations executed are as follows:
Read Strobe at B7
(PM>M>).fwdarw.I
Restore Strobe at B3
FN=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.K.sub.1 Q.multidot.W3 The FN micro-operation occurs at word time 3 and has a duration of eight bit times. It causes an eight-bit byte accessed from the program memory in the FM micro-operation to be scanned out of the memory data lines (I) into the SPM-2 Register. The operations executed are as follows:
(I).fwdarw.SPM<2>.sub.msh at B7 thru B0
(SPM>2>.sub.msh).fwdarw.SPM<2>.sub.lsh at B7 thru B0 These steps scan the contents of the I lines into the most significant half of the SPM-2 Register and the most significant half of the SPM-2 Register into the least significant half of the SPM-2 Register.
FO=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.K.sub.1 Q.multidot.W4 The FO micro-operation occurs in word time 4 and has a duration of 12 bit times. It is used to increment the M-Register to permit the second of the two bytes to be accessed from program memory. This operation can be executed simultaneously with the FN micro operation if a core memory is used, but is performed after the FN micro-operation to permit a ROM to be used in place of a core memory. The operations executed are as follows:
(M)+1.fwdarw.M at B11 thru B0
0.fwdarw.K.sub.8 at B0 The M carry flip-flop is used to increment the M-Register and then reset at the end of this micro-operation.
FP=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.K.sub.1 Q.multidot.W5 The FP micro-operation occurs in word time 5 and has a duration of eight bit times. It is used to access the second byte from program memory. The operations executed are as follows:
Read Strobe at B7
(PM>M>).fwdarw.I
Restore Strobe at B3 This micro-operation transfers the second byte into the memory data lines (I) and then restores the information to the memory.
FQ=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.K.sub.1 Q.multidot.W6 This micro-operation occurs in word time 6 and has a duration of eight bit times. The second byte is scanned out of the I lines and into the SPM-2 Register. The operations executed are as follows:
(I).fwdarw.SPM<2>.sub.msh at B7 thru B0
(SPM<2>.sub.msh).fwdarw.SPM<2>.sub.lsh at B7 thru B0 These operations complete the transfer of the two bytes from memory into the SPM-2 Register.
FR=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.K.sub.4 Q.multidot.K.sub.3 Q.multidot.K.sub.1 Q.multidot.W7 The FR micro-operation occurs in word time 7 and has a duration of 12 bit times. It is used to set the proper flip-flops to guide the data processor through subsequent micro-operations in executing the instruction. This operation could be executed simultaneously with the FQ micro-operation if a core memory is used, but is performed after the FQ micro-operation to permit a ROM to be used in place of a core memory. The operations executed are as follows:
0,0,1,0.fwdarw.D at B11 thru B0 A binary 2 is shifted into the least significant bit positions of the D-Register to address the SPM-2 Register which contains the two operand bytes being processed.
1.fwdarw.C.sub.2 at B0
0,0.fwdarw.K.sub.2,K.sub.1 at B0
0,0,0.fwdarw.K.sub.5,K.sub.4,K.sub.3 at B0
FS=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.5 Q.multidot.K.sub.4 Q.multidot.K.sub.3 Q.multidot.K.sub.1 Q.multidot.W7 The FS micro-operation occurs in word time 7 and has a duration of twelve bit times. It is used to set the proper flip-flop to guide the data processor through subsequent micro-operations in executing the instructions.
0,0,1,0.fwdarw.D at B11 thru B0 A binary 2 is shifted into the least significant bit of the D-Register to address the SPM-2 Registers which store the two operand bytes.
1.fwdarw.C.sub.2 at B0
0,0.fwdarw.K.sub.2,K.sub.1 at B0
0,0,0.fwdarw.K.sub.5,K.sub.4,K.sub.3 at B0
FT=Y38.multidot.C.sub.1 Q.multidot.C.sub.0 Q The FT micro-operation occurs in word time 1 and has a duration of 16 bit times. It is used to add the contents of the A-Register to the contents of an SPM-Register addressed by the D-Register which contains an operand and stores the sum in the A-Register. The contents of the SPM-Register are preserved. The executed operations are as follows:
(A)+(SPM<D>).fwdarw.A at B16 thru B0
(SPM<D>).fwdarw.SPM<D> at B16 thru B0
(B0.multidot.C.sub.n+1).fwdarw.K0 at B0 Any overflow from the addition operation is stored in the K.sub.0 flip-flop.
0.fwdarw.K.sub.7 at B0 The A adder carry flip-flop is used during this micro-operation and reset at B0.
FU=Y38.multidot.C.sub.1 Q.multidot.C.sub.0 Q The FU micro-operation occurs at word time 1 and has a duration of 16 bit times. It is used to subtract an operand stored in the SPM-Register from the contents of the A-Register and stores the difference in the A-Register. The contents of the SPM-Register are preserved. Subtraction is implemented by adding the contents of the A-Register to the ones complement of the operand in the SPM-Register and also adding a least significant bit to convert the ones complement to a twos complement number. The executed operations are as follows:
(A)+(SPM<D>)+(1x2.sup.-n).fwdarw.A at B16 thru B0
(B0.multidot.C.sub.n+1).fwdarw.K0 at B0 Store overflow.
0.fwdarw.K.sub.7 at B0 The A adder carry flip-flop is used during this micro-operation and reset upon its completion.
(C.sub.n +1).fwdarw.K.sub.8 at B0 The final carry term is stored in the carry flip-flop for the M adder
FV=Y38.multidot.C.sub.1 Q.multidot.C.sub.0 Q The FV micro-operation occurs in word time 1 and has a duration of 16 bit times. It is used for index instructions to transfer the address of the SPM-Register containing the operand from the D-Register to the K.sub.5, K.sub.4, and K.sub.3 flip-flops. This makes the D-Register available for the operand address of the next instruction. The executed micro-operations are as follows:
1.fwdarw.K.sub.1 at B0 The K.sub.1 flip-flop is one set to identify an index byte. This will insure that the next instruction will be processed through the FB micro operation, which adds the contents of the selected SPM-Register (identified by the contents of the K.sub.5, K.sub.4, and K.sub.3 flip-flops) to the operand address and stores the sum into the D-Register.
(D.sub.2,D.sub.1,D.sub.0).fwdarw.K.sub.5,K.sub.4,K.sub.3 at B0
FW=Y38.multidot.C.sub.1 Q.multidot.C.sub.0 Q.multidot.K.sub.11 Q The FW micro-operation occurs in word time 1 and has a duration of 16 bit times. It is used to perform the logical AND operation between the contents of the A-Register and an operand stored in an addressed SPM-Register. The executed operations are as follows:
(A).multidot.(SPM<D>).fwdarw.A at B15 thru B0
(SPM<D>).fwdarw.SPM<D> at B15 thru B0
FX=Y38.multidot.C.sub.1 Q.multidot.C.sub.0 Q.multidot.K.sub.11 Q The FX micro-operation occurs in word time 1 and has a duration of 16 bit times. It is used to EXCLUSIVE-OR the contents of the A-Register and an operand stored in an addressed SPM-Register and store the results in the A-Register. The contents of the addressed SPM-Register are preserved.
(A).sym.(SPM<D>).fwdarw.A
(SPM<D>).fwdarw.SPM<D>
FY=C.sub.3 Q.multidot.C.sub.2 Q.multidot.C.sub.1 Q.multidot.C.sub.0 Q.multidot.K.sub.11 Q.multidot.K.sub.10 Q.multidot.D.sub.0 Q.multidot.W1 The FY micro-operation occurs in word time 1 and has a duration of 16 bit times. It is used during transfer type instruction. The next instruction address, contained in the SPM-2 Register, is exchanged with the return address from the M-Register. Thus, the next instruction address for the transfer is placed in the M-Register and the return address is placed in the SPM-2 Register. The executed operations are as follows:
(SPM<2>).sub.1sh .fwdarw.M at B15 thru B4
(M).fwdarw.SPM<2>.sub.lsb at B15 thru B4
0.fwdarw.SPM<2>.sub.msb at B3 thru B0
FZ=(C.sub.3 Q+C.sub.2 Q).multidot.W2 The FZ micro-operation occurs in word time 2 and has a duration of eight bit times. It is used to access the next program instruction from the memory. The executed operations are as follows:
Read Strobe at B7
Restore Strobe at B3
Op[I].fwdarw.C at B0
C.sub.3 Q.multidot.L.sub.1 Q.multidot.(K.sub.1 Q+interrupt):0.fwdarw.K.sub.1 at B0
L.sub.1 Q+K.sub.1 Q.multidot.interrupt:1.fwdarw.K.sub.1 at B0
0.fwdarw.K.sub.2 at B0
C.sub.3 Q:0,0,0.fwdarw.K.sub.5,K.sub.4,K.sub.3 at B0
I.sub.3,I.sub.2 .fwdarw.K.sub.11,K.sub.10 at B0
FAB=C.sub.3 Q C.sub.2 Q C.sub.0 Q Wl The FAB micro-operation occurs in word time 1 and has a duration of 16 bit times. The contents of the A-Register are shifted to a selected output channel while the contents of a selected input channel are simultaneously shifted into the A-Register. Executed operations are as follows:
(A).fwdarw.I/O<D> at B15 thru B0
(I/O<D>).fwdarw.A at B15 thru B0
FAC=C.sub.3 Q.multidot.C.sub.2 Q.multidot.C.sub.1 Q.multidot.C.sub.0 Q.multidot.W1 The FAC micro-operation occurs at word time 1 and has a duration of 16 bit times. It is used to store the contents of the A-Register in an addressed SPM-Register. The executed operations are as follows:
(A).fwdarw.SPM<D> at B15 through B0
(A).fwdarw.A at B15 thru B0 The A-Register is recirculated.
Sn[A].fwdarw.K.sub.1 at B0 The sign of the operand stored in the A-Register, which is the most significant bit, is placed in the K.sub.1 flip-flop but not used.
FAD=C.sub.3 Q.multidot.C.sub.2 Q.multidot.C.sub.1 Q.multidot.C.sub.0 Q.multidot.K.sub.11 Q.multidot.W1 The FAC micro-operation occurs in word time 1 and has a duration of 16 bit times. It is used for a shift lift operation on the A-Register and is implemented by extending the least significant portion of the A-Register with flip-flops K.sub.2, K.sub.3, K.sub.4 and K.sub.5. The A-Register is then shifted right for 16 bit times through these extra four flip-flops. The number of shifts left is selected and implemented by recirculating the output from a selected K flip-flop back to the input of the A-Register. This effectively increases the recirculation path by the required number of bit times delays thereby implementing a left shift after the 16 clock pulses. For instance, if the output of the second flip-flop (K.sub.3 Q) is selected, the contents will be shifted left two positions, and if the third flip-flip (K.sub.4) is selected, the output will be shifted left three positions. For the left shift, the sign bit is shifted into the least significant bit of the A-Register by preloading the K.sub.2 -K.sub.5 flip-flops with the sign bit contained in the K.sub.1 flip flop. The executed operations are as follows:
(K.sub.1 Q).fwdarw.K.sub.2 -K.sub.5 at B15
(A.sub.i).fwdarw.A.sub.i -1 at B15 thru B0
(A.sub.0 Q).fwdarw.K.sub.2 at B15 thru B0
(K.sub.2 Q).fwdarw.K.sub.3 at B15 thru B0
(K.sub.3 Q).fwdarw.K.sub.4 at B15 thru B0
(K.sub.4 Q).fwdarw.K.sub.5 at B15 thru B0
D.sub.1 Q,D.sub.0 Q0:(K.sub.2 Q).fwdarw.A at B15 thru B0
D.sub.1 Q,D.sub.0 Q:(K.sub.3 Q).fwdarw.A at B15 thru B0
D.sub.1 Q,D.sub.0 Q:(K.sub.4 Q).fwdarw.A at B15 thru B0
D.sub.1 Q,D.sub.0 Q:(K.sub.5 Q).fwdarw.A at B15 thru B0
FAE=C.sub.3 Q.multidot.C.sub.2 Q.multidot.C.sub.1 Q.multidot.C.sub.0 Q.multidot.K.sub.11 Q.multidot.K.sub.10 Q.multidot.W1 The FAE micro-operation occurs in word time 1 and has a variable duration ranging from 1 to 16 bit times. It is used for a right shift and is implemented by preloading the bit counter with the contents of the D-Register. The bit counter 1 then clocks the A-Register for the selected number of shifts. For the right shift, the sign bit is shifted into the most significant portion of the accumulator. Executed operations are as follows:
(A.sub.i).fwdarw.A.sub.i -1 at B<D.sub.3,D.sub.2,D.sub.1, D.sub.0 > thru B0
(K.sub.1).fwdarw.A.sub.15 at B<D.sub.3,D.sub.2,D.sub.1, D.sub.0 > thru B0 The sign bit is loaded into the A-Register.
FAF=C.sub.3 Q.multidot.C.sub.2 Q.multidot.C.sub.1 Q.multidot.C.sub.0 Q.multidot.K.sub.11 Q.multidot.K.sub.10 Q.multidot.W1 The FAF micro-operation occurs in word time 1 and has a variable duration from 1 to 16 bit times. It is used for end around shift. The D-Register is used to set the bit timer to the selected number of end around shifts. The bit timer then clocks the A-Register as it counts down. The executed operations are as follows:
(A.sub.i).fwdarw.A.sub.i -1 at B<D.sub.3,D.sub.2,D.sub.1,D.sub.0 > through B0
(A.sub.0).fwdarw.A.sub.15 at B<D.sub.3,D.sub.2,D.sub.1,D.sub.0 > thru B0
FAG=C.sub.3 Q.multidot.C.sub.2 Q.multidot.C.sub.1 Q.multidot.W1 The FAG micro-operation occurs in word time 1 and has a duration of 12 bit times. It is used for the skip on discrete instruction. If the selected discrete is true, the M-Register is clocked and incremented by three. If the selected discrete is false, the M-Register is not clocked and is therefore not incremented. The executed operations are as follows:
DSI<D>:(M)+3.fwdarw.M at B11 thru B0
0.fwdarw.K.sub.8 at B0 The M carry flip-flop is used to increment the M-Register and reset at the end of the micro-operation.
FAH=C.sub.3 Q.multidot.C.sub.2 Q.multidot.C.sub.1 Q.multidot.W1 The FAH micro-operation occurs in word time 1 and has a duration of 12 bit times. It is used to implement the discrete output instruction. The operation executed is as follows:
1.fwdarw.DSO<D< at B11 thru B0
FAI=C.sub.3 Q.multidot.C.sub.2 Q.multidot.K.sub.2 Q.multidot.K.sub.1 Q.multidot.W1 The FAI micro-operation occurs in word time 1 and has a duration of 12 bit times. It is used during the decrement and transfer instruction when the contents of a selected index register has been decremented to a negative number. It should be noted that an alternate path is taken when the contents of the selected index register remain positive. This alternate path is through the FL micro-operation as with other transfer type instructions. The executed operations are as follows:
(M)=2.fwdarw.M at B11 thru B0
1.fwdarw.C.sub.2 at B0
0.fwdarw.K.sub.8 at B0 The M-carry register is used to increment the M-Register and reset to zero at the end of the micro-operation.
FAH=L.sub.1 Q.multidot.W3 The FAJ micro-operation occurs in word time 3 and has a duration of 16 bit times. It is entered for a turn-on interrupt (identified by the L.sub.1 Q signal) and is, effectively, a no operation. The operations executed are:
0.fwdarw.L.sub.1 at B0
FAK=L.sub.1 Q.multidot.P89.multidot.Y7.multidot.W3 The FAK micro-operation occurs in word time 3 and has a duration of 16 bit times. It is used for external interrupts and is entered if there is an external interrupt, P89, and there is no interrupt disable, L.sub.3 Q, or there is a preceding index instruction identified by K.sub.1 Q. It acts as a spacer for the word counter and no operations take place.
FAL=K.sub.1 Q.multidot.W4 The FAL micro-operation occurs in word time 4 and has a duration of 16 bit times. It is used for the start of the interrupt routine, preloading the M-Register with memory address 040.sub.16 and storing the return address in the SPM-2 Register. Operations executed are as follows:
040.sub.16 .fwdarw.M at B15 thru B0
(M).fwdarw.SPM<2>.sub.1sb at B15 thru B0
FAM=K.sub.1 Q.multidot.W5 The FAM micro-operation occurs in word time 5 and has a duration of eight bit times. It is used to access the contents of the program memory portion of the memory at location 040.sub.16, which is the start of the interrupt routine. Operations executed are as follows:
Read Strobe at B7
Restore Strobe at B3
(PM<M=64>).fwdarw.I at B7
Op[I].fwdarw.C.sub.3,C.sub.2,C.sub.1,C.sub.0,K.sub.11,K.sub.10 at B0
0.fwdarw.L.sub.3 at B0 The interrupt disable flip-flop is cleared.
FAN=K.sub.1 Q.multidot.W6 FAN is a no-op.
FAO=K.sub.1 Q.multidot.W7 The FAO micro-operation occurs in word time 7 and has a duration of 12 bit times. It is effectively a no op, merely setting the control flip-flops for a new word time cycle. Operations executed are:
0.fwdarw.W.sub.2,W.sub.1,W.sub.0 at B0 The word counter is reset.
0.fwdarw.K.sub.5,K.sub.4,K.sub.3,K.sub.2,K.sub.1, at B0
FAP=C.sub.3 Q.multidot.C.sub.2 Q.multidot.Y.sub.6 .multidot.K.sub.10 Q.multidot.W1 FAP is a no-op.
FAQ=C.sub.1 Q.multidot.C.sub.0 Q.multidot.Y39 The FAQ micro-operation occurs in word time 1 and has a duration of 16 bit times. The contents of the selected SPM Register is preserved by recirculation and also transfer to the A Register.
(SPM<D>).fwdarw.SPM D at B15 thru B0
(SPM<D>).fwdarw.A at B15 thru B0
INITIALIZATION
During initialization of the data processor 12, the following operations are executed:
1. L.sub.1 is in the true state due to the power turn-on condition.
2. FAJ is always automatically entered for start-up to initialize the following functions:
A. The M-Register is preset to the PM address 040.sub.16 in FAL.
B. All SPM Registers are cleared under program control.
C. The D-Register is loaded from PM<M>=040.sub.16.
D. The C-Register (C.sub.3,C.sub.2, C.sub.1, C.sub.0, K.sub.11, K.sub.10) is loaded from PM<M>=040.
E. The PM Read and Restore Strobes are generated in FAM.
F. The A-Register is cleared under program control.
G. The K.sub.1 flip-flop is cleared in FAO.
H. The K.sub.2 flip-flop is cleared in FAO.
I. Flip-flops K.sub.5, K.sub.4, K.sub.3 are cleared in FAO.
J. Flip-flops K.sub.8, K.sub.7, the M-Register and A-Register carry flip-flops are reset at every BO.
DISCRETE OUTPUTS
The data processor 12 can generate discrete outputs (DO) to meet specific requirements under program control. The DO assignments are:
DO-0 Set interrupt enable.
DO-1 Provide clock pulses to ASR-33 (TELETYPEWRITER).
DO-2 Provides a clock to set the power turn-on interrupt, L.sub.1. A DO-2 instruction (1100-0010) will be contained in program memory location 40.sub.16 to rest L.sub.1 during power turn-on.
DO-3 Iteration timer reset.
DO-4 Trigger to I.sub.2 latch, the discrete input 4 (DI-4) toggle. The I.sub.2 flip-flop is automatically zero set during the power on sequence.
DO-5 Trigger to I.sub.3 latch, the discrete input-5 (DI-5) toggle. The I.sub.3 flip-flop is automatically zero set during the power turn-on sequence.
DO-6 Trigger to the I.sub.4 latch, the discrete input-6 (DI-6) toggle. The I.sub.4 flip-flop is automatically zero set during the power turn-on sequence.
DO-7 Intensity control.
DO-8 Toggles the I.sub.1 flip-flop causing scratch pad memory paging.
DO-9 Main memory paging.
DO-10 Spare.
DO-11 Servo set.
DISCRETE INPUTS
The data processor 12 can operate on a discrete input (DI) with a skip-on-discrete instruction under program control. The discrete inputs are various low frequency digital signals. The purpose of the discrete inputs is to define a status or condition. The DI assignments are:
DI-0 Spare
DI-1 Skip unconditional.
DI-2 Skip on ASR-33 (TELETYPEWRITER).
DI-3 Skip on the sign of (A).
DI-4 Skip on the I.sub.2 Q latch (DO-4 trigger).
DI-5 Skip on I.sub.3 Q latch (DO-5 trigger).
DI-6 Skip on I.sub.4 Q latch (DO-6 trigger).
DI-7 Skip on logical overflow in A-Register.
DI-8 Used for troubleshooting.
DI-9 Skip on arthmetic carry from A-Register.
DI-10 Skip on positive.
DI-11 Skip on servo ready.
INTERRUPTS
Interrupts may be added virtually without limit. All interrupts are logically ORed together (X5) to transfer operation of the data processor 12 to an interrupt subroutine starting in memory location 040.sub.16. The return address is preserved in SPM-2. The interrupt subroutine will scan the discrete interrupt inputs and operate on each interrupt.
The interrupt enable flip-flop (L.sub.3) will automatically disable interrupts within interrupts, but may be set with a DO-0 after the return address in SPM-2 has been stored elsewhere under program control, thereby permitting interrupts within interrupts. The end of the interrupt subroutine requires the transfer to the return address, the setting of the interrupt enable flip-flop (L.sub.3) if required, and the transfer indirect (TI) to the return address contained in SPM-2.
The interrupt enable flip-flop (L.sub.3) may be used to preserve the contents of SPM-2 against the contingency of an interrupt to permit time shared use of SPM-2.
DATA-SAVE
The power supply generates a C signal which indicates the power supply is out of tolerance limits and requests the data processor 12 to generate a data-save signal in the event of a power dropout. Following a delay of sufficient duration to insure the completion of a memory cycle, the data processor generates a data-save signal (L.sub.2 Q) in response to the C signal generated by the power supply. The delay will range from 20 nonoseconds to 35 microseconds and will have an average duration of 7 microseconds. The data-save operation constitutes the power turn-off interrupt, where the C signal will always initiate a data-save function which will terminate normal computer operation.
ADAPTIVE MEMORY CONTROL
The data processor 12 incorporates an adaptive memory control that adds additional memory protection to insure that the power turn-on condition does not cause detrimental system operation and provide protection from loss of program. In the data processor, this power condition is detected and used to initiate a power interrupt (L.sub.1 Q); which forces the data processor to look at a specific memory address (040 HEXADECIMAL) by preloading this address into the M-Register. The data processor will continue to access this address until the power interrupt condition is alleviated. In prior art systems, the power interrupt is eliminated when the voltages come within tolerance. In this invention, adaptive techniques are used that insures that not only are the voltages back into tolerance levels, but memory can be properly accessed. This technique is implemented with a memory access interlock implemented by requiring that an instruction that generates a discrete output (DO-2) be located in the first location of the power interrupt program in memory. This discrete output (DO-2) instruction provides the adpative interlock to insure that memory cannot be accessed before the power interrupt is exited.
MEMORY PROTECT
A memory protect scheme greatly reduces problems with loss of program and protects against the program wiping out part of the program. This is accomplished by logically processing the memory address register outputs to produce a signal P110 (Table II) disabling the write mode (associated with the memory read-write logic) when the M-Register is addressing protected parts of the memory. This technique effectively permits an electrically alterable (core type) memory to be configured as a read-only memory in selected locations for additional protection of the program stored in that memory.
INSTRUCTION REPERTOIRE
The program instructions for the numerical control system 10 are encoded as 8-bit bytes, each byte being stored in a different program memory location of the program memory. The instructions may have multiple bytes, but most have a length of only 1 byte. Each instruction contains an operation code in the most significant portion, and, when required, an operand address in the least significant portion. Indexing is achieved with an index functional modifier byte preceding the instruction whose operand address is to be indexed. Operands can be located in any of the SPM Registers, the constant memory part of the program memory, or in the two program memory bytes following an instruction (in line).
FUNCTIONAL MODIFIER
The program instructions follow a functional modifier concept which yields a high degree of flexibility and economy. This concept permits conservation of memory by the use of short instructions without sacrifice of flexibility or capability. As an example, extensive indexing capability is available when required even though an index field is not required in an instruction. This indexing capability is implemented by programming an index functional modifier prior to an instruction to be indexed. This functional modifier indicates that the following instruction is to be indexed and identifies the location of the index. A functional modifier may also be used to make available double precision shifting capability. The short instruction word length which is configured for efficient use of memory permits only enough instructions for single precision shifting operations. A double precision shift capability is implemented by preceding the shift instructions with a functional modifier to indicate that the subsequent shift instruction is a double precision shift. Thus, both single and double precision shifting capability may be implemented without use of excessively long instruction words.
DETAILED DESCRIPTION OF INSTRUCTIONS
For convenience of discussion, the instructions are divided into four categories A, B, C, and D. During the execution of Group A instructions, operands are obtained from the constant memory portion of the main memory with SPM-2 used as an intermediate working register. Therefore, SPM-2 contents must be expendable when using Group A instructions. The operand address pertains to the corresponding locations in the constant memory portion of the main memory, and are defined as double byte locations 0 through 15, but are indexable through many additional pages of double byte locations. Double byte operands are used becausee two 8-bit bytes are used for each 16 bit operand, each memory location storing one byte. Therefore operand word address 0 defines memory byte address locations 0 and 1, operand word address 1 defines memory byte address locations 2 and 3. Thus, twice the operand word address defines the first of the two operand byte address locations. Certain operand addresses pertain to the two bytes following the instruction. Constants and parameters can be stored in the main memory with the least significant half (msh) of a word in the second byte. The constant memory portion of the main memory is composed of many 16 word pages where each word is composed of two 8-bit bytes. The Group A instructions can be indexed to select required constants or parameters.
The Group A instructions are as follows:
1. LS (load SPM-2 with next two bytes) 0010-0001.
This is a three-byte instruction having the above operation code contained in the zero byte. It causes the subsequent byte 1 and byte 2 containing the least significant half and most significant half, respectively, of an in line operand to be loaded into SPM-2. This instruction is not indexable, it uses micro-operations FA, FL, FM, FN, FO, FP, FQ, FJ, FAP, and FZ.
2. ST (store (A) in PM) 0010-0001.
This is a one byte instruction having the above operation code. It causes a two-byte operand previously stored in the A-Register to be stored in a main memory location whose address is stored in the 12 least significant bits of the SPM-2 register. The first byte (lsh) of the operand is loaded into the memory location addressed by SPM-2 and the second byte (msh) of the operand is loaded into the memory location following the first byte. The operand is also preserved in A. The operand address is incremented twice, identifying the memory location following the second byte, and returned to SPM-2 where it is preserved. This permits a second operand to be loaded into the A-Register and then transferred to the next-in-line memory location with a second ST instruction. The next instruction address is also preserved and can be used to access the next instruction. The micro-operations used during this instruction are FA, FD, FE, FG, FF, FH, FI, FJ, FY, and FZ.
3. TX (decrement and transfer on non-negative) 0010-0110.
This may be either a three or a four-byte instruction. The first byte is an optional index byte and defines an index register. The absence of an index byte defines the SPM-0 Register. The second byte contains the above operation code and the third and fourth bytes define a transfer address. A non-negative decremented number will cause the next instruction to be accessed from the transfer address location defined by the last two bytes of this instruction. The return address is stored in the SPM-2 Register.
A negative decremented number will cause the next instruction to be accessed from the byte following the last byte (address byte 2). The transfer address (which is not used) is preserved in SPM-2.
This instruction is used to guide the data processor through a loop one or more times. The desired number of transfers, less one, is initially loaded into the appropriate index register. This number will then be decremented through zero to a negative number before the loop is exited.
As long as the decremented number is non-negative, the TX instruction goes through micro-operations FC, FL, FM, FN, FO, FP, FQ, FJ, FY and FZ.
As soon as the decremented number becomes negative, the TX instruction goes through micro-operations FC, FAI, and FZ.
4. TR (unconditional transfer) 0010-0111.
This is a three-byte instruction in which the above operation code is contained in the first byte and a transfer address defined by the second and third bytes. This instruction will cause the next instruction to be accessed from the transfer address location defined by the second and third bytes. The return address is preserved in SPM-2. This instruction goes through micro-operations, FA, FL, FM, FN, FO, FP, FQ, FY and FZ.
5. IP (index) 0010-1I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable functional modifier containing the operation code in the five most significant bits and an operand address in the three least significant bits. A first index (IP or IS) instruction preceding a second index (IP or IS) instruction will cause the operand address of the second index (IP or IS) instruction to be indexed by the operand of the first index (IP or IS). Thus, mutilevel indexing is permissible without limit and index parameters can be obtained from locations throughout the memory.
This instruction goes through micro-operations FA, FK, FM, FN, FO, FP, FQ, FR, FV, and FZ.
6. IP-7 (index) 0010-1111
When an index instruction identifies address location 111 it becomes a three-byte non-indexable instruction wherein an operand is contained in the second and third bytes. The operand is transferred to the SPM-2 Register. This instruction goes through micro-operations FA, FL, FM, FN, FO, FP, FQ, FS, FV and FZ.
7. DP (ADD) 0001-I.sub.3 I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the operation code is stored in the first four bits and an operand address is stored in the last four bits. This instruction causes the contents of an SPM-Register identified by the address portion to be added to the contents of the A-Register and the results stored in the A-Register. This instruction goes through micro-operations, FA, FK, FM, FN, FO, FP, FQ, FR, FT and FZ.
8. DP-15 (Add) 0001-1111
When a DP instruction identifies address location 1111 it becomes a three-byte non-indexable instruction with the second and third bytes containing an operand. This operand is added to the contents of the A-Register and the results stored in the A-Register. This instruction goes through micro-operations FA, FL, FM, FN, FO, FP, FQ, FS, FT, and FZ.
9. BP (subtract) 0011-I.sub.3 I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the operation code is contained within the first four bits and an operand address is identified by the second four bits. It causes an operand stored in an SPM-Register defined by the operand address to be subtracted from the contents of the A-Register and the results stored in the A-Register. This instruction goes through micro-operations FA, FK, FM, FN, FO, FP, FQ, FR, FU, and FZ.
10. BP-15 (subtract) 0011-1111
When the operand address defined by a BP instruction is 1111 is becomes a three-byte non-indexable instruction. The second and third bytes contain an operand which is subtracted from the contents of the A-Register and the difference stored in the A-Register. This instruction goes through micro-operations FA, FL, FM, FN, FO, FP, FQ, FS, FU and FZ.
11. XP (exclusive-OR) 0000-0I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction in which the operation code is contained in the five most significant bits and an SPM-Register containing an operand is defined by the three least significant bits. The operand is exclusive-ORed with the contents of the A-Register and the result is stored in the A-Register. This instruction goes through micro-operations FA, FK, FM, FN, FO, FP, FQ, FR, FX and FZ.
12. XP-7 (exclusive-OR) 0000-0111
When an XP instruction defines operand address 111, it becomes a three-byte non-indexable instruction containing an operand in the second and third bytes. This operand is exclusive-ORed with the contents of the A-Register and the result is stored in the A-Register. This instruction goes through micro-operations FA, FL, FM, FN, FO, FP, FQ, FR, FX and FZ.
13. AP (logical AND) 0000-1I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the operation code is contained in the five most significant bits and an SPM-Register address containing an operand is defined by the three least significant bits. The operand contained in the addressed SPM-Register is logical ANDed with the contents of the A-Register and the result is stored in the A-Register. A logical AND with a 0 operand is used to clear the A-Register. This instruction goes through micro-operations FA, FK, FM, FN, FO, FP, FQ, FR, FW, and FZ.
14. AP-7 (logical AND) 0000-1111
When the address defined by an AP instruction is 111, it becomes a three-byte non-indexable instruction having an operand contained in the second and third bytes. The operand is logical ANDed with the contents of the A-Register and the result is stored in the A-Register. This instruction goes through the micro-operations FA, FL, FM, FN, FO, FP, FQ, FS, FW and FZ.
Group B instructions obtain all operands from the scratch pad memory. Each SPM page consists of 16 registers with indexing permitted between the two SPM pages. Caution is required when using SPM-2 because an interrupt will replace the contents of SPM-2 with a return address. This can be circumvented with the use of an interrupt disable discrete. In addition, the use of a Group A instruction will replace the contents of the SPM-2 Register with either data or a return address, requiring the transfer of SPM-2 data to another SPM-Register before a Group A instruction is used if the data is to be preserved.
15. TI (transfer indirect) 0110-0111
This is a one-byte non-indexable instruction having the above operation code. It causes the address of the next instruction to be obtained from SPM-2 and the return address stored in SPM-2. It goes through micro-operations FA, FY and FZ.
16. IS (index) 0110-1I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable functional modifier having the operation code contained in the five most significant bits and an address defining an SPM-Register containing an operand contained in the three least significant bits. A first index (IP or IS) instruction following a second index (IP or IS) instruction will cause the operand address of the second index (IP or IS) instruction to be indexed by the operand of the first index (IP or IS9 instruction. Multilevel indexing is thus permissible without limit. Only SPM-Registers 0 through 7 of each SPM page may be used as index registers. This is a single byte functional modifier programmed immediately prior to an instruction to be indexed. This instruction goes through micro-operations FA, FV and FZ.
17. DS (Add) 0101-I.sub.3 I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the four most significant bits define the operation code and the four least significant bits define an SPM-Register address containing an operand. The operand in the addressed SPM-Register is added to the contents of the A-Register and the sum is stored in the A-Register. This introduction goes through micro-operations FA, FT and FZ.
18. BS (subtract) 0111-I.sub.3 I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the four most significant bits define the operation code and the four least significant bits define a scratch pad memory address containing an operand. The addressed operand is subtracted from the contents of the A-Register and the difference is stored in the A-Register. This introduction goes through micro-operations FA, FU and FZ.
19. XS (exclusive-OR) 0100-0I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the five most significant bits define the operation code and the three least significant bits define an SPM address containing an operand. The operand is exclusive-ORed with the contents of the A-Register and the result is stored in the A-Register. This instruction goes through micro-operations FA, FX and FZ.
20, AS (logical AND) 0100-1I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the five most significant bits define the operation code and the three least significant bits define an SPM address containing an operand. The addressed operand is logical ANDed with the contents of the A-Register and the result is stored in the A-Register. This instruction goes through micro-operations FA, FW and FZ.
The following Group C type instructions relate to operations generally involving the A-Register.
21. SS (store (A) in SPM) 1000-I.sub.3 I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the four most significant bits identify the operation code and the four least significant bits define an SPM address. The contents of the A-Register are placed in the addressed SPM-Register and also preserved in the A-Register. This instruction uses micro-operations FA, FAC and FZ.
22. SL (shift left) 1001-00I.sub.1 I.sub.0
This is a one-byte non-indexable instruction wherein the six most significant bits define the operation code and the two least significant bits define the number of shifts. The contents of the A-Register are shifted left by the binary number defined by (I.sub.1 I.sub.0)+1. In other words, I.sub.1, I.sub.0 =1 shift, I.sub.1 I.sub.0 =2 shifts, I.sub.1 I.sub.0 =3 shifts, and I.sub.1 I.sub.0 =4 shifts. 0's are shifted into the vacated least significant bits of the A-Register. This instruction goes through micro-operations FA, FAD and FZ.
23. SE (shift end around) 1001-11I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the six most significant bits identify the operation code and the two least significant bits identify a number of shifts. The number of bits shifted can be indexed up to a maximum of 16 bits. The contents of the A-Register are shifted by the binary number represented by (I.sub.1 I.sub.0)+1. That is, I.sub.1,I.sub.0 =1 shift, I.sub.1 I.sub.0 =2 shifts, I.sub.1 I.sub.0 =3 shifts, and I.sub.1 I.sub.0 =4 shifts. Additional shifts are accomplished by indexing. The end around shift is effectively a right shift where the least significant bit is shifted out of the A-Register and recirculated into the most significant bit position of the A-Register. This instruction goes through micro-operations FA, FAF and FZ.
24. SR (shift right) 1001-10I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the six most significant bits identify the operation code and the two least significant bits identify a number of shifts. The number of bits shifted can be indexed up to a maximum of 16 bits. The contents of the A-Register are shifted right as indexed or by a number of bits equal to the binary number defined by (I.sub.1 I.sub.0)+1. That is, I.sub.1, I.sub.0 =1 shift, I.sub.1 I.sub.0 =2 shifts, I.sub.1 I.sub.0 =3 shifts, and I.sub.1 I.sub.0 =4 shifts. The sign bit of the A-Register is continuously shifted into the most significant bit position. This instruction goes through micro-operations FA, FAE and FZ.
25. EX (input/output word) 1010-I.sub.3 I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the four most significant bits identify the operation code and the four least significant bits identify an I/O channel address. The contents of the A-Register are output to the addressed channel while the contents of the addressed channel are simultaneously loaded into the A-Register. A shift enable signal is output to gate 16 clock pulses to the selected channel. This instruction goes through micro-operations FA, FAB, and FZ.
26. EX-15 (input/output word) 1010-1111
This instruction clears the A-Register by shifting in the contents of a non-existent input channel which are all zeros. This instruction goes through micro-operations FA, FAB and FZ.
27. LD (load accumulator) 1011-I.sub.3 I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the four most significant bits identify the operation code and the four least significant bits identify an SPM address containing an operand. The operand in the addressed SPM-Register is loaded into the A-Register. This instructon goes through micro-operations FA, FAQ and FZ.
Group D instructions relate to the discretes.
28. DC (discrete output) 110I.sub.4 -I.sub.3 I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the three most significant bits define the operation code and the five least significant bits define an output channel address. A discrete output signal, an inverted 3 microsecond pulse is generated on the addressed output channel. This instruction goes through micro-operations FA, FH and FZ.
29. SK (skip on discrete) 111I.sub.4 -I.sub.3 I.sub.2 I.sub.1 I.sub.0
This is a one-byte indexable instruction wherein the three most significant bits identify the operation code and the five least significant bits identify a discrete input channel address. If a discrete exists on the addressed channel, three bytes (usually a transfer instruction) are skipped and the next instruction is obtained from the fourth byte following the skip on discrete instruction. If a discrete does not exist on the addressed channel, the next instruction (usually a three-byte transfer instruction) is obtained from the three bytes immediately following the skip on discrete instruction. This instruction goes through micro-operations FA, FAG and FZ.
Two rules create exceptions to the above micro operation flow paths.
1. When an interrupt occurs during the execution of an instruction, the instruction will not terminate with the FZ micro-operation but instead will continue through the FAK, FAL, FAM, FAN, FAO micro-operations.
2. Whenever an instruction normally going through the FA micro-operation is preceded by an index functional modifier (IS or IP) it will go through FB in lieu of FA.
SCHEMATIC DIAGRAMS
As previously noted the data processor is physically layed out on a series of printed circuit boards interconnected by a Mother board. The schematic drawings in FIGS. 6-17 show columns of numbers and letters representing plug interconnections and common signal connections, which are summarized in Table IV. The registers and logic gates are implemented with SN 7400 series integrated circuits. The registers and flip flops are shown in detail in FIGS. 6-17 and the various logical equations such as the inputs to these elements are defined in Table I and Table II. Although the illustrated registers and flips flops, combined with the equations in Table I, Table II, and Table III are sufficient to completely define the operation of the data processor 12 (FIG. 1), groups of logical functions have been shown on the printed circuit boards on which they are actually implemented. It should be understood, however, that the location of gates developing logical signals is largely determined by availability of space and primary or intermediary subsignals and may or may not be related to the ultimate use of a particular logical signal.
The numerous computer signals are defined with both, letters and numbers. The signal definitions in FIGS. 6 thru 17 correspond with the signal definitions in the logical equations and with the micro-operation designations. Each logic card shown in FIGS. 6 thru 17 have pin designations that correspond to the signals on that logic card, with those pin designations repeated for each card. The signals for each logic card and the pin designation that corresponds to that signal on that card are shown in Table IV. The pin designations are listed in the left hand column, while the signals corresponding to those pin designations are listed in columns under the card designations (such as cards A, B, C, etc) and the Figure references (such as FIGS. 6, 7, 8, etc).
As shown in FIG. 6 the A-Logic printed circuit board includes the A-Register 130, its associated full adder 132 and the A carry flip-flop K.sub.7 138. Also shown is the M-Register 112, its associated full adder 139, and the carry flip-flop 140. The A-Register overflow detector flip-flop OF.sub.1 134 and logic dates 135 are also located on the A-Logic board.
As shown in FIG. 7 the B-Logic printed circuit board includes the bit counter, flip-flop B.sub.0 150, B.sub.1 152, B.sub.2 154 and B.sub.3 156. Flip-flops B.sub.4 158, B.sub.5 160, B.sub.6 162 and B.sub.7 164 produce the asymmetric main clock signal P3. Also included on this board is the bit time decode logic 166, logic gates 168 and various other logic gates.
As shown in FIG. 8 the C-Logic printed circuit board includes various logic gates 17 as well as the C-Register which includes flip-flops C.sub.3 172, C.sub.2 174, C.sub.1 176, C.sub.0 178, K.sub.11 180 and K.sub.10 182.
As shown in FIG. 9 the D-Logic printed circuit board includes the D-Register 186 as well as varius logic gates 188, 190, 192 and 194.
As shown in FIG. 10 the K-Logic printed circuit board includes flip-flops K.sub.0 196, K.sub.1 198, K.sub.2 200, K.sub.3 202, K.sub.4 204, K.sub.5 206, and L.sub.1 210. Also included are various logic gates 212 and 214.
As shown in FIG. 11 the W-Logic printed circuit board includes the word counter composed of flip-flops W.sub.2 220, W.sub.1 222 and W.sub.0 224 as well as the flip-flop L.sub.2 226. Also included are various logic gates 228, 230 and 232.
As shown in FIG. 12 an A section Scratch Pad Memory printed circuit board includes eight paris of integrated circuit shift registers 234. A binary coded decimal to decimal decoder 236 generates memory select signals P50 through P57 which is gated through a first series of gates 238. This first gated signal in turn gates a clock signal P3A through a second series of gates 240 to clock a selected one of the registers. The outputs from the registers 234 are multiplexed into signals P120A and P121A, each carrying outputs from four of the registers. Three additional scratch pad memory sections B, C and D, identical with A shown in FIG. 12 provide corresponding output signals P120B, 121B, 120C, 121C, 120D and 121D. These in turn are multiplexed by NAND gate 242 into a single output signakl P85. The signals in the B, C and D sections correspond to those of the A section and are defined according to terminal numbers as follows:
______________________________________TerminalNo. A B C D______________________________________ 30 ##STR1## ##STR2## ##STR3## ##STR4## 32 ##STR5## ##STR6## ##STR7## ##STR8## 34 ##STR9## ##STR10## ##STR11## ##STR12## 36 ##STR13## ##STR14## ##STR15## ##STR16## 38 ##STR17## ##STR18## ##STR19## ##STR20## 40 ##STR21## ##STR22## ##STR23## ##STR24## 42 ##STR25## ##STR26## ##STR27## ##STR28## 44 ##STR29## ##STR30## ##STR31## ##STR32## 46 ##STR33## ##STR34## ##STR35## ##STR36## 48 ##STR37## ##STR38## ##STR39## ##STR40##50 C C C C52 B B B B54 A A A A 56 ##STR41## ##STR42## ##STR43## ##STR44##58 P47 P47 P47 P47 60 ##STR45## ##STR46## ##STR47## ##STR48## 62 ##STR49##64 P85 66 ##STR50## ##STR51## ##STR52## ##STR53## 68 ##STR54## 70 ##STR55## 72 ##STR56## 74 ##STR57## 76 ##STR58##______________________________________
As shown in FIG. 13 the IFA-1 printed circuit board contains logic gates 250, 251, 252 and 253 providing input/output functions. The IFA-1 board accepts input and output type instruction micro-operation signals as well as address signals to encode or decode the varius inputs and outputs. The input and output words are exchanged with the A-Register in the data processor 12 (FIG. 4). The input words (IW) are multiplexed by logic gates 253 into signal P108 which is input to the A-Register. Information is output from the A-Register to the various entities by connecting the entities to A.sub.0 Q and clocking a selected entity with a gated clock P104 as determined by logic states 252, shown as output word (OW) signals. Discrete input signals are multiplexed into signal P105 by logic gates 250. Discrete output signals (DO) are decoded and gated by logic gates 251. Micro-operation FAH provides the gating signal. The discrete input signals are accessed with skip on discrete decision instructions, and each discrete output signal (DO) provides a short negative going pulse when selected with a discrete output instruction. The I-Register flip-flops 256, 257, 258 and 259 perform the function of latches toggled or set with the discrete outputs. The I.sub.1 flip-flop 256 is used to directly provide a Scratch Pad Memory paging function. Outputs from the flip flops I.sub.2 257, I.sub.3 258 and I.sub.4 259 become discrete inputs. A C.sub.I -Register 260 is loaded with output word 8 and used for general system functions. This interface C-Register shown in FIGS. 13 and 15 will be referred to as the C.sub.I -Register hereafter to distinguish it from the data processor C-Register shown in FIG. 8. The signals P50-P61 are decoded operand addresses from the data processor.
As shown in FIG. 13, the C.sub.I -Register 260 contains a plurality of discrete commands C.sub.I15 Q-C.sub.I6 Q, where the command conditions are packed together in the data processor A-Register using well known programming methods. This packed word is then output to the C.sub.I register 260 with an EX-8 instruction generating the OW-8 gated clock from logic gates 252 to the clock input CK of the C.sub.I register 260. The contents of the A-Register are shifted into the C.sub.I15 input to the C.sub.I register 260 as the A.sub.0 Q signal on pin 80. The data processor packs a tape reader run/stop bit into the most significant bit position corresponding to the C.sub.I15 Q bit shown on pin 78, where a logical one commands the tape reader 16 to run and a logical zero commands the tape reader 16 to stop. The data processor packs a tape reader forward/rewind bit in the next most significant bit position corresponding to the C.sub.I14 Q bit shown on pin 75, where a logical one commands the tape reader 16 to run forward and a logical zero commands the tape reader 16 to rewind under control of the tape reader run/stop command C.sub.I15 Q on pin 78. These tape reader controls are described in detail in the technical manual for the Remex tape reader previously referenced herein. Other discrete commands from the data processor are shown as signals C.sub.I13 Q-C.sub.I6 Q on pins 75, 48, 31, 32, 29, 2, 5, 6 and 4 respectively and are used for controlling other system operations such as shown in FIG. 1 as machine auxiliary control signals 26 for direct control of various machine operations as described previously.
As shown in FIGS. 14A and 14B, the IFA-2 printed circuit board provides for the scan-in of input words "zero", "three", and "four" to convert the parallel input lines to a serial input that can be processed with the input word multiplexer on the IFA-1 card. Logic gates 262 scan control panel selector switch signals into input word -0, logic gates 264 scan non-system adapted machine auxiliary control signals 26 (FIG. 1) into input word -3 and logic gates 266 scan rudimentary intrinsic tape reader input signals into input word -4.
These machine auxiliary control signals are scanned into the data processor A-Register with logic gates 264 as serial word IW-3 shown on pin 49 upon execution of an EX-3 instruction. Machine limit switch signals S8-S11 shown on pins 43, 29, 46, and 32 respectively are received for examination by the data processor to interlock motion. Machine Cycle Complete signal S4 shown on pin 68 is received for use by the data processor to determine if a machine command such as a discrete command has been executed to interlock machine operations. Turret Cycle Complete signal S7 shown on pin 51 is received by the data processor to determine if a turret command such as described herein has been executed to interlock machine operations. Operator control signals such as the Switch Contact Jog signal shown on pin 27 is received from machine mounted operator control devices and is used in parallel with operator control devices on the panel 14 such as Jog switches 41 and 52 (FIG. 2A) through interpretation by the data processor under program control as discussed previously for the switches mounted on the control panel 14 (FIG. 1). Other machine auxiliary control signals such as signals S5, S6, S3, S2, S1, and S0 shown on pins 65, 54, 28, 25, 7, and 9 respectively are examined by the data processor to determine machine conditions.
The Z-Register 268 includes flip-flops Z.sub.11 through Z.sub.0 and is a static register loaded with output word -7 to set system discrete conditions such as for machine control. It should be noted that this register does not have ambiguous outputs during the shift frame due to selective clocking of the flip-flops in this register. The Z-Register 268 contains a plurality of discrete commands shown as YL5-YL1, XL5-XL1, MFE and Z.sub.0 Q which are packed together in the data processor A-Register using well known programming methods. The packed word is then output to the Z-Register 268 with an EX-7 instruction generating the OW-7 gated clock shown on pin 5 from logic gates 252 (FIG. 13) to clock flip-flops Z.sub.11 -Z.sub.0 as selected with bit time signals shown as B.sub.0 -B.sub.11 respectively to the two-input NAND gates with outputs shown connected to the clock inputs CK of the Z-Register flip-flops. Discrete commands from the data processor are shown as signals YL5-YL1, XL5-XL1, MFE, and Z.sub.0 Q to pins 50, 52, 78, 76, 72, 75, 69, 78, 70, 74, 67, and 73 respectively and are used for controlling various system operations such as shown in FIG. 1 as machine auxiliary control signals 26 for direct control of various machine operations as described previously. For example, a Photo Optical Cycle Command signal MFE is shown on pin 67 to control a photo machine operation.
As shown in FIG. 15, the IFA-3 printed circuit board provides an extension 270 (C.sub.I31 through C.sub.I16) to the C-Register on IFA-1 (FIG. 13) and performs the auxiliary function of decoding some of the discrete conditions for machine turret select 271. The data processor packs a turret select code into the word output to the C.sub.I -Register in positions corresponding to the C.sub.I31, C.sub.I30, and C.sub.I29 stages of C.sub.I -Register extension 270 to excite the Turret Select Decode for generating turret select signals TS-0 through TS-7. Turret change can be enabled with discrete command signals such as previously described. The data processor can monitor the Turret Cycle Complete signal S7 on pin 51 (FIG. 14B) to determine when the turret has been properly repositioned for interlocking system operations. Logic gates 272 provide the input gating, latching and logical functions associated with the momentary switch logic inputs from the control panel and multiplex them into input word -1. In addition, special gating for computer interrupts is provided and the servo lockup 273 is used to disable the machine drives when a detrimental condition is sensed.
The interface assembly (IFA-1, IFA-2 and IFA-3) is not an interface in the conventional sense but constitutes a distributed group of functions that are normally associated with the data processor or the various system entitles. The interface assembly also performs the function of signal distribution between the data processor and various system extremities.
As shown in FIGS. 16A and 16B the servo common board provides control signals for servo operation and updating. The three servos 20, 21 and 22 (FIG. 1) are identical in this embodiment of the invention and exemplified by the X-axis servo 20 as shown in FIGS. 17A and 17B. The three servo channel boards, the servo common board and the A-Register are serially connected in a loop. Data passes from the A-Register and is input to a .DELTA.-Register 276 (FIG. 17A) on the X-axis servo board via I/O channel-2. Data then passes from the X-axis channel board via I/O channel-1 to the I/O channel-2 of the Y-axis servo board (not shown). Similarly, data passes out of the Y-axis servo board into the Z-axis servo board (not shown) and out of the Z-axis servo board to the common board F-Register 312 and back to the A-Register. Thus, communication is provided between the data processor, the three servo channel boards and the servo common board.
The servo drives generate control signals to position the servo motors in response to these commands transferred from the data processor. A resolver 78 (FIG. 3) is used to provide a closed servo feedback loop. Resolvers are exicted with digital square waves generated on the common board by a flip flop counter, N.sub.22 278 and N.sub.23 280. The resolver output signal is a square wave that is processed on the servo board with shaping circuits 82 and applied to an error detector 284 which also receives command signals from a flip-flop N.sub.30 286. A quasi-digital position error signal 87 from the error detector 284 is connected to an analog error signal by an analog integrator and amplifier 88. The command signal, which is a square wave, is generated by the phase counter 302, whichis continually incremented to form a square wave, where the phase of that square wave is changed by a number in the .DELTA.-Register 276 with a full adder 304 and carry flip-flop 306. The command signal 287 is a square wave with a phase that is advanced or retarded with a positive or negative .DELTA. command number. The phase counter sign bit N.sub.30 286 provides a command square wave which is compared with the resolver feedback square wave 83 in the error detector 284 to generate an error signal. As shown in FIG. 18 this error signal has a polarity defined by the N.sub.31 flip-flop 290 which defines whether the feedback signal leads or lags the command signal. NAND gates 292 provide an exclusive or function defining the out-of-phase condition of the feedback and command square waves with an output pulse 294 having a width that is proportional to the magnitude of the error. The error signal is actually a two wire ternary signal, wherein the line 296 or 298 that contains the pulse defines the polarity and the width of the pulse defines the magnitude.
The contour commands are provided to the servos 20, 21, and 22 by the data processor 12 under program control. They are generated successively in real time at an elemental device determined rate and consist of whole number delta commands for each of the servos to command intermediate path defining points along the contour, known to those skilled in the art as interpolation commands. These commands are provided in real time under data processor program control, wherein real time is herein intended to mean having a time characteristic associated with the time related response of the elemental extremity.
As shown in FIG. 17 and more particularly in FIG. 19 the feedback signal is processed with a digital tachometer 92 which compares the input square wave 83 from the resolver 78 with a reference square wave generated in the tachometer 92. Flip flops N.sub.32 305 and N.sub.33 307 synchronize the reference square wave counter 303 with the feedback signal 83, while the output gates 308 detect the pulse width difference between the reference and feedback square waves as indicative of velocity. The polarity of this velocity is defined by whether the reference square wave is of a greater or lesser period than the feedback square wave.
The calculations for the commands which are loaded into the .DELTA. register 276 (FIG. 17) are performed in the data processor under program control. This capability eliminates the need for the digital differential analyzer computational elements typically used for contouring. The relative magnitudes of the .DELTA. parameters loaded into the plurality of channel card .DELTA. registers define the relative position commands or, as a function of time, the relative velocity commands of the plurality of servo channels. As these commands are executed, the three servo axes are driven relative to each other to provide fully synchronized operation controlled through the computations in the data processor.
As shown in FIG. 16, the data processor also controls the speed at which the .DELTA. parameters increment the phase counter. The data processor loads a number into the FR-Register 310, and this number is added to the R-Register 312 every half cycle, as controlled by the signal 314 from the excitation counter composed of flip-flops N.sub.25 317 and N.sub.24 316. When the R-Register 312 overflows, an update is commanded causing adder 318 and associated carry flip-flop N.sub.27 320 to add the contents of the .DELTA.-Register 276 to the phase counter 302 (FIG. 17) to execute the contour command. The mode control flip flops N.sub.21 322 and N.sub.20 324 are reset to request additional contour information from the data processor through the N.sub.26 flip flop 326 and its SD 13 output signal. It should be noted that this SD-13 (hexadecimal) is the same as the previously described SD-11 (decimal), where hexadecimal and decimal numbers may in general be interchanged herein. After loading new contour commands, the data processor will generate the DC13 signal to initiate another contour step.
An alternate technique would replace the N.sub.30 flip-flop 286 (FIG. 17) with a toggle flip flop which would be clocked by a data processor discrete output command at appropriate times thereby generating an output square wave with the timing of that discrete output command controlling the phase and thereby defining the whole number position command. This controlled square wave is an intrinsic signal form which is used directly by the servos in the error detector 284 (FIG. 17) as the command input. It is generated directly by the data processor with a precisely timed discrete output under program control as defined by the contouring computations.
The data processor can operate interactively in conjunction with the servo intrinsic signal forms where the square wave servo has parameters such as velocity 94, position 83, and position error 87 available in square wave form. The data processor can interrogate these square wave signals as discrete inputs with the skip on discrete instructions and derive the parameter from the pulse width or phase of the square waves.
As shown in FIG. 16 the common board further includes a power supply 334, a ramp generator 336 generating ramp functions used by a servo drive signal generator 338 (FIG. 17), and counters generating signals used by the ramp generator 336.
As shown in FIG. 17, the channel board further includes motor drive power amplifiers 340, 341, 342 and 343 as well as resolver excitation 344.
TABLE I______________________________________A-RegisterA.sub.15 D = FAD.multidot. [(K.sub.2 Q.multidot. P50)+(K.sub.3 Q.multidot. P51)+(K.sub.4 Q.multidot. P52)+(K.sub.5 Q.multidot. P53)]+(FAQ.multidot. SPM.sub.0 Q)+(FAB.multidot.P108)+(FAE.multidot. K.sub.1 Q)+A.sub.0 Q.multidot. FW.multidot. SPM.sub.0Q+A.sub.0 Q[FAC+FAF+W0+(FD+FG).multidot. (B.sub.3 Q+B.sub.2 Q)]+(FT+FU+FX) (.SIGMA.A) ##STR59##FAF+W0+FT+FU+FX+(FD+FG).multidot. (B.sub.3 Q+B.sub.2 Q)]A-Adder.SIGMA.A = [(P2.multidot. FB)+(FT+FU+FX).multidot. A.sub.0 Q+FC] .sym. [FU .sym. SPM.sub.0 Q] .sym. [K.sub.7 Q+FU.multidot. B15] ##STR60## ##STR61##A.sub.1 =A.sub.2 =B.sub.1 =B.sub.2 =Ground ##STR62##C.sub.N = K.sub.7 Q+FU.multidot. B15C.sub.N+1 A = [(P2.multidot. FB)+(FT+FU+FX).multidot. A.sub.0 Q+FC] .multidot. [FU .sym. SPM.sub.0 Q]+[(P2.multidot. FB)+(FT+FU+FX.multidot. A.sub.0 Q+FC] .multidot. [K.sub.7 Q+FU.multidot. B15]+[FU .sym. SPM.sub.0 Q] .multidot. [K.sub.7 Q+FU.multidot. B15]B Flip Flops ##STR63## ##STR64##FAC+FAD+FAH] ##STR65## ##STR66## ##STR67##FAC+FAD+FAH] ##STR68##B.sub.2 T = B.sub.0 Q+B.sub.1 Q+ ##STR69## ##STR70## ##STR71## ##STR72## ##STR73##B.sub.3 T = B.sub.0 Q+B.sub.1 Q+B.sub.2 Q+ ##STR74## ##STR75##W1+W4+W5+FE+FM] ##STR76##C-RegisterC.sub.0 D = I4 ##STR77##C.sub.1 D = I5 ##STR78## ##STR79## ##STR80##C.sub.3 D = I7 ##STR81##D-RegisterD.sub.11 D = P2.multidot. (FA+FC)+B11.multidot. FJ+B10.multidot.(FR+FS)+M.sub.0 Q.multidot. FK+.SIGMA.A.multidot. FB+(FD+FG)(B.sub.3 Q+B.sub.2Q).multidot. A.sub.0 Q ##STR82##FG.multidot. (B.sub.3 Q+B.sub.2 Q)+ W0]M-RegisterM.sub.11 D = P43=B9.multidot. FAL+(FD+FY).multidot. SPM.sub.0 Q+D.sub.0 Q.multidot. FR+FK.multidot. K.sub.7 Q+(.SIGMA.M.multidot.B10).multidot. (FAI+FAG.multidot. P105+(.SIGMA.M.multidot. B11).multidot. [FAG.multidot.P105+ ##STR83## ##STR84##FK+FR+FD+FAI+FAG.multidot. P105+ ##STR85##M-Adder.SIGMA.M = M.sub.0 Q .sym. K.sub.8 Q .sym. P44A.sub.1 =A.sub.2 =B.sub.1 =B.sub.2 =GroundC.sub.N = K.sub.8 QC.sub.N+1 M = (M.sub.0 Q.multidot. K.sub.8 Q)+(M.sub.0 Q.multidot.P43)+(K.sub.8 Q.multidot. P43) ##STR86## ##STR87##0 - ##STR88##W Flip Flops ##STR89##W.sub.0 Clock = P3.multidot. B0W.sub.1 T = W.sub.0 Q+FZ.multidot. Y10W.sub.1 Clock = P3.multidot. B0W.sub.2 T = W.sub.0 Q.multidot. W.sub.1 QW.sub.2 Clock = P3.multidot. B0Z-RegisterZ.sub.N D = A.sub.0 Q (Delayed) ##STR90##C.sub.15-6 -RegisterC.sub.15 D = A.sub.0 Q (Delayed)C.sub.N Clock = OW-8 (Turret Select)K-RegisterK.sub.0 D = FB ##STR91##K.sub.1 D = (FA+FB).multidot. C.sub.3 Q.multidot. A.sub.0 Q+FV+ ##STR92## ##STR93## ##STR94##K.sub.2 D = FAD.multidot. A.sub.0 Q+FC ##STR95##K.sub.3 D = FAD.multidot. K.sub.2 Q+FL+FV.multidot. D.sub.0 Q ##STR96##B0.multidot. W7+FV+FAD]K.sub.4 D = FL.multidot. Y4+ D.sub.1 Q+FAD.multidot. K.sub.3 Q ##STR97##B0.multidot. W7+FV+FAD]K.sub.5 D = Y2.multidot. W0+FV.multidot. D.sub.2 Q+FAD.multidot. K.sub.4Q+FL.multidot. K.sub.5 Q ##STR98##B0.multidot. W7+FV+FAD] ##STR99## ##STR100##FAC+FAF+FAD+FT+FU+FX+W0+(FD+FG).multidot. (B.sub.3 Q+B.sub.2 Q)] ##STR101## ##STR102##FR+FD+FAI+FAG.multidot. P105+ ##STR103##K.sub.10 D = I2 ##STR104##K.sub.11 D = I3 ##STR105##I Flip-Flops (FIG. 13)I.sub.1 T = V.sub.CC ##STR106##I.sub.2 T = V.sub.CC ##STR107##I.sub.3 T = V.sub.CC ##STR108##I.sub.4 T = V.sub.CC ##STR109##L-RegisterL.sub.1 D = 0 ##STR110## ##STR111##L.sub.2 D = P87L.sub.2 Clock = W0A Overflow Flip-Flop (OF.sub.i) ##STR112## ##STR113## ##STR114##Lamp Display Register (L.sub.3 -L.sub.15)L.sub.15 D = A.sub.0 QL.sub.N Clock = OW-11Numeric Display Register (N.sub.0 -N.sub.15)N.sub.15 D = A.sub.0 QN.sub.N Clock = OW-9______________________________________
TABLE II______________________________________P TermsP0 = .SIGMA.AP1 = .SIGMA.MP2 = [I0.multidot.B7+I1.multidot.B6+I2.multidot.B5+I3.multidot.B4+I4.multidot.B3+I5.multidot.B2+I6.multidot.B1+I7.multidot.B0.multidot. ##STR115##I0.multidot.B15+I4.multidot.B11.multidot.C.sub.3 Q.multidot.C.sub.2Q+(I3.multidot.B12).multidot. ##STR116## ##STR117##P3.DELTA. = P3 delayed clockP4 = A.sub.0 Q ##STR118## ##STR119## ##STR120## ##STR121##P15 = C.sub.2 Q.multidot.C.sub.3 QP16 = Y38.multidot.C.sub.0 Q.fwdarw.FT+FUP17 = FW+FX+FU+FT+FAC+FAQP18 = FT+FU+FXP21 = B.sub.2 Q+B.sub.3 Q ##STR122## ##STR123## ##STR124##P26 = K.sub.4 Q+K.sub.5 Q ##STR125## ##STR126##P85P29 = FA+FCP30 = FC+FBP31 = FA+FB ##STR127##P35 = W0+W7P36 = W2+W5P37 = FD+FG ##STR128##P39 = FAM+FZP40 = (FR+FS+FAI+FJ)+(FAM+FZ)P41 = FR+FS ##STR129## ##STR130##P44 = P44A+P44B = B10.multidot.(FAI+FAG.multidot.P105)+B11.multidot. ##STR131##P44A = (FAI+FAG.multidot.P105)B10 ##STR132## ##STR133##(FN+FO)+[FD+ (B.sub.3 Q+B.sub.2 Q).(FAL+FY)(B.sub.3 Q+B.sub.2 Q)]M.sub.0 Q+P88P48 = FAL+FY+FN+FQ+B.sub.2 Q.multidot.FE+FW+FX+FU+FT+FAC+FC+FB+FD+FAQP50 = P133.multidot..sup.--A.multidot..sup.--B.multidot..sup.--CP51 = P133.multidot..sup.--A.multidot..sup.--B.multidot.CP52 = P133.multidot..sup.--A.multidot.B.multidot..sup.--CP53 = P133.multidot..sup.--A.multidot.B.multidot.CP54 = P133.multidot.A.multidot..sup.--B.multidot..sup.--CP55 = P133.multidot.A.multidot..sup.--B.multidot.CP56 = P133.multidot.A.multidot.B.multidot..sup.--CP57 = P133.multidot.A.multidot.B.multidot.CP58 = P134.multidot..sup.--A.multidot..sup.--B.multidot..sup.--CP59 = P134.multidot..sup.--A.multidot..sup.--B.multidot.CP60 = P134.multidot. .sup.--A.multidot.B.multidot..sup.--CP61 = P134.multidot..sup.--A.multidot.B.multidot.CP62 = P134.multidot.A.multidot..sup.--B.multidot..sup.--CP63 = P134.multidot.A.multidot..sup.--B.multidot.CP64 = P134.multidot.A.multidot.B.multidot..sup.--CP65 = P134.multidot.A.multidot.B.multidot.C ##STR134## ##STR135## ##STR136##P85 = SPM.sub.0 Q (all registers)P87 = External interruptP88 = FAQ.multidot.SPM.sub.0 Q+FB.multidot.SPM.sub.0 Q+FC.multidot..SIGMA.A+FAC.multidot.A.sub.0 QP89 = External interruptP90 = (FR+FS)+(FD+FG) ##STR137##P92 = B7.multidot.B.sub.4 Q.multidot.(P36+P91) = Cycle initiate commandP93 = B3.multidot.B.sub.4 Q.multidot.(P36+P91) = Restore command ##STR138##P98 = FAL+FY ##STR139## ##STR140## ##STR141## ##STR142## ##STR143##P105 = P50.multidot.DI-0+P51.multidot.DI-1+P52.multidot.DI-2+P53.multidot.DI-3+P54.multidot.DI-4+P55.multidot.DI-5+P56.multidot.DI-6+P57.multidot.DI-7+P58.multidot.DI-8+P59.multidot.DI-9+P60.multidot.DI-10+P61.multidot.DI-11(Discrete Input DI-n To Data Processor)P106 = FAH.multidot.P51 = DO-2 (Resets L.sub.1 flip flop during powerturn-on)P108 = IW-0.multidot.P50+IW-1.multidot.P51+IW-2.multidot.P52+IW-3.multidot.P53+IW-4.multidot.P54+IW-5.multidot.P55+IW-6.multidot.P56+IW-7.multidot.P57 ##STR144## ##STR145## ##STR146## ##STR147## ##STR148## ##STR149##P115 = FAQ+FAB ##STR150##P120 = SPM.sub.0 Q (4 registers)P121 = SPM.sub.0 Q (4 registers) ##STR151## ##STR152## ##STR153## ##STR154## ##STR155## ##STR156## ##STR157## ##STR158## ##STR159## ##STR160## ##STR161##P511 = FN+FQMemory Output LinesI.sub.7 - Most Significant BitI.sub.6 - Second Significant BitI.sub.5 - Third Significant BitI.sub.4 - Fourth Significant BitI.sub.3 - Fifth Significant BitI.sub.2 - Sixth Significant BitI.sub.1 - Seventh Significant BitI.sub.0 - Least Significant BitY Terms ##STR162## ##STR163## ##STR164##Y4 = K.sub.1 Q.multidot.K.sub.2 Q+Y6Y5 = Y3+K.sub.2 Q ##STR165## ##STR166## ##STR167##Y11 = C.sub.2 Q+C.sub.3 Q ##STR168## ##STR169##Terms ##STR170## ##STR171## ##STR172## ##STR173## ##STR174## ##STR175## ##STR176## ##STR177## ##STR178## ##STR179## ##STR180## ##STR181## ##STR182## ##STR183## ##STR184##B15 = B.sub.3 Q.multidot.B.sub.2 Q.multidot.B.sub.1 Q.multidot.B.sub.0 QW Terms ##STR185## ##STR186## ##STR187## ##STR188## ##STR189## ##STR190## ##STR191##W7 = W.sub.2 Q.multidot.W.sub.1 Q.multidot.W.sub.0 QInput WordsIW-0 = B11.multidot.P3+B10.multidot.P2+B9.multidot.P1+B8.multidot.P0+B7.multidot.Spare+B6.multidot.J2+B5.multidot.J1+B4.multidot.J0+B3.multidot.M2+B2.multidot.M1+B1.multidot.M0+B0.multidot.Spare (Selector Switch Scanout andInput Channel-0)IW-1 = B7.multidot.SA+B6.multidot.SB+B5.multidot.SC+B4.multidot.SD+B3.multidot.SE+B2.multidot.Spare+ ##STR192##and Input Channel-1)IW-2 = SpareIW-3 = B11.multidot.S11+B10.multidot.S10+B9+S9+B8.multidot.S8+B7.multidot.S7+B6.multidot.S6+B5.multidot.S5+B4.multidot.S4+B3.multidot.S3+B2.multidot.S2+B1.multidot.S1+B0.multidot.Spare (Auxiliary Control Signals)IW-4 = B11.multidot.T0+B10.multidot.T1+B9.multidot.T2+B8.multidot.T3+B7.multidot.T4+B6.multidot.T5+B5.multidot.T6+B4.multidot.T7+B3.multidot.Spare+B2.multidot.Spare+B1.multidot.Spare+B0.multidot.T8(Elemental Tape Reader Inputs)IW-5 = NRR.sub.0 Q (Numeric Display Register)IW-6 = SpareIW-7 = SpareOutput Words ##STR193## ##STR194## ##STR195## ##STR196## ##STR197## ##STR198## ##STR199## ##STR200## ##STR201##Discrete OutputsD0-0 = FAH.multidot.P50D0-1 = FAH.multidot.P51D0-2 = FAH.multidot.P52D0-3 = FAH.multidot.P53D0-4 = FAH.multidot.P54D0-5 = FAH.multidot.P55D0-6 = FAH.multidot.P56D0-7 = FAH.multidot.P57D0-8 = FAH.multidot.P58D0-9 = FAH.multidot.P59D0-10 = FAH.multidot.P60D0-11 = FAH.multidot.P61S TermsS3 = 1MHZ ##STR202## ##STR203## ##STR204##BS7 = Bit time 7 in the servo bit time counter ##STR205##.0.A = N.sub.22 Q.0.B = N.sub.23 Q______________________________________
TABLE III______________________________________ ##STR206## ##STR207## ##STR208## ##STR209## ##STR210## ##STR211## ##STR212## ##STR213## ##STR214## ##STR215## ##STR216## ##STR217## ##STR218## ##STR219## ##STR220## ##STR221## ##STR222## ##STR223## ##STR224## ##STR225## ##STR226##FU = Y38 .multidot. C.sub.1 Q .multidot. C.sub.0 Q ##STR227## ##STR228## ##STR229## ##STR230##FZ = (C.sub.3 Q + C.sub.2 Q)W2 ##STR231## ##STR232## ##STR233## ##STR234## ##STR235##FAG = C.sub.3 Q .multidot. C.sub.2 Q .multidot. C.sub.1 Q .multidot. W1 ##STR236## ##STR237##FAJ = L.sub.1 Q .multidot. W3 ##STR238##FAL = K.sub.1 Q .multidot. W4FAM = K.sub.1 Q .multidot. W5FAN = K.sub.1 Q .multidot. W6FAO = K.sub.1 Q .multidot. W7 ##STR239##FAQ = C.sub.1 Q .multidot. C.sub.0 Q .multidot. Y39______________________________________
TABLE IV__________________________________________________________________________Logic CardA B C D K W SPM IFA-1 IFA-2 IFA-3Reference FigurePin 6 7 8 9 10 11 12 13 14 15__________________________________________________________________________ 1 Vcc Vcc Vcc Vcc Vcc Vcc Vcc Vcc Vcc Vcc 2 -- -- -- B14 ##STR240## -- -- C9Q W0 -- 3 Vcc Vcc Vcc Vcc Vcc Vcc Vcc Vcc Vcc Vcc 4 M6Q -- -- B15 FC -- -- C6Q -- -- 5 M8Q -- -- B13 ##STR241## P27 -- C8Q OW-7 -- 6 M7Q B9 -- ##STR242## ##STR243## P24 -- C7Q -- -- 7 ##STR244## 8 MHZ I2 I0 ##STR245## ##STR246## -- -- S1 -- 8 M.sub.9 Q B8 -- I2 ##STR247## Y11 -- P105 -- -- 9 ##STR248## -- I3 B4 -- ##STR249## -- P104 S0 --10 -- B6 I4 B7 -- KIQ -- OW-6 -- -- 11 P110 -- I5 I5 -- ##STR250## -- DI-5 M1 ##STR251## 12 ##STR252## B5 I7 A FAB ##STR253## -- DI-6 -- -- 13 -- -- ##STR254## I7 FK P48 -- DI-7 -- ##STR255## 14 P110 B4 ##STR256## B2 P27 -- -- DI-4 ##STR257## ##STR258## 15 FK -- ##STR259## I6 FA1 K5Q -- P60 -- -- 16 FW B3 FAG B0 Y11 Y10 -- P59 -- ##STR260## 17 -- -- ##STR261## I4 FL W0 -- P58 B0 --18 W0 B2 P17 B3 D0Q -- -- P57 -- -- 19 ##STR262## B0 ##STR263## B6 Y2 K4Q -- P56 B3 ##STR264## 20 ##STR265## B1 W1 ##STR266## D2Q W7 -- P55 B1 ##STR267## 21 P16 ##STR268## C3Q B5 B11 K3Q -- P54 -- -- 22 P115 -- P16 I1 DIQ ##STR269## -- P61 B2 -- 23 ##STR270## B4Q ##STR271## P102 -- -- -- L1Q M0 -- 24 ##STR272## -- ##STR273## P37 W0 ##STR274## -- DI-9 T8 -- 25 D.sub.0 Q P93 D1Q ##STR275## W1 ##STR276## -- DI-10 S2 -- 26 P97 -- -- P40 W7 ##STR277## -- -- M2 TX(0) 27 P114 B7 ##STR278## ##STR279## -- K3Q -- DI-11 -- B5 28 ##STR280## P92 ##STR281## ##STR282## B0 W1 -- DI-8 S3 -- 29 P98 -- ##STR283## B12 C3Q FA1 -- C10Q S9 B6 30 -- -- FU P39 ##STR284## ##STR285## ##STR286## -- -- --31 FAB P3 Y2 P101 Y10 P87 -- C12Q P3 B7 32 P108 -- ##STR287## ##STR288## P99 FJ ##STR289## C11Q S11 -- 33 FAE -- FY P2 FB ##STR290## -- ##STR291## T1 B4 34 K.sub.1 Q B15 FY B11 ##STR292## P26 ##STR293## ##STR294## P2 -- 35 FC ##STR295## I0 P41 FZ P40 -- ##STR296## B10 P51 36 P28 ##STR297## -- P29 -- ##STR298## ##STR299## OW-8 T2 -- 37 ##STR300## P109 ##STR301## P4 P0 FZ -- ##STR302## B9 B0 38 FAQ -- -- P21 -- ##STR303## ##STR304## OW-7 B11 -- 39 ##STR305## -- FAQ P105 ##STR306## ##STR307## -- ##STR308## T0 P104 40 ##STR309## P22 ##STR310## P99 -- ##STR311## ##STR312## ##STR313## B.sub.8 -- 41 P21 -- ##STR314## P22 ##STR315## ##STR316## -- ##STR317## P1 -- 42 B9 -- -- FAG ##STR318## -- ##STR319## OW10 T3 -- 43 FX P21 D0Q FK B14 ##STR320## -- ##STR321## S8 TTY"C" 44 P37 ##STR322## -- W0Q P85 P37 ##STR323## ##STR324## P0 -- 45 ##STR325## -- FAB ##STR326## ##STR327## ##STR328## -- FAH IW-0 "C" 46 -- P24 -- ##STR329## -- P41 ##STR330## DW-9 S10 -- 47 ##STR331## -- ##STR332## B0.DELTA. -- P98 -- P104 IW-4 "C" 48 Y11 ##STR333## -- ##STR334## ##STR335## L1Q ##STR336## C13Q P4 -- 49 B0 -- P102 ##STR337## -- P2 -- P50 IW-3 TS-7 50 -- ##STR338## -- ##STR339## ##STR340## -- C P51 YL5 TS-5 51 FU -- -- Y11 -- ##STR341## -- P53 S7 TS-6 52 -- ##STR342## -- W1 -- P97 B P52 YL4 TS-4 53 B15 -- -- K3Q P4 ##STR343## -- OW-11 J2 V.sub.S 54 ##STR344## ##STR345## -- K4Q ##STR346## K2Q A -- S6 -- 55 P103 -- I1 ##STR347## ##STR348## P39 -- IW-5 T6 TX(1) 56 ##STR349## ##STR350## -- ##STR351## ##STR352## Y11 ##STR353## IW-6 -- IW-1 57 ##STR354## -- -- B10 P53 ##STR355## -- IW-7 B7 B1 58 -- P14 -- ##STR356## P51 B2Q P47 IW-4 T5 B2 59 -- ##STR357## Y11 P44A P51 P17 -- P108 B4 B3 60 P85 ##STR358## -- ##STR359## -- P47 -- OW-11 B6 -- 61 ##STR360## -- -- B P52 P88 -- OW-4 T7 -- 62 P2 -- -- -- P28 P511 ##STR361## OW-5 B5 -- 63 ##STR362## -- ##STR363## FY P115 M0Q -- IW-3 J0 TS-3 64 FB B14 -- FV ##STR364## ##STR365## P85 OW-3 T4 -- 65 P0 -- ##STR366## W0 ##STR367## -- -- IW-0 S5 TS-2 66 P4 B13 ##STR368## P114 P50 L3Q -- IW-2 J1 -- 67 D1-7 -- ##STR369## ##STR370## ##STR371## -- -- D1-3 MFE TS-0 68 ##STR372## B12 FX ##STR373## K2Q P3 ##STR374## IW-1 S4 -- 69 ##STR375## -- FW C ##STR376## P11 -- D1-2 XL4 TS-1 70 M.sub.1 Q B11 FAE -- K3Q -- ##STR377## D1-1 XL2 -- 71 M.sub.0 Q -- -- ##STR378## ##STR379## ##STR380## -- ##STR381## -- C14Q 72 M.sub.2 Q B2Q Y11 P511 P7 P85 ##STR382## D1-0 YL1 OW-8 73 M.sub.3 Q -- ##STR383## ##STR384## ##STR385## -- -- ##STR386## -- -- 74 FT B10 W0 ##STR387## ##STR388## -- ##STR389## ##STR390## XL1 -- 75 M.sub.4 Q -- P14 ##STR391## ##STR392## ##STR393## -- C14Q XL5 -- 76 M.sub.5 Q -- B11 D5Q P26 -- ##STR394## ##STR395## YL2 --77 GRD GRD GRD GRD GRD GRD GRD GRD GRD GRD78 -- -- P101 D6Q P26 -- -- C15Q YL3 --79 GRD GRD GRD GRD GRD GRD GRD GRD GRD GRD80 -- -- -- D7Q -- -- -- A0Q -- --90 -- -- -- ##STR396## -- -- -- -- -- -- 91 -- -- -- ##STR397## -- -- -- -- -- --92 -- -- -- P116 -- -- -- -- -- -- 93 -- -- -- ##STR398## -- -- -- -- -- --__________________________________________________________________________ Logic Card Servo Common Servo Channel Reference Figure Pin 16 17__________________________________________________________________________ 1 GND 8 MHZ 2 GND -- 3 -- -- 4 -- Resolver Rotor 5 ##STR399## -- 6 -- -- 7 -- +30 V 8 -- Resolver Ret. 9 .phi.A Resolver Ret. 10 ##STR400## -- 11 .phi.B -- 12 N20Q -- 13 W.sub.0 -- 14 -- -- 15 ##STR401## 16 .DELTA.X0Q -- 17 -- -- 18 SD-13 -- 19 FRQ +Ramp 20 S101 -Ramp 21 S118 -- A -30 V -- B 68 VAC -- C CT +20 V D -21 V .phi.B E +30 V .phi.A F -15 V -- G -- -- H +Ramp S3 = 1 MHZ I -- +70 V J +15 V -- K -RAMP S118 L +20 V ##STR402## M 250 KHZ 1/0-1 N 250 KHZ S101 O -- -- P ##STR403## 1/0-2 Q -- -- R 8 MHZ S100 S -- N20Q T 8 MHZ S103 U -- -30 V V S3 -21 V W S3 -- X ##STR404## -- Y -- -- Z -- 250 KHZ 2A -- 70 V Ret 3A -- Motor High 4A -- -- 5A -- Motor Low 6A -- Motor Low Res. 2B -- .phi.B 3B -- .phi.B 4B -- -- 5B -- .phi.A 6B -- .phi.A A6 S104(B) -- B7 S103(B) -- T1 1 MH.sub.2 -- T5 -- -- .mu. ##STR405## --__________________________________________________________________________
TABLE V______________________________________Micro Operation Word Time Bit Times______________________________________FA 0 16FB 0 16FC 0 16FD 1 12FE 2 8FF 3 1FG 4 12FH 5 8FI 6 8FJ 7 12FK 1 12FL 1 1FM 2 8FN 3 8FO 4 12FP 5 8FQ 6 8FR 7 12FS 7 12FT 1 16FU 1 16FV 1 16FW 1 16FX 1 16FY 1 16FZ 2 8FAA -- --FAB 1 16FAC 1 16FAD 1 16FAE 1 1-16FAF 1 1-16FAG 1 12FAH 1 12FAI 1 12FAJ 3 16FAK 3 16FAL 4 16FAM 5 8FAN 6 --FAO 7 12FAP -- --FAQ 1 16______________________________________
CONCLUSION
Although there has been described above a specific arrangement of a numerical control system in accordance with the invention for the purpose of illustrating the manner in which the invention may be used to advantage, it will be appreciated that the invention is not limited thereto. Accordingly, any and all modifications, variations or equivalent arrangements which may occur to those skilled in the art should be considered to be within the scope of the invention.
Claims
  • 1. A machine control system comprising:
  • an operator input device for generating a machine direction signal in response to an operator action;
  • an integrated circuit stored program computer including
  • (a) an integrated circuit read only main memory for storing instructions,
  • (b) an integrated circuit alterable memory for storing computer operands,
  • (c) input logic for generating a computer input signal in response to the machine direction signal generated by said operator input device under control of the instructions stored in said main memory,
  • (d) storing logic for storing a machine direction related operand in said alterable memory under control of the instructions stored in said main memory in response to the computer input signal generated by said input logic,
  • (e) processor logic for processing a machine direction related operand stored in said alterable memory under control of the instructions stored in said main memory, and
  • (f) an output circuit for generating a machine direction command signal in response to the processing of the machine direction related operand by said processor logic; and
  • a machine controller for controlling direction of a machine in response to the machine direction command signal generated by said output circuit.
  • 2. A machine control system, said system comprising:
  • an operator direction control device for generating an operator direction control signal to control direction of a machine;
  • an integrated circuit processor for controlling direction of a machine, said processor including
  • (a) an integrated circuit main memory for storing a program,
  • (b) integrated circuit input logic for generating a direction control input signal in response to the operator direction control signal generated by said operator direction control device under control of the program stored in said main memory,
  • (c) integrated circuit processing logic for processing the direction control input signal under control of the program stored in said main memory, and
  • (d) integrated circuit direction control output logic for generating a direction control output signal under control of the program stored in said main memory in response to the processing of the direction control input signal by said processing logic; and
  • a controller for controlling direction of motion of a machine in response to the direction control output signal generated by said direction control output logic.
  • 3. The system as set forth in claim 1 above, further comprising a relay for controlling a machine in response to the machine direction command signal.
  • 4. The system as set forth in claim 1 above, wherein said system is a numerical control system and wherein said system further comprises numerical control means for controlling a numerically controlled machine in response to the machine direction command signal.
  • 5. The system as set forth in claim 4 above, further comprising a machine tool for cutting a part under control of said numerical control means.
  • 6. A machine control system comprising:
  • an operator direction control device for generating a machine direction control signal in response to an operator action;
  • a stored program computer for processing digital operands under control of a stored program, said computer including
  • (a) an integrated circuit read only main memory for storing a program,
  • (b) an integrated circuit alterable memory for storing operands,
  • (c) storing logic for storing an operand in said alterable memory under control of the program stored in said main memory in response to the machine direction control signal generated by said operator direction control device,
  • (d) processing logic for processing operands stored in said alterable memory under control of the program stored in said main memory,
  • (e) control output logic for generating a machine direction control signal under control of the program stored in said main memory in response to an operand stored in said alterable memory, and
  • (f) motion display output logic for generating a motion display output signal under control of the program stored in said main memory in response to an operand stored in said alterable memory;
  • a machine controller for controlling direction of motion of a machine in response to the machine motion direction control signal generated by said control output logic; and
  • a motion display for displaying motion information to an operator in response to the motion display output signal generated by said motion display output logic.
  • 7. The system as set forth in claim 1 above, further comprising a machine for performing a machine operation in response to the machine command signal, wherein said machine includes an error mechanism, wherein said processor logic includes means for processing the computer operands stored in said alterable memory to compensate for said machine error mechanism under control of the instructions stored in said read only main memory, and wherein said machine direction command signal is an error compensated machine direction command signal to compensate for the machine error mechanism generated in response to the processing of the machine direction related operand by said processing logic.
  • 8. The system as set forth in claim 1 above, wherein said processor logic includes means for processing the computer operands stored in said alterable memory to compensate for a machine error mechanism, said system further comprising a machine for performing an error compensated machine operation under control of the machine controller.
  • 9. A machine control system comprising:
  • an operator input device for generating a machine turret signal in response to an operator action;
  • an integrated circuit stored program computer including
  • (a) an integrated circuit read only main memory for storing instructions,
  • (b) an integrated circuit alterable memory for storing computer operands,
  • (c) input logic for generating a computer input signal in response to the machine turret signal generated by said operator input device under control of the instructions stored in said main memory,
  • (d) storing logic for storing a machine turret related operand in said alterable memory under control of the instructions stored in said main memory in response to the computer input signal generated by said input logic,
  • (e) processor logic for processing a machine turret related operand stored in said alterable memory under control of the instructions stored in said main memory, and
  • (f) an output circuit for generating a machine turret command signal in response to the processing of the machine turret related operand by said processor logic;
  • a machine controller for controlling a machine turret in response to the machine turret command signal generated by said output circuit; and
  • a machine turret for positioning a machine element under control of the machine controller.
  • 10. The system as set forth in claim 1 above, further comprising a magnetic control element for providing a mechanical control operation under control of the machine controller.
  • 11. The system as set forth in claim 1 above, wherein said output circuit includes a pulse modulation circuit for generating the machine direction command signal as a pulse modulated machine direction command signal to control a machine in response to the computer operands stored in said alterable memory.
  • 12. The system as set forth in claim 1 above, wherein said output circuit includes a pulse modulation circuit for generating the machine direction command signal as a pulse width modulated machine direction command signal in response to the computer operands stored in said alterable memory.
  • 13. The system as set forth in claim 1 above, further comprising a frequency circuit for generating a frequency-related signal in response to the machine direction command signal.
  • 14. A control system comprising:
  • an operator input device for generating an operator command signal;
  • a stored program data processor for processing digital information under control of a stored program, said data processor including
  • (a) an integrated circuit read only main memory for storing a control program,
  • (b) an integrated circuit alterable memory for storing operands,
  • (c) operator input logic for generating an operator input signal in response to the operator command signal generated by said operator input device,
  • (d) storing logic for storing operands in said alterable memory under control of the program stored in said main memory in response to the operator input signal generated by said operator input logic,
  • (e) processing logic for processing the operands stored in said alterable memory under control of the program stored in said main memory, and
  • (f) output logic for generating a control signal under control of the program stored in said main memory in response to the processing of operands by said processing logic; and
  • a process controller for controlling a process in response to the control signal generated by said output logic.
  • 15. The system as set forth in claim 1 above, further comprising a digital-to-analog converter for generating an analog signal in response to the machine direction command signal.
  • 16. The system as set forth in claim 1 above, further comprising an amplifier for generating an amplified signal in response to the machine direction command signal.
  • 17. The system as set forth in claim 1 above, further comprising a power amplifier for generating a power-amplified signal in response to the machine direction command signal.
  • 18. The system as set forth in claim 1 above, further comprising means for generating a square wave control signal in response to the machine direction command signal.
  • 19. The system as set forth in claim 1 above, further comprising means for generating a velocity signal in response to the machine direction command signal.
  • 20. The system as set forth in claim 1 above, further comprising means for generating a frequency-related signal in response to the machine direction command signal.
  • 21. The system as set forth in claim 1 above, further comprising a phase locked loop for controlling phase relationships in response to the machine direction command signal.
  • 22. A machine control system comprising:
  • an operator input device for generating a machine direction signal in response to an operator action;
  • an integrated circuit stored program computer including
  • (a) an integrated circuit read only main memory for storing instructions,
  • (b) an integrated circuit alterable memory for storing computer operands,
  • (c) an error detector for detecting a computer error under control of the instructions stored in said main memory,
  • (d) an error output circuit for generating an error output signal under control of the instructions stored in said main memory,
  • (e) input logic for generating a computer input signal in response to the machine direction signal generated by said operator input device under control of the instructions stored in said main memory,
  • (f) storing logic for storing a machine direction related operand in said alterable memory under control of the instructions stored in said main memory in response to the computer input signal generated by said input logic,
  • (g) processor logic for processing a machine direction related operand stored in said alterable memory under control of the instructions stored in said main memory, and
  • (h) an output circuit for generating a machine direction command signal in response to the processing of the machine direction related operand by said processor logic;
  • a machine controller for controlling direction of a machine in response to the machine direction command signal generated by said output circuit; and
  • an error display for displaying an error condition in response to the error output signal generated by said error output circuit.
  • 23. The system as set forth in claim 1 above, further comprising an elemental extremity for performing an extremity-related operation in response to the machine direction command signal.
  • 24. The system as set forth in claim 1 above, further comprising a minimal interface circuit for controlling a machine in response to the machine direction command signal.
  • 25. A machine control system comprising:
  • a feedback device for generating a feedback signal related to a condition of a machine;
  • an operator input device for generating a machine direction signal in response to an operator action;
  • an integrated circuit stored program computer including
  • (a) an integrated circuit read only main memory for storing instructions,
  • (b) an integrated circuit alterable memory for storing computer operands,
  • (c) input logic for generating a computer input signal in response to the machine direction signal generated by said operator input device under control of the instructions stored in said main memory,
  • (d) feedback logic for generating a computer feedback signal in response to the feedback signal generated by said feedback device under control of the instructions stored in said main memory,
  • (e) storing logic for storing a machine direction related operand in said alterable memory under control of the instructions stored in said main memory in response to the computer input signal generated by said input logic,
  • (f) processor logic for processing a machine direction related operand stored in said alterable memory under control of the instructions stored in said main memory in response to the computer feedback signal generated by said feedback logic, and
  • (g) an output circuit for generating a machine direction command signal in response to the processing of the machine direction related operand by said processor logic; and
  • a controller for controlling direction of a machine in response to the machine direction command signal generated by said output circuit.
  • 26. The system as set forth in claim 1 above, wherein said output circuit includes a sequential circuit for generating the machine direction command signal as a sequence of digital bits.
  • 27. A machine control system comprising:
  • an operator input device for generating a rotation input signal;
  • a stored program computer for generating a rotation command output signal in response to the rotation input signal, said computer including
  • (a) an integrated circuit main memory for storing computer instructions,
  • (b) an integrated circuit alterable memory for storing at least one operand,
  • (c) input logic for generating a computer input signal in response to the rotation input signal generated by said operator input device,
  • (d) processor logic for processing the operand stored in said alterable memory under control of the instructions stored in said main memory in response to the rotation related computer input signal generated by said input logic, and
  • (e) output logic for generating the rotation command output signal in response to the processing of the operand stored in said alterable memory under control of the computer instructions stored in said main memory; and
  • a controller for controlling rotational path of a machine in response to the rotation command output signal generated by said output logic.
  • 28. A machine control system comprising:
  • an operator command device for generating operator input signals in response to operator activation, said operator input device including
  • (a) a motion command operator device for generating an operator motion command signal in response to operator action,
  • (b) a stop command operator device for generating an operator stop command signal in response to operator action, and
  • (c) a direction command operator device for generating an operator direction command signal in response to operator action;
  • an integrated circuit computer for controlling a machine, said computer including
  • (a) an integrated circuit read only main memory for storing a computer program,
  • (b) integrated circuit motion command input logic for generating a motion command input signal under control of the computer program stored in said main memory in response to the operator motion command signal generated by said motion command operator device,
  • (c) integrated circuit stop command input logic for generating a stop command input signal under control of the computer program stored in said main memory in response to the operator stop command signal generated by said stop command operaator device,
  • (d) integrated circuit direction command input logic for generating a direction command input signal under control of the computer program stored in said main memory in response to the operator direction command signal generated by said direction command operator device,
  • (e) integrated circuit motion control processing logic for generating a motion control output signal under control of the computer program stored in said main memory in response to the motion command input signal generated by said motion command input logic,
  • (f) integrated circuit stop control processing logic for generating a stop control output signal under control of the computer program stored in said main memory in response to the stop command input signal generated by said stop command input logic, and
  • (g) integrated circuit direction control processing logic for generating a direction control output signal under control of the computer program stored in said main memory in response to the direction command input signal generated by said direction command input logic; and
  • a controller for controlling a machine, said controller including
  • (a) a motion controller for controlling motion of a machine in response to the motion control output signal generated by said motion control processing logic,
  • (b) a stop controller for controlling stopping of motion of said machine in response to the stop control output signal generated by said stop control processing logic, and
  • (c) a direction controller for controlling direction of motion of said machine in response to the direction control output signal generated by said direction control processing logic.
  • 29. A machine control system comprising:
  • an operator input device for generating a motor speed input signal;
  • a stored program computer for generating a motor speed command output signal in response to the motor speed input signal, said computer including
  • (a) an integrated circuit main memory for storing computer instructions,
  • (b) an integrated circuit alterable memory for storing at least one operand,
  • (c) input logic for generating a computer input signal in response to the motor speed input signal generated by said operator input device,
  • (d) processor logic for processing the operand stored in said alterable memory under control of the instructions stored in said main memory in response to the motor speed related computer input signal generated by said input logic, and
  • (e) output logic for generating the motor speed command output signal in response to the processing of the operand stored in said alterable memory under control of the computer instructions stored in said main memory; and
  • a controller for controlling speed of a motor in response to the motor speed command output signal generated by said output logic.
  • 30. A machine control system comprising:
  • an operator input device for generating a velocity input signal;
  • a stored program computer for generating a velocity command output signal in response to the velocity input signal, said computer including
  • (a) an integrated circuit main memory for storing computer instructions,
  • (b) an integrated circuit alterable memory for storing at least one operand,
  • (c) input logic for generating a computer input signal in response to the velocity input signal generated by said operator input device,
  • (d) processor logic for processing the operand stored in said alterable memory under control of the instructions stored in said main memory in response to the velocity related computer input signal generated by said input logic, and
  • (e) output logic for generating the velocity command output signal in response to the processing of the operand stored in said alterable memory under control of the computer instructions stored in said main memory; and
  • a controller for controlling velocity of machine motion in response to the velocity command output signal generated by said output logic.
  • 31. A machine control system comprising:
  • a speed input device for generating a speed input signal in relation to a desired speed;
  • a stored program computer for generating a speed command output signal in response to the speed input signal, said computer including
  • (a) an integrated circuit main memory for storing computer instructions,
  • (b) an integrated circuit alterable memory for storing at least one operand,
  • (c) input logic for generating a computer input signal in response to the speed input signal generated by said speed input device,
  • (d) processor logic for processing the operand stored in said alterable memory under control of the instructions stored in said main memory in response to the computer input signal generated by said input logic, and
  • (e) output logic for generating the speed command output signal in response to the processing of the operand stored in said alterable memory with said processor logic under control of the computer instructions stored in said main memory; and
  • a controller for controlling speed of a machine in response to the speed command output signal generated by said output logic.
  • 32. A machine control system comprising:
  • a plurality of input devices for generating digital input signals, said plurality of input devices including
  • (a) an operator speed control input device for generating an operator speed control signal in response to operator activation and
  • (b) an operator stop control input device for generating an operator stop control signal in response to operator activation;
  • a stored program digital computer for controlling a machine under control of a stored program, said digital computer including
  • (a) an integrated circuit read only main memory for storing a program,
  • (b) speed control input logic for generating a speed control input signal under control of the program stored in said main memory in response to the operator speed control signal generating by said operator speed control input device,
  • (c) stop control input logic for generating a stop control input signal under control of the program stored in said main memory in response to the operator stop control signal generated by said operator stop control input device,
  • (d) speed control processing logic for generating a speed control output signal under control of the program stored in said main memory in response to the speed control input signal generated by said speed control input logic, and
  • (e) stop control processing logic for generating a stop control output signal under control of the program stored in said main memory in response to the stop control input signal generated by said stop control input logic; and
  • a machine controller for controlling a machine, said machine controller including
  • (a) a speed controller for controlling speed of a machine in response to the speed control output signal generated by said speed control processing logic and
  • (b) a stop controller for stopping motion of a machine in response to the stop control output signal generated by said stop control processing logic.
  • 33. A machine control system comprising:
  • an operator input device for generating a rotation input signal;
  • a stored program computer for generating a rotation command output signal in response to the rotation input signal, said computer including
  • (a) an integrated circuit main memory for storing computer instructions,
  • (b) an integrated circuit alterable memory for storing at least one operand,
  • (c) input logic for generating a computer input signal in response to the rotation input signal generated by said operator input device,
  • (d) processor logic for processing the operand stored in said alterable memory under control of the instructions stored in said main memory in response to the rotation related computer input signal generated by said input logic, and
  • (e) output logic for generating the rotation command output signal in response to the processing of the operand stored in said alterable memory under control of the computer instructions stored in said main memory; and
  • a digital-to-analog converter for generating an analog signal in response to the rotation command output signal generated by said output logic to control rotational path of a machine.
  • 34. The system as set forth in claim 27 above, wherein said controller includes an amplifier for generating an amplified signal in response to the output signal.
  • 35. The system as set forth in claim 27 above, wherein said controller includes a power amplifier for generating a power control signal in response to the output signal.
  • 36. The system as set forth in claim 27 above, wherein said input device includes means for generating the input signal in response to a controlled condition of a machine and wherein said computer includes means for generating the output signal in response to the input signal.
  • 37. A machine control system comprising:
  • an operator input device for generating a position input signal;
  • a stored program computer for generating a position command output signal in response to the position input signal, said computer including
  • (a) an integrated circuit main memory for storing computer instructions,
  • (b) an integrated circuit alterable memory for storing at least one operand,
  • (c) input logic for generating a computer input signal in response to the position input signal generated by said operator input device,
  • (d) processor logic for processing the operand stored in said alterable memory under control of the instructions stored in said main memory in response to the position related computer input signal generated by said input logic, and
  • (e) output logic for generating the position command output signal in response to the processing of the operand stored in said alterable memory under control of the computer instructions stored in said main memory; and
  • a controller for controlling position of a machine element in response to the position command output signal generated by said output logic.
  • 38. A machine control system comprising:
  • an operator input device for generating a mechanical position input signal;
  • a stored program computer for generating a mechanical position command output signal in response to the mechanical position input signal, said computer including
  • (a) an integrated circuit main memory for storing computer instructions,
  • (b) an integrated circuit alterable memory for storing at least one operand,
  • (c) input logic for generating a computer input signal in response to the mechanical position input signal generated by said operator input device,
  • (d) processor logic for processing the operand stored in said alterable memory under control of the instructions stored in said main memory in responses to the mechanical position related computer input signal generated by said input logic, and
  • (e) output logic for generating the mechanical position command output signal in response to the processing of the operand stored in said alterable memory under control of the computer instructions stored in said main memory; and
  • a controller for changing a mechanical position to change an operating condition of a machine in response to the mechanical position command output signal generated by said output logic.
  • 39. The system as set forth in claim 27 above, wherein said controller includes means for controlling rotational path of a machine tool in response to the rotational command output signal.
  • 40. A machine control system comprising:
  • an operator input device for generating a rotation input signal;
  • a stored program computer for generating a rotation command output signal in response to the rotation input signal, said computer including
  • (a) an integrated circuit main memory for storing computer instructions,
  • (b) an integrated circuit alterable memory for storing at least one operand,
  • (c) input logic for generating a computer input signal in response to the rotation input signal generated by said operator input device,
  • (d) processor logic for processing the operand stored in said alterable memory under control of the instructions stored in said main memory in response to the rotation related computer input signal generated by said input logic, and
  • (e) output logic for generating the rotation command output signal in response to the processing of the operand stored in said alterable memory under control of the computer instructions stored in said main memory; and
  • a closed loop controller for providing closed loop rotational path control of a machine in response to the rotation command output signal generated by said output logic.
  • 41. The system as set forth in claim 27 above, wherein said input device includes an electro-magnetic sensor for generating the input signal in response to a sensed condition.
  • 42. The system as set forth in claim 27 above, wherein said input device includes an electro-magnetic resolver for generating the input signal in response to resolver position.
  • 43. The system as set forth in claim 27 above, wherein said input device includes mechanical input device for generating the input signal in response to a mechanical condition.
  • 44. The system as set forth in claim 27 above, wherein said input device includes a mechanical switch for generating the input signal in response to switch actuation.
  • 45. A machine control system comprising:
  • an operator motion control device for generating an operator motion control signal to control motion of a machine;
  • an integrated circuit processor for controlling motion of a machine, said processor including
  • (a) an integrated circuit main memory for storing a program,
  • (b) integrated circuit input logic for generating a motion control input signal in response to the operator motion control signal generated by said operator motion control device under control of the program stored in said main memory,
  • (c) integrated circuit processing logic for processing the motion control input signal under control of the program stored in said main memory,
  • (d) integrated circuit motion control output logic for generating a motion control output signal under control of the program stored in said main memory in response to the processing of the motion control input signal by said processing logic, and
  • (e) integrated circuit operator display output logic for generating a motion display output signal under control of the program stored in said main memory in response to the processing of the motion control input signal by said processing logic;
  • a machine for providing motion in response to the motion control output signal generated by said motion control output logic; and
  • an operator display for displaying machine motion information to an operator in response to the motion display output signal generated by said operator display output logic.
  • 46. The system as set forth in claim 2 above, wherein said machine control system is a process control system, wherein said machine is a process machine, wherein the operator direction control device is a push button switch, and wherein the direction control output signal is a machine plus and minus direction control signal.
  • 47. The system as set forth in claim 32 above, wherein said machine is a machine tool, wherein said operator speed control input device is a cycle start momentary switch, wherein said operator stop control input device is a cycle stop momentary switch, and wherein said machine controller is a closed loop servo.
  • 48. The system as set forth in claim 45 above, wherein said machine control system is a machine tool control system, wherein said machine is a milling machine, and wherein said operator motion control device is a momentary switch.
CROSS-REFERENCE TO RELTATED APPLICATIONS

This application is a continuation-in-part of the chain of copending applications including 1. METHOD AND APPARATUS FOR PROCESSING THE DIGITAL OUTPUT OF AN INPUT MEANS Ser. No. 879,293 filed on Nov. 24, 1969 by Gilbert P. Hyatt now abandoned in favor of continuing application Ser. No. 101,881 and 2. FACTORED DATA PROCESSING SYSTEM FOR DEDICATED APPLICATIONS Ser. No. 101,881 filed on Dec. 28, 1970 by Gilbert P. Hyatt; wherein the benefit of the filing dates of these two applications is herein claimed under 35 USC 120, 35 USC 121, and other authorities provided therefor; wherein the instant application is further related to applications 3. INTERACTIVE CONTROL SYSTEM Ser. No. 101,449 filed on Dec. 28, 1970 by Lee, Cole, Hirsch, Hyatt, and Wimmer now abandoned in favor of continuing application Ser. No. 354,590 and 4. INTERACTIVE CONTROL SYSTEM Ser. No. 354,590 filed on Apr. 24, 1973 by Lee, Cole, Hirsch, Hyatt, and Wimmer now U.S. Pat. No. 4,038,640 issued on July 26, 1977; and wherein said applications Ser. No. 879,293; Ser. No. 101,881; and Ser. No. 101,449 are herein incorporated-by-reference as if fully set forth at length herein.

US Referenced Citations (21)
Number Name Date Kind
3088661 Brigham et al. May 1963
3142820 Daniels Jul 1964
3187321 Kameny Jun 1965
3209074 French Sep 1965
3297107 Shipp Jan 1967
3315235 Carnevale et al. Apr 1967
3332071 Goldman et al. Jul 1967
3346853 Koster Oct 1967
3356836 Stenby Dec 1967
3389404 Koster Jun 1968
3398241 Lee Aug 1968
3462742 Miller et al. Aug 1969
3569814 Rosenberg Mar 1971
3573738 Bottles et al. Apr 1971
3593313 Tomaszewski Jul 1971
3629560 Slawson Dec 1971
3634662 Slawson Jan 1972
3646522 Furman Feb 1972
3668653 Fair et al. Jun 1972
3699317 Middleditch Oct 1972
3702988 Haney Nov 1972
Non-Patent Literature Citations (4)
Entry
Boysel-"Adder on a Chip: LSI Helps Reduce Cost of Small Machine,"-Electronics, Mar. 18, 1968, pp. 119-124.
Hopkins-"Electronic Navigator Charts Man's Path to the Moon" Electronics, Jan. 9, 1967, pp. 109-118.
Levy et al.-"System Utilization of Large Scale Integration," Oct. 1967-IEEE Trans. on Electronic Computers, vol. EC-16, No. 5, pp. 562, 566.
Beelitz et al.-"System Architecture for Large Scale Integration"-AFIPS Conf. Pro., vol. 31, pp. 185-200, Nov. 1967.
Continuation in Parts (1)
Number Date Country
Parent 354590 Apr 1973