19#include <gtest/gtest.h>
45 std::vector<std::string> labels = {
"None",
"PublicInputs",
"Proof" };
58 const bool verified = prover.
verify(proof, public_inputs);
59 EXPECT_TRUE(verified) <<
"native proof verification failed";
64 return { proof, public_inputs_flat };
76 .key_hash = IS_CONSTANT,
85 switch (invalid_witness_target) {
95 witness_values[constraint.
proof[FrCodec::calc_num_fields<AvmFlavor::Commitment>() *
101 return { constraint, witness_values };
113 GTEST_SKIP() <<
"Skipping slow test";
116 size_t num_gates = test_vk_independence<UltraRollupFlavor>();
124 GTEST_SKIP() <<
"Skipping slow test";
126 std::vector<std::string> _ = test_tampering();
132 GTEST_SKIP() <<
"Skipping slow test";
136 AcirConstraint constraint;
138 Base::generate_constraints(constraint, witness);
145 auto builder = create_circuit<Builder>(program, metadata);
169 FF(
"0x01caba77a068a59190885beaf6c30240dcd92b0515064b36dd4a3035b39154ea");
176 const std::vector<FF>& public_inputs_flat)
180 for (
const auto public_input : public_inputs_flat) {
185 for (
const auto proof_element : proof) {
191 PublicInputs::flat_to_columns<field_t<Builder>>(stdlib_public_inputs_flat);
192 auto [mega_proof, goblin_proof, mega_vk] =
195 return { stdlib_proof, public_inputs, { mega_proof, goblin_proof, mega_vk } };
203 GTEST_SKIP() <<
"Skipping slow test";
208 auto [_stdlib_proof, _public_inputs, inner_prover_output] =
209 create_and_prove_inner_circuit(outer_builder, proof, public_inputs_flat);
210 EXPECT_EQ(inner_prover_output.mega_vk->hash(), EXPECTED_INNER_VK_HASH)
211 <<
"The VK hash of the inner circuit in the Goblinized AVM recursive verifier has changed. If this is "
212 "expected, update the expected value in the test.";
223 GTEST_SKIP() <<
"Skipping slow test";
229 auto [stdlib_proof, public_inputs, inner_prover_output] =
230 create_and_prove_inner_circuit(outer_builder, proof, public_inputs_flat);
232 auto mega_proof_tampered = inner_prover_output.mega_proof;
233 mega_proof_tampered[0] +=
FF::one();
239 { mega_proof_tampered, inner_prover_output.goblin_proof, inner_prover_output.mega_vk });
241 EXPECT_TRUE(outer_builder.failed());
246 auto [stdlib_proof, public_inputs, inner_prover_output] =
247 create_and_prove_inner_circuit(outer_builder, proof, public_inputs_flat);
249 auto goblin_proof_tampered = inner_prover_output.goblin_proof;
250 goblin_proof_tampered.merge_proof[0] -=
FF::one();
256 { inner_prover_output.mega_proof, goblin_proof_tampered, inner_prover_output.mega_vk });
258 EXPECT_TRUE(outer_builder.failed());
263 auto [stdlib_proof, public_inputs, inner_prover_output] =
264 create_and_prove_inner_circuit(outer_builder, proof, public_inputs_flat);
266 auto mega_vk_tampered = inner_prover_output.mega_vk;
267 mega_vk_tampered->q_m = mega_vk_tampered->q_m + MegaAvmFlavor::Commitment::one();
273 { inner_prover_output.mega_proof, inner_prover_output.goblin_proof, mega_vk_tampered });
275 EXPECT_TRUE(outer_builder.failed());
#define AVM_PUBLIC_INPUTS_COLUMNS_COMBINED_LENGTH
#define AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED
static void SetUpTestSuite()
static std::vector< Target > get_all()
static std::vector< std::string > get_labels()
static std::pair< AvmProver::Proof, std::vector< FF > > create_avm_data()
static std::pair< AcirConstraint, WitnessVector > invalidate_witness(AcirConstraint constraint, WitnessVector witness_values, const InvalidWitness::Target &invalid_witness_target)
static ProgramMetadata generate_metadata()
static void generate_constraints(AcirConstraint &avm_recursion_constraint, WitnessVector &witness_values)
static void SetUpTestSuite()
static std::tuple< stdlib::Proof< Builder >, std::vector< std::vector< field_t< Builder > > >, InnerProverOutput > create_and_prove_inner_circuit(Builder &outer_builder, const HonkProof &proof, const std::vector< FF > &public_inputs_flat)
AvmGoblinRecursiveVerifier::InnerProverOutput InnerProverOutput
static constexpr FF EXPECTED_INNER_VK_HASH
A ProverInstance is normally constructed from a finalized circuit and it contains all the information...
typename ExecutionTrace::FF FF
static constexpr size_t NUM_WITNESS_ENTITIES
Recursive verifier of AVM2 proofs that utilizes the Goblin mechanism for efficient EC operations.
InnerProverOutput construct_and_prove_inner_recursive_verification_circuit(const stdlib::Proof< UltraBuilder > &stdlib_proof, const std::vector< std::vector< UltraFF > > &public_inputs) const
Construct and prove the inner Mega-arithmetized AVM recursive verifier circuit.
stdlib::recursion::honk::UltraRecursiveVerifierOutput< UltraBuilder > RecursiveAvmGoblinOutput
RecursiveAvmGoblinOutput construct_outer_recursive_verification_circuit(const stdlib::Proof< UltraBuilder > &stdlib_proof, const std::vector< std::vector< UltraFF > > &public_inputs, const InnerProverOutput &inner_output) const
Construct the outer circuit which recursively verifies a Mega proof and a Goblin proof.
bool verify(const Proof &proof, const PublicInputs &pi)
Proof prove(tracegen::TraceContainer &&trace)
A simple wrapper around a vector of stdlib field elements representing a proof.
bool skip_slow_tests()
Check if slow tests should be skipped.
std::pair< tracegen::TraceContainer, PublicInputs > get_minimal_trace_with_pi()
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.
Entry point for Barretenberg command-line interface.
std::vector< fr > HonkProof
UltraCircuitBuilder_< UltraExecutionTraceBlocks > UltraCircuitBuilder
VerifierCommitmentKey< Curve > vk
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
static constexpr field one()
static constexpr field zero()
Output type for recursive ultra verification.