Skip to content

Commit

Permalink
fix: do not cleanup thread all the time while doing parallel proof gen
Browse files Browse the repository at this point in the history
  • Loading branch information
ctrlc03 committed Sep 4, 2024
1 parent 6bf1ffb commit c30e104
Show file tree
Hide file tree
Showing 2 changed files with 36 additions and 12 deletions.
15 changes: 12 additions & 3 deletions packages/circuits/ts/proofs.ts
Original file line number Diff line number Diff line change
Expand Up @@ -118,25 +118,34 @@ async function unlinkFile(filepath: string): Promise<void> {
* @param publicInputs - the public inputs to the circuit
* @param proof - the proof
* @param vk - the verification key
* @param cleanup - whether to cleanup the threads or not
* @returns whether the proof is valid or not
*/
export const verifyProof = async (
publicInputs: PublicSignals,
proof: Groth16Proof,
vk: ISnarkJSVerificationKey,
cleanup = true,
): Promise<boolean> => {
const isValid = await groth16.verify(vk, publicInputs, proof);
await cleanThreads();
if (cleanup) {
await cleanThreads();
}
return isValid;
};

/**
* Extract the Verification Key from a zKey
* @param zkeyPath - the path to the zKey
* @param cleanup - whether to cleanup the threads or not
* @returns the verification key
*/
export const extractVk = async (zkeyPath: string): Promise<IVkObjectParams> =>
export const extractVk = async (zkeyPath: string, cleanup = true): Promise<IVkObjectParams> =>
zKey
.exportVerificationKey(zkeyPath)
.then((vk) => vk as IVkObjectParams)
.finally(() => cleanThreads());
.finally(() => {
if (cleanup) {
cleanThreads();
}
});
33 changes: 24 additions & 9 deletions packages/contracts/tasks/helpers/ProofGenerator.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/* eslint-disable no-console */
import { Network } from "hardhat/types";
import { extractVk, genProof, verifyProof } from "maci-circuits";
import { cleanThreads, extractVk, genProof, verifyProof } from "maci-circuits";
import { CircuitInputs, IJsonMaciState, MaciState, Poll } from "maci-core";
import { genTreeCommitment, hash3, hashLeftRight } from "maci-crypto";

Expand All @@ -16,6 +16,7 @@ import type {
} from "./types";
import type { Proof } from "../../ts/types";
import type { BigNumberish } from "ethers";
import type { IVkObjectParams } from "maci-domainobjs";

import { asHex } from "../../ts/utils";

Expand Down Expand Up @@ -217,9 +218,11 @@ export class ProofGenerator {

console.log("Wait until proof generation is finished");

const processZkey = await extractVk(this.mp.zkey, false);

const proofs = await Promise.all(
inputs.map((circuitInputs, index) =>
this.generateProofs(circuitInputs, this.mp, `process_${index}.json`).then((data) => {
this.generateProofs(circuitInputs, this.mp, `process_${index}.json`, processZkey).then((data) => {
options?.onBatchComplete?.({ current: index, total: totalMessageBatches, proofs: data });
return data;
}),
Expand All @@ -228,6 +231,9 @@ export class ProofGenerator {

console.log("Proof generation is finished");

// cleanup threads
await cleanThreads();

performance.mark("mp-proofs-end");
performance.measure("Generate message processor proofs", "mp-proofs-start", "mp-proofs-end");

Expand Down Expand Up @@ -277,17 +283,27 @@ export class ProofGenerator {

console.log("Wait until proof generation is finished");

const tallyVk = await extractVk(this.tally.zkey, false);

const proofs = await Promise.all(
inputs.map((circuitInputs, index) =>
this.generateProofs(circuitInputs, this.tally, `tally_${index}.json`).then((data) => {
options?.onBatchComplete?.({ current: index, total: totalTallyBatches, proofs: data });
return data;
}),
this.generateProofs(circuitInputs, this.tally, `tally_${index}.json`, tallyVk)
.then((data) => {
options?.onBatchComplete?.({ current: index, total: totalTallyBatches, proofs: data });
return data;
})
.catch((error) => {
console.log(`Error in batch ${index}: ${error}`);
throw error;
}),
),
).then((data) => data.reduce((acc, x) => acc.concat(x), []));

console.log("Proof generation is finished");

// cleanup threads
await cleanThreads();

// verify the results
// Compute newResultsCommitment
const newResultsCommitment = genTreeCommitment(
Expand Down Expand Up @@ -387,6 +403,7 @@ export class ProofGenerator {
circuitInputs: CircuitInputs,
circuitFiles: ICircuitFiles,
outputFile: string,
vk: IVkObjectParams,
): Promise<Proof[]> {
const proofs: Proof[] = [];

Expand All @@ -399,11 +416,9 @@ export class ProofGenerator {
wasmPath: circuitFiles.wasm,
});

// eslint-disable-next-line no-await-in-loop
const vk = await extractVk(circuitFiles.zkey);
// verify it
// eslint-disable-next-line no-await-in-loop
const isValid = await verifyProof(publicSignals, proof, vk);
const isValid = await verifyProof(publicSignals, proof, vk, false);

if (!isValid) {
throw new Error("Error: generated an invalid proof");
Expand Down

0 comments on commit c30e104

Please sign in to comment.