@stevenvo780/st-lang 4.12.0 → 4.14.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 (97) hide show
  1. package/dist/reasoning/datalog/index.d.ts +131 -0
  2. package/dist/reasoning/datalog/index.d.ts.map +1 -0
  3. package/dist/reasoning/datalog/index.js +706 -0
  4. package/dist/reasoning/datalog/index.js.map +1 -0
  5. package/dist/reasoning/galois-fields/index.d.ts +29 -0
  6. package/dist/reasoning/galois-fields/index.d.ts.map +1 -0
  7. package/dist/reasoning/galois-fields/index.js +522 -0
  8. package/dist/reasoning/galois-fields/index.js.map +1 -0
  9. package/dist/reasoning/hoare-logic/index.d.ts +130 -0
  10. package/dist/reasoning/hoare-logic/index.d.ts.map +1 -0
  11. package/dist/reasoning/hoare-logic/index.js +535 -0
  12. package/dist/reasoning/hoare-logic/index.js.map +1 -0
  13. package/dist/reasoning/lattice/index.d.ts +165 -0
  14. package/dist/reasoning/lattice/index.d.ts.map +1 -0
  15. package/dist/reasoning/lattice/index.js +587 -0
  16. package/dist/reasoning/lattice/index.js.map +1 -0
  17. package/dist/reasoning/model-checking/index.d.ts +113 -0
  18. package/dist/reasoning/model-checking/index.d.ts.map +1 -0
  19. package/dist/reasoning/model-checking/index.js +786 -0
  20. package/dist/reasoning/model-checking/index.js.map +1 -0
  21. package/dist/reasoning/polynomial-ring/index.d.ts +30 -0
  22. package/dist/reasoning/polynomial-ring/index.d.ts.map +1 -0
  23. package/dist/reasoning/polynomial-ring/index.js +797 -0
  24. package/dist/reasoning/polynomial-ring/index.js.map +1 -0
  25. package/dist/reasoning/separation-logic/index.d.ts +190 -0
  26. package/dist/reasoning/separation-logic/index.d.ts.map +1 -0
  27. package/dist/reasoning/separation-logic/index.js +758 -0
  28. package/dist/reasoning/separation-logic/index.js.map +1 -0
  29. package/dist/reasoning/universal-algebra/index.d.ts +196 -0
  30. package/dist/reasoning/universal-algebra/index.d.ts.map +1 -0
  31. package/dist/reasoning/universal-algebra/index.js +865 -0
  32. package/dist/reasoning/universal-algebra/index.js.map +1 -0
  33. package/dist/tests/reasoning/datalog/datalog.test.d.ts +2 -0
  34. package/dist/tests/reasoning/datalog/datalog.test.d.ts.map +1 -0
  35. package/dist/tests/reasoning/datalog/datalog.test.js +333 -0
  36. package/dist/tests/reasoning/datalog/datalog.test.js.map +1 -0
  37. package/dist/tests/reasoning/galois-fields/galois-fields.test.d.ts +2 -0
  38. package/dist/tests/reasoning/galois-fields/galois-fields.test.d.ts.map +1 -0
  39. package/dist/tests/reasoning/galois-fields/galois-fields.test.js +226 -0
  40. package/dist/tests/reasoning/galois-fields/galois-fields.test.js.map +1 -0
  41. package/dist/tests/reasoning/hoare-logic/hoare-logic.test.d.ts +2 -0
  42. package/dist/tests/reasoning/hoare-logic/hoare-logic.test.d.ts.map +1 -0
  43. package/dist/tests/reasoning/hoare-logic/hoare-logic.test.js +340 -0
  44. package/dist/tests/reasoning/hoare-logic/hoare-logic.test.js.map +1 -0
  45. package/dist/tests/reasoning/lattice/lattice.test.d.ts +2 -0
  46. package/dist/tests/reasoning/lattice/lattice.test.d.ts.map +1 -0
  47. package/dist/tests/reasoning/lattice/lattice.test.js +238 -0
  48. package/dist/tests/reasoning/lattice/lattice.test.js.map +1 -0
  49. package/dist/tests/reasoning/model-checking/model-checking.test.d.ts +2 -0
  50. package/dist/tests/reasoning/model-checking/model-checking.test.d.ts.map +1 -0
  51. package/dist/tests/reasoning/model-checking/model-checking.test.js +222 -0
  52. package/dist/tests/reasoning/model-checking/model-checking.test.js.map +1 -0
  53. package/dist/tests/reasoning/polynomial-ring/polynomial-ring.test.d.ts +2 -0
  54. package/dist/tests/reasoning/polynomial-ring/polynomial-ring.test.d.ts.map +1 -0
  55. package/dist/tests/reasoning/polynomial-ring/polynomial-ring.test.js +230 -0
  56. package/dist/tests/reasoning/polynomial-ring/polynomial-ring.test.js.map +1 -0
  57. package/dist/tests/reasoning/separation-logic/separation-logic.test.d.ts +2 -0
  58. package/dist/tests/reasoning/separation-logic/separation-logic.test.d.ts.map +1 -0
  59. package/dist/tests/reasoning/separation-logic/separation-logic.test.js +311 -0
  60. package/dist/tests/reasoning/separation-logic/separation-logic.test.js.map +1 -0
  61. package/dist/tests/reasoning/universal-algebra/universal-algebra.test.d.ts +2 -0
  62. package/dist/tests/reasoning/universal-algebra/universal-algebra.test.d.ts.map +1 -0
  63. package/dist/tests/reasoning/universal-algebra/universal-algebra.test.js +289 -0
  64. package/dist/tests/reasoning/universal-algebra/universal-algebra.test.js.map +1 -0
  65. package/dist/tests/type-theory/lambda-cube/lambda-cube.test.d.ts +2 -0
  66. package/dist/tests/type-theory/lambda-cube/lambda-cube.test.d.ts.map +1 -0
  67. package/dist/tests/type-theory/lambda-cube/lambda-cube.test.js +266 -0
  68. package/dist/tests/type-theory/lambda-cube/lambda-cube.test.js.map +1 -0
  69. package/dist/type-theory/lambda-cube/erase.d.ts +26 -0
  70. package/dist/type-theory/lambda-cube/erase.d.ts.map +1 -0
  71. package/dist/type-theory/lambda-cube/erase.js +68 -0
  72. package/dist/type-theory/lambda-cube/erase.js.map +1 -0
  73. package/dist/type-theory/lambda-cube/examples.d.ts +59 -0
  74. package/dist/type-theory/lambda-cube/examples.d.ts.map +1 -0
  75. package/dist/type-theory/lambda-cube/examples.js +110 -0
  76. package/dist/type-theory/lambda-cube/examples.js.map +1 -0
  77. package/dist/type-theory/lambda-cube/index.d.ts +11 -0
  78. package/dist/type-theory/lambda-cube/index.d.ts.map +1 -0
  79. package/dist/type-theory/lambda-cube/index.js +64 -0
  80. package/dist/type-theory/lambda-cube/index.js.map +1 -0
  81. package/dist/type-theory/lambda-cube/normalize.d.ts +17 -0
  82. package/dist/type-theory/lambda-cube/normalize.d.ts.map +1 -0
  83. package/dist/type-theory/lambda-cube/normalize.js +134 -0
  84. package/dist/type-theory/lambda-cube/normalize.js.map +1 -0
  85. package/dist/type-theory/lambda-cube/rules.d.ts +26 -0
  86. package/dist/type-theory/lambda-cube/rules.d.ts.map +1 -0
  87. package/dist/type-theory/lambda-cube/rules.js +67 -0
  88. package/dist/type-theory/lambda-cube/rules.js.map +1 -0
  89. package/dist/type-theory/lambda-cube/typecheck.d.ts +20 -0
  90. package/dist/type-theory/lambda-cube/typecheck.d.ts.map +1 -0
  91. package/dist/type-theory/lambda-cube/typecheck.js +168 -0
  92. package/dist/type-theory/lambda-cube/typecheck.js.map +1 -0
  93. package/dist/type-theory/lambda-cube/types.d.ts +40 -0
  94. package/dist/type-theory/lambda-cube/types.d.ts.map +1 -0
  95. package/dist/type-theory/lambda-cube/types.js +192 -0
  96. package/dist/type-theory/lambda-cube/types.js.map +1 -0
  97. package/package.json +1 -1
@@ -0,0 +1,226 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const vitest_1 = require("vitest");
4
+ const galois_fields_1 = require("../../../reasoning/galois-fields");
5
+ // Helpers ----------------------------------------------------
6
+ function enumerateElements(F) {
7
+ const out = [];
8
+ for (let k = 0; k < F.order; k++) {
9
+ const coeffs = Array.from({ length: F.degree }, () => 0);
10
+ let x = k;
11
+ for (let i = 0; i < F.degree; i++) {
12
+ coeffs[i] = x % F.prime;
13
+ x = Math.floor(x / F.prime);
14
+ }
15
+ out.push((0, galois_fields_1.gfElement)(F, coeffs));
16
+ }
17
+ return out;
18
+ }
19
+ (0, vitest_1.describe)('Galois Fields — irreducibles', () => {
20
+ (0, vitest_1.it)('findIrreducibleOverZp(2, 1) devuelve x', () => {
21
+ (0, vitest_1.expect)((0, galois_fields_1.findIrreducibleOverZp)(2, 1)).toEqual([0, 1]);
22
+ });
23
+ (0, vitest_1.it)('findIrreducibleOverZp(2, 3) devuelve un polinomio de grado 3 mónico', () => {
24
+ const f = (0, galois_fields_1.findIrreducibleOverZp)(2, 3);
25
+ (0, vitest_1.expect)(f).not.toBeNull();
26
+ (0, vitest_1.expect)(f && f[f.length - 1]).toBe(1);
27
+ (0, vitest_1.expect)(f && f.length).toBe(4);
28
+ });
29
+ (0, vitest_1.it)('findIrreducibleOverZp(3, 2) existe y es de grado 2', () => {
30
+ const f = (0, galois_fields_1.findIrreducibleOverZp)(3, 2);
31
+ (0, vitest_1.expect)(f).not.toBeNull();
32
+ (0, vitest_1.expect)(f && f.length).toBe(3);
33
+ });
34
+ (0, vitest_1.it)('rechaza p no primo', () => {
35
+ (0, vitest_1.expect)(() => (0, galois_fields_1.findIrreducibleOverZp)(4, 2)).toThrow();
36
+ });
37
+ });
38
+ (0, vitest_1.describe)('Galois Fields — GF(p)', () => {
39
+ (0, vitest_1.it)('GF(2): suma equivale a XOR', () => {
40
+ const F = (0, galois_fields_1.makeGaloisField)(2, 1);
41
+ const zero = (0, galois_fields_1.gfZero)(F);
42
+ const one = (0, galois_fields_1.gfOne)(F);
43
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfAdd)(F, one, one), zero)).toBe(true);
44
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfAdd)(F, one, zero), one)).toBe(true);
45
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfAdd)(F, zero, zero), zero)).toBe(true);
46
+ });
47
+ (0, vitest_1.it)('GF(2): multiplicación equivale a AND', () => {
48
+ const F = (0, galois_fields_1.makeGaloisField)(2, 1);
49
+ const zero = (0, galois_fields_1.gfZero)(F);
50
+ const one = (0, galois_fields_1.gfOne)(F);
51
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfMul)(F, one, one), one)).toBe(true);
52
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfMul)(F, one, zero), zero)).toBe(true);
53
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfMul)(F, zero, zero), zero)).toBe(true);
54
+ });
55
+ (0, vitest_1.it)('GF(7): inverso de cada no-cero da 1', () => {
56
+ const F = (0, galois_fields_1.makeGaloisField)(7, 1);
57
+ for (let k = 1; k < 7; k++) {
58
+ const a = (0, galois_fields_1.gfElement)(F, [k]);
59
+ const inv = (0, galois_fields_1.gfInverse)(F, a);
60
+ (0, vitest_1.expect)(inv).not.toBeNull();
61
+ if (inv)
62
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfMul)(F, a, inv), (0, galois_fields_1.gfOne)(F))).toBe(true);
63
+ }
64
+ });
65
+ (0, vitest_1.it)('GF(7) tiene primitivo y su orden es 6', () => {
66
+ const F = (0, galois_fields_1.makeGaloisField)(7, 1);
67
+ const g = (0, galois_fields_1.findPrimitive)(F);
68
+ (0, vitest_1.expect)((0, galois_fields_1.order)(F, g)).toBe(6);
69
+ });
70
+ });
71
+ (0, vitest_1.describe)('Galois Fields — GF(2^3)', () => {
72
+ const F = (0, galois_fields_1.makeGaloisField)(2, 3);
73
+ (0, vitest_1.it)('orden del cuerpo = 8', () => {
74
+ (0, vitest_1.expect)(F.order).toBe(8);
75
+ });
76
+ (0, vitest_1.it)('todo no-cero tiene inverso y a · a^-1 = 1', () => {
77
+ const elements = enumerateElements(F);
78
+ const one = (0, galois_fields_1.gfOne)(F);
79
+ for (const a of elements) {
80
+ if ((0, galois_fields_1.gfEq)(a, (0, galois_fields_1.gfZero)(F)))
81
+ continue;
82
+ const inv = (0, galois_fields_1.gfInverse)(F, a);
83
+ (0, vitest_1.expect)(inv).not.toBeNull();
84
+ if (inv)
85
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfMul)(F, a, inv), one)).toBe(true);
86
+ }
87
+ });
88
+ (0, vitest_1.it)('Fermat little: a^(p^n - 1) = 1 para todo no-cero', () => {
89
+ const exp = BigInt(F.order - 1);
90
+ const one = (0, galois_fields_1.gfOne)(F);
91
+ for (const a of enumerateElements(F)) {
92
+ if ((0, galois_fields_1.gfEq)(a, (0, galois_fields_1.gfZero)(F)))
93
+ continue;
94
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfPow)(F, a, exp), one)).toBe(true);
95
+ }
96
+ });
97
+ (0, vitest_1.it)('existe primitivo y su orden divide a p^n − 1', () => {
98
+ const g = (0, galois_fields_1.findPrimitive)(F);
99
+ const ord = (0, galois_fields_1.order)(F, g);
100
+ (0, vitest_1.expect)(ord).toBe(F.order - 1);
101
+ (0, vitest_1.expect)((F.order - 1) % ord).toBe(0);
102
+ });
103
+ });
104
+ (0, vitest_1.describe)('Galois Fields — GF(2^4)', () => {
105
+ const F = (0, galois_fields_1.makeGaloisField)(2, 4);
106
+ (0, vitest_1.it)('orden = 16 y existe primitivo de orden 15', () => {
107
+ (0, vitest_1.expect)(F.order).toBe(16);
108
+ const g = (0, galois_fields_1.findPrimitive)(F);
109
+ (0, vitest_1.expect)((0, galois_fields_1.order)(F, g)).toBe(15);
110
+ });
111
+ (0, vitest_1.it)('discreteLog inverso de gfPow', () => {
112
+ const g = (0, galois_fields_1.findPrimitive)(F);
113
+ for (let k = 0; k < F.order - 1; k++) {
114
+ const target = (0, galois_fields_1.gfPow)(F, g, BigInt(k));
115
+ const log = (0, galois_fields_1.discreteLog)(F, g, target);
116
+ (0, vitest_1.expect)(log).toBe(k);
117
+ }
118
+ });
119
+ (0, vitest_1.it)('gfDiv consistente con gfMul + inverso', () => {
120
+ const a = (0, galois_fields_1.gfElement)(F, [1, 1, 0, 1]);
121
+ const b = (0, galois_fields_1.gfElement)(F, [0, 1, 1, 0]);
122
+ const q = (0, galois_fields_1.gfDiv)(F, a, b);
123
+ (0, vitest_1.expect)(q).not.toBeNull();
124
+ if (q)
125
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfMul)(F, q, b), a)).toBe(true);
126
+ });
127
+ });
128
+ (0, vitest_1.describe)('Galois Fields — leyes algebraicas (GF(3^2))', () => {
129
+ const F = (0, galois_fields_1.makeGaloisField)(3, 2);
130
+ (0, vitest_1.it)('suma asociativa y conmutativa', () => {
131
+ const elements = enumerateElements(F);
132
+ // Muestreo: 3 triples (a,b,c) deterministas.
133
+ const samples = [];
134
+ for (let i = 0; i < 4; i++) {
135
+ const a = elements[(i * 3) % elements.length];
136
+ const b = elements[(i * 5 + 1) % elements.length];
137
+ const c = elements[(i * 7 + 2) % elements.length];
138
+ if (a && b && c)
139
+ samples.push([a, b, c]);
140
+ }
141
+ for (const [a, b, c] of samples) {
142
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfAdd)(F, a, b), (0, galois_fields_1.gfAdd)(F, b, a))).toBe(true);
143
+ const left = (0, galois_fields_1.gfAdd)(F, (0, galois_fields_1.gfAdd)(F, a, b), c);
144
+ const right = (0, galois_fields_1.gfAdd)(F, a, (0, galois_fields_1.gfAdd)(F, b, c));
145
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)(left, right)).toBe(true);
146
+ }
147
+ });
148
+ (0, vitest_1.it)('multiplicación distributiva sobre la suma', () => {
149
+ const elements = enumerateElements(F);
150
+ for (let i = 0; i < 5; i++) {
151
+ const a = elements[(i * 2) % elements.length];
152
+ const b = elements[(i * 3 + 1) % elements.length];
153
+ const c = elements[(i * 5 + 2) % elements.length];
154
+ if (!a || !b || !c)
155
+ continue;
156
+ const left = (0, galois_fields_1.gfMul)(F, a, (0, galois_fields_1.gfAdd)(F, b, c));
157
+ const right = (0, galois_fields_1.gfAdd)(F, (0, galois_fields_1.gfMul)(F, a, b), (0, galois_fields_1.gfMul)(F, a, c));
158
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)(left, right)).toBe(true);
159
+ }
160
+ });
161
+ (0, vitest_1.it)('a − a = 0 y a + (−a) = 0', () => {
162
+ for (const a of enumerateElements(F)) {
163
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfSub)(F, a, a), (0, galois_fields_1.gfZero)(F))).toBe(true);
164
+ }
165
+ });
166
+ });
167
+ (0, vitest_1.describe)('Galois Fields — Reed-Solomon encoding (GF(2^3))', () => {
168
+ const F = (0, galois_fields_1.makeGaloisField)(2, 3);
169
+ (0, vitest_1.it)('rsEncode con mensaje constante c devuelve [c, c, ...]', () => {
170
+ const c = (0, galois_fields_1.gfElement)(F, [1, 0, 1]);
171
+ const word = (0, galois_fields_1.rsEncode)(F, [c], 5);
172
+ (0, vitest_1.expect)(word.length).toBe(5);
173
+ for (const w of word) {
174
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)(w, c)).toBe(true);
175
+ }
176
+ });
177
+ (0, vitest_1.it)('rsEncode evalúa el polinomio en potencias del primitivo', () => {
178
+ const g = (0, galois_fields_1.findPrimitive)(F);
179
+ const m0 = (0, galois_fields_1.gfOne)(F);
180
+ const m1 = (0, galois_fields_1.gfOne)(F);
181
+ // polinomio P(x) = 1 + x
182
+ const word = (0, galois_fields_1.rsEncode)(F, [m0, m1], 3);
183
+ (0, vitest_1.expect)(word.length).toBe(3);
184
+ // P(1) = 1+1 = 0 en GF(2^k)
185
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)(word[0], (0, galois_fields_1.gfZero)(F))).toBe(true);
186
+ // P(g) = 1 + g
187
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)(word[1], (0, galois_fields_1.gfAdd)(F, (0, galois_fields_1.gfOne)(F), g))).toBe(true);
188
+ });
189
+ });
190
+ (0, vitest_1.describe)('Galois Fields — errores y bordes', () => {
191
+ (0, vitest_1.it)('gfInverse(0) = null', () => {
192
+ const F = (0, galois_fields_1.makeGaloisField)(5, 2);
193
+ (0, vitest_1.expect)((0, galois_fields_1.gfInverse)(F, (0, galois_fields_1.gfZero)(F))).toBeNull();
194
+ });
195
+ (0, vitest_1.it)('gfDiv por 0 devuelve null', () => {
196
+ const F = (0, galois_fields_1.makeGaloisField)(5, 2);
197
+ const a = (0, galois_fields_1.gfElement)(F, [1, 2]);
198
+ (0, vitest_1.expect)((0, galois_fields_1.gfDiv)(F, a, (0, galois_fields_1.gfZero)(F))).toBeNull();
199
+ });
200
+ (0, vitest_1.it)('gfPow con exponente 0 da 1', () => {
201
+ const F = (0, galois_fields_1.makeGaloisField)(3, 2);
202
+ const a = (0, galois_fields_1.gfElement)(F, [2, 1]);
203
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfPow)(F, a, 0n), (0, galois_fields_1.gfOne)(F))).toBe(true);
204
+ });
205
+ (0, vitest_1.it)('gfPow exponente negativo usa inverso', () => {
206
+ const F = (0, galois_fields_1.makeGaloisField)(5, 1);
207
+ const a = (0, galois_fields_1.gfElement)(F, [3]);
208
+ // 3^(-1) mod 5 = 2
209
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)((0, galois_fields_1.gfPow)(F, a, -1n), (0, galois_fields_1.gfElement)(F, [2]))).toBe(true);
210
+ });
211
+ (0, vitest_1.it)('makeGaloisField rechaza irreducible reducible', () => {
212
+ // (x^2) sobre Z/2 NO es irreducible.
213
+ (0, vitest_1.expect)(() => (0, galois_fields_1.makeGaloisField)(2, 2, [0, 0, 1])).toThrow();
214
+ });
215
+ (0, vitest_1.it)('makeGaloisField acepta irreducible explícito válido para GF(2^2)', () => {
216
+ // x^2 + x + 1 sobre Z/2 es irreducible.
217
+ const F = (0, galois_fields_1.makeGaloisField)(2, 2, [1, 1, 1]);
218
+ (0, vitest_1.expect)(F.order).toBe(4);
219
+ // Verificar que (1 + x) * (1 + x) reducido tiene sentido.
220
+ const a = (0, galois_fields_1.gfElement)(F, [1, 1]);
221
+ const a2 = (0, galois_fields_1.gfMul)(F, a, a);
222
+ // (1+x)^2 = 1 + 2x + x^2 = 1 + x^2 ≡ 1 + (x+1) = x (mod x^2+x+1, en Z/2)
223
+ (0, vitest_1.expect)((0, galois_fields_1.gfEq)(a2, (0, galois_fields_1.gfElement)(F, [0, 1]))).toBe(true);
224
+ });
225
+ });
226
+ //# sourceMappingURL=galois-fields.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"galois-fields.test.js","sourceRoot":"","sources":["../../../../src/tests/reasoning/galois-fields/galois-fields.test.ts"],"names":[],"mappings":";;AAAA,mCAA8C;AAC9C,oEAkB0C;AAE1C,+DAA+D;AAE/D,SAAS,iBAAiB,CAAC,CAAqC;IAC9D,MAAM,GAAG,GAAgB,EAAE,CAAC;IAC5B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;QACjC,MAAM,MAAM,GAAa,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,GAAG,CAAC,CAAC;QACV,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAClC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;YACxB,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;QACD,GAAG,CAAC,IAAI,CAAC,IAAA,yBAAS,EAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;IACjC,CAAC;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AAED,IAAA,iBAAQ,EAAC,8BAA8B,EAAE,GAAG,EAAE;IAC5C,IAAA,WAAE,EAAC,wCAAwC,EAAE,GAAG,EAAE;QAChD,IAAA,eAAM,EAAC,IAAA,qCAAqB,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,qEAAqE,EAAE,GAAG,EAAE;QAC7E,MAAM,CAAC,GAAG,IAAA,qCAAqB,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACtC,IAAA,eAAM,EAAC,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACzB,IAAA,eAAM,EAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACrC,IAAA,eAAM,EAAC,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,oDAAoD,EAAE,GAAG,EAAE;QAC5D,MAAM,CAAC,GAAG,IAAA,qCAAqB,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACtC,IAAA,eAAM,EAAC,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACzB,IAAA,eAAM,EAAC,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,oBAAoB,EAAE,GAAG,EAAE;QAC5B,IAAA,eAAM,EAAC,GAAG,EAAE,CAAC,IAAA,qCAAqB,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;IACtD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,iBAAQ,EAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,IAAA,WAAE,EAAC,4BAA4B,EAAE,GAAG,EAAE;QACpC,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAChC,MAAM,IAAI,GAAG,IAAA,sBAAM,EAAC,CAAC,CAAC,CAAC;QACvB,MAAM,GAAG,GAAG,IAAA,qBAAK,EAAC,CAAC,CAAC,CAAC;QACrB,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClD,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClD,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,sCAAsC,EAAE,GAAG,EAAE;QAC9C,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAChC,MAAM,IAAI,GAAG,IAAA,sBAAM,EAAC,CAAC,CAAC,CAAC;QACvB,MAAM,GAAG,GAAG,IAAA,qBAAK,EAAC,CAAC,CAAC,CAAC;QACrB,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjD,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnD,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,qCAAqC,EAAE,GAAG,EAAE;QAC7C,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC3B,MAAM,CAAC,GAAG,IAAA,yBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5B,MAAM,GAAG,GAAG,IAAA,yBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC5B,IAAA,eAAM,EAAC,GAAG,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;YAC3B,IAAI,GAAG;gBAAE,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,IAAA,qBAAK,EAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/D,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,uCAAuC,EAAE,GAAG,EAAE;QAC/C,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,GAAG,IAAA,6BAAa,EAAC,CAAC,CAAC,CAAC;QAC3B,IAAA,eAAM,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,iBAAQ,EAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAEhC,IAAA,WAAE,EAAC,sBAAsB,EAAE,GAAG,EAAE;QAC9B,IAAA,eAAM,EAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,QAAQ,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAAC;QACtC,MAAM,GAAG,GAAG,IAAA,qBAAK,EAAC,CAAC,CAAC,CAAC;QACrB,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;YACzB,IAAI,IAAA,oBAAI,EAAC,CAAC,EAAE,IAAA,sBAAM,EAAC,CAAC,CAAC,CAAC;gBAAE,SAAS;YACjC,MAAM,GAAG,GAAG,IAAA,yBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC5B,IAAA,eAAM,EAAC,GAAG,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;YAC3B,IAAI,GAAG;gBAAE,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1D,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,kDAAkD,EAAE,GAAG,EAAE;QAC1D,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QAChC,MAAM,GAAG,GAAG,IAAA,qBAAK,EAAC,CAAC,CAAC,CAAC;QACrB,KAAK,MAAM,CAAC,IAAI,iBAAiB,CAAC,CAAC,CAAC,EAAE,CAAC;YACrC,IAAI,IAAA,oBAAI,EAAC,CAAC,EAAE,IAAA,sBAAM,EAAC,CAAC,CAAC,CAAC;gBAAE,SAAS;YACjC,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjD,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,8CAA8C,EAAE,GAAG,EAAE;QACtD,MAAM,CAAC,GAAG,IAAA,6BAAa,EAAC,CAAC,CAAC,CAAC;QAC3B,MAAM,GAAG,GAAG,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACxB,IAAA,eAAM,EAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QAC9B,IAAA,eAAM,EAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,iBAAQ,EAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAEhC,IAAA,WAAE,EAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,IAAA,eAAM,EAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACzB,MAAM,CAAC,GAAG,IAAA,6BAAa,EAAC,CAAC,CAAC,CAAC;QAC3B,IAAA,eAAM,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,8BAA8B,EAAE,GAAG,EAAE;QACtC,MAAM,CAAC,GAAG,IAAA,6BAAa,EAAC,CAAC,CAAC,CAAC;QAC3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YACrC,MAAM,MAAM,GAAG,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YACtC,MAAM,GAAG,GAAG,IAAA,2BAAW,EAAC,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC;YACtC,IAAA,eAAM,EAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,uCAAuC,EAAE,GAAG,EAAE;QAC/C,MAAM,CAAC,GAAG,IAAA,yBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,GAAG,IAAA,yBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,GAAG,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACzB,IAAA,eAAM,EAAC,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QACzB,IAAI,CAAC;YAAE,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,iBAAQ,EAAC,6CAA6C,EAAE,GAAG,EAAE;IAC3D,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAEhC,IAAA,WAAE,EAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,MAAM,QAAQ,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAAC;QACtC,6CAA6C;QAC7C,MAAM,OAAO,GAA6C,EAAE,CAAC;QAC7D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC3B,MAAM,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;YAC9C,MAAM,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;YAClD,MAAM,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;YAClD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;gBAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,CAAC;QACD,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,OAAO,EAAE,CAAC;YAChC,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACxD,MAAM,IAAI,GAAG,IAAA,qBAAK,EAAC,CAAC,EAAE,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACzC,MAAM,KAAK,GAAG,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC1C,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,QAAQ,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAAC;QACtC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC3B,MAAM,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;YAC9C,MAAM,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;YAClD,MAAM,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;YAClD,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;gBAAE,SAAS;YAC7B,MAAM,IAAI,GAAG,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACzC,MAAM,KAAK,GAAG,IAAA,qBAAK,EAAC,CAAC,EAAE,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACvD,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,0BAA0B,EAAE,GAAG,EAAE;QAClC,KAAK,MAAM,CAAC,IAAI,iBAAiB,CAAC,CAAC,CAAC,EAAE,CAAC;YACrC,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,IAAA,sBAAM,EAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrD,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,iBAAQ,EAAC,iDAAiD,EAAE,GAAG,EAAE;IAC/D,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAEhC,IAAA,WAAE,EAAC,uDAAuD,EAAE,GAAG,EAAE;QAC/D,MAAM,CAAC,GAAG,IAAA,yBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAClC,MAAM,IAAI,GAAG,IAAA,wBAAQ,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACjC,IAAA,eAAM,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC5B,KAAK,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC;YACrB,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChC,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,yDAAyD,EAAE,GAAG,EAAE;QACjE,MAAM,CAAC,GAAG,IAAA,6BAAa,EAAC,CAAC,CAAC,CAAC;QAC3B,MAAM,EAAE,GAAG,IAAA,qBAAK,EAAC,CAAC,CAAC,CAAC;QACpB,MAAM,EAAE,GAAG,IAAA,qBAAK,EAAC,CAAC,CAAC,CAAC;QACpB,yBAAyB;QACzB,MAAM,IAAI,GAAG,IAAA,wBAAQ,EAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACtC,IAAA,eAAM,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC5B,4BAA4B;QAC5B,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAI,CAAC,CAAC,CAAC,EAAE,IAAA,sBAAM,EAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5C,eAAe;QACf,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAI,CAAC,CAAC,CAAC,EAAE,IAAA,qBAAK,EAAC,CAAC,EAAE,IAAA,qBAAK,EAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,iBAAQ,EAAC,kCAAkC,EAAE,GAAG,EAAE;IAChD,IAAA,WAAE,EAAC,qBAAqB,EAAE,GAAG,EAAE;QAC7B,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAChC,IAAA,eAAM,EAAC,IAAA,yBAAS,EAAC,CAAC,EAAE,IAAA,sBAAM,EAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,2BAA2B,EAAE,GAAG,EAAE;QACnC,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,GAAG,IAAA,yBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/B,IAAA,eAAM,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,IAAA,sBAAM,EAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,4BAA4B,EAAE,GAAG,EAAE;QACpC,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,GAAG,IAAA,yBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/B,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,IAAA,qBAAK,EAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,sCAAsC,EAAE,GAAG,EAAE;QAC9C,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,GAAG,IAAA,yBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5B,mBAAmB;QACnB,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,IAAA,yBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,+CAA+C,EAAE,GAAG,EAAE;QACvD,qCAAqC;QACrC,IAAA,eAAM,EAAC,GAAG,EAAE,CAAC,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;IAC3D,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,kEAAkE,EAAE,GAAG,EAAE;QAC1E,wCAAwC;QACxC,MAAM,CAAC,GAAG,IAAA,+BAAe,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAA,eAAM,EAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxB,0DAA0D;QAC1D,MAAM,CAAC,GAAG,IAAA,yBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/B,MAAM,EAAE,GAAG,IAAA,qBAAK,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1B,yEAAyE;QACzE,IAAA,eAAM,EAAC,IAAA,oBAAI,EAAC,EAAE,EAAE,IAAA,yBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=hoare-logic.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hoare-logic.test.d.ts","sourceRoot":"","sources":["../../../../src/tests/reasoning/hoare-logic/hoare-logic.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,340 @@
1
+ "use strict";
2
+ // ============================================================
3
+ // ST Hoare Logic — Tests
4
+ // ============================================================
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const vitest_1 = require("vitest");
7
+ const hoare_logic_1 = require("../../../reasoning/hoare-logic");
8
+ (0, vitest_1.describe)('hoare-logic — sustitución sintáctica', () => {
9
+ (0, vitest_1.it)('substitute reemplaza la variable libre objetivo', () => {
10
+ // (x + 1)[5/x] = 5 + 1
11
+ const expr = (0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(1));
12
+ const result = (0, hoare_logic_1.substitute)(expr, 'x', (0, hoare_logic_1.num)(5));
13
+ (0, vitest_1.expect)(result).toEqual((0, hoare_logic_1.binop)('+', (0, hoare_logic_1.num)(5), (0, hoare_logic_1.num)(1)));
14
+ });
15
+ (0, vitest_1.it)('substitute no toca constantes ni variables distintas', () => {
16
+ const expr = (0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('y'), (0, hoare_logic_1.num)(7));
17
+ const result = (0, hoare_logic_1.substitute)(expr, 'x', (0, hoare_logic_1.num)(99));
18
+ (0, vitest_1.expect)(result).toEqual(expr);
19
+ });
20
+ (0, vitest_1.it)('substitute recorre operadores unarios y anidados', () => {
21
+ // expr: ¬(x < x*2). Sustituyendo x=3 → ¬(3 < 6) = ¬true = false.
22
+ const expr = (0, hoare_logic_1.not)((0, hoare_logic_1.binop)('<', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.binop)('*', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(2))));
23
+ const result = (0, hoare_logic_1.substitute)(expr, 'x', (0, hoare_logic_1.num)(3));
24
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)(result, {})).toBe(false);
25
+ // Y con x=-1: -1 < -2 es false → ¬false = true.
26
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)(expr, { x: -1 })).toBe(true);
27
+ });
28
+ });
29
+ (0, vitest_1.describe)('hoare-logic — wp para statements básicos', () => {
30
+ (0, vitest_1.it)('wp(skip, Q) = Q', () => {
31
+ const post = (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(5));
32
+ (0, vitest_1.expect)((0, hoare_logic_1.wp)((0, hoare_logic_1.skip)(), post)).toEqual(post);
33
+ });
34
+ (0, vitest_1.it)('wp(x := 5, x == 5) = (5 == 5)', () => {
35
+ const post = (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(5));
36
+ const result = (0, hoare_logic_1.wp)((0, hoare_logic_1.assign)('x', (0, hoare_logic_1.num)(5)), post);
37
+ // post[5/x] = (5 == 5)
38
+ (0, vitest_1.expect)(result).toEqual((0, hoare_logic_1.eq)((0, hoare_logic_1.num)(5), (0, hoare_logic_1.num)(5)));
39
+ // Y semánticamente: 5 == 5 es true
40
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)(result, {})).toBe(true);
41
+ });
42
+ (0, vitest_1.it)('wp(x := y + 1, x > 0) = (y + 1 > 0)', () => {
43
+ const post = (0, hoare_logic_1.binop)('>', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(0));
44
+ const result = (0, hoare_logic_1.wp)((0, hoare_logic_1.assign)('x', (0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('y'), (0, hoare_logic_1.num)(1))), post);
45
+ (0, vitest_1.expect)(result).toEqual((0, hoare_logic_1.binop)('>', (0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('y'), (0, hoare_logic_1.num)(1)), (0, hoare_logic_1.num)(0)));
46
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)(result, { y: 5 })).toBe(true);
47
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)(result, { y: -5 })).toBe(false);
48
+ });
49
+ (0, vitest_1.it)('wp seq decompone derecha → izquierda', () => {
50
+ // {x := 1; y := x + 1} {y == 2}
51
+ // wp(y := x+1, y == 2) = (x+1 == 2)
52
+ // wp(x := 1, x+1 == 2) = (1+1 == 2) → true
53
+ const stmt = (0, hoare_logic_1.seq)((0, hoare_logic_1.assign)('x', (0, hoare_logic_1.num)(1)), (0, hoare_logic_1.assign)('y', (0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(1))));
54
+ const post = (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('y'), (0, hoare_logic_1.num)(2));
55
+ const result = (0, hoare_logic_1.wp)(stmt, post);
56
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)(result, {})).toBe(true);
57
+ });
58
+ (0, vitest_1.it)('wp(if B then c1 else c2) combina ambas ramas', () => {
59
+ // if x > 0 then y := 1 else y := -1
60
+ // post: y > -2 (siempre cierto)
61
+ const stmt = (0, hoare_logic_1.ifS)((0, hoare_logic_1.binop)('>', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(0)), (0, hoare_logic_1.assign)('y', (0, hoare_logic_1.num)(1)), (0, hoare_logic_1.assign)('y', (0, hoare_logic_1.num)(-1)));
62
+ const post = (0, hoare_logic_1.binop)('>', (0, hoare_logic_1.v)('y'), (0, hoare_logic_1.num)(-2));
63
+ const result = (0, hoare_logic_1.wp)(stmt, post);
64
+ // Vale para cualquier estado.
65
+ for (const xVal of [-5, -1, 0, 1, 5]) {
66
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)(result, { x: xVal })).toBe(true);
67
+ }
68
+ });
69
+ (0, vitest_1.it)('wp(while sin invariant) = false', () => {
70
+ const stmt = (0, hoare_logic_1.whileS)((0, hoare_logic_1.binop)('<', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(10)), (0, hoare_logic_1.assign)('x', (0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(1))));
71
+ (0, vitest_1.expect)((0, hoare_logic_1.wp)(stmt, (0, hoare_logic_1.bool)(true))).toEqual((0, hoare_logic_1.bool)(false));
72
+ });
73
+ (0, vitest_1.it)('wp(while con invariant) = invariant', () => {
74
+ const I = (0, hoare_logic_1.le)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(10));
75
+ const stmt = (0, hoare_logic_1.whileS)((0, hoare_logic_1.binop)('<', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(10)), (0, hoare_logic_1.assign)('x', (0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(1))), I);
76
+ (0, vitest_1.expect)((0, hoare_logic_1.wp)(stmt, (0, hoare_logic_1.bool)(true))).toEqual(I);
77
+ });
78
+ });
79
+ (0, vitest_1.describe)('hoare-logic — strongest postcondition (sp)', () => {
80
+ (0, vitest_1.it)('sp(skip, P) = P', () => {
81
+ const pre = (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(0));
82
+ (0, vitest_1.expect)((0, hoare_logic_1.spExtension)((0, hoare_logic_1.skip)(), pre)).toEqual(pre);
83
+ });
84
+ (0, vitest_1.it)('sp(x := 5, true) implica x == 5', () => {
85
+ const stmt = (0, hoare_logic_1.assign)('x', (0, hoare_logic_1.num)(5));
86
+ const result = (0, hoare_logic_1.spExtension)(stmt, (0, hoare_logic_1.bool)(true));
87
+ // Debería implicar x == 5 al menos para muestreo concreto.
88
+ const state = { x: 5 };
89
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)(result, state)).toBe(true);
90
+ });
91
+ });
92
+ (0, vitest_1.describe)('hoare-logic — execStmt concreto', () => {
93
+ (0, vitest_1.it)('ejecuta swap correctamente', () => {
94
+ const swap = (0, hoare_logic_1.programSwap)();
95
+ const initial = { x: 7, y: 13 };
96
+ const final = (0, hoare_logic_1.execStmt)(swap, initial);
97
+ (0, vitest_1.expect)('error' in final).toBe(false);
98
+ if (!('error' in final)) {
99
+ (0, vitest_1.expect)(final.x).toBe(13);
100
+ (0, vitest_1.expect)(final.y).toBe(7);
101
+ }
102
+ });
103
+ (0, vitest_1.it)('ejecuta factorial concretamente para n pequeños', () => {
104
+ const fact = (0, hoare_logic_1.programFactorial)();
105
+ for (const n of [0, 1, 2, 3, 5, 6]) {
106
+ const final = (0, hoare_logic_1.execStmt)(fact, { n });
107
+ (0, vitest_1.expect)('error' in final).toBe(false);
108
+ if (!('error' in final)) {
109
+ (0, vitest_1.expect)(final.r).toBe((0, hoare_logic_1.factorial)(n));
110
+ }
111
+ }
112
+ });
113
+ (0, vitest_1.it)('ejecuta GCD por restas correctamente', () => {
114
+ const gcdProg = (0, hoare_logic_1.programGCD)();
115
+ const cases = [
116
+ [12, 18, 6],
117
+ [21, 14, 7],
118
+ [9, 9, 9],
119
+ [100, 75, 25],
120
+ [13, 7, 1],
121
+ ];
122
+ for (const [x, y, expected] of cases) {
123
+ const final = (0, hoare_logic_1.execStmt)(gcdProg, { x, y });
124
+ (0, vitest_1.expect)('error' in final).toBe(false);
125
+ if (!('error' in final)) {
126
+ (0, vitest_1.expect)(final.x).toBe(expected);
127
+ (0, vitest_1.expect)(final.y).toBe(expected);
128
+ (0, vitest_1.expect)(final.x).toBe((0, hoare_logic_1.gcd)(x, y));
129
+ }
130
+ }
131
+ });
132
+ (0, vitest_1.it)('respeta el límite de pasos en loops divergentes', () => {
133
+ // while true do skip
134
+ const infinite = (0, hoare_logic_1.whileS)((0, hoare_logic_1.num)(1), (0, hoare_logic_1.skip)());
135
+ const final = (0, hoare_logic_1.execStmt)(infinite, {}, 50);
136
+ (0, vitest_1.expect)('error' in final).toBe(true);
137
+ });
138
+ (0, vitest_1.it)('if elige rama correcta según condición', () => {
139
+ const stmt = (0, hoare_logic_1.ifS)((0, hoare_logic_1.binop)('>', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(0)), (0, hoare_logic_1.assign)('y', (0, hoare_logic_1.num)(1)), (0, hoare_logic_1.assign)('y', (0, hoare_logic_1.num)(-1)));
140
+ const a = (0, hoare_logic_1.execStmt)(stmt, { x: 5 });
141
+ const b = (0, hoare_logic_1.execStmt)(stmt, { x: -3 });
142
+ (0, vitest_1.expect)(!('error' in a) && a.y === 1).toBe(true);
143
+ (0, vitest_1.expect)(!('error' in b) && b.y === -1).toBe(true);
144
+ });
145
+ });
146
+ (0, vitest_1.describe)('hoare-logic — verifyTriple', () => {
147
+ (0, vitest_1.it)('verifica {x = 5} skip {x = 5}', () => {
148
+ const triple = {
149
+ pre: (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(5)),
150
+ stmt: (0, hoare_logic_1.skip)(),
151
+ post: (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(5)),
152
+ };
153
+ const result = (0, hoare_logic_1.verifyTriple)(triple, { samples: 50 });
154
+ (0, vitest_1.expect)(result.valid).toBe(true);
155
+ });
156
+ (0, vitest_1.it)('verifica {true} x := 5 {x = 5}', () => {
157
+ const triple = {
158
+ pre: (0, hoare_logic_1.bool)(true),
159
+ stmt: (0, hoare_logic_1.assign)('x', (0, hoare_logic_1.num)(5)),
160
+ post: (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(5)),
161
+ };
162
+ const result = (0, hoare_logic_1.verifyTriple)(triple, { samples: 50 });
163
+ (0, vitest_1.expect)(result.valid).toBe(true);
164
+ });
165
+ (0, vitest_1.it)('verifica {x = a ∧ y = b} swap {x = b ∧ y = a}', () => {
166
+ // El swap usa la variable temporal `t`, por lo que la pre y post
167
+ // se expresan sobre x e y; introducimos a y b como variables
168
+ // matemáticas (ghost vars) que se preservan.
169
+ const triple = {
170
+ pre: (0, hoare_logic_1.and)((0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.v)('a')), (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('y'), (0, hoare_logic_1.v)('b'))),
171
+ stmt: (0, hoare_logic_1.programSwap)(),
172
+ post: (0, hoare_logic_1.and)((0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.v)('b')), (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('y'), (0, hoare_logic_1.v)('a'))),
173
+ };
174
+ const result = (0, hoare_logic_1.verifyTriple)(triple, { samples: 100, range: [-3, 3] });
175
+ (0, vitest_1.expect)(result.valid).toBe(true);
176
+ });
177
+ (0, vitest_1.it)('detecta contraejemplo en tripleta incorrecta', () => {
178
+ // {x = 0} x := x + 1 {x = 0} → falso
179
+ const triple = {
180
+ pre: (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(0)),
181
+ stmt: (0, hoare_logic_1.assign)('x', (0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(1))),
182
+ post: (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(0)),
183
+ };
184
+ const result = (0, hoare_logic_1.verifyTriple)(triple, { samples: 30, seed: 42 });
185
+ (0, vitest_1.expect)(result.valid).toBe(false);
186
+ (0, vitest_1.expect)(result.failures.length).toBeGreaterThan(0);
187
+ });
188
+ (0, vitest_1.it)('rechaza while sin invariant', () => {
189
+ const triple = {
190
+ pre: (0, hoare_logic_1.bool)(true),
191
+ stmt: (0, hoare_logic_1.whileS)((0, hoare_logic_1.binop)('<', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(10)), (0, hoare_logic_1.assign)('x', (0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(1)))),
192
+ post: (0, hoare_logic_1.bool)(true),
193
+ };
194
+ const result = (0, hoare_logic_1.verifyTriple)(triple, { samples: 10 });
195
+ (0, vitest_1.expect)(result.valid).toBe(false);
196
+ });
197
+ (0, vitest_1.it)('verifica {n ≥ 0} factorial(n) {r = n!} para n pequeños via execStmt', () => {
198
+ // Verificación semántica concreta (complementa los VCs sintácticos).
199
+ const fact = (0, hoare_logic_1.programFactorial)();
200
+ for (const n of [0, 1, 2, 4, 6]) {
201
+ const final = (0, hoare_logic_1.execStmt)(fact, { n });
202
+ (0, vitest_1.expect)('error' in final).toBe(false);
203
+ if (!('error' in final)) {
204
+ (0, vitest_1.expect)(final.r).toBe((0, hoare_logic_1.factorial)(n));
205
+ }
206
+ }
207
+ });
208
+ (0, vitest_1.it)('verifica invariant válido del while incrementor', () => {
209
+ // {x ≤ 5} while x < 5 do x := x + 1 {x = 5}
210
+ // invariant: x ≤ 5
211
+ const triple = {
212
+ pre: (0, hoare_logic_1.le)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(5)),
213
+ stmt: (0, hoare_logic_1.whileS)((0, hoare_logic_1.binop)('<', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(5)), (0, hoare_logic_1.assign)('x', (0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(1))), (0, hoare_logic_1.le)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(5))),
214
+ post: (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(5)),
215
+ };
216
+ const result = (0, hoare_logic_1.verifyTriple)(triple, { samples: 100, range: [0, 5], seed: 7 });
217
+ (0, vitest_1.expect)(result.valid).toBe(true);
218
+ });
219
+ });
220
+ (0, vitest_1.describe)('hoare-logic — generación de VCs', () => {
221
+ (0, vitest_1.it)('generateVCs incluye 1 VC global para asignación simple', () => {
222
+ const triple = {
223
+ pre: (0, hoare_logic_1.bool)(true),
224
+ stmt: (0, hoare_logic_1.assign)('x', (0, hoare_logic_1.num)(5)),
225
+ post: (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(5)),
226
+ };
227
+ const vcs = (0, hoare_logic_1.generateVCs)(triple);
228
+ (0, vitest_1.expect)(vcs.length).toBe(1);
229
+ });
230
+ (0, vitest_1.it)('generateVCs añade 2 VCs por cada while (mantenimiento + salida)', () => {
231
+ const triple = {
232
+ pre: (0, hoare_logic_1.bool)(true),
233
+ stmt: (0, hoare_logic_1.whileS)((0, hoare_logic_1.binop)('<', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(5)), (0, hoare_logic_1.assign)('x', (0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(1))), (0, hoare_logic_1.bool)(true)),
234
+ post: (0, hoare_logic_1.bool)(true),
235
+ };
236
+ const vcs = (0, hoare_logic_1.generateVCs)(triple);
237
+ // VC global + mantenimiento + salida = 3
238
+ (0, vitest_1.expect)(vcs.length).toBe(3);
239
+ });
240
+ (0, vitest_1.it)('un while sin invariant produce VC bool(false)', () => {
241
+ const triple = {
242
+ pre: (0, hoare_logic_1.bool)(true),
243
+ stmt: (0, hoare_logic_1.whileS)((0, hoare_logic_1.binop)('<', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(5)), (0, hoare_logic_1.assign)('x', (0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.num)(1)))),
244
+ post: (0, hoare_logic_1.bool)(true),
245
+ };
246
+ const vcs = (0, hoare_logic_1.generateVCs)(triple);
247
+ // Al menos uno es bool(false).
248
+ (0, vitest_1.expect)(vcs.some((v) => v.kind === 'bool' && v.value === false)).toBe(true);
249
+ });
250
+ });
251
+ (0, vitest_1.describe)('hoare-logic — variables libres y stmtVars', () => {
252
+ (0, vitest_1.it)('freeVars colecta variables de una expresión', () => {
253
+ const expr = (0, hoare_logic_1.and)((0, hoare_logic_1.eq)((0, hoare_logic_1.v)('x'), (0, hoare_logic_1.v)('a')), (0, hoare_logic_1.eq)((0, hoare_logic_1.v)('y'), (0, hoare_logic_1.v)('b')));
254
+ const vars = (0, hoare_logic_1.freeVars)(expr);
255
+ (0, vitest_1.expect)(vars.has('x')).toBe(true);
256
+ (0, vitest_1.expect)(vars.has('a')).toBe(true);
257
+ (0, vitest_1.expect)(vars.has('y')).toBe(true);
258
+ (0, vitest_1.expect)(vars.has('b')).toBe(true);
259
+ (0, vitest_1.expect)(vars.size).toBe(4);
260
+ });
261
+ });
262
+ (0, vitest_1.describe)('hoare-logic — linear search programa', () => {
263
+ (0, vitest_1.it)('linear search ejecuta sin error y respeta el invariant i ≤ n', () => {
264
+ const prog = (0, hoare_logic_1.programLinearSearch)();
265
+ const final = (0, hoare_logic_1.execStmt)(prog, { a: 3, target: 3, n: 5 });
266
+ (0, vitest_1.expect)('error' in final).toBe(false);
267
+ if (!('error' in final)) {
268
+ // a == target ⇒ found = 1 desde la primera iteración.
269
+ (0, vitest_1.expect)(final.found).toBe(1);
270
+ (0, vitest_1.expect)(final.i).toBeLessThanOrEqual(5);
271
+ }
272
+ });
273
+ (0, vitest_1.it)('linear search sale sin encontrar cuando a != target', () => {
274
+ const prog = (0, hoare_logic_1.programLinearSearch)();
275
+ const final = (0, hoare_logic_1.execStmt)(prog, { a: 1, target: 99, n: 3 });
276
+ (0, vitest_1.expect)('error' in final).toBe(false);
277
+ if (!('error' in final)) {
278
+ (0, vitest_1.expect)(final.found).toBe(0);
279
+ (0, vitest_1.expect)(final.i).toBe(3);
280
+ }
281
+ });
282
+ });
283
+ (0, vitest_1.describe)('hoare-logic — evaluación de expresiones primitivas', () => {
284
+ (0, vitest_1.it)('evalExpr maneja operadores aritméticos', () => {
285
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.binop)('+', (0, hoare_logic_1.num)(2), (0, hoare_logic_1.num)(3)), {})).toBe(5);
286
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.binop)('-', (0, hoare_logic_1.num)(10), (0, hoare_logic_1.num)(4)), {})).toBe(6);
287
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.binop)('*', (0, hoare_logic_1.num)(3), (0, hoare_logic_1.num)(4)), {})).toBe(12);
288
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.binop)('/', (0, hoare_logic_1.num)(20), (0, hoare_logic_1.num)(4)), {})).toBe(5);
289
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.binop)('/', (0, hoare_logic_1.num)(1), (0, hoare_logic_1.num)(0)), {})).toBe(0); // div por cero → 0
290
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.binop)('%', (0, hoare_logic_1.num)(10), (0, hoare_logic_1.num)(3)), {})).toBe(1);
291
+ });
292
+ (0, vitest_1.it)('evalExpr maneja relacionales', () => {
293
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.binop)('<', (0, hoare_logic_1.num)(1), (0, hoare_logic_1.num)(2)), {})).toBe(true);
294
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.binop)('<=', (0, hoare_logic_1.num)(2), (0, hoare_logic_1.num)(2)), {})).toBe(true);
295
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.binop)('>=', (0, hoare_logic_1.num)(2), (0, hoare_logic_1.num)(2)), {})).toBe(true);
296
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.binop)('!=', (0, hoare_logic_1.num)(1), (0, hoare_logic_1.num)(2)), {})).toBe(true);
297
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.binop)('==', (0, hoare_logic_1.num)(1), (0, hoare_logic_1.num)(2)), {})).toBe(false);
298
+ });
299
+ (0, vitest_1.it)('evalExpr maneja booleanos y not', () => {
300
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.and)((0, hoare_logic_1.bool)(true), (0, hoare_logic_1.bool)(false)), {})).toBe(false);
301
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.or)((0, hoare_logic_1.bool)(true), (0, hoare_logic_1.bool)(false)), {})).toBe(true);
302
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.not)((0, hoare_logic_1.bool)(false)), {})).toBe(true);
303
+ });
304
+ (0, vitest_1.it)('evalExpr trata variables no definidas como 0', () => {
305
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.v)('zzz'), {})).toBe(0);
306
+ (0, vitest_1.expect)((0, hoare_logic_1.evalExpr)((0, hoare_logic_1.binop)('+', (0, hoare_logic_1.v)('a'), (0, hoare_logic_1.num)(5)), {})).toBe(5);
307
+ });
308
+ });
309
+ (0, vitest_1.describe)('hoare-logic — invariants documentados', () => {
310
+ (0, vitest_1.it)('GCD: gcd(x, y) se mantiene tras una iteración del body', () => {
311
+ // Verifico el invariant SEMÁNTICAMENTE (no via VC sintáctica)
312
+ // ejecutando una iteración del body sobre estados varios.
313
+ for (let x = 2; x <= 8; x++) {
314
+ for (let y = 2; y <= 8; y++) {
315
+ if (x === y)
316
+ continue;
317
+ const before = (0, hoare_logic_1.gcd)(x, y);
318
+ const body = (0, hoare_logic_1.ifS)((0, hoare_logic_1.binop)('>', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.v)('y')), (0, hoare_logic_1.assign)('x', (0, hoare_logic_1.binop)('-', (0, hoare_logic_1.v)('x'), (0, hoare_logic_1.v)('y'))), (0, hoare_logic_1.assign)('y', (0, hoare_logic_1.binop)('-', (0, hoare_logic_1.v)('y'), (0, hoare_logic_1.v)('x'))));
319
+ const final = (0, hoare_logic_1.execStmt)(body, { x, y });
320
+ (0, vitest_1.expect)('error' in final).toBe(false);
321
+ if (!('error' in final)) {
322
+ const after = (0, hoare_logic_1.gcd)(final.x ?? 0, final.y ?? 0);
323
+ (0, vitest_1.expect)(after).toBe(before);
324
+ }
325
+ }
326
+ }
327
+ });
328
+ (0, vitest_1.it)('Factorial invariant r·(k! relativo a n) mantiene r = k! tras body', () => {
329
+ // Tras j-ésima iteración debe valer r = j! (j = k al fin del body).
330
+ for (let n = 1; n <= 6; n++) {
331
+ const final = (0, hoare_logic_1.execStmt)((0, hoare_logic_1.programFactorial)(), { n });
332
+ (0, vitest_1.expect)('error' in final).toBe(false);
333
+ if (!('error' in final)) {
334
+ (0, vitest_1.expect)(final.r).toBe((0, hoare_logic_1.factorial)(n));
335
+ (0, vitest_1.expect)(final.k).toBe(n);
336
+ }
337
+ }
338
+ });
339
+ });
340
+ //# sourceMappingURL=hoare-logic.test.js.map