我想使用 OWL API 或直接使用 Hermit 推理器之类的东西对本体进行推理。这很容易(代码如下所示)。但是,我想缓存/存储/保存这些结果,这样我就不必每次都重新运行推理器。这就是在 VM 中发生的情况。我第一次这样称呼:
Set<OWLClass> classes = reasoner.getSubClasses(parent, false).getFlattened();
大约需要 20 秒(在本例中)。第二次不需要时间就可以生成相同的结果,因为它们已被缓存。这太棒了。但是,如果我退回我的虚拟机,我必须重新运行推理器(我有一些相当长的查询)或将输出保存到数据库以立即显示它们。
Reasoner 不可序列化(来自 Hermit 或通过 OWL API),我似乎没有明显的方法来重新创建 Reasoner 并将任何以前的结果加载到其中。每次都必须重新计算。
序列化本体很简单,但我看不到任何将结果重新加载到推理器中的方法,以使您不必再次进行相同的调用。
有什么我想念的吗?耶拿会是更好的选择吗?
OWLOntologyManager owlOntologyManager = OWLManager.createOWLOntologyManager();
File file = new File("resource/RDFData/release", "NEMOv2.85_GAFLP1_diffwave_data.rdf");
IRI iri = IRI.create(file);
OWLDataFactory factory = owlOntologyManager.getOWLDataFactory();
OWLOntology owlOntology = owlOntologyManager.loadOntologyFromOntologyDocument(iri);
Reasoner reasoner = new Reasoner(owlOntology);
OWLClass parent = factory.getOWLClass(IRI.create(DataSet.NS + "#NEMO_0877000"));
Set<OWLClass> classes = reasoner.getSubClasses(parent, false).getFlattened();
FileOutputStream fos = null;
ObjectOutputStream out = null;
try {
fos = new FileOutputStream("reasoner.ser");
out = new ObjectOutputStream(fos);
out.writeObject(reasoner);
out.close();
} catch (IOException ex) {
ex.printStackTrace();
}