當前位置: 首頁>>代碼示例>>Java>>正文


Java OWLReasoner類代碼示例

本文整理匯總了Java中org.semanticweb.owlapi.reasoner.OWLReasoner的典型用法代碼示例。如果您正苦於以下問題:Java OWLReasoner類的具體用法?Java OWLReasoner怎麽用?Java OWLReasoner使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


OWLReasoner類屬於org.semanticweb.owlapi.reasoner包,在下文中一共展示了OWLReasoner類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: highlightPropertyIfUnsatisfiable

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
private void highlightPropertyIfUnsatisfiable(final OWLEntity entity, final StyledDocument doc, final int tokenStartIndex, final int tokenLength) {
	try {
		getOWLModelManager().getReasonerPreferences().executeTask(OptionalInferenceTask.SHOW_OBJECT_PROPERTY_UNSATISFIABILITY,
                () -> {
                    OWLObjectProperty prop = (OWLObjectProperty) entity;
                    OWLReasoner reasoner = getOWLModelManager().getReasoner();
                    boolean consistent = reasoner.isConsistent();
                    if(!consistent || reasoner.getBottomObjectPropertyNode().contains(prop)) {
                        doc.setCharacterAttributes(tokenStartIndex, tokenLength, inconsistentClassStyle, true);
                    }
                });
	}
	catch (Exception e) {
		logger.warn("An error occurred whilst highlighting an unsatisfiable property: {}", e);
	}
}
 
開發者ID:lukasged,項目名稱:oops-plugin,代碼行數:17,代碼來源:OOPSTreeCellRenderer.java

示例2: getIndividuals

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
/**
 * @param superclass
 * @param o
 * @return
 */
private static Set<OWLIndividual> getIndividuals(String superclass,
		OWLOntology o) {
	
	OWLReasoner reasoner = PelletReasonerFactory.getInstance()
			.createReasoner(o);
	Set<OWLNamedIndividual> instances = reasoner.getInstances(
			OWL.Class(IRI.create(superclass)), false).getFlattened();
	
	// filter out all owl:sameAs instances...
	Set<OWLIndividual> ind = new TreeSet<>();
	for (OWLNamedIndividual i : instances) {
		ind.add(i);
	}
	logger.info("|I| = " + ind.size());
	logger.debug("I = " + ind);

	return ind;

}
 
開發者ID:AKSW,項目名稱:Resource2Vec,代碼行數:25,代碼來源:R2VManager.java

示例3: highlightPropertyIfUnsatisfiable

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
private void highlightPropertyIfUnsatisfiable(final OWLEntity entity, final StyledDocument doc,
		final int tokenStartIndex, final int tokenLength) {
	try {
		getOWLModelManager().getReasonerPreferences()
				.executeTask(OptionalInferenceTask.SHOW_OBJECT_PROPERTY_UNSATISFIABILITY, () -> {
					OWLObjectProperty prop = (OWLObjectProperty) entity;
					OWLReasoner reasoner = getOWLModelManager().getReasoner();
					boolean consistent = reasoner.isConsistent();
					if (!consistent || reasoner.getBottomObjectPropertyNode().contains(prop)) {
						doc.setCharacterAttributes(tokenStartIndex, tokenLength, inconsistentClassStyle, true);
					}
				});
	} catch (Exception e) {
		logger.warn("An error occurred whilst highlighting an unsatisfiable property: {}", e);
	}
}
 
開發者ID:md-k-sarker,項目名稱:OWLAx,代碼行數:17,代碼來源:OWLCellRenderer.java

示例4: QueryEngineImpl

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
/**
 * QueryEngineImpl constructor
 *
 * @param manager    An OWLOntologyManager instance of OWLAPI v3
 * @param reasoner   An OWLReasoner instance.
 * @param strictMode If strict mode is enabled the query engine will throw a QueryEngineException if data types withing the query are not correct (e.g. Class(URI_OF_AN_INDIVIDUAL))
 */
public QueryEngineImpl(OWLOntologyManager manager, OWLReasoner reasoner, boolean strictMode) {
    this.manager = manager;
    this.reasoner = reasoner;
    this.factory = manager.getOWLDataFactory();
    this.strictMode = strictMode;
    reasoner.getRootOntology()
            .getAxioms(AxiomType.ANNOTATION_ASSERTION, Imports.INCLUDED)
            .stream()
            .filter(ax -> ax.getSubject() instanceof IRI)
            .forEach(ax -> {
                unannotatedAxioms.add(ax.getAxiomWithoutAnnotations());
                annotationAssertionsBySubject.put((IRI) ax.getSubject(), ax);
            });
    Set<OWLClass> classesInSignature = reasoner.getRootOntology().getClassesInSignature(Imports.INCLUDED);
    classesInSignature.add(factory.getOWLThing());
    classesInSignature.add(factory.getOWLNothing());
    classes = ImmutableSet.copyOf(classesInSignature);
    classIris = ImmutableSet.copyOf(classes.stream().map(OWLClass::getIRI).collect(toSet()));

    annotationPropertyIris = ImmutableSet.copyOf(reasoner.getRootOntology().getAnnotationPropertiesInSignature(Imports.INCLUDED).stream().map(
            OWLNamedObject::getIRI).collect(toSet()));
}
 
開發者ID:protegeproject,項目名稱:sparql-dl-api,代碼行數:30,代碼來源:QueryEngineImpl.java

示例5: AbstractLegoTranslator

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
protected AbstractLegoTranslator(OWLOntology model, CurieHandler curieHandler, SimpleEcoMapper mapper) {
    super(model.getOWLOntologyManager().getOWLDataFactory());
    this.curieHandler = curieHandler;
    goCodes = new FindGoCodes(mapper, curieHandler);

    mf = OBOUpperVocabulary.GO_molecular_function.getOWLClass(f);
    cc = f.getOWLClass(IRI.create("http://purl.obolibrary.org/obo/GO_0005575"));
    bp = OBOUpperVocabulary.GO_biological_process.getOWLClass(f);

    bpSet = new HashSet<>();
    mfSet = new HashSet<>();
    ccSet = new HashSet<>();

    ElkReasonerFactory rf = new ElkReasonerFactory();
    OWLReasoner reasoner = rf.createReasoner(model);
    fillAspects(model, reasoner, curieHandler, bpSet, mfSet, ccSet, bp, mf, cc);
    reasoner.dispose();

    assignedByDefault = "GO_Noctua";
}
 
開發者ID:geneontology,項目名稱:minerva,代碼行數:21,代碼來源:AbstractLegoTranslator.java

示例6: getAllSubClasses

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
protected static Set<OWLClass> getAllSubClasses(OWLClass cls, OWLReasoner r, boolean reflexive, String idSpace, CurieHandler curieHandler) {
    Set<OWLClass> allSubClasses = r.getSubClasses(cls, false).getFlattened();
    Iterator<OWLClass> it = allSubClasses.iterator();
    while (it.hasNext()) {
        OWLClass current = it.next();
        if (current.isBuiltIn()) {
            it.remove();
            continue;
        }
        String id = curieHandler.getCuri(current);
        if (id.startsWith(idSpace) == false) {
            it.remove();
            continue;
        }
    }
    if (reflexive) {
        allSubClasses.add(cls);
    }
    return allSubClasses;
}
 
開發者ID:geneontology,項目名稱:minerva,代碼行數:21,代碼來源:AbstractLegoTranslator.java

示例7: create

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
public static InferenceProvider create(OWLReasoner r, OWLOntology ont) {
	Map<OWLNamedIndividual, Set<OWLClass>> inferredTypes = new HashMap<>();
	boolean isConsistent = r.isConsistent();
	if (isConsistent) {
		Set<OWLNamedIndividual> individuals = ont.getIndividualsInSignature();
		for (OWLNamedIndividual individual : individuals) {
			Set<OWLClass> inferred = new HashSet<>();
			Set<OWLClass> flattened = r.getTypes(individual, true).getFlattened();
			for (OWLClass cls : flattened) {
				if (cls.isBuiltIn() == false) {
					inferred.add(cls);
				}
			}
			inferredTypes.put(individual, inferred);
		}
	}
	return new MapInferenceProvider(isConsistent, inferredTypes);
}
 
開發者ID:geneontology,項目名稱:minerva,代碼行數:19,代碼來源:MapInferenceProvider.java

示例8: isEdgeEntailed

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
public boolean isEdgeEntailed(OWLEdge e, OWLOntology currentOntology, OWLReasoner reasoner) {
	OWLOntologyManager m = getManager();

	Set<OWLSubClassOfAxiom> scas = currentOntology.getSubClassAxiomsForSubClass(e.c);
	Set<OWLSubClassOfAxiom> rmAxioms = new HashSet<OWLSubClassOfAxiom>();
	for (OWLSubClassOfAxiom sca : scas) {
		if (sca.getSuperClass().equals(e.p)) {
			LOG.info("REMOVING: "+sca);
			rmAxioms.add(sca);
		}
	}
	boolean isEdgeAsserted = rmAxioms.size() > 0;
	if (isEdgeAsserted) {
		m.removeAxioms(currentOntology, rmAxioms);
		reasoner.flush();
	}
	boolean isEntailed;
	isEntailed = reasoner.getSuperClasses(e.c, false).containsEntity(e.p);
	if (isEdgeAsserted) {
		m.addAxioms(currentOntology, rmAxioms);
		reasoner.flush();
	}

	return isEntailed;
}
 
開發者ID:owlcollab,項目名稱:owltools,代碼行數:26,代碼來源:ProvenanceReasonerWrapper.java

示例9: printHierarchy

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
/**
 * Print the class hierarchy from this class down, assuming this class is at
 * the given level. Makes no attempt to deal sensibly with multiple
 * inheritance.
 */
private void printHierarchy(OWLReasoner reasoner,
                            OWLClass clazz, int level) throws OWLException {
    /*
     * Only print satisfiable classes -- otherwise we end up with bottom
     * everywhere
     */
    if (reasoner.isSatisfiable(clazz)) {
        for (int i = 0; i < level * INDENT; i++) {
            out.print(" ");
        }
        out.println(labelFor(clazz));
        /* Find the children and recurse */
        for (OWLClass child : reasoner.getSubClasses(clazz, true)
                .getFlattened()) {
            if (!child.equals(clazz)) {
                printHierarchy(reasoner, child, level + 1);
            }
        }
    }
}
 
開發者ID:newsreader,項目名稱:StreamEventCoreference,代碼行數:26,代碼來源:OwlReader2.java

示例10: getExplicitOWLDisjointnessAxioms

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
/**
 * OWLDisjointAxiom(A,B,C)
 * @param reasoner
 * @param ontology
 * @param cls
 * @return
 */
public static OWLClassNodeSet getExplicitOWLDisjointnessAxioms(OWLReasoner reasoner, OWLOntology ontology, OWLClass cls){
	
	OWLClassNodeSet nodeSet = new OWLClassNodeSet();
	
	for (OWLDisjointClassesAxiom ax : ontology.getDisjointClassesAxioms(cls)) {                	
           for (OWLClassExpression op : ax.getClassExpressions()) {
               if (!op.isAnonymous() && !op.equals(cls)) { //Op must be differnt to ce
                   nodeSet.addNode(reasoner.getEquivalentClasses(op));
               }
           }
       }
	
	return nodeSet;
	
}
 
開發者ID:ernestojimenezruiz,項目名稱:logmap-matcher,代碼行數:23,代碼來源:DisjointnessAxiomExtractor.java

示例11: getExplicitDLDisjointnessAxioms

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
/**
 * A ^ B -> bottom
 * @param reasoner
 * @param ontology
 * @param cls
 * @author Shuo Zhang
 * @return
 */
public static OWLClassNodeSet getExplicitDLDisjointnessAxioms(OWLReasoner reasoner, OWLOntology ontology, OWLClass cls){
	
	OWLClassNodeSet nodeSet = new OWLClassNodeSet();
	
	OWLClassExpression subExp;
   	Set<OWLClassExpression> set;
       for (OWLSubClassOfAxiom sax : ontology.getSubClassAxiomsForSuperClass(OWLManager.getOWLDataFactory().getOWLNothing())) {
       	subExp = sax.getSubClass();
       	if (subExp instanceof OWLObjectIntersectionOf) {
       		set = subExp.asConjunctSet();
       		if (set.contains(cls) && set.size() == 2) {
       			for (OWLClassExpression op : set) {
       				if (!op.equals(cls) && !op.isAnonymous()) {
       					nodeSet.addNode(reasoner.getEquivalentClasses(op));
       					break;
       				}
       			}
       		}
       	}
       } 
	
       return nodeSet;
       
}
 
開發者ID:ernestojimenezruiz,項目名稱:logmap-matcher,代碼行數:33,代碼來源:DisjointnessAxiomExtractor.java

示例12: removeRedundantSubClassAxioms

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
/**
 * Remove the redundant and marked as inferred super class assertions for
 * each class in the ontology signature. Uses the reasoner to infer the
 * direct super classes.
 * 
 * @param ontology
 * @param reasoner
 * @return map of class to set of redundant axioms
 */
public static Map<OWLClass, Set<RedundantAxiom>> removeRedundantSubClassAxioms(OWLOntology ontology, OWLReasoner reasoner) {
	Iterable<OWLClass> classes = ontology.getClassesInSignature();
	Map<OWLClass, Set<RedundantAxiom>> axioms = findRedundantSubClassAxioms(classes, ontology, reasoner);
	if (!axioms.isEmpty()) {
		Set<OWLSubClassOfAxiom> allAxioms = new THashSet<OWLSubClassOfAxiom>();
		for(OWLClass cls : axioms.keySet()) {
			for(RedundantAxiom redundantAxiom : axioms.get(cls)) {
				allAxioms.add(redundantAxiom.getAxiom());
			}
		}
		OWLOntologyManager manager = ontology.getOWLOntologyManager();
		manager.removeAxioms(ontology, allAxioms);
		LOG.info("Removed "+axioms.size()+" redundant axioms.");
	}
	return axioms;
	
}
 
開發者ID:owlcollab,項目名稱:owltools,代碼行數:27,代碼來源:RedundantInferences.java

示例13: changeReasoner

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
void changeReasoner() {
	ElkReasoner newReasoner = null;
	OWLReasoner reasoner = getEditorKit().getOWLModelManager()
			.getOWLReasonerManager().getCurrentReasoner();
	if (reasoner instanceof ElkReasoner) {
		newReasoner = (ElkReasoner) reasoner;
	}
	if (newReasoner == reasoner_) {
		return;
	}
	// else
	if (reasoner_ != null && reasoner_.equals(newReasoner)) {
		return;
	}
	// else
	reasoner_ = newReasoner;
	for (ChangeListener listener : listeners_) {
		listener.reasonerChanged();
	}
}
 
開發者ID:liveontologies,項目名稱:elk-reasoner,代碼行數:21,代碼來源:ElkProofService.java

示例14: findDescendants

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
protected Set<OWLClass> findDescendants(OWLReasoner r, String expr, Integer numExpected) throws TimeOutException, FreshEntitiesException, InconsistentOntologyException, ClassExpressionNotInProfileException, ReasonerInterruptedException, OWLParserException {
	System.out.println("Query: "+expr);
	OWLClassExpression qc = parseOMN(expr);
	Set<OWLClass> clzs = r.getSubClasses(qc, false).getFlattened();
	clzs.remove(r.getRootOntology().getOWLOntologyManager().getOWLDataFactory().getOWLNothing());
	if (!qc.isAnonymous())
		clzs.add((OWLClass) qc);
	System.out.println("NumD:"+clzs.size());
	for (OWLClass c : clzs) {
		System.out.println("  D:"+c);
	}
	if (numExpected != null) {
		assertEquals(numExpected.intValue(), clzs.size());
	}
	return clzs;
}
 
開發者ID:owlcollab,項目名稱:owltools,代碼行數:17,代碼來源:AbstractReasonerTest.java

示例15: main

import org.semanticweb.owlapi.reasoner.OWLReasoner; //導入依賴的package包/類
public static void main(String[] args) throws OWLOntologyCreationException {
    //register my built-in
    BuiltInRegistry.instance.registerBuiltIn("urn:makub:builtIn#thisYear", new GeneralFunctionBuiltIn(new ThisYear()));
    //initialize ontology and reasoner
    OWLOntologyManager manager = OWLManager.createOWLOntologyManager();
    OWLOntology ontology = manager.loadOntologyFromOntologyDocument(IRI.create(DOC_URL));
    OWLReasonerFactory reasonerFactory = PelletReasonerFactory.getInstance();
    OWLReasoner reasoner = reasonerFactory.createReasoner(ontology, new SimpleConfiguration());
    OWLDataFactory factory = manager.getOWLDataFactory();
    PrefixDocumentFormat pm = manager.getOntologyFormat(ontology).asPrefixOWLOntologyFormat();
    //use the rule with the built-in to infer data property values
    OWLNamedIndividual martin = factory.getOWLNamedIndividual(":Martin", pm);
    listAllDataPropertyValues(martin, ontology, reasoner);

    OWLNamedIndividual ivan = factory.getOWLNamedIndividual(":Ivan", pm);
    listAllDataPropertyValues(ivan, ontology, reasoner);
}
 
開發者ID:martin-kuba,項目名稱:owl2-swrl-tutorial,代碼行數:18,代碼來源:SWRLBuiltInsTutorial.java


注:本文中的org.semanticweb.owlapi.reasoner.OWLReasoner類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。