# CONDITIONS FOR THE DISTRIBUTIVITY OF MULTIPLICATION WITH RESPECT TO SET ADDITION AND THEIR EFFECT ON THE DESIGN OF ARRAY MULTIPLIERS

James E. Robertson

Department of Computer Science University of Illinois at Urbana-Champaign Urbana, Illinois, 61801-2987

Some conditions for distributivity of multiplication with respect to set addition are determined. In particular, distributivity holds if positive numbers are used, but does not hold for negative numbers in radix complement form. Use of simple recoding methods to achieve distributivity is not helpful, since costs of elementary multipliers and summing networks are increased. Distributivity does hold for the digit sets used for signed-digit arithmetic, and the requirement for distributivity provides guidance for the design of elementary multipliers.

#### 1. Introduction

The first purpose of this paper is to point out that multiplication is not necessarily distributive with respect to set addition, and to determine some of the conditions for which distributivity does hold. The basic question is whether or not  $C \times (A + B) = (C \times A) + (C \times B)$ . A, B, and C are digit sets, or sequences of consecutive integers including zero. The parentheses indicate the order of the operations.

The three conditions of practical importance for which distributivity holds are these:

- 1. All digits of both A and B, or all digits of C are positive or zero.
- All digits of both A and B, or all digits of C are negative or zero.
- The digit sets of any two of A, B, and C are symmetric; that is, if X is an element of a digit set, so is -X.

Although other conditions for which distributivity holds are known to exist, it should not be assumed that distributivity holds in general when digit sets with both positive and negative values are involved.

The second purpose of this paper is to relate these results to the design of array multipliers. For the purposes of this paper, the simplistic assumption is made that the array multiplier consists of two more or less independent parts; the array of elementary multipliers, and the summing network which converts the array output to the form desired for the product.

For the binary multiplier array consisting of AND gates, distributivity holds if both multiplier and multiplicand are positive, but does not hold if negative values are introduced through use of a radix (two's) complement representation of operands. This provides a partial explanation of the fact that no reduction in the cost of the summing network can easily be achieved, even though the product precision is reduced by one bit. The simple attempts to achieve distributivity through recoding are self-defeating, since they require more complex elementary multipliers, and require a more costly summing network as well.

For signed digit arithmetic, which requires the use of symmetric digit sets, distributivity is easily achieved. The fact that distributivity must hold for elementary multipliers provides guidance as to the nature of logical designs which are permissible.

# 2. Terminology and Notation

The simplest example for which distributivity does not hold is presented to introduce the terminology and notation. The arithmetic operations involve digit sets, for example,  $a^0 = \{0,1\}$ ,

$$a^1 = \{\overline{1}, 0\}, b^1 = \{\overline{1}, 0, 1\}, and d^2 = \{\overline{2}, \overline{1}, 0, 1, 2\}.$$

The set addition  $b^1 + a^1 + a^0$  is illustrated by

the addition table of Figure 1. The multiplicative

operations  $b^1 \leftarrow a^1 \times b^1$  and  $b^1 \leftarrow a^0 \times b^1$  are illustrated by the multiplication tables of Figures 2 and 3. For the example, the addition table

$$d^2 + b^1 + b^1$$
 (Figure 4) and the multiplication table  $b^1 + b^1 \times b^1$  (Figure 5) are also needed.

Consider the operations  $b^1 \times (a^1 + a^0)$ . If the addition is performed first, the results are  $b^1 \leftarrow a^1 + a^0$  (Figure 1) followed by  $b^1 \leftarrow b^1 \times b^1$  (Figure 5). If the multiplication is given precedence, the results are  $b^1 + b^1 \leftarrow (b^1 \times a^1) + (b^1 \times a^0)$  (Figures 2 and 3) followed by  $d^2 \leftarrow b^1 + b^1$  (Figure 4). Distributivity clearly does not hold.

 $\bigwedge_0^\Delta$  digit set is more generally designated by , and is characterized by two integer

parameters, the diminished cardinality  $\delta$  and the offset  $\omega.$  The digit set is a sequence of consecutive integers, including 0, ranging in value from  $-\omega$  to  $+(\delta-\omega)$ . A digit set is called normalized if  $\omega=0$ , is called symmetric if  $\delta=2\omega$ , (hence  $\delta$  is even), and is called negative normalized if  $\delta=\omega.$  For example, if  $\delta=2$ , the digit set  $\{0,1,2\}$ , with  $\omega=0$ , is

normalized; the digit set  $\{\bar{1},0,1\}$ , with  $\omega=1$ , is symmetric; and the digit set  $\{\bar{2},\bar{1},0\}$  with  $\omega=2$ , is negative normalized.

This terminology was chosen because  $\delta$  and  $\omega$  are preserved under set addition, for example, if

$$\underbrace{\delta_3}^{\omega_3} \quad + \quad \underbrace{\delta_1}^{\omega_1} \quad + \quad \underbrace{\delta_2}^{\omega_2}$$

then  $\delta_3 = \delta_1 + \delta_2$  and  $\omega_3 = \omega_1 + \omega_2$ 

It is convenient, for digit sets of lower cardinality, to adopt a less cumbersome notation by replacing 1 by a, 2 by b, 3 by c, etc. The simplest symmetric digit set  $b^1 = \{1,0,1\}$  will be of importance in sections to follow.

It may be noted that many of the structures for digital computer addition and subtraction, such as binary full adders and subtracters, conform to the rules of set addition; the symbol + is used to differentiate between inputs and outputs of such structures.

#### 3. Basic Derivations

For the investigation of the existence of distributivity, define

in which, for example, the product set

$$\max \left[\omega_1 \ \omega_3, \ (\delta_1 - \omega_1) \ (\delta_3 - \omega_3)\right]$$

Note that, in general, a product set is not necessarily a digit set, since not all consecutive values may be included. For example, the product set  $\{0,1,2\}$  x  $\{0,1,2\}$  =  $\{0,1,2,4\}$ .

The definition of distributivity employed here is that the most negative and the most positive values of the sets  $\sqrt{\delta_4}^{\omega_4}$  and  $\sqrt{\delta_5}^{\omega_5}$  shall be identical, or that  $\omega_4 = \omega_5$  and  $\delta_4 - \omega_4 = \delta_5 - \omega_5$ .

It is easy to determine that

$$\omega_4 = \max \{ \omega_3 (\delta_1 - \omega_1 + \delta_2 - \omega_2),$$
 $(\delta_3 - \omega_3) (\omega_1 + \omega_2) \}$ 

$$\omega_5 = \max \left[ \omega_3 \left( \delta_1 - \omega_1 \right), \ \omega_1 \left( \delta_3 - \omega_3 \right) \right] + 3.5$$

$$\max \left[ \omega_3 \left( \delta_2 - \omega_2 \right), \ \omega_2 \left( \delta_3 - \omega_3 \right) \right]$$

$$\begin{array}{lll}
\delta_4 - \omega_4 &= \max \left[ \omega_3 \left( \omega_1 + \omega_2 \right), \\
(\delta_3 - \omega_3) \left( \delta_1 - \omega_1 + \delta_2 - \omega_2 \right) \right]
\end{array}$$
3.6

$$\delta_5 - \omega_5 = \max \left[ \omega_3 \ \omega_1, \ (\delta_3 - \omega_3) \ (\delta_1 - \omega_1) \right] + 3.7$$

$$\max \left[ \omega_3 \ \omega_2, \ (\delta_3 - \omega_3) \ (\delta_2 - \omega_2) \right]$$

# 4. Some Specific Conditions for Distributivity

#### 4.1. Introduction

The three specific conditions which appear to be of greatest practicality will be discussed first. These are that distributivity exists if any two of the three digit sets

normalized or negative normalized. it is sufficient to show that symmetry applies simultaneously to  $\sqrt[\delta]{1}$  and  $\sqrt[\delta]{3}$ , since commutativity of

set addition then implies that the result will hold for  $\sqrt{\delta_2}^{\omega_2}$  and  $\sqrt{\delta_3}^{\omega_3}$ .

# 4.2 Other Conditions for Distributivity

A number of other conditions for distributivity have been found, primarily by a systematic search of examples, after elimination of cases previously found. These include:

a) 
$$\sqrt{\delta_1}^{\omega_1} = \sqrt{\delta_2}^{\omega_2}$$
  
b)  $\sqrt{\delta_1}^{\omega_1} = -\sqrt{\delta_3}^{\omega_3}$  if either  $\omega_1 = 0$  or  $\omega_3 = 0$ 

c) 
$$\underbrace{ \begin{bmatrix} \delta_1 \end{bmatrix}^{\omega_1}}_{\text{if } \delta_1 - \omega_1} = - \underbrace{ \begin{bmatrix} \delta_3 \end{bmatrix}^{\omega}}_{\text{3}}$$
if  $\delta_1 - \omega_1 > \omega_1$  and  $(\delta_1 - \omega_1) (\delta_2 - \omega_2) > \omega_1 \omega_1$ 
or  $\omega_1 > \delta_1 - \omega_1$  and  $\omega_1 \omega_2 > (\delta_1 - \omega_1) (\delta_2 - \omega_2)$ 

d) 
$$\delta_3 = 2\omega_3$$
 if  $\delta_1 - \omega_1 > \omega_1$  and  $\delta_2 - \omega_2 > \omega_2$  or  $\omega_1 > \delta_1 - \omega_1$  and  $\omega_2 > \delta_2 - \omega_2$ 

e) 
$$\delta_1 + \delta_2 = 2 (\omega_1 + \omega_2)$$
 and  $\omega_3 = 0$  or  $\delta_3 = \omega_3$ 

It is anticipated that a continuation of the systematic search will reveal more examples, with increasingly complex conditions for their applicability. Whether the results will be merely an intellectual curiosity or of practical value is yet to be determined.

### 5. Examples of Simple Array Multipliers

A set of simple examples of array multipliers indicates the nature of the problem in a practical situation. Consider first the multiplication of the 3 bit positive multiplicand  $4\mathbf{x}_2+2\mathbf{x}_1+\mathbf{x}_0$  by

the 3 bit positive multiplier  $4y_2 + 2y_1 + y_0$ , with

the multiplier and multiplicand each ranging from 0 to +7. The product set will range, as expected, from 0 to 49, and may be formed by summing the properly weighted outputs of a 3x3 array of elementary multipliers, which are AND gates, as indicated in Figure 5.1.



Figure 5.1 Weights for a 3x3 positive array of AND gates

It is easy to verify that the maximum sum is 16 + 2(8) + 3(4) + 2(2) + 1 = 49 as expected.

Alternatively, consider the 3x3 array multiplier when a twos (or radix) complement representation is employed, i.e., the multiplicand is  $-4x_2 + 2x_1 + x_0$  and the multiplier is  $-4y_2 + 2y_1$ 

+  $y_0$ . Each operand ranges from -4 to +3, hence the

product set should range from -12 to +16. Consider Figure 5.2, indicating the weights for the 3x3 AND gate array.



Figure 5.2 Weights for a 3x3 radix complement array of AND gates

The summing network must be able to accommodate values ranging from the most negative value -8 + (-8) + (-4) + (-4) = -24 to the most positive value 16 + 4 + 2 + 2 + 1 = 25. Obviously, distributivity does not apply.

# 6. Implications on the Design of Array Multipliers for Radix Complement Representations

A radix complement representation can be transformed into a symmetric representation by a generalization of the Booth (or differentiating)

Let 
$$y = -2^5y_5 + 2^4y + 2^3y_3 + 2^2y_2 + 2y_1 + y_0$$
.  
Then  $2y = -2^6y_5 + 2^5y_4 + 2^4y_3 + 2^3y_2 + 2^2y_1 + 2y_0 + y_{-1}$ , with  $y_{-1} = 0$ .  
Also  $-2^5y_5 = -2^6y_5 + 2^5y_5$ .  
 $y = 2y - y = 2^6 (-y_5 + y_5) + 2^5 (y_4 - y_5)$ 
 $+ 2^4 (y_3 - y_4) + 2^3 (y_2 - y_3) + 2^2 (y_1 - y_2)$ 

In the binary form shown, the resulting recoding is the Booth or differentiating recoding, and transforms each binary digital position into a redundant

symmetric digit set  $b^1 = \{1,0,1\}$ .

 $+ 2 (y_0 - y_1) + (y_{-1} - y_0)$ 

The above formulation may also be written as

$$2^{4} (-2y_{5} + y_{4} + y_{3}) + 2^{2} (-2y_{3} + y_{2} + y_{1})$$
  
+  $2^{0} (-2y_{1} + y_{0} + y_{-1})$ 

Each radix 4 digit is then a member of the symmetric digit set  $d^2 = \{2,1,0,1,2\}$ .

From a theoretical point of view, the use of symmetric digit sets is apparently advantagous. First, distributivity is preserved, as indicated in section 4. Second, for a normalized digit set of diminished cardinality  $\delta$  ( $\delta$  even), the diminished cardinality of the product set is  $\delta$ . In contrast, for a symmetric digit set with  $\delta=2\omega$ , the product set ranges from  $-\frac{\delta^2}{4}$  to  $\frac{\delta^2}{4}$ , with diminished

For the purposes of this paper, an nxn array multiplier will be considered to consist of two parts; an array of elementary multipliers, and a summing network which converts the weighted outputs of the multiplier array to the desired weighted binary product.

Current practice is to use an array of  $n^2$  AND gates for the elementary multipliers, with each AND gate performing an elementary multiplication of

one of the types  $a^0 + a^0 \times a^0 = a^1 \times a^1$ , or  $a^1 + a^1 \times a^0 = a^0 \times a^1$ . The diminished cardinality of the weighted sum of the AND gate array will always be  $2^{2n} - 2^{n+1} + 1$ .

Although the use of symmetric digit sets appears to be theoretically attractive, the recoding procedures necessary to achieve them increase the information content. For example, for the Booth recoding, each digital position requires a

type  $b^l$  digit set, and each element of the multiplier array performs the operation  $b^1 \leftrightarrow b^1 \times b^1$ , at a cost roughly equivalent to a half adder. The

information from each of the n2 elementary multipliers is also doubled, which increases the cost of the summing network as well. Thus, use of the Booth recoding is clearly not cost effective.

Use of the radix four symmetric digit set  $2a^1 + b^0$  requires the use of  $n^2/4$  elementary multipliers of the form  $4a^{1} + 2a^{0} + b^{0} + (2a^{1} + b^{0}) \times a^{1}$ (2a $^1$  + b $^0$ ). The output requires 4 bits, so that the information presented to the summing network is  $4(^{n^2}/_4) = n^2$ , which is the same as that of the

conventional array. Thus the summing network should require roughly the same amount of hardware as the conventional array, but each elementary multiplier is more complicated than the four AND gates of the conventional array that it replaces.

It is also possible to compare the array version of the serial multiplier used in Illiac II

and Illiac III. The multiplicand
$$x = -2^{n-1}x_{n-1} + \sum_{j=0}^{n-2} 2^{j} x_{j} \text{ was left in }$$

conventional form and the multiplier y was recoded radix 4, with each digit of the form

$$\begin{array}{lll} d^2 = \{\,\overline{2},\overline{1},0\,,1\,,2\}\,. & \text{Thus } y = 2y - y = \\ 1/2(n-2) & \Sigma & (-2y_{2i+1} + y_{2i} + y_{2i-1})\,, \text{ with } y_{-1} = 0\,. \\ & \text{The recoded digit of the form } d^2 \text{ controls a condi-} \end{array}$$

tional complementing and doubling circuit.

Without going into the design details, the order of magnitude costs are about the same as those of the conventional array of  $n^2$  AND gates. The reduced cost of the summing network approximately compensates for the additional costs of the multipliers and the conditional complementing and doubling circuits.

# Conclusions

For conventional representations of numbers, the results obtained are disappointing. For the standard nxn array of AND gates, the diminished cardinality of the array output remains invariant when the weights of some of the digits are made negative, and no advantage can be taken of the reduced cardinality which theoretically could be achieved.

Attempts to convert from conventional to symmetric digit sets are self-defeating, because of the increase in information content and because of the increased complexity of both the multiplier array and the summing network.

The technique of recoding the multiplier radix 4, with conditional complementation and doubling, appears to deserve further study in detail, since the order of magnitude calculations indicate that it is cost competitive with the conventional nxn AND gate array.

For signed-digit arithmetic, the results obtained reinforce the desirability of using symmetric digit sets. Not only are symmetric digit sets advantageous for subtraction, since x and -x are always members of the set, but the results indicate that symmetric digit sets are most efficient for multiplication.

For symmetric array multipliers, the tradeoff between the cost of the elementary multiplier array and the cost of the summing network deserves investigation. It appears to be advantageous to  $\frac{n^2}{2} \text{ elementary multipliers of the form}$   $2a^1 + b^0 + b^1 \times (2a^1 + b^0) \text{ rather}$  than  $n^2 \text{ multipliers of the form } b^1 + b^1 \times b^1,$  because of the reduced costs of the summing network. Use of  $\frac{n^2}{4} \text{ elementary multipliers of the}$ 

form  $4a^1 + 2a^0 + b^0 \leftarrow (2a^1 + b^0)$ x  $(2a^1 + b^0)$  should also be investigated.

Note that the designs of elementary multipliers must be logical designs. For example  $b^1 \times (2a^1+b^0)$  should not be designed as  $(b^1 \times 2a^1)+(b^1 \times b^0)$ , since distributivity does not hold. The results obtained thus indicate which algebraic manipulations are permissible for efficient multiplier design.

# 8. Bibliography

- 8.1 Atkins, D. E., "Design of the Arithmetic Units of Illiac III: Use of Redundancy and Higher Radix Methods," IEEE Trans. Comput. Vol. C-19, No. 8, Aug., 1970, pp. 720-733.
- 8.2 Avizienis, A., "Signed-Digit Number Representations for Fast Parallel Arithmetic," IRE Trans. on Electronic Computers, Vol. EC-10, No. 3, pp. 389-400; September, 1961.
- 8.3 Baugh, C. R. and Wooley, B. A., "A Two's Complement Parallel Array Multiplication Algorithm," IEEE Trans. Computers, Vol. C-22, No. 12, December, 1973, pp. 1045-1047.
- 8.4 Hwang, K., "Computer Arithmetic; Principles, Architecture, and Design," John Wiley & Sons, 1979, Chapters 5 and 6.
- 8.5 Robertson, J. E., "A Systematic Approach to the Design of Structures for Arithmetic," Proc. 5th Symposium on Computer Arithmetic, Ann Arbor, MI, May, 1981.

## Acknowledgement:

This paper was supported in part by the National Science Foundation under Grant No. MCS-8109491. The research on which this paper is based was begun at the University of Utah during the summer of 1982 and continued at the University of Illinois during the fall of 1982, and at Stanford University during the winter of 1983. The author is grateful to these institutions and their personnel for their encouragement and support.