1 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Mauro Pullin PROGETTARE CON LA METODOLOGIA DEI DATA FLOW DIAGRAMS DI YOURDON E DE MARCO _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 2 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 0. SOMMARIO 1. PREMESSA 2. PRINCIPALI CARATTERISTICHE DEI DFD 3. ELEMENTI COSTITUTIVI DEI DFD 3.1. Flusso dei Dati 3.2. Processo 3.3. Data store 3.4. Origine e Destinatario dei Dati 3.5. La Legge di Weinberg 4. REGOLE DI DISEGNO DEI DFD 4.1. Identificazione degli input primari e degli output finali 4.2. Riempimento dell’interno del DFD 4.3. Attribuzione di un nome a flussi, data store, origini e destinatari 4.4. Attribuzione di un nome ai processi 4.5. Rappresentazione dei flussi di dati e non di quelli di controllo 4.6. Prepararsi a ricominciare 5. SCOMPOSIZIONE A LIVELLI 5.1. Approccio top-down: il concetto di scomposizione a livelli 5.2. Componenti di DFD a livelli 5.3. Convenzioni 5.4. Determinazione del livello finale 6. BIBLIOGRAFIA _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 3 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 1. PREMESSA Nella realtà odierna, in qualsiasi organizzazione il Sistema Informativo rappresenta il tessuto connettivo fra tutti i soggetti, gli organi e le funzioni all’interno dell’organizzazione stessa. Attraverso i suoi canali fluiscono tutte le informazioni necessarie all’attuazione dei processi decisori, esecutivi e di controllo. Esso consiste in una serie di canali, procedure e strumenti aventi per oggetto la raccolta, l’elaborazione, la conservazione e la trasmissione di dati, informazioni e notizie. L’analisi strutturata ha fra i suoi obiettivi quello di dotarsi di un semplice strumento grafico di scomposizione dell’area oggetto delle specifiche. Il principale strumento di scomposizione in nostro possesso è il Diagramma di Flusso dei Dati (DFD). Un Diagramma di Flusso dei Dati è una rappresentazione reticolare di un Sistema, che può essere automatico, manuale o misto. Esso ci rappresenta il sistema mettendo in evidenza tutti gli elementi che lo compongono, con le interfacce esistenti tra i componenti stessi [1]. In figura 1 è rappresentato un primo esempio di Data Flow Diagram (d’ora in poi si utilizzerà l’acronimo “DFD”). Molti autori, per enfatizzarne la leggibilità, sono soliti dire frasi del tipo “un DFD vale mille parole” (o anche più). Esistono comunemente altre espressioni con cui in letteratura ci si riferisce ai DFD: Diagrammi di Flusso di Dati, Data Flow Graphs, Grafici di Flusso dei Dati, Bubble Charts. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 4 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Figura 1 _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 5 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 2. PRINCIPALI CARATTERISTICHE DEI DFD Di seguito vengono elencate le principali caratteristiche dei DFD. I diagrammi di flusso dei dati: • sono espressi in forma grafica; • sono scomponibili; • sono multidimensionali; • enfatizzano il flusso dei dati (a differenza di quanto accade negli approcci di tipo procedurale); • trascurano il flusso di controllo. L’uso dei DFD in fase di analisi consente di rappresentare la realtà dal punto di vista dei dati e non da quello di qualsiasi persona, ente o organizzazione che interagisca con essi. Questo costituisce una significativa inversione del modo di procedere nell’analisi. Nel modo di procedere tradizionale si studiano le operazioni dal punto di vista dell’utente e conseguentemente si imposta l’attività di indagine per apprendere come egli opera. Quando, invece, si effettua lo studio secondo i modelli proposti dall’Analisi Strutturata si cerca di “fotografare” l’attività di un sistema come “visto dai dati” e non dal punto di vista di chi tratta i dati. Il vantaggio di questo approccio è che i dati “vedono” la globalità del sistema, mentre le persone e le organizzazioni che con esso interagiscono vedono solo una porzione del tutto. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 6 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 3. ELEMENTI COSTITUTIVI DEI DFD Gli elementi basilari che compongono i DFD sono cinque: 1. 2. 3. 4. 5. Flussi (Data Flow), rappresentati per mezzo di linee orientate; Processi (Process), rappresentati per mezzo di cerchi (detti anche “bolle”); Data store (archivi), rappresentati per mezzo di rettangoli aperti; Origini (Source) di dati, rappresentati per mezzo di rettangoli; Destinatari (Sink) di dati, rappresentati per mezzo di rettangoli. Oltre ai cinque elementi sopra citati, a volte se ne considera anche un sesto: 6. Dizionario dei Dati (Repository), che contiene l’elenco di tutti gli oggetti, con descrizione ed eventuale scomposizione in oggetti elementari. Figura 2 In figura 2 è rappresentata una porzione di DFD che comprende tutti e cinque gli elementi. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 7 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Coerentemente con la modalità operativa che prevede di concentrarsi principalmente sui flussi di dati, la figura 2 si legge nel modo seguente: X arriva dall’origine S e viene trasformato in Y dal processo P1 (che richiede l’accesso all’archivio F). Successivamente Y viene trasformato in Z dal processo P2. I processi P1 e P2 debbono ricevere i loro nomi dai flussi di dati che entrano ed escono da loro. Ad esempio, P2 potrebbe essere chiamato “trasformazione di Y in Z”. Nell’analisi classica, invece, i flussi avrebbero dovuto chiamarsi in funzione del processo con cui interagiscono direttamente e quindi Y si sarebbe chiamato “entità generata da P1 per essere usata da P2”, con evidenti lacune di chiarezza. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 8 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 3.1. Flusso dei Dati Si definisce Flusso dei Dati una connessione tra elementi del DFD attraverso cui scorrono pacchetti di informazioni congruenti. I flussi dei dati rappresentano l’interfaccia tra due componenti di un DFD. Essi attraversano processi, entrano o escono da data store, provengono da origini e vanno verso destinatari di dati. Essi sono raffigurati tramite una linea orientata e chiamati in modo preciso. Si osservi ora la figura 3. Figura 3 Si supponga di sapere dal Dizionario dei Dati che il flusso chiamato “Pagamento” consiste in una copia della fattura per il cliente e di uno scontrino. Perché in questo caso si è scelto di evidenziare il Pagamento come un singolo flusso di dati piuttosto che due? Che cosa è dunque un flusso di dati? Per rispondere a questi quesiti, è necessario distinguere tra le interfacce e le informazioni che passano attraverso le interfacce. Siccome, dalla definizione, un flusso di dati è una connessione tra elementi del DFD attraverso cui scorrono pacchetti di informazioni congruenti, nell’esempio riportato il pacchetto di informazioni è costituito dalla copia della fattura e dallo scontrino; tale flusso viaggia dal cliente al processo di fatturazione attraverso una connessione chiamata Pagamento. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 9 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Nella figura 4 è rappresentata una porzione di DFD che ha due flussi di dati che collegano due processi. Figura 4 La ragione per cui essi sono stati distinti è perché non costituiscono un pacchetto di informazioni congruenti, infatti essi non si presentano mai contemporaneamente (ad esempio, il “Riepilogo livelli di giacenza” potrà essere generato settimanalmente, mentre il “Foglio di riordino urgente” verrà prodotto tutte le volte in cui ci si troverà di fronte ad una situazione critica). Il “Riepilogo livelli di giacenza” ed il “Foglio di riordino urgente” sono due flussi di dati che hanno scopi diversi, probabilmente sono prodotti da differenti porzioni del processo di origine e generalmente non hanno molte informazioni in comune. E` per questi motivi che è stato previsto di connettere i due processi con due interfacce separate: qualora, infatti, le si forzasse in una connessione comune si riuscirebbe solo a rendere più oscura l’interfaccia. Tra l’altro, sarebbe molto difficile trovare un nome soddisfacente per questo ipotetico unico flusso di dati. Il riuscire o meno a dare un nome ad un flusso può essere utilizzato come meccanismo di feedback per valutare il modo in cui il sistema è stato scomposto nelle sue parti componenti. Vengono ora fornite, di seguito, alcune convenzioni usate per rappresentare i flussi di dati. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 10 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ • Non devono esistere due flussi con lo stesso nome. • I nomi vanno scelti per rappresentare non solo i dati che fluiscono nella connessione, ma anche ciò che si conosce su quei dati. Ad esempio, in figura 5 sono presenti i flussi “Codice di addebito” e “Codice validato”, che sono strutturalmente equivalenti. Il nome diverso sta tuttavia a significare che si conosce qualcosa di più relativamente al secondo flusso, ovvero che il dato è stato validato. • Non si deve attribuire il nome ai flussi che vanno e/o vengono da data store, in quanto è il nome del data store che li individua. Tutti gli altri flussi di dati debbono invece ricevere un nome. Figura 5 Per concludere, si forniscono alcune precisazioni su quello che non è un flusso di dati. • Il flusso di dati non rappresenta un flusso di controllo. • Il flusso di dati non attiva o disattiva processi. Come dunque si possono rappresentare i flussi di controllo o di attivazione in un DFD? E` semplice, non si rappresentano! Infatti, trattandosi di informazioni di natura procedurale, forniscono un contributo esiguo rispetto agli obiettivi propri dei DFD. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 11 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 3.2. Processo Si definisce Processo la trasformazione dei flussi di ingresso nei flussi di uscita. I Processi illustrano il lavoro eseguito sui dati. Il processo di figura 6, ad esempio, mostra l’attività di dividere il flusso entrante (testo) nelle due connessioni “parole corrette” e “parole errate”. Figura 6 Tale processo è stato chiamato “Verifica dell’ortografia”, ma se gli si volesse attribuire un nome esclusivamente in termini dei suoi input e output, esso sarebbe: “separare il ‘testo’ in ‘parole corrette’ e ‘parole errate’ facendo riferimento ad un ‘dizionario delle parole’”. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 12 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ I processi individuati correttamente hanno tutti la caratteristica di essere chiamati in termini dei propri input e output, è proprio per questo che la definizione li individua come enti che eseguono la trasformazione dei flussi di input nei flussi di output. I processi sono rappresentati simbolicamente con cerchi (talvolta detti anche “bolle”). _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 13 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 3.3. Data store Si definisce Data Store qualsiasi “deposito” temporaneo di dati. Il concetto di Archivio (Data Store) è abbastanza consolidato per chi opera nell’informatica. Nel contesto dei DFD, però, il deposito di dati che costituisce un data store può essere costituito da varie cose: un nastro magnetico, un’area di disco o una “porzione” di floppy disk, uno schedario, una rubrica, il cestino dei rifiuti, un registro contenuto in un apposito cassetto, ecc.. Il verso della freccia, orientato da o verso il data store, è significativo. In figura 6 i dati fluiscono solamente dal data store e non verso esso. Il DFD in essa rappresentato, pertanto, vuole esprimere il fatto che il processo “Verifica dell’ortografia” non accetta alcuna parola nuova e quindi non aggiorna il dizionario. Se così non fosse, la freccia sarebbe presente in entrambi i versi. In figura 7 si assiste invece al caso opposto, nel quale i dati fluiscono nel Catalogo Articoli e non viceversa. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 14 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Figura 7 Naturalmente non si può aggiornare un archivio senza prima leggerlo (come ben sa chi si occupa dello sviluppo di software applicativo), ma nonostante ciò la figura 7 è corretta nel modo in cui è stata disegnata. Si può porre la regola seguente: nei flussi di dati che si interfacciano con i data store vanno indicati solo i versi significativi, si omettono quindi gli aspetti trascurabili di accesso fisico agli archivi. Nel caso esaminato, se alcune delle informazioni del Catalogo Articoli, non presenti nel flusso Nuovo Articolo, finissero nella Lista Arrivi, allora sarebbe corretto evidenziare un flusso orientato secondo tutti e due i versi rispetto al data store. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 15 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 3.4. Origine e Destinatario dei Dati Si definisce Origine dei Dati una persona, un ente o un’organizzazione esterna al contesto del sistema che è l’organizzatore “primo” dei dati. Si definisce Destinatario dei Dati una persona, un ente o un’organizzazione esterna al contesto del sistema che è l’utilizzatore “ultimo” dei dati. Qualsiasi sistema può essere espresso nei DFD tramite flussi, processi, data store. Per aumentare in modo significativo la “leggibilità” del diagramma è necessario evidenziare da dove arrivano gli input al sistema e dove vanno a finire gli output. Le definizioni sopra esposte chiariscono questi concetti. La parte qualificante della definizione è costituita dall’espressione “esterna al contesto del sistema”: infatti le persone, gli enti e le organizzazioni interne al sistema sono rappresentate per mezzo dei processi da essi eseguiti. La linea tratteggiata di figura 8 identifica il contesto del sistema e quindi la corretta individuazione di origini e destinatari permette di descrivere in modo più completo come il sistema si connette con il mondo esterno. Di seguito viene esposta la definizione di sistema. Si definisce Sistema un insieme di procedure, automatiche o manuali, usate per ottenere uno scopo desiderato. Tenendo presente la definizione sopra esposta, si osservi la figura 9, nella quale il contesto comprende sia processi manuali, sia processi automatici. Si tenga presente che il contesto comprende qualsiasi cosa interessi la nostra analisi, non solo quello che interessa alle origini ed ai destinatari. La definizione di contesto è la seguente: Si definisce Contesto dell’Analisi il sistema da automatizzare a cui va aggiunto tutto ciò che potrebbe essere influenzato dal cambiamento dovuto all’automazione. Origine e destinatario si collocano fuori del contesto. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 16 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Figura 8 _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 17 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Figura 9 _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 18 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 3.5. La Legge di Weinberg Il lettore avrà sicuramente osservato che finora si è applicata una tecnica nell’approccio dell’Analisi Strutturata tale da trascurare in prima battuta tutta una serie di considerazioni, che consideriamo “non di importanza immediata”, tra le quali vanno annoverate specialmente quelle di tipo “fisico”. La corretta metodologia dell’Analisi Strutturata insegna che qualsiasi approccio pulito e sistematico ad un problema richiede che si posticipino tutti gli aspetti che riguardano dettagli di una certa consistenza. Questi concetti sono stati espressi da Jerry Weinberg come regola [2]: Se si vuole imparare qualcosa, non bisogna cercare di imparare tutto. In altre parole, si deve rimandare tutto quello che non è subito necessario. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 19 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 4. REGOLE DI DISEGNO DEI DFD Viene fornito, di seguito, il prospetto delle regole che debbono essere seguite per disegnare correttamente i DFD. 1. Bisogna identificare gli input primari e gli output finali e poi li si deve porre lungo il contorno del foglio. 2. Si deve disegnare il DFD come è più comodo o congeniale: dall’input all’output, dall’output all’input, dal centro agli estremi. 3. E` importante dare un nome significativo a flussi, data store, origini, destinatari. 4. Si deve dare un nome ai processi in termini di trasformazione dall’input all’output. 5. E` necessario tralasciare le inizializzazioni. 6. In prima battuta, vanno omessi i dettagli ed i flussi di errore. 7. Non debbono essere indicati i flussi di controllo. 8. E` importante prepararsi a ricominciare. Esaminiamo ora in dettaglio i punti sopra esposti. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 20 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 4.1. Identificazione degli input primari e degli output finali Determinare quali sono gli input primari e gli output finali è un’attività vincolata alla decisione di quale sarà il contesto dello studio. Questa decisione viene presa, in genere, all’inizio della fase di analisi e spesso senza un grosso sforzo di ragionamento, in quanto è più una questione di giudizio e sensibilità. Ci si è già soffermati sul problema di individuare correttamente il contesto del sistema e quindi di evitare impostazioni troppo restrittive o comprensive di elementi estranei al problema. Stabilito quindi il confine del nostro lavoro, gli input primari e gli output finali sono costituiti dai flussi che attraversano il confine del contesto. In questa fase non ci si deve preoccupare troppo se questo semplice criterio non fornisce risultati completi, perché i DFD hanno meccanismi insiti di autocontrollo che permettono di rintracciare i flussi eventualmente dimenticati. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 21 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 4.2. Riempimento dell’interno del DFD In quasi tutti i progetti il primo utilizzo dei DFD è per documentare l’area utente alla data di inizio. Si è quindi chiamati a descrivere non tanto come dovranno essere le cose, quanto come sono effettivamente. Di conseguenza, si può modellare il DFD sulla base di quanto si conosce e di quanto l’utente racconta. I flussi sono insiemi di dati che l’utente conosce, usa comunemente e quindi chiama in qualche modo; i processi sono segmenti del lavoro che si svolge in quest’area. Si deve procedere ponendo l’attenzione, in primo luogo, ai flussi di dati. Si supponga di avere identificato un insieme significativo di informazioni che l’utente tratta in modo unitario (perché arrivano insieme, vengono elaborate insieme, ecc.), certamente esso diverrà un flusso di dati nel DFD. Lo si inserisce quindi nel diagramma e si cerca di collegarlo con i flussi esterni, si aggiungono processi ovunque un qualche lavoro è richiesto per trasformare un flusso o un insieme di flussi in un altro. Non ci si deve comunque preoccupare di trovare per loro un nome. Si indaga ora sui processi così introdotti, per verificare se nascondono un qualche flusso di dati, si esegue la verifica con l’utente e, in caso affermativo, si sostituisce il singolo processo con due, tre o quattro altri processi, introducendo il flusso o i flussi identificato/i in tal modo. Di ogni nuovo flusso si deve arrivare a sapere come è composto e, per ciascuno dei componenti, deve essere individuata la provenienza; si deve poi verificare se qualcuno dei flussi già noti può essere trasformato in uno di questi o viceversa e, in caso affermativo, quali processi debbono intervenire per effettuare la trasformazione. A questo punto si inseriscono i data store (archivi) segnalati dall’utente, dei quali si deve conoscere esattamente il contenuto, in modo da poter raffigurare cosa fluisce da o verso ciascuno di essi. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 22 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 4.3. Attribuzione di un nome a flussi, data store, origini e destinatari La scelta del nome da assegnare ad un flusso ha notevoli effetti per la leggibilità complessiva del DFD. Vengono esposte, di seguito, alcune regole empiriche per evitare errori. • E` necessario riuscire a dare un nome ad ogni singolo flusso. Se per qualche flusso questa operazione non riesce, bisogna scomporlo. • Si deve cercare di attribuire un nome appropriato, che sia rappresentativo dell’intero flusso e non solo dei suoi principali componenti. • E` importante evitare termini generici, quali, ad esempio, “dati” e “informazioni”. • Si deve porre attenzione a non raggruppare assieme in un unico flusso componenti che non devono essere trattati in modo analogo. A volte il nome più appropriato per un flusso è del tipo “cosa necessaria” oppure “misto vario”. Quando ciò avviene non ci si deve sforzare di trovare un nome diverso al flusso, bensì lo si deve spezzare in due o più flussi a cui sia possibile attribuire nomi meno generici. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 23 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 4.4. Attribuzione di un nome ai processi E` opinione diffusa tra gli studiosi della materia che procedere prima concentrandosi sui flussi e poi sui processi sia intrinsecamente un approccio topdown, mentre procedere concentrandosi prima sui processi sia intrinsecamente un approccio bottom-up. Quando a tutti i flussi è stato attribuito un nome, è un problema banale attribuire un nome ai processi. Si osservi ora la figura 10. Figura 10 _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 24 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Come si può facilmente notare, è facile attribuire al processo P il nome “Validare la Transazione”, mentre è impossibile assegnare un nome adeguato ai flussi A, B, C basandosi solo sul nome del processo “Controllo Giacenza”. Nell’attribuire un nome ai processi si consiglia di seguire le regole di seguito esposte. • E` necessario assicurarsi di dare un nome appropriato e rappresentativo dell’attività svolta. • Bisogna esprimere il nome con una frase imperativa composta di un solo predicato verbale e di un solo complemento oggetto; se i predicati verbali sono due, probabilmente il processo deve essere spezzato. • Si debbono evitare termini troppo generici come, ad esempio, “trattare”, “manipolare”, “gestire”. • Qualora l’unico nome appropriato da attribuire ad un processo contenga uno dei termini generici precedentemente indicati, il processo dovrà essere scomposto in uno o più processi ai quali sia possibile dare nomi significativi. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 25 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 4.5. Rappresentazione dei flussi di dati e non di quelli di controllo L’abitudine a ragionare in termini procedurali può indurre a considerare come flusso di dati quello che in realtà è un flusso di controllo. I flussi di controllo vanno eliminati dal DFD. Un flusso è di controllo quando la sua presenza serve solo per attivare un processo o per guidare il modo in cui un processo lavora. In figura 11 solo due sono i flussi di dati legittimi: “somma fattura” e “imposta globale”. Figura 11 _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 26 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 4.6. Prepararsi a ricominciare La mente umana lavora in modo iterativo, non fa mai niente di completamente esatto al primo tentativo. E` pertanto naturale prendere una realizzazione imperfetta di un determinato lavoro ed apportarvi aggiunte significative. In quest’ottica, se consideriamo i DFD e teniamo conto che i meccanismi di disegno sono banali, ripartire cancellando qualcosa è un prezzo non elevato per ottenere un risultato migliore. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 27 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 5. SCOMPOSIZIONE A LIVELLI In figura 12 è illustrato il DFD di un semplice programma di aggiornamento di un archivio di documenti. Esso ci fornisce una sufficiente visione d’insieme, pur avendo eseguito una adeguata scomposizione di processi. Nell’uso dei DFD nasce però un problema: se il quadro di un’applicazione relativamente banale è già sufficientemente grande, cosa si deve disegnare sul singolo foglio di carta? _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 28 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Figura 12 _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 29 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 5.1. Approccio top-down: il concetto di scomposizione a livelli Quando un sistema è troppo grande perché il suo DFD possa essere disegnato in una sola pagina, bisogna scomporlo in sottosistemi. Se anche i sottosistemi sono troppo grandi, vanno scomposti e così via. Se si descrive ognuna di queste successive scomposizioni con un DFD si ottiene un insieme di DFD scomposti a livelli (si veda la figura 13), il quale mantiene lo stesso contenuto di informazioni riguardanti il sistema ma risulta essere decisamente più leggibile. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 30 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Figura 13 _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 31 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 5.2. Componenti di DFD a livelli Un insieme di DFD scomposti a livelli è caratterizzato dal tipo dei livelli: superiore, inferiore, intermedio. Il livello superiore è un unico diagramma definito “di contesto”. Il livello inferiore è composto da un insieme di processi non più divisibili; per questo motivo è chiamato anche “diagramma delle trasformazioni elementari”. I livelli intermedi comprendono infinite varietà tra questi due estremi, a seconda della complessità del sistema analizzato. Il diagramma di contesto identifica il dominio dello studio. In figura 14 sono rappresentati il diagramma di contesto ed il diagramma a livello 0 relativi ad un sistema di cui viene effettuato lo studio. Si può notare come il diagramma di contesto sia sufficiente a far capire di cosa si sta trattando. Nelle figure 15, 16 e 17 sono illustrate le scomposizioni di primo livello dei tre processi individuati a livello 0. Il/i diagramma/i delle trasformazioni elementari comprende/comprendono i processi non più divisibili perché presentano quel tipo di livello atomico che impedisce ulteriori scomposizioni, oppure perché per scelta d’analisi si decide di aver raggiunto un livello di conoscenza adeguato al problema. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 32 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Figura 14 _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 33 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Figura 15 _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 34 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Figura 16 _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 35 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ Figura 17 _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 36 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 5.3. Convenzioni Quando si effettua l’esplosione di un diagramma di partenza in uno o più di arrivo, il diagramma di partenza si chiama genitore e quelli di arrivo si chiamano diagrammi figlio. Un diagramma figlio fornisce una visione più dettagliata della trasformazione indicata nel diagramma padre. E` importante verificare che gli input primari e gli output finali del diagramma figlio coincidano con input e output del corrispondente processo nel diagramma padre. L’equivalenza tra input e output nei diagrammi padre e figlio è espressa con il termine di “bilanciamento”, che sta a significare: tutti i flussi che entrano in un diagramma figlio sono rappresentati nel diagramma padre dagli stessi flussi entranti nel processo associato; gli output del diagramma figlio sono gli stessi output del processo associato nel diagramma padre, con l’eccezione degli scarti banali. Per quanto riguarda i data store, vale la regola seguente: un data store va rappresentato nei DFD al primo livello in cui viene usato come interfaccia tra due processi. Ne consegue che al primo livello in cui compare un data store sono evidenziati tutti i riferimenti ad esso relativi. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 37 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 5.4. Determinazione del livello finale Il processo di scomposizione non può ovviamente proseguire all’infinito: esso si dovrà arrestare ad un livello di dettaglio ritenuto accettabile. In base a precise scelte di progetto, si potrà adottare il criterio che si ritiene più opportuno, per quanto arbitrario esso sia, per stabilire se si è giunti al livello finale di scomposizione, in funzione del risultato che si vuole ottenere (analisi preliminare, analisi funzionale, analisi tecnica, ecc.). Vengono comunque forniti, di seguito, i criteri più diffusi. • Il processo di scomposizione si arresta quando si riesce a descrivere completamente un processo all’ultimo livello con una serie di specifiche sintetiche che riescono a stare in una pagina. Esse saranno “specifiche strutturate”, talvolta espresse sotto forma di pseudocodice [3]. • Il processo di scomposizione deve procedere fino a che ogni processo presenta un solo flusso di ingresso ed uno solo di uscita (ovviamente in questo computo vanno trascurati i flussi banali o di errore), accettando comunque un numero limitato di processi di “merge”, caratterizzati dall’avere più flussi in input ed uno in output. _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams 38 Mauro Pullin - Progetto e realizzazione di soluzioni applicative _______________________________________________________________________________ 6. BIBLIOGRAFIA [ 1] E. Yourdon «Managing The System Life Cicle: Methodology Overview» Yourdon Press, New York, 1982 [ 2] J. Weinberg «Introduction to General Systems Thinking » [ 3] G. Casadei, A. Teolis « Introduzione all’Informatica: la Programmazione » Zanichelli, Bologna, 1979 a Software Development _______________________________________________________________________________ Fondamenti di analisi strutturata: i Data Flow Diagrams