2014-10-26 10:27:33 -07:00
|
|
|
|
import logic data.prod
|
|
|
|
|
open eq.ops prod tactic
|
|
|
|
|
|
|
|
|
|
inductive tree (A : Type) :=
|
2015-02-25 17:00:10 -08:00
|
|
|
|
| leaf : A → tree A
|
|
|
|
|
| node : tree A → tree A → tree A
|
2014-10-26 10:27:33 -07:00
|
|
|
|
|
2015-10-13 15:39:03 -07:00
|
|
|
|
inductive one1.{l} : Type.{max 1 l} :=
|
|
|
|
|
star : one1
|
2014-10-26 10:27:33 -07:00
|
|
|
|
|
|
|
|
|
set_option pp.universes true
|
|
|
|
|
|
|
|
|
|
namespace tree
|
2014-11-12 16:38:46 -08:00
|
|
|
|
namespace manual
|
2014-10-26 10:27:33 -07:00
|
|
|
|
section
|
|
|
|
|
universe variables l₁ l₂
|
|
|
|
|
variable {A : Type.{l₁}}
|
|
|
|
|
variable (C : tree A → Type.{l₂})
|
|
|
|
|
definition below (t : tree A) : Type :=
|
2015-10-13 15:39:03 -07:00
|
|
|
|
tree.rec_on t (λ a, one1.{l₂}) (λ t₁ t₂ r₁ r₂, C t₁ × C t₂ × r₁ × r₂)
|
2014-10-26 10:27:33 -07:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
section
|
|
|
|
|
universe variables l₁ l₂
|
|
|
|
|
variable {A : Type.{l₁}}
|
|
|
|
|
variable {C : tree A → Type.{l₂}}
|
|
|
|
|
definition below_rec_on (t : tree A) (H : Π (n : tree A), below C n → C n) : C t
|
|
|
|
|
:= have general : C t × below C t, from
|
2015-02-11 12:49:27 -08:00
|
|
|
|
tree.rec_on t
|
2015-10-13 15:39:03 -07:00
|
|
|
|
(λa, (H (leaf a) one1.star, one1.star))
|
2014-10-26 10:27:33 -07:00
|
|
|
|
(λ (l r : tree A) (Hl : C l × below C l) (Hr : C r × below C r),
|
|
|
|
|
have b : below C (node l r), from
|
|
|
|
|
(pr₁ Hl, pr₁ Hr, pr₂ Hl, pr₂ Hr),
|
|
|
|
|
have c : C (node l r), from
|
|
|
|
|
H (node l r) b,
|
|
|
|
|
(c, b)),
|
|
|
|
|
pr₁ general
|
|
|
|
|
end
|
2014-11-12 16:38:46 -08:00
|
|
|
|
end manual
|
2015-02-11 12:49:27 -08:00
|
|
|
|
local abbreviation no_confusion := @tree.no_confusion
|
2014-10-26 10:27:33 -07:00
|
|
|
|
check no_confusion
|
|
|
|
|
|
|
|
|
|
theorem leaf_ne_tree {A : Type} (a : A) (l r : tree A) : leaf a ≠ node l r :=
|
|
|
|
|
assume h : leaf a = node l r,
|
|
|
|
|
no_confusion h
|
|
|
|
|
|
|
|
|
|
constant A : Type₁
|
|
|
|
|
constants l₁ l₂ r₁ r₂ : tree A
|
|
|
|
|
axiom node_eq : node l₁ r₁ = node l₂ r₂
|
|
|
|
|
check no_confusion node_eq
|
|
|
|
|
|
|
|
|
|
definition tst : (l₁ = l₂ → r₁ = r₂ → l₁ = l₂) → l₁ = l₂ := no_confusion node_eq
|
|
|
|
|
check tst (λ e₁ e₂, e₁)
|
|
|
|
|
|
|
|
|
|
theorem node.inj1 {A : Type} (l₁ l₂ r₁ r₂ : tree A) : node l₁ r₁ = node l₂ r₂ → l₁ = l₂ :=
|
|
|
|
|
assume h,
|
|
|
|
|
have trivial : (l₁ = l₂ → r₁ = r₂ → l₁ = l₂) → l₁ = l₂, from no_confusion h,
|
|
|
|
|
trivial (λ e₁ e₂, e₁)
|
|
|
|
|
|
|
|
|
|
theorem node.inj2 {A : Type} (l₁ l₂ r₁ r₂ : tree A) : node l₁ r₁ = node l₂ r₂ → l₁ = l₂ :=
|
|
|
|
|
begin
|
|
|
|
|
intro h,
|
|
|
|
|
apply (no_confusion h),
|
|
|
|
|
intros, assumption
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem node.inj3 {A : Type} {l₁ l₂ r₁ r₂ : tree A} (h : node l₁ r₁ = node l₂ r₂) : l₁ = l₂ :=
|
|
|
|
|
begin
|
|
|
|
|
apply (no_confusion h),
|
|
|
|
|
assume (e₁ : l₁ = l₂) (e₂ : r₁ = r₂), e₁
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem node.inj4 {A : Type} {l₁ l₂ r₁ r₂ : tree A} (h : node l₁ r₁ = node l₂ r₂) : l₁ = l₂ :=
|
|
|
|
|
begin
|
|
|
|
|
apply (no_confusion h),
|
|
|
|
|
assume e₁ e₂, e₁
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
end tree
|