@cogitator-ai/neuro-symbolic 0.1.0

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.
Files changed (107) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +494 -0
  3. package/dist/constraints/dsl.d.ts +68 -0
  4. package/dist/constraints/dsl.d.ts.map +1 -0
  5. package/dist/constraints/dsl.js +419 -0
  6. package/dist/constraints/dsl.js.map +1 -0
  7. package/dist/constraints/index.d.ts +7 -0
  8. package/dist/constraints/index.d.ts.map +1 -0
  9. package/dist/constraints/index.js +18 -0
  10. package/dist/constraints/index.js.map +1 -0
  11. package/dist/constraints/prompts.d.ts +44 -0
  12. package/dist/constraints/prompts.d.ts.map +1 -0
  13. package/dist/constraints/prompts.js +175 -0
  14. package/dist/constraints/prompts.js.map +1 -0
  15. package/dist/constraints/simple-sat-solver.d.ts +21 -0
  16. package/dist/constraints/simple-sat-solver.d.ts.map +1 -0
  17. package/dist/constraints/simple-sat-solver.js +378 -0
  18. package/dist/constraints/simple-sat-solver.js.map +1 -0
  19. package/dist/constraints/z3-wasm-solver.d.ts +20 -0
  20. package/dist/constraints/z3-wasm-solver.d.ts.map +1 -0
  21. package/dist/constraints/z3-wasm-solver.js +286 -0
  22. package/dist/constraints/z3-wasm-solver.js.map +1 -0
  23. package/dist/index.d.ts +6 -0
  24. package/dist/index.d.ts.map +1 -0
  25. package/dist/index.js +6 -0
  26. package/dist/index.js.map +1 -0
  27. package/dist/knowledge-graph/index.d.ts +5 -0
  28. package/dist/knowledge-graph/index.d.ts.map +1 -0
  29. package/dist/knowledge-graph/index.js +5 -0
  30. package/dist/knowledge-graph/index.js.map +1 -0
  31. package/dist/knowledge-graph/natural-language-query.d.ts +42 -0
  32. package/dist/knowledge-graph/natural-language-query.d.ts.map +1 -0
  33. package/dist/knowledge-graph/natural-language-query.js +271 -0
  34. package/dist/knowledge-graph/natural-language-query.js.map +1 -0
  35. package/dist/knowledge-graph/prompts.d.ts +56 -0
  36. package/dist/knowledge-graph/prompts.d.ts.map +1 -0
  37. package/dist/knowledge-graph/prompts.js +198 -0
  38. package/dist/knowledge-graph/prompts.js.map +1 -0
  39. package/dist/knowledge-graph/query-language.d.ts +43 -0
  40. package/dist/knowledge-graph/query-language.d.ts.map +1 -0
  41. package/dist/knowledge-graph/query-language.js +569 -0
  42. package/dist/knowledge-graph/query-language.js.map +1 -0
  43. package/dist/knowledge-graph/reasoning-engine.d.ts +53 -0
  44. package/dist/knowledge-graph/reasoning-engine.d.ts.map +1 -0
  45. package/dist/knowledge-graph/reasoning-engine.js +337 -0
  46. package/dist/knowledge-graph/reasoning-engine.js.map +1 -0
  47. package/dist/logic/builtins.d.ts +10 -0
  48. package/dist/logic/builtins.d.ts.map +1 -0
  49. package/dist/logic/builtins.js +527 -0
  50. package/dist/logic/builtins.js.map +1 -0
  51. package/dist/logic/index.d.ts +8 -0
  52. package/dist/logic/index.d.ts.map +1 -0
  53. package/dist/logic/index.js +8 -0
  54. package/dist/logic/index.js.map +1 -0
  55. package/dist/logic/knowledge-base.d.ts +38 -0
  56. package/dist/logic/knowledge-base.d.ts.map +1 -0
  57. package/dist/logic/knowledge-base.js +205 -0
  58. package/dist/logic/knowledge-base.js.map +1 -0
  59. package/dist/logic/parser.d.ts +19 -0
  60. package/dist/logic/parser.d.ts.map +1 -0
  61. package/dist/logic/parser.js +466 -0
  62. package/dist/logic/parser.js.map +1 -0
  63. package/dist/logic/prompts.d.ts +55 -0
  64. package/dist/logic/prompts.d.ts.map +1 -0
  65. package/dist/logic/prompts.js +230 -0
  66. package/dist/logic/prompts.js.map +1 -0
  67. package/dist/logic/proof-tree.d.ts +30 -0
  68. package/dist/logic/proof-tree.d.ts.map +1 -0
  69. package/dist/logic/proof-tree.js +281 -0
  70. package/dist/logic/proof-tree.js.map +1 -0
  71. package/dist/logic/resolver.d.ts +16 -0
  72. package/dist/logic/resolver.d.ts.map +1 -0
  73. package/dist/logic/resolver.js +382 -0
  74. package/dist/logic/resolver.js.map +1 -0
  75. package/dist/logic/unification.d.ts +17 -0
  76. package/dist/logic/unification.d.ts.map +1 -0
  77. package/dist/logic/unification.js +257 -0
  78. package/dist/logic/unification.js.map +1 -0
  79. package/dist/orchestrator.d.ts +57 -0
  80. package/dist/orchestrator.d.ts.map +1 -0
  81. package/dist/orchestrator.js +293 -0
  82. package/dist/orchestrator.js.map +1 -0
  83. package/dist/planning/action-schema.d.ts +48 -0
  84. package/dist/planning/action-schema.d.ts.map +1 -0
  85. package/dist/planning/action-schema.js +358 -0
  86. package/dist/planning/action-schema.js.map +1 -0
  87. package/dist/planning/index.d.ts +6 -0
  88. package/dist/planning/index.d.ts.map +1 -0
  89. package/dist/planning/index.js +6 -0
  90. package/dist/planning/index.js.map +1 -0
  91. package/dist/planning/invariant-checker.d.ts +39 -0
  92. package/dist/planning/invariant-checker.d.ts.map +1 -0
  93. package/dist/planning/invariant-checker.js +293 -0
  94. package/dist/planning/invariant-checker.js.map +1 -0
  95. package/dist/planning/plan-repair.d.ts +38 -0
  96. package/dist/planning/plan-repair.d.ts.map +1 -0
  97. package/dist/planning/plan-repair.js +366 -0
  98. package/dist/planning/plan-repair.js.map +1 -0
  99. package/dist/planning/plan-validator.d.ts +31 -0
  100. package/dist/planning/plan-validator.d.ts.map +1 -0
  101. package/dist/planning/plan-validator.js +379 -0
  102. package/dist/planning/plan-validator.js.map +1 -0
  103. package/dist/planning/prompts.d.ts +50 -0
  104. package/dist/planning/prompts.d.ts.map +1 -0
  105. package/dist/planning/prompts.js +186 -0
  106. package/dist/planning/prompts.js.map +1 -0
  107. package/package.json +96 -0
@@ -0,0 +1,527 @@
1
+ import { unify, applySubstitution, isAtom, isVariable, isNumber, isCompound, isList, termToString, } from './unification';
2
+ const builtins = new Map();
3
+ function registerBuiltin(name, arity, handler) {
4
+ builtins.set(`${name}/${arity}`, handler);
5
+ }
6
+ function success(subst = new Map()) {
7
+ return { success: true, substitutions: [subst] };
8
+ }
9
+ function failure() {
10
+ return { success: false, substitutions: [] };
11
+ }
12
+ function multiSuccess(substitutions) {
13
+ return { success: substitutions.length > 0, substitutions };
14
+ }
15
+ registerBuiltin('true', 0, (_goal, subst) => success(subst));
16
+ registerBuiltin('false', 0, () => failure());
17
+ registerBuiltin('fail', 0, () => failure());
18
+ registerBuiltin('!', 0, (_goal, subst) => ({
19
+ success: true,
20
+ substitutions: [subst],
21
+ cut: true,
22
+ }));
23
+ registerBuiltin('=', 2, (goal, subst) => {
24
+ const [left, right] = goal.args;
25
+ const result = unify(left, right, subst);
26
+ return result ? success(result) : failure();
27
+ });
28
+ registerBuiltin('\\=', 2, (goal, subst) => {
29
+ const [left, right] = goal.args;
30
+ const result = unify(left, right, subst);
31
+ return result ? failure() : success(subst);
32
+ });
33
+ registerBuiltin('==', 2, (goal, subst) => {
34
+ const left = applySubstitution(goal.args[0], subst);
35
+ const right = applySubstitution(goal.args[1], subst);
36
+ return termToString(left) === termToString(right) ? success(subst) : failure();
37
+ });
38
+ registerBuiltin('\\==', 2, (goal, subst) => {
39
+ const left = applySubstitution(goal.args[0], subst);
40
+ const right = applySubstitution(goal.args[1], subst);
41
+ return termToString(left) !== termToString(right) ? success(subst) : failure();
42
+ });
43
+ function evaluateArithmetic(term, subst) {
44
+ const t = applySubstitution(term, subst);
45
+ if (isNumber(t)) {
46
+ return t.value;
47
+ }
48
+ if (isCompound(t)) {
49
+ const args = t.args.map((a) => evaluateArithmetic(a, subst));
50
+ switch (t.functor) {
51
+ case '+':
52
+ return args[0] + args[1];
53
+ case '-':
54
+ if (args.length === 1)
55
+ return -args[0];
56
+ return args[0] - args[1];
57
+ case '*':
58
+ return args[0] * args[1];
59
+ case '/':
60
+ return args[0] / args[1];
61
+ case '//':
62
+ return Math.floor(args[0] / args[1]);
63
+ case 'mod':
64
+ return args[0] % args[1];
65
+ case '^':
66
+ case '**':
67
+ return Math.pow(args[0], args[1]);
68
+ case 'abs':
69
+ return Math.abs(args[0]);
70
+ case 'sign':
71
+ return Math.sign(args[0]);
72
+ case 'min':
73
+ return Math.min(...args);
74
+ case 'max':
75
+ return Math.max(...args);
76
+ case 'sqrt':
77
+ return Math.sqrt(args[0]);
78
+ case 'sin':
79
+ return Math.sin(args[0]);
80
+ case 'cos':
81
+ return Math.cos(args[0]);
82
+ case 'tan':
83
+ return Math.tan(args[0]);
84
+ case 'log':
85
+ return Math.log(args[0]);
86
+ case 'exp':
87
+ return Math.exp(args[0]);
88
+ case 'floor':
89
+ return Math.floor(args[0]);
90
+ case 'ceiling':
91
+ return Math.ceil(args[0]);
92
+ case 'round':
93
+ return Math.round(args[0]);
94
+ case 'truncate':
95
+ return Math.trunc(args[0]);
96
+ case 'random':
97
+ return Math.random();
98
+ case 'pi':
99
+ return Math.PI;
100
+ case 'e':
101
+ return Math.E;
102
+ default:
103
+ throw new Error(`Unknown arithmetic operator: ${t.functor}`);
104
+ }
105
+ }
106
+ throw new Error(`Cannot evaluate arithmetic expression: ${termToString(t)}`);
107
+ }
108
+ registerBuiltin('is', 2, (goal, subst) => {
109
+ try {
110
+ const value = evaluateArithmetic(goal.args[1], subst);
111
+ const result = unify(goal.args[0], { type: 'number', value }, subst);
112
+ return result ? success(result) : failure();
113
+ }
114
+ catch {
115
+ return failure();
116
+ }
117
+ });
118
+ function compareNumbers(goal, subst, compare) {
119
+ try {
120
+ const left = evaluateArithmetic(goal.args[0], subst);
121
+ const right = evaluateArithmetic(goal.args[1], subst);
122
+ return compare(left, right) ? success(subst) : failure();
123
+ }
124
+ catch {
125
+ return failure();
126
+ }
127
+ }
128
+ registerBuiltin('<', 2, (goal, subst) => compareNumbers(goal, subst, (a, b) => a < b));
129
+ registerBuiltin('>', 2, (goal, subst) => compareNumbers(goal, subst, (a, b) => a > b));
130
+ registerBuiltin('=<', 2, (goal, subst) => compareNumbers(goal, subst, (a, b) => a <= b));
131
+ registerBuiltin('>=', 2, (goal, subst) => compareNumbers(goal, subst, (a, b) => a >= b));
132
+ registerBuiltin('=:=', 2, (goal, subst) => compareNumbers(goal, subst, (a, b) => a === b));
133
+ registerBuiltin('=\\=', 2, (goal, subst) => compareNumbers(goal, subst, (a, b) => a !== b));
134
+ registerBuiltin('atom', 1, (goal, subst) => {
135
+ const t = applySubstitution(goal.args[0], subst);
136
+ return isAtom(t) ? success(subst) : failure();
137
+ });
138
+ registerBuiltin('number', 1, (goal, subst) => {
139
+ const t = applySubstitution(goal.args[0], subst);
140
+ return isNumber(t) ? success(subst) : failure();
141
+ });
142
+ registerBuiltin('integer', 1, (goal, subst) => {
143
+ const t = applySubstitution(goal.args[0], subst);
144
+ return isNumber(t) && Number.isInteger(t.value) ? success(subst) : failure();
145
+ });
146
+ registerBuiltin('float', 1, (goal, subst) => {
147
+ const t = applySubstitution(goal.args[0], subst);
148
+ return isNumber(t) && !Number.isInteger(t.value) ? success(subst) : failure();
149
+ });
150
+ registerBuiltin('compound', 1, (goal, subst) => {
151
+ const t = applySubstitution(goal.args[0], subst);
152
+ return isCompound(t) && t.args.length > 0 ? success(subst) : failure();
153
+ });
154
+ registerBuiltin('atomic', 1, (goal, subst) => {
155
+ const t = applySubstitution(goal.args[0], subst);
156
+ return isAtom(t) || isNumber(t) ? success(subst) : failure();
157
+ });
158
+ registerBuiltin('var', 1, (goal, subst) => {
159
+ const t = applySubstitution(goal.args[0], subst);
160
+ return isVariable(t) ? success(subst) : failure();
161
+ });
162
+ registerBuiltin('nonvar', 1, (goal, subst) => {
163
+ const t = applySubstitution(goal.args[0], subst);
164
+ return !isVariable(t) ? success(subst) : failure();
165
+ });
166
+ registerBuiltin('is_list', 1, (goal, subst) => {
167
+ const t = applySubstitution(goal.args[0], subst);
168
+ return isList(t) ? success(subst) : failure();
169
+ });
170
+ registerBuiltin('ground', 1, (goal, subst) => {
171
+ function isGround(term) {
172
+ const t = applySubstitution(term, subst);
173
+ if (isVariable(t))
174
+ return false;
175
+ if (isCompound(t))
176
+ return t.args.every(isGround);
177
+ if (isList(t)) {
178
+ return t.elements.every(isGround) && (!t.tail || isGround(t.tail));
179
+ }
180
+ return true;
181
+ }
182
+ return isGround(goal.args[0]) ? success(subst) : failure();
183
+ });
184
+ function listToArray(list, subst) {
185
+ const t = applySubstitution(list, subst);
186
+ if (!isList(t))
187
+ return null;
188
+ const elements = [...t.elements];
189
+ if (t.tail) {
190
+ const tailElements = listToArray(t.tail, subst);
191
+ if (tailElements === null)
192
+ return null;
193
+ elements.push(...tailElements);
194
+ }
195
+ return elements;
196
+ }
197
+ function arrayToList(elements) {
198
+ return { type: 'list', elements };
199
+ }
200
+ registerBuiltin('member', 2, (goal, subst) => {
201
+ const elem = goal.args[0];
202
+ const list = applySubstitution(goal.args[1], subst);
203
+ if (!isList(list)) {
204
+ return failure();
205
+ }
206
+ const elements = listToArray(list, subst);
207
+ if (!elements)
208
+ return failure();
209
+ const substitutions = [];
210
+ for (const item of elements) {
211
+ const result = unify(elem, item, subst);
212
+ if (result) {
213
+ substitutions.push(result);
214
+ }
215
+ }
216
+ return multiSuccess(substitutions);
217
+ });
218
+ registerBuiltin('append', 3, (goal, subst) => {
219
+ const [list1, list2, result] = goal.args.map((a) => applySubstitution(a, subst));
220
+ if (isList(list1) && isList(list2)) {
221
+ const elements1 = listToArray(list1, subst);
222
+ const elements2 = listToArray(list2, subst);
223
+ if (!elements1 || !elements2)
224
+ return failure();
225
+ const combined = arrayToList([...elements1, ...elements2]);
226
+ const unifyResult = unify(result, combined, subst);
227
+ return unifyResult ? success(unifyResult) : failure();
228
+ }
229
+ if (isList(result)) {
230
+ const resultElements = listToArray(result, subst);
231
+ if (!resultElements)
232
+ return failure();
233
+ const substitutions = [];
234
+ for (let i = 0; i <= resultElements.length; i++) {
235
+ const prefix = arrayToList(resultElements.slice(0, i));
236
+ const suffix = arrayToList(resultElements.slice(i));
237
+ let current = subst;
238
+ const r1 = unify(list1, prefix, current);
239
+ if (!r1)
240
+ continue;
241
+ current = r1;
242
+ const r2 = unify(list2, suffix, current);
243
+ if (!r2)
244
+ continue;
245
+ substitutions.push(r2);
246
+ }
247
+ return multiSuccess(substitutions);
248
+ }
249
+ return failure();
250
+ });
251
+ registerBuiltin('length', 2, (goal, subst) => {
252
+ const list = applySubstitution(goal.args[0], subst);
253
+ const len = applySubstitution(goal.args[1], subst);
254
+ if (isList(list)) {
255
+ const elements = listToArray(list, subst);
256
+ if (!elements)
257
+ return failure();
258
+ const result = unify(len, { type: 'number', value: elements.length }, subst);
259
+ return result ? success(result) : failure();
260
+ }
261
+ if (isNumber(len) && Number.isInteger(len.value) && len.value >= 0) {
262
+ const elements = [];
263
+ for (let i = 0; i < len.value; i++) {
264
+ elements.push({ type: 'variable', name: `_E${i}` });
265
+ }
266
+ const result = unify(list, arrayToList(elements), subst);
267
+ return result ? success(result) : failure();
268
+ }
269
+ return failure();
270
+ });
271
+ registerBuiltin('reverse', 2, (goal, subst) => {
272
+ const list = applySubstitution(goal.args[0], subst);
273
+ const reversed = applySubstitution(goal.args[1], subst);
274
+ if (isList(list)) {
275
+ const elements = listToArray(list, subst);
276
+ if (!elements)
277
+ return failure();
278
+ const result = unify(reversed, arrayToList([...elements].reverse()), subst);
279
+ return result ? success(result) : failure();
280
+ }
281
+ if (isList(reversed)) {
282
+ const elements = listToArray(reversed, subst);
283
+ if (!elements)
284
+ return failure();
285
+ const result = unify(list, arrayToList([...elements].reverse()), subst);
286
+ return result ? success(result) : failure();
287
+ }
288
+ return failure();
289
+ });
290
+ registerBuiltin('sort', 2, (goal, subst) => {
291
+ const list = applySubstitution(goal.args[0], subst);
292
+ const sorted = goal.args[1];
293
+ if (!isList(list))
294
+ return failure();
295
+ const elements = listToArray(list, subst);
296
+ if (!elements)
297
+ return failure();
298
+ const sortedElements = [...elements].sort((a, b) => {
299
+ const as = termToString(applySubstitution(a, subst));
300
+ const bs = termToString(applySubstitution(b, subst));
301
+ return as.localeCompare(bs);
302
+ });
303
+ const unique = sortedElements.filter((el, i, arr) => i === 0 ||
304
+ termToString(applySubstitution(el, subst)) !==
305
+ termToString(applySubstitution(arr[i - 1], subst)));
306
+ const result = unify(sorted, arrayToList(unique), subst);
307
+ return result ? success(result) : failure();
308
+ });
309
+ registerBuiltin('msort', 2, (goal, subst) => {
310
+ const list = applySubstitution(goal.args[0], subst);
311
+ const sorted = goal.args[1];
312
+ if (!isList(list))
313
+ return failure();
314
+ const elements = listToArray(list, subst);
315
+ if (!elements)
316
+ return failure();
317
+ const sortedElements = [...elements].sort((a, b) => {
318
+ const as = termToString(applySubstitution(a, subst));
319
+ const bs = termToString(applySubstitution(b, subst));
320
+ return as.localeCompare(bs);
321
+ });
322
+ const result = unify(sorted, arrayToList(sortedElements), subst);
323
+ return result ? success(result) : failure();
324
+ });
325
+ registerBuiltin('nth0', 3, (goal, subst) => {
326
+ const index = applySubstitution(goal.args[0], subst);
327
+ const list = applySubstitution(goal.args[1], subst);
328
+ const elem = goal.args[2];
329
+ if (!isNumber(index) || !isList(list))
330
+ return failure();
331
+ const elements = listToArray(list, subst);
332
+ if (!elements)
333
+ return failure();
334
+ const i = index.value;
335
+ if (i < 0 || i >= elements.length)
336
+ return failure();
337
+ const result = unify(elem, elements[i], subst);
338
+ return result ? success(result) : failure();
339
+ });
340
+ registerBuiltin('nth1', 3, (goal, subst) => {
341
+ const index = applySubstitution(goal.args[0], subst);
342
+ const list = applySubstitution(goal.args[1], subst);
343
+ const elem = goal.args[2];
344
+ if (!isNumber(index) || !isList(list))
345
+ return failure();
346
+ const elements = listToArray(list, subst);
347
+ if (!elements)
348
+ return failure();
349
+ const i = index.value - 1;
350
+ if (i < 0 || i >= elements.length)
351
+ return failure();
352
+ const result = unify(elem, elements[i], subst);
353
+ return result ? success(result) : failure();
354
+ });
355
+ registerBuiltin('last', 2, (goal, subst) => {
356
+ const list = applySubstitution(goal.args[0], subst);
357
+ const elem = goal.args[1];
358
+ if (!isList(list))
359
+ return failure();
360
+ const elements = listToArray(list, subst);
361
+ if (!elements || elements.length === 0)
362
+ return failure();
363
+ const result = unify(elem, elements[elements.length - 1], subst);
364
+ return result ? success(result) : failure();
365
+ });
366
+ registerBuiltin('functor', 3, (goal, subst) => {
367
+ const term = applySubstitution(goal.args[0], subst);
368
+ const name = goal.args[1];
369
+ const arity = goal.args[2];
370
+ if (isCompound(term)) {
371
+ let result = unify(name, { type: 'atom', value: term.functor }, subst);
372
+ if (!result)
373
+ return failure();
374
+ result = unify(arity, { type: 'number', value: term.args.length }, result);
375
+ return result ? success(result) : failure();
376
+ }
377
+ if (isAtom(term)) {
378
+ let result = unify(name, term, subst);
379
+ if (!result)
380
+ return failure();
381
+ result = unify(arity, { type: 'number', value: 0 }, result);
382
+ return result ? success(result) : failure();
383
+ }
384
+ if (isNumber(term)) {
385
+ let result = unify(name, term, subst);
386
+ if (!result)
387
+ return failure();
388
+ result = unify(arity, { type: 'number', value: 0 }, result);
389
+ return result ? success(result) : failure();
390
+ }
391
+ const n = applySubstitution(name, subst);
392
+ const a = applySubstitution(arity, subst);
393
+ if (isAtom(n) && isNumber(a) && Number.isInteger(a.value) && a.value >= 0) {
394
+ if (a.value === 0) {
395
+ const result = unify(term, n, subst);
396
+ return result ? success(result) : failure();
397
+ }
398
+ const args = [];
399
+ for (let i = 0; i < a.value; i++) {
400
+ args.push({ type: 'variable', name: `_A${i}` });
401
+ }
402
+ const compound = {
403
+ type: 'compound',
404
+ functor: n.value,
405
+ args,
406
+ };
407
+ const result = unify(term, compound, subst);
408
+ return result ? success(result) : failure();
409
+ }
410
+ return failure();
411
+ });
412
+ registerBuiltin('arg', 3, (goal, subst) => {
413
+ const n = applySubstitution(goal.args[0], subst);
414
+ const term = applySubstitution(goal.args[1], subst);
415
+ const arg = goal.args[2];
416
+ if (!isNumber(n) || !isCompound(term))
417
+ return failure();
418
+ const index = n.value - 1;
419
+ if (index < 0 || index >= term.args.length)
420
+ return failure();
421
+ const result = unify(arg, term.args[index], subst);
422
+ return result ? success(result) : failure();
423
+ });
424
+ registerBuiltin('copy_term', 2, (goal, subst) => {
425
+ const original = applySubstitution(goal.args[0], subst);
426
+ const copy = goal.args[1];
427
+ function renameCopy(term, mapping) {
428
+ if (isVariable(term)) {
429
+ if (!mapping.has(term.name)) {
430
+ mapping.set(term.name, `_C${mapping.size}`);
431
+ }
432
+ return { type: 'variable', name: mapping.get(term.name) };
433
+ }
434
+ if (isCompound(term)) {
435
+ return {
436
+ type: 'compound',
437
+ functor: term.functor,
438
+ args: term.args.map((a) => renameCopy(a, mapping)),
439
+ };
440
+ }
441
+ if (isList(term)) {
442
+ return {
443
+ type: 'list',
444
+ elements: term.elements.map((e) => renameCopy(e, mapping)),
445
+ tail: term.tail ? renameCopy(term.tail, mapping) : undefined,
446
+ };
447
+ }
448
+ return term;
449
+ }
450
+ const copied = renameCopy(original, new Map());
451
+ const result = unify(copy, copied, subst);
452
+ return result ? success(result) : failure();
453
+ });
454
+ registerBuiltin('succ', 2, (goal, subst) => {
455
+ const n = applySubstitution(goal.args[0], subst);
456
+ const s = applySubstitution(goal.args[1], subst);
457
+ if (isNumber(n) && Number.isInteger(n.value) && n.value >= 0) {
458
+ const result = unify(s, { type: 'number', value: n.value + 1 }, subst);
459
+ return result ? success(result) : failure();
460
+ }
461
+ if (isNumber(s) && Number.isInteger(s.value) && s.value > 0) {
462
+ const result = unify(n, { type: 'number', value: s.value - 1 }, subst);
463
+ return result ? success(result) : failure();
464
+ }
465
+ return failure();
466
+ });
467
+ registerBuiltin('plus', 3, (goal, subst) => {
468
+ const x = applySubstitution(goal.args[0], subst);
469
+ const y = applySubstitution(goal.args[1], subst);
470
+ const z = applySubstitution(goal.args[2], subst);
471
+ if (isNumber(x) && isNumber(y)) {
472
+ const result = unify(z, { type: 'number', value: x.value + y.value }, subst);
473
+ return result ? success(result) : failure();
474
+ }
475
+ if (isNumber(x) && isNumber(z)) {
476
+ const result = unify(y, { type: 'number', value: z.value - x.value }, subst);
477
+ return result ? success(result) : failure();
478
+ }
479
+ if (isNumber(y) && isNumber(z)) {
480
+ const result = unify(x, { type: 'number', value: z.value - y.value }, subst);
481
+ return result ? success(result) : failure();
482
+ }
483
+ return failure();
484
+ });
485
+ export function isBuiltin(functor, arity) {
486
+ return builtins.has(`${functor}/${arity}`);
487
+ }
488
+ export function executeBuiltin(goal, subst) {
489
+ const key = `${goal.functor}/${goal.args.length}`;
490
+ const handler = builtins.get(key);
491
+ if (!handler) {
492
+ return failure();
493
+ }
494
+ return handler(goal, subst);
495
+ }
496
+ export function getBuiltinList() {
497
+ return [
498
+ 'true',
499
+ 'false',
500
+ 'fail',
501
+ 'cut',
502
+ 'is',
503
+ 'unify',
504
+ 'not',
505
+ 'gt',
506
+ 'gte',
507
+ 'lt',
508
+ 'lte',
509
+ 'eq',
510
+ 'neq',
511
+ 'member',
512
+ 'append',
513
+ 'length',
514
+ 'reverse',
515
+ 'sort',
516
+ 'atom',
517
+ 'number',
518
+ 'compound',
519
+ 'var',
520
+ 'nonvar',
521
+ 'is_list',
522
+ 'functor',
523
+ 'arg',
524
+ 'copy_term',
525
+ ];
526
+ }
527
+ //# sourceMappingURL=builtins.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"builtins.js","sourceRoot":"","sources":["../../src/logic/builtins.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ export { unify, applySubstitution, composeSubstitutions, getVariables, renameVariables, termsEqual, occursIn, termToString, substitutionToString, isAtom, isVariable, isNumber, isString, isCompound, isList, } from './unification';
2
+ export { parseTerm, parseClause, parseProgram, parseQuery, termFromValue, termToValue, } from './parser';
3
+ export { KnowledgeBase, createKnowledgeBase, type KnowledgeBaseOptions } from './knowledge-base';
4
+ export { isBuiltin, executeBuiltin, getBuiltinList, type BuiltinResult } from './builtins';
5
+ export { SLDResolver, createResolver, queryKnowledgeBase, formatSolutions } from './resolver';
6
+ export { formatProofTree, formatProofPath, extractProofPaths, analyzeProofTree, pruneProofTree, proofTreeToMermaid, proofTreeToJSON, type ProofTreeOptions, type ProofPath, type ProofStats, } from './proof-tree';
7
+ export { createNLToQueryPrompt, createNLToFactsPrompt, createNLToRulesPrompt, createExplainResultPrompt, createGenerateQueriesPrompt, createDebugQueryPrompt, formatQueryForLLM, formatClauseForLLM, formatKnowledgeBaseForLLM, parseLLMQueryResponse, parseLLMFactsResponse, type NLToLogicPromptContext, type NLToFactsPromptContext, type NLToRulesPromptContext, type ExplainResultPromptContext, type GenerateQueriesPromptContext, type DebugQueryPromptContext, type ParseLLMResponseResult, } from './prompts';
8
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/logic/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,EACL,iBAAiB,EACjB,oBAAoB,EACpB,YAAY,EACZ,eAAe,EACf,UAAU,EACV,QAAQ,EACR,YAAY,EACZ,oBAAoB,EACpB,MAAM,EACN,UAAU,EACV,QAAQ,EACR,QAAQ,EACR,UAAU,EACV,MAAM,GACP,MAAM,eAAe,CAAC;AAEvB,OAAO,EACL,SAAS,EACT,WAAW,EACX,YAAY,EACZ,UAAU,EACV,aAAa,EACb,WAAW,GACZ,MAAM,UAAU,CAAC;AAElB,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,KAAK,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAEjG,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,cAAc,EAAE,KAAK,aAAa,EAAE,MAAM,YAAY,CAAC;AAE3F,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAE9F,OAAO,EACL,eAAe,EACf,eAAe,EACf,iBAAiB,EACjB,gBAAgB,EAChB,cAAc,EACd,kBAAkB,EAClB,eAAe,EACf,KAAK,gBAAgB,EACrB,KAAK,SAAS,EACd,KAAK,UAAU,GAChB,MAAM,cAAc,CAAC;AAEtB,OAAO,EACL,qBAAqB,EACrB,qBAAqB,EACrB,qBAAqB,EACrB,yBAAyB,EACzB,2BAA2B,EAC3B,sBAAsB,EACtB,iBAAiB,EACjB,kBAAkB,EAClB,yBAAyB,EACzB,qBAAqB,EACrB,qBAAqB,EACrB,KAAK,sBAAsB,EAC3B,KAAK,sBAAsB,EAC3B,KAAK,sBAAsB,EAC3B,KAAK,0BAA0B,EAC/B,KAAK,4BAA4B,EACjC,KAAK,uBAAuB,EAC5B,KAAK,sBAAsB,GAC5B,MAAM,WAAW,CAAC"}
@@ -0,0 +1,8 @@
1
+ export { unify, applySubstitution, composeSubstitutions, getVariables, renameVariables, termsEqual, occursIn, termToString, substitutionToString, isAtom, isVariable, isNumber, isString, isCompound, isList, } from './unification';
2
+ export { parseTerm, parseClause, parseProgram, parseQuery, termFromValue, termToValue, } from './parser';
3
+ export { KnowledgeBase, createKnowledgeBase } from './knowledge-base';
4
+ export { isBuiltin, executeBuiltin, getBuiltinList } from './builtins';
5
+ export { SLDResolver, createResolver, queryKnowledgeBase, formatSolutions } from './resolver';
6
+ export { formatProofTree, formatProofPath, extractProofPaths, analyzeProofTree, pruneProofTree, proofTreeToMermaid, proofTreeToJSON, } from './proof-tree';
7
+ export { createNLToQueryPrompt, createNLToFactsPrompt, createNLToRulesPrompt, createExplainResultPrompt, createGenerateQueriesPrompt, createDebugQueryPrompt, formatQueryForLLM, formatClauseForLLM, formatKnowledgeBaseForLLM, parseLLMQueryResponse, parseLLMFactsResponse, } from './prompts';
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/logic/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,EACL,iBAAiB,EACjB,oBAAoB,EACpB,YAAY,EACZ,eAAe,EACf,UAAU,EACV,QAAQ,EACR,YAAY,EACZ,oBAAoB,EACpB,MAAM,EACN,UAAU,EACV,QAAQ,EACR,QAAQ,EACR,UAAU,EACV,MAAM,GACP,MAAM,eAAe,CAAC;AAEvB,OAAO,EACL,SAAS,EACT,WAAW,EACX,YAAY,EACZ,UAAU,EACV,aAAa,EACb,WAAW,GACZ,MAAM,UAAU,CAAC;AAElB,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAA6B,MAAM,kBAAkB,CAAC;AAEjG,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,cAAc,EAAsB,MAAM,YAAY,CAAC;AAE3F,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAE9F,OAAO,EACL,eAAe,EACf,eAAe,EACf,iBAAiB,EACjB,gBAAgB,EAChB,cAAc,EACd,kBAAkB,EAClB,eAAe,GAIhB,MAAM,cAAc,CAAC;AAEtB,OAAO,EACL,qBAAqB,EACrB,qBAAqB,EACrB,qBAAqB,EACrB,yBAAyB,EACzB,2BAA2B,EAC3B,sBAAsB,EACtB,iBAAiB,EACjB,kBAAkB,EAClB,yBAAyB,EACzB,qBAAqB,EACrB,qBAAqB,GAQtB,MAAM,WAAW,CAAC"}
@@ -0,0 +1,38 @@
1
+ import type { Clause, CompoundTerm, Term, KnowledgeBaseStats } from '@cogitator-ai/types';
2
+ export interface KnowledgeBaseOptions {
3
+ allowDuplicates?: boolean;
4
+ }
5
+ export declare class KnowledgeBase {
6
+ private clauses;
7
+ private factCount;
8
+ private ruleCount;
9
+ private options;
10
+ constructor(options?: KnowledgeBaseOptions);
11
+ private getKey;
12
+ private addClause;
13
+ private clausesEqual;
14
+ assertFact(predicate: string, args: Term[]): void;
15
+ assertRule(head: CompoundTerm, body: CompoundTerm[]): void;
16
+ assert(clauseString: string): boolean;
17
+ consult(program: string): {
18
+ success: boolean;
19
+ errors: string[];
20
+ };
21
+ getClauses(predicate: string, arity: number): Clause[];
22
+ getAllClauses(): Clause[];
23
+ getPredicates(): string[];
24
+ hasPredicate(predicate: string, arity: number): boolean;
25
+ retract(clause: Clause): boolean;
26
+ retractAll(predicate: string, arity: number): number;
27
+ abolish(predicate: string, arity: number): void;
28
+ clear(): void;
29
+ getStats(): KnowledgeBaseStats;
30
+ toString(): string;
31
+ private clauseToString;
32
+ clone(): KnowledgeBase;
33
+ merge(other: KnowledgeBase): void;
34
+ export(): string;
35
+ static import(json: string): KnowledgeBase;
36
+ }
37
+ export declare function createKnowledgeBase(program?: string): KnowledgeBase;
38
+ //# sourceMappingURL=knowledge-base.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"knowledge-base.d.ts","sourceRoot":"","sources":["../../src/logic/knowledge-base.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,IAAI,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAI1F,MAAM,WAAW,oBAAoB;IACnC,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B;AAED,qBAAa,aAAa;IACxB,OAAO,CAAC,OAAO,CAA+B;IAC9C,OAAO,CAAC,SAAS,CAAK;IACtB,OAAO,CAAC,SAAS,CAAK;IACtB,OAAO,CAAC,OAAO,CAAiC;gBAEpC,OAAO,GAAE,oBAAyB;IAM9C,OAAO,CAAC,MAAM;IAId,OAAO,CAAC,SAAS;IAmBjB,OAAO,CAAC,YAAY;IAQpB,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI;IAQjD,UAAU,CAAC,IAAI,EAAE,YAAY,EAAE,IAAI,EAAE,YAAY,EAAE,GAAG,IAAI;IAK1D,MAAM,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO;IASrC,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,MAAM,EAAE,MAAM,EAAE,CAAA;KAAE;IAgBhE,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,EAAE;IAKtD,aAAa,IAAI,MAAM,EAAE;IAQzB,aAAa,IAAI,MAAM,EAAE;IAIzB,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO;IAKvD,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAkBhC,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM;IAkBpD,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAI/C,KAAK,IAAI,IAAI;IAMb,QAAQ,IAAI,kBAAkB;IAsB9B,QAAQ,IAAI,MAAM;IAYlB,OAAO,CAAC,cAAc;IAStB,KAAK,IAAI,aAAa;IAUtB,KAAK,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAQjC,MAAM,IAAI,MAAM;IAQhB,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,aAAa;CAa3C;AAED,wBAAgB,mBAAmB,CAAC,OAAO,CAAC,EAAE,MAAM,GAAG,aAAa,CAMnE"}