Options
All
  • Public
  • Public/Protected
  • All
Menu

bigdecimal.js

BigDecimal.js

NPM Version NPM Downloads

BigInt based BigDecimal(arbitrary precision floats) implementation for Node.js. This implementation is based on java BigDecimal class. Like java BigDecimal class, it uses big integers internally. This implementation is faster than popular big decimal libraries. See benchmarks results part below for comparison.

Note: The library is currently in preview, v1.0.0 will be released soon. API can change in the near future. I appreciate your feedback, thanks.

Features

  • Faster than other BigDecimal libraries because of native BigInt(for now, benchmarked against big.js and bigdecimal )
  • Simple API that is almost same with Java's BigDecimal
  • No dependencies

Installation

npm install bigdecimal.js

Usage

  • The example usage is given below:
const { Big } = require('bigdecimal.js');

// Single constructor for all values
// Construct from a string and copy it

const x = Big('1.1111111111111111111111');
const y = new Big(x); // you can also use 'new'

const z = x.add(y);
console.log(z.toString()); // 2.2222222222222222222222

// You can also construct from a number or BigInt:

const u = Big(1.1);
const v = Big(2n);

console.log(u.toString()); // 1.1
console.log(v.toString()); // 2

You can use MathContext to set precision and rounding mode for a specific operation:

const { Big, MC, RoundingMode } = require('bigdecimal.js');

const x = Big('1');
const y = Big('3');

const res1 = x.divide(y, MC(3)); // MC is MathContext constructor that can be used without `new`
console.log(res1.toString()); // 0.333

const res2 = x.divide(y, new MC(3, RoundingMode.UP));
console.log(res2.toString()); // 0.334

try {
    x.divide(y);
    // throws since full precision is requested but it is not possible
} catch (e) {
    console.log(e); // RangeError: Non-terminating decimal expansion; no exact representable decimal result.
}

Documentation

Testing

  • Install dependencies: npm i
  • Compile: npm run compile
  • Run tests: npm test

Running Benchmarks

There is a benchmark suite that compares

To run the benchmark run npm install and then npm run benchmark.

Benchmark Results

  • Test Machine:
    • AMD Ryzen 5 3600
    • 16 GB 3600 Mhz Ram
    • Ubuntu 20.04
  • Update Date: 01 August 2021
  • Each operation is run with fixed numbers that is a mix of small and big decimal numbers.
  • Micro benchmark framework: benchmark.js. Check out benchmarks folder for source code of benchmarks.
  • Operations per second(op/s):
Operation Bigdecimal.js Big.js GWT Winner
Add 47,477 12,340 55.58 BigDecimal.js
Multiply 362,610 362,610 1,404 BigDecimal.js
Subtract 43,147 11,678 54.10 BigDecimal.js
Divide 9,536 1,053 341 BigDecimal.js
Abs 506,144 937,951 7,992 Big.js
Compare 401,047 935,592 632,812 Big.js
Remainder 5,511 4,275 1,316 BigDecimal.js

Generated using TypeDoc