Library UniMath.CategoryTheory.ProductCategory
**********************************************************
 
Anders Mörtberg
 
2016
 
For a specialization to binary products, see precategory_binproduct.
 
Contents:
 
 
- Definition of the general product category (product_precategory)
-  Functors
- Families of functors (family_functor)
- Projections (pr_functor)
- Delta functor (delta_functor)
- Tuple functor (tuple_functor)
 
- Equivalence between functors into components and functors into product
Require Import UniMath.Foundations.PartD.
Require Import UniMath.MoreFoundations.Tactics.
Require Import UniMath.CategoryTheory.Core.Categories.
Require Import UniMath.CategoryTheory.Core.Functors.
Require Import UniMath.CategoryTheory.opp_precat.
Local Open Scope cat.
Section dep_product_precategory.
Context {I : UU} (C : I -> precategory).
Definition product_precategory_ob_mor : precategory_ob_mor.
Show proof.
  use tpair.
- apply (∏ (i : I), ob (C i)).
- intros f g.
apply (∏ i, f i --> g i).
- apply (∏ (i : I), ob (C i)).
- intros f g.
apply (∏ i, f i --> g i).
Definition product_precategory_data : precategory_data.
Show proof.
    exists product_precategory_ob_mor.
split.
- intros f i; simpl in *.
apply (identity (f i)).
- intros a b c f g i; simpl in *.
exact (f i · g i).
split.
- intros f i; simpl in *.
apply (identity (f i)).
- intros a b c f g i; simpl in *.
exact (f i · g i).
Lemma is_precategory_product_precategory_data :
is_precategory product_precategory_data.
Show proof.
    repeat split; intros; apply funextsec; intro i.
- apply id_left.
- apply id_right.
- apply assoc.
- apply assoc'.
- apply id_left.
- apply id_right.
- apply assoc.
- apply assoc'.
Definition product_precategory : precategory
:= tpair _ _ is_precategory_product_precategory_data.
Definition has_homsets_product_precategory (hsC : ∏ (i:I), has_homsets (C i)) :
has_homsets product_precategory.
Show proof.
  intros ? ?; simpl.
apply impred_isaset; intro; apply hsC.
apply impred_isaset; intro; apply hsC.
End dep_product_precategory.
Goal ∏ (I:UU) (C:I->precategory), product_precategory (λ i, (C i)^op) = (product_precategory C)^op.
reflexivity.
Qed.
The product of categories is again a category. 
Definition product_category {I : UU} (C : I -> category) : category.
use category_pair.
- exact (product_precategory C).
- apply has_homsets_product_precategory.
intro; exact (homset_property (C _)).
Defined.
Section power_precategory.
Context (I : UU) (C : precategory).
Definition power_precategory : precategory
:= @product_precategory I (λ _, C).
Definition has_homsets_power_precategory (hsC : has_homsets C) :
has_homsets power_precategory.
Show proof.
End power_precategory.
use category_pair.
- exact (product_precategory C).
- apply has_homsets_product_precategory.
intro; exact (homset_property (C _)).
Defined.
Section power_precategory.
Context (I : UU) (C : precategory).
Definition power_precategory : precategory
:= @product_precategory I (λ _, C).
Definition has_homsets_power_precategory (hsC : has_homsets C) :
has_homsets power_precategory.
Show proof.
  apply has_homsets_product_precategory.
intro i; assumption.
intro i; assumption.
End power_precategory.
Section functors.
Definition family_functor_data (I : UU) {A B : I -> precategory}
(F : ∏ (i : I), functor (A i) (B i)) :
functor_data (product_precategory A)
(product_precategory B).
Show proof.
use tpair.
- intros a i; apply (F i (a i)).
- intros a b f i; apply (# (F i) (f i)).
- intros a i; apply (F i (a i)).
- intros a b f i; apply (# (F i) (f i)).
Definition family_functor (I : UU) {A B : I -> precategory}
(F : ∏ (i : I), functor (A i) (B i)) :
functor (product_precategory A)
(product_precategory B).
Show proof.
apply (tpair _ (family_functor_data I F)).
abstract
(split; [ intro x; apply funextsec; intro i; simpl; apply functor_id
| intros x y z f g; apply funextsec; intro i; apply functor_comp]).
abstract
(split; [ intro x; apply funextsec; intro i; simpl; apply functor_id
| intros x y z f g; apply funextsec; intro i; apply functor_comp]).
Definition pr_functor_data (I : UU) (C : I -> precategory) (i : I) :
functor_data (product_precategory C) (C i).
Show proof.
use tpair.
- intro a; apply (a i).
- intros x y f; simpl; apply (f i).
- intro a; apply (a i).
- intros x y f; simpl; apply (f i).
Definition pr_functor (I : UU) (C : I -> precategory) (i : I) :
functor (product_precategory C) (C i).
Show proof.
apply (tpair _ (pr_functor_data I C i)).
abstract (split; intros x *; apply idpath).
abstract (split; intros x *; apply idpath).
Definition delta_functor_data (I : UU) (C : precategory) :
functor_data C (power_precategory I C).
Show proof.
use tpair.
- intros x i; apply x.
- intros x y f i; simpl; apply f.
- intros x i; apply x.
- intros x y f i; simpl; apply f.
Definition delta_functor (I : UU) (C : precategory) :
functor C (power_precategory I C).
Show proof.
apply (tpair _ (delta_functor_data I C)).
abstract (split; intros x *; apply idpath).
abstract (split; intros x *; apply idpath).
Definition tuple_functor_data {I : UU} {A : precategory} {B : I → precategory}
(F : ∏ i, functor A (B i)) : functor_data A (product_precategory B).
Show proof.
use tpair.
- intros a i; exact (F i a).
- intros a b f i; exact (# (F i) f).
- intros a i; exact (F i a).
- intros a b f i; exact (# (F i) f).
Lemma tuple_functor_axioms {I : UU} {A : precategory} {B : I → precategory}
(F : ∏ i, functor A (B i)) : is_functor (tuple_functor_data F).
Show proof.
split.
- intros a. apply funextsec; intro i. apply functor_id.
- intros ? ? ? ? ?. apply funextsec; intro i. apply functor_comp.
- intros a. apply funextsec; intro i. apply functor_id.
- intros ? ? ? ? ?. apply funextsec; intro i. apply functor_comp.
Definition tuple_functor {I : UU} {A : precategory} {B : I → precategory}
(F : ∏ i, functor A (B i)) : functor A (product_precategory B)
:= (tuple_functor_data F,, tuple_functor_axioms F).
Lemma pr_tuple_functor {I : UU} {A : precategory} {B : I → precategory} (hsB : ∏ i, has_homsets (B i))
(F : ∏ i, functor A (B i)) (i : I) : tuple_functor F ∙ pr_functor I B i = F i.
Show proof.
now apply functor_eq.
End functors.
Equivalence between functors into components and functors into product
Lemma functor_into_product_weq {I : UU} {A : category} {B : I → category} :
functor A (product_category B) ≃ (∏ i : I, functor A (B i)).
Show proof.
functor A (product_category B) ≃ (∏ i : I, functor A (B i)).
Show proof.
  use weq_iso.
- intros ? i.
- intros ? i.
Compose A ⟶ product_precategory I B ⟶ B i 
    apply (functor_composite (C' := product_precategory B)).
+ assumption.
+ exact (pr_functor _ _ i).
- exact tuple_functor.
- intro y.
apply functor_eq; [apply homset_property|].
reflexivity.
- intro f; cbn.
apply funextsec; intro i.
apply functor_eq; [exact (homset_property (B i))|].
reflexivity.
+ assumption.
+ exact (pr_functor _ _ i).
- exact tuple_functor.
- intro y.
apply functor_eq; [apply homset_property|].
reflexivity.
- intro f; cbn.
apply funextsec; intro i.
apply functor_eq; [exact (homset_property (B i))|].
reflexivity.