2026-06-09 18:36:43 -07:00
|
|
|
import Spa.Lattice
|
|
|
|
|
import Spa.Fixedpoint
|
|
|
|
|
import Spa.Isomorphism
|
2026-06-09 18:48:02 -07:00
|
|
|
import Spa.Lattice.Unit
|
|
|
|
|
import Spa.Lattice.Prod
|
|
|
|
|
import Spa.Lattice.AboveBelow
|
Lean migration: Phase 4 (IterProd + FiniteMap lattices)
- Spa.Lattice.IterProd: k-fold product, recursive Lattice instance,
fixed height k*hA + hB, bot = build of bottoms
- Spa.Lattice.FiniteMap: spine-pinned assoc lists ({l // l.map fst = ks});
with = the 1100-line Map.agda collapses into positional 'combine'.
Same lemma inventory (membership, locate, updating, GeneralizedUpdate,
valuesAt, Provenance-union, le_of_mem_mem) — Nodup is now an explicit
hypothesis where the Agda Map carried it intrinsically. Fixed height
|ks|*hB still via transport along the IterProd isomorphism, which no
longer needs Unique ks (representation is canonical).
Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
2026-06-09 19:12:39 -07:00
|
|
|
import Spa.Lattice.IterProd
|
|
|
|
|
import Spa.Lattice.FiniteMap
|
2026-06-09 19:30:42 -07:00
|
|
|
import Spa.Language.Base
|
|
|
|
|
import Spa.Language.Semantics
|
|
|
|
|
import Spa.Language.Graphs
|
|
|
|
|
import Spa.Language.Traces
|
|
|
|
|
import Spa.Language.Properties
|
|
|
|
|
import Spa.Language
|
2026-06-09 20:14:53 -07:00
|
|
|
import Spa.Analysis.Forward.Lattices
|
|
|
|
|
import Spa.Analysis.Forward.Evaluation
|
|
|
|
|
import Spa.Analysis.Forward.Adapters
|
|
|
|
|
import Spa.Analysis.Forward
|
2026-06-09 20:52:08 -07:00
|
|
|
import Spa.Showable
|
|
|
|
|
import Spa.Analysis.Utils
|
|
|
|
|
import Spa.Analysis.Sign
|
|
|
|
|
import Spa.Analysis.Constant
|