{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE GeneralizedNewtypeDeriving #-}
{-# LANGUAGE OverloadedStrings #-}
module Futhark.Internalise.TypesValues
(
internaliseReturnType,
internaliseLambdaReturnType,
internaliseEntryReturnType,
internaliseType,
internaliseParamTypes,
internaliseLoopParamType,
internalisePrimType,
internalisedTypeSize,
internaliseSumType,
internalisePrimValue,
)
where
import Control.Monad.State
import Data.Bitraversable (bitraverse)
import Data.List (delete, find, foldl')
import qualified Data.Map.Strict as M
import Data.Maybe
import Futhark.IR.SOACS as I
import Futhark.Internalise.Monad
import qualified Language.Futhark as E
internaliseUniqueness :: E.Uniqueness -> I.Uniqueness
internaliseUniqueness :: Uniqueness -> Uniqueness
internaliseUniqueness Uniqueness
E.Nonunique = Uniqueness
I.Nonunique
internaliseUniqueness Uniqueness
E.Unique = Uniqueness
I.Unique
newtype TypeState = TypeState {TypeState -> Int
typeCounter :: Int}
newtype InternaliseTypeM a
= InternaliseTypeM (State TypeState a)
deriving (a -> InternaliseTypeM b -> InternaliseTypeM a
(a -> b) -> InternaliseTypeM a -> InternaliseTypeM b
(forall a b. (a -> b) -> InternaliseTypeM a -> InternaliseTypeM b)
-> (forall a b. a -> InternaliseTypeM b -> InternaliseTypeM a)
-> Functor InternaliseTypeM
forall a b. a -> InternaliseTypeM b -> InternaliseTypeM a
forall a b. (a -> b) -> InternaliseTypeM a -> InternaliseTypeM b
forall (f :: * -> *).
(forall a b. (a -> b) -> f a -> f b)
-> (forall a b. a -> f b -> f a) -> Functor f
<$ :: a -> InternaliseTypeM b -> InternaliseTypeM a
$c<$ :: forall a b. a -> InternaliseTypeM b -> InternaliseTypeM a
fmap :: (a -> b) -> InternaliseTypeM a -> InternaliseTypeM b
$cfmap :: forall a b. (a -> b) -> InternaliseTypeM a -> InternaliseTypeM b
Functor, Functor InternaliseTypeM
a -> InternaliseTypeM a
Functor InternaliseTypeM
-> (forall a. a -> InternaliseTypeM a)
-> (forall a b.
InternaliseTypeM (a -> b)
-> InternaliseTypeM a -> InternaliseTypeM b)
-> (forall a b c.
(a -> b -> c)
-> InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM c)
-> (forall a b.
InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM b)
-> (forall a b.
InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM a)
-> Applicative InternaliseTypeM
InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM b
InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM a
InternaliseTypeM (a -> b)
-> InternaliseTypeM a -> InternaliseTypeM b
(a -> b -> c)
-> InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM c
forall a. a -> InternaliseTypeM a
forall a b.
InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM a
forall a b.
InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM b
forall a b.
InternaliseTypeM (a -> b)
-> InternaliseTypeM a -> InternaliseTypeM b
forall a b c.
(a -> b -> c)
-> InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM c
forall (f :: * -> *).
Functor f
-> (forall a. a -> f a)
-> (forall a b. f (a -> b) -> f a -> f b)
-> (forall a b c. (a -> b -> c) -> f a -> f b -> f c)
-> (forall a b. f a -> f b -> f b)
-> (forall a b. f a -> f b -> f a)
-> Applicative f
<* :: InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM a
$c<* :: forall a b.
InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM a
*> :: InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM b
$c*> :: forall a b.
InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM b
liftA2 :: (a -> b -> c)
-> InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM c
$cliftA2 :: forall a b c.
(a -> b -> c)
-> InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM c
<*> :: InternaliseTypeM (a -> b)
-> InternaliseTypeM a -> InternaliseTypeM b
$c<*> :: forall a b.
InternaliseTypeM (a -> b)
-> InternaliseTypeM a -> InternaliseTypeM b
pure :: a -> InternaliseTypeM a
$cpure :: forall a. a -> InternaliseTypeM a
$cp1Applicative :: Functor InternaliseTypeM
Applicative, Applicative InternaliseTypeM
a -> InternaliseTypeM a
Applicative InternaliseTypeM
-> (forall a b.
InternaliseTypeM a
-> (a -> InternaliseTypeM b) -> InternaliseTypeM b)
-> (forall a b.
InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM b)
-> (forall a. a -> InternaliseTypeM a)
-> Monad InternaliseTypeM
InternaliseTypeM a
-> (a -> InternaliseTypeM b) -> InternaliseTypeM b
InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM b
forall a. a -> InternaliseTypeM a
forall a b.
InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM b
forall a b.
InternaliseTypeM a
-> (a -> InternaliseTypeM b) -> InternaliseTypeM b
forall (m :: * -> *).
Applicative m
-> (forall a b. m a -> (a -> m b) -> m b)
-> (forall a b. m a -> m b -> m b)
-> (forall a. a -> m a)
-> Monad m
return :: a -> InternaliseTypeM a
$creturn :: forall a. a -> InternaliseTypeM a
>> :: InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM b
$c>> :: forall a b.
InternaliseTypeM a -> InternaliseTypeM b -> InternaliseTypeM b
>>= :: InternaliseTypeM a
-> (a -> InternaliseTypeM b) -> InternaliseTypeM b
$c>>= :: forall a b.
InternaliseTypeM a
-> (a -> InternaliseTypeM b) -> InternaliseTypeM b
$cp1Monad :: Applicative InternaliseTypeM
Monad, MonadState TypeState)
runInternaliseTypeM :: InternaliseTypeM a -> a
runInternaliseTypeM :: InternaliseTypeM a -> a
runInternaliseTypeM = [VName] -> InternaliseTypeM a -> a
forall a. [VName] -> InternaliseTypeM a -> a
runInternaliseTypeM' [VName]
forall a. Monoid a => a
mempty
runInternaliseTypeM' :: [VName] -> InternaliseTypeM a -> a
runInternaliseTypeM' :: [VName] -> InternaliseTypeM a -> a
runInternaliseTypeM' [VName]
exts (InternaliseTypeM State TypeState a
m) = State TypeState a -> TypeState -> a
forall s a. State s a -> s -> a
evalState State TypeState a
m (TypeState -> a) -> TypeState -> a
forall a b. (a -> b) -> a -> b
$ Int -> TypeState
TypeState ([VName] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [VName]
exts)
internaliseParamTypes ::
[E.TypeBase E.Size ()] ->
InternaliseM [[I.TypeBase Shape Uniqueness]]
internaliseParamTypes :: [TypeBase Size ()] -> InternaliseM [[TypeBase Shape Uniqueness]]
internaliseParamTypes [TypeBase Size ()]
ts =
([TypeBase Shape Uniqueness]
-> InternaliseM [TypeBase Shape Uniqueness])
-> [[TypeBase Shape Uniqueness]]
-> InternaliseM [[TypeBase Shape Uniqueness]]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
mapM ((TypeBase Shape Uniqueness
-> InternaliseM (TypeBase Shape Uniqueness))
-> [TypeBase Shape Uniqueness]
-> InternaliseM [TypeBase Shape Uniqueness]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
mapM TypeBase Shape Uniqueness
-> InternaliseM (TypeBase Shape Uniqueness)
forall shape u. TypeBase shape u -> InternaliseM (TypeBase shape u)
mkAccCerts) ([[TypeBase Shape Uniqueness]]
-> InternaliseM [[TypeBase Shape Uniqueness]])
-> (InternaliseTypeM [[TypeBase Shape Uniqueness]]
-> [[TypeBase Shape Uniqueness]])
-> InternaliseTypeM [[TypeBase Shape Uniqueness]]
-> InternaliseM [[TypeBase Shape Uniqueness]]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. InternaliseTypeM [[TypeBase Shape Uniqueness]]
-> [[TypeBase Shape Uniqueness]]
forall a. InternaliseTypeM a -> a
runInternaliseTypeM (InternaliseTypeM [[TypeBase Shape Uniqueness]]
-> InternaliseM [[TypeBase Shape Uniqueness]])
-> InternaliseTypeM [[TypeBase Shape Uniqueness]]
-> InternaliseM [[TypeBase Shape Uniqueness]]
forall a b. (a -> b) -> a -> b
$
(TypeBase Size () -> InternaliseTypeM [TypeBase Shape Uniqueness])
-> [TypeBase Size ()]
-> InternaliseTypeM [[TypeBase Shape Uniqueness]]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
mapM (([TypeBase ExtShape Uniqueness] -> [TypeBase Shape Uniqueness])
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
-> InternaliseTypeM [TypeBase Shape Uniqueness]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((TypeBase ExtShape Uniqueness -> TypeBase Shape Uniqueness)
-> [TypeBase ExtShape Uniqueness] -> [TypeBase Shape Uniqueness]
forall a b. (a -> b) -> [a] -> [b]
map TypeBase ExtShape Uniqueness -> TypeBase Shape Uniqueness
forall u. TypeBase ExtShape u -> TypeBase Shape u
onType) (InternaliseTypeM [TypeBase ExtShape Uniqueness]
-> InternaliseTypeM [TypeBase Shape Uniqueness])
-> (TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> TypeBase Size ()
-> InternaliseTypeM [TypeBase Shape Uniqueness]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Map VName Int
-> TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
internaliseTypeM Map VName Int
forall a. Monoid a => a
mempty) [TypeBase Size ()]
ts
where
onType :: TypeBase ExtShape u -> TypeBase Shape u
onType = TypeBase Shape u -> Maybe (TypeBase Shape u) -> TypeBase Shape u
forall a. a -> Maybe a -> a
fromMaybe TypeBase Shape u
forall a. a
bad (Maybe (TypeBase Shape u) -> TypeBase Shape u)
-> (TypeBase ExtShape u -> Maybe (TypeBase Shape u))
-> TypeBase ExtShape u
-> TypeBase Shape u
forall b c a. (b -> c) -> (a -> b) -> a -> c
. TypeBase ExtShape u -> Maybe (TypeBase Shape u)
forall u. TypeBase ExtShape u -> Maybe (TypeBase Shape u)
hasStaticShape
bad :: a
bad = [Char] -> a
forall a. HasCallStack => [Char] -> a
error ([Char] -> a) -> [Char] -> a
forall a b. (a -> b) -> a -> b
$ [Char]
"internaliseParamTypes: " [Char] -> [Char] -> [Char]
forall a. [a] -> [a] -> [a]
++ [TypeBase Size ()] -> [Char]
forall a. Pretty a => a -> [Char]
pretty [TypeBase Size ()]
ts
fixupKnownTypes :: [TypeBase shape1 u1] -> [TypeBase shape2 u2] -> [TypeBase shape2 u2]
fixupKnownTypes :: [TypeBase shape1 u1]
-> [TypeBase shape2 u2] -> [TypeBase shape2 u2]
fixupKnownTypes = (TypeBase shape1 u1 -> TypeBase shape2 u2 -> TypeBase shape2 u2)
-> [TypeBase shape1 u1]
-> [TypeBase shape2 u2]
-> [TypeBase shape2 u2]
forall a b c. (a -> b -> c) -> [a] -> [b] -> [c]
zipWith TypeBase shape1 u1 -> TypeBase shape2 u2 -> TypeBase shape2 u2
forall shape u shape u.
TypeBase shape u -> TypeBase shape u -> TypeBase shape u
fixup
where
fixup :: TypeBase shape u -> TypeBase shape u -> TypeBase shape u
fixup (Acc VName
acc Shape
ispace [Type]
ts u
_) (Acc VName
_ Shape
_ [Type]
_ u
u2) = VName -> Shape -> [Type] -> u -> TypeBase shape u
forall shape u. VName -> Shape -> [Type] -> u -> TypeBase shape u
Acc VName
acc Shape
ispace [Type]
ts u
u2
fixup TypeBase shape u
_ TypeBase shape u
t = TypeBase shape u
t
mkAccCerts :: TypeBase shape u -> InternaliseM (TypeBase shape u)
mkAccCerts :: TypeBase shape u -> InternaliseM (TypeBase shape u)
mkAccCerts (Array PrimType
pt shape
shape u
u) =
TypeBase shape u -> InternaliseM (TypeBase shape u)
forall (f :: * -> *) a. Applicative f => a -> f a
pure (TypeBase shape u -> InternaliseM (TypeBase shape u))
-> TypeBase shape u -> InternaliseM (TypeBase shape u)
forall a b. (a -> b) -> a -> b
$ PrimType -> shape -> u -> TypeBase shape u
forall shape u. PrimType -> shape -> u -> TypeBase shape u
Array PrimType
pt shape
shape u
u
mkAccCerts (Acc VName
c Shape
shape [Type]
ts u
u) =
VName -> Shape -> [Type] -> u -> TypeBase shape u
forall shape u. VName -> Shape -> [Type] -> u -> TypeBase shape u
Acc (VName -> Shape -> [Type] -> u -> TypeBase shape u)
-> InternaliseM VName
-> InternaliseM (Shape -> [Type] -> u -> TypeBase shape u)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> InternaliseM VName
c' InternaliseM (Shape -> [Type] -> u -> TypeBase shape u)
-> InternaliseM Shape
-> InternaliseM ([Type] -> u -> TypeBase shape u)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Shape -> InternaliseM Shape
forall (f :: * -> *) a. Applicative f => a -> f a
pure Shape
shape InternaliseM ([Type] -> u -> TypeBase shape u)
-> InternaliseM [Type] -> InternaliseM (u -> TypeBase shape u)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> [Type] -> InternaliseM [Type]
forall (f :: * -> *) a. Applicative f => a -> f a
pure [Type]
ts InternaliseM (u -> TypeBase shape u)
-> InternaliseM u -> InternaliseM (TypeBase shape u)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> u -> InternaliseM u
forall (f :: * -> *) a. Applicative f => a -> f a
pure u
u
where
c' :: InternaliseM VName
c'
| VName -> Int
baseTag VName
c Int -> Int -> Bool
forall a. Eq a => a -> a -> Bool
== Int
0 = [Char] -> InternaliseM VName
forall (m :: * -> *). MonadFreshNames m => [Char] -> m VName
newVName [Char]
"acc_cert"
| Bool
otherwise = VName -> InternaliseM VName
forall (f :: * -> *) a. Applicative f => a -> f a
pure VName
c
mkAccCerts TypeBase shape u
t = TypeBase shape u -> InternaliseM (TypeBase shape u)
forall (f :: * -> *) a. Applicative f => a -> f a
pure TypeBase shape u
t
internaliseLoopParamType ::
E.TypeBase E.Size () ->
[TypeBase shape u] ->
InternaliseM [I.TypeBase Shape Uniqueness]
internaliseLoopParamType :: TypeBase Size ()
-> [TypeBase shape u] -> InternaliseM [TypeBase Shape Uniqueness]
internaliseLoopParamType TypeBase Size ()
et [TypeBase shape u]
ts =
[TypeBase shape u]
-> [TypeBase Shape Uniqueness] -> [TypeBase Shape Uniqueness]
forall shape1 u1 shape2 u2.
[TypeBase shape1 u1]
-> [TypeBase shape2 u2] -> [TypeBase shape2 u2]
fixupKnownTypes [TypeBase shape u]
ts ([TypeBase Shape Uniqueness] -> [TypeBase Shape Uniqueness])
-> ([[TypeBase Shape Uniqueness]] -> [TypeBase Shape Uniqueness])
-> [[TypeBase Shape Uniqueness]]
-> [TypeBase Shape Uniqueness]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. [[TypeBase Shape Uniqueness]] -> [TypeBase Shape Uniqueness]
forall (t :: * -> *) a. Foldable t => t [a] -> [a]
concat ([[TypeBase Shape Uniqueness]] -> [TypeBase Shape Uniqueness])
-> InternaliseM [[TypeBase Shape Uniqueness]]
-> InternaliseM [TypeBase Shape Uniqueness]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> [TypeBase Size ()] -> InternaliseM [[TypeBase Shape Uniqueness]]
internaliseParamTypes [TypeBase Size ()
et]
internaliseReturnType ::
E.StructRetType ->
[TypeBase shape u] ->
[I.TypeBase ExtShape Uniqueness]
internaliseReturnType :: StructRetType
-> [TypeBase shape u] -> [TypeBase ExtShape Uniqueness]
internaliseReturnType (E.RetType [VName]
dims TypeBase Size ()
et) [TypeBase shape u]
ts =
[TypeBase shape u]
-> [TypeBase ExtShape Uniqueness] -> [TypeBase ExtShape Uniqueness]
forall shape1 u1 shape2 u2.
[TypeBase shape1 u1]
-> [TypeBase shape2 u2] -> [TypeBase shape2 u2]
fixupKnownTypes [TypeBase shape u]
ts ([TypeBase ExtShape Uniqueness] -> [TypeBase ExtShape Uniqueness])
-> [TypeBase ExtShape Uniqueness] -> [TypeBase ExtShape Uniqueness]
forall a b. (a -> b) -> a -> b
$ [VName]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
-> [TypeBase ExtShape Uniqueness]
forall a. [VName] -> InternaliseTypeM a -> a
runInternaliseTypeM' [VName]
dims (Map VName Int
-> TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
internaliseTypeM Map VName Int
exts TypeBase Size ()
et)
where
exts :: Map VName Int
exts = [(VName, Int)] -> Map VName Int
forall k a. Ord k => [(k, a)] -> Map k a
M.fromList ([(VName, Int)] -> Map VName Int)
-> [(VName, Int)] -> Map VName Int
forall a b. (a -> b) -> a -> b
$ [VName] -> [Int] -> [(VName, Int)]
forall a b. [a] -> [b] -> [(a, b)]
zip [VName]
dims [Int
0 ..]
internaliseLambdaReturnType ::
E.TypeBase E.Size () ->
[TypeBase shape u] ->
InternaliseM [I.TypeBase Shape NoUniqueness]
internaliseLambdaReturnType :: TypeBase Size () -> [TypeBase shape u] -> InternaliseM [Type]
internaliseLambdaReturnType TypeBase Size ()
et [TypeBase shape u]
ts =
(TypeBase Shape Uniqueness -> Type)
-> [TypeBase Shape Uniqueness] -> [Type]
forall a b. (a -> b) -> [a] -> [b]
map TypeBase Shape Uniqueness -> Type
forall shape.
TypeBase shape Uniqueness -> TypeBase shape NoUniqueness
fromDecl ([TypeBase Shape Uniqueness] -> [Type])
-> InternaliseM [TypeBase Shape Uniqueness] -> InternaliseM [Type]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> TypeBase Size ()
-> [TypeBase shape u] -> InternaliseM [TypeBase Shape Uniqueness]
forall shape u.
TypeBase Size ()
-> [TypeBase shape u] -> InternaliseM [TypeBase Shape Uniqueness]
internaliseLoopParamType TypeBase Size ()
et [TypeBase shape u]
ts
internaliseEntryReturnType ::
E.StructRetType ->
[[I.TypeBase ExtShape Uniqueness]]
internaliseEntryReturnType :: StructRetType -> [[TypeBase ExtShape Uniqueness]]
internaliseEntryReturnType (E.RetType [VName]
dims TypeBase Size ()
et) =
[VName]
-> InternaliseTypeM [[TypeBase ExtShape Uniqueness]]
-> [[TypeBase ExtShape Uniqueness]]
forall a. [VName] -> InternaliseTypeM a -> a
runInternaliseTypeM' [VName]
dims (InternaliseTypeM [[TypeBase ExtShape Uniqueness]]
-> [[TypeBase ExtShape Uniqueness]])
-> ([TypeBase Size ()]
-> InternaliseTypeM [[TypeBase ExtShape Uniqueness]])
-> [TypeBase Size ()]
-> [[TypeBase ExtShape Uniqueness]]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> [TypeBase Size ()]
-> InternaliseTypeM [[TypeBase ExtShape Uniqueness]]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
mapM (Map VName Int
-> TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
internaliseTypeM Map VName Int
exts) ([TypeBase Size ()] -> [[TypeBase ExtShape Uniqueness]])
-> [TypeBase Size ()] -> [[TypeBase ExtShape Uniqueness]]
forall a b. (a -> b) -> a -> b
$
case TypeBase Size () -> Maybe [TypeBase Size ()]
forall dim as. TypeBase dim as -> Maybe [TypeBase dim as]
E.isTupleRecord TypeBase Size ()
et of
Just [TypeBase Size ()]
ets | Bool -> Bool
not (Bool -> Bool) -> Bool -> Bool
forall a b. (a -> b) -> a -> b
$ [TypeBase Size ()] -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null [TypeBase Size ()]
ets -> [TypeBase Size ()]
ets
Maybe [TypeBase Size ()]
_ -> [TypeBase Size ()
et]
where
exts :: Map VName Int
exts = [(VName, Int)] -> Map VName Int
forall k a. Ord k => [(k, a)] -> Map k a
M.fromList ([(VName, Int)] -> Map VName Int)
-> [(VName, Int)] -> Map VName Int
forall a b. (a -> b) -> a -> b
$ [VName] -> [Int] -> [(VName, Int)]
forall a b. [a] -> [b] -> [(a, b)]
zip [VName]
dims [Int
0 ..]
internaliseType ::
E.TypeBase E.Size () ->
[I.TypeBase I.ExtShape Uniqueness]
internaliseType :: TypeBase Size () -> [TypeBase ExtShape Uniqueness]
internaliseType = InternaliseTypeM [TypeBase ExtShape Uniqueness]
-> [TypeBase ExtShape Uniqueness]
forall a. InternaliseTypeM a -> a
runInternaliseTypeM (InternaliseTypeM [TypeBase ExtShape Uniqueness]
-> [TypeBase ExtShape Uniqueness])
-> (TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> TypeBase Size ()
-> [TypeBase ExtShape Uniqueness]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Map VName Int
-> TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
internaliseTypeM Map VName Int
forall a. Monoid a => a
mempty
newId :: InternaliseTypeM Int
newId :: InternaliseTypeM Int
newId = do
Int
i <- (TypeState -> Int) -> InternaliseTypeM Int
forall s (m :: * -> *) a. MonadState s m => (s -> a) -> m a
gets TypeState -> Int
typeCounter
(TypeState -> TypeState) -> InternaliseTypeM ()
forall s (m :: * -> *). MonadState s m => (s -> s) -> m ()
modify ((TypeState -> TypeState) -> InternaliseTypeM ())
-> (TypeState -> TypeState) -> InternaliseTypeM ()
forall a b. (a -> b) -> a -> b
$ \TypeState
s -> TypeState
s {typeCounter :: Int
typeCounter = Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
1}
Int -> InternaliseTypeM Int
forall (f :: * -> *) a. Applicative f => a -> f a
pure Int
i
internaliseDim ::
M.Map VName Int ->
E.Size ->
InternaliseTypeM ExtSize
internaliseDim :: Map VName Int -> Size -> InternaliseTypeM ExtSize
internaliseDim Map VName Int
exts Size
d =
case Size
d of
E.AnySize Maybe VName
_ -> Int -> ExtSize
forall a. Int -> Ext a
Ext (Int -> ExtSize)
-> InternaliseTypeM Int -> InternaliseTypeM ExtSize
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> InternaliseTypeM Int
newId
E.ConstSize Int
n -> ExtSize -> InternaliseTypeM ExtSize
forall (f :: * -> *) a. Applicative f => a -> f a
pure (ExtSize -> InternaliseTypeM ExtSize)
-> ExtSize -> InternaliseTypeM ExtSize
forall a b. (a -> b) -> a -> b
$ SubExp -> ExtSize
forall a. a -> Ext a
Free (SubExp -> ExtSize) -> SubExp -> ExtSize
forall a b. (a -> b) -> a -> b
$ IntType -> Integer -> SubExp
intConst IntType
I.Int64 (Integer -> SubExp) -> Integer -> SubExp
forall a b. (a -> b) -> a -> b
$ Int -> Integer
forall a. Integral a => a -> Integer
toInteger Int
n
E.NamedSize QualName VName
name -> ExtSize -> InternaliseTypeM ExtSize
forall (f :: * -> *) a. Applicative f => a -> f a
pure (ExtSize -> InternaliseTypeM ExtSize)
-> ExtSize -> InternaliseTypeM ExtSize
forall a b. (a -> b) -> a -> b
$ QualName VName -> ExtSize
namedDim QualName VName
name
where
namedDim :: QualName VName -> ExtSize
namedDim (E.QualName [VName]
_ VName
name)
| Just Int
x <- VName
name VName -> Map VName Int -> Maybe Int
forall k a. Ord k => k -> Map k a -> Maybe a
`M.lookup` Map VName Int
exts = Int -> ExtSize
forall a. Int -> Ext a
I.Ext Int
x
| Bool
otherwise = SubExp -> ExtSize
forall a. a -> Ext a
I.Free (SubExp -> ExtSize) -> SubExp -> ExtSize
forall a b. (a -> b) -> a -> b
$ VName -> SubExp
I.Var VName
name
internaliseTypeM ::
M.Map VName Int ->
E.StructType ->
InternaliseTypeM [I.TypeBase ExtShape Uniqueness]
internaliseTypeM :: Map VName Int
-> TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
internaliseTypeM Map VName Int
exts TypeBase Size ()
orig_t =
case TypeBase Size ()
orig_t of
E.Array ()
_ Uniqueness
u Shape Size
shape ScalarTypeBase Size ()
et -> do
[ExtSize]
dims <- Shape Size -> InternaliseTypeM [ExtSize]
internaliseShape Shape Size
shape
[TypeBase ExtShape Uniqueness]
ets <- Map VName Int
-> TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
internaliseTypeM Map VName Int
exts (TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall a b. (a -> b) -> a -> b
$ ScalarTypeBase Size () -> TypeBase Size ()
forall dim as. ScalarTypeBase dim as -> TypeBase dim as
E.Scalar ScalarTypeBase Size ()
et
[TypeBase ExtShape Uniqueness]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall (f :: * -> *) a. Applicative f => a -> f a
pure [TypeBase ExtShape Uniqueness
-> ExtShape -> Uniqueness -> TypeBase ExtShape Uniqueness
forall shape u_unused u.
ArrayShape shape =>
TypeBase shape u_unused -> shape -> u -> TypeBase shape u
I.arrayOf TypeBase ExtShape Uniqueness
et' ([ExtSize] -> ExtShape
forall d. [d] -> ShapeBase d
Shape [ExtSize]
dims) (Uniqueness -> TypeBase ExtShape Uniqueness)
-> Uniqueness -> TypeBase ExtShape Uniqueness
forall a b. (a -> b) -> a -> b
$ Uniqueness -> Uniqueness
internaliseUniqueness Uniqueness
u | TypeBase ExtShape Uniqueness
et' <- [TypeBase ExtShape Uniqueness]
ets]
E.Scalar (E.Prim PrimType
bt) ->
[TypeBase ExtShape Uniqueness]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall (f :: * -> *) a. Applicative f => a -> f a
pure [PrimType -> TypeBase ExtShape Uniqueness
forall shape u. PrimType -> TypeBase shape u
I.Prim (PrimType -> TypeBase ExtShape Uniqueness)
-> PrimType -> TypeBase ExtShape Uniqueness
forall a b. (a -> b) -> a -> b
$ PrimType -> PrimType
internalisePrimType PrimType
bt]
E.Scalar (E.Record Map Name (TypeBase Size ())
ets)
| Map Name (TypeBase Size ()) -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null Map Name (TypeBase Size ())
ets -> [TypeBase ExtShape Uniqueness]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall (f :: * -> *) a. Applicative f => a -> f a
pure [PrimType -> TypeBase ExtShape Uniqueness
forall shape u. PrimType -> TypeBase shape u
I.Prim PrimType
I.Unit]
| Bool
otherwise ->
[[TypeBase ExtShape Uniqueness]] -> [TypeBase ExtShape Uniqueness]
forall (t :: * -> *) a. Foldable t => t [a] -> [a]
concat ([[TypeBase ExtShape Uniqueness]]
-> [TypeBase ExtShape Uniqueness])
-> InternaliseTypeM [[TypeBase ExtShape Uniqueness]]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> ((Name, TypeBase Size ())
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> [(Name, TypeBase Size ())]
-> InternaliseTypeM [[TypeBase ExtShape Uniqueness]]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
mapM (Map VName Int
-> TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
internaliseTypeM Map VName Int
exts (TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> ((Name, TypeBase Size ()) -> TypeBase Size ())
-> (Name, TypeBase Size ())
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Name, TypeBase Size ()) -> TypeBase Size ()
forall a b. (a, b) -> b
snd) (Map Name (TypeBase Size ()) -> [(Name, TypeBase Size ())]
forall a. Map Name a -> [(Name, a)]
E.sortFields Map Name (TypeBase Size ())
ets)
E.Scalar (E.TypeVar ()
_ Uniqueness
u QualName VName
tn [E.TypeArgType TypeBase Size ()
arr_t SrcLoc
_])
| VName -> Int
baseTag (QualName VName -> VName
forall vn. QualName vn -> vn
E.qualLeaf QualName VName
tn) Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
<= Int
E.maxIntrinsicTag,
VName -> [Char]
baseString (QualName VName -> VName
forall vn. QualName vn -> vn
E.qualLeaf QualName VName
tn) [Char] -> [Char] -> Bool
forall a. Eq a => a -> a -> Bool
== [Char]
"acc" -> do
[Type]
ts <- (TypeBase ExtShape Uniqueness -> Type)
-> [TypeBase ExtShape Uniqueness] -> [Type]
forall a b. (a -> b) -> [a] -> [b]
map (TypeBase Shape Uniqueness -> Type
forall shape.
TypeBase shape Uniqueness -> TypeBase shape NoUniqueness
fromDecl (TypeBase Shape Uniqueness -> Type)
-> (TypeBase ExtShape Uniqueness -> TypeBase Shape Uniqueness)
-> TypeBase ExtShape Uniqueness
-> Type
forall b c a. (b -> c) -> (a -> b) -> a -> c
. TypeBase ExtShape Uniqueness -> TypeBase Shape Uniqueness
forall u. TypeBase ExtShape u -> TypeBase Shape u
onAccType) ([TypeBase ExtShape Uniqueness] -> [Type])
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
-> InternaliseTypeM [Type]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Map VName Int
-> TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
internaliseTypeM Map VName Int
exts TypeBase Size ()
arr_t
let acc_param :: VName
acc_param = Name -> Int -> VName
VName Name
"PLACEHOLDER" Int
0
acc_t :: TypeBase shape Uniqueness
acc_t = VName -> Shape -> [Type] -> Uniqueness -> TypeBase shape Uniqueness
forall shape u. VName -> Shape -> [Type] -> u -> TypeBase shape u
Acc VName
acc_param ([SubExp] -> Shape
forall d. [d] -> ShapeBase d
Shape [Int -> [Type] -> SubExp
forall u. Int -> [TypeBase Shape u] -> SubExp
arraysSize Int
0 [Type]
ts]) ((Type -> Type) -> [Type] -> [Type]
forall a b. (a -> b) -> [a] -> [b]
map Type -> Type
forall u. TypeBase Shape u -> TypeBase Shape u
rowType [Type]
ts) (Uniqueness -> TypeBase shape Uniqueness)
-> Uniqueness -> TypeBase shape Uniqueness
forall a b. (a -> b) -> a -> b
$ Uniqueness -> Uniqueness
internaliseUniqueness Uniqueness
u
[TypeBase ExtShape Uniqueness]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall (f :: * -> *) a. Applicative f => a -> f a
pure [TypeBase ExtShape Uniqueness
forall shape. TypeBase shape Uniqueness
acc_t]
E.Scalar E.TypeVar {} ->
[Char] -> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall a. HasCallStack => [Char] -> a
error ([Char] -> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> [Char] -> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall a b. (a -> b) -> a -> b
$ [Char]
"internaliseTypeM: cannot handle type variable: " [Char] -> [Char] -> [Char]
forall a. [a] -> [a] -> [a]
++ TypeBase Size () -> [Char]
forall a. Pretty a => a -> [Char]
pretty TypeBase Size ()
orig_t
E.Scalar E.Arrow {} ->
[Char] -> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall a. HasCallStack => [Char] -> a
error ([Char] -> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> [Char] -> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall a b. (a -> b) -> a -> b
$ [Char]
"internaliseTypeM: cannot handle function type: " [Char] -> [Char] -> [Char]
forall a. [a] -> [a] -> [a]
++ TypeBase Size () -> [Char]
forall a. Pretty a => a -> [Char]
pretty TypeBase Size ()
orig_t
E.Scalar (E.Sum Map Name [TypeBase Size ()]
cs) -> do
([TypeBase ExtShape Uniqueness]
ts, Map Name (Int, [Int])
_) <-
Map Name [TypeBase ExtShape Uniqueness]
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
internaliseConstructors
(Map Name [TypeBase ExtShape Uniqueness]
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int])))
-> InternaliseTypeM (Map Name [TypeBase ExtShape Uniqueness])
-> InternaliseTypeM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> ([TypeBase Size ()]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> Map Name [TypeBase Size ()]
-> InternaliseTypeM (Map Name [TypeBase ExtShape Uniqueness])
forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
traverse (([[TypeBase ExtShape Uniqueness]]
-> [TypeBase ExtShape Uniqueness])
-> InternaliseTypeM [[TypeBase ExtShape Uniqueness]]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap [[TypeBase ExtShape Uniqueness]] -> [TypeBase ExtShape Uniqueness]
forall (t :: * -> *) a. Foldable t => t [a] -> [a]
concat (InternaliseTypeM [[TypeBase ExtShape Uniqueness]]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> ([TypeBase Size ()]
-> InternaliseTypeM [[TypeBase ExtShape Uniqueness]])
-> [TypeBase Size ()]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> [TypeBase Size ()]
-> InternaliseTypeM [[TypeBase ExtShape Uniqueness]]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
mapM (Map VName Int
-> TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
internaliseTypeM Map VName Int
exts)) Map Name [TypeBase Size ()]
cs
[TypeBase ExtShape Uniqueness]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall (f :: * -> *) a. Applicative f => a -> f a
pure ([TypeBase ExtShape Uniqueness]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> [TypeBase ExtShape Uniqueness]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall a b. (a -> b) -> a -> b
$ PrimType -> TypeBase ExtShape Uniqueness
forall shape u. PrimType -> TypeBase shape u
I.Prim (IntType -> PrimType
I.IntType IntType
I.Int8) TypeBase ExtShape Uniqueness
-> [TypeBase ExtShape Uniqueness] -> [TypeBase ExtShape Uniqueness]
forall a. a -> [a] -> [a]
: [TypeBase ExtShape Uniqueness]
ts
where
internaliseShape :: Shape Size -> InternaliseTypeM [ExtSize]
internaliseShape = (Size -> InternaliseTypeM ExtSize)
-> [Size] -> InternaliseTypeM [ExtSize]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
mapM (Map VName Int -> Size -> InternaliseTypeM ExtSize
internaliseDim Map VName Int
exts) ([Size] -> InternaliseTypeM [ExtSize])
-> (Shape Size -> [Size])
-> Shape Size
-> InternaliseTypeM [ExtSize]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Shape Size -> [Size]
forall dim. Shape dim -> [dim]
E.shapeDims
onAccType :: TypeBase ExtShape u -> TypeBase Shape u
onAccType = TypeBase Shape u -> Maybe (TypeBase Shape u) -> TypeBase Shape u
forall a. a -> Maybe a -> a
fromMaybe TypeBase Shape u
forall a. a
bad (Maybe (TypeBase Shape u) -> TypeBase Shape u)
-> (TypeBase ExtShape u -> Maybe (TypeBase Shape u))
-> TypeBase ExtShape u
-> TypeBase Shape u
forall b c a. (b -> c) -> (a -> b) -> a -> c
. TypeBase ExtShape u -> Maybe (TypeBase Shape u)
forall u. TypeBase ExtShape u -> Maybe (TypeBase Shape u)
hasStaticShape
bad :: a
bad = [Char] -> a
forall a. HasCallStack => [Char] -> a
error ([Char] -> a) -> [Char] -> a
forall a b. (a -> b) -> a -> b
$ [Char]
"internaliseTypeM Acc: " [Char] -> [Char] -> [Char]
forall a. [a] -> [a] -> [a]
++ TypeBase Size () -> [Char]
forall a. Pretty a => a -> [Char]
pretty TypeBase Size ()
orig_t
internaliseConstructors ::
M.Map Name [I.TypeBase ExtShape Uniqueness] ->
( [I.TypeBase ExtShape Uniqueness],
M.Map Name (Int, [Int])
)
internaliseConstructors :: Map Name [TypeBase ExtShape Uniqueness]
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
internaliseConstructors Map Name [TypeBase ExtShape Uniqueness]
cs =
(([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
-> ((Name, [TypeBase ExtShape Uniqueness]), Int)
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int])))
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
-> [((Name, [TypeBase ExtShape Uniqueness]), Int)]
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
forall (t :: * -> *) b a.
Foldable t =>
(b -> a -> b) -> b -> t a -> b
foldl' ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
-> ((Name, [TypeBase ExtShape Uniqueness]), Int)
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
forall k (t :: * -> *) shape a.
(Ord k, Foldable t, Eq shape) =>
([TypeBase shape Uniqueness], Map k (a, [Int]))
-> ((k, t (TypeBase shape Uniqueness)), a)
-> ([TypeBase shape Uniqueness], Map k (a, [Int]))
onConstructor ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
forall a. Monoid a => a
mempty ([((Name, [TypeBase ExtShape Uniqueness]), Int)]
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int])))
-> [((Name, [TypeBase ExtShape Uniqueness]), Int)]
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
forall a b. (a -> b) -> a -> b
$ [(Name, [TypeBase ExtShape Uniqueness])]
-> [Int] -> [((Name, [TypeBase ExtShape Uniqueness]), Int)]
forall a b. [a] -> [b] -> [(a, b)]
zip (Map Name [TypeBase ExtShape Uniqueness]
-> [(Name, [TypeBase ExtShape Uniqueness])]
forall a. Map Name a -> [(Name, a)]
E.sortConstrs Map Name [TypeBase ExtShape Uniqueness]
cs) [Int
0 ..]
where
onConstructor :: ([TypeBase shape Uniqueness], Map k (a, [Int]))
-> ((k, t (TypeBase shape Uniqueness)), a)
-> ([TypeBase shape Uniqueness], Map k (a, [Int]))
onConstructor ([TypeBase shape Uniqueness]
ts, Map k (a, [Int])
mapping) ((k
c, t (TypeBase shape Uniqueness)
c_ts), a
i) =
let ([(TypeBase shape NoUniqueness, Int)]
_, [Int]
js, [TypeBase shape Uniqueness]
new_ts) =
(([(TypeBase shape NoUniqueness, Int)], [Int],
[TypeBase shape Uniqueness])
-> TypeBase shape Uniqueness
-> ([(TypeBase shape NoUniqueness, Int)], [Int],
[TypeBase shape Uniqueness]))
-> ([(TypeBase shape NoUniqueness, Int)], [Int],
[TypeBase shape Uniqueness])
-> t (TypeBase shape Uniqueness)
-> ([(TypeBase shape NoUniqueness, Int)], [Int],
[TypeBase shape Uniqueness])
forall (t :: * -> *) b a.
Foldable t =>
(b -> a -> b) -> b -> t a -> b
foldl' ([(TypeBase shape NoUniqueness, Int)], [Int],
[TypeBase shape Uniqueness])
-> TypeBase shape Uniqueness
-> ([(TypeBase shape NoUniqueness, Int)], [Int],
[TypeBase shape Uniqueness])
forall shape.
Eq shape =>
([(TypeBase shape NoUniqueness, Int)], [Int],
[TypeBase shape Uniqueness])
-> TypeBase shape Uniqueness
-> ([(TypeBase shape NoUniqueness, Int)], [Int],
[TypeBase shape Uniqueness])
f ([TypeBase shape NoUniqueness]
-> [Int] -> [(TypeBase shape NoUniqueness, Int)]
forall a b. [a] -> [b] -> [(a, b)]
zip ((TypeBase shape Uniqueness -> TypeBase shape NoUniqueness)
-> [TypeBase shape Uniqueness] -> [TypeBase shape NoUniqueness]
forall a b. (a -> b) -> [a] -> [b]
map TypeBase shape Uniqueness -> TypeBase shape NoUniqueness
forall shape.
TypeBase shape Uniqueness -> TypeBase shape NoUniqueness
fromDecl [TypeBase shape Uniqueness]
ts) [Int
0 ..], [Int]
forall a. Monoid a => a
mempty, [TypeBase shape Uniqueness]
forall a. Monoid a => a
mempty) t (TypeBase shape Uniqueness)
c_ts
in ([TypeBase shape Uniqueness]
ts [TypeBase shape Uniqueness]
-> [TypeBase shape Uniqueness] -> [TypeBase shape Uniqueness]
forall a. [a] -> [a] -> [a]
++ [TypeBase shape Uniqueness]
new_ts, k -> (a, [Int]) -> Map k (a, [Int]) -> Map k (a, [Int])
forall k a. Ord k => k -> a -> Map k a -> Map k a
M.insert k
c (a
i, [Int]
js) Map k (a, [Int])
mapping)
where
f :: ([(TypeBase shape NoUniqueness, Int)], [Int],
[TypeBase shape Uniqueness])
-> TypeBase shape Uniqueness
-> ([(TypeBase shape NoUniqueness, Int)], [Int],
[TypeBase shape Uniqueness])
f ([(TypeBase shape NoUniqueness, Int)]
ts', [Int]
js, [TypeBase shape Uniqueness]
new_ts) TypeBase shape Uniqueness
t
| Just (TypeBase shape NoUniqueness
_, Int
j) <- ((TypeBase shape NoUniqueness, Int) -> Bool)
-> [(TypeBase shape NoUniqueness, Int)]
-> Maybe (TypeBase shape NoUniqueness, Int)
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Maybe a
find ((TypeBase shape NoUniqueness -> TypeBase shape NoUniqueness -> Bool
forall a. Eq a => a -> a -> Bool
== TypeBase shape Uniqueness -> TypeBase shape NoUniqueness
forall shape.
TypeBase shape Uniqueness -> TypeBase shape NoUniqueness
fromDecl TypeBase shape Uniqueness
t) (TypeBase shape NoUniqueness -> Bool)
-> ((TypeBase shape NoUniqueness, Int)
-> TypeBase shape NoUniqueness)
-> (TypeBase shape NoUniqueness, Int)
-> Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (TypeBase shape NoUniqueness, Int) -> TypeBase shape NoUniqueness
forall a b. (a, b) -> a
fst) [(TypeBase shape NoUniqueness, Int)]
ts' =
( (TypeBase shape NoUniqueness, Int)
-> [(TypeBase shape NoUniqueness, Int)]
-> [(TypeBase shape NoUniqueness, Int)]
forall a. Eq a => a -> [a] -> [a]
delete (TypeBase shape Uniqueness -> TypeBase shape NoUniqueness
forall shape.
TypeBase shape Uniqueness -> TypeBase shape NoUniqueness
fromDecl TypeBase shape Uniqueness
t, Int
j) [(TypeBase shape NoUniqueness, Int)]
ts',
[Int]
js [Int] -> [Int] -> [Int]
forall a. [a] -> [a] -> [a]
++ [Int
j],
[TypeBase shape Uniqueness]
new_ts
)
| Bool
otherwise =
( [(TypeBase shape NoUniqueness, Int)]
ts',
[Int]
js [Int] -> [Int] -> [Int]
forall a. [a] -> [a] -> [a]
++ [[TypeBase shape Uniqueness] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [TypeBase shape Uniqueness]
ts Int -> Int -> Int
forall a. Num a => a -> a -> a
+ [TypeBase shape Uniqueness] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [TypeBase shape Uniqueness]
new_ts],
[TypeBase shape Uniqueness]
new_ts [TypeBase shape Uniqueness]
-> [TypeBase shape Uniqueness] -> [TypeBase shape Uniqueness]
forall a. [a] -> [a] -> [a]
++ [TypeBase shape Uniqueness
t]
)
internaliseSumType ::
M.Map Name [E.StructType] ->
InternaliseM
( [I.TypeBase ExtShape Uniqueness],
M.Map Name (Int, [Int])
)
internaliseSumType :: Map Name [TypeBase Size ()]
-> InternaliseM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
internaliseSumType Map Name [TypeBase Size ()]
cs =
([TypeBase ExtShape Uniqueness]
-> InternaliseM [TypeBase ExtShape Uniqueness])
-> (Map Name (Int, [Int]) -> InternaliseM (Map Name (Int, [Int])))
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
-> InternaliseM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
forall (t :: * -> * -> *) (f :: * -> *) a c b d.
(Bitraversable t, Applicative f) =>
(a -> f c) -> (b -> f d) -> t a b -> f (t c d)
bitraverse ((TypeBase ExtShape Uniqueness
-> InternaliseM (TypeBase ExtShape Uniqueness))
-> [TypeBase ExtShape Uniqueness]
-> InternaliseM [TypeBase ExtShape Uniqueness]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
mapM TypeBase ExtShape Uniqueness
-> InternaliseM (TypeBase ExtShape Uniqueness)
forall shape u. TypeBase shape u -> InternaliseM (TypeBase shape u)
mkAccCerts) Map Name (Int, [Int]) -> InternaliseM (Map Name (Int, [Int]))
forall (f :: * -> *) a. Applicative f => a -> f a
pure (([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
-> InternaliseM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int])))
-> (InternaliseTypeM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int])))
-> InternaliseTypeM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
-> InternaliseM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. InternaliseTypeM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
forall a. InternaliseTypeM a -> a
runInternaliseTypeM (InternaliseTypeM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
-> InternaliseM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int])))
-> InternaliseTypeM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
-> InternaliseM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
forall a b. (a -> b) -> a -> b
$
Map Name [TypeBase ExtShape Uniqueness]
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
internaliseConstructors
(Map Name [TypeBase ExtShape Uniqueness]
-> ([TypeBase ExtShape Uniqueness], Map Name (Int, [Int])))
-> InternaliseTypeM (Map Name [TypeBase ExtShape Uniqueness])
-> InternaliseTypeM
([TypeBase ExtShape Uniqueness], Map Name (Int, [Int]))
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> ([TypeBase Size ()]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> Map Name [TypeBase Size ()]
-> InternaliseTypeM (Map Name [TypeBase ExtShape Uniqueness])
forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
traverse (([[TypeBase ExtShape Uniqueness]]
-> [TypeBase ExtShape Uniqueness])
-> InternaliseTypeM [[TypeBase ExtShape Uniqueness]]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap [[TypeBase ExtShape Uniqueness]] -> [TypeBase ExtShape Uniqueness]
forall (t :: * -> *) a. Foldable t => t [a] -> [a]
concat (InternaliseTypeM [[TypeBase ExtShape Uniqueness]]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> ([TypeBase Size ()]
-> InternaliseTypeM [[TypeBase ExtShape Uniqueness]])
-> [TypeBase Size ()]
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness])
-> [TypeBase Size ()]
-> InternaliseTypeM [[TypeBase ExtShape Uniqueness]]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
mapM (Map VName Int
-> TypeBase Size ()
-> InternaliseTypeM [TypeBase ExtShape Uniqueness]
internaliseTypeM Map VName Int
forall a. Monoid a => a
mempty)) Map Name [TypeBase Size ()]
cs
internalisedTypeSize :: E.TypeBase E.Size als -> Int
internalisedTypeSize :: TypeBase Size als -> Int
internalisedTypeSize (E.Scalar (E.Prim PrimType
_)) = Int
1
internalisedTypeSize (E.Array als
_ Uniqueness
_ Shape Size
_ (E.Prim PrimType
_)) = Int
1
internalisedTypeSize TypeBase Size als
t = [TypeBase ExtShape Uniqueness] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length ([TypeBase ExtShape Uniqueness] -> Int)
-> [TypeBase ExtShape Uniqueness] -> Int
forall a b. (a -> b) -> a -> b
$ TypeBase Size () -> [TypeBase ExtShape Uniqueness]
internaliseType (TypeBase Size als
t TypeBase Size als -> () -> TypeBase Size ()
forall dim asf ast. TypeBase dim asf -> ast -> TypeBase dim ast
`E.setAliases` ())
internalisePrimType :: E.PrimType -> I.PrimType
internalisePrimType :: PrimType -> PrimType
internalisePrimType (E.Signed IntType
t) = IntType -> PrimType
I.IntType IntType
t
internalisePrimType (E.Unsigned IntType
t) = IntType -> PrimType
I.IntType IntType
t
internalisePrimType (E.FloatType FloatType
t) = FloatType -> PrimType
I.FloatType FloatType
t
internalisePrimType PrimType
E.Bool = PrimType
I.Bool
internalisePrimValue :: E.PrimValue -> I.PrimValue
internalisePrimValue :: PrimValue -> PrimValue
internalisePrimValue (E.SignedValue IntValue
v) = IntValue -> PrimValue
I.IntValue IntValue
v
internalisePrimValue (E.UnsignedValue IntValue
v) = IntValue -> PrimValue
I.IntValue IntValue
v
internalisePrimValue (E.FloatValue FloatValue
v) = FloatValue -> PrimValue
I.FloatValue FloatValue
v
internalisePrimValue (E.BoolValue Bool
b) = Bool -> PrimValue
I.BoolValue Bool
b