pub struct CrtClientKey { /* private fields */ }Expand description
Client key “specialized” for CRT decomposition.
This key is a simple wrapper of the ClientKey, that only encrypt and decrypt in CRT decomposition.
§Example
use tfhe::integer::CrtClientKey;
use tfhe::shortint::parameters::PARAM_MESSAGE_3_CARRY_3_KS_PBS_GAUSSIAN_2M128;
let basis = vec![2, 3, 5];
let cks = CrtClientKey::new(PARAM_MESSAGE_3_CARRY_3_KS_PBS_GAUSSIAN_2M128, basis);
let msg = 13_u64;
// Encryption:
let ct = cks.encrypt(msg);
// Decryption:
let dec = cks.decrypt(&ct);
assert_eq!(msg, dec);Implementations§
Source§impl CrtClientKey
impl CrtClientKey
pub fn new<P>(parameters: P, moduli: Vec<u64>) -> Selfwhere
P: Into<PBSParameters>,
pub fn encrypt(&self, message: u64) -> CrtCiphertext
pub fn encrypt_native_crt(&self, message: u64) -> CrtCiphertext
pub fn decrypt(&self, ciphertext: &CrtCiphertext) -> u64
pub fn decrypt_native_crt(&self, ciphertext: &CrtCiphertext) -> u64
Sourcepub fn parameters(&self) -> AtomicPatternParameters
pub fn parameters(&self) -> AtomicPatternParameters
Returns the parameters used by the client key.
pub fn moduli(&self) -> &[u64]
Trait Implementations§
Source§impl AsRef<ClientKey> for CrtClientKey
impl AsRef<ClientKey> for CrtClientKey
Source§impl Clone for CrtClientKey
impl Clone for CrtClientKey
Source§fn clone(&self) -> CrtClientKey
fn clone(&self) -> CrtClientKey
Returns a duplicate 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 Debug for CrtClientKey
impl Debug for CrtClientKey
Source§impl<'de> Deserialize<'de> for CrtClientKey
impl<'de> Deserialize<'de> for CrtClientKey
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl PartialEq for CrtClientKey
impl PartialEq for CrtClientKey
Source§impl Serialize for CrtClientKey
impl Serialize for CrtClientKey
Source§impl Unversionize for CrtClientKeywhere
CrtClientKeyVersions: VersionsDispatch<Self>,
impl Unversionize for CrtClientKeywhere
CrtClientKeyVersions: VersionsDispatch<Self>,
Source§fn unversionize(
versioned: Self::VersionedOwned,
) -> Result<Self, UnversionizeError>
fn unversionize( versioned: Self::VersionedOwned, ) -> Result<Self, UnversionizeError>
Creates an object from a versioned enum, and eventually upgrades from previous
variants.
Source§impl UnversionizeVec for CrtClientKeywhere
CrtClientKeyVersions: VersionsDispatch<Self>,
impl UnversionizeVec for CrtClientKeywhere
CrtClientKeyVersions: VersionsDispatch<Self>,
fn unversionize_vec( versioned: Self::VersionedVec, ) -> Result<Vec<Self>, UnversionizeError>
Source§impl Version for CrtClientKeywhere
ClientKey: VersionizeOwned + Unversionize + Versionize,
Vec<u64>: VersionizeOwned + Unversionize + Versionize,
impl Version for CrtClientKeywhere
ClientKey: VersionizeOwned + Unversionize + Versionize,
Vec<u64>: VersionizeOwned + Unversionize + Versionize,
Source§impl Versionize for CrtClientKeywhere
CrtClientKeyVersions: VersionsDispatch<Self>,
impl Versionize for CrtClientKeywhere
CrtClientKeyVersions: VersionsDispatch<Self>,
Source§type Versioned<'vers> = <CrtClientKeyVersions as VersionsDispatch<CrtClientKey>>::Ref<'vers>
type Versioned<'vers> = <CrtClientKeyVersions as VersionsDispatch<CrtClientKey>>::Ref<'vers>
The equivalent versioned type. It should have a variant for each version.
It may own the underlying data or only hold a read-only reference to it.
Source§fn versionize(&self) -> Self::Versioned<'_>
fn versionize(&self) -> Self::Versioned<'_>
Wraps the object into a versioned enum with a variant for each version. This will
use references on the underlying types if possible.
Source§impl VersionizeOwned for CrtClientKeywhere
CrtClientKeyVersions: VersionsDispatch<Self>,
impl VersionizeOwned for CrtClientKeywhere
CrtClientKeyVersions: VersionsDispatch<Self>,
type VersionedOwned = <CrtClientKeyVersions as VersionsDispatch<CrtClientKey>>::Owned
Source§fn versionize_owned(self) -> Self::VersionedOwned
fn versionize_owned(self) -> Self::VersionedOwned
Wraps the object into a versioned enum with a variant for each version. This will
clone the underlying types.
Source§impl VersionizeSlice for CrtClientKeywhere
CrtClientKeyVersions: VersionsDispatch<Self>,
impl VersionizeSlice for CrtClientKeywhere
CrtClientKeyVersions: VersionsDispatch<Self>,
type VersionedSlice<'vers> = Vec<<CrtClientKey as Versionize>::Versioned<'vers>>
fn versionize_slice(slice: &[Self]) -> Self::VersionedSlice<'_>
Source§impl VersionizeVec for CrtClientKeywhere
CrtClientKeyVersions: VersionsDispatch<Self>,
impl VersionizeVec for CrtClientKeywhere
CrtClientKeyVersions: VersionsDispatch<Self>,
type VersionedVec = Vec<<CrtClientKey as VersionizeOwned>::VersionedOwned>
fn versionize_vec(vec: Vec<Self>) -> Self::VersionedVec
Source§impl VersionsDispatch<CrtClientKey> for CrtClientKeyVersionswhere
CrtClientKey: Version,
impl VersionsDispatch<CrtClientKey> for CrtClientKeyVersionswhere
CrtClientKey: Version,
impl StructuralPartialEq for CrtClientKey
Auto Trait Implementations§
impl Freeze for CrtClientKey
impl RefUnwindSafe for CrtClientKey
impl Send for CrtClientKey
impl Sync for CrtClientKey
impl Unpin for CrtClientKey
impl UnwindSafe for CrtClientKey
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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