pub struct RingSetup<S: RingSuite> {
pub pcs_params: PcsParams<S>,
pub ring_ctx: RingContext<S>,
}Expand description
Ring proof setup.
Contains the cryptographic parameters needed for ring proof key construction, proving and verification:
pcs_params: Polynomial Commitment Scheme parameters (KZG setup)ring_ctx: Ring context containing the PIOP parameters
Fields§
§pcs_params: PcsParams<S>PCS parameters.
ring_ctx: RingContext<S>Ring context (PIOP parameters).
Implementations§
Source§impl<S: RingSuite> RingSetup<S>
impl<S: RingSuite> RingSetup<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 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 the max ring size.
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 the 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 ring_context(&self) -> &RingContext<S>
pub fn ring_context(&self) -> &RingContext<S>
Get a reference to the lightweight RingContext.
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.
Methods from Deref<Target = RingContext<S>>§
Sourcepub fn max_ring_size(&self) -> usize
pub fn max_ring_size(&self) -> usize
The max ring size this context is able to handle.
Sourcepub fn ring_prover(
&self,
prover_key: RingProverKey<S>,
key_index: usize,
) -> RingProver<S>
pub fn ring_prover( &self, prover_key: RingProverKey<S>, key_index: usize, ) -> RingProver<S>
Create a prover instance for a specific position in the ring.
Sourcepub fn ring_verifier(&self, verifier_key: RingVerifierKey<S>) -> RingVerifier<S>
pub fn ring_verifier(&self, verifier_key: RingVerifierKey<S>) -> RingVerifier<S>
Create a verifier instance from a verifier key.
Trait Implementations§
Source§impl<S: RingSuite> CanonicalDeserialize for RingSetup<S>
impl<S: RingSuite> CanonicalDeserialize for RingSetup<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 RingSetup<S>
impl<S: RingSuite> CanonicalSerialize for RingSetup<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
Auto Trait Implementations§
impl<S> Freeze for RingSetup<S>
impl<S> RefUnwindSafe for RingSetup<S>where
<S as Suite>::Affine: Sized,
<<S as Suite>::Affine as AffineRepr>::Config: Sized,
<<S as Suite>::Affine as AffineRepr>::BaseField: Sized + RefUnwindSafe,
<<S as RingSuite>::Pairing as Pairing>::G1Affine: RefUnwindSafe,
<<S as RingSuite>::Pairing as Pairing>::G2Affine: RefUnwindSafe,
impl<S> Send for RingSetup<S>
impl<S> Sync for RingSetup<S>
impl<S> Unpin for RingSetup<S>
impl<S> UnsafeUnpin for RingSetup<S>where
<S as Suite>::Affine: Sized,
<<S as Suite>::Affine as AffineRepr>::Config: Sized,
<<S as Suite>::Affine as AffineRepr>::BaseField: Sized + UnsafeUnpin,
impl<S> UnwindSafe for RingSetup<S>where
<S as Suite>::Affine: Sized,
<<S as Suite>::Affine as AffineRepr>::Config: Sized,
<<S as Suite>::Affine as AffineRepr>::BaseField: Sized + UnwindSafe,
<<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