Library HoTT.Categories.ExponentialLaws.Law3.Law

Laws about an exponential of a product and a product of exponentials

Require Import Category.Core Functor.Core.
Require Import Functor.Prod.
Require Import Functor.Paths.
Require Import Functor.Identity Functor.Composition.Core.
Require Import ExponentialLaws.Law3.Functors.
Require Import Types.Prod ExponentialLaws.Tactics.

Set Universe Polymorphism.
Set Implicit Arguments.
Generalizable All Variables.
Set Asymmetric Patterns.

Local Open Scope functor_scope.

(y × z)ⁿ y × z

Section Law3.
  Context `{Funext}.
  Variables C1 C2 D : PreCategory.

  Lemma helper (c : Functor D C1 × Functor D C2)
  : ((fst o (Basics.Overture.fst c × Basics.Overture.snd c))%functor,
     (snd o (Basics.Overture.fst c × Basics.Overture.snd c))%functor)%core = c.
  Proof.
    apply path_prod;
    [ apply compose_fst_prod
    | apply compose_snd_prod ].
  Defined.

  Lemma Law
  : functor C1 C2 D o inverse C1 C2 D = 1
     inverse C1 C2 D o functor C1 C2 D = 1.
  Proof.
    split; path_functor;
    [ ( (path_forall _ _ helper))
    | ( (path_forall _ _ (fun _Functor.Prod.Universal.unique idpath idpath))) ];
    exp_laws_t;
    unfold helper, compose_fst_prod, compose_snd_prod, Functor.Prod.Universal.unique, Functor.Prod.Universal.unique_helper;
    exp_laws_t.
  Qed.
End Law3.