snarkvm_algorithms::polycommit::sonic_pc

Struct CommitterUnionKey

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

Auto Trait Implementations§

§

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

§

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

§

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>

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

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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