Safe Haskell | Trustworthy |
---|---|
Language | Haskell2010 |
Computation with high-precision floats.
Synopsis
- data BigFloat
- bfPosZero :: BigFloat
- bfNegZero :: BigFloat
- bfPosInf :: BigFloat
- bfNegInf :: BigFloat
- bfNaN :: BigFloat
- bfFromWord :: Word64 -> BigFloat
- bfFromInt :: Int64 -> BigFloat
- bfFromDouble :: Double -> BigFloat
- bfFromInteger :: Integer -> BigFloat
- bfFromString :: Int -> BFOpts -> String -> (BigFloat, Status)
- bfToDouble :: RoundMode -> BigFloat -> (Double, Status)
- bfToString :: Int -> ShowFmt -> BigFloat -> String
- bfToRep :: BigFloat -> BFRep
- data BFRep
- data BFNum
- bfFromBits :: BFOpts -> Integer -> BigFloat
- bfToBits :: BFOpts -> BigFloat -> Integer
- bfIsFinite :: BigFloat -> Bool
- bfIsInf :: BigFloat -> Bool
- bfIsZero :: BigFloat -> Bool
- bfIsNaN :: BigFloat -> Bool
- bfIsNormal :: BFOpts -> BigFloat -> Bool
- bfIsSubnormal :: BFOpts -> BigFloat -> Bool
- bfCompare :: BigFloat -> BigFloat -> Ordering
- bfSign :: BigFloat -> Maybe Sign
- bfExponent :: BigFloat -> Maybe Int64
- bfIsPos :: BigFloat -> Bool
- bfIsNeg :: BigFloat -> Bool
- data Sign
- bfNeg :: BigFloat -> BigFloat
- bfAbs :: BigFloat -> BigFloat
- bfAdd :: BFOpts -> BigFloat -> BigFloat -> (BigFloat, Status)
- bfSub :: BFOpts -> BigFloat -> BigFloat -> (BigFloat, Status)
- bfMul :: BFOpts -> BigFloat -> BigFloat -> (BigFloat, Status)
- bfDiv :: BFOpts -> BigFloat -> BigFloat -> (BigFloat, Status)
- bfRem :: BFOpts -> BigFloat -> BigFloat -> (BigFloat, Status)
- bfFMA :: BFOpts -> BigFloat -> BigFloat -> BigFloat -> (BigFloat, Status)
- bfMulWord :: BFOpts -> BigFloat -> Word64 -> (BigFloat, Status)
- bfMulInt :: BFOpts -> BigFloat -> Int64 -> (BigFloat, Status)
- bfMul2Exp :: BFOpts -> BigFloat -> Int -> (BigFloat, Status)
- bfSqrt :: BFOpts -> BigFloat -> (BigFloat, Status)
- bfPow :: BFOpts -> BigFloat -> BigFloat -> (BigFloat, Status)
- bfRoundFloat :: BFOpts -> BigFloat -> (BigFloat, Status)
- bfRoundInt :: RoundMode -> BigFloat -> (BigFloat, Status)
- bfUnsafeThaw :: BigFloat -> BF
- bfUnsafeFreeze :: BF -> BigFloat
- module LibBF.Opts
Constants
Arbitrary precision floating point numbers.
Instances
Data BigFloat Source # | |
Defined in LibBF gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> BigFloat -> c BigFloat # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c BigFloat # toConstr :: BigFloat -> Constr # dataTypeOf :: BigFloat -> DataType # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c BigFloat) # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c BigFloat) # gmapT :: (forall b. Data b => b -> b) -> BigFloat -> BigFloat # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> BigFloat -> r # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> BigFloat -> r # gmapQ :: (forall d. Data d => d -> u) -> BigFloat -> [u] # gmapQi :: Int -> (forall d. Data d => d -> u) -> BigFloat -> u # gmapM :: Monad m => (forall d. Data d => d -> m d) -> BigFloat -> m BigFloat # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> BigFloat -> m BigFloat # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> BigFloat -> m BigFloat # | |
Show BigFloat Source # | |
NFData BigFloat Source # | |
Eq BigFloat Source # | IEEE 754 equality |
Ord BigFloat Source # | IEEE 754 comparisons |
Hashable BigFloat Source # | |
Conversions
bfFromWord :: Word64 -> BigFloat Source #
A floating point number corresponding to the given word.
bfFromDouble :: Double -> BigFloat Source #
A floating point number corresponding to the given double.
bfFromInteger :: Integer -> BigFloat Source #
A floating point number corresponding to the given integer.
Parse a number from the given string. Returns @NaN` if the string does not correspond to a number we recognize.
Render as a String
, using the given settings.
An explicit representation for big nums.
Instances
Data BFRep Source # | |
Defined in LibBF.Mutable gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> BFRep -> c BFRep # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c BFRep # dataTypeOf :: BFRep -> DataType # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c BFRep) # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c BFRep) # gmapT :: (forall b. Data b => b -> b) -> BFRep -> BFRep # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> BFRep -> r # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> BFRep -> r # gmapQ :: (forall d. Data d => d -> u) -> BFRep -> [u] # gmapQi :: Int -> (forall d. Data d => d -> u) -> BFRep -> u # gmapM :: Monad m => (forall d. Data d => d -> m d) -> BFRep -> m BFRep # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> BFRep -> m BFRep # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> BFRep -> m BFRep # | |
Show BFRep Source # | |
Eq BFRep Source # | |
Ord BFRep Source # | |
Hashable BFRep Source # | |
Defined in LibBF.Mutable |
Representations for unsigned floating point numbers.
Instances
Data BFNum Source # | |
Defined in LibBF.Mutable gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> BFNum -> c BFNum # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c BFNum # dataTypeOf :: BFNum -> DataType # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c BFNum) # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c BFNum) # gmapT :: (forall b. Data b => b -> b) -> BFNum -> BFNum # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> BFNum -> r # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> BFNum -> r # gmapQ :: (forall d. Data d => d -> u) -> BFNum -> [u] # gmapQi :: Int -> (forall d. Data d => d -> u) -> BFNum -> u # gmapM :: Monad m => (forall d. Data d => d -> m d) -> BFNum -> m BFNum # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> BFNum -> m BFNum # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> BFNum -> m BFNum # | |
Show BFNum Source # | |
Eq BFNum Source # | |
Ord BFNum Source # | |
Hashable BFNum Source # | |
Defined in LibBF.Mutable |
Make a float using "raw" bits representing the bitvector representation of a floating-point value with the exponent and precision bits given by the options.
bfToBits :: BFOpts -> BigFloat -> Integer Source #
Turn a float into raw bits.
NaN
is represented as a positive "quiet" NaN
(most significant bit in the significand is set, the rest of it is 0).
Predicates
bfIsFinite :: BigFloat -> Bool Source #
Is this a finite (i.e., non-infinite, non NaN) number.
bfIsNormal :: BFOpts -> BigFloat -> Bool Source #
This is a "normal" number, which means it is not a NaN, not a zero, not infinite, and not subnormal.
bfIsSubnormal :: BFOpts -> BigFloat -> Bool Source #
This number is "subnormal", which means it is among the smallest representable numbers for the given precision and exponent bits. These numbers differ from "normal" numbers in that they do not use an implicit leading 1 bit in the binary representation.
bfCompare :: BigFloat -> BigFloat -> Ordering Source #
Compare the two numbers. The special values are ordered like this:
- -0 < 0
- NaN == NaN
- NaN is larger than all other numbers
Note that this differs from (<=)
bfSign :: BigFloat -> Maybe Sign Source #
Get the sign of a number. Returns Nothing
if the number is NaN
.
bfExponent :: BigFloat -> Maybe Int64 Source #
Get the exponent for the given number. Infinity, zero and NaN do not have an exponent.
Indicates if a number is positive or negative.
Instances
Data Sign Source # | |
Defined in LibBF.Mutable gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Sign -> c Sign # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Sign # dataTypeOf :: Sign -> DataType # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Sign) # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Sign) # gmapT :: (forall b. Data b => b -> b) -> Sign -> Sign # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Sign -> r # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Sign -> r # gmapQ :: (forall d. Data d => d -> u) -> Sign -> [u] # gmapQi :: Int -> (forall d. Data d => d -> u) -> Sign -> u # gmapM :: Monad m => (forall d. Data d => d -> m d) -> Sign -> m Sign # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Sign -> m Sign # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Sign -> m Sign # | |
Show Sign Source # | |
Eq Sign Source # | |
Ord Sign Source # | |
Arithmetic
bfAdd :: BFOpts -> BigFloat -> BigFloat -> (BigFloat, Status) Source #
Add two numbers useing the given options.
bfSub :: BFOpts -> BigFloat -> BigFloat -> (BigFloat, Status) Source #
Subtract two numbers useing the given options.
bfMul :: BFOpts -> BigFloat -> BigFloat -> (BigFloat, Status) Source #
Multiply two numbers using the given options.
bfDiv :: BFOpts -> BigFloat -> BigFloat -> (BigFloat, Status) Source #
Divide two numbers useing the given options.
bfRem :: BFOpts -> BigFloat -> BigFloat -> (BigFloat, Status) Source #
Compute the remainder x - y * n
where n
is the integer
nearest to x/y
(with ties broken to even values of n
).
bfFMA :: BFOpts -> BigFloat -> BigFloat -> BigFloat -> (BigFloat, Status) Source #
Compute the fused-multiply-add (x*y)+z
bfMulWord :: BFOpts -> BigFloat -> Word64 -> (BigFloat, Status) Source #
Multiply a number and a word, using the given options.
bfMulInt :: BFOpts -> BigFloat -> Int64 -> (BigFloat, Status) Source #
Multiply a number and an int, using the given options.
bfSqrt :: BFOpts -> BigFloat -> (BigFloat, Status) Source #
Square root of two numbers useing the given options.
bfPow :: BFOpts -> BigFloat -> BigFloat -> (BigFloat, Status) Source #
Exponentiate a word to a positive integer power.
Rounding
bfRoundFloat :: BFOpts -> BigFloat -> (BigFloat, Status) Source #
Round to a float matching the input parameters.
bfRoundInt :: RoundMode -> BigFloat -> (BigFloat, Status) Source #
Round to an integer using the given rounding mode.
Mutability
bfUnsafeThaw :: BigFloat -> BF Source #
Make a number mutable. WARNING: This does not copy the number, so it could break referential transperancy.
bfUnsafeFreeze :: BF -> BigFloat Source #
Make a number immutable. WARNING: This does not copy the number, so it could break referential transperancy.
Limits
Configuration
module LibBF.Opts