-
Notifications
You must be signed in to change notification settings - Fork 9
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
Challenge: Languagemap for multi-value reference #18
Comments
Hi @thomas-delva, is this issue not the same as #2? |
Hi @dachafra , the issues are related of course, but this one is more specific than the other: it assumes #2 is solved and language tags can be generated from data (with Hope this clears things up! |
Seems to me RML is missing some notion of locality. What we need for this example is:
Iterating twice is conceptually wrong:
|
@thomas-delva I'm trying to understand the example. Particularly the desired result, since the combinations of reference value and language value seem to be randomly combined. That is, it doesn't follow the structure of the document. Is this your intention? If so, I don't see a way to achieve this in a reusable way, since the combination logic can't be derived from the source document. If you want to get this result for this mapping you could do something like (untested):
I guess you could also solve this using a function valued LanguageMap and have a function contain the logic to return the language you want, based on the input. But, for that to work, we first need to be able to solve the more common challenge that is very close to what you describe here, or possibly, intended to. That is, how to get the following output, which does follow the structure of the source.
The general challenge here, is when it comes to combining multiple multi-valued expressions into a result of a term map. Language maps are one example, but another example is an The RML spec needs to provide clarity on how to handle these situations. This is issue #4. For the purpose of this dicussion, let's assume that a cartesian product approach would be the default way of handling these cases. In that case we need something else to solve the case described in this issue. I think we can look at xR2RML's nested term map ( |
Just a complement about xR2RML. xR2RML has introduced the idea of an xrr:languageReference property of an object map. About the multi-value question, xR2RML assumes that the evaluation of a reference (xrr:reference: rr:template, xrr:languageReference) can generate multiple values. Then, the term map generates RDF terms as the product of all the terms generated. So if you have this:
and if the reference returns 2 turns and the languageReference returns 2 terms, then the term map will yield 4 RDF terms. So this is basically "naturally" included in xR2RML, and that does not necessarily concern the xrr:nestedTermMap case. Franck. |
@frmichel but in this case, you don't want to combine all terms, but only those that are grouped together in the source.
So, is my understanding correct that you would use a |
Oh ok, sorry I had not looked carefully enough.
But I'm afraid that the "rdaw:P10086/*" with return the nodes values, and thus you will loose the language attribute. Such that "/@xml:lang" will not return anything. I may have underestimated the differences between XPath and JSONPath actually... |
So
should work in this case. |
Ok, thx for the hint @pmaria . So after all yes, the concept of nestedTermMap could fill that need (I edited my mitaken example above to have xrr:reference instead of rml:language). |
Great! I think it is an elegant solution, since you can tackle arbitrarily nested structures. |
Yes I agree, the rml:LanguageMap is more generic. Cool. |
@pmaria is this discussion already included (or there is a plan to include it ) in rml:LanguageMap? So we can close the issue |
From github issue: RMLio/rmlmapper-java#65
Description
In RML, if there is an object map that has a reference which creates multiple terms creates and that object map also has a language map, the mapper does not know (and cannot know?) which value of the reference to combine with which value of the language map.
It would be interesting to investigate a way to say in RML that the objectmap should go over the
<rdaw:P10086>
tags, and then extract from each a value and a language. (Whereas now, RML can only say to create multiple values from the<rdaw:P10086>
tags, and also, independently, to create multiple language tags from the<rdaw:P10086>
tags.)Input data (xml)
Desired output
The text was updated successfully, but these errors were encountered: