Step
*
1
1
of Lemma
fset-to-list
.....assertion..... 
1. [T] : Type
2. eq : EqDecider(T)
3. [R] : T ⟶ T ⟶ ℙ
4. ∀a,b:T.  Dec(R a b)
5. Linorder(T;a,b.R a b)
6. s : fset(T)
7. ∀L:T List. ∃L':T List. (sorted-by(R;L') ∧ no_repeats(T;L') ∧ L ⊆ L' ∧ L' ⊆ L)
8. sort : L:(T List) ⟶ (T List)
9. ∀L:T List. (sorted-by(R;sort L) ∧ no_repeats(T;sort L) ∧ L ⊆ sort L ∧ sort L ⊆ L)
⊢ sort s ∈ T List
BY
{ (Thin (-3) THEN Dquotient2 (-3) THEN Auto) }
1
.....subterm..... T:t
2:n
1. T : Type
2. eq : EqDecider(T)
3. R : T ⟶ T ⟶ ℙ
4. ∀a,b:T.  Dec(R a b)
5. Linorder(T;a,b.R a b)
6. T List ∈ Type
7. ∀x,y:T List.  (set-equal(T;x;y) ∈ Type)
8. ∀x:T List. set-equal(T;x;x)
9. a : Base
10. b : Base
11. c : a = b ∈ pertype(λx,y. ((x ∈ T List) ∧ (y ∈ T List) ∧ set-equal(T;x;y)))
12. a ∈ T List
13. b ∈ T List
14. set-equal(T;a;b)
15. sort : L:(T List) ⟶ (T List)
16. ∀L:T List. (sorted-by(R;sort L) ∧ no_repeats(T;sort L) ∧ L ⊆ sort L ∧ sort L ⊆ L)
⊢ (sort a) = (sort b) ∈ (T List)
Latex:
Latex:
.....assertion..... 
1.  [T]  :  Type
2.  eq  :  EqDecider(T)
3.  [R]  :  T  {}\mrightarrow{}  T  {}\mrightarrow{}  \mBbbP{}
4.  \mforall{}a,b:T.    Dec(R  a  b)
5.  Linorder(T;a,b.R  a  b)
6.  s  :  fset(T)
7.  \mforall{}L:T  List.  \mexists{}L':T  List.  (sorted-by(R;L')  \mwedge{}  no\_repeats(T;L')  \mwedge{}  L  \msubseteq{}  L'  \mwedge{}  L'  \msubseteq{}  L)
8.  sort  :  L:(T  List)  {}\mrightarrow{}  (T  List)
9.  \mforall{}L:T  List.  (sorted-by(R;sort  L)  \mwedge{}  no\_repeats(T;sort  L)  \mwedge{}  L  \msubseteq{}  sort  L  \mwedge{}  sort  L  \msubseteq{}  L)
\mvdash{}  sort  s  \mmember{}  T  List
By
Latex:
(Thin  (-3)  THEN  Dquotient2  (-3)  THEN  Auto)
Home
Index