@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.
- package/dist/format/stnb/__tests__/executor.test.d.ts +2 -0
- package/dist/format/stnb/__tests__/executor.test.d.ts.map +1 -0
- package/dist/format/stnb/__tests__/executor.test.js +140 -0
- package/dist/format/stnb/__tests__/executor.test.js.map +1 -0
- package/dist/format/stnb/__tests__/parser.test.d.ts +2 -0
- package/dist/format/stnb/__tests__/parser.test.d.ts.map +1 -0
- package/dist/format/stnb/__tests__/parser.test.js +119 -0
- package/dist/format/stnb/__tests__/parser.test.js.map +1 -0
- package/dist/format/stnb/__tests__/renderer.test.d.ts +2 -0
- package/dist/format/stnb/__tests__/renderer.test.d.ts.map +1 -0
- package/dist/format/stnb/__tests__/renderer.test.js +109 -0
- package/dist/format/stnb/__tests__/renderer.test.js.map +1 -0
- package/dist/format/stnb/__tests__/roundtrip.test.d.ts +2 -0
- package/dist/format/stnb/__tests__/roundtrip.test.d.ts.map +1 -0
- package/dist/format/stnb/__tests__/roundtrip.test.js +91 -0
- package/dist/format/stnb/__tests__/roundtrip.test.js.map +1 -0
- package/dist/format/stnb/__tests__/serializer.test.d.ts +2 -0
- package/dist/format/stnb/__tests__/serializer.test.d.ts.map +1 -0
- package/dist/format/stnb/__tests__/serializer.test.js +60 -0
- package/dist/format/stnb/__tests__/serializer.test.js.map +1 -0
- package/dist/format/stnb/executor.d.ts +29 -0
- package/dist/format/stnb/executor.d.ts.map +1 -0
- package/dist/format/stnb/executor.js +139 -0
- package/dist/format/stnb/executor.js.map +1 -0
- package/dist/format/stnb/index.d.ts +19 -0
- package/dist/format/stnb/index.d.ts.map +1 -0
- package/dist/format/stnb/index.js +28 -0
- package/dist/format/stnb/index.js.map +1 -0
- package/dist/format/stnb/renderer-html.d.ts +11 -0
- package/dist/format/stnb/renderer-html.d.ts.map +1 -0
- package/dist/format/stnb/renderer-html.js +180 -0
- package/dist/format/stnb/renderer-html.js.map +1 -0
- package/dist/format/stnb/renderer-markdown.d.ts +13 -0
- package/dist/format/stnb/renderer-markdown.d.ts.map +1 -0
- package/dist/format/stnb/renderer-markdown.js +92 -0
- package/dist/format/stnb/renderer-markdown.js.map +1 -0
- package/dist/format/stnb/serializer.d.ts +14 -0
- package/dist/format/stnb/serializer.d.ts.map +1 -0
- package/dist/format/stnb/serializer.js +21 -0
- package/dist/format/stnb/serializer.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +8 -1
- package/dist/index.js.map +1 -1
- package/dist/logic/profiles/dl-hybrid/__tests__/differential.test.d.ts +2 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/differential.test.d.ts.map +1 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/differential.test.js +141 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/differential.test.js.map +1 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/examples.test.d.ts +2 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/examples.test.d.ts.map +1 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/examples.test.js +55 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/examples.test.js.map +1 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/parser.test.d.ts +2 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/parser.test.d.ts.map +1 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/parser.test.js +149 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/parser.test.js.map +1 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/tableau.test.d.ts +2 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/tableau.test.d.ts.map +1 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/tableau.test.js +105 -0
- package/dist/logic/profiles/dl-hybrid/__tests__/tableau.test.js.map +1 -0
- package/dist/logic/profiles/dl-hybrid/ast.d.ts +160 -0
- package/dist/logic/profiles/dl-hybrid/ast.d.ts.map +1 -0
- package/dist/logic/profiles/dl-hybrid/ast.js +261 -0
- package/dist/logic/profiles/dl-hybrid/ast.js.map +1 -0
- package/dist/logic/profiles/dl-hybrid/differential.d.ts +61 -0
- package/dist/logic/profiles/dl-hybrid/differential.d.ts.map +1 -0
- package/dist/logic/profiles/dl-hybrid/differential.js +291 -0
- package/dist/logic/profiles/dl-hybrid/differential.js.map +1 -0
- package/dist/logic/profiles/dl-hybrid/index.d.ts +10 -0
- package/dist/logic/profiles/dl-hybrid/index.d.ts.map +1 -0
- package/dist/logic/profiles/dl-hybrid/index.js +90 -0
- package/dist/logic/profiles/dl-hybrid/index.js.map +1 -0
- package/dist/logic/profiles/dl-hybrid/parser.d.ts +8 -0
- package/dist/logic/profiles/dl-hybrid/parser.d.ts.map +1 -0
- package/dist/logic/profiles/dl-hybrid/parser.js +410 -0
- package/dist/logic/profiles/dl-hybrid/parser.js.map +1 -0
- package/dist/logic/profiles/dl-hybrid/profile.d.ts +23 -0
- package/dist/logic/profiles/dl-hybrid/profile.d.ts.map +1 -0
- package/dist/logic/profiles/dl-hybrid/profile.js +122 -0
- package/dist/logic/profiles/dl-hybrid/profile.js.map +1 -0
- package/dist/logic/profiles/dl-hybrid/semantics.d.ts +16 -0
- package/dist/logic/profiles/dl-hybrid/semantics.d.ts.map +1 -0
- package/dist/logic/profiles/dl-hybrid/semantics.js +181 -0
- package/dist/logic/profiles/dl-hybrid/semantics.js.map +1 -0
- package/dist/logic/profiles/dl-hybrid/tableau.d.ts +38 -0
- package/dist/logic/profiles/dl-hybrid/tableau.d.ts.map +1 -0
- package/dist/logic/profiles/dl-hybrid/tableau.js +289 -0
- package/dist/logic/profiles/dl-hybrid/tableau.js.map +1 -0
- package/dist/reasoning/dl-hybrid/__tests__/invariant.test.d.ts +2 -0
- package/dist/reasoning/dl-hybrid/__tests__/invariant.test.d.ts.map +1 -0
- package/dist/reasoning/dl-hybrid/__tests__/invariant.test.js +74 -0
- package/dist/reasoning/dl-hybrid/__tests__/invariant.test.js.map +1 -0
- package/dist/reasoning/dl-hybrid/index.d.ts +3 -0
- package/dist/reasoning/dl-hybrid/index.d.ts.map +1 -0
- package/dist/reasoning/dl-hybrid/index.js +16 -0
- package/dist/reasoning/dl-hybrid/index.js.map +1 -0
- package/dist/reasoning/dl-hybrid/invariant-search.d.ts +39 -0
- package/dist/reasoning/dl-hybrid/invariant-search.d.ts.map +1 -0
- package/dist/reasoning/dl-hybrid/invariant-search.js +188 -0
- package/dist/reasoning/dl-hybrid/invariant-search.js.map +1 -0
- package/dist/reasoning/lemma-rag/__tests__/benchmarks.test.d.ts +2 -0
- package/dist/reasoning/lemma-rag/__tests__/benchmarks.test.d.ts.map +1 -0
- package/dist/reasoning/lemma-rag/__tests__/benchmarks.test.js +72 -0
- package/dist/reasoning/lemma-rag/__tests__/benchmarks.test.js.map +1 -0
- package/dist/reasoning/lemma-rag/__tests__/embedding.test.d.ts +2 -0
- package/dist/reasoning/lemma-rag/__tests__/embedding.test.d.ts.map +1 -0
- package/dist/reasoning/lemma-rag/__tests__/embedding.test.js +102 -0
- package/dist/reasoning/lemma-rag/__tests__/embedding.test.js.map +1 -0
- package/dist/reasoning/lemma-rag/__tests__/integration.test.d.ts +2 -0
- package/dist/reasoning/lemma-rag/__tests__/integration.test.d.ts.map +1 -0
- package/dist/reasoning/lemma-rag/__tests__/integration.test.js +40 -0
- package/dist/reasoning/lemma-rag/__tests__/integration.test.js.map +1 -0
- package/dist/reasoning/lemma-rag/__tests__/query.test.d.ts +2 -0
- package/dist/reasoning/lemma-rag/__tests__/query.test.d.ts.map +1 -0
- package/dist/reasoning/lemma-rag/__tests__/query.test.js +136 -0
- package/dist/reasoning/lemma-rag/__tests__/query.test.js.map +1 -0
- package/dist/reasoning/lemma-rag/__tests__/retrieval.test.d.ts +2 -0
- package/dist/reasoning/lemma-rag/__tests__/retrieval.test.d.ts.map +1 -0
- package/dist/reasoning/lemma-rag/__tests__/retrieval.test.js +147 -0
- package/dist/reasoning/lemma-rag/__tests__/retrieval.test.js.map +1 -0
- package/dist/reasoning/lemma-rag/benchmarks.d.ts +30 -0
- package/dist/reasoning/lemma-rag/benchmarks.d.ts.map +1 -0
- package/dist/reasoning/lemma-rag/benchmarks.js +177 -0
- package/dist/reasoning/lemma-rag/benchmarks.js.map +1 -0
- package/dist/reasoning/lemma-rag/embedding.d.ts +26 -0
- package/dist/reasoning/lemma-rag/embedding.d.ts.map +1 -0
- package/dist/reasoning/lemma-rag/embedding.js +243 -0
- package/dist/reasoning/lemma-rag/embedding.js.map +1 -0
- package/dist/reasoning/lemma-rag/index-store.d.ts +35 -0
- package/dist/reasoning/lemma-rag/index-store.d.ts.map +1 -0
- package/dist/reasoning/lemma-rag/index-store.js +105 -0
- package/dist/reasoning/lemma-rag/index-store.js.map +1 -0
- package/dist/reasoning/lemma-rag/index.d.ts +9 -0
- package/dist/reasoning/lemma-rag/index.d.ts.map +1 -0
- package/dist/reasoning/lemma-rag/index.js +34 -0
- package/dist/reasoning/lemma-rag/index.js.map +1 -0
- package/dist/reasoning/lemma-rag/query.d.ts +48 -0
- package/dist/reasoning/lemma-rag/query.d.ts.map +1 -0
- package/dist/reasoning/lemma-rag/query.js +92 -0
- package/dist/reasoning/lemma-rag/query.js.map +1 -0
- package/dist/reasoning/lemma-rag/retrieval.d.ts +33 -0
- package/dist/reasoning/lemma-rag/retrieval.d.ts.map +1 -0
- package/dist/reasoning/lemma-rag/retrieval.js +123 -0
- package/dist/reasoning/lemma-rag/retrieval.js.map +1 -0
- package/dist/reasoning/lemma-rag/types.d.ts +52 -0
- package/dist/reasoning/lemma-rag/types.d.ts.map +1 -0
- package/dist/reasoning/lemma-rag/types.js +13 -0
- package/dist/reasoning/lemma-rag/types.js.map +1 -0
- package/dist/reasoning/proof-mining/__tests__/extractor.test.d.ts +2 -0
- package/dist/reasoning/proof-mining/__tests__/extractor.test.d.ts.map +1 -0
- package/dist/reasoning/proof-mining/__tests__/extractor.test.js +263 -0
- package/dist/reasoning/proof-mining/__tests__/extractor.test.js.map +1 -0
- package/dist/reasoning/proof-mining/__tests__/generalizer.test.d.ts +2 -0
- package/dist/reasoning/proof-mining/__tests__/generalizer.test.d.ts.map +1 -0
- package/dist/reasoning/proof-mining/__tests__/generalizer.test.js +123 -0
- package/dist/reasoning/proof-mining/__tests__/generalizer.test.js.map +1 -0
- package/dist/reasoning/proof-mining/__tests__/integration.test.d.ts +2 -0
- package/dist/reasoning/proof-mining/__tests__/integration.test.d.ts.map +1 -0
- package/dist/reasoning/proof-mining/__tests__/integration.test.js +128 -0
- package/dist/reasoning/proof-mining/__tests__/integration.test.js.map +1 -0
- package/dist/reasoning/proof-mining/__tests__/persistence.test.d.ts +2 -0
- package/dist/reasoning/proof-mining/__tests__/persistence.test.d.ts.map +1 -0
- package/dist/reasoning/proof-mining/__tests__/persistence.test.js +119 -0
- package/dist/reasoning/proof-mining/__tests__/persistence.test.js.map +1 -0
- package/dist/reasoning/proof-mining/__tests__/ranker.test.d.ts +2 -0
- package/dist/reasoning/proof-mining/__tests__/ranker.test.d.ts.map +1 -0
- package/dist/reasoning/proof-mining/__tests__/ranker.test.js +93 -0
- package/dist/reasoning/proof-mining/__tests__/ranker.test.js.map +1 -0
- package/dist/reasoning/proof-mining/extractor.d.ts +73 -0
- package/dist/reasoning/proof-mining/extractor.d.ts.map +1 -0
- package/dist/reasoning/proof-mining/extractor.js +170 -0
- package/dist/reasoning/proof-mining/extractor.js.map +1 -0
- package/dist/reasoning/proof-mining/generalizer.d.ts +46 -0
- package/dist/reasoning/proof-mining/generalizer.d.ts.map +1 -0
- package/dist/reasoning/proof-mining/generalizer.js +245 -0
- package/dist/reasoning/proof-mining/generalizer.js.map +1 -0
- package/dist/reasoning/proof-mining/index.d.ts +62 -0
- package/dist/reasoning/proof-mining/index.d.ts.map +1 -0
- package/dist/reasoning/proof-mining/index.js +235 -0
- package/dist/reasoning/proof-mining/index.js.map +1 -0
- package/dist/reasoning/proof-mining/persistence.d.ts +35 -0
- package/dist/reasoning/proof-mining/persistence.d.ts.map +1 -0
- package/dist/reasoning/proof-mining/persistence.js +126 -0
- package/dist/reasoning/proof-mining/persistence.js.map +1 -0
- package/dist/reasoning/proof-mining/ranker.d.ts +29 -0
- package/dist/reasoning/proof-mining/ranker.d.ts.map +1 -0
- package/dist/reasoning/proof-mining/ranker.js +71 -0
- package/dist/reasoning/proof-mining/ranker.js.map +1 -0
- package/dist/reasoning/proof-mining/statistics.d.ts +11 -0
- package/dist/reasoning/proof-mining/statistics.d.ts.map +1 -0
- package/dist/reasoning/proof-mining/statistics.js +44 -0
- package/dist/reasoning/proof-mining/statistics.js.map +1 -0
- package/dist/reasoning/proof-mining/types.d.ts +117 -0
- package/dist/reasoning/proof-mining/types.d.ts.map +1 -0
- package/dist/reasoning/proof-mining/types.js +24 -0
- package/dist/reasoning/proof-mining/types.js.map +1 -0
- 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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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"}
|