Delete more LLM-generated comments from the migration
This commit is contained in:
@@ -1,21 +1,3 @@
|
||||
/-
|
||||
Port of `Language/Semantics.agda`.
|
||||
|
||||
Correspondence:
|
||||
Value (↑ᶻ) ↦ Value.int
|
||||
Env ↦ Env (= List (String × Value))
|
||||
_∈_ (env lookup) ↦ Env.Mem
|
||||
_,_⇒ᵉ_ ↦ EvalExpr
|
||||
_,_⇒ᵇ_ ↦ EvalBasicStmt
|
||||
_,_⇒ᵇˢ_ ↦ EvalBasicStmts
|
||||
_,_⇒ˢ_ ↦ EvalStmt
|
||||
LatticeInterpretation:
|
||||
⟦_⟧ ↦ interp
|
||||
⟦⟧-respects-≈ ↦ (trivial with `=`; field dropped)
|
||||
⟦⟧-⊔-∨ ↦ interp_sup
|
||||
⟦⟧-⊓-∧ ↦ interp_inf
|
||||
(the `Utils` combinators `_⇒_`, `_∨_`, `_∧_` are inlined as plain logic)
|
||||
-/
|
||||
import Spa.Language.Base
|
||||
import Spa.Lattice
|
||||
|
||||
@@ -27,13 +9,11 @@ inductive Value where
|
||||
|
||||
def Env : Type := List (String × Value)
|
||||
|
||||
/-- Agda: `_∈_` on environments — lookup respecting shadowing. -/
|
||||
inductive Env.Mem : String × Value → Env → Prop
|
||||
| here (s : String) (v : Value) (ρ : Env) : Env.Mem (s, v) ((s, v) :: ρ)
|
||||
| there (s s' : String) (v v' : Value) (ρ : Env) :
|
||||
¬(s = s') → Env.Mem (s, v) ρ → Env.Mem (s, v) ((s', v') :: ρ)
|
||||
|
||||
/-- Agda: `_,_⇒ᵉ_`. -/
|
||||
inductive EvalExpr : Env → Expr → Value → Prop
|
||||
| num (ρ : Env) (n : ℕ) : EvalExpr ρ (.num n) (.int n)
|
||||
| var (ρ : Env) (x : String) (v : Value) :
|
||||
@@ -45,20 +25,17 @@ inductive EvalExpr : Env → Expr → Value → Prop
|
||||
EvalExpr ρ e₁ (.int z₁) → EvalExpr ρ e₂ (.int z₂) →
|
||||
EvalExpr ρ (.sub e₁ e₂) (.int (z₁ - z₂))
|
||||
|
||||
/-- Agda: `_,_⇒ᵇ_`. -/
|
||||
inductive EvalBasicStmt : Env → BasicStmt → Env → Prop
|
||||
| noop (ρ : Env) : EvalBasicStmt ρ .noop ρ
|
||||
| assign (ρ : Env) (x : String) (e : Expr) (v : Value) :
|
||||
EvalExpr ρ e v → EvalBasicStmt ρ (.assign x e) ((x, v) :: ρ)
|
||||
|
||||
/-- Agda: `_,_⇒ᵇˢ_`. -/
|
||||
inductive EvalBasicStmts : Env → List BasicStmt → Env → Prop
|
||||
| nil {ρ : Env} : EvalBasicStmts ρ [] ρ
|
||||
| cons {ρ₁ ρ₂ ρ₃ : Env} {bs : BasicStmt} {bss : List BasicStmt} :
|
||||
EvalBasicStmt ρ₁ bs ρ₂ → EvalBasicStmts ρ₂ bss ρ₃ →
|
||||
EvalBasicStmts ρ₁ (bs :: bss) ρ₃
|
||||
|
||||
/-- Agda: `_,_⇒ˢ_`. -/
|
||||
inductive EvalStmt : Env → Stmt → Env → Prop
|
||||
| basic (ρ₁ ρ₂ : Env) (bs : BasicStmt) :
|
||||
EvalBasicStmt ρ₁ bs ρ₂ → EvalStmt ρ₁ (.basic bs) ρ₂
|
||||
@@ -79,8 +56,6 @@ inductive EvalStmt : Env → Stmt → Env → Prop
|
||||
EvalExpr ρ e (.int 0) →
|
||||
EvalStmt ρ (.whileLoop e s) ρ
|
||||
|
||||
/-- Agda: `LatticeInterpretation` (used there as an instance argument `⦃·⦄`,
|
||||
hence a typeclass here). -/
|
||||
class LatticeInterpretation (L : Type*) [Lattice L] where
|
||||
interp : L → Value → Prop
|
||||
interp_sup : ∀ {l₁ l₂ : L} (v : Value),
|
||||
|
||||
Reference in New Issue
Block a user