pub struct RingProofParams<S: RingSuite> {
pub pcs: PcsParams<S>,
pub piop: PiopParams<S>,
}Expand description
Ring proof parameters.
Contains the cryptographic parameters needed for ring proof generation and verification:
pcs: Polynomial Commitment Scheme parameters (KZG setup)piop: Polynomial Interactive Oracle Proof parameters
Fields§
§pcs: PcsParams<S>PCS parameters.
piop: PiopParams<S>PIOP parameters.
Implementations§
Source§impl<S: RingSuite> RingProofParams<S>
impl<S: RingSuite> RingProofParams<S>
Sourcepub fn from_seed(ring_size: usize, seed: [u8; 32]) -> Self
pub fn from_seed(ring_size: usize, seed: [u8; 32]) -> Self
Construct deterministic ring proof params for the given ring size.
Creates parameters using a transcript-based RNG seeded with seed.
Sourcepub fn from_rand(ring_size: usize, rng: &mut impl RngCore) -> Self
pub fn from_rand(ring_size: usize, rng: &mut impl RngCore) -> Self
Construct random ring proof params for the given ring size.
Generates a new KZG setup with sufficient degree to support the specified ring size.
Sourcepub fn from_pcs_params(
ring_size: usize,
pcs_params: PcsParams<S>,
) -> Result<Self, Error>
pub fn from_pcs_params( ring_size: usize, pcs_params: PcsParams<S>, ) -> Result<Self, Error>
Construct ring proof params from existing KZG setup.
Truncates the setup if larger than needed, or returns an error if it is insufficient for the specified ring size.
Sourcepub fn max_ring_size(&self) -> usize
pub fn max_ring_size(&self) -> usize
The max ring size these parameters are able to handle.
Sourcepub fn prover_key(
&self,
pks: &[AffinePoint<S>],
) -> Result<RingProverKey<S>, Error>
pub fn prover_key( &self, pks: &[AffinePoint<S>], ) -> Result<RingProverKey<S>, Error>
Create a prover key for the given ring of public keys.
Returns Error::InvalidData if pks exceeds Self::max_ring_size.
Sourcepub fn prover(
&self,
prover_key: RingProverKey<S>,
key_index: usize,
) -> RingProver<S>
pub fn prover( &self, prover_key: RingProverKey<S>, key_index: usize, ) -> RingProver<S>
Create a prover instance for a specific position in the ring.
Sourcepub fn verifier_key(
&self,
pks: &[AffinePoint<S>],
) -> Result<RingVerifierKey<S>, Error>
pub fn verifier_key( &self, pks: &[AffinePoint<S>], ) -> Result<RingVerifierKey<S>, Error>
Create a verifier key for the given ring of public keys.
Returns Error::InvalidData if pks exceeds Self::max_ring_size.
Sourcepub fn verifier_key_from_commitment(
&self,
commitment: RingCommitment<S>,
) -> RingVerifierKey<S>
pub fn verifier_key_from_commitment( &self, commitment: RingCommitment<S>, ) -> RingVerifierKey<S>
Create a verifier key from a precomputed ring commitment.
The commitment can be obtained from an existing verifier key via
RingVerifierKey::commitment.
Sourcepub fn verifier_key_builder(
&self,
) -> (VerifierKeyBuilder<S>, RingBuilderPcsParams<S>)
pub fn verifier_key_builder( &self, ) -> (VerifierKeyBuilder<S>, RingBuilderPcsParams<S>)
Create a builder for incremental construction of the verifier key.
Sourcepub fn verifier(&self, verifier_key: RingVerifierKey<S>) -> RingVerifier<S>
pub fn verifier(&self, verifier_key: RingVerifierKey<S>) -> RingVerifier<S>
Create a verifier instance from a verifier key.
Sourcepub fn verifier_no_context(
verifier_key: RingVerifierKey<S>,
ring_size: usize,
) -> RingVerifier<S>
pub fn verifier_no_context( verifier_key: RingVerifierKey<S>, ring_size: usize, ) -> RingVerifier<S>
Create a verifier instance without requiring the full parameters.
Computes necessary PIOP parameters on-the-fly from the ring size rather
than reusing the ones stored in self.
Sourcepub const fn padding_point() -> AffinePoint<S>
pub const fn padding_point() -> AffinePoint<S>
Get the padding point.
This is a point of unknown dlog that can be used in place of any key during ring construction.
Trait Implementations§
Source§impl<S: RingSuite> CanonicalDeserialize for RingProofParams<S>
impl<S: RingSuite> CanonicalDeserialize for RingProofParams<S>
Source§fn deserialize_with_mode<R: Read>(
reader: R,
compress: Compress,
validate: Validate,
) -> Result<Self, SerializationError>
fn deserialize_with_mode<R: Read>( reader: R, compress: Compress, validate: Validate, ) -> Result<Self, SerializationError>
fn deserialize_compressed<R>(reader: R) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_compressed_unchecked<R>(
reader: R,
) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_uncompressed<R>(reader: R) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_uncompressed_unchecked<R>(
reader: R,
) -> Result<Self, SerializationError>where
R: Read,
Source§impl<S: RingSuite> CanonicalSerialize for RingProofParams<S>
impl<S: RingSuite> CanonicalSerialize for RingProofParams<S>
Source§fn serialize_with_mode<W: Write>(
&self,
writer: W,
compress: Compress,
) -> Result<(), SerializationError>
fn serialize_with_mode<W: Write>( &self, writer: W, compress: Compress, ) -> Result<(), SerializationError>
fn serialized_size(&self, compress: Compress) -> usize
fn serialize_compressed<W>(&self, writer: W) -> Result<(), SerializationError>where
W: Write,
fn compressed_size(&self) -> usize
fn serialize_uncompressed<W>(&self, writer: W) -> Result<(), SerializationError>where
W: Write,
fn uncompressed_size(&self) -> usize
Source§impl<S: Clone + RingSuite> Clone for RingProofParams<S>
impl<S: Clone + RingSuite> Clone for RingProofParams<S>
Source§fn clone(&self) -> RingProofParams<S>
fn clone(&self) -> RingProofParams<S>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<S: RingSuite> Valid for RingProofParams<S>
impl<S: RingSuite> Valid for RingProofParams<S>
fn check(&self) -> Result<(), SerializationError>
fn batch_check<'a>(
batch: impl Iterator<Item = &'a Self> + Send,
) -> Result<(), SerializationError>where
Self: 'a,
Auto Trait Implementations§
impl<S> Freeze for RingProofParams<S>
impl<S> RefUnwindSafe for RingProofParams<S>where
<<S as Suite>::Affine as AffineRepr>::Config: Sized,
<<S as Suite>::Affine as AffineRepr>::BaseField: Sized + RefUnwindSafe,
<S as Suite>::Affine: Sized,
<<S as RingSuite>::Pairing as Pairing>::G1Affine: RefUnwindSafe,
<<S as RingSuite>::Pairing as Pairing>::G2Affine: RefUnwindSafe,
impl<S> Send for RingProofParams<S>
impl<S> Sync for RingProofParams<S>
impl<S> Unpin for RingProofParams<S>
impl<S> UnsafeUnpin for RingProofParams<S>where
<<S as Suite>::Affine as AffineRepr>::Config: Sized,
<<S as Suite>::Affine as AffineRepr>::BaseField: Sized + UnsafeUnpin,
<S as Suite>::Affine: Sized,
impl<S> UnwindSafe for RingProofParams<S>where
<<S as Suite>::Affine as AffineRepr>::Config: Sized,
<<S as Suite>::Affine as AffineRepr>::BaseField: Sized + UnwindSafe,
<S as Suite>::Affine: Sized,
<<S as RingSuite>::Pairing as Pairing>::G1Affine: UnwindSafe,
<<S as RingSuite>::Pairing as Pairing>::G2Affine: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CanonicalSerializeHashExt for Twhere
T: CanonicalSerialize,
impl<T> CanonicalSerializeHashExt for Twhere
T: CanonicalSerialize,
fn hash<H>(&self) -> GenericArray<u8, <H as OutputSizeUser>::OutputSize>where
H: Digest,
fn hash_uncompressed<H>(
&self,
) -> GenericArray<u8, <H as OutputSizeUser>::OutputSize>where
H: Digest,
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more