Library HoTT.Colimits.Colimit_Coequalizer

Require Import Basics.
Require Import Types.
Require Import Diagrams.ParallelPair.
Require Import Diagrams.Cocone.
Require Import Colimits.Colimit.
Require Import Colimits.Coeq.

Generalizable All Variables.

Coequalizer as a colimit

In this file, we define Coequalizer the coequalizer of two maps as the colimit of a particuliar diagram, and then show that it is equivalent to Coeq the primitive coequalizer defined as an HIT.

Coequalizer


Section Coequalizer.

  Context {A B : Type}.

  Definition IsCoequalizer (f g : B A)
    := IsColimit (parallel_pair f g).

  Definition Coequalizer (f g : B A)
    := Colimit (parallel_pair f g).

Equivalence with Coeq


  Context {f g : B A}.

  Definition cocone_Coeq : Cocone (parallel_pair f g) (Coeq f g).
  Proof.
    srapply Build_Cocone.
    + intros []; [exact (coeq o g)| exact coeq].
    + intros i j phi x; destruct i, j, phi; simpl;
      [ exact (cglue x) | reflexivity ].
  Defined.

  Lemma iscoequalizer_Coeq `{Funext}
    : IsColimit (parallel_pair f g) (Coeq f g).
  Proof.
    srapply (Build_IsColimit cocone_Coeq).
    srapply Build_UniversalCocone.
    intros X.
    srapply isequiv_adjointify.
    - intros C.
      srapply Coeq_rec.
      + exact (legs C false).
      + intros b.
        etransitivity.
        × exact (legs_comm C true false true b).
        × exact (legs_comm C true false false b)^.
    - intros C.
      srapply path_cocone.
      + intros i x; destruct i; simpl.
        × exact (legs_comm C true false false x).
        × reflexivity.
      + intros i j phi x; destruct i, j, phi; simpl.
        × hott_simpl.
          match goal with
          | [|- ap (Coeq_rec ?a ?b ?c) _ @ _ = _ ]
            ⇒ rewrite (Coeq_rec_beta_cglue a b c)
          end.
          hott_simpl.
        × reflexivity.
    - intros F.
      apply path_forall.
      match goal with
        | [|- ?G == _ ] ⇒ simple refine (Coeq_ind (fun wG w = F w) _ _)
      end.
      + reflexivity.
      + intros b; simpl.
        nrapply (transport_paths_FlFr' (g:=F)).
        apply equiv_p1_1q.
        refine (Coeq_rec_beta_cglue _ _ _ _ @ _).
        apply concat_p1.
  Defined.

  Definition equiv_Coeq_Coequalizer `{Funext}
    : Coeq f g <~> Coequalizer f g.
  Proof.
    srapply colimit_unicity.
    3: eapply iscoequalizer_Coeq.
    eapply iscolimit_colimit.
  Defined.

End Coequalizer.