@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.
- package/LICENSE.md +19 -0
- package/README.md +79 -0
- package/build/algorithms/baby-step-giant-step/index.js +89 -0
- package/build/algorithms/baby-step-giant-step/index.js.map +1 -0
- package/build/algorithms/baby-step-giant-step/index.test.js +32 -0
- package/build/algorithms/baby-step-giant-step/index.test.js.map +1 -0
- package/build/algorithms/blum-blum-shub/index.js +88 -0
- package/build/algorithms/blum-blum-shub/index.js.map +1 -0
- package/build/algorithms/blum-blum-shub/index.test.js +74 -0
- package/build/algorithms/blum-blum-shub/index.test.js.map +1 -0
- package/build/algorithms/chinese-remainder/index.js +111 -0
- package/build/algorithms/chinese-remainder/index.js.map +1 -0
- package/build/algorithms/chinese-remainder/index.test.js +28 -0
- package/build/algorithms/chinese-remainder/index.test.js.map +1 -0
- package/build/algorithms/euclidean/index.js +60 -0
- package/build/algorithms/euclidean/index.js.map +1 -0
- package/build/algorithms/euclidean/index.test.js +22 -0
- package/build/algorithms/euclidean/index.test.js.map +1 -0
- package/build/algorithms/extended-euclidean/index.js +77 -0
- package/build/algorithms/extended-euclidean/index.js.map +1 -0
- package/build/algorithms/extended-euclidean/index.test.js +22 -0
- package/build/algorithms/extended-euclidean/index.test.js.map +1 -0
- package/build/algorithms/fast-modular-exponentiation/index.js +80 -0
- package/build/algorithms/fast-modular-exponentiation/index.js.map +1 -0
- package/build/algorithms/fast-modular-exponentiation/index.test.js +31 -0
- package/build/algorithms/fast-modular-exponentiation/index.test.js.map +1 -0
- package/build/algorithms/miller-rabin-primarily-test/index.js +87 -0
- package/build/algorithms/miller-rabin-primarily-test/index.js.map +1 -0
- package/build/algorithms/miller-rabin-primarily-test/index.test.js +78 -0
- package/build/algorithms/miller-rabin-primarily-test/index.test.js.map +1 -0
- package/build/algorithms/multiplicative-inverse/index.js +83 -0
- package/build/algorithms/multiplicative-inverse/index.js.map +1 -0
- package/build/algorithms/multiplicative-inverse/index.test.js +30 -0
- package/build/algorithms/multiplicative-inverse/index.test.js.map +1 -0
- package/build/algorithms/naor-reingo/index.js +85 -0
- package/build/algorithms/naor-reingo/index.js.map +1 -0
- package/build/algorithms/naor-reingo/index.test.js +27 -0
- package/build/algorithms/naor-reingo/index.test.js.map +1 -0
- package/build/algorithms/pollard-p-1-factorization/index.js +92 -0
- package/build/algorithms/pollard-p-1-factorization/index.js.map +1 -0
- package/build/algorithms/pollard-p-1-factorization/index.test.js +32 -0
- package/build/algorithms/pollard-p-1-factorization/index.test.js.map +1 -0
- package/build/algorithms/pollard-rho/index.js +82 -0
- package/build/algorithms/pollard-rho/index.js.map +1 -0
- package/build/algorithms/pollard-rho/index.test.js +26 -0
- package/build/algorithms/pollard-rho/index.test.js.map +1 -0
- package/build/algorithms/primitive-root-search/index.js +95 -0
- package/build/algorithms/primitive-root-search/index.js.map +1 -0
- package/build/algorithms/primitive-root-search/index.test.js +46 -0
- package/build/algorithms/primitive-root-search/index.test.js.map +1 -0
- package/build/command.js +79 -0
- package/build/command.js.map +1 -0
- package/build/entry-point.js +31 -0
- package/build/entry-point.js.map +1 -0
- package/build/key-encryptions/DiffieHellman.js +56 -0
- package/build/key-encryptions/DiffieHellman.js.map +1 -0
- package/build/key-encryptions/ElGamal.js +83 -0
- package/build/key-encryptions/ElGamal.js.map +1 -0
- package/build/key-encryptions/RSA.js +102 -0
- package/build/key-encryptions/RSA.js.map +1 -0
- package/build/shared/algorithm/math.js +9 -0
- package/build/shared/algorithm/math.js.map +1 -0
- package/build/shared/algorithm/random.js +52 -0
- package/build/shared/algorithm/random.js.map +1 -0
- package/build/shared/algorithm/wasm.js +105 -0
- package/build/shared/algorithm/wasm.js.map +1 -0
- package/build/shared/algorithm/wrap.js +57 -0
- package/build/shared/algorithm/wrap.js.map +1 -0
- package/build/shared/cli/Procedure.js +51 -0
- package/build/shared/cli/Procedure.js.map +1 -0
- package/build/shared/cli/chalk.js +48 -0
- package/build/shared/cli/chalk.js.map +1 -0
- package/build/shared/cli/inquirer.js +13 -0
- package/build/shared/cli/inquirer.js.map +1 -0
- package/build/shared/cli/prompt.js +98 -0
- package/build/shared/cli/prompt.js.map +1 -0
- package/build/shared/cli/utilities.js +145 -0
- package/build/shared/cli/utilities.js.map +1 -0
- package/build/shared/constants.js +21 -0
- package/build/shared/constants.js.map +1 -0
- package/build/shared/testing/wasm.js +78 -0
- package/build/shared/testing/wasm.js.map +1 -0
- package/build/source/algorithms/baby-step-giant-step/main.wasm +0 -0
- package/build/source/algorithms/blum-blum-shub/main.wasm +0 -0
- package/build/source/algorithms/chinese-remainder/main.wasm +0 -0
- package/build/source/algorithms/euclidean/main.wasm +0 -0
- package/build/source/algorithms/extended-euclidean/main.wasm +0 -0
- package/build/source/algorithms/fast-modular-exponentiation/main.wasm +0 -0
- package/build/source/algorithms/miller-rabin-primarily-test/main.wasm +0 -0
- package/build/source/algorithms/multiplicative-inverse/main.wasm +0 -0
- package/build/source/algorithms/naor-reingo/main.wasm +0 -0
- package/build/source/algorithms/pollard-p-1-factorization/main.wasm +0 -0
- package/build/source/algorithms/pollard-rho/main.wasm +0 -0
- package/build/source/algorithms/primitive-root-search/main.wasm +0 -0
- 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":";;;;;AA2BA,uBA8BC;AA6CD,wBAEC;AAxGD,kDAA6C;AAC7C,kDAAuE;AACvE,+DAAuC;AACvC,gDAG6B;AAE7B,MAAM,aAAa,GAAG,IAAA,wBAAiB,EACrC,6BAA6B,EAC7B,CAAC,WAAW,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE;IACtC,IACE,CAAC,WAAW,CAAC,UAAU;QACvB,IAAI,GAAG,EAAE;QACT,QAAQ,GAAG,EAAE;QACb,MAAM,IAAI,EAAE;QACZ,CAAC,IAAA,gBAAS,EAAC,IAAI,CAAC;QAChB,CAAC,IAAA,gBAAS,EAAC,QAAQ,CAAC;QACpB,CAAC,IAAA,gBAAS,EAAC,MAAM,CAAC,EAClB,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,WAAW,CAAC,UAAU,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;AACxD,CAAC,CACF,CAAC;AAEF,SAAwB,IAAI,CAC1B,IAAY,EACZ,QAAgB,EAChB,MAAc;IAEd,IAAI,MAAM,IAAI,EAAE,EAAE,CAAC;QACjB,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;IACpD,CAAC;IACD,IAAI,QAAQ,GAAG,EAAE,EAAE,CAAC;QAClB,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;IACpD,CAAC;IAED,MAAM,eAAe,GAAG,aAAa,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;IAC9D,IAAI,eAAe,KAAK,IAAI,EAAE,CAAC;QAC7B,OAAO,eAAe,CAAC;IACzB,CAAC;IAED,IAAI,MAAM,GAAG,EAAE,CAAC;IAChB,IAAI,WAAW,GAAG,CAAC,CAAC,IAAI,GAAG,MAAM,CAAC,GAAG,MAAM,CAAC,GAAG,MAAM,CAAC;IACtD,IAAI,eAAe,GAAG,QAAQ,CAAC;IAE/B,OAAO,eAAe,GAAG,EAAE,EAAE,CAAC;QAC5B,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC;YAClC,MAAM,GAAG,CAAC,MAAM,GAAG,WAAW,CAAC,GAAG,MAAM,CAAC;QAC3C,CAAC;QACD,WAAW,GAAG,CAAC,WAAW,GAAG,WAAW,CAAC,GAAG,MAAM,CAAC;QACnD,eAAe,KAAK,EAAE,CAAC;IACzB,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,SAAS,GAAG,IAAA,8BAAqB,EACrC,6BAA6B,EAC7B,KAAK,EAAE,EAAE,GAAG,EAAE,SAAS,EAAE,EAAE,EAAE;IAC3B,SAAS,CAAC,4BAA4B,mBAAO,CAAC,SAAS,gBAAgB,CAAC,CAAC;IACzE,SAAS,CAAC,eAAK,CAAC,IAAI,CAAC,gBAAgB,mBAAO,CAAC,SAAS,aAAa,CAAC,CAAC,CAAC;IAEtE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,CAIzC;QACD;YACE,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,MAAM;YACZ,OAAO,EAAE,SAAS,eAAK,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG;YACzC,OAAO,EAAE,CAAC;SACX;QACD;YACE,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,UAAU;YAChB,OAAO,EAAE,SAAS,eAAK,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG;YAC7C,OAAO,EAAE,GAAG;SACb;QACD;YACE,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,SAAS,eAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG;YAC3C,OAAO,EAAE,EAAE;SACZ;KACF,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;IACpE,SAAS,CACP,KAAK,IAAI,IAAI,QAAQ,MAAM,MAAM,IAAI,mBAAO,CAAC,SAAS,IAAI,MAAM,SAAS,MAAM,EAAE,CAClF,CAAC;IAEF,OAAO;QACL,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE;QAClC,MAAM;KACP,CAAC;AACJ,CAAC,CACF,CAAC;AAEK,KAAK,UAAU,MAAM,CAAC,OAAwB;IACnD,OAAO,SAAS,CAAC,OAAO,CAAC,CAAC;AAC5B,CAAC"}
|
|
@@ -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"}
|