**Title:** Design of a Prototype Microcomputer Driven Training Device for an Air Force Maintenance School

**Authors:** Michael F. Winthrop, Capt., USAF

**Performing Organization Name and Address:**
Hq Electronic Systems Division (TOI)
Hanscom AFB
Massachusetts 01731

**Contract or Grant Number(s):**
D 18-8

**Report Date:**
August 1979

**Number of Pages:**
187

**Security Class. (of this report):**
Unclassified

**Distribution Statement (of this report):**
Approved for public release; distribution unlimited.

**Supplementary Notes:**
Patents Pending on devices shown as Air Force Invention No. 13632. Work accomplished under funding and auspices of Keesler Technical Training Center (KTTC/TTVET), Keesler AFB, Mississippi.

**Abstract:**
Microcomputers are no longer toys; they are cheap computers. This project proved that a commercial, "off the shelf" microcomputer could run a simulator used in an Air Force Technical Training school. Research through the Defense Documentation Center (now the Defense Technical Information Center) showed nothing comparable in DoD. Commercial producers of trainers were also unable to show equivalent capability. A reproducible method to evaluate microcomputers is shown and used. Circuits are shown and discussed which provide control of the trainer.

**Key Words:**
- Simulator
- Line Replaceable Unit (LRU)
- Signal Generator
- Maintenance
- Built in Test (BIT)
- TPS-43F Radar
- Trainer
- Built in Test Equipment (BITE)
- Commercial
- Microcomputer
- Programmable
- Off the Shelf
- Radar
- Waveform Generator
and implement outputs. An invention is detailed which produces waveshapes for oscilloscope under program control. Software is provided, with full documentation, that generates waveshapes for the invention (above) which can then run independent of computer inputs.
University of Southern Mississippi

DESIGN OF A PROTOTYPE MICROCOMPUTER DRIVEN TRAINING DEVICE
FOR AN AIR FORCE MAINTENANCE SCHOOL

BY

Michael F. Winthrop

A Thesis
Submitted to the Graduate School
of the University of Southern Mississippi
in Partial Fulfillment of the Requirements
for the Degree of Master of Science

Approved:

__________________________
Director

__________________________
Dean of the Graduate School

August, 1979
ACKNOWLEDGEMENTS

The author wishes to acknowledge that this work was supported by the United States Air Force, Keesler Air Force Base, in Biloxi, Mississippi. Final typing was provided by the Main Plant, Second Floor, Correspondence Center at the Martin Marietta Corporation of Orlando, Florida, with whom the author is serving an extended temporary duty assignment for the Air Force.

The writer is deeply indebted to Professor Cecil D. Burge, Ph.D., P.E., major advisor, for his valuable assistance and direction. Also, the author would like to express appreciation to the people in the chain of command of Air Training Command for their confidence in this project as expressed in money, facilities and personnel. The author wishes to make special note of Lt. Col. selectee James R. Bridges, Jr., Chief of Training Service Division, and prime mover in this project; Mr. Buddy L. Holmes, master technician; and especially the entire group of craftsmen and artisans with whom he had the privilege of working.

I wish also to use this space to thank my wife, Jeanne Elizabeth, and my two sons, Michael Francis and Daniel Scott, for their support and understanding during the many months of 16 hour days and family separation they have endured during this study and its final preparation.
TABLE OF CONTENTS

ACKNOWLEDGEMENTS ............................................. ii
LIST OF TABLES ................................................... vii
LIST OF DRAWINGS .............................................. viii
LIST OF FIGURES .................................................. ix

CHAPTER

I. INTRODUCTION ................................................ 1

   Background of the Project
   Purpose
   Objective
   Scope

II. PERFORMANCE SPECIFICATIONS .......................... 9

   General

       Training Level To Be Achieved
       Method of Instruction
       Length of Course

   Hardware

       Organizational Overview
       Commercially Available

       Computer Instruments

       Specially Fabricated

       Training Cabinet
       Faceplate
       Trainer Specific Electronics
       Programmable Waveform Generator
       Control Circuits

   Software

       Organizational Overview
       Vendor Supplied
III. SELECTION OF EQUIPMENT

Technical Criteria

- Speed
- Cost
- Effectiveness
- Plug Compatibility
- Reliability
- Vendor Capability
- Power

USAF Institutional Constraints

- Funding
- Purchasing System

Decision Matrix

- Collection of Data
- Evaluation of Data

Procurement Decision Parameters

IV. DESIGN IMPLEMENTATION

Hardware

- Programmable Waveform Generator (General)
- The System Input/Output Interface Card
- The Simulator System Front Panel
- Data Select Cards
- The Phase Shift Analog/Digital Converter
Trainer Turn-On and Turn-Off Procedures

Cautions

Trainer Power Requirements

Programmable Waveshape Generator PC Card

Clock Control Circuitry
Power
Port Addressing
PWG Timing Frequencies
Program Control Decoder
Memory Address Latches
Memory Address Counters
Memory Load Control
Write Delay One Sheet Multivibrator (OSMV)

Memory Loading
Oscilloscope Monitoring
Run Mode

Software Locally Developed

Modular Design
Cascade LOGIC Evaluation
Waveform Generation
Error Simulation

Performance Evaluation

Testing Procedures
Results
Observations

V. CONCLUSIONS .................................................. 93

General
Institutional
Engineering

Directions For Future Work

BIBLIOGRAPHY .................................................... 97

APPENDIX A. TRAINING DOCUMENT FORMATS .................. 98

APPENDIX B. LETTER OF TECHNICAL RECOMMENDATIONS TO
STAFF STUDY ..................................................... 107

APPENDIX C. LETTER OF INQUIRY TO VENDORS ................. 112
APPENDIX D. DECISION MATRIX - COMPANIES QUERIED AND RESPONDENTS .............. 115
APPENDIX E. FIGURE OF MERIT PROGRAM ........................................ 131
APPENDIX F. APPLICATION PROGRAM BITE ....................................... 136
APPENDIX G. STUDENT ERROR FILE PROGRAM .................................... 172
APPENDIX H. PICTURE CODE GENERATOR .......................................... 174
# LIST OF TABLES

<table>
<thead>
<tr>
<th>Table</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. Computer Companies Over 100,000</td>
<td>44</td>
</tr>
<tr>
<td>2. S-100 Companies</td>
<td>44</td>
</tr>
<tr>
<td>3. 8080 Sets</td>
<td>46</td>
</tr>
<tr>
<td>4. Z-80 Sets</td>
<td>46</td>
</tr>
</tbody>
</table>
**LIST OF DRAWINGS**

<table>
<thead>
<tr>
<th>Drawing</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. AN/TPS-43E Simulator Programmable Waveshape Generator - Control Circuits</td>
<td>50</td>
</tr>
<tr>
<td>2. AN/TPS-43E Simulator Programmable Waveshape Generator - Memory Circuits</td>
<td>51</td>
</tr>
<tr>
<td>3. AN/TPS-43E Simulator Programmable Waveshape Generator - D/A Converter</td>
<td>52</td>
</tr>
<tr>
<td>4. AN/TPS-43E Simulator System I/O Interface - Control Circuits and S-100 Port</td>
<td>53</td>
</tr>
<tr>
<td>5. AN/TPE-43E Simulator System I/O Interface - Light and Meter Display Circuit</td>
<td>54</td>
</tr>
<tr>
<td>6. AN/TPS-43E Simulator Card #1 Data Select</td>
<td>57</td>
</tr>
<tr>
<td>7. AN/TPS-43E Simulator Card #2 Data Select</td>
<td>58</td>
</tr>
<tr>
<td>8. AN/TPS-43E Simulator Card #3 Data Select</td>
<td>59</td>
</tr>
<tr>
<td>9. AN/TPS-43E Simulator A/D Converter</td>
<td>61</td>
</tr>
<tr>
<td>10. AN/TPS-43E Simulator System Front Panel</td>
<td>62</td>
</tr>
</tbody>
</table>
## LIST OF FIGURES

<table>
<thead>
<tr>
<th>Figure</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. TPS-43E Radar Set</td>
<td>4</td>
</tr>
<tr>
<td>2. TPS-43E BITE Maintenance Trainer</td>
<td>5</td>
</tr>
<tr>
<td>3. Hardware Overview</td>
<td>10</td>
</tr>
<tr>
<td>4. Computer With Disk Drives</td>
<td>12</td>
</tr>
<tr>
<td>5. Oscilloscope in Trainer</td>
<td>13</td>
</tr>
<tr>
<td>6. New Circuits in Computer</td>
<td></td>
</tr>
<tr>
<td>a. Programmable Waveform Generator on Extender Card</td>
<td>14</td>
</tr>
<tr>
<td>b. Input/Output Controller on Extender Card</td>
<td>15</td>
</tr>
<tr>
<td>7. Cabinet Electronics</td>
<td></td>
</tr>
<tr>
<td>a. Faceplate</td>
<td>17</td>
</tr>
<tr>
<td>b. Trainer Card Cages</td>
<td>18</td>
</tr>
<tr>
<td>c. Faceplate MUX Input Circuits</td>
<td>19</td>
</tr>
<tr>
<td>8. Rear View of Trainer Cabinet</td>
<td>20</td>
</tr>
<tr>
<td>9. Exposed External Computer Circuits</td>
<td></td>
</tr>
<tr>
<td>a. Rear View Trainer/Input Card Cage</td>
<td>22</td>
</tr>
<tr>
<td>b. Rear View of Faceplate</td>
<td>23</td>
</tr>
<tr>
<td>10. Milestone Chart</td>
<td>33</td>
</tr>
<tr>
<td>11. TPSPGM Flowchart</td>
<td>81</td>
</tr>
<tr>
<td>12. Block Diagram of I/O Controller</td>
<td>83</td>
</tr>
<tr>
<td>13. DECIDE Flowchart</td>
<td>85</td>
</tr>
<tr>
<td>14. PICTUR Flowchart</td>
<td>88</td>
</tr>
</tbody>
</table>
CHAPTER I

INTRODUCTION

Background of the project

Maintenance training traditionally has been considered an area that requires the actual equipment (end item). The reasons usually advanced are (a) the "realism" of the equipment, (b) user acceptance, and (c) the availability of such devices. Problems that have been encountered are (a) the end item is costly, (b) the end item is frequently more sophisticated than training needs dictate, and (c) the end item is not specifically designed to be "student proof" for training.

Simulation of end items is a method to reduce the costs of training equipment. The object is to design training equipment which will respond to a student the way the real equipment would insofar as training is concerned, but cost less initially and not have the overhead of maintenance and operation of the original equipment. In this document, maintenance simulation is the application of simulation techniques to the area of maintenance training.

The nature of simulation is applicable to operational training because designers are limited to mimicking the outward functions of the original equipment. Of importance today is maintenance simulation which requires mimicking the inner functions of the original equipment.

General purpose computers were used in maintenance simulators as early as the mid-50's. Unfortunately the costs exceeded the benefits of maintenance simulation because of the dedicated computer
requirement. Lately, the price of computers has dropped to the point where maintenance simulation is practical. Cost and the current state of the art are reasons this problem has been attacked.

Much of the Department of Defense work in simulation has been in the operations area, such as pilot and communication operator training. The maintenance training area has been largely ignored because of the belief that a maintenance simulator needs to be a 100 percent duplication of the end item to be effective. Kargo and Steffen have designed and built a computer assisted performance training carrel, and their conclusion was "The system as developed has proven to be feasible for use in performance training and could be expanded to simulate larger and more complex circuits used in higher level courses."

A United States Navy study in 1978 advocated "providing an alternative to the use of operational equipment for intermediate level maintenance training." Literature indicates that no further work has been undertaken on this project. Maintenance simulation as an end item alternative can potentially save large amounts of money when applied to high cost systems, such as radar sets, weapon control systems and power systems.

Electronic maintenance simulation is desirable, and has been for some time. Lack of capability to cheaply produce circuit waveforms for electronics training (i.e., dynamically-controllable, high-speed complex outputs) has prevented maintenance simulation from achieving widespread use. Industrial system control concepts - using large scale integration (LSI) devices such as: eight bit microprocessors and cheap transistor memory devices - have changed the picture drastically in favor of maintenance simulation.
Purpose

The specific purpose of this project was to develop a microcomputer-controlled trainer. The vehicle chosen was the AN/TPS-43E radar set. (See Figure 1.)

Objective

The objective is to perform a design study to demonstrate the feasibility of using maintenance simulation for electronic maintenance training.

Scope

The scope of this project will be limited to designing and constructing a maintenance simulator covering the tasks of the Built-In-Test Equipment (BITE). This is illustrated to the right of the operators in Figure 1 and shown, as actually constructed, in Figure 2. The particular training area that is being investigated is major component replacement maintenance; however, the investigation is not limited to just major component problems. Point-by-point circuit tracing can be easily simulated. This simulator not only reads analog inputs but also is able to create analog outputs which heretofore have only been possible using a mini or a full scale computer.

Documentation specifications of the BITE which the computer driven trainer must mimic came from the documentation available from Westinghouse through 3395 TCHTG/TTEOR on the AN/TPS-43E radar set. The work done was specifically in coordination with the training division at Keesler Technical Training Center, Biloxi, Mississippi, where the E3ABR30332 000 course is in preparation to be taught. The beginning date for the course to use this trainer will be April of 1979.
In brief, the rest of this document is composed of four main divisions: (1) Performance specifications in Chapter 2, (2) Selection of Equipment in Chapter 3, (3) Design Implementation in Chapter 4, and (4) Conclusions in Chapter 5.

Chapter 2 deals with the performance specifications that the maintenance simulator must meet. Methods of instruction, derived by the instructional systems development (ISD) process of course construction, are implemented using a judicious choice of commercial and locally manufactured hardware and software. The tradeoffs of "cost to develop" vs "cost to purchase" are examined and explain the early decision to develop only a limited group of electronic equipment capable of interfacing the greatest number of trainers to the greatest number of microcomputer vendors at the lowest prices and with the greatest ease. As a consequence of the constraints noted above, detailed specifications of hardware and software essential for the design and development of this project are presented in conjunction with the performance specification in Chapter 2 rather than with the selection of equipment in Chapter 3.

Chapter 3 develops the selection of equipment from commercial sources. Technical criteria are evaluated in light of the performance specifications of Chapter 2. Institutional constraints imposed by the Department of Defense (DOD) and the United States Air Force (USAF) are described. Due to the number of criteria and commercial vendors, a decision matrix is used to give each vendor's wares a figure of merit (FOM) useful in the final procurement decision.

Chapter 4 is an annotated operations and maintenance manual of the hardware and software locally developed for this project. Careful
consideration is given to the interface of each to the commercially selected equipment.

Chapter 5 states the conclusions of this work. A review of the institutional and engineering decision factors point to the actions required to provide electronic maintenance simulators in the future. Possible application of the products of this project are enumerated wherein the investment of effort is either largely or exclusively software.

A major effort of this thesis concerns the design and implementation of a programmable waveform generator (PWG) to provide one and two MHz data display rates. This PWG was essential because no single commercially available microprocessor can perform such output rates continuously and direct a microcomputer system at the same time. The PWG is therefore a self-contained output device slaved to the host microcomputer which gives the microcomputer the ability to output unlimited iterations of arbitrary waveforms.

Appendix A provides works accessible to the general public if specifically requested under the Freedom of Information Act. These attachments are volatile in nature and yet represented the grounds for the ISD process at the time of this work. Technological advances continuously redefine a military training system's effectiveness, or lack of it; therefore, the elements or the attachments provided may be obsolete when this work is published. Further information concerning the currency and availability of documents used as attachments to this work may be obtained by written request to Community College of the Air Force, Keesler Technical Training Center, Keesler Air Force Base, Mississippi 39530.
END NOTES

1. Keesler AFB Study, TTVET. Staff Study on the Feasibility of Using Simulation in Maintenance Training, 3 Oct 77


"Digital simulation, as used in simulation and trainers we know today, has followed directly from the larger analog simulators of the 1950s.

"What was probably the first digital simulation system built for training purposes was the UDOFT, Universal Digital Operational Flight Trainer. This system, which was primarily an experimental device, was built by Sylvania under contract to NIDC. It provided much of the experience and education which led to the development of other digital system."


6. Boyle, E.B. op. cit, on citing "Simulation Computer Specifications", notes that MIL-STD-876, which USAF is responsible for, permits only second generation medium and large main frame computers to meet requirements. He noted, "While these requirements will be met for all systems of medium and larger sizes, there seems to be some possibility that some simplification ..." will be required for "...systems of very small size in the next decades." Ironically most mini and a few microcomputer systems meet MIL-STD-876, 11 years later. Pg 39

7. Boyle, E.B. op. cit. pg. 40
CHAPTER II

PERFORMANCE SPECIFICATIONS

General

The maintenance simulator is to be used to provide training to the U.S. Air Force 3-skill level. The "3-skill level" training required in the Air Force constitutes an apprentice level, a person capable of working under the direction of another more skilled person and not expected to work on his (or her) own.

Circuit card replacement is the highest level of maintenance required of the student and will be the student's capability at the end of this course. The student will learn to identify any given circuit which is not working within the radar set covered by the BITE. The student will then be required to identify, remove and replace any particular circuit card within a satisfactory time period and with a minimum of mistakes. Methods of training used during instruction are laboratory performance and class demonstration. The student will be placed in a BITE maintenance situation with a predetermined dysfunction within the equipment. The student will determine what the dysfunction is using standardized Air Force Technical Orders. Satisfactory identification is shown by removing and replacing the dysfunctional circuit card. Length of the course is 12 weeks.

Hardware

The hardware is organized into four major areas: (Figure 3) the microcomputer, the associated test equipment, the output circuitry, and the input circuitry.
Figure 3. Hardware Overview
The first major area is the microcomputer (Figure 4). The computer's power supply should have the ability to power all the associated external digital equipment as well as its own set of internal digital equipment. The operational clock of the computer should be switch selectable at 2 or 4 MHz to accept slower memories. Faceplate access and rack mountable design are desired to simplify cabinet engineering design. The computer should be one of several commercially available and should be capable of directing all the functions necessary within the trainer to achieve the general performance specifications previously outlined.

The second major area is the associated test equipment (Figure 5). Associated test equipment consists of a Tektronix Triservice 100 MHz Dual-Trace Oscilloscope and two faceplate meters. The oscilloscope is the actual radar maintenance oscilloscope. Considerable training results by using this instrument; therefore, the maintenance simulator emphasizes using the actual test equipment where economically feasible.

The third group of equipment is the output circuitry (Figures 6a and 6b) which creates the necessary displays on the oscilloscope and faceplate devices. The output devices have been designed at Keesler Training Services Branch, Keesler Technical Training Center (KTTC), since it was not cost effective to purchase comparable equipment.

Fixed pattern waveform generators have been available for some time, and nonfixed pattern programmable waveform generators have become available recently. The former are unsuitable to the dynamically-controllable complex waveform application and the latter cost between $3,000 and $25,000 per unit. The 3AZR30352 003 course requires two (or
Figure 4. Computer With Disk Drives
more) extra simulators necessitating at least three of these instruments. The cost to develop the display hardware is approximately the same as it would be to purchase two less capable commercial instruments. Training Services expects to make more than two waveform generators which justifies the local design effort.

The devices that output to the faceplate are simple to design and do not justify purchasing. Simple addressable latching devices enabled from the input device, described below, provide controlled value inputs to two digital-to-analog (D/A) converter input meters and 15 indicator lights.

The fourth major group of equipment needed must be able to input those things that the student is investigating via the BITE simulator switches. For the computer to be able to recognize these actions, it is essential to have an input-output (I/O) device utilizing the trainer's faceplate and card cages as if they were the computer's keyboard and display (Figures 7a, 7b and 7c). Instead of using a terminal, the functional training equipment concept shall be implemented by designing the I/O device to sequentially scan the switches and sensing their states. Devices, to input data shall include various kinds of switches and an A/D converter. There will be over 105 inputs available between the faceplate and the card cages. This gives the possibility of 105! combinations and permutations.

The training cabinet shall be a locally fabricated box (Figure 8) containing the rest of the equipment. The faceplate shall be a duplication of the face plate on the actual radar set. Instead of purchasing the radar faceplate from Westinghouse, Training Services
Figure 7c. Faceplate MUX Input Circuits
Division shall design and photoprint one using metal photometal techniques that are available at that facility.

The Cabinet Electronics (Figures 9a and 9b) shall be defined as the electronics to which the computer I/O hardware is attached. These include various kinds of lights, relays and connective wiring. These electronics should also be able to read a potentiometer's analog data and convert it to digital data compatible to the computer. The faceplate in the cabinet shall be used as a chassis to hold an A/D converter.

**Software**

The software falls into two classes - that which is commercially available and that which shall be developed by this project. By selecting a fairly comprehensive microcomputer system, software available should include an ANSI Standard FORTRAN compiler, a Relocatable Assembler, an Extended Basic, a Link Loader, an Editor, a Disk Operating System, a Disk Loaded Monitor (with a disassembler and In-line assembler), and a Power-on Monitor in read only memory (ROM). The latter will allow the user to be able to start a user program without intervention on a terminal. Developed software shall consist of the program BITE and some hardware and software maintenance programs.

Of all the software needed for this project, the most useful will be a high level compiler. FORTRAN IV should meet this requirement better than other options and should prove an essential vehicle for timely completion of this project. The reasons FORTRAN should prove so valuable are (1) the trainer architecture should lend itself particularly well to a word (byte) oriented language, (2) execution time should be close to real time (subjective), (3) no assembler learning
curve should be encountered, and (4) 32K memory will hold the object code.

Hopefully, the assembler, which must be conditional, relocatable, and macrocapable will prove unneeded in this project if the compiler is adequate. Various hardware test routines can be assembled by hand with the ROM monitor, or with the disk monitor, which does in-line mnemonic assembly as well as disassembly.

The Link-Loader should aid use of the FORTRAN compiler. One of its most desired features is the listing of undefined variables. This feature will identify all library subroutines used prior to the use of the FORTRAN library (FORLIB), and locate all undefined calls.

The Editor should be similar to on-line editors on Honeywell 6060 systems and the ZEROX Sigma 9. The full range of internal commands must be available within EDIT. External system commands are also desirable. While lack of external EDIT commands is a serious liability because there is no recovery from a bad disk write, careful consideration to this drawback can prevent the unintentional loss of large amounts of completed EDIT work.³

The Disk Operating System (CDOS) shall be a complete I/O system for many common peripherals. CDOS shall be designed to interface with 5-1/4 inch and 8 inch floppy disks as well as hard disks. RS-232 and parallel outputs must be provided to interface both a printer and a terminal. A single byte modification to CDOS should permit RS-232 signals to the keyboard-terminal to also go to a dot matrix printer with sufficient time delay to allow for a carriage return. This feature is to provide screen records.⁴ CDOS must also contain a load-and-go capability once the system has been booted.
The ROM Disk Operating System (RDOS) must actually be a Power-on Monitor, activated by the reset function when the system is first turned on or when the reset is entered manually to the computer. Such an RDOS will wait for the keyboard to enter up to four RETURNS and use them as data to derive the baud rate of the terminal. Without the returns the cold boot mentioned above shall not occur. When a modified ROM is used for RDOS with the baud rate already established, the entire system shall be cold booted to a user program from power on, or a reset. This particular feature will eliminate the use of a terminal in the trainer.

Project Developed

Among the project developed software, a variety of types of programming will be needed. The required programs will be a program control module, an input device control module, a tree search identify and decide module, an error insertion module and an oscilloscope picture output display/device module.

The program control module shall be a loop which centralizes the activities of the software. The various functions shall be called, as needed, and the student activities will be noted. Improper solutions, or unsafe (simulated) equipment operations, shall cause the oscilloscope to display the word NO, with no student recovery.

The input control module shall be a hardware control subroutine which selects the inputs from the training cabinet electronics. This module shall scan the multiplexed inputs, of the faceplate and card cages, sequentially and shall store the information, as found, for later evaluation. Evaluated input scans shall occur at a rate of no less than 30 times a second.
The tree search identify and decide module shall be a cascade search. Each of more than six switches, when taken in several possible orders shall provide up to 26 different pictures. Sixteen switches must be evaluated wherein each each switch has from two to ten possible positions. The natural order and multiple choices available at each switch are similar to telephone switching systems, which shall provide the model. Each switch shall be evaluated on a "DO CASE" basis which should progress very rapidly to picture selection.

The error insertion module shall be a subroutine which applies selected dysfunctions to the displays. The error conditions shall be dependent and/or independent. Error types are to include: changing correct pictures, and replacing one display with another.

The picture display program shall actually be a point display graphics subroutine. It must calculate enough points to produce vectors. Data will be passed encoded and PICTUR will decode it during picture generation.

Maintenance training requires that dysfunctions must be put into the equipment (real or simulated) so that the student has something to repair. In the past, designers were precluded from doing this with the real equipment because the malfunctions they wished to show could have done some harm to the actual equipment. With microprocessor controlled programmable errors, there is no particular reason to avoid catastrophic dysfunctions, making an error simulation module feasible. Project-developed software shall be able to handle a number of trainers. Requirements should be additional LBUF, MESUP and IPUT buffers, plus independent cabinet electronics.
END NOTES

1. Programmable Waveform Digitizers are now available, such as the Tektronix (7912AD) that connects to the IEEE-488 bus, as noted in Digital Design, Sep 77, Products Review. Cost is $22,000. Horizontal resolution (HR) is 512 points. Another is the HP 8170A available from Hewett-Packard (HP) with an HR of up to 4096 and speed up to 1 MHz; however delivery was not before late September 1978. Price is $5,430 for 1024X8 memory where each 1024X8 extra costs $545 as noted in Electronic Design, Vol 18, Sep 78, pg 149. While both test units are programmable, only the HP8170A is programmable to 4096 words; and it was not even announced until after the author’s programmable Waveform Generator (PWG) was built and working in final form. Another problem with the T7912AD and HP817A is that both are only IEEE-488 bus compatible. Only the low production PET microcomputer is IEEE-488 compatible as of this writing other than HP computers of the miniclass.

2. ANSI document X3.9 - 1966

3. To prevent loss of a program, all editing work is done on an empty disk and transferred to a master disk on completion. Frequent down loading of the current file keeps modification re-edits to a minimum. The CDOS automatically maintains a backup file which is actually the old file, so the above procedures work reasonably well.

4. CDOS has a timing loop constant at location 7C7F (Hex) which normally contains 00 (Hex). Replacing this with C5 (Hex) causes a pause of about one second which allows for a carriage return. This can be accomplished by typing in BYE at the CDOS level and then SM7C7F at the RDOS level. SM means substitute memory. When done, enter RETURN and
then GØ and another RETURN. This jumps directly to the already booted CDOS just modified.

5. The ROM modification is accomplished by replacing 5 bytes of the RDOS. Modification is done by loading DEBUG, then M (move) C000 S400 (to) l000. At location l0EE insert via SM l0EE: 3E 88 D3 00 C9. With the BYTESAVER TM on, make a new ROM at E400 using slot 1 and the command P 1000 S400 E400. The code shown tells the computer it has a 1200 baud I/O device.
Two major areas of concern during the equipment selection phase were technical criteria and USAF constraints. Among the most prominent technical criteria were speed, cost, effectiveness, plug compatibility, reliability, vendor capability, and power. Among the USAF constraints were budget, submission procedures, device designation, engineering procedures, and maintenance after delivery.

Technical Criteria

The student expects a real time response. Therefore, speed of response is first in significance among criteria. Equipment is needed that will allow presentation of a display, or some other response, quickly enough to maintain comparability of the trainer's fidelity to the actual BITE. In Nov. 1977, the fastest complete microcomputer system available operated at 250 nanoseconds (ns) per clock pulse (using a 4 MHz clock) and using 12 clocks per instruction yields about 333,333 instructions per second. In the microcomputer area, this was approximately the best that could be purchased without considerable expense. A 2 MHz operation was acceptable.

The second criterion is cost. This project could not consider a computer in the minicomputer or the main frame class primarily because of the $20,000 total hardware cost ceiling imposed. The relatively low cost of microcomputers provided the only acceptable option for the project. Virtually all the microcomputer systems considered were within a $2,000 to $10,000 price range. The cost of the hardware
to be locally fabricated was initially estimated to be $5,000. The computer system selected had to be best in its class and still leave a reserve equal to its own cost in case of unforeseen complications. This method of optimizing financial resources, and good luck, eventually resulted in $6,500 of hardware funds being saved.

The third criterion is user effectiveness. This is determined by whether or not the equipment is going to serve the training purpose and work well in the training environment. In the training situation simplicity of use is a major asset. Neither student nor instructor are expected to be computer qualified in any sense of the word; therefore, the software-hardware mix must function with the ease of a television game to be effective.

The fourth criterion is plug compatibility. Plug compatibility is used here to mean that a computer will take add-on equipment from a variety of vendors. It would be impractical to purchase a computer supported by one, or at the most, only a few vendors. Such vendors represent a single source market and could consider their prices from the captive market point of view. Even worse is the possibility that a sole source vendor could go out of business; i.e., vendor capability.

The fifth question is vendor capability. Is the USAF dealing with a vendor that has a relatively safe future? Some companies have closed their doors within a short time after opening for business. USAF could not afford to have a single business bankruptcy obsolete a considerable investment in training hardware. At any rate, the cost of development would have to be borne all over again when the next training simulator is made.
The sixth criterion is reliability. If the equipment is going to be in use constantly in a student situation, it is expected to be online almost continuously. Therefore a high mean time between failures is a virtual necessity.

The seventh and final important area is power. Economy of design makes it desirable to have a piece of equipment planned in such a way that there is only one power supply for all the computer related units. Looking at the computer's power supply and the amount of power that is required for the entire trainer, exclusive of the oscilloscope, it becomes possible to consider letting the computer provide all the power required. Meeting the entire trainer's power requirements implies a large and reliable power supply.

**USAF Institutional Constraints**

Air Training Command Regulation (ATCR) 50-221 provides that educational centers, such as Keesler Technical Training Center (KTTC), construct training devices as required, provided that they are "not available elsewhere." "Elsewhere" implies a series of concentric circles of search beginning with a check of existing and/or older modifiable devices. The circle of search then widens to the resources of other training centers and finally to all DOD training resources. When no satisfactory device is available from these sources, feasibility studies are instituted to look at the viability of alternatives.

The feasibility study is a staff report intended as an in-house evaluation of capability to produce and/or procure. In certain special cases, prototypes are authorized as an extension of the feasibility study. Such prototypes become design studies.
The feasibility study, if it has sufficient promise (Appendix B), can be considered for funding. If funding is approved, a schedule is submitted, along with milestones to be met (Figure 10). Personnel are assigned and reports are provided periodically by the project officer to the approving authority until completion, or curtailment, of the project. At completion, a final report is tendered. This document may also become an annex to that final report.

Usually the design study is undertaken to provide a statement of work (SOW) which defines the criterion the trainer must meet when subsequent copies are made. ATCR 52-332 requires that KITC Training Services Division (KITC/TTVET) meet the "functional statement of the requirement, specifications and statement of work..." of the requester. In this case the requester was Headquarters Air Training Command, TTYR. The request was based on the continuing drive of DOD to reduce costs. A design study, where resources permit, provides SOW guidelines for the whole class of devices within its scope.

Device designation and purchase procedures run parallel in training device design. AFR 300-22, paragraph 3e, requires "computers" be purchased through channels designed to control office data processing equipment and/or communications equipment. This project does neither. Instead the computer is designated as a training device component and falls outside those regulations and under Military Standard 876A, Digital Computing System for Real-Time Training Simulators.4

By virtue of the designation selected, the computer chosen cannot be used in any capacity outside of the trainer, but may be used as a module component in any number of different types of trainers. To
### Major Milestone Summary

<table>
<thead>
<tr>
<th>Milestone Description</th>
<th>1977</th>
<th>1978</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>a.</strong> Prepare a staff study on the use of simulation in the electronic maintenance field</td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>b.</strong> Select a system, already in use, to use as a model for exploring the use of simulation.</td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>c.</strong> Determine feasibility of incorporating simulation in the selected system</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### Milestones

<table>
<thead>
<tr>
<th>Major Milestone Summary</th>
<th>1978</th>
<th>1979</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>d.</strong> If study shows it is feasible, build training device.</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Figure 10. Milestone Chart**
exploit the "trainer only" constraint, the system chosen needed to be easily moved from one type trainer to another and, when properly plugged in and the appropriate program loaded, be able to take control of the new trainer with no internal hardware modifications at all. Rack-mountable, totally enclosed front access equipment was indicated in this situation as well as "Power On" loading of software.

Engineering procedures require that the training device be reproducible from drawings and other documents. This could provide a "statement of work" if a large number of such trainers were to be made and contracts were advertised for bid. Simultaneously the engineering documents serve the maintenance personnel well in the event of a breakdown.

Commonly available components with many sources are used to prevent parts obsolescence. Competition among microcomputer and LSI-MSI component manufacturers provides a wide selection of circuits, application notes, technical articles and (surprisingly) personal computing source magazines, from which were extracted many of the solutions to the precise use of the elementary components used in the final design. Frequently the Government procurement system returns military standard substitutes for generically named parts, because they are already in the system. It is actually cheaper to use the more expensive part than to special order cheaper ones not in the system. When a part type is not in the system, and normal procurement channels prove to severely impede work, project acquisition priority is increased to permit ten day buy cycles. The ten day buy cycle starts with a three day computer aided search of resources DOD wide. Undeliverable parts from within resources are purchased on a competitive basis among supply
houses within 100 miles distance of Keesler. Due to the steady drop in the cost of LSI-MSI components an occasional windfall savings may be realized over the standard military inventory priced item. A good purchasing rule is to buy in lots of $10^+, 20^+, 50^+$, and $100^+$ wherever possible to get the volume discount. All basic components worked as advertised, whereas every major preassembled unit failed due to poor assembly.

The major institutional problems encountered in this project were uncertainties caused by project funding and DOD reductions in force (RIF). The problem of funding revolved around budget planning. An error at headquarters level deleted the project money by forgetting to ask for it. Keesler Technical Training Center decided to use unsure local funding resources rather than drop the project thus causing continuous uncertainty. DOD reductions in force were two-fold: first was an impending potential for mass civilian lay off's caused by a study of methods to convert TTV into a contracted service. Second was a directive to reduce manning using attrition as a tool. The attrition positions were first allowed to absorb tenured civil servants RIFed for other causes. The positions were redesignated with a one pay grade reduction. A ranked list of applicants was to be sent to TTV from which a selection had to be made. Internal informal discussions led to the conclusion that by dropping and/or stalling lower priority projects TTV could accomplish more without training old substandard personnel than it could otherwise. Unsure money and insufficient people presented a formidable management challenge.

Maintenance is provided by the 2052 Communications Group who assure that during acceptance procedures the trainer is debugged of
conditions which could cause premature failure. Training Services Division, the designer/fabricator, provides maintenance procedures which are used by 2052 personnel to detect and correct problems that arise.

The Decision Matrix

In order to determine the relative merits of microcomputers to the task at hand, an extensive evaluation was needed. Both purchased and self-generated data sources were used.

Datapro's "All About Microcomputer Specifications" was purchased. This source, while quite extensive, was disappointing in that many companies considered significant in the market were ignored, including the one chosen for this project. Since some of the technical information needed was also not included in the report, all the companies on the Datapro list were contacted. At the same time a canvas of the trade journals, such as BYTE, provided the names of about a dozen other companies.

Over 80 letters of inquiry were sent (Appendix C) asking for information considered needed to build the trainer. Forty-four companies (Appendix D) responded with everything from tearsheets on future products to the complete instruction set of a new language supported by the vendor.

A program was devised (see Appendix E) which developed a figure of merit (FOM) for each of the 44 companies that responded to this author's inquiry. The equation used was:

$$Y = (I.B+K+N+L+D+P+W+C+S+N).R.A.O.T$$  \hspace{1cm} (1)

Where:

$$Y = \text{Figure of merit (decision value)}$$
I = Number instructions available (Basic Instruction set count)
B = Bus used by several companies (10 = yes, 5 = no)
K = Kit or preassembled (Yes = 5, No = 10)
N = Industrial use? (Yes = 10, No = 5, ? = 0)
L = Logistical Support? (Yes = 10, No = 5, ? = 0)
D = Documentation? (Yes = 10, No = 5, ? = 0)
P = Sufficient power (Yes = 10, No = 5, ? = 0)
W = Number of bits in a word (Actual Count)
C = Number of parallel ports up to 4 (Actual Count)
S = Number of serial ports up to 2 (Actual Count)
M = Nonvolatile memory? (Yes = 10, No = 3, ? = 0)
R = Total usefulness of software (Yes = 1, No = 0; Boolean)
A = Total usefulness of peripherals (Yes = 1, No = 0; Boolean)
O = Total usefulness of off-line memory (Disk = 5, M Tape = 3, P. Tape = 1; Boolean)
T = Software at all? (1 = yes, 0 = no; Boolean)

The rationale behind equation (1) is as follows: The number of instructions (I) a microprocessor has in its hardware is a count of the number of options available to a programmer without resorting to algorithms. All other things equal, each extra instruction that microprocessor A has that B lacks is equivalent to a custom-wired macro assembly subroutine in A. Given an upwardly compatible series of microprocessors, it is a virtual certainty that the more primitive members of the series will take both more instructions and more time to execute macros equivalent to instructions defined only on the more current members of the same series.
Different architectures do not compare easily, but comparison of clock cycle times shows that the smaller the number of instructions a microprocessor has (such as the MS 6502 vs the Z80), the smaller the clock cycle count, as a measure of time, needed to execute them. Yet, the smaller the working set, the greater the count of low order instructions needed to accomplish a high order function. Another place for comparison is where clock cycle times of two to one are found in competitive units, such as the 8080 vs the MC 6800. The fact not immediately evident is that the 8080 uses a 500 ns clock while the MC 6800 uses a one microsecond (us) clock, which causes equivalent individual instruction execution times to actually be comparable (being 2-12us and 2-9us, respectively).

Given equivalence in speed of instruction execution and instruction sets adequate to perform the tasks demanded, the greater the instruction repertory a microprocessor possesses, the stronger a position it commands in terms of processing power.

Bits per word (B/W, encoded W) is both important and complex. The importance of B/W revolves around instructions and data formats. The complexity of B/W comes from the ingenuity of bit employment within the B/W CPU architectural constraint.

The importance of B/W is illustrated by the generalization that, for a given processor, instruction formats that are single word oriented usually execute much faster than those which use multiple word formats. The primary cause of this speed differential is the presence, or absence, of extra memory fetches. Short bit length words constrain the CPU architect to use a limited number of simple primitive operation codes (POC) and this in turn forces choice of either selected simple
POCs without a full number of register (or memory) variants, or multiple word POCs. The same argument applies to data formats. Each bit added to B/W increases the possible number of POCs, and/or register-memory variants, by a power of two thereby increasing speed of instruction execution.

The importance of B/W to ingenuity in CPU design becomes apparent when software is being developed. The ultimate POC system, i.e.; a Turing machine, theoretically could generate any conceivable software macro-primitive operation code, but the number of instruction steps would be prohibitive. The critical questions is: which of the macro-primitive operation codes, directly encodable in multi-bit CPU hardware, represent an optimum set to map onto the universe of user sets such that the number of instruction steps, per software macro-primitive, is minimal. The answer to this question is currently empirical and is best answered by matching the architecture to its employment. Within this constraint it is clearly evident that B/W are again a measure of the spectrum available of hardware macro-operation codes.

B/W and the bus were multiplied together to give great weight to the software-hardware mix of the system. It is believed that the initial choice is critical to a system's potential and thus is internalized whence it may be brought to bear on other components effectiveness later on.

The Bus (B) assumes the S-100 as the de facto available standard versus the poorly accepted IEEE-488, as an engineering consideration that enhances the power of an instruction set whenever unusual interface requirements can be satisfied with "off the shelf code" rather than by special "in-house design."
Kit (K) versus pre-built deals with parts reliability. Experience indicates that kits contain component parts that were only checked during production (maybe) and may have an unacceptable failure rate. Preassembled systems have been (or should have been) tested for system operation. A system is not considered preassembled unless it has been run (burnt in) continuously for 72 hours.

Industrial use (N) is a measure of confidence, research, reliability and many other intangibles. Industrial use is difficult to measure; thus, a minor role was assigned to it. If a better measure could be had, the role of N would have been expanded to a major one.

Logistic support (L) is an estimate of deliverability of initial and support equipment on demand. The rule elected in this project was to look at the numbers and locations of authorized outlets for sales and/or repairs along with warranty procedures. If logistic support did not indicate a 14 day repair cycle, or a seven day acquisition cycle, from identification of a defective board to its replacement, then the support was considered weak. Weak logistic support, in the technical training school environment, amounts to loss of training due to lack of facilities.

Documentation (D) includes the data provided on both hardware and software. Any system will fail repeatedly until its operators and programmers understand its capabilities and limitations.

Power sufficiency (P) is a useful and desirable feature that provides expansion capability. A system cannot grow easily when constant consideration to new power design must be made. If power is adequate for growth the system may be put to multiple uses such that when one trainer no longer uses it another may be built that can.
Number of parallel (C) and serial (S) ports are related to the numbers and kinds of peripherals a system can support. Assuming controllers are available for each type of equipment in hardware compatible to the system, a minimum configuration, exclusive of keyboard and monitor, is:

- Four general purpose parallel I/O ports
- One port for magnetic bulk storage media (disk or tape)
- Two serial I/O ports for
  a. One RS-232 port for terminal and/or printer
  b. One TTL port, general purpose

Mass storage (M) is critical to the system, and was considered partially above under parallel and serial ports. In the present case, some form must exist, and its form is a multiple against the whole system's power. The ability to process data is wholly dependent upon access to the data. Therefore, mass storage is not only necessary for a small system to operate, indeed the amount (and type) are a measure of its sufficiency as well.

From the arguments above it is seen that all the elements other than the Boolean values RAO and T simply inflate the final value. With the elements B and I inside the parenthesis there is no likelihood that a value of zero could be generated there, thus the deciding variables are R, A, O and T.

Total usefulness of software (R) is a summation of the various types of software available (Appendix E, lines 145 to 180) commercially. The software must run without any modification requirement to the rest of the system.
The total value of peripherals (A) looks at company supplied peripherals, or plug-in support from peripheral vendors. The particular peripherals examined are: monitor, keyboard and printer. Lack of a clear ability to use any of these immediately precludes a decision value other than zero.

Total value of Off Line Memory (O) looks at which storable memory media are available. Disk ranks highest and paper tape ranks lowest. Since these values are additive, the more, the better because each medium available becomes a source of software input other than that which the vendor supplies.

The variable (T) is another Boolean factor concerned with any available software. The requirement of meeting completion dates precludes developing the development software of the vendor’s system.

Equation (1) states that a system’s effectiveness, i.e., its usefulness, is equal to the sum of its features and directly proportional to the number of ways and ease with which these features may be manipulated to perform useful tasks for the system’s owner.

For the small system user who has immediate engineering and/or industrial controlling in mind, the above evaluation should prove useful. It is not supposed that this is an ultimate or even a reasonable algorithm. Rather this is a convenient and reproducible method to evaluate many systems using an arbitrary yardstick.

The problem of discrimination became simpler as the simulator requirements became better defined. The ISD process, during course construction, identified the requirements of classroom usage. In the classroom the trainer needed to be quickly and easily loadable with the trainer program, have close physical and operational fidelity to the
BITE, have simple power requirements, and be easily moved from one room to another.

The ISD requirements led to the idea of a box on wheels that used a single 120 volt AC supply. The box should be completely front loadable and controlled. Program loading could be either cassette tape or 5 inch floppy disk using an automatic cold boot system from power on or reset condition.

Discrimination from the design point of view required well documented, well known hardwares and softwares with proven good performance. If possible, software portability should be incorporated. These design views led to the 8080 and Z-80 microprocessors utilizing an S-100 bus. Acceptable languages would be FORTRAN, APL, Compiler BASIC and PASCAL.

The companies identified in Appendix D are, for the most part, producers of viable equipment for a variety of projects; however, only a few could meet the needs of the TPS-43E project. Table I is a list of the companies with a FOM of 100,000 or more.

At the time the decision was to be made, only companies with deliverable products were considered. Deliverability was determined by the written advertisements asked for in the letter of inquiry. Presumably those companies choosing to deal with the USAF answered the inquiry, those not answering were considered de facto, undeliverable.

At this point it should be interjected that purchase procedures require competitive bidding for items such as a microcomputer, unless justification is available for a sole source purchase. Such justification was the result, not the object, of the decision matrix.
<table>
<thead>
<tr>
<th>Companies</th>
<th>FOM</th>
<th>8080-Z80</th>
<th>S-100</th>
</tr>
</thead>
<tbody>
<tr>
<td>Control Logic</td>
<td>133224</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>Cromemco</td>
<td>355104</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Digital Equip</td>
<td>447768</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>EL Mem &amp; Magnet Co.</td>
<td>182448</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>IMSAI</td>
<td>136640</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>MICRO KIT</td>
<td>162048</td>
<td>Yes</td>
<td>NO</td>
</tr>
<tr>
<td>MITS</td>
<td>184464</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Processor Tech</td>
<td>157626</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Radio Shack</td>
<td>192124</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>Zilog</td>
<td>262854</td>
<td>Yes</td>
<td>No</td>
</tr>
</tbody>
</table>

Table 1. Computer Companies Over 100,000

<table>
<thead>
<tr>
<th>Companies</th>
<th>Processor</th>
<th>Software</th>
<th>Off Line Mem</th>
<th>FOM</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cromemco</td>
<td>280</td>
<td>34</td>
<td>6</td>
<td>355104</td>
</tr>
<tr>
<td>MITS</td>
<td>280-8080</td>
<td>24</td>
<td>9</td>
<td>184464</td>
</tr>
<tr>
<td>El Mem &amp; Magnet Co</td>
<td>280</td>
<td>14</td>
<td>8</td>
<td>182448</td>
</tr>
<tr>
<td>Processor Tech</td>
<td>8080</td>
<td>21</td>
<td>9</td>
<td>157626</td>
</tr>
<tr>
<td>IMSAI</td>
<td>8080</td>
<td>20</td>
<td>8</td>
<td>136640</td>
</tr>
<tr>
<td>TEI, Inc.</td>
<td>280</td>
<td>11</td>
<td>5</td>
<td>90145</td>
</tr>
<tr>
<td>E &amp; L Instruments</td>
<td>8080</td>
<td>3</td>
<td>3</td>
<td>7551</td>
</tr>
</tbody>
</table>

Table 2. S-100 Companies
The only anomaly of Table 2 is Digital Equipment Corporation (DEC). This company offers the LSI-11/03 micro-processor which uses 16 B/W, and has over 400 instructions. The first problem this company presented was cost. DECs prices then were twice anyone else's and their bus is also nonstandard. More important than price, however, was the large number of competitive 8080/Z-80/S-100 companies. The latter was the deciding factor in not selecting DEC.

Tables 2, 3, and 4 clearly indicate that as of early 1978 the only standard bus was the S-100. The Z-80 and 8080 processors were the primary users of that bus. Since the Z-80 is upward compatible from the 8080, it is a logical choice of the two if all other factors are equal. The wealth of 8080 software available in print, from trade journals, and from vendors, virtually assured suitable software tools for either processor.

Of the other companies in Table 1, only Cromemco was in the same class as DEC. MITS had not begun sale of their announced FORTRAN compiler, and no one else had even announced one. BASIC, however sophisticated, is simply too slow for the application, and a BASIC compiler was not yet available. APL appears only in IBM equipment on SYSTEM-1, and, as yet, this system is beyond the acceptable price range. A FORTH interpreter was available, however when the author requested access to a demonstration given locally at NASA none was given. FOCAL and C were not available, nor was PASCAL.

The final decision was thus one based on computer bus, instruction set, and software tool standardization. The question of cost only concerned a few companies which were eliminated for the reasons mentioned above. As a result of the decision matrix, via the figure of
<table>
<thead>
<tr>
<th>Companies</th>
<th>S-100</th>
</tr>
</thead>
<tbody>
<tr>
<td>Applied Systems</td>
<td>No</td>
</tr>
<tr>
<td>E &amp; L Instruments</td>
<td>Yes</td>
</tr>
<tr>
<td>IMSAI</td>
<td>Yes</td>
</tr>
<tr>
<td>INTEL</td>
<td>No</td>
</tr>
<tr>
<td>Micro Comp</td>
<td>No</td>
</tr>
<tr>
<td>NEC Micro Comp</td>
<td>No</td>
</tr>
<tr>
<td>Process Comp System</td>
<td>No</td>
</tr>
<tr>
<td>Process Tech</td>
<td>Yes</td>
</tr>
<tr>
<td>Pro-Log Corp</td>
<td>No</td>
</tr>
<tr>
<td>Wyle Comp Prod</td>
<td>No</td>
</tr>
<tr>
<td>NITS</td>
<td>Yes</td>
</tr>
</tbody>
</table>

Table 3. 8080 Sets

<table>
<thead>
<tr>
<th>Companies</th>
<th>S-100</th>
</tr>
</thead>
<tbody>
<tr>
<td>Control Logic</td>
<td>No</td>
</tr>
<tr>
<td>Cromemco, Inc.</td>
<td>Yes</td>
</tr>
<tr>
<td>EL Mem &amp; Magnet Co</td>
<td>Yes</td>
</tr>
<tr>
<td>Martin Research</td>
<td>No</td>
</tr>
<tr>
<td>Micro Kit, Inc.</td>
<td>No</td>
</tr>
<tr>
<td>Monolithic System</td>
<td>No</td>
</tr>
<tr>
<td>Mostec Corp</td>
<td>No</td>
</tr>
<tr>
<td>TEI, Inc</td>
<td>Yes</td>
</tr>
<tr>
<td>Zilog</td>
<td>No</td>
</tr>
<tr>
<td>Radio Shack</td>
<td>No</td>
</tr>
<tr>
<td>Wave Mate</td>
<td>No</td>
</tr>
</tbody>
</table>

Table 4. Z-80 Sets
merit, a sole source purchase was justified to USAF Procurement Division.
END NOTES

1. ATCR 50-22 Training Services, 15 Apr 77, Change 1, 29 Jul 77, KTTC Sup, 29 Sept 77

2. ATCR 52-33 Operation of Training Services Activities and UPT Visual Services and Functions, 1 Apr 77, Change 29 Jul 77, KTTC Sup, 27 Sep 76

3. AFR 300-2 Management of the USAF Automatic Data Processing Program, 19 Aug 77, Change 1 (No date available)


5. All About Microcomputer Specifications, Datapro Research Corporation, 1805 Underwood Blvd, Delran, N.J. 08075, June 1977

CHAPTER IV

DESIGN IMPLEMENTATION

Hardware

The main piece of hardware is the Cromemco Model Z2-D Microcomputer (Figure 4) which acts as a switching center for this Simulator/Trainer. Virtually all simulator activity is directed by the Microcomputer. All of the Trainer switches are read by the computer and all of the visual outputs are controlled by the computer.

The Programmable Waveshape Generator P.C. Board

The Programmable Waveshape Generator (PWG) Card is located inside the Microcomputer. Refer to the three schematic drawings (Drawings 1, 2, and 3) of this circuit card. The PWG circuitry is port-addressed. It is capable of generating 64 analog voltages, from 0 to 5 volts in amplitude, in groups from one to 4096 pulses in length, and at rates of either one MHz, or two MHz. It is S-100 bus-compatible (a standard pin out configuration) and may be loaded, under computer program control, at continuous transfer rates of up to two MHz. The PWG, when Loaded and Enabled to run, operates independently of the computer unless action is taken to cause the computer to regain control.

The System Input/Output Interface Card

The System Input/Output (I/O) Interface Card (refer to schematic drawings 4 and 5) is a special purpose memory-mapped I/O controller, located inside the microcomputer. Four memory addresses are used to select the operation of the Data-Out-Port (U-7) and Data-In-Port (U-6) integrated circuits. The 8255 (U-7) uses Port A for
NOTE 1: C-16 THRU C-24 EXIT THROUGS ARE ON BOTH SIDES; DECAPSULATING GAPS DISTRIBUTED THRU OUT THE POWER BUSES ON THE CUT RINGS.

NOTE 2: ALL RESISTORS ARE 1/4 W UNLESS OTHERWISE SPECIFIED.

Drawing -3. AN/TPS-43E Simulator Programmable Waveshape Generator - D/A Converter
Drawing -4. AN/TPS-43E Simulator System I/O Interface - Control Circuits and S-100 Port
computer data output. Ports B and C are control lines to the data select circuits. This integrated circuit (IC) also controls the meters and the display light circuits. The 8212 (U-6) is the computer input IC from the data select circuits.

The I/O interface card uses addresses FFF0 through FFFF to acquire control of four input/output states. In a future modification, pin 13 of U-3 will be connected to pin 4 of U-4 with the output of pin 6 of U-3 going to pin 15 of U-5. The Al input from pin 80 of the PC card edge connector will be connected to pin 8 of U-7. These changes will cause the memory addresses to be FFF0 through FFFF resulting in better memory management.

The outputs of pins 14-17 of U-7 are used as latch enables (Drawing 5) for U-10 through U-17, in groups of two, respectively. Whatever values are at port A of U-7 (Drawing 4) are fed directly through the enabled latches to the meters and/or lights. When pins 14-17 of U-7 go low, those values in the latches remain, resulting in a continuous display.

The Simulator System Front Panel

This front panel is identical in appearance to the BITE section control panel of the AN/TPS-43E Radar Set. Refer to the schematic drawing of the panel, Drawing 10. The outputs of the I/O interface card, described in the preceding paragraph, are wired directly to the panel lights and panel meters. The outputs from the switches (highs or lows) are routed through the data select card circuits to the I/O interface card.
Data Select Cards

The two data select cards (DSC), (Cards #1 and #2), mounted on the simulator front panel are identical. Refer to the schematic (Drawings 6 and 7). The circuitry for each card includes five integrated circuits 16 to 1 multiplexers (16 to 1 MUX). When a simulator front panel switch is in an ON position, +5 volts is applied through the switch contacts, providing a logical one (high), as a multiplexer input. Multiplexer input is grounded through a 330 ohm resistor (logical zero) when +5 volts is not applied (switch OFF position).

The 16 to 1 MUXs select the line to be read by means of pins 11, 13, 14 and 15 which are controlled by lines 22-25 of port B on U-7 of Drawing 4. When pin 13 of port C goes high, the 16 to 1 MUXs are enabled and pass the logic level of the line selected. Connections from the computer to the DSCs is by way of J-4. Connections from the front panel to the DSCs is by way of J-7 and J-8 on Drawing 11.

The third data select card (Card #3) is located in the PC board card rack. The circuitry is similar to that of the data select cards described in the preceding paragraph. (Refer to Drawing 8 for the schematic drawing of this card.) Logical ones and zeros to this card result from the ON or OFF (open or closed) condition of 52 reed switches in the card racks. The trainer card rack simulation is composed of four card racks, (Figure 7b), into which 52 dummy AN/TPS-43E circuit cards are inserted. Magnets, which are attached to the socket ends of the dummy circuit cards, magnetically close the reed switches when the cards are properly seated. A closed switch applies ground (Logical Zero) to a multiplexer input. If a card is not properly seated, or is not inserted, the reed switch remains open and +5 volts
(Logical One) is applied as a multiplexer input. The +5 volts is applied through 2.2K ohm resistors to 80 input lines of the five multiplexers on the data select circuit card.

The Phase Shift Analog/Digital Converter

The phase shift A/D converter PC card is mounted on the simulator front panel. Refer to Drawing 9 for the schematic drawing of this card. This circuit converts positive voltages of from zero to +5 volts into binary values from 0 to 63. These binary values are read by the microcomputer by way of the data select cards on the simulator front panel.

The microcomputer program in use at this time does not utilize the data acquired from the phase shift A/D converter. The utilization of this data may be incorporated into a different microcomputer program at some time in the future.

The oscilloscope used during the operation/maintenance of the simulator/trainer is a Tektronix 465M, or equivalent, equipped with a ten-to-one probe. An adapter, probe tip to BNC, Tektronix P/N 013-0084-01, is used to connect the oscilloscope input jack to the programmable waveshape generator analog output jack (J-1) inside the microcomputer.

The terminal, TV monitor and keyboard is used for maintenance only. This terminal, Lear-Siegler Model ADM-3A, is equipped with an RS-232 connector, which is connected through a cable to the microcomputer during maintenance for floppy disk loading operations.

Trainer Turn-On and Turn-Off Procedures

The following procedures should be followed each time the trainer is operated:
1. Open the hinged front panel of the trainer.

2. Open the disk drive door on the microcomputer front panel.

3. Connect the AC power plug (P-1) to a 120 VAC, 60 Hz source.

4. Turn on CB-1, the switch/circuit breaker marked POWER.

This switch is located on the right front side of the trainer cabinet. A red indicator light on the disk drive inside the microcomputer, and all the indicator lights on the trainer front panel will turn on. Both meters (M-1 and M-2) on the trainer front panel will read full scale.

5. Place the floppy disk (BITE program) into the disk drive with the silver tab down to the ground and towards the operator. Close the disk drive door. A series of clicking sounds from the disk drive, lasting approximately 45 seconds, indicates that the BITE program is being loaded into the microcomputer. At the end of the loading cycle, all of the indicators will turn off and meters M-1 and M-2 will read less than full scale.

6. Open the disk drive door and remove the BITE program disk. Place the BITE program disk in a storage container. Close the disk drive door and the trainer front panel.

7. The trainer is ready for use.

8. The trainer is turned off by placing circuit breaker CB-1 in the OFF position and disconnecting power plug P-1 from the 120 VAC source.

Caution

If an indication described in this procedure does not occur at the designated time, there is a malfunction within the trainer which must be corrected before continuing with the procedure. Power plug P-1 should be disconnected from the 120 VAC source before troubleshooting.
the trainer. If circuit breaker CB-1 trips, do not reset it without determining the cause. If any fuse blows, do not replace the fuse without determining the cause.

Additional Precautions

1. Power plug P-1 should always be disconnected from the power source when the trainer is not in use and during electrical storms.

2. The trainer should not be rolled on soft surfaces such as grass or sand.

3. The microcomputer inside the trainer cabinet should be secured before moving the trainer.

4. The oscilloscope, terminal (TV monitor and keyboard) and all unsecured cabinet drawers should be removed from the cabinet before the trainer is moved.

5. Precautions should be taken to prevent overturning the trainer while rolling or fork-lifting.

6. Only narrow skids should be used when fork-lifting the trainer.

Trainer Power Requirements

The trainer power requirements are as follows:

110 VAC, 60 Hz at 15 amps
+8 VDC at 30 amps*
+18 VDC at 15 amps*
-18 VCD at 15 amps*

*output by the microcomputer's power supply.

Programmable Waveshape Generator PC Card

Refer to the three programmable waveshape generator (PWG) schematic drawings, Drawings 1, 2, and 3 during the following descriptions.
Drawing 2 shows the memory section of the card (U-1 through U-6). Each of these integrated circuits consists of 4 each RAM memories (TMS 4033 integrated circuits) stacked vertically and wired in parallel. The enable control decoder (U-7) is also shown on the Drawing 2. Drawing 1 shows the circuits from which U-1 through U-7 receive their inputs (write lines, address lines and data lines). Drawing 3 shows the D/A converter (U-22), which received data from the data port latches (U-8 and U-9) during the data load mode and reads (senses) the data in the IC memories during the run mode. The 6 outputs of U-22 are applied to the summing network (R-1 through R-19). The analog voltage output from the summing network is applied to the input of Op Amp U-21. The output of the Op Amp is connected to J-1, which is the analog output jack for the PWG.

Clock Control Circuitry

The circuitry for the 2 MHz clock, which is used as the timing source for the PWG during the run mode of operation, is located in the lower left section of drawing 1. The clock circuitry is discussed at this time since the clock output pulses from the clock or write gate (pin 3 of U-30) will be referred to many times in the body of this manual. The frequency of these pulses will be 2 MHz or less and their polarity will be plus at any frequency.

The microcomputer operates at 4 MHz; therefore, the PWG must be able to load at a 4 MHz rate during the MSD, LSD and data load modes. The microcomputer clock and write gate output pulses are both 250 nanoseconds (ns) long. During the run mode, the frequency of these pulses
comes from a 2 MHz crystal and is controlled by the + by 2 clock circuit to be 1 MHz or 2 MHz. The microcomputer in this trainer is programmed to send trigger pulses to the + by 2 clock circuit to change the running frequency of the PWG clock pulses from 2 MHz to 1 MHz and vice versa. These clock frequency changes are caused by the design limitations of the trainer. The + by 2 clock circuit is used during the run mode of operation to control the frequency at which the memory is read (1 MHz to 2 MHz). The waveshape pulse width seen on the oscilloscope connected to analog output jack J-1 is an indication of the frequency which is being used.

The state (set or clear) in which the + by 2 control FF (U-I1A) is operating determines the frequency of the clock pulses from clock or write gate pin 8 of U-30. The state of this FF can be changed by triggers from the microcomputer on edge-connector pin 83. These triggers are applied to pin 1 of the + by 2 clock port NAND gate U-I1B.

The input to pin 2 of + by 2 clock port is the latch strobe, from latch strobe gate U-20 (pin 1), which will be described later in this discussion. When these two inputs to the + by 2 clock port are Hi, the output at pin 3 goes Lo. This Lo is applied to pin 12 of the + by 2 control FF at the same time a Lo from U-7 (pin 4) occurs which enables Q' of U11A for a 1 MHz operation. Each input pulse triggers the + by 2 control FF to change states (set to clear, or clear to set).

At the beginning of the turn-on/turn-off procedures, the output of latch strobe gate U-20 (pin 1) is a steady-state Lo, which is applied to pin 2 of the + by 2 clock port and also to the set input (pin 10) of the + by 2 control FF. This Lo keeps it in the set state until the first trigger from the + by 2 clock port is applied to pin 12.
of the + by 2 control FF. Thus, Q is enabled on initialization to provide 2 MHz operation until a trigger pulse makes Q' go Hi.

The run (002) output transition from Hi to Lo causes the + by 2 control FF to change states when pin 12 is Lo also. Pin 4 of U-7 is high during the run state; therefore, when a new waveshape begins loading it goes low and clears U-11A for 2 MHz operation. The clear mechanism insures a baseline starting value in U-11A for each new data load. When a load is completed, a run mode (002) signal, sent to port 7F (Hex), leaves the 2 MHz controls as is while an identical signal sent to FF (Hex) puts the + by 2 control to 1 MHz operation. Each of the inputs described above triggers the + by 2 control FF to change states and each change causes the output pulses from the clock or write gate to change frequency.

The PWG does not change frequency during the run mode. The state (set or clear) of the + by 2 control FF at the beginning of the run mode will determine the timing pulse frequency (2 MHz or 1 MHz) during the run mode. The 2 MHz clock oscillator is crystal-controlled by crystal Y-1.

The 2 MHz clock pulses from pin 2 output of U-23 are applied to pin 10 of the clock gate (U-11B) and to pin 3 of the + by 2 clock divider FF (U-11A). The other input to clock gate pin 9 (U-11B) is the Q' output from pin 9 of the + by 2 control FF (U-11A). The Q' output from the + by 2 control FF (pin 8) is one input to the + by 2 clock gate (pin 4) and the other input (to pin 5) is the Q output (pin 5) of the + by 2 clock divider FF, which changes states at the 1/2 PWG clock oscillator frequency (1 MHz). When the + by 2 control FF is set, the Q output from pin 9 (U11A) is Hi and the Q' output from pin 8 is Lo. The
clock gate is enabled by the Hi to pin 9 (U11B) while the \( \tau \) by 2 clock gate is inhibited by the Lo to pin 4. Thus, the Hi 2 MHz clock pulses to pin 10 are passed through the clock gate at the original frequency.

The FF (Hex) input trigger to the \( \tau \) by 2 control FF causes it to change from set to clear (\( Q \) goes Lo and \( Q' \) goes Hi). The clock gate is inhibited by the Lo \( Q \) input to pin 9 while the \( \tau \) by 2 clock gate is enabled by the Hi \( Q' \) input to pin 4. Since the \( \tau \) by 2 clock divider FF changes states at the 1 MHz clock frequency, the \( Q \) output (pin 5) is Hi on alternate clock input pulses. Thus, the input to pin 5 of the \( \tau \) by 2 clock gate is at 1 MHz.

The 1 MHz or 2 MHz clock gate (U-11B) passes either frequency that is applied as an input because one of the unselected clock gates is always outputing a steady state Hi. The clock pulses at output pin 11 are applied to input pin 9 of NAND gates U-30. The other input to this NAND gate (pin 10) is a steady-state Hi from the output (pin 11) of another NAND gate of U-30, which has its inputs (pins 12 and 13) tied together and grounded through the reset line. The clock pulses at the output of U-30 (pin 8) are the timing pulses for the PWG.

**Power**

At the top of Drawing -1 are shown the DC power circuits for the PWG circuits. Voltage regulator U-31 has +8 VDC input from edge connector pin 1. The output of U-31 is +5 regulated. Resistors R-30 and R-31, and Zener diodes CR-1 and CR-2, are used to reduce and regulate +18 VDC and -18 VDC inputs to +12 VDC and -12 VDC respectively. The 18 volt inputs are from edge connector pins 2 and 52. These three voltages (+8 VDC, +18 VDC and -18 VDC) are supplied by power supplies
in the microcomputer. All of the other inputs to the programmable waveshape generator (PWG) are also from the microcomputer.

Port Addressing

The eight inputs (D-0 through D-7) to data port latches U-8 and U-9 are sources of the data loaded into the memories. When these two latches are enabled by the latch strobe from pin 1 of latch strobe gate U-20, data and/or address instructions can be brought into the PWG and loaded into the PWG memory. The first six of the inputs to U-8 and U-9 (D-0 through D-5) are data input lines and the last two (D-6 and D-7) are used as mode control lines to program control decoder U-7. The inputs from the microcomputer are TTL logic levels (+5V highs or 0V lows). The value "7C" hex address ("7C" Hex), used to address port address detector U-10, along with SOUT from the S-100 buss, causes highs at all eight U-10 inputs. The output at pin 8 goes Lo and is applied to input pin 2 of latch strobe gate U-20. The PWR write strobe from edge connector pin 77 is the second input to U-20 (at pin 3). These two Lo inputs cause pin 1 of this NOR gate to go Hi. This is the latch strobe and is used in three places in the PWG. Lo inputs A-0 and A-1 of the "7C" hex address are inverted by two sections of inverter U-26 and applied as Hi inputs to NAND gate U-10. The other "7C" hex address inputs to U-10 are Hi. The PWR write strobe (Lo) and SOUT (Hi) occur at the same time as the "7C" hex address. The latch strobe from pin 1 of U-20 goes to pins 4 and 13 of both data port latches U-8 and U-9. These latches are then enabled to bring data from the microcomputer into the PWG.
PWG Timing Frequencies

The microcomputer operates at a 4 MHz clock rate while the PWG, due to the slower speed of its own memories, must operate at a 2 MHz (or less) clock rate. However, due to the time intervals during non-output instructions in the microcomputer, there is sufficient time for the slower PWG memories to be loaded. The memory address latches and memory address counters must be enabled for longer periods of time (after the port address latches are no longer enabled). This is accomplished by using the latch strobe gate, described above, to generate a 500 ns pulse which is used to keep the memory address latches and counters enabled after the termination of a legal port address of "7C" or "FC" (Hex). The Hi latch strobe is applied to pin 5 of U-25 in the write pulse widening one shot multivibrator (OSMV) circuit, shown on the top left section of the referenced schematic. The OSMV is triggered by the trailing edge of the latch strobe. The OSMV is part of the control logic circuit which is made up of one NAND gate of U-25 and three inverters of U-24. Resistors R-26 and R-25 and capacitor C-7 comprise the RC time constant circuit. Rheostat R-25 is adjusted so that the output pulse from the OSMV is approximately 500 ns in duration. The Hi output of U-25 (pin 6) is inverted through three inverter stages of U-24 in succession. Pin 10 output is a Hi 500 ns pulse and pin 8 is a Lo 500 ns pulse. The Hi at pin 10 is the write strobe which is applied to input pin 9 of write gate U-25. The other input to the write gate is the data line (102) from pin 6 of the program control decoder (1/2 of U-7) which is Lo during the data load mode. The data line input is inverted by one inverter of U-23 and pin 8 output of U-23 is applied to pin 10 of the write gate as a Hi.
Program Control Decoder

Lines D-6 and D-7 from the microcomputer to data port latch U-8 are mode control lines to the PWG. When U-8 is enabled by the latch strobe, the outputs (pins 9 and 10) will be in one of four possible combinations of highs and lows, (11₂, 01₂, 10₂ or 00₂), which are applied as inputs to pins 2 and 3 of program control decoder U-7. The outputs of U-7 are used to select one of the four modes in which the PWG operates. The PWG can be in the run mode (00₂); it can be in the data accepting mode (10₂); it can be accepting an address load of the least significant digit (01₂); or it can be accepting an address load of the most significant digit (11₂). The outputs of U-7 are Hi until selected. The mode selected will cause that mode output line to go Lo. The four modes are selected in the following sequences: MSD (11₂), LSD (01₂), Data (10₂) and Run (00₂).

Memory Address Latches

Since only six data lines from the data port latches are used to load 12 bits of address into the MSD and LSD memory address latches, the 12 bits are loaded in two groups of six each. This is done by enabling the MSD memory address latches (U-27 and 1/2 of U-28) during the MSD mode (11₂), and the LSD memory address latches (U-29 and the other 1/2 of U-28) during the LSD mode. When the input combination from U-8 (11₂) causes the MSD load output of the program control decoder to go Lo, this Lo is applied as an input to Pin 11 of MSD load gate U-20. The inverted write strobe (1₀) from pin 8 of inverter U-24 is the other input (pin 12). These two Lo inputs cause the output of the NOR gate (pin 13) to go Hi. This Hi is applied to pins 4 and 13 of U-27 and to pin 4 only of U-28 (memory address latches). U-27 and 1/2 of U-28 are
then enabled to load six MSD address bits from the six output of the data port latches.

When the program control decoder is sequenced to the LSD load mode (012) by the microcomputer the MSD load output goes Hi and pin 13 of MSD load gate U-2 goes Lo, so that the previously loaded memory address latches (U-27 and 1/2 of U-28) are no longer enabled. The LSD load output goes Lo. This Lo LSD output (012) is applied to Pin 8 of the LSD load gate U-20. The reinverted write strobe (Lo) from pin 8 of inverter U-24 is used as the second input to this NOR gate (at pin 9) also. The resultant Hi output at pin 10 is applied to pins 4 and 13 of U-29 and to pin 13 only of U-28. The second half of U-28 and all of U-20 are then enabled to load six LSD address bits from the same six outputs of the data port latches. The 12 output lines of the three memory address latches are connected to 12 inputs of the memory address counters (U-17, U-18, and U-19). These counters are inhibited from receiving the 12 address bits from the latches by the Lo input from pin 4 of NOR gate U-20 (load or last count gate). When the output of the LSD load gate transitions from Hi to Lo, after approximately 500 ns, this Lo inhibits the LSD memory address latches (U-29 and 1/2 of U-28) and is also applied to input pin 5 of the load or last count gate (U-20). The input to pin 6 is normally Lo from pin 12 of the last count inverter (U-23). These two Lo inputs cause a transition from Lo to Hi at output pin 4. This Hi is applied to pins 11 of the three memory address counters as an enabling pulse and the 12 address bits from the memory address latches are loaded into the three memory address counters. The address numbers from the three counters will determine the
duration of the waveshapes observed on the oscilloscope at analog output jack J-1 when the PWG is in the run mode.

Memory Address Counters

The three counters are wired in series so that, when downcounting, the outputs form a series of 12 bit numbers, starting with the maximum binary address value and downcounting to zero. The Hi clock pulses from pin 3 of U-30 (clock or write gate) are applied to pin 4 of U-19. (Refer to paragraph on clock control circuitry for the description of the generation and control of the clock pulses.) Each pulse downclocks the three counters to a different binary address value. The SM74193 counters are designed to be used in multidecade operations, without additional logic, by using the borrow output of one counter as the downclock input to the following counter. When U-19 has counted to 00, a Hi from U-19 (pin 13) to U-18 (pin 4) starts the countdown of U-18. When U-18 counts down to 00, a Hi from U-18 (pin 13) to U-17 (pin 4) starts the countdown of U-17. When U-17 counts down to 00, all of the 12 outputs of the counters are Lo. These outputs are inverted by U-14 and U-15 and applied as Hi inputs to multiple NAND gate U-16, the last count detector. The Lo output at pin 9 of U-16 is inverted by last count inverter U-23 and is applied as a Hi to U-20, pin 6, the load or last count gate. The resultant Lo output at pin 4 of U-20 is applied to pins 11 of the three memory address counters. This Lo inhibits the counters from being loaded from the three memory address latches, as described in paragraph 2-13, until the LSD load gate output (U-20, pin 10) transitions to Lo.

The output of the last count inverter is also applied to sync output jack J-2 and is used to synchronize the oscilloscope. The
countdown pulses used to downcount the memory address counters are Hi outputs of clock or write gate U-30 at pin 3.

**Memory Load Control**

It was stated earlier in this chapter that the PWG, when loaded and in the run mode, could operate independently of the microcomputer. During the data load mode, the data line (102) from the program control decoder is Lo. This Lo is applied to input pin 9 of inverter U-23. The Hi output of U-23 at pin 8 is one input (pin 10) to write gate U-25. The write strobe (alternately Hi or Lo) from pin 10 of U-24 is the other input (to pin 9) of the write gate. Pin 8 output of the write gate is therefore alternately Lo or Hi. It goes Lo in coincidence with the leading edge of the 500 nanosecond write strobe. Clock gate U-25 is inhibited by the Lo at pin 13 from inverter U-23 (pin 10). The input to this inverter (pin 11) is the Hi run (002) output of the program control decoder.

The PWG clock pulses at input pin 12 of the clock gate, from U-30 pin 8, are not passed through the clock gate. The output of the clock gate at pin 11 is the input to pin 2 of clock or write gate U-30 and remains Hi during the data mode. The input to pin 1 of the clock or write gate is the output of the write gate (pin 8). When this input goes Lo, the output at pin 3 goes Hi, in coincidence with the leading edge of the write strobe. The output pulses at pin 3 of the clock or write gate are the pulses used to downclock the memory address counters, and are generated and controlled by the microcomputer program.

However, during the run mode there are no inputs, other than the three power supply voltages, from the microcomputer.
The write gate (U-25) is inhibited by a steady state Lo at pin 9 from pin 10 of U-24 (there are no write strobes during the run mode). The data line (102) input to pin 9 of inverter U-23 is Hi in the run mode. The Lo output of the inverter (pin 8) is applied to input pin 10 of write gate U-25 resulting in a steady state Hi at output pin 8. This Hi is applied as an input to pin 1 of clock or write gate U-30, and also to input pins 4 and 5 of NAND gate U-30 in the write delay OSMV circuit. Since this is a steady state voltage, there are no write pulses generated in the write delay OSMV circuitry during the run mode. Clock gate U-25 is enabled by the Lo output of the run (002) line from program control decoder U-7 during the run mode. This Lo output is inverted to a Hi by inverter U-23. The Hi output at pin 10 is applied to pin 13 of clock gate U-25. The Hi PWG clock pulses (1 MHz or 2 MHz) from pin 8 of U-30 are applied to pin 12 of the clock gate. The clock gate output (pin 11) goes Lo with each pulse. These Lo pulses are applied to pin 2 of clock or write gate U-30. The Hi output pulses at pin 3 are the same frequency as the PWG clock pulses (1 MHz or 2 MHz). These are the downclock pulses used to downclock the memory address counters. They are generated and controlled without inputs from the microcomputer. During the data mode, the downclocking of the memory address counters assures that each data bit is loaded into a different address in the memory. During the run mode, the downloading assures that the data bits in the memory are correctly addressed for reading.

**Write Delay One Shot Multivibrator (OSMV)**

During the data mode, the output pulses from pin 8 of write gate U-25, described in paragraph 2-15, are also used to trigger the
write delay OSMV. This output is applied to input pins 4 and 5 and NAND gate U-30 which acts as an inverter. The output at pin 6 (Hi) is applied to pin 2 of U-25, the OSMV NAND gate. The OSMV is triggered by the trailing edge of the pulse (negative-going), so the OSMV output pulse is delayed approximately 500 ns after the leading edge of the input pulse.

The OSMV circuit is made up of NAND gate U-25 and two inverters of U-24. The RC time constant circuitry is identical to that of the pulse widening OSMV described above. Rheostat R-22 is adjusted so that the output pulse is approximately 500 ns in duration. The Hi output at pin 4 of the second inverter is applied to the inputs of three inverters (U-26) in parallel. These three inverter/buffers are needed to supply the driving power to the write lines to the 24 random access memories (RAMs).

Each inverter/buffer output is applied to the write (pin 3) input of eight RAMs in parallel. The inputs occur after the RAMs are addressed and enable all 24 RAMs to be loaded with data from the data port latches (U-8 and U-9). Lo write input pulses occur 500 ns after the down clock pulses to the memory address counters described earlier. The write delay OSMV is used to compensate for transit time losses in the memory address latches and counters, and to assure that there is sufficient time for the RAMs to be correctly addressed for incoming data and for that data to be correctly loaded into the memory.

Memory Loading

It was explained that the memory address latches (U-27, U-28 and U-29) were enabled to accept address data by the Hi outputs from the MSD and LSD load gates, pins 13 and 10 respectively of the two NOR
gates of U-20. Both of these outputs are Lo during the data mode since the MSD (112) and the LSD (012) outputs from program control decoder U-7 are Hi. Therefore, the memory address latches are inhibited from receiving data of any kind. Any data in the data port latches (U-8 and U-9) will go directly to the RAMs.

Data from U-8 and U-9 is routed to the RAMs on data lines D-0 through D-5, with each of the six data lines connected to the pins 11 (DIN) of one IC (four each TMS4033 RAMs stacked and wired in parallel). The 12 outputs of the memory address counters (U-17, U-18, and U-19), after being inverted by 12 inverters of U-14 and U-15, are each applied to both inputs of one of the 12 NAND gates of memory address drivers U-11, U-12 and U-13. Address lines 0 through 9 from the memory address drivers are wired so that each address line goes to the same input pin of each of the 24 RAMs in parallel. The other two outputs from the memory address drivers (U-11, pins 3 and 6) on lines 10 and 11, are applied as control inputs to enable control decoder U-7 (pins 13 and 14).

One half of U-7 was described in paragraph 2-10 as the program control decoder. This half of U-7 operates in the same manner. The inputs to pins 13 and 14 are four possible combinations of highs and lows (002, 012, 102 and 112). The four outputs at pins 9 through 12 are Hi until selected by one of the binary inputs. At that time, the selected output goes Lo. The four outputs are the Row-Addressing Strobes, with each output connected to pins 13 (CE) of the six RAMs in each of the four rows. The selected Lo output enables six RAMs in one row to load data. Six data bits on the six data line (D-0 through D-5) are loaded into six RAMs in the selected row. Since all 24 RAMs are
addressed identically from the address lines at each address, the electrical locations of the six memory cells in six selected RAMs is also identical. A data bit on any one of the six data input lines can be loaded into only one specific RAM, as determined by the enable control decoder configuration. Each of the 1024 memory cells in each RAM is individually addressed and selected for loading by the combinations of address line inputs from the memory address drivers. The delayed write strobe assures that there is sufficient time for the selected/addressed memories to be loaded.

**Oscilloscope Monitoring**

As the data from the data port latches (U-8 and U-9) is being loaded into the RAMs, it is also applied to the input of six inverters of U-22 in the D/A converter. The outputs of the six inverters are applied to the summing network, composed of resistors R-1 through R-19.

This network is provided with +5 VDC from voltage regulator U-22, which is supplied with +8 VDC from the microcomputer through the PWG circuit board edge connector. The output of the summing network is applied to input pin 8 of operational amplifier (Op Amp) U-21. The output of the Op Amp at pin 4 is connected to analog output jack J-1 which is the monitor point (oscilloscope display) for the trainer/simulator.

The D/A circuit is identical to that in the AN/TPS-43E radar system and has the same response time. The waveshapes seen on the oscilloscope are made up of 64 analog voltages of from 0 volts to 5 volts in amplitude. During the run mode of operation, data loaded into the memory is read sensed by the D/A circuit and applied to the oscilloscope through the same circuitry. As in the AN/TPS-43E radar system,
the oscilloscope display is an indication of the positions of all of
the switches in the system, as read by the microcomputer.

Run Mode

The binary inputs to program control decoder U-7 from the
microcomputer (11₂, 01₂, 10₂ and 00₂) determine the mode in which
the PWG is operating at all times. After the data has been loaded into
the memories, inputs to the program control decoder (00₂) from the
microcomputer switch the PWG to the run mode. The run (00₂) output
from U-7 goes Lo and the other U-7 outputs are hi.

The three memory address latches (U-27, U-28 and U-29) continue
to be inhibited from receiving additional address and the address al-
ready in these latches is controlled by the PWG clock (1 MHz or 2 MHz).
This frequency (1 MHz or 2 MHz) is controlled by the + by 2 clock cir-
cuitry. There are no microcomputer inputs so the PWG is operating in-
dependently of the microcomputer.

The clock pulses from clock or write (U-30, pin 3) count down
the memory address counters (U-17, U-18 and U-19), as described in
paragraph 2-14, but the clock pulses are generated in the PWG clock
oscillator circuit and the frequency (1 MHz or 2 MHz) of the pulses is
controlled by the + by 2 clock circuitry. The counters count down one
digit on each clock pulse, from the maximum binary address value down
to zero. The combination of Hi and Lo outputs on the 12 output lines
changes at each down count and each different combination becomes a
different address; to selected memory cells; in selected RAMs; in se-
lected rows of RAMs.

Since there are no inputs from the microcomputer during the run
mode, there are no outputs from the write pulse widening OSMV circuit
and consequently, no input to pin 9 of write gate U-25 which is therefore inoperative. The output of the write gate (pin 8) was used to trigger the write delay OSMV during the data load mode, to generate the delayed write strobes to the memory. The write strobes are not required during the run mode. The Lo write strobes enabled the addressed locations to be loaded with data during the data mode. The write lines inputs to the RAMs remain Hi during the run mode. This enables the RAMs to be read (sensed) so that data already loaded into the addressed locations is read as each location is addressed during the run mode. This data is routed through the output lines (D-0 through D-5) to the D/A converter circuitry, which was described above. As in the data read mode, the D/A converter output goes to analog output jack J-1 for oscilloscope monitoring. On the last output all the counter values are zero. At this time a pulse from U-16 reloads the counters and also strobes J-2, the sync line of the oscilloscope.

Software Locally Developed

The software created for this project were: the application program in FORTRAN, the support programs in FORTRAN and BASIC and the maintenance programs in BASIC and direct machine code. The application program (Appendix F) is a structured design which easily accommodates testing of program modules. The other programs are very simple and did not require the elaborate planning afforded to the application program.

First consider the control (TPSPGM) module (Figure 11). This particular module has the purposes of bringing the program on line and controlling all other modules, i.e., to provide a central source of control over the other modules. Without this, the structuring of the
Figure 11. TPSPGM Flowchart
program would have been impossible. The software design is intended to have a structure that is not ambiguous to the user. Since software maintenance consumes manpower, and the user expects that the maintenance of the maintenance simulator should be low, a modular design provides "to the module" problem identification.

The input module (INPUT) is a relatively simple subprogram. Its purpose is to go to the necessary ports and memory addresses to acquire information from the trainer itself. Information acquisition actually is broken into two parts. First is the acquisition of data from the faceplate and second, from the equipment of the card cage.

From the faceplate, the computer selects information about the settings of the various switches so that it can determine what particular display needs to be output to the oscilloscope. From the card cages, the computer must determine which card, if any, has been replaced to simulate fault repair. The computer will then respond by presenting a corrected picture. The data acquisition module must distinguish between the faceplate and the card cages in order to be able to get data from these two groups in the correct order.

Due to hardware constraints, it is necessary for the acquisition module to make two searches, one search of the faceplate and one search of the card cages. (See Figure 12.) Each search consists of reading a set of 16 eight-bit bytes representing 128 bit positions controlled by eight 1 of 16 multiplexers (MUX) in parallel. A search is initiated by enabling a data set with a bit in port C and addressing that set via port B. Two sets of data are currently searchable, where the first data set uses all 128 bits and the second data set contains only 55 bits used out of 80 possible wired positions. Once a data set
Figure 12. Block Diagram of I/O Controller
is enabled and a byte within it addressed, it is read from the 8212 at port C.

The ports described thus far are memory mapped rather than actual port addresses. Memory addresses serve to activate the 8255, which is a software programmable I/O device. In systems which do not have large memory requirements, and do have extensive I/O requirements, this procedure is very convenient. For the purpose of this project, both memory map and port addressing are used in the hardware. The reason for using memory map addressing for I/O and regular port addressing elsewhere for the output of the oscilloscope is that the project desired to demonstrate that it can be done both ways. The data acquisition module serves as a method of getting information into the computer. The next thing that is necessary is evaluation modules.

The evaluation module(s) (DECIDE and ADMEN) is (are) designed to look through all the information that has been collected by the data acquisition module. Decisions are made by cascade logic evaluation. This equates to a tree search wherein the keys to the branching are taken from the faceplate switch positions. The general flow, shown in Figure 13, is a series of, at most, ten decisions leading to correct picture determination. Of those ten decisions, five were 'Do Case' decisions, which represent the cascade concept utilized. Most of the pre-decision evaluation is done in terms of boolean logic programming as opposed to arithmetic programming. The reason for using LOGICAL code is speed.

The computer uses an eight-bit data word. If arithmetic means of dealing with these words are chosen, the lead bit is reserved for a sign bit. If that one bit happens to be turned on, automatic two's
Figure 13. DECIDE Flowchart
complement arithmetic takes place making it very difficult to control using simple code. By making everything single-bit LOGICAL, the computer effectively converts every LOGICAL word manipulation in the computer to eight-bit paralleled gating, such as an eight-bit AND, OR, or NOT gate. By performing logical AND, logical ORs, exclusive ORs, and inversions, each point is testable using relatively fast straightforward logic. Another good feature of LOGICAL code is that it is very easily followed by electronic maintenance people who, presumably, are going to be the ones who will look at this program and see whether it is functioning. Boolean logic then is the basis of the evaluation module.

DECIDE and ADMEN conserve memory by examining 32 eight-bit words which form a 328 array of switch conditions on the trainer. Determination that a particular word bit is turned on is accomplished by doing a logical AND with a word that contains only that bit turned on—a true return means that the bit tested is turned on. Conserving memory space is essential since the trainer has a 32,000 word computer and a training program space of approximately 25,000 words. There is not much space for extensive arrays when the 7000 word disk operating system and a 22,000 to 24,000 word program must co-exist there. The evaluation module determines which picture will be displayed by looking at all the switches and then supplying the necessary information to the display module PICTUR. Prior to picture display TPSPGM calls ERROR.

ERROR is called to determine if the student should be given a malfunction dependent on the current settings of the BITE. If such an error should be required, it is inserted into the text of the picture buffer (IODAT) or is passed directly to PICTUR as a systemic error.
The data display module (PICTUR) is a subprogram which functions to create pictures that can be displayed on the oscilloscope (Figure 14). It is broken into three major areas: point-by-point displays, point-to-point vectors, and random point displays.

Area one is the point-by-point displays. This area is specifically intended to allow any individual voltage to be displayed on the oscilloscope followed by another one of a different level without any regard to vector calculation. Therefore an arbitrary point pattern can be displayed.

Area two is the vector display component of this module, which allows display of a line which rises or falls from a baseline of (and to) any of nine predetermined heights (maximum of 4 volts, minimum of zero volts). Display of a level line of any length (e.g., from 1/2 microsecond (us) to 2450 us) at any given voltage desired (e.g., at any of 64 possible voltage levels between zero and 5 volts) is also available. Area one is the special case of the level line where length equals one clock pulse. Each of these is a vector so that only the beginning and the end points need be given and the rest will be calculated, assembled, and transmitted to the PWG.

The reason for this method is that most of the pictures to be generated can be done using a two byte, single integer word. On the rare occasion when one cannot be done this way, as yet not encountered, an option exists which uses two integer words (of 16 bits each), prefixed with a negative sign, to provide any vector whatsoever. The modifications to PICTUR are to be found at the end of Appendix F.

Area three is a random number generator (RNC) used to create digital noise. The RNC is a simple multiplying type which provides
Figure 14. PICTUR Flowchart
random values from 1/2 volt to 3 volts in 1/2 volt steps. The picture module puts a particular picture into the display hardware and allows insertion of any ERROR chosen dysfunction.

As an example, consider a digital to analog converter. Input is 1 of 64 discrete voltage levels encoded in 6 parallel bits. (Drawing 3.) If one of the parallel bit drivers is on, then that driver's output is continuously high regardless of what the input to it is. Thus a malfunction exists that should be demonstrable. One place to inject this malfunction is during the creation of the picture by logically ORing in that bit before data transmission. All the rest of the data will be correct but the error bit will always be on and behave exactly as the actual equipment will when broken as described above.

Another example malfunction exists when a bit is turned off continuously. This is mimicked by using a one's complement of the bit to be removed, logically ANDed with the data. By guaranteeing that the data is logically ANDed with a zero in a particular bit, assurances are made that all of what is in the original picture passes except for the chosen bit. The errors described above are common failures within the actual equipment.

The support software consists of a short program which creates a unique disk record within an error file (Appendix G). Each record is a specific problem which the student will be required to solve. The program consists of two data sets, created using the editor, that are immediately put to disk. The program then terminates. This program is simple enough to preclude serious problems in its own maintenance. FORTRAN was chosen because BASIC files are not compatible with the FORTRAN application program.
The data statement NAME is filled with the file name. The name ERRS??DAT is the file name with the ?? being the particular record number under consideration. The application program will take the octal number of the faceplate's thumb wheel switch and insert an alphanumeric representation of it into the error file-record request.

The data statement IPUT is a coded error record. The nature of the error routine is that multiple dependent and independent dysfunctions are easily created, given the correct error file. The first element in the file is the length of the file, in addressable words. The next seven elements are seven different switches and their associated positions. Because the list is constant, the switch numbers are implied and only the positions appear on the list. The appearance of a zero indicates a "don't care" switch position. The last three values are the error type, card to be replaced, and picture affected respectively.

Of the last three values, the first has a dual role. If it is greater than 49 it is used as a selector of a bit stuck on, or off, as described above. The formula used is:

\[ \text{Bit} \# = \text{Value} - 56 \]  
\[ 49 < \text{Value} < 63. \]  

When this value is coded less than 50, it is taken as the assignment of a new picture, not in the normal set, in place of the one usually found at this switch setting. A separate list is required for each picture affected. The length of the record is 91 words composed of a maximum of nine error lists of ten elements each, plus the record size itself.
Currently there are over 30 different error records on the system. The potential is for 63, with the ØØ record being the null record for normal operation. All error records were decided upon and encoded by instructor personnel.

The second support program is the picture code generator (Appendix H). This program is written in \textsc{basic} to provide ease of use and/or possible maintenance. There are five elements within the program covering points, vectors, and random noise pictures. Due to the extensive documentation within the program all that needs to be said here is that the output is a picture code printout which must be inserted manually into the application program prior to compilation.

\textbf{Performance Evaluation Test Procedures}

The testing of this system consisted of taking a class of new TPS-43E instructors as students when they were about to enter the BITE training phase of the course. The class was broken into two groups. One group was trained on the actual radar, while the other group trained on the BITE simulator. At the conclusion of training each group was tested on knowledge and performance using the alternate equipment trained on. Each group was then given a questionnaire concerning observations of each environment.

\textbf{Results}

The maintenance simulator compared well on ease of use and fidelity of waveforms; the simulator was superior in terms of space and flexibility. The negative remarks were that it drew some waveforms slowly and currently only covered BITE functions. The instructors were unanimous in recommending the trainer be used in place of actual BITE equipment.
Observations

The maintenance simulator (at delivery) performed the BITE functions requested by the user at the beginning of this project. Upon turnover to the user, one of the instructors suggested another BITE function which the simulator hardware could already support. The software was generated in two days (in final form) which indicates the expansion capabilities of the equipment. This fact was not lost on the user who has ordered an expanded model this fiscal year, and another next fiscal year.
CHAPTER V

CONCLUSIONS

Microcomputer driven simulators are feasible for electronic maintenance training. Computers are available from vendors which can be interfaced to maintenance mockups using conservative, yet current, technological concepts. The interfaces resulting from this study permit S-100 bussed microcomputers to be used in a wide variety of training simulators. The TPS-43E BITE is only one example of the ways in which the microcomputer driven maintenance simulator may be used.

In the TPS-43E BITE simulator design phase, concurrent hardware and software construction was an absolute requirement. The potentials of hardware and software design each constrained and aided the other to such an extent that neither could be created alone. The hardware versus software dichotomy of the past three decades vanished in the face of a portable and cheap microcomputer in the hands of the programmer-designer.

Selection of commercial equipment is greatly assisted by decision matrices, since the equipment sought is not expensive enough to support a request for proposal from the vendors. In this case the commercial equipment selected, via an interaction of maximum CPU architectural power, bus utility, and software power, led to a Z-80 processor with an S-100 bus which supports FORTRAN IV. Source data for the decision matrices was frequently supplemented by user reports found in trade journals.
The prototype BITE simulator, (from the design, financial and training points of view), is an unqualified success. The equipment has met, or exceeded, every expectation envisioned at the outset for performance, reliability and maintainability. The overall cost of the project, exclusive of labor and initial design equipment, was $6,500. The total prototype investment was about $65,000. The simulator was delivered two months earlier than projected and began use as a trainer within the first week after delivery. The early decision to develop hardware and software concepts concurrently is the source of the success enjoyed by this project.

The lack of a DOD mandate to Electronic Systems Division (ESD) to pursue the maintenance simulator concept created the source of the management challenge. When a system programming office (SPO) within ESD is created to address maintenance simulators, the project monies and personnel will become reliable resources. Until such a SPO, or its equivalent, is created, projects such as this should be viewed in terms of the person who has the courage to take primary responsibility to ensure project completion. This same person must also be considered in terms of ability to deliver command supported investment of resources to a special activity outside of normal resource allocation channels.

Within the engineering area of concern, the most important thing found was the need for reliable, current data. The trade journals, notably BITE and Electronics, plus the applications notes of the parts manufacturers, were the only reliable source documents available. A single S-100 documentation from the original equipment manufacturers was either incomplete or non-existent; however, the combined data of MITS and CROMENCO, plus INTEL's 8080 timing charts and the
aforementioned journals, were a good substitute. Parts catalogues must be no more than one year old to be useful; therefore, a wise investment was the purchase of several major companies TTL digital components catalogues with cross references for substitutions.

The next most important finding in the engineering area was that the top down design of the hardware-software speeded the development of both. From the programming point of view, hardware became frozen software and the electronic technician's view became "software is temporary hardware." With the views described above, the software acquired hardware overtones, uncommon to higher order languages such as FORTRAN, that generated very fast, efficient code. Similarly, the hardware was basically designed as an algorithm and then was implemented using the appropriate components. By conceiving of the entire device, hardware-software, as a single concept, a top down perspective of design made project planning a trivial exercise outside of the already described institutional problems.

The results of this project indicate an interesting variety of areas for future work. Further military applications include simulation of high voltage power panels, critical circuit troubleshooting, radar maintenance display generation, morse code intercept and transmit training, and oscilloscope wave form demonstrations and training. In the medical area, using a much slowed waveform generator with a voice coil loudspeaker would enable coronary nursing personnel to train with simulated abnormal wave forms. At this lower speed level simulations of EKGs, EEGs and other medical monitor scopes could be made of any known pattern. Used exactly as constructed, the hardware could monitor and control a very sophisticated security system, or run heating
systems or even a traffic light system. The control set could run a MOOG synthesizer. Some modification of the D/A converter would make the PWG a function generator of major value as a test instrument. Used in conjunction with communication equipment, the hardware could test and monitor a variety of circuit parameters with all manner of traffic and report abnormal system behavior.

Maintenance training, traditionally taught using actual equipment, is now being taught using a microcomputer driven simulator. The system hardware-software for this project can be used in a variety of training and nontraining environments where cheap and rugged process control is desired. Cost and training effectiveness make the maintenance simulator a valuable tool for technical schools everywhere.
BIBLIOGRAPHY


Datapro Research Corporation, All About Microcomputer Specifications, 1805 Underwood Blvd., Delran, N.J. 08075, June 1977

Kargo, Donald W. and Steffen, Dale A. Performance Training Corral for Electronics Principles Course, AFHRL-TR 76-62(i), Air Force Human Relations Laboratory, Sept 76.


United States Air Force, Management of the USAF Automatic Data Processing Program, AFR 300-2, 19 Aug 77, Change 1 (No date available)


United States Air Force, Keesler Technical Training Center, Operation of Training Services Activities and UPT Visual Services and Functions, ATCR 52-33, 1 Apr 77, Change 29, Jul 77, KTT Sup, 27 Sept 76

United States Air Force, Keesler Technical Training Center, Training Services, ATCR 50-22, 15 Apr 77, Change 1, 29 Jul 77, KTTC Sup, 29 Sept 77
APPENDIX A

TRAINING DOCUMENT FORMATS
1. **Purpose.** This course training standard as prescribed in ATCR 52-17:

   a. Established the tasks, knowledge and proficiency level of training to be provided by Course F3A2R30352 003, AN/TPS-43F, O/I Maintenance.

   b. Provides the basis for the development of more detailed training materials and objectives, and training evaluation instruments for the course.

2. **Course Description.** The course covered by this standard is designed to provide training for Air Force personnel who possess AFSC 30352/72 and the skills and knowledge necessary to perform organizational and intermediate maintenance on the AN/TPS-43F radar. Scope of training includes circuit analysis, theory of operation, performance tests, adjustment operation, troubleshooting, and repair and the use of pertinent test equipment.

**NOTICE:** Trainees entering this course at a level below that specified by APR 50-9, and/or other established prerequisites cannot be expected to achieve levels indicated.

3. **Qualitative requirements.** Attachment 1 contains the list of tasks, knowledge, and proficiency reference in paragraph 1.

4. **Recommendations.** Comments and recommendations are invited concerning quality of ATC training and graduates (APP 50-38). Use this CTS as a reference and address correspondence to ATC/TF, Randolph Air Force Base, Texas 78148.
## QUALITATIVE REQUIREMENTS

### PROFICIENCY CODE KEY

<table>
<thead>
<tr>
<th>SCALE VALUE</th>
<th>DEFINITION</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Can do simple parts of the task. Needs to be told or shown how to do most of the task. (EXTREMELY LIMITED)</td>
</tr>
<tr>
<td>2</td>
<td>Can do most parts of the task. Needs help only on hardest parts. May not meet local demands for speed or accuracy. (PARTIALLY PROFICIENT)</td>
</tr>
<tr>
<td>3</td>
<td>Can do all parts of the task. Needs only a spot check of completed work. Meets minimum local demands for speed and accuracy. (COMPETENT)</td>
</tr>
<tr>
<td>4</td>
<td>Can do the complete task quickly and accurately. Can tell or show others how to do the task. (HIGHLY PROFICIENT)</td>
</tr>
</tbody>
</table>

### TASK PERFORMANCE LEVELS

- **a**: Can name parts, tools, and simple facts about the task. (NOMENCLATURE)
- **b**: Can determine step by step procedures for doing the task. (PROCEDURES)
- **c**: Can explain why and when the task must be done and why each step is needed. (OPERATING PRINCIPLES)
- **d**: Can predict, identify, and resolve problems about the task. (COMPLETE THEORY)

### TASK KNOWLEDGE LEVELS

- **A**: Can identify basic facts and terms about the subject. (FACTS)
- **B**: Can explain relationship of basic facts and state general principles about the subject. (PRINCIPLES)
- **C**: Can analyze facts and principles and draw conclusions about the subject. (ANALYSIS)
- **D**: Can evaluate conditions and make proper decisions about the subject. (EVALUATION)

### SUBJECT KNOWLEDGE LEVELS

- **EXPLANATIONS**
  - A task knowledge scale value may be used alone or with a task performance scale value to define a level of knowledge for a specific task. (Examples: b and lb)
  - A subject knowledge scale value is used alone to define a level of knowledge for a subject not directly related to any specific task, or for a subject common to several tasks.
  - This mark is used alone instead of a scale value to show that no proficiency training is provided in the course, or that no proficiency is required at this skill level.
  - This mark is used alone in course columns to show that training is not given due to limitations in resources.

---

**Attachment 1**

**ATC FORM 60**

**PREVIOUS EDITION IS OBSOLETE REPLACES**

**ATC FORM 33A, JAN 75, WHICH IS OBSOLETE**

**CTS/TENTATIVE STS PROFICIENCY CODE KEY**
Tasks, Knowledge and Proficiency Level

1. GENERAL
   a. Purpose, characteristics and capabilities
      (1) AN/TPS-43E Radar System  C
      (2) Ancillary Equipment  C
      (3) Site Test Equipment  B
   b. Locate and identify all Assemblies, Subassemblies, and major components  3c
   c. AN/TPS-43 E Digital and Analog Techniques  C
   d. Utilize Schematic, and Functional Diagrams to determine circuit operation and component function  3c
   e. Practice proper Safety Procedures  3c
   f. Remove and replace subassemblies, printed circuits and planar array boards  3c

2. ALIGNMENT AND THEORETICAL TROUBLESHOOTING OF THE SYNCHRONIZER AND SYSTEM TIMING  2c

3. ALIGNMENT AND THEORETICAL TROUBLESHOOTING OF THE TRANSMITTER
   a. Frequency Generator  3c
   b. Driver Amplifier  3c
   c. Pulser  3c
   d. Power Amplifier  3c

4. ALIGNMENT AND THEORETICAL TROUBLESHOOTING OF THE RECEIVERS
   a. Analog Receivers  3c
   b. Jamming Analysis Transmission Selection (JATS) Processor  3c
   c. Search Receiver  3c
   d. Search Processor and Integrator  3c

Attachment 1
<table>
<thead>
<tr>
<th>Tasks, Knowledge and Proficiency Level</th>
</tr>
</thead>
</table>

- Search built-in-test-equipment (RITE) 2b
- MTI Receiver 3c
- MTI Processor and Integrator 2b
- MTI Processor RITE 2b

5. ALIGNMENT, AND THEORETICAL TROUBLESHOOTING OF THE HEIGHT COMPUTERS AND EVALUATOR
   - Height Processor 3c
   - Height Computers 3c
   - Height Evaluator 3c
   - Height Computers and Evaluator RITE 2b

6. ALIGNMENT, AND THEORETICAL TROUBLESHOOTING OF THE SIGNAL DISTRIBUTION UNIT (SDU)
   - Video Gating 3c
   - Range Azimuth Gating 3c
   - Digital Height Readout (DHRO) 3c
   - SDU RITE 2b

7. ALIGNMENT, AND THEORETICAL TROUBLESHOOTING OF THE AN/UPA-62C
   - Range and Timing 3c
   - Azimuth Circuits 3c
   - Reflection Circuits 3c
   - Video Circuits 3c

8. ALIGNMENT, AND THEORETICAL TROUBLESHOOTING OF THE IFF/SIF SYSTEM
   - AN/TPS-43F IFF/SIF Distribution Cabinet 3c

Attachment 1
b. AN/CPX-13a Interference Blanker 3c

c. OK-217/UPX HF Switching Group 3c

d. AN/UPX-23 IFP/SIP Interrogator/Responder 3c

e. AN/UPA-59A Coder/Decoder 3c

9. ANTENNA SYSTEM
   a. Locate and Identify all assemblies and subassemblies 3c
   b. Fruition and Mechanical Antenna Orientation 3c

10. MEASURE AND ADJUST AC AND DC POWER SUPPLIES 3c

11. UTILIZE SCHEMATICS AND FUNCTIONAL DIAGRAMS FOR SIGNAL FLOW AND SYSTEM INTERCABLING 3c

12. PARTICIPATE IN USAF GRADUATE EVALUATION PROGRAM a

Attachment 1
### COURSE CHART

<table>
<thead>
<tr>
<th>NUMBER</th>
<th>PDG CODE</th>
<th>DATE</th>
</tr>
</thead>
<tbody>
<tr>
<td>E3AZR30352 003</td>
<td>NZP</td>
<td>24 October 1978</td>
</tr>
</tbody>
</table>

**COURSE TITLE**
AN/TPS-43E U/I Maintenance

**SUPERSEDES COURSE CHART**
E2ASR30352 006, 19 June 1978

**APPLICABLE TRAINING STANDARDS**
CTS 52-E3AZR30352 003, 23 October 1978

**OPR AND APPROVAL DATE**
KRTC/TGXE, 24 October 1978

**LOCATION OF TRAINING**
Keesler AFB

<table>
<thead>
<tr>
<th>COURSE LENGTH</th>
<th>ACADEMIC DAYS</th>
<th>WARTIME COURSE LENGTH</th>
<th>ACADEMIC DAYS</th>
<th>HOURS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Technical Training</td>
<td>79</td>
<td></td>
<td></td>
<td>624</td>
</tr>
<tr>
<td>Military Training</td>
<td>8</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Commander’s Calls/Briefings (AFRs 30-1 and 190-18)</td>
<td>3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Local Conditions Course, Course II (AFR 50-24)</td>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>End-of-Course Appointments; Predeparture Safety Briefing (ATCR 127-1)</td>
<td>3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>TOTAL</strong></td>
<td><strong>632</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**REMARKS**
Effective Date: 9 Nov 1978 with class 781109.

*Course Chart E2ASR30352 006, 19 June 78, applies to all classes prior to 781109.

---

### TABLE 1 - MAJOR ITEMS OF EQUIPMENT

**Training Equipment:**
- AN/TPS-43E Radar Set
- AN/UPA-62C Indicator
- AN/UPA-59A Decoder
- AN/GPS-11A Interference Blanker
- AN/UPX-23 Interrogator
- RF Switching Group and Monitor
- OK-217

**Test Equipment:**
- AN/UM-37, Test Set
- TK-405, Oscilloscope
- DM-43-DD40, Digital Multimeter and Display Unit
### BLOCK I - System Introduction and Synchronizer

- Orientation (1 hr)
- Training Evaluation Feedback System (0.5 hrs)
- System Description and Block Diagram (6.5 hrs)
- Digital Techniques and Logic Symbology (34 hrs)
- System Synchronizer and Timing Circuits (27 hrs)
- System Maintenance and Performance Procedures (14 hrs)
- Measurement and Critique (3 hrs)
- Military Training (2 hrs)

*(Equipment Hazards and Personnel Safety Integrated with Above Subjects)*

### BLOCK II - Transmitter

- Transmitter System Block Diagram (4 hrs)
- Frequency Generator (5 hrs)
- High Voltage Driver (6 hrs)
- Pulser (10 hrs)
- Power Amplifier (6 hrs)
- Power Distribution (5 hrs)
- Heat Exchanger and Waveguide pressurizer/Dehumidifier (2 hrs)
- Transmitter Performance Testing (14 hrs)
- Measurement and Critique (3 hrs)
- Military Training (1 hr)

*(Equipment Hazards and Personnel Safety Integrated with Above Subjects)*

### BLOCK III - RF/IF Receivers and Jats

- Receiver System Block Diagram (6 hrs)
- Receiver Timing and Gating (9 hrs)
- Analog Receivers, (23 hrs)
- Receiver Checks and Alignments (16 hrs)
- JATS Processor Theory (24 hrs)
- JATS Performance Tests and Alignments (7 hrs)
- Measurement and Critique (3 hrs)

*(Equipment Hazards and Personnel Safety Integrated with Above Subjects)*

### BLOCK IV - Digital Search and MTI

- Digital Search (18 hrs)
- Search BITE (12 hrs)
- Digital MTI Processor and Integrator (29 hrs)
- MTI BITE (19 hrs)
- MTI and Search Performance Testing (14 hrs)
- Measurement and Critique (3 hrs)
- Military Training (1 hr)

*(Equipment Hazards and Personnel Safety Integrated with Above Subjects)*
### TABLE II - TRAINING CONTENT

<table>
<thead>
<tr>
<th>Course Material</th>
<th>96 Hours</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>BLOCK V</strong> - Height Processing System</td>
<td></td>
</tr>
<tr>
<td>Height Processing System Block Diagram (16 hrs); Height Computers Theory (24 hrs); Height Evaluator Theory (24 hrs); Height System Simulation (18 hrs); Height System Performance Testing (11 hrs); Measurement and Critique (3 hrs).</td>
<td></td>
</tr>
<tr>
<td><strong>Equipment Hazards and Personnel Safety Integrated with Above Subjects</strong></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Course Material</th>
<th>80 Hours</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>BLOCK VI</strong> - SDU and AN/UPA-62C</td>
<td></td>
</tr>
<tr>
<td>SDU Theory (24 hrs); SDU Performance Checks (6 hrs); AN/UPA-62C Functional Block Diagram (4 hrs); Indicator Range and Timing (12 hrs); Azimuth Circuits (13 hrs); Deflection Circuits (6 hrs); Video Circuits (2 hrs); D.C. Power Distribution (3 hrs); Indicator Performance Testing and Alignments (6 hrs); Measurement and Critique (3 hrs); Military Training (1 hr).</td>
<td></td>
</tr>
<tr>
<td><strong>Equipment Hazards and Personnel Safety Integrated with Above Subjects</strong></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Course Material</th>
<th>56 Hours</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>BLOCK VII</strong> - AN/UPX-23</td>
<td></td>
</tr>
<tr>
<td>AN/UPX-23 Block Diagram (4 hrs); Trigger and Timing Circuits (16 hrs); Transmitter (6 hrs); Receiver Circuits (8 hrs); Video Circuits (8 hrs); Performance Testing and Alignments (11 hrs); Measurement and Critique (3 hrs).</td>
<td></td>
</tr>
<tr>
<td><strong>Equipment Hazards and Personnel Safety Integrated with Above Subjects</strong></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Course Material</th>
<th>72 Hours</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>BLOCK VIII</strong> - IFF/SIF System</td>
<td></td>
</tr>
<tr>
<td>IFF/SIF Functional Block Diagram (3 hrs)(U); OK-217/UPX RF Switching Unit (6 hrs)(U); AN/GPS-13A Interference Blanker (7 hrs)(U); AN/UPA-59A Decoder Group (12 hrs)(U); IFF/SIF System Performance Testing and Alignments (9 hrs)(U); Measurement and Critique (3 hrs)(U); MODE 4 XIR (18 hrs)(C); Course Critique and Graduation (1 hr)(U); Military Training (3 hrs)(U).</td>
<td></td>
</tr>
<tr>
<td><strong>Equipment Hazards and Personnel Safety Integrated with Above Subjects</strong></td>
<td></td>
</tr>
</tbody>
</table>

(Above Titles are Unclassified)
APPENDIX B

LETTER OF TECHNICAL RECOMMENDATIONS

TO STAFF STUDY
Recommendation to Use a Micro-Processor to Drive A TPS-43 Training Simulator

1. This letter explores the basis for recommending use of a micro-processor to simulate the output of a TPS-43 radar maintenance panel, Built in Test Equipment (BITE). This letter shows that a micro-processor simulation of the BITE is inherently the equal of the original BITE by: describing the BITE to be simulated; the BITE inputs/outputs (I/O) to be generated; types of micro-processor equipment needed to simulate BITE and I/O; the developmental support required; and, a list of parameters to be used when considering acquisition.

2. Micro-processor simulation of the BITE is inherently the equal of the original BITE (for training purposes) because the TPS-43 radar currently has a micro-computer as its BITE system. The BITE is scattered throughout the radar to sample selected essential signals which illustrate the state of repair of the system. The BITE is controlled by a panel containing several sets of multi-switch selecting knobs that direct sample signals from the radar, through a series of converters and counters, to an oscilloscope for signal display. This panel contains arrays of lights which also display certain signals from the system. The BITE presents about 20 standard displays for over 100 possible BITE test positions (where the radar is working correctly). The maintenance person uses this information to pin-point the functional subsystem of the radar that is not working right. Repair is accomplished by "Black Box" replacement of the component at fault. The BITE micro-computer system described above is built into the TPS-43 Radar.

3. BITE I/O is digital, and lends itself to digital simulation. Inputs are from the system in analog form through an analog to digital converter, which enables simple arithmetic testing operations to be performed on the inputs. The tested signals are now sent to an oscilloscope, through a digital to analog converter for display. The radar signals to be sampled are selected via the BITE control panel. Display lights are indicators of digital data taken after the BITE system has captured its sample for testing.

4. The BITE system can be simulated by a variety of micro-computers now on the market, or soon to be announced onto the market, used in a dedicated manner. Any such micro-computer system would keep arrays of signals in memory to sample instead of using a real radar for source data. Such a system would output these signals under control of a training program, in accordance to the commands input from switch settings on a simulated BITE control panel. The BITE control panel
simulation would be sampled frequently by the system, under program control, and would also show light displays appropriate to the data area being sampled. Equipment analysis taken from available journals and other commercial literature indicate that many micro-computer systems can operate at speeds high enough to produce an identical output to the actual radar system when BITE is engaged. One output line (PORT) of the micro-computer system would go directly into a digital to analog converter and then to an oscilloscope. Use of the oscilloscope is part of the training environment, thus it has not been simulated. On other systems to be simulated video presentation can be substituted directly for the D/A converter-oscilloscope combination to include captions and/or other word displays. Power meters, frequency indicators, etc., not functionally within the BITE system can be simulated by using digital displays also driven by the micro-computer.

5. Any micro-computer system chosen will be able to operate with less equipment than will be needed to develop it. Development support will include features needed to write and check computer programs (software). Equipment (hardware) for mass storage in the form of: magnetic tape or disc, beyond the needs of the final system; Erasable Programmable Read Only Memory (EPROM), and its associated equipment; larger power supplies and special controller units to use this hardware. These one time purchases will carry over as benefits into development of other simulators configure around this micro-processor. Precisely because the on-going use of equipment and other software materials used in future developmental support, careful attention must be paid to continued availability and support of both equipment and software.

6. The list below represents parameters considered essential to a prudent selection of equipment:

a. Hardware Requirements

(1) Modular Interchangeability (Compatibility with various plug-in units)
(2) Industrial/Military Standard
(3) Stable Logistic Support
(4) Documentation (Schematics and Operating Characteristics)
(5) Maintenance Support
(6) D/A Converter Capability (with acceptable benchmark criteria)
(7) Sufficient Power Capability
(8) I/O (Input/Output) capability is described based on eight
bit word system or else comparable equipment for 16 bit systems

   (a) Parallel Ports (2 ea) for D/A Converter Unit (8-bit
       words)
   
   (b) Serial Ports (3 ea) for Paper Tape, Keyboard, Cas-
       sette, etc. (Audio cassette requires a modem interface)
   
   (c) Parallel Port (1 ea) for Control of Training Console
       Panel Functions (meters, lights, and input requests)
   
(9) Mass Storage

   (a) Off-line (Paper Tape, Disc, or Magnetic Tape)

(10) Peripherals (Disc, TV Monitor, Cassette, Keyboard)

b. Software Support

   (1) Assembler and/or Higher-Level Language (AF accepted or
       Industrial Standard)
   
   (2) Library or User's Group Sources
   
   (3) Operating System/Editor Capability
   
   (4) Resident Software Programmer

   c. Costs of Equipment

   (1) Micro-processor Hardware (Off-Shelf): $1000 - $2000
   
   (2) Software (Off-Shelf): $1000 maximum
   
   (3) Firmware (Programming PROMs, etc.): $1000 - $2000
   
   (4) Trainer Specific Hardware (O-Scope, Mockup, etc)
   
   (5) Peripherals

      (a) Disc $1000 - $2000

      (b) TV Monitor: $500 (with Interface Board)

      (c) Keyboard - $100

      (d) Audio Cassette: $300 (with tape unit)
This list is constructed to provide flexibility in terms of choice, support and price while insuring against no-standard equipment and/or software. The system maintenance and development should be within the abilities of a programmer with assembly programming experience and also some electronics experience.

7. Prospects of using a micro-computer to simulate the output of a TPS-43 Radar BITE system are clearly excellent, as described above. The criteria described in paragraph 6 represent realistic goals that are available in today's market.

MICHAEL F. WINTHROP, 1ST LT, USAF
Computer Technology Branch
339OTCHGP
APPENDIX C

LETTER OF INQUIRY
1. This letter is a request for information about your product line of micro-computers. My organization is conducting a feasibility study concerning the use of a micro-computer as an interactive and interrupt driven training device. The information that I need concerns your 'off-the-shelf' products, specifically; data about capabilities, compatibilities and costs.

2. The requirements of my use are:

   a. Hardware Requirements

      (1) Modular Interchangeability (compatibility with various plug-in units)

      (2) Industrial Standard

      (3) Stable Logistic Support

      (4) Documentation (Schematics and Operating Characteristics)

      (5) Maintenance Support

      (6) D/A Converter capability with acceptable benchmark criteria of 2 MHz (parallel input, serial output)

      (7) Sufficient Power Capability

      (8) I/O (Input/Output) Capability (Minimum examples below are 8 bit oriented)

         (a) Parallel Ports (2 ea) for D/A Converter Unit (8-bit words)

         (b) Serial Ports (3 ea) for paper tape, keyboard, cassette, etc. (audio cassette requires a modem interface)

         (c) Parallel Port (1 ea) for Control of Training Console Panel Functions (meters, lights, and input requests)
(9) Mass Storage
   (a) Non-Volatile Memory (resident, i.e. EPROM chips)
   (b) Off-line (Paper Tape, Disc, or magnetic Tape)

(10) Peripherals (Disc, TV Monitor, Cassette, Keyboard)

b. Software Support
   (1) Assembler and/or Higher-level Language
       (AF accepted or Industrial Standard)
   (2) Library or User's-Group Source
   (3) Operating System/Editor Capacity

3. This information is being requested without obligation to the United States Government.

4. Please reply to:  HQ, USAF 3300 Technical Training Wing
                     Training Equipment Branch/TTVET
                     Keesler Air Force Base, MS 39534

JAMES R. BRIDGES, Jr., Major, USAF
Chief, Training Services Division
HQ, 3300 Technical Training Wing
APPENDIX D

DECISION MATRIX

COMPANIES QUERIED

AND RESPONDENTS (*)
<table>
<thead>
<tr>
<th>DESCRIPTION OF COMPOSITE WALLS (IN FEET)</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
<th>15</th>
<th>16</th>
<th>17</th>
<th>18</th>
<th>19</th>
<th>20</th>
<th>21</th>
<th>22</th>
<th>23</th>
</tr>
</thead>
<tbody>
<tr>
<td>A. Composite Wall</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>B. Reinforced Concrete Block</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>C. Precast Concrete Units</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>D. Panel</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>E. Prefabricated Wall Panel</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>F. Sandwich Panel</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>G. Corrugated Steel Sheet</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>H. Stud Frame Car</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>I. Other Structural Elements</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
</tbody>
</table>

**Legend:**
- A: All Rights
- B: By Bank
- C: By City
- D: By Date
- E: By Day
- F: By Year

This plan is best quality practicable.

From:...Published to...
<table>
<thead>
<tr>
<th>Product</th>
<th>Type</th>
<th>Model</th>
<th>Notes</th>
<th>Quantity</th>
<th>Parts</th>
<th>Total</th>
</tr>
</thead>
<tbody>
<tr>
<td>Product A</td>
<td>Type 1</td>
<td>#1234</td>
<td>New</td>
<td>50</td>
<td>200</td>
<td>250</td>
</tr>
<tr>
<td>Product B</td>
<td>Type 2</td>
<td>#5678</td>
<td>Used</td>
<td>100</td>
<td>100</td>
<td>200</td>
</tr>
<tr>
<td>Product C</td>
<td>Type 3</td>
<td>#9012</td>
<td>Custom</td>
<td>50</td>
<td>50</td>
<td>100</td>
</tr>
</tbody>
</table>

**Legend**:
- All parts are subject to availability.
- New parts are in stock.
- Used parts are refurbished.
- Custom parts require additional approval.
## MICROCOMPUTER MANUFACTURERS

<table>
<thead>
<tr>
<th>Name, Address and Telephone number</th>
<th>Mfr</th>
<th>Fed Code</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Advanced Memory Systems</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1215 Hammerwood Rd</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sunnyvale, CA 94083</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (408) 734-4330</td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Advanced Micro Devices</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>901 Thompson Pl</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sunnyvale, CA 94086</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (408) 732-2400</td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>American Microsystems, Inc.</strong></td>
<td>31471</td>
<td></td>
</tr>
<tr>
<td>3800 Homestead Rd</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Santa Clara, CA 95051</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (408) 246-0330</td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Applied Computing Technology</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>17961 Sky Park Circle</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Irvine, CA 92707</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (714) 557-9972</td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Applied Data Communications</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1509 E. McFadden Ave</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Santa Clara, CA 91705</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (714) 547-6954</td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Applied Systems Corporation</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>26401 Harper Ave</td>
<td></td>
<td></td>
</tr>
<tr>
<td>St Clair Shores, MI 48081</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (313) 779-8700</td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Automated Computer Systems</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2361 E. Foothill Blvd</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Pasadena, CA 91107</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (213) 449-0616</td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Computer Automation, Inc.</strong></td>
<td>53908</td>
<td></td>
</tr>
<tr>
<td>18651 Von Karman Ave</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Irvine, CA 92664</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (714) 833-8830</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Name, Address and Telephone number  Mfr Fed Code

Control Logic, Inc.*  14931
9 Tech Circle  
Natick, MA 01760  
Tel (617) 655-1170

Cramer Electronics, Inc.*  
85 Wells Avenue  
Newton, MA 02159  
Tel (617) 969-7700

CROMECO Incorporated*  
1432 Charleston Rd  
Mountainview, CA 94143  
Tel (415) 964-7400

Data General Corporation  34984
Route 9  
Southboro, MA 01772  
Tel (617) 485-9100

Data Numerics, Inc  
141-A Central Avenue  
Farmingdale, NY 11735  
Tel (516) 293-6600

Data Translation, Inc  
23 Strathmore Rd  
Natick, MA 01760  
Tel

Digital Electronics Corporation  
415 Peterson Street  
Oakland, CA 94601  
Tel (415) 532-2920

Digital Equipment Corporation*  15476
146 Main St  
Maynard, MA 01754  
Tel (617) 897-5111

Digital Laboratories  
377 Ptnam Avenue  
Cambridge, MA 02139  
Tel (617) 876-6220

Diversified Technology*  
P.O. Box 465  
Ridgeland, MS 39157  
Tel (601) 856-4121
<table>
<thead>
<tr>
<th>Name, Address and Telephone number</th>
<th>Mfr</th>
<th>Fed Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>EBKA Industries Inc</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6920 Melrose Lane, Oklahoma City, OK 73127</td>
<td>EBKA</td>
<td></td>
</tr>
<tr>
<td>Tel (405) 787-3671</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Educational Data Systems</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17891 Sky Park Circle, Irvine, CA 92707</td>
<td>EDS</td>
<td></td>
</tr>
<tr>
<td>Tel (714) 556-4242</td>
<td></td>
<td></td>
</tr>
<tr>
<td>E &amp; L Instruments, Inc*</td>
<td></td>
<td></td>
</tr>
<tr>
<td>61 First Street, Derby, CT 06418</td>
<td>E&amp;L</td>
<td></td>
</tr>
<tr>
<td>Tel (203) 735-8774</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Electronic Memories &amp; Magnetics Corp*</td>
<td>EM</td>
<td>16224</td>
</tr>
<tr>
<td>12621 Chadron Ave, Hawthorne, CA 90250</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (213) 556-2323</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Electronic Product Associates*</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1157 Vega Street, San Diego, CA 92110</td>
<td>EPA</td>
<td></td>
</tr>
<tr>
<td>Tel (714) 276-8911</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Essex International</td>
<td></td>
<td></td>
</tr>
<tr>
<td>564 Alpha Dr, Pittsbug, PA 15238</td>
<td>EIS</td>
<td></td>
</tr>
<tr>
<td>Tel (412) 963-9322</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Fabri-Tek, Inc*</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5901 South Country Road 18, Minneapols, MN 55436</td>
<td>FT</td>
<td>21542</td>
</tr>
<tr>
<td>Tel (612) 935-8811</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Fairchild Semiconductor Components</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1725 Technology Drive, San Jose, CA 95110</td>
<td>FSC</td>
<td></td>
</tr>
<tr>
<td>Tel (408) 998-0:23</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Fairchild Semiconductor</td>
<td></td>
<td></td>
</tr>
<tr>
<td>464 Ellis St, Mountain View, CA 94042</td>
<td>FSC</td>
<td></td>
</tr>
<tr>
<td>Tel (415) 962-3816</td>
<td></td>
<td></td>
</tr>
<tr>
<td>General Automation, Inc*</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1055 South East Street, Anaheim, CA 92805</td>
<td>GA</td>
<td>32453</td>
</tr>
<tr>
<td>Tel (714) 788-4800</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Name, Address and Telephone number

General Instrument
600 W. John St
Hicksville, NY 11802
Tel (516) 733-3130

GTE Information Systems, Inc
5300 E. LaPalma
Anaheim, CA 92807
Tel (714) 524-3131

Harris Semiconductor
P.O. Box 883
Melbourne, FL 32901
Tel (305) 727-5400

Heurikon Corporation
700 W Badger Road
Madison, WI 53713
Tel (608) 155-9075

Hughes Aircraft Company*
Aerospace Group
Culver city, CA 90230
Tel (213) 391-0711

Hughes Solid State Div
2601 Campus Dr
Irvine, CA 92715
Tel (714) 752-6396

IMS Associates*
14800 Wicks Blvd
San Leandro, CA 94577
Tel (415) 483-2093

Intel Corporation*
3065 Bowers Ave
Santa Clara, CA 95051
Tel (408) 246-7501

International Microsystems, Inc*
122 Hutton St
Gaithersburg, MD 10760
Tel (301) 840-1078

Intersil, Inc*
10900 N. Tantau Avenue
Cupertino, CA 95014
Tel (408) 257-5450
Name, Address and Telephone number

ITT Semiconductor
74 Commerce Way
Woburn, MA 01801
Tel (617) 935-7910

Martin Research, Ltd*
3336 Commercial Ave
Northbrook, IL 60062
Tel (312) 498-5060

Microcomputer Associates, Inc*
2589 Scott Blvd
Santa Clara, CA 95050
Tel (408) 247-8940

Microdata Corporation*
14701 Red Hill Ave
Irvine, CA 92705
Tel (714) 540-6730

Microkit, Inc*
2180 Colorado Ave
Santa Monica, CA 90404
Tel (213) 828-8592

Millennium Information Systems
420 Mathew St
Santa Clara, CA 95050
Tel (408) 243-6652

MITS*
2450 Alamo SE
Albuquerque, New Mexico 87106
Tel (505) 265-7553

Monolithic Memories, Inc*
1165 E. Arques Ave
Sunnyvale, CA
Tel (408) 739-3535

Monolithic Systems Corp
14 Iverness Drive East (Bldg 4-J)
Englewood, CO 80110
Tel (303) 770-7400

MOS Technology, Inc*
950 Rittenhouse Rd
Norristown, PA 19401
Tel (215) 666-7950
<table>
<thead>
<tr>
<th>Name, Address and Telephone number</th>
<th>Mfr</th>
<th>Fed Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>Mostek Corporation*</td>
<td>50088</td>
<td></td>
</tr>
<tr>
<td>1400 Upfield Drive</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Carrollton, TX 75006</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (214) 242-0444</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Motorola Semiconductor Products, Inc*</td>
<td>04713</td>
<td></td>
</tr>
<tr>
<td>P.O. Box 10912</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Phoenix, AZ 85036</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (602) 244-6900</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Multisonics, Inc</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3300 Crow Canyon Road</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Box 350, San Ramon, CA 94583</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (415) 837-8111</td>
<td></td>
<td></td>
</tr>
<tr>
<td>MycroTek, Inc</td>
<td></td>
<td></td>
</tr>
<tr>
<td>216 North Washington</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Wichita, KA 67201</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (316) 265-5277</td>
<td></td>
<td></td>
</tr>
<tr>
<td>National Semiconductor Corporation*</td>
<td>27014</td>
<td></td>
</tr>
<tr>
<td>2900 Semiconductor Drive</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Santa Clara, CA 95051</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (408) 732-5000</td>
<td></td>
<td></td>
</tr>
<tr>
<td>NEC Microcomputers, Inc*</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5 Militia Drive</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Lexington, MA 02173</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (617) 862-6410</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Panafacom Ltd</td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.O. Box 4637</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Mountain View, CA 94040</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (415) 854-7050</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Panasonic</td>
<td></td>
<td></td>
</tr>
<tr>
<td>50 Meadowland Parkway</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Secaucus, NJ 07094</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (201) 348-7276</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PCM, Inc*</td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.O. Box 215</td>
<td></td>
<td></td>
</tr>
<tr>
<td>San Ramon, CA 94583</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (415) 837-5400</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Plessey Microsystems</td>
<td>55154</td>
<td></td>
</tr>
<tr>
<td>1674 McCaw Ave</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Irvine, CA 92714</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tel (714) 540-9945</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Name, Address and Telephone number</td>
<td>Mfr</td>
<td>Fed Code</td>
</tr>
<tr>
<td>-----------------------------------</td>
<td>-----</td>
<td>----------</td>
</tr>
<tr>
<td>Process Computer Systems*&lt;br&gt;5467 Hill 23 Drive&lt;br&gt;Flint, MI 48502&lt;br&gt;Tel (313) 767-8920</td>
<td></td>
<td>55530</td>
</tr>
<tr>
<td>Processor Applications Ltd&lt;br&gt;2801 E. Valley View Ave&lt;br&gt;West Covina, CA 91792&lt;br&gt;Tel (213) 965-8865</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Processor Technology Corp*&lt;br&gt;6200 Hollis Street&lt;br&gt;Emeryville, CA 94608&lt;br&gt;Tel (415) 652-8080</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Pro-Log Corporation*&lt;br&gt;2411 Garden Rd&lt;br&gt;Monterey, CA 93940&lt;br&gt;Tel (408) 372-4593</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Radio Shack*&lt;br&gt;Dept TRS-80&lt;br&gt;205 N.W. 7th St&lt;br&gt;Fort Worth, TX 76101&lt;br&gt;Tel (817) 390-3595</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Raytheon Semiconductor&lt;br&gt;350 Ellis Street&lt;br&gt;Mountain View, CA 94040&lt;br&gt;Tel (415) 968-9211</td>
<td>07933</td>
<td></td>
</tr>
<tr>
<td>RCA Solid State Division&lt;br&gt;Route 202&lt;br&gt;Sommerville, NU 08875&lt;br&gt;Tel (201) 685-6000</td>
<td>18723</td>
<td>26720</td>
</tr>
<tr>
<td>Rockwell International&lt;br&gt;P.O. Box 3669&lt;br&gt;RCOI Dept 720&lt;br&gt;Anaheim, CA 92803&lt;br&gt;Tel (714) 632-2321</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Scientific Micro Systems&lt;br&gt;520 Clyde Avenue&lt;br&gt;Mountain View, CA 94043&lt;br&gt;Tel (415) 964-5700</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Signetics Corporation*&lt;br&gt;811 East Arques Avenue&lt;br&gt;Sunnyvale, CA 94086&lt;br&gt;Tel (408) 739-7700</td>
<td></td>
<td>18324</td>
</tr>
</tbody>
</table>
Name, Address and                      Mfr
Telephone number                      Fed Code

Solid State Scientific
Montgomeryville Industrial Park
Montgomeryville, PA 18936
Tel (215) 855-8400

Southwest Technical Products Corp*
219 West Rhapsody
San Antonio, TX 78284
Tel (512) 344-0241

Sphere Corporation
791 S. 500 West
Bountiful, UT 84010
Tel (801) 292-8466

Syneitek
3030 Coronado Dr
Santa Clara, CA 95051
Tel (408) 241-4800

System Integration Associates
RD 1, Box 126
Glenmore, PA 19343
Tel (215) 286-5136

TEI Incorporated
7231 Fondren Rd
Houston, TX 77036
Tel (713) 774-9526

Teledyne Systems Company
19601 Nordhoff Street
Northridge, CA 91324
Tel (213) 886-2211

Tektronix, Inc*
P.O. Box 500
Beaverton, OR 97077
Tel

Texas Instruments Inc*
Components Group, PO Box 1443
Houston, TX 77001
Tel (713) 494-5115

Three Phoenix Company
10632 North 21st Avenue
Phoenix, AZ 85029
Tel (602) 944-2221
<table>
<thead>
<tr>
<th>Name, Address and Mfr</th>
<th>Telephone number</th>
<th>Fed Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>Transitron Electronic Corporation</td>
<td>24046</td>
<td></td>
</tr>
<tr>
<td>Microcomputer Division</td>
<td>168 Albion Street</td>
<td>Tel (617) 245-4500</td>
</tr>
<tr>
<td>Wakefield, MA 01880</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Warner &amp; Swasey Company</td>
<td>62800</td>
<td></td>
</tr>
<tr>
<td>30300 Solon Industrial Parkway</td>
<td>Tel (216) 368-6200</td>
<td></td>
</tr>
<tr>
<td>Solon, OH 44139</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Wave Mate*</td>
<td>1015 West 190th Street</td>
<td>Tel (213) 329-8941</td>
</tr>
<tr>
<td>Gardena, CA 90248</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Western Digital Corporation*</td>
<td>52840</td>
<td></td>
</tr>
<tr>
<td>3126 Red Hill Avenue</td>
<td>Tel (714) 557-3550</td>
<td></td>
</tr>
<tr>
<td>Newport Beach, CA 92663</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Wintex Computer Corporation</td>
<td>544 Lunt Avenue</td>
<td>Tel (312) 529-3080</td>
</tr>
<tr>
<td>Schaumburg, IL 60172</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Wyle Computer Products*</td>
<td>3200 Magruder Boulevard</td>
<td>Tel (804) 838-0122</td>
</tr>
<tr>
<td>Hampton, VA 23666</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ZILOG*</td>
<td>10460 Bubb Road</td>
<td>Tel (408) 446-4666</td>
</tr>
<tr>
<td>Cupertino, CA 95014</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Data received and evaluated
APPENDIX E

FIGURE OF MERIT PROGRAM
1 DIM A(50)
5 CLS
10 PRINT "YOU CAN: REPAIR, START A NEW LIST, OR ADD TO AN OLD ONE"
11 INPUT "REPAIR = 2, START NEW = φ, READ AND ADD = 1"; Q
14 IF Q = φ THEN 50
15 IF Q = 2 THEN 100
16 IF Q = 1 THEN GOSUB 1000: GOTO 50
50 FOR U = 1 TO 100
80 INPUT "THE COMPANY NAME?"; A$
90 PRINT #I, A$
100 INPUT "# INST": I
105 INPUT "TYPE BUS (S10=1. OTHER=5)"; B
110 INPUT "KIT (YES=5. NO=10)"; K
115 INPUT "INDUSTRIAL, LOGISTIC, DOCUMENT (10=Y, 5=N, φ=?)"; N, L, D
120 INPUT "POWER (10=ENOUGH, φ=NOT ENOUGH, φ=?)"; P
125 INPUT "# BITS IN A WORD"; W
130 INPUT "# OF PARALLEL PORTS"; C
135 INPUT "# OF SERIAL I/O PORTS"; S
140 INPUT "NON-VOL MEM.? (Y =10, N =3, φ=?)"; M
145 PRINT "SOFTWARE SUPPORT"
150 PRINT "MACHINE ONLY = φ NON-STD HI-LEVEL = φ"
155 PRINT "ASSEMBLER (ABS)=1 COMPILER=5"
160 PRINT "RELOC. ASSEMBLER = 3 CROSS ASSEMBLER = 2"
165 PRINT "HI-LEVEL INTERP=3 CROSS COMPILER = 4"
170 PRINT "EDITOR = 3 OPERATING SYS = 3"
175 INPUT "ENTER # OF SOFTWARE SUPPORTS AVAILABLE"; X
180 FOR Z=1 TO X: INPUT "VALUE OF SOFTWARE": A(Z): NEXT Z
184 INPUT "PERIFERALS - - MONITOR"; A IF A<>0 THEN 190
185 INPUT "PERIFERALS - - KEYBOARD"; A: IF A<>0 THEN 190
186 INPUT "PERIFERALS - - TELEPRINTER"; A
190 INPUT "OFF LINE MEM (ADD VALUES) - PAPER T=1, MAG T=3, DISC =5, NONE =0"; O
200 INPUT "DOES THIS COMPANY HAVE ANY SOFTWARE, OR DOES ANYONE?", T
205 R=0
310 FOR Z=1 TO X: R=R+A(X): NEXT Z
320 GOSUB 7000
330 GOSUB 2000
400 PRINT #1, I; ",", B; ",", K; ",", N; ",", L; ",", D; ",", P; ",", W
410 PRINT #1, C; ",", S; ",", M; ",", R; ",", A; A", ",", O; ",", T
430 RETURN
1000 INPUT "READ HOW MANY FILES BEFORE YOU ENTER DATA?"; F
1001 FOR E=1 TO F
1002 REM
1003 INPUT #1, A$: INPUT #1, I, B, K, N, L, D, P, W
1004 INPUT #1, C, S, M, R, A, O, T
1005 GOSUB 7000
1006 GOSUB 2000
1040 NEXT E
1050 RETURN
2000 GOSUB 5000: REM THIS GETS THE ALGORITHM
2002 G = G + 1: A(G) = Y
2003 PRINT "THE NAME OF THE COMPANY IS"; A$
2006 PRINT "INSTR", "BUS", "IND. USE", "LOGISTICS": PRINT I, B, N, L
PRINT "DOCUMENTS", "POWER O.K.", "BITS/WD", "PARALLEL PTS": PRINT D, P, W, C
PRINT "SERIAL PTS", "NON-VOL MEM", "SOFTWARE #", "PERIFERALS": PRINT S, M, R, A
PRINT "OFF-LINE MEM", "SOFTWARE AT ALL", "DECISION VALUE": PRINT O, T, Y
IF A(0) = 999 THEN RETURN
PRINT: PRINT: PRINT: INPUT "ANOTHER COMPANY??, YES = 1, NO = 2 ALL = 999": A(0)
IF A(0) = 999 THEN RETURN
IF A(0) - 1 THEN RETURN
END
Y=(I*B+K+N+L+P+W+C+S+M)*R*A*O*T
RETURN
REM THIS PUTS IT IN COPY FORMAT
CLS:PRINT A$;"S HARDWARE"
PRINT "COMPATABLE", "IND STD", "SCHEMATICS", "MAINTAINABLE"
IF (I=72) + (I=78) + (I=158) THEN PRINT "YES": GOTO 7050
PRINT "NO"
Z=N; GOSUB 10000
Z=D; GOSUB 10000
Z=L; IF D + L>14 THEN Z = 10
GOSUB 10000
PRINT
PRINT "POWER", "I/O PORTS OK?", "PARALLEL", "SERIAL"
Z=P: GOSUB 10000
Z=2*(S+C): GOSUB 10000
8020 \( Z=C*5 \): GOSUB 10000
8030 \( Z=S*3 \): GOSUB 10000
8035 PRINT
8040 PRINT "STRG OK?", "NON-VOL", "OFF LINE", "PERIPHERALS"
8050 \( Z=10*(M/M)*(A/A) \): GOSUB 1000
8060 \( Z=M \): GOSUB 10000
8069 \( Z=O+1 \)
8070 RESTORE: FOR \( U=1 \) TO \( Z \): READ B$: NEXT U: PRINT B$
8071 DATA "NONE", "P. TAPE", "", "M. TAPE", "P & M TAPE", "DISK", "DISK & P. TAPE"
8072 DATA "", "DISK & M TAPE", "DISK, P & M TAPE"
8080 \( Z=A*10 \): GOSUB 10000
8085 PRINT
8090 PRINT A$; "'S SOFTWARE"
8100 IF \( R*T \) \( \times 17 \) PRINT "INSUFFICIENT SOFTWARE SUPPORT"; GOTO 8145
8110 PRINT "SOFTWARE SUFFICIENT;"
8115 PRINT "ASSEMBLER, EDITOR, INTERPERTER, DISK O/S, STD HI-LEVEL LANG"
8120 PRINT "ALL STANDARD.!!!!!!!"
8140 IF A(0)<999 THEN 8150
8145 FOR \( U=1 \) "PRESS ENTER TO GET NUMERIC VALUE"; B$
8150 INPUT "PRESS ENTER TO GET NUMERIC VALUES"; B$
8160 CLS: RETURN
10000 IF \( Z = 0 \) THEN \( Z = 0 \)
10010 ON \( \times (Z/5)+1 \) GOTO 10100, 10200, 10300
10100 PRINT "NO DATA", :RETURN
10200 PRINT "NO", :RETURN
10300 PRINT "YES", :RETURN
APPENDIX F

APPLICATION PROGRAM BITE
BLOCK DATA KEEPER

LOGICAL*1 LNBIT(8), LBUF(32), IPUT(91)

DIMENSION IODAT(100), IPICT(450), LIST(27)

COMMON/POOL/LASTP, ISW, INIT, LIST, LNBIT, LBUF, IODAT, IPICT,
*IPRG, IG0A, IGB, IG0C, IPUT, I, II, III, IV, IIII, IX, IPRT, LUBIT

DATA LNBIT/"01", "02", "04", "08", "10", "20", "40", "80"/,
* IPRG/"FFF3", IG0A/"FFF0", IGB/"FFF1", IG0C/"FFF2"/,
* IPRT/2/,
A IPICT/4, 2400, 1, 5804, 15827, 25840, 17400,
B 10, 2400, 1, 5209, 5209, 5209,
* 5209, 15855, 25290, 25290, 25290, 25290, 17400,
C 4, 2400, 1, 6609, 15853, 26690, 15800,
D 18, 2400, 1,
* 5209, 5209, 5209, 5209, 5209, 5209, 5209,
* 15855, 25290, 25290, 25290, 25290,
* 25290, 25290, 25290, 15800,
E 26, 246, 1, 11600, 10155, 10100,
* 10155, 10155, 10155, 10100, 10155, 10155, 10155, 10155,
* 10155, 10155, 10155, 10100, 10155, 10155, 11555,
* 10100, 12555, 10100, 13655, 28190, 15200, 13600,
F 25, 246, 1, 12000, 13655, 10100, 12555, 10100, 11555,
* 10155, 10100, 10155, 10155, 10100, 10155, 10100, 10155, 10155,
* 10155, 10100, 10155, 10155, 10155, 10100, 10155, 15200, 13100,
G 7, 256, 1, 13200, 11600, 10355, 12455, 15155, 12900, 15200,
H 7, 256, 1, 11700, 15200, 15155, 12455, 10355, 11800, 14400,
I 2.128. 0.0.
J 8.128. 1. 10122. 10216. 10122. 10128. 10122. 10116.
* 10122. 10128. 10122. 10128. 10122. 10128. 11528. 15228.
L 11.22. 1. 10128. 10219. 10209. 10207. 1019. 10155. 10107.
* 10211. 10519. 10111. 11419.
M 2.4. 1. 10241. 10275.
N 3.52. 1. 11500. 10155. 11600.
O 2.80. 1. 12000. 13000.
P 84.1438. 1.
* 10165. 14600. 0409. 11055. 15155. 15200.
* 10165. 14600. 0450. 10755. 15155. 15200.
* 10163. 14600. 0510. 15155. 15200.
* 10165. 14600. 0450. 01479. 14055. 15200.
* 10165. 14600. 0450. 02469. 12055. 15200.
* 10165. 14600. 0450. 03759. 11755. 15200.
* 10165. 14600. 05207. 15200.
* 10165. 14600. 05204. 15200.
* 10165. 14600. 0400. 1104. 15145. 15200.
* 10165. 14600. 10600. 05404. 11015. 15122. 15200.
* 10165. 14600. 11100. 02902. 11022. 15122. 15200.
* 10165. 14600. 11900. 02102. 11013. 15112. 15200.
* 10165. 14600. 12600. 01401. 11007. 15107. 15200.
* 10165. 14600. 13200. 10800. 11007. 15107. 15200.
84.3458.1,
* 10163. 15200. 15155. 11055. 24090. 14600.
* 10163. 15200. 15155. 10755. 24290. 14600.
* 10163. 15200. 15155. 25190. 14600.
* 10163. 15200. 14055. 21492. 24620. 14600.
* 10163. 15200. 13055. 22496. 24660. 14600.
* 10163. 15200. 11755. 23795. 24650. 14600.
* 10163. 15200. 25270. 14600.
* 10163. 15200. 25240. 14600.
* 10163. 15200. 15144. 11042. 24070. 14600.
* 10163. 15200. 15127. 11073. 22340. 10600. 14600.
* 10163. 15200. 15127. 11022. 22350. 11100. 14600.
* 10163. 15200. 15117. 11017. 22120. 11900. 14600.
* 10163. 15200. 15107. 11007. 21410. 12600. 14600.
* 10163. 15200. 15107. 10900. 10800. 12200. 14600.
R 6.246 1.11600. 6..009. 15055. 15155. 15200. 12000.
S 6.246 1.11600. 15155. 15055. 25090. 15200. 12000.
T 2.16 1.10855. 10855.
U 2.16 1.10800. 10855.
V 2.8 1.10400. 10455.
W 2.8 1.10428. 10428.
X 2.4 1.10228. 10229.
Y 2.4 1.10229. 10228.
Z 18.262 1.15000. 00109. 20190. 00109. 25090. 00109. 20190.
+ 00109. 20190. 15000. 00109. 26120. 00109. 15052. 20190.
DATA IODAT/255, 0, 0, 0, 0, 1, 17128, 1, 61/
END

SUBROUTINE ERROR(MESUP, ICLST)
LOGICAL KBIT
LOGICAL*1 ICLST(14)
DIMENSION MESUP(101)
LOGICAL*1 LNBIT(8), LBUF(32), IPUT(91)
DIMENSION IODAT(100), IPICT(450), LIST(27)
COMMON/POOL/LASTP, ISW, INIT, LIST, LNBIT, LBUF, IODAT, IPICT,
*IPRG, IGOA, IGOB, IGOC, IPUT, I, II, III, IV, IIII, IX, IPRT, LUBIT
DATA KINIT/1/, MPICT/0/, ICNFS/0/, IWS/0/, KOOL/0/
ASSIGN 1234 TO NO
ISW=0
C
KINIT=INIT
C
1 JZ=MESUP(1)
DO 2 KIX=2, JZ, 10
IZ=MESUP(KIX)
IIZ=MESUP(KIX+1)
IIZ=MESUP(KIX+2)
LUBIZ=MESUP(KIX+3)
IXZ=MESUP(KIX+4)
IIZ=MESUP(KIX+5)
IIIIZ=MESUP(KIX+6)
IF(IVZ.NE. IV. AND. IVZ.NE. 0)GO TO 2
IF(IIZ.NE. III. AND. IIZ.NE. 0)GO TO 2
IF(IZ.NE. I. AND. IZ.NE. 0)GO TO 2
IF(LUBIZ.NE. LUBIT. AND. LUBIZ.NE. 0)GO TO 2
IF(IIZ.NE. II. AND. IIZ.NE. 0)GO TO 2
IF(IIZ.NE. III. AND. IIZ.NE. 0)GO TO 2
C
IF(IVZ+IIZ+IXZ+LUBIZ+IZ+IIZ+IIIIZ.EQ.0)GO TO 2
C
ISOLN=MESUP(KIX+8)
MBIT=MESUP(KIX+9)
MPICT=MESUP(KIX+7)
KINIT=LIST(MPICT)
GO TO 1000
2 CONTINUE
C
C
1000 IIS=1
IF(LBUF(29).AND. LNBIT(5))IIS=0
ICIS=0-IIS
DO 99 K=17,30
   IF(LBUF(K).XOR. ICLST(K-16))GO TO 98
IF(KINIT.EQ.INIT)GO TO 10000

1FCMPCT.GT.49)GO TO 1500

GO TO 1402

L=IPICT(KINIT)+3

DO 99998 ID=1,L

IP=KINIT+ID-1

99998 IODAT(ID)=IPICT(IP)

GO TO 9999

1500 ISW=56-MPICT

9999 LASTP=KINIT

10000 RETURN

END

SUBROUTINE PICTUR

INTEGER*1 INTWD, ISTIK

LOGICAL*1 LWD, MIKE, IKE, KWD

LOGICAL*1 LNB8IT(8), LBUF(32), IPUT(91)

DIMENSION IODAT(100), IPICT(450), LIST(27)

COMMON/POOL/LASTP, ISW, INIT, LIST, LNBIT, LBUF, IODAT, IPICT,

*IPRG, IGOA, IGOB, IGOC, IPUT, I, II, III, IV, IIII, IX, IPRT, LUBIT

EQUIVALENCE (LWD, INTWD), (KWD, ISTIK)

DATA NPORT/'Z’007C'/, IPORT/'Z’00FC'/, P5'/, 05'/

IA2=IODAT(2)
GET COUNT OF PULSES TO BE LOADED

MSB2=IA2/64
IB2=MSB2*64
LSB2=IA2-IB2

CSPLIT COUNT INTO TWO 6 BIT PARTS MOST AND LEAST SIG BITS

INTWD=MSB2
MIKE=LWD
INTWD=LSB2
IKE=LWD

C16 TO 8 BIT WORDS

MIKE=MIKE OR LNBIT(8) OR LNBIT(7)
IKE=IKE OR LNBIT(7)

CTHAT PUTS THE CONTROLS IN

CALL OUT(NPORT,MIKE)
CALL OUT(NPORT,IKE)
IA2=IODAT(1)+3
MSB2=IODAT(2)
DO 1 ID=4,IA2

K=IODAT(ID)

IF(K.EQ.0)GO TO 99999

N=K/10000
L=K-N*10000
M=L/100
L=L-M+100
LL=L
K=L/10
L=L-K*10

IF(M.GT.50)M=50+(M-50)

C A FIVE DIGIT POSITIVE INTEGER NUMBER (<=32767) DECODES THUS:

C N//// -> A '/' => OR '\'
LINE WITH 0, 1, OR 2 VALUE

C //MM// -> A LINE OF LENGTH 0 TO 50 OR A LINE LENGTH 50, TIMES THE
DIFFERENCE OF 50 TO 100

C //KL -> A LINE FROM FROM ONE OF NINE EQUALLY INCREMENTED LEVELS (K)
TO ANOTHER SUCH LEVEL (L) DERIVED FROM THE SPACE REMAINING

C ABOVE (OR BELOW) THE START LEVEL

ZK=K
ZK=ZK+6.3+PS
ZL=L

101 ZL=(ABS(56.7-ZK./9.)+ZL+PS+ZK
GO TO 102
ZL=ZK-((ZK/9.)*(9-ZL)+P5)
ZM=M
IF(M.EQ.0)ZM=1.
Z=ABS(ZK-ZL)/ZM
ISTIK=ABS(ISW)

DO 55 J=1,M
   ZJ=J
   C
   C
   IF(N.EQ.0)INTWD=ZK+Z+ZJ+P5
   IF(N.EQ.1)INTWD=LL
   IF(N.EQ.2)INTWD=ZK-Z+ZJ-P5
   C
   C
   MIKE=KWD
   IF(ISW)5500,5523,5522
5500  MIKE=MIKE. AND. NOT. LNBITS(ISTIK)
       GO TO 5533
5522  MIKE=MIKE. OR. LNBITS(ISTIK)
5533  MIKE=MIKE. NOT. LNBITS(7). OR. MIKE
       CALL OUT(NPORT,MIKE)
   55 CONTINUE
   C
   CONTINUE
1 CONTINUE
   WRITE(5,69)MIKE,ISW
69  FORMAT(1X,'MIKE=' ,I8, '/' , 'ISW=' ,I8, '/')
C SWITCH FOR ONE VERSUS TWO MHZ OPERATION

C

IF(INIT.GT.LIST(4))GO TO 6
CALL OUT(IPORT, 0)
RETURN

C THIS IS THE RANDOM NOISE GENERATOR

DO 5 ID=1, MSB2
ISEED=ISEED*31623
RAN=ABS(ISEED*(1./((2.**15-1.))))
RAN=RAN**31.5+2.
IID=RAN
IF(MOD(IID, 2).EQ.0)GO TO 5
C DIG NOISE NEEDS A "SQUARED LOOK"
C

INTWD=IID
IKE=LWD
IKE=. NOT. (LNBIT(7). OR. IKE)
5 CALL OUT(NPORT, IKE)
6 CALL OUT(NPORT, 0)
RETURN
END

PROGRAM TPSPGM
**LOGICAL** STATISTICS, IPANL(9), NAME(11), NUMB(10), ICLST(14)

**DIMENSION** MESUP(101)

**LOGICAL** STATISTICS, LNBIT(8), LBUF(32), IPUT(9)

**DIMENSION** IODAT(100), IPICT(450), LIST(27)

**COMMON** POOL/LASTP, ISW, INIT, LIST, LNBIT, LBUF, IODAT, IPICT,

**IPRG, IG0A, IG0B, IG0C, IPUT, I, II, III, IV, IIII, IX, IPRT, LUBIT**

**DATA** IPANL/64, 7, 6, 128, 1, 0, 128, 3, 2/, JBITS/Z'3F'/,

**NAME/'E', 'R', 'R', 'O', 'R', 'S', 'D', 'A', 'T'/,**

**NUMB/'O', '1', '2', '3', '4', '5', '6', '7', '8', '9'/**

**C**

**C** INITIALIZE THE BIT I/O FACEPLATE WITH PORTS A, B, AND C OUTPUT ONLY. **C**

**CALL POKE(IPRG, 128)**

**C**

**CALL POKE(IG0A, 0)**

**DO 4 ID=2, 16, 2**

**K=ID+1**

**CALL POKE(IPRG, K)**

**CALL POKE(IPRG, ID)**

**4 CONTINUE**

**CALL POKE(IPRG, 9)**

**CALL POKE(IPRG, 11)**

**DO 5 ID=1, 9, 3**

**CALL POKE(IG0A, IPANL(ID))**

**CALL POKE(IPRG, IPANL(ID+1))**
CALL POKE(IPRG(IPANL(ID)+2))

GET ERROR FOR STUDENT TO FIX

CALL INOUT

IF(LBUF(5).AND.LNBIT(8))IPRT=1
IF(LBUF(5).AND.LNBIT(7))CALL POKE(31871,197)
LBUF(1)=LBUF(3). AND. JBITS
L=LBUF(1)

IF(L. EQ. 0)GO TO 101

KL=L/10
JL=L-KL+10
NAME(7)=NUMB(KL-1)
NAME(8)=NUMB(JL+1)
CALL OPEN(6,NAME,0)
READ(6,2323)(MESUP(ID), ID=1,91)

FORMAT(9(1015,1X,/,,115)
DO 7 ID=1,101
7 MESUP(ID)=MESUP(ID)/10
ENDFILE 6

DO 6 ID=1,14
6 ICLST(ID)=LBUF(ID+16)

WRITE(5,1222)(MESUP(ID), ID=1,91)
1252 FORMAT(1X, 115, 2X, 1015, 2X)

101 DO 10 ID=1, 100
10 IDAT(ID)=0
   ID=0
   ISS=0
   DO 20 K=1, 450
   IF(IPICT(K).NE.1) GO TO 20
   ID=ID+1
   LIST(ID)=-2
20 CONTINUE
   DO 2 ID=1, 2
   LBUF(ID)=.FALSE.
   PUT(ID)=.FALSE.
   CALL INPUT

+++++THIS IS WHERE THE FACE PLATE AND CARD SWITCHES ARE READ+++++

100 CONTINUE

++
   DO 2 ID=1, 2
   IFM1(ID)=LBUF(ID)
   CONTINUE
   CALL INPUT

---THE SWITCHES ARE NOW READ---
C

C****THIS IS WHERE THE FACE PLATE AND CARD SWITCHES ARE ANALYZED.****

   LOOK=0

C

DO 1 ID=1,32
    IF(LBUF(ID).XOR.IPUT(ID))LOOK=1
  1 CONTINUE
    IF(LOOK.EQ.0)GO TO 100
    CALL DECIDE
    IF(L.NE.0)CALL ERROR(MESUP,ICLST)
    IF(LASTP.EQ.INIT)GO TO 100
    CALL PICTUR
    IF(LASTP.EQ.LIST(26))GO TO 9999
    LASTP=INIT

C

C START AGAIN AND LOOK AT THE FACE PLATE AND SWITCHES
    GO TO 100

C

9999 STOP

END

SUBROUTINE INOUT
   INTEGER*1 INTWD,NBIT,8
   LOGICAL*1 LWD
   LOGICAL LLWD
DIMENSION IB1(2), IB2(2)

LOGICAL(1) LNB1T(8), LBUF(32), IPUT(91)

DIMENSION IDAT(100), IPICT(450), LIST(27)

COMMON/POOL/LASTP, ISW, INIT, LIST, LNB1T, LBUF, IDAT, IPICT.

*IPRG, IGOA, IGOB, IGOC, IPUT, I, II, III, IV, IIII, IX, IPRT, LUBIT

DATA IB1/10, 8/, IB2/11, 9/

C

C

J=0

DO 400 ID=1, 2

   DO 401 IK=1, 16
       J=J+1
       K=IK-1
       K1=K

       IF(ID, EQ. 1)K1=K*16

       CALL POKE(IGOB, K1)

       CALL POKE(IPRG, IB1(ID))

       LBUF(J)=PEEK(IGOC)

       CALL POKE(IPRG, IB2(ID))

   401  CONTINUE

400  CONTINUE

   GO TO (500, 501), IPRT

500  DO 5 ID=1, 32

   LWD=LBUF(ID)

C
* 

IF(LWD EQ. IPUT(ID))GO TO 5
I2=LWD
DO 4 IY=1,8
     NBIT(IY)=0
     IF(LWD AND. LNBIT(IY))NBIT(IY)=1
4 CONTINUE
WRITE(5,1221)(NBIT(IY)),IY=1,8)
WRITE(5,1221)(NBIT(IY),IY=1,8)),LWD,ID
1221 FORMAT(1%,017)
1222 FORMAT(1%,1017)
5 CONTINUE
501 RETURN
END

SUBROUTINE DECIDE
INTEGER*1 LEN
LOGICAL*1 LTEST,MTEST,LENT,LENT
LOGICAL*1 LNBIT(8), LBUF(32), IPUT(91)
DIMENSION IODAT(100), IPICT(450), LIST(27)
DIMENSION MTIPS(4),
COMMON POOL,LASTP.ISW, INIT, LIST, LNBIT, LBUF, IODAT, IPICT,
IPPG, IGAA, IGOD, IGOC, IPUT, I, II, III, IV, IIII, IX, IPRT, LUBIT
EQU VALENCE (LEN, LENT)
DATA LENT:.IF .
ASSIGN 9999 TO IFLAT
* ASSIGN 4500 TO IAD
ASSIGN 99999 TO LESGO
C
C
C
C
C /* TURN ON THE BITE TESTER */
C//*S1*/
IF(LBUF(4) .AND. LNBIT(8))GO TO 3700
CALL CLEAR
GO TO IFLAT
C
C
C
C//*S37*/ /*USES POSNS 9&10 ... LBUF(9) HOLDS POSNS 1-8 OF S37*/
3700 IF(LBUF(9))GO TO IFLAT
C//*POSNS 1 THRU 8 OF SW37 ARE INVALID*/
C
C
C /*ELSE GO TO S37 POSN 9 OR 10*/
C//*FIND OUT POSN OF SW45*/
LTEST=LBUF(15)
DO 451 IV=1,7
IF(LTEST .AND. LNBIT(IV))GO TO 452
451 CONTINUE
IV=0
IV = IV + 1

LTEST = LBUF(7)
    DO 460 III = 4, 6
    IF(LTEST .AND. LNBIT(III)) GO TO 461

III = 3

461 III = III - 2

MTEST = LBUF(8)
    DO 3800 II = 1, 7
    IF(MTEST .AND. LNBIT(II)) GO TO 4100
    II = II + 1

(S38) CHANNEL SEL SET = II

MTI/SCH(S41) NEED TO SET DP AND CHR' SEL

(S41) SETS ALL MTI/SCH FUNCTIONS

LTEST = LBUF(12)
    DO 4141 I = 3, 8
    IF(LTEST .AND. LNBIT(I)) GO TO 4142
I = 2
4142 I = I - 1
C
C
C
MTEST = . FALSE.
LTEST = MTEST
IF (LBUF(31). AND. LNBIT(5)) MTEST = . TRUE.
IF (LBUF(32). AND. LNBIT(5)) LTEST = . TRUE.
DO 41022 III = 1, 4
C
C
C
41022 MTIPS(III) = A
IF (LBUF(2). AND. LNBIT(1)) MTIPS(1) = 2
DO 41020 III = 1, 3
III = 9 - III
41020 IF (LBUF(1). AND. LNBIT(III)) MTIPS(III + 1) = III + 2
C
C
IF (IV. NE. 3. OR. IV. NE. 4) CALL CLEAR
GO TO (9999, 9999, 4630, 4640, 45000, 45000, 4500, 4500), IV
45000 CONTINUE
C/*S3709-3710*/ /*MUST NOT BE IN MTL SEARCH FOR A/D MEMORY*/
IF (LBUF(2). AND. LNBIT(4)) GO TO IAD
C /*ELSE DO MTI/SEARCH(33710)-BFLOW*/
C
GO TO (4101, 4102, 4103, 4104, 4150, 4150, 4150), I
C /*MTI DECODER*/
4101 GO TO(9999, 4651, 4651, 4651, 4651, 4651, 4651, 9999), II
C
C
C /*THE II AND III 'GO TO'S' CAN BE EXTENDED TO SHOW ERRORS*/
4651 GO TO(1080, 1090, 1080, 1080, 1100), III
C
C
C /*MTI PEAK SELECT*/
C
C
CHAN SEL MUST= PROCESSOR CHAN OTHERS NOT REQ
C
4102 CONTINUE
   DO 41023 IIII=1,4
41023 IF(MTIPS(IIII) EQ. II)GO TO 41524
   GO TO IFLAT
41024 GO TO (1080, 1090, 1080, 1100), III
C
C
C /*THRESHOLD*/ MTI? OR INTEGRATORS?
C
4104 KLEN=O
   IF(IV. EQ. 6) GO TO 4505
*  
IF(IV, NE. 5) GO TO IFLAT
DO 46540 ILL = 1, 4
IF(MTIPS(Ill), NE. 0) GO TO 4654

46540 CONTINUE
GO TO IFLAT

GO TO (9999, 9999, 9999, 1150), IIL
GO TO (1170, 9999, 1180, 9999), III
GO TO (1040, 9999, 1050, 9999), III
GO TO (1060, 9999, 1070, 9999), III

C
C

C /* INTEGRATOR (MTI (THRESHOLD OR INTEGRATOR) */
C /* INTEGRATOR */

4103 IF(MTEST) GO TO (1150, 9999, 1160, 9999), III
GO TO (1170, 9999, 1180, 9999), III
GO TO (1040, 9999, 1050, 9999), III
GO TO (1060, 9999, 1070, 9999), III

C
C

C/*MTI/THRESHOLD*/ /* INTEGRATOR */

4505 IF(MTEST) GO TO (1040, 9999, 1050, 9999), III
GO TO (1060, 9999, 1070, 9999), III

C
C

C/*MTI INTEGRATOR*/

C----------------------
C/*SEARCH BEGINS HERE*/

4150 IF(IV, NE. 6) GO TO IFLAT
C
C
DO 41500 III=1,5
   IF(LBUF(1).AND.LNBIT(III))GO TO 41501
41500  CONTINUE
   GO TO IFLAT
41501 J=1-6
   LENT=LBUF(J).AND.LENTH
   IF(KLEN.NE.LEN)LASTP=0
   KLEN=LEN
   KLEN=1+KLEN*.25
   KLEN=KLEN*100
   IF(J)4155,4156,4157
C
C /*SEARCH INTEGRATOR*/
4155  GO TO (9999,4655,4655,4655,4655,4655,4655,9999),II
4655  IF(LTEST)GO TO(1150,9999,1150,9999),III
   GO TO (1170,9999,1180,9999),III
C
C /*SEARCH THRESHOLD*/
4156  GO TO (9999,4656,4656,4656,4656,4656,4656,9999),II
4656  IF(LTEST)GO TO(1040,9999,1050,9999),III
   GO TO (1060,9999,1070,9999),III
C
C /*SEARCH PEAK SELECT*/
4157  GO TO (9999,4657,4657,4657,4657,4657,4657,9999),II
4657  IF(LTEST)GO TO(1040,9999,1050,9999),III
GO TO(1060, 9999, 1070, 9999), III

C

;*THIS ENDS HT1/SEARCH*/

C

;*/THIS BEGINS A/D MEMORY*

C

4500  CALL ADMEN
GO TO LES60

C

4600  CONTINUE
4610  CALL HGT
GO TO LES60

C

1040  INIT=LIST(5)
GO TO LES60
1050  INIT=LIST(6)
GO TO LES60
1060  INIT=LIST(7)
GO TO LES60
1070  INIT=LIST(8)
GO TO LES60
1080  INIT=LIST(9)
GO TO LES60
1090  INIT=LIST(10)
GO TO LES60
1100 INIT=LIST(11)
    GO TO LESGO
1130 INIT=LIST(14)
    GO TO LESGO
9999 CONTINUE
1140 INIT=LIST(15)
    GO TO LESGO
1150 INIT=LIST(16)
    GO TO LESGO
1160 INIT=LIST(17)
    GO TO LESGO
1170 INIT=LIST(18)
    GO TO LESGO
1180 INIT=LIST(19)
C
99999 IF(\$ASTP. EQ. INIT). RETURN
    L=IPICT(INIT)+3
    DO 99998 ID=1, L
    IP=INIT+ID-1
99998 IODAT(ID)=IPICT(IP)
    IF(INIT. GT LIST(8). OR. INIT. LT. LIST(5))GO TO 1111
    K1=KLEN/100. +1. 05
    IF(INIT NE LIST(5)) GO TO 1051
    DO 1042 N=1, K1
1042 IODAT(N+4)=10100
GO TO 1111

1051 IF(INIT. NE. LIST(6)) GO TO 1061
   DO 1052 N=1, K1
      NN=27-N
1052 IODAT(NN)=10100
   GO TO 1111
1061 IF(INIT. NE. LIST(7)) GO TO 1071
   IODAT(5)=IODAT(5)-KLEN
   IODAT(6)=IODAT(6)+KLEN
   GO TO 1111
1071 IODAT(8)=IODAT(8)+KLEN
   IODAT(9)=IODAT(9)-KLEN
1111 RETURN
END

SUBROUTINE ADMEM
LOGICAL*1 LTEST, MTEST, LENT, LENTH
LOGICAL*1 LNBIT(8), LBUF(32), IPUT(91)
DIMENSION IODAT(100), IPICT(450), LIST(27)
COMMON/POOL/LASTP, ISW, INIT, LIST, LNBIT, LBUF, IODAT, IPICT,
*IPRG, IGA, IGB, IGC, IPUT, I, II, III, IV, IIII, IX, IPRT, LUBIT
ASSIGN 1111 TO LESC0
ASSIGN 9999 TO IFLAT
IF(LBUF.2) AND. LNBIT(4) GO TO 400
GO TO 9999
LTEST=LBVF(11)
DO 430 IX=1,8
IF(LTEST.AND.LNBIT(IX))GO TO 431
430 CONTINUE
IX=IX+1
431 LBIT=1
IF(LBUF<8> AND. LNBIT<8>)LBIT=2
C
GO TO(9999, 9999, 9999, 9999, 9999, 4507, 4508), IV
4507 GO TO(9999, 9999, 9999, 4304, 4305, 4306, 9999, 4507, 4508), IX
4508 GO TO(4301, 4302, 4302, 9999, 9999, 9999, 9999, 9999, 9999), IX
C.*HEIGHT A-D*/
4301 GO TO(1033, 1020), LBIT
C/*SEARCH A-D*/
4302 GO TO(9999, 4352, 4352, 4352, 4352, 4352, 9999), II
4352 GO TO(1010, 1000), LBIT
C/*MTI A-D*/
4303 GO TO(9999, 4353, 4353, 4353, 4353, 4353, 9999), II
4353 GO TO(1033, 1020), LBIT
C/* MEMORIES */
C/*HEIGHT EVAL MEN*/
4304 GO TO(9999, 1190, 1200, 1210), III
C/*CANC #1 AND 2 */
4305 CONTINUE
4306 GO TO(9999, 4345, 4345, 4345, 4345, 4345, 4345, 9999), II
4345  GO TO(4355, 4365), LUBIT
4355  GO TO(9999, 1190, 1110, 1120), III
4365  GO TO(1220, 1220, 1230, 1240), III
C//SEARCH INT MEM*/
4307  GO TO(9999, 4357, 4357, 4357, 4357, 4357, 4357, 9999), II
4307  GO TO(9999, 1190, 1110, 1120), III
C//MTP INT MEM*/
4308  GO TO(9999, 1190, 1110, 1120), III
C
C
C
C
C
C
C
1000  INIT=LIST(1)
      GO TO LESGO
1010  INIT=LIST(2)
      GO TO LESGO
1020  INIT=LIST(3)
      GO TO LESGO
1030  INIT=LIST(4)
      GO TO LESGO
1110  INIT=LIST(12)
      GO TO LESGO
1120  INIT=LIST(15)
      GO TO LESGO
*  
9999 CONTINUE  
1140 INIT=LIST(15)  
GO TO LESGO  
1190 INIT=LIST(20)  
GO TO LESGO  
1200 INIT=LIST(21)  
GO TO LESGO  
1210 INIT=LIST(22)  
GO TO LESGO  
1220 INIT=LIST(23)  
GO TO LESGO  
1230 INIT=LIST(24)  
GO TO LESGO  
1240 INIT=LIST(25)  
1111 RETURN  
END  

SUBROUTINE CLEAR  
DATA I/'Z'FFFF0'/,J/'Z'FFFF3'/  
CALL POKE(I,0)  
CALL POKE(J,5)  
CALL POKE(J,4)  
RETURN  
END
SUBROUTINE HGT

LOGICAL*1 LTEST

LOGICAL*1 LNBIT(8), LBUF(32), IPUT(91)

DIMENSION IODAT(100), IPICT(450), LIST(27)

LOGICAL*1 IPATN(4), JPATN(4), KPATN(4), LPATN(4)

COMMON /POOL/ LASTP, ISW, INIT, LIST, LNBIT, LBUF, IODAT, IPICT,
*IPRG, IGOA, IGOB, IGOC, IPUT, I, II, III, IV, IIII, IX, IPRT, LUBIT

DATA IPATN/16'E', Z'56', Z'29', Z'95'/,
*       JPATN/13', Z'76', Z'5C', Z'25'/,
*       KPATN/22', Z'5E', Z'4B', Z'E1'/,
*       LPATN/1A', Z'44', Z'35', Z'A6'/

IF(IV. EQ. 3) GO TO 1000
CALL POKE(IGOA, IPATN(III))
GO TO 9999

C

1000 IF(LBUF(16). AND. LNBIT(8)) GO TO 167
IF(LBUF(15). AND. LNBIT(8)) GO TO 157
CALL POKE(IGOA, KPATN(III))
GO TO 9999
C

167 CALL POKE(IGOA, LPATN(III))
GO TO 9999
C

157 CALL POKE(IGOA, JPATHN(III))
C

9999 CALL POKE(IPRG, 5)
CALL POKE(IPRG, 4)
INIT=LIST(15)
RETURN
END
SUBROUTINE PICTUR

INTEGER*4 INTWD, ISTIK
LOGICAL*1 LWD, MIKE, KWD, IKE
LOGICAL*1 LNBIT(9), LBUF(32), IPUT(91)
DIMENSION IODAT(100), IPICT(470), LIST(30)
COMMON/POOL/LASTP, ISW, INIT, LIST, LNBIT, LBUF, IODAT, IPICT,
*IPRG, IGRA, IGOB, IGOC, IPUT, I, II, III, IV, III, IX, IPRT, LUBIT

EQUIVALENCE (LWD, INTWD), (KWD, ISTIK)

DATA: nPORT/Z'007C',/, iPORT/Z'00FC',/, P5/, 05/
DATA IFLIP/-1/

IA2=IODAT(2)
IFLP0=0

C
GET COUNT OF PULSES TO BE LOADED
C

MSB2=IA2/64
IB2=MSB2+64
LSB2=IA2-IB2

CSPLIT COUNT INTO TWO 6 BIT PARTS MOST AND LEAST SIG BITS
C

C

INTWD=MSB2
MIKE=LWD
INTWD=LSB2
IKE=LWD
C16 TO 8 BIT WORDS

C

C

MIKE = MIKE. OR. LNBIT(8). OR. LNBIT(7)
IKE = IKE. OR. LNBIT(7)
CTHAT PUTS THE CONTROLS IN

C

CALL OUT(NPORT, MIKE)
CALL OUT(NPORT, IKE)
IA2 = IODAT(1) + 3
MSB2 = IODAT(2)

C

DO 1 ID = 4, IA2
K = IODAT(ID)
IFLG = K
K = IABS(K)
N = K / 10000.
L = K - N * 10000
M = L / 100
L = L - M * 100
LL = L
IF(IFLG)7, 99999, 8
ICK = IFLP**IFLP0
C SWITCH FOR ONE VERSES TWO MHZ OPERATION

IF(INIT.GT.LIST(4))GO TO 6
CALL OUT(IPORT,0)
RETURN

****  

C THIS IS THE RANDOM NOISE GENERATOR
ISEED=12345

DO 5 ID=1, MSB2
ISEED=ISEED*31623
RAN=ABS(ISEED**(1.0/2.**15-1.))
RAN=RAN*31.5+2.

IID=RAN
IF(MOD(IID,2).EQ.0)GO TO 5

C DIG NOISE NEEDS A "SQUARED LOOK"

C

INTWD=IID
IKE=LWD
IKE=. NOT. (LNBIT(7). OR IKE)
5 CALL OUT(NPORT, Ike)
6 CALL OUT(NPORT, 0)
RETURN

END
IF(I.CK.GE. 0) GO TO 70

IFLP0=1

M=M+M*100+M

ZM=M

ZL=LL

IFLP0=2

GO TO 10.1

70

MM=M

ZK=LL

GO TO 1

8 CONTINUE

K=L/10

L=L-K*10

IF(M GT 50)M=50+(M-50)

ZK=K

ZK=ZK+6 1+P5

J=L

IF(N GT 101)104 105

101

ZL=ABS(56 7-ZK)/9 +L+P5+.1

GO TO 102

102

ZL=ZL+0 2+P9 1+(9-ZL)+P5)
102       ZM=M
         IF(M. EQ. 0) ZM=1.

1021      CONTINUE

         Z=ABS(ZK-ZL)/ZM

         ISTIK=IABS(ISW)

104       DO 55 J=1, M

         ZJ=J

         C

         C

         IF(N. EQ. 0) INTWD=ZK+Z*ZJ+P5
         IF(N. EQ. 1) INTWD=LL
         IF(N. EQ. 2) INTWD=ZK-Z*ZJ-P5

         C

         C

         MIKE=KW
         IF(ISW. EQ. 5500, 5513, 5522)

         5500      MIKE=MIKE. AND. NOT (LNBIT(ISTIK))
                   GO TO 5533

         5522      MIKE=MIKE OR. LNBIT(ISTIK)

         5533      MIKE= NOT (LNBIT(7). OR. MIKE)

                   CALL OUT(NPORT, MIKE)

         55       CONTINUE

         1       CONTINUE
APPENDIX G

STUDENT ERROR FILE PROGRAM
B

PROGRAM ERRS 20

DIMENSION IPUT(91)

LOGICAL NAME(9)


DATA IPUT/41.7, 1, 0, 0, 0, 0, 0, 0, 61, 24, 5,
  7, 2, 0, 0, 0, 0, 0, 61, 24, 5,
  7, 3, 0, 0, 0, 0, 0, 61, 24, 5,
  7, 4, 0, 0, 0, 0, 0, 61, 24, 5,
  50+0/

CALL OPEN(6, NAME, 0)

FORMAT(9.10I5, 1X, /), 115

WRITE(6,1) (IPUT(I), I=1, 91)

ENDFILE 6

STOP

END

B TYPE ERRORS20.DAT

1 7 1 0 0 8 3 0 61 24
5 7 2 0 0 8 3 0 61 24
5 7 3 0 0 8 3 0 61 24
5 7 4 0 0 8 3 0 61 24
5 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0

C
APPENDIX H

PICTURE CODE GENERATOR
1220 LET W1=INT((63*W1)/5+.05)
1230 LET L2=L/100
1240 LET L3=INT(L2+.05)+100
1250 LET L2=(L-L3)*100
1260 LET C1=(Z+L3+W9)-1
1270 LET C2=(Z+L2+W1)-1
1280 LET L0=L0+1
1290 LET I[L0]=C1
1300 LET I[L0]=L0+1
1310 LET I[L0]=C2
1320 RETURN
1330 LET I[L0]=C1
1340 REM**************************RNDOM NOISE********************************
1350 LET L0=L0+1
1360 LET I[L0]=0
1370 LET I[L0]=0
1380 LET I[L0]=0
1390 RETURN
1400 REM****************REGULAR AND RNDOM NOISE MIXTURE************
1410 PRINT "DO THE REST OF THE PICTURE WITH RNDOM NOISE LAST"
1420 PRINT "THEN USE MENU 4"
1430 RETURN
1440 REM**************************WICE PRIN' ROUTINE**************
1450 LET M=L0
1460 LET M=L0
1470 FOR J=1 TO M
1480 PRINT I[J];
1490 LET M=L0
1500 PRINT "IS THAT SATISFACTORY? (YES-NO)"
1510 IF B$="YES" RETURN
1520 PRINT "TRY AGAIN"
1530 LET S=S+L5
1540 RETURN
1550 GOSUB 1460
1560 STOP
1570 END