mathjs
Version:
Math.js is an extensive math library for JavaScript and Node.js. It features a flexible expression parser with support for symbolic computation, comes with a large set of built-in functions and constants, and offers an integrated solution to work with dif
62 lines (61 loc) • 1.92 kB
JavaScript
import { factory } from '../../../utils/factory';
import { deepMap } from '../../../utils/collection';
var name = 'bignumber';
var dependencies = ['typed', 'BigNumber'];
export var createBignumber =
/* #__PURE__ */
factory(name, dependencies, function (_ref) {
var typed = _ref.typed,
BigNumber = _ref.BigNumber;
/**
* Create a BigNumber, which can store numbers with arbitrary precision.
* When a matrix is provided, all elements will be converted to BigNumber.
*
* Syntax:
*
* math.bignumber(x)
*
* Examples:
*
* 0.1 + 0.2 // returns number 0.30000000000000004
* math.bignumber(0.1) + math.bignumber(0.2) // returns BigNumber 0.3
*
*
* 7.2e500 // returns number Infinity
* math.bignumber('7.2e500') // returns BigNumber 7.2e500
*
* See also:
*
* boolean, complex, index, matrix, string, unit
*
* @param {number | string | Fraction | BigNumber | Array | Matrix | boolean | null} [value] Value for the big number,
* 0 by default.
* @returns {BigNumber} The created bignumber
*/
var bignumber = typed('bignumber', {
'': function _() {
return new BigNumber(0);
},
number: function number(x) {
// convert to string to prevent errors in case of >15 digits
return new BigNumber(x + '');
},
string: function string(x) {
return new BigNumber(x);
},
BigNumber: function BigNumber(x) {
// we assume a BigNumber is immutable
return x;
},
Fraction: function Fraction(x) {
return new BigNumber(x.n).div(x.d).times(x.s);
},
"null": function _null(x) {
return new BigNumber(0);
},
'Array | Matrix': function ArrayMatrix(x) {
return deepMap(x, bignumber);
}
});
return bignumber;
});