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 size_t TRACE_OFFSET = HasZK_ ? NUM_DISABLED_ROWS_IN_SUMCHECK : 0;
155 static constexpr bool USE_SHORT_MONOMIALS = UseShortMonomials_;
156 static constexpr bool USE_PADDING = false;
157 static constexpr size_t NUM_WIRES = 4;
158
159 // Entity counts:
160 // Precomputed: q_m, q_l, q_r, q_o, q_4, q_c, q_arith + q_test = 8
161 // Witness: w_l, w_r, w_o, w_4 + w_test_1, w_test_2 = 6
162 // Shifted: w_l_shift, w_4_shift = 2
163 // Note: No gemini_masking_poly - that's a PCS concept, not sumcheck
164 static constexpr size_t NUM_PRECOMPUTED_ENTITIES = 8;
165 static constexpr size_t NUM_WITNESS_ENTITIES = 6;
166 static constexpr size_t NUM_SHIFTED_ENTITIES = 2;
168
169 // Two relations: Arithmetic (linearly independent) + DependentTest (linearly dependent)
170 // Tests can activate either or both via selectors:
171 // - q_arith = 1 : activate arithmetic relation (linearly independent, WILL be scaled)
172 // - q_test = 1 : activate dependent test relation (linearly dependent, will NOT be scaled)
175
176 static constexpr size_t MAX_PARTIAL_RELATION_LENGTH = compute_max_partial_relation_length<Relations>();
177 // For ZK flavors, BATCHED_RELATION_PARTIAL_LENGTH is incremented by 1 for the libra masking univariates
178 // For BN254 with ZK, this must match Curve::LIBRA_UNIVARIATES_LENGTH (9)
179 // Note: MAX_PARTIAL_RELATION_LENGTH = 6 (from ArithmeticRelation's [6,5])
180 // Non-ZK: 6 + 1 = 7
181 // ZK: 6 + 3 = 9 (matches BN254::LIBRA_UNIVARIATES_LENGTH)
183 static constexpr size_t NUM_SUBRELATIONS = compute_number_of_subrelations<Relations>();
186
191 template <typename DataType> class PrecomputedEntities {
192 public:
193 DEFINE_FLAVOR_MEMBERS(DataType,
194 q_m, // Multiplication selector (arithmetic)
195 q_l, // Left wire selector (arithmetic)
196 q_r, // Right wire selector (arithmetic)
197 q_o, // Output wire selector (arithmetic)
198 q_4, // Fourth wire selector (arithmetic)
199 q_c, // Constant selector (arithmetic)
200 q_arith, // Arithmetic gate enable (linearly independent, WILL be scaled)
201 q_test) // Test relation enable (linearly dependent, will NOT be scaled)
202 };
203
208 template <typename DataType> class WitnessEntities {
209 public:
210 DEFINE_FLAVOR_MEMBERS(DataType,
211 w_l, // Left wire (arithmetic)
212 w_r, // Right wire (arithmetic)
213 w_o, // Output wire (arithmetic)
214 w_4, // Fourth wire (arithmetic)
215 w_test_1, // Test wire 1 (dependent test relation)
216 w_test_2) // Test wire 2 (dependent test relation, currently unused)
217 };
218
222 template <typename DataType> class ShiftedEntities {
223 public:
224 DEFINE_FLAVOR_MEMBERS(DataType,
225 w_l_shift, // w_l shifted by 1
226 w_4_shift) // w_4 shifted by 1
227 };
228
235 template <typename DataType>
248
252 class ProverPolynomials : public AllEntities<Polynomial> {
253 public:
254 ProverPolynomials() = default;
255 ProverPolynomials(size_t circuit_size)
256 {
257 for (auto& poly : this->get_precomputed()) {
258 poly = Polynomial(circuit_size);
259 }
260 for (auto& poly : this->get_witness()) {
261 poly = Polynomial(circuit_size);
262 }
263 for (auto& poly : this->get_shifted()) {
264 poly = Polynomial(circuit_size);
265 }
266 }
267
268 [[nodiscard]] size_t get_polynomial_size() const { return this->w_l.size(); }
269
274 auto get_to_be_shifted() { return RefArray{ this->w_l, this->w_4 }; }
275
281 {
282 for (auto [shifted, to_be_shifted] : zip_view(this->get_shifted(), this->get_to_be_shifted())) {
283 shifted = to_be_shifted.shifted();
284 }
285 }
286 };
287
292
297
301 class AllValues : public AllEntities<FF> {
302 public:
304 using Base::Base;
305 };
306
312};
313
314// ================================================================================================
315// Convenient type aliases for common test configurations
316// ================================================================================================
317// Note: All flavors include both relations (arithmetic + test).
318// Tests can choose which to activate via selectors (q_arith = 1 or q_test = 1).
319
325
331
337
344
350
351} // 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 TRACE_OFFSET
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:63
typename Group::affine_element AffineElement
Definition grumpkin.hpp:64
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