2014-12-12 04:14:53 +00:00
|
|
|
-- Copyright (c) 2014 Jakob von Raumer. All rights reserved.
|
|
|
|
-- Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
-- Author: Jakob von Raumer
|
|
|
|
|
|
|
|
import ..precategory.basic ..precategory.morphism ..precategory.iso
|
|
|
|
|
2015-02-21 00:30:32 +00:00
|
|
|
open precategory morphism is_equiv eq is_trunc nat sigma sigma.ops
|
2014-12-12 04:14:53 +00:00
|
|
|
|
|
|
|
-- A category is a precategory extended by a witness,
|
|
|
|
-- that the function assigning to each isomorphism a path,
|
|
|
|
-- is an equivalecnce.
|
|
|
|
structure category [class] (ob : Type) extends (precategory ob) :=
|
|
|
|
(iso_of_path_equiv : Π {a b : ob}, is_equiv (@iso_of_path ob (precategory.mk hom _ comp ID assoc id_left id_right) a b))
|
|
|
|
|
2015-01-26 19:31:12 +00:00
|
|
|
attribute category [multiple-instances]
|
2014-12-22 01:18:38 +00:00
|
|
|
|
2014-12-12 04:14:53 +00:00
|
|
|
namespace category
|
|
|
|
variables {ob : Type} {C : category ob} {a b : ob}
|
|
|
|
include C
|
|
|
|
|
|
|
|
-- Make iso_of_path_equiv a class instance
|
|
|
|
-- TODO: Unsafe class instance?
|
2015-01-26 19:31:12 +00:00
|
|
|
attribute iso_of_path_equiv [instance]
|
2014-12-12 04:14:53 +00:00
|
|
|
|
2014-12-12 19:19:06 +00:00
|
|
|
definition path_of_iso {a b : ob} : a ≅ b → a = b :=
|
2014-12-12 04:14:53 +00:00
|
|
|
iso_of_path⁻¹
|
|
|
|
|
2015-02-07 01:27:56 +00:00
|
|
|
set_option apply.class_instance false -- disable class instance resolution in the apply tactic
|
|
|
|
|
2015-02-21 00:30:32 +00:00
|
|
|
definition ob_1_type : is_trunc (succ nat.zero) ob :=
|
2014-12-12 04:14:53 +00:00
|
|
|
begin
|
2015-02-21 00:30:32 +00:00
|
|
|
apply is_trunc_succ_intro, intros (a, b),
|
|
|
|
fapply is_trunc_is_equiv_closed,
|
2014-12-12 04:14:53 +00:00
|
|
|
exact (@path_of_iso _ _ a b),
|
2015-02-21 00:30:32 +00:00
|
|
|
apply is_equiv_inv,
|
2014-12-12 04:14:53 +00:00
|
|
|
apply is_hset_iso,
|
|
|
|
end
|
|
|
|
|
|
|
|
end category
|
|
|
|
|
|
|
|
-- Bundled version of categories
|
2015-02-21 00:30:32 +00:00
|
|
|
|
|
|
|
structure Category : Type :=
|
|
|
|
(objects : Type)
|
|
|
|
(category_instance : category objects)
|
|
|
|
|
|
|
|
namespace category
|
|
|
|
definition Mk {ob} (C) : Category := Category.mk ob C
|
|
|
|
--definition MK (a b c d e f g h i) : Category := Category.mk a (category.mk b c d e f g h i)
|
|
|
|
|
|
|
|
definition objects [coercion] [reducible] := Category.objects
|
|
|
|
definition category_instance [instance] [coercion] [reducible] := Category.category_instance
|
|
|
|
|
|
|
|
end category
|
|
|
|
|
|
|
|
open category
|
|
|
|
|
|
|
|
protected definition Category.eta (C : Category) : Category.mk C C = C :=
|
|
|
|
Category.rec (λob c, idp) C
|