Step * 1 2 1 1 of Lemma recode-tuple_wf

.....subterm..... T:t
1:n
1. T:Type ⟶ (L:Type List × h:T ⟶ tuple-type(L) × {j:tuple-type(L) ⟶ T| ∀s:T. ((j (h s)) s ∈ T)} )
2. Type
3. Type List
4. tuple-type(v) ⟶ Unit
5. v3 Unit ⟶ tuple-type(v)
6. ∀s:tuple-type(v). ((v3 (h s)) s ∈ tuple-type(v))
7. Type List
8. h1 u ⟶ tuple-type(L)
9. v6 tuple-type(L) ⟶ u
10. ∀s:u. ((v6 (h1 s)) s ∈ u)
11. null(v) ff
12. ¬0 < 0
⊢ λx.let a,b 
     in append-tuple(||L||;0;h1 a;h b) ∈ (u × tuple-type(v)) ⟶ tuple-type(L)
BY
((MemCD THENA Auto) THEN -1 THEN Reduce 0) }

1
1. T:Type ⟶ (L:Type List × h:T ⟶ tuple-type(L) × {j:tuple-type(L) ⟶ T| ∀s:T. ((j (h s)) s ∈ T)} )
2. Type
3. Type List
4. tuple-type(v) ⟶ Unit
5. v3 Unit ⟶ tuple-type(v)
6. ∀s:tuple-type(v). ((v3 (h s)) s ∈ tuple-type(v))
7. Type List
8. h1 u ⟶ tuple-type(L)
9. v6 tuple-type(L) ⟶ u
10. ∀s:u. ((v6 (h1 s)) s ∈ u)
11. null(v) ff
12. ¬0 < 0
13. x1 u
14. x2 tuple-type(v)
⊢ append-tuple(||L||;0;h1 x1;h x2) ∈ tuple-type(L)


Latex:


Latex:
.....subterm.....  T:t
1:n
1.  f  :  T:Type  {}\mrightarrow{}  (L:Type  List
                                  \mtimes{}  h:T  {}\mrightarrow{}  tuple-type(L)
                                  \mtimes{}  \{j:tuple-type(L)  {}\mrightarrow{}  T|  \mforall{}s:T.  ((j  (h  s))  =  s)\}  )
2.  u  :  Type
3.  v  :  Type  List
4.  h  :  tuple-type(v)  {}\mrightarrow{}  Unit
5.  v3  :  Unit  {}\mrightarrow{}  tuple-type(v)
6.  \mforall{}s:tuple-type(v).  ((v3  (h  s))  =  s)
7.  L  :  Type  List
8.  h1  :  u  {}\mrightarrow{}  tuple-type(L)
9.  v6  :  tuple-type(L)  {}\mrightarrow{}  u
10.  \mforall{}s:u.  ((v6  (h1  s))  =  s)
11.  null(v)  =  ff
12.  \mneg{}0  <  0
\mvdash{}  \mlambda{}x.let  a,b  =  x 
          in  append-tuple(||L||;0;h1  a;h  b)  \mmember{}  (u  \mtimes{}  tuple-type(v))  {}\mrightarrow{}  tuple-type(L)


By


Latex:
((MemCD  THENA  Auto)  THEN  D  -1  THEN  Reduce  0)




Home Index