2015-04-09 21:45:18 -04:00
|
|
|
/-
|
|
|
|
Copyright (c) 2015 Floris van Doorn. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
Authors: Floris van Doorn
|
|
|
|
|
2015-06-04 15:57:00 -04:00
|
|
|
Quotients. This is a quotient without truncation for an arbitrary type-valued binary relation.
|
|
|
|
See also .set_quotient
|
2015-04-09 21:45:18 -04:00
|
|
|
-/
|
|
|
|
|
2015-06-04 15:57:00 -04:00
|
|
|
/-
|
|
|
|
The hit quotient is primitive, declared in init.hit.
|
|
|
|
The constructors are, given {A : Type} (R : A → A → Type),
|
|
|
|
* class_of : A → quotient R (A implicit, R explicit)
|
|
|
|
* eq_of_rel : Π{a a' : A}, R a a' → class_of a = class_of a' (R explicit)
|
|
|
|
-/
|
2015-04-09 21:45:18 -04:00
|
|
|
|
2015-06-04 15:57:00 -04:00
|
|
|
open eq equiv sigma.ops
|
2015-04-09 21:45:18 -04:00
|
|
|
|
|
|
|
namespace quotient
|
|
|
|
|
2015-06-04 15:57:00 -04:00
|
|
|
variables {A : Type} {R : A → A → Type}
|
2015-04-09 21:45:18 -04:00
|
|
|
|
2015-06-04 15:57:00 -04:00
|
|
|
protected definition elim {P : Type} (Pc : A → P) (Pp : Π⦃a a' : A⦄ (H : R a a'), Pc a = Pc a')
|
|
|
|
(x : quotient R) : P :=
|
|
|
|
quotient.rec Pc (λa a' H, pathover_of_eq (Pp H)) x
|
2015-04-09 21:45:18 -04:00
|
|
|
|
2015-06-04 15:57:00 -04:00
|
|
|
protected definition elim_on [reducible] {P : Type} (x : quotient R)
|
|
|
|
(Pc : A → P) (Pp : Π⦃a a' : A⦄ (H : R a a'), Pc a = Pc a') : P :=
|
|
|
|
quotient.elim Pc Pp x
|
2015-04-09 21:45:18 -04:00
|
|
|
|
2015-06-04 15:57:00 -04:00
|
|
|
theorem elim_eq_of_rel {P : Type} (Pc : A → P)
|
|
|
|
(Pp : Π⦃a a' : A⦄ (H : R a a'), Pc a = Pc a') {a a' : A} (H : R a a')
|
|
|
|
: ap (quotient.elim Pc Pp) (eq_of_rel R H) = Pp H :=
|
2015-04-09 21:45:18 -04:00
|
|
|
begin
|
2015-06-04 15:57:00 -04:00
|
|
|
apply eq_of_fn_eq_fn_inv !(pathover_constant (eq_of_rel R H)),
|
|
|
|
rewrite [▸*,-apdo_eq_pathover_of_eq_ap,↑quotient.elim,rec_eq_of_rel],
|
2015-04-09 21:45:18 -04:00
|
|
|
end
|
|
|
|
|
2015-06-04 15:57:00 -04:00
|
|
|
protected definition elim_type (Pc : A → Type)
|
|
|
|
(Pp : Π⦃a a' : A⦄ (H : R a a'), Pc a ≃ Pc a') : quotient R → Type :=
|
|
|
|
quotient.elim Pc (λa a' H, ua (Pp H))
|
2015-04-09 21:45:18 -04:00
|
|
|
|
2015-06-04 15:57:00 -04:00
|
|
|
protected definition elim_type_on [reducible] (x : quotient R) (Pc : A → Type)
|
|
|
|
(Pp : Π⦃a a' : A⦄ (H : R a a'), Pc a ≃ Pc a') : Type :=
|
|
|
|
quotient.elim_type Pc Pp x
|
2015-04-27 17:34:55 -04:00
|
|
|
|
2015-06-04 15:57:00 -04:00
|
|
|
theorem elim_type_eq_of_rel (Pc : A → Type)
|
|
|
|
(Pp : Π⦃a a' : A⦄ (H : R a a'), Pc a ≃ Pc a') {a a' : A} (H : R a a')
|
|
|
|
: transport (quotient.elim_type Pc Pp) (eq_of_rel R H) = to_fun (Pp H) :=
|
|
|
|
by rewrite [tr_eq_cast_ap_fn, ↑quotient.elim_type, elim_eq_of_rel];apply cast_ua_fn
|
2015-04-09 21:45:18 -04:00
|
|
|
|
2015-06-04 15:57:00 -04:00
|
|
|
definition elim_type_uncurried (H : Σ(Pc : A → Type), Π⦃a a' : A⦄ (H : R a a'), Pc a ≃ Pc a')
|
|
|
|
: quotient R → Type :=
|
|
|
|
quotient.elim_type H.1 H.2
|
2015-04-09 21:45:18 -04:00
|
|
|
end quotient
|
2015-05-07 16:35:14 -04:00
|
|
|
|
2015-06-04 15:57:00 -04:00
|
|
|
attribute quotient.rec [recursor]
|
2015-07-07 16:37:06 -07:00
|
|
|
attribute quotient.elim [unfold 6] [recursor 6]
|
|
|
|
attribute quotient.elim_type [unfold 5]
|
|
|
|
attribute quotient.elim_on [unfold 4]
|
|
|
|
attribute quotient.elim_type_on [unfold 3]
|