{ [M:Type  Type]
    n2m:  pMsg(P.M[P]). l2m:Id  pMsg(P.M[P]). S0:System(P.M[P]).
    env:pEnvType(P.M[P]).
      let r = pRun(S0;env;n2m;l2m) in
          e:runEvents(r)
            (run-event-state(r;e)
            = rev(map(P.(fst(Process-apply(P;run-event-msg(r;e))));
                      run-event-state-when(r;e)))) 
    supposing Continuous+(P.M[P]) }

{ Proof }



Definitions occuring in Statement :  run-event-state-when: run-event-state-when(r;e) run-event-state: run-event-state(r;e) run-event-msg: run-event-msg(r;e) runEvents: runEvents(r) pRun: pRun(S0;env;nat2msg;loc2msg) pEnvType: pEnvType(T.M[T]) System: System(P.M[P]) Process-apply: Process-apply(P;m) pMsg: pMsg(P.M[P]) Process: Process(P.M[P]) Id: Id strong-type-continuous: Continuous+(T.F[T]) reverse: rev(as) map: map(f;as) nat: let: let uimplies: b supposing a uall: [x:A]. B[x] so_apply: x[s] pi1: fst(t) all: x:A. B[x] lambda: x.A[x] function: x:A  B[x] list: type List universe: Type equal: s = t
Definitions :  prop: bfalse: ff btrue: tt all: x:A. B[x] so_lambda: x.t[x] member: t  T ifthenelse: if b then t else f fi  implies: P  Q pi1: fst(t) pi2: snd(t) do-chosen-command: do-chosen-command(nat2msg;loc2msg;t;S;n;m;nm) so_apply: x[s] squash: T cand: A c B true: True isl: isl(x) outl: outl(x) subtype: S  T top: Top false: False and: P  Q le: A  B lelt: i  j < k int_seg: {i..j} exists: x:A. B[x] let: let spreadn: spread3 assert: b not: A System: System(P.M[P]) list_accum: list_accum(x,a.f[x; a];y;l) reduce: reduce(f;k;as) ycomb: Y filter: filter(P;l) map: map(f;as) append: as @ bs reverse: rev(as) deliver-msg: deliver-msg(t;m;x;Cs;L) mapfilter: mapfilter(f;P;L) deliver-msg-to-comp: deliver-msg-to-comp(t;m;x;S;C) iff: P  Q rev_implies: P  Q component: component(P.M[P]) nat: compose: f o g bool: uimplies: b supposing a uall: [x:A]. B[x] unit: Unit guard: {T} sq_type: SQType(T) or: P  Q lg-is-source: lg-is-source(g;i) pInTransit: pInTransit(P.M[P]) fulpRunType: fulpRunType(T.M[T]) it:
Lemmas :  assert_of_bnot eqff_to_assert bnot_wf uiff_transitivity not_wf eqtt_to_assert assert_wf iff_weakening_uiff bool_wf pInTransit_wf lg-is-source_wf_dag System_wf unit_wf pMsg_wf Id_wf pRun_wf true_wf ldag_wf squash_wf assert_of_le_int bnot_of_lt_int assert_functionality_wrt_uiff assert_of_lt_int bool_subtype_base subtype_base_sq bool_cases top_wf strong-type-continuous_wf isl_wf outl_wf member_wf bfalse_wf assert_elim btrue_neq_bfalse le_int_wf lt_int_wf comm-create_wf create-component_wf it_wf not_functionality_wrt_uiff comm-msg_wf deliver-msg_wf component_wf lg-remove_wf_dag pi2_wf pi1_wf_top assert_of_eq_atom com-kind_wf eq_atom_wf nat_wf lg-size_wf_dag le_wf lg-label_wf_dag eq_id_wf reverse_wf filter_wf map_wf append-nil Process_wf mapfilter_wf reverse-reverse mapfilter-reverse assert-eq-id append_wf add-cause_wf lg-append_wf_dag pExt_wf Process-apply_wf mapfilter-singleton mapfilter-append l_member_wf append_assoc_sq subtype_rel_list map-map

\mforall{}[M:Type  {}\mrightarrow{}  Type]
    \mforall{}n2m:\mBbbN{}  {}\mrightarrow{}  pMsg(P.M[P]).  \mforall{}l2m:Id  {}\mrightarrow{}  pMsg(P.M[P]).  \mforall{}S0:System(P.M[P]).  \mforall{}env:pEnvType(P.M[P]).
        let  r  =  pRun(S0;env;n2m;l2m)  in
                \mforall{}e:runEvents(r)
                    (run-event-state(r;e)
                    =  rev(map(\mlambda{}P.(fst(Process-apply(P;run-event-msg(r;e))));run-event-state-when(r;e)))) 
    supposing  Continuous+(P.M[P])


Date html generated: 2011_08_16-PM-07_01_44
Last ObjectModification: 2011_06_18-AM-11_15_45

Home Index