use backend::hal::layouts::{Data, DataMut, DataRef, VecZnx, VecZnxToMut, VecZnxToRef}; use crate::layouts::{GLWECiphertext, GLWECiphertextToMut, GLWECiphertextToRef, Infos, SetMetaData}; pub struct GLWEPlaintext { pub data: VecZnx, pub basek: usize, pub k: usize, } impl Infos for GLWEPlaintext { type Inner = VecZnx; fn inner(&self) -> &Self::Inner { &self.data } fn basek(&self) -> usize { self.basek } fn k(&self) -> usize { self.k } } impl SetMetaData for GLWEPlaintext { fn set_k(&mut self, k: usize) { self.k = k } fn set_basek(&mut self, basek: usize) { self.basek = basek } } impl GLWEPlaintext> { pub fn alloc(n: usize, basek: usize, k: usize) -> Self { Self { data: VecZnx::alloc(n, 1, k.div_ceil(basek)), basek: basek, k, } } pub fn byte_of(n: usize, basek: usize, k: usize) -> usize { VecZnx::alloc_bytes(n, 1, k.div_ceil(basek)) } } impl GLWECiphertextToRef for GLWEPlaintext { fn to_ref(&self) -> GLWECiphertext<&[u8]> { GLWECiphertext { data: self.data.to_ref(), basek: self.basek, k: self.k, } } } impl GLWECiphertextToMut for GLWEPlaintext { fn to_mut(&mut self) -> GLWECiphertext<&mut [u8]> { GLWECiphertext { data: self.data.to_mut(), basek: self.basek, k: self.k, } } }