diff options
| author | Tom Smeding <tom@tomsmeding.com> | 2025-06-18 00:00:11 +0200 | 
|---|---|---|
| committer | Tom Smeding <tom@tomsmeding.com> | 2025-06-18 00:00:11 +0200 | 
| commit | d1b2e2c3a3cdaf49ff5e4bae6fe9b0612c3779c2 (patch) | |
| tree | 38577e02839ac18244aa46b833da8957cbe9789e /src/AST/Sparse.hs | |
| parent | 2b1a40b5933b8b0dceaae744e5b70cb604822c9d (diff) | |
Tests pass, should check if output is sensible
Diffstat (limited to 'src/AST/Sparse.hs')
| -rw-r--r-- | src/AST/Sparse.hs | 110 | 
1 files changed, 4 insertions, 106 deletions
| diff --git a/src/AST/Sparse.hs b/src/AST/Sparse.hs index 369d395..f0a1f2a 100644 --- a/src/AST/Sparse.hs +++ b/src/AST/Sparse.hs @@ -1,116 +1,19 @@ +{-# LANGUAGE DataKinds #-}  {-# LANGUAGE GADTs #-} -{-# LANGUAGE PolyKinds #-}  {-# LANGUAGE StandaloneDeriving #-} -{-# LANGUAGE TypeFamilies #-} -{-# LANGUAGE TypeOperators #-}  {-# LANGUAGE RankNTypes #-} -{-# LANGUAGE DataKinds #-}  {-# LANGUAGE ScopedTypeVariables #-}  {-# OPTIONS_GHC -fmax-pmcheck-models=80 #-} -module AST.Sparse where +module AST.Sparse (module AST.Sparse, module AST.Sparse.Types) where -import Data.Kind (Constraint, Type)  import Data.Type.Equality  import AST +import AST.Sparse.Types +import Data (SBool(..)) -data Sparse t t' where -  SpSparse :: Sparse t t' -> Sparse t (TMaybe t') -  SpAbsent :: Sparse t TNil - -  SpPair :: Sparse a a' -> Sparse b b' -> Sparse (TPair a b) (TPair a' b') -  SpLEither :: Sparse a a' -> Sparse b b' -> Sparse (TLEither a b) (TLEither a' b') -  SpMaybe :: Sparse t t' -> Sparse (TMaybe t) (TMaybe t') -  SpArr :: Sparse t t' -> Sparse (TArr n t) (TArr n t') -  SpScal :: Sparse (TScal t) (TScal t) -deriving instance Show (Sparse t t') - -class ApplySparse f where -  applySparse :: Sparse t t' -> f t -> f t' - -instance ApplySparse STy where -  applySparse (SpSparse s) t = STMaybe (applySparse s t) -  applySparse SpAbsent _ = STNil -  applySparse (SpPair s1 s2) (STPair t1 t2) = STPair (applySparse s1 t1) (applySparse s2 t2) -  applySparse (SpLEither s1 s2) (STLEither t1 t2) = STLEither (applySparse s1 t1) (applySparse s2 t2) -  applySparse (SpMaybe s) (STMaybe t) = STMaybe (applySparse s t) -  applySparse (SpArr s) (STArr n t) = STArr n (applySparse s t) -  applySparse SpScal t = t - -instance ApplySparse SMTy where -  applySparse (SpSparse s) t = SMTMaybe (applySparse s t) -  applySparse SpAbsent _ = SMTNil -  applySparse (SpPair s1 s2) (SMTPair t1 t2) = SMTPair (applySparse s1 t1) (applySparse s2 t2) -  applySparse (SpLEither s1 s2) (SMTLEither t1 t2) = SMTLEither (applySparse s1 t1) (applySparse s2 t2) -  applySparse (SpMaybe s) (SMTMaybe t) = SMTMaybe (applySparse s t) -  applySparse (SpArr s) (SMTArr n t) = SMTArr n (applySparse s t) -  applySparse SpScal t = t - - -class IsSubType s where -  type IsSubTypeSubject (s :: k -> k -> Type) (f :: k -> Type) :: Constraint -  subtApply :: IsSubTypeSubject s f => s t t' -> f t -> f t' -  subtTrans :: s a b -> s b c -> s a c -  subtFull :: IsSubTypeSubject s f => f t -> s t t - -instance IsSubType (:~:) where -  type IsSubTypeSubject (:~:) f = () -  subtApply = gcastWith -  subtTrans = trans -  subtFull _ = Refl - -instance IsSubType Sparse where -  type IsSubTypeSubject Sparse f = f ~ SMTy -  subtApply = applySparse - -  subtTrans s1 (SpSparse s2) = SpSparse (subtTrans s1 s2) -  subtTrans _ SpAbsent = SpAbsent -  subtTrans (SpPair s1a s1b) (SpPair s2a s2b) = SpPair (subtTrans s1a s2a) (subtTrans s1b s2b) -  subtTrans (SpLEither s1a s1b) (SpLEither s2a s2b) = SpLEither (subtTrans s1a s2a) (subtTrans s1b s2b) -  subtTrans (SpSparse s1) (SpMaybe s2) = SpSparse (subtTrans s1 s2) -  subtTrans (SpMaybe s1) (SpMaybe s2) = SpMaybe (subtTrans s1 s2) -  subtTrans (SpArr s1) (SpArr s2) = SpArr (subtTrans s1 s2) -  subtTrans SpScal SpScal = SpScal - -  subtFull = spDense - -spDense :: SMTy t -> Sparse t t -spDense SMTNil = SpAbsent -spDense (SMTPair t1 t2) = SpPair (spDense t1) (spDense t2) -spDense (SMTLEither t1 t2) = SpLEither (spDense t1) (spDense t2) -spDense (SMTMaybe t) = SpMaybe (spDense t) -spDense (SMTArr _ t) = SpArr (spDense t) -spDense (SMTScal _) = SpScal - -isDense :: SMTy t -> Sparse t t' -> Maybe (t :~: t') -isDense SMTNil SpAbsent = Just Refl -isDense _ SpSparse{} = Nothing -isDense _ SpAbsent = Nothing -isDense (SMTPair t1 t2) (SpPair s1 s2) -  | Just Refl <- isDense t1 s1, Just Refl <- isDense t2 s2 = Just Refl -  | otherwise = Nothing -isDense (SMTLEither t1 t2) (SpLEither s1 s2) -  | Just Refl <- isDense t1 s1, Just Refl <- isDense t2 s2 = Just Refl -  | otherwise = Nothing -isDense (SMTMaybe t) (SpMaybe s) -  | Just Refl <- isDense t s = Just Refl -  | otherwise = Nothing -isDense (SMTArr _ t) (SpArr s) -  | Just Refl <- isDense t s = Just Refl -  | otherwise = Nothing -isDense (SMTScal _) SpScal = Just Refl - -isAbsent :: Sparse t t' -> Bool -isAbsent (SpSparse s) = isAbsent s -isAbsent SpAbsent = True -isAbsent (SpPair s1 s2) = isAbsent s1 && isAbsent s2 -isAbsent (SpLEither s1 s2) = isAbsent s1 && isAbsent s2 -isAbsent (SpMaybe s) = isAbsent s -isAbsent (SpArr s) = isAbsent s -isAbsent SpScal = False -  sparsePlus :: SMTy t -> Sparse t t' -> Ex env t' -> Ex env t' -> Ex env t'  sparsePlus _ SpAbsent _ _ = ENil ext  sparsePlus t sp e1 e2 | Just Refl <- isDense t sp = EPlus ext t e1 e2 @@ -143,11 +46,6 @@ sparsePlus (SMTArr _ t) (SpArr sp) e1 e2 = ezipWith (sparsePlus t sp (evar (IS I  sparsePlus t@SMTScal{} SpScal e1 e2 = EPlus ext t e1 e2 -data SBool b where -  SF :: SBool False -  ST :: SBool True -deriving instance Show (SBool b) -  data Injection sp a b where    -- | 'Inj' is purposefully also allowed when @sp@ is @False@ so that    -- 'sparsePlusS' can provide injections even if the caller doesn't require | 
