Esercitazioni pratiche di elettronica/Logica Combinatoria/Sommare due parole di 4 bit

Indice del libro

Sommatore completo a 4 bit di tipo RIPPLE CARRY modifica

In questa lezione procederemo ad implementare un sommatore completo a 4 bit di tipo RIPPLE CARRY ovvero a propagazione del riporto. Trattasi di un sommatore più lento rispetto alla versione LOOK-AHEAD-CARRY.

Lo schema modifica

 

La somma delle due parole a bit, A[3:0] e B[3:0], viene effettuata ponendo in cascata 4 Full-Adder, collegati in modo che il riporto della cifra precedente, CYOUT, venga inviato all'ingresso di riporto, CYIN, della cifra successiva. L'uscita sarà ancora una parola a 4 bit, SUM[3:0], più l'ultimo riporto in uscita, CYOUT, ottenendo così un totale di 5 bits in uscita.

  • Non dimenticare mai il riporto in uscita ad una somma se non si vogliono perdere cifre significative.

Questo risultato è congruente con il fatto che 4 bits contengono i numeri da 0 a 15 e che sommando due parole di 4 bits potremmo ottenere al massimo, quale risultato, il numero 30 che pùo essere contenuto in un numero di almeno 5 bits.


Bus e Tap modifica

 

Un BUS è un insieme di connessioni, NETS, che hanno lo stesso nome ma indicizzate. Ad esempio il bus A[3:0], (è questa la sintassi da adoperare per definire un BUS), contiene al suo interno 4 NET che separatamente assumono i nomi A[0], A[1], A[2], A[3], e le quali possono essere estratte dal BUS stesso per essere collegate opportunamente tramite gli oggetti che nell'ISE vengono chiamati TAP.

NB:la NET che viene collegata al TAP deve essere rinominata in modo congruente con i nomi delle NETS contenute nel BUS dal quale il TAP sta estraendo la singola NET.

A proposito ancora della sintassi, A[3:0] mi dice che il BUS A si estende ordinatamente a partire da A[3] fino ad A[0]. In modo equivalente da punto di vista elettronico, avremmo potuto chiamare il BUS A con il nome A[0:3] ottenendo lo stesso risultato, è solo una questione di abitudine. Io preferisco la prima soluzione dove la sintassi è:

NOME_DEL_BUS[MAX_INDEX:MIN_INDEX]

ma come ripeto ugualmente buona è la sintassi:

NOME_DEL_BUS[MIN_INDEX:MAX_INDEX]

Riporto precedente alla cifra successiva modifica

 


Da questa immagine si vede come il riporto in uscita dalla somma della prima cifra, effettuata col primo sommatore, CYOUT, viene inviato all'ingresso del sommatore per le cifre di peso successivo all'ingresso di riporto CYIN.

Somma + Riporto modifica

 

Qui sono evidenziati il BUS somma, SUM[3:0] ed il riporto in uscita dall'ultimo sommatore.

Il riporto in ingresso alla cifra di peso zero viene forzato a GND modifica

 

Poiché non abbiamo nessun riporto all'inizio della somma è necessaria questa forzatura del primo ingresso CYIN.


La piedinatura modifica

Si effettua ora la piedinatura dello schema creando un nuovo file sorgente di tipo IMPLEMENTATION CONSTRAINTS FILE. Assegneremo il BUS A[3:0] a 4 switch ed il BUS B[3:0] a gli altri 4 switch rimanenti; per le uscite faremo in modo di inviare il BUS SUM[3:0] a 4 LED ed useremo un quinto LED per il riporto in uscita.

 

L'implementazione e il test modifica

  • Dopo aver effettuato il caricamento del file di programma, sum4bit.jed all'interno del device, settare i switch in modo da assegnare a ciascun bus d'ingresso, A[3:0] e B[3:0], un valore numerico da 0 a 15 a scelta.
  • Osservare la configurazione binaria dei LEDs; il risultato ottenuto è esatto?
  • Rispondere più volte a questa domanda con diverse configurazioni dei bus, in modo da controllare l'esatto funzionamento del sommatore.


La simulazione modifica

 

Sono stati assegnati alcuni valori ai bus di ingresso; osservare la configurazione del bus di uscita, SUM[3:0] e del bit di riporto, CYOUT.

NB:Una simulazione esaustiva, comprendente cioè tutte le possibili combinazioni dei due bus, qui non viene effettuata perché altrimenti troppo lunga in quanto comprenderebbe   combinazioni differenti.