Cadre de référence pour l'analyse
Cette page présente le cadre de référence que M. Jackson1 propose pour l'analyse d'un système d'information. Ce cadre de référence nous permettra par la suite d'exprimer clairement nos besoins, de rédiger la spécification d'un système d'information, et de décrire son environnement.
La Machine
“To develop software is to build a Machine, simply by describing it.”
Jackson utilise le terme Machine pour évoquer ce que nous devons construire, car il estime que le terme « système » est trop ambigu (le système d'information comprend à la fois la Machine et le domaine d'application). Nous pouvons retrouver dans d'autres courants de pensées ce concept de Machine sous certains synonymes tels que « système à construire », SuD [“System under Development”2], « composante informatique/logicielle du système d'information ».
La Machine contient le logiciel lui-même, mais aussi le matériel générique (ordinateurs, terminaux, serveurs, réseau, etc.).
Le domaine d'application
“The parts of the world that will affect the Machine and will be affected by it are its Application Domain.”
Jackson définit le domaine d'application comme étant la partie du monde qui interagit avec la Machine. C'est l'environnement (les entités externes) qui communique directement avec la Machine, ou indirectement si il agit sur la Machine ou en subit les effets. C'est aussi la partie du monde sur laquelle la Machine maintient de l'information.
Nous retrouvons donc dans le domaine d'application des personnes, entités matérielles, informations sur l'environnement, etc.
Machine et Domaine d'Application
Nous pouvons envisager le domaine d'application comme étant donné pour la machine, même s'il est à construire, si nous considérons le système d'information dans son ensemble.
“This distinction between the Machine and the application domain is the key to the much-cited (but little understood) distinction between What and How: what the system does is to be sought in the application domain, while how it does it is to be sought in the Machine itself. The problem is in the application domain. The Machine is the solution.”
Nous retrouvons donc ce qu'il fait dans le domaine d'application tandis que comment il le fait est dans la machine elle-même.
Eléments de description
Nom | Portée | Mode |
Légende : A=domaine d'application; M=Machine | ||
Exigences | A | optatif |
Descriptions du domaine | A | indicatif |
Spécifications | M∩A | optatif |
Design | M\A | optatif |
Exigences
Les « exigences » (en anglais, “requirements”) sont les propriétés attendues du système d'information. Ce sont des assertions5 sur le domaine d'application que la machine doit contribuer à rendre vraies.
Les exigences portent donc sur le domaine d'application, sur un mode optatif6.
Lorsque nous formulons des exigences, nous exprimons des propriétés du domaine d'application qui seront vraies lorsque la machine existera. Nous ne parlons pas ici de la machine (le client connaît le domaine, mais pas encore la machine).
Nous retrouvons de nombreuses analogies entre les descriptions du domaine et des post-conditions.
Descriptions du domaine
Les descriptions du domaine sont des assertions5 indépendantes de la machine.
Nous retrouvons parfois les descriptions du domaine chez d'autres auteurs sous le terme d'hypothèses, bien que ce terme soit une source de mauvaise compréhension. En effet, les descriptions du domaine énoncent « ce qui est », et non « ce qui sera » lorsque la machine existera (ce sont alors des exigences).
Nous retrouvons de nombreuses analogies entre les descriptions du domaine et des pré-conditions.
Les descriptions du domaine portent sur le domaine d'application, sur un mode indicatif7. C'est ce qui nous protège au niveau du contrat; si les descriptions du domaine ne sont pas vraies, nous ne sommes pas responsables si la machine ne correspond pas aux attentes.
Nous retrouvons souvent à tort des descriptions du domaine dans la partie “requirements” (en français, « exigences ») de l'analyse.
Spécifications
Les spécifications sont des assertions5 sur le fonctionnement externe de la machine.
Les spécifications portent sur l'intersection entre le domaine d'application et la machine, sur un mode optatif6. Nous ne retrouverons donc pas ici de notions qui portent seulement sur le domaine d'application ou seulement sur la machine.
Nous rédigerons le plus souvent nos spécifications sous la forme de « stimuli/réaction ».
Design
Les éléments de design sont des assertions5 sur le fonctionnement interne de la machine.
Le design porte sur la différence entre la machine et le domaine d'application, sur un mode optatif6. Nous ne retrouverons donc ici que des notions qui n'appartiennent qu'à la machine et à elle seule.
Nous pouvons nous interroger sur la légitimité de la présence d'éléments de design à ce stade de la conception d'un système d'information (l'analyse, partie description), mais M. Jackson le place parmi les quatre éléments de description.
La présence de contraintes de design à ce stade de l'analyse cache souvent une exigence mal formulée par le client. Ces notions pourraient figurer à titre informatif, par exemple si l'usage du langage C était requis pour des raisons de performances par rapport au C#. Cependant, un tel exemple devrait spécifier la nécessité de performance au lieu de citer un langage particulier (ce qui limite toute prise de décision ultérieure).
Résumé
Si la Machine se comporte comme indiqué dans sa spécification, et si le domaine d'application se comporte comme l'indiquent les descriptions du domaine, alors le système d'information respecte les exigences qui lui sont imposées.
Nederlandse vertaling
U hebt gevraagd om deze site in het Nederlands te bezoeken. Voor nu wordt alleen de interface vertaald, maar nog niet alle inhoud.Als je me wilt helpen met vertalingen, is je bijdrage welkom. Het enige dat u hoeft te doen, is u op de site registreren en mij een bericht sturen waarin u wordt gevraagd om u toe te voegen aan de groep vertalers, zodat u de gewenste pagina's kunt vertalen. Een link onderaan elke vertaalde pagina geeft aan dat u de vertaler bent en heeft een link naar uw profiel.
Bij voorbaat dank.
Document heeft de 05/06/2010 gemaakt, de laatste keer de 27/10/2018 gewijzigd
Bron van het afgedrukte document:https://www.gaudry.be/nl/analyse-systeme-information-reference.html
De infobrol is een persoonlijke site waarvan de inhoud uitsluitend mijn verantwoordelijkheid is. De tekst is beschikbaar onder CreativeCommons-licentie (BY-NC-SA). Meer info op de gebruiksvoorwaarden en de auteur.
- ↑ M. Jackson : Michael Jackson est un scientifique anglais connu pour ses recherches en génie logiciel, et ses méthodes de développement logiciel. Dans l'ordre de création, nous pouvons citer
- “Jackson Structured Programming” (JSP) qui couvre le design des programes
- “Jackson System Development” (JSD) qui couvre non seulement le design des programes, mais aussi du système en entier (plus particulièrement les systèmes d'information)
- “Problem Frames Approach” qui s'applique à tous les types de développements de logiciels, et non seulement les systèmes d'information
- ↑ exigences : komt overeen met “requirements” en anglais
- ↑a,b,c Mode optatif : sera vrai uniquement quand la Machine existera. Nous pouvons aussi parler de mode prescriptif.
- ↑ Mode indicatif : est supposé comme étant déjà vrai. Nous pouvons aussi parler de mode descriptif.
- ↑ requirements : komt overeen met « exigences » en français
Referenties
- Software Requirements & Specifications : M. Jackson,
A Lexicon of Practice, Principles and Prejudices
(1995) - IHDCB335 - AMSI : Patrick HEYMANS,
Analyse et modélisation des systèmes d'information
(2009)
Deze verwijzingen en links verwijzen naar documenten die geraadpleegd zijn tijdens het schrijven van deze pagina, of die aanvullende informatie kunnen geven, maar de auteurs van deze bronnen kunnen niet verantwoordelijk worden gehouden voor de inhoud van deze pagina.
De auteur Deze site is als enige verantwoordelijk voor de manier waarop de verschillende concepten, en de vrijheden die met de referentiewerken worden genomen, hier worden gepresenteerd. Vergeet niet dat u meerdere broninformatie moet doorgeven om het risico op fouten te verkleinen.