@stevenvo780/st-lang 4.5.2 → 4.6.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.
- package/dist/categorical/fin-set.d.ts +39 -0
- package/dist/categorical/fin-set.d.ts.map +1 -0
- package/dist/categorical/fin-set.js +217 -0
- package/dist/categorical/fin-set.js.map +1 -0
- package/dist/categorical/free.d.ts +23 -0
- package/dist/categorical/free.d.ts.map +1 -0
- package/dist/categorical/free.js +168 -0
- package/dist/categorical/free.js.map +1 -0
- package/dist/categorical/functor.d.ts +40 -0
- package/dist/categorical/functor.d.ts.map +1 -0
- package/dist/categorical/functor.js +139 -0
- package/dist/categorical/functor.js.map +1 -0
- package/dist/categorical/index.d.ts +11 -0
- package/dist/categorical/index.d.ts.map +1 -0
- package/dist/categorical/index.js +33 -0
- package/dist/categorical/index.js.map +1 -0
- package/dist/categorical/limits.d.ts +64 -0
- package/dist/categorical/limits.d.ts.map +1 -0
- package/dist/categorical/limits.js +248 -0
- package/dist/categorical/limits.js.map +1 -0
- package/dist/categorical/monoidal.d.ts +14 -0
- package/dist/categorical/monoidal.d.ts.map +1 -0
- package/dist/categorical/monoidal.js +148 -0
- package/dist/categorical/monoidal.js.map +1 -0
- package/dist/categorical/poset.d.ts +14 -0
- package/dist/categorical/poset.d.ts.map +1 -0
- package/dist/categorical/poset.js +115 -0
- package/dist/categorical/poset.js.map +1 -0
- package/dist/categorical/types.d.ts +111 -0
- package/dist/categorical/types.d.ts.map +1 -0
- package/dist/categorical/types.js +15 -0
- package/dist/categorical/types.js.map +1 -0
- package/dist/csp-hoare/analysis.d.ts +51 -0
- package/dist/csp-hoare/analysis.d.ts.map +1 -0
- package/dist/csp-hoare/analysis.js +317 -0
- package/dist/csp-hoare/analysis.js.map +1 -0
- package/dist/csp-hoare/examples.d.ts +33 -0
- package/dist/csp-hoare/examples.d.ts.map +1 -0
- package/dist/csp-hoare/examples.js +108 -0
- package/dist/csp-hoare/examples.js.map +1 -0
- package/dist/csp-hoare/index.d.ts +6 -0
- package/dist/csp-hoare/index.d.ts.map +1 -0
- package/dist/csp-hoare/index.js +50 -0
- package/dist/csp-hoare/index.js.map +1 -0
- package/dist/csp-hoare/semantics.d.ts +49 -0
- package/dist/csp-hoare/semantics.d.ts.map +1 -0
- package/dist/csp-hoare/semantics.js +494 -0
- package/dist/csp-hoare/semantics.js.map +1 -0
- package/dist/csp-hoare/types.d.ts +60 -0
- package/dist/csp-hoare/types.d.ts.map +1 -0
- package/dist/csp-hoare/types.js +31 -0
- package/dist/csp-hoare/types.js.map +1 -0
- package/dist/hindley-milner/index.d.ts +7 -0
- package/dist/hindley-milner/index.d.ts.map +1 -0
- package/dist/hindley-milner/index.js +60 -0
- package/dist/hindley-milner/index.js.map +1 -0
- package/dist/hindley-milner/infer.d.ts +26 -0
- package/dist/hindley-milner/infer.d.ts.map +1 -0
- package/dist/hindley-milner/infer.js +278 -0
- package/dist/hindley-milner/infer.js.map +1 -0
- package/dist/hindley-milner/substitution.d.ts +21 -0
- package/dist/hindley-milner/substitution.d.ts.map +1 -0
- package/dist/hindley-milner/substitution.js +215 -0
- package/dist/hindley-milner/substitution.js.map +1 -0
- package/dist/hindley-milner/types.d.ts +84 -0
- package/dist/hindley-milner/types.d.ts.map +1 -0
- package/dist/hindley-milner/types.js +166 -0
- package/dist/hindley-milner/types.js.map +1 -0
- package/dist/hott/equality.d.ts +4 -0
- package/dist/hott/equality.d.ts.map +1 -0
- package/dist/hott/equality.js +108 -0
- package/dist/hott/equality.js.map +1 -0
- package/dist/hott/index.d.ts +13 -0
- package/dist/hott/index.d.ts.map +1 -0
- package/dist/hott/index.js +77 -0
- package/dist/hott/index.js.map +1 -0
- package/dist/hott/infer.d.ts +11 -0
- package/dist/hott/infer.d.ts.map +1 -0
- package/dist/hott/infer.js +465 -0
- package/dist/hott/infer.js.map +1 -0
- package/dist/hott/normalize.d.ts +5 -0
- package/dist/hott/normalize.d.ts.map +1 -0
- package/dist/hott/normalize.js +240 -0
- package/dist/hott/normalize.js.map +1 -0
- package/dist/hott/path-algebra.d.ts +25 -0
- package/dist/hott/path-algebra.d.ts.map +1 -0
- package/dist/hott/path-algebra.js +67 -0
- package/dist/hott/path-algebra.js.map +1 -0
- package/dist/hott/substitute.d.ts +3 -0
- package/dist/hott/substitute.d.ts.map +1 -0
- package/dist/hott/substitute.js +131 -0
- package/dist/hott/substitute.js.map +1 -0
- package/dist/hott/types.d.ts +126 -0
- package/dist/hott/types.d.ts.map +1 -0
- package/dist/hott/types.js +346 -0
- package/dist/hott/types.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +48 -3
- package/dist/index.js.map +1 -1
- package/dist/lemma-synthesis/index.d.ts +124 -0
- package/dist/lemma-synthesis/index.d.ts.map +1 -0
- package/dist/lemma-synthesis/index.js +640 -0
- package/dist/lemma-synthesis/index.js.map +1 -0
- package/dist/tactic-dsl/combinators.d.ts +6 -0
- package/dist/tactic-dsl/combinators.d.ts.map +1 -0
- package/dist/tactic-dsl/combinators.js +98 -0
- package/dist/tactic-dsl/combinators.js.map +1 -0
- package/dist/tactic-dsl/index.d.ts +39 -0
- package/dist/tactic-dsl/index.d.ts.map +1 -0
- package/dist/tactic-dsl/index.js +162 -0
- package/dist/tactic-dsl/index.js.map +1 -0
- package/dist/tactic-dsl/tactics.d.ts +21 -0
- package/dist/tactic-dsl/tactics.d.ts.map +1 -0
- package/dist/tactic-dsl/tactics.js +536 -0
- package/dist/tactic-dsl/tactics.js.map +1 -0
- package/dist/tactic-dsl/types.d.ts +54 -0
- package/dist/tactic-dsl/types.d.ts.map +1 -0
- package/dist/tactic-dsl/types.js +226 -0
- package/dist/tactic-dsl/types.js.map +1 -0
- package/dist/tests/categorical/categorical.test.d.ts +2 -0
- package/dist/tests/categorical/categorical.test.d.ts.map +1 -0
- package/dist/tests/categorical/categorical.test.js +300 -0
- package/dist/tests/categorical/categorical.test.js.map +1 -0
- package/dist/tests/csp-hoare/csp-hoare.test.d.ts +2 -0
- package/dist/tests/csp-hoare/csp-hoare.test.d.ts.map +1 -0
- package/dist/tests/csp-hoare/csp-hoare.test.js +313 -0
- package/dist/tests/csp-hoare/csp-hoare.test.js.map +1 -0
- package/dist/tests/hindley-milner/hindley-milner.test.d.ts +2 -0
- package/dist/tests/hindley-milner/hindley-milner.test.d.ts.map +1 -0
- package/dist/tests/hindley-milner/hindley-milner.test.js +327 -0
- package/dist/tests/hindley-milner/hindley-milner.test.js.map +1 -0
- package/dist/tests/hott/hott.test.d.ts +2 -0
- package/dist/tests/hott/hott.test.d.ts.map +1 -0
- package/dist/tests/hott/hott.test.js +271 -0
- package/dist/tests/hott/hott.test.js.map +1 -0
- package/dist/tests/lemma-synthesis/lemma-synthesis.test.d.ts +2 -0
- package/dist/tests/lemma-synthesis/lemma-synthesis.test.d.ts.map +1 -0
- package/dist/tests/lemma-synthesis/lemma-synthesis.test.js +460 -0
- package/dist/tests/lemma-synthesis/lemma-synthesis.test.js.map +1 -0
- package/dist/tests/tactic-dsl/tactic-dsl.test.d.ts +2 -0
- package/dist/tests/tactic-dsl/tactic-dsl.test.d.ts.map +1 -0
- package/dist/tests/tactic-dsl/tactic-dsl.test.js +259 -0
- package/dist/tests/tactic-dsl/tactic-dsl.test.js.map +1 -0
- package/dist/tests/tptp/bridge.test.d.ts +2 -0
- package/dist/tests/tptp/bridge.test.d.ts.map +1 -0
- package/dist/tests/tptp/bridge.test.js +154 -0
- package/dist/tests/tptp/bridge.test.js.map +1 -0
- package/dist/tests/tptp/emitter.test.d.ts +2 -0
- package/dist/tests/tptp/emitter.test.d.ts.map +1 -0
- package/dist/tests/tptp/emitter.test.js +128 -0
- package/dist/tests/tptp/emitter.test.js.map +1 -0
- package/dist/tests/tptp/parser.test.d.ts +2 -0
- package/dist/tests/tptp/parser.test.d.ts.map +1 -0
- package/dist/tests/tptp/parser.test.js +192 -0
- package/dist/tests/tptp/parser.test.js.map +1 -0
- package/dist/tests/tptp/tokenizer.test.d.ts +2 -0
- package/dist/tests/tptp/tokenizer.test.d.ts.map +1 -0
- package/dist/tests/tptp/tokenizer.test.js +60 -0
- package/dist/tests/tptp/tokenizer.test.js.map +1 -0
- package/dist/tptp/ast.d.ts +73 -0
- package/dist/tptp/ast.d.ts.map +1 -0
- package/dist/tptp/ast.js +35 -0
- package/dist/tptp/ast.js.map +1 -0
- package/dist/tptp/bridge.d.ts +14 -0
- package/dist/tptp/bridge.d.ts.map +1 -0
- package/dist/tptp/bridge.js +146 -0
- package/dist/tptp/bridge.js.map +1 -0
- package/dist/tptp/emitter.d.ts +5 -0
- package/dist/tptp/emitter.d.ts.map +1 -0
- package/dist/tptp/emitter.js +103 -0
- package/dist/tptp/emitter.js.map +1 -0
- package/dist/tptp/index.d.ts +7 -0
- package/dist/tptp/index.d.ts.map +1 -0
- package/dist/tptp/index.js +31 -0
- package/dist/tptp/index.js.map +1 -0
- package/dist/tptp/parser.d.ts +23 -0
- package/dist/tptp/parser.d.ts.map +1 -0
- package/dist/tptp/parser.js +440 -0
- package/dist/tptp/parser.js.map +1 -0
- package/dist/tptp/tokenizer.d.ts +14 -0
- package/dist/tptp/tokenizer.d.ts.map +1 -0
- package/dist/tptp/tokenizer.js +264 -0
- package/dist/tptp/tokenizer.js.map +1 -0
- package/package.json +4 -1
|
@@ -0,0 +1,226 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// ============================================================
|
|
3
|
+
// Tactic DSL — tipos, parser y normalizador de fórmulas
|
|
4
|
+
// ============================================================
|
|
5
|
+
//
|
|
6
|
+
// El DSL trabaja con fórmulas como strings (legibles para el user)
|
|
7
|
+
// y un AST interno mínimo (`Formula`) que se usa para destructurar
|
|
8
|
+
// goals y reducir hipótesis. El parser soporta:
|
|
9
|
+
//
|
|
10
|
+
// atom: identificador alfanumérico (P, Q, n, x_1, Nat).
|
|
11
|
+
// implicación P -> Q (right-assoc, menor precedencia)
|
|
12
|
+
// disyunción P \/ Q (right-assoc)
|
|
13
|
+
// conjunción P /\ Q (right-assoc, mayor prec. que \/)
|
|
14
|
+
// negación ~P
|
|
15
|
+
// constantes True, False
|
|
16
|
+
// función f(arg1, arg2) — opaco, se trata como atom
|
|
17
|
+
// paréntesis (...)
|
|
18
|
+
//
|
|
19
|
+
// El parser es deliberadamente pequeño: nos importa poder destructurar
|
|
20
|
+
// las fórmulas que los tactics manipulan, no parsear FOL completa.
|
|
21
|
+
// Para cosas como `rewrite`, la igualdad se acepta como string `lhs = rhs`.
|
|
22
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
23
|
+
exports.TacticError = void 0;
|
|
24
|
+
exports.parseFormula = parseFormula;
|
|
25
|
+
exports.formulaToString = formulaToString;
|
|
26
|
+
exports.normalizeFormula = normalizeFormula;
|
|
27
|
+
exports.formulaEq = formulaEq;
|
|
28
|
+
exports.substitute = substitute;
|
|
29
|
+
class TacticError extends Error {
|
|
30
|
+
tactic;
|
|
31
|
+
constructor(tactic, message) {
|
|
32
|
+
super(`[${tactic}] ${message}`);
|
|
33
|
+
this.tactic = tactic;
|
|
34
|
+
this.name = 'TacticError';
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
exports.TacticError = TacticError;
|
|
38
|
+
function peek(s) {
|
|
39
|
+
return s.src[s.pos] ?? '';
|
|
40
|
+
}
|
|
41
|
+
function skipWs(s) {
|
|
42
|
+
while (s.pos < s.src.length && /\s/.test(s.src[s.pos] ?? ''))
|
|
43
|
+
s.pos++;
|
|
44
|
+
}
|
|
45
|
+
function match(s, lit) {
|
|
46
|
+
skipWs(s);
|
|
47
|
+
if (s.src.startsWith(lit, s.pos)) {
|
|
48
|
+
s.pos += lit.length;
|
|
49
|
+
return true;
|
|
50
|
+
}
|
|
51
|
+
return false;
|
|
52
|
+
}
|
|
53
|
+
function isIdStart(ch) {
|
|
54
|
+
return /[A-Za-z_]/.test(ch);
|
|
55
|
+
}
|
|
56
|
+
function isIdPart(ch) {
|
|
57
|
+
return /[A-Za-z0-9_]/.test(ch);
|
|
58
|
+
}
|
|
59
|
+
function parseIdent(s) {
|
|
60
|
+
skipWs(s);
|
|
61
|
+
if (!isIdStart(peek(s)))
|
|
62
|
+
return null;
|
|
63
|
+
let id = '';
|
|
64
|
+
while (s.pos < s.src.length && isIdPart(peek(s))) {
|
|
65
|
+
id += s.src[s.pos];
|
|
66
|
+
s.pos++;
|
|
67
|
+
}
|
|
68
|
+
return id;
|
|
69
|
+
}
|
|
70
|
+
// Parses an opaque function-like atom: f(a, b, c) → just folds into a string atom
|
|
71
|
+
// so we don't try to reason about argument structure.
|
|
72
|
+
function parseAtomOrApp(s) {
|
|
73
|
+
const id = parseIdent(s);
|
|
74
|
+
if (id === null) {
|
|
75
|
+
throw new Error(`expected identifier at pos ${s.pos} in "${s.src}"`);
|
|
76
|
+
}
|
|
77
|
+
if (id === 'True' || id === 'true')
|
|
78
|
+
return { kind: 'true' };
|
|
79
|
+
if (id === 'False' || id === 'false')
|
|
80
|
+
return { kind: 'false' };
|
|
81
|
+
// función opaca
|
|
82
|
+
if (match(s, '(')) {
|
|
83
|
+
const parts = [];
|
|
84
|
+
if (!match(s, ')')) {
|
|
85
|
+
while (true) {
|
|
86
|
+
skipWs(s);
|
|
87
|
+
// recolectar tokens hasta `,` o `)` con balance de paréntesis
|
|
88
|
+
let depth = 0;
|
|
89
|
+
let buf = '';
|
|
90
|
+
while (s.pos < s.src.length) {
|
|
91
|
+
const ch = peek(s);
|
|
92
|
+
if (depth === 0 && (ch === ',' || ch === ')'))
|
|
93
|
+
break;
|
|
94
|
+
if (ch === '(')
|
|
95
|
+
depth++;
|
|
96
|
+
else if (ch === ')')
|
|
97
|
+
depth--;
|
|
98
|
+
buf += ch;
|
|
99
|
+
s.pos++;
|
|
100
|
+
}
|
|
101
|
+
parts.push(buf.trim());
|
|
102
|
+
if (match(s, ','))
|
|
103
|
+
continue;
|
|
104
|
+
if (match(s, ')'))
|
|
105
|
+
break;
|
|
106
|
+
throw new Error(`expected ',' or ')' inside application of '${id}'`);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
return { kind: 'atom', name: `${id}(${parts.join(',')})` };
|
|
110
|
+
}
|
|
111
|
+
return { kind: 'atom', name: id };
|
|
112
|
+
}
|
|
113
|
+
function parsePrimary(s) {
|
|
114
|
+
skipWs(s);
|
|
115
|
+
if (match(s, '(')) {
|
|
116
|
+
const inner = parseImp(s);
|
|
117
|
+
if (!match(s, ')')) {
|
|
118
|
+
throw new Error(`expected ')' at pos ${s.pos} in "${s.src}"`);
|
|
119
|
+
}
|
|
120
|
+
return inner;
|
|
121
|
+
}
|
|
122
|
+
if (match(s, '~') || match(s, '¬')) {
|
|
123
|
+
const body = parsePrimary(s);
|
|
124
|
+
return { kind: 'not', body };
|
|
125
|
+
}
|
|
126
|
+
return parseAtomOrApp(s);
|
|
127
|
+
}
|
|
128
|
+
// equality binds tightest after primary (e.g. `f(n) = g(n)` should be a single eq)
|
|
129
|
+
function parseEq(s) {
|
|
130
|
+
const left = parsePrimary(s);
|
|
131
|
+
skipWs(s);
|
|
132
|
+
if (s.src.startsWith('=', s.pos) && s.src[s.pos + 1] !== '=' && s.src[s.pos + 1] !== '>') {
|
|
133
|
+
s.pos++;
|
|
134
|
+
const right = parsePrimary(s);
|
|
135
|
+
return { kind: 'eq', left, right };
|
|
136
|
+
}
|
|
137
|
+
return left;
|
|
138
|
+
}
|
|
139
|
+
function parseAnd(s) {
|
|
140
|
+
const left = parseEq(s);
|
|
141
|
+
if (match(s, '/\\') || match(s, '∧') || match(s, '&&')) {
|
|
142
|
+
const right = parseAnd(s);
|
|
143
|
+
return { kind: 'and', left, right };
|
|
144
|
+
}
|
|
145
|
+
return left;
|
|
146
|
+
}
|
|
147
|
+
function parseOr(s) {
|
|
148
|
+
const left = parseAnd(s);
|
|
149
|
+
if (match(s, '\\/') || match(s, '∨') || match(s, '||')) {
|
|
150
|
+
const right = parseOr(s);
|
|
151
|
+
return { kind: 'or', left, right };
|
|
152
|
+
}
|
|
153
|
+
return left;
|
|
154
|
+
}
|
|
155
|
+
function parseImp(s) {
|
|
156
|
+
const left = parseOr(s);
|
|
157
|
+
if (match(s, '->') || match(s, '→') || match(s, '⇒')) {
|
|
158
|
+
const right = parseImp(s);
|
|
159
|
+
return { kind: 'imp', left, right };
|
|
160
|
+
}
|
|
161
|
+
return left;
|
|
162
|
+
}
|
|
163
|
+
function parseFormula(src) {
|
|
164
|
+
const s = { src, pos: 0 };
|
|
165
|
+
const f = parseImp(s);
|
|
166
|
+
skipWs(s);
|
|
167
|
+
if (s.pos !== s.src.length) {
|
|
168
|
+
throw new Error(`unexpected trailing input at pos ${s.pos} in "${src}"`);
|
|
169
|
+
}
|
|
170
|
+
return f;
|
|
171
|
+
}
|
|
172
|
+
// ---------- Serializer ----------
|
|
173
|
+
//
|
|
174
|
+
// Forma canónica: usamos '->', '/\', '\/', '~'. Las strings de entrada
|
|
175
|
+
// que usan unicode (∧, ∨, →, ¬) se normalizan a ascii al re-imprimirse.
|
|
176
|
+
function formulaToString(f) {
|
|
177
|
+
switch (f.kind) {
|
|
178
|
+
case 'atom':
|
|
179
|
+
return f.name;
|
|
180
|
+
case 'true':
|
|
181
|
+
return 'True';
|
|
182
|
+
case 'false':
|
|
183
|
+
return 'False';
|
|
184
|
+
case 'not':
|
|
185
|
+
return `~${formulaToString(f.body)}`;
|
|
186
|
+
case 'and':
|
|
187
|
+
return `(${formulaToString(f.left)} /\\ ${formulaToString(f.right)})`;
|
|
188
|
+
case 'or':
|
|
189
|
+
return `(${formulaToString(f.left)} \\/ ${formulaToString(f.right)})`;
|
|
190
|
+
case 'imp':
|
|
191
|
+
return `(${formulaToString(f.left)} -> ${formulaToString(f.right)})`;
|
|
192
|
+
case 'eq':
|
|
193
|
+
return `${formulaToString(f.left)} = ${formulaToString(f.right)}`;
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
// Normaliza una string a la forma canónica re-parseando y serializando.
|
|
197
|
+
// Útil para comparar `P -> P` con `P → P` o con paréntesis extra.
|
|
198
|
+
function normalizeFormula(src) {
|
|
199
|
+
try {
|
|
200
|
+
return formulaToString(parseFormula(src));
|
|
201
|
+
}
|
|
202
|
+
catch {
|
|
203
|
+
return src.trim();
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
function formulaEq(a, b) {
|
|
207
|
+
return normalizeFormula(a) === normalizeFormula(b);
|
|
208
|
+
}
|
|
209
|
+
// ---------- Substitución textual ----------
|
|
210
|
+
//
|
|
211
|
+
// Para `rewrite`: dado `lhs = rhs`, sustituye ocurrencias de `lhs`
|
|
212
|
+
// como string en una fórmula objetivo. Es textual (no αβ-aware) — el
|
|
213
|
+
// alcance del DSL no incluye un substituidor capture-avoiding completo
|
|
214
|
+
// porque las fórmulas son ASCII opacas.
|
|
215
|
+
function substitute(target, lhs, rhs) {
|
|
216
|
+
if (lhs === rhs)
|
|
217
|
+
return target;
|
|
218
|
+
// Word-boundary sensitive replace para identificadores; literal en caso
|
|
219
|
+
// contrario.
|
|
220
|
+
const escaped = lhs.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
221
|
+
const re = /^[A-Za-z_][A-Za-z0-9_]*$/.test(lhs)
|
|
222
|
+
? new RegExp(`\\b${escaped}\\b`, 'g')
|
|
223
|
+
: new RegExp(escaped, 'g');
|
|
224
|
+
return target.replace(re, rhs);
|
|
225
|
+
}
|
|
226
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/tactic-dsl/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"categorical.test.d.ts","sourceRoot":"","sources":["../../../src/tests/categorical/categorical.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// ============================================================
|
|
3
|
+
// ST Categorical — Tests
|
|
4
|
+
// ============================================================
|
|
5
|
+
// Cubre:
|
|
6
|
+
// • FinSet: identidad, asociatividad, hom-sets.
|
|
7
|
+
// • Poset: clausura reflexivo-transitiva y categoricidad.
|
|
8
|
+
// • Free: paths como morfismos, asociatividad.
|
|
9
|
+
// • Functor: identidad y composición; preservación de leyes.
|
|
10
|
+
// • NaturalTransformation: naturalidad estricta y trivial (id).
|
|
11
|
+
// • Limits: product, coproduct, equalizer (FinSet binarios).
|
|
12
|
+
// • Monoidal: unitores y asociador estructurales.
|
|
13
|
+
// ============================================================
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
const vitest_1 = require("vitest");
|
|
16
|
+
const categorical_1 = require("../../categorical");
|
|
17
|
+
// Reutilizamos estos objetos en varios tests.
|
|
18
|
+
const A = { name: 'A', elements: ['a0', 'a1'] };
|
|
19
|
+
const B = { name: 'B', elements: ['b0', 'b1', 'b2'] };
|
|
20
|
+
const C = { name: 'C', elements: ['c0'] };
|
|
21
|
+
(0, vitest_1.describe)('FinSet — categoría', () => {
|
|
22
|
+
(0, vitest_1.it)('FinSet con 2 objetos verifica identity', () => {
|
|
23
|
+
const f = (0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' });
|
|
24
|
+
const cat = (0, categorical_1.FinSet)([A, B], [f]);
|
|
25
|
+
(0, vitest_1.expect)(cat.verifyIdentity()).toBe(true);
|
|
26
|
+
});
|
|
27
|
+
(0, vitest_1.it)('FinSet con 2 objetos verifica associativity', () => {
|
|
28
|
+
const f = (0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' });
|
|
29
|
+
const g = (0, categorical_1.mkFinSetMor)('g', B, C, { b0: 'c0', b1: 'c0', b2: 'c0' });
|
|
30
|
+
const cat = (0, categorical_1.FinSet)([A, B, C], [f, g]);
|
|
31
|
+
(0, vitest_1.expect)(cat.verifyAssociativity()).toBe(true);
|
|
32
|
+
});
|
|
33
|
+
(0, vitest_1.it)('hom-set hom(A, B) contiene a f', () => {
|
|
34
|
+
const f = (0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' });
|
|
35
|
+
const cat = (0, categorical_1.FinSet)([A, B], [f]);
|
|
36
|
+
const homs = cat.hom(A, B);
|
|
37
|
+
(0, vitest_1.expect)(homs.some((m) => cat.eqMor(m, f))).toBe(true);
|
|
38
|
+
});
|
|
39
|
+
(0, vitest_1.it)('mkFinSetMor rechaza imagen fuera del codominio', () => {
|
|
40
|
+
(0, vitest_1.expect)(() => (0, categorical_1.mkFinSetMor)('bad', A, B, { a0: 'b0', a1: 'zzz' })).toThrow(/not in target/);
|
|
41
|
+
});
|
|
42
|
+
(0, vitest_1.it)('compose en FinSet aplica funciones correctamente', () => {
|
|
43
|
+
const f = (0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' });
|
|
44
|
+
const g = (0, categorical_1.mkFinSetMor)('g', B, C, { b0: 'c0', b1: 'c0', b2: 'c0' });
|
|
45
|
+
const cat = (0, categorical_1.FinSet)([A, B, C], [f, g]);
|
|
46
|
+
const gf = cat.compose(g, f);
|
|
47
|
+
(0, vitest_1.expect)(gf.fn.get('a0')).toBe('c0');
|
|
48
|
+
(0, vitest_1.expect)(gf.fn.get('a1')).toBe('c0');
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
(0, vitest_1.describe)('Poset — categoría', () => {
|
|
52
|
+
(0, vitest_1.it)('Poset [1≤2≤3] forma categoría válida', () => {
|
|
53
|
+
const cat = (0, categorical_1.Poset)(['1', '2', '3'], [
|
|
54
|
+
['1', '2'],
|
|
55
|
+
['2', '3'],
|
|
56
|
+
]);
|
|
57
|
+
// Debe haber el morfismo transitivo 1→3
|
|
58
|
+
(0, vitest_1.expect)(cat.hom('1', '3').length).toBe(1);
|
|
59
|
+
(0, vitest_1.expect)(cat.verifyIdentity()).toBe(true);
|
|
60
|
+
(0, vitest_1.expect)(cat.verifyAssociativity()).toBe(true);
|
|
61
|
+
});
|
|
62
|
+
(0, vitest_1.it)('Poset reflexividad: cada objeto tiene identidad', () => {
|
|
63
|
+
const cat = (0, categorical_1.Poset)(['x', 'y'], [['x', 'y']]);
|
|
64
|
+
(0, vitest_1.expect)(cat.hom('x', 'x').length).toBe(1);
|
|
65
|
+
(0, vitest_1.expect)(cat.hom('y', 'y').length).toBe(1);
|
|
66
|
+
});
|
|
67
|
+
(0, vitest_1.it)('Poset sin relaciones es discreto', () => {
|
|
68
|
+
const cat = (0, categorical_1.Poset)(['p', 'q'], []);
|
|
69
|
+
(0, vitest_1.expect)(cat.hom('p', 'q').length).toBe(0);
|
|
70
|
+
(0, vitest_1.expect)(cat.hom('p', 'p').length).toBe(1);
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
(0, vitest_1.describe)('Free — categoría libre sobre grafo', () => {
|
|
74
|
+
(0, vitest_1.it)('Free con 1 edge produce path de longitud 1', () => {
|
|
75
|
+
const cat = (0, categorical_1.Free)(['x', 'y'], [['x', 'y', 'e']]);
|
|
76
|
+
const homs = cat.hom('x', 'y');
|
|
77
|
+
(0, vitest_1.expect)(homs.length).toBeGreaterThanOrEqual(1);
|
|
78
|
+
(0, vitest_1.expect)(homs.some((m) => m.path.length === 1 && m.path[0] === 'e')).toBe(true);
|
|
79
|
+
});
|
|
80
|
+
(0, vitest_1.it)('Free verifica asociatividad', () => {
|
|
81
|
+
const cat = (0, categorical_1.Free)(['x', 'y', 'z'], [
|
|
82
|
+
['x', 'y', 'e1'],
|
|
83
|
+
['y', 'z', 'e2'],
|
|
84
|
+
]);
|
|
85
|
+
(0, vitest_1.expect)(cat.verifyAssociativity()).toBe(true);
|
|
86
|
+
});
|
|
87
|
+
(0, vitest_1.it)('Free verifica identity laws', () => {
|
|
88
|
+
const cat = (0, categorical_1.Free)(['x', 'y'], [['x', 'y', 'e']]);
|
|
89
|
+
(0, vitest_1.expect)(cat.verifyIdentity()).toBe(true);
|
|
90
|
+
});
|
|
91
|
+
});
|
|
92
|
+
(0, vitest_1.describe)('Functor', () => {
|
|
93
|
+
(0, vitest_1.it)('Functor identidad pasa preservation e identity laws', () => {
|
|
94
|
+
const f = (0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' });
|
|
95
|
+
const cat = (0, categorical_1.FinSet)([A, B], [f]);
|
|
96
|
+
const Id = (0, categorical_1.identityFunctor)(cat);
|
|
97
|
+
(0, vitest_1.expect)(Id.verifyIdentityPreservation()).toBe(true);
|
|
98
|
+
(0, vitest_1.expect)(Id.verifyComposition()).toBe(true);
|
|
99
|
+
});
|
|
100
|
+
(0, vitest_1.it)('Functor constante a un objeto verifica leyes', () => {
|
|
101
|
+
const f = (0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' });
|
|
102
|
+
const cat = (0, categorical_1.FinSet)([A, B], [f]);
|
|
103
|
+
const Const = (0, categorical_1.mkFunctor)({
|
|
104
|
+
name: 'Const_C',
|
|
105
|
+
source: cat,
|
|
106
|
+
target: cat,
|
|
107
|
+
onObjects: () => B,
|
|
108
|
+
onMorphisms: () => cat.identity(B),
|
|
109
|
+
});
|
|
110
|
+
(0, vitest_1.expect)(Const.verifyIdentityPreservation()).toBe(true);
|
|
111
|
+
(0, vitest_1.expect)(Const.verifyComposition()).toBe(true);
|
|
112
|
+
});
|
|
113
|
+
(0, vitest_1.it)('Functor Free → FinSet preserve composition (estructura discreta)', () => {
|
|
114
|
+
// Free sobre un vertice solo (sólo identidades).
|
|
115
|
+
const free = (0, categorical_1.Free)(['v'], []);
|
|
116
|
+
const cat = (0, categorical_1.FinSet)([A], []);
|
|
117
|
+
const F = (0, categorical_1.mkFunctor)({
|
|
118
|
+
name: 'F',
|
|
119
|
+
source: free,
|
|
120
|
+
target: cat,
|
|
121
|
+
onObjects: () => A,
|
|
122
|
+
onMorphisms: () => cat.identity(A),
|
|
123
|
+
});
|
|
124
|
+
(0, vitest_1.expect)(F.verifyIdentityPreservation()).toBe(true);
|
|
125
|
+
(0, vitest_1.expect)(F.verifyComposition()).toBe(true);
|
|
126
|
+
});
|
|
127
|
+
(0, vitest_1.it)('Composición de dos functores produce un functor válido', () => {
|
|
128
|
+
const cat = (0, categorical_1.FinSet)([A, B], [(0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' })]);
|
|
129
|
+
const Id = (0, categorical_1.identityFunctor)(cat);
|
|
130
|
+
const IdId = (0, categorical_1.composeFunctors)(Id, Id);
|
|
131
|
+
(0, vitest_1.expect)(IdId.verifyIdentityPreservation()).toBe(true);
|
|
132
|
+
(0, vitest_1.expect)(IdId.verifyComposition()).toBe(true);
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
(0, vitest_1.describe)('NaturalTransformation', () => {
|
|
136
|
+
(0, vitest_1.it)('Identity natural transformation id_F satisfies naturality', () => {
|
|
137
|
+
const f = (0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' });
|
|
138
|
+
const cat = (0, categorical_1.FinSet)([A, B], [f]);
|
|
139
|
+
const Id = (0, categorical_1.identityFunctor)(cat);
|
|
140
|
+
const idNT = (0, categorical_1.identityNT)(Id);
|
|
141
|
+
(0, vitest_1.expect)(idNT.verifyNaturality()).toBe(true);
|
|
142
|
+
});
|
|
143
|
+
(0, vitest_1.it)('NT entre 2 functores constantes (mismo objeto) es natural trivialmente', () => {
|
|
144
|
+
const cat = (0, categorical_1.FinSet)([A, B], [(0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' })]);
|
|
145
|
+
const ConstA = (0, categorical_1.mkFunctor)({
|
|
146
|
+
name: 'KA',
|
|
147
|
+
source: cat,
|
|
148
|
+
target: cat,
|
|
149
|
+
onObjects: () => A,
|
|
150
|
+
onMorphisms: () => cat.identity(A),
|
|
151
|
+
});
|
|
152
|
+
const ConstB = (0, categorical_1.mkFunctor)({
|
|
153
|
+
name: 'KB',
|
|
154
|
+
source: cat,
|
|
155
|
+
target: cat,
|
|
156
|
+
onObjects: () => B,
|
|
157
|
+
onMorphisms: () => cat.identity(B),
|
|
158
|
+
});
|
|
159
|
+
const f = cat.hom(A, B)[0];
|
|
160
|
+
const nt = (0, categorical_1.mkNaturalTransformation)({
|
|
161
|
+
name: 'k',
|
|
162
|
+
source: ConstA,
|
|
163
|
+
target: ConstB,
|
|
164
|
+
component: () => f,
|
|
165
|
+
});
|
|
166
|
+
(0, vitest_1.expect)(nt.verifyNaturality()).toBe(true);
|
|
167
|
+
});
|
|
168
|
+
(0, vitest_1.it)('NT mal definida es rechazada por verifyNaturality', () => {
|
|
169
|
+
// Construimos dos functores: Id y Const_{B}. La transformación
|
|
170
|
+
// natural "constante a f" no satisface naturalidad cuando hay
|
|
171
|
+
// varios morfismos f con dom/cod compatibles. Aquí montamos un
|
|
172
|
+
// contraejemplo concreto.
|
|
173
|
+
const swapA = { name: 'A', elements: ['a0', 'a1'] };
|
|
174
|
+
const f = (0, categorical_1.mkFinSetMor)('swap', swapA, swapA, { a0: 'a1', a1: 'a0' });
|
|
175
|
+
const cat = (0, categorical_1.FinSet)([swapA], [f]);
|
|
176
|
+
const Id = (0, categorical_1.identityFunctor)(cat);
|
|
177
|
+
const Const = (0, categorical_1.mkFunctor)({
|
|
178
|
+
name: 'KA',
|
|
179
|
+
source: cat,
|
|
180
|
+
target: cat,
|
|
181
|
+
onObjects: () => swapA,
|
|
182
|
+
onMorphisms: () => cat.identity(swapA),
|
|
183
|
+
});
|
|
184
|
+
// η_a = swap : Id(a)=a → Const(a)=a. Naturalidad pide
|
|
185
|
+
// Const(swap) ∘ η_a = η_a ∘ Id(swap), i.e. id ∘ swap = swap ∘ swap,
|
|
186
|
+
// i.e. swap = id ⇒ FALSO.
|
|
187
|
+
const bad = (0, categorical_1.mkNaturalTransformation)({
|
|
188
|
+
name: 'bad',
|
|
189
|
+
source: Id,
|
|
190
|
+
target: Const,
|
|
191
|
+
component: () => f,
|
|
192
|
+
});
|
|
193
|
+
(0, vitest_1.expect)(bad.verifyNaturality()).toBe(false);
|
|
194
|
+
});
|
|
195
|
+
});
|
|
196
|
+
(0, vitest_1.describe)('Limits/Colimits — FinSet', () => {
|
|
197
|
+
(0, vitest_1.it)('product A×B construible en FinSet', () => {
|
|
198
|
+
const cat = (0, categorical_1.FinSet)([A, B], []);
|
|
199
|
+
const p = (0, categorical_1.product)(cat, A, B);
|
|
200
|
+
(0, vitest_1.expect)(p).not.toBeNull();
|
|
201
|
+
if (!p)
|
|
202
|
+
return;
|
|
203
|
+
(0, vitest_1.expect)(p.obj.elements.length).toBe(A.elements.length * B.elements.length);
|
|
204
|
+
(0, vitest_1.expect)(p.pi1.src).toBe(p.obj.name);
|
|
205
|
+
(0, vitest_1.expect)(p.pi1.tgt).toBe(A.name);
|
|
206
|
+
(0, vitest_1.expect)(p.pi2.tgt).toBe(B.name);
|
|
207
|
+
});
|
|
208
|
+
(0, vitest_1.it)('coproduct A⊔B construible en FinSet', () => {
|
|
209
|
+
const cat = (0, categorical_1.FinSet)([A, B], []);
|
|
210
|
+
const c = (0, categorical_1.coproduct)(cat, A, B);
|
|
211
|
+
(0, vitest_1.expect)(c).not.toBeNull();
|
|
212
|
+
if (!c)
|
|
213
|
+
return;
|
|
214
|
+
(0, vitest_1.expect)(c.obj.elements.length).toBe(A.elements.length + B.elements.length);
|
|
215
|
+
(0, vitest_1.expect)(c.in1.src).toBe(A.name);
|
|
216
|
+
(0, vitest_1.expect)(c.in1.tgt).toBe(c.obj.name);
|
|
217
|
+
});
|
|
218
|
+
(0, vitest_1.it)('equalizer trivial: f = g ⇒ equalizer es el dominio entero', () => {
|
|
219
|
+
const f = (0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' });
|
|
220
|
+
const cat = (0, categorical_1.FinSet)([A, B], [f]);
|
|
221
|
+
const e = (0, categorical_1.equalizer)(cat, f, f);
|
|
222
|
+
(0, vitest_1.expect)(e).not.toBeNull();
|
|
223
|
+
if (!e)
|
|
224
|
+
return;
|
|
225
|
+
(0, vitest_1.expect)(e.obj.elements.length).toBe(A.elements.length);
|
|
226
|
+
});
|
|
227
|
+
(0, vitest_1.it)('equalizer no trivial: solo elementos donde f y g coinciden', () => {
|
|
228
|
+
const f = (0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' });
|
|
229
|
+
const g = (0, categorical_1.mkFinSetMor)('g', A, B, { a0: 'b0', a1: 'b2' });
|
|
230
|
+
const cat = (0, categorical_1.FinSet)([A, B], [f, g]);
|
|
231
|
+
const e = (0, categorical_1.equalizer)(cat, f, g);
|
|
232
|
+
(0, vitest_1.expect)(e).not.toBeNull();
|
|
233
|
+
if (!e)
|
|
234
|
+
return;
|
|
235
|
+
(0, vitest_1.expect)(e.obj.elements).toEqual(['a0']);
|
|
236
|
+
});
|
|
237
|
+
(0, vitest_1.it)('coequalizer colapsa elementos relacionados por f, g', () => {
|
|
238
|
+
const f = (0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' });
|
|
239
|
+
const g = (0, categorical_1.mkFinSetMor)('g', A, B, { a0: 'b1', a1: 'b1' });
|
|
240
|
+
const cat = (0, categorical_1.FinSet)([A, B], [f, g]);
|
|
241
|
+
const ce = (0, categorical_1.coequalizer)(cat, f, g);
|
|
242
|
+
(0, vitest_1.expect)(ce).not.toBeNull();
|
|
243
|
+
if (!ce)
|
|
244
|
+
return;
|
|
245
|
+
// b0 y b1 se colapsan (via a0), b2 queda solo.
|
|
246
|
+
(0, vitest_1.expect)(ce.obj.elements.length).toBe(2);
|
|
247
|
+
});
|
|
248
|
+
(0, vitest_1.it)('isCone valida correctamente un cono trivial', () => {
|
|
249
|
+
const cat = (0, categorical_1.FinSet)([A, B], [(0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' })]);
|
|
250
|
+
const diagram = {
|
|
251
|
+
vertices: new Map([['v', A]]),
|
|
252
|
+
edges: [],
|
|
253
|
+
};
|
|
254
|
+
const cone = {
|
|
255
|
+
apex: A,
|
|
256
|
+
legs: new Map([['v', cat.identity(A)]]),
|
|
257
|
+
};
|
|
258
|
+
(0, vitest_1.expect)((0, categorical_1.isCone)(cat, diagram, cone)).toBe(true);
|
|
259
|
+
});
|
|
260
|
+
(0, vitest_1.it)('isLimit verifica límite trivial (1 vértice = ese vértice)', () => {
|
|
261
|
+
const cat = (0, categorical_1.FinSet)([A], []);
|
|
262
|
+
const diagram = {
|
|
263
|
+
vertices: new Map([['v', A]]),
|
|
264
|
+
edges: [],
|
|
265
|
+
};
|
|
266
|
+
const cone = {
|
|
267
|
+
apex: A,
|
|
268
|
+
legs: new Map([['v', cat.identity(A)]]),
|
|
269
|
+
};
|
|
270
|
+
(0, vitest_1.expect)((0, categorical_1.isLimit)(cat, diagram, cone)).toBe(true);
|
|
271
|
+
});
|
|
272
|
+
});
|
|
273
|
+
(0, vitest_1.describe)('Monoidal (FinSet, ×, 1)', () => {
|
|
274
|
+
(0, vitest_1.it)('verifica unitor izquierdo: 1⊗A ≅ A', () => {
|
|
275
|
+
const mc = (0, categorical_1.FinSetMonoidal)([A, B]);
|
|
276
|
+
(0, vitest_1.expect)(mc.verifyLeftUnitor()).toBe(true);
|
|
277
|
+
});
|
|
278
|
+
(0, vitest_1.it)('verifica unitor derecho: A⊗1 ≅ A', () => {
|
|
279
|
+
const mc = (0, categorical_1.FinSetMonoidal)([A, B]);
|
|
280
|
+
(0, vitest_1.expect)(mc.verifyRightUnitor()).toBe(true);
|
|
281
|
+
});
|
|
282
|
+
(0, vitest_1.it)('verifica asociador: (A⊗B)⊗C ≅ A⊗(B⊗C)', () => {
|
|
283
|
+
const mc = (0, categorical_1.FinSetMonoidal)([A, B, C]);
|
|
284
|
+
(0, vitest_1.expect)(mc.verifyAssociator()).toBe(true);
|
|
285
|
+
});
|
|
286
|
+
(0, vitest_1.it)('tensor de objetos tiene cardinal producto', () => {
|
|
287
|
+
const mc = (0, categorical_1.FinSetMonoidal)([A, B]);
|
|
288
|
+
const AxB = mc.tensor(A, B);
|
|
289
|
+
(0, vitest_1.expect)(AxB.elements.length).toBe(A.elements.length * B.elements.length);
|
|
290
|
+
});
|
|
291
|
+
(0, vitest_1.it)('tensor de morfismos f×g aplica componentes', () => {
|
|
292
|
+
const mc = (0, categorical_1.FinSetMonoidal)([A, B]);
|
|
293
|
+
const f = (0, categorical_1.mkFinSetMor)('f', A, B, { a0: 'b0', a1: 'b1' });
|
|
294
|
+
const g = (0, categorical_1.mkFinSetMor)('g', B, A, { b0: 'a0', b1: 'a1', b2: 'a0' });
|
|
295
|
+
const fxg = mc.tensorMor(f, g);
|
|
296
|
+
(0, vitest_1.expect)(fxg.fn.get('a0∥b0')).toBe('b0∥a0');
|
|
297
|
+
(0, vitest_1.expect)(fxg.fn.get('a1∥b1')).toBe('b1∥a1');
|
|
298
|
+
});
|
|
299
|
+
});
|
|
300
|
+
//# sourceMappingURL=categorical.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"categorical.test.js","sourceRoot":"","sources":["../../../src/tests/categorical/categorical.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"csp-hoare.test.d.ts","sourceRoot":"","sources":["../../../src/tests/csp-hoare/csp-hoare.test.ts"],"names":[],"mappings":""}
|