Origin Definitions Sections GenAutomata Doc

mb_hybrid
Nuprl Section: mb_hybrid
Selected Objects
THMno_dup_send_inducedE:EventStruct, A:Type, evt:(A|E|), tg:(ALabel), tr_l:A List. No-dup-send(E)(map(evt;tr_l)) No-dup-send( < A,evt,tg > (E))(tr_l)
defremove_msgs(L -msg(a;b) L1) == filter(a.reduce(b,y. msg(a;b)y;true;L1);L)
THMremove_msgs_nilmsg:(AA), L1,L2:A List. (x:A. (x L1) (x L2)) Refl(A)(msg(_1,_2)) (L1 -msg(a,b) L2) = nil
THMremove_msgs_disjointmsg:(AA), L1,L2:A List. (a,b:A. (a L1) (b L2) msg(a,b)) (L1 -msg(a,b) L2) = L1
defswitch_inv2001_03_15_DASH_PM_DASH_12_53_21switch_inv(E; tr) == i,j,k:||tr||. i < j is-send(E)(tr[i]) is-send(E)(tr[j]) tag(E)(tr[i]) = tag(E)(tr[j]) (tr[j] =msg=(E) tr[k]) is-send(E)(tr[k]) (k':||tr||. k' < k & loc(E)(tr[k']) = loc(E)(tr[k]) & (tr[i] =msg=(E) tr[k']) & is-send(E)(tr[k']))
defdeliveries_attr delivered at p == filter(e.is-send(E)(e)loc(E)(e) = p;tr)
defdelivered_atx delivered at time k == (x =msg=(E) tr[k]) & is-send(E)(tr[k])
defP_tag_by_msgTag-by-msg(E)(tr) == i,j:||tr||. (tr[i] =msg=(E) tr[j]) tag(E)(tr[i]) = tag(E)(tr[j])
defP_no_dupNo-dup-deliver(E)(tr) == i,j:||tr||. is-send(E)(tr[i]) is-send(E)(tr[j]) (tr[j] =msg=(E) tr[i]) loc(E)(tr[i]) = loc(E)(tr[j]) i = j
defP_causalCausal(E)(tr) == i:||tr||. j:||tr||. ji & is-send(E)(tr[j]) & (tr[j] =msg=(E) tr[i])
THMP_causal_iffE:EventStruct, tr:|E| List. Causal(E)(tr) (tr':|E| List. tr' tr (xtr'.(ytr'.is-send(E)(y) & (y =msg=(E) x))))
THMP_no_dup_iffE:EventStruct, tr:|E| List. No-dup-deliver(E)(tr) (x,y:|E|. is-send(E)(x) is-send(E)(y) (y =msg=(E) x) loc(E)(x) = loc(E)(y) sublist(|E|;[x; y];tr))
defPTruePTrue(tr) == True
THMP_tag_by_msg_lemmaE:TaggedEventStruct, tr:|E| List. (m:Label. Causal(E)( < tr > _m)) No-dup-send(E)(tr) Tag-by-msg(E)(tr)
THMP_causal_non_nilE:EventStruct, L:|E| List. L = nil Causal(E)(L) (i:||L||. is-send(E)(L[i]))
defmessage_closureC(Q)(i) == k:||L||. Q(k) & (L[k] =msg=(E) L[i])
defsingle_tag_decomposablesingle-tag-decomposable(E)(L) == L = nil |E| List (L_1,L_2:Trace(E). L = (L_1 @ L_2) |E| List & L_2 = nil |E| List & (xL_1.(yL_2.(x =msg=(E) y))) & (m:Label. (xL_2.tag(E)(x) = m)))
deffusion_conditionI fuses P == tr:Trace(E). (m:Label. P( < tr > _m)) I(tr) P(tr)
THMcausal_fusionE:TaggedEventStruct. PTrue fuses Causal(E)
defR_ad_normalR_ad_normal(tr)(a,b) == (is-send(E)(a) is-send(E)(b) (a =msg=(E) b)) & (is-send(E)(a) is-send(E)(b) (x,y:||tr||. x < y & is-send(E)(tr[x]) & is-send(E)(tr[y]) & (tr[x] =msg=(E) b) & (tr[y] =msg=(E) a)) loc(E)(a) = loc(E)(b))
THMdecidable__R_ad_normalE:TaggedEventStruct, tr:|E| List, x,y:|E|. Dec(R_ad_normal(tr)(x,y))
defR_composablecomposableR(E)(L_1,L_2,L) == (xL_1.(yL_2.(x =msg=(E) y))) & L = (L_1 @ L_2) |E| List
THMP_no_dup_composableE:EventStruct. (ternary) composableR(E) preserves No-dup-deliver(E)
defR_strong_safetyInfix R_strong_safety(E)(tr_1,tr_2) == sublist(|E|;tr_2;tr_1)
THMP_no_dup_strong_safetyE:EventStruct. R_strong_safety(E) preserves No-dup-deliver(E)
defR_safetyInfix safetyR(E)(tr_1,tr_2) == tr_2 tr_1
THMno_duplicate_send_safetyE:EventStruct. safetyR(E) preserves No-dup-send(E)
THMP_causal_safetyE:EventStruct. safetyR(E) preserves Causal(E)
defR_memorylessInfix memorylessR(E)(L_1,L_2) == a:|E|. L_2 = filter(b.(b =msg=(E) a);L_1) |E| List
defR_send_enabledInfix send-enabledR(E)(L_1,L_2) == x:|E|. is-send(E)(x) & L_2 = (L_1 @ [x])
THMP_no_dup_send_enabledE:EventStruct. send-enabledR(E) preserves No-dup-deliver(E)
defR_delMacro x R_del(E) y == (x =msg=(E) y) & is-deliver(E)(x) & is-send(E)(y) is-send(E)(x) & is-deliver(E)(y)
deftr_refinesP refines Q == tr:|E| List. P(tr) Q(tr)
THMtr_refines_andE:Structure, P,Q_1,Q_2:((|E| List)Prop). (P refines Q_1) (P refines Q_2) (P refines (Q_1 Q_2))
deftrace_propertyTraceProperty(E) == (|E| List)Prop
THMfusion_weakeningE:TaggedEventStruct, I,J,P:TraceProperty(E). (J refines I) (I fuses P) (J fuses P)
THMfusion_andE:TaggedEventStruct, I,P,Q:TraceProperty(E). (I fuses P) (I fuses Q) (I fuses (P Q))
THMstrong_safety_implies_safetyE:EventStruct, P:TraceProperty(E). R_strong_safety(E) preserves P safetyR(E) preserves P
THMstrong_safety_implies_memorylessE:EventStruct, P:TraceProperty(E). R_strong_safety(E) preserves P memorylessR(E) preserves P
THMfusion_simplificationE:TaggedEventStruct, I,J,P:TraceProperty(E). ((I J) fuses P) (I fuses J) (P refines J) (I fuses P)
THMmemoryless_remove_msgsE:EventStruct, P:TraceProperty(E), L,L1:|E| List. memorylessR(E) preserves P P(L) P((L -x =msg=(E) y L1))
defswap_adjacentInfix swap adjacent[P(x;y)](L1,L2) == i:(||L1||-1). P(L1[i];L1[(i+1)]) & L2 = swap(L1;i;i+1) A List
THMnormal_form_fusionE:TaggedEventStruct, P,I,J,K:TraceProperty(E), R:(Trace(E)Trace(E)Prop). tag_splitable(E;R) (tr_1,tr_2:Trace(E). (tr_1 R tr_2) (tr_2 R tr_1)) R preserves P R preserves K (tr:Trace(E). (I K)(tr) (tr':Trace(E). I(tr') & J(tr') & (tr R tr'))) (((I J) K) fuses P) ((I K) fuses P)
THMP_no_dup_deliver_safetyE:EventStruct. safetyR(E) preserves No-dup-deliver(E)
THMP_tag_by_msg_safetyE:TaggedEventStruct. safetyR(E) preserves Tag-by-msg(E)
THMtag_by_msg_fusion_lemmaE:TaggedEventStruct, P,I:((|E| List)Prop). (P refines Causal(E)) ((I No-dup-send(E) Tag-by-msg(E)) fuses P) ((I No-dup-send(E)) fuses P)
THMno_dup_fusionE:TaggedEventStruct. Tag-by-msg(E) fuses No-dup-deliver(E)
THMno_DASH_dup_DASH_fusionE:TaggedEventStruct, P,I:((|E| List)Prop). (P refines (Causal(E) No-dup-deliver(E))) ((I No-dup-send(E) Tag-by-msg(E) Causal(E) No-dup-deliver(E)) fuses P) ((I No-dup-send(E)) fuses P)
deftag_relR(tg) == swap adjacent[tg(x) = tg(y) Label]^*
deftotalordertotalorder(E)(tr) == p,q:Label. agree_on_common(|MS(E)|;map(msg(E);tr delivered at p);map(msg(E);tr delivered at q))
THMtag_sublist_preservedE:EventStruct, A:Type, evt:(A|E|), tg:(ALabel), m:Label, tr1,tr2:A List. (tr1 R(tg) tr2) < tr1 > _m = < tr2 > _m A List
deflocal_deliver_propertylocal_deliver_property(E;P)(tr) == P(p.tr delivered at p)
defdelivered_before_somewherex somewhere delivered before y == k:||tr||. x delivered at time k & (k':||tr||. y delivered at time k' loc(E)(tr[k']) = loc(E)(tr[k]) kk')
THMdecidable__delivered_before_somewhereE:EventStruct, tr:|E| List, x,y:|E|. Dec(x somewhere delivered before y)
defswitch_normalAD-normal(E)(tr) == i:(||tr||-1). (is-send(E)(tr[i]) is-send(E)(tr[(i+1)]) (tr[i] =msg=(E) tr[(i+1)])) & ((x,y:||tr||. x < y & is-send(E)(tr[x]) & is-send(E)(tr[y]) & tr[x] delivered at time i+1 & tr[y] delivered at time i) loc(E)(tr[i]) = loc(E)(tr[(i+1)]))
THMnot_delivered_before_somewhereE:EventStruct, a,b:|E|, tr:|E| List. a somewhere delivered before b (k:||tr||. a delivered at time k (k':||tr||. k' < k & b delivered at time k' & loc(E)(tr[k']) = loc(E)(tr[k])))
defswitch_decomposableswitch-decomposable(E)(L) == L = nil |E| List (Q:(||L||Prop). (i:||L||. Dec(Q(i))) & (i:||L||. Q(i)) & (i:||L||. Q(i) is-send(E)(L[i])) & (i,j:||L||. Q(i) Q(j) tag(E)(L[i]) = tag(E)(L[j])) & (i,j:||L||. Q(i) ij C(Q)(j)))
THMswitch_decomp_implies_single_tag_decompE:TaggedEventStruct. (switch-decomposable(E) Tag-by-msg(E) Causal(E) No-dup-send(E)) refines single-tag-decomposable(E)
THMswitch_normal_safetyE:TaggedEventStruct. safetyR(E) preserves AD-normal(E)
THMdelivered_before_somewhere_lemmaE:EventStruct, a,b,c:|E|, tr:|E| List. a somewhere delivered before b a somewhere delivered before c c somewhere delivered before b
defmemoryless_composable_safetyMCS(E)(P) == memorylessR(E) preserves P & (ternary) composableR(E) preserves P & safetyR(E) preserves P
THMM_DASH_C_DASH_S_SPACE_inductionE:TaggedEventStruct, P,I:TraceProperty(E). MCS(E)(P) safetyR(E) preserves I (I refines single-tag-decomposable(E)) (I fuses P)
defR_permutationR_permutation(E) == swap adjacent[True]
THMP_no_dup_permutableE:EventStruct. R_permutation(E) preserves No-dup-deliver(E)
defR_delayabledelayableR(E) == swap adjacent[(x =msg=(E) y) & is-send(E)(x) & is-send(E)(y) is-send(E)(x) & is-send(E)(y)]
THMno_duplicate_send_delayableE:EventStruct. delayableR(E) preserves No-dup-send(E)
THMpermutable_implies_delayableE:EventStruct, P:TraceProperty(E). R_permutation(E) preserves P delayableR(E) preserves P
THMR_delayable_symmetricE:EventStruct, x,y:|E| List. (x delayableR(E) y) (y delayableR(E) x)
defR_asyncasyncR(E) == swap adjacent[loc(E)(x) = loc(E)(y) & is-send(E)(x) & is-send(E)(y) is-send(E)(x) & is-send(E)(y)]
THMno_duplicate_send_asyncE:EventStruct. asyncR(E) preserves No-dup-send(E)
THMpermutable_implies_asyncE:EventStruct, P:TraceProperty(E). R_permutation(E) preserves P asyncR(E) preserves P
THMR_async_symmetricE:EventStruct, x,y:|E| List. (x asyncR(E) y) (y asyncR(E) x)
defswitch_invswitch_inv(E)(tr) == i,j,k:||tr||. i < j is-send(E)(tr[i]) is-send(E)(tr[j]) tag(E)(tr[i]) = tag(E)(tr[j]) tr[j] delivered at time k (k':||tr||. k' < k & tr[i] delivered at time k' & loc(E)(tr[k']) = loc(E)(tr[k]))
THMswitch_inv_swapE:TaggedEventStruct, x:|E| List, i:(||x||-1). switch_inv(E)(x) is-send(E)(x[(i+1)]) is-send(E)(x[i]) loc(E)(x[i]) = loc(E)(x[(i+1)]) switch_inv(E)(swap(x;i;i+1))
THMswitch_inv_safetyE:TaggedEventStruct. safetyR(E) preserves switch_inv(E)
deflayer_rellayerR(E) == ((asyncR(E) delayableR(E)) send-enabledR(E))^*
THMno_duplicate_send_layerE:EventStruct. layerR(E)^-1 preserves No-dup-send(E)
defswitch_inv_relInfix switchR(tr)(i,j) == is-send(E)(tr[i]) & is-send(E)(tr[j]) & i < j & tr[j] somewhere delivered before tr[i] j < i & tr[i] somewhere delivered before tr[j]
THMdecidable__switch_inv_relE:EventStruct, x:|E| List, j,z:||x||. Dec(j switchR(x) z)
defswitchable0switchable0(E)(P) == safetyR(E) preserves P & memorylessR(E) preserves P & (ternary) composableR(E) preserves P & send-enabledR(E) preserves P & asyncR(E) preserves P & delayableR(E) preserves P
THMlocal_deliver_switchableE:EventStruct, P:((Label(|E| List))Prop). (f,g:(Label(|E| List)). (p:Label. g(p) f(p)) P(f) P(g)) (f,g:(Label(|E| List)). (a:|E|. p:Label. g(p) = filter(b.(b =msg=(E) a);f(p))) P(f) P(g)) (f,g,h:(Label(|E| List)). (p,q:Label. (xf(p).(yg(q).(x =msg=(E) y)))) (p:Label. h(p) = ((f(p)) @ (g(p)))) P(f) P(g) P(h)) switchable0(E)(local_deliver_property(E;P))
THMP_causal_switchable0E:EventStruct. switchable0(E)(Causal(E))
THMP_no_dup_switchable0E:EventStruct. switchable0(E)(No-dup-deliver(E))
THMswitch_inv_rel_closure_sendE:EventStruct, tr:|E| List, ls,i:||tr||. is-send(E)(tr[ls]) (i (switchR(tr)^*) ls) is-send(E)(tr[i])
THMswitch_inv_rel_same_tagE:TaggedEventStruct, tr:|E| List. switch_inv(E)(tr) (i,j:||tr||. (i switchR(tr) j) tag(E)(tr[i]) = tag(E)(tr[j]))
defb_switchableswitchable(E)(P) == safetyR(E) preserves P & memorylessR(E) preserves P & (ternary) composableR(E) preserves P & send-enabledR(E) preserves P & asyncR(E) preserves P & delayableR(E) preserves P & (P refines Causal(E)) & (P refines No-dup-deliver(E))
THMtotalorder_switchable0E:EventStruct. switchable0(E)(totalorder(E))
THMswitchable0_switchableE:EventStruct, P:TraceProperty(E). switchable0(E)(P) switchable(E)(P Causal(E) No-dup-deliver(E))
THMswitch_inv_rel_closureE:TaggedEventStruct, tr:|E| List, ls:||tr||. switch_inv(E)(tr) (i,j:||tr||. (i (switchR(tr)^*) ls) (j (switchR(tr)^*) ls) tag(E)(tr[i]) = tag(E)(tr[j]))
THMswitch_inv_rel_closure_lemma1E:EventStruct, tr:|E| List, ls:||tr||. is-send(E)(tr[ls]) (j:||tr||. ls < j is-send(E)(tr[j])) (i,j:||tr||. ij is-send(E)(tr[j]) (i (switchR(tr)^*) ls) (j (switchR(tr)^*) ls))
defR_adadR(E) == (delayableR(E) asyncR(E))^*
THMtag_sublist_layerE:TaggedEventStruct. tag_splitable(E;adR(E))
THMswitchable_inducedE:EventStruct, A:Type, f:(A|E|), P:((|E| List)Prop). switchable(E)(P) switchable(induced_event_str(E;A;f))(P o f)
THMtotalorder_switchableE:EventStruct. switchable(E)(totalorder(E) Causal(E) No-dup-deliver(E))
THMstrong_switch_inv_decomposableE:TaggedEventStruct. (switch_inv(E) Causal(E) AD-normal(E) No-dup-deliver(E)) refines switch-decomposable(E)
deffull_switch_invfull_switch_inv(E;A;evt;tg;tr_u;tr_l) == tr_m:A List. (tr_l R(tg) tr_m) & (map(evt;tr_m) layerR(E) tr_u) & switch_inv( < A,evt,tg > (E))(tr_m)
THMswitch_normal_existsE:TaggedEventStruct, tr:Trace(E). (switch_inv(E) No-dup-send(E))(tr) (tr':Trace(E). switch_inv(E)(tr') & AD-normal(E)(tr') & (tr adR(E) tr'))
THMswitchable_induced_taggedE:EventStruct, P:((|E| List)Prop), A:Type, f:(A|E|), t:(ALabel). switchable(E)(P) switchable( < A,f,t > (E))(P o f)
THMswitch_inv_plus_normalE:TaggedEventStruct, P:TraceProperty(E). MCS(E)(P) (P refines (Causal(E) No-dup-deliver(E))) (((switch_inv(E) AD-normal(E)) No-dup-send(E)) fuses P)
THMswitch_inv_theoremE:TaggedEventStruct, P:TraceProperty(E). MCS(E)(P) asyncR(E) preserves P delayableR(E) preserves P (P refines (Causal(E) No-dup-deliver(E))) ((switch_inv(E) No-dup-send(E)) fuses P)
THMswitch_inv_theorem2E:TaggedEventStruct, P:TraceProperty(E). switchable(E)(P) ((switch_inv(E) No-dup-send(E)) fuses P)
THMswitch_theoremE:EventStruct, P:((|E| List)Prop), A:Type, evt:(A|E|), tg:(ALabel), tr:A List. switchable(E)(P) No-dup-send(E)(map(evt;tr)) switch_inv( < A,evt,tg > (E))(tr) (m:Label. P(map(evt; < tr > _m))) P(map(evt;tr))
THMswitch_main_theoremE:EventStruct, P:TraceProperty(E), A:Type, evt:(A|E|), tg:(ALabel), tr_u:Trace(E), tr_l:A List. switchable(E)(P) No-dup-send(E)(tr_u) full_switch_inv(E;A;evt;tg;tr_u;tr_l) (m:Label. P(map(evt; < tr_l > _m))) P(tr_u)

Origin Definitions Sections GenAutomata Doc