pub struct NTTConvolution<R_main, R_twiddle, H, A = Global>where
R_main: ?Sized + ZnRing,
R_twiddle: ?Sized + ZnRing,
H: Homomorphism<R_twiddle, R_main> + Clone,
A: Allocator + Clone,{ /* private fields */ }Expand description
Computes the convolution over a finite field that has suitable roots of unity using a power-of-two length FFT (sometimes called Number-Theoretic Transform, NTT in this context).
§Availability
This API is marked as unstable and is only available when the unstable-enable crate feature is enabled. This comes with no stability guarantees, and could be changed or removed at any time.
Implementations§
Source§impl<R_main, R_twiddle, H, A> NTTConvolution<R_main, R_twiddle, H, A>
impl<R_main, R_twiddle, H, A> NTTConvolution<R_main, R_twiddle, H, A>
Trait Implementations§
Source§impl<R_main, R_twiddle, H, A> ConvolutionAlgorithm<R_main> for NTTConvolution<R_main, R_twiddle, H, A>
impl<R_main, R_twiddle, H, A> ConvolutionAlgorithm<R_main> for NTTConvolution<R_main, R_twiddle, H, A>
Source§type PreparedConvolutionOperand = PreparedConvolutionOperand<R_main, A>
type PreparedConvolutionOperand = PreparedConvolutionOperand<R_main, A>
Additional data associated to a list of ring elements, which can be used to
compute a convolution where this list is one of the operands faster. Read more
Source§fn supports_ring<S: RingStore<Type = R_main> + Copy>(&self, ring: S) -> bool
fn supports_ring<S: RingStore<Type = R_main> + Copy>(&self, ring: S) -> bool
Returns whether this convolution algorithm supports computations of
the given ring. Read more
Source§fn compute_convolution<S: RingStore<Type = R_main> + Copy, V1: VectorView<<R_main as RingBase>::Element>, V2: VectorView<<R_main as RingBase>::Element>>(
&self,
lhs: V1,
rhs: V2,
dst: &mut [R_main::Element],
ring: S,
)
fn compute_convolution<S: RingStore<Type = R_main> + Copy, V1: VectorView<<R_main as RingBase>::Element>, V2: VectorView<<R_main as RingBase>::Element>>( &self, lhs: V1, rhs: V2, dst: &mut [R_main::Element], ring: S, )
Source§fn prepare_convolution_operand<S, V>(
&self,
val: V,
length_hint: Option<usize>,
ring: S,
) -> Self::PreparedConvolutionOperand
fn prepare_convolution_operand<S, V>( &self, val: V, length_hint: Option<usize>, ring: S, ) -> Self::PreparedConvolutionOperand
Takes an input list of values and computes an opaque
ConvolutionAlgorithm::PreparedConvolutionOperand,
which can be used to compute future convolutions with this list of values faster. Read moreSource§fn compute_convolution_prepared<S, V1, V2>(
&self,
lhs: V1,
lhs_prep: Option<&Self::PreparedConvolutionOperand>,
rhs: V2,
rhs_prep: Option<&Self::PreparedConvolutionOperand>,
dst: &mut [R_main::Element],
ring: S,
)where
S: RingStore<Type = R_main> + Copy,
V1: VectorView<R_main::Element>,
V2: VectorView<R_main::Element>,
fn compute_convolution_prepared<S, V1, V2>(
&self,
lhs: V1,
lhs_prep: Option<&Self::PreparedConvolutionOperand>,
rhs: V2,
rhs_prep: Option<&Self::PreparedConvolutionOperand>,
dst: &mut [R_main::Element],
ring: S,
)where
S: RingStore<Type = R_main> + Copy,
V1: VectorView<R_main::Element>,
V2: VectorView<R_main::Element>,
Elementwise adds the convolution of
lhs and rhs to dst. If provided, the given
prepared convolution operands are used for a faster computation. Read moreSource§fn compute_convolution_sum<'a, S, I, V1, V2>(
&self,
values: I,
dst: &mut [R::Element],
ring: S,
)where
S: RingStore<Type = R> + Copy,
I: ExactSizeIterator<Item = (V1, Option<&'a Self::PreparedConvolutionOperand>, V2, Option<&'a Self::PreparedConvolutionOperand>)>,
V1: VectorView<R::Element>,
V2: VectorView<R::Element>,
Self: 'a,
R: 'a,
fn compute_convolution_sum<'a, S, I, V1, V2>(
&self,
values: I,
dst: &mut [R::Element],
ring: S,
)where
S: RingStore<Type = R> + Copy,
I: ExactSizeIterator<Item = (V1, Option<&'a Self::PreparedConvolutionOperand>, V2, Option<&'a Self::PreparedConvolutionOperand>)>,
V1: VectorView<R::Element>,
V2: VectorView<R::Element>,
Self: 'a,
R: 'a,
Computes a convolution for each tuple in the given sequence, and sums the result of each convolution
to
dst. Read moreAuto Trait Implementations§
impl<R_main, R_twiddle, H, A = Global> !Freeze for NTTConvolution<R_main, R_twiddle, H, A>
impl<R_main, R_twiddle, H, A = Global> !RefUnwindSafe for NTTConvolution<R_main, R_twiddle, H, A>
impl<R_main, R_twiddle, H, A> Send for NTTConvolution<R_main, R_twiddle, H, A>
impl<R_main, R_twiddle, H, A> Sync for NTTConvolution<R_main, R_twiddle, H, A>
impl<R_main, R_twiddle, H, A> Unpin for NTTConvolution<R_main, R_twiddle, H, A>
impl<R_main, R_twiddle, H, A> UnwindSafe for NTTConvolution<R_main, R_twiddle, H, A>where
H: UnwindSafe + RefUnwindSafe,
A: UnwindSafe,
<R_main as RingBase>::Element: RefUnwindSafe + UnwindSafe,
<R_twiddle as RingBase>::Element: RefUnwindSafe + UnwindSafe,
R_main: ?Sized,
R_twiddle: ?Sized,
Blanket Implementations§
Source§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> 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