



N O T I C E 
 
THIS DOCUMENT HAS BEEN REPRODUCED FROM 
MICROFICHE. ALTHOUGH IT IS RECOGNIZED THAT 
CERTAIN PORTIONS ARE ILLEGIBLE, IT IS BEING RELEASED 
IN THE INTEREST OF MAKING AVAILABLE AS MUCH 







Based on the original Microfiche, multiple pages appear to be 
missing from this document 
I^.
r
HARDWARE SYNTHESIS FROM DDL DESCRIPTION
(N AS A-Cii- 1 ul 667' 	 dARDWAGE SYNTuESiS FRUr ' 	101- 1 )170
DDL DESC8IPT10a Aauual Technical Report, 1
Oct. 1979 - 30 Sep. 196%j (Aiaivama Univ. iu
huntsvilie.)	 181 p kip A09 /Mt' AU1	 ^.:SCL U9B	 UuC.Ldi
G3/o0 41o69
Prepared by
SAJJAN G. SHIVA and ANIL M. SHAH
Computer Science Department













r	 NAS8 - 33096
r`	 DESIGN SYNTHESIS OF DIGITAL SYSTEMS
George C. Marshall Space Flight Center
t	
Alabama, 35812






E	 This is a technical summary of the research work conducted during
Octoi)er s., 1979 to September 30, 1980 by The University of Alabama in
i
Huntsville towards the fulfillment of the Contract NAS8-33096 from
George C. Marshall Space Flight Center, Alabama. The NASA technical




The details of the digital systems can be conveniently input
into the design automation system by means of Hardware Description
Language (HDL). The Computer Aided Design and Test (CADAT) system
at NASA MSFC is used for the LSI design. The Digital Design Language
(DDL) has been selected as HDL for the CADAT System. DDL translator
output can be used for the hardware implementation of the digital
design. This Thesis addresses problems of selecting the standard
cells from the CADAT standard cell library to realize the logic
implied by the DDL description of the system.
t-














LISTOF TABLES .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . vii
LIST OF FIGURES viii
Chapter
1. INTRODUCTION .	 .	 . 1
2. HDLS IN HARDWARE DESIGN PROCESS 	 .	 . 5
2.1 THE HARDWARE DESIGN PROCESS	 .	 . 5
2.2 COMPUTER HARDWARE DESCRIPTION LANGUAGE . 7
2.3 CADAT SYSTEM	 .	 . 10
2.3.1	 The Standard Cell Library for
CADAT System .	 .	 .	 . .	 11
2.4 SUMMARY . 16
3. DIGITAL DESIGN LANGUAGE	 . i7
3.1 THE LANGUAGE i7
3.2 DDL TRANSLATOR (DDLTRN)	 .	 .	 .	 .	 .	 .	 . .	 19
3.2.1	 Data Structures 19
3.2.2	 Translation Algorithm	 .	 .	 .	 . .	 22
3.3 THE SIMULATOR (DDLSIM) 28
3.4 SUMMARY 29
4. THE LOGIC SYNTHESIS ALGORITHM	 . 31
4.1 COMBINATIONAL LOGIC SYNTHESIS ALGORITHM 31
4.1.1	 Equation involving Reduction and
Selection	 .	 .	 .	 .	 .	 .	 . 36




.	 .	 .	 .	 .	 . .	 .	 .	 38
4.1.4	 Equation with Parenthesis. . 	 .	 . .	 .	 .	 38




4.3	 OVERALL SYNTHESIS ALGORITHM . . . . . . . .	 .	 .	 40
i`
4.4	 SUMMARY	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 42
{	 5. IMPLEMENTATION DETAILS .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 43
` 5.1	 DATA STRUCTURES	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 43
5.2	 SUPPORT PROGRAMS.
	
.	 .	 .	 -.-,	 .	 .	 . .	 .	 49
5.3	 SUMMARY	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 ..	 61
t-
6. EXAMPLES	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 62
_ 6.1	 SEQUENTIAL CIRCUIT . 	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 62
6.2	 SERIAL TWOS COMPLEMENTER. 	 .	 .	 .	 .	 . .
	
.	 . .	 .	 .	 79
6.3	 MEMORY .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 95
6.4	 VARIABLE TIMER . 	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 105
6.5
	 MINICOMPUTER.	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 117
6.6	 SUMMARY	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 143
7. CONCLUSIONS .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 144
-	 BIBLIOGRAPHY .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 145
APPENDICES
A. SYNTAX DIAGRAMS FOR DDL CONSTRUCTS . . 	 .	 . .	 .	 . .	 .	 .	 147










1. CADAT Standard Cell Library (Partial)
	 .	 .	 . .	 .	 .	 15
2. Flag Integers
	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 23
3. Codes for Punctuation and Operators .
	 .	 .	 . .	 .	 25
4. Final Implementation . 33
5. Logic Simplification . 	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 37
6. List of Arrays .
	 .	 . 45
7. List of Variables	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 46
-
8. Record Format	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 47
9. Final Implementation Detail 60
vii
i LIST OF FIGURES
Figure Page
1. The LSI Design Process	 .	 .	 .	 .	 .	 . .	 .	 .	 .	 2
( 2. Performance Evaluation Flowchart .	 .	 . .	 .	 .	 .	 .	 12
1
r. 3. The CADAT System with DDL 	 .	 .	 .	 .	 . .	 .	 .	 .	 14
4. Hierarchy of DDL Description 	 . 18
5. Digital System Model .	 .	 .	 .	 .	 .	 . .	 .	 .	 .	 .	 20
•
6. Implementation for X-A+B*D+M*N*P+Q*R*S . .	 .	 .	 .	 .	 35
7. Implementation for Y-A*B+C*D+E*F+G+H+I+J .	 .	 .	 .	 .	 35
8. EX-OR Implementations	 .	 .	 .	 .	 . .	 .	 .	 .	 39
j 9. RTE Implementation 39
t
10. Memory Module	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 .	 .	 41
11. Memory Write Implementation	 .	 .	 .	 . .	 .	 .	 .	 .	 41
12. Identifier Table Representation 	 .	 .	 . .	 .	 .	 .	 .	 47
13. Synthesis Output Tables . 	 .	 .	 .	 .	 . .	 .	 .	 .	 .	 48
14. Driving Buffer Representation . 	 .	 .	 . .	 .	 .	 .	 50
15. Program Structure .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 .	 51
16. Implementation of B*D*M*N*P*Q . 56
17. Implementation of Z-A+B .	 .	 .	 .	 .	 . .	 .	 .	 .	 .	 56
18. Sequential Circuit 63
19. Serial Twos Complementer 80
20. Memory Circuit	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 .	 .	 96
21. Variable Timer	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 .	 .	 106





The details of the digital systems design can be conveniently in-
put into a design automation system by means of Hardware Description
Languages (HDL). The use of HDLs in Large Scale Integrated (LSI) cir-
cuit design automation is not widespread for the following reasons [1]:
(1) The difficulty in translating the HDL description into an
implementable format, such as the interconnection of
standard circuit modules, logic diagram, etc..
(2) Non-uniform design methodologies: The designer in prac-
tice uses a variety of design techniques that can not be
clearly identified as top-down or bottom-up methods.
(3) The time and cost involved in transporting and tailoring
the HDL software developed at one design center to another.
The complexity of the LSI circuit is greatly increased due to the
advent of Very Large Scale Integration (VLSI). Hence, the breadboard
for a VLSI circuit is a VLSI circuit itself. A thorough verification
of the VLSI design at the earliest stage in the design cycle is abso-
lutely necessary to minimize the costs of mask fabrication and wafer
processing brought about by the later changes in the design. The HDL
can be used to provide such high-level verification capability of a
VLSI design [1.].
The Computer Aided Design And Test (CADAT) system of the National
Aeronautics and Space Administration (NASA)/Marshall Space Flight Center













i	 inputs the detail of the Integrated Circuit (IC) to CADAT as a seti of
standard cells and their interconnections. The standard cell selection
i
is done manually from a standard cell library. This design description
is at the logic diagram level. Detailed logic simulation and refine-
ments are carried out on the design. The final design is input to the
automatic test pattern generation and placement and routing programs.
The IC mask pattern generation is refined interactively and mask anal-
ysis and performance simulation are done before fabricating the mask.
The last two steps in the IC fabrication are the wafer processing and
the final testing [2].
The HDL would help the designer to simulate his design and refine
it at a high-level before entering his design into the current system.
The logic synthesizer (hardware compiler) would allow automatic selec-
tion of the standard cells from the standard cell library acid intercon-
nectiun of these selected cells to realize the logic implied by the HDL
description.
The Digital Systems Design Language (DDL) [3] has been selected [4]
as the HDL for the CARAT system. The DDL Translator (DDLTRN) [3,4]
{	 venerates a set of Boolean Equations (BE) and a set of Register Transfer
Equations (RTE) from a DDL description of the digital system. This
1
Report addresses the problem of selecting standard cells from the stand-
ard cell library and interconnecting these selected cells to realize the
logic implied by the Us and RTES.
L	 Chapter 2 is a brief review of literature on the Hardware Design
Process, HDL and the CADAT system. Chapter 3 	 summarizes the constructs
available in DDL and discusses the translator program DDLTRN. The Hard-
ware Synthosis Algorithm (HSA) is described in Chapter 4. Chapter 5
y
1
4provide-, the implementat. ion details of NSA on SEE-32 computer :+ystem.





CHAPTER 2. HDLS IN HARDWARE DESIGN
This chapter provides a brief review of the Hardware Design method-
ologies. Uses of HDLs in the design process are identified along with
requirements for HDL to be useful in the CADAT system. A brief descrip-
tion of the CADAT system is also given.
i	 2.1 THE HARDWARE DESIGN PROCESS
It is difficult to describe the hardware design process formally,
since it is still an art and depends to a large extent on the individ-
ua?. designer and on the specific design problem to be solved. Starting
i
from a set of sometimes vague and incomplete specifications, the de-
signer applies a series of successive improvements until the system can
be realized within a given technological environment, or until it is
clear that the specifications are not feasible [S].
It is impossible to create a final design at once unless the design
is trivial. Two specific approaches to sys`.ems design arz often recom-
mended. The top-down approach is the approach whcr.:^ the designer di-
vides a problem into a number of interconnected sub-problems. This pro-
cess is then repeated until a solution to each of the sub-problems is
known or until a well-known procedure can be applied to solve these sub-
problems. In the bottom-up approach, several elementary compoenets are
combined to form more compl-:, ones until the complete system design is
achieved. In practice, the designer uses a combination of both the ap-
proaches [6].
Normal methods do exist for solving zertain problems, such as min-
imization of combinational circuits [i], or the state assignments for
5
6I
^	 sequential circuits [ 8]. However, a "Library" of examples is used by
many designers "o base their designs. These examples are drawn from
i
t	 the previous design experiences, the literature, or the class-room
exposure. The advent of Medium Scale Integration (MSI) and. LSI building
blocks has magnifies this tendency of constructing hardware design by
"example" [5,6].
In the early stages of the design cycle more emphasis is placed
on the behavior ,^ f cne system than the structural aspects. In the later
stages, the designer adds more and more structural informatira to the
design in progress until the physical design can be implemented using
the available components. The design of digital systems usually con-
sists of several levels of refinements. In actual design practice, it
is not desirable to predetermine the amount of detail at which a de-
signer should work. The amount of detail is dependent on the technology
used	 implement a design. The amount of detail varies wit :i the in-
dividual designer [6,9]. The levels in which a digital system can be
described [2] are shown below:
(1) Algorithmic level which specifies only the algorithm used
by the hardware for the problem solution,
(2) Processor Memory Switch (PMS) level which describes the
system in terms of processing units, memory component,
peripherals, and switching networks,
(3) Instruction level (programming level) where the instructions
and their interpretation rules are specified,
(4) Register transfer level where the registers ara system
elements, and the data transfer between these registers are
specified according to some rule,
7(5) Switching circuit level where the structure consists of an
interconnection of gates and flip-flops and the behavior
is given by a set of BEs, and
(6) Circuit level where the gates and flip-flops are replaced
by the circuit elements such as transistors, diodes,
registers, etc..
2.2 COMPUTER HARDWARE DESCRIPTION LANGUAGE [2]
High Level Languages (HLL) are used by the software designers to
ex-iress the algorithms in terms of language statements. On the other
hand, HDLs are used by the digital circuit designers to describe the
system being designed. The parallelism, nonrecursive nature, and the
timing issues of the hardware can be easily described by an HDL.
The HDLs differ from the pure sequential nature of a general HLL.
An HDL can also be classified as a procedural or a non-procedural lan-
guage. Each statement in a non-procedural HDL description would contain
a label which describes the condition under which the activities de-
scribed by the statement are to be performed, and hence does not reflect
tlic ordering of the activities. In a procedural HDL description, the
statements are ordered. The activities described by the statements are
performed in that order [2]. HDLs have been in existance since the ear-
ly 1980's. However, within the last few years, a serious effort is be-
ing made to bring HDLs into the design process as useful tools. The
major applications of an HDL [2,5] are listed below:
(1) Description of the behavior and/or structure of a system.
This provides an accurate communication of the system
details among designers and users.
(2) A convenient documentation tool to generate users manuals,
8
service manuals, etc..
(3) Input of the system description into a computer for simu-
lation and design verification at various levels of de-
i
	 tails.
(4) Software generation tool at the preprototype levels, thus
bridging the Hardware/Software development time gap.
(5) Convenient incorporation of design changes into the design
documentation.
(6) Designer/user communication interface at the desired level
of complexity.
(7) As the input to an automatic hardware synthesizer.
Several requirements can be imposed on an HDL to be suitable in
an IC design automation environment. Some of such requirements are
[2,10]:
(1) The language should serve as a medium at and below the
register-transfer level of system description, since the
majority of designs call for such a level of detail.
(2) A translator whose output is amenable to easier logic syn-
thesis and test vector generation is required. A simula-
tion capacity is required. The translator and simulator
of HDL shall be written in a HLL for the portability
aspect.
(3) The Language should be easy to learn and remember, since a
hardware designer may not be a software expert.
(4) The design changes should be incorporated into the de-
scription and corresponding translation should be done
preferably without a complete retranslation. This feature
9
(	
will be useful for an interactive environment.
(5) The structural detail provided at any design level varies
from designer to designer. The HDL should allow the de-
signer to control the amount of the detail during each de-
sign phase.
(6) The description of the standard cells as system components
i
should be straight-forward. If the system is partitioned
by the designer to accomodate the standard cells, this
partitioning should be retained by the HDL translator. This
will enable a modular hardware synthesis.
The following five criteria were used in selecting a suitable HDL
for the CADAT system at NASA-MSFC [2,10]:
(1) Activity
(2) Level of description
(3) Software availability and portability
(4) Ease of logic generation, and
(5) Modularity.
Activity criteria requires one to choose an available popular lan-
guage. The process of improving and adding the newer capabilities to
the selected HDL would be aided by the active interest of the other
groups in the language. The level of description must be at the
register transfer and/or below to aid the LSI design environment. The
selected HDL should have a translator and a simulator. The general port-
ability of the CADAT software should be maintained. Any UI L translator
oriented towards providing information for a simulator, collects and
rearanges the combinational logic and register transfers. Easier logic
10
Igeneration must be possible from this intermediate translated descrip-
tion. The HDL description should be modular enough to reflect the
modularity of the hardware, to enable easier understanding and modular
design verification [2,10].
Among a field of more than 40 HDLs that are recently reported,
only 4 prominent HDLs (Computer Design Language (CDL), A Hardware Pro-
gramming Language (APHL), Digital Systems Design Language (DDL), and
Instruction Set Processor (ISP)) passed activity criterion. These were
further ,ompared and analyzed with respect to the other criteria and the
DDL was chosen [10,11], for the CADAT system.
2.3 CADAT SYSTEM [12,131
The CADAT system of NASA-MSFC is used in the design and fabrica--
tion of ICs and evaluation of IC design in newer technologies. The
CADAT system consists of 3 subsystems: Layout subsystem (LAYOUT),
Evaluation subsystem (EVAL), and Design intent subsystem (LOGIC). The
intended logic is input to logic, which generates the stimuli and ex-
pected performance data required by the EVAL and layout data for the
LAYOUT. LOGIC consists of pre-processor (NTRAN), a post-processor
(TPGITF), and a logic simulator (LOGSIM). The NTRAN accepts data in
cell net format and provides circuit model data for the Test Pattern
Generation (TPG) and LOGSIM. The TPG post-processor (TPGITF) automati-
cally supplies stimuli to the LOGSIM and The Field Effect Transistor
logic simulator (FETLOG). LOGSIM outputs the expected performance of
the intended design to the EVAL. EVAL also requires the mask geometries
as input to provide the performance data. The first program of EVAL is
the Mask Analysis Program (MAP), which looks at the geometric blocks on
all mask levels and determines where transistors, feed-throughs, con-
11
i
ductors, guard-bonds, etc., exist. The MAP program redescribes the
same mask pictures in terms of geometries tagged with their functions.
These tagged geometries, together with definition of the process rules
are checked for errors by MAP. MAP program also describes the circuitry
on the masks in nodal format. This nodal data, together with the func-
tionally tagged geometries are passed along to the Disjunct Analyzer
(DJANAL) program. The DJANAL groups transistor circuits into the dis-
junct circuits for use by the FETLOG simulator. The stimuli from LOGIC
is also input to the FETLOG. The performance evaluation flow is shown
in Figure 2 [12].
The details of the design process discussed in Chapter 1 are shown
in Figure 3 [2,13]. The DDL would help the designer to simulate his de-
sign and refine it at high level before entering his design into the
current system. The Logic Synthesizer (DDLSYN) would allow automatic
selection of the standard cells from the cell library and interconnect-
ion of these selected cells to realize the logic implied by the DDL
description.
2.3.1 The Standard Cell Library for CADAT System
The standard cell library is an open-ended collection of logic
circuits implemented with the Complementary Metal Oxide Semiconductor
(C-MOS) technology. All standard cells have been defined, designed,
topologically configured, analyzed, and then permanently stored for
future use on magnetic tape. The present library is quite extensive and
is designed to meet the present and anticipated C-MOS implementation
needs. It is also possible to define and design r.ew cells to meet





















































U 7D c	 W





I	 c	 II	 a	 I
I





























1120 2 input NOR 4 5.8 A+B 1,1
1130 3 input NOR 6 7.7 7+1r_FC_ 1,1,1
1140 4 input NOR 8 9.6 A	 +D 1,1,1,1
1220 2 input NAND 1	 4 5.8 -A"- 2
1230 3 input NAND 6 7.7B C-- 3







1300 'Non-inverting 4 4.5 i	 A 1
Buffer
I I
1620 ;2 input AND )	 6 5.8 A*B 2
1630 13 input AND
^I 8 7.7 A*B*C 3
1640 ^4 input AND i	 10 9.6 A*B*C*D 4
1720 !2 input ORP '	 6 5.8 A+B	 I 1,1
1	 1730 '3 input OR i	 8 7.7 A+B+C 1,1,1
1740 ;4 input OR 10 9.6 A+B+C+D 1,1,1,1
1800 14x2 input AND + 16 ;	 17.2 AB+CD+EF+GH, 2,2,2,2
+ ;	 4 x NOR i
1860 2x2 input AND 12 13.7 AS+L+t'+CD 2,1,1,2
j	 4 input NOR
1870 2x2 input AND + 8 9.6 BCD" 2,2
2 input NOR
1890 3x2 input AND + 12 16.9 +	 E`F 2,2,2
i 3 input NOR
2310 2 input EX-OR 8 7.8 ACB -
1830 D-Flip-Flop 10 8.4 I	 — —
lb
A partial list of the standard cells available in the CADAT system
is given in Table 1. Each standard cell is defined by cell number as
in Column 1. One of these standard cells can be used in the logic de-
sign by calling the desired cell by the cell number. Column 2 of Table
1 gives the type information for a cell. The number of devices for each
cell and the cell width (as a measure of the silicon area needed) are
shown in Column 3 and 4 respectively. Column 5 defines function
realized by the cell. The last column shows the literals (LPP) in
each product term of the function realized by the cell. The LPP with
one product term (1,2,3,4) and those containing all 1's (11,111,1111)
are single gate realizations.	 The four cells 2222,2112,222 and 22
realize more complex functions than a gate equivalent [10].
2.4 SUMKARY
A potentially important application of HDLs is as the input to a
hardware compiler that automatically translates the high level language
description into a logic design. This is extremely useful, since
together with a register transfer level simulator, it would allow rapid
and accurate hardware design.
II
t
CHAPTER 3. DIGITAL DESIGN LANGUAGE
DDL was first introduced in 1961 by Duley and Dietmeyer [3,14]. A
Fortran based implementation was done at the University of Wisconsin
[15,16]. An Algol based version was implemented by Duley at Hewlett
Packard. A PASCAL version based on the Algol version was implemented
at Stanford University [5]. The translator (DDLTRN) and Simulator
(DDLSIM) are implemented in FORTRAN at NASA-MSFC [4]. The DDLTRN
translates a DDL description into a set of BEs and RTEs. The simulator
program enables the designer to verify his design at the register trans-
fer level. The output of the DDLTRN is an input to the simulator. The
simulator commands enable the designer to control the simulation and
input/output data during the simulation.
The language details will be described first. Brief discussion of
DDLTRN Data Structure and six phases of translation will be described
next, followed by an outline of the DDLSIM.
3.1 THE LANGUAGE [3,4,14]
DDL is a block oriented language. The blocks of a description
correspond to the subsystems, parts, etc. of the hardware system [15]
being described. For the language details of DDL refer to [3,4,14].
The syntax diagrams for DDL declarations are given in Appendix A. The
hierarchv of DDL description is shown in Figure 4. In DDL, the strue-
tural facilities (e.g. Register, Terminal, etc.) are explicitly declared.
The logical statements can be formed using the available primitive



















Figure 4: Hierarchy of DDL Description
••	 19
lhardware components for performing logical and arithmetic functions
such as adders, counters, etc.
One of the major characteristics of the DDL is its assumption that
the digital system is described as a finite state machine. Both data
handling and control facilities are found in an automaton. Each auto-
maton of a system is considered to be a finite state machine which
exerts control over data facilities. The timing mode of an automaton
may be synchronous or asynchrouous [14].
}	 If the flow of information to or from a facility is controlled
i	 entirely by a single automaton, then that facility is "Local" and con-
sidered to be a part of the controlling automaton. If. two or more
t	
automata exert control over a facility, it is a "Global" facility [14].
t	
All communications between automata will take place via global facili-
ties as shown in Figure 5.
3.2 DDL TRANSLATOR (DDLTRN) [4,15]
SThe DDLTRN converts the DDL description of the digital system into
a Facility table, a set of BE and a set of Conditioned RTE. The facility
table is simply a list of the facilities (Registers, Memories, Terminals,
i	 Clocks, etc.) and their parameters implied by the DDL description. The
logic implied by the DDL description is completely described by the BEs
and RTES generated '.,,, the translator. The BEs generated by the trans-
lator are in the Suui of Products (SOP) form. The BEs in the DDL de-
scription that were not in the SOP form are throughout unchanged by the
I
	 translator, Data Structures and the Translation Algorithm are described
in this section.
3.2.1 Data Structures [15]





























;.	 card format. As these cards are read, blanks are ignored, and operator
symbols are encoded as negative integers. The information provided by
declaration statements (e.g. RE, TE, etc.) are accumulated in a facility
table. The statements with connection and transfer operators and en-
closing DDL syntax are placed in a single linked list. The main data
 structure consists of a facility table and linked list.
The current dimension of the facility table is 300 [10].A combina-
tion of primary and secondary facilities can not be greater than 200 in
a description. The columns of the F (Facility) table hold varying in-
formation as translation proceeds. The contents of the table are out-
lined below [15] (Note: F(I,J)-- I th row, Jth column of the F table):
F(I,1),F(I,2)--Facility name in 2A4 format.
F(I,3)--Left subscript of RE, TE, DE, etc.
Number of words of memory.
For state entries, pointer to the binary string facility
that expresses state assignment.
Third word in A4 format in binary string facilities.
F(I,4)--Ri-Yht subscript for registers, terminals, etc.
Number of bits per word of memories.
Magnitude of binary strings.
i
F(1,5)--Total dimension of registers, terminals, etc.. The sign
determines whether subscript ascends to the left or right.
Number of bits per word of memories.
Length of binary string.
F(1,6)--Negative entries indicate facility type.
Positive entries are pointers to primary facilities.
F(1,7)--Pointer to the innermost enclosing facility.
F(I,8)--Starting point of facility operation statement.
F(1,9)--End point of condition on operation statement.
F(1,10)-End point of operation statement.
Linked List (LL) of DDLTRN program is an array of dimension 2000.
LL stores operation statements of a description. Unused LL cells are
t
22
linked in an available pool. Cells are taken from the top of the avail-
able pool to expand the main list. The deleted cells from the main list
are linked back at the end of the available pool. Cells of the main list
may contain [15]:
(1) A character in Character format.
(2) A subscript (integer biased by 201)
(3) A pointer to the F table (integer in the range 1 to 200),
or
i (4) An encoded operator or punctuation (negative integer).
Several minor data structures are also used in DDLTRN. Input-
output routines make use of a 135 word array. A push down stack de-
termines the r3sting of declarations. Name entries in the F table are
located using 129 word hash array during the early phase of processing.
Later this array is used as a general work array [15].
3.2.2 Translation Algorithm [4,15]
DDLTRN program was developed by breaking the translation process
into six major subroutines. Each subroutine is referred here as a
"Phase." Each phase consists of several minor subroutines. A signifi-
cant amount of computing time is not consumed for any phase to make a
scan, major or minor, of the LL. In addition, a LL or a portion of it
is printed by a number of subroutines. These subroutines may be request-
ed to list LL after each or any phase with a suitable Flag declaration
whose details are shown in Table 2.
Phase 1
Phase 1 begins with reading a DDL description in a card (80A1)
format. During this phase:
(1)	 the DDL description is transferred from a card image into
23
Table 2 - Flag Integers [4]
Flag Significance Default
1 Print Source Card Images Set
2 Print Declared Facilities and Operations
3 Print DDL string after Pass 2 Reset
4 If	 n	 to	 of	 is	 3 it
5 It	 It	 to	 of	 4 it
6 of	 to	 it	 it	 5 it
7 "	 of 	 "	 it Set
8 Print F Table after Last Pass Reset
9 Print Encoded string after Last Pass to
10 Execute through Pass 2 only It
11 It	 it	 it	 3 of
12 It	 it	 or	 4	 „ of
13 it	 it	 of 	 5	 n n
14 it 	 to
	 " Set
! 24
the facility table and LL.	 All blanks are ignored.
l
.	
(2) Punctuation and operator symbols are assigned a negative
t
integer by tablr look-up according to Table 3.
(3) <TI>, <RE>, <ME>, <LA>, <M, <DE> declarations type en-
tries are removed from the DDL description.
(4) Declared primary facilities are entered in the facility
table.
(5) Secondary names are also tabulated, but their entries are
linked together to the primary name via positive entries
{
in the sixth column.
(6) Identical primary names defined in the nested or parallel
r
blocks are made unique by appending a double quote (") and
4




(7) COmment declaration and in line comments are also deleted.
(8) For <SY>, <AU>, <OP>, the name of the facility is entered in-
to the facility table.	 The facility is pushed onto the
4 stack.
i	 (9) <BO", type is pushed onto the stack.
f
Names are tabulated in this phase by packing letters and digits
into 2A4 format until punctuation or operator symbol is encountered.
The subscript is converted from ASCII character codes to binary, and the
total dimension and direction of ascendancy is determined. 	 Note that
names in Declared Operations have not yet been examined. 	 (e.g., In the





Table 3 - Codes for Punctuation and Operators [4]
Characterl Code Semantics Character Code Semantics
' -20 $ -40 Extension
-21 [ -41 Concatenation
-22 -42 NOT
-23 ` -43 Selection
-24 If ;	 */ -44 AND reduction
-45 NAND reduction
! -26 If (value) i	 "+/
i!	 -46 i NOR reduction
u -27 value "@/ I	 -47 XNOR reduction
$ -28 <OP>argument @/ -48 XOR reduction
(
-2: +/ -49 OR reduction
-30 * -50 AND
< -31 °* -51 NAND
- I -3" "+ -52 NOR
It
-34 not used @ -54 XOR
I





	 -37 not used _ -60 Connection
i -38 not used <- -61 Transfer
_ -39
I




Syntax reduction begins in this phase.
	 While making-the pass
over the system description in LL:
(1) All secondary names appearing on the right of an equal
sign in declarations (such as TErminal, REgister, etc.)
are replaced with their primary equivalents.
(2) All identifiers are replaced with the string they identify.
(3) All names and binary strings (constants) are encoded
`
I (replaced with pointers to their facility table entries).
(4) Subscript punctuation are deleted and subscript are re-
placed with identifiable biased integers.
i	 (5) The syntax of <OP>, <BO>, and <ST> declaration are removed.
(6) Boolean equations are moved to the head part of their
enclosing <SY> and <AU> declarations.
(7) STate statement syntax is replaced with IF - THEN syntax.
(8) Compound BOolean expressions serving as conditions on
operations are replaced with terminals of unit dimension.
(9) Operator calls with arguments are transferred to the con-
nection statement.
Note that names in operation statements are packed from Al to 2A4
format and subscripts are converted to binary.
Phase 3
A single pass is made over the linked list which is now fully en-
coded and free of all declaration types except SY and AU. 	 During this
pass:
(1)	 IF - THEN and IF - VALUE conditions are combined and dis-
tributed over the members of the set so that each operation
27
1.	 appears as the body of a simple IF - THBN clause.
(2) GU TO operations are converted to conditional transfers
of a constant ( the state assignment) to the state se-
quencing register ( the enclosing automaton).
(3) If the LL scan reveals on <AU> code, the name of the auto-
maton is examined. If the global condition is <TI> facil-
ity, that facility is used as the clock variable. If the
global condition is a Boolean expression, that expression
i
#	 is formed into a Boolean equation and created terminal is
used as clock. (e.g. <AU><AU1:A(1)*A(2):, terminal "1
is created and used as clock where, "l=A(1)*A(2).)
Clocking condition is distributed on all register transfer
f
and memory operations within the Automaton declaration.
At the end of phase 3 system description consists of BEs and con-
!	
ditioned register transfer operations.
{	 Phase 4
Again LL is scanned. The starting point of an operation statement
i
f is retained as the statement is scanned in a search for concatenation
operators. If no concatenation operator is found, the next operation
statement is examined. If the statement includes a concatenation, the
scan pointer is set back to the beginning of the statement. Then a
second scan is made. All concatenation operators are eliminated by
breaking operations into operations on subfacilities formed by parti-
tionin^; operand facilities according to the dimensions of the concate-
nation operands. Concatenated operands of reduction operators are not




It is very useful for two or more connection or transfer state-
s_
ments with identical information sink operands to appear in a descrip-
tion. To obtain the total logic of that sink facility, such portion
of the descriptions must be gathered into one connection transfer state-
ment. During phase 5 all connection and transfer operations with the
same data sink (left operand) are gathered ±.nto one compound operation.
Phase 6
Facilities with subfacilities serving as data sinks of connection
y	 and transfer operations are broken into disjoint subfacilities and a
right hand side of a connection or transfer operation is formed for
each new subfacility. Phase 6 provides the Boolean equations and Regis-
'	 ter transfer statements from which the system may be synthesized.
IExample outputs of each of these phases is piovided in Chapter VI
and also in [4].
3.3 THE SIMULATOR (DDLSIM) [4,16]
DDLSIM is a program for simulating the digital system described in
DDL. The simulator has a simple, powerful and completely free-format
command language. This language provides the user with complete control
over the simulation process. DDL system description modification(s) are
not required during the simulation process. DDLSIM does a through error
checking of described systems, simulation control statements and the
simulation process itself. Self explanatory messages that pin-point
errors are issued.
Digital systems to be simulated are first described in DDL. This
description is translated by DDLTRN. The BE, RTE and the facility







DDLSIM. The description is pre-processed by the simulator to establish
data structures and tables that permit more efficient and controlled
simulation. The information for controlling simulation is provided by
using simulator command language. The DDLSIM command language consists
of twelve different types of declarations for supplying parameters, in-
put data, options and other control information necessary for simula-
tion. The language is largely free of format restrictions. Card im-
ages are scanned in turn from left to right. Any declarations may
start at any point and end at other points in the card deck. A declara-
tion can be continued on as many cards as necessary. More than one
declaration can be supplied on the same card. At the start of a new
declaration, the previous declaration is ended automatically. An 'End
Of File' statement terminates the simulation. In general, the order of
the declaration is not important. More than one declaration of the same
type can be used.
Statements of the simulation deck are sequentially processed by
the simulator. Each simulator declaration has the general syntax [16]:
<Declaration-id> Body.
Only the first two characters of the Declaration-id are examined by
the simulator. All declarations, except the Simulate have a Body
foliowin, the heading. The syntax diagrams of the twelve different
types of declarations are given in Appendix B. For the details of the
simulator command language refer to [4,16].
3.4 SUT AMRy
The output of DDLTRN can be used for the hardware implementation of
the system. The HSA is described in Chapter 4. Designer simulates de-













CHAPTER 4. THE LOGIC SYNTHESIS ALGORITHM
The output of DDLTRN consists of BEs corresponding to the combina-
tional logic and RTEs corresponding to the sequential logic of the di-
gital system described in DDL. An algorithm designed to synthesize
this system using the CADAT system standard cells is described in this
chapter. The algorithm requires that the BEs be in the SOP form.
Hence, the BE output of DDLTRN is converted into the SOP form. The
RTEs are synthesized in two parts: one corresponding to the CONDITION
and the other corresponding to the TRANSFER. This chapter describes
the combinational synthesis algorithm first. Next sequential logic
synthesis is discussed, followed by the overall synthesis algorithm.
4.1 COMBINATIONAL LOGIC SYNTHESIS ALGORITHM [1]
The combinational logic synthesis algorithm is described below.
Let the number of digits in the literal/product pattern (LPP) be n, and
K  is the ith digit of the LPP.
(1) Scan the Boolean function to be implemented and count the
number of literals in each product term to derive the di-
gits of the LPP. Reduce each product term with more than
1 literals into a term with 1 literal (i.e. for Ki = 3 or
4, implement using AND cell with proper number of inputs;
If Ki> 4. implement using more than one AND gate.). Gen-
erate LPP for the function from the above derived (and re-
duced) digits.







digits. (e.g. 2121 is arranged as 2211).
(3)	 For n > 4, LPP is split into several 4 -digit units (last
i
unit can have less than 4 digits). Each unit is imple-
mented independently, thus reducing the unit to a 1 in the
original LPP. To implement the unit with n digits (n 1 4),
i
it is compared with all the n digit standard cell LPPs.
The unit is implemented using the standard cell whose LPP
has minimum number of mismatches according to the following
rules:
(a) If the unit is that of a pure SUM term (i.e.,
ki
 = 1 for all i = 1 to n, n 1 4); implement using
OR cell with proper number of inputs. Implement
above unit as NOR cell instead of OR cell for the
LPP in which K  = 2 for any i = 1 to n, n > 4.
(For example, in the LPP = 22221111 unit 1111 is
implemented using 4 input NOR gate).
(b) If in the unit, Ki
 = 2 for any i = 1 to n, n ^ 4,
the mismatched digit is incremented by 1 to create
the standard cell LPP.
Example: 2221 is implemented as 2222.
2111 is implemented as 2211.
221 is implemented as 222.
211 is implemented as 222.
21 is implemented as 22.
t4)	 Final implementation requires different actions for the
different LPPs, as summarized in Table 4.
(a)	 The output must be inverted for the LPP in which
Ki =2 for any i=1 ton, n: 4.
Ki=i, for all i-1 to n,
c1! 4 .
Ki=1, for all i=1 to n,
%>4.
33
Table 4 - Final Implementation
n - Number of digits in LPP























k i>2, for n=1 /_.^
34
(b) The synthesis is complete for the LPP in which
Ki-1 for all i-1 ton, nf^, 4.
(c) The stored outputs during step 3 (stored after im-
plementation of every 4-digit unit in which ki - 1
for all i - 1 to n, n>4)  are implemented using
OR cells with the proper number of inputs.
i	 (d) The stored outputs during step 3 (stored after
1
implementation of every 4 -digit unit in which
Ki = 2 for any i - 1 to n, n ;P 4) are implemented
using NAND calls with the proper number of inputs.
For a-.,16, only one NAND cell is required, as
shown in Table 4).
	
Output of NAND cells are im-
plemented using OR cells with proper number of
i
:.nputs .
(e) If LPP is that of a PRODUCT term (Ki z 2, n	 1),
implement using AND ga:;es (single oi nultiple
stages).
Note that the above algorithm dces not minimize the Boolean func-




Step 1	 1 2	 3	 3
	
1 2	 1	 1
Step 2	 2 1	 1	 1
	
Step 3-b 2 2	 1	 1
Step 4-a Output of 2211 must be inverted.
The above example can be implemented with 1360, two 1630'x, and
one 1310 cells. The cost is (30 devices, 33 mils) and can be implemen-










Figure 6: Implementation for X=A+B*D+M*N*P+Q*R*S












Figure 7: Implementation for Y=A*B+C*D+E*F+G+H+I+J
36
Y=A*B+C*D+E*F+G+S+I+J,
Step 1	 2 2 2 1 1 1 1
Step 2	 2 2 2 1 1 1 1 (no action necessary)
^.	 Step 3	 2	 2	 2 2 1 1 1
Step 4-d	 Output of 2222 and 111 are input to 2-input NAND.
The above example can be implemented with one 1800, one 1130, and
r
one 1220 cells. The cost is (26 devices, 30.7 mils) and can be imple-
mented as shown in Figure 7.
(	 4.1.1 Equation involving Reduction and Selection
Terms involving AND-reduction and selection are identified as "de-
coders" and are replaced with appropriate logic products. The follow-
ing steps are performed to reduce them to SOP form, which can be synthe-
sized using the above combinational logic synthesis algorithm:
(1) Syntt:size the selection operator by complementing the
bits of its left operand if a zero appears in the corre-
ponding position of the right operand.
(2) Provide the operator defined in the reduction operator be-
tween each bit of the selected left operand.




Terms involving only Reduction Operators are also reduced to the
SOP form by the above process, except that the selection is not involved.
4.1.2 Constants
i	 Constants do not denote physical entities, but they do affect the
r	 treatment of the equations in which they appear. During synthesis con-
s
stants drop out of the design. Table 5 shows the action taken to remove




















0 * Removed Removed Removed
1 * Ranoved Removed None
0 + Removed Removed None
1 + None Removed Removed
0 @ Removed Removed None










A-B*C+D*lD1 correspond to A-B*C+D.
A-B*C+D*OD1 correspond to A-B*C.
A-B*C+D@OD1 correspond to A-B*C+D.
A-B*C+D@1D1 correspond to A-B*C+"D.
A-B*C+0D1 correspond to A-B*C.
A-B*C+lD1 correspond to A-1.
	
'	 A, B, C, D in the above examples are each 1 bit long.
Example: A-B*C+D*1D2 (A, B, C, D are each two bits)





An EX-OR cell is available in the standard cell library. EX-OR
is synthesized using this cell as shown in Figure 8 for the examples
X=A@B and Y=A@B@C@D.
	
^-	 4.1.4 Equations with Parenthesis
If a portion of the BE is in the parenthesis, that portion is
synthesized first as in Combinational Synthesis Algorithm. The rest of
the equation is synthesized next. For nested parenthesis, innermost
parenthesis is synthesized first.
4.2 SEQUENTIAL LOGIC SYNTHESIS ALGORITHM
DDL generates RTE corresponding to sequential logic. Each RTE is
of the form: ]CONDITION] TRANSFER.
The "CONDITION" and "TRANSFER" portions in turn are BEs. Each of
T
these portions are separately synthesized by using the above algorithm.
The "CONDITION" portion provides the clock input; the right hand side of
the "TRANSFER" provides the source and the left hand side of the "TRANS-
FER" provides the destination register. A clocked D flip-flop is as-
sumed for each bit of all the registers.












































Memory references in the DDL description is of the form M(MAR),
where MAR is the same register (assumed to contain the address) in all
references to the memory M. The memory references will generate either
a Memory Read or a Memory Write signal. The memory reference on the
right hand side of the RTE designates a Memory Read, while the memory
reference on the left side of the equation designates a Memory Write.
The memory model assumed for the synthesis is shown in Figure 10.
Example: ]A*P+B*P]M(MAR)<-:k*MBUS+B*MBUS. MAR is memory address
register. MBUS is the terminal through which Memory Read and Memory
Write are performed. The dimension of MAR is a function of the number
of words in the memory, and MBUS must have the same number of bits as
the memory word. A and B are single bit facilities. The hardware im-
plementation is shown in Figure 11.
4.3 OVERALL SYNTHESIS ALGORITHM
The synthesis algorithm follows the following sequence of actions:
(1) Memory references from Memory Equations are reduced to
Memory READ and WRITE signals.
(2) RTEs are broken into two BEs corresponding to "CONDITION"
and "TRANSFER" portions.
(3) Equations with Selection and Reduction operators are reduced
to SOP form.
(4) EX-OR operators, constants and parenthesis from the equa-
tions are eliminated.





































An algorithm for selecting standard cells for implementing combina-
tional and sequential logic is presented. The algorithm is suitable for
implementation as a computer program. The algorithm is general enough
to be useful in any LSI design environment. Logic minimization as-
pects are not considered, although simplifications are done . when con-
stants are involved. The equations from DDLTRN output are implemented








CHAPTER 5. IMPLDIENTATION DETAILS
The HSA described iii Chapter 4 is implemented as a FORTRAN pro-
gram on SEL-32 computer system of NASA-MSFC Electronics and Controls
Laboratory. This chapter provides the implementation details. The
data structures used in the program are discussed followed by the de-
tails of each of the support programs (subroutines). The program flow-
charts are included in Appendix C.
5.1 DATA STRUCTURES
t	 A new subroutine (DLSYN) added to DDLTRN formulates 3-disk resident
data files to provide the input required by DDLSYN. The F table is
1	 transferred as it is, as the first data file (DATAI). The other two
data files (DATA2 and DATA3) are created from LL of DDLTRN. LL is split
1
into DATA2 and DATA3 to separate the mixed formats for subscripts, con-
stants, pointers to facility table and encoded operator sNrmbols (nega-
tive integer). Also, DATA2 and DATA3 arrange the BEs and RTEs in a
sequence, so that no LL pointer information is required to access these
equations. DATAZ file contains the following information for each equa-
1
boil:	 ,
(1)	 Identifier and operator symbols in the character (A4) for-
mat,
(')	 Subscripts as blanks, and
(3)	 Constants in the character (A4) format.
DATA3 file contains the following; information for each equation:
(1)	 Pointer to facility table entry for each identifier and
44
constant,




(3) Subscripts biased by 201.
The use of arrays and variables used in the program are described
I
	 in Table 6 and Table 7 respectively. The arrays QU2 and QU3 constitute
the Identifier Table. QU2 contains identifier name in the character
(2A4) format and QU3 contains subscript fur that identifier in the in-
teger format. Each identifier appearing in the equation is defined in
M	 the identifier table. The identifier is replaced in the equation by a
pointer pointing to the identifier table entry as shown in Figure 12.
There will be one net for each identifier defined in the identifier
table. Net contains connectivity information for that identifier (see
Figure 13). The generated net file of which each record corresponds to
a net (which later can be used as input to the Placement and Routing
2-Dimensional (PR2D) program of the CADAT system) is maintained through-
out the synthesis process on the disk to minimize the core usage. The
Net is accessed randomly by using the identifier pointer as the record
number. The record format for each identifier is shown in Table 8.
The first word of the record is the identifier pointer pointing to the
corresponding net in the identifier table. The second word of the re-
cord gives the number of entries already made. Each entry is made up of
cell number and pin number information. Only 10 entries are allowed per
record. A driving buffer is provided in the net if it has more than 9
entries. The tenth entry is defined as the input to the driving buffer.
t
Output of the driving buffer is defined as a new identifier in the
t
s 45
' TABLE 6 - LIST OF ARRAYS
1'ACL	 - Facility table as described in 3.2.1.
L_L	 IRE Current equation being synthesized in character format.
IDU2	 - Current equation being synthesized:
(a)	 A pointer to the facility table for the identifier
(b)	 An encoded operator or punctuation (negative integer)
(c)	 A subscript (integer biased by 201).
ILRL	 - Contains each digit of the LPP for the equation being
I synthesized.
STK	 - Stack contains operands in the equation.
NEXT	 - Inputs to the selected standard cell are stored here.
QU2	 - This array has identifier in the character format.
`U3	 - This array has subscript information for the identifier in
QU2 (integer format).
UATPE Selected standard cell during synthesis are stored here._
SYOU The output identifier of selected standard cells after every
4 digits for the unit's of SOP expression.
MSTR Used for temporary storing equation when equation in
f parenthesis being synthesized.
ICH	 - Current equation being synthesized:
(a)	 A pointer to the identifier in integer format
(b)	 Operator symbols in character format
_. (c)	 Constants as negative integer.
PCONE	 - Common inputs found during synthesis are stored here.
SCEL	 - Selected standard cells for the first equation of the multibit
equation are stored here.
JLRL1	 - Number of digits in the LPP of the standard cell.




Cell number (as in column 1 of Table 1) for the standard cell
in JLRL1.
J:LVECH - Number of matches for the LPP with the standard cell LPP and
:. standard cell number are shred here.
;LATCH
	 -
Each digit of the LPP for the unit for which standard cell is
( Lo be selected are stored here.
t
46
TABLE 7 - LIST OF VARIABLES
TOP	 - Stack poirter.
IZ	 - Number of digits in LPP being synthesized.
FL	 - Set when equation in parenthesis being synthesized.
NLP	 - Number of left parenthesis in the equation.
NRP - Number of right parenthesis in the equation.
COUNT - Number of product terms in the digit of LPP.
LRAL - LPP for the equation.
ID	 - Number of records allocated In Net table.
IC	 - Size of the equation being synthesized.
NEXOR - Number of EX-OR symbols in the equation.
ICEL - Number of cells stored in SCEL array.
CELL - Number of cells selected for the design.
NCEL - Number of cells selected for the current equation.
POC	 - Number of entries in the PCONE.
IPNTR - Pointer pointing to the equation which will be synthesized
next.
NEQ	 - Reset when no more equation to be synthesized.
ADD	 - Number of equations in the multibit equation.
INPIN - Input pin number of standard cell.
OUPIN - Output pin number of standard cell.
ILZ	 - Number of digits in standard cell LPP required to select
standard cell.
FBIT - First bit of the multibit equation.
LBIT - Last bit of the multibit equation.
NBIT - Number of bits of the equation.
ANDEC - Number of AND reduction symbols in the equation.
ORDEC - Number of OR reduction symbols in the equation.
SELL - Number of selection symbols in the equation.
FL2	 - Set, if any digit of LPP is 2.
FLAB - Set, if LPP is greater than 4.
FLPE - Set, if equation in parenthesis needed to be inverted.
FRONT - Number of entries in SYOU array.
RTE	 - RTE-2, when condition part of RTE equation is synthesized.
RTE=1, when transfer part of RTE equation being synthesized.
RTE-0, when equation being synthesized is not RTE.
FLEX - EX-OR is selected when set.
IRFF - D-flip-flop is selected if set.
CLK	 - Clock input to the flip-flop.
MEMO - Set, when memory read equation being synthesized.
NDIG - Maximum number of digits in the standard cell LPP.
(NDIG is 4 for current version.)
NBUFR - Driving buffer is to be provided after number of entries,







2	 A(1)	 X - A*B
3	 B(1)	 1 - 2*3
t	 t t
Pointer
Figure 12: Identifier Table Representation


































B	 31 4	 2
3


























( Net	 Cell	 Pin	 Cell	 Pin
1	 1	 2
2	 1	 3	 2	 2
3	 2	 4
4	 2	 3	 4	 2
i	 -3'	 3
Same as	 6	 3	 4
Identifier	 7	 4	 3	 I
pointer
	 8	 4	 4
I
Figure 13: Synthesis Output
49
identifier table.
	 The first entry in the net of the new identifier is
defined as the output of the driving buffer.
	 In the original net
(record) the first word is replaced by a pointer pointing to the newly a
defined identifier in the identifier table.
	 If the first word of a
record does not match the record number, it is a pointer to the record
in which the net list continues, as in Figure 14 (new entries for :let A
are made in the record number 15).
The cell table contains the standard cell number (column 1 of
Table 1) from the library.	 In the net, cell number is defined by the
pointer pointing to the cell table (GATPE array) where standard cell
number is stored.	 Figure 13 shows implementation and corresponding en-
tries in the cell table for selected cells.
5.2	 SUPPORT PROGRAMS
r:ach equation in the DDLTRN output during phase 6 is synthesized
separately.	 The structure of the program is `shown in Figure 15. 	 In
this sectiun, details of each subprogram are given: 1
Subroutine IREAD
This subroutine provides input to the synthesis program. 	 One equa-
tion from DATA2 is read into IRE array. 	 Corresporid^'ng information for
the equation is read into IDU2 array from DATA3.	 This subroutine is
called again at the end of the synthesis of an equation-to read a new
equation.	 Flag NEQ is reset when no more equations are left to be syn-
tiiesized for the system.
Subroutine SELECT
This subroutine implements decoder type of equations in the IRE
array.	 (Many selection Lypes of equations make a decoder. 	 Each selec-















































































format.constant with selection operator is in the character 	 It must
be first converted to the integer format.
	
Next, inverters are provided
` for those bitositions of selection operator ' s left operand in whichP	 P	 P
0's are found in the right operand (constant) [ 19,21].	 The operator
symbols defined by the reduction operator is provided for each bit
I
;. position cf the operand by calling SIGN subroutine.
	
At the end of the
- subroutine, the ICH array contains the equation in SOP form for the
selection type of equation in IRE array.
Subroutine SELECI
This subroutine expands the multibit identifier in reduction and
selection type equations in IRE array into ICH array. 	 Each bit of the
multibit identifier is defined in the identifier table. 	 If subscript
range is not defined with the multibit identifier, this subr-,uti.ne uses
the correspondirtq facility table entry to define the subscript range.
ICH array will have multibit identifier expanded for each bit in a
pointer list form by the pointers where each bit is designated by a
pointer to the bit in the identifier table.
Subroutine REDUCT
This subroutine implements reduction type of equations in the IRE
array.	 It calls SELECI
	
for multibit operands. 	 Then operator symbol
" defined in the reduction operator is provided for each bit position of
the operand by calling the SIGN subroutine. 	 At the end of this sub-
' routine, ICH array will contain the equation in SOP form.
Subroutine SEARCH
F•
This subroutine is called everytime an identifier is found during
r
the synthesis.	 It enters the identifier into the identifier table,




^,	 intel;er pointer pointing to the corresponding entry in the identifier
table, to the calling routine.
Subroutine SIGN
This subroutine provides AND, OR and EX- ,OR operator symbols be-
tween two operands defined by the reduction operator (*/,+/,@/). For
example,
i	 */A = A(1) A(2) A(3) (equation after SELECI)
*/A = A(1)*A( 2)*A(3) (equation after SIGN)
i	 where. A is defined to be 3 bits long.
y	 Subroutine CENIRE
This subroutine provides subscript range in IDU2 array (subscripts
biosed by 201), and corresponding blanks in the IRE array, for the
i
multibit equations defined without subscript range. The subscript
range for multibit identifier is found from the facility table. During
7	
synthesis for the blanks in the IRE array, the subscript range is ob-
tained from the IDU2 array.
Subroutine FOP ^ UT)i
This subroutine pops the stack KOUT number of times.
Subroutine SCI.
This subroutine finds the best match for LPP by counting the number
of ^iat`hcs for cacti standard cell LPP. The best matched standard cell
is selected for implementation. ILZ gives the number of digits in the
LPP. Only the ILZ digit standard cell LPPs are compared. The above
procedure is not used to select D-flip-flop or EX-OR. The calling sub-
routine sets 1H.FF to select D Flip-flop, and FLEX to select EX-OR. The





This subroutine implements EX-0R gate with two operands. If com-
plement symbol precedes to the left or right operand of EX-OR equation,
f first inverter and next EX-OR gate is implemented. For example, in the
equation "A U+ B, A +Q "B, inverters for A and B are implemented first.
If one operand is a constant, then EX-OR gate is not implemented. An-
other operand is complemented or not complemented for constant equal to
11111
	
"0" respectively [21). For example, A@O - A and AQ1 - "A.
Subroutine MEMR
This subroutine eliminates memory references on the right of the
connection or transfer operator. ICH array will have memory read equa-
tion at the end of the subroutine.
Subroutine MEMW
i
This subroutine eliminates all multibit references in the memory
write equation to the right of the connection or transfer operator.
IRE array has this new equation without any multibit memory references.
Subroutine CRICH
ThiF subroutine derives ICH array from the array IRE and IDU2.
?	 Each identifier is defined by integer pointer pointing to the identifier
table. The constants are identified as negative integers to differen-
t tiate between constants and integer pointers. Operator symbols are
4	 passed as they are. During this subroutine, the number of left and




being synthesized. For a multibit equation the number of times the








This subroutine scans the equation (BE) to be implemented and
counts the number of literals in each product term for the function.
^.	 For example, equation Z = A+B*D+M*N+P*Q, LPP is defined as 1222. It
pushes the identifier pointers corresponding to the identifiers in the
product term corresponding to each digit of the LPP into the stack as
it generates the LPP. Any digit of LPP greater than 2 is reduced to
less than or equal to 2 by providing an AND gate. For example,
Z = A+B*D*M*N*P*Q is reduced to
Z = A + OU2 as shown in Figure 16.
If parenthesis exist in the equation, then the LPP for the equa-
tion in the innermost parenthesis is generated first. For example in:
Z = A+'(B*D+M*N). The LPP 22 corresponding to the equation within the
parenthesis is generated first. Constants with AND or OR operators are
eliminated in this subroutine as described in section 4.1.2.
Subroutine SYNIN 1
This subroutine derives LPP for the Boolean function in ICH array
by calling SYNIN. If LPP has greater than NDIG digits, then LPP is
t
split into several NDIG units (NDIG = 4 in the current version). Each
unit is implemented independently by calling SCL subroutine, thus re-
ducing the unit to the single digit 1 in the original LPP. The output
of each unit is stored in SYOU array for final implementation. For
the Boolean function with the parenthesis, LPP for the function in the
innermost parenthesis is derived by calling SYNIN, and then implemented.
The equation in the parenthesis is replaced by the required standard
cells. This process is repeated till no parenthesis are left in an


















implemented using standard cell 1870. Next " (B*D+M*N) is replaced by
output (OUl) of the 1870. Now the equation is reduced to Z - A + OU1.
Next LPP it corresponding to this equation is implemented using the
standard cell 1720 (OR gate). Standard cell is selected by calling
SCL subroutine. For the multibit equation, first the equation is
implemented as above. All the cells selected during implementation
of the first bit are stored in the SCEL array. The synthesis of the
subsequent bits in the multibit equation uses these stored standard
cells in SCEL array without repeating the SCL subroutine.
Subroutine SYOUT
This subroutine expands the function LPP to match the number of
inputs needed for the selected standard cells for the LPP. For exam-
ple, ?. = B*D+M*N+P*Q+A has the LPP 2221. The best match for this
function is standard cell LPP 2222 (standard cell number 1800) as
found in SCL subroutine. Each digit of the LPP and the standard cell
LPP are compared. The digits of the LPP defines the number of times
stack is to be popped out. If the digit of the LPP and standard cell
LPP are not the same, the popped out identifier pointer is duplicated
as input to the standard cell. The last digit of LPP 2221 does not
match with the standard cell LPP 2222. The product term (identifier
pointer for A) corresponding to the last digit of LPP must be duplica-
ted in the original function. The input to the standard cell must be:
A,A,Q,P,N,M,D,B.
Subroutine ARNG
This subroutine arranges LPP defined by SYNIN subroutine into an
accenting order. It also rearranges the stack accord. n^!; to the ordered
LPP.
58
' 	 Subroutine NET
This subroutine formulates the Net for each input to the standard
cell by storing input pin number and cell number in each entry of the
record for that Net. Cell number is the pointer pointing to the stan-
dard cell in the cell table. The Record corresponding to the identifier
is accessed randomly from the disk by the record number as discussed in
Section 5.1. The Record number is the pointer pointing to the identi-
fier in the identifier table. For example, Z = A+B requires 1720 (OR
gate) as standard cell, as shown in Figure 17. In the Net of identifier
A, cell number 1 and input pin number 2 are stored as one entry. In the
!	 Net of identifier B, cell number 1 and input pin number 3 are stored as
one entry. This subroutine also provides a driving buffer if there are
i
more than 10 entries for the Net as described in Section 5.1.
Subroutine NETOU
This subroutine formulates the Net for the output signal of the
+	 selected standard cell by storing the output pin number and cell number.
The Record corresponding to the identifier is accessed randomly from the
i
disk by the record number. For the above example, in the net of output
r	 identifier Z, cell number 1 and outpin number 4 are stored. This sub-
routine also provides the driving buffers for the Net as described in
Section 5.1.
Subroutine PRCONE
If the equation reduces to X =A,identifier X is the same as A. So




the synthesis process, this is not done till the complete synthesis is
over, but X and A are stored in the array PCONE. At the end of the
r
	 synthesis, the Nets for X and A are accessed randomly. All entries of
59







Net table is disk-resident. To print out
record of the Net table is accessed randomly.
tries and an entry is made up of a cell number
discussed in Section 5.1). The subroutine OUN
table at the end of the synthesis.
Subroutine CONEC
the Net table, each
Each record has 10 en-
and a pin number (as







This subroutine provides the final implementation for LPP as shown
in Table 9. FL2 is set when K i
 = 2 for any i = 1 to n. FLPE is set
when it is required to invert LPP in the parenthesis. FLAB is set when
n>4. The 3 flags FL2, FLAB, and FLPE give eight possibilities.
(1) when all flags are 0, no action is necessary.
(2) when FL2 and FLAB are 0 and FLPE is 1, no action is neces-
sary, but during standard cell selection NOR cell is selected instead
of OR cell.
(3) when FLAB is 1 and FL2 and FLPE are 0, the stored output of
cacti unit in the SYOU array are implemented using OR cell with the
proper number inputs. If n>16, then more than one OR cells are re-
quires as discussed in Section 4.1.
(4) when FLAB and FLPE are 1 and FL2 is 0, the stored output of
oach unit in the SYOU array is implemented using NOR cell with proper
nuraber of inputs. If n>16, then the first output of units in SYOU
array are implemented usin;; OF cell with the proper number of inputs.
The output of these OR cells is stored back into SYOU array. This































w oH a o °z







z Z o o °z o °z
z
A n n	 n
vl V1 Al vi	 vl
vi vi n n vl A n n
C C ^ C^ Q G C^ C ^^ C
O O O	 O O	 O O O O	 O O	 O	 O
JJ IJ L y u L 11 41 L	 41 LI	 L	 61
r4 4 .4	 '-i r i	 r- 4 r--1 r 4 -4	 ' A r4	 r-1	 r-4
11 if 11	 11 If	 11 It 11 11	 u 11	 11	 If
-H -.a "4	 r4 -rl
	
v-1 -.1 -H r4	 -H r1	 •.4	 r4
-4 r 4	 -4 -4	 1 C C C	 p C	 C	 1r
ro ro ro	 ro ro	 ro ro ro ro	 ro ro	 ro	 ro
w H w	 w w	 1•+ H I~ b	 w N	 w	 3.1
O O O	 O O	 O O O O	 O O	 O	 OW w W W W W w W W W W W w
-H ' rl	 •r4 N N N N N N N
II II II	 h II	 II II 11 11	 II II	 II	 II
rl •^ •r4	 •rf 44	 rl -H rl +I	 •"4 r4	 -A	 -H
aG aG pL al, ^4	 :L ^L aL	 I LL aG ^4	 AG	 AL
cw O O O H r 1	 r-i O .-I O O O	 .-i	 -I
44
Ki
.^ O O r-1	 --I -4	 r-1 O O r-1	 -4 -4	 r--	 .-4
W
I
..7 O O O	 .^^ O O . i r 1	 r-I --1r-1
w
i
ro	 d ro	 .a b	 .a7 ro	 .a	 UO
'? r4 N	 I 'n L 1 D t\
61
Then NUR cells with the proper number of inputs is provided.
(5) When FL2 is 1 and FLAB and FLPE are 0, the output of the
t.
selected standard cell must be inverted.
Z
(6) When FL2 and FLPE are 1, and FLAB is 0, no action is neces-
sary.
(7) When FL2 and FLAB are 1 and FLPE is C, the NOR cells are
I
selected instead of the OR cell during the standard cell selection to
implement. units. The stored output of each unit in the SYOU array is
implemented using NAND. If n>16, then more than one NAND cells are re-
quired. The output of NAND cells are implemented using OR cell.
(8) When all flags are 1, the NOR cells are selected instead
of the OR cells during the standard cell selection to implement units.
The output of each unit of the SYUU array is implemented using AND
}	 cells. If n'16, then implement them using NAND cells. Store the ou.-
put of each NAND cell in SYOU array. Now It reduces to case 4 dis-
cussed above.
Lf the equation is an RTE, then the output of condition part _s
used as the clock input to the D-flip-flop (standard cell. 1830).
5.3  SUMNURY
The implementation details of the synthesis algorithm were pro-
vidcd in this chapter. The output of the DDLSYN is of the format re-




This chapter provides five examples of digital circuit design
using DDL description. The examples range from small synchronous
circuits to a simple, but complete minicomputer.
6.1 SEQUENTIAL CIRCUIT
Figure 18 shows a sequential circuit along with the DD:. descrip-
tion, DDLTRN output, simulation commands, simulation outpe , synthesis
output, and the circuit using the synthesis output. The X(1:5) and S
are inputs to the circuit, M(2:5) ere the outputs of the circuit. When
clock P is present X(2:5) are transferred to modules 1 to 4, M(2) is
transferred to module 5 and M(4) is transferred to module 6. A de-
tailed description of Figure 18(c) follows:
Line 1:	 The name of the system is HELOGIC.
Line 2:	 input termina ls X, 5 bits long (numbered 1 through 5), and
S, 1 bit long.
Line 3:	 Output terminals M23, M24, and M234, 1 bit long, and M, 4
bits long (numbered 2 through 5).
Line 4:	 A single phase .:lock (time) P.
Line 5:	 A latch by name SW
.ine b:
	 Register A, 6 bits long (numbered 2 through 7). Modules 1
to 6 of Figure 18(a) are named as A(2:7).
Lines 7-9: Declare Boolean declarations corresponding to Figure 18(b)..














































(45 * Sl + y2	 ) * (X1 	 + M2 ^) * (X3 	 + X4 ^ )
1
'45 =X1 +(X2 *X3	*X5 ' *M4';
t











































,L	 v r v	 Q
1	 c 11 11	 ••
a	 Z A A A A
v	 ,.,, 1 1 n






.^	 J J	 .r^ .r1 ti v	 1 h? J, Z
.»	 ^.	 1 .c J:
	 iC 2 2 1 f Q	 v v J J e l :.1 V
V
A A	 A A A A


































a w a ^
1 2 Y W












^ ry • a



















































v1 v v q
v K C ^- .
2 t11 ^^ Vcf. ^I • •v a► v F r r+ .^
♦ a va. .c rv a
i► .^ M^ a ♦ V :n s a
M, v...-. Q / S f
t L	 F -'	 f 1
♦ ^ a ♦ ♦ J1 V V
♦ ♦ 	 .. It r.	 •• — .^
.. v r. f1 ^ :v L l^
^ ^ ^l K '^1 ^..^ r+ v V v
•• .ti N r v v Z v g a a
.^ v ^+ L 41- Q v it


































v .r ♦ a
a a	 ..
a ^ ^ J1
rr^ v ^..^ C
. r K Q H .
? a	 --N
.. -	 ....
♦ d 'fir a a x 1 Z
^^^ s a	 1. S t t
v, v .^ •^.	 Q I
	
.. S G
2 v 2 r r. ^ -^ V I li
♦ 	 ♦ ^ Q a ♦ J1 V V




.v ^ ti x M ^.r ... v v v
•• v 'V v v r 2 v Q Q a "'
V :L " L r a ^+ ^( J
1
11	 v	 11	 11	 11	 11	 11	 f	 i
.^ M 11 Z	 J)






















NI r V Q
\ ^ K Q H •
y -. ^ r r 1t
— ^ v	 11 3 ti
— 2	 2	 R .. 3.	 ^ 1	 1
a: ♦ ^ ^ ^[ ♦ Jl v V
f	 t	 r R ^	 • • .-. r.
1	 ` v v
	 _	 H c1 a./ K
. --	 --	 n	 11	 a	 11	 11	 i.
I,	 ^ 11	 11 J ^'^ ^ ^ ^ 'Ji T J
..
,n , :^,	 '1. 7 1' R	 a	 t
y ^ ^^, ^ v V V V± y ^








J.	 • ^L ^
c	 • .. 1 .r
-	 3 ^'I V Q
1	 ^. .^ ^ G R +( 'U 7
vv; r.
..t	 ♦ ... ^, •	 t J1 v v
J.	 •.	 L .0 ..	 .. ^	 .. 3 N ^:
^	 ^ -^	 11	 i	 11	 11	 11 i s s
;!;	 J^7^	 M	 Jr^^ R R t
L	 ^,r ^r ^I	 3 V V l 1 Z

















OF Pt- )R QUALI'f I
70
00 OJ .v L 00 OON ON0000 ON1 V`•q
'VM J1 	 M a
 	 N
it wl	 NA
J ^O 00000 7!^ r ^ OJ O 7 ^G'J.: O
«+ r 4c
s+ v+ J+











J	 ...... .r	 4 .. ti	 G N	 -^ J^ M V
a
..i x^ `^1 ^ 7L ^ t 4 4 Q Q	 1 t Z L L.
2 2 +V	 J
J J
a


























•a	 \ -^ 1\ .c • L
1 • O
n	 s z = — z
.0 A A A A 7 A A
• G Jr.























 V r v
]i(
t L J ^
L
d .-. J .^ .. ... ^.	 ... J .. J J r+ y 2O O ^+ J^ J O r -+ J— J .•+ 0 0 J t
.7 Z J
	
. ... r ] .r
	 .r ..^ J r+ .. .. .r y


















Note that identifier names are not required to be declared in the
terminal declaration. (For example, CM is not required to be declared
as terminal). Also, sometimes using <ID> rather than <BO> reduces the
circuit. For example, if CCl was declared as BOolean, then it would
require 4 standard cells to implement M(2) (an inverter and a 2-input
AND cells to implement CC2, a 3-input AND to implement CC1, a 2-input
AND to implement outputs of CC1 and CC2). The current description
requires 3 standard cells to implement M(2) (an inverter and a 2-input
AND cells to implement CC2, a 4-input AND to implement CU and output
of CC2).
Line 14:	 Automaton CONP is controlled by clock P.
t	 Line 15:	 When SW is 1, (2:5) is transferred to A(2:5), M(2) is
transferred to A(7), if clock P is present. The periods at the end of
line 15 terminate the IF-THEY on SW; AU and SY declarations respectively.
Line 16:	 Sets the flags of DDLTRN to output the results of each of
the six phases and the facility table (see Table 2).
The first 7 equations of the DDLTRN phase 6 output are BEs and the
rest of them are RTEs. Figure 18(d) shows the input commands for
DDLSIM. Flags for DDLSIM are set for octal data input (3) and binary
output (6) in Line 1 (refer to Table 4.2 of [41). SW is initialized to
1 on Line 2. An input/cutput trigger TR (raising edge of P) is declared
in Line 3. Lines 4 and Line 5 read in the values for S and X when TR is
un. (There are 14 sets of values). The values of CONP, A, S, X, M,
M23, M24 are to be output when TR is on (Line 6). The simulation is









y 1	 a a^ 3 r^^ •c K K • J ^^ O
^ V	 K K	 ^ t .n	 .K ^ J r. ... 1 v N
y .t <	 4 <	 X
K K	 K K	 x y 'J
Z x V tD a x v a7 3 • J J	 7J J n Q — nn
G
J	 • t .1) G •^ ?'
._N1M7 L Gi.l
1 2 1 J/ a 4	 K J K K
• J ^	 r '^ 'r >t	 .•	 .r	 A	 ^	 a
K	 A nl	 A A
A	 A A	 At A A J • V .t L MA A	 A A A






s J _ ... 1 M
y 1• ^
•,
.y 2? K ,S 2 K .^[ x ri A ^.M	 .t	 a( :K X	 K • J 0 0 -Z
^ "t1	 K	 ^•	 .•	 A	 X
= J '+1 n MtiMG Z	 A K K x	 A
^ Aj L 40 Z QK K K x	 A %J
A x x x	 A J	 • v1 J r^	 .-.A .K X X	 X J Zi ..r ^+ ^i M
W r
• 1 4. G 7 3 'V r z a x V u
t :.D J N N ^ ti L rny: ti M t L L
.^ -. .. ^... .......-^ .^ ....
r 4A., J vo ^na 1.
"'' ^ J J ^ ti 1'^1 '^1r.. r v v ..i v v 	 v v r
'L "' Z
.y M^ 4 n A x x A x x x A 4 V
•..1 !V	 X A A x A	 x x J.
• J 7 J	 0 0 0Z x x x x X	 x x vc J = J ti r+1 ^► 11: M Ny x x x x •c	 x .! x J
~ y A' V ^^ it Cx x X X X	 x X x
uXXXXx	 xxIK


































s S 33 i
Y 2 ^
S i i 3 2 17 5 3e 2
e 3 t
S . 7 2 11 3 1t 2 27 u
r 5 iG i 37 Y
c t Y 1Y i 21 S i5 Y
1; r 3 c 3 22 3
11 Y i 2 13 2
I l r r t [
1 3 S ^ e 3it r i 1G 2 31 u
7 3 r 3
le r ^ 1u 2
17 c Y 10 3
]r 13 3 2i Y
1^ 11 ? ti 3 29 u
2v Ic i 3 " u
21 11 Y 17 2
2r I2 17 3
c3 13 1S 3
it 1- 3 ^S 2
cS r lc z 17 Y
ie :e 3
c7 r 3 21 Y








l iE 3 30 ? 3c l3 3 35 i 30 3
3r c, it i 27 i 29 c 31 2
3` c• - i& S
3r c' r
i7 3
3 n cr c































Figure 18(f) shows the synthesis output for the sequential cir-
cuit. The NET l for the identifier M23(1) _has only one entry '•n the
NET Table. M23(1) is connected to pin number 4 of cell number 1 (cell
$	 number l corresponds to the standard cell 1720 in the cell table).
..Figure 18(g) -shows the circuit diagram for the sequential circuit
drawn from synthesis output. There are more cells in the automatic de-
sign-compared to the manual design. The excessive cells are due to the
4	 following:
(1)	 (X(1)*S) is repeated in equations M(2) and M(3). This re-
petition adds 2 more cells (an inverter and a 2-input AND). This can
be avoided by declaring (X(1)*S) as:
<BO> Z ^(X(1)*S) and using Z in equations M(2) and M(3).
(2) The SW test condition is not necessary in Line 15 of Figure
- 18(c). The SW condition of the BEs and RTES in the DDLTRN output adds
9, 2-input AND cells. Without SW condition in an . Automaton the simula-
tor gives an error ccndition.
(3) An inverted output is available for the D-Flip-flop. For_
"A(2), "A(3), "A(5), and AA(7) use of the inverted.output can save
4 - inverters.
(1) and (2) above are.DDL description dependent, (3) can not be
avoided in the present implementation because the registers are imple-
mented later in the process and as such, the inverted output information,
's not available during BE synthesis. The mammal design is drawn with
single gate cells only, whereas the automatic design uses larger cells.
-79
6.2 SERIAL TWOS COMPLEMENTER
Figure 19 shows a serial 2's complementer circuit along with the
DDL description, DDLTRN output, simulation commands, synthesis output,
and the circuit using the synthesis output. For DDL description
(Figure 19(b) and simulation commands (Figure 19(c), refer to [4].
"igure 19(d) shows the simulation output. Figure 19(e) shows the
synthesis output for the serial 2's complementer design.
i.
Figure 19(f) shows the circuit design for serial 2's complementer
. drawn from synthesis output. There are more cells in the automatic de-
sign compared to the manual design. The excessive cells are due to the
following:
(1)	 An inverter and a 3-input AND cell can be saved by declar-
ing C(2)*"C(1)*C(0) as Boolean declaration.
G	 The SW and T conditions in the declaration are not necessary
	
i
	 in the .tines 10 and 11 of Figure 19(b). The SW and T conditions of the
ti
BEs and RTES in the DDURN output adds 10, 2-input AND cells, and 4
inverters in the automatic design.
(3)	 As discussed in 6.1, inverters for 'C(1), 'S, "R(6) can be
saved by using available inverted outputs of the D-Flip-flops.
(1) and (2) above are also DDL description dependent, (3) can not
be avoided in the present implementation because the registers are im-
	
1	 pleraented later in the process, and as such the inverted output infor-
mation is not available during BE synthesis.
"'he state declaration in the automatic desiSa changes automaton
G0 11' to a register anJ corresponding :Mates BEs. 'The register transfer
occurs only if the condition part (part of wh-ch in turn is dependent on
	












1 " 1 O
•-
-
V U • W
! ^ "' J V V —. CL









































































































yL '+1 M .^
cr = Z
.1. .. ^ ^ .. ... ^ V x :. ► tJ U	 cn
,_ ^• y ••	 •• ..	 .• ... .•	 A	 A A A A
.. • aJ Z (.t !^ r f 1 V V Y V V
u a
q :L A A	 A A
1^ Sn .L
	 J t





























• J j •
v 1 r ^.
V I	 ..
d J V	 ^...
I t ^
Q V ^4
^ J i •^
Z 11 .1 ••
Aj	 s+ J -- !)Z	 x ..
.)	 •• f. A 1 A
Y ^ 2
W Z JD 171 n
.0	 q V J V
z	 r
a	 v A A



























I 1	 , V
aa .^
v v ^ y
L v
.A 41







r t o `-'
I
I J J L^
^
-.1
^ \ V 1 #
C # 'J ^
-
' 11 1	 ^.. y
a
r 3
a J -.1 U










0	 4L	 49	 IlL	 I	 I	 A	 I
v v 11 4 v
L	 46 Z
v	 w v v 0	 V	 V
•	 • jr	 JL z V.- I z
— X Q--	 r *-	 \.
41 0 4% a it	
-- — — — — — — — — — — — — —
'el	 -P,	 In	 OL
if If
	 16	 to	 it	 li	 t	 qg	 c
-j 4 J.	 .1 1 I	 If






	 V	 t	 i	 2	 a
4K	 &	 A
	 1	 1	 16	 41	 A	 1	 41
-3	 r. v	 L
z	 r	 F v	 v	 V V V
IK	 It	 41	 -IL	 qL	 It





R	 a	 q(	 -K	 4L	 0	 4L	 IF	 R•
L 1 1 1 1	 i L 1 L 1









I=* /CL. N -' 1)0














^ n l l ^ 1 =^ l 




J L• "1	 •	 V•''ti1











O 'V J1 Jt D O O J P v X) O	 O O 4 n ad 7 O O 0' 	 7 .D
.D :r IJ	 J> J O	 4) y — 1/1	 —	 P 1-
7 L .^	 7 O J C O J J 0 0 0 O O 7 0 7>> ^fit
J T ti	 wt	 a s
M 1 ^+1	 M	 7 J
f	 U 1 1)	 - U ti t 'V	 'V 1 M •,r1	 7 T 7 7 Z 7
=1 -:1 7 _ _ = 7 =	 '^ C D	 =^ ^ = _ 7 O : =I 7 ^ 7 => 7
-- Z 1 1 L 1 J' J 3 J' J J t	 ^n n	 J? Or
	 Z G	 -- 11 ,L \


























uI611 A L LE51(,N L A NGU A GE SI P, L I LA10-	 E^-S10%	 SFC 1419
l ;	 <FL>4 6
3:	 cHE>1/^/5,2U
S:	 <LU>L'U11k /CUPwF 	 So, C.I /,I
6 	 c,I>
Figure 19(c): Simulation Commands





ir k ,( L L L uL•i	 ^.	 ^^,
^	 1 l!tJl	 i	 ^	 ^	 (^ i UU 1
1 1tj	 UI ► 	 1 l'1 1
r	 1 1	 1 u L. l	 1	 1 L	 l	 l^ 1
^	 1 0111	 ^•(•	 1 1	 1	 1 1
1^^	 1 lUl1^(	 1 l+^l 1
lr	 1 11u11L	 1 1l1 1
1^	 ^ 111(11	 1 1!•1 l ^	 i1L11
1^	 1 1	 1	 1	 1	 1	 ( x,60 1
1^	 1 0'Il	 IL	 c L • UI 1
iL'	 1 C	 Ul•	 1(	 1	 (' 1	 1	 (, I
!i	 1 I	 Ul , t	 I	 I I	 1 L	 1	 1 1
e I	 L'1'1	 I	 I I uU I
C;	 1 l'	 I	 I	 I	 '	 l	 I I	 L	 I 1
1^ ]011	 L	 1 1(•l U 1^11^
3''	 l 1^	 1	 1^	 ^'	 ^' l	 ^ 	 ^ 1
LF ► JLr	 "f w L ► t.L L  I	 \rL	 1
i J+	 L:	 1	 I^ ► l E 6 w J r L l f l L 1 1 I` r t 
Figure 19(d): Simulation Output
i /^ /1 A A Iq
 A /^ A A A A A A ^ A /1
^^ .^ A w YJ"I •/^ M w .y a. A w•" w w A^ -
-
 y
- 'r v v V v v v v v V V v v r^ V V
.i + M 11 It .4 .0 L x K st x K at 4 K x
s x a a	 K x K x % x K x Kxuue xKxx A xxxit
d K	 x x st •c K x rt K •t
ji x	 +t K x K t► ar ,Y x rt
•`^ K	 K x K K 1t X K A K
^[	 K •l K x K x x .c tC
Y
r v r	 v v v	 ^.. V
ii
^ v v r v	 r	 v	 v r
w M n •t	 4
it. 
t •a a t K x
K	 rt	 Q K X Y	 X K
	
w X
G x	 At	 x K it	 .% K	 •t K
1 •C	 -L	 K x x	 x x	 n K
x	 K	 K x x	 it x	 at K
r K	 -	 ra	 x K x at X	 . At K
`
I
K	 - x	 K A K	 x K	 x K
I • w,	 J	 J rn t^ .. J+ J	 +1 r^	 l+ p r+1
I` 	 i ^
w	
— 




• r v ^ ^ ...^ r ^ •I v v v rr ^ •../ .I ^ r .I
.^ 1 1+ 7 3 x ^-	 x K x K x j x x x x
^. 2 s	 s	 a i	 X ^[ < rt x	 w	 .t X
x :J C +^ x x x x	 x	 x K
1 t J	 x	 x K x x x	 K	 K x
- u x	 K K K +t :	 +a	 x K
XKAXK	 r	 x x
AL	 x .c x x:	 <	 t x1 _ '.a
	
x x X ^[ x	 x	 x x
I	 ;




r .r v .^ r v .,,r `r v v v r r r v v v
a' .► c i f .^ jr t 7t Z x t .c x x K x .I. x
I,	 s	 it	 x	 a
r y x	 x x x x .t	 X
—. L it	 x K x x x	 K
,^ x	 x x x w	 x
• z x	 x x x x x	 At
.., x	 x x +[ x x
	 x






























z J h M
^:. 'iJ Z+ t Z x x
J) •J .w fV r r .... .. .^
e	 a•
J 1111 01 t
—i •+ 'V ^V M	 ? :J^
.aJu
^_ • J O> >> 0 0 0 ^ Q
J J N V '^ N1 r+1 '+1 -^ ^+ 'yL .V L	 L X7	 AoJ ..^ ..r .n w ..r .r .r w w
r J • r M ^^ 7 r+ 'L J"V
J.1 t
J
i '^1 L L• t M •^ L M is
J • I N .r t •)	 o •—
• ^- L L• L N '•. 41•	 L L	 L L L
s _
• J -^ - _	 C cc ^c
J J « .. ,'V M M
.0 c
' J
.n .^ ..r w .+ .^ w w r ... .a
J JJ •— VMMJ.!
CQ J
J
• J •-•z,r^ ;7 t ^,^•.




%miBI  I - - Lt
"t1 CtLL rin	 CELL ► l,N CELL rlt. CELL ^-l h CtLL P I N CtLL 3 I K CELL 0 1'.	 CELL ► In CELL	 0 1'. CELL	 F
1 1 3	 2 5
c
S 3 3	 1 1
c Y	 17 u 14 3 10 u c• J 32 Y 5Y i
^
5 c c
* 5 -	 u 3 e } r 5 1 1 3
7 S 2	 lc r
r r u	 35 r 34 5 1A r YY 5 u7 5 50 54 5 47	 S
v Y 1	 5 2 31 Y
I ^ J	 r^ 3 0 3 35 1 34 3 u2 c Q 3	 .47 5 '.0	 3 ^Y
1	 1 3	 ^ 1
1 r r !	 1 7 2 5e e
1	 3 r Y	 lii u 13 u !0 i
1+ 7 i 2 2^, r r1 1
r 2	 ltl 2 27 Y e2 i
1^ 7 3	 P 3
t	 1 11 r	 io 1 22 3 1+ 3 it, I e0 3 el 3	 oe 3
1- Y 3	 Iu 3
I v IC 5	 11 1
1^ l2 Y
21 I  3	 lu 2 ^u u
cc t1 r	 13 J 1r 3
13 :S 3	 15 2 el u
4? 13 2	 IS 3 1^ i
iS
2^ IY Y	 ii 1
4e r 2
to 1^ 3	 e  2
2 c 17 3	 17 5 213 3 20, °. ^ 3 2d ' ^i i	 31 5 35	 3 5c
3v 17 ^	 1r 2
31 I^ S	 1^ 2
is cC ^	 it 1
;3 ct 3	 23 2 l5 i e 2
it ii +	 13 1
35 c r r	 15 j 1' e,; It




3'- c 5	 5 1 2
r,. 31 5
+1 5c a	 37 2
+! !' J	 3r 2
M3 ^ t 4	 rY 2 JJ Y ^
3 +2 5
r 3	 rl 2
^^ :• r	 u0 2
r (, j	 r 1 ^
c r! r1 2 r u
S: Jc r	 JS 2
5e YY r	 J 5 2





	 4 5	 3	 46	 355	 49
	 4	 50	 2	 50	 4So	 47	 6	 4r
57	 4K	 3	 44	 3
Sh	 52	 4	 53	 2	 5u	 u5 4	 5o	 6	 51	 2
ru	 51	 3	 52	 3h1	 5 h	 4	 57	 2	 57	 4hl	 5u	 3	 54	 3	 Sl	 3h3	 54	 6	 55	 2hu	 Sti	 3	 5r	 3
rS	 57	 t	 5^	 2hr	 5r	 3	 5^	 3

























































the clock and other BE output is independent of the state declaration.
6.3 MEMORY
Figure 20 shows a DDL description for 4 -words, 4 bits /word mem-
ory, along with the DDLTRN output, simulation commands, simulation out-
put, and the circuit using the synthesis output. A detailed descrip-
tion of Figure 20(a) follows:
Line 1:
	 The name of the system is MEMORY
Line 2:	 Four words of the memory are declared as 4-registers R1,
R2, R3, and R4, each 4 bits loi% (numbered as 1 through 4). Register
OU is also 4 bits long (numbered as 1 through 4), used as a buffer.
Line 3:	 A single phase clock (time) ME.
Line 4:	 Input terminals R,'^. and WR, 1 bit long, for READ and WRITE
operations respectively. Terminal S, 2 hiu^ long, to provide word ad-
dress.
Line S:	 Automaton W1 is controlled by Clock ME.
Lincs 6-9: Tile REt%b and WRITE operations take place when clock (ME) is
present. The register (word) is selected depending on the value of S.
The contents of the register (buffer) OU is transferred to the
selected rv,,jster (word) if the WR signal is on. The contents of the
6elected register (word) is transferred to the register (buffer) OU if
the .%'E signal is on.
Line lU:
	
Sets the flays of I)DI RN to output the results of each of
the six phases and the facility table.
Figure 20(b) shows the input commands for DDLSIM. Flags for
DDLSIM are scat for decimal data input (4) and binary data output (6)













e':	 < hE >hl(Y}.k?(4I,h3(w].NY(^J,CI.(^l•
tAt,, >wt M: ME
r:	 1S •OUll ktlLi	 it 
	 11% ORJ R14-UU.
T:	 x1(.?1hkJCL4-kj	 j4%1 ]I624-t,Us
+:	 stt ?l kF! ( l^<-KZ., ) riK1 1,3 <"LiU0
^s	 r3lt!hE1CL4- Feu 	 h4c-uu....
Figure 20(a): Description for Memory
F'AS51--F A L I L I I I t b 1L•FKi1FIFL
LkCLO% tt F6LILIIIts
<^1^ A^wJ,kr




cIF> ^r 11:1 )
















































J J^ • • ... M	 w	 a ..•
a s	 s	 s	 s1
^: t s	 1	 1	 1	 V
,. +1 v V .	 • a V V V J
' L	 • • r • •	 '^, • • 1 .^	 t	 t
J. .L • L 1 •	 ,^ J J. ♦ f
1 • • 2 ti J. 1 s	 J, t • \ ^ .^ .^.	 1
L i a 7  a ^^ A -^ s	 L i	 s	 s	 L	 s
It L v t Z 11	 11	 11 a • • •














5;	 « E>lk/ hF. h ►+r:^U.1.U.1.Ur1.U.1.^r1.U.7
r:	 < UU>1 ►•/ ►•lr^w'.hS.^u.^E.n^.IJL.^/
7:	 <SI>
Figure 2O(b): Simulation Commands
1
l
1 ; 16116L t'F:IL•	 L 1.1,L, U A G ^ ZSIVI L - lL^	 .Ft-^'ILiA rSrL ItiiY
i
F	 ^
11"t h1 ^r	 •3 ^a t	 L1
(' ( 1 U 6 1 ul- I( • 	 C-011 U1uU U	 u	 1 1 111 lU
Uluu (. i l	 I	 (1
	 0011 0100 U	 1	 I	 li, ( u('
u U 0U11 01110 1	 u	 cull 1'1
1 tl	 1(	 (' t' ('
	 1	 G	 (1 I.	 1	 (' 0 1 J t' U	 I	 I1 11	 1	 t.• 1	 I 1
h 01 U0 (u11	 ('010 01J1 1 1	 1'	 1 1t(' I1
T	 t^.0	 ( ► ► ILE ► r AC ft 1 . C?%	 II\ i^1
t	 0L1,	 11	 r. It L	 el 11`r
I









ON 04 ow.........^.NMy1 a...^......»..
AJ
^ x M.00 ^? R M ^.7 .r x x w K K X
.^ K t t .• Q X IK .9 Q x 2 x A A x K KK	 t	 7[	 X K x x K x
Y K	 .l	 x i[ K x 7t xi w	 fl	 x w x x K t
J x	 x	 x x K x x x
^ K	 X x K K X
x	 ^c	 x ^c .c x ^c ^c
• ?^NG^^d.'VOO1sN^O^s





&A.	 JJ ur a1 V` y r.1 r ly K At	 7 K •K K n K
K X
	 K K K K x
L	 K q	 A K X x wA.	 X x
	 K x x x x
t K
	 w X K K x
^^	 K x	 K K ac A x
K K	 K K K K x
v5 r+ •- J . J M r•	 ;t. J .n 1- .. J P M 1^
..... ^^ tiMh Wi o s rs J+C L
	V i 	 11 K n K .. K. ft
^	 i i L .•. t K 2 K L ^ Y K n x t ..
s	 K x K K X n .. K
t	 K	 n	 K •t x it K x
.L	 •^ K x x X K K n
x K K K K K K K
«+	 a X x K x X < X
x t( K K K K K X
•	 ` 41 C J A. .V 1: 0 7 L 'V L'
.^.+.. ti tV ^M «n J ^^ J! L L
ty
_ v— v v— v v v v— v v— v r ../ v v
.l	 K j P^	 7q o J a K^ V X K x K r. K
.^	 t .[ -C L
	 r K	 .t 4 +( = n J+ n K K .a
x	 t	 K	 K K K K +[ X K
.:	 x	 =	 K K K K n K n
y	 K	 x	 K n K n K K K
X	 K	 X	 r[ K K K ^( K
w	 1K	 it	 K x X K 4 KK	 at	 x x A K X X K
































• J 0 0 0 0 0 0 0 0 0
7J NNG""m"WINN





• J O O O O O O X 0 0
Ll J N 'N O-11N^IMM
•- ,.i o n o •n o 0 0 0^
hu ww w www...o..
J • cM^^a—s 1► ^V
J7 w+N11 ♦1! !1^ ^J t
u
• J 70 ^'^ 7 > > ^S O
a^ 'ZA
^.• CCLiLL OO S
n ,,,^ w w w w r w r w w
J • l^ 'V J L '^1 O '^ ! w
J^ r w V `^1 ?! J^ t
r. ar
.^ J • V V w Ml ti V ••1 Ml +1
— ,.r L a;n^ci^^a
1. ,J r r r	 ^—	 w r
J • 7 w-L 11 tiT t^1C
r^ w r V^ N! ,'^ f 0
^. 2
V
• J 0	 7 7	 z OJ 'V 11 _ .• M 1 'V 1 'Vi L L i +^ L O C N O;n J w w r r .. w r w w
J r r— V	 f f
.^ 1
• J Q C G O	 0 0 0 J
^ ^ t `r L L t' L i L
^1 J .^ r r r r r r .n ^
.t	 J	 • 1? t^O A ^^ t•J	 JJ r y w1M 7 f n
1	 L 2
i	 J
• J ^^ 0 0 0 0 J J 0 0
J	 J r V ^ `^titiNtiVr1
J	 ^ .r •^ t t i I t^ L O=















+t' CtLL Y1• CtLL 016 ULL 'I A CELL ► 1• CELL P ik CtLL PIP CELL !1k CELL 01 14 CELL 014 CELL ►
1 ! r • S ! 1
! 1 1 • 3 I2 I
3 1 ? e 2 I1 t
r 1 ! 3 I • !
y 1 s s 2 • 2
• • . ly If • 2Y Y 1s 9 20 •
r 1 ) 1 10 it IS 1
y r 2• 1 so 3 S2 3 I+ I I• S
^ S 2 ! t 11 2 Ir i
10 • r ) s • 3
I1 1 • IS . 17 ) 2u 7 i3 7 2• I
11 r I! 2 SY I rl I •s S •% 3
Is r ;0 ! 11 !
lr 3' r 1) + II 10 S .I S 1. S
1^ 11 „I t •f% 3 SO s !2 S S• 3
I• li r 15 f 1. 3
II IS r IS 1 lI 3 10 ! is 1 l• I
Ir Ir • S• 1 !) I S• s t1 3 •S s
1f. Ilk 3 IS S IS I IS • 14 s !! I .I s y • 3
in Iw 50 1 I• 1 460 c S) 1
^) 1l •aA r
i 4 17 r .0 r
cs 11 r• •
lr 11 t S• r
1 % 11^ It, 1• 1
is 1" 5 19 1 21 1 1S 1 is i
17 11 10 1$ l
d- 1• ! 14 3
1 • cl • 31 2 +1 2 S0 1 2
so ea 0 11 •
II lt' • rl 4.
31 t^ + SI r
ss i  rn •
5^+ i0 10 11 1
5^ it s e2 s
!^ 1S r 30 1 rs i Si 1 tl 2
sl i3 r 3y ^
!• is ! rr +
tr
.3 S3 r
- [ 5 i e1 ^
.1 ri 1( lr 1
^c [+ f i5 +
+± t- r its 1 ^^ ! !^ c eS i
Y^ [1 ! c^ 3
^^ [^ r SI ! 55 t 3b c ! 1 c
•t ^^ sl 5
^t ^[ ^ 33 s
Ss fr + f5 !
Figure 20(d): (Continued)
102
So 36 do	 $7	 3
SS 341 do	 410	 t	 ae
yo 3's so	 40	 1
S7 a1 a1	 3
Sr "3 a	 eo	 3




	 1	 y 1 	 1	 ss	 2	 5s	 i




b 5 ye w	 y r. 	 it	 e0	 1	 el	 i	 e 4	 i
be 57 SA	 3
e7 5 y 60	 3
hr r 1 tt	 {






































1, 2, 3, and 4 respectively in line 2.	 The register OU is initialised
ato 4 in line 3.	 An input/output trigger TR (raising	 of ME) is de-edge
clared in line 4.
	
L.tne S reads in the valued for R8, WR, and 8 when
the TR is on.	 (There are 4 sets of values). 	 The values of RI, R2, R3,
((^^
R4, RE, WR, OU, and S are :o be output when TR is on (line 6). 	 The
simulation is started with the <SI> in line 7.	 Figure 20(c) is the
Lsimulation output.	 Figure 20(d) shows the synthesis output for the
memory circuit. 
Figure 20(e) shows a circuit diagram for the 4 words, 4 bit/word
memory circuit drawn from the synthesis output. 	 The automatic design
from the DDL description output does not add any more cells compared
to the manual design.
r
6.4 VARIABLE TIMER
Figure 21 shows a variable timer circuit, along with the DDL de-
_i
scription, DDLTRN output, simulation commands, simulation output, syn-
thesis output, and the circuit using one synthesis output. 	 Figure
i 21(a) is the block diagram for the variable timer circuit. 	 The circuit
f
consists of a divide by 3600 circuit R along with a counter CT that
counts the number of times R goes to zero.	 CT is compared with the
input setting IN.	 If IN equals CT, an output pulse is given, and the
start register is reset to disable the clock.	 ABORT input clears R,
CT and START.	 START input sets START. 	 A detailed description of
R Figure 21(c) follows:
Line 1:	 The name of the system is VTIMR.
Line 2:	 Declares 12 bits register R, 6 bits registers CT andlN
(numbered 1 through 21).	 START and ABORT are 1 bit registers.
Line 3:
	

































































































































































































11 •	 ^ J
—	
_ _ • -	
_	 1	 -71 • •	 C.	 ••
Z	 II -- L ^ .1 11	 v ••	 11	 •	 •	 ♦ t J)	 11	 •
— - -	 I s	 . — -. —, — .— — 1 1 1 1 ^ J^
L If


































l• o U	 T
k h U	 d
1 J M ^ M L1 I I\	 I I I
0 Uutil; UC.• X15 1	 1 U 0 b2 3547 0u ( 1 5 0 1 (1	 1
2 35y5 to ( 1 S u	 1 0 1 bu 35 4 1 0u 05 0 1 u	 1
4 35 y It- t o t . 05 0	 1 6 1 hh 3 1^4 q Oa 0 5 0 1 0	 1
r, 35 Q / t, V 05 0	 1 0 1 b  3r00 (Au u5 () 1 0 2
t, 3 1^4N t• (1 U5 U	 1 u 1 No jsb00 U5 C5 U I V	 U
1u SS44 to  0 5 0	 1 0 1 72 35Y5 U5 u5 0 1 0	 1
12 3 i1h Ut, V	 1 U 1 7u 354b t'5 ( I 5 6 1 0	 1
1u 3^^U 01 (1 5 U	 1 V G 7o 3547 L. 05 0 1 0	 1
1 3545 (1 u5 L .	 1 i, 1 71- 35	 t% toy uS 0 ! 0	 1
1+^ 354h (1 GS 1.	 1 (I 1 X11 3S Q 4 G U5 0	 1
2t o 35	 7 t	 1 VS 0	 1 0 1 r2 3rto(I l'ti h5 U 1 1	 0
2e 3S U 1 0%u t,0 t,h l 5 1 1 G	 C
lu 3tiv q t . l t'S U	 l U l kt. S5 45 Ul. U5 U 1 U	 1
2b 3 h( , U l : 1 t ti 0	 1 G? hrz 35 ,-h ( • ( I (IS 0 1 0	 1
P. 3 1'5 C	 1 40 3547 uV VS 0 1 0	 1
t0 35 Q S t•2 u5 0	 1 0 1 42 3Yvb uV 05 0 1 6	 1
3r 35 c U5 0	 1 u 1 vu j5 •?4 u0 05 co l 0	 1
3u «1- to uti 0	 1 0 1 4h 3eoU U(I OS U 1 0	 i
3 h t.c, US G	 1 U 1
3r v tt u u	 I U I q  SbUU 01 Uti 0 1 U	 U
w.' U t l 0u 354ti u 1 US 0 1 U	 1
V [ r'Ul- t- '. U	 1 V
uu 35v% U3 V5 0	 I U 1 102 154h U1 05 0 1 0	 1
vh 354r I t5 U	 1 U I IGu 554 7 V1 PS G 1 U	 I
ur 3yrr 7( 3 uti 0 1 1 Ur 3541+ 01 (1^ 0 1 U	 I
St . ;S 4 r t 3 05 l	 1 0 1 1 Uh 55 4. 4 V I GS U 1 t ,	1
S2 35V4 u 3 I-N C	 1 U I I	 ltl 3t`u0 (11 V5 U 1 I	 e
7 u UV t-	 AI U	 1 U 1 1!2 U tic V5 0 1 u	 i
tih 3ht a t o t ti (,	 1 j tr I l u 3545 k-e 05 G I v	 1
5^ 35	 5 C	 1 u 1 llb 354 ,,e OS 0 1 1
t% t o 35
	
to (u , 5 u	 t u 1 1 1 r 3S47 U e 05 0 1 v	 1
J1"1 , L o 11(A It 6 Air l r,&ltl f-	 A-	 .T	 L ti Il@6 tc 11U












Line 4:	 Terminals OUT, X, Y are 1 bit long. Terminal XA is 6 bits
T long.
Lines	 5-6: line 5 compares each bit of CT and IN.	 If all bits are
•
equal,	 then in line 6, X is set.	 Y checks for count in R to be 3600.
Lines 1-10: A special operator named by CNTIJP.
	 The output of the
n - operator is 12 bits number.	 The input is through the argument Z	 (7. is
a formal parameter). The operator CNTUP is simply an add 1 circuit.
Line 11: Automaton VTMR is controlled b y the clock P. VTMR is 2
bits long, thus can have a maximum of 4 states.
Line 12: State 1 with identification 0.
	 Automaton VTMR waits in I
till START is 1.	 Mlhen START is 1, CT is reset if ABORT is 1; ABORT
and OUT are reset, and a transition to state S is made (all in parallel).
The period terminates I.
Line 13:
	
State S with the designation 1. 	 R is incremented by 1	 (R
is counted up fro.a 3595 rather than zero, to save some simulation
steps).	 Transition is made to state T, 	 if Y is set, else remains in
Lite same state.	 The periods terminate	 IF-THEN and state S.
Line 14:	 State T with the designation 2. 	 CT is incremented by 1.
OUT and ABORT are reset if X is set.	 Unconditional transition to state
I	 is made.	 The periods at the end of line 14 terminate IF-THEN,	 state
T.	 ST, AU and S1' declarations respectively.
Ling: 15:
	
Sets the flags of DDLTRN to output 	 results at each of the
six phases and facility tab'e.
Figure	 21(d)	 sh)ws the input commands :or DDLSIM. 	 Flags for
'	 DOLSIM are set for decimal data input	 (4) and decimal data output 	 (8)
in	 line 1.
	
line 2	 initializes	 IN with value	 5.	 line 3 initializes
r. 
ABORT' and START with 1.	 Line 4	 loads R with 3595 whenever in I state.
r_
a o" O tih f► r rr...^ r r r r r... ..
^	 ^• .../ .r v v ..^ u/ `.I v .r v v ..► r 'r v v V v v v v a./ v v v v v v v v
,i	 K ^. rry J1 C a	 C t Y x :J U .^ U U J(L tl CL x K K K K= K x x t art
-^	 X t t	 t -. A J r	 `^ )» X A K x K
r	 K	 K x x	 x x x R K
L	 K	 x L Z L K A x x K	 K K K K A
,a/	 t	 X V U V K K K K K	 K K it  K
_	 K	 n A x K X K	 K A At K K
^••'^	 K	 K K K x K K	 X x K K R
K	 x K x x K K	 x x K K x
•	 o^v s^	 r y o>> s^v oa a^vooa x N 4 Ds xv oo v
w+ •+ 1 1 'V -I1 M? 7 .y r f t D Z P- V- V V Z 7 7 » O '+ r X11 V
'` ^ .. ... r 'V 7 f O O' r .. e+1 J^ A "J r ti O O r ^. r ^ .r — r ^ ... .n ..r
Y r	 .ry
1	 l-- t _ L a — G 'Z A 'V NV _q 'V ^. v A. IL 1 n n n K K A n 'l w X K
r	 t	 r	 K .J -^ Y ^, —	 "^ ^^^ K x A x K .t x	 x K r
_	
—	 _ K
	 ^[ — A K K K ^[ K K	 K K K
L	 L K	 K Z Z C x A K K ^( x K	 K K sf
At	 at	 ift
K	 x K A A K K K K	 K A at
-+	 A	 K A A A^ A K A	 al K A

















+,	 1•	 d, f. — 1,	 w rte- — r .r •^, ^... ;n	 .n ,.	 ,n v an f• 
— 
r	 -•,
.,....	 ^,..+n^ o nr n cow
i
.i	 t 4 NO 7 a K x = K .. K n
A
	
n A A R K K R K
^	 —	 — ^^	 K A K K x K a X
c	 ^	 f c L	 K K A A w A K K
y	 ) u	 A K A K A w A K
_	 K A A A K K A K
—	 K A A K A x X K
K K n < 7t x K A
1	 G	 l V 1>4 L 11 L C 7 L V L	 a A. N t O 4 L A V V J 7 L (V
— ^ -- V t M +n y1 J	 1. J l J . L 1 r-	 F- L J_ V J J	 Z) — — — ty
V r. ? t ti -- ti 7 t 1 .. 1 Z t 1i ^. .... ., .. ... r^ r. .^ .. ...
-+ A	 T A 1	 _ l l A '\ V V • .\ 'V 1 J 1 K K — A A A j •[ A K w
A 2 K ...^ ^ A K .4	 n Z, x A A K A x K
At i K X A at n it A x A
x r .a t	 L n n K K A x K K R
A j x '.J n	 A R K A ^l K X A
A K x A A K x x K K x
XL •
M
KA x x R X A



















•- y	 ^1 D WIN M I O D t D D Tr •^1 D L
J •	 7 ► D f ti P D .^1 O '^ 7 ^» D 1• v
J 7	 -^ N 'V In 7 O Ln D	 t %71 01 O^
J
• J O0O = 00 0 0'^ O .^ O'^O JO
J J	 ^V ^ 7 U ^+ ^' 'V M +1 11 'V 'V /V N •-• ^•
JJ	 .G `•1 Fl- D yl M U 1r L C r L O D Vol N1
J • D --10 p- 7	 Q P 'V T C ^01 O	 ?
• J 7^ C '> >= 7^^ 7 7^ 7 0 O O
— 1	 L r1	 t: ',n X. L L r+1
J J
	 'L iV	 V .y — r` Nr	 NI V - Ml r+ l .'\, n.
L L ") 1 •L L A. L 'rl .L L A. 4
I, J
	
-, - - - - - -. - -
^, • Z	 L r ti T t	 _^ z- L J' 'L T
'J




"" — — L 1. ... ... M >r — L .n Ni n V .^
— y	 M ^1 w1 L L 'rl a'1 Z C ^+1 L 1	 X L 1 L
:J .. U	 U ti	 -	 - - -
J • 1 P D ^1 J 7	 X f v J L '01 O r. 7
J	 1. "^1 r1 7 J•1 J1 1' ^	 L T :1 G
•	 •- X.
	
















• J ^ o 0 0 0 0 0 0 0 0 0 0 0 0 0 0
'.^ J 'V r+ N N •• •• •^1 N O 'V M +1 M O 1+ ^
114
NEI ULL 10 1 k ULL P I N CELL P I N	 CELL PI N 	CkLL P IN	 CtlL	 P I K CLLL 01 1% Ct1. L	 1, 1 k	 CtLL	 O lh	 CELL	 *I%
1 3 y A 3
1 l 2 5 3 n7 y
3 2 1 + 2 ed y
Y 1 3 3 S Y 3
2 3 3 2 5 i
• y Y h 3 1 3	 eV t	 70 S	 7t	 3 70 S 7e	 !	 7C	 3	 !1	 i





' It ) Y +0 ^
II 7 2 e2 ^
Ic r Y ► + o
l•
IS e 1 v 2 Ia o
1• l l ^ r^ Y ^e 1
1^ ^ S 10 1
1^ 11 Y .0 1
l i 11 i 11 Y
I^ 11 ^ iU ^
• 1^ 12 i .49 y 103 1	 105 2	 Ic7 2	 10a	 2 112 2 I1 Y 	i
1u li 3
11 15 ^ 1J y
^• 1c 13 i 51 +
2^ IS 3
20 S
1S I+ 2 53 Y
lr 1^ ]
^. 1) 1S y 1J 1
1r l` 1 55
I a 1S 3
5i Ir ^ 21 3
SI !r c 57 u
3i Ie 3
SS 17 Y c1 2
3w 1	 7 i SV y
s^ 17 3
1. it 1 `. 71 Ve t
11 1 73 a7 2
Sr t 3 75 Y Vv 2
;r 1^ 5 ^V Y 1u7 y
rU I ► • 01 + (n0 Y
y l tr 3 3 w 112 y
^e I^ c a5 + 11+
.3 : ► r lQ 2
++ cv t 12 1
t	 j ^S c 1 + 2i 3
+1 c3 S 3+ 2 a^
r ^^ c3 i 1r ^ 3+ 3
^^ i+ 3 35 2 V^ +
^.
Su c+ i i5 Y S5 3
l ^1 cS 3 Se 2 a^
5c 24 c Ie ^ 1e 3
. 53 c^ 3 S7 2 l 	 A +
I- Figure 21(f): (Continued)
115
s• rr 1 z7 Y !7 i
5 y r7 i St` j I U I Y
1 Sn S
57 ?h !^ ? tut 40
yh ^. 1v r j 4 !
S^ r• ! r1 j 10Y 3
wr, i o 1 SO Y r0 i
^! !^ S J1 j Ian i
w f !^ i !1 Y rt 3
^! ^I Jc l 111^ 3
r. ^ 1 s Si r YI S
^` 'r 3 J) l 111 S
w0 ^ L ! 3 Y r f S
wi ]^ t rJ 1 113 s
^ r ^S ( rr S r^ ^
7U !Y r Jr j 7U j
T I 14 r y0 1 '1 1
7j ^^ Y Sc 1 7Y j
7S 37 A. }r j 7n j
7Y !h r yn j 7• 1
)^ SG . ^^ l hl, r
7A Y1: Y r3
7) rl r ry j
7r 1. Y rT j
7V rS r rG j
• U YY Y Gt j
PI Yy ! Jy
h l ^h ! Sro AU ! r  y er ! ^r 5 Or 1 or G !V S
"3 •^ r r7 j
r Y7 ) Jr 1 11 y! 1 ^^ i 57 i ^G j
•, ^ vl 3
`) ^c r 5! t
-^ }Y r \} S
c
y r eY ; pr j IJS S ICS S Il • ! 111 V ! !li ! Il r Sa^ rY Il •5 (
+• t} S r7 1 er
r7 .r r w7 3
•^ r^ r ' 1 i 7; r ) y L / 1 r 7 06 1 CY	 a
•• 11 t
t tS !
I^1 .r „ J} t
I	 r 7 1
^ Tc r ; 7 5
1	 y 7r to it
i. . c s
1 •1 4 •1 3 ^S ! rS S ► 1 ! 00 } ^i 1 •• S ie S it
1J ► •1 Y rj S
r
I: rt . ^Y S









113 p7 r PV 3
I	 I" !v 3 R
 t vl t 93 2 1
 2
IIS Yb r 91 3
110 Yt v a l 3
117 ^Y Y VS 3
3 oe s oa 3 Iv0 3 Ic1 3 :02 103 5 1011 S lul !tiv Iva a lu+ 1 I10
ItG Iv y a 100 t
121 Iv1 r lu! t
11c 11u 3 110 S 112 S I1m S
113 114) r 111 2
1e+ 112 P. 113 2





Line 5 is output trigger TR (raising edge of P). Line F outputs R, CL,
1N, ABORT, START, OUT, VTMR when TR is on. Line 7 stops simulation
after time 120. The simulation is started with <SI> to line 8. The
E ^' simulation output is iveo in Figure 21(e). Fi re 21
	 givesy	 P	 g	 8 igur 	 f() B a syn-
thesis output for the variable timer circuit.
Figure 21(b) shows the manual circuit for the variable timer.
There a:e more cells in an automatic design compared to manual design.
The excessive cells are due to the following:
(1) The manual design uses a binary counter. Tile counter in
'	 DDL description is described by add 1 circuit. THs adds 24 more cells
for line 10 of Figure 21(c).
(2) The use of the states in an automaton aid., extra cells that
are required in the automatic design. (The first 9 BEs which describe
states, add 8, 2-input AND cells and 2-inverters. The condition
portion of RTES add 7 cells (1 standard cell 1800, 2-18709, 1-1620,
and 3-inverter:;, along with the 2-19308 to declare VIMR register).
6.5 MINICOMPUTER
Figure 22 shows a minicomputer description along with the DDLTRN
output, simulation commands, simulation output, and synthesis output.
For details of the DDL description Figure 22(a), refer to [4].
Figure 22(b) shows the input commands for DDL5E':. Flags for
DDLSIM are set for decimal data input and output (4 and 8) in line I.
The memory locations 0 to 14 are initializes. in linen 2 to 4. Line 5
reads PC value whenever in IN state. Line 6 initializes START with
one. _.ine 7 outputs CPU, IR, PC, `AR whenever in IN state. Lines 8.9
output MAR, 4BR, IR, ACC whenever in FE. and EX itates. The simulation








... «r I I ^. .V
1 ^ L 1
Al
 ^, ,^
1 t •. J 1• .. .^
r ^- ^ ^












































































X .0M 2 A I V A
^ 1 1 Z 1v V = 1J(
^
♦
I F Mt 7 f
-• V • N +t1






` v of .. XK ^n%j
• u




y v QY 1 ^ 1_ • • _
-D
^ 1 _
1 y V ? « 1 •-. .. 2 M
rd 1 y .a.i t t ^
.-.
^ e ` Y
l









. • c .. 11 -. Y r a a
• If n n n ^ 2 ... t Q ^ 1] .. _
^ l - Z G " `^ J M
a J •^, ... ^ 1 ^ q
• ^






1 1 •• •.
If NJ
l v J •—^
_ n 7 J 7 ^ 1 J 1_

































f T • ti
^ ♦ • 1 O l •
^ :A 'Y 2 I 4 ^ •
• t ^ O I V 2 •^• •Z v _, a v x .. .. •






























































Y r x ^ ^ v Y ^• .-. v ..
'V t. t t Q .. 1 2 . a . ...r :l






















































1 'l. 1 Y Ji v v^ r r v 2 ^ 1 e !; 1
v J J a Z v t .^ L ^ v t
^ 1 ^ 2 1 l L J t t ^ ^ ^ '^r., t -. .^ t t 2 1 ^ Q .-. 2 ^ t ^
J i - J 1 1 - 1 J L •• 2 ..
\ ^ t 1_


























•'^1 yl M M r1 M '^1
o-. N 	ni
v^l •y vv^.v	 -•
.	 .	 .... ...	 .0000>>o	 .1,	 z
\ \ \ \ \ \ \
	
..+ ... j r v v	 ♦ s v v — — v .w	 s —	 v v
w s s• a• a 1 1 1 J -+ — 1 1 IZ 1	 1 1 1 .. Z 1 1 1 1 1 >
-^ -• -• -^ -^ • w•• a r w« a • F« «« a w w	 • t a « a w t
.^ .^ .-. ._ ._ _ . , a a a a ti .y ._	 Yt J _	 ]	 '^	 Y 2 i	 7
Z	 L	 - L	 Lz	 iKK K Ka a
	 x K K K Z	 K K K •( K >'(	 .( X K K K !( K
11	 11	 11	 11	 11	 11	 11	 11	 11	 11	 11	 11	 11	 11	 11	 11	 11	 It	 11	 11	 11	 11	 11	 11	 11	 11	 11	 11	 11	 11	 11 41L I0, D 7z v Yl -3 r 
	 "^ L J D	 .y M 7 n 'D^ Y, >> -+N '^ J Xf Z n j
-+%
 L N1 V ti% ti .ti 1 ti M M M ^01 ••011 M y1 y1 1+1 'n J J	 Z, 7 J J Z J















-	 J J J 7	 7^	 L '-'
JL
r ...^ l -^ --
	
--	
1 1 1 1	 1	 i C 7 a'	 'U '^ ? `-' v --. r 1 i i 1 `-'
J, L t	 t 1 1 J 1\\\\\\ ^ JS 1 1 J + 1 .l `-' • ^ ..^ 1 1 ^ .^ •
a	 \ 11	 11	 11	 1.	 11	 11	 •	 L	 V i	 ?	 2	 J	 7	 L' [	 c	 [	 -•	 Z	 - +J..	 ,J ,.,	 ,^ \	 \
— i	 Z	 Z	 L	 L	 Z	 11	 11	 11	 11	 11	 11	 11	 11
.•^ \ \ \ a a	 11 « J \ Q t — 1 1/1	 ,i
11	 II	 11	 11	 11	 -'>	 "^+ ^	 J f	 ^
a	 a	 w	 11	 11	 a	 11	 1	 11	
11	 11




















v	 n a1 —
O	 / a
u	 a v a
N a
• Z
—	 N • a
o a..
o © n .33
a • O






O	 M T •O	 a 1 • ^
J	 7
• .^	 N A .r
« •^	 .-O Zr^
V — N ^ •
s U '^ — N 1 —
.1 O ^ • U V N1
^ — •	 .1	 • i
a »• ^ i = n o f
N - — -• ^V U • • a
r ♦ > w Z a —
a i ^	 • i J ♦ •
...	 ..	 •11 r.1
— f 'V ^ • J ^ I • —
n• • •.• NN^ 7 • Z «
....RaR..• N. z•	 a
... — N -. N N
	
♦ J	 Z
.- • ^ • ... a 'v •	 'v f+ —
R y w ^...	 .... ... R
	 • a•^
. n i
— N — a J .r a r • — .rl r1
V D V _ V 07 1 a •••




































Y —	 Nn ^ Z 71 « D ..
ti
a a •
.. a N Z
• a
+1 J^ ♦ ••1 ^+1
r•1 n
n Z • •
`+ • DT
z z s .
a
M • a
r^ ^ • O •qn • u n n









	Z a a Z	 aV D 9 •
♦ N P 1
r .	 ah ^ h O
	




♦ i ^	 7
V O •
• O N i 7
	
a a NO ..
	_
	
1 P • .+ Z	 D
a	 • -.	 a
	
a ^w	 a
	7 • 	 ••1
	
N O .	 en O
• a a •
Z O
— N 1 Z
	
♦ • e a >	 L
	
+^ o ^-	 a
	
N 1 • u	 a
	





:z a in a n
♦ O
a	 IL	 a
Z Z	 L	 1
	• u	 w
	





m o a • n 	 .
a •	 1
	
.a x n a	 ^
	
• ♦ ♦ • a ^	 a
— 4; -1	 i
u o
—:2	 • n 	 a
	
a 0 n • a P •	 a
	
• • • • O'er x
	
^
.fl P Z T ^ •	 NN •	 • ♦ 	 s
♦ N P • 7
— n	 •
	
n n © a •	 Z
	
— a • O Z
	 ^
O • ♦ • H 7	 I
• N	 • M H . •
	
^+1• .. a ^ n i	 7
1 V n • • ♦ • .. V n
v t • •	 Z — iR ) Z Z ♦ 	 « • •Z	 ♦ S J^
♦ ♦ a 7 .. M ^J+ -+ ' O JI Z • Z1? J a n— r — a
••. v a a• a ♦ a
2 Z x• .+N Z S u 1
n w1M	 O • 1/




r .+y •^. v y
7 s y 7a •• ^ D1 .+ a a
a y • 4f1







. M 1 u1 « V UV O ^ a
r •
n u .• o
« V r nO a a •
v •
Z O ZL N L
a • a ^ti
o ♦ o
• a n
• « . a
vl
• a • •
.r N a% Ma w a.
• •n	 a •
Z n 	 Z
a -, o
•	 s
n -.	 • of
Z •+ Z J
v>	 a
♦ 	 • a
s
• n •





r.1 7 M «
• « • Jf
Z -^	 Z V)y J
s a
n a n •N • N 1^




a ^ 7 N
x v Z ..
7/	 N
a^ DuO 1 0 0 1 a
• 7 O • a O







































1 O a 4
y let \
D 7 Z t
^, r^ 1	 •
1 L J'	 ^ ^ 1 1
.	 J •f^ 1 L L
--I\\_i tG a
2 ••	 1 Z :J 2 2
2	 .t	 Z "" n ^ 1 1
A A A A A A A A A A
J G C C s.l Z






























U I h	^L	 kAN	 MAN kbW 1h FL ACC NAh MbR i N P C ACL
00 GOUT	 000	 000
OOb 0000 0000 Ooe oovo
o0k 0005 0005 009 0000
u05 0000 0005 009 0000
UGt Ou0O 0761► 016 0000
000 0005 07tt 010 0005
010 1030 1030 011 0005
OOh 0001 103U 011 GCOS
011 lU2C 1028 012 0005
U04 uU43 102b 012 0005
012 2sb q 2Sb 14 U13 0005
012 2Sb y 25e4 009 ooUS
Ui:e cOul 07b4 U10 0005
u01 0 v 0 o u7r9 010 0011
UlU 1030 1030 ull 0011
Dub 0002 1030 Oil (A11
Ul f 1020 loe+ % Ole 0011
110&1 0044 ICI 014e Ili LI1
u12 25b y 2S64 U13 0011
012 25bv t5r4 o0S 0011
Ole UO0[ 0770 010 0011
CU 0007 0770 Olu OL1t
JIU 1030 1030 011 001x~
u00 0003 1U30 011 UCIt'
U11 1u2r 102e 01i IOU IC
0u&1 &1(4S ILcr U1e U(Ir
112 2tibti 25o4 013 GoIe
^^ 1 2 15 r,4 1St 4 uP 4 001 t•
UCE Uu03 u171 ulb 0010
(iO3 0000 „i
 71 01 U 011oib
U I U 103&1 luau u11 suit
OOb U U I ,y 1 ( ?t ( 1 1	 1 OG^o
U I I I U 2 b IUlt l 01i UC2t
00u 001,0 1vee 013 0%)er
u1! 1-1 &13 15 Q 3 01 16 0026
007 OUeb 1513 Ulu 0000
Ut , 35ru U15 t'l4
It Iv 	 L^ F 1Lt P-Eit L t t L 	INrUI
^i1 Ow ( I LAII( N ItKo^Iri. IfL Al	 I1"r -	 &157
















,i K J^ x x 2^^^ L, L •L 7 al x x x x ^ x ^= 2 l x ^
... K	 1 It u) N L a a a-. + .-... K x x x N K -% M M L x N1
PC	 U x	 n t	 t a	 x 'K x x a	 At a	 1 2 A. x s2 K	 K K x x
	 X	 l(
W x	 x	 V)	 x '^( x x	 K	 x
r' K	 x	 x K K X	 x	 x
-•^ K	 X	 x
+c	 +^	 K x x K	 X	 x
• svroazN 40 0 2 0 lu0	 zN40o	 r vo-M.v
Z) ^+ -^ 'V 'V N M •%	 0 40 40 •C P-  	 Z 4D f T LP Z> O
Yy
a.^ v^ v r v v v v v 3 ..r ..^ 3 v v v v v 3 v 33 v 3 v
1 L "7 J K .L V^ J J. '1 2^ w r A K V: V 7^ •.^ ^h L L Y K
^ ,	 V ,i n n	 a	 s	 c	 r it	 a	 it	 a	 a	 a	 Y	 L Z x a
x	 4	 x	 ,a
rd w	 x	 K
- x	 x	 x
4	 R	 x




.../ ^, v ,^ r ^/ 3 ^^ rI •^ ^ v r a.. V V V V ^ ^/ u,V ^ V V ^/ tir
Y^^ t y v l "n fl ^ i is 4 L w 4 K R .Q K 'L Z 1 Z ^[ L
^ J	 1	 K ,a :/% j a	 a	 a	 — 4 r^	 t	 t w	 K `n l	 Z K "^'
— ;,	 •, .^	 ..^	 r	 K a	 w
ft *
	
40	 •c a	 2	 2 2 x 40
G r	 K K	 . 4	 4 r x 4	 K	 x
y K	 4 K	 K r K K	 w	 K
<	 4 4	 K r K K	 r	 w
— K	 w r	 r K 4 t	 K	 K
K	 \ r	 M 4 K x	 K	 K
• t=	 c (V u	 Z 4.	 ti	 a	 Z. a	 1	 v 4. :.	 J a• v 4. Z_ ;3 i , -14
1 — — — .-. .-. _ .-, .-. — _ — .-, — -. .-. — — — — .-. .-. — — — .-.
—	 t A
y
r. 4_	 x -^ -- ti	 ^ 7-!) V s r T -- ,n P P ^ X. L x S x
...^	 -. K — .^ • 1 — a	 Z,	 a	 — — — K — % 1. • V L 4'1 1r Z 1 .L K
— r	 K a t
	 i	 -	 a	 .. a	 a	 s	 a	 a	 a	 a	 t Z t x
L r	 w w K	 +	 K
^- R	 w	 <	 K
1	 .^ ^	 n	 x	 7^y	 r 4	 x	 R	 K

























r r ..^ V1 0 ^ r f r r r r r ..n A A A .^ A r r r r r .y r wo
N J J U U LL AK K K x K X K K K K K X K K K K K K
J,	 ))) X K K K K K X: K K X x K K K Ac K x )(
J K X K K K x K K K K x K X x K K K x
L r U K K x x x X X X .K K KK K K K Kw KJ U X X K X K K At x K x K K K K X K K K
K X ^( X x x K X K K K K K K K K K KK K K K K x x K X K X X K K •[ X K K
X K K X K K K K K K K K X K K K X K
rti0 07 To 4 V z ZNZ 'D?T N •O 7 Z7 Z •v 4 00 N
'V "^ '^^ 7 J ? l!1 ./'r	 O o ^	 L	 L O` tT 0	 7 .+
...^ A ..^ ... ..^ r A A A A r r ..^ r r A ..y .r A .+ r r A N 'V N N
A .-....^y? OS ? ^C'V"^1, U'+ OAT
V V V V V V V V V v V V V V V V V V V V V ^/ r/ V V e.I
r J r K .-^ A ^^ l ,a — — r e.. — — — 1 2 t 2 Z Z J:
: s x Y x r u-- : s]_>> n n» to








	 4) C n r- Z 4 S J J>> .+
.^	 _	 - - r - - _ - _ _ - _ r A v I. V
^ 7[ J U U J^ 1 ^ Y r> r r ^- > a a r r a x K K K K
^ 7 ?	 ^^	 a K K K K K
s s t	 -- —	 •[ x K ^( K K
!.	 K K x x K K
J J
	
x K K K K x
K ^[ x K x ^[
K X K K K X
K x K K K K
y Z; 7 a- U L	 7 L 'V L	 7 i ,V t	 4 L v t;;, 43 '10 N 4;) o
- - - .V N ro) 14 1 , 7 X. J• J , y o r` + r\ J, J. , wr Q J o > -
..- .-. - - - - - ^ .-. - - - _ r - - - A - - A - A - 'U 11
-- ^ -- `^ J + 1r l^ 1 ^^ J r t L J Z 'U 1 7 L 1. J 'U
T ^1 r+
 A .... 1 1 U U 'U 'U N L 1J N N v .'U U f t 2 i	 t
	
J, t t t t J J L i L t t t t t t t t s	 ,^ J
t a s x x a K ^	x x k K x	 x V; J Cn J7 J7 J7
L; J
!^ J M+ f7 . ,r` r J Mr` ..Jr p ON _,f1? M	 P 0




















 .............., ,........, r, ..........................
U x x U K ^[ K ^[ U x K U +^ K X u K K at ;,J A K U 2 K Y Z ^[ U KU K	 u K K K	 U K K U K X	 U K K K (1 K K 1 t /( ^ d 1K 4 K
l Q X	 a X K K	 t x K A	 K	 K X X K	 K K	 Z W	 : x	 K
r	 +' K	 X K w	 K K
	
K K
	 K X K	 X A
	 K	 i(	 7(
•	 1 1 A	 K	 K	 K	 it ll	 ll 4
	
ll K 1l
	 ^l	 K	 J^(	 J(	 Ll
`	 1 A	 I( A K	 ^t ^l	 K K IR 4 K	 K t	 K	 A	 Jl
K	 K K K	 ^( K
	 K K	 x IK K	 s( K	 IK	 K	 n(
K	 K K K	 X K
	 K K	 K ^[ K	 1[ K	 ^(	 K	 +(
^ ^ i) N0O 7 x ti^ O7 mNO7 7 ^N DO,^'^'
-- 1r v 'V .^ -n 7 7 1 !^ J
	 O z i+ t• M cc V a 7 G O O r... N •V N •/1
'V N UN -VNNN'VN NNNN'V NN'V V V `nMr +1 r+1 +^M M M '^1
a K J A K K K J X MICK ^^-J^  K K K Z K K Z A A J A A A K
K K	 ;,,) K K ^[ (J s K K Y K l^ K K	 K ^( '1 K K Q )( K 1 K K t K
A K Q A K K Q K K ^(	 .( K Q K R K ^[	 1_ K K 1 1(	 7( K 1[ Z	 7f
X A A K R K A K K K A A A A K K K A K X	 ll
a A A K A K A < K K A K K K K K K K K A	 K
A K X X A K K A K K A A A X K A K K A A	 Pl
X K K K K K X K A A K K X A A A A A K K	 1(
K K K K K K A R K K K A A K X K X K K A	 K
V u NA L N, V v V V V v NJ V V L V NJ V	 4 4 M r^1 M M +1 M `n `^
A a K K K R J 4 M w.	 n K K J K K K ,, K	 M	 K -,,,J K	 s	 j	 j	 K	 Y	 X	 K
K K
K





















K K X	 .( K	 L K	 K K
^a K K	 K K	 R	 K K
K a K .<	 K K R K K K	 K K K A K K	 X K	 K	 K X
K K K K K w K K K A	 A R K K K K	 K K	 K	 K K
AL	 K K K K X K X K K	 K K K A K K	 X K	 X	 K Aj K K K K K K K K K K	 X K K K R K	 K K	 X	 K K
J i` 1: Z^ J d, . -V L .: Q 1 'V L Z, J 4. 'V L	 7 1. 'L 4, r 7 L NV L Z)
.^ _ V V r `n M J J J -' P .n L Ur- r- r` 1 d, r tT P tV	 — •^ •, ,1a '^, MV ti%	 V 1 'V ti -V N 1V 'V 'V N, \. V ti N 1 ti N	 +1 w1 M +1 "n +1 •n
w	 R K A K ,^ a K < w	 ,,,)	 A	 K K K A K Z K A A L X K ,_/ K A J K l
a 4 K
..J	 a 4 4 ,,,^	 t K A K Q K A a Q A A L K A, J A—
K K A Q A K /( Q K K A K 2 K K K t K K K K K
K w K A K A A K X K K K K	 K K A K K
A R < A K K K K K K A R a	 K A A K K
^[ K K X K K X X A A K K K	 K K K K X
K 1[ X K K K A K K A K K K	 K A K K K
A X K K A K K K K X A X K	 K X K K K
















w• _ .^ ...1 ...I .^ ^I .^ .y
 .r w w w .^ .^ wr •K w .^ w ..^ w 'V 7 Q w 'J A .y
V / V V V V V V V V o V V V V ^^ V V V z V V V V V V V V V
K r K K K K K K K K K K /( K K K K X K X ^[ K h J7 N K N K K
K K n[ K K K K . : : 411111 : 414K K K K X K K K K K K R R K^> 7 R) K X
K K K K K K K K K K	 XK K K= m m R R K
K K K K K K K R K K K K X X K K K K K X 1( K x j Z >< 2 K K
A X KK X K Y R K X K X K K K K K R K X X K
	 R R K
K K K X K K X R X K K K K K X R R K X K K K
	 R RA
K K K K K K K n K K K K K K X X K X K K K R
	 K K KK K K x K K x K K K K K K K K X K K x K X K	 K K K
•	 O 7 'U D 7 4 Ti 'V O 'Z 7 V v ^0 O 7 M N 4 7 Z V v O O Z Q
^Z O POD D o p- ti M v z&PM 00 0— _'b'V'VMN1a Z 7
-1MMM •n	 M-n•+lrn-nMM'nrn 7 7? 7 7 7 7 7? a 7 4 7
w ..n
A X x K K /^ K K K K K K K K R n K n A K K c..J K n n uJ R VJ VJ
K Y K '^[ K Y K K K K Y Y ^[ K Y Y Y K K X K •Q K K K	 •[ Z D
K K ^[ K K R K Y K K K K K ^( K K ^ ,f R K Y' K AJ K K K T Y r D ^
K K K K X K K K K X K i K K K K A K K X K l x K K L x t 2 '^K K K K X K X K K A t K
	 At K K K K K K K K A
K A K A K X R K R K K K K A X x n K K X X K X R A
K K K K A X X K K K X K X K K R n K A X X K X K K
	 ^
K K K x K K K x K R K K Y K K K X K Y K R K K K K
	 ^J
Q0j	 P31	 P- J% "Y J, . P 'In
'n '+1 Z 7 7 p r O V	 t J P J, .>	 4
M +1 -n *e. 1-1 'n a1 •n .+1	 1+1 n M `-1 J 7
	 ?	 J J 7 J Z 7 J
!l	 .	 .. .^ .^	 .. ..	 r. ..	 r .. .r	 ..	 i v .r	 v _.	 N
K R K a a i K K K K K i K K K K Y K Y K K K VJ (^ 'J, K K K K	 vX K K K K K K i K i Y K K K K K K K K K K i ^ ^^ ^ a K ^[ Y
K K K K K K K K K K K K K K K K K K ^[ K X K Z - Z K K K K
K a K K K K K K K K K K Y Y K a K K K K K K 2 t 2 x K K K '4
K x K K K R K K K x K K Y K K K ^( ^[ K n K K
	
K K K R	 L1.
K K K X K K K K K < K Y Y K K K K K K K n K	 X R K A
K K K K n K K K K K K K K K i K K K i K K X
	
x K K K
K K K R K Y K K K K Y K K K K K K R K K Y K
	
K K K K
I7 Z v u a L Al u o a s V L a L 'V a. Z' 7 1 No
 L 7 JL V LV1 ,+1 7 7 r J• f & Gfl- r- r- L L J' J J' L .y	 ^+ ^- "V 'V M M M J ZM '+1 e. M 1r1 M 141 .41, .n y1 .+1	 a1 WN +1 V1 w1 7 7 Z ? Z Z Z 7 7 7 7 .7
L
K K n1 K t K ^ K K .1 K A K K K K x A K K K K K R K K N
- K.	 K X K K A a t K i K K K i K x Y 4 J,. K K K A K JL K A	 K Z'
i ^( K K K K A K K K K ^[ K K K K K K x X ^. K x A K K .L K j,
K K K K K X K K K K K K K K K K X K K R K K A K K K j K 2
K K K K Y K K K K i i K X K K i K K K K K K K K K K K
K K K K /( K K K K K K K K K K K K K K K X K /^ K K K K
K K K 4 K K K K ^[ K K K A K K K K K K K K K X K K K K
K X K K K K x K X X R K X K Y K K K K K K K K X
NJ IV




..n .^ .r ... ^• — r r r r .^ ^+ r r r — r r r r — .. r r .r r .r .r .^ ...
^ .^ r v v r v v ...♦ r r v v ..♦ v v v v v v r r v v .. v r v v r
A A 4 4 i K R X A 4 R K X K K K K K R K K R 1( X K X R R R K
4 A 4 ^[ ^+ K R R K K K K R K K K^ K K K R R R K K K R K R K
K 4 K 4	 K K R K 4 K X K K X R X K R R K R K K ^[ X R R K R
a w w K	 K X K R K ^[ K 4 X K R X R X x R K R K R X K ^[ R Rr
A a A A	 K ^a K 4 K X K X K R K K R A X K K X K i[ A K K R X
K a A K	 ^[ K X K K X K R K R X R K K X T[ R K K K Jl K R 4 K
4 ^( K	 ^[ 4 R K K K K 4 X X K K K A K K K ^[ K R K K R 7[ ^(
A R ^[ a	 K 4 t K R 4 K *{ A K K /[ K K rl R R K is 4 R K f K A
^. V 7 7 x rV o> > v 'V v O !7 L 'V to O 4 GUN O Z) u m N o>> D
rr o 0 o^+r o70, 0	 --'VNN101" * v* ilp 4 0 0
7 ? 7 7 7? 1 7 7 4 7 f	 nLn r% nnr• a, v, rjn p 	 n
...—..._..,..,r..........._ ...,,..........----.....r..,.--
a w w 4 a i t r A t a a a A a a 4 n a a a a a 4 n A a a K
K a < ^[	 +( ^	 ^(	 +[ a K a r .t	 w	 t.	 ^[	 a ^[ ^[	 R	 , r[	 M	 ^[	 r	 •	 R KC
.[ t K n 	 a	 a	 .[ K .( K K r w	 w K K w K
4 ^{ a 4 A	 4 A 4 A K r ( K 4 4 a R 4 K 4 A K a K A A t A 4
K 4 4	 ^[	 a w ^( X. ^( A K w K K K rf ,[ w 4 A 4 4 ^[ A A 4 K
A A A w A	 4 A 4 A A A a a r A 4^ K A .( 4 A A A A A 4 A
A A a ^[ A	 At 4 A A a 4 A a a A 4 a A A A A A R A 4 4 X
i. K M a ^(	 w	 a a 4 4 A	 ^[ 4 4 a a a a A a a 4 4 A A w 4 4 A
— r 7 -n w)	 ..J"%	 n^—r Jr,^r r J G L "^ ,^ L t J J J	 ^ -- — V V '+, •, +, 4 7 J r r u G
w r a 4 a 4 j a r w 4 r t( A	 ^ a a	 4	 a w r	 w w	 a r w t w w
A t w ^(	 r	 w	 R a w a a ♦[ a	 a • w	 4 r	 r w	 4 4 r	 a 4 w r ^{
a r 4 4	 w	 w	 .[ a a a s a w	 ^( r 4 w n 	 4 4 4 a ^a w r	 a 4 4 •
r +^ 4 1/	 w r	 4 r K a 4 K a n 4 r a 4 I ^ r 4 w 4 r r r R ^
4 w 4 t w r	 4 `[ a 4 n 4 4	 r r	 w	 K n 	 K Y	 4	 4 ^l	 4	 r	 a	 r	 ^[ t
K a r 4	 r w	 r 4 w K w 4 4 4 a r Q w w w r n A 4 a w 4 w 4
^ ^ w a 4	 4 a	 • ^[ a ^l	 4 4 4 r w r a a a a 4 w w 4 A ^t w K n
A a 4 w	 4	 .[	 r 4 A A 4 4 a r a s 4 A a w a A 4 K n a +a ^( K
r:. L A, u .:.	 7	 a • v a. Z a. ' V	 a	 V u o a a. V V	 a a, +v v
aJ J- J` J . G G L L d J
v --
J	 — v 'b	 ^^1 "^ 7	 rN X. 41 L L
7 7 7 7 7 7 7 7 a a 7 7 7 f	 PJ,J", r r J• J+ r J% r• -fl P 




A	 •+ =	 4	 /l







A 4 A 4 w 4 4 a ^ A A A n a w r ^ a A
a s ^ w w w K w A ^[ • w A • w a K it
t 4 4
^
4	 4 a w .[ t o 4 K
	
w a w r w w a a w A 4 w r, a w w
'( t w	 a t a w a A A A I. 4 ^ K a s w w A R A r w \ I 4 K R
K 4 w K	 a A a a K ^[	 t ♦ -j M A X 4 a w A A R w K 4 K A K 4 K
4 4 4 r'	 r	 4 A w a 4 4 w 4 r. ,n w a s w a r r A w w R A a w a
w K w w	 K A A K w 4 a t A a 4 A w ^[ w R w K A K M A a 4 A R
3 r r C C C L i i 7>> O 	 'v 1a '^	 ] 7 7 r r C C' C






























• J 0 0 7 0 0 0 0 0 0 0 0 0 0 0 0 0 0>> O O O O
7 J •'•.1 V y 'V^+ r1N^+•7 V^V'VrT rT ^rrryal
•^ y '+1 a k a O M O^ ref i► a a O '^f D M ;. M M M M r. 1rV) .J r r r .n r .^ .^ ..• .^ r ... r ...• rV r . ►
 ..n rV 'V 'V 'V •+ •'•
J • ti 7 rZ 1f'VO HOMO ^ ? ^• aJf'VT a ••1O •^? ^+J^ -• 11 N M 0 717 O •^ A^ P P O r -+ V M ^ .1 ./^ ^
y; r r r r— r r .^ r ..w
J
• J O> > O O	 J O 7>>> O O z O r^	 >>> OJ J 'V 7 .7 ' V V •'• V M V 7 r1! V V •^ r J — 'V r r r •rf r
— •u as oC+oMaao^ ao cMMOMar+M MCM
J • C M O^ !— V p 'V P 4 M O 	 O r t r ti P A "-ft O
u
• J O	 7 O O O >> 7 7 J •7 7>> > J 7 7 O' 7 0
^ +. O O O L +► M i L M V C O L '•1 ^. r'•1 L ^1 M M '^1 A m
J • J1 V 7 L 'n	 Jn 1 P O	 J	 -• O f V P
• J > > > > > J
	
> > > r.^o > > O O > > > ' J 40 J O
J V i J V V V' V '•1 V V' V V V ^• ^' J	 J ^ -- •^ wl
— i V v t L y L V L L L v l+ +. "^ M L ^1 1. '+1 M rn M L
n J — — — — — — — — — — — — r
.^	 • 3	 L l V 7 O M' 	 — Z f v J C M ? — L
J -— 1r	 ^^' 7 r s c	 x L 7	 =— 1r M M? r r
A.'	 _ — — — — — — — — —
J
• J 7 z	 >>>> 7 O	 >> Zr = a O= 7 O O	 O
J y— 7 V V v'n v 1'V V V- V--J ^-^	 •• O.•
— a. ♦ 	 t' C V C C O C. V 0 4 M O '^ `^1 L rr n M	 L' M
• J	 7— t 1• V J Z '^ O A	 — L !^ V J O M
J J ? J	 '+ V 1r +1 , .!^ f
r
+ ^, L t	 C G C C G^ C G C	 L '^ x M +ti ^1 M Li. J — — — — — — — — — r — — — — V -^ - — ^ V V r ..
J	 • L J V "^ 	 J -- L	 1 J O "% 0	 7	 n v P O
.1	 J r 1r M M	 f+ 1• G	 Z cT	 c- v '14 +^	 o f
°•	 J
J	 J ? L Z v 1^ 'V 1 ti J ti 'V No	 — r— ... I
J	 — W '+1 rn C	 C C C C	 O C	 C	 .0% -01 L
J













a o o 0 0 0 0 0 0 o o=^ o	 o.o >> o o o
.+ H M O r J M -!2 -f%	 V M n M ^ 7 N 'n V i i ^ V 7 ^ .. ^
n L O -n .n d1 'ry L M a V V O D a = '^ n Z V O O Z T n T
D >t ti .T On--) F- 7 - V J1 V 7 On? t- 7 - Ln N  Ono^ 7
O^ TL J Zo --Vn•'n 761!10 ^V VOl 0 C VVM 7 Jl dn Or
••	 •••• •• •'• 'V 'V 'V N 1! 'V V V N V 'V '\) V M M +1 M -A n 'n 'n n n
7>>=^>> 7 7:D 7 J 0 0 >> 0 Z' J 0>> 0 0 '7
+ n'n^ n r -0 N D y.^ non y 0'V0 a -ti V 0 .n on
L' C L L L L V V D V Z L n iJ 4D r1 O i' 1 n' -0 Z L n u L L n
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
7- L 11 'U J O n 7 1- 7— T _n V J O n 0' ?- Z Jl V J G n
O '^ L Y •T J^ 'V n -n 7 s r r '^ ^ L? o .^ - 'v 'V '++ 7? r C
^ ^+ '^ - - 'V 'V 'V 'V V 'V 'V V 'V "V 'V V ^V 'V +l "'1 + 1 r-1 1+1 +1 + 1 +1 +l Al
^: => 7 7 7 7 7 7 z = O 7 J 17 7- )^ 7 O >>V : n 7^ 7 D
-n -0)	 ] nn r+1 '.J v Z' v n Vn y1 A 7	 ;^ n V J V U- r'.
O L	 C L n L L t V 'n L: L L L v i' L L L v n L y n .0
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
O n r 7- V f V l O '^ 3 ^ 7- L .0 V) u n'- 7- G n V
O '^ i i T G 7-" V 'v n 7	 lj U n J J J 1 L
^• ••• - •^ •.• 11 y N v y V ry b U ' V 'V li V 'V 'U 	 'n r+1 .+l 'n r^ +l n +l
J z J:1 .: -	 Z' z J 7 J V J J	 J J O >> J
+1 - ' r  ^ - l - I^ N > ^t ^ ^ - V wl ^. ^ kz '^1 V V V v J V 1 -
L -'1 L LX' L. '^1 l V L L L l `mil L +. L M I 1 f^ L v ^. 1 L 'n i Ml
- - - - - - - - - - - .. - -
r V T L 41 Z '- 7- L r V J C^ 'C	 7- L r% J u -n =^ 2-C-	 L y Z= - ^: % "n 7 7 r C -- n S 7 J = -- -\ -n 1 7 f C
- - - - - 'V 'V 'v V L 't 1r V 'U U 11 v 'l. 'U v ' 0.% .n +l n n n n 41 -n
.. ,rl .rl vt -	 C J "1 'V Z.) J 7 n V J	 :^ n - V 'U ^ -n ; ti - ?*-
C t. t	 L t' `n L V ^^ I-ri -n L G 'n L L	 t L- L L L L 'n L
... - - - - - - - - - - - - - - - - - - -- - - - - - - - - -
^- L 1, v J c n ^^ 7 -- L 1• V J o 'mil ^ ^ ^ -- s; r V^ u^ 0
G	 L J J=- V V '^ 7 7 J1 O G i J J J	 +l 7 r O
^- - ^-	 - - v 'v V v rV U V ` v V v V 1r . v '-P% W. -. rn "'1 Nr -.. +1 M
L L L	 L L Lv 1 1 L L ^ '^ L L a L L Z	 t L v t	 L' ^l
^n	 7- S. t v J O 'In .^ - ] - L r "U J G le, Z	 7	 L P v?
G	 1 J !	 -- - 1. -0) 7 7 r O G A S .L J	 - %. ^' ^ 7 Jl r% 'U .% ` L ti -'6	 v .1r ^% r1 .n r, !l M, 1. - % .Il
-n r. - r. - n -n	 A n -n n ti ti N= 7 .0 t 7 n L 1 V '. - I-
G t n= r t t L S L L L ^^ L i C C C - - L L L rU G 'V r"n "o ) L
- - - - - - - - - - - - - - - - - - - - - - - - - 
r - - -
U> C -^ -- 7- L 1` ti J C "''> >- 7- L J' 1 J L' _^ J- L
L C- L J 1 Z! - - L -n '01 7 J1 Z C A L L 7	 7 '+ : v 'n ^l 7 r J^
- - - - - - 

















1 3 u 21 3
2 1 2 5 3 0 3 153 r
3 2 i u 2 e 2 155 0
u 1 i 3 3 u 3
5 2 3 3 2 5 2
e 14 u 150 a 1 1314 3
7 S u ISO Y 152 2 15 14 i
+, 1^ 14 150 2
111 a 22 3
1. 7 i I  5 20 5 2 q e a
1 1 r i 15 Y to Y 17 Y 16 Y 302 u
12 q c 13 3 1+ 3 17 3 18 3 306 Y
1 to i 12 2 114 i to 2 to 2 20 i He 0
11 14 7 3 11 12 5 13 S 14 5 is 5 1e 5 11 5 I8 5
15 e 3 1111 Y 12 u 13 14 114 0 19 Y 20 u
1r q 3 11 3 12 3 15 3 110 3 19 3 20 3
17 1
 3 11 2 13 i 15 i 1) 2 14 i
Ie 1c a 214 3
1 0 13 a 35 3 36 3 37 3 38 3
2v IY a 3q 3
21 IS a 57 3 56 3 59 3 e0 3
2c le a e5 3 00 3 e7 3 e8 3
23 17 a 7u i 75 3 7e 3 77 3
it to a 7e 3 74 3 1b0 3 el 3
le y 1q a d2 3 83 3 6 1 3
ie 20 a e5 3 87 3
27
cr c 1 2 22 2
24 22 0 23 3
3u e3 0 Ise 9 210 d 213 9 i I d 9 2	 a 9 22e 0 232 q 23o v 2461
31 23 2 2P 2 38 2 3 q 2 e0 2 66 2 77 2 81 2 e0 2 e7
is 214 Y 25 3 2^ 3 27 3 i6 3
33 2u 2 ids r
3- c5 Y 210 a 213 7 21e 7 i20 7 226 7 232 7 23o 7 i00 7 2Ye
3 c5 2 35 i 57 i 05 a 7u 2 7b i 82 2 F!5 2
3e to c 3u q E 311 9 317 9 3i1 v 325 S 324 9 335 q 334 9 3145
37 c0 2 3e 2 5P. i 66 2 75 2 79 2 e3 i
if e7 Y l q e 2 34 14 3 u01 3 003 3 MOS 3 u07 u Y0 q 5 012 5 ule
i t e7 3T i 5(4 e e1 a 7e c 80 i
+C c^ Y 2r 5 31 3
14 1 cr a c-^3 l ime e
Je i Y 30 J .0 2 51 0 t3 Y 55 0 i13 a 213 14 iIu 2 215
+3 3 30 3 +I 2 147 3 YV 3 55 3 21e i 41e r i19 2 Ziu
++ 30 i +t c 05 2 uv i 53 i el 2 e+ i 2c3 2 2i14
+`: ?	 1 u 3i 3 30 3
+e 3a 5 31 2
r, :i 0 2.e + 294 5
+e ^c c 33 i e2 m c ice + cc q c c[v Y 3d^ 0 32e c Yoe u
rV 3- r C0f4 2 29Y Y 29G Y
^L 33 } 314 2
51 :S 14 4e + 2113 5 21e 5 iiY eeo 5 i3i 5 23e 5 i w 0 5 207
5i 3o 0 See 0 YnP Y YQ 7 090 7 502 7 507 ) 512 Y 51d 7 Set







 CtI.L 3 IN CELL PI A CELL FIN CELL Pin CELL P IN CtLL PIN CELL P IN CELL FIN LELL PIN CELL F1
figure 22 (d): (Continued)
\,
134
511 31' Y Ire a 2946 3 299 3
55 39 u Yu 3 "t 3 Ye 3 50 3 Si 3 Su 3 S• 3
Se 4611 Y Zee a 3463 5
57 46V 3 613 Y a Y 117 Y 469 Y
5e 111 3 Q3 3 445 3 Sl 3 53 3
54 112 3 u3 2 447 2 51 2 55 t
6o 63 5 1146 2
nl 4603 u 207 J 303 46
oe 4613 5 466 2
n3 ur 107 2 2946 2 303 3
e•J 1.7 11!1 2
e5 to u ce'9 6 2 2 303 2
to 4614 5 50 2
c7 ^-2 44 ir9 a 29 13 5 3uu 2 3611 2
rr 51 5 52 2
n9 544 46 ir9 u 2913 46 307 3
70 53 5 544 i
71 be 44 289 2 307 1
72 ^5 5 503 2
73 57 2511 2 257 3 259 3 iel 3 263 3 265 3 It  3 it9 S 272	 i
744 jr u 2014 2 t13 3 218 3 iii 3 228 3 132 3 236 3 imu 3 2116	 2
75 S4 46 3ee 3 44813 2 1141 5 1196 5 502 5 501 S S12 2 518 S 525	 i
703 t0 u c2 3 o44 3 291 a i95 3
77 ee 46 ISr a ISO Y let 46 lee 46 170 J 17Q Y 178 Y 1 !2 46 I e 7	 i
7r t	 1 3 a2 2
714 0344 44 156 u 159 5 lea 5 1t1 5 171 5 175 5 119 5 123 5 Ie9	 i
ra
n1 e5 46 211 8 215 5 2246 5 i25 5 2s 14 5 233 5 237 5 i u 1 5 251	 1
r2 to J 3n p 1 4487 r 1191 3 11;6 3 502 3 507 3 5146 a 5le 3 524
83 e7 46 4435 3 4437 3 1139 3 4441 3 JYJ 3 4u7 3 4450 3 4153 3 4657	 1
r11 er u 73 3 2 14 1 6 295 2 371 7 37S 7 375 7 377 7 379 7 3e2	 e
05 73 44 30Q a 313 7 317 7 321 7 325 7 319 7 335 7 339 7 34611	 c
re e 5 1 	 r 3 313 1 371 1 371 Y 371 t 399 2 4635 i 435 Y 495	 i
b7 e9 04 I 3 317 1 373 i 373 u 373 a 4101 2 1337 2 4637 Y 501	 i
8e e9 3 11-6 3 321 2 375 2 375 Y 375 a 1103 2 4639 2 0439 44 SC. t	 i
1. 9 64 2 170 3 325 2 377 1 377 a 377 t 4605 2 J.41 2 46441 4 SIl	 c
441, 7 I 5 174 3 32 14 2 379 2 379 Y 379 a 1109 2 4409 Y 44444 2 11 445	 c
141 70 Y 1704 3 333 2 3031 2 3e1 44 391 a 441i 2 44li Y uu7 2 14 e	 c
97 70 3 let 3 33 4 2 1e 44 2 3ru Y 3846 a ill 2 46 15 u 450 2 4151	 i
44 3 7tr c Ire 3 3 11 3 c 3036 c 3e6 u 3037 a 1119 2 4419 Y 4 53 2 .4546	 c
444 71 5 192 3 3e9 a 39C Y 310 G 4622 2 1122 4 465 03 2 a ^ 7 4 Sot	 c
v13 71 4 197 3 3 9 2 2 392 46 _'92 a 4625 i 442S u 1159 2 4659 J 551	 i
9r 71 3 201 3 3 9 11 2 3911 u 3GU t J2e c 02e 11 reI c 4t1 44 557	 c
07 11 2 2 1 5 3 $90 c 396 44 396 a 1131 i u32 u Me  2 Yea u Sti	 i
^.8 e4 t 7i 2
99 7 (. t 72 3
1 U 71 r 72 u 73 2
101 1 5
lit 74 46 44x7 ..92 5 4497 5 SC3 508 5 51 44 5io 7 5103 7 533	 c
Su3 75 + ill a 214 3 219 3 ii5 3 12 9 3 233 3 231 3 i.i 3 250	 c
1046 7e u 1503 i 3%1 5 373 5 375 5 377 5 374 5 3r1 5 3em 5 W	 i
Iv y 77 46 2 140 44 2 4 n 5
I c 0 7r 46 4r8 2 516 1 51u 3 teI 3 532 3 537 3 1441 3 540 3 Stu	 i
107 79 46 c I I 44
lur M0 + 371 3 373 3 375 3 377 3 374 3 3e1 3 3811 3 are 3 3446	 i
10 9 rl 190 1 I 14 e 4 3013 44 313 5 317 5 311 5 3i5 5 329 5 335	 i
11^j rc 46 c11 1
tli e3 4 3e9 2 4487 c 4642 3 .47 3	 5.j3 3 Soe Sl46 It Si0 S see	 i




Ili e5 u 31  2 11O 3 31e 3 321 3	 ate 3	 330 3	 At 3 3 3	 367
11- v7 u eve 1 e v e e
115 1. 7 3 87 1 el
1 10 rr ..
117 r8 3 45 1 3131 3
1 1r re 2 eV u 45 3
114 ev 3 9e 2 353 3
120 e 2 9U w v e 3
111 4U 3 v7 2 355 3
121 qf. i 9: o v7 3
123 91 3 4 P 2 357 3
126 vl i 9i yr 3
le5 3 vv 2 35 ,4 3
120 [ v3 u vV 3
127 93 3 IUO 2 301 3
1204 43 i vu u lau 3
lea vu 3 1v1 2 303 3
13a 4. i IJ1 3 1u1 i
1 31
13i 45 u 313 a 313 F
133 317 a 311 r
ISO v7 O ±e1 a 321 e
135 325 a 3e5 r
130 Gv u 319 6 Scv f
137 lUu u 335 a 335 r
13b 11 . 1 6 33 9 0 33 W c
139 It-e 3 3-3 a 3^^ r
tur. I•,.1 3
141 lea 5 tv3 7 1e ., a 43e
1YC 1 " 3 3 11 , 3 a Ien 3 ue, 3
iu3 Ica i 103 O luo 3 117 S
1 66 I,3 I " Q 2
luS I	 S 1_IS 7 11r 2 4U36 3
l-r l 3 luS a 11r 3 uee
lu/ 1^^ c 1uS 1;0 3 1213 3
I-r tu5 r 1^e c
1+ 9 1U7 5 1 4) 7 7 13u 2 vu0 3
150 10 3 Iu7 c 13u 3 6ev O
151 lul a 107 .4 110 3 131 3
152 It , 7 r loe 2
153 tcv S lu g 7 Iii C YY3 3
1 136 1 o4 3 109 a 13^ 3 u70 u
155 104 i luv it 112 3 133 3
15P. 104 r 110 2
1 111 5 1:1 7 13u 2 uue S
15r li! 3 1!! C 13- 3 ull u
15 9 Ilt c 111 lt- 3 135 S
Iet 111 a lIc i
1,1 113 113 7 lie a uuv 3
Ire I1: t !13 13r 3 a7 1 u
1r3 113 c 113 - i!0 3 137 3
ir+ 113 11-
1 I1 5 I15 1 ISr c Utc 3
Ioe 1lS 3 115 a l.i- 3 u73 u
107 IlS c 115 O It s 3 1!ti 3
l.,r I iS - 1 to i
1 7 1j , r ^^^
17. 117 ! 117 a luu S A7S u




172 1 1 Q 11@ e
173 11 40 5 1 11 7 1m1 2	 a b a	 3
1746 119 3 119 a lu g 3	 4671	 46
1i5 1140 2 Il40 u 112 3	 1463	 3
176 11V 110 1
177 111 5 121 7 luu 2	 4600-	 3
178 121 3 121 O 1 3	 Y77
	
46
I I Y III 2 111 u 1246 3	 1465	 3
r 160 111 a 112 1
Ihl 123 5 123 7 1JO 2	 4.61	 3
102 123 ' 123 a 1461 3	 Y78	 46
Iv3 123 2 113 u 11.5 J	 14.7	 3
r 1e" I c 3 a 1246 2
125 3 146 0. 2 46113 3
Iee ► 2S 2 1468 3 46740 u
1
 127 u ISO J JV 1 6
ter Icb 46 lel 1
f^9 12 4 Y 163 46 a97 e
t
1 1. 46 lcr• 46 129 2
1401 131 u Ib7 4. 13463 c
1 1., 13% 131 2
1 r 3 133 4. 171 u 5or e
144 132 Y 133 2
1 1. 5 lib Y 175 46 520 6
I Q 0 13 4. u 13b 2
Iv7 137 4. 179 u 5213 e
I9 A. I 3 u 137 1
1 ,440 1:40 4. lea J S3S tl
200 131 139 2
21,1 I'l J t o e u 537 C
le 1 2
2G3 1w3 r IV3 u 5 46 2 b
2046 l u c Y 1463 2
2013 1^5 u 145 u 5ue C
lGe 1464. u lJS 1
207 I a 7 46 202 Y b5J E
cub lub u 1J7 2
J09 I"4 3 206 Y SSV r	 a
e I U 1 4C u 1Jc
211 150 3 ISO 5 1 130 7	 1546	 V	 156	 3	 156	 5	 ISe	 1	 151	 'i	 20 9	3	 2146
21c 15( IQ 151 2
213 151 3 1S3 2 1 ,35 2
7146 152 u !133 3
cl^ 1546 u IS5 3
cle I  r 257 1 46 14 2 u
217 15r 2 c5A u wee u
21C 15e IC I b 7 1
^l v 1`7 3 1 2 le y 2	 IeG	 a	 173	 c	 171	 2	 1b1	 a	 175	 2	 1 	 2	 1 
2c0 15c 1540 2 154 3
c21 15 4 r lr^ ^
c1c I r C Ir-1 3
e 123 le y J c13 V. a -A u 7 Y
ccJ lac 2 ce0 c
225 1c2 5 Ie3 2 1 3
c25 Ira a IC+ 2
c27 1 3 le y 3



















 107 a The 2
iii lee 3 1c9 3
233 173 J 2e3 a 50a u
e3 44 17Q 2 2eY Y 470 2
235 17o 5 171 2 171 3
c3r 171 a Ili i
i37 172 3 173 3
[3e 177 Y ce5 2 520 e
ci o t 7 u 2 Zee 44 Y/i i
C	 u 1 7- 5 1 75 2 175 3
C
 175 C 17e 2
244e 1711 3 177 3
2.^ 1C1 J c07 2 52 11 C
c •••. 1 7^ c ceC 14 17C e
IJS 1711 5 119 i 17v 3
24e 17 c 16
 e
iY7 1 3 lot 3
iur 1115 4 204 2 532 ti
2JQ tri a i70 Y 47S 2
c5 1112 5 111 3 2 163 3
251 Ica c 1^Y 2
is, 1 3 le y 3
c53 1^1 u 271 2 537 e
25u 11111 2 c73 4474
e55 1r7 3 181 u 1 4 2 197 Y 1101 J 205 J











143 S 14e 5 lice 5 e0e 5 4635 5 4437 5 43 4 5 Jui
cS4 14^ l 141 3
Cet SGe 4 e7{. 2 5442 e
C i Inc c C7e J ..le i
c^c 14i 5 1 C 3 2 1 0 3 3
cr3 193 a 1 1^J 2
2e4 1 4. 3 1 q 3
ie5 l a e 3 1 Q e i 2au i 20 0A 2 ica 2
ice C"11 Y 277 a 5,104 e
iC7 1 %-7 i e7C J 4477 2
Zee 147 5 1 Q1 2 1411 3
cev 1411 a lav c
2TC I ry 3 eJu 3
C 71 iku e74 2 5544 e
e7i C -•: c cA0 u 4711 2
e73 .	 .1 5 ice 2 2u2 3
e' Y C 4, c a 203 2
e75 Cu3 3 eOm 3
i7e C'.	 r J i A 1 2 554 O
ell cl5 i ire + ..74 2
27 c-ie 2 21 3
i7G c . o n cul 2
2110 e^! 3 cue 3
C a l i17 Y
C c13 n 213 e 31e 350 i











21u 7 21u 9 ill 3 211 5 211 1 211 v i54 3 155











e22 i ec7 i [_'1 a 235 i 234 2 i4.. 2 2°! 2
cmr c15 3 c15 J 313 Y 31Y [ YCO Y













Y	 152 t	 152 Y
« 5	 tiv	 a	 11 1 1	 )	317 Y	 3ltl 2	 Y02 Y
^(





Mii' cV9	 [[Y	 a	
1,2	 M	




30U	 tc14	 lu	 c2t	 2
3141
	 115









1 Sum	 ccr	 r	 [t^	 a	 i2e
3 ^'S	 ace	 lu	 c30	 j Y	 35e 2	 ! c e Y31,e	 iiv	 r	 230	 3
+ 0' 7	 c30	 c31
30r	 t35	 14
3 v	 c.c	 a	 c31
	 tl	 332L1;'	 c!c






	 IU	 j3Y	 ^ Y	 }1v Y	 330 2	 14 11	 Y
31c	 e33
	 a	 1314	 3313
	 t3	 i35	 331-	 134	 Y
r
1





'iC	 car	 10	 c3e	 2 !jY Y	 S30 j	 yly	 yilr	 [37	 a	 tic	 3
31 4
	23t	 Y	 c3v	 !
lt^ 1 	tYY	 14
a	 2 140	 A	 Sad
J1c



















t In	 c Y 1	 t	 d 41	 3
5	 y tle
	 tl	 51]	 i
Sib	 14. 3
	
J	 j U A	 3
317	 253
	 Y
31	 e./	 t	 c'Ae	 C	 SJVi 2v	 i-S	 i	 tJe	 Y	 CJv
Y	 50Y j	 !t5 Y
33o	 c.e
	 !	 iJe	 }
c	 1514 Y	 !Y3 Y	 3Y0 c	 y t1	 YF 331
	 c147	 !	 3467	 5
331cwt	 3
	 c a e
	 7
•`' 333
	 car	 It	 252
	 233.,	 cSG	 3	 i50	 3
335	 c51
	 i51
	 S!Se	 c`1	 t	 c51
	 i
# 3^7	 c5c	 c53
	 3
...	 c.5	 !	 i55	 3
c5e	 j 3	 itl35	 ire !	 the teo	 1	 tto	 a	 2P7	 3
i et
J	 ese	 S	 1eJ
c	 c ce14 c	 teo
tit
c	 iet












	 1r5	 cee	 3
3^t
	 crl	 ieN	 3!147	 crc	 J	 ilJ
	
3
3""	 cic	 !	 c72	 3	 e7 y









^' f 1 3.9 c 71 Y 213 3
1 35, i7 46 Y c7e 3
351 .713 3 276 1 278 1 260 1 i e 2 i
S51 277 w 2713 3
t 353 c74 ieo 3
1 35- et, e82 3
li 355 tea 6 1t+41 2
35e 40.0. 3 ce5 1
357 lee 10 193 i
3 	 r crr 3 1136 5 1m 7 2bb 9 ie9 3 269 c 2139 7 269 S i9U 3	 291
359 a 10 191 3
'
30u 11+9 10 193 46
301 cC1 3 i91 5 e91 7 i91 9 i C, 2 3 292 5 309 3 30 q 5 3u4 7	 310
!e[ c - I 10 c 4 3 5
3133 192 e
3r, 143 r 2 9 e 2 301 1 306 1 !C8 2
!135 c f446 C 247 1
See 445 a 1397 S
0 3137 c c e a 297
30r c47 S 2913 3
SO4 i99 a Sol 1
37u 3uu S 301 3
371 3u1 w 3ui 3
31e 3  a Sus 1
373 3046 3 1J5 3
37u 3u5 w 30e 31
575 3	 7 46 30 r 3
370 310 ! 310 9 311 3 3415 3 46	 7 3 4607 5 Y!0 3 4660 5 46130 7	 YMt
!77 310 10 311 1
370 311 46 31i 3
314 31i u 310 1 Se 2 3146 [ !id 1 332 i 336 1 3Y2 i 34 9 2
!r.) 313 10 1l5 1
3r1 3146 46 315 3
3be 3 I 4 3113 3
3133 317 10 319 i
3x46 31 1- w 314 3
arc 31 9 Y 320 3
Sr0 341 10 313 2
3137 3ie w 313 3
Set, 3. 3 3146 3
3 A Sc5 10 317 i
3 0 0 51e 327 3
341 317 46 3ie 3
54i 3e ,6 10 331 i
3^3 3^ Y 331 3
X31 6 33i 3
^`. 33 . 3 33w 3 339 3 3463 3
3 355 S 33 ,4 S 3463 5
_ !r7 3.^ IC SS] i
^.r ^!e Y 351 3
IS Y 33r S
i3,-
.01 3 . k , + 3461 3
m v i Sul Y 34e 3
4601 3Y46 3 34646 350 3 35c 3 1S 4 3 35e 3 3513 S 30J 1 Sec 3	 let
46C46 3.S 3 3.5 5Su 5 351 5 _'S+ 5 350 5 35e 5 3bv 5 !ri S	 See'
4605 3465 1t . :46e c
woe 3467 S 3 46 7 3













Yoe 3 44 r Y 3Y9 3
Y09 350 s 351 1
010 3Sc a 3s3 2
4 11 3S4, r 35 15 2
44 11 35e a 357 2
0 13 356 r 359 2
44144 3eu a 361 2
4415 362 a 363 2
016 3e5 3 36S 3
4417 See 3 366 S 361. 15 44x6 a Y41 9 44v6 9 1502 9 1307 9	 512 a	 519
-to 3rr a Sal 2
r 1 9 37n Y
-2 3e t. a 370 2
- eI ie44 3 370 3
4, te 37c 3 ,44 1 2 4401 Y Y91 6 Y4l ! Yv 2 c
44e3 311 a 372
4,2Y 37Y 3 Y96 2 YVe Y Y96 0 4,66 a 4,97 c
44e 5 373 r 37Y 2
ude 37e 3 502 2 S02 a 502 a 'e2 a 503 2
r17 37S a 376 1
Y1r 3le 3 $07 2 Sul Y 507 6 501 r SOe
4,244 377 r 370 2
443, arc 3 51tl 2 51r Y 51d a 516 a 520 4,
Y 31 37 4 to 3r0 2
Y 3e 303 3 S23 1 5244 Y be 15 6 Sib a 527 Y
Y33 Sri 3 3e2 7 3 r a 7 3r7 7 340 7 392 7 39m 1 j 7	 Yr0 a	 Yea
Y3Y arc a 3e3 2
4435 3t• 5 3 S31 2 1531 531 a t 31 a 532 Y
Y3e 3rw a leS i
r17 3rei 3 Sir 2 5156 4, 153e a X36 a 537 Y
Y3e Sr) 3 387 5 34V S 3441 5 34 Y 5 396 5 me 44 Yd2 3
x344 Sr7 r are 1
.M U 341 3 5a0 2 Sao Y Sao a 5Y0 r Su2 Y
YYl J%U 3 3vo 3 3a1 3 394, 3 346 3 Yeo 2 46 1 2
YY1 34411 a 3 v 1 1
Y4,1 343 3 134,7 2 15Y7 Y S617 6 54,7 r 54,a a
YYr 391 r 3 44 3 2
44,S 3 4 5 3 552 2 551 Y IS 5e a 552 a 550 Y
Yv6 }Qw a 34S 2
YY7 3 44 7 3 SSP 1 550 Y SSd a Ste r $59 Y
Orr 5446 r 3v7 1
rY % 3VM Y " 00 2 aU1 1 a0Y 2 OC6
..S 3.44 Y 000 3
Y^1
.01 Y Y02 3
4,c 0U3 Y YOY 3
r93 4,u5 r roe 5
Y5Y Yy7 r a U P 1
r5t c Y cl c Y1Y c r17 a 44!0 2	 Y3Y 2
.be ruv a YIJ 1
4,S; 0I 3 Y1 3
Y5r 44 12 a Y13 1
r5^ r li 3 441Y 5
^nl 4,16 ! Yf0 S +1 4 t 4,22 5 YcS t 441e t r 51 S
Mel Ylr a Y17 2
Y61 4417 3 Y1 0 3
Yrl YI'. a 01U 2
rrY 46C 3 Y 11 5
r65 r1Y r












rIU rce S Y17 3
r3e, Y








r;^ 613c 3 r3c 3
rTr r3c a Y33 Z
r7t Y33 3 43 r 3
.)• us'!- r u se 2



















Yrr YYy a Y61e 2
rr5 YYr 3 Y.IM Y 5SU Y
rre 61Yr a 6141G 2
rr7 Y51 3 61 41 61 SSS +
rr r Y51 a YS2 2
IC YeL 05r 3










3 JSo 3 Yel 3 Y!3 3	 ube Yet S	
ae7 YG2 1 JGC	 r
rV2 ry7 a YSe 2










5 unn y YoC S Y!V 3	 Y70	 3 6171 3	 J72 3	 973 3 475	 c










3 Y7e 3 r77 3 Y7e 3	 r7 
rrV rrr r
^\ Ye( C Yr1 2
.y
`UI YC I 3 YhY C










3 Yer S Yre T Y !b 4	 JA7	 ] rbl 5	 YN1 1	 YC7 V u!G




















2 Sur 5US c 51U i
`1 rrl 1! +93 2
r r 3 3
y ll + r l r r9Y S










1 4^,3 7 Soe 7 `}+ a	 51U Sce v	 SiS v	 5'7 9 5Y3	 c
1 'ln rv• a YvG 3
^I) 44% Y bUO 3
. I . yu1 3 5u1 Y
1 Ir y \2 10 50 4 1
1 3 0 5Ur 3
SUS 3
cf S\e 3 Sue r
- c 3 S^ } I	 ^ Su 4 c




520 511 3 511 4
S27 $13 3 S13 s
S2r S13 to S17 2
S29 S1S 3 Sl y 9 Sib 3
530 $15 10 $17 3
$31 Sle u 111 4
S32 S17 5 522 2 S30 2 S35 2 '_i9 2 S4S c SSo 2 S5e d	 5e1
533 519 3 519 4 520 14 $31 q '_30 540 G 547 9 552 S	 55n
534 :114 lu S11 2
53S S10 10 S21 3
53e Sit 4 S22 3
$37 Sim 3 S1 4 3 Sit 3 53e 3 540 3 S47 3 552 3 SSe 3
536 1215 3 525 5 531 5 530 S 540 5 547 5 551 S 55d 5
53 14 Ste 3 52e 7 531 7 53e 7 5 4 0 7 547 7 SS2 7 55d 7
540 Ste 10 519 2
541 526 3 51e S S3? 5 537 2 5 Sub 5 5S4 5 559 5
Sur 516 10 52 q 3
543 5214 4 S30 3
S44 531 l0 534 2
S4S S33 3 533 7 537 7 S lit 7 54d 7 554 7 SS9 7
54e 533 10 534 3
S47 534 4 535 3
$4e 53e 10 53e
54 9 537 Iu 536 3
550 Sae 4 1339 3
551 S4c to 544 c
S5c 541 3 bed c ti4n 2 553 1 559 2
553 543 3 543 9 5 4 6 9 SS 4 9 559 S
554 S43 lu 544 3
555 54, 4 5413 3
513e 54r 3 54e 4
S57 541 10 S49 2
SSe 5 4 e 10 1344 3
559 549 4 1350 3
5e0 S51 3 551 4
561 552 10 SSS 2
561 554 3 554 3 1354 3
5e3 554 10 555 3
5e4 5513 4 550 3
^e13 557 3 557 4
500 S5e 10 5e0 1
5e7 S5 q 10 5e0 3
Seb 1360 4 Set 3
























Figure 22(d) shows the synthesis output for the minicomputer.
6.6 SUMMARY
From the above examples, it is clear that DDLSYN adds some extra
inverters in an automatic design. Other extra cells in an automatic
design are dependent on the DDL description. State declaration adds
some extra cells in the automatic design. Careful use of state is






An algorithm to synthesize the logic implied by a DDL description
'	 along with its implementation details were given.
	 The net and cell
table outputs of the synthesis program DDLSYN are of the format re-
quired by the other CADAT programs.	 Manual generation and inputting; of
the net data into the CADAT system is very time consuming. 	 DDLSYN does
Le
this automatically. 	 The net table created by DDLSYN is stored as a
 disk resident file.	 Other CADAT programs can use this file very easily.
The DDLSYN is general enough to be useful in any LSI design en-
vironment.
	 Formal logic minimization aspects were not considered during
DDLSYN implementation, although the constants and operations involving
F	 constants were taken care of. 	 A	 D	 flip-flop is assumed for each bit
of the registers declared in DDL.
	 The available inverted output of the
flip-flop is not used in the synthesis process.
	 Hence,	 some additional
inverters are generated for synthesis.
	 The modularity DDL description
is lost during synthesis, since the system is synthesized as a single
unit.I _
•	 The hardware generated by DDLSYN is almost equivalent in cost to
that designed manually.
	
Some additional hardware is generated due to
the finite state machine model assumed by DDL.
	
Careful use of <ID> and








1. S. G. Shiva, "Combinational Logic Synthesis from an HDL Descrip-
tion," Proc. of 17th Design Auto. Conf., pp. 550-555, June 1980.
2. S. G. Shiva, "Computer Hardware Description Languages -A Tutorial,"
Proc. IEEE, Vol. 56, pp. 1605-1615, Dec. 1979.
3. D.L. Dietmeyer and J.R. Duley, "Register Transfer Languages and
their Translation," in Digital System Design Automation: Languages
Simulation and Data Base, M.S. Breuer, Ed., Woodland Hilts, CA:
Computer Science Press, 1975, Ch. 2, pp. 117-218.
4. S. G. Shiva, "Digital Systems Design Language," NAS8-33096, Marshall
Space Flight Center, AL, Oct. 1979.
5. W. M. VanCleemput, "Computer Hardware Description Languages and
their Applications," Proc. Design Auto. Conf., pp. 554-560, June
1979.
6. W. M. VanCleemput, "An Hierarchial Language for the Structural
Description of Digital S y stems," in Proc. Design Auto. Conf.,
pp. 377-385, 1977.
7. 1. C. Bartee, Digital Computer Fundamentals. Fourth I-Aition,
McGraw-ilill Kogakusha, LTD., Tok yo, 1977.
3.	 H. Taub and D. Schilling, Digital Integrated Electronics, McGraw-
Hill Kogakusha, LTD., Tokyo, 1977.
9. W. M. VanCleemput, "The Role of Design Automation in the Design of
Digital Systems," Computer-Aided Design Tools for Digital Systems,
IEEE Catalog No. EHO132-1, pp. 1-8, 1979.
10. S. G. Shiva, "Use of DDL in an Automatic LSI Design and Test
System," Proc. Int. Conf. on CHDL's Applications, pp. 28-31,
Oct. 1979.
11. S. r . Shiva, "A Comparison of Hardware Description Languages,"
NASA CH-157762, AL. Oct. 1978.
12. J. M. Gould, "1'he Largt. Scal.- Microelectronics Computer-Aided De-
sign and Pest System." NASA TM-78202, Marshall Spare Flight Center,
AL, Oct. 1978.
13. T. M. Edge, "C-MuS Bulk Metal Design Handbook." NASA TM-78126,
Marshall Space Flight Center, AL. June 1977.
145
146
14. D. L. Dietmeyer and J. R. Duley, "A Digital Systems Design
Language (DDL)," IEEE Trans. Comput., Vol.	 C-17, pp.	 350-361,L
Sept.	 1968.
15. D. L.	 Dietmeyer,	 "DDLTRN -Users Manual," Dept, Elec. Comput. Eng.,
University of Wisconsin-Madison.
_ 16. D.	 L.	 Dietmeyer,	 "DDLSIM-Users Manual," Dept. Elec. Comput. Eng.,
University of Wisconsin-Madison.
17. D. L. Dietmeyer, "Introducing DDL," Computer  Aided Design Tools
r
for Digital Systems, 	 IEEE Catalog No.	 EHO 132-1,	 pp. 55-59, 1979.
18. M.	 H.	 Doshi and D.	 L.	 Dietmeyer,	 "Automated PLA Synthesis of the
Combinational Logic of a DDL Description," University of Wisconsin-
Madison,	 Rep.	 ECE 78-17,	 Nov.	 1978.
19. R.	 E.	 Swanson, Z. Navabi and F. J. Hill, "An AH,PL Compiler/Simu-
lator System," Proc. Sixth Texas Conf. 	 Comput.	 Syst., pp.	 595-613,
July 1968.
20. N.	 K.awato, T. Saito, F. Maruyama, and T. Venara, "Design and
^. Verification of Large Scale Computers by using DDL," in Proc.
Design Auto.	 Conf.,	 pp.	 360-366.	 June 1979.
21. T.	 D.	 Friedman and S.	 C. Yang, "Methods used in an Automatic Logic
Design Generator (ALERT)," IEEE Trans. Comput. Vol. C-18,













APPENDIX A. SYNTAX DIAGRAMS FOR DDL CONSTRUCTS
The syntax diagrams for the DDL description constructs are given
in this appendix. For the detailed description and examples of DDL























































































—	 Name -^--- 4 Subscript	 =	 !





—	 Subscript	 Constant	 Operation.	 _
CSUP	 Condition
(	 Operation

































































Head I --	 Body	 I
154





_.	 -- -- - I Head	 Body	 T—	 .
READ














APPENDIX B. SYNTAX DIAGRAMS FOR SIMULATOR COMMANDS
The syntax diagrams for the DDL simulator commands are given in
this appendix. For the detailed description and exampled of DDL simu-



















Name}-- Subscriptj--f{/ )- 	 Time Lis
_C^
Time List	 __














Binary	 octal	 Decima	 Hexa-
	
Number	 Number	 Number	 Decimal
Aw
head	 _	 Facility 	 Data
-- +iMode	 Type	 List
I
Mode
tTrigger	 Peri-	 pec	 c
Name	 odic	 Time
	Periodic	 Time	 Phase






o  lhunti,	 Mode	 - Type T




Name ,	 T e
Simulate







_ i-j Integer ----
Phase








This appendix presents the detailed flowcharts of the synthesis
program. Refer to Table 6 and 7 in Chapter 5 for the array names and





/ Subscrip\^_^ Locate in Facility













LScan Equation in IREI
'Reduc t io^i	
_-_	







































^^G CN I R ii
f
Move IMF; and 1111{:
into :• {'.MPA and 1EMIll
^Celuporar y Arrays








lk• f inr atth.rri} + t it^












	Constant —	 -ve Integer

































- -	 -	 -
i	 No	 I





of LPP into MATCH
--- - -L.--- ---7
Compare ILZ Digit Standard
Cell LPP with the LPP.
Store Number of Match



































J.	 •	 ompare LPP
.
-

















































































































^E ►+ 4:►+ w
y u
a w w O





























































































1 + ' /
iJ_ No





























is used as Record Number)
Number	
No






Define Output of Driving
Buffer in Identifier
Table. Store Identifier
Pointer in First Word
of Current Record	 J
^
Access Record Defined
by Pointer from Net File l
Store First Entry
as Driving Buffer Output
[_iiore  lnpin and]
Cell Number
All Inputs
to Standard Cell
re Stored ,
f
1
I
c
Yes
Return
t
