Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
bb::stdlib::recursion::honk Namespace Reference

Classes

class  BoomerangGoblinRecursiveVerifierTests
 
class  BoomerangRecursiveVerifierTest
 Test suite for recursive verification of Honk proofs for both Ultra and Mega arithmetisation. More...
 
class  ClientIVCRecursionTests
 
class  ClientIVCRecursiveVerifier
 
class  DeciderRecursiveVerifier_
 
class  DefaultIO
 Manages the data that is propagated on the public inputs of an application/function circuit. More...
 
class  GoblinAvmIO
 The data that is propagated on the public inputs of the inner GoblinAvmRecursiveVerifier circuit. More...
 
class  GoblinRecursiveVerifier
 
struct  GoblinRecursiveVerifierOutput
 
class  GoblinRecursiveVerifierTests
 
class  HidingKernelIO
 Manages the data that is propagated on the public inputs of a hiding kernel circuit. More...
 
struct  IpaAccumulator
 
class  KernelIO
 Manages the data that is propagated on the public inputs of a kernel circuit. More...
 
class  OinkRecursiveVerifier_
 
class  ProtogalaxyRecursiveTests
 
class  ProtogalaxyRecursiveVerifier_
 
class  RecursiveDeciderVerificationKey_
 The stdlib counterpart of DeciderVerificationKey, used in recursive folding verification. More...
 
struct  RecursiveDeciderVerificationKeys_
 
class  RecursiveVerifierTest
 Test suite for recursive verification of Honk proofs for both Ultra and Mega arithmetisation. More...
 
class  RollupIO
 The data that is propagated on the public inputs of a rollup circuit. More...
 
class  SpecialPublicInputsTests
 
struct  StdlibTranscriptParams
 
class  UltraRecursiveVerifier_
 
struct  UltraRecursiveVerifierOutput
 

Typedefs

using Flavors = testing::Types< UltraRecursiveFlavor_< UltraCircuitBuilder > >
 
using AppIO = DefaultIO< MegaCircuitBuilder >
 The data that is propagated on the public inputs of an application/function circuit.
 
using UltraStdlibTranscript = BaseTranscript< StdlibTranscriptParams< UltraCircuitBuilder > >
 
using MegaStdlibTranscript = BaseTranscript< StdlibTranscriptParams< MegaCircuitBuilder > >
 
using Builder = UltraCircuitBuilder
 
using UltraFlavor = UltraFlavor
 
using UltraRecursiveFlavor = UltraRecursiveFlavor_< Builder >
 
using FF = fr
 
using NativeTranscript = NativeTranscript
 
using StdlibTranscript = BaseTranscript< StdlibTranscriptParams< Builder > >
 
using StdlibProof = stdlib::Proof< Builder >
 

Functions

 TEST_F (BoomerangGoblinRecursiveVerifierTests, graph_description_basic)
 Construct and check a goblin recursive verification circuit.
 
 TYPED_TEST_SUITE (BoomerangRecursiveVerifierTest, Flavors)
 
 HEAVY_TYPED_TEST (BoomerangRecursiveVerifierTest, SingleRecursiveVerification)
 
 TEST_F (ClientIVCRecursionTests, NativeVerification)
 Ensure the ClientIVC proof used herein can be natively verified.
 
 TEST_F (ClientIVCRecursionTests, Basic)
 Construct and Check a recursive ClientIVC verification circuit.
 
 TEST_F (ClientIVCRecursionTests, ClientTubeBase)
 
 TEST_F (ClientIVCRecursionTests, TubeVKIndependentOfInputCircuits)
 
 TEST_F (GoblinRecursiveVerifierTests, NativeVerification)
 Ensure the Goblin proof produced by the test method can be natively verified.
 
 TEST_F (GoblinRecursiveVerifierTests, Basic)
 Construct and check a goblin recursive verification circuit.
 
 TEST_F (GoblinRecursiveVerifierTests, IndependentVKHash)
 
 TEST_F (GoblinRecursiveVerifierTests, ECCVMFailure)
 Ensure failure of the goblin recursive verification circuit for a bad ECCVM proof.
 
 TEST_F (GoblinRecursiveVerifierTests, TranslatorFailure)
 Ensure failure of the goblin recursive verification circuit for a bad Translator proof.
 
 TEST_F (GoblinRecursiveVerifierTests, TranslationEvaluationsFailure)
 Ensure failure of the goblin recursive verification circuit for bad translation evaluations.
 
 TEST_F (GoblinRecursiveVerifierTests, TranslatorMergeConsistencyFailure)
 Ensure failure of the goblin recursive verification circuit for bad translation evaluations.
 
 TYPED_TEST_SUITE (RecursiveVerifierTest, Flavors)
 
 HEAVY_TYPED_TEST (RecursiveVerifierTest, InnerCircuit)
 
 HEAVY_TYPED_TEST (RecursiveVerifierTest, RecursiveVerificationKey)
 
 HEAVY_TYPED_TEST (RecursiveVerifierTest, SingleRecursiveVerification)
 
 HEAVY_TYPED_TEST (RecursiveVerifierTest, IndependentVKHash)
 
 HEAVY_TYPED_TEST (RecursiveVerifierTest, SingleRecursiveVerificationFailure)
 
 TEST_F (ProtogalaxyRecursiveTests, InnerCircuit)
 
 TEST_F (ProtogalaxyRecursiveTests, NewEvaluate)
 
 TEST_F (ProtogalaxyRecursiveTests, RecursiveFoldingTest)
 
 TEST_F (ProtogalaxyRecursiveTests, RecursiveFoldingTwiceTest)
 
 TEST_F (ProtogalaxyRecursiveTests, FullProtogalaxyRecursiveTest)
 
 TEST_F (ProtogalaxyRecursiveTests, TamperedDeciderProof)
 
 TEST_F (ProtogalaxyRecursiveTests, TamperedAccumulator)
 
 TEST_F (ProtogalaxyRecursiveTests, ConstantVerifierCircuit)
 
template<typename Builder >
std::array< typename bn254< Builder >::Group, Builder::NUM_WIRESempty_ecc_op_tables (Builder &builder)
 Construct commitments to empty subtables.
 
 TEST_F (SpecialPublicInputsTests, Basic)
 
 TEST_F (SpecialPublicInputsTests, Default)
 
 TEST_F (SpecialPublicInputsTests, RollUpIO)
 
 TEST_F (SpecialPublicInputsTests, HidingKernel)
 
template<class Flavor , size_t LENGTH>
auto generate_mock_proof_data (auto prover_transcript)
 Create some mock data; add it to the provided prover transcript in various mock rounds.
 
template<class Flavor , size_t LENGTH>
void perform_mock_verifier_transcript_operations (auto transcript)
 Perform series of verifier transcript operations.
 
 TEST (RecursiveHonkTranscript, InterfacesMatch)
 Test basic transcript functionality and check circuit.
 
 TEST (RecursiveHonkTranscript, ReturnValuesMatch)
 Check that native and stdlib verifier transcript functions produce equivalent outputs.
 
 TEST (RecursiveTranscript, InfinityConsistencyGrumpkin)
 Ensure that when encountering an infinity commitment results stay consistent in the recursive and native case for Grumpkin and the native and stdlib transcripts produce the same challenge.
 
 TEST (RecursiveTranscript, InfinityConsistencyBN254)
 Ensure that when encountering an infinity commitment results stay consistent in the recursive and native case for BN254 and the native and stdlib transcripts produce the same challenge.
 

Typedef Documentation

◆ AppIO

The data that is propagated on the public inputs of an application/function circuit.

Definition at line 191 of file special_public_inputs.hpp.

◆ Builder

◆ FF

Definition at line 21 of file transcript.test.cpp.

◆ Flavors

◆ MegaStdlibTranscript

◆ NativeTranscript

◆ StdlibProof

◆ StdlibTranscript

◆ UltraFlavor

Definition at line 19 of file transcript.test.cpp.

◆ UltraRecursiveFlavor

◆ UltraStdlibTranscript

Function Documentation

◆ empty_ecc_op_tables()

template<typename Builder >
std::array< typename bn254< Builder >::Group, Builder::NUM_WIRES > bb::stdlib::recursion::honk::empty_ecc_op_tables ( Builder builder)

Construct commitments to empty subtables.

In the first iteration of the Merge, the verifier sets the commitments to the previous full state of the op_queue equal to the commitments to the empty tables. This ensures that prover cannot lie, as the starting point of the merge is fixed.

Parameters
builder
Returns
std::array<typename bn254<Builder>::Group, Builder::NUM_WIRES>

Definition at line 36 of file special_public_inputs.hpp.

◆ generate_mock_proof_data()

template<class Flavor , size_t LENGTH>
auto bb::stdlib::recursion::honk::generate_mock_proof_data ( auto  prover_transcript)

Create some mock data; add it to the provided prover transcript in various mock rounds.

Parameters
prover_transcript
Returns
auto proof_data

Definition at line 32 of file transcript.test.cpp.

◆ HEAVY_TYPED_TEST() [1/6]

bb::stdlib::recursion::honk::HEAVY_TYPED_TEST ( BoomerangRecursiveVerifierTest  ,
SingleRecursiveVerification   
)

◆ HEAVY_TYPED_TEST() [2/6]

bb::stdlib::recursion::honk::HEAVY_TYPED_TEST ( RecursiveVerifierTest  ,
IndependentVKHash   
)

Definition at line 414 of file ultra_recursive_verifier.test.cpp.

◆ HEAVY_TYPED_TEST() [3/6]

bb::stdlib::recursion::honk::HEAVY_TYPED_TEST ( RecursiveVerifierTest  ,
InnerCircuit   
)

Definition at line 399 of file ultra_recursive_verifier.test.cpp.

◆ HEAVY_TYPED_TEST() [4/6]

bb::stdlib::recursion::honk::HEAVY_TYPED_TEST ( RecursiveVerifierTest  ,
RecursiveVerificationKey   
)

Definition at line 404 of file ultra_recursive_verifier.test.cpp.

◆ HEAVY_TYPED_TEST() [5/6]

bb::stdlib::recursion::honk::HEAVY_TYPED_TEST ( RecursiveVerifierTest  ,
SingleRecursiveVerification   
)

Definition at line 409 of file ultra_recursive_verifier.test.cpp.

◆ HEAVY_TYPED_TEST() [6/6]

bb::stdlib::recursion::honk::HEAVY_TYPED_TEST ( RecursiveVerifierTest  ,
SingleRecursiveVerificationFailure   
)

Definition at line 427 of file ultra_recursive_verifier.test.cpp.

◆ perform_mock_verifier_transcript_operations()

template<class Flavor , size_t LENGTH>
void bb::stdlib::recursion::honk::perform_mock_verifier_transcript_operations ( auto  transcript)

Perform series of verifier transcript operations.

Operations are designed to correspond to those performed by a prover transcript from which the verifier transcript was initialized.

Parameters
transcriptEither a native or stdlib verifier transcript
Template Parameters
Flavor
LENGTHLength of Univariate to be serialized

Definition at line 74 of file transcript.test.cpp.

◆ TEST() [1/4]

bb::stdlib::recursion::honk::TEST ( RecursiveHonkTranscript  ,
InterfacesMatch   
)

Test basic transcript functionality and check circuit.

Implicitly ensures stdlib interface is identical to native

Definition at line 99 of file transcript.test.cpp.

◆ TEST() [2/4]

bb::stdlib::recursion::honk::TEST ( RecursiveHonkTranscript  ,
ReturnValuesMatch   
)

Check that native and stdlib verifier transcript functions produce equivalent outputs.

Definition at line 135 of file transcript.test.cpp.

◆ TEST() [3/4]

bb::stdlib::recursion::honk::TEST ( RecursiveTranscript  ,
InfinityConsistencyBN254   
)

Ensure that when encountering an infinity commitment results stay consistent in the recursive and native case for BN254 and the native and stdlib transcripts produce the same challenge.

Todo:
(https://github.com/AztecProtocol/barretenberg/issues/1064) Add more transcript tests for both curves

Definition at line 237 of file transcript.test.cpp.

◆ TEST() [4/4]

bb::stdlib::recursion::honk::TEST ( RecursiveTranscript  ,
InfinityConsistencyGrumpkin   
)

Ensure that when encountering an infinity commitment results stay consistent in the recursive and native case for Grumpkin and the native and stdlib transcripts produce the same challenge.

Todo:
(https://github.com/AztecProtocol/barretenberg/issues/1064) Add more transcript tests for both curves

Definition at line 198 of file transcript.test.cpp.

◆ TEST_F() [1/24]

bb::stdlib::recursion::honk::TEST_F ( BoomerangGoblinRecursiveVerifierTests  ,
graph_description_basic   
)

Construct and check a goblin recursive verification circuit.

Definition at line 81 of file graph_description_goblin.test.cpp.

◆ TEST_F() [2/24]

bb::stdlib::recursion::honk::TEST_F ( ClientIVCRecursionTests  ,
Basic   
)

Construct and Check a recursive ClientIVC verification circuit.

Definition at line 66 of file client_ivc_recursive_verifier.test.cpp.

◆ TEST_F() [3/24]

bb::stdlib::recursion::honk::TEST_F ( ClientIVCRecursionTests  ,
ClientTubeBase   
)

Definition at line 89 of file client_ivc_recursive_verifier.test.cpp.

◆ TEST_F() [4/24]

bb::stdlib::recursion::honk::TEST_F ( ClientIVCRecursionTests  ,
NativeVerification   
)

Ensure the ClientIVC proof used herein can be natively verified.

Definition at line 54 of file client_ivc_recursive_verifier.test.cpp.

◆ TEST_F() [5/24]

bb::stdlib::recursion::honk::TEST_F ( ClientIVCRecursionTests  ,
TubeVKIndependentOfInputCircuits   
)

Definition at line 166 of file client_ivc_recursive_verifier.test.cpp.

◆ TEST_F() [6/24]

bb::stdlib::recursion::honk::TEST_F ( GoblinRecursiveVerifierTests  ,
Basic   
)

Construct and check a goblin recursive verification circuit.

Definition at line 107 of file goblin_recursive_verifier.test.cpp.

◆ TEST_F() [7/24]

bb::stdlib::recursion::honk::TEST_F ( GoblinRecursiveVerifierTests  ,
ECCVMFailure   
)

Ensure failure of the goblin recursive verification circuit for a bad ECCVM proof.

Definition at line 174 of file goblin_recursive_verifier.test.cpp.

◆ TEST_F() [8/24]

bb::stdlib::recursion::honk::TEST_F ( GoblinRecursiveVerifierTests  ,
IndependentVKHash   
)

Definition at line 138 of file goblin_recursive_verifier.test.cpp.

◆ TEST_F() [9/24]

bb::stdlib::recursion::honk::TEST_F ( GoblinRecursiveVerifierTests  ,
NativeVerification   
)

Ensure the Goblin proof produced by the test method can be natively verified.

Definition at line 94 of file goblin_recursive_verifier.test.cpp.

◆ TEST_F() [10/24]

bb::stdlib::recursion::honk::TEST_F ( GoblinRecursiveVerifierTests  ,
TranslationEvaluationsFailure   
)

Ensure failure of the goblin recursive verification circuit for bad translation evaluations.

Definition at line 270 of file goblin_recursive_verifier.test.cpp.

◆ TEST_F() [11/24]

bb::stdlib::recursion::honk::TEST_F ( GoblinRecursiveVerifierTests  ,
TranslatorFailure   
)

Ensure failure of the goblin recursive verification circuit for a bad Translator proof.

Definition at line 209 of file goblin_recursive_verifier.test.cpp.

◆ TEST_F() [12/24]

bb::stdlib::recursion::honk::TEST_F ( GoblinRecursiveVerifierTests  ,
TranslatorMergeConsistencyFailure   
)

Ensure failure of the goblin recursive verification circuit for bad translation evaluations.

Definition at line 293 of file goblin_recursive_verifier.test.cpp.

◆ TEST_F() [13/24]

bb::stdlib::recursion::honk::TEST_F ( ProtogalaxyRecursiveTests  ,
ConstantVerifierCircuit   
)

Definition at line 539 of file protogalaxy_recursive_verifier.test.cpp.

◆ TEST_F() [14/24]

bb::stdlib::recursion::honk::TEST_F ( ProtogalaxyRecursiveTests  ,
FullProtogalaxyRecursiveTest   
)

Definition at line 523 of file protogalaxy_recursive_verifier.test.cpp.

◆ TEST_F() [15/24]

bb::stdlib::recursion::honk::TEST_F ( ProtogalaxyRecursiveTests  ,
InnerCircuit   
)

Definition at line 503 of file protogalaxy_recursive_verifier.test.cpp.

◆ TEST_F() [16/24]

bb::stdlib::recursion::honk::TEST_F ( ProtogalaxyRecursiveTests  ,
NewEvaluate   
)

Definition at line 508 of file protogalaxy_recursive_verifier.test.cpp.

◆ TEST_F() [17/24]

bb::stdlib::recursion::honk::TEST_F ( ProtogalaxyRecursiveTests  ,
RecursiveFoldingTest   
)

Definition at line 513 of file protogalaxy_recursive_verifier.test.cpp.

◆ TEST_F() [18/24]

bb::stdlib::recursion::honk::TEST_F ( ProtogalaxyRecursiveTests  ,
RecursiveFoldingTwiceTest   
)

Definition at line 518 of file protogalaxy_recursive_verifier.test.cpp.

◆ TEST_F() [19/24]

bb::stdlib::recursion::honk::TEST_F ( ProtogalaxyRecursiveTests  ,
TamperedAccumulator   
)

Definition at line 534 of file protogalaxy_recursive_verifier.test.cpp.

◆ TEST_F() [20/24]

bb::stdlib::recursion::honk::TEST_F ( ProtogalaxyRecursiveTests  ,
TamperedDeciderProof   
)

Definition at line 529 of file protogalaxy_recursive_verifier.test.cpp.

◆ TEST_F() [21/24]

bb::stdlib::recursion::honk::TEST_F ( SpecialPublicInputsTests  ,
Basic   
)

Definition at line 13 of file special_public_inputs.test.cpp.

◆ TEST_F() [22/24]

bb::stdlib::recursion::honk::TEST_F ( SpecialPublicInputsTests  ,
Default   
)

Definition at line 89 of file special_public_inputs.test.cpp.

◆ TEST_F() [23/24]

bb::stdlib::recursion::honk::TEST_F ( SpecialPublicInputsTests  ,
HidingKernel   
)

Definition at line 246 of file special_public_inputs.test.cpp.

◆ TEST_F() [24/24]

bb::stdlib::recursion::honk::TEST_F ( SpecialPublicInputsTests  ,
RollUpIO   
)

Definition at line 158 of file special_public_inputs.test.cpp.

◆ TYPED_TEST_SUITE() [1/2]

bb::stdlib::recursion::honk::TYPED_TEST_SUITE ( BoomerangRecursiveVerifierTest  ,
Flavors   
)

◆ TYPED_TEST_SUITE() [2/2]

bb::stdlib::recursion::honk::TYPED_TEST_SUITE ( RecursiveVerifierTest  ,
Flavors   
)