Skip to content

Instantly share code, notes, and snippets.

@clayrat
Created January 30, 2019 13:44
Show Gist options
  • Select an option

  • Save clayrat/0cc5d6f942515df526e414740f93d961 to your computer and use it in GitHub Desktop.

Select an option

Save clayrat/0cc5d6f942515df526e414740f93d961 to your computer and use it in GitHub Desktop.
import Data.Vect
import Data.Fin
%default total
%access public export
data Ty : Type where
TyBool: Ty
TyInt: Ty
TyFun: Ty -> Ty -> Ty
interpTy: Ty -> Type
interpTy TyBool = Bool
interpTy TyInt = Integer
interpTy (TyFun x y) = interpTy x -> interpTy y
using (G:Vect n Ty)
data HasType : Fin n -> Vect n Ty -> Ty -> Type where
Stop : HasType FZ (t :: G) t
Pop : HasType k G t -> HasType (FS k) (u :: G) t
data Expr : Vect n Ty -> Ty -> Type where
Var : HasType i G t -> Expr G t
Val : (x : Integer) -> Expr G TyInt
Lam : Expr (a :: G) t -> Expr G (TyFun a t)
App : Expr G (TyFun a t) -> Expr G a -> Expr G t
Op : (interpTy a -> interpTy b -> interpTy c) ->
Expr G a -> Expr G b -> Expr G c
If : Expr G TyBool ->
Lazy (Expr G a) ->
Lazy (Expr G a) -> Expr G a
data Env : Vect n Ty -> Type where
Nil : Env Nil
(::) : interpTy a -> Env G -> Env (a :: G)
lookup : HasType i G t -> Env G -> interpTy t
lookup Stop (x :: xs) = x
lookup (Pop k) (x :: xs) = lookup k xs
interp : Env G -> Expr G t -> interpTy t
interp env (Var i) = lookup i env
interp env (Val x) = x
interp env (Lam sc) = \x => interp (x :: env) sc
interp env (App f s) = interp env f (interp env s)
interp env (Op op x y) = op (interp env x) (interp env y)
interp env (If x t e) = if interp env x then interp env t
else interp env e
add : Expr G (TyFun TyInt (TyFun TyInt TyInt))
add = Lam (Lam (Op (+) (Var Stop) (Var (Pop Stop))))
partial
fact : Expr G (TyFun TyInt TyInt)
fact = Lam (If (Op (==) (Var Stop) (Val 0))
(Val 1)
(Op (*) (App fact (Op (-) (Var Stop) (Val 1)))
(Var Stop)))
partial
main : IO ()
main = do putStr "Enter a number: "
x <- getLine
printLn (interp [] fact (cast x))
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment