
org.obolibrary.macro.AbstractMacroExpansionVisitor Maven / Gradle / Ivy
package org.obolibrary.macro;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.obolibrary.obo2owl.Obo2OWLConstants.Obo2OWLVocabulary;
import org.semanticweb.owlapi.model.IRI;
import org.semanticweb.owlapi.model.OWLAnnotation;
import org.semanticweb.owlapi.model.OWLAnnotationAssertionAxiom;
import org.semanticweb.owlapi.model.OWLAnnotationProperty;
import org.semanticweb.owlapi.model.OWLAnnotationPropertyDomainAxiom;
import org.semanticweb.owlapi.model.OWLAnnotationPropertyRangeAxiom;
import org.semanticweb.owlapi.model.OWLAnnotationValue;
import org.semanticweb.owlapi.model.OWLAsymmetricObjectPropertyAxiom;
import org.semanticweb.owlapi.model.OWLAxiom;
import org.semanticweb.owlapi.model.OWLAxiomVisitorEx;
import org.semanticweb.owlapi.model.OWLClass;
import org.semanticweb.owlapi.model.OWLClassAssertionAxiom;
import org.semanticweb.owlapi.model.OWLClassExpression;
import org.semanticweb.owlapi.model.OWLClassExpressionVisitorEx;
import org.semanticweb.owlapi.model.OWLDataAllValuesFrom;
import org.semanticweb.owlapi.model.OWLDataComplementOf;
import org.semanticweb.owlapi.model.OWLDataExactCardinality;
import org.semanticweb.owlapi.model.OWLDataFactory;
import org.semanticweb.owlapi.model.OWLDataHasValue;
import org.semanticweb.owlapi.model.OWLDataIntersectionOf;
import org.semanticweb.owlapi.model.OWLDataMaxCardinality;
import org.semanticweb.owlapi.model.OWLDataMinCardinality;
import org.semanticweb.owlapi.model.OWLDataOneOf;
import org.semanticweb.owlapi.model.OWLDataPropertyAssertionAxiom;
import org.semanticweb.owlapi.model.OWLDataPropertyDomainAxiom;
import org.semanticweb.owlapi.model.OWLDataPropertyRangeAxiom;
import org.semanticweb.owlapi.model.OWLDataRange;
import org.semanticweb.owlapi.model.OWLDataSomeValuesFrom;
import org.semanticweb.owlapi.model.OWLDataUnionOf;
import org.semanticweb.owlapi.model.OWLDataVisitorEx;
import org.semanticweb.owlapi.model.OWLDatatype;
import org.semanticweb.owlapi.model.OWLDatatypeDefinitionAxiom;
import org.semanticweb.owlapi.model.OWLDatatypeRestriction;
import org.semanticweb.owlapi.model.OWLDeclarationAxiom;
import org.semanticweb.owlapi.model.OWLDifferentIndividualsAxiom;
import org.semanticweb.owlapi.model.OWLDisjointClassesAxiom;
import org.semanticweb.owlapi.model.OWLDisjointDataPropertiesAxiom;
import org.semanticweb.owlapi.model.OWLDisjointObjectPropertiesAxiom;
import org.semanticweb.owlapi.model.OWLDisjointUnionAxiom;
import org.semanticweb.owlapi.model.OWLEquivalentClassesAxiom;
import org.semanticweb.owlapi.model.OWLEquivalentDataPropertiesAxiom;
import org.semanticweb.owlapi.model.OWLEquivalentObjectPropertiesAxiom;
import org.semanticweb.owlapi.model.OWLFacetRestriction;
import org.semanticweb.owlapi.model.OWLFunctionalDataPropertyAxiom;
import org.semanticweb.owlapi.model.OWLFunctionalObjectPropertyAxiom;
import org.semanticweb.owlapi.model.OWLHasKeyAxiom;
import org.semanticweb.owlapi.model.OWLIndividual;
import org.semanticweb.owlapi.model.OWLInverseFunctionalObjectPropertyAxiom;
import org.semanticweb.owlapi.model.OWLInverseObjectPropertiesAxiom;
import org.semanticweb.owlapi.model.OWLIrreflexiveObjectPropertyAxiom;
import org.semanticweb.owlapi.model.OWLLiteral;
import org.semanticweb.owlapi.model.OWLNegativeDataPropertyAssertionAxiom;
import org.semanticweb.owlapi.model.OWLNegativeObjectPropertyAssertionAxiom;
import org.semanticweb.owlapi.model.OWLObjectAllValuesFrom;
import org.semanticweb.owlapi.model.OWLObjectComplementOf;
import org.semanticweb.owlapi.model.OWLObjectExactCardinality;
import org.semanticweb.owlapi.model.OWLObjectHasSelf;
import org.semanticweb.owlapi.model.OWLObjectHasValue;
import org.semanticweb.owlapi.model.OWLObjectIntersectionOf;
import org.semanticweb.owlapi.model.OWLObjectMaxCardinality;
import org.semanticweb.owlapi.model.OWLObjectMinCardinality;
import org.semanticweb.owlapi.model.OWLObjectOneOf;
import org.semanticweb.owlapi.model.OWLObjectProperty;
import org.semanticweb.owlapi.model.OWLObjectPropertyAssertionAxiom;
import org.semanticweb.owlapi.model.OWLObjectPropertyDomainAxiom;
import org.semanticweb.owlapi.model.OWLObjectPropertyExpression;
import org.semanticweb.owlapi.model.OWLObjectPropertyRangeAxiom;
import org.semanticweb.owlapi.model.OWLObjectSomeValuesFrom;
import org.semanticweb.owlapi.model.OWLObjectUnionOf;
import org.semanticweb.owlapi.model.OWLOntology;
import org.semanticweb.owlapi.model.OWLReflexiveObjectPropertyAxiom;
import org.semanticweb.owlapi.model.OWLSameIndividualAxiom;
import org.semanticweb.owlapi.model.OWLSubAnnotationPropertyOfAxiom;
import org.semanticweb.owlapi.model.OWLSubClassOfAxiom;
import org.semanticweb.owlapi.model.OWLSubDataPropertyOfAxiom;
import org.semanticweb.owlapi.model.OWLSubObjectPropertyOfAxiom;
import org.semanticweb.owlapi.model.OWLSubPropertyChainOfAxiom;
import org.semanticweb.owlapi.model.OWLSymmetricObjectPropertyAxiom;
import org.semanticweb.owlapi.model.OWLTransitiveObjectPropertyAxiom;
import org.semanticweb.owlapi.model.SWRLRule;
/**
* Empty abstract visitor for macro expansion. This class allows to minimize the
* code in the actual visitors, as they only need to overwrite the relevant
* methods.
*/
public abstract class AbstractMacroExpansionVisitor implements
OWLClassExpressionVisitorEx,
OWLDataVisitorEx, OWLAxiomVisitorEx {
final Logger log;
final OWLDataFactory dataFactory;
final Map expandAssertionToMap;
final Map expandExpressionMap;
protected AbstractMacroExpansionVisitor(OWLOntology inputOntology,
Logger log) {
super();
this.log = log;
dataFactory = inputOntology.getOWLOntologyManager().getOWLDataFactory();
expandExpressionMap = new HashMap();
expandAssertionToMap = new HashMap();
OWLAnnotationProperty expandExpressionAP = dataFactory
.getOWLAnnotationProperty(Obo2OWLVocabulary.IRI_IAO_0000424
.getIRI());
OWLAnnotationProperty expandAssertionAP = dataFactory
.getOWLAnnotationProperty(Obo2OWLVocabulary.IRI_IAO_0000425
.getIRI());
for (OWLObjectProperty p : inputOntology
.getObjectPropertiesInSignature()) {
for (OWLAnnotation a : p.getAnnotations(inputOntology,
expandExpressionAP)) {
OWLAnnotationValue v = a.getValue();
if (v instanceof OWLLiteral) {
String str = ((OWLLiteral) v).getLiteral();
if (log.isLoggable(Level.WARNING)) {
log.log(Level.WARNING, "mapping " + p + " to " + str);
}
expandExpressionMap.put(p.getIRI(), str);
}
}
}
for (OWLAnnotationProperty p : inputOntology
.getAnnotationPropertiesInSignature()) {
for (OWLAnnotation a : p.getAnnotations(inputOntology,
expandAssertionAP)) {
OWLAnnotationValue v = a.getValue();
if (v instanceof OWLLiteral) {
String str = ((OWLLiteral) v).getLiteral();
if (log.isLoggable(Level.WARNING)) {
log.log(Level.WARNING, "assertion mapping " + p
+ " to " + str);
}
expandAssertionToMap.put(p.getIRI(), str);
}
}
}
}
@Override
public OWLClassExpression visit(OWLObjectIntersectionOf desc) {
Set ops = new HashSet();
for (OWLClassExpression op : desc.getOperands()) {
ops.add(op.accept(this));
}
return dataFactory.getOWLObjectIntersectionOf(ops);
}
@Override
public OWLClassExpression visit(OWLObjectUnionOf desc) {
Set ops = new HashSet();
for (OWLClassExpression op : desc.getOperands()) {
ops.add(op.accept(this));
}
return dataFactory.getOWLObjectUnionOf(ops);
}
@Override
public OWLClassExpression visit(OWLObjectComplementOf desc) {
return dataFactory.getOWLObjectComplementOf(desc.getOperand().accept(
this));
}
@Override
public OWLClassExpression visit(OWLObjectSomeValuesFrom desc) {
OWLClassExpression filler = desc.getFiller();
OWLObjectPropertyExpression p = desc.getProperty();
OWLClassExpression result = null;
if (p instanceof OWLObjectProperty) {
result = expandOWLObjSomeVal(filler, p);
}
if (result == null) {
result = dataFactory.getOWLObjectSomeValuesFrom(desc.getProperty(),
filler.accept(this));
}
return result;
}
protected abstract OWLClassExpression expandOWLObjSomeVal(
OWLClassExpression filler, OWLObjectPropertyExpression p);
@Override
public OWLClassExpression visit(OWLObjectHasValue desc) {
OWLClassExpression result = null;
OWLIndividual filler = desc.getValue();
OWLObjectPropertyExpression p = desc.getProperty();
if (p instanceof OWLObjectProperty) {
result = expandOWLObjHasVal(desc, filler, p);
}
if (result == null) {
result = dataFactory.getOWLObjectHasValue(desc.getProperty(),
filler);
}
return result;
}
protected abstract OWLClassExpression expandOWLObjHasVal(
OWLObjectHasValue desc, OWLIndividual filler,
OWLObjectPropertyExpression p);
@Override
public OWLClassExpression visit(OWLObjectAllValuesFrom desc) {
return desc.getFiller().accept(this);
}
@Override
public OWLClassExpression visit(OWLObjectMinCardinality desc) {
OWLClassExpression filler = desc.getFiller().accept(this);
return dataFactory.getOWLObjectMinCardinality(desc.getCardinality(),
desc.getProperty(), filler);
}
@Override
public OWLClassExpression visit(OWLObjectExactCardinality desc) {
return desc.asIntersectionOfMinMax().accept(this);
}
@Override
public OWLClassExpression visit(OWLObjectMaxCardinality desc) {
OWLClassExpression filler = desc.getFiller().accept(this);
return dataFactory.getOWLObjectMaxCardinality(desc.getCardinality(),
desc.getProperty(), filler);
}
@Override
public OWLClassExpression visit(OWLDataSomeValuesFrom desc) {
OWLDataRange filler = desc.getFiller().accept(this);
return dataFactory.getOWLDataSomeValuesFrom(desc.getProperty(), filler);
}
@Override
public OWLClassExpression visit(OWLDataAllValuesFrom desc) {
OWLDataRange filler = desc.getFiller().accept(this);
return dataFactory.getOWLDataAllValuesFrom(desc.getProperty(), filler);
}
@Override
public OWLClassExpression visit(OWLDataHasValue desc) {
return desc.asSomeValuesFrom().accept(this);
}
@Override
public OWLClassExpression visit(OWLDataExactCardinality desc) {
return desc.asIntersectionOfMinMax().accept(this);
}
@Override
public OWLClassExpression visit(OWLDataMaxCardinality desc) {
int card = desc.getCardinality();
OWLDataRange filler = desc.getFiller().accept(this);
return dataFactory.getOWLDataMaxCardinality(card, desc.getProperty(),
filler);
}
@Override
public OWLClassExpression visit(OWLDataMinCardinality desc) {
int card = desc.getCardinality();
OWLDataRange filler = desc.getFiller().accept(this);
return dataFactory.getOWLDataMinCardinality(card, desc.getProperty(),
filler);
}
@Override
public OWLDataRange visit(OWLDataOneOf node) {
// Encode as a data union of and return result
Set oneOfs = new HashSet();
for (OWLLiteral lit : node.getValues()) {
oneOfs.add(dataFactory.getOWLDataOneOf(lit));
}
return dataFactory.getOWLDataUnionOf(oneOfs).accept(this);
}
@Override
public OWLDataRange visit(OWLDataIntersectionOf node) {
Set ops = new HashSet();
for (OWLDataRange op : node.getOperands()) {
ops.add(op.accept(this));
}
return dataFactory.getOWLDataIntersectionOf(ops);
}
@Override
public OWLDataRange visit(OWLDataUnionOf node) {
Set ops = new HashSet();
for (OWLDataRange op : node.getOperands()) {
ops.add(op.accept(this));
}
return dataFactory.getOWLDataUnionOf(ops);
}
// //////////////////////////////////////////////////////////////////////////////////////////////
//
// Conversion of non-class expressions to MacroExpansionVisitor
//
// /////////////////////////////////////////////////////////////////////////////////////////////
@Override
public OWLAxiom visit(OWLSubClassOfAxiom axiom) {
return dataFactory.getOWLSubClassOfAxiom(
axiom.getSubClass().accept(this),
axiom.getSuperClass().accept(this));
}
@Override
public OWLAxiom visit(OWLDisjointClassesAxiom axiom) {
Set ops = new HashSet();
for (OWLClassExpression op : axiom.getClassExpressions()) {
ops.add(op.accept(this));
}
return dataFactory.getOWLDisjointClassesAxiom(ops);
}
@Override
public OWLAxiom visit(OWLDataPropertyDomainAxiom axiom) {
return dataFactory.getOWLDataPropertyDomainAxiom(axiom.getProperty(),
axiom.getDomain().accept(this));
}
@Override
public OWLAxiom visit(OWLObjectPropertyDomainAxiom axiom) {
return dataFactory.getOWLObjectPropertyDomainAxiom(axiom.getProperty(),
axiom.getDomain().accept(this));
}
@Override
public OWLAxiom visit(OWLObjectPropertyRangeAxiom axiom) {
return dataFactory.getOWLObjectPropertyRangeAxiom(axiom.getProperty(),
axiom.getRange().accept(this));
}
@Override
public OWLAxiom visit(OWLDisjointUnionAxiom axiom) {
Set descs = new HashSet();
for (OWLClassExpression op : axiom.getClassExpressions()) {
descs.add(op.accept(this));
}
return dataFactory.getOWLDisjointUnionAxiom(axiom.getOWLClass(), descs);
}
@Override
public OWLAxiom visit(OWLDataPropertyRangeAxiom axiom) {
return dataFactory.getOWLDataPropertyRangeAxiom(axiom.getProperty(),
axiom.getRange().accept(this));
}
@Override
public OWLAxiom visit(OWLClassAssertionAxiom axiom) {
if (axiom.getClassExpression().isAnonymous()) {
return dataFactory.getOWLClassAssertionAxiom(axiom
.getClassExpression().accept(this), axiom.getIndividual());
}
return axiom;
}
@Override
public OWLAxiom visit(OWLEquivalentClassesAxiom axiom) {
Set ops = new HashSet();
for (OWLClassExpression op : axiom.getClassExpressions()) {
ops.add(op.accept(this));
}
return dataFactory.getOWLEquivalentClassesAxiom(ops);
}
@Override
public OWLClassExpression visit(OWLClass desc) {
return desc;
}
@Override
public OWLClassExpression visit(OWLObjectHasSelf desc) {
return desc;
}
@Override
public OWLClassExpression visit(OWLObjectOneOf desc) {
return desc;
}
@Override
public OWLDataRange visit(OWLDatatype node) {
return node;
}
@Override
public OWLDataRange visit(OWLDataComplementOf node) {
return node;
}
@Override
public OWLAxiom visit(OWLHasKeyAxiom axiom) {
return axiom;
}
@Override
public OWLDataRange visit(OWLDatatypeRestriction node) {
return node;
}
@Override
public OWLDataRange visit(OWLFacetRestriction node) {
return null;
}
@Override
public OWLAxiom visit(OWLNegativeObjectPropertyAssertionAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLAsymmetricObjectPropertyAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLReflexiveObjectPropertyAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLEquivalentObjectPropertiesAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLNegativeDataPropertyAssertionAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLDifferentIndividualsAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLDisjointDataPropertiesAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLDisjointObjectPropertiesAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLObjectPropertyAssertionAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLFunctionalObjectPropertyAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLSubObjectPropertyOfAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLDeclarationAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLAnnotationAssertionAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLSymmetricObjectPropertyAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLFunctionalDataPropertyAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLEquivalentDataPropertiesAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLDataPropertyAssertionAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLTransitiveObjectPropertyAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLIrreflexiveObjectPropertyAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLSubDataPropertyOfAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLInverseFunctionalObjectPropertyAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLSameIndividualAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLSubPropertyChainOfAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLInverseObjectPropertiesAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(SWRLRule rule) {
return rule;
}
@Override
public OWLAxiom visit(OWLAnnotationPropertyDomainAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLAnnotationPropertyRangeAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLSubAnnotationPropertyOfAxiom axiom) {
return axiom;
}
@Override
public OWLAxiom visit(OWLDatatypeDefinitionAxiom axiom) {
return axiom;
}
@Override
public OWLDataRange visit(OWLLiteral node) {
return null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy