Library UniMath.CategoryTheory.yoneda
**********************************************************
 
Benedikt Ahrens, Chris Kapulkin, Mike Shulman
 
january 2013
 
 
 **********************************************************
 
Contents : Definition of the Yoneda functor
           yoneda(C) : [C, [C^op, HSET]]
 
           Proof that yoneda(C) is fully faithful
 
TODO: this file needs cleanup
 
Require Import UniMath.Foundations.PartD.
Require Import UniMath.Foundations.Propositions.
Require Import UniMath.Foundations.Sets.
Require Import UniMath.CategoryTheory.Core.Categories.
Require Import UniMath.CategoryTheory.Core.Functors.
Require Import UniMath.CategoryTheory.Core.Isos.
Require Import UniMath.CategoryTheory.Core.NaturalTransformations.
Require Export UniMath.CategoryTheory.FunctorCategory.
Local Open Scope cat.
Require Import UniMath.CategoryTheory.opp_precat.
Require Import UniMath.CategoryTheory.categories.HSET.Core.
Require Import UniMath.CategoryTheory.categories.HSET.MonoEpiIso.
Require Import UniMath.CategoryTheory.whiskering.
Local Notation "'hom' C" := (precategory_morphisms (C := C)) (at level 2).
Ltac unf := unfold identity,
compose,
precategory_morphisms;
simpl.
The following lemma is already in precategories.v . It should be transparent? 
Lemma iso_comp_left_isweq {C:precategory} {a b:ob C} (h:iso a b) (c:C) :
isweq (λ f : hom _ c a, f · h).
Show proof.
 intros. apply (@iso_comp_right_isweq C^op b a (opp_iso h)). 
Definition yoneda_objects_ob (C : precategory) (c : C)
(d : C) := hom C d c.
Definition yoneda_objects_mor (C : precategory) (c : C)
(d d' : C) (f : hom C d d') :
yoneda_objects_ob C c d' -> yoneda_objects_ob C c d :=
λ g, f · g.
Definition yoneda_ob_functor_data (C : precategory) (hs: has_homsets C) (c : C) :
functor_data (C^op) HSET.
Show proof.
  exists (λ c', hSetpair (yoneda_objects_ob C c c') (hs c' c)) .
intros a b f g. unfold yoneda_objects_ob in *. simpl in *.
exact (f · g).
intros a b f g. unfold yoneda_objects_ob in *. simpl in *.
exact (f · g).
Lemma is_functor_yoneda_functor_data (C : precategory) (hs: has_homsets C) (c : C) :
is_functor (yoneda_ob_functor_data C hs c).
Show proof.
  repeat split; unf; simpl.
unfold functor_idax .
intros.
apply funextsec.
intro f. unf. apply id_left.
intros a b d f g.
apply funextsec. intro h.
apply (! assoc _ _ _ ).
unfold functor_idax .
intros.
apply funextsec.
intro f. unf. apply id_left.
intros a b d f g.
apply funextsec. intro h.
apply (! assoc _ _ _ ).
Definition yoneda_objects (C : precategory) (hs: has_homsets C) (c : C) :
functor C^op HSET :=
tpair _ _ (is_functor_yoneda_functor_data C hs c).
Definition yoneda_morphisms_data (C : precategory)(hs: has_homsets C) (c c' : C)
(f : hom C c c') : ∏ a : ob C^op,
hom _ (yoneda_objects C hs c a) ( yoneda_objects C hs c' a) :=
λ a g, g · f.
Lemma is_nat_trans_yoneda_morphisms_data (C : precategory) (hs: has_homsets C)
(c c' : ob C) (f : hom C c c') :
is_nat_trans (yoneda_objects C hs c) (yoneda_objects C hs c')
(yoneda_morphisms_data C hs c c' f).
Show proof.
  unfold is_nat_trans; simpl.
unfold yoneda_morphisms_data; simpl.
intros d d' g.
apply funextsec; simpl in *.
unfold yoneda_objects_ob; simpl.
unf; intro;
apply ( ! assoc _ _ _ ).
unfold yoneda_morphisms_data; simpl.
intros d d' g.
apply funextsec; simpl in *.
unfold yoneda_objects_ob; simpl.
unf; intro;
apply ( ! assoc _ _ _ ).
Definition yoneda_morphisms (C : precategory) (hs: has_homsets C) (c c' : C)
(f : hom C c c') : nat_trans (yoneda_objects C hs c) (yoneda_objects C hs c') :=
tpair _ _ (is_nat_trans_yoneda_morphisms_data C hs c c' f).
Definition yoneda_functor_data (C : precategory)(hs: has_homsets C) :
functor_data C [C^op , HSET, (has_homsets_HSET) ] :=
tpair _ (yoneda_objects C hs) (yoneda_morphisms C hs).
Lemma is_functor_yoneda (C : precategory) (hs: has_homsets C):
is_functor (yoneda_functor_data C hs).
Show proof.
  unfold is_functor.
repeat split; simpl.
intro a.
set (T:= nat_trans_eq (C:=C^op) (has_homsets_HSET)). simpl.
apply T.
intro c; apply funextsec; intro f.
apply id_right.
intros a b c f g.
set (T:=nat_trans_eq (C:=C^op) (has_homsets_HSET)).
apply T.
simpl; intro d; apply funextsec; intro h.
apply assoc.
repeat split; simpl.
intro a.
set (T:= nat_trans_eq (C:=C^op) (has_homsets_HSET)). simpl.
apply T.
intro c; apply funextsec; intro f.
apply id_right.
intros a b c f g.
set (T:=nat_trans_eq (C:=C^op) (has_homsets_HSET)).
apply T.
simpl; intro d; apply funextsec; intro h.
apply assoc.
Definition yoneda (C : precategory) (hs: has_homsets C) :
functor C [C^op, HSET, has_homsets_HSET] :=
tpair _ _ (is_functor_yoneda C hs).
Definition yoneda_map_1 (C : precategory) (hs: has_homsets C) (c : C)
(F : functor C^op HSET) :
hom _ (yoneda C hs c) F -> pr1 (F c) :=
λ h, pr1 h c (identity c).
Lemma yoneda_map_2_ax (C : precategory) (hs: has_homsets C) (c : C)
(F : functor C^op HSET) (x : pr1 (F c)) :
is_nat_trans (pr1 (yoneda C hs c)) F
(fun (d : C) (f : hom (C ^op) c d) => #F f x).
Show proof.
  intros a b f; simpl in *.
apply funextsec.
unfold yoneda_objects_ob; intro g.
set (H:= @functor_comp _ _ F _ _ b g).
unfold functor_comp in H;
unfold opp_precat_data in H;
simpl in *.
apply (toforallpaths _ _ _ (H f) x).
apply funextsec.
unfold yoneda_objects_ob; intro g.
set (H:= @functor_comp _ _ F _ _ b g).
unfold functor_comp in H;
unfold opp_precat_data in H;
simpl in *.
apply (toforallpaths _ _ _ (H f) x).
Definition yoneda_map_2 (C : precategory) (hs: has_homsets C) (c : C)
(F : functor C^op HSET) :
pr1 (F c) -> hom _ (yoneda C hs c) F.
Show proof.
  intro x.
exists (λ d : ob C, λ f, #F f x).
apply yoneda_map_2_ax.
exists (λ d : ob C, λ f, #F f x).
apply yoneda_map_2_ax.
Lemma yoneda_map_1_2 (C : precategory) (hs: has_homsets C) (c : C)
(F : functor C^op HSET)
(alpha : hom _ (yoneda C hs c) F) :
yoneda_map_2 _ _ _ _ (yoneda_map_1 _ _ _ _ alpha) = alpha.
Show proof.
  simpl in *.
set (T:=nat_trans_eq (C:=C^op) (has_homsets_HSET)).
apply T.
intro a'; simpl.
apply funextsec; intro f.
unfold yoneda_map_1.
intermediate_path ((alpha c · #F f) (identity c)).
apply idpath.
rewrite <- nat_trans_ax.
unf; apply maponpaths.
apply (id_right f ).
set (T:=nat_trans_eq (C:=C^op) (has_homsets_HSET)).
apply T.
intro a'; simpl.
apply funextsec; intro f.
unfold yoneda_map_1.
intermediate_path ((alpha c · #F f) (identity c)).
apply idpath.
rewrite <- nat_trans_ax.
unf; apply maponpaths.
apply (id_right f ).
Lemma yoneda_map_2_1 (C : precategory) (hs: has_homsets C) (c : C)
(F : functor C^op HSET) (x : pr1 (F c)) :
yoneda_map_1 _ _ _ _ (yoneda_map_2 _ hs _ _ x) = x.
Show proof.
  simpl.
rewrite (functor_id F).
apply idpath.
rewrite (functor_id F).
apply idpath.
Lemma isaset_nat_trans_yoneda (C: precategory) (hs: has_homsets C) (c : C)
(F : functor C^op HSET) :
isaset (nat_trans (yoneda_ob_functor_data C hs c) F).
Show proof.
  apply isaset_nat_trans.
apply (has_homsets_HSET).
apply (has_homsets_HSET).
Lemma yoneda_iso_sets (C : precategory) (hs: has_homsets C) (c : C)
(F : functor C^op HSET) :
is_iso (C:=HSET)
(a := hSetpair (hom _ ((yoneda C) hs c) F) (isaset_nat_trans_yoneda C hs c F))
(b := F c)
(yoneda_map_1 C hs c F).
Show proof.
  set (T:=yoneda_map_2 C hs c F). simpl in T.
set (T':= T : hom HSET (F c) (hSetpair (hom _ ((yoneda C) hs c) F)
(isaset_nat_trans_yoneda C hs c F))).
apply (is_iso_qinv (C:=HSET) _ T' ).
repeat split; simpl.
- apply funextsec; intro alpha.
unf; simpl.
apply (yoneda_map_1_2 C hs c F).
- apply funextsec; intro x.
unf; rewrite (functor_id F).
apply idpath.
set (T':= T : hom HSET (F c) (hSetpair (hom _ ((yoneda C) hs c) F)
(isaset_nat_trans_yoneda C hs c F))).
apply (is_iso_qinv (C:=HSET) _ T' ).
repeat split; simpl.
- apply funextsec; intro alpha.
unf; simpl.
apply (yoneda_map_1_2 C hs c F).
- apply funextsec; intro x.
unf; rewrite (functor_id F).
apply idpath.
Definition yoneda_iso_target (C : precategory) (hs : has_homsets C)
(F : [C^op, HSET, has_homsets_HSET])
: functor C^op HSET.
Show proof.
  use (@functor_composite _ [C^op, HSET, has_homsets_HSET]^op).
- apply functor_opp.
apply yoneda. apply hs.
- apply (yoneda _ (functor_category_has_homsets _ _ _ ) F).
- apply functor_opp.
apply yoneda. apply hs.
- apply (yoneda _ (functor_category_has_homsets _ _ _ ) F).
Lemma is_natural_yoneda_iso (C : precategory) (hs : has_homsets C) (F : functor C^op HSET):
is_nat_trans (yoneda_iso_target C hs F) F
(λ c, yoneda_map_1 C hs c F).
Show proof.
  unfold is_nat_trans.
intros c c' f. cbn in *.
apply funextsec.
unfold yoneda_ob_functor_data. cbn.
unfold yoneda_morphisms_data.
unfold yoneda_map_1.
intro X.
assert (XH := nat_trans_ax X).
cbn in XH. unfold yoneda_objects_ob in XH.
assert (XH' := XH c' c' (identity _ )).
assert (XH2 := toforallpaths _ _ _ XH').
rewrite XH2.
rewrite (functor_id F).
cbn.
clear XH2 XH'.
assert (XH' := XH _ _ f).
assert (XH2 := toforallpaths _ _ _ XH').
eapply pathscomp0. 2: apply XH2.
rewrite id_right.
apply idpath.
intros c c' f. cbn in *.
apply funextsec.
unfold yoneda_ob_functor_data. cbn.
unfold yoneda_morphisms_data.
unfold yoneda_map_1.
intro X.
assert (XH := nat_trans_ax X).
cbn in XH. unfold yoneda_objects_ob in XH.
assert (XH' := XH c' c' (identity _ )).
assert (XH2 := toforallpaths _ _ _ XH').
rewrite XH2.
rewrite (functor_id F).
cbn.
clear XH2 XH'.
assert (XH' := XH _ _ f).
assert (XH2 := toforallpaths _ _ _ XH').
eapply pathscomp0. 2: apply XH2.
rewrite id_right.
apply idpath.
Definition natural_trans_yoneda_iso (C : precategory) (hs : has_homsets C)
(F : functor C^op HSET)
: nat_trans (yoneda_iso_target C hs F) F
:= tpair _ _ (is_natural_yoneda_iso C hs F).
Lemma is_natural_yoneda_iso_inv (C : precategory) (hs : has_homsets C) (F : functor C^op HSET):
is_nat_trans F (yoneda_iso_target C hs F)
(λ c, yoneda_map_2 C hs c F).
Show proof.
  unfold is_nat_trans.
intros c c' f. cbn in *.
apply funextsec.
unfold yoneda_ob_functor_data. cbn.
unfold yoneda_map_2.
intro A.
apply nat_trans_eq. { apply (has_homsets_HSET). }
cbn. intro d.
apply funextfun.
unfold yoneda_objects_ob. intro g.
unfold yoneda_morphisms_data.
apply (! toforallpaths _ _ _ (functor_comp F _ _ ) A).
intros c c' f. cbn in *.
apply funextsec.
unfold yoneda_ob_functor_data. cbn.
unfold yoneda_map_2.
intro A.
apply nat_trans_eq. { apply (has_homsets_HSET). }
cbn. intro d.
apply funextfun.
unfold yoneda_objects_ob. intro g.
unfold yoneda_morphisms_data.
apply (! toforallpaths _ _ _ (functor_comp F _ _ ) A).
Definition natural_trans_yoneda_iso_inv (C : precategory) (hs : has_homsets C)
(F : functor C^op HSET)
: nat_trans (yoneda_iso_target C hs F) F
:= tpair _ _ (is_natural_yoneda_iso C hs F).
Lemma isweq_yoneda_map_1 (C : precategory) (hs: has_homsets C) (c : C)
(F : functor C^op HSET) :
isweq
(yoneda_map_1 C hs c F).
Show proof.
  set (T:=yoneda_map_2 C hs c F). simpl in T.
use isweq_iso.
- apply T.
- apply yoneda_map_1_2.
- apply yoneda_map_2_1.
use isweq_iso.
- apply T.
- apply yoneda_map_1_2.
- apply yoneda_map_2_1.
Definition yoneda_weq (C : precategory) (hs: has_homsets C) (c : C)
(F : functor C^op HSET)
: hom [C^op, HSET, has_homsets_HSET] ((yoneda C hs) c) F ≃ pr1hSet (F c)
:= weqpair _ (isweq_yoneda_map_1 C hs c F).
Lemma yoneda_fully_faithful (C : precategory) (hs: has_homsets C) : fully_faithful (yoneda C hs).
Show proof.
  intros a b; simpl.
apply (isweq_iso _
(yoneda_map_1 C hs a (pr1 (yoneda C hs) b))).
- intro; simpl in *.
apply id_left.
- intro gamma.
simpl in *.
apply nat_trans_eq. apply (has_homsets_HSET).
intro x. simpl in *.
apply funextsec; intro f.
unfold yoneda_map_1.
unfold yoneda_morphisms_data.
assert (T:= toforallpaths _ _ _ (nat_trans_ax gamma a x f) (identity _ )).
cbn in T.
eapply pathscomp0; [apply (!T) |].
apply maponpaths.
apply id_right.
apply (isweq_iso _
(yoneda_map_1 C hs a (pr1 (yoneda C hs) b))).
- intro; simpl in *.
apply id_left.
- intro gamma.
simpl in *.
apply nat_trans_eq. apply (has_homsets_HSET).
intro x. simpl in *.
apply funextsec; intro f.
unfold yoneda_map_1.
unfold yoneda_morphisms_data.
assert (T:= toforallpaths _ _ _ (nat_trans_ax gamma a x f) (identity _ )).
cbn in T.
eapply pathscomp0; [apply (!T) |].
apply maponpaths.
apply id_right.
Section yoneda_functor_precomp.
Variables C D : precategory.
Variables (hsC : has_homsets C) (hsD : has_homsets D).
Variable F : functor C D.
Section fix_object.
Variable c : C.
Definition yoneda_functor_precomp' : nat_trans (yoneda_objects C hsC c)
(functor_composite (functor_opp F) (yoneda_objects D hsD (F c))).
Show proof.
  use tpair.
- intros d f ; simpl.
apply (#F f).
- abstract (intros d d' f ;
apply funextsec; intro t; simpl;
apply functor_comp).
- intros d f ; simpl.
apply (#F f).
- abstract (intros d d' f ;
apply funextsec; intro t; simpl;
apply functor_comp).
Definition yoneda_functor_precomp : _ ⟦ yoneda C hsC c, functor_composite (functor_opp F) (yoneda_objects D hsD (F c))⟧.
Show proof.
  exact yoneda_functor_precomp'.
Variable Fff : fully_faithful F.
Lemma is_iso_yoneda_functor_precomp : is_iso yoneda_functor_precomp.
Show proof.
  apply functor_iso_if_pointwise_iso.
intro. simpl.
set (T:= weqpair _ (Fff a c)).
set (TA := hSetpair (hom C a c) (hsC _ _ )).
set (TB := hSetpair (hom D (F a) (F c)) (hsD _ _ )).
apply (hset_equiv_is_iso TA TB T).
intro. simpl.
set (T:= weqpair _ (Fff a c)).
set (TA := hSetpair (hom C a c) (hsC _ _ )).
set (TB := hSetpair (hom D (F a) (F c)) (hsD _ _ )).
apply (hset_equiv_is_iso TA TB T).
End fix_object.
Let A := functor_composite F (yoneda D hsD).
Let B := pre_composition_functor _ _ HSET (has_homsets_opp hsD) (has_homsets_HSET) (functor_opp F).
Definition yoneda_functor_precomp_nat_trans :
@nat_trans
C
[C^op, HSET, (has_homsets_HSET)]
(yoneda C hsC)
(functor_composite A B).
Show proof.
  use tpair.
- intro c; simpl.
apply yoneda_functor_precomp.
- abstract (
intros c c' f;
apply nat_trans_eq; try apply (has_homsets_HSET);
intro d; apply funextsec; intro t;
cbn;
apply functor_comp).
- intro c; simpl.
apply yoneda_functor_precomp.
- abstract (
intros c c' f;
apply nat_trans_eq; try apply (has_homsets_HSET);
intro d; apply funextsec; intro t;
cbn;
apply functor_comp).
End yoneda_functor_precomp.