25 receive_vk_hash_and_public_inputs();
27 verifier_instance->gemini_masking_commitment =
28 transcript->template receive_from_prover<Commitment>(
"Gemini:masking_poly_comm");
30 receive_wire_commitments();
31 receive_lookup_counts_and_w4_commitments();
32 receive_logderiv_commitments();
33 complete_grand_product_round();
36 verifier_instance->alpha = transcript->template get_challenge<FF>(
"alpha");
45 auto vk = verifier_instance->get_vk();
47 FF vk_hash =
vk->hash_with_origin_tagging(*transcript);
48 transcript->add_to_hash_buffer(
"vk_hash", vk_hash);
49 vinfo(
"vk hash in Oink verifier: ", vk_hash);
53 const bool is_write_vk_mode = vk_hash.get_context()->is_write_vk_mode();
54 const bool vk_hash_consistency = verifier_instance->vk_and_hash->hash.get_value() == vk_hash.get_value();
55 if (!vk_hash_consistency && !is_write_vk_mode) {
56 info(
"Recursive Ultra Verifier: VK Hash Mismatch");
58 verifier_instance->vk_and_hash->hash.assert_equal(vk_hash);
61 vk->num_public_inputs.assert_equal(
FF(num_public_inputs),
"OinkVerifier: num_public_inputs mismatch with VK");
63 BB_ASSERT_EQ(verifier_instance->vk_and_hash->hash, vk_hash,
"Native Ultra Verifier: VK Hash Mismatch");
66 static_cast<size_t>(
vk->num_public_inputs),
67 "OinkVerifier: num_public_inputs mismatch with VK");
70 std::vector<FF> public_inputs;
71 for (
size_t i = 0; i < num_public_inputs; ++i) {
72 auto public_input_i = transcript->template receive_from_prover<FF>(
"public_input_" +
std::to_string(i));
73 public_inputs.emplace_back(public_input_i);
75 verifier_instance->public_inputs =
std::move(public_inputs);
85 verifier_instance->witness_commitments.w_l = transcript->template receive_from_prover<Commitment>(comm_labels.w_l);
86 verifier_instance->witness_commitments.w_r = transcript->template receive_from_prover<Commitment>(comm_labels.w_r);
87 verifier_instance->witness_commitments.w_o = transcript->template receive_from_prover<Commitment>(comm_labels.w_o);
91 for (
auto [commitment, label] :
92 zip_view(verifier_instance->witness_commitments.get_ecc_op_wires(), comm_labels.get_ecc_op_wires())) {
93 commitment = transcript->template receive_from_prover<Commitment>(label);
97 for (
auto [commitment, label] :
zip_view(verifier_instance->witness_commitments.get_databus_entities(),
98 comm_labels.get_databus_entities())) {
99 commitment = transcript->template receive_from_prover<Commitment>(label);
111 verifier_instance->relation_parameters.compute_eta_powers(transcript->template get_challenge<FF>(
"eta"));
114 verifier_instance->witness_commitments.lookup_read_counts =
115 transcript->template receive_from_prover<Commitment>(comm_labels.lookup_read_counts);
116 verifier_instance->witness_commitments.lookup_read_tags =
117 transcript->template receive_from_prover<Commitment>(comm_labels.lookup_read_tags);
118 verifier_instance->witness_commitments.w_4 = transcript->template receive_from_prover<Commitment>(comm_labels.w_4);
127 verifier_instance->relation_parameters.compute_beta_powers(beta);
128 verifier_instance->relation_parameters.gamma = gamma;
130 verifier_instance->witness_commitments.lookup_inverses =
131 transcript->template receive_from_prover<Commitment>(comm_labels.lookup_inverses);
134 for (
auto [commitment, label] :
zip_view(verifier_instance->witness_commitments.get_databus_inverses(),
135 comm_labels.get_databus_inverses())) {
136 commitment = transcript->template receive_from_prover<Commitment>(label);
146 auto vk = verifier_instance->get_vk();
148 verifier_instance->relation_parameters.public_input_delta =
149 compute_public_input_delta<Flavor>(verifier_instance->public_inputs,
150 verifier_instance->relation_parameters.beta,
151 verifier_instance->relation_parameters.gamma,
152 vk->pub_inputs_offset);
154 verifier_instance->witness_commitments.z_perm =
155 transcript->template receive_from_prover<Commitment>(comm_labels.z_perm);
162#ifdef STARKNET_GARAGA_FLAVORS
#define BB_ASSERT_EQ(actual, expected,...)
bb::field< bb::Bn254FrParams > FF
static constexpr bool HasZK
Verifier counterpart to OinkProver: receives witness commitments, computes relation parameters,...
void receive_wire_commitments()
Receive wire commitments (w_l, w_r, w_o). For Mega, also receive ECC op wire and DataBus commitments....
void receive_logderiv_commitments()
Receive beta/gamma challenges and log-derivative inverse commitments (plus databus inverses for Mega)...
void receive_vk_hash_and_public_inputs()
Hash the verification key, assert consistency, and receive public inputs from the transcript.
void receive_lookup_counts_and_w4_commitments()
Get sorted witness-table accumulator and fourth wire commitments.
void complete_grand_product_round()
Compute public_input_delta for the permutation argument and receive z_perm commitment.
void verify(bool emit_alpha=true)
Receive witness commitments, compute relation parameters, and prepare for Sumcheck.
Entry point for Barretenberg command-line interface.
VerifierCommitmentKey< Curve > vk
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
std::string to_string(bb::avm2::ValueTag tag)