Trait group_math::Group

source ·
pub trait Group<const LAMBDA: usize>where
    Self: Add<Output = Self> + AddAssign + PartialEq + Eq + Debug + Sized + Clone + Sync + Send + From<[u8; LAMBDA]>,{
    // Required methods
    fn zero() -> Self;
    fn add_inverse(self) -> Self;

    // Provided method
    fn add_inverse_if(self, t: bool) -> Self { ... }
}
Expand description

Group (mathematics) that can be converted from a byte array

Into<[u8; LAMBDA]> is not used so not included, but implemented by [byte] and [int]

Required Methods§

source

fn zero() -> Self

Zero in the group

source

fn add_inverse(self) -> Self

Additive inverse in the group, e.g., -x for x in the integer group

Provided Methods§

source

fn add_inverse_if(self, t: bool) -> Self

Helper to get the additive inverse if true. Used for expressions like $(-1)^n x$, in which t can be computed from n.

Object Safety§

This trait is not object safe.

Implementors§