Skip to main content

BrakedownPCParams

Struct BrakedownPCParams 

Source
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>
where F: PrimeField, C: Config, H: CRHScheme,

Source

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.

Source

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>

Source§

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,

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,

Reads Self from reader using the compressed form if applicable, without validating the deserialized value. Read more
Source§

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,

Reads Self from reader using the uncompressed form, without validating the deserialized value. Read more
Source§

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>

The general serialize method that takes in customization flags.
Source§

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,

Serializes self into writer using the compressed form if applicable.
Source§

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,

Serializes self into writer using the uncompressed form.
Source§

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>

Source§

fn clone(&self) -> Self

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<F: PrimeField, C: Config, H: CRHScheme> Debug for BrakedownPCParams<F, C, H>

Source§

fn fmt(&self, __f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<F, C, H> LinCodeParametersInfo<C, H> for BrakedownPCParams<F, C, H>
where F: PrimeField, C: Config, H: CRHScheme,

Source§

fn check_well_formedness(&self) -> bool

See whether there should be a well-formedness check.
Source§

fn distance(&self) -> (usize, usize)

Get the distance of the code.
Source§

fn sec_param(&self) -> usize

Get the security parameter.
Source§

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

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

Get the parameters for hashing nodes in the merkle tree.
Source§

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>
where F: PrimeField, C: Config, H: CRHScheme,

Source§

fn max_degree(&self) -> usize

Outputs the maximum degree supported by the universal parameters Self was derived from.
Source§

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>
where F: PrimeField, C: Config, H: CRHScheme,

Source§

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>
where F: PrimeField, C: Config, H: CRHScheme,

Source§

fn max_degree(&self) -> usize

Outputs the maximum degree supported by the universal parameters Self was derived from.
Source§

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>

Source§

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>

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,

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>

§

impl<F, C, H> RefUnwindSafe for BrakedownPCParams<F, C, H>

§

impl<F, C, H> Send for BrakedownPCParams<F, C, H>

§

impl<F, C, H> Sync for BrakedownPCParams<F, C, H>

§

impl<F, C, H> Unpin for BrakedownPCParams<F, C, H>

§

impl<F, C, H> UnsafeUnpin for BrakedownPCParams<F, C, H>

§

impl<F, C, H> UnwindSafe for BrakedownPCParams<F, C, H>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CanonicalSerializeHashExt for T

Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V