46 constexpr size_t element_size = Codec::template calc_num_fields<T>();
48 auto element_span = std::span{ proof_data }.subspan(
offset, element_size);
50 return Codec::template deserialize_from_fields<T>(element_span);
55 auto element_fields = Codec::serialize_to_fields(element);
56 proof_data.insert(proof_data.end(), element_fields.begin(), element_fields.end());
100 w_l_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
101 w_r_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
102 w_o_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
105 w_4_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
107 z_perm_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
126 for (
size_t i = 0; i < log_n; ++i) {
132 this->
template deserialize_from_buffer<std::array<FF, NUM_ALL_ENTITIES>>(proof_data,
offset);
138 for (
size_t i = 0; i < log_n; ++i) {
147 for (
size_t i = 0; i < log_n - 1; ++i) {
150 for (
size_t i = 0; i < log_n; ++i) {
154 kzg_w_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
160 for (
size_t i = 0; i < log_n - 1; ++i) {
163 for (
size_t i = 0; i < log_n; ++i) {
176 for (
size_t i = 0; i < num_public_inputs; ++i) {
186 size_t old_size = proof_data.size();
224 this->clear_vectors();
226 for (
size_t i = 0; i < num_public_inputs; ++i) {
227 this->public_inputs.push_back(this->
template deserialize_from_buffer<FF>(proof_data,
offset));
229 hiding_polynomial_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
230 this->deserialize_ultra_witness_comms(proof_data,
offset);
231 libra_concatenation_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
232 libra_sum = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
235 for (
size_t i = 0; i < log_n; ++i) {
236 this->sumcheck_univariates.push_back(
240 libra_claimed_evaluation = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
241 this->sumcheck_evaluations =
242 this->
template deserialize_from_buffer<std::array<FF, Base::NUM_ALL_ENTITIES>>(proof_data,
offset);
243 libra_grand_sum_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
244 libra_quotient_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
247 for (
size_t i = 0; i < log_n - 1; ++i) {
248 this->gemini_fold_comms.push_back(this->
template deserialize_from_buffer<Commitment>(proof_data,
offset));
250 for (
size_t i = 0; i < log_n; ++i) {
251 this->gemini_fold_evals.push_back(this->
template deserialize_from_buffer<FF>(proof_data,
offset));
253 libra_concatenation_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
254 libra_shifted_grand_sum_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
255 libra_grand_sum_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
256 libra_quotient_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
257 this->shplonk_q_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
258 this->kzg_w_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
263 size_t old_size = proof_data.size();
266 for (
const auto& pi : this->public_inputs) {
267 Base::serialize_to_buffer(pi, proof_data);
269 Base::serialize_to_buffer(hiding_polynomial_commitment, proof_data);
270 this->serialize_ultra_witness_comms(proof_data);
271 Base::serialize_to_buffer(libra_concatenation_commitment, proof_data);
272 Base::serialize_to_buffer(libra_sum, proof_data);
275 for (
size_t i = 0; i < log_n; ++i) {
276 Base::serialize_to_buffer(this->sumcheck_univariates[i], proof_data);
278 Base::serialize_to_buffer(libra_claimed_evaluation, proof_data);
279 Base::serialize_to_buffer(this->sumcheck_evaluations, proof_data);
280 Base::serialize_to_buffer(libra_grand_sum_commitment, proof_data);
281 Base::serialize_to_buffer(libra_quotient_commitment, proof_data);
284 for (
size_t i = 0; i < log_n - 1; ++i) {
285 Base::serialize_to_buffer(this->gemini_fold_comms[i], proof_data);
287 for (
size_t i = 0; i < log_n; ++i) {
288 Base::serialize_to_buffer(this->gemini_fold_evals[i], proof_data);
290 Base::serialize_to_buffer(libra_concatenation_eval, proof_data);
291 Base::serialize_to_buffer(libra_shifted_grand_sum_eval, proof_data);
292 Base::serialize_to_buffer(libra_grand_sum_eval, proof_data);
293 Base::serialize_to_buffer(libra_quotient_eval, proof_data);
294 Base::serialize_to_buffer(this->shplonk_q_comm, proof_data);
295 Base::serialize_to_buffer(this->kzg_w_comm, proof_data);
306 using Base::BATCHED_RELATION_PARTIAL_LENGTH;
307 using Base::NUM_ALL_ENTITIES;
351 public_inputs.clear();
352 sumcheck_univariates.clear();
353 gemini_fold_comms.clear();
354 gemini_fold_evals.clear();
360 w_l_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
361 w_r_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
362 w_o_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
363 ecc_op_wire_1_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
364 ecc_op_wire_2_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
365 ecc_op_wire_3_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
366 ecc_op_wire_4_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
367 kernel_calldata_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
368 kernel_calldata_read_counts_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
369 first_app_calldata_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
370 first_app_calldata_read_counts_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
371 second_app_calldata_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
372 second_app_calldata_read_counts_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
373 third_app_calldata_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
374 third_app_calldata_read_counts_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
375 return_data_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
376 return_data_read_counts_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
377 lookup_read_counts_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
378 lookup_read_tags_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
379 w_4_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
380 lookup_inverses_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
381 kernel_calldata_inverses_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
382 first_app_calldata_inverses_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
383 second_app_calldata_inverses_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
384 third_app_calldata_inverses_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
385 return_data_inverses_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
386 z_perm_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
392 Base::serialize_to_buffer(w_l_comm, proof_data);
393 Base::serialize_to_buffer(w_r_comm, proof_data);
394 Base::serialize_to_buffer(w_o_comm, proof_data);
395 Base::serialize_to_buffer(ecc_op_wire_1_comm, proof_data);
396 Base::serialize_to_buffer(ecc_op_wire_2_comm, proof_data);
397 Base::serialize_to_buffer(ecc_op_wire_3_comm, proof_data);
398 Base::serialize_to_buffer(ecc_op_wire_4_comm, proof_data);
399 Base::serialize_to_buffer(kernel_calldata_comm, proof_data);
400 Base::serialize_to_buffer(kernel_calldata_read_counts_comm, proof_data);
401 Base::serialize_to_buffer(first_app_calldata_comm, proof_data);
402 Base::serialize_to_buffer(first_app_calldata_read_counts_comm, proof_data);
403 Base::serialize_to_buffer(second_app_calldata_comm, proof_data);
404 Base::serialize_to_buffer(second_app_calldata_read_counts_comm, proof_data);
405 Base::serialize_to_buffer(third_app_calldata_comm, proof_data);
406 Base::serialize_to_buffer(third_app_calldata_read_counts_comm, proof_data);
407 Base::serialize_to_buffer(return_data_comm, proof_data);
408 Base::serialize_to_buffer(return_data_read_counts_comm, proof_data);
409 Base::serialize_to_buffer(lookup_read_counts_comm, proof_data);
410 Base::serialize_to_buffer(lookup_read_tags_comm, proof_data);
411 Base::serialize_to_buffer(w_4_comm, proof_data);
412 Base::serialize_to_buffer(lookup_inverses_comm, proof_data);
413 Base::serialize_to_buffer(kernel_calldata_inverses_comm, proof_data);
414 Base::serialize_to_buffer(first_app_calldata_inverses_comm, proof_data);
415 Base::serialize_to_buffer(second_app_calldata_inverses_comm, proof_data);
416 Base::serialize_to_buffer(third_app_calldata_inverses_comm, proof_data);
417 Base::serialize_to_buffer(return_data_inverses_comm, proof_data);
418 Base::serialize_to_buffer(z_perm_comm, proof_data);
424 for (
size_t i = 0; i < log_n; ++i) {
425 sumcheck_univariates.push_back(
429 sumcheck_evaluations =
430 this->
template deserialize_from_buffer<std::array<FF, NUM_ALL_ENTITIES>>(proof_data,
offset);
436 for (
size_t i = 0; i < log_n; ++i) {
437 Base::serialize_to_buffer(sumcheck_univariates[i], proof_data);
439 Base::serialize_to_buffer(sumcheck_evaluations, proof_data);
445 for (
size_t i = 0; i < log_n - 1; ++i) {
446 gemini_fold_comms.push_back(this->
template deserialize_from_buffer<Commitment>(proof_data,
offset));
448 for (
size_t i = 0; i < log_n; ++i) {
449 gemini_fold_evals.push_back(this->
template deserialize_from_buffer<FF>(proof_data,
offset));
451 shplonk_q_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
452 kzg_w_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
458 for (
size_t i = 0; i < log_n - 1; ++i) {
459 Base::serialize_to_buffer(gemini_fold_comms[i], proof_data);
461 for (
size_t i = 0; i < log_n; ++i) {
462 Base::serialize_to_buffer(gemini_fold_evals[i], proof_data);
464 Base::serialize_to_buffer(shplonk_q_comm, proof_data);
465 Base::serialize_to_buffer(kzg_w_comm, proof_data);
474 for (
size_t i = 0; i < num_public_inputs; ++i) {
475 public_inputs.push_back(this->
template deserialize_from_buffer<FF>(proof_data,
offset));
477 deserialize_mega_witness_comms(proof_data,
offset);
478 deserialize_sumcheck(proof_data,
offset, log_n);
479 deserialize_pcs(proof_data,
offset, log_n);
484 size_t old_size = proof_data.size();
487 for (
const auto& pi : public_inputs) {
488 Base::serialize_to_buffer(pi, proof_data);
490 serialize_mega_witness_comms(proof_data);
491 serialize_sumcheck(proof_data, log_n);
492 serialize_pcs(proof_data, log_n);
522 this->clear_vectors();
524 for (
size_t i = 0; i < num_public_inputs; ++i) {
525 this->public_inputs.push_back(this->
template deserialize_from_buffer<FF>(proof_data,
offset));
527 if constexpr (flavor_has_gemini_masking<Flavor>()) {
528 hiding_polynomial_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
530 this->deserialize_mega_witness_comms(proof_data,
offset);
531 libra_concatenation_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
532 libra_sum = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
535 for (
size_t i = 0; i < log_n; ++i) {
536 this->sumcheck_univariates.push_back(
540 libra_claimed_evaluation = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
541 this->sumcheck_evaluations =
542 this->
template deserialize_from_buffer<std::array<FF, Base::NUM_ALL_ENTITIES>>(proof_data,
offset);
543 libra_grand_sum_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
544 libra_quotient_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
547 for (
size_t i = 0; i < log_n - 1; ++i) {
548 this->gemini_fold_comms.push_back(this->
template deserialize_from_buffer<Commitment>(proof_data,
offset));
550 for (
size_t i = 0; i < log_n; ++i) {
551 this->gemini_fold_evals.push_back(this->
template deserialize_from_buffer<FF>(proof_data,
offset));
553 libra_concatenation_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
554 libra_shifted_grand_sum_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
555 libra_grand_sum_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
556 libra_quotient_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
557 this->shplonk_q_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
558 this->kzg_w_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
563 size_t old_size = proof_data.size();
566 for (
const auto& pi : this->public_inputs) {
567 Base::serialize_to_buffer(pi, proof_data);
569 if constexpr (flavor_has_gemini_masking<Flavor>()) {
570 Base::serialize_to_buffer(hiding_polynomial_commitment, proof_data);
572 this->serialize_mega_witness_comms(proof_data);
573 Base::serialize_to_buffer(libra_concatenation_commitment, proof_data);
574 Base::serialize_to_buffer(libra_sum, proof_data);
577 for (
size_t i = 0; i < log_n; ++i) {
578 Base::serialize_to_buffer(this->sumcheck_univariates[i], proof_data);
580 Base::serialize_to_buffer(libra_claimed_evaluation, proof_data);
581 Base::serialize_to_buffer(this->sumcheck_evaluations, proof_data);
582 Base::serialize_to_buffer(libra_grand_sum_commitment, proof_data);
583 Base::serialize_to_buffer(libra_quotient_commitment, proof_data);
586 for (
size_t i = 0; i < log_n - 1; ++i) {
587 Base::serialize_to_buffer(this->gemini_fold_comms[i], proof_data);
589 for (
size_t i = 0; i < log_n; ++i) {
590 Base::serialize_to_buffer(this->gemini_fold_evals[i], proof_data);
592 Base::serialize_to_buffer(libra_concatenation_eval, proof_data);
593 Base::serialize_to_buffer(libra_shifted_grand_sum_eval, proof_data);
594 Base::serialize_to_buffer(libra_grand_sum_eval, proof_data);
595 Base::serialize_to_buffer(libra_quotient_eval, proof_data);
596 Base::serialize_to_buffer(this->shplonk_q_comm, proof_data);
597 Base::serialize_to_buffer(this->kzg_w_comm, proof_data);
608 using Base::BATCHED_RELATION_PARTIAL_LENGTH;
609 using Base::NUM_ALL_ENTITIES;
615 static constexpr size_t NUM_BATCH_WITNESS_COMMS = Flavor::NUM_COMMITMENTS_IN_PROOF;
617 static constexpr size_t LOG_MINI_CIRCUIT_SIZE = Flavor::LOG_MINI_CIRCUIT_SIZE;
618 static constexpr size_t NUM_MINICIRCUIT_EVALUATIONS = Flavor::NUM_MINICIRCUIT_EVALUATIONS;
619 static constexpr size_t NUM_FULL_CIRCUIT_EVALUATIONS = Flavor::NUM_FULL_CIRCUIT_EVALUATIONS;
659 witness_comms.clear();
660 sumcheck_univariates.clear();
661 gemini_fold_comms.clear();
662 gemini_fold_evals.clear();
665 gemini_masking_poly_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
666 for (
size_t i = 0; i < NUM_BATCH_WITNESS_COMMS; ++i) {
667 witness_comms.push_back(this->
template deserialize_from_buffer<Commitment>(proof_data,
offset));
669 z_perm_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
672 libra_concatenation_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
673 libra_sum = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
676 for (
size_t i = 0; i < LOG_MINI_CIRCUIT_SIZE; ++i) {
677 sumcheck_univariates.push_back(
682 minicircuit_evaluations =
683 this->
template deserialize_from_buffer<std::array<FF, NUM_MINICIRCUIT_EVALUATIONS>>(proof_data,
offset);
685 for (
size_t i = LOG_MINI_CIRCUIT_SIZE; i < log_n; ++i) {
686 sumcheck_univariates.push_back(
691 full_circuit_evaluations =
692 this->
template deserialize_from_buffer<std::array<FF, NUM_FULL_CIRCUIT_EVALUATIONS>>(proof_data,
offset);
693 libra_claimed_evaluation = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
696 libra_grand_sum_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
697 libra_quotient_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
700 for (
size_t i = 0; i < log_n - 1; ++i) {
701 gemini_fold_comms.push_back(this->
template deserialize_from_buffer<Commitment>(proof_data,
offset));
703 for (
size_t i = 0; i < log_n; ++i) {
704 gemini_fold_evals.push_back(this->
template deserialize_from_buffer<FF>(proof_data,
offset));
708 libra_concatenation_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
709 libra_shifted_grand_sum_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
710 libra_grand_sum_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
711 libra_quotient_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
714 shplonk_q_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
715 kzg_w_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
720 size_t old_size = proof_data.size();
724 Base::serialize_to_buffer(gemini_masking_poly_comm, proof_data);
725 for (
const auto& comm : witness_comms) {
726 Base::serialize_to_buffer(comm, proof_data);
728 Base::serialize_to_buffer(z_perm_comm, proof_data);
731 Base::serialize_to_buffer(libra_concatenation_commitment, proof_data);
732 Base::serialize_to_buffer(libra_sum, proof_data);
735 for (
size_t i = 0; i < LOG_MINI_CIRCUIT_SIZE; ++i) {
736 Base::serialize_to_buffer(sumcheck_univariates[i], proof_data);
739 Base::serialize_to_buffer(minicircuit_evaluations, proof_data);
741 for (
size_t i = LOG_MINI_CIRCUIT_SIZE; i < log_n; ++i) {
742 Base::serialize_to_buffer(sumcheck_univariates[i], proof_data);
745 Base::serialize_to_buffer(full_circuit_evaluations, proof_data);
746 Base::serialize_to_buffer(libra_claimed_evaluation, proof_data);
749 Base::serialize_to_buffer(libra_grand_sum_commitment, proof_data);
750 Base::serialize_to_buffer(libra_quotient_commitment, proof_data);
753 for (
size_t i = 0; i < log_n - 1; ++i) {
754 Base::serialize_to_buffer(gemini_fold_comms[i], proof_data);
756 for (
size_t i = 0; i < log_n; ++i) {
757 Base::serialize_to_buffer(gemini_fold_evals[i], proof_data);
761 Base::serialize_to_buffer(libra_concatenation_eval, proof_data);
762 Base::serialize_to_buffer(libra_shifted_grand_sum_eval, proof_data);
763 Base::serialize_to_buffer(libra_grand_sum_eval, proof_data);
764 Base::serialize_to_buffer(libra_quotient_eval, proof_data);
767 Base::serialize_to_buffer(shplonk_q_comm, proof_data);
768 Base::serialize_to_buffer(kzg_w_comm, proof_data);
779 using Base::NUM_ALL_ENTITIES;
842 sumcheck_round_comms.clear();
843 sumcheck_round_eval_0s.clear();
844 sumcheck_round_eval_1s.clear();
845 gemini_fold_comms.clear();
846 gemini_fold_evals.clear();
849 gemini_masking_poly_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
851 wire_comms.push_back(this->
template deserialize_from_buffer<Commitment>(proof_data,
offset));
853 lookup_inverses_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
854 z_perm_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
857 libra_concatenation_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
858 libra_sum = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
861 for (
size_t i = 0; i < log_n; ++i) {
862 sumcheck_round_comms.push_back(this->
template deserialize_from_buffer<Commitment>(proof_data,
offset));
863 sumcheck_round_eval_0s.push_back(this->
template deserialize_from_buffer<FF>(proof_data,
offset));
864 sumcheck_round_eval_1s.push_back(this->
template deserialize_from_buffer<FF>(proof_data,
offset));
868 sumcheck_evaluations =
869 this->
template deserialize_from_buffer<std::array<FF, NUM_ALL_ENTITIES>>(proof_data,
offset);
872 libra_claimed_evaluation = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
873 libra_grand_sum_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
874 libra_quotient_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
877 for (
size_t i = 0; i < log_n - 1; ++i) {
878 gemini_fold_comms.push_back(this->
template deserialize_from_buffer<Commitment>(proof_data,
offset));
880 for (
size_t i = 0; i < log_n; ++i) {
881 gemini_fold_evals.push_back(this->
template deserialize_from_buffer<FF>(proof_data,
offset));
885 libra_concatenation_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
886 libra_shifted_grand_sum_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
887 libra_grand_sum_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
888 libra_quotient_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
891 shplonk_q_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
894 translation_masking_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
895 translation_op_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
896 translation_Px_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
897 translation_Py_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
898 translation_z1_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
899 translation_z2_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
900 translation_masking_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
901 translation_grand_sum_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
902 translation_quotient_commitment = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
903 translation_concatenation_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
904 translation_shifted_grand_sum_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
905 translation_grand_sum_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
906 translation_quotient_eval = this->
template deserialize_from_buffer<FF>(proof_data,
offset);
909 final_shplonk_q_comm = this->
template deserialize_from_buffer<Commitment>(proof_data,
offset);
914 size_t old_size = proof_data.size();
918 Base::serialize_to_buffer(gemini_masking_poly_comm, proof_data);
919 for (
const auto& comm : wire_comms) {
920 Base::serialize_to_buffer(comm, proof_data);
922 Base::serialize_to_buffer(lookup_inverses_comm, proof_data);
923 Base::serialize_to_buffer(z_perm_comm, proof_data);
926 Base::serialize_to_buffer(libra_concatenation_commitment, proof_data);
927 Base::serialize_to_buffer(libra_sum, proof_data);
930 for (
size_t i = 0; i < log_n; ++i) {
931 Base::serialize_to_buffer(sumcheck_round_comms[i], proof_data);
932 Base::serialize_to_buffer(sumcheck_round_eval_0s[i], proof_data);
933 Base::serialize_to_buffer(sumcheck_round_eval_1s[i], proof_data);
937 Base::serialize_to_buffer(sumcheck_evaluations, proof_data);
940 Base::serialize_to_buffer(libra_claimed_evaluation, proof_data);
941 Base::serialize_to_buffer(libra_grand_sum_commitment, proof_data);
942 Base::serialize_to_buffer(libra_quotient_commitment, proof_data);
945 for (
size_t i = 0; i < log_n - 1; ++i) {
946 Base::serialize_to_buffer(gemini_fold_comms[i], proof_data);
948 for (
size_t i = 0; i < log_n; ++i) {
949 Base::serialize_to_buffer(gemini_fold_evals[i], proof_data);
953 Base::serialize_to_buffer(libra_concatenation_eval, proof_data);
954 Base::serialize_to_buffer(libra_shifted_grand_sum_eval, proof_data);
955 Base::serialize_to_buffer(libra_grand_sum_eval, proof_data);
956 Base::serialize_to_buffer(libra_quotient_eval, proof_data);
959 Base::serialize_to_buffer(shplonk_q_comm, proof_data);
962 Base::serialize_to_buffer(translation_masking_comm, proof_data);
963 Base::serialize_to_buffer(translation_op_eval, proof_data);
964 Base::serialize_to_buffer(translation_Px_eval, proof_data);
965 Base::serialize_to_buffer(translation_Py_eval, proof_data);
966 Base::serialize_to_buffer(translation_z1_eval, proof_data);
967 Base::serialize_to_buffer(translation_z2_eval, proof_data);
968 Base::serialize_to_buffer(translation_masking_eval, proof_data);
969 Base::serialize_to_buffer(translation_grand_sum_commitment, proof_data);
970 Base::serialize_to_buffer(translation_quotient_commitment, proof_data);
971 Base::serialize_to_buffer(translation_concatenation_eval, proof_data);
972 Base::serialize_to_buffer(translation_shifted_grand_sum_eval, proof_data);
973 Base::serialize_to_buffer(translation_grand_sum_eval, proof_data);
974 Base::serialize_to_buffer(translation_quotient_eval, proof_data);
977 Base::serialize_to_buffer(final_shplonk_q_comm, proof_data);
#define BB_ASSERT_EQ(actual, expected,...)
#define BB_ASSERT_LTE(left, right,...)
std::vector< DataType > Proof
typename Curve::ScalarField FF
static constexpr size_t NUM_ALL_ENTITIES
typename G1::affine_element Commitment
static constexpr size_t NUM_WIRES
static constexpr size_t BATCHED_RELATION_PARTIAL_LENGTH
BaseTranscript< Codec, HashFunction > Transcript
A univariate polynomial represented by its values on {0, 1,..., domain_end - 1}.
Entry point for Barretenberg command-line interface.
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
Commitment libra_grand_sum_commitment
Commitment lookup_inverses_comm
Commitment translation_quotient_commitment
FF translation_grand_sum_eval
Commitment final_shplonk_q_comm
std::vector< Commitment > gemini_fold_comms
FF translation_quotient_eval
typename Flavor::Commitment Commitment
FF translation_shifted_grand_sum_eval
FF translation_masking_eval
Commitment gemini_masking_poly_comm
std::vector< Commitment > wire_comms
Commitment translation_grand_sum_commitment
void deserialize(ProofData &proof_data, size_t, size_t log_n)
Commitment shplonk_q_comm
std::vector< FF > sumcheck_round_eval_1s
FF libra_claimed_evaluation
Commitment libra_quotient_commitment
FF libra_concatenation_eval
FF translation_concatenation_eval
Commitment translation_masking_comm
std::vector< Commitment > sumcheck_round_comms
std::array< FF, NUM_ALL_ENTITIES > sumcheck_evaluations
Commitment libra_concatenation_commitment
FF libra_shifted_grand_sum_eval
std::vector< FF > gemini_fold_evals
typename Transcript::Proof ProofData
void serialize(ProofData &proof_data, size_t log_n) const
std::vector< FF > sumcheck_round_eval_0s
Commitment lookup_inverses_comm
Commitment return_data_comm
Commitment ecc_op_wire_2_comm
Commitment ecc_op_wire_4_comm
Commitment first_app_calldata_read_counts_comm
void deserialize_mega_witness_comms(const ProofData &proof_data, size_t &offset)
Commitment ecc_op_wire_1_comm
Commitment first_app_calldata_comm
Commitment third_app_calldata_inverses_comm
Commitment first_app_calldata_inverses_comm
typename Flavor::Commitment Commitment
Commitment lookup_read_counts_comm
Commitment shplonk_q_comm
void deserialize_pcs(const ProofData &proof_data, size_t &offset, size_t log_n)
Commitment lookup_read_tags_comm
std::vector< Commitment > gemini_fold_comms
Commitment ecc_op_wire_3_comm
std::vector< FF > gemini_fold_evals
Commitment kernel_calldata_read_counts_comm
void serialize(ProofData &proof_data, size_t log_n) const
Commitment return_data_inverses_comm
void serialize_mega_witness_comms(ProofData &proof_data) const
void serialize_sumcheck(ProofData &proof_data, size_t log_n) const
void serialize_pcs(ProofData &proof_data, size_t log_n) const
std::array< FF, NUM_ALL_ENTITIES > sumcheck_evaluations
void deserialize(ProofData &proof_data, size_t num_public_inputs, size_t log_n)
void deserialize_sumcheck(const ProofData &proof_data, size_t &offset, size_t log_n)
std::vector< FF > public_inputs
Commitment third_app_calldata_comm
Commitment second_app_calldata_comm
Commitment kernel_calldata_inverses_comm
Commitment second_app_calldata_read_counts_comm
std::vector< bb::Univariate< FF, BATCHED_RELATION_PARTIAL_LENGTH > > sumcheck_univariates
Commitment kernel_calldata_comm
Commitment third_app_calldata_read_counts_comm
Commitment second_app_calldata_inverses_comm
typename Transcript::Proof ProofData
Commitment return_data_read_counts_comm
void deserialize(ProofData &proof_data, size_t num_public_inputs, size_t log_n)
FF libra_claimed_evaluation
typename Flavor::Commitment Commitment
FF libra_shifted_grand_sum_eval
Commitment libra_grand_sum_commitment
Commitment libra_concatenation_commitment
Commitment hiding_polynomial_commitment
FF libra_concatenation_eval
typename Transcript::Proof ProofData
Commitment libra_quotient_commitment
void serialize(ProofData &proof_data, size_t log_n) const
static void serialize_to_buffer(const T &element, ProofData &proof_data)
static constexpr size_t NUM_ALL_ENTITIES
static T deserialize_from_buffer(const ProofData &proof_data, size_t &offset)
typename Flavor::Commitment Commitment
static constexpr size_t BATCHED_RELATION_PARTIAL_LENGTH
typename Transcript::Codec Codec
typename Transcript::Proof ProofData
typename Flavor::Transcript Transcript
Test utility for deserializing/serializing proof data into typed structures.
void deserialize(ProofData &proof_data, size_t, size_t log_n)
void serialize(ProofData &proof_data, size_t log_n) const
Commitment libra_grand_sum_commitment
Commitment gemini_masking_poly_comm
typename Flavor::Commitment Commitment
std::array< FF, NUM_FULL_CIRCUIT_EVALUATIONS > full_circuit_evaluations
Commitment libra_concatenation_commitment
std::array< FF, NUM_MINICIRCUIT_EVALUATIONS > minicircuit_evaluations
FF libra_shifted_grand_sum_eval
FF libra_claimed_evaluation
FF libra_concatenation_eval
std::vector< FF > gemini_fold_evals
std::vector< Commitment > gemini_fold_comms
std::vector< Commitment > witness_comms
Commitment shplonk_q_comm
typename Transcript::Proof ProofData
std::vector< bb::Univariate< FF, BATCHED_RELATION_PARTIAL_LENGTH > > sumcheck_univariates
Commitment libra_quotient_commitment
void serialize(ProofData &proof_data, size_t log_n) const
std::vector< Commitment > gemini_fold_comms
void deserialize_ultra_witness_comms(const ProofData &proof_data, size_t &offset)
std::array< FF, NUM_ALL_ENTITIES > sumcheck_evaluations
Commitment lookup_read_counts_comm
typename Flavor::Commitment Commitment
Commitment lookup_inverses_comm
void deserialize_sumcheck(const ProofData &proof_data, size_t &offset, size_t log_n)
void serialize_ultra_witness_comms(ProofData &proof_data) const
void deserialize(ProofData &proof_data, size_t num_public_inputs, size_t log_n)
std::vector< FF > gemini_fold_evals
Commitment shplonk_q_comm
Commitment lookup_read_tags_comm
std::vector< bb::Univariate< FF, BATCHED_RELATION_PARTIAL_LENGTH > > sumcheck_univariates
void serialize_pcs(ProofData &proof_data, size_t log_n) const
std::vector< FF > public_inputs
void deserialize_pcs(const ProofData &proof_data, size_t &offset, size_t log_n)
void serialize_sumcheck(ProofData &proof_data, size_t log_n) const
typename Transcript::Proof ProofData
FF libra_concatenation_eval
void serialize(ProofData &proof_data, size_t log_n) const
FF libra_shifted_grand_sum_eval
Commitment libra_quotient_commitment
typename Flavor::Commitment Commitment
FF libra_claimed_evaluation
Commitment hiding_polynomial_commitment
void deserialize(ProofData &proof_data, size_t num_public_inputs, size_t log_n)
Commitment libra_concatenation_commitment
Commitment libra_grand_sum_commitment
typename Transcript::Proof ProofData