pub struct CommitterUnionKey<'a, E: PairingEngine> {
    pub powers_of_beta_g: Option<&'a Vec<E::G1Affine>>,
    pub lagrange_bases_at_beta_g: BTreeMap<usize, &'a Vec<E::G1Affine>>,
    pub powers_of_beta_times_gamma_g: Option<&'a Vec<E::G1Affine>>,
    pub shifted_powers_of_beta_g: Option<&'a Vec<E::G1Affine>>,
    pub shifted_powers_of_beta_times_gamma_g: Option<BTreeMap<usize, &'a Vec<E::G1Affine>>>,
    pub enforced_degree_bounds: Option<Vec<usize>>,
}
Expand description

CommitterUnionKey is a union of CommitterKeys, useful for multi-circuit batch proofs.

Fields§

§powers_of_beta_g: Option<&'a Vec<E::G1Affine>>

The key used to commit to polynomials.

§lagrange_bases_at_beta_g: BTreeMap<usize, &'a Vec<E::G1Affine>>

The key used to commit to polynomials in Lagrange basis.

§powers_of_beta_times_gamma_g: Option<&'a Vec<E::G1Affine>>

The key used to commit to hiding polynomials.

§shifted_powers_of_beta_g: Option<&'a Vec<E::G1Affine>>

The powers used to commit to shifted polynomials. This is None if self does not support enforcing any degree bounds.

§shifted_powers_of_beta_times_gamma_g: Option<BTreeMap<usize, &'a Vec<E::G1Affine>>>

The powers used to commit to shifted hiding polynomials. This is None if self does not support enforcing any degree bounds.

§enforced_degree_bounds: Option<Vec<usize>>

The degree bounds that are supported by self. Sorted in ascending order from smallest bound to largest bound. This is None if self does not support enforcing any degree bounds.

Implementations§

source§

impl<'a, E: PairingEngine> CommitterUnionKey<'a, E>

source

pub fn powers(&self) -> Powers<'_, E>

Obtain powers for the underlying KZG10 construction

source

pub fn shifted_powers_of_beta_g( &self, degree_bound: impl Into<Option<usize>> ) -> Option<Powers<'_, E>>

Obtain powers for committing to shifted polynomials.

source

pub fn lagrange_basis( &self, domain: EvaluationDomain<E::Fr> ) -> Option<LagrangeBasis<'_, E>>

Obtain elements of the SRS in the lagrange basis powers, for use with the underlying KZG10 construction.

source

pub fn union<T: IntoIterator<Item = &'a CommitterKey<E>>>( committer_keys: T ) -> Self

Trait Implementations§

source§

impl<'a, E: Clone + PairingEngine> Clone for CommitterUnionKey<'a, E>where E::G1Affine: Clone,

source§

fn clone(&self) -> CommitterUnionKey<'a, E>

Returns a copy 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<'a, E: Debug + PairingEngine> Debug for CommitterUnionKey<'a, E>where E::G1Affine: Debug,

source§

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

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

impl<'a, E: Hash + PairingEngine> Hash for CommitterUnionKey<'a, E>where E::G1Affine: Hash,

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl<'a, E: PartialEq + PairingEngine> PartialEq<CommitterUnionKey<'a, E>> for CommitterUnionKey<'a, E>where E::G1Affine: PartialEq,

source§

fn eq(&self, other: &CommitterUnionKey<'a, E>) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<'a, E: Eq + PairingEngine> Eq for CommitterUnionKey<'a, E>where E::G1Affine: Eq,

source§

impl<'a, E: PairingEngine> StructuralEq for CommitterUnionKey<'a, E>

source§

impl<'a, E: PairingEngine> StructuralPartialEq for CommitterUnionKey<'a, E>

Auto Trait Implementations§

§

impl<'a, E> RefUnwindSafe for CommitterUnionKey<'a, E>where <E as PairingEngine>::G1Affine: RefUnwindSafe,

§

impl<'a, E> Send for CommitterUnionKey<'a, E>

§

impl<'a, E> Sync for CommitterUnionKey<'a, E>

§

impl<'a, E> Unpin for CommitterUnionKey<'a, E>

§

impl<'a, E> UnwindSafe for CommitterUnionKey<'a, E>where <E as PairingEngine>::G1Affine: RefUnwindSafe,

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
§

impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere 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.

§

impl<T> Pointable for T

§

const ALIGN: usize = mem::align_of::<T>()

The alignment of pointer.
§

type Init = T

The type for initializers.
§

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

Initializes a with the given initializer. Read more
§

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

Dereferences the given pointer. Read more
§

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

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

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

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere T: Clone,

§

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 Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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

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

§

fn vzip(self) -> V