@siegesailor/cryptography 1.0.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 (95) hide show
  1. package/LICENSE.md +19 -0
  2. package/README.md +79 -0
  3. package/build/algorithms/baby-step-giant-step/index.js +89 -0
  4. package/build/algorithms/baby-step-giant-step/index.js.map +1 -0
  5. package/build/algorithms/baby-step-giant-step/index.test.js +32 -0
  6. package/build/algorithms/baby-step-giant-step/index.test.js.map +1 -0
  7. package/build/algorithms/blum-blum-shub/index.js +88 -0
  8. package/build/algorithms/blum-blum-shub/index.js.map +1 -0
  9. package/build/algorithms/blum-blum-shub/index.test.js +74 -0
  10. package/build/algorithms/blum-blum-shub/index.test.js.map +1 -0
  11. package/build/algorithms/chinese-remainder/index.js +111 -0
  12. package/build/algorithms/chinese-remainder/index.js.map +1 -0
  13. package/build/algorithms/chinese-remainder/index.test.js +28 -0
  14. package/build/algorithms/chinese-remainder/index.test.js.map +1 -0
  15. package/build/algorithms/euclidean/index.js +60 -0
  16. package/build/algorithms/euclidean/index.js.map +1 -0
  17. package/build/algorithms/euclidean/index.test.js +22 -0
  18. package/build/algorithms/euclidean/index.test.js.map +1 -0
  19. package/build/algorithms/extended-euclidean/index.js +77 -0
  20. package/build/algorithms/extended-euclidean/index.js.map +1 -0
  21. package/build/algorithms/extended-euclidean/index.test.js +22 -0
  22. package/build/algorithms/extended-euclidean/index.test.js.map +1 -0
  23. package/build/algorithms/fast-modular-exponentiation/index.js +80 -0
  24. package/build/algorithms/fast-modular-exponentiation/index.js.map +1 -0
  25. package/build/algorithms/fast-modular-exponentiation/index.test.js +31 -0
  26. package/build/algorithms/fast-modular-exponentiation/index.test.js.map +1 -0
  27. package/build/algorithms/miller-rabin-primarily-test/index.js +87 -0
  28. package/build/algorithms/miller-rabin-primarily-test/index.js.map +1 -0
  29. package/build/algorithms/miller-rabin-primarily-test/index.test.js +78 -0
  30. package/build/algorithms/miller-rabin-primarily-test/index.test.js.map +1 -0
  31. package/build/algorithms/multiplicative-inverse/index.js +83 -0
  32. package/build/algorithms/multiplicative-inverse/index.js.map +1 -0
  33. package/build/algorithms/multiplicative-inverse/index.test.js +30 -0
  34. package/build/algorithms/multiplicative-inverse/index.test.js.map +1 -0
  35. package/build/algorithms/naor-reingo/index.js +85 -0
  36. package/build/algorithms/naor-reingo/index.js.map +1 -0
  37. package/build/algorithms/naor-reingo/index.test.js +27 -0
  38. package/build/algorithms/naor-reingo/index.test.js.map +1 -0
  39. package/build/algorithms/pollard-p-1-factorization/index.js +92 -0
  40. package/build/algorithms/pollard-p-1-factorization/index.js.map +1 -0
  41. package/build/algorithms/pollard-p-1-factorization/index.test.js +32 -0
  42. package/build/algorithms/pollard-p-1-factorization/index.test.js.map +1 -0
  43. package/build/algorithms/pollard-rho/index.js +82 -0
  44. package/build/algorithms/pollard-rho/index.js.map +1 -0
  45. package/build/algorithms/pollard-rho/index.test.js +26 -0
  46. package/build/algorithms/pollard-rho/index.test.js.map +1 -0
  47. package/build/algorithms/primitive-root-search/index.js +95 -0
  48. package/build/algorithms/primitive-root-search/index.js.map +1 -0
  49. package/build/algorithms/primitive-root-search/index.test.js +46 -0
  50. package/build/algorithms/primitive-root-search/index.test.js.map +1 -0
  51. package/build/command.js +79 -0
  52. package/build/command.js.map +1 -0
  53. package/build/entry-point.js +31 -0
  54. package/build/entry-point.js.map +1 -0
  55. package/build/key-encryptions/DiffieHellman.js +56 -0
  56. package/build/key-encryptions/DiffieHellman.js.map +1 -0
  57. package/build/key-encryptions/ElGamal.js +83 -0
  58. package/build/key-encryptions/ElGamal.js.map +1 -0
  59. package/build/key-encryptions/RSA.js +102 -0
  60. package/build/key-encryptions/RSA.js.map +1 -0
  61. package/build/shared/algorithm/math.js +9 -0
  62. package/build/shared/algorithm/math.js.map +1 -0
  63. package/build/shared/algorithm/random.js +52 -0
  64. package/build/shared/algorithm/random.js.map +1 -0
  65. package/build/shared/algorithm/wasm.js +105 -0
  66. package/build/shared/algorithm/wasm.js.map +1 -0
  67. package/build/shared/algorithm/wrap.js +57 -0
  68. package/build/shared/algorithm/wrap.js.map +1 -0
  69. package/build/shared/cli/Procedure.js +51 -0
  70. package/build/shared/cli/Procedure.js.map +1 -0
  71. package/build/shared/cli/chalk.js +48 -0
  72. package/build/shared/cli/chalk.js.map +1 -0
  73. package/build/shared/cli/inquirer.js +13 -0
  74. package/build/shared/cli/inquirer.js.map +1 -0
  75. package/build/shared/cli/prompt.js +98 -0
  76. package/build/shared/cli/prompt.js.map +1 -0
  77. package/build/shared/cli/utilities.js +145 -0
  78. package/build/shared/cli/utilities.js.map +1 -0
  79. package/build/shared/constants.js +21 -0
  80. package/build/shared/constants.js.map +1 -0
  81. package/build/shared/testing/wasm.js +78 -0
  82. package/build/shared/testing/wasm.js.map +1 -0
  83. package/build/source/algorithms/baby-step-giant-step/main.wasm +0 -0
  84. package/build/source/algorithms/blum-blum-shub/main.wasm +0 -0
  85. package/build/source/algorithms/chinese-remainder/main.wasm +0 -0
  86. package/build/source/algorithms/euclidean/main.wasm +0 -0
  87. package/build/source/algorithms/extended-euclidean/main.wasm +0 -0
  88. package/build/source/algorithms/fast-modular-exponentiation/main.wasm +0 -0
  89. package/build/source/algorithms/miller-rabin-primarily-test/main.wasm +0 -0
  90. package/build/source/algorithms/multiplicative-inverse/main.wasm +0 -0
  91. package/build/source/algorithms/naor-reingo/main.wasm +0 -0
  92. package/build/source/algorithms/pollard-p-1-factorization/main.wasm +0 -0
  93. package/build/source/algorithms/pollard-rho/main.wasm +0 -0
  94. package/build/source/algorithms/primitive-root-search/main.wasm +0 -0
  95. package/package.json +79 -0
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const euclidean_1 = __importDefault(require("../../algorithms/euclidean"));
7
+ const chalk_1 = __importDefault(require("../../shared/cli/chalk"));
8
+ const wasm_1 = require("../../shared/testing/wasm");
9
+ describe("Finding the Greatest Common Divisor of the given numbers", () => {
10
+ test.each([
11
+ [2, 4, 2],
12
+ [816, 2260, 4],
13
+ [30513, 40242, 3],
14
+ [614, 513, 1],
15
+ [5102048903, 307803219, 1],
16
+ ])(`GCD(%p, %p) = x.\n\tx = ${chalk_1.default.greenBright("%p")}`, (left, right, result) => {
17
+ const execute = () => (0, euclidean_1.default)(BigInt(left), BigInt(right));
18
+ expect(execute()).toEqual(BigInt(result));
19
+ (0, wasm_1.expectSameResultWithAndWithoutWASM)(execute);
20
+ });
21
+ });
22
+ //# sourceMappingURL=index.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../../source/algorithms/euclidean/index.test.ts"],"names":[],"mappings":";;;;;AAAA,uEAA+C;AAC/C,+DAAuC;AACvC,gDAA2E;AAE3E,QAAQ,CAAC,0DAA0D,EAAE,GAAG,EAAE;IACxE,IAAI,CAAC,IAAI,CAAC;QACR,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;QACT,CAAC,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC;QACd,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QACjB,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;QACb,CAAC,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC;KAC3B,CAAC,CACA,2BAA2B,eAAK,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,EACpD,CAAC,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;QACtB,MAAM,OAAO,GAAG,GAAG,EAAE,CAAC,IAAA,mBAAS,EAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;QAE7D,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;QAC1C,IAAA,yCAAkC,EAAC,OAAO,CAAC,CAAC;IAC9C,CAAC,CACF,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.default = main;
7
+ exports.prompt = prompt;
8
+ const wasm_1 = require("../../shared/algorithm/wasm");
9
+ const chalk_1 = __importDefault(require("../../shared/cli/chalk"));
10
+ const prompt_1 = require("../../shared/cli/prompt");
11
+ const runWASMExtendedEuclidean = (0, wasm_1.createWASMInvoker)("extended-euclidean", (wasmExports, left, right) => {
12
+ if (!wasmExports.extended_euclidean_i64 ||
13
+ !(0, wasm_1.fitsInI64)(left) ||
14
+ !(0, wasm_1.fitsInI64)(right)) {
15
+ return null;
16
+ }
17
+ const allocator = (0, wasm_1.createI64Allocator)(wasmExports);
18
+ allocator.reset();
19
+ const gcdPtr = allocator.allocate(wasm_1.I64_BYTES);
20
+ const xPtr = allocator.allocate(wasm_1.I64_BYTES);
21
+ const yPtr = allocator.allocate(wasm_1.I64_BYTES);
22
+ const view = allocator.view();
23
+ if (gcdPtr === null || xPtr === null || yPtr === null || !view) {
24
+ return null;
25
+ }
26
+ wasmExports.extended_euclidean_i64((0, wasm_1.normalizeI64)(left), (0, wasm_1.normalizeI64)(right), gcdPtr, xPtr, yPtr);
27
+ return [
28
+ view[gcdPtr / wasm_1.I64_BYTES],
29
+ view[xPtr / wasm_1.I64_BYTES],
30
+ view[yPtr / wasm_1.I64_BYTES],
31
+ ];
32
+ });
33
+ function main(left, right) {
34
+ const wasmResult = runWASMExtendedEuclidean(left, right);
35
+ if (wasmResult !== null) {
36
+ return wasmResult;
37
+ }
38
+ const recursion = (left, right) => {
39
+ if (right == BigInt(0))
40
+ return [left, BigInt(1), BigInt(0)];
41
+ const arrayOfResult = main(right, left % right);
42
+ return [
43
+ arrayOfResult[0],
44
+ arrayOfResult[2],
45
+ arrayOfResult[1] - (left / right) * arrayOfResult[2],
46
+ ];
47
+ };
48
+ return recursion(left, right);
49
+ }
50
+ const runPrompt = (0, prompt_1.createAlgorithmPrompt)("extended-euclidean", async ({ ask, writeLine }) => {
51
+ writeLine("\tGCD(left, right) = result");
52
+ writeLine(chalk_1.default.gray("\tGCD(106, 112) = -19 * 106 + 18 * 112 = 2"));
53
+ const { left, right } = await ask([
54
+ {
55
+ type: "number",
56
+ name: "left",
57
+ message: `Enter ${chalk_1.default.italic("left")}:`,
58
+ default: 1,
59
+ },
60
+ {
61
+ type: "number",
62
+ name: "right",
63
+ message: `Enter ${chalk_1.default.italic("right")}:`,
64
+ default: 1,
65
+ },
66
+ ]);
67
+ const [result, x, y] = main(BigInt(left), BigInt(right));
68
+ writeLine(`GCD(${left}, ${right}) = ${x} * ${left} + ${y} * ${right} = ${result}`);
69
+ return {
70
+ inputs: { left, right },
71
+ result: [result, x, y],
72
+ };
73
+ });
74
+ async function prompt(options) {
75
+ return runPrompt(options);
76
+ }
77
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../source/algorithms/extended-euclidean/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const extended_euclidean_1 = __importDefault(require("../../algorithms/extended-euclidean"));
7
+ const chalk_1 = __importDefault(require("../../shared/cli/chalk"));
8
+ const wasm_1 = require("../../shared/testing/wasm");
9
+ describe("Finding the Greatest Common Divisor of the given numbers in smallest integers form", () => {
10
+ test.each([
11
+ { left: 106, right: 112, x: -19, y: 18, result: 2 },
12
+ { left: 640, right: 531, x: 190, y: -229, result: 1 },
13
+ { left: 9123879, right: 421891, x: -19310, y: 417601, result: 1 },
14
+ { left: 102039129492, right: 13, x: 1, y: -7849163807, result: 1 },
15
+ { left: 13, right: 26, x: 1, y: 0, result: 13 },
16
+ ])(`GCD($left, $right) = x.\n\tx = ${chalk_1.default.greenBright("$x * $left + $y * $right")}`, ({ left, right, x, y, result }) => {
17
+ const execute = () => (0, extended_euclidean_1.default)(BigInt(left), BigInt(right));
18
+ expect(execute()).toEqual([BigInt(result), BigInt(x), BigInt(y)]);
19
+ (0, wasm_1.expectSameResultWithAndWithoutWASM)(execute);
20
+ });
21
+ });
22
+ //# sourceMappingURL=index.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../../source/algorithms/extended-euclidean/index.test.ts"],"names":[],"mappings":";;;;;AAAA,yFAAgE;AAChE,+DAAuC;AACvC,gDAA2E;AAE3E,QAAQ,CAAC,oFAAoF,EAAE,GAAG,EAAE;IAClG,IAAI,CAAC,IAAI,CAAC;QACR,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE;QACnD,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,CAAC,EAAE;QACrD,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE;QACjE,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,CAAC,EAAE;QAClE,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;KAChD,CAAC,CACA,kCAAkC,eAAK,CAAC,WAAW,CACjD,0BAA0B,CAC3B,EAAE,EACH,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;QAChC,MAAM,OAAO,GAAG,GAAG,EAAE,CAAC,IAAA,4BAAiB,EAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;QAErE,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAClE,IAAA,yCAAkC,EAAC,OAAO,CAAC,CAAC;IAC9C,CAAC,CACF,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -0,0 +1,80 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.default = main;
7
+ exports.prompt = prompt;
8
+ const constants_1 = require("../../shared/constants");
9
+ const wasm_1 = require("../../shared/algorithm/wasm");
10
+ const chalk_1 = __importDefault(require("../../shared/cli/chalk"));
11
+ const prompt_1 = require("../../shared/cli/prompt");
12
+ const runWASMPowMod = (0, wasm_1.createWASMInvoker)("fast-modular-exponentiation", (wasmExports, base, exponent, modulo) => {
13
+ if (!wasmExports.powmod_u64 ||
14
+ base < 0n ||
15
+ exponent < 0n ||
16
+ modulo <= 0n ||
17
+ !(0, wasm_1.fitsInU64)(base) ||
18
+ !(0, wasm_1.fitsInU64)(exponent) ||
19
+ !(0, wasm_1.fitsInU64)(modulo)) {
20
+ return null;
21
+ }
22
+ return wasmExports.powmod_u64(base, exponent, modulo);
23
+ });
24
+ function main(base, exponent, modulo) {
25
+ if (modulo <= 0n) {
26
+ throw new Error("modulo must be greater than 0.");
27
+ }
28
+ if (exponent < 0n) {
29
+ throw new Error("exponent must be non-negative.");
30
+ }
31
+ const maybeWASMResult = runWASMPowMod(base, exponent, modulo);
32
+ if (maybeWASMResult !== null) {
33
+ return maybeWASMResult;
34
+ }
35
+ let result = 1n;
36
+ let currentBase = ((base % modulo) + modulo) % modulo;
37
+ let currentExponent = exponent;
38
+ while (currentExponent > 0n) {
39
+ if ((currentExponent & 1n) === 1n) {
40
+ result = (result * currentBase) % modulo;
41
+ }
42
+ currentBase = (currentBase * currentBase) % modulo;
43
+ currentExponent >>= 1n;
44
+ }
45
+ return result;
46
+ }
47
+ const runPrompt = (0, prompt_1.createAlgorithmPrompt)("fast-modular-exponentiation", async ({ ask, writeLine }) => {
48
+ writeLine(`\tbase^exponent % modulo ${constants_1.SYMBOLS.CONGRUENT} x. x = result`);
49
+ writeLine(chalk_1.default.gray(`\t2^100 % 71 ${constants_1.SYMBOLS.CONGRUENT} 20. x = 20`));
50
+ const { base, exponent, modulo } = await ask([
51
+ {
52
+ type: "number",
53
+ name: "base",
54
+ message: `Enter ${chalk_1.default.italic("base")}:`,
55
+ default: 2,
56
+ },
57
+ {
58
+ type: "number",
59
+ name: "exponent",
60
+ message: `Enter ${chalk_1.default.italic("exponent")}:`,
61
+ default: 100,
62
+ },
63
+ {
64
+ type: "number",
65
+ name: "modulo",
66
+ message: `Enter ${chalk_1.default.italic("modulo")}:`,
67
+ default: 71,
68
+ },
69
+ ]);
70
+ const result = main(BigInt(base), BigInt(exponent), BigInt(modulo));
71
+ writeLine(`\t${base}^${exponent} % ${modulo} ${constants_1.SYMBOLS.CONGRUENT} ${result}. x = ${result}`);
72
+ return {
73
+ inputs: { base, exponent, modulo },
74
+ result,
75
+ };
76
+ });
77
+ async function prompt(options) {
78
+ return runPrompt(options);
79
+ }
80
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../source/algorithms/fast-modular-exponentiation/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const fast_modular_exponentiation_1 = __importDefault(require("../../algorithms/fast-modular-exponentiation"));
7
+ const chalk_1 = __importDefault(require("../../shared/cli/chalk"));
8
+ const constants_1 = require("../../shared/constants");
9
+ const wasm_1 = require("../../shared/testing/wasm");
10
+ describe("Calculating the remainder from doing modulus for a number with exponentiation", () => {
11
+ test.each([
12
+ [2, 100, 71, 20],
13
+ [394948, 615192, 1093427, 1089500],
14
+ [11, 2, 2, 1],
15
+ [985019284, 118293113, 13, 6],
16
+ [1314520, 17, 11, 4],
17
+ ])(`%p^%p % %p ${constants_1.SYMBOLS.CONGRUENT} x.\n\tx = ${chalk_1.default.greenBright("%p")}`, (base, exponent, modulo, result) => {
18
+ const execute = () => {
19
+ return (0, fast_modular_exponentiation_1.default)(BigInt(base), BigInt(exponent), BigInt(modulo));
20
+ };
21
+ expect(execute()).toEqual(BigInt(result));
22
+ (0, wasm_1.expectSameResultWithAndWithoutWASM)(execute);
23
+ });
24
+ test.each([
25
+ [2n, -1n, 5n, "exponent must be non-negative."],
26
+ [2n, 3n, 0n, "modulo must be greater than 0."],
27
+ ])("keeps the same error with and without WASM for %p^%p mod %p", (base, exponent, modulo, errorMessage) => {
28
+ (0, wasm_1.expectSameErrorWithAndWithoutWASM)(() => (0, fast_modular_exponentiation_1.default)(base, exponent, modulo), errorMessage);
29
+ });
30
+ });
31
+ //# sourceMappingURL=index.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../../source/algorithms/fast-modular-exponentiation/index.test.ts"],"names":[],"mappings":";;;;;AAAA,2GAAiF;AACjF,+DAAuC;AACvC,kDAA6C;AAC7C,gDAG+B;AAE/B,QAAQ,CAAC,+EAA+E,EAAE,GAAG,EAAE;IAC7F,IAAI,CAAC,IAAI,CAAC;QACR,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,CAAC;QAChB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC;QAClC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;QACb,CAAC,SAAS,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,CAAC;QAC7B,CAAC,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;KACrB,CAAC,CACA,cAAc,mBAAO,CAAC,SAAS,cAAc,eAAK,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,EACtE,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE;QACjC,MAAM,OAAO,GAAG,GAAG,EAAE;YACnB,OAAO,IAAA,qCAAyB,EAC9B,MAAM,CAAC,IAAI,CAAC,EACZ,MAAM,CAAC,QAAQ,CAAC,EAChB,MAAM,CAAC,MAAM,CAAC,CACf,CAAC;QACJ,CAAC,CAAC;QAEF,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;QAC1C,IAAA,yCAAkC,EAAC,OAAO,CAAC,CAAC;IAC9C,CAAC,CACF,CAAC;IAEF,IAAI,CAAC,IAAI,CAAC;QACR,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,gCAAgC,CAAC;QAC/C,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,gCAAgC,CAAC;KAC/C,CAAC,CACA,6DAA6D,EAC7D,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE,EAAE;QACvC,IAAA,wCAAiC,EAC/B,GAAG,EAAE,CAAC,IAAA,qCAAyB,EAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,CAAC,EACvD,YAAY,CACb,CAAC;IACJ,CAAC,CACF,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -0,0 +1,87 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.default = main;
7
+ exports.prompt = prompt;
8
+ const fast_modular_exponentiation_1 = __importDefault(require("../../algorithms/fast-modular-exponentiation"));
9
+ const random_1 = require("../../shared/algorithm/random");
10
+ const wasm_1 = require("../../shared/algorithm/wasm");
11
+ const chalk_1 = __importDefault(require("../../shared/cli/chalk"));
12
+ const prompt_1 = require("../../shared/cli/prompt");
13
+ const runWASMMillerRabin = (0, wasm_1.createWASMInvoker)("miller-rabin-primarily-test", (wasmExports, input, level) => {
14
+ if (!wasmExports.miller_rabin_u64 ||
15
+ input < 0n ||
16
+ input > wasm_1.MAX_U64 ||
17
+ !Number.isInteger(level) ||
18
+ level <= 0) {
19
+ return null;
20
+ }
21
+ return wasmExports.miller_rabin_u64(input, level) === 1;
22
+ });
23
+ function main(input, level) {
24
+ if (input <= 1n || input === 4n)
25
+ return false;
26
+ if (input <= 3n)
27
+ return true;
28
+ if (level <= 0) {
29
+ throw new Error("level must be a positive integer.");
30
+ }
31
+ const maybeWASMResult = runWASMMillerRabin(input, level);
32
+ if (maybeWASMResult !== null) {
33
+ return maybeWASMResult;
34
+ }
35
+ let odd = input - 1n;
36
+ while ((odd & 1n) === 0n)
37
+ odd >>= 1n;
38
+ const witnessRound = (n, d) => {
39
+ const a = (0, random_1.randomBigIntBetween)(2n, n - 2n);
40
+ let remainder = (0, fast_modular_exponentiation_1.default)(a, d, n);
41
+ if (remainder === 1n || remainder === n - 1n)
42
+ return true;
43
+ let dCache = d;
44
+ while (dCache !== n - 1n) {
45
+ remainder = (remainder * remainder) % n;
46
+ dCache <<= 1n;
47
+ if (remainder === 1n)
48
+ return false;
49
+ if (remainder === n - 1n)
50
+ return true;
51
+ }
52
+ return false;
53
+ };
54
+ for (let count = 0; count < level; count++) {
55
+ if (!witnessRound(input, odd))
56
+ return false;
57
+ }
58
+ return true;
59
+ }
60
+ const runPrompt = (0, prompt_1.createAlgorithmPrompt)("miller-rabin-primarily-test", async ({ ask, writeLine }) => {
61
+ writeLine("\tisPrime(number, level) = result");
62
+ writeLine(chalk_1.default.gray("\tisPrime(104729, 10) = true"));
63
+ const { input, level } = await ask([
64
+ {
65
+ type: "number",
66
+ name: "input",
67
+ message: `Enter ${chalk_1.default.italic("number")}:`,
68
+ default: 104729,
69
+ },
70
+ {
71
+ type: "number",
72
+ name: "level",
73
+ message: `Enter ${chalk_1.default.italic("level")}:`,
74
+ default: 10,
75
+ },
76
+ ]);
77
+ const result = main(BigInt(input), Number(level));
78
+ writeLine(`\tisPrime(${input}, ${level}) = ${result}`);
79
+ return {
80
+ inputs: { input, level },
81
+ result,
82
+ };
83
+ });
84
+ async function prompt(options) {
85
+ return runPrompt(options);
86
+ }
87
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../source/algorithms/miller-rabin-primarily-test/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ const miller_rabin_primarily_test_1 = __importDefault(require("../../algorithms/miller-rabin-primarily-test"));
40
+ const random = __importStar(require("../../shared/algorithm/random"));
41
+ const chalk_1 = __importDefault(require("../../shared/cli/chalk"));
42
+ const wasm_1 = require("../../shared/testing/wasm");
43
+ describe("Determining if the given number is Prime", () => {
44
+ afterEach(() => {
45
+ jest.restoreAllMocks();
46
+ });
47
+ test.each([
48
+ [7984925229121, 10, false],
49
+ [742621738636840244392549n, 5, true],
50
+ [38270906631533, 5, false],
51
+ [436885159382056146719494010011n, 10, true],
52
+ [1268969304953789, 5, false],
53
+ ])(`%p at level %p is prime.\n\tis ${chalk_1.default.greenBright("%p")}`, (input, level, result) => {
54
+ expect((0, miller_rabin_primarily_test_1.default)(BigInt(input), level)).toEqual(result);
55
+ });
56
+ test.each([
57
+ [101n, 5, true],
58
+ [221n, 5, false],
59
+ [104729n, 5, true],
60
+ [341n, 5, false],
61
+ ])("keeps the same classification with deterministic fallback witnesses for %p", (input, level, result) => {
62
+ const witnesses = [2n, 3n, 5n, 7n, 11n];
63
+ let witnessIndex = 0;
64
+ jest.spyOn(random, "randomBigIntBetween").mockImplementation(() => {
65
+ const witness = witnesses[witnessIndex % witnesses.length];
66
+ witnessIndex += 1;
67
+ return witness;
68
+ });
69
+ const actualResult = (0, miller_rabin_primarily_test_1.default)(input, level);
70
+ expect(actualResult).toEqual(result);
71
+ witnessIndex = 0;
72
+ expect((0, wasm_1.runWithoutWASM)(() => (0, miller_rabin_primarily_test_1.default)(input, level))).toEqual(actualResult);
73
+ });
74
+ test.each([0, -1])("keeps the same error with and without WASM for level %p", (level) => {
75
+ (0, wasm_1.expectSameErrorWithAndWithoutWASM)(() => (0, miller_rabin_primarily_test_1.default)(7n, level), "level must be a positive integer.");
76
+ });
77
+ });
78
+ //# sourceMappingURL=index.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../../source/algorithms/miller-rabin-primarily-test/index.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2GAAgF;AAChF,kEAAoD;AACpD,+DAAuC;AACvC,gDAG+B;AAE/B,QAAQ,CAAC,0CAA0C,EAAE,GAAG,EAAE;IACxD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,IAAI,CAAC;QACR,CAAC,aAAa,EAAE,EAAE,EAAE,KAAK,CAAC;QAC1B,CAAC,yBAAyB,EAAE,CAAC,EAAE,IAAI,CAAC;QACpC,CAAC,cAAc,EAAE,CAAC,EAAE,KAAK,CAAC;QAC1B,CAAC,+BAA+B,EAAE,EAAE,EAAE,IAAI,CAAC;QAC3C,CAAC,gBAAgB,EAAE,CAAC,EAAE,KAAK,CAAC;KAC7B,CAAC,CACA,kCAAkC,eAAK,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,EAC3D,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;QACvB,MAAM,CAAC,IAAA,qCAAwB,EAAC,MAAM,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACzE,CAAC,CACF,CAAC;IAEF,IAAI,CAAC,IAAI,CAAC;QACR,CAAC,IAAI,EAAE,CAAC,EAAE,IAAI,CAAC;QACf,CAAC,IAAI,EAAE,CAAC,EAAE,KAAK,CAAC;QAChB,CAAC,OAAO,EAAE,CAAC,EAAE,IAAI,CAAC;QAClB,CAAC,IAAI,EAAE,CAAC,EAAE,KAAK,CAAC;KACjB,CAAC,CACA,4EAA4E,EAC5E,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;QACvB,MAAM,SAAS,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC;QACxC,IAAI,YAAY,GAAG,CAAC,CAAC;QAErB,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,qBAAqB,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE;YAChE,MAAM,OAAO,GAAG,SAAS,CAAC,YAAY,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;YAC3D,YAAY,IAAI,CAAC,CAAC;YAClB,OAAO,OAAO,CAAC;QACjB,CAAC,CAAC,CAAC;QAEH,MAAM,YAAY,GAAG,IAAA,qCAAwB,EAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAE5D,MAAM,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAErC,YAAY,GAAG,CAAC,CAAC;QACjB,MAAM,CACJ,IAAA,qBAAc,EAAC,GAAG,EAAE,CAAC,IAAA,qCAAwB,EAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAC7D,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;IAC1B,CAAC,CACF,CAAC;IAEF,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAChB,yDAAyD,EACzD,CAAC,KAAK,EAAE,EAAE;QACR,IAAA,wCAAiC,EAC/B,GAAG,EAAE,CAAC,IAAA,qCAAwB,EAAC,EAAE,EAAE,KAAK,CAAC,EACzC,mCAAmC,CACpC,CAAC;IACJ,CAAC,CACF,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -0,0 +1,83 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.default = main;
7
+ exports.prompt = prompt;
8
+ const extended_euclidean_1 = __importDefault(require("../../algorithms/extended-euclidean"));
9
+ const wasm_1 = require("../../shared/algorithm/wasm");
10
+ const chalk_1 = __importDefault(require("../../shared/cli/chalk"));
11
+ const prompt_1 = require("../../shared/cli/prompt");
12
+ const runWASMMultiplicativeInverse = (0, wasm_1.createWASMInvoker)("multiplicative-inverse", (wasmExports, base, modulo) => {
13
+ if (!wasmExports.multiplicative_inverse_i64 ||
14
+ modulo <= 1n ||
15
+ !(0, wasm_1.fitsInI64)(base) ||
16
+ !(0, wasm_1.fitsInI64)(modulo)) {
17
+ return null;
18
+ }
19
+ const value = wasmExports.multiplicative_inverse_i64((0, wasm_1.normalizeI64)(base), (0, wasm_1.normalizeI64)(modulo));
20
+ if (value === wasm_1.MIN_I64) {
21
+ return null;
22
+ }
23
+ return value;
24
+ });
25
+ function main(base, modulo, number) {
26
+ if (modulo <= 1n) {
27
+ throw new Error("modulo must be greater than 1.");
28
+ }
29
+ if (number <= 0) {
30
+ throw new Error("number must be a positive integer.");
31
+ }
32
+ const maybeWASMInverse = runWASMMultiplicativeInverse(base, modulo);
33
+ let inverse;
34
+ if (maybeWASMInverse !== null) {
35
+ inverse = maybeWASMInverse;
36
+ }
37
+ else {
38
+ const [gcd, x] = (0, extended_euclidean_1.default)(base, modulo);
39
+ if (gcd !== 1n) {
40
+ throw new Error("base and modulo must be coprime.");
41
+ }
42
+ inverse = ((x % modulo) + modulo) % modulo;
43
+ }
44
+ const arrayOfInverse = [];
45
+ for (let count = BigInt(1); count <= number; count++) {
46
+ arrayOfInverse.push(inverse * count);
47
+ }
48
+ return arrayOfInverse;
49
+ }
50
+ const runPrompt = (0, prompt_1.createAlgorithmPrompt)("multiplicative-inverse", async ({ ask, writeLine }) => {
51
+ writeLine("\tmultiplicativeInverse(base, modulo, count) = [values]");
52
+ writeLine(chalk_1.default.gray("\tmultiplicativeInverse(23, 41, 5) = [25,50,75,100,125]"));
53
+ const { base, modulo, number } = await ask([
54
+ {
55
+ type: "number",
56
+ name: "base",
57
+ message: `Enter ${chalk_1.default.italic("base")}:`,
58
+ default: 23,
59
+ },
60
+ {
61
+ type: "number",
62
+ name: "modulo",
63
+ message: `Enter ${chalk_1.default.italic("modulo")}:`,
64
+ default: 41,
65
+ },
66
+ {
67
+ type: "number",
68
+ name: "number",
69
+ message: `Enter ${chalk_1.default.italic("count")}:`,
70
+ default: 5,
71
+ },
72
+ ]);
73
+ const result = main(BigInt(base), BigInt(modulo), Number(number));
74
+ writeLine(`\tResult = ${result}`);
75
+ return {
76
+ inputs: { base, modulo, count: number },
77
+ result,
78
+ };
79
+ });
80
+ async function prompt(options) {
81
+ return runPrompt(options);
82
+ }
83
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../source/algorithms/multiplicative-inverse/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const multiplicative_inverse_1 = __importDefault(require("../../algorithms/multiplicative-inverse"));
7
+ const chalk_1 = __importDefault(require("../../shared/cli/chalk"));
8
+ const wasm_1 = require("../../shared/testing/wasm");
9
+ describe("Finding the Multiplicative Inverses of the given numbers", () => {
10
+ test.each([
11
+ { base: 87, modulo: 131, result: [128, 256, 384, 512, 640] },
12
+ { base: 23, modulo: 41, result: [25, 50, 75, 100, 125] },
13
+ { base: 11, modulo: 13, result: [6, 12, 18, 24, 30] },
14
+ { base: 2, modulo: 7, result: [4, 8, 12, 16, 20] },
15
+ { base: 1011, modulo: 913, result: [736, 1472, 2208, 2944, 3680] },
16
+ ])(`y is the multiplicative inverse of $base $ $modulo ($base * y % $modulo = 1)\n\ty = ${chalk_1.default.greenBright("$result")}`, ({ base, modulo, result }) => {
17
+ const execute = () => (0, multiplicative_inverse_1.default)(BigInt(base), BigInt(modulo), 5);
18
+ expect(execute()).toEqual(result.map((item) => BigInt(item)));
19
+ (0, wasm_1.expectSameResultWithAndWithoutWASM)(execute);
20
+ });
21
+ test.each([
22
+ [23n, 1n, 5, "modulo must be greater than 1."],
23
+ [23n, 41n, 0, "number must be a positive integer."],
24
+ [2n, 4n, 1, "base and modulo must be coprime."],
25
+ [(1n << 63n) + 1n, 3n, 1, "base and modulo must be coprime."],
26
+ ])("keeps the same error with and without WASM for %p mod %p", (base, modulo, count, errorMessage) => {
27
+ (0, wasm_1.expectSameErrorWithAndWithoutWASM)(() => (0, multiplicative_inverse_1.default)(base, modulo, count), errorMessage);
28
+ });
29
+ });
30
+ //# sourceMappingURL=index.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../../source/algorithms/multiplicative-inverse/index.test.ts"],"names":[],"mappings":";;;;;AAAA,iGAAwE;AACxE,+DAAuC;AACvC,gDAG+B;AAE/B,QAAQ,CAAC,0DAA0D,EAAE,GAAG,EAAE;IACxE,IAAI,CAAC,IAAI,CAAC;QACR,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE;QAC5D,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE;QACxD,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE;QACrD,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE;QAClD,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE;KACnE,CAAC,CACA,uFAAuF,eAAK,CAAC,WAAW,CACtG,SAAS,CACV,EAAE,EACH,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE;QAC3B,MAAM,OAAO,GAAG,GAAG,EAAE,CACnB,IAAA,gCAAqB,EAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAEzD,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC9D,IAAA,yCAAkC,EAAC,OAAO,CAAC,CAAC;IAC9C,CAAC,CACF,CAAC;IAEF,IAAI,CAAC,IAAI,CAAC;QACR,CAAC,GAAG,EAAE,EAAE,EAAE,CAAC,EAAE,gCAAgC,CAAC;QAC9C,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,oCAAoC,CAAC;QACnD,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,kCAAkC,CAAC;QAC/C,CAAC,CAAC,EAAE,IAAI,GAAG,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,kCAAkC,CAAC;KAC9D,CAAC,CACA,0DAA0D,EAC1D,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,EAAE,EAAE;QACpC,IAAA,wCAAiC,EAC/B,GAAG,EAAE,CAAC,IAAA,gCAAqB,EAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,EAChD,YAAY,CACb,CAAC;IACJ,CAAC,CACF,CAAC;AACJ,CAAC,CAAC,CAAC"}