uk.ac.manchester.cs.owl.explanation.ExplanationUtil Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of explanation-workbench Show documentation
Show all versions of explanation-workbench Show documentation
A plug-in that adds explanation facilities to the Protege Desktop ontology editor.
Written by Matthew Horridge during his PhD at the University of Manchester.
package uk.ac.manchester.cs.owl.explanation;
import org.protege.editor.owl.OWLEditorKit;
import org.protege.editor.core.ui.util.UIUtil;
import org.semanticweb.owl.explanation.api.Explanation;
import org.semanticweb.owlapi.model.*;
import org.semanticweb.owlapi.util.CollectionFactory;
import org.semanticweb.owlapi.apibinding.OWLManager;
import javax.swing.*;
import java.io.File;
import java.net.URI;
/*
* Copyright (C) 2008, University of Manchester
*
* 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 library 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 library 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 library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
/**
* Author: Matthew Horridge The University Of Manchester Information Management Group Date:
* 24-Oct-2008
*/
public class ExplanationUtil {
public static void saveExplanationAsOntology(OWLEditorKit editorKit, Explanation> explanation) throws
OWLOntologyCreationException,
OWLOntologyChangeException,
OWLOntologyStorageException {
File f = UIUtil.saveFile(
SwingUtilities.getAncestorOfClass(JFrame.class, editorKit.getWorkspace()),
"Save ontology as",
"Save justification as ontology",
CollectionFactory.createSet("owl", "txt", "rdf"),
"justification.owl");
if(f == null) {
return;
}
OWLOntologyManager man = OWLManager.createOWLOntologyManager();
OWLOntology ont = man.createOntology(explanation.getAxioms());
OWLDataFactory df = man.getOWLDataFactory();
IRI annotationIRI = IRI.create("http://owl.cs.manchester.ac.uk/explanation/annotations/inferredAxiom");
String entailmentRendering = editorKit.getOWLModelManager().getRendering((OWLAxiom) explanation.getEntailment());
OWLAnnotationProperty prop = df.getOWLAnnotationProperty(annotationIRI);
OWLAnnotation anno = df.getOWLAnnotation(prop, df.getOWLLiteral(entailmentRendering));
man.applyChange(new AddOntologyAnnotation(ont, anno));
man.saveOntology(ont, IRI.create(f));
}
}