diff --git a/build/cli.cjs b/build/cli.cjs index b637f2c5..840b64fa 100755 --- a/build/cli.cjs +++ b/build/cli.cjs @@ -3770,19 +3770,17 @@ async function readHeaderGroth16(fd, sections, toObject) { const n8r = await fd.readULE32(); zkey.n8r = n8r; zkey.r = await binFileUtils__namespace.readBigInt(fd, n8r); - - let curve = await getCurveFromQ(zkey.q); - + zkey.curve = await getCurveFromQ(zkey.q); zkey.nVars = await fd.readULE32(); zkey.nPublic = await fd.readULE32(); zkey.domainSize = await fd.readULE32(); zkey.power = log2(zkey.domainSize); - zkey.vk_alpha_1 = await readG1(fd, curve, toObject); - zkey.vk_beta_1 = await readG1(fd, curve, toObject); - zkey.vk_beta_2 = await readG2(fd, curve, toObject); - zkey.vk_gamma_2 = await readG2(fd, curve, toObject); - zkey.vk_delta_1 = await readG1(fd, curve, toObject); - zkey.vk_delta_2 = await readG2(fd, curve, toObject); + zkey.vk_alpha_1 = await readG1(fd, zkey.curve, toObject); + zkey.vk_beta_1 = await readG1(fd, zkey.curve, toObject); + zkey.vk_beta_2 = await readG2(fd, zkey.curve, toObject); + zkey.vk_gamma_2 = await readG2(fd, zkey.curve, toObject); + zkey.vk_delta_1 = await readG1(fd, zkey.curve, toObject); + zkey.vk_delta_2 = await readG2(fd, zkey.curve, toObject); await binFileUtils__namespace.endReadSection(fd); return zkey; @@ -3807,9 +3805,7 @@ async function readHeaderPlonk(fd, sections, protocol, toObject) { const n8r = await fd.readULE32(); zkey.n8r = n8r; zkey.r = await binFileUtils__namespace.readBigInt(fd, n8r); - - let curve = await getCurveFromQ(zkey.q); - + zkey.curve = await getCurveFromQ(zkey.q); zkey.nVars = await fd.readULE32(); zkey.nPublic = await fd.readULE32(); zkey.domainSize = await fd.readULE32(); @@ -3819,15 +3815,15 @@ async function readHeaderPlonk(fd, sections, protocol, toObject) { zkey.k1 = await fd.read(n8r); zkey.k2 = await fd.read(n8r); - zkey.Qm = await readG1(fd, curve, toObject); - zkey.Ql = await readG1(fd, curve, toObject); - zkey.Qr = await readG1(fd, curve, toObject); - zkey.Qo = await readG1(fd, curve, toObject); - zkey.Qc = await readG1(fd, curve, toObject); - zkey.S1 = await readG1(fd, curve, toObject); - zkey.S2 = await readG1(fd, curve, toObject); - zkey.S3 = await readG1(fd, curve, toObject); - zkey.X_2 = await readG2(fd, curve, toObject); + zkey.Qm = await readG1(fd, zkey.curve, toObject); + zkey.Ql = await readG1(fd, zkey.curve, toObject); + zkey.Qr = await readG1(fd, zkey.curve, toObject); + zkey.Qo = await readG1(fd, zkey.curve, toObject); + zkey.Qc = await readG1(fd, zkey.curve, toObject); + zkey.S1 = await readG1(fd, zkey.curve, toObject); + zkey.S2 = await readG1(fd, zkey.curve, toObject); + zkey.S3 = await readG1(fd, zkey.curve, toObject); + zkey.X_2 = await readG2(fd, zkey.curve, toObject); await binFileUtils__namespace.endReadSection(fd); @@ -5508,7 +5504,7 @@ async function groth16Prove$1(zkeyFileName, witnessFileName, logger) { throw new Error(`Invalid witness length. Circuit: ${zkey.nVars}, witness: ${wtns.nWitness}`); } - const curve = await getCurveFromQ(zkey.q); + const curve = zkey.curve; const Fr = curve.Fr; const G1 = curve.G1; const G2 = curve.G2; @@ -6468,7 +6464,7 @@ async function plonk16Prove(zkeyFileName, witnessFileName, logger) { throw new Error(`Invalid witness length. Circuit: ${zkey.nVars}, witness: ${wtns.nWitness}, ${zkey.nAdditions}`); } - const curve = await getCurveFromQ(zkey.q); + const curve = zkey.curve; const Fr = curve.Fr; const G1 = curve.G1; const n8r = curve.Fr.n8; diff --git a/build/main.cjs b/build/main.cjs index 9e83fabd..f86c8774 100644 --- a/build/main.cjs +++ b/build/main.cjs @@ -357,19 +357,17 @@ async function readHeaderGroth16(fd, sections, toObject) { const n8r = await fd.readULE32(); zkey.n8r = n8r; zkey.r = await binFileUtils__namespace.readBigInt(fd, n8r); - - let curve = await getCurveFromQ(zkey.q); - + zkey.curve = await getCurveFromQ(zkey.q); zkey.nVars = await fd.readULE32(); zkey.nPublic = await fd.readULE32(); zkey.domainSize = await fd.readULE32(); zkey.power = log2(zkey.domainSize); - zkey.vk_alpha_1 = await readG1(fd, curve, toObject); - zkey.vk_beta_1 = await readG1(fd, curve, toObject); - zkey.vk_beta_2 = await readG2(fd, curve, toObject); - zkey.vk_gamma_2 = await readG2(fd, curve, toObject); - zkey.vk_delta_1 = await readG1(fd, curve, toObject); - zkey.vk_delta_2 = await readG2(fd, curve, toObject); + zkey.vk_alpha_1 = await readG1(fd, zkey.curve, toObject); + zkey.vk_beta_1 = await readG1(fd, zkey.curve, toObject); + zkey.vk_beta_2 = await readG2(fd, zkey.curve, toObject); + zkey.vk_gamma_2 = await readG2(fd, zkey.curve, toObject); + zkey.vk_delta_1 = await readG1(fd, zkey.curve, toObject); + zkey.vk_delta_2 = await readG2(fd, zkey.curve, toObject); await binFileUtils__namespace.endReadSection(fd); return zkey; @@ -394,9 +392,7 @@ async function readHeaderPlonk(fd, sections, protocol, toObject) { const n8r = await fd.readULE32(); zkey.n8r = n8r; zkey.r = await binFileUtils__namespace.readBigInt(fd, n8r); - - let curve = await getCurveFromQ(zkey.q); - + zkey.curve = await getCurveFromQ(zkey.q); zkey.nVars = await fd.readULE32(); zkey.nPublic = await fd.readULE32(); zkey.domainSize = await fd.readULE32(); @@ -406,15 +402,15 @@ async function readHeaderPlonk(fd, sections, protocol, toObject) { zkey.k1 = await fd.read(n8r); zkey.k2 = await fd.read(n8r); - zkey.Qm = await readG1(fd, curve, toObject); - zkey.Ql = await readG1(fd, curve, toObject); - zkey.Qr = await readG1(fd, curve, toObject); - zkey.Qo = await readG1(fd, curve, toObject); - zkey.Qc = await readG1(fd, curve, toObject); - zkey.S1 = await readG1(fd, curve, toObject); - zkey.S2 = await readG1(fd, curve, toObject); - zkey.S3 = await readG1(fd, curve, toObject); - zkey.X_2 = await readG2(fd, curve, toObject); + zkey.Qm = await readG1(fd, zkey.curve, toObject); + zkey.Ql = await readG1(fd, zkey.curve, toObject); + zkey.Qr = await readG1(fd, zkey.curve, toObject); + zkey.Qo = await readG1(fd, zkey.curve, toObject); + zkey.Qc = await readG1(fd, zkey.curve, toObject); + zkey.S1 = await readG1(fd, zkey.curve, toObject); + zkey.S2 = await readG1(fd, zkey.curve, toObject); + zkey.S3 = await readG1(fd, zkey.curve, toObject); + zkey.X_2 = await readG2(fd, zkey.curve, toObject); await binFileUtils__namespace.endReadSection(fd); @@ -775,7 +771,7 @@ async function groth16Prove(zkeyFileName, witnessFileName, logger) { throw new Error(`Invalid witness length. Circuit: ${zkey.nVars}, witness: ${wtns.nWitness}`); } - const curve = await getCurveFromQ(zkey.q); + const curve = zkey.curve; const Fr = curve.Fr; const G1 = curve.G1; const G2 = curve.G2; @@ -6425,7 +6421,7 @@ async function plonk16Prove(zkeyFileName, witnessFileName, logger) { throw new Error(`Invalid witness length. Circuit: ${zkey.nVars}, witness: ${wtns.nWitness}, ${zkey.nAdditions}`); } - const curve = await getCurveFromQ(zkey.q); + const curve = zkey.curve; const Fr = curve.Fr; const G1 = curve.G1; const n8r = curve.Fr.n8; diff --git a/src/groth16_prove.js b/src/groth16_prove.js index 49f91833..b3453044 100644 --- a/src/groth16_prove.js +++ b/src/groth16_prove.js @@ -46,7 +46,7 @@ export default async function groth16Prove(zkeyFileName, witnessFileName, logger throw new Error(`Invalid witness length. Circuit: ${zkey.nVars}, witness: ${wtns.nWitness}`); } - const curve = await getCurve(zkey.q); + const curve = zkey.curve; const Fr = curve.Fr; const G1 = curve.G1; const G2 = curve.G2; diff --git a/src/plonk_prove.js b/src/plonk_prove.js index 4a26fab8..47e85547 100644 --- a/src/plonk_prove.js +++ b/src/plonk_prove.js @@ -48,7 +48,7 @@ export default async function plonk16Prove(zkeyFileName, witnessFileName, logger throw new Error(`Invalid witness length. Circuit: ${zkey.nVars}, witness: ${wtns.nWitness}, ${zkey.nAdditions}`); } - const curve = await getCurve(zkey.q); + const curve = zkey.curve; const Fr = curve.Fr; const G1 = curve.G1; const n8r = curve.Fr.n8; diff --git a/src/zkey_utils.js b/src/zkey_utils.js index 93b05b3d..3d046804 100644 --- a/src/zkey_utils.js +++ b/src/zkey_utils.js @@ -237,19 +237,17 @@ async function readHeaderGroth16(fd, sections, toObject) { const n8r = await fd.readULE32(); zkey.n8r = n8r; zkey.r = await binFileUtils.readBigInt(fd, n8r); - - let curve = await getCurve(zkey.q); - + zkey.curve = await getCurve(zkey.q); zkey.nVars = await fd.readULE32(); zkey.nPublic = await fd.readULE32(); zkey.domainSize = await fd.readULE32(); zkey.power = log2(zkey.domainSize); - zkey.vk_alpha_1 = await readG1(fd, curve, toObject); - zkey.vk_beta_1 = await readG1(fd, curve, toObject); - zkey.vk_beta_2 = await readG2(fd, curve, toObject); - zkey.vk_gamma_2 = await readG2(fd, curve, toObject); - zkey.vk_delta_1 = await readG1(fd, curve, toObject); - zkey.vk_delta_2 = await readG2(fd, curve, toObject); + zkey.vk_alpha_1 = await readG1(fd, zkey.curve, toObject); + zkey.vk_beta_1 = await readG1(fd, zkey.curve, toObject); + zkey.vk_beta_2 = await readG2(fd, zkey.curve, toObject); + zkey.vk_gamma_2 = await readG2(fd, zkey.curve, toObject); + zkey.vk_delta_1 = await readG1(fd, zkey.curve, toObject); + zkey.vk_delta_2 = await readG2(fd, zkey.curve, toObject); await binFileUtils.endReadSection(fd); return zkey; @@ -274,9 +272,7 @@ async function readHeaderPlonk(fd, sections, protocol, toObject) { const n8r = await fd.readULE32(); zkey.n8r = n8r; zkey.r = await binFileUtils.readBigInt(fd, n8r); - - let curve = await getCurve(zkey.q); - + zkey.curve = await getCurve(zkey.q); zkey.nVars = await fd.readULE32(); zkey.nPublic = await fd.readULE32(); zkey.domainSize = await fd.readULE32(); @@ -286,15 +282,15 @@ async function readHeaderPlonk(fd, sections, protocol, toObject) { zkey.k1 = await fd.read(n8r); zkey.k2 = await fd.read(n8r); - zkey.Qm = await readG1(fd, curve, toObject); - zkey.Ql = await readG1(fd, curve, toObject); - zkey.Qr = await readG1(fd, curve, toObject); - zkey.Qo = await readG1(fd, curve, toObject); - zkey.Qc = await readG1(fd, curve, toObject); - zkey.S1 = await readG1(fd, curve, toObject); - zkey.S2 = await readG1(fd, curve, toObject); - zkey.S3 = await readG1(fd, curve, toObject); - zkey.X_2 = await readG2(fd, curve, toObject); + zkey.Qm = await readG1(fd, zkey.curve, toObject); + zkey.Ql = await readG1(fd, zkey.curve, toObject); + zkey.Qr = await readG1(fd, zkey.curve, toObject); + zkey.Qo = await readG1(fd, zkey.curve, toObject); + zkey.Qc = await readG1(fd, zkey.curve, toObject); + zkey.S1 = await readG1(fd, zkey.curve, toObject); + zkey.S2 = await readG1(fd, zkey.curve, toObject); + zkey.S3 = await readG1(fd, zkey.curve, toObject); + zkey.X_2 = await readG2(fd, zkey.curve, toObject); await binFileUtils.endReadSection(fd);