1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
|
module Numeric.Natural (Natural,
mkNatural)
where
data Natural = Natural Integer
mkNatural :: Integer -> Natural
mkNatural n | n < 0 = error "mkNatural: negative number!"
| otherwise = Natural n
instance Enum Natural where
toEnum n = Natural (fromIntegral n)
fromEnum (Natural n) = fromEnum n
succ (Natural n) = Natural (succ n)
pred (Natural n) = mkNatural (pred n)
instance Integral Natural where
toInteger (Natural n) = n
quotRem _ 0 = error "Natural / 0"
quotRem _ _ = error "quotRem @Natural unimplemented"
instance Num Natural where
fromInteger = mkNatural
Natural m + Natural n = Natural (m+n)
Natural m * Natural n = Natural (m*n)
Natural m - Natural n = mkNatural (m-n)
abs = id
signum 0 = 0
signum _ = 1
negate _ = error "negate @Natural"
instance Eq Natural where
(Natural m) == (Natural n) = m == n
instance Ord Natural where
(Natural m) < (Natural n) = n < m
(Natural m) <= (Natural n) = n <= m
(Natural m) > (Natural n) = n > m
(Natural m) >= (Natural n) = n >= m
min (Natural m) (Natural n) = Natural (min m n)
max (Natural m) (Natural n) = Natural (max m n)
instance Real Natural where
toRational = toRational . toInteger
instance Show Natural where
-- showsPrec d (Natural n) = showsPrec d n
show (Natural n) = show n
|