我的目标是捕获OWLAPI分别声明和推断的公理,换句话说,区别是本体中已经存在的公理与不存在但由推理机推断的公理之间。

例如:

public void printHierarchy(OWLReasoner r, OWLClass clazz, int level, Set<OWLClass> visited) throws OWLException {
  //Only print satisfiable classes to skip Nothing

  if (!visited.contains(clazz) && reasoner.isSatisfiable(clazz)) {
    visited.add(clazz);
    for (int i = 0; i < level * 4; i++) {
      System.out.print(" ");
    }

    System.out.println(labelFor(clazz, r.getRootOntology()));

     // Find the children and recurse
    NodeSet<OWLClass> classes = r.getSubClasses(clazz, true);
    for (OWLClass child : classes.getFlattened()) {
      printHierarchy(r, child, level + 1);
    }
  }
}


函数getSubClasses返回OWL类的所有子类,而不区分是否在本体中提及。
我也可以执行手动检查,但这可能会非常昂贵。
因此,我的问题如下:是否有内置函数或替代方法来捕获与推论公理分开声明的内容?

最佳答案

如注释中所建议的那样,您可以创建推理结果所建议的公理并检查其是否存在于本体中。该过程中最昂贵的部分将是公理的创建,但是复杂度仍然是线性的-推理仍可能是最大的开销。

08-04 03:21