Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
sumcheck_test_flavor.hpp
Go to the documentation of this file.
1
44#pragma once
45
56
57namespace bb {
58
69template <typename FF_> class DependentTestRelationImpl {
70 public:
71 using FF = FF_;
72
73 static constexpr std::array<size_t, 1> SUBRELATION_PARTIAL_LENGTHS{
74 2 // degree 1: q_test * w_test_1
75 };
76
77 static constexpr std::array<bool, 1> SUBRELATION_LINEARLY_INDEPENDENT{
78 false // This subrelation is NOT linearly independent (should NOT be scaled)
79 };
80
81 template <typename AllEntities> static bool skip(const AllEntities& in) { return in.q_test.is_zero(); }
82
83 template <typename ContainerOverSubrelations, typename AllEntities, typename Parameters>
84 static void accumulate(ContainerOverSubrelations& evals,
85 const AllEntities& in,
86 const Parameters& /*unused*/,
87 const FF& /*scaling_factor*/)
88 {
90 // Note: NO scaling_factor used here - this is linearly dependent!
91 auto tmp = in.w_test_1 * in.q_test;
92 std::get<0>(evals) += Accumulator(tmp);
93 }
94};
95
97
98} // namespace bb
99
100namespace bb {
101
138template <typename CurveType = curve::BN254, bool HasZK_ = false, bool UseShortMonomials_ = true>
140 public:
143 using FF = typename Curve::ScalarField;
144 using GroupElement = typename Curve::Element;
151
152 // Configuration constants from template parameters
153 static constexpr bool HasZK = HasZK_;
154 static constexpr bool USE_SHORT_MONOMIALS = UseShortMonomials_;
155 static constexpr bool USE_PADDING = false;
156 static constexpr size_t NUM_WIRES = 4;
157
158 // Entity counts:
159 // Precomputed: q_m, q_l, q_r, q_o, q_4, q_c, q_arith + q_test = 8
160 // Witness: w_l, w_r, w_o, w_4 + w_test_1, w_test_2 = 6
161 // Shifted: w_l_shift, w_4_shift = 2
162 // Note: No gemini_masking_poly - that's a PCS concept, not sumcheck
163 static constexpr size_t NUM_PRECOMPUTED_ENTITIES = 8;
164 static constexpr size_t NUM_WITNESS_ENTITIES = 6;
165 static constexpr size_t NUM_SHIFTED_ENTITIES = 2;
167
168 // Two relations: Arithmetic (linearly independent) + DependentTest (linearly dependent)
169 // Tests can activate either or both via selectors:
170 // - q_arith = 1 : activate arithmetic relation (linearly independent, WILL be scaled)
171 // - q_test = 1 : activate dependent test relation (linearly dependent, will NOT be scaled)
174
175 static constexpr size_t MAX_PARTIAL_RELATION_LENGTH = compute_max_partial_relation_length<Relations>();
176 // For ZK flavors, BATCHED_RELATION_PARTIAL_LENGTH is incremented by 1 for the libra masking univariates
177 // For BN254 with ZK, this must match Curve::LIBRA_UNIVARIATES_LENGTH (9)
178 // Note: MAX_PARTIAL_RELATION_LENGTH = 6 (from ArithmeticRelation's [6,5])
179 // Non-ZK: 6 + 1 = 7
180 // ZK: 6 + 3 = 9 (matches BN254::LIBRA_UNIVARIATES_LENGTH)
182 static constexpr size_t NUM_SUBRELATIONS = compute_number_of_subrelations<Relations>();
185
190 template <typename DataType> class PrecomputedEntities {
191 public:
192 DEFINE_FLAVOR_MEMBERS(DataType,
193 q_m, // Multiplication selector (arithmetic)
194 q_l, // Left wire selector (arithmetic)
195 q_r, // Right wire selector (arithmetic)
196 q_o, // Output wire selector (arithmetic)
197 q_4, // Fourth wire selector (arithmetic)
198 q_c, // Constant selector (arithmetic)
199 q_arith, // Arithmetic gate enable (linearly independent, WILL be scaled)
200 q_test) // Test relation enable (linearly dependent, will NOT be scaled)
201 };
202
207 template <typename DataType> class WitnessEntities {
208 public:
209 DEFINE_FLAVOR_MEMBERS(DataType,
210 w_l, // Left wire (arithmetic)
211 w_r, // Right wire (arithmetic)
212 w_o, // Output wire (arithmetic)
213 w_4, // Fourth wire (arithmetic)
214 w_test_1, // Test wire 1 (dependent test relation)
215 w_test_2) // Test wire 2 (dependent test relation, currently unused)
216 };
217
221 template <typename DataType> class ShiftedEntities {
222 public:
223 DEFINE_FLAVOR_MEMBERS(DataType,
224 w_l_shift, // w_l shifted by 1
225 w_4_shift) // w_4 shifted by 1
226 };
227
234 template <typename DataType>
246
250 class ProverPolynomials : public AllEntities<Polynomial> {
251 public:
252 ProverPolynomials() = default;
253 ProverPolynomials(size_t circuit_size)
254 {
255 for (auto& poly : this->get_precomputed()) {
256 poly = Polynomial(circuit_size);
257 }
258 for (auto& poly : this->get_witness()) {
259 poly = Polynomial(circuit_size);
260 }
261 for (auto& poly : this->get_shifted()) {
262 poly = Polynomial(circuit_size);
263 }
264 }
265
266 [[nodiscard]] size_t get_polynomial_size() const { return this->w_l.size(); }
267
272 auto get_to_be_shifted() { return RefArray{ this->w_l, this->w_4 }; }
273
279 {
280 for (auto [shifted, to_be_shifted] : zip_view(this->get_shifted(), this->get_to_be_shifted())) {
281 shifted = to_be_shifted.shifted();
282 }
283 }
284 };
285
290
295
299 class AllValues : public AllEntities<FF> {
300 public:
302 using Base::Base;
303 };
304
310};
311
312// ================================================================================================
313// Convenient type aliases for common test configurations
314// ================================================================================================
315// Note: All flavors include both relations (arithmetic + test).
316// Tests can choose which to activate via selectors (q_arith = 1 or q_test = 1).
317
323
329
335
342
348
349} // namespace bb
Common transcript class for both parties. Stores the data for the current round, as well as the manif...
CommitmentKey object over a pairing group 𝔾₁.
A linearly dependent test relation for sumcheck testing.
static bool skip(const AllEntities &in)
static constexpr std::array< bool, 1 > SUBRELATION_LINEARLY_INDEPENDENT
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const Parameters &, const FF &)
static constexpr std::array< size_t, 1 > SUBRELATION_PARTIAL_LENGTHS
A container for storing the partially evaluated multivariates produced by sumcheck.
A template class for a reference array. Behaves as if std::array<T&, N> was possible.
Definition ref_array.hpp:22
A wrapper for Relations to expose methods used by the Sumcheck prover or verifier to add the contribu...
auto get_to_be_shifted()
Get the polynomials that will be shifted.
void set_shifted()
Set all shifted polynomials based on their to-be-shifted counterpart.
A flexible, minimal test flavor for sumcheck testing.
typename Curve::ScalarField FF
static constexpr size_t NUM_SUBRELATIONS
std::tuple< ArithmeticRelation< FF_ >, DependentTestRelation< FF_ > > Relations_
static constexpr bool USE_SHORT_MONOMIALS
static constexpr size_t NUM_ALL_ENTITIES
typename Curve::AffineElement Commitment
static constexpr bool USE_PADDING
bb::Polynomial< FF > Polynomial
static constexpr size_t MAX_PARTIAL_RELATION_LENGTH
static constexpr size_t NUM_SHIFTED_ENTITIES
static constexpr size_t NUM_PRECOMPUTED_ENTITIES
static constexpr size_t NUM_WITNESS_ENTITIES
static constexpr size_t BATCHED_RELATION_PARTIAL_LENGTH
static constexpr size_t NUM_WIRES
typename Curve::Element GroupElement
static constexpr size_t NUM_RELATIONS
Representation of the Grumpkin Verifier Commitment Key inside a bn254 circuit.
typename Group::element Element
Definition grumpkin.hpp:64
typename Group::affine_element AffineElement
Definition grumpkin.hpp:65
Base class templates shared across Honk flavors.
#define DEFINE_FLAVOR_MEMBERS(DataType,...)
Define the body of a flavor class, included each member and a pointer view with which to iterate the ...
#define DEFINE_COMPOUND_GET_ALL(...)
Entry point for Barretenberg command-line interface.
Definition api.hpp:5
UltraCircuitBuilder_< UltraExecutionTraceBlocks > UltraCircuitBuilder
BaseTranscript< FrCodec, bb::crypto::Poseidon2< bb::crypto::Poseidon2Bn254ScalarFieldParams > > NativeTranscript
CurveType
Definition types.hpp:10
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
Definition tuple.hpp:13