Step
*
1
1
2
2
1
of Lemma
consensus-ts4-archived-invariant
1. V : Type@i'
2. ∀v1,v2:V.  Dec(v1 = v2 ∈ V)@i
3. A : Id List@i
4. W : {a:Id| (a ∈ A)}  List List@i
5. x : ConsensusState@i
6. (λa.<-1, ⊗>) ((λx,y. CR[x,y])^*) x@i
7. y : ConsensusState@i
8. (λa.<-1, ⊗>) ((λx,y. CR[x,y])^*) y@i
9. ∀i:ℤ. ∀v:V. ∀a:{a:Id| (a ∈ A)} .
     (by state x, a archived v in inning i
     
⇒ (∀j:ℕi. ∀v':V.  (in state x, inning j could commit v'  
⇒ (v' = v ∈ V))))@i
10. a1 : {a:Id| (a ∈ A)} @i
11. ∀b:{a:Id| (a ∈ A)} 
      ((¬(b = a1 ∈ Id)) 
⇒ ((Inning(y;b) = Inning(x;b) ∈ ℤ) ∧ (Estimate(y;b) = Estimate(x;b) ∈ i:ℤ fp-> V)))@i
12. Inning(y;a1) = Inning(x;a1) ∈ ℤ@i
13. ¬(Inning(x;a1) ∈ fpf-domain(Estimate(x;a1)))@i
14. v1 : V@i
15. state x may consider v1 in inning Inning(x;a1)@i
16. Estimate(y;a1) = Estimate(x;a1) ⊕ Inning(x;a1) : v1 ∈ i:ℤ fp-> V@i
17. i : ℤ@i
18. v : V@i
19. a : {a:Id| (a ∈ A)} @i
20. by state y, a archived v in inning i@i
21. j : ℕi@i
22. v' : V@i
23. in state y, inning j could commit v' @i
24. ¬by state x, a archived v in inning i
25. a = a1 ∈ Id
⊢ v' = v ∈ V
BY
{ (ElimVar `a' THEN ThinVar `a' THEN RenameTo`a' `a1') }
1
1. V : Type@i'
2. ∀v1,v2:V.  Dec(v1 = v2 ∈ V)@i
3. A : Id List@i
4. W : {a:Id| (a ∈ A)}  List List@i
5. x : ConsensusState@i
6. (λa.<-1, ⊗>) ((λx,y. CR[x,y])^*) x@i
7. y : ConsensusState@i
8. (λa.<-1, ⊗>) ((λx,y. CR[x,y])^*) y@i
9. ∀i:ℤ. ∀v:V. ∀a:{a:Id| (a ∈ A)} .
     (by state x, a archived v in inning i
     
⇒ (∀j:ℕi. ∀v':V.  (in state x, inning j could commit v'  
⇒ (v' = v ∈ V))))@i
10. a : {a:Id| (a ∈ A)} @i
11. ∀b:{a:Id| (a ∈ A)} 
      ((¬(b = a ∈ Id)) 
⇒ ((Inning(y;b) = Inning(x;b) ∈ ℤ) ∧ (Estimate(y;b) = Estimate(x;b) ∈ i:ℤ fp-> V)))@i
12. Inning(y;a) = Inning(x;a) ∈ ℤ@i
13. ¬(Inning(x;a) ∈ fpf-domain(Estimate(x;a)))@i
14. v1 : V@i
15. state x may consider v1 in inning Inning(x;a)@i
16. Estimate(y;a) = Estimate(x;a) ⊕ Inning(x;a) : v1 ∈ i:ℤ fp-> V@i
17. i : ℤ@i
18. v : V@i
19. a ∈ Id
20. by state y, a archived v in inning i@i
21. j : ℕi@i
22. v' : V@i
23. in state y, inning j could commit v' @i
24. ¬by state x, a archived v in inning i
⊢ v' = v ∈ V
Latex:
1.  V  :  Type@i'
2.  \mforall{}v1,v2:V.    Dec(v1  =  v2)@i
3.  A  :  Id  List@i
4.  W  :  \{a:Id|  (a  \mmember{}  A)\}    List  List@i
5.  x  :  ConsensusState@i
6.  (\mlambda{}a.<-1,  \motimes{}>)  rel\_star(ConsensusState;  \mlambda{}x,y.  CR[x,y])  x@i
7.  y  :  ConsensusState@i
8.  (\mlambda{}a.<-1,  \motimes{}>)  rel\_star(ConsensusState;  \mlambda{}x,y.  CR[x,y])  y@i
9.  \mforall{}i:\mBbbZ{}.  \mforall{}v:V.  \mforall{}a:\{a:Id|  (a  \mmember{}  A)\}  .
          (by  state  x,  a  archived  v  in  inning  i
          {}\mRightarrow{}  (\mforall{}j:\mBbbN{}i.  \mforall{}v':V.    (in  state  x,  inning  j  could  commit  v'    {}\mRightarrow{}  (v'  =  v))))@i
10.  a1  :  \{a:Id|  (a  \mmember{}  A)\}  @i
11.  \mforall{}b:\{a:Id|  (a  \mmember{}  A)\} 
            ((\mneg{}(b  =  a1))  {}\mRightarrow{}  ((Inning(y;b)  =  Inning(x;b))  \mwedge{}  (Estimate(y;b)  =  Estimate(x;b))))@i
12.  Inning(y;a1)  =  Inning(x;a1)@i
13.  \mneg{}(Inning(x;a1)  \mmember{}  fpf-domain(Estimate(x;a1)))@i
14.  v1  :  V@i
15.  state  x  may  consider  v1  in  inning  Inning(x;a1)@i
16.  Estimate(y;a1)  =  Estimate(x;a1)  \moplus{}  Inning(x;a1)  :  v1@i
17.  i  :  \mBbbZ{}@i
18.  v  :  V@i
19.  a  :  \{a:Id|  (a  \mmember{}  A)\}  @i
20.  by  state  y,  a  archived  v  in  inning  i@i
21.  j  :  \mBbbN{}i@i
22.  v'  :  V@i
23.  in  state  y,  inning  j  could  commit  v'  @i
24.  \mneg{}by  state  x,  a  archived  v  in  inning  i
25.  a  =  a1
\mvdash{}  v'  =  v
By
(ElimVar  `a'  THEN  ThinVar  `a'  THEN  RenameTo`a'  `a1')
Home
Index