

**UNIVERSIDAD DE GRANADA.**

**ESCUELA TECNICA SUPERIOR DE  
INGENIERIAS INFORMATICA Y DE  
TELECOMUNICACIÓN.**



**Departamento de Ingeniería de Computadores,  
Automática y Robótica.**

**TECNOLOGÍA Y ORGANIZACIÓN DE  
COMPUTADORES.**

**PRÁCTICA 3.  
ANÁLISIS Y REALIZACIÓN DE UNA UNIDAD  
ARITMÉTICO-LÓGICA (ALU) DE 4 BITS.**

**1º GRADO EN INGENIERÍA INFORMÁTICA.**



## PRÁCTICA 3.

# ANÁLISIS Y REALIZACIÓN DE UNA UNIDAD ARITMÉTICO-LÓGICA (ALU) DE 4 BITS.

### **Objetivos:**

- *Analizar teóricamente una Unidad Aritmético-Lógica de 4 bits a partir de los esquemáticos de los circuitos que la implementa. Montar y verificar su funcionamiento en un simulador lógico.*

### **Material necesario para el desarrollo de la práctica:**

- Guión de prácticas disponible en SWAD en el apartado ARCHIVOS>DOCUMENTOS>03.-PRACTICAS>PRACTICA\_3.
- Material del Tema 3º disponible en SWAD en el apartado ARCHIVOS>DOCUMENTOS>01.-TEORIA y PROBLEMAS>TEMA\_3>03.-TEMA\_3\_TOC\_SISTEMAS\_COMBINACIONALES.PDF. Apartado 3.4.2. ALU y 3.4.4.- Multiplexores/Demultiplexores.
- Seminario 5. Guía de Trabajo Autónomo. PARTE 1: INTRODUCCIÓN AL MANEJO DE UN SIMULADOR LÓGICO, páginas 1-3 a 1-10 (ambas inclusive) disponible en SWAD en el apartado ARCHIVOS>DOCUMENTOS>02.-SEMINARIOS>SEMINARIO\_5>05.-SEMINARIO\_5\_TOC\_SIMULADOR\_ENTRENADOR\_LOGICO\_GUIA.
- Videoclases de Simulador Lógico disponibles en:  
[https://drive.google.com/open?id=1OsHIQ51fdcfGDe0p\\_6b7LtTTbwpoVXop](https://drive.google.com/open?id=1OsHIQ51fdcfGDe0p_6b7LtTTbwpoVXop)  
<https://drive.google.com/open?id=1gvQIrsORnpHDrqPwKSyvEi2vprk6puL>  
[https://drive.google.com/open?id=16hp2vr4GTzM4j0\\_wm1KFXIB0FjWfnmFn](https://drive.google.com/open?id=16hp2vr4GTzM4j0_wm1KFXIB0FjWfnmFn)  
<https://drive.google.com/open?id=1tlFeDH0nthSq09fc75XL1NSP22aDifh5>
- Software Simulador Lógico LogicWorks.

### 3.1. Estudio preliminar:

Se pretende analizar, realizar y verificar, utilizando un simulador lógico, una Unidad Aritmético-Lógica (ALU) que sea capaz de operar con 2 datos A y B de 4 bits. Esta ALU proporcionará las operaciones aritméticas y lógicas indicadas en la *Figura 3.1*. Cada operación se seleccionará según el valor que tomen (1 ó 0) unas señales de control S<sub>2</sub>, S<sub>1</sub>, S<sub>0</sub> y un acarreo de entrada C<sub>in</sub>.

|                       |                                     |
|-----------------------|-------------------------------------|
| G = B - 1             | Decrementar B                       |
| G = A + B             | Sumar A más B                       |
| G = B                 | Transferir B                        |
| G = $\bar{B}$         | Transferir el complemento de B      |
| G = A $\wedge$ B      | Operación A AND B                   |
| G = A + B + 1         | Sumar A más B más 1                 |
| G = A $\oplus$ B      | Operación A XOR B                   |
| G = $\bar{A} + B$     | Sumar el complemento a 1 de A más B |
| G = B + 1             | Incrementar B                       |
| G = A $\vee$ B        | Operación A OR B                    |
| G = $\bar{A} + 1 + B$ | Restar B - A (en complemento a 2)   |



Figura 3.1: Operaciones que realiza la ALU. Esquema general de entradas y salidas.

La estructura jerárquica modular mediante LogicWorks de la ALU se establece en las *Figuras 3.2, 3.3 y 3.4*. Se parte de los circuitos de la *Figura 3.2(a)* y *3.2(b)* que corresponden a las etapas aritmética y lógica, respectivamente. Ambas operan sobre datos de un bit. La etapa aritmética incluye a un sumador completo de un bit (S-1bit) y la etapa lógica un multiplexor 4:1. Estos módulos se “encapsulan” dando lugar a los bloques indicados en la parte inferior de las *Figura 3.2(a)* y *(b)*.



Figura 3.2(a)

Figura 3.2(b)

Figura 3.2. Estructura modular de cada elemento aritmético ó lógico de 1 bit.

En la *Figura 3.3* se ilustra el diseño y “encapsulado” de la Etapa ALU de un bit que integra los módulos anteriores de la *Figura 3.2*.



*Figura 3.3. Estructura de la Etapa ALU de un bit.*

En la *Figura 3.4* se ilustra el diseño y “encapsulado” de una ALU de 4 bits, utilizando 4 Etapas ALU de un bit, como las diseñadas en la *Figura 3.3*.



*Figura 3.3 (bis). Estructura de un MUX 2 a 1 (izquierda) y de un MUX 4 a 1 (derecha).*



Figura 3.4. Estructura completa de la ALU para palabras de 4 bits.

### 3.2. Realización práctica:

1. Trabajo para realizar:

1.1. Analice teóricamente los esquemáticos de los circuitos y etapas de la ALU mostradas en las Figuras 3.2, 3.3 y 3.4. Deduzca, razonadamente, para qué combinaciones de las señales de control  $S_2, S_1, S_0$  y valor de  $C_{in}$  se realiza cada una de las operaciones indicadas en la Figura 3.1. El resultado indíquelo en la columna de la Tabla 3.1 correspondiente a “Operaciones de la ALU deducidas Teóricamente”.

1.2. A la vista del apartado anterior, con las “Operaciones ALU deducidas Teóricamente” y tomando como datos  $A$  y  $B$  de entrada de 4 bits los siguientes  $A = 1101$  y  $B = 0111$ , obtenga, para cada una de las operaciones obtenidas en el apartado anterior, el resultado (dato numérico  $G$ ) que debería obtenerse y anótelo para compararlo posteriormente con el resultado obtenido experimentalmente.

| SEÑALES<br>$S_2 S_1 S_0 C_{in}$ | Operaciones de la ALU<br>deducidas Teóricamente<br>(expresión matemática de G) | Operaciones de la ALU<br>deducidas Experimentalmente<br>(valor numérico de $C_{out} G_3 G_2 G_1 G_0$ ) |
|---------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| 0 0 0 0                         |                                                                                |                                                                                                        |
| 0 0 0 1                         |                                                                                |                                                                                                        |
| 0 0 1 0                         |                                                                                |                                                                                                        |
| 0 0 1 1                         |                                                                                |                                                                                                        |
| 0 1 0 0                         |                                                                                |                                                                                                        |
| 0 1 0 1                         |                                                                                |                                                                                                        |
| 0 1 1 0                         |                                                                                |                                                                                                        |
| 0 1 1 1                         |                                                                                |                                                                                                        |
| 1 0 0 0                         |                                                                                |                                                                                                        |
| 1 0 0 1                         |                                                                                |                                                                                                        |
| 1 0 1 0                         |                                                                                |                                                                                                        |
| 1 0 1 1                         |                                                                                |                                                                                                        |
| 1 1 0 0                         |                                                                                |                                                                                                        |
| 1 1 0 1                         |                                                                                |                                                                                                        |
| 1 1 1 0                         |                                                                                |                                                                                                        |
| 1 1 1 1                         |                                                                                |                                                                                                        |

Tabla 3.1

2. Realice en LogicWorks la ALU de la *Figura 3.4* y **el circuito de prueba de la Figura 3.5**. Para ello, use (de la biblioteca *Simulation IO.clf*) dos componentes HEX KEYBOARD wo/STB para generar los datos  $A_3 A_2 A_1 A_0$  y  $B_3 B_2 B_1 B_0$ , un componente HEX\_DISPLAY para visualizar las salidas  $G_3 G_2 G_1 G_0$ , cuatro BINARY SWITCH para generar las señales  $S_2 S_1 S_0 C_{in}$ , y un BINARY PROBE para visualizar la salida  $C_{out}$  y así realizar la prueba experimental del circuito.
3. En el Laboratorio, introduzca los ejemplos, deducidos teóricamente en el apartado (1.2), en el circuito de prueba y **deduzca experimentalmente** los valores de las señales de control  $S_2, S_1, S_0$  y valor de  $C_{in}$  correspondiente a cada una de las operaciones indicadas en la *Figura 3.1* y **rellene la última columna** de la *Tabla 3.1*. Compruebe que los resultados obtenidos experimentalmente coinciden con los obtenidos en el apartado 1.2.



Figura 3.5. Circuito de prueba de la ALU de 4 bits.