Documentation

Mathlib.Condensed.Discrete.LocallyConstant

The sheaf of locally constant maps on CompHausLike P #

This file proves that under suitable conditions, the functor from the category of sets to the category of sheaves for the coherent topology on CompHausLike P, given by mapping a set to the sheaf of locally constant maps to it, is left adjoint to the "underlying set" functor (evaluation at the point).

We apply this to prove that the constant sheaf functor into (light) condensed sets is isomorphic to the functor of sheaves of locally constant maps described above.

Proof sketch #

The hard part of this adjunction is to define the counit. Its components are defined as follows:

Let S : CompHausLike P and let Y be a finite-product preserving presheaf on CompHausLike P (e.g. a sheaf for the coherent topology). We need to define a map LocallyConstant S Y(*) ⟶ Y(S). Given a locally constant map f : S → Y(*), let S = S₁ ⊔ ⋯ ⊔ Sₙ be the corresponding decomposition of S into the fibers. Let yᵢ ∈ Y(*) denote the value of f on Sᵢ and denote by gᵢ the canonical map Y(*) → Y(Sᵢ). Our map then takes f to the image of (g₁(y₁), ⋯, gₙ(yₙ)) under the isomorphism Y(S₁) × ⋯ × Y(Sₙ) ≅ Y(S₁ ⊔ ⋯ ⊔ Sₙ) = Y(S).

Now we need to prove that the counit is natural in S : CompHausLike P and Y : Sheaf (coherentTopology (CompHausLike P)) (Type _). There are two key lemmas in all naturality proofs in this file (both lemmas are in the CompHausLike.LocallyConstant namespace):

Main definitions #

The functor from the category of sets to presheaves on CompHausLike P given by locally constant maps.

Equations
  • One or more equations did not get rendered due to their size.
Instances For
    @[simp]
    theorem CompHausLike.LocallyConstant.functorToPresheaves_obj_map {P : TopCatProp} (X : Type (max u w)) {X✝ Y✝ : (CompHausLike P)ᵒᵖ} (f : X✝ Y✝) (g : match X✝ with | Opposite.op S => LocallyConstant (↑S.toTop) X) :
    @[simp]
    theorem CompHausLike.LocallyConstant.functorToPresheaves_map_app {P : TopCatProp} {X✝ Y✝ : Type (max u w)} (f : X✝ Y✝) (x✝ : (CompHausLike P)ᵒᵖ) (t : ((fun (X : Type (max u w)) => { obj := fun (x : (CompHausLike P)ᵒᵖ) => match x with | Opposite.op S => LocallyConstant (↑S.toTop) X, map := fun {X_1 Y : (CompHausLike P)ᵒᵖ} (f : X_1 Y) (g : (fun (x : (CompHausLike P)ᵒᵖ) => match x with | Opposite.op S => LocallyConstant (↑S.toTop) X) X_1) => LocallyConstant.comap f.unop g, map_id := , map_comp := }) X✝).obj x✝) :
    @[simp]
    theorem CompHausLike.LocallyConstant.functorToPresheaves_obj_obj {P : TopCatProp} (X : Type (max u w)) (x✝ : (CompHausLike P)ᵒᵖ) :
    (functorToPresheaves.obj X).obj x✝ = match x✝ with | Opposite.op S => LocallyConstant (↑S.toTop) X

    Locally constant maps are the same as continuous maps when the target is equipped with the discrete topology

    Equations
    • One or more equations did not get rendered due to their size.
    Instances For
      def CompHausLike.LocallyConstant.fiber {P : TopCatProp} [∀ (S : CompHausLike P) (p : S.toTopProp), HasProp P (Subtype p)] {Q : CompHausLike P} {Z : Type (max u w)} (r : LocallyConstant (↑Q.toTop) Z) (a : Function.Fiber r) :

      A fiber of a locally constant map as a CompHausLike P.

      Equations
      Instances For
        instance CompHausLike.LocallyConstant.instHasPropαTopologicalSpaceToTopFiber {P : TopCatProp} [∀ (S : CompHausLike P) (p : S.toTopProp), HasProp P (Subtype p)] {Q : CompHausLike P} {Z : Type (max u w)} (r : LocallyConstant (↑Q.toTop) Z) (a : Function.Fiber r) :
        HasProp P (fiber r a).toTop
        def CompHausLike.LocallyConstant.sigmaIncl {P : TopCatProp} [∀ (S : CompHausLike P) (p : S.toTopProp), HasProp P (Subtype p)] {Q : CompHausLike P} {Z : Type (max u w)} (r : LocallyConstant (↑Q.toTop) Z) (a : Function.Fiber r) :
        fiber r a Q

        The inclusion map from a component of the coproduct induced by f into S.

        Equations
        Instances For
          noncomputable def CompHausLike.LocallyConstant.sigmaIso {P : TopCatProp} [∀ (S : CompHausLike P) (p : S.toTopProp), HasProp P (Subtype p)] {Q : CompHausLike P} {Z : Type (max u w)} (r : LocallyConstant (↑Q.toTop) Z) [HasExplicitFiniteCoproducts P] :

          The canonical map from the coproduct induced by f to S as an isomorphism in CompHausLike P.

          Equations
          Instances For
            theorem CompHausLike.LocallyConstant.sigmaComparison_comp_sigmaIso {P : TopCatProp} [∀ (S : CompHausLike P) (p : S.toTopProp), HasProp P (Subtype p)] {Q : CompHausLike P} {Z : Type (max u w)} (r : LocallyConstant (↑Q.toTop) Z) (a : Function.Fiber r) [HasExplicitFiniteCoproducts P] (X : CategoryTheory.Functor (CompHausLike P)ᵒᵖ (Type (max u w))) :
            CategoryTheory.CategoryStruct.comp (X.mapIso (sigmaIso r).op).hom (CategoryTheory.CategoryStruct.comp (sigmaComparison X fun (a : Function.Fiber r) => (fiber r a).toTop) fun (g : (a : Function.Fiber r) → X.obj (Opposite.op (of P (fiber r a).toTop))) => g a) = X.map (sigmaIncl r a).op
            noncomputable def CompHausLike.LocallyConstant.counitAppAppImage {P : TopCatProp} [∀ (S : CompHausLike P) (p : S.toTopProp), HasProp P (Subtype p)] {S : CompHausLike P} {Y : CategoryTheory.Functor (CompHausLike P)ᵒᵖ (Type (max u w))} [HasProp P PUnit.{u + 1}] (f : LocallyConstant (↑S.toTop) (Y.obj (Opposite.op (of P PUnit.{u + 1})))) (a : Function.Fiber f) :
            Y.obj (Opposite.op (fiber f a))

            The projection of the counit.

            Equations
            Instances For

              The counit is defined as follows: given a locally constant map f : S → Y(*), let S = S₁ ⊔ ⋯ ⊔ Sₙ be the corresponding decomposition of S into the fibers. We need to provide an element of Y(S). It suffices to provide an element of Y(Sᵢ) for all i. Let yᵢ ∈ Y(*) denote the value of f on Sᵢ. Our desired element is the image of yᵢ under the canonical map Y(*) → Y(Sᵢ).

              Equations
              • One or more equations did not get rendered due to their size.
              Instances For
                theorem CompHausLike.LocallyConstant.presheaf_ext {P : TopCatProp} [∀ (S : CompHausLike P) (p : S.toTopProp), HasProp P (Subtype p)] {S : CompHausLike P} {Y : CategoryTheory.Functor (CompHausLike P)ᵒᵖ (Type (max u w))} [HasProp P PUnit.{u + 1}] (f : LocallyConstant (↑S.toTop) (Y.obj (Opposite.op (of P PUnit.{u + 1})))) (X : CategoryTheory.Functor (CompHausLike P)ᵒᵖ (Type (max u w))) [CategoryTheory.Limits.PreservesFiniteProducts X] (x y : X.obj (Opposite.op S)) [HasExplicitFiniteCoproducts P] (h : ∀ (a : Function.Fiber f), X.map (sigmaIncl f a).op x = X.map (sigmaIncl f a).op y) :
                x = y

                To check equality of two elements of X(S), it suffices to check equality after composing with each X(S) → X(Sᵢ).

                This is an auxiliary definition, the details do not matter. What's important is that this map exists so that the lemma incl_comap works.

                Equations
                Instances For

                  The counit is natural in S : CompHausLike P

                  Equations
                  • One or more equations did not get rendered due to their size.
                  Instances For

                    locallyConstantIsoContinuousMap is a natural isomorphism.

                    Equations
                    • One or more equations did not get rendered due to their size.
                    Instances For

                      CompHausLike.LocallyConstant.functorToPresheaves lands in sheaves.

                      Equations
                      • One or more equations did not get rendered due to their size.
                      Instances For
                        @[simp]
                        @[simp]
                        theorem CompHausLike.LocallyConstant.functor_map_val (P : TopCatProp) [HasExplicitFiniteCoproducts P] [HasExplicitPullbacks P] (hs : ∀ ⦃X Y : CompHausLike P⦄ (f : X Y), CategoryTheory.EffectiveEpi fFunction.Surjective f) {X✝ Y✝ : Type (max u w)} (f : X✝ Y✝) :
                        ((functor P hs).map f).val = functorToPresheaves.map f

                        CompHausLike.LocallyConstant.functor is naturally isomorphic to the restriction of topCatToSheafCompHausLike to discrete topological spaces.

                        Equations
                        • One or more equations did not get rendered due to their size.
                        Instances For

                          The counit is natural in both S : CompHausLike P and Y : Sheaf (coherentTopology (CompHausLike P)) (Type (max u w))

                          Equations
                          • One or more equations did not get rendered due to their size.
                          Instances For

                            The unit of the adjunciton is given by mapping each element to the corresponding constant map.

                            Equations
                            • One or more equations did not get rendered due to their size.
                            Instances For
                              @[simp]
                              theorem CompHausLike.LocallyConstant.unit_app (P : TopCatProp) [HasProp P PUnit.{u + 1}] [HasExplicitFiniteCoproducts P] [HasExplicitPullbacks P] (hs : ∀ ⦃X Y : CompHausLike P⦄ (f : X Y), CategoryTheory.EffectiveEpi fFunction.Surjective f) (x✝ : Type (max u u_1)) (x : (CategoryTheory.Functor.id (Type (max u u_1))).obj x✝) :
                              (unit P hs).app x✝ x = LocallyConstant.const (↑(of P PUnit.{u + 1}).toTop) x

                              The unit of the adjunction is an iso.

                              Equations
                              • One or more equations did not get rendered due to their size.
                              Instances For

                                CompHausLike.LocallyConstant.functor is left adjoint to the forgetful functor.

                                Equations
                                • One or more equations did not get rendered due to their size.
                                Instances For
                                  @[reducible, inline]

                                  The functor from sets to condensed sets given by locally constant maps into the set.

                                  Equations
                                  Instances For

                                    CondensedSet.LocallyConstant.functor is isomorphic to Condensed.discrete (by uniqueness of adjoints).

                                    Equations
                                    • One or more equations did not get rendered due to their size.
                                    Instances For
                                      @[reducible, inline]

                                      The functor from sets to light condensed sets given by locally constant maps into the set.

                                      Equations
                                      • One or more equations did not get rendered due to their size.
                                      Instances For

                                        LightCondSet.LocallyConstant.functor is isomorphic to LightCondensed.discrete (by uniqueness of adjoints).

                                        Equations
                                        • One or more equations did not get rendered due to their size.
                                        Instances For

                                          LightCondSet.LocallyConstant.functor is fully faithful.

                                          Equations
                                          • One or more equations did not get rendered due to their size.
                                          Instances For