@stevenvo780/st-lang 4.14.1 → 4.15.1

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 (197) hide show
  1. package/dist/format/stnb/__tests__/executor.test.d.ts +2 -0
  2. package/dist/format/stnb/__tests__/executor.test.d.ts.map +1 -0
  3. package/dist/format/stnb/__tests__/executor.test.js +140 -0
  4. package/dist/format/stnb/__tests__/executor.test.js.map +1 -0
  5. package/dist/format/stnb/__tests__/parser.test.d.ts +2 -0
  6. package/dist/format/stnb/__tests__/parser.test.d.ts.map +1 -0
  7. package/dist/format/stnb/__tests__/parser.test.js +119 -0
  8. package/dist/format/stnb/__tests__/parser.test.js.map +1 -0
  9. package/dist/format/stnb/__tests__/renderer.test.d.ts +2 -0
  10. package/dist/format/stnb/__tests__/renderer.test.d.ts.map +1 -0
  11. package/dist/format/stnb/__tests__/renderer.test.js +109 -0
  12. package/dist/format/stnb/__tests__/renderer.test.js.map +1 -0
  13. package/dist/format/stnb/__tests__/roundtrip.test.d.ts +2 -0
  14. package/dist/format/stnb/__tests__/roundtrip.test.d.ts.map +1 -0
  15. package/dist/format/stnb/__tests__/roundtrip.test.js +91 -0
  16. package/dist/format/stnb/__tests__/roundtrip.test.js.map +1 -0
  17. package/dist/format/stnb/__tests__/serializer.test.d.ts +2 -0
  18. package/dist/format/stnb/__tests__/serializer.test.d.ts.map +1 -0
  19. package/dist/format/stnb/__tests__/serializer.test.js +60 -0
  20. package/dist/format/stnb/__tests__/serializer.test.js.map +1 -0
  21. package/dist/format/stnb/executor.d.ts +29 -0
  22. package/dist/format/stnb/executor.d.ts.map +1 -0
  23. package/dist/format/stnb/executor.js +139 -0
  24. package/dist/format/stnb/executor.js.map +1 -0
  25. package/dist/format/stnb/index.d.ts +19 -0
  26. package/dist/format/stnb/index.d.ts.map +1 -0
  27. package/dist/format/stnb/index.js +28 -0
  28. package/dist/format/stnb/index.js.map +1 -0
  29. package/dist/format/stnb/renderer-html.d.ts +11 -0
  30. package/dist/format/stnb/renderer-html.d.ts.map +1 -0
  31. package/dist/format/stnb/renderer-html.js +180 -0
  32. package/dist/format/stnb/renderer-html.js.map +1 -0
  33. package/dist/format/stnb/renderer-markdown.d.ts +13 -0
  34. package/dist/format/stnb/renderer-markdown.d.ts.map +1 -0
  35. package/dist/format/stnb/renderer-markdown.js +92 -0
  36. package/dist/format/stnb/renderer-markdown.js.map +1 -0
  37. package/dist/format/stnb/serializer.d.ts +14 -0
  38. package/dist/format/stnb/serializer.d.ts.map +1 -0
  39. package/dist/format/stnb/serializer.js +21 -0
  40. package/dist/format/stnb/serializer.js.map +1 -0
  41. package/dist/index.d.ts +6 -0
  42. package/dist/index.d.ts.map +1 -1
  43. package/dist/index.js +8 -1
  44. package/dist/index.js.map +1 -1
  45. package/dist/logic/profiles/dl-hybrid/__tests__/differential.test.d.ts +2 -0
  46. package/dist/logic/profiles/dl-hybrid/__tests__/differential.test.d.ts.map +1 -0
  47. package/dist/logic/profiles/dl-hybrid/__tests__/differential.test.js +141 -0
  48. package/dist/logic/profiles/dl-hybrid/__tests__/differential.test.js.map +1 -0
  49. package/dist/logic/profiles/dl-hybrid/__tests__/examples.test.d.ts +2 -0
  50. package/dist/logic/profiles/dl-hybrid/__tests__/examples.test.d.ts.map +1 -0
  51. package/dist/logic/profiles/dl-hybrid/__tests__/examples.test.js +55 -0
  52. package/dist/logic/profiles/dl-hybrid/__tests__/examples.test.js.map +1 -0
  53. package/dist/logic/profiles/dl-hybrid/__tests__/parser.test.d.ts +2 -0
  54. package/dist/logic/profiles/dl-hybrid/__tests__/parser.test.d.ts.map +1 -0
  55. package/dist/logic/profiles/dl-hybrid/__tests__/parser.test.js +149 -0
  56. package/dist/logic/profiles/dl-hybrid/__tests__/parser.test.js.map +1 -0
  57. package/dist/logic/profiles/dl-hybrid/__tests__/tableau.test.d.ts +2 -0
  58. package/dist/logic/profiles/dl-hybrid/__tests__/tableau.test.d.ts.map +1 -0
  59. package/dist/logic/profiles/dl-hybrid/__tests__/tableau.test.js +105 -0
  60. package/dist/logic/profiles/dl-hybrid/__tests__/tableau.test.js.map +1 -0
  61. package/dist/logic/profiles/dl-hybrid/ast.d.ts +160 -0
  62. package/dist/logic/profiles/dl-hybrid/ast.d.ts.map +1 -0
  63. package/dist/logic/profiles/dl-hybrid/ast.js +261 -0
  64. package/dist/logic/profiles/dl-hybrid/ast.js.map +1 -0
  65. package/dist/logic/profiles/dl-hybrid/differential.d.ts +61 -0
  66. package/dist/logic/profiles/dl-hybrid/differential.d.ts.map +1 -0
  67. package/dist/logic/profiles/dl-hybrid/differential.js +291 -0
  68. package/dist/logic/profiles/dl-hybrid/differential.js.map +1 -0
  69. package/dist/logic/profiles/dl-hybrid/index.d.ts +10 -0
  70. package/dist/logic/profiles/dl-hybrid/index.d.ts.map +1 -0
  71. package/dist/logic/profiles/dl-hybrid/index.js +90 -0
  72. package/dist/logic/profiles/dl-hybrid/index.js.map +1 -0
  73. package/dist/logic/profiles/dl-hybrid/parser.d.ts +8 -0
  74. package/dist/logic/profiles/dl-hybrid/parser.d.ts.map +1 -0
  75. package/dist/logic/profiles/dl-hybrid/parser.js +410 -0
  76. package/dist/logic/profiles/dl-hybrid/parser.js.map +1 -0
  77. package/dist/logic/profiles/dl-hybrid/profile.d.ts +23 -0
  78. package/dist/logic/profiles/dl-hybrid/profile.d.ts.map +1 -0
  79. package/dist/logic/profiles/dl-hybrid/profile.js +122 -0
  80. package/dist/logic/profiles/dl-hybrid/profile.js.map +1 -0
  81. package/dist/logic/profiles/dl-hybrid/semantics.d.ts +16 -0
  82. package/dist/logic/profiles/dl-hybrid/semantics.d.ts.map +1 -0
  83. package/dist/logic/profiles/dl-hybrid/semantics.js +181 -0
  84. package/dist/logic/profiles/dl-hybrid/semantics.js.map +1 -0
  85. package/dist/logic/profiles/dl-hybrid/tableau.d.ts +38 -0
  86. package/dist/logic/profiles/dl-hybrid/tableau.d.ts.map +1 -0
  87. package/dist/logic/profiles/dl-hybrid/tableau.js +289 -0
  88. package/dist/logic/profiles/dl-hybrid/tableau.js.map +1 -0
  89. package/dist/reasoning/dl-hybrid/__tests__/invariant.test.d.ts +2 -0
  90. package/dist/reasoning/dl-hybrid/__tests__/invariant.test.d.ts.map +1 -0
  91. package/dist/reasoning/dl-hybrid/__tests__/invariant.test.js +74 -0
  92. package/dist/reasoning/dl-hybrid/__tests__/invariant.test.js.map +1 -0
  93. package/dist/reasoning/dl-hybrid/index.d.ts +3 -0
  94. package/dist/reasoning/dl-hybrid/index.d.ts.map +1 -0
  95. package/dist/reasoning/dl-hybrid/index.js +16 -0
  96. package/dist/reasoning/dl-hybrid/index.js.map +1 -0
  97. package/dist/reasoning/dl-hybrid/invariant-search.d.ts +39 -0
  98. package/dist/reasoning/dl-hybrid/invariant-search.d.ts.map +1 -0
  99. package/dist/reasoning/dl-hybrid/invariant-search.js +188 -0
  100. package/dist/reasoning/dl-hybrid/invariant-search.js.map +1 -0
  101. package/dist/reasoning/lemma-rag/__tests__/benchmarks.test.d.ts +2 -0
  102. package/dist/reasoning/lemma-rag/__tests__/benchmarks.test.d.ts.map +1 -0
  103. package/dist/reasoning/lemma-rag/__tests__/benchmarks.test.js +72 -0
  104. package/dist/reasoning/lemma-rag/__tests__/benchmarks.test.js.map +1 -0
  105. package/dist/reasoning/lemma-rag/__tests__/embedding.test.d.ts +2 -0
  106. package/dist/reasoning/lemma-rag/__tests__/embedding.test.d.ts.map +1 -0
  107. package/dist/reasoning/lemma-rag/__tests__/embedding.test.js +102 -0
  108. package/dist/reasoning/lemma-rag/__tests__/embedding.test.js.map +1 -0
  109. package/dist/reasoning/lemma-rag/__tests__/integration.test.d.ts +2 -0
  110. package/dist/reasoning/lemma-rag/__tests__/integration.test.d.ts.map +1 -0
  111. package/dist/reasoning/lemma-rag/__tests__/integration.test.js +40 -0
  112. package/dist/reasoning/lemma-rag/__tests__/integration.test.js.map +1 -0
  113. package/dist/reasoning/lemma-rag/__tests__/query.test.d.ts +2 -0
  114. package/dist/reasoning/lemma-rag/__tests__/query.test.d.ts.map +1 -0
  115. package/dist/reasoning/lemma-rag/__tests__/query.test.js +136 -0
  116. package/dist/reasoning/lemma-rag/__tests__/query.test.js.map +1 -0
  117. package/dist/reasoning/lemma-rag/__tests__/retrieval.test.d.ts +2 -0
  118. package/dist/reasoning/lemma-rag/__tests__/retrieval.test.d.ts.map +1 -0
  119. package/dist/reasoning/lemma-rag/__tests__/retrieval.test.js +147 -0
  120. package/dist/reasoning/lemma-rag/__tests__/retrieval.test.js.map +1 -0
  121. package/dist/reasoning/lemma-rag/benchmarks.d.ts +30 -0
  122. package/dist/reasoning/lemma-rag/benchmarks.d.ts.map +1 -0
  123. package/dist/reasoning/lemma-rag/benchmarks.js +177 -0
  124. package/dist/reasoning/lemma-rag/benchmarks.js.map +1 -0
  125. package/dist/reasoning/lemma-rag/embedding.d.ts +26 -0
  126. package/dist/reasoning/lemma-rag/embedding.d.ts.map +1 -0
  127. package/dist/reasoning/lemma-rag/embedding.js +243 -0
  128. package/dist/reasoning/lemma-rag/embedding.js.map +1 -0
  129. package/dist/reasoning/lemma-rag/index-store.d.ts +35 -0
  130. package/dist/reasoning/lemma-rag/index-store.d.ts.map +1 -0
  131. package/dist/reasoning/lemma-rag/index-store.js +105 -0
  132. package/dist/reasoning/lemma-rag/index-store.js.map +1 -0
  133. package/dist/reasoning/lemma-rag/index.d.ts +9 -0
  134. package/dist/reasoning/lemma-rag/index.d.ts.map +1 -0
  135. package/dist/reasoning/lemma-rag/index.js +34 -0
  136. package/dist/reasoning/lemma-rag/index.js.map +1 -0
  137. package/dist/reasoning/lemma-rag/query.d.ts +48 -0
  138. package/dist/reasoning/lemma-rag/query.d.ts.map +1 -0
  139. package/dist/reasoning/lemma-rag/query.js +92 -0
  140. package/dist/reasoning/lemma-rag/query.js.map +1 -0
  141. package/dist/reasoning/lemma-rag/retrieval.d.ts +33 -0
  142. package/dist/reasoning/lemma-rag/retrieval.d.ts.map +1 -0
  143. package/dist/reasoning/lemma-rag/retrieval.js +123 -0
  144. package/dist/reasoning/lemma-rag/retrieval.js.map +1 -0
  145. package/dist/reasoning/lemma-rag/types.d.ts +52 -0
  146. package/dist/reasoning/lemma-rag/types.d.ts.map +1 -0
  147. package/dist/reasoning/lemma-rag/types.js +13 -0
  148. package/dist/reasoning/lemma-rag/types.js.map +1 -0
  149. package/dist/reasoning/proof-mining/__tests__/extractor.test.d.ts +2 -0
  150. package/dist/reasoning/proof-mining/__tests__/extractor.test.d.ts.map +1 -0
  151. package/dist/reasoning/proof-mining/__tests__/extractor.test.js +263 -0
  152. package/dist/reasoning/proof-mining/__tests__/extractor.test.js.map +1 -0
  153. package/dist/reasoning/proof-mining/__tests__/generalizer.test.d.ts +2 -0
  154. package/dist/reasoning/proof-mining/__tests__/generalizer.test.d.ts.map +1 -0
  155. package/dist/reasoning/proof-mining/__tests__/generalizer.test.js +123 -0
  156. package/dist/reasoning/proof-mining/__tests__/generalizer.test.js.map +1 -0
  157. package/dist/reasoning/proof-mining/__tests__/integration.test.d.ts +2 -0
  158. package/dist/reasoning/proof-mining/__tests__/integration.test.d.ts.map +1 -0
  159. package/dist/reasoning/proof-mining/__tests__/integration.test.js +128 -0
  160. package/dist/reasoning/proof-mining/__tests__/integration.test.js.map +1 -0
  161. package/dist/reasoning/proof-mining/__tests__/persistence.test.d.ts +2 -0
  162. package/dist/reasoning/proof-mining/__tests__/persistence.test.d.ts.map +1 -0
  163. package/dist/reasoning/proof-mining/__tests__/persistence.test.js +119 -0
  164. package/dist/reasoning/proof-mining/__tests__/persistence.test.js.map +1 -0
  165. package/dist/reasoning/proof-mining/__tests__/ranker.test.d.ts +2 -0
  166. package/dist/reasoning/proof-mining/__tests__/ranker.test.d.ts.map +1 -0
  167. package/dist/reasoning/proof-mining/__tests__/ranker.test.js +93 -0
  168. package/dist/reasoning/proof-mining/__tests__/ranker.test.js.map +1 -0
  169. package/dist/reasoning/proof-mining/extractor.d.ts +73 -0
  170. package/dist/reasoning/proof-mining/extractor.d.ts.map +1 -0
  171. package/dist/reasoning/proof-mining/extractor.js +170 -0
  172. package/dist/reasoning/proof-mining/extractor.js.map +1 -0
  173. package/dist/reasoning/proof-mining/generalizer.d.ts +46 -0
  174. package/dist/reasoning/proof-mining/generalizer.d.ts.map +1 -0
  175. package/dist/reasoning/proof-mining/generalizer.js +245 -0
  176. package/dist/reasoning/proof-mining/generalizer.js.map +1 -0
  177. package/dist/reasoning/proof-mining/index.d.ts +62 -0
  178. package/dist/reasoning/proof-mining/index.d.ts.map +1 -0
  179. package/dist/reasoning/proof-mining/index.js +235 -0
  180. package/dist/reasoning/proof-mining/index.js.map +1 -0
  181. package/dist/reasoning/proof-mining/persistence.d.ts +35 -0
  182. package/dist/reasoning/proof-mining/persistence.d.ts.map +1 -0
  183. package/dist/reasoning/proof-mining/persistence.js +126 -0
  184. package/dist/reasoning/proof-mining/persistence.js.map +1 -0
  185. package/dist/reasoning/proof-mining/ranker.d.ts +29 -0
  186. package/dist/reasoning/proof-mining/ranker.d.ts.map +1 -0
  187. package/dist/reasoning/proof-mining/ranker.js +71 -0
  188. package/dist/reasoning/proof-mining/ranker.js.map +1 -0
  189. package/dist/reasoning/proof-mining/statistics.d.ts +11 -0
  190. package/dist/reasoning/proof-mining/statistics.d.ts.map +1 -0
  191. package/dist/reasoning/proof-mining/statistics.js +44 -0
  192. package/dist/reasoning/proof-mining/statistics.js.map +1 -0
  193. package/dist/reasoning/proof-mining/types.d.ts +117 -0
  194. package/dist/reasoning/proof-mining/types.d.ts.map +1 -0
  195. package/dist/reasoning/proof-mining/types.js +24 -0
  196. package/dist/reasoning/proof-mining/types.js.map +1 -0
  197. package/package.json +31 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generalizer.test.js","sourceRoot":"","sources":["../../../../src/reasoning/proof-mining/__tests__/generalizer.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=integration.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"integration.test.d.ts","sourceRoot":"","sources":["../../../../src/reasoning/proof-mining/__tests__/integration.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,128 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const vitest_1 = require("vitest");
4
+ const theorem_cache_1 = require("../../../runtime/theorem-cache");
5
+ const index_1 = require("../index");
6
+ function reflexivityProof(id, atom) {
7
+ return {
8
+ id,
9
+ conclusion: `${atom} -> ${atom}`,
10
+ premises: [],
11
+ profile: 'classical',
12
+ cost: 12,
13
+ steps: [
14
+ // sub-tree raíz: implIntro con un assume.
15
+ { rule: 'implIntro', inputs: [atom], output: `${atom} -> ${atom}`, depth: 0 },
16
+ { rule: 'assume', inputs: [], output: atom, depth: 1 },
17
+ ],
18
+ };
19
+ }
20
+ function conjunctionProof(id, l, r) {
21
+ return {
22
+ id,
23
+ conclusion: `${l} and ${r}`,
24
+ premises: [l, r],
25
+ profile: 'classical',
26
+ cost: 20,
27
+ steps: [
28
+ { rule: 'andI', inputs: [l, r], output: `${l} and ${r}`, depth: 0 },
29
+ { rule: 'assume', inputs: [], output: l, depth: 1 },
30
+ { rule: 'assume', inputs: [], output: r, depth: 1 },
31
+ ],
32
+ };
33
+ }
34
+ (0, vitest_1.describe)('mineLemmas — pipeline end-to-end', () => {
35
+ (0, vitest_1.it)('extrae el lemma de reflexividad cuando aparece en múltiples proofs', () => {
36
+ const corpus = [
37
+ reflexivityProof('p1', 'P'),
38
+ reflexivityProof('p2', 'Q'),
39
+ reflexivityProof('p3', 'R'),
40
+ ];
41
+ const { lemmas, stats } = (0, index_1.mineLemmas)(corpus);
42
+ (0, vitest_1.expect)(lemmas.length).toBeGreaterThan(0);
43
+ (0, vitest_1.expect)(stats.proofsAnalyzed).toBe(3);
44
+ (0, vitest_1.expect)(stats.lemmasExtracted).toBeGreaterThan(0);
45
+ // Al menos un lemma debería tener usageCount = 3.
46
+ const trio = lemmas.find((l) => l.usageCount === 3);
47
+ (0, vitest_1.expect)(trio).toBeDefined();
48
+ });
49
+ (0, vitest_1.it)('rankea por savings: el lemma más reusado va primero', () => {
50
+ const corpus = [
51
+ reflexivityProof('p1', 'P'),
52
+ reflexivityProof('p2', 'Q'),
53
+ reflexivityProof('p3', 'R'),
54
+ conjunctionProof('p4', 'A', 'B'),
55
+ conjunctionProof('p5', 'C', 'D'),
56
+ ];
57
+ const { lemmas } = (0, index_1.mineLemmas)(corpus);
58
+ (0, vitest_1.expect)(lemmas.length).toBeGreaterThan(0);
59
+ // El primero debería tener usageCount alto.
60
+ (0, vitest_1.expect)(lemmas[0]?.usageCount).toBeGreaterThanOrEqual(2);
61
+ });
62
+ (0, vitest_1.it)('persiste lemmas en el cache cuando se pasa la opción', () => {
63
+ const cache = new theorem_cache_1.TheoremCache();
64
+ const corpus = [
65
+ reflexivityProof('p1', 'P'),
66
+ reflexivityProof('p2', 'Q'),
67
+ ];
68
+ const { lemmas } = (0, index_1.mineLemmas)(corpus, { cache });
69
+ (0, vitest_1.expect)(lemmas.length).toBeGreaterThan(0);
70
+ (0, vitest_1.expect)(cache.stats().entries).toBeGreaterThan(0);
71
+ });
72
+ (0, vitest_1.it)('savings = cost_subproof × (usageCount - 1)', () => {
73
+ const corpus = [
74
+ reflexivityProof('p1', 'P'),
75
+ reflexivityProof('p2', 'Q'),
76
+ ];
77
+ const { lemmas } = (0, index_1.mineLemmas)(corpus);
78
+ const trio = lemmas.find((l) => l.usageCount === 2);
79
+ (0, vitest_1.expect)(trio).toBeDefined();
80
+ // El sub-tree raíz tiene 2 pasos del proof de cost 12: cost prorrateado
81
+ // = 12 × (2/2) = 12. usageCount=2 ⇒ savings = 12 × 1 = 12.
82
+ (0, vitest_1.expect)(trio?.savings).toBeGreaterThan(0);
83
+ });
84
+ });
85
+ (0, vitest_1.describe)('ProofMiner — fachada stateful', () => {
86
+ let miner;
87
+ (0, vitest_1.beforeEach)(() => {
88
+ miner = new index_1.ProofMiner();
89
+ });
90
+ (0, vitest_1.it)('acumula lemmas entre batches', () => {
91
+ miner.mine([reflexivityProof('p1', 'P'), reflexivityProof('p2', 'Q')]);
92
+ const after1 = miner.all().length;
93
+ miner.mine([reflexivityProof('p3', 'R'), reflexivityProof('p4', 'S')]);
94
+ const after2 = miner.all().length;
95
+ (0, vitest_1.expect)(after2).toBeGreaterThanOrEqual(after1);
96
+ });
97
+ (0, vitest_1.it)('mergea usageCount cuando el mismo lemma aparece en batches distintos', () => {
98
+ miner.mine([reflexivityProof('p1', 'P'), reflexivityProof('p2', 'Q')]);
99
+ miner.mine([reflexivityProof('p3', 'R'), reflexivityProof('p4', 'S')]);
100
+ // Algún lemma debería tener usageCount >= 4 (suma de batches).
101
+ const allUsages = miner.all().map((l) => l.usageCount);
102
+ (0, vitest_1.expect)(Math.max(...allUsages)).toBeGreaterThanOrEqual(4);
103
+ });
104
+ (0, vitest_1.it)('clear() resetea el estado', () => {
105
+ miner.mine([reflexivityProof('p1', 'P'), reflexivityProof('p2', 'Q')]);
106
+ miner.clear();
107
+ (0, vitest_1.expect)(miner.all()).toHaveLength(0);
108
+ (0, vitest_1.expect)(miner.stats().proofsAnalyzed).toBe(0);
109
+ });
110
+ (0, vitest_1.it)('top(k) devuelve los k mejores', () => {
111
+ miner.mine([
112
+ reflexivityProof('p1', 'P'),
113
+ reflexivityProof('p2', 'Q'),
114
+ conjunctionProof('p3', 'A', 'B'),
115
+ conjunctionProof('p4', 'C', 'D'),
116
+ ]);
117
+ const top1 = miner.top(1);
118
+ (0, vitest_1.expect)(top1.length).toBeLessThanOrEqual(1);
119
+ });
120
+ (0, vitest_1.it)('cache compartido: getCache devuelve la instancia interna', () => {
121
+ const cache = new theorem_cache_1.TheoremCache();
122
+ const m = new index_1.ProofMiner({ cache });
123
+ m.mine([reflexivityProof('p1', 'P'), reflexivityProof('p2', 'Q')]);
124
+ (0, vitest_1.expect)(m.getCache()).toBe(cache);
125
+ (0, vitest_1.expect)(cache.stats().entries).toBeGreaterThan(0);
126
+ });
127
+ });
128
+ //# sourceMappingURL=integration.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"integration.test.js","sourceRoot":"","sources":["../../../../src/reasoning/proof-mining/__tests__/integration.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=persistence.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"persistence.test.d.ts","sourceRoot":"","sources":["../../../../src/reasoning/proof-mining/__tests__/persistence.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,119 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const vitest_1 = require("vitest");
4
+ const theorem_cache_1 = require("../../../runtime/theorem-cache");
5
+ const persistence_1 = require("../persistence");
6
+ function mkProof(profile = 'classical', cost = 10) {
7
+ return {
8
+ conclusion: 'P -> P',
9
+ premises: ['P'],
10
+ profile,
11
+ cost,
12
+ steps: [
13
+ { rule: 'MP', inputs: ['P->P', 'P'], output: 'P', depth: 0 },
14
+ { rule: 'axiom', inputs: [], output: 'P->P', depth: 1 },
15
+ { rule: 'axiom', inputs: [], output: 'P', depth: 1 },
16
+ ],
17
+ };
18
+ }
19
+ function mkLemma(id, statement, profile = 'classical') {
20
+ return {
21
+ id,
22
+ statement,
23
+ proof: mkProof(profile),
24
+ abstractionLevel: 1,
25
+ usageCount: 3,
26
+ savings: 27,
27
+ sourceProofs: ['proof-0', 'proof-1', 'proof-2'],
28
+ };
29
+ }
30
+ (0, vitest_1.describe)('persistLemmas', () => {
31
+ let cache;
32
+ (0, vitest_1.beforeEach)(() => {
33
+ cache = new theorem_cache_1.TheoremCache();
34
+ });
35
+ (0, vitest_1.it)('guarda un lemma y retorna su id', () => {
36
+ const lemma = mkLemma('l1', '?0 -> ?0');
37
+ const ids = (0, persistence_1.persistLemmas)([lemma], cache, () => 1717171717171);
38
+ (0, vitest_1.expect)(ids).toHaveLength(1);
39
+ (0, vitest_1.expect)(typeof ids[0]).toBe('string');
40
+ });
41
+ (0, vitest_1.it)('marca el lemma con provedBy = proof-mining', () => {
42
+ const lemma = mkLemma('l1', '?0 -> ?0');
43
+ (0, persistence_1.persistLemmas)([lemma], cache);
44
+ const th = cache.retrieve('?0 -> ?0', 'classical');
45
+ (0, vitest_1.expect)(th?.metadata.provedBy).toBe(persistence_1.MINED_LEMMA_PROVER);
46
+ });
47
+ (0, vitest_1.it)('guarda múltiples lemmas en batch', () => {
48
+ const lemmas = [
49
+ mkLemma('a', '?0 -> ?0'),
50
+ mkLemma('b', '?0 and ?1'),
51
+ mkLemma('c', '?0 or ?1'),
52
+ ];
53
+ const ids = (0, persistence_1.persistLemmas)(lemmas, cache);
54
+ (0, vitest_1.expect)(ids).toHaveLength(3);
55
+ (0, vitest_1.expect)(cache.stats().entries).toBe(3);
56
+ });
57
+ });
58
+ (0, vitest_1.describe)('recoverLemmaFromCache', () => {
59
+ (0, vitest_1.it)('devuelve undefined si la entry no es un mined lemma', () => {
60
+ const cache = new theorem_cache_1.TheoremCache();
61
+ const id = cache.store({
62
+ formula: 'P -> P',
63
+ normalizedFormula: '?0 -> ?0',
64
+ profile: 'classical',
65
+ proof: 'axiom',
66
+ metadata: {
67
+ provedAt: new Date().toISOString(),
68
+ ms: 5,
69
+ provedBy: 'other-prover',
70
+ },
71
+ });
72
+ const th = cache.retrieve('P -> P', 'classical');
73
+ (0, vitest_1.expect)(th).toBeDefined();
74
+ (0, vitest_1.expect)((0, persistence_1.recoverLemmaFromCache)(th)).toBeUndefined();
75
+ (0, vitest_1.expect)(id).toBeDefined();
76
+ });
77
+ (0, vitest_1.it)('reconstruye un MinedLemma desde el cache', () => {
78
+ const cache = new theorem_cache_1.TheoremCache();
79
+ const lemma = mkLemma('l1', '?0 -> ?0');
80
+ (0, persistence_1.persistLemmas)([lemma], cache);
81
+ const th = cache.retrieve('?0 -> ?0', 'classical');
82
+ (0, vitest_1.expect)(th).toBeDefined();
83
+ const recovered = (0, persistence_1.recoverLemmaFromCache)(th);
84
+ (0, vitest_1.expect)(recovered).toBeDefined();
85
+ (0, vitest_1.expect)(recovered?.statement).toBe('?0 -> ?0');
86
+ (0, vitest_1.expect)(recovered?.usageCount).toBe(3);
87
+ (0, vitest_1.expect)(recovered?.savings).toBe(27);
88
+ (0, vitest_1.expect)(recovered?.abstractionLevel).toBe(1);
89
+ });
90
+ });
91
+ (0, vitest_1.describe)('recoverLemmas', () => {
92
+ (0, vitest_1.it)('recupera múltiples lemmas dada la lista de statements esperados', () => {
93
+ const cache = new theorem_cache_1.TheoremCache();
94
+ const lemmas = [
95
+ mkLemma('a', '?0 -> ?0'),
96
+ mkLemma('b', '?0 and ?1'),
97
+ ];
98
+ (0, persistence_1.persistLemmas)(lemmas, cache);
99
+ const recovered = (0, persistence_1.recoverLemmas)(cache, [
100
+ { statement: '?0 -> ?0', profile: 'classical' },
101
+ { statement: '?0 and ?1', profile: 'classical' },
102
+ { statement: 'inexistente', profile: 'classical' },
103
+ ]);
104
+ (0, vitest_1.expect)(recovered).toHaveLength(2);
105
+ });
106
+ (0, vitest_1.it)('round-trip: persist + recover preserva datos clave', () => {
107
+ const cache = new theorem_cache_1.TheoremCache();
108
+ const original = mkLemma('a', '?0 -> ?0');
109
+ (0, persistence_1.persistLemmas)([original], cache);
110
+ const [recovered] = (0, persistence_1.recoverLemmas)(cache, [
111
+ { statement: '?0 -> ?0', profile: 'classical' },
112
+ ]);
113
+ (0, vitest_1.expect)(recovered).toBeDefined();
114
+ (0, vitest_1.expect)(recovered?.usageCount).toBe(original.usageCount);
115
+ (0, vitest_1.expect)(recovered?.savings).toBe(original.savings);
116
+ (0, vitest_1.expect)(recovered?.sourceProofs).toEqual(original.sourceProofs);
117
+ });
118
+ });
119
+ //# sourceMappingURL=persistence.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"persistence.test.js","sourceRoot":"","sources":["../../../../src/reasoning/proof-mining/__tests__/persistence.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=ranker.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ranker.test.d.ts","sourceRoot":"","sources":["../../../../src/reasoning/proof-mining/__tests__/ranker.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,93 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const vitest_1 = require("vitest");
4
+ const ranker_1 = require("../ranker");
5
+ function mkProof(profile = 'classical') {
6
+ return {
7
+ conclusion: 'X',
8
+ premises: [],
9
+ profile,
10
+ cost: 10,
11
+ steps: [{ rule: 'r', inputs: [], output: 'X', depth: 0 }],
12
+ };
13
+ }
14
+ function mkLemma(id, opts) {
15
+ return {
16
+ id,
17
+ statement: `lemma-${id}`,
18
+ proof: mkProof(),
19
+ abstractionLevel: opts.abstraction,
20
+ usageCount: opts.usage,
21
+ savings: opts.savings,
22
+ sourceProofs: [],
23
+ };
24
+ }
25
+ (0, vitest_1.describe)('scoreLemma', () => {
26
+ (0, vitest_1.it)('score aumenta con savings', () => {
27
+ const a = mkLemma('a', { usage: 1, savings: 0, abstraction: 0 });
28
+ const b = mkLemma('b', { usage: 1, savings: 100, abstraction: 0 });
29
+ (0, vitest_1.expect)((0, ranker_1.scoreLemma)(b)).toBeGreaterThan((0, ranker_1.scoreLemma)(a));
30
+ });
31
+ (0, vitest_1.it)('score aumenta con usageCount', () => {
32
+ const a = mkLemma('a', { usage: 2, savings: 10, abstraction: 0 });
33
+ const b = mkLemma('b', { usage: 20, savings: 10, abstraction: 0 });
34
+ (0, vitest_1.expect)((0, ranker_1.scoreLemma)(b)).toBeGreaterThan((0, ranker_1.scoreLemma)(a));
35
+ });
36
+ (0, vitest_1.it)('score aumenta con abstractionLevel', () => {
37
+ const a = mkLemma('a', { usage: 2, savings: 10, abstraction: 0 });
38
+ const b = mkLemma('b', { usage: 2, savings: 10, abstraction: 3 });
39
+ (0, vitest_1.expect)((0, ranker_1.scoreLemma)(b)).toBeGreaterThan((0, ranker_1.scoreLemma)(a));
40
+ });
41
+ (0, vitest_1.it)('weights override default', () => {
42
+ const lemma = mkLemma('a', { usage: 1, savings: 0, abstraction: 10 });
43
+ const baseScore = (0, ranker_1.scoreLemma)(lemma);
44
+ const boosted = (0, ranker_1.scoreLemma)(lemma, { generality: 1 });
45
+ (0, vitest_1.expect)(boosted).toBeGreaterThan(baseScore);
46
+ });
47
+ });
48
+ (0, vitest_1.describe)('rankLemmas', () => {
49
+ (0, vitest_1.it)('ordena descendente por score', () => {
50
+ const a = mkLemma('a', { usage: 1, savings: 0, abstraction: 0 });
51
+ const b = mkLemma('b', { usage: 10, savings: 100, abstraction: 2 });
52
+ const c = mkLemma('c', { usage: 5, savings: 50, abstraction: 1 });
53
+ const ranked = (0, ranker_1.rankLemmas)([a, b, c]);
54
+ (0, vitest_1.expect)(ranked[0]?.id).toBe('b');
55
+ (0, vitest_1.expect)(ranked[2]?.id).toBe('a');
56
+ });
57
+ (0, vitest_1.it)('en empate de score, mayor usageCount gana', () => {
58
+ const x = mkLemma('x', { usage: 5, savings: 10, abstraction: 1 });
59
+ const y = mkLemma('y', { usage: 5, savings: 10, abstraction: 1 });
60
+ const ranked = (0, ranker_1.rankLemmas)([x, y]);
61
+ // Misma score → orden por id asc (determinismo)
62
+ (0, vitest_1.expect)(ranked[0]?.id).toBe('x');
63
+ });
64
+ (0, vitest_1.it)('no muta el array original', () => {
65
+ const a = mkLemma('a', { usage: 1, savings: 0, abstraction: 0 });
66
+ const b = mkLemma('b', { usage: 10, savings: 100, abstraction: 2 });
67
+ const input = [a, b];
68
+ (0, ranker_1.rankLemmas)(input);
69
+ (0, vitest_1.expect)(input[0]?.id).toBe('a');
70
+ (0, vitest_1.expect)(input[1]?.id).toBe('b');
71
+ });
72
+ });
73
+ (0, vitest_1.describe)('topK', () => {
74
+ (0, vitest_1.it)('devuelve los primeros K', () => {
75
+ const lemmas = Array.from({ length: 10 }, (_, i) => mkLemma(`l${i}`, { usage: i, savings: i * 10, abstraction: 0 }));
76
+ const top3 = (0, ranker_1.topK)(lemmas, 3);
77
+ (0, vitest_1.expect)(top3).toHaveLength(3);
78
+ // El de mayor usage/savings (l9) debe estar primero.
79
+ (0, vitest_1.expect)(top3[0]?.id).toBe('l9');
80
+ });
81
+ (0, vitest_1.it)('K = 0 devuelve array vacío', () => {
82
+ const lemmas = [mkLemma('a', { usage: 1, savings: 0, abstraction: 0 })];
83
+ (0, vitest_1.expect)((0, ranker_1.topK)(lemmas, 0)).toHaveLength(0);
84
+ });
85
+ (0, vitest_1.it)('K mayor que la lista devuelve toda la lista', () => {
86
+ const lemmas = [
87
+ mkLemma('a', { usage: 1, savings: 0, abstraction: 0 }),
88
+ mkLemma('b', { usage: 2, savings: 0, abstraction: 0 }),
89
+ ];
90
+ (0, vitest_1.expect)((0, ranker_1.topK)(lemmas, 100)).toHaveLength(2);
91
+ });
92
+ });
93
+ //# sourceMappingURL=ranker.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ranker.test.js","sourceRoot":"","sources":["../../../../src/reasoning/proof-mining/__tests__/ranker.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,73 @@
1
+ import type { ProofStep, ProofTrace } from './types';
2
+ /**
3
+ * Un sub-tree candidato extraído de un proof, antes de pasar a
4
+ * generalización/ranking.
5
+ */
6
+ export interface SubtreeCandidate {
7
+ /** ID del proof origen. */
8
+ proofId: string;
9
+ /** Posición del paso raíz en `steps`. */
10
+ rootIndex: number;
11
+ /** Pasos que componen el sub-tree (en orden top-down). */
12
+ steps: ProofStep[];
13
+ /** Conclusión del sub-tree (= output del paso raíz). */
14
+ conclusion: string;
15
+ /** Profile del proof origen. */
16
+ profile: string;
17
+ /** Cost asignado (igual al cost del proof original prorrateado). */
18
+ cost: number;
19
+ }
20
+ /**
21
+ * Agrupación de sub-trees estructuralmente equivalentes.
22
+ */
23
+ export interface SubtreeGroup {
24
+ /** Hash α-canónico común. */
25
+ key: string;
26
+ /** Conclusión canónica representativa. */
27
+ canonicalConclusion: string;
28
+ /** Sub-trees miembros del grupo. */
29
+ members: SubtreeCandidate[];
30
+ }
31
+ /**
32
+ * Descompone un proof en sub-trees a partir de cada paso. El
33
+ * sub-tree con raíz en `i` incluye `steps[i]` y todos los
34
+ * descendientes consecutivos (depth > steps[i].depth) hasta que
35
+ * vuelve a aparecer un paso de depth ≤ steps[i].depth.
36
+ *
37
+ * Para steps[i] con depth d_i, el sub-tree es:
38
+ * steps[i], steps[i+1], …, steps[j-1]
39
+ * donde j es el menor índice > i con steps[j].depth ≤ d_i (o
40
+ * length si no existe).
41
+ */
42
+ export declare function extractSubtrees(proof: ProofTrace, proofId: string): SubtreeCandidate[];
43
+ /**
44
+ * Clave estructural canónica de un sub-tree.
45
+ *
46
+ * Combina: secuencia de reglas (por orden top-down) + diferencias
47
+ * relativas de depth (para reconstruir forma del árbol) + outputs
48
+ * normalizados α-canónicamente.
49
+ *
50
+ * El canónico depende del orden de aparición de los identificadores
51
+ * de cada output, lo que da un hash estable módulo renombrado de
52
+ * variables.
53
+ */
54
+ export declare function subtreeKey(sub: SubtreeCandidate): string;
55
+ /**
56
+ * Agrupa sub-trees por clave estructural canónica.
57
+ */
58
+ export declare function groupSubtrees(candidates: SubtreeCandidate[]): SubtreeGroup[];
59
+ /**
60
+ * Identifica sub-pruebas auxiliares en el corpus. Recibe un array
61
+ * de proofs, devuelve los grupos de sub-trees estructuralmente
62
+ * equivalentes que pasan los filtros (minReuseThreshold y
63
+ * minSubtreeSize).
64
+ *
65
+ * Esta función NO genera lemmas todavía — solo identifica los
66
+ * candidatos. `mineLemmas` los procesa, genera el statement y los
67
+ * persiste.
68
+ */
69
+ export declare function extractAuxiliaryLemmas(corpus: ProofTrace[], options?: {
70
+ minReuseThreshold?: number;
71
+ minSubtreeSize?: number;
72
+ }): SubtreeGroup[];
73
+ //# sourceMappingURL=extractor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extractor.d.ts","sourceRoot":"","sources":["../../../src/reasoning/proof-mining/extractor.ts"],"names":[],"mappings":"AAyBA,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErD;;;GAGG;AACH,MAAM,WAAW,gBAAgB;IAC/B,2BAA2B;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,yCAAyC;IACzC,SAAS,EAAE,MAAM,CAAC;IAClB,0DAA0D;IAC1D,KAAK,EAAE,SAAS,EAAE,CAAC;IACnB,wDAAwD;IACxD,UAAU,EAAE,MAAM,CAAC;IACnB,gCAAgC;IAChC,OAAO,EAAE,MAAM,CAAC;IAChB,oEAAoE;IACpE,IAAI,EAAE,MAAM,CAAC;CACd;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,6BAA6B;IAC7B,GAAG,EAAE,MAAM,CAAC;IACZ,0CAA0C;IAC1C,mBAAmB,EAAE,MAAM,CAAC;IAC5B,oCAAoC;IACpC,OAAO,EAAE,gBAAgB,EAAE,CAAC;CAC7B;AAMD;;;;;;;;;;GAUG;AACH,wBAAgB,eAAe,CAAC,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,GAAG,gBAAgB,EAAE,CA8BtF;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,UAAU,CAAC,GAAG,EAAE,gBAAgB,GAAG,MAAM,CAoBxD;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,UAAU,EAAE,gBAAgB,EAAE,GAAG,YAAY,EAAE,CAgB5E;AAED;;;;;;;;;GASG;AACH,wBAAgB,sBAAsB,CACpC,MAAM,EAAE,UAAU,EAAE,EACpB,OAAO,CAAC,EAAE;IAAE,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAAC,cAAc,CAAC,EAAE,MAAM,CAAA;CAAE,GAChE,YAAY,EAAE,CA2BhB"}