You're Invited:Meet the Socket Team at RSAC and BSidesSF 2026, March 23–26.RSVP
Socket
Book a DemoSign in
Socket

bigdecimal.js

Package Overview
Dependencies
Maintainers
1
Versions
20
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

bigdecimal.js

A BigDecimal implementation with native BigInts

latest
Source
npmnpm
Version
1.3.1
Version published
Weekly downloads
2.4K
27.5%
Maintainers
1
Weekly downloads
 
Created
Source

BigDecimal.js

NPM Version NPM Downloads codecov

BigInt based BigDecimal implementation for Node.js 10.4 and above. This implementation is inspired from java BigDecimal class. This implementation is faster than popular big decimal libraries for most operations. See benchmarks results part below for comparison of each operation.

Advantages of this library

  • Faster than other BigDecimal libraries because of native BigInt
  • Simple API that is almost same with Java's BigDecimal
  • No dependencies
  • Well tested
  • Includes type definition file

Disadvantages

  • This library's minified version is about 5 times larger than big.js's minified version. So the library is not small.

Installation

npm install bigdecimal.js

Usage

  • The example usage is given below:
// Single unified constructor for multiple values
const { Big } = require('bigdecimal.js');

// Construct from a string and clone 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');

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

const res2 = x.divideWithMathContext(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

For now, benchmarked against big.js and bigdecimal.

  • Test Machine:

    • M1 2021 MacBook Air
    • 16 GB Ram
    • MacOS Sonoma 14.2.1
  • Update Date: January 28th 2024

  • Library versions used:

    • big.js 6.2.1
    • (this library) bigdecimal.js 1.3.1
    • bigdecimal 0.6.1
    • bignumber.js: 9.1.2
    • decimal.js:10.4.3
  • Each operation is run with fixed set of decimal numbers composed of both simple and complex numbers.

  • Micro benchmark framework used is benchmark. Check out benchmarks folder for source code of benchmarks.

  • For now, benchmarked the following operations, more operations will be added later.

  • Operations per second(op/s):

OperationBigdecimal.jsBig.jsBigNumber.jsdecimal.jsGWTBased
Constructor43,962 ( - )38,238 (-13%)42,337 (-4%)42,355 (-4%)2,818 (-94%)
Add80,569 ( - )18,406 (-77%)100,734 (+25%)59,815 (-26%)90 (-100%)
Subtract73,518 ( - )18,265 (-75%)96,022 (+31%)57,130 (-22%)89 (-100%)
Multiply493,291 ( - )33,422 (-93%)26,810 (-95%)79,995 (-84%)2,609 (-99%)
Divide15,341 ( - )1,129 (-93%)11,721 (-24%)13,301 (-13%)645 (-96%)
Remainder9,362 ( - )3,816 (-59%)13,470 (+44%)21,952 (+134%)2,445 (-74%)
Positive pow27,403 ( - )25 (-100%)113 (-100%)3,535 (-87%)6 (-100%)
Negative pow4,863 ( - )21 (-100%)109 (-98%)1,970 (-59%)264 (-95%)
Abs782,251 ( - )1,424,376 (+82%)917,526 (+17%)358,678 (-54%)14,132 (-98%)
Compare546,243 ( - )1,216,388 (+123%)783,432 (+43%)417,873 (-24%)990,187 (+81%)

Keywords

bigdecimal

FAQs

Package last updated on 28 Jan 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts