Clean up namespaces in the analysis framework

- Wrap the forward-analysis framework in a Spa.Forward namespace so its
  generic names (analyze, result, joinAll, variablesAt, ...) no longer
  sit flat in Spa, matching the ConstAnalysis/SignAnalysis convention.
- Merge the split Graph namespace in Graphs.lean by relocating buildCfg.
- Use nested namespace Spa / Fixedpoint instead of Spa.Fixedpoint.

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
This commit is contained in:
2026-06-24 13:54:37 -05:00
parent 7fb9d9aa19
commit 93f913a699
8 changed files with 35 additions and 15 deletions

View File

@@ -5,6 +5,8 @@ import Spa.Showable
namespace Spa namespace Spa
open Forward
abbrev ConstLattice : Type := AboveBelow abbrev ConstLattice : Type := AboveBelow
namespace ConstAnalysis namespace ConstAnalysis
@@ -157,7 +159,7 @@ instance eval_valid : ValidExprEvaluator ConstLattice prog := by
theorem analyze_correct {ρ : Env} (hrun : EvalStmt [] prog.rootStmt ρ) : theorem analyze_correct {ρ : Env} (hrun : EvalStmt [] prog.rootStmt ρ) :
variablesAt prog.finalState (result ConstLattice prog) ρ := variablesAt prog.finalState (result ConstLattice prog) ρ :=
Spa.analyze_correct ConstLattice prog hrun Forward.analyze_correct ConstLattice prog hrun
end ConstAnalysis end ConstAnalysis

View File

@@ -5,6 +5,8 @@ import Spa.Fixedpoint
namespace Spa namespace Spa
namespace Forward
variable {L : Type} [Lattice L] {prog : Program} [E : StmtEvaluator L prog] variable {L : Type} [Lattice L] {prog : Program} [E : StmtEvaluator L prog]
def updateVariablesForState (s : prog.State) (sv : StateVariables L prog) : def updateVariablesForState (s : prog.State) (sv : StateVariables L prog) :
@@ -116,4 +118,6 @@ theorem analyze_correct {ρ : Env} (hrun : EvalStmt [] prog.rootStmt ρ) :
variablesAt prog.finalState (result L prog) ρ := variablesAt prog.finalState (result L prog) ρ :=
walkTrace interp_joinForKey_initialState (prog.trace hrun) walkTrace interp_joinForKey_initialState (prog.trace hrun)
end Forward
end Spa end Spa

View File

@@ -2,6 +2,8 @@ import Spa.Analysis.Forward.Evaluation
namespace Spa namespace Spa
namespace Forward
variable {L : Type} [Lattice L] {prog : Program} [E : ExprEvaluator L prog] variable {L : Type} [Lattice L] {prog : Program} [E : ExprEvaluator L prog]
def updateVariablesFromExpression (k : String) (e : Expr) def updateVariablesFromExpression (k : String) (e : Expr)
@@ -51,4 +53,6 @@ instance ExprEvaluator.toStmtEvaluator_valid [LatticeInterpretation L]
(fun hmem => hne (List.mem_singleton.mp hmem)) hk'l₀ (fun hmem => hne (List.mem_singleton.mp hmem)) hk'l₀
exact hvs _ _ hk'l' _ hmem' exact hvs _ _ hk'l' _ hmem'
end Forward
end Spa end Spa

View File

@@ -2,6 +2,8 @@ import Spa.Analysis.Forward.Lattices
namespace Spa namespace Spa
namespace Forward
variable (L : Type) [Lattice L] (prog : Program) variable (L : Type) [Lattice L] (prog : Program)
class StmtEvaluator where class StmtEvaluator where
@@ -23,4 +25,6 @@ class ValidStmtEvaluator [E : StmtEvaluator L prog] [LatticeInterpretation L] :
{bs : BasicStmt}, {bs : BasicStmt},
EvalBasicStmt ρ₁ bs ρ₂ vs ρ₁ E.eval s bs vs ρ₂ EvalBasicStmt ρ₁ bs ρ₂ vs ρ₁ E.eval s bs vs ρ₂
end Forward
end Spa end Spa

View File

@@ -4,6 +4,8 @@ import Spa.Interp
namespace Spa namespace Spa
namespace Forward
variable (L : Type) [Lattice L] (prog : Program) variable (L : Type) [Lattice L] (prog : Program)
abbrev VariableValues : Type := FiniteMap String L prog.vars abbrev VariableValues : Type := FiniteMap String L prog.vars
@@ -96,4 +98,6 @@ theorem interp_foldr {vs : VariableValues L prog}
· exact interp_sup (Or.inl hvs) · exact interp_sup (Or.inl hvs)
· exact interp_sup (Or.inr (ih hmem')) · exact interp_sup (Or.inr (ih hmem'))
end Forward
end Spa end Spa

View File

@@ -5,6 +5,8 @@ import Spa.Showable
namespace Spa namespace Spa
open Forward
inductive Sign where inductive Sign where
| plus | plus
| minus | minus
@@ -215,7 +217,7 @@ instance eval_valid : ValidExprEvaluator SignLattice prog := by
theorem analyze_correct {ρ : Env} (hrun : EvalStmt [] prog.rootStmt ρ) : theorem analyze_correct {ρ : Env} (hrun : EvalStmt [] prog.rootStmt ρ) :
variablesAt prog.finalState (result SignLattice prog) ρ := variablesAt prog.finalState (result SignLattice prog) ρ :=
Spa.analyze_correct SignLattice prog hrun Forward.analyze_correct SignLattice prog hrun
end SignAnalysis end SignAnalysis

View File

@@ -1,6 +1,8 @@
import Spa.Lattice import Spa.Lattice
namespace Spa.Fixedpoint namespace Spa
namespace Fixedpoint
open FiniteHeightLattice (height) open FiniteHeightLattice (height)
@@ -49,4 +51,6 @@ theorem aFix_le (f : αα) (hf : Monotone f)
{a : α} (ha : a = f a) : aFix f hf a := {a : α} (ha : a = f a) : aFix f hf a :=
doStep_le f hf ha _ _ _ _ (by simpa using FiniteHeightLattice.bot_le α a) doStep_le f hf ha _ _ _ _ (by simpa using FiniteHeightLattice.bot_le α a)
end Spa.Fixedpoint end Fixedpoint
end Spa

View File

@@ -89,17 +89,6 @@ def singleton (bss : List BasicStmt) : Graph where
def wrap (g : Graph) : Graph := def wrap (g : Graph) : Graph :=
singleton [] g singleton [] singleton [] g singleton []
end Graph
open Graph in
def buildCfg : Stmt Graph
| .basic bs => Graph.singleton [bs]
| .andThen s₁ s₂ => buildCfg s₁ buildCfg s₂
| .ifElse _ s₁ s₂ => buildCfg s₁ buildCfg s₂
| .whileLoop _ s => Graph.loop (buildCfg s)
namespace Graph
variable (g : Graph) variable (g : Graph)
def indices : List g.Index := List.finRange g.size def indices : List g.Index := List.finRange g.size
@@ -123,4 +112,11 @@ theorem edge_of_mem_predecessors {idx₁ idx₂ : g.Index}
end Graph end Graph
open Graph in
def buildCfg : Stmt Graph
| .basic bs => Graph.singleton [bs]
| .andThen s₁ s₂ => buildCfg s₁ buildCfg s₂
| .ifElse _ s₁ s₂ => buildCfg s₁ buildCfg s₂
| .whileLoop _ s => Graph.loop (buildCfg s)
end Spa end Spa