Documentation

Mathlib.CategoryTheory.IsConnected

Connected category #

Define a connected category as a nonempty category for which every functor to a discrete category is isomorphic to the constant functor.

NB. Some authors include the empty category as connected, we do not. We instead are interested in categories with exactly one 'connected component'.

We give some equivalent definitions:

We also prove the result that the functor given by (X × -) preserves any connected limit. That is, any limit of shape J where J is a connected category is preserved by the functor (X × -). This appears in CategoryTheory.Limits.Connected.

A possibly empty category for which every functor to a discrete category is constant.

Instances

    We define a connected category as a nonempty category for which every functor to a discrete category is constant.

    NB. Some authors include the empty category as connected, we do not. We instead are interested in categories with exactly one 'connected component'.

    This allows us to show that the functor X ⨯ - preserves connected limits.

    See https://stacks.math.columbia.edu/tag/002S

    Instances
      def CategoryTheory.isoConstant {J : Type u₁} [Category.{v₁, u₁} J] [IsPreconnected J] {α : Type u₂} (F : Functor J (Discrete α)) (j : J) :
      F (Functor.const J).obj (F.obj j)

      If J is connected, any functor F : J ⥤ Discrete α is isomorphic to the constant functor with value F.obj j (for any choice of j).

      Equations
      • One or more equations did not get rendered due to their size.
      Instances For
        theorem CategoryTheory.any_functor_const_on_obj {J : Type u₁} [Category.{v₁, u₁} J] [IsPreconnected J] {α : Type u₂} (F : Functor J (Discrete α)) (j j' : J) :
        F.obj j = F.obj j'

        If J is connected, any functor to a discrete category is constant on objects. The converse is given in IsConnected.of_any_functor_const_on_obj.

        theorem CategoryTheory.IsPreconnected.of_any_functor_const_on_obj {J : Type u₁} [Category.{v₁, u₁} J] (h : ∀ {α : Type u₁} (F : Functor J (Discrete α)) (j j' : J), F.obj j = F.obj j') :

        If any functor to a discrete category is constant on objects, J is connected. The converse of any_functor_const_on_obj.

        theorem CategoryTheory.IsConnected.of_any_functor_const_on_obj {J : Type u₁} [Category.{v₁, u₁} J] [Nonempty J] (h : ∀ {α : Type u₁} (F : Functor J (Discrete α)) (j j' : J), F.obj j = F.obj j') :

        If any functor to a discrete category is constant on objects, J is connected. The converse of any_functor_const_on_obj.

        theorem CategoryTheory.constant_of_preserves_morphisms {J : Type u₁} [Category.{v₁, u₁} J] [IsPreconnected J] {α : Type u₂} (F : Jα) (h : ∀ (j₁ j₂ : J), (j₁ j₂)F j₁ = F j₂) (j j' : J) :
        F j = F j'

        If J is connected, then given any function F such that the presence of a morphism j₁ ⟶ j₂ implies F j₁ = F j₂, we have that F is constant. This can be thought of as a local-to-global property.

        The converse is shown in IsConnected.of_constant_of_preserves_morphisms

        theorem CategoryTheory.IsPreconnected.of_constant_of_preserves_morphisms {J : Type u₁} [Category.{v₁, u₁} J] (h : ∀ {α : Type u₁} (F : Jα), (∀ {j₁ j₂ : J}, (j₁ j₂)F j₁ = F j₂)∀ (j j' : J), F j = F j') :

        J is connected if: given any function F : J → α which is constant for any j₁, j₂ for which there is a morphism j₁ ⟶ j₂, then F is constant. This can be thought of as a local-to-global property.

        The converse of constant_of_preserves_morphisms.

        theorem CategoryTheory.IsConnected.of_constant_of_preserves_morphisms {J : Type u₁} [Category.{v₁, u₁} J] [Nonempty J] (h : ∀ {α : Type u₁} (F : Jα), (∀ {j₁ j₂ : J}, (j₁ j₂)F j₁ = F j₂)∀ (j j' : J), F j = F j') :

        J is connected if: given any function F : J → α which is constant for any j₁, j₂ for which there is a morphism j₁ ⟶ j₂, then F is constant. This can be thought of as a local-to-global property.

        The converse of constant_of_preserves_morphisms.

        theorem CategoryTheory.induct_on_objects {J : Type u₁} [Category.{v₁, u₁} J] [IsPreconnected J] (p : Set J) {j₀ : J} (h0 : j₀ p) (h1 : ∀ {j₁ j₂ : J}, (j₁ j₂)(j₁ p j₂ p)) (j : J) :
        j p

        An inductive-like property for the objects of a connected category. If the set p is nonempty, and p is closed under morphisms of J, then p contains all of J.

        The converse is given in IsConnected.of_induct.

        theorem CategoryTheory.IsConnected.of_induct {J : Type u₁} [Category.{v₁, u₁} J] {j₀ : J} (h : ∀ (p : Set J), j₀ p(∀ {j₁ j₂ : J}, (j₁ j₂)(j₁ p j₂ p))∀ (j : J), j p) :

        If any maximal connected component containing some element j₀ of J is all of J, then J is connected.

        The converse of induct_on_objects.

        Lifting the universe level of morphisms and objects preserves connectedness.

        theorem CategoryTheory.isPreconnected_induction {J : Type u₁} [Category.{v₁, u₁} J] [IsPreconnected J] (Z : JSort u_1) (h₁ : {j₁ j₂ : J} → (j₁ j₂)Z j₁Z j₂) (h₂ : {j₁ j₂ : J} → (j₁ j₂)Z j₂Z j₁) {j₀ : J} (x : Z j₀) (j : J) :
        Nonempty (Z j)

        Another induction principle for IsPreconnected J: given a type family Z : J → Sort* and a rule for transporting in both directions along a morphism in J, we can transport an x : Z j₀ to a point in Z j for any j.

        If J and K are equivalent, then if J is preconnected then K is as well.

        If J and K are equivalent, then if J is connected then K is as well.

        If J is preconnected, then Jᵒᵖ is preconnected as well.

        If J is connected, then Jᵒᵖ is connected as well.

        def CategoryTheory.Zag {J : Type u₁} [Category.{v₁, u₁} J] (j₁ j₂ : J) :

        j₁ and j₂ are related by Zag if there is a morphism between them.

        Equations
        Instances For
          theorem CategoryTheory.Zag.refl {J : Type u₁} [Category.{v₁, u₁} J] (X : J) :
          Zag X X
          theorem CategoryTheory.Zag.symm {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ : J} (h : Zag j₁ j₂) :
          Zag j₂ j₁
          theorem CategoryTheory.Zag.of_hom {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ : J} (f : j₁ j₂) :
          Zag j₁ j₂
          theorem CategoryTheory.Zag.of_inv {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ : J} (f : j₂ j₁) :
          Zag j₁ j₂
          def CategoryTheory.Zigzag {J : Type u₁} [Category.{v₁, u₁} J] :
          JJProp

          j₁ and j₂ are related by Zigzag if there is a chain of morphisms from j₁ to j₂, with backward morphisms allowed.

          Equations
          Instances For
            theorem CategoryTheory.Zigzag.symm {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ : J} (h : Zigzag j₁ j₂) :
            Zigzag j₂ j₁
            theorem CategoryTheory.Zigzag.trans {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ j₃ : J} (h₁ : Zigzag j₁ j₂) (h₂ : Zigzag j₂ j₃) :
            Zigzag j₁ j₃
            theorem CategoryTheory.Zigzag.of_zag {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ : J} (h : Zag j₁ j₂) :
            Zigzag j₁ j₂
            theorem CategoryTheory.Zigzag.of_hom {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ : J} (f : j₁ j₂) :
            Zigzag j₁ j₂
            theorem CategoryTheory.Zigzag.of_inv {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ : J} (f : j₂ j₁) :
            Zigzag j₁ j₂
            theorem CategoryTheory.Zigzag.of_zag_trans {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ j₃ : J} (h₁ : Zag j₁ j₂) (h₂ : Zag j₂ j₃) :
            Zigzag j₁ j₃
            theorem CategoryTheory.Zigzag.of_hom_hom {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ j₃ : J} (f₁₂ : j₁ j₂) (f₂₃ : j₂ j₃) :
            Zigzag j₁ j₃
            theorem CategoryTheory.Zigzag.of_hom_inv {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ j₃ : J} (f₁₂ : j₁ j₂) (f₃₂ : j₃ j₂) :
            Zigzag j₁ j₃
            theorem CategoryTheory.Zigzag.of_inv_hom {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ j₃ : J} (f₂₁ : j₂ j₁) (f₂₃ : j₂ j₃) :
            Zigzag j₁ j₃
            theorem CategoryTheory.Zigzag.of_inv_inv {J : Type u₁} [Category.{v₁, u₁} J] {j₁ j₂ j₃ : J} (f₂₁ : j₂ j₁) (f₃₂ : j₃ j₂) :
            Zigzag j₁ j₃

            The setoid given by the equivalence relation Zigzag. A quotient for this setoid is a connected component of the category.

            Equations
            Instances For
              theorem CategoryTheory.zigzag_prefunctor_obj_of_zigzag {J : Type u₁} [Category.{v₁, u₁} J] {K : Type u₂} [Category.{v₂, u₂} K] (F : J ⥤q K) {j₁ j₂ : J} (h : Zigzag j₁ j₂) :
              Zigzag (F.obj j₁) (F.obj j₂)

              If there is a zigzag from j₁ to j₂, then there is a zigzag from F j₁ to F j₂ as long as F is a prefunctor.

              theorem CategoryTheory.zigzag_obj_of_zigzag {J : Type u₁} [Category.{v₁, u₁} J] {K : Type u₂} [Category.{v₂, u₂} K] (F : Functor J K) {j₁ j₂ : J} (h : Zigzag j₁ j₂) :
              Zigzag (F.obj j₁) (F.obj j₂)

              If there is a zigzag from j₁ to j₂, then there is a zigzag from F j₁ to F j₂ as long as F is a functor.

              theorem CategoryTheory.eq_of_zag (X : Type u_1) {a b : Discrete X} (h : Zag a b) :
              a.as = b.as

              A Zag in a discrete category entails an equality of its extremities

              theorem CategoryTheory.eq_of_zigzag (X : Type u_1) {a b : Discrete X} (h : Zigzag a b) :
              a.as = b.as

              A zigzag in a discrete category entails an equality of its extremities

              theorem CategoryTheory.zag_of_zag_obj {J : Type u₁} [Category.{v₁, u₁} J] {K : Type u₂} [Category.{v₂, u₂} K] (F : Functor J K) [F.Full] {j₁ j₂ : J} (h : Zag (F.obj j₁) (F.obj j₂)) :
              Zag j₁ j₂
              theorem CategoryTheory.equiv_relation {J : Type u₁} [Category.{v₁, u₁} J] [IsPreconnected J] (r : JJProp) (hr : _root_.Equivalence r) (h : ∀ {j₁ j₂ : J}, (j₁ j₂)r j₁ j₂) (j₁ j₂ : J) :
              r j₁ j₂

              Any equivalence relation containing (⟶) holds for all pairs of a connected category.

              theorem CategoryTheory.isPreconnected_zigzag {J : Type u₁} [Category.{v₁, u₁} J] [IsPreconnected J] (j₁ j₂ : J) :
              Zigzag j₁ j₂

              In a connected category, any two objects are related by Zigzag.

              theorem CategoryTheory.zigzag_isPreconnected {J : Type u₁} [Category.{v₁, u₁} J] (h : ∀ (j₁ j₂ : J), Zigzag j₁ j₂) :
              theorem CategoryTheory.zigzag_isConnected {J : Type u₁} [Category.{v₁, u₁} J] [Nonempty J] (h : ∀ (j₁ j₂ : J), Zigzag j₁ j₂) :

              If any two objects in a nonempty category are related by Zigzag, the category is connected.

              theorem CategoryTheory.exists_zigzag' {J : Type u₁} [Category.{v₁, u₁} J] [IsConnected J] (j₁ j₂ : J) :
              ∃ (l : List J), List.Chain Zag j₁ l (j₁ :: l).getLast = j₂
              theorem CategoryTheory.isPreconnected_of_zigzag {J : Type u₁} [Category.{v₁, u₁} J] (h : ∀ (j₁ j₂ : J), ∃ (l : List J), List.Chain Zag j₁ l (j₁ :: l).getLast = j₂) :

              If any two objects in a nonempty category are linked by a sequence of (potentially reversed) morphisms, then J is connected.

              The converse of exists_zigzag'.

              theorem CategoryTheory.isConnected_of_zigzag {J : Type u₁} [Category.{v₁, u₁} J] [Nonempty J] (h : ∀ (j₁ j₂ : J), ∃ (l : List J), List.Chain Zag j₁ l (j₁ :: l).getLast = j₂) :

              If any two objects in a nonempty category are linked by a sequence of (potentially reversed) morphisms, then J is connected.

              The converse of exists_zigzag'.

              If Discrete α is connected, then α is (type-)equivalent to PUnit.

              Equations
              • One or more equations did not get rendered due to their size.
              Instances For
                theorem CategoryTheory.nat_trans_from_is_connected {J : Type u₁} [Category.{v₁, u₁} J] {C : Type w₂} [Category.{w₁, w₂} C] [IsPreconnected J] {X Y : C} (α : (Functor.const J).obj X (Functor.const J).obj Y) (j j' : J) :
                α.app j = α.app j'

                For objects X Y : C, any natural transformation α : const X ⟶ const Y from a connected category must be constant. This is the key property of connected categories which we use to establish properties about limits.