@aztec/bb-prover 0.60.0 → 0.62.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/dest/bb/cli.d.ts.map +1 -1
- package/dest/bb/cli.js +3 -2
- package/dest/bb/execute.d.ts.map +1 -1
- package/dest/bb/execute.js +1 -8
- package/dest/prover/bb_private_kernel_prover.d.ts.map +1 -1
- package/dest/prover/bb_private_kernel_prover.js +2 -2
- package/dest/prover/bb_prover.d.ts +8 -33
- package/dest/prover/bb_prover.d.ts.map +1 -1
- package/dest/prover/bb_prover.js +35 -109
- package/dest/stats.d.ts.map +1 -1
- package/dest/stats.js +5 -9
- package/dest/test/test_circuit_prover.d.ts +5 -11
- package/dest/test/test_circuit_prover.d.ts.map +1 -1
- package/dest/test/test_circuit_prover.js +39 -141
- package/package.json +11 -8
- package/src/bb/cli.ts +1 -0
- package/src/bb/execute.ts +1 -7
- package/src/prover/bb_private_kernel_prover.ts +1 -0
- package/src/prover/bb_prover.ts +62 -176
- package/src/stats.ts +4 -8
- package/src/test/test_circuit_prover.ts +128 -327
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
2
|
import { makeProofAndVerificationKey, makePublicInputsAndRecursiveProof, } from '@aztec/circuit-types';
|
|
3
|
-
import { AVM_VERIFICATION_KEY_LENGTH_IN_FIELDS, EmptyNestedData, NESTED_RECURSIVE_PROOF_LENGTH, PrivateKernelEmptyInputs, RECURSIVE_PROOF_LENGTH, RootParityInput, TUBE_PROOF_LENGTH, VerificationKeyData,
|
|
3
|
+
import { AVM_PROOF_LENGTH_IN_FIELDS, AVM_VERIFICATION_KEY_LENGTH_IN_FIELDS, EmptyNestedData, NESTED_RECURSIVE_PROOF_LENGTH, PrivateKernelEmptyInputs, RECURSIVE_PROOF_LENGTH, RootParityInput, TUBE_PROOF_LENGTH, VerificationKeyData, makeEmptyRecursiveProof, makeRecursiveProof, } from '@aztec/circuits.js';
|
|
4
4
|
import { createDebugLogger } from '@aztec/foundation/log';
|
|
5
5
|
import { sleep } from '@aztec/foundation/sleep';
|
|
6
6
|
import { Timer } from '@aztec/foundation/timer';
|
|
7
|
-
import { ProtocolCircuitVkIndexes, ProtocolCircuitVks, SimulatedServerCircuitArtifacts, convertBaseParityInputsToWitnessMap, convertBaseParityOutputsFromWitnessMap, convertBlockMergeRollupInputsToWitnessMap, convertBlockMergeRollupOutputsFromWitnessMap, convertBlockRootRollupInputsToWitnessMap, convertBlockRootRollupOutputsFromWitnessMap, convertEmptyBlockRootRollupInputsToWitnessMap, convertEmptyBlockRootRollupOutputsFromWitnessMap, convertMergeRollupInputsToWitnessMap, convertMergeRollupOutputsFromWitnessMap, convertPrivateKernelEmptyInputsToWitnessMap, convertPrivateKernelEmptyOutputsFromWitnessMap, convertRootParityInputsToWitnessMap, convertRootParityOutputsFromWitnessMap, convertRootRollupInputsToWitnessMap, convertRootRollupOutputsFromWitnessMap,
|
|
7
|
+
import { ProtocolCircuitVkIndexes, ProtocolCircuitVks, SimulatedServerCircuitArtifacts, convertBaseParityInputsToWitnessMap, convertBaseParityOutputsFromWitnessMap, convertBlockMergeRollupInputsToWitnessMap, convertBlockMergeRollupOutputsFromWitnessMap, convertBlockRootRollupInputsToWitnessMap, convertBlockRootRollupOutputsFromWitnessMap, convertEmptyBlockRootRollupInputsToWitnessMap, convertEmptyBlockRootRollupOutputsFromWitnessMap, convertMergeRollupInputsToWitnessMap, convertMergeRollupOutputsFromWitnessMap, convertPrivateKernelEmptyInputsToWitnessMap, convertPrivateKernelEmptyOutputsFromWitnessMap, convertRootParityInputsToWitnessMap, convertRootParityOutputsFromWitnessMap, convertRootRollupInputsToWitnessMap, convertRootRollupOutputsFromWitnessMap, convertSimulatedPrivateBaseRollupInputsToWitnessMap, convertSimulatedPrivateBaseRollupOutputsFromWitnessMap, convertSimulatedPrivateKernelEmptyOutputsFromWitnessMap, convertSimulatedPublicBaseRollupInputsToWitnessMap, convertSimulatedPublicBaseRollupOutputsFromWitnessMap, getVKSiblingPath, } from '@aztec/noir-protocol-circuits-types';
|
|
8
8
|
import { WASMSimulator, emitCircuitSimulationStats } from '@aztec/simulator';
|
|
9
9
|
import { trackSpan } from '@aztec/telemetry-client';
|
|
10
10
|
import { ProverInstrumentation } from '../instrumentation.js';
|
|
@@ -18,15 +18,13 @@ let TestCircuitProver = (() => {
|
|
|
18
18
|
let _instanceExtraInitializers = [];
|
|
19
19
|
let _getBaseParityProof_decorators;
|
|
20
20
|
let _getRootParityProof_decorators;
|
|
21
|
-
let
|
|
21
|
+
let _getPrivateBaseRollupProof_decorators;
|
|
22
|
+
let _getPublicBaseRollupProof_decorators;
|
|
22
23
|
let _getMergeRollupProof_decorators;
|
|
23
24
|
let _getBlockRootRollupProof_decorators;
|
|
24
25
|
let _getEmptyBlockRootRollupProof_decorators;
|
|
25
26
|
let _getBlockMergeRollupProof_decorators;
|
|
26
27
|
let _getRootRollupProof_decorators;
|
|
27
|
-
let _getPublicKernelInnerProof_decorators;
|
|
28
|
-
let _getPublicKernelMergeProof_decorators;
|
|
29
|
-
let _getPublicTailProof_decorators;
|
|
30
28
|
return _a = class TestCircuitProver {
|
|
31
29
|
constructor(telemetry, simulationProvider, opts = { proverTestDelayMs: 0 }) {
|
|
32
30
|
this.simulationProvider = (__runInitializers(this, _instanceExtraInitializers), simulationProvider);
|
|
@@ -41,20 +39,12 @@ let TestCircuitProver = (() => {
|
|
|
41
39
|
async getEmptyPrivateKernelProof(inputs) {
|
|
42
40
|
const emptyNested = new EmptyNestedData(makeRecursiveProof(RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['EmptyNestedArtifact'].keyAsFields);
|
|
43
41
|
const kernelInputs = new PrivateKernelEmptyInputs(emptyNested, inputs.header, inputs.chainId, inputs.version, inputs.vkTreeRoot, inputs.protocolContractTreeRoot);
|
|
44
|
-
|
|
45
|
-
const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts.PrivateKernelEmptyArtifact);
|
|
46
|
-
const result = convertSimulatedPrivateKernelEmptyOutputsFromWitnessMap(witness);
|
|
47
|
-
await this.delay();
|
|
48
|
-
return makePublicInputsAndRecursiveProof(result, makeRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['PrivateKernelEmptyArtifact']);
|
|
42
|
+
return await this.simulate(kernelInputs, 'PrivateKernelEmptyArtifact', NESTED_RECURSIVE_PROOF_LENGTH, convertPrivateKernelEmptyInputsToWitnessMap, convertSimulatedPrivateKernelEmptyOutputsFromWitnessMap);
|
|
49
43
|
}
|
|
50
44
|
async getEmptyTubeProof(inputs) {
|
|
51
45
|
const emptyNested = new EmptyNestedData(makeRecursiveProof(RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['EmptyNestedArtifact'].keyAsFields);
|
|
52
46
|
const kernelInputs = new PrivateKernelEmptyInputs(emptyNested, inputs.header, inputs.chainId, inputs.version, inputs.vkTreeRoot, inputs.protocolContractTreeRoot);
|
|
53
|
-
|
|
54
|
-
const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts.PrivateKernelEmptyArtifact);
|
|
55
|
-
const result = convertPrivateKernelEmptyOutputsFromWitnessMap(witness);
|
|
56
|
-
await this.delay();
|
|
57
|
-
return makePublicInputsAndRecursiveProof(result, makeRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), VerificationKeyData.makeFakeHonk());
|
|
47
|
+
return await this.simulate(kernelInputs, 'EmptyNestedArtifact', NESTED_RECURSIVE_PROOF_LENGTH, convertPrivateKernelEmptyInputsToWitnessMap, convertPrivateKernelEmptyOutputsFromWitnessMap);
|
|
58
48
|
}
|
|
59
49
|
/**
|
|
60
50
|
* Simulates the base parity circuit from its inputs.
|
|
@@ -62,16 +52,8 @@ let TestCircuitProver = (() => {
|
|
|
62
52
|
* @returns The public inputs of the parity circuit.
|
|
63
53
|
*/
|
|
64
54
|
async getBaseParityProof(inputs) {
|
|
65
|
-
const
|
|
66
|
-
|
|
67
|
-
// use WASM here as it is faster for small circuits
|
|
68
|
-
const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts.BaseParityArtifact);
|
|
69
|
-
const result = convertBaseParityOutputsFromWitnessMap(witness);
|
|
70
|
-
const rootParityInput = new RootParityInput(makeRecursiveProof(RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['BaseParityArtifact'].keyAsFields, getVKSiblingPath(ProtocolCircuitVkIndexes['BaseParityArtifact']), result);
|
|
71
|
-
this.instrumentation.recordDuration('simulationDuration', 'base-parity', timer);
|
|
72
|
-
emitCircuitSimulationStats('base-parity', timer.ms(), inputs.toBuffer().length, result.toBuffer().length, this.logger);
|
|
73
|
-
await this.delay();
|
|
74
|
-
return Promise.resolve(rootParityInput);
|
|
55
|
+
const result = await this.simulate(inputs, 'BaseParityArtifact', RECURSIVE_PROOF_LENGTH, convertBaseParityInputsToWitnessMap, convertBaseParityOutputsFromWitnessMap);
|
|
56
|
+
return new RootParityInput(result.proof, result.verificationKey.keyAsFields, getVKSiblingPath(ProtocolCircuitVkIndexes['BaseParityArtifact']), result.inputs);
|
|
75
57
|
}
|
|
76
58
|
/**
|
|
77
59
|
* Simulates the root parity circuit from its inputs.
|
|
@@ -79,52 +61,26 @@ let TestCircuitProver = (() => {
|
|
|
79
61
|
* @returns The public inputs of the parity circuit.
|
|
80
62
|
*/
|
|
81
63
|
async getRootParityProof(inputs) {
|
|
82
|
-
const
|
|
83
|
-
|
|
84
|
-
// use WASM here as it is faster for small circuits
|
|
85
|
-
const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts.RootParityArtifact);
|
|
86
|
-
const result = convertRootParityOutputsFromWitnessMap(witness);
|
|
87
|
-
const rootParityInput = new RootParityInput(makeRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['RootParityArtifact'].keyAsFields, getVKSiblingPath(ProtocolCircuitVkIndexes['RootParityArtifact']), result);
|
|
88
|
-
this.instrumentation.recordDuration('simulationDuration', 'root-parity', timer);
|
|
89
|
-
emitCircuitSimulationStats('root-parity', timer.ms(), inputs.toBuffer().length, result.toBuffer().length, this.logger);
|
|
90
|
-
await this.delay();
|
|
91
|
-
return Promise.resolve(rootParityInput);
|
|
92
|
-
}
|
|
93
|
-
/**
|
|
94
|
-
* Simulates the base rollup circuit from its inputs.
|
|
95
|
-
* @param input - Inputs to the circuit.
|
|
96
|
-
* @returns The public inputs as outputs of the simulation.
|
|
97
|
-
*/
|
|
98
|
-
async getBaseRollupProof(input) {
|
|
99
|
-
const timer = new Timer();
|
|
100
|
-
const witnessMap = convertSimulatedBaseRollupInputsToWitnessMap(input);
|
|
101
|
-
const simulationProvider = this.simulationProvider ?? this.wasmSimulator;
|
|
102
|
-
const witness = await simulationProvider.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts.BaseRollupArtifact);
|
|
103
|
-
const result = convertSimulatedBaseRollupOutputsFromWitnessMap(witness);
|
|
104
|
-
this.instrumentation.recordDuration('simulationDuration', 'base-rollup', timer);
|
|
105
|
-
emitCircuitSimulationStats('base-rollup', timer.ms(), input.toBuffer().length, result.toBuffer().length, this.logger);
|
|
106
|
-
await this.delay();
|
|
107
|
-
return makePublicInputsAndRecursiveProof(result, makeRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['BaseRollupArtifact']);
|
|
64
|
+
const result = await this.simulate(inputs, 'RootParityArtifact', NESTED_RECURSIVE_PROOF_LENGTH, convertRootParityInputsToWitnessMap, convertRootParityOutputsFromWitnessMap);
|
|
65
|
+
return new RootParityInput(result.proof, result.verificationKey.keyAsFields, getVKSiblingPath(ProtocolCircuitVkIndexes['RootParityArtifact']), result.inputs);
|
|
108
66
|
}
|
|
109
67
|
async getTubeProof(_tubeInput) {
|
|
110
68
|
await this.delay();
|
|
111
69
|
return makeProofAndVerificationKey(makeEmptyRecursiveProof(TUBE_PROOF_LENGTH), VerificationKeyData.makeFakeHonk());
|
|
112
70
|
}
|
|
71
|
+
async getPrivateBaseRollupProof(inputs) {
|
|
72
|
+
return await this.simulate(inputs, 'PrivateBaseRollupArtifact', NESTED_RECURSIVE_PROOF_LENGTH, convertSimulatedPrivateBaseRollupInputsToWitnessMap, convertSimulatedPrivateBaseRollupOutputsFromWitnessMap);
|
|
73
|
+
}
|
|
74
|
+
async getPublicBaseRollupProof(inputs) {
|
|
75
|
+
return await this.simulate(inputs, 'PublicBaseRollupArtifact', NESTED_RECURSIVE_PROOF_LENGTH, convertSimulatedPublicBaseRollupInputsToWitnessMap, convertSimulatedPublicBaseRollupOutputsFromWitnessMap);
|
|
76
|
+
}
|
|
113
77
|
/**
|
|
114
78
|
* Simulates the merge rollup circuit from its inputs.
|
|
115
79
|
* @param input - Inputs to the circuit.
|
|
116
80
|
* @returns The public inputs as outputs of the simulation.
|
|
117
81
|
*/
|
|
118
82
|
async getMergeRollupProof(input) {
|
|
119
|
-
|
|
120
|
-
const witnessMap = convertMergeRollupInputsToWitnessMap(input);
|
|
121
|
-
// use WASM here as it is faster for small circuits
|
|
122
|
-
const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts.MergeRollupArtifact);
|
|
123
|
-
const result = convertMergeRollupOutputsFromWitnessMap(witness);
|
|
124
|
-
this.instrumentation.recordDuration('simulationDuration', 'merge-rollup', timer);
|
|
125
|
-
emitCircuitSimulationStats('merge-rollup', timer.ms(), input.toBuffer().length, result.toBuffer().length, this.logger);
|
|
126
|
-
await this.delay();
|
|
127
|
-
return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['MergeRollupArtifact']);
|
|
83
|
+
return await this.simulate(input, 'MergeRollupArtifact', NESTED_RECURSIVE_PROOF_LENGTH, convertMergeRollupInputsToWitnessMap, convertMergeRollupOutputsFromWitnessMap);
|
|
128
84
|
}
|
|
129
85
|
/**
|
|
130
86
|
* Simulates the block root rollup circuit from its inputs.
|
|
@@ -132,14 +88,7 @@ let TestCircuitProver = (() => {
|
|
|
132
88
|
* @returns The public inputs as outputs of the simulation.
|
|
133
89
|
*/
|
|
134
90
|
async getBlockRootRollupProof(input) {
|
|
135
|
-
|
|
136
|
-
const witnessMap = convertBlockRootRollupInputsToWitnessMap(input);
|
|
137
|
-
// use WASM here as it is faster for small circuits
|
|
138
|
-
const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts.BlockRootRollupArtifact);
|
|
139
|
-
const result = convertBlockRootRollupOutputsFromWitnessMap(witness);
|
|
140
|
-
this.instrumentation.recordDuration('simulationDuration', 'block-root-rollup', timer);
|
|
141
|
-
emitCircuitSimulationStats('block-root-rollup', timer.ms(), input.toBuffer().length, result.toBuffer().length, this.logger);
|
|
142
|
-
return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['BlockRootRollupArtifact']);
|
|
91
|
+
return await this.simulate(input, 'BlockRootRollupArtifact', NESTED_RECURSIVE_PROOF_LENGTH, convertBlockRootRollupInputsToWitnessMap, convertBlockRootRollupOutputsFromWitnessMap);
|
|
143
92
|
}
|
|
144
93
|
/**
|
|
145
94
|
* Simulates the empty block root rollup circuit from its inputs.
|
|
@@ -147,14 +96,7 @@ let TestCircuitProver = (() => {
|
|
|
147
96
|
* @returns The public inputs as outputs of the simulation.
|
|
148
97
|
*/
|
|
149
98
|
async getEmptyBlockRootRollupProof(input) {
|
|
150
|
-
|
|
151
|
-
const witnessMap = convertEmptyBlockRootRollupInputsToWitnessMap(input);
|
|
152
|
-
// use WASM here as it is faster for small circuits
|
|
153
|
-
const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts.EmptyBlockRootRollupArtifact);
|
|
154
|
-
const result = convertEmptyBlockRootRollupOutputsFromWitnessMap(witness);
|
|
155
|
-
this.instrumentation.recordDuration('simulationDuration', 'empty-block-root-rollup', timer);
|
|
156
|
-
emitCircuitSimulationStats('empty-block-root-rollup', timer.ms(), input.toBuffer().length, result.toBuffer().length, this.logger);
|
|
157
|
-
return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['EmptyBlockRootRollupArtifact']);
|
|
99
|
+
return await this.simulate(input, 'EmptyBlockRootRollupArtifact', NESTED_RECURSIVE_PROOF_LENGTH, convertEmptyBlockRootRollupInputsToWitnessMap, convertEmptyBlockRootRollupOutputsFromWitnessMap);
|
|
158
100
|
}
|
|
159
101
|
/**
|
|
160
102
|
* Simulates the block merge rollup circuit from its inputs.
|
|
@@ -162,14 +104,7 @@ let TestCircuitProver = (() => {
|
|
|
162
104
|
* @returns The public inputs as outputs of the simulation.
|
|
163
105
|
*/
|
|
164
106
|
async getBlockMergeRollupProof(input) {
|
|
165
|
-
|
|
166
|
-
const witnessMap = convertBlockMergeRollupInputsToWitnessMap(input);
|
|
167
|
-
// use WASM here as it is faster for small circuits
|
|
168
|
-
const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts.BlockMergeRollupArtifact);
|
|
169
|
-
const result = convertBlockMergeRollupOutputsFromWitnessMap(witness);
|
|
170
|
-
this.instrumentation.recordDuration('simulationDuration', 'block-merge-rollup', timer);
|
|
171
|
-
emitCircuitSimulationStats('block-merge-rollup', timer.ms(), input.toBuffer().length, result.toBuffer().length, this.logger);
|
|
172
|
-
return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['BlockMergeRollupArtifact']);
|
|
107
|
+
return await this.simulate(input, 'BlockMergeRollupArtifact', NESTED_RECURSIVE_PROOF_LENGTH, convertBlockMergeRollupInputsToWitnessMap, convertBlockMergeRollupOutputsFromWitnessMap);
|
|
173
108
|
}
|
|
174
109
|
/**
|
|
175
110
|
* Simulates the root rollup circuit from its inputs.
|
|
@@ -177,59 +112,14 @@ let TestCircuitProver = (() => {
|
|
|
177
112
|
* @returns The public inputs as outputs of the simulation.
|
|
178
113
|
*/
|
|
179
114
|
async getRootRollupProof(input) {
|
|
180
|
-
|
|
181
|
-
const witnessMap = convertRootRollupInputsToWitnessMap(input);
|
|
182
|
-
// use WASM here as it is faster for small circuits
|
|
183
|
-
const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts.RootRollupArtifact);
|
|
184
|
-
const result = convertRootRollupOutputsFromWitnessMap(witness);
|
|
185
|
-
this.instrumentation.recordDuration('simulationDuration', 'root-rollup', timer);
|
|
186
|
-
emitCircuitSimulationStats('root-rollup', timer.ms(), input.toBuffer().length, result.toBuffer().length, this.logger);
|
|
187
|
-
await this.delay();
|
|
188
|
-
return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['RootRollupArtifact']);
|
|
189
|
-
}
|
|
190
|
-
async getPublicKernelInnerProof(inputs) {
|
|
191
|
-
const timer = new Timer();
|
|
192
|
-
const artifact = 'PublicKernelInnerArtifact';
|
|
193
|
-
const circuitName = mapProtocolArtifactNameToCircuitName(artifact);
|
|
194
|
-
const witnessMap = convertSimulatedPublicInnerInputsToWitnessMap(inputs);
|
|
195
|
-
const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts[artifact]);
|
|
196
|
-
const result = convertSimulatedPublicInnerOutputFromWitnessMap(witness);
|
|
197
|
-
this.instrumentation.recordDuration('simulationDuration', circuitName, timer);
|
|
198
|
-
emitCircuitSimulationStats(circuitName, timer.ms(), inputs.toBuffer().length, result.toBuffer().length, this.logger);
|
|
199
|
-
await this.delay();
|
|
200
|
-
return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks[artifact]);
|
|
201
|
-
}
|
|
202
|
-
async getPublicKernelMergeProof(inputs) {
|
|
203
|
-
const timer = new Timer();
|
|
204
|
-
const artifact = 'PublicKernelMergeArtifact';
|
|
205
|
-
const circuitName = mapProtocolArtifactNameToCircuitName(artifact);
|
|
206
|
-
const witnessMap = convertSimulatedPublicMergeInputsToWitnessMap(inputs);
|
|
207
|
-
const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts[artifact]);
|
|
208
|
-
const result = convertSimulatedPublicMergeOutputFromWitnessMap(witness);
|
|
209
|
-
this.instrumentation.recordDuration('simulationDuration', circuitName, timer);
|
|
210
|
-
emitCircuitSimulationStats(circuitName, timer.ms(), inputs.toBuffer().length, result.toBuffer().length, this.logger);
|
|
211
|
-
await this.delay();
|
|
212
|
-
return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks[artifact]);
|
|
213
|
-
}
|
|
214
|
-
async getPublicTailProof(inputs) {
|
|
215
|
-
const timer = new Timer();
|
|
216
|
-
const artifact = 'PublicKernelTailArtifact';
|
|
217
|
-
const circuitName = mapProtocolArtifactNameToCircuitName(artifact);
|
|
218
|
-
const witnessMap = convertSimulatedPublicTailInputsToWitnessMap(inputs);
|
|
219
|
-
// use WASM here as it is faster for small circuits
|
|
220
|
-
const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts[artifact]);
|
|
221
|
-
const result = convertSimulatedPublicTailOutputFromWitnessMap(witness);
|
|
222
|
-
this.instrumentation.recordDuration('simulationDuration', circuitName, timer);
|
|
223
|
-
emitCircuitSimulationStats(circuitName, timer.ms(), inputs.toBuffer().length, result.toBuffer().length, this.logger);
|
|
224
|
-
await this.delay();
|
|
225
|
-
return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks[artifact]);
|
|
115
|
+
return await this.simulate(input, 'RootRollupArtifact', NESTED_RECURSIVE_PROOF_LENGTH, convertRootRollupInputsToWitnessMap, convertRootRollupOutputsFromWitnessMap);
|
|
226
116
|
}
|
|
227
117
|
async getAvmProof(_inputs) {
|
|
228
118
|
// We can't simulate the AVM because we don't have enough context to do so (e.g., DBs).
|
|
229
119
|
// We just return an empty proof and VK data.
|
|
230
120
|
this.logger.debug('Skipping AVM simulation in TestCircuitProver.');
|
|
231
121
|
await this.delay();
|
|
232
|
-
return makeProofAndVerificationKey(
|
|
122
|
+
return makeProofAndVerificationKey(makeEmptyRecursiveProof(AVM_PROOF_LENGTH_IN_FIELDS), VerificationKeyData.makeFake(AVM_VERIFICATION_KEY_LENGTH_IN_FIELDS));
|
|
233
123
|
}
|
|
234
124
|
async delay() {
|
|
235
125
|
if (this.opts.proverTestDelayMs > 0) {
|
|
@@ -240,34 +130,42 @@ let TestCircuitProver = (() => {
|
|
|
240
130
|
verifyProof(_1, _2) {
|
|
241
131
|
return Promise.reject(new Error('Method not implemented.'));
|
|
242
132
|
}
|
|
133
|
+
async simulate(input, artifactName, proofLength, convertInput, convertOutput) {
|
|
134
|
+
const timer = new Timer();
|
|
135
|
+
const witnessMap = convertInput(input);
|
|
136
|
+
const circuitName = mapProtocolArtifactNameToCircuitName(artifactName);
|
|
137
|
+
const simulationProvider = this.simulationProvider ?? this.wasmSimulator;
|
|
138
|
+
const witness = await simulationProvider.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts[artifactName]);
|
|
139
|
+
const result = convertOutput(witness);
|
|
140
|
+
this.instrumentation.recordDuration('simulationDuration', circuitName, timer);
|
|
141
|
+
emitCircuitSimulationStats(circuitName, timer.ms(), input.toBuffer().length, result.toBuffer().length, this.logger);
|
|
142
|
+
await this.delay();
|
|
143
|
+
return makePublicInputsAndRecursiveProof(result, makeRecursiveProof(proofLength), ProtocolCircuitVks[artifactName]);
|
|
144
|
+
}
|
|
243
145
|
},
|
|
244
146
|
(() => {
|
|
245
147
|
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
|
|
246
148
|
_getBaseParityProof_decorators = [trackSpan('TestCircuitProver.getBaseParityProof')];
|
|
247
149
|
_getRootParityProof_decorators = [trackSpan('TestCircuitProver.getRootParityProof')];
|
|
248
|
-
|
|
150
|
+
_getPrivateBaseRollupProof_decorators = [trackSpan('TestCircuitProver.getPrivateBaseRollupProof')];
|
|
151
|
+
_getPublicBaseRollupProof_decorators = [trackSpan('TestCircuitProver.getPublicBaseRollupProof')];
|
|
249
152
|
_getMergeRollupProof_decorators = [trackSpan('TestCircuitProver.getMergeRollupProof')];
|
|
250
153
|
_getBlockRootRollupProof_decorators = [trackSpan('TestCircuitProver.getBlockRootRollupProof')];
|
|
251
154
|
_getEmptyBlockRootRollupProof_decorators = [trackSpan('TestCircuitProver.getEmptyBlockRootRollupProof')];
|
|
252
155
|
_getBlockMergeRollupProof_decorators = [trackSpan('TestCircuitProver.getBlockMergeRollupProof')];
|
|
253
156
|
_getRootRollupProof_decorators = [trackSpan('TestCircuitProver.getRootRollupProof')];
|
|
254
|
-
_getPublicKernelInnerProof_decorators = [trackSpan('TestCircuitProver.getPublicKernelInnerProof')];
|
|
255
|
-
_getPublicKernelMergeProof_decorators = [trackSpan('TestCircuitProver.getPublicKernelMergeProof')];
|
|
256
|
-
_getPublicTailProof_decorators = [trackSpan('TestCircuitProver.getPublicTailProof')];
|
|
257
157
|
__esDecorate(_a, null, _getBaseParityProof_decorators, { kind: "method", name: "getBaseParityProof", static: false, private: false, access: { has: obj => "getBaseParityProof" in obj, get: obj => obj.getBaseParityProof }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
258
158
|
__esDecorate(_a, null, _getRootParityProof_decorators, { kind: "method", name: "getRootParityProof", static: false, private: false, access: { has: obj => "getRootParityProof" in obj, get: obj => obj.getRootParityProof }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
259
|
-
__esDecorate(_a, null,
|
|
159
|
+
__esDecorate(_a, null, _getPrivateBaseRollupProof_decorators, { kind: "method", name: "getPrivateBaseRollupProof", static: false, private: false, access: { has: obj => "getPrivateBaseRollupProof" in obj, get: obj => obj.getPrivateBaseRollupProof }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
160
|
+
__esDecorate(_a, null, _getPublicBaseRollupProof_decorators, { kind: "method", name: "getPublicBaseRollupProof", static: false, private: false, access: { has: obj => "getPublicBaseRollupProof" in obj, get: obj => obj.getPublicBaseRollupProof }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
260
161
|
__esDecorate(_a, null, _getMergeRollupProof_decorators, { kind: "method", name: "getMergeRollupProof", static: false, private: false, access: { has: obj => "getMergeRollupProof" in obj, get: obj => obj.getMergeRollupProof }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
261
162
|
__esDecorate(_a, null, _getBlockRootRollupProof_decorators, { kind: "method", name: "getBlockRootRollupProof", static: false, private: false, access: { has: obj => "getBlockRootRollupProof" in obj, get: obj => obj.getBlockRootRollupProof }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
262
163
|
__esDecorate(_a, null, _getEmptyBlockRootRollupProof_decorators, { kind: "method", name: "getEmptyBlockRootRollupProof", static: false, private: false, access: { has: obj => "getEmptyBlockRootRollupProof" in obj, get: obj => obj.getEmptyBlockRootRollupProof }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
263
164
|
__esDecorate(_a, null, _getBlockMergeRollupProof_decorators, { kind: "method", name: "getBlockMergeRollupProof", static: false, private: false, access: { has: obj => "getBlockMergeRollupProof" in obj, get: obj => obj.getBlockMergeRollupProof }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
264
165
|
__esDecorate(_a, null, _getRootRollupProof_decorators, { kind: "method", name: "getRootRollupProof", static: false, private: false, access: { has: obj => "getRootRollupProof" in obj, get: obj => obj.getRootRollupProof }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
265
|
-
__esDecorate(_a, null, _getPublicKernelInnerProof_decorators, { kind: "method", name: "getPublicKernelInnerProof", static: false, private: false, access: { has: obj => "getPublicKernelInnerProof" in obj, get: obj => obj.getPublicKernelInnerProof }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
266
|
-
__esDecorate(_a, null, _getPublicKernelMergeProof_decorators, { kind: "method", name: "getPublicKernelMergeProof", static: false, private: false, access: { has: obj => "getPublicKernelMergeProof" in obj, get: obj => obj.getPublicKernelMergeProof }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
267
|
-
__esDecorate(_a, null, _getPublicTailProof_decorators, { kind: "method", name: "getPublicTailProof", static: false, private: false, access: { has: obj => "getPublicTailProof" in obj, get: obj => obj.getPublicTailProof }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
268
166
|
if (_metadata) Object.defineProperty(_a, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
269
167
|
})(),
|
|
270
168
|
_a;
|
|
271
169
|
})();
|
|
272
170
|
export { TestCircuitProver };
|
|
273
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test_circuit_prover.js","sourceRoot":"","sources":["../../src/test/test_circuit_prover.ts"],"names":[],"mappings":"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"}
|
|
171
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test_circuit_prover.js","sourceRoot":"","sources":["../../src/test/test_circuit_prover.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,9 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/bb-prover",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.62.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"exports": {
|
|
6
|
-
".": "./dest/index.js"
|
|
6
|
+
".": "./dest/index.js",
|
|
7
|
+
"./prover": "./dest/prover/index.js",
|
|
8
|
+
"./verifier": "./dest/verifier/index.js",
|
|
9
|
+
"./test": "./dest/test/index.js"
|
|
7
10
|
},
|
|
8
11
|
"bin": {
|
|
9
12
|
"bb-cli": "./dest/bb/index.js"
|
|
@@ -62,12 +65,12 @@
|
|
|
62
65
|
]
|
|
63
66
|
},
|
|
64
67
|
"dependencies": {
|
|
65
|
-
"@aztec/circuit-types": "0.
|
|
66
|
-
"@aztec/circuits.js": "0.
|
|
67
|
-
"@aztec/foundation": "0.
|
|
68
|
-
"@aztec/noir-protocol-circuits-types": "0.
|
|
69
|
-
"@aztec/simulator": "0.
|
|
70
|
-
"@aztec/telemetry-client": "0.
|
|
68
|
+
"@aztec/circuit-types": "0.62.0",
|
|
69
|
+
"@aztec/circuits.js": "0.62.0",
|
|
70
|
+
"@aztec/foundation": "0.62.0",
|
|
71
|
+
"@aztec/noir-protocol-circuits-types": "0.62.0",
|
|
72
|
+
"@aztec/simulator": "0.62.0",
|
|
73
|
+
"@aztec/telemetry-client": "0.62.0",
|
|
71
74
|
"@msgpack/msgpack": "^3.0.0-beta2",
|
|
72
75
|
"@noir-lang/noirc_abi": "portal:../../noir/packages/noirc_abi",
|
|
73
76
|
"@noir-lang/types": "portal:../../noir/packages/types",
|
package/src/bb/cli.ts
CHANGED
package/src/bb/execute.ts
CHANGED
|
@@ -151,6 +151,7 @@ export async function generateKeyForNoirCircuit(
|
|
|
151
151
|
const args = ['-o', `${outputPath}/${VK_FILENAME}`, '-b', bytecodePath];
|
|
152
152
|
const timer = new Timer();
|
|
153
153
|
let result = await executeBB(pathToBB, `write_vk_${flavor}`, args, log);
|
|
154
|
+
|
|
154
155
|
// If we succeeded and the type of key if verification, have bb write the 'fields' version too
|
|
155
156
|
if (result.status == BB_RESULT.SUCCESS) {
|
|
156
157
|
const asFieldsArgs = ['-k', `${outputPath}/${VK_FILENAME}`, '-o', `${outputPath}/${VK_FIELDS_FILENAME}`, '-v'];
|
|
@@ -504,7 +505,6 @@ export async function generateAvmProof(
|
|
|
504
505
|
}
|
|
505
506
|
|
|
506
507
|
// Paths for the inputs
|
|
507
|
-
const bytecodePath = join(workingDirectory, AVM_BYTECODE_FILENAME);
|
|
508
508
|
const calldataPath = join(workingDirectory, AVM_CALLDATA_FILENAME);
|
|
509
509
|
const publicInputsPath = join(workingDirectory, AVM_PUBLIC_INPUTS_FILENAME);
|
|
510
510
|
const avmHintsPath = join(workingDirectory, AVM_HINTS_FILENAME);
|
|
@@ -525,10 +525,6 @@ export async function generateAvmProof(
|
|
|
525
525
|
|
|
526
526
|
try {
|
|
527
527
|
// Write the inputs to the working directory.
|
|
528
|
-
await fs.writeFile(bytecodePath, input.bytecode);
|
|
529
|
-
if (!filePresent(bytecodePath)) {
|
|
530
|
-
return { status: BB_RESULT.FAILURE, reason: `Could not write bytecode at ${bytecodePath}` };
|
|
531
|
-
}
|
|
532
528
|
await fs.writeFile(
|
|
533
529
|
calldataPath,
|
|
534
530
|
input.calldata.map(fr => fr.toBuffer()),
|
|
@@ -553,8 +549,6 @@ export async function generateAvmProof(
|
|
|
553
549
|
}
|
|
554
550
|
|
|
555
551
|
const args = [
|
|
556
|
-
'--avm-bytecode',
|
|
557
|
-
bytecodePath,
|
|
558
552
|
'--avm-calldata',
|
|
559
553
|
calldataPath,
|
|
560
554
|
'--avm-public-inputs',
|