{-# LANGUAGE ConstraintKinds #-} {-# LANGUAGE FlexibleContexts #-} {-# LANGUAGE FlexibleInstances #-} {-# OPTIONS_GHC -fno-warn-orphans #-} -- | -- Module : Data.Array.Accelerate.Classes.Num -- Copyright : [2016..2017] Manuel M T Chakravarty, Gabriele Keller, Trevor L. McDonell -- License : BSD3 -- -- Maintainer : Trevor L. McDonell -- Stability : experimental -- Portability : non-portable (GHC extensions) -- module Data.Array.Accelerate.Classes.Num ( Num, (P.+), (P.-), (P.*), P.negate, P.abs, P.signum, P.fromInteger, ) where import Data.Array.Accelerate.Array.Sugar import Data.Array.Accelerate.Smart import Data.Array.Accelerate.Type import Prelude ( (.) ) import qualified Prelude as P -- Should we replace 'Prelude.Num' with our own version, as we did with 'Ord' -- and 'Eq'? That might require clients to enable RebindableSyntax in order to -- get the correct 'fromInteger' (or miss out on special magic and need to add -- 'constant' instead). -- -- I think that we should, because otherwise we require FlexibleContexts and -- constraints are going to be inconsistent, e.g.: -- -- f :: (P.Num (Exp a), A.Ord a) => ... -- -- A light-weight alternative is the following constraint kind: -- -- | Basic numeric class -- type Num a = (Elt a, P.Num (Exp a)) instance P.Num (Exp Int) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp Int8) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp Int16) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp Int32) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp Int64) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp Word) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp Word8) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp Word16) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp Word32) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp Word64) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp CInt) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp CUInt) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp CLong) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp CULong) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp CLLong) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp CULLong) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp CShort) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp CUShort) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp Float) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp Double) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp CFloat) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger instance P.Num (Exp CDouble) where (+) = mkAdd (-) = mkSub (*) = mkMul negate = mkNeg abs = mkAbs signum = mkSig fromInteger = constant . P.fromInteger