U6\_1. Realizar las siguientes operaciones en binario natural (verificar las respuestas en decimal):

| <b>1.</b> 1100110 <sub>2</sub> + 1001011 <sub>2</sub>                                                          | <b>2.</b> 1011 <sub>2</sub> - 0101 <sub>2</sub>     |
|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| <b>3.</b> 11 <sub>2</sub> + 11 <sub>2</sub>                                                                    | <b>4.</b> 1000 <sub>2</sub> - 101 <sub>2</sub>      |
| <b>5.</b> 100 <sub>2</sub> + 10 <sub>2</sub>                                                                   | <b>6.</b> 1100 <sub>2</sub> - 1000 <sub>2</sub>     |
| <b>7.</b> 111 <sub>2</sub> + 1 <sub>2</sub>                                                                    | <b>8.</b> 1110001 <sub>2</sub> x 111 <sub>2</sub>   |
| <b>9.</b> 110 <sub>2</sub> + 100 <sub>2</sub>                                                                  | <b>10.</b> 101010 <sub>2</sub> x 1001 <sub>2</sub>  |
| <b>11.</b> 1100 <sub>2</sub> + 1000 <sub>2</sub>                                                               | <b>12.</b> 1011 <sub>2</sub> x 101 <sub>2</sub>     |
| <b>13.</b> 1010 <sub>2</sub> + 1011 <sub>2</sub>                                                               | <b>14.</b> 1100 <sub>2</sub> x 101 <sub>2</sub>     |
| <b>15.</b> 1001 <sub>2</sub> + 1011 <sub>2</sub>                                                               | <b>16.</b> 1011 <sub>2</sub> x 11 <sub>2</sub>      |
| <b>17.</b> 1 <sub>2</sub> + 1 <sub>2</sub> + 1 <sub>2</sub> + 1 <sub>2</sub> + 1 <sub>2</sub>                  | <b>18.</b> 1001111 <sub>2</sub> x 0110 <sub>2</sub> |
| <b>19.</b> 1 <sub>2</sub> + 1 <sub>2</sub> | <b>20.</b> 1100 <sub>2</sub> : 100 <sub>2</sub>     |
| <b>21.</b> 11 <sub>2</sub> - 01 <sub>2</sub>                                                                   | <b>22.</b> 101100 <sub>2</sub> : 100 <sub>2</sub>   |
| <b>23.</b> 11 <sub>2</sub> - 10 <sub>2</sub>                                                                   | <b>24.</b> 100100 <sub>2</sub> : 11 <sub>2</sub>    |
| <b>25.</b> 111 <sub>2</sub> - 100 <sub>2</sub>                                                                 | <b>26.</b> 110000 <sub>2</sub> : 110 <sub>2</sub>   |
| <b>27.</b> 101 <sub>2</sub> - 010 <sub>2</sub>                                                                 |                                                     |
|                                                                                                                |                                                     |

- **U6\_2.** Realizar la operación  $0001000_2 111001_2$  en donde los operandos están en binario natural. Utilice 10 bits en las operaciones.
  - a) Comprobar que en binario natural no se puede realizar la operación
  - b) En complemento a 2
- **U6\_3.** Efectuar las siguientes restas en las que los operandos están en binario natural, dando los resultados binario y C-2 con 10 bits (verificar las respuestas en decimal):
  - a) 10000000 110111
  - **b)** 00111111 00011100
  - **c)** 00011100 00111111
  - **d)** 100001 10000
- **U6 4.** Efectuar las siguientes restas, dando los resultados en C-2 con 10 bits
  - **a)**  $20_{10} 30_{10}$
  - **b)**  $51_{10} 64_{10}$
  - **c)** 12<sub>10</sub>-19<sub>10</sub>
- **U6\_5.** Representar los siguientes números en signo-magnitud y C-2 utilizando 7 bits:
  - a)  $+14_{10}$
  - **b)** -15<sub>10</sub>
- **U6\_6.** Dados los siguientes números y sus representaciones, indicar el equivalente en decimal:

| <b>1.</b> 000011 <sub>2</sub> , (C2)  | <b>2.</b> 1001001, (SM) |
|---------------------------------------|-------------------------|
| <b>3.</b> 1100101 <sub>2</sub> , (C2) |                         |

**U6\_7.** Realizar las siguientes operaciones teniendo en cuenta que todos los números son enteros en la representación en complemento a 2 con 12 bits. Dar el resultado tanto en la representación en complemento a 2 con 12 bits como su equivalente en decimal.

| 1. 7D0 + 3E8        | <b>2.</b> A24 – 5DC |
|---------------------|---------------------|
| <b>3.</b> 496 + 0EB | <b>4.</b> 0AF – 7D0 |
| <b>5.</b> 3E8 + 418 | <b>6.</b> 4B0 – 258 |
| <b>7.</b> B3C + 216 | <b>8.</b> D44 + 2BC |

#### U6\_8. Codificar en BCD:

|   | 1. | 23510  | 2.  | 95610              |
|---|----|--------|-----|--------------------|
|   | 3. | 3510   | 4.  | 4578510            |
|   | 5. | 9810   | 6.  | 82610              |
|   | 7. | 17010  | 8.  | 1807 <sub>10</sub> |
| Ī | 9. | 246910 | 10. | 290510             |

**U6\_9.** Decodificar los siguientes números representados en BCD:

| <b>1.</b> 0001 0000 0000 0011 0100 | <b>2.</b> 0001 0011 0101 0111 |
|------------------------------------|-------------------------------|
| <b>3.</b> 1001 1100 0010           |                               |

U6\_10. Realizar las siguientes sumas en BCD:

| 1. | 10011000 + 00110101         | 2.  | 1001 + 1001                 |
|----|-----------------------------|-----|-----------------------------|
| 3. | 100110010011 + 010101101000 | 4.  | 00110111 + 01000110         |
| 5. | 00100011 + 00010101         | 6.  | 010101100001 + 011100001000 |
| 7. | 10000110 + 00010011         | 8.  | 01010001 + 01011000         |
| 9. | 01100111 + 01010011         | 10. | 10011000 + 10010111         |

**U6** 11. Decodificar el siguiente texto en ASCII:

59 6F 75 20 68 61 76 65 20 73 75 63 63 65 65 64 65 64 2E

- U6\_12. Codificar el siguiente texto en ASCII (la comilla simple no pertenece al mensaje): 'Feliz Año'
- **U6** 13. Completar los siguientes números añadiendo un bit de paridad siguiendo el criterio de paridad par:

| Paridad par               | Paridad impar            |
|---------------------------|--------------------------|
| a) 1001001 <sub>2</sub>   | a) 0110001 <sub>2</sub>  |
| b) 000010101 <sub>2</sub> | b) 0111110 <sub>2</sub>  |
| c) 10111101 <sub>2</sub>  | c) 10111000 <sub>2</sub> |

- **U6\_14.** Se pretende transmitir el texto "Hola" en código ASCII (básico con 7 bits) con VRC, LRC y paridad cruzada, utilizando paridad par. Construir los códigos hexadecimales (por columnas) que realmente se transmitirán (los datos se dispondrán en una matriz 7x4, añadiendo la fila de paridades como primera fila y la columna de paridades como última columna).
- **U6\_15.** Un circuito lógico tiene 5 entradas y una salida. Cuatro de las entradas A, B, C, y D representan un dígito decimal en BCD y la quinta entrada, E, es de control. Cuando el control está en '0' lógico, la salida vale '0' si el número decimal es par y vale '1' si es impar. Cuando el control está a '1' lógico, la salida vale '0' cuando el número es múltiplo de 3 y vale '1' en el resto de los casos. Se pide diseñar el circuito. NOTA: Se considera que el cero es un múltiplo de 3.
- **U6\_16.** Un circuito lógico acepta como entradas dos números enteros de 2 bits  $A=A_1A_0\,$  y  $B=B_1B_0\,$  y suministra una salida de 4 bits  $P=P_3P_2P_1P_0\,$  que es el producto numérico de A y B. Se pide diseñar y dibujar el circuito correspondiente.
- **U6\_17.** a) Mostrar en una tabla con 4 entradas (X<sub>1</sub>X<sub>0</sub> e Y<sub>1</sub>Y<sub>0</sub>) que representan a dos números binarios X e Y de 2 bits en complemento a dos, el resultado de la suma X+Y, también en complemento a 2. Utilice el menor número de bits de salida que necesite. b) Expresar en maxterms la función par el bit de signo del resultado. c) Expresar también esta misma función como producto de sumas en la forma más simplificada posible.
- **U6\_18.** Se pretende diseñar un circuito que multiplique dos números de 3 bits cada uno, codificados en complemento a 2.  $A(A_2A_1A_0)$  x  $B(B_2B_1B_0)$  =  $R(R_5R_4R_3R_2R_1R_0)$ Se pide:
- a) Obtener la expresión de la función R₅ como la mínima suma de productos. Dibujar el circuito resultante.
- b) Obtener la expresión de la función R<sub>0</sub> como el mínimo producto de sumas. Dibujar el circuito resultante.
- **U6\_19.** Diseñar un circuito combinacional cuya salida sea el valor de multiplicar por 4 un número en binario natural de 4 bits. Se quiere que la solución sea un diseño que utilice el menor número de puertas lógicas posibles y con el menor número de entradas.



**U6\_20.** Sabiendo que X e Y son números en complemento a 2, se quiere diseñar un circuito que acepte como entrada un número X de 4 bits:  $X(X_3X_2X_1X_0)$ , y cuya salida  $Y(Y_4Y_3Y_2Y_1Y_0)$  satisfaga la siguiente ecuación:

| Y = +15 | si | X > + 4       |
|---------|----|---------------|
| Y = 2⋅X | si | + 4 ≥ X ≥ - 4 |
| Y = -15 | si | X < - 4       |

Se pide:

- a) Realizar la tabla de verdad
- b) Obtener la expresión de la función Y2 como la mínima suma de productos. Dibujar el circuito resultante.
- c) Obtener la expresión de la función Y1 como el mínimo producto de sumas. Dibujar el circuito resultante.
- **U6\_21.** Se pretende diseñar un circuito cuyas dos entradas,  $A(A_1A_0)$  y  $B(B_1B_0)$ , sean dos números en complemento a 2, y cuya salida  $S(S_3S_2S_1S_0)$  sea la suma de A y B, también en complemento a 2. Esto es, S=A+B. Se pide:
  - a) Escribir la tabla de verdad.
  - b) Obtener la expresión de la función S2 como la mínima suma de productos.
  - c) Obtener la expresión de la función S<sub>0</sub> como el mínimo producto de sumas.
  - d) Obtener la expresión de la función S<sub>3</sub> como producto completo de Maxterms.
- **U6\_22.** Un circuito lógico tiene 5 entradas y una salida. Cuatro de las entradas A, B, C, y D representan un dígito decimal en BCD y la quinta entrada, E, es de control. Cuando el control está en '0' lógico, la salida vale '0' si el número decimal es par y vale '1' si es impar. Cuando el control está a '1' lógico, la salida vale '0' cuando el número es múltiplo de 3 y vale '1' en el resto de los casos. Se pide diseñar el circuito. NOTA: Se considera que el cero es un múltiplo de 3.
- **U6\_23.** Un circuito lógico acepta como entradas dos números enteros de 2 bits  $A = A_1A_0$  y  $B = B_1B_0$  y suministra una salida de 4 bits  $P = P_3P_2P_1P_0$  que es el producto numérico de A y B. Se pide diseñar y dibujar el circuito correspondiente.
- **U6\_24.** a) Mostrar en una tabla con 4 entradas ( $X_1X_0$  e  $Y_1Y_0$ ) que representan a dos números binarios X e Y de 2 bits en complemento a dos, el resultado de la suma X+Y, también en complemento a 2. Utilice el menor número de bits de salida que necesite. b) Expresar en maxterms la función par el bit de signo del resultado. c) Expresar también esta misma función como producto de sumas en la forma más simplificada posible.
- **U6\_25.** Dado el número real negativo escrito en decimal: A = 5142,25, se pide representar A en los siguientes formatos:
  - **a.1.** En un formato signo-magnitud en coma fija para 16 bits, con 2 bits para la parte fraccionaria.
  - a.2. En un formato signo-magnitud en coma fija para 32 bits, con 4 bits para la parte fraccionaria.
  - a.3. En un formato en complemento a dos para 16 bits, con 2 bits para la parte fraccionaria.
  - a.4. En un formato en complemento a dos para 32 bits, con 4 bits para la parte fraccionaria.
- **U6\_26.** Dado el número real negativo, escrito en decimal: A = -2.040,125, se pide representar A en los siguientes formatos:
- **a.1.** En complemento a dos para 16 bits, con 4 bits para la parte fraccionaria.
- **a.2.** En complemento a dos para 32 bits, con 8 bits para la parte fraccionaria. Es obligatorio dar el resultado en Hexadecimal.
- **U6\_27.** Se pretende diseñar un circuito cuyas dos entradas,  $A(A_1A_0)$  y  $B(B_1B_0)$ , sean dos números en complemento a 2, y cuya salida  $S(S_3S_2S_1S_0)$  sea la suma de A y B, también en complemento a 2. Esto es, S=A+B. Se pide:
- a) Completar la tabla de verdad adjunta
- b) Obtener la expresión de la función S2 como la mínima suma de productos.
- c) Obtener la expresión de la función S<sub>0</sub> como el mínimo producto de sumas.
- d) Obtener la expresión de la función S3 como producto completo de Maxterms
- **U6\_28.** Se pretende diseñar un circuito multiplicador de dos números de 3 bits X e Y, codificados en signomagnitud. Para simplificar su implementación, se ha utilizado una memoria de 64x8 (64 posiciones de 8 bits de datos cada una de ellas). Se pide:

- a. Indicar las conexiones de las variables de entrada (X2, X1, X0, Y2, Y1 e Y0) y las funciones de salida (S4, S3, S2, S1 y S0) con la memoria.
- b. Completar el contenido de las siguientes posiciones de memoria para que realice la función pedida: 0x00, 0x01, 0x02, 0x03, 0x15, 0x1A, 0x24, 0x25, 0x27, 0x29, 0x2C, 0x2D, 0x32, 0x38, 0x3B y 0x3F.



**U6\_29.** Se pide diseñar un circuito secuencial de MEALY que sirva como detector de paridad para un sistema que recibe en serie y síncronamente con la señal del reloj, paquetes de cuatro bits por una única línea de entrada. Al recibir el cuarto bit de cada bloque, la salida del circuito Z, tomará el valor 1 sólo si el número total de unos recibidos en el bloque es un número par y 0 en caso contrario. Tras la recepción del cuarto bit de cada bloque, el sistema debe estar listo para recibir y analizar sin ningún retardo los cuatro bits correspondientes del siguiente bloque. Realice el diagrama de estados mínimo, la tabla de transición y utilizando FF tipo-D, las ecuaciones de excitación (estado) y salida. Suponga que recibir 4 ceros es paridad par.

**U6\_30.** Un circuito secuencial tiene dos entradas ( $X_1$ ,  $X_0$ ) y dos salidas ( $Z_1$ ,  $Z_0$ ). Las entradas representan un número binario de dos bits,  $N = X_1X_0$ . Si el valor actual de N es mayor que el valor anterior, entonces  $Z_1 = 1$ . Si el valor actual de N es menor que el valor anterior, entonces  $Z_0 = 1$ . Si el valor actual de N es igual que el valor anterior, las dos salidas permanecen a 0. Cuando se recibe el primer par de entradas, tras una señal asíncrona de Reset, no hay ningún valor anterior de N, así que no es posible determinar si el valor de N actual es mayor o menor que el valor anterior, por lo que ambas salidas deben ser N0. Se pide diseñar una máquina de estado de Mealy para el circuito.

**U6\_31.** Se quiere diseñar un circuito secuencial que funcione como un sumador serie completo de n bits. Partiendo de una señal de Reset asíncrono que inicializa toda la lógica secuencial a "0", el circuito recibe en serie (síncronamente con el reloj) por sus dos entradas y empezando por los menos significativos los bits de los dos operandos Ai y Bi. El circuito debe suministrar por sus dos salidas tanto el bit de la suma Si como el de acarreo Ci+1. Se supone que la suma continúa indefinidamente hasta que se recibe un nuevo Reset por la entrada asíncrona, momento en el que la introducción de nuevos operandos se entiende como el comienzo de una nueva suma. Se pide:

- a) Diseñe el diagrama de estados del circuito en su versión Moore, utilizando los estados necesarios de los diagramas adjuntos, añadiendo más si fuera necesario o dejando en blanco los que no se necesiten.
- b) Utilizando flip-flops tipo T, indique el número de biestables necesarios. Realice la tabla de asignación de estados, la tabla de transición entre estados, la función para la excitación de los biestables y la tabla de salida. Utilice las plantillas facilitadas eliminando, si las hubiere, las filas o columnas innecesarias o añadiendo las que considere necesarias.
- c) Exprese en su forma más simplificada como suma de productos las ecuaciones de salida.

**U6\_32.** Diseñe un circuito secuencial de Mealy que calcule, dependiendo del valor de una entrada "S" el complemento a 1 (S = 0) o el complemento a 2 (S = 1) de un número de 3 bits que se va introduciendo en serie por una entrada "X" comenzando por el bit menos significativo. El bit más significativo del complemento correspondiente aparecerá en la salida al tercer ciclo de reloj. Una vez que se ha empezado a hacer un tipo de complemento (a 1 o a 2) no se cambiará el cálculo aunque varíe la entrada "S".

Realice únicamente el diagrama de estados utilizando los estados necesarios del diagrama adjunto, añadiendo más si fuera necesario o dejando en blanco los que no se necesiten.

**U6\_33.** Se pide el diseño de una máquina de estados finita, FSM de Moore, que detecte si un número entero desconocido es múltiplo de cuatro. Cuando lo detecte, la FSM debe poner la única salida Z = '1', en caso contrario Z = '0'. Después de una señal asíncrona de Reset, el número en binario de n bits, empezando por el bit de menos peso, llega al sistema secuencial bit a bit, con cada flanco ascendente del reloj. Una nueva señal de Reset señala el final de número actual y el comienzo del siguiente.

Nota: El número cero es múltiplo de cuatro.

| Ue | <b>J6_34.</b> Dado el número decimal $X = -9.547,25$ se pide su representación, en los siguientes formatos: |       |        |       |        |       |       |     |        |          |      |       |        |        |      |        |        |       |  |  |
|----|-------------------------------------------------------------------------------------------------------------|-------|--------|-------|--------|-------|-------|-----|--------|----------|------|-------|--------|--------|------|--------|--------|-------|--|--|
| a1 | <b>)</b> Códig                                                                                              | o bin | ario ( | con 2 | 0 bits | s, en | signo | mag | gnitud | d, utili | zand | o 4 b | its pa | ara la | part | e frac | cciona | aria. |  |  |
|    | X =                                                                                                         |       |        |       |        |       |       |     |        |          |      |       |        |        |      |        |        |       |  |  |
| a2 | (a2) Código binario con 20 bits, en complemento a dos, utilizando 4 bits para la parte fraccionaria.        |       |        |       |        |       |       |     |        |          |      |       |        |        |      |        |        |       |  |  |
|    | X =                                                                                                         |       |        |       |        |       |       |     |        |          |      |       |        |        |      |        |        |       |  |  |

a3) Código hexadecimal con 32 bits en complemento a dos, utilizando 8 bits para la parte fraccionaria.

| V            |  |
|--------------|--|
| X =          |  |
| <i>,</i> , – |  |
|              |  |
|              |  |

**b)** Se tienen dos números binarios ambos enteros y representados en hexadecimal, A = 0x830F codificado en complemento a dos y B = 0x7654 codificado en signo magnitud. Se pide el resultado de la operación de resta R = A - B, **en binario y en hexadecimal** con un formato de 24 bits en complemento a dos.

**Nota:** En todo el ejercicio <u>NO</u> se permite el uso de calculadora. Para calificar el apartado b), <u>debe hacer</u> necesariamente la operación en binario.