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 [[maybe_unused]]
size_t num_gates = test_vk_independence<UltraRollupFlavor>();
125 GTEST_SKIP() <<
"Skipping slow test";
127 std::vector<std::string> _ = test_tampering();
134 GTEST_SKIP() <<
"Skipping slow test";
138 AcirConstraint constraint;
140 Base::generate_constraints(constraint, witness);
147 auto builder = create_circuit<Builder>(program, metadata);
155 static constexpr FF EXPECTED_OUTER_VK_HASH =
156 FF(
"0x195059523571dbadeae1b213250567e17b4994568b736b73a1aae2b0c65fd2cd");
157 EXPECT_EQ(
vk->hash(), EXPECTED_OUTER_VK_HASH)
158 <<
"The VK hash of the outer circuit in the Goblinized AVM recursive verifier has changed. If this is "
159 "expected, update the expected value in the test.";
170 FF(
"0x2be1149e37f087a8420d61586aed0d7db942f04937f2d3fa01bdf7f4cc62fb3c");
178 const std::vector<FF>& public_inputs_flat)
182 for (
const auto public_input : public_inputs_flat) {
187 for (
const auto proof_element : proof) {
192 PublicInputs::flat_to_columns<field_t<Builder>>(stdlib_public_inputs_flat);
193 auto [mega_proof, goblin_proof, mega_vk] =
197 return { stdlib_proof, public_inputs, { mega_proof, goblin_proof, mega_vk } };
208 GTEST_SKIP() <<
"Skipping slow test";
216 for (
const auto public_input : public_inputs_flat) {
221 for (
const auto proof_element : proof) {
226 PublicInputs::flat_to_columns<field_t<Builder>>(stdlib_public_inputs_flat);
230 inner_builder, stdlib_proof, public_inputs);
235 EXPECT_EQ(mega_vk->hash(), EXPECTED_INNER_VK_HASH)
236 <<
"The VK hash of the inner circuit in the Goblinized AVM recursive verifier has changed. If this is "
237 "expected, update the expected value in the test.";
238 EXPECT_EQ(inner_builder.num_gates(), EXPECT_GATE_COUNT);
249 GTEST_SKIP() <<
"Skipping slow test";
255 auto [stdlib_proof, public_inputs, inner_prover_output] =
256 create_and_prove_inner_circuit(outer_builder, proof, public_inputs_flat);
258 auto mega_proof_tampered = inner_prover_output.mega_proof;
259 mega_proof_tampered[0] +=
FF::one();
265 { mega_proof_tampered, inner_prover_output.goblin_proof, inner_prover_output.mega_vk });
267 EXPECT_TRUE(outer_builder.failed());
272 auto [stdlib_proof, public_inputs, inner_prover_output] =
273 create_and_prove_inner_circuit(outer_builder, proof, public_inputs_flat);
278 static constexpr size_t evals_after_op = 3;
279 const size_t op_eval_idx = inner_prover_output.goblin_proof.eccvm_proof.size() - evals_after_op;
281 auto goblin_proof_tampered = inner_prover_output.goblin_proof;
282 goblin_proof_tampered.eccvm_proof[op_eval_idx] +=
FF(1);
288 { inner_prover_output.mega_proof, goblin_proof_tampered, inner_prover_output.mega_vk });
290 EXPECT_TRUE(outer_builder.failed());
295 auto [stdlib_proof, public_inputs, inner_prover_output] =
296 create_and_prove_inner_circuit(outer_builder, proof, public_inputs_flat);
298 auto mega_vk_tampered = inner_prover_output.mega_vk;
299 mega_vk_tampered->q_m = mega_vk_tampered->q_m + MegaAvmFlavor::Commitment::one();
305 { inner_prover_output.mega_proof, inner_prover_output.goblin_proof, mega_vk_tampered });
307 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)
static constexpr size_t EXPECT_GATE_COUNT
TwoLayerAvmRecursiveVerifier::InnerProverOutput InnerProverOutput
static constexpr FF EXPECTED_INNER_VK_HASH
Base Native verification key class.
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
bool verify(const Proof &proof, const PublicInputs &pi)
Proof prove(tracegen::TraceContainer &&trace)
Recursive verifier of AVM2 proofs that utilizes the Goblin mechanism for efficient EC operations.
static void construct_inner_recursive_verification_circuit(MegaCircuitBuilder &inner_builder, const stdlib::Proof< UltraCircuitBuilder > &stdlib_proof, const std::vector< std::vector< UltraFF > > &public_inputs)
Construct the inner recursive verification circuit for the AVM2 recursive verifier.
static InnerProverOutput construct_and_prove_inner_recursive_verification_circuit(const stdlib::Proof< UltraCircuitBuilder > &stdlib_proof, const std::vector< std::vector< UltraFF > > &public_inputs)
Construct and prove the inner Mega-arithmetized AVM recursive verifier circuit.
stdlib::recursion::honk::UltraRecursiveVerifierOutput< UltraCircuitBuilder > TwoLayerAvmRecursiveVerifierOutput
TwoLayerAvmRecursiveVerifierOutput construct_outer_recursive_verification_circuit(const stdlib::Proof< UltraCircuitBuilder > &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.
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.