2015-01-03 01:29:53 -05:00
|
|
|
-- Copyright (c) 2015 Jakob von Raumer. All rights reserved.
|
|
|
|
-- Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
-- Authors: Jakob von Raumer
|
|
|
|
-- Category of sets
|
|
|
|
|
2015-02-20 19:30:32 -05:00
|
|
|
import .basic types.pi types.trunc
|
2015-01-03 01:29:53 -05:00
|
|
|
|
2015-02-20 19:30:32 -05:00
|
|
|
open is_trunc sigma sigma.ops pi function eq morphism precategory
|
2015-01-03 01:29:53 -05:00
|
|
|
open equiv
|
|
|
|
|
|
|
|
namespace precategory
|
|
|
|
|
|
|
|
universe variable l
|
|
|
|
|
|
|
|
definition set_precategory : precategory.{l+1 l} (Σ (A : Type.{l}), is_hset A) :=
|
|
|
|
begin
|
|
|
|
fapply precategory.mk.{l+1 l},
|
2015-02-20 19:30:32 -05:00
|
|
|
intros (a, a_1), apply (a.1 → a_1.1),
|
|
|
|
intros, apply is_trunc_pi, intros, apply b.2,
|
2015-01-03 01:29:53 -05:00
|
|
|
intros, intro x, exact (a_1 (a_2 x)),
|
|
|
|
intros, exact (λ (x : a.1), x),
|
2015-02-20 19:30:32 -05:00
|
|
|
intros, apply funext.eq_of_homotopy, intro x, apply idp,
|
|
|
|
intros, apply funext.eq_of_homotopy, intro x, apply idp,
|
|
|
|
intros, apply funext.eq_of_homotopy, intro x, apply idp,
|
2015-01-03 01:29:53 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
end precategory
|
|
|
|
|
|
|
|
namespace category
|
|
|
|
|
|
|
|
universe variable l
|
2015-01-26 11:31:12 -08:00
|
|
|
local attribute precategory.set_precategory.{l+1 l} [instance]
|
2015-01-03 01:29:53 -05:00
|
|
|
|
|
|
|
definition set_category_equiv_iso (a b : (Σ (A : Type.{l}), is_hset A))
|
|
|
|
: (a ≅ b) = (a.1 ≃ b.1) :=
|
|
|
|
/-begin
|
|
|
|
apply ua, fapply equiv.mk,
|
|
|
|
intro H,
|
|
|
|
apply (isomorphic.rec_on H), intros (H1, H2),
|
|
|
|
apply (is_iso.rec_on H2), intros (H3, H4, H5),
|
|
|
|
fapply equiv.mk,
|
|
|
|
apply (isomorphic.rec_on H), intros (H1, H2),
|
|
|
|
exact H1,
|
|
|
|
fapply is_equiv.adjointify, exact H3,
|
|
|
|
exact sorry,
|
|
|
|
exact sorry,
|
|
|
|
end-/ sorry
|
|
|
|
|
|
|
|
definition set_category : category.{l+1 l} (Σ (A : Type.{l}), is_hset A) :=
|
2015-01-03 15:17:18 -05:00
|
|
|
/-begin
|
2015-01-03 01:29:53 -05:00
|
|
|
assert (C : precategory.{l+1 l} (Σ (A : Type.{l}), is_hset A)),
|
|
|
|
apply precategory.set_precategory,
|
|
|
|
apply category.mk,
|
2015-02-20 19:30:32 -05:00
|
|
|
assert (p : (λ A B p, (set_category_equiv_iso A B) ▹ iso_of_path p) = (λ A B p, @equiv_of_eq A.1 B.1 p)),
|
2015-01-03 15:17:18 -05:00
|
|
|
apply is_equiv.adjointify,
|
2015-01-03 01:29:53 -05:00
|
|
|
intros,
|
|
|
|
apply (isomorphic.rec_on a_1), intros (iso', is_iso'),
|
|
|
|
apply (is_iso.rec_on is_iso'), intros (f', f'sect, f'retr),
|
2015-02-20 19:30:32 -05:00
|
|
|
fapply sigma_eq,
|
2015-01-03 01:29:53 -05:00
|
|
|
apply ua, fapply equiv.mk, exact iso',
|
|
|
|
fapply is_equiv.adjointify,
|
|
|
|
exact f',
|
|
|
|
intros, apply (f'retr ▹ _),
|
|
|
|
intros, apply (f'sect ▹ _),
|
|
|
|
apply (@is_hprop.elim),
|
2015-02-20 19:30:32 -05:00
|
|
|
apply is_hprop_is_trunc,
|
2015-01-03 15:17:18 -05:00
|
|
|
intros,
|
|
|
|
end -/ sorry
|
2015-01-03 01:29:53 -05:00
|
|
|
|
|
|
|
end category
|