poulpy_core/layouts/
glwe_to_lwe_ksk.rs1use poulpy_hal::{
2 layouts::{Data, DataMut, DataRef, FillUniform, MatZnx, ReaderFrom, Reset, WriterTo},
3 source::Source,
4};
5
6use crate::layouts::{GGLWESwitchingKey, Infos};
7
8use std::fmt;
9
10#[derive(PartialEq, Eq, Clone)]
12pub struct GLWEToLWESwitchingKey<D: Data>(pub(crate) GGLWESwitchingKey<D>);
13
14impl<D: DataRef> fmt::Debug for GLWEToLWESwitchingKey<D> {
15 fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
16 write!(f, "{}", self)
17 }
18}
19
20impl<D: DataMut> FillUniform for GLWEToLWESwitchingKey<D> {
21 fn fill_uniform(&mut self, log_bound: usize, source: &mut Source) {
22 self.0.fill_uniform(log_bound, source);
23 }
24}
25
26impl<D: DataMut> Reset for GLWEToLWESwitchingKey<D> {
27 fn reset(&mut self) {
28 self.0.reset();
29 }
30}
31
32impl<D: DataRef> fmt::Display for GLWEToLWESwitchingKey<D> {
33 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
34 write!(f, "(GLWEToLWESwitchingKey) {}", self.0)
35 }
36}
37
38impl<D: Data> Infos for GLWEToLWESwitchingKey<D> {
39 type Inner = MatZnx<D>;
40
41 fn inner(&self) -> &Self::Inner {
42 self.0.inner()
43 }
44
45 fn basek(&self) -> usize {
46 self.0.basek()
47 }
48
49 fn k(&self) -> usize {
50 self.0.k()
51 }
52}
53
54impl<D: Data> GLWEToLWESwitchingKey<D> {
55 pub fn digits(&self) -> usize {
56 self.0.digits()
57 }
58
59 pub fn rank(&self) -> usize {
60 self.0.rank()
61 }
62
63 pub fn rank_in(&self) -> usize {
64 self.0.rank_in()
65 }
66
67 pub fn rank_out(&self) -> usize {
68 self.0.rank_out()
69 }
70}
71
72impl<D: DataMut> ReaderFrom for GLWEToLWESwitchingKey<D> {
73 fn read_from<R: std::io::Read>(&mut self, reader: &mut R) -> std::io::Result<()> {
74 self.0.read_from(reader)
75 }
76}
77
78impl<D: DataRef> WriterTo for GLWEToLWESwitchingKey<D> {
79 fn write_to<W: std::io::Write>(&self, writer: &mut W) -> std::io::Result<()> {
80 self.0.write_to(writer)
81 }
82}
83
84impl GLWEToLWESwitchingKey<Vec<u8>> {
85 pub fn alloc(n: usize, basek: usize, k: usize, rows: usize, rank_in: usize) -> Self {
86 Self(GGLWESwitchingKey::alloc(n, basek, k, rows, 1, rank_in, 1))
87 }
88}