12#include <gtest/gtest.h>
39 size_t frs_per_Fq = FrCodec::calc_num_fields<FF>();
40 size_t frs_per_Fr = FrCodec::calc_num_fields<Flavor::BF>();
41 size_t frs_per_G = FrCodec::calc_num_fields<typename Flavor::Commitment>();
45 manifest_expected.
add_entry(round,
"vk_hash", frs_per_Fr);
46 manifest_expected.
add_entry(round,
"Gemini:masking_poly_comm", frs_per_G);
47 manifest_expected.
add_entry(round,
"TRANSCRIPT_ADD", frs_per_G);
48 manifest_expected.
add_entry(round,
"TRANSCRIPT_EQ", frs_per_G);
49 manifest_expected.
add_entry(round,
"TRANSCRIPT_MSM_TRANSITION", frs_per_G);
50 manifest_expected.
add_entry(round,
"TRANSCRIPT_PX", frs_per_G);
51 manifest_expected.
add_entry(round,
"TRANSCRIPT_PY", frs_per_G);
52 manifest_expected.
add_entry(round,
"TRANSCRIPT_Z1", frs_per_G);
53 manifest_expected.
add_entry(round,
"TRANSCRIPT_Z2", frs_per_G);
54 manifest_expected.
add_entry(round,
"TRANSCRIPT_Z1ZERO", frs_per_G);
55 manifest_expected.
add_entry(round,
"TRANSCRIPT_Z2ZERO", frs_per_G);
56 manifest_expected.
add_entry(round,
"TRANSCRIPT_OP", frs_per_G);
57 manifest_expected.
add_entry(round,
"TRANSCRIPT_MSM_X", frs_per_G);
58 manifest_expected.
add_entry(round,
"TRANSCRIPT_MSM_Y", frs_per_G);
59 manifest_expected.
add_entry(round,
"PRECOMPUTE_POINT_TRANSITION", frs_per_G);
60 manifest_expected.
add_entry(round,
"PRECOMPUTE_S1LO", frs_per_G);
61 manifest_expected.
add_entry(round,
"PRECOMPUTE_S2HI", frs_per_G);
62 manifest_expected.
add_entry(round,
"PRECOMPUTE_S2LO", frs_per_G);
63 manifest_expected.
add_entry(round,
"PRECOMPUTE_S3HI", frs_per_G);
64 manifest_expected.
add_entry(round,
"PRECOMPUTE_S3LO", frs_per_G);
65 manifest_expected.
add_entry(round,
"PRECOMPUTE_S4HI", frs_per_G);
66 manifest_expected.
add_entry(round,
"PRECOMPUTE_S4LO", frs_per_G);
67 manifest_expected.
add_entry(round,
"PRECOMPUTE_SKEW", frs_per_G);
68 manifest_expected.
add_entry(round,
"MSM_SIZE_OF_MSM", frs_per_G);
69 manifest_expected.
add_entry(round,
"MSM_ADD2", frs_per_G);
70 manifest_expected.
add_entry(round,
"MSM_ADD3", frs_per_G);
71 manifest_expected.
add_entry(round,
"MSM_ADD4", frs_per_G);
72 manifest_expected.
add_entry(round,
"MSM_X1", frs_per_G);
73 manifest_expected.
add_entry(round,
"MSM_Y1", frs_per_G);
74 manifest_expected.
add_entry(round,
"MSM_X2", frs_per_G);
75 manifest_expected.
add_entry(round,
"MSM_Y2", frs_per_G);
76 manifest_expected.
add_entry(round,
"MSM_X3", frs_per_G);
77 manifest_expected.
add_entry(round,
"MSM_Y3", frs_per_G);
78 manifest_expected.
add_entry(round,
"MSM_X4", frs_per_G);
79 manifest_expected.
add_entry(round,
"MSM_Y4", frs_per_G);
80 manifest_expected.
add_entry(round,
"MSM_COLLISION_X1", frs_per_G);
81 manifest_expected.
add_entry(round,
"MSM_COLLISION_X2", frs_per_G);
82 manifest_expected.
add_entry(round,
"MSM_COLLISION_X3", frs_per_G);
83 manifest_expected.
add_entry(round,
"MSM_COLLISION_X4", frs_per_G);
84 manifest_expected.
add_entry(round,
"MSM_LAMBDA1", frs_per_G);
85 manifest_expected.
add_entry(round,
"MSM_LAMBDA2", frs_per_G);
86 manifest_expected.
add_entry(round,
"MSM_LAMBDA3", frs_per_G);
87 manifest_expected.
add_entry(round,
"MSM_LAMBDA4", frs_per_G);
88 manifest_expected.
add_entry(round,
"MSM_SLICE1", frs_per_G);
89 manifest_expected.
add_entry(round,
"MSM_SLICE2", frs_per_G);
90 manifest_expected.
add_entry(round,
"MSM_SLICE3", frs_per_G);
91 manifest_expected.
add_entry(round,
"MSM_SLICE4", frs_per_G);
92 manifest_expected.
add_entry(round,
"TRANSCRIPT_RESET_ACCUMULATOR", frs_per_G);
93 manifest_expected.
add_entry(round,
"LOOKUP_READ_COUNTS_0", frs_per_G);
94 manifest_expected.
add_entry(round,
"LOOKUP_READ_COUNTS_1", frs_per_G);
95 manifest_expected.
add_entry(round,
"TRANSCRIPT_BASE_INFINITY", frs_per_G);
96 manifest_expected.
add_entry(round,
"TRANSCRIPT_BASE_X_INVERSE", frs_per_G);
97 manifest_expected.
add_entry(round,
"TRANSCRIPT_BASE_Y_INVERSE", frs_per_G);
98 manifest_expected.
add_entry(round,
"TRANSCRIPT_ADD_X_EQUAL", frs_per_G);
99 manifest_expected.
add_entry(round,
"TRANSCRIPT_ADD_Y_EQUAL", frs_per_G);
100 manifest_expected.
add_entry(round,
"TRANSCRIPT_ADD_LAMBDA", frs_per_G);
101 manifest_expected.
add_entry(round,
"TRANSCRIPT_MSM_INTERMEDIATE_X", frs_per_G);
102 manifest_expected.
add_entry(round,
"TRANSCRIPT_MSM_INTERMEDIATE_Y", frs_per_G);
103 manifest_expected.
add_entry(round,
"TRANSCRIPT_MSM_INFINITY", frs_per_G);
104 manifest_expected.
add_entry(round,
"TRANSCRIPT_MSM_X_INVERSE", frs_per_G);
105 manifest_expected.
add_entry(round,
"TRANSCRIPT_MSM_COUNT_ZERO_AT_TRANSITION", frs_per_G);
106 manifest_expected.
add_entry(round,
"TRANSCRIPT_MSM_COUNT_AT_TRANSITION_INVERSE", frs_per_G);
107 manifest_expected.
add_entry(round,
"TRANSCRIPT_MUL", frs_per_G);
108 manifest_expected.
add_entry(round,
"TRANSCRIPT_MSM_COUNT", frs_per_G);
109 manifest_expected.
add_entry(round,
"PRECOMPUTE_SCALAR_SUM", frs_per_G);
110 manifest_expected.
add_entry(round,
"PRECOMPUTE_S1HI", frs_per_G);
111 manifest_expected.
add_entry(round,
"PRECOMPUTE_DX", frs_per_G);
112 manifest_expected.
add_entry(round,
"PRECOMPUTE_DY", frs_per_G);
113 manifest_expected.
add_entry(round,
"PRECOMPUTE_TX", frs_per_G);
114 manifest_expected.
add_entry(round,
"PRECOMPUTE_TY", frs_per_G);
115 manifest_expected.
add_entry(round,
"MSM_TRANSITION", frs_per_G);
116 manifest_expected.
add_entry(round,
"MSM_ADD", frs_per_G);
117 manifest_expected.
add_entry(round,
"MSM_DOUBLE", frs_per_G);
118 manifest_expected.
add_entry(round,
"MSM_SKEW", frs_per_G);
119 manifest_expected.
add_entry(round,
"MSM_ACCUMULATOR_X", frs_per_G);
120 manifest_expected.
add_entry(round,
"MSM_ACCUMULATOR_Y", frs_per_G);
121 manifest_expected.
add_entry(round,
"MSM_COUNT", frs_per_G);
122 manifest_expected.
add_entry(round,
"MSM_ROUND", frs_per_G);
123 manifest_expected.
add_entry(round,
"MSM_ADD1", frs_per_G);
124 manifest_expected.
add_entry(round,
"MSM_PC", frs_per_G);
125 manifest_expected.
add_entry(round,
"PRECOMPUTE_PC", frs_per_G);
126 manifest_expected.
add_entry(round,
"TRANSCRIPT_PC", frs_per_G);
127 manifest_expected.
add_entry(round,
"PRECOMPUTE_ROUND", frs_per_G);
128 manifest_expected.
add_entry(round,
"PRECOMPUTE_SELECT", frs_per_G);
129 manifest_expected.
add_entry(round,
"TRANSCRIPT_ACCUMULATOR_NOT_EMPTY", frs_per_G);
130 manifest_expected.
add_entry(round,
"TRANSCRIPT_ACCUMULATOR_X", frs_per_G);
131 manifest_expected.
add_entry(round,
"TRANSCRIPT_ACCUMULATOR_Y", frs_per_G);
132 manifest_expected.
add_challenge(round, std::array{
"beta",
"gamma" });
135 manifest_expected.
add_entry(round,
"LOOKUP_INVERSES", frs_per_G);
136 manifest_expected.
add_entry(round,
"Z_PERM", frs_per_G);
139 for (
size_t i = 0; i < CONST_ECCVM_LOG_N; i++) {
141 std::string label =
"Sumcheck:gate_challenge_" +
std::to_string(i);
146 manifest_expected.
add_entry(round,
"Libra:concatenation_commitment", frs_per_G);
147 manifest_expected.
add_entry(round,
"Libra:Sum", frs_per_Fq);
151 for (
size_t i = 0; i < CONST_ECCVM_LOG_N; ++i) {
154 manifest_expected.
add_entry(round,
"Sumcheck:univariate_comm_" + idx, frs_per_G);
155 manifest_expected.
add_entry(round,
"Sumcheck:univariate_" + idx +
"_eval_0", frs_per_Fq);
156 manifest_expected.
add_entry(round,
"Sumcheck:univariate_" + idx +
"_eval_1", frs_per_Fq);
157 std::string label =
"Sumcheck:u_" + idx;
163 manifest_expected.
add_entry(round,
"Sumcheck:evaluations", frs_per_evals);
164 manifest_expected.
add_entry(round,
"Libra:claimed_evaluation", frs_per_Fq);
165 manifest_expected.
add_entry(round,
"Libra:grand_sum_commitment", frs_per_G);
166 manifest_expected.
add_entry(round,
"Libra:quotient_commitment", frs_per_G);
171 for (
size_t i = 1; i < CONST_ECCVM_LOG_N; ++i) {
173 manifest_expected.
add_entry(round,
"Gemini:FOLD_" + idx, frs_per_G);
177 for (
size_t i = 1; i <= CONST_ECCVM_LOG_N; ++i) {
179 manifest_expected.
add_entry(round,
"Gemini:a_" + idx, frs_per_Fq);
181 manifest_expected.
add_entry(round,
"Libra:concatenation_eval", frs_per_Fq);
182 manifest_expected.
add_entry(round,
"Libra:shifted_grand_sum_eval", frs_per_Fq);
183 manifest_expected.
add_entry(round,
"Libra:grand_sum_eval", frs_per_Fq);
184 manifest_expected.
add_entry(round,
"Libra:quotient_eval", frs_per_Fq);
187 manifest_expected.
add_entry(round,
"Shplonk:Q", frs_per_G);
191 manifest_expected.
add_entry(round,
"Translation:concatenated_masking_term_commitment", frs_per_G);
192 manifest_expected.
add_challenge(round,
"Translation:evaluation_challenge_x");
195 manifest_expected.
add_entry(round,
"Translation:op", frs_per_Fq);
196 manifest_expected.
add_entry(round,
"Translation:Px", frs_per_Fq);
197 manifest_expected.
add_entry(round,
"Translation:Py", frs_per_Fq);
198 manifest_expected.
add_entry(round,
"Translation:z1", frs_per_Fq);
199 manifest_expected.
add_entry(round,
"Translation:z2", frs_per_Fq);
200 manifest_expected.
add_challenge(round,
"Translation:batching_challenge_v");
203 manifest_expected.
add_entry(round,
"Translation:masking_term_eval", frs_per_Fq);
204 manifest_expected.
add_entry(round,
"Translation:grand_sum_commitment", frs_per_G);
205 manifest_expected.
add_entry(round,
"Translation:quotient_commitment", frs_per_G);
206 manifest_expected.
add_challenge(round,
"Translation:small_ipa_evaluation_challenge");
209 manifest_expected.
add_entry(round,
"Translation:concatenation_eval", frs_per_Fq);
210 manifest_expected.
add_entry(round,
"Translation:grand_sum_shift_eval", frs_per_Fq);
211 manifest_expected.
add_entry(round,
"Translation:grand_sum_eval", frs_per_Fq);
212 manifest_expected.
add_entry(round,
"Translation:quotient_eval", frs_per_Fq);
216 manifest_expected.
add_entry(round,
"Shplonk:Q", frs_per_G);
219 return manifest_expected;
226 size_t frs_per_Fq = FrCodec::calc_num_fields<FF>();
227 size_t frs_per_G = FrCodec::calc_num_fields<Flavor::Commitment>();
230 manifest_expected.
add_entry(round,
"IPA:commitment", frs_per_G);
231 manifest_expected.
add_entry(round,
"IPA:challenge", frs_per_Fq);
232 manifest_expected.
add_entry(round,
"IPA:evaluation", frs_per_Fq);
233 manifest_expected.
add_challenge(round,
"IPA:generator_challenge");
235 for (
size_t i = 0; i < CONST_ECCVM_LOG_N; ++i) {
238 manifest_expected.
add_entry(round,
"IPA:L_" + idx, frs_per_G);
239 manifest_expected.
add_entry(round,
"IPA:R_" + idx, frs_per_G);
240 std::string label =
"IPA:round_challenge_" + idx;
245 manifest_expected.
add_entry(round,
"IPA:G_0", frs_per_G);
246 manifest_expected.
add_entry(round,
"IPA:a_0", frs_per_Fq);
247 return manifest_expected;
254 using Fr =
typename G1::Fr;
256 auto generators = G1::derive_generators(
"test generators", 3);
258 typename G1::element
a = generators[0];
259 typename G1::element
b = generators[1];
260 typename G1::element c = generators[2];
264 op_queue->add_accumulate(
a);
265 op_queue->mul_accumulate(
a, x);
266 op_queue->mul_accumulate(
b, x);
267 op_queue->mul_accumulate(
b, y);
268 op_queue->add_accumulate(
a);
269 op_queue->mul_accumulate(
b, x);
270 op_queue->eq_and_reset();
271 op_queue->add_accumulate(c);
272 op_queue->mul_accumulate(
a, x);
273 op_queue->mul_accumulate(
b, x);
274 op_queue->eq_and_reset();
275 op_queue->mul_accumulate(
a, x);
276 op_queue->mul_accumulate(
b, x);
277 op_queue->mul_accumulate(c, x);
279 add_hiding_op_for_test(op_queue);
305 ipa_transcript->enable_manifest();
306 PCS::compute_opening_proof(prover.
key->commitment_key, opening_claim, ipa_transcript);
309 auto manifest_expected = this->construct_eccvm_honk_manifest();
310 auto prover_manifest = prover.
transcript->get_manifest();
313 ASSERT_GT(manifest_expected.size(), 0);
314 for (
size_t round = 0; round < manifest_expected.size(); ++round) {
315 ASSERT_EQ(prover_manifest[round], manifest_expected[round]) <<
"Prover manifest discrepency in round " << round;
318 auto ipa_manifest_expected = this->construct_eccvm_ipa_manifest();
319 auto prover_ipa_manifest = ipa_transcript->get_manifest();
322 ASSERT_GT(ipa_manifest_expected.size(), 0);
323 for (
size_t round = 0; round < ipa_manifest_expected.size(); ++round) {
324 ASSERT_EQ(prover_ipa_manifest[round], ipa_manifest_expected[round])
325 <<
"IPA prover manifest discrepency in round " << round;
342 prover_transcript->enable_manifest();
347 prover_ipa_transcript->enable_manifest();
348 PCS::compute_opening_proof(prover.
key->commitment_key, opening_claim, prover_ipa_transcript);
352 verifier_transcript->enable_manifest();
358 verifier_ipa_transcript->enable_manifest();
363 auto prover_manifest = prover.
transcript->get_manifest();
364 auto verifier_manifest = verifier.
get_transcript()->get_manifest();
370 ASSERT_GT(prover_manifest.size(), 0);
371 for (
size_t round = 0; round < prover_manifest.size() - 1; ++round) {
372 ASSERT_EQ(prover_manifest[round], verifier_manifest[round])
373 <<
"Prover/Verifier manifest discrepency in round " << round;
377 auto prover_ipa_manifest = prover_ipa_transcript->get_manifest();
378 auto verifier_ipa_manifest = verifier_ipa_transcript->get_manifest();
379 ASSERT_GT(prover_ipa_manifest.size(), 0);
380 for (
size_t round = 0; round < prover_ipa_manifest.size(); ++round) {
381 ASSERT_EQ(prover_ipa_manifest[round], verifier_ipa_manifest[round])
382 <<
"Prover/Verifier IPA manifest discrepency in round " << round;
394 auto transcript = Flavor::Transcript::prover_init_empty();
396 std::vector<std::string> challenge_labels{
"a",
"b",
"c",
"d",
"e",
"f" };
397 auto challenges = transcript->template get_challenges<FF>(challenge_labels);
399 for (
size_t i = 0; i < challenges.size(); ++i) {
400 ASSERT_NE(challenges[i], 0) <<
"Challenge " << i <<
" is 0";
402 constexpr uint32_t random_val{ 17 };
403 transcript->send_to_verifier(
"random val", random_val);
405 challenge_labels = {
"a",
"b",
"c" };
406 challenges = transcript->template get_challenges<FF>(challenge_labels);
408 ASSERT_NE(challenges[0], 0) <<
"Challenge a is 0";
409 ASSERT_NE(challenges[1], 0) <<
"Challenge b is 0";
410 ASSERT_NE(challenges[2], 0) <<
"Challenge c is 0";
ECCVMCircuitBuilder generate_trace(numeric::RNG *engine=nullptr)
TranscriptManifest construct_eccvm_honk_manifest()
Construct a manifest for a ECCVM Honk proof.
TranscriptManifest construct_eccvm_ipa_manifest()
Common transcript class for both parties. Stores the data for the current round, as well as the manif...
static constexpr size_t ECCVM_FIXED_SIZE
static constexpr size_t NUM_ALL_ENTITIES
BaseTranscript< Codec, HashFunction > Transcript
std::shared_ptr< Transcript > transcript
std::pair< Proof, OpeningClaim > construct_proof()
std::shared_ptr< ProvingKey > key
Unified ECCVM verifier class for both native and recursive verification.
std::shared_ptr< Transcript > get_transcript() const
ReductionResult reduce_to_ipa_opening()
Reduce the ECCVM proof to an IPA opening claim.
IPA (inner product argument) commitment scheme class.
void add_entry(size_t round, const std::string &element_label, size_t element_size)
void add_challenge(size_t round, const std::string &label)
Add a single challenge label to the manifest for the given round.
Representation of the Grumpkin Verifier Commitment Key inside a bn254 circuit.
Base class templates for structures that contain data parameterized by the fundamental polynomials of...
void add_hiding_op_for_test(const std::shared_ptr< ECCOpQueue > &op_queue)
Set a hiding op on the op_queue for testing.
RNG & get_debug_randomness(bool reset, std::uint_fast64_t seed)
std::filesystem::path bb_crs_path()
void init_file_crs_factory(const std::filesystem::path &path)
Entry point for Barretenberg command-line interface.
TEST_F(IPATest, ChallengesAreZero)
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
std::string to_string(bb::avm2::ValueTag tag)
static field random_element(numeric::RNG *engine=nullptr) noexcept