module A201605.AbelChapmanExtended.Syntax where
data Ty : Set where
⊥ : Ty
_⇒_ : (a b : Ty) → Ty
_∧_ : (a b : Ty) → Ty
⊤ : Ty
infixr 5 _⇒_
data Cx : Set where
∅ : Cx
_,_ : (Γ : Cx) (a : Ty) → Cx
data Var : Cx → Ty → Set where
top : ∀ {Γ a} → Var (Γ , a) a
pop : ∀ {Γ a b} (x : Var Γ a) → Var (Γ , b) a
data Tm (Γ : Cx) : Ty → Set where
loop : ∀ {c} (t : Tm Γ ⊥) → Tm Γ c
var : ∀ {a} (x : Var Γ a) → Tm Γ a
lam : ∀ {a b} (t : Tm (Γ , a) b) → Tm Γ (a ⇒ b)
app : ∀ {a b} (t : Tm Γ (a ⇒ b)) (u : Tm Γ a) → Tm Γ b
pair : ∀ {a b} (t : Tm Γ a) (u : Tm Γ b) → Tm Γ (a ∧ b)
fst : ∀ {a b} (t : Tm Γ (a ∧ b)) → Tm Γ a
snd : ∀ {a b} (t : Tm Γ (a ∧ b)) → Tm Γ b
unit : Tm Γ ⊤
data Ne (Ξ : Cx → Ty → Set) (Γ : Cx) : Ty → Set where
loop : ∀ {c} → Ne Ξ Γ ⊥ → Ne Ξ Γ c
var : ∀ {a} → Var Γ a → Ne Ξ Γ a
app : ∀ {a b} → Ne Ξ Γ (a ⇒ b) → Ξ Γ a → Ne Ξ Γ b
fst : ∀ {a b} → Ne Ξ Γ (a ∧ b) → Ne Ξ Γ a
snd : ∀ {a b} → Ne Ξ Γ (a ∧ b) → Ne Ξ Γ b
data Nf (Δ : Cx) : Ty → Set where
ne : (n : Ne Nf Δ ⊥) → Nf Δ ⊥
lam : ∀ {a b} (n : Nf (Δ , a) b) → Nf Δ (a ⇒ b)
pair : ∀ {a b} (n : Nf Δ a) (m : Nf Δ b) → Nf Δ (a ∧ b)
unit : Nf Δ ⊤
mutual
data Val (Δ : Cx) : Ty → Set where
ne : ∀ {a} (v : Ne Val Δ a) → Val Δ a
lam : ∀ {Γ a b} (t : Tm (Γ , a) b) (ρ : Env Δ Γ) → Val Δ (a ⇒ b)
pair : ∀ {a b} (v : Val Δ a) (w : Val Δ b) → Val Δ (a ∧ b)
unit : Val Δ ⊤
data Env (Δ : Cx) : Cx → Set where
∅ : Env Δ ∅
_,_ : ∀ {Γ a} (ρ : Env Δ Γ) (w : Val Δ a) → Env Δ (Γ , a)
v₀ : ∀ {Γ a} → Tm (Γ , a) a
v₀ = var top
v₁ : ∀ {Γ a b} → Tm ((Γ , a) , b) a
v₁ = var (pop top)
v₂ : ∀ {Γ a b c} → Tm (((Γ , a) , b) , c) a
v₂ = var (pop (pop top))
nev₀ : ∀ {Δ a} → Val (Δ , a) a
nev₀ = ne (var top)