












The University of Tennessee









National Aeronautics and Space Administration
Goddard Space Flight Center
Greenbelt, Maryland 20771





This report represents the findings of the work completed under
a nine-month study of programmable data collection platforms. The sys-
tem has been implemented with a microcomputer, and the results show
that programmable data collection platforms can carry out all the func-
tions of hardwired data collection platforms with capacity left to
perform a number of desirable computational functions.
; CONTENTS
Section Page
1 INTRODUCTION . . 1-1
1.1 BACKGROUND AND PURPOSE 1-1
1.2 SUMMARY 1-2
2 MICROCOMPUTER HARDWARE AND SOFTWARE . . . . 2-1
2.1 HARDWARE ARCHITECTURE OF THE MICROPROCESSOR 2-4
2.1.1 Arithmetic/Logic Unit (ALU) . . . . . . . . . 2-4
2.1.2 Registers 2-8
2.1.2.1 Program Counter Register 2-9
2.1.2.2 Stack and Stack Pointer 2-10
2.1.2.3 Accumulator and General Purpose
Registers 2-11
2.1.2.4 Instruction Register 2-11
2.1.2.5 Address Registers 2-12
2.1.3 Control Logic 2-12
2.2 MICROCOMPUTER SOFTWARE ASPECTS . . . . . . . . . . . . 2-19
2.2.1 Microcomputer Instruction Sets 2-22
2.2.2 Microcomputer Programming ... 2-25
2.2.2.1 Programming Languages 2-27
2.2.2.2 Utility Programs 2-29
2.2.2.3 Microprogramming 2-31
i
3 PDCP SYSTEM HARDWARE 3-1
3.1 SENSOR CLASSIFICATION AND INTERFACING 3-1
3.1.1 Sensor Classification 3-1
3.1.2 Sensor Interfacing 3-9
3.1.2.1 Sensor Interface . . . . . 3-11
3.1.2.2 Microprocessor Interface 3-11
3.2 DIGITAL CONTROL LOGIC AND MEMORY 3-12






4 PDCP SYSTEM SOFTWARE. ' 4-1
4.1 PDCP SOFTWARE ORGANIZATION 4-1
4.2 PDCP SYSTEM TIMING 4-3
4.3 PDCP SOFTWARE DEVELOPMENT 4-5
4.3.1 Applications-Oriented Software Development. . 4-5
4.3.2 Assembly Language and Microprogrammed
Subroutines 4-7
4.4 PDCP PROGRAM EXAMPLES 4-8
4.4.1 Data Input and Sensor Control 4-8
4.4.1.1 Frequency Measurement 4-9
4.4.1.2 Autoranging 4-13
'4.4.1.3 Software Controlled
Analog-to-Digital Conversion .... 4-17
4.4.2 Data 'Compaction and Preprocessing 4-19
4.4.2.1 General-Purpose Binary Math
Package 4-22
4.4.2.2 Determination of Minimum and
Maximum Data Values 4-27
4.4.2.3 Zero-Order Floating Aperture
Predictor .. . 4-27
4.4.2.4 Data Average 4-40
4.4.2.5 Mean, Variance, and Standard
Deviation 4-40
4.4.3 Data Formatting and Transmitter Control ... 4-50
4.4.3.1 TWERLE Format Transmitter
Subroutine 4-57
4.4.3.2 GOES Format Transmitter Routine. . . 4-68
4.4.3.3 TIROS-N Format Transmitter
Routine 4-68
4.4.3.4 Landsat Format Transmitter
Subroutine 4-84
4.4.4 Special Computations 4-84
4.4.4.1 The FFT Program 4-95




5 PROGRAMMABLE DATA COLLECTION PLATFORM DEMONSTRATION
SYSTEM 5-1
"5.1 UT PDCP DEVELOPMENT SYSTEM HARDWARE 5-1
5.1.1 Basic Pro-Log System 5-2
5.1.1.1 Central Processing Unit Card .... 5-5
5.1.1.2 Random-Access Memory Cards . . . . . 5-5
5.1.1.3 Read-Only Memory Cards 5-6
5.1.1.4 Latched Parallel Output Card . . . . 5-6
5.1.1.5 Parallel Input Card 5-7
5.1.2 Special Purpose Interface Cards 5-8
5.1.2.1 Dual Serial I/O Card 5-9
5.1.2.2 Analog Interface Card 5-10
5.1.2.3 Cassette Analog Interface and Baud
Rate Clock Card 5-10
5.1.2.4 General-Purpose Utility Card . . . . 5-11
5.1.3 -Miscellaneous-Ha-rdwa-re -Components of the UT
PDCP Development System 5-11
5.2 UT PDCP DEVELOPMENT SYSTEM SOFTWARE PACKAGE. . . . . 5-13
6 FUTURE PDCP SYSTEMS ..... 6-1
6.1 EVALUATION OF AVAILABLE MICROPROCESSORS 6-1
6.2 TECHNOLOGY FORECAST 6-14
APPENDICES
A BINARY MATH PACKAGE A-l
B A NEW PRINCIPLE FOR FAST FOURIER TRANSFORMATION B-l




2.1(1) General Block Diagram of CPU. 2-5
2.1.1(1) . Typical Arithmetic/Logic Unit 2-6
2.2(1) Coding Levels 2-20
2.2.1(1) Data Movement in the Microcomputer. 2-23
2.2.2(1) Typical Flow Chart Symbols 2-26
3(1) DCP Hardware Subsystems . . . . . 3-2
3.2(1) Microprocessor Based PDCP Control Subsystem
Organization 3-13
4.1(1) PDCP Software System Organization 4-2
4.4.1.1(1) Flow Chart for Frequency Sensor Input Subroutine. ... 4-12
4.4.1.2(1) Microprocessor-Controlled Variable-Gain Amplifier . . 4-14
-4,-4.-l-.-2-(-2) -Ana-log Data- Acquisition System for a PDCP 4-17
4.4.1.2(3) Flow Chart for Variable Gain Amplifier Control
Program . . 4-18
4.4.1.3(1) Flow Chart for Successive Approximation ADC
Subroutine 4-21
• 4.4.1.3(2) Simplified Schematic of the ADC Hardware 4-21a
4.4.2.1(1) Flow Chart for Square Root Subroutine 4-26
4.4.2.3(1) Flow Chart for the Double Precision Zero-Order
Floating-Aperture Predictor Subroutine 4-35
4.4.2.3(2) Flow Chart for the Multiprecision Zero-Order
Floating Aperture Predictor Subroutine 4-39
4.4.2.4(1) Flow Chart for the Data Accumulation Subroutine . . . 4-42
4.4.2.4(2) Flow Chart fot the Data Averaging Subroutine 4-44
4.4.2.5(1) Flow Chart for Data Preparation for Mean, Variance,
and Standard Deviation Subroutine 4-51
















Bit Assignments for Transmitter Control
Port XCNTR
Simplified Flow Chart for Subroutine
TWXMIT
Detailed Flow Chart for the Data
Transmission Block of Subroutine
TWXMIT
Flow Chart for GOES Transmitter
Subroutine
Flow Chart for Subroutine BIPHS
Flow Chart for TIROS-N Transmitter
Subroutine
Flow Chart for the PDCP Conventional
Encoder Subroutine
Seismic Record Preprocessing and
Classification . . . . . . . .
FFT Data Flow Chart . . . .
Major Components of the UT PDCP Development
System


















4.4.1.1(1) Frequency Sensor Input 4-10
4.4.1.2(1) Variable Gain Ampl i f ie r Control 4-15
4.4.1.3(1) Analog-to-Digital Conversion 4-20
4.4.2.2(1) Minimum-Maximum Value Determination 4-29
4.4.2.3(1) Zero-Order Floating-Aperture Predictor . . . . 4-32
4.4.2.3(2) Mult iprecision Zero-Order Floating-Aperture
Predictor 4-36
4.4.2.4(1) Data Accumulation Subroutine . 4-41
4.4 .2 .4(2) Data Averaging Subroutine 4-43
4.4 .2 .5(1) Data Preparation Subroutine for Mean, Variance
and Standard Deviat ion 4-45
4.4.2.5.(2) Mean, Variance and Standard Deviation 4-47
4.4.3.1(1) TWERLE Format Transmitter Subroutine 4-59
4.4.3.2(1) GOES Format Transmitter Subroutine 4-70
4.4.3.3(1) TIROS-N Format Transmitter Subroutine 4-78
4.4.3.4(1) PDCP Convolutional Encoder Subroutine 4-86
4.4.3.4(2) Landsat Format Transmitter Subroutine 4-91
A ( l ) Short Multiprecision Add A-l
A(2) Short Mult iprecision Subtract A-2
A(3) Double-Precision Add With Memory A-3
A(4) Double-Precision Subtract with Memory A-4
A(5) Double-Precision Compare A-5
A(6) Double-Precision Multiply A-6
A(7) Double Precision Divide A-8
A(8) Square Root A-10
A(9) Multibyte Binary Addition and Subtraction . . . A-13
A(10) Multibyte Compare A-15
A ( l l ) Multibyte Memory-to-Memory Move A-17
A{12) General Purpose Exit Subroutine A-18


















Satellite Data Collection Disciplines ....
Sensor Measurement Parameters and
Associated Disciplines .....
Typical Satellite Data Collection Sensors . .
General Purpose PDCP Binary Math Package . .
Binary Math Subroutine Execution Times . . .
Transmitter Control Signals
Transmission Rates for the Landsat, GOES,
TWERLE, and TIROS-N Data Collection Systems .
TWERLE Data Transmission Sequence
Specifications .
Format of the TWERLE RAM Data Block
'GOES 'Data "Transnfi ssion 'Sequence
Specifications
TIROS-N Data Transmission Sequence
Specifications























1.1 BACKGROUND AND PURPOSE :
Data collection by satellite is a rather young branch of science
which was first demonstrated in 1967 using the ATS-1 satellite. This
first NASA demonstration was the Omega Position Location Equipment Sys-
tem (OPLE) which primarily determined that an accurate position fix
could be obtained from platforms in remote locations. This system was
followed by the Interrogation, Recording and Location System (IRLS)
flown on the Nimbus-3 satellite in 1969. The IRLS was closely followed
by the French Eole satellite which was solely devoted to the tasks of
data collection and position location for remote platforms distributed
around the globe.
One fact that stood out from these early experiments was that the
user costs for platform and data reduction must be kept low if the sat-
ellite data collection concepts are to be utilized on a large-scale
.basis. A way .to reduce .costs .was incorporated by the Landsat data col-
lection system flown in 1972. The platform transmissions were random
rather than ordered. This simplified the platforms by eliminating
on-board receivers and reduced the costs substantially. In 1974 the
GOES satellite carried a data collection system which again utilized an
ordered system, but costs were kept low because of improvements in
semiconductor technology.
In 1975 the Nimbus-6 satellite carried the Tropical Wind Energy-con-
version and Reference Level Experiment (TWERLE) into orbit. The TWERLE
utilized the low cost of the random transmission system combined with
new low-cost integrated circuits to maintain a still lower platform
cost.
In 1977 the TIROS-N satellite will be launched carrying a data col-
lection system designed by France. The system will use the random trans-
mission feature which will help to lower user costs and aid in making
the system internationally acceptable.
1-1
1-2
A primary purpose of this study is to determine if the recent
advances in semiconductor technology can be incorporated in the design
of data collection platforms to further reduce their cost and, conse-
quently, make their application more desirable to the user.
At the time of the instigation of this study, all data collection
platforms used hardwired logic circuitry to implement the identification
and formatting of the data collected by a platform. Hardwired circuitry
was also used to control the sensors and the transmitter. In the last
two years, a new semiconductor device which has the potential of dras-
tically reducing hardware costs while increasing the capability of the
data collection platform has appeared on the commercial market. The
device is the microprocessor. The microprocessor is a computer
central-processing unit (CPU) on a single integrated circuit chip. The
equivalent of thousands of discrete electronic components are fabricated :
on a single microprocessor chip with unit costs projected to be in the
ten-dollar range.
The goals of this study are to determine what present data collec-
tion functions can be accomplished by substituting a microprocessor for
most of the hardwired logic, to uncover new tasks which would enhance
the utility of data collection platforms by virtue of having a micro-
processor available, and to determine if the programmable feature of the
microprocessor will allow future platforms to be compatible with more
than one satellite data collection system. To prove the concepts devel-
oped in achieving these goals, a model programmable data collection
platform (PDCP) development system has been implemented. The details
of the University of Tennessee (UT) PDCP development system are des-
cribed in Section 5 of this report.
1.2 SUMMARY
This report describes the results of a study of the feasibility of
incorporating microprocessors in data collection platforms (DCP's). An
introduction to microcomputer hardware and software concepts is provided
in Section 2. Thus, readers who are not familiar with the microprocessor
1-3
field are furnished necessary background information on the basic organ-
ization of a microcomputer and software development techniques.
Programmable data collection platform (PDCP) hardware design goals
include minimizing power consumption, maintenance, weight, and cost
while providing accurate and reliable operation. Section 3 discusses
the influence of microprocessor technology on the design of PDCP hard-
ware. A standard, modular PDCP design capable of meeting the design
goals listed above is proposed. The microprocessor contributes to this
design by minimizing PDCP control logic and simplifying sensor inter-
faces. Also, standard PDCP sensor and transmitter interfaces will pro-
mote further cost reductions.
Although the standard, modular PDCP design proposed in Section 3 is
economically desirable, the PDCP must be sufficiently flexible to oper-
ate efficiently with a number of different sensors, data compaction
techniques, and data transmission formats. The PDCP software described
in Section 4 is the key to attaining these goals. Numerous examples of
 a.
"•potentfaT-PDCP programs' are "presented "to demonstrate that a micropro-
cessor is capable of performing all tasks of current DCP random logic
control units. Furthermore, the PDCP software system will contribute
to reduced hardware costs by replacing random logic and complex sensor
interfaces with inexpensive program memory. In addition, a PDCP can
economically perform data compaction operations that are impractical for
random logic implementation. This will allow users to obtain more
information from each PDCP without exceeding transmission channel band-
width limitations.
Section 4 also discusses the process of developing PDCP programs.
A specific PDCP software organization designed to minimize software
development costs is described. Traditional program development tech-
niques are inadequate for PDCP software development by applications
oriented users. A PDCP software development system which would allow
applications oriented users to define the software structure of their
individual PDCP's in familiar terms is recommended for a future study.
The proposed editor/translator software development system retains the
1-4
efficiency of assembly language programming because users are allowed to
create software systems from a library of subroutines written by experi-
enced assembly language programmers.
An integral part of this study was the design and construction of
the UT PDCP development system described in Section 5. This system is
useful in the development, evaluation, and demonstration of potential
PDCP programs. The UT PDCP provides all the capabilities of a PDCP
control unit. Programs developed for use on the UT PDCP include sensor
data input subroutines, data compaction subroutines, and data trans-
mission subroutines. The UT PDCP is intended for use primarily as a
program development and demonstration system. Therefore, the design of
the system is not intended to represent the design of an actual PDCP.
The system will serve as a machine through which NASA personnel can
acquaint themselves with the details of PDCP software and PDCP software
development.
A PDCP design should be based on a knowledge of currently available
•m-teroproeessors-and projected future'microprocessors. Section 6 des-
cribes a weighting matrix technique for evaluating microprocessors and
provides a microprocessor technology forecast covering the next five
years. The weighting matrix provides a systematic procedure for gen-
erating PDCP application performance measures for the various micropro-
cessors.
2. MICROCOMPUTER HARDWARE AND SOFTWARE
The control logic found in most current data collection platform
designs is an example of the custom random logic approach to process
control system design. Custom random logic combines individual logic
elements (such as flip-flops, gates, counters, etc.) to perform a par-
ticular system control task. The primary tasks of the random logic of
a DCP are to control the sensors, input sensor data, format the data,
and control the DCP transmitter. CMOS logic is prevalent in current DCP
designs due to the extremely low power requirements for CMOS circuits.
A major disadvantage of current hardwired DCP's is that they are
based on customized designs which are intended to perform only specific
tasks. In practice, applications for DCP's vary considerably due to the
diversified requirements of the various users. As a result, the intro-.
duction of new DCP applications or a new data collection satellite can
require the development of a new DCP design. This increases DCP costs
due to both the increase in direct development cost and the increase in
manufacturing cost resulting "from the production of smaller quantities
of each specific design.
What are the alternatives for a state-of-the-art, cost-effective
DCP design? A close look at modern process control systems suggests an
answer. Until the introduction of the microprocessor, state-of-the-art
process control systems depended on custom built random logic designs or
the dedicated minicomputer.
Custom built random logic can be cost effective if a large number
of identical systems are required where the initial high design costs
can be effectively shared by a large number of users. This approach
certainly has merit in the DCP field, but the question still remains as
to whether a more versitile and perhaps more cost effective approach
exists with modern technology. Also, a DCP user requiring only a small
number of platforms must pay an extremely high price for a new design
unless a present design can satisfy his requirements.
2-1
2-2
The dedicated minicomputer approach would provide versitility in a
DCP design as modification of the DCP tasks could be implemented in soft-
ware. Unfortunately, the minicomputer is physically too large and heavy
to be practical in a DCP design. Also, power requirements for the mini-
computer cannot be met by the typical DCP power supply.
The microprocessor is causing a revolution in the process control
field [1-4]. A microprocessorized DCP would be programmable like the
minicomputer, yet cost, size, weight, and power requirements would be
greatly reduced. Produced in quantity, a microprocessorized process
control system provides reduced hardware costs over an equivalent custom
random-logic process-control system. This is due mainly to a reduction
in the number of components required [1-3, 5-7].
A microprocessor-based DCP could not only provide reduced hardware
costs, but later modification of the DCP task could be achieved at a
significantly lov/er cost compared to a custom random-logic design. The
cost of redesigning a custom random logic system could well exceed the
intti-al -design cost. The microprocessor-based DCP would probably require
only a software revision. Hardware cost would be limited to replacement
or reprogramming of one or more read-only memories (ROM's). Software
costs should in general be low compared to high redesign and hardware
costs for a custom random logic-system. -''"
Besides providing great flexibility [3, 4] in altering the task
performed by the DCP, a microprocessor-based design offers the added
advantage of providing data processing capability at a small additional
cost. Providing data processing capability would require adding the
necessary software to perform the additional task. Again, hardware cost
would be minimal requiring only the addition of one or more ROM's.
Software cost could be spread out among the large number of DCP users.
Field programmable ROM's would be used in prototype models, and cost
effective mask-programmed ROM's would be used in production DCP's to
minimize hardware costs. Further hardware aspects of the proposed pro-
grammable DCP (PDCP) are discussed later in this report (Section 3.2).
*
References are located at the end of each chapter.
2-3
To fully appreciate the potential capabilities and advantages of a
microprocessor based DCP, one must be familiar with the basic concepts
of a general computer system and the specific hardware and software char-
acteristics of a microprocessor. Therefore, the remainder of this sec-
tion is devoted to a discussion of the basic characteristics of a
microcomputer.
The definition of a microcomputer differs from author to author;
however, a suitable definition for the purpose of this study is that a
microcomputer is a computer whose major component, the central process-
ing unit, is a single microprocessor chip or microprocessor chip set.
To complete the definition, the term computer must be defined.
Briefly, a computer is a device or machine which performs a pro-
grammed sequence of operations on data. A computer is comprised of
three major components:
• Central Processing Unit (CPU)
e Memory
• Input/Output (I/O)
Instructions and data are placed in the computer memory. The cen-
tral processing unit (CPU) fetches instructions from the memory and
executes the instructions. The instructions are programmed to cause the
CPU to process data. The set of instructions executed by the CPU is
called a program. Data may be initially in memory, processed by the
CPU, and results returned to memory. Input/output ports of the computer
provide a means of entering and retrieving the data from the CPU and/or
the memory. Note that data can be control words or signals as well as
numerical quantities. Thus, the computer is capable of performing the
following tasks:
1. Input data and control signals
\
2. Process and format data
3. Output control signals and data
2-4
In particular, a computer could input DCP sensor data; process the
data (convolutional encoding, Manchester encoding, data compaction, etc.);
provide and recognize DCP control signals; and format the platform data
to emulate any of the typical DCP data formats.
Sections 2.Land 2.2 discuss the hardware architecture and software
aspects of the typical microprocessor. These sections reveal the pro-
cessing and control capabilities of the microcomputer and provide insight
into the question as to whether the microcomputer is indeed capable of
performing the task of a typical DCP.
2.1 HARDWARE ARCHITECTURE OF THE MICROPROCESSOR
There are three basic components of the typical central processing
unit (CPU) as depicted in Figure 2.1(1).
e Arithmetic/Logic Unit (ALU)
• Registers (Temporary Storage)
• Control Logic
The arithmetic/logic unit (ALU), as the name implies, performs the
arithmetic and logical operations on the data processed by the CPU.
Registers provide temporary internal storage for operands and results
as well as address pointers for input/output and memory. The control
logic provides the various signals for initiating processor functions
and controlling external circuits. Recognition of external control
signals is also a function of the control logic. The next three sub-
sections explain in detail the functions of the ALU, registers, and
control logic.
2.1.1 Arithmetic/Logic Unit (ALU)
All microprocessors have an arithmetic/logic unit (ALU) which per-
forms the arithmetic and logical operations. As shown in Figure 2.1.1(1),


































Figure 2.1(1) General Block Diagram of CPU.
2-6
















Figure 2.1.1(1) Typical Arithmetic/Logic Unit.
2-7
One input (Operand No. 1) to the ALU is usually the output of an
accumulator buffer. The buffer stores the accumulator data throughout
the ALL) operation. Typically, all arithmetic operations are performed
betv/een the accumulator register and a temporary register, which in some
CPU's may be a second accumulator. Input to the accumulator or second
operand register may be memory data, an input port, or some other hard-
ware register. The result of the operation is placed on the internal
CPU data bus. Often the result is returned to the accumulator. In this
case, the accumulator requires a buffer so that the original data in the
accumulator can be stored and applied to the ALU while the arithmetic or
logical operation is being performed. Thus, the result can be returned
to the accumulator even though the result is a function of the accumu-
lator's original contents.
All ALU's perform the basic arithmetic function of binary addition.
Additional arithmetic/logical operations performed by most CPU's include
binary subtraction, logical AND, logical OR, logical exclusive OR, com-
plement and register bit shift. Although not yet common functions, some
of the more recent microprocessors such as Texas Instruments' TMS 9900
also include binary multiplication and division.
A very simple ALU may only provide binary addition. In this case,
binary subtraction, multiplication, and division may be performed only
after the programmer has written software routines to perform these
functions. Routines can be written to perform binary subtraction, mul-
tiplication, and division with only the basic binary addition instruction
in conjunction with the ALU flags. Algorithms for performing various
binary operations in terms of simpler binary operations can be written
as needed for a given processing task. For example, multiplication by
two is equivalent to a single bit shift left, and division by two is
equivalent to a single bit shift right.
Although even the simplest ALU provides binary addition, the number
of additional binary operations provided varies widely from microprocessor
to microprocessor. One of the fundamental problems in selecting a micro-
processor for a particular task is deciding how much power in performing
arithmetic/logical operations is sufficient.
2-8
Referring again to Figure 2.1.1(1), notice that the data path
between the flag register is bidirectional. The operations performed by
the ALU produce an output which may be zero, have a carry or borrow,
have even or odd parity, or have positive or negative sign. These aux-
iliary outputs are called flags and are stored in the flag register for
subsequent ALU operations. The flag register is thus a source and
destination register.
Besides providing additional data to the ALU, the flag register
often provides information for the control logic. Program branching may
be conditional on the result of an ALU operation (value of a flag). For
example, the programmer may wish to call an overflow subroutine if an
ALU operation produces a carry. By placing a call on carry instruction
after the ALU operation instruction, the overflow subroutine would be
called only if the result of the operation produced a carry. References
10-14 discuss the use of flags and conditional branching in more detail.
2.1.2 Registers
The hardware registers internal to the CPU provide temporary stor-
age locations for data, instructions, and address pointers. The number
of bits per register is usually an integer multiple of the characteris-
tic word length of the CPU. All computers have a characteristic word
length. The characteristic word length is generally determined by the
size of the internal storage elements (registers) and the interconnect-
ing buses. As an example, a CPU that has mostly eight-bit registers and
eight-bit buses that transfer information between the registers is said
to have an eight-bit word length. Some confusion results when the
address bus is other than the characteristic word length.
Perhaps a better indication of the word length of the CPU is the
maximum number of data bits stored at a single memory address. Most
hardware registers of the CPU are usually equal in size to the memory
word length. An example is the 8080A used in the UT PDCP development
system. The word length of memory is eight bits. The internal gen-
eral purpose registers in the 8080A CPU are eight bits. Certain
address registers such as the program counter and stack pointer are
2-9
comprised of 2 eight-bit registers. Registers, then, are simply tempo-
rary storage elements in the CPU. There are many types of special
purpose registers which are summarized below.
2.1.2.1 Program Counter Register - All CPU's contain a program
counter register. This register stores the memory address from which
instructions are fetched from memory. Each time an instruction is
fetched, the program counter is normally incremented by one to point to
the memory location where the next instruction is located. Multibyte
instructions may require multiple incrementing of the program counter
in order to read the entire instruction (usually accomplished automat-
ically). Some instructions contain immediate data stored sequentially
following the instruction. In this case, the program counter is
incremented one or more times so that the entire instruction is read in.
After the last byte of the instruction is read, the program counter
register is incremented again to point to the first byte of the next
instruction.
'Most'CPU''s'provi'de at'Tea'st'two "means to alter an otherwise sequen-
tial fetching of instructions. The jump-type instruction alters the
program counter register contents according to a particular addressing
mode specified by the jump instruction (see References 10-14). The
subroutine call instruction allows program flow to another area of
memory, and upon completion of the "called subroutine" the program
returns to the instruction following the call. Execution of a subrou-
tine call requires a stack to store the address of the instruction fol-
lowing the call instruction. When a call instruction is encountered,
the address of the instruction following the call instruction is stored
in the stack. Then the program counter is loaded with the address of
the subroutine and the subroutine is executed. Upon completion of the
subroutine, the address previously stored in the stack is returned from
the stack and placed into the program counter. This action is initiated
by placing a return from subroutine instruction as the last executed
instruction at the end of the subroutine. This causes program execution
to return to the calling program.
2-10
2.1.2.2 Stack and Stack Pointer - A CPU that provides subroutine
calls must have a stack. A stack is a last in, first out (LIFO) buffer
storage element; that is, the last value stored is the first to be read
out.
Two types of stacks are found in microprocessors. The hardware •
stack (e.g., the Intel 8008) is a LIFO buffer storage element internal
to the microprocessor integrated circuit. The software stack (e.g.,
Intel 8080A or Motorola 6800) is a LIFO buffer storage element imple-
mented in the computer random-access memory or some memory external to
the CPU integrated circuit.
An advantage of the software stack is that stack size is limited
only by the amount of external memory the programmer dedicates to the
stack function. In the case of a software stack, an internal (to the
CPU) address register called a stack pointer register is used to address
the memory area which is software programmable to serve as the CPU stack.
The stack pointer register is generally the same size as the program
-counter-regis-ter.
Besides storing addresses for subroutine calls, the stack may also
serve as a data storage element. For example, in the 8080A, there are
"push" and "pop" instructions which provide for storage of the contents
of the various hardware registers. An instruction set possessing this
capability has a significant advantage over the ones that do not. Sup-
pose an external interrupt request occurs while the CPU is executing a
main program. Further, suppose the interrupt service routine may change
CPU register contents depending on which device issues the interrupt.
Without stack storage of processor status (contents of CPU registers),
the interrupt may have to be delayed until a point is reached in the
main program where loss of CPU status is not critical. With stack stor-
age of CPU status, the interrupt can be processed almost immediately
with processor status "pushed" onto the stack at the beginning of the
interrupt service subroutine and CPU status restored by "popping" the
stack at the end of the interrupt subroutine.
2-n
2.1.2.3 Accumulator and General Purpose Registers - One of the
operands used in ALU operations is generally the current contents of the
accumulator. The number of bits in the accumulator register is a good
indication of the characteristic word length of the CPU.
During an ALU operation, the accumulator register's contents and
some other register's contents are applied to the inputs of the ALU
[see Figure 2.1.1(1)]. The result of the operation is usually returned
to the accumulator via the internal data bus of the CPU.
In contrast to other operand registers which may be input to the
ALU, the accumulator contents are, in general, altered following the com-
pletion of an ALU operation. The accumulator is a source for operands
and, in most cases, also a destination for results. The buffer register
following the accumulator provides the temporary storage of the accumu-
lator register data while the ALU operation takes place. This allows
the result of the ALU operation to be returned to the accumulator.
Other hardware registers which serve only as a source or destina-
tion register (but not both simultaneously) are called general purpose
registers. Some microprocessor architectures do not provide general
purpose registers, thus requiring all ALU or other CPU operations to be
performed between accumulators, memory, and I/O only. Microprocessors
lacking general purpose registers often provide more flexible memory
addressing modes to allow single or double byte instructions to execute
ALU or other operations with different memory locations. In other
words, external memory is used for general purpose registers.
2.1.2.4 Instruction Register - The instruction register is used
for temporary storage of the instruction fetched from memory. At the
beginning of the instruction cycle (see Section 2.1.3), the instruction
is fetched from memory and loaded into the instruction register. The
word length of the instruction register is thus equal to the word length
of memory.
Corresponding to each particular operation the CPU must perform is
a unique code called the instruction or operation code. For an n-bit
2-12
machine, there are 2n unique instruction codes that could be used. Thus,
o
an eight-bit machine allows for up to 2 (256) unique instruction codes.
The codes are stored sequentially in memory and are fetched one by one
into the instruction register where they are stored during decoding and
execution of the instruction.
2.1.2.5 Address Registers - The stack pointer and program counter
are examples of special function address registers. Some CPU's have
other address registers which provide absolute memory pointers, relative
memory pointers, input port address pointers, and output port address
pointers.
In some CPU's, a general purpose address register may be used for
many functions. For example, the 8080A has two general purpose registers
(H and L) which are absolute memory address pointers; yet, they may also
be used for data storage, stack pointer storage, and even double preci-
sion shift left and add.
.Memory reference instructions require an address register to hold
the address of the memory location to be referenced by the instruction.
Sometimes this address register is loaded with an address fetched by;
memory as part of a multibyte instruction. Some CPU's such as the
Motorola 6800 provide an address index register which is used as an
indexed memory pointer. Data can be stored or retrieved from the address
specified by the index register plus or minus a fixed amount (relative
addressing).
2.1.3 Control Logic
The primary and most complex component of the CPU is the control
logic. The control logic provides the sequential signals that perform
the various processing tasks.
A necessary input signal to the control logic of all CPU's is a
master clock. Some microprocessors such as the MOS Technology MCS 6502
have an internal clock while others require an external clock. The
popular Intel 8080A used in the UT PDCP requires an external two-phase
clock.
2-13
Other inputs to the control logic include decoded instructions from
the instruction register, flags generated by previous ALU operations,
and external control signals such as interrupt, wait, or DMA (direct
memory access) requests. The function of the control logic is to take
all these input signals and output the necessary signals in the proper
sequence so as to execute the appropriate processing task.
The CPU operates in a cycle. That is, the processor fetches an
instruction, decodes the instruction, executes the instruction, fetches
the next instruction, etc. The master clock provides a reference timing
signal to synchronize the events in a processor cycle.
An instruction fetch, instruction decode, and instruction execution
is .often called an instruction cycle. The instruction cycle generally
requires one or more subcycles called machine cycles. Each distinct
function performed during a machine cycle is called a state. A state
generally requires one or more periods of the master clock. The first
state of every instruction cycle is an instruction fetch. During the
"instruction fetch state, the program counter provides the address of the
next instruction, and a memory read subcycle places the instruction
fetched from memory on the internal data bus. From the data bus, the
instruction is loaded into the instruction register. The instruction
remains in the instruction register throughout the instruction cycle.
Following the decoding of the instruction, cycle status information
is provided by the control logic. Cycle status signals indicate the
type of machine cycle that is to be performed. For example, the instruc-
tion cycle may be input/output (I/O), memory referencing (memory read or
write), internal CPU processing, or a combination of these.
Input/output cycles may not be provided by some microprocessors.
This class of microprocessors relies on a technique called memory-mapped
I/O. That is, input and output ports are treated like any other memory
location. Data sent to or from a memory-mapped I/O port appears to the
CPU to have been written into or read from memory. All microprocessors have
the capability of memory-mapped I/O. Those microprocessors providing
I/O cycles offer a second method to input and output data to and from
2-14
the CPU. The I/O cycle is flagged by I/O status bits following the
decoding of an I/O instruction. The I/O flag bits combined with the I/O
port address provide the signals to select the external I/O ports and
whether the operation is to be an input or output. Memory mapped I/O
uses memory read or write flag bits combined with reserved memory addresses
to operate the external I/O ports.
Memory reference subcycles are either memory read (data is returned
from memory) or memory write (data is stored in memory). Several machine
states are usually required to execute a memory reference subcycle. For
example, in a memory read subcycle status information is first provided
by the control logic, indicating a memory read cycle is to be excecuted.
Following status information, the memory address is sent to the external
address bus. At this point in the subcycle, depending on the capabilities
of the microprocessor, the memory read signal is issued or delayed if
necessary to allow for minimum memory access time. Finally, data is
returned from memory on the external data bus and routed to the appro-
priate destination register within the CPU.
For a memory write subcycle, the sequential operation is reversed
slightly compared to the memory read subcycle. In this case, the first
and second steps are similar; that is, status information is sent out by
the control logic indicating a memory write subcycle is to be performed.
Then, the memory address is placed on the external memory address bus.
The third step differs in that data (instead of a control signal) is
sent out by the CPU to the external memory data bus. Finally, the mem-
ory write signal is sent out by the control logic. Again, some micro-
processors provide a means to delay the memory write signal to allow for
minimum memory access time.
Microprocessors providing delay for slow memory or I/O have what is
called a ready control signal input and a special machine state called a
wait state. As long as the ready control signal input is true, CPU
operation takes place at full machine speed set by the CPU master clock.
Making the ready input false .temporarily freezes CPU operation while
retaining all CPU status. Usually, the ready input is checked just prior
2-15
to the memory or I/O, read or write control signal. Thus, address and
data are held constant while in the wait state. If memory or I/O is too
slow when the CPU operates at full speed, a wait-cycle generator can be
used to place the CPU in the wait state for a minimum period of time
required for memory or I/O access. Memory or I/O that is fast enough to
operate" with the CPU at full machine speed is said to be capable of
operating synchronously with the CPU. Memory or I/O which is not fast
enough and requires the CPU to synchronize with the external memory or
I/O cycle is called asychronous memory or I/O. Assuming the micropro-
cessor has a ready signal input, slow memory requires an external
wait-cycle generator to delay the appropriate read or write control
signal.
• The class of microprocessors that do not provide a wait state require
additional hardware to operate with asynchronous memory or I/O. First,
a circuit is needed to recognize the memory or I/O cycle. The problem
arises at this point as the only alternative to suspend CPU operation,
yet retain data on the address and data buses, is to provide external
address and data storage and place the CPU in DMA if indeed DMA is pro-
vided. A possible second alternative is to stop the CPU master clock.
Stopping the clock, however, is usually not a solution since many pro-
cessors are dynamic and internal status requires clock refresh cycles.
In practice, the clock pulse is stretched just long enough to allow the
memory or I/O access. The hardware to provide this operation is con-
siderably more involved than a wait-cycle generator circuit.
Using slow memory or I/O with a microprocessor may be possible
without any external wait-cycle generation circuitry. If the application
does not require the microprocessor to be run faster than the memory or
I/O access times, the CPU clock frequency can be reduced to meet memory
or I/O access times. This solution is applicable only if the minimum
CPU clock frequency requirement is met. For example, the Pro-Log MPS
system used in the UT PDCP (see Section 5.1) uses a 1.6666 psec state
time which allows the use of slow ROM without need for a wait-cycle
generator.
2-16
Internal processing subcycles generally require the least amount of
time (fewest number of states) to execute. Typical internal processing
cycles are register-to-register move, arithmetic operations between
registers, and increment a register's contents. Since the internal
operations involve only internal storage elements, no time is required
for access of external I/O or memory. The minimum cycle time specified
for a particular machine is usually the minimum time in which some simple
internal CPU operation can be performed. Minimum cycle time for a CPU
is not necessarily a good criteria for evaluation of a particular micro-
processor. Although the minimum cycle time of two microprocessors may
be the same, one may perform a larger function than the other during the
minimum cycle time.
As presented earlier, some instruction cycles may be a combination
of basic I/O, memory reference, or internal CPU operation subcycles.
For example, one instruction may involve reading data from memory and
adding the data to the internal accumulator register. Usually two
machine subcycles are required to perform an add memory to accumulator
type instruction. The first machine subcycle would fetch the add memory
instruction, decode the instruction, send out the memory address of the
data to be added, and fetch the data to an internal temporary storage
register. Several machine states would be required to perform this part
of the instruction. The second machine subcycle would be an internal
CPU operation subcycle which would be to input the accumulator and the
temporary storage register contents to the ALU; direct the ALU to add
the operands; and finally, place the result in a destination register
(usually the accumulator). Many combinations of machine subcycles can
be generated to perform various instruction cycles. The programming of
machine subcycles comes under the topic of microprogramming which is
discussed in Section 2.2.2.3.
Interrupt and hold control signal inputs are provided by most micro-
processors. An interrupt, as the name implies, allows temporary inter-
ruption of main program processing to allow for execution of some sub-
routine. The principle advantage of interrupt capability is evident
when using a peripheral much slower than the CPU. Suppose output to a
2-17
slow peripheral is required. Without interrupt provision, the processor
must wait for the slow output device. With interrupt capability, the
processor can be continuously processing, and when the slow output device
is ready to take data, an interrupt request is sent to the CPU. The
output routine to service the interrupt is executed, and the processor
returns to the main processing task. The CPU need never wait for a slow
peripheral.
The hold signal input provides just the opposite speed difference
capability. Suppose an external peripheral is capable of outputting or
inputting data faster than the CPU can process or generate data. If the
processor provides a hold cycle, data may be passed between memory and
the external device at a rate equal to the access time of the memory
plus the time required for the CPU to recognize a hold request. When
the control logic recognizes a hold request, the address and data buses
are placed in the tri-state mode (floating), and a flag is generated by
the control logic to indicate to the external circuitry that the address
and data buses are now available for use by the external device that
requested the CPU hold cycle. The external device may then address
memory directly and perform a memory read or write cycle independent of
the CPU. This operation is called direct memory access or simply DMA.
In PDCP applications, the data rate between CPU and sensors, or CPU
and the platform transmitter, is generally slow compared to the process-
ing speed of the microprocessor. Therefore, in PDCP applications, the
DMA or hold capability will probably not be required.
The only remaining topic of the hardware architecture of the micro-
processor that must be considered is the problem of system start-up.
All microprocessors have the capability to load the program counter with
some particular address upon the application of an external start-up
signal. This is equivalent to initiation of a program since the program
counter is loaded with the starting address of the program. Perhaps the
best way to discuss hardware start-up is through examples.
2-18
The 8080A microprocessor provides three techniques for initiating a
program. The most fundamental of these is application of an external
reset signal to the reset control signal input of the 8080A chip. The
control logic recognizes a reset request and places zero in the program
counter. All other CPU status is unchanged. Thus, a vectored start-up
to absolute address zero is performed. The problem with this method is
that either location zero must be the starting point of the start-up
program or the location must be preloaded with a jump instruction to the
desired location. If location zero is ROM, then on power-up, the system
may be started immediately with only a reset pushbutton required. If
location zero is volatile RAM, location zero must be preloaded. A fur-
ther complication results if all memory is volatile; in this case, a
short boot-strap loader program must be toggled in by hand, and system
start-up would include jumping to the boot-strap loader program which
loads the system program(s). Usually, the simple boot-strap loader is
used to load a more complicated loader with some sort of error checking.
The more complicated loader then loads the system program(s) and passes
control to the system program(s) at the conclusion of the loading
routine. One microprocessor, the RCA CPD 1802 provides a hardware
boot-strap. The CPD 1802 provides a special DMA cycle which permits
sequential memory loading starting at location zero.
The second and third methods of starting the 8080A series micropro-
cessors involve the interrupt capabilities of the device. There are
eight single-bit restart instructions which cause an unconditional call
to eight particular locations in memory (locations 0, 10, 20, 30, 40,
50, 60, and 70 octal). That is, the present value of the program counter
is saved in the stack, and the program counter is loaded with one of the
eight appropriate restart locations. All other CPU status is unaffected.
The restart 0 (restart to location 0) is similar to a reset, only addi-
tional hardware is required to jam the interrupt restart instruction onto
the data bus. Also, the stack is affected by the restart instruction.
The original 8080 provides only the reset and restart interrupt methods
of system start-up. The newer 8080A series of microprocessors permit a
three-byte instruction interrupt. That is, a three-byte instruction may
be jammed onto the data bus during the interrupt. This permits unlimited
2-19
vectoring of the program counter since a call or jump instruction can
specify a branch to any of the 2 (65,536) possible memory locations.
Of course, additional hardware is required to interrupt with three bytes
since three bytes must be presented sequentially to the CPU data bus
instead of only one.
Most microprocessors provide some sort of reset input that vectors
the program counter to a particular location although the location is
not always zero. The Motorola 6800 provides an interesting start-up
technique which differs from the three methods just described. The
desired program starting address is preloaded in the top two locations
of memory. The reset signal initiates a special machine cycle which
loads the program counter with the address stored in the top two memory
locations. The resulting operation is equivalent to an unconditional "
jump to the memory location specified by the contents of the top two
memory locations. Again, the top memory locations must be either
non-volatile or pre-programmed.
'272 '"MICROCOMPUTER-SOFTWARE "ASPECTS
A microcomputer must be programmed in order to perform a process
control task. In the case of a microprocessor!"zed DCP, the DCP system
algorithms must be converted into a set of instructions (the microcom-
puter program) that can be directly loaded into the system memory. The
process of converting system algorithms into machine executable instruc-
tions is often called coding.
As depicted in Figure 2.2(1), there are many levels of microcom-
puter coding. At the top of the scale are compilers and interpreters
such as FORTRAN, PL/1, and BASIC. These high-level languages are
machine independent in that a program written in any high-level language
can be executed on any machine which supports that particular high-level
language. For example, one could write a FORTRAN program to run on a
DEC PDP-11/45 and also execute the program on an Intel 8080A microcom-
puter with little or no change in the original FORTRAN source program.














Figure 2.2(1) Coding Levels.
2-21
Intermediate-level programming is a more complex process than
high-level programming. An assembly language programmer must have a
thorough knowledge of the particular microprocessor's instruction set
and a complete understanding of the particular microcomputer's hardware
architecture. Assembly language programming is called machine dependent
programming since instruction sets vary greatly from one microprocessor
to another.
At the bottom of the coding scale is low-level programming. Machine
language programming is extremely time consuming and should generally be
avoided. Machine language programming is the process of hand loading
the machine binary digits representing the various instructions the pro-
grammer wishes the CPU to perform. The binary digits are literally
"toggled in" from a switch register or typed in as numbers from a key-
board. This process requires considerable time and effort from the
programmer. Machine coding should not be required for PDCP applications
since assembly language programs are available for most current micro-
processors. The UT PDCP system described in Section 4 provides machine
level coding capabilities as well as simplified symbolic assembly lan-
guage programming.
The most basic level of microcomputer coding is a highly machine
dependent technique called microprogramming. Microprogramming is some-
times referred to as the bridge between hardware and software [8].
This is because a microprogram consists of the control words used to
decode machine instructions (software) into machine operations (hard-
ware). The microprogram resides in the control storage element of the
CPU. The control storage device is either a read only memory (ROM) or
programmable logic array (PLA). Some microprocessor manufacturers allow
the user to specify the microprogram. Since the microprogram defines
the instruction set of the microprocessor, this allows the user to develop
the optimal software structure for a particular application.
In addition to programming languages, the microcomputer programmer
requires several utility programs to complete the programming task. A
text editor program is useful in preparing the source code of a program.
2-22
Source code is the name given to the human readable program. Source
code is compiled or assembled into equivalent machine executable object
code. Another required utility program is a loader which is used to
load the object code output of a compiler, interpreter or assembler pro-
gram directly into the microcomputer memory. Finally, debugging and
simulator programs aid in testing the object program. The remainder of
this section provides a more detailed description of the software aspects
of the microcomputer.
ii.
2.2.1 Microcomputer Instruction Sets
A microcomputer instruction provides the binary information required
by the control logic of the CPU to perform a particular processing task.
According to Weiss [9], microprocessor instructions can be conveniently
grouped into four basic categories:
1. Data Movement
2. Data Manipulation
3. Decision and Control
4. Input/Output
Data movement instructions control the movement of data from
register-to-register, register-to-memory, memory-to-register, and
memory-to-memory. Figure 2.2.1(1) graphically illustrates possible
sources and destinations for data movement. Note that data flow to and
from input/output ports is also depicted in Figure 2.2.1(1). Input/out-
put data movement is a special case of the general class of data move-
ment instructions.
Data manipulation instructions provide arithmetic and logical
operations on data. Arithmetic instructions include add, subtract,
multiply, divide, and increment/decrement. Typical logical operations
are logical AND, OR, exclusive OR, complement, compare, and rotate/shift.
All microprocessor instruction sets provide the basic binary add instruc-
tion. If other data manipulation instructions are required but are not
included in the instruction set, the needed instructions can usually be























Figure 2.2.1(1) Data Movement in the Microcomputer.
2-24
Microprocessors execute instructions in a sequential manner unless
otherwise directed by a decision and control instruction. Non-sequen-
tial alteration of the program counter is a result of the execution of a
conditional or unconditional jump, jump to subroutine, return from sub-
routine, or skip instruction. Unconditional jump or call instructions
are sometimes called branch instructions. Also, some authors prefer
the use of the simpler term "call" to indicate a jump to subroutine type
instruction.
The choice of input/output device interfacing depends largely on
the nature of the input/output instructions provided by the particular
microprocessor. Many microprocessors provide no formal input/output
instructions. Instead, memory referencing instructions must be used
with a technique called memory-mapped I/O (see Section 2.1.3), Input/
output instructions provide data transfer between the microcomputer and
external I/O devices.
An explanation of the instruction set of a particular microprocessor
'can"general"ly be 'found In the user's manual published by that micropro-
cessor's manufacturer. A complete description of the Intel 8080A
instruction set used in the UT PDCP development system is contained in
the Intel 808QA User's Manual [10]. A copy of the Intel 8080A User's
Manual is included with the UT PDCP System Operation Manual.
Microcomputer instructions are similar to typical minicomputer
instructions. The major difference is that the execution speed of
instructions is generally much faster for a minicomputer. Recent tech-
nological advances, however, are narrowing this speed gap. Since the
form and resulting operations of microcomputer instructions are similar
to minicomputer instructions, texts and papers discussing general mini-
computer instruction sets are applicable to microcomputer instructions.
References 9, 11, and 12 provide excellent discussions of typical mini-
and microcomputer instruction sets.
Microcomputer instructions sets vary considerably from manufacturer
to manufacturer. The ability of a particular microprocessor to effi-
ciently implement a PDCP is primarily a function of that particular
2-25
microprocessor's instruction set. Evaluation of the microprocessor's
instruction set must be a primary consideration in the selection of a
particular microprocessor for a PDCP design. As a result of the soft-
ware development incorporated in this study (see Section 4), certain
types of instructions appear to be highly desirable for PDCP applica-
tions. Choosing a microprocessor that contains as many of the desirable
instruction types as possible will result in reduced memory costs due to
more efficient coding. These desired instruction types are given higher
weighting factors in the microprocessor evaluation presented in Section
6 of this report.
2.2.2 Microcomputer Programming
As indicated at the beginning of Section 2.2, the procedure for
converting process control system algorithms to machine executable
instructions is often called coding. Efficient coding requires a well
structured algorithm. Flowcharting is a useful technique for reducing
the algorithm to a form which can easily be converted to a computer
program. The'flow chart is a graphical representation of the distinct
operations required to implement the computer program. Numerous
examples of program flowcharting appear throughout Section 4 of this
report. Typical flow chart symbols are presented in Figure 2.2.2(1).
Once the flow chart for a program is developed, the programmer proceeds
to implement each block of the flow chart using an appropriate program-
ming language.





The first two tools are programs that are actually run on the particular
microcomputer (resident program) or on some other computer (cross program-













THAT CAUSE THE PAR-
TICULAR PATH FOLLOWED
I REPRESENTS THE STARTING OR
V ENDING POINT OF THE PROGRAM
V
REPRESENTS A CONNECTION
POINT BETWEEN TWO OR




Figure 2 .2 .2 (1 ) Typical Flow Chart Symbols.
2-27
Sections 2.2.2.1 and 2.2.2.2, respectively. The third tool, micropro-
gramming, is discussed in Section 2.2.2.3 of this report.
2.2.2.1 Programming Languages - Programming languages are con-
veniently grouped into three classes [see Figure 2.2(1)]:
1. High-level languages (compilers and interpreters)
2. Intermediate level languages (assemblers)
3. Low-level languages (machine language^and microprogramming)
High-level languages include compilers and interpreters such as FORTRAN,
PL/M, COBOL, FOCAL, or BASIC. Al-1 five of these languages are currently
available for one or more microprocessors. For example, the Intersil
6100 will support all software available for the DEC PDP-8E minicomputer
including FOCAL, BASIC, COBOL, and FORTRAN. The Intel 8080A used in the
UT PDCP development system is supported by FORTRAN, PL/M, BASIC,
FOCAL, and COBOL. The significant advantages of high-level programming
are machine independence and a reduction in programming time. High-level
languages can reduce programming time by 50 to 80 percent. Also, exist-
ing high-level language programs can be recompiled to run on a micropro-
cessor which supports the particular high-level language used. The
high-level programming languages were each developed for particular
programming tasks. FORTRAN is designed primarily to solve mathematical
problems and thus may be useful for PDCP data processing. COBOL, however,
is a business oriented language and would have little application in the
PDCP field. PL/M, a microprocessor compiler originated by Intel, is a
subset of IBM's powerful PL/1 compiler. PL/M provides instructions
oriented toward commercial control and scientific problem solving.
BASIC is an interpretive language in that each line of source code is
compiled as the program executes. BASIC requires a relatively large
amount of memory to execute even short programs. This is because the
BASIC source program and the BASIC interpreter program must both be
resident in memory during program execution. A compiler differs from an
interpreter in that the final compiled program is machine executable
object code. The compiler is not needed once the object code is
2-28
generated. Finally, FOCAL is a language which was developed by Digital
Equipment Corporation to fill the gap between BASIC and FORTRAN. Like
BASIC, FOCAL is an interpretive language that requires considerable
memory overhead to run even short programs. Neither BASIC nor FOCAL are
recommended for potential PDCP application due to their high memory
requirements.
The principle disadvantage of using any high-level language for
PDCP programming is the inefficiency of the compiled object code.
Another significant disadvantage is inadequate input/output flexibility.
Also, program execution times are generally unknown and uncontrollable.
PDCP software timing routines require precise knowledge of the number of
machine states required to execute various subroutines. Even interrupt
timing techniques (see Section 4) require knowledge of execution times.
In this case, worst case execution times must be known to guarantee that
the subroutine will be completed within the alotted time span.
Assembly languages are intermediate level languages. An assembler
translates symbolic machine instructions or mnemonics directly into
machine executable object code. A mnemonic is a short form symbolic
name given to each instruction in the instruction set of a particular
microprocessor. Mnemonics used to represent instructions vary greatly
from manufacturer to manufacturer. This is due to the wide variation in
microprocessor instruction sets. Since microprocessor instruction sets
vary from machine to machine, assembly language programming is machine
dependent. A primary disadvantage of assembly language programming is a
direct result of the variation of instruction sets. The microcomputer
programmer must be thoroughly familiar with the instruction set of the
machine to be programmed. Furthermore, efficient assembly language
programming requires complete understanding of the particular microcom-
puter's hardware architecture.
Many types of microcomputer assemblers are available. Cross assem-
blers are run on a machine other than the microcomputer for which the
program is written, whereas resident assemblers are run on the machine
for which the program is written. All assemblers translate symbolic
2-29
instructions to their equivalent object code. Several additional fea-
tures are often found on current microcomputer assemblers. The most
useful feature is a provision for symbolic addresses and constants.
These symbolic names and labels can be used to represent address and
data constants. This feature reduces programming errors by freeing the
programmer from the burden of keeping track of absolute addresses and
constants. Some assemblers even provide algebraic manipulation of
address and data expressions. Recognition of pseudo assembly directives
is provided by most assemblers. For example, the pseudo directive "END"
informs a typical 8080A assembler that the location of the END directive
marks the end of the source code to be assembled. Macroassemblers
usually provide for all the above features plus the assembly of macro-
instructions. A macroinstruction is a single line instruction used to
represent a multi-instruction sequence. This feature supplies some of
the programming simplicity of a high-level language since a single line
of source code can replace many machine instructions. Note, however,
that assembly language efficiency is retained. Other features provided
by some microcomputer ..assemblers, .include..conditional assembly directives,
relocation and linkage of multiple program segments, optional assembler
listing formats, and loading of object code output directly into memory
or to some external storage device for later loading into memory.
Microcomputer assemblers are quite similar to typical minicomputer
assemblers. References 13 and 14 provide general discussions of typical
mini- and microcomputer assemblers.
2.2.2.2 Utility Programs - Once a program has been written and
translated to object code, the object code must be loaded into the sys-
tem memory and the program must be checked for correct operation. A
loader program is used to load the object code directly into memory. A
loader program is not required when using a programming language that
outputs object code directly to memory. This feature is provided by
some microprocessor assemblers. Certain high-level languages do not
have object code output (such as BASIC). In this case, a loader is
required to enter the source code. Several types of program loaders are
available for current microcomputers. The simplest is a boot-strap
loader. The boot-strap loader-program is purposely very short and
2-30
provides none of the error checking or other advanced features typical
of the more complex general purpose loaders. A simple boot-strap loader
could be used to load any program; however, the boot-strap loader is
typically used to read a more sophisticated loader. Control is then
transfered to the second loader which usually provides error-checking
and automatic program start-up following'the loading process. Unless a
machine has non-volatile memory pre-programmed with a loader, the pro-
grammer.must manually load a boot-strap loader program to initiate sub-
sequent program loading. The UT PDCP development system includes an
error-checking cassette loader routine as an integral part of the system •
monitor program (see the System Operation Manual). The loader routine
is stored in PROM (programmable read only memory) and is available to
the user at all times.
Once a user program is loaded into memory, the program can be
executed and checked for correct operation. If the program runs cor-
rectly, the software task is complete. Typically, however, programs
contain "bugs" which prevent correct operation of the program. The bugs
mus'fbe removed by a technique called program debugging. Microcomputer
programs which allow examination and alteration of memory contents to
assist the programmer in debugging and correcting the program are avail-
able. Often these programs include a routine which will print the CPU
status (register contents). Breakpoints may be set in memory to tempo-
rarily suspend program execution when a specified point in the program
is encountered. Thus, breakpoints permit the programmer to examine CPU
status and memory at any point of program execution. This enables the
programmer to debug the program in.small sections. As bugs are found,
they are corrected, if possible, by altering the instruction sequence in
memory. Often the programmer will initially insert "no operation"
instructions throughout an untested program. This provides memory space
between the original program instructions so that additional instructions
can be inserted if they are required. The UT PDCP system monitor con-
tains extensive program debugging aids.
A simulator program provides a very powerful technique for testing
and debugging a microcomputer program. A simulator program, as the name
2-31
implies, simulates the operation of the microcomputer. Program develop-
ment and testing is simplified by using a large computer system supported
by peripherals such as a video display terminal, a high-speed line
printer, and a disk drive. The full potential of a simulator can only
be realized by using such a developmental system.
The simulator provides the basic function of program instruction
tracing. That is, the result of executing each instruction can be dis-
played and verified by the programmer. Any discrepancy between what the
program actually does and what the programmer feels should be happening
is immediately evident. The programmer can then patch the program to
correct errors as they are found. The process continues until the pro-
gram runs without error. Some simulators provide additional features
such as counting machine states required to execute a program segment,
optional tracing and listing modes, and simulated memory examination and
alteration. Final program verification must be performed on the actual
PDCP system since the simulator cannot verify correct operation of I/O
and control interfacing. For example, external A/D conversion may be
dependent on software timing which must be verified on the actual PDCP
hardware system. Full simulator potential plus final checkout could be
achieved simultaneously by using a microcomputer development system that
includes the same hardware interfaces that are used on the PDCP system.
2.2.2.3 Microprogramming - A microprogram is an integral part of
the control logic of most microprocessors. In a microprogrammed control
unit, the numerous individual operations required to execute each
instruction cycle are defined by microinstructions fetched from a
read-only-memory or a programmable logic array. Therefore, each macro-
instruction written by a user is actually executed by a microprogram,
and the instruction set of the microprocessor is defined by the set of
microprograms stored in the CPU control unit read-only-memory.
Some microprocessor organizations are designed to permit users to
specify the microprogram. These microprogrammable microprocessors offer
users the potential advantage of defining an optimal instruction set for
their particular application. Microprogramming essentially extends the
advantages of programmed logic one step further down the quantum ladder.
2-32
The constraint of a predefined instruction set is removed leaving only
the basic constraints imposed by the hardware architecture of a partic-
ular microprocessor.
The PDCP software development portion of this study (Section 4)
provides some insight into the problem of defining an optimal microcom-
puter instruction set for a PDCP. In Section 4.3, the potential contri-
butions of microprogramming to the development of block operator
subroutines for the library of an applications-oriented software devel-
opment system are outlined. General microprogramming concepts are
discussed in References 8, 15, 16, 17, 18, and 19.
2-33
REFERENCES
1. Lewis, D. R., "Microprocessor or Random Logic," Electronics Design
]J5, September 1, 1973.
2. Electronics Staff, "Diverse Industry Users Clamber Aboard the
Microprocessor Band Wagon," Electronics, July 11, 1974, pp. 81-108.
3. Altman, L., "Single-Chip Microprocessors Open Up New World of
Applications," Electronics, April 18, 1974, pp. 81-87.
4. Smith, H., "Impact of Microcomputers on the Designer," 1973 WESCON
Technical Papers, Session 2.
5. Morris, J. H., Patel, H., and Schwartz, M., "Scamp Microprocessor
Aims to Replace Mechanical Logic," Electronics, September 18, 1975,
pp. 81-87.
6., Chung, D., "Four-Chip Microprocessor Family Reduces System Parts
Counts," Electronics, March 6, 1975, pp. 87-92.
7. Weissberger, A. 0., "Microprocessors Simplify Industrial Control,"
Electronic Design 22, October 25, 1975, pp. 96-99.
8. Galey, J. M., "Microprogramming: The Bridge Between Hardware and
•Software," Computer, -August 1975, -Vol. 8, 'No. -8, p. 23.
9. Weiss, C. D., "Software for MOS/LSI Microprocessors," Electronic
Design 7, April 1, 1974, pp. 50-57.
10. Intel 8080 Microcomputer User's Manual, July 1975, pp. 4-1 to 4-15.
11. Mano, M. M., Computer Logic Design, Prentice-Hall, Inc., Englewood
Cliffs, New Jersey, pp. 326-377.
12. Korn, G. A., Minicomputers for Engineers and Scientists, McGraw-Hill,
New York, New York, pp. 44-63.
13. Korn, G. A., Minicomputers for Engineers and Scientists, McGraw-Hill,
New York, New York, pp. 206-213.
14. Weiss, C. D., "MOS/LSI Microcomputer Coding," Electronic Design 8,
April 12, 1974, pp. 66-71
15. Jones, L. H., "A Survey of Current Work in Microprogramming,"
Computer, August 1975, Vol. 8, No. 8, pp. 33-37.
16. Broadbent, J. K., "Microprogramming and System Architecture," The
Computer Journal, Vol. 17, 1974, pp. 2-8.
2-34
17. Cox, G. W. and Schneider, V. B., "On Improving Operating System
Efficiency Through Use of a Microprogrammed, Low-Level
Environment," Preprints, Micro 7, pp. 297-298.
18. Montangero, C., "An Approach to the Optimal Specification of
Read-Only Memories in Microprogrammed Digital Computers," IEEE -
Trans. Computers, Vol. C-23, April 1974, pp. 375-387.
19. Vandling, G. C. and Halddecker, D. E., "The Microprogram Control
Technique for Digital Logic Design," Computer Design, August 1969,
pp. 44-51.
3. PDCP SYSTEM HARDWARE
PDCP system hardware must be designed to satisfy the constraints
imposed by the remote data collection application. Typically, design
goals include minimizing power consumption, weight, maintenance, and
cost while providing accurate and reliable operation. As illustrated
in Figure 3(1), DCP hardware can be partitioned into three systems con-
sisting of the sensors, the digital control logic, and the transmitter.
This section discusses the influence of microprocessor technology on the
design of each system of a PDCP. In addition, standards which could
promote lower PDCP costs are recommended, and the development of a stan-
dard, modular PDCP design is proposed.
3.1 SENSOR CLASSIFICATION AND INTERFACING
The most variable elements in data collection systems are the sen-
sors. With measurements being made in such diverse fields as agriculture,
ecology, hydrology, and search and rescue, many types of sensors must be
.accommodated by the data collection platform. A signal conditioner is
generally placed between the sensor output and the DCP to convert the
sensor output to a standard electrical signal which is compatible with
the DCP. In previous systems, this signal has been a voltage, a fre-
quency, or a digital logic level depending upon the particular design of
a data collection platform telemetry system. For programmable data col-
lection platforms, the ideal interface occurs at digital logic levels.
For analog sensors, an analog-to-digital converter is required as a
signal conditioner. The sensor interface is then made at the input to
the analog-to-digital converter.
3.1.1 Sensor Classification
User requirements have been documented in recent studies [1].
Table 3.1.1(1) gives a list of the disciplines which have a need for
data collection by satellite. Table 3.1.1(2) provides a list of para-























Figure 3(1) DCP Hardware Subsystems.
3-3
TABLE 3.1.1(1)




































































































































































































































































sensor could be utilized. Among this list are sensors which have already
seen service in satellite data collection systems. A typical group com-
posed of hydrology sensors is listed in Table 3.1.1(3) along with their
signal conditioner outputs. While the direct output of each sensor may
be a measurement in volts, amperes, or ohms with nonlinear and suppressed
zero scales, the signal conditioners have conveniently translated the
output ranges to lie between zero and plus five volts.
3.1.2 Sensor Interfacing
A number of sensors already exist which could interface directly
with a programmable data collection platform including those in Table
3.1.1(3) with the addition of an analog-to-digital converter. Some
sensors include their own signal conditioning equipment which converts
the basic sensor output to a digital logic level. For example, the
temperature sensor in the TWERLE experiment converts the measured tem-
perature to a frequency output. A counter measures the number of cycles
of this frequency over a fixed period; the contents of the counter regis-
ters -are a digital representation of-the-temperature value.
Two basic classes of signal conditioners will probably be required
in a PDCP system. One class converts the non-standard basic sensor
output to a standard output. This will normally be the responsibility
of the sensor designer. A second class of signal conditioners converts
the standard output to digital logic levels which are compatible with
the microcomputer. In many cases, the second class of signal condi-
tioners will be time-shared between a number of sensors and would be
provided as a standard module by the PDCP designer. Of course, a direct
conversion of the basic sensor output to a logic level is very desirable
since this eliminates the need for the second class of signal condi-
tioners; however, the second class of signal conditioners will be
required to utilize existing sensors. Fortunately, these signal condi-
tioners convert from a standard input to a standard output; therefore,
their cost is low.
3-10
TABLE 3.1.1(3)
TYPICAL SATELLITE DATA COLLECTION SENSORS
Signal Conditioning Output
Sensor Specification
Dissolved Oxygen 0.0 to +5.0 Volts dc
pH 0.0 to +5.0 Volts dc
Specific Conductance 0.0 to +5.0 Volts dc
Temperature 0.0 to +5.0 Volts dc
3-11
3.1.2.1. Sensor Interface - Little can be said about the basic
sensor output since this can be almost any variable. The sensor signal
conditioner takes this output and converts it to a standard output.
Tradit ional ly, for analog sensors this output has been zero to plus five
volts dc. Another standard range for low-voltage or low-current devices
has been zero to 50 mi l l ivo l t s dc. If at this point in time a recommend-
ation were to be made for a standard output range for analog sensors,
it would have to be zero to p lus five volts. This, however, may present
a problem if some of the newer technologies are used in fabricating the2
microprocessor. The integrated injection logic (I L) technology (see
Section 6.1) can operate at voltages lower than one volt , and operating
the signal conditioner from the same power supply voltage would be advan-
tageous. This would require a low-voltage output from the signal
conditioner.
As previously mentioned, some sensors produce a digi ta l output directly.
The analog-to-digital .conversion process may be bui ' l t into the sensor. The
output of such a sensor should have an interface compatible wi th CMOS logic.
In c o n t r a s t to the analog output of zero to p lus five volts dc, the
digital sensor output should be as follows: a zero would be represented
by a level between zero and 0.8 volts, and a logical one would be repre-
sented by a level of 3.5 to 5 volts dc. Unt i l more experience is gained
2
with I L devices, the above specification foi
sensor would be a reasonable recommendation.
i   h  cation r the output of the digital
3.1.2.2. Microprocessor Interface - The second level of signal con-
ditioning converts the standard interface signals to signals which match
the logic characteristics of the microprocessor. The most common signal
conditioner of this type is the analog-to-digital converter (ADC). This
device takes a zero to plus five-volt dc analog signal and converts it
to an equivalent digital word. For the PDCP application, the ADC output
should be coded in natural binary at CMOS compatible logic levels. A
parallel output word will generally be required for direct interface to
the microprocessor data bus. However, in some applications where the
ADC and sensor must be located in an area remote from the PDCP a clocked
serial output is desirable to minimize the number of wires required for
the data link. Both the parallel and serial outputs should be three-
state outputs to permit the signal lines to be shared with other devices.
3-12
In a three-state device two states are the usual high or low output
(input) states. A control signal converts this output (input) to a
high impedance state effectively removing the device from the bus.
Suitable low-power CMOS-logic ADC's which would interface directly to
the bus of a CMOS microprocessor-based PDCP are commercially available.
Similar to the analog-to-digital converter is the frequency-to-
digital converter which is needed by sensors having an output frequency
proportional to the measured variable. This conversion of frequency to
a digital signal can be performed by the microprocessor with no external
hardware. Using the Intel 8080A-1 microprocessor, sensor frequencies
up to approximately 20 kilohertz can be digitized. The frequency-to-
digital conversion capability of the microprocessor provides a low cost
interface to a variety of sensors since most sensor outputs can conven-
iently be produced as a frequency.
A big advantage in interfacing the microprocessor with a set of
sensors is that sensors with different resolution requirements can easily
be accommodated. For example, one sensor may require a resolution of
eight bits and another require a resolution of sixteen bits from a time-
shared ADC. For the eight-bit resolution sensor only the eight highest-
order bits need to be multiplexed from the ADC while the whole sixteen
bits of the high resolution sensor would be transferred to the micro-
processor. This is easily accomplished through program control.
3.2 DIGITAL CONTROL LOGIC AND MEMORY
In current DCP designs, the digital control system is generally a
hardwired logic circuit manufactured with standard CMOS integrated cir-
cuits. Because of the cost and complexity of the random logic design,
control functions are limited to elementary sensor control, data format-
ting, and transmitter control. A microprocessor-based PDCP will be
capable of performing additional tasks such as data compaction and data
preprocessing without excessive cost increases (see Section 4).
A block diagram of a microprocessor-based PDCP control system is
illustrated in Figure 3.2(1). The number of integrated circuits




Z3 O. i-i —.
0. t- > >-•








o to o: s:
o uj o «t












ct to t— ;D
I— oo >-i o.














































ments, memory requirements, and the microprocessor architecture.
Already, two-chip microprocessor sets containing a clock circuit, 64
bytes of RAM, 1024 bytes of ROM, and several input/output ports are
available. Thus, a minimal PDCP control system may require as few as
two integrated circuits.
Future DCP user requirements are expected to range from basic plat-
forms capable of performing the tasks of current DCP's through advanced
platforms capable of extensive data preprocessing and data compaction.
From the standpoint of economics, a standard, universal DCP design is
desirable. This goal is impractical for a random logic design but is
practical for a microprocessor-based PDCP design. As illustrated in
Figure 3.2(1), the microprocessor-based PDCP control system organization
is based upon address, control, and data buses. This organization pro-
duces a system which is modularly expandable. A basic PDCP capable of
replacing current DCP designs will utilize all of the functions shown
in Figure 3.2(1). An advanced PDCP with extensive data compaction capa-
bilities will utilize the identical functions. The distinction between
these systems will be the amount of ROM, RAM, and I/O provided and their
software organizations. Section 4 demonstrates that a unique PDCP soft-
ware organization can be defined for each user by plugging a different
ROM into the system. Thus, a PDCP design which will function efficiently
as a basic DCP but which can easily be expanded to form an advanced
processing PDCP can be developed.
Physically, the standard PDCP design could be implemented as a modu-
lar set of printed circuit (PC) boards. A basic PDCP system would prob-
ably require one or two small PC boards. The system could be expanded
by adding extra integrated circuits in spaces provided on the basic PC
card set. Large scale expansion would involve adding standard memory or
I/O cards and, possibly, bus driver circuits. This implementation of
the standard PDCP design would provide most potential users with the
capability they require at a minimum cost since the design and develop-
ment expenses could be prorated. If a potential user did require a
unique PDCP construction, the electrical design would not necessarily
have to be changed. Additional PC board development cost would be
incurred, but additional circuit design cost would not be incurred.
3-15
3.3 TRANSMITTER, RECEIVER, AND ANTENNA
Section 4.4.3 demonstrates that a microprocessor-based PDCP can
easily control transmitter modules which have been developed for current
DCP designs. Transmitter control inputs should be digital signals com-
patible with the technology chosen for the PDCP control system. Other-
wise, no constraints are imposed upon the electrical design of trans-
mitters and antennas for PDCP's. Traditional design techniques are
satisfactory.
Since the sensor interface and digital control systems of a PDCP
will be developed as modular PC board sets, the transmitter system
could be similarly designed. One approach is to provide individual
transmitter modules designed specifically for each data transmission
technique. The PDCP user could then customize the modular system by
selecting a transmitter module (Landsat, GOES, TWERLE, or TIROS-N), a
basic or expanded control module, and various sensor interface modules.
For data collection platforms installed near land lines, a telephone
modem module could be chosen instead of a specific transmitter module.
A better approach would be to utilize the flexible nature of
the microprocessor to control a single modulator which can emulate
the modulation of all of the data collection systems. A standard
PDCP system will be capable of operating with all current data trans-
mission formats under software control by using the techniques demon-
strated in Section 4.4.3. As a result, a universal transmitter design
that can switch between the various data transmission modes under
software control could be designed. The required carrier frequencies
might be developed from a standard frequency reference by a phase-locked
loop containing a programmable frequency divider. This system would
eliminate the requirement for multiple transmitter modules and would
be more adaptable to any future changes in data transmission techniques.
A further study will be required to determine the potential cost effec-
tiveness and performance of the two transmitter construction techniques
outlined above.
3-16
Some DCP's have been developed with receivers for remote command
applications. A PDCP with this capability can be produced by adding a
receiver module to the system. The receiver should be interfaced to
the PDCP buses at standard logic levels. PDCP software can be devel-
oped to. poll the receiver and decode the command signals as they are
received. Alternately, the receiver can provide a signal to the
interrupt line of the microprocessor to indicate that a command signal
is being received. The microprocessor would then suspend data processing
operations temporarily to input and decode the control message.
3.4 SUMMARY
The problem of standardization of sensor output and microprocessor
input is a difficult one to solve; however, attempts should be made
towards standardization to reduce the types of signal conditioners
required.
It is recommended that new designs for analog sensors have outputs
which are 0.0 to +5.0 volts dc. The recommendation for digital interface
for CMOS logic is zero to 0.8 volts for a logical zero and 3.5 to 5 volts
dc for a logical one.
3-17
REFERENCES
Wolfe, E. A., Cote, C. E., and Painter, J. E., Satellite Data
Collection User Requirements Workship, NASA - Goddard Space Flight
Center, Greenbelt, Maryland, May 21, 1975.
4. PDCP SYSTEM SOFTWARE
As demonstrated in Section 2, significant advantages can often be
obtained by replacing a hardwired circuit with a software-controlled
microprocessor system. The potential advantages of a programmed logic
system arise from substitution of relatively inexpensive software stor-
age for complex hardwired circuits. Therefore, the flexibility and cost
effectiveness of a PDCP will be highly dependent upon the system soft-
ware and the extent to which PDCP functions can be software controlled.
Unfortunately, system constraints can preclude the use of programmed
logic, and, as shown in Section 2, the cost of developing special pur-
pose software for low quantity applications can.be excessive. This
section will demonstrate that microprocessors are capable of performing
PDCP tasks and describe a potential PDCP software package organization
designed to minimize software development cost. Included also are dis-
cussions of the effects of various PDCP system constraints on the soft-
ware package and descriptions of subroutines which have been developed
.for.typical PDCP applications.
4.1 PDCP SOFTWARE ORGANIZATION
Standardization is the key to minimum PDCP system cost. However, a
PDCP design must be sufficiently flexible to operate efficiently with a
number of different sensors, data compaction techniques, and data trans-
mission formats. In addition, a software system organization which pro-
vides a simple technique by which individual experimenters and organiza-
tions can create special purpose PDCP programs is desirable. The PDCP
software system organization outlined in Figure 4.1(1) is designed to
meet these goals.
A PDCP software package based on the organization proposed in Figure
4.1(1) would contain an executive program and a number of called sub-
routines. The executive program controls the operation of the PDCP by
executing a set of conditional and unconditional calls to various sub-







































RAW DATA FROM MEMORY
<
- ^ PREPROCESSED DATA TO
MEMORY
RAW DATA FROM MEMORY
PREPROCESSED DATA TO
MEMORY
RAW DATA FROM MEMORY
PROCESSED DATA TO MEMORY
PROCESSED DATA FROM MEMORY
CONTROL TO TRANSMITTER
ENCODED SERIAL DATA TO
TRANSMITTER
Figure 4.1(1) PDCP Software System Organization.
4-3
each different application. Major subroutines called by the executive
program control the sampling of a raw sensor data, preprocessing of raw
data, special computations, and data transmission to the satellite. The
executive program and major subroutines share multipurpose minor sub-
routines such as software delay loops. Standard sensor data input, gen-
eral purpose data preprocessing, and transmitter control routines can be
provided to users as firmware ROM options for the PDCP. Using this
approach, most PDCP software development costs can be prorated over a
large number of PDCP's so that the effective software cost will be mini-
mal. The additional program development required for new PDCP software
systems could generally be restricted to an executive routine and, when
necessary, special purpose subroutines. Since complex control and data
processing tasks would generally be controlled by subroutines, the cost
of developing executive programs should be low. Special subroutine
development costs can be minimized by maintaining a user program library.
4.2 PDCP SYSTEM TIMING
The program organization proposed above is independent of the vari-
ous system constraints imposed upon PDCP software and the actual tech-
niques used for program development. The major PDCP system constraints
which will affect software development is timing. In many cases, the
usual goal of minimum execution time will apply to data preprocessing and
special purpose subroutines. In general, however, sensor control and
transmitter subroutines will require precise timing between specified
events, and the total elapsed time between data transmissions should be
precisely controlled. These constraints must be considered during PDCP
software system development.
Software and interrupt timing are the two basic techniques which
can be employed to insure correct PDCP transmission intervals. The micro-
processor and associated support logic must operate continuously if soft-
2
ware timing is employed. For low power CMOS or I L devices, this is not
necessarily a disadvantage since maximum throughput can be obtained with
a continuously operating system. In addition, however, the precise
execution time for each PDCP software routine must be known, and provi-
sion must be made for holding the total program execution time between
4-4
transmissions constant. Most programs contain various mutually exclusive
branches which may require different execution times. As a result, delay
must be inserted within certain program branches to equalize execution
times. Alternately, program execution time can be allowed to vary if
each time the subroutine is called a flag is set to indicate the actual
execution time. The executive program may then use any excess time to
call optional subroutines (for example, system maintenance or low pri-
ority data input routines) and a variable delay subroutine. Although
average throughput can be increased using this technique, worst-case
throughput is not necessarily improved. The major advantage of software
timing is that neither an interval timer nor interrupt logic is required.
Interrupt timing can be relatively independent of system software
but requires the use of an external interval timer and interrupt logic.
The microprocessor can be powered-down between transmissions or operated
continuously. Worst-case execution time for each subroutine must be
known in order to guarantee that the microprocessor will either complete
data input or processing before a new .transmission is required or will
be executing an interruptable routine. In the event that the transmis-
sion request interrupt is allowed to occur before data processing has
been completed, the programmer will have the choice of discarding unpro-
cessed data or completing the processing at the conclusion of the trans-
mission sequence.
Assembly language programming can be used to develop subroutines
utilizing either interrupt or software timing. Programs written in
assembly language generally provide maximum performance while requiring
minimal storage area. Efficient assembly language programming, however,
requires a thorough knowledge of the available instruction set and
entails the highest development cost per program. Subroutines which
require precise internal timing, and general purpose subroutines which
will be included in firmware ROM packages provided to PDCP users should
be written in assembly language. This will insure precise timing and
minimal program storage area. Unfortunately, assembly language program-
ming cost for small-quantity, special-purpose systems could be excessive
and should be avoided when possible.
4-5
The development of many types of numeric data processing subroutines
could be simplified by using a high-level language such as PL-1, FORTRAN,
COBAL, or BASIC. Each of these languages is represented by a compiler
written for at least one microprocessor. The major disadvantages of
these languages are inadequate input/output structures, inefficient mem-
ory utilization, and poorly defined timing. Subroutines written using
these high-level languages cannot be used in a PDCP software system which
relies upon software timing unless the resulting machine code is investi-
gated to determine all possible execution times. Even for an interrupt-
timed system, the maximum execution time of the subroutines must be
determined to insure that processing can be completed between
transmissions.
4.3 PDCP SOFTWARE DEVELOPMENT
As presented above, neither assembly languages nor standard high-
level languages are ideally suited for the development of PDCP software
systems. This problem is not unique to the data collection field but
is of general concern in the areas of mini- and microcomputer program-
ming. Therefore, a new program development technique which retains the
advantages of both high-level and assembly languages should be developed.
4.3.1 Applications-Oriented Software Development
A simplified technique for microcomputer programming by applications-
oriented nonprogrammers has recently been proposed by Korn [1]. This
technique is based on a software system organization nearly identical to
the one illustrated in Figure 4.1(1). Korn [1] assumes that a set of
well-defined assembly language, block-operator subroutines are available
to perform each of the subfunctions which may be required by an applica-
tions program. The applications program is specified by means of a
block-diagram employing the standard functions. An interactive editor/
translator program running on a small minicomputer is used to translate
the block-diagram specifications into an address table. The address
table serves the same function as the executive program proposed in
Figure 4.1(1). During program execution, the address table specifies suc-
cessive jumps to the standard subroutines required to correctly execute
4-6
the applications program. A choice between the address table and execu-
tive program techniques will depend upon the extent to which indirect
addressing and subroutine calls are supported by a particular micropro-
cessor's instruction set.
Korn [1] states that the editor/translator programming system should
satisfy the following requirements:
1. The language used to communicate with the editor/translator pro-
gram should be easy to learn and understand.
2. Simple elementary operations well known to engineers and scientists
should be used to build up complex operations.
3. The language should be entirely independent of the specific
microcomputer used.
4. The editor/translator system should generate microprocessor code
as efficient in the use of time and memory as that developed by
a good assembly language programmer.
These goals are applicable to the proposed PDCP program development
system but are not sufficient. A PDCP program development system should
also satisfy the following requirements:
1. In addition to the elementary operations, as many major PDCP
system programs as possible should be available to the user in
block form. For example, this would include transmitter programs
(see Section 3.3) and the zero-order floating aperture predictor
subroutine (see Section 3.2).
2. Memory requirements should be indicated to the user in a form
that is representative of memory cost. This implies that mem-
ory required for storage of the executive program (usually, user
defined ROM or PROM) should be listed separately from data stor-
age or scratch pad RAM memory. Also, the number of firmware ROM
modules required for storage of the standard subroutines should
be indicated.
4-7
3. Program execution time should be indicated to the user, and an
error should be noted if the program execution time exceeds a
specified transmission interval.
4. Alternate subroutine structures should be available for software
and interrupt-timed systems. This is necessary to obtain maximum
system throughput with minimum program storage area.
A PDCP software development system with the capabilities described above
could significantly enhance usage of PDCP's by applications-oriented
nonprogrammers.
4.3.2 Assembly Language and Microprogrammed Subroutines
To insure efficiency and accurate timing, the functional block sub-
routines employed in the programming system described above should be
developed by experienced programmers using assembly language and/or micro-
programming techniques. Within the constraints of a given instruction
set., assembly language programming can produce the optimum realization of
a particular software task. Many microprocessors have general purpose
instruction sets which are fixed by hardwired control logic integrated
within the microprocessor chip itself. These instruction sets must be
individually evaluated to determine their relative merits in particular
applications such as PDCP programming (see Section 6). In contrast, the
instruction set of a microprogrammable microprocessor can be optimized
for a particular application. A microprogrammed microprocessor utilizes
a programmed logic control unit rather than a hardwired control unit.
This permits the user to define and sequence microprocessor operations at
the most elementary level. As a result, the power of a microprogrammed
instruction set is limited only by the amount of control storage avail-
able and the capabilities of the microprocessor's arithmetic/logic unit.
In fact, when sufficient control storage is available, microprogramming
need not be limited to the development of a simple instruction set. Those
operations which are used most frequently, or require minimum execution
time, can be implemented as microprogrammed subroutines. Regardless of
whether or not the microprocessor chosen for the PDCP has a microprogram-
mable instruction set, PDCP operations which are not included in the
4-8
machine's basic instruction set can be implemented using assembly lan-
guage programming. Examples of assembly language subroutines which could
be included in the library of the editor/translator program are presented
in the following section.
4.4 PDCP PROGRAM EXAMPLES
The hardwired logic control units used in most current DCP designs
perform four basic tasks: data input, elementary sensor control, data
formatting, and transmitter control. In this section, example programs
are presented to demonstrate the ability of a microprocessor based con-
trol unit to perform each of these tasks. These example programs show
that, even when a microprocessor based control unit is used to perform
all basic DCP tasks, excess computational capability exists. This capa-
bility can be used for data preprocessing or special computations which
would reduce the load on the satellite data link. Fourier analysis of
seismic data is presented as a potential special computation. Examples
of data preprocessing subroutines are also shown.
Unless otherwise indicated, the programs listed in the following
sections have been written to be executed on the 8080A-based PDCP demon-
stration system (see Section 5). Standard Intel Corporation 8080A
mnemonics [2] have been used except within macroinstructions. Instruc-
tions such as NOP and MOV A.A are sometimes used to produce a required
delay without otherwise affecting program execution. Macro delay
instructions have been defined so that this usage of an instruction will
be clear within the context of the program. The mnemonic DLY XX is used
for these macroinstruction groups. The decimal number which replaces XX
indicates the length of the delay in states. Since the assembly language
program listings were produced using a POP 11/40 minicomputer, constants
and addresses are represented as octal numbers except as noted by the
use of a decimal point.
4.4.1 Data Input and Sensor Control
Data input and elementary sensor control are two of the four basic
tasks performed by the hardwired control logic currently used in most
4-9
DCP designs. A microprocessor based control unit is ideally suited to
performing these tasks. Each PDCP sensor can be serviced by a simple
subroutine which provides the functions of data input and sensor control.
Because of the versatility of the microprocessor, the cost and complex-
ity of the data acquisition channels can potentially be reduced without
a significant increase in control logic. Subroutines which demonstrate
microprocessor control of the data input and sensor control functions
are listed below.
4.4.1.1 Frequency Measurement - Many sensors currently in use on
DCP's produce an output signal whose frequency is proportional to the
parameter of interest (temperature or air pressure for example). Pro-
gram 4.4.1.1(1) has been developed to demonstrate that a PDCP can dig-
itize the output of these sensors directly. A flow chart for Program
4.4.1.1(1) is illustrated in Figure 4.4.1.1(1). This frequency counter
program is presented in the form of a subroutine which is suitable for
use as an input block operation in the programming system described in
.Section 4.3.1. The sensor output signal is input to the microprocessor
on one bit of input port zero. Signal frequency is determined by count-
ing 0 to 1 logic level transitions for a preset interval of time. Two
parameters, the number of samples to be taken and the input bit assigned
to the sensor, are passed to the subroutine from the calling program.
The input bit assignment for the sensor is specified by a mask byte in
register C. This byte contains a one in the bit position corresponding
to the bit position of the input signal and zero's in all other bits.
Thus, a single frequency counter subroutine can service up to eight sens-
ors without multiplexing. The number of samples to be taken is specified
by the contents of register pair DE. Since the number of samples is
proportional to the measurement interval, the resolution and scale factor
of the digitization process are determined by the number of samples
taken. With a measurement interval of one second, the sensor frequency
is measured directly in units of Hertz (Hz). The binary output is
returned to the calling program in register pair DE.
The sampling interval establishes an upper bound on the frequency



























































a u. N LJ
LJ O N r>
x _J
•-« Ci CLL, uj :**
a
c r a LJ
r> O ~
LJ Z -< i~
cj c;
z LJ LJ
CO P ~ LJ
0 _J
- Z Ci.
. u i-i z:
c: _i _j c.
-' Cu L. CO
C T. f:.





CO LJ t~ ii
»-« '•' f~




' • * - ? _
Lj Z k-J
a a o u
— LJ >-« il'
or i- t-i
u >-« ^ -i
r. ~> o cs
r- Ci i- U




CO Ey ^ co c
« LJ " CO
H H Z LJ
"L!1 ^ i.:' C
U . C t~
X L. r- CO
LJ O
CO LJ
LJ 1- LJ Z
^ Z _J ^
O XT O
5~ XT CI d













LJ LJ lij- _J CO
CO L. C
O CLJ co ;—
C' -<LJ a
'- ay _, y
— c P
LJ "~ LJ













J — L^ LJ
Z LJ














































O 1-1i- a _i
f-^ ~* ~
O CJ -




































































































LJ O CJ H
1- CJ "
co _ A a
co fe : H
Ci M .^ - C~
••* .-^  ••» •-»
O »i er
r u c3 a
f
CO r-i •-< >
-• x > O







n ^i <o N
c- «r ~ 0










































O JLJ a a.j— ^
d •• c^
-• UJ CO





















































































































































o o o -< ^  n IN ^0 jo r- :•• o o o >-) n o co -o -o N N n n co o
o o o o o o o o o o o .-« ^< «-•-<-' •-« • < • < — '« - cj c-4 c< ?i
o o o o o o o o o o o o o o o o o o o o o o o o o o
o o o o coo c> o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o o o o o o o o









































































~ 0. C. K
o o o u





























«r *!• V IT) kO -0 ^1 fs r- O O .0 n V V 1)0 JO O x? N N ~ M ^J kO
c; >N c--: c-i ci N o c-i ri co co o o co o co co co co co o <• o- <r ^~
O O O O O O O O O O O O O O O O O O O O C) O O O O
o o o o o o o o o o o o o o o o o o o o o o o o o
ooooooooooooooooooo o o o o o o




FOR 1 SEC. PERIOD.


























SAMPLE = 1, PREVIOUS





Figure 4.4.1.1(1) Flow Chart for Frequency Sensor Input Subroutine.
4-13
is desirable, but the interval must be constant. As shown in Figure
4.4.1.1(1), the program executes one of three branches depending upon
the value of the current and the preceding sample. The longest natural
program branch (Branch A) occurs when a positive signal transition is
detected. Delay must be added to the other two program loops so that
all three loops will execute in the same number of states. Unfortu-
nately, arbitrary delays are not possible because the microprocessor is
synchronized to a constant frequency clock. As a result, a minimum
delay of five states must be added to Branch A so that the execution time
of all three branches can be equalized.
Program 4.4.1.1(1) requires 77 states between samples of the input
signal. Each state is a minimum of 500 nsec for an 8080A microprocessor
or 325 nsec for a high speed 8080A-1 microprocessor. Thus, the maximum
sampling frequencies are 25,974 Hz and 39,960 Hz, respectively. From
the sampling theorem [3], these sampling frequencies establish upper
bounds on the input signal frequencies of 12,987 Hz and 19,980 Hz,
respectively. Frequency prescaling will be required for sensors which
produce higher output frequencies.
4.4.1.2 Autoranging - In some PDCP applications, the parameter of
interest is a relatively slowly changing function of time which can vary
over a wide range. The design of an accurate data acquisition channel
for parameters of this type is difficult because linearity must be main-
tained over a wide dynamic range. If the data acquisition channel gain
is set to produce a detectable signal level for the minimum sensor output,
the later stages of the data acquisition channel may saturate as the
sensor output increases. A solution to this problem is to vary the gain
of the data acquisition channel so that the signal is always within the
most linear and accurate system dynamic range. This can be accomplished
by including a logarithmic amplifier in the front end of the data channel.
The logarithmic amplifier, however, introduces a log conformity error
which is unsatisfactory for systems requiring high resolution throughout
the voltage range. In addition, the logarithmic scaling of the digitized
data is inconvenient for most PDCP data preprocessing subroutines. These
problems can be avoided by using a variable gain amplifier in place of the
logarithmic amplifier.
. 4-14
The concept of a microprocessor-controlled variable gain amplifier
is illustrated in Figure 4.4.1.2(1). A block-diagram of a typical data
acquisition system using the variable gain amplifier is shown in Figure
4.4.1.2(2). Channel 1 is designed to acquire data from a sensor which
produces a slowly varying, wide-range (200:1) output voltage. This sig-
nal is digitized by the analog-to-digital converter and input to the
PDCP's microprocessor. Program 4.4.1.2(1) controls data acquisition on
Channel 1. A flow chart for Program 4.4.1.2(1) is shown in Figure
4.4.1.2(3). Each time the executive PDCP program calls the data acquisi-
tion subroutine for Channel 1, a sample is obtained. If the sample is
between 10 percent and 90 percent of full scale, the value of the sample
and a code representing the current channel gain are stored in memory
for.later transmission. Whenever the sample is not within the ideal
range of 10 percent - 90 percent of full scale, the gain of the ampli-
fier is adjusted and another sample is obtained. Thus, a maximum system

































_J U LJa 3 LJ
C h- 3




O > _J -
O CO;; co > i-
»-< •—< J
C i- O
O 2 p >










O C. I- GH r u
G Ci. CO
Q LJ
LJ LJ LJ _l







2 •-< O X
•-.« L. N O
5 c. a a
ci s: 2 2
. G G G

























































































































































































































































































































































































































































O O O ~ — M fl C> CO ^ <r
6 o c.> o 6 0006 o o
o o o o o o o o o o o
ooooooooooo
ooooooooooo
r-. N O O 01 iN 'JO iO
O O - — •-<« — -'
o o o o o o o o
o o o o o o o o
o o o o o o o o
o o o o o o o o
O O fl M CO CO -O -0 ."-- N CI CIfi ri M -M ci fi oi n ci c-j c:> o
o o oo oooooooo
o o o o o o o o o o o o
o o o o o o o o o o o o
oooooooooooo
ilO UO O O "
"i C) «r «.- «r
iN C) CO CO '
«,- <J- *f <• *^- ^ J-
o o o o o o o o o o o




































ii u a 2
o E z >-•
u o <n
Z H L. O


























































<• 1)0 ll^ N N O O O >"? «r * i~- N r> r> »-J Cl 'j~< \f) -3 *3
«?».-«-«•«• \r> ^  j) uo ii") \n ui jo ^> o -o <) v) -o -o <i
o o o o o o o o o o o o o o c> o o o o o o
o o o o o o o o o o o o o o o o o o o o o
O O O O O O O O O O O O O C) O O O O O O O
ooooooooooooooooooooo
4-17










































Figure 4.4.1.2(2) Analog Data Acquisition System for a PDCP.
4.4.1.3 Software Controlled Analog-to-Digital Conversion - The
traditional analog-to-digital converter (ADC) consists of a digital-to-
analog converter, a comparator, and some control logic. A digital word
loaded into the digital-to-analog converter (DAC) produces an analog
output signal (voltage or current) which is applied to one input of the
comparator. The second comparator input is the analog signal which is
to be digitized. The comparator output signal indicates whether the
analog input is greater than or less than the reference signal produced
by the DAC. This signal is fed back to the control logic which uses a
fixed algorithm to update the DAC input. The above process continues
until the DAC output equals the analog signal input. At that point, the
digital word in the DAC is the digital representation of the analog input
voltage.
A number of different algorithms can be employed in the analog-to-
digital conversion process but one of the most widely used is successive







































Figure 4.4.1.2(3) Flow Chart for Variable Gain
Amplifier Control Program.
4-19
input is compared to the DAC output with only the most significant bit
(MSB) true. This DAC output corresponds to one-half of full scale. If
the input is greater than the MSB, the MSB is left in the logical "1" or
true state and the next bit (which corresponds to one-quarter of full
scale) is set to a logical "1". If the second bit does not cause the DAC
output to exceed the unknown analog input, it is left in the logical "1"
state and the next bit is set to "1". If the second bit causes the DAC
output to exceed the unknown analog signal, it is set back to a logical
"0" as the next bit is set to a logical "1" for another comparison. This
process continues in order of decending bit weight until the proper state
of the last bit has been determined. At that time the digital input to
the DAC represents the correct digitization of the previously unknown
analog voltage or current.
All of the digital control logic normally found in the successive
approximation ADC can be replaced by a software subroutine using the
microprocessor. Program 4.4.1.3(1) is a successive approximation
analog-to-digital conversion subroutine written for the UT PDCP devel-
opment system. A flow chart for this program is illustrated in Figure
4.4.1.3(2) and a simplified schematic of the ADC hardware used in the
development system is shown in Figure 4.4.1.3(3).
The successive approximation subroutine uses only 34 bytes of ROM
and six bytes of RAM. As currently implemented, the analog-to-digital
conversion requires a fixed time of 748 states. For a standard 8080A
operating with a 2-MHz clock, this corresponds to 2673 conversions per
second, a rate which should be more than satisfactory for the PDCP
application.
4.4.2 Data Compaction and Preprocessing
The amount of data which must be handled by data collection satel-
lites is constantly increasing. The major factors contributing to this
increase are the use of high sampling-rate sensors and a general growth
in the number of DCP's. PDCP's can be expected to contribute substantially
to the increase in remote data collection activities by opening new


























































i- O h- .
c i— 2:
>-• LJ ~'~




-'. G £ _Jo o G
C 0 H
S: 2 G Z
« -J O
J '•- ' >-«
-J _J £ H
c z> r) G
CO O T.
CO LJ O •-«
u ^ c x
:> o
c u LJ c:
C) ^. Z i.
LJ G
Z Z
-« . - LJ
j~ CO ->
— ^  "•""( O i-H
5 C LJ COi: _j z co
co "" 5 cj
- a i- o













































c: co D z
O CO






c; K s . .
o
a


















A 1 O H; G
H H
LJ 0
»-4 CO CD CC
- cci o
^. ^
a a a G
"^" .
CO >-" n > o


















C J G O
H Q CJ
Z CO
-" LJ O CJ
H i- GH a
>-> LJ H
h- D H
U G L. ~>
> LJ i- t.
G t: D Z




G Go a a a
> G :-o cr 3 z









































































































































































































































































































































M -• O N
0-J N -0 O
CO -•« CJ «H







!O 04 o - > • - < • • « O
N O N CJ O •-« O
0 CO " CO CO CJ 0






















O O O •->•-< iN M JO iiO N h- O O •-• -" C) fl O CO IjO
o o o o o o o o o o o ••« ••« r-. ^. ,.... ^. ^ . .•< ,
O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O C? Q O O O O
O O CJ O O O O O O O O O O O O O O O O O O O O O O O CJ C! O O O O O O O O O O O O O O O O O O O
O O O O O O O O O O O O O O O O O O O O O O O O O O O G O CJ O O O O O O O O O C) O O O O O O O









TO TEST NEXT BIT
DELAY 14
STATUS FOB EQUAL TIME 100
PUT A T IN APPROPRIATE
POSITION OF RESULT
REGISTER
































Figure 4.4.1.3(2) Simplified Schematic of the ADC Hardware.
4-22
present data collection satellites, significant increases in data flow
would require corresponding increases in the capacity of present ground-
to-ground communication lines, data storage areas, and data processing
facilities. Therefore, techniques should be developed for reducing the
volume of data flow without significantly reducing the amount of informa-
tion acquired.
One of the most useful ways to reduce data flow to manageable pro-
portions is to apply compression or compaction before the data is trans-
mitted from the PDCP. There are two basic types of data compression
techniques: entropy-reducing and information-preserving [4]. Entropy-
reducing algorithms perform an irreversible transformation on the input
data and therefore cause a pre-transmission loss of some information.
Information-preserving algorithms perform a reversible transformation on
the input data. As a result, the information carried by the original
data can be recovered within a specified allowable tolerance or peak
error. Bit compaction rates of two-to-one can normally be achieved by
information-preserving algorithms. Much higher degrees of data compac-
tion can be obtained by using entropy-reducing algorithms.
Data compaction techniques have not been employed in previous DCP
designs because of the extra hardware and expense involved in hardwired
implementations of the algorithms. Many data compression algorithms,
however, can be economically used with PDCP's. In most cases, the only
additional hardware required to provide data compression capabilities
will be the memory used to store subroutine implementations of the vari-
ous data compression algorithms. Data compression subroutines are
excellent candidates for the subroutine library within the applications-
oriented PDCP programming system (see Section 4.3.1). Several examples
of data compression programs are presented in the following sections.
4.4.2.1 General-Purpose Binary Math Package - Most data compression
algorithms are based upon mathematical operations. Therefore, a general-
purpose binary math package has been developed for use in data compaction
operations. The math package consists of subroutines which perform the
unsigned binary operations specified in Table 4.4.2.1(1). Unsigned binary
























°£ <"<*-£ QJ O



































































* — * ^>~ ^  — x
QJ CM •*
i^  -j- 4_> ^
XI CM i- «3-
3 + O +











Q CQ ^3 CQ ^>
Q ZD CO •=> 5!




z co i— ^ co
VO CO "^ }" **O *Oin i — in ««t-
o CM i^- o «*
f^v i — o r^- co
i — i — CM i — f--.




r — O r -
1
 * *r~~ * 1
t 00 f
1 — 1 C T- 1 — 1C
ID O O VO O
c in •!- QJ c in •!-
O CM 00 i- O CM OO
•r- 1 T- Q. - i - l -r—
00 r— O •!- 00 r— U
•r- 1 1 QJ -4-) -r- 1 1 QJ
0 + S- i— U + S-
QJ 1 — 1 Q. 3 QJ 1 — l Q-
S_ <£> '—* 5: . — - S- l£> '-^
o.tn QJ CM •* o.in oi «*
•r- CM r"~ "f* •4-' T "• — CM r— -j*
•Ml JOCM i.-vf + - > l J3CM
r— r— 3+ O+ •— r— 3X
31 — 1 O CM -C CM 31 P O CM
O
o S
1 — I ot- — t
•=t o_





























f — * ' — ^
QJ CM QJ r~~
r— 't' r~ \
J3 CM jQ .
3 •!• 3 [CM





































O .£: to <+-
•r- •"• CU 0
3 2 « S-
































































C I — 1 I — 1
o to o
•r- C LO C H-
10 O CM O
•r- -r- 1 T- LU
o to i— to >
CU T- 1 1 •!- Oi- 01 o s:
Q. CU I — I CU I — I
S- VO S- to
CU Q.LT) Q-LO
i — '-^ T- CM -r- CM
JQ CM -l-> 1 -l-> 1
31 i— r— r— r-













































form. Listings of the math package subroutines are provided as Programs
A(l) through A(12) in Appendix A.
The most important PDCP math subroutines (addition and subtraction)
are available in three formats: double precision (numbers up to 16 bits
long), short multiprecision (mixed 16-bit and 32-bit number operations),
and multiprecision (numbers up to 2048 bits long). This allows the PDCP
programmer to consider memory requirements, execution time, and operand
resolution in selecting t^e best subroutine for a particular task. Most
PDCP data words will be eight to ten bits long and can most appropriately
be manipulated using the double precision subroutines. The short multi-
precision subroutines supplement the double precision subroutines and are
intended for use in operations such as summing a large number of data
points where the result could overflow 16 bits (i.e., a result greater
than 65,535). Short multiprecision and double precision subroutines
should be sufficient for PDCP data compaction operations. Multiprecision
subroutines capable of operating on numbers up to 256 bytes long are pro-
vided primarily to illustrate that numbers of any magnitude can be pro-
cessed by a microprocessor based PDCP if sufficient calculation time is
available. .
The comparison, multiplication, division, and square-root subroutines
permit significant data compaction operations such as data averaging to
be performed by the PDCP. Since a special square-root algorithm developed
by Kostopoulos [5] was implemented, a flow chart for the square-root
subroutine is shown in Figure 4.4.2.1(1). The MOVE subroutine is provided
for transferring multiprecision data blocks between temporary storage
and working memory areas when using multiprecision arithmetic subroutines.
EXIT is a general purpose block of code which is used to restore all CPU
status when returning from selected subroutines. The complete binary
math package is 403 bytes long and would occupy only 40 percent of a 8K
ROM.
Normally, a PDCP will not require all of the subroutines listed in
Table 4.4.2.1(1). A basic math package consisting of double and short
multiprecision addition and subtraction, double precision compare, and









TO 8 AND CLEAR








SHIFT 01 INTO LEFT
OF PARTIAL ROOT YES
RESTORE NUMBER FROM I
STACK AND SHIFT 2 MSB'sj
OF NUMBER INTO 2 LSB I














Figure 4.4.2.1(1) Flow Chart for Square Root Subroutine.
4-27
basic math package can be stored in 79 bytes of ROM. Multiplication and
division can be added to the basic math package to support more advanced
data compaction operations such as data averaging. A total of 216 bytes
are required to store this form of the math package. Standard deviation
calculations require the addition of a square-root subroutine which
increases the memory storage area used by the extended version of the
basic math package to 300 bytes. Execution times of the PDCP binary math
subroutines are shown in Table 4.4.2.1(2).
4.4.2.2 Determination of Minimum and Maximum Data Values - Program
4.4.2.2(1) is an entropy-reducing data compaction subroutine which deter-
mines the minimum and maximum data samples obtained from a sensor over a
particular time interval. The DMINMAX program uses the double precision
compare subroutine from the binary math package and operates on numbers
up to 16 bits long. Each time the DMINMAX routine is called by the PDCP
executive program, the value of a new data point is compared to previously
established upper and lower bounds. The carry and zero flags indicate
the result of this comparison. If the new data point is outside one of
the boundaries, the data point is stored as a new boundary. Therefore,
just prior to transmission, the upper and lower bounds will represent
the minimum and maximum data samples obtained since the last transmis-
sion. Program 4.4.2.2(1) is 29 bytes long and requires eight bytes of
RAM for stack operations. Worse case execution time is 264 states which
would permit a data rate of over 7,500 samples per second.
A multiprecision MINMAX subroutine is listed as Program 4.4.2.2(2).
The MINMAX program uses two subroutines from the multiprecision binary
math package and operates on numbers up to 256 bytes long. The value of
a memory location named TMCODE indicates the result of the MINMAX program
execution. Program 4.4.2.2(2) is 120 bytes long and requires 20 bytes
of RAM for stack operations. These figures include the required multi-
byte COMPARE and MEMORY-TO-MEMORY MOVE subroutines from the math package.
4.4.2.3 Zero-Order Floating Aperture Predictor - A potentially
more useful data compression algorithm is implemented in Program 4.4.2.3(1)
The zero-order floating aperture predictor algorithm is an information-

















































































oo co co co co co
cn co •— cn co r-
vo in co vo in co




CO COin in CM in in CM
• — o in i — o in
to vo
co IT in co £Z in
00 ^ 4- CO ^  +r
~ in •"" in
cn cn





















































































































































































-« a a2 D _J:
i . 9 5
H " "' t S
...c.a n .
'Q 2 z co co
co co co »- i~LJ u LJ > c:
'<- \- ',- iil \-
o o c: e <r co
c o cj o N
CO O h- ^ ^* ^  JO IJC'.( co d *j a a 2L j u a z z z - - "
a a 2
a a LJ





It » R E II II cJ
f-J
A -r ~ O
_ _i o c:


















































































x J- CO x x _J
CJ LJ D Z Z C
a ^ ^ >-> -i u
NX
O































































o o ^ -«
& • • < ) ' ) • ' - •
O *-> CO O C4
N s N rt r< co co - O « O N N O O » - « - < M
CO CO CO «r T o <• v c- <• v lit u"! aO jO 1)0
JO iiO liO JO iiO JO jT> JO JO -lO 'j"> JO JO iiO JO ii'>
o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o o
O O O O O O O O O O O O O Q O O O O O O
ci co o v *f -jo 'jo -o -i •-< —
bO u"' -)0 J"i J^ JO jO 'jO a'< i~> O
UO u'.' ^ 0 10 j~> j) :J~' jj HO liO 1)0
c> o o o
<r %- ao ao -o -o N N o o -• ~ ft ?i co co
-ji o <) -i> t> -J'i •<"> -O r- N N N N N Is- NjO :jO JO JO iiO liO J? jO aO JO iiO iiO tiO i)0 i^ l>0
o o o o o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o o o o o













































2 LJ f~ C CO
- _J G r'< G
c a ,-. e. 2
:- _j a G . •-•>
G V 2 U. U a
a a r; 22 L. . o - a3 >-< a o t~ u
LJ U. 2 D 2
2 •-• DUO O
. Q ~ ii. r-«G a a i- a co
... 2 . D 2
o a 5 Do ' " ~2 a £_ LJ 2
LJ D £. J- r ~
D O t: D _j i-
_j a LJ D u
G 33 CO L. a
> ~ 0 LJ LJ Q _
LJ _l ^ LJ P
Z " 3 LJ LJ E
. — LJ " ~'~ •"* a
£i 2 H h- i-- LJ
CO LJ £
^.' 3 LJ CO LJ 2 Di: o z LJ H o co
C _l (- £ G -< CO
i. O CJ I- CE a co cj « D
O 2 LJ uJ a ! ' ' -
cj G E a 2 u i:O w >: C
LJ '- O a LJ2 a LJ 2 o co :—;-• D a H u p: G
D a 5 i- P a c:
o c: 2 u E o
;: u LJ co a D u.
a C. L. D 22
p Z. 0 _l CO G



























































































" " LJ .(- r- a
O 2L. a D
0 G 0
a






























































































































































































































LJ .2 >- c;























































































































































































































































































































































































































































































«• «!• -17 'JO O O *-• -• M CJ ii) -ft ,-- N O O CO CO «.*• •? N N •r-. *-> «*• «.•• N N r-- -« -• f f f -0 -O
O O O O *~* *-• -^ *-• *-«»-•-• »-i »-»»-• c I Cl Cl Cl CJ Cl Cl Cl O O O CO CO CO CO T O" «r ^ <^" *t~ «J"
O O O O O O O O O O O O O O O O O O O O O O O 6 O O O O O O Q O O O O O
o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o
O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O
O O O O O O O O O O O O O O O O O Q O O O O O O O O O O O O O O O O O < ~ >
• ~ Cl M 'JO JOin 10 jo 10 10 'jo
O C.' O O O O
o o o o o o
o o o o o o
o o o o o o
4-32





















































~ LJL: o a .-LJ a LJ >
•z ^ co a
J p LJ £




> '— '_> 2
L. H ~
i- O C CO
Z CJ
C ul O .-
CJ 1- _J COi-i :- GL. a >- LJ
* § 5 b
CO CJ i." 2
• r-« G
H L. U i:
co £ :: LJ
LJ S O
_l -• i- i-
00 G
 ,
o t~ a o
CO LJ
O G '- CO
co LJ <_j co
LJ _l i- LJ
LC C~t L^
a LJ ' a















2 LJ "'{? 3
L: o 2 a
LJ _l G LJ
O 2 P O
S— C LX
Z C^ h~
2 H LJ CO
»-« 1- LJi: co G a
>- CO LJ
-• LJ i: LJ3 _i o t:
c.
CO CO CO
J— t *-4 •-< ^
Q
C C C r-
!- i- !- C
C G G _J
-, -, -~ ^
LJ LJ LJ CJ
2 2 2 O
G
i^  ^ l^  Q
2
~ 0 ^ G




















































































o 3 a L.i- _i
G A CO
a i- a G
2 G Z _1
a L.
LJ L.
C^ -^<G a a
J f: j
£ li H v
o a ~> D


















\r> o .N iio
»•« *^ CO ^0
O 0 O O
S N N f 1 C-l O O v> vl





















































































- a r r co
1
x .j x x CJ
2 G CJ CJ Z






O iiO CO 0 N
* - SO If) N
O CO O O fO
r> ro <- f .-- N o o -• "
























































































































vj O ^- -< «f































































































O O O O O O O O O O
o o o o o o o o o o
oooooooooo
<r <•<)•<:- ^ <r *r c* *? *J~ iiO lj'.' J') jO Si")
O O O O O
o o
oo
O Q O O O O O O O O O O O O O O O O O O '
o o o o o o o o o o a o o o o o o o o o o o o <




































































































































































































































































































































o *« t-i ^^ oo o o
10 ill 10 1)0 !i> JO 10 JO 10
o o o o o c< c> o o
o o o o o o o o o
o o o o o o o o o
M 10i >--i ri M
' iiO JO uO
.' O O O
o o o o
o o «o N :*• o o •-« ••« *) o c> o e <r uo jo -o o
N c-j C, ,-| fj C) O c, O O CO O O C) C) C) CO CO CO
0 JO J? j^  jO 'JO iO iiO J') !O iO j) ill JO jO I/O 10 Ijl iiO
;, o O O O O O O O O O O O O O O O O O
D O O . O O O O O O O O O O O O O O O O00000600666606060600000
4-34
based on the prediction that later data samples will be within a speci-
fied tolerance of the first sample. If this prediction is true, the
data sample is considered redundant and should not be transmitted. The
first sample which is not within the specified tolerance is flagged for
transmission and becomes the new reference point for subsequent predic-
tions. The result of the comparison is indicated by the states of the
zero and carry flags after the program has been executed. The zero flag
must be tested first to avoid incorrect results. A flow chart for the
zero-order floating aperture predictor subroutine is illustrated in
Figure 4.4:2.3(1). This program is 56 bytes long and uses three sub-
routines from the binary math package requiring an additional 34 bytes.
Six bytes of RAM are required for stack operations. At present, 100-
piece CMOS ROM prices, the incremental component cost of providing the
zero-order floating aperture predictor subroutine and the required math
package subroutines as part of a standard PDCP ROM, is approximately
$7.21. As shown in Section 4.4.3.2, the longest data formatting and
transmitter control subroutine (GOES format) is 236 bytes long. There-
fore, the double precision zero-order floating-aperture predictor
algorithm and a transmitter subroutine would occupy only 32 percent of
the capacity of an 8K bit ROM. The remaining 698 bytes of ROM should be
sufficient to contain an executive program and several sensor data input
and control subroutines. For example, the frequency sensor input sub-
routine [Program 4.4.1.1(1)] which is capable of serving eight different
sensors requires only 36 additional bytes of ROM.
Program 4.4.2.3(2) is a multiprecision implementation of the zero-
order floating-aperture predictor algorithm. A flow chart for this pro-
gram is illustrated in Figure 4.4.2.3(2). Program execution times and
For example, RCA's CDP1831CD 512 x 8 ROM with a 400 nsec access
time and 0.5 mW typical quiescent power dissipation costs $41.00 each
for the first 100 devices, including the mask charge. Therefore,
A Cost =
 51 kbytes x 90 bytes = $7'21'
4-35





































.- - 2 CO
Ci H CO U h-
LU CO _l CO
d. LJ CL Ci CI
<C . Ci E M 1-
i CC CL d LL d H
O O E CO DO CO
Z co o LU z >-i co ; •
n CO O Ci Z U i-i LL O O
I-LJ L J I - Z C O Z LJ M |-
d O d h- 1- M CJ LJ £T Q
O O h- d LL >-<O LJ Cl
_J Ci d _l 0 - a Z Z 3 C i L U
U CL Cl LJ Z 3 d LJ CL E
O h- LJ Zi d Ci Z Zi
Ci Ci _l d O Ci LJ LJ h- CO
L J O d Z Z l - l - _ l _ I L J Z C ' i
G M M h- d Z L - O ^ - L J d
CiEE Ci CO C E 1- h- Z)
O O Z L J i - i O d 0 LJ
i d Z O _J Z CO Q CO LJ Ci
O O >• M o Z Z> LJ LJ CO d
Ci CO _1 i- V- O O 1— I-H E CQ
LJ O O O i-i LJ CO L. O D CO
H CO CL 1-1 Q H- Ci Ci 1-1 O CO Ci
D LJ O M O LJ LJ
L J Z C D L J i ~ « t - i G L L L j C Q C i C u
LC d Z CL LL O LJ CL OE
1- i - iL i- iLJCiLJf.OQL.Zi
CD > O C i U Z Z Z
CO Z Ci LU LJ CL Q >- U d H
.I--M-LJ Z CL M Z Z _J
Z co co i- co co co H a M _i
LJDLJ MZ . ^ U O d
LJ E C- O PoLJ i -< t - > ~
_J Z Z 1- Z M LJ CO
t . l - Z D M L L C O i - 1 - E O Z
M C£ M CO H E3ZLJi - iOI-CIi-i LJCO dCiH
Z_IE L J L d O l - '
K O Z> CO CL d 1-
D Ci LL 0 E CO
O 0 Z •-• _J d
CC 1- M z _l CO
« O Z M
3 M z 0 3


























































































































































































































CO LJ M x





LU O Q U
Z II X
1-1 LJ 3 CO
Z Q LJ •-•
O O Z _ld o a





I'M — 1 LU
Z H 0 LU
Ci LU A Q . .
Zi Ci LJ >
'>- Q CO _l
LU Z 0 <t _1
Ci O O Z <I
E O
Ci 1- LU M
U . CC LL
I-LJ . O 1-1
d 1- 1- L. O
_l > Z LJ LJ
CO d Ci i.
D D LJ CO
Z O Z X
d d * H-
_l Q \-
CO LL LU Q Z
LU Ci Z w
^ d ^ 1*^d CO CL
CO CO d 1-
d 3 Z LU
LJ C U
z at- Ci z.
M LU Z H LJ
h- CO M -,"£
Zi D 0 Ci LJ
O LL LJ LL
Ci CO Lt LU
CO M c Ci
D H l~
CO LJ d O 3
Q Q Z LJ
CO 0 Z
M O 3 CO



























Z Z Z LJ
ci ci i— _J
Z Ct 0
1- LU Z H-
_l ci£i o ic co
LJ i- 1- Zi
1- Z
<I CO CO 1-1
LJ -> CO E
Ci _l U
O CL _l LJ
O
CO LJ CO Z.
M O I-H LJ
Z Ci
CI LU CT LU
H Ci r- LL
d LJ C '.if
CJ LL Q Ci
LJ
3 Ci 3 LJ
LJ LJ Z
Z U Z ^ -
T













































































































































































































L Q D ~
*y "7* ~ *•"
CO CO CO CO
D D 3 D























































































































































































































































































































































































































O O O -" -« N M CO CO * «f ilO liO O O -t ~~> N N UO 1)0 N N O O C^ CO «f ^- N IN *-• -« »T <T N N N «-« «-•
0000000000000000000000000006000660066600






































































































































































































































































































































































































































































































































































































































<• V «fr s> -0 — -• M N CO CO f 1- 1^ N — --• M (••> Ul llO -O O N 1^ O O -" -" f-< CN CO CO t t \T> IT> O O -> •-• C-t M !T> iJO
«T «f «r fl- V llO ill 1)0 lj~> ll"> UO UO llO 00 1)0 <i -0 ~0 ~3 >0 -0 v3 vl s5 «0 N N N N N N N N f-- N N t^ O O O O O O O O
O O O O Q O O O O O O O O O O O O O O O O O O O O O O O O O Q O O O O O Q - " ' * - - ! ' - ' - " ' - ' - ' - '




























ND = VALUE OF NEW DATA POINT
UB = VALUE OF UPPER BOUND
LB = VALUE OF LOWER BOUND
TOL = VALUE OF TOLERANCE
Figure 4 .4 .2 .3 (2 ) Flow Chart for the Multiprecision
Zero-Order Floating Aperture Predictor
Subroutine.
4-40
the results of the multiprecision zero-order floating-aperture predictor
subroutine are indicated by the value returned in the memory location
called TMCODE. This program is 71 bytes long and uses four subroutines
from the multiprecision binary math package for a minimum storage require-
ment of 178 bytes. Twenty bytes of RAM are required for stack operations.
4.4.2.4 Data Average - Data averaging is one useful form of data
preprocessing which can easily be performed by a PDCP. Normally two
distinct subroutines will be used to obtain the average value of a set
of N data points. A data accumulation subroutine such as Program
4.4.2.4(1) will be called each time a data sample is obtained. When the
average value of the data is desired, a final data averaging subroutine
will be called. As illustrated by the flow chart in Figure 4.4.2.4(1),
the data accumulation subroutine will simply increment the sample count
(N) and add the new sample to the previous sum of samples. Program
4.4.2.4(1) can process up to 65,535 samples of 16-bit'sensor data while
using only 18 bytes of ROM and 10 bytes of stack.
-Program 4.4.2.4(2) is an example of a data averaging subroutine.
A flow chart for this program is shown in Figure 4.4.2.4(2). The data
averaging subroutine calls the short multiprecision divide routine to
divide the accumulated sum of samples by the number of samples, N.
The resultant average is returned in register pair DE. Only 24 bytes
of ROM and 18 bytes of stack are required for this subroutine. There-
fore, data averaging can be accomplished by the PDCP at a cost of only
42 bytes of ROM and 18 bytes of stack in addition to the general purpose
binary math subroutines.
4.4.2.5 Mean, Variance, and Standard Deviation - Much more infor-
mation can be obtained from the mean or average of a number of data
samples if the variance and standard deviation are also known. Programs
4.4.2.5(1) and 4.4.2.5(2) can be used in conjunction with the data accu-
mulation subroutine [Program 4.4.2.4(1)] to calculate this information
aboard the PDCP. Program 4.4.2.5(1) is called each time a data sample
is obtained. This program prepares the data for the mean, variance, and











































































































a G u co o
G LJ
a z a -r G
i^L,s i : j










:~l X A — f~* O "~"i- -i _i ' i: *-c'i r •- co G
a ' v . 2 u ;-
LJ CO £ Z g J- CO
a "" - "" S Q DG '^  co a u.
CJ LJ LJ LJ r- O
CO O I-- Q ^ Z
- _J > Ci r- C _J
a a e o _j
— z •-« c
O LJ O CO •" L^
a o 3 LJ e r1
— G r- 1- i" Z
c > z <-•ii o i- a o *-•
t- CO CJ CO
































































- G ^ Z C
co to






















































































































•o *-• •-• •-<
*^ «j- %0 rt
o o o o
«.- «r «r ;o n o o r^- r- ^> •*• ?i:: o o <!• «r o -o N r-- o o o o f f in n
s ,-^ ^. r. r, ,-. N r-. r^ o o o o o o o o o o o o -< •-. ~ .-. ^ « ^. ^  ^ <
Irt a") iiO iO U") 1O « ^ j) <• >0 <' v^ <i <i <• vj <. o O -0 ^ <i vj o v) o o O
O O O O O O O O O O O O O O C:- O O O O O O O O O O O O O O











































o _J ai.. _. *
c 5 G







ill i ': &
LJ 'N























































r- O01 a >-
0 1 £ COQ rj D
tO LJ CO H
LJ . CO 0 G
\~ CO D G ti. a t-
> LJ h- £ 0 LJ CO
a !- G ul r-
G H > £ G LJ
CO r- CO G D _J Z
•"• CO . CO LJ ' DMLJ LJ Q x: n:
- LJ Z £0 P _l DO
U Z LJ Z 0 G
z •-« :n Q i- o x:
•-« ~ CJ h- G A G
I- CJ G _l ! LJ
D C E CO D i LJ C' ZQ x: LJ x: a o ci
"" CO > > Or- > CO ' r-
> o c <a o G >-. LJ LJ











a G . >
LJ . K
^ « :? i: E i: E EZ: a 2
' " L x a ^ c j z a ^ L J z a r a t i n i Q a a x a L
^-
o^
c: ^ 3: ^: z o jCO CO CO > x ?> x > x > x CO > x r> ~ i. _J L t. ' L r-CO D D D O Z O Z O 2 O Z D O Z O O O G O O O LJ












































-. o o •-<
r-i 1^1 ft 01


























































«»• «.- jo uo -o o N
CO O i) CO C) C) i)










M ft CO CO
*r <"«,*• <r
<1 -0 <1 vl
o
-0 O N N O O « "• (I (•> C> CO <f t 1)0 UO O ^ N N O O -• -• M M CO COV f JO liO -0 O N :v- M CJ CO CO f f !T< liO
vj *0 s^ v i^ O vj *0 *0 *0  «O ^ 0 *O *"* *O v? *0 *O *O **^ vl1 ^? v) ^0 *O ^^ "O *O *i'' v"' sj *O O ) v) v^ *0 v? *0 "*0 *O *O *O O
o o o o o o o o o o o o o 6 o o o o 6 6 o o o o o o o o o o o o 6 o o o o o o o o o o o
O O O O O C) O O Q O O O O O O O O a O O O O O O O O O O O O O O O O O O O O O O O O O O

















































i i! it i;
/•i A O












































































































































































































o 0 CO 0
n i^ .-« O














O O -0 N f-- O O -• -« Cl CJ If) u") O O •-••-« CJ CJ f) CO v3 O N iv- O O -< -• CJ CJ CO P «- «• <j~> \T>
f v f v «,- u> ij) 10 'JO j> JO 'j) j) O O O v) v? -0 x> <i O •«) O -0 T- h- N N h- f- r- N .-^ N N N
O O -0 O «0 xj -O vj O -0 O v> <i v> vO v} v) v> xl v) x) vj x) vO -<) -J) x> <1 -C «0 v> x) O -0 O ~J -O
O O O O C> O O O O O C) O O O O O O O O C) C? O O O p O O O O O O O O O O O O
O O O O O O O O O O O O Q O O O O O O CJ O O O O O O O O O O O O O O O O O









































































































































































































































N N o o b b 6 o o o 6 6 o o b o t. ^
o o b b b b b b o b o b o o o b o o
o o o o o o o o o o o o o o o o o o















































C il t. • •
> LJ X 2
:; u o
Z ~ £ LJ
c z. c a
LJ U C
z: u o a
a o J
U Lt •->i: co •— L.
f-- C «
CO ~ ^ -Ii





 5 y '-:~'
cj ~" ^
_J C 'r- >
<t H D £1
0 C 0 0
a £; £
2 • ~i i"
-• O CO
c 2
— ' Z Z *•"*
9 ° ° „
5 P ? o
3 C C -
CO "21-
> c c
CO LJ iL- £































































































_J r- 0 .
Ci- C CN LJ
z: « co
c :> ~ c:
CO LJ UJ U
a .,:• co
L. CD
o u a ^
0 £ CJ MLV: z c: coLJ c a i. c:
||| 1 =5
£ Z > CO <3! CO
x: LJi-ii li 11 i! a >LJ a
CJ
~ '• '- Z COA A <r IN
•N "(•)<• >
: A -r -H Q a
_j _j _j _j c: z
v c? v v KE: n r £ o co













































-* "» -1 .^  -^ .
.
2 O O
CO >C - a a r c x j i z
" ":" ~^" *t* j
CO CO CO CO _l X > X







« jo iio uo \n co N co
-0 O N * ••« If) O 'JO
O CO C) 0 CO 0 *+ 0
ID u") to *o o r*-* Is* o o *-«•*-« o <r \f\ u") ><> >o
••<«-« »-* •-* «-^ *-« •-* el O1' CJ CJ r i C"4 oj c*J ci cj




































r - r z z LJ
> X X X X >
Q Z Z Z 2 0
CO CO CO CO CO
<) <3- <<• »r >J-
^ O O O O
N ^- o o ^ -^ n n co co «-
oj fi c? c) ro co c^ c^ co co co





























0 -0 CO -0
CO « w- «N
^1 «H O »-<
«r 1:0 tiO O *0 N N
CO C ) CO CO CO CO CO





















































o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o





















































































































































































































































































































































































u~> •-• liO -• -i N CO tiO
» - < « 3 - * O - - ' O ' - < « - <


































































a) in o s) N

































































































c^i n i'o c"?
i-l * 1 A J A.^































z : E H
•> * Li.
a ^1 Q LJ HI C3 CO
r^
> X CO > X > X
0 Z D 0 Z 0 Z
-0 CO liO <> CO -O
Cl «• (•! CO «- »N
— P CO " O -•
«• .^- J") aO <> x) N N p P -^ r1 V.'










































































«^ c- jo in o <•>


































N .~- P P
i"-"^  f-"\ <" ^J"






















0. C. C.to co co o z a :r
0
X X X > X > ' - ~ l ~
O O U O Z O O CJ UQ Q a z : « - < z : c , x c :
CO CO CO -0 CO O ^ CO(^ h^ N ^t v- p *j- JO
O P P -« p — « CO CO
" -• 0-1 C-J CO CO «T «• JO llO -0 -O N r- P P «



















C O O Q O O O O
o o o o o o o o
o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o c> o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o
4-50
sum of the samples, and the sum of the squared samples. A flow chart
for Program 4.4.2.5(1) is provided in Figure 4.4.2.5(1).
Program 4.4.2.5(2) calculates the mean, variance, and standard
deviation of the data using the formulas
MEAN - 1 j X, ,
Variance (S2) = -L [ I X.2 - 1 ( I X.)2], and
n
~' i=l 1 n i=l 1
Standard Deviation(S) = /T
A PDCP with this capability would typically calculate and transmit the
mean and variance of sensor data acquired between transmissions rather
"than "transmitting a Targe number of data points. This will significantly
reduce the load on the satellite data collection system by reducing
bandwidth and data storage requirements. In addition, this data prepro-
cessing operation provides the user with immediate knowledge of the
average size of the sample values and the dispersion of the samples
about the mean.
A flow chart for Program 4.4.2.5(2) is shown in Figure 4.4.2.5(2).
The data accumulation; data preparation for mean, variance, and standard
deviation; and mean, variance, and standard deviation subroutines require
a total of 150 bytes of program storage and 28 bytes of stack.
4.4.3 Data Formatting and Transmitter Control
Data formatting and transmitter control are two of the four basic
tasks performed by the hardwired control logic currently used in most
DCP designs. Special emphasis has been placed on developing data format-
ting and transmitter control subroutines for each of the major data



















Figure 4.4.2.5(1) Flow Chart for Data Preparation for Mean,




DIVIDE SUM OF SAMPLES



























Figure 4 . 4 . 2 . 5 ( 2 ) Flow Chart for Mean, Variance,
and Standard Deviation Subroutine.
4-53
precise timing. Normally, both data formatting and transmitter control
will be provided by a single subroutine in order to reduce the amount of
RAM required for data storage. For example, in the GOES data transmis-
sion format an eight-bit data byte is encoded as two 11-bit ASCII words.
Each ASCII word is then Manchester encoded before transmission, Thus,
as many as 44 bites of RAM would be required to store only eight bits of
data. However, if the microprocessor is sufficiently fast, the RAM
allocation for data storage can be reduced 82 percent by performing both
the ASCII and Manchester encoding in real time during transmission.
The transmitter control programs illustrated in this section assume
transmitter modules which operate in basically the same manner as the
Landsat-GOES convertible transmitter designed by Ball Brothers Corporation
[6]. This transmitter module was chosen because control signal specifica-
tions were readily available. Note that the programs presented in this
section can easily be modified to function with any reasonable transmit-
ter design.
Ball'Brothers''transmitter control signals INTEGRATE, TRANSMITTER
ENABLE, and ±15V POWER ON are designated as INT, XMITE, and XPWR, respec-
tively. To demonstrate the versatility of a PDCP, additional control
signals which could select Landsat (LS), GOES (GO), TIROS-N (TN), or
TWERLE (TW) transmitter modes are provided. Normally, a particular PDCP
would be required to transmit data to only one type of satellite, and
thus a simple modular transmitter designed specifically for that satel-
lite could be used. In this case, control signals LS, GO, TN, and TW
would not be required. However, if an electrically convertible trans-
mitter is available and a PDCP is required to transmit data to more than
one type of satellite, the LS, GO, TN, and TW signals would enable the
correct transmitter mode.
The 8080A programs listed in this section assign transmitter con-
trol to output port XCNTR (Port 1). Biphase data to the transmitter
appears on the least significant bit of output port XMIT (Port 0, see
Section 5.1.1.4). Bit assignments for the individual control signals on











































control signal is specified in Table 4.4.3(1). As an example of micro-




The first instruction moves the octal byte 124 into the accumulator, and
the second instruction causes the contents of the accumulator to be
latched into output port XCNTR. As a result, power is applied to the
transmitter, GOES mode is selected, and the integrator is disabled as
specified by the binary code 01010100.
Timing is an important consideration in transmitter subroutines.
Correct reception of data at the satellite depends upon the self-clock-
ing characteristic of the Manchester code. The transmission rate must
be held constant during each transmission, and the 0 ->- 1 or 1 -»• 0 transi-
tions representing data must occur precisely at the middle of each bit
time. In addition, the transmission rate must be held within a reason-
ably tight tolerance over the operational life of the PDCP, which can be
greater than one year. Because some variation in the frequency of the
PDCP master clock must be expected, the transmitter subroutines should
not be allowed to contribute to the total error budget. The entire error
budget can then be applied to the system oscillator so that the cost of
the clock will be minimized.
Since microprocessor controlled operations can only occur at dis-
crete time intervals defined by the system clock, the clock frequency
must be chosen to provide an integer number of states during each phase
of a data bit. This technique has been employed in the design of the
model PDCP (see Section 5.1.1.1). A low frequency clock was chosen so
that the microprocessor could be interfaced with inexpensive, low speed
memory without the need for a wait-cycle generator. Further, the specific
600-KHz CPU clock was chosen so that an integer number of states will




















UNUSED BIT provides don't care condition
to minimize the number of instructions
required to initialize the transmitter
data port (Port XMIT)
Selects TWERLE transmitter mode
INTEGRATE inhibits carrier modulation and
thus control clear carrier transmission
Selects Landsat transmitter mode
Selects GOES transmitter mode
Enables the transmitter RF signal
Controls power supply to transmitter
Selects TIROS-N transmitter mode
4-57
transmission rates. This restriction on the microprocessor clock does
not significantly reduce the potential speed of the microprocessor. For
example, only a 0.225 percent increase in the theoretical minimum cycle
time of the higher speed 8080A-1 microprocessor is required to satisfy
the restriction. Table 4.4.3(2) lists the transmission rates for each
major data collection satellite system and the corresponding number of
states within each phase of the Manchester-encoded data stream for an
8080A with a 600-KHz clock and for an 8080A-1 with a 3.07-MHz clock.
Note that the microprocessor must output to port XMIT at a rate equiva-
lent to twice the data rate.
TABLE 4.4.3(2)
TRANSMISSION RATES FOR THE LANDSAT, GOES, TWERLE,












Number of States Between Phases of













4.4.3.1 TWERLE Format Transmitter Subroutine - Specifications for
the TWERLE data transmission sequence are shown in Table 4.4.3.1(1).
Program 4.4.3.1(1) is a listing of the TWERLE format transmitter routine
written for the UT PDCP. This subroutine provides complete control of
the transmitter and generates a Manchester-encoded data stream at a rate
of precisely 100 bits per second. A simplified flow chart for Program
4.4.3.1(1) is illustrated in Figure 4.4.3.1(1), and a detailed flow chart
for the data transmission block is presented in Figure 4.4.3.1(2).
4-58
TABLE 4.4.3.1(1)
TWERLE DATA TRANSMISSION SEQUENCE
SPECIFICATIONS
Transmission Interval: 1 second nominal
Transmission Rate: 100 bits per second
Coding: Manchester encoded with a 0 -*• 1
transition representing a 1
Transmission Sequence:
1. Transmitter power-up followed by a 1 second warm-up delay
2. Clear carrier transmission for 0.32 to 0.36 seconds
3. Data transmission
a. Bit synchronization code (10101010) (8 bits)
b. Frame synchronization code (110101100000) (12 bits)
c. Address code (assigned to user) (10 bits)
d. Mode bits (2 MSB's of radio altimeter data,
LSB first) (2 bits)
e. Data bits (32 bits, LSB first)
1) Radio altimeter data (8 bits)
2) Air temperature data (8 bits)
3) Air pressure data (8 bits)

















































































































LJ LJ LJ £ LJ U
_l _l _l CO _l _l
Ci Ci Ci Z Ci £i
LJ LJ LJ CT LJ U
333 Ci 3"3
1- H I- I- i- H
O
O
O M CO -0
O If) ID O
CM O -H « ••« *i
II II II II II
* O ~
II II II It II
COO -<
I- I- Z Z O O t- CO CO
Q w 2 > i - t . O D CiCi
















































































































> ID x cr
























O O «-i CO -0 • O -•










O <!• t «f O -0 O O O O O -0 O OO <t *t *f *t <• bO llO U") U"> u~) L~i ^ 0 >0
O M M CI CI CI CI CI CI CI CI Ci CI CI
























E 1C 1- LJ
OH LJ H
CT E Z •-•
L. Z CT H _l
Op -I
CO LL > UU CD i- a H
«-• z cr cr
C- w _J Q tO
cr a L. u
> z c: u.
LJ to "
U Cl. H D to
E LJ Z G DK a LJ u a
H > CT E
. LU •-•
z u cr to z
o LJ c. cr
.wtO -.-.LJ
CO CO LJ -L
CO CO "-i O H
*-* *}" ""•" Z
E O H LJ a
z co LJ cr
cr . . L. o
cr o co c ca
H CO LJ CT
O LJ H
a: H cr z E
LJ . 0 « LJ
•i o a H
a: LJ <r E to
or co c: >
<r E o to
CJ N CC U
111 O H CO
cr o LL cr E









































































cr ^ • ;
O U LJ 3




o cr o i
z H z ;M cr >H a to o
z z
o cr <-• to .
o. cr a a














iio tio r- N
CM CM CM CM
oo co co o>i
O 0 0 0









































O O CM CMt^ r^ r^» j^
C-I CM CM Cl
CO CO CO CO
0 0 0 0
































































(••) CO t f
r^ r^» r^ r^
CJ Cl Ft Cl
O 01 (1 ,'1
O O O O



















































































































M M CO CO 1)0 ll")
'"i '^  '"^ O O O
0 Cl O Cl CO O
O CO 0 C> CO Cl
o o o o o o
























































*0 ^3 N N
O O ^ O
CO CO CO Cl
CO CO CO 01
o o o o


































-^ ^ oo co «• «r
O CO 00 CO CO 00
CO CO 00 CO CO CO
o o o o o o













1-1 ' • LJ
-P
<*•
M lL'Z i cr
o a o
















X z z r a cr
a a a a x >
cr cr cr cr z oQ a a a 1-1 E
•
in in in in o
o o o o o
*n in <5 <!* N f^ o o »-< — « cj
co ci 01 '.'••> 1:0 co io o •:••> •:••' (*••>
co o co c^ »••") o co co C'i C-. ,-.-»
o o o o o o o o o o o































































































































































tO V Z i C£ Zi C
1- •-! : Q H U









































































































































































































































































































































































































llO N CO * N CO CO 1)0 -«
N O O N O O O * - " O












CM O O t t llO 111 s5 ~0 N N O O -" -< fl- rr N N
«M CM CM CM CM M C» M M CM CM CO C> CO CO CO CO CO CO
o co co co co co co n co o co co co co co co o co co
O O CO CO CO CO CO CO CO CO CO O CO CO CO CO CO CO CO
ooo oooooooooooo oooo
ooo oooooooooooo oooo
04 C^ J ^ f 1^" *0 ""0
CO C1 CO CO CO CO
CO CO CO CO CO CO
o o o o o o
o o o o o o
O O •-!»-<in m in in
CO CO CO CO

































CO LU Li <r
CO £ ;
>-• <r co a
£ CC i- 3
CO L. « H
•z. ca
<I L. CO
c: o <r co
i- H LJ
o <r t;
CO t- Q Q
_l >-« D






















































































































































































































































































































N S IN O O N W CO O 111 111 O <0 N S f-J N O CO 111 UO -0 >0 O O -< -H <t <T 111 «0 >0 O O -< -« M N >"0 CO 111 111 O O -i -H «f <t
111 bl 10 ^ 0 <t >0 v? >0 >0 x> <> O *O <) ^0 N N N N f^> rv |% r^ o O O O O O O O O *-* •-* w-t ** •* *-* "^ *^ *H -1 C-l C-M"-I M CI C-Jto co o co co co co co co co ci co co co co co co co co o co ro co T t * i- T t *r *t *r <r *t <r c- <t t T <r «• >»• <r <r «r t ^r «-































































































































































































































liO O li") <»•
o \n t*- <>
CO O « CN
o -<
rt CO
n iii N rs o o <r> fi if> (IT N NIN N >N r-i fo co co co co co ci co
« t * r « f « r < f * r < r * r < j ' < j ' < t - v
co co co co co co o co co co 01 co
o o o o o o o o o o o o
O O G O O O O O Q O O O
o o
CO C) 0> CO CO CO CO CO CO CO O CO CO CO
o o o o o o o o o o o o o o
o o o o o o o o o o o o o o






I ENABLE TRANSMITTER RF,
NO
MODULATION
MOVE BIT SYNC AND FRAME






















Figure 4 .4 .3 .1(1) Simplified Flow Chart for
Subroutine TWXMIT.
4-65














Figure 4.4.3.1(2) Detailed Flow Chart for the Data
Transmission Block of Subroutine
TWXMIT.
4-66
Each TWERLE DCP is assigned a unique ten-bit address code which is
normally plug-wired [7]. The TWXMIT subroutine assumes a similar arrange-
ment in which the PDCP address is plug-wired on two bits of input port
ADRS1 and eight bits of input port ADRS. These input ports are sampled
during the clear carrier portion of each transmission, and the plug-wired
address is temporarily stored in the RAM data block. The bit and frame
synchronization codes are also moved to the RAM data storage block tem-
porarily so that the data can be transmitted from sequential memory
locations. Table 4.4.3.1(2) illustrates the format of the RAM data block.
TABLE 4.4.3.1(2)




































1 0 1 0
1 0 1 0
Xl X0 ° °
X9 X8 X7 X6
A A A AM5 4 3 2
T5 T4 T3 T2
P5 P4 P3 P2
Pt5 Pt4 Pt3 Pt2


















TWERLE DCP's transmit to the RAM's system aboard the Nimbus-F satel-
lite. This system relies on time and frequency division multiplexing of
the data from the various DCP's to prevent transmission interference [8],
In present TWERLE DCP designs, time-division multiplexing depends upon
establishing a random variation in the length of the clear carrier
transmission from each DCP. An average clear carrier transmission time
of 0.34 seconds with nominal range of 0.32 to 0.36 seconds is desired.
Currently, an imprecise one-shot circuit which must be manually adjusted
for proper timing is used to control the clear carrier transmission time
[7] and prevent two systems from interfering with each other for an
excessive period. The TWXMIT subroutine listed as Program 4.4.3.1(1)
makes a substantial improvement over this system. A software delay
routine establishes a minimum clear carrier transmission time of 0.31952
seconds which may be increased to a maximum of 0.36048 seconds according,
to the formula
T = 319.52 + 40A,
where T = clear carrier transmission time in microseconds, and A = deci-
mal equivalent to PDCP TWERLE address. Since each TWERLE PDCP is
assigned a unique address, this technique guarantees that two systems
will not remain in time sequence and interfere with each other. In addi-
tion, the transmission interval for each TWERLE PDCP can be computed
from the address assigned to that system. Any variation from the
assigned transmission interval would provide an early warning of possible
system malfunction. Also, the need for manual adjustment of the trans-
mission interval is eliminated.
The TWERLE format transmitter routine uses a general-purpose, long-
delay routine which is 11 bytes long. Only 123 additional bytes of ROM
are required to store the program. At present 100-piece CMOS 512 byte
ROM prices, the incremental component cost of providing the TWXMIT sub-
routine as part of a standard PDCP ROM is approximately $9.85. In addi-
tion, this subroutine utilizes 12 bytes of RAM for data and stack storage,
10 input bits to specify the platform address, and 8 output bits to pro-
vide data and control to the transmitter.
4-68
4.4.3.2 GOES Format Transmitter Routine - Specifications for the
GOES data transmission sequence [6] are presented in Table 4.4.3.2(1).
Program 4.4.3.2(1) is an assembly language listing of the GOES format
transmitter routine written for the UT PDCP. This subroutine provides
all necessary data formatting and encoding as well as complete transmit-
ter control. In contrast to the TWERLE format transmitter subroutine,
Program 4.4.3.2(1) assumes that the unique 31-bit address code assigned
to each GOES PDCP is either stored in PROM or plug-wired to a memory-
oriented input port. Both ASCII and Manchester data encoding are accom-
plished in real time during transmission to minimize data storage
requirements.
A flow chart for the basic GOES format transmitter subroutine is
illustrated in Figure 4.4.3.2(1), and a flow chart for the BIPHS sub-
routine called by the GOES subroutine is shown in Figure 4.4.3.2(2).
Since the amount of GOES data transmitted is variable, the first byte
of the RAM data storage block is used to indicate the current number of
data bytes. Twelve additional bytes of RAM are required for stack oper-
ations. The GOES transmitter program, .including subroutine BIPHS and the
table area required to store preamble data, occupies 225 bytes of ROM.
This program also requires the same 11-byte, general-purpose long-delay
subroutine used by the TWERLE format transmitter routine. Primarily
because of the ASCII encoding requirement, the GOES format transmitter
subroutine is significantly longer than either the TWERLE, TIROS-N, or
Landsat transmitter programs. Nevertheless, the GOES transmitter routine
would occupy only one-fourth of an 8K-bit ROM. The incremental component
cost of providing this subroutine in a standard PDCP ROM is approximately
$18.02.
4.4.3.3 TIROS-N Format Transmitter Routine - Program 4.4.3.3(1) is
an assembly language listing of the TIROS-N format transmitter subroutine
written for the UT PDCP. This program is based on the preliminary
TIROS-N DCP specifications [9] presented in Table 4.4.3.3(1). A flow
chart for Program 4.4.3.3(1) is illustrated in Figure 4.4.3.3(1). The
TIROS-N transmitter subroutine provides real-time Manchester encoding
of the preamble and the 32 data bits. Data is transmitted at a rate of
400 bits per second using the standard transmitter control signals
4-69
TABLE 4.4.3.2(1)
GOES DATA TRANSMISSION SEQUENCE
SPECIFICATIONS




100 bits per second
Preamble - Manchester encoded with a 0 -»• 1
transition representing a 1
Data and EOT characters - ASCII encoded then
Manchester encoded as above
Transmission Sequence:
1. Transmitter power-up followed by a 1-second warm-up delay
2. Clear carrier transmission for a minimum of 5 seconds
3. Preamble transmission
a. Bit synchronization clock (250 bits minimum)
b. Frame synchronization code (100010011010111) (15 bits)
c. Address code (assigned to user) (31 bits)
4. Data transmission (up to 2000 bits)
















y ^^<r o co a
Ci 1- D Z
CD 0
O L H O£ D <r u
L E CO ,
u. c: o
c: o o c:
LJ L. CJ
1- Z w
(- O CO E
H i-H LJ
E CO 0 >0
CO CO O <'
Z I"* *i"
^ E Z *0
e co >-i <i
<r c «
H DC H
<r i- <r cE a
u. co ~
o _i a H
L. O LJ «
c a 3
CO H O
Ul Z O £
0 0 Z 0
















































































































O 1- CJ h-
co z
c; z z <r
LJ 0 0 H
3 CJ i-i CO
O CO ZL cr co o
LJ i-< CJ
c: »-i ELJ e: co L.




z <r <r H
« LJ i- i-
e _i <r •-<H o a Eto
CO CO 00 Z
LJ LJ LJ 1
0 0 0 £









































































































LJ 3 O CO













































CN -• f-I * O
II O II « O -O <t-
<x ii e: u -i -i oi- t- t- o n ii o
<r « z L o i- n
a E u i- u a o




Z CN _l O Z <t CO _l
O - L J - C J . - L J
























































O O —i «t * O <t-
O O O f -I <' -O O
o o o •-• —• —• o
o o o o o o o
M O O O O O O

























O O O N f'' t «*• N S iN M t t -O O O O CO CO O -0
o o o o o o o o o -« -i -• -i -• ~ r-t M M n IN c-j
o o o o o o o o o o o o o o o o o o o o o
000
o o o
N N CN M CO CO llT If) N Nf-i (i co co co co co co o co







o o o o






















































































































£ CD _J LJ
> > CO Ul CO Z «-i
<r <r Q ZLV: er HQ
_i _i z cr i- LJ
u LJ »-i c: z co o LJ





















































































































































































































































pv CO •-• «H —•in N tn uo uo








•o in >o -o










S N O O N N CO CO <T <f UO UO O O -i -<
t *t uo uo in \i~> uo uo in uo uo uo -o -o >o <o
0 0 0 0 0 0 0 0 0 0 6 0 o o o o
s f ' ^ J ' ^ O ^ O N N O O
^5 <5 *>0 ^ *0 *0 ^« t^
o o o o o o o o
<N CN co co «r «»• in in .N N o o
r^ r^ r*^ r*** r^ r** r^ r^ r^* t**1 o o
O O O O O O O O O O — -i
CO CO «*• «t- <i »0 r^  N N iN CO C"i
O O O O O O O O -. ^.
 rt .H ,






























































•rt .-« N CM
CM N M M
O O O O























































10 in o >0(t IN CI CM
O O O O


































































































































































































































u > "h- >











CO -« CD LJ
•H w O Ci
Z Ci t. O





CO 1- -0o -" c^
-o -o M in
*t" o *f 01
CO CO CO 0
-o -o o o M ci in in
" ^ ^ ^ ^ * 2 S
o o o o o o o o





















1 - 1 O X
i- CO
CJ _J i-"
Ci ~ CO >t- ui cr <r
CO > 1- _J
z cr co u





> CO w >
_J D > _l






N 111 -0 ON * <r' o
« CO 0 0
~0 -O N N O O M N
<f «r y »f ill lil in in
O O O O O Q O O























































co t- bo in
111 ill liO 111
o o o o










































































































































CO CO UO ul
>0 ijj >^ xj
o o o o















'_ ' '— *
co cr
•.i- LJ
LJ !.:"' • —
_j , —
CJ LJ .^.
r-t \ — O ' ~1^
IZ ^;
~ '"."i —-
•— ~i '_J C"
z c; _j -r-
LU LL iU: 4-:
'^ ~ "— *~_t
Ci _l -- c;
3 X Z >'.
CJ -ilU X
X O Oj— 1— '^j — "'
CO T~'
U. LJ L_ ^ — '















O O -< -iIs* r^- f^* r^-
o o o o




























































N M 111 bl
^ ~ ~ £
O O O O

























*0 *o r^ Is*
Is* N r*s r^-
o o o o













































O > CL >
cc -J z: _j










N O O CO N
— « O O O N
O O O CO -"
O O •-• — CO bl 111 O O
CJ CN Cl Cl Ct CJ Cl Cl Cl
Q O O O O O O O O


















































































































































N N — — Cl
Cl Cl f-l Cl Cl
o o o o o





























































































































o o *-* c.
, I-H
^ »n *^* co
CO _l
H *"* *~* X~ J




O CO N O -O
O O N O -•
O O N O CO
sO sO %O O 111
N O vt O -i
O 0 0 0 CO
o o ("•) r-j c~ M" *o ^o o oi*-i f o C'"i f '^  o i" ^  co i"1^ ^r *i"
ri o ci ci ci ri « ci ci 04
• O O O O O O O O O O

























































a zh- to to to •- -•
o to u u LJ o -
LJ LJ h- h- 1- —
•. i- cr cr cr
<T h- h- (- H Q
z H to to to to u
c to <i i-
O O O _J H
Ll_ Is* * - < • - ( *H i-<
o LJ z:
s>- > - > - > • ~" 0' '
to cr <r cr cr <- zi- _i _i _j _i <r
CJ Q a Q Q ~ P
z: co
X
= = z s: o o
^ Q Q Q Ci N
o cr cr cr o z






•0 -4 - -• « C.
^ li"* b") IP *-> •"•
^ 6 o 6 o o
o o <r <- u"> U"> <• ^o N rx q o
04 04 OJ OJ 0-4 04 01 OJ 01 01 C-'i 04
o o o o o o o o o o o o

































































































co n iio uo ~o -o -< — co co i/o uo
llO 1)0 I") UO 10 1/0 -C> -O ~0 <i vO -0





























































































= I Z a
CM CM
> >- x > <x M i-










If) 111 CO 1)0 * CM -4
O O LO S <i O -•
CO CO O - 'CM CO CO
•* -i CO CO UO UO UO -0 *0 fx |x o O CO CO
N (N (N (M CM CM C-l CM CI CM M CO CO CO CO
o o o o o o o o o o o o o o o













































g i 3 3 a
d o S 2 ^
ca ca i-i ~ ^ . oto r i- i- t-
O Z _l J- tO
O 3 i_ L. U
u o o L. o o z :-
ci r t- o t- _i
Q to a ca r-
o H ca to to to z
<X CO X CO _J _J 1-1 LJ
<r LJ _i cito z u u o :i
LJ O LJ Z Z CO D
O LJ LJ Z 1- r- <I U
O Ci Z 1-o i- - •z. a co
c. H z o g z to
a 5 z> a o i
t- LJ D . O Ci Ci CO Q
ca o -i ci z z to a
H CT Z i- h- LJ <!
1-1 Q Z LJ h- Ci
c a _ i t - c a c a c a a u
i D ca to to Q z
-i o ca <- to £ z: <E ;-
co z to to £
to £ D LJ LJ fc.
<I £ LJ Z Z O .to LJ z ;- i- a to
D tO Z JO i- £. CO
Z LJ 1- to CO tO LJ
<L Ci _J tO C <L LJ Ci
D tO <X Z Q
Q Q <£ LJ i)0 CO I- d
tr d z N «-i n <r
O O i— <E <I ct L. •
3 tO <T 1 . i 0 £.
LJ ; «r IN Q O
o o <i . -• !••) co ca a
Z ' C' <E a <L C <I tO t.
tO 1- tO O tO tO tO LJ
« 1- 31- f- h- LJZi - c a w • - i i - ' > - i Z i - .
w i ca to ca a ca h- o
Kl '-i >-> L. Ci
1 CO LJ Z LJ U LJ tO Q U
u o e r i - c i C i C i ' - ' r - i
—i LJ i~> i~i o n ca
Z H U. H i- t- O tO tO
C i- tO 0 00 tO tO C £ «
- - -
N -0 -^ O O O
O CM O O O O
,H CO O O O O
ca ca co ca ca caQ a Q Q a a
N -0 -• O O O
O C) O O O O
-« CO O O O O
1)0 UO -0 O N N O O <i -" (N (M
co co co co co co co co co co co co
o o o o o o o o o o o o

























































































































z ~ ca ca
-0
*»• CO
>- >-• > c: N c.
_l > _l 0 2 Z
















































































































































































































































































































































































« t - 0
0 CO
111 ~->












O ' - <
CO O
,-, ^, ^4 -4 -H rl ^. IN Cl ft C-l f ( M
CO C-> CO CO CO CO CO CO <~> CO CO CO CO
o o o o o o o o o o o o o
o o o o o o o o o o o o o
N N o o M M co co -o 0 r^ s n <N co co uo uo ~o o N N o N coIN r i co co co co co co n co co co y v f t <r f *t * <J- * in uo iio
co co co co co co co co co co co co co co co co co co co co co co co co co
o o o o o o o o o o o o o o o o o o o o o o o o o


























( CALL BIPHS AND
TRANSMIT A BYTE OF
THE PREAMBLE
POINT ADDRESS REGISTER
TO RAM DATA STORAGE
AREA
INCREMENT ADDRESS
REGISTER AND GET A




DELAY TO CREATE 100
EPS RATE
/ CALL BIPHS AND
fTRANSMIT .FIRST 8 BITS
OF ASCII CODE




BITS OF ASCII /
CALL BIPHS AND
TRANSMIT FIRST 8
BITS OF ASCII EOT
CHARACTER
DELAY TO CREATE 100
BPS RATE
£ALL BIPHS AND TRANS-
/MIT REMAINING 3 BITS
/ OF ASCII EOT I
/ CHARACTER /
DELAY TO CREATE 100
BPS RATE




























TRANSMIT LSB PHASE 2
ROTATE DATA BYTE
RIGHT ONE BIT

























































f -J Cd _l










2 <X H .
<r E co LJtie c:
1- O Q C
L_ "^  ~~
U 0 ?
r 2 o L.
t- i LJ 0
CO CO CO
CO O 0
_i c cr 2




0 1-1 -0 Z
CJ <i CO
<r -o n
E H 0 _l
^ ^ ^ L.
C Q . E
0 ~ 0
O Q CJ
C LJ « 0CL. Q ^
o -
01 CJ t- LJ
*•< 5? ( | r^

























































































, LJ O O
- 3 U M
0 COt. cr co
LJ *->
a: -i E





























































































































































































































































O *+ <t <f O
O o O <r f
O O PI CO CO
00 000
o o o o o
o o o o o
co -i
N f











































>t «r r^ N r -i ct «*• <r -o -o o o
O O O O •-<--•-< -i -• •- >N Cl
O O O 0 O O O O O O O 0
CO CO CO 01 01 CO CO CO O il O CO
o o o o o o o o o o o o



























































































































































































































































































































CO CO CO CO










N N M M CO
co c o «• «r «r
o o o o o
cr H- M >-i r> i-< -^
E D X X O > _l
0 0 _J _l E E a
0 0
0 0
O N O *
o -« o «r
O O CM O
fv CO -i •* O O
ID N O «t r» CO
O CO O O •-• O





































































































„ _ _ . .. . _ . _ _ 00
n co co ci co ci ci co co co co co co co co c> co co co co co co ;o co ci ro o ci
o o o o o o o o o o o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o o o o o o o o o o
N N O O 'N C-l CO CO uO UO f^- N O O — •-• <f ^f UO bO N r^ O O
^ O v C ' r ^ r ^ - f ^ r ^ f ^ f ^ r ^ r - ^ r ^ r ^ o o o o o o o o 00*^ * - *
O O O O O O O O O O O O - - « ~ - i - i - « - i ' - ' " i - ' -,«.-.„
CO 00 CO CO CO 00 CO CO CO CO CO CO CO CO CO CO CO CO CO CO CO CO 00 CO
O Q O O O O O O O O O O O O O O O O O O O O O O





































































































































































































































































































































































































ID M O N CO N bl ^0 >0 N
co o o N n -• o co o o


















N CM CO CO -0 -0 O
« IN
M N O CO
CM C-J CM N
<t u") IT) N
CM C-J CI IN 01 co co co o co CI M UO ID O Oin ijo ijo uo -o -o <5 -O
-0
CO CO 0> CO CO CO CO CO CO
ooooooooo
ooooooooo
CO CO CO CO CO CO CO CO CO CO
O O O Q O O O O O O
o o o o o o o o o o
co co co co co co
o o o o o o
o o o o o o
CO CO 01 CO CO CO CO CO
o o o o o o o o
o o o o o o o o




















































































































































O O -• -< (N (N UO 111 N
CO O O O O O O O 01 O O O O
ooooooooooooo
O O O O O O O O O O O O Q
O O O -> ~ ti M
O O O O O O Q
ON ON M ft >-| f I CI
o o m 0101 (••> o
o o o o o o o
o o o o o o o
0101 «f i- in \n
o o o o o o
n M ci N IN ri
O 01 01 00 01 00
o o o o o o











Transmission Interval: Variable 40, 60, or 80 seconds
Transmission Rate: 400 bits per second
Coding: Manchester encoded with a 0 ->- 1
transition representing a 1
Transmission Sequence:
1. Transmitter power-up followed by a 1 second
warm-up delay
2. Clear carrier transmission for 160 -2.5
milliseconds
3. Preamble transmission
a. Bit synchronization clock (15 bits)
b. Frame synchronization code (000101111) (9 bits)
c. Address code (assigned to user) (24 bits)


























































Figure 4.4 .3 .3(1) Flow Chart for TIROS-N Transmitter Subroutine.
4-84
defined in Section 4.4.3. The TIROS-N transmitter program utilizes
eight bytes of RAM for data storage and stack operations and 124 bytes
of ROM for program and preamble storage. In addition, this program also
uses the standard long-delay subroutine.
4.4.3.4 Landsat Format Transmitter Subroutine - Specifications for
the Landsat data transmission sequence [6] are presented in Table
4.4.3.4(1)- The Landsat data transmission rate of 5000 bits per second
is significantly higher than the data transmission rates used in the
TWERLE, GOES, and TIROS-N data collection systems. Because of this high
data transmission rate, convolutional encoding of Landsat data cannot be
accomplished in real time during transmission from the UT PDCP system.
Instead, a separate subroutine [Program 4.4.3.4(1)] is used to convolu-
tionally encode the data prior to transmission. A flow chart for the
PDCP convolutional encoder subroutine is illustrated in Figure 4.4.3.4(1),
This subroutine is called by the executive program prior to each data
transmission. The convolutional encoding process creates two code bits
for each original bit of data but provides error detection and correc-
tion capabilities.
Manchester encoding, transmitter control, and actual Landsat data
transmission are provided by Program 4.4.3.4(2). A flow chart for the
Landsat format transmitter subroutine is shown in Figure 4.4.3.4(2).
Together, Program 4.4.3.4(1) and Program 4.4.3.4(2) require 188 bytes
of ROM for program storage and 31 bytes of RAM for data storage and
stack operations.
4.4.4 Special Computations
Remote processing of data is a logical extension of the capabilities
of the microprocessor-based PDCP. The question arises, however, as to
what sort of numerical techniques are practical given the present time
and memory restrictions of a PDCP system. In an effort to answer this
question, the Fast Fourier Transform (FFT) was chosen for implementation.
It is a sophisticated and powerful tool in numerical analysis, allowing
the decomposition of time signals into their frequency components. It
has been proposed, for example, that seismic events may be detected by
4-85
TABLE 4.4.3.4(1)
LANDSAT DATA TRANSMISSION SEQUENCE
SPECIFICATIONS
Transmission Interval: 90 or 180 seconds
Transmission Rate:
Coding:
5000 bits per second
Convolutional encoding, rate 1/2,
constraint length 5
Manchester encoded, 1 .-> 0 transition
representing a 1
Transmission Sequence:
1. Transmitter and platform power-up for 50 milliseconds
2. Turn on RF power simultaneous with first serial data bit
3. Data transmission
a. Message preamble (000000000000000)
b. Platform address (assigned to user)
c. Sensor data 1-8 eight-bit words







4. Transmitter and platform power-down
NOTE: The 39-95 bits of Landsat message are before convolutional
and Manchester encoding. The actual transmitted message is




































































































































l~ _J CO L. n: LJ
D 1- CO
-I C CO . Z>
w H >-* C Z
. .,>.« ;h- M.li
Z Q CD C d O
o z ci H <r
O U. »-» Z 1—
o Q c: o co
CO O LJ <I£ ii u H u
c; D z t-
O O LJ HI O Q
L. _l E H LJ
c: a LJ to >
LJ Z Z Q -1
L C 1- <! LU O
t; £ >
E Z H3Z
<r o . 01 o
CC CO H CO 0
o i/> co <r <r
O LJ E LJG a: c; c; co ca
c. t- o o M






















































































































































































































































































Q Q Q Q Q Q Q
X X X
x <r x c x <r x
Z K Z 1- Z 1- Z




















































































































































-. N N N N CO N
N O O If) t N N
O O •« CN -• O O
o p co ci «r «t- ii"> iii «o -o r* N o o ^
O O O O O O O O O O O O - * ' " ' - '
O O O O O O O O O O O O O O o
O O O O O O O O O O O O O O o















































































































































































































































































































































































































































































































































































































































«»• c- N N O O O O f t in !<•> -0 >0 •" "• N N 111 111
N CN (N N O f) O f> C? fl O O O O «r «f t *f «T *
o o o o o o o o o o o o o o oo oo oo
y) ir> • (I
1) 1
0 0 0 0 0 0 0
.O ~0 N N O O O ("I <f * N N
ui iii iii iii <o -o o ~o >o -o -o -o

















































































































































































































































































- -• n M
o o o o
o o o o




































































































111 111 N N
O O O O
O O O O















































O O O O









































































^0 «0 N N O O
0 0 0 0 0 0






























































LJ 0 Q w ''^
> H LJ CQ -0
_l CO CO CU
O CO H Li Z3
> to LJ • «-> LJ C
Z « Ci CQ ~ •,-
O Q H H 4-1
CJ K Q CO U 0
 c
_l C Ci Z Z o
O D n O CI „
h- CO > L_ >;.
LJ _l U U
LJ Ci 1- 0 > >
Z Z _/ -I
•-< (- LJ Ci O O -^
K M CO CI > > '—
D Ci LJ LJ Z Z — -
0 1 CC _l 0 O «*
Ci CO Ci. 0 U 0
CO
CQ ca "^
h- H c-O x x *b





















(N N N tf * S N
N CI 04 CJ C4 C< M
o o o o o o o




























































































































































































N til tr> o o -• -<
O O O «f «»• <f •*
<N
«r O O«r «r
1
 o o o o o o o1
 o o o o o o o
00
O O o o oo o o
4-90
( START J
POINT (DL) AT UATA
BLOCK. FETCH » CYTES
TO BE CONVOLVED FROM
FIRST BYTE IN DATA
BLOCK
LOAD 0'S OF PREAMBLE




FROM ROM AND LOAD
IN DATA BLOCK RIGHT |





FETCH A BYTE OF
DATA AND CONVOLVE




FETCH i BYTES CONVOLVED
FROM BEGINNING OF DATA
BLOCK
CONVERTS TO NUMBER OF
BITS TO BE BI PHASED
AND STORE AT BEGINNING
OF BLOCK
( RETURN j




























































































































•-« Z H L.
co «-< a o <r co
CO CO H CO H
•-• D CO CO D
E Z U C.
CO LJ CD M CO H
Z CD Z D D
<E <X O Q <£ O
cr co u LJ o(- CO LJ Z Z
LJ CO CO r LJ
U E O '-> O LJ
•s cr _i •-" 3
H <t O Cu r H
H « E 3 LJ
co « E o ca
_J Q U Z
O -0 O O CO
c: a o <i M a
H LJ -0 HZ
Z H O LJ O O
OH . (T 13 0
o <r -H <r t: u
E H COE £ <r co co >-
<E O Z Z _1
c: L. r o w _i(D t- w t->
O H M H O E
1C C 3 O Ci
C. CO ZOO
Q CC D <£ 111












































































II LLZ II LL
O Z 0
cr o c:3 LL 2
a. c: CL
N -0 O


























































































































































O O CO CO
O O s-\ f^\J \J \J
o o o o
Ol Ol 01 Ol
o o o o

































































































-0 -0 O O
o o o o
M 01 01 01
O O O O

















































































O C A •- Z L
U M ; ca LJ nLJ L. ; ;: a
CO H 2
>-i o ca co o
_l H a Ci LJ H
J | ! •—(
>-* H H L. C£ U
E Z CO H1-1 c: H H
O O >i p LJ LJ
^ — ... ... — ...
H
E >H CO
r <r x LJ
X > h- t-.
Z O D >




O -0 CO -0
t N Ol CO
O -« CO O
01 (N O C"> * *T -0-0
o o o o o o o o
Ol M 01 ivl 01 01 01 01
O O O O O O 0 0











































































































































































































CL x > >
E Z O O






































ID -• CO tf> * M ^  N O N O
«l-«tiih.OOVNOrx N
O O O -• (M CO O — O -H O o
-0 10 O CO
N O O O








O O •-• «t 111 O r> M C> UO -0 N N
N N M (M (N M iN CO CO (0 CO CO fO
O O O O Q O O O O O O O O
(N N CJ C>( M 0-1 N (N >N >N M Cl lxl
O O O Q O O O O O O O O O
ooooooooooooo
.-4 r. fO CO <t t <3 O O CO CO * t U"> ll"> -0 -0 N N Q O M Cl *
o- »r v <r t v vf 10 uo uo ii'i ui u~> i)> ii^  u") b^ 10 iii ~o -o so vj ^
O O O O O O O O O O O O O O O O O O O OOOOQ
IN (N N fI M >N Cl IN IN IN fl fl N fl iN iN rt Ci iN ft C-l Cl Cl f-l
O O O O O O O O O O O O O O O O O O O O O O O O





































































































































































































































































































































































































































































































1^ -• Ot^ o o




















N 10 O O O
N O O O CM
-000 O 0
o o "i *+ (N (N O O t 't N N
O O O O O O O Q O O O O O O
N N M M 0-4 M 01 VN C-l 01 M C-l 01 01
oooooooooooooo
oooooooooooooo
O O IN O 0) <i -0 O O 0-1 <f
O O O O O O O - " — -! —
Ill 111 N N —i
********(*!( ' n ID r^ o o r-i NI 0-1 0-4 CJ O O O O













MODE RF POWER OFF
DELAY 50 MSEC. FOR
WARM-UP. SET UP DATA
ADDRESS POINTER
GET # BITS TO BE
BIPKASED FROM FIRST
BYTE OF DATA BLOCK.
INCREMENT DATA
ADDRESS POINTER
fOUTPUT FIRST PHASE OF,
FIRST DATA BIT JUST /










PHASE OF DATA BIT
DECREMENT BIT COUNT
OUTPUT FIRST




GET NEXT BIT TO BE
BIPHASED
NO
Figure 4.4.3.4(2) Flow Chart for the Landsat Transmitter
Subroutine.
4-95
an analysis of their frequency components, and with this in mind a classi-
fier based on the Bayes decision rule was investigated for its possible
practical application to seismic event detection. Figure 4.4.4(1) shows
how the FFT and Bayes classifier would work together in a detection
scheme.
4.4.4.1 The FFT Program - The implementation of the fast Fourier
transform (FFT) program was carefully studied. Because of limitations
in execution time and memory size imposed by the PDCP, the commonly used
forms of the algorithm were unacceptable. Most involve considerable
manipulation of complex numbers, in particular, complex multiplication.
Also, most existing FFT programs require the calculation of weighting
factors, which are themselves complex and trigonometric in nature.
A method which avoids these time consuming problems was reported in
a short paper by Dr. C. M. Rader and N. M. Brenner [9]. It outlines an
approach whereby only pure imaginary weighting factors are required,
thus decreasing the total number of multiplications necessary. In addi-
-tron, 'the •wevghttnxffa'ctors 'fall in a convenient range of values, from
jO.5 to j5 (for 64-point transforms or less).
The derivation of the Rader-Brenner form is outlined in Appendix B
and need not be repeated here. However, it is helpful to see the flow of
the process. Figure 4.4.4(2) outlines the sequence of events graphically
for each data byte pair (complex data value) of a 16-point transform.
First is the summation stage where c is calculated for the two-point,
four-point, and eight-point cases. Recall from the derivation that c =
a2N+l + a2N 1 + Q' wnere n = 0, 1, ..., N/2-1. Next, the data values are
permuted so that the final output data will be in numerical and not bit-
reverse order [10]. That is, cell one will contain the first Fourier
coefficient, cell two will contain the second, and so on. Finally, the
two-, four-, eight- and 16-point transforms are calculated.
As can be seen from the 8080A FFT program source listing, (Program
C(l) in Appendix C) a FORTRAN program is used as the logical model for
the assembly language program. There are several advantages to this

























































break down the operations of the program. Secondly, a program written
in FORTRAN (with certain hard-to-implement instructions like DO omitted)
can be reduced to minimum complexity and debugged on a logical level
before assembly language programming begins. Thus, one is assured of
the integrity of the logic before proceeding to assembly language pro-
gramming. The 8080A fast Fourier transform subroutine (FFT80) requires
1102 bytes of ROM.
After the FORTRAN framework is decided upon, compilation to assembly
language can begin. However, assembly by a FORTRAN compiler would be
quite unsatisfactory. Very great increases in efficiency and speed can
be achieved by taking advantage of the architecture of the 8080A CPU.
For example, instead of storing commonly used program variables in mem-
ory, which would require time consuming memory read/write operations,
these values can be retained and operated upon using internal registers.
It is, of course, occasionally necessary to free registers for other
uses, which is achieved by pushing and popping the variables on the
stack. The total time required for these operations is small compared
to the time required for repeated memory accesses.
It would have been preferable to use a word length of 16 bits in this
program as it allows greater resolution of incoming signals and removes
the fear of overflow errors. This would mean complex data values would
be 32 bits long. Unfortunately, the 8080A's double word (16 bit) instruc-
tion set is quite limited and very time consuming, while separately man-
ipulating each byte of a double word is even more inefficient. The only
reasonable approach then is to use 8-bit values, thus trading resolution
for speed. In a few intermediate steps of the program it is necessary to
expand to double words, such as in manipulation of the variable SUM in
the add up stage of the program. SUM is a mean value which first con-
tains a sum of values and then is divided by the number of values summed.
Before division, SUM can easily grow to a value in excess of eight bits
in length, so the word length is increased. After division, of course,
eight bits is sufficient since an average cannot be larger than the
largest of the averaged values.
4-100
The 8080A does not provide hardware multiplication, and conventional
software multiplication is quite time consuming especially considering
the non-integer factors involved. Thus, an alternate multiplication tech-
nique has been developed. From the development in Appendix B, it is seen
that the weighting factors are pure imaginary and have the values:
wk = 0.5 cosecant(27rk/N)j, k t 0,N/2 .
In Program C(l), 2k is defined Ml and N is defined M2. That is, wk =
0.5 cosecant(frMl/M2)j. The sequence M1/M2 is:
M1/M2 = m/2n ,
where m = 1, 3, 5, ..., 2n~1-l for each n = 1, 2, 3, ..., (log2N)-l
(where N = number of points of the transform). For a 64-point transform,
M1/M2 is the sequence 1/2, 1/4, 1/8, 3/8, 1/16, 3/16, 5/16, 7/16, 1/32,
3/32, 5/32, 7/32, 9/32, 11/32, 13/32, 15/32. A 16-point transform would
require only the sequence M1/M2 = 1/2, 1/4, 1/8, 3/8. Table 4.4.4(1)
delineates the ratios and consequent values of w..i K
The shifts listed in the table are used by the special multiplica-
tion subroutine MULCON (TEMP,K). MULCON multiplies by shifting the value
in TEMP right or left a number of times and adding or subtracting the
shifted value with the original value of TEMP. The number of shifts and
the decision as to whether the resulting shifted value is to be added to
or subtracted from TEMP is stored in a look-up table (called TABLE in the
program). K is the index for TABLE. For example, suppose K = 10g when
MULCON is called. M1/M2 = 3/8 and wfc = 0.54. The value in TEMP is to be
multiplied by 0.54, thus TABLE (10g) = -1 ,+5. TEMP is duplicated in
TMPROD and shifting proceeds on TMPROD. The 1 value in TABLE indicates
that TEMP is to be shifted right one time, yielding 0.5 TEMP, and the
minus sign means that the shifted value is to be subtracted from TMPROD.
Recalling that TMPROD = TEMP originally, we now have TMPROD = TMPROD -
TEMP/2 = 0.5 TEMP. Next, TEMP is shifted right five times and the shifted
value is added to TMPROD, which equals 0.5 TEMP from the last operation. Five
4-101
shifts yield 0.031 TEMP and TMPROD = TMPROD + TEMP/25 = 0.5 TEMP +
0.031 TEMP = 0.53 TEMP. From Table 4.4.4(1) it can be seen that the
exact answer is 0.54; the error is less than 0.01 TEMP. This is
usually less than round-off error when working with integer arithmetic.
Upon completion of the FFT portion of the program, the array DATA,
which initially held the time domain data, now contains the Fourier
series coefficients. These transform values, however, are complex and
for the purposes of Bayes classification, only magnitudes are of interest.
The normal procedure for finding the magnitude of some value (a+jb) is
to take the square root of the sum of the squares of the coefficients,
that is, A2 + ^2 . To speed up this computation for a microprocessor
application, a method is used which does not require the squaring and
square-root routines; only the division routine is required. This method
is described in the following paragraph.
A complex number can be visualized as a vector of magnitude m hav-
ing two orthogonal components. Since m is always positive, the signs of
these components are irrelevant; only the absolute values need be con-
sidered. The absolute value of the smaller component is defined here as
a and the larger as b, so m is graphed.
Larger Component Axis
i
I Smaller Component Axis
It is clear that for these conditions, 45° <_ Q <_ 90°. What is needed is
some function, C(a,b), such that a*C = m, that is, some function that
relates the smaller component to the magnitude. It is apparent that
a*secant(0) = m, but this is a function of 0. The next step is to
express 0 as a function of a and b. Of course, 0 = arctan(b/a), so the
above expression becomes:














































































































,+4 Shift left but do












w., = 0.5 cosecant(TrMl/M2)j
4-103
Thus, C = secant[arctan(b/a)]. Now the calculation of C for each b and
a would be as difficult as the RMS method, but this calculation is not
necessary. Instead, a "window" technique is used, whereby a value C is
associated with a certain range of values of b/a. In the actual program,
the value 8b/a is calculated using a standard division routine as this
preserves more significant digits in the quotient.
Because it is desired to perform the effective "multiplication" of
C*a by successive additions of a, integral values of C are desired.
Further, since the value 0.5a can be easily found and'stored, then C can
take the values 1.5, 2, 2.5, 3, ..., 9, 9.5.
What must now be found is the range of values of b/a for which a
particular value of C will be chosen. It seems reasonable, where the
possible values of C are 2, 2.5, 3, 3.5, etc., that those values of b/a
which yield a 2.25 ^ C < 2.75 should be assigned the value C = 2.5, or
where 2.75 <_ C < 3.25, then C = 3. Using this method, the absolute error
in the resulting magnitude is less than 0.25 times the smallest compon-
'erit. 'The magnitude, therefore, is an approximation; however, this
approximation is adequate for most purposes.
The FFT program composes what can be called the preprocessor part
of the classification scheme. It receives the incoming data and finds
in it certain parameters or features of interest, in this case frequency
components. The next step is to extract those features which can be
used to assign the data to a particular class. For FFT80, feature extrac-
tion merely means taking certain pre-determined complex frequency compon-
ents, finding their magnitudes, and storing these magnitudes in a stor-
age array, called MTUDE. The contents of the MTUDE array become the
input data to the pattern recognizer stage of the program.
4.4.4.2 The Bayes Classifier - The classification scheme investi-
gated uses the Bayes decision rule. In order to understand how this
process works, it is helpful to visualize a space in which every pattern
(input value) is a point in space. Thus, the space has as many dimensions
as the pattern. For example, suppose the three low frequency components
4-104
XI, X2, and X3 are being used to classify a signal. Then for each frame
pattern, x has three components as seen in Figure 4.4.4(1). Each point.
X(F2,F.,,F4), represents a pattern in three-space. If, after a sufficient
number of trials (points plotted), the points are observed to cluster in
groups, the Bayes decision rule can be applied. The clustered groups are
called classes and some decision must be made as to what constitutes a
class boundary. Once the boundaries are defined, each succeeding pattern
will be classified according to which side of a boundary it falls upon.
The Bayes method does not assure that misclassifications will not be made,
but it does assure a minimum average loss in classification; that is, it
assures statistical optimization [11]. The average loss in assigning a
pattern x" to a class j given m classes is
m
where p(x/w.) is the probability density function of w., p(w.) is the
probability of the occurrence of the class w. and L-. is a "loss matrix"
which assigns a loss of zero for correct classifications and a loss of
one for misclassifications. A pattern is assigned to the class offering
the smallest average loss. Consider a simple example. Suppose we are
receiving a signal that has been corrupted by Gaussian noise. The sig-
nal is made up of 1's and O's, so the actual received signal has a
probability density
while p(w ) is the probability of a 0 being sent and p(w-,) is the prob-
ability of a 1 being sent. A reliable classifier can be implemented
only if the two density curves do not significantly overlap.
4-105
In separating seismic signals into normal (background noise) and
abnormal (seismic activity) classes, based on spectral composition,
several things must be known. The values of p(normal) and p(abnormal)
are not critical and can be arbitrarily set to p(normal) = 0.9999 and
p(abnormal) = 0.0001. However, calculating values for the probability
densities of normal and abnormal classes is more difficult. To an
extent these are functions of the location of the seismic sensor. A
PDCP located near a highway, for example, would have a noise spectrum
and probability density different from one located in a more remote
area. The factors affecting the probability density of seismic spectral
components are not well understood and there is a dearth of information on
the subject [12]. But perhaps the greatest problem encountered in the
use of the Bayes classifier on spectral components of signals is that
the signals of both classes are largely impulsive in nature. Impulses,
when transformed, exhibit all frequencies equally, and, seismic and
noise signals, while not pure impulses, are similarly sharp, fast-
changing time functions. The problem then is that any given combination
of frequencies that can be extracted from PDCP processing will be similar
for both noise and seismic signals. That is, their probability density
curves overlap to an extent that they cannot be reliably separated.
It is possible, however, to use the Bayes classifier to separate
patterns with high frequency (impulsive-type) components from those with
only low frequency components. This would enable noise and seismic sig-
nals to be differentiated from calm background activity; but if this
were all that was required, a simple high pass filter would be the
obvious choice.
While the use of Bayes classification of spectral data cannot be
removed from consideration, it is suggested that to be of practical value
very high resolution (multiple point) transforms are required. In addi-
tion, PDCP's must be trained individually with data taken from the sites
on which they will be placed.
The implementation of a fast Fourier transform subroutine on an 8080A
microcomputer requires the addition of 1.1K of memory. It will execute
16 point transforms in 39 ms, 32 point transforms in 96 ms, and 64 point
4-106
transforms in 228 ms at a CPU clock rate of 2 mHz. This demonstrates the
feasibility of performing sophisticated and complex mathematical functions
remotely on PDCP. With the advent of new microprocessors with increased
speed, indirect addressing, and hardware multiply/divide, such as the




1. Korn, G. A., Minicomputers for Engineers and Scientists, McGraw-Hill,
New York, New York, 1973.
2. "Intel 8080 Microcomputer Systems User's Manual," Intel Corporation,
July 1975.
3. Lathi, B. P., Communication Systems, John Wiley & Sons, Inc., New
York, New York, 1965, pp. 89-91.
4. Hogg, G., "A Data Compression Primer," X-Document X-521-65-320,
NASA - Goddard Space Flight Center, Greenbelt, Maryland, August
1965.
5. Kostopulos, G. K., Digital Engineering. John Wiley & Sons, Inc.,
New York, New York, 1975, pp. 309-311.
6. Schoep, V. R., "ERTS/GOES Convertible Data Collection Platform,"
Ball Brothers Research Corporation, Final Report for U. S.
Geological Survey EROS Program Office Contract 14-08-0001-1390,
1974.
7. Lichfield, E. W. and Carlson, N. E., "Tropical Wind, Energy Conversion
and Reference Level Experiment (TWERLE)," Engineering Design Report
No. 2, National Center for-Atmospheric Research, November 1974.
8. Coates, J. L., "The Nimbus-F Random Access Measurement System
(RAMS)," IEEE Transactions on Geoscience Electronics, Vol. GE-13,
No. 1, January 1975, pp. 18-27.
9. Rader, C. M. and N. M. Brenner, "A New Principle for Fast Fourier
Transformation," Unpublished notes, 1972.
10. Brigham, Oran E., The Fast Fourier Transform, Englewood Cliffs,
New Jersey: Prentice-Hall, 1974, p. 175.
11. Tou, J. T. and R. C. Gonzalez, Pattern Recognition Principles,
Reading, Massachusetts: Addison-Wesley Publishing Co., 1974, p. 113.
12. Bath, Markus, Introduction to Seismology, New York: Halsted Press,
1973, pp. 249-251.
5. PROGRAMMABLE DATA COLLECTION PLATFORM DEVELOPMENT SYSTEM
The University of Tennessee programmable data collection platform
development system includes an Intel 8080 based special-purpose micro-
computer, a video display terminal, a cassette bulk storage device, and
supportive system software.
5.1 UT PDCP DEVELOPMENT SYSTEM HARDWARE
A major objective of the PDCP study is to conceive and describe a
programmable data collection platform. To aid in achieving this goal,
the UT PDCP development system using the Intel 8080 microprocessor has
been built. The UT PDCP is designed to serve as a developmental tool
which will aid in determining the feasibility of using a microprocessor
to perform all current DCP tasks as well as additional tasks which are
not possible with contemporary DCP designs. The UT PDCP includes the
capability of simulating the transmitted data messages for typical
Landsat, GOES, TIROS-N and TWERLE data collection platforms. In addi-
tion, the UT PDCP is interfaced to a video display terminal and keyboard
permitting user intervention with the various PDCP demonstration pro-
grams. The UT PDCP is not intended to reflect a choice of microproces-
sors for an actual PDCP; this choice will depend on many factors which
are described in Section 6.
The basic hardware system consists of eight 11'.43cm x 16.51cm (4.5"
x 6.5") printed circuit cards manufactured by Pro-Log Corporation. There
are three 4K RAM cards, two 2K ROM cards, one 32-line input card, one
32-line output card, and the CPU card. The eight Pro-Log MPS components
cards supply 32 parallel input and output lines for interfacing simula-
ted sensors, the system memory (12K RAM and up to 4K ROM), and the micro-
processor chip and support logic. To complete the UT PDCP, four printed
circuit cards have been added to the basic Pro-Log system. The addi-
tional cards include a dual serial I/O card, an analog interface card, a
cassette analog interface and baud-rate timing card, and a utility card
containing hardware system start-up, a baud-rate clock and current loop
5-1
5-2
interface for the video terminal, and single step control logic. All
printed circuit cards plug into a small 12.7cm x 25.4cm (5" x 10") rack
with a wire-wrapped back plane. The rack is mounted inside an attrac-
tive gray cabinet. Power is provided by a small external power supply.
The front panel switches are minimal as control of the UT PDCP is inten-
ded to be from keyboard commands issued from the video terminal. Jacks
for interconnection of the video terminal and cassette recorder are on
the rear panel. Simulation of several DCP functions is provided by LED's
mounted on the front panel. All connections between the cassette
recorder, video display and the UT PDCP are via plug-in cables for ease
of interconnection of the three system components. The only additional
hardware needed to completely demonstrate the capabilities of the UT
PDCP system are a laboratory dual-sweep oscilloscope and a frequency
counter with period measurement capability. A description of the oper-
ating procedure for these instruments is included in the System Operation
Manual. The following sections describe in detail the individual com-
ponents of the UT PDCP system. A block diagram of the major components
of the UT PDCP system hardware is depicted in Figure 5.1(1). Figure
5.1(2) presents a more detailed view of the PDCP microcomputer system
components.
5.1.1 Basic Pro-Log System
An 8080 based microprocessor system was selected for the UT PDCP.
There are several reasons for this choice. -rThe 8080 microprocessor has
an eight bit word size which should be optimal for the PDCP application.
Extensive software support packages including resident text editors,
assemblers, simulators, BASIC, FOCAL, and FORTRAN are available for the
8080. In addition, cross-assemblers, a cross-simulator, and a FORTRAN
cross-compiler are also available. A few recent microprocessors have
extensive software support available now; however, at the beginning of
this study only the 8080A had extensive software support. Due to the
short period allotted for this study, extensive software support was








(for user interaction with system)
UT PDCP MICROCOMPUTER






























































































































i<i iu Oi h- a£
CO O O Ul <C








r-~- CM 3-T >- a:
i— i — • CC <_)
CO CM ^CM n
LU CO
«=C 1— CD
\O CM S >- Qi
f— CD O CQ <C
-^ r-* CXL LJ



























- o o ^  o
5-5
The 8080 based Pro-Log Corporation Microprocessor System (MRS) card
components offer a stripped-down, cost-effective basic system. With the
addition of four specially designed cards, a powerful PDCP development
system is obtained. Other companies were interviewed as a source of
basic system hardware; however, on the basis of economics and availa-
bility, a decision was made to use a set of eight basic cards made by
Pro-Log Corporation and add to them four specially designed cards to
create a special purpose microcomputer. Perhaps a better PDCP develop-
ment system could have been designed starting with only a microprocessor
chip set and no commercial cards. However, due to the short time span
of this study, the ideal approach had to be compromised. Thus, the
Pro-Log MPS cards provide the basic microcomputer system functions, and
four add-on cards were designed to form a powerful PDCP development
system.
5.1.1.1 Central Processing Unit Card - The major component of the
Pro-Log system is the 8811 Central Processing Unit (CPU) card. The CPU
card contains an Intel 8080 microprocessor, a two-phase clock, a power-up
•reset circuit, and data, address, memory, and I/O control logic. A few
timing signals needed for special functions were not brought out to the
edge connector on the stock CPU card. Thus, these signals were either
brought out on spare edge connector pins or generated externally on the
utility card (see Section 5.1.3). To facilitate accurate timing for
PDCP transmitter demonstration programs, the crystal in the clock cir-
cuit for the CPU was changed from 5.0 MHz to 4.8 MHz. The 4.8 MHz clock
provides a basic 1.6666 microsecond (ysec) state time for all instruc-
tions. This state time was chosen to provide an integer number of states
between phases of a Manchester encoded data stream transmitted at the
typical DCP rates (100, 400, or 5000 bits per second). Note that a 1.6666"
usec state time is over three times slower than the nominal 500 nanosec-
ond (nsec) state time for a full speed 8080 system. The slower state
time also permits the use of low speed, inexpensive memory without the
need for wait-cycle generation circuitry.
5.1.1.2 Random-Access Memory Cards - There are three 8117
Random-Access Memory (RAM) cards in the basic Pro-Log system which
5-6
provide a total of 12K of RAM. Each RAM card provides 4K by eight bits
of statis RAM (2102 type, 1.0 ysec access time). An actual PDCP would
not require such a large amount of RAM. The UT PDCP is provided with
12K bytes of RAM to facilitate program development and to provide a
storage area for the text of the extensive comments which accompany the
PDCP demonstration software. The 12K of RAM permits all the programs of
the PDCP demonstration package to be resident simultaneously with room
for additional programs.
Although the access time of the 2102 type RAM's used on the three
8117 RAM cards is faster (1.0 ysec compared to 1.666~6 ysec state time)
than the basic state time of the CPU, the frequency of the system clock
is limited by the access time of the read-only memory (ROM). A
wait-cycle generator circuit could have been added to obtain maximum
overall system speed; however, different cycle times for RAM, ROM, and
non-memory referencing instructions would have complicated software
timing routines. Maximum system speed is not needed to simulate all DCP
functions performed by current DCP's. The three 8117 RAM cards are
assigned absolute memory addresses 0-12K.
5.1.1.3 Read-Only Memory Cards - The two 8116 Read-Only Memory
(ROM) cards provide non-volatile program storage. A powerful system
monitor program resides in slightly less than 3.5K of ROM. General pur-
pose binary math subroutines occupy the remaining 0.5K of ROM. Both
ROM cards accept up to eight 256 x 8 bit Intel 1702A type PROM's. Thus,
each card can accommodate up to 2K of ROM. To keep costs low and still
meet maximum data rate specifications, 1.7 ysec maximum access time
1702A ROM's are used.
The ROM's are ultraviolet-eraseable memories and are programmed
with the department's Intel lee 8/Mod 80 microcomputer. The two 8116 ROM
cards have been assigned the 16-20K absolute memory addresses.
5.1.1.4 Latched Parallel Output Card - Thirty-two parallel latched
output lines are provided by a Pro-Log 8115-1 Output Card. The parallel
output card is organized as four 8-bit parallel output ports. Execution
of an "OUT" instruction causes the eight bits in the accumulator to be
5-7
latched into a particular eight-bit output port depending on the port
address specified by the "OUT" instruction. The output lines are TTL
compatible with a fanout of 10. The four 8-bit parallel output ports
are assigned the absolute output port addresses 0-3. Output port 0 is
normally used for PDCP data output. Bit 0 of port 0 is normally a serial
data output for PDCP transmitter formatted data. Other bits of port 0
provide scope data and synchronization signals as well as front panel
LED data displays. Output port 1 is normally used to drive PDCP status
displays and PDCP transmitter control signals. For example, four bits
are used to drive the front panel PDCP mode displays (Landsat, GOES,
TIROS-N, or TWERLE mode). Other bits of output port 1 represent signals
to control platform functions such as platform power on and off, RF
power on and off, data enable, and data integrator initial conditions
control. Presently, output port 2 controls the cassette read/write
flag LED, while port 3 is brought out to the rear panel for transmitter
timing verification.
An additional parallel output port is provided on the dual serial
I/O card (see Section 5.1.2.1) to control the cassette recorder interface.
5.1.1.5 Parallel Input'Card - The last member of the Pro-Log MPS
components card family is the 8113, 32-line parallel input card. Like
the parallel output card, the input card is organized as four 8-bit
parallel ports. The parallel input card provides parallel data input.
The input ports are assigned absolute addresses 0-3, the same as the
parallel output ports. The eight-bit data switch register on the front
panel is connected to input port 0.
The switch register serves as simulated parallel sensor data. The
eight-bit byte loaded on the data switch register is input to the accu-
mulator of the CPU upon execution of the "IN 0" instruction. The remain-
ing three parallel input ports provide additional simulated sensor,
inputs.
The dual serial I/O card also has a parallel input port (see Section
5.1.2.1) which is used to input status of the cassette recorder interface,
the digital-to-analog converter, and the two Universal Asynchronous
5-8
Receiver Transmitter (UART) chips used to interface the serial data of
the video display terminal and the cassette recorder.
5.1.2 Special Purpose Interface Cards
The eight 8080 based Pro-Log MRS components cards provide the basic
functions of a microcomputer: CPU, memory, and parallel input/output.
Four special-purpose interface cards have been added to the basic Pro-
Log system to create a powerful special-purpose microcomputer system
capable of simulating all the tasks performed by present DCP designs
[see Figure 5.1(2)].
The dual serial I/O card was developed to interface the serial data
format of the video display terminal to the parallel bus structure of
the'CPU. The second serial interface provides serial/parallel conver-
sions for the cassette recorder interface to and from the CPU bus. A
parallel input and output port is included on the dual serial I/O card
to input status from the serial interfaces and cassette recorder and to
output control signals to the cassette interface card and the external
frequency counter.
The analog interface card provides simulated sensor input of analog
data. The card contains an eight-bit digital-to-analog (DAC) converter,
a comparator, a voltage-to-frequency converter and the necessary handshake
logic to permit software analog-to-digital conversion.
The cassette interface card uses a frequency shift keyed (FSK)
technique to store and retrieve data from an inexpensive cassette
recorder. A subharmonic of the baud rate clock used to clock data to
the cassette is also recorded. Thus, on playback, the subharmonic of
the baud rate clock is used to phaselock the baud rate clock decoding
the data. This technique permits large speed fluctuations from the
cassette with no effect on the error rate of the data.
The general purpose utility card provides several special functions
including hardware system start-up; baud rate clock and current loop
interface for the video terminal; and single step control logic. A more
detailed description of the four special purpose cards is provided below.
5-9
5.1.2.1 Dual Serial I/O Card - The dual serial I/O card and the
other three special-purpose cards were designed to be directly compati-
ble with the address and data-bus structure of the Pro-Log 8811 CPU
card. The bus inputs and outputs are buffered so that the CPU bus driv-
ing capability is preserved. Two serial input and two serial output
ports are implemented on the dual serial I/O card as well as a parallel
input and output port.
The major component of the dual serial I/O card is a MOS, LSI
device called a Universal Asynchronous Receiver Transmitter (UART). The
UART performs serial-to-parallel and parallel-to-serial data conversion
as well as providing status information on the states of the input and
output buffers included in the device. The UART can be programmed to
receive and transmit five to eight bit words, with or without parity
and with one or two stop bits. The UART interfacing the video terminal
is hardwire programmed for an eight-bit word, one stop bit and no parity.
The second UART interfaces the serial data format of the cassette recorder
and is programmed under software control via the parallel output port
included on the dual serial I/O card.
The parallel output port also controls the motor of the cassette
deck. Also provided on the dual serial I/O card is an eight-bit paral-
lel input port used to input UART status. Port absolute-address decod-
ing is included on the card, making it a stand-alone card except for
baud rate clocks needed to drive the UART's. A standard Pro-Log single
serial interface card would have required connection to the Pro-Log par-
allel input and output cards due to inadequate buffering of their serial
interface card and the lack of address decoding. The specially designed
dual serial I/O card not only provides two serial I/O ports and all the
CPU handshaking required, but it is independent of the parallel I/O cards
thus freeing all 64 parallel I/O lines for special purpose use.
The serial I/O data absolute port address assignment for the video
display terminal is port 7. Input status and output cassette control
and UART programming has been assigned to port 6.
5-10
5.1.2.2 Analog Interface Card - The analog interface card contains
an eight-bit CMOS digital-to-analog converter (DAC), a comparator, a
voltage-to-frequency converter, and CPU handshake logic. The eight-bit
DAC and comparator are used in a software successive approximation
analog-to-digital conversion technique. The voltage-to-frequency con-
verter provides a second, less expensive technique for analog-to-digital
conversion. The frequency output is counted with a software frequency
counter routine resulting in a digital conversion of the analog input.
The software routines for the successive approximation analog-to-digital
conversion (ADC) and the voltage-to-frequency to digital conversion are
included in PROM.
• 5.1.2.3 Cassette Analog Interface and Baud Rate Clock Card - The
audio interface to and from the cassette recorder is provided by the
cassette analog interface and baud rate clock card. Serial data from
the cassette serial data output port of the dual serial I/O card is con-
verted to AFSK tones of 4,500-Hz (space tone) and 5,500-Hz (mark tone).
The AFSK signal is created on the cassette analog card and is recorded
on the right channel of the cassette recorder. In playback, the recov-
ered AFSK tones from the right channel are converted back to serial TTL
compatible levels with an EXAR-210 FSK demodulator integrated circuit.
The recovered serial data from the cassette analog card is then applied
to the dual serial I/O card's cassette serial input port.
Simultaneous recording of a 600-Hz tone on the left channel is pro-
vided by a baud rate timing circuit on the cassette analog and baud rate
timing card. A master clock frequency of 57,600-Hz is divided down to
600-Hz. The divider chain provides optional baud rates of 300, 600,
1200, and 1800 baud. The 1200 baud clock was selected for reliable,
fast data recording.
The master 57,600-Hz clock is derived from two sources. In record,
a 555 Timer 1C operating as a fixed frequency astable oscillator supplies
5-11
the master clock frequency. In playback, the recovered 600-Hz subhar-
monic tone is used to phase-lock a VCO to 96 times the recovered 600-Hz
tone. The synthesized recovered baud rate clock provides timing for the
serial decoding of recovered data. Since the recovered baud rate timing
suffers approximately the same timing errors as the recovered data,
overall serial data decoding is relatively immune to timing errors due
to the speed variations of an inexpensive cassette recorder.
5.1.2.4 General-Purpose Utility Card - This card contains:
1. Hardware monitor start-up circuit.
*
2. Baud rate clock for the video display terminal.
3. TTY current interface for the video display terminal.
4. Single step and other control logic.
A single push button switch is used to activate a hardware start-up
-cir-cu.it. In .addition, a power-up circuit on the CPU card also activates
the start-up circuit so that application of power starts the system.
The dual serial I/O card provides TTL logic level serial data. The
utility card interfaces the standard 20mA current loop of the video dis-
play terminal to the TTL logic levels of the dual serial I/O card. A
baud rate clock for the video terminal is included on the utility card
providing switch selectable standard baud rates.
Synchronous run, wait, and single step logic is provided for hard-
ware control of the UT PDCP. In addition, a special "slow-run" circuit
is provided to permit slow execution of a program. This feature is par-
ticularly useful for demonstrating PDCP transmitter routines.
5.1.3 Miscellaneous Hardware Components of the UT PDCP
jjeyel_ppment System
The eight Pro-Log MPS components cards and the four special purpose
interface cards plug into a small 12.7cm x 25.4cm (5" x 10") rack with
5-12
wire-wrapped edge connectors. The cards are powered by three voltages
(+5, +12, and -9 volts) obtained from two commercial short-circuit proof
power supply modules which were made specifically for the Pro-Log MRS
components cards. The analog interface card also utilizes a -12 volt
power supply which was added to the system.
An attractive gray cabinet houses the small rack containing the 12
system cards. The AC power supply is external and connected via a long
flexible cable. The front panel of the cabinet contains a minimum num-
ber of switches and displays in an effort to simplify use of the UT
PDCP system. A set of eight switches provides a fixed value data input
source and is useful in simulating a sensor data source. The value tog-
gled on the data switch register is input to the accumulator of the CPU
upon execution of an "IN 0" instruction. Other switches on the front
panel include wait, single step, slow-run, start, power-on, and cassette
motor-on. The function of these switches is explained in the System
Operation Manual. Several LED's are included on the front panel to simu-
late special functions being performed by PDCP software routines. Finally,
BNC-type jacks located on the front panel are used to display signals on
an external oscilloscope, and one jack can be connected to an external
frequency counter to provide timing verification of PDCP functions. The
LED indications and signals appearing at the BNC jacks are explained in
detail in the System Operation Manual.
The rear panel of the UT PDCP contains a jack for interconnection
of the cassette recorder. Another connector provides interconnection to
the video-display terminal. A baud rate select switch for the serial
teletype interface also appears on the rear panel. The terminal baud
rate switch allows connection of a hard copy teleprinter (such as an
ASR-33) in place of the video terminal in the event hard copy is desired.
User interaction with the UT PDCP system is provided by a Digital
Equipment Corporation VT-50/CA video diesplay and data entry terminal.
The VT-50/CA communicates via a full-duplex serial TTY current loop. A
TTY current loop interface is included on the general-purpose utility
card. Full duplex operation is maintained to achieve maximum versatility
of the VT-50/CA. The VT-50/CA provides an 80-character per line, 12 line
5-13
alpha-numeric display and a multimode ASCII two-key rollover keyboard.
The connector feeding the VT-50/CA could be used to operate any
other ASCII TTY 20mA current-loop device such as the industry standard
low-speed ASR-33. Most applications for the UT PDCP system are best
suited to a high-speed video terminal with cursor control like the DEC
VT-50/CA; however, hard copy of program listings and data can be obtained
using an ASR-33 teletype if desired.
Several cassette recorders were tested for suitability as a bulk
program storage device. Of all the recorders tested, the Lafayette
RK-725 stereo cassette deck exhibited the best frequency response
(approximately twice the frequency response of all other units tested).
Since a speaker and high-power audio amplifier are not needed, a cassette
deck is preferable to a cassette player. The high-frequency data audio
tones for the cassette interface take advantage of the high-frequency
response of the Lafayette RK-725. Higher frequency AFSK tones reduce
jitter from the phase locked loop demodulator. Also, having two chan-
nels permits excellent isolation between the AFSK tones and the baud
rate subharmonic tone. No filter is required to separate the tones as
would be the case for a monaural recorder. Frequency jitter on playback
(a common problem of inexpensive recorders) was not substantial and as
discussed in Section 5.1.2.3, a 600-Hz baud rate subharmonic tone record-
ing is used to eliminate timing errors in decoding the data.
In summary, the hardware for the UT PDCP development system consists
of a special purpose 8080-based microcomputer, a DEC VT-50/CA video ter-
minal, and a cassette recorder and interface for program storage.
5.2 UT PDCP DEVELOPMENT SYSTEM SOFTWARE PACKAGE
To develop a large number of PDCP demonstration programs in the
short time period of this study, software support must be extensive. At
the beginning of this research period, the only microprocessor family
possessing substantial software support was the Intel 8080 microprocessor
5-14
family. Since then, several companies have second-sourced the 8080
including improved versions. Several software firms have also added
software support. Intel's user's library contains many useful programs,
including a Macro Cross Assembler which runs on the DEC PDP-11 minicom-
puter. Dr. Steve Olsen of the University of Utah supplied a paper tape
of his cross assembler, and all of the PDCP programs written during the
research period were assembled on the department's PDP-11/40 using a
modified version of Dr. Olsen's cross assembler.
Microcomputer software is often developed using the hexadecimal or
octal number systems. The PDCP programs developed on the PDP-11/40 use
an octal format whereas standard Intel 8080 software is provided in a
hexadecimal format. In addition, non-programmers may not be familiar
with either hexadecimal or octal and, thus, would prefer to work in deci-
mal. To facilitate the development of PDCP programs a multiradix sys-
tem monitor was developed for the UT PDCP development system. This
monitor will execute commands in octal, hexadecimal, or decimal. For
example, programs can be listed in any of the three radices.
The PDCP resident system monitor provides several key functions for
the operation of the UT PDCP system. Examination and modification of
memory contents, cassette storage and retrieval of bulk data, radix con-
versions, and program execution commands with debugging techniques are
among the many system monitor functions which have been incorporated
under this study. In addition, a special keyboard assembler command
permits programming of the UT PDCP directly from the keyboard using stan-
dard Intel instruction mnemonics. Finally, memory contents may be dis-
played symbolically using a special list symbolic command. The PDCP
resident monitor resides in non-volatile ROM and is available immediately
on system start-up. The two 8116 Pro-Log PROM cards contain the entire
PDCP system monitor. The System Operation Manual support software section
describes in detail the resident monitor software and commands.
The system monitor requires about 3.5K of the available 4K of PROM.
The remaining 0.5K of PROM contains general purpose PDCP subroutines.
Having these often used subroutines resident in non-volatile memory
5-15
simplifies source program writing as the routines are simply called when
needed instead of repeating the source code of the entire subroutine.
Source listings and explanations of these PDCP subroutines are described
in the System Operation Manual support software section.
6. FUTURE PDCP SYSTEMS
The last five years have witnessed the birth, development, and appli-
cation of the microprocessor. It is difficult to accurately predict what
will happen during the next five years in this field. Semiconductor manu-
facturers are already working on thirdrgeneration microprocessors. The
designers of data collection system platforms should have available to
them a prediction or reasonable projection of the future characteristics
and capabilities of the microprocessor if a programmable data collection
platform is to be considered. The purpose of this section of the report
is to provide a method of microprocessor selection and to furnish the
designer with a microprocessor capability forecast for the next five-year
period.
6.1 ' EVALUATION OF AVAILABLE MICROPROCESSORS
The research proposal for this contract projected the source-des-
tination matrix [1] for evaluation of microprocessor instruction sets.
In this technique, an instruction is considered as the transfer of data
from a selected source to a selected destination. By constructing a
matrix in which the sources are in rows and the destination in columns,
the instruction set and functional operations of the microprocessor can
be depicted in a concise format. However, the source-destination matrix
has two significant disadvantages. First, no accepted methods exist for
evaluating or establishing a performance measurement for the microproces-
sor from the source-destination matrix such that a comparison of differ-
ent microprocessors can be made. Secondly, the source-destination matrix
does not integrate other system characteristics into the evaluation.
Present trends in system evaluation are toward the development of
classification and performance measures which integrate all the operat-
ing characteristics of a system. For a microprocessor system, this
includes system constraints, hardware organization, memory hierarchy,
software structures, and application directorates. In fact, most of




Performance Measure = f(system constraints,
application constraints,
software constraints) .
System constraints include power, weight, size, and speed considerations,
while application constraints focus on "the specific computational tasks
to be executed. Thus, application constraints more clearly define the
capability of various microprocessors to meet computational requirements.
Software constraints are imposed by the failure to provide software sup-
port for the system. For instance, new applications are difficult to
program and implement for a microprocessor system with no cross assembler,
editor, or simulator.
This research has directed effort toward generating performance
measures relating to system, application, and software constraints. A
systematic procedure for generating a performance measure is implemented
by constructing a system for matrices relating these constraints to the















W. is a weighting matrix associated with the importance of a particular
constraint; whereas, R.. is a rating or measure matrix for pP • (the jth
J ' J
microprocessor) which evaluates the capability of the microprocessor to
satisfy the conditions imposed by the constraint. The performance mea-
sure, PM., for viP • is given by
\) \J
6-3
PMj = [W]' [R..]
V
Within each general constraint there are numerous conditons for which
the measure matrix, R.., must be established. For instance,, consider
the submatrix formed for the general system constraints in Table 6.1(1).
A weighting factor, W,., is associated with the importance of the ith
parameter. In evaluating a given microprocessor, a measure (r.j-1,-) of
the ability of the microporcessor to satisfy the parameter requirement
can be established. Similar submatrices are formed for the applications
constraints of Table 6.1(2) and the software constraints of Table 6.1(3).
To provide an example of this method for microprocessor evaluation,
a comparsion of the INTEL 8080A and RCA COSMAC microprocessors is devel-
oped. In generating each measure matrix, the difference in performance
measures is the dominant consideration. The absolute values of the mea-
sures would be adjusted as additional information about other micropro-
cessor families is included. Each measure value is established on a
scale from 1 to 100. The larger measure values indicate the micropro-
cessor to be more suitable in satisfying the parameter constraints.
If a large number of microprocessors are included in the evaluation,
the system lends itself to computer implementation for bookkeeping purposes.
A computer with higher-order language capability and containing matrix
multiplication features such as API is ideally suited for the bookkeeping
task. Changes in absolute value of the measures can be easily entered




Weighting Matrix Measure Matrix
Parameter 1 jl
Power Consumption W,, r.,,
'Number of Power Supplies W,? r-i?
Weight W,,. r.,,.
I *5 J 1 *5
Size W14 rj!4
Cost
Minumum System Complexity W



























































Weighting Matrix Measure Matrix



























The system measure matrices, R,, and RR,, from Table 6.1(1)




































In an attempt to justify a few of the measure values, the following com-
ments are provided. Notice that r^-,, = 20 and rR-,-, = 95. The justifica-
tion of this difference is simple. COSMAC consumes an order of magnitude
less power than the 8080A. Next, rJ12 = 40 and rR12 = 100. The 8080A
requires three power supplies while COSMAC requires only one unregulated
supply. On the other hand, rj,y = 75 and rRi7 = 50. INTEL provides
support hardware in a family of integrated circuits which is superior to
that provided by RCA at this time. There are similar considerations for
establishing each measure value in R~T-, and R^,.
Next, consider the system constraints performance measure, SPM. =
I J
W, R.,. If the weighting matrix, W,, is chosen as unity,
W ' R








where the product W,' R.^ has been normalized to a value of 100 for the
ideal microprocessor by dividing the result by the sum of the system con-
straint weights, £ W, .
COSMAC makes a somewhat better showing; however, a more realistic




















W,, is weighted more heavily than all other factors combined since power
consumption is the most important consideration. Among the remaining
system constraints, the availability of second sources for the micro-
processor is the most important since this provides some protection
against long delivery delays and premature removal of the product from
the market. W1(- = 10, indicating cost is not as important when compar-
ing microprocessor-based systems. This weight could become increasingly
more important if a microprocessor-based PDCP was being compared to a
hardwired DCP.
Using the more realistic choice of weights for the weighting matrix,





The superiority of COSMAC to satisfy system constraints in PDCP applica-
tions becomes more evident.
Generating the measure matrix, R.~, for the application constraints














































The measures relating to bench mark programs are not included since pro-
grams for COSMAC have not been sufficiently developed to provide a
realistic comparison. Note that rI22 = 0 = rR22- Neither microprocessor
provides .a hardware multiply or divide at the present time. Since the
8080A has superior subroutine linkage, rT?. = 95 and rR?. = 60. On the
other hand, COSMAC provides for better I/O communications; therefore,
r!26 = 50 ancl rR26 = 80> The stacl< operations of the Intel 8080A are far
superior to those of COSMAC, resulting in = 80 oog
6-10
Considering the importance of the measure in the application con-























The comparison of the application constraints performance measure, ARM.
\J







APMD = — — = 65.88
V 11
<• 2n
These results indicate that the Intel 8080A is a better choice in satis-
fying application constraints.
6-11



































At the present time, INTEL provides better software support than
RCA, especially in compiler design. However, compiler design is less
important in PDCP applications than the availability of a cross assem-
bler and simulator programs. Thus, the weighting matrix, W,, for soft-




















The software constraints performance measure for the two microproces-
sors is
W3' RI3





SOPMR = — = 76.87 .
"3n
The software support performance measure of the 8080A is not really that
superior to COSMAC.
Linearly combining the results generated from these considerations,
the overall performance measure for the two microprocessors is evaluated
to be
VT R,




PM = - - = 75.74 .
The RCA 1802' s performance measure is only ten percentage points higher
than the INTEL 8080's. However, in PDCP applications, system constraints
will generally be considerably more important than either application or











The 1802 now has a clear performance advantage of nearly 27 percentage
points.
The attempt here is not to conclusively state which of the available
microprocessors is better suited for a microprocessor-based PDCP, but
rather, to emphasize this technique as a method for evaluating and com-
paring microprocessors for suitability in PDCP applications. Perfor-
mance measures derived using this technique are primarily intended to
aid in choosing between two or more microprocessors which are known to
meet the basic constraints of the application. Invalid results can be
obtained if one attempts to make an "apples to oranges" type comparison
by failing to eliminate machines with unacceptable characteristics before
proceeding with the performance evaluation. For example, a bipolar
6-14
microprocessor should be eliminated on the basis of unacceptable power
consumption even though program execution time would be much shorter
than for a CMOS or NMOS microprocessor. This limitation of the perfor-
mance evaluation procedure is not a significant handicap since the
initial screening process is relatively easy to accomplish. The final
screening, which is much more difficult to perform, can be simplified
by applying the performance evaluation procedure developed in this
section.
6.2 TECHNOLOGY FORECAST
In selecting whether to include the programmable feature in a data
collection platform system, the designer should have available any pro-
jections which indicate the characteristics and capabilities of semi-
conductor devices for a period covering the next five to ten years.
While these predictions are difficult to obtain, reasonably accurate
models can be developed which yield satisfactory results over this time
span.
There are a number of methods of technology forecasting [2] which
will lead to the development of a set of performance characteristics of
components during a particular period in the future. These different
methods can be reduced to two basic classes of forecasting techniques.
One method, called trend forecasting, involves the development of a
mathematical model which utilizes past history as a guide for the pro-
jection in the future. The second utilizes the judgement of experts in
the field to predict the changes in future technology. This is termed
intuitive forecasting.
There are essentially two components which will have the greatest
effect upon the design of a programmable data collection system. One
component is the microprocessor chip itself, and the other is the memory
associated with the microprocessor.- Already microprocessors are begin-
ning to appear with clock, input/output buffers and control logic on a
single chip. There is even some attempt to include a small memory area
on the microprocessor substate making a true single-chip microcomputer.
6-15
Trend forecasting has predicted that the average computer add time
will decrease by one order of magnitude in a decade [3]. Five years
from now, one could expect the average computer add time to be one-third
that of the present day average add time. The same performance improve-
ment can be expected in microprocessors. The average present day micro-
processor has an add time of two microseconds. In five years, the aver-
age add time is expected to be 670 nanoseconds.
Semiconductor memories have taken a more dramatic reduction in chip
area, power, and cost requirements. The area of the memory cell is
decreasing at the rate of one order of magnitude in seven-1 years. Some
experts believe that a 128K-bit memory chip could be available in 1980.
Therefore, it seems reasonable to predict that a microprocessor with a
600-nanosecond add time and 8K of eight-bit words could be fabricated
on a single chip within five years. The cost of such a device will be
in the $25 range. With powerful computational capabilities such as
these becoming available in the not too distant future, the programmable
data collection platform should be a viable element in'data collection
systems.
The most promising low power technologies for use on future PDCPs
appear to be silicon-on-sapphire CMOS (SOS), closed cell COS/MOS logic
2 2 2(C L), and integrated injection logic (I L). I L is a bipolar circuit
design technique which significantly increases the density of bipolar
circuits and permits operation at any point along a constant speed-power
product line spanning several decades of propagation delay and power
consumption. Thus, low power operation can be achieved at the cost of
increased propagation delay or speed can be improved if higher power
consumption is acceptable. Although future production of low power
2
microprocessor systems using I L is feasible, most manufacturers are
2
currently concentrating I L development efforts in the areas of
linear-to-digital interface circuits and combinations of linear and
2
digital processing on a single chip. Many I L designs use a level con-
2
version circuit to provide a simple interface between the I L I/O signals
2
and standard TTL logic. A CMOS to I L interface should also be feasible
since most new CMOS designs are capable of driving a TTL load. Thus,
6-16
2
I L circuits may provide LSI combinations of digital and analog periph-
eral functions for future microprocessor based PDCPs.
The standard bulk CMOS process has recently been improved by two
different techniques which both have excellent potential for providing
future advances in microprocessor systems. Commercial products using
2
SOS and C L technologies are already available. SOS integrated circuits
are manufactured using many of the standard bulk CMOS processing pro-
cedures. The main distinction between SOS and bulk CMOS is that a
sapphire substrate is utilized in SOS processing to reduce load capaci-
tance and improve circuit density. Propagation delay is also reduced.
High speed, low power, SOS memories which are compatible with the 1802
microprocessor are currently manufactured by RCA. These devices exhibit
lower power consumption than bulk CMOS devices for operating speeds
above approximately 1KHz but consume more power than bulk CMOS devices
in static operation.
The most recent advancement in CMOS processing is the closed cell
?
COS/MOS, or C L, process developed by RCA for the 1802 microprocessor.
2
C L is a circuit design technique that permits a common source struc-
ture for 200 to 300 transistors. The transistor's gate electrode forms
a closed circle which provides gate termination and eliminates the need
for guardbands. As a result, circuit densities are approximately the
2
same as for SOS. C L also results in a higher transconductance-to-drain
capacitance ratio. In conjunction with a self-aligned silicon gate which
2
reduces Miller capacitance, C L offers significant speed improvements
2
over bulk CMOS. Additional refinements in the C L and SOS technologies
are expected to provide continued improvements in microprocessors and




1. Nichols, J., "The Source-Destination Matrix for Instruction Set
Presentation," IEEE Spring Computer Conference, San Francisco,
California, February 25-26, 1975, pp. 61-63.
2. Bright, J. R., Editor, Technological Forecasting for Industry and
Government, Prentice-Hall, Inc., Englewood Cliffs, New Jersey,
pp. 146-147, 1968.
3. Wintz, et al., "Study of On-Board Processing for Earth Resources
Data," Wintek Corp., Lafayette, Indiana, NASA - Ames Contract No.












































































• LJ : a
1-4 ^ »-4 1J
L, r- L. CO
2 > 2 LJ
co a co K
»-4 H-i ;_|
co a co a
LJ G
. — ^-4 i—
,Tt i C-"' 2
C "< G 0
uJ O U —
_j LJ -J ,-
L. G
i~ C"1 '-J O
o: LJ oq 2 2 _i
LJ H< D >
c LJ o










LJ o a o
a 2 _ 2
~"i 2 r"i 2
2 2 2
^4 LJ -I
i- CO Z C'
a a ' a
<N r- . 1-
CO CO ;J CO
LJ r-4 »-4
T" ^. j. ;.
P O
LJ LJ
D i~ CO h-
I- >- H J-a 2 a
a uiy r~ c c
a G o c"













































































LJ CO H • •
P L. 5 0
0 L. _J
LJ
. co >-- a
a u c:
U I- 0 2
ci: >- ^_ LJ
D a co >
CJ »-«
C' <f G O
o
CO CO
3 LJ . -
O CO CO
_J -< LJ 2
!_ 1- 0
G >-•
LJ H i- !-
> p CO G
LJ **'V 2
«H G
2 L. <J- -J








































































































































































H- r I- Q
2 JC D 2
-« D CO w H
O CO O 2 E
t. G L. C. <E C D
L. O O CO
CO 0 0 CO 0 ~
CO 1- LJ CO H L. L.
U • LJ H LJ n O
5 H > a a H C O L J
G Q Q G a CO >-
f— ! — L"i *-* J~ i— F- ~"
2 X -4 ;r 2 x CO CO
L J L J Z I - L J L J O E L J
£ 2 V- E 2 £ CT2
LJ LJ LJ _ y 0 C
U > Li O CJ > £ O CO H
2 Q O r - 2 0 0 i - L J L J
•-< jc L, co w ic L. co t: c:
51 cE 53 CI
» » • » • • .
^ ^ j C o x r L i < z o x z 2 C
X ^ »-« ^» X ^ •-* ^ t. r—
Z O O Q Z Z O O O O L J











































ii") O •-• N O Nj O N O v) O r-. O >0 x) N •-« -<
« J - N O - < ) < l - N ' - < - O t ^ N ' - « - 0 * f - - T - « ^ ) « j - r t



























_J cE 0i^  cr z ut
c: H LJ LJLJ i^  a c: H a
a co o D uj 2 2
Z O G CO !_ -• iU
D C H L. 0 -'
_J CO L. -« L. 2
co u. o a •-LJ co co x:
i- a LJ LJ u. co
C 2 I— f- O '_! li-
0 C > > £ Q
>-< ci a LJ a
at: i- a LJ
2 O «r LJ CO > e: t~
•-« H t- _i a >-
c c. > i- a
-" _J Z a i- CO 2
li D G _J O _l UJ a
> s: .: co e x: 2
0 D E _l t: LJ LJ C-J
o c u i~ K c:
— cj u: > H a o o !~
ci <£ cT. U -i i- Z LJ
_J CO CO O CO CO >-" C3
^ LJ




r-1 f JA a




at- z: c i:
a < ~ ~ < £ c j E i : : c z
-0 ''
• "^
. . a zLJ co > a > x >
~ co > *• o -• o z a
A HO C. E O E « Z:
s a H
V CO
E N U a






C - 2 3 2
:- t: LJ c: z LJ
a LJ LJ t: LJ u c:
r> o H o u t- D LJ
CO 2 2 2 U. 2 Z L.
u >-• LJ L. r-< « li.
•J. t : 0 3 «OE •-.
o LJ c. 2 a u. a
L. rt U.
U U CO E Li. CO 0 L.
H -• CO O CO O
>• O U L. 3 U LJ 3
a E o o LJ E: H o • LJ
_ i a £ H a > - c ; H
a c a L J C > - a a c : >Z i - c t H o a c : o a
r< H >• a ~ a _i
u : n a a H H r zHC2 i - t : H c: H H
CJ L. D a O CO LJ D U «*• LJ
C E t : < I E O G C 2
c.' LJ LJ co cr LJ LJ L. t: u o t:f - u t c ; f - u r c . - : H C : H D
a o u H a o u H a o co H
r i H Z U D r - 2 L J D H i J U
co co ^< o co co >-> a co co c: t:
«r E <r E c
a E Z C O E Z C O E Z
a > x > w > x > w > a . f -
a o z o a o z o o o o u
CO E K E CO E -• E CO E £. C












































O -• o -oo -<
*• -•o o
T «.- «}• JO iiO O v? N N O O *-• -« ;N N O O <r <f !iO U"> -0 -0 O O -i •-• M Cl CO O JO UO s> -0 N N
\-4 M M C'J N CJ >•) ;•-) fJ O C) CO O CO CO C) CO CO f-> O CO CO CO «." «.- «• <• «r «• «r <r «r v «• T <r «r
O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O
O O O O O O O O O Q O O O O O O O O O O O O O O O O O O O O O O O O O O O
o c? o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o












& co oLJ o c
> c t—
O _) CO





















































































































a -o u £






















O ft CO CO
«-« C-l 1)0 CO
ft O O O CO
O O O •-• -i f\ D CO CO •*• <t liO iiO O O r-. N O O -• «-• M C-<
U") J"!' -J> -J~! 'JO 'Jl J"> \T> <J~> \f> ilT j> if) j^  :JT U") j~) -0 -0 ^ -0 O -0
o o o o o o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o o o o o
O O O O O Q O O O O O O O O O O O O O O O O O




























































































































































































O o o «r e « i") N) «o r^ r>- o o i i f< f< o o * <t- « «
•O O vj v} vj «O O -O O <ii O N N N -N N !"• N t^- r- N N N
o o o o o o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o o o o o






































































































































>- ii! LJi: s:
o o
2: LJ L. CO
iij H O£ > oj^ Q m £Q
« f~"O CO > O
_i a >-
u u
1- r- Q _J 1- CO
> c: >-. c: >- u
a o r> a i-
ii C< >
3 •-' t- LJ CO a
- C CO _l
o a o i- co
E O 1- _1
r- -J 2 CO
CO ~ iJ LJ ill
o c: >• »- £
r H c cj: c
2 C. d LJ C.
H « S E to E
l_l O O U _J Otj c^ o i: LJ o
s: cL x:
X -
c ~ a LJ <c o
> X £. M > u.






,-••> <t ,-.•) o f-J v3










































O *J" C- a") If) O O N •-- O O D O <• «.- n a") -0 -0
C> CO CO C) O O CJ CO ^ T ^ T f ' f t i - v ' l - f f f
v V c- «- <r t- *• v <• c- <r v *r «." c- e- <r «r *
O O O O O O O O O O O O O O O O O O O
O O O O O O O O O Q O O O O O O O O O

































































































































































































































































































































































































































































































































































































































































































'z. c a ;: a
CO G G CO G



































O *-* C*J »•*
O *}" *i* *?*
O O O C-O
CO aO UO O Q CO CO
_) CO _l O P
G D Z Z C







ID aO N (•! <-<
-i * aO W C-O
ro co o co o













N r-- N n jo bo











_) K N £. i.
X O Z 0 0







(N If) <S -<
* o o «*•
o o r-o co




- O s ? o r - - N O O - - < ' - iN N N N N O O O O
o c> o o o o o o o o o o o o G o o o o o o o o o o o o b o o o o o b b o b o b o o o o o o o




















































































































ill M fl O
t-i 111 Ul -0






o O O M O
o «s- -o o
rt O »< O
N
CO O ti") »-«
O »^ O
CO ti- «• !il 1)1 O O -• »•< M
n Ji a! ji j> v? ~) v? -o <>
o o o o o o o o o o
o o o o o o o o o o




o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o
C) O O O O O O O O O O O O O O O O O O O O O O O O O O O O
o o ••««-« n IN ci 01 «• «*• iii iii o «oo o o o o o o o o o o o o o
C) M C'J C-J CI f) IN f I CJ D >N) iN 04 CJ




































LJ HI Z CO
a z r-< >-<
-. c o
> D -« h-
>-« H c: z
a LJ o u .
cr "- a
a LJ H LJ
z co ^ o c:
c >-« .- -• 3
CS CJ
LJ I- . O
a z _J u C'
_j u n: r
Z *-• i- L.
HZ L.
Z O -» Q
-i D . ;
cs a 0 ai: u a z
LJ L) Z -•
a r E z o
r. (-- D « eD i-
z u a co
. K LJ UJ
HO Z ^ -i7« a co i: _i
f Z ^  H £
o S c
r** ' a •-<
c u z a u
a -• z >-
C> ^ C C CJC^ "t y~
o z LJ a
u t: LJ L.
x ^ LJ C 5
LJ O Z CO •i H a
U -0 CO LU
z - LJ -« a
>-• _J ZH u.' -• c; D
Z S Z 0 0
-• r- -Z. CO £:
o -
























































































































































































































































































































































































N «r N N
1") N N «*•
*-* *^ O »-*
f «r J> 10 ••> O
n ii") j') i'i i" ..
ci ;-< IN ri c: •>
o o o o o -•
O O O O O :
O O O O O O
N N O O "• -< »N 0-1 O O -O -0 N N O O -« -• <N fl CO O <f <f :f> !l") -O -0 r-- NID io -ii <• o -o <) -o -o -o -o -o v? -o N r-- N N N .^- ^  N r-- N N N r-- ^  N N
ci i-i ;•< 01 01 i-i N CJ n n >N M a ?i ci ci c-i c>i rj w o N rj n c-< ;N rj ;-j o-i ci
o o o o o o o o o o o o o o o o o C) o o o c? o o o o o o o o
O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O
O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O
O O -< -« M f-J O O «r «• in iiO vj v)
o o o o o o o o o o o o o o
O C) (0 O C-> O O C) O O O C) O O
O O O O O O O O O Q O O O O
O O O Q O O O O O O Q O O O






























Z D 0 CO
£.- O LJ
z o ii c;
r-H
J LJ Ci
> J Z LJ
i — GI }— C*
r* ^
r" r~
2 . . Z
c c: co !-•
r> o co
O r- C LJ
C _J "r-
i~ ,J U C
,-H ~l i'-JQ ^~ a — ^>
"' Z 0




x: " c o
*-*
 lf~ -J JC
>' "~l
C 2 E <E
J^ ^  D
O LJ
c f cj a
CJ C -"
CO O >i- c; !- o
cj u. ci
U UJ U u.
•-. S. CJ
x tJT X O
LJ '^ LJ H
C;SLJ co a u.
Z LJ L.
-< LJ > O
h~* ^  Ci :i k* LJ a
0 CO LJ
z. i'< LJ a
? £ z
•-* "^  O


































































































































CO CO -i w CO CO C
_ U Z « x x D D C i

































































































« * 111 •-«
^ O « *•






N •»• r*. O O •-• -« N ?J u? SO O O •* -• N C< fO CO <r «• 1)0 JO O O *-• •+ c- * !i") i/) vj -0 N N M M CO CO v) -0
o o o « - • -< ' - • ' - « -« • - ' - « • - ' « ' » ct ft M ci M -M N rt ci ci •;; t) o to c\. co o o o o ;o o co «r «r <• o- «r «r
o co co co co o co c") ;:> o D c? o o co o o co o co c-> co co o co co c:i o co «o c» o co o co co co co co o co
o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o


















































































































































































































































































_i co _j _i
c c3 5 <E

























































































UO SO <j> 1)0






S t- C) M i"> O v5 -O
<f IT ll> gj JT Ij-) fc) J-)
O i) O O ;•? C5 i) O
O C> O O O O O O
O C' O O O O O O
c o o o o o o o
-• -^ f) CM C") CO «l- o- 1)0 uO -0 s) r- N N f-J CO CO <r e- aO 1)0 O <i -•< ~ »N Cl ID 1)0 v? -0 N N O O CO CO -0 -0 -• ^ ri iN liO 1/0
o o s) -o <> <i o <> »J <) -o <> -o -o N r- .v- N N r-- N N N ^. o o o o o o o o o o ~< •-« **> ~< *~> ~< <•> N M N M c-i0 ;•) o o r> -:~> \~> c> o ci c? o o o o ;o co co ro co c> fo c? co <•« . •« -«•«•<• «r «• «r «• v «• v o «•«• <.w <- c- * «i- ««•
O O O O O O O C1 O C) O O O O O O O O O O O O O C! O O O O C? O O O O O O O O O O O O O O O O O
O O O O O O O O O O O O O O O O O O O O O O O O O O O Q O C) O O O O O O O O O O O O O O O O


























« O N O -«O O
N f i r< "J o co o o o o
«r c- <•" c- v v- «J- «j- <f <r
O O O O O O O O O O
o o f > o o o o o o o



























































































































































































































































































































































































































































































































































































































































































C O O « •-< C-J M CO CO «" f li"> JO -•) x> N N O O »-t ^< «J- «h iiO iO -0 »0
C O O O O O O O O O O O O O O O O "• ~ " •-< ^t -« ~~> — -> "
C O O O O O O C) O O O O O O O O O O O O O O O O O O O
C O O O O O p O O O O O O O O O O O O O O O O O O O O
o o o o o o o o o o o o o o o o o o o o o o o o o o o
G O O O O O O O Q O O O O O O O O O O O O O G O O O G
« .-t ,-• C-J N CO CO I" «J" ilO IT)
<N >N C< 04 04 04 04 04 04 N 04
O O O O O O C) O O O O
o o o o o o o o o o o
G O O G G O O O G O O


























































































•0 >0 ^ N O O ~ -. rj rj j"> u~) O ^ N N
t-t {-I C-l ;••; C> i) o ;) f) C) CO (0 CO O CO O
O O O O O O O O O O O O O O O O
o o o o o o o o o o o o o o o o
O O O O O O O O O O O O O O O O

































































































































































































































































































































































































































































































































































































































X2 X2 t. > L. >o o o o



























-o N li") N O O O «-• N
N O -• * O O W O
-• O O O O O O «
O M T< »<
N O «0 «-•
^ O O O
0^ >") O j"> 1") O O O N M O i"^ JO Si") -O «0 O O •-<—•«• «r •/> |O -<> O «-« •-< —• 04 f-4 C-> O «r «f \T> ID ~0 -0 N N
1^. N N r-- N O O O O O CJ O O O O O — — ' - ' - ' - • -t " ^ •-«•-• C4 C-4 04 C4 C4 C4 C4 C4 C4 04 04 04 04 f4 C~4
O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O
O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O



































r— _ J CT





























































































o o o -• -•















r- 0 L. CO
C E i- D ^-
a LJ 02
E LJ Lt ^«
L. i- r 0
0 2 LJ H G.
LJ _J
LJ 2 L. U. LJ
1- 5C •-« CO
>- 0 0 -•
a r- u 2 3
a u LJ D LJ
C > > I- =
C' C' 0 LJ r-
_J E £ Ci O




o r: a E LJ u a
~ "^ X
co co c: > t: x
D D a 0 U M 2





!O JO N N IO t-lC-4 ^ ^-» \0 Co »-«
O O O v* O f)
0^1 M CO CO «• * !lO aO O -0 > N CJ













































































O O O O O O O O O O O O O O O O O O O O O OO























r- >• D *-• -•
^"* — J J f™
1 *V* ^
CO C LJ O O COD 2 r L. L: p
H C O ^ a H£
•-> to u >-< i-
a i: 2 c; x co
2 0 « « LJ
<£ 0 D UJ
CO -' G: U 2
i: C -I LJ CO •-•
o 2 ;.» L: o z
C 2 C. 0
K CO -< LJ C: C
co ~' ^ D i:
1- CO <X • L
U C LJ CO
Z r- i- LJ _J LJ
r- CO C 2 C £: 2
>- •" c: o c:
L. O CO t- . U I- D
L. 2 D 2 2 CO r-
O «-" LJ C' O U LJ LJ
£ 2 £ >- CO a X.
CO D *-• i-
D CO Z CO D - -
i- CO O "-i O
C C C Z LJ
1- £ i- X
CO tO U
D O tO






C 2 C O
« I- t-
CO - CO 3L. o a coC'CLJu ~ a a t .
i. £ Z CO
H D
2 J 0 2
>-• C H O
I - 2 - " L . L . L . L . I -
D CO O 1- 0 O O 0 LJ
8^03 i - C - C _ v ^ u .
"~ 0 LJ Li
CO I- X H
^« CO CO CO
g LJ p 2 j-






























a") l -0 ,~> N O O -<
O O O O O O O Q O O O O
ooooooooooo o
APPENDIX B
A NEW PRINCIPLE FOR FAST FOURIER TRANSFORMATION
APPENDIX B
A NEW PRINCIPLE FOR FAST FOURIER TRANSFORMATION
by
C. M. Rader, N. M. Brenner
Let {a } be a sequence of N = 2 data, whose Discrete Fourier Trans-
form is {A. }. Let W = exp(-j2ir/N). Present FFT algorithms are derived
from an equation like (1) or its dual
) + Wk * D F T { a - } . (1)
Each of the DFT's in (1) is a DFT of a half-length data sequence, and can
be expressed as two still shorter DFT'.s. After m such stages of simplifi-
cation an algorithm is evident which requires 5 (N Iog2 N) operations to
execute.
. This note presents an alternative to Equation (1) which may similarly
be applied iteratively to itself leading to an FFT algorithm. The new
algorithm which so results has the peculiarity that none of the multiply-
ing constants is complex. Its advantages would therefore seem to be most
pronounced in systems for which multiplications are most costly.
*
Equation (1) is too specialized, leading to radix-2 algorithms.




Let {b } and {c } be the sequences
bn = a2n
cn = a2n+l - a2n-l
n = 0, 1, ..., N/2 - 1 (2)
where
The ^-points DFT's of these sequences are {B. } and {C. }. It is
c. K K
helpful to consider the sequence {d } and its DFT, (D.) defined by
dn = a2n+l n = 0, 1, .... N/2 - 1 (3)
so that {Bk} and {Dk> are the DFT's in Equation (1).
C. and D. can be simply related. Since Q is a constant, it appears
in C. in only one term, C . Furthermore, C is exactly equal to D . For
other values of k, C, can be expressed by the circular shifting theorem
for DFT.
C. = D. (1 - W2k)
rv N
= W~kDk(Wk - W"k)
k = 1, 2, .... |- 1 (4)
Hence,
WkDk = Ck/(Wk - W'k) k f 0 (5)
B-3
and we can rewrite Equation (1)
Ak = Bk + Ck/(Wk - W"k)
k = 1, 2, ...,|-l,|+l,|+2, ..., N - 1 (6a)
Ao - Bo + Co
AN/2 BN/2 ~ CN/2
(6b)
k -kSince W and W are complex conjugates, their difference is twice the
imaginary part, e.g.,
Wk - W"k = -2j sin
so that (6a) may be written
Ak = Bk + ij csc(- k) Ck k f 0, N/2 (6a)
Equations (6a) and (6b) are the replacements for Equation (1) promised.
A fast Fourier Transform algorithm based on (6a) and (6b) requires only
multiplication by pure imaginary constants.
Comments
IJQ could have been added to the output terms A , A..^  rather than to
each of j input terms as in Equation (2) but this would have made the
substitution of Equation (2) recursively into itself, to produce an FFT
algorithm, a difficult matter. In hardware implementation, e.g., "pipe-
lines" this may not be a consideration.
B-4
If, in Equation (2) we had used a^n+l * a? -1 * *^e m^nus s^9n wou^d change
to + in Equations (4), (5), and (6a), thus changing ^J csc(2Tik/N) to
•j sec(2nk/M). The exceptional cases for k would then be k = N/4, 3N/4 and
these would involve ±j, the only non-real operation encountered. We
judge that the secant form offers no advantages over the cosecant form.
k
Whereas the constants W used in Equation (1) have unity magnitude,
csc(2irk/N) can get very large. Therefore, small computation errors can
lead to large output errors. Experience verifies that this is the case.
We recommend that the method be modified if more than 8192 points are
used. A conventional factoring can reduce a DFT to shorter DFT's and
each of these can be computed by the cosecant method.
Substantial savings in multiplications can be made in the conventional
FFT by deriving the algorithm in a higher radix. The method proposed here
-can -also -be developed for -radices other than two. The (p-1 ) -sequences to
be formed are of the form c = a
 +Q - a + Q . We have no idea
whether computational savings can result from higher radix methods.
APPENDIX C
8080A FAST FOURIER TRANSFORM PROGRAM
APPENDIX C
8080A FAST FOURIER TRANSFORM PROGRAM
C-l
LJ LJ




o c: aL. 2 u: 2
o z G
03
>• - it L:G 2 -« - LI _
z u co 2 a i: -• 2 to G o coi: t~ 2 ci c : •} -> --:: u u >-
e >- c Q z: :.- o ^ ^i - £ 2
^-« i; <_' T- a . a r- «-«2 t: u _i . cj > c to u co oG 3 LJ >- _i co — to r- 2 c_
> a _ 2 K u 2 w
z (o a 7* i- a
_ ^ Z" LJ
E G Li U ? _l ' LJ r- LJ *••i— cc c: a a -• u a :- a D z *=
> O •- L: E LJ a O H r.L: <z L. co co o to « c: *
LJ CiT CO LJ G G LO C.: D a G CC' K
- ir 2 •: 3 z _j LJ LJ z E z. *
£ G G i- G 3 LJ E £ •-< r.;j t: a a LJ c: u LJ Q co *




u. U O CO C
_j i-i. r. co
C
co co - ~
'i-   - *- -LJ c: o ~> G o >
co i: «-> r- z: i- i: LJ o ci a



























































_JLJH- -J G - aE E C _ J L J
a t : - - , . a - , - G t :














































G G G G

























v T. CO X £
v r- LJ LJ
v li li * L. t- H
* V U CO CO
* JP a to o
*= 2 T= a u u




















































































































































































CJ NO (>•CO ft O NN O O
-• CO «-<
O >0 CO <r(^ O lN N
* * C O N O
»-• if) •-• Is
«r N o ill
o -• t-t -
f J ^ <•• s T ao











S N Cl M
00--
o o o o
o o o o
o o o o






h- i". O O
o o o o o o
o o o o o o
o c> o o o o
o o o o o o
D N f J ix) Cl M
o o o o o o
o o o o o o
o o o o o o
o o o o o o
i>o iio v> -o o o — — M rt
t-l ft '> iN CO C? ;"> CO CO CO
O O O O O O O O O O
o o o o o o o o o o
o o o o o o o o o o
oooooooooo
co co -o 1s- o ••<«.- iio o •< M co <- ^- .--- n a <r v
C"i C> CO O <- o «r «• iiO 1)0 ilO JO llO 10 i)0 -*> -0 -O v)
o o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o

































































































































































•+ >• f-t «• CJ -0 O v.1 N 0-4 O u") « CJ CJ v} •-< >N
o ;o OJ «r <r ;». «r a"? «i- «r n «f O -i") -• O -" «•




C4 r-. -. o
<*• O <r y>





10 ^ O O
<•> v> N N
o coo
0 0 0 0
o o o o

































*• ft CO f IiO O O --• — CJ rj CO CO -0 O N N •-« -< C~l CJ uO UO O O -« •-• CJ CJ aO iO -0 -0
,^ _ ^, r. „ f j oi ^4 ;i ;i cj fj -J ,'J C-4 C 1 M C1 CO CO CO CO CO f v «r «• .«• «r f T <• «•
O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O
o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o










































































o — a :: o Q
_j c _i to :z _iiz r* — n* o in



























































O -• CO O
MN
O
*J" *?* N N O O C1") O <• <• il") 'j"> O *0 ••« »-< 04 C4 if) j") <i >0 •-<»-*
l)> u"' al i)^> O v) v) <> v? O vi v> O vj N r-- 1s- N S h- N N O O
o o o o o o b o boo o oo o o o o oo o o o b
O O O O O O O O O O O C) O O O O O O O O O O O O
O v > O O v > O G O O O O O O O O O O O O O O O O O
«  <r N S O O .-« .-i «!• «r ID If) O <> N N
 O O O " •-• •-• « -• •< .-i T-« •-• •r-" •-< n
(-1 M 01 (N N iN "J iN n 0) Cl M >s' i"-< >"< C)
O O O O O O O C) O O O O O O O O
O O O O O O O O O O C) O O O O C)
O O O O O O O O O O O O O O O O
O O •* ~* ?l ,-|
ri v~l M
 tN TJ >-J04 0) 04 (t 01 f4
O O O O O O
O O O O O O
O O O O O O
O O * *f -0 -0 *+
04 M 04 C4 04 01 O
04 OJ fl 04 0-4 01 C4
o o o o o o o
o o o o o o o


























































































co j r3 " o o
1C





























































*-« O •"• O •-« f-4
N N ~* N N C4
-• O S CO -« !^









r-4 r i o•~* *.*" *f -j") jo o *o »-< »-4 rj ri tio uo <? ^ i
CO O'1 0-) C-) C-"' 00 C) t." ^ «r o «r «r j^- «.*• «J~ j^* y"^ j") 'j") |>")
c-4 04 C4 04 r-4 04 c-4 f4 oi 04 oi ri M n r-4 oi r-4 >-4 ri r4 01
o o o o o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o
jr N N O O -i •+ 04 C4 CO O <r «.- j"> iO -O -0 N h- O O *•« •-• ri C-4 O CO «t- «4- g") uO O O '••
oi ri ri r-4 o 04 r-4 rt 04 o-i ci ?i ci ri oi r4 ri r-4 c-i c-4 r; ci tt h r4 r4 r'.§ r-4 c-4 04 04 co co co
o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o





















































































































































IO ^« <l li") «^ il") -• N M ^- M -0 CO -0 N C4 «-• * N 111 ^" O M f-J CO N
N *3" N ^0 C" N O If) C4 *3- «- N <T U") <" «3" <) O C-J f^ - «T O !lO «O O" »0
CO O -• CO O ^ C) .-i CO O O ^ O *~> *-• O CO Cl '-i --• O iN O ~ o **
••« v «i- j) !)•• O «3 •-« -« N Cl
O O O O O :• t) -•-•-•-•C'> o o o i">.: • ;? c^ co o o
O O O O O c: O O O O O
O O O O C.' G O O O O O





«• f \i~) if) O O •-• -«
r. r. ^, ,. f| ci 01 CJ
O f) C) C) f) O O r)
C) O O O O O O O
o o o o o o o o
o o o o o o o o
ci f-t \r> -3 f- o o <r N o -• ri co -o «o N r- o o •+ -• M ci j") u") ~o o -> -< o n o o
>~l C) (I ft ;~1 •;•) CO i-) O «r «j' «- -r «r «r cf «• i") u"' W 'j') i') u) u') if) if) ii') -0 O O -O v) M)
o o o o r> co co ci o o 0 a ;> co co o c-> o o o o co o c> .::• co o co o co n co o
oooooooo o o o o o o o o o o o o o o o o o o o o o o o o o






























O - O L.
























































































































O -0 N N
v? <l Vj vj
o f) o r>
D O O O
o o o o
o o o o
o o «-«»-i c •> o o ^
,--. ,^  > r-. N ,-x N N
£•> O i") CO C) O CO CO
o o o o o o o o
o o o o o o o o
o o o o o o o o
^ -< iN f4 CO C7 tf «f i") iO O O O CO «r *
OOOO OOOOOO-«'« «H «•« «H -i
c- v c- «• «- <r c- «r «r <r «• «r «• «r «r «•
OOOO OOOOOOOO O O O O
OOOO O O O O O O O O O O O O








M N CO CO 1-
M N f) N C4
«• «j- <r «r ^r
o o o o o
o o o o o













































































































« 'f! O N iN
«i- r- O j) C I «• «r
O •-« CJ •-< C) O Q
-0 N
O •- O
> .1 !-. i-J * M -0 O »0 N N
O \T> M «r c- r-. <t if) <1- «r
CJ ••• O O O -« O •-< ^ < O
« CO <N M CO CO N CO M N CO CO
C-J aO aO *0 *J* *0 aO ii") uO *0 *J" *0






O O O O O O O O O Q O O O O O
o o o o o o o o o o o o o o o
O O O O O O O O O O O C) O O O
CO O >0 ^ >-) CO e N O CO «- 1)0 -0 N d (I CO CO <T f N N O O ^ -<
ao ii') aO o vo o v> ^> r- r- r- N r^ .-- o o q p p p p p ^ ^ ^< ^
o o o o o o c? o o o o o o o 6 6 6 6 6 6 6 6 6 6 6 ci
O C> O O O O O O O O O O O O O O O O O O O O O C J O O
ooooooooooooooooooooooooo
01 M aO JO O O -i - PJ f ( CO CO f
,-, ... ... .-. ,. ~
 K-j M c; ,-i o n ci
UO uO uO j) iD a) ii") aO uO aO iiO uO uO


























oi- c. K .;
co •-« co v
U M LJ





















































































































c- i)') 10 N r- o o — ~d ri i-1 n ,N o >? >> f>
\i~.' j"1 !iO j') :f> j~> a~> \T> jS
o o o o o o o o 6
O O O O O O O O o
O O O O O O C-> O O
.-I fl CO O <r »r
o o:> c^ o c> n
iT> uT liO iiO ti) a")
o o o o o o
o o o o o o
o o o o o o
N f-. O O -• «-« f t f 1 CO O <J- «• UO '/> O O •-<•-« C;< M iD iO -<7 -0 N Is- •-< -"
CO C^ <r c- <r «.- «.- «r <r «• c- e- <r «• ii> u) ii") ii> ii> li") 'jO iiO j) W 'Jl u> -.1 «i>
JO UO u") iiO ii> i") iiO Ji JO JO \i'< U') J'> liO J) J) li") J) li"' u'> UO JO U"' J"' 'J') 'JO a) -iO
o o o o o o o o o o o o o o o o o o o o o o o o o c> o o
O O O O O O O O O O C) O C) O O O O O O O O O O O O O O O
o o o o o o o o o o o o o o o o o o o o o o o o o o o o
«J; «J- IiO IiO -O -0
v'j <l »/) <} O V)j'j til li> :i~> \i~l JO
o o o o o o
o o o o o o































.H tl *-> O
•-" ~j "Z. 'Z. T. 2
U vJ U) IU ul LJ
_J _J _l _J _J _)
,a,£u.ia.aia.a
"CT'C <C 'fL'G. '<E
c c <c «r
> > > >





























CO CO CO CO CO CO
a a a a a a
_j _i _j _j _i _i

















'A c- a LJ r _j
D LJ LJ id LJ LJ
f- r- r- (~ (~ i- O
CO CO CO CO CO CO V
CO O O CO O CD ~"
UJ iJ LJ LJ U LJ
.-•- /r r-' r^  r-* r-*
« X ^<
I; H >

































































N o o -• -• n cj fo i"o « ao
O N ^ fv (^ N N N > N N
1)0 iO JO if" iiO JO HO UO UO JO UO
O O O O O O O O O O O
o o o o o o o o o o o
o o o o o o o o o o o
o o co co \r> uo v) vo o o M n o o -o -o N r» o o *•• ^ o co <r «)• r- r- o o -•
o o o o o o o o •-• ^ •-> " ^ *-< ^ r. ^. r. r* M M oi i-j rj n r< >y( M co co co
-0 -0 -0 <> <^ O «0 O -0-0 <i <' ^) O v) -O <• <) O •!> -0 v) ~0 <' v) O -0 -0 -0 -0 -0
ooo o o o o o o o o ooooo o o oo o o o o o o o o ooo
o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o












































> M > JI CO *-•




















































-" v- V If) ill O O -• *-• iN 0-1
CO »0 CO CO CO v c- ».•- «r v <r
O <i O -0 -O -0 <i o o v) v)
o o o o c> o o o o o o
o o o o o o o o o o o
o o o o o o o o o o o
o co «-<-<•> «o
V v c- v <? «.-
•O O v? <J O -O
o o o o o o
o o o o o o
o o o o o o
N N O O C) O «c «f
«r «r j"i JO u"' a~> !f> 'J~>
-0 sj -0 O O -0 -O O
o o o o o o o o
o o o o o o o o
o o o o o o o o
N
ii")!rt 1)0 -0 -0 NUO lO bT j~> iO
O ^0 <* O vi v)
c> o o c.> o o
o o o o o o
o o o o o o
O O -• -• M f J "f f
-i) -0 -0 v5 -i? -i> <i «)
•0 «0 -0 v) xj O -O -O
o o o o o o o o
oooooooo
oooooooo
•o >:> r- N r- r- N Is- N N N
•O -O O -0 -) O -) V> -> -O ^)
o o o o o o o o o o o
o o o o o o o o o o o

























































































































































CO O f CO
••• !i> -i f- >N «r M O O -O
f ^- O !i") M «r V ."-. <J- >j")





















O N N M rl CO CO
N N N O O O O
-i> v} v) N r- ••>• IN
O O O O O O O
O O O O O O O
o o o o o o o
«• «r IP U") O -0
o o o o o o
N N h- N N N
O O O O O O
o o o o o o
o o o o o o
N N O O CO V lf> -O ** iN
O O ^< — -•• ~> -. ^. CJ >N
r- f- ,^ . >-. r- r. ,v. f, .^ j-.
o o o o o o o o o o
o o o o o o o o o o
oooooooooo
if) -0 N O *-« f f N N
CJ ivJ >N CO CO CO CO CO CO
N S iX h- S N N N x-
oooooooob
o o o o o o o o o
o o o o o o o o o
O O •-••-< (N \-l CO O «!• «r
tr«r«r*r<-«r«j-^<i'«j-
.^ ,^ . f", ,^ N .^ N Is- N N
oooooooooo
o o o o o o o o o o
oooooooooo
N N O O CO CO «f <r i") if) -0
•3- «- ii'> •)") il « li) U") li> \f> j~>
 N N r*- r~- -v- r« N- N r^ r^-
o o o o o o o o o o b





















































o z _; >
u o z o













































« * • ! ) • > «-• M O r. UT O N M «-• *N v5 O ~0
0) rt o U") ui «r N O :J"> M <•- v N «• u)
















s) h- N N M CO fO O -0 N .->. N <0 «r If) O ^> «r :f> «Ci |x O O P «r <f « al O O r- N O O ••*
tt n"> in o *) <o v> o •<» <i v> N r> N N o o o o o o '-••-' ^ '«-•-• — "•-••-'--• <> ?* -"JN ,-- N f. N ix > (-. fs ,-, .v. ,v. N ,v N O O O O O C) O O O O O O O O O O O O O O
O O O O O O O O O O O O O O O •-«•-« T-«»-4 .-< »-4 »-« ,H .-4 .-• T-« .^ »-4 »-«»-<•-« •-« rt tr4 r*
O O O O O C> O O O O O O O O O CJ O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O
OOOOO O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O
C I C I CO CO O O Is- N O O -< -<M M c~i c-i fi c< n ^^ co co i") o
O O O O O O O O O O O O
c« n so ID o o N
CO CO O f0 CO C) CO
o o o o o o o
O O O O O O O








































Q > r _l
O O O














1^ . t, »-» Z>













± > a >
-• O O Q









l-i ^  ^



















































































o o -• *» »-i N co co «.* «f r- N o o -• n M ct c? o
<•<-<- <r c- <r <r- <- «.- «r «r «r 37 111 li? J") j'J uO -j^ 'jl




-< •-! D ci co o
O v> o v) O v>
O O O O O O
«>•«!- il") d) -O O O OO <i v) v) O v) N N
O O O O Q O Q O
uO o o
o o o
o o o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o o o
o o o o o o
O O O O O O
o o o o o o
o o o o o o
O O O O O O O O
o o o o o o o o
O O O O C) O O O .< -• •-•
o o o
o o o
O O O O O O O O





























































































































O O -• O
O O n no -•
<> -o N r- '-•'-• 04 04 o n <r '
O O O O » - ^ » - » » - « ^ 4 r - t r - » r « .
J? W O O ^ •-« 04 04
»- •- 01 04 0) 01 04 04 \T> I)")04 04 h- r
1
- o o o o "?" *J" ti") u^> *o >o





O O O O Q O
o o o o o o



















O • - < * - • :
2^ — ^~ *^
; co * '*
T* "• >!4 \'(
,->! »: ^ i^
- C-4 Z Z
: : : :
V V V V
c: c <L c
-
c
_i <r a a a
a Q a a >D a a D o






















— CO •-< £. C.
1 D X E 0






















•o co M z: c LJ
*-i *^ ^ * ^ i




















Z- . CO D.
O •-« K
C3 P Z LJ
Z H Ir- 1-
Z -* Z
— i- C L. aO
li H -« N
c: >- co
u r z o
a co o .
K CJ N -
DC C- LJ
Z LJ £ D
> CO U _
c a o H c
C- >. >
o a L ao
z y p IN _i
> co l o z
c. !j - co 5
*-« £. LJ Q •-•i- z: _i _i c:
_l O iL U OD o £ -«
s: o <E >- LJ
<E x in
££ LJ C i^ *-
O CO LJ
- L. •- c: E: E
ii 0 •- 0
- ij co L. i- c:
.^ Z M L.
z: •-< ~ o
LU 1- H . 3 Ci
h- D Z H U
~ O O 1-
Z Z. . « H CJ
0 H H X C
CJ _J Z >-« CO C
_j <z <r n !-• •-jo co -i -. \~ Q t: H
c-j co z: o co c: ~<
CO ^ ^ iil Z \ CO
C Z CO CO LJ 1- O LJ 0.
z co <j > E: z
p.~± . . . i i i i
V-J *^  '"^  !JJ fcJ
o H o: c co t- z
- D CO v t-
O CO >- LJ
ci —i o c. " ••« a •' "> co co
c- c. r: HE: a uz-
a u -j -D DZ- . D«
0 CO O C. CO 'r- LJ
a -. cj E L. D
_i LJ a r-> _j











































h- iO -" -0 -• >N
O «*• «r N «!• «i
- o o N co o
lf> *-• O CO N -< ill « -0 N CO
^ J * < " N O > 0 ^ " N N N f * * O
c o . o -• n - co oo co co co
C> ^ ^. f-j ,-| f) p o- w j-> j-> <i v> N N 0 O O CO <• <r jO aO O O
O O O O O O O O O O O O O O O O O O O O O O O O O






























f <»• JO ilO
O O O O
cj M cj rj
o o o o













a >-• LJ L.
u a <r ay ~ LJ cj u
? *" o a b
CO -i '" HLJ 3 co i a
x: MUD
- - _J CO
r— •'• >— £1
x: z e: c:
LT LJ C H O
-')-(->.
0 <• CO O
L. ID -Z. Z H
:•-. o «-<i- . o a
X 0 U LJ
O ~ — ' Qi- o o _i a
CI >— C <£ C
: .| ^ *
a co uLJ •-«:•: c a)-- ~ O
L. t~ u L. O
*~* O K~
~ o a
o z LJ.Z co
,--, 3 ^  ii M
'"'• a ~i co u
C C 3
LJ LJ ..1
C ;'-•' " CT
^ > • ^ >
P- i. H a
t? — V i ="~
<> a ~
Zi O L. C CO
O . O r-
Z 0 v LJ
co D >- P
. -> 3 C
co £:£.-£:
i- f~ U i' LJ
_J _l Z C ^
D D H
CO CO LJ ^J L-
ii( LJ ~ ~ ~
i; C^ !~ y- 3




2Z *"* ' '^  *"^
-!• a Q
z : L ; ^ o ^ o
O _l £_ E C. ££E Q x: L E LL. c u x: LJ x:
1- 1- i- H H
A ^* .^^  ^ s.*
~ x: a • _j _j o o
^ - ' • • ' L J O V ^ * C Z ^ < E < E -H - H I : v L J L J E X :
« t - £ : ~ C ; : D : - « * - <i • x: a <E
; v v i- a ; ; ^ = ; ;
V B <E V V 01 V V V







_l E 0 O
c a o o t. oi.' x: o i- a u c '- si x: -« c-4 x: a <r u c 04 o. a
. x: r: o a n: a a u i- . - c r j co . -• co H c c ca <x c o co u <r a:
J LJ O LJ >F O H
C t- U Z 04 04 *
H li . . li 04 ID
o a c» sii a nHO a ; ; o o a; £ - • : > - « ' - • a > > _ i si>-« > r - i s i ' - < r - i i : > a > > a > ! - c . o > a
a c . x o > x c r o o 2 : » - x o L N ^ - £ . Z £ . o a o o a o n c i o aDX:_J x: x: _j a x: >- co i i x: c;. -j L . U - - x:x: c x: x: c x: a ~j LV.X: c
CO >- M •-< H CO XC
••* • « «^ -» -» -^ f~
iJ Z
— o u
1— O K O O
_J O JH ^ «
x: ' o '- b
«r * -0 * 04 04 04
O 0 O O O O O
o o o o o o o
-« O «i- 04 i^ 04 O 04 Irt !D
li) O !i"> O ill 04 -0 ** N N
O 0 O 0 O 0 04 0 04 0<
•-< >0 -0 «-• •-« 04 O 04 >H O <0 M O 01 01 N N CO N N C-> 01
« j - « - 4 O * . " « - * O » - « * l * « 3 " N N * - * N O N O O N O * - < O N
O •-• O O O • - < • - < O O «-€ C> O O O •-• 04 « - « . - « C-4 •-• f> -•
l>~> 1)0 O O •-< -H fl O -0 x) N N O O *+ -> «J- «r N N O O iN 01 LO li"> -N N 01 01 O CO «T «1" '/> :J") -0 -O N N O O O CO «)•
— -" 01 O.' f.1 iN CJ (-J 01 01 01 f. O O O O CO C-> lO CO «r <• V «• <T «r f f iiO UO -lO i)") liO 'JO Li") 'J~t j") iO j" ^0 -O -0 -0 <> -0
f4 01 01 01 01 fl 01 01 01 fl 01 iN 01 fl 04 fl 01 01 01 fl 01 f< iN 01 01 fl 01 fl 04 fl 01 01 01 fl 01 fl >N 01 01 01 04 01 01 04 01
o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o



















































<* •-• M C.
- 15 z: o
c in c; oi.i i
UJ m~J
• : y.
V V Z. r-
B CO








 . O ii
G LJ <t CO CO 0> aO
£ U N U
a a c e G a o ~ e: = . to _i r:LJ co ai- H G
co 2 c: H
li t: LJ li
co co i- _j :c
-j > > a Q a :> i: ~« z: ci z G co
2 C' O a Q Q O il > CIO ^-M >D
c z: z: G G c z; -jz: ^JQ U.T MI.
>- r- >-• !-
2 2 ~ •*
O O iO liO
M M M iN
M M t-l M







N iN N CO S r> N N «0 liO N
o o o r > - o o o » < * • « r • - «
M M •-< -• M N N -• O O CO
J-> <i O N r- O O •-«•-« M M CO CO <• «r iiO iiO N h- O O CO
<> ^) v) -o o r-- N r-- >-. N r-- r-- N N N Is- r-- N r~- o o o
M M M M C-l M ;N M Cl C) M M C-l M M M M »N M CO CO CO
O O O O O O O O O O O O O Q O O O O O O O O















<E _J _J f~











Q *-» ^» — •
o o o o o aG z: . c co ao o _iii i- - M ci f i G:





a i; M o x
_J > L. 1- > «T r- Ci CO >
z o o ^-o z z: v. M LD o








o • o «•«
liO M «0 «-• N N N Cl iiO
<.- uo r- * in «r N -« *•
CO 0 ^ CO ^ M CO CO CO
Ci «• «f N N O O — • "-> C"l M CO CO -0 <J r* *+ C
6 C> O O O •-• -• . >-• -• " •-* -• -• '-•'-• MM M
CO CO CO C) O C> O CO CO C) CO CO O CO CO O C) O
O O O O O O O O O O O Q O O O O O O




























CJ CO CO t-\t M M n
CO CO CO CO
o o o o




































M ;N M CO
Cl CO CO CO
O O O O

























































C O C _l
M .-« t <r















































































































































o »N cj -JT jo N r-- ci c-j co o -o -o :*- ^  o o co i") <• f 'j> \r> -3 -^ r~. N r-j r-j <• f N N ••« • •• * «•
(0 CO C) C) C) CO CO w <r «r v «-- «.- «.- v /) j> a:- i") uO ID !)'» J'' lj» ii^  iT> 0") O O O <' O O r- N r-- N .-. r- Q
O C) O O CO CO Cl C> CO (1 CO CO Cl CJ C) CO CO i) C) CO C> CO CO (1 CO CO O O C) CO CO CJ CO O CO CO CO CO O T
o o -• -• r j t-i to v> o v?
Q O O O O C) O O O O
«r «r «!• «r «i- <• «r «r
o o c> o o o o o o o o o o o o o o o o o o o o o o o b o o o o o o o o o o o o o o o o o o o o o o
o o o o o o o o o o o o o o o o o o c> o o o o.o o Q o o o o o o a o o o o o o o o a a o o o o o o
N N f J
CO •-•
ro n
o o o o o o o

































































































































^ N O O
•r* N O O





































h- N M 01
r< i^ pi (i fi n
«r c-
CJ >N
N O O •-• -• «J- «r vO -i> — r-,
PI n r) O O O () >") O «r f
PI M C} O
ii") u") u) ii) :
«r N
li') o")
N O O — •-•
III -0 -O -0 <i
I M O O -0 -O O O i"> O '





o o o o o o
o o o o o o
o o o o o c? o o o c> o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o
































c _i j o o <z a
< £ c j c c t a ^ a a
Z L i- C E D O -' D
C -• tO £ -' CO E CO tO
53































£ Q 0 SI L
c <r n c <c i-J ra o E
a H H cj LJ
a c o u c r - x ^ r ci a s _i i -i: iio oi- cj c:
e cj L
E E Z
a a a o »- a c:
> a a > a _ j x _ t _ i - L i i > > _ j D H
O D D C ' C X Z J I O E L 0 0 2 : i - L J
E CO tO E ii _J -« CO t. 0 M E E E Cl LJ Xt- CD LJ c:




if) if) CJ »
O O O O





























































- *~ Ci .
c co c: a
H >- C Z
C D
a -u LJ o
Q r L.
LJ D H-t: t- uLJ « z a
^1 Z *~*
3
 <i 2 li
•* £1 *"*
EC >- 3d u a
r- Z (.0 CO
o — o a LJ
c x LJ a
P L. P
X LJ LJ '-«>-«
LJ ^ ZJ C- H
0 _l LJ CD
L: r- C £. «E



















































































I") O O •« • < <r V JO l~> O -0 •-• -• Cl CJ C-l C-l «J" f ID ID <> -0 C- N O O —C- O p p O O O O ppp ••« •-• «H r. ... n ~ ^. ^  ^. r. -i .-< « f| f|
o o o o o o o o o o b o o o o o o o o o o o o o o o o
ooooooooooooooooooooooooooo
«J- !.O !D O O •-• -"
CJ CJ CJ CJ CJ Cl O (1
JO !D iO ij'.< a') !rt ID ID
o o o o o o o o
o o o o o o o o
o
o o
T D D O -O
o :•) :•) ro o
0 f> D JO JO
'4 rH •« iH r-«
D O > O O













ill Ha <rD a
r~











— i ^ .-<








r x: £ a
a j
x :; c: >




.-" 10 N «a-
CO >N CO O
CO CO M O
••« N ill «o
«" * *1 O
O O CO O
«." ^ N N P) C-l aO UO
v • «• e- w u~> 10 i)':> io






































N N f) C-( 1)0






•^  L_ *^
CO 0 t-
- D








O •- LJD. u a:
M O «*•
li) ii il)
a a a a a a
D H D H . D H)- O Z . >~ CO Z O 1- 10 Z
O S: O C3 O £ O O ' « 3u O O
r _ - C C - ^ c ^ < ^ , - _ : < : ' : < ^
aj a _j a J
^> X "^ <T "> X ":"" d ^» >i *~ d UE _j co cJ fc _j co u z: _i co a c;
to * * co * * to * * co
o o o o o o o o o o
o o o o o o o o o o
M -0 O iiO M O v liS C-J N i)0 10 iN
tO O CO N CO •-« CO C) CO •-< CO M CO
N 0 CO CO M 0 CO CO N O CO CO »N
10 -0 -< iN 10 vj -• (•» 10 vj ^ ,N !iO <ri
* - * O v * } • - • - < O ' J ' ^ r v ^ O * ! " 1 ^ « - 4 * - «
CO 0 0 0 CO 0 00 CO 0 0 0 CO CO
ID o o ^^ c-j no i~> o o co co uo oo o o co co v> -o o o to co -o -o •-«•-«
<)(>. N N N N N O O O O O O •-«•- ' ' -«•-•-<••< 0) Cl fl C4 M C-) CO CO

















































































































o r-- (••j «• r» -o o
O uO M * O- N *
O -" t( •-« CO O O •-« O
O N O CO «*• N O
CO co «i- «r «»• <r ill
:> o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o o
3 O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O























t: K . c
V li. V O
;:




c: c co co
> c c ii >
O Z L E 2 0








<f iiOCO 0O ft
N M <• N C4 N «T r-
"?" *J" t*- «J" N? U~* JN. r*
•to t c-1 O O O *•«
M CO O O N N O O CO CO f f !)0 'J~>
u." IJO bO 1") 10 iiO O v) O -0 o -o •*) O
O O O O O O O O O O O O O O





















<£ C CO C _J
> c <t c: >








10 N iN N <r N
N «- -O IiO N !)0
•< C-4 CO O O •"
vO ^ i^ . N O O CO CO <!• «• JO 10
v? »o *o N^ r*- r*« iT1* •**• r*« r*» f** r*«
•O *0 »O *0 O ^O *0 "O sj v"1 *0 *0
o o o o o o o o o o o o





































CO 31 M £_
j 2 2 E










N N N .-- O O
O O O O O O


















<r o >-€ <SI
> ^ E
£ V o o
o _i ci ca
a :c c <c







-< o j: iio t:
CO «f LJ





M « > t. Z C.
2 > 0 E >- 1~








N O 0- CO
O * irt O
CO O ^ C-0
CO CO «i> O O O «H ••« «j"
o o o o -•< •-< «-i *^ •-<N r*' r*- N r*- r^ N N r~-
o o o o o o o o c>































«- !f> u"> O
« ^. -« C)
.^ .v. ~. r.
o o o o










































































~nci.f) C4 c< n n M
N N N N N f»
000 O 0 0


































O Li Ci G
Ci a LJ _l
=! 3 ?d ~
»= * 1-1 G O
CO CO Z £
CJ 10 H
: i G O
v v £ • u
_J U - ^ fc
















a a ^ co > c
G G U O Z







»H .-« f) ,-.
If) !iO n N
0 0 CO ~
o o -• »« IN n co co «.••










D UJ O "
1 Q DC t" d
G U Z
UJ Z ^ CO
Ci D 3 >- -•
LJ -J 0 Ci CO
O GO Ci
» ^ ^H r*™
G >~ O O
_J Ci *-« O
u a u E:
V J CO G t-
G •-• 1- x
_J E O LJ










a UJ oT-> ,"\ o ci
> Ci !f> C C- a G U




M L j c . > « - > > > _ iz ~ r > - > o o o G










O S * » • •
<• iN T-. rt
O CO CO 0
N iN »N O -O M N CO
«• O !iO O O N ft N
fj CO O CO o • • « » < • • «
«r uO JO O O CO CO -0 O O Q ~ *-> f-l CI CO
CO CO CO «--<-«•«• e- <- iiO uO aO j') j> UO a')












H^ Q -^'1 ^~ -^^
CO D « Z 0
e > u G
r- w •-< O
co c: a i-o u o aK a t~ D a
Ci O Q G
U O G
H Ci Ci
G "^ ~ H~ til L*JH o a a co
O -H D Ci _l
Ci ^ CO O LJ
^ -^ .~ ^
O 0
G *?* Q CO
CO i CO
U Q CO G CJ CO t)
> ci > _i Q o a
o o M o G -• z a






N f-- If) M f-l N -i N
M CO O -• N N M C-l
O •-• O CO r< o M CO






























CO G G CO
i. > G Gs: o x: z E:









••-• CO CO N S
O O N If) «J-
n co -• o c-J
N o o o o e «J- ao iio -o

































o o o o o o o o o o o o o o o o o
ooooooo oooooooooo
C1 O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O





































































































































CO i- H CO
n O G Ci
G jf O
LJ L. i H
D x 0
_J LJ 0 C
G +. •£. L.
t~
Ci LJ G .
LJ Z Ci
_J i O LJ
_j £ H a
G C- F.
£ LJ 5- D
to H a z
a a a x
Z LJ LJ










_J LJH z ^ a
Z -< 3 D
LJ H
*-" lJ Lj ^
f- IT1 H' Z
O _l _J O
D G G G











































































H L. -^ '' *• G M
O ^" CO G aO H H
0 LJ -« - . E 0 Z
D Z O D 3 11
>• . _J H G CO O O
a '- G Z H Z * L
'- > LJ r. LJ Z CO
LJ if.i ' -i CO Z O H
Q ft '.: H H •-« u. G
G . LJ O L. H i Z
: — J 1^ *^ M
CO X C »= IO O . O
<-> r- z: co . CN G u H
o co ~ . a
z — a '- o LJ D c.
Q N LJ Z iO -r > H D
r-A TH "^  <^ C"'J CJ •"* *~*
H i- . - CO Z LJ
G CO L. O X CO O D
Z O - _ ! < - - • L J G - J
' - 'C.) ' - -LiJ--^-orGi: o -•- co ^ co o >
c; c: uo H T- o =:• LJ
LJ G C- J i O O CO Z Z
i . *- O I- O
L;J <•* O- O ^*-C£ LJ M
a G - H x G r co H
HO i — H G M
co * «- a ^ z ai-< co x LJ co G o a a .
- • r n a O H H U G L JHZ a cj r. z a
I- CO G CJ CO a Ci LU n
*-. O C U D > H
~ 3 CJ 5- G V a H -« «
iio o _J — a LJ co z
. H i: L J Z H G Ci CO CO
C- Z G > G Z LJ C
- u ~ i H LJ co co cj z:
C% ;-< Z CO ^ rH *i *"< O
- r- G CO CO I- D LJ
. O H LJ O LJ U CO 31
"~l K t_!t ~^~ "^ "~l ~! i—! 5 co cj H 3 _' _i LJ
- r. D •-">/: G G Z CO














































































































































, C-4 CO CO «!• tf 30 UO N) <i N N
f j O O O O O O O O O O O
o o o o o o o o o o o o
O CJ C-l ivJ 0-4 ;N »N CJ f) C"-J iN C-4
C J O O O O O O O O O O Ogooooooooooo
O O ft {•> iiO JO -0 i) N .-. O O O C> <• «r JO LiO -0 -0 N N O O ft f< ID 1)0 N
_ ^, ^, ^, ... _ _ .H ^ . ,. fi CJ fl f) fl C J 0) f) ^) ft CM .-) CO CO CO CO CO CO O
O C) O O O O O O O O O O O O O O O O O O O O O O O O O O OIN ft ft ft ft CM ft fi ft ci ci n IN c. <N M *-i c~i ci >v: r« n n c. IN >N <N w c-J
o o o o o o o o o o o o o o o o o o o o o o o o o o o o o

























































































































































CO -^ O N
O N O •*




















h- n M !)•> 10 O O N N O O O CO f f UO DO O -0 N N •-« — >r <r -O v> .1 ^ «• «r uO IjO O v? N N iN CJ CO CO «• «!• iiO liO vi <> o O CO CO uO 10 O O CO CO
CO «.- «r »r «." <• <f «.- «- iiO JO JO a~' 1)0 IiO 3) JO aO JO iO aO vO O <i v? O O h- N N f- ,N- ^- N N N N O O O O O Q O O O O -•< •-< • < -< •• -« CJ CJ CJ CJ
o o o o o o o o o o o o o o c? o o o o o o o o o o o o o o n o o o o o o o «-« *« ••• <-• -« ••< -< •< -« -• -• — -« •-• •< •-« -•< •-• •-< ~*C4 i-j ci cj CJ IN N cj c: CJ CJ cj cj ft ci >N c. cj c. oj ;i cj ~, ct cj CJ tt cj cj cj c; cj c-i ct c. ci CJ CJ cj ci n ci fj ci cj CJ :i CJ c~J CJ f; ci CJ cj rj CJ c;
O O O Q O O O O O O O O Q O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O O


































































































































































Cl CO «!• V
CO CO CO CJ















M CO CO <r «• !iO aO O O -• »-< n Cl CO CO ^- «*• s5 O *-< *-• fO CO
'j~i y ^  jj"^ u~i ii"^  j"|i u"^ i vO *O ^0 *O *O *0 >C' ^^ *0 v^ v!1 v^ Is* ?** r^ « f*1*
o o o o o o c> o o o o o o o o o o o o o o o o
<i •« --• n cj o o *r
^- O O O p O O O
fj M M fl fl iN M CI
o o o o o o o o

















































































































































O N O O
O •-• N N
;N n « CO CO CO CO «-« N
f>- CO
' - ' O
-• ."0
CO
*_• \ '^ W \-f V-1 \- V- V-' V-' V-* \ '^
































































O Z > O .
•> £ D £
"• Lj G r G
Z Z I- C
U (~ >- O
a a . o
- •** &
O « 2 O C.
r- ri »-« O
O U
i - r -OO^
z <c « o H
c s - o
LJ H - O >•E ^ a
- a
U . <-< _J »Hc: LJ ~ u :
c z M
w O >-. OU t- 1- <I
_i D o
a o a H a
c: E u u
i - a - JE t -D a G LIto a E c: ii
« u o c.
- z co o c:t- o w E uo o: u r-
Z _l Z
*-< D CO UJ w
E " =
CO H LJ
C LJ r a
U X CJ Z























-• i: M u G
- H LJLJ a LJ z c:
> LJ _j u
•-< i- a s; _ii- z G LJ _i
C LJ t- _J w
co co co co co co t? £ c. 3
aaaaaaL . ruux :
z _i z o u
c. I- O _lLU E: a































«• •»• 01 O
*~t *^ »-< 0*4
























-O O iiO f 4 ix4 «r
N O N N O O




C- <r JO O -0 N O -« M CO <f <f UO
ijO JO JO 10 !iO JO v> -O -O <) -0 vj «0
CO CO CO CO CO CO CO CO CO CO O CO CO
Cl t> C-4 0-4 iN iN C4 M 0-4 0-4 C-4 C4 C-4
o o o o o o o o o o o o o

















CO CO 00 CO CO CO CO CO H
.. a a a _». j - .
. .C I .QPOC:<IC
'£:£:«<]:«:>»-r>u~0r - .v ; - ) r - i i io r- Q Q r- EJ a a
• e o »N
» O N :v-
> O '.-> O
vj o o o n o
NO ^- O O O
f) O CO O O O
•r-. M * O 00 if)O O O O N O
O O O O CO O
-0 O «0 ^  -0 liO
f- O N O N O
CO O CO O CO O
-0 O
N O
CO O
