Conjugate morphisms by isomorphisms #
We define
CategoryTheory.Iso.homCongr : (X ≅ X₁) → (Y ≅ Y₁) → (X ⟶ Y) ≃ (X₁ ⟶ Y₁)
,
cf. Equiv.arrowCongr
,
and CategoryTheory.Iso.isoCongr : (f : X₁ ≅ X₂) → (g : Y₁ ≅ Y₂) → (X₁ ≅ Y₁) ≃ (X₂ ≅ Y₂)
.
As corollaries, an isomorphism α : X ≅ Y
defines
- a monoid isomorphism
CategoryTheory.Iso.conj : End X ≃* End Y
byα.conj f = α.inv ≫ f ≫ α.hom
; - a group isomorphism
CategoryTheory.Iso.conjAut : Aut X ≃* Aut Y
byα.conjAut f = α.symm ≪≫ f ≪≫ α
which can be found inCategoryTheory.Conj
.
def
CategoryTheory.Iso.homCongr
{C : Type u}
[Category.{v, u} C]
{X Y X₁ Y₁ : C}
(α : X ≅ X₁)
(β : Y ≅ Y₁)
:
If X
is isomorphic to X₁
and Y
is isomorphic to Y₁
, then
there is a natural bijection between X ⟶ Y
and X₁ ⟶ Y₁
. See also Equiv.arrowCongr
.
Equations
- One or more equations did not get rendered due to their size.
Instances For
@[simp]
theorem
CategoryTheory.Iso.homCongr_apply
{C : Type u}
[Category.{v, u} C]
{X Y X₁ Y₁ : C}
(α : X ≅ X₁)
(β : Y ≅ Y₁)
(f : X ⟶ Y)
:
(α.homCongr β) f = CategoryStruct.comp α.inv (CategoryStruct.comp f β.hom)
@[simp]
theorem
CategoryTheory.Iso.homCongr_symm_apply
{C : Type u}
[Category.{v, u} C]
{X Y X₁ Y₁ : C}
(α : X ≅ X₁)
(β : Y ≅ Y₁)
(f : X₁ ⟶ Y₁)
:
(α.homCongr β).symm f = CategoryStruct.comp α.hom (CategoryStruct.comp f β.inv)
theorem
CategoryTheory.Iso.homCongr_comp
{C : Type u}
[Category.{v, u} C]
{X Y Z X₁ Y₁ Z₁ : C}
(α : X ≅ X₁)
(β : Y ≅ Y₁)
(γ : Z ≅ Z₁)
(f : X ⟶ Y)
(g : Y ⟶ Z)
:
(α.homCongr γ) (CategoryStruct.comp f g) = CategoryStruct.comp ((α.homCongr β) f) ((β.homCongr γ) g)
@[simp]
theorem
CategoryTheory.Iso.homCongr_symm
{C : Type u}
[Category.{v, u} C]
{X₁ Y₁ X₂ Y₂ : C}
(α : X₁ ≅ X₂)
(β : Y₁ ≅ Y₂)
:
(α.homCongr β).symm = α.symm.homCongr β.symm
def
CategoryTheory.Iso.isoCongr
{C : Type u}
[Category.{v, u} C]
{X₁ Y₁ X₂ Y₂ : C}
(f : X₁ ≅ X₂)
(g : Y₁ ≅ Y₂)
:
If X
is isomorphic to X₁
and Y
is isomorphic to Y₁
, then
there is a bijection between X ≅ Y
and X₁ ≅ Y₁
.
Equations
Instances For
@[simp]
theorem
CategoryTheory.Iso.isoCongr_symm_apply
{C : Type u}
[Category.{v, u} C]
{X₁ Y₁ X₂ Y₂ : C}
(f : X₁ ≅ X₂)
(g : Y₁ ≅ Y₂)
(h : X₂ ≅ Y₂)
:
@[simp]
theorem
CategoryTheory.Iso.isoCongr_apply
{C : Type u}
[Category.{v, u} C]
{X₁ Y₁ X₂ Y₂ : C}
(f : X₁ ≅ X₂)
(g : Y₁ ≅ Y₂)
(h : X₁ ≅ Y₁)
:
If X₁
is isomorphic to X₂
, then there is a bijection between X₁ ≅ Y
and X₂ ≅ Y
.
Equations
- f.isoCongrLeft = f.isoCongr (CategoryTheory.Iso.refl Y)
Instances For
If Y₁
is isomorphic to Y₂
, then there is a bijection between X ≅ Y₁
and X ≅ Y₂
.
Equations
- g.isoCongrRight = (CategoryTheory.Iso.refl X).isoCongr g
Instances For
theorem
CategoryTheory.Functor.map_homCongr
{C : Type u}
[Category.{v, u} C]
{D : Type u₁}
[Category.{v₁, u₁} D]
(F : Functor C D)
{X Y X₁ Y₁ : C}
(α : X ≅ X₁)
(β : Y ≅ Y₁)
(f : X ⟶ Y)
:
F.map ((α.homCongr β) f) = ((F.mapIso α).homCongr (F.mapIso β)) (F.map f)
theorem
CategoryTheory.Functor.map_isoCongr
{C : Type u}
[Category.{v, u} C]
{D : Type u₁}
[Category.{v₁, u₁} D]
(F : Functor C D)
{X Y X₁ Y₁ : C}
(α : X ≅ X₁)
(β : Y ≅ Y₁)
(f : X ≅ Y)
:
F.mapIso ((α.isoCongr β) f) = ((F.mapIso α).isoCongr (F.mapIso β)) (F.mapIso f)