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
55
56namespace bb {
57
68template <typename FF_> class DependentTestRelationImpl {
69 public:
70 using FF = FF_;
71
72 static constexpr std::array<size_t, 1> SUBRELATION_PARTIAL_LENGTHS{
73 2 // degree 1: q_test * w_test_1
74 };
75
76 static constexpr std::array<bool, 1> SUBRELATION_LINEARLY_INDEPENDENT{
77 false // This subrelation is NOT linearly independent (should NOT be scaled)
78 };
79
80 template <typename AllEntities> static bool skip(const AllEntities& in) { return in.q_test.is_zero(); }
81
82 template <typename ContainerOverSubrelations, typename AllEntities, typename Parameters>
83 static void accumulate(ContainerOverSubrelations& evals,
84 const AllEntities& in,
85 const Parameters& /*unused*/,
86 const FF& /*scaling_factor*/)
87 {
89 // Note: NO scaling_factor used here - this is linearly dependent!
90 auto tmp = in.w_test_1 * in.q_test;
91 std::get<0>(evals) += Accumulator(tmp);
92 }
93};
94
96
97} // namespace bb
98
99namespace bb {
100
137template <typename CurveType = curve::BN254, bool HasZK_ = false, bool UseShortMonomials_ = true>
139 public:
142 using FF = typename Curve::ScalarField;
143 using GroupElement = typename Curve::Element;
150
151 // Configuration constants from template parameters
152 static constexpr bool HasZK = HasZK_;
153 static constexpr bool USE_SHORT_MONOMIALS = UseShortMonomials_;
154 static constexpr bool USE_PADDING = false;
155 static constexpr size_t NUM_WIRES = 4;
156
157 // Entity counts:
158 // Precomputed: q_m, q_l, q_r, q_o, q_4, q_c, q_arith + q_test = 8
159 // Witness: w_l, w_r, w_o, w_4 + w_test_1, w_test_2 = 6
160 // Shifted: w_l_shift, w_4_shift = 2
161 // Note: No gemini_masking_poly - that's a PCS concept, not sumcheck
162 static constexpr size_t NUM_PRECOMPUTED_ENTITIES = 8;
163 static constexpr size_t NUM_WITNESS_ENTITIES = 6;
164 static constexpr size_t NUM_SHIFTED_ENTITIES = 2;
166
167 // Two relations: Arithmetic (linearly independent) + DependentTest (linearly dependent)
168 // Tests can activate either or both via selectors:
169 // - q_arith = 1 : activate arithmetic relation (linearly independent, WILL be scaled)
170 // - q_test = 1 : activate dependent test relation (linearly dependent, will NOT be scaled)
173
174 static constexpr size_t MAX_PARTIAL_RELATION_LENGTH = compute_max_partial_relation_length<Relations>();
175 // For ZK flavors, BATCHED_RELATION_PARTIAL_LENGTH is incremented by 1 for the libra masking univariates
176 // For BN254 with ZK, this must match Curve::LIBRA_UNIVARIATES_LENGTH (9)
177 // Note: MAX_PARTIAL_RELATION_LENGTH = 6 (from ArithmeticRelation's [6,5])
178 // Non-ZK: 6 + 1 = 7
179 // ZK: 6 + 3 = 9 (matches BN254::LIBRA_UNIVARIATES_LENGTH)
181 static constexpr size_t NUM_SUBRELATIONS = compute_number_of_subrelations<Relations>();
184
189 template <typename DataType> class PrecomputedEntities {
190 public:
191 DEFINE_FLAVOR_MEMBERS(DataType,
192 q_m, // Multiplication selector (arithmetic)
193 q_l, // Left wire selector (arithmetic)
194 q_r, // Right wire selector (arithmetic)
195 q_o, // Output wire selector (arithmetic)
196 q_4, // Fourth wire selector (arithmetic)
197 q_c, // Constant selector (arithmetic)
198 q_arith, // Arithmetic gate enable (linearly independent, WILL be scaled)
199 q_test) // Test relation enable (linearly dependent, will NOT be scaled)
200 };
201
206 template <typename DataType> class WitnessEntities {
207 public:
208 DEFINE_FLAVOR_MEMBERS(DataType,
209 w_l, // Left wire (arithmetic)
210 w_r, // Right wire (arithmetic)
211 w_o, // Output wire (arithmetic)
212 w_4, // Fourth wire (arithmetic)
213 w_test_1, // Test wire 1 (dependent test relation)
214 w_test_2) // Test wire 2 (dependent test relation, currently unused)
215 };
216
220 template <typename DataType> class ShiftedEntities {
221 public:
222 DEFINE_FLAVOR_MEMBERS(DataType,
223 w_l_shift, // w_l shifted by 1
224 w_4_shift) // w_4 shifted by 1
225 };
226
233 template <typename DataType>
245
249 class ProverPolynomials : public AllEntities<Polynomial> {
250 public:
251 ProverPolynomials() = default;
252 ProverPolynomials(size_t circuit_size)
253 {
254 for (auto& poly : this->get_precomputed()) {
255 poly = Polynomial(circuit_size);
256 }
257 for (auto& poly : this->get_witness()) {
258 poly = Polynomial(circuit_size);
259 }
260 for (auto& poly : this->get_shifted()) {
261 poly = Polynomial(circuit_size);
262 }
263 }
264
265 [[nodiscard]] size_t get_polynomial_size() const { return this->w_l.size(); }
266
271 auto get_to_be_shifted() { return RefArray{ this->w_l, this->w_4 }; }
272
278 {
279 for (auto [shifted, to_be_shifted] : zip_view(this->get_shifted(), this->get_to_be_shifted())) {
280 shifted = to_be_shifted.shifted();
281 }
282 }
283 };
284
289
294
298 class AllValues : public AllEntities<FF> {
299 public:
301 using Base::Base;
302 };
303
309};
310
311// ================================================================================================
312// Convenient type aliases for common test configurations
313// ================================================================================================
314// Note: All flavors include both relations (arithmetic + test).
315// Tests can choose which to activate via selectors (q_arith = 1 or q_test = 1).
316
322
328
334
341
347
348} // 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:62
typename Group::affine_element AffineElement
Definition grumpkin.hpp:63
Base class templates for structures that contain data parameterized by the fundamental polynomials of...
#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