2014-11-25 16:53:09 -08:00
|
|
|
import logic data.nat.basic
|
|
|
|
open nat
|
|
|
|
|
|
|
|
inductive inftree (A : Type) : Type :=
|
2015-02-25 17:00:10 -08:00
|
|
|
| leaf : A → inftree A
|
|
|
|
| node : (nat → inftree A) → inftree A → inftree A
|
2014-11-25 16:53:09 -08:00
|
|
|
|
|
|
|
namespace inftree
|
|
|
|
inductive dsub {A : Type} : inftree A → inftree A → Prop :=
|
2015-02-25 17:00:10 -08:00
|
|
|
| intro₁ : Π (f : nat → inftree A) (a : nat) (t : inftree A), dsub (f a) (node f t)
|
|
|
|
| intro₂ : Π (f : nat → inftree A) (a : nat) (t : inftree A), dsub t (node f t)
|
2014-11-25 16:53:09 -08:00
|
|
|
|
|
|
|
definition dsub.node.acc {A : Type} (f : nat → inftree A) (hf : ∀a, acc dsub (f a))
|
|
|
|
(t : inftree A) (ht : acc dsub t) : acc dsub (node f t) :=
|
|
|
|
acc.intro (node f t) (λ (y : inftree A) (hlt : dsub y (node f t)),
|
2014-12-03 15:28:22 -08:00
|
|
|
by cases hlt; apply (hf a); apply ht)
|
2014-11-25 16:53:09 -08:00
|
|
|
|
|
|
|
definition dsub.leaf.acc {A : Type} (a : A) : acc dsub (leaf a) :=
|
|
|
|
acc.intro (leaf a) (λ (y : inftree A) (hlt : dsub y (leaf a)),
|
2014-12-03 15:28:22 -08:00
|
|
|
by cases hlt)
|
2014-11-25 16:53:09 -08:00
|
|
|
|
|
|
|
definition dsub.wf (A : Type) : well_founded (@dsub A) :=
|
|
|
|
well_founded.intro (λ (t : inftree A),
|
2015-02-11 12:49:27 -08:00
|
|
|
inftree.rec_on t
|
2014-11-25 16:53:09 -08:00
|
|
|
(λ a, dsub.leaf.acc a)
|
|
|
|
(λ f t (ihf :∀a, acc dsub (f a)) (iht : acc dsub t), dsub.node.acc f ihf t iht))
|
|
|
|
|
|
|
|
end inftree
|