From d58e602a4f3f4ae50219b6a8f0ed9e7370cb2b77 Mon Sep 17 00:00:00 2001 From: sifnoc Date: Mon, 11 Dec 2023 06:24:38 +0000 Subject: [PATCH 1/2] fix: benchmark code; updated v1 benchmark result --- zk_prover/README.md | 24 +++++++++++------------- zk_prover/benches/full_solvency_flow.rs | 21 ++++----------------- 2 files changed, 15 insertions(+), 30 deletions(-) diff --git a/zk_prover/README.md b/zk_prover/README.md index f2615d8e..4a0d6427 100644 --- a/zk_prover/README.md +++ b/zk_prover/README.md @@ -94,15 +94,14 @@ The benchmarking included the following areas: In order to run the benchmarking, we provide a set of dummy `username, balances` entries formatted in csv files. The csv files can be downloaded as follows -``` -cd benches -mkdir csv -cd csv -wget https://summa-solvency.s3.eu-central-1.amazonaws.com/csv_files.tar.bz2 -tar -xjf csv_files.tar.bz2 +```bash +mkdir -p benche/csv +cd benche/csv +wget https://summa-solvency.s3.eu-central-1.amazonaws.com/1_entry_2_20.zip +unzip sample_csv_files_for_bench.zip ``` -The csv folder will contain two subfolder namely `one_asset` and `two_assets`. Each folders will contain files named as `one_asset_entry_2_17.csv` or `two_assets_entry_2_5.csv`. 2^17 or 2^5 is the number of entries in the file that will be used to feed the merkle sum tree and, eventually, the zk prover. These entries represent the number of users of the exchange. +The file naming convention, such as `1_entry_2_20.csv`, follows the pattern `[number of cryptocurrency]_entry_2_[power of 2]`. In this example, `1_entry` indicates a single currency, and the `2_20` part represents $2^{20}$ entries in the file. These entries, which are intended to populate the Merkle sum tree and feed the zk prover, correspond to the number of users on the exchange. To run the benches @@ -112,7 +111,7 @@ You can set the following parameters to run the benches: - `LEVELS` -> the number of entries in the merkle sum tree. By default it is set to 20, which means that the benches will run for 2^20 entries. - `SAMPLE_SIZE` -> the number of samples to run for each bench. By default it is set to 10, which is the minimum allowed by criterion.rs -- `N_CURRENCIES and PATH_NAME` -> the number of currencies to be used in the benchmarking. By default it is set to 1. For now you can only switch it between 1 and 2 as these are the only csv folder available. More will be added soon. +- `N_CURRENCIES` -> the number of currencies to be used in the benchmarking. By default it is set to 1. Note that the `k` of the circuit may vary based on the LEVELS @@ -120,21 +119,20 @@ Furthermore the benchmarking function `verify_zk_proof_benchmark` will also prin ## Current Benches -Run on MacBook Pro 2023, M2 Pro, 32GB RAM, 12 cores +Run on AWS m7a.8xlarge with 32 vcores and 128GB RAM 2^20 entries (1048576) users, 1 currency | MST init | | -------- | -| 73.695 s | +| 24.272 s | | MST init (sorted) | | -------- | -| 73.847 s | +| 25.480 s | For Merkle Sum Tree Proof of Inclusion circuit | VK Gen | Pk Gen | Proof Generation | Proof Verification | Proof Size (bytes) | | ------------------ | ------------------- | ------------------- | ------------------- | ------------------ | -| 183.25 ms | 116.32 ms | 517.98 ms | 3.3291 ms | 1632 | - +| 87.78 ms | 123.86 ms | 380.86 ms | 3.7287 ms | 1632 | diff --git a/zk_prover/benches/full_solvency_flow.rs b/zk_prover/benches/full_solvency_flow.rs index d4389e64..bc467413 100644 --- a/zk_prover/benches/full_solvency_flow.rs +++ b/zk_prover/benches/full_solvency_flow.rs @@ -11,16 +11,12 @@ use summa_solvency::{ const SAMPLE_SIZE: usize = 10; const LEVELS: usize = 20; const N_CURRENCIES: usize = 1; -const PATH_NAME: &str = "one_asset"; const N_BYTES: usize = 14; fn build_mstree(_c: &mut Criterion) { let mut criterion = Criterion::default().sample_size(SAMPLE_SIZE); - let csv_file = format!( - "benches/csv/{}/{}_entry_2_{}.csv", - PATH_NAME, PATH_NAME, LEVELS - ); + let csv_file = format!("benches/csv/{}_entry_2_{}.csv", N_CURRENCIES, LEVELS); let bench_name = format!( "build Merkle sum tree for 2 power of {} entries with {} currencies", @@ -37,10 +33,7 @@ fn build_mstree(_c: &mut Criterion) { fn build_sorted_mstree(_c: &mut Criterion) { let mut criterion = Criterion::default().sample_size(SAMPLE_SIZE); - let csv_file = format!( - "benches/csv/{}/{}_entry_2_{}.csv", - PATH_NAME, PATH_NAME, LEVELS - ); + let csv_file = format!("benches/csv/{}_entry_2_{}.csv", N_CURRENCIES, LEVELS); let bench_name = format!( "build sorted Merkle sum tree for 2 power of {} entries with {} currencies", @@ -97,10 +90,7 @@ fn generate_zk_proof_mst_inclusion_circuit(_c: &mut Criterion) { let (params, pk, _) = generate_setup_artifacts(13, None, empty_circuit).unwrap(); - let csv_file = format!( - "benches/csv/{}/{}_entry_2_{}.csv", - PATH_NAME, PATH_NAME, LEVELS - ); + let csv_file = format!("benches/csv/{}_entry_2_{}.csv", N_CURRENCIES, LEVELS); let merkle_sum_tree = MerkleSumTree::::from_csv(&csv_file).unwrap(); @@ -130,10 +120,7 @@ fn verify_zk_proof_mst_inclusion_circuit(_c: &mut Criterion) { let (params, pk, vk) = generate_setup_artifacts(13, None, empty_circuit).unwrap(); - let csv_file = format!( - "benches/csv/{}/{}_entry_2_{}.csv", - PATH_NAME, PATH_NAME, LEVELS - ); + let csv_file = format!("benches/csv/{}_entry_2_{}.csv", N_CURRENCIES, LEVELS); let merkle_sum_tree = MerkleSumTree::::from_csv(&csv_file).unwrap(); From a645178884b8b01202a469857d3f09428e59530d Mon Sep 17 00:00:00 2001 From: sifnoc Date: Mon, 11 Dec 2023 08:12:04 +0000 Subject: [PATCH 2/2] fix: removed leftovers --- zk_prover/README.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/zk_prover/README.md b/zk_prover/README.md index 4a0d6427..f2324f8a 100644 --- a/zk_prover/README.md +++ b/zk_prover/README.md @@ -95,10 +95,10 @@ The benchmarking included the following areas: In order to run the benchmarking, we provide a set of dummy `username, balances` entries formatted in csv files. The csv files can be downloaded as follows ```bash -mkdir -p benche/csv -cd benche/csv +mkdir -p benches/csv +cd benches/csv wget https://summa-solvency.s3.eu-central-1.amazonaws.com/1_entry_2_20.zip -unzip sample_csv_files_for_bench.zip +unzip 1_entry_2_20.zip ``` The file naming convention, such as `1_entry_2_20.csv`, follows the pattern `[number of cryptocurrency]_entry_2_[power of 2]`. In this example, `1_entry` indicates a single currency, and the `2_20` part represents $2^{20}$ entries in the file. These entries, which are intended to populate the Merkle sum tree and feed the zk prover, correspond to the number of users on the exchange.