module Data.Array.Accelerate.Trafo (
Phase(..), phases,
convertAcc, convertAccWith,
convertAfun, convertAfunWith,
module Data.Array.Accelerate.Trafo.Fusion,
rebuildAcc,
module Data.Array.Accelerate.Trafo.Substitution,
) where
import System.IO.Unsafe
import Data.Array.Accelerate.Smart
import Data.Array.Accelerate.Debug
import Data.Array.Accelerate.Pretty ( )
import Data.Array.Accelerate.Array.Sugar ( Arrays, Elt )
import Data.Array.Accelerate.Trafo.Base
import Data.Array.Accelerate.Trafo.Fusion hiding ( convertAcc, convertAfun )
import Data.Array.Accelerate.Trafo.Sharing ( Function, FunctionR, Afunction, AfunctionR )
import Data.Array.Accelerate.Trafo.Substitution
import qualified Data.Array.Accelerate.AST as AST
import qualified Data.Array.Accelerate.Trafo.Fusion as Fusion
import qualified Data.Array.Accelerate.Trafo.Rewrite as Rewrite
import qualified Data.Array.Accelerate.Trafo.Simplify as Rewrite
import qualified Data.Array.Accelerate.Trafo.Sharing as Sharing
data Phase = Phase
{
recoverAccSharing :: Bool
, recoverExpSharing :: Bool
, floatOutAccFromExp :: Bool
, enableAccFusion :: Bool
, convertOffsetOfSegment :: Bool
}
phases :: Phase
phases = Phase
{ recoverAccSharing = True
, recoverExpSharing = True
, floatOutAccFromExp = True
, enableAccFusion = True
, convertOffsetOfSegment = False
}
convertAcc :: Arrays arrs => Acc arrs -> DelayedAcc arrs
convertAcc = convertAccWith phases
convertAccWith :: Arrays arrs => Phase -> Acc arrs -> DelayedAcc arrs
convertAccWith ok acc
= Fusion.convertAcc
$ Rewrite.convertSegments `when` convertOffsetOfSegment
$ Sharing.convertAcc (recoverAccSharing ok) (recoverExpSharing ok) (floatOutAccFromExp ok) acc
where
when f phase
| phase ok = f
| otherwise = id
convertAfun :: Afunction f => f -> DelayedAfun (AfunctionR f)
convertAfun = convertAfunWith phases
convertAfunWith :: Afunction f => Phase -> f -> DelayedAfun (AfunctionR f)
convertAfunWith ok acc
= Fusion.convertAfun
$ Rewrite.convertSegmentsAfun `when` convertOffsetOfSegment
$ Sharing.convertAfun (recoverAccSharing ok) (recoverExpSharing ok) (floatOutAccFromExp ok) acc
where
when f phase
| phase ok = f
| otherwise = id
convertExp :: Elt e => Exp e -> AST.Exp () e
convertExp
= Rewrite.simplify
. Sharing.convertExp (recoverExpSharing phases)
convertFun :: Function f => f -> AST.Fun () (FunctionR f)
convertFun
= Rewrite.simplify
. Sharing.convertFun (recoverExpSharing phases)
instance Arrays arrs => Show (Acc arrs) where
show = withSimplStats . show . convertAcc
instance Afunction (Acc a -> f) => Show (Acc a -> f) where
show = withSimplStats . show . convertAfun
instance Elt e => Show (Exp e) where
show = withSimplStats . show . convertExp
instance Function (Exp a -> f) => Show (Exp a -> f) where
show = withSimplStats . show . convertFun
withSimplStats :: String -> String
#ifdef ACCELERATE_DEBUG
withSimplStats x = unsafePerformIO $ do
enabled <- queryFlag dump_simpl_stats
if not enabled
then return x
else do resetSimplCount
stats <- length x `seq` simplCount
traceMessage dump_simpl_stats (show stats)
return x
#else
withSimplStats x = x
#endif