- From: Franconi Enrico <franconi@inf.unibz.it>
- Date: Mon, 20 Mar 2023 10:49:45 +0000
- To: Pierre-Antoine Champin <pierre-antoine@w3.org>
- CC: RDF-star WG <public-rdf-star-wg@w3.org>
- Message-ID: <CE670EC9-D40F-41BD-A126-75AAC07C4DF9@inf.unibz.it>
Hi Pierre-Antoine,
Your example emphasises exactly my point of never allowing a RDF-star graph to contain unstar: predicates. In my view, unstar: predicates are only useful to suggest an easy but sound and complete implementation of RDF-star entailments via RDF-1.1 simple entailment. Roughly speaking, an RDF-star triple T is RDF-star entailed by RDF-star graph G if and only if L(G) RDF-1.1 simply entails L(T). Notice that the game changes already for extensions such just adding owl:sameas, where the above is not true anymore.
Cheers
—e.
On 20 Mar 2023, at 10:56, Pierre-Antoine Champin <pierre-antoine@w3.org> wrote:
Hi Enrico,
during our conversation last Friday, I promised a discussion about the unstar mapping defined in the CG Report (https://www.w3.org/2021/12/rdf-star.html#dfn-unstar).
What you said (or at least what I understand you said) was: given an RDF-star graph G, G and unstar(G) have the same entailments. I disagree with this assertion (see 1 below), but I agree with a weaker version of this assertion (see 2 below).
1. I disagree with the assertion
Consider the following RDF-star graph G (serialized in Turtle, assuming the appropriate prefix declarations):
ex:a unstar:subject ex:b.
unstar(G) is the following:
ex:a unstar:subject_ ex:b. # notice the underscore at the end of the predicate
which entails G'
ex:a unstar:subject_ [].
unstar(G) entails G', however, G does not entail G'!
On the other hand, consider the RDF-star graph H:
ex:a unstar:subject [].
We can see that unstar(H) = G'
(that is, assuming that "[]" in both Turtle sources refer to the *same blank node*)
Since unstar(G) entails unstar(H), it follows that G entails H. However, unstar(G) does not entail H.
So G and unstar(G) both entail a graph that is not entailed by the other.
2. I agree with a weaker version of the assertion
Granted, my examples above are somewhat pathological, because I use the 'unstar:' vocabulary in the RDF-star graph. Since we want to avoid nasty interactions with this kind of pathological triples and the triples produced by the unstar mapping, we use a form of escaping, which is why, in my counterexample above, G and unstar(G) have different entailments.
If we restrict ourselves to "nice" RDF-star graphs, i.e. RDF-star graphs that do not use the 'unstar:' vocabulary, then we can assert :
for any "nice" RDF-star graph G containing no quoted triple, then G = unstar(G)
(and therefore G and unstar(G) have the same entailments!)
Note that, for any "nice" RDF-star graph that contains some quoted tripes, there are some entailments of unstar(G) that are not entailedby G. E.g., unstar(G) will always entail
[] unstar:subject [] .
while G will not (because, being nice, it contains no triple with predicate unstar:subject).
Note also that there are also some entailments of G that are not entailed by unstar(G). For example, G entails itself, while unstar(G) can not entail anything that contains quoted triples (being an RDF 1.1 graph).
best
<OpenPGP_0x9D1EDAEEEF98D438.asc>
Received on Monday, 20 March 2023 10:50:02 UTC