{-# LANGUAGE RebindableSyntax #-}
module Data.Array.Accelerate.Data.Functor (
Functor(..),
(<$>),
($>),
void,
) where
import Data.Array.Accelerate.Sugar.Elt
import Data.Array.Accelerate.Lift
import Data.Array.Accelerate.Smart
import Data.Monoid
import Data.Semigroup
import Prelude ( (.), const, flip )
class Functor f where
fmap :: (Elt a, Elt b, Elt (f a), Elt (f b)) => (Exp a -> Exp b) -> Exp (f a) -> Exp (f b)
infixl 4 <$
(<$) :: (Elt a, Elt b, Elt (f a), Elt (f b)) => Exp a -> Exp (f b) -> Exp (f a)
(<$) = (Exp b -> Exp a) -> Exp (f b) -> Exp (f a)
forall a b.
(Elt a, Elt b, Elt (f a), Elt (f b)) =>
(Exp a -> Exp b) -> Exp (f a) -> Exp (f b)
forall (f :: * -> *) a b.
(Functor f, Elt a, Elt b, Elt (f a), Elt (f b)) =>
(Exp a -> Exp b) -> Exp (f a) -> Exp (f b)
fmap ((Exp b -> Exp a) -> Exp (f b) -> Exp (f a))
-> (Exp a -> Exp b -> Exp a) -> Exp a -> Exp (f b) -> Exp (f a)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Exp a -> Exp b -> Exp a
forall a b. a -> b -> a
const
infixl 4 <$>
(<$>) :: (Functor f, Elt a, Elt b, Elt (f a), Elt (f b)) => (Exp a -> Exp b) -> Exp (f a) -> Exp (f b)
<$> :: forall (f :: * -> *) a b.
(Functor f, Elt a, Elt b, Elt (f a), Elt (f b)) =>
(Exp a -> Exp b) -> Exp (f a) -> Exp (f b)
(<$>) = (Exp a -> Exp b) -> Exp (f a) -> Exp (f b)
forall a b.
(Elt a, Elt b, Elt (f a), Elt (f b)) =>
(Exp a -> Exp b) -> Exp (f a) -> Exp (f b)
forall (f :: * -> *) a b.
(Functor f, Elt a, Elt b, Elt (f a), Elt (f b)) =>
(Exp a -> Exp b) -> Exp (f a) -> Exp (f b)
fmap
infixl 4 $>
($>) :: (Functor f, Elt a, Elt b, Elt (f a), Elt (f b)) => Exp (f a) -> Exp b -> Exp (f b)
$> :: forall (f :: * -> *) a b.
(Functor f, Elt a, Elt b, Elt (f a), Elt (f b)) =>
Exp (f a) -> Exp b -> Exp (f b)
($>) = (Exp b -> Exp (f a) -> Exp (f b))
-> Exp (f a) -> Exp b -> Exp (f b)
forall a b c. (a -> b -> c) -> b -> a -> c
flip Exp b -> Exp (f a) -> Exp (f b)
forall a b.
(Elt a, Elt b, Elt (f a), Elt (f b)) =>
Exp a -> Exp (f b) -> Exp (f a)
forall (f :: * -> *) a b.
(Functor f, Elt a, Elt b, Elt (f a), Elt (f b)) =>
Exp a -> Exp (f b) -> Exp (f a)
(<$)
void :: (Functor f, Elt a, Elt (f a), Elt (f ())) => Exp (f a) -> Exp (f ())
void :: forall (f :: * -> *) a.
(Functor f, Elt a, Elt (f a), Elt (f ())) =>
Exp (f a) -> Exp (f ())
void Exp (f a)
x = () -> Exp ()
forall e. (HasCallStack, Elt e) => e -> Exp e
constant () Exp () -> Exp (f a) -> Exp (f ())
forall a b.
(Elt a, Elt b, Elt (f a), Elt (f b)) =>
Exp a -> Exp (f b) -> Exp (f a)
forall (f :: * -> *) a b.
(Functor f, Elt a, Elt b, Elt (f a), Elt (f b)) =>
Exp a -> Exp (f b) -> Exp (f a)
<$ Exp (f a)
x
instance Functor Sum where
fmap :: forall a b.
(Elt a, Elt b, Elt (Sum a), Elt (Sum b)) =>
(Exp a -> Exp b) -> Exp (Sum a) -> Exp (Sum b)
fmap Exp a -> Exp b
f = (Exp (Sum a) -> Exp (Sum b))
-> Exp (Plain (Exp (Sum a))) -> Exp (Plain (Exp (Sum b)))
forall a b.
(Unlift Exp a, Lift Exp b) =>
(a -> b) -> Exp (Plain a) -> Exp (Plain b)
lift1 ((Exp a -> Exp b) -> Exp (Sum a) -> Exp (Sum b)
forall a b.
(Elt a, Elt b, Elt (Sum a), Elt (Sum b)) =>
(Exp a -> Exp b) -> Exp (Sum a) -> Exp (Sum b)
forall (f :: * -> *) a b.
(Functor f, Elt a, Elt b, Elt (f a), Elt (f b)) =>
(Exp a -> Exp b) -> Exp (f a) -> Exp (f b)
fmap Exp a -> Exp b
f)
instance Functor Product where
fmap :: forall a b.
(Elt a, Elt b, Elt (Product a), Elt (Product b)) =>
(Exp a -> Exp b) -> Exp (Product a) -> Exp (Product b)
fmap Exp a -> Exp b
f = (Exp (Product a) -> Exp (Product b))
-> Exp (Plain (Exp (Product a))) -> Exp (Plain (Exp (Product b)))
forall a b.
(Unlift Exp a, Lift Exp b) =>
(a -> b) -> Exp (Plain a) -> Exp (Plain b)
lift1 ((Exp a -> Exp b) -> Exp (Product a) -> Exp (Product b)
forall a b.
(Elt a, Elt b, Elt (Product a), Elt (Product b)) =>
(Exp a -> Exp b) -> Exp (Product a) -> Exp (Product b)
forall (f :: * -> *) a b.
(Functor f, Elt a, Elt b, Elt (f a), Elt (f b)) =>
(Exp a -> Exp b) -> Exp (f a) -> Exp (f b)
fmap Exp a -> Exp b
f)
instance Functor Min where
fmap :: forall a b.
(Elt a, Elt b, Elt (Min a), Elt (Min b)) =>
(Exp a -> Exp b) -> Exp (Min a) -> Exp (Min b)
fmap Exp a -> Exp b
f = (Exp (Min a) -> Exp (Min b))
-> Exp (Plain (Exp (Min a))) -> Exp (Plain (Exp (Min b)))
forall a b.
(Unlift Exp a, Lift Exp b) =>
(a -> b) -> Exp (Plain a) -> Exp (Plain b)
lift1 ((Exp a -> Exp b) -> Exp (Min a) -> Exp (Min b)
forall a b.
(Elt a, Elt b, Elt (Min a), Elt (Min b)) =>
(Exp a -> Exp b) -> Exp (Min a) -> Exp (Min b)
forall (f :: * -> *) a b.
(Functor f, Elt a, Elt b, Elt (f a), Elt (f b)) =>
(Exp a -> Exp b) -> Exp (f a) -> Exp (f b)
fmap Exp a -> Exp b
f)
instance Functor Max where
fmap :: forall a b.
(Elt a, Elt b, Elt (Max a), Elt (Max b)) =>
(Exp a -> Exp b) -> Exp (Max a) -> Exp (Max b)
fmap Exp a -> Exp b
f = (Exp (Max a) -> Exp (Max b))
-> Exp (Plain (Exp (Max a))) -> Exp (Plain (Exp (Max b)))
forall a b.
(Unlift Exp a, Lift Exp b) =>
(a -> b) -> Exp (Plain a) -> Exp (Plain b)
lift1 ((Exp a -> Exp b) -> Exp (Max a) -> Exp (Max b)
forall a b.
(Elt a, Elt b, Elt (Max a), Elt (Max b)) =>
(Exp a -> Exp b) -> Exp (Max a) -> Exp (Max b)
forall (f :: * -> *) a b.
(Functor f, Elt a, Elt b, Elt (f a), Elt (f b)) =>
(Exp a -> Exp b) -> Exp (f a) -> Exp (f b)
fmap Exp a -> Exp b
f)