Documentation

Mathlib.CategoryTheory.MorphismProperty.Representable

Relatively representable morphisms #

In this file we define and develop basic results about relatively representable morphisms.

Classically, a morphism f : F ⟶ G of presheaves is said to be representable if for any morphism g : yoneda.obj X ⟶ G, there exists a pullback square of the following form

  yoneda.obj Y --yoneda.map snd--> yoneda.obj X
      |                                |
     fst                               g
      |                                |
      v                                v
      F ------------ f --------------> G

In this file, we define a notion of relative representability which works with respect to any functor, and not just yoneda. The fact that a morphism f : F ⟶ G between presheaves is representable in the classical case will then be given by yoneda.relativelyRepresentable f.

Main definitions #

Throughout this file, F : C ⥤ D is a functor between categories C and D.

  F.obj b --F.map snd--> F.obj a
      |                     |
     fst                    g
      |                     |
      v                     v
      X ------- f --------> Y

API #

Given hf : relativelyRepresentable f, with f : X ⟶ Y and g : F.obj a ⟶ Y, we provide:

Main results #

A morphism f : X ⟶ Y in D is said to be relatively representable if for any g : F.obj a ⟶ Y, there exists a pullback square of the following form

F.obj b --F.map snd--> F.obj a
    |                     |
   fst                    g
    |                     |
    v                     v
    X ------- f --------> Y
Equations
Instances For
    noncomputable def CategoryTheory.Functor.relativelyRepresentable.pullback {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {f : X Y} (hf : F.relativelyRepresentable f) {a : C} (g : F.obj a Y) :
    C

    Let f : X ⟶ Y be a relatively representable morphism in D. Then, for any g : F.obj a ⟶ Y, hf.pullback g denotes the (choice of) a corresponding object in C such that there is a pullback square of the following form

    hf.pullback g --F.map snd--> F.obj a
        |                          |
       fst                         g
        |                          |
        v                          v
        X ---------- f ----------> Y
    
    Equations
    • hf.pullback g = .choose
    Instances For
      @[reducible, inline]
      noncomputable abbrev CategoryTheory.Functor.relativelyRepresentable.snd {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {f : X Y} (hf : F.relativelyRepresentable f) {a : C} (g : F.obj a Y) :
      hf.pullback g a

      Given a representable morphism f : X ⟶ Y, then for any g : F.obj a ⟶ Y, hf.snd g denotes the morphism in C giving rise to the following diagram

      hf.pullback g --F.map (hf.snd g)--> F.obj a
          |                                 |
         fst                                g
          |                                 |
          v                                 v
          X -------------- f -------------> Y
      
      Equations
      • hf.snd g = .choose
      Instances For
        @[reducible, inline]
        noncomputable abbrev CategoryTheory.Functor.relativelyRepresentable.fst {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {f : X Y} (hf : F.relativelyRepresentable f) {a : C} (g : F.obj a Y) :
        F.obj (hf.pullback g) X

        Given a relatively representable morphism f : X ⟶ Y, then for any g : F.obj a ⟶ Y, hf.fst g denotes the first projection in the following diagram, given by the defining property of f being relatively representable

        hf.pullback g --F.map (hf.snd g)--> F.obj a
            |                                 |
        hf.fst g                              g
            |                                 |
            v                                 v
            X -------------- f -------------> Y
        
        Equations
        • hf.fst g = .choose
        Instances For
          @[reducible, inline]
          noncomputable abbrev CategoryTheory.Functor.relativelyRepresentable.fst' {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} (g : F.obj a Y) [F.Full] :
          hf'.pullback g b

          When F is full, given a representable morphism f' : F.obj b ⟶ Y, then hf'.fst' g denotes the preimage of hf'.fst g under F.

          Equations
          • hf'.fst' g = F.preimage (hf'.fst g)
          Instances For
            theorem CategoryTheory.Functor.relativelyRepresentable.map_fst' {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} (g : F.obj a Y) [F.Full] :
            F.map (hf'.fst' g) = hf'.fst g
            theorem CategoryTheory.Functor.relativelyRepresentable.isPullback {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {f : X Y} (hf : F.relativelyRepresentable f) {a : C} (g : F.obj a Y) :
            IsPullback (hf.fst g) (F.map (hf.snd g)) f g
            theorem CategoryTheory.Functor.relativelyRepresentable.w {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {f : X Y} (hf : F.relativelyRepresentable f) {a : C} (g : F.obj a Y) :
            CategoryStruct.comp (hf.fst g) f = CategoryStruct.comp (F.map (hf.snd g)) g
            theorem CategoryTheory.Functor.relativelyRepresentable.w_assoc {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {f : X Y} (hf : F.relativelyRepresentable f) {a : C} (g : F.obj a Y) {Z : D} (h : Y Z) :
            theorem CategoryTheory.Functor.relativelyRepresentable.isPullback' {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} (g : F.obj a Y) [F.Full] :
            IsPullback (F.map (hf'.fst' g)) (F.map (hf'.snd g)) f' g

            Variant of the pullback square when F is full, and given f' : F.obj b ⟶ Y.

            theorem CategoryTheory.Functor.relativelyRepresentable.w' {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y Z : C} {f : X Z} (hf : F.relativelyRepresentable (F.map f)) (g : Y Z) [F.Full] [F.Faithful] :
            CategoryStruct.comp (hf.fst' (F.map g)) f = CategoryStruct.comp (hf.snd (F.map g)) g
            theorem CategoryTheory.Functor.relativelyRepresentable.w'_assoc {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y Z : C} {f : X Z} (hf : F.relativelyRepresentable (F.map f)) (g : Y Z) [F.Full] [F.Faithful] {Z✝ : C} (h : Z Z✝) :
            CategoryStruct.comp (hf.fst' (F.map g)) (CategoryStruct.comp f h) = CategoryStruct.comp (hf.snd (F.map g)) (CategoryStruct.comp g h)
            theorem CategoryTheory.Functor.relativelyRepresentable.isPullback_of_map {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y Z : C} {f : X Z} (hf : F.relativelyRepresentable (F.map f)) (g : Y Z) [F.Full] [F.Faithful] :
            IsPullback (hf.fst' (F.map g)) (hf.snd (F.map g)) f g
            theorem CategoryTheory.Functor.relativelyRepresentable.hom_ext {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {f : X Y} (hf : F.relativelyRepresentable f) {a : C} {g : F.obj a Y} [F.Faithful] {c : C} {a✝ b : c hf.pullback g} (h₁ : CategoryStruct.comp (F.map a✝) (hf.fst g) = CategoryStruct.comp (F.map b) (hf.fst g)) (h₂ : CategoryStruct.comp a✝ (hf.snd g) = CategoryStruct.comp b (hf.snd g)) :
            a✝ = b

            Two morphisms a b : c ⟶ hf.pullback g are equal if

            • Their compositions (in C) with hf.snd g : hf.pullback ⟶ X are equal.
            • The compositions of F.map a and F.map b with hf.fst g are equal.
            theorem CategoryTheory.Functor.relativelyRepresentable.hom_ext' {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} [F.Full] [F.Faithful] {c : C} {a✝ b✝ : c hf'.pullback g} (h₁ : CategoryStruct.comp a✝ (hf'.fst' g) = CategoryStruct.comp b✝ (hf'.fst' g)) (h₂ : CategoryStruct.comp a✝ (hf'.snd g) = CategoryStruct.comp b✝ (hf'.snd g)) :
            a✝ = b✝

            In the case of a representable morphism f' : F.obj Y ⟶ G, whose codomain lies in the image of F, we get that two morphism a b : Z ⟶ hf.pullback g are equal if

            • Their compositions (in C) with hf'.snd g : hf.pullback ⟶ X are equal.
            • Their compositions (in C) with hf'.fst' g : hf.pullback ⟶ Y are equal.
            noncomputable def CategoryTheory.Functor.relativelyRepresentable.lift {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {f : X Y} (hf : F.relativelyRepresentable f) {a : C} {g : F.obj a Y} {c : C} (i : F.obj c X) (h : c a) (hi : CategoryStruct.comp i f = CategoryStruct.comp (F.map h) g) [F.Full] :
            c hf.pullback g

            The lift (in C) obtained from the universal property of F.obj (hf.pullback g), in the case when the cone point is in the image of F.obj.

            Equations
            Instances For
              @[simp]
              theorem CategoryTheory.Functor.relativelyRepresentable.lift_fst {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {f : X Y} (hf : F.relativelyRepresentable f) {a : C} {g : F.obj a Y} {c : C} (i : F.obj c X) (h : c a) (hi : CategoryStruct.comp i f = CategoryStruct.comp (F.map h) g) [F.Full] :
              CategoryStruct.comp (F.map (hf.lift i h hi)) (hf.fst g) = i
              @[simp]
              theorem CategoryTheory.Functor.relativelyRepresentable.lift_fst_assoc {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {f : X Y} (hf : F.relativelyRepresentable f) {a : C} {g : F.obj a Y} {c : C} (i : F.obj c X) (h : c a) (hi : CategoryStruct.comp i f = CategoryStruct.comp (F.map h) g) [F.Full] {Z : D} (h✝ : X Z) :
              CategoryStruct.comp (F.map (hf.lift i h hi)) (CategoryStruct.comp (hf.fst g) h✝) = CategoryStruct.comp i h✝
              @[simp]
              theorem CategoryTheory.Functor.relativelyRepresentable.lift_snd {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {f : X Y} (hf : F.relativelyRepresentable f) {a : C} {g : F.obj a Y} {c : C} (i : F.obj c X) (h : c a) (hi : CategoryStruct.comp i f = CategoryStruct.comp (F.map h) g) [F.Full] [F.Faithful] :
              CategoryStruct.comp (hf.lift i h hi) (hf.snd g) = h
              @[simp]
              theorem CategoryTheory.Functor.relativelyRepresentable.lift_snd_assoc {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {f : X Y} (hf : F.relativelyRepresentable f) {a : C} {g : F.obj a Y} {c : C} (i : F.obj c X) (h : c a) (hi : CategoryStruct.comp i f = CategoryStruct.comp (F.map h) g) [F.Full] [F.Faithful] {Z : C} (h✝ : a Z) :
              CategoryStruct.comp (hf.lift i h hi) (CategoryStruct.comp (hf.snd g) h✝) = CategoryStruct.comp h h✝
              noncomputable def CategoryTheory.Functor.relativelyRepresentable.lift' {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} {c : C} (i : c b) (h : c a) (hi : CategoryStruct.comp (F.map i) f' = CategoryStruct.comp (F.map h) g) [F.Full] :
              c hf'.pullback g

              Variant of lift in the case when the domain of f lies in the image of F.obj. Thus, in this case, one can obtain the lift directly by giving two morphisms in C.

              Equations
              • hf'.lift' i h hi = hf'.lift (F.map i) h hi
              Instances For
                @[simp]
                theorem CategoryTheory.Functor.relativelyRepresentable.lift'_fst {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} {c : C} (i : c b) (h : c a) (hi : CategoryStruct.comp (F.map i) f' = CategoryStruct.comp (F.map h) g) [F.Full] [F.Faithful] :
                CategoryStruct.comp (hf'.lift' i h hi) (hf'.fst' g) = i
                @[simp]
                theorem CategoryTheory.Functor.relativelyRepresentable.lift'_fst_assoc {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} {c : C} (i : c b) (h : c a) (hi : CategoryStruct.comp (F.map i) f' = CategoryStruct.comp (F.map h) g) [F.Full] [F.Faithful] {Z : C} (h✝ : b Z) :
                CategoryStruct.comp (hf'.lift' i h hi) (CategoryStruct.comp (hf'.fst' g) h✝) = CategoryStruct.comp i h✝
                @[simp]
                theorem CategoryTheory.Functor.relativelyRepresentable.lift'_snd {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} {c : C} (i : c b) (h : c a) (hi : CategoryStruct.comp (F.map i) f' = CategoryStruct.comp (F.map h) g) [F.Full] [F.Faithful] :
                CategoryStruct.comp (hf'.lift' i h hi) (hf'.snd g) = h
                @[simp]
                theorem CategoryTheory.Functor.relativelyRepresentable.lift'_snd_assoc {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} {c : C} (i : c b) (h : c a) (hi : CategoryStruct.comp (F.map i) f' = CategoryStruct.comp (F.map h) g) [F.Full] [F.Faithful] {Z : C} (h✝ : a Z) :
                CategoryStruct.comp (hf'.lift' i h hi) (CategoryStruct.comp (hf'.snd g) h✝) = CategoryStruct.comp h h✝
                noncomputable def CategoryTheory.Functor.relativelyRepresentable.symmetry {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} (hg : F.relativelyRepresentable g) [F.Full] :
                hf'.pullback g hg.pullback f'

                Given two representable morphisms f' : F.obj b ⟶ Y and g : F.obj a ⟶ Y, we obtain an isomorphism hf'.pullback g ⟶ hg.pullback f'.

                Equations
                • hf'.symmetry hg = hg.lift' (hf'.snd g) (hf'.fst' g)
                Instances For
                  @[simp]
                  theorem CategoryTheory.Functor.relativelyRepresentable.symmetry_fst {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} (hg : F.relativelyRepresentable g) [F.Full] [F.Faithful] :
                  CategoryStruct.comp (hf'.symmetry hg) (hg.fst' f') = hf'.snd g
                  @[simp]
                  theorem CategoryTheory.Functor.relativelyRepresentable.symmetry_fst_assoc {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} (hg : F.relativelyRepresentable g) [F.Full] [F.Faithful] {Z : C} (h : a Z) :
                  CategoryStruct.comp (hf'.symmetry hg) (CategoryStruct.comp (hg.fst' f') h) = CategoryStruct.comp (hf'.snd g) h
                  @[simp]
                  theorem CategoryTheory.Functor.relativelyRepresentable.symmetry_snd {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} (hg : F.relativelyRepresentable g) [F.Full] [F.Faithful] :
                  CategoryStruct.comp (hf'.symmetry hg) (hg.snd f') = hf'.fst' g
                  @[simp]
                  theorem CategoryTheory.Functor.relativelyRepresentable.symmetry_snd_assoc {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} (hg : F.relativelyRepresentable g) [F.Full] [F.Faithful] {Z : C} (h : b Z) :
                  CategoryStruct.comp (hf'.symmetry hg) (CategoryStruct.comp (hg.snd f') h) = CategoryStruct.comp (hf'.fst' g) h
                  @[simp]
                  theorem CategoryTheory.Functor.relativelyRepresentable.symmetry_symmetry {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} (hg : F.relativelyRepresentable g) [F.Full] [F.Faithful] :
                  CategoryStruct.comp (hf'.symmetry hg) (hg.symmetry hf') = CategoryStruct.id (hf'.pullback g)
                  @[simp]
                  theorem CategoryTheory.Functor.relativelyRepresentable.symmetry_symmetry_assoc {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} (hg : F.relativelyRepresentable g) [F.Full] [F.Faithful] {Z : C} (h : hf'.pullback g Z) :
                  CategoryStruct.comp (hf'.symmetry hg) (CategoryStruct.comp (hg.symmetry hf') h) = h
                  noncomputable def CategoryTheory.Functor.relativelyRepresentable.symmetryIso {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} (hg : F.relativelyRepresentable g) [F.Full] [F.Faithful] :
                  hf'.pullback g hg.pullback f'

                  The isomorphism given by Presheaf.representable.symmetry.

                  Equations
                  • hf'.symmetryIso hg = { hom := hf'.symmetry hg, inv := hg.symmetry hf', hom_inv_id := , inv_hom_id := }
                  Instances For
                    @[simp]
                    theorem CategoryTheory.Functor.relativelyRepresentable.symmetryIso_hom {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} (hg : F.relativelyRepresentable g) [F.Full] [F.Faithful] :
                    (hf'.symmetryIso hg).hom = hf'.symmetry hg
                    @[simp]
                    theorem CategoryTheory.Functor.relativelyRepresentable.symmetryIso_inv {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} (hg : F.relativelyRepresentable g) [F.Full] [F.Faithful] :
                    (hf'.symmetryIso hg).inv = hg.symmetry hf'
                    instance CategoryTheory.Functor.relativelyRepresentable.instIsIsoSymmetryOfFaithful {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {Y : D} {b : C} {f' : F.obj b Y} (hf' : F.relativelyRepresentable f') {a : C} {g : F.obj a Y} (hg : F.relativelyRepresentable g) [F.Full] [F.Faithful] :
                    IsIso (hf'.symmetry hg)
                    theorem CategoryTheory.Functor.relativelyRepresentable.map {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] (F : Functor C D) [F.Full] [Limits.HasPullbacks C] {a b : C} (f : a b) [∀ (c : C) (g : c b), Limits.PreservesLimit (Limits.cospan f g) F] :
                    F.relativelyRepresentable (F.map f)

                    When C has pullbacks, then F.map f is representable with respect to F for any f : a ⟶ b in C.

                    theorem CategoryTheory.Functor.relativelyRepresentable.of_isIso {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] (F : Functor C D) {X Y : D} (f : X Y) [IsIso f] :
                    F.relativelyRepresentable f
                    instance CategoryTheory.Functor.relativelyRepresentable.isMultiplicative {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] (F : Functor C D) :
                    F.relativelyRepresentable.IsMultiplicative
                    instance CategoryTheory.Functor.relativelyRepresentable.isStableUnderBaseChange {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] (F : Functor C D) :
                    F.relativelyRepresentable.IsStableUnderBaseChange
                    instance CategoryTheory.Functor.relativelyRepresentable.respectsIso {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] (F : Functor C D) :
                    F.relativelyRepresentable.RespectsIso

                    Given a morphism property P in a category C, a functor F : C ⥤ D and a morphism f : X ⟶ Y in D. Then f satisfies the morphism property P.relative with respect to F iff:

                    • The morphism is representable with respect to F
                    • For any morphism g : F.obj a ⟶ Y, the property P holds for any represented pullback of f by g.
                    Equations
                    • One or more equations did not get rendered due to their size.
                    Instances For
                      @[reducible, inline]

                      Given a morphism property P in a category C, a morphism f : F ⟶ G of presheaves in the category Cᵒᵖ ⥤ Type v satisfies the morphism property P.presheaf iff:

                      • The morphism is representable.
                      • For any morphism g : F.obj a ⟶ G, the property P holds for any represented pullback of f by g. This is implemented as a special case of the more general notion of P.relative, to the case when the functor F is yoneda.
                      Equations
                      Instances For
                        theorem CategoryTheory.MorphismProperty.relative.rep {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {P : MorphismProperty C} {f : X Y} (hf : relative F P f) :
                        F.relativelyRepresentable f

                        A morphism satisfying P.relative is representable.

                        theorem CategoryTheory.MorphismProperty.relative.property {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {P : MorphismProperty C} {f : X Y} (hf : relative F P f) ⦃a b : C (g : F.obj a Y) (fst : F.obj b X) (snd : b a) :
                        IsPullback fst (F.map snd) f gP snd
                        theorem CategoryTheory.MorphismProperty.relative.property_snd {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {P : MorphismProperty C} {f : X Y} (hf : relative F P f) {a : C} (g : F.obj a Y) :
                        P (.snd g)
                        theorem CategoryTheory.MorphismProperty.relative.of_exists {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {P : MorphismProperty C} [F.Faithful] [F.Full] [P.RespectsIso] {f : X Y} (h₀ : ∀ ⦃a : C⦄ (g : F.obj a Y), ∃ (b : C) (fst : F.obj b X) (snd : b a) (_ : IsPullback fst (F.map snd) f g), P snd) :
                        relative F P f

                        Given a morphism property P which respects isomorphisms, then to show that a morphism f : X ⟶ Y satisfies P.relative it suffices to show that:

                        • The morphism is representable.
                        • For any morphism g : F.obj a ⟶ G, the property P holds for some represented pullback of f by g.
                        theorem CategoryTheory.MorphismProperty.relative_of_snd {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {X Y : D} {P : MorphismProperty C} [F.Faithful] [F.Full] [P.RespectsIso] {f : X Y} (hf : F.relativelyRepresentable f) (h : ∀ ⦃a : C⦄ (g : F.obj a Y), P (hf.snd g)) :
                        relative F P f
                        theorem CategoryTheory.MorphismProperty.relative_map {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {P : MorphismProperty C} [F.Faithful] [F.Full] [Limits.HasPullbacks C] [P.IsStableUnderBaseChange] {a b : C} {f : a b} [∀ (c : C) (g : c b), Limits.PreservesLimit (Limits.cospan f g) F] (hf : P f) :
                        relative F P (F.map f)

                        If P : MorphismProperty C is stable under base change, F is fully faithful and preserves pullbacks, and C has all pullbacks, then for any f : a ⟶ b in C, F.map f satisfies P.relative if f satisfies P.

                        theorem CategoryTheory.MorphismProperty.of_relative_map {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {P : MorphismProperty C} {a b : C} {f : a b} (hf : relative F P (F.map f)) :
                        P f
                        theorem CategoryTheory.MorphismProperty.relative_map_iff {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} {P : MorphismProperty C} [F.Faithful] [F.Full] [Limits.PreservesLimitsOfShape Limits.WalkingCospan F] [Limits.HasPullbacks C] [P.IsStableUnderBaseChange] {X Y : C} {f : X Y} :
                        relative F P (F.map f) P f

                        If P' : MorphismProperty C is satisfied whenever P is, then also P'.relative is satisfied whenever P.relative is.

                        instance CategoryTheory.MorphismProperty.relative_isStableUnderComposition {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} (P : MorphismProperty C) [F.Faithful] [F.Full] [P.IsStableUnderComposition] :
                        (relative F P).IsStableUnderComposition
                        instance CategoryTheory.MorphismProperty.relative_isMultiplicative {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {F : Functor C D} (P : MorphismProperty C) [F.Faithful] [F.Full] [P.IsMultiplicative] [P.RespectsIso] :
                        (relative F P).IsMultiplicative

                        Morphisms satisfying (monomorphism C).presheaf are in particular monomorphisms.