# 5. OTROS CIRCUITOS COMBINACIONALES



#### 5. OTROS CIRCUITOS COMBINACIONALES

#### **5.1** Circuitos y subsistemas combinacionales

- Concepto de circuito combinacional
- Multiplexor digital:

Concepto general.

Extensión de capacidad en multiplexores.

Aplicaciones de los multiplexores: conversión paralelo-serie y generación de funciones.

- Codificadores:

Codificadores sin prioridad.

Codificadores con prioridad.

- Decodificadores:

Decodificadores de salidas mutuamente excluyentes (no excitadores),

Decodificadores excitadores (Drivers).

Extensión de la capacidad de un decodificador.

Aplicaciones de decodificadores: Conversión serie-paralelo (demultiplexor) y generar funciones.

- Convertidores de código.
- Generador-comprobador de paridad:

Extensión de la capacidad de un generador-comprobador de paridad.

- Comparador binario:

Concepto general, Extensión de la capacidad de un comparador.

#### Concepto de circuito combinacional

Aquel en el que los estados lógicos de las variables de salida en cada instante dependen únicamente de los estados lógicos de las variables de entrada en el mismo instante



En el siguiente capítulo se abordarán circuitos más complejos, donde la salida también depende de datos que hay almacenados en memoria. Se trata del otro gran grupo: los circuitos secuenciales.

En este capítulo se verán circuitos combinacionales relacionados con transferencia de información y generación de códigos para presentar la información de salida de los sistemas digitales: multiplexores y demultiplexores, codificadores y decodificadores, conversores de código, generadores y detectores de bit de paridad, y comparadores

#### Multiplexor digital

En electrónica analógica el multiplexor analógico conecta una señal seleccionada de entre varias entradas a una sola salida:



En el multiplexor analógico existe contacto directo entre la línea de transmisión y la línea seleccionada El multiplexor digital funciona distinto. Una serie de entradas de control eligen una de las entradas de datos digitales, y el valor de la entrada seleccionada se transmite a la salida sin que haya contacto

entre la entrada y la salida:





La relación entre las entradas de control y las de datos en multiplexor debe cumplir:

- Si un multiplexor tiene N entradas de datos y n entradas de control, 2<sup>n</sup>≥N En el multiplexor comercial CD54ACT151 (http://bit.ly/108I5nq), hay 8 entradas de datos y 3 control Cumple la anterior relación ya que:  $2^3=8$ :

#### **TABLA DE VERDAD**

**FUNCTION TABLE** 

|   | II.    | IPUTS |        | OUTI | PUTS |
|---|--------|-------|--------|------|------|
|   | SELECT |       | STROBE | v    | w    |
| С | В      | Α     | G      | •    | **   |
| X | X      | X     | Н      | L    | н    |
| L | L      | L     | L      | D0   | D0   |
| L | L      | Н     | L      | D1   | D1   |
| L | Н      | L     | L      | D2   | D2   |
| L | Н      | Н     | L      | D3   | D3   |
| Н | L      | L     | L      | D4   | D4   |
| Н | L      | Н     | L      | D5   | D5   |
| Н | Н      | L     | L      | D6   | D6   |
| Н | Н      | Н     | L      | D7   | D7   |

D0, D1 . . . D7 = the level of the respective D input

#### **CIRCUITO DIGITAL**

logic diagram (positive logic)



#### • Extensión de la capacidad de los multiplexores

No existen multiplexores comerciales de más de 16 entradas de datos.

¿Cómo hacer entonces para diseñar un multiplexor de más entradas de control?



#### Aplicaciones de los multiplexores

#### a) Generación de funciones

La ecuación general de un multiplexor de dos entradas de control genera los productos canónicos de dichas entradas de control:

$$\mathsf{Z} = \overline{\mathsf{S}_1} \cdot \overline{\mathsf{S}_0} \cdot \mathsf{I}_0 + \overline{\mathsf{S}_1} \cdot \mathsf{S}_0 \cdot \mathsf{I}_1 + \mathsf{S}_1 \cdot \overline{\mathsf{S}_0} \cdot \mathsf{I}_2 + \mathsf{S}_1 \cdot \mathsf{S}_0 \cdot \mathsf{I}_3$$

Por tanto, si los I<sub>0</sub>, I<sub>1</sub>, I<sub>2</sub> e I<sub>3</sub> corresponden con otra variable, con un multiplexor se puede obtener una función de n entradas de control más una variable. Es decir, de n+1 variables siendo n el número de entradas de control.

**Ejemplo:** obtener la siguiente función de 4 variables con un multiplexor (tendrá 3 de control):

$$F = \overline{B} \cdot C \cdot D + A \cdot \overline{B} \cdot D + \overline{A} \cdot \overline{B} \cdot C$$

El primer paso es poner la función en forma canónica (suma de minterms):

$$F = (A + \overline{A}) \cdot \overline{B} \cdot C \cdot D + A \cdot \overline{B} \cdot (C + \overline{C}) \cdot D + \overline{A} \cdot \overline{B} \cdot C \cdot (D + \overline{D}) = A \cdot \overline{B} \cdot C \cdot D + \overline{A} \cdot \overline{B} \cdot C \cdot D$$

A continuación se eligen tres variables de control (en nuestro caso elegiremos A, B y C).

Después ordenamos los términos de la ecuación para que se corresponda con la ecuación de un Multiplexor (los términos que no existen se multiplican por 0):



#### a) Generación de funciones

Aunque con multiplexores habitualmente sólo se pueden representar funciones de n+1 variables (siendo n el número de entradas de control), hay casos como el siguiente en que se puede aumentar el número de variables a representar:

$$Y = \overline{A} \cdot \overline{B} \cdot C \cdot D + \overline{A} \cdot B \cdot C \cdot E + A \cdot \overline{B} \cdot \overline{C} \cdot F + A \cdot B \cdot C \cdot G$$

Lo ponemos en forma de ecuación de multiplexor eligiendo A,B y C como variables de control:

$$Y = \overline{A} \cdot \overline{B} \cdot \overline{C} \cdot 0 + \overline{A} \cdot \overline{B} \cdot C \cdot D + \overline{A} \cdot B \cdot \overline{C} \cdot 0 + \overline{A} \cdot B \cdot C \cdot E + A \cdot \overline{B} \cdot \overline{C} \cdot F + A \cdot \overline{B} \cdot C \cdot 0 + A \cdot B \cdot \overline{C} \cdot 0 + A \cdot B \cdot \overline{C} \cdot O + A \cdot B \cdot \overline{C$$



#### b) Conversión paralelo-serie.



#### Codificador

Obtiene un código de salida que se ajusta a los valores introducidos a la entrada



Existen dos versiones:

#### a) Codificador sin prioridad

Sólo se activa una entrada

La salida es la codificación de la entrada activa

Ejemplo: Codificador Decimal a BCD



$$D=E_8+E_9$$
  $A=E_1+E_3+E_5+E_7+E_9$   $C=E_4+E_5+E_6+E_7$   $B=E_2+E_3+E_6+E_7$   $E_0$   $E_1$   $E_2$   $E_3$   $E_4$   $E_5$   $E_6$   $E_7$   $E_8$   $E_9$   $D$ 

#### b) Codificador con prioridad

Se puede activar más de una entrada a la vez

Si se activan varias entradas a la vez, la salida codificada corresponde a la entrada de mayor prioridad (en los codificadores sin prioridad se produce un error si se activa más de una entrada)

Ejemplo 1: Codificador 4 a 2 con prioridad  $E_3 > E_2 > E_1 > E_0$ 



Ejemplo 2: 10 a 4 con prioridad  $I_9 > I_8 > I_7 > I_6 > I_5 > I_4 > I_3 > I_2 > I_1$  (las entradas y las salidas son activas a nivel bajo = L) <a href="http://bit.ly/1pvyvLa">http://bit.ly/1pvyvLa</a>



|           |           |               |               | INPUTS |    |               |    |               |           | OUT       | PUTS      |           |
|-----------|-----------|---------------|---------------|--------|----|---------------|----|---------------|-----------|-----------|-----------|-----------|
| <u>11</u> | <u>12</u> | <del>13</del> | <del>14</del> | 15     | 16 | <del>17</del> | Ī8 | <del>19</del> | <u>Y3</u> | <u>Y2</u> | <u>Y1</u> | <u>Y0</u> |
| Н         | Н         | Н             | Н             | Н      | Н  | Н             | Н  | Н             | Н         | Н         | Н         | Н         |
| Х         | X         | X             | X             | X      | X  | X             | X  | L             | L         | Н         | Н         | L         |
| Х         | X         | X             | X             | X      | Х  | X             | L  | Н             | L         | Н         | Н         | Н         |
| Х         | X         | X             | Х             | Х      | X  | L             | Н  | Н             | Н         | L         | L         | L         |
| Х         | X         | X             | X             | X      | L  | Н             | Н  | Н             | Н         | L         | L         | Н         |
| X         | X         | X             | Х             | L      | Н  | Н             | Н  | Н             | Н         | L         | Н         | L         |
| X         | X         | X             | L             | Н      | Н  | Н             | Н  | Н             | Н         | L         | Н         | Н         |
| X         | X         | L             | Н             | Н      | Н  | Н             | Н  | Н             | Н         | Н         | L         | L         |
| X         | L         | Н             | Н             | Н      | Н  | Н             | Н  | Н             | Н         | Н         | L         | Н         |
| L         | Н         | Н             | Н             | Н      | Н  | Н             | Н  | Н             | Н         | Н         | Н         | L         |

H = High Logic Level, L = Low Logic Level, X = Don't Care

#### Decodificadores

Se traduce un código recibido por las entradas en valores de salida que representan de una forma sencilla dicho código

Existen de dos tipos:

#### a) Decodificadores con salidas mutuamente excluyentes (no excitadores):

Ante un código de entrada se activa una salida (es la función opuesta al codificador sin prioridad, donde ante una entrada activada se obtenía un código a la salida)

Ejemplo 1: decodificador de 2 entradas (2 a 4)



| Entra | idas                 |                                         | Salidas                                                                                              |                                                       |                                                        |  |  |  |  |  |
|-------|----------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------|--|--|--|--|--|
| $E_1$ | $E_0$                | <b>S</b> <sub>3</sub>                   | $S_2$                                                                                                | $S_1$                                                 | $S_0$                                                  |  |  |  |  |  |
| 0     | 0                    | 0                                       | 0                                                                                                    | 0                                                     | 1                                                      |  |  |  |  |  |
| 0     | 1                    | 0                                       | 0                                                                                                    | 1                                                     | 0                                                      |  |  |  |  |  |
| 1     | 0                    | 0                                       | 1                                                                                                    | 0                                                     | 0                                                      |  |  |  |  |  |
| 1     | 1                    | 1                                       | 0                                                                                                    | 0                                                     | 0                                                      |  |  |  |  |  |
|       | E <sub>1</sub> 0 0 1 | 0 0 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | $\begin{array}{c cccc} E_1 & E_0 & S_3 \\ \hline 0 & 0 & 0 \\ 0 & 1 & 0 \\ 1 & 0 & 0 \\ \end{array}$ | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ |  |  |  |  |  |

$$S_3 = E_1 \cdot E_0$$
  $S_1 = \overline{E}_1 \cdot E_0$   
 $S_2 = E_1 \cdot \overline{E}_0$   $S_0 = \overline{E}_1 \cdot \overline{E}_0$ 



Ejemplo 2: codificador BCD a decimal (circuito sn74ls42 http://bit.ly/1ohdG23)



#### **FUNCTION TABLE**

|         |   | BCD I | NPUT |   |   | DECIMAL OUTPUT |   |   |   |   |   |   |   |   |
|---------|---|-------|------|---|---|----------------|---|---|---|---|---|---|---|---|
| NO.     | D | С     | В    | Α | 0 | 1              | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| 0       | L | L     | L    | L | L | Н              | Н | Н | Н | Н | Н | Н | Н | Н |
| 1       | L | L     | L    | н | Н | L              | н | H | н | н | Н | Н | Н | Н |
| 2       | L | L     | н    | L | н | Н              | L | Н | н | н | н | н | н | н |
| 3       | L | L     | н    | н | н | н              | н | L | н | H | Н | Н | н | Н |
| 4       | L | Н     | L    | L | н | н              | Н | Н | L | н | н | Н | н | Н |
| 5       | L | Н     | L    | Н | Н | Н              | Н | Н | н | L | н | Н | н | Н |
| 6       | L | н     | н    | L | н | Н              | H | Н | н | н | L | н | н | Н |
| 7       | L | Н     | н    | Н | н | H              | н | н | н | н | н | L | Н | Н |
| 8       | н | L     | L    | L | н | н              | Н | н | н | н | н | н | L | Н |
| 9       | н | L     | L    | н | н | Н              | н | Н | Н | н | н | Н | Н | L |
|         | Н | L     | Н    | L | Н | Н              | н | Н | Н | н | н | Н | Н | Н |
| _       | н | L     | н    | н | н | H              | H | н | н | н | н | Н | н | Н |
| Ħ       | н | н     | L    | L | н | н              | Н | н | н | н | Н | н | Н | Н |
| INVALID | н | н     | L    | н | н | Н              | н | н | н | н | н | н | н | Н |
| =       | н | Н     | н    | L | н | н              | н | н | н | н | н | н | н | Н |
|         | н | н     | н    | н | н | Н              | н | Н | Н | Н | Н | Н | Н | Н |



H = high level, L = low level

#### Ejemplo 3: extensión de decodificadores

Análogamente que con los multiplexores, si queremos hacer un decodificador de más de 32 salidas se combinan circuitos decodificadores más sencillos como el CD54ACT138 (<a href="http://bit.ly/1u7uAW9">http://bit.ly/1u7uAW9</a>):



#### b) Decodificadores excitadores (Drivers)

El código de entrada se traduce en la activación de una serie de salidas que excitarán un dispositivo visual como puede ser un display de 7 segmentos o una pantalla LCD. Para excitar el dispositivo visual se permite, a diferencia del excitador con salidas mutuamente excluyentes, activar más de una salida

**Ejemplo:** Decodificador excitador para display 7 segmentos

Un display de 7 segmentos es un dispositivo electrónico con 9 pines: los 7 segmentos, el punto y la





Esta configuración se llama cátodo común y el cátodo se conecta a tierra.

Si las entradas a,b,c,d,e,f,g ó h tienen tensión alta el LED se enciende, y si tienen tensión baja el LED está apagado

Esta configuración se llama ánodo común y el ánodo se conecta a tensión de alimentación del circuito (Vcc). Si las entradas a,b,c,d,e,f,g ó h tienen tensión baja el LED se enciende, y si tienen tensión alta el LED está apagado

El decodificador excitador se conecta al display de la siguiente manera (suponiendo configuración cátodo común)



#### b) Decodificadores excitadores (Drivers)

Un ejemplo de circuito excitador comercial para displays 7 segmentos es el SN7446A (<a href="http://bit.ly/1zEive8">http://bit.ly/1zEive8</a>). No utiliza el punto (segmento h):



'LS49 FUNCTION TABLE (T3)

| DECIMAL  |   | II | IPUT | s |    |    |    | ΟL | JTPU | тѕ |     |     | NOTE |
|----------|---|----|------|---|----|----|----|----|------|----|-----|-----|------|
| FUNCTION | D | С  | В    | Α | BI | а  | b  | С  | d    | е  | f   | g   |      |
| 0        | L | L  | L    | L | Н  | H  | Н  | Н  | Н    | Н  | Н   | L   |      |
| 1 1      | L | L  | L    | н | н  | L  | Н  | н  | L    | L  | L   | L   |      |
| 2        | L | L  | Н    | L | н  | н  | Н  | L  | Н    | Н  | L   | н   |      |
| 3        | L | L  | Н    | н | н  | Н  | Н  | Н  | H_   | L  | _L_ | Н   |      |
| 4        | L | Н  | L    | L | Н  | L  | Н  | Н  | L    | L  | Н   | н   | 1    |
| 5        | L | н  | Ł    | н | Н  | н  | L  | Н  | н    | L  | Н   | н   |      |
| 6        | L | н  | н    | L | н  | L  | L  | Н  | Н    | Н  | Н   | Н   |      |
| 7        | L | Н  | H    | н | Н  | н  | H  | Н  | L    | L  | L   | L   | 1 1  |
| 8        | Н | L  | L    | L | Н  | Н  | Н  | Н  | Н    | Н  | Н   | Н   | ' '  |
| 9        | Н | L  | L    | Н | Н  | н  | Н  | н  | L    | L  | Н   | Н   |      |
| 10       | Н | L  | Н    | L | Н  | L  | L. | L  | Н    | н  | L   | Н   |      |
| 11       | Н | L  | Н    | н | Н  | L  | L  | н  | н    | L  | L   | _н_ |      |
| 12       | H | Н  | L    | L | Н  | L  | Н  | L  | L    | L  | Н   | Н   |      |
| 13       | н | н  | L    | Н | н  | н  | L  | L  | Н    | L  | Н   | Н   |      |
| 14       | н | Н  | Н    | L | Н  | L  | L  | L  | Н    | н  | Н   | Н   |      |
| 15       | Н | н  | Н    | Н | Н  | L_ | L  | L  | L    | L  | L   | L   |      |
| ВІ       | X | Х  | X    | Х | L  | L  | L  | L  | L    | L  | L   | L   | 2    |

H = high level, L = low level, X = irrelevant

- NOTES: 1. The blanking input (BI) must be open or held at a high logic level when output functions 0 through 15 are desired.
  - 2. When a low logic level is applied directly to the blanking input (BI), all segment outputs are low regardless of the level of any other input.

#### • Aplicaciones de los decodificadores

#### a) Generación de funciones

Con un decodificador de 3 entradas y 8 salidas, si se unen las salidas a una puerta OR se obtiene:



Regla general: si la función tiene n variables se necesita un decodificador de n entradas de control para obtener dicha función conectando a la puerta OR las salidas necesarias para obtener dicha función.

Ejemplo:  $F=X\cdot Y\cdot Z+X\cdot Y\cdot \overline{Z}+X\cdot \overline{Y}\cdot Z+\overline{X}\cdot \overline{Y}\cdot Z$ asignando X=A, Y=B, Y=C $X\cdot Y\cdot Z=A\cdot B\cdot C=7$  $X\cdot Y\cdot \overline{Z}=A\cdot B\cdot \overline{C}=6$  $X\cdot \overline{Y}\cdot Z=A\cdot \overline{B}\cdot C=5$  $\overline{X}\cdot \overline{Y}\cdot Z=\overline{A}\cdot \overline{B}\cdot C=1$ 



#### a) Generación de funciones

En cambio si el multiplexor tiene las salidas activa a nivel bajo, éstas se conectan a una puerta NAND El ejemplo de la página anterior es, con salidas del decodificador activas a nivel bajo:



b) Conversión serie-paralelo: se usan demultiplexores (decodificadores con entrada de habilitación)



#### c) Combinación de un decodificador con un multiplexor

Uniendo las salidas de un decodificador a las entradas de un multiplexor se consigue obtener a la salida del multiplexor una función de número de variables igual al número de entradas de control del multiplexor más el número de entradas del decodificador

**Ejemplo:** obtener la siguiente función mediante un decodificador de 3 entradas y un multiplexor de 3 entradas de control:

$$F=S \cdot U \cdot V \cdot \overline{X} \cdot Y \cdot Z + S \cdot \overline{U} \cdot V \cdot X \cdot Y + \overline{S} \cdot \overline{U} \cdot V \cdot \overline{X} \cdot Y \cdot \overline{Z}$$

Se pone la función en forma canónica

$$F=S \cdot U \cdot V \cdot \overline{X} \cdot Y \cdot Z + S \cdot \overline{U} \cdot V \cdot X \cdot Y \cdot (Z + \overline{Z}) + \overline{S} \cdot \overline{U} \cdot V \cdot \overline{X} \cdot Y \cdot \overline{Z}$$

$$F = \underbrace{S \cdot U \cdot V \cdot \overline{X} \cdot Y \cdot Z}_{S_7} + \underbrace{S \cdot \overline{U} \cdot V \cdot X \cdot Y \cdot Z}_{I_7} + \underbrace{S \cdot \overline{U} \cdot V \cdot \overline{X} \cdot Y \cdot \overline{Z}}_{I_6} + \underbrace{S \cdot \overline{U} \cdot V \cdot \overline{X} \cdot Y \cdot \overline{Z}}_{I_6}$$



#### Conversores de código

En el capítulo de circuitos aritméticos se diseñaron conversores de código basados en sumadores.

También existen circuitos comerciales que realizan conversión de código

a) Conversor BCD a binario: <a href="http://bit.ly/1zluTdj">http://bit.ly/1zluTdj</a>

# 6-BIT CONVERTER MSD LSD B A D C B A SN54184 OR SN74184 Y5 Y4 Y3 Y2 Y1 25 24 23 22 21 20 6-BIT BINARY OUTPUT

#### FUNCTION TABLE BCD-TO-BINARY CONVERTER

| 200           | • |    | INP   | UTS   |    |    | OUTPUTS    |      |           |      |    |  |
|---------------|---|----|-------|-------|----|----|------------|------|-----------|------|----|--|
| BCD           |   | (8 | iee N | ote / | 4) |    |            | (Sec | Not       | e B) |    |  |
| WORDS         | E | D  | С     | В     | A  | G  | <b>Y</b> 5 | Y4   | <b>Y3</b> | Y2   | Y1 |  |
| Q·1           | L | L  | L     | L     | L  | L  | L          | L    | L         | L    | L  |  |
| 2.3           | L | L  | L     | L     | н  | L  | Ł          | L    | L         | L    | Н  |  |
| 4-5           | L | L  | L     | н     | Ł  | L  | L          | L    | L         | н    | L  |  |
| 6-7           | L | L  | L     | н     | н  | L  | L          | L    | L         | н    | Н  |  |
| 8.9           | L | L  | H     | L     | L  | L  | L          | L    | Н         | L    | Ł  |  |
| 10-11         | L | н  | L     | L     | L  | L  | Ł          | L    | Н         | L    | Н  |  |
| 12-13         | L | н  | L     | L     | н  | L  | Ł          | L    | Н         | н    | L  |  |
| 14-15         | L | н  | L     | н     | L  | L  | L          | L    | н         | н    | н  |  |
| 16-17         | L | н  | L     | н     | н  | L  | L          | н    | L         | L    | L  |  |
| 18-19         | L | н  | н     | L     | Ļ  | L  | L          | н    | L         | L    | н  |  |
| 20-21         | Н | L  | L     | L     | L  | L  | L          | Н    | L         | Н    | L  |  |
| 22-23         | н | L  | L     | L     | Н  | L  | L          | н    | L         | н    | н  |  |
| 24-25         | н | L  | L     | н     | L  | L  | L          | н    | н         | L    | L  |  |
| 26-27         | н | L  | L     | н     | н  | L  | ι          | н    | Н         | L    | Н  |  |
| 28-29         | н | L  | н     | L     | L  | L  | L          | Н    | н         | Н    | L  |  |
| 30-31         | н | н  | L     | L     | Ĺ  | L  | L          | Н    | н         | Н    | н  |  |
| 32-33         | н | н  | L     | L     | н  | L  | н          | L    | L         | L    | L  |  |
| 34-35         | н | н  | L     | ч     | L  | L  | н          | L    | L         | L    | н  |  |
| <b>36</b> -37 | н | н  | L     | Н     | н  | L  | н          | L    | L         | н    | L  |  |
| 38-39         | н | н  | н     | L     | Ĺ  | L. | н          | L    | L         | н    | н  |  |
| ANY           | х | Х  | Х     | ×     | Х  | Н  | Н          | н    | н         | Н    | Н  |  |

H = high level, L = low level, X = irrelevant

NOTES: A. Input conditions other than those shown produce highs at outputs Y1 through Y5.

 Outputs Y6, Y7, and Y8 are not used for BCD-tobinary conversion.

# Conversores de código

b) Conversor binario a BCD: <a href="http://bit.ly/1zluTdi">http://bit.ly/1zluTdi</a>





| DIN CO.         |     |     | ı    | NPU | TS |        | OUTPUTS |            |          |            |    |           |    |           |
|-----------------|-----|-----|------|-----|----|--------|---------|------------|----------|------------|----|-----------|----|-----------|
| BINARY          | BII | NAR | Y \$ | ELE | CT | ENABLE |         |            |          |            |    |           |    |           |
| WORDS           | E   | D   | C    | В   | Α  | G      | Y8      | <b>¥</b> 7 | Y6       | <b>Y</b> 5 | ¥4 | <b>Y3</b> | ¥2 | <b>Y1</b> |
| 0 · 1           | L   | L   | L    | L   | Ł  | L      | н       | н          | L        | L          | L  | L         | L  | L         |
| 2 · 3           | L   | L   | L    | L   | н  | L      | н       | н          | Ł        | L          | L  | L         | L  | н         |
| 4 - 5           | Ł   | L   | L    | н   | L  | L      | н       | н          | Ł        | L          | L  | L         | н  | L         |
| 6 - 7           | L   | L   | L    | н   | н  | L      | н       | Н.         | <u>L</u> | L          | L  | ᆫ         | н  | н         |
| 8 - 9           | L   | L   | н    | L   | L  | L      | н       | н          | L        | L          | L  | н         | L. | ι         |
| 10 - 11         | Ł   | L   | н    | L   | н  | L      | н       | н          | L        | L          | Н  | L         | L  | Ł         |
| 12 - 13         | L.  | L   | Н    | н   | L  | L :    | н       | Н          | Ł        | L          | н  | L         | L  | н         |
| 14 - 15         | Ł   | L   | н    | н   | н  | L      | н       | н          | Ł        | Ł          | Н  | L         | н  | L         |
| 16 - 17         | L   | н   | L    | L   | Ļ. | L      | н       | н          | Ł        | L          | Н  | L         | Н  | н         |
| 18 19           | L   | н   | ι    | L   | н  | L L    | н       | н          | L.       | L          | H  | н         | L  | L         |
| 20 - 21         | L   | н   | L    | н   | L  | lι     | н       | н          | L        | н          | L  | L         | L  | L.        |
| 22 - 23         | L   | н   | L    | н   | Н  | L_     | н       | н          | L        | н          | L  | L         | L  | н         |
| 24 - 25         | L   | Н   | Ĥ    | L   | L  | L      | н       | н          | L        | н          | L  | L         | Н  | Ļ         |
| 26 · 27         | L   | н   | н    | L   | н  | Ł      | н       | н          | L        | н          | L  | L         | н  | H         |
| 28 - 29         | L   | н   | н    | н   | L  | ι      | н       | н          | L        | н          | L  | н         | L  | L         |
| 30 - 31         | L   | н   | н    | Н   | Н  | L      | н       | н          | L        | н          | н  | L         | L  | L         |
| 32 - 33         | н   | L   | L    | L   | L  | ι      | Н       | н          | L        | н          | Н  | L         | L  | н         |
| 34 - 35         | н   | L   | L    | L   | н  | L L    | н       | н          | Ł        | н          | Н  | L         | н  | L         |
| 36 - 37         | н   | L   | ι    | н   | Ł  | L L    | н       | н          | L        | н          | н  | L         | н  | н         |
| 38 - 39         | н   | L   | L    | н   | н  | l L    | н       | н          | L        | н          | н  | н         | L  | L         |
| 40 - 41         | Н   | L   | Н    | L   | L  | L      | н       | н          | н        | ι          | L  | L.        | L  | L         |
| 42 - 43         | н   | L   | н    | L   | н  | L      | н       | н          | н        | L          | L  | L         | L  | н         |
| 44 45           | н   | L   | н    | н   | L  | L      | н       | н          | н        | L          | L  | L         | н  | L         |
| 46 - 47         | н   | L   | н    | н   | н  | L      | н       | н          | н        | L          | L  | L         | н  | н         |
| 48 49           | н   | н   | L    | L   | L  | L      | н       | н          | н        | L          | L  | н         | L  | L         |
| 50 - 51         | н   | н   | L    | Ł   | н  | L      | н       | н          | н        | L          | н  | L         | L  | L         |
| 52 - 53         | н   | н   | L    | н   | L  | L      | н       | н          | н        | Ł          | н  | L         | Ł. | н         |
| <b>54 · 5</b> 5 | н   | н   | L    | н   | н  | L      | н       | н          | н        | L          | н  | Ł         | н  | L         |
| 56 - 57         | н   | н   | н    | L   | L  | L      | н       | н          | н        | L          | н  | L         | н  | н         |
| 58 - 59         | н   | н   | н    | L   | н  | L      | н       | н          | н        | L          | н  | н         | L  | L         |
| 60 - 61         | н   | н   | н    | н   | L  | L      | н       | н          | н        | Н          | Ł  | L         | L  | Ł         |
| 62 - 63         | н   | н   | н    | н   | н  | L      | н       | н          | н        | н          | L  | L         | L  | н         |
| ALL             | х   | ×   | ×    | х   | X  | н      | н       | н          | н        | Н          | н  | н         | н  | н         |

H = high level, L = low level, X = irrelevant

#### Generador- comprobador de bit de paridad

Si se tiene un código binario de 4 bit y se desea añadirle un bit de paridad par (se obtiene un 0 cuando el número de 1s es par y un 1 cuando es impar) basta con aplicar la función XOR:



Por otro lado, para detectar un error de bit de paridad en un código de 4 bits + 1 bit de paridad que se recibe, basta con aplicar la función XOR al código recibido sin el bit de paridad y comparar el resultado obtenido con el bit de paridad recibido en el receptor:



Nota: se recomienda revisar la parte final del capítulo 2 sobre detección y corrección de errores

Circuito comercial CY74FCT480T generador y detector de paridad (<a href="http://bit.ly/1upAj9X">http://bit.ly/1upAj9X</a>)

Se emplea para números de 8 bit y la salida ERROR indica cuándo el bit de paridad es incorrecto para los dos códigos introducidos. Esto sirve para avisar de errores en el cálculo del bit de paridad en el transmisor y en el receptor

**FUNCTION TABLE** 

|                                                        | INPUT                                                         | 'S      |                  |                  |                  | OUTPUT           | s     |
|--------------------------------------------------------|---------------------------------------------------------------|---------|------------------|------------------|------------------|------------------|-------|
| A <sub>1</sub> -H <sub>1</sub>                         | A <sub>2</sub> -H <sub>2</sub>                                | CHK/GEN | PAR <sub>1</sub> | PAR <sub>2</sub> | ODD <sub>1</sub> | ODD <sub>2</sub> | ERROR |
|                                                        |                                                               | Н       | Н                | Н                | L                | L                | Η     |
|                                                        | Number of                                                     | Н       | L                | Н                | Н                | L                | L     |
|                                                        | A <sub>2</sub> -H <sub>2</sub> inputs,                        | Н       | Н                | L                | L                | Н                | L     |
|                                                        | high is even                                                  | Н       | L                | L                | Н                | Н                | L     |
| Number of                                              |                                                               | L       | X                | X                | Н                | Н                | L     |
| A <sub>1</sub> -H <sub>1</sub> inputs,<br>high is even |                                                               | Н       | Н                | Н                | L                | Н                | L     |
|                                                        | Number of inputs A <sub>2</sub> –H <sub>2</sub> , high is odd | Н       | L                | Н                | Н                | Н                | L     |
|                                                        |                                                               | Н       | Н                | L                | L                | L                | Н     |
|                                                        |                                                               | Н       | L                | L                | Н                | L                | L     |
|                                                        |                                                               | L       | X                | X                | Н                | L                | L     |
|                                                        |                                                               | Н       | Н                | Н                | Н                | L                | L     |
|                                                        | Number of                                                     | Н       | L                | Н                | L                | L                | Н     |
|                                                        | A <sub>2</sub> -H <sub>2</sub> inputs,                        | Н       | Н                | L                | Н                | Н                | L     |
|                                                        | high is even                                                  | Н       | L                | L                | L                | Н                | L     |
| Number of<br>A <sub>1</sub> -H <sub>1</sub> inputs,    |                                                               | L       | X                | X                | L                | Н                | L     |
| high is odd                                            |                                                               | Н       | Н                | Н                | Н                | Н                | ٦     |
|                                                        | Number of                                                     | Н       | L                | Н                | L                | Н                | L     |
|                                                        | A <sub>2</sub> -H <sub>2</sub> inputs,                        | Н       | Н                | L                | Н                | L                | L     |
|                                                        | high is odd                                                   | Н       | L                | L                | L                | L                | Н     |
|                                                        |                                                               | L       | X                | X                | L                | L                | Н     |



H = High logic level, L = Low logic level, X = Don't care

#### • Comparador binario

a) Concepto general: el comparador binario tiene por objeto determinar si un número es mayor, menor o igual que otro, y se utiliza en la toma de decisiones

#### Comparador binario de 1 bit con 1 bit:



| A | В | G | Е | L | $G = A \cdot \overline{B}$                                                | Λ .                   |
|---|---|---|---|---|---------------------------------------------------------------------------|-----------------------|
| 0 | 0 | 0 | 1 | 0 | G = A·B                                                                   | $A \longrightarrow G$ |
| 0 | 1 | 0 | 0 | 1 | $E = \overline{A} \cdot \overline{B} + A \cdot B = \overline{A \oplus B}$ |                       |
| 1 | 0 | 1 | 0 | 0 | $L = \overline{A} \cdot B$                                                |                       |
| 1 | 1 | 0 | 1 | 0 |                                                                           | В —                   |

Para números de más bits se van comparando sucesivamente (de más significativo a menos significativo) los dígitos de igual peso de ambos números, hasta encontrar un que es mayor que otro.





$$G = G_4 + E_4 \cdot G_3 + E_4 \cdot E_3 \cdot G_2 + E_4 \cdot E_3 \cdot E_2 \cdot G_1$$

$$E = E_4 \cdot E_3 \cdot E_2 \cdot E_1$$

$$L = L_4 + E_4 \cdot L_3 + E_4 \cdot E_3 \cdot L_2 + E_4 \cdot E_3 \cdot E_2 \cdot L_1$$

G(A>B) si: 
$$A_4 > B_4$$
 ó  $A_4 = B_4$  y  $A_3 > B_3$  ó  $A_4 = B_4$  y  $A_3 = B_3$  y  $A_2 > B_2$  ó  $A_4 = B_4$  y  $A_3 = B_3$  y  $A_2 = B_2$  y  $A_1 > B_1$   $A_4 = B_4$  y  $A_3 = B_3$  y  $A_2 = B_2$  y  $A_1 > B_1$   $A_4 = B_4$  y  $A_3 = B_3$  y  $A_2 = B_2$  y  $A_1 < B_1$ 





#### • Extensión de comparadores con entradas de expansión

Sólo existen comparadores de números de 4 bits. Utilizando tres entradas de expansión  $G_c$ ,  $E_c$  y  $L_c$  (análogas a la entrada de acarreo en circuitos sumadores), se pueden conectar comparadores entre sí para poder comparar números de más de 4 bit:



Ejemplo: comparador de 8 bits a partir de dos de 4 bit:



#### • Extensión de comparadores sin entradas de expansión

#### a) Método ascendente

Se parece al método que utiliza las entradas de expansión. Las salidas del comparador para los 4 bit menos significativos se llevan a los dos bit menos significativos del comparador de los cuatro bit más significativos. De esta manera, sólo se miran las entradas de los bit menos significativos si las de los bit más significativos son iguales



#### b) Método descendente

Las salidas del comparador para los 4 bit más significativos se llevan a los dos bit más significativos del comparador de los cuatro bit menos significativos. Es similar al cálculo mental de comparación de números decimales: primero comparamos el dígito más significativo, y si son iguales se compara el siguiente dígito



Tamaño máximo de los números binarios con N comparadores:

sin entradas de expansión: n = 3N+1 bits con entradas de expansión: n = 4N bits

# Circuito comparador comercial CD74HC85 (<a href="http://bit.ly/1sfisEK">http://bit.ly/1sfisEK</a>)

Pines del chip y tabla de verdad para:

- Un solo dispositivo (comparador de 4 bit con 4 bit)
- Varios dispositivos (conexión mediante entradas de expansión para comparar 8 bit con 8 bit, etc.)
- Varios dispositivos (conexión mediante entradas de expansión en paralelo)

#### TRUTH TABLE



|              | COMPARI       | NG INPUTS | _       | CAS   | CADING IN | PUTS  |       | OUTPUTS |       |
|--------------|---------------|-----------|---------|-------|-----------|-------|-------|---------|-------|
| A3, B3       | A2, B2        | A1, B1    | A0, B0  | A > B | A < B     | A = B | A > B | A < B   | A = B |
| SINGLE DEVIC | E OR SERIES C | ASCADING  | _       | _     | _         | _     |       |         |       |
| A3 > B3      | Х             | Х         | Х       | Х     | Х         | X     | Н     | L       | L     |
| A3 < B3      | Х             | Х         | Х       | X     | Х         | Х     | L     | Н       | L     |
| A3 = B3      | A2 >B2        | Х         | Х       | X     | Х         | Х     | Н     | L       | L     |
| A3 = B3      | A2 < B2       | X         | Х       | X     | Х         | Х     | L     | Н       | L     |
| A3 = B3      | A2 = B2       | A1 > B1   | Х       | X     | Х         | X     | Н     | L       | L     |
| A3 = B3      | A2 = B2       | A1 < B1   | Х       | X     | X         | Х     | L     | Н       | L     |
| A3 = B3      | A2 = B2       | A1 = B1   | A0 > B0 | X     | X         | Х     | Н     | L       | L     |
| A3 = B3      | A2 = B2       | A1 = B1   | A0 < B0 | X     | Х         | Х     | L     | Н       | L     |
| A3 = B3      | A2 = B2       | A1 = B1   | A0 = B0 | Н     | L         | L     | Н     | L       | L     |
| A3 = B3      | A2 = B2       | A1 = B1   | A0 = B0 | L     | Н         | L     | L     | Н       | L     |
| A3 = B3      | A2 = B2       | A1 = B1   | A0 = B0 | L     | L         | Н     | L     | L       | Н     |
| PARALLEL CA  | SCADING       |           |         |       |           | _     |       |         |       |
| A3 = B3      | A2 = B2       | A1 = B1   | A0 = B0 | X     | Х         | Н     | L     | L       | Н     |
| A3 = B3      | A2 = B2       | A1 = B1   | A0 = B0 | Н     | Н         | L     | L     | L       | L     |
| A3 = B3      | A2 = B2S      | A1 = B1   | A0 = B0 | L     | L         | L     | Н     | Н       | L     |

H = High Voltage Level, L = Low Voltage, Level, X = Don't Care

# Circuito comparador comercial CD74HC85 (<a href="http://bit.ly/1sfisEK">http://bit.ly/1sfisEK</a>)

- conexión mediante entradas de expansión en paralelo:

El circuito CD74HC85 está preparado para conexión paralelo, lo que reduce el tiempo de respuesta del dispositivo.

En la figura de la derecha se puede mediante sólo 2 etapas obtener un comparador de 24 bit, mientras que con el método de conexión en serie harían falta 6 comparadores y cada comparador supondría una etapa.

Como ejemplo, si con la familia LS85 el tiempo de respuesta para 24 bits es de 48 ns, mediante conexión en serie el tiempo es el triple (6 etapas frente a 2 etapas), es decir, de 144 ns.

