Step
*
1
1
2
2
1
of Lemma
bag-splits-permutation
1. T : Type
2. ∀b:T List. (bag-splits(b) ∈ (bag(T) × bag(T)) List)
3. L1 : T List
4. L2 : T List
5. permutation(T;L1;L2)
6. a : T
7. u : T
8. v : T List
9. permutation(bag(T) × bag(T);bag-splits([a / v]);bag-splits(v @ [a]))
10. Trans((bag(T) × bag(T)) List;x,y.permutation(bag(T) × bag(T);x;y))
⊢ permutation(bag(T) × bag(T);bag-splits([u; [a / v]]);bag-splits([u / (v @ [a])]))
BY
{ (MoveToConcl (-2) THEN GenConclAtAddr [1;3;1] THEN GenConclAtAddr [1;2;1] THEN ThinVar `v' THEN Auto) }
1
1. T : Type
2. ∀b:T List. (bag-splits(b) ∈ (bag(T) × bag(T)) List)
3. L1 : T List
4. L2 : T List
5. permutation(T;L1;L2)
6. a : T
7. u : T
8. Trans((bag(T) × bag(T)) List;x,y.permutation(bag(T) × bag(T);x;y))
9. v1 : T List
10. v2 : T List
11. permutation(bag(T) × bag(T);bag-splits(v2);bag-splits(v1))
⊢ permutation(bag(T) × bag(T);bag-splits([u / v2]);bag-splits([u / v1]))
Latex:
Latex:
1.  T  :  Type
2.  \mforall{}b:T  List.  (bag-splits(b)  \mmember{}  (bag(T)  \mtimes{}  bag(T))  List)
3.  L1  :  T  List
4.  L2  :  T  List
5.  permutation(T;L1;L2)
6.  a  :  T
7.  u  :  T
8.  v  :  T  List
9.  permutation(bag(T)  \mtimes{}  bag(T);bag-splits([a  /  v]);bag-splits(v  @  [a]))
10.  Trans((bag(T)  \mtimes{}  bag(T))  List;x,y.permutation(bag(T)  \mtimes{}  bag(T);x;y))
\mvdash{}  permutation(bag(T)  \mtimes{}  bag(T);bag-splits([u;  [a  /  v]]);bag-splits([u  /  (v  @  [a])]))
By
Latex:
(MoveToConcl  (-2)
  THEN  GenConclAtAddr  [1;3;1]
  THEN  GenConclAtAddr  [1;2;1]
  THEN  ThinVar  `v'
  THEN  Auto)
Home
Index