2014-11-30 21:16:01 -08:00
|
|
|
prelude
|
2014-09-09 09:25:35 -07:00
|
|
|
-- category
|
|
|
|
|
2014-09-17 14:39:05 -07:00
|
|
|
definition Prop := Type.{0}
|
2014-10-02 16:20:52 -07:00
|
|
|
constant eq {A : Type} : A → A → Prop
|
2014-09-09 09:25:35 -07:00
|
|
|
infix `=`:50 := eq
|
|
|
|
|
|
|
|
inductive category (ob : Type) (mor : ob → ob → Type) : Type :=
|
|
|
|
mk : Π (id : Π (A : ob), mor A A),
|
|
|
|
(Π (A B : ob) (f : mor A A), id A = f) → category ob mor
|
|
|
|
|
2014-09-17 14:39:05 -07:00
|
|
|
definition id (ob : Type) (mor : ob → ob → Type) (Cat : category ob mor) := category.rec (λ id idl, id) Cat
|
2014-09-09 09:25:35 -07:00
|
|
|
|
2015-01-24 20:23:21 -08:00
|
|
|
attribute id [reducible]
|
2014-09-09 09:25:35 -07:00
|
|
|
theorem id_left (ob : Type) (mor : ob → ob → Type) (Cat : category ob mor) (A : ob) (f : mor A A) :
|
|
|
|
@eq (mor A A) (id ob mor Cat A) f :=
|
|
|
|
@category.rec ob mor (λ (C : category ob mor), @eq (mor A A) (id ob mor C A) f)
|
|
|
|
(λ (id : Π (A : ob), mor A A)
|
|
|
|
(idl : Π (A : ob), _),
|
|
|
|
idl A A f)
|
|
|
|
Cat
|