use backend::hal::{ api::{FillUniform, Reset}, layouts::{Data, DataMut, DataRef, MatZnx, ReaderFrom, WriterTo}, }; use crate::layouts::{GGLWESwitchingKey, GLWECiphertext, Infos}; use byteorder::{LittleEndian, ReadBytesExt, WriteBytesExt}; use std::fmt; #[derive(PartialEq, Eq, Clone)] pub struct GGLWEAutomorphismKey { pub(crate) key: GGLWESwitchingKey, pub(crate) p: i64, } impl fmt::Debug for GGLWEAutomorphismKey { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { write!(f, "{}", self) } } impl FillUniform for GGLWEAutomorphismKey { fn fill_uniform(&mut self, source: &mut sampling::source::Source) { self.key.fill_uniform(source); } } impl Reset for GGLWEAutomorphismKey where MatZnx: Reset, { fn reset(&mut self) { self.key.reset(); self.p = 0; } } impl fmt::Display for GGLWEAutomorphismKey { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "(AutomorphismKey: p={}) {}", self.p, self.key) } } impl GGLWEAutomorphismKey> { pub fn alloc(n: usize, basek: usize, k: usize, rows: usize, digits: usize, rank: usize) -> Self { GGLWEAutomorphismKey { key: GGLWESwitchingKey::alloc(n, basek, k, rows, digits, rank, rank), p: 0, } } pub fn bytes_of(n: usize, basek: usize, k: usize, rows: usize, digits: usize, rank: usize) -> usize { GGLWESwitchingKey::bytes_of(n, basek, k, rows, digits, rank, rank) } } impl Infos for GGLWEAutomorphismKey { type Inner = MatZnx; fn inner(&self) -> &Self::Inner { self.key.inner() } fn basek(&self) -> usize { self.key.basek() } fn k(&self) -> usize { self.key.k() } } impl GGLWEAutomorphismKey { pub fn p(&self) -> i64 { self.p } pub fn digits(&self) -> usize { self.key.digits() } pub fn rank(&self) -> usize { self.key.rank() } pub fn rank_in(&self) -> usize { self.key.rank_in() } pub fn rank_out(&self) -> usize { self.key.rank_out() } } impl GGLWEAutomorphismKey { pub fn at(&self, row: usize, col: usize) -> GLWECiphertext<&[u8]> { self.key.at(row, col) } } impl GGLWEAutomorphismKey { pub fn at_mut(&mut self, row: usize, col: usize) -> GLWECiphertext<&mut [u8]> { self.key.at_mut(row, col) } } impl ReaderFrom for GGLWEAutomorphismKey { fn read_from(&mut self, reader: &mut R) -> std::io::Result<()> { self.p = reader.read_u64::()? as i64; self.key.read_from(reader) } } impl WriterTo for GGLWEAutomorphismKey { fn write_to(&self, writer: &mut W) -> std::io::Result<()> { writer.write_u64::(self.p as u64)?; self.key.write_to(writer) } }