2015-02-26 13:19:54 -05:00
|
|
|
/-
|
2015-04-25 00:20:59 -04:00
|
|
|
Copyright (c) 2015 Floris van Doorn. All rights reserved.
|
2015-02-26 13:19:54 -05:00
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
2015-04-25 00:20:59 -04:00
|
|
|
Authors: Floris van Doorn, Jakob von Raumer
|
|
|
|
|
2015-10-27 19:02:42 -04:00
|
|
|
The category of sets is complete and cocomplete
|
2015-02-26 13:19:54 -05:00
|
|
|
-/
|
|
|
|
|
2015-10-27 19:02:42 -04:00
|
|
|
import .colimits ..constructions.set hit.set_quotient
|
2015-02-26 13:19:54 -05:00
|
|
|
|
2015-10-27 19:02:42 -04:00
|
|
|
open eq functor is_trunc sigma pi sigma.ops trunc set_quotient
|
2015-02-26 13:19:54 -05:00
|
|
|
|
|
|
|
namespace category
|
2015-09-25 15:02:14 -04:00
|
|
|
local attribute Category.to.precategory [unfold 1]
|
|
|
|
local attribute category.to_precategory [unfold 2]
|
|
|
|
|
2015-09-25 16:25:46 -04:00
|
|
|
definition is_complete_set_cone.{u v w} [constructor]
|
2015-10-02 19:54:27 -04:00
|
|
|
(I : Precategory.{v w}) (F : I ⇒ set.{max u v w}) : cone_obj F :=
|
2015-09-25 15:02:14 -04:00
|
|
|
begin
|
|
|
|
fapply cone_obj.mk,
|
|
|
|
{ fapply trunctype.mk,
|
|
|
|
{ exact Σ(s : Π(i : I), trunctype.carrier (F i)),
|
|
|
|
Π{i j : I} (f : i ⟶ j), F f (s i) = (s j)},
|
2015-10-02 19:54:27 -04:00
|
|
|
{ with_options [elaborator.ignore_instances true] -- TODO: fix
|
|
|
|
( refine is_trunc_sigma _ _;
|
|
|
|
( apply is_trunc_pi);
|
|
|
|
( intro s;
|
|
|
|
refine is_trunc_pi _ _; intro i;
|
|
|
|
refine is_trunc_pi _ _; intro j;
|
|
|
|
refine is_trunc_pi _ _; intro f;
|
|
|
|
apply is_trunc_eq))}},
|
2015-09-25 15:02:14 -04:00
|
|
|
{ fapply nat_trans.mk,
|
|
|
|
{ intro i x, esimp at x, exact x.1 i},
|
|
|
|
{ intro i j f, esimp, apply eq_of_homotopy, intro x, esimp at x, induction x with s p,
|
|
|
|
esimp, apply p}}
|
|
|
|
end
|
|
|
|
|
2015-10-02 19:54:27 -04:00
|
|
|
definition is_complete_set.{u v w} [instance] : is_complete.{(max u v w)+1 (max u v w) v w} set :=
|
2015-09-25 15:02:14 -04:00
|
|
|
begin
|
|
|
|
intro I F, fapply has_terminal_object.mk,
|
2015-09-25 16:25:46 -04:00
|
|
|
{ exact is_complete_set_cone.{u v w} I F},
|
2015-09-25 15:02:14 -04:00
|
|
|
{ intro c, esimp at *, induction c with X η, induction η with η p, esimp at *,
|
|
|
|
fapply is_contr.mk,
|
|
|
|
{ fapply cone_hom.mk,
|
|
|
|
{ intro x, esimp at *, fapply sigma.mk,
|
|
|
|
{ intro i, exact η i x},
|
|
|
|
{ intro i j f, exact ap10 (p f) x}},
|
|
|
|
{ intro i, reflexivity}},
|
|
|
|
{ esimp, intro h, induction h with f q, apply cone_hom_eq, esimp at *,
|
|
|
|
apply eq_of_homotopy, intro x, fapply sigma_eq: esimp,
|
|
|
|
{ apply eq_of_homotopy, intro i, exact (ap10 (q i) x)⁻¹},
|
2015-10-02 19:54:27 -04:00
|
|
|
{ with_options [elaborator.ignore_instances true] -- TODO: fix
|
|
|
|
( refine is_hprop.elimo _ _ _;
|
|
|
|
refine is_trunc_pi _ _; intro i;
|
|
|
|
refine is_trunc_pi _ _; intro j;
|
|
|
|
refine is_trunc_pi _ _; intro f;
|
|
|
|
apply is_trunc_eq)}}}
|
2015-10-01 16:26:50 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
definition is_cocomplete_set_cone_rel.{u v w} [unfold 3 4]
|
2015-10-02 19:54:27 -04:00
|
|
|
(I : Precategory.{v w}) (F : I ⇒ set.{max u v w}ᵒᵖ) : (Σ(i : I), trunctype.carrier (F i)) →
|
2015-10-01 16:26:50 -04:00
|
|
|
(Σ(i : I), trunctype.carrier (F i)) → hprop.{max u v w} :=
|
|
|
|
begin
|
|
|
|
intro v w, induction v with i x, induction w with j y,
|
|
|
|
fapply trunctype.mk,
|
|
|
|
{ exact ∃(f : i ⟶ j), to_fun_hom F f y = x},
|
|
|
|
{ exact _}
|
2015-09-25 15:02:14 -04:00
|
|
|
end
|
2015-09-25 19:44:04 -04:00
|
|
|
|
2015-10-27 19:02:42 -04:00
|
|
|
|
2015-10-01 16:26:50 -04:00
|
|
|
definition is_cocomplete_set_cone.{u v w} [constructor]
|
2015-10-02 19:54:27 -04:00
|
|
|
(I : Precategory.{v w}) (F : I ⇒ set.{max u v w}ᵒᵖ) : cone_obj F :=
|
2015-10-01 16:26:50 -04:00
|
|
|
begin
|
|
|
|
fapply cone_obj.mk,
|
|
|
|
{ fapply trunctype.mk,
|
|
|
|
{ apply set_quotient (is_cocomplete_set_cone_rel.{u v w} I F)},
|
|
|
|
{ apply is_hset_set_quotient}},
|
|
|
|
{ fapply nat_trans.mk,
|
|
|
|
{ intro i x, esimp, apply class_of, exact ⟨i, x⟩},
|
|
|
|
{ intro i j f, esimp, apply eq_of_homotopy, intro y, apply eq_of_rel, esimp,
|
|
|
|
exact exists.intro f idp}}
|
|
|
|
end
|
|
|
|
|
2015-10-23 01:12:34 -04:00
|
|
|
-- TODO: change this after induction tactic for trunc/set_quotient is implemented
|
2015-10-01 16:26:50 -04:00
|
|
|
definition is_cocomplete_set.{u v w} [instance]
|
|
|
|
: is_cocomplete.{(max u v w)+1 (max u v w) v w} set :=
|
|
|
|
begin
|
|
|
|
intro I F, fapply has_terminal_object.mk,
|
|
|
|
{ exact is_cocomplete_set_cone.{u v w} I F},
|
|
|
|
{ intro c, esimp at *, induction c with X η, induction η with η p, esimp at *,
|
|
|
|
fapply is_contr.mk,
|
|
|
|
{ fapply cone_hom.mk,
|
|
|
|
{ refine set_quotient.elim _ _,
|
|
|
|
{ intro v, induction v with i x, exact η i x},
|
|
|
|
{ intro v w r, induction v with i x, induction w with j y, esimp at *,
|
|
|
|
refine trunc.elim_on r _, clear r,
|
|
|
|
intro u, induction u with f q,
|
|
|
|
exact ap (η i) q⁻¹ ⬝ ap10 (p f) y}},
|
|
|
|
{ intro i, reflexivity}},
|
|
|
|
{ esimp, intro h, induction h with f q, apply cone_hom_eq, esimp at *,
|
|
|
|
apply eq_of_homotopy, refine set_quotient.rec _ _,
|
|
|
|
{ intro v, induction v with i x, esimp, exact (ap10 (q i) x)⁻¹},
|
|
|
|
{ intro v w r, apply is_hprop.elimo}}},
|
|
|
|
end
|
|
|
|
|
2015-02-26 13:19:54 -05:00
|
|
|
end category
|