-
Notifications
You must be signed in to change notification settings - Fork 5
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Proposal: convert GAZ to an instance-based representation #20
Comments
Note @rctauber has made a start at modularization: https://github.com/EnvironmentOntology/gaz/tree/master/src/ontology/subsets e.g. https://github.com/EnvironmentOntology/gaz/blob/master/src/ontology/subsets/countries/Andorra.owl |
Interestingly, a lot of the entities in GAZ are both classes and instances, which gets quite weird. The 'located in' axioms are on the instances. There are some subclass axioms, I believe mostly under populated places. Anyway, I say +1 to moving entirely to instances. We could run SPARQL UPDATE to convert? I haven't thought much about that though. |
UPDATE I just remembered gaz.owl is already instance-based, using a transformation I made possibly a decade ago...
Also sometimes punning is induced:
Looks like OLS loads the obo OntoBee loads the OWL, however, it doesn't show instance-instance connections, so things look sparse: |
My comment crossed with Becky's who noticed the weirdness It's not a completely straightforward transform, since there are some class-like things in GAZ: However, it may be most straightforward to treat everything as instances, even if the name is class-like. It could be framed as a mereological sum. E.g. "Neotropical region" = population of all such regions, subClassOf => part-of |
The biogeographic regions are pertinent to some classes we've been incubating in ENVO. See EnvironmentOntology/envo#658 I'll create a new issue about that, but what's relevant here is that, in general, ENVO should provide the classes for GAZ instances. @rctauber feel free to request such classes if they're missing. |
For modularization: using GAZ.owl |
We have the class 'populated place, X' and then we have subclasses of that populated place. For example, 'populated place, Yemen' is both a class and an instance. It has the object property assertion 'located in' Yemen. All populated places are subclasses of 'populated place, X' AND instances with "located in" object property assertions (but they do not have class assertions). Here, I think it would make more sense to have these actual places be instances of 'populated place' that are located in X (using object property assertions). There would be no more 'populated place, X' classes. Governorates, municipalities, regions, rivers... all of these follow this pattern. In this representation, each country becomes only an instance of country, instead of both a class and an instance. That said, an instance-based representation is not easy to browse and edit using Protege. One solution is to switch completely to template-based development. Another question is - how will this be displayed on OLS? Can we somehow have an instance-based browser that follows the located_in hierarchy or will we need to release a version of GAZ that converts all the instances to classes? |
The protege folks (Matthew Horridge) might have a suggestion or be open to changes for improving instance data views, and navigation via 'located in'. Web protege 5.5 apparently has the facility for navigating via other object relations besides is-a. (Display relationships section in http://protegeproject.github.io/protege/views/class-hierarchy/ ). I can picture one extra toggle allowing instances to be listed under each class using object properties. Protege seems to handle long subclass lists no problem so a long list of instances might be easy to render too. |
Hello Chris,
What is the driving use case to change the GAZ to instances ?
Lynn
…Sent from my iPhone
On Apr 29, 2019, at 10:45 AM, Chris Mungall ***@***.***> wrote:
Currently GAZ is represented as all classes. E.g. Andorra is a class. Clearly this is not correct, but it's well-known that the reason for this choice is purely pragmatic - Michael would edit in Obo-Edit, which only handles classes.
I propose the following:
gaz.owl is converted to an instance-based representation
gaz.obo is converted to classes in the release process (instances are not well-supported in .obo format)
Any consumers of gaz.obo (which includes a number of relational database systems) should be unaffected, provided the conversion does not lose anything.
We would also need to check with all consumers of gaz.owl to make sure this does not break anything.
I think the OLS display would break somewhat, but we can just point OLS at gaz.obo
This will need considerable planning.
Will editing instances in Protege be as easy as editing classes? The current representation of GAZ is not just geared towards OE, it's an easy structure to browse (especially now Protege supports existential hierarchies directly)
We will need at least preliminary rdf:type / ClassAssertion axioms, I had a conversion at some point, will look this up...
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub, or mute the thread.
|
What do we gain with the switch to instances ?
…Sent from my iPhone
On Aug 1, 2019, at 11:07 AM, Damion Dooley ***@***.***> wrote:
The protege folks (Matthew Horridge) might have a suggestion or be open to changes for improving instance data views, and navigation via 'located in'. Web protege 5.5 apparently has the facility for navigating via other object relations besides is-a. (Display relationships section in http://protegeproject.github.io/protege/views/class-hierarchy/ ). I can picture one extra toggle allowing instances to be listed under each class using object properties. Protege seems to handle long subclass lists no problem so a long list of instances might be easy to render too.
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub, or mute the thread.
|
In my opinion, it makes more sense for these to be instances because they are specific countries, cities, etc. There's not multiple instances of the city of Paris that is located in France. That said, I'm sure there's an argument for ease-of-use with a class-based representation. Either way, each entity should be one or the other. The fact that most, if not all, of the entities in GAZ are both instances and classes is making it very difficult to run some ROBOT commands. @cmungall talked about changing everything to instances:
Any of the proper nouns (like Neotropical region) are talking about specific things. I like saying that the 'Central Andes bioregion' is part of the 'Neotropical region' and that would be very easy to convert from subclass axioms to 'part of' axioms. I don't think terms like 'biogeographic realm' would be instances, though. All of the current subclasses of 'biogeographic realm' would become instances of 'biogeographic realm' instead. |
It’s good we are discussing the options, implementations and downstream impacts.
To do much of this work, practically, we will need other funding sources.
Lynn
…Sent from my iPhone
On Aug 1, 2019, at 11:24 AM, Becky Jackson ***@***.***> wrote:
In my opinion, it makes more sense for these to be instances because they are specific countries. That said, I'm sure there's an argument for ease-of-use with a class-based representation. Either way, each entity should be one or the other. The fact that most, if not all, of the entities in GAZ are both instances and classes is making it very difficult to run some ROBOT commands.
@cmungall talked about changing everything to instances:
However, it may be most straightforward to treat everything as instances, even if the name is class-like. It could be framed as a mereological sum. E.g. "Neotropical region" = population of all such regions, subClassOf => part-of
Any of the proper nouns (like Neotropical region) are talking about specific things. I like saying that the 'Central Andes bioregion' is part of the 'Neotropical region' and that would be very easy to convert from subclass axioms to 'part of' axioms. I don't think terms like 'biogeographic realm' would be instances, though.
All of the current subclasses of 'biogeographic realm' would become instances of 'biogeographic realm' instead.
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub, or mute the thread.
|
@rctauber - that plan sounds good. Note that decomposition of pre-composed terms will have some impact on hierarchical browsing, regardless of questions of class vs instance.. Quick summary so far
|
I popped the protege class-instance navigation question on protegeproject/protege#912 . |
Great idea !!
…Sent from my iPhone
On Aug 2, 2019, at 9:05 AM, Damion Dooley ***@***.***> wrote:
I popped the protege class-instance navigation question on protegeproject/protege#912 .
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub, or mute the thread.
|
Really basic question: All geopolitical gaz entities are ultimately sites? Each site has a context and fiat boundary. (It may be moving only to the extent that redistricting and plate techtonics allow ;) ). |
I strongly recommend against modeling anything as immaterial entities. This has multiple negative consequences. Certainly the Atlantic Ocean, London, Mt Everest, etc are material. Given the existing part-of and overlaps axioms in GAZ already, OWL inconsistencies will immediately arise if we have a mix of immaterial and material entities. |
I've always struggled with concept of "site". Seems useful for things like "lung cavity". It also seemed appropriate for things whose boundaries were arbitrary (politically defined), rather than inherent. But I see wisdom of avoiding material and non-material stuff together. Perhaps simply, "a geopolitical reference to some region at any time t is a reference to a material entity as defined politically at that time." |
Currently GAZ is represented as all classes. E.g. Andorra is a class. Clearly this is not correct, but it's well-known that the reason for this choice is purely pragmatic - Michael would edit in Obo-Edit, which only handles classes.
I propose the following:
Any consumers of gaz.obo (which includes a number of relational database systems) should be unaffected, provided the conversion does not lose anything.
We would also need to check with all consumers of gaz.owl to make sure this does not break anything.
I think the OLS display would break somewhat, but we can just point OLS at gaz.obo
This will need considerable planning.
The text was updated successfully, but these errors were encountered: