pub struct Randomness<F: PrimeField, P: DenseUVPolynomial<F>> {
pub rand: Randomness<F, P>,
pub shifted_rand: Option<Randomness<F, P>>,
}Expand description
Randomness hides the polynomial inside a commitment. It is output by KZG10::commit.
Fields§
§rand: Randomness<F, P>Commitment randomness for a KZG10 commitment.
shifted_rand: Option<Randomness<F, P>>Commitment randomness for a KZG10 commitment to the shifted polynomial.
This is None if the committed polynomial does not enforce a strict
degree bound.
Trait Implementations§
Source§impl<'a, F: PrimeField, P: DenseUVPolynomial<F>> Add<&'a Randomness<F, P>> for Randomness<F, P>
impl<'a, F: PrimeField, P: DenseUVPolynomial<F>> Add<&'a Randomness<F, P>> for Randomness<F, P>
Source§impl<'a, F: PrimeField, P: DenseUVPolynomial<F>> Add<(F, &'a Randomness<F, P>)> for Randomness<F, P>
impl<'a, F: PrimeField, P: DenseUVPolynomial<F>> Add<(F, &'a Randomness<F, P>)> for Randomness<F, P>
Source§type Output = Randomness<F, P>
type Output = Randomness<F, P>
The resulting type after applying the
+ operator.Source§fn add(self, other: (F, &'a Randomness<F, P>)) -> Self
fn add(self, other: (F, &'a Randomness<F, P>)) -> Self
Performs the
+ operation. Read moreSource§impl<'a, F: PrimeField, P: DenseUVPolynomial<F>> AddAssign<&'a Randomness<F, P>> for Randomness<F, P>
impl<'a, F: PrimeField, P: DenseUVPolynomial<F>> AddAssign<&'a Randomness<F, P>> for Randomness<F, P>
Source§fn add_assign(&mut self, other: &'a Self)
fn add_assign(&mut self, other: &'a Self)
Performs the
+= operation. Read moreSource§impl<'a, F: PrimeField, P: DenseUVPolynomial<F>> AddAssign<(F, &'a Randomness<F, P>)> for Randomness<F, P>
impl<'a, F: PrimeField, P: DenseUVPolynomial<F>> AddAssign<(F, &'a Randomness<F, P>)> for Randomness<F, P>
Source§fn add_assign(&mut self, (f, other): (F, &'a Randomness<F, P>))
fn add_assign(&mut self, (f, other): (F, &'a Randomness<F, P>))
Performs the
+= operation. Read moreSource§impl<F: PrimeField, P: DenseUVPolynomial<F>> CanonicalDeserialize for Randomness<F, P>
impl<F: PrimeField, P: DenseUVPolynomial<F>> CanonicalDeserialize for Randomness<F, P>
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, P: DenseUVPolynomial<F>> CanonicalSerialize for Randomness<F, P>
impl<F: PrimeField, P: DenseUVPolynomial<F>> CanonicalSerialize for Randomness<F, P>
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, P: DenseUVPolynomial<F>> Clone for Randomness<F, P>
impl<F: PrimeField, P: DenseUVPolynomial<F>> Clone for Randomness<F, P>
Source§impl<F: PrimeField, P: DenseUVPolynomial<F>> Debug for Randomness<F, P>
impl<F: PrimeField, P: DenseUVPolynomial<F>> Debug for Randomness<F, P>
Source§impl<F: PrimeField, P: DenseUVPolynomial<F>> Hash for Randomness<F, P>
impl<F: PrimeField, P: DenseUVPolynomial<F>> Hash for Randomness<F, P>
Source§impl<F: PrimeField, P: DenseUVPolynomial<F>> PCCommitmentState for Randomness<F, P>
impl<F: PrimeField, P: DenseUVPolynomial<F>> PCCommitmentState for Randomness<F, P>
Source§type Randomness = Randomness<F, P>
type Randomness = Randomness<F, P>
This is the type of
Randomness that the rand method returnsSource§fn rand<R: RngCore>(
hiding_bound: usize,
has_degree_bound: bool,
_: Option<usize>,
rng: &mut R,
) -> Self
fn rand<R: RngCore>( hiding_bound: usize, has_degree_bound: bool, _: Option<usize>, rng: &mut R, ) -> Self
Samples randomness for commitments;
num_queries specifies the number of queries that the commitment will be opened at.
has_degree_bound indicates that the corresponding commitment has an enforced
num_vars specifies the number of variables for multivariate commitment.
strict degree bound.Source§impl<F: PrimeField, P: DenseUVPolynomial<F>> PartialEq for Randomness<F, P>
impl<F: PrimeField, P: DenseUVPolynomial<F>> PartialEq for Randomness<F, P>
Source§impl<F: PrimeField, P: DenseUVPolynomial<F>> Valid for Randomness<F, P>
impl<F: PrimeField, P: DenseUVPolynomial<F>> Valid for Randomness<F, P>
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.impl<F: PrimeField, P: DenseUVPolynomial<F>> Eq for Randomness<F, P>
Auto Trait Implementations§
impl<F, P> Freeze for Randomness<F, P>where
P: Freeze,
impl<F, P> RefUnwindSafe for Randomness<F, P>where
P: RefUnwindSafe,
F: RefUnwindSafe,
impl<F, P> Send for Randomness<F, P>where
P: Send,
impl<F, P> Sync for Randomness<F, P>
impl<F, P> Unpin for Randomness<F, P>
impl<F, P> UnsafeUnpin for Randomness<F, P>where
P: UnsafeUnpin,
impl<F, P> UnwindSafe for Randomness<F, P>where
P: 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<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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