# EXANOR를 사용한 Three-Level PLA 論 文 32~1~3 # The Three-Level PLA Design Using EXANOR 趙 東 燮\*・李 鍾 元\*\*・黄 熈 隆\*\*\* (Dong-Sub Cho· Jong-Won Rhee·Hee-Yeung Hwang) ### Abstract This paper deals with the three-level PLA constructed by EXCLUSIVE-OR, AND, and OR. (abbreviated as EXANOR). Most PLA circuits have constraints on minimum chip area and minimal input lines. Thus, the reduction of PLA chip area is an important factor in design of logic circuits. In this paper, newly constructed architecture of PLA is proposed and then, its reduction effect is proved theoretically and some of selected examples are illustrated for designing three-level PLA circuits. ### 1. Introduction Programmable logic arrays (PLA's) are known as an approach to implement logic circuits having low production potential [1]-[3]. In this paper, two types of PLA is discussed; two-level PLA and three-level PLA. First of all, the problem to implement PLA are; - 1) the number of inputs - 2) the number of outputs - 3) the number of product term lines - 4) the number of NOT gates - 5) logic time delay In this paper, 3) and 4) are discussed for reduction of PLA size. The three-level PLA using EXANOR is shown in Fig. 1. In section 2, two types of three-level PLA structures are introduced, in section 3, how the three-level PLA is implemented is introduced, and in section 4, implementation of three-level PLA \* 正 會 員:付き大 大學院 電子計算機工學科 博士課程 \*\* 正 會 員:서울大 大學院 電子計算機工學科 硬士課程 \*\*\* 正 會 員:서울大 工大 電子計算機工學科 副教授・工博 \*\*\* 止 智 員: 付き大工大 電子計算機工學科 副教授\*工内接受日字: 1982年 8月 13日 circuits is introduced. And then in section 5, the PLA sizes of two types of PLA are compared with the conventional PLA. Fig. 1. Three-level PLA using EXANOR # 2. Two Types of Three-Level PLA (EXCLUSIVE OR-AND-OR) Three-level PLA which is treated in this paper, is divided into the following two types. TYPE 1: First type of three-level PLA implementation is shown in Fig. 2. and its MOS structure in Fig. 3. Fig. 2. The number of input; 2n Fig. 3. The strusture of EX-OR array As shown in Fig. 2, inputs and their inverted inputs are used. So, the number of input lines is 2n. (where n is the number of input variables) TYPE 2: Second type of three-level PLA implementation is shown in Fig. 4. and its MOS structure is in Fig. 5. The number of input lines is n+2. In this case, NOT gates is needless to be used. Instead, X and X is implemented by X⊙O and Y⊕1, respectively. In every row, EX-OR gate which has MOS elements is located to the first part of PLA. So, the number of MOS's required for circuit design can be reduced. #### 3. How to implement The Three-level PLA In this section, some definitions and theorems are derived and two methods to implement three-level PLA are introduced. Fig. 4. The number of inputs; n+2 Fig. 5. The structure of Ex-OR array ## A. Definitions for implementing three-level PLA An ordinary function $f(x_1, x_2, ..., x_n)$ : $B^n \rightarrow B$ , $B = \{0, 1\}$ , can be represented by a Boolean expression of two-valued variables $x_i$ (i = 1, 2, ..., n). Definition 1) An element of a Bolean algebra B is called a constant on B. Definition 2) A symbol that may represent any one of the elements of B is called a (Boolean) variable on B. Definition 3) There are $22^n$ different mappings which map from the Cartesian Product set $\{0, 1\}^n$ into $\{0, 1\}$ . Definition 4) A literal is defined to be a constant, variable or complemented variable. Definition 5) Let $a = (a_1, a_2, ..., a_n)$ be a constant in $B^n$ . $$f(x_1, x_2, ..., x_n) = f(a_1, a_2, ..., a_n)$$ $$x_1^{a_1}, x_2^{a_2} \dots x_n^{a_n}$$ where $x_i^{a_i} = x_i$ if $a_i = 1$ $\overline{x}_i$ otherwise is called the canonical sum-of-product form, # B. First method to implement three-level PLA of Boolean function First of all, two theorems necessary to implenent first method are derived as follows; Theorem 1] Any AND-OR minterms can be converted into EX-OR-AND-OR minterms: $$\begin{array}{ll} f(x_1,x_2,...,x_n,+,\cdot) = f(x_1,x_2,...,x_n,+,\cdot,\cdot) \\ \text{Proof.} & \text{Let a switching function be } f(x_1,x_2,\ldots,x_n), \\ \text{first n variables are divided into two parts such that } f((x_1),(x_2,x_3,\ldots,x_n)) = f(p_1,P_2) \\ \text{Thus } f(P_1,P_2) = f(r_1,r_2)P_1^{-r_1} \cdot P_2^{-r_2} \text{ where } \\ (r_1,r_2) \text{ is element of } P_1 \times P_2^{-r_3} \text{ and } x \text{ denotes Cartesian Product.} \end{array}$$ The term $P_1^{r_1} \cdot P_2^{r_2}$ can be replaced by $$P_{1}^{r_{1}} (P_{1}^{r_{1}} \cdot P_{2}^{r_{2}} + P_{1}^{\bar{r}_{1}}, P_{2}^{\bar{r}_{2}}) =$$ $$P_{1}^{r_{1}} (P_{1} \oplus P_{2})^{r_{1}} \stackrel{\oplus}{} r_{2}$$ Applying this rule to overall variables, switching function can be expressed as EX-OR-AND-OR forms without loss of generality. EXAMPLE 1. If a switching function is $f(x_1, x_2) = x_1 \overline{x}_2$ , it can be represented $f(x_1, x_2) = (1, 0) \begin{bmatrix} 1 \\ x \end{bmatrix} \cdot x \begin{bmatrix} 0 \\ 2 \end{bmatrix}$ by theorem 1). From here, $$x \frac{1}{1} \cdot x \frac{0}{2} = x \frac{1}{1} \cdot (x \frac{1}{1} \cdot x \frac{0}{2} + x \frac{0}{1} \cdot x \frac{1}{2})$$ $$= x \frac{1}{1} \cdot (x \frac{1}{1} \oplus x \frac{1}{2}) \oplus 0$$ $$= x \frac{1}{1} \cdot (x \frac{1}{1} \oplus x \frac{1}{2}) \oplus 0$$ Theorem 2] Any two minterms can be combined and reduced to one term. Proof. Let $X = (a_1, a_2, \ldots, a_n)$ and $Y = (b_1, b_2, \ldots, b_n)$ be the binary representation of two terms of f. Two terms such that $x_1^{a_1} x_2^{a_2} \dots x_n^{a_n}$ and $$x_1^{b_1} x_2^{b_2} \dots x_n^{b_n}$$ be supposed to be identical term except for two bit position i, j $(1 \le i \text{ or } j \le n)$ . And then two terms are reduced to one term by using EX-OR and EX-NOR operation. $$x_{1}^{a_{1}} x_{2}^{a_{2}} \dots x_{i}^{a_{i}} \dots x_{j}^{a_{j}} \dots x_{n}^{a_{n}}$$ $$+ x_{1}^{b_{1}} x_{2}^{b_{2}} \dots x_{i}^{b_{i}} \dots x_{j}^{b_{j}} \dots x_{n}^{b_{n}}$$ $$= x_{1}^{a_{1}} x_{2}^{a_{2}} \dots x_{n}^{a_{n}} (x_{i}^{a_{i}} x_{j}^{a_{j}} + x_{i}^{b_{i}} x_{j}^{b_{j}})$$ $$= x_{1}^{a_{1}} x_{2}^{a_{2}} \dots x_{n}^{a_{n}} (x_{i} \oplus x_{j})^{a_{i} \oplus a_{j}}$$ By theorem 1 and 2, it is proved that any Boolean function expressed by sum-of-products can be converted into EX-OR-AND-OR three-level form. EXAMPLE 2 Suppose that $$X = x_1 x_2 x_3 x_4 \overline{x}_5 x_6$$ $Y = x_1 x_2 \overline{x}_3 x_4 x_5 x_6$ . $X + Y = x_1 x_2 x_3 x_4 \overline{x}_5 x_6 + x_1 x_2 \overline{x}_3 x_4 x_5 x_6$ $= x_1 x_2 x_4 x_6 (x_3 \overline{x}_5 + \overline{x}_3 x_5)$ $= x_1 x_2 x_4 x_6 (x_3 \oplus x_5)$ by theorem 2), any two-minterms can be reduced one ex-or or ex-nor form. EXAMPLE 3. In case of realizing three-level PLA from two-level PLA, suppose that a AND array part of two-level PLA is constructed the form shown in Fig. 6. To minimize the AND array part, theorem 2 can be applied to Fig. 6. Product terms (= AND array part of two-level PLA) shown in Fig. 6. can be converted EX-OR-AND terms using first method Fig. 6 The AND array of two-evel PLA - 1) From 1st and 2nd column; By theorem 2 $\overline{x}_1$ , $x_2$ , $\overline{x}_3$ + $x_1$ , $\overline{x}_2$ , $\overline{x}_3$ = $(x_1 \oplus x_2)$ , $\overline{x}_3$ - 3) From 5th and 6th column; By theorem 2 $\overline{X}_1$ , $X_2$ , $\overline{X}_3$ + $X_1$ , $\overline{X}_2$ , $X_3$ $$= (X_1 \oplus X_2) (X_2 \oplus X_3)$$ Fig. 6. can be converted as Fig. 7. Fig. 7. The EX-OR and AND array of three-level PLA EXAMPLE 4. In the Fig. 8, 9, 10, and 11, example which is the case of changing binary code into gray code, is shown (applying method) | | B <sub>3</sub> | В2 | В <sub>1</sub> | _B <sub>0</sub> | G <sub>3</sub> | $G_2$ | G <sub>1</sub> | $G_0$ | |----|----------------|----|----------------|-----------------|----------------|-------|----------------|-------| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | | 2 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | | 3 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | | 4 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | | 5 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | | 6 | ŋ | 1 | 1 | 0 | 0 | 1 | 0 | 1 | | 7 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | | 8 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | 9 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | | 10 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | 11 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | | 12 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | | 13 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | | 14 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | | 15 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 00 | Fig. 8. Truth-table for Changing binary code into gray code Fig. 9. The canonical sum-of-products for changing binary code into gray code Fig. 10. The standard sum-of-products for two-level PLA Fig. 11. The Binary-to-Gray code converter using EXANOR PLA Fig. 8. is for truth table, fig. 9. for canonical sum-of-products form, fig. 10. for standard sum-of-products form, and fig. 11. for three-level PLA. # C. Second method to implement three-level PLA of Boolean Function In this case, MASK [9] method, which is computer-aided method, is used. Using MASK method, two MASK tables can be made. One is made using given variables, and another is using new variables which consists of EX-OR forms. From two MASK tables, a new MASK table, which is called modified MASK table, is made and PI's are selected with optimal cost in that table. Theorems necessary to implement second method are derived as follows: Theroem 3] Expressions of switching functions for three-level PLA by the linked variables: $$f(x_{1}, x_{2}, ..., x_{n}) = \sum f(a_{1}, a_{2}, ..., a_{n}) x_{1}^{a_{1}} (x_{1} + x_{2})^{a_{1} \oplus a_{2}} ... (x_{n-2} + x_{n-1})^{a_{n-2} \oplus a_{n-1}}$$ $$(x_{n-1} + x_{n})^{a_{n-1} \oplus a_{n}}$$ Proof. Applying theorem 1] to the each two variables, theorem 3] can be proved. Theorem 4] Expressions of switching functions for three-level PLA by the partitioned variables: $$f(x_{1}, x_{2}, ..., x_{n}) = \sum f(a_{1}, a_{2}, ..., a_{n}) x_{1}^{a_{1}} x_{3}^{a_{3}} ...$$ $$x_{n-1}^{a_{n-1}} (x_{1} \oplus x_{2})^{a_{1} \oplus a_{2}}$$ $$(x_{3} \oplus x_{4})^{a_{3} \oplus a_{4}} ...$$ $$(x_{n-1} \oplus x_{n})^{a_{n-1}} \odot a_{n}$$ Proof. Applying theorem 1] to the partitioned variables, $$f(x_{1}, x_{2}, ..., x_{n})$$ $$= \sum f(a_{1}, a_{2}, ..., a_{n}) x_{1}^{a_{1}} x_{1}^{a_{2}} ... x_{n}^{a_{n}}$$ $$= \sum f(a_{1}, a_{2}, ..., a_{n}) x_{1}^{a_{1}} (x_{1} \oplus x_{2})^{a_{1} \oplus a_{2}}$$ $$x_{3}^{a_{3}} (x_{3} \oplus x_{4})^{a_{3} \oplus a_{4}} ...$$ $$x_{n-1}^{a_{n-1}} (x_{n-1} + x_{n})^{a_{n-1} + a_{n}}$$ $$= \sum f(a_{1}, a_{2}, ..., a_{n}) x_{1}^{a_{1}} x_{3}^{a_{3}} ... x_{n-1}^{a_{n-1}}$$ $$(x_1 \oplus x_2)^{a_1 \oplus a_2} \cdot (x_3 \oplus x_4)^{a_3 \oplus a_4} \cdot \dots$$ $(x_{n-1} \oplus x_n)^{a_{n-1} \oplus a_n}$ EXAMPLE 5. Of theorem 4], the term $x_1 \overline{x}_2 \overline{x}_3 x_4$ , can be expressed as EX-OR-AND form $$f(x_1, x_2, x_3, x_4) = x_1 \overline{x}_2 \overline{x}_3 x_4$$ $$= x_1 (x_1 \oplus x_2) \overline{x}_3 (x_3 \oplus x_4)$$ $$= x_1 \overline{x}_3 (x_1 \oplus x_2) (x_3 \oplus x_4)$$ Theorem 5] Terms such as $x_1$ , $(x_1 \oplus x_2)$ , ..., $(x_{n-1} \oplus x_n)$ can be substituted for newly generated variables; $s_1$ , $s_2$ , ..., $s_n$ . So, the original truth table is converted to the new truth table of n variables. The following two examples are taken for application of the second method. EXAMPLE 6. Suppose that any Karnaugh map of Boolean function is given in Fig. 12. a). It can be converted using second method. From Fig. 12. a), if two-level PLA is used, there are the following 16 prime implicants; $$\begin{array}{c} x_{1}x_{2}x_{3}x_{4}x_{5}x_{6}, \quad x_{1}x_{1}x_{3}x_{4}x_{5}x_{6}, \\ \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}x_{5}x_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}x_{4}\overline{x}_{5}x_{6}, \\ \overline{x}_{1}x_{2}x_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \quad \overline{x}_{1}x_{2}x_{3}\overline{x}_{4}x_{5}x_{6}, \quad \overline{x}_{1}x_{2}x_{3}x_{4}\overline{x}_{5}x_{6}, \\ x_{1}\overline{x}_{2}x_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \quad x_{1}\overline{x}_{2}x_{3}x_{4}\overline{x}_{5}x_{6}, \quad x_{1}\overline{x}_{2}x_{3}x_{4}x_{5}\overline{x}_{6}, \\ x_{1}x_{2}\overline{x}_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \quad x_{1}x_{2}\overline{x}_{3}\overline{x}_{4}x_{5}x_{6}, \quad x_{1}x_{2}\overline{x}_{3}x_{4}\overline{x}_{5}x_{6}, \\ \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}x_{4}x_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}x_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}x_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}x_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}x_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}x_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}x_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}x_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}x_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}x_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}x_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \\ \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4}\overline{x}_{5}\overline{x}_{6}, \quad \overline{x}_{1}\overline{x}_{2}\overline{x}_{3}\overline{x}_{4$$ And by the theorem 3], $$S_1 S_2 S_3 S_4 S_5 S_6 = x_1 x_2 (x_2 \oplus x_3) x_4 x_5 (x_5 \oplus x_6)$$ Then new variables such as $s_1, s_2, s_3, s_4$ , are assigned to each position and new truth table is generated as shown in Fig. 12.b). From Fig. 12.b), the following 4 prime implicants are obtained; $\bar{s}_{1}\bar{s}_{2}\bar{s}_{4}\bar{s}_{6}$ , $\bar{s}_{1}\bar{s}_{3}s_{4}s_{6}$ , $s_{1}s_{3}\bar{s}_{4}\bar{s}_{6}$ , $s_{1}s_{3}s_{4}s_{6}$ 011 1 1 1 1 010 110 1 1 1 1 111 101 1 1 1 1 100 a) for variables xi Fig. 12. The Karnaugh maps for example 4 EXAMPLE 7. Suppose that any Karnaugh map of Boolean function is given in Fig. 13. a). It can be converted using second method. From Fig. 13. a), there are 15 prime implicant; | $\bar{x}_1\bar{x}_2\bar{x}_3\bar{x}_4\bar{x}_5$ | $\bar{x}_1 \bar{x}_2 \bar{x}_4 x_6$ , | $\bar{x}_1\bar{x}_2\bar{x}_3x_4x_5\bar{x}_6$ | |---------------------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------| | $\overline{x}_1 x_2 x_4 x_6$ | x2x3x4x5x6, | $\bar{x}_{1}x_{2}x_{3}x_{4}x_{5}$ | | x <sub>1</sub> x <sub>2</sub> x <sub>4</sub> x <sub>6</sub> , | x <sub>1</sub> x <sub>3</sub> x 4x 5x 6 | x <sub>1</sub> x <sub>2</sub> x <sub>3</sub> x <sub>4</sub> x <sub>5</sub> , | | x <sub>1</sub> x <sub>2</sub> x 4x 5, | x <sub>1</sub> x <sub>2</sub> x 3x 4x 6, | $x_1x_2\overline{x}_3x_4x_5\overline{x}_6$ | | $\bar{x}_{3}^{x}_{4}\bar{x}_{5}^{x}_{6}$ | x <sub>2</sub> x <sub>3</sub> x <sub>4</sub> x <sub>5</sub> x <sub>6</sub> , | $\bar{x}_{1}^{x}_{3}\bar{x}_{4}^{x}_{5}^{x}_{6}$ | From Fig. 13. b), following 11 prime implicants are obtained; | s <sub>1</sub> s <sub>3</sub> s <sub>4</sub> s <sub>6</sub> , | • | $\bar{s}_1$ | $s_2 \bar{s}_4$ | S 5 S 6 | , | S <sub>1</sub> S <sub>2</sub> | S <sub>4</sub> S <sub>5</sub> | 5 <sub>6</sub> , | |---------------------------------------------------------------|--------------------------------------|------------------|-------------------------------|-------------------|-----|-------------------------------|---------------------------------|------------------| | $s_1\bar{s}_2s_4s_5\bar{s}_5$ | 5 <sub>6</sub> , | S <sub>1</sub> S | S <sub>3</sub> S <sub>4</sub> | 5<br>6' | | S <sub>1</sub> S <sub>2</sub> | 5̄ <sub>4</sub> 5̄ <sub>5</sub> | , | | s <sub>1</sub> s <sub>3</sub> s <sub>4</sub> s <sub>6</sub> , | | $\bar{s}_1$ | 5̃35̄ <b>3</b> | ε̃ <sub>6</sub> , | ; | $\bar{s}_1\bar{s}_2$ | S <sub>4</sub> S <sub>5</sub> | s <sub>6</sub> , | | \$2\$384\$5 | - | ទី | S <sub>2</sub> S <sub>4</sub> | 5<br>5<br>5<br>6 | | | | | | $x_1 x_2 x_3 $ $x_4$ | x <sub>5</sub> x <sub>6</sub><br>000 | 001 | 011 | 010 | 110 | 111 | 101 | 100 | | 000 | 1 | 1 | 1 | | 1 | | 1 | | | 001 | | 1 | 1 | | | | | | | 011 | 1 | | 1 | | 1 | 1 | 1 | | | 010 | | | | | | 1 | 1 | | | 110 | 1 | 1 | 1 | | 1 | | 1 | | | 111 | 1 | 1 | | | | | | | | 101 | 1 | | 1 | | 1 | 1 | 1 | | | 100 | | | | | | 1 | 1 | | b) for variables si Fig. 13. The Karnaugh maps for example 5 # 4. Implementation of three-level PLA circuits In section 3, two design methods are discussed for three-level PLA. The first method which use the direct conversion approach to generate the EXANOR PLA is simple but tedious. And the second method which treats the switching function more genral in all the design phase, is more applicable to practical implementations. Thus, in this section three-level PLA circuit design is realized based on the second method. Before discussing the procedure, the terminologies are defined; Definition 6) The prime implicant generated from original switching function, whose variables are $x_i$ (i = 1,2,...,n), is defined as $XPI_i$ , where i designates the order of genrating PI's. Definition 7) The prime implicant generated from new switching function, whose variables are determined by the partitioned variables $s_i$ (i = 1,2,...,n), is defined as $SPI_i$ , where i denotes the order of generating PI's. Definition 8) The table which consists of XPI<sub>i</sub> and SPI<sub>i</sub> is called the mixed PI table. Next, procedure for implementation of threelevel PLA circuit is as follows; ## Procedure: - Generate XPI<sub>i</sub> whose variables are x<sub>i</sub> (i = 1,2,..., n) using MASK method. - 2) Generate $SPI_i$ whose variables are $s_i$ (i = 1,2,...,n) using MASK method. - 3) Make the mixed PI table. - 4) From the mixed PI table, count the number of the checks in each row and let it be the original cost. - Select the PI which has the maximum value of cost. If PI is more than one, then PI in SPI has priority. - 6) Arrange the new cost, and if all the minterms are covered, go to step 7). Otherwise, go to step 5). - 7) Stop. Example 8. In example 6, choose the PI's using the procedure. By the procedure, mixed PI table is made. And from the mixed PI table, 4 PI's are selected as follows; $$\bar{s}_1 \bar{s}_3 \bar{s}_4 \bar{s}_6$$ , $\bar{s}_1 \bar{s}_3 s_4 s_6$ , $s_1 s_3 \bar{s}_4 \bar{s}_6$ , $s_1 s_3 s_4 s_6$ $$\overline{s}_{1}\overline{s}_{3}s_{4}s_{6}$$ Cost: the number of minterms covered by the prime implicant. | Minterm | | | | | | | | | | | | | | | • | | | Selected | |-------------------|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|------|----------| | XPI or SPI | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | Cost | PI's | | XPI <sub>1</sub> | x | | | | | | | | | | | | | | | | 1 | | | XPI <sub>2</sub> | | x | | | | | | | | | | | | | | | 1 | | | XPI <sub>3</sub> | | | x | | | | | | | | | | | | | | 1 | | | XPI <sub>4</sub> | | | | x | | | | | | | | | | | | | 1 | | | XPI <sub>5</sub> | | | | | x | | | | | | | | | | | | 1 | | | XPI <sub>6</sub> | | | | | | x | | | | | | | | | | | 1 | | | XPI <sub>7</sub> | | | | | | | x | | | | | | | | | | 1 | | | хрі <sub>8</sub> | | | | | | | | x | | | | | | | | | 1 | | | XPI <sub>9</sub> | | | | | | | | | x | | | | | | | | 1 | | | XPI <sub>10</sub> | | | | | | | | | | x | | | | | | | 1 | | | XPI <sub>11</sub> | | | | | | | | | | | x | | | | | | 1 | | | XPI <sub>12</sub> | | | | | | | | | | | | x | | | | | 1 | | | XPI <sub>13</sub> | | | | | | | | | | | | | x | | | | 1 | | | XPI <sub>14</sub> | | | | | | | | | | | | | | x | | | 1 | | | XPI <sub>15</sub> | | | | | | | | | | | | | | | x | | 1 | | | XPI <sub>16</sub> | | | | | | | | | | | | | | | | x | 1 | | | SPI <sub>1</sub> | x | x | | | x | x | | | | | | | | | | | 4 | + | | SPI <sub>2</sub> | | | x | x | | | x | x | | | | | | | | | 4 | + | | SPI <sub>3</sub> | | | | | | | | | x | x | | | x | x | | | 4 | + | | SPI <sub>4</sub> | | | | | | | | | | | x | x | | | x | х | 4 | + | Fig. 14. The mixed P1 table for example 8 Fig. 14-1. Circuit for example 6 and example 8 Example 9. In example 7, choose the PI's using the procedure. By the procedure, mixed PI table is made. And from the mixed PI table, $$\begin{array}{l} -\frac{8}{x_{1}}\overset{8}{x_{2}}\overset{7}{x_{4}}\overset{8}{x_{5}}, \ \overset{7}{x_{1}}\overset{7}{x_{2}}\overset{7}{x_{4}}\overset{8}{x_{5}}, \ \overset{7}{x_{1}}\overset{7}{x_{2}}\overset{7}{x_{4}}\overset{8}{x_{6}}, \ \overset{7}{\overline{s}_{1}}\overset{7}{\overline{s}_{3}}\overset{7}{s_{4}}\overset{8}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{3}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{5}}, \ \overset{7}{s_{1}}\overset{7}{s_{3}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{3}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \ \overset{7}{s_{1}}\overset{7}{s_{3}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{3}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{4}}\overset{7}{s_{6}}, \\ \overset{7}{s_{1}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}}\overset{7}{s_{2}$$ | Minterm<br>XPI or SPI | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 3 2 | 4 2 | 5 20 | 6 2 | 27 28 | Cost | Selected<br>Pl's | |-----------------------|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|------|-----|-------|------|------------------| | XPI <sub>1</sub> | x | x | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | | | XPI <sub>2</sub> | | x | x | | | X | x | | | | | | | | | | | | | | | | | | | | | | 4 | + | | XPI <sub>3</sub> | | | | X | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | XPI <sub>4</sub> | | | | | | | | x | X | | | x | | X | | | | | | | | | | | | | | | 4 | + | | XPI <sub>5</sub> | | | | | | | | | | X | | | | | | | | | | | | | | | | | ) | Κ. | 1 | : | | XPI <sub>6</sub> | | | | | | | | | | | | | x | x | | | | | | | | | | | | | | | 2 | | | XPI <sub>7</sub> | | | | | | | | | | | | | | | x | x | | | x | | x | | | | | | | | 4 | + | | XPI <sub>8</sub> | | | | | | | | | | | | | | | | | x | | | | | | | | | | > | Κ. | 2 | | | XPI <sub>9</sub> | | | | | | | | | | | | | | | | | | | | x | x | | | | | | | | 2 | | | XPI <sub>10</sub> | | | | | | | | | | | | | | | | | | | | | | x | x | | | | > | x x | 4 | | | XPI <sub>11</sub> | | | | | | | | | | | | | | | | | | | | | | | x | X | | | | | 2 | | | XPI <sub>12</sub> | | | | | | | | | | | | | | | | | | | | | | | | | | X | | | 1 | | | XPI <sub>13</sub> | | | X | | | | x | | | | | | | | x | | | | | | | | | | х | | | | 4 | | | XPI <sub>14</sub> | | | | | | x | | | | | | | | | | | | X | | | | | | | | | | | 2 | | | XPI <sub>15</sub> | | | | | | X | | | | | x | | | | | | | | | | | | | | | | | | 2 | | | Minterm<br>XPI or SPI | 1 2 3 | 4 5 | 6 7 | 8 9 | 10 1 | 1 12 | 13 | 14 15 | 16 | 17 | 18 | 19 2 | 20 2 | 21 : | 22 : | 23 | 24 | 25 2 | 26 | 27 28 | Cost | Selected<br>PI's | |-----------------------|-------|---------|-----|-----|-------|------|-------|-------|----|------------|-----|------|------|------|------------|----|-----|-------|----|---------|------|------------------| | SPI <sub>1</sub> | | x * x * | | | | x. | * X * | | | | | | | | | | | | | | 4 | | | SPI <sub>2</sub> | X* | | X* | | | | | | | | | | | | | | | | | | 2 | | | SPI <sub>3</sub> | | | | Х* | • | | | X* | | | | | | | | | | | | | 2 | | | SPI <sub>4</sub> | | | | | | | | | X* | | | | Х | * | | | | | | | 2 | | | SPI <sub>5</sub> | | | | | | | | | | <b>x</b> * | X * | | | 2 | <b>K</b> * | | X * | | | | 4 | | | SPI <sub>6</sub> | | | | | | | | | | | | | | 7 | (*) | (* | | | 2 | X * X * | 4 | | | $^{\mathrm{SPI}}7$ | | | | | | | | | | | | X* > | * | | | | | X * X | (* | | 4 | | | SPI <sub>8</sub> | X* X* | | | | x * x | * | | | | | | | | | | | | | | | 4 | | | SPI <sub>9</sub> | X* | | X * | | | | | | | | | | | | | | | | | | 2 | | | SPI <sub>10</sub> | | X:* | | | | | | X* | | | | | | | | | | | | | 2 | | | SPI <sub>11</sub> | | | | X* | | Х* | | | | | | | | | | | | | | | 2 | | Fig. 15. The mixed P1 table for example 9 Fig. 15-1. Circuit for example 7 and example 9 # 5. Size Comprison with Two-Level PLA and Three-Level PLA In this section, comparison with two-level PLA size and three-level PLA size is discussed. In the case of physical design, MOS array size plays an important role in estimating overall chip size. In Fig. 16. and Fig. 17, their sizes S(n) are evaluated as follows; Two-level PLA: $S_2(n) = (2n + m)W$ Three-level PLA: $S_3(n) = (n + 2 + W) H + Wm$ Fig. 16. The dimension of two -levelPLA Without loss of generality, output function is regarded as simple output switching function. Theorem 6] In two-level PLA, W is 2<sup>n-1</sup>, and in three-level PLA, W is 2<sup>n-2</sup>. The W sizes of two-level and three-level PLA are 2<sup>n-1</sup> and 2<sup>n-2</sup>, respectively. Fig. 17. The dimension of three-level PLA Proof. In two-level PLA, if the number of input is n, then in worst case, W is 2<sup>n</sup>. But the number of columns are 2<sup>n</sup>/2 because of duality of switching function. And by theorem 2], the number of columns of two-level PLA is divided by 2. So W of three-level PLA leads to $2^{n-1}/2$ . By theorem 6], sizes of two types of PLA are evaluated as follows; Size of two-level PLA: $S_2(n) = (2n+1)2^{n-1}$ Size of three-level PLA: $$S_3(n) = (n+2+2^{n-2}) 2n+2^{n-2}$$ $$= (2n+1)2^{n-2}+2n^2+4n$$ And let the ratio of reduction R, be $$\frac{S_3(n)}{S_2(n)}$$ Ratio of reduction is $$R = 1 - \frac{(2n+1)2^{n-2} + 2n^2 + 4n}{(2n+1)2^{n-1}} = 0.5$$ So, using three-level PLA, a half of size is reduced. #### 6. Conclusion In this paper the new design methodology of PLA is considered and evaluated by using PLA chip size. Some of problems encountered in design of PLA are the reduction of input lines and product terms. To reduce the product terms and input lines, the architecture of three-level PLA is proposed in this paper. This architecture is composed of the three-level PLA such as EX-OR, AND and OR. By theorem 1] - 3], all the switching functions are expressed as EX-OR, AND and OR. And there are two types of expressing the given switching functions. Some examples are introduced for the clarity of theorems, finally, ratio of size reduction is considered and its reduction ratio results in a half time as much as the conventional two-level PLA size. #### References - [1] H. Fleisher and L.I. Maissel; "An introduction to array logic", IBM J. Res. Develop., vol. 19, pp. 98-109, Mar. 1975. - [2] S.J. Hong, R.G. Cain, and D.L. Ostapko; "MINI; A heuristic approach for logic minimization", - IBM J. Res. Develop. vol. 18, pp. 443-458, Sept. 1974. - [3] R.A. Wood; "High-speed dynamic programmable logic array chip," IBM J. Res. Develop., vol. 19, pp. 379-383, July 1975. - [4] TSUTOMU SASAO; "Multiple-valued decomposition of generalized boolean functions and the complexity of programmable logic arrays," IEEE trans. com., vol. c-30, pp. 635-643, Sept. 1981. - [5] YAHITO KAMBAYASHI; "Logic design of programmable logic arrays," IEEE trans. com., vol. c-28, pp. 609-617, Sept. 1979. - [6] G. Pomper and J.R. Armstrong; "Representation of multivalued functions using the direct cover method," IEEE trans. com. vol c-30, pp. 674-679, Sept. 1981. - [7] Sahni and Horowitz; "Fundamentals of computer algorithms" Computer Science Press, Inc. - [8] THADDEUS KOBYLARZ and ATEF AL-NAJJAR; "An examination of the cost function for programmable Logic Arrays," IEEE Trans. Com. vol. c-28, No. 8, pp. 586-590, Aug. 1979. - [9] Cho Dong Sub and Hwang Hee Yeung; "On the minimization of the switching function by the MASK method," KIEE, vol. 28, No. 11, pp. 801-808, Nov. 1979. - [10] Hwang Hee Yeung; "A new approach to the minimization of switching functions by the simple table method, "KIEE, vol. 28, No. 6, pp. 61-77, June 1979