module Feldspar.Core.Constructs.Logic
( Logic (..)
) where
import Language.Syntactic
import Language.Syntactic.Constructs.Binding
import Feldspar.Core.Types
import Feldspar.Core.Interpretation
import Feldspar.Core.Constructs.Eq
import Feldspar.Core.Constructs.Ord
data Logic a
where
And :: Logic (Bool :-> Bool :-> Full Bool)
Or :: Logic (Bool :-> Bool :-> Full Bool)
Not :: Logic (Bool :-> Full Bool)
instance Semantic Logic
where
semantics And = Sem "(&&)" (&&)
semantics Or = Sem "(||)" (||)
semantics Not = Sem "not" not
semanticInstances ''Logic
instance EvalBind Logic where evalBindSym = evalBindSymDefault
instance AlphaEq dom dom dom env => AlphaEq Logic Logic dom env
where
alphaEqSym = alphaEqSymDefault
instance Sharable Logic
instance Monotonic Logic
instance SizeProp (Logic :|| Type)
where
sizeProp a@(C' _) args = sizePropDefault a args
instance ( (Logic :|| Type) :<: dom
, (EQ :|| Type) :<: dom
, (ORD :|| Type) :<: dom
, Monotonic dom
, OptimizeSuper dom
)
=> Optimize (Logic :|| Type) dom
where
constructFeatOpt _ (C' And) (a :* b :* Nil)
| Just True <- viewLiteral a = return b
| Just False <- viewLiteral a = return a
| Just True <- viewLiteral b = return a
| Just False <- viewLiteral b = return b
| a `alphaEq` b = return a
constructFeatOpt _ (C' Or) (a :* b :* Nil)
| Just True <- viewLiteral a = return a
| Just False <- viewLiteral a = return b
| Just True <- viewLiteral b = return b
| Just False <- viewLiteral b = return a
| a `alphaEq` b = return a
constructFeatOpt _ (C' Not) ((op :$ a) :* Nil)
| Just (C' Not) <- prjF op = return a
constructFeatOpt opts (C' Not) ((op :$ a :$ b) :* Nil)
| Just (C' Equal) <- prjF op = constructFeat opts (c' NotEqual) (a :* b :* Nil)
| Just (C' NotEqual) <- prjF op = constructFeat opts (c' Equal) (a :* b :* Nil)
| Just (C' LTH) <- prjF op = constructFeat opts (c' GTE) (a :* b :* Nil)
| Just (C' GTH) <- prjF op = constructFeat opts (c' LTE) (a :* b :* Nil)
| Just (C' LTE) <- prjF op = constructFeat opts (c' GTH) (a :* b :* Nil)
| Just (C' GTE) <- prjF op = constructFeat opts (c' LTH) (a :* b :* Nil)
constructFeatOpt opts a args = constructFeatUnOpt opts a args
constructFeatUnOpt opts x@(C' _) = constructFeatUnOptDefault opts x