pub struct GGSW<D: Data> { /* private fields */ }Implementations§
Source§impl GGSW<Vec<u8>>
impl GGSW<Vec<u8>>
Source§impl<D: DataMut> GGSW<D>
impl<D: DataMut> GGSW<D>
pub fn automorphism<A, K, T, M, BE: Backend>(
&mut self,
module: &M,
a: &A,
key: &K,
tsk: &T,
scratch: &mut Scratch<BE>,
)where
A: GGSWToRef + GGSWInfos,
K: GetGaloisElement + GGLWEPreparedToRef<BE> + GGLWEInfos,
T: GGLWEToGGSWKeyPreparedToRef<BE> + GGLWEInfos,
Scratch<BE>: ScratchTakeCore<BE>,
M: GGSWAutomorphism<BE>,
pub fn automorphism_inplace<K, T, M, BE: Backend>(
&mut self,
module: &M,
key: &K,
tsk: &T,
scratch: &mut Scratch<BE>,
)where
K: GetGaloisElement + GGLWEPreparedToRef<BE> + GGLWEInfos,
T: GGLWEToGGSWKeyPreparedToRef<BE>,
Scratch<BE>: ScratchTakeCore<BE>,
M: GGSWAutomorphism<BE>,
Source§impl<D: DataMut> GGSW<D>
impl<D: DataMut> GGSW<D>
pub fn from_gglwe<G, M, T, BE: Backend>(
&mut self,
module: &M,
gglwe: &G,
tsk: &T,
scratch: &mut Scratch<BE>,
)where
M: GGSWFromGGLWE<BE>,
G: GGLWEToRef,
T: GGLWEToGGSWKeyPreparedToRef<BE>,
Scratch<BE>: ScratchTakeCore<BE>,
Source§impl GGSW<Vec<u8>>
impl GGSW<Vec<u8>>
pub fn encrypt_sk_tmp_bytes<M, A, BE: Backend>(module: &M, infos: &A) -> usizewhere
A: GGSWInfos,
M: GGSWEncryptSk<BE>,
Source§impl<D: DataMut> GGSW<D>
impl<D: DataMut> GGSW<D>
pub fn encrypt_sk<P, S, M, BE: Backend>(
&mut self,
module: &M,
pt: &P,
sk: &S,
source_xa: &mut Source,
source_xe: &mut Source,
scratch: &mut Scratch<BE>,
)where
P: ScalarZnxToRef,
S: GLWESecretPreparedToRef<BE>,
M: GGSWEncryptSk<BE>,
Scratch<BE>: ScratchTakeCore<BE>,
Source§impl<DataSelf: DataMut> GGSW<DataSelf>
impl<DataSelf: DataMut> GGSW<DataSelf>
pub fn external_product<A, B, M, BE: Backend>(
&mut self,
module: &M,
a: &A,
b: &B,
scratch: &mut Scratch<BE>,
)where
M: GGSWExternalProduct<BE>,
A: GGSWToRef,
B: GGSWPreparedToRef<BE>,
Scratch<BE>: ScratchTakeCore<BE>,
pub fn external_product_inplace<A, M, BE: Backend>( &mut self, module: &M, a: &A, scratch: &mut Scratch<BE>, )
Source§impl GGSW<Vec<u8>>
impl GGSW<Vec<u8>>
Source§impl<D: DataMut> GGSW<D>
impl<D: DataMut> GGSW<D>
pub fn keyswitch<M, A, K, T, BE: Backend>(
&mut self,
module: &M,
a: &A,
key: &K,
tsk: &T,
scratch: &mut Scratch<BE>,
)where
A: GGSWToRef,
K: GGLWEPreparedToRef<BE> + GGLWEInfos,
T: GGLWEToGGSWKeyPreparedToRef<BE>,
Scratch<BE>: ScratchTakeCore<BE>,
M: GGSWKeyswitch<BE>,
pub fn keyswitch_inplace<M, K, T, BE: Backend>(
&mut self,
module: &M,
key: &K,
tsk: &T,
scratch: &mut Scratch<BE>,
)where
K: GGLWEPreparedToRef<BE> + GGLWEInfos,
T: GGLWEToGGSWKeyPreparedToRef<BE>,
Scratch<BE>: ScratchTakeCore<BE>,
M: GGSWKeyswitch<BE>,
Source§impl<D: DataRef> GGSW<D>
impl<D: DataRef> GGSW<D>
pub fn noise<M, BE: Backend, P, S>(
&self,
module: &M,
row: usize,
col: usize,
pt_want: &P,
sk_prepared: &S,
scratch: &mut Scratch<BE>,
) -> Statswhere
S: GLWESecretPreparedToRef<BE>,
P: ScalarZnxToRef,
M: GGSWNoise<BE>,
Scratch<BE>: ScratchTakeCore<BE>,
Source§impl GGSW<Vec<u8>>
impl GGSW<Vec<u8>>
pub fn alloc_from_infos<A>(infos: &A) -> Selfwhere
A: GGSWInfos,
pub fn alloc( n: Degree, base2k: Base2K, k: TorusPrecision, rank: Rank, dnum: Dnum, dsize: Dsize, ) -> Self
pub fn bytes_of_from_infos<A>(infos: &A) -> usizewhere
A: GGSWInfos,
pub fn bytes_of( n: Degree, base2k: Base2K, k: TorusPrecision, rank: Rank, dnum: Dnum, dsize: Dsize, ) -> usize
Source§impl<D: DataMut> GGSW<D>
impl<D: DataMut> GGSW<D>
pub fn decompress<O, M>(&mut self, module: &M, other: &O)where
O: GGSWCompressedToRef,
M: GGSWDecompress,
Trait Implementations§
Source§impl<D: DataMut> FillUniform for GGSW<D>
impl<D: DataMut> FillUniform for GGSW<D>
fn fill_uniform(&mut self, log_bound: usize, source: &mut Source)
Source§impl<D: Data> GLWEInfos for GGSW<D>
impl<D: Data> GLWEInfos for GGSW<D>
fn rank(&self) -> Rank
fn glwe_layout(&self) -> GLWELayout
Source§impl<D: DataMut> ReaderFrom for GGSW<D>
impl<D: DataMut> ReaderFrom for GGSW<D>
impl<D: Eq + Data> Eq for GGSW<D>
impl<D: Data> StructuralPartialEq for GGSW<D>
Auto Trait Implementations§
impl<D> Freeze for GGSW<D>where
D: Freeze,
impl<D> RefUnwindSafe for GGSW<D>where
D: RefUnwindSafe,
impl<D> Send for GGSW<D>where
D: Send,
impl<D> Sync for GGSW<D>where
D: Sync,
impl<D> Unpin for GGSW<D>where
D: Unpin,
impl<D> UnwindSafe for GGSW<D>where
D: 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> CheckedAs for T
impl<T> CheckedAs for T
Source§fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
Casts the value.
Source§impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
Source§fn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
Casts the value.
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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 moreSource§impl<T> OverflowingAs for T
impl<T> OverflowingAs for T
Source§fn overflowing_as<Dst>(self) -> (Dst, bool)where
T: OverflowingCast<Dst>,
fn overflowing_as<Dst>(self) -> (Dst, bool)where
T: OverflowingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere
Src: OverflowingCast<Dst>,
impl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere
Src: OverflowingCast<Dst>,
Source§fn overflowing_cast_from(src: Src) -> (Dst, bool)
fn overflowing_cast_from(src: Src) -> (Dst, bool)
Casts the value.
Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> SaturatingAs for T
impl<T> SaturatingAs for T
Source§fn saturating_as<Dst>(self) -> Dstwhere
T: SaturatingCast<Dst>,
fn saturating_as<Dst>(self) -> Dstwhere
T: SaturatingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere
Src: SaturatingCast<Dst>,
impl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere
Src: SaturatingCast<Dst>,
Source§fn saturating_cast_from(src: Src) -> Dst
fn saturating_cast_from(src: Src) -> Dst
Casts the value.
Source§impl<T> UnwrappedAs for T
impl<T> UnwrappedAs for T
Source§fn unwrapped_as<Dst>(self) -> Dstwhere
T: UnwrappedCast<Dst>,
fn unwrapped_as<Dst>(self) -> Dstwhere
T: UnwrappedCast<Dst>,
Casts the value.
Source§impl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere
Src: UnwrappedCast<Dst>,
impl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere
Src: UnwrappedCast<Dst>,
Source§fn unwrapped_cast_from(src: Src) -> Dst
fn unwrapped_cast_from(src: Src) -> Dst
Casts the value.
Source§impl<T> WrappingAs for T
impl<T> WrappingAs for T
Source§fn wrapping_as<Dst>(self) -> Dstwhere
T: WrappingCast<Dst>,
fn wrapping_as<Dst>(self) -> Dstwhere
T: WrappingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> WrappingCastFrom<Src> for Dstwhere
Src: WrappingCast<Dst>,
impl<Src, Dst> WrappingCastFrom<Src> for Dstwhere
Src: WrappingCast<Dst>,
Source§fn wrapping_cast_from(src: Src) -> Dst
fn wrapping_cast_from(src: Src) -> Dst
Casts the value.