Difference between revisions of "SimpleGraph-Core"
(15 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
− | Basically SimpleGraph core has the idea of Vertex and Edges being able to carry "payloads". Some of the payload data will be replicated as properties to be | + | Basically {{Link|target=SimpleGraph}}-core has the idea of Vertex and Edges being able to carry "payloads". Some of the payload data will be replicated as properties to be |
able to search for the payload and do something with it but the main thing is to have some kind of pointer/key that a certain SimpleGraph Module will be able work with to | able to search for the payload and do something with it but the main thing is to have some kind of pointer/key that a certain SimpleGraph Module will be able work with to | ||
allow working with the API for the payload. | allow working with the API for the payload. | ||
+ | |||
+ | Going from a Vertex to a Payload (which is a JavaObject) is currently done with a property SimpleNode.SELF_LABEL | ||
+ | see https://github.com/BITPlan/com.bitplan.simplegraph/blob/master/simplegraph-core/src/main/java/com/bitplan/simplegraph/core/SimpleNode.java | ||
+ | <source lang='java'> | ||
+ | Object payLoad=v.property(SimpleNode.SELF_LABEL).value(); | ||
+ | </source> | ||
+ | In some cases it might be necessary to find a Vertex for a Payload. Currently we use a work-around by putting the Java hashCode of a payload as a property "java.hashCode" into the corresponding Edge or Vertex. This way we can simply lookup the Java Object with | ||
+ | <source lang='java'> | ||
+ | Vertex myVertex=g.V().has("java.hashCode",this.hashCode()) | ||
+ | </source> | ||
+ | |||
= Example = | = Example = | ||
− | Lets's assume we'd like to | + | Lets's assume we'd like to access some data about [https://en.wikipedia.org/wiki/List_of_gravitational_wave_observations Gravitational Wave observations]. |
− | A Source for general information on these events is WikiData where you can get a list of the events with a SPARQL query. | + | A Source for general information on these events is WikiData where you can get a list of the events with a [https://query.wikidata.org/#%23%20Find%20Gravitational%20wave%20events%0A%23%20Created%202018-10-16%20by%20Wolfgang%20Fahl%20BITPlan%20GmbH%0A%23%0A%23%20select%20the%20events%0ASELECT%20%3Fevent%20%3FcatalogCode%20%3Fdiscovery%20%3FeventLabel%20%3Fduration%20%3Flodurl%20%3Farticle%20%0AWHERE%20%0A%7B%0A%20%20%23%20any%20subject%0A%20%20%23%20which%20is%20an%20instance%20of%0A%20%20%23%20https%3A%2F%2Fwww.wikidata.org%2Fwiki%2FProperty%3AP31%0A%20%20%0A%20%20%23%20gravitational%20wave%20event%0A%20%20%23%20https%3A%2F%2Fwww.wikidata.org%2Fwiki%2FQ24748034%0A%20%20%3Fevent%20wdt%3AP31%20wd%3AQ24748034.%0A%20%20%0A%20%20%23%20and%20might%20hava%20catalog%20code%0A%20%20%23%20https%3A%2F%2Fwww.wikidata.org%2Fwiki%2FProperty%3AP528%0A%20%20%23%20catalog%20Code%0A%20%20OPTIONAL%20%7B%0A%20%20%20%20%3Fevent%20wdt%3AP528%20%3FcatalogCode%0A%20%20%7D%0A%20%20%0A%20%20%23%20and%20might%20have%20a%20time%20of%20discovery%0A%20%20%23%20https%3A%2F%2Fwww.wikidata.org%2Fwiki%2FProperty%3AP575%0A%20%20OPTIONAL%20%7B%0A%20%20%20%20%3Fevent%20wdt%3AP575%20%3Fdiscovery%0A%20%20%7D%20%20%20%0A%20%20%0A%20%20%23%20and%20might%20have%20a%20time%20duration%0A%20%20%23%20https%3A%2F%2Fwww.wikidata.org%2Fwiki%2FProperty%3AP2047%0A%20%20OPTIONAL%20%7B%0A%20%20%20%20%3Fevent%20wdt%3AP2047%20%3Fduration%0A%20%20%7D%20%20%20%0A%20%20%0A%20%20%23%20and%20might%20have%20a%20linked%20open%20data%20url%0A%20%20%23%20https%3A%2F%2Fwww.wikidata.org%2Fwiki%2FProperty%3AP973%0A%20%20OPTIONAL%20%7B%0A%20%20%20%20%3Fevent%20wdt%3AP973%20%3Flodurl%0A%20%20%7D%20%20%20%0A%20%20%0A%20%20%23%20show%20the%20Labels%20%28e.g.%20eventLabel%29%0A%20%20SERVICE%20wikibase%3Alabel%20%7B%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%23%20...%20include%20the%20labels%0A%20%20%20%20%20%20%20%20bd%3AserviceParam%20wikibase%3Alanguage%20%22%5BAUTO_LANGUAGE%5D%2Cen%22%0A%20%20%7D%0A%20%20%0A%20%20%23%20the%20event%20might%20have%20an%20english%20wikipedia%20article%0A%20%20OPTIONAL%20%7B%0A%20%20%20%20%20%20%3Farticle%20schema%3Aabout%20%3Fevent%20.%0A%20%20%20%20%20%20%3Farticle%20schema%3AinLanguage%20%22en%22%20.%0A%20%20%20%20%20%20FILTER%20%28SUBSTR%28str%28%3Farticle%29%2C%201%2C%2025%29%20%3D%20concat%28%22https%3A%2F%2Fen.wikipedia.org%2F%22%29%29%0A%20%20%7D%0A%7D%0Aorder%20by%20%3Fdiscovery%0A SPARQL query]. |
− | <graphviz> | + | <graphviz format='svg'> |
− | digraph | + | digraph example2 { |
− | WikiData -> GW150914 | + | GW150914 [ URL="[https://en.wikipedia.org/wiki/First_observation_of_gravitational_waves|Wikipedia Article on GW150914]" ] |
− | WikiData -> GW151226 | + | GW151226 [ URL="[https://en.wikipedia.org/wiki/GW151226|Wikipedia Article on GW151226]" ] |
+ | GW170817 [ URL="[https://en.wikipedia.org/wiki/GW170817|Wikipedia Article on GW170817]" ] | ||
+ | WikiData [ URL="[[SimpleGraph-WikiData]]" ] | ||
+ | WikiData -> GW150914 | ||
+ | WikiData -> GW151226 | ||
WikiData -> GW170817 | WikiData -> GW170817 | ||
} | } | ||
Line 14: | Line 29: | ||
Each event is represented as a Vertex. The main info is the event name e.g. "GW150914" with that name you can lookup more detail on the event e.g. You'll find wikipedia articles for it or the source of linked opendata from the Ligo Observatory: | Each event is represented as a Vertex. The main info is the event name e.g. "GW150914" with that name you can lookup more detail on the event e.g. You'll find wikipedia articles for it or the source of linked opendata from the Ligo Observatory: | ||
{{GW|150914}} | {{GW|150914}} | ||
+ | |||
+ | Now you might be interested in some details that are not available via WikiData. https://www.gw-openscience.org/events/GW150914/ for instance has link to the orginal HDF5 datasets | ||
+ | from the two detectors Hanford and Livingston: | ||
+ | * https://www.gw-openscience.org/GW150914data/H-H1_LOSC_4_V2-1126259446-32.hdf5 | ||
+ | * https://www.gw-openscience.org/GW150914data/L-L1_LOSC_4_V2-1126259446-32.hdf5 | ||
+ | |||
+ | To read the data you'd now have to download a HDFView software to find the starttime of the event as GPS Time 1126259446 UTC 2015-09-14T09:50:29. | ||
+ | |||
+ | Let's simplify this process by using three modules from the SimpleGraphProject | ||
+ | # {{Link|target=SimpleGraph-WikiData}} to get the general event data from WikiData with the link to Linked Open Data URL | ||
+ | # {{Link|target=SimpleGraph-HTML}} to extract the link to the original hdf5 files from the observatories | ||
+ | # {{Link|target=SimpleGraph-HDF5}} to get to the event details and the original measurement data | ||
+ | |||
+ | = Sources = | ||
+ | * https://github.com/BITPlan/com.bitplan.simplegraph/tree/master/simplegraph-core | ||
+ | |||
[[Category:SimpleGraph]][[Category:frontend]] | [[Category:SimpleGraph]][[Category:frontend]] |
Latest revision as of 10:13, 17 October 2018
Basically SimpleGraph-core has the idea of Vertex and Edges being able to carry "payloads". Some of the payload data will be replicated as properties to be able to search for the payload and do something with it but the main thing is to have some kind of pointer/key that a certain SimpleGraph Module will be able work with to allow working with the API for the payload.
Going from a Vertex to a Payload (which is a JavaObject) is currently done with a property SimpleNode.SELF_LABEL see https://github.com/BITPlan/com.bitplan.simplegraph/blob/master/simplegraph-core/src/main/java/com/bitplan/simplegraph/core/SimpleNode.java
Object payLoad=v.property(SimpleNode.SELF_LABEL).value();
In some cases it might be necessary to find a Vertex for a Payload. Currently we use a work-around by putting the Java hashCode of a payload as a property "java.hashCode" into the corresponding Edge or Vertex. This way we can simply lookup the Java Object with
Vertex myVertex=g.V().has("java.hashCode",this.hashCode())
Example
Lets's assume we'd like to access some data about Gravitational Wave observations. A Source for general information on these events is WikiData where you can get a list of the events with a SPARQL query.
Each event is represented as a Vertex. The main info is the event name e.g. "GW150914" with that name you can lookup more detail on the event e.g. You'll find wikipedia articles for it or the source of linked opendata from the Ligo Observatory:
GW150914
- https://en.wikipedia.org/wiki/GW150914
- https://de.wikipedia.org/wiki/GW150914
- https://www.gw-openscience.org/events/GW150914/
Now you might be interested in some details that are not available via WikiData. https://www.gw-openscience.org/events/GW150914/ for instance has link to the orginal HDF5 datasets
from the two detectors Hanford and Livingston:
- https://www.gw-openscience.org/GW150914data/H-H1_LOSC_4_V2-1126259446-32.hdf5
- https://www.gw-openscience.org/GW150914data/L-L1_LOSC_4_V2-1126259446-32.hdf5
To read the data you'd now have to download a HDFView software to find the starttime of the event as GPS Time 1126259446 UTC 2015-09-14T09:50:29.
Let's simplify this process by using three modules from the SimpleGraphProject
- SimpleGraph-WikiData to get the general event data from WikiData with the link to Linked Open Data URL
- SimpleGraph-HTML to extract the link to the original hdf5 files from the observatories
- SimpleGraph-HDF5 to get to the event details and the original measurement data