break_infinity.js icon indicating copy to clipboard operation
break_infinity.js copied to clipboard

A replacement for decimal.js for incremental games who want to deal with very large numbers (bigger in magnitude than 1e308, up to as much as 1e(9e15) ) and want to prioritize speed over accuracy.

NPM

A replacement for https://github.com/MikeMcl/decimal.js/ for incremental games which need to deal with very large numbers (bigger in magnitude than 1e308, up to as much as 1e9e15) and want to prioritize speed over accuracy.

If you want to prioritize accuracy over speed, please use decimal.js instead.

NEW:

  • https://github.com/Razenpok/BreakInfinity.cs - C# port, for your C#/Unity incremental games
  • https://github.com/Patashu/break_eternity.js - the sequel to break_infinity.js that goes to 10^^3, 10^^4, 10^^5 and far beyond

Load

The library is a single JavaScript file break_infinity.js (or minified, break_infinity.min.js) which can be found on https://github.com/Patashu/break_infinity.js/releases page.

It can be loaded using a script tag in an HTML document for the browser

    <!-- You can load it as a local file... -->
    <script src="path/to/break_infinity.js"></script>

    <!-- ...or from CDN -->
    <script src="https://cdn.jsdelivr.net/npm/break_infinity.js"></script>

or as a JS module using import

    import Decimal from "break_infinity.js";

or as a Node.js module using require.

    var Decimal = require("break_infinity.js");

For the module approaches, the library is available from the npm registry

    $ npm install --save break_infinity.js

If you are already using decimal.js, just swap out for break_infinity.js and everything will work the same (if there's a missing function or behavioural difference, open an issue and I'll take a look).

Use

The library exports a single class Decimal, constructor of which accepts a Number, String or Decimal.

    const x = new Decimal(123.4567);
    const y = new Decimal("123456.7e-3");
    const z = new Decimal(x);
    const equals = x.equals(y) && y.equals(z) && x.equals(z); // true

The methods that return a Decimal can be chained.

    const short = x.dividedBy(y).plus(z).times(9).floor();
    const long = x.times("1.23456780123456789e+9")
      .plus(9876.5432321)
      .dividedBy("4444562598.111772")
      .ceil();

For the complete list of functions refer to Typescript definitions, decimal.js docs or check out generated API docs

Benchmarks

So how much faster than decimal.js is break_infinity.js? Operations per second comparison using the same computer with these benchmarks link link:

Project decimal.js break_infinity.js Speedup
new Decimal("1.23456789e987654321") 1.6e6 4.5e6 2.8x
Decimal.add("1e999", "9e998") 1.3e6 3.2e6 2.5x
Decimal.mul("1e999", "9e998") 1.3e6 3.8e6 2.9x
Decimal.log10("987.654e789") 3.9e4 4.7e6 121x
Decimal.exp(1e10) 1.1e4 4.3e6 401x
Decimal.pow(987.789, 123.321) 1.3e4 5.8e6 442x

Antimatter Dimensions script time improved by 4.5x after swapping from decimal.js to break_infinity.js. This could be your incremental game:

image

Build

First, clone the repo

git clone git://github.com/Patashu/break_infinity.js.git
cd break_infinity.js

Then install npm dependencies

npm install

And then run build command which will build all targets to the dist directory.

npm run build

Acknowledgements

Dedicated to Hevipelle, and all the CPUs that struggled to run Antimatter Dimensions.

Related song: https://soundcloud.com/patashu/8-bit-progressive-stoic-platonic-ideal

Special thanks to projects from which I have sourced code or ideas from:

  • https://github.com/MikeMcl/decimal.js
  • https://github.com/Yaffle/BigInteger
  • https://bitbucket.org/heldercorreia/speedcrunchand

Additional thanks to https://github.com/Razenpok for porting the code to TypeScript and cleaning up this README.

Other Number Libraries

  • https://github.com/munrocket/double.js double.js, a wasm/typescript implementation of 128-bit floating point with a focus on performance and accuracy
  • https://github.com/aarextiaokhiao/magna_numerus.js/blob/master/logarithmica_numerus_lite.js logarithmica_numerus_lite.js, an alternate take on break_infinity.js where there's just one field, exponent. Roughly 2x faster but can't represent negative numbers
  • https://github.com/Razenpok/BreakInfinity.cs/blob/master/BreakInfinity.Benchmarks/Quadruple/Quad.cs Quad.cs, a C# implementation of 128-bit floating point with a focus on performance and accuracy
  • https://naruyoko.github.io/ExpantaNum.js/index.html https://github.com/Naruyoko/OmegaNum.js ExpantaNum.js and OmegaNum.js, numerical libraries that have low performance but can represent insanely large googological numbers like {10,9e15,1,2} and 10{1000}9e15