[−][src]Struct amcl_wrapper::group_elem_g2::G2Vector
Methods
impl G2Vector
[src]
pub fn inner_product_const_time(
&self,
b: &FieldElementVector
) -> Result<G2, ValueError>
[src]
&self,
b: &FieldElementVector
) -> Result<G2, ValueError>
Computes inner product of 2 vectors, one of field elements and other of group elements. [a1, a2, a3, ...field elements].[b1, b2, b3, ...group elements] = (a1b1 + a2b2 + a3*b3)
pub fn inner_product_var_time(
&self,
b: &FieldElementVector
) -> Result<G2, ValueError>
[src]
&self,
b: &FieldElementVector
) -> Result<G2, ValueError>
pub fn inner_product_var_time_with_ref_vecs(
group_elems: Vec<&G2>,
field_elems: Vec<&FieldElement>
) -> Result<G2, ValueError>
[src]
group_elems: Vec<&G2>,
field_elems: Vec<&FieldElement>
) -> Result<G2, ValueError>
pub fn hadamard_product(&self, b: &Self) -> Result<Self, ValueError>
[src]
Calculates Hadamard product of 2 group element vectors.
Hadamard product of a
and b
= a
o b
= (a0 o b0, a1 o b1, ...).
Here o
denotes group operation, which in elliptic curve is point addition
pub fn split_at(&self, mid: usize) -> (Self, Self)
[src]
pub fn multi_scalar_mul_const_time_naive(
&self,
field_elems: &FieldElementVector
) -> Result<G2, ValueError>
[src]
&self,
field_elems: &FieldElementVector
) -> Result<G2, ValueError>
Constant time multi-scalar multiplication. Naive approach computing n
scalar
multiplications and n-1 additions for n
field elements
pub fn multi_scalar_mul_const_time(
&self,
field_elems: &FieldElementVector
) -> Result<G2, ValueError>
[src]
&self,
field_elems: &FieldElementVector
) -> Result<G2, ValueError>
Constant time multi-scalar multiplication
pub fn multi_scalar_mul_var_time(
&self,
field_elems: &FieldElementVector
) -> Result<G2, ValueError>
[src]
&self,
field_elems: &FieldElementVector
) -> Result<G2, ValueError>
Variable time multi-scalar multiplication
pub fn multi_scalar_mul_var_time_from_ref_vecs(
group_elems: Vec<&G2>,
field_elems: Vec<&FieldElement>
) -> Result<G2, ValueError>
[src]
group_elems: Vec<&G2>,
field_elems: Vec<&FieldElement>
) -> Result<G2, ValueError>
pub fn multi_scalar_mul_var_time_with_precomputation_done(
lookup_tables: &[G2LookupTable],
field_elems: Vec<&FieldElement>
) -> Result<G2, ValueError>
[src]
lookup_tables: &[G2LookupTable],
field_elems: Vec<&FieldElement>
) -> Result<G2, ValueError>
Strauss multi-scalar multiplication. Passing the lookup tables since in lot of cases generators will be fixed
pub fn multi_scalar_mul_const_time_with_precomputation_done(
group_elem_multiples: &Vec<Vec<G2>>,
field_elems: &FieldElementVector
) -> Result<G2, ValueError>
[src]
group_elem_multiples: &Vec<Vec<G2>>,
field_elems: &FieldElementVector
) -> Result<G2, ValueError>
Trait Implementations
impl GroupElementVector<G2> for G2Vector
[src]
fn new(size: usize) -> Self
[src]
fn with_capacity(capacity: usize) -> Self
[src]
fn as_slice(&self) -> &[G2]
[src]
fn len(&self) -> usize
[src]
fn push(&mut self, value: G2)
[src]
fn append(&mut self, other: &mut Self)
[src]
fn pop(&mut self) -> Option<G2>
[src]
fn insert(&mut self, index: usize, element: G2)
[src]
fn remove(&mut self, index: usize) -> G2
[src]
fn sum(&self) -> G2
[src]
fn scale(&mut self, n: &FieldElement)
[src]
fn scaled_by(&self, n: &FieldElement) -> Self
[src]
fn plus(&self, b: &Self) -> Result<Self, ValueError>
[src]
fn minus(&self, b: &Self) -> Result<Self, ValueError>
[src]
fn iter(&self) -> Iter<G2>
[src]
impl Clone for G2Vector
[src]
impl PartialEq<G2Vector> for G2Vector
[src]
impl IntoIterator for G2Vector
[src]
type Item = G2
The type of the elements being iterated over.
type IntoIter = IntoIter<G2>
Which kind of iterator are we turning this into?
fn into_iter(self) -> Self::IntoIter
[src]
impl From<Vec<G2>> for G2Vector
[src]
impl<'_> From<&'_ [G2]> for G2Vector
[src]
impl Index<usize> for G2Vector
[src]
impl IndexMut<usize> for G2Vector
[src]
impl Debug for G2Vector
[src]
impl Serialize for G2Vector
[src]
fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error> where
__S: Serializer,
[src]
__S: Serializer,
impl<'de> Deserialize<'de> for G2Vector
[src]
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
__D: Deserializer<'de>,
[src]
__D: Deserializer<'de>,
Auto Trait Implementations
impl Send for G2Vector
impl Unpin for G2Vector
impl Sync for G2Vector
impl UnwindSafe for G2Vector
impl RefUnwindSafe for G2Vector
Blanket Implementations
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
fn to_owned(&self) -> T
[src]
fn clone_into(&self, target: &mut T)
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<I> IntoIterator for I where
I: Iterator,
[src]
I: Iterator,
type Item = <I as Iterator>::Item
The type of the elements being iterated over.
type IntoIter = I
Which kind of iterator are we turning this into?
fn into_iter(self) -> I
[src]
impl<T> From<T> for T
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Same<T> for T
type Output = T
Should always be Self
impl<T> DeserializeOwned for T where
T: Deserialize<'de>,
[src]
T: Deserialize<'de>,