Struct snarkvm_algorithms::polycommit::sonic_pc::SonicKZG10
source · pub struct SonicKZG10<E: PairingEngine, S: AlgebraicSponge<E::Fq, 2>> { /* private fields */ }
Expand description
Polynomial commitment based on [KZG10], with degree enforcement and batching taken from [MBKM19, “Sonic”] (more precisely, their counterparts in [Gabizon19, “AuroraLight”] that avoid negative G1 powers). The (optional) hiding property of the commitment scheme follows the approach described in [CHMMVW20, “Marlin”].
Implementations§
source§impl<E: PairingEngine, S: AlgebraicSponge<E::Fq, 2>> SonicKZG10<E, S>
impl<E: PairingEngine, S: AlgebraicSponge<E::Fq, 2>> SonicKZG10<E, S>
pub fn load_srs(max_degree: usize) -> Result<UniversalParams<E>, PCError>
pub fn trim( pp: &UniversalParams<E>, supported_degree: usize, supported_lagrange_sizes: impl IntoIterator<Item = usize>, supported_hiding_bound: usize, enforced_degree_bounds: Option<&[usize]> ) -> Result<(CommitterKey<E>, UniversalVerifier<E>)>
sourcepub fn commit<'b>(
universal_prover: &UniversalProver<E>,
ck: &CommitterUnionKey<'_, E>,
polynomials: impl IntoIterator<Item = LabeledPolynomialWithBasis<'b, E::Fr>>,
rng: Option<&mut dyn RngCore>
) -> Result<(Vec<LabeledCommitment<Commitment<E>>>, Vec<Randomness<E>>), PCError>
pub fn commit<'b>( universal_prover: &UniversalProver<E>, ck: &CommitterUnionKey<'_, E>, polynomials: impl IntoIterator<Item = LabeledPolynomialWithBasis<'b, E::Fr>>, rng: Option<&mut dyn RngCore> ) -> Result<(Vec<LabeledCommitment<Commitment<E>>>, Vec<Randomness<E>>), PCError>
Outputs commitments to polynomials
.
If polynomials[i].is_hiding()
, then the i
-th commitment is hiding
up to polynomials.hiding_bound()
queries.
rng
should not be None
if polynomials[i].is_hiding() == true
for any i
.
If for some i
, polynomials[i].is_hiding() == false
, then the
corresponding randomness is Randomness<E>::empty()
.
If for some i
, polynomials[i].degree_bound().is_some()
, then that
polynomial will have the corresponding degree bound enforced.
pub fn combine_for_open<'a>(
universal_prover: &UniversalProver<E>,
ck: &CommitterUnionKey<'_, E>,
labeled_polynomials: impl ExactSizeIterator<Item = &'a LabeledPolynomial<E::Fr>>,
rands: impl ExactSizeIterator<Item = &'a Randomness<E>>,
fs_rng: &mut S
) -> Result<(DensePolynomial<E::Fr>, Randomness<E>)>where
Randomness<E>: 'a,
Commitment<E>: 'a,
sourcepub fn batch_open<'a>(
universal_prover: &UniversalProver<E>,
ck: &CommitterUnionKey<'_, E>,
labeled_polynomials: impl ExactSizeIterator<Item = &'a LabeledPolynomial<E::Fr>>,
query_set: &QuerySet<E::Fr>,
rands: impl ExactSizeIterator<Item = &'a Randomness<E>>,
fs_rng: &mut S
) -> Result<BatchProof<E>>where
Randomness<E>: 'a,
Commitment<E>: 'a,
pub fn batch_open<'a>(
universal_prover: &UniversalProver<E>,
ck: &CommitterUnionKey<'_, E>,
labeled_polynomials: impl ExactSizeIterator<Item = &'a LabeledPolynomial<E::Fr>>,
query_set: &QuerySet<E::Fr>,
rands: impl ExactSizeIterator<Item = &'a Randomness<E>>,
fs_rng: &mut S
) -> Result<BatchProof<E>>where
Randomness<E>: 'a,
Commitment<E>: 'a,
On input a list of labeled polynomials and a query set, open
outputs a proof of evaluation
of the polynomials at the points in the query set.
pub fn batch_check<'a>(
vk: &UniversalVerifier<E>,
commitments: impl IntoIterator<Item = &'a LabeledCommitment<Commitment<E>>>,
query_set: &QuerySet<E::Fr>,
values: &Evaluations<E::Fr>,
proof: &BatchProof<E>,
fs_rng: &mut S
) -> Result<bool>where
Commitment<E>: 'a,
pub fn open_combinations<'a>(
universal_prover: &UniversalProver<E>,
ck: &CommitterUnionKey<'_, E>,
linear_combinations: impl IntoIterator<Item = &'a LinearCombination<E::Fr>>,
polynomials: impl IntoIterator<Item = LabeledPolynomial<E::Fr>>,
rands: impl IntoIterator<Item = &'a Randomness<E>>,
query_set: &QuerySet<E::Fr>,
fs_rng: &mut S
) -> Result<BatchLCProof<E>>where
Randomness<E>: 'a,
Commitment<E>: 'a,
sourcepub fn check_combinations<'a>(
vk: &UniversalVerifier<E>,
linear_combinations: impl IntoIterator<Item = &'a LinearCombination<E::Fr>>,
commitments: impl IntoIterator<Item = &'a LabeledCommitment<Commitment<E>>>,
query_set: &QuerySet<E::Fr>,
evaluations: &Evaluations<E::Fr>,
proof: &BatchLCProof<E>,
fs_rng: &mut S
) -> Result<bool>where
Commitment<E>: 'a,
pub fn check_combinations<'a>(
vk: &UniversalVerifier<E>,
linear_combinations: impl IntoIterator<Item = &'a LinearCombination<E::Fr>>,
commitments: impl IntoIterator<Item = &'a LabeledCommitment<Commitment<E>>>,
query_set: &QuerySet<E::Fr>,
evaluations: &Evaluations<E::Fr>,
proof: &BatchLCProof<E>,
fs_rng: &mut S
) -> Result<bool>where
Commitment<E>: 'a,
Checks that values
are the true evaluations at query_set
of the polynomials
committed in labeled_commitments
.
Trait Implementations§
source§impl<E: Clone + PairingEngine, S: Clone + AlgebraicSponge<E::Fq, 2>> Clone for SonicKZG10<E, S>
impl<E: Clone + PairingEngine, S: Clone + AlgebraicSponge<E::Fq, 2>> Clone for SonicKZG10<E, S>
source§fn clone(&self) -> SonicKZG10<E, S>
fn clone(&self) -> SonicKZG10<E, S>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more