pub struct BrakedownPCParams<F: PrimeField, C: Config, H: CRHScheme> { /* private fields */ }Expand description
The public parameters for Brakedown PCS.
Implementations§
Source§impl<F, C, H> BrakedownPCParams<F, C, H>
impl<F, C, H> BrakedownPCParams<F, C, H>
Sourcepub fn default<R: RngCore>(
rng: &mut R,
poly_len: usize,
check_well_formedness: bool,
leaf_hash_param: LeafParam<C>,
two_to_one_hash_param: TwoToOneParam<C>,
col_hash_params: H::Parameters,
) -> Self
pub fn default<R: RngCore>( rng: &mut R, poly_len: usize, check_well_formedness: bool, leaf_hash_param: LeafParam<C>, two_to_one_hash_param: TwoToOneParam<C>, col_hash_params: H::Parameters, ) -> Self
Create a default UniversalParams, with the values from Fig. 2 from the paper.
Sourcepub fn new(
sec_param: usize,
a: (usize, usize),
b: (usize, usize),
r: (usize, usize),
base_len: usize,
n: usize,
m: usize,
a_dims: Vec<(usize, usize, usize)>,
b_dims: Vec<(usize, usize, usize)>,
a_mats: Vec<SprsMat<F>>,
b_mats: Vec<SprsMat<F>>,
check_well_formedness: bool,
leaf_hash_param: LeafParam<C>,
two_to_one_hash_param: TwoToOneParam<C>,
col_hash_params: H::Parameters,
) -> Self
pub fn new( sec_param: usize, a: (usize, usize), b: (usize, usize), r: (usize, usize), base_len: usize, n: usize, m: usize, a_dims: Vec<(usize, usize, usize)>, b_dims: Vec<(usize, usize, usize)>, a_mats: Vec<SprsMat<F>>, b_mats: Vec<SprsMat<F>>, check_well_formedness: bool, leaf_hash_param: LeafParam<C>, two_to_one_hash_param: TwoToOneParam<C>, col_hash_params: H::Parameters, ) -> Self
This function creates a UniversalParams. It does not check if the paramters are consistent/correct.
Trait Implementations§
Source§impl<F: PrimeField, C: Config, H: CRHScheme> CanonicalDeserialize for BrakedownPCParams<F, C, H>
impl<F: PrimeField, C: Config, H: CRHScheme> CanonicalDeserialize for BrakedownPCParams<F, C, H>
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>
The general deserialize method that takes in customization flags.
Source§fn deserialize_compressed<R>(reader: R) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_compressed<R>(reader: R) -> Result<Self, SerializationError>where
R: Read,
Reads
Self from reader using the compressed form if applicable.
Performs validation if applicable.Source§fn deserialize_compressed_unchecked<R>(
reader: R,
) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_compressed_unchecked<R>(
reader: R,
) -> Result<Self, SerializationError>where
R: Read,
Reads
Self from reader using the compressed form if applicable, without validating the
deserialized value. Read moreSource§fn deserialize_uncompressed<R>(reader: R) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_uncompressed<R>(reader: R) -> Result<Self, SerializationError>where
R: Read,
Reads
Self from reader using the uncompressed form. Performs validation if applicable.Source§fn deserialize_uncompressed_unchecked<R>(
reader: R,
) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_uncompressed_unchecked<R>(
reader: R,
) -> Result<Self, SerializationError>where
R: Read,
Reads
Self from reader using the uncompressed form, without validating the deserialized
value. Read moreSource§impl<F: PrimeField, C: Config, H: CRHScheme> CanonicalSerialize for BrakedownPCParams<F, C, H>
impl<F: PrimeField, C: Config, H: CRHScheme> CanonicalSerialize for BrakedownPCParams<F, C, H>
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>
The general serialize method that takes in customization flags.
Source§fn serialized_size(&self, compress: Compress) -> usize
fn serialized_size(&self, compress: Compress) -> usize
Returns the size in bytes of the serialized version of
self with the given compression mode.Source§fn serialize_compressed<W>(&self, writer: W) -> Result<(), SerializationError>where
W: Write,
fn serialize_compressed<W>(&self, writer: W) -> Result<(), SerializationError>where
W: Write,
Serializes
self into writer using the compressed form if applicable.Source§fn compressed_size(&self) -> usize
fn compressed_size(&self) -> usize
Returns the size in bytes of the compressed serialized version of
self.Source§fn serialize_uncompressed<W>(&self, writer: W) -> Result<(), SerializationError>where
W: Write,
fn serialize_uncompressed<W>(&self, writer: W) -> Result<(), SerializationError>where
W: Write,
Serializes
self into writer using the uncompressed form.Source§fn uncompressed_size(&self) -> usize
fn uncompressed_size(&self) -> usize
Returns the size in bytes of the uncompressed serialized version of
self.Source§impl<F: PrimeField, C: Config, H: CRHScheme> Clone for BrakedownPCParams<F, C, H>
impl<F: PrimeField, C: Config, H: CRHScheme> Clone for BrakedownPCParams<F, C, H>
Source§impl<F: PrimeField, C: Config, H: CRHScheme> Debug for BrakedownPCParams<F, C, H>
impl<F: PrimeField, C: Config, H: CRHScheme> Debug for BrakedownPCParams<F, C, H>
Source§impl<F, C, H> LinCodeParametersInfo<C, H> for BrakedownPCParams<F, C, H>
impl<F, C, H> LinCodeParametersInfo<C, H> for BrakedownPCParams<F, C, H>
Source§fn check_well_formedness(&self) -> bool
fn check_well_formedness(&self) -> bool
See whether there should be a well-formedness check.
Source§fn compute_dimensions(&self, _n: usize) -> (usize, usize)
fn compute_dimensions(&self, _n: usize) -> (usize, usize)
Compute the dimensions of the coefficient matrix.
Source§fn leaf_hash_param(&self) -> &<<C as Config>::LeafHash as CRHScheme>::Parameters
fn leaf_hash_param(&self) -> &<<C as Config>::LeafHash as CRHScheme>::Parameters
Get the hash parameters for obtaining leaf digest from leaf value.
Source§fn two_to_one_hash_param(
&self,
) -> &<<C as Config>::TwoToOneHash as TwoToOneCRHScheme>::Parameters
fn two_to_one_hash_param( &self, ) -> &<<C as Config>::TwoToOneHash as TwoToOneCRHScheme>::Parameters
Get the parameters for hashing nodes in the merkle tree.
Source§fn col_hash_params(&self) -> &<H as CRHScheme>::Parameters
fn col_hash_params(&self) -> &<H as CRHScheme>::Parameters
Get the parameters for hashing a vector of values,
representing a column of the coefficient matrix, into a leaf value.
Source§impl<F, C, H> PCCommitterKey for BrakedownPCParams<F, C, H>
impl<F, C, H> PCCommitterKey for BrakedownPCParams<F, C, H>
Source§fn max_degree(&self) -> usize
fn max_degree(&self) -> usize
Outputs the maximum degree supported by the universal parameters
Self was derived from.Source§fn supported_degree(&self) -> usize
fn supported_degree(&self) -> usize
Outputs the maximum degree supported by the committer key.
Source§impl<F, C, H> PCUniversalParams for BrakedownPCParams<F, C, H>
impl<F, C, H> PCUniversalParams for BrakedownPCParams<F, C, H>
Source§fn max_degree(&self) -> usize
fn max_degree(&self) -> usize
Outputs the maximum degree supported by the committer key.
Source§impl<F, C, H> PCVerifierKey for BrakedownPCParams<F, C, H>
impl<F, C, H> PCVerifierKey for BrakedownPCParams<F, C, H>
Source§fn max_degree(&self) -> usize
fn max_degree(&self) -> usize
Outputs the maximum degree supported by the universal parameters
Self was derived from.Source§fn supported_degree(&self) -> usize
fn supported_degree(&self) -> usize
Outputs the maximum degree supported by the verifier key.
Source§impl<F: PrimeField, C: Config, H: CRHScheme> Valid for BrakedownPCParams<F, C, H>
impl<F: PrimeField, C: Config, H: CRHScheme> Valid for BrakedownPCParams<F, C, H>
Source§const TRIVIAL_CHECK: bool
const TRIVIAL_CHECK: bool
Whether the
check method is trivial (i.e. always returns Ok(())). If this is true,
the batch_check method will skip all checks and return Ok(()).
This should be set to true for types where check is trivial, e.g.
integers, field elements, etc.
This is false by default.
This is primarily an optimization to skip unnecessary checks in batch_check.Source§fn check(&self) -> Result<(), SerializationError>
fn check(&self) -> Result<(), SerializationError>
Checks whether
self is valid. If self is valid, returns Ok(()). Otherwise, returns
an error describing the failure.
This method is called by deserialize_with_mode if validate is Validate::Yes.Source§fn batch_check<'a>(
batch: impl Iterator<Item = &'a Self> + Send,
) -> Result<(), SerializationError>where
Self: 'a,
fn batch_check<'a>(
batch: impl Iterator<Item = &'a Self> + Send,
) -> Result<(), SerializationError>where
Self: 'a,
Checks whether all items in
batch are valid. If all items are valid, returns Ok(()).
Otherwise, returns an error describing the first failure.Auto Trait Implementations§
impl<F, C, H> Freeze for BrakedownPCParams<F, C, H>where
<<C as Config>::LeafHash as CRHScheme>::Parameters: Freeze,
<<C as Config>::TwoToOneHash as TwoToOneCRHScheme>::Parameters: Freeze,
<H as CRHScheme>::Parameters: Freeze,
impl<F, C, H> RefUnwindSafe for BrakedownPCParams<F, C, H>where
<<C as Config>::LeafHash as CRHScheme>::Parameters: RefUnwindSafe,
<<C as Config>::TwoToOneHash as TwoToOneCRHScheme>::Parameters: RefUnwindSafe,
<H as CRHScheme>::Parameters: RefUnwindSafe,
F: RefUnwindSafe,
impl<F, C, H> Send for BrakedownPCParams<F, C, H>where
<<C as Config>::LeafHash as CRHScheme>::Parameters: Send,
<<C as Config>::TwoToOneHash as TwoToOneCRHScheme>::Parameters: Send,
<H as CRHScheme>::Parameters: Send,
impl<F, C, H> Sync for BrakedownPCParams<F, C, H>
impl<F, C, H> Unpin for BrakedownPCParams<F, C, H>where
<<C as Config>::LeafHash as CRHScheme>::Parameters: Unpin,
<<C as Config>::TwoToOneHash as TwoToOneCRHScheme>::Parameters: Unpin,
<H as CRHScheme>::Parameters: Unpin,
F: Unpin,
impl<F, C, H> UnsafeUnpin for BrakedownPCParams<F, C, H>where
<<C as Config>::LeafHash as CRHScheme>::Parameters: UnsafeUnpin,
<<C as Config>::TwoToOneHash as TwoToOneCRHScheme>::Parameters: UnsafeUnpin,
<H as CRHScheme>::Parameters: UnsafeUnpin,
impl<F, C, H> UnwindSafe for BrakedownPCParams<F, C, H>where
<<C as Config>::LeafHash as CRHScheme>::Parameters: UnwindSafe,
<<C as Config>::TwoToOneHash as TwoToOneCRHScheme>::Parameters: UnwindSafe,
<H as CRHScheme>::Parameters: UnwindSafe,
F: 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
Mutably borrows from an owned value. Read more
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>
Converts
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>
Converts
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