## **S**ón

a) Para comparar X e Y es necesario comparar cada bit de uno de ellos con el bit de igual peso del otro. Para hacer estas comparaciones utilizamos los comparadores de 1 bit propuestos. Si el resultado de la comparación de  $x_i$  e  $y_i$  es:  $M_i$ ,  $I_i$  y  $m_i$ , se cumple que:

$$\begin{aligned} \mathbf{M}_i = &1 \text{ si} \quad \mathbf{x}_i > \mathbf{y}_i \\ \mathbf{I}_i = &1 \text{ si} \quad \mathbf{x}_i = \mathbf{y}_i \\ \mathbf{m}_i = &1 \text{ si} \quad \mathbf{x}_i < \mathbf{y}_i \end{aligned}$$

A partir de  $M_i$ ,  $I_i$  y  $m_i$  se generan las salidas M, I y m del comparador de 2 bits mediante las siguientes funciones booleanas:

$$\mathbf{M} = \mathbf{M}_1 + \mathbf{I}_1 \, \mathbf{M}_0$$
$$\mathbf{I} = \mathbf{I}_1 \, \mathbf{I}_0$$
$$\mathbf{m} = \mathbf{m}_1 + \mathbf{I}_1 \, \mathbf{m}_0$$

La explicación de estas expresiones es inmediata:

$$\mathbf{x} > \mathbf{y} \text{ si } (\mathbf{x}_1 > \mathbf{y}_1) \mathbf{o} ((\mathbf{x}_1 = \mathbf{y}_1) \mathbf{y} (\mathbf{x}_0 > \mathbf{y}_0))$$
  
 $\mathbf{x} = \mathbf{y} \text{ si } (\mathbf{x}_1 = \mathbf{y}_1) \mathbf{y} (\mathbf{x}_0 = \mathbf{y}_0)$   
 $\mathbf{x} < \mathbf{y} \text{ si } (\mathbf{x}_1 < \mathbf{y}_1) \mathbf{o} ((\mathbf{x}_1 = \mathbf{y}_1) \mathbf{y} (\mathbf{x}_0 < \mathbf{y}_0))$ 

La Figura 2000-2-2 muestra el circuito lógico pedido en este apartado obtenido a partir de las expresiones anteriores.



Figura 2000-2-2: Circuito lógico de un comparador de dos números de 2bits

- **b**) Para calcular el tamaño de la memoria ROM necesaria hay que saber el número entradas y salidas del circuito.
  - Entradas. Este circuito tiene **5 entradas**: 2 para la entrada de datos  $X(x_1x_0)$ , 2 para la entrada de datos  $Y(y_1y_0)$  y una entrada de control (c) para la selección de la operación a realizar por el circuito. Esta última entrada de control va a tener el siguiente significado:
    - c = 0: Suma
    - c = 1: Producto
  - Salidas: Este circuito tiene **4 salidas**. El resultado de la suma de dos números de dos bits tiene tan sólo 3 bits pero, para el resultado del producto de dos números de dos bits se requieren 4 bits. Como el circuito a diseñar tiene que poder hacer ambas operaciones, su salida ha de tener, necesariamente, 4 bits.

Por tanto, el tamaño de la memoria ROM necesario para implementar el sumador es de:  $2^5$  palabras  $\times$  4 bits/palabra. El significado de cada una de sus entradas y salidas se muestra claramente en la Figura 2000-2-3. Finalmente, en la Tabla 2000-2-2 se muestra el contenido que debería tener la memoria ROM.



Figura 2000-2-3: Sumador/Multiplicador diseñado con memoria ROM

| Dirección memoria<br>c x <sub>1</sub> x <sub>0</sub> y <sub>1</sub> y <sub>0</sub> | Contenido                                            | <b>Dirección memoria</b><br>c x <sub>1</sub> x <sub>0</sub> y <sub>1</sub> y <sub>0</sub> | Contenido                                |
|------------------------------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------|------------------------------------------|
| $A_4 A_3 A_2 A_1 A_0$                                                              | $b_3 b_2 b_1 b_0$                                    | $A_4 A_3 A_2 A_1 A_0$                                                                     | $b_3 b_2 b_1 b_0$                        |
| 0 0 0 0 0                                                                          | 0 0 0 0                                              | 1 0 0 0 0                                                                                 | 0 0 0 0                                  |
| 0 0 0 0 1                                                                          | 0 0 0 1                                              | 1 0 0 0 1                                                                                 | 0 0 0 0                                  |
| 0 0 0 1 0                                                                          | 0 0 1 0                                              | 1 0 0 1 0                                                                                 | 0 0 0 0                                  |
| 0 0 0 1 1                                                                          | 0 0 1 1                                              | 1 0 0 1 1                                                                                 | 0 0 0 0                                  |
| 0 0 1 0 0<br>0 0 1 0 1<br>0 0 1 1 0<br>0 0 1 1 1                                   | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 1 0 1 0 0<br>1 0 1 0 1<br>1 0 1 1 0<br>1 0 1 1 1                                          | 0 0 0 0<br>0 0 0 1<br>0 0 1 0<br>0 0 1 1 |
| 0 1 0 0 0                                                                          | 0 0 1 0                                              | 1 1 0 0 0                                                                                 | 0 0 0 0                                  |
| 0 1 0 0 1                                                                          | 0 0 1 1                                              | 1 1 0 0 1                                                                                 | 0 0 1 0                                  |
| 0 1 0 1 0                                                                          | 0 1 0 0                                              | 1 1 0 1 0                                                                                 | 0 1 0 0                                  |
| 0 1 0 1 1                                                                          | 0 1 0 1                                              | 1 1 0 1 1                                                                                 | 0 1 1 0                                  |
| 0 1 1 0 0                                                                          | 0 0 1 1                                              | 1 1 1 0 0                                                                                 | 0 0 0 0                                  |
| 0 1 1 0 1                                                                          | 0 1 0 0                                              | 1 1 1 0 1                                                                                 | 0 0 1 1                                  |
| 0 1 1 1 0                                                                          | 0 1 0 1                                              | 1 1 1 1 0                                                                                 | 0 1 1 0                                  |
| 0 1 1 1 1                                                                          | 0 1 1 0                                              | 1 1 1 1 1                                                                                 | 1 0 0 1                                  |

Tabla 2000-2-2: Contenido de la memoria ROM

 $\mathbf{c}$ ) En la Figura 2000-2-4 se muestra el diseño de la UAL pedida en el problema donde se han utilizado 4 multiplexores para seleccionar el valor adecuado a colocar en la salida, gobernados por las entradas de control  $\mathbf{c}_1$  y  $\mathbf{c}_0$ . También la entrada de control de la UAL  $\mathbf{c}_0$  se utiliza para seleccionar la operación a realizar por el Sumador/Multiplicador.



Figura 2000-2-4: UAL pedida en el problema