Séminaire « Développement logiciel et ontologies » J.M. Vanel - 2009-10-03 Appliquer l'intelligence artificielle au génie logiciel Modélisation, moteurs.

Slides:



Advertisements
Présentations similaires
Web Sémantique: Le Relief Actuel
Advertisements

OIL & UPML DREVET - HUMBERT Introduction OIL : un langage de description dontologies UPML : un langage de description de systèmes à base.
Laboratoire de Bioinformatique des Génomes et des Réseaux Université Libre de Bruxelles, Belgique Introduction Statistics.
Moteurs de recherche ontologiques
Système de gestion d'entrées pour un cinéma Scanvion Michel – Etudiant 4.
Nouvelles technologies pour automatiser le développement Déductions J.M. Vanel Appliquer l'intelligence artificielle au génie logiciel Modélisation,
Séminaire « Développement logiciel et ontologies » J.M. Vanel Appliquer l'intelligence artificielle au génie logiciel Modélisation, moteurs.
Formation web sémantique J.M. Vanel RDF, RDF Schema, SPARQL, OWL, Modélisation, moteurs de règles Licence Creative Commons.
Le projet Déductions Faire tomber les murs du logiciel.
1 UML: applications, études de cas ● Processus (Extreme Programming, Unified Process) ● Architectures ● Expression du besoin technique Conception Préliminaire.
MDA ( Model Driven Architecture ). Introduction Model Driven Architecture ● Framework ● Développement de logiciels ● Object Management Group (OMG) ●
1 Case Study 1: UNIX and LINUX Chapter History of unix 10.2 Overview of unix 10.3 Processes in unix 10.4 Memory management in unix 10.5 Input/output.
Traffic Sign Recognition Jacob Carlson Sean St. Onge Advisor: Dr. Thomas L. Stewart.
Template Provided By Genigraphics – Replace This Text With Your Title John Smith, MD 1 ; Jane Doe, PhD 2 ; Frederick Smith, MD, PhD 1,2 1.
Subject: CMS(Content Management System) Université Alioune DIOP de Bambey UFR Sciences Appliquées et Technologies de l’Information et de la Communication.
FINAL EXAM FLIP CHART French 2 Semester 2
(Indirect Object Pronouns)
Support uniforme de types de données personnalisés dans RDF et SPARQL
(Indirect Object Pronouns)
OWL-S.
Collecte de données CAPI
Work: ISA8895 Implementation Section: Interoperability Chapter: B2O
Speaking Exam Preparation
Theme Two Speaking Questions
IDL_IDL bridge The IDL_IDLBridge object class allows an IDL session to create and control other IDL sessions, each of which runs as a separate process.
The past infinitive You already know how to use infinitives in some sentences. Ex. Le conflit va éclater entre les deux pays. Conflict is going to break.
Samples for evaluation from All Charts & Templates Packs for PowerPoint © All-PPT-Templates.comPersonal Use Only – not for distribution. All Rights Reserved.
Reflective verbs or Pronominal verbs
Quantum Computer A New Era of Future Computing Ahmed WAFDI ??????
Statistics & Econometrics Statistics & Econometrics Statistics & Econometrics Statistics & Econometrics Statistics & Econometrics Statistics & Econometrics.
Systèmes Intelligents – M2- BD-IA1 Protégé-OWL Tutorial 8 th International Protégé Conférence Madrid, July 2005 Nick Drummond, Matthew Horridge, University.
Global Tags Idées : Contient toutes les conditions du détecteur afin d’avoir une cohérence entre analyses de CMS (reproductibilité a 100%). Idéalement,
Theme One Speaking Questions
Déductions: appliquer l'IA au logiciel
1 RDF Schema pour les ontologies légères Présentation de la famille de primitives de formalisation proposées par RDFS.
© 2004 Prentice-Hall, Inc.Chap 4-1 Basic Business Statistics (9 th Edition) Chapter 4 Basic Probability.
Plus de 4000 langages....
Modèles de représentation des systèmes d’information
G. Peter Zhang Neurocomputing 50 (2003) 159–175 link Time series forecasting using a hybrid ARIMA and neural network model Presented by Trent Goughnour.
Lect12EEE 2021 Differential Equation Solutions of Transient Circuits Dr. Holbert March 3, 2008.
Introduction to Computational Journalism: Thinking Computationally JOUR479V/779V – Computational Journalism University of Maryland, College Park Nick Diakopoulos,
Comment créer des applications Sharepoint Intelligentes
Le soir Objectifs: Talking about what you do in the evening
Auditeur: Léonardo AMODIO Cours: NFE107
A Note the forms of the irregular verb connaître (to know). connaître
POLITIQUES EN FAVEUR DES JEUNES
Structuration des documents pédagogiques
SUJET : E C L A T UNIVERSITE GASTON BERGER DE SAINT LOUIS UFR DES SCIENCES APPLIQUEES ET DE TECHNOLOGIE MASTER PROFESSIONNEL EN DÉVELOPPEMENT DE SYSTÈMES.
ENSEIGNER L’ALGORITHMIQUE ET LA PROGRAMMATION AU COLLÈGE
1-1 Introduction to ArcGIS Introductions Who are you? Any GIS background? What do you want to get out of the class?
WRITING A PROS AND CONS ESSAY. Instructions 1. Begin your essay by introducing your topic Explaining that you are exploring the advantages and disadvantages.
(Direct Object Pronouns)
بسم الله الرحمن الرحيم.
PLATE FORME DE GESTION ÉLECTRONIQUE DE DOCUMENTS Présenté par: Amine LARIBI.
TP1 - DBMAIN BFSH Lausanne - Switzerland - Tel Université de Lausanne.
POWERPOINT PRESENTATION FOR INTRODUCTION TO THE USE OF SPSS SOFTWARE FOR STATISTICAL ANALISYS BY AMINOU Faozyath UIL/PG2018/1866 JANUARY 2019.
Les formes et les couleurs
Dans ma Salle de classe
Avoiding the Pitfalls of Bad Slides Tips to be Covered Outlines Slide Structure Fonts Colour Background Graphs Spelling and Grammar Conclusions Questions.
Design Patterns en programmation par objets
Le Passé Composé (Perfect Tense)
Les négatifs et l’interrogation
Les promesses des plateformes d’échanges de données
Soutenance de thèse: Okba Taouali 1 02/08/2019 Fathia AZZOUZI, Adam BOURAS, Nizar JEBLI Conceptual specifications of a cooperative inter- machines dialogue.
Over Sampling methods IMBLEARN Package Realised by : Rida benbouziane.
M’SILA University Information Communication Sciences and technology
Transcription de la présentation:

Séminaire « Développement logiciel et ontologies » J.M. Vanel Appliquer l'intelligence artificielle au génie logiciel Modélisation, moteurs de règles

Sommaire 1.RDF et la vision par le W3C du Web Sémantique 2.Modélisations SQL, UML, langages OO, RDFS, logique des propositions, OWL 3.Le langage N3, langage de convergence 4.Moteurs à base de règles (RETE) 5.Moteurs en logique des prédicats 6.Transformations de modèles via des règles 7.Architectures d'application 8.L'environnement EulerGUI centré sur le langage N3 9.Le projet Déductions

Partie 1 1.RDF et la vision par le W3C du Web Sémantique 2.Modélisations SQL, UML, langages OO, RDFS, logique des propositions, OWL 3.le langage N3, langage de convergence 4.Moteurs à base de règles (RETE) 5.moteurs en logique des prédicats 6.transformations de modèles via des règles 7.générateurs d'applications 8.l'environnement EulerGUI centré sur le langage N3 9.le projet Déductions

Web Sémantique: la vision ● Le Web lisible par une machine ● Via le format RDF (XML)

Web Sémantique: RDF ● Adapté au Web; tout est URI et types primitifs ● Un socle pour n'importe quel graphe d'objets (cf XMI) ● Monde ouvert: l'information disponible n'est pas supposée complète – on peut « annoter » tout ce qui a un URI; ● Qu'est ce qu'un URI ? ● Standards annexes: SPARQL, RDFa

Web Sémantique: RDF 2

Partie 2 1.RDF, RDFS et la vision par le W3C du Web Sémantique 2.Modélisation OWL 3.le langage N3, langage de convergence 4.Moteurs à base de règles (RETE) 5.moteurs en logique des prédicats 6.transformations de modèles via des règles 7.générateurs d'applications 8.l'environnement EulerGUI centré sur le langage N3 9.le projet Déductions

Modélisation: logique de description, OWL ● Adapté au raisonnement, via les « restrictions » – Si un programmeur est qq'un qui connait un langage de programmation, Richard Stallman sera classifié comme programmeur – Mais on peut aussi comme en Java, UML, etc, déclarer a priori l'apartenance à un classe ● Moteur (raisonneur) OWL: il classifie ● on a des algorithmes efficaces

OWL Lite: RDF Schema ● Class (Thing, Nothing) ● rdfs:subClassOf ● rdf:Property ● rdfs:subPropertyOf ● rdfs:domain ● rdfs:range ● Individual

OWL lite: (In)Egalité ● equivalentClass ● equivalentProperty ● sameAs ● differentFrom ● AllDifferent ● distinctMembers ● Sous-propriétés ● Classes disjointes ● Enumérations (oneOf)

OWL lite: Caractéristiques de propriété ● ObjectProperty ● DatatypeProperty ● inverseOf ● TransitiveProperty ● SymmetricProperty ● FunctionalProperty ● InverseFunctionalProperty

OWL lite: Restrictions de propriété ● Restriction ● onProperty ● allValuesFrom ● someValuesFrom

OWL lite: divers ● Intersection de classe : – intersectionOf ● Types de données XSD ● Propriétés d'annotation : – rdfs:label – rdfs:comment – rdfs:seeAlso – rdfs:isDefinedBy – AnnotationProperty – OntologyProperty

Modélisation facilitée – UML textuel Person<|---Customer---Buying<|---ServiceBuying <|---MerchandiseBuying HelpRequest Buying date: Date explanation: String Saisie 5 fois plus rapide qu'un éditeur UML ! Encore plus rapide que N3 !

Modélisation facilitée – Anglais contrôlé Every card is a means of a payment. Le modèle formel est récupéré à partir de la phrase: Card ---|> MeansOfPayment Project ACE ( Attempto Controlled English ) Essayez-le avec l'interface Ajax:

Récapitulation modélisation ● Exemple monétique: Client, Commande, Paiement ● Annotations RDF: incident de paiement, commandes passées ● Modélisation ● Modélisation OWL: classes dynamiques ( alors qu'en UML figées) ● Monde ouvert: RDF; SQL etc: monde fermé ● Règles: encore plus d'expressivité ● Anglais contrôlé → logique formelle ● UML simplifié

Partie 3 1.RDF, RDFS et la vision par le W3C du Web Sémantique 2.Modélisations SQL, UML, langages OO, RDFS, logique des propositions, OWL 3.le langage N3, langage de convergence 4.Moteurs à base de règles (RETE) 5.moteurs en logique des prédicats 6.transformations de modèles via des règles 7.générateurs d'applications 8.l'environnement EulerGUI centré sur le langage N3 9.le projet Déductions

N3 : données et owl:. :p1 a :Person ; :size :Person a owl:Class. :size a owl:DatatypeProperty ; rdfs:domain :Person ; rdfs:range xsd:double ; rdfs:label "size (m)". Données Modèle

Rule example 1 # add a field in the form for each property of a class: { ?CLASS gui:hasForm ?FORM. ?PROP rdfs:domain ?CLASS. } => { ?FORM gui:hasField ?FIELD. ?FIELD gui:inputWidgetSpecification ?PROP. }. ?CLASS, ?FORM, ?PROP are universally qualified FIELD is existentially qualified

Rule example 2 # The type of the field depends on the type of the # property: ObjectProperty or DatatypeProperty { ?FIELD gui:inputWidgetSpecification ?PROP. ?PROP a owl:DatatypeProperty. } => { ?FIELD a gui:DatatypeInputWidget. }.

OWL implemented with N3 logic ● as part of the Euler project, a library of N3 rules implements the logic of OWL and RDF Schema (transitive property, inheritance, etc), and other goodies, see: ● p/trunk/2003/03swap/rpo-rules.n3 p/trunk/2003/03swap/rpo-rules.n3 { ?P a owl:TransitiveProperty. ?S ?P ?X. ?X ?P ?O. } => { ?S ?P ?O }.

Partie 4 1.RDF, RDFS et la vision par le W3C du Web Sémantique 2.Modélisations SQL, UML, langages OO, RDFS, logique des propositions, OWL 3.le langage N3, langage de convergence 4.Moteurs à base de règles (RETE) 5.moteurs en logique des prédicats 6.transformations de modèles via des règles 7.générateurs d'applications 8.l'environnement EulerGUI centré sur le langage N3 9.le projet Déductions

Exemples de systèmes à base de règles ● Diagnostics médicaux ● juridique ● tarification d'appels téléphoniques ● processus métier (workflow): états et transitions – gestion de contenus (CMS): règles d'approbation – gestion de stock – Gestion relation client ● Suggestions de contacts (Facebook)

Moteurs de règles: avantages ● Une règle isolée a un sens ● Le moteur enchaîne les règles, pas le programmeur ● + efficace que la programmation classique ● Capture bien l'expertise métier ● Traduisible depuis et vers le langage naturel ● Les « systèmes experts « ont fait leurs preuves

Partie 5 1.RDF, RDFS et la vision par le W3C du Web Sémantique 2.Modélisations SQL, UML, langages OO, RDFS, logique des propositions, OWL 3.Le langage N3, langage de convergence 4.Moteurs à base de règles (RETE) 5.Moteurs en logique des prédicats 6.Transformations de modèles via des règles 7.Générateurs d'applications 8.l'environnement EulerGUI centré sur le langage N3 9.le projet Déductions

Comparaison moteurs FOL, moteurs de règles ● Avec FOL on peut : – Démontrer des théorèmes – travailler sur une connaissance « négative » ● Exemple jeu de damier: on sait que le monstre n'est pas dans les cases B2 et C3

Partie 6: Transformations 1.RDF, RDFS et la vision par le W3C du Web Sémantique 2.Modélisations SQL, UML, langages OO, RDFS, logique des propositions, OWL 3.Le langage N3, langage de convergence 4.Moteurs à base de règles (RETE) 5.Moteurs en logique des prédicats 6.Transformations de modèles via des règles 7.générateurs d'applications 8.l'environnement EulerGUI centré sur le langage N3 9.le projet Déductions

Transformations via des règles ● 2 architectures: – créer des objets de proche en proche, – annoter les objets existants si on a une correspondance 1 à 1 ● Comparaison avec XSLT – Avec la logique on est indépendant de la structure ● Comparaison avec QVT – On est dans la programmation logique; QVT est déclaratif mais ça reste assez procédural

Partie 7: générateurs 1.RDF, RDFS et la vision par le W3C du Web Sémantique 2.Modélisations SQL, UML, langages OO, RDFS, logique des propositions, OWL 3.le langage N3, langage de convergence 4.Moteurs à base de règles (RETE) 5.moteurs en logique des prédicats 6.transformations de modèles via des règles 7. Architectures d'applications 8.l'environnement EulerGUI centré sur le langage N3 9.le projet Déductions

OO and KB ● Object Oriented for the business data has lived – In OO, data model, bizz rules, infrastructure are mixed ● time for knowledge bases ! ● OO remains fit for the infrastructure code though ● A Copernican revolution !

Développement basé sur des ontologies - 1 Hiérarchie d'ontologies Ontologie haut niveau Ontologie s métier Ontologi e d'entrepr ise Ontologie applicativ e

Développement basé sur des ontologies – 2 – Scénario OO Ontologie applicativ e Classes métier brutes Classes métier + méthodes Présentation (IHM) Sources de données Générateur de code

Développement basé sur ontologies – 3 – Scénario OO+ moteur de règles Classes métier + méthodes Présentation (IHM) Sources de données Moteur de règles règles

Développement basé sur des ontologies – 4 – Scénario IA Ontologie applicativ e Présentation (IHM) Données utilisateur (faits) Moteur d'inférence Règles applicatives Application Base de connaissance

Partie 8 1.RDF, RDFS et la vision par le W3C du Web Sémantique 2.Modélisations SQL, UML, langages OO, RDFS, logique des propositions, OWL 3.le langage N3, langage de convergence 4.Moteurs à base de règles (RETE) 5.moteurs en logique des prédicats 6.transformations de modèles via des règles 7.générateurs d'applications 8.l'environnement EulerGUI centré sur le langage N3 9.le projet Déductions

EulerGUI EulerGUI est bati autour d'une simple classe: Project Sources: N3Source[] N3Query: N3Source RunDroolsTriples(): List

Le flux d'information (vu par le concepteur) Réutiliser la technologie existante Modèle métier SQ L UML POJ O RDFS, OWL Règl es N3 SWR L Rewers e Prolog Droo ls Déducti ons Applicati on Abstraite Platefor me Concrète Swin g PH P eclips e.Net JDB C Sesa me Web Services C embarqué

Cohérence et réutilisation Réutiliser les modèles existants Modèle métier Règl es Déducti ons Application 1 Java Swing MySQL Expose / appelle Services Web Extraction, particularisatio n Application 2 PHP MySQL Application 3

Partie 9 1.RDF, RDFS et la vision par le W3C du Web Sémantique 2.Modélisations SQL, UML, langages OO, RDFS, logique des propositions, OWL 3.le langage N3, langage de convergence 4.Moteurs à base de règles (RETE) 5.moteurs en logique des prédicats 6.transformations de modèles via des règles 7.générateurs d'applications 8.l'environnement EulerGUI centré sur le langage N3 9.le projet Déductions

The Deductions project ● Application generation – platform independence ● User-friendliness : the Good Servant ● component-based application building: Intelligent modularity ● Comprehension without prior protocol

Advanced GUI features ● GUI rules: building components tree, behavior: cardinalities, inheritance, constraints (solve to infer values), ● Advanced features: propagate edits or not (money Xfer between accounts), has few values, graph view (following user past actions, lens), zip paradigm ● record user actions, and show some simple feed-back, maybe last object creations used for suggesting object link ● show table view (like relational DB table) ● show tree view : 1. follow object properties; 2. follow subclassOf, then rdf:type ● demonstrate UML front-end

GUI: the good servant ● every user action should be recorded ● exploit to infer her/his intentions ● Also draw all consequences from the model and data

Intelligent modularity : letting valences connect ● Re-use the wealth of existing libraries and components ● Tag libraries with their purpose ● Add protocol state machines ● Then we can infer actual call sequence and automate application building ● Also possibility to find libraries and applications by their functionalities

Comprehension without prior protocol ● Between human and computer ● Between computers ● Leverage on linguistics – opencyc.org, WordNet, upper level ontologies: Sumo, Milo,... ● ACE project ( Attempto Controled English )

Conclusion ● Copernic revolution: the infrastructures and OO techniques are at the periphery, Ontologies and rules and at the center ● Reduce the Babel effect effect in computer science by applying AI techniques ● Automatize application building will allow IT projects to concentrate on essential matters: domain model and business rules