Step
*
2
1
1
1
2
1
1
1
of Lemma
bar-separation-implies-twkl!
1. T : Type
2. ∃size:ℕ. T ~ ℕsize
3. BarSep(T;T)
4. A : {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. g : s:(T List) ⟶ T
13. ∀s:T List. ∀t':T.  ((¬(t' = (g s) ∈ T)) 
⇒ tbar(T;¬(λx.(A ((s @ [t']) @ x)))))
14. n : ℤ
15. 0 < n
16. ||primrec(n - 1;[];λn',s. (s @ [g s]))|| = (n - 1) ∈ ℤ
17. 0 < n - 1 
⇒ (primrec(n - 1;[];λn',s. (s @ [g s]))[n - 1 - 1] = (g primrec(n - 1 - 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" 0 THENA Auto) THEN AutoSplit THEN (RWO "length-append" 0 THENA Auto) THEN Reduce 0 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