{-# LANGUAGE TypeFamilies #-}
module Futhark.IR.SOACS
( SOACS,
usesAD,
module Futhark.IR.Prop,
module Futhark.IR.Traversals,
module Futhark.IR.Pretty,
module Futhark.IR.Syntax,
module Futhark.IR.SOACS.SOAC,
)
where
import Futhark.Builder
import Futhark.Construct
import Futhark.IR.Pretty
import Futhark.IR.Prop
import Futhark.IR.SOACS.SOAC
import Futhark.IR.Syntax
import Futhark.IR.Traversals
import Futhark.IR.TypeCheck qualified as TC
data SOACS
instance RepTypes SOACS where
type OpC SOACS = SOAC
instance ASTRep SOACS where
expTypesFromPat :: forall (m :: * -> *).
(HasScope SOACS m, Monad m) =>
Pat (LetDec SOACS) -> m [BranchType SOACS]
expTypesFromPat = [ExtType] -> m [ExtType]
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ([ExtType] -> m [ExtType])
-> (Pat Type -> [ExtType]) -> Pat Type -> m [ExtType]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Pat Type -> [ExtType]
forall dec. Typed dec => Pat dec -> [ExtType]
expExtTypesFromPat
instance TC.Checkable SOACS where
checkOp :: Op (Aliases SOACS) -> TypeM SOACS ()
checkOp = Op (Aliases SOACS) -> TypeM SOACS ()
SOAC (Aliases SOACS) -> TypeM SOACS ()
forall rep. Checkable rep => SOAC (Aliases rep) -> TypeM rep ()
typeCheckSOAC
instance Buildable SOACS where
mkBody :: Stms SOACS -> Result -> Body SOACS
mkBody = BodyDec SOACS -> Stms SOACS -> Result -> Body SOACS
forall rep. BodyDec rep -> Stms rep -> Result -> Body rep
Body ()
mkExpPat :: [Ident] -> Exp SOACS -> Pat (LetDec SOACS)
mkExpPat [Ident]
merge Exp SOACS
_ = [Ident] -> Pat Type
basicPat [Ident]
merge
mkExpDec :: Pat (LetDec SOACS) -> Exp SOACS -> ExpDec SOACS
mkExpDec Pat (LetDec SOACS)
_ Exp SOACS
_ = ()
mkLetNames :: forall (m :: * -> *).
(MonadFreshNames m, HasScope SOACS m) =>
[VName] -> Exp SOACS -> m (Stm SOACS)
mkLetNames = [VName] -> Exp SOACS -> m (Stm SOACS)
forall rep (m :: * -> *).
(ExpDec rep ~ (), LetDec rep ~ Type, MonadFreshNames m,
TypedOp (OpC rep), HasScope rep m) =>
[VName] -> Exp rep -> m (Stm rep)
simpleMkLetNames
instance BuilderOps SOACS
instance PrettyRep SOACS
usesAD :: Prog SOACS -> Bool
usesAD :: Prog SOACS -> Bool
usesAD Prog SOACS
prog = (Stm SOACS -> Bool) -> Stms SOACS -> Bool
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
any Stm SOACS -> Bool
stmUsesAD (Prog SOACS -> Stms SOACS
forall rep. Prog rep -> Stms rep
progConsts Prog SOACS
prog) Bool -> Bool -> Bool
|| (FunDef SOACS -> Bool) -> [FunDef SOACS] -> Bool
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
any FunDef SOACS -> Bool
funUsesAD (Prog SOACS -> [FunDef SOACS]
forall rep. Prog rep -> [FunDef rep]
progFuns Prog SOACS
prog)
where
funUsesAD :: FunDef SOACS -> Bool
funUsesAD = Body SOACS -> Bool
bodyUsesAD (Body SOACS -> Bool)
-> (FunDef SOACS -> Body SOACS) -> FunDef SOACS -> Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. FunDef SOACS -> Body SOACS
forall rep. FunDef rep -> Body rep
funDefBody
bodyUsesAD :: Body SOACS -> Bool
bodyUsesAD = (Stm SOACS -> Bool) -> Stms SOACS -> Bool
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
any Stm SOACS -> Bool
stmUsesAD (Stms SOACS -> Bool)
-> (Body SOACS -> Stms SOACS) -> Body SOACS -> Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Body SOACS -> Stms SOACS
forall rep. Body rep -> Stms rep
bodyStms
stmUsesAD :: Stm SOACS -> Bool
stmUsesAD = Exp SOACS -> Bool
expUsesAD (Exp SOACS -> Bool)
-> (Stm SOACS -> Exp SOACS) -> Stm SOACS -> Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Stm SOACS -> Exp SOACS
forall rep. Stm rep -> Exp rep
stmExp
lamUsesAD :: Lambda SOACS -> Bool
lamUsesAD = Body SOACS -> Bool
bodyUsesAD (Body SOACS -> Bool)
-> (Lambda SOACS -> Body SOACS) -> Lambda SOACS -> Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Lambda SOACS -> Body SOACS
forall rep. Lambda rep -> Body rep
lambdaBody
expUsesAD :: Exp SOACS -> Bool
expUsesAD (Op JVP {}) = Bool
True
expUsesAD (Op VJP {}) = Bool
True
expUsesAD (Op (Stream SubExp
_ [VName]
_ [SubExp]
_ Lambda SOACS
lam)) = Lambda SOACS -> Bool
lamUsesAD Lambda SOACS
lam
expUsesAD (Op (Screma SubExp
_ [VName]
_ (ScremaForm Lambda SOACS
lam [Scan SOACS]
scans [Reduce SOACS]
reds))) =
Lambda SOACS -> Bool
lamUsesAD Lambda SOACS
lam
Bool -> Bool -> Bool
|| (Scan SOACS -> Bool) -> [Scan SOACS] -> Bool
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
any (Lambda SOACS -> Bool
lamUsesAD (Lambda SOACS -> Bool)
-> (Scan SOACS -> Lambda SOACS) -> Scan SOACS -> Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Scan SOACS -> Lambda SOACS
forall rep. Scan rep -> Lambda rep
scanLambda) [Scan SOACS]
scans
Bool -> Bool -> Bool
|| (Reduce SOACS -> Bool) -> [Reduce SOACS] -> Bool
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
any (Lambda SOACS -> Bool
lamUsesAD (Lambda SOACS -> Bool)
-> (Reduce SOACS -> Lambda SOACS) -> Reduce SOACS -> Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Reduce SOACS -> Lambda SOACS
forall rep. Reduce rep -> Lambda rep
redLambda) [Reduce SOACS]
reds
expUsesAD (Op (Hist SubExp
_ [VName]
_ [HistOp SOACS]
ops Lambda SOACS
lam)) =
Lambda SOACS -> Bool
lamUsesAD Lambda SOACS
lam Bool -> Bool -> Bool
|| (HistOp SOACS -> Bool) -> [HistOp SOACS] -> Bool
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
any (Lambda SOACS -> Bool
lamUsesAD (Lambda SOACS -> Bool)
-> (HistOp SOACS -> Lambda SOACS) -> HistOp SOACS -> Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. HistOp SOACS -> Lambda SOACS
forall rep. HistOp rep -> Lambda rep
histOp) [HistOp SOACS]
ops
expUsesAD (Op (Scatter SubExp
_ [VName]
_ ScatterSpec VName
_ Lambda SOACS
lam)) =
Lambda SOACS -> Bool
lamUsesAD Lambda SOACS
lam
expUsesAD (Match [SubExp]
_ [Case (Body SOACS)]
cases Body SOACS
def_case MatchDec (BranchType SOACS)
_) =
(Case (Body SOACS) -> Bool) -> [Case (Body SOACS)] -> Bool
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
any (Body SOACS -> Bool
bodyUsesAD (Body SOACS -> Bool)
-> (Case (Body SOACS) -> Body SOACS) -> Case (Body SOACS) -> Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Case (Body SOACS) -> Body SOACS
forall body. Case body -> body
caseBody) [Case (Body SOACS)]
cases Bool -> Bool -> Bool
|| Body SOACS -> Bool
bodyUsesAD Body SOACS
def_case
expUsesAD (Loop [(FParam SOACS, SubExp)]
_ LoopForm
_ Body SOACS
body) = Body SOACS -> Bool
bodyUsesAD Body SOACS
body
expUsesAD (WithAcc [WithAccInput SOACS]
_ Lambda SOACS
lam) = Lambda SOACS -> Bool
lamUsesAD Lambda SOACS
lam
expUsesAD BasicOp {} = Bool
False
expUsesAD Apply {} = Bool
False