FR2835948A1 - Parametrage et compilation automatique de structures utilisant des reseaux de representation standard - Google Patents

Parametrage et compilation automatique de structures utilisant des reseaux de representation standard Download PDF

Info

Publication number
FR2835948A1
FR2835948A1 FR0213239A FR0213239A FR2835948A1 FR 2835948 A1 FR2835948 A1 FR 2835948A1 FR 0213239 A FR0213239 A FR 0213239A FR 0213239 A FR0213239 A FR 0213239A FR 2835948 A1 FR2835948 A1 FR 2835948A1
Authority
FR
France
Prior art keywords
module
parameter
computer device
interconnectable
tree structure
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Withdrawn
Application number
FR0213239A
Other languages
English (en)
Inventor
Bernard Hautbergue
Emmanuel Benoit
Stephane Donders
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
CROSSBEE
Original Assignee
CROSSBEE
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from FR0114144A external-priority patent/FR2831696A1/fr
Application filed by CROSSBEE filed Critical CROSSBEE
Priority to FR0213239A priority Critical patent/FR2835948A1/fr
Publication of FR2835948A1 publication Critical patent/FR2835948A1/fr
Withdrawn legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T1/00General purpose image data processing
    • G06T1/20Processor architectures; Processor configuration, e.g. pipelining

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Stored Programmes (AREA)

Abstract

L'invention concerne un dispositif informatique comprenant une première mémoire comportant une représentation de structure arborescente constituée d'une pluralité de modules interconnectables successifs et une entité de traitement capable de travailler avec la première mémoire. L'entité de traitement est capable de définir des paramètres (V, R), d'attribuer un paramètre à un module donné (M500) parmi la pluralité de modules interconnectables et d'instituer un héritage de ce paramètre à un module interconnectable déterminé parmi la pluralité de modules interconnectables.

Description

<Desc/Clms Page number 1>
Paramétrage et compilation automatique de structures utilisant des réseaux de représentation standard.
L'invention se rapporte au domaine des applications de processus.
Des modèles de représentation de processus sous forme de réseaux sont connus, par exemple les réseaux de Pétri, GRAFCET. Ces réseaux ne sont utilisés dans la plupart des cas que pour des processus industriels complexes. Ainsi, ces réseaux sont orientés vers la réalisation du processus final, exécutable par un algorithme reconnaissant les concepts développés dans les réseaux de Pétri, appelé séquenceur.
Cette orientation tend à limiter l'application à des processus industriels complexes.
L'invention vise notamment à améliorer la situation.
Elle propose à cet effet un dispositif informatique comprenant une première mémoire comportant une représentation de structure arborescente constituée d'une pluralité de modules interconnectables successifs et une entité de traitement capable de travailler avec la première mémoire.
Selon une caractéristique de l'invention, l'entité de traitement est capable de définir un paramètre, d'attribuer ce paramètre à un module donné parmi la pluralité de modules interconnectables et d'instituer un héritage de ce paramètre à un module interconnectable situé en aval du module donné parmi la pluralité de modules interconnectables.
Selon une autre caractéristique de l'invention, le dispositif informatique comprend un compilateur capable de travailler avec la première mémoire pour récupérer la structure arbores-
<Desc/Clms Page number 2>
cente et capable d'enregistrer dans une seconde mémoire le paramètre attribué pour le module donné et ce paramètre hérité pour le module interconnectable situé en aval du module donné.
Dans une réalisation avantageuse de l'invention, l'entité de traitement est capable de traiter une requête par lecture d'un paramètre relatif à un module interconnectable dans la seconde mémoire.
Dans une autre réalisation avantageuse de l'invention, l'entité de traitement est capable d'enregistrer dans la seconde mémoire, sur requête, un paramètre modifié relatif à un module interconnectable.
Avantageusement, l'entité de traitement est capable d'instituer un héritage du paramètre à un groupe de modules interconnectables situés en aval du module donné parmi la pluralité de modules interconnectables.
Selon un aspect de l'invention, l'entité de traitement est capable d'associer au module donné une structure arborescente supplémentaire et d'instituer un héritage du paramètre du module donné à au moins une partie de ladite structure arborescente supplémentaire.
Selon un aspect particulier de l'invention, le paramètre comprend une règle (R), une variable (V).
Selon une réalisation particulière de l'invention, la structure arborescente est une structure d'organisation et le paramètre comprend une règle d'organisation concernant une hiérarchie de fonctions et/ou une variable définissant ces fonctions.
Selon une réalisation complémentaire de l'invention, la structure arborescente est une structure d'organisation et en
<Desc/Clms Page number 3>
ce que le paramètre comprend une variable définissant des responsabilités issues des fonctions.
Selon une autre réalisation complémentaire de l'invention, la structure arborescente est une structure d'organisation et en ce que le paramètre comprend une information concernant un utilisateur rattaché à un module interconnectable de la structure arborescente.
Selon une réalisation optionnelle de l'invention, l'entité de traitement est capable d'attribuer une pluralité de paramètres à au moins un module donné parmi la pluralité de modules interconnectables.
L'invention concerne également un produit logiciel comprenant une interface utilisateur propre à élaborer la représentation de la structure arborescente du dispositif de l'invention.
Dans une réalisation optionnelle, l'interface utilisateur comprend un éditeur de graphe.
Dans une autre réalisation optionnelle, l'interface utilisateur comprend un éditeur de règles.
D'autres caractéristiques et avantages de l'invention apparaîtront à l'examen de la description détaillée ci-après, des dessins annexés sur lesquels : - la figure 1 illustre un environnement matériel dans lequel est réalisé l'invention.
Figure img00030001
- la figure 2 illustre un réseau représentant un processus, - la figure 3 représente schématiquement une structure de réseau représentant un processus selon l'invention,
<Desc/Clms Page number 4>
- la figure 4 représente une forme réseau simple de la structure de la figure 3, - la figure 5 représente une forme réseau simple associée à une forme réseau complexe de la structure de la figure 3, - la figure 6 représente un exemple de réalisation de la forme réseau complexe de la figure 5, assorti d'étiquettes en langage de programmation, - la figure 7 représente un exemple de réalisation présentant une structure arborescente d'objets selon l'invention,
Figure img00040001

- la figure 8 représente un exemple de réalisation d'une forme réseau complexe selon l'invention, - la figure 9 représente un ordinogramme de la définition d'une structure arborescente d'objets à un utilisateur avant utilisation, - la figure 10 représente un ordinogramme d'utilisation de la structure arborescente d'objets définie selon l'ordinogramme de la figure 9.
Les dessins contiennent, pour l'essentiel, des éléments de caractère certain. Ils pourront donc non seulement servir à mieux faire comprendre la description, mais aussi contribuer à la définition de l'invention, le cas échéant.
La figure 1 représente un environnement de matériel informatique comprenant une unité centrale 2 reliée à un système d'exploitation 4, une machine à traiter les réseaux 8 et des périphériques 6. La machine à traiter les réseaux 8 comporte un logiciel, une mémoire 7 comprenant une représentation de processus après modélisation de ce processus, un séquenceur 5 décrit ci-après selon l'invention.
<Desc/Clms Page number 5>
Il est connu de représenter graphiquement des processus sous forme de réseaux classiques tels que le réseau de Pétri, de Grafcet ou de blocs fonctionnels. Ces modèles sont utilisés notamment pour des descriptions de processus industriels complexes. Comme présentée sur la figure 2, une représentation hybride est adoptée dans la suite de la description, adaptable aux représentations classiques. Ainsi, la figure 2 présente un modèle de représentation de processus avec des concepts développés par les réseaux. Le modèle est défini à partir de différents concepts : - un noeud, appelé également place, activité ou tâche, représente une étape de processus, comme par exemple les places 1,10, 20,30 et 40 ; une transition est située entre deux places successives ; - un jeton 15 représente l'état d'avancement du processus, le passage du jeton d'une place à une autre est fonction de la validité des transitions ; - une transition, appelée également condition, comme Tlll, T211, T311 ou T411, supporte une condition de passage d'un jeton d'une place à la suivante, cette condition utilise des variables définies sur le réseau.
- un lien, par exemple Ll, est un chemin possible entre une place et une transition ; une succession de liens, comme par exemple L2, L3 et L4, peut définir une boucle partant, dans l'exemple, de la même transition T2 et arrivant à cette même transition T2 ; - une variable est définie par un nom et une valeur ; une variable locale est limitée au réseau sur lequel elle est définie, une variable globale est limitée à un ensemble de réseaux sur lequel elle est définie ; la valeur des variables peut être modifiée sur une place et testée sur une transition.
<Desc/Clms Page number 6>
D'autre part, des opérations logiques peuvent être représentées, par exemple les opérations ET convergent, ET divergent, OU convergent, OU divergent, OU exclusif. La représentation de ces opérations se fait en utilisant une combinaison particulière de liens et de transitions.
Dans la description, le terme module représente un élément d'un graphe par exemple. Ce terme peut également définir un noeud (c'est-à-dire une place ou une tâche) d'un processus dit de premier niveau.
La figure 3 illustre, en partie A, un processus sous forme d'un graphe de modules. Chaque module représente une partie de processus complexe. Le graphe est constitué d'un module Ml relié en parallèle selon trois conditions distinctes aux modules M2, M3 et M4. Ces derniers sont reliés selon trois autres conditions distinctes au module M5, lui-même relié, selon une condition, au module M6.
Cette représentation est destinée à l'utilisateur final qui peut définir ou simplement observer la partie de processus liée aux modules. Cette représentation est notamment générée par un éditeur spécifique. Chaque module prend en charge une fonction complexe du processus.
Ainsi, la représentation du processus sous forme de modules est reliée à la représentation du processus équivalent sous forme de réseau simplifié selon la partie B de la figure 3.
Chaque module de la partie A est représenté par deux places successives reliées par une transition selon la partie B.
La condition entre deux modules successifs de la partie A est représentée par une transition équivalente dans la partie B.
<Desc/Clms Page number 7>
Ainsi, selon la figure 4, le module Ml est représenté par une succession d'une place El, d'une transition et d'une place E10.
Dans une réalisation, El définit une place spécifiant la fonction complexe prise en charge par le module correspondant Ml. La transition est toujours validée et la place E10 ne comporte pas de fonction spécifique, E10 est constante.
Dans une autre réalisation, la place El ne comporte pas de fonction spécifique, El est constante. La transition est toujours validée. E10 définit une place spécifiant la fonction complexe prise en charge par le module correspondant Ml.
Dans la figure 3, les modules M2, M3, M4 et M6 sont reliés chacun à la représentation du processus équivalent sous forme de réseau simplifié. Ainsi, pour ces modules, le processus équivalent est représenté respectivement par deux places successives E2 et E20, E3 et E30, E4 et E40, E6 et E60.
Le module M5 définit entre autre un module de convergence entre les modules M2, M3 et M4 d'une part et le module M6 d'autre part. Ainsi, le module M5 est reliée à la représentation du processus équivalent sous forme de réseau simplifié.
Ce processus équivalent est représenté par les places E51, E52 et E53 en parallèle reliées à une transition à la place E50 de façon à définir une opération logique ET convergent.
Un séquenceur est défini comme un mécanisme d'ensemble permettant d'exécuter les tâches successives d'un processus lorsqu'il est défini sous forme de réseau avec les concepts réseau.
Cette représentation, remplaçant tous les modules par un équivalent standard sous forme de réseau, est utilisée pour qu'un séquenceur puisse notamment exécuter, module après
<Desc/Clms Page number 8>
module, le processus défini pour l'utilisateur final. Cette représentation permet de synchroniser un module avec ses prédécesseurs et ses successeurs.
La place grisée El de la partie B spécifiant une fonction complexe est associée à une représentation de réseau équivalent complexe illustrée en partie C de la figure 3. Ainsi, chaque place grisée E2, E3, E4 et E6 spécifie une fonction complexe associée à une représentation de réseau équivalent complexe. Ce réseau équivalent complexe représente le processus lié à la fonction complexe.
L'exemple du module 1 associé à une représentation de deux places équivalentes sous forme de réseau simplifié est plus particulièrement illustré sur la figure 5. Dans cet exemple, la première des deux places est associée à une représentation de réseau équivalent complexe. Dans une autre réalisation, la deuxième des deux places est associée à une représentation de réseau équivalent complexe. La place associée à une représentation de réseau équivalent complexe est appelée"place à équivalence complexe".
Ainsi, la place El est associée à un processus lié à la
Figure img00080001

fonction complexe. Ce processus comprend des places FI, F10, Fil, F12, F13 et F14 reliées entre elles par des transitions de manière à former un processus répondant aux exigences du module 1. Cette représentation détaillée est utilisée pour spécifier la fonction complexe prise en charge par un module dans l'exécution générale du processus. Cette représentation est utilisée pour calculer les fonctions internes du module.
Une place du processus équivalent sous forme de réseau simplifié est avantageusement un objet au sens d'un objet défini en programmation orientée objet.
<Desc/Clms Page number 9>
Le langage privilégié dans le reste de la description concernant les objets fait référence aux objets définis dans le langage de programmation java dans les références suivantes http : //Java. sun. com pour Java http : //Java. sun. com/beans/spec. html pour JavaBeans et/ou les documents imprimés correspondants, par exemple"The Java Language Specification", J. GOSLING, Bill Joy, Guy STEELE, Addison Wesley, 1996, ISBN 0-201-63451-1.
Toutefois, tout autre langage de programmation objet peut être utilisé, tel que le langage C++ défini à la référence suivante :"The C programming language", Brian W. Kernighan, Dennis M.
Ritchie.
Une classe mère est définie avec des attributs et des méthodes, notamment une méthode d'exécution appelée run ne définissant pas de paramètres et un attribut dont la valeur signifie la présence ou l'absence d'un jeton. Cette classe mère permet d'instancier les objets que sont les places du processus équivalent sous forme de réseau simplifié.
Avantageusement, les places du processus lié à la fonction complexe (partie C) sont définies comme des objets instanciés à partir d'une classe étendue de la classe mère, dite classe fille. Cette classe fille hérite des attributs et des méthodes de la classe mère et définit d'autres méthodes et attributs qui lui sont propres. De plus, chaque objet ainsi instancié peut utiliser une bibliothèque d'informations stockées dans une base de données par exemple. Ainsi, la méthode d'exécution run des objets instanciés à partir de la classe fille peut avoir pour paramètre, par exemple, des méthodes stockées dans une base de données.
Selon une réalisation, le système utilise l'algorithme que définit le séquenceur pour exécuter les places du processus équivalent sous forme de réseau simplifié. Pour chaque place
<Desc/Clms Page number 10>
à équivalence complexe dont l'attribut précise la présence d'un jeton, le séquenceur est apte à s'appeler lui-même pour exécuter le processus lié à la fonction complexe. Ainsi, le séquenceur est apte à exécuter les fonctions internes de chaque module, notamment les méthodes run des places définies dans le processus lié à la fonction complexe.
Le séquenceur est défini comme un algorithme récursif ou réentrant, c'est-à-dire que cet algorithme est apte à s'appeler lui-même.
Cette représentation de processus en trois niveaux différents (partie A, partie B, partie C) permet une description utilisateur simple, transformée en une suite de représentations complexes et exécutables par un algorithme unique standard et récursif, le séquenceur. De plus, certains attributs ou méthodes peuvent être modifiés de façon unique, les règles d'héritage intervenant pour propager la modification dans les différentes places concernées.
La figure 6 présente un exemple de réseau pour effectuer une fonction particulière associée à un module de la partie A de la figure 5. La figure 6 présente une forme complexe (correspondant à la partie C de la figure 5) d'un processus de validation mettant en oeuvre un système de négociation entre un demandeur et un exécuteur. Ce processus correspond à un algorithme externe affecté au module lors d'une phase de configuration.
Ce processeur peut être associé à l'une des trois phases d'exécution suivantes : - Pré-process : action automatique exécutée au début de chaque module, -Process : action programmée lors de la phase de configuration. Cette phase est adaptée notamment aux actions de type utilisateur (saisie d'informations par exemple). Une action
<Desc/Clms Page number 11>
utilisateur peut utiliser un principe de connecteur indépendant qui permet de démarrer des processus externes, par exemple un sous processus, une fonction indépendante.
- Post-process : action automatique exécutée systématiquement en fin de module.
Une action peut également être associée à d'autres phases d'exécution du réseau. D'autre part, un process peut consister à ne rien faire. Plus généralement, des phases d'exécution peuvent ne définir aucune action particulière.
Le pré-process commence à la place F100. Après la transition Tl, la place F140 permet d'attendre la requête du pré-process.
La place F120 permet d'effectuer le pré-process. Les places F140 et F120 sont toutes les deux reliées aux transitions T3 et T4 qui permettent respectivement de passer à la place F130 afin d'effectuer l'action du pré-process, et de passer à la place F160 de fin du pré-process. La place F130 est d'autre part reliée par une transition T2 à la place F140.
Une place F110 permet de déterminer une erreur survenue au niveau du pré-process. Cette place est reliée par une transition T12 à la place F150 permettant de désigner l'erreur du pré-process. Cette place F150 est associée à la transition T5 avec la place F160. Cette place F150 est également associée à la transition T17 pour arriver à l'étape F400 de fin de l'action en cours.
Après la transition T5, la place F240 permet d'attendre la requête du process. La place F220 permet d'effectuer le process. Les places F240 et F220 sont toutes les deux reliées aux transitions T7 et T8 qui permettent respectivement de passer à la place F230 afin d'effectuer le dernier process, et de passer à la place F260 de fin du process. Une place F270 qui permet de déterminer la dernière action du processus est
<Desc/Clms Page number 12>
reliée à la place F260 par la transition T8. La place F230 est d'autre part reliée par une transition T6 à la place F240.
Une place F210 permet de déterminer une erreur survenue au niveau du process. Cette place est reliée par une transition T13 à la place F250 permettant de désigner l'erreur du process. Cette place F250 est associée à la transition T15 avec la place F260. Cette place F250 est également associée à la transition T18 pour arriver à l'étape F400 de fin de l'action en cours.
Après la transition T15, la place F340 permet d'attendre la requête du post-process. La place F320 permet d'effectuer le post-process. Les places F340 et F320 sont toutes les deux reliées aux transitions T10 et T11 qui permettent respectivement de passer à la place F330 afin d'effectuer l'action du post-process, et de passer à la place F360 de fin du postprocess. La place F330 est d'autre part reliée par une transition T9 à la place F340.
Une place F310 permet de déterminer une erreur survenue au niveau du post-process. Cette place est reliée par une transition T14 à la place F350 permettant de désigner l'erreur du post-process. La place F360 est également reliée par la transition T14 à la place F350. Cette place F350 est associée à la transition T19 pour arriver à l'étape F400 de fin de l'action en cours. La place F360 est également associée à la transition T16 pour arriver à l'étape F400.
Un mode de réalisation de l'invention est présenté sur les figures 7 à 10. Ce mode de réalisation présente une application des éléments décrits ci-dessus pour la mise en place d'une structure arborescente d'objets. Dans l'exemple de réalisation décrit, la structure arborescente d'objets est appliquée à une entreprise.
<Desc/Clms Page number 13>
La figure 7 présente une structure arborescente d'objets Aa permettant de définir, sous forme de modules, la structure hiérarchique de l'entreprise. Ainsi, le module M500 représente le module de la direction générale relié aux modules du service des ventes M502, du marketing M504, de la production M506. Le module du service de la production est lui-même relié aux modules du service du produit C++ M510, du produit java M512, du produit QA M514. Le module du service du produit C++ M510 est relié au module du service Recherche et Développement 1 M520. Le module du service du produit java M521 est relié au module du service Recherche et Développement 2 M522. Chaque module est relié au module suivant en fonction d'une condition de passage.
La structure arborescente d'objets Aa est associée à une structure équivalente standard sous forme de réseau Ba. Ainsi, comme décrit plus haut, le module M500 est associé à un équivalent standard sous forme de réseau composé de deux places successives E500 et E501 reliées par une transition. Les module M502, M504 et M506 sont associés chacun à un équivalent standard sous forme de réseau composé de deux places successives, respectivement E502 et E503, E504 et E505, E506 et E507, reliées entre-elles par une transition.
Les module M510, M512 et M514 sont associés chacun à un équivalent standard sous forme de réseau composé de deux places successives, respectivement E510 et E511, E512 et E513, E514 et E515, reliées entre-elles par une transition.
Le module M520 est associé à un équivalent standard sous forme de réseau composé de deux places successives E520 et E521 reliées par une transition. Le module M522 est associé à un équivalent standard sous forme de réseau composé de deux places successives E522 et E523 reliées par une transition.
<Desc/Clms Page number 14>
Chaque ensemble de deux places successives reliées par une transition est relié à l'ensemble suivant par une transition correspondant à la condition de passage entre un module et le module suivant. Ainsi, le séquenceur peut atteindre une place à équivalence complexe si la transition en amont est valide.
Dans une réalisation avantageuse, des variables V sont associées à au moins certains modules, par exemple M500, et à la place à équivalence complexe associée, par exemple E500.
Ces variables V sont par exemple des attributs dans le cas d'objet (au sens programmation orientée objet). Ces variables V peuvent être des définitions de fonctions applicables dans l'entreprise, des définitions de responsabilités, des définitions d'équipes.
Dans une autre réalisation, des règles R sont associées à au moins certains modules, par exemple M500, et à la place à équivalence complexe associée, par exemple E500. Ces règles, définies plus amplement ci-après, peuvent comprendre des règles d'organisation concernant la hiérarchie des fonctions, des responsabilités issues de fonction.
Dans l'exemple de la réalisation proposée, chaque place à équivalence complexe est associée à un même réseau équivalent complexe représentant le processus lié à la fonction complexe
Figure img00140001

Ca.
La figure 8 illustre le réseau équivalent complexe de l'exemple de la figure 7. Ainsi, la place F500 représente le début du processus. Les transitions T5003, T5002, T5001 en parallèle permettent d'orienter le séquenceur respectivement vers une place de compilation de hiérarchie F506, une place de compilation de politique de voyage F504, une place de compilation de politique d'achat F502. Une fois l'exécution de la place F502,
<Desc/Clms Page number 15>
F504 ou F506 terminée, les transitions T502, T504, T506 permettent d'autoriser la fin du processus sur une place F508.
Lors de la mise en route du séquenceur, certains paramètres sont définis, comme un paramètre permettant de choisir entre l'exécution d'une compilation de la structure hiérarchique, l'exécution d'une compilation d'une politique de voyage et l'exécution d'une compilation de politique d'achat. Dans une réalisation de l'invention, ce paramètre est une variable globale.
Ainsi, le séquenceur est orienté vers l'une des trois exécutions pour chaque place à équivalence complexe en fonction de cette variable globale.
La figure 9 illustre un ordinogramme de mise en place chez un utilisateur d'un outil permettant de déterminer une structure organisationnelle selon une réalisation de l'invention. Cet outil comprend un moteur, un configurateur permettant de définir la structure, des variables, des règles (méthodes et attributs des objets) et une base de donnée. Le configurateur comporte un éditeur de graphe propre à définir la structure organisationnelle, certaines variables et un éditeur de règles propre à définir des règles. Le moteur comporte le séquenceur et des connecteurs.
Un connecteur peut être défini comme une interface permettant l'exécution par exemple d'un processus, l'exécution pouvant être synchrone ou asynchrone.
L'outil est tout d'abord installé à l'étape 100 chez l'utilisateur. L'étape 102 permet de créer une structure d'organisation hiérarchique dans l'exemple de réalisation présenté. L'exemple de structure d'organisation est donné pour une entreprise de voyage. Ainsi, un modèle organisationnel est tout d'abord créé via un outil graphique appelé éditeur de
<Desc/Clms Page number 16>
graphe. Les modules et les places associées du modèle sont également appelés unités d'organisation. Une entité à organiser est définie comme un ensemble d'unités d'organisation ayant une dimension transversale en commun. L'arborescence hiérarchique est créée et est définie différemment pour chaque entité à organiser de l'entreprise. Un ensemble de variables V, telles que définies précédemment, est associé à au moins certaines des unités d'organisation.
Un ensemble de règles R est associé à certaines au moins des unités d'organisation par l'éditeur de règles. Ces règles R comprennent par exemple - des règles de politique de voyages concernant des produits, des itinéraires, le modèle d'organisation, le profil d'un utilisateur, des opérateurs, les conditions de voyage ; - des règles de politique d'achat concernant des produits, des tarifs, des remises à priori et à posteriori, l'évolution des remises, le cumul de remises, des conditions pour y accéder, avec paramètres et objectifs.
Ces règles R et ces variables V dépendent également des unités d'organisation considérées.
Dans le cas des unités d'organisation qui n'ont pas de règles et/ou de variables directement associées, des principes d'héritage s'appliquent. En d'autres termes, ces unités d'organisation héritent des règles et/ou des variables des unités d'organisation en amont dans le modèle.
Dans la suite de la description, le terme compilation signifie que le moteur inscrit dans une base de donnée ou sous tout autre format les paramètres correspondant à la compilation demandée.
Une fois définie ces paramètres que sont le modèle organisationnel, les règles et les variables, l'étape 104 permet de
<Desc/Clms Page number 17>
compiler. Ainsi, comme proposé dans la figure 8, un paramètre de choix de compilation permet d'effectuer soit la compilation du modèle organisationnel, soit la compilation d'une politique de voyage, soit la compilation d'une politique d'achat.
Avantageusement, les trois compilations sont réalisées successivement. Le séquenceur permet, comme décrit précédemment, d'effectuer le processus équivalent complexe définissant les compilations possibles.
La compilation du modèle organisationnel implique l'enregistrement des informations concernant les unités d'organisation et les utilisateurs concernés, les liens de responsabilité, les hiérarchies, et ceci par entité à organiser. La compilation d'une politique de voyage implique l'enregistrement des informations concernant les règles de voyage applicables sur chaque unité d'organisation et ceci par entité à organiser. Enfin, la compilation d'une politique d'achat implique l'enregistrement des informations concernant les règles d'achat applicables sur chaque unité d'organisation et ceci par entité à organiser.
A l'étape 106, un utilisateur peut, sur requête, utiliser la structure organisationnelle pour obtenir des renseignements qui sont délivrés sans calcul, par exemple lus dans une base ou sous tout autre format.
A l'étape 108, les paramètres peuvent être modifiés sur demande d'un utilisateur. Le processus retourne à l'étape 102 afin de redéfinir certains paramètres puis d'effectuer une compilation adéquate à la modification des paramètres.
Si les paramètres ne sont pas modifiés, l'utilisateur a le choix de réutiliser la structure organisationnelle ou non à l'étape 110. Dans le cas d'une utilisation, le processus reprend à l'étape 106. Dans l'autre cas, le processus est terminé à l'étape 112.
<Desc/Clms Page number 18>
La figure 10 illustre plus particulièrement l'utilisation de la structure organisationnelle de l'étape 106 de la figure 9 par un employé désirant effectuer un voyage.
Ainsi, l'utilisateur est amené à rédiger une requête, appelée également ordre de mission à l'étape 200. L'employé est identifié ainsi que le contexte de la demande à l'étape 202.
Dans une partie de la base contenant la structure organisationnelle, le moteur lit les variables définissant le nom des personnes ayant les responsabilités correspondant à la requête à l'étape 204. Les prises de décision sont assignées à ces personnes à l'étape 206.
Parallèlement à l'étape 204, dans une autre partie de la base contenant les règles applicables à la politique de voyage, le moteur lit les variables définissant les règles de voyage correspondant à la requête à l'étape 208.
Parallèlement à l'étape 208, dans une partie différente de la base contenant les règles applicables à la politique d'achat, le moteur lit les variables définissant les règles d'achat correspondant à la requête à l'étape 210.
Après les tâches 208,210 et 206, l'étape 212 permet la réservation du produit, ici du voyage, correspondant à la requête de l'étape 200.
Bien entendu, l'invention n'est pas limitée à la forme de réalisation décrite précédemment à titre d'exemple, elle s'étend à d'autres variantes.
L'objet de l'invention peut être réalisé dans le cadre d'un logiciel. Il peut être réalisé pour être vendu en module indépendant pour être intégrer à un produit logiciel, par
<Desc/Clms Page number 19>
exemple être vendu à des intégrateurs ou des éditeurs de logiciel.

Claims (15)

  1. Figure img00200001
    Revendications 1. Dispositif informatique comprenant une première mémoire (7) comportant une représentation de structure arborescente constituée d'une pluralité de modules interconnectables successifs (M500, M506, M510) et une entité de traitement (8) capable de travailler avec la première mémoire, caractérisé en ce que l'entité de traitement (8) est capable de définir un paramètre, d'attribuer ce paramètre à un module donné parmi la pluralité de modules interconnectables et d'instituer un héritage de ce paramètre à un module interconnectable situé en aval du module donné parmi la pluralité de modules interconnectables.
  2. 2. Dispositif informatique selon la revendication 1, caractérisé en ce qu'il comprend un moyen de compilation capable de travailler avec la première mémoire pour récupérer la structure arborescente et capable d'enregistrer dans une seconde mémoire le paramètre attribué pour le module donné et ce paramètre hérité pour le module interconnectable situé en aval du module donné.
  3. 3. Dispositif informatique selon les revendications 1 et 2, caractérisé en ce que l'entité de traitement est capable de traiter une requête par lecture d'un paramètre relatif à un module interconnectable dans la seconde mémoire.
  4. 4. Dispositif informatique selon la revendication 3, caractérisé en ce que l'entité de traitement est capable d'enregistrer dans la seconde mémoire, sur requête, un paramètre modifié relatif à un module interconnectable.
  5. 5. Dispositif informatique selon l'une des revendications 1 à 4, caractérisé en ce que l'entité de traitement est capable d'instituer un héritage du paramètre à un groupe de modules
    <Desc/Clms Page number 21>
    interconnectables situés en aval du module donné parmi la pluralité de modules interconnectables.
  6. 6. Dispositif informatique selon l'une des revendications 1 à 5, caractérisé en ce que l'entité de traitement est capable d'associer au module donné une structure arborescente supplémentaire et d'instituer un héritage du paramètre du module donné à au moins une partie de ladite structure arborescente supplémentaire.
  7. 7. Dispositif informatique selon l'une des revendications 1 à 6, caractérisé en ce que le paramètre comprend une règle (R).
  8. 8. Dispositif informatique selon l'une des revendications 1 à 7, caractérisé en ce que le paramètre comprend une variable (V).
  9. 9. Dispositif informatique selon l'une des revendications 1 à 8, caractérisé en ce que la structure arborescente est une structure d'organisation et en ce que le paramètre comprend une règle d'organisation concernant une hiérarchie de fonctions et/ou une variable définissant ces fonctions.
  10. 10. Dispositif informatique selon la revendication 9, caractérisé en ce que la structure arborescente est une structure d'organisation et en ce que le paramètre comprend une variable définissant des responsabilités issues des fonctions.
  11. 11. Dispositif informatique selon l'une des revendications 1 à 10, caractérisé en ce que la structure arborescente est une structure d'organisation et en ce que le paramètre comprend une information concernant un utilisateur rattaché à un module interconnectable de la structure arborescente.
    <Desc/Clms Page number 22>
  12. 12. Dispositif informatique selon l'une des revendications 1 à 11, caractérisé en ce que l'entité de traitement est capable d'attribuer une pluralité de paramètres à au moins un module donné parmi la pluralité de modules interconnectables.
  13. 13. Produit logiciel comprenant une interface utilisateur propre à élaborer la représentation de la structure arborescente du dispositif selon l'une des revendications 1 à 12.
  14. 14. Produit logiciel selon la revendication 13, caractérisé en ce que l'interface utilisateur comprend un éditeur de graphe.
  15. 15. Produit logiciel selon l'une des revendications 13 et 14, caractérisé en ce que l'interface utilisateur comprend un éditeur de règles.
FR0213239A 2001-10-31 2002-10-23 Parametrage et compilation automatique de structures utilisant des reseaux de representation standard Withdrawn FR2835948A1 (fr)

Priority Applications (1)

Application Number Priority Date Filing Date Title
FR0213239A FR2835948A1 (fr) 2001-10-31 2002-10-23 Parametrage et compilation automatique de structures utilisant des reseaux de representation standard

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
FR0114144A FR2831696A1 (fr) 2001-10-31 2001-10-31 Parametrage et compilation automatique de structures utilisant des reseaux de representation standard
FR0213239A FR2835948A1 (fr) 2001-10-31 2002-10-23 Parametrage et compilation automatique de structures utilisant des reseaux de representation standard

Publications (1)

Publication Number Publication Date
FR2835948A1 true FR2835948A1 (fr) 2003-08-15

Family

ID=27624192

Family Applications (1)

Application Number Title Priority Date Filing Date
FR0213239A Withdrawn FR2835948A1 (fr) 2001-10-31 2002-10-23 Parametrage et compilation automatique de structures utilisant des reseaux de representation standard

Country Status (1)

Country Link
FR (1) FR2835948A1 (fr)

Similar Documents

Publication Publication Date Title
US10713608B2 (en) Systems and methods for a real-time workflow platform
US8332811B2 (en) Systems and methods for generating source code for workflow platform
EP0546894B1 (fr) Procédé de modélisation conceptuelle d&#39;expertise sur un système informatique
EP0527664B1 (fr) Procédé d&#39;aide au développement d&#39;un ensemble d&#39;automates communicants
MX2011010795A (es) Composicion dinamica de aplicaciones de procesamiento de flujo de datos.
FR2964224A1 (fr) Procede et dispositif de deploiement et d&#39;aide au deploiement de composants formant un systeme temps reel embarque
Arbez et al. The ABCmod conceptual modeling framework
EP3827368A1 (fr) Outil et procédé de conception et de validation d&#39;un système flots de données par un modèle formel
WO2017109386A1 (fr) Procede hors ligne d&#39;allocation d&#39;un logiciel embarque temps reel sur une architecture multicontrôleur multicoeur, et son utilisation pour des applications embarquees dans un vehicule automobile
FR3021769A1 (fr) Dispositif et procede de generation d&#39;au moins un fichier informatique pour la realisation d&#39;une interface graphique d&#39;un equipement electronique, et produit programme d&#39;ordinateur associe
FR2931272A1 (fr) Procede d&#39;import export de donnees d&#39;une base de donnees
EP1326148A2 (fr) Paramétrage et compilation automatique de structures utilisant des réseaux de représentation standard
FR2835948A1 (fr) Parametrage et compilation automatique de structures utilisant des reseaux de representation standard
EP3881515B1 (fr) Système de supervision formelle de communications
EP1907931A1 (fr) Architecture a composants logiciels pour les applications a plate-forme d&#39;execution donnant acces au niveau metaprogramme
US20180247206A1 (en) Sequencing of input prompts for data structure completion
FR2907240A1 (fr) Procede de simulation d&#39;un systeme complexe avec expansion de vecteurs d&#39;instances, produit programme d&#39;ordinateur et moyen de stokage correspondants
EP1262867A1 (fr) Procédé d&#39;implémentation d&#39;une pluralité d&#39;interfaces d&#39;objets
US20060064439A1 (en) Comparing process sizes
WO2020174186A1 (fr) Procédé de validation d&#39;un système flots de données
Ganishev et al. Adaptive workflow system concept for scientific project collaboration
FR2818401A1 (fr) Procede de generation automatique d&#39;applications embarquees et distribuees de controle-commande dans un reseau d&#39;automates a partir de la modelisation de ce reseau
FR2910650A1 (fr) Procede de commande d&#39;un equipement materiel
Balme et al. Ethylene: composants dynamiques pour la mise en œuvre d'IHM plastiques en informatique ambiante
WO1992017843A1 (fr) Dispositif perfectionne d&#39;evaluation de performance adaptable

Legal Events

Date Code Title Description
ST Notification of lapse