mathlib documentation

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

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

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 TopCommRingTop.

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