-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathowl2_to_prolog_dlp.plt
99 lines (83 loc) · 3.64 KB
/
owl2_to_prolog_dlp.plt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/* -*- Mode: Prolog -*- */
:- use_module(owl2_to_prolog_dlp).
:- begin_tests(owl2_to_prolog_dlp,[setup(init_axioms),cleanup(retract_all_axioms)]).
init_axioms :-
Axioms=[
ontology(animals),
class(organism),
class(animal),
class(plant),
class(carnivore),
class(herbivore),
class(leg),
objectProperty(eatsChain),
objectProperty(eats),
objectProperty(eatenBy),
objectProperty(hasPart),
objectProperty(partOf),
subPropertyOf(eats,eatsChain),
transitiveProperty(eatsChain),
transitiveProperty(partOf),
transitiveProperty(hasPart),
inverseProperties(eats,eatenBy),
subClassOf(animal,organism),
equivalentClasses([sixLeggedAnimal,intersectionOf([animal,exactCardinality(hasPart,6,leg)])]),
equivalentClasses([carnivore,intersectionOf([animal,someValuesFrom(eats,animal)])]),
equivalentClasses([herbivore,
intersectionOf([animal,
allValuesFrom(eats,complementOf(animal))])]),
%equivalentClasses([auto_carnivore,hasSelf(eats)]),
disjointClasses([plant,animal]),
disjointClasses([herbivore,carnivore])
],
retract_all_axioms,
maplist(assert_axiom,Axioms).
test(all) :-
forall(axiom(Ax),
(
writeln(axiom=Ax),
owl_dlpterm(Ax,Pl),
writeln(prolog=Pl),
owl_write_prolog_code(Pl,[]))),
format('% end~n').
testmap(equivalentClasses([a1,a2]),
[(a1(X):-a2(X)),(a2(X):-a1(X))]).
testmap(equivalentClasses([a_and_b,intersectionOf([a,b])]),
( a_and_b(X):-(a(X),b(X)))).
testmap(equivalentClasses([a_or_b,unionOf([a,b])]),
( a_or_b(X):-(a(X);b(X)))).
testmap(equivalentClasses([only_has_part_a,allValuesFrom(has_part,a)]),
true).
testmap(equivalentClasses([only_has_part_a_and_b,
allValuesFrom(has_part,
intersectionOf([a,b]))]),
true).
testmap(equivalentClasses([ribonucleotide,
allValuesFrom(has_part,
intersectionOf(['phosphate unit',
'ribose ring',
intersectionOf([nucleobase,
someValuesFrom(covalently_bonded_to,
intersectionOf(['ribose ring',
someValuesFrom(covalently_bonded_to,
'phosphate unit')]))])]))]),
( true)).
test(x) :-
forall(testmap(Owl,PlMatch),
( format('owl: ~w :: expected: ~w~n',[Owl,PlMatch]),
owl_dlpterm(Owl,Pl),
format(' plterm: ~w~n',[Pl]),
owl_write_prolog_code(Pl,[]))).
:- end_tests(owl2_to_prolog_dlp).
/** <module> tests for OWL2 model
---+ Synopsis
Command line:
==
swipl
?- [owl2_to_prolog_dlp].
?- load_test_files([]).
?- run_tests.
==
---+ Details
This is a test module for the module owl2_from_rdf.pl
*/