Add scalar multiplication to BigInt
This commit is contained in:
parent
79448cbdf9
commit
8b1288ea01
bigint/src
|
@ -485,6 +485,8 @@ impl<'a, 'b> Mul<&'b BigInt> for &'a BigInt {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
forward_all_scalar_binop_to_val_val_commutative!(impl Mul<BigDigit> for BigInt, mul);
|
||||||
|
|
||||||
impl Mul<BigDigit> for BigInt {
|
impl Mul<BigDigit> for BigInt {
|
||||||
type Output = BigInt;
|
type Output = BigInt;
|
||||||
|
|
||||||
|
|
|
@ -483,10 +483,14 @@ impl Mul<BigDigit> for BigUint {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
fn mul(mut self, other: BigDigit) -> BigUint {
|
fn mul(mut self, other: BigDigit) -> BigUint {
|
||||||
|
if other == 0 {
|
||||||
|
self.data.clear();
|
||||||
|
} else {
|
||||||
let carry = scalar_mul(&mut self.data[..], other);
|
let carry = scalar_mul(&mut self.data[..], other);
|
||||||
if carry != 0 {
|
if carry != 0 {
|
||||||
self.data.push(carry);
|
self.data.push(carry);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -703,23 +703,25 @@ fn test_mul() {
|
||||||
fn test_scalar_mul() {
|
fn test_scalar_mul() {
|
||||||
for elm in MUL_TRIPLES.iter() {
|
for elm in MUL_TRIPLES.iter() {
|
||||||
let (a_vec, b_vec, c_vec) = *elm;
|
let (a_vec, b_vec, c_vec) = *elm;
|
||||||
|
let a = BigInt::from_slice(Plus, a_vec);
|
||||||
|
let b = BigInt::from_slice(Plus, b_vec);
|
||||||
let c = BigInt::from_slice(Plus, c_vec);
|
let c = BigInt::from_slice(Plus, c_vec);
|
||||||
let nc = BigInt::from_slice(Minus, c_vec);
|
let (na, nb, nc) = (-&a, -&b, -&c);
|
||||||
|
|
||||||
if a_vec.len() == 1 {
|
if a_vec.len() == 1 {
|
||||||
let b = BigInt::from_slice(Plus, b_vec);
|
|
||||||
let nb = BigInt::from_slice(Minus, b_vec);
|
|
||||||
let a = a_vec[0];
|
let a = a_vec[0];
|
||||||
assert!(b * a == c);
|
assert_op!(b * a == c);
|
||||||
assert!(nb * a == nc);
|
assert_op!(a * b == c);
|
||||||
|
assert_op!(nb * a == nc);
|
||||||
|
assert_op!(a * nb == nc);
|
||||||
}
|
}
|
||||||
|
|
||||||
if b_vec.len() == 1 {
|
if b_vec.len() == 1 {
|
||||||
let a = BigInt::from_slice(Plus, a_vec);
|
|
||||||
let na = BigInt::from_slice(Minus, a_vec);
|
|
||||||
let b = b_vec[0];
|
let b = b_vec[0];
|
||||||
assert!(a * b == c);
|
assert_op!(a * b == c);
|
||||||
assert!(na * b == nc);
|
assert_op!(b * a == c);
|
||||||
|
assert_op!(na * b == nc);
|
||||||
|
assert_op!(b * na == nc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue