Documentation

Mathlib.CategoryTheory.FiberedCategory.Fiber

Fibers of a functors #

In this file we define, for a functor p : š’³ ā„¤ š’“, the fiber categories Fiber p S for every S : š’® as follows

For any category C equipped with a functor F : C ā„¤ š’³ such that F ā‹™ p is constant at S, we define a functor inducedFunctor : C ā„¤ Fiber p S that F factors through.

def CategoryTheory.Functor.Fiber {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] (p : Functor š’³ š’®) (S : š’®) :
Type uā‚‚

Fiber p S is the type of elements of š’³ mapping to S via p.

Equations
  • p.Fiber S = { a : š’³ // p.obj a = S }
Instances For
    instance CategoryTheory.Functor.Fiber.fiberCategory {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} :

    Fiber p S has the structure of a category with morphisms being those lying over šŸ™ S.

    Equations
    def CategoryTheory.Functor.Fiber.fiberInclusion {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} :
    Functor (p.Fiber S) š’³

    The functor including Fiber p S into š’³.

    Equations
    Instances For
      instance CategoryTheory.Functor.Fiber.instIsHomLiftIdMapFiberInclusion {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} {a b : p.Fiber S} (Ļ† : a āŸ¶ b) :
      p.IsHomLift (CategoryStruct.id S) (fiberInclusion.map Ļ†)
      theorem CategoryTheory.Functor.Fiber.hom_ext {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} {a b : p.Fiber S} {Ļ† Ļˆ : a āŸ¶ b} (h : fiberInclusion.map Ļ† = fiberInclusion.map Ļˆ) :
      Ļ† = Ļˆ
      instance CategoryTheory.Functor.Fiber.instFaithfulFiberInclusion {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} :
      def CategoryTheory.Functor.Fiber.fiberInclusionCompIsoConst {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} :
      fiberInclusion.comp p ā‰… (const (p.Fiber S)).obj S

      For fixed S : š’® this is the natural isomorphism between fiberInclusion ā‹™ p and the constant function valued at S.

      Equations
      Instances For
        @[simp]
        theorem CategoryTheory.Functor.Fiber.fiberInclusionCompIsoConst_hom_app {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} (X : p.Fiber S) :
        @[simp]
        theorem CategoryTheory.Functor.Fiber.fiberInclusionCompIsoConst_inv_app {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} (X : p.Fiber S) :
        theorem CategoryTheory.Functor.Fiber.fiberInclusion_comp_eq_const {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} :
        fiberInclusion.comp p = (const (p.Fiber S)).obj S
        def CategoryTheory.Functor.Fiber.mk {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} {a : š’³} (ha : p.obj a = S) :
        p.Fiber S

        The object of the fiber over S corresponding to a a : š’³ such that p(a) = S.

        Equations
        Instances For
          @[simp]
          theorem CategoryTheory.Functor.Fiber.fiberInclusion_mk {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} {a : š’³} (ha : p.obj a = S) :
          fiberInclusion.obj (mk ha) = a
          def CategoryTheory.Functor.Fiber.homMk {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] (p : Functor š’³ š’®) (S : š’®) {a b : š’³} (Ļ† : a āŸ¶ b) [p.IsHomLift (CategoryStruct.id S) Ļ†] :
          mk ā‹Æ āŸ¶ mk ā‹Æ

          The morphism in the fiber over S corresponding to a morphism in š’³ lifting šŸ™ S.

          Equations
          Instances For
            @[simp]
            theorem CategoryTheory.Functor.Fiber.fiberInclusion_homMk {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] (p : Functor š’³ š’®) (S : š’®) {a b : š’³} (Ļ† : a āŸ¶ b) [p.IsHomLift (CategoryStruct.id S) Ļ†] :
            fiberInclusion.map (homMk p S Ļ†) = Ļ†
            @[simp]
            theorem CategoryTheory.Functor.Fiber.homMk_id {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] (p : Functor š’³ š’®) (S : š’®) (a : š’³) [p.IsHomLift (CategoryStruct.id S) (CategoryStruct.id a)] :
            @[simp]
            theorem CategoryTheory.Functor.Fiber.homMk_comp {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} {a b c : š’³} (Ļ† : a āŸ¶ b) (Ļˆ : b āŸ¶ c) [p.IsHomLift (CategoryStruct.id S) Ļ†] [p.IsHomLift (CategoryStruct.id S) Ļˆ] :
            CategoryStruct.comp (homMk p S Ļ†) (homMk p S Ļˆ) = homMk p S (CategoryStruct.comp Ļ† Ļˆ)
            def CategoryTheory.Functor.Fiber.inducedFunctor {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} {C : Type uā‚ƒ} [Category.{vā‚ƒ, uā‚ƒ} C] {F : Functor C š’³} (hF : F.comp p = (const C).obj S) :
            Functor C (p.Fiber S)

            Given a functor F : C ā„¤ š’³ such that F ā‹™ p is constant at some S : š’®, then we get an induced functor C ā„¤ Fiber p S that F factors through.

            Equations
            Instances For
              @[simp]
              theorem CategoryTheory.Functor.Fiber.inducedFunctor_map {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} {C : Type uā‚ƒ} [Category.{vā‚ƒ, uā‚ƒ} C] {F : Functor C š’³} (hF : F.comp p = (const C).obj S) {X Y : C} (f : X āŸ¶ Y) :
              fiberInclusion.map ((inducedFunctor hF).map f) = F.map f
              def CategoryTheory.Functor.Fiber.inducedFunctorCompIsoSelf {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} {C : Type uā‚ƒ} [Category.{vā‚ƒ, uā‚ƒ} C] {F : Functor C š’³} (hF : F.comp p = (const C).obj S) :

              Given a functor F : C ā„¤ š’³ such that F ā‹™ p is constant at some S : š’®, then we get a natural isomorphism between inducedFunctor _ ā‹™ fiberInclusion and F.

              Equations
              Instances For
                @[simp]
                theorem CategoryTheory.Functor.Fiber.inducedFunctorCompIsoSelf_inv_app {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} {C : Type uā‚ƒ} [Category.{vā‚ƒ, uā‚ƒ} C] {F : Functor C š’³} (hF : F.comp p = (const C).obj S) (X : C) :
                @[simp]
                theorem CategoryTheory.Functor.Fiber.inducedFunctorCompIsoSelf_hom_app {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} {C : Type uā‚ƒ} [Category.{vā‚ƒ, uā‚ƒ} C] {F : Functor C š’³} (hF : F.comp p = (const C).obj S) (X : C) :
                theorem CategoryTheory.Functor.Fiber.inducedFunctor_comp {š’® : Type uā‚} {š’³ : Type uā‚‚} [Category.{vā‚, uā‚} š’®] [Category.{vā‚‚, uā‚‚} š’³] {p : Functor š’³ š’®} {S : š’®} {C : Type uā‚ƒ} [Category.{vā‚ƒ, uā‚ƒ} C] {F : Functor C š’³} (hF : F.comp p = (const C).obj S) :