From 83087cc24c00e8415b8f292058786fcd42e4d212 Mon Sep 17 00:00:00 2001 From: Bogdan Opanchuk Date: Thu, 28 Dec 2023 15:56:17 -0800 Subject: [PATCH 1/3] Add `Integer::from_limb_like()`, `one_like()`, `zero_like()`. --- src/traits.rs | 13 +++++++++++++ src/uint.rs | 4 ++++ src/uint/boxed.rs | 6 ++++++ 3 files changed, 23 insertions(+) diff --git a/src/traits.rs b/src/traits.rs index cff9782c..245eb9f4 100644 --- a/src/traits.rs +++ b/src/traits.rs @@ -158,6 +158,19 @@ pub trait Integer: /// The value `1`. fn one() -> Self; + /// The value `0` with the same precision as `other`. + fn zero_like(other: &Self) -> Self { + Self::from_limb_like(Limb::ZERO, other) + } + + /// The value `1` with the same precision as `other`. + fn one_like(other: &Self) -> Self { + Self::from_limb_like(Limb::ONE, other) + } + + /// Returns an integer with the first limb set to `limb`, and the same precision as `other`. + fn from_limb_like(limb: Limb, other: &Self) -> Self; + /// Number of limbs in this integer. fn nlimbs(&self) -> usize; diff --git a/src/uint.rs b/src/uint.rs index 7ab7ead5..e483e0b5 100644 --- a/src/uint.rs +++ b/src/uint.rs @@ -249,6 +249,10 @@ impl Integer for Uint { Self::ONE } + fn from_limb_like(limb: Limb, _other: &Self) -> Self { + Self::from(limb) + } + fn nlimbs(&self) -> usize { Self::LIMBS } diff --git a/src/uint/boxed.rs b/src/uint/boxed.rs index d8b50647..9e0935e0 100644 --- a/src/uint/boxed.rs +++ b/src/uint/boxed.rs @@ -307,6 +307,12 @@ impl Integer for BoxedUint { Self::one() } + fn from_limb_like(limb: Limb, other: &Self) -> Self { + let mut ret = Self::zero_with_precision(other.bits_precision()); + ret.limbs[0] = limb; + ret + } + fn nlimbs(&self) -> usize { self.nlimbs() } From bb823e10db5b438e4249ecd54522dbbb640a9c43 Mon Sep 17 00:00:00 2001 From: Bogdan Opanchuk Date: Thu, 28 Dec 2023 15:56:34 -0800 Subject: [PATCH 2/3] Add `Monty::params()` and `as_montgomery()` --- src/modular/boxed_monty_form.rs | 8 ++++++++ src/modular/monty_form.rs | 8 ++++++++ src/traits.rs | 6 ++++++ 3 files changed, 22 insertions(+) diff --git a/src/modular/boxed_monty_form.rs b/src/modular/boxed_monty_form.rs index 2c6fe07e..5098d5db 100644 --- a/src/modular/boxed_monty_form.rs +++ b/src/modular/boxed_monty_form.rs @@ -256,6 +256,14 @@ impl Monty for BoxedMontyForm { BoxedMontyForm::one(params) } + fn params(&self) -> &Self::Params { + &self.params + } + + fn as_montgomery(&self) -> &Self::Integer { + &self.montgomery_form + } + fn div_by_2(&self) -> Self { BoxedMontyForm::div_by_2(self) } diff --git a/src/modular/monty_form.rs b/src/modular/monty_form.rs index 905a7267..2e018790 100644 --- a/src/modular/monty_form.rs +++ b/src/modular/monty_form.rs @@ -250,6 +250,14 @@ impl Monty for MontyForm { MontyForm::one(params) } + fn params(&self) -> &Self::Params { + &self.params + } + + fn as_montgomery(&self) -> &Self::Integer { + &self.montgomery_form + } + fn div_by_2(&self) -> Self { MontyForm::div_by_2(self) } diff --git a/src/traits.rs b/src/traits.rs index 245eb9f4..990e714b 100644 --- a/src/traits.rs +++ b/src/traits.rs @@ -800,6 +800,12 @@ pub trait Monty: /// Returns one in this representation. fn one(params: Self::Params) -> Self; + /// Returns the parameter struct used to initialize this object. + fn params(&self) -> &Self::Params; + + /// Access the value in Montgomery form. + fn as_montgomery(&self) -> &Self::Integer; + /// Performs division by 2, that is returns `x` such that `x + x = self`. fn div_by_2(&self) -> Self; } From 927045978298f3acf6cffd1573857fbc4c2f37dd Mon Sep 17 00:00:00 2001 From: Bogdan Opanchuk Date: Fri, 29 Dec 2023 10:55:50 -0800 Subject: [PATCH 3/3] Move `zero_like()` to the `Zero` trait --- src/traits.rs | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/src/traits.rs b/src/traits.rs index 990e714b..410f3c68 100644 --- a/src/traits.rs +++ b/src/traits.rs @@ -158,11 +158,6 @@ pub trait Integer: /// The value `1`. fn one() -> Self; - /// The value `0` with the same precision as `other`. - fn zero_like(other: &Self) -> Self { - Self::from_limb_like(Limb::ZERO, other) - } - /// The value `1` with the same precision as `other`. fn one_like(other: &Self) -> Self { Self::from_limb_like(Limb::ONE, other) @@ -257,6 +252,16 @@ pub trait Zero: ConstantTimeEq + Sized { fn set_zero(&mut self) { *self = Zero::zero(); } + + /// Return the value `0` with the same precision as `other`. + fn zero_like(other: &Self) -> Self + where + Self: Clone, + { + let mut ret = other.clone(); + ret.set_zero(); + ret + } } /// Trait for associating a constant representing zero.