Skip to content
Jean-Marc Vanel edited this page May 2, 2017 · 31 revisions

User Manual in english

SF, qu'est ce que c'est?

Semantic_forms est une application générique à la fois de navigation du web sémantique et d'annotation, et un cadriciel (framework) pour construire des applications d'entreprise centrées sur les formulaires (entrée ou lecture seule). Ce manuel parle de l'application générique. Pour les autres aspects, voir le Wiki.

Toutes les données et tous les modèles de données (ontologies) s'appuient sur les recommandations du Web sémantique du W3C: https://fr.wikipedia.org/wiki/Semantic_Web

Utiliser, installer

Un bac à sable est ici: http://163.172.179.125:9111/

On peut aussi télécharger la distribution et lancer l'application web sur sa machine, voir: Installation de l'application générique semantic_forms

Usages possibles

Les usages peuvent être personnels (via la distribution zip qui est une application web), ou collective lorsque hébergé sur un serveur. Avec seulement les modèles par défaut et les formulaires associés, ces usages sont possibles:

  • gestionnaire de contacts,
  • gestionnaire de projets,
  • moteur de blog,
  • gestionnaire de notes,
  • ...

On peut créer son profil FOAF (pour l'héberger en statique ailleurs ou le visualiser dans l'application), naviguer sur le Web de données en gardant trace, ou tout type de gestion de données structurées.

La techniques sous-jacente

En ce qui concerne la mise en œuvre, Semantic_forms tire parti de Jena TDB, de Play! Framework, Scala et Banana-RDF.

Semantic_forms est fonctionnel en sortant de la boîte, une fois qu'on a dézippé le logiciel, ou qu'on l'a construit à partir des sources. Pas besoin d'installer séparément une base de données ou d'autres composants. Vous pouvez naviguer dans vos données RDF (Turtle, JSON-LD) chargées dans la base locale Jena TDB aussi facilement que dans les profils FOAF sur Internet, ou mélanger les deux. Semantic_forms ressemble aux pages de DBPedia (par exemple http://dbPedia.org/resource/Cycas), mais où l'on peut aussi modifier tous les champs, et charger n'importe quelles données du LOD, y compris des modèles de données et des formulaires.

Le code et la façon de construire à partir de sources sont ici: https://github.com/jmvanel/semantic_forms/tree/master/scala/forms_play .

Authentification et comptes

Avant de faire quoi que ce soit, il faut s'authentifier et/ou créer un compte avec un nom d'utilisateur et un mot de passe.

NOTE: pour l'instant il n'y a pas de mail associé aux compte. Cependant le nom d'utilisateur peut être votre mail, précédé par mailto: , ainsi transformé en URL.

ATTENTION il faut choisir un nom d'utilisateur qui soit un URI absolu (comme "u:uu"). Certaines choses ne marcheront pas avec un URI relatif (comme "bla" ou "/ble").

Naviguer

Essayez de glisser / déposer cet URI dans le champ "Afficher": http://dbpedia.org/resource/Bobby_Bland

Vous allez voir des paires propriété-valeur au sujet de ce chanteur, Bobby Bland. Cela constitue autant de triplets sujet-propriété-valeur, qui sont l'essence du Web Sémantique. On peut voir aussi des statistiques sur les données téléchargées depuis cet URI, par exemple:

23 subjects, 229 triples, 52 predicates, 148 objects, 148 objects from page URI 

Pour s'initier au Web Sémantique, à part l'utilisation de Semantic_forms, vous pouvez regarder cette courte introduction . Voir aussi la page wikipedia.org Web Sémantique.

D'une manière générale, coller dans le champ "Afficher" un URI téléchargeable, disons <U1>, que ce soit un dbpedia ou profil FOAF, ou une ontologie, affiche les triplets au sujet de <U1> , c'est à dire:

<U1> ?P ?O.

comme l'application web DBPedia.org le fait aussi. Ensuite, vous pouvez naviguer de liens en liens, tout comme dans DBPedia (et aussi dans le LOD, ce que DBPedia.org ne fait pas).

Pour voir les liens "inverses"

?S ?P <U1> .

cela se passe différemment de DBPedia.org . Comme ils peuvent être très nombreux, ils ne sont pas affichés dans la même page, il y a un bouton "liens inverses" sur la page (et sur chaque triplet).

Si on ne trouve pas ce qu'on veut dans les "liens inverses", on peut lancer la "recherche étendue". Celle ci va chercher tout ce qui est à 2 sauts dans le graphe global (4 possibilités: direct-direct, direct-inverse, inverse-direct, inverse-inverse).

Il y a quelques points de départ dans le champ de saisie "URI pour afficher", cliquez sur le triangle sur la droite.

Chargement de données sémantiques

En naviguant comme ci-dessus, vous avez visualisé, et vous avez aussi chargé. Qu'est ce que des données sémantiques? Il s'agit d'URL (URI) qui contiennent non pas du contenu destiné à la visualisation directe (HTML), mais des triplets. C'est ce qu'on appelle LOD (Données Ouvertes Liées, Linked Open Data). Typiquement, ces URI téléchargeables sont:

  • des profils personnels FOAF: exemple: mon profil FOAF public
  • des entrées de dbpedia.org comme ci-dessus
  • un URI d'un conteneur LDP (Linked Data Platform): exemple: les URI créés par Semantic_forms lui-même.

En quoi consiste le chargement des données sémantiques? La navigation et l'affichage d'un URI téléchargeable charge également dans la base de données (base SPARQL Jena TDB). Et ensuite, les données téléchargées sont ré-utilisées partout dans l'applications: affichage des triplets, des formulaires, des libellés (à partir de rdfs:label et autres prédicats), recherche, ... Ainsi, au fur et à mesure de la navigation, on se fait sa propre sélection de l'Internet des données. Et si c'est une instance partagée de Semantic_forms, on partage:

  1. la connaissance de ce qui a été chargé par chacun, via la page historique, historique sur localhost ),
  2. la possibilité de créer des liens sémantiques via un menu déroulant (voir édition plus bas)

Le cache et la base de données RDF

La base de données Jena TDB agit comme un cache (indexé par horodatage Last-Updated par ETag, par Expires) pour les données RDF Internet, ce qui signifie:

  • Afficher la deuxième fois est beaucoup plus rapide;
  • En tenant compte des en-têtes HTTP, les données peuvent être rechargées si la source distante est modifiée

A l'intérieur de la base de données RDF (SPARQL), les triplets téléchargés à partir de l'URI <U1> sont chargés dans un graphe nommé dont le nom est aussi <U1>. C'est ce qu'on appelle le "cache sémantique".

Vous pouvez avoir une vue sur les graphes nommés dans la page "outils"; ici dans le sandbox : http://163.172.179.125:9111/tools , et ici en local.

Avertissement sur l'usage

Si vous voulez juste naviguer sur la source de données dbPedia.org, par exemple dbPedia.org, sans vouloir enrichir la base commune avec les URL parcourus, il vaut mieux ne pas utiliser une instance partagée de Semantic_forms. Dans ce cas, vous pouvez naviguer à peu près de la même façon sur dbPedia.org lui-même.

Édition

Modification des données existantes

Lors de l'affichage d'un objet par son URI, cliquez sur l'icône "crayon" pour afficher un formulaire de saisie pour cet URI. Vous pouvez modifier n'importe quel triplet, et créer plusieurs valeurs avec le bouton "+". Lorsque vous avez terminé l'édition, le bouton SAUVER met à jour la base de données.

Pour enlever un triplet, enlever le contenu du champ de saisie. La donnée sera supprimée dans la base lors de l'appui sur le bouton SAUVER.

ATTENTION: il n'y a pas de vérification que des données entrées pourraient être perdues si on appuie sur autre chose que le bouton SAUVER.

Création d'une nouvelle ressource d'un certain type RDF

Choix de la classe

Il y a deux manières. On peut d'abord simplement se baser sur les classes suggérées définies dans la page Web. On sélectionne dans le menu déroulant à proximité du bouton "Créer" l'une des classes pré-définies (les classes FOAF, etc). on appuie sur le bouton "Créer", et le formulaire inféré pour la classe sera affiché.

Vous pouvez prendre également n'importe quelle classe OWL ou RDF Schéma, qui soit auto-hébergée. C'est à dire que l'URI (URL dans ce cas) de la classe permet de de télécharger les triplets qui définissent celle-ci, ou bien toute l'ontologie à laquelle elle appartient. Cela fait partie des bonnes pratiques du web sémantique (cf les 5 étoiles sur la tasse de Tim B.L. ).

Donc vous pouvez coller l'URI d'une classe dans le champ "Créer", Essayez de chercher une classe RDF depuis les moteurs de recherche LOV ou Swoogle, et de le glisser / déposer dans le champ "créer une instance". Par exemple glisser-déposer cette URL pour créer une espèce biologique: http://dbpedia.org/ontology/Species

REMARQUE: par défaut de nombreuses ontologies utiles sont pré-chargées, comme l'ontologie DBPedia (voir "README updading RDF content"  pour en pré-charger plus). Dans le cas où l'ontologie ne serait pas pré-chargée, cela marchera quand, parce que SF va la télécharger. Vous pouvez aussi la charger explicitelent , comme tous les types de données, à partir de son URL, comme expliqué ci-dessus dans Navigation. A noter que, après le téléchargement de l'ontologie, vous ne verrez pas grand'chose, car vous ne verrez typiquement que les triplets au sujet de l'ontologie elle même. Cependant toutes les classes et propriétés sont bien là, comme le montrent les statistiques de téléchargement.

Edition des formulaires

Les champs littéraux (chaînes de caractères) sont entrés en fonction de leur type de données (chaîne simple, nombre, date, ...) avec des champs d'entrée conformes à HTML5. Le bouton "EDIT" à proximité ouvre une fenêtre pour entrer un texte de plusieurs lignes.

Les champs de resources (liens sémantiques) sont saisis soit par:

  1. le choix d'une valeur possible par menu déroulant, et qui a été inférée des triplets contenant rdfs:domain, rdfs:range, rdf:type et rdfs:subclassOf,
  2. Coller, ou glisser-déposer, un URI venant d'ailleurs (page web ordinaire, ou application Semantic_forms),
  3. Entrer n'importe quelle chaîne, qui sera ajoutée dans la base de données comme un URI (les espaces seront remplacés par des soulignés; le rdf:type de cette nouvelle URI est défini selon les ontologies dans la base de données (lors de l'enregistrement du formulaire).

L'option 3 crée une nouvelle ressource dans la base de données, qui pourrait déjà exister; il vaut mieux regarder d'abord dans le menu déroulant pour entrer une ressource déjà existante. Ce comportement est similaire à un Wiki ordinaire, où l'on crée un lien (rouge) que l'on peuplera ensuite. Mais ici c'est un "wiki sémantique", où chaque noeud est typé.

Remarquez les champs marqués avec "complétion dbPedia», comme compétences et points d'intérêt. Là, on tape quelques lettres, et c'est complété par les concepts pertinents de Wikipedia (en anglais). La complétion fonctionne sur Firefox, Chrome, Opéra, et Android (mais il se peut que le serveur dbPedia Lookup soit hors service).

Annotation de sites web

Si on "charge" un site web non sémantique (non RDFa ni microdata), il se passe ceci dans semantic_forms:

  • le type foaf:Document lui est attribué
  • un formulaire approprié est ouvert en édition, qui permet de lui ajouter des métadonnées, et notamment des dc:subject via la complétion dbPedia

On a un ainsi une fonctiopnalité de type Diigo, mais avec le vaste thésaurus de Wikipedia.

Graphe et diagrammes

Les bases de données en graphe (structure mathématique avec des noeuds et des liens) sont à la mode. Justement le Web Sémantique constitue un immense graphe, dont les noeuds sont les URI des resources traitées, et les liens sont représentés par les triplets sujet-propriété-objet.

Cet immense graphe est la réunion de tous les documents RDF (ou Turtle ou JSON-LD) publics (Linked Open Data) ou même privés. Dès qu'un même URI est référencé par deux documents RDF, les graphes sont ainsi connectés.

Bien sûr, cet immense graphe (la partie publique) n'est pas couramment chargé dans une base de données. Mais c'est possible. Ce qu'on fait, plus modestement, dans Semantic_forms est de charger au fur et à mesure de la navigation. On maintient ainsi un graphe pertinent par rapport aux usages. Les (multiples) chemins d'un URI à un autre prennent en compte toutes les sources chargées. Ces chemins sont navigables par des pages de l'application, mais aussi et surtout par programme:

  • requêtes SPARQL
  • algorihmes de graphes

La structure de graphe est plus générale que celles d'arbre et de table. Ce qui signifie que les arbres et les tables peuvent facilement se reformuler en graphes. Et dans l'autre sens, une table peut de manière naturelle être vue comme un graphe.

A partir de l'application Semantic_forms, on peut tracer des diagrammes en appuyant sur les icones au triangle avec 3 ronds. On ne peut (encore) ajouter / enlever des noeuds dans ces diagrammes, voir l'issue: https://github.com/jmvanel/semantic_forms/issues/91

A noter qu'on peut générer un diagramme à partir d'une requête quelconque, dans la page /tools . On peut ainsi confectionner son graphe à volonté, par exemple, mes amis et les amis de mes amis:

PREFIX foaf: <http://xmlns.com/foaf/0.1/>

CONSTRUCT {
  <http://jmvanel.free.fr/jmv.rdf#me> foaf:knows ?FRIEND .
  ?FRIEND foaf:familyName ?N1 .
  ?FRIEND foaf:knows ?FF .
  ?FF foaf:familyName ?N2 .
} WHERE {
  GRAPH ?GR {
   <http://jmvanel.free.fr/jmv.rdf#me> foaf:knows ?FRIEND .
  }
  {
    GRAPH ?GR2 {
     { ?FRIEND foaf:familyName ?N1 . }
     UNION { ?FRIEND foaf:knows ?FF . }
    }
  } UNION {
  GRAPH ?GR3 {
     ?FF foaf:familyName ?N2 .
    }
  }
}

Divers

Outils

Ce site offre un convertisseur commode entre RDFa, Turtle, etc: http://www.easyrdf.org/converter

Clone this wiki locally