-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathprimitive_2_CTL.mso
49 lines (40 loc) · 1.34 KB
/
primitive_2_CTL.mso
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
Qx=[vrai, faux]{
etat=2;
init=0;
0=faux;
1=vrai;
0->1[devientVrai];
1->0[devientFaux];
1->1[estCeVrai];
0->0[estCeFaux];
};;
Processus=[crit, debut, fin, attente]{
etat=4;
init=2;
0=attente;
1=crit;
2=debut;
3=fin;
2->0[vaCrit];
0->1[execCrit];
1->3[fin];
};;
Systeme=<Qx Q1, Qx Q2, Processus P1, Processus P2>{
<devientVrai,_,vaCrit,_>;
<_,estCeFaux,execCrit,_>;
<devientFaux,_,fin,_>;
<_,devientVrai,_,vaCrit>;
<estCeFaux,_,_,execCrit>;
<_,devientFaux,_,fin>;
};;
// Surete 1 : Il existe au moins un chemin menant à la fin des deux processus
Systeme += surete <- AF(P1.fin && P2.fin);;
// Exclusion mutuelle : Il n'existe pas de chemin menant à deux exécutions critiques simultanées
Systeme += exclusionMutuelle <- !(EF(P1.crit && P2.crit));;
// Surete 2 : Il existe au moins un chemin menant à un deadlock
Systeme += deadlock <- EF(!EX(true) && (!P1.fin || !P2.fin));;
// Equité Forte : Quel que soit le chemin, un processus au moins a effectué sa section critique
Systeme += equiteForte <- AG((P1.attente -> AF(P1.crit)) &&(P2.attente -> AF(P2.crit)));;
// Equité Faible : Il existe un chemin pour lequel p1 ou p2 peut exécuter sa section critique
Systeme += equiteFaible <- AG((P1.attente -> EF(P1.crit)) && (P2.attente -> EF(P2.crit)));;
todot primitive2CTL.dot Systeme;;