57 auto goblin_proof = goblin.
prove();
61 auto ultra_ops_table_columns = goblin.
op_queue->construct_ultra_ops_table_columns();
64 table_commitments[idx] = pcs_commitment_key.
commit(ultra_ops_table_columns[idx]);
69 recursive_table_commitments[idx] = RecursiveCommitment::from_witness(outer_builder, table_commitments[idx]);
72 recursive_table_commitments[idx].unset_free_witness_tag();
76 return { goblin_proof, table_commitments, recursive_table_commitments };
88 auto [proof, table_commitments, recursive_table_commitments] = create_goblin_avm_prover_output(&
builder);
93 auto output = verifier.reduce_to_pairing_check_and_ipa_opening();
96 inputs.pairing_inputs = output.translator_pairing_points;
97 inputs.ipa_claim = output.ipa_claim;
100 builder.ipa_proof = output.ipa_proof.get_value();
105 auto verification_key =
108 OuterProver prover(prover_instance, verification_key);
109 OuterVerifier verifier(vk_and_hash);
110 auto proof = prover.construct_proof();
111 bool verified = verifier.verify_proof(proof).result;
113 ASSERT_TRUE(verified);
116 auto translator_pairing_points = output.translator_pairing_points;
124 translator_pairing_points.P0.fix_witness();
125 translator_pairing_points.P1.fix_witness();
126 info(
"Recursive Verifier: num gates = ",
builder.num_gates());
128 auto variables_in_one_gate = graph.get_variables_in_one_gate();
132 EXPECT_EQ(variables_in_one_gate.size(), 4);
Common transcript class for both parties. Stores the data for the current round, as well as the manif...
CommitmentKey object over a pairing group 𝔾₁.
Commitment commit(PolynomialSpan< const Fr > polynomial) const
Uses the ProverSRS to create a commitment to p(X)
Simple verification key class for fixed-size circuits (ECCVM, Translator).
Specialization of Goblin for the AVM.
GoblinAvmProof prove()
Constuct a full GoblinAvm proof (ECCVM, Translator)
TranslatorFlavor::VerificationKey TranslatorVerificationKey
ECCVMFlavor::VerificationKey ECCVMVerificationKey
Curve::AffineElement Commitment
std::array< Commitment, UltraCircuitBuilder::NUM_WIRES > TableCommitments
std::shared_ptr< OpQueue > op_queue
static constexpr size_t NUM_WIRES
static void construct_arithmetic_circuit(Builder &builder, const size_t target_log2_dyadic_size=4, bool include_public_inputs=true)
Populate a builder with a specified number of arithmetic gates; includes a PI.
A ProverInstance is normally constructed from a finalized circuit and it contains all the information...
Curve::AffineElement Commitment
UltraCircuitBuilder CircuitBuilder
UltraRollupFlavor extends UltraFlavor with IPA proof support.
bb::GoblinAvmRecursiveVerifier::Commitment RecursiveCommitment
UltraRollupFlavor::Commitment Commitment
std::array< Commitment, UltraCircuitBuilder::NUM_WIRES > TableCommitments
bb::GoblinAvmRecursiveVerifier::TableCommitments RecursiveTableCommitments
static void SetUpTestSuite()
static ProverOutput create_goblin_avm_prover_output(OuterBuilder *outer_builder)
Create a goblin proof needed by the goblin recursive verifier.
The data that is propagated on the public inputs of a rollup circuit.
std::filesystem::path bb_crs_path()
void init_file_crs_factory(const std::filesystem::path &path)
TEST_F(BoomerangGoblinRecursiveVerifierTests, graph_description_basic)
Construct and check a goblin recursive verification circuit.
BaseTranscript< stdlib::StdlibCodec< stdlib::field_t< UltraCircuitBuilder > >, stdlib::poseidon2< UltraCircuitBuilder > > UltraStdlibTranscript
MegaCircuitBuilder_< field< Bn254FrParams > > MegaCircuitBuilder
UltraStaticAnalyzer StaticAnalyzer
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
RecursiveTableCommitments recursive_table_commitments
TableCommitments table_commitments