Step * 2 1 1 1 2 1 1 1 of Lemma bar-separation-implies-twkl!


1. Type
2. ∃size:ℕ~ ℕsize
3. BarSep(T;T)
4. {A:(T List) ⟶ ℙdown-closed(T;A) ∧ Unbounded(A)} 
5. ¬tbar(T;¬(A))
6. Decidable(A)
7. ∀as,bs:T List.  (as ≤ bs  (A bs)  (A as))
8. T
9. ∀a,b:T.  Dec(a b ∈ T)
10. eff-unique-path(T;A)
11. ∀s:T List. ∃t:T. ∀t':T. ((¬(t' t ∈ T))  tbar(T;¬x.(A ((s [t']) x)))))
12. s:(T List) ⟶ T
13. ∀s:T List. ∀t':T.  ((¬(t' (g s) ∈ T))  tbar(T;¬x.(A ((s [t']) x)))))
14. : ℤ
15. 0 < n
16. ||primrec(n 1;[];λn',s. (s [g s]))|| (n 1) ∈ ℤ
17. 0 <  (primrec(n 1;[];λn',s. (s [g s]))[n 1] (g primrec(n 1;[];λn',s. (s [g s]))) ∈ T)
18. map(λn.primrec(n 1;[];λn',s. (s [g s]))[n];upto(n 1)) primrec(n 1;[];λn',s. (s [g s])) ∈ (T List)
⊢ ||primrec(n;[];λn',s. (s [g s]))|| n ∈ ℤ
BY
((RWO "primrec-unroll" THENA Auto) THEN AutoSplit THEN (RWO "length-append" THENA Auto) THEN Reduce THEN Auto')
⋅ }


Latex:


Latex:

1.  T  :  Type
2.  \mexists{}size:\mBbbN{}.  T  \msim{}  \mBbbN{}size
3.  BarSep(T;T)
4.  A  :  \{A:(T  List)  {}\mrightarrow{}  \mBbbP{}|  down-closed(T;A)  \mwedge{}  Unbounded(A)\} 
5.  \mneg{}tbar(T;\mneg{}(A))
6.  Decidable(A)
7.  \mforall{}as,bs:T  List.    (as  \mleq{}  bs  {}\mRightarrow{}  (A  bs)  {}\mRightarrow{}  (A  as))
8.  T
9.  \mforall{}a,b:T.    Dec(a  =  b)
10.  eff-unique-path(T;A)
11.  \mforall{}s:T  List.  \mexists{}t:T.  \mforall{}t':T.  ((\mneg{}(t'  =  t))  {}\mRightarrow{}  tbar(T;\mneg{}(\mlambda{}x.(A  ((s  @  [t'])  @  x)))))
12.  g  :  s:(T  List)  {}\mrightarrow{}  T
13.  \mforall{}s:T  List.  \mforall{}t':T.    ((\mneg{}(t'  =  (g  s)))  {}\mRightarrow{}  tbar(T;\mneg{}(\mlambda{}x.(A  ((s  @  [t'])  @  x)))))
14.  n  :  \mBbbZ{}
15.  0  <  n
16.  ||primrec(n  -  1;[];\mlambda{}n',s.  (s  @  [g  s]))||  =  (n  -  1)
17.  0  <  n  -  1
{}\mRightarrow{}  (primrec(n  -  1;[];\mlambda{}n',s.  (s  @  [g  s]))[n  -  1  -  1]  =  (g  primrec(n  -  1  -  1;[];\mlambda{}n',s.  (s  @  [g  s]))))
18.  map(\mlambda{}n.primrec(n  +  1;[];\mlambda{}n',s.  (s  @  [g  s]))[n];upto(n  -  1))  =  primrec(n  -  1;[];\mlambda{}n',s.  (s  @  [g  s]\000C))
\mvdash{}  ||primrec(n;[];\mlambda{}n',s.  (s  @  [g  s]))||  =  n


By


Latex:
((RWO  "primrec-unroll"  0  THENA  Auto)
  THEN  AutoSplit
  THEN  (RWO  "length-append"  0  THENA  Auto)
  THEN  Reduce  0
  THEN  Auto')\mcdot{}




Home Index