BigFloat

Uses BigInt to make BigFloats

이 스크립트는 직접 설치하는 용도가 아닙니다. 다른 스크립트에서 메타 지시문 // @require https://update.greasyfork.org/scripts/563676/1740238/BigFloat.js을(를) 사용하여 포함하는 라이브러리입니다.

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램을 설치해야 합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

작성자
NotYou
버전
1.0.0
생성일
2026-01-22
갱신일
2026-01-22
크기
8.86KB
라이선스
MIT

BigFloat

Description

BigFloat library was created to avoid IEEE754 floating point numbers, meaning more accurate results and ability to work with larger (actually sometimes smaller) values. BigFloat uses esnext feature called BigInt to implement this solution.

Usage Examples

console.log(new BigFloat(0.123456789).add(0.987654321).toNumber({ precision: 9 })) // 1.11111111

console.log(new BigFloat(0.1).add(0.2).multiply(3).toNumber()) // 0.9

// vs using built-in operators

console.log(0.12345678 + 0.987654321) // 1.1111111009999999

console.log((0.1 + 0.2) * 3) // 0.9000000000000001

Instance Properties

BigFloat.prototype[Symbol.toStringTag]

The value of [Symbol.toStringTag] is "BigFloat" (which is the name of the class).

Note: BigFloat also has stringify instance method, which converts the value to the string.

Instance Methods

Note

AcceptableValue is number | (backtick)${number}(backtick) | BigInt | InstanceType<typeof BigFloat>

I wrote ` as (backtick) because markdown doesn't allow me to write template strings is readable way.

BigFloat.prototype.getRawValue

@returns {bigint}

Returns the value of the big float as a raw bigint

console.log(new BigFloat('12.34').getRawValue()) // 1234n

BigFloat.prototype.getScale

@returns {number}

Returns the scale of the value

console.log(new BigFloat('12.34').getScale()) // -2

BigFloat.prototype.stringify

@param {Optional<{

trailingZero: boolean, // default: true

headZero: boolean, // default: true

precision: number, // default: 3

fixedPointNotation: boolean // default: false

}>} options

@returns {string}

Stringifies big float

console.log(new BigFloat(12.34).stringify()) // '12.34'
console.log(new BigFloat(1).stringify()) // '1.0'
console.log(new BigFloat(1.123456789).stringify()) // '1.123' (default precision is 3)
console.log(new BigFloat(1.123456789).stringify({ precision: 9 })) // '1.123456789'
console.log(new BigFloat(1).stringify({ trailingZero: false })) // '1'
console.log(new BigFloat(0.123).stringify({ headZero: false })) // '.123'
console.log(new BigFloat(1).stringify({ precision: 5, fixedPointNotation: true })) // '1.00000'

BigFloat.prototype.toNumber

@param {Optional<{

precision: number // default: 3

}>} options

@returns {number}

Firstly stringfies the number using stringify (with default params) method, and then converts it to number

console.log(new BigFloat('12.34').toNumber()) // 12.34
console.log(new BigFloat('1.0').toNumber()) // 1
console.log(new BigFloat('1.12345689').toNumber()) // 0.123 (default precision is 3)
console.log(new BigFloat('1.12345689').toNumber({ precision: 9 })) // 1.123456789

BigFloat.prototype.add

@param {AcceptableValue} value

@returns {this}

console.log(new BigFloat('1.1').add('2.2').toNumber()) // 3.3

BigFloat.prototype.subtract

@param {AcceptableValue} value

@returns {this}

console.log(new BigFloat('1.1').subtract('2.2').toNumber()) // -1.1

BigFloat.prototype.multiply

@param {AcceptableValue} value

@returns {this}

console.log(new BigFloat('3.333').multiply('3.333').toNumber({ precision: 6 })) // 11.108889

BigFloat.prototype.divide

@param {AcceptableValue} value

@param {number} precision default is 3

@returns {this}

console.log(new BigFloat('3.333').divide('9', 10).stringify({ precision: 10 })) // 0.3703333333