From cbca890ffc42a4d38379e6960cf7f2a2425a2320 Mon Sep 17 00:00:00 2001 From: Cody Date: Wed, 20 Nov 2024 00:59:28 +0000 Subject: [PATCH 01/10] Single allocation in CIVC --- .../barretenberg/client_ivc/client_ivc.cpp | 16 +++++++++++---- .../barretenberg/client_ivc/client_ivc.hpp | 10 ++++++++-- .../commitment_schemes/commitment_key.hpp | 4 +++- .../barretenberg/dsl/acir_proofs/c_bind.cpp | 2 +- .../src/barretenberg/eccvm/eccvm_prover.cpp | 3 +-- .../cpp/src/barretenberg/goblin/goblin.hpp | 10 ++++++---- .../src/barretenberg/goblin/mock_circuits.hpp | 8 +++++--- .../execution_trace/mega_execution_trace.hpp | 20 +++++++++++++++++-- .../stdlib_circuit_builders/mega_flavor.hpp | 8 +++++--- .../src/barretenberg/sumcheck/sumcheck.hpp | 2 +- .../translator_vm/translator_prover.cpp | 14 ++++++------- .../translator_vm/translator_prover.hpp | 4 +++- .../ultra_honk/decider_prover.cpp | 4 ++-- .../ultra_honk/decider_proving_key.hpp | 8 +++++--- .../barretenberg/ultra_honk/merge_prover.cpp | 7 ++++--- .../barretenberg/ultra_honk/merge_prover.hpp | 3 ++- .../barretenberg/ultra_honk/oink_prover.cpp | 2 ++ 17 files changed, 85 insertions(+), 40 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.cpp b/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.cpp index 9119e17f6ea..9a8add8988f 100644 --- a/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.cpp +++ b/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.cpp @@ -176,9 +176,16 @@ void ClientIVC::accumulate(ClientCircuit& circuit, const std::shared_ptr(circuit, trace_settings); trace_usage_tracker = ExecutionTraceUsageTracker(trace_settings); } else { - proving_key = std::make_shared( - circuit, trace_settings, fold_output.accumulator->proving_key.commitment_key); + proving_key = std::make_shared(circuit, trace_settings); + } + + if (!bn254_commitment_key) { + info("commitment key being initialized"); + bn254_commitment_key = std::make_shared(proving_key->dyadic_circuit_size); + } else { + info("commitment key already initialized"); } + proving_key->proving_key.commitment_key = bn254_commitment_key; vinfo("getting honk vk... precomputed?: ", precomputed_vk); // Update the accumulator trace usage based on the present circuit @@ -274,11 +281,11 @@ HonkProof ClientIVC::construct_and_prove_hiding_circuit() builder.add_pairing_point_accumulator(stdlib::recursion::init_default_agg_obj_indices(builder)); - // Construct the last merge proof for the present circuit and add to merge verification queue + // Construct the last merge proof for the present circuit and add to merge verification queuee MergeProof merge_proof = goblin.prove_merge(builder); merge_verification_queue.emplace_back(merge_proof); - auto decider_pk = std::make_shared(builder); + auto decider_pk = std::make_shared(builder, TraceSettings(), bn254_commitment_key); honk_vk = std::make_shared(decider_pk->proving_key); MegaProver prover(decider_pk); @@ -338,6 +345,7 @@ bool ClientIVC::verify(const Proof& proof) HonkProof ClientIVC::decider_prove() const { vinfo("prove decider..."); + fold_output.accumulator->proving_key.commitment_key = bn254_commitment_key; MegaDeciderProver decider_prover(fold_output.accumulator); return decider_prover.construct_proof(); vinfo("finished decider proving."); diff --git a/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.hpp b/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.hpp index c1389ed814d..c0028a791ff 100644 --- a/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.hpp +++ b/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.hpp @@ -98,8 +98,6 @@ class ClientIVC { using ProverFoldOutput = FoldingResult; public: - GoblinProver goblin; - ProverFoldOutput fold_output; // prover accumulator and fold proof std::shared_ptr verifier_accumulator; // verifier accumulator @@ -122,11 +120,19 @@ class ClientIVC { // Setting auto_verify_mode = true will cause kernel completion logic to be added to kernels automatically bool auto_verify_mode; + std::shared_ptr bn254_commitment_key; + + GoblinProver goblin; + bool initialized = false; // Is the IVC accumulator initialized ClientIVC(TraceSettings trace_settings = {}, bool auto_verify_mode = false) : trace_settings(trace_settings) , auto_verify_mode(auto_verify_mode) + , bn254_commitment_key(trace_settings.structure.has_value() + ? std::make_shared>(trace_settings.dyadic_size()) + : nullptr) + , goblin(bn254_commitment_key) {} void instantiate_stdlib_verification_queue( diff --git a/barretenberg/cpp/src/barretenberg/commitment_schemes/commitment_key.hpp b/barretenberg/cpp/src/barretenberg/commitment_schemes/commitment_key.hpp index 6440c016a62..c7c3d960958 100644 --- a/barretenberg/cpp/src/barretenberg/commitment_schemes/commitment_key.hpp +++ b/barretenberg/cpp/src/barretenberg/commitment_schemes/commitment_key.hpp @@ -69,7 +69,9 @@ template class CommitmentKey { : pippenger_runtime_state(get_num_needed_srs_points(num_points)) , crs_factory(srs::get_crs_factory()) , srs(crs_factory->get_prover_crs(get_num_needed_srs_points(num_points))) - {} + { + info("CommitmentKey constructor from num_points being called!"); + } // Note: This constructor is to be used only by Plonk; For Honk the srs lives in the CommitmentKey CommitmentKey(const size_t num_points, std::shared_ptr> prover_crs) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_proofs/c_bind.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_proofs/c_bind.cpp index 25d4f90d85a..ba802bcb5a5 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_proofs/c_bind.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_proofs/c_bind.cpp @@ -236,7 +236,7 @@ WASM_EXPORT void acir_prove_and_verify_aztec_client(uint8_t const* acir_stack, } // TODO(#7371) dedupe this with the rest of the similar code // TODO(https://github.com/AztecProtocol/barretenberg/issues/1101): remove use of auto_verify_mode - ClientIVC ivc{ { E2E_FULL_TEST_STRUCTURE }, /*auto_verify_mode=*/true }; + ClientIVC ivc{ { CLIENT_IVC_BENCH_STRUCTURE }, /*auto_verify_mode=*/true }; // Accumulate the entire program stack into the IVC // TODO(https://github.com/AztecProtocol/barretenberg/issues/1116): remove manual setting of is_kernel once databus diff --git a/barretenberg/cpp/src/barretenberg/eccvm/eccvm_prover.cpp b/barretenberg/cpp/src/barretenberg/eccvm/eccvm_prover.cpp index 99f1350f920..d95a2f01ad7 100644 --- a/barretenberg/cpp/src/barretenberg/eccvm/eccvm_prover.cpp +++ b/barretenberg/cpp/src/barretenberg/eccvm/eccvm_prover.cpp @@ -104,8 +104,7 @@ void ECCVMProver::execute_relation_check_rounds() gate_challenges[idx] = transcript->template get_challenge("Sumcheck:gate_challenge_" + std::to_string(idx)); } - auto commitment_key = std::make_shared(Flavor::BATCHED_RELATION_PARTIAL_LENGTH); - zk_sumcheck_data = ZKSumcheckData(key->log_circuit_size, transcript, commitment_key); + zk_sumcheck_data = ZKSumcheckData(key->log_circuit_size, transcript, key->commitment_key); sumcheck_output = sumcheck.prove(key->polynomials, relation_parameters, alpha, gate_challenges, zk_sumcheck_data); } diff --git a/barretenberg/cpp/src/barretenberg/goblin/goblin.hpp b/barretenberg/cpp/src/barretenberg/goblin/goblin.hpp index a8580ae94a7..fae8b19ec45 100644 --- a/barretenberg/cpp/src/barretenberg/goblin/goblin.hpp +++ b/barretenberg/cpp/src/barretenberg/goblin/goblin.hpp @@ -51,6 +51,7 @@ class GoblinProver { */ std::shared_ptr op_queue = std::make_shared(); + std::shared_ptr> commitment_key; MergeProof merge_proof; GoblinProof goblin_proof; @@ -70,11 +71,12 @@ class GoblinProver { GoblinAccumulationOutput accumulator; // Used only for ACIR methods for now public: - GoblinProver() + GoblinProver(const std::shared_ptr>& bn254_commitment_key = nullptr) { // Mocks the interaction of a first circuit with the op queue due to the inability to currently handle zero // commitments (https://github.com/AztecProtocol/barretenberg/issues/871) which would otherwise appear in the // first round of the merge protocol. To be removed once the issue has been resolved. - GoblinMockCircuits::perform_op_queue_interactions_for_mock_first_circuit(op_queue); + commitment_key = bn254_commitment_key ? bn254_commitment_key : nullptr; + GoblinMockCircuits::perform_op_queue_interactions_for_mock_first_circuit(op_queue, commitment_key); } /** * @brief Construct a MegaHonk proof and a merge proof for the present circuit. @@ -160,7 +162,7 @@ class GoblinProver { merge_proof_exists = true; } - MergeProver merge_prover{ circuit_builder.op_queue }; + MergeProver merge_prover{ circuit_builder.op_queue, commitment_key }; return merge_prover.construct_proof(); }; @@ -209,7 +211,7 @@ class GoblinProver { auto translator_builder = std::make_unique(translation_batching_challenge_v, evaluation_challenge_x, op_queue); - translator_prover = std::make_unique(*translator_builder, transcript); + translator_prover = std::make_unique(*translator_builder, transcript, commitment_key); } { diff --git a/barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp b/barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp index 2ddcdfb2038..6cafcd7398f 100644 --- a/barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp +++ b/barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp @@ -121,7 +121,8 @@ class GoblinMockCircuits { * * @param op_queue */ - static void perform_op_queue_interactions_for_mock_first_circuit(std::shared_ptr& op_queue) + static void perform_op_queue_interactions_for_mock_first_circuit( + std::shared_ptr& op_queue, std::shared_ptr commitment_key = nullptr) { PROFILE_THIS(); @@ -134,11 +135,12 @@ class GoblinMockCircuits { // Manually compute the op queue transcript commitments (which would normally be done by the merge prover) bb::srs::init_crs_factory("../srs_db/ignition"); - auto commitment_key = CommitmentKey(op_queue->get_current_size()); + auto bn254_commitment_key = + commitment_key ? commitment_key : std::make_shared(op_queue->get_current_size()); std::array op_queue_commitments; size_t idx = 0; for (auto& entry : op_queue->get_aggregate_transcript()) { - op_queue_commitments[idx++] = commitment_key.commit({ 0, entry }); + op_queue_commitments[idx++] = commitment_key->commit({ 0, entry }); } // Store the commitment data for use by the prover of the next circuit op_queue->set_commitment_data(op_queue_commitments); diff --git a/barretenberg/cpp/src/barretenberg/plonk_honk_shared/execution_trace/mega_execution_trace.hpp b/barretenberg/cpp/src/barretenberg/plonk_honk_shared/execution_trace/mega_execution_trace.hpp index a30a879142b..26edf196c2d 100644 --- a/barretenberg/cpp/src/barretenberg/plonk_honk_shared/execution_trace/mega_execution_trace.hpp +++ b/barretenberg/cpp/src/barretenberg/plonk_honk_shared/execution_trace/mega_execution_trace.hpp @@ -59,8 +59,15 @@ template struct MegaTraceBlockData { }; } - static uint32_t size() { return 0; } - static uint32_t dyadic_size() { return 0; } + size_t size() const + requires std::same_as + { + size_t result{ 0 }; + for (const auto& block_size : get()) { + result += block_size; + } + return static_cast(result); + } bool operator==(const MegaTraceBlockData& other) const = default; }; @@ -72,6 +79,15 @@ struct TraceSettings { // The size of the overflow block. Specified separately because it is allowed to be determined at runtime in the // context of VK computation uint32_t overflow_capacity = 0; + + size_t size() const { return structure->size() + static_cast(overflow_capacity); } + + size_t dyadic_size() const + { + const size_t total_size = size(); + const size_t lower_dyadic = 1 << numeric::get_msb(total_size); + return total_size > lower_dyadic ? lower_dyadic << 1 : lower_dyadic; + } }; class MegaTraceBlock : public ExecutionTraceBlock { diff --git a/barretenberg/cpp/src/barretenberg/stdlib_circuit_builders/mega_flavor.hpp b/barretenberg/cpp/src/barretenberg/stdlib_circuit_builders/mega_flavor.hpp index e87ebe9ea76..60165e1913e 100644 --- a/barretenberg/cpp/src/barretenberg/stdlib_circuit_builders/mega_flavor.hpp +++ b/barretenberg/cpp/src/barretenberg/stdlib_circuit_builders/mega_flavor.hpp @@ -581,11 +581,13 @@ class MegaFlavor { VerificationKey(ProvingKey& proving_key) { set_metadata(proving_key); - if (proving_key.commitment_key == nullptr) { - proving_key.commitment_key = std::make_shared(proving_key.circuit_size); + auto& ck = proving_key.commitment_key; + if (!ck || ck->srs->get_monomial_size() < proving_key.circuit_size) { + vinfo("commitment key being constructed in VK constructor"); + ck = std::make_shared(proving_key.circuit_size); } for (auto [polynomial, commitment] : zip_view(proving_key.polynomials.get_precomputed(), this->get_all())) { - commitment = proving_key.commitment_key->commit(polynomial); + commitment = ck->commit(polynomial); } } diff --git a/barretenberg/cpp/src/barretenberg/sumcheck/sumcheck.hpp b/barretenberg/cpp/src/barretenberg/sumcheck/sumcheck.hpp index 887730da472..0a670c80e5c 100644 --- a/barretenberg/cpp/src/barretenberg/sumcheck/sumcheck.hpp +++ b/barretenberg/cpp/src/barretenberg/sumcheck/sumcheck.hpp @@ -3,7 +3,7 @@ #include "barretenberg/polynomials/polynomial_arithmetic.hpp" #include "barretenberg/sumcheck/sumcheck_output.hpp" #include "barretenberg/transcript/transcript.hpp" -#include "barretenberg/ultra_honk/decider_proving_key.hpp" +#include "barretenberg/ultra_honk/decider_proving_key.hpp" // WORKTODO: not needed? #include "sumcheck_round.hpp" namespace bb { diff --git a/barretenberg/cpp/src/barretenberg/translator_vm/translator_prover.cpp b/barretenberg/cpp/src/barretenberg/translator_vm/translator_prover.cpp index 0172648feeb..a106f571648 100644 --- a/barretenberg/cpp/src/barretenberg/translator_vm/translator_prover.cpp +++ b/barretenberg/cpp/src/barretenberg/translator_vm/translator_prover.cpp @@ -8,17 +8,18 @@ namespace bb { -TranslatorProver::TranslatorProver(CircuitBuilder& circuit_builder, const std::shared_ptr& transcript) +TranslatorProver::TranslatorProver(CircuitBuilder& circuit_builder, + const std::shared_ptr& transcript, + std::shared_ptr commitment_key) : dyadic_circuit_size(Flavor::compute_dyadic_circuit_size(circuit_builder)) , mini_circuit_dyadic_size(Flavor::compute_mini_circuit_dyadic_size(circuit_builder)) , transcript(transcript) + , key(std::make_shared(circuit_builder)) { PROFILE_THIS(); - // Compute total number of gates, dyadic circuit size, etc. - key = std::make_shared(circuit_builder); + key->commitment_key = commitment_key ? commitment_key : std::make_shared(key->circuit_size); compute_witness(circuit_builder); - compute_commitment_key(key->circuit_size); } /** @@ -159,9 +160,8 @@ void TranslatorProver::execute_relation_check_rounds() gate_challenges[idx] = transcript->template get_challenge("Sumcheck:gate_challenge_" + std::to_string(idx)); } - // create masking polynomials for sumcheck round univariates and auxiliary data - auto commitment_key = std::make_shared(Flavor::BATCHED_RELATION_PARTIAL_LENGTH); - zk_sumcheck_data = ZKSumcheckData(key->log_circuit_size, transcript, commitment_key); + // // create masking polynomials for sumcheck round univariates and auxiliary data + zk_sumcheck_data = ZKSumcheckData(key->log_circuit_size, transcript, key->commitment_key); sumcheck_output = sumcheck.prove(key->polynomials, relation_parameters, alpha, gate_challenges, zk_sumcheck_data); } diff --git a/barretenberg/cpp/src/barretenberg/translator_vm/translator_prover.hpp b/barretenberg/cpp/src/barretenberg/translator_vm/translator_prover.hpp index a8a19591ef8..989596fd02b 100644 --- a/barretenberg/cpp/src/barretenberg/translator_vm/translator_prover.hpp +++ b/barretenberg/cpp/src/barretenberg/translator_vm/translator_prover.hpp @@ -28,7 +28,9 @@ class TranslatorProver { size_t dyadic_circuit_size = 0; // final power-of-2 circuit size size_t mini_circuit_dyadic_size = 0; // The size of the small circuit that contains non-range constraint relations - explicit TranslatorProver(CircuitBuilder& circuit_builder, const std::shared_ptr& transcript); + explicit TranslatorProver(CircuitBuilder& circuit_builder, + const std::shared_ptr& transcript, + std::shared_ptr commitment_key = nullptr); void compute_witness(CircuitBuilder& circuit_builder); void compute_commitment_key(size_t circuit_size); diff --git a/barretenberg/cpp/src/barretenberg/ultra_honk/decider_prover.cpp b/barretenberg/cpp/src/barretenberg/ultra_honk/decider_prover.cpp index bdee7b3d8cd..467adebf3bb 100644 --- a/barretenberg/cpp/src/barretenberg/ultra_honk/decider_prover.cpp +++ b/barretenberg/cpp/src/barretenberg/ultra_honk/decider_prover.cpp @@ -57,11 +57,11 @@ template void DeciderProver_::execute_relation_ch */ template void DeciderProver_::execute_pcs_rounds() { - if (proving_key->proving_key.commitment_key == nullptr) { + if (!proving_key->proving_key.commitment_key) { + vinfo("Constructor vk in decider PCS rounds function"); proving_key->proving_key.commitment_key = std::make_shared(proving_key->proving_key.circuit_size); } - vinfo("made commitment key"); using OpeningClaim = ProverOpeningClaim; OpeningClaim prover_opening_claim; diff --git a/barretenberg/cpp/src/barretenberg/ultra_honk/decider_proving_key.hpp b/barretenberg/cpp/src/barretenberg/ultra_honk/decider_proving_key.hpp index cb9f954d193..a41d218e7af 100644 --- a/barretenberg/cpp/src/barretenberg/ultra_honk/decider_proving_key.hpp +++ b/barretenberg/cpp/src/barretenberg/ultra_honk/decider_proving_key.hpp @@ -44,12 +44,12 @@ template class DeciderProvingKey_ { std::vector gate_challenges; // The target sum, which is typically nonzero for a ProtogalaxyProver's accmumulator FF target_sum; - size_t final_active_wire_idx{ 0 }; // idx of last non-trivial wire value in the trace + size_t dyadic_circuit_size{ 0 }; // final power-of-2 circuit size DeciderProvingKey_(Circuit& circuit, TraceSettings trace_settings = {}, - std::shared_ptr commitment_key = nullptr) + std::shared_ptr commitment_key = nullptr) : is_structured(trace_settings.structure.has_value()) { PROFILE_THIS_NAME("DeciderProvingKey(Circuit&)"); @@ -79,6 +79,7 @@ template class DeciderProvingKey_ { // Complete the public inputs execution trace block from circuit.public_inputs Trace::populate_public_inputs_block(circuit); + vinfo("populated public inputs block"); circuit.blocks.compute_offsets(is_structured); // Find index of last non-trivial wire value in the trace @@ -101,9 +102,11 @@ template class DeciderProvingKey_ { proving_key = ProvingKey(dyadic_circuit_size, circuit.public_inputs.size(), commitment_key); // If not using structured trace OR if using structured trace but overflow has occurred (overflow block in // use), allocate full size polys + vinfo("allocated polynomials object in proving key"); if ((IsMegaFlavor && !is_structured) || (is_structured && circuit.blocks.has_overflow)) { // Allocate full size polynomials proving_key.polynomials = typename Flavor::ProverPolynomials(dyadic_circuit_size); + vinfo("allocated polynomials object in proving key"); } else { // Allocate only a correct amount of memory for each polynomial // Allocate the wires and selectors polynomials { @@ -328,7 +331,6 @@ template class DeciderProvingKey_ { private: static constexpr size_t num_zero_rows = Flavor::has_zero_row ? 1 : 0; static constexpr size_t NUM_WIRES = Circuit::NUM_WIRES; - size_t dyadic_circuit_size = 0; // final power-of-2 circuit size size_t compute_dyadic_size(Circuit&); diff --git a/barretenberg/cpp/src/barretenberg/ultra_honk/merge_prover.cpp b/barretenberg/cpp/src/barretenberg/ultra_honk/merge_prover.cpp index d4bb3526c87..00d3757db44 100644 --- a/barretenberg/cpp/src/barretenberg/ultra_honk/merge_prover.cpp +++ b/barretenberg/cpp/src/barretenberg/ultra_honk/merge_prover.cpp @@ -10,13 +10,14 @@ namespace bb { * */ template -MergeProver_::MergeProver_(const std::shared_ptr& op_queue) +MergeProver_::MergeProver_(const std::shared_ptr& op_queue, + std::shared_ptr commitment_key) : op_queue(op_queue) { // Update internal size data in the op queue that allows for extraction of e.g. previous aggregate transcript op_queue->set_size_data(); - // Get the appropriate commitment based on the updated ultra ops size - pcs_commitment_key = std::make_shared(op_queue->get_current_size()); + pcs_commitment_key = + commitment_key ? commitment_key : std::make_shared(op_queue->get_current_size()); } /** diff --git a/barretenberg/cpp/src/barretenberg/ultra_honk/merge_prover.hpp b/barretenberg/cpp/src/barretenberg/ultra_honk/merge_prover.hpp index 9499ed5fa01..9a265698c09 100644 --- a/barretenberg/cpp/src/barretenberg/ultra_honk/merge_prover.hpp +++ b/barretenberg/cpp/src/barretenberg/ultra_honk/merge_prover.hpp @@ -27,7 +27,8 @@ template class MergeProver_ { public: std::shared_ptr transcript; - explicit MergeProver_(const std::shared_ptr&); + explicit MergeProver_(const std::shared_ptr& op_queue, + std::shared_ptr commitment_key = nullptr); BB_PROFILE HonkProof construct_proof(); diff --git a/barretenberg/cpp/src/barretenberg/ultra_honk/oink_prover.cpp b/barretenberg/cpp/src/barretenberg/ultra_honk/oink_prover.cpp index cbea1470ab5..aaf00b6284a 100644 --- a/barretenberg/cpp/src/barretenberg/ultra_honk/oink_prover.cpp +++ b/barretenberg/cpp/src/barretenberg/ultra_honk/oink_prover.cpp @@ -58,8 +58,10 @@ template void OinkProver::prove() // Generate relation separators alphas for sumcheck/combiner computation proving_key->alphas = generate_alphas_round(); +#ifndef __wasm__ // Free the commitment key proving_key->proving_key.commitment_key = nullptr; +#endif } /** From 4b73307ba3d5b95e6d2e737a727ecfc37b87c4d0 Mon Sep 17 00:00:00 2001 From: Cody Date: Wed, 20 Nov 2024 18:58:34 +0000 Subject: [PATCH 02/10] WASM tests pass; 1373GB on 3 function stack --- barretenberg/ts/scripts/build_wasm.sh | 4 +++- barretenberg/ts/src/barretenberg/index.ts | 4 ++-- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/barretenberg/ts/scripts/build_wasm.sh b/barretenberg/ts/scripts/build_wasm.sh index b12348a16e8..983468b05d1 100755 --- a/barretenberg/ts/scripts/build_wasm.sh +++ b/barretenberg/ts/scripts/build_wasm.sh @@ -5,7 +5,9 @@ if [ -z "$SKIP_CPP_BUILD" ]; then # Build the wasms and strip debug symbols. cd ../cpp cmake --preset wasm-threads -DCMAKE_MESSAGE_LOG_LEVEL=Warning && cmake --build --preset wasm-threads - cmake --preset wasm -DCMAKE_MESSAGE_LOG_LEVEL=Warning && cmake --build --preset wasm + if [ -z "$SKIP_ST_BUILD" ]; then + cmake --preset wasm -DCMAKE_MESSAGE_LOG_LEVEL=Warning && cmake --build --preset wasm + fi ./scripts/strip-wasm.sh cd ../ts fi diff --git a/barretenberg/ts/src/barretenberg/index.ts b/barretenberg/ts/src/barretenberg/index.ts index 81481db9130..4cd972257b7 100644 --- a/barretenberg/ts/src/barretenberg/index.ts +++ b/barretenberg/ts/src/barretenberg/index.ts @@ -68,8 +68,8 @@ export class Barretenberg extends BarretenbergApi { async initSRSClientIVC(): Promise { // crsPath can be undefined - const crs = await Crs.new(2 ** 21 + 1, this.options.crsPath); - const grumpkinCrs = await GrumpkinCrs.new(2 ** 16 + 1, this.options.crsPath); + const crs = await Crs.new(2 ** 19 + 1, this.options.crsPath); + const grumpkinCrs = await GrumpkinCrs.new(2 ** 14 + 1, this.options.crsPath); // Load CRS into wasm global CRS state. // TODO: Make RawBuffer be default behavior, and have a specific Vector type for when wanting length prefixed. From b60289af3ef52b0f5b981eb29ea38ee436184868 Mon Sep 17 00:00:00 2001 From: Cody Date: Wed, 20 Nov 2024 18:58:54 +0000 Subject: [PATCH 03/10] Add log output and copy and paste to browser app --- yarn-project/ivc-integration/src/serve.ts | 55 +++++++++++++++++++++++ 1 file changed, 55 insertions(+) diff --git a/yarn-project/ivc-integration/src/serve.ts b/yarn-project/ivc-integration/src/serve.ts index 0910e64aae2..5b2b4e4043b 100644 --- a/yarn-project/ivc-integration/src/serve.ts +++ b/yarn-project/ivc-integration/src/serve.ts @@ -5,9 +5,64 @@ import { generate3FunctionTestingIVCStack, proveAndVerifyBrowser } from './index createDebug.enable('*'); const logger = createDebug('aztec:ivc-test'); +// Function to set up the output element and redirect all console output +function setupConsoleOutput() { + const container = document.createElement('div'); + container.style.marginBottom = '10px'; + document.body.appendChild(container); + + const copyButton = document.createElement('button'); + copyButton.innerText = 'Copy Logs to Clipboard'; + copyButton.style.marginBottom = '10px'; + copyButton.addEventListener('click', () => { + const logContent = logContainer.textContent || ''; // Get text content of log container + navigator.clipboard + .writeText(logContent) + .then(() => { + alert('Logs copied to clipboard!'); + }) + .catch(err => { + console.error('Failed to copy logs:', err); + }); + }); + container.appendChild(copyButton); + + const logContainer = document.createElement('pre'); + logContainer.id = 'logOutput'; + logContainer.style.border = '1px solid #ccc'; + logContainer.style.padding = '10px'; + logContainer.style.maxHeight = '400px'; + logContainer.style.overflowY = 'auto'; + container.appendChild(logContainer); + + // Helper to append messages to logContainer + function addLogMessage(message: string) { + logContainer.textContent += message + '\n'; + logContainer.scrollTop = logContainer.scrollHeight; // Auto-scroll to the bottom + } + + // Override console methods to output to the page as well + const originalLog = console.log; + const originalDebug = console.debug; + + console.log = (...args: any[]) => { + const message = args.join(' '); + originalLog.apply(console, args); // Keep original behavior + addLogMessage(message); + }; + + console.debug = (...args: any[]) => { + const message = args.join(' '); + originalDebug.apply(console, args); // Keep original behavior + addLogMessage(message); + }; +} + (window as any).proveAndVerifyBrowser = proveAndVerifyBrowser; document.addEventListener('DOMContentLoaded', function () { + setupConsoleOutput(); // Initialize console output capture + const button = document.createElement('button'); button.innerText = 'Run Test'; button.addEventListener('click', async () => { From 7abaea947b2196cd3d7b2f64a3172e8514596d0b Mon Sep 17 00:00:00 2001 From: Cody Date: Wed, 20 Nov 2024 19:23:47 +0000 Subject: [PATCH 04/10] Cleanup --- .../cpp/src/barretenberg/client_ivc/client_ivc.cpp | 8 +------- .../commitment_schemes/commitment_key.hpp | 4 +--- .../stdlib_circuit_builders/mega_flavor.hpp | 1 - .../src/barretenberg/ultra_honk/decider_prover.cpp | 14 ++++++-------- .../ultra_honk/decider_proving_key.hpp | 3 +-- 5 files changed, 9 insertions(+), 21 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.cpp b/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.cpp index 9a8add8988f..0cdad759654 100644 --- a/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.cpp +++ b/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.cpp @@ -179,12 +179,6 @@ void ClientIVC::accumulate(ClientCircuit& circuit, const std::shared_ptr(circuit, trace_settings); } - if (!bn254_commitment_key) { - info("commitment key being initialized"); - bn254_commitment_key = std::make_shared(proving_key->dyadic_circuit_size); - } else { - info("commitment key already initialized"); - } proving_key->proving_key.commitment_key = bn254_commitment_key; vinfo("getting honk vk... precomputed?: ", precomputed_vk); @@ -281,7 +275,7 @@ HonkProof ClientIVC::construct_and_prove_hiding_circuit() builder.add_pairing_point_accumulator(stdlib::recursion::init_default_agg_obj_indices(builder)); - // Construct the last merge proof for the present circuit and add to merge verification queuee + // Construct the last merge proof for the present circuit and add to merge verification queue MergeProof merge_proof = goblin.prove_merge(builder); merge_verification_queue.emplace_back(merge_proof); diff --git a/barretenberg/cpp/src/barretenberg/commitment_schemes/commitment_key.hpp b/barretenberg/cpp/src/barretenberg/commitment_schemes/commitment_key.hpp index c7c3d960958..6440c016a62 100644 --- a/barretenberg/cpp/src/barretenberg/commitment_schemes/commitment_key.hpp +++ b/barretenberg/cpp/src/barretenberg/commitment_schemes/commitment_key.hpp @@ -69,9 +69,7 @@ template class CommitmentKey { : pippenger_runtime_state(get_num_needed_srs_points(num_points)) , crs_factory(srs::get_crs_factory()) , srs(crs_factory->get_prover_crs(get_num_needed_srs_points(num_points))) - { - info("CommitmentKey constructor from num_points being called!"); - } + {} // Note: This constructor is to be used only by Plonk; For Honk the srs lives in the CommitmentKey CommitmentKey(const size_t num_points, std::shared_ptr> prover_crs) diff --git a/barretenberg/cpp/src/barretenberg/stdlib_circuit_builders/mega_flavor.hpp b/barretenberg/cpp/src/barretenberg/stdlib_circuit_builders/mega_flavor.hpp index 60165e1913e..9838f439f78 100644 --- a/barretenberg/cpp/src/barretenberg/stdlib_circuit_builders/mega_flavor.hpp +++ b/barretenberg/cpp/src/barretenberg/stdlib_circuit_builders/mega_flavor.hpp @@ -583,7 +583,6 @@ class MegaFlavor { set_metadata(proving_key); auto& ck = proving_key.commitment_key; if (!ck || ck->srs->get_monomial_size() < proving_key.circuit_size) { - vinfo("commitment key being constructed in VK constructor"); ck = std::make_shared(proving_key.circuit_size); } for (auto [polynomial, commitment] : zip_view(proving_key.polynomials.get_precomputed(), this->get_all())) { diff --git a/barretenberg/cpp/src/barretenberg/ultra_honk/decider_prover.cpp b/barretenberg/cpp/src/barretenberg/ultra_honk/decider_prover.cpp index 467adebf3bb..16a718be76a 100644 --- a/barretenberg/cpp/src/barretenberg/ultra_honk/decider_prover.cpp +++ b/barretenberg/cpp/src/barretenberg/ultra_honk/decider_prover.cpp @@ -57,33 +57,31 @@ template void DeciderProver_::execute_relation_ch */ template void DeciderProver_::execute_pcs_rounds() { - if (!proving_key->proving_key.commitment_key) { - vinfo("Constructor vk in decider PCS rounds function"); - proving_key->proving_key.commitment_key = - std::make_shared(proving_key->proving_key.circuit_size); - } using OpeningClaim = ProverOpeningClaim; + auto& ck = proving_key->proving_key.commitment_key; + ck = ck ? ck : std::make_shared(proving_key->proving_key.circuit_size); + OpeningClaim prover_opening_claim; if constexpr (!Flavor::HasZK) { prover_opening_claim = ShpleminiProver_::prove(proving_key->proving_key.circuit_size, proving_key->proving_key.polynomials.get_unshifted(), proving_key->proving_key.polynomials.get_to_be_shifted(), sumcheck_output.challenge, - proving_key->proving_key.commitment_key, + ck, transcript); } else { prover_opening_claim = ShpleminiProver_::prove(proving_key->proving_key.circuit_size, proving_key->proving_key.polynomials.get_unshifted(), proving_key->proving_key.polynomials.get_to_be_shifted(), sumcheck_output.challenge, - proving_key->proving_key.commitment_key, + ck, transcript, zk_sumcheck_data.libra_univariates_monomial, sumcheck_output.claimed_libra_evaluations); } vinfo("executed multivariate-to-univarite reduction"); - PCS::compute_opening_proof(proving_key->proving_key.commitment_key, prover_opening_claim, transcript); + PCS::compute_opening_proof(ck, prover_opening_claim, transcript); vinfo("computed opening proof"); } diff --git a/barretenberg/cpp/src/barretenberg/ultra_honk/decider_proving_key.hpp b/barretenberg/cpp/src/barretenberg/ultra_honk/decider_proving_key.hpp index a41d218e7af..72533aefef8 100644 --- a/barretenberg/cpp/src/barretenberg/ultra_honk/decider_proving_key.hpp +++ b/barretenberg/cpp/src/barretenberg/ultra_honk/decider_proving_key.hpp @@ -79,7 +79,6 @@ template class DeciderProvingKey_ { // Complete the public inputs execution trace block from circuit.public_inputs Trace::populate_public_inputs_block(circuit); - vinfo("populated public inputs block"); circuit.blocks.compute_offsets(is_structured); // Find index of last non-trivial wire value in the trace @@ -102,7 +101,6 @@ template class DeciderProvingKey_ { proving_key = ProvingKey(dyadic_circuit_size, circuit.public_inputs.size(), commitment_key); // If not using structured trace OR if using structured trace but overflow has occurred (overflow block in // use), allocate full size polys - vinfo("allocated polynomials object in proving key"); if ((IsMegaFlavor && !is_structured) || (is_structured && circuit.blocks.has_overflow)) { // Allocate full size polynomials proving_key.polynomials = typename Flavor::ProverPolynomials(dyadic_circuit_size); @@ -264,6 +262,7 @@ template class DeciderProvingKey_ { /* size=*/dyadic_circuit_size, /*virtual size=*/dyadic_circuit_size, /*start_idx=*/0); } } + vinfo("allocated polynomials object in proving key"); // We can finally set the shifted polynomials now that all of the to_be_shifted polynomials are // defined. proving_key.polynomials.set_shifted(); // Ensure shifted wires are set correctly From fa7b6a02140a5ca254e56c2c8fb5491000e8b945 Mon Sep 17 00:00:00 2001 From: Cody Date: Wed, 20 Nov 2024 20:35:59 +0000 Subject: [PATCH 05/10] Adjust logging --- .../cpp/src/barretenberg/client_ivc/client_ivc.cpp | 12 ++++++++++-- .../cpp/src/barretenberg/dsl/acir_proofs/c_bind.cpp | 4 ++++ 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.cpp b/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.cpp index 31c6734d600..8f889fc8b2c 100644 --- a/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.cpp +++ b/barretenberg/cpp/src/barretenberg/client_ivc/client_ivc.cpp @@ -354,11 +354,19 @@ HonkProof ClientIVC::decider_prove() const bool ClientIVC::prove_and_verify() { auto start = std::chrono::steady_clock::now(); - auto proof = prove(); + const auto proof = prove(); auto end = std::chrono::steady_clock::now(); auto diff = std::chrono::duration_cast(end - start); vinfo("time to call ClientIVC::prove: ", diff.count(), " ms."); - return verify(proof); + + start = end; + const bool verified = verify(proof); + end = std::chrono::steady_clock::now(); + + diff = std::chrono::duration_cast(end - start); + vinfo("time to verify ClientIVC proof: ", diff.count(), " ms."); + + return verified; } /** diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_proofs/c_bind.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_proofs/c_bind.cpp index ba802bcb5a5..6e045c395c5 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_proofs/c_bind.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_proofs/c_bind.cpp @@ -267,6 +267,10 @@ WASM_EXPORT void acir_prove_and_verify_aztec_client(uint8_t const* acir_stack, bool result = ivc.prove_and_verify(); info("verified?: ", result); + end = std::chrono::steady_clock::now(); + diff = std::chrono::duration_cast(end - start); + vinfo("time to construct, accumulate, prove and verify all circuits: ", diff.count()); + *verified = result; } From c1c93bbbbe0000b2785384edb9fbc8d424cb91f1 Mon Sep 17 00:00:00 2001 From: Cody Date: Wed, 20 Nov 2024 21:05:34 +0000 Subject: [PATCH 06/10] This produces a button --- yarn-project/ivc-integration/package.json | 2 +- yarn-project/ivc-integration/package.local.json | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/yarn-project/ivc-integration/package.json b/yarn-project/ivc-integration/package.json index c9fc4dae62e..54c7f409712 100644 --- a/yarn-project/ivc-integration/package.json +++ b/yarn-project/ivc-integration/package.json @@ -11,7 +11,7 @@ "./package.local.json" ], "scripts": { - "build": "yarn clean && yarn generate && rm -rf dest && webpack && tsc -b", + "build": "yarn clean && yarn generate && tsc -b && rm -rf dest && webpack", "clean": "rm -rf ./dest .tsbuildinfo src/types artifacts", "formatting": "run -T prettier --check ./src && run -T eslint ./src", "formatting:fix": "run -T eslint --fix ./src && run -T prettier -w ./src", diff --git a/yarn-project/ivc-integration/package.local.json b/yarn-project/ivc-integration/package.local.json index ecdfdf5167a..f3ab16fc679 100644 --- a/yarn-project/ivc-integration/package.local.json +++ b/yarn-project/ivc-integration/package.local.json @@ -1,6 +1,6 @@ { "scripts": { - "build": "yarn clean && yarn generate && rm -rf dest && webpack && tsc -b", + "build": "yarn clean && yarn generate && tsc -b && rm -rf dest && webpack", "clean": "rm -rf ./dest .tsbuildinfo src/types artifacts", "test:non-browser": "NODE_NO_WARNINGS=1 node --experimental-vm-modules ../node_modules/.bin/jest --testPathIgnorePatterns=browser --passWithNoTests ", "test:browser": "./run_browser_tests.sh", From 4e56cd2a756bc9f62692851e09d0705e050e7e1a Mon Sep 17 00:00:00 2001 From: Cody Date: Wed, 20 Nov 2024 21:32:19 +0000 Subject: [PATCH 07/10] Clean up output --- yarn-project/ivc-integration/src/serve.ts | 25 +++++++++++++++++++---- 1 file changed, 21 insertions(+), 4 deletions(-) diff --git a/yarn-project/ivc-integration/src/serve.ts b/yarn-project/ivc-integration/src/serve.ts index 5b2b4e4043b..8857cf3574b 100644 --- a/yarn-project/ivc-integration/src/serve.ts +++ b/yarn-project/ivc-integration/src/serve.ts @@ -41,18 +41,36 @@ function setupConsoleOutput() { logContainer.scrollTop = logContainer.scrollHeight; // Auto-scroll to the bottom } - // Override console methods to output to the page as well + // Override console methods to output clean logs const originalLog = console.log; const originalDebug = console.debug; console.log = (...args: any[]) => { - const message = args.join(' '); + const message = args + .map(arg => + typeof arg === 'string' + ? arg + .replace(/%c/g, '') + .replace(/color:.*?(;|$)/g, '') + .trim() + : arg, + ) + .join(' '); originalLog.apply(console, args); // Keep original behavior addLogMessage(message); }; console.debug = (...args: any[]) => { - const message = args.join(' '); + const message = args + .map(arg => + typeof arg === 'string' + ? arg + .replace(/%c/g, '') + .replace(/color:.*?(;|$)/g, '') + .trim() + : arg, + ) + .join(' '); originalDebug.apply(console, args); // Keep original behavior addLogMessage(message); }; @@ -67,7 +85,6 @@ document.addEventListener('DOMContentLoaded', function () { button.innerText = 'Run Test'; button.addEventListener('click', async () => { logger(`generating circuit and witness...`); - []; const [bytecodes, witnessStack] = await generate3FunctionTestingIVCStack(); logger(`done. proving and verifying...`); const verified = await proveAndVerifyBrowser(bytecodes, witnessStack); From dd146973a4f83a2b3a525e5d690464ec3021997f Mon Sep 17 00:00:00 2001 From: Cody Date: Wed, 20 Nov 2024 21:52:27 +0000 Subject: [PATCH 08/10] Allow console here --- yarn-project/ivc-integration/src/serve.ts | 2 ++ 1 file changed, 2 insertions(+) diff --git a/yarn-project/ivc-integration/src/serve.ts b/yarn-project/ivc-integration/src/serve.ts index 8857cf3574b..b16a125a05c 100644 --- a/yarn-project/ivc-integration/src/serve.ts +++ b/yarn-project/ivc-integration/src/serve.ts @@ -5,6 +5,8 @@ import { generate3FunctionTestingIVCStack, proveAndVerifyBrowser } from './index createDebug.enable('*'); const logger = createDebug('aztec:ivc-test'); +/* eslint-disable no-console */ + // Function to set up the output element and redirect all console output function setupConsoleOutput() { const container = document.createElement('div'); From 3e36b0576d624ab74c4478b783ad16ffb0cc8103 Mon Sep 17 00:00:00 2001 From: Cody Date: Wed, 20 Nov 2024 22:05:14 +0000 Subject: [PATCH 09/10] Unused variable was not an issue... --- barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp b/barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp index 8dd3ae2bc24..e2d1c598799 100644 --- a/barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp +++ b/barretenberg/cpp/src/barretenberg/goblin/mock_circuits.hpp @@ -140,7 +140,7 @@ class GoblinMockCircuits { std::array op_queue_commitments; size_t idx = 0; for (auto& entry : op_queue->get_aggregate_transcript()) { - op_queue_commitments[idx++] = commitment_key->commit({ 0, entry }); + op_queue_commitments[idx++] = bn254_commitment_key->commit({ 0, entry }); } // Store the commitment data for use by the prover of the next circuit op_queue->set_commitment_data(op_queue_commitments); From 043f787950b74abbcbc2cda3430765dc8404b3ed Mon Sep 17 00:00:00 2001 From: Cody Date: Wed, 20 Nov 2024 22:09:09 +0000 Subject: [PATCH 10/10] Remove WORKTODO --- barretenberg/cpp/src/barretenberg/sumcheck/sumcheck.hpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/barretenberg/cpp/src/barretenberg/sumcheck/sumcheck.hpp b/barretenberg/cpp/src/barretenberg/sumcheck/sumcheck.hpp index 0a670c80e5c..887730da472 100644 --- a/barretenberg/cpp/src/barretenberg/sumcheck/sumcheck.hpp +++ b/barretenberg/cpp/src/barretenberg/sumcheck/sumcheck.hpp @@ -3,7 +3,7 @@ #include "barretenberg/polynomials/polynomial_arithmetic.hpp" #include "barretenberg/sumcheck/sumcheck_output.hpp" #include "barretenberg/transcript/transcript.hpp" -#include "barretenberg/ultra_honk/decider_proving_key.hpp" // WORKTODO: not needed? +#include "barretenberg/ultra_honk/decider_proving_key.hpp" #include "sumcheck_round.hpp" namespace bb {