Documentation

Mathlib.Order.CompactlyGenerated.Basic

Compactness properties for complete lattices #

For complete lattices, there are numerous equivalent ways to express the fact that the relation > is well-founded. In this file we define three especially-useful characterisations and provide proofs that they are indeed equivalent to well-foundedness.

Main definitions #

Main results #

The main result is that the following four conditions are equivalent for a complete lattice:

This is demonstrated by means of the following four lemmas:

We also show well-founded lattices are compactly generated (CompleteLattice.isCompactlyGenerated_of_wellFounded).

References #

Tags #

complete lattice, well-founded, compact

A compactness property for a complete lattice is that any sup-closed non-empty subset contains its sSup.

Equations
Instances For

    A compactness property for a complete lattice is that any subset has a finite subset with the same sSup.

    Equations
    Instances For

      An element k of a complete lattice is said to be compact if any set with sSup above k has a finite subset with sSup above k. Such an element is also called "finite" or "S-compact".

      Equations
      Instances For
        theorem CompleteLattice.isCompactElement_iff {α : Type u} [CompleteLattice α] (k : α) :
        CompleteLattice.IsCompactElement k ∀ (ι : Type u) (s : ια), k iSup s∃ (t : Finset ι), k t.sup s
        theorem CompleteLattice.isCompactElement_iff_le_of_directed_sSup_le (α : Type u_2) [CompleteLattice α] (k : α) :
        CompleteLattice.IsCompactElement k ∀ (s : Set α), s.NonemptyDirectedOn (fun (x1 x2 : α) => x1 x2) sk sSup sxs, k x

        An element k is compact if and only if any directed set with sSup above k already got above k at some point in the set.

        theorem CompleteLattice.IsCompactElement.exists_finset_of_le_iSup (α : Type u_2) [CompleteLattice α] {k : α} (hk : CompleteLattice.IsCompactElement k) {ι : Type u_3} (f : ια) (h : k ⨆ (i : ι), f i) :
        ∃ (s : Finset ι), k is, f i
        theorem CompleteLattice.IsCompactElement.directed_sSup_lt_of_lt {α : Type u_3} [CompleteLattice α] {k : α} (hk : CompleteLattice.IsCompactElement k) {s : Set α} (hemp : s.Nonempty) (hdir : DirectedOn (fun (x1 x2 : α) => x1 x2) s) (hbelow : xs, x < k) :
        sSup s < k

        A compact element k has the property that any directed set lying strictly below k has its sSup strictly below k.

        theorem CompleteLattice.isCompactElement_finsetSup {α : Type u_3} {β : Type u_4} [CompleteLattice α] {f : βα} (s : Finset β) (h : xs, CompleteLattice.IsCompactElement (f x)) :
        theorem WellFoundedGT.finite_of_sSupIndep {α : Type u_2} [CompleteLattice α] [WellFoundedGT α] {s : Set α} (hs : sSupIndep s) :
        s.Finite
        @[deprecated WellFoundedGT.finite_of_sSupIndep]

        Alias of WellFoundedGT.finite_of_sSupIndep.

        theorem WellFoundedGT.finite_ne_bot_of_iSupIndep {α : Type u_2} [CompleteLattice α] [WellFoundedGT α] {ι : Type u_3} {t : ια} (ht : iSupIndep t) :
        {i : ι | t i }.Finite
        @[deprecated WellFoundedGT.finite_ne_bot_of_iSupIndep]
        theorem CompleteLattice.WellFoundedGT.finite_ne_bot_of_independent {α : Type u_2} [CompleteLattice α] [WellFoundedGT α] {ι : Type u_3} {t : ια} (ht : iSupIndep t) :
        {i : ι | t i }.Finite

        Alias of WellFoundedGT.finite_ne_bot_of_iSupIndep.

        theorem WellFoundedGT.finite_of_iSupIndep {α : Type u_2} [CompleteLattice α] [WellFoundedGT α] {ι : Type u_3} {t : ια} (ht : iSupIndep t) (h_ne_bot : ∀ (i : ι), t i ) :
        @[deprecated WellFoundedGT.finite_of_iSupIndep]
        theorem CompleteLattice.WellFoundedGT.finite_of_independent {α : Type u_2} [CompleteLattice α] [WellFoundedGT α] {ι : Type u_3} {t : ια} (ht : iSupIndep t) (h_ne_bot : ∀ (i : ι), t i ) :

        Alias of WellFoundedGT.finite_of_iSupIndep.

        theorem WellFoundedLT.finite_of_sSupIndep {α : Type u_2} [CompleteLattice α] [WellFoundedLT α] {s : Set α} (hs : sSupIndep s) :
        s.Finite
        @[deprecated WellFoundedLT.finite_of_sSupIndep]

        Alias of WellFoundedLT.finite_of_sSupIndep.

        theorem WellFoundedLT.finite_ne_bot_of_iSupIndep {α : Type u_2} [CompleteLattice α] [WellFoundedLT α] {ι : Type u_3} {t : ια} (ht : iSupIndep t) :
        {i : ι | t i }.Finite
        @[deprecated WellFoundedLT.finite_ne_bot_of_iSupIndep]
        theorem CompleteLattice.WellFoundedLT.finite_ne_bot_of_independent {α : Type u_2} [CompleteLattice α] [WellFoundedLT α] {ι : Type u_3} {t : ια} (ht : iSupIndep t) :
        {i : ι | t i }.Finite

        Alias of WellFoundedLT.finite_ne_bot_of_iSupIndep.

        theorem WellFoundedLT.finite_of_iSupIndep {α : Type u_2} [CompleteLattice α] [WellFoundedLT α] {ι : Type u_3} {t : ια} (ht : iSupIndep t) (h_ne_bot : ∀ (i : ι), t i ) :
        @[deprecated WellFoundedLT.finite_of_iSupIndep]
        theorem CompleteLattice.WellFoundedLT.finite_of_independent {α : Type u_2} [CompleteLattice α] [WellFoundedLT α] {ι : Type u_3} {t : ια} (ht : iSupIndep t) (h_ne_bot : ∀ (i : ι), t i ) :

        Alias of WellFoundedLT.finite_of_iSupIndep.

        A complete lattice is said to be compactly generated if any element is the sSup of compact elements.

        Instances
          @[simp]
          theorem le_iff_compact_le_imp {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {a b : α} :
          a b ∀ (c : α), CompleteLattice.IsCompactElement cc ac b
          theorem DirectedOn.inf_sSup_eq {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {a : α} {s : Set α} (h : DirectedOn (fun (x1 x2 : α) => x1 x2) s) :
          a sSup s = bs, a b

          This property is sometimes referred to as α being upper continuous.

          theorem DirectedOn.sSup_inf_eq {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {a : α} {s : Set α} (h : DirectedOn (fun (x1 x2 : α) => x1 x2) s) :
          sSup s a = bs, b a

          This property is sometimes referred to as α being upper continuous.

          theorem Directed.inf_iSup_eq {ι : Sort u_1} {α : Type u_2} [CompleteLattice α] {f : ια} [IsCompactlyGenerated α] {a : α} (h : Directed (fun (x1 x2 : α) => x1 x2) f) :
          a ⨆ (i : ι), f i = ⨆ (i : ι), a f i
          theorem Directed.iSup_inf_eq {ι : Sort u_1} {α : Type u_2} [CompleteLattice α] {f : ια} [IsCompactlyGenerated α] {a : α} (h : Directed (fun (x1 x2 : α) => x1 x2) f) :
          (⨆ (i : ι), f i) a = ⨆ (i : ι), f i a
          theorem DirectedOn.disjoint_sSup_right {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {a : α} {s : Set α} (h : DirectedOn (fun (x1 x2 : α) => x1 x2) s) :
          Disjoint a (sSup s) ∀ ⦃b : α⦄, b sDisjoint a b
          theorem DirectedOn.disjoint_sSup_left {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {a : α} {s : Set α} (h : DirectedOn (fun (x1 x2 : α) => x1 x2) s) :
          Disjoint (sSup s) a ∀ ⦃b : α⦄, b sDisjoint b a
          theorem Directed.disjoint_iSup_right {ι : Sort u_1} {α : Type u_2} [CompleteLattice α] {f : ια} [IsCompactlyGenerated α] {a : α} (h : Directed (fun (x1 x2 : α) => x1 x2) f) :
          Disjoint a (⨆ (i : ι), f i) ∀ (i : ι), Disjoint a (f i)
          theorem Directed.disjoint_iSup_left {ι : Sort u_1} {α : Type u_2} [CompleteLattice α] {f : ια} [IsCompactlyGenerated α] {a : α} (h : Directed (fun (x1 x2 : α) => x1 x2) f) :
          Disjoint (⨆ (i : ι), f i) a ∀ (i : ι), Disjoint (f i) a
          theorem inf_sSup_eq_iSup_inf_sup_finset {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {a : α} {s : Set α} :
          a sSup s = ⨆ (t : Finset α), ⨆ (_ : t s), a t.sup id

          This property is equivalent to α being upper continuous.

          theorem sSupIndep_iff_finite {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {s : Set α} :
          sSupIndep s ∀ (t : Finset α), t ssSupIndep t
          @[deprecated sSupIndep_iff_finite]
          theorem CompleteLattice.setIndependent_iff_finite {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {s : Set α} :
          sSupIndep s ∀ (t : Finset α), t ssSupIndep t

          Alias of sSupIndep_iff_finite.

          theorem iSupIndep_iff_supIndep_of_injOn {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {ι : Type u_3} {f : ια} (hf : Set.InjOn f {i : ι | f i }) :
          iSupIndep f ∀ (s : Finset ι), s.SupIndep f
          @[deprecated iSupIndep_iff_supIndep_of_injOn]
          theorem CompleteLattice.independent_iff_supIndep_of_injOn {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {ι : Type u_3} {f : ια} (hf : Set.InjOn f {i : ι | f i }) :
          iSupIndep f ∀ (s : Finset ι), s.SupIndep f

          Alias of iSupIndep_iff_supIndep_of_injOn.

          theorem sSupIndep_iUnion_of_directed {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {η : Type u_3} {s : ηSet α} (hs : Directed (fun (x1 x2 : Set α) => x1 x2) s) (h : ∀ (i : η), sSupIndep (s i)) :
          sSupIndep (⋃ (i : η), s i)
          @[deprecated sSupIndep_iUnion_of_directed]
          theorem CompleteLattice.setIndependent_iUnion_of_directed {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {η : Type u_3} {s : ηSet α} (hs : Directed (fun (x1 x2 : Set α) => x1 x2) s) (h : ∀ (i : η), sSupIndep (s i)) :
          sSupIndep (⋃ (i : η), s i)

          Alias of sSupIndep_iUnion_of_directed.

          theorem iSupIndep_sUnion_of_directed {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {s : Set (Set α)} (hs : DirectedOn (fun (x1 x2 : Set α) => x1 x2) s) (h : as, sSupIndep a) :
          @[deprecated iSupIndep_sUnion_of_directed]
          theorem CompleteLattice.independent_sUnion_of_directed {α : Type u_2} [CompleteLattice α] [IsCompactlyGenerated α] {s : Set (Set α)} (hs : DirectedOn (fun (x1 x2 : Set α) => x1 x2) s) (h : as, sSupIndep a) :

          Alias of iSupIndep_sUnion_of_directed.

          @[deprecated CompleteLattice.IsSupClosedCompact.wellFoundedGT]

          Alias of CompleteLattice.IsSupClosedCompact.wellFoundedGT.

          @[deprecated CompleteLattice.IsSupFiniteCompact.wellFoundedGT]

          Alias of the reverse direction of CompleteLattice.wellFoundedGT_iff_isSupFiniteCompact.


          Alias of the reverse direction of CompleteLattice.wellFoundedGT_iff_isSupFiniteCompact.

          @[deprecated CompleteLattice.WellFoundedGT.isSupClosedCompact]

          Alias of the reverse direction of CompleteLattice.isSupClosedCompact_iff_wellFoundedGT.


          Alias of the reverse direction of CompleteLattice.isSupClosedCompact_iff_wellFoundedGT.

          @[deprecated WellFoundedGT.finite_of_sSupIndep]

          Alias of WellFoundedGT.finite_of_sSupIndep.

          @[deprecated WellFoundedGT.finite_ne_bot_of_iSupIndep]
          theorem CompleteLattice.WellFounded.finite_ne_bot_of_independent {α : Type u_2} [CompleteLattice α] [WellFoundedGT α] {ι : Type u_3} {t : ια} (ht : iSupIndep t) :
          {i : ι | t i }.Finite

          Alias of WellFoundedGT.finite_ne_bot_of_iSupIndep.

          @[deprecated WellFoundedGT.finite_of_iSupIndep]
          theorem CompleteLattice.WellFounded.finite_of_independent {α : Type u_2} [CompleteLattice α] [WellFoundedGT α] {ι : Type u_3} {t : ια} (ht : iSupIndep t) (h_ne_bot : ∀ (i : ι), t i ) :

          Alias of WellFoundedGT.finite_of_iSupIndep.

          @[deprecated CompleteLattice.isCompactlyGenerated_of_wellFoundedGT]

          Alias of CompleteLattice.isCompactlyGenerated_of_wellFoundedGT.

          A compact element k has the property that any b < k lies below a "maximal element below k", which is to say [⊥, k] is coatomic.

          @[instance 100]

          See [Lemma 5.1][calugareanu].

          Now we will prove that a compactly generated modular atomistic lattice is a complemented lattice. Most explicitly, every element is the complement of a supremum of indepedendent atoms.

          theorem exists_sSupIndep_isCompl_sSup_atoms {α : Type u_2} [CompleteLattice α] [IsModularLattice α] [IsCompactlyGenerated α] (h : sSup {a : α | IsAtom a} = ) (b : α) :
          ∃ (s : Set α), sSupIndep s IsCompl b (sSup s) ∀ ⦃a : α⦄, a sIsAtom a

          In an atomic lattice, every element b has a complement of the form sSup s, where each element of s is an atom. See also complementedLattice_of_sSup_atoms_eq_top.

          @[deprecated exists_sSupIndep_isCompl_sSup_atoms]
          theorem exists_setIndependent_isCompl_sSup_atoms {α : Type u_2} [CompleteLattice α] [IsModularLattice α] [IsCompactlyGenerated α] (h : sSup {a : α | IsAtom a} = ) (b : α) :
          ∃ (s : Set α), sSupIndep s IsCompl b (sSup s) ∀ ⦃a : α⦄, a sIsAtom a

          Alias of exists_sSupIndep_isCompl_sSup_atoms.


          In an atomic lattice, every element b has a complement of the form sSup s, where each element of s is an atom. See also complementedLattice_of_sSup_atoms_eq_top.

          theorem exists_sSupIndep_of_sSup_atoms_eq_top {α : Type u_2} [CompleteLattice α] [IsModularLattice α] [IsCompactlyGenerated α] (h : sSup {a : α | IsAtom a} = ) :
          ∃ (s : Set α), sSupIndep s sSup s = ∀ ⦃a : α⦄, a sIsAtom a
          @[deprecated exists_sSupIndep_of_sSup_atoms_eq_top]
          theorem exists_setIndependent_of_sSup_atoms_eq_top {α : Type u_2} [CompleteLattice α] [IsModularLattice α] [IsCompactlyGenerated α] (h : sSup {a : α | IsAtom a} = ) :
          ∃ (s : Set α), sSupIndep s sSup s = ∀ ⦃a : α⦄, a sIsAtom a

          Alias of exists_sSupIndep_of_sSup_atoms_eq_top.

          See [Theorem 6.6][calugareanu].