Skip to main content

Cl15k

Struct Cl15k 

Source
pub struct Cl15k<Up, Udk> {
    p: Odd<Up>,
    absolute_value: Udk,
}
Expand description

A fundamental discriminant as part of the CL15 cryptosystem.

This is constructed as detailed in “Linearly Homomorphic Encryption from DDH” by Guilhem Castagnos and Fabien Laguillaumie (https://eprint.iacr.org/2025/047), corresponding to $\Delta_K$.

Up is the numeric type used to represent the prime p. Udk is the numeric type used to represent the discriminant’s absolute value, the product $q * p$.

Fields§

§p: Odd<Up>§absolute_value: Udk

Implementations§

Source§

impl<Up, Udk> Cl15k<Up, Udk>

Source

pub fn p(&self) -> &Up

The prime p from the setup.

Trait Implementations§

Source§

impl<Up: Clone, Udk: Clone> Clone for Cl15k<Up, Udk>

Source§

fn clone(&self) -> Cl15k<Up, Udk>

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<Up, Udk> Discriminant for Cl15k<Up, Udk>

Source§

impl<Up, Udk> FundamentalDiscriminant for Cl15k<Up, Udk>

Source§

fn inject<E: Element>(&self, element: impl Element, p: &impl Encoding) -> E

Available on crate feature alloc only.
Take an element of the class group with fundamental discriminant and apply the injection such that it is mapped to an element of the class group with non-fundamental discriminant. Read more
Source§

impl<Up, Udk: Encoding> NegativeDiscriminant for Cl15k<Up, Udk>

Source§

fn absolute_value(&self) -> impl AsRef<[u8]>

This runs in time variable to the bit-length of the discriminant.

Source§

fn upper_bound_on_order(&self) -> u32

An upper bound on the order of the class group with this discriminant. Read more
Source§

impl<Up, Udk> OddDiscriminant for Cl15k<Up, Udk>

Auto Trait Implementations§

§

impl<Up, Udk> Freeze for Cl15k<Up, Udk>
where Udk: Freeze, Up: Freeze,

§

impl<Up, Udk> RefUnwindSafe for Cl15k<Up, Udk>
where Udk: RefUnwindSafe, Up: RefUnwindSafe,

§

impl<Up, Udk> Send for Cl15k<Up, Udk>
where Udk: Send, Up: Send,

§

impl<Up, Udk> Sync for Cl15k<Up, Udk>
where Udk: Sync, Up: Sync,

§

impl<Up, Udk> Unpin for Cl15k<Up, Udk>
where Udk: Unpin, Up: Unpin,

§

impl<Up, Udk> UnsafeUnpin for Cl15k<Up, Udk>
where Udk: UnsafeUnpin, Up: UnsafeUnpin,

§

impl<Up, Udk> UnwindSafe for Cl15k<Up, Udk>
where Udk: UnwindSafe, Up: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> SizedTypeProperties for T

Source§

#[doc(hidden)]
const SIZE: usize = _

🔬This is a nightly-only experimental API. (sized_type_properties)
Source§

#[doc(hidden)]
const ALIGN: usize = _

🔬This is a nightly-only experimental API. (sized_type_properties)
Source§

#[doc(hidden)]
const ALIGNMENT: Alignment = _

🔬This is a nightly-only experimental API. (ptr_alignment_type)
Source§

#[doc(hidden)]
const IS_ZST: bool = _

🔬This is a nightly-only experimental API. (sized_type_properties)
true if this type requires no storage. false if its size is greater than zero. Read more
Source§

#[doc(hidden)]
const LAYOUT: Layout = _

🔬This is a nightly-only experimental API. (sized_type_properties)
Source§

#[doc(hidden)]
const MAX_SLICE_LEN: usize = _

🔬This is a nightly-only experimental API. (sized_type_properties)
The largest safe length for a [Self]. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.