Step
*
3
of Lemma
add-polynom-val
1. k : ℕ
2. ∀k:ℕk
     ∀[n:ℕ]. ∀[p,q:polyform(n)].
       (((tree_size(p) + tree_size(q)) ≤ k) 
⇒ (∀[l:{l:ℤ List| n ≤ ||l||} ]. (add-polynom(p;q)@l = (p@l + q@l) ∈ ℤ)))
3. n : ℕ
4. left : tree(ℤ)
5. p2 : tree(ℤ)
6. ↑(((ispolyform(left) (n - 1)) ∧b (ispolyform(p2) n)) ∧b 0 <z n)
7. q1 : ℤ
8. True
9. (((1 + tree_size(left)) + tree_size(p2)) + 0) ≤ k
10. l : {l:ℤ List| n ≤ ||l||} 
11. tree_node(left;p2) ∈ polyform(n)
12. tree_leaf(q1) ∈ polyform(n)
⊢ eval a = add-polynom(left;tree_leaf(q1)) in
  eval b = p2 in
    tree_node(a;b)@l
= (tree_node(left;p2)@l + tree_leaf(q1)@l)
∈ ℤ
BY
{ (Fold `polyconst` 0
   THEN (RW assert_pushdownC 6 THENA Auto)
   THEN (Assert left ∈ polyform(n - 1) BY
               Auto)
   THEN RepeatFor 2 ((CallByValueReduce 0 THEN Auto))) }
1
1. k : ℕ
2. ∀k:ℕk
     ∀[n:ℕ]. ∀[p,q:polyform(n)].
       (((tree_size(p) + tree_size(q)) ≤ k) 
⇒ (∀[l:{l:ℤ List| n ≤ ||l||} ]. (add-polynom(p;q)@l = (p@l + q@l) ∈ ℤ)))
3. n : ℕ
4. left : tree(ℤ)
5. p2 : tree(ℤ)
6. ↑(ispolyform(left) (n - 1))
7. ↑(ispolyform(p2) n)
8. 0 < n
9. q1 : ℤ
10. True
11. (((1 + tree_size(left)) + tree_size(p2)) + 0) ≤ k
12. l : {l:ℤ List| n ≤ ||l||} 
13. tree_node(left;p2) ∈ polyform(n)
14. tree_leaf(q1) ∈ polyform(n)
15. left ∈ polyform(n - 1)
⊢ tree_node(add-polynom(left;polyconst(q1));p2)@l = (tree_node(left;p2)@l + polyconst(q1)@l) ∈ ℤ
Latex:
Latex:
1.  k  :  \mBbbN{}
2.  \mforall{}k:\mBbbN{}k
          \mforall{}[n:\mBbbN{}].  \mforall{}[p,q:polyform(n)].
              (((tree\_size(p)  +  tree\_size(q))  \mleq{}  k)
              {}\mRightarrow{}  (\mforall{}[l:\{l:\mBbbZ{}  List|  n  \mleq{}  ||l||\}  ].  (add-polynom(p;q)@l  =  (p@l  +  q@l))))
3.  n  :  \mBbbN{}
4.  left  :  tree(\mBbbZ{})
5.  p2  :  tree(\mBbbZ{})
6.  \muparrow{}(((ispolyform(left)  (n  -  1))  \mwedge{}\msubb{}  (ispolyform(p2)  n))  \mwedge{}\msubb{}  0  <z  n)
7.  q1  :  \mBbbZ{}
8.  True
9.  (((1  +  tree\_size(left))  +  tree\_size(p2))  +  0)  \mleq{}  k
10.  l  :  \{l:\mBbbZ{}  List|  n  \mleq{}  ||l||\} 
11.  tree\_node(left;p2)  \mmember{}  polyform(n)
12.  tree\_leaf(q1)  \mmember{}  polyform(n)
\mvdash{}  eval  a  =  add-polynom(left;tree\_leaf(q1))  in
    eval  b  =  p2  in
        tree\_node(a;b)@l
=  (tree\_node(left;p2)@l  +  tree\_leaf(q1)@l)
By
Latex:
(Fold  `polyconst`  0
  THEN  (RW  assert\_pushdownC  6  THENA  Auto)
  THEN  (Assert  left  \mmember{}  polyform(n  -  1)  BY
                          Auto)
  THEN  RepeatFor  2  ((CallByValueReduce  0  THEN  Auto)))
Home
Index