use super::engine_error;
use crate::prelude::{DecompositionBaseLog, DecompositionLevelCount, GlweSize, PolynomialSize};
use crate::specification::engines::AbstractEngine;
use crate::specification::entities::LweBootstrapKeyEntity;
engine_error! {
LweBootstrapKeyCreationError for LweBootstrapKeyCreationEngine @
NullDecompositionBaseLog => "The key decomposition base log must be greater than zero.",
NullDecompositionLevelCount => "The key decomposition level count must be greater than zero.",
DecompositionTooLarge => "The decomposition precision (base log * level count) must not exceed \
the precision of the ciphertext.",
InvalidContainerSize => "The length of the container used to create the LWE bootstrap key \
needs to be a multiple of \
`decomposition_level_count * glwe_size * glwe_size * poly_size`."
}
impl<EngineError: std::error::Error> LweBootstrapKeyCreationError<EngineError> {
pub fn perform_generic_checks(
container_length: usize,
glwe_size: GlweSize,
poly_size: PolynomialSize,
decomposition_base_log: DecompositionBaseLog,
decomposition_level_count: DecompositionLevelCount,
ciphertext_modulus_log: usize,
) -> Result<(), Self> {
if decomposition_base_log.0 == 0 {
return Err(Self::NullDecompositionBaseLog);
}
if decomposition_level_count.0 == 0 {
return Err(Self::NullDecompositionLevelCount);
}
if decomposition_base_log.0 * decomposition_level_count.0 > ciphertext_modulus_log {
return Err(Self::DecompositionTooLarge);
}
if container_length
% (decomposition_level_count.0 * glwe_size.0 * glwe_size.0 * poly_size.0)
!= 0
{
return Err(Self::InvalidContainerSize);
}
Ok(())
}
}
pub trait LweBootstrapKeyCreationEngine<Container, BootstrapKey>: AbstractEngine
where
BootstrapKey: LweBootstrapKeyEntity,
{
fn create_lwe_bootstrap_key_from(
&mut self,
container: Container,
glwe_size: GlweSize,
poly_size: PolynomialSize,
decomposition_base_log: DecompositionBaseLog,
decomposition_level_count: DecompositionLevelCount,
) -> Result<BootstrapKey, LweBootstrapKeyCreationError<Self::EngineError>>;
unsafe fn create_lwe_bootstrap_key_from_unchecked(
&mut self,
container: Container,
glwe_size: GlweSize,
poly_size: PolynomialSize,
decomposition_base_log: DecompositionBaseLog,
decomposition_level_count: DecompositionLevelCount,
) -> BootstrapKey;
}