JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 1086
  • Score
    100M100P100Q102277F
  • License MIT

Arbitrary-precision decimals. Enables making math calculations with rational numbers, without precision loss.

Package Exports

  • exactnumber
  • exactnumber/dist/index.esm.js
  • exactnumber/dist/index.umd.js

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (exactnumber) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

ExactNumber

npm package codecov Build status JSDelivr downloads

Arbitrary-precision decimals. Enables making math calculations with rational numbers, without precision loss.

Features

  • Works with arbitrary large numbers without precision loss
  • All fractions can be represented as repeating decimals like 1.23(45)
  • This repeating decimal format (1.23(45)) can also be parsed back
  • Works with all number bases between 2 and 16
  • No special values like NaN, Infinity or -0.
  • No silent errors: it throws errors immediatelly when a confusing parameter is received (e.g. 0/0)
  • Supports bitwise operators (and, or, xor, shiftLeft, shiftRight)
  • Supports all modern browsers, web workers, Node.js and Deno
  • Includes TypeScript type definitions: documentation
  • Zero external dependencies
  • Under the hood, it relies on the BigInt type. It automatically switches back and forth between fixed-precision and fractional representations.
  • Tries to deliver the best possible performance
  • 100% open source + MIT license

Comparision with built-in numbers

import { ExactNumber as N } from 'exactnumber';

1 + 0.36 // 1.3599999999999999
N(1).add('0.36').toString() // 1.36

(1 / 49) * 49 // 0.9999999999999999
N(1).div(49).mul(49).toString() // 1

10e16 + 5 // 100000000000000000
N('10e16').add(5).toString() // 100000000000000005

1 / 3 // 0.3333333333333333
N(1).div(3).toString() // 0.(3)

2**32 >> 32 // 0
N(2).pow(32).shiftRight(32).toString() // 1

Installation

npm i exactnumber

It can also be used directly from HTML (via jsDelivr):

<!-- loads the full, minified library into the global `exactnumber` variable -->
<script src="https://cdn.jsdelivr.net/npm/exactnumber"></script>

<!-- or loads the non-minified library -->
<script src="https://cdn.jsdelivr.net/npm/exactnumber/dist/index.umd.js"></script>

Usage

import { ExactNumber as N } from 'exactnumber';

N(1).add('3').toString(); // 4

N('1/7').add('1/10').toFraction(); // 17/70

N('1/7').toString(); // 0.(142857)
N('1/7').toString(6); // 0.(05)
N('1/7').toFixed(3); // 0.142
N('1/7').trunc(3).toString(); // 0.142
N('0.(3)').add('0.(6)').toString(); // 1

N('0b1100').bitwiseAnd('0b1010').toString(2); // 1000

N.max('1/1', '10/2', 3).toString(); // 5
N.fromBase('123', 4).toString(); // 27

Functions

  • Addition / subtraction: add(), sub()
  • Multiplication / division: mul(), div(), divToInt()
  • Exponentiation: pow()
  • Modular arithmetic: mod(), powm()
  • Getting the sign / absolute value: sign(), abs()
  • Negation / inversion: neg(), inv()
  • Integer and fractional parts: intPart(), fracPart()
  • Comparisons: cmp(), eq(), lt(), lte(), gt(), gte()
  • Special comparisons: isZero(), isOne()
  • Type testing: isInteger()
  • Rounding: round(), roundToDigits(), floor(), ceil(), trunc()
  • Bitwise operators: bitwiseAnd(), bitwiseOr(), bitwiseXor(), shiftLeft(), shiftRight()
  • Clamping: clamp()
  • Fraction helper: getFractionParts()
  • Normalization / simplifying fractions: normalize()
  • String output: toFixed(), toExponential(), toPrecision(), toString(), toFraction()
  • Number output: toNumber()
  • GCD, LCM: ExactNumber.gcd(), ExactNumber.lcm()
  • Minimum, maximum: ExactNumber.min(), ExactNumber.max()
  • Parsing numbers in different bases: ExactNumber.fromBase()
  • Range generator: ExactNumber.range()

Rounding modes

  • NEAREST_TO_POSITIVE - Rounds to nearest number, with ties rounded towards +Infinity. Similar to Math.round().

  • NEAREST_TO_NEGATIVE - Rounds to nearest number, with ties rounded towards -Infinity.

  • NEAREST_TO_EVEN - Rounds to nearest number, with ties rounded towards the nearest even number.

  • NEAREST_TO_ZERO - Rounds to nearest number, with ties rounded towards zero.

  • NEAREST_AWAY_FROM_ZERO - Rounds to nearest number, with ties rounded away from zero.

  • TO_POSITIVE - Rounds towards +Infinity. Similar to Math.ceil().

  • TO_NEGATIVE - Rounds towards -Infinity. Similar to Math.floor().

  • TO_ZERO - Rounds towards zero. Similar to Math.trunc().

  • AWAY_FROM_ZERO - Rounds away from zero

Modulo variants

  • TRUNCATED
  • FLOORED
  • EUCLIDEAN

Read more about them here.

License: MIT

Copyright © 2025 Dani Biró