

# Fundamentos de Computadores

1º curso del Grado en Ingeniería Informática

## Tema 5

*Aritmética binaria*



Universidad  
de Huelva



*Departamento de Ingeniería Electrónica,  
de Sistemas Informáticos y Automática*

## Tema 5. Aritmética binaria

### Representación de números con signo

En un computador se efectúan múltiples operaciones aritméticas. En este tema se tratará la forma de realizar algunas de ellas, tales como la suma y la resta, así como los dispositivos y circuitos que las llevan a cabo. Las unidades lógicas y aritméticas (ALU), como parte integrante de cualquier procesador, también se estudian aquí.

Hasta el momento, se han estudiado una serie de códigos que únicamente permiten representar cantidades positivas. No obstante, en las operaciones realizadas en los computadores tanto los operandos como los resultados pueden tener signo positivo o negativo. Así pues se hace necesario el estudio de nuevos sistemas de representación de números que incluyan el signo de las cantidades.

A continuación se tratan algunos formatos de representación de números con signo:

- **Signo-magnitud.**
- **Complemento a 1.**
- **Complemento a 2.**

En los tres formatos a estudiar, para representar las cantidades se utilizan combinaciones de  $n$  bits, de los cuales el bit de mayor peso se usa para indicar el signo ( $S$ ) y los  $n - 1$  bits restantes para expresar el valor.



## Tema 5. Aritmética binaria

### Representación de números con signo (Signo magnitud)

En el formato de **signo-magnitud**, la representación de números con signo mediante combinaciones de **n** bits posee el siguiente rango:

$$[-2^{n-1} + 1, +2^{n-1} - 1]$$

- Si se usan combinaciones de 4 bits ( $n = 4$ ) el rango de representación será : [-7, +7].
- El rango de representación es simétrico y posee dos combinaciones para la representación del valor 0 (000...00 y 100...00).
- Para invertir el signo de una combinación basta con cambiar el valor del bit de signo de 0 a 1, o viceversa.

Las cantidades se representan de la siguiente forma.

- Bit de signo:
  - Números positivos:  $S = 0$ .
  - Números negativos:  $S = 1$ .
- $n - 1$  bits restantes:
  - Números positivos: Se codifica el valor en binario natural.
  - Números negativos: Se codifica el valor en binario natural.

Ejemplos de representación de cantidades para  $n = 8$ .

- **00100101**: + 37.
- **01110010**: + 114.
- **01000100**: + 68.
- **00000000**: + 0.
- **10000000**: - 0.
- **11111000**: - 120.
- **10100001**: - 33.

| D | C | B | A | VALOR DECIMAL |
|---|---|---|---|---------------|
| 0 | 0 | 0 | 0 | + 0           |
| 0 | 0 | 0 | 1 | + 1           |
| 0 | 0 | 1 | 0 | + 2           |
| 0 | 0 | 1 | 1 | + 3           |
| 0 | 1 | 0 | 0 | + 4           |
| 0 | 1 | 0 | 1 | + 5           |
| 0 | 1 | 1 | 0 | + 6           |
| 0 | 1 | 1 | 1 | + 7           |
| 1 | 0 | 0 | 0 | - 0           |
| 1 | 0 | 0 | 1 | - 1           |
| 1 | 0 | 1 | 0 | - 2           |
| 1 | 0 | 1 | 1 | - 3           |
| 1 | 1 | 0 | 0 | - 4           |
| 1 | 1 | 0 | 1 | - 5           |
| 1 | 1 | 1 | 0 | - 6           |
| 1 | 1 | 1 | 1 | - 7           |

## Tema 5. Aritmética binaria

### Representación de números con signo (Complemento a 1)

En el formato de **complemento a 1**, la representación de números con signo mediante combinaciones de n bits posee el siguiente rango:

$$[-2^{n-1} + 1, +2^{n-1} - 1]$$

- Si se usan combinaciones de 4 bits ( $n = 4$ ) el rango de representación será : [-7, +7].
- El rango de representación es simétrico y posee dos combinaciones para la representación del valor 0 (000...00 y 111...11).
- Para invertir el signo de una combinación se calcula su complemento a 1, es decir, se cambian ceros por unos, y viceversa.

Las cantidades se representan de la siguiente forma.

- Bit de signo:
  - Números positivos:  $S = 0$ .
  - Números negativos:  $S = 1$ .
- $n - 1$  bits restantes:
  - Números positivos: Se codifica el valor en binario natural.
  - Números negativos: Se codifica el valor en complemento a 1.

Ejemplos de representación de cantidades para  $n = 8$ .

- **00100101**: + 37.
- **01110010**: + 114.
- **01000100**: + 68.
- **00000000**: + 0.
- **11111111**: - 0.
- **10000111**: - 120.
- **11011110**: - 33.

| D | C | B | A | VALOR DECIMAL |
|---|---|---|---|---------------|
| 0 | 0 | 0 | 0 | + 0           |
| 0 | 0 | 0 | 1 | + 1           |
| 0 | 0 | 1 | 0 | + 2           |
| 0 | 0 | 1 | 1 | + 3           |
| 0 | 1 | 0 | 0 | + 4           |
| 0 | 1 | 0 | 1 | + 5           |
| 0 | 1 | 1 | 0 | + 6           |
| 0 | 1 | 1 | 1 | + 7           |
| 1 | 0 | 0 | 0 | - 7           |
| 1 | 0 | 0 | 1 | - 6           |
| 1 | 0 | 1 | 0 | - 5           |
| 1 | 0 | 1 | 1 | - 4           |
| 1 | 1 | 0 | 0 | - 3           |
| 1 | 1 | 0 | 1 | - 2           |
| 1 | 1 | 1 | 0 | - 1           |
| 1 | 1 | 1 | 1 | - 0           |

## Tema 5. Aritmética binaria

### Representación de números con signo (Complemento a 2)

En el formato de **complemento a 2**, la representación de números con signo mediante combinaciones de n bits posee el siguiente rango:

$$[-2^{n-1}, +2^{n-1} - 1]$$

- Si se usan combinaciones de 4 bits ( $n = 4$ ) el rango de representación será : [-8, +7].
- El rango de representación no es simétrico y posee una sola combinación para la representación del valor 0 (000...00).
- Para invertir el signo de una combinación se calcula su complemento a 2, del modo que se describirá posteriormente.

Las cantidades se representan de la siguiente forma.

- Bit de signo:
  - Números positivos:  $S = 0$ .
  - Números negativos:  $S = 1$ .
- $n - 1$  bits restantes:
  - Números positivos: Se codifica el valor en binario natural.
  - Números negativos: Se codifica el valor en complemento a 2.

Ejemplos de representación de cantidades para  $n = 8$ .

- **00100101**: + 37.
- **01110010**: + 114.
- **01000100**: + 68.
- **00000000**: + 0.
- **11111111**: - 1.
- **10001000**: - 120.
- **11011111** : - 33.

| D | C | B | A | VALOR DECIMAL |
|---|---|---|---|---------------|
| 0 | 0 | 0 | 0 | + 0           |
| 0 | 0 | 0 | 1 | + 1           |
| 0 | 0 | 1 | 0 | + 2           |
| 0 | 0 | 1 | 1 | + 3           |
| 0 | 1 | 0 | 0 | + 4           |
| 0 | 1 | 0 | 1 | + 5           |
| 0 | 1 | 1 | 0 | + 6           |
| 0 | 1 | 1 | 1 | + 7           |
| 1 | 0 | 0 | 0 | - 8           |
| 1 | 0 | 0 | 1 | - 7           |
| 1 | 0 | 1 | 0 | - 6           |
| 1 | 0 | 1 | 1 | - 5           |
| 1 | 1 | 0 | 0 | - 4           |
| 1 | 1 | 0 | 1 | - 3           |
| 1 | 1 | 1 | 0 | - 2           |
| 1 | 1 | 1 | 1 | - 1           |

## Tema 5. Aritmética binaria

### Representación de números con signo (Complemento a 2)

#### Formas de calcular el complemento a 2 de una combinación

- Restar el valor expresado en complemento a 2 de  $2^n - 1$ :

**Ejemplo:** Dado el valor + 2, que codificado en complemento a 2 con cuatro bits es **0010**, restamos esta combinación de  $2^4 = 16$ , que expresado en binario es **10000**.

$$\begin{array}{r} 10000 \\ - 0010 \\ \hline 1110 \end{array}$$

Como resultado se obtiene la combinación **1110**, que es la codificación del valor - 2 en formato de complemento a 2 con 4 bits.

- Calcular el complemento a 1 de la combinación y a continuación sumarle 1:

**Ejemplo:** Dado el valor + 2, que codificado según el formato del complemento a 2 con cuatro bits es **0010**, comenzamos por obtener su complemento a 1, que es **1101**. A continuación sumamos 1 a la combinación obtenida.

$$\begin{array}{r} 1101 \\ + 1 \\ \hline 1110 \end{array}$$

Como resultado se obtiene la combinación **1110**, que es la codificación del valor - 2 en formato de complemento a 2 con 4 bits. Este es el método que se emplea para realizar la resta en los circuitos digitales, como se verá posteriormente en este tema.

- Mantener intactos todos los 0 situados a la derecha de la combinación y el primer 1, e invertir el resto de los bits:

**Ejemplo:** Dado el valor + 2, que codificado según el formato del complemento a 2 con cuatro bits es **0010**, se opera de la forma siguiente.

$$\begin{array}{r} 0010 \\ \downarrow \\ 1110 \end{array}$$

Como se puede apreciar, este método proporciona el mismo resultado que los anteriores.

## Tema 5. Aritmética binaria

### Suma binaria

La **suma binaria** es una operación muy parecida a la suma decimal que conocemos, salvo que en ésta las combinaciones poseen sólo dos dígitos, el 0 y el 1.

La suma de dos combinaciones de n bits puede producir un resultado de n+1 bits, debido al acarreo que puede producirse en el bit de mayor peso (MSB).

**Ejemplo:** Suma de los valores 11 y 9 expresados en binario.

$$\begin{array}{r} 1011 \\ + 1001 \\ \hline 10100 \end{array}$$

Como se puede apreciar, la suma de números binarios de 4 bits puede dar como resultado un número de 5 bits.

Para llevar a cabo la suma de dos combinaciones **A** y **B**, es necesario comenzar por los bits de menos peso e ir sumando en cada etapa los bits correspondientes a ambas combinaciones (**A<sub>n</sub>** y **B<sub>n</sub>**) con el acarreo de la etapa anterior (**C<sub>n-1</sub>**), lo cual dará como resultado el resultado de la suma correspondiente a dicha etapa (**S<sub>n</sub>**) mas el acarreo a sumar a la etapa siguiente (**C<sub>n</sub>**).

### Sumador completo de 1 bit

Un **sumador completo** de un bit es un circuito combinacional capaz de realizar la suma de dos bits más un acarreo de entrada para producir un bit de suma mas un acarreo de salida.

| A | B | Cl | CO | S |
|---|---|----|----|---|
| 0 | 0 | 0  | 0  | 0 |
| 0 | 0 | 1  | 0  | 1 |
| 0 | 1 | 0  | 0  | 1 |
| 0 | 1 | 1  | 1  | 0 |
| 1 | 0 | 0  | 0  | 1 |
| 1 | 0 | 1  | 1  | 0 |
| 1 | 1 | 0  | 1  | 0 |
| 1 | 1 | 1  | 1  | 1 |

$$\begin{aligned} S &= \overline{A}\overline{B}C_I + \overline{A}B\overline{C}_I + A\overline{B}\overline{C}_I + ABC_I = \overline{A}(\overline{B}C_I + B\overline{C}_I) + A(\overline{B}\overline{C}_I + BC_I) = \\ &= \overline{A}(B \oplus C_I) + A(\overline{B} \oplus \overline{C}_I) = A \oplus B \oplus C \end{aligned}$$

$$\begin{aligned} C_O &= \overline{A}\overline{B}C_I + \overline{A}\overline{B}\overline{C}_I + A\overline{B}\overline{C}_I + ABC_I = \\ &= AB(\overline{C}_I + C_I) + AC_I(\overline{B} + B) + BC_I(\overline{A} + A) = AB + (A + B)C_I \end{aligned}$$

## Tema 5. Aritmética binaria

### Suma binaria

Las expresiones obtenidas anteriormente permite implementar el sumador completo como sigue.



Diagrama lógico y símbolo de un sumador completo de 1 bit

### Sumador paralelo de 4 bits

Mediante la conexión de cuatro sumadores completos de 1 bit con propagación del acarreo en serie se puede obtener un sumador paralelo de cuatro bits, que permite realizar la suma entre dos combinaciones de 4 bits mas un acarreo de entrada.



## Tema 5. Aritmética binaria

## Suma binaria

## Ejemplos de usos de los sumadores

### Ejemplo 1: Conversión de BCD Natural a BCD exceso 3.



**Ejemplo 2:** Conversión de BCD Natural a BCD Aiken.

|       | BCD NATURAL    |                |                |                | CORRECCIÓN     |                |                |                | BCD AIKEN      |                |                |                |   |
|-------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|---|
| Valor | N <sub>3</sub> | N <sub>2</sub> | N <sub>1</sub> | N <sub>0</sub> | C <sub>3</sub> | C <sub>2</sub> | C <sub>1</sub> | C <sub>0</sub> | A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> |   |
| 0     | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0 |
| 1     | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1 |
| 2     | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0 |
| 3     | 0              | 0              | 1              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1 |
| 4     | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0 |
| 5     | 0              | 1              | 0              | 1              | 0              | 1              | 1              | 0              | 1              | 0              | 1              | 1              | 1 |
| 6     | 0              | 1              | 1              | 0              | 0              | 1              | 1              | 0              | 1              | 1              | 0              | 0              | 0 |
| 7     | 0              | 1              | 1              | 1              | 0              | 1              | 1              | 0              | 1              | 1              | 0              | 1              | 1 |
| 8     | 1              | 0              | 0              | 0              | 0              | 1              | 1              | 0              | 1              | 1              | 1              | 0              | 0 |
| 9     | 1              | 0              | 0              | 1              | 0              | 1              | 1              | 0              | 1              | 1              | 1              | 1              | 1 |

$$C_3 = C_0 = 0$$

$$C_2 = C_1 = N_3 + N_2N_1 + N_2N_0 = \\ = \overline{N_3} \cdot \overline{N_2N_1} \cdot \overline{N_2N_0}$$



## Tema 5. Aritmética binaria

### Suma binaria (Asociación de sumadores)

Mediante la conexión de sumadores paralelos de 4 bits con propagación del acarreo en serie se puede obtener un sumador paralelo para combinaciones de tantos bits como sea necesario. El inconveniente de este tipo de conexión consiste en que cuantos más circuitos se añadan a la cadena mayor será el retardo del circuito obtenido.

**Ejemplo:** Obtener un sumador paralelo para combinaciones de 16 bits mediante el uso de sumadores paralelos de 4 bits.



## Tema 5. Aritmética binaria

### Resta binaria (Circuito restador en complemento a 2)

En los sistemas digitales, la **resta binaria** se suele llevar a cabo en la práctica mediante circuitos implementados con sumadores.

Para ello, la resta binaria se trata como una suma algebraica, de la siguiente manera:

$$A - B = A + (-B)$$

Si se representan los números en formato de complemento a 2 ( $n-1$  bits más signo), como se indicó anteriormente, para cambiarlos de signo bastará con hacerles el complemento a 1 (invertir todos sus bits) y sumarle 1 al resultado.

Así pues, para implementar un restador de cuatro bits se aplicará el minuendo directamente a uno de los operandos de un bloque sumador y el sustraendo al otro operando a través de cuatro inversores (que realizan el complemento a 1), mientras que al acarreo de entrada se le aplica el valor 1 (para sumar 1 al resultado).



Al realizar una resta binaria hay que asegurarse de que el resultado no sobrepase la capacidad de representación de la combinación de salida  $\Rightarrow [-2^{n-1}, +2^{n-1} - 1]$ . Si el valor obtenido queda fuera de este rango se produce un desbordamiento (*overflow*), y por tanto no será válido.

Este desbordamiento puede ser detectado fácilmente mediante la siguiente función:

$$D = \overline{S_A} \overline{S_B} \overline{S_S} + S_A S_B \overline{S_S}$$

## Tema 5. Aritmética binaria

### Resta binaria (Circuito sumador/restador en complemento a 2)

Con frecuencia, en un sistema digital deben realizarse tanto sumas como restas, por lo que se hace necesario disponer de un circuito capaz de realizar ambas operaciones.

En la figura se muestra el modo de implementar un circuito sumador/restador capaz de operar sobre dos combinaciones de tres bits mas signo.



Cuando se aplica a la señal  $\bar{S}/R$  el valor **0**, al operando B del sumador llega el número Y sin complementar y el acarreo de entrada también adopta el valor **0**, por lo que el circuito realiza la suma de los dos números. Por el contrario, si es puesto a **1**, se aplica al operando B del sumador el complemento a uno del número Y, y un **1** al acarreo de entrada, por lo que el circuito realiza la resta  $X - Y$ .

## Tema 5. Aritmética binaria

### Operaciones aritméticas en VHDL (Suma y resta)

Para realizar la suma de dos números en VHDL:

$$S \leq A + B;$$

- Los números A y B pueden ser vectores y enteros. Los operandos A y B pueden ser de distinta longitud. Si S se declara de la misma longitud que el operando de mayor longitud, el acarreo no se tiene en cuenta. Si se quiere conservar el acarreo, S debe tener un bit más que el operando de mayor longitud, y en ese caso la suma se escribirá:

$$S \leq '0' \& A + B;$$

- Si operamos con números positivos y negativos, deben declararse S, A y B de la misma longitud, y la operación R  $\leq A + B$  usará el complemento a 2 para representar números negativos. Se puede añadir un circuito que detecte el *overflow* comprobando los bits de signo.
- Cuando A o B son de menor longitud que S, el paquete **std\_logic\_unsigned** añade ceros hasta completar la longitud de la suma. Si se emplea el paquete **std\_logic\_signed**, la longitud se completa repitiendo el bit de signo.

Para realizar la resta de dos números en VHDL:

$$R \leq A - B;$$

Los operandos pueden ser de distinta longitud, y el resultado R ha de ser de longitud igual o mayor que el operando de mayor longitud.

Dependiendo de si trabajamos con números positivos y negativos, o sólo positivos, emplearemos uno de estos paquetes:

**use ieee.std\_logic\_unsigned.all;**

**use ieee.std\_logic\_signed.all;**

## Tema 5. Aritmética binaria

### Operaciones aritméticas en VHDL (Ejemplo de diseño)

Ejemplo: Realizar una descripción VHDL de un sumador completo de 4 bits.



```
-- Sumador de 4 bits
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;

entity sumador_4 is
    port (B, A : in std_logic_vector (3 downto 0);
          C0 : in std_logic;
          S : out std_logic_vector (3 downto 0);
          C4: out std_logic);
end sumador_4;

architecture suma of sumador_4 is
    signal sum : std_logic_vector (4 downto 0);
begin
    sum <= ('0' & A) + ('0' & B) + ("0000" & C0);
    C4 <= sum(4);
    S <= sum(3 downto 0);
end suma;
```

# Tema 5. Aritmética binaria

## Unidades aritmético-lógicas (ALUs)

Las **unidades aritmético-lógicas** o **ALUs** (*Arithmetic Logic Units*) son circuitos combinacionales que, como su nombre indica, son capaces de realizar un conjunto de operaciones tanto lógicas como aritméticas.

Estos circuitos reciben dos operandos A y B (normalmente de 4 bits) más un acarreo de entrada ( $C_i$ ) y proporcionan un salida F de la misma longitud que los operandos y un acarreo de salida ( $C_o$ ). Además, suelen incorporar salidas de generación (CG) y propagación (CP) de acarreos, que se usan para asociar varios circuitos mediante la generación de acarreos en paralelo, y una salida  $A = B$  (de colector abierto) que permite detectar si las combinaciones de entrada son iguales.



| SELECCIÓN | DATOS ACTIVOS A NIVEL ALTO (TABLA 2) |                                           |                                                          |  |
|-----------|--------------------------------------|-------------------------------------------|----------------------------------------------------------|--|
|           | M = 1<br>FUNCIONES LÓGICAS           | M = 0; OPERACIONES ARITMÉTICAS            |                                                          |  |
|           |                                      | $\bar{C}_n = 1$<br>(Sin acarreo)          | $\bar{C}_n = 0$<br>(Con acarreo)                         |  |
| 0 0 0 0   | $F = A$                              | $F = A$                                   | $F = A \text{ MAS } 1$                                   |  |
| 0 0 0 1   | $F = \bar{A} + B$                    | $F = A + B$                               | $F = (A + B) \text{ MAS } 1$                             |  |
| 0 0 1 0   | $F = \bar{A}\bar{B}$                 | $F = A + \bar{B}$                         | $F = (A + \bar{B}) \text{ MAS } 1$                       |  |
| 0 0 1 1   | $F = 0$                              | $F = \text{MENOS } 1 \text{ (COMPL. 2)}$  | $F = 0$                                                  |  |
| 0 1 0 0   | $F = \bar{A}\bar{B}$                 | $F = A \text{ MAS } \bar{A}\bar{B}$       | $F = A \text{ MAS } \bar{A}\bar{B} \text{ MAS } 1$       |  |
| 0 1 0 1   | $F = \bar{B}$                        | $F = (A + B) \text{ MAS } \bar{A}\bar{B}$ | $F = (A + B) \text{ MAS } \bar{A}\bar{B} \text{ MAS } 1$ |  |
| 0 1 1 0   | $F = A \oplus B$                     | $F = A \text{ MENOS } B \text{ MENOS } 1$ | $F = A \text{ MENOS } B$                                 |  |
| 0 1 1 1   | $F = \bar{A}\bar{B}$                 | $F = \bar{A}\bar{B} \text{ MENOS } 1$     | $F = \bar{A}\bar{B}$                                     |  |
| 1 0 0 0   | $F = \bar{A} + B$                    | $F = A \text{ MAS } AB$                   | $F = A \text{ MAS } AB \text{ MAS } 1$                   |  |
| 1 0 0 1   | $F = A \oplus \bar{B}$               | $F = A \text{ MAS } B$                    | $F = A \text{ MAS } B \text{ MAS } 1$                    |  |
| 1 0 1 0   | $F = B$                              | $F = (A + \bar{B}) \text{ MAS } AB$       | $F = (A + \bar{B}) \text{ MAS } AB \text{ MAS } 1$       |  |
| 1 0 1 1   | $F = AB$                             | $F = AB \text{ MENOS } 1$                 | $F = AB$                                                 |  |
| 1 1 0 0   | $F = 1$                              | $F = A \text{ MAS } A$                    | $F = A \text{ MAS } A \text{ MAS } 1$                    |  |
| 1 1 0 1   | $F = A + \bar{B}$                    | $F = (A + B) \text{ MAS } A$              | $F = (A + B) \text{ MAS } A \text{ MAS } 1$              |  |
| 1 1 1 0   | $F = A + B$                          | $F = (A + \bar{B}) \text{ MAS } A$        | $F = (A + \bar{B}) \text{ MAS } A \text{ MAS } 1$        |  |
| 1 1 1 1   | $F = A$                              | $F = A \text{ MENOS } 1$                  | $F = A$                                                  |  |