 tr = nil
tr = nil ||tr||
||tr|| j:
j: ||tr||. ls < j
||tr||. ls < j 
 
  is-send(E)(tr[j])
is-send(E)(tr[j]) 
  Q:(
Q:( ||tr||
||tr||
 Prop). 
(
Prop). 
( i:
i: ||tr||. Dec(Q(i)))
 &  (
||tr||. Dec(Q(i)))
 &  ( i:
i: ||tr||. Q(i))
 &  (
||tr||. Q(i))
 &  ( i:
i: ||tr||. Q(i)
||tr||. Q(i) 
 is-send(E)(tr[i]))
 &  (
 is-send(E)(tr[i]))
 &  ( i,j:
i,j: ||tr||. Q(i)
||tr||. Q(i) 
 Q(j)
 Q(j) 
 tag(E)(tr[i]) = tag(E)(tr[j]))
 &  (
 tag(E)(tr[i]) = tag(E)(tr[j]))
 &  ( i,j:
i,j: ||tr||. Q(i)
||tr||. Q(i) 
 i
 i j
j 
 C(Q)(j))
 C(Q)(j)) i:
i: ||tr||. (i (switchR(tr)^*) ls)
||tr||. (i (switchR(tr)^*) ls) 
 is-send(E)(tr[i]))
((Inst
 
  Thm*
 is-send(E)(tr[i]))
((Inst
 
  Thm*  E:EventStruct, tr:|E| List, ls,i:
E:EventStruct, tr:|E| List, ls,i: ||tr||.
 is-send(E)(tr[ls])
||tr||.
 is-send(E)(tr[ls]) 
 (i (switchR(tr)^*) ls)
 (i (switchR(tr)^*) ls) 
 is-send(E)(tr[i])
 [E;tr;ls])
 THEN
 EasyHyp)
 is-send(E)(tr[i])
 [E;tr;ls])
 THEN
 EasyHyp)
 E:TaggedEventStruct, tr:|E| List, ls:
E:TaggedEventStruct, tr:|E| List, ls: ||tr||.
 switch_inv(E)(tr)
||tr||.
 switch_inv(E)(tr) 
 (
 
 ( i,j:
i,j: ||tr||.
 (i (switchR(tr)^*) ls)
||tr||.
 (i (switchR(tr)^*) ls) 
 (j (switchR(tr)^*) ls)
 (j (switchR(tr)^*) ls) 
 tag(E)(tr[i]) = tag(E)(tr[j]))
 [E;tr;ls]
 tag(E)(tr[i]) = tag(E)(tr[j]))
 [E;tr;ls]
 E:EventStruct. EquivRel(|E|)(_1 =msg=(E) _2)
 [E]
E:EventStruct. EquivRel(|E|)(_1 =msg=(E) _2)
 [E]
 i.i (switchR(tr)^*) ls]
i.i (switchR(tr)^*) ls]
 x,y:T, R:(T
x,y:T, R:(T
 T
T
 Prop). x = y
Prop). x = y 
 (x (R^*) y)))
 (x (R^*) y)))
| 1 | 3. Causal(E)(tr) 4. AD-normal(E)(tr) 5. No-dup-deliver(E)(tr) 6.  tr = nil 7. ls:  ||tr|| 8. is-send(E)(tr[ls]) 9.  j:  ||tr||. ls < j     is-send(E)(tr[j]) 10.  i:  ||tr||. (i (switchR(tr)^*) ls)   is-send(E)(tr[i]) 11. EquivRel(|E|)(_1 =msg=(E) _2)    i,j:  ||tr||. (i (switchR(tr)^*) ls)   i  j   C(  i.i (switchR(tr)^*) ls)(j) | 
About:
|  |  |  |  |  |  |  |  | 
|  |  |  |  |  |  | 
|  |