- Unified Modeling Language
-
Pour les articles homonymes, voir UML.
UML (en anglais Unified Modeling Language ou « langage de modélisation unifié ») est un langage de modélisation graphique à base de pictogrammes. Il est apparu dans le monde du génie logiciel, dans le cadre de la « conception orientée objet ». Couramment utilisé dans les projets logiciels, il peut être appliqué à toutes sortes de systèmes ne se limitant pas au domaine informatique [1].
UML est l'accomplissement de la fusion de précédents langages de modélisation objet : Booch, OMT, OOSE. Principalement issu des travaux de Grady Booch, James Rumbaugh et Ivar Jacobson, UML est à présent un standard défini par l'Object Management Group (OMG). La dernière version diffusée par l'OMG est UML 2.4.1 depuis aout 2011[2].
Utilité d'UML
UML est utilisé pour spécifier, visualiser, modifier et construire les documents nécessaire au bon développement d'un logiciel orienté objet. UML offre un standard de modélisation, pour représenter l'architecture logiciels. Les différents élements représentables sont :
- Activité d'un objet/logiciel
- Acteurs
- Processus
- Schéma de base de données
- Composants logiciels
- Réutilisation de composants
Grâce aux outils de modélisation UML, il est également possible de générer automatiquement une partie de code, par exemple Java, à partir des divers documents réalisés.
Histoire
Avant UML 1.x
UML 1.x
UML 2.x
Le formalisme d'UML
UML 2.3 propose 13 types de diagrammes (9 en UML 1.3). UML n'étant pas une méthode, leur utilisation est laissée à l'appréciation de chacun, même si le diagramme de classes est généralement considéré comme l'élément central d'UML ; des méthodologies, telles que l'UnifiedProcess, axent elles l'analyse en tout premier lieu sur les diagrammes de cas d'utilisation (Use Case). De même, on peut se contenter de modéliser seulement partiellement un système, par exemple certaines parties critiques.
- UML se décompose en plusieurs sous-ensembles
- Les vues : Les vues sont les observables du système. Elles décrivent le système d'un point de vue donné, qui peut être organisationnel, dynamique, temporel, architectural, géographique, logique, etc. En combinant toutes ces vues, il est possible de définir (ou retrouver) le système complet.
- Les diagrammes : Les diagrammes sont des éléments graphiques. Ceux-ci décrivent le contenu des vues, qui sont des notions abstraites. Les diagrammes peuvent faire partie de plusieurs vues.
- Les modèles d'élément : Les modèles d'élément sont les briques des diagrammes UML, ces modèles sont utilisés dans plusieurs types de diagramme. Exemple d'élément : cas d'utilisation (CU ou cadut'), classe, association, etc.
Mise en œuvre d'une démarche à l'aide d'UML : les vues
Une façon de mettre en œuvre UML est de considérer différentes vues qui peuvent se superposer pour collaborer à la définition du système :
- Vue des cas d'utilisation : c'est la description du modèle « vue » par les acteurs du système. Elle correspond aux besoins attendus par chaque acteur (c'est le QUOI et le QUI).
- Vue logique : c'est la définition du système vu de l'intérieur. Elle explique comment peuvent être satisfaits les besoins des acteurs (c'est le COMMENT).
- Vue d'implémentation : cette vue définit les dépendances entre les modules.
- Vue des processus : c'est la vue temporelle et technique, qui met en œuvre les notions de tâches concurrentes, stimuli, contrôle, synchronisation, etc.
- Vue de déploiement : cette vue décrit la position géographique et l'architecture physique de chaque élément du système (c'est le OÙ).
Nota : le POURQUOI, n'est pas défini dans UML.
Les diagrammes
Les 13 diagrammes UML sont dépendants hiérarchiquement et se complètent, de façon à permettre la modélisation d'un projet tout au long de son cycle de vie.
Diagrammes structurels ou statiques
Les diagrammes structurels ou statiques (Structure Diagram) rassemblent :
- Diagramme de classes (Class diagram) : il représente les classes intervenant dans le système.
- Diagramme d'objets (Object diagram) : il sert à représenter les instances de classes (objets) utilisées dans le système.
- Diagramme de composants (Component diagram) : il permet de montrer les composants du système d'un point de vue physique, tels qu'ils sont mis en œuvre (fichiers, bibliothèques, bases de données...)
- Diagramme de déploiement (Deployment diagram) : il sert à représenter les éléments matériels (ordinateurs, périphériques, réseaux, systèmes de stockage...) et la manière dont les composants du système sont répartis sur ces éléments matériels et interagissent entre eux.
- Diagramme des paquetages (Package diagram) : un paquetage étant un conteneur logique permettant de regrouper et d'organiser les éléments dans le modèle UML, le Diagramme de paquetage sert à représenter les dépendances entre paquetages, c’est-à-dire les dépendances entre ensembles de définitions.
- Diagramme de structure composite (Composite Structure Diagram) : depuis UML 2.x, permet de décrire sous forme de boîte blanche les relations entre composants d'une classe.
Diagrammes comportementaux
Les diagrammes comportementaux (Behavior Diagram) rassemblent :
- Diagramme des cas d'utilisation (use-cases ou Use Case Diagram) : il permet d'identifier les possibilités d'interaction entre le système et les acteurs (intervenants extérieurs au système), c'est-à-dire toutes les fonctionnalités que doit fournir le système.
- Diagramme états-transitions (State Machine Diagram) : permet de décrire sous forme de machine à états finis le comportement du système ou de ses composants.
- Diagramme d'activité (Activity Diagram) : permet de décrire sous forme de flux ou d'enchaînement d'activités le comportement du système ou de ses composants.
Diagrammes d'interaction ou dynamiques
Les diagrammes d'interaction ou dynamiques (Interaction Diagram) rassemblent :
- Diagramme de séquence (Sequence Diagram) : représentation séquentielle du déroulement des traitements et des interactions entre les éléments du système et/ou de ses acteurs.
- Diagramme de communication (Communication Diagram) : depuis UML 2.x, représentation simplifiée d'un diagramme de séquence se concentrant sur les échanges de messages entre les objets.
- Diagramme global d'interaction (Interaction Overview Diagram) : depuis UML 2.x, permet de décrire les enchaînements possibles entre les scénarios préalablement identifiés sous forme de diagrammes de séquences (variante du diagramme d'activité).
- Diagramme de temps (Timing Diagram) : depuis UML 2.x, permet de décrire les variations d'une donnée au cours du temps.
Les éléments de modélisation
- Le Stéréotype est une marque de généralisation notée par des guillemets, cela montre que l'objet est une variété d'un modèle.
- Le classeur est une annotation qui permet de regrouper des unités ayant le même comportement ou structure. Un classeur se représente par un rectangle conteneur, en traits pleins.
- Un paquetage regroupe des diagrammes ou des unités.
- Chaque classe ou objet se définit précisément avec le signe « :: », ainsi l'identification d'une Classe X en dehors de son package ou de son classeur sera définie par « Package A::Classeur B::Classe X ».
Les éléments de modélisation de type commun
Symbolique des modèles d'éléments :
-
Classe (Class)
-
Objet (Object)
-
Cas d'utilisation (Use case)
-
Paquetage (Package)
- Node (Nœud )
-
Nœud (Node)
- Fourche (Fork)
-
Acteur (Actor)
-
État (State)
-
Activité (Activity)
- État initial (Initial state)
- État terminal (Final state)
- Interface
- O<----- sens du flux de l'interface
- O)----- est un raccourci pour la superposition de →O et O←
Les éléments de modélisation de type relation
-
Dépendance (Dependency)
- Généralisation (Generalization)
- Association (Association)
-
Agrégation (Aggregation)
-
Composition (Composition)
- Réalisation
- Utilisation
Autres éléments descriptifs
- Les stéréotypes peuvent dépendre du langage que l'on souhaite utiliser
- Les archétypes
- Les profils
Standardisation et Certification UML
UML n'est pas un standard de fait mais un standard « industriel » de l'OMG (novembre 1997) au même titre que CORBA par exemple. Ceci étant, vu le succès initial de ce langage, il aurait pu tout aussi bien être simplement « standard de fait ». Depuis juillet 2005, la première version 2.* de UML est validée par l'OMG.
Par ailleurs, depuis 2003, l'OMG a mis en place un programme de certification à la pratique et la connaissance d'UML : OCUP[3] (OMG Certified UML Professional), qui recouvre trois niveaux successifs de maîtrise.
Exemple de séquence de création des diagrammes
Diagramme étape du cycle en V 1. Diagramme de cas d'utilisation Spécification, cahier des charges 2. Diagramme de séquence 3. Diagramme d'activité (processus métiers) 4. Diagramme d'activité (cinématique et/ou processus applicatifs) 5. Diagramme de classe Conception Architecturale 6. Diagramme d'objet 7. Diagramme de communication 8. Diagramme de déploiement 9. Diagramme de composant Logiciels de modélisation UML
Article détaillé : Comparaison des logiciels d'UML.Il existe de nombreux outils logiciels de modélisation UML. Malheureusement aucun d'entre eux ne respecte strictement aucune des versions de UML, particulièrement UML2 : beaucoup de ces outils introduisent des notations particulières non conformes, très peu supportent les différents types de diagrammes définis par le standard. Beaucoup en revanche incluent des outils de génération de squelette de code, particulièrement à partir du diagramme de classes, qui est celui qui se prête le mieux à une telle automatisation.
Notes et références
(en)OMG, « OMG Unified Modeling LanguageTM (OMG UML),Superstructure », OMG, aout 2011. Consulté le 20 novembre 2011
(en)OMG, « OMG Unified Modeling LanguageTM (OMG UML), Infrastructure », OMG, aout 2011. Consulté le 20 novembre 2011
Voir aussi
Liens internes
- Unified Process
- Ingénierie dirigée par les modèles
- MDA
- (en) MTL
- ATL
- OCL, (en) OCL
- Transformation
- (en) Transformation de modèles
- Modeling and Analysis of Real Time and Embedded systems
- Merise (informatique)
- Acceleo
- BLU AGE
- BOUML
- Modelio
- Open ModelSphere
- QVT
- SysML
- StarUML
- SunUML
- WebML
Liens externes
- (en) UML.org
- (en) OMG (Object Management Group)
- (en) UML liste des outils
Bibliographie
- Grady Booch, James Rumbaugh, Ivar Jacobson (2000). Le guide de l'utilisateur UML (ISBN 2-212-09103-6)
- (fr) UML 2 – de l'apprentissage à la pratique (cours et exercices) – Laurent Audibert – Ellipses 2009 (ISBN 978-2729852696)
- UML 2 et MDE, Ingénierie des modèles avec études de cas (Franck Barbier) ISBN 978-2-10-049526-9 Études de cas téléchargeables
- UML 2 et les Design Patterns - Craig Larman (3e édition) (ISBN 2-7440-7090-4)
- Martin Fowler et al. (2004). UML 2.0 (ISBN 2-7440-1713-2) : initiation aux aspects essentiels de la notation
- Pascal Roques, UML 2 - Modéliser une application Web, Eyrolles, 2007 (ISBN 2-212-12136-9)
- Pascal Roques, UML 2 par la pratique - Études de cas et exercices corrigés, Eyrolles, 2006 (ISBN 2-212-12014-1)
- Jim Conallen, Concevoir des applications web avec UML, Eyrolles, 2000, 288 p. (ISBN 978-2212091724)
Wikimedia Foundation. 2010.