@noble/curves 1.9.0 → 1.9.2
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/README.md +78 -34
- package/_shortw_utils.d.ts +7 -5
- package/_shortw_utils.d.ts.map +1 -1
- package/_shortw_utils.js +2 -8
- package/_shortw_utils.js.map +1 -1
- package/abstract/bls.d.ts +60 -24
- package/abstract/bls.d.ts.map +1 -1
- package/abstract/bls.js +158 -109
- package/abstract/bls.js.map +1 -1
- package/abstract/curve.d.ts +44 -9
- package/abstract/curve.d.ts.map +1 -1
- package/abstract/curve.js +99 -11
- package/abstract/curve.js.map +1 -1
- package/abstract/edwards.d.ts +112 -25
- package/abstract/edwards.d.ts.map +1 -1
- package/abstract/edwards.js +141 -92
- package/abstract/edwards.js.map +1 -1
- package/abstract/fft.d.ts +122 -0
- package/abstract/fft.d.ts.map +1 -0
- package/abstract/fft.js +438 -0
- package/abstract/fft.js.map +1 -0
- package/abstract/hash-to-curve.d.ts +25 -11
- package/abstract/hash-to-curve.d.ts.map +1 -1
- package/abstract/hash-to-curve.js +17 -14
- package/abstract/hash-to-curve.js.map +1 -1
- package/abstract/modular.d.ts +28 -17
- package/abstract/modular.d.ts.map +1 -1
- package/abstract/modular.js +156 -139
- package/abstract/modular.js.map +1 -1
- package/abstract/montgomery.d.ts +3 -8
- package/abstract/montgomery.d.ts.map +1 -1
- package/abstract/montgomery.js +73 -93
- package/abstract/montgomery.js.map +1 -1
- package/abstract/poseidon.d.ts +5 -13
- package/abstract/poseidon.d.ts.map +1 -1
- package/abstract/poseidon.js +12 -7
- package/abstract/poseidon.js.map +1 -1
- package/abstract/tower.d.ts +20 -46
- package/abstract/tower.d.ts.map +1 -1
- package/abstract/tower.js +10 -4
- package/abstract/tower.js.map +1 -1
- package/abstract/utils.d.ts +1 -115
- package/abstract/utils.d.ts.map +1 -1
- package/abstract/utils.js +17 -371
- package/abstract/utils.js.map +1 -1
- package/abstract/weierstrass.d.ts +152 -73
- package/abstract/weierstrass.d.ts.map +1 -1
- package/abstract/weierstrass.js +487 -404
- package/abstract/weierstrass.js.map +1 -1
- package/bls12-381.d.ts +2 -0
- package/bls12-381.d.ts.map +1 -1
- package/bls12-381.js +504 -480
- package/bls12-381.js.map +1 -1
- package/bn254.d.ts +2 -0
- package/bn254.d.ts.map +1 -1
- package/bn254.js +44 -32
- package/bn254.js.map +1 -1
- package/ed25519.d.ts +25 -9
- package/ed25519.d.ts.map +1 -1
- package/ed25519.js +89 -65
- package/ed25519.js.map +1 -1
- package/ed448.d.ts +29 -10
- package/ed448.d.ts.map +1 -1
- package/ed448.js +116 -81
- package/ed448.js.map +1 -1
- package/esm/_shortw_utils.d.ts +7 -5
- package/esm/_shortw_utils.d.ts.map +1 -1
- package/esm/_shortw_utils.js +2 -8
- package/esm/_shortw_utils.js.map +1 -1
- package/esm/abstract/bls.d.ts +60 -24
- package/esm/abstract/bls.d.ts.map +1 -1
- package/esm/abstract/bls.js +158 -109
- package/esm/abstract/bls.js.map +1 -1
- package/esm/abstract/curve.d.ts +44 -9
- package/esm/abstract/curve.d.ts.map +1 -1
- package/esm/abstract/curve.js +96 -12
- package/esm/abstract/curve.js.map +1 -1
- package/esm/abstract/edwards.d.ts +112 -25
- package/esm/abstract/edwards.d.ts.map +1 -1
- package/esm/abstract/edwards.js +141 -94
- package/esm/abstract/edwards.js.map +1 -1
- package/esm/abstract/fft.d.ts +122 -0
- package/esm/abstract/fft.d.ts.map +1 -0
- package/esm/abstract/fft.js +425 -0
- package/esm/abstract/fft.js.map +1 -0
- package/esm/abstract/hash-to-curve.d.ts +25 -11
- package/esm/abstract/hash-to-curve.d.ts.map +1 -1
- package/esm/abstract/hash-to-curve.js +17 -14
- package/esm/abstract/hash-to-curve.js.map +1 -1
- package/esm/abstract/modular.d.ts +28 -17
- package/esm/abstract/modular.d.ts.map +1 -1
- package/esm/abstract/modular.js +155 -138
- package/esm/abstract/modular.js.map +1 -1
- package/esm/abstract/montgomery.d.ts +3 -8
- package/esm/abstract/montgomery.d.ts.map +1 -1
- package/esm/abstract/montgomery.js +74 -94
- package/esm/abstract/montgomery.js.map +1 -1
- package/esm/abstract/poseidon.d.ts +5 -13
- package/esm/abstract/poseidon.d.ts.map +1 -1
- package/esm/abstract/poseidon.js +12 -7
- package/esm/abstract/poseidon.js.map +1 -1
- package/esm/abstract/tower.d.ts +20 -46
- package/esm/abstract/tower.d.ts.map +1 -1
- package/esm/abstract/tower.js +10 -4
- package/esm/abstract/tower.js.map +1 -1
- package/esm/abstract/utils.d.ts +1 -115
- package/esm/abstract/utils.d.ts.map +1 -1
- package/esm/abstract/utils.js +3 -344
- package/esm/abstract/utils.js.map +1 -1
- package/esm/abstract/weierstrass.d.ts +152 -73
- package/esm/abstract/weierstrass.d.ts.map +1 -1
- package/esm/abstract/weierstrass.js +485 -406
- package/esm/abstract/weierstrass.js.map +1 -1
- package/esm/bls12-381.d.ts +2 -0
- package/esm/bls12-381.d.ts.map +1 -1
- package/esm/bls12-381.js +503 -479
- package/esm/bls12-381.js.map +1 -1
- package/esm/bn254.d.ts +2 -0
- package/esm/bn254.d.ts.map +1 -1
- package/esm/bn254.js +41 -29
- package/esm/bn254.js.map +1 -1
- package/esm/ed25519.d.ts +25 -9
- package/esm/ed25519.d.ts.map +1 -1
- package/esm/ed25519.js +84 -60
- package/esm/ed25519.js.map +1 -1
- package/esm/ed448.d.ts +29 -10
- package/esm/ed448.d.ts.map +1 -1
- package/esm/ed448.js +113 -78
- package/esm/ed448.js.map +1 -1
- package/esm/jubjub.d.ts +4 -0
- package/esm/jubjub.d.ts.map +1 -1
- package/esm/jubjub.js +4 -0
- package/esm/jubjub.js.map +1 -1
- package/esm/misc.d.ts.map +1 -1
- package/esm/misc.js +31 -26
- package/esm/misc.js.map +1 -1
- package/esm/nist.d.ts +8 -16
- package/esm/nist.d.ts.map +1 -1
- package/esm/nist.js +87 -97
- package/esm/nist.js.map +1 -1
- package/esm/p256.d.ts +3 -3
- package/esm/p384.d.ts +3 -3
- package/esm/p521.d.ts +3 -3
- package/esm/pasta.d.ts +4 -0
- package/esm/pasta.d.ts.map +1 -1
- package/esm/pasta.js +4 -0
- package/esm/pasta.js.map +1 -1
- package/esm/secp256k1.d.ts +6 -6
- package/esm/secp256k1.d.ts.map +1 -1
- package/esm/secp256k1.js +44 -41
- package/esm/secp256k1.js.map +1 -1
- package/esm/utils.d.ts +96 -0
- package/esm/utils.d.ts.map +1 -0
- package/esm/utils.js +279 -0
- package/esm/utils.js.map +1 -0
- package/jubjub.d.ts +4 -0
- package/jubjub.d.ts.map +1 -1
- package/jubjub.js +4 -0
- package/jubjub.js.map +1 -1
- package/misc.d.ts.map +1 -1
- package/misc.js +35 -30
- package/misc.js.map +1 -1
- package/nist.d.ts +8 -16
- package/nist.d.ts.map +1 -1
- package/nist.js +87 -97
- package/nist.js.map +1 -1
- package/p256.d.ts +3 -3
- package/p384.d.ts +3 -3
- package/p521.d.ts +3 -3
- package/package.json +26 -8
- package/pasta.d.ts +4 -0
- package/pasta.d.ts.map +1 -1
- package/pasta.js +4 -0
- package/pasta.js.map +1 -1
- package/secp256k1.d.ts +6 -6
- package/secp256k1.d.ts.map +1 -1
- package/secp256k1.js +47 -44
- package/secp256k1.js.map +1 -1
- package/src/_shortw_utils.ts +5 -15
- package/src/abstract/bls.ts +260 -145
- package/src/abstract/curve.ts +125 -18
- package/src/abstract/edwards.ts +282 -127
- package/src/abstract/fft.ts +519 -0
- package/src/abstract/hash-to-curve.ts +51 -27
- package/src/abstract/modular.ts +156 -143
- package/src/abstract/montgomery.ts +81 -111
- package/src/abstract/poseidon.ts +22 -18
- package/src/abstract/tower.ts +37 -68
- package/src/abstract/utils.ts +3 -378
- package/src/abstract/weierstrass.ts +752 -461
- package/src/bls12-381.ts +542 -507
- package/src/bn254.ts +47 -35
- package/src/ed25519.ts +104 -76
- package/src/ed448.ts +156 -105
- package/src/jubjub.ts +4 -0
- package/src/misc.ts +39 -34
- package/src/nist.ts +138 -126
- package/src/p256.ts +3 -3
- package/src/p384.ts +3 -3
- package/src/p521.ts +3 -3
- package/src/pasta.ts +5 -1
- package/src/secp256k1.ts +59 -47
- package/src/utils.ts +328 -0
- package/utils.d.ts +96 -0
- package/utils.d.ts.map +1 -0
- package/utils.js +313 -0
- package/utils.js.map +1 -0
package/abstract/fft.js
ADDED
|
@@ -0,0 +1,438 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FFTCore = void 0;
|
|
4
|
+
exports.isPowerOfTwo = isPowerOfTwo;
|
|
5
|
+
exports.nextPowerOfTwo = nextPowerOfTwo;
|
|
6
|
+
exports.reverseBits = reverseBits;
|
|
7
|
+
exports.log2 = log2;
|
|
8
|
+
exports.bitReversalInplace = bitReversalInplace;
|
|
9
|
+
exports.bitReversalPermutation = bitReversalPermutation;
|
|
10
|
+
exports.rootsOfUnity = rootsOfUnity;
|
|
11
|
+
exports.FFT = FFT;
|
|
12
|
+
exports.poly = poly;
|
|
13
|
+
function checkU32(n) {
|
|
14
|
+
// 0xff_ff_ff_ff
|
|
15
|
+
if (!Number.isSafeInteger(n) || n < 0 || n > 0xffffffff)
|
|
16
|
+
throw new Error('wrong u32 integer:' + n);
|
|
17
|
+
return n;
|
|
18
|
+
}
|
|
19
|
+
/** Checks if integer is in form of `1 << X` */
|
|
20
|
+
function isPowerOfTwo(x) {
|
|
21
|
+
checkU32(x);
|
|
22
|
+
return (x & (x - 1)) === 0 && x !== 0;
|
|
23
|
+
}
|
|
24
|
+
function nextPowerOfTwo(n) {
|
|
25
|
+
checkU32(n);
|
|
26
|
+
if (n <= 1)
|
|
27
|
+
return 1;
|
|
28
|
+
return (1 << (log2(n - 1) + 1)) >>> 0;
|
|
29
|
+
}
|
|
30
|
+
function reverseBits(n, bits) {
|
|
31
|
+
checkU32(n);
|
|
32
|
+
let reversed = 0;
|
|
33
|
+
for (let i = 0; i < bits; i++, n >>>= 1)
|
|
34
|
+
reversed = (reversed << 1) | (n & 1);
|
|
35
|
+
return reversed;
|
|
36
|
+
}
|
|
37
|
+
/** Similar to `bitLen(x)-1` but much faster for small integers, like indices */
|
|
38
|
+
function log2(n) {
|
|
39
|
+
checkU32(n);
|
|
40
|
+
return 31 - Math.clz32(n);
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Moves lowest bit to highest position, which at first step splits
|
|
44
|
+
* array on even and odd indices, then it applied again to each part,
|
|
45
|
+
* which is core of fft
|
|
46
|
+
*/
|
|
47
|
+
function bitReversalInplace(values) {
|
|
48
|
+
const n = values.length;
|
|
49
|
+
if (n < 2 || !isPowerOfTwo(n))
|
|
50
|
+
throw new Error('n must be a power of 2 and greater than 1. Got ' + n);
|
|
51
|
+
const bits = log2(n);
|
|
52
|
+
for (let i = 0; i < n; i++) {
|
|
53
|
+
const j = reverseBits(i, bits);
|
|
54
|
+
if (i < j) {
|
|
55
|
+
const tmp = values[i];
|
|
56
|
+
values[i] = values[j];
|
|
57
|
+
values[j] = tmp;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return values;
|
|
61
|
+
}
|
|
62
|
+
function bitReversalPermutation(values) {
|
|
63
|
+
return bitReversalInplace(values.slice());
|
|
64
|
+
}
|
|
65
|
+
const _1n = /** @__PURE__ */ BigInt(1);
|
|
66
|
+
function findGenerator(field) {
|
|
67
|
+
let G = BigInt(2);
|
|
68
|
+
for (; field.eql(field.pow(G, field.ORDER >> _1n), field.ONE); G++)
|
|
69
|
+
;
|
|
70
|
+
return G;
|
|
71
|
+
}
|
|
72
|
+
/** We limit roots up to 2**31, which is a lot: 2-billion polynomimal should be rare. */
|
|
73
|
+
function rootsOfUnity(field, generator) {
|
|
74
|
+
// Factor field.ORDER-1 as oddFactor * 2^powerOfTwo
|
|
75
|
+
let oddFactor = field.ORDER - _1n;
|
|
76
|
+
let powerOfTwo = 0;
|
|
77
|
+
for (; (oddFactor & _1n) !== _1n; powerOfTwo++, oddFactor >>= _1n)
|
|
78
|
+
;
|
|
79
|
+
// Find non quadratic residue
|
|
80
|
+
let G = generator !== undefined ? BigInt(generator) : findGenerator(field);
|
|
81
|
+
// Powers of generator
|
|
82
|
+
const omegas = new Array(powerOfTwo + 1);
|
|
83
|
+
omegas[powerOfTwo] = field.pow(G, oddFactor);
|
|
84
|
+
for (let i = powerOfTwo; i > 0; i--)
|
|
85
|
+
omegas[i - 1] = field.sqr(omegas[i]);
|
|
86
|
+
// Compute all roots of unity for powers up to maxPower
|
|
87
|
+
const rootsCache = [];
|
|
88
|
+
const checkBits = (bits) => {
|
|
89
|
+
checkU32(bits);
|
|
90
|
+
if (bits > 31 || bits > powerOfTwo)
|
|
91
|
+
throw new Error('rootsOfUnity: wrong bits ' + bits + ' powerOfTwo=' + powerOfTwo);
|
|
92
|
+
return bits;
|
|
93
|
+
};
|
|
94
|
+
const precomputeRoots = (maxPower) => {
|
|
95
|
+
checkBits(maxPower);
|
|
96
|
+
for (let power = maxPower; power >= 0; power--) {
|
|
97
|
+
if (rootsCache[power])
|
|
98
|
+
continue; // Skip if we've already computed roots for this power
|
|
99
|
+
const rootsAtPower = [];
|
|
100
|
+
for (let j = 0, cur = field.ONE; j < 2 ** power; j++, cur = field.mul(cur, omegas[power]))
|
|
101
|
+
rootsAtPower.push(cur);
|
|
102
|
+
rootsCache[power] = rootsAtPower;
|
|
103
|
+
}
|
|
104
|
+
return rootsCache[maxPower];
|
|
105
|
+
};
|
|
106
|
+
const brpCache = new Map();
|
|
107
|
+
const inverseCache = new Map();
|
|
108
|
+
// NOTE: we use bits instead of power, because power = 2**bits,
|
|
109
|
+
// but power is not neccesary isPowerOfTwo(power)!
|
|
110
|
+
return {
|
|
111
|
+
roots: (bits) => {
|
|
112
|
+
const b = checkBits(bits);
|
|
113
|
+
return precomputeRoots(b);
|
|
114
|
+
},
|
|
115
|
+
brp(bits) {
|
|
116
|
+
const b = checkBits(bits);
|
|
117
|
+
if (brpCache.has(b))
|
|
118
|
+
return brpCache.get(b);
|
|
119
|
+
else {
|
|
120
|
+
const res = bitReversalPermutation(this.roots(b));
|
|
121
|
+
brpCache.set(b, res);
|
|
122
|
+
return res;
|
|
123
|
+
}
|
|
124
|
+
},
|
|
125
|
+
inverse(bits) {
|
|
126
|
+
const b = checkBits(bits);
|
|
127
|
+
if (inverseCache.has(b))
|
|
128
|
+
return inverseCache.get(b);
|
|
129
|
+
else {
|
|
130
|
+
const res = field.invertBatch(this.roots(b));
|
|
131
|
+
inverseCache.set(b, res);
|
|
132
|
+
return res;
|
|
133
|
+
}
|
|
134
|
+
},
|
|
135
|
+
omega: (bits) => omegas[checkBits(bits)],
|
|
136
|
+
clear: () => {
|
|
137
|
+
rootsCache.splice(0, rootsCache.length);
|
|
138
|
+
brpCache.clear();
|
|
139
|
+
},
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Constructs different flavors of FFT. radix2 implementation of low level mutating API. Flavors:
|
|
144
|
+
*
|
|
145
|
+
* - DIT (Decimation-in-Time): Bottom-Up (leaves -> root), Cool-Turkey
|
|
146
|
+
* - DIF (Decimation-in-Frequency): Top-Down (root -> leaves), Gentleman–Sande
|
|
147
|
+
*
|
|
148
|
+
* DIT takes brp input, returns natural output.
|
|
149
|
+
* DIF takes natural input, returns brp output.
|
|
150
|
+
*
|
|
151
|
+
* The output is actually identical. Time / frequence distinction is not meaningful
|
|
152
|
+
* for Polynomial multiplication in fields.
|
|
153
|
+
* Which means if protocol supports/needs brp output/inputs, then we can skip this step.
|
|
154
|
+
*
|
|
155
|
+
* Cyclic NTT: Rq = Zq[x]/(x^n-1). butterfly_DIT+loop_DIT OR butterfly_DIF+loop_DIT, roots are omega
|
|
156
|
+
* Negacyclic NTT: Rq = Zq[x]/(x^n+1). butterfly_DIT+loop_DIF, at least for mlkem / mldsa
|
|
157
|
+
*/
|
|
158
|
+
const FFTCore = (F, coreOpts) => {
|
|
159
|
+
const { N, roots, dit, invertButterflies = false, skipStages = 0, brp = true } = coreOpts;
|
|
160
|
+
const bits = log2(N);
|
|
161
|
+
if (!isPowerOfTwo(N))
|
|
162
|
+
throw new Error('FFT: Polynomial size should be power of two');
|
|
163
|
+
const isDit = dit !== invertButterflies;
|
|
164
|
+
isDit;
|
|
165
|
+
return (values) => {
|
|
166
|
+
if (values.length !== N)
|
|
167
|
+
throw new Error('FFT: wrong Polynomial length');
|
|
168
|
+
if (dit && brp)
|
|
169
|
+
bitReversalInplace(values);
|
|
170
|
+
for (let i = 0, g = 1; i < bits - skipStages; i++) {
|
|
171
|
+
// For each stage s (sub-FFT length m = 2^s)
|
|
172
|
+
const s = dit ? i + 1 + skipStages : bits - i;
|
|
173
|
+
const m = 1 << s;
|
|
174
|
+
const m2 = m >> 1;
|
|
175
|
+
const stride = N >> s;
|
|
176
|
+
// Loop over each subarray of length m
|
|
177
|
+
for (let k = 0; k < N; k += m) {
|
|
178
|
+
// Loop over each butterfly within the subarray
|
|
179
|
+
for (let j = 0, grp = g++; j < m2; j++) {
|
|
180
|
+
const rootPos = invertButterflies ? (dit ? N - grp : grp) : j * stride;
|
|
181
|
+
const i0 = k + j;
|
|
182
|
+
const i1 = k + j + m2;
|
|
183
|
+
const omega = roots[rootPos];
|
|
184
|
+
const b = values[i1];
|
|
185
|
+
const a = values[i0];
|
|
186
|
+
// Inlining gives us 10% perf in kyber vs functions
|
|
187
|
+
if (isDit) {
|
|
188
|
+
const t = F.mul(b, omega); // Standard DIT butterfly
|
|
189
|
+
values[i0] = F.add(a, t);
|
|
190
|
+
values[i1] = F.sub(a, t);
|
|
191
|
+
}
|
|
192
|
+
else if (invertButterflies) {
|
|
193
|
+
values[i0] = F.add(b, a); // DIT loop + inverted butterflies (Kyber decode)
|
|
194
|
+
values[i1] = F.mul(F.sub(b, a), omega);
|
|
195
|
+
}
|
|
196
|
+
else {
|
|
197
|
+
values[i0] = F.add(a, b); // Standard DIF butterfly
|
|
198
|
+
values[i1] = F.mul(F.sub(a, b), omega);
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
if (!dit && brp)
|
|
204
|
+
bitReversalInplace(values);
|
|
205
|
+
return values;
|
|
206
|
+
};
|
|
207
|
+
};
|
|
208
|
+
exports.FFTCore = FFTCore;
|
|
209
|
+
/**
|
|
210
|
+
* NTT aka FFT over finite field (NOT over complex numbers).
|
|
211
|
+
* Naming mirrors other libraries.
|
|
212
|
+
*/
|
|
213
|
+
function FFT(roots, opts) {
|
|
214
|
+
const getLoop = (N, roots, brpInput = false, brpOutput = false) => {
|
|
215
|
+
if (brpInput && brpOutput) {
|
|
216
|
+
// we cannot optimize this case, but lets support it anyway
|
|
217
|
+
return (values) => (0, exports.FFTCore)(opts, { N, roots, dit: false, brp: false })(bitReversalInplace(values));
|
|
218
|
+
}
|
|
219
|
+
if (brpInput)
|
|
220
|
+
return (0, exports.FFTCore)(opts, { N, roots, dit: true, brp: false });
|
|
221
|
+
if (brpOutput)
|
|
222
|
+
return (0, exports.FFTCore)(opts, { N, roots, dit: false, brp: false });
|
|
223
|
+
return (0, exports.FFTCore)(opts, { N, roots, dit: true, brp: true }); // all natural
|
|
224
|
+
};
|
|
225
|
+
return {
|
|
226
|
+
direct(values, brpInput = false, brpOutput = false) {
|
|
227
|
+
const N = values.length;
|
|
228
|
+
if (!isPowerOfTwo(N))
|
|
229
|
+
throw new Error('FFT: Polynomial size should be power of two');
|
|
230
|
+
const bits = log2(N);
|
|
231
|
+
return getLoop(N, roots.roots(bits), brpInput, brpOutput)(values.slice());
|
|
232
|
+
},
|
|
233
|
+
inverse(values, brpInput = false, brpOutput = false) {
|
|
234
|
+
const N = values.length;
|
|
235
|
+
const bits = log2(N);
|
|
236
|
+
const res = getLoop(N, roots.inverse(bits), brpInput, brpOutput)(values.slice());
|
|
237
|
+
const ivm = opts.inv(BigInt(values.length)); // scale
|
|
238
|
+
// we can get brp output if we use dif instead of dit!
|
|
239
|
+
for (let i = 0; i < res.length; i++)
|
|
240
|
+
res[i] = opts.mul(res[i], ivm);
|
|
241
|
+
// Allows to re-use non-inverted roots, but is VERY fragile
|
|
242
|
+
// return [res[0]].concat(res.slice(1).reverse());
|
|
243
|
+
// inverse calculated as pow(-1), which transforms into ω^{-kn} (-> reverses indices)
|
|
244
|
+
return res;
|
|
245
|
+
},
|
|
246
|
+
};
|
|
247
|
+
}
|
|
248
|
+
function poly(field, roots, create, fft, length) {
|
|
249
|
+
const F = field;
|
|
250
|
+
const _create = create ||
|
|
251
|
+
((len, elm) => new Array(len).fill(elm ?? F.ZERO));
|
|
252
|
+
const isPoly = (x) => Array.isArray(x) || ArrayBuffer.isView(x);
|
|
253
|
+
const checkLength = (...lst) => {
|
|
254
|
+
if (!lst.length)
|
|
255
|
+
return 0;
|
|
256
|
+
for (const i of lst)
|
|
257
|
+
if (!isPoly(i))
|
|
258
|
+
throw new Error('poly: not polynomial: ' + i);
|
|
259
|
+
const L = lst[0].length;
|
|
260
|
+
for (let i = 1; i < lst.length; i++)
|
|
261
|
+
if (lst[i].length !== L)
|
|
262
|
+
throw new Error(`poly: mismatched lengths ${L} vs ${lst[i].length}`);
|
|
263
|
+
if (length !== undefined && L !== length)
|
|
264
|
+
throw new Error(`poly: expected fixed length ${length}, got ${L}`);
|
|
265
|
+
return L;
|
|
266
|
+
};
|
|
267
|
+
function findOmegaIndex(x, n, brp = false) {
|
|
268
|
+
const bits = log2(n);
|
|
269
|
+
const omega = brp ? roots.brp(bits) : roots.roots(bits);
|
|
270
|
+
for (let i = 0; i < n; i++)
|
|
271
|
+
if (F.eql(x, omega[i]))
|
|
272
|
+
return i;
|
|
273
|
+
return -1;
|
|
274
|
+
}
|
|
275
|
+
// TODO: mutating versions for mlkem/mldsa
|
|
276
|
+
return {
|
|
277
|
+
roots,
|
|
278
|
+
create: _create,
|
|
279
|
+
length,
|
|
280
|
+
extend: (a, len) => {
|
|
281
|
+
checkLength(a);
|
|
282
|
+
const out = _create(len, F.ZERO);
|
|
283
|
+
for (let i = 0; i < a.length; i++)
|
|
284
|
+
out[i] = a[i];
|
|
285
|
+
return out;
|
|
286
|
+
},
|
|
287
|
+
degree: (a) => {
|
|
288
|
+
checkLength(a);
|
|
289
|
+
for (let i = a.length - 1; i >= 0; i--)
|
|
290
|
+
if (!F.is0(a[i]))
|
|
291
|
+
return i;
|
|
292
|
+
return -1;
|
|
293
|
+
},
|
|
294
|
+
add: (a, b) => {
|
|
295
|
+
const len = checkLength(a, b);
|
|
296
|
+
const out = _create(len);
|
|
297
|
+
for (let i = 0; i < len; i++)
|
|
298
|
+
out[i] = F.add(a[i], b[i]);
|
|
299
|
+
return out;
|
|
300
|
+
},
|
|
301
|
+
sub: (a, b) => {
|
|
302
|
+
const len = checkLength(a, b);
|
|
303
|
+
const out = _create(len);
|
|
304
|
+
for (let i = 0; i < len; i++)
|
|
305
|
+
out[i] = F.sub(a[i], b[i]);
|
|
306
|
+
return out;
|
|
307
|
+
},
|
|
308
|
+
dot: (a, b) => {
|
|
309
|
+
const len = checkLength(a, b);
|
|
310
|
+
const out = _create(len);
|
|
311
|
+
for (let i = 0; i < len; i++)
|
|
312
|
+
out[i] = F.mul(a[i], b[i]);
|
|
313
|
+
return out;
|
|
314
|
+
},
|
|
315
|
+
mul: (a, b) => {
|
|
316
|
+
if (isPoly(b)) {
|
|
317
|
+
const len = checkLength(a, b);
|
|
318
|
+
if (fft) {
|
|
319
|
+
const A = fft.direct(a, false, true);
|
|
320
|
+
const B = fft.direct(b, false, true);
|
|
321
|
+
for (let i = 0; i < A.length; i++)
|
|
322
|
+
A[i] = F.mul(A[i], B[i]);
|
|
323
|
+
return fft.inverse(A, true, false);
|
|
324
|
+
}
|
|
325
|
+
else {
|
|
326
|
+
// NOTE: this is quadratic and mostly for compat tests with FFT
|
|
327
|
+
const res = _create(len);
|
|
328
|
+
for (let i = 0; i < len; i++) {
|
|
329
|
+
for (let j = 0; j < len; j++) {
|
|
330
|
+
const k = (i + j) % len; // wrap mod length
|
|
331
|
+
res[k] = F.add(res[k], F.mul(a[i], b[j]));
|
|
332
|
+
}
|
|
333
|
+
}
|
|
334
|
+
return res;
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
else {
|
|
338
|
+
const out = _create(checkLength(a));
|
|
339
|
+
for (let i = 0; i < out.length; i++)
|
|
340
|
+
out[i] = F.mul(a[i], b);
|
|
341
|
+
return out;
|
|
342
|
+
}
|
|
343
|
+
},
|
|
344
|
+
convolve(a, b) {
|
|
345
|
+
const len = nextPowerOfTwo(a.length + b.length - 1);
|
|
346
|
+
return this.mul(this.extend(a, len), this.extend(b, len));
|
|
347
|
+
},
|
|
348
|
+
shift(p, factor) {
|
|
349
|
+
const out = _create(checkLength(p));
|
|
350
|
+
out[0] = p[0];
|
|
351
|
+
for (let i = 1, power = F.ONE; i < p.length; i++) {
|
|
352
|
+
power = F.mul(power, factor);
|
|
353
|
+
out[i] = F.mul(p[i], power);
|
|
354
|
+
}
|
|
355
|
+
return out;
|
|
356
|
+
},
|
|
357
|
+
clone: (a) => {
|
|
358
|
+
checkLength(a);
|
|
359
|
+
const out = _create(a.length);
|
|
360
|
+
for (let i = 0; i < a.length; i++)
|
|
361
|
+
out[i] = a[i];
|
|
362
|
+
return out;
|
|
363
|
+
},
|
|
364
|
+
eval: (a, basis) => {
|
|
365
|
+
checkLength(a);
|
|
366
|
+
let acc = F.ZERO;
|
|
367
|
+
for (let i = 0; i < a.length; i++)
|
|
368
|
+
acc = F.add(acc, F.mul(a[i], basis[i]));
|
|
369
|
+
return acc;
|
|
370
|
+
},
|
|
371
|
+
monomial: {
|
|
372
|
+
basis: (x, n) => {
|
|
373
|
+
const out = _create(n);
|
|
374
|
+
let pow = F.ONE;
|
|
375
|
+
for (let i = 0; i < n; i++) {
|
|
376
|
+
out[i] = pow;
|
|
377
|
+
pow = F.mul(pow, x);
|
|
378
|
+
}
|
|
379
|
+
return out;
|
|
380
|
+
},
|
|
381
|
+
eval: (a, x) => {
|
|
382
|
+
checkLength(a);
|
|
383
|
+
// Same as eval(a, monomialBasis(x, a.length)), but it is faster this way
|
|
384
|
+
let acc = F.ZERO;
|
|
385
|
+
for (let i = a.length - 1; i >= 0; i--)
|
|
386
|
+
acc = F.add(F.mul(acc, x), a[i]);
|
|
387
|
+
return acc;
|
|
388
|
+
},
|
|
389
|
+
},
|
|
390
|
+
lagrange: {
|
|
391
|
+
basis: (x, n, brp = false, weights) => {
|
|
392
|
+
const bits = log2(n);
|
|
393
|
+
const cache = weights || brp ? roots.brp(bits) : roots.roots(bits); // [ω⁰, ω¹, ..., ωⁿ⁻¹]
|
|
394
|
+
const out = _create(n);
|
|
395
|
+
// Fast Kronecker-δ shortcut
|
|
396
|
+
const idx = findOmegaIndex(x, n, brp);
|
|
397
|
+
if (idx !== -1) {
|
|
398
|
+
out[idx] = F.ONE;
|
|
399
|
+
return out;
|
|
400
|
+
}
|
|
401
|
+
const tm = F.pow(x, BigInt(n));
|
|
402
|
+
const c = F.mul(F.sub(tm, F.ONE), F.inv(BigInt(n))); // c = (xⁿ - 1)/n
|
|
403
|
+
const denom = _create(n);
|
|
404
|
+
for (let i = 0; i < n; i++)
|
|
405
|
+
denom[i] = F.sub(x, cache[i]);
|
|
406
|
+
const inv = F.invertBatch(denom);
|
|
407
|
+
for (let i = 0; i < n; i++)
|
|
408
|
+
out[i] = F.mul(c, F.mul(cache[i], inv[i]));
|
|
409
|
+
return out;
|
|
410
|
+
},
|
|
411
|
+
eval(a, x, brp = false) {
|
|
412
|
+
checkLength(a);
|
|
413
|
+
const idx = findOmegaIndex(x, a.length, brp);
|
|
414
|
+
if (idx !== -1)
|
|
415
|
+
return a[idx]; // fast path
|
|
416
|
+
const L = this.basis(x, a.length, brp); // Lᵢ(x)
|
|
417
|
+
let acc = F.ZERO;
|
|
418
|
+
for (let i = 0; i < a.length; i++)
|
|
419
|
+
if (!F.is0(a[i]))
|
|
420
|
+
acc = F.add(acc, F.mul(a[i], L[i]));
|
|
421
|
+
return acc;
|
|
422
|
+
},
|
|
423
|
+
},
|
|
424
|
+
vanishing(roots) {
|
|
425
|
+
checkLength(roots);
|
|
426
|
+
const out = _create(roots.length + 1, F.ZERO);
|
|
427
|
+
out[0] = F.ONE;
|
|
428
|
+
for (const r of roots) {
|
|
429
|
+
const neg = F.neg(r);
|
|
430
|
+
for (let j = out.length - 1; j > 0; j--)
|
|
431
|
+
out[j] = F.add(F.mul(out[j], neg), out[j - 1]);
|
|
432
|
+
out[0] = F.mul(out[0], neg);
|
|
433
|
+
}
|
|
434
|
+
return out;
|
|
435
|
+
},
|
|
436
|
+
};
|
|
437
|
+
}
|
|
438
|
+
//# sourceMappingURL=fft.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fft.js","sourceRoot":"","sources":["../src/abstract/fft.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,9 +5,9 @@
|
|
|
5
5
|
* @module
|
|
6
6
|
*/
|
|
7
7
|
/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */
|
|
8
|
+
import type { CHash } from '../utils.ts';
|
|
8
9
|
import type { AffinePoint, Group, GroupConstructor } from './curve.ts';
|
|
9
10
|
import { type IField } from './modular.ts';
|
|
10
|
-
import type { CHash } from './utils.ts';
|
|
11
11
|
export type UnicodeOrBytes = string | Uint8Array;
|
|
12
12
|
/**
|
|
13
13
|
* * `DST` is a domain separation tag, defined in section 2.2.5
|
|
@@ -17,14 +17,19 @@ export type UnicodeOrBytes = string | Uint8Array;
|
|
|
17
17
|
* * `expand` is `xmd` (SHA2, SHA3, BLAKE) or `xof` (SHAKE, BLAKE-XOF)
|
|
18
18
|
* * `hash` conforming to `utils.CHash` interface, with `outputLen` / `blockLen` props
|
|
19
19
|
*/
|
|
20
|
-
export type
|
|
20
|
+
export type H2COpts = {
|
|
21
21
|
DST: UnicodeOrBytes;
|
|
22
|
+
expand: 'xmd' | 'xof';
|
|
23
|
+
hash: CHash;
|
|
22
24
|
p: bigint;
|
|
23
25
|
m: number;
|
|
24
26
|
k: number;
|
|
27
|
+
};
|
|
28
|
+
export type H2CHashOpts = {
|
|
25
29
|
expand: 'xmd' | 'xof';
|
|
26
30
|
hash: CHash;
|
|
27
31
|
};
|
|
32
|
+
export type Opts = H2COpts;
|
|
28
33
|
/**
|
|
29
34
|
* Produces a uniformly random byte string using a cryptographic hash function H that outputs b bits.
|
|
30
35
|
* [RFC 9380 5.3.1](https://www.rfc-editor.org/rfc/rfc9380#section-5.3.1).
|
|
@@ -46,7 +51,7 @@ export declare function expand_message_xof(msg: Uint8Array, DST: Uint8Array, len
|
|
|
46
51
|
* @param options `{DST: string, p: bigint, m: number, k: number, expand: 'xmd' | 'xof', hash: H}`, see above
|
|
47
52
|
* @returns [u_0, ..., u_(count - 1)], a list of field elements.
|
|
48
53
|
*/
|
|
49
|
-
export declare function hash_to_field(msg: Uint8Array, count: number, options:
|
|
54
|
+
export declare function hash_to_field(msg: Uint8Array, count: number, options: H2COpts): bigint[][];
|
|
50
55
|
export type XY<T> = (x: T, y: T) => {
|
|
51
56
|
x: T;
|
|
52
57
|
y: T;
|
|
@@ -67,18 +72,27 @@ export type MapToCurve<T> = (scalar: bigint[]) => AffinePoint<T>;
|
|
|
67
72
|
export type htfBasicOpts = {
|
|
68
73
|
DST: UnicodeOrBytes;
|
|
69
74
|
};
|
|
70
|
-
export type
|
|
75
|
+
export type H2CMethod<T> = (msg: Uint8Array, options?: htfBasicOpts) => H2CPoint<T>;
|
|
76
|
+
export type HTFMethod<T> = H2CMethod<T>;
|
|
71
77
|
export type MapMethod<T> = (scalars: bigint[]) => H2CPoint<T>;
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
78
|
+
/**
|
|
79
|
+
* RFC 9380 methods, with cofactor clearing. See https://www.rfc-editor.org/rfc/rfc9380#section-3.
|
|
80
|
+
*
|
|
81
|
+
* * hashToCurve: `map(hash(input))`, encodes RANDOM bytes to curve (WITH hashing)
|
|
82
|
+
* * encodeToCurve: `map(hash(input))`, encodes NON-UNIFORM bytes to curve (WITH hashing)
|
|
83
|
+
* * mapToCurve: `map(scalars)`, encodes NON-UNIFORM scalars to curve (NO hashing)
|
|
84
|
+
*/
|
|
85
|
+
export type H2CHasher<T> = {
|
|
86
|
+
hashToCurve: H2CMethod<T>;
|
|
87
|
+
encodeToCurve: H2CMethod<T>;
|
|
75
88
|
mapToCurve: MapMethod<T>;
|
|
76
|
-
defaults:
|
|
89
|
+
defaults: H2COpts & {
|
|
77
90
|
encodeDST?: UnicodeOrBytes;
|
|
78
91
|
};
|
|
79
92
|
};
|
|
80
|
-
|
|
81
|
-
|
|
93
|
+
export type Hasher<T> = H2CHasher<T>;
|
|
94
|
+
/** Creates hash-to-curve methods from EC Point and mapToCurve function. See {@link H2CHasher}. */
|
|
95
|
+
export declare function createHasher<T>(Point: H2CPointConstructor<T>, mapToCurve: MapToCurve<T>, defaults: H2COpts & {
|
|
82
96
|
encodeDST?: UnicodeOrBytes;
|
|
83
|
-
}):
|
|
97
|
+
}): H2CHasher<T>;
|
|
84
98
|
//# sourceMappingURL=hash-to-curve.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hash-to-curve.d.ts","sourceRoot":"","sources":["../src/abstract/hash-to-curve.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,sEAAsE;AACtE,OAAO,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AACvE,OAAO,EAAiB,KAAK,MAAM,EAAO,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"hash-to-curve.d.ts","sourceRoot":"","sources":["../src/abstract/hash-to-curve.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,8 +5,8 @@ exports.expand_message_xof = expand_message_xof;
|
|
|
5
5
|
exports.hash_to_field = hash_to_field;
|
|
6
6
|
exports.isogenyMap = isogenyMap;
|
|
7
7
|
exports.createHasher = createHasher;
|
|
8
|
+
const utils_ts_1 = require("../utils.js");
|
|
8
9
|
const modular_ts_1 = require("./modular.js");
|
|
9
|
-
const utils_ts_1 = require("./utils.js");
|
|
10
10
|
// Octet Stream to Integer. "spec" implementation of os2ip is 2.5x slower vs bytesToNumberBE.
|
|
11
11
|
const os2ip = utils_ts_1.bytesToNumberBE;
|
|
12
12
|
// Integer to Octet Stream (numberToBytesBE)
|
|
@@ -97,14 +97,17 @@ function expand_message_xof(msg, DST, lenInBytes, k, H) {
|
|
|
97
97
|
* @returns [u_0, ..., u_(count - 1)], a list of field elements.
|
|
98
98
|
*/
|
|
99
99
|
function hash_to_field(msg, count, options) {
|
|
100
|
-
(0, utils_ts_1.
|
|
101
|
-
DST: 'stringOrUint8Array',
|
|
100
|
+
(0, utils_ts_1._validateObject)(options, {
|
|
102
101
|
p: 'bigint',
|
|
103
|
-
m: '
|
|
104
|
-
k: '
|
|
105
|
-
hash: '
|
|
102
|
+
m: 'number',
|
|
103
|
+
k: 'number',
|
|
104
|
+
hash: 'function',
|
|
106
105
|
});
|
|
107
106
|
const { p, k, m, hash, expand, DST: _DST } = options;
|
|
107
|
+
if (!(0, utils_ts_1.isBytes)(_DST) && typeof _DST !== 'string')
|
|
108
|
+
throw new Error('DST must be string or uint8array');
|
|
109
|
+
if (!(0, utils_ts_1.isHash)(options.hash))
|
|
110
|
+
throw new Error('expected valid hash');
|
|
108
111
|
(0, utils_ts_1.abytes)(msg);
|
|
109
112
|
anum(count);
|
|
110
113
|
const DST = typeof _DST === 'string' ? (0, utils_ts_1.utf8ToBytes)(_DST) : _DST;
|
|
@@ -152,7 +155,7 @@ function isogenyMap(field, map) {
|
|
|
152
155
|
return { x, y };
|
|
153
156
|
};
|
|
154
157
|
}
|
|
155
|
-
/** Creates hash-to-curve methods from EC Point and mapToCurve function. */
|
|
158
|
+
/** Creates hash-to-curve methods from EC Point and mapToCurve function. See {@link H2CHasher}. */
|
|
156
159
|
function createHasher(Point, mapToCurve, defaults) {
|
|
157
160
|
if (typeof mapToCurve !== 'function')
|
|
158
161
|
throw new Error('mapToCurve() must be defined');
|
|
@@ -168,21 +171,21 @@ function createHasher(Point, mapToCurve, defaults) {
|
|
|
168
171
|
}
|
|
169
172
|
return {
|
|
170
173
|
defaults,
|
|
171
|
-
// Encodes byte string to elliptic curve.
|
|
172
|
-
// hash_to_curve from https://www.rfc-editor.org/rfc/rfc9380#section-3
|
|
173
174
|
hashToCurve(msg, options) {
|
|
174
|
-
const
|
|
175
|
+
const dst = defaults.DST ? defaults.DST : {};
|
|
176
|
+
const opts = Object.assign({}, defaults, dst, options);
|
|
177
|
+
const u = hash_to_field(msg, 2, opts);
|
|
175
178
|
const u0 = map(u[0]);
|
|
176
179
|
const u1 = map(u[1]);
|
|
177
180
|
return clear(u0.add(u1));
|
|
178
181
|
},
|
|
179
|
-
// Encodes byte string to elliptic curve.
|
|
180
|
-
// encode_to_curve from https://www.rfc-editor.org/rfc/rfc9380#section-3
|
|
181
182
|
encodeToCurve(msg, options) {
|
|
182
|
-
const
|
|
183
|
+
const dst = defaults.encodeDST ? defaults.encodeDST : {};
|
|
184
|
+
const opts = Object.assign({}, defaults, dst, options);
|
|
185
|
+
const u = hash_to_field(msg, 1, opts);
|
|
183
186
|
return clear(map(u[0]));
|
|
184
187
|
},
|
|
185
|
-
|
|
188
|
+
/** See {@link H2CHasher} */
|
|
186
189
|
mapToCurve(scalars) {
|
|
187
190
|
if (!Array.isArray(scalars))
|
|
188
191
|
throw new Error('expected array of bigints');
|