From 995973b0226ddd7ae4cb5c3501859bec10f4eb93 Mon Sep 17 00:00:00 2001 From: ledwards2225 <98505400+ledwards2225@users.noreply.github.com> Date: Wed, 17 Jan 2024 10:50:31 -0700 Subject: [PATCH] fix: reinstate Ultra arith rec verifier test (#3886) Reinstate the Builder template param on the GoblinUltraRecursive flavor. This allows for the aithmetization of a GUH recursive verifier circuit to be GU or U - both of which will be needed in the aztec architecture. --- .../cpp/src/barretenberg/flavor/flavor.hpp | 17 +++++++++++------ .../flavor/goblin_ultra_recursive.hpp | 12 ++++++------ .../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, 24 insertions(+), 19 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..8c439e84baa 100644 --- a/barretenberg/cpp/src/barretenberg/flavor/goblin_ultra_recursive.hpp +++ b/barretenberg/cpp/src/barretenberg/flavor/goblin_ultra_recursive.hpp @@ -38,14 +38,14 @@ 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; - 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 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