pub struct RNSConvolutionZn<I = BigIntRing, C = NTTConvolution<ZnBase, ZnFastmulBase, CanHom<ZnFastmul, Zn>>, A = Global, CreateC = CreateNTTConvolution>where
I: RingStore + Clone,
I::Type: IntegerRing,
C: ConvolutionAlgorithm<ZnBase>,
A: Allocator + Clone,
CreateC: Fn(Zn) -> C,{ /* private fields */ }
Expand description
Same as RNSConvolution
, but computes convolutions over ZnRing
s.
§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.
Trait Implementations§
Source§impl<R, I, C, A, CreateC> ConvolutionAlgorithm<R> for RNSConvolutionZn<I, C, A, CreateC>where
I: RingStore + Clone,
I::Type: IntegerRing,
C: ConvolutionAlgorithm<ZnBase>,
A: Allocator + Clone,
CreateC: Fn(Zn) -> C,
R: ?Sized + ZnRing + CanHomFrom<I::Type>,
impl<R, I, C, A, CreateC> ConvolutionAlgorithm<R> for RNSConvolutionZn<I, C, A, CreateC>where
I: RingStore + Clone,
I::Type: IntegerRing,
C: ConvolutionAlgorithm<ZnBase>,
A: Allocator + Clone,
CreateC: Fn(Zn) -> C,
R: ?Sized + ZnRing + CanHomFrom<I::Type>,
Source§type PreparedConvolutionOperand = PreparedConvolutionOperand<R, C>
type PreparedConvolutionOperand = PreparedConvolutionOperand<R, C>
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 compute_convolution<S: RingStore<Type = R> + Copy, V1: VectorView<<R as RingBase>::Element>, V2: VectorView<<R as RingBase>::Element>>(
&self,
lhs: V1,
rhs: V2,
dst: &mut [<R as RingBase>::Element],
ring: S,
)
fn compute_convolution<S: RingStore<Type = R> + Copy, V1: VectorView<<R as RingBase>::Element>, V2: VectorView<<R as RingBase>::Element>>( &self, lhs: V1, rhs: V2, dst: &mut [<R as RingBase>::Element], ring: S, )
Source§fn supports_ring<S: RingStore<Type = R> + Copy>(&self, _ring: S) -> bool
fn supports_ring<S: RingStore<Type = R> + Copy>(&self, _ring: S) -> bool
Returns whether this convolution algorithm supports computations of
the given ring. Read more
Source§fn prepare_convolution_operand<S, V>(
&self,
val: V,
len_hint: Option<usize>,
ring: S,
) -> Self::PreparedConvolutionOperand
fn prepare_convolution_operand<S, V>( &self, val: V, len_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::Element],
ring: S,
)
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::Element], ring: S, )
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, J, V1, V2>(
&self,
values: J,
dst: &mut [R::Element],
ring: S,
)where
S: RingStore<Type = R> + Copy,
J: 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, J, V1, V2>(
&self,
values: J,
dst: &mut [R::Element],
ring: S,
)where
S: RingStore<Type = R> + Copy,
J: 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 moreSource§impl<'a, I, C, A, CreateC> From<&'a RNSConvolution<I, C, A, CreateC>> for &'a RNSConvolutionZn<I, C, A, CreateC>where
I: RingStore + Clone,
I::Type: IntegerRing,
C: ConvolutionAlgorithm<ZnBase>,
A: Allocator + Clone,
CreateC: Fn(Zn) -> C,
impl<'a, I, C, A, CreateC> From<&'a RNSConvolution<I, C, A, CreateC>> for &'a RNSConvolutionZn<I, C, A, CreateC>where
I: RingStore + Clone,
I::Type: IntegerRing,
C: ConvolutionAlgorithm<ZnBase>,
A: Allocator + Clone,
CreateC: Fn(Zn) -> C,
Source§fn from(value: &'a RNSConvolution<I, C, A, CreateC>) -> Self
fn from(value: &'a RNSConvolution<I, C, A, CreateC>) -> Self
Converts to this type from the input type.
Source§impl<'a, I, C, A, CreateC> From<&'a RNSConvolutionZn<I, C, A, CreateC>> for &'a RNSConvolution<I, C, A, CreateC>where
I: RingStore + Clone,
I::Type: IntegerRing,
C: ConvolutionAlgorithm<ZnBase>,
A: Allocator + Clone,
CreateC: Fn(Zn) -> C,
impl<'a, I, C, A, CreateC> From<&'a RNSConvolutionZn<I, C, A, CreateC>> for &'a RNSConvolution<I, C, A, CreateC>where
I: RingStore + Clone,
I::Type: IntegerRing,
C: ConvolutionAlgorithm<ZnBase>,
A: Allocator + Clone,
CreateC: Fn(Zn) -> C,
Source§fn from(value: &'a RNSConvolutionZn<I, C, A, CreateC>) -> Self
fn from(value: &'a RNSConvolutionZn<I, C, A, CreateC>) -> Self
Converts to this type from the input type.
Source§impl<I, C, A, CreateC> From<RNSConvolution<I, C, A, CreateC>> for RNSConvolutionZn<I, C, A, CreateC>where
I: RingStore + Clone,
I::Type: IntegerRing,
C: ConvolutionAlgorithm<ZnBase>,
A: Allocator + Clone,
CreateC: Fn(Zn) -> C,
impl<I, C, A, CreateC> From<RNSConvolution<I, C, A, CreateC>> for RNSConvolutionZn<I, C, A, CreateC>where
I: RingStore + Clone,
I::Type: IntegerRing,
C: ConvolutionAlgorithm<ZnBase>,
A: Allocator + Clone,
CreateC: Fn(Zn) -> C,
Source§fn from(value: RNSConvolution<I, C, A, CreateC>) -> Self
fn from(value: RNSConvolution<I, C, A, CreateC>) -> Self
Converts to this type from the input type.
Source§impl<I, C, A, CreateC> From<RNSConvolutionZn<I, C, A, CreateC>> for RNSConvolution<I, C, A, CreateC>where
I: RingStore + Clone,
I::Type: IntegerRing,
C: ConvolutionAlgorithm<ZnBase>,
A: Allocator + Clone,
CreateC: Fn(Zn) -> C,
impl<I, C, A, CreateC> From<RNSConvolutionZn<I, C, A, CreateC>> for RNSConvolution<I, C, A, CreateC>where
I: RingStore + Clone,
I::Type: IntegerRing,
C: ConvolutionAlgorithm<ZnBase>,
A: Allocator + Clone,
CreateC: Fn(Zn) -> C,
Source§fn from(value: RNSConvolutionZn<I, C, A, CreateC>) -> Self
fn from(value: RNSConvolutionZn<I, C, A, CreateC>) -> Self
Converts to this type from the input type.
Auto Trait Implementations§
impl<I = RingValue<MPZBase>, C = NTTConvolution<ZnBase, ZnFastmulBase, CanHom<RingValue<ZnFastmulBase>, RingValue<ZnBase>>>, A = Global, CreateC = CreateNTTConvolution> !Freeze for RNSConvolutionZn<I, C, A, CreateC>
impl<I = RingValue<MPZBase>, C = NTTConvolution<ZnBase, ZnFastmulBase, CanHom<RingValue<ZnFastmulBase>, RingValue<ZnBase>>>, A = Global, CreateC = CreateNTTConvolution> !RefUnwindSafe for RNSConvolutionZn<I, C, A, CreateC>
impl<I, C, A, CreateC> Send for RNSConvolutionZn<I, C, A, CreateC>
impl<I, C, A, CreateC> Sync for RNSConvolutionZn<I, C, A, CreateC>
impl<I, C, A, CreateC> Unpin for RNSConvolutionZn<I, C, A, CreateC>
impl<I, C, A, CreateC> UnwindSafe for RNSConvolutionZn<I, C, A, CreateC>where
I: UnwindSafe + RefUnwindSafe,
CreateC: UnwindSafe,
A: UnwindSafe + RefUnwindSafe,
C: RefUnwindSafe + UnwindSafe,
<<I as RingStore>::Type as RingBase>::Element: RefUnwindSafe + UnwindSafe,
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