shithub: MicroHs

ref: 60e96185f08ab8f36698c16c41633bc3a4295b77
dir: /lib/Data/Double.hs/

View raw version
module Data.Double(Double) where
import Prelude()
import Primitives
import Data.Bool
import Data.Eq
import Data.FloatW
import Data.Floating
import Data.Fractional
import Data.Function
import Data.List
import Data.Num
import Data.Ord
import Data.Real
import Data.RealFloat
import Data.RealFrac
import Text.Read
import Text.Show

-- XXX I should really implement newtype deriving...

newtype Double = D FloatW
unD :: Double -> FloatW
unD (D x) = x

un :: (FloatW -> FloatW) -> (Double -> Double)
un f x = D (f (unD x))

bin :: (FloatW -> FloatW -> FloatW) -> (Double -> Double -> Double)
bin f x y = D (f (unD x) (unD y))

cmp :: (FloatW -> FloatW -> Bool) -> (Double -> Double -> Bool)
cmp f x y = f (unD x) (unD y)

instance Num Double where
  (+) = bin (+)
  (-) = bin (-)
  (*) = bin (*)
  negate = un negate
  abs = un abs
  signum = un signum
  fromInteger = D . fromInteger

instance Fractional Double where
  (/) = bin (/)
  fromRational = D . fromRational

instance Eq Double where
  (==) = cmp (==)
  (/=) = cmp (/=)

instance Ord Double where
  (<) = cmp (<)
  (<=) = cmp (<=)
  (>) = cmp (>)
  (>=) = cmp (>=)

instance Show Double where
  showsPrec p = showsPrec p . unD

instance Read Double where
  readsPrec p = map (\ (x, s) -> (D x, s)) . readsPrec p

instance Real Double where
  toRational = toRational . unD

instance RealFrac Double where
  properFraction x = (a, D b) where (a, b) = properFraction (unD x)

instance Floating Double where
  pi = D pi
  log = un log
  exp = un exp
  sqrt = un sqrt
  sin = un sin
  cos = un cos
  tan = un tan
  asin = un asin
  acos = un acos
  atan = un atan

instance RealFloat Double where
  floatRadix = floatRadix . unD
  floatDigits = floatDigits . unD
  floatRange = floatRange . unD
  decodeFloat = decodeFloat . unD
  encodeFloat e = D . encodeFloat e
  isNaN = isNaN . unD
  isInfinite = isInfinite . unD
  isDenormalized = isDenormalized . unD
  isNegativeZero = isNegativeZero . unD
  isIEEE = isIEEE . unD
  atan2 = bin atan2