feat(hott/types): start characterization of pi-types and W-types
This commit is contained in:
parent
2913035a61
commit
e52157a8ea
2 changed files with 212 additions and 0 deletions
153
library/hott/types/W.lean
Normal file
153
library/hott/types/W.lean
Normal file
|
@ -0,0 +1,153 @@
|
|||
/-
|
||||
Copyright (c) 2014 Floris van Doorn. All rights reserved.
|
||||
Released under Apache 2.0 license as described in the file LICENSE.
|
||||
Author: Floris van Doorn
|
||||
|
||||
Theorems about W-types (well-founded trees)
|
||||
-/
|
||||
|
||||
import .sigma .pi
|
||||
open path sigma sigma.ops equiv is_equiv
|
||||
|
||||
|
||||
inductive W {A : Type} (B : A → Type) :=
|
||||
sup : Π(a : A), (B a → W B) → W B
|
||||
|
||||
namespace W
|
||||
notation `WW` binders `,` r:(scoped B, W B) := r
|
||||
|
||||
universe variables l k
|
||||
variables {A A' : Type.{l}} {B B' : A → Type.{k}} {C : Π(a : A), B a → Type}
|
||||
{a a' : A} {f : B a → W B} {f' : B a' → W B} {w w' : WW(a : A), B a}
|
||||
|
||||
definition pr1 (w : WW(a : A), B a) : A :=
|
||||
W.rec_on w (λa f IH, a)
|
||||
|
||||
definition pr2 (w : WW(a : A), B a) : B (pr1 w) → WW(a : A), B a :=
|
||||
W.rec_on w (λa f IH, f)
|
||||
|
||||
namespace ops
|
||||
postfix `.1`:(max+1) := W.pr1
|
||||
postfix `.2`:(max+1) := W.pr2
|
||||
notation `⟨` a `,` f `⟩`:0 := W.sup a f --input ⟨ ⟩ as \< \>
|
||||
end ops
|
||||
open ops
|
||||
|
||||
protected definition eta (w : WW a, B a) : ⟨w.1 , w.2⟩ ≈ w :=
|
||||
cases_on w (λa f, idp)
|
||||
|
||||
definition path_W_sup (p : a ≈ a') (q : p ▹ f ≈ f') : ⟨a, f⟩ ≈ ⟨a', f'⟩ :=
|
||||
path.rec_on p (λf' q, path.rec_on q idp) f' q
|
||||
|
||||
definition path_W (p : w.1 ≈ w'.1) (q : p ▹ w.2 ≈ w'.2) : w ≈ w' :=
|
||||
cases_on w
|
||||
(λw1 w2, cases_on w' (λ w1' w2', path_W_sup))
|
||||
p q
|
||||
|
||||
definition pr1_path (p : w ≈ w') : w.1 ≈ w'.1 :=
|
||||
path.rec_on p idp
|
||||
|
||||
definition pr2_path (p : w ≈ w') : pr1_path p ▹ w.2 ≈ w'.2 :=
|
||||
path.rec_on p idp
|
||||
|
||||
namespace ops
|
||||
postfix `..1`:(max+1) := pr1_path
|
||||
postfix `..2`:(max+1) := pr2_path
|
||||
end ops
|
||||
open ops
|
||||
|
||||
definition sup_path_W (p : w.1 ≈ w'.1) (q : p ▹ w.2 ≈ w'.2)
|
||||
: dpair (path_W p q)..1 (path_W p q)..2 ≈ dpair p q :=
|
||||
begin
|
||||
reverts (p, q),
|
||||
apply (cases_on w), intros (w1, w2),
|
||||
apply (cases_on w'), intros (w1', w2', p), generalize w2', --change to revert
|
||||
apply (path.rec_on p), intros (w2', q),
|
||||
apply (path.rec_on q), apply idp
|
||||
end
|
||||
|
||||
definition pr1_path_W (p : w.1 ≈ w'.1) (q : p ▹ w.2 ≈ w'.2) : (path_W p q)..1 ≈ p :=
|
||||
(!sup_path_W)..1
|
||||
|
||||
definition pr2_path_W (p : w.1 ≈ w'.1) (q : p ▹ w.2 ≈ w'.2)
|
||||
: pr1_path_W p q ▹ (path_W p q)..2 ≈ q :=
|
||||
(!sup_path_W)..2
|
||||
|
||||
definition eta_path_W (p : w ≈ w') : path_W (p..1) (p..2) ≈ p :=
|
||||
begin
|
||||
apply (path.rec_on p),
|
||||
apply (cases_on w), intros (w1, w2),
|
||||
apply idp
|
||||
end
|
||||
|
||||
definition transport_pr1_path_W {B' : A → Type} (p : w.1 ≈ w'.1) (q : p ▹ w.2 ≈ w'.2)
|
||||
: transport (λx, B' x.1) (path_W p q) ≈ transport B' p :=
|
||||
begin
|
||||
reverts (p, q),
|
||||
apply (cases_on w), intros (w1, w2),
|
||||
apply (cases_on w'), intros (w1', w2', p), generalize w2',
|
||||
apply (path.rec_on p), intros (w2', q),
|
||||
apply (path.rec_on q), apply idp
|
||||
end
|
||||
|
||||
definition path_W_uncurried (pq : Σ(p : w.1 ≈ w'.1), p ▹ w.2 ≈ w'.2) : w ≈ w' :=
|
||||
destruct pq path_W
|
||||
|
||||
definition sup_path_W_uncurried (pq : Σ(p : w.1 ≈ w'.1), p ▹ w.2 ≈ w'.2)
|
||||
: dpair (path_W_uncurried pq)..1 (path_W_uncurried pq)..2 ≈ pq :=
|
||||
destruct pq sup_path_W
|
||||
|
||||
definition pr1_path_W_uncurried (pq : Σ(p : w.1 ≈ w'.1), p ▹ w.2 ≈ w'.2)
|
||||
: (path_W_uncurried pq)..1 ≈ pq.1 :=
|
||||
(!sup_path_W_uncurried)..1
|
||||
|
||||
definition pr2_path_W_uncurried (pq : Σ(p : w.1 ≈ w'.1), p ▹ w.2 ≈ w'.2)
|
||||
: (pr1_path_W_uncurried pq) ▹ (path_W_uncurried pq)..2 ≈ pq.2 :=
|
||||
(!sup_path_W_uncurried)..2
|
||||
|
||||
definition eta_path_W_uncurried (p : w ≈ w') : path_W_uncurried (dpair p..1 p..2) ≈ p :=
|
||||
!eta_path_W
|
||||
|
||||
definition transport_pr1_path_W_uncurried {B' : A → Type} (pq : Σ(p : w.1 ≈ w'.1), p ▹ w.2 ≈ w'.2)
|
||||
: transport (λx, B' x.1) (@path_W_uncurried A B w w' pq) ≈ transport B' pq.1 :=
|
||||
destruct pq transport_pr1_path_W
|
||||
|
||||
definition isequiv_path_W /-[instance]-/ (w w' : W B)
|
||||
: is_equiv (@path_W_uncurried A B w w') :=
|
||||
adjointify path_W_uncurried
|
||||
(λp, dpair (p..1) (p..2))
|
||||
eta_path_W_uncurried
|
||||
sup_path_W_uncurried
|
||||
|
||||
definition equiv_path_W (w w' : W B) : (Σ(p : w.1 ≈ w'.1), p ▹ w.2 ≈ w'.2) ≃ (w ≈ w') :=
|
||||
equiv.mk path_W_uncurried !isequiv_path_W
|
||||
|
||||
definition double_induction_on {P : W B → W B → Type} (w w' : W B)
|
||||
(H : ∀ (a a' : A) (f : B a → W B) (f' : B a' → W B),
|
||||
(∀ (b : B a) (b' : B a'), P (f b) (f' b')) → P (sup a f) (sup a' f')) : P w w' :=
|
||||
begin
|
||||
revert w',
|
||||
apply (rec_on w), intros (a, f, IH, w'),
|
||||
apply (cases_on w'), intros (a', f'),
|
||||
apply H, intros (b, b'),
|
||||
apply IH
|
||||
end
|
||||
|
||||
/- truncatedness -/
|
||||
open truncation
|
||||
definition trunc_W [FUN : funext.{k (max 1 l k)}] (n : trunc_index) [HA : is_trunc (n.+1) A]
|
||||
: is_trunc (n.+1) (WW a, B a) :=
|
||||
begin
|
||||
fapply is_trunc_succ, intros (w, w'),
|
||||
apply (double_induction_on w w'), intros (a, a', f, f', IH),
|
||||
fapply trunc_equiv',
|
||||
apply equiv_path_W,
|
||||
apply trunc_sigma,
|
||||
fapply succ_is_trunc,
|
||||
intro p, revert IH, generalize f', --change to revert after simpl
|
||||
apply (path.rec_on p), intros (f', IH),
|
||||
apply (@pi.trunc_path_pi FUN (B a) (λx, W B) n f f'), intro b,
|
||||
apply IH
|
||||
end
|
||||
|
||||
end W
|
59
library/hott/types/pi.lean
Normal file
59
library/hott/types/pi.lean
Normal file
|
@ -0,0 +1,59 @@
|
|||
/-
|
||||
Copyright (c) 2014 Floris van Doorn. All rights reserved.
|
||||
Released under Apache 2.0 license as described in the file LICENSE.
|
||||
Author: Floris van Doorn
|
||||
Ported from Coq HoTT
|
||||
|
||||
Theorems about pi-types (dependent function spaces)
|
||||
-/
|
||||
|
||||
import ..trunc ..axioms.funext
|
||||
open path equiv is_equiv funext
|
||||
|
||||
namespace pi
|
||||
universe variables l k
|
||||
variables [H : funext.{l k}] {A : Type.{l}} {B : A → Type.{k}} {C : Πa, B a → Type}
|
||||
{D : Πa b, C a b → Type}
|
||||
{a a' a'' : A} {b b₁ b₂ : B a} {b' : B a'} {b'' : B a''} {f g h : Πa, B a}
|
||||
include H
|
||||
/- Paths -/
|
||||
|
||||
/- Paths [p : f ≈ g] in a function type [Πx:X, P x] are equivalent to functions taking values in path types, [H : Πx:X, f x ≈ g x], or concisely, [H : f == g].
|
||||
|
||||
This equivalence, however, is just the combination of [apD10] and function extensionality [funext], and as such, [path_forall], et seq. are given in axioms.funext and path: -/
|
||||
|
||||
/- Now we show how these things compute. -/
|
||||
|
||||
definition equiv_apD10 : (f ≈ g) ≃ (f ∼ g) :=
|
||||
equiv.mk _ !funext.ap
|
||||
|
||||
open truncation
|
||||
definition trunc_pi [instance] (B : A → Type.{k}) (n : trunc_index)
|
||||
[H : ∀a, is_trunc n (B a)] : is_trunc n (Πa, B a) :=
|
||||
begin
|
||||
reverts (B, H),
|
||||
apply (truncation.trunc_index.rec_on n),
|
||||
intros (B, H),
|
||||
fapply is_contr.mk,
|
||||
intro a, apply center, apply H, --remove "apply H" when term synthesis works correctly
|
||||
intro f, apply path_forall,
|
||||
intro x, apply (contr (f x)),
|
||||
intros (n, IH, B, H),
|
||||
fapply is_trunc_succ, intros (f, g),
|
||||
fapply trunc_equiv',
|
||||
apply equiv.symm, apply equiv_apD10,
|
||||
apply IH,
|
||||
intro a,
|
||||
show is_trunc n (f a ≈ g a), from
|
||||
succ_is_trunc (f a) (g a)
|
||||
end
|
||||
|
||||
definition trunc_path_pi [instance] (n : trunc_index) (f g : Πa, B a)
|
||||
[H : ∀a, is_trunc n (f a ≈ g a)] : is_trunc n (f ≈ g) :=
|
||||
begin
|
||||
apply trunc_equiv', apply equiv.symm,
|
||||
apply equiv_apD10,
|
||||
apply trunc_pi, exact H,
|
||||
end
|
||||
|
||||
end pi
|
Loading…
Reference in a new issue