From bd5d2db3efac04126c4d351c8d7aadc15a6e8c55 Mon Sep 17 00:00:00 2001 From: codygunton Date: Tue, 12 Mar 2024 03:53:02 +0000 Subject: [PATCH 1/2] Multithread accumulator update --- .../src/barretenberg/protogalaxy/protogalaxy_prover.cpp | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/protogalaxy/protogalaxy_prover.cpp b/barretenberg/cpp/src/barretenberg/protogalaxy/protogalaxy_prover.cpp index 172c02009ed..130830397bf 100644 --- a/barretenberg/cpp/src/barretenberg/protogalaxy/protogalaxy_prover.cpp +++ b/barretenberg/cpp/src/barretenberg/protogalaxy/protogalaxy_prover.cpp @@ -87,9 +87,11 @@ std::shared_ptr ProtoGalaxyProver_prover_polynomials.get_all())) { - for (auto [acc_el, inst_el] : zip_view(acc_poly, inst_poly)) { - acc_el += inst_el * lagranges[inst_idx]; - } + run_loop_in_parallel(acc_poly.size(), [&](size_t start_idx, size_t end_idx) { + for (size_t idx = start_idx; idx < end_idx; idx++) { + acc_poly[idx] += inst_poly[idx] * lagranges[inst_idx]; + } + }); } } next_accumulator->prover_polynomials = std::move(acc_prover_polynomials); From 77424891e780e552fa1f48dff16ea1e16f9d7789 Mon Sep 17 00:00:00 2001 From: codygunton Date: Tue, 12 Mar 2024 12:29:14 +0000 Subject: [PATCH 2/2] Other strategy; 3% improvement on folding --- .../protogalaxy/protogalaxy_prover.cpp | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/protogalaxy/protogalaxy_prover.cpp b/barretenberg/cpp/src/barretenberg/protogalaxy/protogalaxy_prover.cpp index 130830397bf..cb2df2fb6e2 100644 --- a/barretenberg/cpp/src/barretenberg/protogalaxy/protogalaxy_prover.cpp +++ b/barretenberg/cpp/src/barretenberg/protogalaxy/protogalaxy_prover.cpp @@ -85,14 +85,17 @@ std::shared_ptr ProtoGalaxyProver_prover_polynomials.get_all())) { - run_loop_in_parallel(acc_poly.size(), [&](size_t start_idx, size_t end_idx) { - for (size_t idx = start_idx; idx < end_idx; idx++) { - acc_poly[idx] += inst_poly[idx] * lagranges[inst_idx]; + auto accumulator_polys = acc_prover_polynomials.get_all(); + auto input_polys = instances[inst_idx]->prover_polynomials.get_all(); + run_loop_in_parallel(Flavor::NUM_ALL_ENTITIES, [&](size_t start_idx, size_t end_idx) { + for (size_t poly_idx = start_idx; poly_idx < end_idx; poly_idx++) { + auto& acc_poly = accumulator_polys[poly_idx]; + auto& inst_poly = input_polys[poly_idx]; + for (auto [acc_el, inst_el] : zip_view(acc_poly, inst_poly)) { + acc_el += inst_el * lagranges[inst_idx]; } - }); - } + } + }); } next_accumulator->prover_polynomials = std::move(acc_prover_polynomials);