{ [Info,A,B:Type]. [X:EClass(A)]. [Y:EClass(B)]. [f:Id  A  B].
  [g:A  (Id List)]. [es:EO+(Info)].
    (X f Y@g  ) }

{ Proof }



Definitions occuring in Statement :  es-propagation-rule: A f B@g eclass: EClass(A[eo; e]) event-ordering+: EO+(Info) Id: Id uall: [x:A]. B[x] prop: member: t  T function: x:A  B[x] list: type List universe: Type
Definitions :  uall: [x:A]. B[x] member: t  T prop: es-propagation-rule: A f B@g exists: x:A. B[x] and: P  Q all: x:A. B[x] implies: P  Q l_all: (xL.P[x]) l_exists: (xL. P[x]) cand: A c B assert: b so_lambda: x y.t[x; y] btrue: tt ifthenelse: if b then t else f fi  true: True so_lambda: x.t[x] es-E-interface: E(X) so_apply: x[s1;s2] uimplies: b supposing a sq_type: SQType(T) guard: {T} so_apply: x[s] subtype: S  T
Lemmas :  es-E-interface_wf not_wf es-E_wf l_disjoint_wf es-causl_wf event-ordering+_inc eclass-val_wf subtype_base_sq bool_wf bool_subtype_base es-loc_wf l_member_wf l_all_wf2 Id_wf event-ordering+_wf eclass_wf assert_elim in-eclass_wf

\mforall{}[Info,A,B:Type].  \mforall{}[X:EClass(A)].  \mforall{}[Y:EClass(B)].  \mforall{}[f:Id  {}\mrightarrow{}  A  {}\mrightarrow{}  B].  \mforall{}[g:A  {}\mrightarrow{}  (Id  List)].
\mforall{}[es:EO+(Info)].
    (X  {}f\mRightarrow{}  Y@g  \mmember{}  \mBbbP{})


Date html generated: 2011_08_16-PM-05_14_27
Last ObjectModification: 2011_06_20-AM-01_15_19

Home Index