@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.
Files changed (185) hide show
  1. package/dist/categorical/fin-set.d.ts +39 -0
  2. package/dist/categorical/fin-set.d.ts.map +1 -0
  3. package/dist/categorical/fin-set.js +217 -0
  4. package/dist/categorical/fin-set.js.map +1 -0
  5. package/dist/categorical/free.d.ts +23 -0
  6. package/dist/categorical/free.d.ts.map +1 -0
  7. package/dist/categorical/free.js +168 -0
  8. package/dist/categorical/free.js.map +1 -0
  9. package/dist/categorical/functor.d.ts +40 -0
  10. package/dist/categorical/functor.d.ts.map +1 -0
  11. package/dist/categorical/functor.js +139 -0
  12. package/dist/categorical/functor.js.map +1 -0
  13. package/dist/categorical/index.d.ts +11 -0
  14. package/dist/categorical/index.d.ts.map +1 -0
  15. package/dist/categorical/index.js +33 -0
  16. package/dist/categorical/index.js.map +1 -0
  17. package/dist/categorical/limits.d.ts +64 -0
  18. package/dist/categorical/limits.d.ts.map +1 -0
  19. package/dist/categorical/limits.js +248 -0
  20. package/dist/categorical/limits.js.map +1 -0
  21. package/dist/categorical/monoidal.d.ts +14 -0
  22. package/dist/categorical/monoidal.d.ts.map +1 -0
  23. package/dist/categorical/monoidal.js +148 -0
  24. package/dist/categorical/monoidal.js.map +1 -0
  25. package/dist/categorical/poset.d.ts +14 -0
  26. package/dist/categorical/poset.d.ts.map +1 -0
  27. package/dist/categorical/poset.js +115 -0
  28. package/dist/categorical/poset.js.map +1 -0
  29. package/dist/categorical/types.d.ts +111 -0
  30. package/dist/categorical/types.d.ts.map +1 -0
  31. package/dist/categorical/types.js +15 -0
  32. package/dist/categorical/types.js.map +1 -0
  33. package/dist/csp-hoare/analysis.d.ts +51 -0
  34. package/dist/csp-hoare/analysis.d.ts.map +1 -0
  35. package/dist/csp-hoare/analysis.js +317 -0
  36. package/dist/csp-hoare/analysis.js.map +1 -0
  37. package/dist/csp-hoare/examples.d.ts +33 -0
  38. package/dist/csp-hoare/examples.d.ts.map +1 -0
  39. package/dist/csp-hoare/examples.js +108 -0
  40. package/dist/csp-hoare/examples.js.map +1 -0
  41. package/dist/csp-hoare/index.d.ts +6 -0
  42. package/dist/csp-hoare/index.d.ts.map +1 -0
  43. package/dist/csp-hoare/index.js +50 -0
  44. package/dist/csp-hoare/index.js.map +1 -0
  45. package/dist/csp-hoare/semantics.d.ts +49 -0
  46. package/dist/csp-hoare/semantics.d.ts.map +1 -0
  47. package/dist/csp-hoare/semantics.js +494 -0
  48. package/dist/csp-hoare/semantics.js.map +1 -0
  49. package/dist/csp-hoare/types.d.ts +60 -0
  50. package/dist/csp-hoare/types.d.ts.map +1 -0
  51. package/dist/csp-hoare/types.js +31 -0
  52. package/dist/csp-hoare/types.js.map +1 -0
  53. package/dist/hindley-milner/index.d.ts +7 -0
  54. package/dist/hindley-milner/index.d.ts.map +1 -0
  55. package/dist/hindley-milner/index.js +60 -0
  56. package/dist/hindley-milner/index.js.map +1 -0
  57. package/dist/hindley-milner/infer.d.ts +26 -0
  58. package/dist/hindley-milner/infer.d.ts.map +1 -0
  59. package/dist/hindley-milner/infer.js +278 -0
  60. package/dist/hindley-milner/infer.js.map +1 -0
  61. package/dist/hindley-milner/substitution.d.ts +21 -0
  62. package/dist/hindley-milner/substitution.d.ts.map +1 -0
  63. package/dist/hindley-milner/substitution.js +215 -0
  64. package/dist/hindley-milner/substitution.js.map +1 -0
  65. package/dist/hindley-milner/types.d.ts +84 -0
  66. package/dist/hindley-milner/types.d.ts.map +1 -0
  67. package/dist/hindley-milner/types.js +166 -0
  68. package/dist/hindley-milner/types.js.map +1 -0
  69. package/dist/hott/equality.d.ts +4 -0
  70. package/dist/hott/equality.d.ts.map +1 -0
  71. package/dist/hott/equality.js +108 -0
  72. package/dist/hott/equality.js.map +1 -0
  73. package/dist/hott/index.d.ts +13 -0
  74. package/dist/hott/index.d.ts.map +1 -0
  75. package/dist/hott/index.js +77 -0
  76. package/dist/hott/index.js.map +1 -0
  77. package/dist/hott/infer.d.ts +11 -0
  78. package/dist/hott/infer.d.ts.map +1 -0
  79. package/dist/hott/infer.js +465 -0
  80. package/dist/hott/infer.js.map +1 -0
  81. package/dist/hott/normalize.d.ts +5 -0
  82. package/dist/hott/normalize.d.ts.map +1 -0
  83. package/dist/hott/normalize.js +240 -0
  84. package/dist/hott/normalize.js.map +1 -0
  85. package/dist/hott/path-algebra.d.ts +25 -0
  86. package/dist/hott/path-algebra.d.ts.map +1 -0
  87. package/dist/hott/path-algebra.js +67 -0
  88. package/dist/hott/path-algebra.js.map +1 -0
  89. package/dist/hott/substitute.d.ts +3 -0
  90. package/dist/hott/substitute.d.ts.map +1 -0
  91. package/dist/hott/substitute.js +131 -0
  92. package/dist/hott/substitute.js.map +1 -0
  93. package/dist/hott/types.d.ts +126 -0
  94. package/dist/hott/types.d.ts.map +1 -0
  95. package/dist/hott/types.js +346 -0
  96. package/dist/hott/types.js.map +1 -0
  97. package/dist/index.d.ts +7 -0
  98. package/dist/index.d.ts.map +1 -1
  99. package/dist/index.js +48 -3
  100. package/dist/index.js.map +1 -1
  101. package/dist/lemma-synthesis/index.d.ts +124 -0
  102. package/dist/lemma-synthesis/index.d.ts.map +1 -0
  103. package/dist/lemma-synthesis/index.js +640 -0
  104. package/dist/lemma-synthesis/index.js.map +1 -0
  105. package/dist/tactic-dsl/combinators.d.ts +6 -0
  106. package/dist/tactic-dsl/combinators.d.ts.map +1 -0
  107. package/dist/tactic-dsl/combinators.js +98 -0
  108. package/dist/tactic-dsl/combinators.js.map +1 -0
  109. package/dist/tactic-dsl/index.d.ts +39 -0
  110. package/dist/tactic-dsl/index.d.ts.map +1 -0
  111. package/dist/tactic-dsl/index.js +162 -0
  112. package/dist/tactic-dsl/index.js.map +1 -0
  113. package/dist/tactic-dsl/tactics.d.ts +21 -0
  114. package/dist/tactic-dsl/tactics.d.ts.map +1 -0
  115. package/dist/tactic-dsl/tactics.js +536 -0
  116. package/dist/tactic-dsl/tactics.js.map +1 -0
  117. package/dist/tactic-dsl/types.d.ts +54 -0
  118. package/dist/tactic-dsl/types.d.ts.map +1 -0
  119. package/dist/tactic-dsl/types.js +226 -0
  120. package/dist/tactic-dsl/types.js.map +1 -0
  121. package/dist/tests/categorical/categorical.test.d.ts +2 -0
  122. package/dist/tests/categorical/categorical.test.d.ts.map +1 -0
  123. package/dist/tests/categorical/categorical.test.js +300 -0
  124. package/dist/tests/categorical/categorical.test.js.map +1 -0
  125. package/dist/tests/csp-hoare/csp-hoare.test.d.ts +2 -0
  126. package/dist/tests/csp-hoare/csp-hoare.test.d.ts.map +1 -0
  127. package/dist/tests/csp-hoare/csp-hoare.test.js +313 -0
  128. package/dist/tests/csp-hoare/csp-hoare.test.js.map +1 -0
  129. package/dist/tests/hindley-milner/hindley-milner.test.d.ts +2 -0
  130. package/dist/tests/hindley-milner/hindley-milner.test.d.ts.map +1 -0
  131. package/dist/tests/hindley-milner/hindley-milner.test.js +327 -0
  132. package/dist/tests/hindley-milner/hindley-milner.test.js.map +1 -0
  133. package/dist/tests/hott/hott.test.d.ts +2 -0
  134. package/dist/tests/hott/hott.test.d.ts.map +1 -0
  135. package/dist/tests/hott/hott.test.js +271 -0
  136. package/dist/tests/hott/hott.test.js.map +1 -0
  137. package/dist/tests/lemma-synthesis/lemma-synthesis.test.d.ts +2 -0
  138. package/dist/tests/lemma-synthesis/lemma-synthesis.test.d.ts.map +1 -0
  139. package/dist/tests/lemma-synthesis/lemma-synthesis.test.js +460 -0
  140. package/dist/tests/lemma-synthesis/lemma-synthesis.test.js.map +1 -0
  141. package/dist/tests/tactic-dsl/tactic-dsl.test.d.ts +2 -0
  142. package/dist/tests/tactic-dsl/tactic-dsl.test.d.ts.map +1 -0
  143. package/dist/tests/tactic-dsl/tactic-dsl.test.js +259 -0
  144. package/dist/tests/tactic-dsl/tactic-dsl.test.js.map +1 -0
  145. package/dist/tests/tptp/bridge.test.d.ts +2 -0
  146. package/dist/tests/tptp/bridge.test.d.ts.map +1 -0
  147. package/dist/tests/tptp/bridge.test.js +154 -0
  148. package/dist/tests/tptp/bridge.test.js.map +1 -0
  149. package/dist/tests/tptp/emitter.test.d.ts +2 -0
  150. package/dist/tests/tptp/emitter.test.d.ts.map +1 -0
  151. package/dist/tests/tptp/emitter.test.js +128 -0
  152. package/dist/tests/tptp/emitter.test.js.map +1 -0
  153. package/dist/tests/tptp/parser.test.d.ts +2 -0
  154. package/dist/tests/tptp/parser.test.d.ts.map +1 -0
  155. package/dist/tests/tptp/parser.test.js +192 -0
  156. package/dist/tests/tptp/parser.test.js.map +1 -0
  157. package/dist/tests/tptp/tokenizer.test.d.ts +2 -0
  158. package/dist/tests/tptp/tokenizer.test.d.ts.map +1 -0
  159. package/dist/tests/tptp/tokenizer.test.js +60 -0
  160. package/dist/tests/tptp/tokenizer.test.js.map +1 -0
  161. package/dist/tptp/ast.d.ts +73 -0
  162. package/dist/tptp/ast.d.ts.map +1 -0
  163. package/dist/tptp/ast.js +35 -0
  164. package/dist/tptp/ast.js.map +1 -0
  165. package/dist/tptp/bridge.d.ts +14 -0
  166. package/dist/tptp/bridge.d.ts.map +1 -0
  167. package/dist/tptp/bridge.js +146 -0
  168. package/dist/tptp/bridge.js.map +1 -0
  169. package/dist/tptp/emitter.d.ts +5 -0
  170. package/dist/tptp/emitter.d.ts.map +1 -0
  171. package/dist/tptp/emitter.js +103 -0
  172. package/dist/tptp/emitter.js.map +1 -0
  173. package/dist/tptp/index.d.ts +7 -0
  174. package/dist/tptp/index.d.ts.map +1 -0
  175. package/dist/tptp/index.js +31 -0
  176. package/dist/tptp/index.js.map +1 -0
  177. package/dist/tptp/parser.d.ts +23 -0
  178. package/dist/tptp/parser.d.ts.map +1 -0
  179. package/dist/tptp/parser.js +440 -0
  180. package/dist/tptp/parser.js.map +1 -0
  181. package/dist/tptp/tokenizer.d.ts +14 -0
  182. package/dist/tptp/tokenizer.d.ts.map +1 -0
  183. package/dist/tptp/tokenizer.js +264 -0
  184. package/dist/tptp/tokenizer.js.map +1 -0
  185. 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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=categorical.test.d.ts.map
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=csp-hoare.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"csp-hoare.test.d.ts","sourceRoot":"","sources":["../../../src/tests/csp-hoare/csp-hoare.test.ts"],"names":[],"mappings":""}