13 std::shared_ptr<MegaZKVK> mega_zk_vk,
14 std::shared_ptr<Transcript> transcript)
15 : mega_zk_inst(
std::move(mega_zk_instance))
16 , mega_zk_vk(
std::move(mega_zk_vk))
17 , transcript(
std::move(transcript))
29 oink_prover.
prove(
false);
68 const FF alpha =
transcript->template get_challenge<FF>(
"Sumcheck:alpha");
77 FF alpha_power_KH =
FF(1);
79 alpha_power_KH *= alpha;
89 const size_t mega_zk_log_n =
mega_zk_inst->log_dyadic_size();
113 auto& mega_zk_params =
mega_zk_inst->relation_parameters;
114 auto& translator_polys =
translator_key->proving_key->polynomials;
117 MegaZKPartialEvals mega_zk_partial(mega_zk_polys,
static_cast<size_t>(1) << mega_zk_log_n);
129 auto send_round = [&](
size_t round_idx) ->
FF {
139 auto update_round_state = [&](
size_t round_idx,
const FF& u) {
141 transcript->send_to_verifier(
"Sumcheck:minicircuit_evaluations",
153 auto do_round = [&](
auto& hpolys,
auto& tpolys,
size_t round_idx) ->
FF {
156 auto U_H = mega_zk_round.
compute_univariate(hpolys, mega_zk_params, mega_zk_gate_sep, mega_zk_alphas);
158 hpolys, mega_zk_params, mega_zk_gate_sep, mega_zk_alphas, round_idx, rdp);
163 for (
auto& eval : U_T.evaluations) {
164 eval *= alpha_power_KH;
168 return send_round(round_idx);
174 const FF u = do_round(mega_zk_polys, translator_polys, 0);
175 MegaZKSumcheck::partially_evaluate(mega_zk_polys, mega_zk_partial, u);
176 TransSumcheck::partially_evaluate(translator_polys, translator_partial, u);
179 update_round_state(0, u);
183 for (
size_t round_idx = 1; round_idx < mega_zk_log_n; round_idx++) {
184 const FF u = do_round(mega_zk_partial, translator_partial, round_idx);
185 MegaZKSumcheck::partially_evaluate_in_place(mega_zk_partial, u);
186 TransSumcheck::partially_evaluate_in_place(translator_partial, u);
189 update_round_state(round_idx, u);
209 for (
size_t round_idx = mega_zk_log_n; round_idx <
JOINT_LOG_N; round_idx++) {
213 mega_zk_partial, mega_zk_params, mega_zk_gate_sep, mega_zk_alphas);
219 for (
auto& eval : U_T.evaluations) {
220 eval *= alpha_power_KH;
224 const FF u = send_round(round_idx);
227 for (
auto& poly : mega_zk_partial.get_all()) {
228 if (poly.end_index() > 0) {
229 poly.at(0) *= (
FF(1) - u);
232 TransSumcheck::partially_evaluate_in_place(translator_partial, u);
233 update_round_state(round_idx, u);
240 transcript->send_to_verifier(
"Sumcheck:evaluations_translator",
271 small_subgroup_ipa.prove();
275 const size_t joint_circuit_size =
static_cast<size_t>(1) <<
JOINT_LOG_N;
276 const size_t mega_zk_max_end =
mega_zk_inst->polynomials.max_end_index();
277 const size_t trans_max_end =
translator_key->proving_key->circuit_size;
278 const size_t max_end_index =
std::max(mega_zk_max_end, trans_max_end);
280 PolynomialBatcher polynomial_batcher(joint_circuit_size, max_end_index);
283 auto mega_zk_unshifted =
mega_zk_inst->polynomials.get_unshifted();
284 auto trans_unshifted =
translator_key->proving_key->polynomials.get_pcs_unshifted();
285 auto joint_unshifted =
concatenate(mega_zk_unshifted, trans_unshifted);
286 polynomial_batcher.set_unshifted(joint_unshifted);
289 auto mega_zk_shifted =
mega_zk_inst->polynomials.get_to_be_shifted();
290 auto trans_shifted =
translator_key->proving_key->polynomials.get_pcs_to_be_shifted();
291 auto joint_shifted =
concatenate(mega_zk_shifted, trans_shifted);
292 polynomial_batcher.set_to_be_shifted_by_one(joint_shifted);
300 small_subgroup_ipa.get_witness_polynomials());
#define BB_ASSERT(expression,...)
std::shared_ptr< MegaZKProverInstance > mega_zk_inst
BatchedHonkTranslatorProver(std::shared_ptr< MegaZKProverInstance > mega_zk_instance, std::shared_ptr< MegaZKVK > mega_zk_vk, std::shared_ptr< Transcript > transcript)
MegaZKFlavor::AllValues mega_zk_claimed_evals
std::shared_ptr< TranslatorProvingKey > translator_key
static constexpr size_t JOINT_LOG_N
std::vector< FF > joint_challenge
void execute_joint_sumcheck_rounds()
Execute the joint 17-round sumcheck.
bb::RelationParameters< FF > translator_relation_parameters
TranslatorFlavor::AllValues trans_claimed_evals
std::shared_ptr< Transcript > transcript
void execute_joint_pcs()
Execute the joint Shplemini / KZG PCS over both circuits' polynomials.
std::array< FF, MegaZKFlavor::NUM_SUBRELATIONS - 1 > MegaZKSubrelationSeparators
HonkProof prove(std::shared_ptr< TranslatorProvingKey > translator_proving_key)
FF claimed_libra_evaluation
std::array< FF, TranslatorFlavor::NUM_SUBRELATIONS - 1 > TransSubrelationSeparators
void execute_mega_zk_oink()
Run the MegaZK circuit's Oink phase.
std::shared_ptr< MegaZKVK > mega_zk_vk
void execute_translator_oink()
Run the translator's Oink phase on the shared transcript.
HonkProof prove_mega_zk_oink()
ZKSumcheckData< MegaZKFlavor > ZKData
CommitmentKey object over a pairing group 𝔾₁.
Class responsible for computation of the batched multilinear polynomials required by the Gemini proto...
static void compute_opening_proof(const CK &ck, const ProverOpeningClaim< Curve > &opening_claim, const std::shared_ptr< Transcript > &prover_trancript)
Computes the KZG commitment to an opening proof polynomial at a single evaluation point.
static constexpr size_t NUM_SUBRELATIONS
Executes the "Oink" phase of the Honk proving protocol: the initial rounds that commit to witness dat...
void prove(bool emit_alpha=true)
Commit to witnesses, compute relation parameters, and prepare for Sumcheck.
Unverified claim (C,r,v) for some witness polynomial p(X) such that.
A container for storing the partially evaluated multivariates produced by sumcheck.
Polynomial p and an opening pair (r,v) such that p(r) = v.
static OpeningClaim prove(size_t circuit_size, PolynomialBatcher &polynomial_batcher, std::span< FF > multilinear_challenge, const CommitmentKey< Curve > &commitment_key, const std::shared_ptr< Transcript > &transcript, const std::array< Polynomial, NUM_SMALL_IPA_EVALUATIONS > &libra_polynomials={}, const std::vector< Polynomial > &sumcheck_round_univariates={}, const std::vector< std::array< FF, 3 > > &sumcheck_round_evaluations={})
A Curve-agnostic ZK protocol to prove inner products of small vectors.
Flavor::CommitmentKey commitment_key
The implementation of the sumcheck Prover for statements of the form for multilinear polynomials .
Imlementation of the Sumcheck prover round.
SumcheckRoundUnivariate compute_virtual_contribution(ProverPolynomialsOrPartiallyEvaluatedMultivariates &polynomials, const bb::RelationParameters< FF > &relation_parameters, const GateSeparatorPolynomial< FF > &gate_separator, const SubrelationSeparators &alphas)
SumcheckRoundUnivariate compute_disabled_contribution(ProverPolynomialsOrPartiallyEvaluatedMultivariates &polynomials, const bb::RelationParameters< FF > &relation_parameters, const bb::GateSeparatorPolynomial< FF > &gate_separators, const SubrelationSeparators &alphas, const size_t round_idx, const RowDisablingPolynomial< FF > row_disabling_polynomial)
For ZK Flavors: A method disabling the last 4 rows of the ProverPolynomials.
SumcheckRoundUnivariate compute_univariate(ProverPolynomialsOrPartiallyEvaluatedMultivariates &polynomials, const bb::RelationParameters< FF > &relation_parameters, const bb::GateSeparatorPolynomial< FF > &gate_separators, const SubrelationSeparators &alphas)
Return the evaluations of the univariate round polynomials. Toggles between chunked computation (desi...
static SumcheckRoundUnivariate compute_libra_univariate(const ZKData &zk_sumcheck_data, size_t round_idx)
Compute Libra round univariate expressed given by the formula.
size_t round_size
In Round , equals .
static std::array< FFType, NUM_FULL_CIRCUIT_EVALUATIONS > get_full_circuit_evaluations(AllEntities< FFType > &evals)
Prover: extract the full-circuit evaluations via get_full_circuit_entities().
static constexpr size_t LOG_MINI_CIRCUIT_SIZE
static constexpr size_t NUM_SUBRELATIONS
static std::array< FF, NUM_MINICIRCUIT_EVALUATIONS > get_minicircuit_evaluations(PolyContainer &polys)
Prover: read the 154 minicircuit wire evaluations from partially-evaluated polynomials.
BB_PROFILE void execute_preamble_round()
Add circuit size and values used in the relations to the transcript.
BB_PROFILE void execute_grand_product_computation_round()
Compute permutation product polynomial and commitments.
bb::RelationParameters< FF > relation_parameters
BB_PROFILE void execute_wire_and_sorted_constraints_commitments_round()
Compute commitments to wires and ordered range constraints.
A univariate polynomial represented by its values on {0, 1,..., domain_end - 1}.
static constexpr size_t SUBGROUP_SIZE
constexpr T get_msb(const T in)
Entry point for Barretenberg command-line interface.
std::vector< fr > HonkProof
RefArray< T,(Ns+...)> constexpr concatenate(const RefArray< T, Ns > &... ref_arrays)
Concatenates multiple RefArray objects into a single RefArray.
CommitmentKey< Curve > ck
std::array< FF, N > initialize_relation_separator(const FF &alpha)
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
std::string to_string(bb::avm2::ValueTag tag)
Implementation of the methods for the -polynomials used in in Sumcheck.
void partially_evaluate(FF challenge)
Partially evaluate the -polynomial at the new challenge and update .
Polynomial for Sumcheck with disabled Rows.
void update_evaluations(FF round_challenge, size_t round_idx)
Compute the evaluations of L^{(i)} at 0 and 1.
ClaimedLibraEvaluations libra_evaluations
void update_zk_sumcheck_data(const FF &round_challenge, const size_t round_idx)
Upon receiving the challenge , the prover updates Libra data. If .