Documentation

Mathlib.CategoryTheory.Subobject.Comma

Subobjects in the category of structured arrows #

We compute the subobjects of an object A in the category StructuredArrow S T for T : C ⥤ D and S : D as a subtype of the subobjects of A.right. We deduce that StructuredArrow S T is well-powered if C is.

Main declarations #

Implementation notes #

Our computation requires that C has all limits and T preserves all limits. Furthermore, we require that the morphisms of C and D are in the same universe. It is possible that both of these requirements can be relaxed by refining the results about limits in comma categories.

We also provide the dual results. As usual, we use Subobject (op A) for the quotient objects of A.

Every subobject of a structured arrow can be projected to a subobject of the underlying object.

Equations
  • One or more equations did not get rendered due to their size.
Instances For
    def CategoryTheory.StructuredArrow.liftSubobject {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {S : D} {T : Functor C D} {A : StructuredArrow S T} (P : Subobject A.right) {q : (Functor.fromPUnit S).obj A.left T.obj (Subobject.underlying.obj P)} (hq : CategoryStruct.comp q (T.map P.arrow) = A.hom) :

    A subobject of the underlying object of a structured arrow can be lifted to a subobject of the structured arrow, provided that there is a morphism making the subobject into a structured arrow.

    Equations
    Instances For

      Projecting and then lifting a subobject recovers the original subobject, because there is at most one morphism making the projected subobject into a structured arrow.

      def CategoryTheory.StructuredArrow.subobjectEquiv {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {S : D} {T : Functor C D} [Limits.HasFiniteLimits C] [Limits.PreservesFiniteLimits T] (A : StructuredArrow S T) :
      Subobject A ≃o { P : Subobject A.right // ∃ (q : (Functor.fromPUnit S).obj A.left T.obj (Subobject.underlying.obj P)), CategoryStruct.comp q (T.map P.arrow) = A.hom }

      If A : S → T.obj B is a structured arrow for S : D and T : C ⥤ D, then we can explicitly describe the subobjects of A as the subobjects P of B in C for which A.hom factors through the image of P under T.

      Equations
      • One or more equations did not get rendered due to their size.
      Instances For
        @[simp]
        theorem CategoryTheory.StructuredArrow.subobjectEquiv_symm_apply {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {S : D} {T : Functor C D} [Limits.HasFiniteLimits C] [Limits.PreservesFiniteLimits T] (A : StructuredArrow S T) (P : { P : Subobject A.right // ∃ (q : (Functor.fromPUnit S).obj A.left T.obj (Subobject.underlying.obj P)), CategoryStruct.comp q (T.map P.arrow) = A.hom }) :
        (RelIso.symm A.subobjectEquiv) P = Subobject.mk (homMk (↑P).arrow )

        If C is well-powered and complete and T preserves limits, then StructuredArrow S T is well-powered.

        Every quotient of a costructured arrow can be projected to a quotient of the underlying object.

        Equations
        • One or more equations did not get rendered due to their size.
        Instances For
          def CategoryTheory.CostructuredArrow.liftQuotient {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {S : Functor C D} {T : D} {A : CostructuredArrow S T} (P : Subobject (Opposite.op A.left)) {q : S.obj (Opposite.unop (Subobject.underlying.obj P)) (Functor.fromPUnit T).obj A.right} (hq : CategoryStruct.comp (S.map P.arrow.unop) q = A.hom) :

          A quotient of the underlying object of a costructured arrow can be lifted to a quotient of the costructured arrow, provided that there is a morphism making the quotient into a costructured arrow.

          Equations
          Instances For
            @[simp]
            theorem CategoryTheory.CostructuredArrow.unop_left_comp_underlyingIso_hom_unop {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {S : Functor C D} {T : D} {A : CostructuredArrow S T} {P : (CostructuredArrow S T)ᵒᵖ} (f : P Opposite.op A) [Mono f.unop.left.op] :
            CategoryStruct.comp f.unop.left (Subobject.underlyingIso f.unop.left.op).hom.unop = (Subobject.mk f.unop.left.op).arrow.unop

            Technical lemma for lift_projectQuotient.

            Projecting and then lifting a quotient recovers the original quotient, because there is at most one morphism making the projected quotient into a costructured arrow.

            theorem CategoryTheory.CostructuredArrow.unop_left_comp_ofMkLEMk_unop {C : Type u₁} [Category.{v₁, u₁} C] {D : Type u₂} [Category.{v₂, u₂} D] {S : Functor C D} {T : D} {A : CostructuredArrow S T} {P Q : (CostructuredArrow S T)ᵒᵖ} {f : P Opposite.op A} {g : Q Opposite.op A} [Mono f.unop.left.op] [Mono g.unop.left.op] (h : Subobject.mk f.unop.left.op Subobject.mk g.unop.left.op) :
            CategoryStruct.comp g.unop.left (Subobject.ofMkLEMk f.unop.left.op g.unop.left.op h).unop = f.unop.left

            Technical lemma for quotientEquiv.

            If A : S.obj B ⟶ T is a costructured arrow for S : C ⥤ D and T : D, then we can explicitly describe the quotients of A as the quotients P of B in C for which A.hom factors through the image of P under S.

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