{-# LANGUAGE FlexibleInstances    #-}
{-# LANGUAGE GADTs                #-}
{-# LANGUAGE LambdaCase           #-}
{-# LANGUAGE OverloadedStrings    #-}
{-# LANGUAGE RecordWildCards      #-}
{-# LANGUAGE TemplateHaskell      #-}
{-# LANGUAGE TypeFamilies         #-}
{-# LANGUAGE TypeSynonymInstances #-}
{-# OPTIONS_HADDOCK hide #-}
-- |
-- Module      : Data.Array.Accelerate.Trafo.Delayed
-- Copyright   : [2012..2020] The Accelerate Team
-- License     : BSD3
--
-- Maintainer  : Trevor L. McDonell <trevor.mcdonell@gmail.com>
-- Stability   : experimental
-- Portability : non-portable (GHC extensions)
--
-- The type of delayed arrays. This representation is used to annotate the AST
-- in the recursive knot to distinguish standard AST terms from operand arrays
-- that should be embedded into their consumers.
--

module Data.Array.Accelerate.Trafo.Delayed
  where

import Data.Array.Accelerate.AST
import Data.Array.Accelerate.Analysis.Hash
import Data.Array.Accelerate.Analysis.Match
import Data.Array.Accelerate.Representation.Array
import Data.Array.Accelerate.Representation.Type
import Data.Array.Accelerate.Trafo.Substitution

import Data.Array.Accelerate.Debug.Internal.Stats                   as Stats

import Control.DeepSeq
import Data.ByteString.Builder
import Data.ByteString.Builder.Extra


type DelayedAcc      = DelayedOpenAcc ()
type DelayedAfun     = PreOpenAfun DelayedOpenAcc ()
type DelayedOpenAfun = PreOpenAfun DelayedOpenAcc

-- type DelayedOpenSeq = PreOpenSeq DelayedOpenAcc
-- data DelayedSeq t where
--   DelayedSeq :: Extend DelayedOpenAcc () aenv
--              -> DelayedOpenSeq aenv () t
--              -> DelayedSeq t

data DelayedOpenAcc aenv a where
  Manifest              :: PreOpenAcc DelayedOpenAcc aenv a
                        -> DelayedOpenAcc aenv a

  Delayed               ::
    { forall sh e aenv.
DelayedOpenAcc aenv (Array sh e) -> ArrayR (Array sh e)
reprD             :: ArrayR (Array sh e)
    , forall sh e aenv. DelayedOpenAcc aenv (Array sh e) -> Exp aenv sh
extentD           :: Exp aenv sh
    , forall sh e aenv.
DelayedOpenAcc aenv (Array sh e) -> Fun aenv (sh -> e)
indexD            :: Fun aenv (sh  -> e)
    , forall sh e aenv.
DelayedOpenAcc aenv (Array sh e) -> Fun aenv (Int -> e)
linearIndexD      :: Fun aenv (Int -> e)
    }                   -> DelayedOpenAcc aenv (Array sh e)

instance HasArraysR DelayedOpenAcc where
  arraysR :: forall aenv a. DelayedOpenAcc aenv a -> ArraysR a
arraysR (Manifest PreOpenAcc DelayedOpenAcc aenv a
a) = PreOpenAcc DelayedOpenAcc aenv a -> ArraysR a
forall aenv a. PreOpenAcc DelayedOpenAcc aenv a -> ArraysR a
forall (f :: * -> * -> *) aenv a.
HasArraysR f =>
f aenv a -> ArraysR a
arraysR PreOpenAcc DelayedOpenAcc aenv a
a
  arraysR Delayed{ArrayR (Array sh e)
Exp aenv sh
Fun aenv (sh -> e)
Fun aenv (Int -> e)
reprD :: forall sh e aenv.
DelayedOpenAcc aenv (Array sh e) -> ArrayR (Array sh e)
extentD :: forall sh e aenv. DelayedOpenAcc aenv (Array sh e) -> Exp aenv sh
indexD :: forall sh e aenv.
DelayedOpenAcc aenv (Array sh e) -> Fun aenv (sh -> e)
linearIndexD :: forall sh e aenv.
DelayedOpenAcc aenv (Array sh e) -> Fun aenv (Int -> e)
reprD :: ArrayR (Array sh e)
extentD :: Exp aenv sh
indexD :: Fun aenv (sh -> e)
linearIndexD :: Fun aenv (Int -> e)
..}  = ArrayR a -> ArraysR a
forall (s :: * -> *) a. s a -> TupR s a
TupRsingle ArrayR a
ArrayR (Array sh e)
reprD

instance Rebuildable DelayedOpenAcc where
  type AccClo DelayedOpenAcc = DelayedOpenAcc
  rebuildPartial :: forall (f' :: * -> *) (fa :: (* -> * -> *) -> * -> * -> *) aenv
       aenv' a.
(Applicative f', SyntacticAcc fa) =>
(forall sh e.
 ArrayVar aenv (Array sh e)
 -> f' (fa (AccClo DelayedOpenAcc) aenv' (Array sh e)))
-> DelayedOpenAcc aenv a -> f' (DelayedOpenAcc aenv' a)
rebuildPartial forall sh e.
ArrayVar aenv (Array sh e)
-> f' (fa (AccClo DelayedOpenAcc) aenv' (Array sh e))
v = \case
    Manifest PreOpenAcc DelayedOpenAcc aenv a
pacc -> PreOpenAcc DelayedOpenAcc aenv' a -> DelayedOpenAcc aenv' a
forall aenv a.
PreOpenAcc DelayedOpenAcc aenv a -> DelayedOpenAcc aenv a
Manifest (PreOpenAcc DelayedOpenAcc aenv' a -> DelayedOpenAcc aenv' a)
-> f' (PreOpenAcc DelayedOpenAcc aenv' a)
-> f' (DelayedOpenAcc aenv' a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (forall sh e.
 ArrayVar aenv (Array sh e)
 -> f' (fa (AccClo (PreOpenAcc DelayedOpenAcc)) aenv' (Array sh e)))
-> PreOpenAcc DelayedOpenAcc aenv a
-> f' (PreOpenAcc DelayedOpenAcc aenv' a)
forall (f' :: * -> *) (fa :: (* -> * -> *) -> * -> * -> *) aenv
       aenv' a.
(Applicative f', SyntacticAcc fa) =>
(forall sh e.
 ArrayVar aenv (Array sh e)
 -> f' (fa (AccClo (PreOpenAcc DelayedOpenAcc)) aenv' (Array sh e)))
-> PreOpenAcc DelayedOpenAcc aenv a
-> f' (PreOpenAcc DelayedOpenAcc aenv' a)
forall (f :: * -> * -> *) (f' :: * -> *)
       (fa :: (* -> * -> *) -> * -> * -> *) aenv aenv' a.
(Rebuildable f, Applicative f', SyntacticAcc fa) =>
(forall sh e.
 ArrayVar aenv (Array sh e)
 -> f' (fa (AccClo f) aenv' (Array sh e)))
-> f aenv a -> f' (f aenv' a)
rebuildPartial Var ArrayR aenv (Array sh e)
-> f' (fa (AccClo (PreOpenAcc DelayedOpenAcc)) aenv' (Array sh e))
Var ArrayR aenv (Array sh e)
-> f' (fa (AccClo DelayedOpenAcc) aenv' (Array sh e))
forall sh e.
ArrayVar aenv (Array sh e)
-> f' (fa (AccClo (PreOpenAcc DelayedOpenAcc)) aenv' (Array sh e))
forall sh e.
ArrayVar aenv (Array sh e)
-> f' (fa (AccClo DelayedOpenAcc) aenv' (Array sh e))
v PreOpenAcc DelayedOpenAcc aenv a
pacc
    Delayed{ArrayR (Array sh e)
Exp aenv sh
Fun aenv (sh -> e)
Fun aenv (Int -> e)
reprD :: forall sh e aenv.
DelayedOpenAcc aenv (Array sh e) -> ArrayR (Array sh e)
extentD :: forall sh e aenv. DelayedOpenAcc aenv (Array sh e) -> Exp aenv sh
indexD :: forall sh e aenv.
DelayedOpenAcc aenv (Array sh e) -> Fun aenv (sh -> e)
linearIndexD :: forall sh e aenv.
DelayedOpenAcc aenv (Array sh e) -> Fun aenv (Int -> e)
reprD :: ArrayR (Array sh e)
extentD :: Exp aenv sh
indexD :: Fun aenv (sh -> e)
linearIndexD :: Fun aenv (Int -> e)
..}   -> (\OpenAccExp DelayedOpenAcc () aenv' sh
e OpenAccFun DelayedOpenAcc () aenv' (sh -> e)
i OpenAccFun DelayedOpenAcc () aenv' (Int -> e)
l -> ArrayR (Array sh e)
-> Exp aenv' sh
-> Fun aenv' (sh -> e)
-> Fun aenv' (Int -> e)
-> DelayedOpenAcc aenv' (Array sh e)
forall sh e aenv.
ArrayR (Array sh e)
-> Exp aenv sh
-> Fun aenv (sh -> e)
-> Fun aenv (Int -> e)
-> DelayedOpenAcc aenv (Array sh e)
Delayed ArrayR (Array sh e)
reprD (OpenAccExp DelayedOpenAcc () aenv' sh -> Exp aenv' sh
forall env aenv a (acc :: * -> * -> *).
OpenAccExp acc env aenv a -> OpenExp env aenv a
unOpenAccExp OpenAccExp DelayedOpenAcc () aenv' sh
e) (OpenAccFun DelayedOpenAcc () aenv' (sh -> e) -> Fun aenv' (sh -> e)
forall env aenv a (acc :: * -> * -> *).
OpenAccFun acc env aenv a -> OpenFun env aenv a
unOpenAccFun OpenAccFun DelayedOpenAcc () aenv' (sh -> e)
i) (OpenAccFun DelayedOpenAcc () aenv' (Int -> e)
-> Fun aenv' (Int -> e)
forall env aenv a (acc :: * -> * -> *).
OpenAccFun acc env aenv a -> OpenFun env aenv a
unOpenAccFun OpenAccFun DelayedOpenAcc () aenv' (Int -> e)
l))
                              (OpenAccExp DelayedOpenAcc () aenv' sh
 -> OpenAccFun DelayedOpenAcc () aenv' (sh -> e)
 -> OpenAccFun DelayedOpenAcc () aenv' (Int -> e)
 -> DelayedOpenAcc aenv' a)
-> f' (OpenAccExp DelayedOpenAcc () aenv' sh)
-> f'
     (OpenAccFun DelayedOpenAcc () aenv' (sh -> e)
      -> OpenAccFun DelayedOpenAcc () aenv' (Int -> e)
      -> DelayedOpenAcc aenv' a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (forall sh e.
 ArrayVar aenv (Array sh e)
 -> f'
      (fa (AccClo (OpenAccExp DelayedOpenAcc ())) aenv' (Array sh e)))
-> OpenAccExp DelayedOpenAcc () aenv sh
-> f' (OpenAccExp DelayedOpenAcc () aenv' sh)
forall (f' :: * -> *) (fa :: (* -> * -> *) -> * -> * -> *) aenv
       aenv' a.
(Applicative f', SyntacticAcc fa) =>
(forall sh e.
 ArrayVar aenv (Array sh e)
 -> f'
      (fa (AccClo (OpenAccExp DelayedOpenAcc ())) aenv' (Array sh e)))
-> OpenAccExp DelayedOpenAcc () aenv a
-> f' (OpenAccExp DelayedOpenAcc () aenv' a)
forall (f :: * -> * -> *) (f' :: * -> *)
       (fa :: (* -> * -> *) -> * -> * -> *) aenv aenv' a.
(Rebuildable f, Applicative f', SyntacticAcc fa) =>
(forall sh e.
 ArrayVar aenv (Array sh e)
 -> f' (fa (AccClo f) aenv' (Array sh e)))
-> f aenv a -> f' (f aenv' a)
rebuildPartial Var ArrayR aenv (Array sh e)
-> f'
     (fa (AccClo (OpenAccExp DelayedOpenAcc ())) aenv' (Array sh e))
Var ArrayR aenv (Array sh e)
-> f' (fa (AccClo DelayedOpenAcc) aenv' (Array sh e))
forall sh e.
ArrayVar aenv (Array sh e)
-> f'
     (fa (AccClo (OpenAccExp DelayedOpenAcc ())) aenv' (Array sh e))
forall sh e.
ArrayVar aenv (Array sh e)
-> f' (fa (AccClo DelayedOpenAcc) aenv' (Array sh e))
v (Exp aenv sh -> OpenAccExp DelayedOpenAcc () aenv sh
forall env aenv a (acc :: * -> * -> *).
OpenExp env aenv a -> OpenAccExp acc env aenv a
OpenAccExp Exp aenv sh
extentD)
                              f'
  (OpenAccFun DelayedOpenAcc () aenv' (sh -> e)
   -> OpenAccFun DelayedOpenAcc () aenv' (Int -> e)
   -> DelayedOpenAcc aenv' a)
-> f' (OpenAccFun DelayedOpenAcc () aenv' (sh -> e))
-> f'
     (OpenAccFun DelayedOpenAcc () aenv' (Int -> e)
      -> DelayedOpenAcc aenv' a)
forall a b. f' (a -> b) -> f' a -> f' b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> (forall sh e.
 ArrayVar aenv (Array sh e)
 -> f'
      (fa (AccClo (OpenAccFun DelayedOpenAcc ())) aenv' (Array sh e)))
-> OpenAccFun DelayedOpenAcc () aenv (sh -> e)
-> f' (OpenAccFun DelayedOpenAcc () aenv' (sh -> e))
forall (f' :: * -> *) (fa :: (* -> * -> *) -> * -> * -> *) aenv
       aenv' a.
(Applicative f', SyntacticAcc fa) =>
(forall sh e.
 ArrayVar aenv (Array sh e)
 -> f'
      (fa (AccClo (OpenAccFun DelayedOpenAcc ())) aenv' (Array sh e)))
-> OpenAccFun DelayedOpenAcc () aenv a
-> f' (OpenAccFun DelayedOpenAcc () aenv' a)
forall (f :: * -> * -> *) (f' :: * -> *)
       (fa :: (* -> * -> *) -> * -> * -> *) aenv aenv' a.
(Rebuildable f, Applicative f', SyntacticAcc fa) =>
(forall sh e.
 ArrayVar aenv (Array sh e)
 -> f' (fa (AccClo f) aenv' (Array sh e)))
-> f aenv a -> f' (f aenv' a)
rebuildPartial Var ArrayR aenv (Array sh e)
-> f'
     (fa (AccClo (OpenAccFun DelayedOpenAcc ())) aenv' (Array sh e))
Var ArrayR aenv (Array sh e)
-> f' (fa (AccClo DelayedOpenAcc) aenv' (Array sh e))
forall sh e.
ArrayVar aenv (Array sh e)
-> f'
     (fa (AccClo (OpenAccFun DelayedOpenAcc ())) aenv' (Array sh e))
forall sh e.
ArrayVar aenv (Array sh e)
-> f' (fa (AccClo DelayedOpenAcc) aenv' (Array sh e))
v (Fun aenv (sh -> e) -> OpenAccFun DelayedOpenAcc () aenv (sh -> e)
forall env aenv a (acc :: * -> * -> *).
OpenFun env aenv a -> OpenAccFun acc env aenv a
OpenAccFun Fun aenv (sh -> e)
indexD)
                              f'
  (OpenAccFun DelayedOpenAcc () aenv' (Int -> e)
   -> DelayedOpenAcc aenv' a)
-> f' (OpenAccFun DelayedOpenAcc () aenv' (Int -> e))
-> f' (DelayedOpenAcc aenv' a)
forall a b. f' (a -> b) -> f' a -> f' b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> (forall sh e.
 ArrayVar aenv (Array sh e)
 -> f'
      (fa (AccClo (OpenAccFun DelayedOpenAcc ())) aenv' (Array sh e)))
-> OpenAccFun DelayedOpenAcc () aenv (Int -> e)
-> f' (OpenAccFun DelayedOpenAcc () aenv' (Int -> e))
forall (f' :: * -> *) (fa :: (* -> * -> *) -> * -> * -> *) aenv
       aenv' a.
(Applicative f', SyntacticAcc fa) =>
(forall sh e.
 ArrayVar aenv (Array sh e)
 -> f'
      (fa (AccClo (OpenAccFun DelayedOpenAcc ())) aenv' (Array sh e)))
-> OpenAccFun DelayedOpenAcc () aenv a
-> f' (OpenAccFun DelayedOpenAcc () aenv' a)
forall (f :: * -> * -> *) (f' :: * -> *)
       (fa :: (* -> * -> *) -> * -> * -> *) aenv aenv' a.
(Rebuildable f, Applicative f', SyntacticAcc fa) =>
(forall sh e.
 ArrayVar aenv (Array sh e)
 -> f' (fa (AccClo f) aenv' (Array sh e)))
-> f aenv a -> f' (f aenv' a)
rebuildPartial Var ArrayR aenv (Array sh e)
-> f'
     (fa (AccClo (OpenAccFun DelayedOpenAcc ())) aenv' (Array sh e))
Var ArrayR aenv (Array sh e)
-> f' (fa (AccClo DelayedOpenAcc) aenv' (Array sh e))
forall sh e.
ArrayVar aenv (Array sh e)
-> f'
     (fa (AccClo (OpenAccFun DelayedOpenAcc ())) aenv' (Array sh e))
forall sh e.
ArrayVar aenv (Array sh e)
-> f' (fa (AccClo DelayedOpenAcc) aenv' (Array sh e))
v (Fun aenv (Int -> e) -> OpenAccFun DelayedOpenAcc () aenv (Int -> e)
forall env aenv a (acc :: * -> * -> *).
OpenFun env aenv a -> OpenAccFun acc env aenv a
OpenAccFun Fun aenv (Int -> e)
linearIndexD)

instance Sink DelayedOpenAcc where
  weaken :: forall env env'.
(env :> env')
-> forall t. DelayedOpenAcc env t -> DelayedOpenAcc env' t
weaken env :> env'
k = Text -> DelayedOpenAcc env' t -> DelayedOpenAcc env' t
forall a. Text -> a -> a
Stats.substitution Text
"weaken" (DelayedOpenAcc env' t -> DelayedOpenAcc env' t)
-> (DelayedOpenAcc env t -> DelayedOpenAcc env' t)
-> DelayedOpenAcc env t
-> DelayedOpenAcc env' t
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (forall sh e.
 ArrayVar env (Array sh e)
 -> PreOpenAcc (AccClo DelayedOpenAcc) env' (Array sh e))
-> DelayedOpenAcc env t -> DelayedOpenAcc env' t
forall (f :: * -> * -> *) (fa :: (* -> * -> *) -> * -> * -> *) aenv
       aenv' a.
(Rebuildable f, SyntacticAcc fa) =>
(forall sh e.
 ArrayVar aenv (Array sh e) -> fa (AccClo f) aenv' (Array sh e))
-> f aenv a -> f aenv' a
forall (fa :: (* -> * -> *) -> * -> * -> *) aenv aenv' a.
SyntacticAcc fa =>
(forall sh e.
 ArrayVar aenv (Array sh e)
 -> fa (AccClo DelayedOpenAcc) aenv' (Array sh e))
-> DelayedOpenAcc aenv a -> DelayedOpenAcc aenv' a
rebuildA ((env :> env')
-> Var ArrayR env (Array sh e)
-> PreOpenAcc DelayedOpenAcc env' (Array sh e)
forall env env' sh e (acc :: * -> * -> *).
(env :> env')
-> ArrayVar env (Array sh e) -> PreOpenAcc acc env' (Array sh e)
rebuildWeakenVar env :> env'
k)

instance NFData (DelayedOpenAfun aenv t) where
  rnf :: DelayedOpenAfun aenv t -> ()
rnf = NFDataAcc DelayedOpenAcc -> DelayedOpenAfun aenv t -> ()
forall (acc :: * -> * -> *) aenv t.
NFDataAcc acc -> PreOpenAfun acc aenv t -> ()
rnfPreOpenAfun DelayedOpenAcc aenv t -> ()
NFDataAcc DelayedOpenAcc
rnfDelayedOpenAcc

instance NFData (DelayedOpenAcc aenv t) where
  rnf :: DelayedOpenAcc aenv t -> ()
rnf = DelayedOpenAcc aenv t -> ()
NFDataAcc DelayedOpenAcc
rnfDelayedOpenAcc

encodeDelayedOpenAcc :: EncodeAcc DelayedOpenAcc
encodeDelayedOpenAcc :: EncodeAcc DelayedOpenAcc
encodeDelayedOpenAcc HashOptions
options DelayedOpenAcc aenv a
acc =
  let
      travE :: Exp aenv sh -> Builder
      travE :: forall aenv sh. Exp aenv sh -> Builder
travE = OpenExp () aenv sh -> Builder
forall env aenv exp. OpenExp env aenv exp -> Builder
encodeOpenExp

      travF :: Fun aenv f -> Builder
      travF :: forall aenv f. Fun aenv f -> Builder
travF = OpenFun () aenv f -> Builder
forall env aenv f. OpenFun env aenv f -> Builder
encodeOpenFun

      travA :: PreOpenAcc DelayedOpenAcc aenv a -> Builder
      travA :: forall aenv a. PreOpenAcc DelayedOpenAcc aenv a -> Builder
travA = HashOptions
-> EncodeAcc DelayedOpenAcc
-> PreOpenAcc DelayedOpenAcc aenv a
-> Builder
forall (acc :: * -> * -> *) aenv arrs.
HasArraysR acc =>
HashOptions -> EncodeAcc acc -> PreOpenAcc acc aenv arrs -> Builder
encodePreOpenAcc HashOptions
options HashOptions -> DelayedOpenAcc aenv a -> Builder
EncodeAcc DelayedOpenAcc
encodeDelayedOpenAcc

      deepA :: PreOpenAcc DelayedOpenAcc aenv a -> Builder
      deepA :: forall aenv a. PreOpenAcc DelayedOpenAcc aenv a -> Builder
deepA | HashOptions -> Bool
perfect HashOptions
options = PreOpenAcc DelayedOpenAcc aenv a -> Builder
forall aenv a. PreOpenAcc DelayedOpenAcc aenv a -> Builder
travA
            | Bool
otherwise       = ArraysR a -> Builder
forall arrs. ArraysR arrs -> Builder
encodeArraysType (ArraysR a -> Builder)
-> (PreOpenAcc DelayedOpenAcc aenv a -> ArraysR a)
-> PreOpenAcc DelayedOpenAcc aenv a
-> Builder
forall b c a. (b -> c) -> (a -> b) -> a -> c
. PreOpenAcc DelayedOpenAcc aenv a -> ArraysR a
forall aenv a. PreOpenAcc DelayedOpenAcc aenv a -> ArraysR a
forall (f :: * -> * -> *) aenv a.
HasArraysR f =>
f aenv a -> ArraysR a
arraysR
  in
  case DelayedOpenAcc aenv a
acc of
    Manifest PreOpenAcc DelayedOpenAcc aenv a
pacc    -> Int -> Builder
intHost $(hashQ ("Manifest" :: String)) Builder -> Builder -> Builder
forall a. Semigroup a => a -> a -> a
<> PreOpenAcc DelayedOpenAcc aenv a -> Builder
forall aenv a. PreOpenAcc DelayedOpenAcc aenv a -> Builder
deepA PreOpenAcc DelayedOpenAcc aenv a
pacc
    Delayed ArrayR (Array sh e)
_ Exp aenv sh
sh Fun aenv (sh -> e)
f Fun aenv (Int -> e)
g -> Int -> Builder
intHost $(hashQ ("Delayed"  :: String)) Builder -> Builder -> Builder
forall a. Semigroup a => a -> a -> a
<> Exp aenv sh -> Builder
forall aenv sh. Exp aenv sh -> Builder
travE Exp aenv sh
sh Builder -> Builder -> Builder
forall a. Semigroup a => a -> a -> a
<> Fun aenv (sh -> e) -> Builder
forall aenv f. Fun aenv f -> Builder
travF Fun aenv (sh -> e)
f Builder -> Builder -> Builder
forall a. Semigroup a => a -> a -> a
<> Fun aenv (Int -> e) -> Builder
forall aenv f. Fun aenv f -> Builder
travF Fun aenv (Int -> e)
g

matchDelayedOpenAcc :: MatchAcc DelayedOpenAcc
matchDelayedOpenAcc :: MatchAcc DelayedOpenAcc
matchDelayedOpenAcc (Manifest PreOpenAcc DelayedOpenAcc aenv s
pacc1) (Manifest PreOpenAcc DelayedOpenAcc aenv t
pacc2)
  = MatchAcc DelayedOpenAcc
-> PreOpenAcc DelayedOpenAcc aenv s
-> PreOpenAcc DelayedOpenAcc aenv t
-> Maybe (s :~: t)
forall (acc :: * -> * -> *) aenv s t.
HasArraysR acc =>
MatchAcc acc
-> PreOpenAcc acc aenv s
-> PreOpenAcc acc aenv t
-> Maybe (s :~: t)
matchPreOpenAcc DelayedOpenAcc aenv s -> DelayedOpenAcc aenv t -> Maybe (s :~: t)
MatchAcc DelayedOpenAcc
matchDelayedOpenAcc PreOpenAcc DelayedOpenAcc aenv s
pacc1 PreOpenAcc DelayedOpenAcc aenv t
pacc2
matchDelayedOpenAcc (Delayed ArrayR (Array sh e)
_ Exp aenv sh
sh1 Fun aenv (sh -> e)
ix1 Fun aenv (Int -> e)
lx1) (Delayed ArrayR (Array sh e)
_ Exp aenv sh
sh2 Fun aenv (sh -> e)
ix2 Fun aenv (Int -> e)
lx2)
  | Just sh :~: sh
Refl <- Exp aenv sh -> Exp aenv sh -> Maybe (sh :~: sh)
forall env aenv s t.
OpenExp env aenv s -> OpenExp env aenv t -> Maybe (s :~: t)
matchOpenExp Exp aenv sh
sh1 Exp aenv sh
sh2
  , Just (sh -> e) :~: (sh -> e)
Refl <- Fun aenv (sh -> e)
-> Fun aenv (sh -> e) -> Maybe ((sh -> e) :~: (sh -> e))
forall env aenv s t.
OpenFun env aenv s -> OpenFun env aenv t -> Maybe (s :~: t)
matchOpenFun Fun aenv (sh -> e)
ix1 Fun aenv (sh -> e)
ix2
  , Just (Int -> e) :~: (Int -> e)
Refl <- Fun aenv (Int -> e)
-> Fun aenv (Int -> e) -> Maybe ((Int -> e) :~: (Int -> e))
forall env aenv s t.
OpenFun env aenv s -> OpenFun env aenv t -> Maybe (s :~: t)
matchOpenFun Fun aenv (Int -> e)
lx1 Fun aenv (Int -> e)
lx2
  = (s :~: t) -> Maybe (s :~: t)
forall a. a -> Maybe a
Just s :~: s
s :~: t
forall {k} (a :: k). a :~: a
Refl
matchDelayedOpenAcc DelayedOpenAcc aenv s
_ DelayedOpenAcc aenv t
_
  = Maybe (s :~: t)
forall a. Maybe a
Nothing

rnfDelayedOpenAcc :: NFDataAcc DelayedOpenAcc
rnfDelayedOpenAcc :: NFDataAcc DelayedOpenAcc
rnfDelayedOpenAcc (Manifest PreOpenAcc DelayedOpenAcc aenv t
pacc) =
  NFDataAcc DelayedOpenAcc -> PreOpenAcc DelayedOpenAcc aenv t -> ()
forall (acc :: * -> * -> *) aenv t.
HasArraysR acc =>
NFDataAcc acc -> PreOpenAcc acc aenv t -> ()
rnfPreOpenAcc DelayedOpenAcc aenv t -> ()
NFDataAcc DelayedOpenAcc
rnfDelayedOpenAcc PreOpenAcc DelayedOpenAcc aenv t
pacc
rnfDelayedOpenAcc (Delayed ArrayR (Array sh e)
aR Exp aenv sh
sh Fun aenv (sh -> e)
ix Fun aenv (Int -> e)
lx) =
  ArrayR (Array sh e) -> ()
forall arr. ArrayR arr -> ()
rnfArrayR ArrayR (Array sh e)
aR () -> () -> ()
forall a b. a -> b -> b
`seq` Exp aenv sh -> ()
forall env aenv t. OpenExp env aenv t -> ()
rnfOpenExp Exp aenv sh
sh () -> () -> ()
forall a b. a -> b -> b
`seq` Fun aenv (sh -> e) -> ()
forall env aenv t. OpenFun env aenv t -> ()
rnfOpenFun Fun aenv (sh -> e)
ix () -> () -> ()
forall a b. a -> b -> b
`seq` Fun aenv (Int -> e) -> ()
forall env aenv t. OpenFun env aenv t -> ()
rnfOpenFun Fun aenv (Int -> e)
lx

liftDelayedOpenAcc :: LiftAcc DelayedOpenAcc
liftDelayedOpenAcc :: LiftAcc DelayedOpenAcc
liftDelayedOpenAcc (Manifest PreOpenAcc DelayedOpenAcc aenv a
pacc) =
  [|| PreOpenAcc DelayedOpenAcc aenv a -> DelayedOpenAcc aenv a
forall aenv a.
PreOpenAcc DelayedOpenAcc aenv a -> DelayedOpenAcc aenv a
Manifest $$(LiftAcc DelayedOpenAcc
-> PreOpenAcc DelayedOpenAcc aenv a
-> CodeQ (PreOpenAcc DelayedOpenAcc aenv a)
forall (acc :: * -> * -> *) aenv a.
HasArraysR acc =>
LiftAcc acc
-> PreOpenAcc acc aenv a -> CodeQ (PreOpenAcc acc aenv a)
liftPreOpenAcc DelayedOpenAcc aenv a -> CodeQ (DelayedOpenAcc aenv a)
LiftAcc DelayedOpenAcc
liftDelayedOpenAcc PreOpenAcc DelayedOpenAcc aenv a
pacc) ||]
liftDelayedOpenAcc (Delayed ArrayR (Array sh e)
aR Exp aenv sh
sh Fun aenv (sh -> e)
ix Fun aenv (Int -> e)
lx) =
  [|| ArrayR (Array sh e)
-> Exp aenv sh
-> Fun aenv (sh -> e)
-> Fun aenv (Int -> e)
-> DelayedOpenAcc aenv (Array sh e)
forall sh e aenv.
ArrayR (Array sh e)
-> Exp aenv sh
-> Fun aenv (sh -> e)
-> Fun aenv (Int -> e)
-> DelayedOpenAcc aenv (Array sh e)
Delayed $$(ArrayR (Array sh e) -> CodeQ (ArrayR (Array sh e))
forall a. ArrayR a -> CodeQ (ArrayR a)
liftArrayR ArrayR (Array sh e)
aR) $$(Exp aenv sh -> CodeQ (Exp aenv sh)
forall env aenv t. OpenExp env aenv t -> CodeQ (OpenExp env aenv t)
liftOpenExp Exp aenv sh
sh) $$(Fun aenv (sh -> e) -> CodeQ (Fun aenv (sh -> e))
forall env aenv t. OpenFun env aenv t -> CodeQ (OpenFun env aenv t)
liftOpenFun Fun aenv (sh -> e)
ix) $$(Fun aenv (Int -> e) -> CodeQ (Fun aenv (Int -> e))
forall env aenv t. OpenFun env aenv t -> CodeQ (OpenFun env aenv t)
liftOpenFun Fun aenv (Int -> e)
lx) ||]