Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep...
Transcript of Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep...
![Page 1: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/1.jpg)
Unified Modeling LanguageEen introductie voor leden van de expertgroep Informatiemodellen
Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING
![Page 2: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/2.jpg)
2DOELSTELLING PRESENTATIEGEMEENSCHAPPELIJKE TAAL BINNEN DE EXPERTGROEP
• Situatie
• Gemêleerd gezelschap
• Hoe gemêleerd? Wat zijn jullie achtergronden?
• Domeinkennis
• Kennis van modelleren
• Kennis van UML
• Gemeenschappelijke taal, gemeenschappelijk niveau
• Elkaar begrijpen,
• De materie kunnen doorgronden
![Page 3: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/3.jpg)
SCOPE PRESENTATIE
• Introductie
• Wat behandelen we
• Subset van UML t.b.v. Informatiemodellen
• Model
• Diagram
• Element
3
• Relatie
• Wat behandelen we niet
• Alle details
• Object Constraint Language
• Inhoudelijkheid (is slechts ter illustratie)
![Page 4: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/4.jpg)
4WAT IS UNIFIED MODELING LANGUAGE?
• Een standaardnotatie voor modellen(waaronder diagrammen) t.b.v. systeemontwikkeling
• Een standaard die wordt beheerd door de Object Management Groep(www.omg.org)
• De definitie van modelelementen
•• De definitie van diagramtypen
![Page 5: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/5.jpg)
5WAT IS UNIFIED MODELING LANGUAGE NIET?
UML is niet:
• Een methode
• Methoden maken wel vaak gebruikvan UML
• Een procedure
• Een procedure is wel te beschrijvenin UMLin UML
• Een applicatie
• Een scala aan tools beschikbaar in de markt die conformeren aan UML
![Page 6: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/6.jpg)
6OORSPRONG UML
• Object Oriëntatie
• Simula 67
• Smalltalk
• C++
• etc
• Allerlei notaties
![Page 7: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/7.jpg)
7HISTORIE UML
• Invloeden
• Booch 93
• Object Modeling Technique 94
• Object Oriented Software Engineering 94
• Tegenwoordig versie 2.3• Tegenwoordig versie 2.3
• Bredere scope dan software ontwikkeling
• O.a. bedrijfsdomein
• Model Driven Development (MDD)
• Uitbreidbaar
![Page 8: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/8.jpg)
8WAAROM UML?
• Enige levende standaard op gebied van analyse- en ontwerpmodellering
• Breed geaccepteerd
• Veel gebruikt
• Open standaard (OMG)
• Veel tools beschikbaar
• Veel opleidingsmogelijkheden• Veel opleidingsmogelijkheden
• Methode-onafhankelijk
• Aangenomen als standaard modelleertaalstelsel
• Issue 80
• Adoptie door:
• NHR, GeoNovum, Kadaster
![Page 9: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/9.jpg)
9MODEL EN DIAGRAM
• Model bestaat uit
• Elementen
• Relaties tussen elementen
• Diagrammen
• Diagram is
• Grafische weergave
• Van (deel van) model
• Conformerend aan model
• Vanuit een bepaald perspectief
• Vele diagrammen, één model
![Page 10: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/10.jpg)
10UML DIAGRAMMEN
![Page 11: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/11.jpg)
11DIAGRAMMEN IN SCOPE VAN PRESENTATIE
![Page 12: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/12.jpg)
12CLASS DIAGRAM
• Class
• Attribuut
• Operatie
• Relatie
• Typen
• Generalisatie
• Associatie
• Aggregatie
• Compositie
• Association Class
• Multipliciteit
• Rol
• Reflexive
![Page 13: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/13.jpg)
13CLASS
• Class
• Representeert de gezamelijkekenmerken en het gemeenschappelijke gedrag van een verzameling objecten
• Heeft een naam
• Is eigenaar van kenmerken• Is eigenaar van kenmerken(attributen)
• Beschrijft gedrag (operaties)
![Page 14: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/14.jpg)
14CLASS VERSCHIJNINGSVORMEN
![Page 15: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/15.jpg)
CLASS VERSUS OBJECT
• Object is een individuele, concrete, run-time verschijning van eenClass
• Een object heeft een status d.m.v. concrete waarden voor de in de betreffende class gedefinieerde kenmerken
• Een object is een instantie van een class
• Een object heeft een eigen levencyclus
• Object is van type Class
15
• Object is van type Class
![Page 16: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/16.jpg)
16GENERALISATIE RELATIE
• Typeringshiërarchie
• Class Specifiek ‘erft kenmerken en gedrag van’ class Algemeen
• Class Specifiek kan gedrag van class Algemeen herdefiniëren
• Een object van class Specifiek bevatde kenmerken van class Specifiekde kenmerken van class Specifieken van class Algemeen
• Een object van class Specifiek kanworden beschouwd als een object van class Algemeen. Hergedefinieerd gedrag wordt weluitgevoerd, eigen gedefinieerdgedrag (van Specifiek) is nietbenaderbaar
• Class Algemeen heeft geen kennisvan class Specifiek
![Page 17: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/17.jpg)
17MEERVOUDIGE GENERALISATIE
• Auto ‘erft’ kenmerken en gedrag van zowel Motorvoertuig als van Vervoermiddel
• Leidt vaak tot extra complexiteit
• Beter te vermijden
![Page 18: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/18.jpg)
18ABSTRACT CLASS
• Een class waarvan geen object teinstantieren valt anders dan door diensspecifiekere concrete classe(s)
• Een object van type Vervoermiddelis altijd ook van type Auto of van type Fiets
• Kenmerken van abstract class zijnbenaderbaar door overervendebenaderbaar door overervendeconcrete class
![Page 19: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/19.jpg)
19ASSOCIATIE RELATIE
• Relatie tussen twee classes waardoorobjecten van die classes met elkaargekoppeld zijn.
• Een gekoppeld object is navigeerbaarvanuit het andere object
• De associatie heeft een naam(werkwoordsvorm) en een richting
•• De associatie heeft een vermelding van de rol die het object van de aangewezenclass speelt voor het object van de aanwijzende class
• Associaties kunnen unidirectioneel en bidrectioneel zijn
![Page 20: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/20.jpg)
20VOORBEELD ASSOCIATIE RELATIE
• Twee verschillende associaties tussendezelfde classes
• Bedrijf ‘levert aan’ Persoon
• Bedrijf heeft voor Persoon de rol van ‘leverancier’
• Persoon ‘werkt bij’ Bedrijf
• Persoon heeft voor Bedrijf de rol van • Persoon heeft voor Bedrijf de rol van ‘medewerker’
• Persoon werkt bij ten hoogste één object van type Bedrijf
• Bedrijf levert aan een willekeurig aantalobjecten van type Persoon
![Page 21: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/21.jpg)
21UNIDIRECTIONELE ASSOCIATIE RELATIE
• Fles heeft kennis van Vloeistof
• Vloeistof heeft geen kennis van Fles
• Fles is afhankelijk van Vloeistof
• Minimaliseren van afhankelijkheden
• Vloeistof blijft dan algemeen toepasbaar
![Page 22: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/22.jpg)
22AGGREGATIE EN COMPOSITIE RELATIE
• Aggregatie: Brandstof behoort toe aanAuto
• Aggregatie: zwakke binding tussenclasses; geen binding van levencyclus
• Compositie: Auto bestaat uit vier objectenvan type Wiel
• Compositie: sterke binding tussen• Compositie: sterke binding tussenclasses; gelinkte objecten van type Wielleven niet langer dan het linkende object van type Auto
![Page 23: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/23.jpg)
23COMPOSITIE RELATIE VOORBEELD
• Een lijn kan niet tot zowel een driehoekals een rechthoek behoren
![Page 24: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/24.jpg)
24REFLEXIVE RELATIE
• Een relatie naar de eigen Class
• Voorbeeld
• Relatie van class Persoon naarclass Persoon met als rollen ‘ouder’ en ‘kind’
class Reflexiv e
Persoon-kind*
-ouder2
object Object
Johanna :Persoon Karel :Persoon
Kees :Persoon
Johanna :Persoon Karel :Persoon
Piet :Persoon Klaartj e :Persoon
Maria :Persoon
![Page 25: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/25.jpg)
25ASSOCIATION CLASS RELATIE
• Informatie behorend bij de relatie en nietbij de gerelateerde classes
• Wanner er een link is tussen eenobject van type Persoon en eenObject van type Telecommunicatieprovider, danbestaat daarvoor ook een instantievan type Abonnementvan type Abonnement
![Page 26: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/26.jpg)
VRAGEN? 26
![Page 27: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/27.jpg)
27PACKAGE DIAGRAM
• Package
• Een container om gelijksoortigemodelelementen te verzamelen en afzonderlijk te beheren
• Gelaagdheid
• Semantische specificatie
• Realiserend specificatie• Realiserend specificatie
• Versiebeheer
• Afhankelijkheden tussen Packages
• Traceability tussen lagen
• Connectie met anderedisciplines
• Navigeerbaarheid
![Page 28: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/28.jpg)
28PROFILE DIAGRAM
• Stereotype als mogelijkheid om de standaard elementen van UML uit tebreiden met projectspecifieke, eigenkenmerken en gedrag, een zogenaamdeigen metamodel
• Specificatie van tagged values voorstereotyped elementen
• Gebruikmaken van UML om profile te• Gebruikmaken van UML om profile tespecificeren.
• Profile inlezen in UML-omgeving omeigengedefinieerde stereotypes beschikbaar te krijgen
![Page 29: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/29.jpg)
TOEPASSING 29
![Page 30: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/30.jpg)
30TENSLOTTE
• UML wordt toegepast voor beschrijving van de semantische informatiemodellen RSGB en RGBZ
• Niet alleen modelniveau wordt gedefinieerd maar ook metamodelniveau
• Enterprise Architect (www.sparxsystems.com) wordt ingezet als modelbeheertool
• Genereren documentatie
• RTF
• HTML• HTML
• Referentie
• www.uml.org (OMG)
OrdinaRingwade 13439 LM NieuwegeinTel. 030 663 .. ..www.ordina.nl
![Page 31: Introductie Unified Modeling Language€¦ · Een introductie voor leden van de expertgroep Informatiemodellen Harmen Mantel, Ordina ICT Management & Consultancy, werkzaam voor KING.](https://reader034.fdocument.pub/reader034/viewer/2022043014/5fc18cfceb717013ca3cae9e/html5/thumbnails/31.jpg)
VRAGEN? 31