Hom

Struct Hom 

Source
pub struct Hom<G: AffineRepr>(pub Vec<G>);

Tuple Fields§

§0: Vec<G>

First n-k elements for multiples of P_i and next n for g. This holds the vector of bases such that the inner product of this vector and vector Y given P_i

Implementations§

Source§

impl<G: AffineRepr> Hom<G>

Source

pub fn new( g: G, P: G, k: usize, n: usize, i: usize, ) -> Result<Self, CompSigmaError>

For k known openings of n total commitments, the homomorphism for the commitment at index i is g * t_i + P_i * -\sum_{j in 1..n-k}(a_j*i^j) For g * t_i, the bases will be a vector [0, 0, ..., g, 0, ..., 0] of size n with g at index i and rest as 0 For P_i * \sum_{j in 1..n-k}(a_j*i^j), its equal to P_i * -a_1 * i + P_2 * -a_2 * i^2 + ... + P_i * -a_{n-k} * i^{n-k} which is equal to (P_i * -i) * a_1 + (P_i * -i^2) * a_2 + ... + (P_i * -i^{n-k}) * a_{n-k}. Thus the bases for it can be written as vector [(P_i * -i), (P_i * -i^2), ..., (P_i * -i^{n-k})] of size n-k. Thus the final bases are [(P_i * -i), (P_i * -i^2), ..., (P_i * -i^{n-k}), 0, 0, ..., g, 0, ..., 0] of size 2*n-k

Trait Implementations§

Source§

impl<G: Clone + AffineRepr> Clone for Hom<G>

Source§

fn clone(&self) -> Hom<G>

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<G: AffineRepr> Homomorphism<<G as AffineRepr>::ScalarField> for Hom<G>

Source§

type Output = G

Source§

fn eval(&self, x: &[G::ScalarField]) -> Result<Self::Output, CompSigmaError>

Source§

fn scale(&self, scalar: &G::ScalarField) -> Self

Source§

fn add(&self, other: &Self) -> Result<Self, CompSigmaError>

Source§

fn split_in_half(&self) -> (Self, Self)

Source§

fn size(&self) -> usize

Source§

fn pad(&self, new_size: u32) -> Self

Auto Trait Implementations§

§

impl<G> Freeze for Hom<G>

§

impl<G> RefUnwindSafe for Hom<G>
where G: RefUnwindSafe,

§

impl<G> Send for Hom<G>

§

impl<G> Sync for Hom<G>

§

impl<G> Unpin for Hom<G>
where G: Unpin,

§

impl<G> UnwindSafe for Hom<G>
where G: UnwindSafe,

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> 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, 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> SendIfParallel for T

Source§

impl<T> SyncIfParallel for T