{-# LANGUAGE AllowAmbiguousTypes #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE DefaultSignatures #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TupleSections #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE UndecidableInstances #-}
{-# OPTIONS_HADDOCK hide #-}
module Data.Array.Accelerate.Sugar.Elt ( Elt(..) )
where
import Data.Array.Accelerate.Representation.Elt
import Data.Array.Accelerate.Representation.Tag
import Data.Array.Accelerate.Representation.Type
import Data.Array.Accelerate.Type
import Data.Bits
import Data.Char
import Data.Kind
import Language.Haskell.TH hiding ( Type )
import Language.Haskell.TH.Extra
import GHC.Generics
class Elt a where
type EltR a :: Type
type EltR a = GEltR () (Rep a)
eltR :: TypeR (EltR a)
tagsR :: [TagR (EltR a)]
fromElt :: a -> EltR a
toElt :: EltR a -> a
default eltR
:: (GElt (Rep a), EltR a ~ GEltR () (Rep a))
=> TypeR (EltR a)
eltR = TypeR () -> TypeR (GEltR () (Rep a))
forall (f :: * -> *) t. GElt f => TypeR t -> TypeR (GEltR t f)
geltR @(Rep a) TypeR ()
forall (s :: * -> *). TupR s ()
TupRunit
default tagsR
:: (Generic a, GElt (Rep a), EltR a ~ GEltR () (Rep a))
=> [TagR (EltR a)]
tagsR = TagR () -> [TagR (GEltR () (Rep a))]
forall (f :: * -> *) t. GElt f => TagR t -> [TagR (GEltR t f)]
gtagsR @(Rep a) TagR ()
TagRunit
default fromElt
:: (Generic a, GElt (Rep a), EltR a ~ GEltR () (Rep a))
=> a
-> EltR a
fromElt = () -> Rep a Any -> GEltR () (Rep a)
forall (f :: * -> *) t a. GElt f => t -> f a -> GEltR t f
gfromElt () (Rep a Any -> GEltR () (Rep a))
-> (a -> Rep a Any) -> a -> GEltR () (Rep a)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> Rep a Any
forall a x. Generic a => a -> Rep a x
from
default toElt
:: (Generic a, GElt (Rep a), EltR a ~ GEltR () (Rep a))
=> EltR a
-> a
toElt = Rep a Any -> a
forall a x. Generic a => Rep a x -> a
to (Rep a Any -> a)
-> (GEltR () (Rep a) -> Rep a Any) -> GEltR () (Rep a) -> a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ((), Rep a Any) -> Rep a Any
forall a b. (a, b) -> b
snd (((), Rep a Any) -> Rep a Any)
-> (GEltR () (Rep a) -> ((), Rep a Any))
-> GEltR () (Rep a)
-> Rep a Any
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. GEltR () (Rep a) -> ((), Rep a a)
forall (f :: * -> *) t a. GElt f => GEltR t f -> (t, f a)
gtoElt @(Rep a) @()
class GElt f where
type GEltR t f
geltR :: TypeR t -> TypeR (GEltR t f)
gtagsR :: TagR t -> [TagR (GEltR t f)]
gfromElt :: t -> f a -> GEltR t f
gtoElt :: GEltR t f -> (t, f a)
gundef :: t -> GEltR t f
guntag :: TagR t -> TagR (GEltR t f)
instance GElt U1 where
type GEltR t U1 = t
geltR :: TypeR t -> TypeR (GEltR t U1)
geltR TypeR t
t = TypeR t
TypeR (GEltR t U1)
t
gtagsR :: TagR t -> [TagR (GEltR t U1)]
gtagsR TagR t
t = [TagR t
TagR (GEltR t U1)
t]
gfromElt :: t -> U1 a -> GEltR t U1
gfromElt t
t U1 a
U1 = t
GEltR t U1
t
gtoElt :: GEltR t U1 -> (t, U1 a)
gtoElt GEltR t U1
t = (t
GEltR t U1
t, U1 a
forall k (p :: k). U1 p
U1)
gundef :: t -> GEltR t U1
gundef t
t = t
GEltR t U1
t
guntag :: TagR t -> TagR (GEltR t U1)
guntag TagR t
t = TagR t
TagR (GEltR t U1)
t
instance GElt a => GElt (M1 i c a) where
type GEltR t (M1 i c a) = GEltR t a
geltR :: TypeR t -> TypeR (GEltR t (M1 i c a))
geltR = forall t. GElt a => TypeR t -> TypeR (GEltR t a)
forall (f :: * -> *) t. GElt f => TypeR t -> TypeR (GEltR t f)
geltR @a
gtagsR :: TagR t -> [TagR (GEltR t (M1 i c a))]
gtagsR = forall t. GElt a => TagR t -> [TagR (GEltR t a)]
forall (f :: * -> *) t. GElt f => TagR t -> [TagR (GEltR t f)]
gtagsR @a
gfromElt :: t -> M1 i c a a -> GEltR t (M1 i c a)
gfromElt t
t (M1 a a
x) = t -> a a -> GEltR t a
forall (f :: * -> *) t a. GElt f => t -> f a -> GEltR t f
gfromElt t
t a a
x
gtoElt :: GEltR t (M1 i c a) -> (t, M1 i c a a)
gtoElt GEltR t (M1 i c a)
x = let (t
t, a a
x1) = GEltR t a -> (t, a a)
forall (f :: * -> *) t a. GElt f => GEltR t f -> (t, f a)
gtoElt GEltR t a
GEltR t (M1 i c a)
x in (t
t, a a -> M1 i c a a
forall k i (c :: Meta) (f :: k -> *) (p :: k). f p -> M1 i c f p
M1 a a
x1)
gundef :: t -> GEltR t (M1 i c a)
gundef = forall t. GElt a => t -> GEltR t a
forall (f :: * -> *) t. GElt f => t -> GEltR t f
gundef @a
guntag :: TagR t -> TagR (GEltR t (M1 i c a))
guntag = forall t. GElt a => TagR t -> TagR (GEltR t a)
forall (f :: * -> *) t. GElt f => TagR t -> TagR (GEltR t f)
guntag @a
instance Elt a => GElt (K1 i a) where
type GEltR t (K1 i a) = (t, EltR a)
geltR :: TypeR t -> TypeR (GEltR t (K1 i a))
geltR TypeR t
t = TypeR t -> TupR ScalarType (EltR a) -> TupR ScalarType (t, EltR a)
forall (s :: * -> *) a b. TupR s a -> TupR s b -> TupR s (a, b)
TupRpair TypeR t
t (Elt a => TupR ScalarType (EltR a)
forall a. Elt a => TypeR (EltR a)
eltR @a)
gtagsR :: TagR t -> [TagR (GEltR t (K1 i a))]
gtagsR TagR t
t = TagR t -> TagR (EltR a) -> TagR (t, EltR a)
forall a b. TagR a -> TagR b -> TagR (a, b)
TagRpair TagR t
t (TagR (EltR a) -> TagR (t, EltR a))
-> [TagR (EltR a)] -> [TagR (t, EltR a)]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Elt a => [TagR (EltR a)]
forall a. Elt a => [TagR (EltR a)]
tagsR @a
gfromElt :: t -> K1 i a a -> GEltR t (K1 i a)
gfromElt t
t (K1 a
x) = (t
t, a -> EltR a
forall a. Elt a => a -> EltR a
fromElt a
x)
gtoElt :: GEltR t (K1 i a) -> (t, K1 i a a)
gtoElt (t, x) = (t
t, a -> K1 i a a
forall k i c (p :: k). c -> K1 i c p
K1 (EltR a -> a
forall a. Elt a => EltR a -> a
toElt EltR a
x))
gundef :: t -> GEltR t (K1 i a)
gundef t
t = (t
t, TupR ScalarType (EltR a) -> EltR a
forall t. TypeR t -> t
undefElt (Elt a => TupR ScalarType (EltR a)
forall a. Elt a => TypeR (EltR a)
eltR @a))
guntag :: TagR t -> TagR (GEltR t (K1 i a))
guntag TagR t
t = TagR t -> TagR (EltR a) -> TagR (t, EltR a)
forall a b. TagR a -> TagR b -> TagR (a, b)
TagRpair TagR t
t (TupR ScalarType (EltR a) -> TagR (EltR a)
forall t. TypeR t -> TagR t
untag (Elt a => TupR ScalarType (EltR a)
forall a. Elt a => TypeR (EltR a)
eltR @a))
instance (GElt a, GElt b) => GElt (a :*: b) where
type GEltR t (a :*: b) = GEltR (GEltR t a) b
geltR :: TypeR t -> TypeR (GEltR t (a :*: b))
geltR = forall t. GElt b => TypeR t -> TypeR (GEltR t b)
forall (f :: * -> *) t. GElt f => TypeR t -> TypeR (GEltR t f)
geltR @b (TypeR (GEltR t a) -> TypeR (GEltR (GEltR t a) b))
-> (TypeR t -> TypeR (GEltR t a))
-> TypeR t
-> TypeR (GEltR (GEltR t a) b)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall t. GElt a => TypeR t -> TypeR (GEltR t a)
forall (f :: * -> *) t. GElt f => TypeR t -> TypeR (GEltR t f)
geltR @a
gtagsR :: TagR t -> [TagR (GEltR t (a :*: b))]
gtagsR = (TagR (GEltR t a) -> [TagR (GEltR (GEltR t a) b)])
-> [TagR (GEltR t a)] -> [TagR (GEltR (GEltR t a) b)]
forall (t :: * -> *) a b. Foldable t => (a -> [b]) -> t a -> [b]
concatMap (forall t. GElt b => TagR t -> [TagR (GEltR t b)]
forall (f :: * -> *) t. GElt f => TagR t -> [TagR (GEltR t f)]
gtagsR @b) ([TagR (GEltR t a)] -> [TagR (GEltR (GEltR t a) b)])
-> (TagR t -> [TagR (GEltR t a)])
-> TagR t
-> [TagR (GEltR (GEltR t a) b)]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall t. GElt a => TagR t -> [TagR (GEltR t a)]
forall (f :: * -> *) t. GElt f => TagR t -> [TagR (GEltR t f)]
gtagsR @a
gfromElt :: t -> (:*:) a b a -> GEltR t (a :*: b)
gfromElt t
t (a a
a :*: b a
b) = GEltR t a -> b a -> GEltR (GEltR t a) b
forall (f :: * -> *) t a. GElt f => t -> f a -> GEltR t f
gfromElt (t -> a a -> GEltR t a
forall (f :: * -> *) t a. GElt f => t -> f a -> GEltR t f
gfromElt t
t a a
a) b a
b
gtoElt :: GEltR t (a :*: b) -> (t, (:*:) a b a)
gtoElt GEltR t (a :*: b)
t =
let (GEltR t a
t1, b a
b) = GEltR (GEltR t a) b -> (GEltR t a, b a)
forall (f :: * -> *) t a. GElt f => GEltR t f -> (t, f a)
gtoElt GEltR t (a :*: b)
GEltR (GEltR t a) b
t
(t
t2, a a
a) = GEltR t a -> (t, a a)
forall (f :: * -> *) t a. GElt f => GEltR t f -> (t, f a)
gtoElt GEltR t a
t1
in
(t
t2, a a
a a a -> b a -> (:*:) a b a
forall k (f :: k -> *) (g :: k -> *) (p :: k).
f p -> g p -> (:*:) f g p
:*: b a
b)
gundef :: t -> GEltR t (a :*: b)
gundef t
t = GEltR t a -> GEltR (GEltR t a) b
forall (f :: * -> *) t. GElt f => t -> GEltR t f
gundef @b (t -> GEltR t a
forall (f :: * -> *) t. GElt f => t -> GEltR t f
gundef @a t
t)
guntag :: TagR t -> TagR (GEltR t (a :*: b))
guntag TagR t
t = TagR (GEltR t a) -> TagR (GEltR (GEltR t a) b)
forall (f :: * -> *) t. GElt f => TagR t -> TagR (GEltR t f)
guntag @b (TagR t -> TagR (GEltR t a)
forall (f :: * -> *) t. GElt f => TagR t -> TagR (GEltR t f)
guntag @a TagR t
t)
instance (GElt a, GElt b, GSumElt (a :+: b)) => GElt (a :+: b) where
type GEltR t (a :+: b) = (TAG, GSumEltR t (a :+: b))
geltR :: TypeR t -> TypeR (GEltR t (a :+: b))
geltR TypeR t
t = TupR ScalarType TAG
-> TupR ScalarType (GSumEltR (GSumEltR t a) b)
-> TupR ScalarType (TAG, GSumEltR (GSumEltR t a) b)
forall (s :: * -> *) a b. TupR s a -> TupR s b -> TupR s (a, b)
TupRpair (ScalarType TAG -> TupR ScalarType TAG
forall (s :: * -> *) a. s a -> TupR s a
TupRsingle ScalarType TAG
forall a. IsScalar a => ScalarType a
scalarType) (TypeR t -> TypeR (GSumEltR t (a :+: b))
forall (f :: * -> *) t.
GSumElt f =>
TypeR t -> TypeR (GSumEltR t f)
gsumEltR @(a :+: b) TypeR t
t)
gtagsR :: TagR t -> [TagR (GEltR t (a :+: b))]
gtagsR TagR t
t = (TAG
-> TagR (GSumEltR (GSumEltR t a) b)
-> TagR (TAG, GSumEltR (GSumEltR t a) b))
-> (TAG, TagR (GSumEltR (GSumEltR t a) b))
-> TagR (TAG, GSumEltR (GSumEltR t a) b)
forall a b c. (a -> b -> c) -> (a, b) -> c
uncurry TAG
-> TagR (GSumEltR (GSumEltR t a) b)
-> TagR (TAG, GSumEltR (GSumEltR t a) b)
forall a. TAG -> TagR a -> TagR (TAG, a)
TagRtag ((TAG, TagR (GSumEltR (GSumEltR t a) b))
-> TagR (TAG, GSumEltR (GSumEltR t a) b))
-> [(TAG, TagR (GSumEltR (GSumEltR t a) b))]
-> [TagR (TAG, GSumEltR (GSumEltR t a) b)]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> TAG -> TagR t -> [(TAG, TagR (GSumEltR t (a :+: b)))]
forall (f :: * -> *) t.
GSumElt f =>
TAG -> TagR t -> [(TAG, TagR (GSumEltR t f))]
gsumTagsR @(a :+: b) TAG
0 TagR t
t
gfromElt :: t -> (:+:) a b a -> GEltR t (a :+: b)
gfromElt = TAG -> t -> (:+:) a b a -> (TAG, GSumEltR t (a :+: b))
forall (f :: * -> *) t a.
GSumElt f =>
TAG -> t -> f a -> (TAG, GSumEltR t f)
gsumFromElt TAG
0
gtoElt :: GEltR t (a :+: b) -> (t, (:+:) a b a)
gtoElt (k,x) = TAG -> GSumEltR t (a :+: b) -> (t, (:+:) a b a)
forall (f :: * -> *) t a.
GSumElt f =>
TAG -> GSumEltR t f -> (t, f a)
gsumToElt TAG
k GSumEltR t (a :+: b)
GSumEltR (GSumEltR t a) b
x
gundef :: t -> GEltR t (a :+: b)
gundef t
t = (TAG
0xff, t -> GSumEltR t (a :+: b)
forall (f :: * -> *) t. GSumElt f => t -> GSumEltR t f
gsumUndef @(a :+: b) t
t)
guntag :: TagR t -> TagR (GEltR t (a :+: b))
guntag TagR t
t = TagR TAG
-> TagR (GSumEltR (GSumEltR t a) b)
-> TagR (TAG, GSumEltR (GSumEltR t a) b)
forall a b. TagR a -> TagR b -> TagR (a, b)
TagRpair (ScalarType TAG -> TagR TAG
forall a. ScalarType a -> TagR a
TagRundef ScalarType TAG
forall a. IsScalar a => ScalarType a
scalarType) (TagR t -> TagR (GSumEltR t (a :+: b))
forall (f :: * -> *) t. GSumElt f => TagR t -> TagR (GSumEltR t f)
gsumUntag @(a :+: b) TagR t
t)
class GSumElt f where
type GSumEltR t f
gsumEltR :: TypeR t -> TypeR (GSumEltR t f)
gsumTagsR :: TAG -> TagR t -> [(TAG, TagR (GSumEltR t f))]
gsumFromElt :: TAG -> t -> f a -> (TAG, GSumEltR t f)
gsumToElt :: TAG -> GSumEltR t f -> (t, f a)
gsumUndef :: t -> GSumEltR t f
gsumUntag :: TagR t -> TagR (GSumEltR t f)
instance GSumElt U1 where
type GSumEltR t U1 = t
gsumEltR :: TypeR t -> TypeR (GSumEltR t U1)
gsumEltR TypeR t
t = TypeR t
TypeR (GSumEltR t U1)
t
gsumTagsR :: TAG -> TagR t -> [(TAG, TagR (GSumEltR t U1))]
gsumTagsR TAG
n TagR t
t = [(TAG
n, TagR t
TagR (GSumEltR t U1)
t)]
gsumFromElt :: TAG -> t -> U1 a -> (TAG, GSumEltR t U1)
gsumFromElt TAG
n t
t U1 a
U1 = (TAG
n, t
GSumEltR t U1
t)
gsumToElt :: TAG -> GSumEltR t U1 -> (t, U1 a)
gsumToElt TAG
_ GSumEltR t U1
t = (t
GSumEltR t U1
t, U1 a
forall k (p :: k). U1 p
U1)
gsumUndef :: t -> GSumEltR t U1
gsumUndef t
t = t
GSumEltR t U1
t
gsumUntag :: TagR t -> TagR (GSumEltR t U1)
gsumUntag TagR t
t = TagR t
TagR (GSumEltR t U1)
t
instance GSumElt a => GSumElt (M1 i c a) where
type GSumEltR t (M1 i c a) = GSumEltR t a
gsumEltR :: TypeR t -> TypeR (GSumEltR t (M1 i c a))
gsumEltR = forall t. GSumElt a => TypeR t -> TypeR (GSumEltR t a)
forall (f :: * -> *) t.
GSumElt f =>
TypeR t -> TypeR (GSumEltR t f)
gsumEltR @a
gsumTagsR :: TAG -> TagR t -> [(TAG, TagR (GSumEltR t (M1 i c a)))]
gsumTagsR = forall t.
GSumElt a =>
TAG -> TagR t -> [(TAG, TagR (GSumEltR t a))]
forall (f :: * -> *) t.
GSumElt f =>
TAG -> TagR t -> [(TAG, TagR (GSumEltR t f))]
gsumTagsR @a
gsumFromElt :: TAG -> t -> M1 i c a a -> (TAG, GSumEltR t (M1 i c a))
gsumFromElt TAG
n t
t (M1 a a
x) = TAG -> t -> a a -> (TAG, GSumEltR t a)
forall (f :: * -> *) t a.
GSumElt f =>
TAG -> t -> f a -> (TAG, GSumEltR t f)
gsumFromElt TAG
n t
t a a
x
gsumToElt :: TAG -> GSumEltR t (M1 i c a) -> (t, M1 i c a a)
gsumToElt TAG
k GSumEltR t (M1 i c a)
x = let (t
t, a a
x') = TAG -> GSumEltR t a -> (t, a a)
forall (f :: * -> *) t a.
GSumElt f =>
TAG -> GSumEltR t f -> (t, f a)
gsumToElt TAG
k GSumEltR t a
GSumEltR t (M1 i c a)
x in (t
t, a a -> M1 i c a a
forall k i (c :: Meta) (f :: k -> *) (p :: k). f p -> M1 i c f p
M1 a a
x')
gsumUntag :: TagR t -> TagR (GSumEltR t (M1 i c a))
gsumUntag = forall t. GSumElt a => TagR t -> TagR (GSumEltR t a)
forall (f :: * -> *) t. GSumElt f => TagR t -> TagR (GSumEltR t f)
gsumUntag @a
gsumUndef :: t -> GSumEltR t (M1 i c a)
gsumUndef = forall t. GSumElt a => t -> GSumEltR t a
forall (f :: * -> *) t. GSumElt f => t -> GSumEltR t f
gsumUndef @a
instance Elt a => GSumElt (K1 i a) where
type GSumEltR t (K1 i a) = (t, EltR a)
gsumEltR :: TypeR t -> TypeR (GSumEltR t (K1 i a))
gsumEltR TypeR t
t = TypeR t -> TupR ScalarType (EltR a) -> TupR ScalarType (t, EltR a)
forall (s :: * -> *) a b. TupR s a -> TupR s b -> TupR s (a, b)
TupRpair TypeR t
t (Elt a => TupR ScalarType (EltR a)
forall a. Elt a => TypeR (EltR a)
eltR @a)
gsumTagsR :: TAG -> TagR t -> [(TAG, TagR (GSumEltR t (K1 i a)))]
gsumTagsR TAG
n TagR t
t = (TAG
n,) (TagR (t, EltR a) -> (TAG, TagR (t, EltR a)))
-> (TagR (EltR a) -> TagR (t, EltR a))
-> TagR (EltR a)
-> (TAG, TagR (t, EltR a))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. TagR t -> TagR (EltR a) -> TagR (t, EltR a)
forall a b. TagR a -> TagR b -> TagR (a, b)
TagRpair TagR t
t (TagR (EltR a) -> (TAG, TagR (t, EltR a)))
-> [TagR (EltR a)] -> [(TAG, TagR (t, EltR a))]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Elt a => [TagR (EltR a)]
forall a. Elt a => [TagR (EltR a)]
tagsR @a
gsumFromElt :: TAG -> t -> K1 i a a -> (TAG, GSumEltR t (K1 i a))
gsumFromElt TAG
n t
t (K1 a
x) = (TAG
n, (t
t, a -> EltR a
forall a. Elt a => a -> EltR a
fromElt a
x))
gsumToElt :: TAG -> GSumEltR t (K1 i a) -> (t, K1 i a a)
gsumToElt TAG
_ (t, x) = (t
t, a -> K1 i a a
forall k i c (p :: k). c -> K1 i c p
K1 (EltR a -> a
forall a. Elt a => EltR a -> a
toElt EltR a
x))
gsumUntag :: TagR t -> TagR (GSumEltR t (K1 i a))
gsumUntag TagR t
t = TagR t -> TagR (EltR a) -> TagR (t, EltR a)
forall a b. TagR a -> TagR b -> TagR (a, b)
TagRpair TagR t
t (TupR ScalarType (EltR a) -> TagR (EltR a)
forall t. TypeR t -> TagR t
untag (Elt a => TupR ScalarType (EltR a)
forall a. Elt a => TypeR (EltR a)
eltR @a))
gsumUndef :: t -> GSumEltR t (K1 i a)
gsumUndef t
t = (t
t, TupR ScalarType (EltR a) -> EltR a
forall t. TypeR t -> t
undefElt (Elt a => TupR ScalarType (EltR a)
forall a. Elt a => TypeR (EltR a)
eltR @a))
instance (GElt a, GElt b) => GSumElt (a :*: b) where
type GSumEltR t (a :*: b) = GEltR t (a :*: b)
gsumEltR :: TypeR t -> TypeR (GSumEltR t (a :*: b))
gsumEltR = forall t. GElt (a :*: b) => TypeR t -> TypeR (GEltR t (a :*: b))
forall (f :: * -> *) t. GElt f => TypeR t -> TypeR (GEltR t f)
geltR @(a :*: b)
gsumTagsR :: TAG -> TagR t -> [(TAG, TagR (GSumEltR t (a :*: b)))]
gsumTagsR TAG
n TagR t
t = (TAG
n,) (TagR (GEltR (GEltR t a) b) -> (TAG, TagR (GEltR (GEltR t a) b)))
-> [TagR (GEltR (GEltR t a) b)]
-> [(TAG, TagR (GEltR (GEltR t a) b))]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> TagR t -> [TagR (GEltR t (a :*: b))]
forall (f :: * -> *) t. GElt f => TagR t -> [TagR (GEltR t f)]
gtagsR @(a :*: b) TagR t
t
gsumFromElt :: TAG -> t -> (:*:) a b a -> (TAG, GSumEltR t (a :*: b))
gsumFromElt TAG
n t
t (a a
a :*: b a
b) = (TAG
n, GEltR t a -> b a -> GEltR (GEltR t a) b
forall (f :: * -> *) t a. GElt f => t -> f a -> GEltR t f
gfromElt (t -> a a -> GEltR t a
forall (f :: * -> *) t a. GElt f => t -> f a -> GEltR t f
gfromElt t
t a a
a) b a
b)
gsumToElt :: TAG -> GSumEltR t (a :*: b) -> (t, (:*:) a b a)
gsumToElt TAG
_ GSumEltR t (a :*: b)
t0 =
let (GEltR t a
t1, b a
b) = GEltR (GEltR t a) b -> (GEltR t a, b a)
forall (f :: * -> *) t a. GElt f => GEltR t f -> (t, f a)
gtoElt GSumEltR t (a :*: b)
GEltR (GEltR t a) b
t0
(t
t2, a a
a) = GEltR t a -> (t, a a)
forall (f :: * -> *) t a. GElt f => GEltR t f -> (t, f a)
gtoElt GEltR t a
t1
in
(t
t2, a a
a a a -> b a -> (:*:) a b a
forall k (f :: k -> *) (g :: k -> *) (p :: k).
f p -> g p -> (:*:) f g p
:*: b a
b)
gsumUndef :: t -> GSumEltR t (a :*: b)
gsumUndef = forall t. GElt (a :*: b) => t -> GEltR t (a :*: b)
forall (f :: * -> *) t. GElt f => t -> GEltR t f
gundef @(a :*: b)
gsumUntag :: TagR t -> TagR (GSumEltR t (a :*: b))
gsumUntag = forall t. GElt (a :*: b) => TagR t -> TagR (GEltR t (a :*: b))
forall (f :: * -> *) t. GElt f => TagR t -> TagR (GEltR t f)
guntag @(a :*: b)
instance (GSumElt a, GSumElt b) => GSumElt (a :+: b) where
type GSumEltR t (a :+: b) = GSumEltR (GSumEltR t a) b
gsumEltR :: TypeR t -> TypeR (GSumEltR t (a :+: b))
gsumEltR = forall t. GSumElt b => TypeR t -> TypeR (GSumEltR t b)
forall (f :: * -> *) t.
GSumElt f =>
TypeR t -> TypeR (GSumEltR t f)
gsumEltR @b (TypeR (GSumEltR t a) -> TypeR (GSumEltR (GSumEltR t a) b))
-> (TypeR t -> TypeR (GSumEltR t a))
-> TypeR t
-> TypeR (GSumEltR (GSumEltR t a) b)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall t. GSumElt a => TypeR t -> TypeR (GSumEltR t a)
forall (f :: * -> *) t.
GSumElt f =>
TypeR t -> TypeR (GSumEltR t f)
gsumEltR @a
gsumFromElt :: TAG -> t -> (:+:) a b a -> (TAG, GSumEltR t (a :+: b))
gsumFromElt TAG
n t
t (L1 a a
a) = let (TAG
m,GSumEltR t a
r) = TAG -> t -> a a -> (TAG, GSumEltR t a)
forall (f :: * -> *) t a.
GSumElt f =>
TAG -> t -> f a -> (TAG, GSumEltR t f)
gsumFromElt TAG
n t
t a a
a
in (TAG -> Int -> TAG
forall a. Bits a => a -> Int -> a
shiftL TAG
m Int
1, GSumEltR t a -> GSumEltR (GSumEltR t a) b
forall (f :: * -> *) t. GSumElt f => t -> GSumEltR t f
gsumUndef @b GSumEltR t a
r)
gsumFromElt TAG
n t
t (R1 b a
b) = let (TAG
m,GSumEltR (GSumEltR t a) b
r) = TAG -> GSumEltR t a -> b a -> (TAG, GSumEltR (GSumEltR t a) b)
forall (f :: * -> *) t a.
GSumElt f =>
TAG -> t -> f a -> (TAG, GSumEltR t f)
gsumFromElt TAG
n (t -> GSumEltR t a
forall (f :: * -> *) t. GSumElt f => t -> GSumEltR t f
gsumUndef @a t
t) b a
b
in (TAG -> Int -> TAG
forall a. Bits a => a -> Int -> a
setBit (TAG
m TAG -> Int -> TAG
forall a. Bits a => a -> Int -> a
`shiftL` Int
1) Int
0, GSumEltR t (a :+: b)
GSumEltR (GSumEltR t a) b
r)
gsumToElt :: TAG -> GSumEltR t (a :+: b) -> (t, (:+:) a b a)
gsumToElt TAG
k GSumEltR t (a :+: b)
t0 =
let (GSumEltR t a
t1, b a
b) = TAG -> GSumEltR (GSumEltR t a) b -> (GSumEltR t a, b a)
forall (f :: * -> *) t a.
GSumElt f =>
TAG -> GSumEltR t f -> (t, f a)
gsumToElt (TAG -> Int -> TAG
forall a. Bits a => a -> Int -> a
shiftR TAG
k Int
1) GSumEltR t (a :+: b)
GSumEltR (GSumEltR t a) b
t0
(t
t2, a a
a) = TAG -> GSumEltR t a -> (t, a a)
forall (f :: * -> *) t a.
GSumElt f =>
TAG -> GSumEltR t f -> (t, f a)
gsumToElt (TAG -> Int -> TAG
forall a. Bits a => a -> Int -> a
shiftR TAG
k Int
1) GSumEltR t a
t1
in
if TAG -> Int -> Bool
forall a. Bits a => a -> Int -> Bool
testBit TAG
k Int
0
then (t
t2, b a -> (:+:) a b a
forall k (f :: k -> *) (g :: k -> *) (p :: k). g p -> (:+:) f g p
R1 b a
b)
else (t
t2, a a -> (:+:) a b a
forall k (f :: k -> *) (g :: k -> *) (p :: k). f p -> (:+:) f g p
L1 a a
a)
gsumTagsR :: TAG -> TagR t -> [(TAG, TagR (GSumEltR t (a :+: b)))]
gsumTagsR TAG
k TagR t
t =
let a :: [(TAG, TagR (GSumEltR t a))]
a = TAG -> TagR t -> [(TAG, TagR (GSumEltR t a))]
forall (f :: * -> *) t.
GSumElt f =>
TAG -> TagR t -> [(TAG, TagR (GSumEltR t f))]
gsumTagsR @a TAG
k TagR t
t
b :: [(TAG, TagR (GSumEltR (GSumEltR t a) b))]
b = TAG
-> TagR (GSumEltR t a) -> [(TAG, TagR (GSumEltR (GSumEltR t a) b))]
forall (f :: * -> *) t.
GSumElt f =>
TAG -> TagR t -> [(TAG, TagR (GSumEltR t f))]
gsumTagsR @b TAG
k (TagR t -> TagR (GSumEltR t a)
forall (f :: * -> *) t. GSumElt f => TagR t -> TagR (GSumEltR t f)
gsumUntag @a TagR t
t)
in
((TAG, TagR (GSumEltR t a))
-> (TAG, TagR (GSumEltR (GSumEltR t a) b)))
-> [(TAG, TagR (GSumEltR t a))]
-> [(TAG, TagR (GSumEltR (GSumEltR t a) b))]
forall a b. (a -> b) -> [a] -> [b]
map (\(TAG
x,TagR (GSumEltR t a)
y) -> (TAG
x TAG -> Int -> TAG
forall a. Bits a => a -> Int -> a
`shiftL` Int
1, TagR (GSumEltR t a) -> TagR (GSumEltR (GSumEltR t a) b)
forall (f :: * -> *) t. GSumElt f => TagR t -> TagR (GSumEltR t f)
gsumUntag @b TagR (GSumEltR t a)
y)) [(TAG, TagR (GSumEltR t a))]
a [(TAG, TagR (GSumEltR (GSumEltR t a) b))]
-> [(TAG, TagR (GSumEltR (GSumEltR t a) b))]
-> [(TAG, TagR (GSumEltR (GSumEltR t a) b))]
forall a. [a] -> [a] -> [a]
++
((TAG, TagR (GSumEltR (GSumEltR t a) b))
-> (TAG, TagR (GSumEltR (GSumEltR t a) b)))
-> [(TAG, TagR (GSumEltR (GSumEltR t a) b))]
-> [(TAG, TagR (GSumEltR (GSumEltR t a) b))]
forall a b. (a -> b) -> [a] -> [b]
map (\(TAG
x,TagR (GSumEltR (GSumEltR t a) b)
y) -> (TAG -> Int -> TAG
forall a. Bits a => a -> Int -> a
setBit (TAG
x TAG -> Int -> TAG
forall a. Bits a => a -> Int -> a
`shiftL` Int
1) Int
0, TagR (GSumEltR (GSumEltR t a) b)
y)) [(TAG, TagR (GSumEltR (GSumEltR t a) b))]
b
gsumUndef :: t -> GSumEltR t (a :+: b)
gsumUndef t
t = GSumEltR t a -> GSumEltR (GSumEltR t a) b
forall (f :: * -> *) t. GSumElt f => t -> GSumEltR t f
gsumUndef @b (t -> GSumEltR t a
forall (f :: * -> *) t. GSumElt f => t -> GSumEltR t f
gsumUndef @a t
t)
gsumUntag :: TagR t -> TagR (GSumEltR t (a :+: b))
gsumUntag TagR t
t = TagR (GSumEltR t a) -> TagR (GSumEltR (GSumEltR t a) b)
forall (f :: * -> *) t. GSumElt f => TagR t -> TagR (GSumEltR t f)
gsumUntag @b (TagR t -> TagR (GSumEltR t a)
forall (f :: * -> *) t. GSumElt f => TagR t -> TagR (GSumEltR t f)
gsumUntag @a TagR t
t)
class GTags (f :: Type -> Type) where
gtags :: TAG -> [(String, TAG)]
instance GTags a => GTags (D1 c a) where
gtags :: TAG -> [(String, TAG)]
gtags = GTags a => TAG -> [(String, TAG)]
forall (f :: * -> *). GTags f => TAG -> [(String, TAG)]
gtags @a
instance Constructor c => GTags (C1 c a) where
gtags :: TAG -> [(String, TAG)]
gtags TAG
k = [ (M1 D c a () -> String
forall k (c :: k) k1 (t :: k -> (k1 -> *) -> k1 -> *)
(f :: k1 -> *) (a :: k1).
Constructor c =>
t c f a -> String
conName (M1 D c a ()
forall a. HasCallStack => a
undefined :: D1 c a ()), TAG
k) ]
instance (GTags a, GTags b) => GTags (a :+: b) where
gtags :: TAG -> [(String, TAG)]
gtags TAG
k =
let as :: [(String, TAG)]
as = TAG -> [(String, TAG)]
forall (f :: * -> *). GTags f => TAG -> [(String, TAG)]
gtags @a TAG
k
bs :: [(String, TAG)]
bs = TAG -> [(String, TAG)]
forall (f :: * -> *). GTags f => TAG -> [(String, TAG)]
gtags @b TAG
k
in
((String, TAG) -> (String, TAG))
-> [(String, TAG)] -> [(String, TAG)]
forall a b. (a -> b) -> [a] -> [b]
map (\(String
x,TAG
y) -> (String
x, TAG
y TAG -> Int -> TAG
forall a. Bits a => a -> Int -> a
`shiftL` Int
1) ) [(String, TAG)]
as [(String, TAG)] -> [(String, TAG)] -> [(String, TAG)]
forall a. [a] -> [a] -> [a]
++
((String, TAG) -> (String, TAG))
-> [(String, TAG)] -> [(String, TAG)]
forall a b. (a -> b) -> [a] -> [b]
map (\(String
x,TAG
y) -> (String
x, TAG -> Int -> TAG
forall a. Bits a => a -> Int -> a
setBit (TAG
y TAG -> Int -> TAG
forall a. Bits a => a -> Int -> a
`shiftL` Int
1) Int
0)) [(String, TAG)]
bs
untag :: TypeR t -> TagR t
untag :: TypeR t -> TagR t
untag TypeR t
TupRunit = TagR t
TagR ()
TagRunit
untag (TupRsingle ScalarType t
t) = ScalarType t -> TagR t
forall a. ScalarType a -> TagR a
TagRundef ScalarType t
t
untag (TupRpair TupR ScalarType a
ta TupR ScalarType b
tb) = TagR a -> TagR b -> TagR (a, b)
forall a b. TagR a -> TagR b -> TagR (a, b)
TagRpair (TupR ScalarType a -> TagR a
forall t. TypeR t -> TagR t
untag TupR ScalarType a
ta) (TupR ScalarType b -> TagR b
forall t. TypeR t -> TagR t
untag TupR ScalarType b
tb)
instance Elt ()
instance Elt Bool
instance Elt Ordering
instance Elt a => Elt (Maybe a)
instance (Elt a, Elt b) => Elt (Either a b)
instance Elt Char where
type EltR Char = Word32
eltR :: TypeR (EltR Char)
eltR = ScalarType Word32 -> TupR ScalarType Word32
forall (s :: * -> *) a. s a -> TupR s a
TupRsingle ScalarType Word32
forall a. IsScalar a => ScalarType a
scalarType
tagsR :: [TagR (EltR Char)]
tagsR = [ScalarType Word32 -> TagR Word32
forall a. ScalarType a -> TagR a
TagRsingle ScalarType Word32
forall a. IsScalar a => ScalarType a
scalarType]
toElt :: EltR Char -> Char
toElt = Int -> Char
chr (Int -> Char) -> (Word32 -> Int) -> Word32 -> Char
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Word32 -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral
fromElt :: Char -> EltR Char
fromElt = Int -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (Int -> Word32) -> (Char -> Int) -> Char -> Word32
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Char -> Int
ord