Sistemi digitaliUn sistema o circuito digitale è un sistema dinamico artificiale che manipola in modo numerico (0 e 1) segnali numerici di ingresso, che rappresentano l'informazione da elaborare, per produrre segnali di uscita anch'essi numerici. NascitaL'uomo, anche senza esserne cosciente, ha sempre avuto a che fare con la logica e con essa la logica binaria, il linguaggio comune che usiamo spesso non fa altro che associare un valore di verità ad una frase, la formalizzazione matematica, e quindi l'idea base che ha dato vita a tutti i circuiti digitali antichi e moderni, della parte dell'algebra che opera con soli due valori possibili si può far risalire a George Boole. Se però all'epoca di Boole questi studi attraevano solo i logici matematici, con l'invenzione delle valvole termoioniche e successivamente dei transistori divennero la base dell'elettronica e tuttora descrivono il modo con cui opera qualsiasi calcolatore dalla calcolatrice al Road Runner di Los Alamos. FondamentiUn circuito digitale opera con numeri che possono assumere solo due valori, alto o basso, 1 o 0, per questo vengono detti numeri binari. Tutte le operazioni che svolgono gli attuali sistemi, anche le più complesse, derivano da tale semplicità. Contare in binarioContare in binario non è molto diverso dal contare in decimale, l'unica differenza è che si hanno 2 simboli invece che 10. Quindi se in decimale si ha: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 ed una volta finiti i simboli si ricomincia da capo aggiungendo una cifra: 10, 11, 12, 13, 14, 15, 16, 17... in digitale sarà lo stesso: 0, 1 Finiti i simboli si aggiunge una cifra (detta bit) 10, 11 (che si leggeranno uno, zero e uno, uno e non dieci e undici) e ancora 100, 101, 110, 111... Operazioni logicheLe operazioni logiche che si possono applicare ad un bit sono: La negazione, detta NOT che trasforma uno zero in un uno e viceversa.
Il circuito che realizza questa funzione, detto porta not, è:
La AND che riguarda due o più bit; il risultato di tale operatore è 1 solo se tutti i bit in ingresso sono 1.
Il circuito che realizza questa funzione, detto porta AND, è:
La OR che riguarda due o più bit; il risultato di tale operatore è 1 se uno qualsiasi dei bit di ingresso è 1.
Il circuito che realizza questa funzione, detto porta OR, è:
La OR esclusiva, detta XOR; il risultato di tale operatore è 1 se i bit di ingresso sono esclusivamente ad 1.
Rappresentare l'informazioneUna successione di bit qualsiasi potrebbe significare qualsiasi cosa, essere una porzione di una riga di codice, una parte di informazione di una immagine oppure un semplice numero, da questa "confusione" nasce l'esigenza di una corretta codifica delle stringhe binarie, ovvero bisogna sapere cosa si vuole rappresentare ed esplicitare come lo si sta facendo affinché tutti interpretino bene i dati che stanno leggendo. Si prendano ora in esame solo i numeri interi positivi e relativi decimali. La prima ed intuitiva regola per rappresentare i numeri interi positivi decimali in binario è peso-posizione, cioè si associa a ciascun numero decimale il suo corrispettivo binario, tale metodo è detto binario naturale
Da questa semplice tabella è facile vedere la semplice associazione che si fa tra binario e decimale. Inoltre è possibile capire un'altra semplice regola: In base dieci con una cifra (un bit) posso rappresentare dieci numeri poiché ho dieci diversi simboli (0, 1, 2, 3, 4, 5, 6, 7, 8, 9) In base 2 con un bit posso rappresentare due numeri poiché ho due diversi simboli 0 e 1, quindi posso contare da 0 a 1. In base dieci con 2 cifre posso contare fino a 99 cioè rappresentare 100 numeri (compreso lo 0), in base 2 con 2 bit posso contare 00, 01, 10, 11 cioè 4 numeri; Generalizzando questo discorso possiamo concludere che in base B con N bit si possono rappresentare numeri e contare da 0 a Un occhio di riguardo per il simbolo (uno, zero) esso in qualsiasi base si conta rappresenta sempre la base, se tradotto in decimale, in numeri: in base 2, 10 è il decimale 2, infatti se si prova a contare 00 = 0, 01 = 1, 10 = 2! In base 3, 10 è il decimale 3, 00 = 0, 01 = 1, 02 = 2, 10 = 3! In base 4, 10 è il decimale 4, 00 = 0, 01 = 1, 02 = 2, 03 = 3, 10 = 4! E così via. Questa rappresentazione così semplice ha un grosso limite, non riesce a rappresentare numeri negativi! Per ovviare a tale inconveniente è stata inventata la codifica binario naturale modulo e segno. In tale codifica il primo bit di ogni numero rappresenta il segno, se 0 il numero è positivo, se 1 il numero è negativo.
Anche sapendo rappresentare i numeri negativi, questa codifica non è utilizzata sia perché si perde un bit per rappresentare il segno ma soprattutto perché lo zero è rappresentato due volte! Un altro passo intermedio verso la codifica "ideale" è stato fatto con l'introduzione del complemento a 1. In questa codifica per passare da numero positivo a numero negativo basta "negare" tutte le cifre:
Ma anche qui la doppia codifica dello zero rappresenta una debolezza importante. L'ultimo passo è stato compiuto con la rappresentazione in complemento a 2. Questa codifica si ottiene dal binario naturale in due passi:
Sfrutta tutte le combinazioni possibili con N bit, ed elimina la ridondanza dello zero. Sintesi dei circuiti logici combinatoriMappe KLe mappe K è un metodo per determinare la forma minima di una switching expression. Ovviamente a tale risultato si può arrivare applicando in modo corretto l'algebra di Boole. Esempi, Mux, Demux, ComparatoreMUX= Multiplexer: un dispositivo che consente di indirizzare in uscita le informazioni presenti su uno degli n ingressi dati tramite l'attivazione degli ingressi di selezione. Il dispositivo si attiva con l'enable. Macchina a stati finitiI blocchi combinatori finora analizzati, per quanto complessi, operano sempre seguendo una tabella di verità, non sono in grado di implemetare una minima intelligenza. In elettronica digitale c'è la necessità di sviluppare degli algoritmi, ovvero una successione temporalmente stabilita di azioni precise e ripetibili dipendenti dagli ingressi dati alla macchina; ovvero c'è la necessità di creare un automa. Un automa per definizione è costituito da:
L'automa evolve da uno stato interno all'altro a seconda degli ingressi, producendo ogni volta il set desiderato di uscite; tale evoluzione è definita temporalmente. Una precisazione importante riguarda l'evoluzione temporale della macchina: se il registro di stato varia al solo comando di un segnale detto clock allora la macchina si dice sincrona se questo non è vero la macchina si dice asincrona. Preferiremo le macchine sincrone nelle prossime architetture. Per descrivere tale complessità il metodo più semplice risulta essere la stesura di una A.S.M.(algoritmic state machine) che sarà traducibile in HW poiché si stabilisce una serie di relazioni biunivoche tra elementi circuitali e ASM. Riassumendo l'automa sarà circuitalmente implementato da una macchina a stati finiti di cui si definiranno:
Secondo il modello di Moore. Tali elementi saranno sintetizzati da mappe K del diagramma di flusso che rappresenta l'algoritmo da eseguire e far eseguire. Un diagramma di flusso è costituito da 3 blocchi fondamentali: Blocco di stato, blocco di uscita condizionale e blocco di condizione Utilizzando tali blocchi si può descrivere qualsiasi algoritmo. Vediamo l'esempio di un contatore di eventi sincrono. Ipotizziamo di voler contare fino a 3, quindi 4 numeri, che significa come detto prima 2 bit per il conteggio, e ipotizziamo che la macchina debba essere sensibile solo ai cambiamenti di una linea detta go. Istanziazione e ASM Nella prima parte dell'immagine si vede l'istanziazione del blocco con tutte le entrate e le uscite. Nella seconda parte è riportato il diagramma di flusso del contatore sincrono, che effettivamente traduce l'algoritmo in una serie di blocchi, mentre nell'ultima parte è riportata la sintesi del blocco combinatorio di uscita Y0 e del blocco combinatorio di ingresso A (per semplicità non si riportano gli altri, facilmente intuibili da Y0 e A). Mentre la composizione della mappa K di Y0 è immediata, così non è per PROX.A la tabella della A prossima deve essere completata guardando appunto il prossimo A e non il presente così che la macchina saprà dove deve andare al clock successivo. Una precisazione importante per quanto riguarda il clock macchina, esso detiene sempre il comando totale sull'automa, se teniamo fermo il clock il dispositivo non si muove qualsiasi sia GO; ecco perché tale macchina è detta asincrona! Se però il clock è molto più lento del segnale GO si rischia di perdere degli eventi. Esistono due soluzioni:
Per risparmiare commutazioni, e quindi energia consumata dai flip flop dei registri di stato, essi possono anche essere codificati secondo 'Grey' ovvero: 00, 01, 11, 10. Come si vede varia solo uno dei bit alla volta. Con questi metodi è possibile implementare tutte le macchine a stati finiti che la nostra fantasia riesce a generare per ottemperare ai compiti più disparati. In fin dei conti è la macchina a stati finiti il vero cervello di ogni circuito digitale! MemorieFlip FlopVHDLStoriaAll'inizio degli anni ottanta, il Dipartimento della Difesa americano desiderava creare un linguaggio standard di descrizione e documentazione di sistemi hardware per avere indipendenza nei confronti dei loro fornitori. Da queste intenzioni nascerà il VHDL (acronimo di VHSIC Hardware Description Language, dove "VHSIC" è la sigla di Very High Speed Integrated Circuits). Nel tempo il VHDL si affermerà sempre di più e nel 1987 verrà normalizzato dall'IEEE (Institute of Electrical and Electronics Engineers). Nel 1993 una nuova versione dell'IEEE ha permesso di sfruttare a pieno le potenzialità del linguaggio in particolare per:
Il VHDL non è un linguaggio direttamente eseguibile ovvero non descrive quali operazioni un esecutore deve svolgere per ricavare il risultato di una elaborazione, bensì descrive gli elementi che costituiscono il circuito digitale in grado di effettuare l'elaborazione richiesta. Una specifica VHDL non è quindi eseguibile e deve essere pensata come qualche cosa di completamente diverso da un programma o un algoritmo, tuttavia può essere simulata mediante opportuni strumenti. Simulare una specifica VHDL significa simulare il comportamento del circuito che la specifica descrive, quindi, ancora una volta, non si tratta di nulla di simile alla esecuzione di un programma. Principi di funzionamentoÈ un linguaggio estremamente ricco e flessibile, permette di fornire specifiche di circuiti digitali a diversi livelli di astrazione, in particolare:
Molto importante, quanto meno per capire meglio il funzionamento di un sintetizzatore digitale, è comprendere che la stessa funzione digitale può essere implementata con diverse soluzioni hardware, ad esempio un multiplexer può essere implementato in due modi:
Già con questi piccoli esempi ci si rende conto di come diversi sintetizzatori possono produrre hardware diversi con lo stesso codice in ingresso, e questo non accade solo per software diversi (tipo VHDL e verilog) ma anche tra diverse versioni dello stesso software, ecco perché diventa molto importante definire dall'inizio quale e che versione di sintetizzatore digitale si usa. Schede elettroniche programmabiliUna FPGA (Field Programmable Gate Array) è un circuito integrato digitale ad alta scala di integrazione gestibile dall'utente. In esso sono state localizzate fisicamente un numero consistentemente grande di insiemi di porte logiche equivalenti e flip-flop. La connessione tra queste unita logiche può essere configurata e riconfigurata (da qui il concetto di programmable) dall'utente attraverso opportuni tools SW per realizzare le funzioni e le funzionalità logiche progettate. Il risultato di questo flusso, definibile come programma di utente o applicativo o file di configurazione, è un file binario che contiene l'immagine virtuale della logica di utente che una volta caricata nel componente scelto fornirà un'immagine reale del progetto. Il caricamento del file nella fisicità della logica configurabile è quell'operazione definita come programmazione del componente. Possiamo dividere, da un punto di vista didattico, le logiche programmabili in due categorie: PLD (Programmable Logic Device) e FPGA (Field Programmable Gate Array). Gli FPGA sono formati da blocchi logici combinatori corrdati da FF circondati da una complessa struttura di canali di interconnessione (o routing) segmentati. Il blocco logico di un FPGA è basato sulla look-up table (LUT) che rappresenta una funzione booleana di quattro ingressi e una uscita e il flip flop che rappresenta l'elemento sequenziale anche in questo caso escludibile se necessario. Voci correlate |
Portal di Ensiklopedia Dunia