Dr. rer. nat. DRUCKSACHE R. Karl-Adolf Zech Diplom-Mathematiker Schliemannstrasse 28 Berlin DDR - 1058 German Democratic Republic Dr. rer. nat. Schliemannstrasse 28 R. Karl-Adolf Zech Berlin Diplom-Mathematiker DDR - 1058 German Democratic Republic Consultant Software Engineer Deas Dr. Maraddal, free I should be very obliged to you for sending me a copy of your paper entitled: A functional model of RT Dex C5-88-16 JAW 1 , 1989 Thanking you in advance, yours sincerely, a. m July ## 15101 ## Printing Requisition / Graphic Services Please complete unshaded areas on form as applicable. TITLE OR DESCRIPTION - Distribute copies as follows: White and Yellow to Graphic Services. Retain Pink Copies for your records. - On completion of order the Yellow copy will be returned with the printed material. - Please direct enquiries, quoting requisition number and account number, to extension 3451. | A Func | ctinnal Model of R | egister-Transf <b>e</b> r I | Designs | CS-8 | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Oct. 28 | ONED | DATE REQUIRED | | | ACCOUN <b>4</b> , <b>1</b> | | 6 4 1 | | REQUISITIONER- | | PHONE <b>4430</b> | | SI | GNING AUTHOR | market | | | MAILING | NAME<br>Sue DeAngelis | DEPT. | | BLDG. | & ROOM NO. | X DELIVER | | | the ¡<br>Univ | reby agree to assume all reprocessing of, and reproductiversity of Waterloo from any essed as a result of this re | ction of, any of the materia<br>/ liability which may arise | ils herein requested.<br>from said processin | I further | agree to indemr | offy and hold blame<br>acknowledge that m | less the<br>aterials | | NUMBER<br>OF PAGES | 25 NUMBE | 20 | NEGATIVES | i i i je koje koje<br>Li je je pristori | QUANTITY | OPER. L<br>NO. TIME | ABOUR<br>CODE | | TYPE OF PAPER | | | ── | Administration | | | | | PAPER SIZE | 8½ x 14 11 x 17 | | - F,L,M | | | | C <sub>1</sub> 0 <sub>1</sub> 1 | | PAPER COLOUR | | BLACK | F L M | | | | | | PRINTING | NUI | MBERING<br>FROM TO | [F <sub>I</sub> L <sub>i</sub> M j | 111 | | | [C <sub> </sub> 0 <sub> </sub> 1 | | BINDING/FINISH | ING 3 down left Hai | de<br>HED PLASTIC RING | PMT | | | | G 0 1 | | FOLDING/<br>PADDING | CU<br>SIZ | TTING | $ P_1M_1T_{-1-1}$ | | | | Salar Salar Salar | | Special Instruct | | | P M T | | | | | | Math | P <sub>[M1</sub> T] | | | | | | | | riacii | fronts and backs | encropeda | PLT | 111 | | | P 0;1 | | | | | | | | | ] [P]0]1 | | | | | | | | | P_0_1 | | | | | STOCK | South a season was a Sung<br>of an appropriate to the own | | e de la como com<br>La como de la de<br>La como de la | The second secon | | COPY CENTRE | | OPER. MACH. | | | t de State de La State de la State<br>La companya de la co | | | | erie gewennen gewennen gewennen gewennen.<br>Die gewennen ge | | NO. BLOG. NO. | | 114 | | | | | DESIGN & PAS | TE-UR | OPER LABOUR<br>NO. TIME CODE | Section of the sectio | | | | | | | | $\lfloor \lfloor \lfloor \lfloor \lfloor \lfloor \rfloor \rfloor \rfloor \rfloor \rfloor D_1 0$ | | | | | 0 0 1 | | | | <u> </u> | RINIG | | | | B 0,1 | | | | | R <sub>I</sub> N <sub>I</sub> G | E a H | | | B <sub> </sub> 0,1 | | TYPESETTING | 그래요, 이 역하고, 학교에 보냈다면 된다. | 11 | | | | | B <sub> </sub> 0 <sub>1</sub> 1 | | P <sub>I</sub> A <sub>I</sub> P <sub>I</sub> O <sub>1</sub> O <sub>1</sub> O | | <u> </u> | | | | | Service States | | $ P_{i}A_{i}P 0_{i}0_{i}0_{i}0_{i}0_{i} $ | | | | | | | Bon | | $P_1A_1P_0_10_1$ | $\mathbf{b}_1 \mathbf{o}_1 \mathbf{o}_1 $ | | 11 UUTSIDE SER | 141053 | | | and the second s | | PROOF<br> P <sub> </sub> P <sub>1</sub> F | | | | | | | and the state of t | | F <sub>i</sub> R <sub>i</sub> F <sub> 1</sub> | | | | | | Service of the servic | e de la proposition de la company comp | | P.B.F | | | | | | COST | hes es a servicion of | # A Functional Model of Register-Transfer Designs Farhad Mavaddat Dept. of Computer Science University of Waterloo Research Report CS-88-16 October, 1988 ## A Functional Model of Register-Transfer Designs Farhad Mavaddat VLSI Group Department of Computer Science University of Waterloo Waterloo, Ontario, Canada #### **ABSTRACT** We propose a strongly-typed functional model of register-transfer-level design specifications. The model is influenced by Gordon's register-transfer model of digital design and, compared to it, is presented from a more intuitive point of view, which in a way is closer to the reality of the RT design. We use the typed nature of the design environment to develop a semantic model for our SDC design notation, reported earlier, and to enforce correct composition of SDC-based designs. The model can be used for design specification purposes as well as for analysing and reasoning about designs. ## A Functional Model of Register-Transfer Designs Farhad Mayaddat VLSI Group Department of Computer Science University of Waterloo Waterloo, Ontario, Canada #### 1. Motivation Register-Transfer (RT) based designs enjoy a high degree of structural regularity, which contributes to their acceptance as suitable models of VLSI design. This regularity is manifested by the explicit separation of a design into a PLA-type control-part and a slice-based data-path-part, and leads to an efficient placement and routing scheme. Layout efficiency and regularity has been the main motivation behind a number of silicon compilation activities in the past,<sup>2-4</sup> and will likely continue to contribute to future developments. Theoretical interest in RT-level modeling has also gained momentum over the last few years<sup>5, 6</sup> and, among others, Gordon's functional model<sup>5</sup> has received special attention. Unfortunately, that model (among others) does not capture the above-mentioned regularities in an explicit form and so, fails to act as a direct representation of the corresponding RT design. It is our belief that for a design abstraction to gain acceptance, there should be a one-to-one link between the objects of the design and the elements of the model, similar to the relationship between the logic-gate-based designs and their corresponding Boolean algebra model. It is the purpose of this report to adapt a modified and extended version of Gordon's model to the direct capture of digital designs. To achieve this, we apply the model to the SDC design primitives<sup>1, 7</sup> and show that SDC-based designs can be modeled in a direct, one-to-one form, using the proposed functional model. ## 2. Defining Combinational Modules Let **T** be the set of basic signal types used in communication with a device. We define an m-input, n-output ( $m \times n$ -put) combinatorial device D, shown in Figure 1, to be of type: $$D: (t_1 \times t_2 \times \cdots \times t_m) \to (t_{m+1} \times t_{m+2} \times \cdots \times t_{m+n})$$ (1) if $t_1, t_2, \dots, t_{m+n} \in T$ represent the types of values appearing at the m input and the n output ports of device D respectively. We define the behavior of D by: $$D = \lambda(\eta_1, \eta_2, \cdots, \eta_m) \cdot (E_1, E_2, \cdots, E_n); \tag{2}$$ where the right side of (2) is a short form for: $$\lambda(\eta_1,\eta_2,\cdots,\eta_m)$$ $E_i$ , $1 \leq i \leq n$ $\eta_j: t_j \in \mathbb{T}$ , $1 \le j \le m$ is the *jth* input port's value, and $g_k: (t_1 \times t_2 \times \cdots \times t_m) \to t_{m+k}$ , defined by $g_k = \lambda(\eta_1, \eta_2, \cdots, \eta_m)$ . $E_k$ , $1 \le k \le n$ , defines the *kth* output-port's value. Figure 1 ## 3. Defining Sequential Circuits At every state, the behavior of a Mealy-type sequential machine B, shown in Figure 2, has two components. First, its combinational behavior, $B_{cmb}$ , under the influence of the current state and port inputs, and second, its next state behavior, $B_{seq}$ , under the influence of the state and the port inputs at the time of transition to the next state. Therefore, the behavior of an $m \times n$ -put, q-state sequential machine B, at state $(s_1, s_2, \dots, s_q)$ , $s_i: t_i \in T$ , $1 \le i \le q$ , is modeled by two combinational circuits of types: $$B_{cmb} : (t_1 \times t_2 \times \cdots \times t_q \times t_{q+1} \times t_{q+2} \times \cdots \times t_{q+m}) \rightarrow (t_{q+m+1} \times t_{q+m+2} \times \cdots \times t_{q+m})$$ $$(3)$$ and, $$B_{seq} : (t_1 \times t_2 \times \cdots \times t_q \times t_{q+1} \times t_{q+2} \times \cdots \times t_{q+m}) \to (t_1 \times t_2 \times \cdots \times t_q)$$ $$(4)$$ and is defined by: $$\begin{cases} B_{cmb} \\ B_{seq} \end{cases} = \lambda (\eta_1, \eta_2, \dots, \eta_q, \eta_{q+1}, \dots, \eta_{q+m}) \cdot \begin{cases} (E_1, E_2, \dots, E_n) \\ (F_1, F_2, \dots, F_q) \end{cases} (5)$$ A few observations are appropriate at this point. - $E_1, E_2, \dots, E_n$ are the *n* output port values produced in response to the corresponding input-port and input-state values at all times. - $F_1, F_2, \dots, F_q$ are the q next-state values produced in response to the corresponding input-port and input-state values at every step. They are evaluated at the time of the transition to the next state. - The q+m inputs represent the m input-port (environment) and q input-state values. To distinguish between the state and the port inputs we (sometimes) move the input-state bound variables to the left of the equality symbol, while keeping the environment inputs on the right side of the definition. - We write $B(s_1, s_2, \dots, s_q)$ to represent module B at state $(s_1, s_2, \dots, s_q)$ , and $B(F_1, F_2, \dots, F_q)$ , to define a next state $(F_1, F_2, \dots, F_q)$ for B, where $F_j: t_j \in T$ , $1 \le j \le q$ is the new value for the *jth* state variable. Combining the two components of (5) into a single definition, and following the new practice of separating the bound variables, we write $$B(s_{1}, s_{2}, \cdots, s_{q}) = \lambda(\eta_{1}, \eta_{2}, \cdots, \eta_{m}).$$ $$((E_{1}, E_{2}, \cdots, E_{n}), B(F_{1}, F_{2}, \cdots, F_{q}))$$ (6) to represent the behavior of B and re-write (3) and (4) as $$B_{cmb}$$ $(s_1, s_2, \dots, s_q) = \lambda(\eta_1, \eta_2, \dots, \eta_m) \cdot (E_1, E_2, \dots, E_n)$ (7) and $$B_{seq} (s_1, s_2, \dots, s_q) = \lambda(\eta_1, \eta_2, \dots, \eta_m) \cdot (F_1, F_2, \dots, F_q)$$ (8) to represent B's combinational and sequential behaviors, respectively. ## 4. Composite Modules So far we have concentrated on the definition of primitive modules, or the leaf cells.<sup>8</sup> It is the purpose of this section to propose a formalism for the definition of composite modules in terms of the instances of primitive and/or other (possibly predefined) composite modules. In the context of a composite module, we refer to the lower level instances as its sub-modules. An $m \times n$ —put composite module $\mathbf{f}^c$ is defined as the interconnection of s submodules $\mathbf{f}^0$ , $\mathbf{f}^1$ , $\cdots$ , $\mathbf{f}^{s-1}$ , and a (hypothetical) $n \times m$ —put environment module $\mathbf{f}^s$ , where the input and output ports of $\mathbf{f}^s$ respectively define the output and the input ports of $\mathbf{f}^c$ , as shown in Figure 3. Furthermore, we define: - I = $\bigcup_{i=0}^{s} I^{i}$ , O = $\bigcup_{i=0}^{s} O^{i}$ , as the set of internal input and the output ports respectively, where $I^{i}$ , $0 \le i \le s$ , and $O^{i}$ , $0 \le i \le s$ , are the respective sets of input and output ports of the *ith* module, and - $P = \{p_1, p_2, \dots, p_t\}$ as the set of *nets* used in connecting the submodules, such that $h: O \cup I \rightarrow P$ is a total function assigning a single *net* to every port, $h: O \rightarrow P$ is *one-to-one*, and $h: I \rightarrow P$ is *onto*. To capture the *net* connections of a module, say $f^i$ ( $m^i \times n^i - put$ , $q^i - state$ ), in a functional form, we write $$(y_1, y_2, \dots, y_{n^i}) = \mathbf{f}_{cmb}^i(s_1, s_2, \dots, s_{q^i})(x_1, x_2, \dots, x_{m^i})$$ (9) as a short form for $$y_{j} = (\lambda(\eta_{1}, \eta_{2}, \cdots, \eta_{q^{i}}, \eta_{q^{i}+1}, \eta_{q^{i}+2}, \cdots, \eta_{q^{i}+m^{i}}) \cdot E_{j})$$ $$(s_{1}, s_{2}, \cdots, s_{q^{i}}, x_{1}, x_{2}, \cdots, x_{m^{i}}) \quad 1 \leq j \leq n^{i} ,$$ $$(10)$$ Figure 3 where $$\mathbf{f}_{cmb}^{i} = \lambda(\eta_{1}, \eta_{2}, \dots, \eta_{a^{i}}, \eta_{a^{i}+1}, \eta_{a^{i}+2}, \dots, \eta_{a^{i}+m^{i}}) \cdot (E_{1}, E_{2}, \dots, E_{n^{i}}),$$ and $y_j \in h(O^i)$ , $0 \le j \le n^i$ and $x_j \in h(I^i)$ , $0 \le j \le m^i$ are the values of the *nets* connected to the corresponding ports. Thus, the behavior of the module $\mathbf{f}^c$ , composed of the interconnection of submodules: $\mathbf{f}^0$ , $\mathbf{f}^1$ , $\cdots$ , $\mathbf{f}^s$ , using the connection nets P, can be defined as: $$\mathbf{f}^{c}(S^{1}, S^{2}, \cdots, S^{s}) = \lambda(h(O^{s})) \cdot (\mathbf{rec})$$ $$(Y^{i} = \mathbf{f}^{i}_{cmb}(S^{i})(X^{i}) \quad 1 \le i \le s-1)$$ $$\mathbf{in}(h(I^{s}), \mathbf{f}^{c}(\mathbf{f}^{i}_{seq}(S^{i})(X^{i}) \quad 1 \le i \le s-1))$$ (11) where $$Y^{i} = (y_{1}^{i}, y_{2}^{i}, \dots, y_{n^{i}}^{i}), y_{i}^{i} \in P - h(O^{s}), 1 \le i \le n^{i}, 1 \le i \le s-1,$$ and $$X^{i} = (x_{1}^{i}, x_{2}^{i}, \cdots, x_{m^{i}}^{i}), x_{j}^{i} \in P, \quad 1 \leq j \leq m^{i}, 1 \leq i \leq s,$$ are the *net* values, $S^i = (s_1^i, s_2^i, \dots, s_{q^i}^i)$ is the set of states of $\mathbf{f}^i$ , $q^i$ is the number of state variables in $\mathbf{f}^i$ , $1 \le i \le s$ , and **rec** and **in** are defined as in. ## 5. The SDC Model of Register-Transfer Design Let $T = \{S, C, D\}$ be the set of signal types used in the design of a register-transfer-based design, where: - S is the type of signal indicating the truth values of the assertions made about the status of the *data-path*. - C is the type of signal selecting among the path alternatives inside the data-path. - **D** is the type of signal carrying data values among the path *slice* components. Such data values depend on the width of *slice* being defined. For example, for a binary *slices*, we have $D_b = \{0, 1\}$ , and in case of a decimal slice, we have $D_d = \{0, 1, 2, 3, 4, 5, 6, 7, 8, 9\}$ . In the remainder of this report we will use small letter identifiers as variables ranging over the above sets of values and ' $\langle \rangle$ ', '[]', and '{} ' to enclose S, C, and D type variables, respectively. We now introduce four design primitives which constitute the building blocks of our SDC model. #### 5.1. The Selector-Slice Primitive A selector—slice sel, Figure 4, is a combinational device of type sel: $D \times D \times C \rightarrow D \times C$ , defined by: $$sel = \lambda \{d_1, d_2\}[c] \cdot \{c \rightarrow d_2, d_1\}[c], \tag{12}$$ where ' $\rightarrow$ ', in the context of an expression, stands for the *if\_then\_else* operator. Definition (12) indicates that the output of a *selector* is equal to one of its two data inputs and the selection is made according to the value of input $c: \mathbb{C}$ . Figure 4 #### 5.2. Functional Primitives Functional -slices are a family of $(m + k) \times (n + k)$ -put combinational devices of type $(\mathbf{D}^m \times \mathbf{S}^k) \to (\mathbf{D}^n \times \mathbf{S}^k)$ , as shown in Figure 5, where: m > 1, $1 \ge k \ge 0$ , $1 \ge n \ge 0$ , and $n + k \ge 1$ . Thus, the behavior of a functional primitive can be defined by one of the following three definition schemes: $$\lambda \{ d_1, d_2, \cdots, d_m \} \langle s \rangle . \{ E \} \langle F \rangle$$ (13) $$\lambda \{ d_1, d_2, \cdots, d_m \} \langle s \rangle . \langle F \rangle$$ (14) $$\lambda \{ d_1, d_2, \cdots, d_m \} . \{ E \}.$$ (15) Depending on the nature of application, the number and type of operators used in E and F may vary. For example, multiplication might not be allowed when the model is used as the input to a silicon compiler, while its use in simulation applications might be allowed. In a similar way, addition might prove to be un-acceptable when the model is used for reasoning about hardware, but acceptable when the model is intended for silicon implementation. We now present a few typical functional-slices specified according to the techniques discussed in (13)-(15). ## Ex.1- Binary 'and' Slice: A binary and slice is a $D_b^2 \rightarrow D_b$ type device defined by: and $$= \lambda \{a, b\}. \{a \wedge b\}.$$ (16) ## Ex.2- Binary 'equal' Slice: A binary equal slice is a $D_b^2 \times S \rightarrow S$ type device defined by: equal = $$\lambda \{a, b\} \langle s \rangle . \langle s \wedge \overline{(a \oplus b)} \rangle$$ , (17) where a and b are the slice's data inputs, s is the status input indicating the result of comparisons at more significant slices, and $s \wedge \overline{(a \oplus b)}$ is the status output to the less significant neighbouring slice. #### Ex.3- Decimal 'add' Slice: A decimal add slice is a $D_d^2 \times S \rightarrow D_d \times S$ type device defined by: $$add = \lambda \{ a, b | \langle s \rangle : \{ (a+b+num(s)) \mod 10 \} \langle num(s) + a+b > 9 \rangle (18)$$ Where a and b are the slice's data inputs, s is the carry input from the less significant neighbouring slice, $(a + b + num(s)) \mod 10 \in \mathbf{D}$ is the data output, $(num(s) + a + b > 9) \in \mathbf{S}$ is the carry to the more significant neighbouring slice, and $num: \mathbf{S} \to \mathbf{D}$ is a function that produces the numerical equivalent of the status input signal. #### 5.3. The Controller Primitives Controllers are a family of $m \times n$ —put devices of type $\mathbb{C}^p \times \mathbb{S}^q \to \mathbb{C}^s \times \mathbb{S}^t$ , where m = p + q and n = s + t, $p \ge 0$ , $q \ge 0$ , $s \ge 1$ , and $t \ge 0$ ; a typical way of defining this might be as: $$\lambda[\eta_1, \eta_2, \cdots, \eta_p] \langle \eta_{p+1}, \eta_{p+2}, \cdots, \eta_{p+q} \rangle \cdot [B_1, B_2, \cdots, B_s]$$ $$\langle S_1, S_2, \cdots, S_t \rangle,$$ $$(19)$$ where $B_i$ , $1 \le i \le s$ , and $S_i$ , $1 \le i \le t$ , are the sum of the products of the bound variables and their complements. ## 5.4. The Unit Delay Primitive A unit-delay del is a $1\times 1-put$ , single state, polymorphic <sup>10</sup> sequential device of type del: (\* $\times$ \*) $\rightarrow$ (\* $\times$ \*), shown in Figure 6 and defined by: $$del(n) = \lambda(i) \cdot (n, del(i))$$ (20) Figure 6 ## 6. Typed Connections We extend the concept of typed ports to that of typed *nets*. This assumes that the *nets* of a particular type connect the ports of the same type. We continue to use the parenthesis pairs [], and $\{\}$ and $\langle \rangle$ , to enclose *control*, *data*, and *status nets*, respectively. In this spirit we partially re-write (9) as: $$\{y_1, y_2, \dots, y_{n_d}\} = \mathbf{f}_{cmb}(s_1, s_2, \dots, s_q)(x_1, x_2, \dots, x_m)$$ (21) to emphasize the output data conections of f, where $n_d$ is the number of data outputs of f. In a similar way, one may specify the *control* and *status* type connections, or extend the definition into a single statement of the form: $$\{Y_D\}[Y_C]\langle Y_S\rangle = \mathbf{f}_{cmb}(S)\{X_D\}[X_C]\langle X_S\rangle \tag{22}$$ so as to re-write (9) in a completely-typed form. We also write: $$\{\mathbf{f}_{cmb}(S)\{X_D\}[X_C]\langle X_S\rangle\}, [\mathbf{f}_{cmb}(S)\{X_D\}[X_C]\langle X_S\rangle],$$ and $$\langle \mathbf{f}_{cmb}(S) \{ X_D \} [X_C] \langle X_S \rangle \rangle$$ in order to refer to the *net* sets: $Y_D$ , $Y_C$ , and $Y_S$ , respectively. Extending this convention to the sequential behavior, we write: $$\mathbf{f}_{seq}(S)\{X_D\}[X_C]\langle X_S\rangle, \tag{23}$$ to refer to the next-state values of f. Finally, we call a composition a data- (or control-, or status-) composition, if only data (or control, or status) type nets are used in making the connections. ## 7. Register-Transfer Slices A Register-Transfer (RT) slice is defined as the data-composition of primitives and/or other data-composed sub-modules. This guarantees that the control and status ports of an RT-slice remain unconnected. We now present a number of RT slice examples. • The m-bit "register-counter" slice: Following are the behavioral definitions of three submodules: sel, del, and inc used in the composition of the m-bit "register-counter" slice shown in Figure 7. sel = $$\lambda \{ in_1, in_2 \} [c] . \{ c \rightarrow in_2, in_1 \} [c]$$ del $(n) = \lambda \{ in \} . (\{ n \}, del (in ))$ inc = $\lambda \{ in \} . \{ (in +1) \mod 2^m \}.$ Next we write the composition rule for the m-bit "register-counter" using the above sub-modules, the nets $y_1$ , $y_2$ , $y_3$ , in, $c_{in}$ , and $c_{ot}$ . According to the (11), count $$(n) = \lambda \{ in \} [c_{in}]$$ . (rec $(\{y_1\} [c_{ot}] = \text{sel}_{cmb} \{ y_3, in \} [c_{in}] ;$ $\{y_2\} = \text{del}_{cmb} (n) \{y_1\} ;$ $\{y_3\} = \text{inc}_{cmb} \{y_2\} )$ in $(\{y_2\} [c_{ot}], \text{ count } (\text{del}_{seq} (n) (y_1))) )$ . This can be expanded to count (n) = $$\lambda \{ \text{in } \} [c_{\text{in}}] \cdot (\text{rec } ($$ $$y_1 = c_{in} \to in , y_3;$$ $$c_{ot} = c_{in};$$ $$y_2 = n;$$ $$y_3 = (y_2 + 1) \mod 2^m ) \text{ in } (\{y_2\} [c_{\text{ot}}], \text{ count } (y_1))),$$ and reduced to count $$(n) = \lambda \{ in \} [c_{in}] \cdot (\{ n \} [c_{in}] , count (c_{in} \rightarrow in , (n+1) mod 2^m).$$ Verbally, count is a single state (n) sequential device with one data input (in), one data output, one control input $(c_{in})$ and one control output. The counter's next state value is controlled by the value of the control input which selects between (n+1) mod $2^m$ and in as the next state value. ## The "shift-register" slice: The following is the behavioral definition of one slice of a shift register shown in Figure 8. The sub-modules sel, and del used in the composition of the "shift-register" slice are defined as usual. The shift slice is a new functional primitive defined as $$\mathbf{shift} = \lambda \{ in_1 \} \langle in_2 \rangle \cdot \{ in_2 \} \langle in_1 \rangle.$$ Next, we write the composition rule for forming the "shift register" slice using the above sub-modules and the nets $y_1$ , $y_2$ , $y_3$ , $y_4$ , in, $c_{in_1}$ , $c_{in_2}$ , $s_{in}$ , $c_{ot_1}$ , $c_{ot_2}$ , and $s_{ot}$ . According to the (11), This is expanded to shift -register ( $$n$$ ) = $\lambda \{in \} [c_{in_1}, c_{in_2}] \langle s_{in} \rangle$ . (rec ( $y_1 = c_{in_1} \rightarrow in , y_4$ ; $c_{ot_1} = c_{in_1}$ ; $y_2 = c_{in_2} \rightarrow y_1, y_3$ ; $c_{ot_2} = c_{in_2}$ ; $y_3 = n$ ; $y_4 = s_{in}$ ; $s_{ot} = y_3$ ) in $(\{y_3\} [c_{ot_1}, c_{ot_2}] \langle s_{ot} \rangle$ , shift -register $(y_2)$ )). and reduced to $$\begin{aligned} \text{shift} &-\text{register} \; (\; n\;) = \lambda \{\; in\;\} [c_{in_1},\; c_{in_2}] \langle s_{in}\; \rangle \; . \; (\{\; n\;\} [c_{in_1},\; c_{in_2}] \langle n\; \rangle \; , \\ \\ & \text{shift} \; -\text{register} \; (\; c_{in_2} \longrightarrow (\; c_{in_1} \longrightarrow in\;,\; s_{in}\;),\; n\;\; ). \end{aligned}$$ ## • Hierarchical Design Example: In the following example we first give the behavioral definition of one slice of a register with add capability, called **radd**, shown in Figure 9. We then show the use of this unit in a hierarchical design using two such modules. The sub-modules used in composition of the radd are sel, del, and a binary adder called badd defined by **badd** = $$\lambda \{ in_1, in_2 \} \langle s_{in} \rangle$$ . $\{ in_1 \oplus in_2 \oplus s_{in} \} \langle in_1 \wedge in_2 + in_1 \wedge s_{in} + in_2 \wedge s_{in} \rangle$ . Next, we write the composition rule for forming the **radd** slice, using the above sub-modules, the nets $y_1$ , $y_2$ , $y_3$ , $in_1$ , $in_2$ , $c_{in}$ , $s_{in}$ , $c_{ot}$ , and $s_{ot}$ . According to the (11), This is expanded to radd $$(n) = \lambda \{ in_1, in_2 \} [c_{in}] \langle s_{in} \rangle$$ . (rec $(y_1 = c_{in} \rightarrow in_1, y_3;$ $$\begin{split} c_{ot} &= c_{in} ;\\ y_2 &= y_1 \oplus in_2 \oplus s_{in} ;\\ s_{ot} &= y_1 \wedge in_2 + y_1 \wedge s_{in} + in_2 \wedge s_{in} ;\\ y_3 &= n \end{split}$$ $$in (\{y_3, y_2\}[c_{ot}] \langle s_{ot} \rangle, radd (y_2))), \end{split}$$ and reduced to $$\mathbf{radd} \ (n \ ) = \lambda \{ \ in \ _1, \ in \ _2 \} [c_{in} \ ] \langle s_{in} \ \rangle \ .$$ $$(\{ \ n \ , \ ( \ c_{in} \to in \ _1, \ n \ ) \oplus in \ _2 \oplus s_{in} \ \} [c_{in} \ ]$$ $$\langle ( \ c_{in} \to in \ _1, \ n \ ) \wedge in \ _2 + (c_{in} \to in \ _1, \ n \ ) \wedge s_{in} \ + in \ _2 \wedge s_{in} \ \rangle \ ,$$ $$\mathbf{radd} \ (( \ c_{in} \to in \ _1, \ n \ ) \oplus in \ _2 \oplus s_{in} \ )).$$ A further reduction yields radd $$(n) = \lambda \{in_1, in_2\}[c_{in}] \langle s_{in} \rangle$$ . $$(\{n, (c_{in} \rightarrow in_1, n) \oplus in_2 \oplus s_{in}\}[c_{in}] \}$$ $$\langle (in_2 + s_{in}) \wedge (c_{in} \rightarrow in_1, n) + in_2 \wedge s_{in} \rangle,$$ radd $((c_{in} \rightarrow in_1, n) \oplus in_2 \oplus s_{in})).$ We are now interested in deriving the behavior of the serial connection of two radds, as shown in Figure 10. The following derivations lead to the definition of combined behavior. First, $$\begin{aligned} \mathbf{Dradd} \; (n \; , m \; ) &= \lambda \{in_{\,1}, \; in_{\,2}\}[c_{in_{\,1}}, \; c_{in_{\,2}}] \big\langle s_{in_{\,1}}, \; s_{in_{\,2}} \big\rangle \; . \; (\mathbf{rec} \; (\\ & \{y_{\,1}, \; y_{\,2}\}[c_{ot_{\,1}}] \big\langle s_{ot_{\,1}} \big\rangle = \mathbf{radd} \; _{cmb} \; (n \; ) \{in_{\,1}, \; in_{\,2}\}[c_{in_{\,1}}] \big\langle s_{in_{\,1}} \big\rangle \\ & \{ot_{\,1}, \; ot_{\,2}\}[c_{ot_{\,2}}] \big\langle s_{ot_{\,2}} \big\rangle = \mathbf{radd} \; _{cmb} \; (m \; ) \{y_{\,1}, \; y_{\,2}\}[c_{in_{\,2}}] \big\langle s_{in_{\,2}} \big\rangle ) \\ & \mathbf{in} \; (\{ot_{\,1}, \; ot_{\,2}\}[c_{ot_{\,1}}, \; c_{ot_{\,2}}] \big\langle s_{ot_{\,1}}, \; s_{ot_{\,2}} \big\rangle, \\ & \mathbf{Dradd} \; (\mathbf{radd} \; _{seq} \; (n \; ) \{in_{\,1}, \; in_{\,2}\}[c_{in_{\,1}}] \big\langle s_{in_{\,1}} \big\rangle, \\ & \mathbf{radd} \; _{seq} \; (m \; ) \{y_{\,1}, \; y_{\,2}\}[c_{in_{\,2}}] \big\langle s_{in_{\,2}} \big\rangle))). \end{aligned}$$ This is expanded to Dradd $$(n, m) = \lambda \{in_1, in_2\} [c_{in_1}, c_{in_2}] \langle s_{in_1}, s_{in_2} \rangle$$ . (rec ( $$y_1 = n;$$ $$y_2 = (c_{in_1} \rightarrow in_1, n) \oplus in_2 \oplus s_{in_1};$$ $$c_{ot_1} = c_{in_1};$$ $$s_{ot_1} = (in_2, s_{in_1}) \wedge (c_{in_1} \rightarrow in_1, n) + in_2 \wedge s_{in_1};$$ $$ot_1 = m;$$ $$ot_2 = (c_{in_2} \rightarrow y_1, m) \oplus y_2 \oplus s_{in_2};$$ $$c_{ot_2} = c_{in_2};$$ $$s_{ot_2} = (y_2 + s_{in_2}) \wedge (c_{in_2} \rightarrow y_1, m) + y_2 \wedge s_{in_2})$$ $$\text{in } (\{ot_1, ot_2\} [c_{ot_1}, c_{ot_2}] \langle s_{ot_1}, s_{ot_2} \rangle, \text{ Dradd } ($$ $$(c_{in_1} \rightarrow in_1, n) \oplus in_2 \oplus s_{in_1},$$ $$(c_{in_2} \rightarrow y_1, m) \oplus y_2 \oplus s_{in_2}),$$ and reduced to $$\begin{aligned} \mathbf{Dradd} \; (\; n\;, m\;) &= \lambda \{in_{\;1},\; in_{\;2}\}[c_{in_{\;1}},\; c_{in_{\;2}}] \langle s_{in_{\;1}},\; s_{in_{\;2}} \rangle \; . \; (\\ & \{m\;,\; (c_{in_{\;2}} \!\!\to\! n\;,\; m\;) \oplus ((c_{in_{\;1}} \!\!\to\! in_{\;1},\; n\;) \oplus in_{\;2} \oplus s_{in_{\;1}}) \oplus s_{in_{\;2}} \} \\ & [c_{in_{\;1}},\; c_{in_{\;2}}] \\ & \; \langle (in_{\;2},\; s_{in_{\;1}}) \wedge (c_{in_{\;1}} \!\!\to\! in_{\;1},\; n\;) + in_{\;2} \wedge s_{in_{\;1}}, \\ & \; (((c_{in_{\;1}} \!\!\to\! in_{\;1},\; n\;) \oplus in_{\;2} \! \oplus\! s_{in_{\;1}}) + s_{in_{\;2}}) \wedge (c_{in_{\;2}} \!\!\to\! n\;,\; m\;) + \\ & \; ((c_{in_{\;1}} \!\!\to\! in_{\;1},\; n\;) \oplus in_{\;2} \! \oplus\! s_{in_{\;1}}) \wedge s_{in_{\;2}} \rangle, \\ & \; \mathbf{Dradd} \; ((c_{in_{\;1}} \!\!\to\! in_{\;1},\; n\;) \oplus in_{\;2} \! \oplus\! s_{in_{\;1}}, \\ & \; (c_{in_{\;2}} \!\!\to\! n\;,\; m\;) \oplus ((c_{in_{\;1}} \!\!\to\! in_{\;1},\; n\;) \\ & \; \oplus in_{\;2} \! \oplus\! s_{in_{\;1}}) \; \oplus s_{in_{\;2}}))). \end{aligned}$$ #### 8. Multi-Slice Data-Path Definition Given a data—slice f and a positive integer n, an n-wide data-path is formed by concatenating n such slices along their control and status ports, as shown in Figure 11. Therefore, the behavior of an n-wide data-path F is defined by: $$DP (f, n) = F (S^{1}, S^{2}, \dots, S^{n}) = \lambda \{D^{1}, D^{2}, \dots, D^{n}\} [C] .$$ $$(n = 1 \rightarrow (\{f_{cmb}(S^{1})\{D^{1}\}[C] \langle \nabla \rangle \} \langle f_{cmb}(S^{1})\{D^{1}\}[C] \langle \nabla \rangle \rangle, \qquad (24)$$ $$f_{seq}(S^{1})\{D^{1}\} [C] \langle \nabla \rangle ),$$ $$(\{f_{cmb}(S^{n})\{D^{n}\}[C] \langle \langle DP(f, n-1)\{D^{1}, D^{2}, \dots, D^{n-1}\}[C] \rangle \rangle \}$$ $$\langle f_{cmb}(S^{n})\{D^{n}\}[C] \langle \langle DP(f, n-1)\{D^{1}, D^{2}, \dots, D^{n-1}\}[C] \rangle \rangle \rangle,$$ $$f_{seq}(S^{n})\{D^{n}\}[C] \langle \langle DP(f, n-1)\{D^{1}, D^{2}, \dots, D^{n-1}\}[C] \rangle \rangle ),$$ where $S^i = s_1^i$ , $s_2^i$ , $\cdots$ , $s_q^i$ , $1 \le i \le n$ , are the values and q is the length of the state vector of *ith*. slice; $D^i = d_1^i$ , $d_2^i$ , $\cdots$ , $d_m^i$ , $1 \le i \le n$ , are the m data input values; C is the control input vector of each slice; and $\nabla$ is the first slice's status initialization vector. A few observations are in order here. • Since the slices are identical<sup>†</sup>, concatenations can be realized through the abutment<sup>11</sup> of the corresponding layouts. $<sup>\</sup>dagger$ - In practice f can be parametrized and the *ith* slice can receive i as its parameter. - We have assumed that the status information is passed from the lower indexed slices to the higher indexed ones. Assuming that the smallest indexed slice is also the least significant slice (under some number representation scheme), this formulation satisfies the requirements of certain functionals, such as the carry propagations in a sliced adder. - A similar formulation exists for the case where the status signal has to propagate in the opposite direction, for example a sliced comparator. Since *control* signals are simply passed through the slices without any modification, simultaneous flows of both formulations will not lead to infinite recursion, as might be feared. - Definition (24) can be used to extend certain slice properties to that of the data-path itself, through structural induction proof techniques. In the past, designers have assumed this in an implied way and have used the properties of the slice and the corresponding *n*-wide data-paths in an interchangeable form. We also do this in the next example by defining a single slice, and applying the control part to the slice, assuming that the multi-bit version of the data-path leads to the identical behavior. ## 9. A Complete Example The SDC-based graphical representation of a circuit designed to calculate the greatest common divisor (GCD) of two values at its data-input ports ' $in_1$ ' and ' $in_2$ ', and producing the result at its data-output port 'out' is shown in Figure 12. The input values are sampled at the last assertion of the 'r' (reset) control input and the availability of the result is signaled by the first assertion of the 'f' (finish) status output. The hardware follows the usual GCD algorithm of repeatedly subtracting the smaller value from the larger value until the two values match. It is the purpose of this section to develop the functional models of the data-path and the control parts independently, and to combine them to form the total module's behavioral model. We start by applying the composition rule (11) to the data-path. Given functional primitives: eql = $$\lambda \{ a, b \} . \langle a \equiv b \rangle$$ gt = $\lambda \{ b, b \} . \langle a > b \rangle$ sub = $\lambda \{ a, b \} . \{ a - b \}$ and the composite register module $$\operatorname{reg}(a) = \lambda \{ in \} [ld] . (\{ a \}, \operatorname{reg}(ld \rightarrow in, a))$$ the gcd\_path is defined by: $$\gcd_{path}(a, b) = \lambda \{ in_{1}, in_{2} \} [ j, k, la, lb ] . (rec ( \{y_{1}\} = sel_{cmb} \{y_{7}, in_{1}\} [ j ];$$ $$\{y_{2}\} = sel_{cmb} \{y_{7}, in_{2}\} [ j ];$$ $$\{y_{3}\} = reg_{cmb}(a) \{y_{1}\} [ la ];$$ $$\{y_{4}\} = reg_{cmb}(b) \{y_{2}\} [ lb ];$$ $$\langle s_{1}\rangle = eql_{cmb} \{y_{3}, y_{4}\};$$ $$\langle s_{2}\rangle = gt_{cmb} \{y_{3}, y_{4}\};$$ $$\{y_{5}\} = sel_{cmb} \{y_{4}, y_{3}\} [ k ];$$ $$\{y_{6}\} = sel_{cmb} \{y_{3}, y_{4}\} [ k ];$$ $$\{y_{7}\} = sub_{cmb} \{y_{5}, y_{6}\}) in ($$ $$\{y_{3}\} \langle s_{1}, s_{2}\rangle, gcd_{path} (reg_{seq}(a) \{y_{1}\} [ la ],$$ $$(reg_{seq}(b) \{y_{2}\} [ lb ])).$$ Please note that in this example we have used a single *slice* and a data-path of those *slices* in an interchangeable form. As the result, we have assumed that the *status* inputs to the data-path receive proper initialization without explicit reference to them. After expansion and simplifications, gcd\_path behavior reduces to: This completes the definition of the data-path part. The control part is made of two sub-modules: the PLA and the *unit-delay* parts. The PLA realizes the microprogram to be executed by the module. The *unit-delay* holds the state of the control-part. We start by first defining the PLA part, called **pla**, and combine it with a *unit-delay* element to form the complete control-part, called **contunit**. Following are these two steps. $$\mathbf{pla} = \lambda[\mathbf{r}] \langle \mathbf{s}_1, \mathbf{s}_2, \mathbf{c} \rangle . ([\mathbf{c}', \mathbf{j}, \mathbf{k}, \mathbf{la}, \mathbf{lb}] \langle \mathbf{f} \rangle)$$ which is expanded to: $$\mathbf{pla} = \lambda [r] \langle s_1, s_2, c \rangle . ([(\bar{r} \wedge \bar{c} \wedge s_1) \vee (\bar{r} \wedge c), \\ r, (\bar{r} \wedge \overline{s_1} \wedge s_2 \wedge \bar{c}), (r \vee (\bar{r} \wedge \overline{s_1} \wedge s_2 \wedge \bar{c})), \\ (r \vee (\bar{r} \wedge \overline{s_1} \wedge \overline{s_2} \wedge \bar{c}))] \langle \bar{r} \wedge c \rangle)$$ and contunit $$(p) = \lambda [r] \langle s_1, s_2 \rangle$$ . (rec $([y_1, j, k, la, lb] \langle f \rangle = \text{pla}_{cmb} [r] \langle s_1, s_2, y_2 \rangle$ ; $\langle y_2 \rangle = \text{del}_{cmb} (p) [y_1] )$ in $([j, k, la, lb] \langle f \rangle$ , contunit $(\text{del}_{seq} (p) [y_1] )$ ). contunit can be reduced to contunit $$(p) = \lambda[r] \langle s_1, s_2 \rangle . ([r, \overline{r} \wedge \overline{s_1} \wedge s_2 \wedge \overline{p}, r \vee (\overline{r} \wedge \overline{s_1} \wedge s_2 \wedge \overline{p}), r \vee (\overline{r} \wedge \overline{s_1} \wedge \overline{s_2} \wedge \overline{p})]$$ $\langle \overline{r} \wedge p \rangle$ , contunit $((\overline{r} \wedge \overline{p} \wedge s_1) \vee (\overline{r} \wedge p))$ Combining gcd-path and contunit, as shown in Figure 13, to form the complete module, called gcd, leads initially to: $$\gcd(\ a\ , b\ , p\ ) = \lambda \{in_1, in_2\}[\ r\ ]\ .\ (\ \text{rec}\ (\\ \{\ out\ \}\capprox\ s_1, s_2\capped\ \_path\ _{cmb}\ (\ a\ , b\ )\{\ in_1, in_2\}[\ j\ , k\ , la\ , lb\ ];$$ $$[\ j\ , k\ , la\ , lb\ ]\capped\ (\ j\ , k\ , la\ , lb\ ]\capped\ (\ s_1, s_2\capped\ )\$$ $$in\ (\ \{\ out\ \}\capped\ f\ \capped\ , k\ , la\ , lb\ ],$$ $$\gcd(\ \gcd\_path\ _{seq}\ (\ a\ , b\ )\{\ in\ _1, in\ _2\}[\ j\ , k\ , la\ , lb\ ],$$ $$\operatorname{contunit}\ _{seq}\ (\ p\ )[\ r\ ]\capped\ (\ s\ _1, s\ _2\capped\ )));$$ this exapnds to: $$\gcd(a, b, p) = \lambda \{in_1, in_2\}[r] \cdot (rec(a_1, b_2), p) = \lambda \{in_1, in_2\}[r] \cdot (rec(a_2, b_2), p) = a_2 \cdot$$ $$lb = r \lor (\bar{r} \land \bar{s_1} \land \bar{s_2} \land \bar{p});$$ $$f = \bar{r} \land p) \text{ in } (\{out\} \langle f \rangle, \\ \text{gcd } ((la \rightarrow (j \rightarrow in_1, (k \rightarrow (a-b), (b-a))), a), \\ ((lb \rightarrow (j \rightarrow in_2, (k \rightarrow (a-b), (b-a))), b)), \\ (\bar{r} \land \bar{p} \land s_1) \lor (\bar{r} \land p)))),$$ and can eventually be reduces to: $$\gcd(a,b,p) = \lambda \{in_1, in_2\}[r] \cdot (\{a\} \langle \bar{r} \wedge p \rangle, \gcd((r \vee q) \rightarrow (r \rightarrow in_1, (q \rightarrow (a-b), (b-a))), a), \\ ((r \vee q') \rightarrow (r \rightarrow in_2, (q \rightarrow (a-b), (b-a))), b), \\ (\bar{r} \wedge \bar{p} \wedge s_1 \vee (\bar{r} \wedge p)))$$ $$\text{where}$$ $$q = \bar{r} \wedge \overline{(a \equiv b)} \wedge (a > b) \wedge \bar{p}$$ $$q' = \bar{r} \wedge \overline{(a \equiv b)} \wedge \overline{(a > b)} \wedge \bar{p}$$ ## 10. Acknowledgement Useful discussions with Dr. Mantis H. M. Cheng of the University of Victoria, British Columbia, especially on formulating design composition rules in terms of bound and free variables, are gratefully acknowledged, as is funding from the University of Waterloo Operating Grant. #### 11. References - 1. Mavaddat, F., A Model for Register-Transfer Level Design Specification: The SDC Notation, CS-84-34, Department of Computer Science, submitted for publication and under revision, University of Waterloo, Waterloo, Ontario (October 1984). - 2. Johannsen, D., Bristle Blocks: A Silicon Compiler, Proceedings of the 16th. Design Automation Conference, pp. 310-313 (July 1979). - 3. Southard, J. R., MacPitts: An Approach to Silicon Compilation, *IEEE Computer Magazine* 16(12) pp. 74-82 (December 1983). - 4. Anceau, F., CAPRI: A Design Methodology and a Silicon Compiler for VLSI Specified by Algorithms, pp. 15-31 in *Third Caltech Conference on Very Large Scale Integration*, ed. R. Bryant, Computer Science Press, Rockville, Maryland (1983). - 5. M. Gordon, A Model of Register Transfer Systems with Application to Microcode and VLSI Correctness, CSR-82-81, University of Edinburgh, Dept. of Computer Science, Edinburgh, Scotland (March 1981- revised May 1982). - 6. Hafer L. J. and A. C. Parker, A formal Method for Specification, Analysis, and Design of Register-Transfer Level Digital Logic, *IEEE Transactions on Computer-Aided Design* CAD 2(1) pp. 4-18 (January 1983). - 7. Mavaddat, F., An Architecture and Layout for Register Transfer Level IC Design, Report 85-4, Institute for Computer Research, University of Waterloo, Waterloo, Ontario (January 1985). - 8. Rowson, James A., Understanding Hierarchical Design, Ph.D Thesis, California Institute of Technology, Pasadena, California (April 1980). - 9. Landin, P. J., The Mechanical Evaluation of Expressions, Computer Journal 6(4) pp. 308-320 (Jan. 1984). - 10. Cardelli, Luca and Wegner, Peter, On Understanding Types, Data Abstraction, and Polymorphism, *Computing Surveys* 17(4) pp. 471-522 (December 1985). - 11. Carver Mead and Lynn Conway, *Introduction to VLSI Systems*, Addison Wesley, Reading, Mass. (1980).