Skip to content

Commit

Permalink
Poly-commitment/IPA: introduce PBT on the SRS trait
Browse files Browse the repository at this point in the history
Moving the regression test regarding the number of expected chunks into this PBT
module.
Transforming it into a PBT helps testing the output with the different PCS
available in the library.
  • Loading branch information
dannywillems committed Oct 5, 2024
1 parent 730c145 commit 9db8c60
Show file tree
Hide file tree
Showing 3 changed files with 86 additions and 63 deletions.
7 changes: 5 additions & 2 deletions poly-commitment/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ pub mod ipa;
/// KZG polynomial commitment scheme
pub mod kzg;

// Exposing property based tests for the SRS trait
pub mod pbt_srs;

pub use commitment::PolyComm;

use crate::{
Expand Down Expand Up @@ -76,8 +79,8 @@ pub trait SRS<G: CommitmentCurve>: Clone + Sized {
/// also contain the additional chunks.
///
/// See the test
/// `test_regression_commit_non_hiding_expected_number_of_chunks` for an
/// example of the number of chunks returned.
/// [crate::pbt_srs::test_regression_commit_non_hiding_expected_number_of_chunks]
/// for an example of the number of chunks returned.
fn commit_non_hiding(
&self,
plnm: &DensePolynomial<G::ScalarField>,
Expand Down
77 changes: 77 additions & 0 deletions poly-commitment/src/pbt_srs.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
//! This module defines Property-based tests for the SRS trait.
//! It includes tests regarding methods the SRS trait should implement.
//! It aims to verify the implementation respects the properties described in
//! the documentation of the methods.
use ark_ff::Zero;
use ark_poly::{univariate::DensePolynomial, DenseUVPolynomial};
use rand::Rng;

use crate::{commitment::CommitmentCurve, SRS};

// Testing how many chunks are generated with different polynomial sizes and
// different number of chunks requested.
pub fn test_regression_commit_non_hiding_expected_number_of_chunks<
G: CommitmentCurve,
Srs: SRS<G>,
>() {
let mut rng = &mut o1_utils::tests::make_test_rng(None);
// maximum random srs size is 64
let log2_srs_size = rng.gen_range(1..6);
let srs_size = 1 << log2_srs_size;
let srs = Srs::create(srs_size);

// If we have a polynomial of the size of the SRS (i.e. of degree `srs_size -
// 1`), and we request 1 chunk, we should get 1 chunk.
{
// srs_size is the number of evaluation degree
let poly_degree = srs_size - 1;
let poly = DensePolynomial::<G::ScalarField>::rand(poly_degree, &mut rng);
let commitment = srs.commit_non_hiding(&poly, 1);
assert_eq!(commitment.len(), 1);
}

// If we have a polynomial of the size of the SRS (i.e. of degree `srs_size -
// 1`), and we request k chunks (k > 1), we should get k chunk.
{
// srs_size is the number of evaluation degree
let poly_degree = srs_size - 1;
// maximum 10 chunks for the test
let k = rng.gen_range(2..10);
let poly = DensePolynomial::<G::ScalarField>::rand(poly_degree, &mut rng);
let commitment = srs.commit_non_hiding(&poly, k);
assert_eq!(commitment.len(), k);
}

// Same than the two previous cases, but with the special polynomial equals to zero.
{
let k = rng.gen_range(1..10);
let poly = DensePolynomial::<G::ScalarField>::zero();
let commitment = srs.commit_non_hiding(&poly, k);
assert_eq!(commitment.len(), k);
}

// Polynomial of exactly a multiple of the SRS size, i.e degree is k *
// srs_size - 1.
{
let k = rng.gen_range(2..5);
let poly_degree = k * srs_size - 1;
let poly = DensePolynomial::<G::ScalarField>::rand(poly_degree, &mut rng);
// if we request a number of chunks smaller than the multiple, we will
// still get a number of chunks equals to the multiple.
let requested_num_chunks = rng.gen_range(1..k);
let commitment = srs.commit_non_hiding(&poly, requested_num_chunks);
assert_eq!(commitment.len(), k);

// if we request a number of chunks equals to the multiple, we will get
// the exact number of chunks.
let commitment = srs.commit_non_hiding(&poly, k);
assert_eq!(commitment.len(), k);

// if we request a number of chunks greater than the multiple, we will
// get the exact number of chunks requested.
let requested_num_chunks = rng.gen_range(k + 1..10);
let commitment = srs.commit_non_hiding(&poly, requested_num_chunks);
assert_eq!(commitment.len(), requested_num_chunks);
}
}
65 changes: 4 additions & 61 deletions poly-commitment/tests/ipa_commitment.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,15 @@ use ark_poly::{
Radix2EvaluationDomain as D, Radix2EvaluationDomain,
};
use groupmap::GroupMap;
use mina_curves::pasta::{Fp, Vesta as VestaG};
use mina_curves::pasta::{Fp, Pallas, Vesta as VestaG};
use mina_poseidon::{
constants::PlonkSpongeConstantsKimchi as SC, sponge::DefaultFqSponge, FqSponge,
};
use o1_utils::ExtendedDensePolynomial;
use poly_commitment::{
commitment::{combined_inner_product, BatchEvaluationProof, CommitmentCurve, Evaluation},
ipa::{DensePolynomialOrEvaluations, SRS},
PolyComm, SRS as _,
pbt_srs, PolyComm, SRS as _,
};
use rand::Rng;
use std::array;
Expand Down Expand Up @@ -220,63 +220,6 @@ fn test_opening_proof() {
// different number of chunks requested.
#[test]
fn test_regression_commit_non_hiding_expected_number_of_chunks() {
let mut rng = &mut o1_utils::tests::make_test_rng(None);
// maximum random srs size is 64
let log2_srs_size = rng.gen_range(1..6);
let srs_size = 1 << log2_srs_size;
let srs = SRS::<VestaG>::create(srs_size);

// If we have a polynomial of the size of the SRS (i.e. of degree `srs_size -
// 1`), and we request 1 chunk, we should get 1 chunk.
{
// srs_size is the number of evaluation degree
let poly_degree = srs_size - 1;
let poly = DensePolynomial::<Fp>::rand(poly_degree, &mut rng);
let commitment = srs.commit_non_hiding(&poly, 1);
assert_eq!(commitment.len(), 1);
}

// If we have a polynomial of the size of the SRS (i.e. of degree `srs_size -
// 1`), and we request k chunks (k > 1), we should get k chunk.
{
// srs_size is the number of evaluation degree
let poly_degree = srs_size - 1;
// maximum 10 chunks for the test
let k = rng.gen_range(2..10);
let poly = DensePolynomial::<Fp>::rand(poly_degree, &mut rng);
let commitment = srs.commit_non_hiding(&poly, k);
assert_eq!(commitment.len(), k);
}

// Same than the two previous cases, but with the special polynomial equals to zero.
{
let k = rng.gen_range(1..10);
let poly = DensePolynomial::<Fp>::zero();
let commitment = srs.commit_non_hiding(&poly, k);
assert_eq!(commitment.len(), k);
}

// Polynomial of exactly a multiple of the SRS size, i.e degree is k *
// srs_size - 1.
{
let k = rng.gen_range(2..5);
let poly_degree = k * srs_size - 1;
let poly = DensePolynomial::<Fp>::rand(poly_degree, &mut rng);
// if we request a number of chunks smaller than the multiple, we will
// still get a number of chunks equals to the multiple.
let requested_num_chunks = rng.gen_range(1..k);
let commitment = srs.commit_non_hiding(&poly, requested_num_chunks);
assert_eq!(commitment.len(), k);

// if we request a number of chunks equals to the multiple, we will get
// the exact number of chunks.
let commitment = srs.commit_non_hiding(&poly, k);
assert_eq!(commitment.len(), k);

// if we request a number of chunks greater than the multiple, we will
// get the exact number of chunks requested.
let requested_num_chunks = rng.gen_range(k + 1..10);
let commitment = srs.commit_non_hiding(&poly, requested_num_chunks);
assert_eq!(commitment.len(), requested_num_chunks);
}
pbt_srs::test_regression_commit_non_hiding_expected_number_of_chunks::<VestaG, SRS<VestaG>>();
pbt_srs::test_regression_commit_non_hiding_expected_number_of_chunks::<Pallas, SRS<Pallas>>()
}

0 comments on commit 9db8c60

Please sign in to comment.