Skip to main content

VerifyingKey

Struct VerifyingKey 

Source
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::G1Affine

The alpha * G, where G is the generator of E::G1.

§beta_g2: E::G2Affine

The alpha * H, where H is the generator of E::G2.

§gamma_g2: E::G2Affine

The gamma * H, where H is the generator of E::G2.

§delta_g2: E::G2Affine

The 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>
where E: Pairing, E::G1Affine: Absorb, E::G2Affine: Absorb,

Source§

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>)

Converts the object into field elements that can be absorbed by a CryptographicSponge. Append the list to dest
Source§

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,

Converts the object into field elements that can be absorbed by a CryptographicSponge. Return the list as Vec
Source§

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,

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,

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,

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>

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<E: Pairing> CanonicalSerialize for VerifyingKey<E>

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<E: Clone + Pairing> Clone for VerifyingKey<E>
where E::G1Affine: Clone, E::G2Affine: Clone,

Source§

fn clone(&self) -> VerifyingKey<E>

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<E: Debug + Pairing> Debug for VerifyingKey<E>
where E::G1Affine: Debug, E::G2Affine: Debug,

Source§

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

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

impl<E: Pairing> Default for VerifyingKey<E>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<E: Pairing> From<PreparedVerifyingKey<E>> for VerifyingKey<E>

Source§

fn from(other: PreparedVerifyingKey<E>) -> Self

Converts to this type from the input type.
Source§

impl<E: Pairing> From<VerifyingKey<E>> for PreparedVerifyingKey<E>

Source§

fn from(other: VerifyingKey<E>) -> Self

Converts to this type from the input type.
Source§

impl<E: PartialEq + Pairing> PartialEq for VerifyingKey<E>

Source§

fn eq(&self, other: &VerifyingKey<E>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<E: Pairing> Valid for VerifyingKey<E>

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

impl<E: Pairing> StructuralPartialEq for VerifyingKey<E>

Auto Trait Implementations§

§

impl<E> Freeze for VerifyingKey<E>
where <E as Pairing>::G1Affine: Freeze, <E as Pairing>::G2Affine: Freeze,

§

impl<E> RefUnwindSafe for VerifyingKey<E>

§

impl<E> Send for VerifyingKey<E>

§

impl<E> Sync for VerifyingKey<E>

§

impl<E> Unpin for VerifyingKey<E>
where <E as Pairing>::G1Affine: Unpin, <E as Pairing>::G2Affine: Unpin,

§

impl<E> UnsafeUnpin for VerifyingKey<E>

§

impl<E> UnwindSafe for VerifyingKey<E>

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> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more