Step * 1 of Lemma mapfilter-no-rep-fun


1. Type
2. Type
3. Type
4. eq EqDecider(U)
5. List
6. U
7. T ⟶ U
8. {x:{x:T| (x ∈ L)} | ↑(eq f[x] u)}  ⟶ V
9. no_repeats(U;map(f;L))
10. ||mapfilter(g;λx.(eq f[x] u);L)|| ∈ ℤ
11. 2 ≤ ||mapfilter(g;λx.(eq f[x] u);L)||
⊢ False
BY
(RepUR ``mapfilter`` (-1)
   THEN (RWO "length-map" (-1) THENA Auto)
   THEN (Assert ⌜∃L':T List. (L' ⊆ L ∧ (filter(λx.(eq f[x] u);L) L' ∈ (T List)))⌝⋅
         THENA (InstConcl [⌜filter(λx.(eq f[x] u);L)⌝]⋅ THEN Auto THEN BLemma `filter_is_sublist` THEN Auto)
         )
   THEN ExRepD
   THEN (RWO "-1" (-4) THENA Auto)
   THEN (Assert ⌜∀x:T. ((x ∈ L')  (f[x] u ∈ U))⌝⋅
         THENA (Auto THEN (RWO "-4<(-1) THENA Auto) THEN GenListD (-1) THEN Auto THEN AllPushDown THEN Auto)
         )
   THEN (Assert ⌜f[L'[0]] f[L'[1]] ∈ U⌝⋅
         THENA ((InstHyp [⌜L'[0]⌝(-1)⋅ THENA (Auto THEN GenListD 0))
                THEN (InstHyp [⌜L'[1]⌝(-2)⋅ THENA (Auto THEN GenListD 0))
                THEN Auto)
         )
   THEN (FLemma `l_before_sublist` [-5] THENA Auto)
   THEN (InstHyp [⌜L'[0]⌝;⌜L'[1]⌝(-1)⋅ THENA (Auto THEN BLemma `l_before_select` THEN Auto))) }

1
1. Type
2. Type
3. Type
4. eq EqDecider(U)
5. List
6. U
7. T ⟶ U
8. {x:{x:T| (x ∈ L)} | ↑(eq f[x] u)}  ⟶ V
9. no_repeats(U;map(f;L))
10. ||mapfilter(g;λx.(eq f[x] u);L)|| ∈ ℤ
11. L' List
12. L' ⊆ L
13. filter(λx.(eq f[x] u);L) L' ∈ (T List)
14. 2 ≤ ||L'||
15. ∀x:T. ((x ∈ L')  (f[x] u ∈ U))
16. f[L'[0]] f[L'[1]] ∈ U
17. ∀x,y:T.  (x before y ∈ L'  before y ∈ L)
18. L'[0] before L'[1] ∈ L
⊢ False


Latex:


Latex:

1.  T  :  Type
2.  U  :  Type
3.  V  :  Type
4.  eq  :  EqDecider(U)
5.  L  :  T  List
6.  u  :  U
7.  f  :  T  {}\mrightarrow{}  U
8.  g  :  \{x:\{x:T|  (x  \mmember{}  L)\}  |  \muparrow{}(eq  f[x]  u)\}    {}\mrightarrow{}  V
9.  no\_repeats(U;map(f;L))
10.  ||mapfilter(g;\mlambda{}x.(eq  f[x]  u);L)||  \mmember{}  \mBbbZ{}
11.  2  \mleq{}  ||mapfilter(g;\mlambda{}x.(eq  f[x]  u);L)||
\mvdash{}  False


By


Latex:
(RepUR  ``mapfilter``  (-1)
  THEN  (RWO  "length-map"  (-1)  THENA  Auto)
  THEN  (Assert  \mkleeneopen{}\mexists{}L':T  List.  (L'  \msubseteq{}  L  \mwedge{}  (filter(\mlambda{}x.(eq  f[x]  u);L)  =  L'))\mkleeneclose{}\mcdot{}
              THENA  (InstConcl  [\mkleeneopen{}filter(\mlambda{}x.(eq  f[x]  u);L)\mkleeneclose{}]\mcdot{}
                            THEN  Auto
                            THEN  BLemma  `filter\_is\_sublist`
                            THEN  Auto)
              )
  THEN  ExRepD
  THEN  (RWO  "-1"  (-4)  THENA  Auto)
  THEN  (Assert  \mkleeneopen{}\mforall{}x:T.  ((x  \mmember{}  L')  {}\mRightarrow{}  (f[x]  =  u))\mkleeneclose{}\mcdot{}
              THENA  (Auto
                            THEN  (RWO  "-4<"  (-1)  THENA  Auto)
                            THEN  GenListD  (-1)
                            THEN  Auto
                            THEN  AllPushDown
                            THEN  Auto)
              )
  THEN  (Assert  \mkleeneopen{}f[L'[0]]  =  f[L'[1]]\mkleeneclose{}\mcdot{}
              THENA  ((InstHyp  [\mkleeneopen{}L'[0]\mkleeneclose{}]  (-1)\mcdot{}  THENA  (Auto  THEN  GenListD  0))
                            THEN  (InstHyp  [\mkleeneopen{}L'[1]\mkleeneclose{}]  (-2)\mcdot{}  THENA  (Auto  THEN  GenListD  0))
                            THEN  Auto)
              )
  THEN  (FLemma  `l\_before\_sublist`  [-5]  THENA  Auto)
  THEN  (InstHyp  [\mkleeneopen{}L'[0]\mkleeneclose{};\mkleeneopen{}L'[1]\mkleeneclose{}]  (-1)\mcdot{}  THENA  (Auto  THEN  BLemma  `l\_before\_select`  THEN  Auto)))




Home Index