use backend::{alloc_aligned, ZnxView, ZnxViewMut}; use crate::{lwe::{LWEPlaintext}, Infos, LWECiphertext, LWESecret, SetMetaData}; impl LWECiphertext where DataSelf: AsRef<[u8]>{ pub fn decrypt(&self, pt: &mut LWEPlaintext, sk: &LWESecret) where DataPt: AsRef<[u8]> + AsMut<[u8]>, DataSk: AsRef<[u8]>{ #[cfg(debug_assertions)]{ assert_eq!(self.n(), sk.n()); } (0..pt.size().min(self.size())).for_each(|i|{ pt.data.at_mut(0, i)[0] = self.data.at(0, i)[0] + self.data.at(0, i)[1..].iter().zip(sk.data.at(0, 0)).map(|(x, y)| x * y).sum::(); }); let mut tmp_bytes: Vec = alloc_aligned(size_of::()); pt.data.normalize(self.basek(), 0, &mut tmp_bytes); pt.set_basek(self.basek()); pt.set_k(self.k().min(pt.size() * self.basek())); } }