eyeling 1.12.9 → 1.12.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,107 +1,3 @@
1
1
  @prefix : <https://eyereasoner.github.io/eye/reasoning#> .
2
2
 
3
- (7 4 2) :needTak true .
4
- (3 2 8) :needTak true .
5
- (1 8 4) :needTak true .
6
- (1 8 4) :tak 4 .
7
- (6 4 2) :needTak true .
8
- (3 2 7) :needTak true .
9
- (1 7 4) :needTak true .
10
- (2 2 8) :needTak true .
11
- (1 8 3) :needTak true .
12
- (7 3 2) :needTak true .
13
- (1 7 4) :tak 4 .
14
- (2 2 8) :tak 8 .
15
- (1 8 3) :tak 3 .
16
- (5 4 2) :needTak true .
17
- (3 2 6) :needTak true .
18
- (1 6 4) :needTak true .
19
- (2 2 7) :needTak true .
20
- (1 7 3) :needTak true .
21
- (6 3 2) :needTak true .
22
- (1 6 4) :tak 4 .
23
- (2 2 7) :tak 7 .
24
- (1 7 3) :tak 3 .
25
- (4 4 2) :needTak true .
26
- (3 2 5) :needTak true .
27
- (1 5 4) :needTak true .
28
- (2 2 6) :needTak true .
29
- (1 6 3) :needTak true .
30
- (5 3 2) :needTak true .
31
- (4 4 2) :tak 2 .
32
- (1 5 4) :tak 4 .
33
- (2 2 6) :tak 6 .
34
- (1 6 3) :tak 3 .
35
- (2 2 5) :needTak true .
36
- (1 5 3) :needTak true .
37
- (4 3 2) :needTak true .
38
- (2 2 5) :tak 5 .
39
- (1 5 3) :tak 3 .
40
- (3 3 2) :needTak true .
41
- (2 2 4) :needTak true .
42
- (1 4 3) :needTak true .
43
- (3 3 2) :tak 2 .
44
- (2 2 4) :tak 4 .
45
- (1 4 3) :tak 3 .
46
- (2 4 3) :needTak true .
47
- (2 4 3) :tak 3 .
48
- (4 3 2) :tak 3 .
49
- (5 3 3) :needTak true .
50
- (3 5 3) :needTak true .
51
- (4 3 3) :needTak true .
52
- (2 3 5) :needTak true .
53
- (2 5 3) :needTak true .
54
- (3 5 3) :tak 3 .
55
- (2 3 5) :tak 5 .
56
- (2 5 3) :tak 3 .
57
- (5 3 2) :tak 3 .
58
- (3 3 3) :needTak true .
59
- (2 3 4) :needTak true .
60
- (3 3 3) :tak 3 .
61
- (2 3 4) :tak 4 .
62
- (6 3 3) :needTak true .
63
- (3 6 3) :needTak true .
64
- (3 4 3) :needTak true .
65
- (2 3 6) :needTak true .
66
- (2 6 3) :needTak true .
67
- (3 6 3) :tak 3 .
68
- (3 4 3) :tak 3 .
69
- (2 3 6) :tak 6 .
70
- (2 6 3) :tak 3 .
71
- (6 3 2) :tak 3 .
72
- (4 3 3) :tak 3 .
73
- (7 3 3) :needTak true .
74
- (3 7 3) :needTak true .
75
- (5 3 3) :tak 3 .
76
- (2 3 7) :needTak true .
77
- (2 7 3) :needTak true .
78
- (3 7 3) :tak 3 .
79
- (2 3 7) :tak 7 .
80
- (2 7 3) :tak 3 .
81
- (7 3 2) :tak 3 .
82
- (3 2 5) :tak 3 .
83
- (6 3 3) :tak 3 .
84
- (8 3 3) :needTak true .
85
- (5 4 2) :tak 4 .
86
- (3 2 6) :tak 3 .
87
- (7 3 3) :tak 3 .
88
- (2 3 8) :needTak true .
89
- (2 8 3) :needTak true .
90
- (2 3 8) :tak 8 .
91
- (2 8 3) :tak 3 .
92
- (4 3 4) :needTak true .
93
- (3 8 3) :needTak true .
94
- (3 2 7) :tak 3 .
95
- (3 3 4) :needTak true .
96
- (2 4 4) :needTak true .
97
- (3 8 3) :tak 3 .
98
- (3 3 4) :tak 4 .
99
- (2 4 4) :tak 4 .
100
- (4 4 3) :needTak true .
101
- (8 3 3) :tak 3 .
102
- (4 4 3) :tak 3 .
103
- (3 2 8) :tak 3 .
104
- (4 3 4) :tak 3 .
105
- (6 4 2) :tak 3 .
106
- (7 4 2) :tak 4 .
107
- (8 4 2) :tak 3 .
3
+ (8 4 2) :takeuchi 3 .
@@ -10,73 +10,20 @@
10
10
  @prefix math: <http://www.w3.org/2000/10/swap/math#>.
11
11
  @prefix : <https://eyereasoner.github.io/eye/reasoning#>.
12
12
 
13
- # Forward/tabling style: compute only what’s reachable from :needTak.
14
-
15
- # Seed: only the call we want
16
- (8 4 2) :needTak true .
17
-
18
- # If a call is needed and X>Y, mark the three direct subcalls as needed
19
- {
20
- (?X ?Y ?Z) :needTak true.
21
- ?X math:greaterThan ?Y.
22
- (?X 1) math:difference ?X1.
23
- (?Y 1) math:difference ?Y1.
24
- (?Z 1) math:difference ?Z1.
25
- }
26
- =>
27
- {
28
- (?X1 ?Y ?Z) :needTak true.
29
- (?Y1 ?Z ?X) :needTak true.
30
- (?Z1 ?X ?Y) :needTak true.
31
- }.
32
-
33
- # Base case: if X<=Y then result is Z
34
- {
35
- (?X ?Y ?Z) :needTak true.
36
- ?X math:notGreaterThan ?Y.
37
- }
38
- =>
39
- {
40
- (?X ?Y ?Z) :tak ?Z.
13
+ {(?X ?Y ?Z) :tak ?Z} <= {
14
+ ?X math:notGreaterThan ?Y.
41
15
  }.
42
16
 
43
- # Once the three direct subcalls have results, we also need the “final call” tak(A1,A2,A3)
44
- {
45
- (?X ?Y ?Z) :needTak true.
46
- ?X math:greaterThan ?Y.
47
-
48
- (?X 1) math:difference ?X1.
49
- (?X1 ?Y ?Z) :tak ?A1.
50
-
51
- (?Y 1) math:difference ?Y1.
52
- (?Y1 ?Z ?X) :tak ?A2.
53
-
54
- (?Z 1) math:difference ?Z1.
55
- (?Z1 ?X ?Y) :tak ?A3.
56
- }
57
- =>
58
- {
59
- (?A1 ?A2 ?A3) :needTak true.
60
- }.
61
-
62
- # Recursive case: if everything is known, tak(X,Y,Z) is tak(A1,A2,A3)
63
- {
64
- (?X ?Y ?Z) :needTak true.
65
- ?X math:greaterThan ?Y.
66
-
67
- (?X 1) math:difference ?X1.
68
- (?X1 ?Y ?Z) :tak ?A1.
69
-
70
- (?Y 1) math:difference ?Y1.
71
- (?Y1 ?Z ?X) :tak ?A2.
72
-
73
- (?Z 1) math:difference ?Z1.
74
- (?Z1 ?X ?Y) :tak ?A3.
75
-
76
- (?A1 ?A2 ?A3) :tak ?A.
77
- }
78
- =>
79
- {
80
- (?X ?Y ?Z) :tak ?A.
17
+ {(?X ?Y ?Z) :tak ?A} <= {
18
+ ?X math:greaterThan ?Y. # guard makes this clause disjoint from the base case
19
+ (?X 1) math:difference ?X1.
20
+ (?X1 ?Y ?Z) :tak ?A1.
21
+ (?Y 1) math:difference ?Y1.
22
+ (?Y1 ?Z ?X) :tak ?A2.
23
+ (?Z 1) math:difference ?Z1.
24
+ (?Z1 ?X ?Y) :tak ?A3.
25
+ (?A1 ?A2 ?A3) :tak ?A.
81
26
  }.
82
27
 
28
+ # test
29
+ {(8 4 2) :tak ?A} => {(8 4 2) :takeuchi ?A}.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "eyeling",
3
- "version": "1.12.9",
3
+ "version": "1.12.11",
4
4
  "description": "A minimal Notation3 (N3) reasoner in JavaScript.",
5
5
  "main": "./index.js",
6
6
  "keywords": [
@@ -50,6 +50,6 @@
50
50
  "test": "npm run test:all",
51
51
  "posttest": "npm run test:package",
52
52
  "preversion": "npm test",
53
- "postversion": "git push --follow-tags"
53
+ "postversion": "git push origin HEAD --follow-tags"
54
54
  }
55
55
  }