feat(algebra|types): small additions

add to markdown file for algebra, and add some definitions in types/
This commit is contained in:
Floris van Doorn 2015-11-20 22:32:35 -05:00 committed by Leonardo de Moura
parent 5328486d49
commit 88a62f8e74
5 changed files with 26 additions and 8 deletions

View file

@ -1,16 +1,24 @@
algebra algebra
======= =======
Note: most of these files are ported from the standard library. If anything needs to be changed, it is probably a good idea to change it in the standard library and then port the file again (see also [script/port.pl](../../script/port.pl)). The following files are ported from the standard library. If anything needs to be changed, it is probably a good idea to change it in the standard library and then port the file again (see also [script/port.pl](../../script/port.pl)).
* [binary](binary.hlean) : properties of binary operations * [binary](binary.hlean) : properties of binary operations
* [relation](relation.hlean) : properties of relations * [relation](relation.hlean) : properties of relations
* [group](group.hlean) * [group](group.hlean)
* [ring](ring.hlean) * [ring](ring.hlean)
* [order](order.hlean)
* [ordered_group](ordered_group.hlean) * [ordered_group](ordered_group.hlean)
* [ordered_ring](ordered_ring.hlean) * [ordered_ring](ordered_ring.hlean)
* [field](field.hlean) * [field](field.hlean)
Files which are not ported:
* [hott](hott.hlean) : Basic theorems about the algebraic hierarchy specific to HoTT
* [trunc_group](trunc_group.hlean) : truncate an infinity-group to a group
* [homotopy_group](homotopy_group.hlean) : homotopy groups of a pointed type
* [e_closure](e_closure.hlean) : the type of words formed by a relation
Subfolders: Subfolders:
* [category](category/category.md) : Category Theory * [category](category/category.md) : Category Theory

View file

@ -104,13 +104,13 @@ namespace trunc
/- Propositional truncation -/ /- Propositional truncation -/
-- should this live in hprop? -- should this live in hprop?
definition merely [reducible] (A : Type) : Type := trunc -1 A definition merely [reducible] (A : Type) : hprop := trunctype.mk (trunc -1 A) _
notation `||`:max A `||`:0 := merely A notation `||`:max A `||`:0 := merely A
notation `∥`:max A `∥`:0 := merely A notation `∥`:max A `∥`:0 := merely A
definition Exists [reducible] (P : X → Type) : Type := ∥ sigma P ∥ definition Exists [reducible] (P : X → Type) : hprop := ∥ sigma P ∥
definition or [reducible] (A B : Type) : Type := ∥ A ⊎ B ∥ definition or [reducible] (A B : Type) : hprop := ∥ A ⊎ B ∥
notation `exists` binders `,` r:(scoped P, Exists P) := r notation `exists` binders `,` r:(scoped P, Exists P) := r
notation `∃` binders `,` r:(scoped P, Exists P) := r notation `∃` binders `,` r:(scoped P, Exists P) := r

View file

@ -352,4 +352,8 @@ namespace pointed
definition equiv_of_pequiv [constructor] (f : A ≃* B) : A ≃ B := definition equiv_of_pequiv [constructor] (f : A ≃* B) : A ≃ B :=
equiv.mk f _ equiv.mk f _
definition pua {A B : Type*} (f : A ≃* B) : A = B :=
Pointed_eq (equiv_of_pequiv f) !respect_pt
end pointed end pointed

View file

@ -413,11 +413,11 @@ namespace sigma
notation [parsing_only] `{` binder `|` r:(scoped:1 P, subtype P) `}` := r notation [parsing_only] `{` binder `|` r:(scoped:1 P, subtype P) `}` := r
/- To prove equality in a subtype, we only need equality of the first component. -/ /- To prove equality in a subtype, we only need equality of the first component. -/
definition subtype_eq [H : Πa, is_hprop (B a)] (u v : {a | B a}) : u.1 = v.1 → u = v := definition subtype_eq [H : Πa, is_hprop (B a)] {u v : {a | B a}} : u.1 = v.1 → u = v :=
sigma_eq_unc ∘ inv pr1 sigma_eq_unc ∘ inv pr1
definition is_equiv_subtype_eq [H : Πa, is_hprop (B a)] (u v : {a | B a}) definition is_equiv_subtype_eq [H : Πa, is_hprop (B a)] (u v : {a | B a})
: is_equiv (subtype_eq u v) := : is_equiv (subtype_eq : u.1 = v.1 → u = v) :=
!is_equiv_compose !is_equiv_compose
local attribute is_equiv_subtype_eq [instance] local attribute is_equiv_subtype_eq [instance]
@ -426,14 +426,13 @@ namespace sigma
definition subtype_eq_inv {A : Type} {B : A → Type} [H : Πa, is_hprop (B a)] (u v : Σa, B a) definition subtype_eq_inv {A : Type} {B : A → Type} [H : Πa, is_hprop (B a)] (u v : Σa, B a)
: u = v → u.1 = v.1 := : u = v → u.1 = v.1 :=
(subtype_eq u v)⁻¹ᶠ subtype_eq⁻¹ᶠ
local attribute subtype_eq_inv [reducible] local attribute subtype_eq_inv [reducible]
definition is_equiv_subtype_eq_inv {A : Type} {B : A → Type} [H : Πa, is_hprop (B a)] definition is_equiv_subtype_eq_inv {A : Type} {B : A → Type} [H : Πa, is_hprop (B a)]
(u v : Σa, B a) : is_equiv (subtype_eq_inv u v) := (u v : Σa, B a) : is_equiv (subtype_eq_inv u v) :=
_ _
/- truncatedness -/ /- truncatedness -/
theorem is_trunc_sigma (B : A → Type) (n : trunc_index) theorem is_trunc_sigma (B : A → Type) (n : trunc_index)
[HA : is_trunc n A] [HB : Πa, is_trunc n (B a)] : is_trunc n (Σa, B a) := [HA : is_trunc n A] [HB : Πa, is_trunc n (B a)] : is_trunc n (Σa, B a) :=
@ -447,6 +446,11 @@ namespace sigma
exact IH _ _ _ _} exact IH _ _ _ _}
end end
theorem is_trunc_subtype (B : A → hprop) (n : trunc_index)
[HA : is_trunc (n.+1) A] : is_trunc (n.+1) (Σa, B a) :=
@(is_trunc_sigma B (n.+1)) _ (λa, !is_trunc_succ_of_is_hprop)
end sigma end sigma
attribute sigma.is_trunc_sigma [instance] [priority 1490] attribute sigma.is_trunc_sigma [instance] [priority 1490]
attribute sigma.is_trunc_subtype [instance] [priority 1200]

View file

@ -241,6 +241,8 @@ namespace trunc
: transport (λa, trunc n (P a)) p (tr x) = tr (p ▸ x) := : transport (λa, trunc n (P a)) p (tr x) = tr (p ▸ x) :=
by induction p; reflexivity by induction p; reflexivity
definition image {A B : Type} (f : A → B) (b : B) : hprop := ∃(a : A), f a = b
end trunc open trunc end trunc open trunc
namespace function namespace function