## THE STATE MATRIX METHOD FOR

### THE SYNTHESIS OF DIGITAL

### LOGIC SYSTEMS

 $\mathbf{By}$ 

ROBERT L. WOODS () Bachelor of Science

Southern Methodist University

Dallas, Texas

1967

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, 1970 THE STATE MATRIX METHOD FOR

STATE

5 1970

TAL PSIT

LOGIC SYSTEMS

# Thesis Approved:

a esiş Advisen Graduate College Dean theof

### ACKNOWLEDGMENTS

I would like to take this opportunity to express my thanks to those people involved in this thesis. In particular, I wish to thank Messrs. Engelland, Brun, and Gertsen for their encouragement during the earily stages of development of this synthesis philosophy.

Thanks are in order to my committee, Professors K. N. Reid, E. C. Fitch, and P. A. McCollum, and a special thanks to Dr. Reid for serving as my thesis adviser.

I also wish to thank Dr. Fitch for allowing this thesis to be published under the Basic Fluid Power Research Program even though this work was not supported by BFPR.

I want to thank Velda Davis for providing such an excellent typing service. It is greatly appreciated.

Those of you who have not undertaken a formal writing such as this cannot realize how important a good wife can be. Those who have, know what I mean when I say, thank you, Brenda.

iii

## TABLE OF CONTENTS

| Chapter | <b>•</b>                                                          | Page                       |
|---------|-------------------------------------------------------------------|----------------------------|
| I.      | INTRODUCTION                                                      | 1                          |
|         | Background                                                        | 2<br>3<br>5                |
| II.     | THE FEEDBACK SEQUENTIAL STATE MATRIX<br>SYNTHESIS PROCEDURE       | 7                          |
|         | Formal Matrix Representation Persistent States                    | 7<br>11<br>19<br>23<br>26  |
| III.    | THE STATE MATRIX SYNTHESIS PROCEDURE<br>FOR RANDOM INPUT CIRCUITS | 34                         |
|         | The Primitive Flow Table                                          | 34<br>39<br>41<br>43<br>46 |
| IV.     | DIGITAL EQUATION SIMULATION AND THE<br>CANONICAL FLOW TABLE       | 54                         |
|         | Digital Equation Simulation                                       | 55<br>61                   |
| v.      | DIGITAL COMPUTER PROGRAMS                                         | 67                         |
|         | Synthesis Program LOGSYN                                          | 68<br>70                   |
| VI.     | SUMMARY AND CONCLUSIONS                                           | 72                         |
|         | Summary                                                           | 72<br>73<br>77             |
| A SELEC | CTED BIBLIOGRAPHY                                                 | 80                         |

| Chapter                                   | Page |
|-------------------------------------------|------|
| APPENDIX A - THE PASSIVE MEMORY           | 81   |
| APPENDIX B - LISTING OF COMPUTER PROGRAMS | 90   |
| APPENDIX C - EXAMPLE COMPUTER SOLUTIONS   | 104  |
|                                           |      |
| y.                                        |      |
|                                           |      |

· .

 $\mathbf{v}$ 

# LIST OF TABLES

| Table      |                                                                                                                                                            | Page |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| I.         | The Developing State Matrix Relation<br>for the Sequence $Z_1$ , $Z_2$ , $\overline{Z}_1$ , $\overline{Z}_2$                                               | 10   |
| II.        | The State Matrix Relation for the Sequence $Z_1$ , $\overline{Z}_1$ , $Z_2$ , $\overline{Z}_2$                                                             | 12   |
| III.       | The State Matrix Relation for $Z_1$ , $Z_2$ , $\overline{Z}_1$ , $\overline{Z}_2$ , $Z_1$ , $\overline{Z}_1$ , $\overline{Z}_2$ , $Z_1$ , $\overline{Z}_1$ | 20   |
| IV.        | The State Matrix for a 2, 2, 1 Counter                                                                                                                     | 24   |
| <b>V</b> . | Primitive Flow Table for Example 3.1                                                                                                                       | 36   |
| VI.        | Primitive Flow Table for Example 3.2                                                                                                                       | 37   |
| VII.       | Canonical Flow Table for Example 3.2                                                                                                                       | 38   |
| VIII.      | The State Matrix Relation for Example 3.1                                                                                                                  | 40   |
| IX.        | The State Matrix Relation for Example 3.2                                                                                                                  | 41   |
| Χ.         | The Unique State Matrix Relation for<br>Example 3.2                                                                                                        | 43   |
| XI.        | The Primitive Flow Table for Example 3.3                                                                                                                   | 51   |
| XII.       | Step-By-Step Development of Digital<br>Equation Simulation                                                                                                 | 58   |
| XIII.      | The Development of the Canonical Flow Table                                                                                                                | 63   |

vi

### LIST OF FIGURES

| Figu | re                                                                                                                                | Page |
|------|-----------------------------------------------------------------------------------------------------------------------------------|------|
| 1.   | Hydraulic Circuit Illustrating Notation                                                                                           | 8    |
| 2.   | Synthesized Hydraulic Circuit for $Z_1$ , $\overline{Z}_1$ , $Z_2$ , $\overline{Z}_2$                                             | 16   |
| 3.   | Hydraulic Implementation for $Z_1$ , $Z_2$ ,<br>$\overline{Z}_1$ , $\overline{Z}_2$ , $Z_1$ , $\overline{Z}_1$                    | 22   |
| 4.   | Hydraulic Implementation for<br>1, $\overline{1}$ , 1, $\overline{1}$ , 2, 3, 1, $\overline{2}$ , $\overline{1}$ , $\overline{3}$ | 33   |
| 5.   | Logic Circuit for Example 3.3                                                                                                     | 53   |
| 6.   | Flow Chart for Simulation Method                                                                                                  | 56   |
| 7.   | Flow Diagram for Logic Systems Program                                                                                            | 69   |
| 8.   | Passive Memory Valve                                                                                                              | 82   |
| 9.   | Fluidic Memory Circuit                                                                                                            | 84   |
| 10.  | Passive Memory Assignment Circuits                                                                                                | 86   |
| 11.  | Passive Memory Code Schematic                                                                                                     | 87   |

### CHAPTER I

### INTRODUCTION

The technology of switching circuit theory, although relatively young, has found great application and utility in modern design. Most of the theory has been developed for application in electrical engineering since electronics has dominated the field of computation and logic for the last dew decades.

Recent years have seen a rebirth of the use of a fluid medium to perform the logic and computation in sequential machines. The newly emerging field of fluid technology termed "fluidics" is one major reason for this rebirth of fluid logic. Since fluid power is often used as the muscle of machines, it is convenient also to use the fluid itself for the required computation in order to avoid the electrical to fluid interfaces.

To realize maximum utilization of fluid logic devices, it is necessary to develop a technology of switching circuits applicable to fluid circuits. The theory should consider the unique properties of fluid devices not only in the implementation of circuits, but also in the synthesis procedure itself. The synthesis procedure presented in this

thesis does take advantage of the unique properties of devices in order to produce simple fluid circuits containing minimal hardware.

### Background

Modern switching theory had its origin in 1938 when C. E. Shannon (9), of M.I.T., applied the laws of Boolean algebra to the representation of electrical switches.<sup>1</sup> Although this was a great advancement for combinational switching circuits, there was no formal procedure for the synthesis of sequential switching circuits until 1954 when D. A. Huffman (3) and E. F. Moore (8) independently developed the synthesis technique which is used today. This technique has gained such widespread use and application that today it is taught at every major university and is even referred to as the "classical method". The synthesis procedure presented in this thesis relies upon much of the notation of the classical method. The reader not familiar with this method, should refer to a book on classical switching theory (2), (5), (7), (8).

E. C. Fitch (2), of Oklahoma State University, was one of the first authors to apply the methods of sequential switching circuit theory to hydraulics. However, his work did not take into account any special properties of hydraulic valves except in the implementation of logic circuits.

<sup>&</sup>lt;sup>1</sup>Numbers in parentheses refer to references in the Selected Bibliography.

Later work at Oklahoma State University by J. H. Cole (1) did consider the properties of devices in the synthesis procedure. Dr. Cole used the properties of the passive memory devices to produce extremely simple circuits for the feedback sequential type problem. This work has been a major advancement for the field even though its scope of application is limited.

G. E. Maroney (6) extended Cole's tabular method to include the random input type circuit. This method was fundamentally the same as Cole's except that the random input possibility necessarily complicated the execution of the method. This technique also utilized the passive memory effect to reduce hardware.

Development of the State Matrix Method

The state matrix synthesis procedure evolved from the assumption that the outputs are related to the inputs and the past state of the system. This relationship can be written in matrix form as:

$$\begin{bmatrix} \mathbf{Z} \end{bmatrix} = \begin{bmatrix} \mathbf{M} \end{bmatrix} \begin{bmatrix} \mathbf{X} \end{bmatrix}.$$

Here, the outputs are contained in the  $\begin{bmatrix} Z \end{bmatrix}$  vector, the  $\begin{bmatrix} X \end{bmatrix}$  vector contains the inputs, and the matrix  $\begin{bmatrix} M \end{bmatrix}$  contains output and memory information. This binary matrix changes with time to yield different outputs representing the different states of a sequence.

Early experiments with this type of synthesis were restricted to the feedback sequential type problems because of their simplicity. A close examination of the resulting equations revealed that they were essentially identical to those obtained from Cole's method. This was very encouraging since Cole's method was known to produce valid expressions. The matrix arrangement of this method also gave insight to many of the hidden subtleties of Cole's method.

Once the rules for the synthesis of feedback sequential circuits using state matrices were defined, the method was extended to handle the random input problems. The main difference between the state matrix methods for random input and feedback sequential problems was the input vector used. The feedback sequential input vector contained only the changed input, whereas the random input vector contained the total input state.

The random input form of the state matrix synthesis procedure has since received more attention since it is the more general procedure. This form will also handle the feedback sequential problems in some respects better than the original state matrix method. Hereafter, the random input form of this method will be referred to simply as the "state matrix method", and the method using the changed input vector will be referred to as the "feedback sequential state matrix method."

### Scope and Results of Study

Although the state matrix synthesis procedure is the most important item in this thesis, many other original topics have arisen from this study. The major accomplishments of this study are:

- (1) The development of the feedback sequential state matrix synthesis procedure. (Chapter II)
- (2) The development of the state matrix synthesis procedure for random input circuits.(Chapter III)
- (3) A digital computer program to perform the state matrix synthesis procedure. (Chapter V)
- (4) The development of a simulation technique to check the logical implications of digital equations. (Chapter IV)
- (5) A digital computer program to perform the digital equation simulation and to formulate the implied primitive flow table. (Chapter V)
- (6) The definition of a standard format for the primitive flow table. (Chapter IV)

The state matrix synthesis procedures have the following distinguishing features:

- (1) The basic concepts of circuit synthesis are much easier to grasp than those of other methods.
- (2) The execution of the procedure is straightforward with few or no exceptions to

established rules.

- (3) The resulting digital equations have few of the usual logical complications.
- (4) The procedure takes advantage of device properties to produce circuits with fast response and minimal hardware.
- (5) There is virtually no limitation upon the size or length of the problems which can be handled.

The simulation method presented here provides a check upon the digital equations resulting from a synthesis procedure. Each possible input change is systematically inspected for its effect upon circuit equations and the resulting transitions are recorded in a primitive flow table. This flow table may then be compared to the original flow table which should contain identical information.

In comparing the simulated flow table to its original primitive flow table, it is convenient, if not necessary, to establish a standard flow table format. For this reason, a method similar to the simulation method is used to define the canonical flow table format.

The computer programs included in Appendix B perform the mechanics of synthesis or simulation rapidly and accurately. These programs encompass all of the defined rules and methods for the analysis of digital logic systems and can be utilized to good advantage in design work.

### CHAPTER II

# THE FEEDBACK SEQUENTIAL STATE MATRIX SYNTHESIS PROCEDURE

Although feedback sequential circuits are comparatively simple, they have found a large field of application in modern automation. Consequently, the synthesis of such circuits is of major importance to industrial designers.

Feedback sequential circuits are characterized by their use of a signal indicating the completion of one event to initiate the next event in a prescribed sequence. Feedback sequential circuits are automatic and, once started, require no further attention to sustain sequential action.

### Formal Matrix Representation

In sequential circuits, each element is associated with one corresponding output from the logic circuit. In a hydraulic circuit this element is typically a hydraulic cylinder and the output is the fluid flow which actuates the cylinder. Since there is usually more than one element in a sequential machine, it is convenient to let  $Z_1$  represent the output which extends cylinder one and  $\overline{Z}_1$  represent the

retract output for the cylinder.<sup>1</sup> The signal  $X_2$  is used as an input to the logic circuit indicating the full extension of cylinder two, and the signal  $\overline{X}_2$  appears when cylinder two is fully retracted. Figure 1 illustrates a physical realization of these variables. The reader who is unfamiliar with hydraulic circuit notation should refer to the literature.



Figure 1. Hydraulic Circuit Illustrating Notation

Using this notation, a sequence involving two cylinders

<sup>&</sup>lt;sup>1</sup>This notation is somewhat unfortunate since  $Z_1$  is used in this chapter to specify only the <u>change</u> of cylinder one, not its continuous state. Also,  $Z_1$  and  $\overline{Z_1}$  are not perfect complements since the specification of one does not imply the other. A more appropriate notation would be  $\Delta Z_1$ , etc.; however, the Z,  $\overline{Z}$  notation is used here for simplicity. A similar statement is true for the inputs X and  $\overline{X}$  used in this chapter only.

can be written as  $Z_1$ ,  $Z_2$ ,  $\overline{Z}_1$ ,  $\overline{Z}_2$ . This implies that cylinder one extends, then cylinder two extends, cylinder one retracts, cylinder two retracts, and then the entire sequence is repeated indefinitely. Each event is initiated by the completion of the proceeding event.

The synthesis of a circuit to execute this sequence proceeds from the assumption that the required outputs from the logic circuit are related to the inputs by the matrix equation given below.

$$\begin{bmatrix} Z_{1} \\ \overline{Z}_{1} \\ \vdots \\ Z_{n} \\ \overline{Z}_{n} \end{bmatrix} = \begin{bmatrix} m_{11} & m_{12} & \dots & m_{1n} \\ \vdots & & \ddots & \vdots \\ m_{n1} & \dots & m_{nn} \end{bmatrix} \begin{bmatrix} X_{1} \\ \overline{X}_{1} \\ \vdots \\ X_{n} \\ \overline{X}_{n} \end{bmatrix}$$
(1)

Recall from the rules of matrix multiplication that when multiplying the matrix [M] by the [X] vector, every entry in the j<sup>th</sup> column of [M] is multiplied by the element in the j<sup>th</sup> row of [X]. Thus, each column in [M] is associated only with the corresponding input element of [X].

For the sequence under consideration, the first event is the extension of cylinder one which results from the previous retraction of cylinder two. Thus, the state number 1 is entered in the matrix in the row of the  $Z_1$  output and the column associated with the  $\overline{X}_2$  input (column four). See Table I.

The next event, the extension of cylinder two, is initiated by the full extension of cylinder one. Hence, the state number 2 is entered in the  $Z_2$  row and the  $X_1$ column. Similarly, state 3 is in the  $\overline{Z}_1$  row and the  $X_2$ column. The sequence is completed by state 4 in the  $\overline{Z}_2$  row,  $\overline{X}_1$  column.

### TABLE I

THE DEVELOPING STATE MATRIX RELATION FOR THE SEQUENCE  $Z_1$ ,  $Z_2$ ,  $\overline{Z}_1$ ,  $\overline{Z}_2$ 

| $z_1$            | - |   |   |        | 1 | x1                                   |
|------------------|---|---|---|--------|---|--------------------------------------|
| $\overline{Z}_1$ |   |   |   | 3      |   | $\overline{\mathbf{x}}_{\mathtt{l}}$ |
| Z₂               | ~ | 2 |   | -<br>- |   | χ <sup>s</sup>                       |
| Ī₂               |   |   | 4 |        |   | Σ <sub>2</sub>                       |

After all state numbers are entered into Table I, the state matrix must be inspected to ensure that each state is unique and does not represent any contradictions. For this extremely simple problem, this is true and further attention is not required. Table I may now be written matrix form by placing a logical "1" for each state and a "0" elsewhere.

$$\begin{bmatrix} Z_{1} \\ \overline{Z}_{1} \\ Z_{2} \\ \overline{Z}_{2} \end{bmatrix} = \begin{bmatrix} 0 & 0 & 0 & 1 \\ 0 & 0 & 1 & 0 \\ 1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \end{bmatrix} \begin{bmatrix} X_{1} \\ \overline{X}_{1} \\ X_{2} \\ \overline{X}_{2} \end{bmatrix}$$
(2a)

The matrix in Table I is termed the <u>state matrix</u> since it only shows the states of the sequence. The matrix in Equation (2a) is termed the <u>output matrix</u> because Equation (2a) is merely a set of digital output equations in matrix notation. Writing Equations (2a) in longhand, one has:

$$Z_{1} = X_{2}$$

$$\overline{Z}_{1} = X_{2}$$

$$Z_{2} = X_{1}$$

$$\overline{Z}_{2} = \overline{X}_{1}$$

$$(2b)$$

Note that the variables used in digital equations are Boolean or binary logic variables.

Since this introductory problem is simple and requires no memory, one could almost predict the results without the use of any formal synthesis procedure. However, further problems in this chapter illustrate the general case.

### Persistent States

The problem of persistent states are prevalent in almost every feedback sequential circuit. Persistent states result when signals remain on long enough to form a

contradiction. The exact cause and remedy for this can best be illustrated by an example.

Consider as example 2 the sequence  $Z_1$ ,  $\overline{Z}_1$ ,  $Z_2$ ,  $\overline{Z}_2$ . The state numbers are entered into Table II in exactly the same fashion as the previous example. That is, state 1 is in the  $Z_1$  row,  $\overline{X}_2$  column. State 2 is in the  $\overline{Z}_1$  row,  $X_1$  column. The remaining state numbers are entered similarly and the resulting state matrix is shown in Table II.

#### TABLE II

# THE STATE MATRIX RELATION FOR THE SEQUENCE $Z_1$ , $\overline{Z}_1$ , $Z_2$ , $\overline{Z}_2$

| $\begin{bmatrix} Z_1 \end{bmatrix}$ |   |   |   |   | 1 | X1                                   |
|-------------------------------------|---|---|---|---|---|--------------------------------------|
| $\overline{Z}_1$                    |   | 2 | ÷ |   |   | $\overline{\mathbf{X}}_{\mathtt{l}}$ |
| Ζ₂                                  | ~ |   | 3 |   |   | Xa                                   |
| īz2                                 |   |   |   | 4 |   | Σs                                   |

If this state matrix were now converted into the output matrix by placing a "1" for the states and a "0" elsewhere, the following equations would result:

$$Z_1 = \overline{X}_2$$

$$\overline{Z}_1 = X_1$$
(3)

Reference to these equations and the state sequence in Table II reveals that cylinder one would be extended by  $\overline{X}_2$  and subsequently retracted by  $X_1$ . However, at the time of retraction the extent signal  $\overline{X}_2$  would still be on, because cylinder two has not been changed since its retraction. Hence, there is a contradiction because cylinder one is trying to extend and retract simultaneously. The signal which remains on creating a contradiction is called a <u>persistent state</u>. In this case, the persistent state is the signal  $\overline{X}_2$  from state 1. This problem arises because only the changed input and the changed output are used in the state matrix relation. An event is specified only by the variables that change, not by the present state of all variables.

This condition can be alleviated by entering a shut-off memory element at the persisting state and its complement at the contradiction. The memory element should be in the "set" position prior to the persistent state and should be in the "reset" position either prior to or on the contradicting state. The complemented memory signal is not used in state signal formulation; it is only used as a reminder when it should be off or in the "reset" position.

For the problem under consideration, the persistent state 1 contradicts state 2. Consequently, state 1 must be modified with a shut-off memory element, say  $W_{12}$ . This element can then be used to shut-off the persistent signal thereby avoiding a contradiction. Further examination of

Table 2 reveals that state 3 is persisting at state 4. Hence, the memory element  $W_{34}$  is assigned to state 3. The state matrix for example 2.1 may now be written in output equation form as:

$$\begin{bmatrix} Z_{1} \\ \overline{Z}_{1} \\ Z_{2} \\ \overline{Z}_{2} \end{bmatrix} = \begin{bmatrix} 0 & 0 & 0 & W_{12} \\ 1 & 0 & 0 & 0 \\ 0 & W_{34} & 0 & 0 \\ 0 & 0 & 1 & 0 \end{bmatrix} \begin{bmatrix} X_{1} \\ \overline{X}_{1} \\ X_{2} \\ \overline{X}_{2} \end{bmatrix}$$
(4)

Equations (4) give all of the required output equations to sustain the desired sequential action only if the shutoff memory elements are switched at the proper times.  $W_{12}$ must be in the "set" position in order to formulate the state signal 1; therefore, it may be set prior to its state. In this case,  $W_{12}$  is set by the state signal 4 which is  $X_2$ .  $W_{12}$  must be reset either prior to, or by, state 2. Since the previous state is the persisting state, its signal may not be used to reset itself. Therefore, the contradicting state must be used to shut-off or reset the memory element. Thus, the switching conditions for  $W_{12}$  may be shown as follows:

Set Reset  
W<sub>12</sub> 
$$X_2$$
  $X_1$   
State 4 State 2

The notation adopted for subscripting the W elements is quite fortunate since the subscripts of  $W_{l_2}$  (read W one, two) give both the persisting and the contradicting states, respectively. The switching conditions may then be stated by simply observing the subscripts. For example, the memory element  $W_{34}$  is set prior to the persistent state 3 and is reset by the contradicting state 4. Thus, the complete logic specifications for example 2.1 are:

Output Equations:

$$Z_{1} = \overline{X}_{2} \quad W_{12}$$

$$\overline{Z}_{1} = X_{1}$$

$$Z_{2} = \overline{X}_{1} \quad W_{34}$$

$$\overline{Z}_{2} = X_{2}$$

$$(5)$$

Switching Conditions:

SetReset
$$W_{12}$$
 $X_2$  $X_1$  $W_{34}$  $X_1$  $X_2$ 

Before going any further into synthesis procedures, it might be helpful to demonstrate the circuit implementation for this problem. If the circuit shown in Figure 2 is not selfexplanatory, the reader is advised to consult a text on fluid circuits. Refer to Figure 1 for the circuit implied by the boxes representing the cylinders.

Persistent states always occur when two events involving one cylinder are consecutive; however, the same problem arises anytime there is a possibility for a contradiction. This problem may best be illustrated by an example. Consider for example 2.2 the three cylinder sequence  $Z_1$ ,  $Z_2$ ,





 $Z_3$ ,  $\overline{Z}_3$ ,  $\overline{Z}_2$ ,  $\overline{Z}_1$ . Following through the sequence, it is found that  $Z_2$  is caused by  $X_1$  in event two. Later, in event five,  $\overline{Z}_2$  is required. However, since cylinder one is not retracted between events two and five, the signal  $X_1$  from event two is still on. Thus, state 2 is a persisting state contradicting event 5. A shut-off memory,  $W_{25}$ , is required to modify state 2. Since states 2 and 5 are not consecutive, the shut-off memory element  $W_{25}$  can be reset just prior to the contradiction, state 5, rather than by the contradiction itself. This is usually more desirable; however, the particular circuit hardware might dictate otherwise.

There are three other persistent states in this sequence. The reader is encouraged to develop the state matrix for this sequence and verify the memory assignment and switching conditions represented by Equations (6). The output matrix for the sequence  $Z_1$ ,  $Z_2$ ,  $Z_3$ ,  $\overline{Z}_3$ ,  $\overline{Z}_2$ ,  $\overline{Z}_1$  is:

| Z                |   | ο               | 1 | 0               | 0               | 0 | ο               | x1                              |     |
|------------------|---|-----------------|---|-----------------|-----------------|---|-----------------|---------------------------------|-----|
| $\overline{Z}_1$ |   | 0               | 0 | 0               | W <sub>61</sub> | 0 | о               | $\bar{\mathbf{x}}_{\mathtt{l}}$ |     |
| Ζa               |   | W <sup>22</sup> | 0 | 0               | Ŏ               | 0 | 0               | x²                              | (6) |
| Ζa               | = | 0               | 0 | O               | 0               | 0 | W <sub>52</sub> | ₹.                              | (0) |
| Z3               |   | 0               | 0 | W <sub>34</sub> | 0               | 0 | 0               | хa                              |     |
| ₹ <sub>3</sub>   |   | 0               | 0 | 0               | 0               | 1 | 0               | ₹.                              |     |

where the switching conditions are:

|                 | Set                                   | Reset                                |
|-----------------|---------------------------------------|--------------------------------------|
| W <sub>25</sub> | $\overline{X}_1$                      | X <sub>3</sub>                       |
| ₩ <sub>34</sub> | X <sub>1</sub> W <sub>25</sub>        | X <sub>3</sub>                       |
| W <sub>61</sub> | X <sub>3</sub> ₩ <sub>52</sub>        | $\overline{\mathbf{X}}_{\mathtt{l}}$ |
| W <sub>52</sub> | X <sub>3</sub>                        | $\overline{\mathbf{x}}_{1}$          |
|                 | · · · · · · · · · · · · · · · · · · · | ·····                                |

When determining persistent states, it is convenient to partition the state matrix according to outputs. The two rows for  $Z_1$  and  $\overline{Z}_1$  represent the output partition one, etc. The two columns for  $X_2$  and  $\overline{X}_2$  are input partition two, etc. With the matrix partitioned in this manner, a systematic method for determining persisting states can be defined. This method requires the individual investigation of each output partition. Starting with the first entry in an output partition, each state is checked by investigating the next entry in the output partition. This next entry is always in the complementary half of the output partition. These two states are always contradictory if they are consecutive and are not within a diagonal partition. A diagonal partition is the four entry square formed by the intersection of an output partition and its corresponding input partition. This square will always be on the diagonal of the matrix. Two consecutive entries in a diagonal partition are not contradictory since the first event turns itself off by the next entry. For the same reason, the event in the output partition following an entry in its diagonal partition is not contradictory. States not covered by the above rule must be examined by applying the following general rule. If the next entry in the output partition is not consecutive and is not within a diagonal partition, then the complementary event of the state immediately preceding the first entry in the output partition must occur before the next entry in the output partition. In other words, the signal that initiated the first entry in the output partition must be negated or turned-off prior to the next entry in the output partition, otherwise the first entry will be a persisting state. The application of these rules is discussed in detail for the example given in the Procedure Summary.

### Memory Assignment

In most sequences, an element is cycled more than once, thus causing an input signal to appear more than once during the sequence. Often, this input signal will initiate a different event each time it appears. In order to determine which event is called for when that input appears, memory of previous events is required.

Consider for example 2.3 the sequence  $Z_1$ ,  $Z_2$ ,  $\overline{Z}_1$ ,  $Z_2$ ,  $Z_1$ ,  $\overline{Z}_1$ . The state matrix shown in Table III is constructed by entering the state numbers as previously discussed. A close examination of this sequence reveals that state 5 is a persistent state. The element  $W_{56}$  is assigned to state 5 to prevent the contradiction at state 6. This element is then

entered into the output matrix for state 5. This is the only persistent state in this sequence.

#### TABLE III

# THE STATE MATRIX RELATION FOR $Z_1$ , $Z_2$ , $\overline{Z}_1$ , $\overline{Z}_2$ , $Z_1$ , $\overline{Z}_1$

| Zı             |     | 1 |   | 5 |                                      |
|----------------|-----|---|---|---|--------------------------------------|
| ĪZı            | 6   |   | 3 |   | $\overline{\mathbf{x}}_{\mathtt{l}}$ |
| Z <sub>2</sub> | . 2 | 1 |   |   | X2                                   |
| Īz             |     | 4 |   |   | X2                                   |

Columns one and two of Table III contain more than one stable state per column. The states 6 and 2 in column one indicate that there are two separate outputs initiated by the input  $X_1$ . One time the input signal  $X_1$  initiates the output  $Z_2$ ; the next time  $X_1$  appears, the output  $\overline{Z}_1$  is desired. In order to distinguish between these states, a memory element is assigned to one of these states and its complement is assigned to the other. For instance, the memory element  $Y_{26}$  is assigned to state 2 and  $\overline{Y}_{26}$  is assigned state 6. In accordance with the W elements, the Y elements are subscripted to denote their associated states. The element  $Y_{26}$  is used to distinguish between states 2 and 6, and is set prior to state 2 and is reset before 6. A similar condition exists between states 1 and 4. The memory element  $Y_{14}$  is used to make each of these states unique.

The output matrix is constructed by entering all of the Y elements to distinguish between common input states. The W elements are entered at their persisting states and a "1" is entered for any stable state which does not require memory. A "0" is entered elsewhere. The resulting output matrix for example 2.3 is given by Equation (7).

$$\begin{bmatrix} Z_{1} \\ \bar{Z}_{1} \\ Z_{2} \\ \bar{Z}_{2} \\ \bar{Z}_{2} \end{bmatrix} = \begin{bmatrix} 0 & Y_{14} & 0 & W_{56} \\ \bar{Y}_{26} & 0 & 1 & 0 \\ Y_{26} & 0 & 0 & 0 \\ 0 & \bar{Y}_{14} & 0 & 0 \end{bmatrix} \begin{bmatrix} X_{1} \\ \bar{X}_{1} \\ X_{2} \\ \bar{X}_{2} \end{bmatrix}$$
(7)

Written out, these equations are:

$$Z_{1} = \overline{X}_{1} Y_{14} + \overline{X}_{2} W_{56}$$

$$\overline{Z}_{1} = X_{1} \overline{Y}_{26} + X_{2}$$

$$Z_{2} = X_{1} Y_{26}$$

$$\overline{Z}_{2} = \overline{X}_{1} \overline{Y}_{14}$$

The switching conditions are:

|                 | Set                                  | Reset                    |
|-----------------|--------------------------------------|--------------------------|
| Y <sub>26</sub> | X <sub>1</sub> Y <sub>14</sub>       | X̄₂ ₩ <sub>56</sub>      |
| Y <sub>14</sub> | X1 Y26                               | X2                       |
| W <sub>56</sub> | $\overline{X}_1$ $\overline{Y}_{14}$ | $X_1  \overline{Y}_{26}$ |

Figure 3 is a hydraulic implementation of the logic circuit for this sequence. The passive memory effect is





utilized in this circuit to reduce circuit complexity and hardware. At this point, the reader should refer to Appendix A for a complete discussion of the passive memory effect, assignment, and implementation for hydraulic and fluidic circuits.

### Counting Sequences

Counting sequences are characterized by their repetitious cycling of outputs. For example, a 2,2,1 counter cycles (i.e., extends, retracts) the first element twice, the second twice, and the third once and then repeats the sequence. Counting sequences are handled in exactly the same manner as any other automatic circuit; however, their uniqueness deserves special mention.

In synthesizing this circuit, the usual formal notation is dropped and the simplified approach is introduced. The first simplification is the omission of the output and input vectors. Instead of writing a formal state matrix relation, the rows and columns of the state matrix are labeled corresponding to their associated vectors. With this simplified approach, the state numbers representing the sequence are entered into the matrix as usual. The required memory elements are then assigned adjacent to their state number eliminating the need for rewriting the state matrix into the output matrix form. The output equations are written directly from the completed state matrix.

The first step in synthesizing the equations for

example 2.4 is to enter the state numbers representing the sequence into the state matrix as shown in Table IV. This sequence is written as  $Z_1$ ,  $\overline{Z}_1$ ,  $Z_1$ ,  $\overline{Z}_1$ ,  $Z_2$ ,  $\overline{Z}_2$ ,  $Z_2$ ,  $\overline{Z}_2$ ,  $Z_3$ ,  $\overline{Z}_3$ .

### TABLE IV

 $\overline{\mathbf{X}}_{1}$ Χz х<sub>з</sub>  $X_1$  $X_2$ Xa 1 W<sub>12</sub> 3 Y<sub>35</sub>  $Z_1$ 2 Y24  $\overline{\mathbf{Z}}_{1}$  $4 \overline{Y}_{24}$ Y35W56 5 7 Y<sub>79</sub> Ζz 6 Y<sub>68</sub> Ζ₂ 8 ¥6.8 9 Y79 W910  $Z_3$ 10  $\overline{Z}_3$ 

THE STATE MATRIX FOR A 2,2,1 COUNTER

The next step is the determination of the existence of any persistent states. Applying the rules from page 18 to the matrix under consideration, it is found that states 1 and 2 are contradictory since they are consecutive entries within the same output partition and different input partitions. States 2 and 3 and 3 and 4 are both within diagonal partitions and, thus, are not contradictory. Since state 4 is in a diagonal partition, there is no contradiction between states 4 and 1. Entries like 5 and 6 in the second partition and 9 and 10 in the third partition are contradictory. By similar application of these rules, it can be seen that these are the only three contradictions in this sequence. The shut-off memories (W elements) are now entered into Table IV adjacent to their corresponding persistent states (e.g.,  $W_{12}$  at 1,  $W_{56}$  at 5, and  $W_{910}$  at 9).

The next step of the procedure is the assignment of input memory elements (Y elements). Here, the rule is simple: whenever there is more than one state in a column, a secondary memory state must be assigned to make each state in the column unique. In Table IV there are four such columns requiring memory. The memory elements  $Y_{24}$ ,  $Y_{35}$ ,  $Y_{68}$ ,  $Y_{79}$  are assigned to their corresponding states in accordance to Appendix A.

The last step in the procedure is the specification of the output equations and switching conditions. The output equations are written directly from the state matrix in the same manner as initially discussed. The switching conditions are determined directly from the element subscripts. The complete logical specifications for example 2.4 are given below:

Output equations:

$$Z_{1} = \overline{X}_{1} Y_{35} + \overline{X}_{3} W_{12}$$

$$\overline{Z}_{1} = X_{1} Y_{24} + X_{1} \overline{Y}_{24} = X_{1}$$

$$Z_{2} = \overline{X}_{1} \overline{Y}_{35} W_{56} + \overline{X}_{2} Y_{79}$$

$$\overline{Z}_{2} = X_{2} Y_{68} + X_{2} \overline{Y}_{68} = X_{2}$$

$$Z_{3} = \overline{X}_{2} \overline{Y}_{79} W_{910}$$

$$\overline{Z}_{3} = X_{3}$$
(8)

Switching conditions:

|                  | Set                                                                      | Reset                                       |
|------------------|--------------------------------------------------------------------------|---------------------------------------------|
| Y <sub>24</sub>  | ∏ <sub>3</sub> W₁₂                                                       | Χ <sub>1</sub> Υ <sub>35</sub>              |
| Υ <sub>35</sub>  | $\dot{X}_{1}$ $Y_{24}$                                                   | $X_1  \overline{Y}_{24}$                    |
| Y <sub>68</sub>  | $\overline{\mathrm{X}}_{1}$ $\overline{\mathrm{Y}}_{35}$ W <sub>56</sub> | $\overline{\mathrm{X}}_{2}$ Y <sub>79</sub> |
| Y <sub>79</sub>  | X <sub>2</sub> Y <sub>68</sub>                                           | $X_2$ $\overline{Y}_{68}$                   |
| Ylz              | X <sub>3</sub>                                                           | X <sub>1</sub> Y <sub>24</sub>              |
| W <sub>56</sub>  | $X_1 \overline{Y}_{24}$                                                  | X <sub>2</sub> Y <sub>68</sub>              |
| W <sub>910</sub> | Х <sub>3</sub> Ў <sub>68</sub>                                           | X <sub>3</sub>                              |

Notice that the equations for  $\overline{Z}_1$  and  $\overline{Z}_2$  both reduce, thereby eliminating a memory element. This does not imply that these memory elements are not required. These two signals (states 2 and 4) must be unique since they are used to switch other memories to prepare the proper transition paths.

### Procedure Summary

The procedure for the synthesis of feedback sequential digital control circuits is summarized by the following

four steps:

- Enter State Numbers Write down the specified sequence and number each event in the sequence. Starting with the first event, sequentially enter the state numbers into the state matrix in the row corresponding to the desired output and the column corresponding to the previous event.
- 2. <u>Correct Persistent States</u> Whenever a state signal remains on to form an extend-retract contradiction, the persistent state signal must be modified by a W memory element.
- 3. <u>Assign Memory States</u> Whenever there is more than one state in any column of the state matrix, memory states are required to make each of these states unique.
- 4. <u>Determine Output and Switching Conditions</u> -The digital output equations are obtained from the state matrix by replacing each state number by a logical "1" and all blank entries in the matrix by "0" and then multiplying the matrix. The switching conditions are determined from the memory subscripts.

The following example encompasses all of the defined rules for the synthesis of feedback sequential logic circuits and is worked in detail as a final illustration of this synthesis procedure. The entire problem is presented on page 31 and the procedure is discussed in detail below.

First of all, the sequence is specified and written with state numbers below it, as shown on page 31. This sequence is then entered into the state matrix by placing the state numbers in the row of the desired output and the column of the present input. For example, the state number 1 is entered in the  $Z_1$  row and the  $\bar{X}_3$  column since the first event,  $Z_1$ , is initiated by the previous event which is the retraction of cylinder three. The next event is the retraction of cylinder one; accordingly, state 2 is located in the  $\bar{Z}_1$  row and  $X_1$  column. The remainder of the sequence is entered into the state matrix in the same fashion.

The next step of the procedure requires the investigation of each output partition for the possibility of persistent states. The first partition is investigated by starting with state 1. The next entry in this partition is state 2. Since this is a consecutive entry not within a diagonal partition, states 1 and 2 are contradictory and must be corrected by modifying the persistent state (state 1) with the memory element  $W_{12}$ .  $W_{12}$  is entered in the matrix adjacent to state number 1. The next entry in this partition is state 3. This entry, as well as the next, is within a diagonal partition and is not contradictory. The next entry in partition one after state 4 is state 7. Since state 4 is within a diagonal partition, its initiating signal is negated prior to the next entry (state 7). States 7 and 9 form a contradiction since event 6 has not been

negated before state 9. Accordingly, the memory element  $W_{\gamma 9}$  is entered by state 7. The final entry in partition one is state 1. Since event 8 is not negated before state 1,  $W_{91}$  is placed beside state 9 to correct this contradiction.

The next partition has only two states (5 and 8). It can be seen that these states do not form a contradiction since event 4 is negated by event 7. Similarly, state 8 is not persisting at state 5.

The possible contradiction in partition three (6 and 10) is eliminated since event 5 is negated by event 8. Thus, the signal causing state 6 is turned off before state 10. The state prior to state 10 (state 9) is negated before state 6 eliminating this possible contradiction.

Now that all persistent states have been corrected, the next step in the procedure is the assignment of any required memory states. Column one of the state matrix contains three states (2, 4, and 8). Each of these states must be made unique by modifying the states with the proper memory state. This is done by placing  $Y_{28}$   $Y_{24}$  at state 2,  $Y_{28}$   $\overline{Y}_{24}$  at state 4 and  $\overline{Y}_{28}$  at state 8. (Notice the double subscript notation.) Column two also contains three states, 3, 5, and 10, and the memory elements  $Y_{35}$  and  $Y_{310}$  are assigned accordingly. There are no other columns requiring memory.

The final step of the procedure is the specification of output and switching conditions. The output equations are obtained by mentally replacing each state number by the

logical "1" and multiplying the matrix by the input vector.

The switching conditions for the memory elements are obtained from the element subscripts. For example,  $W_{12}$  is set prior to state 1 by state 10 and is reset by state 2.  $W_{79}$  is set by state 6 and is reset by state 8.  $Y_{24}$  is set by state 1 and reset by state 3, etc.

This problem is worked to completion on the following page.

EXAMPLE PROBLEM

Sequence: 1 1 1  $\overline{2}$  $\mathbf{2}$ State Nos: 

|                | X1                                                                                      | $\overline{\mathbf{X}}_{1}$        | X2 | $\overline{\mathrm{X}}_{2}$ | X <sub>3</sub>    | $\overline{X}_{3}$ |
|----------------|-----------------------------------------------------------------------------------------|------------------------------------|----|-----------------------------|-------------------|--------------------|
| Z              |                                                                                         | 3 Y <sub>310</sub> Y <sub>35</sub> |    |                             | 7 W <sub>79</sub> | 1 W <sub>l/2</sub> |
| ₹₁             | $\begin{array}{cccc} 2 & Y_{28} & Y_{24} \\ 4 & Y_{28} & \overline{Y}_{24} \end{array}$ |                                    |    | 9 W <sub>91</sub>           |                   |                    |
| Zə             |                                                                                         | 5 Y <sub>310</sub> Y <sub>35</sub> |    |                             |                   |                    |
| Σ₂             | 8 Y <sub>28</sub>                                                                       |                                    |    |                             |                   |                    |
| Z <sub>3</sub> |                                                                                         |                                    | 6  |                             |                   |                    |
| ₹ <sub>3</sub> |                                                                                         | 10 Y <sub>310</sub>                |    |                             |                   |                    |

Output Equations:

# Switching Conditions:

| Set                                                           | Reset                                                 |
|---------------------------------------------------------------|-------------------------------------------------------|
| $\overline{\mathrm{X}}_{3}$ W <sub>12</sub>                   | $\overline{X}_1$ $Y_{310}$ $Y_{35}$                   |
| $\overline{\mathrm{X}}_{_{3}}$ W <sub>l2</sub>                | X <sub>3</sub> W <sub>79</sub>                        |
| X <sub>1</sub> Y <sub>28</sub> Y <sub>24</sub>                | $X_1 Y_{28} \overline{Y}_{24}$                        |
| X <sub>1</sub> Y <sub>28</sub> Y <sub>24</sub>                | $\overline{X}_{arsigma}$ W <sub>91</sub>              |
| $X_1  \overline{Y}_{28}$                                      | $\overline{X}_1$ $\overline{Y}_{3lo}$                 |
| X <sub>2</sub>                                                | X <sub>1</sub> $\overline{Y}_{28}$                    |
| $ar{\mathrm{X}}_{\texttt{l}}$ $ar{\mathrm{Y}}_{\texttt{3lo}}$ | $X_1 X_{28} Y_{24}$                                   |
|                                                               | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ |

The hydraulic implementation for this circuit is shown in Figure 4. In this circuit, the actual switching signals have been replaced by the notation  $S_{24}$ ,  $R_{35}$ , etc., where  $S_{24}$ denotes the "set" signal for  $Y_{24}$  from the above switching conditions.





ယ ယ

#### CHAPTER III

# THE STATE MATRIX SYNTHESIS PROCEDURE FOR RANDOM INPUT CIRCUITS

Unlike feedback sequential circuits, random input circuits do not anticipate the next input; consequently, every possible input change must be considered. An example of this type of circuit is the secret combination lock in which only one sequence of input changes will result in the proper output (i.e., the opening of the lock). Other sequences might result in different outputs, return to starting position, or many other conceivable situations. In any event, the response to all input change possibilities from any state in the sequence must be specified before a circuit to perform the required logic can be synthesized.

# The Primitive Flow Table

The synthesis of a circuit to perform certain logic sequences must proceed from the word statement of the possible inputs and the desired response to input changes. For every input change, two things must be specified: the resulting output and the desired transition paths from that state. These specifications are most conveniently

represented by the information table termed the <u>Primitive</u> <u>Flow Table</u>.

The primitive flow table contains the complete logic specifications for a problem and is arranged as follows. The columns of the table indicate all of the possible input combinations. These input states are usually labeled above each column according to the Gray code (one variable change between columns). Each row of this table represents the state of the logic system and its corresponding output, Z. Numbers with parentheses around them indicate stable <u>states</u> of the circuit and the unparenthesized numbers show the possible transition paths from one stable state to another.

As example 3.1, consider the primitive flow table shown by Table V. This example has two inputs,  $X_1$  and  $X_2$ , and one output,  $Z_1$ . The table indicates that the logic circuit must provide a path from state (1) to state (2) when the input changes from "00" to "10" as indicated by the transition path numbered 2 in the first row. Also, the circuit must return from (2) to (1) by the path indicated in the second row, first column. Notice that no transition path is shown from input "00", state (1), to input "11", since this would require two inputs to be changed at exactly the same instant, which is highly improbable.

#### TABLE V

PRIMITIVE FLOW TABLE FOR EXAMPLE 3.1

| _ | 00             | 10  | 11  | 01  | Zı |
|---|----------------|-----|-----|-----|----|
|   | (1)            | 2   | _   | 3   | 0  |
|   | 1              | (2) | 4   | -   | 0  |
|   | 1              | -   | 4   | (3) | 0  |
|   | : <del>_</del> | 2   | (4) | 3   | 1  |

In Table V, the output  $Z_1$  results when both inputs are actuated by either the path from state 2 or 3. As is the case with this example, the primitive flow table should specify every possible transition path and should form a closed loop in that there is a path back to the origin or any other state. The above example is extremely simple and requires no memory. When the sequences get larger and inputs are cycled, the need for memory arises as is shown in the next example.

Consider for example 3.2 the primary sequence 00, 10, 11, 01, 11, 10, which results in the output  $Z_1$ . The sequence 00, 01, 11 results in the  $Z_2$  output. All other possible sequences are considered and the transition paths are shown in the completed primitive flow table, Table VI. PRIMITIVE FLOW TABLE FOR EXAMPLE 3.2

| $X_1 X_2$ |     |     |     |    |    |
|-----------|-----|-----|-----|----|----|
| ± 00      | 10  | 11  | 01  | Zl | Za |
| (1)       | 2   | -   | 7   | 0  | 0  |
| 1         | (2) | 3   | -   | 0  | 0  |
| _         | 2   | (3) | 4   | 0  | 0  |
| 1         | -   | 5   | (4) | 0  | 0  |
| -         | 6   | (5) | 4   | 0  | 0  |
| 1         | (6) | 3   | -   | 1  | 0  |
| 1         | -   | 8   | (7) | 0  | 0  |
| -         | 9   | (8) | 7   | 0  | 1  |
| 1 *       | (9) | 3   | -   | 0  | 0  |

Before synthesizing a circuit to perform the indicated logic of Table VI, it is advantageous, although not completely necessary, to administer two additional steps to the primitive flow table. First of all, the primitive flow table should be checked for the possibility of <u>redundant</u> <u>states</u>. Two stable states are said to be redundant if and only if they have the same input state, the same output state, and the same or equivalent transition paths. For example, the states (2) and (9) in Table VI are redundant since they have the same input (they are in the same column), the same output ( $\overline{Z}_1 \ \overline{Z}_2$ ), and the same transition paths (1 and 3). For this reason, the row containing state (9) may be completely removed and all of the transition paths 9 may be replaced with the path indicator 2. There are no more redundancies in this table and the resulting flow table is termed the reduced primitive flow table.

Another advantageous operation on this flow table is the transformation to the <u>canonical flow table</u>. This operation is not completely necessary for the purposes of this chapter, so the definition and detailed discussion of it is deferred until Chapter IV. Briefly though, the basic concept is to <u>order</u> the states according to systematic input changes. The canonical flow table for the problem under consideration (which includes the above mentioned reduction) is shown in Table VII.

#### TABLE VII

#### CANONICAL FLOW TABLE FOR EXAMPLE 3.2

X<sub>1</sub> X<sub>n</sub>

|   | 00  | 10  | 11  | 01  | Zı | Z2 |
|---|-----|-----|-----|-----|----|----|
| ſ | (1) | 2   | -   | 3   | 0  | 0  |
|   | 1   | (2) | 4   | -   | 0  | 0  |
|   | 1   | -   | 5   | (3) | 0  | 0  |
|   | -   | 2   | (4) | 6   | 0  | 0  |
|   | -   | 2   | (5) | 3   | 0  | 1  |
|   | 1   | · — | 7   | (6) | 0  | 0  |
|   | -   | 8   | (7) | 6   | 0  | 0  |
|   | 1   | (8) | • 4 | -   | 1  | 0  |

#### Formal Matrix Representation

Once a problem has been completely specified and the canonical flow table has been derived, the next step is the <u>synthesis</u> of circuit equations to perform the required logic. This synthesis can be reduced to the determination of a unique matrix [M] satisfying the relation.

# $\begin{bmatrix} \mathbf{Z} \end{bmatrix} = \begin{bmatrix} \mathbf{M} \end{bmatrix} \begin{bmatrix} \mathbf{X} \end{bmatrix}$

This is a statement that the outputs  $\begin{bmatrix} Z \end{bmatrix}$  are related to the inputs  $\begin{bmatrix} X \end{bmatrix}$  and previous events. The matrix  $\begin{bmatrix} M \end{bmatrix}$  provides this relationship and contains memory information which defines the present state. The only difference between this matrix relation and the one used for the feedback sequential circuits is the input and output vectors used. In feedback sequential circuit synthesis, the changed input and the changed output vectors are used. For random input circuit synthesis, the input vector contains the total input state (present state of all inputs) and the output vector represents the continuous output state (present state of each output) rather than the change output.

As a first step toward constructing this matrix, the state numbers from the canonical flow table are entered into each of the output partitions. States with an output of  $Z_i$ are entered in the top half of the i<sup>th</sup> output partition and states with the  $\overline{Z}_i$  output are entered in the bottom half. This determines the rows in which states are entered. To determine the proper entry column, recall from the rules of matrix multiplication that each column in the matrix is multiplied only by a corresponding row of the input vector  $\begin{bmatrix} X \end{bmatrix}$ . Thus, a column of the matrix represents events associated with only one input state. Hence, state numbers are entered in the proper row of the output partition and in the column associated with that input state.

To illustrate the state matrix synthesis concept, consider example 3.1 as represented by Table V. This primitive flow table is entered into the state matrix by entering the stable state numbers in the row of the individual output and the column of the present input similar to the way it was done in Chapter II. This matrix is given by Table VIII.

#### TABLE VIII

## THE STATE MATRIX RELATION FOR EXAMPLE 3.1



To obtain the output equation, replace every state number by the logical "1" and place a "0" elsewhere. Multiplying the matrix yields the result:

$$\mathbf{Z}_{1} = \mathbf{X}_{1} \mathbf{X}_{2} \tag{10}$$

The above example illustrates the basic concept of circuit synthesis using state matrices. This problem did not require memory; a more general problem requiring memory is discussed below.

As another example of circuit synthesis, consider example 3.2 represented by the canonical flow table given in Table VIII. The state numbers are entered into the matrix as described above and the result is termed the <u>state matrix</u> relation. See Table IX.

#### TABLE IX

THE STATE MATRIX RELATION FOR EXAMPLE 3.2



### Memory Assignment

As can be seen from Table IX, the only time the output

 $Z_1$  appears is state 8. Since state 8 is associated with the input "10", one would be tempted to state that the output  $Z_1$ is equal to  $X_1 \bar{X}_2$ . However, this is not the case since state 2 also has the input "10" but does not have the output  $Z_1$ . Thus, some method to distinguish between states 2 and 8 is required. This is most conveniently done by assigning a memory state at both states. If a memory element was in the "set" position for 2 and in the "reset" position for 8, then these two states would be a unique combination of the input and memory states. This memory element may be represented by placing  $Y_{28}$  adjacent to every 2 in Table IX and its logical complement  $\bar{Y}_{28}$  by states 8. This double subscript notation implies that the memory element  $Y_{28}$  is used to distinguish between states 2 and 8 and is set prior to 2 and is reset prior to 8.

A similar condition exists in column four. Although states 3 and 6 do not have differing outputs, they still required uniqueness since they have different transition paths and their signals are used to switch different memory elements. Therefore, the memory element  $Y_{36}$  is assigned to state 3 and its complement  $\overline{Y}_{36}$  is assigned to state 6. States 4, 5, and 7 in column three also require memory to demand their uniqueness. The memory state  $Y_{47}$   $Y_{45}$  is assigned to state 4,  $Y_{47}$   $\overline{Y}_{45}$  to state 5, and  $\overline{Y}_{47}$  to state 7. Here again, the switching conditions are inferred by the subscripts. At this point, the reader should refer to

Appendix A for further information concerning the passive memory.

The matrix shown in Table X has all of the above memory modifications. Now, each state in this matrix has a unique representation.

### TABLE X

#### THE UNIQUE STATE MATRIX RELATION FOR EXAMPLE 3.2

|                 |   |          |                                        |                                                                                                              |                                         | X <sub>1</sub> 2 | X2 |
|-----------------|---|----------|----------------------------------------|--------------------------------------------------------------------------------------------------------------|-----------------------------------------|------------------|----|
| Z               |   |          | 8 Ī <sub>28</sub>                      |                                                                                                              |                                         | Γο               | 0  |
| <b>Z</b> ₁      |   | 1        | 2 Y <sub>28</sub>                      | $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                         | 3 Ү <sub>зб</sub><br>6 Ұ <sub>зб</sub>  | 1                |    |
| Zə              | ~ |          |                                        | 5 $Y_{47}$ $\overline{Y}_{45}$                                                                               |                                         | 0                | 1  |
| _∑ <sup>2</sup> |   | <b>1</b> | 2 Y <sub>28</sub><br>8 <del>Y</del> 28 | $\begin{array}{c} 4  \mathbf{Y}_{4 \ 7}  \mathbf{Y}_{4 \ 5} \\ 7  \overline{\mathbf{Y}}_{4 \ 7} \end{array}$ | 3 Ү <sub>з</sub> е<br>6 <del>Ү</del> зе | _                |    |

ł

## Output and Switching Conditions

The purpose of any synthesis procedure is to give every state a unique signal representation. This signal (or variations upon this signal) is then used either as an output signal or as a switching signal for other memory elements. The above steps produce a state matrix in which every state is represented uniquely by a certain combination of input and memory states. The only remaining step is the specification of the output and switching conditions.

The output equations are obtained from the state matrix relation by replacing every state number designation in the state matrix by the logical "1" and by placing a logical "0" elsewhere. Once this substitution has been made, the resulting matrix is termed the <u>output matrix</u> since it now represents a set of digital equations rather than a state matrix relation. These equations can be rewritten in the individual equation form by multiplying the matrix by the input vector.

The final step in the synthesis procedure is the one which insures the proper circuit operation; this is the specification of when each memory element is to be switched to the proper state. These switching conditions are inferred from the element subscripts and the flow table. For example, the memory element  $Y_{ij}$  is set <u>prior</u> to the state "i" and is reset <u>prior</u> to state "j". This information is obtained from the flow table by observing the possible transition paths to states i and j. The corresponding previous states are to be used for switching signals.

As a specific example, the output and switching conditions for the problem given in Table X are as follows. The output matrix equation is:

|                                   |   |                                      | <u></u>                                                                                           |                                      | X <sub>1</sub> X <sub>2</sub> |
|-----------------------------------|---|--------------------------------------|---------------------------------------------------------------------------------------------------|--------------------------------------|-------------------------------|
|                                   | 0 | Ϋ́ <sub>28</sub>                     | 0 0                                                                                               | 0                                    | 00                            |
| $\overline{Z}_{1}^{\prime\prime}$ | 1 | Y <sub>28</sub>                      | $\begin{array}{cccc} Y_{4\gamma} & Y_{45} & + \\ Y_{4\gamma} & \overline{Y}_{45} & + \end{array}$ | Y <sub>36</sub> +<br>7 <sub>36</sub> | 10                            |
|                                   |   |                                      | $\overline{Y}_{4:\gamma}$                                                                         |                                      | 11                            |
| Z <sub>2</sub>                    | 0 | 0                                    | $Y_{47}$ $\overline{Y}_{45}$                                                                      | 0                                    | 01                            |
| ₹₂                                | 1 | Y <sub>28</sub> +<br>Ŧ <sub>28</sub> | $\begin{array}{cccc} Y_{4\ \gamma} & Y_{4\ 5} & + \\ \overline{Y}_{4\ \gamma} & \end{array}$      | Y <sub>36</sub> +<br>Y <sub>36</sub> |                               |

(11a)

Since the outputs  $Z_1$  and  $\overline{Z}_1$  are perfect complements, only the equations for  $Z_1$  and  $Z_2$  need to be specified. These are:

$$Z_{1} = X_{1} \overline{X}_{2} \overline{Y}_{28}$$

$$Z_{2} = X_{1} X_{2} Y_{47} \overline{Y}_{45}$$
(11b)

The switching conditions as determined from the subscripts and the flow table (Table VII) are:

$$\begin{array}{rll} Y_{4\,5}: & {\rm Set} = {\rm States}\ 2\,+\,8\\ & = & X_1\,\overline{X}_2\\ & {\rm Reset} = {\rm State}\ 3\\ & = & \overline{X}_1\,X_2\ Y_{3\,6}\\ & {\rm Y}_{3\,6}: & {\rm Set} = {\rm States}\ 1\,+\,5\\ & = & \overline{X}_1\,\overline{X}_2\ +\,X_1\,X_2\ Y_{4\,7}\ \overline{Y}_{4\,5}\\ & {\rm Reset} = {\rm States}\ 4\,+\,7\\ & = & X_1\,X_2\ Y_{4\,7}\ Y_{4\,5}\ +\,X_1\,X_2\ \overline{Y}_{4\,7}\end{array}$$

In more compact notation, the switching conditions are:

|                  | Set                                  | Reset                                         |
|------------------|--------------------------------------|-----------------------------------------------|
| Y28              | $00 + 11 Y_{47}$                     | 11 Y <sub>47</sub>                            |
| Y <sub>47</sub>  | 10                                   | 01 $\bar{Y}_{36}$                             |
| Ү <sub>4 Б</sub> | 10                                   | 01 Y <sub>36</sub>                            |
| Y <sub>36</sub>  | 00 + 11 $Y_{47}$ $\overline{Y}_{45}$ | 11 $Y_{47}$ $Y_{45}$ + 11 $\overline{Y}_{47}$ |

Procedure Summary

The state matrix synthesis procedure consists of the following four steps:

- 1. <u>Develop Primitive Flow Table</u> From the word statement of the problem, construct a primitive flow table showing all possible input changes, all possible transitions, and the corresponding outputs. If desired, this flow table may then be transformed into the canonical flow table.
- 2. Form <u>State Matrix</u> Enter the stable state numbers into the state matrix. Each state

number appears in every output partition under the proper column.

- 3. <u>Assign Memory States</u> Whenever there is more than one stable state number in a column, make each state unique by assigning the appropriate memory state.
- 4. <u>Determine Output and Switching Conditions</u> -The output equations are obtained by replacing each state number by "1" and placing a "0" elsewhere and then multiplying the matrix. The output complement need not be specified. The switching conditions are determined from the element subscripts and previous events shown in the flow table.

As a final example of the state matrix synthesis procedure, example 3.3 is worked to completion on page 51, and each step is explained in detail below. The reader may refer to Appendix C for further example problems and their solutions.

Before working the final example, some of the formality of the method can be dropped and the shorthand notation introduced. First of all, the formal matrix representation is omitted and the rows and columns of the matrix itself are merely labeled according to their outputs and inputs. Next, the intermediate step of writing the output matrix is eliminated by mentally multiplying the matrix rather than rewriting it. As a matter of fact, the matrix representation

itself can be eliminated by working directly with the primitive flow table once the reader is familiar with the technique. However, this step is not presented here.

Consider for example 3.3 a secret combination lock in which there is only one proper sequence of output actuations which will open the lock (output  $Z_1$ ). Any deviation from this sequence sounds an alarm (output  $Z_2$ ). The correct sequence is  $X_1$ ,  $X_2$ ,  $\overline{X}_2$ ,  $X_2$ ,  $\overline{X}_1$ ; where X means actuate and hold,  $\overline{X}$  means release. Even though a mistake sounds the alarm, there should be a path provided back to the origin. This primitive flow table is shown on page 51 and is not transformed into the canonical form.

Once the primitive flow table is developed, the next step is the formation of the corresponding state matrix. This is done by entering each state number in the column of the input state and the rows of the individual outputs. For the first output, all state numbers except state 6 are entered in the lower half of output partition one, since all of them have the  $\overline{Z}_1$  output. State 6 is then entered into the  $Z_1$  row of the state matrix. Next, states 1 through 6 are entered in partition two in the  $\overline{Z}_2$  row and states 7 through 10 are entered in the  $Z_2$  row. These two row partitions comprise the state matrix for this example.

The next step is the determination of memory requirements. To do this, each column, representing one combination of the inputs, is treated separately. Reference to the state matrix reveals that every column has multiple states

and requires memory to make each state unique. Column one has two states, 1 and 8, requiring one memory element,  $Y_{18}$ .  $Y_{18}$  is thus entered beside every 1 in the matrix, and its complement  $\overline{Y}_{18}$  is entered adjacent to states 8. Similarily, column two contains three states, 2, 4, and 9. Each of these states is made unique by assigning two memory elements,  $Y_{29}$  and  $Y_{24}$ , in accordance with Appendix A. Column three has three states and column four has two. Memory elements are assigned to these states in the same manner as above.

After the state matrix is formed and the memory requirements are entered adjacent to their respective states, the output equations are obtained by mentally replacing the state numbers with "1's" and then multiplying the matrix by the input vector. The output complements do not have to be specified. The output  $Z_1$  appears at state 6 only. The  $Z_2$ output appears at states 8, 9, 10, and 7.

The final step is the specification of the switching conditions; this step ensures proper circuit operation. If the double subscript notation is used to denote memory elements, the switching conditions are stated from knowledge of the subscripts and the flow table. The subscripts indicate when an element should be in the "set" or "reset" position and the flow table shows the possible transitions to these states. For example,  $Y_{18}$  is set by any state immediately preceding state 1 and is reset by states preceding state 8. From the flow table, it can be seen that the only transition path to only transition path to state 1 is from state 6. There are transition paths to state 8 from states 2, 4, 7, and 9. Thus,  $Y_{18}$  is set by state 6 and is reset by state 2, 4, 7, or 9. The element  $Y_{29}$  is set by state 1 or 8 and is reset by state 5 or 10. The remaining switching conditions are determined in the same fashion and the complete table or switching conditions is given below.

This problem is shown on the next page and the logic circuit schematic is shown in Figure 5.

THE PRIMITIVE FLOW TABLE FOR EXAMPLE 3.3

| x <sub>1</sub> x <sub>2</sub> |     |      |     |                |    |
|-------------------------------|-----|------|-----|----------------|----|
| 00                            | 10  | 11   | 01  | Z <sub>1</sub> | Z2 |
| (1)                           | 2   |      | 7   | 0              | 0  |
| 8                             | (2) | 3    |     | 0              | 0  |
|                               | 4   | (3)  | 7   | 0              | 0  |
| 8                             | (4) | 5    |     | 0              | 0  |
|                               | 9   | (5)  | 6   | 0              | 0  |
| 1                             |     | 10   | (6) | 1              | 0  |
| 8                             |     | 10   | (7) | 0              | 1  |
| (8)                           | 2   |      | 7   | 0              | 1  |
| 8                             | (9) | 10   |     | 0              | 1  |
|                               | 9   | (10) | 7   | 0              | 1  |

The State Matrix:

|    | 00                                     | 10                                                                     | 11                                                                                                                   | 01                |
|----|----------------------------------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|-------------------|
| Z  |                                        |                                                                        |                                                                                                                      | 6 Y <sub>67</sub> |
| Zı | 1 Y <sub>18</sub><br>8 Ÿ <sub>18</sub> | $\begin{array}{cccccccccccccccccccccccccccccccccccc$                   | $\begin{array}{cccc} 3 & Y_{310} & Y_{35} \\ 5 & Y_{310} & \overline{Y}_{35} \\ 10 & \overline{Y}_{310} \end{array}$ | 7 Ŷ <sub>67</sub> |
| Zg | 8 <b>Y</b> 18                          | 9 ¥29                                                                  | 10 \$\bar{Y}_{310}\$                                                                                                 | 7 Ī <sub>67</sub> |
| ₹₂ | 1 Y <sub>18</sub>                      | 2 Y <sub>29</sub> Y <sub>24</sub><br>4 Y <sub>29</sub> <del>Y</del> 24 | 3 Y <sub>310</sub> Y <sub>35</sub><br>5 Y <sub>310</sub> <del>Y</del> <sub>35</sub>                                  | 6 Y <sub>67</sub> |

Output Equations:

$$Z_{1} = \overline{X}_{1} X_{2} Y_{67}$$

$$Z_{2} = \overline{X}_{1} \overline{X}_{2} \overline{Y}_{18} + X_{1} \overline{X}_{2} \overline{Y}_{29} + X_{1} X_{2} \overline{Y}_{310} + \overline{X}_{1} X_{2} \overline{Y}_{67}$$
(12)

# Switching Conditions:

|                  | Set                                                    | Reset                                                                                  |
|------------------|--------------------------------------------------------|----------------------------------------------------------------------------------------|
| Y <sub>18</sub>  | $\overline{X}_1 X_2 Y_{67}$                            | $ \begin{array}{ c c c c c c c c c c c c c c c c c c c$                                |
| Y29              | $\overline{\mathbf{X}}_{1}  \overline{\mathbf{X}}_{2}$ | $X_1 X_2 Y_{310} \overline{\overline{Y}}_{35} + X_1 X_2 \overline{\overline{Y}}_{310}$ |
| Y <sub>24</sub>  | $\bar{\mathbf{X}}_{1}  \bar{\mathbf{X}}_{2}$           | $X_1 X_2 Y_{310} Y_{35}$                                                               |
| Y <sub>3lo</sub> | $X_1 \overline{X}_2 Y_{29} Y_{24}$                     | $\overline{X}_1 X_2 + X_1 \overline{X}_2 \overline{Y}_{29}$                            |
| Y <sub>35</sub>  | $X_1 \overline{X}_2 Y_{29} Y_{24}$                     | $X_1 \overline{X}_2  Y_{29} \overline{Y}_{24}$                                         |
| Y <sub>6 7</sub> | $X_1 X_2 Y_{310} \overline{Y}_{35}$                    | $\bar{X}_{1} \bar{X}_{2} + X_{1} X_{2} Y_{310} Y_{35} + X_{1} X_{2} \bar{Y}_{310}$     |



Figure 5. Logic Circuit for Example 3.3

#### CHAPTER IV

# DIGITAL EQUATION SIMULATION AND THE CANONICAL FLOW TABLE

All synthesis procedures will produce valid equations for the representation of the specified logic when the procedure is executed correctly. However, some methods are not easily understood or require personal preference in certain steps. Often, intuitively designed circuits do not function properly or for some reason the circuit action needs to be analyzed. To do this, the implied equations of the circuit can be written.

Whether for verification or analysis, it is often necessary to check the system equations. For this reason, a systematic digital equation simulation method has been developed. This method involves the systematic excitation of the inputs to the equations to produce a primitive flow table. This simulated flow table representing the equations may then be compared to the desired circuit action to ascertain if the equations represent the required logic.

Once the simulated flow table is obtained, the task of comparing this table to the original flow table may be larger than the original task of verifying the equations if the state numbers do not coincide. For this reason, it is

advantageous, if not mandatory, to define a standard format for flow tables. The canonical flow table defined in this chapter satisfies this requirement.

Digital Equation Simulation

The simulation technique presented here offers a systematic method for checking equations and in no way assumes prior knowledge of system response. The basic idea is to change one input from some base state and then observe the resulting output and memory states. If these output and memory states are different from any previously determined, then a new state is defined. If they are the same as some other state, then this new state is redundant and is replaced by its equivalent state. By extending this procedure, there finally results a closed flow table. The flow chart shown in Figure 6 illustrates the complete simulation method.

The method may best be explained by an example. Table XII illustrates the step-by-step development of the simulation discussed below. Consider the logic represented by the following equations as derived by the classical method:

$$Z_{1} = X_{1} \overline{X}_{2} \quad \overline{Y}_{1} Y_{2}$$

$$Z_{2} = \overline{X}_{1} X_{2} \quad Y_{1} Y_{2}$$

$$Y_{1} = S_{1} + Y_{1} \overline{R}_{1}$$

$$Y_{2} = S_{2} + Y_{2} \overline{R}_{2}$$

$$(13)$$



Figure 6. Flow Table for Simulation Method

Where the switching conditions are given by:

$$S_{1} = X_{1} X_{2} + X_{2} Y_{2}$$

$$R_{1} = \overline{X}_{1} \overline{X}_{2} + \overline{X}_{2} Y_{2}$$

$$S_{2} = X_{1} \overline{X}_{2} Y_{1} + \overline{X}_{1} X_{2} Y_{1}$$

$$R_{2} = X_{1} X_{2} Y_{1} + \overline{X}_{1} \overline{X}_{2} \overline{Y}_{1}$$
(14)

The simulation is started by the initial assumption of a memory state and an input state. For convenience, assume that all memories are in the reset position,  $(\bar{Y}_1, \bar{Y}_2)$ , and that all inputs are off, (00). This state is termed the temporary base and is entered into a flow table by placing a (1) in the first row under the input column "00". The corresponding output and memory states are also indicated for this row. Starting with this state, (1), as a base, each input is excited individually to determine the system response. First, the input  $X_1$  is excited. This defines a new state, (2), in the "10" column of Table XII (a). The transition path to stable state (2) is indicated by the unparenthesized 2 in row one. Reference to the equations reveal that the corresponding output and memory states do not change. Next, input two is changed from the base, resulting in the new state (3) in the "01" column. Again, the output and memory states remain the same. This completes the investigation from base (1) and the resulting response is indicated by Table XII (a).

The next step is to return to the oldest new state and repeat the procedure with this state as the base.

# TABLE XII

STEP-BY-STEP DEVELOPMENT OF DIGITAL EQUATION SIMULATION

| X <sub>1</sub> X <sub>2</sub> |       |    |     |   |    |    |     |
|-------------------------------|-------|----|-----|---|----|----|-----|
| 00                            | 10    | 11 | 01  |   | Z₂ | Yı | Y2  |
| (1)                           | 2 (2) | _  | 3   | 0 | 0  | 0  | 0   |
|                               | (2)   |    |     | 0 | 0  | 0  | · 0 |
|                               |       |    | (3) | 0 | 0  | 0  | 0   |
|                               |       |    |     | • |    |    |     |

(a) Initial Investigation

| X₁ X₂   |     |     |     |    |        |          |    |
|---------|-----|-----|-----|----|--------|----------|----|
| 00      | 10  | 11  | 01  | Zı | Z2     | Yı       | Ya |
| <br>(1) | 2   | _ · | . 3 | 0  | 0      | 0        | 0  |
| 1       | (2) | 4   | -   | 0  | 0      | 0        | 0  |
|         |     |     | (3) | 0  | 0<br>0 | 0        | 0  |
|         |     | (4) |     | 0  | 0      | 0        | 0  |
| •       | ,   |     | L   |    | ,      | ,<br>, , | ,  |

(b) Investigation of Base (2)

| x <sub>1</sub> x <sub>2</sub> |     |     |     |    |    |    |    |
|-------------------------------|-----|-----|-----|----|----|----|----|
| 00                            | 10  | 11  | 01  | Zı | Z2 | Yı | Y2 |
| (1)                           | 2   | -   | 3   | 0  | 0  | 0  | 0  |
| 1                             | (2) | 4   | -   | 0  | 0  | 0  | 0  |
| 1                             | -   | 4   | (3) | 0  | 0  | 0  | 0  |
|                               |     | (4) |     | 0  | 0  | 1  | 0  |
| -                             | 1   | •   | •   | •  |    | •  | •  |

(c) Investigation of Base (3)

| X <sub>1</sub> X <sub>2</sub> |            |        |       |      |      |     |    |
|-------------------------------|------------|--------|-------|------|------|-----|----|
| 00                            | 10         | 11     | 01    | Zı   | Zə   | Yı  | Ya |
| (1)                           | 2          | -      | 3     | ο    | 0    | 0   | 0  |
| 1                             | (2)        | 4      | -     | 0    | 0    | 0   | 0  |
| 1                             | -          | 4      | (3)   | 0    | 0    | 0   | 0  |
|                               | 6          | (4)    | 5     | 0    | 0    | 1   | 0  |
|                               |            |        | (5)   | 0    | 1    | 1   | 1  |
|                               | (6)        |        |       | 1    | 0    | 0   | 1  |
| ,                             | '<br>(d) I | nvesti | gatio | n of | Base | (4) | •  |

| $\mathbf{X}_{1}$ | Xa |
|------------------|----|
|                  |    |

| 00  | 10  | 11  | 01  | Zı | Za | Yı | Ya |
|-----|-----|-----|-----|----|----|----|----|
| (1) | 2   | -   | 3   | 0  | 0  | 0  | 0  |
| 1   | (2) | 4   | -   | 0  | 0  | 0  | -0 |
| 1   | -   | 4   | (3) | 0  | 0  | 0  | 0  |
| -   | 6   | (4) | 5   | 0  | 0  | 1  | 0  |
| 1   | -   | · 4 | (5) | 0  | 1  | 1  | 1  |
| 1   | (6) | 4   | -   | 1  | 0  | 0  | 1  |

(e) Investigations of Bases (5) and (6) and the Final Simulated Flow Table At this point, the oldest new state is (2). With "10" as a new base, changing the first input defines a transition to the "00" column. The reader is encouraged to check both the output and switching equations to verify that the resulting output and memory states for this possible transition remain the same. The new state defined in column one is redundant since it is equivalent to (1). Hence, a transition path from (2) to (1) is indicated by a 1 entered in column one. Next, the second input is changed from the base. This defines a new state, (4), in the "11" column and the input "11" sets  $Y_1$ . This completes the investigation of (2). The result is shown in Figure XII (b).

The next base is (3) and investigations from this base reveal that both input changes describe redundant information. The first input change transfers to (4) and the second change transfers to (1). See Table XII (c).

The first input change from the next base, (4), sets  $Y_2$ , subsequently giving the output  $Z_2$ . Since this new state is not redundant, the state number (5) is assigned in the "01" column. Changing the second input from base (4) sets  $Y_2$ .  $\overline{X}_2 Y_2$  resets  $Y_1$  which results in the  $Z_1$  output. Again, this new state is not redundant and the state number (6) is assigned to this transition. See Table XII (d).

The first input change from state (5) resets  $Y_2$  and produces no output. This is equivalent to state (4) so no new state number is assigned. The second input change from (5) resets  $Y_1$  and then  $Y_2$ , and has no output. This

defines a transition path back to state (1).

The final state to be investigated is state (6). It can be shown that both input changes describe transitions to previously defined states. Since there are no new states to be investigated, this completes the simulation; the final simulated flow table is shown in Table XII (e).

The equations examined above were derived from the classical method. In the classical method, each memory state is assigned to a complete row. In the state matrix method, the memory elements are associated with input columns individually, not the complete row. Consequently, when simulating the state matrix equations, the particular sub-memory state associated with a column, not the total memory state, is all that needs to be considered during investigations. With this in mind, it is convenient to place the designation of the memory state beside the state number in the flow table rather than beside the complete row.

#### Canonical Flow Table

Considering the previously mentioned need for the canonical flow table and the simulation method discussed above, it seems reasonable to define the canonical flow table in a manner analogous to the simulated flow table. The process used here is the systematic ordering of the rows of a primitive flow table in accordance with the specified response to input changes. Starting with the origin

or first stable state as a base, the state resulting from the first input change is placed in the second row. The state resulting from the second input change is placed in the third row, etc. Upon the completion of the investigation of this base, the oldest new state is then used as a base and the entire process is repeated until all rows have been reordered. The state numbers are then resequenced.

The process is best illustrated by an example. Consider the primitive flow table used in Chapter III, Table VI. The redundant state is eliminated and the reduced primitive flow table is shown in Table XIII (a).

Starting with state (1) as a base, the first input change indicates a transition path to state (2). Since state (2) is already in row two, no reordering is necessary. The second input change indicates a transition path to (7). Hence, the row containing state (7) is placed third as shown in Table XIII (b). This completes the investigation from (1).

The first input change from (2) indicates a path back to a previously ordered state, (1), requiring no reordering. The second input change indicates a path to (3). Since it happens that (3) is already in the next row, no reordering is required. See Table XIII (c).

The next base is (7). This state has transitions to states (8) and (1), respectively. Thus, state (8) is moved to the fourth row and the transition to (1) is already ordered. See Table XIII (d).

# TABLE XIII

THE DEVELOPMENT OF THE CANONICAL FLOW TABLE

| $\mathbf{X}_{1} \mathbf{X}_{2}$ |     |      |     |    |    |
|---------------------------------|-----|------|-----|----|----|
| 00                              | 10  | : 11 | 01  | Zl | Zą |
| (1)                             | 2   | _    | 7   | 0  | 0  |
| 1                               | (2) | 3    | _   | 0  | 0  |
| -                               | 2   | (3)  | 4   | 0  | 0  |
| 1                               | _   | 5    | (4) | 0  | 0  |
| -                               | 6   | (5)  | 4   | 0  | 0  |
| 1                               | (6) | 3    | -   | 1  | 0  |
| 1                               | -   | 8    | (7) | 0  | 0  |
|                                 | 2   | (8)  | 7   | 0  | 1  |

| (a) | Original | Primitive | Flow | Table |
|-----|----------|-----------|------|-------|
|-----|----------|-----------|------|-------|



| 00         | 10      | 11  | 01  | Zı | Za  |
|------------|---------|-----|-----|----|-----|
| (1)        | 2       | -   | 7   | 0  | 0   |
| 1          | (2)     | 3   | -   | 0  | 0   |
| 1          | -       | 8   | (7) | 0  | 0   |
| -          | 2       | (3) | 4.  | 0  | 0   |
| 1          | -       | 5   | (4) | 0  | 0   |
| ´ <b>_</b> | 6       | (5) | 4   | 0  | 0   |
| 1          | (6)     | 3   | _   | 1  | 0   |
|            | 2       | (8) | 7   | 0  | 1   |
| (1)        | T • / • | 1 7 |     |    | (4) |

(b) Initial Investigation From (1)

|   | x <sub>1</sub> x <sub>2</sub> |     |     |     |                |    |
|---|-------------------------------|-----|-----|-----|----------------|----|
|   | 00                            | 10  | 11  | 01  | Z <sub>1</sub> | Z2 |
| Γ | (1)                           | 2   | -   | 7   | 0              | 0  |
|   | 1                             | (2) | 3   | -   | 0              | 0  |
|   | 1                             | -   | 8   | (7) | 0              | 0  |
|   | -                             | 2   | (3) | 4   | 0              | 0  |
|   | 1                             | -   | 5   | (4) | 0              | 0  |
|   | -                             | 6   | (5) | 4   | 0              | 0  |
|   | 1                             | (6) | 3   | -   | 1              | 0  |
|   | _                             | 2   | (8) | 7   | 0              | 1  |

(c) Investigation of State (2)

| $\mathbf{X}_{1} \mathbf{X}_{2}$ |            |     |     |                |     |
|---------------------------------|------------|-----|-----|----------------|-----|
| 00                              | 10         | 11  | 01  | Z <sub>1</sub> | Z2  |
| (1)                             | 2          | -   | 7   | 0              | 0   |
| 1 .                             | (2)        | 3   | -   | 0              | 0   |
| 1                               | _          | 8   | (7) | 0              | 0   |
| -                               | 2          | (3) | 4   | 0              | 0   |
| -                               | 2          | (8) | 7   | 0              | 1   |
| 1                               | -          | 5   | (4) | 0              | 0   |
| -                               | 6          | (5) | 4   | 0              | 0   |
| 1                               | (6)        | 3   |     | 1              | 0   |
| ( -                             | \ <b>-</b> |     |     |                | (-) |

(d) Investigation of State (7)

| X <sub>1</sub> X <sub>2</sub> |     |     |     |    |    |
|-------------------------------|-----|-----|-----|----|----|
| <br>00                        | 10  | 11  | 01  | Zı | Za |
| (1)                           | 2   | -   | 7   | 0  | 0  |
| 1                             | (2) | 3   |     | 0  | 0  |
| 1                             | -   | 8   | (7) | 0  | 0  |
| -                             | 2   | (3) | 4   | 0  | 0  |
|                               | 2   | (8) | 7   | 0  | 1  |
| 1                             | -   | 5   | (4) | 0  | 0  |
| -                             | 6   | (5) | 4   | 0  | 0  |
| 1                             | (6) | 3   | _   | 1  | 0  |

(e) Investigation of State (3)

| $\mathbf{X}_{1} \mathbf{X}_{2}$ |       |     |     |                |    |
|---------------------------------|-------|-----|-----|----------------|----|
| 00                              | 10    | 11  | 01  | Z <sub>1</sub> | Za |
| (1)                             | 2     | -   | 3   | 0              | 0  |
| 1                               | (2)   | 4   | -   | 0              | 0  |
| 1                               | -     | 5   | (3) | 0              | 0  |
| -                               | 2     | (4) | 6   | 0              | 0  |
| -                               | 2     | (5) | 3   | 0              | 1  |
| 1                               | -     | 7   | (6) | 0 .            | 0  |
| _                               | 8     | (7) | 6   | 0              | 0  |
| 1                               | . (8) | 4   | -   | 1              | 0  |

(f) The Completed Canonical Flow Table With Resequenced State Numbers The reader is encouraged to investigate states (3), (8), (4), and (5) to verify that the remaining states are already in the proper order. Once the rows are in the proper order, the state numbers are then resequenced so that each stable state number corresponds to its row number. The completed canonical flow table is shown in Table XIII (f).

One further point which has not been decided at the time of this writing is the definition of an origin for the primitive flow table. The origin is usually thought of as being the state with the inputs off and having the desired sequence or logic developed from this point. However, a more meaningful definition of the origin should consider the topology of the transitions as being more important than the number of inputs or outputs that are on or off. This definition should be comprehensive enough so that an origin can be uniquely determined for any primitive flow table.

Since an origin is not defined in this chapter, the canonical flow table used here is not unique. The rows are in the proper order, but the origin or first row in the canonical flow table will be the first row given in the primitive flow table. This depends upon the designer's personal preference and will, in general, not be unique. However, for all of the cases investigated by the author, the simulated flow table has resulted with the same origin as the canonical primitive flow table, thereby presenting no problem.

### CHAPTER V

### DIGITAL COMPUTER PROGRAMS

The logic systems program is designed to perform either the synthesis or simulation of digital control systems. In order to perform system synthesis, the user needs only to supply the primitive flow table describing the desired logic; the computer program will then perform the necessary steps to obtain the digital equations by the state matrix synthesis procedure given in Chapter III. These equations may then be implemented to obtain a circuit containing the information represented by the primitive flow table.

With this capability, the designer does not need to know a formal synthesis procedure; he only needs to know how to write a primitive flow table, call the program, and then implement the resulting equations.

The simulation program offers a powerful tool for the analysis of digital systems. This program generates the primitive flow table implied by a set of digital equations by the method described in Chapter IV. The simulation program may be used either to confirm the validity of equations or to analyze the logical implications of existing circuits. This can be advantageous when working with intuitively designed circuits.

The FORTRAN IV source deck listed in Appendix B has been running on the WATFOR terminal of OSU's IBM 360/50 computing facility. A time-share version of the program is also available to allow users with remote teletype terminals to have access to the program from any phone line. A user's guide for the time share program will be made available under a separate cover.

Since the programs are rather lengthy and the listings given in Appendix B contain many of the details of the programs, only the philosophy of the programs is presented in the rest of this chapter. Appendix C shows both the calling information and the computer solutions to many example problems. For further details of the use of this program, see the write-up in Appendix B and the example solutions in Appendix C.

## Synthesis Program LOGSYN

Subroutine LOGSYN is the executive subroutine for the synthesis of digital systems. The flow chart showing the relation of subroutines is given by Figure 7. Subroutine LOGSYN reads in the input data concerning the primitive flow table and then uses subroutine PRINT to print the original primitive flow table. This primitive flow table is then examined by subroutine EQUIV to reduce any redundant information which might be contained in the flow table. If two states are found to be redundant, one is eliminated and an indication of this reduction is printed out below the



Figure 7. Flow Diagram for Logic Systems Program

original primitive flow table. This reduced primitive flow table is then put into canonical form by subroutine CANON. In this routine the rows of the primitive flow table are reordered and resequenced as described in Chapter IV. The resulting canonical flow table is then printed by subroutine PRINT.

Subroutine OUTPUT performs most of the steps required for system synthesis. In this routine, the memory requirements for each column are determined and subroutine ASSIGN is used to provide the passive memory assignment code to distinguish between stable states. After each state is made unique by the proper memory assignment, the state signals are printed. This gives the input and memory combination which describes each stable state. Next, the switching conditions required for proper circuit action are printed. The switching conditions are presented by giving the state numbers at which a switch occurs. Finally, the output equations are given by printing the states at which the individual outputs appear. This completes the synthesis procedure and the program then returns to the main calling program to exit.

## Simulation Program LOGSIM

Subroutine LOGSIM is the executive program for systems simulation. As can be seen by Figure 7, this routine reads the data cards containing basic information concerning the system to be simulated. Subroutine LOGSIM then sets up a

loop similar to the one shown in Figure 6 of Chapter IV. This routine changes an input according to a Gray code. The Gray code is supplied by subroutine ASSIGN. The corresponding system response is determined by subroutine DIGEQN. Subroutine DIGEQN is a subroutine supplied by the user containing the switching and output equations. The input change and the corresponding response determines a new state. This state is then checked for redundancy by subroutine EQUIV. If the new state is not equivalent to a previously defined state, a state number is assigned to this state.

This process is continued until all states have been investigated and no new information is being generated. At this point, the simulation is completed and subroutine PRINT is then used to print the simulated primitive flow table.

Appendix C contains many examples of problems solved with both the synthesis and simulation programs. The reader is referred to the appendices for further information concerning the usage and input for these computer programs.

### CHAPTER VI

### SUMMARY AND CONCLUSIONS

### Summary

The major effort of this thesis has been concentrated upon the development of new techniques for the synthesis and analysis of digital logic systems. The synthesis procedures are based upon the assumption that the outputs are related to the inputs. This relation can be represented by the vector matrix equation

$$\begin{bmatrix} \mathbf{Z} \end{bmatrix} = \begin{bmatrix} \mathbf{M} \end{bmatrix} \begin{bmatrix} \mathbf{X} \end{bmatrix}$$

(15)

Since the input vector  $\begin{bmatrix} X \end{bmatrix}$  and the desired output vector  $\begin{bmatrix} Z \end{bmatrix}$  are known, the synthesis reduces to the determination of the binary matrix  $\begin{bmatrix} M \end{bmatrix}$ . The entries in this matrix give the relationship between the inputs and the outputs and contain memory information of previous states.

The synthesis proceeds from entering the state numbers from a statement of the desired logic or sequence into the matrix [M]. The memory requirements are then determined and entered into the matrix, producing the set of output equations in matrix form. Specification of the switching

conditions for the memory elements completes the synthesis procedure.

The simulation technique presented here is quite helpful either to verify digital equations or to analyze existing circuits. This technique can also be used to totally redesign existing circuits by first writing the equations for the circuit, obtaining the simulated flow table, and then synthesizing the state matrix equations from this flow table. The canonical flow table is also an aid for analysis and comparison.

The digital computer programs developed to perform either systems synthesis or simulation offer a great design tool to the designer who is unfamiliar with switching circuit theory. These programs perform the steps necessary to synthesize or simulate digital systems as described in Chapters III and IV. With these programs, the designer only needs to be able to write a primitive flow table and to implement equations.

## Comparison to Other Techniques

To fully evaluate the merits of this synthesis technique, a general comparison to existing techniques should be made. This technique is compared to the classical method and those methods suggested by Cole (1) and Maroney (6) on the basis of the following areas:

<u>Simplicity of the Synthesis Procedure</u> - The execution of the state matrix synthesis

procedure is much less complicated than the classical method since the merging operation, operational flow table, Karnaugh maps, etc., are eliminated. The total concepts of circuit synthesis are much easier to grasp, partially due to the use of the familiar matrix notation. In comparing to the tabular methods of Cole and Maroney, one can only compare on the basis of procedure simplicity since these methods produce essentially the same equations as the techniques presented here. The philosophy of circuit implementation is also the same. Thus, any comment made about the state matrix equations or circuits is equally applicable to those of the tabular methods.

Cole's tabular technique for the synthesis of feedback sequential circuits handles persistent states in a more straightforward manner than does the matrix method. However, the search procedure for persistent states in the matrix is more mechanical. It is felt that the synthesis concepts using the matrix notation are easier to grasp than the tabular method; but this is a matter of personal preference.

Maroney's tabular method handles random input problems in a tabular technique similar

to Cole's method. The random input possibility requires multiple transition paths from states. The transitions from each state are very hard to follow in the tabular form; whereas, the primitive flow table provides a graphic display of transition paths. This causes a slight problem for involved sequences since the designer must keep much of this information in his head rather than on paper. Also, redundant states are harder to sense from the tabular technique than from the primitive flow table. Again, it is felt that the matrix synthesis concepts are easier to grasp.

- 2. <u>Simplicity of Circuit Implementation Procedure</u> -The state matrix and tabular synthesis procedures offer a specific step-by-step procedure for circuit implementation; whereas, the classical method does not lend itself to any set procedure.
- 3. <u>Circuit Complexity</u> The number of elements required to implement a circuit is generally a good indication of the circuit complexity. Although the state matrix equations usually require more memory elements, the use of the passive memory effect reduces the total number of elements to about the same or less than that required by the classical method. However, this is not a very rigid basis for comparison

since the classical method offers such a flexibility in writing equations from the Karnaugh maps. Each designer might derive different equations from the classical method depending upon his own personal preference. Thus, to compare on this basis, the equations from the classical Karnaugh maps must be rewritten until a combination with minimum hardware is determined. This is then compared to the state matrix method.

4. Other Circuit Considerations - The state matrix synthesis procedure offers circuit features that are not available from the classical method. Among these are the elimination of switching hazards, cycles, and other logical complications. Another very important feature is the prepared flow path concept. In this procedure, each memory is switched prior to any input change, thus preparing all possible paths from that state. Notice that in the classical method the input change causes the switching of a memory to give the next state. The prepared flow path feature produces circuits in which the only delays are the delays caused by forming the input combination and any transmission time delay. Thus, circuit response time is at a minimum.

Another important feature stemming from the prepared flow path concept is that the passive memory elements used in this synthesis procedure are never switched when they are under power as they are in the classical method. Switching under power causes undesirable transient pulses in the circuit. This is avoided by switching the element before the passive signal appears.

### Suggestions for Further Study

As is true with any study, there are many areas providing interesting further study. Among these are:

1. <u>A Synthesis Procedure Considering Some Combination</u> of the Total Input and Changed Inputs - The synthesis procedure for feedback sequential circuits presented in Chapter II considers only the changed input whereas the procedure for random input circuits (Chapter III) considers only the total input state. Both of these approachs have their own distinguishing merit; however, it is felt that some combination of the two concepts will consistently produce circuits having more of the desirable features of both methods.

In the feedback sequential method, the W elements can often be replaced by "anding" another input signal to the state signal. Rules

for doing this should be investigated.

Another interesting synthesis concept is the use of internal information as an auxiliary input. It seems that as more information is used as input information, the less complicated the resulting circuit. This concept has not yet been pursued.

2. Definition of Origin for Canonical Flow Table -The canonical flow table defined in Chapter IV has a unique relationship involving the order of the rows of a primitive flow table. Any two flow tables containing the same information will always result in canonical flow tables having the same row relationships. However, the row appearing first in the table is thus far left to the designer's preference. Although this is usually acceptable, a rigorous definition for the origin or first row of the canonical flow table should be made considering only the topology of the table's transition paths. This would provide a unique format for displaying the information contained in any primitive flow table.

3. <u>Computer Program for Feedback Sequential</u> <u>Synthesis</u> - Efforts should be made to write a computer program to perform the necessary steps for the synthesis of feedback sequential circuits as presented in Chapter II. The techniques already developed for the present program could be easily adapted to provide a program to accomplish this from a statement of the desired sequence.

4. A Logic Synthesis Procedure Considering Proportional As Well As Binary Variables - To date, the synthesis of physical systems using formal logic has been restricted to binary or digital systems. Considering the matrix synthesis philosophy presented in this thesis, it seems natural to extend this technique to include proportional or dynamic variables as well as binary variables. A proportional variable could be entered into the state matrix to modify a state in the same manner as the memory elements are in this thesis. The proportional state modifier would tell not only when to give the output but would also tell how. This "how" could be the proportional signal rather than the binary signal now used.

The author is currently engaged in investigating the possibilities of such a synthesis procedure.

### A SELECTED BIBLIOGRAPHY

- (1) Cole, J. H. "Synthesis of Optimum Complex Fluid Logic Sequential Circuits." (Ph.D. Thesis, Oklahoma State University, 1968).
- (2) Fitch, E. C. Jr. <u>Fluid Logic</u>. Stillwater: Oklahoma State University, 1966.
- (3) Huffman, D. A. "The Synthesis of Sequential Circuits." <u>Journal of the Franklin Institute</u>, Vol. 257, No. 4 (1954).
- (4) Jensen, D. F., et al. "Pneumatic Diaphragm Logic."
   <u>Proceedings of the Fluidics Symposium</u>. New York: ASME, 1967.
- (5) Marcus, M. P. <u>Switching Circuits For Engineers</u>. Englewood Cliffs: Prentice-Hall, 1962.
- Maroney, G. E. "A Synthesis Technique for Asynchronous Digital Control Networks." (M.S. Report, Oklahoma State University, 1969).
- (7) Miller, R. E. <u>Switching Theory</u>, 2 Vols. New York: John Wiley, 1965.
- (8) Moore, E. F., ed. <u>Sequential</u> <u>Machines: Selected</u> Papers. Reading, Mass.: <u>Addison-Wesley</u>, 1964.
- (9) Shannon, C. E. "A Symbolic Analysis of Relay and Switching Circuits." <u>Trans. AIEE</u>, Vol. 57 (1938).

# APPENDIX A

# THE PASSIVE MEMORY

### APPENDIX A

## THE PASSIVE MEMORY

This appendix deals with the definition, description, and assignment of passive memory elements.

## Definition

Any memory element which does not rely upon an active power source to retain its output state is said to be a <u>passive</u> memory element. In most cases, these devices have a mechanical memory and the logic signal is merely directed through the device according to its mechanical position. The best example of this concept is the four-way, twoposition detent value shown in Figure 8.



Figure 8. Passive Memory Valve

### Description

This device has many salient features, most important of which is the mechanical memory. Once the device has been switched by either the set or reset signals, the device remains in that position due to the detent hold feature. The signal sent through the device does not necessarily have to be an active signal connected to the supply; this signal may be an input or logic signal which appears only occasionally.

By sending a logic signal through the device, the output XY appears only when the memory element is in the proper position (indicated by Y) "and" the logic signal X is on. The  $X\overline{Y}$  signal appears only when the device is in the "reset" position "and" the signal X is on. This device holds its mechanical position to display memory characteristics and it forms two "and" combinations (X·Y and X· $\overline{Y}$ ); thus, the passive memory device serves the function of three logic elements, memory and two "ands". By utilizing this effect, circuit complexity and hardware can be reduced substantially.

Another advantageous feature of this device is the complementary output. Notice that the device has two outputs, XY and  $\overline{XY}$ ; when one is on (pressurized) the other is off (to tank). Thus, the need for the inversion of Y to get its complement  $\overline{Y}$  is eliminated.

The pneumatic diaphragm logic device (4) possesses similar mechanical memory characteristics as the valve

described above.

Fluidic passive memory devices without moving mechanical parts do not exist; however, a similar savings in circuit hardware can be made by the use of the two devices shown in Figure 9. The bistable amplifier is an active memory element and its complementary outputs are fed into a passive "and". The passive "and" element has complementary outputs serving the function of two separate "ands" to form XY and  $X\overline{Y}$ .



Figure 9. Fluidic Memory Circuit

The latching relay performs the analogous passive memory function in electronic circuits. However, modern

technology has almost phased out the use of relays in compact logic circuits. Even so, the addition of two extra "ands" in an electronic circuit is much less costly than the same for fluid circuits. The usual bistable flip-flop integrated circuit could be built with outputs XY, and  $X\overline{Y}$  instead of the usual Y,  $\overline{Y}$  where X is some logic signal.

### Assignment

As has been shown above, the passive memory can be used to reduce hardware when distinguishing between two states. The problem of assignment when higher orders of memory are required is discussed next. By using one more passive memory element, the circuit of Figure 8 is modified to form three unique memory states as shown by Figure 10 (a). Four unique states are obtained in Figure 10 (b) by adding one more passive memory element.

As shown by the previous discussion, each time another memory element is added, another unique passive memory state results. In general, N-1 passive memory elements describe N unique states. The assignment schematic shown in Figure 11 illustrates the passive memory code. To describe N unique states, omit all memory elements numbered above N-1.

The alternating placement of elements in the assignment code allows the proper balance of fluid power. Higher orders may be obtained in the same alternating pattern.

To illustrate the assignment technique for making each state of an input column unique, consider the three states



(a) Three Unique States, X  $Y_1 Y_2$ , X  $Y_1 \overline{Y}_2$ and X  $\overline{Y}_1$ 



(b) Four Unique States,  $X Y_1 Y_2$ ,  $X Y_1 \overline{Y}_2$ ,  $X \overline{Y}_1 Y_3$ , and  $X \overline{Y}_1 \overline{Y}_3$ 

Figure 10. Passive Memory Assignment Circuits



1, 3, and 5. Using the double subscript notation, the memory states are assigned as follows:

(1) 
$$Y_{15}Y_{13}$$
  
(3)  $Y_{15}\overline{Y}_{13}$   
(5)  $\overline{Y}_{15}$ 

The reader is cautioned not to confuse the double subscript notation discussed here and the single subscript notation used in Figure 11. The double subscript notation carries information of the switching conditions. For example,  $Y_{15}$  (read Y, one, five) is set prior to state 1, and is reset prior to state 5. As an example of higher order memory state assignment, consider the states 1, 3, 5, 8, 10, and 13. The assignment is as follows:

> (1)  $Y_{18}Y_{15} Y_{13}$ (3)  $Y_{18}Y_{15} \overline{Y}_{13}$ (5)  $Y_{18}\overline{Y}_{15}$ (8)  $\overline{Y}_{18}Y_{813}Y_{810}$ (10)  $\overline{Y}_{18}Y_{813}\overline{Y}_{810}$ (13)  $\overline{Y}_{18}\overline{Y}_{873}$

The reader is encouraged to implement this circuit using Figure 11 as a guideline.

As a final note, it should be pointed out that this synthesis procedure allows every column in the state matrix to be treated independently. In this respect, each input state (or changed input) may be sent through memory elements as a passive signal.

# APPENDIX B

## LISTING OF COMPUTER PROGRAMS

|           | ***************************************                                                                                                       |                    |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| 1         |                                                                                                                                               | *1.SP01            |
| 1         | LOGIC SYSTEMS PROGRAM                                                                                                                         | *LSP00             |
|           |                                                                                                                                               | *LSP01             |
|           |                                                                                                                                               | *L SP04<br>*L SP04 |
|           | RUBERT L. WOODS                                                                                                                               | *LSP0              |
|           | SCHOOL OF MECHANICAL AND AEROSPACE ENGINEERING                                                                                                | *LSP01             |
|           | SEMUL OF RELANDICAL AND ACKOSYNCE CHOINERKING     OKLAHONA STATE UNIVERSITY                                                                   | *LSP0              |
| · .       | DECEMBER, 1969                                                                                                                                | +LSP0              |
| S. 1      |                                                                                                                                               | +LSP0              |
|           |                                                                                                                                               | *LSPOR             |
|           |                                                                                                                                               | #1.5P0             |
|           | THIS PROGRAM IS DESIGNED TO PERFORM EITHER THE SYNTHESIS                                                                                      | *LSPO              |
| 3         | * OR SIMULATION OF DIGITAL CONTROL SYSTEMS. FOR FURTHER                                                                                       | *LSP0              |
| -         | * INFORMATION, SEE THE M.S. THESIS "THE STATE MATRIX METHOD                                                                                   | *L\$PO             |
| - 1       | FOR THE SYNTHESIS OF DIGITAL LOGIC SYSTEMS".                                                                                                  | *LSP0              |
|           |                                                                                                                                               | *LSP00             |
| 1         |                                                                                                                                               | *LSP00             |
| 4         |                                                                                                                                               | *LSP0              |
| ;         |                                                                                                                                               | *LSPO              |
|           | *SYSTF#S STRTHESIS:                                                                                                                           | +L SPO             |
|           |                                                                                                                                               | *LSP0              |
|           | <ul> <li>IN ORDER TO PERFORM SYSTEM SYNTHESIS USING THE STATE</li> <li>MATRIX SYNTHESIS PROCEDURE, THE USER MUST USE THE FOLLOWING</li> </ul> | #LSP0              |
|           | <ul> <li>MATRIX STATHESTS PROCEDURE: THE USER AUGH USE THE FULLWING</li> <li>CALLING PROGRAM.</li> </ul>                                      | *LSP0              |
|           | CALLIND FRUDRAM.                                                                                                                              | +LSP0/             |
|           | CALL LUGSYN                                                                                                                                   | *LSP0              |
|           | STOP                                                                                                                                          | +LSPO              |
|           | END                                                                                                                                           | +LSP0              |
|           |                                                                                                                                               | +LSP0              |
| ·         |                                                                                                                                               | *L SPD             |
|           | THE USER MUST ALSO SUPPLY THE FOLLOWING INFORMATION TO                                                                                        | *LSPO              |
| ` '       | * BE READ FROM DATA CARDS.                                                                                                                    | *LSPO              |
| 1         |                                                                                                                                               | *LSP0              |
|           | CARD 1 - PROBLEM IDENTIFICATION                                                                                                               | +LSPO              |
| 2         | ANYTHING READ FROM THIS CARD WILL BE PRINTED IN                                                                                               |                    |
|           | THE OUTPUT.                                                                                                                                   | *L'SPO             |
|           | CARD 2 - NI, NO, NR = FORMAT(312) NI = NUMBER OF INPUTS                                                                                       | *LSP0              |
|           | <pre>* AL = MURBER OF OUTPUTS * NO = NUMBER OF OUTPUTS</pre>                                                                                  | +LSP0              |
|           | • NO = NUMBER OF ROWS IN THE PRIMITIVE FLOW TABLE                                                                                             |                    |
| · •       | <ul> <li>CARD 3 - INPUT STATES FOR EACH COLUMN = FORMAT(16(411))</li> </ul>                                                                   |                    |
|           | FOR THE INPUTS, THE CARD SHOULD READ                                                                                                          | *LSP0              |
|           | • 00 10 11 01                                                                                                                                 | +LSPD              |
|           | CARD 4 AND SUCCESSIVE CARDS EACH CONTAIN ONE ROW OF THE                                                                                       | +LSPO              |
|           | PRIMITIVE FLOW TABLE AND THE CORRESPONDING                                                                                                    | +LSP0              |
|           | OUTPUT STATE = FORMATII614,6111                                                                                                               | #LSPO              |
| · .       | 16 COLUMNS AND 6 OUTPUTS ARE READ FROM EACH                                                                                                   | *1.SP0             |
|           | <ul> <li>CARD. STABLE STATES ARE INDICATED BY ADDING</li> </ul>                                                                               | *LSP0              |
| . 1       | 1000 TO THE STATE NUMBER TO DISTINGUISH THEM                                                                                                  | *LSP0              |
| $\sim 10$ | FROM TRANSITION PATHS. A "DON'T CARE" OUTPUT                                                                                                  | +LSP0              |
|           | IS INDICATED BY ENTERING A #2# INSTEAD OF A #0*                                                                                               |                    |
| • •       | ¢ GRA "I".                                                                                                                                    | *LSP0              |
| •         |                                                                                                                                               | *LSPOC             |
|           |                                                                                                                                               | *LSP00             |
| - 3       |                                                                                                                                               | *LSP04<br>*LSP04   |
|           |                                                                                                                                               |                    |

| *SYSTEMS SINULATION:                                                                                              | -+LSP0060  |
|-------------------------------------------------------------------------------------------------------------------|------------|
| Statuta attock tota                                                                                               | +LSP0061   |
|                                                                                                                   | *LSP0062   |
| IN ORDER TO PERFORM SYSTEM SIMULATION, THE USER MUST USE                                                          |            |
| * THE FOLLOWING CALLING PROGRAM.                                                                                  | *L SP0064  |
| * THE FULLWING CALLING PROGRAM                                                                                    | *LSP0065   |
|                                                                                                                   | *LSP0066   |
| CALL LOGSIN                                                                                                       | *LSP0067   |
| STOP                                                                                                              | *LSP0068   |
| END                                                                                                               | *LSP0069   |
| THE USER MUST ALSO SUPPLY THE SUBROUTINE DIGEON                                                                   | *LSP0070   |
| THE USER HUST ALSO SUPPLY THE SUBRUITINE DIGENN     DESCRIBING THE SYSTEM EQUATIONS, AND THE FOLLOWING INFORMATIO |            |
|                                                                                                                   | *LSP0072   |
| * TO BE READ FROM DATA CARDS.                                                                                     | *LSP0073   |
|                                                                                                                   | *LSPD074   |
| * CARD 1 - PROBLEM IDENTIFICATION                                                                                 |            |
| * ANYTHING READ FROM THIS CARD WILL BE PRINTED IN                                                                 |            |
| * THE OUTPUT.                                                                                                     | *LSP0076   |
| * CARD 2 - NI, ND, NM = FORMAT(312)                                                                               | *LSPOD77   |
| * THE NUMBER OF INPUTS, OUTPUTS, AND MEMORIES.                                                                    | *LSP0078   |
| * CARD 3 - V(H), X(I) = FORMAT(1811,411)                                                                          | *LSP0079   |
| * THE INITIAL STATE OF ALL OF THE MEMORY ELEMENTS                                                                 |            |
|                                                                                                                   | *LSP0081   |
| * CARD 4 AND SUCCESSIVE CARDS EACH CONTAIN: THE NUMBER OF                                                         |            |
| * HEMORY ELEMENTS ASSOCIATED WITH THE JC-TH                                                                       | *LSP0083   |
| * COLUMN, MCIJC, II, AND THE CORRESPONDING NUMBER                                                                 | *LSPD084   |
| * DESIGNATION OF THE JH-TH MEMORY IN THE JC-TH                                                                    | *LSP0085   |
| COLUMN, MC(JC,JH+1) = FORMAT(12,912)                                                                              | *LSP0086   |
|                                                                                                                   | *LSP0087   |
|                                                                                                                   | *LSP0088   |
|                                                                                                                   | *LSP0089   |
|                                                                                                                   | *LSP0090   |
| * ARRAY SIZES                                                                                                     | -*LSP0091  |
|                                                                                                                   | *LSPD092   |
|                                                                                                                   | *LSP0'093  |
| * /ALL/ - IX(NI,NC), IY(NM,NR), IZ(NO,NR), S(NR,NC)                                                               | *LSP0094   |
| * /EQN/ - X(NI), Y(NH), Z(NO), KS(NR,NC), MC(NC,NH/2+1)                                                           | *LSP0095   |
| <pre>* /DUT/ - SSC(NC,NR/2+1), SSR(NR)</pre>                                                                      | *LSP0096   |
| * /ASN / - IG(NR/2-1,NR/2)                                                                                        | *LSP0097   |
| * /IDN/ - TDEN(20)                                                                                                | *LSP0098   |
|                                                                                                                   | *LSP0099   |
| * DIMENSION STATEMENTS -                                                                                          | *LSP0100   |
| DIGEQN - ITS(NC), MS(NM), MR(NM)                                                                                  | *LSP0101   |
| * EQUIV - IT(NC)                                                                                                  | *L SP0 102 |
| OUTPUT - SET(NM,NR/2), RESET(NM,NR/2), PS(NR/2)                                                                   | *L SP0103  |
| # IZSIND, NR), JL(NM/2), IYP(MO, NR/2), INOT(HO, NR/2)                                                            |            |
| * NY(MO=5), IO(NR=40)                                                                                             | *1.SP0105  |
| <pre>* PRINT - IN3(41), IXP(NI=4), IZP(NO=6), MS(NC), MSS(NC)</pre>                                               | *LSP0106   |
| ASSIGN - IA(NR/2), RA(NR/2)                                                                                       | *LSP0107   |
|                                                                                                                   | *LSP0108   |
| * NOTES -                                                                                                         | #L SP0 109 |
| * - NM = NR-NC                                                                                                    | *LSP0110   |
| * - MO = LOG(NR,1) + 1                                                                                            | *LSP0111   |
| * - SUBSCRIPTS SUCH AS IXPINI=4) IMPLY THAT THE ARRAY IXP                                                         |            |
| * IS DEFINED IN A DATA STATEMENT.                                                                                 | *LSP0113   |
| n ≢r an an tha an                                                             | *LSP0114   |
|                                                                                                                   | **1.SP0115 |
| CALL LDGSYN                                                                                                       | LSP0116    |
| CALL LOGSIN                                                                                                       | LSP0117    |
| STOP                                                                                                              | LSP0118    |
| END                                                                                                               | LSP0119    |

SUBROUTINE LOGSYN LSP0120 \*L SP0122 SUBROUTINE LOGSYN IS THE EXECUTIVE PROGRAM FOR SYSTEM \*LSP0123 SYNTHESIS. THIS PROGRAM READS THE DATA CARDS, PRINTS THE \*LSP0124 DRIGINAL PRIMITIVE FLOW TABLE, CHECKS FOR ANY REDUNDANT \*LSP0125 INFORMATION IN THE PRIMITIVE FLOW TABLE, REARRANGES THE ROWS \*LSP0126 \*\* TO FORM THE CANONICAL FLOW TABLE, PRINTS THE CANONICAL FLOW \*L SP0127 \* TABLE, AND THEN PRINTS THE STATE, SWITCHING, AND DUTPUT \*LSP0128 INFORMATION. \*LSP0129 \* \*LSP0130 \*LSP0131 NI = THE NUMBER OF INPUTS \*LSP0132 \* NO = THE NUMBER OF OUTPUTS \*LSP0133 \* NR = THE NUMBER OF ROWS IN THE PRIMITIVE FLOW TABLE #1.SP0134 . NC = THE NUMBER OF COLUMNS IN THE PRIMITIVE FLOW TABLE. #1 SP0135 IX(1,JC) = THE STATE OF THE I-TH INPUT FOR THE JC-TH COLUMN IZ(JJIR) = THE STATE OF THE J-TH MEMORY IN THE IR-TH ROW#I SP0136 \*L SP0137 S(IR, JC) = THE ENTRY IN THE IR-TH ROW AND JC-TH COLUMN OF THE \*LSP0138 PRIMITIVE FLOW TABLE. STABLE STATES ARE INDICATED \*LSP0139 BY ADDING 1000 TO THE STATE NUMBER TO DISTINGUISH \*LSP0140 THEM FROM TRANSITION PATHS. \*LSP0141 SSC(JC.1) = THE NUMBER OF STABLE STATES IN THE JC-TH COLUMN \*LSP0142 SSC(JC+K+1) = THE K-TH STABLE STATE IN THE JC-TH COLUMN \*L SP0143 SSR(IR) = THE STABLE STATE IN THE IR-TH ROW \*LSP0144 \*LSP0145 COMMON /ALL/ N1.N0.NR.NM.NC.IX(4.16).IY(36.40).IZ(6.40).S(40.16) LSP0147 COMMON /DUT/ SSC(16,21), SSR(40) LSP0148 COMMON /IDN/ IDEN(20) L SP0 149 INTEGER S. SSC. SSR LSP0150 1 FORMAT (20A4) LSP0151 2 FORMAT(312) LSP0152 3 FORMAT(16(411)) LSP0153 4 FORMAT(1614,6I1) 1 SP0 154 5 FORMAT(1H1,30X, LOGIC SYNTHESIS',/,27X, FOR 11, INPUTS, 1,11, LSP0155 \* ' DUTPUTS.',///)
6 FORMAT(10X'ORIGINAL PRIMITIVE FLOW TABLE FOR'/15X,2044///) 1 SP0156 1 SP0 157 7 FORMAT(1H1,9X\*CANONICAL FLOW TABLE FOR\*/15X,20A4///) LSP0158 8 FORMATI/10X\*WHAT IS "14" IN COLUMN "12", ROW "12"?"/ LSP0159 10X CHECK YOUR DATA FOR ERROR!) LSP0160 9 FORMAT(1H1) LSP0161 10 FORMAT (1H1,9X, 'NUMBER OF INPUTS = '12', NUMBER OF OUTPUTS = '12 LSP0162 \*, NUMBER OF ROWS = \*12/10X\*TO RUN & PROBLEM OF THIS SIZE\*LSP0163 \*, THE ARRAY SIZES MUST BE ALTERED.\*) LSP0164 READ(5,1) IDEN L SP0 165 READ(5.2) NI+ NO+ NR LSP0166 ERROR = 0 LSP0167 IF(N1 .GT. 4) ERROR = 1 LSP0168 IF(NO .GT. 6) ERROR = 1 LSP0169 L SP0170 IF(NR .GT.40) ERROR = 1 1F( ERROR .EQ. 1.0) WRITE(6.10) NI, ND, NR I SP0171 NC = 2\*\*NI LSP0172 READ(5,3)((IX(I,JC),I=1,4),JC=1,NC) LSP0173 READ(5,4)((S(IR,JC),JC=1,16),(IZ(J,IR),J=1,6),IR=1,NR) L SP0 174 L\$P0175 WRITE(6.5) NI. ND WRITE(6.6) IDEN LSP0176 CALL PRINTIO) LSP0177 CALL EQUIVION LSP0178 CALL CANON L SP0179

C

c

r.

ċ

с

C.

c

C

r

C C C

r

r

C.

č

| RITE(6,7) IDEN                                 | LSP0180                                                                                                                                                                                                                           |
|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ALL PRINT(O)                                   | LSP0181                                                                                                                                                                                                                           |
| ) 21 JC=1.NC                                   | LSP0182                                                                                                                                                                                                                           |
| = 0                                            | L\$P0183                                                                                                                                                                                                                          |
| 20 IR=1.NR                                     | L\$P0184                                                                                                                                                                                                                          |
| S = S(IR.JC) - 1000                            | LSP0185                                                                                                                                                                                                                           |
| (IS .LT. 0) GD TD 20                           | L SP0186                                                                                                                                                                                                                          |
| = K+1                                          | LSP0187                                                                                                                                                                                                                           |
| SC(JC+K+1) = IS                                | LSP018B                                                                                                                                                                                                                           |
| SR(1R) = IS                                    | L SP0189                                                                                                                                                                                                                          |
| -(S(IR.JC) .LT. 0) WRITE(6.8) S(IR.JC). JC. IR | LSP0190                                                                                                                                                                                                                           |
|                                                | LSP0191                                                                                                                                                                                                                           |
| ALL OUTPUT                                     | L SP0 192                                                                                                                                                                                                                         |
| RITE(6.9)                                      | LSP0193                                                                                                                                                                                                                           |
| ETURN                                          | LSP0194                                                                                                                                                                                                                           |
| ND                                             | LSP0195                                                                                                                                                                                                                           |
|                                                | ALL PRINT(0)<br>D 21 JC=1,NC<br>= 0<br>D 20 IR=1,NR<br>S = S(IR,JC) - 1000<br>= (K+1)<br>S(IJC,K+1) = IS<br>S(IJC,K+1) = IS<br>S(IR,JC) .LT. 0) WRITE(6,8) S(IR,JC), JC, IR<br>S(IC,JC,1) = K<br>ALL OUTPUT<br>RITE(6,9)<br>ETURN |

SUBROUTINE LOGSIN LSP0196 #LSP0197 \*LSP0198 SUBROUTINE LOGSIN IS THE EXECUTIVE PROGRAM FOR SYSTEM \*LSP0199 SIMULATION. THIS PROGRAM READS THE REQUIRED DATA CARDS AND \*LSP0200 CONDUCTS THE SYSTEMATIC IMPUT EXCITATION. THE RESPONSE TO \*L SP0201 INPUT CHANGES IS CHECKED EACH TIME BY CALLING THE SUBROUTINE \*LSP0202 -CONTAINING THE DIGITAL EQUATIONS. EACH NEW STATE DEFINED IS \*LSP0203 CHECKED FOR REDUNDANCY AND IS ELIMINATED IF EQUIVALENT TO A \*LSP0204 PREVIOUSLY DEFINED STATE. UPON COMPLETION OF THE SIMULATION, #LSP0205 . THE RESULTING PRIMITIVE FLOW TABLE IS PRINTED. \*LSP0206 \*LSP0207 \*LSP0208 ٠ NI = THE NUMBER OF INPUTS \*LSP0209 NO = THE NUMBER OF GUTPUTS \*LSP0210 \* NR = THE NUMBER OF ROWS IN THE PRINITIVE FLOW TABLE NC = THE NUMBER OF COLUMNS IN THE PRINITIVE FLOW TABLE. #I SP0211 #1 SP0212 NC = THE HEMBER OF COLUMNS IN THE PRINITYE FLOW TABLE. +LSP0212 IX(1,JC) = THE STATE OF THE I-TH IMPUT FOR THE JC-TH COLUMN +LSP0213 IY(N,IR) = THE STATE OF THE J-TH MEMORY IN THE IR-TH ROW IZ(J,IR) = THE STATE OF THE J-TH MEMORY ELEMENT IN THE IR-TH +LSP0215 S(IR,JC) = THE ENTRY IN THE IR-TH ROW AND JC-TH COLUMN OF THE +LSP0216 PRINITY FLOW TABLE. STATE ON THE INDICATED +LSP0217 BY ADDING 1000 TO THE STATE NUMBER TO DISTINGUISH +LSP0218 THEN FROM TRANSITION PATHS. \*LSP0219 NC(JC,1) = THE NUMBER OF MEMORY ELEMENTS ASSOCIATED WITH THE \*LSP0220 JC-TH COLUMN \*LSP0221 ACIJC, JN+11 = THE NUMBER DESIGNATION OF THE JM-TH MEMORY \*LSP0222 IN THE JC-TH COLUMN \*LSP0223 \*LSP0224 COMMON /ALL/ HI,NO, HR, NE, IX14, 161, IY(36,40), IZ(6,40), S(40,16) LSP0226 COMMON /EON/ X141, Y1361, Z161, X5140,161, MC(16,19) LSP0227 COMMON /ASH/ 16(19,20) LSP0228 COMMON /IDM/ IDEN(2D) LSP0229 INTEGER X. Y. Z. S LSP0230 -1 FORMAT (20A4) LSP0231 2 FORMAT (312) LSP0232 3 FORMAT (3011.411) LSP0233 4 FORMAT ((1912)) 1 SP0234 5 FORMAT(1H1-30X\*LOGIC SIMULATION\*/20X\*FOR \*11\* INPUTS, \*11 L SP0235 \* DUTPUTS, \*12\* HEMORIES.\*////10X\*SIMULATED FLOW TABLE FOR\*LSP0236 \* /15%.2044///) LSP0237 6 FORNAT (10X, "THE SIMULATED FLOW TABLE WILL BE LONGER THAN 40 ROVS"/LSP023B 10X, THE PARTIAL FLOW TABLE IS GIVEN BELOW' / ) LSP0239 9 FORMAT(1H1) LSP0240 16 FORMAT (1H1, 9X\*HUMBER OF INPUTS = \*12\*. MUMBER OF DUTPUTS = \*12 LSP0241 \*, NUMBER OF MEMORIES = "12/10X"TO RUN A PROBLEM OF THIS "LSP0242 "SIZE, THE ARRAY SIZES PUST BE ALTERED.") LSP0243 ÷. 17 FORMAT(1H1,9X\*THE NUMBER OF MENORIES IN COLUMN \*12' = \*12/10X LSP0244 "TO RUN & PROBLEM OF THIS SIZE, THE ARRAY SIZES MUST BE . LSP0245 "ALTERED."} L SP0246 READ(5,1) IDEN LSP0247 READ(5,2) HI, MD, NH LSP0248 LSP0249 ERROR = 0 IFINI .GT. 4) ERROR = 1 LSP0250 LSP0251 IFING .GT. 6) ERROR = 1 TE(NH \_61\_36) FRRDR = 7 LSP0252 IF(ERROR .EQ.I.0) WRITE(6,16) MI, ND, ME LSP0253 LSP0254 HC = 2\*\*NI READ(5,3)(Y(M), M=1, MM), (X(1),1=1,4) LSP0255

€

c

£

c

c

C

C

С

C

£ £ £ £ £ C C

ε

c

Ē

c

ε

| READ(5.4)({MC(JC.JM), JM=1.19), JC=1.NC}                                  | LSP0256      |
|---------------------------------------------------------------------------|--------------|
| 00 19 JC=1.NC                                                             | LSP0257      |
| 19 IF(MC(JC,1) .GT. 18) WRITE(6,17) JC, MC(JC,1)                          | LSP0258      |
| WRITE(6.5) NT. NO. NM. IDEN                                               | L SP0 259    |
| NIS = $2^{++NI}$                                                          | LSP0260      |
|                                                                           | L SP0 261    |
| CALL ASSIGN(NIS,1)                                                        | L\$P0262     |
| 00 11 J=1,NC                                                              | L\$P0263     |
| L = 3L                                                                    |              |
| DO 10 I=I+NI                                                              | LSP0264      |
| IF(X(1) .NE. IG(1,J)) GD TO 11                                            | LSP0 265     |
| 10 CONTINUE                                                               | LSP0266      |
| GO TO 12                                                                  | LSP0267      |
| 11 CONTINUE                                                               | LSP0268      |
| 12 IR = 1                                                                 | L SP0269     |
| CALL DIGEON                                                               | LSP0270      |
| NR = 1                                                                    | LSP0271      |
| NRS = 1                                                                   | LSP0272      |
| DG 13 H=1.NM                                                              | LSP0273      |
| 13 IY(M,NR) = Y(M)                                                        | LSP0274      |
| D0 14 J=1+N0                                                              | LSP0275      |
| 14 IZ(J,NR) = 2(J)                                                        | LSP0276      |
| DO 15 1=1,40                                                              | LSP0277      |
| DO 15 J=1,NC                                                              | LSP0278      |
| KS(1,J) = 0                                                               | LSP0279      |
| 15 S(1,J) = 0                                                             | L SP0280     |
| S(NR,JC) = 1001                                                           | LSP0281      |
|                                                                           | LSP0282      |
| 20 DO 21 I=1,NI                                                           | LSP0283      |
| IX(I,JC) = IG(1,JC)                                                       | LSP0284      |
| $21 X(I) = IX(I_{\bullet}JC)$                                             | LSP0285      |
| DO 50 I=1.NI                                                              | LSP0286      |
| $\mathbf{X}(\mathbf{I}) = \mathbf{NOT}(\mathbf{X}(\mathbf{I})\mathbf{I})$ | LSP0288      |
| CALL DIGEON                                                               |              |
| NR = NR+1                                                                 | LSP0288      |
| NRS = NRS+1                                                               | LSP0 289     |
| 00 23 <sup>7</sup> J=1,NC                                                 | LSP0290      |
| DO 22 II=1+NI                                                             | LSP0291      |
| IF(X(II) .NE. IG(II,J)) GO TO 23                                          | LSP0292      |
| 22 CONTINUE                                                               | LSP0293      |
| JC = J                                                                    | LSP0294      |
| GO TO 24                                                                  | LSP0295      |
| 23 CONTINUE                                                               | L\$P0296     |
| 24 IF(NR .LT. 40) GD TO 25                                                | L\$P0297     |
| WRITE(6,6)                                                                | LSP0298      |
| CALL PRINT(NM)                                                            | LSP0299      |
| RETURN                                                                    | LSP0 300     |
| 25 S(NR+JC) = NRS+1000                                                    | LSP0301      |
| S(IR+JC) = NRS                                                            | L S P 0 302  |
| DO 26 M=1,NM                                                              | L SP0303     |
| 26 IY(M,NR) * Y(MI                                                        | LSP0304      |
| DD 30 J=1.NO                                                              | L SP0 30 5   |
| 30 12(J+NR) = Z(J)                                                        | LSP0306      |
| KS(NR, JC) = 1                                                            | L \$ PO 30 7 |
| 50 X(1) = NDT(X(1))                                                       | LSP0308      |
| CALL EQUIVINM                                                             | LSP0309      |
| DO 60 JR=2, NR                                                            | L\$P0310     |
| DD 60 IC=1.NC                                                             | LSP0311      |
|                                                                           | LSP0312      |
| 1F(K\$(JR, IC) . EQ. 0) GO TO 60                                          | LSP0313      |
| $KS(JR,IC) \neq 0$                                                        | LSP0314      |
| IR = JR<br>17 = 17                                                        | LSP0315      |
|                                                                           |              |

S Ś

|     |                                    | and the second |
|-----|------------------------------------|------------------------------------------------------------------------------------------------------------------|
|     | END                                | L SP0 336                                                                                                        |
|     | RETURN                             | LSP0335                                                                                                          |
|     | WR1TE(6,9)                         | LSP0334                                                                                                          |
|     | CALL PRINT(NM)                     | LSP0333                                                                                                          |
| 110 | $S[I_*J] = -S[I_*J]$               | LSP0332                                                                                                          |
|     | DO 110 J=1,NC                      | LSP0331                                                                                                          |
|     | DO 110 I=1,NR                      | LSP0330                                                                                                          |
| 100 | CONTINUE                           | LSP0329                                                                                                          |
| 90  | CONTINUE                           | L SP0328                                                                                                         |
|     | GG TO 100                          | LSP0327                                                                                                          |
|     | S(I,J) = -(I+1000)                 | LSP0326                                                                                                          |
| 80  | IF(S(I1+J) - EQ - IS) S(I1+J) = -I | LSP0325                                                                                                          |
|     | DC 80 11=1.NR                      | LSP0324                                                                                                          |
|     | 1F(IS .LT. 0) GO TO 90             | LSP0323                                                                                                          |
|     | 15 = S(1, J) - 1000                | LSP0322                                                                                                          |
|     | DD 90 J=1-NC                       | LSP0321                                                                                                          |
|     | DO 100 I=1,NR                      | LSP0320                                                                                                          |
| 60  | CONTINUE                           | L SP0319                                                                                                         |
|     | GO TO 20                           | LSP0318                                                                                                          |
| 55  | Y(M) = 1Y(M, IR)                   | LSP0317                                                                                                          |
|     | DO 55 M=1,NM                       | LSP0 316                                                                                                         |

÷.,-

|   | •       | -                                                                                                             |                       |     |                                 |
|---|---------|---------------------------------------------------------------------------------------------------------------|-----------------------|-----|---------------------------------|
|   |         | SUBROUTINE DIGEON                                                                                             | DIGEQN01              | c   |                                 |
|   | C       | *****                                                                                                         | **DIGEQNO2            |     | DD 15 M=1.NM                    |
|   | C       | *                                                                                                             | *DIGEQN03             |     | NCH = Y{N}                      |
|   | C       | SUBROUTINE DIGEQN CONTAINS THE OUTPUT AND SWITCHING                                                           | *DIGEQNO4             |     | Y(H) = MEMORY(Y(H))             |
|   | с       | * EQUATIONS NECESSARY TO PERFORM SYSTEM SIMULATION. THE USER                                                  | *DIGEQN05             |     | IF(MS(N)*MR(M) .E               |
|   | C       | * MAY FIND IT ADVANTAGEOUS TO USE THE TOTAL INPUT STATE ARRAY                                                 | *DIGEONO6             |     | IF(Y(M) .NE. MCH)               |
|   | C       | ITS(JC), INSTEAD OF FORMING THESE STATES IN HIS EQUATIONS. THE                                                | ≠DIGEQN07             |     | 15 CONTINUE                     |
|   | С       | * SWITCHING EQUATIONS ARE REPEATED TO ALLOW FOR ANY INTERNAL                                                  | *D1GEQN08             |     | IF(ICH .EQ. I) GC               |
|   | с       | * STATE SWITCHING OR CYCLING.                                                                                 | ≠DIGEQN09             | c   |                                 |
|   | с       | THE USER SHOULD ONLY SUPPLY THE SWITCHING EQUATIONS AND                                                       | <pre>#DIGEQN10</pre>  | с   |                                 |
|   | Ċ       | * THE OUTPUT EQUATIONS IN THIS SUBROUTINE.                                                                    | ≠DIGEQN11             | c   |                                 |
|   | C       | FUNCTION NOT MAY BE USED TO PERFORM THE LOGICAL                                                               | *DIGEON12             |     | $Z\{1\} \neq ITS\{2\} \neq NOT$ |
|   | C       | * COMPLEMENT                                                                                                  | *DIGE ON13            | · c |                                 |
|   | С       | *                                                                                                             | *DIGEON14             | c   |                                 |
|   | C       | *                                                                                                             | <pre># DIGEON15</pre> |     | DO 20 J=1,NO                    |
|   | С       | * X(I) = THE CURRENT STATE OF THE I-TH INPUT                                                                  | *DIGEQN16             |     | IF(Z(J) _GT_ I) Z               |
|   | c       | ★ Y{M} = THE CURRENT STATE OF THE M-TH MEMORY                                                                 | *DIGEON17             |     | 20 CONTINUE                     |
|   | С       | ★ Z(J) = THE CURRENT STATE OF THE J-TH OUTPUT                                                                 | ≠DIGEQNIS             |     | RETURN                          |
|   | с       | <pre># ITS(JC)= THE TOTAL INPUT STATE FOR THE JC-TH COLUMN</pre>                                              | *DIGEON19             |     | END                             |
|   | 3       | * MS{M} = THE "SET" SIGNAL FOR THE M-TH MEMORY                                                                | *DIGEON20             |     |                                 |
|   | с       | * MR(M) = THE "RESET" SIGNAL FOR THE M-TH MEMORY                                                              | <pre>#DIGEQN21</pre>  |     |                                 |
|   | С       | *                                                                                                             | *DIGEON22             |     |                                 |
|   | ċ       | **************************************                                                                        | ≠DTGE QN23            |     |                                 |
|   |         | COMMON /ALL/ NI,ND, NR, NM, NC, IX(4,16), IY(36,40), IZ(6,40), S(40,16)                                       | DIGE QN24             |     |                                 |
|   |         | COMMON /EQN/ X(4), Y(36), Z(6), KS(40,16), MC(16,19)                                                          | DIGEQN25              |     |                                 |
|   |         | DIMENSION ITS(16), MS(36), MR(36)                                                                             | DIGE ON26             |     |                                 |
|   |         | INTEGER X, Y, Z, S                                                                                            | DIGE QN27             |     |                                 |
|   | 1       | FORMAT(10X,*SET AND RESET SIGNALS APPEARED SIMULTANEOUSLY*/                                                   | DIGE QN28             |     |                                 |
|   | · · · , | $10X_1 X = *411 Y = *1811$                                                                                    | DIGEON29              |     |                                 |
|   |         | ITS( 1) = NOT(X(1))*NOT(X(2))*NOT(X(3))*NOT(X(4))                                                             | DIGE QN30             |     |                                 |
|   |         | ITS( 2) = X(1) *NOT(X(2))*NOT(X(3))*NOT(X(4))                                                                 | DIGEON31              |     |                                 |
|   |         | ITS(3) = $X{1} \neq X{2} * NOT{X{3}} * NOT{X{4}}$                                                             | DIGE QN32             |     |                                 |
|   |         | ITS(4) = NOT(X(1))* X(2) *NOT(X(3))*NOT(X(4))                                                                 | DIGEON33              |     |                                 |
|   |         | ITS: 5) = NDT(X(1))* $X(2) * X(3) * NDT(X(4))$                                                                | DIGEON34              |     |                                 |
|   |         | ITS( 6) = $X(1) + X(2) + X(3) + NOT(X(4))$                                                                    | DIGE 0N35             |     |                                 |
|   |         | ITS(7) = X(1) *NOT(X(2)) * X(3) *NOT(X(4))                                                                    | DI GE QN36            | -   |                                 |
|   |         | 1TS(8) = NOT(X(1))*NOT(X(2))* X(3) *NOT(X(4))                                                                 | DIGEQN37              |     |                                 |
|   |         | ITS[9] = NOT(X(1))*NOT(X(2))* X(3) * X(4)                                                                     | DI GE QN38            |     |                                 |
|   |         | $ITS(10) = X(1) \neq NOT(X(2)) \neq X(3) \neq X(4)$                                                           | DIGEON39              |     |                                 |
|   |         | ITS(11) = X(1) + X(2) + X(3) + X(4)                                                                           | DIGE 9N40             |     |                                 |
|   |         | ITS(12) = NOT(X(1)) * X(2) * X(3) * X(4)                                                                      | DIGEQN41              |     |                                 |
|   |         | ITS(13) = NOT(X(1)) * X(2) * NOT(X(3)) * X(4)                                                                 | DIGEON42              |     |                                 |
|   |         | ITS(14) = X(1) * X(2) *NOT(X(3))* X(4)                                                                        | DIGEON43              |     |                                 |
|   |         | ITS(15) = X(1) *NOT(X(2))*NOT(X(3))* X(4)                                                                     | DIGEON44              |     |                                 |
|   |         | 115(16) = NOT(X(1)) * NOT(X(2)) * NOT(X(3)) * X(4)                                                            | DIGE QN45             |     |                                 |
| • | . 10    | 1CH = 0                                                                                                       | DIGEON46              |     |                                 |
|   | c 10    |                                                                                                               | DIGE 0N47             |     |                                 |
|   | č       | ENTER SWITCHING EQUATIONS                                                                                     |                       |     |                                 |
|   | ε.      |                                                                                                               | DIGEQN49              |     |                                 |
|   | L       | MS(1) = 1TS(2) * Y(2) * Y(3) + ITS(4)                                                                         | DICLENTS              |     |                                 |
|   |         | $MR{1} = ITS{2} + Y{2} + NOT{Y{3}}$                                                                           |                       |     |                                 |
|   |         | MS(2) = ITS(1) + ITS(3) + Y(4)                                                                                |                       |     |                                 |
|   |         | MR(2) = [TS(3)*NOT(Y(4))]                                                                                     |                       |     |                                 |
|   |         | MS(3) = 1TS(1)*Y(1)                                                                                           |                       |     | 2                               |
|   |         | MR(3) = ITS(1) + NOT(Y(1)) + ITS(3) + Y(4)                                                                    |                       |     |                                 |
|   |         | MS(4) = TS(2)*Y(2)*Y(3) + TS(4)*Y(5)                                                                          |                       |     |                                 |
|   |         | MS(4) = ITS(2)*Y(2)*Y(3) + ITS(4)*Y(3)<br>MR(4) = ITS(2)*Y(2)*NOT(Y(3)) + ITS(2)*NOT(Y(2)) + ITS(4)*NOT(Y(5)) |                       |     |                                 |
|   |         |                                                                                                               |                       |     |                                 |
|   |         | MS(5) = ITS(1) + ITS(3) + Y(4)                                                                                |                       |     |                                 |
|   | ~       | MR(5) = ITS(3) * NOT(Y(4))                                                                                    | DI GEQN50             |     |                                 |
|   | С       |                                                                                                               | DIGLERUU              |     |                                 |
|   |         |                                                                                                               |                       |     |                                 |
|   |         |                                                                                                               |                       |     |                                 |

.

| • · · · · · · · · · · · · · · · · · · ·     |           |   |                                                               |            |
|---------------------------------------------|-----------|---|---------------------------------------------------------------|------------|
|                                             |           |   |                                                               |            |
|                                             |           |   |                                                               |            |
| -                                           |           |   |                                                               | DICCONFI   |
|                                             | DIGEQN01  | c |                                                               | DIGEON51   |
| ** *** *** *** ** ** ** *** ***********     |           |   | DD 15 M=1,NM                                                  | DIGEON52   |
|                                             | *DIGEQN03 |   | NCH = Y(N)                                                    | DIGEQN55   |
| GEQN CONTAINS THE OUTPUT AND SWITCHING      | *DIGEQN04 |   | Y(M) = MEMORY(Y(M),MS(M),MR(M))                               | DIGEON55   |
| Y TO PERFORM SYSTEM SIMULATION. THE USER    | *DIGEQN05 |   | IF(MS(N)*MR(M) .EQ. 1) WRITE(6,1) (X(I),J=1,4),(Y(J),J=1,NM)  | DIGEON56   |
| AGEDUS TO USE THE TOTAL INPUT STATE ARRAY   | *DIGEQN06 |   | IF(Y(M) .NE. MCH) ICH = 1                                     | DIGEON50   |
| F FORMING THESE STATES IN HIS EQUATIONS. TH |           |   | 15 CONTINUE                                                   | DIGEQN57   |
| IS ARE REPEATED TO ALLOW FOR ANY INTERNAL   | ≠D1GEQN08 |   | IF(ICH .EQ. I) GO TO 10                                       |            |
| CYCLING.                                    | ≠DIGEQN09 | c |                                                               | DIGE QN 59 |
| LD ONLY SUPPLY THE SWITCHING EQUATIONS AND  | *DIGEQN10 | c | ENTER OUTPUT EQUATIONS                                        | DIGEQN60   |
| NS IN THIS SUBROUTINE.                      | ≠DIGEQN11 | С |                                                               | DIGEQN61   |
| MAY BE USED TO PERFORM THE LOGICAL          | *DIGEQN12 |   | Z{1} = ITS{2}*NOT(Y{2}} + ITS{3}*NOT(Y{4}) + ITS(4)*NOT(Y{5}) |            |
| •                                           | *DIGEON13 | Ċ |                                                               | OIGE QN62  |
|                                             | *DIGEON14 | C |                                                               | DIGEQN63   |
|                                             | *DIGEON15 |   | DD 20 J=1,ND                                                  | DIGEQN64   |
| NT STATE OF THE I-TH INPUT                  | *DIGEQN16 |   | $IF(Z{J} GT I) Z{J} = 1$                                      | DIGEQN65   |
| NT STATE OF THE M-TH MEMORY                 | *DIGEON17 |   | 20 CONTINUE                                                   | DIGE QN66  |
| ENT STATE OF THE J-TH BUTPU7                | *DIGEQNI8 |   | RETURN                                                        | DIGEON67   |
| L INPUT STATE FOR THE JC-TH COLUMN          | *DIGEQN19 |   | END                                                           | DIGE QN68  |
| TOTALL FOR THE N THE NEW ORK                | +0100000  |   |                                                               |            |

1500337 SUBROUTINE EQUIV(KNH) #LSP0339 SUBROUTINE EQUIV SENSES ANY REDUNDANT STATES IN THE #LSP0340 PRIMITIVE FLOW TABLE AND REPLACES THESE STATES WITH THEIR EQUIVALENT STATES. THIS ROUTINE IS USED WITH EITHER THE SYNTHESIS OR SIMULATION PROGRAMS. + #LSP0341 \*LSP0342 \*LSP0343 ٠ \*LSP0344 \*LSP0345 KNM = THE NUMBER OF MEMORY ELEMENTS TO BE CHECKED FOR \*LSP0346 \* EQUIVALENCE DURING SYSTEM SIMULATION. KNH = 0 FOR \*LSP0347 SYSTEM SYNTHESIS. \*LSP0348 MC(JC.1) = THE NUMBER OF MEMORY ELEMENTS ASSOCIATED WITH THE \*LSP0349 JC-TH COLUMN \*LSP0350 MC(JC, JM+1) = THE NUMBER DESIGNATION OF THE JM-TH MEMORY \*LSP0351 IN THE JC-TH COLUMN \*LSP0352 CDMMDN /ALL/ NI,NG,NR,NM,NC, IX(4,16), IY(36,40), IZ(6,40), S(40,16) LSP0354 COMMON /EQN/ X(4), Y(36), Z(6), KS(40,16), KC(16,19) LSP0355 DIMENSION IT(16) LSP0356 INTEGER S LSP0357 1 \$20358 FORMAT(//// 2 FORMAT (IOX, STATE 'I3' WAS EQUIVALENT TO STATE 'I3' AND HAS BEEN' LSP0359 RÉMOVED.\*1 1 SP0360 IFINR .LE. 21 RETURN 1 SP0361 1 SP0362 IFIKNH .EQ. OF WRITE(6+1) 7 1RC = 0 DO 70 JC=1,NC LSP0363 LSP0364 L SP0365 NR1 = NR-1DO 40 11=1,NR1 LSP0366 LSP0367  $111 \pm 11+1$ 1F(S(11,JC) .LE. 1000) GD TO 40 LSP0368 LSP0369 DO 30 12=111,NR IF(S(12, JC) .LE. 1000) GD TO 30 LSP0370 DO 10 J=1,NO LSP0371 IF(IZ(J+I1) .GT. 1) IZ(J+I1) = -1 LSP0372 IF(12(J,11).LT.0 .OR. 12(J,12).LT.0) GO TO 10 LSP0373 IF(12(J,11) .NE. 12(J,12)) GO TO 30 LSP0374 10 CONTINUE LSP0375 IF (KNM .EQ. 0) GO TO 12 LSP0376 NMC = MC(JC,1) L SP0377 IFINMC .EQ. 01 GD TD 12 1 SP0378 LSP0379 DG 11 JM=1,NMC L SP0 380 M1 = MC(JC,JM+1) If(IY(M1,I1) .NE. IY(M1,I2)) GO TO 30 LSP0381 LSP0382 11 CONTINUE LSP0383 12 D8 13 J=1.NC IF(J .EQ. JC) GD TO 13IT(J) = S(I1,J) + S(12,J)LSP0384 LSP0385 IF(S(11,J) .EQ. 0 .OR. S(12,J) .EQ. 0) GO TO 13 IF(S(11,J) .NE. S(12,J)) GO TO 30 LSP0386 LSP0387 IT(J) = S(I1,J)LSP0388 13 CONTINUE LSP0389 IRC = 1L SP0390 IR = S(12,JC) - 1000 LSP0391 IS = S(II.JC) - 1000 LSP0392 IF(KNH .EQ. D) WRITE(6,2) IR, IS 1 520393 L SP0394 IT(JC) = S(11, JC)LSP0395 DO 14 13=1.NR 14 IF(S(13,JC) .EQ. S(12,JC)-IOCD) S(13,JC) = S(11,JC) +1000 LSP0396

С

С

£

С

С

C

C.

С

r

C-

c

c

c

C.

C.

С

|     | NR = NR-I                           | LSP0397  |
|-----|-------------------------------------|----------|
|     | IF(12 .EQ. NR+1) GO TO 25           | LSP0 398 |
|     | 00 24 14=12.NR                      | LSP0399  |
|     | 00 20 J=1.NC                        | LSP0400  |
|     | $S(11_{*J}) = IT(J)$                | L SP0401 |
|     | S(14,J) = S(14+1,J)                 | LSP040   |
| 20  | D = KS(14+1+J)                      | L SP0 40 |
| 20  |                                     | LSP0404  |
|     | DO 21 $J=1$ ,ND                     | LSP040   |
| 23  | 1 12(J, J4) = IZ(J, J4+1)           | LSP040   |
|     | IF(KNM .EQ. 0) GD TD 23             | LSP040   |
|     | DD 22 M=1.KNM                       |          |
| 22  | $2 IY(M_*I4) = IY(M_*I4+1)$         | LSP0408  |
| 23  | 3 CONTINUE                          | LSP0409  |
| 24  | 4 CONTINUE                          | LSP0410  |
| 25  | 5 DD 26 J=1,NC                      | LSP041   |
|     | S(NR+1,J) = 0                       | L\$P0412 |
| 26  | 6  KS(NR+1,J) = 0                   | LSP0413  |
|     | D CONTINUE                          | LSP0414  |
|     | O CONTINUE                          | LSP041   |
|     | OCONTINUE                           | LSP041   |
| ••• | IF{IRC.NE.0 .AND. KNM.EQ.0) GO TO 7 | LSP041   |
|     | RETURN                              | LSP041   |
|     |                                     | LSP0419  |
|     |                                     |          |

|    | SUBROUTINE CANON                                                                                                                | LSP0420              |
|----|---------------------------------------------------------------------------------------------------------------------------------|----------------------|
|    | ***************************************                                                                                         |                      |
|    | *                                                                                                                               | *LSP0422             |
|    | SUBROUTINE CANON TAKES THE PRIMITIVE FLOW TABLE FROM                                                                            | *LSP0423             |
|    | * THE SYNTHESIS PROGRAM AND REORDERS THE ROWS ACCORDING TO                                                                      | *LSP0424             |
|    | * SYSTEMATIC INPUT CHANGES AS OUTLINED IN THE THESIS. THE STATE<br>* NUMBERS ARE THEN RESEQUENCED TO PRODUCE THE CANONICAL FLOW |                      |
|    |                                                                                                                                 | *LSP0426<br>*LSP0427 |
|    | * TABLE.                                                                                                                        | *LSP0428             |
|    | ***************************************                                                                                         |                      |
|    | COMMON /ALL/ NI,NO,NR,NM,NC, IX(4,16), IY(36,40), IZ(6,40), S(40,16)                                                            |                      |
|    | COMMON /EQN/ X(4), Y(36), Z(6), KS(40,16), MC(16,19)                                                                            | LSP0431              |
|    | INTEGER S. X                                                                                                                    | L SP0 432            |
| 1  | FORMAT(LOX'THERE IS NO STABLE STATE IN THE FIRST ROW.")                                                                         | LSP0433              |
|    | DO 10 I=1,NR                                                                                                                    | L SP0434             |
|    | DO 10 J=1.NC                                                                                                                    | LSP0435              |
| 10 | $KS(I_{FJ}) = 0$                                                                                                                | LSP0436              |
|    | DO 11 J=1+NC                                                                                                                    | LSP0437              |
|    | IF(S(1,J) .LT. 1000) GO TO 11                                                                                                   | LSP0438              |
|    | IR = 1                                                                                                                          | LSP0439              |
|    | IRR= 1                                                                                                                          | LSP0440              |
|    | JC = J                                                                                                                          | LSP0441              |
|    | GD TO 20                                                                                                                        | LSP0442              |
| 11 | CONTINUE<br>WRITE(6,1)                                                                                                          | LSP04493             |
| 20 | DO 22 I=1,NI                                                                                                                    | LSP0445              |
|    | $\mathbf{x}(\mathbf{I}) = \mathbf{I}\mathbf{x}(\mathbf{I},\mathbf{J}\mathbf{C})$                                                | LSP0446              |
|    | DO 50 I=1.N1                                                                                                                    | LSP0447              |
|    |                                                                                                                                 | L5P0448              |
|    | DD 30 J1=1,NC                                                                                                                   | LSP0449              |
|    | 00 23 11=L.NI                                                                                                                   | L\$P0450             |
|    | IF(X(11) .NE. IX(11,J1)) GD TO 30                                                                                               | L\$P0451             |
| 23 | CONTINUE                                                                                                                        | LSP0452              |
|    | IF(S(IRR,JL) .EQ. 0) GO TO 50                                                                                                   | LSP0453              |
|    | IRI = IR+1                                                                                                                      | LSP0454              |
|    | DO 26 IRI=IRI+NR<br>1F(S(IR1,JI)-1000 .NE+ S(IRR,J1)) GD TD 26                                                                  | LSP0455<br>LSP0456   |
|    | 1R = 1R+1                                                                                                                       | LSP0457              |
|    | KS(IR,JI) = 1                                                                                                                   | LSP0458              |
|    | DD 24 JC1=1+NC                                                                                                                  | LSP0459              |
|    | ST = S(IR, JCI)                                                                                                                 | LSP0460              |
|    | S(IR, JCI) = S(IRI, JCI)                                                                                                        | LSP0461              |
| 24 | S(IR1, JC1) = ST                                                                                                                | LSP0462              |
|    | 00 25 JZ=1+N0                                                                                                                   | LSP0463              |
|    | $ZT = IZ(JZ_*IR)$                                                                                                               | L SP0464             |
|    | IZ(JZ, IR) = IZ(JZ, IRI)                                                                                                        | LSP0465              |
| 25 | IZ(JZ, IR1) = ZT                                                                                                                | LSP0466              |
|    | GO TD 31                                                                                                                        | LSP0467<br>LSP0468   |
|    | CONTINUE                                                                                                                        | LSP0469              |
|    | IF(IR .GE. NR) GD TO 61                                                                                                         | LSP0489              |
|    | x(1) = NOT(x(1))                                                                                                                | LSP0471              |
| 20 | DO 60 I2=2+NR                                                                                                                   | LSP0472              |
|    | D0 60 J2=1,NC                                                                                                                   | LSP0473              |
|    | IF(KS(12, J2) .EQ. 0) GO TO 60                                                                                                  | LSP0474              |
|    | KS(12,J2) = 0                                                                                                                   | LSP0475              |
|    | IRR = I2                                                                                                                        | LSP0476              |
|    | JC = J2                                                                                                                         | LSP0477              |
|    | GO TO 20                                                                                                                        | LSP0478              |
| 60 | CONTINUE                                                                                                                        | LSP0479              |

۰.

| 61  | DO 100 I=1,NR                    |
|-----|----------------------------------|
|     | DO 90 J=1,NC                     |
|     | $IS = S(I_{+}J) - 1000$          |
|     | IF(IS .LT. 0) GD TD 90           |
|     | 00 80 11=1,NR                    |
| 80  | IF(S(11,J) .EQ. IS) S(11,J) = -1 |
|     | S(1,J) = -(1+1000)               |
|     | GO TO 100                        |
| -90 | CONTINUE                         |
| 100 | CONTINUE                         |
|     | DO 110 I=1.NR                    |
|     | 00 110 J=1,NC                    |
| 110 | $S(I_{+}J) = -S(I_{+}J)$         |
|     | RETURN                           |
|     | END                              |
|     |                                  |

LSP0480 LSP0481 LSP0482 LSP0483 LSP0484 LSP0485 LSP0487 LSP0488 LSP0489 LSP0490 LSP0490 LSP0493 LSP0493 LSP0493

SUBROUTINE OUTPUT LSP0495 \*\*\*\*\*\*\* \*\*LSP0496 #1 520497 SUBROUTINE OUTPUT DETERMINES THE MEMORY REQUIREMENTS. \*LSP0498 PRINTS THE STATE SIGNALS, THE SWITCHING CONDITIONS, AND THE \*LSP0499 \*L SP0500 DUTPUT SIGNALS. \*L SP0 501 \*LSP0502 = THE M-TH STATE SIGNAL USED TO SET THE K-TH \*LSP0503 SET (K,M) MENDRY ELEMENT \*LSP0504 RESET(K,N) = THE M-TH STATE SIGNAL USED TO RESET THE K-TH \*LSP0505 MEMORY ELEMENT \*LSP0506 = THE M-TH PREVIOUS STATE TO A STABLE STATE PS(M) \*LSP0507 SET(K,1) = THE NUMBER OF "SET" SIGNALS FOR THE K-TH MEMORY \*LSP0508 RESET(K,1) = THE NUMBER OF "RESET" SIGNALS FOR THE K-TH MEMORY\*LSP0509 . MC(JC,1) = THE NUMBER OF MEMORY ELEMENTS IN THE JC-TH COLUMN\*LSP0510 -#i SP0511 IN THE RESULTING PRINT-OUT: #1 SP0512 ź - THE STATE SIGNALS ARE TO BE SUBSTITUTED FOR THE STATE #I \$P0513 NUMBERS IN THE SWITCHING AND OUTPUT EQUATIONS \*LSP0514 - "+" IMPLIES THE LOGICAL "AND" \*L SP0515 - "+" IMPLIES THE LOGICAL "OR" \*LSP0516 \*LSP0517 COMMON /ALL/ NI.ND.NR.NM.NC.IX(4,16).IY(36,40).IZ(6,40).S(40,16) LSP0519 COMMON /OUT/ SSC(16,21), SSR(40) L SP0 520 COMMON /EQN/ X(4), Y(36), Z(6), KS(40,16), MC(16,19) L SP0521 COMMON /ASN/ IG(19,20) L SP0522 DIMENSION SET(36,20), RESET(36,20), PS(20), IZS(6,40), JL(19), LSP0523 IYP(5,20), INOT(5,20), NY(5), IO(40) 1 SP0524 TYP(5,20), INUT(5,201, NT(5), 10(40) INTEGER S, SSC, SSR, SET, RESET, PS DATA IAB,IAV/1H, 1H\_', NY/5\*4H \* Y/, ID/1H, 39\*1H+/
 FORMAT(1/10X\*(FASSIVE MEMORY ASSIGNMENT)\*/)
 FORMAT(1/X\*STATE SIGNALS:\*/)
 FORMAT(15X,1H(+12+4H) =+4X; I1+12(A4+12))
 FORMAT(15X,1H(+12+4H) =+3X,211+12(A4+12))
 FORMAT(15X,1H(+12+4H) =+3X,211+12(A4+12)) 1 520525 LSP0526 L SP0527 LSP0528 1 SP0 529 LSPD530 7 FORMAT(15X,1H(,12,4H) =+2X+311+12(A4+12)) LSP0531 8 FORMAT(15X+1H(,12+4H) =+1X+411+12(44+12)) L SP0532 9 FORMAT(1H+,26X,(16(3X,A1,2X)/)) LSP0533 10 FORMAT(IOX\*OUTPUT SIGNALS:\*/) LSP0534 11 FORMAT(15x,\*Z\*,11.\* =\* 13(13,1X,A1),/(19X,13(13,1X,A1))) LSP0535 12 FORMAT(10X\*SWITCHING CONDIT(ONS:'/) L SP0 536 13 FORMAT(15X'Y',12,6X'SET =',10(13,1X,A1),/(2IX,10(13,1X,A1))) 14 FORMAT(24X,\*RESET =',10(13,1X,A1),/(2IX,10(13,1X,A1))) LSP0537 L SP0 538 LSP0539 15 FORMAT(IOX\*THERE ARE NO TRANSITION PATHS TO STATE\*, 14) I SP0540 16 FORMAT(IX) 1520541 .NM = 0 DO 20 J=1+NC LSP0542 MC(J,1) = LOG(SSC(J,1),2) 20 NM = NM + MC(J,1) IF(NM .EQ. 0) GO TO 26 LSP0543 LSP0544 L SP0545 LSP0546 WRITE(6,3) LSP0547 DO 25 K=1.NM  $SET{K,1} = 0$ LSP0548 25 RESET(K+1) = 0 LSP0549 26 LM = 0 LSP0550 MCL = 1 L\$P0551 MC1 = 0LSP0552 WRITE(6+4) LSP0553 DO 170 JC=1.NC L\$P0554

6

£

C

r.

Ċ

c

Ċ

c

ĉ

č

C

С

E.

C

Ċ

Ċ.

£

c

С

С

C C

.....

|   |     | HC1 = HC1 + HC(JC+1)                                                | LSP0555    |
|---|-----|---------------------------------------------------------------------|------------|
|   |     | L = SSC(JC,1)                                                       | LSP0556    |
|   |     | if(L-1)170,160,30                                                   | L SP0557   |
|   | 30  | CALL ASSIGN(L.2)                                                    | LSP0558    |
|   |     | DG 100 1≈1,L                                                        | LSP0559    |
|   |     | M1 = 0                                                              | LSP0560    |
|   |     | DO 35 IR=1.NR                                                       | LSP0561    |
|   |     | IF(S(IR, JC) .NE. SSC(JC, 1+1)) GO TO 35                            |            |
|   |     | M1 = H1 + 1                                                         | LSP0562    |
|   |     | PS(M1) = SSR(IR)                                                    | L SP0 56 3 |
|   | 25  | CONTINUE                                                            | LSP0564    |
|   |     | IF(M1 .EQ. 0) WRITE(6,15) SSC(JC,1+1)                               | LSP0565    |
|   |     | $J1 \simeq 0$                                                       | LSP0566    |
|   |     | DD 90 K=HCL . MC1                                                   | LSP0567    |
|   |     | JK = K-HCL+1                                                        | LSP0568    |
|   |     |                                                                     | LSP0569    |
|   |     | IF(IG(JK.1) .LT. 0) GO TO 90                                        | LSP0570    |
|   |     | J1 = J1+1                                                           | LSP0571    |
|   |     | INOT(J1,I) = IAB                                                    | LSP0572    |
|   |     | $[YP(J1_91) = K]$                                                   | LSP0573    |
|   |     | IF(IG(JK, 1) = 0) IND $T(J1, 1) = IAN$                              | LSP0574    |
|   |     | NS1 = SET(K,1)                                                      | LSP0575    |
|   |     | NR1 = RESET(K,1)                                                    | LSP0576    |
|   |     | IF(IG(JK,I) .EQ. 0) GO TO 83                                        | LSP0577    |
|   |     | $SET(K_{0}1) = NS1 + M1$                                            | LSP0578    |
|   |     | DO 82 M=1,M1                                                        | LSP0579    |
|   | 82  | $SET(X_{2}) + M + NS(1) = PS(M)$                                    | LSP0580    |
|   |     | GO TO 85                                                            | LSP0581    |
|   | 83  | RESET(X+1) = NR1 + H1                                               | LSP0582    |
|   |     | DD 84 M≖1.M1                                                        |            |
|   | 84  | RESET(K,1+M+NR1) = PS(N)                                            | L SP0583   |
|   |     | CONTINUE                                                            | LSP0584    |
|   |     | CONTINUE                                                            | LSP0585    |
|   | - • | JL(I) = JI                                                          | L SP0586   |
|   | 100 | CONTINUE                                                            | LSP0587    |
|   | 100 | .00 155- KK≈1,1                                                     | L SP0588   |
|   |     | $J1 = JL\{KK\}$                                                     | L\$P0589   |
|   |     |                                                                     | L SP0590   |
|   | 160 | GO TO (150,151,152,153),NI                                          | LSP0591.   |
|   | 190 | WRITE (6,5) SSC(JC,KK+1),(IX(I,JC),I=1,NI),(NY(K),IYP(K,KK),K=1,J1) | LSP0592    |
|   |     | WRITE(6,9)(INOT(M,KK),M=1,JI)                                       | LSP0593    |
|   |     | GO TO 155                                                           | LSP0594    |
|   | təf | WRITE(6,6) SSC(JC,KK+1),(IX(I,JC),I=1+NI)+(NY(K),IAP(K,KK),K=1,JI)  | LSP0595    |
|   |     | wKIIE(0+4)(INUI(M+KK)+M=I+JI)                                       | LSP0596    |
|   |     | GO TO 155                                                           | L SP0597   |
|   | 152 | WRITE(6,7) SSC(JC,KK+1),(IX(I,JC),I=1,NI),(NY(K),IYP(K,KK),K=1,J1)  | LSP0598    |
|   |     | mktic(0*Attion({W*KK}*W=T*]]}                                       | L\$P0599   |
|   |     | GO TO 155                                                           | 1 600 600  |
|   | 153 | WRITE(6,8) SSC(JC,KK+1),(IX(I,JC),I=1,NI),(NY(K),IYP(K,KK),K=1,J1)  | L SP0601   |
|   |     | WRITE(6,9)(INOT(M,KK),M=1,J1)                                       | L SP0602   |
|   | 155 | CONTINUE                                                            | LSP0603    |
|   |     |                                                                     | LSP0604    |
| • |     | CO TO 170                                                           |            |
|   | 160 | TEINT IE 21 HOTTEIL IN GERLIG AN INNIA NAME AND AND                 | LSP0605    |
|   |     | TEINI EO 31 URITEIL 71 COCLUC DI LEVIL VAL A VAL                    | LSP0606    |
|   |     | IF(NI .EQ. 4) WRITE(6.8) SSC(JC.2).(IX(I.JC).I=LONI)                | LSP0607    |
|   |     |                                                                     | L SP0608   |
|   | 170 | HCL + HCL + HCL (C 1)                                               | LSP0609    |
|   |     | 15(NH 50 0) CO TO 17/                                               | L SP0610   |
|   |     | UDITE/6 131                                                         | LSP0611    |
|   |     | DO 175 V-1 NM                                                       | LSP0612    |
|   |     | N1 - CET (4 1)                                                      | LSP0613    |
|   |     | TL - JEIINALI                                                       | L SP0614   |



|    | SUBROUTINE PRINT(KNM)                                                                                                      | L SP0 631              |
|----|----------------------------------------------------------------------------------------------------------------------------|------------------------|
|    | ***************************************                                                                                    |                        |
|    |                                                                                                                            | *L SP0633<br>*L SP0634 |
|    | <ul> <li>SUBROUTINE PRINT IS USED TO PRINT THE FLOW TABLES</li> <li>INVOLVED IN EITHER SYNTHESIS OR SIMULATION.</li> </ul> | *L SP0635              |
|    | * INVOLVED IN EITHER STNIRESIS DR SINGLATION.                                                                              | *LSP0636               |
|    | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~                                                                                     |                        |
|    | COMMON /ALL/ NI, NO, NR, NM, NC, IX(4, 16), IY(36, 40), IZ(6, 40), S(40, 16)                                               |                        |
|    | DIMENSION MS(16), MSS(16), IN3(41), IXP(4), IZP(6)                                                                         | L SP0639               |
|    | INTEGER S                                                                                                                  | LSP0640                |
|    | DATA JAB, JAP, IN3, JXP, JZP/4H ,4H( ),41+3H,4+1HX,6+1HZ/                                                                  |                        |
| 1. | FORMAT(11X,4(1X,A1,11)/)                                                                                                   | L \$P0642              |
|    | FORMAT(10X,2(5X, I1),3X,6(1X,A1,I1))                                                                                       | L\$P0643               |
| 3  | FORMAT(10X,4(4X,211),3X,6(1X,A1,11))                                                                                       | LSP0644                |
| 4  | FORMAT(10X+8(3X,311),3X,6(1X,A1,11))                                                                                       | LSP0645                |
| 5  | FORMAT( 16(2X+411)+3X+6(1X+A1+11))                                                                                         | L SP0646               |
| 6  | FORMAT(12X,41A3)                                                                                                           | L SP0 647              |
| 7  | FORMAT(2X,41A3)                                                                                                            | LSP0648                |
| 8  | FORMAT(10X+216+3X+6(2X+11))                                                                                                | LSP0649                |
|    | FORMAT(10X,416,3X,6(2X,11))                                                                                                | L'SP0650               |
|    | FORMAT(10X,816,3X,6(2X,11))                                                                                                | LSP0651                |
|    | FORMAT( 1616,3X,6(2X,11))                                                                                                  | L SP0652               |
|    | FORHAT(1H+, 50X,1612)                                                                                                      | LSP0653                |
|    | FORMAT(1H+, 62X,1612)                                                                                                      | LSP0654                |
|    | FORMAT(1H+, 86X,1612)                                                                                                      | L SP0 655              |
|    | FORMAT(1H+,115X,1611)                                                                                                      | LSP0656                |
|    | FORMAT(1H+,10X,1H),1X,A4,3(2X,A4),2H )                                                                                     | LSP0657                |
|    | FORMAT(1H+,10X,1H),1X,A4,7(2X,A4),2H )                                                                                     | LSP0658                |
| 10 | FORMAT(3H+1, $A4, 15(2X, A4), 2H$ 1)<br>INC = 1+NC $\neq$ 2+NO                                                             | L SP0659<br>L SP0660   |
|    | WRITE(6,1)(IXP(I),I,I=1,NI)                                                                                                | LSP0661                |
|    | GO TO (20,25,30,35), NI                                                                                                    | LSP0662                |
| 20 | WRITE{6,2){(IX(I,JC),I=1,NI),JC=1,NC},(IZP(J),J,J=1,NO)                                                                    | LSP0663                |
| 20 | wRITE(6,6)(IN3(I),I=1,INC)                                                                                                 | LSP0664                |
|    | DO 22 IR=1-NR                                                                                                              | L SP0665               |
|    | DO 21 JC=1,NC                                                                                                              | LSP0666                |
|    | MS(JC) = S(IR, JC)                                                                                                         | LSP0667                |
|    | MSS(JC)= IAB                                                                                                               | LSP0668                |
|    | IF(S(IR, JC) .LE. 1000) GO TO 21                                                                                           | LSP0669                |
|    | MS(JC) = S(IR, JC) - 1000                                                                                                  | LSP0670                |
|    | MSS(JC)= 1AP                                                                                                               | LSP0671                |
| 21 | CONTINUE                                                                                                                   | LSP0672                |
|    | WRITE(6, 8)(MS(JC),JC=1,NC),(IZ(J,IR),J=1,NB)                                                                              | LSP0673                |
|    | IF(KNM .NE. 0) WRITE(6,12)(IY(M,IR),M=1,KNM)                                                                               | LSP0674                |
| 22 | WRITE(6,16)(MSS(JC)+JC=1,NC)                                                                                               | LSP0675                |
|    | GO TO 40                                                                                                                   | L SP0676               |
| 25 | WRITE(6,3)((IX(I,JC),I=1,NI),JC=1,NC),(IZP(J),J,J=1,NC)                                                                    | L SP0677               |
|    | WRITE(6,6)(IN3(1), I=1, INC)                                                                                               | LSP0678                |
|    | DO 27 1R=1,NR                                                                                                              | LSP0679                |
|    | DO 26 JC=1, NC                                                                                                             | 1 SP0680               |
|    | MS{JC} = S(IR,JC}<br>MSS(JC}= IAB                                                                                          | LSP0681<br>LSP0682     |
|    | MSS(JC)= TAB<br>IF(S(TR,JC) .LE. 1000) GD TO 26                                                                            | LSP0683                |
|    | MS(JC) = S(1R, JC) - 1000                                                                                                  | LSP0684                |
|    | MS(JC) = IAP                                                                                                               | LSP0685                |
| 26 | CONTINUE                                                                                                                   | LSPD686                |
|    | WRITE(6, 9)(MS(JC), JC=1, NC), (IZ(J, IR), J=1, NO)                                                                        | L SP0687               |
|    | IF(KNM .NE. 0) WRITE(6,13)(1Y(M,1R),M=1,KNM)                                                                               | L SP0 688              |
| 27 | WRITE(6,16)(MSS(JC),JC=1,NC)                                                                                               | LSP0689                |
|    | GO TO 40                                                                                                                   | LSP0690                |

| 30 | WRITE(6,4)((IX(I,JC),I=1,NI),JC=1,NC),(IZP(J),J,J=1,NC)  | L SP0693 |
|----|----------------------------------------------------------|----------|
|    | WRITE(6,6)(IN3(I),I=1,INC)                               | LSP0692  |
|    | DO 32 IR=I+NR                                            | LSP0693  |
|    | DO 31 JC=1.NC                                            | LSP0694  |
|    | MS(JC) = S(IR, JC)                                       | LSP0695  |
|    | MSS(JC)= IAB                                             | L SP0696 |
|    | IF(S(IR,JC) +LE, 1000) 60 TO 31                          | L SP0697 |
|    | $HS(JC) = S(IR_{y}JC) - 1000$                            | L SP0698 |
|    | MSS(JC)= IAP                                             | LSP0699  |
| 31 | CONTINUE                                                 | LSP0700  |
|    | WRITE(6,10)(MS(JC),JC=1,NC),(IZ(J,IR),J=1,NO)            | LSP0701  |
|    | IF(KNH .NE. 0) WRITE(6,14)(IY(H,IR), M=1.KNM)            | L SP0702 |
| 32 | WRITE(6,17)(MSS(JC),JC=1.NC)                             | LSP0702  |
|    | GO TO 40                                                 | LSP0704  |
| 35 | WRITE(6,5)((1X(I,JC),I=1,NI),JC=1,NC),(IZP(J),J,J=1,NO)  | LSP0705  |
|    | WRITE(6,7)(IN3(1), I=1, INC)                             | LSP0705  |
|    | DO 37 IR=1.NR                                            | LSP0708  |
|    | DO 36 JC=1, NC                                           | LSP0707  |
|    | MS(JC) = S(IR, JC)                                       | LSP0708  |
|    | NSS(JC) = TAB                                            |          |
|    | IF(S(IR, JC) .LE. 1000) GD TD 36                         | LSP0710  |
|    | $MS(JC) = S(IR_{y}JC) - 1000$                            | LSP0711  |
|    | MSS(JC) = IAP                                            | LSP0712  |
| 34 | CONTINUE                                                 | LSP0713  |
| 50 |                                                          | LSP0714  |
|    | <pre>WRITE(6,11)(MS(JC),JC≠1,NC),(IZ(J,IR),J=1,NO)</pre> | LSP0715  |
|    | IF(KNM .NE. 0) WRITE(6,15)(IY(M,IR), M=1,KNM)            | LSP0716  |
| 51 | WRITE(6,18)(MSS(JC),JC=I,NC)                             | LSP0717  |
|    | WRITE(6,7)(IN3(I),I=1,INC)                               | LSP0718  |
|    | RETURN                                                   | LSP0719  |
| 40 | WRITE(6,6)(IN3(I),I=1,INC)                               | LSP0720  |
|    | RETURN                                                   | LSP0721  |
|    | END                                                      | LSP0722  |
|    |                                                          |          |

SUBROUTINE ASSIGN(K, NA) LSP0723 \*LSP0725 SUBROUTINE ASSIGN PRODUCES EITHER THE PASSIVE MEMORY OR #LSP0726 ċ GRAY ASSIGNMENT CODE. THE PASSIVE MEMORY ASSIGNMENT CODE IS \*L SP0727 \* С USED FOR MEMORY ASSIGNMENT IN THE SYNTHESIS PROGRAM AND THE \*LSP0728 \* С \$ GRAY CODE IS USED FOR INPUT STATES IN THE SIMULATION PROGRAM. #LSP0729 С \* THE GRAY CODE PRODUCED BY THIS SUBROUTINE HAS THE ELEMENT ON \*LSP0730 \* THE LEFT MOST FREQUENTLY CHANGING. \*LSP0731 \*LSP0732 \*LSP0733 NA = OPTION SPECIFYING CODE C. \* \*LSP0734 1 = GRAY CODE (INPUT STATES) 2 = PASSIVE CODE (MEMDRY ASSIGNMENT) K = THE NUMBER OF STATES(OR COLUMNS) REQUIRED С \* \*LSP0735 #I SP0736 # \*LSP0737 С \* IG(1,J) = THE VALUE OF THE I-TH MEMORY (OR INPUT) IN THE \*LSP0738 С ÷ J-TH STATE (OR COLUMN). \*LSP0739 С  $\sim$ \*LSP0740 COMMON /ASN/ IG(19,20) LSP0742 DIMENSION IA(16), RA(16) LSP0743 INTEGER RA LSP0744 IFIK .LE. 1) RETURN LSP0745 NM1 = LOG{K,NA} LSP0746 IF(NA .EQ. 2) GO TO 30 LSP0747 10 DO 11 I=1.K LSP0748 DO 11 J=1,NM1 1 520749 IG(J,I) = 0LSP0750  $JM = 2 \neq \neq \{NM1 - J\}$ LSP0751 00 11 M=1,JN,2 L SP0752 LSP0753  $\Delta M = M$ A1 = 2\*\*J\*(AM+0.5) LSP0754 A2 = 2\*\*J\*(AM-0.5)LSP0755 IF(I.GT.A1 .OR. I.LE.A2) GO TO 11 LSP0756 LSP0757  $IG\{J,I\} = 1$ 11 CONTINUE LSP0758 LSP0759 RETURN 30 DO 31 1=1,19 LSP0760 DB 31 J=1,20 LSP0761  $31 IG(I_{+}J) = -1$ LSP0762 NRA = 1LSP0763 NR = 1LSP0764 32 M = 1 LSP0765 DO 33 I=1,NRA LSP0766 33 IA(I) = 0 LSP0767 L SP0 768 IF(NRA .GT. 1) IA(1) = 1 L SP0769 34 M = M\*2 LSP0770 DO 35 J=1.M.2 35 IA(1+J\*NRA/M) = IA(1+(J-1)\*NRA/M) + M/2IF(M .LT. NRA) GO TO 34 LSP0771 L SP0772 DG 37 I=I.NRA LSP0773 IK = 0LSP0774 IR1 = 1LSP0775 DO 36 14=1,IR1 LSP0776 36 IF(IA(14) .LT. IA(1)) IK = IK+1 LS P0 777 37 RA(1) = IA(1) + IK 1.5P0778 NRR = NR+NRA LSP0779 LSP0780 DO 39 J=1.NRA IM = NR-1+IL SP 0781 1590782 IR = RA(I)

С

С

С

С

С

c

с

С

с

DO 38 I1=IR, NRR I2 = NRR + IR - I1DO 38 M1=1, IM 38 IG(M1, 12+1) = IG(M1, 12)IG(IN, IR) = 1IG(IM, IR+1) = 0IF (NR+1 . EQ. K) GO TO 40 39 CONTINUE NR = NRR NRA = NRA#2 GD-T0 32 40 CONTINUE RETURN END

LSP0783 LSP0784 LSP0785 LSP0786 LSP0787 LSP0788 LSP0789 LSP0790 LSP0791 LSP0792 LSP0793 LSP0794 LSP0795 LSP0796

|        | FUNCTION LOG(K, NA)                                      | LSP079          |
|--------|----------------------------------------------------------|-----------------|
| Ċ      | ***************************************                  | *********LSP079 |
| C<br>C | *                                                        | *LSP079         |
| Ċ      | FUNCTION LOG DETERMINES THE NUMBER OF MEMORIES           | *LSP080         |
| ć      | * (OR INPUTS) REQUIRED FOR K ROWS (OR COLUMNS) USING THE | PASSIVE*LSP080  |
| ē.     | * MEMORY (OR GRAY) ASSIGNMENT CODE.                      | *LSP080         |
| č      | * · · · · · · · · · · · · · · · · · · ·                  | *L SP0 60       |
| ē.     | *                                                        | *LSP080         |
| č      | * NA - OPTION SPECIFYING CODE                            | *LSP080         |
| č      | * 1 = GRAY CODE (INPUT STATES)                           | *LSP0 80        |
| č      | * 2 = PASSIVE MEMORY CODE (MEMORY STATES)                | *LSP060         |
| č      | * K = THE NUMBER OF ROWS (OR COLUMNS).                   | *L5P080         |
| c.     | *                                                        | *LSP080         |
| č      | ***************************************                  |                 |
| -      | 10G = 0                                                  | LSP08           |
|        | IF(NA .EQ. 2) GO TO 30                                   | LSPOB           |
| 10     | KK = 1                                                   | LSPOBI          |
|        | DO 11 I=1.10                                             | LSPOBI          |
|        | IF(KK LT. K) LOG = I                                     | LSP081          |
| 11     | KK = KK + 2                                              | L SP081         |
|        | RETURN                                                   | LSP08           |
| 20     | IF(K .GE. 2) LOG = $K-1$                                 | LSPOB           |
| 50     | RETURN                                                   | LSPORI          |
|        | END                                                      | LSP082          |

|    | FUNCTION NOT(IA)                                      | LSP0821     |
|----|-------------------------------------------------------|-------------|
| 2  | ***************************************               | ****LSP0822 |
| с. | . <b>4</b>                                            | *LSP0823    |
|    | # FUNCTION NOT PERFORMS THE LOGICAL COMPLEMENT OF THE | *LSP0824    |
|    | * VARIABLE IA.                                        | *LSP0825    |
|    | ♣                                                     | *LSP0826    |
|    | ***************************************               | ****LSP0827 |
|    | $IF(IA \_GE. 1) NOT = 0$                              | LSP0828     |
|    | IF(IA $\cdot$ EQ. 0) NOT = 1                          | LSP0629     |
|    | RETURN                                                | LSP0830     |
|    | END                                                   | LSP0831     |

| *********                               | ********   | ***********    | ****** | *******   |          |
|-----------------------------------------|------------|----------------|--------|-----------|----------|
| *                                       |            |                |        |           | *LSP083  |
| FUNCTION MEMORY                         | CONTAINS 1 | THE SIMPLIFIED | MEMORY | EQUATION. | *L SP083 |
| * · · · · · · · · · · · · · · · · · · · |            |                |        |           | *LSP083  |
| • • • • • • • • • • • • • • • • •       |            |                |        |           | *LSP08   |
| # MS = SET SIGNAL                       |            |                |        |           | *LSP08   |
| ★ MR = RESET SIGNAL                     |            |                |        |           | *LSP08   |
| IY = PREVIOUS MEMORY                    | STATE      |                |        |           | *LSP08   |
| *                                       |            |                |        |           | *LSP08   |
| *******************                     | ********   | ***********    | ****** | ********* | **LSP08  |
| MEMORY = MS + IY*NOT(MR)                |            |                |        |           | LSP08    |
| IF (MEMORY .GT. 1) MEMORY               | = 1        | · ·            |        |           | LSP08    |
| RETURN                                  |            |                |        |           | L SPO 8  |
| END                                     |            |                |        |           | LSP08    |

SENTRY

### APPENDIX C

## EXAMPLE COMPUTER SOLUTIONS

\$J0B

CALL LOGSYN Stop End

....

1 101005 6 1 101006 8 101007 1008 2 7 81009 10 91010 7

EXAMPLE C.1 - TABLE XI REPRESENTING EXAMPLE 3.3 2 210 00 10 11 01 1001 2 7 81002 3 41003 7 81004 5 91005 6 1 101006

-----

# LOGIC SYNTHESIS FOR 2 INPUTS, 2 DUTPUTS.

## ORIGINAL PRIMITIVE FLOW TABLE FOR Example C.1 - TABLE XI REPRESENTING EXAMPLE 3.3

|   |    | x2<br>00 |     | 10 | 11   | , | 01 |    | Z 1 | 12. |
|---|----|----------|-----|----|------|---|----|----|-----|-----|
| 1 | (  | 1)       |     | 2  | 0    |   | 7  | ŀ  | 0.  | 0   |
| 1 |    | 8        | - € | 21 | 3    |   | 0  | Ŧ  | 0   | 0   |
| 1 |    | 0        |     | 4  | (3)  |   | 7  | ŧ  | 0   | 0   |
| ١ |    | 8        | - ( | 4) | 5    |   | 0  | .1 | 0   | 0   |
| ł |    | 0        |     | 9  | (5)  |   | 6  | 1  | 0   | 0   |
| 1 |    | 1        |     | 0  | 10   | • | 61 | 1  | 1   | 0   |
| 1 |    | 8        |     | 0  | 10   | ( | 71 | ÷  | ō   | 1   |
| 1 | ۰. | 8.)      |     | 2  | 0 -  |   | 7  | 1  | 0   | 1   |
| L |    | 8        | (   | 91 | 10   |   | 0  | 1  | 0   | 1   |
| 1 |    | 0        |     | 9  | (10) |   | 7  | ÷. | 0   | 1   |

## CANONICAL FLOW TABLE FOR EXAMPLE C-1 - TABLE XI REPRESENTING EXAMPLE 3.3

|     | X2<br>09 | ;   | 10 | ; | 11  | C   | 1   |     | Z1 | 22 |
|-----|----------|-----|----|---|-----|-----|-----|-----|----|----|
| 1 ( | 1)       |     | 2  |   | 0   |     | 3   | 1   | •0 | 0  |
| ŧ . | 4        | - 1 | 21 |   | 5   |     | 0   | 1   | 0  | 0  |
| i   | 4        |     | 0  |   | 6   | - ( | 31  | 1   | 0  | 1  |
| 1 ( | 4)       |     | 2  |   | 0   |     | 3   | 1   | 0  | 1  |
| 1   | 0        |     | 7  | £ | 51  |     | 3   | 1   | 0  | 0  |
| i   | ō        |     | 8  | Ċ | 6.) |     | 3   | - Í | 0  | 1  |
| i   | 4        | (   | 7) |   | 9   |     | 0   | 1   | 0  | 0  |
| i   | 4        | i   | 8) |   | 6   |     | 0   | 1   | 0  | 1  |
| i i | ò        | -   | 8  | 4 | 91  |     | 10  | i   | Ó  | 0  |
| i   | ĩ        |     | ō  | - | 6   |     | 10) | i   | 1  | ō  |

### (PASSIVE MEMORY ASSIGNMENT)

| l     | .11 | ±  | 00 | * | Y | 1 |   |   |    |
|-------|-----|----|----|---|---|---|---|---|----|
| t     | 41  | ÷  | 00 | * | ¥ | 1 |   |   |    |
| ٠t    | 2)  | =  | 10 | * | Y | 2 | * | Y | з. |
| •     | 71  | =  | 10 | * | Y | 2 | * | Y | 3  |
| ť     | 8)  | =  | 10 | * | ¥ | 2 |   |   |    |
| t     | 5)  | æ. | 11 | * | ¥ | 4 | ٠ | Y | 5  |
| 1     | 61  | =  | 11 | ۰ | Y | 4 | * | Y | 5  |
| (     | 91  | =  | 11 | * | ¥ | 4 |   | • |    |
| <br>t | 3}  | =  | 01 | * | Y | 6 |   |   |    |
| - C   | 10) | =  | 01 | ۰ | Y | 6 |   |   |    |

### SWITCHING CONDITIONS:

| Ý.         | 1      | SET<br>RESET |        | 10<br>2 | •      | 3 | + | 7  | + | 8  |  |
|------------|--------|--------------|--------|---------|--------|---|---|----|---|----|--|
| . <b>Y</b> | 2      | SET<br>RESET |        | 1<br>6  | +<br>+ |   | + | 5  |   |    |  |
| Ŷ          | 3      | SET<br>RESET | a<br>9 | 1<br>5  | +      | 4 |   |    |   |    |  |
| ۲          | 4      | SET<br>RESET | =      |         | +      | 3 | + | 8  | + | 10 |  |
| Ý          | 5      | SET<br>RESET |        | 2<br>3  | +.     | 8 | ٠ | 10 |   |    |  |
| ۲          | 6      | SET<br>RESET | 8<br>2 | 19      | +      | 4 | + | 5  | + | 6  |  |
| UTPUT      | SIGNAL | S:           |        |         |        |   |   |    |   |    |  |

### ល

| Z1 =         | 10  |     |     |   |  |
|--------------|-----|-----|-----|---|--|
| 21 =<br>22 = | 3 + | 4 4 | 6 + | 8 |  |

\$308 CALL LOGSYN STOP END 

### EXAMPLE C.2 - TABLE 6.4 FROM FLUID LOGIC TEXT BY E.C. FITCH 2 112 00 10 11 01 1001 2 7 81002 3 101004 5 111005 6

10 4 1011 5 1012 6

### LOGIC SYNTHESIS FOR 2 INPUTS, 1 OUTPUTS.

### ORIGINAL PRIMITIVE FLOW TABLE FOR Example C.2 - Table 6.4 FROM Fluid logic text by E.C. Fitch

| 1  | K1 X2<br>00 | 10   | 11   | 01   |    | 21  |            |
|----|-------------|------|------|------|----|-----|------------|
| 1  | (1)         | 2    | 0    | 7    | 1  | 0   |            |
| 1  | 6           | [2]  | 3    | 0    | ł  | 0   |            |
| ŧ  | 0           | 4    | ( 31 | 9    |    | 0   |            |
| ÷. | 10          | ( 4) | 5    | 0    | i  | Ó   |            |
| ÷. | 0           | 11   | ( 5) | . 6  | j. | i   |            |
| 4  | 1           | 0    | 12   | ( 6) | i. | · 1 |            |
| ÷. | 1           | 0    | 0    | (7)  | ÷  | Ο.  |            |
| ÷. | 1 81        | z    | Ó    | D    | -i | 0   |            |
| ÷  | 0           | ō    | . 3  | { 9} | i. | Ō   |            |
| i. | (10)        | 4    | · 0. | Ó    | i  | 0   | . <u>.</u> |
| í  | Ō           | (11) | 5    | ō    | i. | ĩ   |            |
| i  | . 0         | 0    | (12) | 6    | i  | ĩ   |            |

١.

| STATE | 8  | WAS | EQUI VALENT | TD | STATE | 1   | AND | HAS | BEEN | REMOVED. |  |
|-------|----|-----|-------------|----|-------|-----|-----|-----|------|----------|--|
| STATE | 12 | WAS | EQUIVALENT  | TO | STATE | . 5 | AND | HAS | BEEN | REMOVED. |  |
| STATE | 9  | WAS | EQUIVALENT  | TD | STATE | 7   | AND | HAS | BEEN | REMOVED. |  |

| CANONICAL FLOW TABLE FOR     |                                  |
|------------------------------|----------------------------------|
| EXAMPLE C.2 - TABLE 6.4 FROM | A FLUID LOGIC TEXT BY E.C. FITCH |

|     | x2<br>00 |   | 10 |     | 11 | ( | 01 |    | Z 1 |
|-----|----------|---|----|-----|----|---|----|----|-----|
| 1 1 | 1)       |   | 2  |     | 0  |   | 3  | 1  | 0   |
| 1   | 1        |   | 2) |     | 4  |   | 0  | 1  | 0   |
| 1   | 1        |   | 0  |     | 4  | t | 33 | 1  | 0   |
| 1   | 0        |   | 5  | . ( | 41 |   | 3  | 1  | 0   |
| 1.  | 6        | ( | 5) |     | 7  |   | Ó  | 1  | 0   |
| 1-1 | 6)       |   | 5  |     | 0  |   | 0  | 1  | 0   |
| 1   | 0        |   | 9  | 1   | 71 |   | 8  | 1  | 1   |
| 1   | 1        |   | 0  |     | 7  | • | 8) | ÷. | 1   |
| 1   | o        | t | 91 |     | 7  |   | 0  | 1  | 1   |

### (PASSIVE MEMDRY ASSIGNMENT)

### STATE SIGNALS:

. .

| · · · · | ŧ   | 1)  | ÷   | 00 | * | ¥  | 1 |   |   |   |  |
|---------|-----|-----|-----|----|---|----|---|---|---|---|--|
|         | (   | 6)  | =   | 00 | * | X, | 1 |   |   |   |  |
|         | . ( | 2)  | -   | 10 | * | ٠¥ | 2 | * | Y | 3 |  |
|         | 1   | 51  |     |    | ٠ | Y  | 2 | * | ¥ | 3 |  |
|         |     | 91  | × . | 10 |   |    |   |   |   |   |  |
|         | C   | 41  | ÷   | i1 | * | ¥  | 4 |   | ÷ |   |  |
|         | ť   | 7). | =   | μ  | ٠ | ¥  | 4 |   |   |   |  |
|         | t   | 3)  | =   | 01 | + | ¥  | 5 |   |   |   |  |
|         | ç   | 8)  | *   | 01 | * | ¥  | 5 |   |   |   |  |
|         |     |     |     |    |   |    |   |   |   |   |  |

### SWITCHING CONDITIONS:

| Y 1 | SET = 2 + 3 + 8<br>RESET = 5     |
|-----|----------------------------------|
| Y 2 | SET ≕ 1 + 4 + 6<br>RESET = 7     |
| ¥ 3 | SET = 1<br>RESET = 4 + 6         |
| Y 4 | SET = 2 + 3<br>RESET = 5 + 8 + 9 |
| Y 5 | SET = 1 + 4<br>RESET = 7         |

### OUTPUT SIGNALS:

.

Z1 = 7 + 8 + 9

| 1001 | 00011<br>2 |     | 10  |     |    |     | 13  |             |     |     |    |     |     |     | 1400000  |
|------|------------|-----|-----|-----|----|-----|-----|-------------|-----|-----|----|-----|-----|-----|----------|
|      | 002        | 3   | **  |     |    | 15  |     |             |     |     |    |     |     | 16  | 10000    |
| ••   | 210        |     | 10  |     | 4  | .,  |     |             |     |     |    |     | 17  |     | 11000    |
|      |            | 3   | ••  | 181 |    | 15  |     |             |     | 5   |    |     | ••  |     | 11100    |
|      |            | -   |     | 101 | 4  | 12  |     |             | 191 |     | 6  |     | 17  |     | 11110    |
|      |            |     |     | 18  |    |     |     | 7           |     | 510 |    | 11  | ••  |     | 01110    |
|      |            |     |     |     |    |     | 131 |             | 19  |     | 6  | ••  |     |     | 800110   |
| 9    |            |     |     |     |    |     |     | 7           | • • |     | •  | 11  |     | 161 | 00800011 |
| 1009 | 20         |     | 10  |     |    |     | 13  | •           |     |     |    | •-  |     |     | 00000    |
| i    |            | 310 |     | 18  |    |     |     |             |     |     |    | 11  |     |     | 01000    |
| -    |            |     | 10  | ••  |    |     |     |             |     |     | 61 | 011 | 17  |     | 1201010  |
| 1    |            |     |     |     | ÷. |     |     | 7           |     |     |    | 11  | ••• | 161 | 01200011 |
| 1    |            |     |     | 18  |    | 151 | 013 | 7<br>7<br>7 |     |     |    |     |     |     | 00100    |
| 1    |            |     |     |     |    |     |     | 7           |     |     |    | 11  |     | 161 | 01400011 |
|      | 2          |     |     |     | 41 | 015 | 13  |             | 19  |     |    |     |     |     | 10100    |
|      | 2<br>2     |     |     |     |    |     | _   |             | 19  |     |    |     | 171 | 016 | 1210010  |
|      |            | 3   |     |     |    |     |     |             |     | 5   |    | 111 | 017 | 16  | 11010    |
|      |            |     | 101 | 018 | 4  |     | 13  |             |     |     | 6  |     |     |     | 01100    |
|      |            |     |     |     |    | 15  |     | 71          | 019 | 5   |    |     |     | 16  | 10110    |
| 211  | 020        | 3   |     |     |    | 15  |     |             | 1   |     |    |     |     | 16  | 10000    |
| 1021 | 22         |     | 10  |     |    |     | 13  |             |     |     |    |     |     |     | 1400000  |
| 231  | 022        | 3   |     |     |    | 15  |     |             |     |     |    |     |     | 16  | 10000    |
| 1023 | 24         |     | 10  |     |    |     | 13  |             |     |     |    |     |     |     | 1400000  |
| 251  | 024        | 3   |     |     |    | 15  |     |             |     |     |    |     |     | 16  | 10000    |
| 1025 | 20         |     | 10  |     |    |     | 13  |             |     |     |    | •   |     |     | 2600000  |
| 9    |            |     |     |     |    |     |     | 27          |     |     |    | 11  |     | 161 | 02600010 |
|      |            |     |     |     |    |     | 281 | 027         | 19  |     | 6  |     |     |     | 800110   |
| 1    |            |     |     | 18  |    | 291 | 028 | 7           |     |     |    |     |     |     | 10100    |
|      | 30         |     |     |     | 41 | 029 | 13  |             | 19  |     |    |     |     |     | 10100    |
| 11   | 030        | 3   |     |     |    | 15  |     |             |     |     |    |     |     | 16  | 10001    |

\$JOB

CALL LOGSYN Stop End

### STATE 25 WAS EQUIVALENT TO STATE 9 AND HAS BEEN REMOVED. STATE 14 WAS EQUIVALENT TO STATE 12 AND HAS BEEN REMOVED.

|   | 0000    | 1000  | 1100 | 0100        | 0110 | 1110         | 1010   | 0010     | 0011 | 1011 | 1111    | 0111 | 0101 | 1101 | 1001 | 0001 | Z1  | 22 | Z3  | Z4  | Z5, | Z6  |  |
|---|---------|-------|------|-------------|------|--------------|--------|----------|------|------|---------|------|------|------|------|------|-----|----|-----|-----|-----|-----|--|
|   | (1)     | 2     | 0    | 10          | Q    | 0            | 0      | 13       | 0    | 0    | 0       | 0    | 0    | 0    | 0    | 14   | 1 0 | 0  | 0   | 0   | 0   | 0   |  |
|   | 1       | [2]   | 3    | 0           | 0    | 0            | 15     | 0        | 0    | 0    | · 0     | 0    | 0    | 0    | 16   | 0    | 1   | 0  | 0   | · 0 | 0   | 0   |  |
|   | 0       | 2     | (3)  | 10          | 0    | 4            | 0      | . 0      | 0    | . 0  | 0       | 0    | 0    | 17   | 0    | · O  | ( 1 | 1  | 0   | 0   | 0   | 0   |  |
|   | 0       | 0     | 3    | 0           | . 18 | ( <b>4</b> ) | 15     | 0        | 0    | 0    | 5       | 0 -  | 0    | 0    | 0    | 0    | 1   | 1  | - 1 | 0   | 0   | 0   |  |
|   | 1 0     | 0     | 0    | ·0          | 0    | 4            | 0      | 0        | . 0  | 1.9  | - { 5 } | 6    | 0    | 17   | . 0  | 0    | 1 1 | 1. | 1   | 1   | 0   | 0   |  |
|   | 1 0     | 0     | 0    | . 0         | 18   | 0            | 0      | 0        | 7    | 0    | 5       | (6)  | 11   | · O  | 0    | 0    | 0   | 1  | 1   | 1   | 0.  | 0   |  |
|   | 0       | 0     | 0    | · 0         | 0    | 0            | 0      | 13       | L 7) | 19   | 0       | 6    | -0   | 0    | 0    | 6 )  | 1 0 | 0  | 1   | 1   | 0   | . 0 |  |
|   | 9       | . 0 - | 0    | 0           | 0    | 0            | 0      | <b>O</b> | 7    | 0    | 0       | 0    | 11   | 0    | 16   | (8)  | 1 0 | 0  | 0   | 1   | 1   | 0   |  |
|   | ( 9)    | 20    | 0    | . 10        | 0    | 0            | 0      | 13       | 0    | 0    | 0       | 0    | 0    | 0    | 0    | 0    | t 0 | 0  | 0   | 0   | 0   | 0   |  |
|   | 1       | 0     | 3    | (10)        | 18   | 0            | 0      | 0.       | 0    | 0    | · · · O | 0    | 11   | 0    | O    | 0    | 1 0 | 1  | ` O | 0   | 0.  | . 0 |  |
|   | 0       | . 0   | 0    | 10          | 0    | 0            | 0      | 0        | . 0  | Ö    | 0       | 6    | (11) | 17   | 0    | . 12 | 0   | 1  | 0   | 1   | 0   | 0   |  |
|   | 1       | 0     | . 0  | 0           | 0    | 0.           | 0      | 0        | 7    | · .0 | 0       | 0    | 11   | 0    | 16 - | (12) | 1 0 | 0  | 0   | 1   | 1   | 1   |  |
|   | 1       | 0     | . 0  | 0           | 18   | 0            | 15     | (13)     | 7    | 0    | 0       | 0    | 0    | - 0  | 0    | 0    | 1 0 | 0  | - 1 | · 0 | 0   | 0   |  |
|   | 1.1     | 0     | 0    | 0           | 0    | 0            | 0      | 0        | 7    | 0    | 0       | 0    | 11   | 0    | 16   | (14) | 1 0 | 0  | 0   | 1   | 1   | 1   |  |
|   | 1 0     | - 2   | 0    | 0           | 0    | . 4          | 1151   | 13       | 0    | 19   | · 0     | 0    | 0    | 0    | 0    | 0    | 1 1 | 0  | · 1 | o   | 0   | 0   |  |
|   | 0 1     | 2     | 0    | . • 0       | · 0  | 0            | 0      | 0        | 0    | 19   | 0       | . 0  | 0    | 17   | (16) | 12   | 1 1 | 0  | · 0 | 1   | 0   | 0   |  |
|   | 1 0     | .0    | 3    | 0           | 0    | . 0          | 0      | 0        | 0    | 0    | . 5     | 0    | 11   | (17) | 16   | 0    | i i | 1  | 0   | 1   | 0   | 0   |  |
| 1 | 0       | 0     | 0    | 10          | [18] | 4            | 0      | 13       | 0    | 0    | 0       | 6    | 0    | 0    | 0    | 0    | 0   | 1  | 1   | 0   | 0   | 0   |  |
|   | 0       | 0     | 0    | 0           | 0    | Ó            | 15     | 0        | 7    | [19] | 5       | . 0  | 0    | 0    | 16   | 0    | 1 1 | 0  | 1   | 1   | 0   | . 0 |  |
|   | 21      | (20)  | 3    | 0           | 0    | 0            | 15     | .0       | 0    | 0    | 0       | 0    | 0    | 0    | 16   | . 0  | 1 1 | 0  | 0   | 0   | 0   | 0   |  |
|   | (21)    | 22    | 0    | 10          | 0    | . 0          | 0      | 13 -     | 0    | . 0  | 0.      | . 0  | 0.   | . 0  | · 0  | 14   | 1 0 | 0  | 0   | 0   | 0   | 0 . |  |
|   | 23      | (22)  | 3    | 0           | 0    | 0            | 15     | 0        | 0    | . 0  | 0       | 0    | 0    | 0    | 16   | 0    | 1 1 | 0  | 0   | 0   | Ö   | 0   |  |
|   | i (23)  | 24    | · 0  | - 10-       | 0    | 0            | 0      | 13       | . 0, | 0    | . 0     | 0    | 0    | 0    | 0    | 14   | 1 0 | 0  | 0   | 0   | 0   | 0   |  |
|   | -25     | (24)  | 3    | · O         | 0    | 0            | 15     | 0        | 0    | 0    | · 0     | . 0  | 0    | 0    | 16   | 0    | 1 1 | 0  | 0   | 0   | 0   | 0   |  |
|   | (25)    | 20    | : 0  | 10          | 0    | 0            | 0      | 13       | 0    | 0    | 0       | 0    | 0    | 0    | 0    | 26   | 1 0 | 0  | 0   | 0   | 0   | 0   |  |
|   | 9       | 0     | 0    | . 0         | . 0  | · 0          | 0      | 0        | 27   | 0    | 0       | Ó    | . 11 | : 0  | 16   | (26) | 0   | 0  | 0   | 1   | 0   | 0   |  |
|   | 0       | 0     | O,   | · 0         | 0    | 0            | · 0    | 28       | (27) | 19   | 0       | 6    | 0    | 0    | . 0  | . 8  | 0   | 0  | 1   | 1   | 0   | 0   |  |
|   | 1       | Ò     | 0    | 0           | 18   | 0            | 29     | 1281     | . 7  | . 0  | · 0     | 0    | 0    | .0   | 0    | 0    | 1 1 | 0  | 1   | 0   | 0   | 0   |  |
|   | i . o . | 30    | 0    | . · · · O · | 0    | 4            | [ 29 ] | 13       | 0    | 19   | 0       | 0    | 0    | 0    | 0    | 0    | 1 1 | 0  | 1   | 0   | 0   | 0   |  |
|   | 1       | (30)  | .3   | 0           | 0    | 0            | 15     | 0        | 0    | 0    | 0       | 0.   | 0    | 0    | 16   | 0    | 1 1 | 0  | .0  | 0   | 1   | 0   |  |

ORIGINAL PRIMITIVE FLOW TABLE FOR Example C.3 - 4-input, 30 Row

X1 X2 X3 X4

. .

LOGIC SYNTHESIS FOR 4 INPUTS, 6 OUTPUTS. CANONICAL FLOW TABLE FOR EXAMPLE C.3 - 4-INPUT, 30 ROW

### X1 X2 X3 X4 0000 1000 1100 0100 0110 1110 1010 0010 0011 1011 1111 0111 0101 1101 1001 0001 21 22 23 24 25 26 Ð 3 6 n - 3 -5 (Z) n õ õ ( 3) Ó ò - 6 ō ō ō õ C (5) ź £ 6) ò г ( 7) ŧ 8) C ł 9} C (10) n (11) 0 (12) Q n (13) n n n n (14) 17 (15) 10 10 11 • (16) 15 ō 0 (17) n ō zõ (18) -0 (19) 0 23 0 18 Ó Ó õ (20) (21) ō ō ō 0 (22) õ Ó .16 .0 (23) 0 27 28 (27) (24) 4 4 0 (25) - 3 18 0 C Ō İ. (28) A

(PASSIVE MEMORY ASSIGNMENT)

( 3) = 0100

STATE SIGNALS:

| (1)  | <b>≖ 0000</b>     | * | Y  | ı | * | Y  | 2 |   |    |   |   |  |
|------|-------------------|---|----|---|---|----|---|---|----|---|---|--|
|      | = 0000            |   |    |   |   |    |   |   | 1  |   |   |  |
| 1211 | = 0000            | * | ٠¥ | 1 | * | ¥  | 3 |   |    |   |   |  |
|      | = 0000            |   |    |   |   |    |   |   |    |   | : |  |
| 1 2) | = 1000            | * | Ŷ  | 4 | * | Ý  | 5 | * | ۷  | 7 |   |  |
| (19) | - = 1000          | * | Ý  | 4 | ۰ | Y  | 5 | * | ĭ  | 7 |   |  |
|      | = 1000            |   |    |   |   |    |   |   |    |   |   |  |
| (27) | = 1000            | * | ¥  | 4 | * | ÷Ϋ | 6 |   | Ξ. |   |   |  |
|      | = 1000            |   |    |   |   |    |   |   |    |   |   |  |
| er j | a transfer of the |   |    |   |   |    |   |   | ÷. |   |   |  |
| 1 61 | = 1100            |   |    |   | · |    |   |   |    |   |   |  |
|      |                   |   |    |   |   |    |   |   |    |   |   |  |

| ( 9)      | = 0110                                                |
|-----------|-------------------------------------------------------|
| (12)      | = 1110                                                |
|           | = 1010 * Y 8<br>= 1010 * Y 8                          |
| ( 4)      | -<br>= 0010 <b>*</b> Y 9                              |
| (24)      | = 0010 * ¥ 9                                          |
|           | = 0011 + Y10<br>= 0011 + Y10                          |
| (14)      | = 1011                                                |
| (17)      | = 1111                                                |
| (15)      | = 0111                                                |
| {10}      | = 0101                                                |
| (13)      | ≠ 1101                                                |
| ( 8)      | = 1001                                                |
|           | = 0001 * Y11 * Y12                                    |
| (16)      | = 0001 + Y11 + Y12                                    |
| (20)      | = 0001 * Y11                                          |
| SWITCHING | CONDITIONS:                                           |
| Y 1       | SET = 2 + 3 + 4 + 5 + 24 + 28<br>RESET = 19 + 23      |
| ¥ 2       | SET = 2 + 3 + 4 + 5 + 24 + 28<br>RESET = 16 + 20 + 27 |
|           |                                                       |

-

SET = 19 RESET = 23 Y 3 Υ4 SET = 1 + 6 + 7 + 8 + 18 + 21 RESET = 25 + 26 . Y 5 SET = 1 + 6 + 7 + 8 + 18RESET = 21SET = 25 Y 6 RESET = 26 SET = 1 + 6 + 7 + 8Y 7 RESET = 18 SET = 2 + 4 + 12 + 14 + 19 + 23 + 27 + 28 Y 8 RESET = 24

Y 9 SET = 1 + 7 + 9 + 11 + 18 + 21 + 25 + 26 RESET = 22 ¥10 SET = 4 + 5 + 14 + 15 + 16 + 24

4 + 5 + 24 + 28 + 16 + 20 + 27

### RESET = 20

SET = 1 + 8 + 10 + 21 + 25 + 11 + 22 ¥11 RESET = 18

SET = 1 + 8 + 10 + 21 + 25 RESET = 11 + 22 ¥12

OUTPUT SIGNALS:

```
Z1 = 2 + 6 + 7 + 8 + 12 + 13 + 14 + 17 + 19 + 23 + 24 + 26 + 27 +
```

\$JOB Call LOGSYN Stop END

0000000

000000000

<u>در</u> س

~

## LOGIC SYNTHESIS FOR 1 INPUTS, 1 OUTPUTS.

## ORIGINAL PRIMITIVE FLOW TABLE FOR EXAMPLE C.4 - B EVENT COUNTER

|      |          |      | · · · |
|------|----------|------|-------|
|      |          |      |       |
|      |          |      |       |
| ×ı   |          |      |       |
|      | 0        | 1    | Z 1   |
| _    | <u> </u> |      |       |
| 1 (  | 1)       | 2    | 0     |
|      | 3        | (2)  | ŏ     |
|      | 31       |      | ŏ     |
|      |          | . 7. |       |
|      | 5        | (4)  | 0     |
|      | 5)       | 6    | 0     |
|      | 7        | ( 6) | 0     |
| 1.0  | 71       | 6    | 0     |
| 1    | 9        | (8)  | 0     |
| 1.0  | 91       | 10 - | 0     |
| i i  | 1        | (10) | 0     |
|      | 1)       | 12   | 0     |
|      | 3        | (12) | ō     |
|      | 31       | 14   | ö     |
|      | 5        | (14) | ŏ     |
|      | 5)       |      | ŏ     |
| 1 (1 |          | 16   |       |
| 1 -  | 1        | (16) | 1     |

| CANONICAL FLOW TABLE | FOR   |         |
|----------------------|-------|---------|
| EXAMPLE C.4 - 8      | EVENT | COUNTER |
|                      |       |         |

| ×1<br>0 | 1    | 21  |
|---------|------|-----|
| 1 ( ii  | z    | 0   |
| 1 3     | (2)  | 0   |
| 1 ( 3)  | 4    | 0   |
| 1 5     | { 4} | 0   |
| 1 1 51  | 6    | 0   |
| 1 7     | [6]  | 0   |
| 1 ( 7)  | 8    | 0   |
| 1 9     | (8)  | 0   |
| 1 ( 9)  | 10   | 0   |
| 1 11    | (10) | 0   |
| i an    | 12   | 0   |
| 1 13    | {12} | 0   |
| 1 (13)  | 14   | . 0 |
| 1 15    | (14) | Ū.  |
| 1 (15)  | 16   | Ó   |
| 1 1     | (16) | 1   |

(PASSIVE MEMORY ASSIGNMENT)

STATE SIGNALS:

| (1)                | =-   | 0   | *  | Y  | 1 | * | ¥  | 2  | *  | ۷  | 4  |
|--------------------|------|-----|----|----|---|---|----|----|----|----|----|
| (3)                |      | 0   | ٠  | ۲. | 1 | ٠ | ¥  | 2  | ٠  | x  | 4  |
| (5)                | =    | 0   | .* | Y  | 1 | * | X  | 2  | ٠  | Ÿ  | 6  |
| (7)                | -    | 0   | ٠  | Y  | 1 |   | Ĩ  | 2  | ٠  | X  | 6  |
| <sup>(*</sup> 1 91 | =    | 0   | ٠  | x  | 1 | ۰ | ¥  | з  |    | Ÿ  | 5  |
| (11)               | =    | 0   | ٠  | Ī  | I | ٠ | Y  | 3  |    | x  | 5  |
| (13)               | =    | 0   | ۰  | X  | 1 | ۰ | X  | 3  | ٠  | Y  | 7  |
| (15)               | ٠    | 0   | *  | ï  | 1 | ٠ | ¥  | 3  | *  | ¥  | 7  |
| (2)                | =    | ì   | *  | ۲  | 8 | * | Y  | 9  | *  | ¥1 | 11 |
| (4)                | - 2  | 1   | ٠  | Y  | 8 | ٠ | Y. | 9  | ٠  | ΥÌ | 11 |
| (6)                | `= . | 1   | ٠  | ۷  | 8 | ٠ | X  | 9  | ٠  | Y  | 13 |
| (8)                | =    | 1   | ٠  | Y  | 8 | * | Y  | 9  | ۰. | X1 | LЗ |
| (10)               | . =  | 1   | ٠  | x  | 8 | ٠ | Ŷ  | 10 | ٠  | ¥1 | 12 |
| (12)               | =    | 1   | ٠  | Ŷ  | 8 |   | Υ: | 10 | ٠  | Y  | 12 |
| (14)               | =    | 1   | ۰  | Ŷ  | 8 | ٠ | X  | 10 | ٠  | Y  | 4  |
| (16)               | = .  | - 1 | ٠  | X  | 8 | * | Y  | 10 | ۰  | X) | ۱4 |

SWITCH

Y 1 -

Υ2 Υ 3

| (15) | *          | 0   | ۰ | X | 1 | ۰  | X 3  | ۰ | X 7 |  |
|------|------------|-----|---|---|---|----|------|---|-----|--|
| (2)  | =          | ì   |   | Y | 8 | *  | ¥ 9  |   | ¥11 |  |
| (4)  | - <b>a</b> | 1   | ٠ | Y | 8 | ٠  | Y. 9 | ٠ | ¥11 |  |
| (6)  | `= .       | 1   | ٠ | ۷ | 8 | *  | X.9  | ٠ | ¥13 |  |
| (8)  | =          | 1   | ٠ | Y | 8 | ٠. | ¥9   | • | ¥13 |  |
| (10) | . =        | 1   | ٠ | X | 8 | ٠  | ¥10  | ٠ | ¥12 |  |
| (12) | =          | 1   | ٠ | Ŷ | 8 |    | ¥10  | ٠ | ¥12 |  |
| (14) | =          | 1   | ۰ | Ŷ | 8 | ٠  | ¥10  | ٠ | ¥14 |  |
| (16) | =.         | · 1 | ٠ | Ÿ | 8 | *  | ¥10  | ۰ | ¥14 |  |

| (6)   | -    | 1   | ۰   | Y  | 8 | *  | X.9 | ٠  | Y13 |   |
|-------|------|-----|-----|----|---|----|-----|----|-----|---|
| (8)   | =    | 1   | ٠   | Y  | 8 | ٠. | ¥9  | ۰, | ¥13 |   |
| (10)  | . =  | 1   | ٠   | X  | 8 | ٠  | ¥10 | ٠  | ¥12 |   |
| (12)  | =    | 1   | ٠   | Ÿ  | 8 |    | ¥10 | ٠  | ¥12 |   |
|       | =    | 1   |     | Ŷ  | 8 | ٠  | ¥10 | ٠  | ¥14 |   |
| (16)  | Ξ.   | · 1 | ٠   | X  | 8 | *  | ¥10 | ٠  | ¥14 |   |
| CHING | COND | 111 | JN! | 5: |   |    |     |    |     | • |

SET = 16 + 2RESET = 4 + 6

SET = 8 + 10

SET = 16 + 2 + 4 + 6 RESET = 8 + 10 + 12 + 14

RESET = 12 + 14

SET = 16 Y 4 RESET = Z SET = 8 RESET = 10 Y 5 ¥ 6 SET = 4 RESET = 6 SET = 12 RESET = 14 Y 7 SET = 1 + 3 + 5 + 7 RESET = 9 + 11 + 13 + 15 ¥ 8 SET = 1 + 3 RESET = 5 + 7 ¥ 9 SET = 9 + 11 RESET = 13 + 15 ¥10 ¥11 SET = 1 RESET = 3 ¥12 SET = 9 5 RESET = 11 SET ≖ 5 ¥13 RESET = 7 SET = 13 Reset = 15 ¥14

### OUTPUT SIGNALS:

21 = 16

.

MS(1) = ITS(3) + X(2)\*Y(2) HR(1) = ITS(1) + NOT(X(2))\*Y(2) MS(2) = ITS(2)\*Y(1) + ITS(4)\*Y(1) HR(2) = ITS(3)\*Y(1) + ITS(1)\*NOT(Y(1)) Z(1) = ITS(2)\*NOT(Y(1))\*Y(2) Z(2) = ITS(4)\*Y(1)\*Y(2) ......

EXAMPLE C.5 - TABLE XII - CLASSICAL EQUATIONS 2 2 2 0000 2 1 2 2 1 2 2 1 2 2 1 2 2 1 2 2 1 2

\$J08

CALL LOGSIM STOP END

### LOGIC SIMULATION For 2 Inputs, 2 Dutputs, 2 Memories.

### SIMULATED FLOW TABLE FOR EXAMPLE C.5 - TABLE XII - CLASSICAL EQUATIONS

|     |      |   |     |   |    |    |    |     |    | ÷  |   |  | • |
|-----|------|---|-----|---|----|----|----|-----|----|----|---|--|---|
| X   | 1 X2 |   | 10  |   | 11 |    | 01 |     | 71 | 22 |   |  |   |
|     |      |   |     |   |    |    |    |     |    |    | _ |  |   |
| 1   | ( 1) |   | 2   |   | 0  |    | 3  | 1   | 0  | 0  |   |  |   |
| 1   | 1    | 1 | Z } |   | 4  |    | 0  | ÷.  | 0  | 0  |   |  |   |
| ŧ   | 1    |   | 0   |   | 4  |    | 31 | Í.  | 0  | 0  | · |  |   |
| - È | 0    |   | 6   | ( | 4) |    | 5  | - È | 0  | 0  |   |  |   |
| ÷.  | 1    |   | 0   |   | 4  | -1 | 51 | -È  | 0  | 1  |   |  |   |
| i   | 1    | 6 | 6)  |   | 4  |    | 0  | i   | 1  | ō  |   |  |   |
|     |      |   |     |   | _  |    |    |     | -  | _  | _ |  |   |

## 

EXAMPLE C.6 - ROTATION DIRECTION SENSOR - STATE MATRIX EQUATIONS

2 1 4 000000 1 1 1 2 1 3 1 4

\$108

CALL LOGSIM STOP END

MS(1) = ITS(4)#NOT(Y(4)) NR(1) = ITS(2) + ITS(4)=Y(4) MS(2) = ITS(3) MR(2) = ITS(1) MS(3) = ITS(4) MR(3) = ITS(2) MS(4) = ITS(3) MR(4) = ITS(1) Z(1) = ITS(1)+Y(1) + ITS(2)+NOT(Y(2)) + ITS(3)+NOT(Y(3)) + TTS(4)+Y(4)

ITS(4)\*Y(4) .

### LOGIC SIMULATION FOR 2 INPUTS, 1 DUTPUTS, 4 MEMORIES.

### SIMULATED FLOW TABLE FOR Example C.6 - ROTATION DIRECTION SENSOR - STATE MATRIX EQUATIONS

| 1  |   | x2<br>20 |   | 10 |   | 11 |   | 01 |   | Z1 |
|----|---|----------|---|----|---|----|---|----|---|----|
| ı. | ( | 11       |   | 2  |   | 0  |   | 3  | 1 | 0  |
| Ł  |   | 1        | 1 | 2) |   | 4  |   | 0  | 5 | 1  |
| 1  |   | 6        |   | C  |   | 5  | C | 3) | Ŧ | 0  |
| 1  |   | 0        |   | 8  | ( | 4) |   | 7  | 1 | 1  |
| I  |   | 0        |   | 8  | 1 | 51 |   | 7  | ł | 0  |
| 1  | t | 61       |   | 2  |   | 0  |   | 3  | 1 | 1  |
| 1  |   | 1        |   | 0  |   | 5  | ( | 7) | ł | 1  |
| 1  |   | 1        |   | 8) |   | 4  |   | 0  | ł | 0  |

1

. .

119

ł

1 1 2 2 3 1 4 1 5 MS(1) = ITS(2)+Y(2)+Y(3) + ITS(4) MS(1) = ITS(2)\*V(2)\*V(3) + ITS(4) MR(1) = ITS(2)\*V(2)\*NOT(V(3)) HS(2) = ITS(1) + (TS(3)\*V(4) HR(2) = ITS(1)\*V(1) HR(3) = ITS(1)\*V(1) + ITS(3)\*V(4) MS(4) = ITS(2)\*V(2)\*NOT(V(3)) + ITS(4)\*NOT(V(2)) + ITS(4)\*NOT(V(5)) HR(4) = ITS(2)\*V(2)\*NOT(V(3)) + ITS(2)\*NOT(V(2)) + ITS(4)\*NOT(V(5)) HR(5) = ITS(1)\*V(1) + ITS(3)\*V(4) HR(5) = ITS(2)\*NOT(V(2)) + ITS(3)\*NOT(V(4)) + ITS(4)\*NOT(V(5)) Z(1) = ITS(2)\*NOT(V(2)) + ITS(3)\*NOT(V(4)) + ITS(4)\*NOT(V(5))

120

EXAMPLE C.2 - TABLE 6.4 FROM FLUID LOGIC BY FITCH - STATE MATRIX EQUATIONS

2 1 5 1111100

\$ JDB

CALL LOGSIM Stop End

LDGIC SIMULATION For 2 Inputs, 1 Outputs, 5 Memories.

SINULATED FLOW TABLE FOR EXAMPLE C.2 - TABLE 6.4 FROM FLUID LOGIC BY FITCH - STATE MATRIX EQUATIONS

5. -

### VITA

### Robert Loren Woods

### Candidate for the Degree of

Master of Science

### Thesis: THE STATE MATRIX METHOD FOR THE SYNTHESIS OF DIGITAL LOGIC SYSTEMS

Major Field: Mechanical Engineering

Biographical:

- Personal Data: Born in Frederick, Oklahoma, April 14, 1945, the son of Mr. and Mrs. Aldon Woods.
- Education: Graduated from Frederick High School, Frederick, Oklahoma, in May, 1963; attended Oklahoma State University from 1963 to 1965; received the Bachelor of Science degree from Southern Methodist University in 1967, with a major in Mechanical Engineering; completed requirements for the Master of Science degree from Oklahoma State University in May, 1970.
- Professional Experience: Technical analyst, Nuclear Research Services, Dallas, Texas, 1967; graduate teaching assistant, Southern Methodist University, 1968; graduate research assistant, Oklahoma State University, 1968-69.

Professional Organizations: Member Pi Tau Sigma.