

# Sistemas Digitales

# Índice

Tema 1: [Introducción a los Sistemas Digitales Electrónicos.](#)

Tema 2: [Representación Digital de la Información.](#)

Tema 3: [Algebra de Boole. Puertas Lógicas.](#)

Tema 4: [Lenguaje de Descripción Hardware VHDL.](#)

Tema 5: [Circuitos Aritméticos.](#)

Tema 6: [Otros Circuitos Combinacionales.](#)

# Tema 1 : Introducción a los Sistemas Digitales Electrónicos

- Presentación
  - Profesor
  - Calendario
  - Sistemas Digital: TAC
  - Electrónica
  - Procesamiento de señales eléctricas
- Organización Académica
  - Programa
  - Prácticas
  - Ejercicios
  - Evaluación
  - Metodología

# Profesorado

- Prof. Cándido Aramburu Mayoz.
  - Doctor Ingeniero Telecomunicación (UPNA-Universidad Politécnica de Madrid)
  - Empresa Ikusi S.A. (Sistemas de Telemedida 1989)
  - Profesor Titular UPNA (Dpto Ingeniería Electrónica y Comunicaciones 2000)
- Profesor Prácticas: Aitor Urrutia
- Profesor Euskera: Marko Galarza
- Profesor Inglés: Ignacio del Villar
- <https://www.etsit.upm.es/>
- <https://www.velatia.com/es/empresas-que-forman-velatia/ikusi/>
- <https://www.unavarra.es/eu/sites/Portada/home.html>

# Contacto

- Despacho: Edificio Los Tejos 2 Planta: Despacho 2028 (Prof. Candido Aramburu)
- Miaulario → correo interno
- Clase
  - G1: A112 : Lunes (12-14) y Jueves (10-12)
  - G2: A012 : Lunes (10-12) y Miércoles (12-14)
- Tutorías
  - Lunes (14-17) y Miércoles (9-12)
  - Cita Previa

# **Calendario**

## Febrero

| Lunes                                                                                   | Miércoles                                              |
|-----------------------------------------------------------------------------------------|--------------------------------------------------------|
| 30-Presentación..Repre_info:Numeros bases                                               | 1-Repre_Info:Enteros..C2:Expansion Signo               |
| 6-C2:Overflow..Tema3:Morgan                                                             | 8-Tema3:Morgan..DK:examples                            |
| 13-BCD..Tema3:Repaso y Ejercicios                                                       | 15-Tema4_VHDL:Intro..Archit y Tema3:Dudas y Ejercicios |
| 20-Tema5_Aritmética:Intro..Tema5:Sumador/Restador y Tema4:Paquetes;STD y Standard_Logic | 27-Tema5:Semirestador..ALU y Tema4:Process()           |

## Marzo

| Lunes | Lunes |
|-------|-------|
| 6     | 13    |
| 20    | 27    |

# Sistemas Digitales

# Tomografía axial computarizada



# Sistema Digital



Entrada **Análogica** → Sensores Magnéticos.

**Conversor A/D:** Señal Analógica a Señales Digitales.

Circuitos **Lógicos**: multiplexores, filtros, codificadores, etc ...

**Procesadores Lógicos:** procesamiento de las señales digitales para obtener la imagen.

# FPGA : Field Programming Gate Array.

# DSP : Digital Signal Processing.

# CPU : Centra Procesor Unit.

# GPU : Graphic Procesor Unit.

# Electrónica

## Equipos de Electrónica



# Esquema Eléctrico



# Componentes de una tarjeta de circuito impreso



Componentes:

- Discretos: resistencias, condensadores, transistores, transformadores, etc.
- Integrados ("chips", microelectrónica).
- material de semiconductor: Silicio.
- el componente básico es el transistor → un procesador puede tener cientos de millones.
- los microcircuitos hechos de transistores pueden ser tanto circuitos analógicos (un amplificador) como digitales (puertas lógicas)

## Printed Circuit Board



# Instrumentación



# La Electrónica en la Profesión

## Digital Electronics Engineer

|            |                             |
|------------|-----------------------------|
| Ref No.    | EMP439757                   |
| Location   | Twickenham, London, England |
| Job type   | Permanent                   |
| Job Status | Closed                      |

You can not apply for this job as its status is **Closed**.

 Save  Email

Share:   

### Introduction

Are you interested in working for a continuously growing company that really value their staff and offer a fantastic range of benefits?

### Important

Digital electronics, FPGA, VHDL/Verilog, DSP, PCB

### The Job

This opportunity is for a Senior Electronics Engineer to join a team that have tripled in size over the last 10 years due to continued success. The company design and manufacture sensors that use state-of-the-art acoustic resonance technology, and are distributed internationally across a number of industries including marine and defence.

## Técnico



## **¿ Profesiones relacionadas con la Electrónica?**

# Fases de Diseño de Circuitos Electrónicos Binarios

1. Funcional (manual): abstracción matemática
2. Automatización del proceso matemático
  - a. Herramientas de Diseño con ayuda del Computador (EDA)
  - b. Simulación del Diseño del Circuito Electrónico antes de fabricar el prototipo: Depuración
3. Fabricación del prototipo
  - a. Instrumentación
  - b. Verificación del funcionamiento en el Laboratorio
  - c. Verificación del funcionamiento en Campo
4. Comercialización
5. Producción

# La Electrónica en la Carrera Universitaria

- Conocimientos de Electrónica
  - ¿ Para .... ?
  - Tecnología Hardware
    - Fabricación de Prototipos
    - Diseño de Prototipos : Conceptos Teóricos y Herramientas de diseño por computador
    - Desarrollo de Sistemas: Equipos, Plataformas
    - Comercialización
    - Usuario: Equipos, Plataformas

# Representación Científica y Prefijos de las Unidades

*Table 1. Prefijos*

| Prefijos                         | Tera      | Giga   | Mega   | Kilo   | mili      | micro     | nano      | pico       |
|----------------------------------|-----------|--------|--------|--------|-----------|-----------|-----------|------------|
| Base 10 → magnitudes:m,gr,Hz, .. | $10^{12}$ | $10^9$ | $10^6$ | $10^3$ | $10^{-3}$ | $10^{-6}$ | $10^{-9}$ | $10^{-12}$ |
| Base 2 → magnitudes: Byte        | $2^{12}$  | $2^9$  | $2^6$  | $2^3$  | $2^{-3}$  | $2^{-6}$  | $2^{-9}$  | $2^{-12}$  |

- Ejemplo: representar la magnitud=1000000000Hz debidamente
  - Notación científica →  $10^9$ Hz
  - Debidamente: Notación científica con prefijos f=1GHz → T=1/f=10<sup>-9</sup>seg= 1ns

# Señales: Conversión Analógica Digital

## Analogica vs Digital

- Señal Continua
  - Amplitud: *oo* valores posibles en el rango
  - Tiempo: *oo* valores posibles en el rango
- Señal Discreta ó Digital
  - Amplitud: finitos valores posibles en el rango
  - Tiempo: finitos valores posibles en el rango

## Señales : Muestreo y Cuantificación



## Codificación



Calcular para las resoluciones de 3 bit y 16 bits cual es el mínimo incremento de señal codificable o error de cuantificación: con 3 bits el número de niveles es  $2^3=8$  niveles y el mínimo relativo es  $2^3=1/8$ ; con 16 bits el número de niveles es  $2^{16}$  y el mínimo relativo es  $2^{-16}= 1/65536$ .

Representación de los números en código binario : [Tema 2 : Representación Digital de la Información](#)

## Señales Binarias : Abstractas



Eje ordenada: valores abstractos (0/1, High/Low, ON/OFF, etc ...).

Cronograma: Representación temporal de las señales digitales binarias.

Esa representación típica de los libros de texto, pizarra de clase, etc ... es ideal ya que físicamente siempre habrá distorsión.

## Señales Binarias : Físicas



Eje ordenada: magnitudes físicas (mV ó mA).

La señal física está distorsionada por causas como pej: línea larga de transmisión (efectos capacitivos e inductivos).

Un ejemplo típico de distorsión son los tiempos de subida y bajada, que no son nulos sino del orden de unos nanosegundos.

La distancia considerable entre los dos niveles (binario) a la entrada del receptor hace fácil la discriminación entre el '0' y el '1'.

# Digitalización de las Señales

## Ventajas

- Calidad: Fácil de recuperar a pesar de la distorsión
- Almacenamiento: Fiabilidad, Diversidad Formatos
- Compatibilidad: Diversidad de Equipos (PC, móvil, coche, etc)
- Procesamiento: Sencillo, Flexible
- Coste: Barato (componentes)

# Abstracción

- Niveles: el 0 y el 1
- Lógica binaria
  - Matemáticas: Algebra de Boole

# Organización Académica

# Programa de la Asignatura

- [Ficha Web Upna](http://www.unavarra.es/ficha-asignaturaDOA/?languageld=100000&codPlan=246&codAsig=246110&anio=2022) [http://www.unavarra.es/ficha-asignaturaDOA/?languageld=100000&codPlan=246&codAsig=246110&anio=2022]
- Programa en 3 partes
  - i. ***Circuitos Combinacionales***
  - ii. ***Circuitos Secuenciales***
  - iii. Otros: Números, Lógica Programable (VHDL), Teoría Tecnología
- Bibliografía

# Prácticas

- Tipo de prácticas:
  - Diseño manual
  - Simulación con la herramienta software Quartus de Intel.
  - Captura gráfica de Esquemas Electrónicos
  - Descripción del Circuito mediante el Lenguaje VHDL. Fabricación del Circuito en tecnología FPGA

# Ejercicios

- Tipo de problemas: Libro Verde → Ejercicios tipo examen → Sin calculadora y sin libros

El libro verde se adquiere en el edificio de rectorado, en la sección de comunicación,  
que se encuentra en planta baja del edificio.  
El horario: 8 a 14:30. Precio 8.5\$.

- \* Capítulo 1: 1.1, 1.2, 1.4, 1.5, 1.6, 1.8, 1.9
- \* Capítulo 2: 2.1
- \* Capítulo 3: 3.2 3.3 -> 2º parcial
- \* Capítulo 4: 4.2, 4.4, 4.6
- \* Capítulo 5: 5.2, 5.3, 5.4
- \* Capítulo 6: 6.1, 6.2 -> 2º parcial
- \* Capítulo 7: 7.2, 7.3 y 7.4 -> 2º parcial
- \* Capítulo 8: 8.1, 8.3 y 8.5 -> 2º parcial

- Los ejercicios del tema 2 (Representación de la Información) no están en el libro verde
  - Miaulario → Recursos → Ejercicios

# Evaluación

- Sistema de Evaluación:
  - 75% teoría y 25% prácticas
  - Evaluación continua Teoría: dos parciales (30% 1º parcial y 45% 2º parcial). Nota mínima en el 2º parcial: 5. El Primer parcial se realizará el sábado 25 de Marzo a las 9:00, el segundo parcial el 24 de Mayo a las 8:00 y la recuperación el 12 de Junio a las 8:00
  - Recuperación Teoría: Entra todo. Nota mínima: 5.
  - Evaluación Prácticas: Un único exámen el sábado XX de Mayo, no recuperable.

# Metodología

- Trabajo en clase: principalmente Ejercicios con su teoría asociada
- Trabajo en casa
  - Teoría desarrollada en los apuntes PDF en mi aulario
  - Prácticas
    - En casa: Ejercicios de diseño manual
    - En casa: Utilización de Quartus y Memorias
- Tutorías
  - Resolución de dudas

# Tema 2 : Representación Digital de la Información

# Indice

- Información: números, caracteres, imagen, sonido, etc ..
- Números
  - Sistemas posicionales: base 10 (decimales), base 2 (binaria)
  - Naturales: bases 10,2,8,16 . Conversión entre bases
  - Enteros: Signo Magnitud, Complemento a la base-1, Complemento a la base
  - Operaciones aritméticas: Suma,Resta
  - Reales: coma fija y coma flotante
- Caracteres
  - Alfanuméricos y Signos de Puntuación
  - ASCII standard y extendido
  - Unicode: UTF-8

# Representación de los Números

# Representación de los Números Decimales

- Decimal
  - 10 dígitos : 0,1,2,3,4,5,6,7,8,9
  - Pesos con base 10 :  $10^n$  donde n es la posición del dígito dentro del número
- Ejemplo: número 5421

Table 2. Número 5421

| Representación:       | los símbolos 5421                                                                              |                                       |                                 |                          |
|-----------------------|------------------------------------------------------------------------------------------------|---------------------------------------|---------------------------------|--------------------------|
| Posiciones:           | 3                                                                                              | 2                                     | 1                               | 0                        |
| Pesos:                | $10^3 \rightarrow 1000$                                                                        | $10^2 \rightarrow 100$                | $10^1 \rightarrow 10$           | $10^0 \rightarrow 1$     |
| Dígitos:              | 5                                                                                              | 4                                     | 5                               | 1                        |
| Valores : ponderación | $5 \cdot 1000 = \text{cinco mil}$                                                              | $4 \cdot 100 = \text{cuatro cientos}$ | $5 \cdot 10 = \text{cincuenta}$ | $1 \cdot 1 = \text{uno}$ |
| Valor:                | $5 \cdot 1000 + 4 \cdot 100 + 5 \cdot 10 + 1 = \text{cinco mil cuatrocientos cincuenta y uno}$ |                                       |                                 |                          |

# Representación de los Valores Enteros en Código Binario

- ¿Número? ¿Valor? ¿Código? ¿Representación?
  - 2 dígitos : 0,1
  - Pesos con base 2 :  $2^n$  donde n es la posición del dígito dentro del número: ....-1024-512-256-128-64-32-16-8-4-2-1...
- Ejemplo: número 0b1011

Table 3. Número 0b1011

| Representación:       | los símbolos 1011         |                           |                          |                          |
|-----------------------|---------------------------|---------------------------|--------------------------|--------------------------|
| Posiciones:           | 3                         | 2                         | 1                        | 0                        |
| Pesos:                | $2^3 \rightarrow 8$       | $2^2 \rightarrow 4$       | $2^1 \rightarrow 2$      | $2^0 \rightarrow 1$      |
| Dígitos:              | 1                         | 0                         | 1                        | 1                        |
| Valores : ponderación | $1 \cdot 8 = \text{ocho}$ | $0 \cdot 4 = \text{cero}$ | $1 \cdot 2 = \text{dos}$ | $1 \cdot 1 = \text{uno}$ |
| Valor:                | ocho+cero+dos+uno= once   |                           |                          |                          |

# Representación de los Valores Enteros en Código Binario

- ¿Cómo se representa en binario el valor 123.125? b1111011.001
- ¿Cómo se calcula el valor del número binario b1111011.001?
- Parte Entera: divisiones sucesivas por la base 2
- Parte Fracción: multiplicaciones sucesivas por la base 2

# Representación de los Valores Enteros en Código Octal

- Dígitos: 0,1,2,3,4,5,6,7
- Posiciones y Pesos
- ¿Cómo se representa en octal el valor 123.125? 0o173.1
- ¿Cómo se calcula el valor del número octal 0o173.1?
- Parte Entera: divisiones sucesivas por la base 8
- Parte Fracción: multiplicaciones sucesivas por la base 8

# Representación de los Números en Hexadecimal

- Dígitos: 0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F \_ el valor de A es 10, B→11, C→12, D→13, E→14, F→15
- Posiciones y Pesos
- ¿Cómo se representa en hexadecimal el valor 123.125? 0x7B.2
- ¿Cómo se calcula el valor del número octal 0x7B.2?
- Parte Entera: divisiones sucesivas por la base 16
- Parte Fracción: multiplicaciones sucesivas por la base 16

# Calculadora de Python

[Python Interpreter Shell](https://www.programiz.com/python-programming/online-compiler/) [https://www.programiz.com/python-programming/online-compiler/]

```
bin(123)
oct(123)
hex(123)
int(0b1111011)
int(0o173)
int(0x7B)
```

# Conversiones entre el sistema binario y sistemas con base potencia de 2

- Conversión Binaria-Hexadecimal
  - base  $16=2^4$
  - grupos de 4 bits empezando por la dcha
  - $b1111011 \rightarrow 111 - 1011 \rightarrow 0x7B$
- Conversión Hexadecimal-Binaria
  - grupos de 4 bits
- Conversión Binaria-Octal
  - base  $8=2^3$
  - grupos de 3 bits empezando por la dcha
  - $b1111011 \rightarrow 1 - 111 - 011 \rightarrow 0o173$
- Conversión Octal-Binaria
  - grupos de 3 bits

## Suma binaria

- Suma  $10011011 + 00011011 = 10110110$

|               |                              |
|---------------|------------------------------|
| Llevadas -->  | 1 1 1 1                      |
|               | 1 0 0 1 1 0 1 1 <--sumando   |
|               | + 0 0 0 1 1 0 1 1 <--sumando |
| Valor suma    | 1 3 2 1 3 2                  |
|               | *****                        |
| Resultado --> | 1 0 1 1 0 1 1 0 <--suma      |

- Cuando la suma en una posición específica tiene un valor es mayor o igual a la base hay que restar **n** veces la base y el valor **n** será la llevada a sumar en la posición siguiente.

## Resta binaria

- Resta  $10110110 - 10011011 = 00011011$

Sumar crédito al minuendo

2 2 2 2

$$\begin{array}{r} 1 0 1 1 0 1 1 0 \leftarrow \text{minuendo} \\ - 1 0 0 1 1 0 1 1 \leftarrow \text{sustraendo} \\ \hline \end{array}$$

Sumar llevada al sustraendo

1 1 1 1

\*\*\*\*\*

Resta

0 0 0 1 1 0 1 1

- Cuando en una posición específica el minuendo es menor que el sustraendo se suma la base al minuendo antes de realizar la resta y se suma la llevada al sustraendo de la posición siguiente.

## Aritmética Modular: la rueda



Representación binaria de números con 3 dígitos.

$2^3$  : 8 combinaciones posibles,

Ejemplo: cuentakilómetros del coche.

Ejemplo: registro de 3 celdas → limitado a 8 combinaciones posibles.

¿Cuál es la siguiente combinación a 111?,

$$111 + 1 = ?$$

Calcular la representación del valor 33 en módulo 8 → Resto( $33/8$ )=1 → en binario 001

33 pasos en la rueda equivale al número 001 → aritmética modular en módulo 8

# Operaciones aritméticas: Octal y Hexadecimal

- Base Octal
  - $0o675 + 0o304 = 0o1201$
  - $0o632 - 0o374 = 0o236$
- Base hexadecimal
  - $0xD1B + 0xFF = 0x181A$
  - $0xE53 - 0xBA9 = 0x2A9$

# Representación de Números con Valores Enteros

- Signo-Magnitud
- Complemento a la base menos 1
- Complemento a la base

# Representación en Signo-Magnitud

- Signo → un dígito
- Base 10:
  - valores positivos: el signo el dígito 0 en la posición MSD (More Significant Digit) y resto de dígitos representa el módulo
  - valores negativos: el signo el dígito 9 (base-1) en la posición MSD (More Significant Digit) y resto de dígitos representa el módulo
  - Ejemplo +123 → 0123 y -123 → 9123

# Representación en Signo-Magnitud

- Signo → un bit (Binary digit)
- Base 2 :
  - valores positivos: el signo el bit 0 en la posición MSB (More Significant Bit) y resto de bits representa el módulo
  - valores negativos: el signo el bit 1 (base-1) en la posición MSB (More Significant Bit) y resto de bits representa el módulo
  - Ejemplo +123 → 0b01111011 y -123 → 0b11111011
  - Dibujar la tabla y la rueda con todos los valores con sus representaciones.
  - ¿Cuántas representaciones son posibles? ¿Es simétrico el rango de valores representado? ¿Cuántas representaciones tiene el cero?
  - Extender el número de bits del número sin cambiar su valor

## Representación en complemento a la base menos 1. C9

- Base 10: Complemento a 9 → C9
- Signo → un dígito
- Valores positivos: igual que los valores positivos en código Signo-Magnitud
- Valores negativos: Hay que restar el código del valor en positivo del minuendo 99999999 (base-1)
  - Ejemplo +123 → 0123 y -123 → 9999-0123 = 9876
- El C9 de un número positivo es el código de su valor en negativo
- El C9 de un número negativo es el código de su valor en positivo

# Representación en complemento a la base menos 1. C1

- Base 2 : base-1=1 → Complemento a 1 → C1
- Signo → un dígito
- Valores positivos: igual que los valores positivos en código Signo-Magnitud
- Valores negativos: Hay que restar el código del valor en positivo del minuendo 11111111 (base-1)
  - Ejemplo '+123' → 0b01111011 y -123 → 11111111-01111011 = 10000100
  - El código del valor negativo se puede calcular invirtiendo los bits del código del valor positivo
- El C1 de un número positivo es el código C1 de su valor en negativo y del de un número negativo es el código C1 de su valor en positivo
  - Dibujar la tabla y la rueda con todos los valores con sus representaciones.
  - ¿Cuantas representaciones son posibles? ¿Es simétrico el rango de valores representado? ¿Cuantas representaciones tiene el cero?
  - Extender el número de bits del número sin cambiar su valor

## Representación en complemento a la base 10 : C10

- Signo → un dígito
- Base 10: Complemento a 10 → C10
- Valores positivos: igual que los valores positivos en código Signo-Magnitud
- Valores negativos: Hay que restar el código del valor en positivo del minuendo 0000000 (base)
  - Ejemplo '+123' → 0123 y -123 → 0000-0123 = 9877
- El C10 de un número positivo es el código de su valor en negativo
- El C10 de un número negativo es el código de su valor en positivo

## Representación en complemento a la base 2 : C2

- Signo → un dígito
- Base 2: Complemento a 2 → C2
- Valores positivos: igual que los valores positivos en código Signo-Magnitud
- Valores negativos: Hay que restar el código del valor en positivo del minuendo 0000000 (base)
  - Ejemplo **+123** → 0b01111011 y **-123** → 00000000-01111011 = 0b100000101
  - El código del valor negativo se puede calcular invirtiendo los bits del código del valor positivo y después sumarle 1
    - Equivale a calcular el C1 y sumarle 1
  - El código del valor negativo se puede calcular a partir del código del valor positivo
    - empezando por la dcha repetir los bits hasta el primer uno e invertir el resto de bits

## Representación en complemento a la base 2 : C2

- El C2 de un número positivo es el código C2 de su valor en negativo
- El C2 de un número negativo es el código C2 de su valor en positivo
  - Dibujar la tabla y la rueda con todos los valores con sus representaciones.
  - ¿Cuántas representaciones son posibles? ¿Es simétrico el rango de valores representado? ¿Cuántas representaciones tiene el cero?
  - Extender el número de bits del número sin cambiar su valor → Extensión del bit de SIGNO

## Extensión del signo en C2

Table 4. Razonamiento de la extensión de signo de un número negativo: números de 3 bits

| Valor | C2 sin extensión                        | C2 con extensión                           |
|-------|-----------------------------------------|--------------------------------------------|
| +33   | 0100001                                 | 00100001                                   |
| -33   | 0000000<br>-0100001<br>-----<br>1011111 | 00000000<br>-00100001<br>-----<br>11011111 |
|       |                                         |                                            |

Se observa que en el C2 con extensión, al hacer la resta y extender con un 0 más el minuendo y el sustraendo, provoca la extensión con un bit más en la resta de valor 1 en el dígito más significante. Según añado ceros al minuendo y sustraendo, aparecen unos en la resta sin alterar su valor.

# Operaciones aritméticas en C2

- Suma
  - Se realiza como se ha visto para números naturales.
  - Si hay llevada en el MSBit, no se tiene en cuenta, se elimina.
  - $A=0b11011011$ . Suma  $A+A$

```
Llevadas -> 1 1   1 1   1 1  
  
          1 1 0 1 1 0 1 1 (Valor -37)  
          + 1 1 0 1 1 0 1 1 (Valor -37)  
  
Valor suma      2 1 3 2 1 3 2  
*****  
Resultado --> 1 0 1 1 0 1 1 0<--(Valor -74)
```

- Resta
  - La resta de números con signo se puede realizar de dos formas:  $A-B$  ó  $A-B = A+(-B)$
  - $A = 0b00110110$  y  $B = 0b10011011$
  - Si hay llevada en el MSBit, no se tiene en cuenta, se elimina.

```
Crédito    2 2   2 2   2 2  
  
          1 0 1 1 0 1 1 0<--(Valor -74)  
          - 1 1 0 1 1 0 1 1<--(Valor -37)  
  
LLevada 1 1 1   1 1   1 1  
*****  
Resta     1 1 0 1 1 0 1 1 (Valor -101)
```

## Operaciones aritméticas C2: Overflow o Desbordamiento

- A = 0b00110110 y B = 0b10011011 → Calcular A-B
- Con 8 bits el máximo valor es 01111111 de valor  $2^7 - 1 = 128 - 1 = 127$
- La resta A-(B)=A+(-B)=54+103=157>127 → **Overflow o Desbordamiento**

Crédito 2 2 2 2

$$\begin{array}{r} 0\ 0\ 1\ 1\ 0\ 1\ 1\ 0 \leftarrow (\text{Valor} = 54) \\ - 1\ 0\ 0\ 1\ 1\ 0\ 1\ 1 \leftarrow (\text{Valor} = -103) \\ \hline \end{array}$$

Llevada 1 1 1 1

\*\*\*\*\*

Resta 1 0 0 1 1 0 1 1 (Valor -101)

- El valor -101 en lugar de la resta correcta +157 es debido a que el resultado está fuera de rango →
- Observamos que hemos hecho la SUMA de dos números POSITIVOS y el resultado ha sido NEGATIVO

## Operaciones aritméticas C2: Overflow



Al realizar la suma de dos valores con el mismo signo si el resultado es de signo contrario hay overflow

## Operaciones aritméticas C2: Overflow

- Overflow: la operación requiere operandos con mayor número de bits manteniendo el valor para que el resultado sea correcto.
- Si dos operandos a sumar tienen diferente signo nunca hay overflow
- Si dos operandos a sumar tienen el mismo signo y resultado tiene signo contrario : **Error de Overflow**.
- Ejemplo:
  - Operandos de 1 byte :  $01111111+01111111=11111110 \rightarrow$  sumandos positivos y resultado negativo
    - Solución: **Extensión del signo** : Operandos 9 bits  $\rightarrow 001111111+001111111=011111110$
    - la repetición del bit más significativo no altera el valor de la representación
    - el bit más significativo es 0 si es positivo y 1 si es negativo. Por lo tanto, 01010 equivale a 01010 ó 001010 ó 0....0001010. Por lo tanto, 1010 equivale a 11010 ó 111010 ó 1....1111010

## C2: Representación gráfica del Overflow



Si a partir de la posición 010 nos movemos dos posiciones en sentido horario llegamos a la posición 100.  
Si a 010 le sumamos el valor 2 nos da como resultado 100  
Por lo tanto  $010+010=100$ , es decir,  $2+2=-4 \rightarrow \text{overflow}$  ya que el +4 necesita 4 bits y estamos trabajando con 3 bits únicamente.

## Asimetría del rango en C2: -4 con 3 bits

- Con números de 3 bits los formatos S-M y C1 son simétricos con valores en el rango (+3,-3), en cambio el formato C2 tiene el rango (+3,-4)
- En C2 el valor +4 se representa como 0b0100 y necesita por lo tanto 4 bits, no se puede representar con 3 bits, y el valor -4 se representa con el C2(0100), es decir, 1100 también con 4 bits. El 1100 se puede comprimir ya que tiene el signo extendido con la repetición de 1 de bit más significativo, por lo que la representación 100 es la representación del -4

## Complemento a 2 : Ejemplos

- 0b101010101 está en C2 → ¿Cuál es su valor?
  - como es negativo no es un sistema posicional
  - tenemos que calcular el valor negativo a través del valor positivo
  - La representación del valor positivo es el C2 del valor negativo
    - $C2(0b101010101) = 0b010101011$  cuyo valor es  $2^7 + 2^5 + 2^3 + 2^1 + 2^0 = 128 + 32 + 8 + 2 + 1 = +171$
    - El valor de 0b101010101 es -171
- Si la representación de -123 es 0b100000101 ¿cuál es la de '+123' ?
  - $C2(0b100000101) = 0b011111011$  representa el valor '+123'

## Aritmética Modular de valores representados en Complemento a 2



Representación de números binarios de 3 bits en C2  
Operaciones de suma y resta modular → método gráfico  
A partir de la posición 001 si nos movemos en sentido horario (SUMA modular) 2 posiciones obtenemos la posición 011, es decir,  $1+2=3$   
A partir de la posición 110 si nos movemos en sentido horario (SUMA modular) 9 posiciones obtenemos la posición 111, es decir,  $-2+9=-1$   
A partir de la posición 110 si nos movemos en sentido antihorario (RESTA modular) 4 posiciones obtenemos la posición 010, es decir,  $-2-4=+2$   
Los errores de **overflow** se resuelven aumentando el número de bits de la

representación, pero siempre existirá un rango que si lo traspasamos dará overflow.

# Comparación S-M, C1 y C2

Table 5. Números de 3 bits

| Valor | S-M | C1  | C2  |
|-------|-----|-----|-----|
| +3    | 011 | 011 | 011 |
| +2    | 010 | 010 | 010 |
| +1    | 001 | 001 | 001 |
| 0     | 000 | 000 | 000 |
|       | 100 | 011 | --- |
| -1    | 101 | 110 | 111 |
| -2    | 110 | 101 | 110 |
| -3    | 111 | 100 | 101 |
| -4    | -   | -   | 100 |

## Número en complemento a 2 y base hexadecimal



Un número binario se puede representar en hexadecimal y hacer la interpretación en complemento a 2. Hay que tener cuidado con las extensiones del signo

- Calcular el valor del número 0xAAA si dicho número tiene formato en complemento a 2
  - si lo convertimos a binario el número empieza por 1, luego es negativo
  - para saber su valor calculo su complementario C2 y tendré la representación del positivo
    - $0x000-0xAAA = 0x556 \rightarrow 5*16^2+5*16^1+5*16^0 = 5*256+5*16+5 = 1280+80+5 = '+213' \rightarrow 0xAAA$  tiene de valor -213

# Número en complemento a 2 y base hexadecimal

- Realizar la suma de los números en formato complemento a 2: 0x80+0x80
  - sumar sin extender el signo de los operandos ¿Hay overflow?



Extender el número 0x80. ¿ Por qué hay que tener cuidado ?

- sumar extendiendo un dígito el signo de los operandos 0x80

## Extensión del signo en C2: problema de la BASE

Table 6. Extensión del Signo del N° 0x80 en C2 en binario, hexadecimal y octal

| NºBits | Binario       | Hexadecimal                  | Octal                         |
|--------|---------------|------------------------------|-------------------------------|
| 8      | 10000000      | 1000_0000 → 0x80             | 110_000_000 → 0o600           |
| 9      | 110000000     | 1111_1000_0000 → 0xF80       | 110_000_000 → 0o600           |
| 10     | 1110000000    | 1111_1000_0000 → 0xF80       | 111_110_000_000 → 0o7600      |
| 11     | 11110000000   | 1111_1000_0000 → 0xF80       | 111_110_000_000 → 0x7600      |
| 12     | 111110000000  | 1111_1000_0000 → 0xF80       | 111_110_000_000 → 0x77600     |
| 13     | 1111110000000 | 1111_1111_1000_0000 → 0xFF80 | 111_111_110_000_000 → 0x77600 |

# Suma y Resta aritmética en C1

- Ejemplos con datos de 4 bits → Rango (-7,+7).
  - ¿Qué ocurre si **sumamos** dos números sin que haya overflow?.
  - Primer caso: dos operandos positivos  $0011+0011=0110 \rightarrow$  correcto.
  - Segundo caso: dos operandos negativos donde todas ellas tienen acarreo en el MSB
    - $1111+1111=1110 \rightarrow 0+0=-1$  ;  $1100+1100=1000 \rightarrow -3-3=-7$  ;  $1100+1011=0111 \rightarrow -3-3=+7$ .
    - el valor del resultado siempre da una **unidad menor** y siempre hay acarreo en el MSB.
    - Solución: la suma en C1 es la suma de los sumandos **más el acarreo MSB**.
    - $1111+1111=1110+1 \rightarrow 0$  ;  $1100+1100=1000+1 \rightarrow -6$  ;  $1100+1011=0111+1=1000 \rightarrow -7$ .
  - ¿Qué ocurre si **restamos** dos números?.
  - El resultado es correcto si no hay acarreo MSB.
  - Si hay acarreo la resta da una **unidad mayor**, por lo tanto el resultado es la resta **menos uno**.
  - El resultado es la resta **menos el acarreo MSB**.
- Caso de overflow: el resultado es incorrecto por limitación del tamaño de los datos

## Suma aritmética en C1



Figure 1. Razonamiento

Si nos fijamos en los números negativos su valor esta desplazado una unidad de la rueda hacia la izda: el valor cero está en la marca 1 de la rueda, el valor -1 está en la marca 2 de la rueda, etc. El valor representado por el segmento perimetral de la circunferencia tiene una unidad inferior: el valor -1 tiene un segmento de 2 marcas del 0 hacia la izda.

El segmento o distancia del cero (1111) es UNO, el del -1 es DOS, el del -2 es TRES.....

## Suma aritmética en C1



Figure 2. Ejemplos a completar para  $A=2$  y  $B=5$

## Suma y Resta aritmética en C1

- Ej\_1: suma: no hay conflicto  $\rightarrow 2+5=7 \rightarrow 0010+0101=0111$
- Ej\_2: suma: sí hay conflicto : el segmento B por ser negativo tiene un segmento superior en una unidad, por lo que a la suma hay que **sumarle 1**  $\rightarrow -2+(-5)=-7 \rightarrow 1101+1010=0111$  y acarreo\_MSB  $\rightarrow 0111+1=1000 \rightarrow -7$
- Ej\_3: suma
  - si la flecha B cruza el cero (1111), el segmento B, por ser negativa tiene un segmento mayor en 1, compensa el desplazamiento entre ceros y la suma es correcta.  $\rightarrow 2+(-5)=-3 \rightarrow 0010+1010=1100 \rightarrow -3$
  - si la flecha B no cruza el cero (1111), a la suma hay que **sumarle 1**
- Ej\_4: resta
  - si la flecha B cruza el cero (1111), B por ser positivo no compensa el desplazamiento entre ceros. A la resta hay que **restarle 1**  $\rightarrow 2-(+5)=-3 \rightarrow 0010-0101=1101$  y acarreo\_MSB  $\rightarrow 1101-1=1100 \rightarrow -3$
- Ej\_5: resta: no cruza el cero (1111), B por ser negativo tiene un segmento mayor en 1. A la resta hay que **restarle 1**  $\rightarrow 2-(-5)=+7 \rightarrow 0010-1010=1000$  y acarreo\_MSB  $\rightarrow 1000-1=0111 \rightarrow +7$

# Números Reales Binarios

- Coma Fija
  - 123.125 → b1111011.001
- Coma flotante
  - Notación científica: potencias en la base del sistema (decimal, binario, etc)
  - En decimal →  $1.23125 \times 10^2$
  - En binario →  $1.111011001 \times 2^6$ 
    - el factor que no es potencia se denomina mantisa
    - Se dice que el número real en binario y en notación científica está normalizado si la parte entera de la mantisa vale 1.

## Números Reales Binarios: Norma IEEE-754

- Campos del formato en notación científica : Signo, parte entera de la mantisa, parte fracción de la mantisa, base , exponente (módulo y signo)
- ¿Es necesario representar los **seis** campos del formato de la notación científica?
  - Si esta normalizado la parte entera de la mantisa siempre vale 1
  - La base del factor potencia siempre vale 2
  - Por lo tanto la parte entera y la base no son necesario representarlas. Son implícitas a la representación.
  - Hay una forma de no tener que representar el signo del exponente del factor potencia
    - es sumarle una cantidad para que al representarlo en EXCESO siempre sea positivo
- Resumiendo, sólo es necesario representar: el signo del número , la fracción de la mantisa y el exponente en exceso. Por lo tanto el formato IEEE-754 tiene 3 campos.

## Formato IEEE-754 simple

- representación de 32 bits: 1 bit para el signo / 8 bits para el exponente en exceso a 127 / 23 bits para la fracción
- bit de signo: 0 si es positivo y 1 si es negativo



## Formato IEEE-754 doble

- representación de 64 bits: 1 bit para el signo / 11 bits para el exponente en exceso a 1023 / 52 bits para la fracción
- bit de signo: 0 si es positivo y 1 si es negativo



# El Nº -5.5/1024 en los dos Formatos IEEE-754

- Signo negativo
- Conversión binaria del módulo
  - módulo:  $5.5/1024 = 5.5 \cdot 2^{-10} = 101.1 \cdot 2^{-10}$
  - Normalización de la mantisa →  $1.011 \cdot 2^8$
- Formato Simple de 32 bits
  - Signo negativo: bit 1
  - Exponente en exceso  $127 = -8 + 127 = 119 = 01110111$
  - Fracción de la mantisa=011
  - Solución:
    - 1\_01110111\_01100000000000000000000000
    - 0b10111011101100000000000000000000
    - **0xBBB00000**
    - [calculador ieee](http://weitz.de/ieee/) [<http://weitz.de/ieee/>]
- Formato Doble de 64 bits
  - Signo negativo: bit 1
  - Exponente en exceso  $1023 = -8 + 1023 = 1015 = 0111110111$
  - Fracción de la mantisa=011
  - Solución:
    - 1\_0111110111\_0110...0
    - 0b101111101110110...0
    - **0xBF76000000000000**

# Representación de los Caracteres

# Representación de los Caracteres

- Tipos de Caracteres:
  - Alfanuméricos: a,b,...z.0,1,...9,A,B...Z
  - Signos de Puntuación: !"#\$%&/()=
  - de Control: Salto de Línea (\n), Fin de Fichero (EOF), Fin de String (\00, ...)
- Formatos
  - ASCII: standard y extendido
  - Unicode: UTF-8

## ASCII Standard

| 2  | 3  | 4 | 5 | 6 | 7 | 30  | 40 | 50 | 60 | 70 | 80 | 90 | 100 | 110 | 120 |
|----|----|---|---|---|---|-----|----|----|----|----|----|----|-----|-----|-----|
| 0: | 0  | @ | P | ` | p | 0:  | (  | 2  | <  | F  | P  | Z  | d   | n   | x   |
| 1: | !  | 1 | A | Q | a | q   | )  | 3  | =  | G  | Q  | [  | e   | o   | y   |
| 2: | "  | 2 | B | R | b | r   | *  | 4  | >  | H  | R  | \  | f   | p   | z   |
| 3: | #  | 3 | C | S | c | s   | !  | 5  | ?  | I  | S  | ]  | g   | q   | {   |
| 4: | \$ | 4 | D | T | d | t   | :  | 6  | @  | J  | T  | ^  | h   | r   |     |
| 5: | %  | 5 | E | U | e | u   | #  | -  | 7  | A  | K  | U  | _   | i   | s   |
| 6: | &  | 6 | F | V | f | v   | :  | 8  | B  | L  | V  | `  | j   | t   | ~   |
| 7: | '  | 7 | G | W | g | w   | %  | /  | 9  | C  | M  | W  | a   | k   | u   |
| 8: | (  | 8 | H | X | h | x   | &  | 0  | :  | D  | N  | X  | b   | l   | DEL |
| 9: | )  | 9 | I | Y | i | y   | :  | 1  | ;  | E  | O  | Y  | c   | m   | w   |
| A: | *  | : | J | Z | j | z   |    |    |    |    |    |    |     |     |     |
| B: | +  | ; | K | [ | k | {   |    |    |    |    |    |    |     |     |     |
| C: | ,  | < | L | \ | l |     |    |    |    |    |    |    |     |     |     |
| D: | -  | = | M | ] | m | }   |    |    |    |    |    |    |     |     |     |
| E: | .  | > | N | ^ | n | ~   |    |    |    |    |    |    |     |     |     |
| F: | /  | ? | O | _ | o | DEL |    |    |    |    |    |    |     |     |     |

American Standard Code for Information Interchange

Alfabeto anglosajón

7 bits →  $2^7 = 128$  caracteres : 0x00 hasta 0x1F son 32 caracteres de control y el resto alfanuméricos

En hexadecimal rango [0x00-0x7F]

En decimal rango [0-127]

Upna : 0x55706E61

año 2023: 0x61—6F2032303233

## ASCII Extendido

- Para poder representar caracteres de otras culturas Europeas es necesario expandir el standard con 1 bit más
- ASCII 8 bits →  $2^8 = 256$  caracteres
- [Python Interpreter Shell](https://www.programiz.com/python-programming/online-compiler/) [https://www.programiz.com/python-programming/online-compiler/]

```
ord('A')
hex(ord('A'))
hex(ord('\n'))
chr(65)
chr(0x41)
[hex(ord(c)) for c in "Hola"]
[chr(c) for c in [0x48, 0x6f, 0x6c, 0x61, 0x20, 0x4d, 0x75, 0x6e, 0x64, 0x6f]]
[hex(ord(c)) for c in "ñ"]
[hex(ord(c)) for c in "\n \t"]
```

- La ñ tiene el código ASCII 0xF1

## UTF-8

- [Character Set, HTML Converter, etc ...](https://www.charset.org/utf-8) [https://www.charset.org/utf-8]
- Unicode Transformation Format (UTF)
- UTF-8: Esta orientado a la transmisión de palabras de 1 byte
- Los caracteres pueden tener entre 1 y 4 bytes →  $2^{21}$  code points ≈ 2 millones;
- The dominant encoding on the World Wide Web and on most Unix-like operating systems
- En linux comando **localectl status** : informa sobre el sistema del teclado
- ñ:
  - hex code 0xC3B1
  - unicode point U+00F1 → los primeros 256 caracteres equivalen al ascii extendido

## Unicode Points

- [html css js online](#) [<https://html-css-js.com/>]: &#x00f1;
- U+2228: ✓
- U+22bc: ✕
- U+22bd: ✖
- U+22a6: ✊
- U+1f60b: 🤝
- U+00f1: ñ
- OrduU+00F1a: Orduña
- U+2190: ←
- U+2192: →

## Tema 2: Ejercicios

- Miaulario/Recursos/Ejercicios
- Fundamentos de sistemas digitales Thomas Floyd

# **Tema 3 : Algebra de Conmutación ó Boole. Funciones Lógicas.**

# Matemática Lógica Binaria

- Valores Lógicos Binarios : "0" , "1"
  - representa dos estados: los estados de una señal binaria (High/Low), los estados de una bombilla (encendido/apagado), de un interruptor (on/off), de una condición (verdadero/falso), etc, cualquier situación que se pueda modelar mediante dos estados.
- Variables lógicas: ...u, x1, x2, y, v1, u2, ...
  - Una variable independiente que puede tomar los valores "0" y "1"
- Función lógica: z1, z2, z3, F, ....
  - Una función lógica expresa una relación lógica o/y aritmética o/y comparativa o/y etc entre las variables independientes a través de unos operadores matemáticos.
- Operadores
  - Operadores aritméticos: suma, resta, multiplicación, ...
  - Operadores lógicos: or (suma), and (producto), negación, or exclusiva, etc...
  - Operadores comparadores: > , >, ==, etc

# Tablas de la Verdad de los operadores NOT, OR, AND, XOR

Table 7. NOT

| x | $z = \bar{x}$ |
|---|---------------|
| 0 | 1             |
| 1 | 0             |

Table 8. OR

| x | y | $z = x + y$ |
|---|---|-------------|
| 0 | 0 | 0           |
| 0 | 1 | 1           |
| 1 | 0 | 1           |
| 1 | 1 | 1           |

Table 9. AND

| x | y | $z = x \cdot y$ |
|---|---|-----------------|
| 0 | 0 | 0               |
| 0 | 1 | 0               |
| 1 | 0 | 0               |
| 1 | 1 | 1               |

Table 10. XOR

| x | y | $z = x \oplus y$ |
|---|---|------------------|
| 0 | 0 | 0                |
| 0 | 1 | 1                |
| 1 | 0 | 1                |
| 1 | 1 | 0                |

# Tablas de la Verdad de los operadores NOR, NAND, XNOR

Table 11. NOR

| x | y | $z = x + y$ |
|---|---|-------------|
| 0 | 0 | 1           |
| 0 | 1 | 0           |
| 1 | 0 | 0           |
| 1 | 1 | 0           |

Table 12. NAND

| x | y | $z = x \cdot y$ |
|---|---|-----------------|
| 0 | 0 | 1               |
| 0 | 1 | 1               |
| 1 | 0 | 1               |
| 1 | 1 | 0               |

Table 13. XNOR

| x | y | $z = x \oplus y$ |
|---|---|------------------|
| 0 | 0 | 1                |
| 0 | 1 | 0                |
| 1 | 0 | 0                |
| 1 | 1 | 1                |

# Puertas Lógicas



# Circuitos Digitales : Expresiones Lógicas

$$F(x,y) = \bar{x}y + x\bar{y}$$

$$F(x,y,z) = \overline{\bar{x}yz} + xy\bar{z} + \bar{x}yz + xy\bar{z}$$

Circuito digital en 3 niveles: not-and-or.



# Transparencias PDF: Miaulario/Recursos/Apuntes

- Postulados del Algebra de Boole
- Teoremas del Algebra de Boole (Leyes de Morgan)
- $(a*b)+(c*d); a+a*b$
- Generación de funciones con puertas lógicas: Ejemplo 1 a) y b)
- Simplificación de funciones mediante Teoremas: Al final
- Formas canónicas: Sum of Products (SOP) y Product of Sums (POS)
  - minitérminos y maxitérminos
  - Ejemplos básicos
- Diagramas de Karnaugh (DK)
  - Agrupar celdas adyacentes en potencias de  $2^n$
  - Ejemplos básicos
- Relación SOP-POS
  - ejemplo1:  $a+ab$
  - ejemplo2: general 3 variables x,y,z
- Simplificación de funciones mediante Teoremas
  - Extender los términos como minitérminos
  - Dibujar DK y agrupar celdas equivale a sacar factor común

## Link: álgebra de conmutación funciones.pdf

- [Algebra de Boole. Funciones Lógicas](#) [./PDF/03\_algebra\_de\_commutacion\_funciones\_logicas.pdf]

# Generación de Funciones mediante puertas Lógicas NAND



$$= X_1 + \overline{X_1} \cdot \overline{X_2} \cdot \overline{X_3} =$$



# Formas Canónicas de una Función: Síntesis por minitérminos y maxitérminos

- Hay dos formas canónicas (standard) de expresar una función
  - suma de productos (SOP) de variables
  - producto de sumas (POS) de variables

# Lógica Positiva/Negativa: Relación y/o con \*/+

- Lógica positiva → ¿Cuando vale **1** una función, una expresión, una variable, etc ?
- Lógica negativa → ¿Cuando vale **0** una función, una expresión, una variable, etc ?

Table 14. OR

| x | y | $Z = x + y$ |
|---|---|-------------|
| 0 | 0 | 0           |
| 0 | 1 | 1           |
| 1 | 0 | 1           |
| 1 | 1 | 1           |

$Z = 0$  si "X" e "Y" valen 0 →  $z = (x+y)$

$Z = 1$  si "X" o "Y" valen 1 →  $z = (x+y)$

Table 15. AND

| x | y | $Z = x \cdot y$ |
|---|---|-----------------|
| 0 | 0 | 0               |
| 0 | 1 | 0               |
| 1 | 0 | 0               |
| 1 | 1 | 1               |

$Z = 0$  si "X" o "Y" valen 0 →  $(z=x \cdot y)$

$Z = 1$  si "X" e "Y" valen 1 →  $(z=x \cdot y)$

# Forma Canónica SOP: Suma de Minitérminos

Table 16. Tabla de la Verdad de la Función  $F(x_1, x_2, x_3)$

| x1 | x2 | x3 | F | minitérminos                          |
|----|----|----|---|---------------------------------------|
| 0  | 0  | 0  | 0 | $m_0 : \bar{x}_1 \bar{x}_2 \bar{x}_3$ |
| 0  | 0  | 1  | 0 | $m_1 : \bar{x}_1 \bar{x}_2 x_3$       |
| 0  | 1  | 0  | 0 | $m_2 : \bar{x}_1 x_2 \bar{x}_3$       |
| 0  | 1  | 1  | 1 | $m_3 : \bar{x}_1 x_2 x_3$             |
| 1  | 0  | 0  | 1 | $m_4 : x_1 \bar{x}_2 \bar{x}_3$       |
| 1  | 0  | 1  | 1 | $m_5 : x_1 \bar{x}_2 x_3$             |
| 1  | 1  | 0  | 0 | $m_6 : x_1 x_2 \bar{x}_3$             |
| 1  | 1  | 1  | 0 | $m_7 : x_1 x_2 x_3$                   |

Lenguaje natural → F vale **1** (lógica positiva) si  $m_3 \circ m_4 \circ m_5$  vale **1** → **suma**

Lenguaje natural →  $m_3$  vale **1** (lógica positiva) si  $\bar{x}_1$  y  $x_2$  y  $x_3$  valen **1** → **multiplicación**

Lenguaje lógico →  $F = \text{SOP} = m_3 + m_4 + m_5$ .

$$F(x_1, x_2, x_3) = \bar{x}_1 x_2 x_3 + x_1 \bar{x}_2 x_3 + x_1 x_2 \bar{x}_3.$$

Cada minitermino se sintetiza mediante una puerta AND.

La síntesis de la función F tendría un nivel de puertas AND de 3 entradas y un nivel con una puerta OR con tantas entradas como minitérminos hacen 1 a la función.

# Forma Canónica POS: Producto de Maxiterminos

Table 17. Tabla de la Verdad de la Función  $F(x_1, x_2, x_3)$

| x1 | x2 | x3 | F | maxitérminos                         |
|----|----|----|---|--------------------------------------|
| 0  | 0  | 0  | 0 | M0 : $x_1+x_2+x_3$                   |
| 0  | 0  | 1  | 0 | M1 : $x_1+x_2+\bar{x}_3$             |
| 0  | 1  | 0  | 0 | M2 : $x_1+\bar{x}_2+x_3$             |
| 0  | 1  | 1  | 1 | M3 : $x_1+\bar{x}_2+\bar{x}_3$       |
| 1  | 0  | 0  | 1 | M4 : $\bar{x}_1+x_2+x_3$             |
| 1  | 0  | 1  | 1 | M5 : $\bar{x}_1+x_2+\bar{x}_3$       |
| 1  | 1  | 0  | 0 | M6 : $\bar{x}_1+\bar{x}_2+x_3$       |
| 1  | 1  | 1  | 0 | M7 : $\bar{x}_1+\bar{x}_2+\bar{x}_3$ |

Lenguaje natural → F vale **0** (lógica negativa) si M0 ó M1 ó M2 ó M6 ó M7 vale **0** → multiplicación

Lenguaje natural → M1 vale **0** (lógica negativa) si  $x_1$  y  $x_2$  y  $\bar{x}_3$  valen **0** → suma

Lenguaje lógico → F = POS = M0M1M2M6M7.

$$F(x_1, x_2, x_3) = (x_1+x_2+x_3)(x_1+x_2+\bar{x}_3)(x_1+\bar{x}_2+x_3)(\bar{x}_1+\bar{x}_2+x_3)(\bar{x}_1+\bar{x}_2+\bar{x}_3).$$

Cada maxitérmino se sintetiza mediante una puerta OR.

La síntesis función F tendría un nivel de puertas OR de 3 entradas y un nivel con una puerta AND con tantas entradas como maxitérminos hacen 0 a la función.

## Relación entre la forma canónica SOP y POS

- Ejemplo  $F = F(x_1, x_2, x_3) = m_3 + m_4 + m_5$
- $F = m_0 + m_1 + m_2 + m_6 + m_7$
- $F = m_0 + m_1 + m_2 + m_6 + m_7 =$
- $F = \bar{m}_0 \cdot \bar{m}_1 \cdot \bar{m}_2 \cdot \bar{m}_6 \cdot \bar{m}_7$
- $F = M_0 \cdot M_1 \cdot M_2 \cdot M_6 \cdot M_7 = F$

# Simplificación de las funciones mediante los Diagramas de Karnaugh (DK)

- El Diagrama de Karnaugh es una representación gráfica multidimensional (2D, 3D, etc) mediante celdas de los minitérminos y maxitérminos de la tabla de la verdad unidimensional 1D
- Ejemplo  $F(x_1, x_2, x_3) = \bar{x}_1 x_2 x_3 + x_1 \bar{x}_2 \bar{x}_3 + x_1 \bar{x}_2 x_3$ .
  - los minitérminos y maxitérminos siguen la secuencia unidimensional 000-001-010-011-100-101-110-111
  - Los reorganizamos en una matriz de celdas **adyacentes**, donde dos celdas adyacentes tienen todas las variables comunes **excepto una**
- **Simplificación:**
  - Agrupar celdas adyacentes en grupos de un número de celdas potencia de dos  $\rightarrow 2^n : 2, 4, 8, \text{etc} \dots$
  - Cuanto mayor sea el número de celdas agrupadas mayor será el número de variables y términos simplificados.

## Diagrama de Karnaugh de la función $F(x_1, x_2, x_3)$

celdas adyacentes: todas las variables comunes menos una.

|          |    |    |    |    |
|----------|----|----|----|----|
| $x_1x_2$ | 00 | 01 | 11 | 10 |
| $x_3$    | 0  | 0  | 0  | 1  |
|          | 1  | 0  | 1  | 0  |

miniter/maxiter adyacentes: todas las variables comunes menos una

|          |    |           |           |           |           |
|----------|----|-----------|-----------|-----------|-----------|
| $x_1x_2$ | 00 | 01        | 11        | 10        |           |
| $x_3$    | 0  | $m_0/M_0$ | $m_2/M_2$ | $m_6/M_6$ | $m_4/M_4$ |
|          | 1  | $m_1/M_1$ | $m_3/M_3$ | $m_7/M_7$ | $m_5/M_5$ |

- Son adyacentes las celdas de la misma columna o de la misma fila con todas las variables comunes **menos una**. Por eso la tercera columna ha de ser 11
- Observar que cada celda equivale a un minitérmino y un maxitérmino de la Tabla de la verdad
- Por lo tanto, el diagrama DK representa las formas canónicas SOP y POS.

## Simplificación de la Función mediante DK

celdas adyacentes: todas las variables comunes menos una.

|          |    |    |    |    |
|----------|----|----|----|----|
| $x_1x_2$ | 00 | 01 | 11 | 10 |
| $x_3$    | 0  | 0  | 0  | 1  |
| 1        | 0  | 1  | 0  | 1  |

miniter/maxiter adyacentes: todas las variables comunes menos una

|          |           |           |           |           |
|----------|-----------|-----------|-----------|-----------|
| $x_1x_2$ | 00        | 01        | 11        | 10        |
| $x_3$    | $m_0/M_0$ | $m_2/M_2$ | $m_6/M_6$ | $m_4/M_4$ |
| 1        | $m_1/M_1$ | $m_3/M_3$ | $m_7/M_7$ | $m_5/M_5$ |

Si sumamos los miniterminos de la 4<sup>a</sup> columna  $Y = f(x_1, x_2, x_3) = m_4 + m_5 = x_1\bar{x}_2\bar{x}_3 + x_1\bar{x}_2x_3 = x_1\bar{x}_2(\bar{x}_3 + x_3) = x_1\bar{x}_2$ , se ha simplificado el número de variables de 3 a dos. La función simplificada es  $Y = \bar{x}_1x_2x_3 + x_1\bar{x}_2$ . Sumar dos miniterminos adyacentes equivale a agrupar dos celdas adyacentes y reducir una variable.

# Ejercicios básicos matemáticos en el dominio del Algebra de Boole

- $x * 0 = 0; x * 1 = x ; x * \bar{x} = 0 ; x + \bar{x} = 1$
- $x = x * 1 = x * (y + \bar{y}) ; x = x + 0 = x + y * \bar{y}$
- $x \cdot (x + u + v + ...) = x ; x + (x \cdot u \cdot v \cdot ...) = x$
- Transformar una suma de productos de variables lógicas en producto de sumas de variables lógicas
  - $F = y\bar{z} + x\bar{y} + x\bar{y}z$
  - cambio de nomenclatura para facilitar la explicación  $F = a_1a_2 + b_1b_2 + c_1c_2c_3$

# Ejercicios básicos matemáticos en el dominio del Algebra de Boole



$$F = a_1 a_2 + b_1 b_2 + c_1 c_2 c_3 = (a_1 + b_1 + c_1)(a_1 + b_1 + c_2)(a_1 + b_1 + c_3) \cdot \\ \cdot (a_1 + b_2 + c_1)(a_1 + b_2 + c_2)(a_1 + b_2 + c_3) \cdot \\ \cdot (a_2 + b_1 + c_1)(a_2 + b_1 + c_2)(a_2 + b_1 + c_3) \cdot \\ \cdot (a_2 + b_2 + c_1)(a_2 + b_2 + c_2)(a_2 + b_2 + c_3)$$

$$F = y\bar{z} + x\bar{y} + x\bar{y}z = (y + x + x)(y + x + \bar{y})(y + x + z) \cdot \\ \cdot (y + \bar{y} + x)(y + \bar{y} + \bar{y})(y + \bar{y} + z) \cdot \\ \cdot (\bar{z} + x + x)(\bar{z} + x + \bar{y})(\bar{z} + x + z) \cdot \\ \cdot (\bar{z} + \bar{y} + x)(\bar{z} + \bar{y} + \bar{y})(\bar{z} + \bar{y} + z)$$

# Ejercicios básicos matemáticos en el dominio del Algebra de Boole

Simplificación

$$\begin{aligned}F &= (y + x)(1)(y + x + z)(1)(1)(1)(\bar{z} + x)(\bar{z} + x + \bar{y})(1)(\bar{z} + \bar{y} + x)(\bar{z} + \bar{y})(1) = \\&= (y + x)(y + x + z)(\bar{z} + x)(\bar{z} + x + \bar{y})(\bar{z} + \bar{y} + x)(\bar{z} + \bar{y})\end{aligned}$$

POS → Expansión para que tenga cada término las 3 variables

$$F = (y + x + z\bar{z})(y + x + z)(\bar{z} + x + y\bar{y})(\bar{z} + x + \bar{y})(\bar{z} + \bar{y} + x)(\bar{z} + \bar{y} + x\bar{x})$$

Aplico la propiedad Distributiva a cada término

$$\begin{aligned}F &= (y + x + z)(y + x + \bar{z})(y + x + z)(\bar{z} + x + y)(\bar{z} + x + \bar{y})(\bar{z} + x + \bar{y}) \cdot \\&\quad (\bar{z} + \bar{y} + x)(\bar{z} + \bar{y} + x)(\bar{z} + \bar{y} + \bar{x}) = (y + x + z)(y + x + \bar{z})(\bar{z} + x + \bar{y})(\bar{z} + \bar{y} + \bar{x}) = \\&= (x + y + z)(x + y + \bar{z})(x + \bar{y} + \bar{z})(\bar{x} + \bar{y} + \bar{z}) = M_0M_1M_3M_7\end{aligned}$$

## Ejercicios básicos matemáticos en el dominio del Algebra de Boole

- F en la 1<sup>a</sup> forma canónica
- $F = y\bar{z} + x\bar{y} + x\bar{y}z = y\bar{z} \cdot (x + \bar{x}) + x\bar{y} \cdot (z + \bar{z}) + x\bar{y}z = y\bar{z}x + y\bar{z} \cdot \bar{x} + x\bar{y}z + x\bar{y}\bar{z} + x\bar{y}z = xy\bar{z} + \bar{x}y\bar{z} + x\bar{y}z + x\bar{y}\bar{z} = m_6 + m_2 + m_5 + m_4$

## Nominación Teoremas

- commutativa  $a \cdot b =$
- idempotencia  $a + a =$
- identidad  $a \cdot 1 =$
- complementario  $a + \bar{a} =$
- absorción  $a + ab =$
- distributiva  $ab + cd =$
- $a+1$
- $a^*0$

# Simplificación de funciones mediante axiomas y teoremas del Algebra de Boole



celdas adyacentes equivale a minitérminos con factores comunes, que pueden ser agrupados y simplificados.

- Ejemplo 1:  $Y=f(x_1,x_2,x_3)=\bar{x}_1\bar{x}_2\bar{x}_3 + \bar{x}_1\bar{x}_2x_3 + x_1\bar{x}_2\bar{x}_3 + x_1\bar{x}_2x_3 + x_1x_2\bar{x}_3 + x_1x_2x_3$
- Dibujar la TV y el DK de la función Y
- Simplificar la función Y mediante el agrupamiento de celdas en el DK
- Partiendo del agrupamiento DK razonar la simplificación de la función Y mediante los **axiomas y teoremas del algebra de Boole**.

# Simplificación de funciones mediante el Diagrama de Karnaugh

- Agrupar celdas adyacentes en grupos de un número de celdas  $2^n$  : 2, 4, 8, etc ...
- Cuanto mayor sea el número de celdas agrupadas mayor será el número de variables y términos simplificados.
- $y = f(x_1, x_2, x_3, x_4) = \bar{x}_1\bar{x}_2\bar{x}_3 + \bar{x}_1\bar{x}_2x_3 + \dots$
- $y = f(x_1, x_2, x_3, x_4) = \sum(m_0 + m_1 + m_3 + m_4 + m_5 + m_7 + m_9 + m_{11} + m_{13} + m_{14} + m_{15})$
- $y = f(x_1, x_2, x_3, x_4) = \sum(0, 1, 3, 4, 5, 7, 9, 11, 13, 14, 15)$
- Simplificar la función "y" tanto simplificando la forma SOP como simplificando la forma POS y dibujar el resultado de la síntesis.

# Ejercicios matemáticos en dos dominios Gráfico/Algebra de Boole

- $F = f(x_1, x_2) = x_1 = x_1 + x_2\bar{x}_2$ 
  - obtener la forma canónica SOP y POS mediante TV y DK
  - obtener la forma canónica SOP analíticamente: propiedad identidad
  - obtener la forma canónica POS analíticamente: propiedad distributiva
  - convertir la forma canónica POS a SOP mediante la equivalencia entre minitérminos y máxitérminos
  - convertir la forma canónica POS a SOP analíticamente
- $F = f(x_1, x_2, x_3) = x_1\bar{x}_2x_3 + x_1x_2\bar{x}_3 + x_2x_3$ 
  - obtener analíticamente la forma canónica SOP
    - primero expandir por la propiedad distributiva
    - simplificar cada factor
    - simplificar factores repetidos
    - extender cada factor para que tenga las 3 variables
    - aplicar la propiedad distributiva

# Cuaderno de Ejercicios: Capítulo 1

- 1.1, 1.2, 1.4, 1.5, 1.6, 1.8, 1.9
- Metodología: antes de comenzar a resolver el ejercicio hay que describir el método a seguir para resolver el ejercicio.

# Planteamiento de los Ejercicios Capítulo 1

- Ejercicio 1.1
  - Resolverlo primero por DK
  - asociar DK con álgebra de Boole
  - SOP, POS, factor común, ordenar, simplificar
- Ejercicio 1.2
  - Análisis, TV (combinaciones repeticiones)
  - variable indiferente → valor X
  - variable nula → TV y DK reducidas
- Ejercicio 1.3
  - lenguaje natural → lenguaje lógico
  - $F = SOP$
  - lógica positiva ( $o/y \rightarrow */+$ ) →  $F=1$  si ...
  - lógica negativa ( $o/y \rightarrow */+$ ) →  $F=0$  si ...
    - deducir máxiterminos y miniterminos
  - $F=X$  si ...
    - Función: valor no definido: X
    - DK : definición libre para simplificar: 0 ó 1

# Planteamiento de los Ejercicios Capítulo 1

- Ejercicio 1.4
  - Resolverlo por DK
    - Formato ajedrez → Factor Común → XOR
- Ejercicio 1.5
  - lenguaje natural → lenguaje lógico
  - lógica positiva - lógica negativa
    - o/y → \*/+
  - Condiciones → miniterminos o maxiterminos

# Planteamiento de los Ejercicios Capítulo 1

- Ejercicio 1.6
  - lenguaje natural → lenguaje lógico
  - lógica positiva - lógica negativa
    - o/y → \*/+
  - Condiciones → miniterminos o maxiterminos
- Ejercicio 1.8
  - Escenificación → Diferentes Casos
    - Entro al pasillo por la izda y salgo por la dcha
    - Entro al pasillo por la izda y salgo por la izda
- Ejercicio 1.9
  - Señal binaria: Relación de aspecto
    - Período: Duración nivel alto respecto nivel bajo
  - Módulos o subcircuitos:
    - Anidamiento de funciones → subfunciones

## Binary Coded Decimal (BCD)

- El código binario BCD codifica, cada dígito decimal de un número, de forma directa con 4 bits para cada dígito decimal.
- Ejemplos
  - $23 \rightarrow 0010\ 0011$
  - $87045 \rightarrow 1000\ 0111\ 0000\ 0100\ 0101$
- Diseñar un circuito digital simplificado que decodifique el código binario BCD en uno de los diez dígitos:  $0, 1, \dots, 9$



- códigos y dígitos

| Código | Dígito Decimal |
|--------|----------------|
| 0000   | 0              |
| 0001   | 1              |
| 0010   | 2              |
| 0011   | 3              |
| 0100   | 4              |

- códigos y dígitos

| Código | Dígito Decimal |
|--------|----------------|
| 0101   | 5              |
| 0110   | 6              |
| 0111   | 7              |
| 1000   | 8              |
| 1001   | 9              |

- códigos y dígitos

| Código | Dígito Decimal |
|--------|----------------|
| 1010   | X              |
| 1011   | X              |
| 1100   | X              |
| 1101   | X              |
| 1101   | X              |

| Código | Dígito Decimal |
|--------|----------------|
| 1111   | X              |

# Tema 4: Lenguaje de Descripción Hardware VHDL

# Very high speed integrated circuits Hardware Description Language (VHDL)

- HDL: Hardware Description Languages
- NO son lenguajes de programación sino de **descripción de Hardware**. Es una lenguaje que está pensado para describir circuitos de la misma forma que otras formas de describir un circuito digital: mediante un esquema eléctrico, mediante una tabla de la verdad, mediante diagramas de secuencias de estados, etc ...
- También sirve para describir las formas de onda cuadradas de las señales binarias de entrada de un circuito digital
- ... y por supuesto también tiene sentencias y estructuras de programación que no describen circuitos digitales, por ejemplo imprimir en la pantalla una frase como "Hello World".

# Descripción del Hardware de un circuito digital.

```
-- Descripción VHDL Primavera 2023
-- Circuito light_bit.vhd:
-- Puerta lógica XOR extendida
entity light_bit is
  port (
    x,y : in bit;
    z   : out bit
  );
end entity;

architecture rtl of light_bit is
  signal s,t,u,v : bit;
begin
  s <= not x;
  t <= not y;
  u <= x and t;
  v <= y and s;
  z <= u or v;
end rtl;
```



Figure 3. Circuito light\_bit.vhd

# Cronogramas



## Señales VHDL :tipos

- Hay dos **tipos de señales** en el lenguaje vhdl:
  - PORT : x,y,z
    - son señales de acceso al circuito: su **modo** puede ser de entrada (IN) ó de salida (OUT)
    - una señal de entrada tipo IN no puede conectarse a la salida de una puerta lógica
    - una señal de salida tipo OUT no puede conectarse a la entrada de una puerta lógica
  - SIGNAL : s,t,u,v
    - son señales internas al circuito y son bidireccionales: pueden conectarse tanto a la entrada como a la salida de una puerta lógica

## Señales VHDL : tipos de datos

- hay diferentes **tipos de datos** para las señales
- tipo de dato bit único : BIT : admite únicamente dos valores: el ' 0 ' y el ' 1 '
- en VHDL los valores de los bits hay que entrecollarlos para diferenciarlos de los datos de tipo INTEGER
- tipo de dato secuencia de bits: " 010001010101 " → doble entrecollado si el dato se representa con más de un bit.

## Señales VHDL : Buses

- Físicamente un Bus es un conjunto de pistas metálicas que sirven para transportar señales conectando dos unidades
- Por ejemplo el "bus de direcciones" de 32 hilos ó pistas de la memoria RAM sirve para seleccionar una dirección de 32 bits de la memoria. La dirección **01100110011001100110011001100110** se transporta desde la CPU hasta la memoria RAM a través de un bus de 32 pistas. Al bus de direcciones de memoria (address bus) se le podría llamar **A** y a cada hilo del bus  $A_{31}, A_{30}, \dots, A_1, A_0$ .
- Desde el punto de vista lógico un bus es un vector o un array de dimensión "n", por ejemplo n=32.
- El tipo de datos de los buses **A** y **B** de 32 bits se podrían declarar como:
  - signal A,B :bit\_vector(31 downto 0); donde el bit MSB(más a la izquierda) sería el hilo  $A_{31}$  y el bit LSB(más a la derecha) el bit  $A_0$  y lo mismo con el bus B
  - signal A,B :bit\_vector(0 to 31); donde el bit MSB(más a la izquierda) sería el hilo  $A_0$  y el bit LSB(más a la derecha) el bit  $A_{31}$  y lo mismo con el bus B

## Sentencias VHDL : Asignación Concurrente

- CAS : Concurrent Assignment Sentence
- La sentencia CAS se representa mediante el símbolo  $\leftarrow$
- El valor resultante de **evaluar** la expresión a la derecha del símbolo  $\leftarrow$  se asigna a la señal a la izquierda del símbolo  $\leftarrow$

```
s <= not x;  
t <= not y;  
u <= x and t;  
v <= y and s;  
z <= u or v;
```

## Sentencias Concurrentes

Concepto de concurrencia: ¿ CUANDO se ejecuta una sentencia concurrente? cuando hay un **evento** en una de las **señales sensibles** de la sentencia. En el caso de la sentencia CAS la señales sensibles son las señales a la derecha del símbolo  $\Leftarrow$ .

Ejemplo:

```
s <= not x;  
t <= not y;  
u <= x and t;  
v <= y and s;  
z <= u or v;
```

Ejemplo: Ver cronograma

0- "x" = "y" = **0**  $\Rightarrow$  s = t = **1**  $\Rightarrow$  u = v = **0**  $\Rightarrow$  z = **0**

1- Se produce un **EVENTO (0→1)** en la señal puerto "x"

2- "x" es una señal sensible en la línea 1 del código

y en la línea 3 del código

3- Se ejecutan las líneas 1 y 3 del código

4- Ejecución de la línea 1: "s" (**1→0**)

5- Ejecución de la línea 3: "u" (**0→1**)

6- Hay un evento en "s": se ejecuta la línea 4 : "v" no cambia  $\rightarrow$  no evento

7- Hay un evento en "u": se ejecuta la línea 5 : "z" cambia (**0→1**)

8- La señal z no es una señal sensible en ninguna de las sentencias  $\Leftarrow$  : FIN

9- FIN de la actualización de todas las señales hasta el próximo evento en "x" o/y "y"

# Sentencias Concurrentes

Las sentencias concurrentes NO se ejecutan secuencialmente, sino **simultáneamente**, de la misma forma que en el circuito "**light\_bit.vhd**" la puerta lógica OR proceza sus dos entradas al mismo tiempo que las puertas NOT y AND del mismo circuito.

En los 4 ejemplos siguientes la actualización de los valores de todas las señales, ante el evento de una de ellas, da el MISMO resultado, ya que la ejecución no es secuencial, sino que se ejecutan UNICAMENTE las sentencias concurrentes cuyas señales sensibles varían; y las sentencias que se ejecutan lo hacen SIMULTANEAMENTE.

```
s <= not x;  
t <= not y;  
u <= x and t;  
v <= y and s;  
z <= u or v;
```

```
z <= u or v;  
v <= y and s;  
u <= x and t;  
t <= not y;  
s <= not x;
```

```
u <= x and t;  
v <= y and s;  
z <= u or v;  
s <= not x;  
t <= not y;
```

```
u <= x and t;  
t <= not y;  
s <= not x;  
z <= u or v;  
v <= y and s;
```

## Entidad

La **entidad** describe el comportamiento del circuito digital visto desde fuera, es decir, describe únicamente los accesos de entrada y salida del circuito. Los accesos de entrada y salida se realizan a través de señales digitales binarias denominadas **puertos**.

La entidad se define con el keyword ENTITY

La entidad que hay nominarla con un nombre. Este nombre condiciona el nombre del fichero donde se almacena, que ha de tener el mismo nombre con la extensión **.vhdl**

Las señales tipo PORT pueden ser de entrada (IN) ó salida (OUT) ó salida\_y\_entrada (BUFFER).

Además del **modo** de la señal (IN-OUT-BUFFER) es necesario declarar el tipo de los datos (BIT)



Las señales cuyos datos son de tipo BIT admiten los valores '0' y '1'

### Sintaxis

```
entity of light_bit is
  port (
    x,y : in bit;
    z    : out bit
  );
end entity;
```

# Arquitectura

REGISTER TRANSFER LEVEL  
RTL



BEHAVIORAL

Si  $x$  e  $y$  valen 0 entonces la salida vale 0... ó si las entradas valen 1 la salida vale 0.....

| x | y | $z=x \oplus y$ |
|---|---|----------------|
| 0 | 0 | 0              |
| 0 | 1 | 1              |
| 1 | 0 | 1              |
| 1 | 1 | 0              |

STRUCTURAL



SINTESIS



3 Tipos de arquitecturas:

RTL: Expresiones lógicas

Behavioral o comportamental: funcionalidad

Structural: conectar subcircuitos

La descripción más sencilla es la **behavioral** ... pero también es la que exige un mayor esfuerzo al sintetizador.

# Arquitectura

## *Sintaxis*

```
architecture rtl of light_bit is
    signal s,t,u,v : bit;
begin
    s <= not x;
    t <= not y;
    u <= x and t;
    v <= y and s;
    z <= u or v;
end rtl;
```

La arquitectura del circuito se declara con el keyword architecture

La arquitectura del circuito hay que nominarla con cualquier nombre: rtl, fun, etc... y relacionarla con una entidad

Las señales internas hay que declararlas con el keyword signal y definir el tipo de datos: pej bit

La relación entre las señales (puertos e internas) se define mediante "sentencias vhdl" entre los keywords begin y end

# **Hojas de Referencia**

[Hoja de referencia simple \[./PDF/VHDL\\_Cheat\\_Sheet.pdf\]](#)

[Hoja de referencia completa \[./PDF/VHDL\\_QRC\\_\\_01.pdf\]](#)

## Síntesis: Herramienta Quartus

The screenshot shows the Quartus Prime software interface. The menu bar includes File, Edit, View, Project, Assignments, Processing, Tools, Window, and Help. The toolbar has various icons for file operations like Open, Save, and Run. The Project Navigator shows a hierarchy with 'light\_bit' selected under 'Entity:Instance'. The main window displays the VHDL code for 'light\_bit.vhd'. The code defines an entity 'light\_bit' with a single input port 'SW' (bit vector from 1 downto 0) and one output port 'LEDR' (bit vector from 0 downto 0). It contains an architecture 'rtl' with four signals 's', 't', 'u', and 'v'. The logic is implemented using AND, OR, and NOT operations on these signals to map the input to the output.

```
library std; -- La librería std no es necesario declararla
use std.standard.all; -- Si no se declara la librería std, tampoco el paquete standard

ENTITY light_bit IS
PORT(SW : IN bit_vector (1 downto 0);
      LEDR : OUT bit_vector (0 downto 0));
END light_bit;

ARCHITECTURE rtl OF light_bit IS
signal s,t,u,v : bit;
BEGIN
  s <= NOT SW(0);
  t <= NOT SW(1);
  u <= SW(0) AND t;
  v <= SW(1) AND s;
  LEDR(0) <= u OR v;
END rtl ;
```

Entrada: código VHDL "light\_bit.vhd"



Salida: simulación y síntesis : bitstream "quartus\_light.sof"

# Simulación: Herramienta Modelsim/Questa



Verificar el correcto funcionamiento del circuito antes de su Fabricación

## Fabricación: FPGA Cyclone V de Intel

- Tarjeta de prototipado de Terasic **DE1 SoC**
- La tarjeta contiene la **FPGA Cyclone V** y sus periféricos
- El diseño "light\_bit" se implementa en el chip FPGA (**Field Programmable Gate Array**)

# Librerías y Paquetes

- Las definiciones de las sentencias, tipos de señales, tipos de datos, etc se encuentran definidas en las librerías.
- Por ejemplo el tipo de dato bit y bit\_vector se encuentran definidos en la librería std y en el paquete standard
- Las librerías y los paquetes hay que declararlos al principio, antes de las entidades y de las arquitecturas

La librería std **NO** es obligado declararla

```
library std;
use std.standard.all;
entity of light_bit is
  port (
    x,y : in bit;
    z    : out bit
  );
end entity;
architecture rtl of light_bit is
  signal s,t,u,v : bit;
begin
  s <= not x;
  t <= not y;
  u <= x and t;
  v <= y and s;
  z <= u or v;
end rtl;
```

# Primer Diseño

Descripción del circuito minimalista  **$z=x$**

```
entity of light_bit is
  port (
    x  : in bit;
    z  : out bit
  );
end entity;
architecture minima of light_bit is
begin
  z <= x;
end minima;
```

- El objetivo de este código es ser lo suficientemente simple para no dificultar su comprensión y centrarse en poner a punto la herramienta de desarrollo **Intel Quartus Prime Lite** desde cualquier computadora utilizando los recursos remotos de la UPNA.

## Primer Diseño

Para poder ser fabricado en el laboratorio Remoto, es necesario que los puertos tenga los mismos nombres que se utilizan en el servidor del laboratorio Remoto. En este ejemplo la entrada serán los switches SW y la salida los leds rojos LEDR.

```
entity of light_bit is
  port (
    SW   : in bit_vector (0 downto 0);
    LEDR  : out bit_vector (0 downto 0);
  );
end entity;
architecture minima of light_bit is
begin
  LEDR(0) <= SW(0);
end minima;
```

# Ejercicios Prácticos de Diseño de Circuitos

- Tutorial de VHDL mediante recursos Remotos: Quartus Prime Lite, Questa Intel, Laboratorio de dispositivos FPGA [vhdl\_lab\_remoto.html]
- La única forma de aprender un lenguaje de descripción de HW o de programación es practicando.
- La Upna brinda la posibilidad de utilizar los recursos EDA de diseño automático de circuitos integrados de forma remota, bien desde dentro del Campus Universitario o desde fuera de él, sin la necesidad de realizar ningún tipo de instalación en el portátil personal ni de acceder a ningún laboratorio.



En el escritorio virtual de la Upna al utilizar el programa Quartus no utilizar la carpeta de Descargas como ubicación del proyecto de diseño. Si se utiliza la carpeta Descargas es necesario utilizar un SUBDIRECTORIO como por ejemplo "Descargas\ssdd"

# Ejercicios Prácticos de Diseño de Circuitos

1. light\_bit: inicio
2. light\_de1soc: señales std\_logic y fabricación del diseño
3. light\_signal: ver el esquema del circuito sintetizado
4. light\_de1soc: simulación Questa
5. light\_csa: sentencia concurrente, Tabla de la Verdad
6. light\_process: sentencias secuenciales
7. light\_if: sentencia secuencial
8. light\_with: sentencia concurrente
9. light\_case: sentencia secuencial
10. light\_sum: librería ieee paquete numeric\_std

# Librerías y Paquetes

- Librerías: contienen paquetes que definen tipos de señales, tipos de datos, operadores, etc
- Librería std
  - Paquete standard → definición del tipo BIT, BIT\_VECTOR, etc
  - Paquete textio
  - no es necesario declararla
  - declaración

```
library std;
use std.standard.all;
```

- El paquete está descrito en el propio lenguaje VHDL → C:/intelFPGA\_lite/21.1/questa\_fse/vhdl\_src/std/standard.vhdl

## Señales std\_logic



Figure 4. Señales binarias distorsionadas

- 8 Umbrales para definir el valor de la señal binaria
- 6 tipos medibles: 1,H,W,X,L,0

## Señales std\_logic

|   |                            |
|---|----------------------------|
| 1 | : forzosamente un 1        |
| H | : débilmente un 1          |
| W | : débilmente desconocido   |
| X | : forzosamente desconocido |
| W |                            |
| L | : débilmente un 0          |
| 0 | : forzosamente un 0        |

Figure 5. Valores Medibles

8 umbrales

Valores No medibles:

- : don't care → puede tomar cualquiera de los valores definidos "mesurables" y no afecta al funcionamiento del circuito.

**U** : indefinido → representa el estado de un circuito secuencial al encenderse y sin estado de reset de reset. Puede ser cualquiera de los 6 valores definidos pero al no tener estado inicial, no puede determinarse su estado.

**Z**: alta impedancia : salida en circuito abierto

## Librería IEEE: Paquete std\_logic\_1164

- tipos de señales: std\_logic y std\_logic\_vector

```
library ieee;
use ieee.std_logic_1164.all;

ENTITY light_de1soc IS
PORT(SW : IN std_logic_vector (1 downto 0) ;
      LEDR : OUT std_logic);
END light_de1soc ;
```

- El paquete std\_logic\_1164 está localizado en:  
C:/intelFPGA\_lite/21.1/questa\_fse/vhdl\_src/ieee/stdlogic.vhdl

# Simulación y Fabricación

- Simulación
  - Simulador Questa
  - Simulador Waveform
- Fabricación: acceso a través de Miaulario : Pestaña **DE1-SoC→>>Remoto**

# Tema 5: Circuitos Aritméticos

# Índice

- [Tema4 Circuitos Aritméticos \[PDF/04\\_circuitos\\_aritmeticos.pdf\]: PDF](#)
- Operaciones Aritméticas: Suma, Resta, Complemento C1-C2, Multiplicación
- Circuitos sumadores
- Circuitos restadores
- Circuitos sumador/restador
- Circuito Multiplicador
- Unidad Aritmetico-Lógica (ALU)

# Operaciones Aritméticas

- Suma y Resta : binario, hexadecimal y números enteros C1-C2
- Multiplicación

$$\begin{array}{r} 101101 \quad \rightarrow 45 \\ \times 101101 \quad \rightarrow 45 \\ \hline 101101 \\ 000000 \\ 101101 \\ 101101 \\ 000000 \\ 101101 \\ \text{Llevadas} \quad -1112111-- \\ \hline 11111101001 \quad \rightarrow 2025 \end{array}$$

El resultado de la multiplicación tiene un tamaño de bits suma del número de bits de los factores.

## Semi-Sumador (Half Adder)

- Función: Suma de dos bits → resultado suma y carry (llevada,acarreo)
- Suma aritmética →  $Suma = A_i + B_i$
- Resultado: 2 funciones :  $S_i$  y el acarreo de la posición i a la posición i+1 →  $C_i$
- Diseño: dibujar diagrama de bloques del circuito
  - Dos funciones y dos variables → TV, DK → expresión lógica positiva
- $S_i = \overline{A}_i \cdot B_i + A_i \cdot \overline{B}_i = A_i \oplus B_i$
- $C_i = A_i \cdot B_i$



# Sumador Completo (Full Adder)

- Función: Suma de dos bits y acarreo anterior → resultado suma y acarreo posterior
- Suma aritmética →  $S_i = A_i + B_i + C_{i-1}$
- Resultado: 2 funciones :  $S_i$  y el acarreo →  $C_i$
- Diseño: dibujar diagrama de bloques del circuito
  - Dos funciones y tres variables → TV, DK → expresión lógica positiva
- $S_i = \overline{A}_i \cdot \overline{B}_i \cdot C_{i-1} + \overline{A}_i \cdot B_i \cdot \overline{C}_{i-1} + A_i \cdot B_i \cdot C_{i-1} + A_i \cdot \overline{B}_i \cdot \overline{C}_{i-1} = \overline{A}_i \cdot (\overline{B}_i \cdot C_{i-1} + B_i \cdot \overline{C}_{i-1}) + A_i \cdot (B_i \cdot C_{i-1} + \overline{B}_i \cdot \overline{C}_{i-1}) = \overline{A}_i \cdot (B_i \oplus C_{i-1}) + A_i \cdot \overline{(B_i \oplus C_{i-1})} = A_i \oplus B_i \oplus C_{i-1}$
- $C_i = A_i \cdot B_i + A_i \cdot C_{i-1} + B_i \cdot C_{i-1}$

## Sumador Completo



Figure 6. Full Adder

## Sumador Completo usando semi-sumadores



Concepto nuevo: Diseñar un circuito no como combinación de puertas lógicas sino como combinación de otros circuitos o bloques



Concepto nuevo: introducir en la tabla de la verdad variables-funcion nuevas como Sa,Ca,Sb,Cb para obtener las funciones C1 y S1 en función de ellas.

# Sumador Completo usando semi-sumadores

Particionamiento: utilizar señales intermedias

$A_i+B_i$  puede ser sustituido por un Half Adder

Razonar la suma de 3 bits con sumas parciales de 2 bits

$$\begin{array}{r} 1 & 1 \\ 1 & + 1 \\ + 1 & \rightarrow \quad --- \\ --- & C_a S_a \\ & + 1 \\ & C_b \\ & --- \\ & C_1 S_b \end{array}$$

$S_1 = S_b$

¿  $C_1$  ?

$$\text{Suma} = (A_1 + B_1) + C_0 = (S_a, C_a) + C_0 = C_a, (S_a + C_0) = C_a, (S_b, C_b) = (S_1, C_1)$$

$$\text{HA}_a \rightarrow (S_a, C_a)$$

$$\text{HA}_b \rightarrow (S_b, C_b)$$

¿  $C_1$  ?

# Sumador Completo usando semisumadores

Tabla de la verdad con 3 variables y 6 funciones

$A_1, B_1, C_0, S_a, C_a, S_b, C_b, C_1, S_1$

$$S_1 = S_b$$

$$C1 = \overline{C}_a \cdot C_b + C_a \cdot \overline{C}_b = C_a \oplus C_b$$

| $C_1$ | $C_b$ | 0 | 1 |
|-------|-------|---|---|
| $C_a$ | 0     | 0 | 1 |
|       | 1     | 1 | X |

$$C1 = C_a + C_b$$

Table 18. Full Adder

| A1 | B1 | C0 | Sa | Ca | Sb | Cb | C1 | S1 |
|----|----|----|----|----|----|----|----|----|
| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 1  |
| 0  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | 1  |
| 0  | 1  | 1  | 1  | 0  | 0  | 1  | 1  | 0  |
| 1  | 0  | 0  | 1  | 0  | 1  | 0  | 0  | 1  |
| 1  | 0  | 1  | 1  | 0  | 0  | 1  | 1  | 0  |
| 1  | 1  | 0  | 0  | 1  | 0  | 0  | 1  | 0  |
| 1  | 1  | 1  | 0  | 1  | 1  | 0  | 1  | 1  |

## Sumador Completo usando semisumadores



## Sumador Paralelo Acarreo Serie



Figure 7. Full Adders en Cadena

## Sumador Paralelo Acarreo Paralelo

- El acarreo serie ralentiza la obtención de la suma → ¿solución? → Carry Look Ahead
- Full Adder: Tabla de la verdad :
  - segmentar la tabla de la verdad
    - fijarse en la relación entre los dos acarreos , el anterior y el posterior, cada dos filas, ya que son el problema.
    - 3 casos: no hay acarreo, se propaga el acarreo, se genera el acarreo → lo expresamos lógicamente mediante las funciones **G** y **P**
- Particionamiento: Variables ó Funciones Intermedias → generación y propagación
  - 2 funciones-variables intermedias para codificar 3 casos → **G** y **P** se pueden calcular en paralelo en función de los sumandos ya que NO DEPENDEN de los acarreos → Los acarreos de salida se pueden calcular en función de G y P, que no dependen de los acarreos de entrada
- Diseñar el circuito
  - Más rápido pero más complejo

# Sumador Paralelo Acarreo Paralelo

Table 19. Funciones de Generación y Propagación del Acarreo

| A_i | B_i | C_{i-1} | C_i | Descripción                | G | P |
|-----|-----|---------|-----|----------------------------|---|---|
| 0   | 0   | 0       | 0   | Ni se Genera Ni se Propaga | 0 | 0 |
| 0   | 0   | 1       | 0   |                            | 0 | 0 |
| 0   | 1   | 0       | 0   | Se Propaga                 | 0 | 1 |
| 0   | 1   | 1       | 1   |                            | 0 | 1 |
| 1   | 0   | 0       | 0   |                            | 0 | 1 |
| 1   | 0   | 1       | 1   |                            | 0 | 1 |
| 1   | 1   | 0       | 1   | Se Genera                  | 1 | 0 |
| 1   | 1   | 1       | 1   |                            | 1 | 0 |

## Sumador Paralelo Acarreo Paralelo

$$C_i = \overline{A}_i B_i C_{i-1} + A_i \overline{B}_i C_{i-1} + A_i B_i \overline{C}_{i-1} + A_i B_i C_{i-1} = = (A_i \oplus B_i) \cdot C_{i-1} + A_i B_i = P_i \cdot C_{i-1} + G_i$$

| $P_i$     | $A_i B_i$ |    |    |    |  | $G_i$     | $A_i B_i$ |    |    |    |  |
|-----------|-----------|----|----|----|--|-----------|-----------|----|----|----|--|
| $C_{i-1}$ | 00        | 01 | 11 | 10 |  | $C_{i-1}$ | 00        | 01 | 11 | 10 |  |
| 0         | 0         | 1  | 0  | 1  |  | 0         | 0         | 0  | 1  | 0  |  |
| 1         | 0         | 1  | 0  | 1  |  | 1         | 0         | 0  | 1  | 0  |  |

Conclusión:  $P_i$  y  $G_i$  permiten expresar el acarreo de forma más clara.

$$C_1 = G_1 + P_1 \cdot C_0$$

$$C_2 = G_2 + P_2 \cdot C_1 = G_2 + P_2 G_1 + P_2 P_1 C_0$$

$$C_3 = G_3 + P_3 \cdot C_2 = \dots = G_3 + P_3 P_2 + P_3 P_2 G_1 + P_3 P_2 P_1 C_0$$

# Sumador Serie

Sumador serie:

- Un Full Adder con 3 entradas (sumandos y acarreo anterior) y dos salidas (suma y acarreo)
- Necesita de 3 "registros de desplazamiento" para memorizar los operandos y la suma. Cuando el **reloj** genera un disparo positivo, el contenido de las celdas del registro se desplazan una posición hacia la derecha.
- Celda de memoria para recordar el acarreo previo. La escritura de la memoria es síncrona con el **reloj**.
- Puerta de bloqueo: mientras el **reloj** está a cero los sumandos valen cero
- Dispositivo de **sincronismo**: el reloj



## Sumador/Restador de 4 bits

- Operandos: números con signo en formato C1 ó C2
- Diagrama de bloques del circuito:
  - Señal de control para sumar o restar → la resta equivale a sumar cambiando de signo al sustraendo
  - Resta: cambiar el signo para sólo sumar
    - bloque complementador para generar el complementario
  - bloque sumador completo de 4 bits
- Diseño C1 :
  - C1 : complementario
  - suma: la última llevada (MSB) se suma. Ver [Suma-Resta C1](#)
- Diseño C2 :
  - C2 : complementario más 1
  - suma: la última llevada no se tiene en cuenta

## Complementador

| Control | Entrada | Salida |
|---------|---------|--------|
| 1       | 0       | 0      |
|         | 1       | 1      |
| 0       | 0       | 1      |
|         | 1       | 0      |

$$\text{Salida}_i = \overline{\text{Control} \oplus \text{Entrada}_i}$$



$$\text{Control} = 1 \quad O_i = B_i$$

$$\text{Control} = 0 \quad O_i = \overline{B_i}$$

## Sumador/Restador de 4 bits



## Sumador/Restador de 4 bits



## Semi-Restador

- Mismos conceptos de diseño que para el Semi-Sumador
  - TV → lógica positiva o negativa → Obtener Expresión lógica
- La llevada (L) en lugar de acarreo recibe el nombre de Borrow

## **Restador Completo**

- Mismos conceptos de diseño que para el Sumador Completo
  - TV → lógica positiva o negativa → Obtener Expresión lógica

## Acumulador

- Almacenar resultados parciales y reutilizarlos como operandos

# Multiplicador

- Concepto de diseño:
  - Estructura matricial: el bus A en "m" Filas y el bus B en "n" columnas
  - En cada punto de la matriz  $(i,j)$  se dispone de un sumador Full-Adder para realizar las sumas de dos en dos verticalmente y teniendo en cuenta el acarreo de la columna anterior, al igual que se realiza manualmente.
  - Tener en cuenta que el número de bits del resultado es  $m+n$ .

## Unidad Aritmético Lógica (ALU)

- Puede realizar diferentes operaciones: aritméticas , lógicas, etc
- El circuito tiene como entrada señales de control para seleccionar la operación a realizar
- ALUs comercial 714181 → Interpretación de las Hoja de Características
  - la entrada  $M$ : selecciona la categoría de la operaciones: Aritmética o Lógica.
  - la entrada  $C_n$  : selecciona la subcategoría de las operaciones dentro de la categoría Aritmética:
  - En total hay  $3 \times 2^4$  operaciones = 48 operaciones
  - las entradas  $S_3S_2S_1S_0$  seleccionan el tipo de operación dentro de las 2 categorías.
  - Los datos de entrada A y B y el de salida F son de 4 bits
  - Los datos de entrada y salida siguen la lógica negativa : son activas las señales de valor 0.
  - Lógica negativa → el dato 1000 representa al valor 7.

# Tema 6: Otros Circuitos Combinacionales

## Tema 6: Índice

- Tema5 Otros Circuitos Combinacionales [PDF/05\_otros\_circuitos\_combinacionales.pdf]: PDF
  1. Circuitos Combinacionales.
  2. Multiplexor
  3. Codificador (Encoder)
  4. Decodificador / Demux
  5. Convertidores de Código
  6. Generador-Comprobador de Paridad
  7. Comparador Binario

## Circuitos Combinacionales

- Concepto: Circuitos cuya salida un instante es resultado de la entrada en ese mismo instante sin tener cuenta la historia pasada
- No tienen MEMORIA

# Multiplexor

1. Concepto
2. Símbolo
3. Diseño
4. Esquema Eléctrico
5. Hoja de características comercial
6. Extensión
7. Aplicaciones: Generador de Funciones

## Concepto - Símbolo

El circuito multiplexor de N entradas de datos y 1 salida de datos tiene la función de seleccionar una de las entradas y conectarla a la salida. Para ello se sirve de M entradas de control donde  $2^M=N$



Figure 8. Multiplexor 4x1



# Diseño

Lenguaje natural: función del multiplexor  $\rightarrow F = I_0$  si  $S_1=0$  y  $S_0=0$  ó  $F = I_1$  si  $S_1=0$  y  $S_0=1$  ó .....

$$F = I_0 \text{ ó } F = I_1 \text{ ó } F = I_2 \text{ ó } F = I_3$$

Table 20. TV

| I <sub>3</sub> | I <sub>2</sub> | I <sub>1</sub> | I <sub>0</sub> | S <sub>2</sub> | S <sub>1</sub> | F              |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| X              | X              | X              | X              | 0              | 0              | I <sub>0</sub> |
| X              | X              | X              | X              | 0              | 1              | I <sub>1</sub> |
| X              | X              | X              | X              | 1              | 0              | I <sub>2</sub> |
| X              | X              | X              | X              | 1              | 1              | I <sub>3</sub> |

# Esquema Eléctrico

- Señal Strobe : señal de validación, habilitación. Es necesario que este activa para que el circuito procese los datos de entrada y la salida sea válida.
  - Se implementa mediante la función (  $Z = \text{Strobe AND } F$  ) donde es necesario activar Strobe para que la salida Z tenga el valor de F, en caso contrario  $Z=0$ . Si la señal strobe se activa con lógica negativa  $\rightarrow Z = \overline{\text{Strobe}} \cdot F$



# Hoja de Características Comercial

| INPUTS |   |        | OUTPUTS |               |
|--------|---|--------|---------|---------------|
| SELECT |   | STROBE | Y       | W             |
| C      | B | A      | G       | $\bar{G}$     |
| X      | X | X      | H       | L H           |
| L      | L | L      | L       | D0 $\bar{D0}$ |
| L      | L | H      | L       | D1 $\bar{D1}$ |
| L      | H | L      | L       | D2 $\bar{D2}$ |
| L      | H | H      | L       | D3 $\bar{D3}$ |
| H      | L | L      | L       | D4 $\bar{D4}$ |
| H      | L | H      | L       | D5 $\bar{D5}$ |
| H      | H | L      | L       | D6 $\bar{D6}$ |
| H      | H | H      | L       | D7 $\bar{D7}$ |

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

Dispositivo buffer: adapta la señal (I,V)  
Símbolo círculo "O" : negación

FUNCTION TABLE logic diagram (positive logic)



## Extensión de Multiplexores

- El número de entradas de los multiplexores es limitado. No hay multiplexores con 64 entradas. Para diseñar un multiplexor de 64 entradas es necesario utilizar multiplexores con un número de entradas inferior : 16,8,4,2 entradas.
- Pej cómo diseñar un mux de 64 entradas con mux de 16 entradas de datos
  - Un mux de 64 entradas necesita 6 señales de selección o control  $\rightarrow 2^6$
  - Un mux de 64 entradas es la combinación de 4 mux de 16 entradas de datos y 4 entradas de selección . Las 4 salidas de los 4 mux se multiplexan con un segundo mux de 4 entradas.
  - Las señales de selección del 1º nivel de mux están interconectadas dando lugar a 4 entradas de control y el 2º nivel de mux tendría 2 entradas de control. Los dos niveles suman 6 entradas de control.

# Extensión de Multiplexores



Ejemplo: para seleccionar la en

$C_5C_4C_3C_2C_1C_0=010010$

Con  $C_3C_2C_1C_0=0010$  se selecciona cada multiplexor de 16 entradas

Con  $C_5C_4=01$  se elige la entrada MUX1

## Aplicaciones: Generador de Funciones

- Las salida del multiplexor tiene el formato de una función canónica SOP donde las entradas de control son las variables independientes de la función. Las entradas de datos tomar valores "0" ó "1" o ser también variables.
- Por lo tanto un multiplexor con 3 entradas de control puede implementar una función lógica de 3 o más variables independientes.
- Ejemplos.

## Ejemplos: Generador de Funciones

1. Generar con un MUX 8x1 la función  $F = \overline{B}CD + A\overline{B}D + \overline{A}\overline{B}C$ 
  - Para hacer la equivalencia con la función de un MUX la función F tiene que tener formato SOP
  - Variables independientes: las 3 entradas de selección del MUX 8x1 → Pej las variables A,B y C
  - La variable independiente D se implemente mediante las entradas de datos del MUX.
2. Implementar mediante un MUX Nx1 la función  $F = \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$ 
  - Se observan variables comunes en todos los sumandos → SOP

# Codificador (Encoder)

1. Concepto
2. Símbolo
3. Ejemplo de Diseño: BCD sin prioridad, 4x2 con prioridad

## Concepto

- Un codificador realiza la conversión de un número con cualquier tipo de código no binario a código binario.
- Pej: un codificador de código hexadecimal a código binario se implementa mediante un circuito con un bus de datos de entrada de 16 hilos donde únicamente (codificador sin prioridad) se activa el hilo asociado a uno de los 16 dígitos hexadecimales. Para codificar en binario los 16 dígitos son necesarios 4 bits ( $2^4$  combinaciones), por lo que el bus de datos de entrada tiene un tamaño de 16 pistas y el de salida tiene un tamaño de 4 pistas.



# Codificador Hexadecimal sin Prioridad : Diseño

Table 21. TV del Codificador Hexadecimal

| $E_{15}$                        | $E_{14}$ | $E_{13}$ | .. | $E_1$    | $E_0$    | $S_3$ | $S_2$ | $S_1$ | $S_0$ | Fila            |
|---------------------------------|----------|----------|----|----------|----------|-------|-------|-------|-------|-----------------|
| 0                               | 0        | 0        | .. | 0        | <b>1</b> | 0     | 0     | 0     | 0     | 0 <sup>a</sup>  |
| 0                               | 0        | 0        | .. | <b>1</b> | 0        | 0     | 0     | 0     | 1     | 1 <sup>a</sup>  |
| ..                              | ..       | ..       | .. | ..       | ..       | ..    | ..    | ..    | ..    |                 |
| 0                               | 0        | <b>1</b> | .. | 0        | 0        | 1     | 1     | 0     | 1     | 13 <sup>a</sup> |
| 0                               | <b>1</b> | 0        | .. | 0        | 0        | 1     | 1     | 1     | 0     | 14 <sup>a</sup> |
| <b>1</b>                        | 0        | 0        | .. | 0        | 0        | 1     | 1     | 1     | 1     | 15 <sup>a</sup> |
| RESTO de COMBINACIONES POSIBLES |          |          |    |          |          | X     | X     | X     | X     |                 |

- El resto de combinaciones "no van a ocurrir" por lo que salida queda "X" en DK ó "don't care" en VHDL , es decir, no importa que la salida valga cero ó uno para dichas entradas y las tenemos que definir 0 ó 1 en función de su optimización.

## Codificador Hexadecimal : Diseño

- No se puede recurrir directamente a un DK ya que el número de celdas es muy elevado
- Es necesario recurrir al lenguaje natural para obtener las 4 salidas y optimizarlas mediante la matemática booleana.
- Función  $S_0 \rightarrow$  lógica positiva
  - vale 1 si: filas 1<sup>a</sup>, 3<sup>a</sup>, 5<sup>a</sup>...15<sup>a</sup>
    - fila 1<sup>a</sup>: 0000000000000010 → es el minitérmino  $m_2$  de 16 variables → optimización: ¿se puede reducir el N° de variables?
    - Si de las filas RESTO capturo todas las filas  $m_i$  donde  $E_1$  valga 1 y las sumo a la fila 1<sup>a</sup> → puedo sacar factor común  $E_1$
    - $E_1 * sum(m_i) = E_1 cdot 1$  y así con las filas 3<sup>a</sup>, 5<sup>a</sup>, etc
  - $S_0 = E_1 + E_3 + E_5 + E_7 + E_9 + E_{11} + E_{13} + E_{15}$

## Codificador Hexadecimal : Diseño

- Aplicamos el mismo método a las 4 salidas
  - $S_0 = E_1 + E_3 + E_5 + E_7 + E_9 + E_{11} + E_{13} + E_{15}$
  - $S_1 = E_2 + E_3 + E_6 + E_7 + E_{10} + E_{11}$
  - $S_2 = E_4 + E_5 + E_6 + E_7 + E_{12} + E_{13} + E_{14} + E_{15}$
  - $S_3 = E_8 + E_9 + E_{10} + E_{11} + E_{12} + E_{13} + E_{14} + E_{15}$
- ¿ Hubiésemos llegado al mismo resultado mediante el lenguaje natural?
  - La salida  $S_k$  igual a 1 si la entrada  $E_i = 1$  ó la entrada  $E_j = 1$  ó etc ...

## Ejemplo de Diseño: BCD sin prioridad

- Mismo procedimiento que el codificador Hexadecimal sin prioridad.

## Ejemplo de Diseño: Codificador 4x2 con prioridad

Se puede activar más de una entrada...pero se selecciona únicamente UNA → la de mayor prioridad  
Ejemplo 1 : Codificador 4x2 con prioridad  $E_3 > E_2 > E_1 > E_0$

Table 22. Tabla de la verdad

| $E_3$ | $E_2$ | $E_1$ | $E_0$ | $S_1$ | $S_0$ |
|-------|-------|-------|-------|-------|-------|
| 1     | X     | X     | X     | 1     | 1     |
| 0     | 1     | X     | X     | 1     | 0     |
| 0     | 0     | 1     | X     | 0     | 1     |
| 0     | 0     | 0     | 1     | 0     | 0     |
| 0     | 0     | 0     | 0     | 0     | 0     |

- lógica positiva

$$\circ S_0 = E_3 + \overline{E_3} \overline{E_2} E_1 = \text{optimizar} = E_3 + E_3 \overline{E_2} E_1 + \overline{E_3} \overline{E_2} E_1 = E_3 + \overline{E_2} E_1$$

$$\circ S_1 = E_3 + \overline{E}_3 E_2 = \text{optimizar} = E_3 + E_3 E_2 + \overline{E}_3 E_2 = E_3 + E_2$$

# Decodificador / Demux

1. Concepto
2. Diseño: Salidas mutuamente excluyentes
3. Ejemplo de Diseño: Decodificador BCD
4. Excitador de un Display de 7 segmentos
5. Aplicaciones:
  - a. Generador de Funciones
  - b. Conversor Serie Paralelo
  - c. Generador de Funciones: Decodificador y Multiplexor

## Concepto

- El Decodificador realiza la función inversa del codificador, es decir, convierte la entrada de datos binaria en una salida de datos en código no binario.

## Diseño: Salidas mutuamente excluyentes

Salidas Mutuamente excluyentes: únicamente se activa una de las salidas



Figure 9. Decodificador Hexadecimal

## Diseño: Salidas mutuamente excluyentes

- Lenguaje Natural
  - La salida  $S_0$  vale 1 si la entrada  $E_3E_2E_1E_0$  vale 0000 → minitérmino  $m_0$ 
    - $S_0 = \overline{E}_3\overline{E}_2\overline{E}_1\overline{E}_0$
  - La salida  $S_1$  vale 1 si la entrada  $E_3E_2E_1E_0$  vale 0001 → minitérmino  $m_1$ 
    - $S_1 = \overline{E}_3\overline{E}_2\overline{E}_1E_0$
  - La salida  $S_{15}$  vale 1 si la entrada  $E_3E_2E_1E_0$  vale 1111 → minitérmino  $m_{15}$ 
    - $S_{15} = E_3E_2E_1E_0$

## Ejemplo de Diseño: Decodificador BCD

- Decodificador BCD/DEC sn74ls42 [http://bit.ly/1ohdG23]
- símbolo línea con lógica negativa



## Extensión de los Decodificadores

- **3-LINE TO 8-LINE DECODERS/DEMULTIPLEXERS** [<https://www.ti.com/lit/ds/symlink/cd54act138.pdf>]: Diseñar un Decodificador de 32 Salidas mediante decodificadores CD54ACT138 3x8
  - Hacen falta 4 decodificadores CD54ACT138 cuyas características son:
  - 2 tipos de entradas: de selección y de datos
  - La función **enable** (habilitación) se obtiene mediante el operador **&** (and) de las 3 señales:  $\overline{G2A}$ ,  $\overline{G2B}$  y  $G1$  correspondientes a los pines 4,5 y 6 del circuito integrado CD54ACT138.
  - Las 8 salidas de datos operan en lógica **negativa** : se activan con un **0**

# Extensión de los Decodificadores mediante CD54ACT138.

- El decodificador resultante de 32 salidas tendría una entrada binaria de 5 bits  $\rightarrow 2^5$ ,  $A_4, A_3, A_2, A_1, A_0$  y el decodificador CD54ACT138 3x8 solo tiene 3 entradas de datos, por lo que es necesario utilizar las señales "Enable".
- Las entradas  $A_2, A_1, A_0$  se asignan al bus de datos del decodificador 3x8
  - Una combinación  $A_2, A_1, A_0$  seleccionará la misma salida de los 4 decodificadores 3x8 : tendremos seleccionadas 4 salidas del decodificador 5x32, por lo que es necesaria una segunda selección para seleccionar únicamente uno de los 4 decodificadores 3x8.
- Para realizar la segunda selección las entradas  $A_4, A_3$  se asignan al bus de control Enable de los 4 decodificadores 3x8

# Extensión de los Decodificadores mediante CD54ACT138.

Table 23. Tabla de la Verdad

| Decodificador Seleccionado | $A_4$ | $A_3$ | $\bar{G}2B$ | $\bar{G}2A$ | $G1$ |
|----------------------------|-------|-------|-------------|-------------|------|
| Primero                    | 0     | 0     |             |             |      |
| Segundo                    | 0     | 1     |             |             |      |
| Tercero                    | 1     | 0     |             |             |      |
| Cuarto                     | 1     | 1     |             |             |      |

- Hay que conectar las 3 señales de control con las 2 entradas de datos  $A_4$ ,  $A_3$

## Diodo L.E.D.

- Light-Emitting Diode : diodo LED



## LED: Circuito Excitador



[CC BY-SA 2.5](https://creativecommons.org/licenses/by-sa/2.5 "Creative Commons Attribution-Share Alike 3.5"), [Link](https://commons.wikimedia.org/w/index.php?curid=2550282)

Para que el diodo LED se encienda es necesario inyectarle una corriente en la dirección Anodo → Cátodo mediante una **tensión** del Anodo superior a la tensión del Cátodo.



Controlando la **tensión** de uno de los dos terminales producimos el encendido/apagado (ON/OFF) del diodo LED.

## Display 7 segmentos



<a href="https://creativecommons.org/licenses/by-sa/3.0" title="Creative Commons Attribution-Share Alike 3.0">CC BY-SA 3.0</a>, <a href="https://commons.wikimedia.org/w/index.php?curid=2550282">Link</a>

Cada uno de los 7 segmentos del Display es un diodo LED que se puede encender/apagar.



<a href="https://creativecommons.org/licenses/by-sa/4.0" title="Creative Commons Attribution-Share Alike 4.0">CC BY-SA 4.0</a>, <a href="https://commons.wikimedia.org/w/index.php?curid=105121223">Link</a>

# Excitador de un Display de 7 segmentos



[Link](https://commons.wikimedia.org/w/index.php?curid=582271)

Los 7 LEDs del Display se nombran con 7 letras según su posición.

Los 7 LEDs del Display tienen el Anodo ó el Cátodo común.

Si el Display es de **Anodo Común**, se puede controlar el Cátodo de cada LED libremente con un **0** : lógica negativa.

- Iluminar el 0 : activar los segmentos a-b-c-d-e-f → 0000001.
- Iluminar el 5: activar los segmentos a-c-d-f-g → 0100100.

Si el Display es de **Cátodo Común**, se puede controlar el Anodo de cada LED libremente con un **1** : lógica positiva.

- Iluminar el 0 : activar los segmentos a-b-c-d-e-f → 1111110.
- Iluminar el 5: activar los segmentos a-c-d-f-g → 1011011.

## Decodificador Display 7 Segmentos

- Mediante un decodificador 4x7 Binario/7seg\_code podemos visualizar en el display un dígito hexadecimal codificado en binario.
- Diseñar un Decodificador BIN\_HEX a Display\_7\_segmentos de Anodo Común en código VHDL. Verificar su funcionamiento mediante la tarjeta DE1-SoC
  - Utilizar como puerto de entrada las señales de los switches SW(3 downto 0)
  - Utilizar como puerto de salida las señales del Display de 7 segmentos HEX0(6 downto 0)
  - Cada dígito hexadecimal de entrada estará codificado en binario con 4 bits y la salida será un bus de 7 líneas donde cada línea irá a uno de los LEDs

## Decodificador Display 7 Segmentos



## Aplicaciones: Generador de Funciones

- El Decodificador de salidas mutuamente excluyentes activa una salida para cada combinación de la entrada por lo que cada salida responde a un minitérmino.
- Las entradas del Decodificador representan las variables independientes.
- Se puede generar una función mediante la primera forma canónica SOP realizando la suma lógica, **exclusivamente** de las salidas correspondientes a los minitérminos que hacen uno a la función, mediante una puerta OR cuya salida representa a la Función.



- Si la función se expresa según la 2<sup>a</sup> forma canónica sustituiríamos la puerta OR de salida por una puerta AND.

## Aplicaciones: Conversor Serie Paralelo

Aplicación como **Demultiplexor**: 1 entrada ENABLE que se conecta a una de las salidas seleccionada mediante las entradas de selección. - En realidad la entrada enable no se conecta físicamente sino que **inhibe** (todas las salidas desactivadas) o **habilita** (salida seleccionada activa) el dispositivo.

Mediante un Decodificador con entrada ENABLE como bus de datos serie se puede enviar cada bit de dicha entrada a una salida diferente del decodificador si hacemos un barrido de las combinaciones de entrada mediante la secuencia binaria de un contador.

El contador:

- El contador ve incrementada su cuenta a cada disparo positivo del reloj de entrada: cuenta pulsos del reloj
- El tamaño del contador binaria ha de ser igual al número de entradas binarias del decodificador.
- El valor de la cuenta es accesible en el bus paralelo de salida del contador, donde cada línea del bus representa cada bit de la cuenta.



El contador cuenta pulsos del reloj

Contador en módulo 16: 0000-0001-...-1111-0000-0001-...

## Aplicaciones: Generador de Funciones: Decodificador y Multiplexor

Se puede generar una función mediante un Decodificador y/o un Multiplexor.

$$F = SUV\bar{X}YZ + S\bar{U}VXY + \bar{S}\bar{U}V\bar{X}Y\bar{Z}$$

Una función con 6 variables puede distribuir las variables entre el decodificador (3x8) y el multiplexor (8x1) : 3 variables cada uno.

$$F = SOP = SUV\bar{X}YZ + S\bar{U}VXYZ + S\bar{U}VXY\bar{Z} + \bar{S}\bar{U}V\bar{X}Y\bar{Z}$$



- F=1 Si SUV=111, entonces  $O_7 = 1$ , XYZ=011 e  $I_3$  y  $O_7$  están conectados  
 ó Si SUV=101, entonces  $O_5 = 1$ , XYZ=111 e  $I_7$  y  $O_5$  están conectados  
 ó Si SUV=101, entonces  $O_5 = 1$ , XYZ=110 e  $I_6$  y  $O_5$  están conectados  
 ó Si SUV=001, entonces  $O_1 = 1$ , XYZ=010 e  $I_2$  y  $O_1$  están conectados



# Convertidores de Código

- Convertidor BCD a Binario , 74184 [https://www.digchip.com/datasheets/parts/datasheet/477/SN74184.php]
  - Entrada de 6 bits para dos dígitos BCD : 2bits MSD y 4 bits LSD → rango 00 hasta 39
  - Atención: el chip únicamente tiene 5 bits de entrada (A,B,C,D,E) ya que la posición 0 es directamente la salida  $Y_0$ , por eso en la tabla para cada par de valores los 5 bits de entrada, del chip, son idénticos
  - Para el rango de entrada hacen falta 6 bits del código BINARIO de salida. El chip proporciona las salidas  $Y_5, Y_4, Y_3, Y_2, Y_1$
- Convertidor Binario a BCD , 74185 [https://www.digchip.com/datasheets/parts/datasheet/477/SN74185.php]
  - Entrada de 6 bits del código BINARIO: Rango 00-63
  - Atención: el chip únicamente tiene como entradas 5 bits (A,B,C,D,E) ya que la posición 0 es directamente la salida  $Y_0$ , por eso en la tabla para cada par de valores los 5 bits de entrada, del chip, son idénticos.
  - Para el rango de entrada hacen falta 7 bits BCD y sólo hay 6 bits BCD, por lo que el rango queda limitado a los valores 00-39

# Generador-Comprobador de Paridad

1. Concepto de Paridad
2. Detección de Errores
3. Hoja de Datos Comercial

## Generador-Comprobador de Paridad

Bit de paridad Par: Al dato hay que añadir un bit (el bit de paridad Par) para que el número total de **1** sea Par

- Ejemplo: el dato de 8 bits 01101101 tiene un número impar de 1, luego hay que añadirle un 1, quedando los 9 bits → **1** 01101101

Bit de paridad Impar: Al dato hay que añadir un bit (el bit de paridad Impar) para que el número total de **1** sea Impar

- Ejemplo: el dato de 8 bits 01101101 tiene un número impar de 1, luego hay que añadirle un 0, quedando los 9 bits → **0** 01101101

Table 24. Dato de 2 bits: Tabla de la Verdad Paridad Par

| $X_1$ | $Y_1$ | Bit de Paridad Par | Nº total de <b>1</b> |
|-------|-------|--------------------|----------------------|
| 0     | 0     | 0                  | 0                    |
| 0     | 1     | 1                  | 2                    |
| 1     | 0     | 1                  | 2                    |
| 1     | 1     | 0                  | 2                    |

La síntesis es la puerta XNOR de dos entradas

Si el dato tiene más de dos bits la evaluación se realiza de dos en dos bits y en distintos niveles de evaluación.

Ejemplo: Bit de paridad par del dato 01101101



# Generador-Comprobador de Paridad: Comunicaciones



Si el generador de paridad del Receptor no coincide con el bit de paridad del Transmisor: Error en la línea de comunicaciones y hay que retransmitir el dato del bus de 4 bits.

# Generador-Comprobador de Paridad CY74FCT480T: Hoja de Características

<https://www.digchip.com/datasheets/parts/datasheet/477/CY74FCT480ATPC.php>

Dos entradas de datos de 1 byte cada uno:  $(AB...H)_1$  y  $(AB...H)_2$

Funciona como generador CHK/GEN=0 o como detector CHK/GEN=1

Como generador: genera 2 bits de paridad impar (ODD), uno para cada **dato a transmitir**:  $ODD_1$  y  $ODD_2$

Como detector: recibe los 2 datos de 8 bits y los 2 bits de paridad  $PAR_1$  y  $PAR_2$

-Como detector genera el bit de paridad impar del **dato recibido** y lo compara con el **bit recibido PAR**

-En caso de error, no distingue si el error es en la línea de datos 1 o en la línea de datos 2.



# Comparador Binario

1. Concepto
2. Diseño comparador de 4 bits
3. Extensión con Entradas de Expansión
4. Extensión sin Entradas de Expansión
5. Hoja de Datos Comercial

# Concepto

Comparador Binario: compara 2 datos A y B de entrada y expresa la relación entre ellos: A>B, A<B, A=B

Table 25. Tabla de la Verdad: 2 datos de 1 bit

| A | B | G | E | L |
|---|---|---|---|---|
| 0 | 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 | 0 |

$$L = \overline{A}B$$

$$G = A\overline{B}$$

$$E = \overline{A}\overline{B} + AB = \overline{A \oplus B} = \overline{L \oplus G}$$

# Diseño comparador de 4 bits

Para comparar 2 datos de varios bits se realiza la comparación bit a bit (wise) comenzando por el bit MSB  
Síntesis de un comparador de 4 bits  $A_1, A_2, A_3, A_4$  y  $B_1, B_2, B_3, B_4$ .

- Lenguaje natural:  $G=1$  si [stem 52c19cc9dec9b093069373374faa5785] ó  $A_4 = B_4 = 0$  y  $A_3 > B_3$  ó ...

-  $G = A_4\bar{B}_4 + \bar{A}_4\bar{B}_4A_3\bar{B}_3 + \dots$

Síntesis por extensión de comparadores de 1 bit

- Lenguaje natural:  $G=1$  si  $G_4 = 1$  ó  $E_4G_3 = 1$  ó  $E_4E_3G_2 = 1$  ó  $E_4E_3E_2G_1 = 1$

-  $L=1$  si  $L_4 = 1$  ó  $E_4L_3 = 1$  ó  $E_4E_3L_2 = 1$  ó  $E_4E_3E_2L_1 = 1$

-  $E=1$  si  $E_4E_3E_2E_1 = 1$

Table 26. Tabla de la Verdad. 2 datos de 1 bit

| A | B | G | E | L |
|---|---|---|---|---|
| 0 | 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 | 0 |

## Comparadores de 4 bits con entradas de Expansión



$$G = G_4 + E_4 G_3 + E_4 E_3 G_2 + E_4 E_3 E_2 G_1 + E_4 E_3 E_2 E_1 G_C$$

$$L = L_4 + E_4 L_3 + E_4 E_3 L_2 + E_4 E_3 E_2 L_1 + E_4 E_3 E_2 E_1 L_C$$

$$E = E_4 E_3 E_2 E_1 E_C$$



$$G_C = 0 \quad L_C = 0 \quad E_C = 1$$

$$G_L = G_4 + E_4 G_3 + E_4 E_3 G_2 + E_4 E_3 E_2 G_1 + E_4 E_3 E_2 E_1 G_C$$

$$L_L = L_4 + E_4 L_3 + E_4 E_3 L_2 + E_4 E_3 E_2 L_1 + E_4 E_3 E_2 E_1 L_C$$

$$E_L = E_4 E_3 E_2 E_1 E_C$$

$$G_H = G_8 + E_8 G_7 + E_8 E_7 G_6 + E_8 E_7 E_6 G_5 + E_8 E_7 E_6 E_5 G_L$$

$$L_H = L_4 + E_4 L_3 + E_4 E_3 L_2 + E_4 E_3 E_2 L_1 + E_4 E_3 E_2 E_1 L_C$$

$$E_H = E_8 E_7 E_6 E_5 E_L$$

# Extensión de Comparadores sin Entradas de Expansión

- Diseñar un Comparador de datos de 7 bits mediante 2 comparadores de 4 bits.
- Método ascendente : primero se compara los 4 bits LSB y a continuación los 4 bits MSB
  - La salida del comparador (G,E,L) es la del comparador MSB
  - El bit  $A_5$  del comparador MSB se conecta a la salida G del comparador LSB
  - El bit  $B_5$  del comparador MSB se conecta a la salida L del comparador LSB
- Método descendente : primero se compara los 4 bits MSB y a continuación los 4 bits LSB
  - La salida del comparador (G,E,L) es la del comparador LSB
  - El bit  $A_3$  del comparador LSB se conecta a la salida G del comparador MSB
  - El bit  $B_3$  del comparador LSB se conecta a la salida L del comparador MSB

# Comparador Comercial

- Comparador CD74HC85 [<https://www.digchip.com/datasheets/parts/datasheet/321/7485.php>]

# Comparador CD74HC85: conexión mediante entradas de expansión en paralelo

- Diseñar un comparador de 24 bits mediante 6 comparadores : 5 comparadores ( $C_0, C_1, C_2, C_3, C_4$  y  $C_5$ ) en el primer nivel de comparación y 1 comparador ( $C_6$ ) en el segundo nivel.
- El comparador  $C_0$  tiene las entradas GEL=010
- Los comparadores del primer nivel ( $C_1, C_2, C_3$  y  $C_4$ ) tienen 4 entradas de datos y las entradas GEL con los **bits dato** ( $C_1 \rightarrow A_4, B_4$ ), ( $C_2 \rightarrow A_9, B_9$ ), ( $C_3 \rightarrow A_{14}, B_{14}$ ) y ( $C_4 \rightarrow A_{19}, B_{19}$ )
- El comparador de segundo nivel tiene como entradas de datos las salidas GEL de los 4 comparadores del primer nivel ( $C_1, C_2, C_3$  y  $C_4$ ) y como entrada GEL la salida GEL del comparador  $C_0$ .

## Ejercicios

### Fin del Primer Parcial