## INSTITUTO TECNOLÓGICO DE BUENOS AIRES

22.12 - Electrónica III

# Trabajo Práctico $N^{\circ}3$

# Grupo 4

BERTACHINI, Germán 58750 GALDEMAN, Agustín 59827 LAGUINGUE, Juan Martín 57430

Profesores:

DEWALD, Kevin WUNDES, Pablo



Presentado el 14 de Noviembre de 2019

# Índice

| jercicio 1                                  | 2  |
|---------------------------------------------|----|
| Introducción                                | 2  |
| Tabla de transiciones y diagrama de estados | 3  |
| Implementación - Caso I                     | 4  |
| Implementación - Caso II                    | 5  |
| Conexión Caso I y II                        | 5  |
| jercicio 2                                  | 6  |
| Introducción                                | 6  |
| Implementación                              | 7  |
| Asignación de estados                       | 7  |
| Mapas de Karnaugh                           | 8  |
| Circuito resultante                         | 8  |
| Simulación                                  | 8  |
| Experimental                                | 9  |
| jercicio 3                                  | 9  |
| Introducción                                | 9  |
| Implementación                              |    |
| Consideraciones para la placa               | 11 |
| Uso de level shifters                       |    |
| Componenetes utilizados                     | 12 |

## Ejercicio 1

#### Introducción

En este ejercicio se plantea una máquina de estados para controlar la carga de un tanque de agua mediante la utilización de dos bombas independientes.

La cátedra solicita una implementación mediante una máquina de Moore, la cual se caracteriza porque las salidas no dependan de las entradas. Estas últimas servirán para realizar cambios de estado y controlar el flujo general de la máquina. Por otro lado, cada estado tendrá asociado una salida. La implementación característica de una máquina de Moore se presenta a continuación:



Figura 1: Máquina de Moore

Los sensores S e I ubicados en la parte superior e inferior del tanque respectivamente, actuarán como las entradas de la máquina de estado, su valor será 1 al detectar agua y 0 en caso contrario. Para la implementación se utilizarán cuatro estados los cuales indicarán el estado de funcionamiento de las bombas como se muestra en la tabla (1).

Para representar dichos estados son necesarios dos bits, como dichos bits representarán el estado de las bombas, los estados coincidirán con las salidas de la máquina de Moore.

| Estado | $Q_1$ | $Q_0$ |
|--------|-------|-------|
| А      | 0     | 0     |
| В      | 0     | 1     |
| C      | 1     | 0     |
| D      | 1     | 1     |

Tabla 1: Estados utilizados

Donde dichos estados representan:

- A: Ninguna bomba está encendida
- B: La bomba 0 está encendida
- C: La bomba 1 está encendida
- D: Ambas bombas están encendidas

### Tabla de transiciones y diagrama de estados

Todas las transiciones posibles se pueden observar en el tabla (2). Se plantean las siguientes consideraciones:

- Si llega la entrada I=0 y S=1, lo que implicaría que se detecta agua en la parte superior pero no en la inferior, se considera un absurdo y la máquina se mantendrá en su estado actual.
- Para la transición entre los estados A y D a los estados B o C, con esta tabla resulta imposible determinar cuál fue la última bomba encendida por lo que se pondrá "Don't care". Para realizar dichas transiciones se realizará una lógica aparte.

| E                           | $Q_1$                                                         | $Q_0$                                                         | I                                                                            | S                | $E^*$                           | $Q_1^*$                                                                      | $Q_0^*$                                                            |
|-----------------------------|---------------------------------------------------------------|---------------------------------------------------------------|------------------------------------------------------------------------------|------------------|---------------------------------|------------------------------------------------------------------------------|--------------------------------------------------------------------|
| Α                           |                                                               |                                                               | 0                                                                            | 0                | D                               | 1                                                                            | 1                                                                  |
| Α                           | 0                                                             | 0                                                             | 0                                                                            | 1                | Α                               | 0                                                                            | 0                                                                  |
| Α                           | 0                                                             | 0                                                             | 1                                                                            | 0                | X                               | Χ                                                                            | X                                                                  |
| Α                           | 0                                                             | 0                                                             | 1                                                                            |                  | Α                               | 0                                                                            | 0                                                                  |
| В                           | 0                                                             | 1                                                             | 0                                                                            | 0                | D                               | 1                                                                            | 1                                                                  |
| В                           | 0                                                             | 1                                                             | 0                                                                            | 1                | D<br>A<br>X<br>A<br>D<br>B      | 0                                                                            | 1                                                                  |
| В                           | 0                                                             | 1                                                             | 1                                                                            | 1<br>0<br>1<br>0 | В                               | 0                                                                            | 1                                                                  |
| В                           | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>1<br>1<br>1<br>1<br>1 | 0<br>0<br>1<br>1<br>1<br>1<br>0<br>0<br>0<br>0<br>1<br>1<br>1 | 1<br>1<br>0<br>0<br>1<br>1<br>0<br>0<br>1<br>1<br>0<br>0<br>1<br>1<br>0<br>0 | 1<br>0<br>1      | Α                               | 0                                                                            | 0                                                                  |
| C                           | 1                                                             | 0                                                             | 0                                                                            | 0                | D                               | 1                                                                            | 1                                                                  |
| C                           | 1                                                             | 0                                                             | 0                                                                            | 1                | C                               | 1                                                                            | 0                                                                  |
| C                           | 1                                                             | 0                                                             | 1                                                                            | 0                | C                               | 1                                                                            | 0                                                                  |
| C                           | 1                                                             | 0                                                             | 1                                                                            | 1                | Α                               | 0                                                                            | 0                                                                  |
| D                           | 1                                                             | 1                                                             | 0                                                                            | 0                | D                               | 1                                                                            | 1                                                                  |
| D                           | 1                                                             | 1                                                             | 0                                                                            | 1                | D                               | 1                                                                            | 1                                                                  |
| A A A B B B C C C C D D D D |                                                               | 1                                                             |                                                                              | 0                | A<br>D<br>C<br>C<br>A<br>D<br>D | 1<br>0<br>X<br>0<br>1<br>0<br>0<br>0<br>1<br>1<br>1<br>1<br>0<br>1<br>1<br>X | 1<br>0<br>X<br>0<br>1<br>1<br>1<br>0<br>0<br>0<br>0<br>1<br>1<br>X |
| D                           | 1                                                             | 1                                                             | 1                                                                            | 1                | Α                               | 0                                                                            | 0                                                                  |

Tabla 2: Transiciones entre estados

La tabla anterior nos indicará la lógica de entrada para un Caso I mientras que para transiciones entre los estados A y D a los estados B o C se considerará la lógica para un Caso II.

A continuación, se representa el diagrama de estados y la tabla de transiciones resumida de nuestra máquina para el Caso I.

| Estado | S=0 |     | S=  | =1  |
|--------|-----|-----|-----|-----|
| Actual | I=0 | l=1 | I=0 | l=1 |
| A      | D   | Α   | Χ   | Α   |
| В      | D   | В   | В   | Α   |
| C      | D   | C   | C   | Α   |
| D      | D   | D   | Χ   | Α   |

Tabla 3: Tabla de transiciones



Figura 2: Diagrama de estados

# Implementación - Caso I

Se necesitan dos bits para almacenar los cuatro estados utilizados, por lo que se necesitarán dos Flip-Flop D para guardarlos en memoria. Desarrollando las tablas obtenemos los siguientes mapas de Karnaugh que nos indicarán los circuitos lógicos necesarios para el Caso I.



Dando como resultado el siguiente circuito:



Figura 3: Lógica de la entrada - Caso I

#### Implementación - Caso II

Por otro lado, para el Caso II era necesario almacenar cual había sido la última bomba en no activarse por lo que decidió guardar dicha información en un Flip-Flop T. Dicho bit sólo debería ser cambiado bajo dos condiciones, cuando la máquina tenga entradas I=1 y S=0 estando en el estado A o D.

Para el primer caso implica que ambas bombas están apagadas y se detecta que el tanque se encuentra por la mitad, por lo que hay que proceeder a activar la última bomba en no activarse. Para el otro, se está trabajando con ambas bombas y se detecta que el reservorio está por la mitad, por lo que se procederá a apagar la última en entrar en servicio. Las salidas del Flip-Flop T representarán el próximo estado ya que representan el estado de las bombas.

El siguiente circuito(??) representa dicha lógica.



Figura 4: Lógica de la entrada - Caso II

La entrada I funcionará como el clock del FFT asociado a una compuerta AND que sólo se activará al estar en los estados previamente mencionados. Consecuentemente, el flanco de clock para dicho Flip-Flop sólo llegará al transicionar entre dichos estados.

### Conexión Caso I y II

Para finalizar era necesario un circuito que indicará cuando el siguiente estado iba a provenir del cirucito de entrada lógico del Caso I o del Caso II. Por ende, se implementa un multiplexor cuya entrada de activación va a estar dada por el Caso II.

Por lo tanto, cuando la variable de control del multiplexor sea 1, el próximo estado va a estar determinado por las salidas del Flip-Flop T mientras que, para el caso contrario, será provisto por el circuito lógico de entrada del Caso I.



Figura 5: Conexión lógica de las lógicas de entrada

Se adjunta simulación en Proteus y Verilog para respaldar el diseño.

# Ejercicio 2

#### Introducción

En esta sección desarrollaremos el diseño de una máquina de estados de Mealy capaz de reconocer la secuencia 1-1-0-1, enviada de forma serial y una vez reconocida la secuencia, obtendremos una salida de encendido. Mientras que, en el caso contrario tendremos una salida apagada.

La misma consiste en 4 estados, un default que va a ser el estado donde siempre va a volver en caso de error y 3 estados de transición. El estado default va a ser el estado inicial de la misma.

A continuación podemos observar el diagrama de la misma:



Figura 6: Diagrama de estados

En donde Z es la salida, W es la entrada y las flechas indican hacia donde se realiza la transición así como bajo qué valor de la entrada sucede la misma.

De la figura 6 podemos obtener la siguiente tabla de estados:

Tabla 4: Tabla de estados

| Estado Actual | Estado s | siguiente | Salida |       |
|---------------|----------|-----------|--------|-------|
| LStado Actual | W = 0    | W = 1     | W = 0  | W = 1 |
| Default       | Default  | Α         | 0      | 0     |
| А             | Default  | В         | 0      | 0     |
| В             | С        | Default   | 0      | 0     |
| С             | Default  | Default   | 0      | 0     |

## **Implementación**

Para implementar una máquina de Mealy utilizamos el siguiente circuito secuencial genérico:



Figura 7: Circuito genérico

#### Asignación de estados

Por último, se realiza la asignación de los estados dando lugar a la siguiente tabla:

Tabla 5: Tabla de estados asignados

|               | Asignado del estado actual | Estado s | siguiente | Sal   | ida   |
|---------------|----------------------------|----------|-----------|-------|-------|
| Estado Actual | 24.24                      | W = 0    | W = 1     |       |       |
|               | $y_2y_1$                   | $Y_2Y_1$ | $Y_2Y_1$  | W = 0 | W = 1 |
| Default       | 00                         | 00       | 01        | 0     | 0     |
| А             | 01                         | 00       | 10        | 0     | 0     |
| В             | 10                         | 11       | 00        | 0     | 0     |
| С             | 11                         | 00       | 00        | 0     | 1     |

#### Mapas de Karnaugh

A partir de la tabla 5 se obtienen los siguientes mapas de Karnaugh:



#### Circuito resultante

Para la realización del circuito utilizamos los Flip-Flop D debido a que poseen una relación directa con las variables de estado  $y_i$  y  $Y_i$ . Donde las variables  $y_i = Q_i$ , pero cabe mencionar que esto es equivalente para todos los distintos tipos de Flip-Flop y  $Y_i = D_i$  que es exclusivo del mismo. Finalmente, a partir de los mapas de Karnaugh anteriormente mostrados, surge el siguiente circuito:



Figura 8: Circuito genérico

### Simulación

Luego, se generó la correspondiente simulación en Verilog, el cual nos brinda el comportamiento ideal del mismo. Esto dio lugar al siguiente resultado:



Figura 9: Circuito genérico

### **Experimental**

Finalmente, se realizó la implementación en PBC de lo obtenido en las anteriores subsecciones dando a lugar los siguientes resultandos:



Figura 10: Lo visualizado en el osciloscopio



Figura 11: Lo obtenido explicado

Cabe mencionar que las imágenes fueron editadas para tener un mejor entendimiento y realizar una mejor exposición sobre las mismas. Ademas, todas las mediciones fueron obtenidas por medio del analog discovery.

# Ejercicio 3

#### Introducción

En este ejercicio se implementará la siguiente máquina de Moore provista por la cátedra mediante su diagrama de estados(??):



Figura 12: Diagrama de estados

Esta máquina cuenta con tres estados que son los siguientes:

| Estado | $Q_1$ | $Q_0$ |
|--------|-------|-------|
| Α      | 0     | 0     |
| В      | 0     | 1     |
| C      | 1     | 0     |

Tabla 6: Estados utilizados

La tabla de transición para esta máquina es la que se muestra a continuación:

| Estado Astual    | Ent | Salida |   |
|------------------|-----|--------|---|
| Estado Actual X= |     | X=1    | S |
| А                | Α   | В      | 0 |
| В                | Α   | C      | 1 |
| С                | Α   | C      | 0 |

Tabla 7: Tabla de transiciones

### Implementación

Se necesitan dos bits para almacenar los tres estados utilizados, por lo que se necesitarán dos Flip-Flop D para guardarlos en memoria. Desarrollando las tablas obtenemos los siguientes mapas de Karnaugh que nos indicarán los circuitos lógicos necesarios.



Dando como resultado el siguiente circuito:



Figura 13: Lógica de entrada

Por otro lado, se puede observar claramente en la tabla de transiciones (??) que el valor de la salida sólo se encuentra alto para el caso del estado B. Dando como resultado que el valor de la salida va a estar dado por:

$$S = \bar{Q}_1 Q_0 \tag{1}$$

Por ende, la lógica de salida para nuestra máquina de estados estará representada por:



Figura 14: Lógica de salida

Se adjunta simulación en Proteus para respaldar el diseño.

### Consideraciones para la placa

La cátedra solicita que las entradas y salidas de la máquina de estados tengan una lógica de 5V mientras que la lógica interna sea de  $3.3\,V$ .

Como primer medida, se utilizará un regulador de tensión (LMS1587CS) para obtener la tensión para la lógica interna. Dentro del circuito interno no se podrán usar integrados de puertas discretas usuales sino que será necesario utilizar integrados de baja tensión, en nuestro caso un integrado (74AUP1G08-Q1) para las compuertas AND de dos entradas y un (74AUP2G32) para la compuerta OR. Por otro lado, también será necesario un Flip Flop D de baja tensión (74AUP1G79).

#### Uso de level shifters

Para variar la tensión de entrada de 5V a 3.3V se utilizan dos transistores NPN a modo de level shifter como se muestran en la figura (??).



Figura 15: Level Shifter 3.3V to 5V

Para variar la tensión de entrada de  $3.3\,V$  a  $5\,V$  se utilizan dos transistores NPN a modo de level shifter como se muestran en la figura (??).



Figura 16: Level Shifter 5V to 3.3V

#### Componenetes utilizados

- $\blacksquare$  Regulador de tensión 5V a 3.3V LMS1587CS
- Flip-Flop D 74*AUP*1*G*79
- ullet Compuerta AND 2 entradas 74AUP1G08-Q1
- ullet Compuerta OR 2 entradas 74AUP2G32
- Transistor NPN BC548 74AUP2G32