Documentation

Mathlib.CategoryTheory.Sites.Sheaf

Sheaves taking values in a category #

If C is a category with a Grothendieck topology, we define the notion of a sheaf taking values in an arbitrary category A. We follow the definition in https://stacks.math.columbia.edu/tag/00VR, noting that the presheaf of sets "defined above" can be seen in the comments between tags 00VQ and 00VR on the page https://stacks.math.columbia.edu/tag/00VL. The advantage of this definition is that we need no assumptions whatsoever on A other than the assumption that the morphisms in C and A live in the same universe.

Implementation notes #

Occasionally we need to take a limit in A of a collection of morphisms of C indexed by a collection of objects in C. This turns out to force the morphisms of A to be in a sufficiently large universe. Rather than use UnivLE we prove some results for a category A' instead, whose morphism universe of A' is defined to be max u₁ v₁, where u₁, v₁ are the universes for C. Perhaps after we get better at handling universe inequalities this can be changed.

A sheaf of A is a presheaf P : Cᵒᵖ => A such that for every E : A, the presheaf of types given by sending U : C to Hom_{A}(E, P U) is a sheaf of types.

https://stacks.math.columbia.edu/tag/00VR

Equations
Instances For

    Condition that a presheaf with values in a concrete category is separated for a Grothendieck topology.

    Equations
    • One or more equations did not get rendered due to their size.
    Instances For
      def CategoryTheory.Presheaf.conesEquivSieveCompatibleFamily {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] (P : Functor Cᵒᵖ A) {X : C} (S : Sieve X) (E : Aᵒᵖ) :
      (S.arrows.diagram.op.comp P).cones.obj E { x : Presieve.FamilyOfElements (P.comp (coyoneda.obj E)) S.arrows // x.SieveCompatible }

      Given a sieve S on X : C, a presheaf P : Cᵒᵖ ⥤ A, and an object E of A, the cones over the natural diagram S.arrows.diagram.op ⋙ P associated to S and P with cone point E are in 1-1 correspondence with sieve_compatible family of elements for the sieve S and the presheaf of types Hom (E, P -).

      Equations
      • One or more equations did not get rendered due to their size.
      Instances For
        @[simp]
        theorem CategoryTheory.Presheaf.conesEquivSieveCompatibleFamily_apply_coe {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] (P : Functor Cᵒᵖ A) {X : C} (S : Sieve X) (E : Aᵒᵖ) (π : (S.arrows.diagram.op.comp P).cones.obj E) (x✝ : C) (f : x✝ X) (h : S.arrows f) :
        ((conesEquivSieveCompatibleFamily P S E) π) f h = π.app (Opposite.op { obj := Over.mk f, property := h })
        @[simp]
        theorem CategoryTheory.Presheaf.conesEquivSieveCompatibleFamily_symm_apply_app {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] (P : Functor Cᵒᵖ A) {X : C} (S : Sieve X) (E : Aᵒᵖ) (x : { x : Presieve.FamilyOfElements (P.comp (coyoneda.obj E)) S.arrows // x.SieveCompatible }) (f : S.arrows.categoryᵒᵖ) :
        ((conesEquivSieveCompatibleFamily P S E).symm x).app f = x (Opposite.unop f).obj.hom
        def CategoryTheory.Presieve.FamilyOfElements.SieveCompatible.cone {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] {P : Functor Cᵒᵖ A} {X : C} {S : Sieve X} {E : Aᵒᵖ} {x : FamilyOfElements (P.comp (coyoneda.obj E)) S.arrows} (hx : x.SieveCompatible) :
        Limits.Cone (S.arrows.diagram.op.comp P)

        The cone corresponding to a sieve_compatible family of elements, dot notation enabled.

        Equations
        Instances For
          def CategoryTheory.Presheaf.homEquivAmalgamation {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] {P : Functor Cᵒᵖ A} {X : C} {S : Sieve X} {E : Aᵒᵖ} {x : Presieve.FamilyOfElements (P.comp (coyoneda.obj E)) S.arrows} (hx : x.SieveCompatible) :
          (hx.cone P.mapCone S.arrows.cocone.op) { t : (P.comp (coyoneda.obj E)).obj (Opposite.op X) // x.IsAmalgamation t }

          Cone morphisms from the cone corresponding to a sieve_compatible family to the natural cone associated to a sieve S and a presheaf P are in 1-1 correspondence with amalgamations of the family.

          Equations
          • One or more equations did not get rendered due to their size.
          Instances For
            theorem CategoryTheory.Presheaf.isLimit_iff_isSheafFor {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] (P : Functor Cᵒᵖ A) {X : C} (S : Sieve X) :
            Nonempty (Limits.IsLimit (P.mapCone S.arrows.cocone.op)) ∀ (E : Aᵒᵖ), Presieve.IsSheafFor (P.comp (coyoneda.obj E)) S.arrows

            Given sieve S and presheaf P : Cᵒᵖ ⥤ A, their natural associated cone is a limit cone iff Hom (E, P -) is a sheaf of types for the sieve S and all E : A.

            theorem CategoryTheory.Presheaf.subsingleton_iff_isSeparatedFor {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] (P : Functor Cᵒᵖ A) {X : C} (S : Sieve X) :
            (∀ (c : Limits.Cone (S.arrows.diagram.op.comp P)), Subsingleton (c P.mapCone S.arrows.cocone.op)) ∀ (E : Aᵒᵖ), Presieve.IsSeparatedFor (P.comp (coyoneda.obj E)) S.arrows

            Given sieve S and presheaf P : Cᵒᵖ ⥤ A, their natural associated cone admits at most one morphism from every cone in the same category (i.e. over the same diagram), iff Hom (E, P -)is separated for the sieve S and all E : A.

            theorem CategoryTheory.Presheaf.isSheaf_iff_isLimit {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] (J : GrothendieckTopology C) (P : Functor Cᵒᵖ A) :
            IsSheaf J P ∀ ⦃X : C⦄, SJ X, Nonempty (Limits.IsLimit (P.mapCone S.arrows.cocone.op))

            A presheaf P is a sheaf for the Grothendieck topology J iff for every covering sieve S of J, the natural cone associated to P and S is a limit cone.

            theorem CategoryTheory.Presheaf.isSeparated_iff_subsingleton {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] (J : GrothendieckTopology C) (P : Functor Cᵒᵖ A) :
            (∀ (E : A), Presieve.IsSeparated J (P.comp (coyoneda.obj (Opposite.op E)))) ∀ ⦃X : C⦄, SJ X, ∀ (c : Limits.Cone (S.arrows.diagram.op.comp P)), Subsingleton (c P.mapCone S.arrows.cocone.op)

            A presheaf P is separated for the Grothendieck topology J iff for every covering sieve S of J, the natural cone associated to P and S admits at most one morphism from every cone in the same category.

            theorem CategoryTheory.Presheaf.isLimit_iff_isSheafFor_presieve {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] (P : Functor Cᵒᵖ A) {X : C} (R : Presieve X) :
            Nonempty (Limits.IsLimit (P.mapCone (Sieve.generate R).arrows.cocone.op)) ∀ (E : Aᵒᵖ), Presieve.IsSheafFor (P.comp (coyoneda.obj E)) R

            Given presieve R and presheaf P : Cᵒᵖ ⥤ A, the natural cone associated to P and the sieve Sieve.generate R generated by R is a limit cone iff Hom (E, P -) is a sheaf of types for the presieve R and all E : A.

            theorem CategoryTheory.Presheaf.isSheaf_iff_isLimit_pretopology {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] (P : Functor Cᵒᵖ A) [Limits.HasPullbacks C] (K : Pretopology C) :
            IsSheaf (Pretopology.toGrothendieck C K) P ∀ ⦃X : C⦄, RK.coverings X, Nonempty (Limits.IsLimit (P.mapCone (Sieve.generate R).arrows.cocone.op))

            A presheaf P is a sheaf for the Grothendieck topology generated by a pretopology K iff for every covering presieve R of K, the natural cone associated to P and Sieve.generate R is a limit cone.

            def CategoryTheory.Presheaf.IsSheaf.amalgamate {C : Type u₁} [Category.{v₁, u₁} C] {J : GrothendieckTopology C} {A : Type u₂} [Category.{v₂, u₂} A] {E : A} {X : C} {P : Functor Cᵒᵖ A} (hP : IsSheaf J P) (S : J.Cover X) (x : (I : S.Arrow) → E P.obj (Opposite.op I.Y)) (hx : ∀ ⦃I₁ I₂ : S.Arrow⦄ (r : I₁.Relation I₂), CategoryStruct.comp (x I₁) (P.map r.g₁.op) = CategoryStruct.comp (x I₂) (P.map r.g₂.op)) :
            E P.obj (Opposite.op X)

            This is a wrapper around Presieve.IsSheafFor.amalgamate to be used below. If Ps a sheaf, S is a cover of X, and x is a collection of morphisms from E to P evaluated at terms in the cover which are compatible, then we can amalgamate the xs to obtain a single morphism E ⟶ P.obj (op X).

            Equations
            • hP.amalgamate S x hx = .amalgamate (fun (Y : C) (f : Y X) (hf : (↑S).arrows f) => x { Y := Y, f := f, hf := hf })
            Instances For
              @[simp]
              theorem CategoryTheory.Presheaf.IsSheaf.amalgamate_map {C : Type u₁} [Category.{v₁, u₁} C] {J : GrothendieckTopology C} {A : Type u₂} [Category.{v₂, u₂} A] {E : A} {X : C} {P : Functor Cᵒᵖ A} (hP : IsSheaf J P) (S : J.Cover X) (x : (I : S.Arrow) → E P.obj (Opposite.op I.Y)) (hx : ∀ ⦃I₁ I₂ : S.Arrow⦄ (r : I₁.Relation I₂), CategoryStruct.comp (x I₁) (P.map r.g₁.op) = CategoryStruct.comp (x I₂) (P.map r.g₂.op)) (I : S.Arrow) :
              CategoryStruct.comp (hP.amalgamate S x hx) (P.map I.f.op) = x I
              @[simp]
              theorem CategoryTheory.Presheaf.IsSheaf.amalgamate_map_assoc {C : Type u₁} [Category.{v₁, u₁} C] {J : GrothendieckTopology C} {A : Type u₂} [Category.{v₂, u₂} A] {E : A} {X : C} {P : Functor Cᵒᵖ A} (hP : IsSheaf J P) (S : J.Cover X) (x : (I : S.Arrow) → E P.obj (Opposite.op I.Y)) (hx : ∀ ⦃I₁ I₂ : S.Arrow⦄ (r : I₁.Relation I₂), CategoryStruct.comp (x I₁) (P.map r.g₁.op) = CategoryStruct.comp (x I₂) (P.map r.g₂.op)) (I : S.Arrow) {Z : A} (h : P.obj (Opposite.op I.Y) Z) :
              CategoryStruct.comp (hP.amalgamate S x hx) (CategoryStruct.comp (P.map I.f.op) h) = CategoryStruct.comp (x I) h
              theorem CategoryTheory.Presheaf.IsSheaf.hom_ext {C : Type u₁} [Category.{v₁, u₁} C] {J : GrothendieckTopology C} {A : Type u₂} [Category.{v₂, u₂} A] {E : A} {X : C} {P : Functor Cᵒᵖ A} (hP : IsSheaf J P) (S : J.Cover X) (e₁ e₂ : E P.obj (Opposite.op X)) (h : ∀ (I : S.Arrow), CategoryStruct.comp e₁ (P.map I.f.op) = CategoryStruct.comp e₂ (P.map I.f.op)) :
              e₁ = e₂
              theorem CategoryTheory.Presheaf.IsSheaf.hom_ext_ofArrows {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] {J : GrothendieckTopology C} {P : Functor Cᵒᵖ A} (hP : IsSheaf J P) {I : Type u_1} {S : C} {X : IC} (f : (i : I) → X i S) (hf : Sieve.ofArrows X f J S) {E : A} {x y : E P.obj (Opposite.op S)} (h : ∀ (i : I), CategoryStruct.comp x (P.map (f i).op) = CategoryStruct.comp y (P.map (f i).op)) :
              x = y
              theorem CategoryTheory.Presheaf.IsSheaf.existsUnique_amalgamation_ofArrows {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] {J : GrothendieckTopology C} {P : Functor Cᵒᵖ A} (hP : IsSheaf J P) {I : Type u_1} {S : C} {X : IC} (f : (i : I) → X i S) (hf : Sieve.ofArrows X f J S) {E : A} (x : (i : I) → E P.obj (Opposite.op (X i))) (hx : ∀ ⦃W : C⦄ ⦃i j : I⦄ (a : W X i) (b : W X j), CategoryStruct.comp a (f i) = CategoryStruct.comp b (f j)CategoryStruct.comp (x i) (P.map a.op) = CategoryStruct.comp (x j) (P.map b.op)) :
              ∃! g : E P.obj (Opposite.op S), ∀ (i : I), CategoryStruct.comp g (P.map (f i).op) = x i
              @[deprecated CategoryTheory.Presheaf.IsSheaf.existsUnique_amalgamation_ofArrows (since := "2024-12-17")]
              theorem CategoryTheory.Presheaf.IsSheaf.exists_unique_amalgamation_ofArrows {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] {J : GrothendieckTopology C} {P : Functor Cᵒᵖ A} (hP : IsSheaf J P) {I : Type u_1} {S : C} {X : IC} (f : (i : I) → X i S) (hf : Sieve.ofArrows X f J S) {E : A} (x : (i : I) → E P.obj (Opposite.op (X i))) (hx : ∀ ⦃W : C⦄ ⦃i j : I⦄ (a : W X i) (b : W X j), CategoryStruct.comp a (f i) = CategoryStruct.comp b (f j)CategoryStruct.comp (x i) (P.map a.op) = CategoryStruct.comp (x j) (P.map b.op)) :
              ∃! g : E P.obj (Opposite.op S), ∀ (i : I), CategoryStruct.comp g (P.map (f i).op) = x i

              Alias of CategoryTheory.Presheaf.IsSheaf.existsUnique_amalgamation_ofArrows.

              def CategoryTheory.Presheaf.IsSheaf.amalgamateOfArrows {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] {J : GrothendieckTopology C} {P : Functor Cᵒᵖ A} (hP : IsSheaf J P) {I : Type u_1} {S : C} {X : IC} (f : (i : I) → X i S) (hf : Sieve.ofArrows X f J S) {E : A} (x : (i : I) → E P.obj (Opposite.op (X i))) (hx : ∀ ⦃W : C⦄ ⦃i j : I⦄ (a : W X i) (b : W X j), CategoryStruct.comp a (f i) = CategoryStruct.comp b (f j)CategoryStruct.comp (x i) (P.map a.op) = CategoryStruct.comp (x j) (P.map b.op)) :
              E P.obj (Opposite.op S)

              If P : Cᵒᵖ ⥤ A is a sheaf and f i : X i ⟶ S is a covering family, then a morphism E ⟶ P.obj (op S) can be constructed from a compatible family of morphisms x : E ⟶ P.obj (op (X i)).

              Equations
              Instances For
                @[simp]
                theorem CategoryTheory.Presheaf.IsSheaf.amalgamateOfArrows_map {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] {J : GrothendieckTopology C} {P : Functor Cᵒᵖ A} (hP : IsSheaf J P) {I : Type u_1} {S : C} {X : IC} (f : (i : I) → X i S) (hf : Sieve.ofArrows X f J S) {E : A} (x : (i : I) → E P.obj (Opposite.op (X i))) (hx : ∀ ⦃W : C⦄ ⦃i j : I⦄ (a : W X i) (b : W X j), CategoryStruct.comp a (f i) = CategoryStruct.comp b (f j)CategoryStruct.comp (x i) (P.map a.op) = CategoryStruct.comp (x j) (P.map b.op)) (i : I) :
                CategoryStruct.comp (hP.amalgamateOfArrows f hf x hx) (P.map (f i).op) = x i
                @[simp]
                theorem CategoryTheory.Presheaf.IsSheaf.amalgamateOfArrows_map_assoc {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] {J : GrothendieckTopology C} {P : Functor Cᵒᵖ A} (hP : IsSheaf J P) {I : Type u_1} {S : C} {X : IC} (f : (i : I) → X i S) (hf : Sieve.ofArrows X f J S) {E : A} (x : (i : I) → E P.obj (Opposite.op (X i))) (hx : ∀ ⦃W : C⦄ ⦃i j : I⦄ (a : W X i) (b : W X j), CategoryStruct.comp a (f i) = CategoryStruct.comp b (f j)CategoryStruct.comp (x i) (P.map a.op) = CategoryStruct.comp (x j) (P.map b.op)) (i : I) {Z : A} (h : P.obj (Opposite.op (X i)) Z) :
                CategoryStruct.comp (hP.amalgamateOfArrows f hf x hx) (CategoryStruct.comp (P.map (f i).op) h) = CategoryStruct.comp (x i) h
                structure CategoryTheory.Sheaf {C : Type u₁} [Category.{v₁, u₁} C] (J : GrothendieckTopology C) (A : Type u₂) [Category.{v₂, u₂} A] :
                Type (max (max (max u₁ u₂) v₁) v₂)

                The category of sheaves taking values in A on a grothendieck topology.

                Instances For
                  structure CategoryTheory.Sheaf.Hom {C : Type u₁} [Category.{v₁, u₁} C] {J : GrothendieckTopology C} {A : Type u₂} [Category.{v₂, u₂} A] (X Y : Sheaf J A) :
                  Type (max u₁ v₂)

                  Morphisms between sheaves are just morphisms of presheaves.

                  • val : X.val Y.val

                    a morphism between the underlying presheaves

                  Instances For
                    theorem CategoryTheory.Sheaf.Hom.ext {C : Type u₁} {inst✝ : Category.{v₁, u₁} C} {J : GrothendieckTopology C} {A : Type u₂} {inst✝¹ : Category.{v₂, u₂} A} {X Y : Sheaf J A} {x y : X.Hom Y} (val : x.val = y.val) :
                    x = y
                    @[simp]
                    theorem CategoryTheory.Sheaf.instCategorySheaf_comp_val {C : Type u₁} [Category.{v₁, u₁} C] {J : GrothendieckTopology C} {A : Type u₂} [Category.{v₂, u₂} A] {X✝ Y✝ Z✝ : Sheaf J A} (f : X✝ Y✝) (g : Y✝ Z✝) :
                    Equations
                    theorem CategoryTheory.Sheaf.hom_ext {C : Type u₁} [Category.{v₁, u₁} C] {J : GrothendieckTopology C} {A : Type u₂} [Category.{v₂, u₂} A] {X Y : Sheaf J A} (x y : X Y) (h : x.val = y.val) :
                    x = y

                    The inclusion functor from sheaves to presheaves.

                    Equations
                    Instances For
                      @[simp]
                      theorem CategoryTheory.sheafToPresheaf_obj {C : Type u₁} [Category.{v₁, u₁} C] (J : GrothendieckTopology C) (A : Type u₂) [Category.{v₂, u₂} A] (self : Sheaf J A) :
                      (sheafToPresheaf J A).obj self = self.val
                      @[simp]
                      theorem CategoryTheory.sheafToPresheaf_map {C : Type u₁} [Category.{v₁, u₁} C] (J : GrothendieckTopology C) (A : Type u₂) [Category.{v₂, u₂} A] {X✝ Y✝ : Sheaf J A} (f : X✝ Y✝) :
                      (sheafToPresheaf J A).map f = f.val
                      @[reducible, inline]

                      The sections of a sheaf (i.e. evaluation as a presheaf on C).

                      Equations
                      Instances For

                        The functor Sheaf J A ⥤ Cᵒᵖ ⥤ A is fully faithful.

                        Equations
                        • One or more equations did not get rendered due to their size.
                        Instances For
                          @[simp]
                          theorem CategoryTheory.fullyFaithfulSheafToPresheaf_preimage_val {C : Type u₁} [Category.{v₁, u₁} C] (J : GrothendieckTopology C) (A : Type u₂) [Category.{v₂, u₂} A] {X✝ Y✝ : Sheaf J A} (f : (sheafToPresheaf J A).obj X✝ (sheafToPresheaf J A).obj Y✝) :
                          ((fullyFaithfulSheafToPresheaf J A).preimage f).val = f
                          @[reducible, inline]
                          abbrev CategoryTheory.Sheaf.homEquiv {C : Type u₁} [Category.{v₁, u₁} C] {J : GrothendieckTopology C} {A : Type u₂} [Category.{v₂, u₂} A] {X Y : Sheaf J A} :
                          (X Y) (X.val Y.val)

                          The bijection (X ⟶ Y) ≃ (X.val ⟶ Y.val) when X and Y are sheaves.

                          Equations
                          Instances For
                            theorem CategoryTheory.Sheaf.Hom.mono_of_presheaf_mono {C : Type u₁} [Category.{v₁, u₁} C] (J : GrothendieckTopology C) (A : Type u₂) [Category.{v₂, u₂} A] {F G : Sheaf J A} (f : F G) [h : Mono f.val] :

                            This is stated as a lemma to prevent class search from forming a loop since a sheaf morphism is monic if and only if it is monic as a presheaf morphism (under suitable assumption).

                            instance CategoryTheory.Sheaf.Hom.epi_of_presheaf_epi {C : Type u₁} [Category.{v₁, u₁} C] (J : GrothendieckTopology C) (A : Type u₂) [Category.{v₂, u₂} A] {F G : Sheaf J A} (f : F G) [h : Epi f.val] :
                            Epi f
                            def CategoryTheory.sheafOver {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] {J : GrothendieckTopology C} (ℱ : Sheaf J A) (E : A) :
                            Sheaf J (Type v₂)

                            The sheaf of sections guaranteed by the sheaf condition.

                            Equations
                            Instances For
                              @[simp]
                              theorem CategoryTheory.sheafOver_val {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] {J : GrothendieckTopology C} (ℱ : Sheaf J A) (E : A) :
                              (sheafOver E).val = .val.comp (coyoneda.obj (Opposite.op E))
                              theorem CategoryTheory.Presheaf.IsSheaf.isSheafFor {C : Type u₁} [Category.{v₁, u₁} C] {J : GrothendieckTopology C} {P : Functor Cᵒᵖ (Type w)} (hP : IsSheaf J P) {X : C} (S : Sieve X) (hS : S J X) :

                              The category of sheaves on the bottom (trivial) Grothendieck topology is equivalent to the category of presheaves.

                              Equations
                              • One or more equations did not get rendered due to their size.
                              Instances For
                                @[simp]
                                theorem CategoryTheory.sheafBotEquivalence_counitIso {C : Type u₁} [Category.{v₁, u₁} C] (A : Type u₂) [Category.{v₂, u₂} A] :
                                (sheafBotEquivalence A).counitIso = Iso.refl ({ obj := fun (P : Functor Cᵒᵖ A) => { val := P, cond := }, map := fun {X Y : Functor Cᵒᵖ A} (f : X Y) => { val := f }, map_id := , map_comp := }.comp (sheafToPresheaf A))
                                @[simp]
                                theorem CategoryTheory.sheafBotEquivalence_inverse_map_val {C : Type u₁} [Category.{v₁, u₁} C] (A : Type u₂) [Category.{v₂, u₂} A] {X✝ Y✝ : Functor Cᵒᵖ A} (f : X✝ Y✝) :
                                ((sheafBotEquivalence A).inverse.map f).val = f
                                Equations
                                • One or more equations did not get rendered due to their size.

                                If the empty sieve is a cover of X, then F(X) is terminal.

                                Equations
                                Instances For
                                  Equations
                                  Equations
                                  Equations
                                  Equations
                                  Equations
                                  Equations
                                  @[simp]
                                  theorem CategoryTheory.Sheaf.Hom.add_app {C : Type u₁} [Category.{v₁, u₁} C] {J : GrothendieckTopology C} {A : Type u₂} [Category.{v₂, u₂} A] [Preadditive A] {P Q : Sheaf J A} (f g : P Q) (U : Cᵒᵖ) :
                                  (f + g).val.app U = f.val.app U + g.val.app U
                                  Equations
                                  def CategoryTheory.Presheaf.isLimitOfIsSheaf {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] (J : GrothendieckTopology C) (P : Functor Cᵒᵖ A) {X : C} (S : J.Cover X) (hP : IsSheaf J P) :
                                  Limits.IsLimit (S.multifork P)

                                  When P is a sheaf and S is a cover, the associated multifork is a limit.

                                  Equations
                                  Instances For
                                    theorem CategoryTheory.Presheaf.isSheaf_iff_multifork {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] (J : GrothendieckTopology C) (P : Functor Cᵒᵖ A) :
                                    IsSheaf J P ∀ (X : C) (S : J.Cover X), Nonempty (Limits.IsLimit (S.multifork P))
                                    def CategoryTheory.Presheaf.IsSheaf.isLimitMultifork {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] {J : GrothendieckTopology C} {P : Functor Cᵒᵖ A} (hP : IsSheaf J P) {X : C} (S : J.Cover X) :
                                    Limits.IsLimit (S.multifork P)

                                    If F : Cᵒᵖ ⥤ A is a sheaf for a Grothendieck topology J on C, and S is a cover of X : C, then the multifork S.multifork F is limit.

                                    Equations
                                    • hP.isLimitMultifork S = .some
                                    Instances For
                                      theorem CategoryTheory.Presheaf.isSheaf_iff_multiequalizer {C : Type u₁} [Category.{v₁, u₁} C] {A : Type u₂} [Category.{v₂, u₂} A] (J : GrothendieckTopology C) (P : Functor Cᵒᵖ A) [∀ (X : C) (S : J.Cover X), Limits.HasMultiequalizer (S.index P)] :
                                      IsSheaf J P ∀ (X : C) (S : J.Cover X), IsIso (S.toMultiequalizer P)

                                      The middle object of the fork diagram given in Equation (3) of [MLM92], as well as the fork diagram of https://stacks.math.columbia.edu/tag/00VM.

                                      Equations
                                      Instances For

                                        The left morphism of the fork diagram given in Equation (3) of [MLM92], as well as the fork diagram of https://stacks.math.columbia.edu/tag/00VM.

                                        Equations
                                        Instances For

                                          The rightmost object of the fork diagram of https://stacks.math.columbia.edu/tag/00VM, which contains the data used to check a family of elements for a presieve is compatible.

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

                                            The map pr₀* of https://stacks.math.columbia.edu/tag/00VM.

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

                                              The map pr₁* of https://stacks.math.columbia.edu/tag/00VM.

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

                                                An alternative definition of the sheaf condition in terms of equalizers. This is shown to be equivalent in CategoryTheory.Presheaf.isSheaf_iff_isSheaf'.

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

                                                  (Implementation). An auxiliary lemma to convert between sheaf conditions.

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

                                                    The equalizer definition of a sheaf given by isSheaf' is equivalent to isSheaf.

                                                    theorem CategoryTheory.Presheaf.isSheaf_iff_isSheaf_forget {C : Type u₁} [Category.{v₁, u₁} C] {A' : Type u₂} [Category.{max v₁ u₁, u₂} A'] (J : GrothendieckTopology C) (P' : Functor Cᵒᵖ A') (s : Functor A' (Type (max v₁ u₁))) [Limits.HasLimits A'] [Limits.PreservesLimits s] [s.ReflectsIsomorphisms] :
                                                    IsSheaf J P' IsSheaf J (P'.comp s)

                                                    For a concrete category (A, s) where the forgetful functor s : A ⥤ Type v preserves limits and reflects isomorphisms, and A has limits, an A-valued presheaf P : Cᵒᵖ ⥤ A is a sheaf iff its underlying Type-valued presheaf P ⋙ s : Cᵒᵖ ⥤ Type is a sheaf.

                                                    Note this lemma applies for "algebraic" categories, eg groups, abelian groups and rings, but not for the category of topological spaces, topological rings, etc since reflecting isomorphisms doesn't hold.