diff options
author | Jacques Comeaux <jacquesrcomeaux@protonmail.com> | 2024-02-16 20:29:43 -0600 |
---|---|---|
committer | Jacques Comeaux <jacquesrcomeaux@protonmail.com> | 2024-02-16 20:29:43 -0600 |
commit | 14a4f246b61e763cea32281e3a5f73bde38fe5d4 (patch) | |
tree | 4cdb5bdae2abcc8d8f1f80a50e017951da7de649 /src/Circuit.hs | |
parent | 5da77fee409e8f4d80563c4283bfe71c8e272266 (diff) |
Add helper function for merging finite sets
Diffstat (limited to 'src/Circuit.hs')
-rw-r--r-- | src/Circuit.hs | 41 |
1 files changed, 0 insertions, 41 deletions
diff --git a/src/Circuit.hs b/src/Circuit.hs deleted file mode 100644 index d64e8c1..0000000 --- a/src/Circuit.hs +++ /dev/null @@ -1,41 +0,0 @@ -module Circuit () where - -import RIO - -import Data.Kind - - -data Nat = Zero | Succ Nat | Plus Nat Nat - -data Env :: Nat -> Type -> Type where - Leaf :: Env Zero a - Cons :: a -> Env n a -> Env (Succ n) a - Node :: Env l a -> Env r a -> Env (Plus l r) a - -data Circuit :: Nat -> Type -> Type where - Con :: Int -> Circuit Zero t - Var :: t -> Circuit Zero t - Add :: Circuit m t -> Circuit n t -> Circuit (Plus m n) t - Let :: Circuit m t -> (t -> Circuit n t) -> Circuit (Plus m n) t - Fix :: (t -> Circuit n t) -> Circuit n t - Reg :: Circuit n t -> Circuit (Succ n) t - -eval :: (Circuit n Int, Env n Int) -> Int -eval (Con i , _) = i -eval (Var x , _) = x -eval (Add e1 e2, Node l r) = eval (e1, l) + eval (e2, r) -eval (Let e1 e2, Node l r) = eval (e2 (eval (e1, l)), r) -eval (Fix e , env) = fix (\x -> eval (e x, env)) -eval (Reg _ , Cons v _) = v - -step :: (Circuit n Int, Env n Int) -> Env n Int -step (Con i , _) = Leaf -step (Var x , _) = Leaf -step (Add e1 e2, Node l r) = Node (step (e1, l)) (step (e2, r)) -step (Let e1 e2, Node l r) = Node (step (e1, l)) (step (e2 (eval (e1, l)), r)) -step (Fix e , env) = step (fix (\e' -> e (eval (e', env))), env) -step (Reg e , Cons _ vs) = Cons (eval (e, vs)) (step (e, vs)) - -acc i = Fix (\x -> Reg (Add (Var x) (Var i))) -fib = Fix (\x -> Reg (acc x)) -pipe = Reg (Reg (Reg (Reg (Reg (Reg (Con 6)))))) |