Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Set-enriched categories #1467

Open
wants to merge 62 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
62 commits
Select commit Hold shift + click to select a range
d884132
Uniqueness of general products (up to isomorphism)
langston-barrett Oct 21, 2018
0d97d7f
Associativity of binary products
langston-barrett Oct 21, 2018
b222d1f
Fix notation conflict
langston-barrett Oct 21, 2018
c13d72e
monoidal structure on categories with products
langston-barrett Oct 22, 2018
e629c8b
Migrate proof of binary product associativity to binproducts.v
langston-barrett Oct 28, 2018
dabdc7b
Add Cartesian.v to CONTENTS.md
langston-barrett Oct 28, 2018
ca9bf06
fix errors
umedaikiti Nov 23, 2021
38574c7
Merge branch 'master' into univalence-slices
nmvdw Feb 13, 2022
2d319b9
Merge pull request #1457 from nmvdw/univalence-slices
benediktahrens Feb 14, 2022
096421b
Street (op)fibs in Cat
nmvdw Feb 14, 2022
70324d3
Merge branch 'master' into street-fib-in-cat
nmvdw Feb 14, 2022
d2273bf
Merge pull request #1458 from nmvdw/street-fib-in-cat
benediktahrens Feb 14, 2022
d04c63d
try to get the unicode notation table to look nice in ASCII viewing mode
DanGrayson Feb 17, 2022
36b3874
Merge branch 'master' of github.com:UniMath/UniMath
DanGrayson Feb 17, 2022
5ff1ae2
add some remarks about emacs to USAGE.md
DanGrayson Feb 17, 2022
c725e07
try to get the unicode notation table to look nice in ASCII viewing m…
DanGrayson Feb 17, 2022
f3bb66e
Duality involutions, rework discrete bicats
nmvdw Feb 18, 2022
393e08c
Merge branch 'master' into duality-involution
nmvdw Feb 18, 2022
fc49805
Whoops....
nmvdw Feb 18, 2022
d239668
Remove comments
nmvdw Feb 18, 2022
368f71d
Forgot to add a file
nmvdw Feb 18, 2022
91d2bb0
Merge pull request #1460 from nmvdw/duality-involution
benediktahrens Feb 18, 2022
6cc9f2e
Uniqueness of general products (up to isomorphism)
langston-barrett Oct 21, 2018
8018188
Associativity of binary products
langston-barrett Oct 21, 2018
e1dd9d7
Fix notation conflict
langston-barrett Oct 21, 2018
6c4c07b
monoidal structure on categories with products
langston-barrett Oct 22, 2018
7e7b846
Migrate proof of binary product associativity to binproducts.v
langston-barrett Oct 28, 2018
740c86e
Add Cartesian.v to CONTENTS.md
langston-barrett Oct 28, 2018
2eeccd0
fix errors
umedaikiti Nov 23, 2021
503a80e
remove obsolete file Cats.v with def of precat of cats
benediktahrens Feb 20, 2022
b76613d
dissolve DispCat/Aux
benediktahrens Feb 20, 2022
c08e9d4
Merge pull request #1461 from benediktahrens/issue-1404
DanGrayson Feb 21, 2022
0da7f1c
Merge branch 'master' into issue-1421-sq
benediktahrens Feb 21, 2022
9abbfb0
Merge pull request #1462 from benediktahrens/issue-1421-sq
DanGrayson Feb 21, 2022
ac60705
remove duplicate z_iso_inv_mor
benediktahrens Feb 22, 2022
9ff746c
remove duplicate z_iso_is_z_isomorphism2
benediktahrens Feb 22, 2022
bb95381
remove comments
benediktahrens Feb 22, 2022
f0da7e2
arguments now implicit
benediktahrens Feb 22, 2022
c5f099d
arguments now implicit II
benediktahrens Feb 22, 2022
78e12b4
arguments now implicit III
benediktahrens Feb 22, 2022
b089c47
arguments now implicit IV
benediktahrens Feb 22, 2022
5362f3a
Merge pull request #1463 from benediktahrens/issue-948
benediktahrens Feb 23, 2022
ff504a7
mention tags-search in the INSTALL file
DanGrayson Mar 2, 2022
e4111db
move tags-search discussion from USAGE to INSTALL
DanGrayson Mar 2, 2022
dbda0c0
remove autorewrite
umedaikiti Mar 4, 2022
6d7c516
Merge branch 'cartesian-monoidal' of github.com:umedaikiti/UniMath in…
umedaikiti Mar 4, 2022
2ac52f4
add correspondence between HSET-enriched and ordinary categories
umedaikiti Mar 5, 2022
126a7e9
improve proofs
umedaikiti Mar 5, 2022
39ea615
Merge branch 'UniMath:master' into cartesian-monoidal
umedaikiti Mar 5, 2022
ea2e038
Merge branch 'UniMath:master' into cartesian-monoidal
umedaikiti Mar 5, 2022
0a08dae
remove auto and autorewrite
umedaikiti Mar 5, 2022
16ae6a5
move some parts to UniMath/Bicategories/EnrichedCategories
umedaikiti Mar 7, 2022
18f4a6c
Merge branch 'master' into cartesian-monoidal
benediktahrens Mar 11, 2022
7166753
Merge branch 'master' into cartesian-monoidal
benediktahrens Oct 18, 2022
70c125f
Update UniMath/CategoryTheory/limits/binproducts.v
benediktahrens Nov 7, 2022
9788301
Update UniMath/CategoryTheory/limits/binproducts.v
benediktahrens Nov 7, 2022
2a7cdc5
Update UniMath/CategoryTheory/limits/binproducts.v
benediktahrens Nov 7, 2022
5d42579
Update UniMath/CategoryTheory/limits/binproducts.v
benediktahrens Nov 7, 2022
7c41460
Update UniMath/CategoryTheory/limits/binproducts.v
benediktahrens Nov 7, 2022
98f0cc6
Merge branch 'master' into cartesian-monoidal
benediktahrens Nov 7, 2022
41339c6
Merge branch 'master' into cartesian-monoidal
benediktahrens Nov 18, 2022
9d5e0e4
Update UniMath/CategoryTheory/Monoidal/Cartesian.v
benediktahrens Nov 18, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Migrate proof of binary product associativity to binproducts.v
  • Loading branch information
langston-barrett authored and umedaikiti committed Feb 19, 2022
commit 7e7b846acc1f618c780ff008b20087060e8a5f3f
38 changes: 3 additions & 35 deletions UniMath/CategoryTheory/Monoidal/Cartesian.v
Original file line number Diff line number Diff line change
Expand Up @@ -71,49 +71,16 @@ Section CartesianMonoidal.
(* Local Notation "π1[ ( x ) ⊗ ( y ) ]" := (BinProductPr1 _ (BC x y)). *)
(* Local Notation "π2[ ( x ) ⊗ ( y ) ]" := (BinProductPr2 _ (BC x y)). *)

(* Equalities for which it almost always pays to rewrite forward *)
Hint Resolve BinProductArrow : binprod.
Hint Resolve BinProductPr1 : binprod.
Hint Resolve BinProductPr2 : binprod.
Hint Resolve compose : binprod.

(** The behavior of eauto here is to [apply] the above hints until successful *)
Definition binprod_assoc_r {x y z} : C⟦x ⊗ (y ⊗ z), (x ⊗ y) ⊗ z⟧.
Proof.
eauto with binprod.
Defined.

Definition binprod_assoc_l {x y z} : C⟦(x ⊗ y) ⊗ z, x ⊗ (y ⊗ z)⟧.
Proof.
eauto with binprod.
Defined.

(* Equalities for which it almost always pays to rewrite forward *)
Hint Rewrite BinProductPr1Commutes : binprod.
Hint Rewrite BinProductPr2Commutes : binprod.
Hint Rewrite BinProductOfArrowsPr1 : binprod.
Hint Rewrite BinProductOfArrowsPr2 : binprod.

Lemma assoc_l_qinv_assoc_r {x y z : C} :
is_inverse_in_precat (@binprod_assoc_l x y z) (@binprod_assoc_r x y z).
Proof.
unfold is_inverse_in_precat.
split.
- unfold binprod_assoc_l, binprod_assoc_r.
do 2 rewrite precompWithBinProductArrow.
repeat ( rewrite assoc || autorewrite with binprod ).
refine (_ @ !BinProductArrowEta _ _ _ _ _ (id (x ⊗ y ⊗ z))).
do 2 rewrite id_left.
apply (maponpaths (fun f => BinProductArrow _ _ f _)).
exact (! BinProductArrowEta _ _ _ _ _ (BinProductPr1 _ _)).
- unfold binprod_assoc_l, binprod_assoc_r.
do 2 rewrite precompWithBinProductArrow.
repeat ( rewrite assoc || autorewrite with binprod ).
refine (_ @ !BinProductArrowEta _ _ _ _ _ (id (x ⊗ (y ⊗ z)))).
do 2 rewrite id_left.
apply (maponpaths (fun f => BinProductArrow _ _ _ f)).
exact (! BinProductArrowEta _ _ _ _ _ (BinProductPr2 _ _)).
Qed.

Local Lemma f_equal_2 :
forall {A B C : UU} (f : A -> B -> C) (a a' : A) (b b' : B),
a = a' -> b = b' -> f a b = f a' b'.
Expand All @@ -138,6 +105,7 @@ Section CartesianMonoidal.
use tpair.
+ use mk_nat_trans.
* intros x.
unfold assoc_left; cbn.
apply binprod_assoc_l.
* intros x y f; cbn.
unfold binprod_assoc_l.
Expand Down Expand Up @@ -203,4 +171,4 @@ Section CartesianMonoidal.
rewrite id_right.
reflexivity.
Defined.
End CartesianMonoidal.
End CartesianMonoidal.
65 changes: 63 additions & 2 deletions UniMath/CategoryTheory/limits/binproducts.v
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ Extended by: Langston Barrett (@siddharthist), 2018
- Terminal object as the unit (up to isomorphism) of binary products
- Equivalence with indexed products over [bool]
- Associativity
- Direct proof
- Alternate proof based on equivalence with three-way products

*)

Expand Down Expand Up @@ -833,11 +835,70 @@ End ProductsBool.

(** ** Associativity *)

(** *** Direct proof *)

Section Assoc.
Context {C : precategory}.
Context (BC : BinProducts C).

Hint Resolve BinProductArrow : binprod.
Hint Resolve BinProductPr1 : binprod.
Hint Resolve BinProductPr2 : binprod.
Hint Resolve compose : binprod.

Local Notation "c '⊗' d" := (BinProductObject C (BC c d)) : cat.
Local Notation "f '××' g" := (BinProductOfArrows _ _ _ f g) (at level 80) : cat.
Local Open Scope cat.

(** The behavior of eauto here is to [apply] the above hints until successful *)
Definition binprod_assoc_r {x y z} : C⟦x ⊗ (y ⊗ z), (x ⊗ y) ⊗ z⟧.
Proof.
eauto with binprod.
Defined.

Definition binprod_assoc_l {x y z} : C⟦(x ⊗ y) ⊗ z, x ⊗ (y ⊗ z)⟧.
Proof.
eauto with binprod.
Defined.

(* Equalities for which it almost always pays to rewrite forward *)
Hint Rewrite BinProductPr1Commutes : binprod.
Hint Rewrite BinProductPr2Commutes : binprod.
Hint Rewrite BinProductOfArrowsPr1 : binprod.
Hint Rewrite BinProductOfArrowsPr2 : binprod.

(** This isomorphism extends to a natural ismorphism, see
[CategoryTheory.Monoidal.Cartesian]. *)
Lemma assoc_l_qinv_assoc_r {x y z : C} :
is_inverse_in_precat (@binprod_assoc_l x y z) (@binprod_assoc_r x y z).
Proof.
unfold is_inverse_in_precat.
split.
- unfold binprod_assoc_l, binprod_assoc_r.
do 2 rewrite precompWithBinProductArrow.
do 4 ( rewrite assoc || autorewrite with binprod ).
refine (_ @ !BinProductArrowEta _ _ _ _ _ (identity _)).
do 2 rewrite id_left.
apply (maponpaths (fun f => BinProductArrow _ _ f _)).
exact (! BinProductArrowEta _ _ _ _ _ (BinProductPr1 _ _)).
- unfold binprod_assoc_l, binprod_assoc_r.
do 2 rewrite precompWithBinProductArrow.
do 4 ( rewrite assoc || autorewrite with binprod ).
refine (_ @ !BinProductArrowEta _ _ _ _ _ (identity _)).
do 2 rewrite id_left.
apply (maponpaths (fun f => BinProductArrow _ _ _ f)).
exact (! BinProductArrowEta _ _ _ _ _ (BinProductPr2 _ _)).
Qed.

End Assoc.

(** *** Alternate proof based on equivalence with three-way products *)

(** We show associativity by demonstrating that [(a × b) × c] and
[a × (b × c)] are both ternary products of a, b, and c, and so
are isomorphic. *)

Section Assoc.
Section Assoc3.
Context {C : precategory}.
Context (BPC : BinProducts C).
Context (hsC : has_homsets C).
Expand Down Expand Up @@ -970,4 +1031,4 @@ Section Assoc.
eapply product_unique.
Defined.

End Assoc.
End Assoc3.