# mathlibdocumentation

topology.sheaves.forget

# Checking the sheaf condition on the underlying presheaf of types. #

If G : C ⥤ D is a functor which reflects isomorphisms and preserves limits (we assume all limits exist in both C and D), then checking the sheaf condition for a presheaf F : presheaf C X is equivalent to checking the sheaf condition for F ⋙ G.

The important special case is when C is a concrete category with a forgetful functor that preserves limits and reflects isomorphisms. Then to check the sheaf condition it suffices to check it on the underlying sheaf of types.

## References #

def Top.presheaf.sheaf_condition.diagram_comp_preserves_limits {C : Type u₁} {D : Type u₂} (G : C D) {X : Top} (F : X) {ι : Type v} (U : ι → ) :

When G preserves limits, the sheaf condition diagram for F composed with G is naturally isomorphic to the sheaf condition diagram for F ⋙ G.

Equations
def Top.presheaf.sheaf_condition.map_cone_fork {C : Type u₁} {D : Type u₂} (G : C D) {X : Top} (F : X) {ι : Type v} (U : ι → ) :

When G preserves limits, the image under G of the sheaf condition fork for F is the sheaf condition fork for F ⋙ G, postcomposed with the inverse of the natural isomorphism diagram_comp_preserves_limits.

Equations
def Top.presheaf.sheaf_condition_equiv_sheaf_condition_comp {C : Type u₁} {D : Type u₂} (G : C D) {X : Top} (F : X) :

If G : C ⥤ D is a functor which reflects isomorphisms and preserves limits (we assume all limits exist in both C and D), then checking the sheaf condition for a presheaf F : presheaf C X is equivalent to checking the sheaf condition for F ⋙ G.

The important special case is when C is a concrete category with a forgetful functor that preserves limits and reflects isomorphisms. Then to check the sheaf condition it suffices to check it on the underlying sheaf of types.

Another useful example is the forgetful functor TopCommRing ⥤ Top.

See https://stacks.math.columbia.edu/tag/0073. In fact we prove a stronger version with arbitrary complete target category.

Equations

As an example, we now have everything we need to check the sheaf condition for a presheaf of commutative rings, merely by checking the sheaf condition for the underlying sheaf of types.

example (X : Top) (F : presheaf CommRing X) (h : sheaf_condition (F ⋙ (forget CommRing))) :
sheaf_condition F :=
(sheaf_condition_equiv_sheaf_condition_forget F).symm h