pub struct VerifyingKey<E: Pairing> {
pub alpha_g1: E::G1Affine,
pub beta_g2: E::G2Affine,
pub gamma_g2: E::G2Affine,
pub delta_g2: E::G2Affine,
pub gamma_abc_g1: Vec<E::G1Affine>,
}Expand description
A verification key in the Groth16 SNARK.
Fields§
§alpha_g1: E::G1AffineThe alpha * G, where G is the generator of E::G1.
beta_g2: E::G2AffineThe alpha * H, where H is the generator of E::G2.
gamma_g2: E::G2AffineThe gamma * H, where H is the generator of E::G2.
delta_g2: E::G2AffineThe delta * H, where H is the generator of E::G2.
gamma_abc_g1: Vec<E::G1Affine>The gamma^{-1} * (beta * a_i + alpha * b_i + c_i) * H, where H is
the generator of E::G1.
Trait Implementations§
Source§impl<E> Absorb for VerifyingKey<E>
impl<E> Absorb for VerifyingKey<E>
Source§fn to_sponge_bytes(&self, dest: &mut Vec<u8>)
fn to_sponge_bytes(&self, dest: &mut Vec<u8>)
Converts the object into a list of bytes that can be absorbed by a
CryptographicSponge.
Append the list to dest.Source§fn to_sponge_field_elements<F: PrimeField>(&self, dest: &mut Vec<F>)
fn to_sponge_field_elements<F: PrimeField>(&self, dest: &mut Vec<F>)
Converts the object into field elements that can be absorbed by a
CryptographicSponge.
Append the list to destSource§fn to_sponge_bytes_as_vec(&self) -> Vec<u8> ⓘ
fn to_sponge_bytes_as_vec(&self) -> Vec<u8> ⓘ
Converts the object into a list of bytes that can be absorbed by a
CryptographicSponge.
Return the list as Vec.Source§fn to_sponge_field_elements_as_vec<F>(&self) -> Vec<F>where
F: PrimeField,
fn to_sponge_field_elements_as_vec<F>(&self) -> Vec<F>where
F: PrimeField,
Converts the object into field elements that can be absorbed by a
CryptographicSponge.
Return the list as VecSource§fn batch_to_sponge_bytes(batch: &[Self], dest: &mut Vec<u8>)where
Self: Sized,
fn batch_to_sponge_bytes(batch: &[Self], dest: &mut Vec<u8>)where
Self: Sized,
Specifies the conversion into a list of bytes for a batch. Append the list to
dest.Source§fn batch_to_sponge_bytes_as_vec(batch: &[Self]) -> Vec<u8> ⓘwhere
Self: Sized,
fn batch_to_sponge_bytes_as_vec(batch: &[Self]) -> Vec<u8> ⓘwhere
Self: Sized,
Specifies the conversion into a list of bytes for a batch. Return the list as
Vec.Source§fn batch_to_sponge_field_elements<F>(batch: &[Self], dest: &mut Vec<F>)where
F: PrimeField,
Self: Sized,
fn batch_to_sponge_field_elements<F>(batch: &[Self], dest: &mut Vec<F>)where
F: PrimeField,
Self: Sized,
Specifies the conversion into a list of field elements for a batch. Append the list to
dest.Source§fn batch_to_sponge_field_elements_as_vec<F>(batch: &[Self]) -> Vec<F>where
F: PrimeField,
Self: Sized,
fn batch_to_sponge_field_elements_as_vec<F>(batch: &[Self]) -> Vec<F>where
F: PrimeField,
Self: Sized,
Specifies the conversion into a list of field elements for a batch. Return the list as
Vec.Source§impl<E: Pairing> CanonicalDeserialize for VerifyingKey<E>
impl<E: Pairing> CanonicalDeserialize for VerifyingKey<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>
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<E: Pairing> CanonicalSerialize for VerifyingKey<E>
impl<E: Pairing> CanonicalSerialize for VerifyingKey<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>
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<E: Clone + Pairing> Clone for VerifyingKey<E>
impl<E: Clone + Pairing> Clone for VerifyingKey<E>
Source§fn clone(&self) -> VerifyingKey<E>
fn clone(&self) -> VerifyingKey<E>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl<E: Pairing> Default for VerifyingKey<E>
impl<E: Pairing> Default for VerifyingKey<E>
Source§impl<E: Pairing> From<PreparedVerifyingKey<E>> for VerifyingKey<E>
impl<E: Pairing> From<PreparedVerifyingKey<E>> for VerifyingKey<E>
Source§fn from(other: PreparedVerifyingKey<E>) -> Self
fn from(other: PreparedVerifyingKey<E>) -> Self
Converts to this type from the input type.
Source§impl<E: Pairing> From<VerifyingKey<E>> for PreparedVerifyingKey<E>
impl<E: Pairing> From<VerifyingKey<E>> for PreparedVerifyingKey<E>
Source§fn from(other: VerifyingKey<E>) -> Self
fn from(other: VerifyingKey<E>) -> Self
Converts to this type from the input type.
Source§impl<E: Pairing> Valid for VerifyingKey<E>
impl<E: Pairing> Valid for VerifyingKey<E>
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<E: Pairing> StructuralPartialEq for VerifyingKey<E>
Auto Trait Implementations§
impl<E> Freeze for VerifyingKey<E>
impl<E> RefUnwindSafe for VerifyingKey<E>
impl<E> Send for VerifyingKey<E>
impl<E> Sync for VerifyingKey<E>
impl<E> Unpin for VerifyingKey<E>
impl<E> UnsafeUnpin for VerifyingKey<E>
impl<E> UnwindSafe for VerifyingKey<E>
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> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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