From fae265445ac4d8ef44d1c4361608e8beadc670dd Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?J=C3=A9r=C3=B4me=20Euzenat?= <Jerome.Euzenat@inria.fr>
Date: Thu, 9 Jul 2009 12:10:21 +0000
Subject: [PATCH] - Added working tutorial2

---
 html/relnotes.html           |  51 +++++---
 html/tutorial2/MyApp.class   | Bin 0 -> 9527 bytes
 html/tutorial2/MyApp.java    | 192 ++++++++++++++++++------------
 html/tutorial2/Skeleton.java | 220 +++++++++++++++++++++++++++++++++++
 4 files changed, 370 insertions(+), 93 deletions(-)
 create mode 100644 html/tutorial2/MyApp.class
 create mode 100644 html/tutorial2/Skeleton.java

diff --git a/html/relnotes.html b/html/relnotes.html
index d20d26b5..3d8dc411 100644
--- a/html/relnotes.html
+++ b/html/relnotes.html
@@ -14,10 +14,10 @@
   change your code; minor release numbers bring bug fixes and new
   functionnalities but should not require change in existing code.</p>
 
-<h2>Plan for release 4 (you can comment)</h2>
+<h2>Plan for release 5 (you can comment)</h2>
 
 <p>
-The next major release, release 4, is now in sight due to various
+The next major release, release 5, is now in sight due to various
 constraints and needs that have arousen in the past months. Here are
 the main ruptures that will appear:
 <ul compact="1">
@@ -27,25 +27,16 @@ the main ruptures that will appear:
   will provide the opportunity to define everyone owns relation (and
   generalise the use of relation algebras). (api/impl)</li>
 <li>The <tt>onto</tt> package will be fully externalised from the
-  Alignment API. This means in particular (a) the full disappearance
-  of the the <tt>OWLAPICell</tt> and <tt>OWLAPIAlignment</tt>
-  deprecated since version 3.3, (b) virtualisation of the Ontology
-  support from OMWGAlignments which are currently based on Jena, (c)
+  Alignment API. This means in particular (a) virtualisation of the Ontology
+  support from OMWGAlignments which are currently based on Jena, (b)
   release of separated subpackages offering OWL API 1.0, OWL API 2.0,
-  Jena 2.5, OLGraph and SKOS. (onto)</li>
-<li>Creation of a different project, OntoSim, for supporting distances
-  and similarities across ontologies. This project will adopt several
-  parts of the current implementation part. It will have no impact on
-  the API.</li>
+  Jena 2.5, and SKOS. (onto)</li>
 </ul>
 Other less radical changes include:
 <ul compact="1">
-<li>Replacement of <tt>Parameters</tt> by Java <tt>Property</tt> (api/impl)</li>
 <li>Implementation of <tt>Relation</tt> and <tt>Confidence</tt> interfaces </li>
 <li>Implement <tt>onto</tt> support in database store (server)</li>
 <!--li>Move <tt>OLgraphs</tt> as HeavyLoadedOntology (onto)</li-->
-<li>Integrate OWMG as part of the Alignment API code (impl)</li>
-<li>Implement database store for OMWG Language (server)</li>
 </ul>
 Currently the development and maintainance of 3 versions continue.
 </p>
@@ -60,6 +51,8 @@ Currently the development and maintainance of 3 versions continue.
 <li>Improve HTML interface layout and usability (server)</li>
 <li>Implement metadata edition (server)</li>
 <li>Implement correspondence selection (server)</li>
+<li>Implement semantic precision and recall (impl)</li>
+<li>Implement fully relaxed precision and recall (impl)</li>
 <li>Render alignments as module descriptions (impl)</li>
 <li>Implement extensive evaluation framework (impl)</li>
 <li>Implement debug options with log4j</li>
@@ -67,16 +60,21 @@ Currently the development and maintainance of 3 versions continue.
 <li>Add more tests</li>
 </ul></p>
 
-<h2>Next version (3.7: Rouquine carm&eacute;lite)</h2>
+<h2>Next version (4.0: Rouquine carm&eacute;lite)</h2>
 
 <p>
 This version under development is planned for next September. It is
 likely to include:
 <ul>
-<li>Integration of OMWG alignments</li>
-<li>Migration to OWL API 2 as the default Ontology implementation</li>
-<li>Separation from <a href="http://ontosim.gforge.inria.fr">OntoSim</a></li>
 <li>Integrate some basic reasoning.</li>
+<li>Implementing semantic precision and recall /bug (impl).</li>
+<li>Added a parameter to the OWLAxiomsRenderer so that it could render
+  heterogeneous axioms, like Class sameAs Property (impl).</li>
+<li>Bug in triming, maybe leaves one item to much (impl)</li>
+<li>Integration of OMWG alignments (impl)</li>
+<li>Replacement of <tt>Parameters</tt> by Java <tt>Property</tt> (api/impl)</li>
+<li>Implement database store for OMWG Language (server)</li>
+<li>Addition of advanced tutorial (doc)</li>
 </ul>
 </p>
 
@@ -88,9 +86,24 @@ likely to include:
 
 <p>
 <ul compact="1">
+<li>Separated the Alignment API from <a href="http://ontosim.gforge.inria.fr">OntoSim</a> (impl/ling)</li>
+<li>Reintegrated <tt>JWNLAlignment</tt> in implementation (procalign)</li>
+<li>Migrated to OWL API 2 as the default Ontology implementation (onto)</li>
+<li>Lifted OWL API 2 as <tt>HeavyLoadedOntology</tt> (onto)</li>
+<li>Added computation of MAP (Mean Average Precision)
+  in <tt>PRGraphEvaluator</tt> (impl).</li>
 <li>Added pretty-printing of names in server (server)</li>
+<li>Added initialisation through initial alignment
+  in <tt>MatrixMeasure</tt> (impl)</li>
+<li>Suppressed of the <tt>OWLAPICell</tt> and <tt>OWLAPIAlignment</tt>
+  (deprecated since version 3.3) (impl)</li>
 <li>Reorganised the lib directory hierarchically (build)</li>
-<li>Corrected a bug when the server is launched without -S (server)</li>
+<li>Corrected a bug when the server is launched without -S
+  (server)</li>
+<li>Corrected a bug in retrieving alignments from ontologies when the
+  two ontologies are the same (server)</li>
+<li>Corrected a bug when <tt>StringDistAignment<tt> fail to raise
+      exception when bad method given (impl)</tt>
 <!--li>Suppressed the capability to export alignments in WSML (impl/omwg)</li-->
 </ul>
 </p>
diff --git a/html/tutorial2/MyApp.class b/html/tutorial2/MyApp.class
new file mode 100644
index 0000000000000000000000000000000000000000..bfaa81a3472255bafa857ecde20222d0a3893ba3
GIT binary patch
literal 9527
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

literal 0
HcmV?d00001

diff --git a/html/tutorial2/MyApp.java b/html/tutorial2/MyApp.java
index f1ddb55b..78762b37 100644
--- a/html/tutorial2/MyApp.java
+++ b/html/tutorial2/MyApp.java
@@ -43,6 +43,7 @@ import fr.inrialpes.exmo.align.parser.AlignmentParser;
 // Jena
 import com.hp.hpl.jena.rdf.model.ModelFactory;
 import com.hp.hpl.jena.rdf.model.Model;
+import com.hp.hpl.jena.ontology.OntModelSpec;
 import com.hp.hpl.jena.query.QueryFactory;
 import com.hp.hpl.jena.query.Query;
 import com.hp.hpl.jena.query.ResultSet;
@@ -50,7 +51,14 @@ import com.hp.hpl.jena.query.ResultSetFormatter;
 import com.hp.hpl.jena.query.QueryExecution;
 import com.hp.hpl.jena.query.QueryExecutionFactory;
 
-// Pellet
+// Pellet and OWL API
+import org.mindswap.pellet.owlapi.Reasoner;
+import org.semanticweb.owl.model.OWLOntologyManager;
+import org.semanticweb.owl.model.OWLOntology;
+import org.semanticweb.owl.model.OWLOntologyCreationException;
+import org.semanticweb.owl.model.OWLClass;
+import org.semanticweb.owl.model.OWLAxiom;
+import org.semanticweb.owl.apibinding.OWLManager;
 
 // IDDL
 import fr.inrialpes.exmo.iddl.IDDLReasoner;
@@ -78,6 +86,7 @@ import javax.xml.xpath.XPathExpressionException;
 import javax.xml.xpath.XPathConstants;
 
 // Java standard classes
+import java.util.Set;
 import java.io.PrintWriter;
 import java.io.StringWriter;
 import java.io.BufferedWriter;
@@ -101,7 +110,7 @@ import java.net.URISyntaxException;
 /**
  * MyApp
  *
- * Takes two files as arguments and align them.
+ * Reconcile two ontologies in various ways
  */
 
 public class MyApp {
@@ -117,9 +126,12 @@ public class MyApp {
 	Alignment al = null;
 	URI uri1 = null;
 	URI uri2 = null;
-	//	String u1 = "http://alignapi.gforge.inria.fr/tutorial/edu.mit.visus.bibtex.owl";
-	//	String u2 = "http://alignapi.gforge.inria.fr/tutorial/myOnto.owl";
+	//String u1 = "http://alignapi.gforge.inria.fr/tutorial2/ontology1.owl";
+	//String u2 = "http://alignapi.gforge.inria.fr/tutorial2/ontology2.owl";
+	String u1 = "file:ontology1.owl";
+	String u2 = "file:ontology2.owl";
 	String method = "fr.inrialpes.exmo.align.impl.method.StringDistAlignment";
+	String tempOntoFileName = "/tmp/myresult.owl";
 	Parameters params = new BasicParameters();
 	try {
 	    uri1 = new URI( u1 );
@@ -127,77 +139,89 @@ public class MyApp {
 	} catch (URISyntaxException use) { use.printStackTrace(); }
 
 	// ***** First exercise: matching *****
-	// Try to find an alignment between two ontologies from the server
+	// (Sol1) Try to find an alignment between two ontologies from the server
+	// ask for it
 	String found = getFromURLString( RESTServ+"find?onto1="+u1+"&onto2="+u2, false );
+	// retrieve it
 	// If there exists alignments, ask for the first one
 	NodeList alset = extractFromResult( found, "//findResponse/alignmentList/alid[1]/text()", false );
 
-	// Alternative: match the ontologies from the server
-	if ( alset.getLength() == -1 ) {
+	// (Sol3) Match the ontologies on the server
+	if ( alset.getLength() == 0 ) {
+	    // call for matching
 	    // * tested (must add force = true)
 	    //String match = getFromURLString( RESTServ+"match?onto1="+u1+"&onto2="+u2+"&method="+method+"&pretty="+myId+"&action=Match", true );
 	    // This returns a URI
 	}
 
-	// Ask it
-	String alid = alset.item(0).getNodeValue();
-	found = getFromURLString( RESTServ+"retrieve?method=fr.inrialpes.exmo.align.impl.renderer.RDFRendererVisitor&id="+alid, false );
-	alset = extractFromResult( found, "//retrieveResponse/result/*[1]",true );
+	if ( alset.getLength() > 0 ) {
+	    // Ask it
+	    String alid = alset.item(0).getNodeValue();
+	    found = getFromURLString( RESTServ+"retrieve?method=fr.inrialpes.exmo.align.impl.renderer.RDFRendererVisitor&id="+alid, false );
+	    alset = extractFromResult( found, "//retrieveResponse/result/*[1]",true );
 
-	// This code is heavy as hell
-	String xmlString = null;
-	try {
-	    // Set up the output transformer
-	    TransformerFactory transfac = TransformerFactory.newInstance();
-	    Transformer trans = transfac.newTransformer();
-	    trans.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes");
-	    trans.setOutputProperty(OutputKeys.INDENT, "yes");
-
-	    // Print the DOM node
-	    StringWriter sw = new StringWriter();
-	    DOMSource source = new DOMSource( alset.item(0) );
-	    trans.transform(source, new StreamResult(sw));
-	    xmlString = sw.toString();
-
-	    //System.out.println(xmlString);
-	} catch (TransformerException e) {
-	    e.printStackTrace();
-	}
+	    // This code is heavy as hell
+	    String xmlString = null;
+	    try {
+		// Set up the output transformer
+		TransformerFactory transfac = TransformerFactory.newInstance();
+		Transformer trans = transfac.newTransformer();
+		trans.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes");
+		trans.setOutputProperty(OutputKeys.INDENT, "yes");
+
+		// Print the DOM node
+		StringWriter sw = new StringWriter();
+		DOMSource source = new DOMSource( alset.item(0) );
+		trans.transform(source, new StreamResult(sw));
+		xmlString = sw.toString();
+		//System.out.println(xmlString);
+	    } catch (TransformerException e) {
+		e.printStackTrace();
+	    }
 
-	// Parse it (better passing to the SAXHandler)
-	try {
-	    AlignmentParser aparser = new AlignmentParser(0);
-	    Alignment alu = aparser.parseString( xmlString );
-	    al = ObjectAlignment.toObjectAlignment((URIAlignment)alu);
-	} catch (ParserConfigurationException pce) { 
-	    pce.printStackTrace();
-	} catch (SAXException saxe) { 
-	    saxe.printStackTrace(); 
-	} catch (IOException ioe) { 
-	    ioe.printStackTrace();
-	} catch (AlignmentException ae) { 
-	    ae.printStackTrace();
+	    // parse it as an alignment
+	    // (better passing to the SAXHandler)
+	    try {
+		AlignmentParser aparser = new AlignmentParser(0);
+		Alignment alu = aparser.parseString( xmlString );
+		al = ObjectAlignment.toObjectAlignment((URIAlignment)alu);
+	    } catch (ParserConfigurationException pce) { 
+		pce.printStackTrace();
+	    } catch (SAXException saxe) { 
+		saxe.printStackTrace(); 
+	    } catch (IOException ioe) { 
+		ioe.printStackTrace();
+	    } catch (AlignmentException ae) { 
+		ae.printStackTrace();
+	    }
 	}
 
+	// (Sol2) Match the ontologies with a local algorithm
 	if ( al == null ){ // Unfortunatelly no alignment was available
-	    // Match the ontologies with a local algorithm
 	    AlignmentProcess ap = new StringDistAlignment();
 	    try {
 		ap.init( uri1, uri2 );
 		params.setParameter("stringFunction","smoaDistance");
+		params.setParameter("noinst","1");
 		ap.align( (Alignment)null, params );
 		al = ap;
+		// Supplementary:
+		// upload the result on the server
+		// store it
 	    } catch (AlignmentException ae) { ae.printStackTrace(); }
 	}
 
-	// Alternative: find an intermediate ontology between which there is matching + Compose it!
+	// Alternative: find an intermediate ontology between which there are alignments
+	// find (basically a graph traversal operation)
+	// retrieve them
+	// parse them
+	// compose them
 
 	// ***** Second exercise: merging/transforming *****
 
-	// generate a merged ontology between the ontologies (OWLAxioms)
-	// @@@@@@@@@@@@@@@@TODO => Set in a file...
+	// (Sol1) generate a merged ontology between the ontologies (OWLAxioms)
 	PrintWriter writer = null;
-	File merged = new File( "/tmp/myresult.owl" );
+	File merged = new File( tempOntoFileName );
 	try {
 	    writer = new PrintWriter ( new FileWriter( merged, false ), true );
 	    AlignmentVisitor renderer = new OWLAxiomsRendererVisitor(writer);
@@ -215,31 +239,35 @@ public class MyApp {
 	    }
 	}
 
-	// Alternative: import the data from one ontology into the other
+	// (Sol2) import the data from one ontology into the other
 
-	// ***** Third exercise: querying *****
+	// ***** Third exercise: querying/reasoning *****
 
-	// Use SPARQL to answer queries
-	// @@@@@@@@@@@@@@@@TOTEST
+	// (Sol1) Use SPARQL to answer queries (at the data level)
 	InputStream in = null;
 	QueryExecution qe = null;
 	try {
-	    // Open the bloggers RDF graph from the filesystem
-	    in = new FileInputStream( merged );
-	    
-	    // Create an empty in-memory model and populate it from the graph
-	    Model model = ModelFactory.createDefaultModel();
-	    //Model model = ModelFactory.createMemModelMaker().createModel();
-	    model.read(in,null); // null base URI, since model URIs are absolute
+	        in = new FileInputStream( merged );
+		//in = new URL("http://alignapi.gforge.inria.fr/tutorial2/ontology1.owl").openStream();
+		//OntModelSpec.OWL_MEM_RDFS_INF or no arguments to see the difference...
+		Model model = ModelFactory.createOntologyModel(OntModelSpec.OWL_DL_MEM_RULE_INF,null);
+	    model.read(in,"file:///tmp/myresult.owl"); 
 	    in.close();
 	
 	    // Create a new query
+	    // Could also be selected by supervisor ???
 	    String queryString = 
 		"PREFIX foaf: <http://xmlns.com/foaf/0.1/> " +
-		"SELECT ?url " +
+		"PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> " +
+		"PREFIX aa: <http://alignapi.gforge.inria.fr/tutorial2/ontology1.owl#> " +
+		"SELECT ?fn ?ln ?t ?s " +
+		//"SELECT ?fn ?ln " +
 		"WHERE {" +
-		"      ?contributor foaf:name \"Jon Foobar\" . " +
-		"      ?contributor foaf:weblog ?url . " +
+                "      ?student rdf:type aa:Estudiante . " +
+		"      ?student aa:firstname  ?fn. " +
+		"      ?student aa:lastname  ?ln. " +
+		"OPTIONAL   {   ?student aa:affiliation ?t . } " +
+		"OPTIONAL   {   ?student aa:supervisor ?s . } " +
 		"      }";
 
 	    Query query = QueryFactory.create(queryString);
@@ -260,33 +288,49 @@ public class MyApp {
 	}
 
 	// Alternative: Use Pellet to answer queries
-	// @@@@@@@@@@@@@@@@TODO
-	
+
 	// ***** Fourth exercise: reasoning *****
-	PelletReasoner reasoner = new PelletReasoner();
 	OWLOntologyManager manager = OWLManager.createOWLOntologyManager();
-	// should not be a file
-	OWLOntology ontology = manager.loadOntology( merged );
-	OWLAxiom axiom = df.getOWLSubClassAxiom( headache, pain );
+	Reasoner reasoner = new Reasoner( manager );
+
+	// ontology that will be used
+	String file = "http://www.mindswap.org/2004/owl/mindswappers";
+
+	// Load the ontology 
+	try {
+	    OWLOntology ontology = manager.loadOntology( URI.create( "file://"+tempOntoFileName ) );
+	    reasoner.loadOntology( ontology );
+	} catch (OWLOntologyCreationException ooce) { ooce.printStackTrace(); }
+
+	// get the instances of a class
+	OWLClass person = manager.getOWLDataFactory().getOWLClass( URI.create( "http://alignapi.gforge.inria.fr/tutorial2/ontology1.owl#Estudiante" ) );   
+	Set instances  = reasoner.getIndividuals( person, false );
+	System.err.println("There are "+instances.size()+" students "+person.getURI());
+
+	/*
+	OWLClass person2 = manager.getOWLDataFactory().getOWLClass( URI.create( "http://alignapi.gforge.inria.fr/tutorial2/ontology2.owl#Person" ) );   
+	OWLAxiom axiom = manager.getOWLSubClassAxiom( person, person2 );
+	boolean isit = reasoner.isEntailed( axiom );
+	*/
 	/*
 	// test consistency of aligned ontologies
-	IDDLReasoner reasoner = new IDDLReasoner( Semantics.DL );
+	IDDLReasoner reasoner = new IDDLReasoner( Semantics.IDDL );
 	reasoner.addOntology( uri1 );
 	reasoner.addOntology( uri2 );
-	reasoner.addAlignment( align1 );
+	reasoner.addAlignment( al );
 	// What to do if not consistent?
 	if ( reasoner.isConsistent() ) {
 	    Alignment al2 = new URIAlignment();
-	    al2.init( uri1, uri2 );
+	    try {
+		al2.init( uri1, uri2 );
 	    // add the cell
 	    //al2.addAlignCell( c2.getObject1(), c2.getObject2(), c2.getRelation().getRelation(), 1. );
+	    } catch (AlignmentException ae) { ae.printStackTrace(); }
 	    reasoner.isEntailed( al2 );
          } else {
 	System.err.println( "your alignment is inconsistent");
-    }
+	}
 	*/
-	// 
-
     }
 
     public String getFromURLString( String u, boolean print ){
diff --git a/html/tutorial2/Skeleton.java b/html/tutorial2/Skeleton.java
new file mode 100644
index 00000000..415f0c95
--- /dev/null
+++ b/html/tutorial2/Skeleton.java
@@ -0,0 +1,220 @@
+/*
+ * $Id$
+ *
+ * Copyright (C) INRIA, 2009
+ *
+ * Modifications to the initial code base are copyright of their
+ * respective authors, or their employers as appropriate.  Authorship
+ * of the modifications may be determined from the ChangeLog placed at
+ * the end of this file.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public License
+ * as published by the Free Software Foundation; either version 2.1 of
+ * the License, or (at your option) any later version.
+ * 
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ * 
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+ * USA.
+ */
+
+// Alignment API classes
+import org.semanticweb.owl.align.Alignment;
+import org.semanticweb.owl.align.AlignmentException;
+import org.semanticweb.owl.align.AlignmentProcess;
+import org.semanticweb.owl.align.AlignmentVisitor;
+import org.semanticweb.owl.align.Parameters;
+
+// Alignment API implementation classes
+import fr.inrialpes.exmo.align.impl.BasicParameters;
+import fr.inrialpes.exmo.align.impl.ObjectAlignment;
+import fr.inrialpes.exmo.align.impl.URIAlignment;
+import fr.inrialpes.exmo.align.impl.BasicAlignment;
+import fr.inrialpes.exmo.align.impl.method.StringDistAlignment;
+import fr.inrialpes.exmo.align.impl.renderer.OWLAxiomsRendererVisitor;
+import fr.inrialpes.exmo.align.parser.AlignmentParser;
+
+// Jena
+import com.hp.hpl.jena.rdf.model.ModelFactory;
+import com.hp.hpl.jena.rdf.model.Model;
+import com.hp.hpl.jena.ontology.OntModelSpec;
+import com.hp.hpl.jena.query.QueryFactory;
+import com.hp.hpl.jena.query.Query;
+import com.hp.hpl.jena.query.ResultSet;
+import com.hp.hpl.jena.query.ResultSetFormatter;
+import com.hp.hpl.jena.query.QueryExecution;
+import com.hp.hpl.jena.query.QueryExecutionFactory;
+
+// Pellet
+
+// IDDL
+import fr.inrialpes.exmo.iddl.IDDLReasoner;
+import fr.inrialpes.exmo.iddl.conf.Semantics;
+
+// SAX standard classes
+import org.xml.sax.SAXException;
+
+// DOM Standard classes
+import org.w3c.dom.Document;
+import org.w3c.dom.NodeList;
+import javax.xml.transform.TransformerFactory;
+import javax.xml.transform.Transformer;
+import javax.xml.transform.TransformerException;
+import javax.xml.transform.OutputKeys;
+import javax.xml.transform.dom.DOMSource;
+import javax.xml.transform.stream.StreamResult;
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.ParserConfigurationException;
+import javax.xml.xpath.XPathFactory;
+import javax.xml.xpath.XPath;
+import javax.xml.xpath.XPathExpression;
+import javax.xml.xpath.XPathExpressionException;
+import javax.xml.xpath.XPathConstants;
+
+// Java standard classes
+import java.io.PrintWriter;
+import java.io.StringWriter;
+import java.io.BufferedWriter;
+import java.io.OutputStreamWriter;
+import java.io.BufferedReader;
+import java.io.InputStreamReader;
+import java.io.InputStream;
+import java.io.FileInputStream;
+import java.io.FileNotFoundException;
+import java.io.ByteArrayInputStream;
+import java.io.StringReader;
+import java.io.IOException;
+import java.io.UnsupportedEncodingException;
+import java.io.File;
+import java.io.FileWriter;
+import java.net.URI;
+import java.net.URL;
+import java.net.MalformedURLException;
+import java.net.URISyntaxException;
+
+/**
+ * MyApp
+ *
+ * Reconcile two ontologies in various ways
+ */
+
+public class MyApp {
+
+    String RESTServ = "http://aserv.inrialpes.fr/rest/";
+
+    public static void main( String[] args ) {
+	new MyApp().run( args );
+    }
+
+    public void run( String[] args ) {
+
+	// Setting variables
+	String myId = "JETest";
+	Alignment al = null;
+	URI uri1 = null;
+	URI uri2 = null;
+	//String u1 = "http://alignapi.gforge.inria.fr/tutorial2/ontology1.owl";
+	//String u2 = "http://alignapi.gforge.inria.fr/tutorial2/ontology2.owl";
+	String u1 = "file:ontology1.owl";
+	String u2 = "file:ontology2.owl";
+	String method = "fr.inrialpes.exmo.align.impl.method.StringDistAlignment";
+	Parameters params = new BasicParameters();
+	try {
+	    uri1 = new URI( u1 );
+	    uri2 = new URI( u2 );
+	} catch (URISyntaxException use) { use.printStackTrace(); exit(); }
+
+	try {
+
+	    // ***** First exercise: matching *****
+	    // (Sol1) Try to find an alignment between two ontologies from the server
+	    // ask for it
+	    // retrieve it
+	    // parse it as an alignment
+
+	    // (Sol2) Match the ontologies with a local algorithm
+	    // match
+
+	    // (Sol3) Match the ontologies on the server
+	    // call for matching
+	    // retrieve it
+	    // parse it as an alignment
+
+	    // Alternative: find an intermediate ontology between which there are alignments
+	    // find (basically a graph traversal operation)
+	    // retrieve them
+	    // parse them
+	    // compose them
+
+	    // Supplementary:
+	    // upload the result on the server
+	    // store it
+
+	    // ***** Second exercise: merging/transforming *****
+
+	    // (Sol1) generate a merged ontology between the ontologies (OWLAxioms)
+
+	    // (Sol2) import the data from one ontology into the other
+
+	    // ***** Third exercise: querying and reasoning *****
+
+	    // (Sol1) Use SPARQL to answer queries (at the data level)
+
+	    // (Sol2) Use Pellet to answer queries (at the ontology level)
+
+	} catch (Exception e) { e.printStackTrace(); exit();  }
+    }
+
+    public String getFromURLString( String u, boolean print ){
+	URL url = null;
+	String result = "<?xml version='1.0'?>";
+	try {
+	    url = new URL( u );
+	    BufferedReader in = new BufferedReader(
+    				new InputStreamReader(
+    				  url.openStream()));
+	    String inputLine;
+	    while ((inputLine = in.readLine()) != null) {
+		if (print) System.out.println(inputLine);
+		result += inputLine;
+	    }
+	    in.close();
+	}
+	catch ( MalformedURLException mue ) { mue.printStackTrace(); }
+	catch ( IOException mue ) { mue.printStackTrace(); }
+	return result;
+    }
+
+    public NodeList extractFromResult( String found, String path, boolean print ){
+	Document document = null;
+	NodeList nodes = null;
+	try { // Parse the returned string as XML
+	    DocumentBuilder parser =
+		DocumentBuilderFactory.newInstance().newDocumentBuilder();
+	    document = parser.parse(new ByteArrayInputStream( found.getBytes() ));
+	} catch ( ParserConfigurationException pce ) { pce.printStackTrace(); }
+	catch ( SAXException se ) { se.printStackTrace(); }
+	catch ( IOException ioe ) { ioe.printStackTrace(); }
+
+	try { // Apply the Xpath expression
+	    XPathFactory factory = XPathFactory.newInstance();
+	    XPath xpath = factory.newXPath();
+	    XPathExpression expr = xpath.compile( path );
+	    Object result = expr.evaluate( document, XPathConstants.NODESET );
+	    nodes = (NodeList)result;
+	    if ( print ) {
+		for ( int i = 0; i < nodes.getLength(); i++) {
+		    System.out.println(nodes.item(i).getNodeValue()); 
+		}
+	    }
+	} catch (XPathExpressionException xpee) { xpee.printStackTrace(); }
+	return nodes;
+    }
+}
-- 
GitLab