Immutable multiple precision integer library for AssemblyScript.
- Multiple precision integers (theoretically limited by memory)
- Fast (extensivly benchmarked)
- Accurate* (tested against JavaScript BigInt)
- For use in AssemblyScript projects
- No dependencies
While `as-mpz`` has undergone rigorous testing and benchmarking to ensure its reliability and performance, the developers would like to emphasize that the library is provided "as is," and they assume no responsibility for any issues that may arise from its use.
npm install @hypercubed/as-mpz
import { MpZ } from '@hypercubed/as-mpz';
const a = MpZ.from(18448972);
const b = MpZ.from('7881297289452930');
const c = MpZ.from('0x583F99D51C76AB3DEAB75');
const c = a.add(b).mul(c);
Or using operators:
import { MpZ } from '@hypercubed/as-mpz';
const a = MpZ.from(18448972);
const b = MpZ.from('7881297289452930');
const c = MpZ.from('0x583F99D51C76AB3DEAB75');
const c = (a + b) * c;
Note: Arithmatic methods and operators can be used interchangably, with operators acting as shorthand for the methods. However, unlike instance methods, the operators do not coerce inputs to an MpZ.
Value is stored as a sign and magnitude.
Note: Arithmatic methods and operators can be used interchangably, with operators acting as shorthand for the methods. However, unlike instance methods, the operators do not coerce inputs to an MpZ.
Creates a new MpZ from a number or string. The MpZ.from
method accepts a number or string. The string can be in decimal or hexadecimal format (prefixed with 0x
). The string can also be prefixed with -
to indicate a negative number.
Note: The MpZ class should not be instantiated directly (using
new
). Instead use the staticMpZ.from
method to create a new MpZ.
Returns true
if this
MpZ is negative, otherwise false
.
Returns the absolute value of this
MpZ.
Returns the sign of this
MpZ, indicating whether x is positive (1
), negative (-1
), or zero (0
).
Returns true
if this
MpZ is odd, otherwise false
.
Returns true
if this
MpZ is even, otherwise false
.
Returns the negation of this
MpZ (-this
).
Returns the sum of this
MpZ and rhs
.
Returns the increment of this
MpZ (this + 1
).
Returns the difference of this
MpZ and the rhs
.
Returns the decrement of this
MpZ (this - 1
).
Returns the product of this
MpZ and the rhs
(this * rhs
).
Returns the product of this
MpZ multiplied and 2**rhs
(this * 2 ** rhs
).
Returns the quotient of this
MpZ divided by the rhs
(trunc(this / rhs)
) truncated towards zero.
Throws RangeError if rhs
is zero.
Returns the quotant of this
MpZand 2**rhs
(this / 2 ** rhs
) truncated towards zero.
Returns the modulus of this
MpZ divided by the rhs
.
Throws RangeError if rhs
is zero.
Note: The
#mod
method is not the same as the%
operator. The%
operator returns the#rem
of the division of the lhs and rhs, while the#mod
method returns the modulo of the lhs and rhs.
Returns the remainder of this
MpZ divided by the rhs
(this % rhs
).
Throws RangeError if rhs
is zero.
Note: The
#rem
method is the same as the%
operator. The%
operator returns the#rem
of the division of the lhs and rhs, while the#mod
method returns the modulo of the lhs and rhs.
Returns the value of this
MpZ raised to the power of rhs
(this ** rhs
).
Throws RangeError if rhs
is negative.
Returns the value of this
MpZ raised to the power of rhs
mod m
(this ** rhs mod m
).
Throws RangeError if m
is <= 0.
Throws RangeError if rhs
is negative.
Returns the greatest integer less than or equal to the square root of this
.
Throws RangeError if this
is negative.
Returns the greatest integer less than or equal to the nth root of this
.
Throws RangeError if n
is zero or this
is negative and n
is even.
Returns the base 2 logarithm of this
.
Throws RangeError if this
is negative or zero.
Returns the base 10 logarithm of this
.
Throws RangeError if this
is negative or zero.
Returns the factorial of this
MpZ (this!
).
Throws RangeError if this
is negative or too large (greater than MAX_INTEGER
).
Returns the greatest common divisor of this
MpZ and rhs
.
Returns the least common multiple of this
MpZ and rhs
.
Returns the value of this
MpZ left shifted by rhs
(this << rhs
). Negative rhs
values shift right.
Throws RangeError if the result exceeds the maximum MpZ size.
Note: The
#shiftLeft
method return the result of the bitwise shift as if the MpZ was a 2's complement signed integer; matching JavaScript's BigInt<<
operator.
Returns the value of this
MpZ right shifted by rhs
(this >> rhs
). Negative rhs
values shift left.
Throws RangeError if the result exceeds the maximum MpZ size.
Note: The
#shiftLeft
method return the result of the bitwise shift as if the MpZ was a 2's complement signed integer; matching JavaScript's BigInt>>
operator.
Returns the bitwise NOT of this
MpZ (~this
).
Note: The
#not
method returns the result as if the MpZ was a 2's complement signed integer (yeilding-(x + 1)
); matching JavaScript's BigInt~
operator.
Returns the bitwise AND of this
MpZ and rhs
.
Note: The
#and
method returns the result of the bitwiseAND
as if the MpZ was a 2's complement signed integer; matching JavaScript's&
BigInt operator.
Returns the bitwise OR of this
MpZ and rhs
.
Note: The
#or
method returns the result of the bitwiseOR
as if the MpZ was a 2's complement signed integer; matching JavaScript's BigInt|
operator.
Returns the bitwise XOR of this
MpZ and rhs
.
Note: The #xor
method returns the result of the bitwise XOR
as if the MpZ was a 2's complement signed integer; matching JavaScript's BigInt ^
operator.
Returns the value of this
MpZ as a string. The radix can be from 2 and 36 (inclusive). The default radix is 10. Negative numbers are prefixed with a -
. Negitive radix values return the result in uppercase.
Throws Error if the radix is not between 2 and 36.
Note: The resulting string is not prefixed with the radix (e.g. 0x
or 0b
) and therefore not compatible as input to MpZ.from
(radix of 10 excluded).
Returns the value of this
MpZ as a hexadecimal string.
Note: The resulting string is prefixed with
0x
and is therefore compatible as input toMpZ.from
.
Returns the value of this
MpZ as a decimal string.
Returns the value of this
MpZ as a number
.
Returns the value of this
MpZ as a string in exponential notation.
If this
MpZ has more digits than requested, the number is rounded to the nearest number represented by n
digits.
Returns the value of this
MpZ as an unsigned 32-bit integer array. Ther sign of the MpZ is ignored.
Returns the value of this
MpZ as an unsigned 32-bit integer. If this
MpZ is too big to fit in an int32, only the low-order 32 bits are returned.
If this
MpZ is negative, the returned value is the 2's complement representation of the MpZ.
Returns the value of this
MpZ as a signed 32-bit integer. If this
MpZ is too big to fit in an int32, only the low-order 32 bits are returned.
Returns the value of this
MpZ as an unsigned 64-bit integer. If this
MpZ is too big to fit in an int64, only the low-order 64 bits are returned.
Returns the value as a signed 64-bit integer. If this
MpZ is too big to fit in an int64, only the low-order 64 bits are returned.
Returns true
if this
MpZ is equal to zero.
Returns -1
if this
MpZ is less than the rhs, 0
if this
MpZ is equal to the rhs, or 1
if this
MpZ is greater than the rhs.
Returns true
if this
MpZ is equal to the rhs.
Returns true
if this
MpZ is not equal to the rhs.
Returns true
if this
MpZ is greater than the rhs.
Returns true
if this
MpZ is greater than or equal to the rhs.
Returns true
if this
MpZ is less than the rhs.
Returns true
if this
MpZ is less than or equal to the rhs.
The following static values are provided for convenience:
MpZ.ZERO
- The MpZ value0
.MpZ.ONE
- The MpZ value1
.MpZ.TWO
- The MpZ value2
.MpZ.TEN
- The MpZ value10
.
Returns the negation of this
MpZ (-this
).
Same as the #add
, #sub
, #mul
, #div
methods.
Same as the #eq
, #gt
, #ge
, #lt
, #le
, #ne
methods.
Returns the remainder of the lhs and rhs (lhs % rhs
).
Throws RangeError if rhs
is zero.
Note: The
%
operator is not the same as the#mod
method. The%
operator returns the#rem
of the division of the lhs and rhs; matching JavaScript's BigInt%
operator.
Returns the power of the lhs to the rhs (lhs ** rhs
).
Returns the result of the left/right shift of the lhs by the rhs. Negitive rhs values will result in a opposite shift. Throws RangeError if the result exceeds the maximum MpZ size.
Shift operators behave as if they were represented in two's-complement notation; like JavaScripts's
<<
and>>
operators.
Returns the bitwise NOT of this
MpZ (~this
).
Returns the bitwise AND
, OR
, XOR
operation on the two operands.
This operator returns the result of the bitwise
AND
,OR
,XOR
as if the values were 2's complement signed integers; matching JavaScript's BigInt&
,|
,^
operators.
Returns the logical NOT of this
MpZ (!this
). This is equivalent to #eqz()
.
Returns a BigInt value truncated to the given number of least significant bits and returns that value as a signed integer. If the leading bit of the remaining number is 1, the result is negative.
Returns a BigInt value truncated to the given number of least significant bits and returns that value as an unsigned integer. Results are always non-negative and two's complement in binary.
Returns a random MpZ value with the specified maximum number of bits.
Throws RangeError if bits
exceeds the maximum MpZ size.
Licensed under MIT. MIT License
Copyright (c) 2024 Jayson Harshbarger
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.