Sintesi di Reti Sequenziali Sincrone

Documenti analoghi
Sintesi di Reti sequenziali Sincrone

Sintesi di Reti Sequenziali Sincrone

Introduzione. Sintesi Sequenziale Sincrona. Modello del circuito sequenziale. Progetto e strumenti. Il modello di un circuito sincrono può essere

Introduzione - Modello. Introduzione - progetto e strumenti

Sintesi Sequenziale Sincrona Sintesi Comportamentale di reti Sequenziali Sincrone

Macchine sequenziali. Automa a Stati Finiti (ASF)

Sintesi Sequenziale Sincrona. Mariagiovanna Sami Corso di reti Logiche 8 Anno

Sintesi di Reti Sequenziali Sincrone

Macchine sequenziali

I Indice. Prefazione. Capitolo 1 Introduzione 1

Flip-flop, registri, la macchina a stati finiti

Automi a stati finiti

1. Automi a stati finiti: introduzione

FSM: Macchine a Stati Finiti

COMPITO A Esercizio 1 (13 punti) Dato il seguente automa:

Fondamenti di informatica II 1. Sintesi di reti logiche sequenziali

Esercitazioni di Reti Logiche. Lezione 5

Prova d esame di Reti Logiche T 10 Giugno 2016

Reti sequenziali sincrone

Reti sequenziali. Nord

Macchine a stati finiti. Sommario. Sommario. M. Favalli. 5th June 2007

Macchine a stati finiti. Sommario. Sommario. M. Favalli. Le macchine a stati si utilizzano per modellare di sistemi fisici caratterizzabili mediante:

Reti Logiche 1. Prof. B. Buttarazzi A.A. 2009/2010 ASF

Reti Sequenziali. Reti Sequenziali. Corso di Architetture degli Elaboratori

Reti Logiche Appello del 1 marzo 2011

I Bistabili. Maurizio Palesi. Maurizio Palesi 1

Flip-flop Macchine sequenziali

I CONTATORI. Definizioni

Macchine a stati finiti G. MARSELLA UNIVERSITÀ DEL SALENTO

Compito A. Esercizio 1 (13 punti) Minimizzare l automa descritto dalla seguente tabella degli stati

Esercitazioni di Reti Logiche

Flip-flop, registri, la macchina a stati finiti

Progetto di Contatori sincroni. Mariagiovanna Sami Corso di reti Logiche 8 Anno

Macchine a stati finiti sincrone

ITIS E. BARSANTI POMIGLIANO D ARCO CORSO DI SISTEMI ELETTRONICI AUTOMATICI Prof. Paolo Bisconti AUTOMA A STATI FINITI

Calcolatori Elettronici A a.a. 2008/2009. RETI SEQUENZIALI: ESERCIZI Massimiliano Giacomin

Calcolatori Elettronici

Esercizio 1 (12 punti) Minimizzare il numero di stati dell automa qui rappresentato. Disegnare l automa minimo.

orario ricevimento via orario ufficio risposta entro 3 giorni

Esercizi Logica Digitale,Circuiti e Bus

I bistabili ed il register file

Reti Logiche A Esame del 19 febbraio 2007

I REGISTRI. Reti autonome e contatori

Reti sequenziali. Esempio di rete sequenziale: distributore automatico.

Macchine Sequenziali

Indice. Prefazione. sommario.pdf 1 05/12/

Minimizzazione di Reti Logiche Combinatorie Multi-livello. livello

Corso di Reti Logiche

Circuiti sequenziali

Calcolatori Elettronici T. Complementi ed Esercizi di Reti Logiche

Automi. Sono così esempi di automi una lavatrice, un distributore automatico di bibite, un interruttore, una calcolatrice tascabile,...

Calcolatori Elettronici

LATCH E FLIP-FLOP PREMESSA

Circuiti sequenziali. Gli elementi di memoria: i bistabili I registri. Circuiti sequenziali e bistabili. Bistabili: : classificazione

LATCH E FLIP-FLOP PREMESSA

Circuiti sequenziali e latch

Esercizio sugli automi di Moore

Ricerca Operativa. G. Liuzzi. Lunedí 20 Aprile 2015

ELEMENTI DI PROGRAMMAZIONE a.a. 2012/13 MACCHINE, ALGORITMI, PROGRAMMI

ELEMENTI DI PROGRAMMAZIONE a.a. 2013/14 UNA GERARCHIA DI MACCHINE

Maurizio Palesi. Maurizio Palesi 1

Corso di Reti Logiche. Macchine Sequenziali. Dipartimento di Informatica e Sistemistica Università degli Studi di Napoli Federico II

FSM: Macchine a Stati Finiti

Macchine combinatorie: encoder/decoder e multiplexer/demultiplexer

A.C. Neve Esercizi Digitali 1

Esercizio 1. semaforo verde semaforo rosso T V1 VG 1. semaforo verde-giallo semaforo rosso T G V 2. semaforo rosso semaforo verde T V2 VG 2

Esercizi vari con soluzione

Flip-flop e loro applicazioni

Macchine a Stati finiti

Metodo di Quine- McCluskey

PROGRAMMA DEL DÌ AUTOMATICI

Introduzione ai microcontrollori

RIDUZIONE DEL NUMERO DI STATI DI UN AUTOMA

Calcolatori Elettronici Reti Sequenziali Asincrone

Circuiti sincroni Circuiti sequenziali: i bistabili

Tecniche di Progettazione Digitale. Reti combinatorie: Le mappe di Karnaugh

Reti Combinatorie: sintesi

Minimizzazione di Reti Logiche Combinatorie Multi-livello

Funzioni booleane. Vitoantonio Bevilacqua.

PIANO DI LAVORO DEI DOCENTI

x y z F x y z F F = x z + y z + yz + xyz G = wyz + vw z + vwy + vwz + v w y z Sommario

Esercitazione di Calcolatori Elettronici Ing. Battista Biggio. Corso di Laurea in Ingegneria Elettronica. Esercitazione 1 (Capitolo 2) Reti Logiche

Esercitazioni di Reti Logiche. Lezione 4

INTRODUZIONE ALLE MACCHINE A STATI

Esercitazioni di Reti Logiche

Programma (piano di lavoro) svolto

Circuiti sequenziali e elementi di memoria

un insieme finito di segnali d uscita U (nell ascensore U={stare fermo, salire, scendere})

Laurea Specialistica in Informatica

Transcript:

Sintesi di Reti Sequenziali Sincrone Maurizio Palesi Maurizio Palesi 1

Macchina Sequenziale Una macchina sequenziale è definita dalla quintupla (I,U,S,δ,λ ) dove: I è l insieme finito dei simboli d ingresso U è l insieme finito dei simboli d uscita S è l insieme finito e non vuoto degli stati δ è la funzione stato prossimo λ è la funzione d uscita La funzione stato prossimo δ :S I S associa ad ogni stato presente per per ogni simbolo di ingresso uno stato futuro La funzione d uscita λ genera un simbolo d uscita Macchina di Mealy: L uscita dipende sia dallo stato sia dall ingresso (λ :S I U) Macchina di Moore: L uscita dipende solamente dallo stato (λ :S U) Maurizio Palesi 2

Modello di Huffman X 1 Z 1 X 2 Z 2 X 3 X n Ingressi RETE COMBINATORIA δ, λ Z 3 Z m Uscite FF 1 Stato presente S t Y Y Stato prossimo S t+1 1 1 Y 2 FF 2 Y 2 Y k FF k Y k Memoria di stato Maurizio Palesi 3

Sintesi di una Rete Sequenziale Il problema della sintesi di una rete sequenziale consiste nella Identificazione delle funzioni δ e λ Sintesi della rete combinatoria che le realizza Gli elementi di memoria sono costituiti da Flip-Flop I flip-flop di tipo D sono quelli usati più comunemente La funzione stato prossimo dipende dal tipo di bistabile utilizzato La funzione d uscita non dipende dal tipo di bistabile utilizzato Maurizio Palesi 4

Tabella degli Stati Una Macchina a Stati Finiti (FSM) può essere descritta mediante la Tabella degli stati in cui Gli indici di colonna sono i simboli di ingresso i α I Gli indici di riga sono i simboli dello stato presente s j S Gli elementi della tabella sono La coppia {u β, s k } con u β =λ (i α,s j ) e s k =δ (i α,s j ) (Macchine di Mealy) Il simbolo stato prossimo s k =δ (i α,s j ) (Macchine di Moore) Nelle macchine di Moore i simboli d uscita sono associati allo stato presente Maurizio Palesi 5

Tabella degli stati Macchina di Mealy Stato attuale s 1 t s 2 t Macchina di Moore Stato attuale s 1 t s 2 t Ingresso i 1 i 2 s j t+1 /u j s k t+1 /u k s m t+1 /u m s n t+1 /u n Ingresso i 1 i 2 s j t+1 s m t+1 s k t+1 s n t+1 u 1 u 2 Maurizio Palesi 6

Diagramma degli Stati Spesso la stesura della tabella degli stati è preceduta dalla costruzione di una rappresentazione grafica equivalente denominata Diagramma degli stati Il diagramma degli stati è un grafo orientato G(V,E,L) V: Insieme dei nodi Ogni nodo rappresenta uno stato Ad ogni nodo è associato un simbolo d uscita (macchine di Moore) E: Insieme degli archi Ogni arco rappresenta una transizione di stato L: Insieme degli: Ingressi e Uscite (macchine di Mealy) Ingressi (macchine di Moore) Maurizio Palesi 7

Da Diagramma a Tabella degli Stati Macchine di Mealy S i i x /u y S j Stato attuale Ingresso i x s i s j /u y Macchine di Moore S i /u i i x S j /u j Stato attuale Ingresso i x s i s j u i Maurizio Palesi 8

Macchina di Mealy - Esempio 0/1 S 0 S 1 1/0 1/1 S 2 0/1 1/1 0/0 0 1 S0 S 1 /1 S 2 /1 S1 S 1 /0 S2/1 S2 S 2 /1 S 0 /0 Maurizio Palesi 9

Macchina di Moore - Esempio 0 S 0 /1 S 1 /0 0 1 1 S 2 /1 0 1 0 1 S0 S 1 S 2 1 S1 S 1 S2 0 S2 S 2 S 0 1 Maurizio Palesi 10

Sintesi di Reti Sequenziali Sincrone Il procedimento generale di sintesi si svolge nei seguenti passi: 1. Realizzazione del diagramma degli stati a partire dalle specifiche del problema 2. Costruzione della tabella degli stati 3. Minimizzazione del numero degli stati 4. Codifica degli stati interni 5. Costruzione della tabella delle transizioni 6. Scelta degli elementi di memoria 7. Costruzione della tabella delle eccitazioni 8. Sintesi sia della rete combinatoria che realizza la funzione stato prossimo sia di quella che realizza la funzione d uscita Maurizio Palesi 11

Codifica degli Stati Interni Il processo di codifica degli stati ha l obiettivo di identificare per ogni rappresentazione simbolica dello stato una corrispondente rappresentazione binaria In seguito alla codifica la Tabella degli stati viene trasformata in Tabella delle Transizioni In questa fase è necessario affrontare i seguenti problemi Scelta del codice A minimo numero di bit One-Hot Distanza Minima Identificazione della codifica di ogni stato Maurizio Palesi 12

Codifica degli Stati Interni Una volta scelto il codice, la codifica degli stati influisce sia sull area sia sulle prestazioni del dispositivo Il problema della identificazione della codifica ottima è un problema NP-completo Il numero di possibili codifiche per il codice a minimo numero di bit è: 2 [ log S 1! 2 [ log S S!*[ log S ]! Es.: Per S =8 si hanno 840 possibili codifiche Spesso, scelto il codice si preferisce non ricorrere ad alcuna strategia di codifica Maurizio Palesi 13

Codifica degli Stati Interni Binario Naturale Il numero di bit è minimo Al primo stato corrisponde la configurazione di bit associata a 0, al secondo stato corrisponde la configurazione di bit associata a 1, L ordinamento degli stati è quello determinato in fase di realizzazione della tabella degli stati One-Hot Il numero di bit è pari al numero degli stati In ogni codifica un solo bit assume il valore 1, tutti gli altri assumono valore 0 Binario naturale Hot-One S0 00 0001 S1 01 0010 S2 10 0100 S3 11 1000 Maurizio Palesi 14

Esempio Specifica Realizzare la sintesi di un sistema con due ingressi ed una uscita che abbia il seguente comportamento: Ingressi 00: l uscita non cambia valore Ingressi 01: l uscita assume il valore 0 Ingressi 10: l uscita assume il valore 1 Ingressi 11: l uscita assume il valore opposto Maurizio Palesi 15

Esempio Passo 1 (Diagramma degli stati) S 0 /0 S 1 /1 Maurizio Palesi 16

Esempio Passo 1 (Diagramma degli stati) 00 00 S 0 /0 S 1 /1 Ingressi 00: L uscita non cambia valore Maurizio Palesi 17

Esempio Passo 1 (Diagramma degli stati) 00 00 01 S 0 /0 S 1 /1 01 Ingressi 01: L uscita assume il valore 0 Ingressi 00: L uscita non cambia valore Maurizio Palesi 18

Esempio Passo 1 (Diagramma degli stati) 10 00 00 01 S 0 /0 S 1 /1 10 Ingressi 10: L uscita assume il valore 1 01 Ingressi 01: L uscita assume il valore 0 Ingressi 00: L uscita non cambia valore Maurizio Palesi 19

Esempio Passo 1 (Diagramma degli stati) 10 11 00 00 01 S 0 /0 S 1 /1 10 Ingressi 10: L uscita assume il valore 1 01 11 Ingressi 01: L uscita assume il valore 0 Ingressi 11: L uscita assume il valore opposto Ingressi 00: L uscita non cambia valore Maurizio Palesi 20

Esempio Passo 2 (Tabella degli stati) 10 11 00 00 01 S 0 /0 S 1 /1 10 01 11 Stato Ingresso S 0 S 0 S 0 S 1 S 1 0 S 1 S 1 S 0 S 0 S 1 1 Maurizio Palesi 21

Esempio Stato Ingresso S 0 S 0 S 0 S 1 S 1 0 S 1 S 1 S 0 S 0 S 1 1 Passo 4 (Codifica degli stati interni) Es. Codifica Naturale S 0 = 0 S 1 = 1 S 0 = 1 S 1 = 0 Passo 5 (Tabella delle transizioni) Stato Ingresso 0 0 0 1 1 0 1 1 0 0 1 1 Stato Ingresso 1 1 1 0 0 0 0 0 1 1 0 1 Maurizio Palesi 22

Esempio Stato Ingresso S 0 S 0 S 0 S 1 S 1 0 S 1 S 1 S 0 S 0 S 1 1 Passo 4 (Codifica degli stati interni) Es. One-Hot S 0 = 01 S 1 = 10 Passo 5 (Tabella delle transizioni) Stato Ingresso 01 01 01 10 10 0 10 10 01 01 10 1 Maurizio Palesi 23

Scelta degli Elementi di Memoria La tabella delle transizioni descrive la relazione tra i bit dello stato presente e quelli dello stato futuro La configurazione in bit dello stato presente è in diretta corrispondenza con l uscita degli elementi di memoria La configurazione in bit dello stato futuro indica ciò che si vuole ottenere Cambiando il tipo dei bistabili variano i segnali che bisogna generare per realizzare la transizione stato presente-stato futuro I segnali di ingresso di un bistabile prendono il nome di eccitazioni La tabella delle eccitazione di un bistabile rappresenta lo strumento per passare dalla tabella delle transizioni alla tabella delle eccitazioni di una specifica macchina a stati Maurizio Palesi 24

Scelta degli Elementi di Memoria X 1 Z 1 Ingressi X 2 X 3 X n Rete combinatoria derivata dalla tabella delle transizioni Z 2 Z 3 Z m Uscite Stato prossimo S t+1 Stato presente S t Y 1 Y 2 Y 1 Eccitazioni Y 2 Rete combinatoria per la trasformazione stato-eccitazione Rete combinatoria derivata dalla tabella delle eccitazioni Y k Registri di stato Y k Memoria di stato Maurizio Palesi 25

Scelta degli Elementi di Memoria λ Ingressi δ Uscite Memoria di stato Clock Maurizio Palesi 26

Tabelle delle Transizioni ed Eccitazioni Tabelle delle Transizioni C S R * 0 - - 1 0 0 1 0 1 0 1 1 0 1 1 1 1 - C J K * 0 - - 1 0 0 1 0 1 0 1 1 0 1 1 1 1 C D * 0-1 0 0 1 1 1 C T * 0-1 0 1 1 Tabelle delle Eccitazioni * C S R 0 0 0 - - 1 1 0 - - 0 0 1 0-0 1 1 1 0 1 0 1 0 1 1 1 1-0 * C J K 0 0 0 - - 1 1 0 - - 0 0 1 0-0 1 1 1-1 0 1-1 1 1 1-0 * C D 0 0 0-1 1 0-0 0 1 0 0 1 1 1 1 0 1 0 1 1 1 1 * C T 0 0 0-1 1 0-0 0 1 0 0 1 1 1 1 0 1 1 1 1 1 0 Maurizio Palesi 27

Scelta Bistabile e Costruzione Tabella delle Eccitazioni (Passo 3) Codifica Naturale S 0 =0, S 1 =1 (Passo 5) Tabella delle Transizioni (Passo 6) Scelta del Bistabile 0 0 0 1 1 0 1 1 0 0 1 1 * C S R 0 0 0 - - 1 1 0 - - 0 0 1 0-0 1 1 1 0 1 0 1 0 1 1 1 1-0 (Passo 7) Costruzione Tabella delle eccitazioni 0 0-0- 10 10 0 1-0 01 01-0 1 Maurizio Palesi 28

Sintesi Stato (Passo 8) Sintesi Mappa di Karnaugh per S 0 0-0- 10 10 0 1-0 01 01-0 1 U = Tabella delle eccitazioni Mappa di Karnaugh per R 0 0 0 1 1 1-0 0 - S = I H 0 - - 0 0 1 0 1 1 0 R = I L C K I H I L S R FF SR U Maurizio Palesi 29

Scelta Bistabile e Costruzione Tabella delle Eccitazioni (Passo 3) Codifica Naturale S 0 =0, S 1 =1 (Passo 5) Tabella delle Transizioni (Passo 6) Scelta del Bistabile 0 0 0 1 1 0 1 1 0 0 1 1 * C J K 0 0 0 - - 1 1 0 - - 0 0 1 0-0 1 1 1-1 0 1-1 1 1 1-0 (Passo 7) Costruzione Tabella delle eccitazioni 0 0-0- 1-1- 0 1-0 -1-1 -0 1 Maurizio Palesi 30

Sintesi (Passo 8) Sintesi Mappa di Karnaugh per J 0 0-0- 1-1- 0 1-0 -1-1 -0 1 U = Tabella delle eccitazioni Mappa di Karnaugh per K 0 0 0 1 1 1 - - - - J = I H 0 - - - - 1 0 1 1 0 R = I L C K I H I L J K FF JK U Maurizio Palesi 31

Scelta Bistabile e Costruzione Tabella delle Eccitazioni (Passo 3) Codifica Naturale S 0 =0, S 1 =1 (Passo 5) Tabella delle Transizioni (Passo 6) Scelta del Bistabile 0 0 0 1 1 0 1 1 0 0 1 1 * C D 0 0 0-1 1 0-0 0 1 0 0 1 1 1 1 0 1 0 1 1 1 1 (Passo 7) Costruzione Tabella delle eccitazioni 0 0 0 1 1 0 1 1 0 0 1 1 Maurizio Palesi 32

Sintesi 0 0 0 1 1 0 1 1 0 0 1 1 U = Tabella delle eccitazioni (Passo 8) Sintesi Mappa di Karnaugh per D 0 0 0 1 1 1 1 0 0 1 D = I H + I L I H I L C K D FF D U Maurizio Palesi 33

Scelta Bistabile e Costruzione Tabella delle Eccitazioni (Passo 3) Codifica Naturale S 0 =0, S 1 =1 (Passo 5) Tabella delle Transizioni (Passo 6) Scelta del Bistabile 0 0 0 1 1 0 1 1 0 0 1 1 * C T 0 0 0-1 1 0-0 0 1 0 0 1 1 1 1 0 1 1 1 1 1 0 (Passo 7) Costruzione Tabella delle eccitazioni 0 0 0 1 1 0 1 0 1 1 0 1 Maurizio Palesi 34

Sintesi 0 0 0 1 1 0 1 0 1 1 0 1 U = Tabella delle eccitazioni (Passo 8) Sintesi Mappa di Karnaugh per T 0 0 0 1 1 1 0 1 1 0 T = I H + I L I H I L C K T FF T U Maurizio Palesi 35