

### Instituto Tecnologico de Buenos Aires

#### Ingeniera Electronica

### ELECTRONICA III

### Implementación de circuitos logicos

Autores:
Martín Rodriguez Turco
Tobias Scala
Guido Panaggio
Juan Martin Laguinge

Profesores:
Kevin DEWALD
Pablo WUNDES
Sebastian FALCONARO

11 de noviembre de 2018

# Índice general

| 1. | Ejercicio 2           | 2 |
|----|-----------------------|---|
|    | 1.1. Máquina de Moore | 3 |
|    | 1.2. Máquina de Mealy | 5 |
| Aı | ppendix               | 7 |
| R  | eferences             | 8 |

## Capítulo 1

# Ejercicio 2

Se desea diseñar una máquina de estados que, al recibir la siguiente secuencia de bits en forma sincrónica 1-1-0-1 encienda una salida y en caso contrario, la mantiene apagada. Se obtienen 5 estados para la misma, en los cuales va a haber un default que va a ser el estado al cual todos los demás estados van a volver en caso de no recibir los deseados además de ser el estado por el cual va a empezar la máquina de estados.

Podemos representar los mismos en el siguiente diagrama de estados:

En donde Z es la salida dada por la máquina de estados al encontrarse en el estado co-



Figura 1.1: Diagrama de estados

rrespondiente y W es la entrada necesaria para que traicione al siguiente estado y la flecha es la encargada de indicar el sentido de la transición.

Este mismo esquema también queda encapsulado en la siguiente tabla de estados:

Cuadro 1.1: Tabla de estados

| Estado  | Estado s     | Salida  |         |
|---------|--------------|---------|---------|
| actual  | W=0 $W=1$    |         | ${f Z}$ |
| Default | Default A    |         | 0       |
| A       | Default      | В       | 0       |
| В       | $\mathbf{C}$ | Default | 0       |
| C       | Default      | D       | 0       |
| D       | Default      | Default | 1       |

Para la implementación de esté falta realizar la asignación de valores de estado, lo cual nos lleva cambiar la tabla anterior por la siguiente:

Cuadro 1.2: Tabla de estados asignados

| Estado  | Asignacion del | Estado siguiente |     | Salida       |
|---------|----------------|------------------|-----|--------------|
| actual  | Estado actual  | W=0              | W=1 | $\mathbf{Z}$ |
| Default | 000            | 000              | 001 | 0            |
| A       | 001            | 000              | 010 | 0            |
| В       | 010            | 011              | 000 | 0            |
| С       | 011            | 000              | 100 | 0            |
| D       | 100            | 000              | 000 | 1            |

### 1.1. Máquina de Moore

Para nuestro caso tenemos el siguiente circuito secuencial genérico:



Figura 1.2: Circuito generico

Donde vamos a utilizar Flip-Flops D dado que la entrada D de estos va a corresponder

con el estado siguiente  $Y_i$  y van a estar seteados por el clock para que esta salida luego cambia la variable  $y_i$  a  $Y_i$ , dado que  $y_i$  son las variables de estado actual.De la tabla 1, obtenemos los siguientes mapas de Karnaugh:

Figura 1.3: Mapa de Karnaugh para  $Y_1$ 

Figura 1.4: Mapa de Karnaugh para  $Y_2$ 

| $WY_3$ | ${}^{2}Y_{1} \\ 00$ | 01 | 11 | 10 |
|--------|---------------------|----|----|----|
| 00     | 0                   | 0  | 0  | 1  |
| 01     | 0                   | X  | X  | X  |
| 11     | 0                   | X  | X  | X  |
| 10     | 0                   | 1  | 0  | 0  |

Figura 1.5: Mapa de Karnaugh para  $Y_3$ 

| $WY_3$ | ${}^{2}Y_{1} \\ 00$ | 01 | 11 | 10 |
|--------|---------------------|----|----|----|
| 00     | 0                   | 0  | 0  | 0  |
| 01     | 0                   | X  | X  | X  |
| 11     | 0                   | X  | X  | X  |
| 10     | 0                   | 0  | 1  | 0  |

Figura 1.6: Mapa de Karnaugh para Z

| $Y_3$ | ${}^{2}Y_{1} \\ 00$ | 01 | 11 | 10 |
|-------|---------------------|----|----|----|
| 0     | 0                   | 0  | 0  | 0  |
| 1     | 1                   | X  | X  | X  |

En donde las X representan el don't care y se les decidió dar un valor acorde al cual permiten la simplificación del circuito. Dando como resultado las siguientes ecuaciones:

$$Y_1 = W \cdot \overline{y_3} \cdot \overline{y_2} \cdot \overline{y_1} + \overline{W} \cdot \overline{y_1} \cdot y_2$$

$$Y_2 = W \cdot \overline{y_2} \cdot y_1 + \overline{W} \cdot \overline{y_1} \cdot y_2$$

$$Y_3 = W \cdot y_2 \cdot y_1$$

$$Z = y_3$$

Se realizo la correspondiente simulación en verilog, el cual nos da un comportamiento ideal del circuito, obteniendo el siguiente resultado:



Figura 1.7: Simulación

### 1.2. Máquina de Mealy

Para poder realizar la máquina de estados con el modelo de Mealy es necesario que la salida dependa tanto de los estados como de la entrada de esta, con lo cual van a ser necesarios realizar cambios a la actual máquina de estados.

Quitando el último estado del diagrama 1 y expresando la salida junto con la entrada podemos obtener el siguiente diagrama:



Figura 1.8: Diagrama de estados

El diagrama tiene un estado menos ahorra, esto provoca los siguientes cambio en la tabla de asignación:

Cuadro 1.3: Tabla de estados asignados

| Estado  | Asignacion del | Estado siguiente |     | Salida Z |                |
|---------|----------------|------------------|-----|----------|----------------|
| actual  | Estado actual  | W=0              | W=1 | W=0      | $\mathbf{W}=1$ |
| Default | 00             | 00               | 01  | 0        | 0              |
| A       | 01             | 00               | 10  | 0        | 0              |
| В       | 10             | 11               | 00  | 0        | 0              |
| C       | 11             | 00               | 00  | 0        | 1              |

La cual nos permite obtener los siguientes mapas de Karnaugh:

Figura 1.9: Mapa de Karnaugh para  $Y_1$ 



Figura 1.10: Mapa de Karnaugh para  $Y_2$ 



Figura 1.11: Mapa de Karnaugh para Z

| $Y_3$ | ${}^{2}Y_{1} \\ 00$ | 01 | 11 | 10 |
|-------|---------------------|----|----|----|
| 0     | 0                   | 0  | 0  | 0  |
| 1     | 0                   | 0  | 1  | 0  |

Dando como resultado de las simplificaciones las siguientes ecuaciones:

$$Y_1 = W \cdot \overline{y_2} \cdot \overline{y_1} + \overline{W} \cdot \overline{y_1} \cdot y_2$$

$$Y_2 = W \cdot \overline{y_2} \cdot y_1 + \overline{W} \cdot \overline{y_1} \cdot y_2$$

$$Z = W \cdot y_2 \cdot y_1$$

Se realizo la correspondiente simulación en verilog, el cual nos da un comportamiento ideal del circuito, obteniendo el siguiente resultado:



Figura 1.12: Simulación

# Appendix

# Bibliografía

[1] Stephen Brown and Zvonko Vranesic. "Fundamentals of Digital Logic with Verilog Design" third edition.