2015-04-10 22:15:47 +00:00
|
|
|
|
/-
|
|
|
|
|
Copyright (c) 2015 Floris van Doorn. All rights reserved.
|
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
Author: Floris van Doorn
|
|
|
|
|
|
2015-05-27 23:38:31 +00:00
|
|
|
|
Squares in a type
|
2015-04-10 22:15:47 +00:00
|
|
|
|
-/
|
|
|
|
|
|
|
|
|
|
open eq equiv is_equiv
|
|
|
|
|
|
2015-05-27 01:39:29 +00:00
|
|
|
|
namespace eq
|
2015-04-10 22:15:47 +00:00
|
|
|
|
|
2015-05-27 23:38:31 +00:00
|
|
|
|
variables {A B : Type} {a a' a'' a₀₀ a₂₀ a₄₀ a₀₂ a₂₂ a₂₄ a₀₄ a₄₂ a₄₄ : A}
|
2015-04-10 22:15:47 +00:00
|
|
|
|
/-a₀₀-/ {p₁₀ : a₀₀ = a₂₀} /-a₂₀-/ {p₃₀ : a₂₀ = a₄₀} /-a₄₀-/
|
|
|
|
|
{p₀₁ : a₀₀ = a₀₂} /-s₁₁-/ {p₂₁ : a₂₀ = a₂₂} /-s₃₁-/ {p₄₁ : a₄₀ = a₄₂}
|
|
|
|
|
/-a₀₂-/ {p₁₂ : a₀₂ = a₂₂} /-a₂₂-/ {p₃₂ : a₂₂ = a₄₂} /-a₄₂-/
|
|
|
|
|
{p₀₃ : a₀₂ = a₀₄} /-s₁₃-/ {p₂₃ : a₂₂ = a₂₄} /-s₃₃-/ {p₄₃ : a₄₂ = a₄₄}
|
|
|
|
|
/-a₀₄-/ {p₁₄ : a₀₄ = a₂₄} /-a₂₄-/ {p₃₄ : a₂₄ = a₄₄} /-a₄₄-/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
inductive square {A : Type} {a₀₀ : A}
|
|
|
|
|
: Π{a₂₀ a₀₂ a₂₂ : A}, a₀₀ = a₂₀ → a₀₂ = a₂₂ → a₀₀ = a₀₂ → a₂₀ = a₂₂ → Type :=
|
|
|
|
|
ids : square idp idp idp idp
|
|
|
|
|
/- square top bottom left right -/
|
|
|
|
|
|
|
|
|
|
variables {s₁₁ : square p₁₀ p₁₂ p₀₁ p₂₁} {s₃₁ : square p₃₀ p₃₂ p₂₁ p₄₁}
|
|
|
|
|
{s₁₃ : square p₁₂ p₁₄ p₀₃ p₂₃} {s₃₃ : square p₃₂ p₃₄ p₂₃ p₄₃}
|
|
|
|
|
|
2015-05-27 23:38:31 +00:00
|
|
|
|
definition ids [reducible] [constructor] := @square.ids
|
2015-05-21 03:37:43 +00:00
|
|
|
|
definition idsquare [reducible] [constructor] (a : A) := @square.ids A a
|
2015-04-10 22:15:47 +00:00
|
|
|
|
|
2015-05-21 03:37:43 +00:00
|
|
|
|
definition hrefl [unfold-c 4] (p : a = a') : square idp idp p p :=
|
2015-04-10 22:15:47 +00:00
|
|
|
|
by cases p; exact ids
|
|
|
|
|
|
2015-05-21 03:37:43 +00:00
|
|
|
|
definition vrefl [unfold-c 4] (p : a = a') : square p p idp idp :=
|
2015-04-10 22:15:47 +00:00
|
|
|
|
by cases p; exact ids
|
|
|
|
|
|
2015-05-27 23:38:31 +00:00
|
|
|
|
definition hrfl [unfold-c 4] {p : a = a'} : square idp idp p p :=
|
|
|
|
|
!hrefl
|
|
|
|
|
definition vrfl [unfold-c 4] {p : a = a'} : square p p idp idp :=
|
|
|
|
|
!vrefl
|
|
|
|
|
|
2015-04-10 22:15:47 +00:00
|
|
|
|
definition hconcat (s₁₁ : square p₁₀ p₁₂ p₀₁ p₂₁) (s₃₁ : square p₃₀ p₃₂ p₂₁ p₄₁)
|
|
|
|
|
: square (p₁₀ ⬝ p₃₀) (p₁₂ ⬝ p₃₂) p₀₁ p₄₁ :=
|
|
|
|
|
by cases s₃₁; exact s₁₁
|
|
|
|
|
|
|
|
|
|
definition vconcat (s₁₁ : square p₁₀ p₁₂ p₀₁ p₂₁) (s₁₃ : square p₁₂ p₁₄ p₀₃ p₂₃)
|
|
|
|
|
: square p₁₀ p₁₄ (p₀₁ ⬝ p₀₃) (p₂₁ ⬝ p₂₃) :=
|
|
|
|
|
by cases s₁₃; exact s₁₁
|
|
|
|
|
|
|
|
|
|
definition hinverse (s₁₁ : square p₁₀ p₁₂ p₀₁ p₂₁) : square p₁₀⁻¹ p₁₂⁻¹ p₂₁ p₀₁ :=
|
|
|
|
|
by cases s₁₁;exact ids
|
|
|
|
|
|
|
|
|
|
definition vinverse (s₁₁ : square p₁₀ p₁₂ p₀₁ p₂₁) : square p₁₂ p₁₀ p₀₁⁻¹ p₂₁⁻¹ :=
|
|
|
|
|
by cases s₁₁;exact ids
|
|
|
|
|
|
|
|
|
|
definition transpose (s₁₁ : square p₁₀ p₁₂ p₀₁ p₂₁) : square p₀₁ p₂₁ p₁₀ p₁₂ :=
|
|
|
|
|
by cases s₁₁;exact ids
|
|
|
|
|
|
|
|
|
|
definition eq_of_square (s₁₁ : square p₁₀ p₁₂ p₀₁ p₂₁) : p₁₀ ⬝ p₂₁ = p₀₁ ⬝ p₁₂ :=
|
|
|
|
|
by cases s₁₁; apply idp
|
|
|
|
|
|
2015-05-27 23:38:31 +00:00
|
|
|
|
definition hdeg_square {p q : a = a'} (r : p = q) : square idp idp p q :=
|
2015-04-10 22:15:47 +00:00
|
|
|
|
by cases r;apply hrefl
|
|
|
|
|
|
2015-05-27 23:38:31 +00:00
|
|
|
|
definition vdeg_square {p q : a = a'} (r : p = q) : square p q idp idp :=
|
2015-04-10 22:15:47 +00:00
|
|
|
|
by cases r;apply vrefl
|
|
|
|
|
|
|
|
|
|
definition square_of_eq (r : p₁₀ ⬝ p₂₁ = p₀₁ ⬝ p₁₂) : square p₁₀ p₁₂ p₀₁ p₂₁ :=
|
|
|
|
|
by cases p₁₂; (esimp [concat] at r); cases r; cases p₂₁; cases p₁₀; exact ids
|
|
|
|
|
|
2015-05-26 13:56:41 +00:00
|
|
|
|
definition aps {B : Type} (f : A → B) (s₁₁ : square p₁₀ p₁₂ p₀₁ p₂₁)
|
|
|
|
|
: square (ap f p₁₀) (ap f p₁₂) (ap f p₀₁) (ap f p₂₁) :=
|
|
|
|
|
by cases s₁₁;exact ids
|
|
|
|
|
|
|
|
|
|
definition square_of_homotopy {B : Type} {f g : A → B} (H : f ∼ g) (p : a = a')
|
|
|
|
|
: square (H a) (H a') (ap f p) (ap g p) :=
|
|
|
|
|
by cases p; apply vrefl
|
|
|
|
|
|
|
|
|
|
definition square_of_homotopy' {B : Type} {f g : A → B} (H : f ∼ g) (p : a = a')
|
|
|
|
|
: square (ap f p) (ap g p) (H a) (H a') :=
|
|
|
|
|
by cases p; apply hrefl
|
|
|
|
|
|
2015-04-10 22:15:47 +00:00
|
|
|
|
definition square_equiv_eq (t : a₀₀ = a₀₂) (b : a₂₀ = a₂₂) (l : a₀₀ = a₂₀) (r : a₀₂ = a₂₂)
|
|
|
|
|
: square t b l r ≃ t ⬝ r = l ⬝ b :=
|
|
|
|
|
begin
|
|
|
|
|
fapply equiv.MK,
|
|
|
|
|
{ exact eq_of_square},
|
|
|
|
|
{ exact square_of_eq},
|
|
|
|
|
{ intro s, cases b, esimp [concat] at s, cases s, cases r, cases t, apply idp},
|
|
|
|
|
{ intro s, cases s, apply idp},
|
|
|
|
|
end
|
|
|
|
|
|
2015-06-04 01:41:21 +00:00
|
|
|
|
definition natural_square [unfold-c 8] {f g : A → B} (p : f ∼ g) (q : a = a') :
|
2015-05-29 18:50:19 +00:00
|
|
|
|
square (p a) (p a') (ap f q) (ap g q) :=
|
|
|
|
|
eq.rec_on q vrfl
|
|
|
|
|
|
2015-05-21 03:37:43 +00:00
|
|
|
|
definition rec_on_b [recursor] {a₀₀ : A}
|
2015-04-10 22:15:47 +00:00
|
|
|
|
{P : Π{a₂₀ a₁₂ : A} {t : a₀₀ = a₂₀} {l : a₀₀ = a₁₂} {r : a₂₀ = a₁₂}, square t idp l r → Type}
|
|
|
|
|
{a₂₀ a₁₂ : A} {t : a₀₀ = a₂₀} {l : a₀₀ = a₁₂} {r : a₂₀ = a₁₂}
|
|
|
|
|
(s : square t idp l r) (H : P ids) : P s :=
|
|
|
|
|
have H2 : P (square_of_eq (eq_of_square s)),
|
|
|
|
|
from eq.rec_on (eq_of_square s : t ⬝ r = l) (by cases r; cases t; exact H),
|
2015-05-01 03:23:12 +00:00
|
|
|
|
left_inv (to_fun !square_equiv_eq) s ▸ H2
|
2015-04-10 22:15:47 +00:00
|
|
|
|
|
2015-05-21 03:37:43 +00:00
|
|
|
|
definition rec_on_r [recursor] {a₀₀ : A}
|
2015-04-10 22:15:47 +00:00
|
|
|
|
{P : Π{a₀₂ a₂₁ : A} {t : a₀₀ = a₂₁} {b : a₀₂ = a₂₁} {l : a₀₀ = a₀₂}, square t b l idp → Type}
|
|
|
|
|
{a₀₂ a₂₁ : A} {t : a₀₀ = a₂₁} {b : a₀₂ = a₂₁} {l : a₀₀ = a₀₂}
|
|
|
|
|
(s : square t b l idp) (H : P ids) : P s :=
|
|
|
|
|
let p : l ⬝ b = t := (eq_of_square s)⁻¹ in
|
|
|
|
|
have H2 : P (square_of_eq (eq_of_square s)⁻¹⁻¹),
|
|
|
|
|
from @eq.rec_on _ _ (λx p, P (square_of_eq p⁻¹)) _ p (by cases b; cases l; exact H),
|
2015-05-01 03:23:12 +00:00
|
|
|
|
left_inv (to_fun !square_equiv_eq) s ▸ !inv_inv ▸ H2
|
2015-04-10 22:15:47 +00:00
|
|
|
|
|
2015-05-21 03:37:43 +00:00
|
|
|
|
definition rec_on_l [recursor] {a₀₁ : A}
|
2015-04-10 22:15:47 +00:00
|
|
|
|
{P : Π {a₂₀ a₂₂ : A} {t : a₀₁ = a₂₀} {b : a₀₁ = a₂₂} {r : a₂₀ = a₂₂},
|
|
|
|
|
square t b idp r → Type}
|
|
|
|
|
{a₂₀ a₂₂ : A} {t : a₀₁ = a₂₀} {b : a₀₁ = a₂₂} {r : a₂₀ = a₂₂}
|
|
|
|
|
(s : square t b idp r) (H : P ids) : P s :=
|
|
|
|
|
let p : t ⬝ r = b := eq_of_square s ⬝ !idp_con in
|
|
|
|
|
have H2 : P (square_of_eq (p ⬝ !idp_con⁻¹)),
|
|
|
|
|
from eq.rec_on p (by cases r; cases t; exact H),
|
2015-05-01 03:23:12 +00:00
|
|
|
|
left_inv (to_fun !square_equiv_eq) s ▸ !con_inv_cancel_right ▸ H2
|
2015-04-10 22:15:47 +00:00
|
|
|
|
|
2015-05-21 03:37:43 +00:00
|
|
|
|
definition rec_on_t [recursor] {a₁₀ : A}
|
2015-04-29 19:25:31 +00:00
|
|
|
|
{P : Π {a₀₂ a₂₂ : A} {b : a₀₂ = a₂₂} {l : a₁₀ = a₀₂} {r : a₁₀ = a₂₂}, square idp b l r → Type}
|
2015-04-10 22:15:47 +00:00
|
|
|
|
{a₀₂ a₂₂ : A} {b : a₀₂ = a₂₂} {l : a₁₀ = a₀₂} {r : a₁₀ = a₂₂}
|
|
|
|
|
(s : square idp b l r) (H : P ids) : P s :=
|
|
|
|
|
let p : l ⬝ b = r := (eq_of_square s)⁻¹ ⬝ !idp_con in
|
|
|
|
|
assert H2 : P (square_of_eq ((p ⬝ !idp_con⁻¹)⁻¹)),
|
|
|
|
|
from eq.rec_on p (by cases b; cases l; exact H),
|
2015-04-29 19:16:37 +00:00
|
|
|
|
assert H3 : P (square_of_eq ((eq_of_square s)⁻¹⁻¹)),
|
|
|
|
|
from eq.rec_on !con_inv_cancel_right H2,
|
|
|
|
|
assert H4 : P (square_of_eq (eq_of_square s)),
|
|
|
|
|
from eq.rec_on !inv_inv H3,
|
|
|
|
|
proof
|
2015-05-01 03:23:12 +00:00
|
|
|
|
left_inv (to_fun !square_equiv_eq) s ▸ H4
|
2015-04-29 19:16:37 +00:00
|
|
|
|
qed
|
2015-04-10 22:15:47 +00:00
|
|
|
|
|
2015-05-21 03:37:43 +00:00
|
|
|
|
definition rec_on_tb [recursor] {a : A}
|
2015-04-10 22:15:47 +00:00
|
|
|
|
{P : Π{b : A} {l : a = b} {r : a = b}, square idp idp l r → Type}
|
|
|
|
|
{b : A} {l : a = b} {r : a = b}
|
|
|
|
|
(s : square idp idp l r) (H : P ids) : P s :=
|
|
|
|
|
have H2 : P (square_of_eq (eq_of_square s)),
|
|
|
|
|
from eq.rec_on (eq_of_square s : idp ⬝ r = l) (by cases r; exact H),
|
2015-05-01 03:23:12 +00:00
|
|
|
|
left_inv (to_fun !square_equiv_eq) s ▸ H2
|
2015-04-10 22:15:47 +00:00
|
|
|
|
|
2015-05-29 18:50:19 +00:00
|
|
|
|
definition rec_on_lr [recursor] {a : A}
|
|
|
|
|
{P : Π{a' : A} {t : a = a'} {b : a = a'}, square t b idp idp → Type}
|
|
|
|
|
{a' : A} {t : a = a'} {b : a = a'}
|
|
|
|
|
(s : square t b idp idp) (H : P ids) : P s :=
|
|
|
|
|
let p : idp ⬝ b = t := (eq_of_square s)⁻¹ in
|
|
|
|
|
assert H2 : P (square_of_eq (eq_of_square s)⁻¹⁻¹),
|
|
|
|
|
from @eq.rec_on _ _ (λx q, P (square_of_eq q⁻¹)) _ p (by cases b; exact H),
|
|
|
|
|
to_left_inv (!square_equiv_eq) s ▸ !inv_inv ▸ H2
|
|
|
|
|
|
|
|
|
|
definition eq_of_hdeg_square {p q : a = a'} (s : square idp idp p q) : p = q :=
|
|
|
|
|
rec_on_tb s idp
|
|
|
|
|
|
|
|
|
|
definition eq_of_vdeg_square {p q : a = a'} (s : square p q idp idp) : p = q :=
|
|
|
|
|
rec_on_lr s idp
|
2015-05-27 23:38:31 +00:00
|
|
|
|
|
2015-05-29 18:50:19 +00:00
|
|
|
|
--we can also do the other recursors (tl, tr, bl, br, tbl, tbr, tlr, blr), but let's postpone this until they are needed
|
2015-04-10 22:15:47 +00:00
|
|
|
|
|
2015-05-27 01:39:29 +00:00
|
|
|
|
end eq
|