Nuprl Lemma : new_23_sig-ilf

(∀[z1:ℤ]. ∀[propose,notify:Atom List]. ∀[clients:bag(Id)]. ∀[Cmd:{T:Type| valueall-type(T)} ].
 ∀[f:new_23_sig_headers_type{i:l}(Cmd;notify;propose)]. ∀[es:EO+(Message(f))]. ∀[e:E]. ∀[d:ℤ]. ∀[i:Id]. ∀[m:Message(f)].
   {<d, i, m> ∈ new_23_sig_Notify(Cmd;clients;notify;propose;f) z1(e)
   ⇐⇒ (no (new_23_sig_decision(Cmd;clients;notify;propose;f) 
            z1 new_23_sig_decided'base(Cmd;notify;propose;f)) prior to e)
       ∧ <d, i, m> ∈
          {(new_23_sig_decision(Cmd;clients;notify;propose;f) z1 new_23_sig_decided'base(Cmd;notify;propose;f))}(e)})
∧ (∀[z6,z1:ℤ]. ∀[reps:bag(Id)]. ∀[propose,notify:Atom List]. ∀[flrs,coeff:ℤ]. ∀[Cmd:{T:Type| valueall-type(T)} ].
   ∀[cmdeq:EqDecider(Cmd)]. ∀[f:new_23_sig_headers_type{i:l}(Cmd;notify;propose)]. ∀[es:EO+(Message(f))]. ∀[e:E].
   ∀[d:ℤ]. ∀[i:Id]. ∀[m:Message(f)].
     {<d, i, m> ∈ new_23_sig_Quorum(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f) <z1, z6>(e)
     ⇐⇒ ((header(e) ``new_23_sig vote`` ∈ Name) ∧ has-es-info-type(es;e;f;ℤ × ℤ × Cmd × Id))
         ∧ (↑(new_23_sig_newvote(Cmd) <z1, z6> msgval(e) new_23_sig_QuorumStateFun(Cmd;notify;propose;f;<z1, z6>;es;e)))
         ∧ (||fst(new_23_sig_QuorumStateFun(Cmd;notify;propose;f;<z1, z6>;es;e))|| (coeff flrs) ∈ ℤ)
         ∧ (d 0 ∈ ℤ)
         ∧ (↓(((fst(poss-maj(cmdeq;[snd(fst(msgval(e))) (fst(new_23_sig_QuorumStateFun(Cmd;notify;propose;f;<z1, z6>;e\000Cs;e)))];snd(fst(msgval(e)))))) ((coeff flrs) 1) ∈ ℤ)
             ∧ i ↓∈ reps
             ∧ (m
               make-Msg(``new_23_sig decided``;<fst(fst(fst(msgval(e))))
                                                 snd(poss-maj(cmdeq;[snd(fst(msgval(e))) 
                                                                       (fst(new_23_sig_QuorumStateFun(Cmd;...;...;f;<z1
                                                                                                                    z6
                                                                                                                    >;es\000C;e)))];snd(fst(msgval(e)))))
                                                 >)
               ∈ Message(f)))
             ∨ ((¬((fst(poss-maj(cmdeq;[snd(fst(msgval(e))) 
                                        (fst(new_23_sig_QuorumStateFun(Cmd;notify;propose;f;<z1, z6>;es;e)))];snd(fst(ms\000Cgval(e))))))
                ((coeff flrs) 1)
                ∈ ℤ))
               ∧ (i loc(e) ∈ Id)
               ∧ (m
                 make-Msg(``new_23_sig retry``;<<fst(fst(fst(msgval(e)))), (snd(fst(fst(msgval(e))))) 1>
                                                 snd(poss-maj(cmdeq;[snd(fst(msgval(e))) 
                                                                       (fst(new_23_sig_QuorumStateFun(Cmd;...;...;f;<z1
                                                                                                                    z6
                                                                                                                    >;es\000C;e)))];snd(fst(msgval(e)))))
                                                 >)
                 ∈ Message(f))))})
∧ (∀[z1:ℤ]. ∀[propose,notify:Atom List]. ∀[clients:bag(Id)]. ∀[Cmd:{T:Type| valueall-type(T)} ].
   ∀[f:new_23_sig_headers_type{i:l}(Cmd;notify;propose)]. ∀[es:EO+(Message(f))]. ∀[e:E]. ∀[d:ℤ]. ∀[i:Id].
   ∀[m:Message(f)].
     {<d, i, m> ∈
       (new_23_sig_decision(Cmd;clients;notify;propose;f) z1 new_23_sig_decided'base(Cmd;notify;propose;f))(e)
     ⇐⇒ (header(e) ``new_23_sig decided`` ∈ Name)
         ∧ has-es-info-type(es;e;f;ℤ × Cmd)
         ∧ ((fst(msgval(e))) z1 ∈ ℤ)
         ∧ i ↓∈ clients
         ∧ (d 0 ∈ ℤ)
         ∧ (m make-Msg(notify;msgval(e)) ∈ Message(f))})
∧ (∀[Cmd:{T:Type| valueall-type(T)} ]. ∀[clients:bag(Id)]. ∀[cmdeq:EqDecider(Cmd)]. ∀[coeff,flrs:ℤ].
   ∀[notify,propose:Atom List]. ∀[reps:bag(Id)]. ∀[slots:set-sig{i:l}(ℤ)].
   ∀[f:new_23_sig_headers_type{i:l}(Cmd;notify;propose)]. ∀[es:EO+(Message(f))]. ∀[e:E]. ∀[d:ℤ]. ∀[i:Id].
   ∀[m:Message(f)].
     {<d, i, m> ∈ new_23_sig_main()(e)
     ⇐⇒ loc(e) ↓∈ reps
         ∧ (↓∃e':{e':E| e' ≤loc 
              ∃z1:ℤ
               ∃z2:Cmd
                (((((header(e') propose ∈ Name)
                ∧ has-es-info-type(es;e';f;ℤ × Cmd)
                ∧ (<z1, z2> msgval(e') ∈ (ℤ × Cmd)))
                ∨ ((header(e') ``new_23_sig vote`` ∈ Name)
                  ∧ has-es-info-type(es;e';f;ℤ × ℤ × Cmd × Id)
                  ∧ (z1 (fst(fst(fst(msgval(e'))))) ∈ ℤ)
                  ∧ (z2 (snd(fst(msgval(e')))) ∈ Cmd)))
                ∧ (¬↑(set-sig-member(slots) z1 new_23_sig_ReplicaStateFun(Cmd;notify;propose;slots;f;es;e'))))
                ∧ (((no new_23_sig_Notify(Cmd;clients;notify;propose;f) z1 between e' and e)
                  ∧ ((((i ↓∈ reps ∧ (d 0 ∈ ℤ) ∧ (m make-Msg(``new_23_sig vote``;<<<z1, 0>z2>loc(e)>) ∈ Message(f\000C))) ∧ (e e' ∈ E))
                    ∨ ((no new_23_sig_Quorum(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f) <z1, 0> between e' and e)
                      ∧ <d, i, m> ∈ {new_23_sig_Quorum(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f) <z1, 0>}(e)))
                    ∨ (∃e1:{e1:E| e1 ≤loc 
                        ∃z6:ℤ
                         ∃z7:Cmd
                          (new_23_sig_NewRoundsStateFun(Cmd;notify;propose;f;z1;es.e';e1) < z6
                          ∧ (((header(e1) ``new_23_sig retry`` ∈ Name)
                            ∧ has-es-info-type(es;e1;f;ℤ × ℤ × Cmd)
                            ∧ (<<z1, z6>z7> msgval(e1) ∈ (ℤ × ℤ × Cmd)))
                            ∨ ((header(e1) ``new_23_sig vote`` ∈ Name)
                              ∧ has-es-info-type(es;e1;f;ℤ × ℤ × Cmd × Id)
                              ∧ (<<z1, z6>z7> (fst(msgval(e1))) ∈ (ℤ × ℤ × Cmd))))
                          ∧ (((... ↓∈ ... ∧ ...) ∧ ...) ∨ ...)))))
                  ∨ ...)))})


Proof




Definitions occuring in Statement :  new_23_sig_main: new_23_sig_main() new_23_sig_ReplicaStateFun: new_23_sig_ReplicaStateFun(Cmd;notify;propose;slots;f;es;e) new_23_sig_Notify: new_23_sig_Notify(Cmd;clients;notify;propose;f) new_23_sig_decision: new_23_sig_decision(Cmd;clients;notify;propose;f) new_23_sig_NewRoundsStateFun: new_23_sig_NewRoundsStateFun(Cmd;notify;propose;f;x;es;e) new_23_sig_Quorum: new_23_sig_Quorum(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f) new_23_sig_QuorumStateFun: new_23_sig_QuorumStateFun(Cmd;notify;propose;f;x;es;e) new_23_sig_newvote: new_23_sig_newvote(Cmd) new_23_sig_decided'base: new_23_sig_decided'base(Cmd;notify;propose;f) new_23_sig_headers_type: new_23_sig_headers_type{i:l}(Cmd;notify;propose) set-sig-member: set-sig-member(s) set-sig: set-sig{i:l}(Item) msg-interface: Interface make-Msg: make-Msg(hdr;val) es-info-body: msgval(e) has-es-info-type: has-es-info-type(es;e;f;T) es-header: header(e) Message: Message(f) eclass0: (f X) no-classrel-in-interval: (no between start and e) no-prior-classrel: (no prior to e) classrel: v ∈ X(e) eo-forward: eo.e event-ordering+: EO+(Info) es-le: e ≤loc e'  es-loc: loc(e) es-E: E Id: Id name: Name poss-maj: poss-maj(eq;L;x) length: ||as|| cons: [a b] nil: [] list: List deq: EqDecider(T) valueall-type: valueall-type(T) assert: b less_than: a < b uall: [x:A]. B[x] guard: {T} pi1: fst(t) pi2: snd(t) exists: x:A. B[x] iff: ⇐⇒ Q not: ¬A squash: T or: P ∨ Q and: P ∧ Q set: {x:A| B[x]}  apply: a pair: <a, b> product: x:A × B[x] multiply: m add: m natural_number: $n int: token: "$token" atom: Atom universe: Type equal: t ∈ T bag-member: x ↓∈ bs bag: bag(T)
Definitions unfolded in proof :  and: P ∧ Q uall: [x:A]. B[x] member: t ∈ T new_23_sig_headers_type: new_23_sig_headers_type{i:l}(Cmd;notify;propose) name: Name subtype_rel: A ⊆B prop: listp: List+ implies:  Q sq_stable: SqStable(P) l_all: (∀x∈L.P[x]) all: x:A. B[x] so_lambda: λ2x.t[x] vatype: ValueAllType so_apply: x[s] iff: ⇐⇒ Q new_23_sig_headers: new_23_sig_headers(notify;propose) rev_implies:  Q guard: {T} or: P ∨ Q uimplies: supposing a new_23_sig_headers_fun: new_23_sig_headers_fun(Cmd;notify;propose) bool: 𝔹 unit: Unit it: btrue: tt uiff: uiff(P;Q) ifthenelse: if then else fi  cand: c∧ B new_23_sig_headers_no_rep: new_23_sig_headers_no_rep(notify;propose) squash: T no_repeats: no_repeats(T;l) nat: le: A ≤ B less_than': less_than'(a;b) false: False not: ¬A length: ||as|| list_ind: list_ind cons: [a b] nil: [] less_than: a < b true: True ge: i ≥  satisfiable_int_formula: satisfiable_int_formula(fmla) exists: x:A. B[x] top: Top select: L[n] subtract: m bfalse: ff sq_type: SQType(T) bnot: ¬bb assert: b name_eq: name_eq(x;y) name-deq: NameDeq list-deq: list-deq(eq) band: p ∧b q atom-deq: AtomDeq eq_atom: =a y null: null(as) no-prior-classrel: (no prior to e) alle-lt: e<e'.P[e] classrel: v ∈ X(e) bag-member: x ↓∈ bs make-msg-interface: make-msg-interface(i;l;m) new_23_sig_Notify: new_23_sig_Notify(Cmd;clients;notify;propose;f) has-es-info-type: has-es-info-type(es;e;f;T) new_23_sig_Quorum: new_23_sig_Quorum(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f) equal-info-body: body(e) new_23_sig_vote'base: new_23_sig_vote'base(Cmd;notify;propose;f) encodes-msg-type: hdr encodes T new_23_sig_when_quorum: new_23_sig_when_quorum(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f) new_23_sig_roundout: new_23_sig_roundout(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f) so_lambda: λ2y.t[x; y] so_apply: x[s1;s2] new_23_sig_decided'broadcast: new_23_sig_decided'broadcast(Cmd;notify;propose;f) pi1: fst(t) pi2: snd(t) msg-interface: Interface new_23_sig_retry'send: new_23_sig_retry'send(Cmd;notify;propose;f) mk-msg-interface: mk-msg-interface(l;m) new_23_sig_decided'base: new_23_sig_decided'base(Cmd;notify;propose;f) new_23_sig_decision: new_23_sig_decision(Cmd;clients;notify;propose;f) new_23_sig_notify'broadcast: new_23_sig_notify'broadcast(Cmd;notify;propose;f) rev_uimplies: rev_uimplies(P;Q) new_23_sig_main: new_23_sig_main() new_23_sig_Replica: new_23_sig_Replica(Cmd;clients;cmdeq;coeff;flrs;notify;propose;reps;slots;f) new_23_sig_NewVoters: new_23_sig_NewVoters(Cmd;notify;propose;slots;f) new_23_sig_Proposal: new_23_sig_Proposal(Cmd;notify;propose;f) sq_or: a ↓∨ b new_23_sig_propose'base: new_23_sig_propose'base(Cmd;notify;propose;f) new_23_sig_Voter: new_23_sig_Voter(Cmd;clients;cmdeq;coeff;flrs;notify;propose;reps;f) new_23_sig_Rounds: new_23_sig_Rounds(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f) new_23_sig_Round: new_23_sig_Round(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f) new_23_sig_NewRounds: new_23_sig_NewRounds(Cmd;notify;propose;f) new_23_sig_RoundInfo: new_23_sig_RoundInfo(Cmd;notify;propose;f) new_23_sig_retry'base: new_23_sig_retry'base(Cmd;notify;propose;f) new_23_sig_vote2prop: new_23_sig_vote2prop(Cmd) new_23_sig_when_new_proposal: new_23_sig_when_new_proposal(Cmd;slots) new_23_sig_vote'broadcast: new_23_sig_vote'broadcast(Cmd;notify;propose;f) new_23_sig_vote2retry: new_23_sig_vote2retry(Cmd) new_23_sig_when_new_round: new_23_sig_when_new_round(Cmd) hint: hint(t) decidable: Dec(P)

Latex:
(\mforall{}[z1:\mBbbZ{}].  \mforall{}[propose,notify:Atom  List].  \mforall{}[clients:bag(Id)].  \mforall{}[Cmd:\{T:Type|  valueall-type(T)\}  ].
  \mforall{}[f:new\_23\_sig\_headers\_type\{i:l\}(Cmd;notify;propose)].  \mforall{}[es:EO+(Message(f))].  \mforall{}[e:E].  \mforall{}[d:\mBbbZ{}].
  \mforall{}[i:Id].  \mforall{}[m:Message(f)].
      \{<d,  i,  m>  \mmember{}  new\_23\_sig\_Notify(Cmd;clients;notify;propose;f)  z1(e)
      \mLeftarrow{}{}\mRightarrow{}  (no  (new\_23\_sig\_decision(Cmd;clients;notify;propose;f) 
                        z1  o  new\_23\_sig\_decided'base(Cmd;notify;propose;f))  prior  to  e)
              \mwedge{}  <d,  i,  m>  \mmember{}
                    \{(new\_23\_sig\_decision(Cmd;clients;notify;propose;f) 
                        z1  o  new\_23\_sig\_decided'base(Cmd;notify;propose;f))\}(e)\})
\mwedge{}  (\mforall{}[z6,z1:\mBbbZ{}].  \mforall{}[reps:bag(Id)].  \mforall{}[propose,notify:Atom  List].  \mforall{}[flrs,coeff:\mBbbZ{}].
      \mforall{}[Cmd:\{T:Type|  valueall-type(T)\}  ].  \mforall{}[cmdeq:EqDecider(Cmd)].
      \mforall{}[f:new\_23\_sig\_headers\_type\{i:l\}(Cmd;notify;propose)].  \mforall{}[es:EO+(Message(f))].  \mforall{}[e:E].  \mforall{}[d:\mBbbZ{}].
      \mforall{}[i:Id].  \mforall{}[m:Message(f)].
          \{<d,  i,  m>  \mmember{}  new\_23\_sig\_Quorum(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f)  <z1,  z6>(e)
          \mLeftarrow{}{}\mRightarrow{}  ((header(e)  =  ``new\_23\_sig  vote``)  \mwedge{}  has-es-info-type(es;e;f;\mBbbZ{}  \mtimes{}  \mBbbZ{}  \mtimes{}  Cmd  \mtimes{}  Id))
                  \mwedge{}  (\muparrow{}(new\_23\_sig\_newvote(Cmd)  <z1,  z6>  msgval(e)  new\_23\_sig\_QuorumStateFun(Cmd;notify;propos\000Ce;f;<z1,  z6>es;e)))
                  \mwedge{}  (||fst(new\_23\_sig\_QuorumStateFun(Cmd;notify;propose;f;<z1,  z6>es;e))||  =  (coeff  *  flrs))
                  \mwedge{}  (d  =  0)
                  \mwedge{}  (\mdownarrow{}(((fst(poss-maj(cmdeq;[snd(fst(msgval(e)))  / 
                                                                        (fst(new\_23\_sig\_QuorumStateFun(Cmd;notify;propose;f;<z1,  z6>es;\000Ce)))];snd(fst(msgval(e))))))
                            =  ((coeff  *  flrs)  +  1))
                          \mwedge{}  i  \mdownarrow{}\mmember{}  reps
                          \mwedge{}  (m
                              =  make-Msg(``new\_23\_sig  decided``;<fst(fst(fst(msgval(e))))
                                                                                                  ,  snd(poss-maj(cmdeq;[snd(fst(msgval(e)))  / 
                                                                                                                                              (fst(...))];snd(fst(...))))
                                                                                                  >)))
                          \mvee{}  ((\mneg{}((fst(poss-maj(cmdeq;[snd(fst(msgval(e)))  / 
                                                                                (fst(new\_23\_sig\_QuorumStateFun(Cmd;notify;propose;f;<z1,  z6>\000C;es;e)))];snd(fst(msgval(e))))))
                                =  ((coeff  *  flrs)  +  1)))
                              \mwedge{}  (i  =  loc(e))
                              \mwedge{}  (m
                                  =  make-Msg(``new\_23\_sig  retry``;<<fst(fst(fst(msgval(e))))
                                                                                                    ,  (snd(fst(fst(msgval(e)))))  +  1
                                                                                                    >
                                                                                                  ,  snd(poss-maj(cmdeq;[snd(fst(msgval(e)))  / 
                                                                                                                                              (fst(...))];snd(fst(...))))
                                                                                                  >))))\})
\mwedge{}  (\mforall{}[z1:\mBbbZ{}].  \mforall{}[propose,notify:Atom  List].  \mforall{}[clients:bag(Id)].  \mforall{}[Cmd:\{T:Type|  valueall-type(T)\}  ].
      \mforall{}[f:new\_23\_sig\_headers\_type\{i:l\}(Cmd;notify;propose)].  \mforall{}[es:EO+(Message(f))].  \mforall{}[e:E].  \mforall{}[d:\mBbbZ{}].
      \mforall{}[i:Id].  \mforall{}[m:Message(f)].
          \{<d,  i,  m>  \mmember{}
              (new\_23\_sig\_decision(Cmd;clients;notify;propose;f) 
                z1  o  new\_23\_sig\_decided'base(Cmd;notify;propose;f))(e)
          \mLeftarrow{}{}\mRightarrow{}  (header(e)  =  ``new\_23\_sig  decided``)
                  \mwedge{}  has-es-info-type(es;e;f;\mBbbZ{}  \mtimes{}  Cmd)
                  \mwedge{}  ((fst(msgval(e)))  =  z1)
                  \mwedge{}  i  \mdownarrow{}\mmember{}  clients
                  \mwedge{}  (d  =  0)
                  \mwedge{}  (m  =  make-Msg(notify;msgval(e)))\})
\mwedge{}  (\mforall{}[Cmd:\{T:Type|  valueall-type(T)\}  ].  \mforall{}[clients:bag(Id)].  \mforall{}[cmdeq:EqDecider(Cmd)].  \mforall{}[coeff,flrs:\mBbbZ{}].
      \mforall{}[notify,propose:Atom  List].  \mforall{}[reps:bag(Id)].  \mforall{}[slots:set-sig\{i:l\}(\mBbbZ{})].
      \mforall{}[f:new\_23\_sig\_headers\_type\{i:l\}(Cmd;notify;propose)].  \mforall{}[es:EO+(Message(f))].  \mforall{}[e:E].  \mforall{}[d:\mBbbZ{}].
      \mforall{}[i:Id].  \mforall{}[m:Message(f)].
          \{<d,  i,  m>  \mmember{}  new\_23\_sig\_main()(e)
          \mLeftarrow{}{}\mRightarrow{}  loc(e)  \mdownarrow{}\mmember{}  reps
                  \mwedge{}  (\mdownarrow{}\mexists{}e':\{e':E|  e'  \mleq{}loc  e  \} 
                            \mexists{}z1:\mBbbZ{}
                              \mexists{}z2:Cmd
                                (((((header(e')  =  propose)
                                \mwedge{}  has-es-info-type(es;e';f;\mBbbZ{}  \mtimes{}  Cmd)
                                \mwedge{}  (<z1,  z2>  =  msgval(e')))
                                \mvee{}  ((header(e')  =  ``new\_23\_sig  vote``)
                                    \mwedge{}  has-es-info-type(es;e';f;\mBbbZ{}  \mtimes{}  \mBbbZ{}  \mtimes{}  Cmd  \mtimes{}  Id)
                                    \mwedge{}  (z1  =  (fst(fst(fst(msgval(e'))))))
                                    \mwedge{}  (z2  =  (snd(fst(msgval(e')))))))
                                \mwedge{}  (\mneg{}\muparrow{}(set-sig-member(slots)  z1 
                                            new\_23\_sig\_ReplicaStateFun(Cmd;notify;propose;slots;f;es;e'))))
                                \mwedge{}  (((no  new\_23\_sig\_Notify(Cmd;clients;notify;propose;f)  z1  between  e'  and  e)
                                    \mwedge{}  ((((i  \mdownarrow{}\mmember{}  reps
                                        \mwedge{}  (d  =  0)
                                        \mwedge{}  (m  =  make-Msg(``new\_23\_sig  vote``;<<<z1,  0>,  z2>,  loc(e)>)))
                                        \mwedge{}  (e  =  e'))
                                        \mvee{}  ((no  new\_23\_sig\_Quorum(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f)  <z1,  0>  bet\000Cween  e'  and  e)
                                            \mwedge{}  <d,  i,  m>  \mmember{}  \{new\_23\_sig\_Quorum(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f) 
                                                                          <z1,  0>\}(e)))
                                        \mvee{}  (\mexists{}e1:\{e1:E|  e1  \mleq{}loc  e  \} 
                                                \mexists{}z6:\mBbbZ{}
                                                  \mexists{}z7:Cmd
                                                    (new\_23\_sig\_NewRoundsStateFun(Cmd;notify;propose;f;z1;es.e';e1)  <  z6
                                                    \mwedge{}  (((header(e1)  =  ``new\_23\_sig  retry``)
                                                        \mwedge{}  has-es-info-type(es;e1;f;\mBbbZ{}  \mtimes{}  \mBbbZ{}  \mtimes{}  Cmd)
                                                        \mwedge{}  (<<z1,  z6>,  z7>  =  msgval(e1)))
                                                        \mvee{}  ((header(e1)  =  ``new\_23\_sig  vote``)
                                                            \mwedge{}  has-es-info-type(es;e1;f;\mBbbZ{}  \mtimes{}  \mBbbZ{}  \mtimes{}  Cmd  \mtimes{}  Id)
                                                            \mwedge{}  (<<z1,  z6>,  z7>  =  (fst(msgval(e1))))))
                                                    \mwedge{}  (((i  \mdownarrow{}\mmember{}  reps
                                                        \mwedge{}  (d  =  0)
                                                        \mwedge{}  (m  =  make-Msg(``new\_23\_sig  vote``;<<<z1,  z6>,  z7>,  loc(e)>)))
                                                        \mwedge{}  (e  =  e1))
                                                        \mvee{}  ((no  new\_23\_sig\_Quorum(Cmd;cmdeq;coeff;flrs;notify;propose;reps;f) 
                                                                      <z1,  z6>  between  e1  and  e)
                                                            \mwedge{}  <d,  i,  m>  \mmember{}
                                                                  \{new\_23\_sig\_Quorum(Cmd;cmdeq;coeff;flrs;...;...;...;...)  ...\}(
                                                                  ...)))))))
                                    \mvee{}  ...)))\})



Date html generated: 2016_05_17-PM-02_12_14
Last ObjectModification: 2016_04_03-PM-09_38_35

Theory : 2!3!consensus!with!signatures


Home Index