From 0eb8674656623313d344f7769725375739a0b545 Mon Sep 17 00:00:00 2001 From: Alex Kuzmin Date: Thu, 14 Mar 2024 16:06:35 +0800 Subject: [PATCH 1/2] Remove the unused N_POINTS generic constant --- backend/examples/summa_solvency_flow.rs | 5 ++-- backend/src/apis/round.rs | 17 +++++-------- backend/src/tests.rs | 7 +++-- kzg_prover/benches/kzg.rs | 34 ++++++++----------------- kzg_prover/bin/gen_commit_and_proofs.rs | 6 ++--- kzg_prover/src/circuits/tests.rs | 5 ++-- kzg_prover/src/circuits/utils.rs | 4 +-- 7 files changed, 29 insertions(+), 49 deletions(-) diff --git a/backend/examples/summa_solvency_flow.rs b/backend/examples/summa_solvency_flow.rs index 8fa58c1b..c4b34453 100644 --- a/backend/examples/summa_solvency_flow.rs +++ b/backend/examples/summa_solvency_flow.rs @@ -25,7 +25,6 @@ use summa_solvency::{ const K: u32 = 17; const N_CURRENCIES: usize = 2; -const N_POINTS: usize = N_CURRENCIES + 1; const N_USERS: usize = 16; const USER_INDEX: usize = 0; @@ -96,7 +95,7 @@ async fn main() -> Result<(), Box> { // Using the `round` instance, the commitment is dispatched to the Summa contract with the `dispatch_commitment` method. let timestamp = 1u64; - let mut round = Round::::new( + let mut round = Round::::new( &signer, zk_snark_proof, advice_polys, @@ -143,7 +142,7 @@ async fn main() -> Result<(), Box> { let commitment = summa_contract.commitments(snapshot_time).call().await?; // Ensure the length of the commitment matches the expected size for the number of points. - assert_eq!(commitment.to_vec().len(), 0x40 * N_POINTS); + assert_eq!(commitment.to_vec().len(), 0x40 * (N_CURRENCIES - 1)); // Validate the inclusion proof using the contract verifier. let mut verification_result = false; diff --git a/backend/src/apis/round.rs b/backend/src/apis/round.rs index 3afa4a8c..da1b0d34 100644 --- a/backend/src/apis/round.rs +++ b/backend/src/apis/round.rs @@ -45,7 +45,6 @@ impl KZGProof { /// # Type Parameters /// /// * `N_CURRENCIES`: The number of currencies for which solvency is verified in this round. -/// * `N_POINTS`: The number of points in the `UnivariateGrandSum` circuit, which is `N_CURRENCIES + 1`. /// * `N_USERS`: The number of users involved in this round of the protocol. /// /// These parameters are used for initializing the `UnivariateGrandSum` circuit within the `Snapshot` struct. @@ -57,14 +56,13 @@ impl KZGProof { /// * `snapshot`: A `Snapshot` struct capturing the round's state, including user identities and balances. /// * `signer`: A reference to a `SummaSigner`, the entity responsible for signing transactions with the Summa contract in this round. /// -pub struct Round<'a, const N_CURRENCIES: usize, const N_POINTS: usize, const N_USERS: usize> { +pub struct Round<'a, const N_CURRENCIES: usize, const N_USERS: usize> { timestamp: u64, - snapshot: Snapshot, + snapshot: Snapshot, signer: &'a SummaSigner, } -impl - Round<'_, N_CURRENCIES, N_POINTS, N_USERS> +impl Round<'_, N_CURRENCIES, N_USERS> where [usize; N_CURRENCIES + 1]: Sized, { @@ -75,10 +73,10 @@ where params: ParamsKZG, verifying_key: VerifyingKey, timestamp: u64, - ) -> Round<'_, N_CURRENCIES, N_POINTS, N_USERS> { + ) -> Round<'_, N_CURRENCIES, N_USERS> { Round { timestamp, - snapshot: Snapshot::::new( + snapshot: Snapshot::::new( zk_snark_proof, advice_polys, params, @@ -118,15 +116,14 @@ where /// * `params`: The parameters for the KZG commitment scheme. /// * `verifying_key`: The verifying key for getting domains, which is used for generating inclusion proofs. /// -pub struct Snapshot { +pub struct Snapshot { zk_snark_proof: Vec, advice_polys: AdviceSingle, params: ParamsKZG, verifying_key: VerifyingKey, } -impl - Snapshot +impl Snapshot where [usize; N_CURRENCIES + 1]: Sized, { diff --git a/backend/src/tests.rs b/backend/src/tests.rs index 7d8a918c..81e794ac 100644 --- a/backend/src/tests.rs +++ b/backend/src/tests.rs @@ -150,7 +150,6 @@ mod test { const K: u32 = 17; const N_CURRENCIES: usize = 2; - const N_POINTS: usize = N_CURRENCIES + 1; const N_USERS: usize = 16; const PARAMS_PATH: &str = "../backend/ptau/hermez-raw-17"; @@ -210,7 +209,7 @@ mod test { &[instances.clone()], ); - let mut round_one = Round::::new( + let mut round_one = Round::::new( &signer, zk_snark_proof.clone(), advice_polys.clone(), @@ -218,7 +217,7 @@ mod test { vk.clone(), 1, ); - let mut round_two = Round::::new( + let mut round_two = Round::::new( &signer, zk_snark_proof, advice_polys, @@ -331,7 +330,7 @@ mod test { )); let snapshot_time = 1u64; - let mut round = Round::::new( + let mut round = Round::::new( &signer, zk_snark_proof, advice_polys, diff --git a/kzg_prover/benches/kzg.rs b/kzg_prover/benches/kzg.rs index c883d035..ab20584d 100644 --- a/kzg_prover/benches/kzg.rs +++ b/kzg_prover/benches/kzg.rs @@ -18,8 +18,6 @@ use summa_solvency::{ verify_user_inclusion, }, }, - cryptocurrency::Cryptocurrency, - entry::Entry, utils::{big_uint_to_fp, generate_dummy_entries}, }; @@ -27,7 +25,6 @@ fn bench_kzg< const K: u32, const N_USERS: usize, const N_CURRENCIES: usize, - const N_POINTS: usize, CONFIG: CircuitConfig, >( name: &str, @@ -243,7 +240,7 @@ fn bench_kzg< b.iter_batched( || (column_range.clone(), omega, user_index), |(column_range, omega, user_index)| { - verify_user_inclusion::( + verify_user_inclusion( ¶ms, &zk_snark_proof, &openings_batch_proof, @@ -259,39 +256,30 @@ fn bench_kzg< fn criterion_benchmark(_c: &mut Criterion) { const N_CURRENCIES: usize = 1; - const N_POINTS: usize = N_CURRENCIES + 1; // Demonstrating that a higher value of K has a more significant impact on benchmark performance than the number of users #[cfg(not(feature = "no_range_check"))] { const K: u32 = 17; const N_USERS: usize = 2usize.pow(K) + 2usize.pow(16) - 6; // Subtracting 2^16 (reserved for range checks) and 6 (reserved rows) from 2^K. - bench_kzg::< - K, - N_USERS, - N_CURRENCIES, - N_POINTS, - UnivariateGrandSumConfig, - >(format!("K = {K}, N_USERS = {N_USERS}, N_CURRENCIES = {N_CURRENCIES}").as_str()); + bench_kzg::>( + format!("K = {K}, N_USERS = {N_USERS}, N_CURRENCIES = {N_CURRENCIES}").as_str(), + ); } #[cfg(not(feature = "no_range_check"))] { const K: u32 = 18; const N_USERS: usize = 2usize.pow(K) - 2usize.pow(16) - 6; // Subtracting 2^16 (reserved for range checks) and 6 (reserved rows) from 2^K. - bench_kzg::< - K, - N_USERS, - N_CURRENCIES, - N_POINTS, - UnivariateGrandSumConfig, - >(format!("K = {K}, N_USERS = {N_USERS}, N_CURRENCIES = {N_CURRENCIES}").as_str()); + bench_kzg::>( + format!("K = {K}, N_USERS = {N_USERS}, N_CURRENCIES = {N_CURRENCIES}").as_str(), + ); } //Use the following benchmarks for quick evaluation/prototyping (no range check) #[cfg(feature = "no_range_check")] { const K: u32 = 9; const N_USERS: usize = 2usize.pow(K) - 6; - bench_kzg::>( + bench_kzg::>( format!("K = {K}, N_USERS = {N_USERS}, N_CURRENCIES = {N_CURRENCIES}").as_str(), ); } @@ -299,7 +287,7 @@ fn criterion_benchmark(_c: &mut Criterion) { { const K: u32 = 10; const N_USERS: usize = 2usize.pow(K) - 6; - bench_kzg::>( + bench_kzg::>( format!("K = {K}, N_USERS = {N_USERS}, N_CURRENCIES = {N_CURRENCIES}").as_str(), ); } @@ -307,7 +295,7 @@ fn criterion_benchmark(_c: &mut Criterion) { { const K: u32 = 11; const N_USERS: usize = 2usize.pow(K) - 6; - bench_kzg::>( + bench_kzg::>( format!("K = {K}, N_USERS = {N_USERS}, N_CURRENCIES = {N_CURRENCIES}").as_str(), ); } @@ -315,7 +303,7 @@ fn criterion_benchmark(_c: &mut Criterion) { { const K: u32 = 12; const N_USERS: usize = 2usize.pow(K) - 6; - bench_kzg::>( + bench_kzg::>( format!("K = {K}, N_USERS = {N_USERS}, N_CURRENCIES = {N_CURRENCIES}").as_str(), ); } diff --git a/kzg_prover/bin/gen_commit_and_proofs.rs b/kzg_prover/bin/gen_commit_and_proofs.rs index 09171d3e..69f2973b 100644 --- a/kzg_prover/bin/gen_commit_and_proofs.rs +++ b/kzg_prover/bin/gen_commit_and_proofs.rs @@ -104,7 +104,7 @@ fn main() { let poly_length = 1 << u64::from(K); let total_balances = csv_total .iter() - .map(|x| big_uint_to_fp(&(x)) * Fp::from(poly_length).invert().unwrap()) + .map(|x| big_uint_to_fp(x) * Fp::from(poly_length).invert().unwrap()) .collect::>(); let mut grand_sums_kzg_proof = Vec::new(); @@ -165,8 +165,8 @@ fn main() { let user_values = &entries .get(user_index as usize) .map(|entry| { - std::iter::once(big_uint_to_fp(&(entry.username_as_big_uint()))) - .chain(entry.balances().iter().map(|x| big_uint_to_fp(x))) + std::iter::once(big_uint_to_fp(entry.username_as_big_uint())) + .chain(entry.balances().iter().map(big_uint_to_fp)) .collect::>() }) .unwrap(); diff --git a/kzg_prover/src/circuits/tests.rs b/kzg_prover/src/circuits/tests.rs index b1a5b4d7..6641cf99 100644 --- a/kzg_prover/src/circuits/tests.rs +++ b/kzg_prover/src/circuits/tests.rs @@ -25,7 +25,6 @@ mod test { const K: u32 = 17; const N_CURRENCIES: usize = 2; - const N_POINTS: usize = N_CURRENCIES + 1; const N_USERS: usize = 16; #[test] @@ -239,7 +238,7 @@ mod test { let column_range = 0..N_CURRENCIES + 1; // The Verifier verifies the inclusion of the 4th user entry - let (inclusion_verified, id_and_balance_values) = verify_user_inclusion::( + let (inclusion_verified, id_and_balance_values) = verify_user_inclusion( ¶ms, &zk_snark_proof, &openings_batch_proof, @@ -314,7 +313,7 @@ mod test { // Test failure case with the wrong group generator // Slightly modify the generator let bad_omega = omega.sub(&Fp::one()); - let (balances_verified, _) = verify_user_inclusion::( + let (balances_verified, _) = verify_user_inclusion( ¶ms, &zk_snark_proof, &openings_batch_proof, diff --git a/kzg_prover/src/circuits/utils.rs b/kzg_prover/src/circuits/utils.rs index 2a9c5b8d..eefb06ef 100644 --- a/kzg_prover/src/circuits/utils.rs +++ b/kzg_prover/src/circuits/utils.rs @@ -365,8 +365,6 @@ pub fn verify_grand_sum_openings( /// Verifies the KZG batch proof of the polynomial openings being the evaluations /// of the advice polynomials at the point corresponding to the user index /// -/// * `N_POINTS` - the size of the user entry being verified (e.g., 1 ID value + 4 balance values = 5) -/// /// # Arguments /// * `params` - the KZG parameters /// * `zk_snark_proof` - the ZK-SNARK proof of the circuit whose advice columns contain the user entry polynomials @@ -378,7 +376,7 @@ pub fn verify_grand_sum_openings( /// # Returns /// * `bool` - whether the user entry openings are verified correctly /// * `Vec` - the evaluations of the advice polynomials at the point corresponding to the user index -pub fn verify_user_inclusion( +pub fn verify_user_inclusion( params: &ParamsKZG, zk_snark_proof: &[u8], balance_opening_batch_proof: &[u8], From 214f095c981c5d7fd1cda680d1bdcf1c6b048bf8 Mon Sep 17 00:00:00 2001 From: Alex Kuzmin Date: Thu, 14 Mar 2024 18:25:41 +0800 Subject: [PATCH 2/2] Fix the number of points calculation --- backend/examples/summa_solvency_flow.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/backend/examples/summa_solvency_flow.rs b/backend/examples/summa_solvency_flow.rs index c4b34453..8c403ba8 100644 --- a/backend/examples/summa_solvency_flow.rs +++ b/backend/examples/summa_solvency_flow.rs @@ -142,7 +142,7 @@ async fn main() -> Result<(), Box> { let commitment = summa_contract.commitments(snapshot_time).call().await?; // Ensure the length of the commitment matches the expected size for the number of points. - assert_eq!(commitment.to_vec().len(), 0x40 * (N_CURRENCIES - 1)); + assert_eq!(commitment.to_vec().len(), 0x40 * (N_CURRENCIES + 1)); // Validate the inclusion proof using the contract verifier. let mut verification_result = false;