Step * 1 2 1 1 1 of Lemma member-gcd-reduce-constraints


1. : ℕ+
2. : ℤ
3. [%2] n ∈ ℤ
4. {L:ℤ List| ||L|| n ∈ ℤ}  List
5. ∀sat:{L:ℤ List| ||L|| n ∈ ℤ}  List. ∀cc:{L:ℤ List| ||L|| n ∈ ℤ.
     ((↑isl(gcd-reduce-eq-constraints(sat;v)))  (cc ∈ sat)  (cc ∈ outl(gcd-reduce-eq-constraints(sat;v))))
6. 0 ∈ ℤ
⊢ ∀sat:{L:ℤ List| ||L|| n ∈ ℤ}  List. ∀cc:{L:ℤ List| ||L|| n ∈ ℤ.
    ((↑isl(let s' ⟵ inl [[u] sat]
           in accumulate_abort(L,Ls.let h,t 
                                    in if Ax then if h=0 then inl [L Ls] else (inr ⋅ )
                                       otherwise eval |gcd-list(t)| in
                                                 if (1) < (g)
                                                    then if rem g=0
                                                         then eval L' eager-map(λx.(x ÷ g);L) in
                                                              inl [L' Ls]
                                                         else (inr ⋅ )
                                                    else (inl [L Ls]);s';v)))
     (cc ∈ sat)
     (cc ∈ outl(let s' ⟵ inl [[u] sat]
                  in accumulate_abort(L,Ls.let h,t 
                                           in if Ax then if h=0 then inl [L Ls] else (inr ⋅ )
                                              otherwise eval |gcd-list(t)| in
                                                        if (1) < (g)
                                                           then if rem g=0
                                                                then eval L' eager-map(λx.(x ÷ g);L) in
                                                                     inl [L' Ls]
                                                                else (inr ⋅ )
                                                           else (inl [L Ls]);s';v))))
BY
(RepeatFor ((D THENA Auto))
   THEN (CallByValueReduce THENA Auto)
   THEN Fold `gcd-reduce-eq-constraints` 0
   THEN Auto) }


Latex:


Latex:

1.  n  :  \mBbbN{}\msupplus{}
2.  u  :  \mBbbZ{}
3.  [\%2]  :  1  =  n
4.  v  :  \{L:\mBbbZ{}  List|  ||L||  =  n\}    List
5.  \mforall{}sat:\{L:\mBbbZ{}  List|  ||L||  =  n\}    List.  \mforall{}cc:\{L:\mBbbZ{}  List|  ||L||  =  n\}  .
          ((\muparrow{}isl(gcd-reduce-eq-constraints(sat;v)))
          {}\mRightarrow{}  (cc  \mmember{}  sat)
          {}\mRightarrow{}  (cc  \mmember{}  outl(gcd-reduce-eq-constraints(sat;v))))
6.  u  =  0
\mvdash{}  \mforall{}sat:\{L:\mBbbZ{}  List|  ||L||  =  n\}    List.  \mforall{}cc:\{L:\mBbbZ{}  List|  ||L||  =  n\}  .
        ((\muparrow{}isl(let  s'  \mleftarrow{}{}  inl  [[u]  /  sat]
                      in  accumulate\_abort(L,Ls.let  h,t  =  L 
                                                                        in  if  t  =  Ax  then  if  h=0  then  inl  [L  /  Ls]  else  (inr  \mcdot{}  )
                                                                              otherwise  eval  g  =  |gcd-list(t)|  in
                                                                                                  if  (1)  <  (g)
                                                                                                        then  if  h  rem  g=0
                                                                                                                  then  eval  L'  =  eager-map(\mlambda{}x.(x  \mdiv{}  g);L)  in
                                                                                                                            inl  [L'  /  Ls]
                                                                                                                  else  (inr  \mcdot{}  )
                                                                                                        else  (inl  [L  /  Ls]);s';v)))
        {}\mRightarrow{}  (cc  \mmember{}  sat)
        {}\mRightarrow{}  (cc
                  \mmember{}  outl(let  s'  \mleftarrow{}{}  inl  [[u]  /  sat]
                                in  accumulate\_abort(L,Ls.let  h,t  =  L 
                                                                                  in  if  t  =  Ax  then  if  h=0  then  inl  [L  /  Ls]  else  (inr  \mcdot{}  )
                                                                                        otherwise  eval  g  =  |gcd-list(t)|  in
                                                                                                            if  (1)  <  (g)
                                                                                                                  then  if  h  rem  g=0
                                                                                                                            then  eval  L'  =  eager-map(...;L)  in
                                                                                                                                      inl  [L'  /  Ls]
                                                                                                                            else  (inr  \mcdot{}  )
                                                                                                                  else  (inl  [L  /  Ls]);s';v))))


By


Latex:
(RepeatFor  2  ((D  0  THENA  Auto))
  THEN  (CallByValueReduce  0  THENA  Auto)
  THEN  Fold  `gcd-reduce-eq-constraints`  0
  THEN  Auto)




Home Index