operator * method
Multiply an Edwards curve point by a scalar.
This method multiplies an Edwards curve point by a scalar value using an efficient multiplication algorithm. The scalar value is provided as a BigInt, and the result is returned as a new Edwards curve point.
Parameters:
other
: The scalar value to multiply the point by.
Returns:
- A new Edwards curve point resulting from the multiplication.
Implementation
@override
EDPoint operator *(BigInt other) {
BigInt x2 = _coords[0];
BigInt t2 = _coords[3];
BigInt y2 = _coords[1];
BigInt z2 = _coords[2];
if (x2 == BigInt.zero || t2 == BigInt.zero || other == BigInt.zero) {
return EDPoint.infinity(curve: curve);
}
if (order != null) {
other %= (order! * BigInt.two);
}
_maybePrecompute();
if (_precompute.isNotEmpty) {
return _mulPrecompute(other);
}
BigInt x3 = BigInt.zero;
BigInt y3 = BigInt.one;
BigInt z3 = BigInt.one;
BigInt t3 = BigInt.one;
final nf = BigintUtils.computeNAF(other).reversed.toList();
for (BigInt i in nf) {
List<BigInt> resultCoords = _double(x3, y3, z3, t3, curve.p, curve.a);
x3 = resultCoords[0];
y3 = resultCoords[1];
z3 = resultCoords[2];
t3 = resultCoords[3];
if (i < BigInt.zero) {
List<BigInt> doubleCoords =
_add(x3, y3, z3, t3, -x2, y2, z2, -t2, curve.p, curve.a);
x3 = doubleCoords[0];
y3 = doubleCoords[1];
z3 = doubleCoords[2];
t3 = doubleCoords[3];
} else if (i > BigInt.zero) {
List<BigInt> doubleCoords =
_add(x3, y3, z3, t3, x2, y2, z2, t2, curve.p, curve.a);
x3 = doubleCoords[0];
y3 = doubleCoords[1];
z3 = doubleCoords[2];
t3 = doubleCoords[3];
}
}
if (x3 == BigInt.zero || t3 == BigInt.zero) {
return EDPoint.infinity(curve: curve);
}
return EDPoint._(curve, [x3, y3, z3, t3], order: order);
}