# COMPUTER AIDED DESIGN OF A DIGITAL FREQUENCY SYNTHESIZER

Bу

BIENVENIDO C. PERALTA Bachelor of Science Oklahoma State University Stillwater, Oklahoma

1953

Submitted to the Faculty of the Graduate College of the Oklahoma State University in partial fulfillment of the requirements for the Degree of MASTER OF SCIENCE May, 1974

OKLAHOMA STATE UNIVERSITY LIBRARY

SEP 3 1974

# COMPUTER AIDED DESIGN OF A DIGITAL FREQUENCY SYNTHESIZER

## Thesis Approved:

aut Thesis Adviser J Ed L 0

hard L. Cumm Ri

Graduate College the Dean of

## ACKNOWLEDGMENTS

The author wishes to thank the members of his committee, Professors Paul A. McCollum, Richard L. Cummins, and Bennett L. Basore for their guidance and patience.

A note of thanks also to Max Buckles, a colleague at Magnavox, for many helpful programming ideas.

To my wife, Lydia, special thanks for her unquestioning support and encouragement.

# TABLE OF CONTENTS

| Chapter |                                                | Page                         |
|---------|------------------------------------------------|------------------------------|
| Ι.      | INTRODUCTION                                   | . 1                          |
|         | Objectives and Results                         | . 3<br>. 5                   |
| II.     | APPROACH                                       | . 7                          |
| ·       | System Level CAD                               | . 7<br>. 7<br>. 8            |
|         | Sequential Circuits                            | . 91                         |
|         | State Assignment                               | . 17<br>. 18                 |
|         | Output Gating                                  | . 23                         |
| III.    | SYSTEM LEVEL DESIGN                            | . 27                         |
|         | Digital Frequency Synthesizer<br>Specification | . 29<br>. 35                 |
|         | Simulation at the Register Transfer<br>Level   | . 41<br>. 41<br>. 42<br>. 50 |
| IV.     | SYNCHRONOUS LOGIC DESIGN                       | . 53                         |
|         | Input Formats                                  | 53<br>55<br>56               |

Chapter

Page

| I۷  | . ( | (CONTINUED) |  |
|-----|-----|-------------|--|
| 4 1 | •   | 00111110207 |  |

| Counters                                                                                         | 59       |
|--------------------------------------------------------------------------------------------------|----------|
| V. COMPUTER PROGRAM DOCUMENTATION                                                                | 6.5      |
| Synchronous Logic Synthesis Program<br>Asynchronous Logic Synthesis Program                      | 65<br>65 |
| VI. SUMMARY AND CONCLUSIONS                                                                      | 69       |
| Summary                                                                                          | 69<br>70 |
| A SELECTED BIBLIOGRAPHY                                                                          | 71       |
| APPENDIX A - SAMPLE INPUT CODING AND PROGRAM PRINTOUT:<br>SYNCHRONIZATION INDICATOR AND VARIABLE |          |
| MODULO COUNTER                                                                                   | 72       |
| APPENDIX B - SPECIMEN PROGRAM OUTPUTS FROM LOGICMIN                                              | 77       |
| APPENDIX C - COMPUTER LISTING OF SYNCHRONOUS LOGIC<br>DESIGN PROGRAM                             | 82       |
| APPENDIX D - COMPUTER LISTING OF CUBE LOGIC OR<br>ASYNCHRONOUS LOGIC DESIGN PROGRAM              | 95       |

# LIST OF TABLES

| Table |                                                                                                                                       |   | Pa | age |
|-------|---------------------------------------------------------------------------------------------------------------------------------------|---|----|-----|
| I.    | State Transition Table for FFA of<br>Synchronization Indicator                                                                        | • | •  | 14  |
| II.   | Logic Simulator Input Coding for<br>Synchronization Indicator                                                                         | • | •  | 20  |
| III.  | Printout from Logic Simulator Program                                                                                                 | • | •  | 22  |
| IV.   | Printout from FFT Program After Processing<br>Thirty Two Samples of Non-Truncated Data<br>(top) and Seven Bit Data (bottom)           | • | •  | 36  |
| ۷.    | Spectral Analysis Using FFT for Truncated<br>and Non-Truncated Samples. Case I.<br>Synthesizer Set to Lowest Frequency                | • | •  | 37  |
| VI.   | Spectral Analysis Using FFT for Truncated<br>and Non-Truncated Samples. Case II.<br>Synthesizer Set to Five Times Lowest<br>Frequency | • | •  | 38  |
| VII.  | Spectral Analysis Using FFT for Truncated<br>and Non-Truncated Samples. Case III.<br>Synthesizer Set to Six Times Lowest<br>Frequency | • | •  | 39  |
| VIII. | Strength in db of Largest Undesired Frequency<br>Within Pass Band Versus Sample Size                                                  | • | •  | 40  |
| IX.   | Register Transfer Description Used as the<br>System Simulation Program                                                                | • | •  | 44  |
| Χ.    | Sample Output from System Simulation                                                                                                  | • | •  | 47  |

# LIST OF FIGURES

| Figui | re                                                                                                    |   | P | age |
|-------|-------------------------------------------------------------------------------------------------------|---|---|-----|
| 1.    | Timing Diagram for Synchronization Indicator<br>Logic Input = X Output = F1                           | • | • | 12  |
| 2.    | State Diagram of Synchronization Indicator                                                            | • |   | 12  |
| 3.    | Karnaugh Maps for FFA of Synchronization<br>Indicator                                                 | • | • | 14  |
| 4.    | Synchronization Indicator Logic Drawn from<br>Equations Generated by CAD Programs                     | • | • | 16  |
| 5.    | Plot of Time Series of Samples Obtained from<br>Read Only Memory                                      | • | • | 28  |
| 6.    | Characteristics of Low Pass Filter                                                                    | • | • | 30  |
| 7.    | Block Diagram of Frequency Synthesizer                                                                | • | • | 31  |
| 8.    | Frequency Synthesizer Timing Chart                                                                    | • | • | 32  |
| 9.    | Timing Diagram for Sweep Mode, Initial f = 32f <sub>lo</sub><br>and Sweep Control Set for 14 Cycles   | • | • | 32  |
| 10.   | Flow Chart Used to Construct Register Transfer<br>Description                                         | • | • | 43  |
| 11.   | Shift Register for Testing Synchronization<br>Indicator                                               | • | • | 57  |
| 12.   | State Diagram Specifying Variable Modulo<br>Counter                                                   | • | • | 58  |
| 13.   | Synchronous Variable Modulo Counter Logic<br>Diagram Drawn from Equations Generated<br>by CAD Program | • | • | 58  |
| 14.   | State Diagram Specifying Divide-by-7 Counter                                                          | • | • | 60  |
| 15.   | Divide-by-7 Counter Obtained from CAD<br>Equations                                                    | • | • | 60  |
| 16.   | State Assignment for Modulo-5 Counter Used<br>in Frequency Sweep Logic                                | • | • | 61  |

| Figu | re                                                                              |   |   |   | Р | age |
|------|---------------------------------------------------------------------------------|---|---|---|---|-----|
| 17.  | Modulo-5 Counter with No Latch Up States                                        | • | • | • | • | 61  |
| 18.  | Frequency Sweep Output Gating Obtained from<br>Multiple Output Prime Implicants | • | • | • | • | 63  |
| 19.  | Flow Chart of Synchronous Logic Synthesis<br>Program                            | • | • | • | • | 66  |
| 20.  | Flow Chart of Asynchronous Logic Synthesis<br>Program                           | • | • | • |   | 67  |

i

## CHAPTER I

#### INTRODUCTION

Computer-aided design, known as CAD in the literature, means many things to many people. The term currently covers all engineering design tasks and certain manufacturing support functions which are assisted by computers.

One of CAD's most successful applications to date is in automating much of the drafting and manual preparation of the "artwork" needed to make printed circuit boards. Programs have been developed which optimize the layout (placement of components) of a circuit board in regard to conductor length and other constraints.

To digital systems engineering, a more significant development occurred when device technologists learned to apply CAD programs similar to those used in circuit board design to their own integrated circuit (IC) artwork generation. Results have been astounding although this started only within the past five years. Improvements in device processing and packaging <u>per se</u> (e.g., passivated silicon junction, epitaxy) had reached a plateau by 1967 or so. However, CAD was able to further reduce the cost of manufacturing IC's while permitting increases in device complexity and performance. Consequently there has been a

growing trend to find new applications of digital circuitry in traditional electronic equipment as well as in automotive, medical, vending machines, and other fields.

CAD of digital components has therefore impacted on the logic design engineer in terms of <u>what</u> work there is to do; it is interesting to note that it is also affecting <u>how</u> to do it. On the matter of "how to do it," device technology today offers components which allow the designer to work at essentially two levels: at the gate/FF level, and at the register transfer or system level. In general, both design levels will be encountered since the former permits synthesis of functions not manufactured as standard IC modules, while the latter uses pre-designed building blocks or standard modules.

Although as noted above CAD has been used profitably in digital device design and production, CAD programs for logic and digital system design and development are not as yet generally available. This may come as a surprise to the reader who knows that <u>analog</u> filter design programs may be purchased, or rented (along with computer time) via remote terminals.

The present situation in regard to <u>digital</u> CAD programs (and particularly sets or systems of inter-related programs) is somewhat similar to the era when a new tool such as the oscilloscope, or perhaps the minicomputer, had just arrived on the scene. Initially they are expensive, and many potential users prefer to wait for a proven, mass produced

model. Others find it more cost-effective to build their own. The author in doing this thesis project has joined with those in the builder category.

Objectives and Results

The goal of this study was to implement a set of programs applicable for the computer-aided design of small digital systems or subsystems.

A survey of expected sources of CAD programs in the areas of logic and digital system design indicated that several synthesis and simulation programs were being used in industry. With the limitations of this study in mind these programs were categorized as available and not avail-The former included low-cost library items such as able. graphical plotting routines, as well as logic simulators and filter design programs which may be accessed via remote terminals. In the not available class were two types of programs: proprietary (for owner company's internal use) and secondly, the few existing CAD software-hardware packages. From this project's viewpoint, the software-hardware systems were unavailable not only because of the five-figure dollar amounts required for their lease but also due to their being primarily data base and documentation systems.

Accordingly, the following objectives were considered:

(1) Develop a computer program for designing synchronous sequential circuits.

(2) To complement item (1) develop a program suitable for system level design.

(3) Search for other programs that are available, in the sense defined previously, for CAD adaptation.

(4) Devise a procedure for applying these programs inCAD of digital systems.

Addressing each of the cited objectives the results of this study are as follows:

(1) A synchronous sequential logic synthesis program was written and "debugged." It accepts as input a simple tabular representation of the state flow diagram of a specification. It outputs all equations needed to construct the circuit synthesized from the state diagram. The schematic may be drawn from the equations using JK flip-flops and IC gates as components.

(2) A register transfer simulation program described in the literature was modified and improved. Although simulation is not synthesis, this simulator can aid the designer by allowing convenient experimentation and evaluation of tentative system configurations. The system structure is described to the program in building block format, while system behavior is simulated in terms of sequences of register transfers and related operations.

(3) Computations for non-digital aspects of the design problem, e.g. spectral analysis and filter design, may be handled with the aid of the fast Fourier transform or FFT

(a library subroutine) and through commercial remote terminals, respectively.

A gate/FF level simulator program was rented after familiarizing with a time-shared version. This program was used for verifying sequential logic designs.

(4) A methodology for computer-assisted design employing the set of programs is reported in this thesis. A case study involving the detailed design of a digital frequency synthesizer is summarized therein.

#### Overview

The five chapters following the Introduction are organized as follows:

Chapter II describes the approaches and algorithms required to implement the programs. A methodology for using these programs for computer-assisted design is also outlined. Topics introduced in Chapter II which may seem tangential include design language, system level and gate level simulation, and non-digital design aspects. Gate level simulation is explained with an example. Programming topics regarding major subroutines of original programs are relegated to Chapter V.

Chapter III considers the design problem at the system level. A new type of frequency synthesizer is presented as a case study in digital system design, hence its functions and specifications are described. Next, the size of the memory word for the synthesizer is determined by analyzing

with the FFT the deterioration of the output waveform as word size is decreased. Feasibility of a proposed system configuration is then studied by simulation. To this end, conversion of block diagrams into register transfer notation is illustrated.

Chapter IV describes the synthesis of synchronous (clocked) sequential circuits. The first example consists of a control function. Subsequent examples deal with shift registers and counters. The remaining examples are concerned with minimization of output gating, and effects of state assignment. All were used in designing the frequency synthesizer.

Programming details, flow charts, listings of the logic synthesis programs, and samples of input coding and resulting printouts (and these comprise "documentation" as used by programmers) are contained in Chapter V and the appendices. For the convenience of the reader, a program which generates asynchronous logic and which served as the prototype for the program employed in Chapter IV is included in Appendix D.

## CHAPTER II

## APPROACH

## System Level CAD

Given today's pre-packaged gate arrays, flip-flops, registers, adders, and other building blocks the task of design starts naturally with the consideration of system level structure and behavior. One may assume that a system can be constructed by (1) selecting a set of building blocks and interconnecting them, and (2) designing non-standard functional blocks, if any are needed, after the system structure has been developed. For this purpose it is convenient to employ a simulator and its programming language.

## Design Language

To simulate a digital system one needs to provide data to a simulator program which describes the system's organization. Additionally the data must convey the details of the system's operations, timing, and control. For ease of preparation and readability, a digital system should be described via a design language.

Duley, et al. [1] and Baray, et al. [2] have proposed languages in which programs containing design specifications may be written, and which serve as inputs for simulation and

synthesis. Chu [3] incorporated the register transfer concept in an Algol-like language that has seen actual use in computer design.

The language adapted in this study is a subset of Chu's Computer Design Language (CDL). As will be shown in Chapter III it can define any register, decoder, memory, and other building blocks. It is easier to learn than Fortran since it is a higher order language. Compared to an equivalent Fortran program, a CDL program would have considerably fewer statements.

## **Register Transfer Simulation**

A CDL description, in conjunction with test data, permits the simulator program to compute a system's behavior or response. The response is characterized primarily as a sequence of values of contents of registers belonging to the system being simulated.

The simulator program used in this study contains two sections: the translator section and simulator proper. The former translates the CDL model of a system (in punched card form) into an internal compiler code and sets up various tables. The latter consists of four routines: Loader, Output, Switch, and Simulate. The Loader accepts the initialization and test data segments of the input card deck and stores them in simulated registers and memories. Results of the simulation are formatted for printing by the Output routine. Printout typically consists of the contents of

certain registers and memory words evaluated at each clock time. Items to be printed are selected by the user. The Switch routine simulates manual switches. The Simulate routine executes the internal compiler code interpretively (i.e. the simulation is performed as though the input program were in machine language).

# Gate Level CAD: Synchronous

## Sequential Circuits

## Manual versus CAD Procedures

A synthesis procedure for synchronous sequential circuits, modelled as Moore machines, consists of five steps:

- (1) Make a flow table from the design specification.
- (2) Reduce the number of rows of the flow table.
- (3) Assign a binary code to each state.
- (4) Determine the flip-flop input equations.
- (5) Design the combinational logic for the output.

We are justified in treating synchronous logic exclusively since its preponderance over asynchronous sequential logic is well known. To a large degree this is due to the fact that the critical race problem does not exist in synchronous sequential circuits and so they are easier to design. When the Moore machine viewpoint is taken, designing the output gating is more straightforward compared with the Mealey model since the output function depends only on the internal state. Further, Friedmann and Menon [4] have

recently shown that this approach lends itself to more systematic production of test patterns (useful in manufacturing and maintenance).

In practice, state assignment is usually done by trial and error. Steps (2) and (4) also contain many tedious operations when more than a few input signals and internal states are required. When done manually step (5) may prove difficult if a large multi-output minimal cost network is desired. Hence the design procedure can benefit from CAD programs.

The CAD programs that were developed assist the designer in performing steps (4) and (5). The name Synchronous Logic Synthesis Program is given to the set since logic equations are generated from which a schematic diagram may be drawn. For reasons to be explained later, methods intended for flow table reduction and state assignment were not programmed.

The suggested CAD procedure follows the manual procedure with two modifications:

(a) The flow table prepared for step (3) is converted into a state diagram.

(b) Only JK flip-flops will be used.

The state diagram of item (a) serves as the input to the synthesis program. Punched cards are easily prepared which convey the node and transition signal data in the form of a from - to table or "wire list." Regarding (b), the JK flip-flop is widely used so that specializing the present

version to a single flip-flop type in order to simplify the program seems justified.

#### CAD Synthesis Algorithms

The following algorithm is commonly used for determining the flip-flop input equations of sequential circuits using JKFF's. (Notations of the form JKFF and FFA denote JK flip-flop and flip-flop A respectively.)

(1) Make a state transition table for each JKFF to be used.

(2) Draw Karnaugh maps for each state transition table.

(3) Derive the minimized JKFF input equations from the maps.

The Synchronous Logic Synthesis Program mechanizes the above procedure. Corresponding to the first step, a "list" data structure is constructed and stored in memory when the data cards are read. Instead of the Karnaugh map, a subroutine processes the list using a version of the Quine-McCluskey minimization algorithm. The minimal expressions  $(J_A \text{ and } K_A \text{ for FFA, etc.})$  are then printed out.

To illustrate the equation generation process, a control logic function will be synthesized by going through steps (1) to (3) manually. The results are then compared with the CAD program's output.

The control logic function (Synchronization Indicator) is specified by the timing diagram shown in Figure 1. The diagram defines the behavior of the function's output for the



Figure 1. Timing Diagram for Synchronization Indicator Logic. Input = X Output = F1



(FI= OUTP UT )

Figure 2. State Diagram of Synchronization Indicator

input signal given. Either a state diagram is drawn from a flow table derived from Figure 1, or made directly without benefit of formal state minimization techniques.

Figure 2 shows a state diagram for the Synchronization Indicator having seven states and an optional state, S7. The label F1 on nodes S3 through S6 indicates that the output is true when the present state is in any of these nodes.

The state transition table for FFA, Table I, was constructed from the state diagram after making the state assignment:

| S0  | S1  | S2  | S 3 | S 4 | S 5 | S6  | S 7 |
|-----|-----|-----|-----|-----|-----|-----|-----|
| 000 | 110 | 101 | 100 | 011 | 010 | 001 | 111 |

In Table I, the entries NC(0) and NC(1) in the Action Desired column mean "no change, state 0" and "no change, state 1" respectively. The table gives the values required for inputs J,K to cause the actions <u>set</u>, <u>reset</u>, <u>NC(0)</u>, and <u>NC(1)</u> to occur during the next clock period. For example in the first row of the table, the next state of FFA is given as <u>1</u> when X = 1. Hence FFA must be set and this requires J = 1 and K = d, where d denotes <u>don't care</u>.

In Figure 3 the Karnaugh maps for  $J_A$  and  $K_A$  are depicted. These maps were constructed by treating Table I as a table of combinations for the present state and input X. For example, cell 0100 of the maps contain the entries 1, d respectively. These were taken from row 3 of Table I with X = 0 columns indicating set A is the desired action.

| Present State | Next Sta     | te (FFA)     | Action                     | Desired*     |
|---------------|--------------|--------------|----------------------------|--------------|
| FFA FFB FFC   | <u>X = 0</u> | <u>X = 1</u> | $\underline{X} = 0$        | <u>X = 1</u> |
| 000           | 0            | 1            | NC(0)                      | Set          |
| 001           | 0            | 1            | NC(0)                      | Set          |
| 010           | 1            | 0            | Set                        | NC(0)        |
| 011           | 0            | 1            | NC(0)                      | Set          |
| 100           | 1            | 0            | NC(1)                      | Reset        |
| 101           | 1            | 1            | NC(1)                      | NÇ(1)        |
| 110           | 1            | 1            | NC(1)                      | NC(1)        |
| 111           | 1            | 1            | NC(1)                      | NC(1)        |
| * Set ⇒       | J = 1, K     | = d          | $NC(0) \Rightarrow J = 0,$ | K = d        |
| Reset ⇒       | J = d, K     | = 1          | $NC(1) \Rightarrow J = d,$ | K = 0        |



## TABLE I

STATE TRANSITION TABLE FOR FFA OF SYNCHRONIZATION INDICATOR

Figure 3. Karnaugh Maps for FFA of Synchronization Indicator

The minimal expressions derived from the loops of the  $J_{\rm A},\ {\rm K}_{\rm A}$  maps are:

$$J_{A} = B\bar{C}\bar{X} + \bar{B}X + CX$$
$$\kappa_{A} = \bar{B}\bar{C}X$$

The CAD program when given the same state diagram and state assignment generates exactly the same equations for  $J_A$  and  $K_A$ . These equations as well as those for the two other FF's required are shown in the computer printouts of Appendix A. Note that the minterms comprising a loop are also displayed.

The equations for FFB and FFC are:

$$J_{B} = \bar{c} X$$
$$K_{B} = \bar{A} X + \bar{c}$$

and

$$J_{C} = AX + BX$$
$$K_{C} = \overline{X} + \overline{A} + B$$

The foregoing equations are depicted in logic schematic form in Figure 4.

The output gating in Figure 4 was obtained by making a truth table of the output function (F1) from the timing diagram and minimizing it with another CAD program. This completed the design of the Synchronizer Indicator.

Referring again to Figure 3, cells 1111 and 1110 of both maps contain dashes, d's, and O's. The dashes are <u>don't care</u> entries which apply when the unspecified state S7 is ignored.



Figure 4. Synchronization Indicator Logic Drawn from Equations Generated by CAD Programs

The d's and O's apply when S7 is assigned binary code 111. Although the expressions generated are the same in either case, they may be different from each other for other state assignments. State assignment and output gating will be discussed further in later sections.

## Flow Table Reduction and State Assignment

Taking into account that the present set of CAD programs do not perform flow table reduction and state assignment, the following guidelines are suggested.

<u>Flow Table Reduction</u>. Manually process a primitive flow table using a method intended for the type of table. Procedures for reducing the number of rows have been detailed by Givone [5] for completely specified, incompletely specified, and input restricted types.

<u>State Assignment</u>. An algorithm is described in a recent paper by Story, Harrison, and Reinhard [6]. This and other methods known to the designer may be used to produce a number of state assignments for each problem. Since it is a simple matter to input these data to the CAD program, all these trials may be submitted in each run. The best solution (fewest number of input terms and/or number of gates) is then selected from the printouts.

Many papers have appeared in the literature proposing schemes for flow table reduction and optimal state assignment. These methods seem to have one or more problems such as incompatibility with don't care conditions, tedious to apply, not appropriate for synchronous logic, and use of a heuristic approach rather than algorithmic.

From the viewpoint of CAD program implementation, it is important that a procedure be definable as an algorithm. Experience has shown that a heuristic method sometimes defies conversion into a program having reasonable memory and running time requirements.

## Verification by Simulation

As an approach to the problem of verification of a logic design, simulation at the gate/FF level is gaining acceptance. Like most CAD tools it is appreciated most when the design to be verified exceeds a few dozen gates and FF's. This is due to the fact that program setup time for the simulation becomes significantly less than the cost of a comparable breadboarding effort. Verifying designs with a good simulator (one which can include effects of gate delays and detect violations of loading rules) permits prototyping with confidence. Hence the need for prototype "kluges" is minimized.

The simulator program employed in this study goes by the trade name of LOGSIM. Literature on its capabilities and an application manual are obtainable from Tymeshare, Inc. [7].

The maximum allowable number of gate-equivalents per simulation is 300, each JKFF being equivalent to 7-10 gates (depending on the particular commercial type). For example, for a network containing 20 JKFF's, 140-200 gates would be allocated for modelling the JKFF's leaving 100-160 gates to be used as gates or inverters. Other simulators have comparable characteristics and may be rated as to availability of gate delay and other modelling features, editing and file saving facilities, and run time and memory requirements.

Table II indicates the coding format and language used for LOGSIM. The circuit modelled by the statements is an 18-gate version of the Synchronization Indicator which resulted from one of several state assignments tried.

The first three lines of Table II describe the flipflops used in the circuit. For example, the significance of the symbols in line 1,

1 JK (2, QA, NA, JA, KA, P, O, O ) taken from left to right is: This statement is from card number 1 of the network's LOGSIM model. A JKFF is specified. There are two outputs, QA and NA. The synchronous inputs are JA, KA, and P. The initial condition for the asynchronous inputs (direct set and direct reset) are O, O, respectively.

Lines 4 through 21 specify AND, OR, and inverter gates and the way they are connected. Line 5 is read "KA is the output of an OR gate whose inputs are A5 and A2." AND gate and inverter declarations are read similarly.

The clock pulse source, P, is declared in line 23. This clock is "connected" to any component where the name P is declared as an input. That is, the node associated with

## TABLE II

# LOGIC SIMULATOR INPUT CODING FOR SYNCHRONIZATION INDICATOR

| and the second | 1. A. |                  |                                       |   |
|------------------------------------------------------------------------------------------------------------------|-------------------------------------------|------------------|---------------------------------------|---|
| 1 JK(2,QA,NA, JA,KA,P,0,0)                                                                                       |                                           |                  | •                                     |   |
| 2 JK (2, QB, NB, JB, KB, P, 0, 0)                                                                                |                                           |                  |                                       |   |
| 3 JK(2,QC,NC, JC,KC,P,0,0)                                                                                       |                                           |                  |                                       |   |
| 4 JA=OR(AN1,A2,A3,A4)                                                                                            |                                           |                  |                                       |   |
|                                                                                                                  | · · · · · · · · · · · · · · · · · · ·     |                  |                                       |   |
| 5 KA= $OR(A5,A2)$                                                                                                |                                           |                  |                                       |   |
| 6  AN1 = AND(QB, NC, NX)                                                                                         |                                           |                  |                                       |   |
| 7 A2 = AND(NB, X)                                                                                                |                                           |                  |                                       |   |
| 8 A3=AND(NA,QC)                                                                                                  |                                           |                  |                                       |   |
| 9 A4=AND(QC,X)                                                                                                   |                                           | - · ·            | •                                     |   |
| 10 A5=AND(NC,X)                                                                                                  |                                           |                  |                                       |   |
| 11 JB=OR(A6,QA)                                                                                                  |                                           |                  |                                       |   |
| 12 KB=OR(A7,A8)                                                                                                  |                                           |                  |                                       |   |
| 13 AG=AND(OC,X)                                                                                                  |                                           |                  |                                       |   |
| 14 A7=AND(QA,NC,X)                                                                                               |                                           |                  |                                       |   |
| 15 AB=AND(NA, QC, NX)                                                                                            |                                           |                  |                                       |   |
| 16 JC=AND(QA, QB, X)                                                                                             |                                           |                  |                                       |   |
|                                                                                                                  | •                                         |                  |                                       |   |
| 17 KC=OR(A10,A11,A12)                                                                                            |                                           |                  |                                       | • |
| 18 A10=AND(QA,NB,NX)                                                                                             |                                           |                  |                                       |   |
| 19 All=AND( $NA$ , X)                                                                                            |                                           |                  |                                       |   |
| 20  A12=AND (NA,QB)                                                                                              |                                           |                  |                                       |   |
| 21 NX=INVERT(X)                                                                                                  |                                           |                  |                                       |   |
| 23 P=A(PULSE)                                                                                                    |                                           |                  |                                       |   |
| 25 F1=OR(A13,A14,A15)                                                                                            |                                           |                  |                                       |   |
| 26 A13=AND(NA,QC)                                                                                                |                                           |                  |                                       |   |
| 27 A14=AND(QA, QB, NC)                                                                                           |                                           |                  |                                       |   |
| 28 A15=AND(NH,QC)                                                                                                |                                           |                  |                                       |   |
| 29 JK(2,W, NW, JW,KW, P.0.0)                                                                                     |                                           |                  |                                       |   |
| 30 JK(2, A1, NA1, W, NW, P,0,0)                                                                                  |                                           |                  |                                       |   |
| 31 JK(2,0Z,NZ, Y, NY, P,0,0)                                                                                     |                                           |                  |                                       |   |
|                                                                                                                  |                                           |                  |                                       |   |
| 32 JK(2, Y,NY, A1,NA1,P,0,0)                                                                                     |                                           |                  |                                       |   |
| 33 JK(2, X,NQX,QZ,NZ, P,0,0)                                                                                     |                                           |                  |                                       |   |
| 34 KW=INVERT(JW)                                                                                                 |                                           |                  |                                       |   |
| 35 JW=UR (A20, A21, A22, A23, A24, A2                                                                            | 25)                                       |                  |                                       |   |
| 36 A20=AND(NW,NA1,Y,QZ,X)                                                                                        |                                           |                  |                                       |   |
| 37 A21=AND(NW,A1,NY,QZ,X)                                                                                        |                                           |                  |                                       |   |
| 38 A22=AND(NW,NA1,NY,NZ,X)                                                                                       |                                           |                  |                                       |   |
| 39 A23=AND(NW,A1,Y,NZ,NQX)                                                                                       |                                           |                  |                                       |   |
| 40 A24= AND(H, NA1, NY, QZ, X)                                                                                   |                                           |                  |                                       |   |
| 41 A25=AND1W, NQX, NY, NZ)                                                                                       |                                           |                  |                                       |   |
|                                                                                                                  | ACT OC OD O                               |                  |                                       |   |
|                                                                                                                  | AS194094094                               | A . ASI . JA. KA | • AS 1                                |   |
| OUTPUTS J3,KB,AST,JC,KC,AST,F1                                                                                   | L . A S I                                 |                  |                                       |   |
| OUTPUTS AST, W, AL, Y, QZ, X, AST, AS                                                                            | 51,A20,A21,A                              | 22,A23,A24,      | A25                                   |   |
| END                                                                                                              |                                           |                  |                                       |   |
|                                                                                                                  |                                           |                  |                                       |   |
| - SIMULATION COM                                                                                                 |                                           |                  |                                       |   |
| STRUCATION COMI                                                                                                  | MANDD                                     | A T A P          | AGE 1                                 |   |
|                                                                                                                  |                                           |                  |                                       |   |
|                                                                                                                  |                                           |                  |                                       |   |
|                                                                                                                  |                                           | · · · ·          | · · · · · · · · · · · · · · · · · · · |   |
| 1 CLOCKED 'SYNCHRONIZER' USING .                                                                                 | J-K FFS ICA                               | D SOL N          |                                       |   |
| PULSE 150.0                                                                                                      | •                                         | -                |                                       |   |
|                                                                                                                  |                                           |                  |                                       |   |
| END                                                                                                              |                                           |                  |                                       |   |

a literal is connected to any component declaring it as an input signal, assuming of course that the format rules exemplified by the JKFF example are observed.

Lines 29-41 model a shift register which simulates the X-input sequence needed to test the design. It is not part of the logic function being verified.

"Housekeeping" statements which specify outputs to be printed out, the title heading, and number of clock pulses to be generated comprise the rest of the simulation input program.

When the program of Table II is executed, the printout prepared by the LOGSIM simulator is shown in Table III. The left-most heading, TEST, denotes row or line number. The heading P identifies the column used for the clock pulses. Similarly QC, QB, QA, ..., A25 are for FF's and gates specified by the user. The output values are printed alternately for P = 0 and P = 1 in Table III. The JKFF's are shown to change state after a 1-0 transition.

In the present example, Table III shows that the output F1 followed the timing diagram of Figure 1. Note also that the shift register (see columns W through X) produced the input signal sequence specified in the timing diagram. Thus the simulated circuit (or model) driven by a test pattern generated a printout from which the designer can infer that the logic specification was met.

## TABLE III

# PRINTOUT FROM LOGIC SIMULATOR PROGRAM

|   |          |          | CLOCKED                 | I S YN     | СНЕ      |    | I ZEP  | Į •    | USIN     | IG | J-K           | FFS .                 |
|---|----------|----------|-------------------------|------------|----------|----|--------|--------|----------|----|---------------|-----------------------|
| Ť | EST      | INPUT ID | Ρ                       | QQQ<br>CBA | JK<br>AA |    | -      | F<br>1 | WAY<br>1 |    | 22            | AAAA<br>22222<br>2345 |
|   |          |          |                         |            |          |    |        |        |          |    |               |                       |
|   | 1<br>2   |          | **()**<br>**1**         |            |          |    |        |        |          |    |               |                       |
|   | 3        |          | **()**                  |            |          |    |        |        |          |    |               |                       |
|   | 4        |          | **]**                   | 001        | 11       | 11 | + 00 × | •0*    | *011     | 11 | * <b>*</b> 00 | 00000                 |
|   | 5        | · · · ·  | **0**                   | -          |          |    |        |        |          |    |               |                       |
|   | 6        |          | **1**<br>**0**          | -          |          |    | -      | -      | -        |    |               |                       |
|   | 7<br>8   |          | **0**                   |            |          |    |        |        |          |    |               |                       |
|   | 9        |          | **0**                   |            |          |    |        |        |          |    |               |                       |
|   | 10       |          | **1**                   |            |          |    |        |        |          |    |               |                       |
|   | 11       |          | **0**                   |            |          |    |        |        |          |    |               |                       |
|   | 12       |          | **1**                   |            |          |    |        | -      |          |    |               |                       |
|   | 13<br>14 |          | **()**<br>**1**         |            |          |    |        |        |          |    |               |                       |
|   | 15       |          | **0**                   |            |          |    |        |        |          |    |               |                       |
|   | 16       |          | **1**                   |            |          |    |        |        |          |    |               |                       |
|   | 17       |          | **()≍*                  |            |          | _  | _      |        |          |    |               |                       |
|   | 18       |          | **1=*                   |            |          |    |        |        |          |    |               |                       |
|   | 19       |          | **0**                   |            |          |    |        |        |          |    |               |                       |
|   | 20       |          | ± ≠ 1 <b>*</b> ×        | _          |          |    |        | _      | -        |    |               |                       |
|   | 21<br>22 |          | **()**<br>**1**         |            |          |    |        | -      |          |    |               |                       |
|   | 27       |          | **()**                  |            |          |    | -      | -      |          |    |               |                       |
|   | 24       |          | **1=1                   |            |          |    |        |        |          |    |               |                       |
|   | 25       |          | **()**                  |            |          |    |        | -      |          | -  |               |                       |
|   | 26       |          | **1**                   |            |          |    |        |        |          |    |               |                       |
|   | 27       |          | **0**                   | -          |          |    |        | -      | -        |    |               | -                     |
|   | 28<br>29 |          | ≠≠1≈5<br>≠≠0≈1          |            |          | -  |        |        |          |    |               |                       |
|   | 30       |          | **1**                   |            |          |    |        |        | _        |    |               |                       |
|   | 31       |          | **() <b>*</b> ≭         |            |          |    |        |        |          |    |               | -                     |
|   | 32       |          | **1**                   |            |          |    |        | -      |          |    |               |                       |
|   | 33       |          | ×*()**                  |            |          |    |        |        |          | _  |               |                       |
|   | 34       |          | <b>≠ ≈</b> ] <b>*</b> 4 |            |          |    |        |        |          | -  |               |                       |
|   | 35<br>36 |          | >×()××<br>≈×1×1         |            |          |    |        | -      |          |    |               |                       |
|   | 31       |          | **0**                   |            |          |    |        |        |          | -  |               |                       |
|   | 39       |          | **1**                   |            |          |    |        |        |          |    |               |                       |
|   | 39       |          | **()* <b>*</b>          | 010*       | 01*      | 00 | ×01*   | •0*    | *110     | 01 | **00          | 0000                  |
|   | 40       |          | ×≠1××                   |            | -        |    | -      |        |          | -  |               |                       |
|   | 41       |          | **0**                   |            |          |    |        | -      |          |    |               |                       |
|   | 42<br>43 |          | **1**<br>**()**         |            |          |    |        |        |          |    |               |                       |
|   | 44       |          | ×.≠()×.≠<br>≍.≭].≭¤     |            | -        | -  | -      | -      |          | -  |               |                       |
|   | 45       |          | **()**                  |            |          |    |        |        |          |    |               |                       |
|   |          |          |                         |            | -        | -  |        |        | -        |    |               |                       |
|   |          |          |                         |            |          |    |        |        |          |    |               |                       |

# Gate Level CAD: Minimization of Output Gating

To obtain the minimized expression to be used for an output gating circuit, punched cards representing its truth table are input to LOGICMIN. This program is external to the Synchronous Logic Synthesis Program. These two programs were separated since some modification of the minimization algorithm and different printout formats were desired in each case. LOGICMIN may be used for any combinational switching function provided its truth table has no more than 1024 rows and 32 literals.

#### Single-Output Functions

The algorithm used here is the well known Quine-McCluskey method which initially determines the prime implicants of a given function. The method then finds a set of irredundant expressions from which minimal expressions are formed. A hazard-free minimal sum is also computed for possible use with the asynchronous (direct set/reset) inputs of JKFF's.

## Multiple-Output Functions

For this type of gating an extension of the Quine-McCluskey method described by Givone [8] was used in LOGICMIN. The extension amounts to employing the original algorithm to process tagged product terms and using a mask (AND type) operation on the tags. LOGICMIN computes several candidate solutions for each truth table. One set of solutions tends to optimize cost with respect to the number of input lines and gates. A second set has a different criterion namely that of using smaller (2-input or 3-input) gates rather than larger gates.

To aid the user in drawing the logic schematic from the minimized gating expressions, cross-reference tables, printplots, and binary code labels are included in the printout of results.

#### Non-Digital Aspects

## Spectral Analysis with FFT

The FFT is an efficient method of computing the discrete Fourier transform. Basore [9] has prepared a monograph explaining this computational short-cut.

For CAD programming if the FFT is included in a computer library of subroutines, then it is simply called by the user's program. The version used in this study was written in Fortran and invoked by a statement of the form

CALL COOL (N, ARRAY, -1)

where N specifies the number of samples, ARRAY is the name of an array dimensioned as two rows and N columns, and -1 signifies the direct transform (+1 would specify inverse). ARRAY stores the real and imaginary components computed by the subroutine. The user's program typically provides for the reading in of the sampled data, subsequent conversion of the spectral components into db, and tabulation of results.

## Filter Design

An analog filter synthesis program available through remote terminals was used in designing the low-pass filter specified in Chapter III. The program, designated MATCH by the Applicon Company [10], employs the conjugate gradient approach for optimization.

## Methodology

The CAD procedure suggested for systems consists of seven steps one or more of which may be optional. The choice of which step to by-pass and how many iterations to perform depends on the user's judgement.

(1) Convert the block diagram and timing chart of a system into a register transfer description for input to the simulator program. Reconfigure and simulate again as necessary to refine and simplify the design.

(2) Determine the standard and non-standard building blocks of the system developed in the first step.

For each non-standard block do steps (3) to (7).

(3) Input the state diagram data of a non-standard function to the Synchronous Logic Synthesis Program.

(4) Input to LOGICMIN the truth table of the output gating function.

(5) Draw the schematic for the equations generated in step (3). Label the JKFF terminals to correspond with the state assignment used. Select one of the equations obtained in step (4) and draw its schematic.

(6) Interconnect the output gating from step (5) to the JKFF's.

(7) Verify the complete schematic of the non-standard function by gate level simulation.

Following completion of the above, prototype hardware may be assembled from off-the-shelf items and from the nonstandard functions designed with the procedure.

It is assumed that previous to step (1), non-digital aspects involving filters and related interface circuitry had been dealt with. As noted, CAD programs are commercially available for this portion of the design task.

## CHAPTER III

## SYSTEM LEVEL DESIGN

A new approach which competes favorably with analog techniques in the area of very stable frequency generation is described and used as a design example. The method computes a sequence of sinusoid samples with a simple table look-up scheme followed by interpolation by means of a low pass filter. Table look-up is practical since the number of samples is small, and low-cost read only memory (ROM) used to store the samples is now available. The technique is simpler than digital recursion and produces less noise [11].

The process generates a time series of sine wave samples represented by the expression

 $\{\sin 2\pi fnT\}$  n = 0, 1, 2, ...

where f = frequency to be generated, n = time index, and T = sampling interval.

The lowest frequency,  $f_{lo}$  is synthesized when the total number of samples stored in the table, N, are used in each period. This is depicted in Figure 5a with N = 16. For a given T,

$$f_{10} = 1/NT.$$







b.) Time Series for 3f<sub>lo</sub>

Figure 5. Plot of Time Series of Samples Obtained from Read Only Memory

To select a frequency we provide a frequency index k such that

and the time series expression may be written

 $\{\sin(2\pi nk/N)\}$   $k \le N/4; n = 0, 1, 2, ...$ 

The above indicates that the generated frequency can be set by index k. Due to the Nyquist condition, and for ease of filtering, the highest frequency is constrained to  $f = (N/4)f_{10}$ .

Figure 5b shows the sequence of samples corresponding to k = 3. It also shows that after the third cycle the sequence repeats. This implies that as n increases, the product nk is treated modulo N. The generation of time series therefore involves accumulating multiples of k. In terms of the table look-up scheme, accumulated values of k are used as memory addresses and no other computations are needed.

Digital Frequency Synthesizer Specification

Being a case study in system level design pertinent characteristics of the synthesizer are specified as analog and digital. The <u>analog</u> specifications are: (1) number of frequencies = 32; (2) lowest frequency = 1 Hz; (3) maximum in-band noise referred to a generated frequency = -40 db; (4) low pass filter transition band is from 32 to 64 Hz with out-of-band attenuation of 80 db. (See Figure 6). The



Figure 6. Characteristics of Low Pass Filter

<u>digital</u> portion of the design specification follows. Binary arithmetic is to be used in implementing the block diagram of Figure 7. There are two modes of frequency selection: fixed and sweep. Provide a synchronizer indicator function. The timing charts of Figure 8 and Figure 9 are part of the specification.

In Figure 7 the accumulation process for index k described earlier is done by an accumulator which consists of an address register that feeds back to an adder. The input register holds the value of the control word corresponding to index k for generating a constant frequency. Similarly, the frequency sweep up-counter serves as an



Figure 7. Block Diagram of Frequency Synthesizer







Figure 9.

9. Timing Diagram for Sweep Mode, Initial f = 32f<sub>lo</sub> and Sweep Control set for 14 Cycles

input register except it increments the frequency during the sweep mode.

The table look-up operation is performed by the ROM and accumulator. The digital to analog converter DAC changes the binary coded samples into analog voltages which are then interpolated by the filter LPF. The sampling interval is determined by the clock CLK1 since the address decoder gets the next address after each CLK1 pulse. The box labelled "synch detector" has a logic function which determines if an external pulse train is in synchronism with CLK2.

The cycle counter in Figure 7 controls how long a frequency stays fixed during the sweep mode. It contains a  $\div$  7 counter in series with a variable-modulo counter ( $\div$  2, 4, 6, 8 depending on sweep control word). Hence CLK2 pulses are derived from transitions of the 2<sup>6</sup> bit of the adder divided by 14, 28, 42, or 56. In turn, the frequency sweep up-counter supplies k index values 7, 8, 9, 10, 11, 7, .... Since CLK2 drives this counter, the output frequency will be 7f<sub>10</sub>, 8f<sub>10</sub>, .... and will remain fixed for 14, 28, 42, or 56 cycles before changing (sweep mode only).

Figure 8 gives the timing relationship between the operations which occur in the Frequency Synthesizer. After each CLK1 pulse enables the address register a new address is loaded into the address decoder. The next sum is ready after a slight delay needed for adding the k index and the

present sum. The time allowed for reading out the ROM and for analog conversion must be short enough so that the analog sample is ready before the next CLK1 pulse.

Some details of fixed and sweep mode operation are depicted in Figure 9. Initially the fixed mode applies, and the selected frequency is assumed to be  $32f_{10}$ . The diagram shows that the 2<sup>6</sup> sum bit indicates overflow after every four samples. The address values are shown to be 0, 32, 64, 96, 0, .... (modulo 128). Because the sweep control is set to permit 14 cycles to be generated, CLK2 is shown to fall after 56 CLK1 pulses. The figure also assumes that the sweep mode was selected at this time, and that the sweep register (or sweep up-counter) was enabled to the adder when it contained the value 7.

The ROM used for storing the sine wave samples is described in Figure 7 as having  $128 \times 8$  bit words. This means that the number of words, N, is double that required by the Nyquist criterion for a maximum frequency of 32 Hz. The 8-bit word size was obtained by taking the worst case error as being equal to the least significant bit. This gives for an 8-bit word (7 bits magnitude plus sign) 20 log 2<sup>-7</sup> or -42 db. This is less than the -40 db specification for in-band noise. The 8-bit word length will be validated later by means of the FFT.

Only 7 bits of the adder in Figure 7 are connected to the address register. That is, the sum bits 2° to 2<sup>6</sup> are used thereby converting the accumulated k index values modulo 128.

# Effects of Truncation and Sampling Errors on Memory Word Length

Determining the correct word length is important since too small a word could result in failing to meet the noise specification due to truncation (round off) effects. Too large a word causes extra power dissipated due to unnecessarily large registers and adders. Further, ROM modules are relatively expensive due to the additional process of "programming" the values to be stored into the module. Hence a change of word size means that a completely new ROM must be programmed.

The effect of word size on spectral purity was studied empirically by using the FFT to compute spectra of samples having different word lengths. For simplicity it was assumed that the synthesizer had a total of 16 samples and that word lengths can be adjusted to 4, 7, and 31 bits.

The results from a 32-point transform are shown in Table IV for 7-bit and 31-bit samples. The 31-bit case was called non-truncated since this is the full word size for single-precision arithmetic. Only the positive 16 samples are shown. The table is for the case when the lowest frequency,  $f_{10}$  was selected.

Table V presents the data of Table IV in db referred to  $f_{10}$ . Additional data for the 4-bit case were included. Similarly, Tables VI and VII give the results for  $5f_{10}$  and  $6f_{10}$  respectively.

# TABLE IV

# PRINTOUT FROM FFT PROGRAM AFTER PROCESSING THIRTY TWO SAMPLES OF NON-TRUNCATED DATA (TOP) AND SEVEN BIT DATA (BOTTOM)

| LINE NO.                                                               | MAGNITUDE                                                                                                                                       | SAMPLED DATA                                                                                                                                                                                     |
|------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                                                                      | 0.4192E-06                                                                                                                                      | 0.0                                                                                                                                                                                              |
| 1                                                                      | 0.4976E 00                                                                                                                                      | 0.0                                                                                                                                                                                              |
| 2<br>3                                                                 | 0.7764E-06                                                                                                                                      | 0.3826830                                                                                                                                                                                        |
|                                                                        | 0.4079E-06                                                                                                                                      | 0.3826830                                                                                                                                                                                        |
| 4                                                                      | 0.3128E-06                                                                                                                                      | 0.7071062                                                                                                                                                                                        |
| 5                                                                      | 0.2016E-06                                                                                                                                      | 0.7071062                                                                                                                                                                                        |
| 6                                                                      | 0.2020E-06                                                                                                                                      | 0.9238790                                                                                                                                                                                        |
| 7                                                                      | 0.4142E-06                                                                                                                                      | 0.9238790                                                                                                                                                                                        |
| · <b>B</b>                                                             | 0.1489E-06                                                                                                                                      | 1.000000                                                                                                                                                                                         |
| 9                                                                      | 0.2300E-06                                                                                                                                      | 1.0000000                                                                                                                                                                                        |
| 10                                                                     | 0.1350E-06                                                                                                                                      | 0.9238603                                                                                                                                                                                        |
| 11                                                                     | 0.1661E-06                                                                                                                                      | 0.9238803                                                                                                                                                                                        |
| 12                                                                     | 0.1296E-06                                                                                                                                      | 0.7071087                                                                                                                                                                                        |
| 13                                                                     | 0.9045E-07                                                                                                                                      | 0.7071087                                                                                                                                                                                        |
| 14                                                                     | 0.1544E-06                                                                                                                                      | 0.3826867                                                                                                                                                                                        |
| 15                                                                     | 0.4901E-01                                                                                                                                      | 0.3826867                                                                                                                                                                                        |
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13 | 0.0<br>0.4968E 00<br>0.0<br>0.1795E-02<br>0.0<br>0.1263E-02<br>0.0<br>0.1169E-03<br>0.0<br>0.9601E-04<br>0.0<br>0.6750E-03<br>0.0<br>0.5444E-03 | 0.0<br>0.0<br>0.3828125<br>0.3828125<br>0.7109375<br>0.7109375<br>0.9218750<br>0.9218750<br>0.9921875<br>0.9218750<br>0.9218750<br>0.9218750<br>0.9218750<br>0.9218750<br>0.7109375<br>0.7109375 |
| 14                                                                     | 0.0                                                                                                                                             | 0.3828125                                                                                                                                                                                        |
| 15                                                                     | 0.4894E-01                                                                                                                                      | 0.3828125                                                                                                                                                                                        |
|                                                                        |                                                                                                                                                 |                                                                                                                                                                                                  |

#### TABLE V

# SPECTRAL ANALYSIS USING FFT FOR TRUNCATED AND NON-TRUNCATED SAMPLES CASE I SYNTHESIZER SET TO LOWEST FREQUENCY

| larmonic*       | No Truncation |                                   | 7-bit Samples |                                   | 4-bit Samples |                                   |
|-----------------|---------------|-----------------------------------|---------------|-----------------------------------|---------------|-----------------------------------|
|                 | Magnitude     | H <sub>1</sub> /H <sub>n</sub> db | Magnitude     | H <sub>1</sub> /H <sub>n</sub> db | Magnitude     | H <sub>1</sub> /H <sub>n</sub> db |
| H <sub>1</sub>  | 0.4976        | 0.0                               | 0.4968        | 0.0                               | 0.475         | 0.0                               |
| Н <sub>з</sub>  | 0.4079E-6     | 121.7                             | 0.1795E-2     | 48.8                              | 0.696E-2      | 36.7                              |
| H <sub>5</sub>  | 0.2016E-6     | 127.8                             | 0.1263E-2     | 51.9                              | 0.130E-2      | 51.3                              |
| H <sub>7</sub>  | 0.4142E-6     | 121.6                             | 0.1169E-3     | 72.6                              | 0.694E-3      | 56.7                              |
| Н <sub>е</sub>  | 0.2300E-6     | 126.7                             | 0.9601E-4     | 74.3                              | 0.569E-3      | 58.4                              |
| H <sub>11</sub> | 0.1661E-6     | 129.5                             | 0.6750E-3     | 57.3                              | 0.693E-3      | 56.7                              |
| H <sub>l3</sub> | 0.9045E-7     | 134.8                             | 0.5444E-3     | 59.2                              | 0.211E-2      | 47.0                              |
| H <sub>15</sub> | 0.4901E-1     | 20.1                              | 0.4894E-1     | 20.1                              | 0.467E-1      | 20.1                              |

\*  $H_1 = f_{10}$ .

 $f_{10}$  . The zero and even order harmonics vanish for truncated data and less than  $10^{-5}$  for non-truncated data.

ω

# TABLE VI

# SPECTRAL ANALYSIS USING FFT FOR TRUNCATED AND NON-TRUNCATED SAMPLES CASE II SYNTHESIZER SET TO FIVE TIMES LOWEST FREQUENCY

| larmonic*       | No Truncation |                      | 7-bit Samples |                      | 4-bit Samples |                      |
|-----------------|---------------|----------------------|---------------|----------------------|---------------|----------------------|
|                 | Magnitude     | H₅/H <sub>n</sub> db | Magnitude     | H₅/H <sub>n</sub> db | Magnitude     | H₅/H <sub>n</sub> db |
| H <sub>1</sub>  | 0.240E-6      | 125.3                | 0.187E-2      | 47.4                 | 0.724E-2      | 35.3                 |
| H <sub>3</sub>  | 0.532E-6      | 118.4                | 0.145E-3      | 69.6                 | 0.859E-3      | 53.8                 |
| H <sub>5</sub>  | 0.441         | 0.0                  | 0.440         | 0.0                  | 0.421         | 0.0                  |
| H <sub>7</sub>  | 0.272E-6      | 124.2                | 0.111E-2      | 52.0                 | 0.114E-2      | 51.3                 |
| Н <sub>э</sub>  | 0.182E-6      | 127.7                | 0.909E-3      | 53.7                 | 0.933E-3      | 53.1                 |
| H <sub>11</sub> | 0.236         | 5.4                  | 0.235         | 5.4                  | 0.225         | 5.4                  |
| H <sub>13</sub> | 0.183E-7      | 147.6                | 0.439E-4      | 80.0                 | 0.260E-3      | 64.2                 |
| H <sub>15</sub> | 0.417E-7      | 140.5                | 0.184E-3      | 67.6                 | 0.713E-3      | 55.4                 |

 $* H = f_{1}$ 

 $f_{10}$  . The zero and even order harmonics vanish for truncated data and less than  $10^{-5}$  for non-truncated data.

# TABLE VII

# SPECTRAL ANALYSIS USING FFT FOR TRUNCATED AND NON-TRUNCATED SAMPLES CASE III SYNTHESIZER SET TO SIX TIMES LOWEST FREQUENCY

| armonic*       | No Tru    | Incation 7-bit Samples |           | 4-bit Sa             | 4-bit Samples |                      |
|----------------|-----------|------------------------|-----------|----------------------|---------------|----------------------|
|                | Magnitude | H₃/H <sub>n</sub> db   | Magnitude | H₃/H <sub>n</sub> db | Magnitude     | H₃/H <sub>n</sub> db |
| H <sub>1</sub> | 0.545E-6  | 117.3                  | 0.433E-3  | 59.2                 | 0.566E-2      | 36.9                 |
| Н <sub>з</sub> | 0.398     | 0.0                    | 0.397     | 0.0                  | 0.397         | 0.0                  |
| H <sub>5</sub> | 0.245     | 4.2                    | 0.245     | 4.2                  | 0.233         | 4.6                  |
| H <sub>7</sub> | 0.422E-7  | 139.5                  | 0.668E-4  | 75.5                 | 0.875E-3      | 53.1                 |

\*  $H_1 = 2f_{10}$ 

| Size of Samples<br>in Bits | Output Frequency Setting   |                           |                            |  |
|----------------------------|----------------------------|---------------------------|----------------------------|--|
|                            | flo                        | 5f <sub>10</sub>          | 6f <sub>lo</sub>           |  |
| 4                          | - 36.7 (3f <sub>10</sub> ) | - 35.3 (f <sub>lo</sub> ) | - 36.9 (2f <sub>lo</sub> ) |  |
| 7                          | - 51.9 (5f <sub>lo</sub> ) | - 47.4 (f <sub>10</sub> ) | - 59.2 (2f <sub>lo</sub> ) |  |
| 31                         | -122 (3f <sub>10</sub> )   | -118 (3f <sub>10</sub> )  | -117 (2f <sub>lo</sub> )   |  |

# STRENGTH IN DB OF LARGEST UNDESIRED FREQUENCY WITHIN PASS BAND VERSUS SAMPLE SIZE

TABLE VIII

In Table VIII in-band noise frequencies were collected from Tables V, VI, and VII. In-band is defined here as coincident with the pass band of a low pass filter having a corner frequency of  $5f_{10}$ . The entry in the 4-bit row and under column  $f_{10}$  is read "the strength of the strongest noise in the pass band is -36.7 db (referred to  $f_{10}$ ) and its frequency is  $3f_{10}$ ."

Analyzing Table VIII further, for any output frequency setting the noise decreases as the sample size is increased. The 4-bit word case would fail a -40 db noise specification, while the 7-bit word would pass. The number of samples (and this goes inversely with the output frequency) seems to have no effect on in-band noise. This implies that sampling effects appear to have no bearing on word size.

Simulation at the Register Transfer Level

#### Programming Considerations

The following comments are concerned with the format and language conventions for modelling the Frequency Synthesizer.

A source program deck is composed of statement, control, and data cards. <u>Statement cards</u> provide a description of a digital process or sequence. <u>Control cards</u> specify the user's commands and options to the simulator program. <u>Data</u> cards supply values for initialization and testing. There are two types of statements: <u>configuration</u> <u>statements</u> and <u>sequence description statements</u>. The former declare the types of components to be used in the model. The latter are executable statements which define operations.

Logic operators .AND., .OR., .NOT. are used with multi-bit operands such as register contents. Incrementing by 1 is done with the .COUNT. operator.

Counters, data buses, and address lines are declared as registers. Constants and subscripts must be integers.

#### Models and Source Programs

The block diagram of Figure 7 may be considered as a tentative system configuration. We can model it in register transfer language in order to simulate operations needed for selecting a frequency and for table look-up. These test the correctness of the size of registers and adders and also indicate if a sinusoidal sequence of samples is being read out.

A flow chart (Figure 10) was drawn after studying Figure 7 and the timing charts of Figure 8, 9. The flow chart is a guide for writing the register transfer description. It is mainly used for sequence statements and need not contain configuration data.

Based on the flow chart of Figure 10 a source program was written (see Table IX for listing). The configuration statements come before the sequence description statements. Following these are the options and commands from the

42

Į.



Figure 10.

Flow Chart Used to Construct Register Transfer Description

## TABLE IX

# REGISTER TRANSFER DESCRIPTION USED AS THE SYSTEM SIMULATION PROGRAM

C "FREQUENCY SYNTHESIZER" (SIMPLIFIED MODEL) С C-C С < CUNFIGURATION STATEMENTS > C. \$SIMULATE -REGISTER. ADRS(0-6), DAC(0-6), INC(0-4), IN SIMULATE PHASE 1 STEP(0-3), CYCL(0-5), SWEEP(0-3) С SIMULATION CONTROL CARDS: C DECLARE INPUT AND ADDRESS LINES AS REGISTERS: REGISTER, IN1(0-4), ABUS(0-5) С DECODER. K(1-4) = STEP\*OUTPUT CLUCK(1)=ADRS, DAC, STEP, CYCLE, SWEEP, ABUS, INC. С \*SWITCH 1. START=UN TERMINAL, SUM = ADRS .ADD. INC \*LDAD C. MEMORY, ROM(ABUS) = ROM(0-63,0-6)IN1 = 16С SWITCH, START (ON) RUM(0-)=1,2,3,4,5,6,7,8,9,16, C CLOCK. р RUM(10-)=17,18,19,20,21,22,23,24,25,32, С С < SEQUENCE DESCRIPTIONS > RUM(20-)=33,34,35,36,37,38,39,40,41,48, C /START(ON)/ STEP=1, ADRS=0, RUM(30-)=49,50,51,52,53,54,55,56,57,64, CYCL=0, SWEEP=7, DAC=1, INC=IN1 ROM(40-)=65,66,67,68,69,70,71,72,73,80, C (ADRS REGISTER STROBE PULSE OCCURS AT K(1)\*P TIME) С ROM(50-)=81,82,83,84,85,86,87,88,89,96, C /K(I)#P/ ADRS=SUM, ROM(60-)=97,98,99,100 ABUS=ADRS(1-6), STEP=2 \*SI M 500,3 С /K(2)\*P/ DAC=ROM(ABUS), C. ADRS(0) = MSBС С IF(ADRS(0).EQ.1) THEN(STEP=3) ELSE ( STEP=1 ) ٢, /K(3)\*P/ CYCL=CYCL .COUNT., ADRS(0)=0, IF( CYCL .EQ. 14) THEN( STEP=4,CYCL=0 ) ELSE( STEP=1 ) С /K(4)\*P/ SWEEP=SWEEP .COUNT., STEP=1, INC=SWEEP, IF( SWEEP .EQ. 11) THEN ( SWEEP =1 ) С CONTROL SEQUENCE STOPS WHEN NO. OF CLOCK PERIODS SPECIFIED IN CONTROL CARD IS EXCEEDED. C

control cards and finally the values specified by data cards.

Components declared in the configuration statements of Table IX are identified as follows:

ADRS (0 - 6) signifies that ADRS is the name given to the address register in Figure 7, that it is 7 bits long, and the most significant bit is at the left end of the register (bit position 0). The input register and its input bus are named INC and IN1 respectively. (NOTE: These were declared 5 bits instead of 6 bits. The ROM was decreased to 64 words. The adder was shortened to 6 bits for proper overflow (modulo 64). These valid changes were made to simplify the model.)

ABUS is the address bus. CYCL and SWEEP are registers for simulating the cycle counter and sweep up-counter respectively.

The DECODER declaration provides sequencing and branching capabilities. The statement

#### K(1-4) = STEP

provides for four control steps. These are shown as /K (1)\*P/ through /K(4)\*P/ in the flow chart. The variable STEP assigned to decoder K takes values 1-4 from the sequence description statements and thus selects K(1) through K(4).

The TERMINAL declaration defines a variable SUM and assigns to it the sum of the contents of the registers

represented by ADRS and INC. Note that operator .ADD. is used in place of "+".

The MEMORY statement declares a ROM whose address values are taken from ABUS and contains 64 7-bit words.

The SWITCH declaration permits a start label to be used for initialization as required in Figure 10.

"CLOCK, P" defines a 1-phase clock, P. Figure 9 indicates that two clock sources are needed. CLK2 is derived from CLK1 and hence clock P is sufficient.

<u>Sequence description cards</u>. This part of Table IX corresponds 1:1 with Figure 10, the register transfer statements replacing the legends of the flow chart.

/START(ON)/ initialized registers at the start of a run to the values listed. This may be checked against the first line of the simulation printout, Table X.

The labels /K(1)\*P/ through /K(4)\*P/ have the same purpose as statement numbers in Fortran. That is, STEP=2 may cause a branch to the statement with label /K(2)\*P/at clock time. Note that the equal sign is used in STEP=2, while the operator .EQ. is used for specifying logical tests as in IF(CYCL .EQ. 14) THEN... <u>Parallel operation</u> is assumed whenever several statements are given under one label.

Near the end of Table IX we have \*SIMULATE which calls the simulator program. The next two lines are messages and do not represent control cards.

# TABLE X

SAMPLE OUTPUT FROM SYSTEM SIMULATION

#### REGISTER 1 TRANSFER 1 SIMULATION 1 PRINTOUT 1 1 . 1 TITLE: "FREQUENCY SYNTHESIZER MODEL" (FOR USER'S MANUAL) /BP/ FEB'73 SWITCH INTERRUPT STAR = ON ADPS = ...00 DAC = ..01 STEP = ...1 CYCL = ..00 SWEF = ...7 ABUS = ..00 INC = ...10 LABEL CYCLE 1 ACTIVE LABELS CLOCK TIME = 1 /K(1)\*P/ ADRS = ...10 DAC = ..01 STEP = ...2 CYCL = ..00 SWEE = ...7 ABUS = ..00 INC = ..10 LABEL CYCLE 2 ACTIVE LABELS CLOCK TIME = 2 /K(2 )\*P/ ADRS = ...10 DAC = ..01 STEP = ...1 CYCL = ..00 SWEE = ...7 - ABUS = ..00 INC = ..10 LABEL CYCLE 3 ACTIVE LABELS CLOCK TIME = 3 /K(1)\*P/ ADRS = ...20 CYCL = ...00 SWEE = ...7 ABUS = ..10 DAC = ...01 STEP = ...2 INC = ...10 \_ \_ \_ \_ \_ \_ \_ \_ \_ \_ \_ . . . . . . . . . . . LABEL CYCLE 4 ACTIVE LABELS CLOCK TIME = 4 /K(2)\*P/ ADRS = ...20 DAC = ...17 STEP = ...1 CYCL = ..00 SWEE = ...7 ABUS = ...10 INC = ...10 \_ \_ \_ \_ \_ \_ \_ \_ \_ \_ \_ LABEL CYCLE 5 ACTIVE LABELS CLOCK TIME = 5 ZKI1 ).≭PZ DAC = ...17 STEP = ...2 INC = ...10 ADRS = ...30 CYCL = ...00 SWEE = ...7 ABUS = ...20 - - - - - - - - - - - - -. . . . . . . . . LABEL CYCLE 6 ACTIVE LABELS CLOCK TIME = /K(2)\*P/ DAC = ..... STEP = ....1 CYCL = ...00 SWEE = ...7 ABUS = ...20 INC = ..10 . **.** . . . . **.** . . LABEL CYCLE 7 ACTIVE LABELS CLOCK TIME = 7 /K{1 )\*P/ ADRS = ...40 CYCL = ...00 SWEE = ...7 INC = ..10 - - - -LABEL CYCLE 8 CLOCK TIME = ACTIVE LABELS /K(2)\*P/

ADRS = ..00 DAC = ..49 STEP = ...1 CYCL = ..01 SWEE = ...7 ABUS = ..30 INC = ..10

# TABLE X (CONTINUED)

ACTIVE LABELS LABEL CYCLE 133 CLOCK TIME = 133 /K(1)\*P/ ADRS = ..40 DAC = ..33 STEP = ...2 CYCL = ..0E SWEE = ...7 ABUS = ..30 INC = ..10 ACTIVE LABELS CLOCK TIME = 134 LABEL CYCLE 134 /K(2)\*P/ ADRS = ...40 DAC = ...49 STEP = ...3 CYCL = ...0E SWEE = ...7 ABUS = ...30 INC = ...10 LARFL CYCLE 135 ACTIVE LABELS CLUCK TIME = 135 /K(3 )\*P/ ADRS = ...00 DAC = ...49 STEP = ...4 CYCL = ..00 SWEE = ...7 ABUS = ...30 INC = ...10 LABEL CYCLE 136 ACTIVE LABELS CLOCK TIME = 136 /K(4)\*P/ ADRS = ...00 DAC = ...49 STEP = ...1 CYCL = ...00 SWEE = ....8 ABUS = ...30 INC = ..07 - - - - |- - - - - -INC = ..07 LABEL CYCLE 138 ACTIVE LABELS CLOCK TIME = 138 /K(2 )\*P/ ADRS = ..07 DAC = ..01 STEP = ...1 CYCL = ..00 SWEE = ...8 ABUS = ..00 INC = ...07 \_ \_ \_ \_ \_ \_ \_ \_ \_ \_ . LABEL CYCLE 139 ACTIVE LABELS CLOCK TIME = 139 /K(1 )\*P/ ADRS = ...0E DAC = ...01 STEP = ...2 CYCL = ..00 SWEE = ...B ABUS = ...07 INC = ...07 ACTIVE LABELS CLOCK TIME = 140LABEL CYCLE 140 /K(2)\*P/ ADRS = ..0E DAC = ...08 STEP = ...1 CYCL = ...00 SWEE = ...8 ABUS = ...07 INC = ..07 ACTIVE LABELS LABEL CYCLE 141 CLOCK TIME = 141 /K(1 )\*P/ ADRS = ...15 DAC = ...08 STEP = ...2 CYCL = ...00 SWEE = ...8 ABUS = ...0E INC = ..07 CLOCK TIME = 142 LABEL CYCLE 142 ACTIVE LABELS /K(2)\*P/ ADRS = ..15 DAC = ..15 STEP = ...1 CYCL = ..00 SWEE = ...8 ABUS = ..0E INC = ..07 CLOCK TIME = 143 LABEL CYCLE 143 ACTIVE LABELS /K(1 )\*P/ ADRS = ...1C DAC = ...15 STEP = ...2 CYCL = ...00 SWEE = ...8 ABUS = ...15 CLOCK TIME = 144 LABEL CYCLE 144 ACTIVE LABELS /K(2)\*P/ ADPS = ...1C DAC = ...22 STEP = ...1 CYCL = ..00 SWEE = ...8 ABUS = ...15 INC = ..07 LARFL CYCLE 145 ACTIVE LABELS CLOCK TIME = 145 /K(1)\*P/ ADRS = ...23 DAC = ...22 STEP = ...2 CYCL = ...00 SWEE = ...8 ABUS = ...1C INC = ...07 

TABLE X (CONTINUED)

LABEL CYCLE 418 ACTIVE LABELS CLOCK TIME = 418 /K(2 )\*P/ ADRS = ...2A DAC = ...36 STEP = ...1 CYCL = ..0E SWEE = ...8 ABUS = ...23 INC = ...07 \_ \_ \_ \_ \_ \_ \_ \_ \_ \_ \_ \_ ACTIVE LABELS LABEL GYCLE 419 CLOCK TIME = 419 /K(1 )\*P/ DAC = ...36 STEP = ...2 CYCL = ..0E SWEE = ...8 ABUS = ...2A ADRS = ••31 INC = ..07 . . . . . . . . . . ACTIVE LABELS LABEL CYCLE 420 CLOCK TIME = 420/K(2 )\*P/ ADRS = ..31 DAC = ...43 STEP = ...1 CYCL = ..0E SWEF = ...8 ABUS = ..2A INC = ..07 ACTIVE LABELS CLOCK TIME = 421 LABEL CYCLE 421 /K(1 )\*P/ . . . . . . . . . . . . . . . . . . . . ACTIVE LABELS LABEL CYCLE 422 CLOCK TIME = 422 /K(2)\*P/ ADRS = ...38 DAC = ...50 STEP = ...1 CYCL = ..0E SWEE = ...8 ABUS = ...31 INC = ...07 \_ \_ \_ \_ \_ \_ \_ \_ \_ \_ \_ ACTIVE LABELS LABEL CYCLE 423 CLOCK TIME = 423/K(1 \_)\*P/ INC = ...07 ACTIVE LABELS LAREL CYCLE 424 CLOCK TIME = 424 /K(2)\*P/ 40RS = ...3F DAC = ...57 STEP = ...1 CYCL = ...0E SWEE = ...8 INC = ...07 ACTIVE LABELS LABEL CYCLE 425 CLOCK TIME = 425 /K{l }\*P/ ADRS = ...46 DAC = ...57 STEP = ...2 CYCL = ...0E SWEE = ...8 ABUS = ...3F INC = ...07 ACTIVE LARELS LABEL CYCLE 426 CLUCK TIME = 426/K(2 )\*P/ ADRS = ...46 DAC = ...64 STEP = ...3 CYCL = ...0E SWEE = ...8 ABUS = ...3F ACTIVE LABELS LAREL CYCLE 427 CLOCK TIME = 427/K(3)\*P/ 4PRS = ...6 DAC = ...64 STEP = ....6 CYCL = ...00 SWEE = ....8 ABUS = ...3F INC = ...07 ACTIVE LABELS LABEL CYCLE 428 CLOCK TIME = 428 /K(4 )\*P/ ADRS = ...06 DAC = ...64 STEP = ...1 CYCL = ...00 SWEE = ...9 ABUS = ...3F INC = ...08 ACTIVE LABELS LAREL CYCLE 429 CLOCK TIME = 429 /K(1 )\*P/ ADRS = ...OE DAC = ...64 STEP = ...2 CYCL = ...00 SWEE = ...9 ABUS = ...06 INC = ...08 \_\_\_\_\_\_\_\_\_\_ ACTIVE LABELS CLOCK TIME = 430 LABEL CYCLF 430 /K(2 )\*P/ ADRS = ...OE DAC = ...O7 STEP = ...1 CYCL = ...OO SWEE = ...9 ABUS = ...O6 INC = • • O a 

The \*OUTPUT card contains a list of variables to be printed out as in Table X. \*SWITCH initiates the operation of a manual switch. "1, START(ON)" specifies the Label Cycle before which the switch operates. In the example, "1" is supplied and any larger number N would constitute simulating a delayed operation (turn on would wait for the N-1 th Label Cycle).

\*LOAD tells the simulator to enter the constants listed. In the example, register IN1 will be initialized to 16, while the 64 ROM words are to be assigned the values listed. Thus "ROM(0-)=1,2,3...." means that address 0 will contain a 1, etc. The values in the example are not sine wave samples for simplicity but were chosen to force decimal digits to be printed for DAC.

"\*SIM 500,3" is the last card and specifies that the simulation shall run for 500 Label Cycles. The 3 specifies that simulation would stop if in any three consecutive Label Cycles, the same group of labels were activated. This feature prevents "infinite loops" from wasting computer time and paper.

#### Simulation Results

Table X shows three of the five pages of results printed out after executing the source program. To verify the model, the contents of registers and other components at certain clock times are obtained from the table. (For compactness register values are printed in <u>hexadecimal</u>.

Thus in the row marked Label Cycle 1 of Table X, INC contains the initial value 10 which is 16 in decimal.)

By examining a few values in each column of the printout one may be able to determine if the flow chart of Figure 10 was followed. If it was, then the printout is assumed valid and further analysis may be done. Proceeding with the address register ADRS, a new value should come every /K(1)\*P/ time. This is seen in every row where /K(1)\*P/ is active, e.g. Label Cycles 1,3,5 and so on. It is clear that the contents of INC are being transferred and accumulated in ADRS. Label Cycles 136 and 428 depict the condition when INC changes value. The effect on ADRS may be seen in the next clock period.

The time series of samples are represented by the DAC sequence. Updating occurs at /K(2)\*P/ as may be seen in Label Cycle 2. Label Cycle 128 shows that the DAC sequence is cyclic. This is due to the address sequence being cyclic also (modulo 64). (DAC numbers are read as decimal due to the way the ROM words were initialized.)

CYCL is incremented at Label Cycles 9 and 135 for the pages included in Table X. In each case the DAC values show that the end of a cycle occurred. In Label Cycle 427, after counting to 14, CYCL is reset to zero as required.

Simulation of the sweep mode is shown partially at Labels 136 and 428. Here the active label is /K(4)\*P/. INC replaces its previously constant value with 07 in Label

Cycle 136, while it is incremented by 1 in Label Cycle 428. The latter cycle indicates the start of the "frequency sweep" action required in this mode.

### CHAPTER IV

# SYNCHRONOUS LOGIC DESIGN

In this chapter we use CAD Programs to design the non-standard functions of the digital frequency synthesizer discussed in Chapter III. These functions are the synchronization indicator, frequency sweep up-counter, and cycle counter.

All the examples to be discussed are used to implement the non-standard functions. In practice they would be assembled from gate level components known in the industry as small scale integrated (SSI) circuits. The other functional blocks in the system block diagram may be conveniently built from pre-designed medium scale integrated (MSI) circuits.

#### Input Formats

The set of punched cards needed to input a state diagram's data to the Sequential Logic Synthesis Program consists of a title card, node/transition cards (one per state), \*STATES card, state assignment cards (one per state), and an "end" card containing a single \*. They must be submitted in that order.

The title card contains in columns 6-45 any text for identifying the printout.

A node/transition card has three fields which are used as follows: column 1-16 for the name of a node, column 21-36 for successor node name, column 41-80 for the transition signal or a Boolean expression of several signals.

The \*STATES card marks the beginning of the state assignment cards.

A state assignment card has two fields for defining the binary code assigned to a node. The octal equivalent of the code is punched in column 1-2, while column 21-36 is for the name of the node involved.

In the case of program LOGICMIN, one card is punched for each row of a truth table. The first card of a set specifies the number of input variables (columns 2-5) and also serves as a title card (columns 6-45 for text). The number of outputs is not declared.

The format of the truth table data card is as follows:

# INPUT STATE/OUTPUT STATE

For a 4-variable problem for example, 12/-01 denotes a row of the truth table with the inputs (W,X,Y,Z)=1100 and outputs (F1,F2,F3)=-01. A second format option allows coding the input n-tuple in octal for rows with minterms, and binary-dash notation for rows with <u>don't cares</u>. The output is always in binary-dash.

## Control Logic Design Example

The synchronization indicator of the Frequency Synthesizer detects synchronism between an external signal and CLK2 (see Figure 7). Its output may be used to stop the frequency sweep up-counter. Introduced in Chapter II, its state diagram (Figure 2) and schematic (Figure 4) are found therein.

As shown in Appendix A the printout from the Synchronous Logic Synthesis Program includes a record of the state diagram data submitted. In this regard the clock signal is implicit and is not AND-ed with the input variable X. Note that because of the <u>don't care</u> condition for the S7 to S1 transition, Line 12 of the present example does not have an input signal.

The second page of the printout contains the JKFF input equations from which the logic schematic of Figure 4 was drawn. A small table labelled "Input Summary" is provided for documentation.

The output gating expression was minimized by LOGICMIN. The four data cards which encoded the truth table were punched as 4/1, 3/2, 2/1, 1/1. The output expression returned by the program was

 $F1 = \overline{A}BC + \overline{A}C + \overline{A}B.$ 

#### Shift Registers

The shift register in this example is a pattern generator. It shifts out a pattern used to test the synchronization indicator. As such it may be included in the actual hardware as a built in test signal source.

The circuit shown in Figure 11 was designed for RSFF type. The front-end JKFF was therefore provided with an inverter. This circuit resulted from coding the state transition table as a 5-variable single-output gating function and then submitted to LOGICMIN.

# Counters

The CYCL counter divides its clock pulses by 14,28,42, or 56 depending on a 2-bit control word. Instead of being designed as a single counter with six JKFF's, it was partitioned into a variable-modulo ( $\div$  2, 4, 6, 8) counter and a  $\div$  7 counter. Because the former is basically a binary counter the pair may have fewer gates than a single nonbinary counter. Further the small counters may be used separately as building blocks.

The frequency sweep up-counter supplies the values 7, 8, 9, 10, 11, 7, .... in binary to an accumulator. A modulo-5 counter and output gating may be used.

#### Variable-Modulo

With input variables V, W selection of a modulo is depicted in Figure 12. The printout of results is included



Figure 11. Shift Register for Testing Synchronization Indicator



Figure 12. State Diagram Specifying Variable Modulo Counter



Figure 13. Synchronous Variable Modulo Counter Logic Diagram Drawn from Equations Generated by CAD Program

in Appendix A starting with the third page. In this page the state diagram data from Figure 12 is shown along with state assignments. The fourth page gives the design equations for the counter of Figure 13.

The output gating is just one 3-input NAND gate whose output is used as the clock for the ÷ 7 counter (not shown in Figure 13). The inputs of the NAND gate go 1:1 with the complimented outputs of the JKFF.

#### Divide-by-7

Figure 14 is a state diagram with nodes labelled according to the state assignment. This assignment produced the equations

$$J_{A} = \overline{B}\overline{C} = K_{A}$$
$$J_{B} = \overline{C} = K_{B}$$
$$J_{C} = A + B$$
$$K_{C} = 1.$$

The logic diagram for the above equations is shown in Figure 15. The output is taken directly from the flip-flop FFA.

#### Modulo 5

Given the state diagram of Figure 16 the program generated the equations







Figure 15. Divide-by-7 Counter Obtained from CAD Equations



Figure 16.

State Assignment for Modulo-5 Counter Used in Frequency Sweep Logic



Figure 17. Modulo-5 Counter with No Latch Up States  $J_{A} = K_{A} = \overline{B}\overline{C}$  $J_{B} = A\overline{C}$  $K_{B} = \overline{C}$  $J_{C} = A + B$  $K_{C} = 1.$ 

Figure 17 is the logic diagram of a counter drawn from the above equations. This counter has no latch up states because there is always a next state for any present state. This is in contrast with designs where an unused state could be entered due to noise.

#### <u>Output Gating</u>

The output gating of the modulo-5 counter must encode the 3-bit internal state into 4-bit words. This makes it into a frequency sweep up-counter.

The truth table of the output gating is given in the second page of Appendix B. Two solutions from a set of six are included in the third page. The literals XYZ correspond to ABC in Figure 18 where the two solutions have been drawn as logic diagrams.

Part (a) of Figure 18 differs from part (b) in number of input lines, gate count, and size of gates. The first solution has fewer input lines and gates than the second. However the second uses mostly 2-input gates compared to mostly 3-input and one 4-input gate for the first. In other words the solutions are based on two different cost



a.) Minimized with Respect to Type 1 Criterion





Figure 18. Frequency Sweep Output Gating Obtained from Multiple Output Prime Implicants

criteria, and the user selects the one which applies to the problem at hand.

If the gating were a single-output function the printout from LOGICMIN would be in the form shown in the last page of Appendix B.

#### State Assignment

Because the state assignment can be easily changed and a number of these trials submitted at the same time, the Synchronous Logic Synthesis Program may be used to search for improved assignments. Since evaluation is by inspection (compare equations of each solution) the number of trials will be finite. This number (and the speed involved) is still large in comparison with what one gets by paper and pencil methods.

An example of how a cluster of possible trials may develop in state assignment may be made by considering the rule:

> Two or more states having the same state for a given input state should be made adjacent.

In practice, for the medium size design range of 4 - 7 FF's with 2 or 3 input signals one may see several nodes of a state diagram where the rule may be applied, and dozens of ways to make the affected pairs (or sets) of states adjacent.

## CHAPTER V

## COMPUTER PROGRAM DOCUMENTATION

Three programs were implemented in this study: Synchronous Logic Synthesis, LOGICMIN, and Register Transfer Simulator. Because most of the programming effort was invested in it and due to space requirements, only the synthesis program and related routines have been listed.

Synchronous Logic Synthesis Program

The flow chart of this program is depicted in Figure 19. Appendix C contains the listing. This version is in Fortran IV and ran on the IBM 360/65. The flow chart and listing refer to certain techniques and data structures used in another program (see below).

Asynchronous Logic Synthesis Program

This program was based on the so-called Cube Logic Technique of Senders and Lucchesi [12]. The flow chart of Figure 20 is quite detailed and displays statement numbers used in the program (Appendix D). These items are supplementary to Appendix C.





Figure 20. Flow Chart of Asynchronous Logic Synthesis Program



Figure 20. (Continued)

### CHAPTER VI

### SUMMARY AND CONCLUSIONS.

### Summary

This study was concerned with implementing a set of programs applicable for the computer-aided design (CAD) of small digital systems. Three areas of design for which CAD tools were desired are system level, gate level, and nondigital aspects. The thesis summarizes (1) approaches used to implement programs that were not available (2) a methodology for using these and existing programs (3) application of the method and programs in designing a digital frequency synthesizer.

Programs were written for the synthesis of a synchronous sequential circuit specified by its state diagram. A register transfer simulator program was also implemented. Gate level simulators and programs for servicing non-digital aspects are available commercially. With the digital frequency synthesizer as a case study it was found that the programs can assist the designer in synthesis of non-standard functions, verifying designs by simulation, and in dealing with analog oriented problems.

### Recommendations for Further Study

Synthesis techniques at the system level seem to be non-existent. As an extension of the register transfer concept and using a design language, it should be possible to devise a synthesis procedure which operates on register transfer modules.

There appears to be an absence of efficient algorithms for flow table reduction and state assignment. Consequently the logic synthesis program can be improved if automatic state minimization and optimal assignment capabilities were added.

### A SELECTED BIBLIOGRAPHY

- (1) Duley, J. and Dietmeyer. "Translation of DDL Digital System Specification to Boolean Equations." <u>IEEE Trans. Comput.</u>, Vol. C-18 (1969), 305-313.
- (2) Baray, M. B., S. Y. Su, and R. Carberry. "The Structure and Operation of a Design Language Simulator." <u>Proceedings of the 8th Annual Design Automation</u> <u>Workshop</u>, Atlantic City, N. J.; 1971.
- (3) Chu, Y. <u>Introduction to Computer Organization</u>. Englewood Cliffs, N. J.: Prentice-Hall, Inc., 1970.
- (4) Friedman, A. and P. Menon. "Restricted Checking Sequences for Sequential Machines." <u>IEEE Trans</u>. Comput., Vol. C-22 (1973), 397-399.
- (5) Givone, D. <u>Introduction to Switching Circuit Theory</u>. New York: McGraw-Hill; 1970, pp. 402-436.
- (6) Story, J., H. Harrison, and E. Reinhard. "Optimum State Assignment for Synchronous Sequential Circuits." <u>IEEE Trans</u>. <u>Comput</u>., Vol. C-21 (1972), 1365-1373.
- (7) LOGSIM User's Manual. 525 Univ. Ave. Palo Alto, Cal.: Tyme-share Inc., 1971.
- (8) Givone, D. <u>Introduction to Switching Circuit Theory</u>. New York: McGraw-Hill; 1970, pp. 181-194.
- (9) Basore, B. L. <u>The Fast Fourier Transform</u>: <u>Speed from</u> <u>Cyclic Repetition</u>. <u>ARO Monograph Project</u>, College of Engineering, Oklahoma State University, (1970).
- (10) MATCH: Applicon's Optimizing Filter Synthesis Program. 83 Second Ave. Burlington, Mass.: Applicon Inc., 1972.
- (11) Tierney, J., et al. "A Digital Frequency Synthesizer." in <u>Digital Signal Processing</u> (Rabiner, L., ed.). New York: IEEE Press; 1972.
- (12) Senders, S. and J. Lucchesi. "Design of Sequential Switching Circuits with the Cube Logic Technique." <u>Computer</u> <u>Design</u>, Vol. 10 (1971), 59-64.

## APPENDIX A

## SAMPLE INPUT CODING AND PROGRAM PRINTOUT: SYNCHRONIZATION INDICATOR AND VARIABLE MODULO COUNTER

"SYNCHRONISM INDICATOR" LOGIC (J-K FF'S TIME= 21.23.45 DATE= 73.135

INPUT DATA

| 1   | FROM= | S 0 | T0=   | 51  | INPUT | SIGNALS=  | x          |
|-----|-------|-----|-------|-----|-------|-----------|------------|
| 2   | FROM= | S 1 | TO≃   | S2  | INPUT | SIGNALS=  | X          |
| 3   | FROM= | S1  | • TO= | \$3 | INPUT | SIGNALS=  | <b>¬</b> X |
| . 4 | FROM= | S2  | 10=   | \$3 | INPUT | SIGNALS = | ۰X         |
| 5   | FROM= | S 3 | TO≃   | S4  | INPUT | SIGNALS=  | X          |
| 6   | FROM≖ | S4  | TO=   | 53  | INPUT | SIGNALS=  | X          |
| 7   | FROM= | S4  | T 0=  | \$5 | INPUT | SIGNALS=  | ٦X         |
| 8   | FROM= | S 5 | T0=   | \$3 | INPUT | SIGNALS≖  | ¬X         |
| 9   | FROM= | S5  | T0=   | 56  | INPUT | SIGNALS = | X          |
| 10  | FROM= | S6  | TO=   | \$3 | INPUT | SIGNALS≖  | X          |
| 11  | FROM= | 56  | T0=   | S 0 | INPUT | SIGNALS = | ۰X         |
| 12  | FROM= | 57  | T0=   | S1  | INPUT | SIGNALS=  |            |
|     |       |     |       |     |       |           |            |

\*STATE

#### INPUT SUMMARY

- 3 J/K FLIP-FLOPS REQUIRED
- 12 INPUT FRUM-TO CARDS
- 8 STATE-FLOW NUDES
- I INPUT SIGNAL VARIABLES

|   | NODE NAME | ASSIGNED STATE |
|---|-----------|----------------|
| 1 | so        | 000 (-A-B-C)   |
| 2 | S1        | 110 (AB-C)     |
| 3 | S2        | 101 (A-BC)     |
| 4 | 53        | 100 (A-8-C)    |
| 5 | S4        | 011 (¬ABC)     |
| 6 | \$5       | 010 (¬A8¬C)    |
| 7 | 56        | 001 (-A-BC)    |
| 8 | \$7       | 111 (ABC)      |

#### INPUT VARIABLES

| x                                           |                 |          |   |
|---------------------------------------------|-----------------|----------|---|
| J/K FL1P FL<br>-001<br>-111<br>-100<br>-011 |                 | EQUATION | 1 |
| JA = B¬C¬X<br>-100                          | + ¬BX +<br>−0−1 | -        |   |
| J/K FLIP FL<br>-001                         | OP 1            | EQUATION | 2 |
| KA = ¬B¬CX<br>-001                          |                 |          |   |
| J/K FLIP FL<br>0-01<br>1-01                 | 0P 2            | EQUATION | 1 |
| JB = ¬CX<br>01                              |                 |          |   |
| J/K FLIP FL<br>1-01<br>1-00<br>0-11<br>0-00 | OP 2            | EQUATION | 2 |

0-00 0-01

| KB = -AX + -C<br>010                                        | -   |          |   |
|-------------------------------------------------------------|-----|----------|---|
| J/K FLIP FLOP<br>11-1<br>10-1<br>01-1                       | 3   | EQUATION | 1 |
| JC = AX + BX $1 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1$          | 1   |          |   |
| J/K FLIP FLOP<br>10-0<br>01-1<br>01-0<br>00-1<br>00-0<br>11 | 3   | EQUATION | 2 |
| KC = -X + -A<br>0 0                                         | + B | 1        |   |

"VARIARES HODDLD COUNTER"

### TIME= 23.45.53 DATE= 73.135

INPUT: DATA

| 1   | FRCM≠  | V-M O | T0=    | VM1 | INPUT     | SIGNALS=  | -VW  |
|-----|--------|-------|--------|-----|-----------|-----------|------|
| 2   | [FP]M≃ | VMO   | T0=    | VM3 | INPUT     | SIGNALS=  | -v.₩ |
| 3   | ⊂Ri}M= | V M O | T0=    | VM5 | INPUT     | SIGNALS=  | VW   |
| 4   | FROM≢  | VMO   | TO=    | VM7 | INPUT     | SIGNALS=  | V.W  |
| 5   | FPNM=  | V M 7 | T()=   | VM6 | INPUT     | SIGNALS=  |      |
| 5.  | FROM=  | V 146 | TO=    | VM5 | INPUT     | SIGNALS=  | •    |
| 7   | FRI)M= | V M 5 | T () = | VM4 | INPUT     | SIGNALS=  |      |
| . 3 | FROM=  | V M 4 | TO=    | VM3 | INPUT     | SIGNALS=  |      |
| 9   | FRIM=  | V M 3 | TU=    | VM2 | INPUT     | SIGNALS=  |      |
| 1)  | FROM=  | V M 2 | T()=   | VM1 | <br>INPUT | SIGNALS = |      |
| 11  | FROM=  | VML   | 10=    | VMO | INPUT     | SIGNALS=  |      |
|     |        |       |        |     |           |           |      |

#### \*STATES

| ASSIGNED<br>ASSIGNED<br>ASSIGNED<br>ASSIGNED<br>ASSIGNED<br>ASSIGNED<br>ASSIGNED | STATE (OCTAL) =<br>STATE (OCTAL) =<br>STATE (OCTAL) =<br>STATE (OCTAL) =<br>STATE (OCTAL) =<br>STATE (OCTAL) =<br>STATE (OCTAL) = | 4<br>2<br>6<br>1<br>5<br>3 | NODE<br>NODE<br>NODE<br>NODE<br>NODE<br>NODE | NAME<br>NAME<br>NAME<br>NAME<br>NAME<br>NAME<br>NAME | * * * * * | VM1<br>VM2<br>VM3<br>VM4<br>VM5<br>VM6 |
|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|----------------------------|----------------------------------------------|------------------------------------------------------|-----------|----------------------------------------|
| ASSIGNED                                                                         | STATE (OCTAL) =                                                                                                                   | 7                          | NODE                                         | NAME                                                 | Ē         | VM7                                    |

#### INPUT SUMMARY

- 3 J/K FLTP-FLOPS REQUIRED
- 11 INPUT FROM-TO CARDS
- 8 STATE-FLOW NODES
- 2 INPUT SIGNAL VARIABLES

|     | NODE NAME | ASSIGNED STATE |
|-----|-----------|----------------|
| 1   | VMO       | 000 (-A-8-C)   |
| . 2 | V41       | 100 (A-B-C)    |
| 3   | VM3       | 110 (AB-C)     |
| 4   | V 15      | 101 (A-BC)     |
| 5   | VM7       | 111 (ABC)      |
| 6   | V 16      | 011 (¬ABC)     |
| 7   | V 14      | 001 (-A-BC)    |
| 8   | V 12      | 010 (-AB-C)    |

INPUT VARIABLES

| v             |    |          |   |                       |
|---------------|----|----------|---|-----------------------|
|               |    |          |   |                       |
| W             |    |          |   | 01 0                  |
| J/K FLIP FLOP | 1  | EQUATION | 1 | J/K FLIP FLOP         |
| -0000         |    |          |   | 0-1                   |
| -0001         |    |          |   | 0-1                   |
| -0010         |    |          |   | 0=0==                 |
| -0011         |    |          |   | KB = ⊣A               |
| -11           |    |          |   |                       |
| -             |    |          |   | 0                     |
| -01           |    |          |   |                       |
| -10           |    |          |   | JZK FLIP FLOP         |
|               |    |          |   | 00-10                 |
| JA = 1        |    |          |   | 00-11                 |
|               |    |          |   |                       |
|               |    |          |   | $JC = \neg A \neg RV$ |
| J/K FLIP FLOP | 1  | EQUATION | 2 | 00-1-                 |
| -11           |    |          |   | <b>•••</b>            |
| -01           |    |          |   | J/K FLTP FLOP         |
| -10           |    |          |   | 00                    |
| -00           |    |          |   | 00                    |
|               |    |          |   | KC = ¬A¬B             |
| κA = 1        |    |          |   | 00                    |
|               |    |          |   | 00                    |
|               |    |          |   |                       |
| J/K FLIP FLOP | 2  | EQUATION | 1 |                       |
| 0-001         |    |          |   |                       |
| 0-011         |    |          |   |                       |
| 0-1           |    |          |   |                       |
| · -           |    | 1        |   |                       |
| JB =          | ٩C |          |   |                       |

0~1--

· 3

2

.

3 EQUATION 1

EQUATION 2

FQUATION 2

JB = -4W + -4C

## APPENDIX B

## SPECIMEN PROGRAM OUTPUTS FROM LOGICMIN

#### PROGRAM LOGICMIN

THIS PROGRAM FINDS THE SINGLE OR MULTIPLE-OUTPUT MINIMAL SUMS GIVEN THE INPUT MINTERMS OF A SUM OF BOOLEAN PRODUCTS AND THE CORRESPONDING DUTPUT STATES. DON'T CARE STATES ARE ALLOWED AND ARE REPRESENTED BY A DASH '-'.

INPUT TO THE PROGRAM HAS THE FOLLOWING FORMAT FOR THE PUNCHED CARDS.

DECIMAL EQUIVALENT OF MINTERM / FUNCTION OUTPUT STATES

#### EXAMPLE.

| I NI<br>V AF |   |   | LES |   | 001 | PUT | STATES |  | CARDS | PUNCHE | )       |
|--------------|---|---|-----|---|-----|-----|--------|--|-------|--------|---------|
| W            | X | Y | Z   | 1 | F1  | F2  | F3     |  | 4     | (PRD8. | [DENT.] |
| 0            | 0 | 1 | 0   | 1 | -   | 0   | 1      |  | 2/-01 |        |         |
| 1            | 1 | 0 | 0   | 1 | 0   | 0   | 1      |  | 12/00 | 1      |         |
|              |   |   |     |   |     |     |        |  | *     |        |         |

WHERF O REPRESENTS A COMPLEMENTED VARIABLE 1 REPRESENTS AN UNCOMPLEMENTED VARIABLE - REPRESENTS DON'T CARE

#### A MAXIMUM OF 32 INPUT VARIABLES AND 32 OUTPUTS ALLOWED

THE FIRST CARD FOR EACH PROBLEM MUST CONTAIN THE FOLLOWING CC 2-5 THE NUMBER OF INPUT VARIABLES CC 6-45 A PROBLEM IDENTIFICATION

OUTPUT FROM THE PROGRAM CONSISTS OF THE FOLLOWING

1. FOR SINGLE OUTPUT PROBLEMS A. A LIST OF THE PRIME IMPLICANTS B. PRIME IMPLICANT TABLE (NOT NECESSARILY FREE FROM HAZARDS) C. PRIME IMPLICANT TABLE FOR HAZARD FREE DESIGNS

- D. THE POSSIBLE MINIMAL SUMS BASED ON TABLE B.

2. FUR MULTIPLE-OUTPUT PROBLEMS

A. A LIST OF THE PRIME IMPLICANTS AND THE OUTPUT FUNCTIONS IMPLIED B. THE POSSIBLE MINIMAL SUMS (NOT NECESSARILY HAZARD-FREE) I. MINIMAL SUMS FROM MULTIPLE-OUTPUT PRIME IMPLICANTS II. MINIMAL SUMS AFTER ADDITIONAL MINIMIZATION OF EACH OUTPUT FUNCTION

RAMP GEN. GATING #3

#### CARD INPUT

| 0/0111 |  |
|--------|--|
| 1/1000 |  |
| 2/1001 |  |
| 3/1010 |  |
| 4/1011 |  |

## RAMP GER. GATING #3

### INPUT MINTERMS / HULTIPLE-FUNCTION

| *: | W | X | Y | 1 | ç | F | F | F  |  |
|----|---|---|---|---|---|---|---|----|--|
|    |   |   |   |   | 1 | ? | ٦ | 4  |  |
| t  | 0 | υ | 0 | 1 | 0 | 1 | ı | I. |  |
| 2  | 0 | 0 | 1 | 1 | 1 | υ | 0 | 0  |  |
| .3 | 0 | 1 | 0 | 1 | l | υ | 0 | l  |  |
| 4  | Э | 1 | 1 | 1 | 1 | 0 | 1 | 3  |  |
| 5  | 1 | ) | 0 | 7 | 1 | U | t | 1  |  |
|    |   |   |   |   |   |   |   |    |  |

#### RAMP GEN. GATING #3

#### PRIME IMPLICANTS / DUTPUT FUNCTION'S IMPLIED

|   | W | x | Y | 1 | F<br>1 | F<br>2 |          |   |  |
|---|---|---|---|---|--------|--------|----------|---|--|
| 1 | 0 | 0 | 0 | 1 | 0      | 1      | 1        | 1 |  |
| 2 | 0 | 1 | 0 | 1 | 1      | 0      | 0        | 1 |  |
| 3 | 0 | 1 | 1 | 1 | 1      | 0      | 1        | 0 |  |
| 4 | 1 | 0 | 0 | 1 | 1      | 0      | 1        | 1 |  |
| 5 | 0 | - | 0 | 1 | -      | -      | -        | 1 |  |
| 6 | - | 0 | 0 | 1 | -      | -      | 1        | 1 |  |
| 7 | 0 | - | 1 | 1 | 1      | -      | -        | - |  |
| 8 | 0 | 1 | - | 1 | 1      | -      | <u> </u> | - |  |

ł

```
SOLUTION NUMBER 1
                          RAMP GEN. GATING #3
I. MINIMAL SUMS FROM MULTIPLE-DUTPUT PRIME IMPLICANTS
     WITH RESPECT TO SEVERAL CRITERIA
P-FUNCTION TERM EXPANDED = 1 2 3 4 7
F 1 = -WX-Y + -WXY + W-X-Y + -WY
            011 100 0-1
      010
F 2 = -W-X-Y
      000
F = 3 = \neg W \neg X \neg Y + \neg W X Y + W \neg X \neg Y
     . 000
             011 100
000 010 100
CROSS REFERENCE MINIMAL SUM MINTERMS WITH FUNCTION USAGE
MINTERMS
               FUNCTION CROSS REFERENCE
       1 4
010
01 İ
       1 3
100
       1
          74
0-1
       l
      2 3 4
000
II. MINIMAL SUMS AFTER ADDITIONAL MINIMIZATION OF EACH OUTPUT FUNCTION
F 1 = W \neg X \neg Y + \neg WY + \neg WX 
100 0-1 01-
      100
F 2 = -++-X-Y
     000
F 3 = \neg \forall XY + \neg X \neg Y
      011 -00
F 4 = \neg W \neg Y + \neg X \neg Y
      0-0
            -00
```

CROSS REFERENCE MINIMAL SUM MINTERMS WITH FUNCTION USAGE

| AINTE | RMS |   | FUNCTION CROSS REFERENCE |
|-------|-----|---|--------------------------|
| 100   | 1   |   | 0-0 4                    |
| 0-1   | 1   |   |                          |
| -11-  | 1   |   |                          |
| )00   | 2   |   |                          |
| 111   | 3   |   |                          |
| - 0 0 | 3   | 4 |                          |

#### EX-OR TEST 3

PRIME IMPLICANTS / OUTPUT FUNCTIONS IMPLIED

|   | W | x | Y | Z | 1 | F<br>1 |  |
|---|---|---|---|---|---|--------|--|
| 1 | 0 | 0 | 0 | 1 | 1 | 1      |  |
| 2 | 0 | 0 | 1 | 0 | 1 | 1      |  |
| 3 | 0 | 1 | 0 | 0 | 1 | 1      |  |
| 4 | 1 | 0 | 0 | 0 | 1 | 1      |  |

SOLUTION NUMBER 1 EX-OR TEST 3 I. MINIMAL SUMS FROM SINGLE-OUTPUT PRIME IMPLICANTS WITH RESPECT TO SEVERAL CRITERIA

P-FUNCTION TERM EXPANDED = 1 2 3 4

F 1 = ¬₩¬X¬YZ + ¬₩¬XY¬Z + ¬₩X¬Y¬Z + ₩¬X¬Y¬Z 0001 0010 0100 1000

PRIME IMPLICANT TABLE FOR EX-OR TEST 3

MINTERMS PRIME IMPLICANTS (LESS D.C.) 1 2 3 4

| 2001 | X |
|------|---|
| 0010 | X |
| 0100 | × |
| 1000 | x |

PRIME IMPLICANT TABLE FOR EX-OR TEST 3

THIS TABLE FOR HAZARD FREE GATING

MINTERMS PRIME IMPLICANTS (LESS D.C.) 1 2 3 4

> × . . × × × ×

0001

0010

0100

1000

 $\infty$ 

# DESIGN PROGRAM

APPENDIX C

## COMPUTER LISTING OF SYNCHRONOUS LOGIC

С THIS PROGRAM IS FOR SYNTHESIS OF SYNCHRONOUS DIGITAL CIRCUITS USING J/K FKIP FLUPS. THE GENERATED CIRCUIT EQUATIONS ARE MINIMIZED IN A COMBINATORIAL SENSE TO ARRIVE AT MINIMUM GATING. C С С INPUT TO THE PROGRAM IS BY PUNCHED CARDS AND HAS THE FOLLOWING C C FORMAT. С CONTENTS С CAPD CARD COL. 0000 6-45 ANY DESIRED PROBLEM TITLE 1 FROM NODE NAME OF STATE-FLOW FROM-TO TO NODE NAME OF STATE-FLOW FROM-TO 1-16 2 С 21-36 С 41-80 A BOOLEAN EXPRESSION FOR THE INPUT SIGNALS THAT CAUSES THE FROM-TO TRANSITION (THIS FIELD MAY BE 00000 BLANK.] REPEAT TYPE 2 CARDS UNTIL STATE-FLOW FROM-TO'S ALL DESCRIBED 3 N 1-7 \*STATES С N+1 1-20 THE INTERNAL FLIP FLOP STATE FOR THIS NODE. THIS NUMBER IS IN OCTAL. (EX. A-BCD IN LITERAL FORM = 1011 IN BINARY FORM = 13 IN OCTAL FORM.) С Ċ С 21-36 NUDE NAME FOR THIS STATE-FLOW NODE. REPEAT AS REQUIRED. N+2 (MARKS END OF A PROBLEM. ADDITIONAL PROBLEMS MAY BE STACKED FULLOWING: \*) M 1 × A MAXIMUM OF 32 FLIP FLOPS + INPUT VARIABLES ARE ALLOWED. OUTPUT CONSISTS OF AN INPUT SUMMARY AND THE MINIMIZED J.K. CIRCUIT EQUATIONS. STATE DIAGRAM OF EXAMPLE -v.w) \*\*\* \*N2\* \*N5\* \*N6\* ×N0≭ \*N1\* \*N3\*4 \*N4\* \*N7\* C. \*\*\*\* \*\*\*\* \*\*\*\* \*\*\*\* \*\*\* \*\*\*\* \*\*\*\* \*\*\*\*

C С

С

000

С c

0000000

00000000

с с

| FORTRAN IV G LEVE | L 21     |              | MAIN        |                | ĐAT      | E = 731  | 35 .     | 21/16      | 5/38 |
|-------------------|----------|--------------|-------------|----------------|----------|----------|----------|------------|------|
| C<br>C            | 000 1    | 00 010       | 110         | 001            | 101      | 011      | 111      | INTERNAL   |      |
| C<br>C            | 0 4      | z            | ,           |                | e        |          | -        | STATE      |      |
| c c               | U 4      | · . Z        | 6           | 1              | 5        | 3        | 7        | (OCTAL)    |      |
| č                 |          |              |             |                |          |          |          |            |      |
| c.                |          |              |             |                |          |          |          |            |      |
| С                 | INPUT    | CARDS FOR    | EXAMPLE     | (CARD          | COLUMNS  | FOLLOW   | }        |            |      |
| с                 |          | 1 1          | 22          | 3              | 3 4      |          |          |            |      |
| , ç               | 16       | 16           | 16          | 1              | 6 1      |          |          |            |      |
| С                 |          |              |             |                |          |          |          |            |      |
| . C               |          | LE PROBLEM   | -           |                |          |          |          |            |      |
| C                 | NO       |              | N1          |                |          | •        |          |            |      |
| C<br>C            | NO       |              | N3          |                |          | • W      |          |            |      |
| C C               | N0<br>N0 |              | N5<br>N7    |                | v.<br>v. |          |          |            |      |
| C                 | N7       |              | N6          |                | ۷.       | *        |          |            |      |
| · C               | N6       |              | N5          |                |          |          |          |            |      |
| c                 | N5       |              | N4          |                |          |          |          |            |      |
| c                 | N4       |              | N3          |                |          |          |          |            |      |
| č                 | N3       |              | N2          |                |          |          |          |            |      |
| č                 | N2       |              | NI          |                |          |          |          |            |      |
| č                 | N1       |              | NO          |                |          |          |          |            |      |
| č                 | *STATES  |              | 10          |                |          |          |          |            |      |
| c                 | 0        |              | NO          |                |          |          |          |            |      |
| Ċ                 | 4        |              | N1          |                |          |          |          |            |      |
| С                 | 2,       |              | N2          |                |          |          |          |            |      |
| c                 | 6        |              | Ň3          |                |          |          |          |            |      |
| c                 | 1        |              | N4          |                |          |          |          |            |      |
| C.                | 5        |              | N5          |                |          |          |          |            |      |
| c                 | 3        |              | N6          |                |          |          |          |            |      |
| C                 | 7        |              | N7          |                |          |          |          |            |      |
| с                 | *        |              |             |                |          |          |          |            |      |
| С                 |          | •            |             |                |          |          |          |            |      |
| C                 | 8.       | PERALTA D    | PT 522      | MARCH          | 73       | 49137    | - 2      |            |      |
| C                 |          |              |             |                |          |          |          |            |      |
| ç                 |          |              |             |                |          |          |          |            |      |
| C<br>C            | PRIUR P  |              | 11384 - C   |                |          |          |          |            |      |
| C C               |          |              | 11539 - L   | UGICMIN        |          |          |          |            |      |
| 0001              | LOGICAL  | LCON         |             |                |          |          |          |            |      |
| 0001              |          | SIGLEN, K    | -           | . <u>колта</u> | (16) K   |          | <b>1</b> |            |      |
| 0003              |          | N KARD(80)   | ()) Kat 107 | , KKUI-J       | (1077 N  | NU310(4  |          |            |      |
| 0004              | EQUIVALE |              | (1), KRDFR  | M(1)).         |          | 11. 6901 |          |            |      |
|                   |          | (41), KRDS I |             |                | (NAROTZ  |          |          |            |      |
| 0005              |          | OSTRNG(80)   |             | 4.32).         | LENFQ(1  | 28)      |          |            |      |
| 0006              |          | WORK(132)    | , 1131-101  |                |          |          |          |            |      |
|                   |          |              |             |                |          |          |          |            |      |
| 0107              | DIMENSIO | N NODNAM (-  | 4,128), N   | XFROM(1        | 281. NX  | TO(128)  | NXS:     | [G(40,128) |      |

| FORTRAN | IV G | LEVEL     | 21                 | MAIN                         | DATE =         | 73135      | 21/16/38    |
|---------|------|-----------|--------------------|------------------------------|----------------|------------|-------------|
| 0008    |      | ·         | DIMENSIO           | N NODE(128), JTERMO(12       | 8), JTERMD(128 | )          |             |
| 0.009   |      |           | OIMENSIO           | N. JEUNO(128), JEUND(12      | 28), [EQP(256) | ,IEQ010(25 | 61          |
| 0010    |      |           | DIMENSIO           | N IUNASN(128)                |                |            |             |
| 0011    |      |           |                    | N KTERMO(128) KTERMD(12      | 8).KFUN0(128)  | .KFUND(128 | )           |
| 0012    |      |           |                    | N TITLE(10)                  |                |            |             |
| 0013    |      |           |                    | DATE TIME                    |                |            |             |
| 0014    |      |           | DATA IBL           |                              |                |            |             |
| 0015    |      |           |                    | FT, IRIGHT / ( *, *) */      |                |            |             |
| 0016    |      |           |                    | • INUT /*+*•*                |                |            |             |
| 0017    |      |           | INTEGER            | [VAR(32)/*A*,*B*,*C*,*[      | 1              |            | J*.*K*.* *. |
| 0011    |      |           |                    | , *O*, *P*, *Q*, *R*, *S*, * |                |            |             |
| •       |      |           | 2 121,131          |                              |                |            |             |
| 0218    |      |           |                    | EX (TIME,DATE)               |                |            |             |
| 0019    |      |           | IIN=5              | Ex (Trincybare)              | '              |            |             |
| 0020    |      |           | 10UT=6             |                              |                |            |             |
| 0021    |      |           | MAXETX=1           | 79                           |                |            |             |
| 0021    |      |           | MAXNUD=1           |                              | 1              |            |             |
| 0023    |      |           | MXTERM=1.          |                              |                |            |             |
| 0024    |      |           | NAMLEN=1           |                              |                |            |             |
| 0024    |      |           | SIGLEN=4           |                              |                |            |             |
| 0025    |      |           | IEND=0             | U .                          |                |            |             |
| 0028    |      |           | NXFTO=0            |                              | ,              |            |             |
|         |      | - 4       | NXP10=0<br>NSYM8=0 |                              |                |            |             |
| 0028    |      |           |                    |                              |                |            |             |
| 0029    |      |           | IERR=0             | HANNOR                       |                |            |             |
| 0030    |      |           | 00 1 I=1           |                              |                |            |             |
| 2031    |      |           | NODE(I)=           | -1                           |                |            |             |
| 0032    |      | -         | CONTINUE           |                              |                |            |             |
|         |      | C         | CTADE DA           | TA INPUT. READ STATE-FL      | IN EDON TOPS   |            | STONAL S    |
|         |      | C         |                    | DDE SYMBOL TABLE AS INF      |                |            |             |
|         |      | С<br>С    | BUILD N            | DUE STHOUL TABLE AS INF      | OT ACCEPTED 3  | AVING 14FU | 1 SIGNALSI  |
| 0033    |      | ι         | DEAD /11           | N.1150.EN0=990) TITLE        |                |            |             |
| 0033    |      | 1150      | FORMAT (           |                              |                |            |             |
| 0034    |      | 1150      |                    | DUT,1151} TITLE, TIME,       | DATE           |            |             |
| 0035    |      |           |                    | 1H1,10A4, TIME= *,A          |                | 4971       |             |
| 0036    |      | 1151      |                    |                              | ST DATE- T     | 4077       |             |
| 0037    |      | 1100      |                    | DUT,1190)<br>• INPUT DATA*/) |                |            |             |
| 0038    |      |           | NXFTO=NXI          |                              |                |            |             |
| 0039    |      | 2         |                    | D LE. MAXETX) GO TO (        | ,              |            |             |
| 0040    |      |           |                    | OUT,1195} MAXETX             |                |            |             |
| 0041    |      | 1105      |                    | 10*+* STATE-FLOW FROM-1      |                | 151        |             |
| 0742    |      | 1195      |                    |                              | U S LAGELU ,   | 1.77       |             |
| 0043    |      | c         | GO TO 99           | 7                            |                |            |             |
| 0.244   |      | C,        |                    | N 1200 END-0001 KAOD         |                |            |             |
| 0044    |      |           |                    | N,1200,END=999) KARD         |                |            |             |
| 0/04/5  |      | 1200<br>C | FORMAT (           |                              |                |            |             |
| 00//    |      | L         |                    | CHECK FOR "*" IN COLUMN      |                |            |             |
| 0046    |      |           |                    | (KARD(1),***,1) ) GO T(      | 1 FM           |            |             |
| 0047    |      |           | WRITE (10          | BUT,1205) NXFTO,KARD         |                |            |             |
|         |      |           |                    |                              |                |            |             |

| FORTRAN      | I¥ | G | LEVEL | 21          | · · ·          | MAIN       |                                                  | DA         | TE = 73135      | 21/16/38      |
|--------------|----|---|-------|-------------|----------------|------------|--------------------------------------------------|------------|-----------------|---------------|
| 0048         |    |   | 1205  | FORMAT      | (1X,15,*       | FROM= ",   | 20A1, "                                          | 10= ',20A  | 1, INPUT SIG    | NALS= •,40A1) |
|              |    |   | C     |             |                |            |                                                  |            |                 |               |
|              |    |   | С     |             |                |            |                                                  |            | TE-FLOW NODE    |               |
| 0.349        |    |   |       | CALL IS     | SYMBL (NAM     | ILEN, KRDF | RM ,NO                                           | S.DSTRNG.  | NSYMB, NODNAM   | (MAXNOD, IER) |
| 0050         |    |   |       | IF (IE      | ₹.EQ.0.        | AND. NOS.  | EQ.4) (                                          | GO'TO 20   |                 |               |
| 0051         |    |   |       |             | (1001,1220     |            |                                                  |            |                 |               |
| 0052         |    |   | 1220  | FORMAT      | (* *** EP      | ROR IN "   | FROM                                             | STATE-FL   | DW NODE NAME    | 4)            |
| 0053         |    |   |       | I F R R = 1 |                |            |                                                  |            |                 |               |
| 0054         |    |   |       |             | (NXFTO)=0      |            |                                                  |            |                 |               |
| 0055         |    |   | _     | GO TO A     | -              |            |                                                  |            |                 |               |
|              |    |   | С     |             |                | NAME ADD   | RESS                                             |            |                 |               |
| 0056         |    |   |       | NXFROM      | (NXFTO) =0     |            |                                                  |            |                 |               |
|              |    |   | С     |             |                | TO' NAME   |                                                  |            |                 |               |
| 0.057        |    |   | 21    |             |                |            |                                                  |            | SYMB + NODNAM + | MAXNUD, LERI  |
| 0058         |    |   |       |             | R .EQ.0 .A     |            | Q.41 G                                           | J TO 30    |                 |               |
| 0059         |    |   |       |             | (10UT.1230     |            |                                                  |            |                 |               |
| 0060         |    |   | 1230  |             | (* *** EK      | KUR IN "   | 10                                               | AIE-FLUW   | NODE NAME*)     |               |
| 0061         |    |   |       | IFRR=1      |                |            |                                                  |            |                 |               |
| 0062         |    |   |       |             | (FTO)=0        |            |                                                  |            |                 |               |
| 0063         |    |   | ~     | GO TO :     |                |            |                                                  |            |                 |               |
| 00()         |    |   | 0     |             |                | NAME ADD   | RE22                                             |            |                 |               |
| 0064<br>0065 |    |   |       | •           | (FTO) =051     |            |                                                  |            | ~               |               |
| 0065         |    |   | 21    | GO TO       | DVE (NXSI      | GUIANAFIU  | I INKUSI                                         | 10147316L  |                 |               |
| 0000         |    |   | с     | 00 10       |                | R **STATE  | C1 CADI                                          | <b>`</b>   |                 |               |
| -            |    |   | c     |             | UNCON FU       | -JIAIC     | J CAN                                            |            |                 |               |
| 0067         |    |   | -     | NMAX=0      |                |            |                                                  |            |                 |               |
| 0068         |    |   | 10    |             | T.LCOM (KA     | RD(1).**   | \$ 1                                             | ГАТ        | E 1.241         | ) GO TO 90    |
| 0069         |    |   |       |             | 1001,1772      |            | •                                                |            |                 |               |
| 0070         |    |   | 1772  |             | ( '0' . 80A1   |            |                                                  |            |                 |               |
|              |    |   | c     |             |                | S. READ S  | TATE AS                                          | SIGNMENT   | CARDS           |               |
| 0071         |    |   | 75    | READ (      | [ [ N, 1200, E |            | ARD                                              |            |                 |               |
| 0072         |    |   |       |             | COM(KARD(1     |            | ) GO TO                                          | 90         |                 |               |
| 0073         |    |   |       | WPITE (     | 1001,1775      | ) KARD     |                                                  |            |                 |               |
| 0074         |    |   | 1775  | FORMAT      | ( ASSIGN       | ED STATE(  | OCTAL)=                                          | •,20A1,    | NODE NAME       | = ',60A1)     |
|              |    |   | С     |             | CONVERT        | STATE ASS  | IGNMEN1                                          | IN OCTAL   | TO INTERNA      | L BINARY      |
| 0975         |    |   |       | NSTATE:     | = 0            |            |                                                  |            |                 |               |
| 0076         |    |   |       | 00 77 1     | 1=1,20         |            |                                                  |            |                 |               |
| 0077         |    |   |       | IE=21-1     | [              |            |                                                  |            |                 |               |
| 0078         |    |   |       | IF (KAP     | RD(1E) .NE     | IBLNK)     | GO TO 1                                          | 78 -       |                 |               |
| 0079         |    |   |       | CONTINU     | JE             |            |                                                  |            |                 |               |
|              |    |   | C     |             |                | STATE ASS  | I GNMENT                                         | BLANK      |                 |               |
| 0080         |    |   |       |             | IOUT,1777      |            |                                                  |            |                 |               |
| 0081         |    |   | 1777  |             | (* *** ER      | ROR. STAT  | E ASSIC                                          | INMENT BLA | NK*)            |               |
| 0082         |    |   |       | IFRR=1      |                |            |                                                  |            |                 |               |
| 0.083        |    |   |       | GO TO E     |                |            |                                                  |            |                 |               |
| 0084         |    |   |       | 00 79 1     |                |            | ر درمه دینیدهمینه در اینده<br>آنجو رو ارتفار هما |            |                 |               |
| 0085         |    |   | 79    | CALL MP     | UT C NST       | ATE        | • "M##\$#                                        | 1. KARDLI  | E+1-[], 5,      | 31            |

| ENRTRAN | IV G | LEVEL | 21           | MAIN                          | DATE = 73135              | 21/16/38      |
|---------|------|-------|--------------|-------------------------------|---------------------------|---------------|
|         |      | Ċ     |              | CHECK NODE NAME               |                           |               |
| 0086    |      | 80    | NS=NSYMB     |                               |                           |               |
| 0087    |      | 00    |              | MBL (NAMLEN, KARD(21), I      | NOS-OSTRNG-NSYMB-NODNAM   | MAXNOD, LER 1 |
| 0038    |      |       |              | Q.NSYMB .AND. IER.EQ.O        |                           |               |
| 0050    |      | с     |              | FRROR IN NODE NAME            | • AND• NUS•EN•+1 GU TU 6. | 2             |
| 0089    |      |       |              | OUT,1780}                     |                           |               |
| 0090    |      | 1780  | FORMAT (     | * *** ERROR IN NODE NAM       | E*)                       |               |
| 0091    |      |       | IERR=1       |                               |                           |               |
| 0092    |      |       | NSYMB=NS     |                               |                           |               |
| 0093    |      |       | GO TO 75     |                               |                           |               |
|         |      | С     |              |                               |                           |               |
|         |      | ċ     |              | SAVE STATE DATA               |                           |               |
| 0094    |      | -     | N=DSTRNG     |                               |                           |               |
| 0095    |      |       |              | = NSTATE                      |                           |               |
| 0096    | •    |       |              | AXO(NMAX+NSTATE)              |                           |               |
| 0093    |      |       | GU TO 75     |                               |                           |               |
| 0 1 4 1 |      |       | 60 10 72     |                               |                           |               |
|         |      | C     |              | CHECK LE ANY NODE NAMES       |                           |               |
|         |      | C     |              | CHECK IF ANY NODE NAMES       | HAVE UNASSIGNED STATES    |               |
| 0098    |      |       | IEND=1       |                               |                           |               |
| 0009    |      | 90    | NXETO=NX     |                               |                           |               |
| 0100    |      |       | 00 95 I≃     |                               |                           |               |
| 0101    |      | с ,   |              | E(I) .NE1 ) GO TO 95<br>ERPOR |                           |               |
| 0102    |      |       | WRITE (I     | OUT,1191) (NODNAM(J,I         | ). ]=1.4)                 |               |
| 0103    |      | 1191  |              | * *** ERROR . NO ASSIGNE      |                           | • • 4441      |
| 0104    |      |       | IFRR=1       |                               |                           |               |
| 0105    |      | 95    | CONTINUE     |                               |                           | 1             |
| •••     |      | c     | 0.5.1.1.1.0. |                               |                           |               |
|         |      | č     |              | DETERMINE NUMBER OF FLIP      | P-FLOPS REQUIRED          |               |
| 0106    |      | C     |              | .442695*ALUG[FLOAT[NMAX       |                           |               |
| 0108    |      | с     |              | .442033#AEUG11EUAT114.4AX     | · · · ·                   |               |
|         |      |       |              |                               |                           |               |
|         |      | c     |              | ADD FLIP FLOP VARIABLE        | NAMES TO STMBOL TABLE     |               |
|         |      | С     |              |                               |                           | ,             |
| 0107    |      |       | DO 97 I=     |                               |                           |               |
| 0108    |      |       |              | , I ) = I VAR (I)             |                           |               |
| 0109    |      |       | DD 97.J=     |                               |                           |               |
| 0110    |      | 91    | INSYMB(J     | ,I)=IBLNK                     |                           |               |
|         |      | С     |              |                               |                           | -             |
| -       |      | С     |              | FORM SYMBOL TABLE OF IN       | PUT SIGNAL VARIABLES      |               |
|         |      | С     |              |                               |                           |               |
| 0111    |      |       | INP=0        |                               |                           |               |
| 0112    |      |       | DO 100 I     | =1,NXFTO                      |                           |               |
| 0113    |      |       |              | MBL ( SIGLEN, NXSIG(1.1)      | • NOS • OSTRNG • LNP •    |               |
|         |      |       |              | YMB(1,NFF+1); 32-NFF; I       |                           |               |
| 0114    |      |       |              | EQ.2) IERR=1                  |                           |               |
| 0115    |      |       | LENEQ(I)     |                               |                           |               |
|         |      |       |              |                               |                           |               |
| 0116    |      | c     | IF INUS+E    | Q.0) GU TO 100                | S THOUT STONAL COULTTON   |               |
|         |      | C     |              | SAVE PARTIALLY PROCESSED      | J INPUT SISNAT PULLATION  |               |

| FORTRAN       | <b>IV</b> ⊂G | LEVEL            | 21                         | MAIN                                           | DATE         | = 73135      | 21/15/38               |
|---------------|--------------|------------------|----------------------------|------------------------------------------------|--------------|--------------|------------------------|
| 0117          |              |                  |                            | . SIGLEN) WRITE (IOUT                          |              |              |                        |
| 0118          |              |                  |                            | #* ERROR. INPUT SIGNA<br>R ISYMBL PROCESSING*) | L EQUATION ( | DN LINE*,13  | <pre>* EXCEEDS*,</pre> |
| 0119          |              |                  |                            | (NOS, SIGLEN)                                  | . ·          |              |                        |
| 0120          |              |                  |                            | NXSIG(1,1), OSTRNG,                            | 4*NOS)       |              |                        |
| 0121          |              | 100<br>C         | CONTINUE                   |                                                |              |              |                        |
| 0122          |              | U.               | WRITE (IOUT                | ,1221) NEE,NXETO,NSYM                          | B. INP       |              |                        |
| 0123          |              |                  |                            | NPUT SUMMARY 1/                                | • •          |              | 1                      |
|               |              |                  |                            | K FLIP-FLOPS REQUIRED<br>PUT FROM-TO CARDS*/   | • /          |              |                        |
|               |              |                  |                            | ATE-FLOW NODES*/                               | • •          |              |                        |
|               |              |                  |                            | PUT SIGNAL VARIABLES*                          | /            |              |                        |
|               |              | c                | F)                         |                                                |              |              |                        |
|               |              | Č                | PLAC                       | E ( ) AROUND VARIABL                           | E NAMES GRE  | ATER THAN 1  | CHAR                   |
| 0124          |              | L                | DO 120 I=1.                | INP                                            |              |              |                        |
| 0125          |              |                  |                            | (INSYMB(1,I+NFF),1,4                           | ,WORK(2),1,  | NAMLEN, IER) |                        |
| 0126          |              |                  | DO 125 J=1,                |                                                |              |              |                        |
| 0127          |              |                  | JJ=NAMLEN+2                |                                                | 127          |              |                        |
| 0128          |              | 125              | IF (WORK(JJ<br>CONTINUE    | ) .NE. [BLNK) GO TO                            | 125          |              |                        |
| 0129<br>.0130 |              |                  |                            | 2) GO TO 120                                   |              |              |                        |
|               |              | c <sup>120</sup> |                            | PARANS                                         |              |              |                        |
| 0131          |              |                  | WORK(1) = $I$              |                                                |              |              |                        |
| 0132          |              |                  | WORK(JJ+1)                 |                                                |              |              |                        |
| 0133<br>0134  |              | 1.20             | CALL CVAIA4                | {WORK,1,NAMLEN,INSYM                           | BEL, I+NFFI, | 1,4,11683    |                        |
| 01.24         |              | C 120            | CONTINUE                   |                                                |              |              |                        |
|               |              | C                | PRIN                       | T STATE-FLOW NODES                             |              |              |                        |
|               |              | С                |                            |                                                |              |              |                        |
| 0135          |              | 1210             | WRITE (IOUT<br>FORMAT (/// |                                                | ASSICN       |              | ITERAL FORM)           |
| 0136          |              |                  | A* /)                      | NOOL NAME                                      |              |              |                        |
| 0137          |              |                  | 00 130 I=1,                | NSYMB                                          |              |              |                        |
|               |              | C                |                            | VERT NODE STATE TO 0,                          |              |              |                        |
| 0138          |              | ~                |                            | (NFF. , NODE(I),0,                             |              |              |                        |
| 0139          |              | С                | WORK(NEF+1)                | VERT NODE STATE TO LI                          | IERAL FURM   |              |                        |
| 0140          |              |                  | WORK(NFF+2)                |                                                |              |              |                        |
| 0141          |              |                  | NDS1=NFF+2                 |                                                |              |              |                        |
| 0142          |              |                  | DO 135 J=1,                |                                                |              |              |                        |
| 0143          |              |                  |                            | (4,NUDE(1), 31-NFF                             | +J,IVAL)     |              | · . · ·                |
| 0144          |              | c                |                            | Q. 1) GO TO 136                                |              |              |                        |
| 0145          |              | C                | NOS1=NOS1+1                | LEMENTED VARIABLE                              |              |              |                        |
| 0145          |              |                  | WOPK[NOS1]=                |                                                |              |              |                        |
|               |              |                  |                            |                                                |              |              |                        |

| TURTERIN | τ <b>ν</b> () | LEVEL | <i>2</i> 1                             | 44 I W        | DATE = 15155          | 21/10/35                                                                                                        |
|----------|---------------|-------|----------------------------------------|---------------|-----------------------|-----------------------------------------------------------------------------------------------------------------|
|          |               | С     | UNCOMPLEMENTE                          | D VARIABLE    |                       |                                                                                                                 |
| 0147     |               | 136   | NGS1=NOS1+1                            |               |                       |                                                                                                                 |
| 0143     |               |       | WOPK(NOS1) = IVAR(J)                   |               |                       |                                                                                                                 |
| 0149     |               | 135   | CONTINUE                               |               |                       |                                                                                                                 |
| 9150     |               |       | NOS1 = NOS1+1                          | •             |                       |                                                                                                                 |
| 0151     |               |       | WORK(NOS1)=IRIGHT                      |               |                       |                                                                                                                 |
| 0152     |               |       | WRITE (IOUT,1320) 1,(                  | NODNAM(J.I).  | J=1,4), (WORK(J),J=1, | NOS1)                                                                                                           |
| 0153     |               | 130   | CONTINUE                               |               |                       |                                                                                                                 |
| 0154     |               | 1320  | FORMAT (1X, 14, 2X, 4A4,               | 2X,100A1)     |                       |                                                                                                                 |
|          |               | С     |                                        |               |                       |                                                                                                                 |
|          |               | C     | PRINT INPUT VA                         | NRIABLES      |                       |                                                                                                                 |
|          |               | Ç     |                                        |               |                       |                                                                                                                 |
| 0155     |               |       | IF (INP .GT. O)                        |               |                       |                                                                                                                 |
|          |               |       | «WRITE (IOUT,1340) ((I                 |               |                       |                                                                                                                 |
| 0156     | 4             |       | FORMAT (///'OINPUT VA                  | RIABLES'// [] | 1X,4A4))              |                                                                                                                 |
|          |               | С,    |                                        |               |                       |                                                                                                                 |
| 0157     |               |       | IF (IERR .GT. 0) GO                    | TO 999        |                       |                                                                                                                 |
|          |               | C     |                                        |               |                       |                                                                                                                 |
|          |               | C.    | FIND UNASSIGN                          | IED STATES    |                       |                                                                                                                 |
|          |               | C.    | 10 Dist 1155                           |               |                       |                                                                                                                 |
| 0158     |               |       | NS=2**NFF                              |               |                       |                                                                                                                 |
| 0159     |               |       | NUN=0                                  |               |                       |                                                                                                                 |
| 0160     |               |       | 00 150 I=1,NS                          |               |                       |                                                                                                                 |
| 0161     |               |       |                                        |               |                       |                                                                                                                 |
| 0162     |               |       | 00 152 J=1,NSYM9                       | GU TO 150     |                       |                                                                                                                 |
| 0163     |               | 160   | IF ( NODE(J) .EQ. NA)<br>CONTINUE      | 60 10 100     |                       |                                                                                                                 |
| 0164     |               | C 192 | FJUND ONE                              |               |                       |                                                                                                                 |
| 0165     |               | U.    | TE (NUN .LT. MXTERM)                   | CO TO 152     |                       | ÷                                                                                                               |
| 0156     |               |       | WPITE (IOUT,1152)                      | 30 (0 1))     |                       |                                                                                                                 |
| 0167     |               | 1152  |                                        | UNASSIGNED S' | TATES EXCESSIVE. PROC | ESSING BYPAS                                                                                                    |
| 0101     |               |       | ASED 1)                                | 00000000000   | The second states was |                                                                                                                 |
| 0163     |               | •     | NUN=0                                  |               |                       |                                                                                                                 |
| 0169     |               |       | GO TO 155                              |               |                       |                                                                                                                 |
|          |               | C     | •••••••••••••••••••••••••••••••••••••• |               |                       |                                                                                                                 |
| 0170     |               |       | NUN=NUN+1                              |               |                       |                                                                                                                 |
| 0171     |               |       | IUNASN(NUN) = NA                       |               |                       |                                                                                                                 |
| 0172     |               | .150  | CUNTINUE                               |               |                       |                                                                                                                 |
|          |               | С     |                                        |               |                       |                                                                                                                 |
| 0173     |               | 155   | CONTINUE                               |               |                       |                                                                                                                 |
|          |               | C.    |                                        |               |                       |                                                                                                                 |
|          |               | Ç     |                                        |               |                       |                                                                                                                 |
|          |               | С     | SHIFT FF STAT                          | E OVER TO ACC | COMMODATE INPUT VARIA | BLES                                                                                                            |
|          |               | C     |                                        |               |                       |                                                                                                                 |
| 0174     |               |       | IMULT=2**INP                           |               |                       |                                                                                                                 |
| 0175     |               |       | DO 160 E≈1,NSYM8                       |               |                       |                                                                                                                 |
| 0176     |               |       | NODE(I) = NODE(I)*IMU                  | ILT ST        |                       | 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - |
| 0177     |               | 160   | CONTINUE                               |               |                       |                                                                                                                 |
|          |               |       |                                        |               |                       |                                                                                                                 |
|          |               |       |                                        |               |                       |                                                                                                                 |

MAIN

FURTHAN IV G LEVEL

21

DATE = 73135

89

21/16/38

| FORTRAN      | tv G | LEVFL    | 21                   | MAIN                 | DATE = 73135            | 21/16/38        |
|--------------|------|----------|----------------------|----------------------|-------------------------|-----------------|
| 0178         |      |          | IF (NUN .            | F0. 0) GD TO 162     |                         |                 |
| 0179         |      |          | 00 161 I=            | 1+NUN                |                         |                 |
| 0180         |      | 161<br>C | IUNASN(I)            | = IUNASN(I)*IMULT    |                         |                 |
|              |      | C .      |                      |                      | EQUATIONS TO SUM OF PRO | DUCTS FORM      |
| 0181         |      | 162      | DE 1900 I            |                      |                         |                 |
| 0182         |      | 1000     |                      | EQ ( LENEQ(E), NXS   | 16(1,1), WURK )         |                 |
| 0183         |      | С        | CONTINUE             |                      |                         |                 |
|              |      | c<br>c   | r                    |                      | OUNTIONS COON STATE OF  | AN ERIN TOLS    |
| 31.37        |      | C        |                      |                      | QUATIONS FROM STATE-FL  | UW FRUM-IU'S    |
| 3134         |      |          | IBITS = N<br>IDSFT=0 | FF + INP             |                         |                 |
| 0145<br>0186 |      |          |                      | LF. 0) GU TO 2001    |                         |                 |
| 0136         |      |          | IF (INP .            |                      |                         |                 |
| 0188         |      |          |                      | T (1, IDSET, 32-1)   |                         |                 |
|              |      | С<br>С   |                      |                      |                         |                 |
| 0189         |      |          | 00 2200 N            |                      |                         |                 |
| 0190         |      | 2001     | NN=31-IBI            |                      |                         |                 |
| 0190         |      | С        | 101-101              | 1.3+1                |                         |                 |
|              |      | C<br>C   |                      |                      | ERTED FOR ADDITIONAL AS |                 |
|              |      |          |                      | HIBITED TEMPORARILY  | WITH COL. 1 "C".        | • ·             |
|              |      | C        | 00 2200 N            |                      |                         |                 |
|              |      | С        |                      |                      | RESET EQUATION          |                 |
| 0191         |      |          | DD 2199 N            | FQ=1,2               |                         |                 |
|              |      | ç        | _                    |                      |                         |                 |
|              |      | ç        | . D                  | D 2100 LOOP SEARCHS  | FOR TRANSITIONS OF FF I | N QUESTION      |
| 01.00        |      | C .      | NTRM=0               |                      |                         |                 |
| 0192<br>0193 |      |          | DO 2100 K            |                      |                         |                 |
| 0145         |      | с        | 00 2100 K            | K=1+NAFTU            |                         |                 |
|              |      | c        | C                    | HECK IF FF IS CHANGI | NG                      |                 |
| 0194         |      |          |                      | T ( 4, NODE(NXEROM(K |                         |                 |
| 0195         |      |          |                      | T ( 4, NODE(NXTO(KK) |                         |                 |
|              |      | С        |                      |                      | T / RESET TERMS (SAME S | TATE MAINTAIND) |
| 0196         |      |          |                      | .FO. JVAL) GO TO 210 |                         |                 |
|              |      | C        | GO TO 210            |                      | •                       |                 |
|              |      | C        |                      | .FQ. MOD(NEQ,2)1 G   | 0 TO 2120               |                 |
|              |      | С        |                      | HECK FOR SET / RESET |                         |                 |
| 0197         |      | 2111     | IF ( 2+1             | VAL + JVAL .NE. NEQ  | I GO TO 2100            |                 |
|              |      | C        |                      |                      | FFT FOULTION            |                 |
|              |      | С<br>С   | д                    | DD TERM TO SET / RE  | SET EQUATION            |                 |
| 0198         |      | 2120     | .1=0                 |                      |                         |                 |
| 0199         |      |          | NTRM=NTRM-           | +1                   |                         |                 |
| 0200         |      |          |                      | RM) = NODE(NXFROM(KK | 33                      |                 |
|              |      |          |                      |                      |                         |                 |

÷,

| FORTRAN | IV G | LEVEL    | 21                   | - <b>- H</b> | AIN         | DATE                                     | = 73135     | . 217     | /16/38 |
|---------|------|----------|----------------------|--------------|-------------|------------------------------------------|-------------|-----------|--------|
| 0201    |      |          | JTERMD(NTRM)         | = IDSET      |             |                                          |             |           |        |
|         |      | c        |                      | ASH INTO     | THES FEES   | BIT POSITIO                              | N TO FLININ | ATE       |        |
|         |      | č        |                      |              | UND ENCIES  |                                          |             |           |        |
| 0202    |      | 0        | CALL PBTST (         | -            |             | VAL                                      |             |           |        |
| 0203    |      |          | CALL PBTST (         |              |             |                                          |             |           |        |
| 0204    |      |          | JEUNO (NTRM) =       |              |             |                                          |             |           |        |
| 0205    |      |          | JFUND(NTRM)=         | -            |             |                                          |             |           |        |
| 0200    |      | с        |                      |              |             | IN MINTERM                               | ( INTERNAL  | 0 1 -1    |        |
| 0001    |      |          | J=J+1                | ODE INPUT    | VANIADLES   | IN HINLERH                               | TIMIENNAL   | 0,1,-1    |        |
| 0206    |      | 2122     | IF (J .GT. L         |              | CO TO 21    | 00                                       |             |           |        |
| 0207    |      | <i>c</i> |                      |              |             |                                          |             | ANOTHER   | TEON   |
|         |      | С        |                      |              |             | SIGNAL EQUA                              |             | ANUTHER   | IERM   |
| 0208    |      | с        | IF ( LCOM(N)<br>CHEC | K FOR NOT    |             | J GU TU 212.                             | L           |           |        |
| 0209    |      |          | IF L .NOT. L         |              |             | •. 1) ) GO                               | TO 2126     |           |        |
|         |      | c        | COMP                 | LEMENTED     |             |                                          |             |           |        |
| 0210    | ·    |          | J=J+1                |              |             |                                          |             |           |        |
| 0211    |      |          | IF ( NXSIG(          | J,KK) .G1    | r. 10000) G | O TO 2130                                |             |           |        |
| 0212    |      |          | NB=31-INP+N)         | SIG(J,KK)    |             |                                          |             |           |        |
| 0213    |      |          | CALL PRIST (         | 3. JTERM     | 10(NTRM), N | B, IVAL)                                 |             |           |        |
| 0214    |      |          | CALL PBTST (         | 3, JTERM     | 4D(NTRM), N | B, IVAL)                                 |             |           |        |
| 0215    |      |          | GO TO 2130           |              |             |                                          |             |           |        |
|         |      | С        | UNCOMP               | LEMENTED     | VARIABLE    |                                          |             |           |        |
| 0216    |      | 2126     | IF ( NXSIGL          | .KK) .GT.    | 10000) GO   | TO 2130                                  |             |           |        |
| 0217    |      |          | NB=31-INP+N)         | SIGIJ.KKI    | +           |                                          |             |           |        |
| 0219    |      |          | CALL PBTST (         |              |             | B. IVAL)                                 | •           |           |        |
| 0219    |      |          | CALL PRIST (         |              |             |                                          |             |           |        |
|         |      | с        |                      |              |             |                                          |             |           |        |
| 0220    |      | -        | GO TO 2122           | 3            |             |                                          |             |           |        |
| 0221    |      | -        | CONTINUE             |              |             |                                          |             |           |        |
|         |      | c        | 0.5.411101.          |              |             |                                          |             |           |        |
|         |      | С        | PRIN                 | T TERMS G    | SENERATED   |                                          |             |           |        |
|         |      | С        |                      |              |             |                                          |             |           |        |
| 0222    |      |          | WRITE (6,801         |              |             |                                          |             |           |        |
| 0223    |      | 8010     | FORMAT ('O J         | /K FLIP P    | LOP ',13,'  | EQUATION                                 | •,12)       |           |        |
| 0224    |      |          | NB ≃ NFF+INP         |              |             |                                          |             |           |        |
| 0225    |      |          | DO 8000 KQ =         | 1,NTRM       |             |                                          |             |           |        |
| 0226    |      |          | CALL TERMOT          | ( NB, JT     | ERMO(KQ),   | JTERMD(KQ),                              | KARDI       |           |        |
| 0227    |      |          | WRITE (6,800         | 5) (KARD     | (KN),KN=1,  | NB)                                      |             |           |        |
| 0228    |      | 8005     | FORMAT ( 5X.         | 8041)        |             |                                          |             |           |        |
| 0229    |      | 8000     | CONTINUE             |              |             |                                          |             |           |        |
|         |      | С        |                      |              |             |                                          |             |           |        |
|         |      | Ċ.       | SUBRO                | UTINE EXM    | INDC EXPAND | S MINTERM DO                             | N'T CARES   | INTO      |        |
|         |      | Ĉ        |                      |              | 0.1 MINTER  |                                          |             |           |        |
|         |      | č        |                      |              |             |                                          |             |           |        |
| 0230    |      |          | CALL EXMNDC          | (IBITS.NT    | RM.MXTERM.  | JTERMO, JTERM                            | D.JFUNO.JF  | JND, IER) |        |
| 0231    |      |          | IF (IER .GE.         |              |             |                                          |             |           |        |
|         |      | с        |                      |              |             |                                          |             |           |        |
|         |      | č        | TNCI                 |              |             | SIGNED STATE                             | S IF NES=2  |           |        |
|         |      | ~        | INCL                 | ODL HOUI     | LUNAL DINAS | U. U | J 11 11.J-Z |           |        |

| FORTRAN IV G LEV | EL 21 MAIN                                                                        | DATE = 73135                | 21/16/38     |
|------------------|-----------------------------------------------------------------------------------|-----------------------------|--------------|
| 1.0              | EL 21 MAIN                                                                        | DATE - TSTSS                | 21/10/50     |
| · C              | · · · · ·                                                                         |                             |              |
| 0232             | IF (NES .NE. 2) GO TO 540                                                         |                             |              |
| 0233             | NT=NTRM+1                                                                         |                             |              |
| 0234             | IDS=IDSET                                                                         |                             |              |
| 0235             | CALL PBIST (1,IDS,NN,IVAL)                                                        |                             |              |
| 0.2.36           | CALL ADTRME (IBITS,NFF,NTRM,M)<br>A IDS ,IER)                                     | (TERM, JTERMO, JTERMD, NUN, | LUNASN +     |
| 02 <b>37</b>     | IF (IER .NE. 0) GO TO 999<br>FILL IN FUNCTIONAL ARE                               | RAYS FOR MINTERMS JUST A    | DDED         |
| 0238             | IF (NTRM .LT. NT) GO TO 2200                                                      |                             |              |
| 0239             | 00 530 KQ=NT,NTRM                                                                 | · ·                         |              |
| 0240             | JEUNO(KQ) = 1                                                                     |                             |              |
|                  | 30 JFUND(KQ)=0                                                                    |                             |              |
| 0241 C           | EXPAND MENTERM DON'T                                                              | ****                        |              |
| 0242             | CALL EXMNDC (IBITS, NTRM, MXTER)                                                  |                             | IND. TERI    |
| 0243             | IF (IER .GE. 2) GO TO 999                                                         |                             |              |
| C                |                                                                                   |                             |              |
| ç                |                                                                                   |                             | · ·          |
| ç                |                                                                                   |                             | * * CUMC COD |
| c<br>c           | FIND PRIME IMPLICANTS FOR EACH<br>FOR SINGLE OUTPUT FUNCTION }                    | FUNCTION THE MINIMIZ        | T LERMS FUR  |
| С                | · · · · · · · · · · · · · · · · · · ·                                             |                             |              |
|                  | 40 CALL PPIMIM (IBITS,NTRM,JTERM)<br>A ,NPRIM, KTERMO,KTERMO,KEUNO,               |                             |              |
| C                |                                                                                   | ·                           |              |
| c                | PRINT MINIMIZED FUNCT                                                             | ION .                       |              |
| 0245             | 00 542 KQ=1,256                                                                   |                             |              |
| 0246             | IEQP(KQ) = IBLNK                                                                  |                             |              |
|                  | 42 IEQ01D(KQ)=IBLNK                                                               |                             |              |
| 0248             | NOS1 = 0                                                                          |                             |              |
| 0249             | DO 549  KS = 1, NPRIM                                                             |                             |              |
| 0250             | KSW=0                                                                             |                             |              |
| C<br>C<br>C      | CHECK IF THIS SINGLE OUTPUT<br>FOLLOWING PRIME IMPLICANTS<br>THE EQUATION STRING. |                             |              |
| 0251             | KT=KS+1                                                                           |                             |              |
| 0252             | IF (KT .GT. NPRIM ) GO TO 546                                                     | 51                          |              |
| 0253             | DO 546 KR=KT.NPRIM                                                                | -                           |              |
| 0254             | CALL SUBSUM (IBITS, KTERMO(KS))                                                   | KTERMD(KS) KTERMO(KR) KI    | ERMIN(KR).   |
|                  | A IRET).                                                                          |                             |              |
| 0255             | IF (IRET .EQ. 1) GO TO 549                                                        |                             |              |
| 0256 54          | 6 CONTINUE                                                                        |                             |              |
|                  | 61 CONTINUE                                                                       | •                           |              |
| c                |                                                                                   | · ·                         |              |
| 0258             | N S=NO S1+1                                                                       |                             |              |
| 0259             | DO 548 L=1,IBITS                                                                  |                             |              |
| 0260             | LL=31-IBITS+L                                                                     |                             |              |
| 0261             | CALL PBTST (4,KTERMD(KS),LL,IV                                                    | AL)                         |              |

| FORTRAN | 1V 0 | G LEV <del>e</del> l | 21                    | MAIN           | DATE = 73135                          | 21/16/38                                |
|---------|------|----------------------|-----------------------|----------------|---------------------------------------|-----------------------------------------|
| 0262    |      |                      | IF (IVAL .EQ. 1)      | GO TO 548      |                                       |                                         |
| 0263    |      |                      | CALL PBIST (4.KTE     | ERMO(KS).LL.IV | AL)                                   |                                         |
| 0264    |      |                      | IF (IVAL .EQ. 1)      | GO TO 547      |                                       |                                         |
|         |      | C.                   |                       | NTED VARIABLE  |                                       |                                         |
| 0265    |      |                      | NOS1 = NOS1+1         |                |                                       | F                                       |
| 0266    |      |                      | $IF_{P}(NOS1) = INOT$ | T.             |                                       |                                         |
|         |      | С                    | UNCOMPLEM             | MENTED VARIABL | E                                     |                                         |
| 0267    |      | 547                  | NOS1=NOS1+1           |                |                                       |                                         |
| 0268    |      |                      | CALL CVA4A1 ( INS     | SYMB(1,L),1,4, | IEQP(NOS1), 1.NAMLEN .                | IERI                                    |
|         |      | C                    | SUPPRESS              | TRAILING BLAN  | KS                                    |                                         |
| 0269    |      |                      | K S W = 1             |                |                                       |                                         |
| 0270    | •    |                      | NOS1=NOS1+NAMLEN-     | -1             |                                       |                                         |
| 0271    |      |                      | DO 5471 KQ=1,NAM      | MLEN           |                                       |                                         |
| 0272    |      |                      | IF ( LEQP(NOS1) .     | NE. IBLNK) G   | 0 TO 548                              |                                         |
| 0273    |      | 5471                 | NOS1=NOS1-1           |                |                                       |                                         |
| 0274    |      | 548                  | CONTINUE              | •              |                                       |                                         |
|         |      | <b>C</b> -           | IF TERM W             | HAS ALL 1-1, F | ILL IN WITH A "1"                     |                                         |
| 0275    |      |                      | IF (KSW_EQ.0) CA      | ALL MOVE (IEQP | (NCS1+1), 11, 1)                      |                                         |
|         |      | C                    | FILL IN 0,1,-         |                |                                       |                                         |
| 0276    |      |                      |                       |                | KTERMD(KS),IEQ01D(NS))                |                                         |
|         |      | C                    | PUT IN '              | + 1            |                                       |                                         |
| 0277    |      |                      | NOS1=MAXO(NOS1+2      |                |                                       |                                         |
| 0278    |      |                      | IEQP(NOS1) = IC       | 3R             |                                       |                                         |
| 0279    |      |                      | NOS1=NOS1+1           |                |                                       | · . ,                                   |
| 0530    |      |                      | CONTINUE              |                |                                       |                                         |
|         |      | C                    |                       |                |                                       |                                         |
|         |      | C                    |                       | ATION IDENTIFI | ER                                    |                                         |
| 0281    |      |                      | ID = IBLNK            |                |                                       |                                         |
| 0282    |      |                      | CALL MPUT (ID,24,     |                |                                       |                                         |
| 0283    |      |                      | IF (NEQ .EQ. 1)       |                |                                       |                                         |
| 0284    |      |                      | [F (NEO .EQ. 2)       |                | +16+"K"+0+8)                          |                                         |
|         |      | С                    | PRINT EQU             |                | •                                     | •                                       |
| 0285    |      |                      | CALL JKPRNT (ID+N     | NOSI-2,IEQP,IE | Q01D)                                 |                                         |
| 0286    |      |                      | CONTINUE              |                |                                       |                                         |
| 0287    |      | 2200                 | CONTINUE              |                |                                       | 2 C C C C C C C C C C C C C C C C C C C |
| 0238    |      |                      | IF (IEND) 4,4,990     | )              |                                       |                                         |
|         |      | C                    |                       |                |                                       |                                         |
|         |      | c                    | RUN ABORT             | TED. PRINT TE  | RMINATION MESSAGE.                    |                                         |
|         |      | С                    |                       |                |                                       |                                         |
| 0299    |      |                      | WRITE (IOUT,1999)     |                | · · · · · · · · · · · · · · · · · · · |                                         |
| 0290    |      |                      |                       | IIUN TERMINATE | D BECAUSE OF ERROR*) /                |                                         |
| 0291    |      | 990                  | STOP                  |                |                                       |                                         |
| 0292    |      |                      | END                   |                |                                       |                                         |

ι.

| FORTRAN      | IV G.L                | EVEL | 21                        | ADTRME                                                                               | DAT                          | E = 73135                   | 21/16/38                                |
|--------------|-----------------------|------|---------------------------|--------------------------------------------------------------------------------------|------------------------------|-----------------------------|-----------------------------------------|
| 0001         |                       | l    |                           | ADTRME(18ITS,NFF,N<br>IDSET,IRET)                                                    | TERM,MXTERM,.                | JTERMO, JTERMD              | • NUN                                   |
|              | 0<br>0<br>0<br>0<br>0 |      | INPUT LIST.<br>IS THAT AN | BROUTINE ADDS UNSPE<br>AN EXHAUSTIVE AP<br>ADDED TERM MUST BE<br>DNLY INTERNAL STATE | PROACH IS USI<br>ADJACENT TO | ED, THE CHEC<br>AN EXISTING | K MADE                                  |
| 0002         | L                     |      | DIMENSION                 | TEMP(10)                                                                             |                              |                             |                                         |
| 0003         |                       |      |                           | JTERMO(1),JTERMD(1                                                                   | . FUNASNELL                  |                             |                                         |
| 0003         |                       |      | IRET=0                    | JIERHOLIJIJJIERHOLI                                                                  | // 10/04/5/111/              |                             |                                         |
| 0005         |                       |      | K1=1                      |                                                                                      |                              |                             |                                         |
| 0000         |                       | 5    | IANY=0                    |                                                                                      |                              |                             |                                         |
| 2207         |                       |      | K2=NTERM+                 | l                                                                                    |                              |                             |                                         |
| 3301         | с                     |      | 1.2 - 11 E IV IV 2        | •                                                                                    |                              |                             |                                         |
|              | č.                    |      | ST                        | ART LOOP THROUGH UN                                                                  | ASSIGNED STA                 | TES                         |                                         |
| 0008         | .0                    |      | 00 50 1=1                 |                                                                                      |                              |                             |                                         |
| 0.000        | ċ                     |      |                           | CK IF ADJACENT TO                                                                    | ANY EXISTING                 | TERM                        |                                         |
| 0009         | 0                     |      | NT=NTERM                  | ten in Aberecht ver                                                                  |                              | 12.00                       |                                         |
| 0010         |                       |      | DO 40 J=K1                | NT                                                                                   |                              |                             |                                         |
| 0011         |                       |      | M=0                       |                                                                                      |                              |                             |                                         |
| 0012         |                       |      | 90 30 K=1.                | NEE                                                                                  |                              |                             |                                         |
| 0013         |                       |      | NN=31-18113               |                                                                                      |                              |                             |                                         |
| 0014         |                       |      |                           | (4, JTERMD(J), NN, I                                                                 | VAL)                         |                             |                                         |
| 0015         |                       |      |                           | EQ. 1) GO TO 30                                                                      |                              |                             |                                         |
| 0016         |                       |      | CALL PRTST                | (4, IDSET, NN, IVAL)                                                                 |                              |                             |                                         |
| 0017         |                       |      |                           | EQ. 1) GU TO 30                                                                      |                              |                             |                                         |
| 0018         |                       |      |                           | (4, JTERMO(J), NN, I                                                                 | VAL)                         |                             |                                         |
| 0019         |                       |      |                           | (4. IUNASN(I), NN. J                                                                 |                              |                             |                                         |
| 0020         |                       |      | IF ( IVAL .               | EQ. JVAL) GO TO 30                                                                   |                              |                             |                                         |
| 0021         |                       |      | M=M+1                     |                                                                                      |                              |                             |                                         |
| 0.022        |                       |      | 1F ( M .GT.               | . 1) GO TO 40                                                                        |                              |                             |                                         |
| 0023         |                       | 30   | CONTINUE                  | •                                                                                    |                              |                             |                                         |
| 0024         |                       |      |                           | 1) GO TU 40                                                                          |                              |                             |                                         |
|              | C                     |      | S E 4                     | ARCH LIST FOR LIKE                                                                   | TERMS. DO NO                 | IT ADD IF ONE               | FOUND.                                  |
| 0025         |                       |      | JO=IUNASN()               |                                                                                      |                              |                             |                                         |
| 0026         |                       |      |                           | (11, JO, IDSET, IVAL)                                                                |                              |                             |                                         |
| 1027         |                       |      | 00 32 KQ=1                |                                                                                      |                              |                             |                                         |
| 0.028        |                       |      |                           | (KQ).EQ.JO .AND. JT                                                                  | ERMD(KQ).EQ.I                | DSET) GO TO                 | 40                                      |
| 0029         |                       | 32   | CONTINUE                  |                                                                                      |                              |                             | ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) |
| 0000         | С                     |      |                           | D TERM                                                                               | 25                           |                             |                                         |
| 0600         |                       |      |                           | .LT. MXTERM) GO TO                                                                   | 57                           |                             | · · ·                                   |
| 0031<br>0032 |                       | 100  | WRITE (6,10               | **ERROR. MINTERM                                                                     | TOT EVCEEDS                  | 1.15)                       |                                         |
| 0733         |                       | 100  | IRET=1                    | ***ERROR. MINIERM                                                                    | LIST EXCEEDS                 |                             |                                         |
| 0734         |                       |      | RETURN                    |                                                                                      |                              |                             |                                         |
| 0.035        |                       | 26   | IANY=1                    |                                                                                      |                              |                             |                                         |
| 0736         |                       | ,,,  | NTERMENTERM               | 1+1                                                                                  |                              |                             |                                         |
|              |                       |      |                           |                                                                                      |                              |                             | •                                       |
| 0037         |                       |      | JTERMO(NTER               | M) = 10                                                                              |                              |                             | S A S                                   |
| 0038         |                       |      | JTERMOUNTER               |                                                                                      |                              |                             | <b>`</b> a                              |
| 0039         |                       |      |                           | (IBITS, JTERMO(NTE                                                                   | RM).ITERMD(N)                | (ERM).TEMP)                 | i -                                     |
| 0040         |                       |      |                           | 00) (TEMP(KQ),KQ=1                                                                   |                              |                             |                                         |
| 0040         |                       | 1000 |                           | JNASSIGNED TERM ADD                                                                  |                              |                             |                                         |
| 0041<br>0042 |                       | 1000 | GO TO 50                  | STADDIONED TERM AND                                                                  |                              |                             |                                         |
| 0042         | ç                     |      |                           |                                                                                      |                              |                             |                                         |
| 0043         | Q                     | 40   | CONTINUE                  |                                                                                      |                              |                             |                                         |
| 0.949        | С                     | .0   |                           |                                                                                      |                              |                             |                                         |
| 00/44        | Ŭ                     | 50   | CONTINUE                  |                                                                                      |                              |                             |                                         |
| 0045         |                       |      | K1=K2                     |                                                                                      |                              |                             |                                         |
| 0046         |                       |      | IF (IANY .                | EQ. 1) GO TO 5                                                                       |                              |                             |                                         |
| 0047         |                       |      | RETURN                    | · .                                                                                  |                              |                             |                                         |
| 0048         |                       |      | END                       |                                                                                      |                              |                             |                                         |
|              |                       |      |                           |                                                                                      |                              |                             |                                         |

## APPENDIX D

## COMPUTER LISTING OF CUBE LOGIC OR ASYNCHRONOUS DESIGN PROGRAM

SQLGSYN - SEQUENTIAL LOGIC SYNTHESIS PROGRAM REFERENCES 1. IDESIGN OF SEQUENTIAL SWITCHING CIRCUITS WITH THE CUBE LOGIC TECHNIQUE', S.L. SENDERS AND J.R. LUCCHESI (IBM), COMPUTER DESIGN, APRIL 1971, PP.59-64 THE FULLOWING ARRAYS CONTAIN DATA ABOUT NODES ON THE STATE FLOW DIAGRAM AND THE INTERNAL CUBE NODES. - CONTAINS CUBE VERTEX NUMBER FOR NODE IN NODNAM ARRAY NODE NODAAM - CUNTAINS ALL UNIGUE NODE NAMES NODADR - EACH ELEMENT REPRESENTS ONE VERTEX OF THE CUBE AND CONTAINS A POINTER TO THE NODE, NODNAM, AND NODUSE ARRAYS. - A DUPLICATE OF ARRAY 'NODE'. USED AS A WORK AREA. - A DUPLICATE OF ARRAY 'NODADR'. USED AS A WORK AREA. JODE JUDADR - COUNT OF THE NUMBER OF TIMES NODNAM APPEARS IN THE STATE NODUSE -FLOW FROM-TO LIST. - PRIORITY OF NODE WITH RESPECT TO MAPPING (HIGHER NUMBERS NODPR I GET MAPPED FIRST THE FOLLOWING ARRAYS CONTAIN DATA ON FROM-TO RELATIONSHIPS OF THE STATE-FLOW DIAGRAM NXEROM - FROM NODE OF STATE-FLOW FROM-TO'S - TU NODE OF STATE-FLOW FROM-TO'S - SIGNALS PRESENT FOR TRANSITION OF FROM-TO'S (MAY BE BOOLEAN EXPRESSION) NXTO NXSIG - STATUS OF CORRESPUNDING STATE-FLOW FROM-TO NXSTAT =0 NOT YET MAPPED ONTO CUBE =1 MAPPED ONTO CUBE =2 USED IN PRINTING EQUATIONS THE FOLLOWING ARRAYS CONTAIN DATA ON THE INTERNAL CUBE MAPPING NDEROM - FROM CUBE VERTEX NUMBER FOR THIS FROM-TO - TO CUBE VERTEX NUMBER FOR THIS FROM-TO NDTO THE CONTENTS OF NDFROM AND NDTO CONTAIN POINTERS TO THE NUDADR ARRAY WHICH IN TURN POINTS TO STATE-FLOW NUDES OR DUMMY NODES. THE FOLLOWING ARRAYS CONTAIN DATA ABOUT INPUT ASSIGNED STATES - CONTAINS THE STATE ASSIGNMENTS - CONTAINS ADDRESS OF THE NODE NAME FOR EACH ASSIGNMENT - NOT AN ARRAY BUT CONTAINS COUNT OF NUMBER OF ASSIGNED NSTATE NSTADR NSTAT STATES NEE - NUMBER OF STORAGE ELEMENTS REQUIRED MAXNOD - MAXIMUM NUMBER OF STATE-FLOW + DUMMY NODES ALLOWED

с С

c c

с с

C C C

С

с с

С С С

Č C

С

С

с с

С С С

С С

С

С

С

С

С

C C

С

C C

С С

C

ĉ

C

С

с С

С

С

ſ

С

С

С С С

С

```
С
       HAXFTX - MAXIMUM NUMBER OF STATE-FLOW FROM-TO'S
               - MAXIMUM NUMBER OF INTERNAL FROM-TO'S
С
       MAXETO
               - NUMBER OF STATE-FLOW + DUMMY NODES
- NUMBER OF STATE-FLOW FROM-TO'S
- NUMBER OF INTERNAL FROM-TO'S
000
       NC OUN T
       NXFTO
       NDFTO
       NODDUM - FIRST DUMMY NODE IN NODE ARRAYS
Ċ
       COMMON /COMMAP/
                                       NXFTO,
                                                   NDFTO,
                                                               NC OUNT,
                            'NFF,
                                                                          MAXETX,
                                                               ITRACE,
                            MAXNOD.
      1
                                       MAXETO,
                                                   NODDUM,
                            JODADR(128),
      2
           JODE (128).
                            NODNAM(16,128),NODADR(128),
      4
          NUDE (128).
                                                               NODPRI(128),
      5
          NODUSE(128).
          NXFROM(64),
                            NXTO(64),
                                             NXSIG(40,64),
                                                              NXSTAT(64),
          NDEROM(128),
                            NDT0(128)
       DIMENSION ITAGA(128)
       DIMENSION NSTATE(128), NSTADR(128)
       LOGICAL SSTATE
       INTEGER IVAR(32)/*A*,*B*,*C*,*D*,*E*,*E*,*G*,*H*,*I*,*J*,*K*,*L*,
      INTEGER IDUM(6)/*D*,*U*,*M*,*M*,*Y*,* */
       INTEGER SIGLEN, KRDTO(16), KRDSIG(40)
               - LENGTH OF LOOPS OR SEGMENTS
- HOLDS CLOSED NUN-SELF-INTERSECTING LOOPS OF STATE-FLOW
       LOOPLN
C
C
       NXLOUP
C
C
                  DIAGRAM
                - HOLDS MAPPING PRIORITY OF LOOP OR SEGMENT
       LOOPRI
       DIMENSION NXLOOP(24,32),LOOPRI(32),LOOPLN(32),LOPTAG(32)
       DIMENSION KARD(80)
       DIMENSION ISET(240)
       FOUIVALENCE (KARD(21), KRDTO(1)), (KARD(41), KRDSIG(1))
       DATA IAST / ***/
       DATA IBLNK, IOR, INOT, ILEFT, IRIGHT /* *, ***, *~*, *(*,*)*/
       KSETR(KSET) = MOD(KSET-1+240) + 1
С
       ID UNIT NUMBERS
с
ç
       IIN = 5
       I \cap UT = 6
       IFND=0
С
               - MAXINUM NUMBER OF STORAGE ELEMENTS TO BE CONSIDERED
- MAXIMUM NUMBER OF TRIALS AT MAPPING AT PRESENT NUMBER
OF STORAGE ELEMENTS
С
С
      MAXNEE
      MAXTRY
С
               - NUMBER OF SUCCESSFUL SOLUTIONS DESIRED
с
       MSUCES
ċ
      ITRACE - TRACE OF MAPPING
c.
                  =0 FINAL PRINTOUTS ONLY
С
                  =1 PRINTOUTS AFTER EACH SUCCESSFUL & UNSUCCESSFUL
                  MAPPING IN THE MAIN PROGRAM
=2 SAME AS =1 BUT INCLUDES UNSUCCESSFUL ATTEMPIS
С
С
                        AT LOWER LEVELS
С
С
    1 READ (IIN, 1180, END=999) MAXNEF, MAXTRY, MSUCES, ITRACE
 1180 FURMAT (415)
      WRITE (IOUT,1170) MAXNEE,MAXTRY,MSUCES,ITRACE
 1170 FORMAT ('1 SQLGSYN - SEQUENTIAL LOGIC CIRCUIT SYNTHESES'//
1 1X,15,' - MAXIMUM NUMBER OF STORAGE ELEMENTS TO BE USED FOR SOLUT
```

```
IF (NCOUNT .EQ. 0) GO TO 20
DO 15 I = 1,NCOUNT
        IF (ICUMPR (NODNAM(1,1),KARD(1),4*NAMLEN)) 15,25,15
    15 CONTINUE
 15 CUNTINGE
NEW NODE NAME. CHECK IF ROOM FOR IT
20 IF (NCOUNT .LT. MAXNOD) GO TO 22
WRITE (IOUT,1210) MAXNOD
1210 FURMAT (*0*** NUMBER UF STATE-FLOW NODES EXCEED *,15)
С
       GU TO 999
с
Ċ,
                  CHECK FOR ALL BLANKS FOR FROM NODE NAME
    22 DO 23 K = 1, NAMLEN
        IF (KARD(K) .NE. IBLNK) GO TO 24
    23 CONTINUE
 WRITE (IOUT,1220)
1220 FURMAT ('O*** FROM NODE NAME ALL BLANKS. TRY AGAIN.')
       IERR = I
    SAVE NODE NAME
24 NCOUNT = NCOUNT + 1
С
        I = NCOUNT
   00 21 K= 1.NAMLEN
21 NODNAM(K,I) = KARD(K)
С
    25 \text{ NODUSE(I)} = \text{NODUSE(I)} + 1
       NXFROM(NXFTO) = I
С
C٠
        CHECK IF STATE-FLOW TO NODE NAME IS NEW
С
        00 30 I=1,NCOUNT
        IF (ICOMPR(NODNAM11,I), KRDTO, 4*NAMLEN)) 30,45,30
    30 CONTINUE
        NEW NODE NAME. CHECK IF ROOM FOR IT.
IF (NCDUNT .LT. MAXNOD) GO TO 35
WPITE (IOUT,1210) MAXNOD
С
        GU TO 999
С
                 CHECK FOR ALL BLANKS IN TO NODE NAME
    35 DB 40 K=1,NAMLEN
IF (KROTU(K) .NE. IBLNK) GO TO 42
    40 CONTINUE
 WRITE (IOUT,1230)
1230 FORMAT (*O*** TO NODE NAME ALL BLANKS. TRY AGAIN.*)
        IERR = 1
    42 NCOUNT = NCOUNT + 1
        I = NCOUNT
        00 44 K = 1,NAMLEN
   44 NODNAM(K,I) = KRDTO(K)
BUMP USAGE COUNT AND SET POINTER
45 NODUSE(I) = NODUSE(I) + 1
С
        NXTO(NXETO) = I
С
č
        SAVE EXTERNAL SIGNAL(S) OR BOOLEAN EXPRESSION.
С
       DO 50 K = 1,SIGLEN
    50 NXSIG(K,NXFTO) = KRDSIG(K)
        GO TO 5
С
```

98

```
3 1X.15.1 - MAXIMUM VALUE OF TRIALS FOR EACH NUMBER OF STORAGE ELEM 4ENIS!//
       5 1X, I5, ' - NUMBER OF SOLUTIONS DESIRED'//
5 1X, I5, ' - TRACE PARAMETER')
С
         NAMLEN = 16
         SIGLEN = 40
IERR = 0
         MAXNOD = 128
         MAXFTX = 64
         MAXETO = 128
         NCOUNT = 0
         NXFTO = 0
         NDFTO = 0
         $STATE=.FALSE.
C
         INITIALIZE ARRAYS
С
С
         DO 4 I = 1, MAXNOD
NODE(I) = -1
NODADR(I) = 0
         NODUSE(I) = 0
         NODPRI(I) = 0
      DD 4 J = 1,NAMLEN
4 NODNAM(J,I) = IBLNK
         DO 2 I =1,MAXETX
NXEROM(I) = 0
         NXTO (I) = 0
         NXSTAT(I) = 0
      00 \ 2 \ J=1.SIGLEN
2 NXSIG(J,I) = IBLNK
         DU 3 I=1, MAXETO
NOFROM(I) = 0
    3 \text{ NDTO(1)} = 0
C,
С
         READ STATE-FLOW FROM-TO LIST
c
c
          PICK DUT ALL UNIQUE STATE-FLOW NODE NAMES AND COUNT HOW MANY TIME
          S EACH APPEARS.
С
 C
WRITE (IOUT,1190)
1190 FORMAT (*1 INPUT DATA*/)
5 NXFTO = NXFTO + 1
IF {NXFTO .LE. MAXFTX} GO_TO 7
WRITE {IOUT,1195} MAXFTX
1195 FORMAT (*0*** STATE-FLOW FROM-TO*'S EXCEED*,15)
CO_TO_909
      GO TO 999
7 READ (IIN,1200,END=89) KARD
 1200 FURMAT (80A1)
                    CHECK FOR ***
С
 IF (KARD(1) -EQ. IAST) GO TO 70
WRITE (IOUT,1205) NXETO,KARD
1205 FORMAT (1X,15,' FROM= ',20A1,'TO= ',20A1,'SIGNAL(S)= ',40A1)
C
         CHECK IF FROM STATE-FLOW NODE 15 NEW
```

С

```
С
       CHECK FOR **STATES* CARD
С
   70 IF (ICOMPR(KARD(1), ** S T A T E *;
YES IT IS. READ STATE ASSIGNMENT CARDS
                                                 T E ',24) ) 90,72,90
С
   72 $STATE = .TRUE.
      NSTAT=0
       WRITE (INUT,1772) KARD
   75 READ (IIN, 1200, END=89) KARD
1772 FOPMAT ('0',80A1/)

1772 FOPMAT ('0',80A1/)

IF (KARD(1) -EQ. IAST) GD TO 90

wpite (IOUT,1775) KARD

1775 FORMAT ('ASSIGNED STATE(UCTAL) = ',20A1,4' NODE NAME = ',60A1)
С
                CONVERT STATE ASSIGNMENT (IN OCTAL) TO INTERNAL BINARY
       NSTAT=NSTAT+1
       NSTATE (NSTAT)=0
       00 77 1=1,20
       IE = 21-I
IF (KARD(IE) .NE. IBLNK) GO TO 78
   77 CONTINUE
                ERROR. STATE ASSIGNMENT BLANK.
С
       WRITE (10UT,1777)
 1777 FORMAT ("OF ** ERROR. STATE ASSIGNMENT BLANK")
       ItRR=1
       GU TO 80
С
   78 DO 79 I=1,IE
79 CALL MPUT ( NSTATE(NSTAT), 32-3*1, KARD(IE+1-1), 5, 3)
             CHECK IF NODE NAME NEW
С
   80 DO 82 I=1, NCOUNT
       IF (ICUMPR (NODNAM(1,I),KARD(21), 4*NAMLEN )) 82,85,82
   82 CONTINUE
С
                ERPOR. NEW NAME
       WRITE (IOUT,1782)
 1782 FORMAT ('0#** ERROR, NODE NAME ON ABOVE CARD NOT ON ANY FROM-TO CA
     ARD 1/1
      IFPR=1
       GO TO 75
С
С
               SAVE ASSIGNED STATE DATA
   85 NSTADR(NSTAT) = I
                                                   e
       GO TO 75
с
С
       DETERMINE MINIMUM NUMBER OF STORAGE ELEMENTS
Ċ
       NEEDED FOR NUMBER OF STATE-FLOW NODES.
C
  89 IEND=1
   90 NFF =
             32
       IF (NCOUNT .EQ. 0 .OR. NXFTO .EQ. 1) GO TO 900
00 91 K=1,32
       CALL PBTST (4, NCOUNT-1, K-1, [VAL)
   1F (IVAL .EQ. 1) GO TO 92
91 NFF = NFF - 1
   92 NXFTO = NXFTO - 1
       NODDUM = NCOUNT+1
С
С.
                FILL IN DUMMY NODE NAMES
```

```
IF (NODDUM .GT. MAXNOD) GO TO 101
        N = 1
        DO 100 I=NODDUM,MAXNOD
   \frac{100 \ 105 \ J = 1,6}{105 \ NODNAM(J,I) = IDUM(J)}
        CALL CNVIAL (NODNAM(1,I),6,8,N,IER)
   100 N = N+ 1
101 MAXNUD = 2**NFF
        CALL LOGIC (NFF)
 UALL LUGIC INF;

WRITE (IOUT,1240) NXFTO,NCOUNT,NEF

1240 FORMAT (*1 SQLGSYN - SEQUENTIAL LOGIC CIRCUIT SYNTHESIS*/

1 *0 STATE-FLUW DIAGRAM FRUM-TO RECORDS= *,15/

2 *0 STATE-FLUW DIAGRAM NODES = *,15/

3 *0 MINIMUM NUMBER OF STORAGE ELEMENTS= *,15)
        WRITE (IOUT,1250) (I,(NODNAM(K,NXFROM(I)),K=1,NAMLEN),NXFRUM(I),
               (NODNAM(K, NXTO(I)), K=1, NAMLEN), NXTO(I),
       1
       2
            (NXSIG(J,I), J=1, SIGLEN), I=1, NXFTO)
  1250 FORMAT ('1 STORED STATE-FLOW FROM-TO LIST'/

1 '0ND. FROM',22X,'TU',24X,'SIGNAL'//

2 (1X,I4,2X,16A1,' (',I3,')',4X,16A1,' (',I3,')',4X,40A1))
C
С
        FOR FIRST PASS ASSIGN PRIORITY BASED ON NODUSE ARRAY
С
        CALL TAGSRT (NCOUNT, NODUSE, ITAGA)
        00 110 J = 1, NCOUNT
  110 NODPRI(ITAGA(J)) = J
С
         PRINT LIST OF STATE-FLOW NODES
С
С
        WRITE (IOUT,1260)
 1260 FURMAT ('1 STATE-FLOW NODES'//' NO. NAME',12X,' CNT PRI'/)
WPITE (IOUT,1270) (I,(NODNAM(K,I),K=1,NAMLEN),NODUSE(I),NODPRI(I),
       1
             I=1,NCOUNT)
 1270 FORMAT (1X,14,2X,16A1,215)
        IF (IERR .EQ. 1) GO TO 900
C
        DETERMINE LOOPS AND SEGMENTS IN STATE FLOW DIAGRAM
С
С
Ċ
        NLOOP
                  - COUNT OF NUMBER OF LOOPS IN NXLOOP
        NLOOP = 0
                  USE HIGHEST PRIORITY NODE AS A CONVENIENT STARTING POINT
С
        KODE = ITAGA(NCOUNT)
C.
                   SEARCH STATE FLOW FROM'S FOR THIS NODE
С
  145 DO 150 I = L,NXFTO
IF (NXFROM(I) .EQ. KODE .AND. NXSTAT(I) .EQ. 0) GO TO 160
  150 CONTINUE
                  ELSE START AT FIRST AVAILABLE FROM-TO
С
        DO 155 I = 1,NXFTO
IF (NXSTAT(I) .EQ. 0) GO TO 160
  155 CONTINUE
        GO TO 300
С
                   START LOOP
  160 NLOOP = NLOOP + 1
NXLOOP(1+NLOOP) = NXFROM(I)
        NXLOOP(2, NLOOP) = NXTO(1)
```

```
C
           2. OPEN SEGMENTS - LENGTH
С
  300 CALL TAGSRT (NLOOP, LOOPLN, LOPTAG)
       N = 0
       00 310 I' = 1,NLOOP
        K = LOPTAG(I)
       IF (NXLOUP(1,K) .EQ. NXLOOP(LOOPLN(K),K)) GO TO 310
       N = N + 1
       LOOPRI(K) = N
  310 CONTINUE
       00 320 I = 1,NLOOP
       K = LOPTAG(I)
IF (NXLOOP(1,K) .NE. NXLOOP(LOOPLN(K),K)) GO TO 320
       N = N + 1
LOOPRI (K) = N
  320 CONTINUE
с
с
       PRINT LOOPS AND SEGMENTS FOUND.
С
 WRITE (IOUT,1300)
1300 FORMAT (*1 LOOPS AND SEGMENTS IN STATE-FLOW FROM-TO LIST*/)
DO 350 I = 1,NLOOP
       WRITE (IOUT,1310) I,LOOPRI(I)
 1310 FORMAT ('OLOOP NUMBER =',14,6X, 'INITIAL PRIORITY=',14//
 1 20X, 'NODE'/)

WRITE (IOUT,1320) (NODNAM(J,NXLOOP(1,I)),J=1,NAMLEN),NXLOOP(1,I)

1320 FORMAT (10X, FROM*,5X,16A1,1X,'(',13,')')
       NN = LOOPLN(I)
       DO 330 K = 2,NN
WRITE (IOUT,1330) (NODNAM(J,NXLOOP(K,I)),J=1,NAMLEN),NXLOOP(K,I)
 1330 FORMAT (10X,* TO*,5X,16A1,1X,*(*,I3,*)*)
  330 CONTINUE
  350 CONTINUE
       С
с
С
       MAP LOOPS AND SEGMENTS ONTO CUBE
       NC = NCOUNT
       NSUCES = 0
NTRY = 0
  400 DO 401 I=1,MAXNOD
  NODE(I) = -1
401 NODADR(I) = 0
       \begin{array}{l} \mathsf{NCDUNT} = \mathsf{NC} \\ \mathsf{NDFTO} = \mathsf{O} \end{array}
       NTRY = NTRY + 1
Ċ
                 CHECK FOR INPUT ASSIGNED STATES
C,
Ċ
       IF (.NOT. $STATE) GO TO 409
THERE ARE ASSIGNED INPUT STATES. FILL IN NODE AND NODADR
ARRAYS TO REFLECT INPUT ASSIGNED STATES.
С
С
       DO 405 I=1.NSTAT
NODE(NSTADR(I)) = NSTATE(I)
  405 NODADR(NSTATE([]+1) = NSTADR([]
С
ċ
```

```
LOOPLN(NLOOP) = 2
        NXSTAT(I) = 1
  165 KFROM = NXTO(I)
  166 \text{ K}1 = 1
       NREM = 0
                  SEARCH FOR A CONTINUATION OF THIS LOOP
С
  SEARCH FOR A CONTINUATION

167 IF (K1 .GT. NXFTO) GO TO 175

DO 170 I = K1.NXFTO

IF (NXSTAT(I) .NE. 0) GO TO 170

NREM = NPEM + 1
        IF (NXFROM(I) .EQ. KFROM) GO TO 180
  170 CONTINUE
END OF LOOP PROCESSING
175 IF (NPEM .EQ. 0) GO TO 300
GO TO 145
С
                  LOOP CONTINUATION FOUND. CHECK IF THIS NODE ALREADY IN
С
                     LOOP.
С
  180 NN = LOOPLN(NLOOP)
       00 190 K=1,NN
        IF (NXLOOP(K,NLOOP) .EQ. NXTO(I)) GO TO 200
  190 CONTINUE
        OK. SAVE IT
LOOPLN(NLOOP) = LOOPLN(NLOOP) + 1
C
        NXLOOP(LOOPLN(NLOOP),NLOOP) = NXTO(1)
        NXSTAT(1) = 1
        GO TO 165
С
                   IF LOOPS TO IMMEDIATELY PRECEDING NODE, THEN OK.
С
  200 IF (K .NE. NN-1) GO TO 210
THE SKIPPED STATE-FLOW FROM-TO WILL BE PICKED UP LATER
K1 IS SET HERE SO THAT THE FROM-TO NEXT EXAMINED WILL BE
С
с
С
                    THE FIRST ONE FOLLOWING THE LAST ONE PROCESSED.
        KI = I + I
        GO TO 167
                  IF LOOP TO FIRST NODE IN LOOP, SAVE IT AND GO TO NEXT LOOP
С
  210 IF (K .NE. 1) GO TO 220
LOOPLN(NLOOP) = LOOPLN(NLOOP) + 1
NXLUOP(LOOPLN(NLOOP),NLOOP) = NXTO(1)
        NXSTAT(I) = 1
       GU TU 145
                  APPARENTLY A SMALLER LOOP FOUND. SAVE BEGINNING SECTION
С
  220 00 230 J = 1,K
  230 NXLOOP(J,NEOOP+1) = NXLOOP(J,NEOOP)
  LOOPLN(NLOOP+1) = K

LOOPLN(NLOOP+1) = K

KFROM = NXLOOP(K,NLOOP+1)

SHIFT NLOOP STRING OVER

DO 240 J = K,NN

240 NXLOOP(J-K+1,NLOOP) = NXLOOP(J,NLOOP)
С
        LOOPLN(NLOOP) = LOOPLN(NLOOP) - K + 2
        NXLOOP(LOUPLN(NLOOP),NLOOP) = NXTO(I)
        NXSTAT (I) = 1
        NLOOP = NLOOP + 1
        GO TO 166
С
          ASSIGN INITIAL LOOP PRIORITY
с
с
          1. CLOSED LOOPS - LENGTH
```

```
С
С
                  SUCCESSFUL SOLUTION. PRINT SOME PARAMETERS
С
С
  600 NSUCES = NSUCES + 1
        WRITE (IDUT, 1610) NSUCES, NEF, NCOUNT, MAXNOD, NTRY
 1610 FORMAT ('I RESULTS OF SOLUTION NUMBER',14//

1 1x,15,' STORAGE ELEMENTS USED'//

2 1X,15,' STATES USED OUT OF',15,' TOTAL STATES AVAILABLE'//

3 1X,15,' TRIALS THIS NUMBER OF STORAGE ELEMENTS'///).
С
                  PRINT NODE MAP.
С
С
       WRITE (IDUT,1620)
 1620 FORMAT ('0',10X, NODE MAP'//7X, NODE NAME',9X, STATE (LITERAL FORM
      A}!/}
        00 650 I = 1,NCOUNT
CALL TFRMOT (NFF,NODE(I),0,KARD)
CONVERT INTERNAL NODE TO A,B,C'S
С
         KARD(NEE+1)=18LNK
        KARD(NFF+2)=ILEFT
        K=NFF+2
        N=N1+V2
DO 630 NN = 1.NFF
CALL PRTST (4.NODE(I).31-NFF+NN, IB)
IF (IB .EQ. 1) GO TO 625
KARD(K+1) = INOT
        KARD(K+2) = IVAR(NN)
        K = K+2
        GO TO 630
   625 KARO(K+1) = IVAR(NN)
        K = K+1
   630 CONTINUE
        K=K+1
        KARD(K)=IRIGHT
 wRITE (IDUT,1630) I,(NODNAM(J,I),J=1,NAMLEN),(KARD(J),J=1,K)
1630 FORMAT (1x,14,2x,16A1,2x,80A1)
  050 CONTINUE
С
C
                  PRINT INTERNAL FROM-TO MAPPING
С
        WRITE (IOUT,1660)
 1660 FORMAT ('1',10X,"FROM-TO TABLE'/' FROM NODE',19X,"TO NODE'/)
DO 670 I = 1,NDFTO
        WRITE (IOUT, 1670) (NODNAM(J, NODADR(NDFROM(I)+1)), J=1, NAMLEN),
       1 NODADR(NDFROM(I)+1),
               (NODNAM(J,NODADR(NDTO(I)+1)), J=1,NAMLEN)
      1
          ,NODADR(NDTO(I)+1)
      2
 1670 FORMAT (1X,16A1,1X,*(*,13,*)*,6X,16A1,1X,*(*,13,*)*)
  670 CUNTINUE
        *******
С
                                                                       ******
č
        FORM SET AND RESET EQUATIONS FOR STORAGE ELEMENTS
C
        WRITE (IOUT, 1090)
. WKITE (IOUT)
1090 FORMAT (IHI)
C
```

С

```
SORT INTO PRIORITY
С
 409 CALL TAGSRT (-NLOOP,LOOPRI,ITAGA)
IF (ITRACE .GE. 1) WRITE (IOUT,1400) (NTRY,NFF,I=1,188)
1400 FORMAT (1H1/4(' BEGIN TRIAL=',I3,' FOR NFF=',I3))
         NLL = 1
   410 NL = ITAGA(NLL)
c
                    CHECK FOR CLOSED LOOPS
         CHECK FOR CLOSED LDUPS
IF (NXLOOP(1,NL) .NE. NXLOOP(LOOPLN(NL),NL)) GO TO 420
YES CLOSED. GO MAP IT
CALL LOPMAP (LOOPLN(NL)-1, NXLOOP(1,NL),IRET)
IF (IRET .GT. 0) GO TO 430

С
         GO TO 460
С
  MAP SEGMENT
420 CALL SEGMAP (LOOPLN(NL),NXLOOP(1,NL),IRET)
IF (IRET .GT. 0) GO TO 430
č
С
                     SET UP FOR NEXT LOOP OR SEGMENT
C.
 460 NLL = NLL + 1
IF (ITRACE .GE. 1) WRITE (IOUT,1460) NL
1460 FORMAT ('1 THE FOLLOWING NODE MAP IS FOR LOOP',14,' WHICH WAS SUC
       ICESSFULLY MAPPED'/)
IF (ITRACE .GE. 1) CALL ERRPRT
IF (NLL .GT. NLUOP) GD TO 600
         GO TO 410
С
С
                      MAPPING UNSUCCESSFUL. UP PRIORITY OF LAST LOOP OR
                      SEGMENT TO GET IT MAPPED SOONER.
C
С
 480 IF (ITRACE .GE. 1) WRITE (IOUT,1480) NL,NTRY
1480 FORMAT (* *** MAPPING OF LOOP OR SEGMENT*,13,* UNSUCCESSFUL. NUMBE
18. OF TRIES=*,14)
         IF (NTRY .GE. MAXTRY) GO TO 500
с
с
                     BUMP PRIORITY OF LOOP THAT FAILED
         ITEMP = LOOPRI(NL)
         LOOPRI(NL) = LOOPRI(NL) + 1
 IF (ITRACE .GE. 1) WRITE (IOUT,1482) NL,LOOPRI(NL),ITEMP
1482 FORMAT ('0*** LOOP',I4,' PRIORITY NOW=',I4,' WAS=',I4)
485 IF (ITRACE .LT. 1) GO TO 400
         CALL ERRPRT
         WRITE (IOUT,1481)
 1481 FORMAT (10 STATUS OF MAPPING AT FAILURE PRECEDES THIS MESSAGE'
              1X,120(***)/)
       1
         GO TO 400
С
С
                     TRY BUMPING NEF BY ONE
С
   500 NFF = NFF + 1
 IF (NFF .GT. MAXNFF) GO TO 900
WRITE (IOUT,1500) NFF
1500 FOPMAT (*0*** STORAGE ELEMENTS INCREASED TO *,14/)
         MAXNOD = 2**NFF
         CALL LOGIC (NFF)
         NTRY = 0
         GO TO 485
```

```
IF (NODADR(KTO+1) .LT. NODOUM) GO TO 2125
                 CONTINUE DUMMY PATH
С
        NP = 0
        KS = KTO
       DG 2121 NN=1,NDFTO
IF (NDFPOM(NN) .NE. KTO) GO TO 2121
       NP = NP + 1
JTU = NDTO(NN)
 2121 CUNTINUE
       IF (NP-1) 2122,2119,2123
                 NO APPARENT PATH (HAZARD)
С
C ND APPARENT FAIL COALAGY

2122 WRITE (IOUT,12122) KS

12122 FORMAT (*0',120(**'))* PROBABLE HAZARD AT CUBE NODE= ',Z3/

1 1X,120(**'))

GO TO 2125

C MULTIPLE PATHS FROM A DUMMY NODE (PROBABLE RACE).
.....1
2123 WRITE (IOUT,12123) KS
12123 FOPMAT ('0',120('*')/' PROBABLE RACE AT CUBE NODE= ',28/
1 1X,120('*'))
       GO TO 2119
 2125 CONTINUE
с
С
       DO 2130 NN=1+NXFT0
       IF (NODE(NXFROM(NN)) .NE. NDFROM(KK) .OR. NODE(NXTO(NN)) .NE.
           KT0) GO TO 2130
      1
                 FOUND SIGNAL. SCAN FIELD BACKWARDS TO ELIMINATE BLANKS
С
       00 2131 I=1,SIGLEN
        IK = SIGLEN+1 - I
        IF (NXSIG(IK,NN) .NE. IBLNK) GO TO 2132
 2131 CONTINUE
С
 2132 ISET(KSETR(KSET+1)) = ILEFT
        KSET = KSET + 1
        00 2133 I=1,IK
        KSFT = KSET + 1
 2133 ISET(KSETR(KSET)) = NXSIG(I,NN)
       KSET = KSET + 1
        ISET(KSETR(KSET)) = IRIGHT
 2130 CONTINUE
C
                 CHECK FOR PRINT LINE OVERFLOW
        ARRAY ISET IS TREATED AS CIRCULAR
IF (KSET - IQBEG .LT. 120) GO TO 2100
С
                PRINT FROM LOBEG TO KORSET
С
        IF (KPR .GT. 0) GO TO 2105
       KPR = 1
       IF (NEQ .EQ. 1) WRITE(IOUT,1100) IVAR(N),(ISET(KSETR(I)),I=IQBEG,
             KORSET)
      1
       IF (NEQ .EQ. 2) WRITE(IOUT,1110) IVAR(N),(ISET(KSETR(I)),I=IQBEG,
             KORSETI
      1
       GO TO 2109
 2105 WRITE (INUT,1105) (ISET(KSETR(I)),I=IQBEG,KORSET)
 2109 IQBEG = KORSET+1
С
 2100 CONTINUE
                 PRINT REMAINING PORTION OF THE EQUATION
C
```

```
START SCAN OF VARIABLES (NODE BIT 31 IS FIRST)
С
С
        DO 2200 N=1,NFF
С
                  LOUP TO 2199 TO PICK FIRST SET THEN RESET EQUATIONS
        DO 2199 NEQ = 1,2
         KSET = 0
        00 2101 I=1,240
 2101 ISET(I) = IBLNK
         KOPSET = 0
        I ЭНЕС = 1
        KPR = 0
С
Ċ
C
       DO 2100 LOOP MATCHES ALL INTERNAL FROM.TO'S WITH FACH OTHER LOOKING
        FOR ONES WHICH DIFFER ONLY IN THE VARIABLE IN QUESTION
С
        00 2100 KK=1,NDFT0
CALL NODFCM (NDFROM(KK),NDTO(KK),32-N,IVAL)
        IF (IVAL .NF. NEQ) GO TO 2100
С
        ADD TERMS TO EQUATIONS. NEG=1 FOR SET. NEG=2 FOR RESET
С
С
        IF (KSET .EQ. 0) GO TO 2111
OR TERMS AFTER FIRST
IF (KSET-IOBEG-IOBEG .LT. 120) KORSET = KSET
ISET(KSETR(KSET+2)) = IOR
С
         KSET = KSET + 3
 2111 00 2120 NN=1.NFF
С
                    IF THE SET OR RESET EQUATION BEING WRITTEN IS FOR THE SAME
        INTERNAL VARIABLE (IE, N=NN), THEN THE VARIABLE IS
PROBABLY REDUNDANT. A CHECK IS PERFORMED TO DFTECT IF
THIS FROM-TO MAPPING IS PART OF AN EDGE LOOP. IF IT IS,
RETAIN THE FULL PRESENT STATE MINTERM.
IF (N.N.F. NN) GO TO 2114
С
С
с
ç
        00 2112 KQ=1,NDFT0
        IF (NDFROM(KK) .EQ. NDTO(KQ) .AND. NDTO(KK) .EQ. NDFROM(KQ))
       Α
                  GO TO 2114
 2112 CONTINUE
        GB TO 2120
 2114 CALL PBTST (4,NDFROM(KK),31-NFF+NN,1B)
IF (ID .EQ. 1) GO TO 2115
ISET(KSETR(KSET+1)) = INOT
        ISET(KSETR(KSET+2)) = IVAR(NN)
        KSET = KSET + 2
        GU TO 2120
C.
 2115 ISET(KSETR(KSET+1)) = IVAR(NN)
        KSET = KSET + 1
 2120 CUNTINUE
                   LOOK FOR EXTERNAL SIGNALS TO BE AND "ED WITH THIS TERM
С
с
        IF NDTO(KK) IS A DUMMY NODE, THEN FOLLOW DUMMY PATH UNTIL AN
EXTERNAL NODE IS REACHED. IF THERE ARE TWO POSSIBLE PATHS TO
FULLOW, PRINT ERROR MESSAGE TO THAT EFFECT (PROBABLE RACE).
Ċ
С
С
С
        JTO = NDTO(KK)
```

2119 KTO = JTO

```
CHECK IF KFROM AND KTO ARE NEIGHBORS
C,
        CALL NABOR (NFF,KFROM,KTO,M)
IF DNLY ONE BIT DIFFERENT, NODE MAPPING SUFFICIENT
С
        IF (M .NE. 1) GO TO 120
CHECK IF APPROPRIATE FROM-TO IN TABLES
С
        IF (NDFTD .LE. 0) GO TO 111
ND 110 JF=1.NDFTO
        IF (KEROM .EQ. NDEROM(JE) .AND. KTO .EQ. NDTO(JE)) GO TO 900
   110 CONTINUE
                   NOT FOUND. ADD IT.
С
   111 NDFTO = NDFTO + 1
NDFROM(NOFTO) = KFROM
        NOTO(NDFTO) = KTO
        GN TO 900
С
                    MORE THAN ONE CUBE NODE AWAY. CHECK IF ANY EXISTING
С
   DUMY PATHS LEAD TO NODE KTO.
120 IF (M.EQ. 0) GO TO 900
CALL DUMXST (KTO,N.NODSAV)
С
         IF (N .NE. 0) GO TO 250
C
                    NO DUMMY PATHS EXIST. ROUTE ONE
с
         JTO = KTO
         ISW = 1
   130 DO 150 MAX=1,NFF
        IFROM = KFROM
         ITO = JTO
   140 IPREF = 0
         IF (2*MAX .LE. NFF) IPREF = LXOR(IFROM, ITO)
        IF (2-MAX LEE NFF) IFREF = LAUR(IFROM,ITO)
CALL NSELCT (IFROM,IPREF,NFF,JUDADR,NEIGH,IERR)
IF (IERR .GT. 0) GO TO 145
ADD DUMMY NODE
CHECK FOR NODE ARRAY OVERFLOW
C.
ċ
        IF (NCOUNT .GE. MAXNOD) GO TO 145
NCOUNT = NCOUNT + 1
         JODE(NCOUNT) = NEIGH
        JODADR(NFIGH+1) = NCOUNT
NDFTO = NDFTO + 1
NDFKOM(NDFTO) = IFROM
NDTO(NDFTO) = NEIGH
                    CHECK IF ROUTING COMPLETE
с
         CALL NABOR (NFF, NEIGH, JTO, M)
        IF (M .EQ. 1) GO TO 160
IFROM = NEIGH
        GO TO 140
  SET UP TO TRY ANOTHER PATH

145 NN = NCA + 1

IF (NN .GT. NCOUNT) GO TO 149

RESTORE ARRAYS
С
С
        DO 148 J=NN,NCOUNT
        JODADR(JODE(J)+1) = 0
   148.JUDE(J) = -1
   149 NDFTO = NDA
NCOUNT = NCA
   150 CONTINUE
        IF (KPR .GT. 0) GO TO 2205
        IF (NFQ.EQ.1) WRITE(IOUT,1100) IVAR(N),(ISET(KSETR(I)),I=IQBEG,
              KSET)
       1
 1100 FORMAT ('O SET ',A1,' = ',120A1)
IF (NEQ.EQ.2) WRITE(IOUT,1110) IVAR(N),(ISET(KSETR(I)),I=IQBEG,
 1 KSET)
1110 FORMAT('ORESET ',A1,' = ',120A1)
       GD TO 2199
 2205 WRITE (IOUT,1105) (ISET(KSETR(I)),I=IOBEG,KSET)
1105 FORMAT (11X,120A1)
 2199 CONTINUE
C
С
2200 CONTINUE
WRITF (IOUT,1090)
IF (NSUCES .LT. MSUCES) GO TO 400
IF (IEND) 1,1,999
с
                   RUN UNSUCCESSFUL. PRINT MESSAGE.
С
 900 WRITE (IBUT,1900)
1900 FORMAT ('1 RUN UNSUCCESSFUL')
        GD TD 999
   999 ST.DP
```

```
999 ST.OP
END
```

, VITA ↔ Bienvenido C. Peralta

Candidate for the Degree of

Master of Science

# Thesis: COMPUTER AIDED DESIGN OF A DIGITAL FREQUENCY SYNTHESIZER

Major Field: Electrical Engineering

Biographical:

Personal Data: Born in Manila, Philippines, December 7, 1927, the son of B. L. Peralta and Dr. Maria A.Cid.

- Education: Graduated from Ilocos Norte High School, Ilocos Norte, Philippines in 1946; received the Bachelor of Science degree in Electrical Engineering from Oklahoma State University in 1953; completed requirements for the Master of Science degree from Oklahoma State University in May, 1974.
- Professional Experience: Educational grant and on-thejob training at FAA Aeronautical Center, Oklahoma City, 1947-49; instructor, University of Missouri at Rolla, 1953-55; research assistant, Emerson Electric, St. Louis, Mo., 1956-60; design engineer, Honeywell Corporation, Clearwater, Fla., 1960-65; project engineer, Battelle Laboratories, 1965-68; staff engineer in computer programming, Magnavox Company, 1968.

Professional Organizations: Member IEEE and National Management Association.