22template <
typename Flavor>
23void put_translation_data_in_relation_parameters_impl(RelationParameters<typename Flavor::FF>& relation_parameters,
25 const typename Flavor::BF& batching_challenge_v,
27 requires(!Flavor::Curve::is_stdlib_type)
32 const auto compute_four_limbs = [](
const auto& in) {
33 constexpr size_t NUM_LIMB_BITS = Flavor::NUM_LIMB_BITS;
34 return std::array<FF, 4>{ in.slice(0, NUM_LIMB_BITS),
35 in.slice(NUM_LIMB_BITS, NUM_LIMB_BITS * 2),
36 in.slice(NUM_LIMB_BITS * 2, NUM_LIMB_BITS * 3),
37 in.slice(NUM_LIMB_BITS * 3, NUM_LIMB_BITS * 4) };
40 const auto compute_five_limbs = [](
const auto& in) {
41 constexpr size_t NUM_LIMB_BITS = Flavor::NUM_LIMB_BITS;
43 in.slice(NUM_LIMB_BITS, NUM_LIMB_BITS * 2),
44 in.slice(NUM_LIMB_BITS * 2, NUM_LIMB_BITS * 3),
45 in.slice(NUM_LIMB_BITS * 3, NUM_LIMB_BITS * 4),
49 relation_parameters.evaluation_input_x = compute_five_limbs(evaluation_input_x);
51 uint256_t batching_challenge_v_power{ batching_challenge_v };
52 for (
size_t i = 0; i < 4; i++) {
53 relation_parameters.batching_challenge_v[i] = compute_five_limbs(batching_challenge_v_power);
54 batching_challenge_v_power = BF(batching_challenge_v_power) * batching_challenge_v;
57 relation_parameters.accumulated_result = compute_four_limbs(accumulated_result);
61template <
typename Flavor>
62void put_translation_data_in_relation_parameters_impl(RelationParameters<typename Flavor::FF>& relation_parameters,
64 const typename Flavor::BF& batching_challenge_v,
66 requires(Flavor::Curve::is_stdlib_type)
71 const auto compute_four_limbs = [](
const BF& in) {
72 auto result = std::array<FF, 4>{
FF(in.binary_basis_limbs[0].element),
73 FF(in.binary_basis_limbs[1].element),
74 FF(in.binary_basis_limbs[2].element),
75 FF(in.binary_basis_limbs[3].element) };
77 for (
const auto& limb : result) {
83 const auto compute_five_limbs = [](
const BF& in) {
85 FF(in.binary_basis_limbs[1].element),
86 FF(in.binary_basis_limbs[2].element),
87 FF(in.binary_basis_limbs[3].element),
88 FF(in.prime_basis_limb) };
90 for (
const auto& limb : result) {
96 relation_parameters.evaluation_input_x = compute_five_limbs(evaluation_input_x);
98 BF batching_challenge_v_power = batching_challenge_v;
99 for (
size_t i = 0; i < 4; i++) {
100 relation_parameters.batching_challenge_v[i] = compute_five_limbs(batching_challenge_v_power);
101 batching_challenge_v_power = batching_challenge_v_power * batching_challenge_v;
104 relation_parameters.accumulated_result = compute_four_limbs(accumulated_result);
116 for (
auto& limb : relation_parameters.accumulated_result) {
117 limb.clear_round_provenance();
124 put_translation_data_in_relation_parameters_impl<Flavor>(
125 relation_parameters, evaluation_input_x, batching_challenge_v, accumulated_result);
133template <
typename Flavor>
136 using PCS =
typename Flavor::PCS;
139 using ClaimBatch =
typename ClaimBatcher::Batch;
142 transcript->load_proof(proof);
145 transcript->add_to_hash_buffer(
"vk_hash", vk_hash);
146 vinfo(
"Translator vk hash in verifier: ", vk_hash);
153 if constexpr (IsRecursive) {
154 mark_witness_as_used(accumulated_result.prime_basis_limb);
158 put_translation_data_in_relation_parameters();
161 commitments.gemini_masking_poly = transcript->template receive_from_prover<Commitment>(
"Gemini:masking_poly_comm");
164 commitments.op = op_queue_wire_commitments[0];
165 commitments.x_lo_y_hi = op_queue_wire_commitments[1];
166 commitments.x_hi_z_1 = op_queue_wire_commitments[2];
167 commitments.y_lo_z_2 = op_queue_wire_commitments[3];
170 for (
auto [comm, label] :
zip_view(commitments.get_non_opqueue_wires_and_ordered_range_constraints(),
171 commitment_labels.get_non_opqueue_wires_and_ordered_range_constraints())) {
172 comm = transcript->template receive_from_prover<Commitment>(label);
176 FF beta = transcript->template get_challenge<FF>(
"beta");
177 FF gamma = transcript->template get_challenge<FF>(
"gamma");
179 relation_parameters.beta = beta;
180 relation_parameters.gamma = gamma;
183 commitments.z_perm = transcript->template receive_from_prover<Commitment>(commitment_labels.z_perm);
187 const FF alpha = transcript->template get_challenge<FF>(
"Sumcheck:alpha");
193 for (
size_t idx = 0; idx < gate_challenges.size(); idx++) {
194 gate_challenges[idx] = transcript->template get_challenge<FF>(
"Sumcheck:gate_challenge_" +
std::to_string(idx));
199 libra_commitments[0] = transcript->template receive_from_prover<Commitment>(
"Libra:concatenation_commitment");
204 auto sumcheck_output = sumcheck.verify(relation_parameters, gate_challenges, padding_indicator_array);
206 libra_commitments[1] = transcript->template receive_from_prover<Commitment>(
"Libra:grand_sum_commitment");
207 libra_commitments[2] = transcript->template receive_from_prover<Commitment>(
"Libra:quotient_commitment");
211 auto& claimed = sumcheck_output.claimed_evaluations;
213 claimed.get_groups_to_be_concatenated_shifted(),
std::span<const FF>(sumcheck_output.challenge));
216 auto combined_unshifted_comms = commitments.get_pcs_unshifted();
217 auto combined_unshifted_evals = claimed.get_pcs_unshifted();
221 auto combined_shifted_comms = commitments.get_pcs_to_be_shifted();
222 RefVector<FF> combined_shifted_evals(claimed.get_pcs_shifted());
223 for (
auto& eval : concat_shift_evals) {
232 ClaimBatcher claim_batcher{ .unshifted = ClaimBatch{ combined_unshifted_comms, combined_unshifted_evals },
233 .shifted = ClaimBatch{ combined_shifted_comms, combined_shifted_evals } };
236 if constexpr (IsRecursive) {
237 commitment_one = Commitment::one(
builder);
239 commitment_one = Commitment::one();
242 auto [opening_claim, consistency_checked] =
243 Shplemini::compute_batch_opening_claim(padding_indicator_array,
245 sumcheck_output.challenge,
250 sumcheck_output.claimed_libra_evaluation);
252 auto pairing_points = PCS::reduce_verify_batch_opening_claim(
std::move(opening_claim), transcript);
254 vinfo(
"Translator Verifier: sumcheck verified: ", sumcheck_output.verified);
255 vinfo(
"Translator Verifier: consistency checked: ", consistency_checked);
257 return { pairing_points, sumcheck_output.verified && consistency_checked };
#define BB_ASSERT(expression,...)
#define BB_ASSERT_EQ(actual, expected,...)
bb::field< bb::Bn254FrParams > FF
typename Curve::ScalarField FF
typename Curve::BaseField BF
static constexpr RepeatedCommitmentsData REPEATED_COMMITMENTS
IPA (inner product argument) commitment scheme class.
A template class for a reference vector. Behaves as if std::vector<T&> was possible.
void push_back(T &element)
Implementation of the sumcheck Verifier for statements of the form for multilinear polynomials .
static constexpr size_t NUM_PCS_UNSHIFTED
static constexpr size_t CONST_TRANSLATOR_LOG_N
static std::array< FFType, NUM_CONCATENATED_POLYS > reconstruct_concatenated_evaluations(const std::vector< RefVector< FFType > > &groups, std::span< const FFType > challenge)
Reconstruct concatenated polynomial evaluations from individual wire evaluations using the Lagrange b...
static constexpr size_t NUM_PCS_TO_BE_SHIFTED
Translator verifier class that verifies the proof of the Translator circuit.
ReductionResult reduce_to_pairing_check()
Reduce the translator proof to a pairing check.
void put_translation_data_in_relation_parameters()
Populate relation parameters with translation data from ECCVM verifier.
typename Flavor::VerifierCommitments VerifierCommitments
typename Flavor::CommitmentLabels CommitmentLabels
typename Flavor::Commitment Commitment
Entry point for Barretenberg command-line interface.
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
std::string to_string(bb::avm2::ValueTag tag)
This file contains part of the logic for the Origin Tag mechanism that tracks the use of in-circuit p...
Logic to support batching opening claims for unshifted and shifted polynomials in Shplemini.
Result of reducing translator proof to pairing check.