annotate service/reasoning/graphop.py @ 923:4ae49c6adecb

errors and logging in reasoning Ignore-this: 112b2985e0f5fd2a36abded52a5292b6 darcs-hash:20130922073139-312f9-4bb490330fe3e64b3ee87176e7eb2385255c4c72
author drewp <drewp@bigasterisk.com>
date Sun, 22 Sep 2013 00:31:39 -0700
parents 1815d2343a3f
children 0f2ac014d9ea
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
854
1815d2343a3f cleanup
drewp <drewp@bigasterisk.com>
parents: 853
diff changeset
1 import logging
1815d2343a3f cleanup
drewp <drewp@bigasterisk.com>
parents: 853
diff changeset
2 from rdflib import URIRef, ConjunctiveGraph
1815d2343a3f cleanup
drewp <drewp@bigasterisk.com>
parents: 853
diff changeset
3 log = logging.getLogger()
853
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
4
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
5 def graphWithoutMetadata(g, ignorePredicates=[]):
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
6 """
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
7 graph filter that removes any statements whose subjects are
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
8 contexts in the graph and also any statements with the given
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
9 predicates
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
10 """
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
11 ctxs = map(URIRef, set(g.contexts())) # weird they turned to strings
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
12
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
13 out = ConjunctiveGraph()
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
14 for stmt in g.quads((None, None, None)):
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
15 if stmt[0] not in ctxs and stmt[1] not in ignorePredicates:
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
16 out.addN([stmt])
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
17 return out
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
18
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
19 def graphEqual(a, b, ignorePredicates=[]):
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
20 """
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
21 compare graphs, omitting any metadata statements about contexts
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
22 (especially modification times) and also any statements using the
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
23 given predicates
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
24 """
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
25 stmtsA = set(graphWithoutMetadata(a, ignorePredicates))
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
26 stmtsB = set(graphWithoutMetadata(b, ignorePredicates))
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
27 if stmtsA == stmtsB:
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
28 return True
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
29
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
30 if log.getEffectiveLevel() <= logging.INFO:
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
31 lost = stmtsA - stmtsB
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
32 if lost:
923
4ae49c6adecb errors and logging in reasoning
drewp <drewp@bigasterisk.com>
parents: 854
diff changeset
33 log.info("graph A only:")
853
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
34 for s in lost:
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
35 log.info(" %s", s)
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
36 new = stmtsB - stmtsA
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
37 if new:
923
4ae49c6adecb errors and logging in reasoning
drewp <drewp@bigasterisk.com>
parents: 854
diff changeset
38 log.info("graph B only:")
853
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
39 for s in new:
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
40 log.info(" %s", s)
39857f82922e refactor graph ops
drewp <drewp@bigasterisk.com>
parents:
diff changeset
41 return False