DIGITAL SYSTEMS DESIGN LANGUAGE - DESIGN SYNTHESIS OF DIGITAL SYSTEMS

By Sajjan G. Shiva
University of Alabama
Computer Science Department
Huntsville, AL 35807

Technical Report

October 1979

Prepared for:

NASA - GEORGE C. MARSHALL SPACE FLIGHT CENTER
Marshall Space Flight Center, Alabama 35812
Digital Systems Design Language
Design Synthesis of Digital Systems

Sajjan G. Shiva

University of Alabama
Computer Science Department
Huntsville, AL 35807

National Aeronautics and Space Administration
Washington, DC

Contract Monitor: Robert E. Jones

Date for General Release: October 1983

Digital Systems Design Language (DDL) has been implemented on the SEL-32 Computer Systems of the Electronics and Controls Laboratory. This document provides the details of the language; the translator and the simulator programs. Several example descriptions and a tutorial on hardware description languages are provided, to guide the user.

17. KEY WORDS
Digital Systems Design Language
Digital Computer Implementation
Translator and Simulator
Tutorial Examples
FOREWORD

This is a technical summary of the research work conducted during October 1, 1978 to September 30, 1979 by The University of Alabama in Huntsville towards the fulfillment of the Contract NAS8-33096 from the George C. Marshall Space Flight Center, Alabama. The NASA technical officer for this contract is Mr. Robert E. Jones.

The author gratefully acknowledges the numerous discussions with and helpful comments of Mr. John H. Gould during this research work, and thanks Professor Donald Dietmeyer of the University of Wisconsin-Madison for providing the DDL Software.
# TABLE OF CONTENTS

LIST OF TABLES--------------------------------------------------------------- IV
LIST OF FIGURES-------------------------------------------------------------- IV

1. INTRODUCTION-------------------------------------------------------------- 1

2. THE LANGUAGE (DDL)------------------------------------------------------ 2
   2.1 Syntax Rules------------------------------------------------------------ 5
   2.2 Declaration Statements------------------------------------------------ 5
   2.3 Operations-------------------------------------------------------------- 8
   2.4 If-Value Clause-------------------------------------------------------- 10
   2.5 Identifier------------------------------------------------------------- 11
   2.6 Operator Declarations------------------------------------------------ 11
   2.7 State Declaration------------------------------------------------------ 13
   2.8 Automaton and System Declarations-------------------------------------- 14

3. THE TRANSLATOR (DDLTRAN)------------------------------------------------ 19
   3.1 The Translation Process----------------------------------------------- 20
   3.2 An Example-------------------------------------------------------------- 23

4. THE SIMULATOR (DDLSIM)--------------------------------------------------- 31
   4.1 Simulation Models------------------------------------------------------- 32
   4.2 Simulator Command Language--------------------------------------------- 37
   4.3 Simulation Algorithm---------------------------------------------------- 61
   4.4 Errors---------------------------------------------------------------- 64

5. EXAMPLES
   Example 1: A Serial Twos Complementer------------------------------------- 66
   Example 2: The Serial Twos Complementer (variation 1)---------------------- 77
   Example 3: Twos Complementer (variation 2)--------------------------------- 84
   Example 4: Multiplier------------------------------------------------------- 94
   Example 5: Minicomputer----------------------------------------------------- 99

6. CONCLUSIONS--------------------------------------------------------------- 102
APPENDIX

III
LIST OF TABLES

2.1 OPERATORS-------------------------------------------------------------18
3.1 FLAG INTEGERS--------------------------------------------------------20

LIST OF FIGURES

2.1 Local and Global Facilities-----------------------------------------------4
5.1 A Serial Twos Complementer-----------------------------------------------70
5.2 The Serial Twos Complementer (variation 1)-------------------------------78
5.3 The Serial Twos Complementer (variation 2)-------------------------------85
5.4 Multiplier---------------------------------------------------------------96
5.5 Minicomputer------------------------------------------------------------101
1. INTRODUCTION

Hardware Description Languages (HDL) provide a convenient medium of inputting the design details into a design automation system. This report gives the details of one such language, Digital Systems Design Language (DDL), selected for integration into the Computer Aided Design and Test System (CADAT) of the Electronics and Controls Laboratory.

Chapter 2 provides the language details, Chapter 3 discusses the translator program and Chapter 4 discusses the Simulator Program. Some example descriptions are provided in Chapter 5. A tutorial on Hardware Description Languages is provided in the Appendix. An exhaustive bibliography for some of the literature in this area is also provided in the Appendix. Readers not familiar with any HDL are referred to the Appendix before reading the rest of the report.

The Simulator and Translator Programs are currently being tested on SEL-32 Computer System and hence, the complete deck set up details for the use of these programs is not included in this manual.
2. THE LANGUAGE [31]*

DDL was introduced in 1967 by Duley and Dietmeyer [33]. A translator and a simulator are written for a subset of this language in IFTRAN, an extended version of FORTRAN [35,36]. These programs are implemented in FORTRAN on SEL 32 Computer System. The translator (DDLTRAN) translates a DDL description into a set of Boolean equations and register-transfer statements. The simulator (DDLSIM) enables the system designer to verify his design. The output of the translator is an input to the simulator. Simulation parameters are to be input by the designer. In DDL the structural elements are explicitly declared. At the lower level of description, functional and structural elements correspond directly to the actual elements of the system. DDL is highly suitable for describing the system at the gate, register transfer and major combinational block level.

The logical statements can be formed using the available primitive operators. The functional specification of the system consists of these logical statements, in blocks. The statements describe the state transitions of a finite state machine controlling the processes of the intended algorithm. The block then appears as an automaton.

Parallel operations are permitted. Synchronous behavior is described by either identifying the pulses or by including delay elements described in terms of multiples of clock pulses. Asynchronous behavior is modelled by using conditional statements. Data paths can be explicitly declared by using terminal declarations.

*The numbers in brackets point to the references listed in the Appendix.
DDL is a "block-oriented" language; the blocks of a DDL description usually correspond to natural divisions (blocks) of the hardware being described. Thus a computer may have a major block called an "ALU," which contains a block called "adder," which consists of interconnected logic blocks called "full-adders." This nested view of the hardware can be directly reflected in the DDL description of the computer.

Both facility declarations and operations can appear within the body of the more complex declarations that have a heading part. Identifiers declared within such complex declarations are said to be local facilities of that declaration, and are global facilities of complex declarations that appear in the body of the encompassing declaration. Other complex declarations that parallel the encompassing declaration cannot control or sense such facilities. Operations can reference only facilities that are local or global to the block in which they appear. Thus the same identifier may be declared in more than one parallel block without ambiguity.

Figure 2-1 illustrates some of the possibilities. Facilities A, B, and C are declared facilities of the overall block named SYSTEM. These facilities are global to all blocks within SYSTEM; any or all of these blocks may control or sense the states of facilities A, B, and C. Hence A, B, and C are said to be public facilities. Facilities D and E are local to SUBSYSTEM 1, global to PART 1 and PART 2. SUBSYSTEM 2 and its inner blocks are not aware that facilities D and E exist; no reference to D and E may appear in the description of SUBSYSTEM 2.

Facilities H and I are local to PART 1; no other block of Fig. 2-1 may control or sense these facilities. PART 2 has its own facility I which may be of a very different hardware nature than facility I of
PART 1. PART 1 and PART 2 each control and sense their own facility I.

Similarly, PART 2 controls and senses its local facility J as does ASSEMBLY for its local facility J, which is global to CARD and hence can be controlled and sensed by CARD. References to K within CARD pertain to the most locally declared facility K, e.g., the one declared within CARD.

Permitting the same identifier to be used in parallel blocks allows designers working in parallel on the blocks to select without restriction names that appeal to them. If parallel blocks must communicate, facilities global to them must be established and assigned unique names. The designers of the parallel blocks must know and use these global names. Thus in Fig. 2-1 SUBSYSTEM 1 and SUBSYSTEM 2 may communicate via A, B, or C. PART 1 and PART 2 may communicate via D or E, or via A, B, or C.
2.1 SYNTAX RULES

VARIABLES:
Variable name may contain 1 to 8 characters, the first of which must be alphabetic. The remaining characters must be letters or digits.

Examples: MULT
          SYSI
          COMPLMNT

CONSTANTS:
Constants take the general form nRk. n is the number in base R (R=D for decimal, 0 for octal). k is the number of bits required for the representation, \( k \leq 32 \). k is decimal.

Examples:

<table>
<thead>
<tr>
<th>Representation</th>
<th>Binary equivalent</th>
</tr>
</thead>
<tbody>
<tr>
<td>1D2</td>
<td>01</td>
</tr>
<tr>
<td>5D4</td>
<td>0101</td>
</tr>
<tr>
<td>20D5</td>
<td>10100</td>
</tr>
<tr>
<td>203</td>
<td>010</td>
</tr>
<tr>
<td>2006</td>
<td>010000</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

2.2 DECLARATION STATEMENTS

The general format of a declaration statement is <DT> body.

The declaration type (device) is enclosed in angle brackets and the period terminates the declaration. Body consists of a list of items separated by commas. Following devices are allowed:
Terminal

Sets of wires

Registers

Sets of synchronized flip-flops

Memory

Sets of synchronized flip-flops

Latches

Sets of asynchronous latches

Time

Clock

Delay

Delay elements

Boolean

Combinational logic

Element

Off-the-shelf components

The device type can be abbreviated to the first two characters.

Examples:

\(<\text{TE}>\) X, Y(4), Z(0:2), W(3,4:1), A(12) = B \& C(0:10)\) identifies a single wire \(X\), four wires \(Y_1, Y_2, Y_3, Y_4\) with \(Y_1\) on the left, 3 wires \(Z_0, Z_1, Z_2\) and 12 wires corresponding to \(W\), placed in 3 rows, ith row of wires numbered \(W_{i4}, W_{i3}, W_{i2}, W_{i1}\). The subscripts always have a left to right interpretation. A single subscript \(n\) indicates the range 1 to \(n\) while a range \(n:m\) indicates \(n\) to \(m\) left to right. In the above declaration, \(A_1\) is also named \(B\), \(A(2:12)\) are named \(C(0:10)\). \& is the concatenation operator. The concatenation of \(B\) and \(C\) is a 12 bit terminal \(A\) with the most significant bit same as that of \(B\) and the least significant 11 bits same as those of \(C\).

Register and Latch DECLARATIONS

\(<\text{RE}>\) IR(16) = OP(0:3) \& IX(1:3) \& ADRS(9), X(12). declares a 16 bit register \(IR\) and a 12 bit register \(X\).

\(<\text{LA}>\) BUF(4). declares a set of 4 latches BUF.
<RE> A(8).

declares an 8 bit register, bits numbered from 1 to 8, left to right.

Memory DECLARATION

<ME> M(X:Y).

declares X words (numbered from 0 to X-1) of Y bits each (numbered 1 through Y).

<ME> MF(256:8).

declares a 256 word memory, 8 bits/word.

References to the memory must be of the form M(MAR) where MAR is the same register in all references to M. MAR is declared in a RE declaration. Only full words may be accessed from memories.

Time DECLARATION

<TI> A(1E-6), Q(20E-9) $2^2$.

declares a single phase clock A with a 1 microsecond period and a two-phase clock Q with 20 nanosecond period.

<TI> P.

declares a single phase clock with an arbitrary time period (unit).

Delay DECLARATION

<DE> P(10E-9), Q(5E-7).

declares two delays P with 10 nanoseconds and Q with .5 microsecond.

The context in which the Delay element is referenced determines whether its input or output terminal is used.

Boolean DECLARATION

<BO> Identifier = Boolean expression.

Examples:

<TE> A, B(5), C(0:4), D(6, 5:1).

<BO> D(4) = B+C, D(5) = A*B.
declares that the fourth row of D is formed by ORing terminals B and C
i.e. \( D_{45} = B_1 + C_0 \) etc.) bit by bit; the fifth row of D is a bit by bit
AND of A and B. Since A is 1 wire and B is a set of 5 wires, A is fanned
out to combine with each bit of B.

**Element Declaration**

Enables the description of an element in the system whose logical
specifications are unknown or impertinent.

For example,

\[
\langle \text{EL} \rangle \ JKFF \ (Q_1, NQ_1: C, J_1, K_1), \ COUNT \ (K(5:1), \ ZERO: \ UPDWN, \ CLK).
\]

declares an element JKFF with 3 inputs C,J_1,K_1 and two output Q_1 and
NQ_1; and an element COUNT with two inputs and 6 outputs. The only
information available on these black boxes is the input/output terminals.

**2.3 Operations**

Table 2.1(a) shows the operations allowed and their hierarchy;
Table 2.1(b) shows three special operators. "=" is used to show the
connections while \(<-\) indicates a data transfer from one facility to the
other \(->\) is equivalent to a "GOTO", used to show a state transition.

The extension operator "\$" creates k copies of the terminal or
terminal set offered as its left operand.

The selection operator ", selectively complements, or not comple-
ments the bits of the facility (left hand operand) depending on the
value of the corresponding bit in kDn is a 0 or 1.
For example, $A'10D5$ is equivalent to

\[ \begin{array}{l}
1 \\
2 \\
A \\
3 \\
4 \\
5 \\
A'01010
\end{array} \]

The operator preceding the reduction operator (/) determines the nature of the reduction on the right hand operand of /. Six types of reductions are possible. For example, given a signal $A$,

$\ast/A$ implies

\[ A \]

If $A$ is a 3 bit signal,

$\ast/A'2D3$ implies

Selection

\[ \begin{array}{l}
\mathrm{A} \\
\mathrm{A} \\
\mathrm{A} \\
\end{array} \]

Reduction
Boolean expressions (Be) can be formed by using the operators and variables in the usual manner. Parathesis could be used where there is an ambiguity. The expressions are evaluated from left to right following the operator hierarchy.

Conditional operations have the format

\[ \text{!BE! OP}_1 \text{ or !BE! OP}_1 \text{; OP}_2 \]

The first form implies: If the value of BE is 1, perform OP\(_1\); the second form implies: If BE is 1, perform OP\(_1\) else perform OP\(_2\). "If ... then" operations can be nested:

\[ \text{! A ! ! B ! OP}_1 ! ! C ! OP}_2 \]

2.4 IF - VALUE CLAUSE

"." is used for "IF" and "#va" is used for the value in an IF-value clause. For example,

\[ B = \text{C #0 DO #1 D1 #2 D2.} \]

implies that DO is connected to B if the value of C is 0, D1 is connected to B if the value of C is 1, etc.

As another example,

\[ X \#0D2 A<-B \#1D2 A<-C \#2D2 A<-AB \#3D2 A<-AC. \]

describes a 4 way conditional transfer operation into A depending on the
value of X.

### 2.5 IDENTIFIER

**Identifier** declaration enables the naming of a group of operations so that they do not have to be written repeatedly (equivalent to MACROS). The general format of Identifier declaration is,

```
<ID> list
```

where `list` takes the form

- `id = compound facility`
- `id = (CSOP)`

For example, `<ID> X = C(2:10) f1` names the compound facility `f(2:10)f1` to be X. Then, any reference to X is expanded into `C(2:10)f`. For example, `S = R ◊ X` is equivalent to `S = R ◊ C (2:10) f1`.

(A compatible set of operations (CSOP) is a set of operations separated by commas. It must be possible for the hardware to perform all these operations simultaneously.)

The order in which the operations are listed is of no consequence. For example,

```
<ID> A = (Y <- X, Z <- Z(2:5) fA2(1)),
```

names two CSOPS. Note that the operations `Y <- X` and `Z <- Y` in `B` are simultaneous and are compatible.

### 2.6 OPERATOR DECLARATION

Blocks of combinational circuitry can be defined with the Operator declaration. The body of the Operator declaration consists of a **Boolean** declaration and perhaps a **Terminal** declaration. Boolean equations in the body of the **Boolean** declaration include Boolean expressions which
may involve conditions and be relatively complex. References in these Boolean equations may be made to (1) facilities global to the OPERATOR declaration. (2) local terminals declared within the OPERATOR declaration by a TERMINAL declaration, and (3) terminals declared and dimensioned in the head of the OPERATOR declaration. The TERMINAL declaration may be used to define local terminals of the operator, and must be used to dimension "dummy" identifiers listed in the heading, if any.

The head of the OPERATOR declaration consists of one or a list (separated by commas) of identifiers with or without an argument list enclosed in $s$, with or without parenthetic subscript ranges. Permitted syntactic forms for heads are:

$$id_1, id_2(1_2), id_3 \_ X_1, X_2 \ldots X_k, id_4 (1_4)$

$$X_1, X_2 \ldots X_k$$

where subscript ranges can also be placed within the parenthesis. The identifiers name the combinational logic blocks and their output terminals. Parenthetic integers dimension the output terminal sets with the same syntax and semantics as in TERMINAL declarations. The arguments are local dummy identifiers of input terminals of the combinational blocks. Such dummy identifiers must be dimensioned via a local terminal declaration within the OPERATOR body.

As an example of a time-shared operator block, ALU is declared below. This combinational block is able to add two 16-bit binary sequences presented to it on lines X and Y or form their bit-by-bit EXCLUSIVE-OR. Input signal F determines which task is performed. The carry into rightmost full-adder must also be presented to the unit.

```plaintext
<OP> ALU(16) $ X, Y, CIN, F$
<TE> X(16), Y(16), CIN, F, C(16) = CXECC(15).
```
<BO> C=XY + CCE CIN* (X+Y),
ALU = (IF! X@Y@ CCECIN; X@Y). (end of BO, end of OP)
\textbf{Note the inline comment capability of DDL (end of BO, end of OP).}

Suppose the following declaration is global to ALU,
<RE> ACC(16), MBR(16), COUNT (12).

we can define several operations using ALU as following:

\begin{align*}
\text{!LDA!} & \quad \text{ACC} \leftarrow \text{ALUSO}, \text{MBR}, 0, 0$
\text{!ADD!} & \quad \text{ACC} \leftarrow \text{ALUSACC}, \text{MBR}, 0, 1$
\text{!SUB!} & \quad \text{ACC} \leftarrow \text{ALUSACC}, \text{AMBR}, 1, 1$
\text{!KNT!} & \quad \text{COUNT} \leftarrow \text{ALU}(5:16) \ SOD4\%\text{COUNT}, 0, 1, 1$
\text{!XOR!} & \quad \text{ACC} \leftarrow \text{ALUSACC}, \text{MBR}, 0, 0$
\end{align*}

\textbf{2.7 STATE DECLARATION}

DDL views the operation sequencing (control) circuitry as a finite state machine. Each state (step) of the control circuitry is described by a STate declaration:

\textbf{<ST> State List.}

State list consists of a list of state statements (without separating commas). Each state statement has one of the following forms:

Sid (n): csop.

Sid (n): Be: csop.

Sid is a simple unsubscripted identifier. n is the decimal state assignment. csops include the state change operations using the state transition operator $\rightarrow$.

In the first form, csop is performed whenever the automaton is in the state Sid.

In the second form, csop is performed when the automaton is in Sid and also Be is satisfied. The automaton waits in the state till Be is
satisfied.

A 15 bit multiplier control can be described as following:

\[
\begin{align*}
&\text{<ST> } \text{SO(0):MPY:ACC<-O, CNT<-15D4, } \rightarrow \text{S1.} \\
&\text{S1(1): } \rightarrow \text{S2, DECR$ CNT$ !Q(15) ! ACC<-ACC+R}. \\
&\text{S2(2):SHR$ACC$Q$, } [+\text{CNT}] \rightarrow \text{S1;S0 ...} \\
\end{align*}
\]

(End of conditional, end of S2, end of ST)

\(\text{SHR}\) is shift right (zero fill) operator and \(\text{DECR}\) is a decrement operator assumed to be defined using \(<\text{OP}>\) declaration.

2.8. AUTOMATON and SYSTEM DECLARATIONS

Relatively independent disjoint portions of a digital system are identified as automata in DDL with syntax.

\(<\text{AU}>\) head body.

The \(\text{AUtomaton declaration}\) is the most complex type of declaration of DDL. Its head may take any of four forms, for example:

- \(\text{auid:}\)
- \(\text{auid:csop}\)
- \(\text{auid:Be:}\)
- \(\text{auid:Be:csop}\)

First, an automaton identifier, \(\text{auid}\), may be subscripted, but may not include parenthetical arguments; it names the block only. A compatible set of operations may be included in the head of an automaton. These operations are to be performed whenever the \(\text{Be}\) of the heading, if any, is satisfied. Conditional as well as unconditional operations may be included in this heading \(\text{csop}\), so whether a specific operation is performed or not may depend on conditions throughout the automaton or system.

\(\text{Be}\) in the heading of the \(\text{AUtomaton declaration}\) is a condition on
all operations declared throughout the body of the declaration except
connection operations. Usually $Be$ is the clock signal that synchronizes
the automaton. It is generally unnecessary and undesirable to include
such global conditions as clock signals in combinational circuits; in
fact, signal propagation in combinational networks usually precedes
clock pulses. If a clock with $n$ phases is used to synchronize an autom-
aton, then a dimensional $Be$ or a concatenation of $n$ Bes appears in place
of the single $Be$ in the A\textit{ut}omaton declaration head.

The body of an A\textit{ut}omaton declaration consists of other declarations.
Each of these declarations is terminated with its own period; punctuation
is not placed between them. The following declaration types may appear:

\begin{verbatim}
<ME>, <RE>, <LA>, <TE>
<TI>, <DE>, <OP>, <EL>, <ID>, <BO>, <ST>
\end{verbatim}

$ME$, $RE$, $LA$, $TE$, $TI$, $DE$, AND $EL$ declarations are used to declare the
existence of local facilities of the automaton. The $OP$erator and $BO$olean
declarations specify combinational blocks and interconnections of facil-
ities. The $ID$entifier declaration may be used to simplify or clarify the
overall A\textit{ut}omaton declaration. The $ST$ate declaration is usually used to
specify the operations of the automaton. If the $ST$ate declaration is not
used, then all operations appear in the $csop$ of the A\textit{ut}omaton declaration
head.

The $SY$stem declaration has syntax identical to the A\textit{ut}omaton decla-
ration. The system is identified in the head. Global conditions and
$csop$ may be specified also. The body of a $SY$stem declaration may contain
A\textit{ut}omaton declarations as well as all other types of declarations, but
$ST$ate declarations must appear within A\textit{ut}omaton declarations. Public
facilities are declared with $ME$, $RE$, $TE$, etc., declarations outside of all
Automaton or Operator declarations.

Example:

A multiplier controller is described below to illustrate the System and Automaton facilities. The counter is treated as a separate automaton. Perhaps other unspecified automaton of SYSTEM 1 can use the counter when automaton MC is not.

<SY> SYSTEM 1:

<RE> ACC(15), Q(15), R(15).
<TE> SET, DEC, DONE, MPY.
<TI> P(1E-7).
<AU> CPU: P:

<ST> ...
  ...
  ...
  Q17: DONE: Q ← Multiplier,
  R ← Multiplicand, MPY = 1.
  ...
  .. (end CPU)
<AU> MC: P:

<ST> SO: MPY: ACC ← 0, SET = 1, → S1.
  S1: → S2, DEC = 1, 'Q (15)Q ACC ← ACC+R.
  S2: ACCQ ← SHRACCQ$ !DONEI → S1 ...
<AU> K: P:

<ST> [i=1;15] T(i): DEC: →T(i-1)...
  T(0): DONE = 1, !SET! → T(15); → T(0)...

(end SY)
Automaton CPU is shown only as placing the multiplier and multiplicand in public registers and issuing command MPY to multiplier control MC. If the counter automaton K is idle, it will be issuing DONE = 1. CPU waits in its state Q17 until this condition is satisfied (perhaps K is still doing a job for some other automaton). MC clears ACC, but the counter is initialized by SET = 1. Specifically SET = 1 will cause K to go from its state T(0) to T(15) where it will remain until it is told to decrement via public terminal DEC. MC tests the multiplier, adds or not and shifts repeatedly until it is informed by K via public terminal DONE that all multiplier bits have been examined. In the example above interacting automata MC and K operate in parallel.

**NOTE:** The "For clause" shown in the Automaton K for the decrement operation \([i=1;15] T(i):\text{DEC}: \rightarrow T(i-1)\) is not allowed in the present version of the DDL software. This statement has to be broken up into;

\[
T(1): \text{DEC}: \rightarrow T(0) \\
T(2): \text{DEC}: \rightarrow T(1) \\
\ldots \\
T(15): \text{DEC}: \rightarrow T(14)
\]

SHR is a single argument operator (assumed to be declared earlier) that shifts the argument one bit right, and fills zero on the left.
**TABLE 2.1(a) : OPERATORS**

<table>
<thead>
<tr>
<th>OPERATOR</th>
<th>SYMBOL</th>
<th>TYPICAL SYNTAX</th>
<th>COMMENTS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Extension</td>
<td>$</td>
<td>A$^k</td>
<td>k copies of A</td>
</tr>
<tr>
<td>Concatenation</td>
<td>£</td>
<td>A£B</td>
<td>Bit by bit</td>
</tr>
<tr>
<td>Complementation</td>
<td>Λ</td>
<td>ΛA</td>
<td>Bit by bit complement</td>
</tr>
<tr>
<td>Selection</td>
<td>'</td>
<td>A'kDn</td>
<td>Selective complementation</td>
</tr>
<tr>
<td>Reduction</td>
<td>/</td>
<td>p/A</td>
<td>A_1pA_2p...pA_n, where p is one of these: <em>, Λ</em>, A+, ΛΩ, Ω, +.</td>
</tr>
</tbody>
</table>

| AND            | *      | A*B            | Bit by bit                                    |
| NAND           | Λ*    | ΛΛ*B           | Operations                                    |
| NOR            | Λ+    | ΛΛ+B           | Operations                                    |
| XNOR           | ΛΩ    | ΛΛΩB           | Operations                                    |
| XOR            | @      | Λ@B            | Operations                                    |
| OR             | +      | Λ+B            | Operations                                    |

**TABLE 2.1(b) : SPECIAL OPERATORS**

| CONNECTION     | =      |
| TRANSFER       | −<    |
| GO TO          | →>    |

**NOTE:** Refer to Chapter 3 (The Translator) for variations of these Operators.
3. THE TRANSLATOR (DDLTRN) [36]

DDLTRN is a program that translates a DDL description of a digital system to 1) a DDL description that consists of Boolean equations and register transfer statements in the heading of a system declaration only, and 2) a tabulation of facilities and subfacilities declared in the DDL description and/or defined in the translation process. Some modifications of DDL recognized by DDLTRN are listed below. The translation process is briefly discussed and illustrated in Section 3.1.

1) The following operators are changed to accommodate the SEL-32 peripherals:

<table>
<thead>
<tr>
<th>DDL Operator</th>
<th>Key Punch</th>
<th>CRT Terminal</th>
<th>Printer</th>
</tr>
</thead>
<tbody>
<tr>
<td>Concatenation $&amp;$</td>
<td>$&amp;$</td>
<td>[</td>
<td>[</td>
</tr>
<tr>
<td>Complement $A$</td>
<td>$\neg$</td>
<td>$A$</td>
<td>$+$</td>
</tr>
<tr>
<td>IF - THEN !</td>
<td>!</td>
<td>]</td>
<td>]</td>
</tr>
<tr>
<td>IF - VALUE !</td>
<td>!</td>
<td></td>
<td>!</td>
</tr>
</tbody>
</table>

The other operators of DDL are compatible with the peripherals of SEL-32 and remain the same.

2) Comment declarations end with a left angle bracket<.

3) Values in "If-value" clauses are limited to a single integer values. Ranges, lists and else (;) values are not permitted.

4) Concatenation operands must be simple facilities with or without subscripts, or binary strings.

5) State assignments are specified in decimal following the state identifier of each state statement, e.g., "S1(2):..."

6) Automata names are used as state sequencing register names and thus should be dimensioned in the <AU> declaration head, e.g., "<AU> CPU (5): P:..."
7) DDLTRN accepts FlAg declarations with syntax: <FlAg> list. List consists of integers, and/or integers preceded by the complement symbol (A), separated by commas. Each integer specifies the setting of a flag. Each complemented integer specifies that the corresponding flag is to be reset. Table 3.1 summarizes the significance of set flags and the default states of the flags.

8) Identifiers defined in IDentifier declarations must not be subscripted.

<table>
<thead>
<tr>
<th>Flag</th>
<th>Significance</th>
<th>Default</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Print Source Card Images</td>
<td>Set</td>
</tr>
<tr>
<td>2</td>
<td>Print Declared Facilities and Operations</td>
<td>&quot;</td>
</tr>
<tr>
<td>3</td>
<td>Print DDL string after Pass 2</td>
<td>Reset</td>
</tr>
<tr>
<td>4</td>
<td>&quot; &quot; &quot; &quot; &quot; &quot; 3</td>
<td>&quot;</td>
</tr>
<tr>
<td>5</td>
<td>&quot; &quot; &quot; &quot; &quot; &quot; 4</td>
<td>&quot;</td>
</tr>
<tr>
<td>6</td>
<td>&quot; &quot; &quot; &quot; &quot; &quot; 5</td>
<td>&quot;</td>
</tr>
<tr>
<td>7</td>
<td>&quot; &quot; &quot; &quot; &quot; &quot; 6</td>
<td>Set</td>
</tr>
<tr>
<td>8</td>
<td>Print F Table after Last Pass</td>
<td>Reset</td>
</tr>
<tr>
<td>9</td>
<td>Print Encoded string after Last Pass</td>
<td>&quot;</td>
</tr>
<tr>
<td>10</td>
<td>Execute through Pass 2 only</td>
<td>&quot;</td>
</tr>
<tr>
<td>11</td>
<td>&quot; &quot; &quot; &quot; 3</td>
<td>&quot;</td>
</tr>
<tr>
<td>12</td>
<td>&quot; &quot; &quot; &quot; 4</td>
<td>&quot;</td>
</tr>
<tr>
<td>13</td>
<td>&quot; &quot; &quot; &quot; 5</td>
<td>&quot;</td>
</tr>
<tr>
<td>14</td>
<td>&quot; &quot; &quot; &quot; 6</td>
<td>Set</td>
</tr>
</tbody>
</table>

3.1. THE TRANSLATION PROCESS

DDLTRN is the result of a research effort to develop efficient language translation algorithms. As a result it emphasizes translation
efficiency rather than error detection and control. Neither the syntax of supplied DDL descriptions nor the translation process itself are checked in detail.

A DDL description is stored as a single string in a singly linked list in memory. Operator and punctuation symbols are represented by codes. As processing proceeds facility names and subscript ranges are also encoded to shorten the string and hence the time required to pass over it.

Facts about declared facilities such as name, subscript range, type, etc. are recorded in a facility table F. Translation consists of passing over the DDL string a number of times. With each pass the DDL string and F table are modified according to unique rules. Six main passes may be identified by the user: The DDL string and F table may be printed after any of these main passes.

Pass 1 -- Facilities Identified

Data cards bearing a DDL description are read and echo printed. All blank columns are ignored; all card columns 1 - 80 are examined. Declared facilities are entered in the F table. TIme, REgister, MEmory, LAtch, TErninal and DELay declarations are removed from the DDL description, as are all COmment declarations and parenthesized comments. Identical primary names declared in nested or parallel blocks are made unique by appending a double quote ("u") and integer. Identical names declared in the same block are rejected, of course.

Pass 2 -- Syntax Reduced

Names and binary strings in connection and register transfer operations are encoded. Secondary names (names appearing on the right of an equal sign in a TErninal, REgister, etc. declaration) are replaced with
their subscripted primary name equivalents. Identifiers from IDENTIFIER declarations are replaced in operations and expressions serving as conditions on operations with the symbol string they represent. The syntax of OPERATOR, BOOLEAN and STATE declarations is removed, the connection operations being transferred to the head of the enclosing AUTOMATON or SYSTEM declaration. STATE statement syntax is replaced with "if-then" conditions on operations. OPERATOR call arguments are transformed to connection statements. Compound Boolean expressions serving as conditions on operations are replaced with terminals of unit dimension. These new terminals are connected to the Boolean expressions via connection operations inserted in the head of the enclosing AUTOMATON or SYSTEM declaration.

Pass 3 -- Conditions Distributed

"if-then" and "if-value" conditions on sets of operations are combined and distributed over the members of the set so that each operation appears as the body of a simple "if-then" clause. "Go-to" operations are converted to conditional transfers of a constant (the state assignment) to the state sequencing register (the enclosing automaton). Automaton syntax is eliminated by recognizing the global condition, if any, and distributing it as a clocking condition on all register transfer and memory operations within the AUTOMATON declaration.

Pass 4 -- Concatenation Removed

All concatenation operations except those that form operands for reduction operators are eliminated by breaking operations into operations on subfacilities formed by partitioning operand facilities according to the dimensions of the concatenation operands.
Pass 5 -- Operations Gathered

All connection and transfer operations with the same data sink (left operand) are gathered into one compound operation.

Pass 6 -- Subfacilities Disjoined

Facilities with subfacilities serving as data sinks of connection and transfer operations are broken into disjoint subfacilities and a right-hand side of a connection or transfer operation is formed for each new subfacility.

3.2 An Example

System EX1 illustrates the use of secondary names and IDentifier declarations. Registers A and D of automaton A1 are each broken into subregisters via secondary names in the REGISTER declaration. Ascending and descending subscripts are illustrated. Identifiers X, Y and Z name a new concatenation of the subregisters of D, a portion of one of these subregisters, and a NOR reduction, respectively. A register A is declared in automaton A2 also. The operations of A2 all appear in the head portion of its AUTOMATON declaration.

The listing obtained after Pass 1 summarizes the declared facilities and their relations. Since two A registers are declared in parallel blocks, the name of one is changed to A"1 so that the two may be distinguished. The declared operations are listed with indentation used to indicate the nested relations of blocks. Block structure errors would be easily identified.

Pass 2 replaces secondary names and identifiers with their primary equivalents. A careful examination of the results after Pass 2 indicates that operation A-X in state S becomes A-FVE when X is replaced. Then
secondary names are removed giving \( A + D(4:1) \oplus D(8:5) \). The operations of state T require that secondary names \( F, B, C \) and \( E \) be replaced with their primary equivalents. Then \( Z \) within "if-then" punctuation is replaced with \( \neg \wedge Y \) is replaced with \( \neg \wedge F(3:2) \) is replaced with \( \neg \wedge D(2:1) \). Note that state statement syntax is also converted to "if-then" syntax in Pass 2. A state decoder network on automaton register \( R_1 \) is prescribed by equations in the head of the SYstem declaration at this point.

Pass 3 distributes conditions over sets of operations and removes \( \text{Auto} \text{m} \text{at} \text{o} \text{n} \) declaration syntax. The results listed indicate that five internal signals named "double-quote-integer" have been formed in order to simplify the expression of conditions on operations. Each of the conditioned operations can be traced back to the source DDL description. "Go to" operations are converted to conditioned transfers to the automaton register.

Pass 4 eliminates the concatenation operations. As a first example observe that

\[
!P*S! A<-S*D(4:1) \oplus D(8:5).
\]

is broken to

\[
!P*S! A(1:4)<-S*D(4:1),
!P*S! A(5:8)<-S*D(8:5).
\]

Pass 5 gathers operations with the same left operand. The operations

\[
!P*S! A(1:4)<-S*D(4:1),
\]

are gathered to

\[
\]

No logic minimization or even simplification is performed as part of the gathering process.
In Pass 6 the A and D registers of automaton A1 are partitioned and transfer statements are developed for each subfacility. Pass 5 provides the following transfers to the A register or some part of it.

\[ \text{SAS + P}^5 \text{ A(1:4) } \leq \text{SD(4:1) } + \text{"SD(4:1).} \]

\[ \text{SAS + P}^5 \text{ A(5:8) } \leq \text{SD(8:5) } + \text{"SD(8:5).} \]

\[ \text{P}^3 \text{ A } \leq \text{"3D.} \]

The last of these operations involves the entire A register; the others involve a part of it. Pass 6 partitions the A register to A(1:4) and A(5:8), and forms the correct transfers to each of these subfacilities.

The F table as it appears after Pass 6 is listed as the final result of this example. Facility names are followed by left and right subscripts and facility dimensions. The next column indicates the type of the facility with negative entries (-1 for System, -6 for Register, -9 for Terminal, etc.). Positive entries point to the row of the parent facility. The final columns point to the beginning and ending points of facility operation statements in the DDL string.
AN EXAMPLE SYSTEM THAT EMPHASIZES SECONDARY NAMES

A

SYNTAX EX1: <II>.

<AU>A1(2):T:

<HE>A(x) = H(210) I C(5:7), U(n1) = E(4) I F(5:2).

<IL>x=tLt, t = L(3:2), L = t+t/L.

<S1> S(0):A <- x, -> T.


U(2):->S, 1Y #U2 A<-O #1U2 U<-A

#2D2 A<-x....

<AU>A2:R: A<-B, B<-A

<HE>A(24), B(24)...(END OF SYSTEM)

<TL>3, 4, 5, 6, 8.
PASSI--FACILITIES IDENTIFIED

DECLARED FACILITIES

<SY> EX1
<TI> P(1:1)
<AU> A1
<RE> A(1:8) = 0(2:0) [C(3:7)
D(0:1) = E(1:4) [F(5:2)
<ID> X(1:1)
Y(1:1)
Z(1:1)

<SI> S
T
U
<AU> A2

<WE> A"1(1:24)
A(1:24)

DECLARED OPERATIONS

0)
<SY> EX1:
<AU> A1: P:
<ST> S: A->X, ->T.

T: F<->B[C(7), E<->10D4,
]ZI ->S; ->U.

U: ->S,

Y
#0D2A<-U
#1D2D<-A
#2D2A<-X ....

<AU> A2: P: A<-H, B<-A ..
PASS2—SYNTAX REDUCED

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
\[ L = A \]

\[ S = A \]
\[ T = A \]
PASS5--OPERATIONS GATHERED

<SY> EX1: S=*/AI'002 ,
    1=*/AI'010 ,
    U=*/AI'202 ,
    "1=1*+/D(2:1) ,
    s2=1*+/U(2:1) ,
    s3=U*+/U(2:1)'002 ,
    "4=U*+/D(2:1)'102 ,
    s5=U*+/U(2:1)'202 ,
    IP+5 P="5 A(1:4)<-S*U(4:1) + 5*U(4:1) ,
    IP+5 P="5 A(5:6)<-S*U(4:5) + 5*U(4:5) ,
    IP+5 P="5 + P="2 + PU A1<-S*102 + 1*U02 + 2*G2 + U*U02 .

    IP+1 0(4:2)<-I*A(1:5) ,
    IP+1 0(1)<-I*A(8) ,
    IP+1 0(5)<-I*1004 ,
    IP+3 A<-3*U ,
    IP+3 U<-4*A ,
    IP] A"1<-B ,

PASS6--SUBFACILITIES DISJOINTED

<SY> EX1: S=*/AI'002 ,
    1=*/AI'010 ,
    U=*/AI'202 ,
    "1=1*+/D(2:1) ,
    s2=1*+/U(2:1) ,
    s3=U*+/U(2:1)'002 ,
    "4=U*+/D(2:1)'102 ,
    s5=U*+/U(2:1)'202 ,
    IP*3 + P*5 P="5 A(1:4)<-3*D(8:15) + S*U(4:1) + 5*G(4:1) ,
    IP*3 + P*5 P="5 A(5:6)<-3*D(4:1) + S*U(4:5) + 5*U(4:5) ,
    IP+5 P+"1 + P="2 + PU A1<-S*102 + 1*U02 + 2*G2 + U*U02 .

    IP*4 + P*1 0(8:5)<-4*A(1:4) + 1*1004 ,
    IP*4 + P*1 0(4:1)<-4*A(5:7) + I*A(1:3) ,
    IP*4 + P*1 0(1)<-4*A(8) + I*A(8) ,
    IP] A"1<-B ,
<table>
<thead>
<tr>
<th></th>
<th>EX1</th>
<th>1</th>
<th>1</th>
<th>1</th>
<th>1</th>
<th>-1</th>
<th>0</th>
<th>304</th>
<th>U</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>P</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-5</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>A1</td>
<td>1</td>
<td>2</td>
<td>2</td>
<td>-6</td>
<td>0</td>
<td>184</td>
<td>254</td>
<td>263</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>A</td>
<td>1</td>
<td>8</td>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>&quot;1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>213</td>
<td>0</td>
<td>222</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>&quot;2</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>233</td>
<td>0</td>
<td>245</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>D</td>
<td>8</td>
<td>1</td>
<td>0</td>
<td>-9</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>&quot;3</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>266</td>
<td>0</td>
<td>274</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>&quot;4</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>286</td>
<td>0</td>
<td>294</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>&quot;5</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>307</td>
<td>0</td>
<td>320</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>D</td>
<td>1</td>
<td>1</td>
<td>7</td>
<td>-13</td>
<td>0</td>
<td>516</td>
<td>525</td>
<td>516</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>U</td>
<td>4</td>
<td>2</td>
<td>-3</td>
<td>7</td>
<td>0</td>
<td>544</td>
<td>551</td>
<td>542</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>S</td>
<td>21</td>
<td>0</td>
<td>1</td>
<td>-13</td>
<td>0</td>
<td>158</td>
<td>0</td>
<td>163</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>T</td>
<td>22</td>
<td>1</td>
<td>1</td>
<td>-13</td>
<td>0</td>
<td>165</td>
<td>0</td>
<td>170</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>U</td>
<td>23</td>
<td>2</td>
<td>1</td>
<td>-13</td>
<td>0</td>
<td>174</td>
<td>0</td>
<td>177</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>A2</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>A&quot;1</td>
<td>1</td>
<td>24</td>
<td>24</td>
<td>0</td>
<td>0</td>
<td>324</td>
<td>335</td>
<td>332</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>A</td>
<td>1</td>
<td>24</td>
<td>24</td>
<td>0</td>
<td>0</td>
<td>333</td>
<td>334</td>
<td>336</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td></td>
<td>164</td>
<td>10</td>
<td>4</td>
<td>-17</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td></td>
<td>0</td>
<td>2</td>
<td>2</td>
<td>-17</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td></td>
<td>1</td>
<td>2</td>
<td>2</td>
<td>-17</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>-17</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td></td>
<td>5</td>
<td>6</td>
<td>4</td>
<td>-4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td></td>
<td>1</td>
<td>4</td>
<td>4</td>
<td>-4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td></td>
<td>8</td>
<td>5</td>
<td>-4</td>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
4. THE SIMULATOR (DDLSIM) [35]

DDLSIM is a program for simulating digital systems described using DDL. The simulator has a simple, powerful and completely free-format command language that provides the user with complete control over the simulation process without requiring that the DDL system description be modified. DDLSIM does very extensive error-checking of described systems, simulation control cards, and the simulation process itself. Self-explanatory messages that pin-point errors are issued.

Digital systems to be simulated are first described in DDL. This description is translated by DDLTRN into a set of Boolean equations and Register Transfer expressions. These can be used for implementation or simulation of the digital system. They, together with other data structures and tables established by DDLTRN constitute the system description required by DDLSIM. This description is pre-processed by the simulator to establish data structures and tables that permit more efficient and controlled simulation.

The original and translated DDL descriptions of a system neither contain any information for controlling simulation nor do they supply any input data for simulation. These items are supplied by a second source to DDLSIM, a simulation deck. This deck consists of simulator control declarations described using a simulator command language that is not unlike DDL. Twelve different declaration types are available for selecting options and supplying control information, parameters, and data for simulation. Every simulation job consists of:

1. processing the system description,
2. processing the simulation deck, and
3. simulation of the system.
The following notational conventions are used in subsequent sections to describe the syntax of translated DDL and to define control language syntax.

Script characters - an item of the language. Item \( a \) will be defined in terms of items \( b \) and \( y \) with notation

\[ a : b, y \]

which is read "an \( a \) is a \( b \) or a \( y \)"

\[ [ \ ] \]

- appearance of the enclosed syntactic structure is optional

\[ [ \ ]^n \]

- the enclosed syntactic structure may be repeated an arbitrary number of times or not at all.

Blanks have no significance in syntax descriptions just as they have no significance in DDL or the DDLSIM control language.

4.1 SIMULATION MODELS

As mentioned earlier, Boolean equations (BE) and Register Transfer Expressions (RTE) generated by DDLTRN constitute the system description required by DDLSIM. The models of combinational networks and registers used by DDLSIM is the subject of this section.

4.1.1 Terminals, Element Inputs, and State Terminals

The terminals, element inputs, and state terminals declared in a system are described using BEs. In addition, DDLTRN generates BEs for a number of intermediate signals. All such BEs constitute the combinational portion of a system. They are first sorted into an ordered list according to the level of their operands, i.e., if a terminal \( A \) is used in the BE for another terminal \( B \), \( A \) will appear before \( B \) in the sorted list. However, if the system contains loop(s) in its combinational portion, it is not possible to sort the equations in this
manner. In such cases the BEs constituting the loop(s) (or loop equations) are separated from other BEs. The remainder of the BEs are then sorted into an ordered list as described. Loop equations are then added to the sorted list at an appropriate point.

During simulation the combinational portion of a system is simulated at the BE level. BEs can vary from a simple sum-of-products form to the most complex and compound of forms. The BEs are evaluated in the order established by sorting with the loop equations being simulated repeatedly until their output values stabilize. Failure of a loop to stabilize after a fixed number (determined by the characteristics of the loop equations) simulations, indicates instability in the loop. In such a case a warning is issued to the user and the simulation is continued with the last computed values for the loop equations taken as their final values. Thus DDLSIM also permits the simulation of systems having loops in their combinational portion.

4.1.2 Delays

The delays declared in a system (using <DE> declarations of DDL or DDLSIM) are also described using BEs. These delays are assigned their delay time periods (Δs) using <Delay> declaration of DDLSIM (see Sec. 4.2.4). All the delay facilities are assumed to be inertial delays, i.e., an output signal(s) will assume a new value(s) Δ time units after it's input prescribes that change, if and only if the input signal prescribes that value for at least Δ consecutive time units. Unlike the BEs discussed above, the BEs for delays are not sorted in any particular order.

During simulation each delay is simulated at the BE level with specified inertial delay assigned to it's output. The new computed
value(s) for each delay is compared with its present output value(s). If they are different, a future event at Δ time units from present simulation time \( T \) is scheduled to carry out the change(s) in the output value(s). However, if the BE does not continue to prescribe the change for at least the next Δ time units, the scheduled event is cancelled and the output(s) of the delay remains unchanged.

It is possible to assign the same delay time \( \frac{t_d}{2} \) (see Sec. 4.2.2, 4.2.5) to all the BEs for the combinational portion (see Sec. 4.2.1) of the system by setting flag number 13 (see Sec. 4.2.14) In such a case all these facilities become equivalent to delays. It is important to note that the delay time assigned to these BEs is the same for all of them, irrespective of their complexity.

4.1.3 Registers

The registers declared in a system are described using RTEs. RTE consists of a Condition Expression (CE) followed by a Transfer Expression (TE). RTEs generated by DDLTRN have the following general syntax:

\[
\text{RTE} : \mid \text{CE} \mid \text{TE}.
\]

\[
\text{CE} : \text{C} \ [\text{+C}]^n
\]

Condition term \( C : C_C \ [C_L] \ [C_L^*] \)

Clock condition \( C_C : \text{global condition in the heading of an <AU> declaration of DDL, a clock declared in a <TI> declaration of DDL.} \)

Load condition \( C_L : \delta \) with \( \delta_{\omega} = 1. \) (see Sec. 4.2.1)

\[
\text{TE} : \delta + \varepsilon
\]

Load expression \( E : \varepsilon \ [\varepsilon]^n \)
Expression term $e$:  

$$C_e \cdot V_e$$

Load value $V_e$: an expression

Example:  

$$P^{*}LDX + P^{*}ORXY + P^{*}LDY | ACC + LDX^{*}X + ORXY^{*}(X+Y) + LDY^{*}Y.$$  

In the example $P$ is a clock; ACC, $X$, and $Y$ are all registers having dimensions of 24; LDX, ORXY, and LDY are terminals declared using appropriate declarations. The CE in this example has three condition terms specifying the conditions for performing different register transfers on ACC. All the register transfers in this case are carried out under the control of the same clock $P$. In the RTE for registers declared as global facilities and used in different automata, each having a separate clock or global condition, the CEs may have different clock conditions $C_C$. For each condition term $C$ in the CE, there is a corresponding expression term $e$ in the TE. When a load condition $C_L$ becomes true (logic 1) and the corresponding clock condition $C$ performs a 0-to-1 transition, the next-output value for the register is computed using the load value $V_e$ from corresponding expression term $e$. On the next 0-to-1 transition of the $C_C$, this next-output value becomes the present-output value.

During simulation CEs for all the registers are evaluated only at certain event-times (see Sec. 4.3). On a 0-to-1 transition in the value for a CE, the corresponding $E$ is evaluated and the computed value is stored as the next-output value for the register. On a 1-to-0 transition of the same CE at some future evaluation, the next-output value for the register becomes it's present-output value. In order to make simulation fast and efficient, CEs are evaluated only at event-times at which 0-to-1 or 1-to-0 transitions of clock conditions take place. It is not possible to have a 1-to-0 and 0-to-1 transitions for the same CE at the same
simulation time \( T \). It is possible to simulate asynchronous sequential systems using DDLSIM.

The simulation model used for a register is very similar to a GL (gate and latch) flip-flop. A logical OR of load conditions \( C_L \) from \( CE \) constitutes the Boolean equation for the GATE of the flip-flop, \( E \) from \( RE \) constitutes the LATCH equation for the flip-flop, and a logical OR of the clock conditions \( C_C \) from \( CE \) constitute the CLOCK of the flip-flop. (See the figure below)

4.1.4 Memories

The memories declared in a system are also described using RTEs. A \( RTE \) for a memory is similar to that for a register with an address specified for the facility \( \xi \), i.e.,

\[
\text{memory } \xi : \xi(a)
\]

address expression \( a : \) an expression

The simulation model used for memories is also similar to that used for registers. For memory-write operations the address expression \( a \) is evaluated on a 0-to-1 transition of the associated \( CE \) and the computed value is stored as the address of the memory location. On the next 1-to-0 transition of the condition expression \( CE \), the contents of the addressed location are changed to the supplied value. Memory-read operations are instantaneous, i.e., contents of the referenced memory location are fetched immediately.
4.2 SIMULATOR COMMAND LANGUAGE AND DECLARATIONS

The DDLSIM command language consists of twelve different types of declarations for supplying parameters, input data, options and other control information necessary for simulation. The language is largely free of format restrictions. Card images are scanned in turn from left to right. Any declaration may start at any point and end at any later point in the card deck. A declaration can be continued on as many cards as necessary; more than one declaration can be supplied on the same card. The start of a declaration automatically ends the previous declaration. The last declaration in a simulation deck is ended by an End-Of-File (normally a card having 'S' in the first column). In general, the order in which the declarations are specified is not important. It is possible to have more than one declaration of the same type. Everything following the vertical line character (\textbackslash) on a card is treated as a comment, and is not processed as a part of a declaration. Scanning continues on the next card. This provides the capability of having in-line comments in a simulation deck.

Each card from a simulation deck is processed sequentially by the simulator. First it is printed together with its sequence number. It is possible to suppress echo printing of the simulation deck by turning the list option off, i.e., resetting Flag 1.

Each simulator declaration has the general syntax

\[<\text{Declaration-id}> \text{ Body}\]

Each declaration begins with a left angle (\texttt{<}) followed by a Declaration-id that identifies the type of the declaration. Only the first two characters of the Declaration-id are examined by the simulator. The Declaration-id is terminated by a right angle (\texttt{>}). All declarations except the
4.2.1 Facilities

Facilities are defined here as in DDL to be any piece of hardware declared in a digital system including terminals, registers, memories, and assemblage of hardware, clocks, delays, etc. If a facility name \( \delta_n \) exceeds 8 characters, only the last 8 characters are retained. If a facility has dimension greater than one, individual elements are identified by appending a non-negative integer subscript \( S_1 \) enclosed in parentheses to \( \delta_n \). A range of elements of a facility is identified by using a DDL subscript range, i.e., \( \delta_n(S_1 : S_2) \). A script letter \( \delta \) will be used to represent a facility or a part of it.

\[
\delta : \delta_n(S_1 : S_2), \delta_n(S_1), \delta_n
\]
where

\[
\delta_n(S_1) = \delta_n(S_1 : S_1)
\]

\[
\delta = \delta_n(S_2 : S_2)
\]

\( S_\ell \) = subscript for leftmost element of \( \delta_n \).

\( S_\ell \) = subscript for rightmost element of \( \delta_n \).

Facility width \( \delta_w \) of a facility \( \delta \) is defined as the total number of elements in it, i.e.,

\[
\delta_w = \max(S_1, S_2) - \min(S_1, S_2) + 1
\]

During simulation one machine word is used to store the values of facility \( \delta \). The SEL 32 machine has 32 bits per word. Hence it is necessary that the facility width \( \delta_w \) for any facility \( \delta_w \) in the system not exceed 32, i.e., \( \delta_w \leq 32 \). However, \( S_\ell \) and \( S_\ell \) may have larger values; only their difference is restricted.

A facility list \( \xi_\delta \) is defined as a list of facilities \( \delta \) separated by commas, i.e.,

\[
\xi_\delta : \delta[\delta]^n
\]
Whether a specific facility can be used in a facility list for a specific type of declaration is determined by both the type \( \xi \) of the facility and the type of the declaration. The following facility types exist for DDL SIM.

\[ \xi \in \{ \text{System clock, Register, Memory, Terminal, System delay, Element input, Element output, State terminals, Trigger, Simulation delay, Simulation clock, List name} \} \]

Every facility \( \xi \) used in a DDL SIM declaration must satisfy exactly one of the following conditions:

1. \( \xi \) is declared in the DDL description of the system.
2. \( \xi \) is declared during the present simulation run using a \(<\text{Clock}>, <\text{Delay}>, <\text{Trigger}>, \text{or} <\text{List}> \) declaration. The type of declaration in which \( \xi \) appears determines its type \( \xi \), which cannot be changed for the remainder of the simulation job.
3. \( \xi \) is declared during any previous simulation run as discussed in 2 above.

4.2.2 Numbers and Data Lists

\[ T_{\text{MAX}} \] - a decimal integer having the value \((2^{31} - 1)\).

\[ P_{\text{MAX}} \] - a decimal integer having the value \((2^{16} - 1)\).

\[ n_{i,j} \] - a decimal integer \( n \) in the range \( i \leq n \leq j \) where \( i \) and \( j \) are each non-negative decimal integers. Whenever \( j \) is not specified \( j = T_{\text{MAX}} \) is assumed; whenever \( i \) is not specified \( i = 0 \) is assumed.

\[ n_{i,j}^P = n_{i,j} \] enclosed in parentheses
R - Repeat factor, a positive decimal integer

\[ R = n_1 \]

A repeat factor \( R \) can be used before a data value or parameter value, i.e.,

\[ R \times \text{value}, \]

to indicate that the same value is to be repeated \( R \) times in the list.

\( T \) - Simulation time

\[ T = n \]

\( t_d \) - Default time period

\[ t_d = n_1, P_{\text{MAX}} \]

Data is described with the following syntactic structures.

\( d_B \) - a binary digit

\[ d_B : 0, 1 \]

\( d_0 \) - an octal digit

\[ d_0 : 0, 1, 2, 3, 4, 5, 6, 7 \]

\( d_D \) - a decimal digit

\[ d_D : 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 \]

\( d_H \) - a hexadecimal digit

\[ d_H : 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F \]

\( d_G \) - a general digit excluding the hexadecimal digits B and D.

\[ d_G : 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, C, E, F \]

\( B \) - a binary number

\[ B \ [\pm, \cdot] d_B [d_B]^n, \ (\pm, \cdot) d_B [d_B]^{d_B} \]
0 - an octal number

\[ 0 : [+,-]0d_0 [d_0]^n, ([+,-]0d_0 [d_0]^n) \]

\( D \) - a decimal number

\[ D : [+,-]Dd_p [d_p]^n, ([+,-]Dd_p [d_p]^n) \]

\( H \) - a hexadecimal number

\[ H : [+,-]Hd_h [d_h]^n, ([+,-]Hd_h [d_h]^n) \]

\( N \) - a binary, octal, decimal or hexadecimal number.


Optional leading minus signs (-) before any of above five types of numbers specifies the 2's complement of the number. 1's complement encoded negative numbers are obtained by setting Flag 10 (see Sec. 4.2.13).

\( N_2 \) - Data value

\[ N_2 : B, 0, D, H, N, \]

\( N_1 \) - Data spec

\[ N_1 : [R=] N_2 \]

\( \ell_d \) - a data list consisting of data specs separated by commas.

\[ \ell_d : N_1 [N_1]^n \]

Whenever a data value is specified as a number \( N \) without leading radix specification, the default radix is used for computing the value of number. The default radix of 8 (octal) can be changed to 2 (binary), 8 (octal), 10 (decimal), or 16 (hexadecimal) by setting flag numbers 2 thru 5 (see Sec. 4.2.14 respectively. Resetting these flags returns the radix to the default value of 8 (octal).

4.2.3 <Clock> Declarations

This declaration provides a means for specifying or changing the time period, pulse width and phase of clock facilities. It also permits users to declare new clocks to be used to control simulation input and
output activities. Syntax for this declaration is as follows:

```xml
<Clock> Body

Body : [\ell/, \ell]\n
List \ell : \ell_c/\ell_t

Clock list \ell_c : \ell_0, where

Facility type \ell : system clock, simulation clock

Time list \ell_t : \ell[t, t]^n

Time spec \ell : [R*] P [W[\theta]]

Time period P : \frac{P}{2}, \text{MAX}

Pulse width W : \frac{W}{P-1}

Phase \theta : \frac{W}{P-1}

Example: <CL> CLOCK1(1:5), CLOCK2/2*100(30) (50)/,
         CLOCK1(6:10), CLOCK3/100,100(30)/
```

Time period $P$ - the $P$ field specifies the time period of a clock. In the above example each clock has a time period of 100 in some arbitrary units.

Pulse width $W$ - This is an optional field specifying the time $W$ for which a clock remains at logic 1 during any clock period $P$. For the remaining time $(P-W)$ the clock remains at logic 0. When the pulse width is not specified along with the time period, the following default value $W$ is used.

$$W = \lfloor P/2 \rfloor$$

In the example a pulse width of 30 units is supplied for both CLOCK(1:5) and CLOCK2. CLOCK3 is assigned a pulse width of 30 units.

No pulse width is explicitly specified for CLOCK1(6:10), hence a default value of $\lfloor 100/2 \rfloor = 50$ units is used as the pulse width.

Phase $\theta$ - At the start of a simulation run, i.e., $T = 0$ a clock with a
period $P$ and the pulse width $W$ is set to start at logic 0. It remains at logic 0 for the next $(P-W)$ time units; then a 0-to-1 transition takes place. For the next $W$ time units, it stays at logic 1; then a 1-to-0 transition takes place and the cycle is repeated. The occurrence of the first and every subsequent 0-to-1 transition can be advanced relative to the starting of simulation by specifying the phase $\theta$.

1. For phase $\theta < P - W$, a clock starts at logic 0 and has its first 0-to-1 transition at $(P-W-\theta)$ time units after the start of simulation.

2. For phase $\theta = P - W$, a 0-to-1 transition takes place at $T = 0$.

The default value for $\theta$ is zero. In the example a phase of 50 units is specified for CLOCK1(1:5) and CLOCK2. Since no phase specification is given for CLOCK1(6:10) and CLOCK3, $\theta = 0$ is assumed for them. Waveforms for these clocks are shown below. Note that it is necessary to specify pulse width $W$, if it is desired to specify phase $\theta$.

During a simulation run, none of the parameters, $P$, $W$, and $\theta$ can be respecified for a clock facility. These parameters remain effective in all subsequent runs until respecified.

CLOCK1 (1:5)

\[ P = 100, W = 30, \theta = 50 \]

CLOCK2

\[ P = 100, W = 30, \theta = 0 \]

CLOCK1 (6:10)

\[ P = 100, W = 50, \theta = 0 \]

CLOCK

\[ P = 100, W = 30, \theta = 0 \]

\[ 0 \quad 20 \quad 50 \quad 70 \quad 100 \quad 120 \]
As mentioned earlier this declaration allows new facilities to be declared as simulation clocks. Since these clocks cannot affect the activity within the system itself, they are a source of periodic signals which can be used to control input, reinitialization, output, etc., during simulation. They can be used in realizing signals with complex waveforms that are needed to control various activities during simulation. Simulation clocks may also be used as sources of input signals to the networks being simulated.

Each facility \( \mathbf{c} \) from clock list \( \mathbf{c} \) is assigned parameters \( \mathbf{t} \) from associated time list \( \mathbf{t} \). Insufficient or excess data in time list \( \mathbf{t} \) will result in a non-fatal error (see Sec. 4.4 for errors). In the case of insufficient data, default parameters are assigned to facilities remaining in \( \mathbf{c} \).

4.2.4 <DElay> Declarations

This declaration provides a means for specifying delay time \( \Delta \) for delay facilities. Syntax for this declaration is very similar to that of the <Clock> declaration.

\[
\text{<DElay> Body}
\]
\[
\text{Body} \quad [\ell/,]^{n} \ell [/]
\]

- list \( \ell : \mathbb{E}_{d}/\mathbb{E}_{t} \)
- Delay list \( \mathbb{E}_{d} : \ell_{0} \) where
- Facility type \( \mathbb{E}_{f} : \text{system delay, simulation delay} \)
- Time list \( \mathbb{E}_{t} : \ell_{t}^{[*,\ell]}^{n} \)
- Time spec \( \mathbf{t} : [R^{+}]\Delta \)
- Delay time \( \Delta : n_{1} \)

Example: \(<\text{DElay}> \text{DELAY1}(1:2), \text{DELAY2}, \text{DELAY1}(3:5)/2*100,50/\)
DELAY1(1:2) and DELAY2 are each assigned a delay time of 100 units.
DELAY1(3:5) is assigned a delay time of 50 units.

All the delay facilities are assumed to be inertial delays, i.e., an output signal(s) will assume a new value(s) \( \Delta \) time units after its input signal prescribes that change, if and only if the input signal prescribes that new value for at least \( \Delta \) consecutive time units. As an example of inertial delay assume that waveform A below serves as the input signal to both DELAY1(1) and DELAY1(3). Waveforms B and C represent the actual output of DELAY1(1) and DELAY(3) respectively.

\[
\begin{align*}
A & \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \\
B & \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill A = 100 \\
C & \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill \hfill A = 50 \\
\end{align*}
\]

Delay time period \( A \) can not be respecified within a simulation run. Once specified, \( A \) remains effective in all subsequent simulation runs until respecified.

Like the <Clock> declaration, this declaration also allows a user to declare new delay facilities that may also be used for controlling various activities during simulation.
Every delay facility from $\ell_d$ is assigned, in turn, delay times from the associated time list $\ell_c$. Insufficient or excess data in $\ell_c$ will result in a non-fatal error. In the case of insufficient data, the default delay time (4.2.5) is used for remaining facilities in $\ell_d$.

4.2.5 Default Values for Clock Parameters and Delay Times

Before any simulation can be performed, it is necessary to assign clock parameters to every clock facility and delay time to every delay facility. Values specified through <Clock> and <Delay> declarations are used for specified facilities. For the remaining clock and delay facilities, default values are used. A default time period $\ell_d$ is used in determining the default values.

1. Default clock parameters
   
   Default time period $P = \ell_d$
   
   Default pulse width $W = \lfloor\ell_d/2\rfloor$
   
   Default Phase $\theta = 0$

2. Default delay time period $= \lfloor\ell_d/2\rfloor$

   At the start of a simulation job $\ell_d$ is set to a value of 2. If any <Clock> or <Delay> declaration is encountered in the simulation deck, the value $\ell_d$ is changed to

   $\ell_d = \min(P, 2A)$ where $P$ is any clock period specified, if none $P = 2$, and $A$ is any delay time specified, if none $A = 1$.

4.2.6 <Initialize> Declaration

This declaration provides a means for initializing the output value(s) of delays, registers, memories, element outputs, primary input signals, terminals and triggers with delays. Syntax for this declaration is as follows:
<INInitialze> Body

Body : \([l/l]^n \ell[l]

List \ell : \ell_r/\ell_d

Initialize List \ell_i : \ell_d where

Facility type \ell_o : system delays, simulation delays, registers,
memories, element outputs, primary inputs,
terminals, and triggers with delays.

\ell_d : Data list (see Sec. 4.2.2.)

Every facility \ell from \ell_d is initialized to a specified value
obtained from the associated \ell_d. Insufficient or excess data in \ell_d
will result in a non-fatal error. If data in \ell_d is insufficient,
remaining facilities from \ell_i are initialized to default values.

EXAMPLE: <IN> INPUT, MEM(0:1023)/B1011,1024*0/

INPUT (declared as register having width 4) is initialized to the binary
value 1011 and the first 1024 locations of MEM are all initialized to 0.

Before any simulation can be performed during a run, it is necessary
to define output values or initialize all the facilities. For all the
facilities initialized through an <INInitialze> declaration(s), specified
values are used. For remaining facilities initial values are determined
as follows:

1. Delays, Registers, Element outputs, Primary inputs, Terminals, or
   Triggers with delays are all initialized to zero.
2. Memory locations are not initialized at all. They will have the
   same contents as at the termination of previous simulation run.
   For the first simulation run their contents are unpredictable.
3. Initial values for Terminal, Triggers, and Element inputs without
delays are determined by using initial values for other facilities
and simulating the system at $T = 0$.

4.2.7 <REad> Declarations

This declaration provides a means for establishing input data values for various facilities. Syntax for this declaration is as follows:

\[
\text{<REad> \ Body \ Body : } [L_1, L_2, \ldots, L_n] \\
\text{List} \quad L : m/L_4/L_d \\
\text{Mode} \quad m : X, Y, Z \\
\text{Triggered or Mode,} \quad X : \delta \text{ where } \delta_w = 1 \\
\text{Periodic or Mode,} \quad Y : P[\theta] \\
\quad \quad \text{Period } P : n_1, P_{\text{MAX}} \\
\quad \quad \text{Phase } \theta : n_0, P \\
\text{Specific Time or Mode } Z : n \\
\text{Read List} \quad L_m : \ell_6 \text{ where} \\
\text{Facility type} \quad \delta_x : \text{ registers, system delays, simulation delays,} \\
\quad \text{memory locations, element outputs, terminal} \\
\quad \text{or triggers or element inputs with delays} \\
\text{Data List} \quad L_d : \text{ same as in <INitialize>} \\
\text{Example: } \text{<TR> \ TR/EXINP+EXBIN1/ (see Sec. 4.2.15)} \\
\quad \text{<CL> \ P/100(30)/} \\
\quad \text{<RE> \ TR/INPUT/1,2,3,4,-5/} \\
\]

As shown in the syntax, the READ operation may be carried out in three different modes:

1. Mode $X$ -- Triggered Mode

In this mode a 0-to-1 transition of the triggering signal establishes a new set of input values, obtained sequentially from the associated data
list $\ell_d$, for the facilities specified in the associated read list $\ell_A$.

At any simulation time input values are established before any other simulation activity except for updating of clocks and delay outputs. Hence, if the triggering signal itself is not a clock or delay facility, input values will be established at a time later than the actual 0-to-1 transition time of the triggering signal. In fact they are established at the next event time.

2. Mode $Y$ -- Periodic Mode

This mode provides an easy means for establishing input values periodically. $P$ specifies the time period for performing the READ operation. The first READ operation is performed at $T = P$, the next at $T = 2P$, and so on. However, the first and all subsequent READ operations may be advanced relative to the beginning of simulation i.e., $T = 0$, by optionally specifying the phase $\theta$. Thus, in the case of $P = 100$, and $\theta = 30$, the first READ operation will be performed at $T = 70$ (advanced by 30), the the next at $T = 170$, and so on. When $\theta = P$, the first READ operation is performed at $T = 0$. This is equivalent to initializing the associated facilities using an <Initialize> declaration.

In all cases except for $P = 1$, an identical periodic READ operation can be obtained using a clock with period $P$, any valid pulse-width $W$ and appropriate phase $\theta$ as a triggering signal in mode $X$.

3. Mode $Z$ -- Specific Time Mode:

In this mode the READ operation is performed only once at the specified time.

In Mode $X$ and Mode $Y$ READ operations, data values are supplied in sets. The first set of values are used for the first READ operation,
and the next set is used for the second READ operation. These sets are not separated by any special delimiter. Instead they are grouped in the form of a single data list \( \ell_d \). In Mode Z only one set of data values are necessary.

4.2.8 <LOad> Declarations

This declaration provides a means for establishing the same input values repeatedly on specified facilities. Syntax for this declaration is as follows:

<LOad> Body

Body : same as in the <REad> except that the Load list \( \ell_l \) is used in place of the Read list \( \ell_r \).

Three modes of LOAD operation function in the same way as the three modes of READ operation. The only difference between LOAD and READ operations is the input data values used during successive operations. In the case of READ operations, a new set of data values is used for each successive operation. The LOAD operation uses the same data set repeatedly, requiring only one set of data values. This peculiar property of the LOAD operation provides an easy means for establishing identical conditions in the system at desired times. If the READ operation were used to achieve the same results, the same data set would have to be repeated for every occurrence of READ operation. The Mode Z or specific time LOAD operation is identical in all respects to the Mode Z READ operation.

The three modes available for READ and LOAD operations give a high degree of freedom in setting up data sets in an efficient manner. Each of these modes may be used more than once. More than one mode may be used in a simulation. All the data lists \( \ell_d \) specified in <REad> and
<LOAD> declarations are transferred to an incore buffer (if necessary to a disk data file) and retrieved from there whenever needed. This facility of having multiple input streams for simulation is very helpful to the user.

More than one READ and/or LOAD operation may take place at the same simulation time. Simultaneous operations may attempt to establish input values on the same facilities. As long as they do not attempt to establish conflicting values, simulation will proceed, otherwise a fatal error condition results in an immediate termination of the current simulation run. A similar situation may arise with <INITIALIZE> declarations. In this case remaining declarations for the simulation run are processed before terminating that simulation run. This fatal error condition may be avoided by setting Flag 12 (see Sec. 4.2.14).

The following order is used in performing various input operations during simulation:

1. Periodic READ
2. Specific Time READ
3. Periodic LOAD
4. Specific Time LOAD
5. Triggered READ
6. Triggered LOAD

If more than one operations of the same type and same mode take place at the same time, they are performed according to their order in the simulation deck. This is one case in which the order of declarations may be important.

Insufficient data to complete a READ or LOAD operation during simulation will result in an immediate termination of the run. This
provides a means to terminate a simulate run without using the <Stop> declaration.

4.2.9 <Output> Declarations

This declaration provides a means for printing the values of various facilities at various instants during simulation. Syntax for this declaration is as follows:

<Output> Body

Body : [\ell_1, \ell_2, ..., \ell_n]

List
\ell : m/\ell_0

Mode
m : X, Y, Z

Triggered or Mode X
: \ell where \ell \ell_\ell = 1

Periodic or Mode Y
: P[\theta]

Period
P : n_1, P_{MAX}

Phase
\theta : n_0, P

Specific Time or Mode Z
: n

Output List
\ell_0 : \ell where \ell \ell_\ell \neq \text{memory}

Like <Read> and <Load> declarations, this declaration has three modes of operation. Values are printed when a specific output operation takes place. It is important to note that in the case of triggered or Mode X output, 0-to-1 transition of the triggering signal causes the output values to be printed at the same time rather than the next event time as in case of READ or LOAD operations. This is due to the fact that output operations are performed after all other operations in a simulation step. More than one <Output> declarations may be specified. Any combination of the three <Output> modes may be used.

Values are normally printed in an octal format. They may be printed
in binary, octal, decimal or hexadecimal by setting the appropriate flag number from 5 to 9 (see Sec. 4.2.14). All values are printed in the same format.

Output formatting is done by the simulator with the objective of maximizing the total no. of facilities than can be printed. If one or more output operations occur at a simulation time only a single line of output is printed. The first entry in each line printed is the simulation time in decimal. Values for each facility specified in any output lists are printed in fixed columns. Facilities are allocated columns from left to right in the following way:

1. Triggered or Mode X OUTPUT lists
2. Periodic or Mode V OUTPUT lists
3. Specific time or Mode Z OUTPUT lists

If more than one lists of a mode are specified, they are allocated columns in the order of their specification in the simulation deck. If output values for all specified facilities cannot be printed due to lack of room, excess facilities are ignored and a message listing them is printed. Output values for two neighboring facilities are always printed. Output values for two neighboring facilities are always separated by at least one blank column. A heading of the names of the facilities along with the subscript(s), if necessary, whose values appear below is printed on alternate pages of the simulation report. If a complete facility is included in \( \xi \), no subscripts are printed in the heading. When the value of a partial facility is to be printed, a subscript range is included in the heading. The name of a facility is normally printed in a horizontal format in the heading. A vertical format (in a column) is used if doing
so saves room on output line. A subscript range is indicated by two sub-
scripts separated by a colon (:) .

Whenever an output operation occurs, only the output values for fa-
cilities from the associated output list $\ell_0$ are printed. Other columns in the line are left blank. This tends to increase the readability of results. This feature of multiple output lists with each list having its own output control may be used to make simulation reports look more in-
formative. If the output values for one group of facilities change less frequently than those of another group, both groups can be printed with different periods. Such an output will clearly illustrate the actual activity within the system.

4.2.10 <Dump> Declarations

This declaration provides a means for dumping the contents of specified memory locations at various instants during simulation. Syntax for this declaration is given below:

\[\text{Dump} \text{ Body} \]

\textbf{Body} : same as for <Output> except $\ell_x : \text{memory}$

A DUMP operation functions in a manner identical to the OUTPUT operation. The print format is different, however. First, values for each specified memory facility are printed separately. For each facility, the first line printed indicates the facility name, locations dumped and simulation time. Following this line a heading that separates addresses and contents of locations is printed. One or more lines of DUMP output follows. In each line the first entry represents the octal address of the first location in the line. The rest of the line contains the octal contents of the next eight locations. Various DUMP operations are carried out in the following order:
1. Triggered or Mode X DUMPS
2. Periodic or Mode Y DUMPS
3. Specific time or Mode Z DUMPS

DUMP operations are performed before any OUTPUT operations within a simulation step.

4.2.11 \texttt{<STop> Declarations}

This declaration provides a means for stopping or terminating a simulation run at a specified simulation time or on a 0-to-1 transition of a triggering signal. Syntax for this declaration is as follows:

\begin{verbatim}
<STop> Body
Body : m[\_m]^n
Mode
m : X, Z
Triggered or Mode X : \_\_ where \_M = 1
Specific Time or Mode Z : n
\end{verbatim}

It is clear from the syntax that more than one triggering signal or specific time may be specified to stop the simulation. More than one \texttt{<STop>} declarations may be specified. In any case the occurrence of a first stop event will cause the simulation for that run to be terminated. At a given simulation time stop events are simulated after all other events have been simulated. If no \texttt{<STop>} declaration is supplied for the current simulation run stop events, if any, from a previous simulation run are used for the current run.

Insufficient data to complete a READ or LOAD operation will result in an immediate termination of the simulation run. This condition is described as "END-OF-FILE ON INPUT." If one is sure of EOF terminations, \texttt{<STop>} declarations may be omitted altogether. Whenever simulation is
stopped or terminated a message describing the reason for termination
(a stop event or EOF on input) is printed and the simulator moves to the
next simulation run. At the end of all simulation runs an "END OF
SIMULATION" message is printed.

4.2.12 <List> Declarations

When a list of same facilities \( \ell_6 \) is used in a number of different
declarations, it is convenient to identify the entire list with a single
name. This name can then replace the list of facilities in all of the
declarations. This is achieved by using a <List> declaration. This
declaration provides a means for assigning a unique name to a list of
facilities. Syntax for this declaration is as follows:

\[
\begin{align*}
\text{<List>} & \quad \text{Body} \\
\text{Body} & \quad : [\ell / , ]^n \ell [/] \\
\text{List} & \quad : \ell / \ell_6 \\
\text{List Name} & \quad : \ell \quad \text{where } \ell_w = 1
\end{align*}
\]

A list-name can be included in the facility list \( \ell_6 \) for a declaration
only if the list of facilities identified by it can be directly used
there. It is also possible to use list-names in defining new list-names.
Nesting of list-names can be done up to any desired level. List recursion,
i.e., using a list-name in defining itself, is not permitted. Once de-
clared for a simulation run, list-name cannot be redefined in the same
run.

For large systems, use of list-names will result in reduction of data
structure storage space. List-names are most commonly used in <REad> and
<LOad> declarations since it is necessary to respecify these declarations
for each simulation run, if a <REad> or <LOad> declaration requires a
long facility list, it is very worthwhile to assign a list-name to these facilities and use the list-name in their place.

4.2.13 <Simulate> Declarations

As discussed earlier this declaration is used to separate different simulation runs in a simulation job. Syntax for this declaration is very simple:

<Simulate>

On encountering a <Simulate> declaration, simulation is performed for current run. If this simulation is terminated normally i.e., through a <Stop> command or EOF on input condition, processing for the next run is initiated. If the termination is abnormal, the entire simulation job is terminated. Declarations and parameters effective during one run are carried over to the next run as described below. Modifications and additions are easily made with appropriate declarations.

1. Parameters for clock and delay facilities remain effective from one simulation run to the next; any parameter may be changed by using the appropriate declaration. New clocks and delays may also be declared.

2. Trigger expressions remain unchanged from run to run unless they are respesified. New trigger facilities may be declared for a simulation run.

3. <Read> or <Load> declarations do not carry from one run to the next. <Read> and <Load> declarations must be respesified for each run or replaced with new declarations.

4. <Output>, <Dump>, and <Stop> declarations are carried from run to run. However, supplying one of these declaration with a specified mode (X, Y, or Z) will nullify all declarations from previous run
of that type and mode.

5. All flags are carried from run to run. Flags can be changed in any way by including a new <Flag> declaration.

6. Lists are carried from run to run. If it is necessary to redefine a list the new definition must be declared before the list is used directly or indirectly in any declaration for the current run.

4.2.14 <Flag> Declarations

This declaration provides a means for selecting various options for simulation runs by setting or resetting associated flags. A flag number is associated with each option. Syntax for this declaration is as follows:

```
<Flag> Body

Body : $V_o \ [\ [- ]\ F\ ]$
```

Option Value $V_o$ : [-] F

Flag Number $F$ : $n_{1,14}$

If the flag number $F$ is not preceded by a complement sign (-), the associated option is set, otherwise it is reset. An option may be set or reset as many times as desired. The Flag table provides a description of the option controlled by each flag number and the default value for the option. As shown in the table flag numbers 2 thru 5 are used to select the radix for input data. This option applies only to data values not having any explicit radix specification (see Sec. 4.2.2). Data values having explicit radix specifications are interpreted accordingly. If more than one of these options is set, only the last set option is used, i.e., <FL> 2, 4 is equivalent to <FL> 4. Moreover, resetting any of these options brings the default radix specification to its default value of 8 (octal). Similar action is taken for output format selection flags 6 thru 9.
### FLAG TABLE

<table>
<thead>
<tr>
<th>Flag</th>
<th>Significance</th>
<th>Default</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Print source card images</td>
<td>Set</td>
</tr>
<tr>
<td>2</td>
<td>Binary data input</td>
<td>Reset</td>
</tr>
<tr>
<td>3</td>
<td>Octal data input</td>
<td>Set</td>
</tr>
<tr>
<td>4</td>
<td>Decimal data input</td>
<td>Reset</td>
</tr>
<tr>
<td>5</td>
<td>Hexadecimal data input</td>
<td>Reset</td>
</tr>
<tr>
<td>6</td>
<td>Binary output format</td>
<td>Reset</td>
</tr>
<tr>
<td>7</td>
<td>Octal output format</td>
<td>Set</td>
</tr>
<tr>
<td>8</td>
<td>Decimal output format</td>
<td>Reset</td>
</tr>
<tr>
<td>9</td>
<td>Hexadecimal output format</td>
<td>Reset</td>
</tr>
<tr>
<td>10</td>
<td>Use 1's complement notation</td>
<td>Reset</td>
</tr>
<tr>
<td>11</td>
<td>Write processed system to file</td>
<td>Reset</td>
</tr>
<tr>
<td>12</td>
<td>Do not abort on &quot;conflicting inputs&quot; error</td>
<td>Reset</td>
</tr>
<tr>
<td>13</td>
<td>Simulate comb. portion of the system with delay</td>
<td>Reset</td>
</tr>
<tr>
<td>14</td>
<td>Not used</td>
<td></td>
</tr>
</tbody>
</table>

#### 4.2.15 <TRigger> Declarations

As discussed earlier, a triggering signal is used to control triggered or mode X READ, LOAD, OUTPUT, DUMP, and STOP operations. Any element of a declared facility, except a list-name, may be used as the triggering signal for these operations. Appropriate triggering signals to control the simulation may not be available in the DDL description of a system. The <TRigger> declaration provides a means for declaring new facilities that can be used as triggering signals to control simulation.
without requiring that the DDL system description be modified. The syntax for this declaration is as follows:

\[
\text{<Trigger>} \quad \text{Body}
\]

\[
\text{Body} : \ [t_e, t_e \ [ ] ]
\]

Trigger expression \( t_e \) : \( t_0 / E \)

Trigger facility \( t_0 \) : \( \delta \) where \( \delta_0 = 1 \)

Expression \( E \) : an expression

Example: \( \text{<TR>} \quad \text{TR/EXINP+EXBIN1} \)

The expression \( E \) in the above syntax is a logical expression which can vary from simple sum-of-products form to the most complex and compound of forms. It defines the associated trigger facility \( t_0 \). A trigger facility may be used in defining other trigger facilities.

Looping or trigger facilities, i.e., using a trigger facility directly or indirectly to define itself, is not permitted, however. In the example trigger TR is defined as the logical OR of EXINP and EXBIN1. Both EXINP and EXBIN1 have been declared to be states of an automaton. The automaton waits in each of these states for data from an input device. The input device can be simulated using a triggered \(<\text{Read}>\) operation with TR as the triggering signal as shown in the example in Sec. 4.2.7.

A trigger facility cannot be redefined during a simulation run. The definition of a trigger facility remains effective in all subsequent runs until respecified. A trigger facility may be assigned a delay time \( \Delta \) using a \(<\text{Delay}>\) declaration. Similarly a delay declared during simulation may also be defined using a \(<\text{Trigger}>\) declaration. For such facilities, both the delay time \( \Delta \) and the expression \( E \) remain effective in subsequent runs until respecified.
4.3 SIMULATION ALGORITHM

DDLSIM is a table-driven, event-oriented simulator. Time is treated as a discrete quantity and advanced from event time to event time where the following actions are considered by the simulator to be events:

1. Zero-to-one transitions of clocks. During these events data input signals to registers and memories are sampled, and next values of register and memory contents are computed and saved.

2. One-to-zero transitions of clocks. During these events register and memory contents are updated to new values.

3. Delay lines taking new values.

4. Simulator input, output and control events.

The simulator maintains a list of events to be executed in the future. Simulation is performed only at event-times. The simulation clock is always stepped from one event-time to the next event-time, no simulation being performed for the intermediate time interval. The absence of any event during these intermediate time intervals implies that no change is taking place in the system. For each event-time tests are performed to establish the need for simulation. Simulation is performed at event-time only if needed. A periodic event causes a future event to be scheduled.

Event time simulation makes the units used for time specification unimportant. Any arbitrary units can be used. The number of events simulated and not the number of time units elapsed determine the computer time consumed by a simulation run. Since the largest integer handled by the SEL 32 machine is \((2^{32}-1)\), it is necessary to keep the simulation termination time within this limit. It is suggested that smaller
time periods be used for long simulation runs to avoid overflow of the simulation clock.

At a given event-time various events, if present, are processed in the following order:

1. Zero-to-one transitions of clocks
2. One-to-zero transitions of clocks
3. Change of output values for delays
4. Periodic or Mode Y READ operations
5. Specific time or Mode Z READ operations
6. Periodic or Mode Y LOAD operations
7. Specific time or Mode Z LOAD operations
8. Periodic or Mode Y DUMP operations
9. Specific time or Mode Z DUMP operations
10. Periodic or Mode Y OUTPUT operations
11. Specific time or MODE Z OUTPUT operations
12. Specific time STOP operation

After processing these events different simulations steps, if necessary, are performed in the following order:

1. Triggered or Mode A <REad> operations are completed
2. Triggered or Mode A <LOad> operations are completed
3. If there were any new one-to-zero transitions of clocks declared in the DDL description or combinational clocks, i.e., signals generated using combinational logic and used as clocks for registers, output values for affected Registers or memory locations are changed to their new values.
4. If necessary, the combinational portion of the system is simulated. If any new one-to-zero transitions of combinational clocks are detected, Step 3 and 4 are repeated until no more one-to-zero transitions occur.

5. If any one-to-zero transitions of system clocks or combinational clocks were registered, new output values are computed and saved for affected registers and memory locations.

6. If necessary, delays are simulated to compute new future output values.

7. Triggered or Mode X DUMP operations are completed

8. Triggered or Mode X OUTPUT operations are completed

9. Triggered or Mode X STOP operations are completed

This procedure is repeated until the simulation is terminated.
4.4 ERRORS

DDLSIM performs very extensive error checking. On detection of an error, an error message is printed. Whenever possible an attempt is made to pin-point the error. Error messages are printed in one of the two formats discussed below.

1. Error messages which can be associated with a card in the simulation deck resulting from syntax errors are printed in the following format. The card containing the error is printed (if not already printed) with a vertical bar (|) placed under the column containing the error or the column next to the item containing error. A dotted line starting from the column next to vertical bar (|) and terminating with the error message on right end of the page is printed.
Example: <CL> CLOCK1 (185) CLOCK (6:10)/2*100/
|..........................INVALID DELIMITER

Processing of the remainder of the declaration and the simulation deck is continued by skipping to an appropriate position in the declaration.

2. Errors which cannot be easily associated with a particular card in the simulation deck are printed in this format. The error message preceded by three asterisks, i.e., '***' is printed on the left end of the line. Error messages printed in this format normally contain an error description with associated parameters, i.e., facility name with appropriate subscripts, simulation time, etc., to help in locating the error. Some of the error messages require more than one line.
Example: ***RESPECIFICATION OF DATA FOR INPUT(1:5)

***AT TIME = 200
Errors are generally classified as fatal or non-fatal depending upon the nature, position and stage of simulation during which they occur. Fatal errors normally result in an immediate termination or abort of the simulation job. However, up to 10 fatal errors are allowed during the processing of the simulation deck for a simulation run. If any fatal errors were detected during the processing of the simulation deck, the entire simulation job is aborted. Whenever a simulation job is terminated due to fatal error(s) a message identifying the action is printed, i.e.,

***TO MANY FATAL ERRORS - SIMULATION TERMINATED.

Non-fatal errors do not cause the termination of the simulation job. In this regard they are warnings rather than errors.

DDLSIM performs complete syntax checking on the BEs and RTEs describing a digital system. Any errors detected during the processing of system description are treated as fatal errors. However, the simulation job is not terminated immediately. Since the errors detected during this stage cannot be easily associated with the DDL deck, they are printed using the second format described above. During the simulation stage complete error-checking is performed on the simulation process itself looking for errors such as:

1. invalid memory addressing,
2. instability in networks containing loops, and
3. attempts to input conflicting data on a facility.
5. EXAMPLES

This chapter provides some example DDL descriptions. The examples range from small synchronous circuits to a simple, but complete computer. These examples do not illustrate all the capabilities of DDL, but provide a good introduction to the user unfamiliar with DDL.

Example 1: A Serial Twos Complementer

The serial twos complementer uses the familiar copy/complement algorithm: starting from the least significant end of the number, copy the bits as they are till and including the first non-zero bit; complement the remaining bits till the most significant end. As an example,

```
0 0 1 0 1 0:1 0 0       Number
1 1 0 1 0 1:1 0 0       Twos complement
```

complement : copy

This algorithm is implemented using a shift register and right circulating its contents while copying or complementing as required. The number of shifts is equivalent to the number of bits in the register. A flip-flop can be used to store the copy or complement state.

Figure 5-1(a) shows the description of the serial twos complementer in DDL. The content of the six bit register R is to be replaced by its twos complement. Register C (3 bits) counts the number of shifts. S is a state flip-flop to indicate the copy or complement state. T is a control flip-flop to indicate RUN/STOP state for the complementer. The complementer waits for SW to be ON, to start complementing. There is a clock P. An Operator ADD is described in lines 5-8. This is a 3 bit adder to increment the contents of the argument register by 1. The Automaton COMP has two states: a waiting state I, and a processing
state S1. Setting of SW is required for the transition to S1 state. In S1, the register R is circulated right 1 bit with the least significant bit copied or complemented, depending on the state of S being 0 or 1. If register C has reached a value of 5, the complementation is stopped by setting T to 0 and returning to state I. If C ≠ 5, COMP stays in S1 state and increments C. The FLag statement (line 13) sets the flags of the translator to provide the outputs at each of its six phases. Figure 5.1(b) shows these outputs. A detailed description of Figure 5.1(a) follows:

**Line 1:** The name of the system is COMPLEMENTER. Only the last 8 characters of this name are retained by DDLTRN. There is no period at the end of this line, since the system description is not complete yet.

**Line 2:** REgister R has 6 bits numbered 1 through 6, left to right; C has 3 bits numbered 2 through 0; S and T are single bit registers. C counts the shifts; S is the copy (0)/COMPLEMENT (1) state flip-flop. T is a flip-flop indicating that the complementing process is underway. It is not really required, but included to illustrate some DDL features. Period terminates the REgister description.

**Line 3:** A Latch by name SW

**Line 4:** A single phase CLock (Time) P.

**Line 5:** A special OPerator by name ADD. The output of the operator is a 3 bit number. The input is through the argument X (X is a formal parameter). No period to terminate, since the operator description is not complete yet.

**Line 6:** Declares the Termina1 X to be of 3 bits and a new 3 bit register C. DDLTRN changes this name to C."
Line 7: Declares a new IDentifier for the concatenation of the last two bits of C and a 1.

Line 8: Declares the CARRY and SUM bits of an adder consisting of 3 half adders. C has the carry bits from each half adder, CC consists of carry bits from previous stages along with a 1 for the least significant bit. ADD consists of the SUM bits output. Note that ADD is the name of the operator, which is simply an ADD 1 circuit. The circuit implied (modelled) by lines 5-8 is:

```
\begin{align*}
X(1) &\quad C(2) \\
\downarrow &\quad \downarrow \\
HA &\quad HA \\
C(1) &\quad ADD (1) \\
\end{align*}
```

Note the periods at the end of line 8. The first terminates <BO> and the second terminates <OP>.

Line 9: Automaton COMP is controlled by the clock P. Since COMP is not subscripted (by parenthesis), it is assumed to be having only two states (1 bit). (If there are more than 2 states, then the number of bits required for state identification must be shown)

Line 10: State (Step) I with identification 0. Automaton COMP waits in I till SW is 1. When SW is 1, T is set to 1, C and S are set to 0, and a transition is made to state S 1 (all in parallel). The period terminates I.
Line 11: State S1 with the designation 1. waits for T to be 1. If S is 1, R is circulated right one bit with the bit R(6) complemented; otherwise R is simply circulated. S receives R(6) if S = 0. Also in this state, the value of C is checked to be equivalent to 5(1012). If C=5, T is set to 0 and a transition to I is made; if not, C is incremented and S 1 state continues. The periods at the end of line 12 terminate the If .... THEN on C, S 1, ST, AU and SY declarations respectively.

Line 13: Sets the Flags of DDLTKN to output results of each of the six passes.

Figure 5.1(c) shows the input commands for DDLSIM. Flags for DDLSIM are set for decimal data input (4) and binary output (6) in Line 1. SW is initialized to 1 in line 2. Two values are read into R one each time state I is reached (line 3). An output trigger OUTTR is declared to be ON at the falling edge of clock P (line 4). The values of COMP, R, S, C, T are to be Output when OUTTR is ON and that of R when in I state (line 5). The simulation is started with <SI> in line 6. Figure 5.1(d) shows the simulation output. The TIME starts with the raising edge of clock. Each edge is a time event. At time 0, all registers are zeroed and the circuit is in state I. At 1 SW is set to 1. At 2, R receives 5. 12 more time slots (6 clock pulses) are required for R to have its twos complement (time 14). At time 16, the new value for R (20) is received and its twos complement is ready at time 28. Since all the inputs are exhausted, the simulator stops at time 29.
DIGITAL DESIGN LANGUAGE TRANSLATOR

1: <SY>COMPLEMENT<TE>:
2: <HE>×(1:6),C(2:0),S,1.
3: <LA>S.$
4: <LI>P.
5: <OP> ADD(3)$×$
6: <TE> ×(3),C(3).
7: <ID> CC=(C(2:3)IIC1).
8: <RD> C=x×CC,ADD=x×CC
9: <AU>CONP: P:
10: <ST>I(0):SK:T<1,C<0,S<0,->S1.
11: S1(1;T:)S1 ×(1)<×T(6),R(2:6)<×R(1:5) IS<×R(6),R<×R(6)(R(1:5)
12: IC(2)<×C(1)C(0)T<0,->IC<ADD×C$
13: <FL>3,4,5,6,R.

FIGURE 5.1(a): DDLTRN INPUT
Figure 5.1(b) DDLTRAN Output

DIGITAL DESIGN LANGUAGE TRANSLATION

DECLARE OPERATIONS

C <- C + 1

Figure 5.1(b) DDLTRAN Output

ORIGIN: BISECT

ORIGIN: BISECT

OF POISON QUALITY
DIGITAL DESIGN LANGUAGE TRANSLATION

PASS 2: SYNTAX REDUCED

\(<\text{SY}>\) \text{LF}\text{ENTER:}\ \text{I}==/\text{COMP}'0, \text{S}1==/\text{COMP}'1\text{D}1\ \ \text{C}''\text{I}=\text{x} \times \text{C}''(2:3)(101)\ \ \text{ADD}==\text{x}\times\text{C}''(2:3)(101)\ .

\(<\text{AU}>\) \text{COMP}=\text{P:}

\{\}

\{S\}\text{I}\neg\neg\text{I}==101\ \ \text{C}==0, \text{S}==0, \rightarrow\text{S}1...

\{S\}I

\{T\}

\{S\} \text{P}(1)==\neg\neg\neg\neg\text{H}(6), \text{N}(2:5)==\neg\neg\neg\neg\text{H}(1:5); \text{S}==\text{R}(6), \text{R}==\text{R}(6)\{R(1:5):.

\{C\}(2)==\neg\neg\text{C}(1)\times\text{C}(0)\ \ \text{I}==0, \rightarrow\text{T}

\{C\}==\neg\neg\text{ADD}, \text{x}==\text{C}.......

Figure 5.1(b)(Continued)
Figure 5.1(b): (Continued)
DIGITAL DESIGN LANGUAGE TRANSLATION

PASS5=OPERATIONS GATHERED

<SY>
LEMENTHR:
1=*/COMP'0,
S1=*/COMP'101,
1'=1*S,
2'=S1*T,
3'=S2*S,
4'=2*T,
5'=2*C(2)*C(1)*C(0),
6'=2*T(C(2)*C(1)*C(0)),
C"1(1:2)=x(1:2)*C"1(2:3),
C"1(3)=x(3)*101,
ADD(1:2)=(x(1:2)*C"1(2:3)),
ADD(3)=(x(3)*101),
P*"1 + P*"5 I<="1*101 + "5*0,
P*"1 + P*"6 I<="1*0 + "6*ADD,
P*"1 + P*"4 S<="1*0 + "4*R(b),
P*"1 + P*"5 COMP<="1*101 + "5*0,
P*"3 + P*"4 R(1)<="3*R(b) + "4*R(b),
P*"3 + P*"4 R(2:6)<="3*R(1:5) + "4*R(1:5),
X="6*C,

PASS6=SUBFACILITIES DISJOINED

<SY>
LEMENTHR:
1=*/COMP'0,
S1=*/COMP'101,
1'=1*S,
2'=S1*T,
3'=S2*S,
4'=2*T,
5'=2*C(2)*C(1)*C(0),
6'=2*T(C(2)*C(1)*C(0)),
C"1(1:2)=x(1:2)*C"1(2:3),
C"1(3)=x(3)*101,
ADD(1:2)=(x(1:2)*C"1(2:3)),
ADD(3)=(x(3)*101),
P*"1 + P*"5 I<="1*101 + "5*0,
P*"1 + P*"6 I<="1*0 + "6*ADD,
P*"1 + P*"4 S<="1*0 + "4*R(b),
P*"1 + P*"5 COMP<="1*101 + "5*0,
P*"3 + P*"4 R(1)<="3*R(b) + "4*R(b),
P*"3 + P*"4 R(2:6)<="3*R(1:5) + "4*R(1:5),
X="6*C,

Figure 5.1(b): Continued
<table>
<thead>
<tr>
<th></th>
<th>FACILITY</th>
<th>1</th>
<th>1</th>
<th>1</th>
<th></th>
<th>0</th>
<th>339</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>R</td>
<td>1</td>
<td>6</td>
<td>6</td>
<td></td>
<td>0</td>
<td></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>C</td>
<td>2</td>
<td>0</td>
<td>-3</td>
<td>-6</td>
<td>0</td>
<td>227</td>
<td>358</td>
<td>362</td>
</tr>
<tr>
<td>4</td>
<td>S</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td>0</td>
<td>235</td>
<td>291</td>
<td>295</td>
</tr>
<tr>
<td>5</td>
<td>T</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td>0</td>
<td>216</td>
<td>321</td>
<td>325</td>
</tr>
<tr>
<td>6</td>
<td>S</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-8</td>
<td>0</td>
<td></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>P</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-5</td>
<td>0</td>
<td></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>A/P</td>
<td>1</td>
<td>3</td>
<td>3</td>
<td>-9</td>
<td>0</td>
<td>191</td>
<td>0</td>
<td>194</td>
</tr>
<tr>
<td>9</td>
<td>X</td>
<td>1</td>
<td>3</td>
<td>3</td>
<td></td>
<td>0</td>
<td></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>&quot;1&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>213</td>
<td>0</td>
<td>219</td>
</tr>
<tr>
<td>11</td>
<td>&quot;2&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>252</td>
<td>0</td>
<td>258</td>
</tr>
<tr>
<td>12</td>
<td>&quot;3&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>244</td>
<td>330</td>
<td>340</td>
</tr>
<tr>
<td>13</td>
<td>&quot;4&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>196</td>
<td>0</td>
<td>201</td>
</tr>
<tr>
<td>14</td>
<td>&quot;5&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>203</td>
<td>0</td>
<td>208</td>
</tr>
<tr>
<td>15</td>
<td>&quot;6&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>255</td>
<td>0</td>
<td>264</td>
</tr>
<tr>
<td>16</td>
<td>&quot;7&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>280</td>
<td>0</td>
<td>287</td>
</tr>
<tr>
<td>17</td>
<td>&quot;8&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>304</td>
<td>0</td>
<td>310</td>
</tr>
<tr>
<td>18</td>
<td>&quot;9&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>337</td>
<td>0</td>
<td>354</td>
</tr>
<tr>
<td>19</td>
<td>&quot;10&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>489</td>
<td>0</td>
<td>497</td>
</tr>
<tr>
<td>20</td>
<td>&quot;11&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>499</td>
<td>0</td>
<td>511</td>
</tr>
<tr>
<td>21</td>
<td>&quot;12&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>456</td>
<td>463</td>
<td>454</td>
</tr>
<tr>
<td>22</td>
<td>&quot;13&quot;</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-9</td>
<td>0</td>
<td>480</td>
<td>487</td>
<td>478</td>
</tr>
</tbody>
</table>

**Figure 5.1(b) (Continued)**
**Figure 5.1(c) DDLSIM Input**

<table>
<thead>
<tr>
<th>TIME</th>
<th>P</th>
<th>R</th>
<th>S</th>
<th>C</th>
<th>T</th>
<th>R</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>000000</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>000101</td>
<td>0</td>
<td>000</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>1</td>
<td>100010</td>
<td>1</td>
<td>001</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>1</td>
<td>110001</td>
<td>1</td>
<td>010</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>1</td>
<td>011000</td>
<td>1</td>
<td>011</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>1</td>
<td>101100</td>
<td>1</td>
<td>100</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>1</td>
<td>110110</td>
<td>1</td>
<td>101</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>111011</td>
<td>1</td>
<td>101</td>
<td>0</td>
<td>111011</td>
</tr>
<tr>
<td>16</td>
<td>1</td>
<td>010100</td>
<td>0</td>
<td>000</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>1</td>
<td>001010</td>
<td>0</td>
<td>001</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>1</td>
<td>000101</td>
<td>0</td>
<td>010</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>1</td>
<td>100010</td>
<td>1</td>
<td>011</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>1</td>
<td>110001</td>
<td>1</td>
<td>100</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>1</td>
<td>101000</td>
<td>1</td>
<td>101</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>101100</td>
<td>1</td>
<td>101</td>
<td>0</td>
<td>101100</td>
</tr>
</tbody>
</table>

**Figure 5.1(d) DDLSIM Output**
Example 2: The Serial Twos Complementer (variation 1)

Figure 5.2(a) illustrates another version of the twos complementer. Two operators are used. The six bit COM operator circulates register X. The bit fed into X(1) during circulation is either X(6) or \(\overline{X(6)}\) depending on the value of \(Y\) is 0 or 1, respectively. The CNTUP operator is the same as the ADD operator in example 1. This version just illustrates the use of operators. Figures 5.2(b) shows the DDLTRN output, 5.2(C) shows DDLSIM input and 5.2(d) shows the DDLSIN output.
DIGITAL DESIGN LANGUAGE TRANSLATION

1: <SYxCOMPLEMENTER>
2: <RFX(R(1;S),C(2;0);S;T).
3: <L4xSx>
4: <T1xP>.
5: <OPxCOM(6);X,Y$>
6: <TExX(6),Y>.
7: <HOxCOM(1)="(L);X(b);X(A),C(2;0)=X(1;5).
8: <UPxCNUH(3);X>
9: <TExX(3),C(3).>
10: <ID>C=(C(2;3)(1;1)).
11: <R0xC=X;C,CATLP=X;CC.
12: <AUxCOP:P>.
13: <S1xI(0);Sii:if=1,C<=0,S<=0,S=S1.
14: S1(1):T:R<-COM$X,S,S,1+1S}S<-X(6),C(2)*X(C(1)*C(0)) T<-0,->11
15: C<-CATLP$C$....
16: <FLx3,4,5,6,8>.

FIGURE 5.2(a) DDLTRN INPUT
DIGITAL DESIGN LANGUAGE TRANSLATION

DECLARE FACILITIES IDENTIFIED

DECLARE FACILITIES

<ST> LEX: TNP
<HP> Y(1:1)
   C(2:1)
   S(1:1)
   T(1:1)
<L> SV(1:1)
<I> P(1:1)
   <IP> CIV(1:1)
   <TP> X(1:1)
   Y(1:1)
   <UP> C111M(1:3)
   <IE> X"I(1:3)
   C"1(1:3)
 C"1(1:3)
<IL> CC(1:1)
<L1> C0YP
<L1> 1
   <SL>

DECLARE OPERATIONS

<ST> LEX: TNP:
  <HP> CIV, Y2
  <HC> CIV(1)=
        X(1:5), CIV(2:6)=X(1:5)...
  <HIP> C111M:
  <H1> C=XXCC, C111M=XCIC...
  <A1> C0YP: P1
  <ST>
  1: S<: 1<-1, C<-0, S<-0, ->S1.
S1: 1: H<:C0M1, S1,
  IT5] S<-4(0),
  IT5] C(2) C(1) C(0) 1<-0, ->1] C<-CNTUP$CS......

FIGURE 5.2(b): DDLTRN OUTPUT
PASS 2--SYNTAX REDUCED

```sy``` LFM(TFTK):
I=*/<COMP'0>, S1=*/<COMP'101>, CCW(1)=
(1)
\( \text{t}(e) \); = (e), CCW(2)x=x(1;5), C"1"x="1+C"1(2;3)11E1, CNTUP=x*1dC"1(2;3)11O1
```

PASS 3--CONDITIONS DISPLACED

```sy``` LFM(TFTK):
I=*/<COMP'0>,
S1=*/<COMP'101>,
I=1=1y, "2=1*5a,
"3=S1*1,
"4=3*5s,
"5=3*CC(3)*tC(1)10C(0),
"6=3*CC(2)10C(1)10C(0)),
CCW(1)=(y+x(h)+"1*x(h)),
CCW(2)=x(1;5),
C"1"x="1+C"1(2;3)11E1,
C"1"TUP=x*1dC"1(2;3)11O1
```

PASS 4--CONCATENATION REMOVED

```sy``` LFM(TFTK):
I=*/<COMP'0>,
S1=*/<COMP'101>,
"1=1y, "2=1*5a,
"3=S1*1,
"4=3*5s,
"5=3*CC(2)10C(1)10C(0),
"6=3*CC(2)10C(1)10C(0)),
CCW(1)=(y+x(h)+"1*x(h)),
CCW(2)=x(1;5),
C"1"1(1;2)=x"1(1;2)+C"1(2;3),
C"1"(3)=x"1(3)+11O1,
C"1"TUP(1;2)=x*1dC"1(2;3),
C"1"TUP(3)=x"1dC"1(3)+11O1,
```

FIGURE 5.2(b) (Continued)
FIGURE 5.2(b) (Continued)
FACILITY TABLE

<p>| | | | | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>LEMENEN</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>2</td>
<td>0</td>
<td>-3</td>
<td>-3</td>
</tr>
<tr>
<td>4</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>6</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>7</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>8</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>9</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>10</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>11</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>12</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>13</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>14</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>15</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>16</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>17</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>18</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>19</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>20</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>21</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>22</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>23</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>24</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>25</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>26</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>27</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>28</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>29</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>30</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>31</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
<tr>
<td>32</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-6</td>
</tr>
</tbody>
</table>

FIGURE 5.2(b) (Continued)
DIGITAL DESIGN LANGUAGE SIMULATOR

FIGURE 5.2(c) DDLSIM INPUT

<table>
<thead>
<tr>
<th>TIME</th>
<th>P</th>
<th>S</th>
<th>C</th>
<th>T</th>
<th>R</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>000000</td>
<td>0</td>
<td>000</td>
<td>000000</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>000101</td>
<td>0</td>
<td>000</td>
<td>1</td>
</tr>
<tr>
<td>4</td>
<td>1</td>
<td>106010</td>
<td>1</td>
<td>001</td>
<td>1</td>
</tr>
<tr>
<td>6</td>
<td>1</td>
<td>110001</td>
<td>1</td>
<td>010</td>
<td>1</td>
</tr>
<tr>
<td>8</td>
<td>1</td>
<td>011000</td>
<td>1</td>
<td>011</td>
<td>1</td>
</tr>
<tr>
<td>10</td>
<td>1</td>
<td>101100</td>
<td>1</td>
<td>100</td>
<td>1</td>
</tr>
<tr>
<td>12</td>
<td>1</td>
<td>110110</td>
<td>1</td>
<td>101</td>
<td>1</td>
</tr>
<tr>
<td>14</td>
<td>1</td>
<td>011011</td>
<td>1</td>
<td>101</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>1</td>
<td>010100</td>
<td>0</td>
<td>000</td>
<td>1</td>
</tr>
<tr>
<td>18</td>
<td>1</td>
<td>001010</td>
<td>0</td>
<td>001</td>
<td>1</td>
</tr>
<tr>
<td>20</td>
<td>1</td>
<td>000101</td>
<td>0</td>
<td>010</td>
<td>1</td>
</tr>
<tr>
<td>22</td>
<td>1</td>
<td>100010</td>
<td>1</td>
<td>011</td>
<td>1</td>
</tr>
<tr>
<td>24</td>
<td>1</td>
<td>110001</td>
<td>1</td>
<td>100</td>
<td>1</td>
</tr>
<tr>
<td>26</td>
<td>1</td>
<td>011000</td>
<td>1</td>
<td>101</td>
<td>1</td>
</tr>
<tr>
<td>28</td>
<td>1</td>
<td>101100</td>
<td>1</td>
<td>101</td>
<td>0</td>
</tr>
</tbody>
</table>

- EOF of file reached on input

Simulation terminated at time = 29

FIGURE 5.2(d): DDLSIM OUTPUT
Example 3: Twos Complementer (variation 2)

Figure 5.3(a) shows a version of twos complementer description with the use of several Automata. Automaton CNT adds 1 to C, checks if it is 5 and sets DONE to 1 if C = 5. It is activated by COUNT. Automaton CMP is activated by CPT; performs the one bit circulation of R; sets COUNT to 1 to activate CNT. COMP is the controlling Automaton, activated by SW and in turn activates CMP in state S1 and waits for CCT to be 1 (for CNT completed) in S2. If DONE is 1, goes into wait state.

Figure 5.3(b) shows the DDLTRN output. Figure 5.3(c) and (d) show the DDLSIM input and output respectively. Note the effect of this version of description (Automata interaction) on simulation time.
1: <SY>COMPLEMENTER:
2: <SF>R(1+6),C(2+0),S,T.
3: <TF>COUNT,CONF,CT.
4: <TF>CT.
5: <TT>P.
6: <LA>Sx.
7: <OP> AND(3)+X4
8: <TF> X(3),C(3).
9: <TN> CC=(L(2+3)(101)).
10: <HP> C=X+CC,APP=xyCC..
11: <AL>C\T:\H:
12: <SL>C1(B):CONF T;c<-4+G(GS,)->G2.
13: <L>(1):CCT=1,TG(7)=C(1)+T(0)) CONF=1;SUN=0.,->C1..
14: .
15: <AL>C\P:\H:
16: <ST>S0(1):C11.
18: S1(1):OPTIONS,=1.,->S1..
19: .
20: <AL>C\P(0):P.
21: <ST>S1(6):S:T<-1,R<-0,S<-0,->S1.
23: S2(0): C11: 1ST+F1->T:->S1....
24: .
25: <FL>3,4,5,6,7.

Figure 5.3(a):DDLTRN Input
Figure 5.3(b) : DDLTRN Output
DECLARE OPERATIONS

CH  L:\*

DP  A*T C

CT:  P:

C1:  COUNT:  C <-- A*C,  --> C.

C2:  C1=1,

1C(2)*C(1)*1C(0)1  DUNF=1;  COMF=G,  --> C1...

CR:  P:

S0:  CR1:

IS]  R(1)<-TR(A),  R(2: 6)<-R(1: 5);  S<-N(c),  R<-N(6)[R(1: 5)],  --> S1.

S1:  COUNT=1,  --> S0...

CDP:  P:

S1:

1:  S1:  I<-1,  I<-0,  S<-0,  --> S1.

S1**1:  T:  CPI=1,  --> S2.

S2:  CCL:

100ME]  --> I;  --> S1....

Figure 5.3(b) : Continued
PASS2 = SYNTAX REDUCED

<SY>
LEMENTFH: C1==*/CNT'0, C2==*/CNT'1P1, SO=*/CMP'0, S1=*/CMP'1C1, I=*/CCMP'002, S1"1==*/CCMP'102,
S2=*/CCMP'202, C"1=x*C"1(2:3)(101), ADD=x*C"1(2:3)(101),

<AU> CNT: P:
  [C1]
  [COUNT] C<--AND, X=C, \rightarrow C2...
  [C2] CCT=1D1,
    IC(2)*IC(1)*IC(0) D(101) : CCWE=0., \rightarrow C1...

<AU> CMP: P:
  [SO]
  [CPT]
    IS1) R(1)<-TH(6), W(2:6)<-R(1:5); S<--R(6), P<-P(6)(R(1:5), \rightarrow S1...
  [S1) COUNT=1D1 , \rightarrow SO...

<AU> CMP: P:
  [T1]
    [SW] T<--D1, S<--0, \rightarrow S1*1...
    [S1*1)
      [T] CPT=1D1, \rightarrow S2...
    [S2]
      [CCT]
        [NONE] \rightarrow T: \rightarrow S1*1... ...

Figure 5.3(b) : Continued
Figure 5.3(b) : Continued
Figure 5.3(b) : Continued
Figure 5.3(b) : Continued
<table>
<thead>
<tr>
<th>LEVEL</th>
<th>FACILITY ID</th>
<th>...</th>
<th>VOLUME</th>
<th>...</th>
<th>VOLUME</th>
<th>...</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>492</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>472</td>
<td>530</td>
<td>534</td>
</tr>
<tr>
<td>4</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>472</td>
<td>530</td>
<td>534</td>
</tr>
<tr>
<td>5</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>516</td>
<td>522</td>
<td>526</td>
</tr>
<tr>
<td>6</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>192</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>161</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>220</td>
<td>0</td>
<td>244</td>
</tr>
<tr>
<td>9</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>78</td>
<td>0</td>
<td>13</td>
</tr>
<tr>
<td>10</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>344</td>
<td>436</td>
<td>440</td>
</tr>
<tr>
<td>18</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>315</td>
<td>0</td>
<td>370</td>
</tr>
<tr>
<td>19</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>327</td>
<td>0</td>
<td>327</td>
</tr>
<tr>
<td>20</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>592</td>
<td>512</td>
<td>612</td>
</tr>
<tr>
<td>21</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>379</td>
<td>0</td>
<td>334</td>
</tr>
<tr>
<td>22</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>341</td>
<td>0</td>
<td>341</td>
</tr>
<tr>
<td>23</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>540</td>
<td>602</td>
<td>646</td>
</tr>
<tr>
<td>24</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>348</td>
<td>0</td>
<td>348</td>
</tr>
<tr>
<td>25</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>355</td>
<td>0</td>
<td>355</td>
</tr>
<tr>
<td>26</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>362</td>
<td>0</td>
<td>362</td>
</tr>
<tr>
<td>27</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>31</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>32</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>33</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>34</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>35</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>36</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>37</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>38</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>39</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>40</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>41</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>42</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>43</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>44</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>45</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>46</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>47</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>48</td>
<td>111</td>
<td>-1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Figure 5.3(b) · Continued
DIGITAL DESIGN LANGUAGE SIMULATOR
VERSION HSF 1979

Figure 5.3(c): DDLSIM Input

Figure 5.3(d): DDLSIM Output
Example 4: MULTIPLIER [35]

A MULTIPLIER unit that calculates the product of two 8-bit numbers is described in Figure 5.4(a). A listing of the deck used for simulating the MULTIPLIER system along with the simulation report is given in Figure 5.4(b). The <Flag> declaration in the simulation deck specifies that all data-values specified without radix specification be interpreted in decimal (Flag 4), and that output values be printed in binary (Flag 6). The control unit MPY of the system waits idly in state S1 until it receives a START command. A <Initialize> declaration is used to initialize the START signal to 1 and start the MULTIPLIER unit. On receiving the START command in state S1, the control unit proceeds to load the R register with the multiplicand obtained from the BUS and proceeds to state S2. In state S2 the B register is loaded with the multiplier obtained from the BUS. A triggered READ operation with state terminal S1 as the triggering signal is used to supply the BUS with the multiplicand. During simulation, whenever the control unit reaches state S1, the BUS is supplied with a new value of the multiplicand. The multiplier is supplied to the BUS in a similar manner with another triggered READ operation using state terminal S2 as the triggering signal. After loading the multiplicand and the multiplier, the control unit proceeds to state S3. In state S3 the multiplicand is added to the partial product, if the multiplier bit is a logic 1. The control proceeds to state S4 in any case. The A and B registers are shifted right together and the multiplication cycle counter MCOUNT is incremented. If the count has been completed, status line DONE is set to logic 1 and the control unit returns to its idle state S1. If not all bits of the multiplier have been tested, the control unit returns to state S3.
A triggering signal OUTTR defined using a <Trigger> declaration is used in a triggered OUTPUT operation to control the printing of the values for MPY, MOUNT, A, and B. These values are printed in binary on every trailing edge of the clock P signal. Another triggered OUTPUT operation using state terminal S1 as the triggering signal controls the printing of the values for the multiplicand, multiplier and the final product. Note that these values are printed only once, i.e., when the final product is available, during a given multiplication operation. The two output lists printed with different frequency make the simulation report more informative and readable. Since no <Clock> declaration is included in the simulation deck, default values are used for P, W, and Q. Note that for a single simulation run a <Simulate> declaration is not required. Since an EOF condition is expected no explicit <Stop> declaration is included in the simulation deck to terminate the simulation.
DIGITAL DESIGN LANGUAGE TRANSLATOR

1:  <CO>MULTIPLIER<
2:  <SY>MULTIPLIER;<TI>P,<RE>A(0:8),B(8),R(8),MCOUNT(3).>
3:  <RE>ZERO,ONE.
4:  <TE>START,BUS(8),DONE.
5:  <TE>SUM(8),COUT(8),CSUM(3),CCOUT(3).
6:  <ID>CIN=COUT(2:8)ZERO.
7:  <ID>CCIN=CCOUT(2:3)ONE.
8:  <BO>COUT=R*A(1:8)+R*CIN+A(1:8)*CIN,CSUM=RAA(1:8)*CIN,
9:  CCOUT=MCOUNT*CSUM,CSUM=MCOUNT*CSUM.
10: <AU>MPY(2):P;
11: <ST>S1(0):START:K<=BUS,MCOUNT<=0,ZERO<=0,ONE<=1,->S2.
12:  S2(1):A<=BUS,B<=0,->S3.
13:  S3(2):A(0)A<=COUT(1)SUM,->S4.
14:  S4(3):A(1:8)B<=A(B(1:7),A(0)<=0,
15:  MCOUNT<=CSUM,MCOUNT1ONE=1,->S1->S3.....
16:  <FL>3,4,5,6,8.

Figure 5.4(a) : DDLTRN Input
Figure 5.4(b) : DDLSIM Input
<table>
<thead>
<tr>
<th>TIME</th>
<th>Y</th>
<th>A</th>
<th>B</th>
<th>H</th>
<th>BUS</th>
<th>B</th>
<th>B</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>32</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>33</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>34</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>35</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>36</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>37</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>38</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>39</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>40</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>41</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>42</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>43</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>44</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>45</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>46</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>47</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>48</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>49</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>50</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>51</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>52</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>53</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>54</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>55</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>56</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>57</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>58</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>59</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>60</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>61</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>62</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>63</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>64</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>65</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>66</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>67</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>68</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>69</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>70</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>71</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>72</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

END OF FILE REACHED ON INPUT
SIMULATION TERMINATED AT TIME =  73

Figure 5.4(b) : DDLSIM Output
Example 5: MINICOMPUTER [52]

A description of a simple minicomputer is given in Figure 5.5. The details of the minicomputer are given in the Appendix. Lines 2-4 in Figure 5.5 describe the registers. Lines 5 declares a memory bus. Line 6 declares a START latch. Line 7 declares a four phase clock. Lines 8-11 declare a Increment (by 1) circuit. Lines 12-16 declare a 12 bit adder. Lines 18-19 are CPU initialization. Lines 20-23 show the FETCH cycle. Lines 24-25 show the DEFER state for Indirect Address calculation. Lines 26-27 show the OPCODE decoding. Lines 28-43 show the microoperations for each instruction.
Figure 5.5(a): Minicomputer Description

1: <SY>MINI:
4: 1:ETH:US:1:2:.
5: 1:ETH:US:1:2:.
6: 1:ETH:US:1:2:.
7: 1:ETH:US:1:2:.
8: 1:ETH:US:1:2:.
9: 1:ETH:US:1:2:.
10: 1:ETH:US:1:2:.
11: 1:ETH:US:1:2:.
12: 1:ETH:US:1:2:.
14: 1:ETH:US:1:2:.
15: 1:ETH:US:1:2:.
16: 1:ETH:US:1:2:.
17: 1:ETH:US:1:2:.
18: 1:ETH:US:1:2:.
19: 1:ETH:US:1:2:.
20: 1:ETH:US:1:2:.
21: 1:ETH:US:1:2:.
23: 1:ETH:US:1:2:.
24: 1:ETH:US:1:2:.
25: 1:ETH:US:1:2:.
26: 1:ETH:US:1:2:.
27: 1:ETH:US:1:2:.
28: 1:ETH:US:1:2:.
29: 1:ETH:US:1:2:.
Figure 5.5(a): (Continued)
6. CONCLUSIONS

DDLTRN and DDLSIM programs are currently being tested on SEL-32 Computer System. The output of the DDLTRN is suitable for logic generation. The output at PASS 6 and the Facility table are now being analyzed to derive the algorithms for logic synthesis. With the logic synthesis programs complete, CADAT will be a true automatic design system.
APPENDIX

This is a preprint of the article to be published in the December 1979 issue of the "Proceedings of IEEE."
Computer Hardware Description Languages—A Tutorial

SAJJAN G. SHIVA, MEMBER, IEEE

I. INTRODUCTION

A NY digital system can be described in the following six levels of complexity [1]-[4]:

1) Algorithmic level which specifies only the algorithm used by the hardware for the problem solution.
2) Processor memory switch (PMS) level which describes the system in terms of processing units, memory components, peripherals, and switching networks.
3) Instructional level (programming level) where the instructions and their interpretation rules are specified.
4) Register transfer level where the registers are system elements and the data transfer between these registers are specified according to some rule.
5) Switching circuit level where the system structure consists of an interconnection of gates and flip-flops and the behavior is given by a set of Boolean equations.
6) Circuit level where the gates and flip-flops are replaced by the circuit elements such as transistors, diodes, resistors, etc.

Logic diagrams and Boolean equations have been used as media of hardware description. The complexity of these media increases rapidly as the system complexity increases and they are not convenient to suppress the details and still provide accurate descriptions as we move into the higher levels from the switching circuit level. Hardware description languages (HDL's) evolved as a solution. Although the use of computer oriented languages to describe digital system design can be traced back to Shannon's work on switching circuits in 1939, Aiken's work on switching theory in the 1940's, the logic diagrams at M.I.T. and NBS in the late 1940's and the flip-flop equations in the 1950's [5], Plessman's work [6] on a formal HDL probably initiated the contemporary interest in this area of research. An HDL is similar to any other high-level programming language (HLL) and provides a means of

Manuscript received May 24, 1979, revised August 20, 1979. This work was supported by the National Aeronautics and Space Administration under Grants NGL 305-073 and NAS 5-19069. The submission of this paper is not accompanied by an advance protocol.

The author is with the Department of Computer Science, University of Alabama in Huntsville, Huntsville, AL 35807.

1) Precise yet concise description of the system.
2) Convenient documentation to generate user manuals, service manuals, etc.
3) Input of the system description into a computer for simulation and design verification at various levels of detail.
4) Software generation at the prototype level, thus bridging the hardware-software development life cycle.
5) Incorporation of design changes and corresponding changes in documentation, efficiently.
6) Design/report (teacher/student) communication interface at the desired level of complexity.

HDL's are capable of describing the parallelism, noncoercive nature, and timing issues in the hardware more naturally, and thus differ from the pure sequential nature of a general purpose HLL. (Some existing HLL's provide concurrency or simulated concurrency constructs in their language elements, for example, PFOR in PEP [7].) An HDL can be classified as a procedural or a nonprocedural language [4]. Each statement in a nonprocedural HDL description would contain a label which describes the condition under which the statement is to be performed. Thus the sequential ordering of the statements does not impose the ordering of the activities. In a procedural HDL description, the activities are performed following the sequential ordering of the statements.

HDL's are designed to describe both the structural and behavioral characteristics of a digital system. The fundamental properties of hardware systems and the art of hardware design process drastic the essential features of an HDL. For an HDL to be a useful tool, it has to possess the following properties:

1) It has to have a natural way of describing the parallelism, noncoercive nature, and timing issues in digital hardware.
2) The structure and control parts of the hardware should be easily described and preferably the description of the two parts be separated (if such a division enhances the description) so that a user interested in the behavior of the system need not concern himself with the structure of the system. This division provides the flexibility to use hardware, software, or firmware for the control part, whichever is economical.
3) The language should serve as a medium at all levels of system description.
4) The design changes should easily be incorporated into the description and corresponding translation should be done preferably without a complete retranslation. This feature will be useful for the interactive environment. (A translator translates the HDL description into an intermediate code from which the simulator and other programs can be driven. See Fig. 1.) The intermediate code could be a set of Boolean and registered transfer equations [21] or a computer executable code like patch strings [22].)
5) The language should be easy to learn and remember, to accommodate the software/hardware designer, although the hardware engineer cannot neglect the software aspects any more, due to the impact of microprocessors. The design system should be portable, thus necessitating the translators and simulators of HDL's be written in higher level languages.
6) Two approaches to system design are often proposed: the bottom-up approach where the elementary components are combined to form more complex ones and the top-down approach, where the system is decomposed into a collection of subsystems until the elementary components are reached. In practice, the designer may choose a combination of the two approaches. The structural detail at any design level varies from designer to designer. The HDL should allow the designer to control the amount of detail during each design stage.
7) The description of the large and medium scale integrated circuit (LSI and MS1) modules as system components should be straightforward, so should be the inclusion of lower modules. If the system is partitioned by the designer to accommodate standard modules, this partitioning should be retained by the HDL translators and simulators.
Several HDL's have been reported [91-176] since Verson's proposal of an HDL. Translators to convert the description into an intermediate executable code and simulators to execute this code have been written for some of these languages. No single HDL has met all the above characteristics. The tendency has been to invent a new HDL to suit a particular design environment, basically due to the difficulty in transporting the translators and simulators to the new computing systems and extending them to accommodate the requirements of the new design environment. Table I [8] lists the implementation details of several HDL's reported. This list is by no means exhaustive.

Section II discusses the utility of HDL's in system design. A brief discussion of one popular HDL, the computer design language (CDL), is given in Section III along with two example descriptions. Two case studies are presented: one to select an HDL for an integrated circuit design environment (Section IV) and the other to show the utility of HDL's in concurrent hardware/software development (Section V). Future work required and current research topics are discussed in Section VI.

II. HDL'S IN SYSTEM DESIGN

Fig. 1 shows the utility of an HDL in a digital system design environment. The designer uses the HDL to describe his design. This description is translated into a computer-executable data base, which serves as the source for various other operations. The design can be refined by simulating at the description level (Loop 1), before proceeding to a more detailed simulation (Loop 2) at the logic level. The data-base also serves as a source for logic diagram generation, microcode and test set generation. The physical construction of the system follows the simulation and refinement at the logic level.

Translation and simulation of HDL's have been well defined [91-176]. Physical construction aspects have also been automated and are widely used in industry [77]. Test generation [78] and hardware compilation [12, 39] need further investigations and the variety of design methodologies, the artistic nature of the design process, and the ambiguity posed by the variety of components available make the hardware compilation a tedious task.

III. COMPUTER DESIGN LANGUAGE

A hardware programming language (AHPL), computer design language (CDL), digital systems design language (DSDL) and the instruction set processor (ISP) have been the most popular languages, partly due to their early introduction as general purpose HDL's. These languages were developed in university environments and are used in teaching digital logic design. New features are being added to these languages to make them more versatile. Well-tested translators and simulators are available for these languages (see Table I for references). Although several HDL's have been designed for an industrial use [59], [64], the design process being proprietary in nature, the use of HDL's is not widely reported [79].

This section provides a brief introduction to CDL. Example descriptions in CDL are provided. CDL was chosen over the others due to its simple structure and the author's familiarity with the language. CDL was proposed originally by Chu [201-212]. A translator and simulator were written for a subset of this language [23]. Several modifications were made to this translator and simulator [26]-[29].

CDL describes the structural and functional parts of a digital system. The structural components like memory, registers, clocks, switches, etc., are declared explicitly at the beginning of the description. The functional behavior of the element is described by the commonly used operators and user defined operators. Valid data paths are declared implicitly whenever there is a data transfer. Both parallel and sequential operations are allowed. Synchronous operations require a conditional test for an appropriate signal. The language is easy to understand and is highly readable.

All the variables in a CDL description are global. The system description can be only at one level, and there is no subroutine facility in CDL, thus making it unsuitable for describing hardware in a modular fashion. It is not possible to include special hardware components like integrated circuits (IC's) in a description. However, its simplicity of structure and its portability resulting from the FORTRAN implementation have made CDL a popular language. The description of CDL syntax and semantics is accepted by the present version of translator and simulator [29] as given below. Table II shows the standard operators in CDL. Facilities are declared at the beginning of the system description with declaration statements of the format

\[
\text{DEVICE, list}
\]

where DEVICE can be a \text{REGISTER, SUBC}LISTER, MEM-
ORY, DECODER, SWITCH, TERMINAL, BUS, BLOCK, and
CLOCK. Some example declarations are shown below.

\[
\text{REGISTER}(A(0-2), R, F(4-1))
\]

\[
\text{SUBREGISTER}, F(O-F(3-1), F(0-F(6-4))
\]

\[
\text{MEMORY, H(0-W(0-77-10)}
\]

\[
\text{Address register R}.
\]

\[
\text{DECODER, L(0-15)+G(2-5)}
\]

\[
4 \text{ bits of } G \text{ are decoded into } L_0, \ldots, L_4.
\]

\[
\text{CLOCK, P(2)}
\]

\[
A \text{ clock with } 3 \text{ phases } P(0), P(1), P(2).
\]

\[
\text{SWITCH, STRT (OFF, ON)}
\]

\[
A \text{ switch with } 2 \text{ positions. A maximum of } 10 \text{ positions allowed.}
\]

\[
\text{TERMINAL, B=\text{A}},, C=A+B,
\]

\[
D=A\times B
\]

\[
\text{BUS, Z(0-7)}
\]

\[
A \text{ } 8 \text{ line BUS } Z
\]

\[
\text{BLOCK, SERCOM (A=A(1)^{-A(5-2))}}
\]

\[
\text{SERCOM is an alternate name for the operations within the parentheses.}
\]

A DO:SERCOM statement is used to invoke the set of statements declared by BLOCK, SERCOM. An unconditional microstatement has the form

\[
\text{Variable = Expression}
\]

Example: \( A=1, B(1-5)+C=Y = E(2,0-1)
\]

A conditional microstatement has the form

\[
\text{IF (expression) THEN \text{n microstatements}}
\]

Example: \( \text{IF (A=0) THEN (R=0) \text{ ELSE (R=1) }}
\]

A labeled statement has the format

\[
\text{label: microstatements}
\]

where

\[
\text{label = expression or clock}
\]

Example: \( \text{K(0)}=\text{P(A+B)A}
\]

Special operators can be established by the user through a separate subprogram. The format is

\[
\text{OPERATOR: Parameters Name}
\]

\[
\text{microstatements, RETURN END}
\]
A count operator is defined below:

```
OPERATOR, 2,1-1, COUNT:
Z[1] = IF (a) = 0 THEN x[1] = 0, 0
ELSE IF (a) = 0 THEN x[1] = 2-1, 0
ELSE IF (a) = 2-1 THEN x[1] = 1-0
ELSE x[1] = 0-0 RETURN
END
```

Several commonly used operations (Table II) are included in the current CDFL software.

Examples 4-4 CNTLP, C4 ADDB

The CDFL TRANSLATOR performs a syntax check of the description and translates it into a set of tables and a polish string program.

The CDFL SIMULATOR executes the output of the translator and can accept simulation parameters through the following command set:

```
LOAD
OUTPUT
SWITCH
RESET
SIMULATE
```

CDFL can be used to describe simple to very complex digital systems. Two example descriptions are provided below to illustrate this feature.

Example 1 A Serial Ten 1 Counter

A circuit to replace the contents of a 6-bit register R by its complement will be described. The complementation is done by the well-known two-complement algorithm starting from the least significant bit of R. Copy the bits as they are for the first nonzero bit, complement the bits after the first nonzero bit, and copy the most significant bit of the register.

Fig. 2 shows the circuit and its CDFL description. A 6-bit register C is used to count the number of shifts (C=0: flip-flop S indicates the COPY (5=0) and COMPLEMENT (5=1) states. A shift SW is used to start the complementation process. Statements 2, 3, and 5 describe these facitites. The control circuitry includes a single phase clock P and a 1-bit state register T (Statements 6 and 51). Fig. 3 shows the state diagram for the control circuit. The controller waits in state 30 until the SW is off. When SW is on, the C and S are cleared and a state change occurs (Statement B1). As long as C=0, the shift signal is on. Statement 9 describes the process of copying or complementation according to 5=0 or 1. Note that the evaluation of the register R is delayed using the concatenation operator. When the counter reaches 5, the controller goes to state 30, thus completing the complementation.

CDFL being a nonprocedural language, evaluates labels and tests the contents of the active label. Each such evaluation is labeled with a number. During simulation, the values of R, C, and S are requested to be OUTPUT at each label cycle (Statement 11). The switch is turned on or off at cycle 1 (Statement 6). P is loaded with 514 preshaft signals indicate the base of the number, the number is decimal if not subscripted initially (Statements 12, 14) and simulation is requested for 20 label cycles with 6-sequence evaluation requests to seek an active label before terminating. Fig. 4 shows the simulation results. The contents of R(1-3) 4 at the end of the label cycle 6 are the two's complement of the original contents 0-5, thus indicating the validity of the design.

The clock and label cycles are RESET and R was loaded with 214, Fig. 4b) shows the corresponding simulation results.

The CDFL description in Fig. 2 serves as a compact and precise description of the structure and behavior of the hardware.

Example 2 A Microcomputer

Fig. 5 shows the structural details of instruction set, and the CDFL description of a microcomputer [15]. The microcomputer has a 256-word 16-bit memory, with an 8-bit memory address register (MAR) and a 12-bit memory buffer register (MBR). There is a 1-bit program counter (PC) and an accumulator (AC) of 12 bits. The arithmetic logic unit (ALU) receives the operands from MAR and a 12-bit register, and puts the results on to the 12-bit BUS. The instructions consist of a 3-bit operation code, an indirect address flag bit, and a 8-bit address. The register-set description is provided by the Statements 1-3 of Fig. 5b. The BUS is not explicitly described to retain the high level description nature. Fig. 5c) shows the details of the instruction set. Statement 4 or 5b) describes a START signal to a RUN switch to indicate the RUN STOP state, and a three state switch for indicating instruction fetch (F), indirect address computation (Def), and execution of the phase. Statements 5 and 6 provide the instruction decoding details. There is a 4-phase clock in Statements 5, which activates the synchronous control unit (same cycle consists of 4 cycles). The additional instruction waits for the next instruction to occur. The instruction identification and fetch cycle, Def cycle, and the Execute cycle for each instruction. Fig. 5d) shows a program in assembly language number locations 0-3 and store the same in location 7. The program will be loaded in memory locations 10-16. Location 0 is initialized to -3 and incremented by 1 each time through the loop, and tested for zero to terminate the summing operation. The data values are accessed by an indirect reference (TAM) to location 6 which is incremented from 0 to 1 each time through the loop. Fig. 5e) shows the program in assembly, binary, and decimal forms. Fig. 5f) shows the memory map that exists at the execution of the program. This memory map is summarized by the LOAD command for the CDFL simulator (Statements 43-45 in Fig. 5b). The program counter is set to 1G (Statement 46), the switch is turned ON (Statement 47), and a simulation is requested for 200 label cycles (Statements 48), outputting several register contents (Statement 49) at each label cycle. The simulation results are similar to the in the complement example; the same are not shown, for the sake of brevity. It is evident that the CDFL description of the microcomputer is concise and more precise than any natural language description could be.

IV. Selection of HDL

Due to the large number of HDL's proposed, the selection of an HDL for a particular design environment becomes a nontrivial task. Although the structure of the language, the operator available, the capabilities of the language to describe the design in a logical manner are important considerations, the implementation issues seem to overshadow them. One such selection process is described here along with the system description. Fig. 6 shows the details of the computer aided design and test (CADAT), system of the NASA Marshall Space Flight Center [64]. The designer inputs the details of the IC to CADAT as a set of standard cells and their connections. The standard cell selection is done manually from a standard cell library. This description is at the input diagram level. Detailed layout simulation and refinements are carried out on the design. The final design is input to the automatic transistor generation and placement and routing programs. The IC mask pattern generation is done interactively and a mask analysis and performance simulation are done before fabricating the mask. The last two steps in the CD fabrication are the wafer processing and the final testing.

At present, the generation of logic diagrams and choosing the standard cells from the cell library for the design are done manually. Integration of a high-level design language could help the designer to simulate his design and refine it at a high level before entering his design into the current system. This requires an HDL with a simulator and logic synthesis software (hardware complete) that generates the logic net input requested by
VII CONCLUSIONS

The capabilities of HDLs were discussed. A brief introduction to the use of such languages (CDL) along with examples of descriptions were given. Case studies for selection of an HDL and the use of HDL in software development were given. The areas for further investigations were indicated.

ACKNOWLEDGMENT

The author wishes to thank J. M. Gould and R. M. Hsu for helpful discussions during the preparation of this paper. Michigan Technological University Computer Center provided the CDL Software, and C. Chamber for the assistance in preparation of the manuscript.

REFERENCES

the CADAT System. The board-level implementation and testing of a complex large-scale integrated circuit (LSI) design is not feasible since it cannot be properly revalized with anything but the CADAT. With an HDL, however, the housing process can be simulated with a computer simulation of the LSI design, thus minimizing the design changes and, hence, the cost of manufacturing and write-up process.

The four criteria were used in selecting a suitable language [14].

1. Activity
2. Level of description
3. Software reusability and portability
4. Ease of program generation

1. Activity. It is important to choose a language which will be used to reserve the benefits of the extension to the language. Most of the HDL's proposed do not have a translator and a simulator that is up-to-date and fast, especially though the language itself is expensive. The process of improving the HDL software and capabilities could be aided by the active interest of the other group in the language.

2. Level of description. The selected HDL should accommodate a description at the register transfer level and be able to facilitate the logic generation. A higher level description will not be needed for the IC design environment of CADAT.

3. Software Reusability and Portability. The development of an HDL is expensive without a translator and a test pattern written for it, since the software development process requires the language structure. The software should be portable to accommodate the general purpose of the CADAT software.

4. Ease of Logic Generation. An HDL translator converted towards providing information for a simulator collects and rearranges the compilation, input, and register transfer. The intermediate translated output should be amenable to logic generation.

Motivation. The HDL description should be modular enough to reflect the modularity of the hardware, to enable easier understanding and modular design verification.

A comparison of the four prominent HDL's with respect to the above criteria is shown in Table III IS. Although, whereas, the four level description is very low, the structure of a translator is the main drawback in the implementation of the logic diagram and the difficulty in using the HDL's to design a large chip. Though the strong feature in input and output is the translator's aspect, the translator's aspect is that it is easier to develop a translation, given that language is relatively difficult. Although a hardware computer is available for HDL's, its HDL/SDL implementation lacks the necessary implementation power for CADAT, which is preeminent in FORTRAN. The SDL translator provides a set of boolean equations and register transfer expressions which can be fed for hardware compilation [19, 176] though not very easy. The black structure and the software of SDL made it a better choice over HDL for the CADAT system.

Note that the selection of the HDL is oriented more towards the implementation issues, rather than a rigorous analysis of the capabilities and the characteristics of the HDL such as the structure of the language, the facilities available, ease of understanding, etc. Such a rigorous analysis although valuable will not aid at the selection of the language since the implementation issues are determined by the other criteria.

The above criteria ignored the potential of developing a new language to extend the CADAT environment. However, criteria also stimulated several other HDL's like EDL [174] and SDL [172] from consideration.

V CONCURRENT HARDWARE AND SOFTWARE DEVELOPMENT

The use of HDL's in hardware development is obvious. The recent advances in hardware design have tremendous increased the speed of new system development. But the software development for the new systems has not caught up with the rate of development of the hardware. It is now possible to develop software for the hardware concurrently to make the software/hardware development interface. This section describes an experiment to measure the performance of CSL in software development [26].

A multiprogramming system consisting of a Digital Equipment Corporation PDP-8/M Microcomputer and an IBM 1130 Input/Output processor was used. The two processors were simulated individually, followed by the simulation of the shared memory and the input device for the system. The input device is an eight-bit microprocessor which handles the bookkeeping of these measurements for use by PDP-8. Several programs were written both for CSL and PDP-8. The programs on PDP-8 accept the measurements from CSL output whether they are within specifications, and transfer the condition of the system to CSL. The programs were written in assembly language of the particular processor and were stored in the shared memory in the machine language form. The results of the simulations can be found in [27].

An important consideration in developing programs is the assembly time required by the host processor. Running the CSL simulation of PDP-8 and 1130-10 Table II shows the CPU times required for typical programs on an IBM 370 155. Clearly, the cost of such simulations is prohibitive. However, since the cross-assemblers are available on the host machine, developing an application program using PDCL simulation would not be very expensive, since these programs would usually be shorter than an assembler or a computer. A rational user would be the performance comparison of such simulations using high level language simulators rather than an HDL. Much of the overhead of the HDL translation simulator software could be reduced by using an HDL for describing and simulating the processor. A comparison of such HDL versus HDL descriptions and their run times is included.

VI FUTURE WORK

Although the suitability of an HDL for hardware system description is well recognized, the HDL's are not uniformly used, partly due to the variety of structures and notations used in these HDL's, making them harder to understand. Many structures found in HDL's are simple for a software designer to understand and use. But a hardware designer not familiar with programming finds them hard to use. This problem will be partially solved by the popularity of the HDL's as design elements, requiring the hardware designer to understand software.

The differences in notations and structures used by HDL's make it difficult to borrow a language developed elsewhere. This difficulty is augmented by the nonstandard design meth-
<table>
<thead>
<tr>
<th>Language</th>
<th>Reference</th>
<th>Adapted from</th>
<th>Implemented Machines</th>
<th>Implementation Language</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACDL</td>
<td>9</td>
<td>APL</td>
<td>CDC 6400</td>
<td>SNOBOL</td>
</tr>
<tr>
<td>ADFL</td>
<td>10-12</td>
<td>APL</td>
<td>DEC 10</td>
<td>FORTRAN</td>
</tr>
<tr>
<td>ALERT</td>
<td>13-14</td>
<td>APL</td>
<td>IBM 7090</td>
<td></td>
</tr>
<tr>
<td>APL</td>
<td>15-16</td>
<td>ALGOL</td>
<td>CDC 6400</td>
<td>ALGOL-40</td>
</tr>
<tr>
<td>APL-50S</td>
<td>17</td>
<td>APL</td>
<td>many</td>
<td>assembly</td>
</tr>
<tr>
<td>CASSANDRE</td>
<td>18</td>
<td>PL/I</td>
<td>IBM 360</td>
<td></td>
</tr>
<tr>
<td>CASSANDRE</td>
<td>19</td>
<td>ALGOL</td>
<td>IBM 360,370</td>
<td>assembly</td>
</tr>
<tr>
<td>CDL</td>
<td>20-29</td>
<td>ALGOL</td>
<td>IBM 370</td>
<td>FORTRAN ASSEMBLY</td>
</tr>
<tr>
<td>CLO</td>
<td>30</td>
<td>ALGOL</td>
<td>IBM 370-155</td>
<td>BCPL</td>
</tr>
<tr>
<td>DDL</td>
<td>31-39</td>
<td>PL/I</td>
<td>Markus 602/84</td>
<td></td>
</tr>
<tr>
<td>EXTRAN</td>
<td>40</td>
<td>PL/I</td>
<td></td>
<td></td>
</tr>
<tr>
<td>EDDL</td>
<td>41</td>
<td>DSM</td>
<td>IBM 360</td>
<td>XPL</td>
</tr>
<tr>
<td>EDSL</td>
<td>42</td>
<td>DSM</td>
<td>IBM 360</td>
<td></td>
</tr>
<tr>
<td>FLOWWARE</td>
<td>43</td>
<td>PL/I</td>
<td>IBM 360</td>
<td>FORTRAN</td>
</tr>
<tr>
<td>FVS</td>
<td>44</td>
<td>CDC</td>
<td>NOVA 800</td>
<td>FORTRAN IV</td>
</tr>
<tr>
<td>GLIDE</td>
<td>45</td>
<td>ALGOL</td>
<td></td>
<td></td>
</tr>
<tr>
<td>HARGOL</td>
<td>46</td>
<td>ALGOL</td>
<td></td>
<td></td>
</tr>
<tr>
<td>HILO</td>
<td>47</td>
<td>RCL 1900</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ISP</td>
<td>48-49</td>
<td>ALGOL</td>
<td>POP-10</td>
<td>BLISS</td>
</tr>
<tr>
<td>ISPL</td>
<td>50-57</td>
<td>ALGOL</td>
<td>IBM 360-91</td>
<td></td>
</tr>
<tr>
<td>ISPL</td>
<td>50-57</td>
<td>ALGOL</td>
<td>CDC 6400</td>
<td>SNOBOL</td>
</tr>
<tr>
<td>LASCAR</td>
<td>51</td>
<td>CASSANDRE</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LCD</td>
<td>52</td>
<td>PL/I</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ODG</td>
<td>60</td>
<td>RTL</td>
<td>Burroughs</td>
<td>ALGOL-60</td>
</tr>
<tr>
<td>LOCAL</td>
<td>61</td>
<td>RTL</td>
<td>UNIVAC 1108</td>
<td>FORTRAN IV</td>
</tr>
<tr>
<td>LOTIS</td>
<td>62</td>
<td>ALGOL</td>
<td></td>
<td></td>
</tr>
<tr>
<td>MDL</td>
<td>63</td>
<td>APL</td>
<td></td>
<td></td>
</tr>
<tr>
<td>MODUL/LINDA</td>
<td>64</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>OSM</td>
<td>65</td>
<td>ODR-A-303</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PNS</td>
<td>66</td>
<td>ALGOL</td>
<td>CDC 1604</td>
<td>SNOBOL</td>
</tr>
<tr>
<td>RTS</td>
<td>67-48</td>
<td>ALGOL</td>
<td>Burroughs 4004/151</td>
<td>FORTRAN</td>
</tr>
<tr>
<td>RTS</td>
<td>67-48</td>
<td>ALGOL</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RTN</td>
<td>69</td>
<td>ALGOL</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RTN</td>
<td>69</td>
<td>CYBER 774</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SDK</td>
<td>70</td>
<td>RTL</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SIM</td>
<td>71</td>
<td>ALGOL</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SIM</td>
<td>71</td>
<td>CYBER 174</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VDS</td>
<td>74</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>VPM</td>
<td>74</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

NOTES: 1) "-" indicates that the detail is either not available or not known.
2) No necessary is counted for the contents of this table.
TABLE II

<table>
<thead>
<tr>
<th>Format</th>
<th>Description</th>
<th>Example</th>
<th>Explanation</th>
</tr>
</thead>
<tbody>
<tr>
<td>CO</td>
<td>A 1.0.B</td>
<td>Expression a 1 if (A) = (B)</td>
<td></td>
</tr>
<tr>
<td>NF</td>
<td>A 1.0.B</td>
<td>Expression a 0 if (A) = (B)</td>
<td></td>
</tr>
<tr>
<td>SI</td>
<td>A 1.0.B</td>
<td>Expression a 1 if (A) &gt; (B)</td>
<td></td>
</tr>
<tr>
<td>LT</td>
<td>A 1.0.B</td>
<td>Expression a 0 if (A) &lt; (B)</td>
<td></td>
</tr>
<tr>
<td>AND</td>
<td>A AND B, A±B</td>
<td>Performs logical AND bit by bit</td>
<td></td>
</tr>
<tr>
<td>OR</td>
<td>A OR B</td>
<td>Performs logical exclusive OR bit by bit</td>
<td></td>
</tr>
<tr>
<td>SUB</td>
<td>A SUB B</td>
<td>Binary sum of (A) and (B) or (A) + (B)</td>
<td></td>
</tr>
<tr>
<td>CNTD</td>
<td>A CNTD</td>
<td>Increments A by 1 or (A) + 1</td>
<td></td>
</tr>
<tr>
<td>CNTDN</td>
<td>A CNTDN</td>
<td>Decrements A by 1 or (A) - 1</td>
<td></td>
</tr>
<tr>
<td>SHR</td>
<td>A SHR</td>
<td>Shits right one bit position, zero 0 at left</td>
<td></td>
</tr>
<tr>
<td>SML</td>
<td>A SML</td>
<td>Shifts A left one bit position, zeroes 0 at right</td>
<td></td>
</tr>
<tr>
<td>CIR</td>
<td>A CIR</td>
<td>Circular (closed) right shift of A 1 bit</td>
<td></td>
</tr>
<tr>
<td>CLR</td>
<td>A CLR</td>
<td>Circular (closed) left shift of A 1 bit</td>
<td></td>
</tr>
<tr>
<td>SHRRA</td>
<td>A SHRRA</td>
<td>Arithmetic right shift of A 1 bit, no change at left must be zero bit</td>
<td></td>
</tr>
<tr>
<td>A = B</td>
<td></td>
<td>Contents of A are replaced by contents of B</td>
<td></td>
</tr>
</tbody>
</table>

TABLE III

<table>
<thead>
<tr>
<th>Feature</th>
<th>ISP</th>
<th>CDL</th>
<th>AHPL</th>
<th>DDL</th>
</tr>
</thead>
<tbody>
<tr>
<td>1) Software</td>
<td>PDP-10 BLISS</td>
<td>Man-For-Trans/Assembly</td>
<td>CDC 6600 Fortran</td>
<td>Harris 6024 Fortran</td>
</tr>
<tr>
<td>2) Level of Description</td>
<td>PDP-10 BLISS</td>
<td>Man-For-Trans/Assembly</td>
<td>CDC 6400 Assembler</td>
<td>Harris 6024 Fortran (partial)</td>
</tr>
<tr>
<td>3) Modularity</td>
<td>no</td>
<td>no</td>
<td>yes</td>
<td>no</td>
</tr>
<tr>
<td>4) Logic Generation</td>
<td>no</td>
<td>not very well</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>5) Programming Ease</td>
<td>difficult</td>
<td>easy</td>
<td>difficult</td>
<td>difficult</td>
</tr>
</tbody>
</table>

TABLE IV

<table>
<thead>
<tr>
<th>Feature Description</th>
<th>Time (s)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Average time to simulate an instruction</td>
<td>0.23</td>
</tr>
<tr>
<td>Number of instructions to assemble an instruction</td>
<td>0.8 K</td>
</tr>
<tr>
<td>CPU time for assembling a 20 instruction program</td>
<td>8000 s</td>
</tr>
</tbody>
</table>

Note: K = 1024
Figure 2(a) : Serial Twos Complementer Hardware Structure
TRANSLATION

*MAIN
1 C **START**
2 REGISTER 1 (L = 0)
3 SWITCH 1 (0 -> OFF)
4 C **CONTROL**
5 REGISTER 2 (Z = 0)
6 CLOCK
7 C **PROC. SOUN**
8 /5/? (U1) = 1, C = 0, Z = 0
9 /1/P/S (S = E) OR THEN (S = K(U), K(U) = K (I = 0)) ELSE
   (K = K(U) + K(I = 0)) IF (C.E = 0) THEN (I = 0)
   ELSE (C = C + 1)
10 END

SIMULATE

*OUTPUT
11 /OUTPUT/ LABEL(1) = (L, U, S) 1
12 *SWITCH 1 = 1, S = U
13 *LOAD
14 K = 5
15 *SIN 20

Figure 2(b) : CDL Description
Figure 3: Controller for the Twos Complementer
Figure 4(a) : Twos Complementer Simulation Results for R = (05)\textsubscript{8}
OUTPUT OF SIMULATION - OCTAL

SWITCH TRANSITION AT LABEL CYCLE 1

\[ \text{S}_{11} \rightarrow \text{ON} \]

\[ \begin{align*}
R & = 21 & C = 0 & S = 0 & I = 1 \\
\text{LABEL CYCLE 1} & & \text{TRUE LABELS} & \text{CLOCK TIME 1} \\
R & = 50 & C = 1 & S = 1 & I = 1 \\
\text{LABEL CYCLE 2} & & \text{TRUE LABELS} & \text{CLOCK TIME 2} \\
R & = 64 & C = 2 & S = 1 & I = 1 \\
\text{LABEL CYCLE 3} & & \text{TRUE LABELS} & \text{CLOCK TIME 3} \\
R & = 72 & C = 3 & S = 1 & I = 1 \\
\text{LABEL CYCLE 4} & & \text{TRUE LABELS} & \text{CLOCK TIME 4} \\
R & = 75 & C = 4 & S = 1 & I = 1 \\
\text{LABEL CYCLE 5} & & \text{TRUE LABELS} & \text{CLOCK TIME 5} \\
R & = 56 & C = 5 & S = 1 & I = 1 \\
\text{LABEL CYCLE 6} & & \text{TRUE LABELS} & \text{CLOCK TIME 6} \\
R & = 57 & C = 5 & S = 1 & I = 0 \\
\end{align*} \]

SIMULATION ENDS AFTER 6 REPETITIONS
FINAL LABEL CYCLE IS:

\[ \text{6} \]

Figure 4(b) : Twos Complementer Simulation Results for \( R = (21)_{8} \)
Figure 5(a) : Minicomputer Bus Structure
TRANSLATION

*MAIN*
1 LOAD REGISTERS II, ARK(0-7), MRR(0-11), PC(0-7), ACC(0-11), IR(11), X(0-11) READ ON X: 2 SAVE REGISTERS IR(vi) = IR(0-11), LATCH = IR(0) CMPLT = IR(4-11) 3 READ ON X: 4 SAVE REGISTERS 5 SWITCHEP = START(1, OFF), IF = IR(0-11), STATE = ON 6 LOAD ON X: 7 CHC(1,R) = K(0), LO-K(1), LO-Z(2), WH = K(3), JR = K(4), JMP = K(5), 8 RLT = K(0), RLT = K(7) 9 LOAD ON X:
   C **** INITIALIZATION
   8 /RUN(X) = ACC = U, Mem[PC], IR = OFF, Mem = A = L = START = OFF, IR = ON, STATE = F
   C **** FIRST THREE MINOR CYCLES OF FETCH
   9 /RUN(X) = STATE(R) = P(L) / MEM = F
   10 /RUN(X) = STATE(R) = P(L) / PC = P(L) + 1, Mem = R(4-11)
   11 /RUN(X) = STATE(R) = P(L) / IR = Mem
   C **** FOURTH FETCH MINOR CYCLE FOR SET "HALT" INSTRUCTION
   C **** DEFER STATE IF IN(HALT) EXECUTE STATE IF NOT
   12 /RUN(X) = STATE(R) = P(L) + 1 = (IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, IR, I
<table>
<thead>
<tr>
<th>Code</th>
<th>Mnemonic</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>AND</td>
<td>(ACC) * (Mem) → ACC  AND Memory</td>
</tr>
<tr>
<td>1</td>
<td>TAD</td>
<td>(ACC) + (Mem) → ACC  ADD</td>
</tr>
<tr>
<td>2</td>
<td>ISZ</td>
<td>Increment memory and skip next instruction, if zero.</td>
</tr>
<tr>
<td>3</td>
<td>DCA</td>
<td>Deposit and clear ACC.</td>
</tr>
<tr>
<td>4</td>
<td>JSR</td>
<td>Jump to Subroutine, (PC) → MP(0)</td>
</tr>
<tr>
<td>5</td>
<td>JMP</td>
<td>Jump</td>
</tr>
<tr>
<td>6</td>
<td>RET</td>
<td>Return</td>
</tr>
<tr>
<td>7</td>
<td>HLT</td>
<td>Halt</td>
</tr>
</tbody>
</table>

NOTE: ( ) indicates "Contents of"
<table>
<thead>
<tr>
<th>Memory Location</th>
<th>Assembly</th>
<th>Binary</th>
<th>Decimal</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>AND 5</td>
<td>000 0 00000101</td>
<td>5</td>
</tr>
<tr>
<td>11</td>
<td>L1</td>
<td>TAD* 6</td>
<td>000 1 00000110</td>
</tr>
<tr>
<td>12</td>
<td>ISZ 6</td>
<td>010 0 00000110</td>
<td>1030</td>
</tr>
<tr>
<td>13</td>
<td>ISZ 4</td>
<td>010 0 00000100</td>
<td>1028</td>
</tr>
<tr>
<td>14</td>
<td>JMP L1</td>
<td>101 0 00001011</td>
<td>2571</td>
</tr>
<tr>
<td>15</td>
<td>DCA 7</td>
<td>011 0 00001111</td>
<td>1543</td>
</tr>
<tr>
<td>16</td>
<td>HLT</td>
<td>111 0 00000000</td>
<td>3584</td>
</tr>
</tbody>
</table>

Figure 5(d): Program to Add Four Integers
<table>
<thead>
<tr>
<th>Address</th>
<th>Contents</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>5</td>
</tr>
<tr>
<td>1</td>
<td>6</td>
</tr>
<tr>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>3</td>
<td>8</td>
</tr>
<tr>
<td>4</td>
<td>-3</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>-</td>
</tr>
<tr>
<td>8</td>
<td>-</td>
</tr>
<tr>
<td>9</td>
<td>-</td>
</tr>
<tr>
<td>10</td>
<td>5</td>
</tr>
<tr>
<td>11</td>
<td>774</td>
</tr>
<tr>
<td>12</td>
<td>1030</td>
</tr>
<tr>
<td>13</td>
<td>1028</td>
</tr>
<tr>
<td>14</td>
<td>2571</td>
</tr>
<tr>
<td>15</td>
<td>1543</td>
</tr>
<tr>
<td>16</td>
<td>3584</td>
</tr>
</tbody>
</table>

Figure 5(e): Memory Map
Figure 6: CADAT System
End of Document