scientific
Version 0.3.4.5 revision 0 uploaded by BasVanDijk.
Package meta
- Synopsis
- Numbers represented using scientific notation
- Description
Data.Scientific
provides the number type Scientific. Scientific numbers are arbitrary precision and space efficient. They are represented using scientific notation. The implementation uses a coefficientc :: Integer
and a base-10 exponente :: Int
. A scientific number corresponds to the Fractional number:fromInteger c * 10 ^^ e
.Note that since we're using an Int to represent the exponent these numbers aren't truly arbitrary precision. I intend to change the type of the exponent to Integer in a future release.
The main application of Scientific is to be used as the target of parsing arbitrary precision numbers coming from an untrusted source. The advantages over using Rational for this are that:
A Scientific is more efficient to construct. Rational numbers need to be constructed using % which has to compute the gcd of the numerator and denominator.
Scientific is safe against numbers with huge exponents. For example:
1e1000000000 :: Rational
will fill up all space and crash your program. Scientific works as expected:
> read "1e1000000000" :: Scientific 1.0e1000000000
- Author
- Bas van Dijk
- Bug reports
- https://github.com/basvandijk/scientific/issues
- Category
- Data
- Copyright
- n/a
- Homepage
- https://github.com/basvandijk/scientific
- Maintainer
- Bas van Dijk <v.dijk.bas@gmail.com>
- Package URL
- n/a
- Stability
- n/a