#[repr(transparent)]pub struct PackedMontyField31Neon<PMP: PackedMontyParameters>(pub [MontyField31<PMP>; 4]);
Expand description
Vectorized NEON implementation of MontyField31
arithmetic.
Tuple Fields§
§0: [MontyField31<PMP>; 4]
Trait Implementations§
Source§impl<FP: FieldParameters> AbstractField for PackedMontyField31Neon<FP>
impl<FP: FieldParameters> AbstractField for PackedMontyField31Neon<FP>
const ZERO: Self = _
const ONE: Self = _
const TWO: Self = _
const NEG_ONE: Self = _
type F = MontyField31<FP>
fn from_f(f: Self::F) -> Self
Source§fn from_canonical_u8(n: u8) -> Self
fn from_canonical_u8(n: u8) -> Self
Convert from a canonical
u8
. Read moreSource§fn from_canonical_u16(n: u16) -> Self
fn from_canonical_u16(n: u16) -> Self
Convert from a canonical
u16
. Read moreSource§fn from_canonical_u32(n: u32) -> Self
fn from_canonical_u32(n: u32) -> Self
Convert from a canonical
u32
. Read moreSource§fn from_canonical_u64(n: u64) -> Self
fn from_canonical_u64(n: u64) -> Self
Convert from a canonical
u64
. Read moreSource§fn from_canonical_usize(n: usize) -> Self
fn from_canonical_usize(n: usize) -> Self
Convert from a canonical
usize
. Read morefn from_wrapped_u32(n: u32) -> Self
fn from_wrapped_u64(n: u64) -> Self
fn cube(&self) -> Self
Source§fn zero_vec(len: usize) -> Vec<Self>
fn zero_vec(len: usize) -> Vec<Self>
Allocates a vector of zero elements of length
len
. Many operating systems zero pages
before assigning them to a userspace process. In that case, our process should not need to
write zeros, which would be redundant. However, the compiler may not always recognize this. Read morefn double(&self) -> Self
fn square(&self) -> Self
fn exp_const_u64<const POWER: u64>(&self) -> Self
fn exp_power_of_2(&self, power_log: usize) -> Self
Source§fn mul_2exp_u64(&self, exp: u64) -> Self
fn mul_2exp_u64(&self, exp: u64) -> Self
self * 2^exp
fn powers(&self) -> Powers<Self>
fn shifted_powers(&self, start: Self) -> Powers<Self>
fn powers_packed<P>(&self) -> PackedPowers<Self, P>where
P: PackedField<Scalar = Self>,
fn shifted_powers_packed<P>(&self, start: Self) -> PackedPowers<Self, P>where
P: PackedField<Scalar = Self>,
fn dot_product<const N: usize>(u: &[Self; N], v: &[Self; N]) -> Self
fn try_div<Rhs>(self, rhs: Rhs) -> Option<Self::Output>
Source§impl<PMP: PackedMontyParameters> Add<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> Add<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
Source§type Output = PackedMontyField31Neon<PMP>
type Output = PackedMontyField31Neon<PMP>
The resulting type after applying the
+
operator.Source§fn add(self, rhs: MontyField31<PMP>) -> Self
fn add(self, rhs: MontyField31<PMP>) -> Self
Performs the
+
operation. Read moreSource§impl<PMP: PackedMontyParameters> Add<PackedMontyField31Neon<PMP>> for MontyField31<PMP>
impl<PMP: PackedMontyParameters> Add<PackedMontyField31Neon<PMP>> for MontyField31<PMP>
Source§type Output = PackedMontyField31Neon<PMP>
type Output = PackedMontyField31Neon<PMP>
The resulting type after applying the
+
operator.Source§fn add(self, rhs: PackedMontyField31Neon<PMP>) -> PackedMontyField31Neon<PMP>
fn add(self, rhs: PackedMontyField31Neon<PMP>) -> PackedMontyField31Neon<PMP>
Performs the
+
operation. Read moreSource§impl<PMP: PackedMontyParameters> Add for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> Add for PackedMontyField31Neon<PMP>
Source§impl<PMP: PackedMontyParameters> AddAssign<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> AddAssign<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
Source§fn add_assign(&mut self, rhs: MontyField31<PMP>)
fn add_assign(&mut self, rhs: MontyField31<PMP>)
Performs the
+=
operation. Read moreSource§impl<PMP: PackedMontyParameters> AddAssign for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> AddAssign for PackedMontyField31Neon<PMP>
Source§fn add_assign(&mut self, rhs: Self)
fn add_assign(&mut self, rhs: Self)
Performs the
+=
operation. Read moreSource§impl<PMP: Clone + PackedMontyParameters> Clone for PackedMontyField31Neon<PMP>
impl<PMP: Clone + PackedMontyParameters> Clone for PackedMontyField31Neon<PMP>
Source§fn clone(&self) -> PackedMontyField31Neon<PMP>
fn clone(&self) -> PackedMontyField31Neon<PMP>
Returns a copy of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl<PMP: Debug + PackedMontyParameters> Debug for PackedMontyField31Neon<PMP>
impl<PMP: Debug + PackedMontyParameters> Debug for PackedMontyField31Neon<PMP>
Source§impl<PMP: PackedMontyParameters> Default for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> Default for PackedMontyField31Neon<PMP>
Source§impl<PMP: PackedMontyParameters> Distribution<PackedMontyField31Neon<PMP>> for Standard
impl<PMP: PackedMontyParameters> Distribution<PackedMontyField31Neon<PMP>> for Standard
Source§fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> PackedMontyField31Neon<PMP>
fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> PackedMontyField31Neon<PMP>
Generate a random value of
T
, using rng
as the source of randomness.Source§fn sample_iter<R>(self, rng: R) -> DistIter<Self, R, T>
fn sample_iter<R>(self, rng: R) -> DistIter<Self, R, T>
Create an iterator that generates random values of
T
, using rng
as
the source of randomness. Read moreSource§impl<FP: FieldParameters> Div<MontyField31<FP>> for PackedMontyField31Neon<FP>
impl<FP: FieldParameters> Div<MontyField31<FP>> for PackedMontyField31Neon<FP>
Source§type Output = PackedMontyField31Neon<FP>
type Output = PackedMontyField31Neon<FP>
The resulting type after applying the
/
operator.Source§fn div(self, rhs: MontyField31<FP>) -> Self
fn div(self, rhs: MontyField31<FP>) -> Self
Performs the
/
operation. Read moreSource§impl<FP, const D: u64, const WIDTH: usize> ExternalLayer<PackedMontyField31Neon<FP>, WIDTH, D> for Poseidon2ExternalLayerMonty31<FP, WIDTH>where
FP: FieldParameters,
impl<FP, const D: u64, const WIDTH: usize> ExternalLayer<PackedMontyField31Neon<FP>, WIDTH, D> for Poseidon2ExternalLayerMonty31<FP, WIDTH>where
FP: FieldParameters,
Source§fn permute_state_initial(&self, state: &mut [PackedMontyField31Neon<FP>; WIDTH])
fn permute_state_initial(&self, state: &mut [PackedMontyField31Neon<FP>; WIDTH])
Perform the initial external layers of the Poseidon2 permutation on the given state.
Source§fn permute_state_terminal(
&self,
state: &mut [PackedMontyField31Neon<FP>; WIDTH],
)
fn permute_state_terminal( &self, state: &mut [PackedMontyField31Neon<FP>; WIDTH], )
Perform the terminal external layers of the Poseidon2 permutation on the given state.
Source§impl<FP: FieldParameters, const WIDTH: usize> ExternalLayerConstructor<PackedMontyField31Neon<FP>, WIDTH> for Poseidon2ExternalLayerMonty31<FP, WIDTH>
impl<FP: FieldParameters, const WIDTH: usize> ExternalLayerConstructor<PackedMontyField31Neon<FP>, WIDTH> for Poseidon2ExternalLayerMonty31<FP, WIDTH>
Source§fn new_from_constants(
external_constants: ExternalLayerConstants<MontyField31<FP>, WIDTH>,
) -> Self
fn new_from_constants( external_constants: ExternalLayerConstants<MontyField31<FP>, WIDTH>, ) -> Self
A constructor which internally will convert the supplied
constants into the appropriate form for the implementation.
Source§impl<PMP: PackedMontyParameters> From<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> From<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
Source§fn from(value: MontyField31<PMP>) -> Self
fn from(value: MontyField31<PMP>) -> Self
Converts to this type from the input type.
Source§impl<FP, ILP, const WIDTH: usize, const D: u64> InternalLayer<PackedMontyField31Neon<FP>, WIDTH, D> for Poseidon2InternalLayerMonty31<FP, WIDTH, ILP>where
FP: FieldParameters,
ILP: InternalLayerBaseParameters<FP, WIDTH>,
impl<FP, ILP, const WIDTH: usize, const D: u64> InternalLayer<PackedMontyField31Neon<FP>, WIDTH, D> for Poseidon2InternalLayerMonty31<FP, WIDTH, ILP>where
FP: FieldParameters,
ILP: InternalLayerBaseParameters<FP, WIDTH>,
Source§fn permute_state(&self, state: &mut [PackedMontyField31Neon<FP>; WIDTH])
fn permute_state(&self, state: &mut [PackedMontyField31Neon<FP>; WIDTH])
Perform the internal layers of the Poseidon2 permutation on the given state.
Source§impl<FP: FieldParameters, const WIDTH: usize, ILP: InternalLayerBaseParameters<FP, WIDTH>> InternalLayerConstructor<PackedMontyField31Neon<FP>> for Poseidon2InternalLayerMonty31<FP, WIDTH, ILP>
impl<FP: FieldParameters, const WIDTH: usize, ILP: InternalLayerBaseParameters<FP, WIDTH>> InternalLayerConstructor<PackedMontyField31Neon<FP>> for Poseidon2InternalLayerMonty31<FP, WIDTH, ILP>
Source§fn new_from_constants(internal_constants: Vec<MontyField31<FP>>) -> Self
fn new_from_constants(internal_constants: Vec<MontyField31<FP>>) -> Self
A constructor which internally will convert the supplied
constants into the appropriate form for the implementation.
Source§impl<PMP: PackedMontyParameters> Mul<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> Mul<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
Source§type Output = PackedMontyField31Neon<PMP>
type Output = PackedMontyField31Neon<PMP>
The resulting type after applying the
*
operator.Source§fn mul(self, rhs: MontyField31<PMP>) -> Self
fn mul(self, rhs: MontyField31<PMP>) -> Self
Performs the
*
operation. Read moreSource§impl<PMP: PackedMontyParameters> Mul<PackedMontyField31Neon<PMP>> for MontyField31<PMP>
impl<PMP: PackedMontyParameters> Mul<PackedMontyField31Neon<PMP>> for MontyField31<PMP>
Source§type Output = PackedMontyField31Neon<PMP>
type Output = PackedMontyField31Neon<PMP>
The resulting type after applying the
*
operator.Source§fn mul(self, rhs: PackedMontyField31Neon<PMP>) -> PackedMontyField31Neon<PMP>
fn mul(self, rhs: PackedMontyField31Neon<PMP>) -> PackedMontyField31Neon<PMP>
Performs the
*
operation. Read moreSource§impl<PMP: PackedMontyParameters> Mul for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> Mul for PackedMontyField31Neon<PMP>
Source§impl<PMP: PackedMontyParameters> MulAssign<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> MulAssign<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
Source§fn mul_assign(&mut self, rhs: MontyField31<PMP>)
fn mul_assign(&mut self, rhs: MontyField31<PMP>)
Performs the
*=
operation. Read moreSource§impl<PMP: PackedMontyParameters> MulAssign for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> MulAssign for PackedMontyField31Neon<PMP>
Source§fn mul_assign(&mut self, rhs: Self)
fn mul_assign(&mut self, rhs: Self)
Performs the
*=
operation. Read moreSource§impl<PMP: PackedMontyParameters> Neg for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> Neg for PackedMontyField31Neon<PMP>
Source§impl<FP: FieldParameters> PackedField for PackedMontyField31Neon<FP>
impl<FP: FieldParameters> PackedField for PackedMontyField31Neon<FP>
type Scalar = MontyField31<FP>
Source§impl<FP: FieldParameters> PackedFieldPow2 for PackedMontyField31Neon<FP>
impl<FP: FieldParameters> PackedFieldPow2 for PackedMontyField31Neon<FP>
Source§fn interleave(&self, other: Self, block_len: usize) -> (Self, Self)
fn interleave(&self, other: Self, block_len: usize) -> (Self, Self)
Take interpret two vectors as chunks of
block_len
elements. Unpack and interleave those
chunks. This is best seen with an example. If we have: Read moreSource§impl<FP: FieldParameters> PackedValue for PackedMontyField31Neon<FP>
impl<FP: FieldParameters> PackedValue for PackedMontyField31Neon<FP>
const WIDTH: usize = 4usize
type Value = MontyField31<FP>
fn from_slice(slice: &[MontyField31<FP>]) -> &Self
fn from_slice_mut(slice: &mut [MontyField31<FP>]) -> &mut Self
fn as_slice(&self) -> &[MontyField31<FP>]
fn as_slice_mut(&mut self) -> &mut [MontyField31<FP>]
fn pack_slice(buf: &[Self::Value]) -> &[Self]
fn pack_slice_with_suffix(buf: &[Self::Value]) -> (&[Self], &[Self::Value])
fn pack_slice_mut(buf: &mut [Self::Value]) -> &mut [Self]
fn pack_maybe_uninit_slice_mut( buf: &mut [MaybeUninit<Self::Value>], ) -> &mut [MaybeUninit<Self>]
fn pack_slice_with_suffix_mut( buf: &mut [Self::Value], ) -> (&mut [Self], &mut [Self::Value])
fn pack_maybe_uninit_slice_with_suffix_mut( buf: &mut [MaybeUninit<Self::Value>], ) -> (&mut [MaybeUninit<Self>], &mut [MaybeUninit<Self::Value>])
fn unpack_slice(buf: &[Self]) -> &[Self::Value]
Source§impl<PMP: PartialEq + PackedMontyParameters> PartialEq for PackedMontyField31Neon<PMP>
impl<PMP: PartialEq + PackedMontyParameters> PartialEq for PackedMontyField31Neon<PMP>
Source§impl<FP: FieldParameters> Product<MontyField31<FP>> for PackedMontyField31Neon<FP>
impl<FP: FieldParameters> Product<MontyField31<FP>> for PackedMontyField31Neon<FP>
Source§fn product<I>(iter: I) -> Selfwhere
I: Iterator<Item = MontyField31<FP>>,
fn product<I>(iter: I) -> Selfwhere
I: Iterator<Item = MontyField31<FP>>,
Takes an iterator and generates
Self
from the elements by multiplying
the items.Source§impl<FP: FieldParameters> Product for PackedMontyField31Neon<FP>
impl<FP: FieldParameters> Product for PackedMontyField31Neon<FP>
Source§impl<PMP: PackedMontyParameters> Sub<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> Sub<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
Source§type Output = PackedMontyField31Neon<PMP>
type Output = PackedMontyField31Neon<PMP>
The resulting type after applying the
-
operator.Source§fn sub(self, rhs: MontyField31<PMP>) -> Self
fn sub(self, rhs: MontyField31<PMP>) -> Self
Performs the
-
operation. Read moreSource§impl<PMP: PackedMontyParameters> Sub<PackedMontyField31Neon<PMP>> for MontyField31<PMP>
impl<PMP: PackedMontyParameters> Sub<PackedMontyField31Neon<PMP>> for MontyField31<PMP>
Source§type Output = PackedMontyField31Neon<PMP>
type Output = PackedMontyField31Neon<PMP>
The resulting type after applying the
-
operator.Source§fn sub(self, rhs: PackedMontyField31Neon<PMP>) -> PackedMontyField31Neon<PMP>
fn sub(self, rhs: PackedMontyField31Neon<PMP>) -> PackedMontyField31Neon<PMP>
Performs the
-
operation. Read moreSource§impl<PMP: PackedMontyParameters> Sub for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> Sub for PackedMontyField31Neon<PMP>
Source§impl<PMP: PackedMontyParameters> SubAssign<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> SubAssign<MontyField31<PMP>> for PackedMontyField31Neon<PMP>
Source§fn sub_assign(&mut self, rhs: MontyField31<PMP>)
fn sub_assign(&mut self, rhs: MontyField31<PMP>)
Performs the
-=
operation. Read moreSource§impl<PMP: PackedMontyParameters> SubAssign for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> SubAssign for PackedMontyField31Neon<PMP>
Source§fn sub_assign(&mut self, rhs: Self)
fn sub_assign(&mut self, rhs: Self)
Performs the
-=
operation. Read moreSource§impl<FP: FieldParameters> Sum<MontyField31<FP>> for PackedMontyField31Neon<FP>
impl<FP: FieldParameters> Sum<MontyField31<FP>> for PackedMontyField31Neon<FP>
Source§fn sum<I>(iter: I) -> Selfwhere
I: Iterator<Item = MontyField31<FP>>,
fn sum<I>(iter: I) -> Selfwhere
I: Iterator<Item = MontyField31<FP>>,
Takes an iterator and generates
Self
from the elements by “summing up”
the items.Source§impl<FP: FieldParameters> Sum for PackedMontyField31Neon<FP>
impl<FP: FieldParameters> Sum for PackedMontyField31Neon<FP>
impl<PMP: Copy + PackedMontyParameters> Copy for PackedMontyField31Neon<PMP>
impl<PMP: Eq + PackedMontyParameters> Eq for PackedMontyField31Neon<PMP>
impl<PMP: PackedMontyParameters> StructuralPartialEq for PackedMontyField31Neon<PMP>
Auto Trait Implementations§
impl<PMP> Freeze for PackedMontyField31Neon<PMP>
impl<PMP> RefUnwindSafe for PackedMontyField31Neon<PMP>where
PMP: RefUnwindSafe,
impl<PMP> Send for PackedMontyField31Neon<PMP>
impl<PMP> Sync for PackedMontyField31Neon<PMP>
impl<PMP> Unpin for PackedMontyField31Neon<PMP>where
PMP: Unpin,
impl<PMP> UnwindSafe for PackedMontyField31Neon<PMP>where
PMP: UnwindSafe,
Blanket Implementations§
Source§impl<AF> AbstractExtensionField<AF> for AFwhere
AF: AbstractField,
impl<AF> AbstractExtensionField<AF> for AFwhere
AF: AbstractField,
const D: usize = 1usize
fn from_base(b: AF) -> AF
Source§fn from_base_slice(bs: &[AF]) -> AF
fn from_base_slice(bs: &[AF]) -> AF
Suppose this field extension is represented by the quotient
ring B[X]/(f(X)) where B is
Base
and f is an irreducible
polynomial of degree D
. This function takes a slice bs
of
length at exactly D, and constructs the field element
\sum_i bs[i] * X^i. Read morefn from_base_iter<I>(iter: I) -> AFwhere
I: Iterator<Item = AF>,
Source§fn from_base_fn<F>(f: F) -> AF
fn from_base_fn<F>(f: F) -> AF
Similar to
core:array::from_fn
, with the same caveats as
from_base_slice
.Source§fn as_base_slice(&self) -> &[AF]
fn as_base_slice(&self) -> &[AF]
Suppose this field extension is represented by the quotient
ring B[X]/(f(X)) where B is
Base
and f is an irreducible
polynomial of degree D
. This function takes a field element
\sum_i bs[i] * X^i and returns the coefficients as a slice
bs
of length at most D containing, from lowest degree to
highest. Read moreSource§fn monomial(exponent: usize) -> Self
fn monomial(exponent: usize) -> Self
Suppose this field extension is represented by the quotient
ring B[X]/(f(X)) where B is
Base
and f is an irreducible
polynomial of degree D
. This function returns the field
element X^exponent
if exponent < D
and panics otherwise.
(The fact that f is not known at the point that this function
is defined prevents implementing exponentiation of higher
powers since the reduction cannot be performed.) Read moreSource§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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