DA UML A MATLAB

52
DA UML A MATLAB Come ricavare un modello di simulazione in ambiente Matlab partendo da una descrizione in linguaggio UML Progetto di Controllo dei Processi Studenti: Roberto Nicolino, Nicola di Lecce

description

DA UML A MATLAB. Progetto di Controllo dei Processi. Come ricavare un modello di simulazione in ambiente Matlab partendo da una descrizione in linguaggio UML. Studenti: Roberto Nicolino, Nicola di Lecce. Brevemente. - PowerPoint PPT Presentation

Transcript of DA UML A MATLAB

Page 1: DA UML A MATLAB

DA UML A MATLABCome ricavare un modello di simulazione in ambiente Matlab

partendo da una descrizione in linguaggio UML

Progetto di Controllo dei Processi

Studenti: Roberto Nicolino, Nicola di Lecce

Page 2: DA UML A MATLAB

Partendo da una analisi approfondita sulle potenzialità che oggi offre Unified Modeling Language si mostrerà come questo linguaggio si ponga da tramite tra cliente e committente, per evitare inutili incomprensioni e per permettere la realizzazione di un modello completo e dettagliato di un sistema. Grazie ad UML è possibile realizzare simulazioni in ambiente Matlab percorrendo un processo di integrazione completo tra le due piattaforme di sviluppo.

BrevementeBrevemente

Page 3: DA UML A MATLAB

• Cosa è UML e a cosa serve

• Come integrare il linguaggio Uml con Matlab o altri ambienti di simulazione

• Quali procedure adottare per tradurre un modello descritto in UML in un modello utile alla simulazione

Si procederà descrivendoSi procederà descrivendo

Page 4: DA UML A MATLAB

• Lo Unified Modeling Language è un linguaggio per specificare, costruire, visualizzare e documentare manufatti sia di sistemi software, che di altri sistemi non strettamente software.

• UML rappresenta una collezione di best practices di ingegneria, dimostratesi vincenti nella modellazione di vasti e complessi sistemi.

• UML permette di visualizzare, per mezzo di un formalismo rigoroso, “manufatti” dell’ingegneria, consentendo di illustrare idee, decisioni prese, e soluzioni adottate.

• Tale linguaggio favorisce, inoltre, la divulgazione delle informazioni, in quanto standard internazionale non legato alle singole imprese.

Intoduzione ad UMLIntoduzione ad UML1/2

Page 5: DA UML A MATLAB

• Lo UML dispone di tutti i meccanismi necessari per la specifica di qualsiasi dettaglio ritenuto rilevante in ogni fase del ciclo di vita del progetto e quindi, in ultima analisi, per produrre modelli accurati.

• Lo UML, permette di realizzare modelli che si prestano ad essere implementati con diversi linguaggi di programmazione e ambienti di simulazione tipo Matlab

• Sul mercato sono presenti diversi tool, in grado di generare codice a partire dal relativo modello, sia interattivamente durante la fase di disegno, sia su richiesta. L’esistenza di queste funzionalità, sebbene ancora non del tutto mature, dovrebbe far capire che l’implementazione è veramente un dettaglio del disegno, specie con linguaggi come Java.

• lo UML fornisce sia dei meccanismi molto formali, sia del testo libero da aggiungere, ogni qual volta lo si ritenga necessario, a parti ritenute poco chiare o particolarmente complesse, al fine di aumentarne il livello di dettaglio.

Intoduzione ad UMLIntoduzione ad UML2/2

Page 6: DA UML A MATLAB

Perché utilizzare UML ?

Page 7: DA UML A MATLAB

• Ogni qualvolta, in una disciplina dell’ingegneria, vi sia la necessità di realizzare un “manufatto”, indipendentemente dalla dimensione e dal settore di interesse (una casa, un grattacielo, un particolare meccanismo, un ponte, un dipartimento di un’azienda, e così via) si procede cercando di realizzarne un modello.

• L’obiettivo è produrre, in tempi relativamente brevi e soprattutto a costi contenuti, una versione razionalizzata e semplificata del sistema reale che, tuttavia, consenta di evidenziarne l’aspetto finale e di studiarne prestazioni, affidabilità e comportamento.

• Si provi a immaginare che cosa potrebbe accadere se si avviasse la progettazione di un ponte a partire da specifiche sommarie, magari comunicate verbalmente o, peggio ancora, se si partisse subito a costruirlo materialmente, magari affidandosi all’esperienza di qualche costruttore

Perché utilizzare UMLPerché utilizzare UML1/2

Page 8: DA UML A MATLAB

Il risultato sarebbe il seguente:

2/2

Perché utilizzare UMLPerché utilizzare UML

Page 9: DA UML A MATLAB

Questo è il motivo per cui è importante utilizzare un linguaggio di modellizzazione universale

Page 10: DA UML A MATLAB

Attualmente è possibile sfruttare le caratteristiche descrittive offerte da UML attraverso numerosi software free disponibili in rete, tra questi si segnala:

Argo UMLhttp://argouml.tigris.org/

Page 11: DA UML A MATLAB

Componenti UML

Page 12: DA UML A MATLAB

• Il linguaggio UML contiene svariati elementi grafici che vengono messi insieme durante la creazione dei diagrammi. Dato che l'UML è un linguaggio, come tale utilizza delle regole per combinare i componenti nella creazione dei diagrammi.

• L'obiettivo dei diagrammi è quello di costruire molteplici viste di un sistema tutte correlate tra di loro.

• La notazione UML include dieci tipi di diagrammi, divisi in cinque categorie. Si tenga presente che è assolutamente possibile costruire e aggiungere dei diagrammi differenti dagli standard (che vengono definiti ibridi) rispetto a quelli definiti dal linguaggio. La tabella seguente mostra le categorie e i diagrammi corrispondenti.

Componenti UMLComponenti UML1/14

Page 13: DA UML A MATLAB

Categoria Diagrammi

Diagrammi per analisi dei requisiti Diagrammi dei casi d’uso (use case)

Diagammi di struttura statica

Diagrammi dei package

Diagrammi delle classi (class)

Diagrammi degli oggetti (object)

Diagrammi di interazioneDiagrammi di sequenza (sequence)

Diagrammi di collaborazione (collaboration)

Diagrammi di statoDiagrammi di stato (statechart)

Diagrammi di attività (activity)

Diagrammi di implementazioneDiagramma dei componenti (component)

Diagrammi di dilocamento (deployment)

Page 14: DA UML A MATLAB

• Per avere una idea immediata di cosa sia una classe è possibile usare come esempio il fatto che tutti gli oggetti o esseri viventi, spesso, sono riconducibili a determinate categorie (computers, automobili, piante, animali). Queste categorie costituiscono le classi. Una classe è una categoria o un gruppo di oggetti (con questo termine si includono, per comodità anche gli esseri viventi) che hanno attributi simili e comportamenti analoghi. I Class Diagrams forniscono le rappresentazioni utilizzate dagli sviluppatori.

3/14 Componenti UML: Class DiagramsComponenti UML: Class Diagrams

Page 15: DA UML A MATLAB

• Un oggetto è una istanza di una classe, ovvero una qualcosa di specifico che ha dei valori determinati per i suoi attributi e dei comportamenti specifici.

4/14 Componenti UML: Object DiagramsComponenti UML: Object Diagrams

Page 16: DA UML A MATLAB

• Uno Use Case (caso d'uso) è una descrizione di un comportamento particolare di un sistema dal punto di vista dell'utente. Per gli sviluppatori, gli use case diagram rappresentano uno strumento notevole: infatti tramite tali diagrammi, essi possono agevolmente ottenere una idea chiara dei requisiti del sistema dal punto di vista utente e quindi scrivere il codice senza timore di non aver recepito bene lo scopo finale. Nella rappresentazione grafica, viene utilizzato un simbolo particolare per l'actor (l'utente o un altro sistema che interagisce) che si vedrà in seguito.

• L'actor è l'entità che interagisce con uno use case facendo partire la sequenza di azioni descritte dallo use case stesso e, eventualmente, ricevendo delle precise risposte dal sistema. Può essere una persona o anche un altro sistema.

5/14 Componenti UML: Use Case DiagramsComponenti UML: Use Case Diagrams

Page 17: DA UML A MATLAB

• Ad un determinato istante, durante il funzionamento del sistema, un oggetto si trova in un particolare stato. Gli State Diagrams rappresentano tali stati, ed i loro cambiamenti nel tempo. Ogni state diagram inizia con un simbolo che identifica lo stato iniziale (Start State) e termina con un altro simbolo che rappresenta lo stato finale (End State). Per esempio, ogni persona può essere identificato dai seguenti stati: neonato, bambino, adolescente, adulto, anziano.

6/14 Componenti UML: State DiagramsComponenti UML: State Diagrams

Page 18: DA UML A MATLAB

• I class diagrams e gli object diagrams rappresentano informazione statica. In un sistema funzionante, tuttavia, gli oggetti interagiscono l'uno con l'altro, e queste interazioni avvengono in relazione al trascorrere del tempo. Il sequence diagram mostra le dinamiche, basate sul tempo, delle varie interazioni tra gli oggetti.

7/14 Componenti UML: Sequence DiagramsComponenti UML: Sequence Diagrams

Page 19: DA UML A MATLAB

• Le attività che si riscontrano all'interno di use case o all'interno del comportamento di un oggetto accadono, tipicamente, in una sequenza ben definita. Tale sequenza si rappresentata con gli activity diagrams.

8/14 Componenti UML: Activity DiagramsComponenti UML: Activity Diagrams

Page 20: DA UML A MATLAB

• Gli elementi di un sistema lavorano insieme per realizzare e soddisfare le necessità del sistema. Un linguaggio di modellazione deve avere un modo per rappresentare tale cooperazione. Il Collaboration Diagram nasce proprio per questa ragione.

9/14 Componenti UML: Collaboration DiagramsComponenti UML: Collaboration Diagrams

Page 21: DA UML A MATLAB

• Oggi, nell'ingegneria del software si utilizza sempre più il modello di organizzazione secondo il quale ognuno nel team di lavoro lavora su un componente differente. Il component diagram descrive questa importante caratteristica.

10/14 Componenti UML: Component DiagramsComponenti UML: Component Diagrams

Page 22: DA UML A MATLAB

• Il Deployment Diagram mostra l'architettura dal punto di vista fisico e logistico di un sistema. Tale diagramma può descrivere i vari dispositivi presenti, mostrare le varie connessioni che intercorrono tra di essi e, ancora, il software che è installato su ogni macchina.

11/14 Componenti UML: Deployment DiagramsComponenti UML: Deployment Diagrams

Page 23: DA UML A MATLAB

• Elementi Strutturali

12/14

I simboli graficiI simboli grafici

ClassInterface

Use Case

Deployment

Component

State

ActivityCollaboration

:Name1

:Name2

1:Messages

• Elementi Comportamentali

:Name2:Name1

Sequence

Page 24: DA UML A MATLAB

• Relazioni

13/14

I simboli graficiI simboli grafici

• Raggruppamento

Association

Generalization

Dependency

Realization

Package

Page 25: DA UML A MATLAB

• Estensioni

14/14

I simboli graficiI simboli grafici

• Annotazioni ed Actor

Note

Actor

<<Stereotipo>>

{Constraint}

Page 26: DA UML A MATLAB

• Nell’effettuare la traduzione di un sistema descritto in ambiente UML in un sistema descritto in ambiente Matlab ci si serve prevalentemente di:

– Class Diagram– State Diagram– Collaboration Diagram– Sequence Diagram

UML: ConsiderazioniUML: Considerazioni

Page 27: DA UML A MATLAB

• Esistono principalmente due modi per poter simulare un sistema descritto in UML attraverso le funzionalità offerte da Matlab:

1. Mediante Simulink e Stateflow utilizzati rispettivamente per simulare sistemi continui e ad eventi discreti (macchine a stati)

1. Mediante scrittura di codice in linguaggio S-Function, anch’esso integrato pienamente in Matlab.

• Si procederà ora analizzando prima lo Stateflow che risulta essere lo strumento più semplice per poter rappresentare sistemi di tipo discreto o ibridi (in aggiunta a Simulink) e che rispetto ad S-function è più “User Friendly”

Ambiente MatlabAmbiente Matlab

Page 28: DA UML A MATLAB

• Lo stateflow è uno strumento di sviluppo grafico per sistemi basati sulla teoria delle macchine a stati finiti ossia sistemi di controllo logici (controllore on-off, scheduler), o sistemi di supervisione (controllori ad alto livello, ecc).

• Una macchina a stati finiti, dunque, non è altro che la rappresentazione di un sistema a eventi discreti la cui evoluzione è regolata dal susseguirsi di condizioni vere o false.

• L’approccio utilizzato da Stateflow per descrivere un sistema a stati discreti è quello di modellarne il comportamento, in termini di transizioni attraverso gli stati. Lo stato attivo è determinato basandosi sul susseguirsi di eventi sotto determinate condizioni. Pertanto le transizioni e gli stati nel loro complesso non sono altro che delle rappresentazioni grafiche basate su questo tipo di approccio.

Ambiente Matlab: StateflowAmbiente Matlab: Stateflow1/5

Page 29: DA UML A MATLAB

• Le macchine a stati finiti che questo ambiente di sviluppo permette di descrivere, sono caratterizzate da uno stato, un ingresso ed un’uscita e si connettono fra di loro mediante delle transizioni. In dettaglio:

– Stato: è la condizione (modo) di funzionamento della macchina;

– Transizione: è la condizione di cambiamento dello stato della macchina;

– Ingressi: sono informazioni provenienti dall’esterno (eventi, segnali);

– Uscite: sono segnali verso l’esterno il cui valore può essere funzione degli stati o delle transizioni.

Ambiente Matlab: StateflowAmbiente Matlab: Stateflow2/5

Page 30: DA UML A MATLAB

• Di seguito è riportato un semplice esempio di controllo On-Off di un forno per porre in evidenza le parti caratterizanti di una Macchina a Sati descritta in Stateflow:

Ambiente Matlab: StateflowAmbiente Matlab: Stateflow3/5

Page 31: DA UML A MATLAB

• Le macchine a stati finiti che questo ambiente di sviluppo permette di descrivere, sono caratterizzate da uno stato, un ingresso ed un’uscita e si connettono fra di loro mediante delle transizioni. In dettaglio:

– Stato: è la condizione (modo) di funzionamento della macchina;

– Transizione: è la condizione di cambiamento dello stato della macchina;

– Ingressi: sono informazioni provenienti dall’esterno (eventi, segnali);

– Uscite: sono segnali verso l’esterno il cui valore può essere funzione degli stati o delle transizioni.

Ambiente Matlab: StateflowAmbiente Matlab: Stateflow4/5

Page 32: DA UML A MATLAB

• Le transizioni avvengono al verificarsi di un evento che può coincidere ad esempio con la variazione di un “oggetto Dato” o “Tempo”.

• Tali oggetti sono variabili di tipo numerico utilizzate da Stateflow per scambiare informazioni con Simulink, e quindi con il Workspace di Matlab, o con altre Macchine a Stati.

Ambiente Matlab: StateflowAmbiente Matlab: Stateflow5/5

Page 33: DA UML A MATLAB

• Come già anticipato, è anche possibile tradurre una descrizione UML in ambiente Matlab attraverso le S-Function, rispettando le regole di scrittura ampiamente trattate in letteratura.

• Una S-Function è una descrizione, di un sistema dinamico, realizzata attraverso un linguaggio di programmazione, il cui codice può essere scritto utilizzando i linguaggi Matlab o C.

• Mediante S-Function è possibile descrivere un sistema ibrido completo e pronto per la simulazione, semplicemente analizzando la descrizione UML.

Ambiente Matlab: ConsiderazioniAmbiente Matlab: Considerazioni

Page 34: DA UML A MATLAB

Da UML a Matlab: Un Esempio

Page 35: DA UML A MATLAB

• Si vedrà ora quali procedure adottare per poter realizzare un modello di simulazione Matlab-Simulink partendo da una descrizione UML di un sistema di tipo ibrido. Verrà considerato come sistema una cella di lavoro da poter utilizzare in catene di montaggio industriali

• Il sistema, costituito da due bracci robotici, da una rastrelliera, da una attrezzatura su cui eseguire la saldatura, da un nastro trasportatore, e da un pallet svolge ciclicamente le seguenti azioni:

– Prelievo pezzo A con Movimentatore da rastrelliera; – Deposito pezzo A su attrezzatura di saldatura; – Prelievo pezzo B con Movimentatore da rastrelliera;– Deposito pezzo B su attrezzatura di saldatura; – Esecuzione saldatura a punti (Saldatore); – Posizionamento dell’assieme su pallet (Movimentatore); – Ripetizione saldatura per un secondo pezzo; – Allontanamento del pallet con due pezzi saldati dalla cella.

UML-Matlab: EsempioUML-Matlab: Esempio

Page 36: DA UML A MATLAB

• Analizzando tale cella sarà possibile modellare la dinamica dei robots con uno schema Simulink tempo continuo e il funzionamento di tutti gli altri componenti come una sequenza di operazione discrete, ottenendo un sistema complessivamente Ibrido. Verrà elaborata prima una descrizione del sistema in UML, seguendo le procedure già descritte ossia la realizzazione di:

– Class Diagram– State Diagram– Collaboration Diagram– Sequence Diagram

• In seguito, servendosi dello State Diagram, si rappresenteranno mediante precise regole di traduzione, le componenti discrete del sistema in ambente Stateflow.

UML-Matlab: EsempioUML-Matlab: Esempio

Page 37: DA UML A MATLAB

• La soluzione adottata per la cella di lavoro prevede che il robot2 (Saldatore) sia posto rispetto alla tavola girevole dalla parte opposta al robot1 (Movimentatore). In figura si indicano schematicamente con Ras la rastrelliera, con R1 e R2 rispettivamente il robot1 e il robot2, con TG la tavola girevole, con P il pallet e con Tr il trasportatore.

UML-Matlab: EsempioUML-Matlab: Esempio

Page 38: DA UML A MATLAB

• Una volta scelti i componenti del sistema si procede con la realizzazione del Class Diagram che servirà a specificare quali oggetti costituiscono il sistema e a grandi linee che relazioni ci sono tra questi tipi di oggetti, ossia che operazioni compiono.

• Il diagramma contiene pertanto una classe generica Robot e due istanze di tale classe: Saldatore e Movimentatore. Associate ad esse vi è una classe Pezzo, che è a sua volta associata, con molteplicità 2, alla classe Assemblato (composizione dei pezzi A e B). La comunicazione tra i vari elementi della cella è garantita da 3 segnali presenza_pezzo, finecorsa_nastro e presenza assemblato, inviati ai due Robot dalle classi Rastrelliera, TavolaGirevole e NastroTrasportatore.

• La Dinamica è trattata come una classe a se in cui andranno specificate attraverso delle Note o delle Constraint le equazioni differenziali che regolano il funzionamento del braccio Saldatore e del braccio Movimentatore.

Class DiagramClass Diagram

Page 39: DA UML A MATLAB
Page 40: DA UML A MATLAB

• Nella realizzazione dello State Diagram si è tenuto conto che il sistema è costituito da due elementi fondamentali che risultano essere i due Robots.

• Il funzionamento della cella di lavoro nel suo complesso si basa infatti sulle azioni che i due Robots devono compiere per poter effettuare la movimentazione dei pezzi e la saldatura.

• Le altre componenti ossia la Tavola Girevole, la Rastrelliera e il Nastro Trasportatore sono visti come degli elementi passivi di cui i Robots si servono per poter ricavare delle informazioni o per poter impartire dei comandi.

State DiagramState Diagram

Page 41: DA UML A MATLAB

• Si è scelto dunque di realizzare due State Diagram:– uno per il robot Movimentatore;– uno per il robot Saldatore.

• Di seguito per completezza sono riportati i rispettivi schemi

State DiagramState Diagram

Page 42: DA UML A MATLAB
Page 43: DA UML A MATLAB
Page 44: DA UML A MATLAB

• Il Collaboration Diagram visualizza lo scambio dei messaggi che avviene tra i vari componenti del sistema, come rappresentato in figura:

Collaboration DiagramCollaboration Diagram

Page 45: DA UML A MATLAB

• La realizzazione del Sequence Diagram risulta abbastanza semplice, basta considerare infatti la sequenza delle interazioni che avvengono durante il funzionamento del sistema e rappresentarle secondo la sintassi.

Sequence DiagramSequence Diagram

Page 46: DA UML A MATLAB
Page 47: DA UML A MATLAB

• Una volta terminata la realizzazione dei diagrammi UML si passa alla traduzione del sistema in un modello di simulazione all’interno di Matlab. Pertanto si procede con la descrizione della componente continua attraverso dei blocchetti simulink e con la descrizione della componente discreta mediante una macchina a stati.

Matlab: Simulink e StateflowMatlab: Simulink e Stateflow

Page 48: DA UML A MATLAB
Page 49: DA UML A MATLAB

• Si riportano per completezza i passaggi che devono essere effettuati per poter trasformare la descrivere un sistema in UML e poi trasformare tale descrizione in un modello Matlab:

1. Analisi dei componenti e delle specifiche di progetto

2. Descrizione dettagliata della dinamica del sistema

3. Realizzazione di opportuni controllori che consentano il rispetto delle specifiche

4. Scrittura del Class Diagram UML

5. Scrittura dello State Diagram

6. Scrittura del Collaboration Diagram e del Sequence Diagram

7. Realizzazione del modello Matlab (componenti continue con Simulink e discrete con Stateflow)

8. Eventuale generazione di codice per la configurazione e la programmazione dei componenti del sistema.

Regole di TraduzioneRegole di Traduzione

Page 50: DA UML A MATLAB

• L’unicità di questa procedura è garantita anche grazie ai numerosi strumenti offerti da UML per realizzare la descrizione di un sistema, tra questi assume rilevante importanza il costrutto constraint.

• La sua funzione è quella di fornire dei vincoli che garantiscano le specifiche determinanti del sistema.

Regole di TraduzioneRegole di Traduzione

Page 51: DA UML A MATLAB

• UML, che di fatto oggi è uno standard, si pone al vertice tra gli strumenti che consentano di strutturare in differenti fasi un qualsiasi tipo di progettazione. Pertanto si rivela estremamente utile nella produzione di software, o in altri campi dell’ingegneria, tra cui anche quello dell’automazione industriale.

• Se si utilizzasse UML come tramite ossia come punto di unione tra chi ha il compito di descrivere e progettare e chi ha invece il compito di realizzare si potrebbero eliminare inutili e spiacevoli incomprensioni che spesso sono alla base del fallimento di un determinato processo produttivo e di sviluppo.

• Uno sviluppo futuro potrebbe essere quello di racchiudere le regole di traduzione da UML a Matlab in un software che permetta di generare in modo univoco codice in formato S-Function inserendo i parametri della dinamica e fornendo i file dei diagrammi UML del sistema.

Sviluppi FuturiSviluppi Futuri

Page 52: DA UML A MATLAB

• Questo permetterebbe senza dubbio di descrivere un sistema attraverso un linguaggio universale che non risulti legato a nessun tipo di programma (Matlab, Scilab e così via) ma che attraverso regole simili a quelle per Matlab permetta di sfruttare quella descrizione su qualsiasi piattaforma di simulazione e con qualsiasi sistema operativo (Linux, Windows).

Sviluppi FuturiSviluppi Futuri