Library HoTT.Categories.ExponentialLaws.Law1.Functors
Require Import Category.Core Functor.Core FunctorCategory.Core Functor.Identity NaturalTransformation.Core NaturalTransformation.Paths.
Require Import InitialTerminalCategory.Core InitialTerminalCategory.Functors InitialTerminalCategory.NaturalTransformations.
Require Import HoTT.Basics HoTT.Types.
Set Universe Polymorphism.
Set Implicit Arguments.
Generalizable All Variables.
Set Asymmetric Patterns.
Local Open Scope functor_scope.
Section law1.
Context `{Funext}.
Context `{IsInitialCategory zero}.
Context `{IsTerminalCategory one}.
Local Notation "0" := zero : category_scope.
Local Notation "1" := one : category_scope.
Variable C : PreCategory.
Require Import InitialTerminalCategory.Core InitialTerminalCategory.Functors InitialTerminalCategory.NaturalTransformations.
Require Import HoTT.Basics HoTT.Types.
Set Universe Polymorphism.
Set Implicit Arguments.
Generalizable All Variables.
Set Asymmetric Patterns.
Local Open Scope functor_scope.
Section law1.
Context `{Funext}.
Context `{IsInitialCategory zero}.
Context `{IsTerminalCategory one}.
Local Notation "0" := zero : category_scope.
Local Notation "1" := one : category_scope.
Variable C : PreCategory.
C¹ → C
Definition functor : Functor (1 → C) C
:= Build_Functor (1 → C) C
(fun F ⇒ F (center _))
(fun s d m ⇒ m (center _))
(fun _ _ _ _ _ ⇒ idpath)
(fun _ ⇒ idpath).
Definition inverse_morphism_of
s d (m : morphism C s d)
: morphism (1 → C)
(Functors.from_terminal _ s)
(Functors.from_terminal _ d).
Proof.
refine (Build_NaturalTransformation
(Functors.from_terminal _ s)
(Functors.from_terminal _ d)
(fun _ ⇒ m)
_).
simpl; intros.
etransitivity;
[ apply right_identity
| symmetry; apply left_identity ].
Defined.
Global Arguments inverse_morphism_of / _ _ _.
:= Build_Functor (1 → C) C
(fun F ⇒ F (center _))
(fun s d m ⇒ m (center _))
(fun _ _ _ _ _ ⇒ idpath)
(fun _ ⇒ idpath).
Definition inverse_morphism_of
s d (m : morphism C s d)
: morphism (1 → C)
(Functors.from_terminal _ s)
(Functors.from_terminal _ d).
Proof.
refine (Build_NaturalTransformation
(Functors.from_terminal _ s)
(Functors.from_terminal _ d)
(fun _ ⇒ m)
_).
simpl; intros.
etransitivity;
[ apply right_identity
| symmetry; apply left_identity ].
Defined.
Global Arguments inverse_morphism_of / _ _ _.
C → C¹
Definition inverse : Functor C (1 → C).
Proof.
refine (Build_Functor
C (1 → C)
(@Functors.from_terminal _ _ _ _ _)
inverse_morphism_of
_
_
);
abstract (path_natural_transformation; trivial).
Defined.
End law1.
Section law1'.
Context `{Funext}.
Context `{IsInitialCategory zero}.
Context `{IsTerminalCategory one}.
Local Notation "0" := zero : category_scope.
Local Notation "1" := one : category_scope.
Variable C : PreCategory.
Global Instance: IsTerminalCategory (C → 1) := {}.
Proof.
refine (Build_Functor
C (1 → C)
(@Functors.from_terminal _ _ _ _ _)
inverse_morphism_of
_
_
);
abstract (path_natural_transformation; trivial).
Defined.
End law1.
Section law1'.
Context `{Funext}.
Context `{IsInitialCategory zero}.
Context `{IsTerminalCategory one}.
Local Notation "0" := zero : category_scope.
Local Notation "1" := one : category_scope.
Variable C : PreCategory.
Global Instance: IsTerminalCategory (C → 1) := {}.