Tooling to make copies of lattice structures #
Sometimes it is useful to make a copy of a lattice structure where one replaces the data parts with provably equal definitions that have better definitional properties.
A function to create a provable equal copy of a top order with possibly different definitional equalities.
Equations
- c.copy top eq_top le_eq = OrderTop.mk ⋯
Instances For
A function to create a provable equal copy of a bottom order with possibly different definitional equalities.
Equations
- c.copy bot eq_bot le_eq = OrderBot.mk ⋯
Instances For
A function to create a provable equal copy of a bounded order with possibly different definitional equalities.
Equations
- c.copy top eq_top bot eq_bot le_eq = BoundedOrder.mk
Instances For
A function to create a provable equal copy of a lattice with possibly different definitional equalities.
Equations
- c.copy le eq_le sup eq_sup inf eq_inf = Lattice.mk ⋯ ⋯ ⋯
Instances For
A function to create a provable equal copy of a distributive lattice with possibly different definitional equalities.
Equations
- c.copy le eq_le sup eq_sup inf eq_inf = DistribLattice.mk ⋯
Instances For
A function to create a provable equal copy of a generalised heyting algebra with possibly different definitional equalities.
Equations
- One or more equations did not get rendered due to their size.
Instances For
A function to create a provable equal copy of a generalised coheyting algebra with possibly different definitional equalities.
Equations
- One or more equations did not get rendered due to their size.
Instances For
A function to create a provable equal copy of a heyting algebra with possibly different definitional equalities.
Equations
- c.copy le eq_le top eq_top bot eq_bot sup eq_sup inf eq_inf himp eq_himp compl eq_compl = let __spread.0 := HeytingAlgebra.toOrderBot.copy bot eq_bot ⋯; HeytingAlgebra.mk ⋯
Instances For
A function to create a provable equal copy of a coheyting algebra with possibly different definitional equalities.
Equations
- c.copy le eq_le top eq_top bot eq_bot sup eq_sup inf eq_inf sdiff eq_sdiff hnot eq_hnot = let __spread.0 := CoheytingAlgebra.toOrderTop.copy top eq_top ⋯; CoheytingAlgebra.mk ⋯
Instances For
A function to create a provable equal copy of a biheyting algebra with possibly different definitional equalities.
Equations
- One or more equations did not get rendered due to their size.
Instances For
A function to create a provable equal copy of a complete lattice with possibly different definitional equalities.
Equations
- c.copy le eq_le top eq_top bot eq_bot sup eq_sup inf eq_inf sSup eq_sSup sInf eq_sInf = CompleteLattice.mk ⋯ ⋯ ⋯ ⋯ ⋯ ⋯
Instances For
A function to create a provable equal copy of a frame with possibly different definitional equalities.
Equations
- One or more equations did not get rendered due to their size.
Instances For
A function to create a provable equal copy of a coframe with possibly different definitional equalities.
Equations
- One or more equations did not get rendered due to their size.
Instances For
A function to create a provable equal copy of a complete distributive lattice with possibly different definitional equalities.
Equations
- One or more equations did not get rendered due to their size.
Instances For
A function to create a provable equal copy of a conditionally complete lattice with possibly different definitional equalities.
Equations
- c.copy le eq_le sup eq_sup inf eq_inf sSup eq_sSup sInf eq_sInf = ConditionallyCompleteLattice.mk ⋯ ⋯ ⋯ ⋯