Step
*
of Lemma
Memory-class-trans
∀[Info,B,A:Type].
  ∀R:B ─→ B ─→ ℙ. ∀f:A ─→ B ─→ B. ∀init:Id ─→ bag(B). ∀X:EClass(A). ∀es:EO+(Info). ∀e1,e2:E. ∀v1,v2:B.
    (Trans(B;x,y.R[x;y])
    
⇒ (∀s1,s2:B.  SqStable(R[s1;s2]))
    
⇒ (∀a:A. ∀e:E.  (a ∈ X(e) 
⇒ (∀s:B. R[s;f a s])))
    
⇒ single-valued-classrel(es;X;A)
    
⇒ single-valued-bag(init loc(e1);B)
    
⇒ v1 ∈ Memory-class(f;init;X)(e1)
    
⇒ v2 ∈ Memory-class(f;init;X)(e2)
    
⇒ (e1 <loc e2)
    
⇒ (∃e:E. (e1 ≤loc e  ∧ (e <loc e2) ∧ (∃a:A. a ∈ X(e))))
    
⇒ R[v1;v2])
BY
{ ((Auto THEN Try ((Unfold `label` 0 THEN Auto)))
   THEN (RWO "Memory-classrel" (-4) THENA Auto)
   THEN (RWO "Memory-classrel" (-3) THENA Auto)
   THEN D (-4)
   THEN D (-3)
   THEN Auto) }
1
1. [Info] : Type
2. [B] : Type
3. [A] : Type
4. R : B ─→ B ─→ ℙ@i'
5. f : A ─→ B ─→ B@i
6. init : Id ─→ bag(B)@i
7. X : EClass(A)@i'
8. es : EO+(Info)@i'
9. e1 : E@i
10. e2 : E@i
11. v1 : B@i
12. v2 : B@i
13. Trans(B;x,y.R[x;y])@i
14. ∀s1,s2:B.  SqStable(R[s1;s2])@i
15. ∀a:A. ∀e:E.  (a ∈ X(e) 
⇒ (∀s:B. R[s;f a s]))@i
16. single-valued-classrel(es;X;A)@i
17. single-valued-bag(init loc(e1);B)@i
18. ↑first(e1)
19. v1 ↓∈ init loc(e1)
20. ¬↑first(e2)
21. iterated_classrel(es;B;A;f;init;X;pred(e2);v2)
22. (e1 <loc e2)@i
23. ∃e:E. (e1 ≤loc e  ∧ (e <loc e2) ∧ (∃a:A. a ∈ X(e)))@i
⊢ R[v1;v2]
2
1. [Info] : Type
2. [B] : Type
3. [A] : Type
4. R : B ─→ B ─→ ℙ@i'
5. f : A ─→ B ─→ B@i
6. init : Id ─→ bag(B)@i
7. X : EClass(A)@i'
8. es : EO+(Info)@i'
9. e1 : E@i
10. e2 : E@i
11. v1 : B@i
12. v2 : B@i
13. Trans(B;x,y.R[x;y])@i
14. ∀s1,s2:B.  SqStable(R[s1;s2])@i
15. ∀a:A. ∀e:E.  (a ∈ X(e) 
⇒ (∀s:B. R[s;f a s]))@i
16. single-valued-classrel(es;X;A)@i
17. single-valued-bag(init loc(e1);B)@i
18. ¬↑first(e1)
19. iterated_classrel(es;B;A;f;init;X;pred(e1);v1)
20. ¬↑first(e2)
21. iterated_classrel(es;B;A;f;init;X;pred(e2);v2)
22. (e1 <loc e2)@i
23. ∃e:E. (e1 ≤loc e  ∧ (e <loc e2) ∧ (∃a:A. a ∈ X(e)))@i
⊢ R[v1;v2]
Latex:
Latex:
\mforall{}[Info,B,A:Type].
    \mforall{}R:B  {}\mrightarrow{}  B  {}\mrightarrow{}  \mBbbP{}.  \mforall{}f:A  {}\mrightarrow{}  B  {}\mrightarrow{}  B.  \mforall{}init:Id  {}\mrightarrow{}  bag(B).  \mforall{}X:EClass(A).  \mforall{}es:EO+(Info).  \mforall{}e1,e2:E.
    \mforall{}v1,v2:B.
        (Trans(B;x,y.R[x;y])
        {}\mRightarrow{}  (\mforall{}s1,s2:B.    SqStable(R[s1;s2]))
        {}\mRightarrow{}  (\mforall{}a:A.  \mforall{}e:E.    (a  \mmember{}  X(e)  {}\mRightarrow{}  (\mforall{}s:B.  R[s;f  a  s])))
        {}\mRightarrow{}  single-valued-classrel(es;X;A)
        {}\mRightarrow{}  single-valued-bag(init  loc(e1);B)
        {}\mRightarrow{}  v1  \mmember{}  Memory-class(f;init;X)(e1)
        {}\mRightarrow{}  v2  \mmember{}  Memory-class(f;init;X)(e2)
        {}\mRightarrow{}  (e1  <loc  e2)
        {}\mRightarrow{}  (\mexists{}e:E.  (e1  \mleq{}loc  e    \mwedge{}  (e  <loc  e2)  \mwedge{}  (\mexists{}a:A.  a  \mmember{}  X(e))))
        {}\mRightarrow{}  R[v1;v2])
By
Latex:
((Auto  THEN  Try  ((Unfold  `label`  0  THEN  Auto)))
  THEN  (RWO  "Memory-classrel"  (-4)  THENA  Auto)
  THEN  (RWO  "Memory-classrel"  (-3)  THENA  Auto)
  THEN  D  (-4)
  THEN  D  (-3)
  THEN  Auto)
Home
Index