



## Circuiti combinatori notevoli

Prof. Alberto Borghese  
Dipartimento di Informatica  
[alberto.borghese@unimi.it](mailto:alberto.borghese@unimi.it)

Università degli Studi di Milano

Riferimenti sul Patterson Hennessy: Sezione B3.



## Sommario



Implementazione circuitale mediante PLA o ROM

Circuiti combinatori notevoli



# Circuiti combinatori



- Circuiti logici digitali in cui le operazioni (logiche) dipendono solo da una combinazione degli input. Come nelle funzioni a valori reali.
  - Il risultato dell'elaborazione del circuito viene aggiornato immediatamente dopo il cambiamento dell'input (si suppone il tempo di commutazione trascurabile cioè che il tempo di attesa prima di guardare l'output sia sufficientemente ampio per permettere a tutti i circuiti la commutazione).
  - Circuiti senza memoria. Ogni volta che si inseriscono in ingresso gli stessi valori, si ottengono le stesse uscite. Il risultato non dipende dallo stato del circuito.
- I circuiti combinatori implementano delle espressioni Booleane. Queste espressioni si ottengono combinando tra loro (in parallelo o in cascata) gli operatori logici: **NOT, AND, OR**.
- Se consideriamo l'uscita del circuito combinatorio in funzione di tutti i possibili valori in ingresso al circuito passiamo al concetto di funzione logica.
  - Il funzionamento di una funzione logica può essere descritto come **tavella della verità**.



# Razionale della prima forma canonica



$$F = A B + B \bar{C}$$

| A | B | C | F |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |

$$F = \bar{A} \bar{B} \bar{C} + \bar{A} \bar{B} C + A \bar{B} C$$

$$F = 1$$

iff

$$A = 0 \ B = 1 \ C = 0$$

*OR*

$$A = 1 \ B = 1 \ C = 0$$

*OR*

$$A = 1 \ B = 1 \ C = 1$$



## La prima forma canonica



- Esiste un metodo per ricavare automaticamente un circuito che implementi una tabella di verità?
- Una **forma canonica** garantisce di poter realizzare una qualunque tabella di verità con solo due livelli di porte OR, AND e NOT:
- Somme di Prodotti (SOP) è la prima forma canonica (OR di AND):

| A B C | F       |
|-------|---------|
| 0 0 0 | 0       |
| 0 0 1 | 0       |
| 0 1 0 | 1 $m_2$ |
| 0 1 1 | 0       |
| 1 0 0 | 0       |
| 1 0 1 | 0       |
| 1 1 0 | 1 $m_6$ |
| 1 1 1 | 1 $m_7$ |

A.A. 2024-2025

$$F = m_2 + m_6 + m_7$$

mintermini

$$F = \bar{A} \bar{B} \bar{C} + A \bar{B} \bar{C} + A B C$$

5/47

<http://borghese.di.unimi.it/>

## Livelli di astrazione intermedi: anche per le linee



descrizione  
a livello di  
astrazione  
più alto



descrizione  
a livello di  
astrazione  
più basso

A.A. 2024-2025

6/47

<http://borghese.di.unimi.it/>



## La prima forma canonica



- Una **forma canonica** garantisce di poter realizzare una qualunque tabella di verità con solo due livelli di porte OR, AND e NOT:
- Somme di Prodotti (SOP) è la prima forma canonica (OR di AND):

| A B C | F       |
|-------|---------|
| 0 0 0 | 0       |
| 0 0 1 | 0       |
| 0 1 0 | 1 $m_2$ |
| 0 1 1 | 0       |
| 1 0 0 | 0       |
| 1 0 1 | 0       |
| 1 1 0 | 1 $m_6$ |
| 1 1 1 | 1 $m_7$ |

$F = m_2 + m_6 + m_7$   
 $F = \bar{A}B\bar{C} + A\bar{B}\bar{C} + AB\bar{C}$

A,B,C → 3 → F  
(3 ingressi  
1 uscita) → F

7/47

<http://borgheze.di.unimi.it/>



## Tipi di circuiti che implementano le SOP



In generale abbiamo funzioni logiche booleane multi-input / multi-output.

I circuiti complessi si ottengono collegando «piccoli» blocchi funzionali, dove ciascun blocco implementa una funzione logica.

- **Logica distribuita.**
- **PLA:** Programmable Logic Array: matrici regolari AND e OR in successione, personalizzabili dall'utente.
- **ROM:** Read Only Memory circuiti ad hoc che implementano una particolare funzione in modo irreversibile.



## Logica distribuita



A.A. 2024-2025

9/47

<http://borghese.di.unimi.it/>

## PLA (Programmable Logical Array)



- Architettura a 2 livelli:
    - Un primo livello di AND
    - Un secondo livello di OR
- 
- La matrice degli AND ha **n** linee di ingresso: ciascuna porta ha in ingresso le **n linee** e il loro complemento.
  - L'utente specifica per ogni porta AND a disposizione se la linea in ingresso entra direttamente o dopo una negazione.
    - Crea la matrice dei mintermini, bruciando in ingresso alle porte AND le linee che non servono.
  - Le uscite della matrice AND entrano nella matrice OR programmata come la precedente per ottenere l'OR dei mintermini della funzione.
    - Si utilizza una porta OR per ogni funzione calcolata (**m** OR per **m linee** di uscite)



Programmazione mediante POD

A.A. 2024-2025

<http://borghese.di.unimi.it/>



## Struttura di una PLA



## Sintesi separata delle uscite



| $X_0$ | $X_1$ | $X_2$ | $Z_0$ | $Z_1$ |
|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     |
| 0     | 0     | 1     | 1     | 0     |
| 0     | 1     | 0     | 1     | 0     |
| 0     | 1     | 1     | 0     | 1     |
| 1     | 0     | 0     | 1     | 0     |
| 1     | 0     | 1     | 0     | 1     |
| 1     | 1     | 0     | 0     | 1     |
| 1     | 1     | 1     | 1     | 1     |



$$Z_0 = \overline{X_0} \overline{X_1} X_2 + \overline{X_0} X_1 \overline{X_2} + X_0 \overline{X_1} \overline{X_2} + X_0 X_1 X_2 = m_1 + m_2 + m_4 + m_7$$

$$Z_1 = \overline{X_0} X_1 X_2 + X_0 \overline{X_1} X_2 + X_0 X_1 \overline{X_2} + X_0 X_1 X_2 = m_3 + m_5 + m_6 + m_7$$

Non è efficiente perché non si sfruttano le operazioni in comune alle due funzioni.



## Sintesi mediante PLA



- Realizzare con un PLA la funzione descritta dalla seguente TT

|                   | $X_0$ | $X_1$ | $X_2$ | $Z_0$ | $Z_1$ |
|-------------------|-------|-------|-------|-------|-------|
|                   | 0     | 0     | 0     | 0     | 0     |
| $m_1 \rightarrow$ | 0     | 0     | 1     | 1     | 0     |
|                   | 0     | 1     | 0     | 1     | 0     |
|                   | 0     | 1     | 1     | 0     | 1     |
|                   | 1     | 0     | 0     | 1     | 0     |
|                   | 1     | 0     | 1     | 0     | 1     |
| $m_6 \rightarrow$ | 1     | 1     | 0     | 0     | 1     |
| $m_7 \rightarrow$ | 1     | 1     | 1     | 1     | 1     |



$$Z_0 = \overline{X_0} \overline{X_1} X_2 + \overline{X_0} X_1 \overline{X_2} + X_0 \overline{X_1} \overline{X_2} + X_0 X_1 X_2 = m_1 + m_2 + m_4 + m_7$$

$$\text{A.. } Z_1 = \overline{X_0} X_1 X_2 + X_0 \overline{X_1} X_2 + X_0 X_1 \overline{X_2} + X_0 X_1 X_2 = m_3 + m_5 + m_6 + m_7$$

ii.it\



## Configurazione di una PLA



Costruzione di una porta AND ( $m_1$ )



Costruzione di una porta OR ( $Z_0$ )



A.A. 202

<http://borgheze.di.unimi.it/>





## Decoder a 2 ingressi



Tabella della verità



| I1 | I0 | U0 | U1 | U2 | U3 |
|----|----|----|----|----|----|
| 0  | 0  | 1  | 0  | 0  | 0  |
| 0  | 1  | 0  | 1  | 0  | 0  |
| 1  | 0  | 0  | 0  | 1  | 0  |
| 1  | 1  | 0  | 0  | 0  | 1  |



## Decoder a 2 ingressi: realizzazione



| I1 | I0 | U0 | U1 | U2 | U3 |
|----|----|----|----|----|----|
| 0  | 0  | 1  | 0  | 0  | 0  |
| 0  | 1  | 0  | 1  | 0  | 0  |
| 1  | 0  | 0  | 0  | 1  | 0  |
| 1  | 1  | 0  | 0  | 0  | 1  |

$$U_i = f_i(I_0, I_1)$$



Tabella della verità

| I1 | I0 | U0 | U1 | U2 | U3 |
|----|----|----|----|----|----|
| 0  | 0  | 1  | 0  | 0  | 0  |
| 0  | 1  | 0  | 1  | 0  | 0  |
| 1  | 0  | 0  | 0  | 1  | 0  |
| 1  | 1  | 0  | 0  | 0  | 1  |



## Decoder a 3 ingressi



| A | B | C | U <sub>0</sub> | U <sub>1</sub> | U <sub>2</sub> | U <sub>3</sub> | U <sub>4</sub> | U <sub>5</sub> | U <sub>6</sub> | U <sub>7</sub> |
|---|---|---|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 0 | 0 | 0 | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| 0 | 0 | 1 | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              |
| 0 | 1 | 0 | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              |
| 0 | 1 | 1 | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              |
| 1 | 0 | 0 | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              |
| 1 | 0 | 1 | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              |
| 1 | 1 | 0 | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              |
| 1 | 1 | 1 | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              |

Le funzioni di uscita sono  $2^n$  per n input:

$$U_0 = \sim A \sim B \sim C$$

...

$$U_7 = A BC$$

$$U_j = m_j$$

I mintermini sono AND a 3 ingressi



## Valutazione del decoder a 3 ingressi



| A | B | C | U <sub>0</sub> | U <sub>1</sub> | U <sub>2</sub> | U <sub>3</sub> | U <sub>4</sub> | U <sub>5</sub> | U <sub>6</sub> | U <sub>7</sub> |
|---|---|---|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 0 | 0 | 0 | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| 0 | 0 | 1 | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              |
| 0 | 1 | 0 | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              |
| 0 | 1 | 1 | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              |
| 1 | 0 | 0 | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              |
| 1 | 0 | 1 | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              |
| 1 | 1 | 0 | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              |
| 1 | 1 | 1 | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              |

Le funzioni di uscita sono  $2^n$  per n input:

$$U_0 = \sim A \sim B \sim C$$

...

$$U_7 = A BC$$

$$U_j = m_j$$

I mintermini sono AND a 3 ingressi

Complessità:  $8 \cdot 2 = 16$

Cammino critico: 2





## Rappresentazione circuitale mediante ROM



- Read Only Memory, memoria di sola lettura.  
Funge anche da modulo combinatorio a uscita multipla.
- n linee di ingresso, m linee di uscita (ampiezza)  
a ciascuna delle  $2^n$  (altezza) configurazioni di ingresso  
(parole di memoria) è associata permanentemente una  
combinazione delle m linee di uscita.
- l'input seleziona la parola da leggere di m bit, che appare in uscita
- L'input funziona da **indice** all'interno della ROM.

Viene realizzato con un decoder da n-ad- $2^n$  seguito da  
una matrice di m porte OR.

| $X_0$ | $X_1$ | $X_2$ | $Z_0$ | $Z_1$ |
|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     |
| 0     | 0     | 1     | 1     | 0     |
| 0     | 1     | 0     | 1     | 0     |
| 0     | 1     | 1     | 0     | 1     |
| 1     | 0     | 0     | 1     | 0     |
| 1     | 0     | 1     | 0     | 1     |
| 1     | 1     | 0     | 0     | 1     |
| 1     | 1     | 1     | 1     | 1     |

A.A. 2024-2025

21/47



## ROM - esempio



|   | $X_0$ | $X_1$ | $X_2$ | $Z_0$ | $Z_1$ |
|---|-------|-------|-------|-------|-------|
| 0 | 0     | 0     | 0     | 0     | 0     |
| 1 | 0     | 0     | 1     | 1     | 0     |
| 2 | 0     | 1     | 0     | 1     | 0     |
| 3 | 0     | 1     | 1     | 0     | 1     |
| 4 | 1     | 0     | 0     | 1     | 0     |
| 5 | 1     | 0     | 1     | 0     | 1     |
| 6 | 1     | 1     | 0     | 0     | 1     |
| 7 | 1     | 1     | 1     | 1     | 1     |



$$Z_0 = \overline{X_0} \overline{X_1} X_2 + \overline{X_0} X_1 \overline{X_2} + X_0 \overline{X_1} \overline{X_2} + X_0 X_1 X_2$$

$$Z_1 = \overline{X_0} X_1 X_2 + X_0 \overline{X_1} X_2 + X_0 X_1 \overline{X_2} + X_0 X_1 X_2$$



## EEPROM



| <b>X<sub>0</sub></b> | <b>X<sub>1</sub></b> | <b>X<sub>2</sub></b> | <b>Z<sub>0</sub></b> | <b>Z<sub>1</sub></b> |
|----------------------|----------------------|----------------------|----------------------|----------------------|
| 0                    | 0                    | 0                    | <b>0</b>             | <b>0</b>             |
| 0                    | 0                    | 1                    | <b>1</b>             | <b>0</b>             |
| 0                    | 1                    | 0                    | <b>1</b>             | <b>0</b>             |
| 0                    | 1                    | 1                    | <b>0</b>             | <b>1</b>             |
| 1                    | 0                    | 0                    | <b>1</b>             | <b>0</b>             |
| 1                    | 0                    | 1                    | <b>0</b>             | <b>1</b>             |
| 1                    | 1                    | 0                    | <b>0</b>             | <b>1</b>             |
| 1                    | 1                    | 1                    | <b>1</b>             | <b>1</b>             |



## Valutazione ROM



| <b>X<sub>0</sub></b> | <b>X<sub>1</sub></b> | <b>X<sub>2</sub></b> | <b>Z<sub>0</sub></b> | <b>Z<sub>1</sub></b> |
|----------------------|----------------------|----------------------|----------------------|----------------------|
| 0                    | 0                    | 0                    | <b>0</b>             | <b>0</b>             |
| 0                    | 0                    | 1                    | <b>1</b>             | <b>0</b>             |
| 0                    | 1                    | 0                    | <b>1</b>             | <b>0</b>             |
| 0                    | 1                    | 1                    | <b>0</b>             | <b>1</b>             |
| 1                    | 0                    | 0                    | <b>1</b>             | <b>0</b>             |
| 1                    | 0                    | 1                    | <b>0</b>             | <b>1</b>             |
| 1                    | 1                    | 0                    | <b>0</b>             | <b>1</b>             |
| 1                    | 1                    | 1                    | <b>1</b>             | <b>1</b>             |



Complessità:  $8 \cdot 2 + 2 \cdot 3 = 22$

Cammino critico:  $2 + 2 = 4$



## Confronto PLA / ROM



## Confronto PLA - ROM



ROM – fornisce un’uscita per ognuna delle combinazioni degli ingressi (mintermini e maxtermini). Decoder con  $2^n$  uscite, dove  $n$  è il numero di variabili in ingresso alla ROM. Crescita esponenziale delle uscite. Approccio più generale. Può implementare una qualsiasi funzione, dato un certo numero di input e output.

PLA – contiene solamente i mintermini in uscita al primo livello.  
Il loro numero cresce meno che esponenzialmente.

E’ più veloce una PLA o una ROM? Valutare in termini di cammino critico.

FPGA – Maggiore libertà. E’ costituita da celle: moduli di PLA. E’ una rete di strutture a 2 livelli.



## Esercizi sulla PLA



Realizzare mediante PLA con 3 ingressi con il numero adeguato di linee interne:

- la funzione maggioranza.
- la funzione che vale 1 se e solo se 1 solo bit di ingresso vale 1
- un decoder
- la funzione che vale 0 se l'input è pari, 1 se dispari
- la funzione che calcola i multipli di 3 (con 4 ingressi)

Realizzare le stesse funzioni con una ROM o con logica distribuita e operare un confronto. Fare una valutazione comparata in termini di complessità e cammino critico.



## Sommario



Implementazione circuitale mediante PLA o ROM.

Circuiti combinatori notevoli.



## Porta XOR



| a | b | y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

$$SOP: \quad y = \overline{a}\overline{b} + a\overline{b}$$

OR esclusivo  
Disuguaglianza di 2 ingressi



Complessità e cammino critico di 1 porta logica

$y = a \oplus b$



## Uscite indifferenti di un tabella delle verità



X = “don’t care” = {0,1} a seconda di quello che conviene.

| A | B | F |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | X |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

Ho 2 possibilità:

1) X = 0       $F = AB$



2) X = 1       $F = \overline{A}B + AB = B$



Diminuisce il numero di porte e si accorcia il cammino critico.



## Codificatore (encoder)



- E' caratterizzato da n linee di input e  $\text{ceil}(\log_2 n)$  linee di output



- Una sola linea di ingresso può essere attiva.
- il numero binario espresso dalla configurazione delle linee di output rappresenta la linea di ingresso attiva.
- es.: con 16 linee di input e 4 di output, se in ingresso arriva il valore 0000 0100 0000 0000<sub>2</sub>, in uscita leggiamo il numero 1010<sub>2</sub> = 10<sub>10</sub>.



## La funzione encoder



| ABCD | $Y_1 Y_2$ | Codifica quattro linee in ingresso: 0,1,2,3                                                                                                                                                                                                                                        |
|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000 | XX        | <b>Suppongo <math>X = 0</math></b>                                                                                                                                                                                                                                                 |
| 0001 | 0 0       | $Y_1 = \overline{\underline{A}} \overline{\underline{B}} \overline{\underline{C}} \overline{\underline{D}} + \overline{\underline{A}} \overline{\underline{B}} \overline{\underline{C}} \overline{\underline{D}} = \overline{\underline{C}} \overline{\underline{D}} (A \oplus B)$ |
| 0010 | 0 1       |                                                                                                                                                                                                                                                                                    |
| 0011 | XX        | $m_4 + m_8$                                                                                                                                                                                                                                                                        |
| 0100 | 1 0       |                                                                                                                                                                                                                                                                                    |
| 0101 | XX        |                                                                                                                                                                                                                                                                                    |
| 0110 | XX        | $Y_2 = \overline{\underline{A}} \overline{\underline{B}} \overline{\underline{C}} \overline{\underline{D}} + \overline{\underline{A}} \overline{\underline{B}} \overline{\underline{C}} \overline{\underline{D}} = \overline{\underline{B}} \overline{\underline{D}} (A \oplus C)$ |
| 0111 | XX        |                                                                                                                                                                                                                                                                                    |
| 1000 | 1 1       | $m_2 + m_8$                                                                                                                                                                                                                                                                        |
| 1001 | XX        |                                                                                                                                                                                                                                                                                    |
| 1010 | XX        | Complessità: $2 \cdot 3 + 1 = 7$                                                                                                                                                                                                                                                   |
| 1011 | XX        | Complessità circuito semplificato: 3                                                                                                                                                                                                                                               |
| 1100 | XX        | Cammino critico: $2 + 1 = 3$                                                                                                                                                                                                                                                       |
| 1101 | XX        | Cammino critico circuito semplificato: 2                                                                                                                                                                                                                                           |
| 1110 | XX        |                                                                                                                                                                                                                                                                                    |
| 1111 | XX        | Si può fare di meglio?<br>Come è conveniente impostare le X? <a href="http://borghese.di.unimi.it/">http://borghese.di.unimi.it/</a>                                                                                                                                               |



## La funzione encoder: ottimizzazione - I



| ABCD | Y <sub>1</sub> Y <sub>2</sub> |                                                                                                   |
|------|-------------------------------|---------------------------------------------------------------------------------------------------|
| 0000 | 0 X                           | Consideriamo la prima funzione, Y <sub>1</sub>                                                    |
| 0001 | 0 0                           |                                                                                                   |
| 0010 | 0 1                           | <b>Specifichiamo in modo opportuno i valori di uscita indifferenti, X</b>                         |
| 0011 | 0 X                           |                                                                                                   |
| 0100 | 1 0                           |                                                                                                   |
| 0101 | 1 X                           |                                                                                                   |
| 0110 | 1 X                           | $Y_1 = \bar{A} \bar{B} \bar{C} \bar{D} + \bar{A} \bar{B} \bar{C} D + \bar{A} B \bar{C} \bar{D} +$ |
| 0111 | 1 X                           |                                                                                                   |
| 1000 | 1 1                           | $\bar{A} \bar{B} C D + A \bar{B} \bar{C} \bar{D} + A \bar{B} \bar{C} D +$                         |
| 1001 | 1 X                           |                                                                                                   |
| 1010 | 1 X                           | $\bar{A} \bar{B} C D = (A \oplus B)$                                                              |
| 1011 | 1 X                           |                                                                                                   |
| 1100 | 0 X                           | Complessità: 1                                                                                    |
| 1101 | 0 X                           | Cammino critico: 1                                                                                |
| 1110 | 0 X                           |                                                                                                   |
| 1111 | 0 X                           |                                                                                                   |



## La funzione encoder: ottimizzazione - II



| ABCD | Y <sub>1</sub> Y <sub>2</sub> |                                                                                                   |
|------|-------------------------------|---------------------------------------------------------------------------------------------------|
| 0000 | 0 0                           | Consideriamo la prima funzione, Y <sub>1</sub>                                                    |
| 0001 | 0 0                           |                                                                                                   |
| 0010 | 0 1                           | <b>Specifichiamo in modo opportuno i valori di uscita indifferenti, X</b>                         |
| 0011 | 0 1                           |                                                                                                   |
| 0100 | 1 0                           |                                                                                                   |
| 0101 | 1 0                           |                                                                                                   |
| 0110 | 1 1                           | $Y_2 = \bar{A} \bar{B} \bar{C} \bar{D} + \bar{A} \bar{B} \bar{C} D + \bar{A} B \bar{C} \bar{D} +$ |
| 0111 | 1 1                           | $\bar{A} B \bar{C} D + A \bar{B} \bar{C} \bar{D} + A \bar{B} \bar{C} D + A B \bar{C} =$           |
| 1000 | 1 1                           | $A \bar{B} C D + \bar{A} B C \bar{D} + A \bar{B} C D + A B \bar{C} =$                             |
| 1001 | 1 1                           | $(A \oplus C)$                                                                                    |
| 1010 | 1 0                           |                                                                                                   |
| 1011 | 1 0                           |                                                                                                   |
| 1100 | 0 1                           | Complessità: 1                                                                                    |
| 1101 | 0 1                           | Cammino critico: 1                                                                                |
| 1110 | 0 0                           |                                                                                                   |
| 1111 | 0 0                           |                                                                                                   |



# Multiplexer



# Multiplexer (selettor)



- Ha la funzione di un sistema di semafori.
- E' caratterizzato da:
  - n linee di input (data) -  $\{x_i\}$
  - k linee di controllo (selezione) . $\{S\}$ .
  - 1 linea di output.
- In base alla linea di controllo viene connessa all'uscita la linea di ingresso selezionata.

Quante linee di controllo, k, servono?

$$k = \text{ceil}(\log_2 n)$$

Esempio: con 4 linee di input (da 0 a 3), se sulle linee di controllo c'è 11, in uscita si avrà il valore presente sulla linea 3





## AND come semaforo (interruttore)



Il segnale di selezione S, “apre” la porta opportuna, cioè chiude il cammino opportuno.

L'AND funziona da porta di uscita (da semaforo)



| S | x | y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |



## Multiplexer



| S | x <sub>0</sub> | x <sub>1</sub> | y |
|---|----------------|----------------|---|
| 0 | 0              | 0              | 0 |
| 0 | 0              | 1              | 0 |
| 0 | 1              | 0              | 1 |
| 0 | 1              | 1              | 1 |
| 1 | 0              | 0              | 0 |
| 1 | 0              | 1              | 1 |
| 1 | 1              | 0              | 0 |
| 1 | 1              | 1              | 1 |

Il circuito deve portare in uscita il contenuto della linea  $x_0$  o  $x_1$  a seconda del valore di S





## Sintesi della funzione Mux



| S | x <sub>0</sub> | x <sub>1</sub> | y |
|---|----------------|----------------|---|
| 0 | 0              | 0              | 0 |
| 0 | 0              | 1              | 0 |
| 0 | 1              | 0              | 1 |
| 0 | 1              | 1              | 1 |
| 1 | 0              | 0              | 0 |
| 1 | 0              | 1              | 1 |
| 1 | 1              | 0              | 0 |
| 1 | 1              | 1              | 1 |

SOP:  $y = \bar{S}x_0\bar{x}_1 + \bar{S}x_0x_1 + S\bar{x}_0x_1 + Sx_0\bar{x}_1$   
 $= \bar{S}x_0 + Sx_1 \quad \text{cvd}$

Il mux si comporta come interruttore:

If ( $S == 1$ ) then

$$y = x_1$$

If ( $S == 0$ ) then

$$y = x_0$$



Complessità: 3

Cammino critico: 2



## Mux a n vie.



Una sola linea alla volta viene aperta dal segnale S (una semaforo solo è verde).

**Le linee sono mutuamente esclusive.**



## Complessità di un Mux a 8 vie



Complessità = 8



## Cammino critico di un Mux a 8 vie



Cammino critico = 1





## Il Multiplexer a un ingresso di selezione è l' "if" dell'hardware



- Software

```
if A>B  
then y=A  
else y=B
```

- Hardware



## Il Multiplexer a un ingresso di selezione è l' "if" dell'hardware



- Software

```
if A>B  
then y=g(X)  
else y=f(X)
```

- Hardware



Entrambe le funzioni  
sono calcolate, ma solo  
un risultato alla volta  
viene usato!

Esecuzione  
condizionata



## Comparatore a 1 bit



| A | B | C |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

XOR

| A <sub>n</sub> | B <sub>0</sub> | C <sub>0</sub> |
|----------------|----------------|----------------|
| 0              | 0              | 1              |
| 0              | 1              | 0              |
| 1              | 0              | 0              |
| 1              | 1              | 1              |

XNOR

$$C_0 = \overline{A_0 \oplus B_0}$$



## Comparatore a n bit



- E' caratterizzato da:
  - 1 numero su n bit in ingresso, A
  - 1 numero su n bit in ingresso, B
  - 1 uscita

$$C_k = \overline{A_k \oplus B_k}$$

| A <sub>0</sub> | B <sub>0</sub> | C <sub>0</sub> | A <sub>1</sub> | B <sub>1</sub> | C <sub>1</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|
| 0              | 0              | 1              | 0              | 0              | 1              |
| 0              | 1              | 0              | 0              | 1              | 0              |
| 1              | 0              | 0              | 1              | 0              | 0              |
| 1              | 1              | 1              | 1              | 1              | 1              |

...

$$C = C_0 C_1 C_2 \dots \dots \quad C_{n-1} = (A_0 \oplus B_0) (A_1 \oplus B_1) \dots \dots (A_{n-1} \oplus B_{n-1})$$

Attraverso De Morgan:

$$C = \overline{C_0} + \overline{C_1} + \overline{C_2} \dots + \overline{C_{n-1}} = (A_0 \ominus B_0) + (A_1 \ominus B_1) + \dots + (A_{n-1} \ominus B_{n-1})$$



## Sommario



Implementazione circuitale mediante PLA o ROM.

Circuiti combinatori notevoli.