Up-sets and down-sets #
This file proves results on the upper and lower sets in an order.
Main declarations #
upperClosure
: The greatest upper set containing a set.lowerClosure
: The least lower set containing a set.UpperSet.Ici
: Principal upper set.Set.Ici
as an upper set.UpperSet.Ioi
: Strict principal upper set.Set.Ioi
as an upper set.LowerSet.Iic
: Principal lower set.Set.Iic
as a lower set.LowerSet.Iio
: Strict principal lower set.Set.Iio
as a lower set.
Notation #
×ˢ
is notation forUpperSet.prod
/LowerSet.prod
.
Notes #
Upper sets are ordered by reverse inclusion. This convention is motivated by the fact that this
makes them order-isomorphic to lower sets and antichains, and matches the convention on Filter
.
TODO #
Lattice structure on antichains. Order equivalence between upper/lower sets and antichains.
Unbundled upper/lower sets #
Alias of the reverse direction of isLowerSet_preimage_ofDual_iff
.
Alias of the reverse direction of isUpperSet_preimage_ofDual_iff
.
Alias of the reverse direction of isLowerSet_preimage_toDual_iff
.
Alias of the reverse direction of isUpperSet_preimage_toDual_iff
.
Alias of the forward direction of isUpperSet_iff_Ici_subset
.
Alias of the forward direction of isLowerSet_iff_Iic_subset
.
Upper/lower sets and Fibrations #
Alias of Relation.Fibration.isLowerSet_image
.
Alias of Relation.Fibration.isUpperSet_image
.
Bundled upper/lower sets #
Equations
- UpperSet.instSetLike = { coe := UpperSet.carrier, coe_injective' := ⋯ }
Equations
- LowerSet.instSetLike = { coe := LowerSet.carrier, coe_injective' := ⋯ }
Order #
Equations
- UpperSet.instMax = { max := fun (s t : UpperSet α) => { carrier := ↑s ∩ ↑t, upper' := ⋯ } }
Equations
- UpperSet.instMin = { min := fun (s t : UpperSet α) => { carrier := ↑s ∪ ↑t, upper' := ⋯ } }
Equations
- UpperSet.instTop = { top := { carrier := ∅, upper' := ⋯ } }
Equations
- UpperSet.instBot = { bot := { carrier := Set.univ, upper' := ⋯ } }
Equations
- UpperSet.instSupSet = { sSup := fun (S : Set (UpperSet α)) => { carrier := ⋂ s ∈ S, ↑s, upper' := ⋯ } }
Equations
- UpperSet.instInfSet = { sInf := fun (S : Set (UpperSet α)) => { carrier := ⋃ s ∈ S, ↑s, upper' := ⋯ } }
Equations
- UpperSet.completeLattice = Function.Injective.completeLattice (⇑OrderDual.toDual ∘ SetLike.coe) ⋯ ⋯ ⋯ ⋯ ⋯ ⋯ ⋯
Equations
- One or more equations did not get rendered due to their size.
Equations
- UpperSet.instInhabited = { default := ⊥ }
Equations
- LowerSet.instMax = { max := fun (s t : LowerSet α) => { carrier := ↑s ∪ ↑t, lower' := ⋯ } }
Equations
- LowerSet.instMin = { min := fun (s t : LowerSet α) => { carrier := ↑s ∩ ↑t, lower' := ⋯ } }
Equations
- LowerSet.instTop = { top := { carrier := Set.univ, lower' := ⋯ } }
Equations
- LowerSet.instBot = { bot := { carrier := ∅, lower' := ⋯ } }
Equations
- LowerSet.instSupSet = { sSup := fun (S : Set (LowerSet α)) => { carrier := ⋃ s ∈ S, ↑s, lower' := ⋯ } }
Equations
- LowerSet.instInfSet = { sInf := fun (S : Set (LowerSet α)) => { carrier := ⋂ s ∈ S, ↑s, lower' := ⋯ } }
Equations
Equations
- One or more equations did not get rendered due to their size.
Equations
- LowerSet.instInhabited = { default := ⊥ }
Complement #
Upper sets are order-isomorphic to lower sets under complementation.
Equations
- upperSetIsoLowerSet = { toFun := UpperSet.compl, invFun := LowerSet.compl, left_inv := ⋯, right_inv := ⋯, map_rel_iff' := ⋯ }
Instances For
Equations
Equations
Map #
Principal sets #
The smallest upper set containing a given element.
Equations
- UpperSet.Ici a = { carrier := Set.Ici a, upper' := ⋯ }
Instances For
The smallest upper set containing a given element.
Equations
- UpperSet.Ioi a = { carrier := Set.Ioi a, upper' := ⋯ }
Instances For
Principal lower set. Set.Iic
as a lower set. The smallest lower set containing a given
element.
Equations
- LowerSet.Iic a = { carrier := Set.Iic a, lower' := ⋯ }
Instances For
Strict principal lower set. Set.Iio
as a lower set.
Equations
- LowerSet.Iio a = { carrier := Set.Iio a, lower' := ⋯ }
Instances For
The greatest upper set containing a given set.
Equations
- upperClosure s = { carrier := {x : α | ∃ a ∈ s, a ≤ x}, upper' := ⋯ }
Instances For
The least lower set containing a given set.
Equations
- lowerClosure s = { carrier := {x : α | ∃ a ∈ s, x ≤ a}, lower' := ⋯ }
Instances For
Equations
Equations
upperClosure
forms a reversed Galois insertion with the coercion from upper sets to sets.
Equations
- One or more equations did not get rendered due to their size.
Instances For
lowerClosure
forms a Galois insertion with the coercion from lower sets to sets.
Equations
- giLowerClosureCoe = { choice := fun (s : Set α) (hs : ↑(lowerClosure s) ≤ s) => { carrier := s, lower' := ⋯ }, gc := ⋯, le_l_u := ⋯, choice_eq := ⋯ }
Instances For
Alias of the reverse direction of bddAbove_lowerClosure
.
Alias of the forward direction of bddAbove_lowerClosure
.
Alias of the reverse direction of bddBelow_upperClosure
.
Alias of the forward direction of bddBelow_upperClosure
.
Set Difference #
The biggest lower subset of a lower set s
disjoint from a set t
.
Equations
- s.sdiff t = { carrier := ↑s \ ↑(upperClosure t), lower' := ⋯ }
Instances For
The biggest lower subset of a lower set s
not containing an element a
.
Equations
- s.erase a = { carrier := ↑s \ ↑(UpperSet.Ici a), lower' := ⋯ }
Instances For
The biggest upper subset of a upper set s
disjoint from a set t
.
Equations
- s.sdiff t = { carrier := ↑s \ ↑(lowerClosure t), upper' := ⋯ }
Instances For
The biggest upper subset of a upper set s
not containing an element a
.
Equations
- s.erase a = { carrier := ↑s \ ↑(LowerSet.Iic a), upper' := ⋯ }
Instances For
Product #
Equations
- UpperSet.instSProd = { sprod := UpperSet.prod }
Equations
- LowerSet.instSProd = { sprod := LowerSet.prod }