From 7b4c3e1e4c5a9088139d8364899668df9e498710 Mon Sep 17 00:00:00 2001 From: ledwards2225 Date: Tue, 16 Jan 2024 23:27:53 +0000 Subject: [PATCH 1/2] reinstate builder templating for GU recursive flavor --- .../cpp/src/barretenberg/flavor/flavor.hpp | 17 +++++++++++------ .../flavor/goblin_ultra_recursive.hpp | 4 ++-- .../src/barretenberg/goblin/mock_circuits.hpp | 4 ++-- .../honk/verifier/goblin_verifier.test.cpp | 6 +++--- .../honk/verifier/ultra_recursive_verifier.cpp | 3 ++- .../honk/verifier/ultra_recursive_verifier.hpp | 1 - 6 files changed, 20 insertions(+), 15 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/flavor/flavor.hpp b/barretenberg/cpp/src/barretenberg/flavor/flavor.hpp index e5979a6cd82..bf99f19cb0a 100644 --- a/barretenberg/cpp/src/barretenberg/flavor/flavor.hpp +++ b/barretenberg/cpp/src/barretenberg/flavor/flavor.hpp @@ -263,7 +263,7 @@ class Ultra; class ECCVM; class GoblinUltra; template class UltraRecursive_; -class GoblinUltraRecursive; +template class GoblinUltraRecursive_; } // namespace proof_system::honk::flavor // Forward declare plonk flavors @@ -293,18 +293,23 @@ concept IsUltraFlavor = IsAnyOf concept IsGoblinFlavor = IsAnyOf; + honk::flavor::GoblinUltraRecursive_, + honk::flavor::GoblinUltraRecursive_>; template concept IsRecursiveFlavor = IsAnyOf, honk::flavor::UltraRecursive_, - honk::flavor::GoblinUltraRecursive>; + honk::flavor::GoblinUltraRecursive_, + honk::flavor::GoblinUltraRecursive_>; template concept IsGrumpkinFlavor = IsAnyOf; -template concept IsFoldingFlavor = IsAnyOf, - honk::flavor::UltraRecursive_, - honk::flavor::GoblinUltraRecursive>; +template concept IsFoldingFlavor = IsAnyOf, + honk::flavor::UltraRecursive_, + honk::flavor::GoblinUltraRecursive_, + honk::flavor::GoblinUltraRecursive_>; template concept UltraFlavor = IsAnyOf; diff --git a/barretenberg/cpp/src/barretenberg/flavor/goblin_ultra_recursive.hpp b/barretenberg/cpp/src/barretenberg/flavor/goblin_ultra_recursive.hpp index ee257322187..b05e8daedfc 100644 --- a/barretenberg/cpp/src/barretenberg/flavor/goblin_ultra_recursive.hpp +++ b/barretenberg/cpp/src/barretenberg/flavor/goblin_ultra_recursive.hpp @@ -38,9 +38,9 @@ namespace proof_system::honk::flavor { * * @tparam BuilderType Determines the arithmetization of the verifier circuit defined based on this flavor. */ -class GoblinUltraRecursive { +template class GoblinUltraRecursive_ { public: - using CircuitBuilder = GoblinUltraCircuitBuilder; + using CircuitBuilder = BuilderType; // Determines arithmetization of circuit instantiated with this flavor using Curve = plonk::stdlib::bn254; using GroupElement = Curve::Element; using FF = Curve::ScalarField; diff --git a/barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp b/barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp index bd959eeea77..43ecdc8a1a9 100644 --- a/barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp +++ b/barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp @@ -18,8 +18,8 @@ class GoblinMockCircuits { using OpQueue = proof_system::ECCOpQueue; using GoblinUltraBuilder = proof_system::GoblinUltraCircuitBuilder; using Flavor = proof_system::honk::flavor::GoblinUltra; - using RecursiveFlavor = proof_system::honk::flavor::GoblinUltraRecursive; - using RecursiveVerifier = proof_system::plonk::stdlib::recursion::honk::GoblinRecursiveVerifier; + using RecursiveFlavor = proof_system::honk::flavor::GoblinUltraRecursive_; + using RecursiveVerifier = proof_system::plonk::stdlib::recursion::honk::UltraRecursiveVerifier_; using KernelInput = Goblin::AccumulationOutput; static constexpr size_t NUM_OP_QUEUE_COLUMNS = Flavor::NUM_WIRES; diff --git a/barretenberg/cpp/src/barretenberg/stdlib/recursion/honk/verifier/goblin_verifier.test.cpp b/barretenberg/cpp/src/barretenberg/stdlib/recursion/honk/verifier/goblin_verifier.test.cpp index 2e6a67f41ca..dc34ccabcee 100644 --- a/barretenberg/cpp/src/barretenberg/stdlib/recursion/honk/verifier/goblin_verifier.test.cpp +++ b/barretenberg/cpp/src/barretenberg/stdlib/recursion/honk/verifier/goblin_verifier.test.cpp @@ -33,9 +33,9 @@ template class GoblinRecursiveVerifierTest : public testi using InnerFF = InnerFlavor::FF; // Types for recursive verifier circuit - using RecursiveFlavor = ::proof_system::honk::flavor::GoblinUltraRecursive; - using RecursiveVerifier = UltraRecursiveVerifier_; using OuterBuilder = BuilderType; + using RecursiveFlavor = ::proof_system::honk::flavor::GoblinUltraRecursive_; + using RecursiveVerifier = UltraRecursiveVerifier_; using VerificationKey = typename RecursiveVerifier::VerificationKey; // Helper for getting composer for prover/verifier of recursive (outer) circuit @@ -255,7 +255,7 @@ template class GoblinRecursiveVerifierTest : public testi }; // Run the recursive verifier tests with conventional Ultra builder and Goblin builder -using BuilderTypes = testing::Types; +using BuilderTypes = testing::Types; TYPED_TEST_SUITE(GoblinRecursiveVerifierTest, BuilderTypes); diff --git a/barretenberg/cpp/src/barretenberg/stdlib/recursion/honk/verifier/ultra_recursive_verifier.cpp b/barretenberg/cpp/src/barretenberg/stdlib/recursion/honk/verifier/ultra_recursive_verifier.cpp index fb9719d6cde..acce057a008 100644 --- a/barretenberg/cpp/src/barretenberg/stdlib/recursion/honk/verifier/ultra_recursive_verifier.cpp +++ b/barretenberg/cpp/src/barretenberg/stdlib/recursion/honk/verifier/ultra_recursive_verifier.cpp @@ -127,5 +127,6 @@ std::array UltraRecursiveVerifier_::ve template class UltraRecursiveVerifier_>; template class UltraRecursiveVerifier_>; -template class UltraRecursiveVerifier_; +template class UltraRecursiveVerifier_>; +template class UltraRecursiveVerifier_>; } // namespace proof_system::plonk::stdlib::recursion::honk diff --git a/barretenberg/cpp/src/barretenberg/stdlib/recursion/honk/verifier/ultra_recursive_verifier.hpp b/barretenberg/cpp/src/barretenberg/stdlib/recursion/honk/verifier/ultra_recursive_verifier.hpp index 284b3b11850..2aa3c917f3e 100644 --- a/barretenberg/cpp/src/barretenberg/stdlib/recursion/honk/verifier/ultra_recursive_verifier.hpp +++ b/barretenberg/cpp/src/barretenberg/stdlib/recursion/honk/verifier/ultra_recursive_verifier.hpp @@ -40,5 +40,4 @@ template class UltraRecursiveVerifier_ { // Instance declarations for Ultra and Goblin-Ultra verifier circuits with both conventional Ultra and Goblin-Ultra // arithmetization. using UltraRecursiveVerifier = UltraRecursiveVerifier_; -using GoblinRecursiveVerifier = UltraRecursiveVerifier_; } // namespace proof_system::plonk::stdlib::recursion::honk From 3d9db2ea999cca162a900198970ee3f09333af96 Mon Sep 17 00:00:00 2001 From: ledwards2225 Date: Wed, 17 Jan 2024 14:43:26 +0000 Subject: [PATCH 2/2] fix build --- .../src/barretenberg/flavor/goblin_ultra_recursive.hpp | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/flavor/goblin_ultra_recursive.hpp b/barretenberg/cpp/src/barretenberg/flavor/goblin_ultra_recursive.hpp index b05e8daedfc..8c439e84baa 100644 --- a/barretenberg/cpp/src/barretenberg/flavor/goblin_ultra_recursive.hpp +++ b/barretenberg/cpp/src/barretenberg/flavor/goblin_ultra_recursive.hpp @@ -42,10 +42,10 @@ template class GoblinUltraRecursive_ { public: using CircuitBuilder = BuilderType; // Determines arithmetization of circuit instantiated with this flavor using Curve = plonk::stdlib::bn254; - using GroupElement = Curve::Element; - using FF = Curve::ScalarField; - using Commitment = Curve::Element; - using CommitmentHandle = Curve::Element; + using GroupElement = typename Curve::Element; + using FF = typename Curve::ScalarField; + using Commitment = typename Curve::Element; + using CommitmentHandle = typename Curve::Element; using NativeVerificationKey = flavor::GoblinUltra::VerificationKey; // Note(luke): Eventually this may not be needed at all