From 894594b14cf27e149cf537c6e5b28feb6e7583cd Mon Sep 17 00:00:00 2001 From: Jennifer Vendetti Date: Thu, 2 Nov 2023 16:38:15 -0700 Subject: [PATCH] Add IRIMapper for SKOS Core Vocabulary Resolves #22 --- .../ncbo/owlapi/wrapper/OntologyParser.java | 12 + src/main/resources/skos.rdf | 468 ++++++++++++++++++ .../owlapi/wrapper/OntologyParserTest.java | 21 + .../skos_core/testSKOSCoreVocabImport.owl | 11 + 4 files changed, 512 insertions(+) create mode 100644 src/main/resources/skos.rdf create mode 100644 src/test/resources/repo/input/skos_core/testSKOSCoreVocabImport.owl diff --git a/src/main/java/org/stanford/ncbo/owlapi/wrapper/OntologyParser.java b/src/main/java/org/stanford/ncbo/owlapi/wrapper/OntologyParser.java index 1212416c..22433d1b 100644 --- a/src/main/java/org/stanford/ncbo/owlapi/wrapper/OntologyParser.java +++ b/src/main/java/org/stanford/ncbo/owlapi/wrapper/OntologyParser.java @@ -16,6 +16,7 @@ import org.semanticweb.owlapi.search.EntitySearcher; import org.semanticweb.owlapi.util.AutoIRIMapper; import org.semanticweb.owlapi.util.InferredSubClassAxiomGenerator; +import org.semanticweb.owlapi.util.SimpleIRIMapper; import org.semanticweb.owlapi.vocab.OWLRDFVocabulary; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -25,6 +26,7 @@ import java.io.BufferedReader; import java.io.File; import java.io.FileReader; +import java.net.URL; import java.util.*; public class OntologyParser { @@ -52,6 +54,16 @@ public OntologyParser(ParserInvocation parserInvocation) throws OntologyParserEx setLocalFileRepositaryMapping(this.sourceOwlManager, this.parserInvocation.getInputRepositoryFolder()); this.targetOwlManager = OWLManager.createOWLOntologyManager(); + + // Maintain a local copy of the SKOS Core Vocabulary to work around W3C rate limiting + IRI skosCoreIRI = IRI.create("http://www.w3.org/2004/02/skos/core"); + ClassLoader classLoader = OntologyParser.class.getClassLoader(); + URL url = classLoader.getResource("skos.rdf"); + log.info("Loaded SKOS Core Vocabulary from: {}", url.getPath()); + IRI skosCoreDocumentIRI = IRI.create(url); + SimpleIRIMapper mapper = new SimpleIRIMapper(skosCoreIRI, skosCoreDocumentIRI); + this.sourceOwlManager.getIRIMappers().add(mapper); + this.targetOwlManager.getIRIMappers().add(mapper); } diff --git a/src/main/resources/skos.rdf b/src/main/resources/skos.rdf new file mode 100644 index 00000000..1ddeb9a5 --- /dev/null +++ b/src/main/resources/skos.rdf @@ -0,0 +1,468 @@ + + + + + SKOS Vocabulary + Dave Beckett + Nikki Rogers + Participants in W3C's Semantic Web Deployment Working Group. + An RDF vocabulary for describing the basic structure and content of concept schemes such as thesauri, classification schemes, subject heading lists, taxonomies, 'folksonomies', other types of controlled vocabulary, and also concept schemes embedded in glossaries and terminologies. + Alistair Miles + Sean Bechhofer + + + + Concept + + An idea or notion; a unit of thought. + + + + + Concept Scheme + + A set of concepts, optionally including statements about semantic relationships between those concepts. + A concept scheme may be defined to include concepts from different sources. + Thesauri, classification schemes, subject heading lists, taxonomies, 'folksonomies', and other types of controlled vocabulary are all examples of concept schemes. Concept schemes are also embedded in glossaries and terminologies. + + + + + + + Collection + + A meaningful collection of concepts. + Labelled collections can be used where you would like a set of concepts to be displayed under a 'node label' in the hierarchy. + + + + + + + + + Ordered Collection + + An ordered collection of concepts, where both the grouping and the ordering are meaningful. + Ordered collections can be used where you would like a set of concepts to be displayed in a specific order, and optionally under a 'node label'. + + + + + + + is in scheme + + Relates a resource (for example a concept) to a concept scheme in which it is included. + A concept may be a member of more than one concept scheme. + + + + + + + + + has top concept + + Relates, by convention, a concept scheme to a concept which is topmost in the broader/narrower concept hierarchies for that scheme, providing an entry point to these hierarchies. + + + + + + + + + + + + + is top concept in scheme + + Relates a concept to the concept scheme that it is a top level concept of. + + + + + + + + + + + + + preferred label + + The preferred lexical label for a resource, in a given language. + + + + + + A resource has no more than one value of skos:prefLabel per language tag, and no more than one value of skos:prefLabel without language tag. + + The range of skos:prefLabel is the class of RDF plain literals. + + skos:prefLabel, skos:altLabel and skos:hiddenLabel are pairwise + disjoint properties. + + + + + alternative label + + An alternative lexical label for a resource. + Acronyms, abbreviations, spelling variants, and irregular plural/singular forms may be included among the alternative labels for a concept. Mis-spelled terms are normally included as hidden labels (see skos:hiddenLabel). + + + + + + The range of skos:altLabel is the class of RDF plain literals. + + skos:prefLabel, skos:altLabel and skos:hiddenLabel are pairwise disjoint properties. + + + + + hidden label + + A lexical label for a resource that should be hidden when generating visual displays of the resource, but should still be accessible to free text search operations. + + + + + + The range of skos:hiddenLabel is the class of RDF plain literals. + + skos:prefLabel, skos:altLabel and skos:hiddenLabel are pairwise disjoint properties. + + + + + notation + + A notation, also known as classification code, is a string of characters such as "T58.5" or "303.4833" used to uniquely identify a concept within the scope of a given concept scheme. + By convention, skos:notation is used with a typed literal in the object position of the triple. + + + + + + + note + + A general note, for any purpose. + This property may be used directly, or as a super-property for more specific note types. + + + + + + + change note + + A note about a modification to a concept. + + + + + + + + + definition + + A statement or formal explanation of the meaning of a concept. + + + + + + + + + editorial note + + A note for an editor, translator or maintainer of the vocabulary. + + + + + + + + + example + + An example of the use of a concept. + + + + + + + + + history note + + A note about the past state/use/meaning of a concept. + + + + + + + + + scope note + + A note that helps to clarify the meaning and/or the use of a concept. + + + + + + + + + is in semantic relation with + + Links a concept to a concept related by meaning. + This property should not be used directly, but as a super-property for all properties denoting a relationship of meaning between concepts. + + + + + + + + + + + has broader + + Relates a concept to a concept that is more general in meaning. + Broader concepts are typically rendered as parents in a concept hierarchy (tree). + By convention, skos:broader is only used to assert an immediate (i.e. direct) hierarchical link between two conceptual resources. + + + + + + + + + + + has narrower + + Relates a concept to a concept that is more specific in meaning. + By convention, skos:broader is only used to assert an immediate (i.e. direct) hierarchical link between two conceptual resources. + Narrower concepts are typically rendered as children in a concept hierarchy (tree). + + + + + + + + + + + has related + + Relates a concept to a concept with which there is an associative semantic relationship. + + + + + + + + skos:related is disjoint with skos:broaderTransitive + + + + + has broader transitive + + skos:broaderTransitive is a transitive superproperty of skos:broader. + By convention, skos:broaderTransitive is not used to make assertions. Rather, the properties can be used to draw inferences about the transitive closure of the hierarchical relation, which is useful e.g. when implementing a simple query expansion algorithm in a search application. + + + + + + + + + + + + + has narrower transitive + + skos:narrowerTransitive is a transitive superproperty of skos:narrower. + By convention, skos:narrowerTransitive is not used to make assertions. Rather, the properties can be used to draw inferences about the transitive closure of the hierarchical relation, which is useful e.g. when implementing a simple query expansion algorithm in a search application. + + + + + + + + + + + + + has member + + Relates a collection to one of its members. + + + + + + + + + + + + + + + + + + has member list + + Relates an ordered collection to the RDF list containing its members. + + + + + + + + + + For any resource, every item in the list given as the value of the + skos:memberList property is also a value of the skos:member property. + + + + + is in mapping relation with + + Relates two concepts coming, by convention, from different schemes, and that have comparable meanings + These concept mapping relations mirror semantic relations, and the data model defined below is similar (with the exception of skos:exactMatch) to the data model defined for semantic relations. A distinct vocabulary is provided for concept mapping relations, to provide a convenient way to differentiate links within a concept scheme from links between concept schemes. However, this pattern of usage is not a formal requirement of the SKOS data model, and relies on informal definitions of best practice. + + + + + + + + + has broader match + + skos:broadMatch is used to state a hierarchical mapping link between two conceptual resources in different concept schemes. + + + + + + + + + + + + + has narrower match + + skos:narrowMatch is used to state a hierarchical mapping link between two conceptual resources in different concept schemes. + + + + + + + + + + + + + has related match + + skos:relatedMatch is used to state an associative mapping link between two conceptual resources in different concept schemes. + + + + + + + + + + + + + has exact match + + skos:exactMatch is used to link two concepts, indicating a high degree of confidence that the concepts can be used interchangeably across a wide range of information retrieval applications. skos:exactMatch is a transitive property, and is a sub-property of skos:closeMatch. + + + + + + + + + + skos:exactMatch is disjoint with each of the properties skos:broadMatch and skos:relatedMatch. + + + + + has close match + + skos:closeMatch is used to link two concepts that are sufficiently similar that they can be used interchangeably in some information retrieval applications. In order to avoid the possibility of "compound errors" when combining mappings across more than two concept schemes, skos:closeMatch is not declared to be a transitive property. + + + + + + + + + + diff --git a/src/test/java/org/stanford/ncbo/owlapi/wrapper/OntologyParserTest.java b/src/test/java/org/stanford/ncbo/owlapi/wrapper/OntologyParserTest.java index 914d027e..12d4699f 100644 --- a/src/test/java/org/stanford/ncbo/owlapi/wrapper/OntologyParserTest.java +++ b/src/test/java/org/stanford/ncbo/owlapi/wrapper/OntologyParserTest.java @@ -4,6 +4,9 @@ import org.junit.Before; import org.junit.Test; import org.semanticweb.owlapi.model.IRI; +import org.semanticweb.owlapi.model.OWLClass; +import org.semanticweb.owlapi.model.OWLDataFactory; +import org.semanticweb.owlapi.model.OWLOntology; import java.io.File; @@ -142,7 +145,25 @@ public void parse_DetectsOntologyIRI_ReturnsTrue() throws Exception { IRI sourceIRI = parser.getParsedOntologies().stream().findFirst().get().getOntologyID().getOntologyIRI().orNull(); assertNotNull(targetIRI); assertEquals(sourceIRI, targetIRI); + } + + @Test + public void parse_ImportSKOSCoreVocab_ShouldLoad() throws Exception { + ParserInvocation pi = new ParserInvocation( + "./src/test/resources/repo/input/skos_core", + "./src/test/resources/repo/output/skos_core", + "testSKOSCoreVocabImport.owl", + true); + OntologyParser parser = new OntologyParser(pi); + parser.parse(); + + OWLOntology ontology = parser.getTargetOwlOntology(); + assertNotNull(ontology); + IRI skosConceptIRI = IRI.create("http://www.w3.org/2004/02/skos/core#Concept"); + OWLDataFactory factory = ontology.getOWLOntologyManager().getOWLDataFactory(); + OWLClass skosConceptClass = factory.getOWLClass(skosConceptIRI); + assertNotNull(skosConceptClass); } @After diff --git a/src/test/resources/repo/input/skos_core/testSKOSCoreVocabImport.owl b/src/test/resources/repo/input/skos_core/testSKOSCoreVocabImport.owl new file mode 100644 index 00000000..119e0aa8 --- /dev/null +++ b/src/test/resources/repo/input/skos_core/testSKOSCoreVocabImport.owl @@ -0,0 +1,11 @@ + + + + + + + \ No newline at end of file