1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
pub mod glv;
pub mod wnaf;
pub mod fixed_base;
pub mod variable_base;
use crate::Group;
use ark_std::{
ops::{Add, AddAssign, Mul, Neg, Sub, SubAssign},
vec::Vec,
};
fn ln_without_floats(a: usize) -> usize {
(ark_std::log2(a) * 69 / 100) as usize
}
pub trait ScalarMul:
Group
+ Add<Self::MulBase, Output = Self>
+ AddAssign<Self::MulBase>
+ for<'a> Add<&'a Self::MulBase, Output = Self>
+ for<'a> AddAssign<&'a Self::MulBase>
+ Sub<Self::MulBase, Output = Self>
+ SubAssign<Self::MulBase>
+ for<'a> Sub<&'a Self::MulBase, Output = Self>
+ for<'a> SubAssign<&'a Self::MulBase>
+ From<Self::MulBase>
{
type MulBase: Send
+ Sync
+ Copy
+ Eq
+ core::hash::Hash
+ Mul<Self::ScalarField, Output = Self>
+ for<'a> Mul<&'a Self::ScalarField, Output = Self>
+ Neg<Output = Self::MulBase>;
const NEGATION_IS_CHEAP: bool;
fn batch_convert_to_mul_base(bases: &[Self]) -> Vec<Self::MulBase>;
}