Nuprl Lemma : std-components-property

[M:Type  Type]
  n2m:  pMsg(P.M[P]). l2m:Id  pMsg(P.M[P]). Cs:component(P.M[P]) List.
    assuming(env,r.reliable-env(env; r))
     <Cs, lg-nil()|= es.cause:E  (E?)
                           (CCs.e:E
                                    let G = last(data-stream(snd(C);map(e.info(e);loc(e)))) in
                                        pG.let y,c = p 
                                             in (com-kind(c)  ``msg choose new``)
                                                 (e':E
                                                     ((loc(e') = y)
                                                      (e < e')
                                                      (n:. nm:Id. (info(e') = command-to-msg(c;n2m n;l2m nm)))
                                                      ((cause e') = (inl e )))) 
                                    supposing loc(e) = (fst(C))) 
  supposing Continuous+(P.M[P])


Proof not projected




Definitions occuring in Statement :  system-strongly-realizes: system-strongly-realizes command-to-msg: command-to-msg(c;nmsg;lmsg) reliable-env: reliable-env(env; r) component: component(P.M[P]) com-kind: com-kind(c) pMsg: pMsg(P.M[P]) lg-all: xG.P[x] lg-nil: lg-nil() es-info: info(e) es-le-before: loc(e) es-causl: (e < e') es-loc: loc(e) es-E: E data-stream: data-stream(P;L) Id: Id strong-type-continuous: Continuous+(T.F[T]) map: map(f;as) nat: let: let uimplies: b supposing a uall: [x:A]. B[x] so_apply: x[s] pi1: fst(t) pi2: snd(t) all: x:A. B[x] exists: x:A. B[x] implies: P  Q and: P  Q unit: Unit apply: f a lambda: x.A[x] function: x:A  B[x] spread: spread def pair: <a, b> inl: inl x  union: left + right cons: [car / cdr] nil: [] list: type List token: "$token" atom: Atom universe: Type equal: s = t l_all: (xL.P[x]) last: last(L) l_member: (x  l)
Definitions :  suptype: suptype(S; T) subtype: S  T stdEO: stdEO(n2m;l2m;env;S) runEO: runEO(n2m;l2m;env;S) prop: cand: A c B true: True bfalse: ff eq_atom: x =a y ifthenelse: if b then t else f fi  assert: b btrue: tt mk-eo: mk-eo(E;dom;l;R;a;b;c;d;e;f) run-eo: EO(r) system-realizes: system-realizes so_lambda: x.t[x] ext-eq: A  B member: t  T System: System(P.M[P]) and: P  Q implies: P  Q es-le-before: loc(e) let: let es-loc: loc(e) es-E: E exists: x:A. B[x] system-strongly-realizes: system-strongly-realizes all: x:A. B[x] so_apply: x[s] strong-type-continuous: Continuous+(T.F[T]) uimplies: b supposing a uall: [x:A]. B[x] l_all: (xL.P[x]) lt_int: i <z j bnot: b le_int: i z j length: ||as|| select: l[i] null: null(as) not: A ycomb: Y top: Top last: last(L) pi2: snd(t) map: map(f;as) es-causl: (e < e') es-info: info(e) dataflow-ap: df(a) run-event-msg: run-event-msg(r;e) es-before: before(e) squash: T InitialSystem: InitialSystem(P.M[P]) component: component(P.M[P]) false: False uiff: uiff(P;Q) bool: unit: Unit l_contains: A  B Process-stream: Process-stream(P;msgs) iterate-Process: iterate-Process(P;msgs) it:
Lemmas :  strong-type-continuous_wf pMsg_wf Id_wf component_wf InitialSystem_wf sub-system_wf pEnvType_wf reliable-env_wf unit_wf2 run-cause_wf run-event-loc_wf true_wf runEvents_wf reliable-env-property2 pRun_wf2 pInTransit_wf lg-nil_wf_dag nat_wf pRun-invariant2 l_member_wf pi1_wf_top es-loc_wf equal_wf false_wf pExt_wf es-info_wf Process-stream_wf last_append data-stream-cons es-before_wf map_wf data-stream-append es-locl_wf es-E_wf top_wf event-ordering+_wf event-ordering+_inc stdEO_wf es-before_wf3 map_append_sq pRun_wf run-event-state-when_wf Process_wf iterate-Process_wf assert_of_bnot eqff_to_assert not_wf bnot_wf assert_wf uiff_transitivity eqtt_to_assert bool_wf es-first_wf run-event-state_wf squash_wf es-le-before_wf es-pred_wf es-init-elim2

\mforall{}[M:Type  {}\mrightarrow{}  Type]
    \mforall{}n2m:\mBbbN{}  {}\mrightarrow{}  pMsg(P.M[P]).  \mforall{}l2m:Id  {}\mrightarrow{}  pMsg(P.M[P]).  \mforall{}Cs:component(P.M[P])  List.
        assuming(env,r.reliable-env(env;  r))
          <Cs,  lg-nil()>  |=  es.\mexists{}cause:E  {}\mrightarrow{}  (E?)
                                                      (\mforall{}C\mmember{}Cs.\mforall{}e:E
                                                                        let  G  =  last(data-stream(snd(C);map(\mlambda{}e.info(e);\mleq{}loc(e))))  in
                                                                                \mforall{}p\mmember{}G.let  y,c  =  p 
                                                                                          in  (com-kind(c)  \mmember{}  ``msg  choose  new``)
                                                                                                {}\mRightarrow{}  (\mexists{}e':E
                                                                                                          ((loc(e')  =  y)
                                                                                                          \mwedge{}  (e  <  e')
                                                                                                          \mwedge{}  (\mexists{}n:\mBbbN{}
                                                                                                                  \mexists{}nm:Id
                                                                                                                    (info(e')
                                                                                                                    =  command-to-msg(c;n2m  n;l2m  nm)))
                                                                                                          \mwedge{}  ((cause  e')  =  (inl  e  )))) 
                                                                        supposing  loc(e)  =  (fst(C))) 
    supposing  Continuous+(P.M[P])


Date html generated: 2012_01_23-PM-12_45_36
Last ObjectModification: 2011_12_14-PM-11_32_14

Home Index