@aztec/bb-prover 0.55.0 → 0.56.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.
@@ -4,12 +4,11 @@ import { AvmVerificationKeyData, EmptyNestedData, NESTED_RECURSIVE_PROOF_LENGTH,
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, convertMergeRollupInputsToWitnessMap, convertMergeRollupOutputsFromWitnessMap, convertPrivateKernelEmptyInputsToWitnessMap, convertPrivateKernelEmptyOutputsFromWitnessMap, convertRootParityInputsToWitnessMap, convertRootParityOutputsFromWitnessMap, convertRootRollupInputsToWitnessMap, convertRootRollupOutputsFromWitnessMap, convertSimulatedBaseRollupInputsToWitnessMap, convertSimulatedBaseRollupOutputsFromWitnessMap, convertSimulatedPrivateKernelEmptyOutputsFromWitnessMap, convertSimulatedPublicTailInputsToWitnessMap, convertSimulatedPublicTailOutputFromWitnessMap, getVKSiblingPath, } from '@aztec/noir-protocol-circuits-types';
7
+ import { ProtocolCircuitVkIndexes, ProtocolCircuitVks, SimulatedServerCircuitArtifacts, convertBaseParityInputsToWitnessMap, convertBaseParityOutputsFromWitnessMap, convertBlockMergeRollupInputsToWitnessMap, convertBlockMergeRollupOutputsFromWitnessMap, convertBlockRootRollupInputsToWitnessMap, convertBlockRootRollupOutputsFromWitnessMap, convertMergeRollupInputsToWitnessMap, convertMergeRollupOutputsFromWitnessMap, convertPrivateKernelEmptyInputsToWitnessMap, convertPrivateKernelEmptyOutputsFromWitnessMap, convertRootParityInputsToWitnessMap, convertRootParityOutputsFromWitnessMap, convertRootRollupInputsToWitnessMap, convertRootRollupOutputsFromWitnessMap, convertSimulatedBaseRollupInputsToWitnessMap, convertSimulatedBaseRollupOutputsFromWitnessMap, convertSimulatedPrivateKernelEmptyOutputsFromWitnessMap, convertSimulatedPublicInnerInputsToWitnessMap, convertSimulatedPublicInnerOutputFromWitnessMap, convertSimulatedPublicMergeInputsToWitnessMap, convertSimulatedPublicMergeOutputFromWitnessMap, convertSimulatedPublicTailInputsToWitnessMap, convertSimulatedPublicTailOutputFromWitnessMap, 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';
11
- import { SimulatedPublicKernelArtifactMapping } from '../mappings/mappings.js';
12
- import { mapPublicKernelToCircuitName } from '../stats.js';
11
+ import { mapProtocolArtifactNameToCircuitName } from '../stats.js';
13
12
  /**
14
13
  * A class for use in testing situations (e2e, unit test, etc) and temporarily for assembling a block in the sequencer.
15
14
  * Simulates circuits using the most efficient method and performs no proving.
@@ -24,7 +23,8 @@ let TestCircuitProver = (() => {
24
23
  let _getBlockRootRollupProof_decorators;
25
24
  let _getBlockMergeRollupProof_decorators;
26
25
  let _getRootRollupProof_decorators;
27
- let _getPublicKernelProof_decorators;
26
+ let _getPublicKernelInnerProof_decorators;
27
+ let _getPublicKernelMergeProof_decorators;
28
28
  let _getPublicTailProof_decorators;
29
29
  return _a = class TestCircuitProver {
30
30
  constructor(telemetry, simulationProvider, opts = { proverTestDelayMs: 0 }) {
@@ -143,6 +143,9 @@ let TestCircuitProver = (() => {
143
143
  emitCircuitSimulationStats('block-root-rollup', timer.ms(), input.toBuffer().length, result.toBuffer().length, this.logger);
144
144
  return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['BlockRootRollupArtifact']);
145
145
  }
146
+ getBlockRootRollupFinalProof(input) {
147
+ return this.getBlockRootRollupProof(input);
148
+ }
146
149
  /**
147
150
  * Simulates the block merge rollup circuit from its inputs.
148
151
  * @param input - Inputs to the circuit.
@@ -174,31 +177,42 @@ let TestCircuitProver = (() => {
174
177
  await this.delay();
175
178
  return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['RootRollupArtifact']);
176
179
  }
177
- async getPublicKernelProof(kernelRequest) {
180
+ async getPublicKernelInnerProof(inputs) {
178
181
  const timer = new Timer();
179
- const kernelOps = SimulatedPublicKernelArtifactMapping[kernelRequest.type];
180
- if (kernelOps === undefined) {
181
- throw new Error(`Unable to prove for kernel type ${kernelRequest.type}`);
182
- }
183
- const witnessMap = kernelOps.convertInputs(kernelRequest.inputs);
184
- const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts[kernelOps.artifact]);
185
- const result = kernelOps.convertOutputs(witness);
186
- const circuitName = mapPublicKernelToCircuitName(kernelRequest.type);
182
+ const artifact = 'PublicKernelInnerArtifact';
183
+ const circuitName = mapProtocolArtifactNameToCircuitName(artifact);
184
+ const witnessMap = convertSimulatedPublicInnerInputsToWitnessMap(inputs);
185
+ const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts[artifact]);
186
+ const result = convertSimulatedPublicInnerOutputFromWitnessMap(witness);
187
187
  this.instrumentation.recordDuration('simulationDuration', circuitName, timer);
188
- emitCircuitSimulationStats(circuitName, timer.ms(), kernelRequest.inputs.toBuffer().length, result.toBuffer().length, this.logger);
188
+ emitCircuitSimulationStats(circuitName, timer.ms(), inputs.toBuffer().length, result.toBuffer().length, this.logger);
189
189
  await this.delay();
190
- return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks[kernelOps.artifact]);
190
+ return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks[artifact]);
191
191
  }
192
- async getPublicTailProof(kernelRequest) {
192
+ async getPublicKernelMergeProof(inputs) {
193
193
  const timer = new Timer();
194
- const witnessMap = convertSimulatedPublicTailInputsToWitnessMap(kernelRequest.inputs);
194
+ const artifact = 'PublicKernelMergeArtifact';
195
+ const circuitName = mapProtocolArtifactNameToCircuitName(artifact);
196
+ const witnessMap = convertSimulatedPublicMergeInputsToWitnessMap(inputs);
197
+ const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts[artifact]);
198
+ const result = convertSimulatedPublicMergeOutputFromWitnessMap(witness);
199
+ this.instrumentation.recordDuration('simulationDuration', circuitName, timer);
200
+ emitCircuitSimulationStats(circuitName, timer.ms(), inputs.toBuffer().length, result.toBuffer().length, this.logger);
201
+ await this.delay();
202
+ return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks[artifact]);
203
+ }
204
+ async getPublicTailProof(inputs) {
205
+ const timer = new Timer();
206
+ const artifact = 'PublicKernelTailArtifact';
207
+ const circuitName = mapProtocolArtifactNameToCircuitName(artifact);
208
+ const witnessMap = convertSimulatedPublicTailInputsToWitnessMap(inputs);
195
209
  // use WASM here as it is faster for small circuits
196
- const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts['PublicKernelTailArtifact']);
210
+ const witness = await this.wasmSimulator.simulateCircuit(witnessMap, SimulatedServerCircuitArtifacts[artifact]);
197
211
  const result = convertSimulatedPublicTailOutputFromWitnessMap(witness);
198
- this.instrumentation.recordDuration('simulationDuration', 'public-kernel-tail', timer);
199
- emitCircuitSimulationStats('public-kernel-tail', timer.ms(), kernelRequest.inputs.toBuffer().length, result.toBuffer().length, this.logger);
212
+ this.instrumentation.recordDuration('simulationDuration', circuitName, timer);
213
+ emitCircuitSimulationStats(circuitName, timer.ms(), inputs.toBuffer().length, result.toBuffer().length, this.logger);
200
214
  await this.delay();
201
- return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks['PublicKernelTailArtifact']);
215
+ return makePublicInputsAndRecursiveProof(result, makeEmptyRecursiveProof(NESTED_RECURSIVE_PROOF_LENGTH), ProtocolCircuitVks[artifact]);
202
216
  }
203
217
  async getAvmProof(_inputs) {
204
218
  // We can't simulate the AVM because we don't have enough context to do so (e.g., DBs).
@@ -226,7 +240,8 @@ let TestCircuitProver = (() => {
226
240
  _getBlockRootRollupProof_decorators = [trackSpan('TestCircuitProver.getBlockRootRollupProof')];
227
241
  _getBlockMergeRollupProof_decorators = [trackSpan('TestCircuitProver.getBlockMergeRollupProof')];
228
242
  _getRootRollupProof_decorators = [trackSpan('TestCircuitProver.getRootRollupProof')];
229
- _getPublicKernelProof_decorators = [trackSpan('TestCircuitProver.getPublicKernelProof')];
243
+ _getPublicKernelInnerProof_decorators = [trackSpan('TestCircuitProver.getPublicKernelInnerProof')];
244
+ _getPublicKernelMergeProof_decorators = [trackSpan('TestCircuitProver.getPublicKernelMergeProof')];
230
245
  _getPublicTailProof_decorators = [trackSpan('TestCircuitProver.getPublicTailProof')];
231
246
  __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);
232
247
  __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);
@@ -235,11 +250,12 @@ let TestCircuitProver = (() => {
235
250
  __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);
236
251
  __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);
237
252
  __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);
238
- __esDecorate(_a, null, _getPublicKernelProof_decorators, { kind: "method", name: "getPublicKernelProof", static: false, private: false, access: { has: obj => "getPublicKernelProof" in obj, get: obj => obj.getPublicKernelProof }, metadata: _metadata }, null, _instanceExtraInitializers);
253
+ __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);
254
+ __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);
239
255
  __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);
240
256
  if (_metadata) Object.defineProperty(_a, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
241
257
  })(),
242
258
  _a;
243
259
  })();
244
260
  export { TestCircuitProver };
245
- //# 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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"}
261
+ //# 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,6 +1,6 @@
1
1
  {
2
2
  "name": "@aztec/bb-prover",
3
- "version": "0.55.0",
3
+ "version": "0.56.0",
4
4
  "type": "module",
5
5
  "exports": {
6
6
  ".": "./dest/index.js"
@@ -59,12 +59,12 @@
59
59
  ]
60
60
  },
61
61
  "dependencies": {
62
- "@aztec/circuit-types": "0.55.0",
63
- "@aztec/circuits.js": "0.55.0",
64
- "@aztec/foundation": "0.55.0",
65
- "@aztec/noir-protocol-circuits-types": "0.55.0",
66
- "@aztec/simulator": "0.55.0",
67
- "@aztec/telemetry-client": "0.55.0",
62
+ "@aztec/circuit-types": "0.56.0",
63
+ "@aztec/circuits.js": "0.56.0",
64
+ "@aztec/foundation": "0.56.0",
65
+ "@aztec/noir-protocol-circuits-types": "0.56.0",
66
+ "@aztec/simulator": "0.56.0",
67
+ "@aztec/telemetry-client": "0.56.0",
68
68
  "@msgpack/msgpack": "^3.0.0-beta2",
69
69
  "@noir-lang/noirc_abi": "portal:../../noir/packages/noirc_abi",
70
70
  "@noir-lang/types": "portal:../../noir/packages/types",
@@ -74,6 +74,7 @@
74
74
  },
75
75
  "devDependencies": {
76
76
  "@aztec/ethereum": "workspace:^",
77
+ "@aztec/types": "workspace:^",
77
78
  "@jest/globals": "^29.5.0",
78
79
  "@types/jest": "^29.5.0",
79
80
  "@types/memdown": "^3.0.0",
package/src/honk.ts CHANGED
@@ -2,7 +2,10 @@ import { type ProtocolArtifact } from '@aztec/noir-protocol-circuits-types';
2
2
 
3
3
  export type UltraHonkFlavor = 'ultra_honk' | 'ultra_keccak_honk';
4
4
 
5
- const UltraKeccakHonkCircuits = ['BlockRootRollupArtifact'] as const;
5
+ const UltraKeccakHonkCircuits = [
6
+ 'BlockRootRollupFinalArtifact',
7
+ 'RootRollupArtifact',
8
+ ] as const satisfies ProtocolArtifact[];
6
9
  type UltraKeccakHonkCircuits = (typeof UltraKeccakHonkCircuits)[number];
7
10
  type UltraHonkCircuits = Exclude<ProtocolArtifact, UltraKeccakHonkCircuits>;
8
11
 
package/src/index.ts CHANGED
@@ -3,3 +3,5 @@ export * from './test/index.js';
3
3
  export * from './verifier/index.js';
4
4
  export * from './config.js';
5
5
  export * from './bb/execute.js';
6
+
7
+ export { type ClientProtocolCircuitVerifier } from '@aztec/circuit-types';
@@ -2,8 +2,6 @@
2
2
  import {
3
3
  type AvmProofAndVerificationKey,
4
4
  type PublicInputsAndRecursiveProof,
5
- type PublicKernelNonTailRequest,
6
- type PublicKernelTailRequest,
7
5
  type ServerCircuitProver,
8
6
  makePublicInputsAndRecursiveProof,
9
7
  } from '@aztec/circuit-types';
@@ -27,7 +25,10 @@ import {
27
25
  type PrivateKernelEmptyInputData,
28
26
  PrivateKernelEmptyInputs,
29
27
  Proof,
28
+ type PublicKernelCircuitPrivateInputs,
30
29
  type PublicKernelCircuitPublicInputs,
30
+ type PublicKernelInnerCircuitPrivateInputs,
31
+ type PublicKernelTailCircuitPrivateInputs,
31
32
  RECURSIVE_PROOF_LENGTH,
32
33
  RecursiveProof,
33
34
  RootParityInput,
@@ -36,6 +37,7 @@ import {
36
37
  type RootRollupPublicInputs,
37
38
  TUBE_PROOF_LENGTH,
38
39
  type TubeInputs,
40
+ type VMCircuitPublicInputs,
39
41
  type VerificationKeyAsFields,
40
42
  type VerificationKeyData,
41
43
  makeRecursiveProofFromBinary,
@@ -59,6 +61,10 @@ import {
59
61
  convertMergeRollupOutputsFromWitnessMap,
60
62
  convertPrivateKernelEmptyInputsToWitnessMap,
61
63
  convertPrivateKernelEmptyOutputsFromWitnessMap,
64
+ convertPublicInnerInputsToWitnessMap,
65
+ convertPublicInnerOutputFromWitnessMap,
66
+ convertPublicMergeInputsToWitnessMap,
67
+ convertPublicMergeOutputFromWitnessMap,
62
68
  convertPublicTailInputsToWitnessMap,
63
69
  convertPublicTailOutputFromWitnessMap,
64
70
  convertRootParityInputsToWitnessMap,
@@ -94,7 +100,6 @@ import {
94
100
  import type { ACVMConfig, BBConfig } from '../config.js';
95
101
  import { type UltraHonkFlavor, getUltraHonkFlavorForCircuit } from '../honk.js';
96
102
  import { ProverInstrumentation } from '../instrumentation.js';
97
- import { PublicKernelArtifactMapping } from '../mappings/mappings.js';
98
103
  import { mapProtocolArtifactNameToCircuitName } from '../stats.js';
99
104
  import { extractAvmVkData, extractVkData } from '../verification_key/verification_key_data.js';
100
105
 
@@ -206,47 +211,70 @@ export class BBNativeRollupProver implements ServerCircuitProver {
206
211
  }
207
212
 
208
213
  /**
209
- * Requests that a public kernel circuit be executed and the proof generated
214
+ * Requests that a public kernel inner circuit be executed and the proof generated
210
215
  * @param kernelRequest - The object encapsulating the request for a proof
211
216
  * @returns The requested circuit's public inputs and proof
212
217
  */
213
- @trackSpan('BBNativeRollupProver.getPublicKernelProof', kernelReq => ({
214
- [Attributes.PROTOCOL_CIRCUIT_NAME]: mapProtocolArtifactNameToCircuitName(
215
- PublicKernelArtifactMapping[kernelReq.type]!.artifact,
216
- ),
217
- }))
218
- public async getPublicKernelProof(
219
- kernelRequest: PublicKernelNonTailRequest,
218
+ @trackSpan('BBNativeRollupProver.getPublicKernelInnerProof', {
219
+ [Attributes.PROTOCOL_CIRCUIT_NAME]: 'public-kernel-inner',
220
+ })
221
+ public async getPublicKernelInnerProof(
222
+ inputs: PublicKernelInnerCircuitPrivateInputs,
223
+ ): Promise<PublicInputsAndRecursiveProof<VMCircuitPublicInputs>> {
224
+ const artifact = 'PublicKernelInnerArtifact';
225
+
226
+ const { circuitOutput, proof } = await this.createRecursiveProof(
227
+ inputs,
228
+ artifact,
229
+ NESTED_RECURSIVE_PROOF_LENGTH,
230
+ convertPublicInnerInputsToWitnessMap,
231
+ convertPublicInnerOutputFromWitnessMap,
232
+ );
233
+
234
+ const verificationKey = await this.getVerificationKeyDataForCircuit(artifact);
235
+
236
+ await this.verifyProof(artifact, proof.binaryProof);
237
+
238
+ return makePublicInputsAndRecursiveProof(circuitOutput, proof, verificationKey);
239
+ }
240
+
241
+ /**
242
+ * Requests that a public kernel merge circuit be executed and the proof generated
243
+ * @param kernelRequest - The object encapsulating the request for a proof
244
+ * @returns The requested circuit's public inputs and proof
245
+ */
246
+ @trackSpan('BBNativeRollupProver.getPublicKernelMergeProof', {
247
+ [Attributes.PROTOCOL_CIRCUIT_NAME]: 'public-kernel-merge',
248
+ })
249
+ public async getPublicKernelMergeProof(
250
+ inputs: PublicKernelCircuitPrivateInputs,
220
251
  ): Promise<PublicInputsAndRecursiveProof<PublicKernelCircuitPublicInputs>> {
221
- const kernelOps = PublicKernelArtifactMapping[kernelRequest.type];
222
- if (kernelOps === undefined) {
223
- throw new Error(`Unable to prove kernel type ${kernelRequest.type}`);
224
- }
252
+ const artifact = 'PublicKernelMergeArtifact';
225
253
 
226
254
  // We may need to convert the recursive proof into fields format
227
- kernelRequest.inputs.previousKernel.proof = await this.ensureValidProof(
228
- kernelRequest.inputs.previousKernel.proof,
229
- kernelOps.artifact,
230
- kernelRequest.inputs.previousKernel.vk,
255
+ inputs.previousKernel.proof = await this.ensureValidProof(
256
+ inputs.previousKernel.proof,
257
+ artifact,
258
+ inputs.previousKernel.vk,
231
259
  );
232
260
 
233
261
  await this.verifyWithKey(
234
- getUltraHonkFlavorForCircuit(kernelOps.artifact),
235
- kernelRequest.inputs.previousKernel.vk,
236
- kernelRequest.inputs.previousKernel.proof.binaryProof,
262
+ getUltraHonkFlavorForCircuit(artifact),
263
+ inputs.previousKernel.vk,
264
+ inputs.previousKernel.proof.binaryProof,
237
265
  );
238
266
 
239
267
  const { circuitOutput, proof } = await this.createRecursiveProof(
240
- kernelRequest.inputs,
241
- kernelOps.artifact,
268
+ inputs,
269
+ artifact,
242
270
  NESTED_RECURSIVE_PROOF_LENGTH,
243
- kernelOps.convertInputs,
244
- kernelOps.convertOutputs,
271
+ convertPublicMergeInputsToWitnessMap,
272
+ convertPublicMergeOutputFromWitnessMap,
245
273
  );
246
274
 
247
- const verificationKey = await this.getVerificationKeyDataForCircuit(kernelOps.artifact);
275
+ const verificationKey = await this.getVerificationKeyDataForCircuit(artifact);
248
276
 
249
- await this.verifyProof(kernelOps.artifact, proof.binaryProof);
277
+ await this.verifyProof(artifact, proof.binaryProof);
250
278
 
251
279
  return makePublicInputsAndRecursiveProof(circuitOutput, proof, verificationKey);
252
280
  }
@@ -257,10 +285,10 @@ export class BBNativeRollupProver implements ServerCircuitProver {
257
285
  * @returns The requested circuit's public inputs and proof
258
286
  */
259
287
  public async getPublicTailProof(
260
- kernelRequest: PublicKernelTailRequest,
288
+ inputs: PublicKernelTailCircuitPrivateInputs,
261
289
  ): Promise<PublicInputsAndRecursiveProof<KernelCircuitPublicInputs>> {
262
290
  const { circuitOutput, proof } = await this.createRecursiveProof(
263
- kernelRequest.inputs,
291
+ inputs,
264
292
  'PublicKernelTailArtifact',
265
293
  NESTED_RECURSIVE_PROOF_LENGTH,
266
294
  convertPublicTailInputsToWitnessMap,
@@ -337,20 +365,43 @@ export class BBNativeRollupProver implements ServerCircuitProver {
337
365
  public async getBlockRootRollupProof(
338
366
  input: BlockRootRollupInputs,
339
367
  ): Promise<PublicInputsAndRecursiveProof<BlockRootOrBlockMergePublicInputs>> {
340
- // TODO(#7346): When batch rollups are integrated, we probably want the below to be this.createRecursiveProof
341
- // since we will no longer be verifying it directly on L1
342
- const { circuitOutput, proof } = await this.createProof(
368
+ const { circuitOutput, proof } = await this.createRecursiveProof(
343
369
  input,
344
370
  'BlockRootRollupArtifact',
371
+ NESTED_RECURSIVE_PROOF_LENGTH,
372
+ convertBlockRootRollupInputsToWitnessMap,
373
+ convertBlockRootRollupOutputsFromWitnessMap,
374
+ );
375
+
376
+ const verificationKey = await this.getVerificationKeyDataForCircuit('BlockRootRollupArtifact');
377
+
378
+ await this.verifyProof('BlockRootRollupArtifact', proof.binaryProof);
379
+
380
+ return makePublicInputsAndRecursiveProof(circuitOutput, proof, verificationKey);
381
+ }
382
+
383
+ /**
384
+ * Simulates the block root rollup circuit from its inputs.
385
+ * Returns a non-recursive proof to verify on L1.
386
+ * @dev TODO(palla/prover): This is a temporary workaround to get the proof to L1 with the old block flow.
387
+ * @param input - Inputs to the circuit.
388
+ * @returns The public inputs as outputs of the simulation.
389
+ */
390
+ public async getBlockRootRollupFinalProof(
391
+ input: BlockRootRollupInputs,
392
+ ): Promise<PublicInputsAndRecursiveProof<BlockRootOrBlockMergePublicInputs>> {
393
+ const { circuitOutput, proof } = await this.createProof(
394
+ input,
395
+ 'BlockRootRollupFinalArtifact',
345
396
  convertBlockRootRollupInputsToWitnessMap,
346
397
  convertBlockRootRollupOutputsFromWitnessMap,
347
398
  );
348
399
 
349
400
  const recursiveProof = makeRecursiveProofFromBinary(proof, NESTED_RECURSIVE_PROOF_LENGTH);
350
401
 
351
- const verificationKey = await this.getVerificationKeyDataForCircuit('BlockRootRollupArtifact');
402
+ const verificationKey = await this.getVerificationKeyDataForCircuit('BlockRootRollupFinalArtifact');
352
403
 
353
- await this.verifyProof('BlockRootRollupArtifact', proof);
404
+ await this.verifyProof('BlockRootRollupFinalArtifact', proof);
354
405
 
355
406
  return makePublicInputsAndRecursiveProof(circuitOutput, recursiveProof, verificationKey);
356
407
  }
package/src/stats.ts CHANGED
@@ -1,8 +1,6 @@
1
1
  import type { CircuitName } from '@aztec/circuit-types/stats';
2
2
  import { type ClientProtocolArtifact, type ServerProtocolArtifact } from '@aztec/noir-protocol-circuits-types';
3
3
 
4
- export { mapPublicKernelToCircuitName } from '@aztec/circuit-types';
5
-
6
4
  export function mapProtocolArtifactNameToCircuitName(
7
5
  artifact: ServerProtocolArtifact | ClientProtocolArtifact,
8
6
  ): CircuitName {
@@ -21,12 +19,10 @@ export function mapProtocolArtifactNameToCircuitName(
21
19
  return 'block-merge-rollup';
22
20
  case 'RootRollupArtifact':
23
21
  return 'root-rollup';
24
- case 'PublicKernelSetupArtifact':
25
- return 'public-kernel-setup';
26
- case 'PublicKernelAppLogicArtifact':
27
- return 'public-kernel-app-logic';
28
- case 'PublicKernelTeardownArtifact':
29
- return 'public-kernel-teardown';
22
+ case 'PublicKernelInnerArtifact':
23
+ return 'public-kernel-inner';
24
+ case 'PublicKernelMergeArtifact':
25
+ return 'public-kernel-merge';
30
26
  case 'PublicKernelTailArtifact':
31
27
  return 'public-kernel-tail';
32
28
  case 'PrivateKernelInitArtifact':
@@ -53,6 +49,8 @@ export function mapProtocolArtifactNameToCircuitName(
53
49
  return 'empty-nested';
54
50
  case 'PrivateKernelEmptyArtifact':
55
51
  return 'private-kernel-empty';
52
+ case 'BlockRootRollupFinalArtifact':
53
+ return 'block-root-rollup-final';
56
54
  default: {
57
55
  const _foo: never = artifact;
58
56
  throw new Error(`Unknown circuit type: ${artifact}`);
package/src/test/index.ts CHANGED
@@ -1,2 +1,3 @@
1
1
  export * from './test_circuit_prover.js';
2
2
  export * from './test_verifier.js';
3
+ export * from './test_avm.js';
@@ -0,0 +1,85 @@
1
+ import {
2
+ AztecAddress,
3
+ ContractStorageRead,
4
+ ContractStorageUpdateRequest,
5
+ Gas,
6
+ GlobalVariables,
7
+ Header,
8
+ L2ToL1Message,
9
+ LogHash,
10
+ MAX_L1_TO_L2_MSG_READ_REQUESTS_PER_CALL,
11
+ MAX_L2_TO_L1_MSGS_PER_CALL,
12
+ MAX_NOTE_HASHES_PER_CALL,
13
+ MAX_NOTE_HASH_READ_REQUESTS_PER_CALL,
14
+ MAX_NULLIFIERS_PER_CALL,
15
+ MAX_NULLIFIER_NON_EXISTENT_READ_REQUESTS_PER_CALL,
16
+ MAX_NULLIFIER_READ_REQUESTS_PER_CALL,
17
+ MAX_PUBLIC_CALL_STACK_LENGTH_PER_CALL,
18
+ MAX_PUBLIC_DATA_READS_PER_CALL,
19
+ MAX_PUBLIC_DATA_UPDATE_REQUESTS_PER_CALL,
20
+ MAX_UNENCRYPTED_LOGS_PER_CALL,
21
+ NoteHash,
22
+ Nullifier,
23
+ PublicCircuitPublicInputs,
24
+ PublicInnerCallRequest,
25
+ ReadRequest,
26
+ RevertCode,
27
+ TreeLeafReadRequest,
28
+ } from '@aztec/circuits.js';
29
+ import { computeVarArgsHash } from '@aztec/circuits.js/hash';
30
+ import { padArrayEnd } from '@aztec/foundation/collection';
31
+ import { type PublicExecutionResult } from '@aztec/simulator';
32
+
33
+ // TODO: pub somewhere more usable - copied from abstract phase manager
34
+ export function getPublicInputs(result: PublicExecutionResult): PublicCircuitPublicInputs {
35
+ return PublicCircuitPublicInputs.from({
36
+ callContext: result.executionRequest.callContext,
37
+ proverAddress: AztecAddress.ZERO,
38
+ argsHash: computeVarArgsHash(result.executionRequest.args),
39
+ noteHashes: padArrayEnd(result.noteHashes, NoteHash.empty(), MAX_NOTE_HASHES_PER_CALL),
40
+ nullifiers: padArrayEnd(result.nullifiers, Nullifier.empty(), MAX_NULLIFIERS_PER_CALL),
41
+ l2ToL1Msgs: padArrayEnd(result.l2ToL1Messages, L2ToL1Message.empty(), MAX_L2_TO_L1_MSGS_PER_CALL),
42
+ startSideEffectCounter: result.startSideEffectCounter,
43
+ endSideEffectCounter: result.endSideEffectCounter,
44
+ returnsHash: computeVarArgsHash(result.returnValues),
45
+ noteHashReadRequests: padArrayEnd(
46
+ result.noteHashReadRequests,
47
+ TreeLeafReadRequest.empty(),
48
+ MAX_NOTE_HASH_READ_REQUESTS_PER_CALL,
49
+ ),
50
+ nullifierReadRequests: padArrayEnd(
51
+ result.nullifierReadRequests,
52
+ ReadRequest.empty(),
53
+ MAX_NULLIFIER_READ_REQUESTS_PER_CALL,
54
+ ),
55
+ nullifierNonExistentReadRequests: padArrayEnd(
56
+ result.nullifierNonExistentReadRequests,
57
+ ReadRequest.empty(),
58
+ MAX_NULLIFIER_NON_EXISTENT_READ_REQUESTS_PER_CALL,
59
+ ),
60
+ l1ToL2MsgReadRequests: padArrayEnd(
61
+ result.l1ToL2MsgReadRequests,
62
+ TreeLeafReadRequest.empty(),
63
+ MAX_L1_TO_L2_MSG_READ_REQUESTS_PER_CALL,
64
+ ),
65
+ contractStorageReads: padArrayEnd(
66
+ result.contractStorageReads,
67
+ ContractStorageRead.empty(),
68
+ MAX_PUBLIC_DATA_READS_PER_CALL,
69
+ ),
70
+ contractStorageUpdateRequests: padArrayEnd(
71
+ result.contractStorageUpdateRequests,
72
+ ContractStorageUpdateRequest.empty(),
73
+ MAX_PUBLIC_DATA_UPDATE_REQUESTS_PER_CALL,
74
+ ),
75
+ publicCallRequests: padArrayEnd([], PublicInnerCallRequest.empty(), MAX_PUBLIC_CALL_STACK_LENGTH_PER_CALL),
76
+ unencryptedLogsHashes: padArrayEnd(result.unencryptedLogsHashes, LogHash.empty(), MAX_UNENCRYPTED_LOGS_PER_CALL),
77
+ historicalHeader: Header.empty(),
78
+ globalVariables: GlobalVariables.empty(),
79
+ startGasLeft: Gas.from(result.startGasLeft),
80
+ endGasLeft: Gas.from(result.endGasLeft),
81
+ transactionFee: result.transactionFee,
82
+ // TODO(@just-mitch): need better mapping from simulator to revert code.
83
+ revertCode: result.reverted ? RevertCode.APP_LOGIC_REVERTED : RevertCode.OK,
84
+ });
85
+ }