@awsless/big-float
v0.0.4
Published
[![npm version](https://img.shields.io/npm/dw/@awsless/big-float)](https://www.npmjs.org/package/@awsless/big-float) [![npm version](https://img.shields.io/npm/v/@awsless/big-float.svg?style=flat-square)](https://www.npmjs.org/package/@awsless/big-float)
Downloads
86
Readme
A library for arbitrary precision decimal floating point arithmetic that can exactly represent all decimal fractions, unlike JavaScript's number data type which is 64-bit binary floating point.
We are wrapping bigfloat-esnext
behind the scenes.
Basic usage
import { BigFloat, sqrt } from "@awsless/big-float";
sqrt(new BigFloat(2)).toString() // "1.4142"
Change precision
import { sqrt, set_precision } from "@awsless/big-float";
sqrt(2).toString(); // "1.4142"
set_precision(-10);
sqrt(2).toString(); // "1.4142135623"
The bigfloat interface
interface IBigFloat {
coefficient: bigint;
exponent: number;
}
Available API
import { BigFloat, set_precision } from "@awsless/big-float";
// arithmetic
import { neg, abs, add, sub, mul, div, sqrt, pow, ceil, floor, factor } from '@awsless/big-float'
// retational
export { eq, lt, lte, gt, gte, min, max } from '@awsless/big-float'
// constants
export { ZERO, ONE, TWO, THREE, FOUR, FIVE, SIX, SEVEN, EIGHT, NINE, TEN, HUNDRED, THOUSAND, MILLION, BILLION, TRILLION } from '@awsless/big-float'