pub struct VerifierKey<E: Pairing> {
pub g: E::G1Affine,
pub gamma_g: E::G1Affine,
pub h: E::G2Affine,
pub beta_h: E::G2Affine,
pub prepared_h: E::G2Prepared,
pub prepared_beta_h: E::G2Prepared,
pub degree_bounds_and_neg_powers_of_h: Option<Vec<(usize, E::G2Affine)>>,
pub supported_degree: usize,
pub max_degree: usize,
}Expand description
VerifierKey is used to check evaluation proofs for a given commitment.
Fields§
§g: E::G1AffineThe generator of G1.
gamma_g: E::G1AffineThe generator of G1 that is used for making a commitment hiding.
h: E::G2AffineThe generator of G2.
beta_h: E::G2Affine\beta times the generator of G2.
prepared_h: E::G2PreparedThe generator of G2, prepared for use in pairings.
prepared_beta_h: E::G2PreparedThe \beta times the generator of G2, prepared for use in pairings.
degree_bounds_and_neg_powers_of_h: Option<Vec<(usize, E::G2Affine)>>Pairs a degree_bound with its corresponding G2 element, which has been prepared for use in pairings.
Each pair is in the form (degree_bound, \beta^{degree_bound - max_degree} h), where h is the generator of G2 above
supported_degree: usizeThe maximum degree supported by the trimmed parameters that self is
a part of.
max_degree: usizeThe maximum degree supported by the UniversalParams self was derived
from.
Implementations§
Source§impl<E: Pairing> VerifierKey<E>
impl<E: Pairing> VerifierKey<E>
Sourcepub fn get_shift_power(&self, degree_bound: usize) -> Option<E::G2Prepared>
pub fn get_shift_power(&self, degree_bound: usize) -> Option<E::G2Prepared>
Find the appropriate shift for the degree bound.
Trait Implementations§
Source§impl<E: Pairing> CanonicalDeserialize for VerifierKey<E>
impl<E: Pairing> CanonicalDeserialize for VerifierKey<E>
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>
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,
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,
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,
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,
Self from reader using the uncompressed form, without validating the deserialized
value. Read moreSource§impl<E: Pairing> CanonicalSerialize for VerifierKey<E>
impl<E: Pairing> CanonicalSerialize for VerifierKey<E>
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>
Source§fn serialized_size(&self, compress: Compress) -> usize
fn serialized_size(&self, compress: Compress) -> usize
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,
self into writer using the compressed form if applicable.Source§fn compressed_size(&self) -> usize
fn compressed_size(&self) -> usize
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,
self into writer using the uncompressed form.Source§fn uncompressed_size(&self) -> usize
fn uncompressed_size(&self) -> usize
self.Source§impl<E: Pairing> Clone for VerifierKey<E>
impl<E: Pairing> Clone for VerifierKey<E>
Source§impl<E: Pairing> Debug for VerifierKey<E>
impl<E: Pairing> Debug for VerifierKey<E>
Source§impl<E: Pairing> Default for VerifierKey<E>
impl<E: Pairing> Default for VerifierKey<E>
Source§impl<E: Pairing> PCPreparedVerifierKey<VerifierKey<E>> for PreparedVerifierKey<E>
impl<E: Pairing> PCPreparedVerifierKey<VerifierKey<E>> for PreparedVerifierKey<E>
Source§fn prepare(vk: &VerifierKey<E>) -> Self
fn prepare(vk: &VerifierKey<E>) -> Self
prepare PreparedVerifierKey from VerifierKey
Source§impl<E: Pairing> PCVerifierKey for VerifierKey<E>
impl<E: Pairing> PCVerifierKey for VerifierKey<E>
Source§fn max_degree(&self) -> usize
fn max_degree(&self) -> usize
Self was derived from.Source§fn supported_degree(&self) -> usize
fn supported_degree(&self) -> usize
Source§impl<E: Pairing> Valid for VerifierKey<E>
impl<E: Pairing> Valid for VerifierKey<E>
Source§fn check(&self) -> Result<(), SerializationError>
fn check(&self) -> Result<(), SerializationError>
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§const TRIVIAL_CHECK: bool = false
const TRIVIAL_CHECK: bool = false
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 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,
batch are valid. If all items are valid, returns Ok(()).
Otherwise, returns an error describing the first failure.Auto Trait Implementations§
impl<E> Freeze for VerifierKey<E>
impl<E> RefUnwindSafe for VerifierKey<E>where
<E as Pairing>::G1Affine: RefUnwindSafe,
<E as Pairing>::G2Affine: RefUnwindSafe,
<E as Pairing>::G2Prepared: RefUnwindSafe,
impl<E> Send for VerifierKey<E>
impl<E> Sync for VerifierKey<E>
impl<E> Unpin for VerifierKey<E>
impl<E> UnsafeUnpin for VerifierKey<E>where
<E as Pairing>::G1Affine: UnsafeUnpin,
<E as Pairing>::G2Affine: UnsafeUnpin,
<E as Pairing>::G2Prepared: UnsafeUnpin,
impl<E> UnwindSafe for VerifierKey<E>where
<E as Pairing>::G1Affine: UnwindSafe,
<E as Pairing>::G2Affine: UnwindSafe,
<E as Pairing>::G2Prepared: 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