Documentation

Mathlib.CategoryTheory.EssentiallySmall

Essentially small categories. #

A category given by (C : Type u) [Category.{v} C] is w-essentially small if there exists a SmallModel C : Type w equipped with [SmallCategory (SmallModel C)] and an equivalence C ≌ SmallModel C.

A category is w-locally small if every hom type is w-small.

The main theorem here is that a category is w-essentially small iff the type Skeleton C is w-small, and C is w-locally small.

A category is EssentiallySmall.{w} if there exists an equivalence to some S : Type w with [SmallCategory S].

  • equiv_smallCategory : ∃ (S : Type w) (x : SmallCategory S), Nonempty (C S)

    An essentially small category is equivalent to some small category.

Instances

    Constructor for EssentiallySmall C from an explicit small category witness.

    An arbitrarily chosen small model for an essentially small category.

    Equations
    Instances For

      The (noncomputable) categorical equivalence between an essentially small category and its small model.

      Equations
      Instances For

        A category is w-locally small if every hom set is w-small.

        See ShrinkHoms C for a category instance where every hom set has been replaced by a small model.

        • hom_small (X Y : C) : Small.{w, v} (X Y)

          A locally small category has small hom-types.

        Instances

          We define a type alias ShrinkHoms C for C. When we have LocallySmall.{w} C, we'll put a Category.{w} instance on ShrinkHoms C.

          Equations
          Instances For

            Help the typechecker by explicitly translating from C to ShrinkHoms C.

            Equations
            Instances For

              Help the typechecker by explicitly translating from ShrinkHoms C to C.

              Equations
              • X.fromShrinkHoms = X
              Instances For
                @[simp]
                theorem CategoryTheory.ShrinkHoms.to_from {C' : Type u_1} (X : C') :
                (toShrinkHoms X).fromShrinkHoms = X
                @[simp]
                theorem CategoryTheory.ShrinkHoms.from_to {C' : Type u_1} (X : ShrinkHoms.{u_1} C') :
                toShrinkHoms X.fromShrinkHoms = X
                @[simp]
                theorem CategoryTheory.ShrinkHoms.instCategory_comp (C : Type u) [Category.{v, u} C] [LocallySmall.{w, v, u} C] {X✝ Y✝ Z✝ : ShrinkHoms.{u} C} (f : X✝ Y✝) (g : Y✝ Z✝) :
                CategoryStruct.comp f g = (equivShrink (X✝.fromShrinkHoms Z✝.fromShrinkHoms)) (CategoryStruct.comp ((equivShrink (X✝.fromShrinkHoms Y✝.fromShrinkHoms)).symm f) ((equivShrink (Y✝.fromShrinkHoms Z✝.fromShrinkHoms)).symm g))
                @[simp]
                theorem CategoryTheory.ShrinkHoms.instCategory_id (C : Type u) [Category.{v, u} C] [LocallySmall.{w, v, u} C] (X : ShrinkHoms.{u} C) :
                CategoryStruct.id X = (equivShrink (X.fromShrinkHoms X.fromShrinkHoms)) (CategoryStruct.id X.fromShrinkHoms)

                Implementation of ShrinkHoms.equivalence.

                Equations
                Instances For
                  @[simp]
                  theorem CategoryTheory.ShrinkHoms.functor_map (C : Type u) [Category.{v, u} C] [LocallySmall.{w, v, u} C] {X Y : C} (f : X Y) :
                  (functor C).map f = (equivShrink (X Y)) f

                  Implementation of ShrinkHoms.equivalence.

                  Equations
                  • One or more equations did not get rendered due to their size.
                  Instances For
                    @[simp]
                    theorem CategoryTheory.ShrinkHoms.inverse_map (C : Type u) [Category.{v, u} C] [LocallySmall.{w, v, u} C] {X Y : ShrinkHoms.{u} C} (f : X Y) :
                    (inverse C).map f = (equivShrink (X.fromShrinkHoms Y.fromShrinkHoms)).symm f
                    @[simp]

                    The categorical equivalence between C and ShrinkHoms C, when C is locally small.

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

                      The categorical equivalence between C and Shrink C, when C is small.

                      Equations
                      Instances For

                        A category is essentially small if and only if the underlying type of its skeleton (i.e. the "set" of isomorphism classes) is small, and it is locally small.

                        @[instance 100]

                        Any thin category is locally small.

                        A thin category is essentially small if and only if the underlying type of its skeleton is small.