Browse Source
Added some benchmark models from param website
Added some benchmark models from param website
Fixed two bugs considering nonatomic subformulae and constant results
Qualitative modelchecking needs to be done when applying a policy!
Former-commit-id: bd88228214
main
27 changed files with 1647 additions and 577 deletions
-
2examples/pmdp/brp/brp.prctl
-
400examples/pmdp/brp/brpRegions.txt
-
139examples/pmdp/brp/brp_16_2.nm
-
139examples/pmdp/brp/brp_256_5.nm
-
139examples/pmdp/brp/brp_512_5.nm
-
139examples/pmdp/brp/brp_64_4.nm
-
69examples/pmdp/consensus/4pars/coin4_2.nm
-
69examples/pmdp/consensus/4pars/coin4_8.nm
-
4examples/pmdp/consensus/coin.prctl
-
400examples/pmdp/consensus/coin2ParRegions.txt
-
65examples/pmdp/consensus/coin2_1024.nm
-
56examples/pmdp/consensus/coin2_128.nm
-
41examples/pmdp/consensus/coin2_2.nm
-
56examples/pmdp/consensus/coin2_4.nm
-
41examples/pmdp/consensus/coin2_64.nm
-
56examples/pmdp/consensus/coin2_7.nm
-
41examples/pmdp/consensus/coin2_8.nm
-
67examples/pmdp/consensus/coin4_2.nm
-
67examples/pmdp/consensus/coin4_8.nm
-
69examples/pmdp/consensus/coin6_2.nm
-
70examples/pmdp/consensus/coin6_8.nm
-
4src/modelchecker/region/AbstractSparseRegionModelChecker.cpp
-
18src/modelchecker/region/SparseDtmcRegionModelChecker.cpp
-
23src/modelchecker/region/SparseMdpRegionModelChecker.cpp
-
19src/solver/GameSolver.cpp
-
23src/solver/GmmxxMinMaxLinearEquationSolver.cpp
-
8test/functional/modelchecker/SparseMdpRegionModelCheckerTest.cpp
@ -0,0 +1,2 @@ |
|||||
|
P<0.5 [ F (s=5 & T) ] |
||||
|
|
@ -0,0 +1,400 @@ |
|||||
|
0.000010<=pL<=0.050000, 0.000010<=pK<=0.050000; |
||||
|
0.000010<=pL<=0.050000, 0.050000<=pK<=0.100000; |
||||
|
0.000010<=pL<=0.050000, 0.100000<=pK<=0.150000; |
||||
|
0.000010<=pL<=0.050000, 0.150000<=pK<=0.200000; |
||||
|
0.000010<=pL<=0.050000, 0.200000<=pK<=0.250000; |
||||
|
0.000010<=pL<=0.050000, 0.250000<=pK<=0.300000; |
||||
|
0.000010<=pL<=0.050000, 0.300000<=pK<=0.350000; |
||||
|
0.000010<=pL<=0.050000, 0.350000<=pK<=0.400000; |
||||
|
0.000010<=pL<=0.050000, 0.400000<=pK<=0.450000; |
||||
|
0.000010<=pL<=0.050000, 0.450000<=pK<=0.500000; |
||||
|
0.000010<=pL<=0.050000, 0.500000<=pK<=0.550000; |
||||
|
0.000010<=pL<=0.050000, 0.550000<=pK<=0.600000; |
||||
|
0.000010<=pL<=0.050000, 0.600000<=pK<=0.650000; |
||||
|
0.000010<=pL<=0.050000, 0.650000<=pK<=0.700000; |
||||
|
0.000010<=pL<=0.050000, 0.700000<=pK<=0.750000; |
||||
|
0.000010<=pL<=0.050000, 0.750000<=pK<=0.800000; |
||||
|
0.000010<=pL<=0.050000, 0.800000<=pK<=0.850000; |
||||
|
0.000010<=pL<=0.050000, 0.850000<=pK<=0.900000; |
||||
|
0.000010<=pL<=0.050000, 0.900000<=pK<=0.950000; |
||||
|
0.000010<=pL<=0.050000, 0.950000<=pK<=0.999990; |
||||
|
0.050000<=pL<=0.100000, 0.000010<=pK<=0.050000; |
||||
|
0.050000<=pL<=0.100000, 0.050000<=pK<=0.100000; |
||||
|
0.050000<=pL<=0.100000, 0.100000<=pK<=0.150000; |
||||
|
0.050000<=pL<=0.100000, 0.150000<=pK<=0.200000; |
||||
|
0.050000<=pL<=0.100000, 0.200000<=pK<=0.250000; |
||||
|
0.050000<=pL<=0.100000, 0.250000<=pK<=0.300000; |
||||
|
0.050000<=pL<=0.100000, 0.300000<=pK<=0.350000; |
||||
|
0.050000<=pL<=0.100000, 0.350000<=pK<=0.400000; |
||||
|
0.050000<=pL<=0.100000, 0.400000<=pK<=0.450000; |
||||
|
0.050000<=pL<=0.100000, 0.450000<=pK<=0.500000; |
||||
|
0.050000<=pL<=0.100000, 0.500000<=pK<=0.550000; |
||||
|
0.050000<=pL<=0.100000, 0.550000<=pK<=0.600000; |
||||
|
0.050000<=pL<=0.100000, 0.600000<=pK<=0.650000; |
||||
|
0.050000<=pL<=0.100000, 0.650000<=pK<=0.700000; |
||||
|
0.050000<=pL<=0.100000, 0.700000<=pK<=0.750000; |
||||
|
0.050000<=pL<=0.100000, 0.750000<=pK<=0.800000; |
||||
|
0.050000<=pL<=0.100000, 0.800000<=pK<=0.850000; |
||||
|
0.050000<=pL<=0.100000, 0.850000<=pK<=0.900000; |
||||
|
0.050000<=pL<=0.100000, 0.900000<=pK<=0.950000; |
||||
|
0.050000<=pL<=0.100000, 0.950000<=pK<=0.999990; |
||||
|
0.100000<=pL<=0.150000, 0.000010<=pK<=0.050000; |
||||
|
0.100000<=pL<=0.150000, 0.050000<=pK<=0.100000; |
||||
|
0.100000<=pL<=0.150000, 0.100000<=pK<=0.150000; |
||||
|
0.100000<=pL<=0.150000, 0.150000<=pK<=0.200000; |
||||
|
0.100000<=pL<=0.150000, 0.200000<=pK<=0.250000; |
||||
|
0.100000<=pL<=0.150000, 0.250000<=pK<=0.300000; |
||||
|
0.100000<=pL<=0.150000, 0.300000<=pK<=0.350000; |
||||
|
0.100000<=pL<=0.150000, 0.350000<=pK<=0.400000; |
||||
|
0.100000<=pL<=0.150000, 0.400000<=pK<=0.450000; |
||||
|
0.100000<=pL<=0.150000, 0.450000<=pK<=0.500000; |
||||
|
0.100000<=pL<=0.150000, 0.500000<=pK<=0.550000; |
||||
|
0.100000<=pL<=0.150000, 0.550000<=pK<=0.600000; |
||||
|
0.100000<=pL<=0.150000, 0.600000<=pK<=0.650000; |
||||
|
0.100000<=pL<=0.150000, 0.650000<=pK<=0.700000; |
||||
|
0.100000<=pL<=0.150000, 0.700000<=pK<=0.750000; |
||||
|
0.100000<=pL<=0.150000, 0.750000<=pK<=0.800000; |
||||
|
0.100000<=pL<=0.150000, 0.800000<=pK<=0.850000; |
||||
|
0.100000<=pL<=0.150000, 0.850000<=pK<=0.900000; |
||||
|
0.100000<=pL<=0.150000, 0.900000<=pK<=0.950000; |
||||
|
0.100000<=pL<=0.150000, 0.950000<=pK<=0.999990; |
||||
|
0.150000<=pL<=0.200000, 0.000010<=pK<=0.050000; |
||||
|
0.150000<=pL<=0.200000, 0.050000<=pK<=0.100000; |
||||
|
0.150000<=pL<=0.200000, 0.100000<=pK<=0.150000; |
||||
|
0.150000<=pL<=0.200000, 0.150000<=pK<=0.200000; |
||||
|
0.150000<=pL<=0.200000, 0.200000<=pK<=0.250000; |
||||
|
0.150000<=pL<=0.200000, 0.250000<=pK<=0.300000; |
||||
|
0.150000<=pL<=0.200000, 0.300000<=pK<=0.350000; |
||||
|
0.150000<=pL<=0.200000, 0.350000<=pK<=0.400000; |
||||
|
0.150000<=pL<=0.200000, 0.400000<=pK<=0.450000; |
||||
|
0.150000<=pL<=0.200000, 0.450000<=pK<=0.500000; |
||||
|
0.150000<=pL<=0.200000, 0.500000<=pK<=0.550000; |
||||
|
0.150000<=pL<=0.200000, 0.550000<=pK<=0.600000; |
||||
|
0.150000<=pL<=0.200000, 0.600000<=pK<=0.650000; |
||||
|
0.150000<=pL<=0.200000, 0.650000<=pK<=0.700000; |
||||
|
0.150000<=pL<=0.200000, 0.700000<=pK<=0.750000; |
||||
|
0.150000<=pL<=0.200000, 0.750000<=pK<=0.800000; |
||||
|
0.150000<=pL<=0.200000, 0.800000<=pK<=0.850000; |
||||
|
0.150000<=pL<=0.200000, 0.850000<=pK<=0.900000; |
||||
|
0.150000<=pL<=0.200000, 0.900000<=pK<=0.950000; |
||||
|
0.150000<=pL<=0.200000, 0.950000<=pK<=0.999990; |
||||
|
0.200000<=pL<=0.250000, 0.000010<=pK<=0.050000; |
||||
|
0.200000<=pL<=0.250000, 0.050000<=pK<=0.100000; |
||||
|
0.200000<=pL<=0.250000, 0.100000<=pK<=0.150000; |
||||
|
0.200000<=pL<=0.250000, 0.150000<=pK<=0.200000; |
||||
|
0.200000<=pL<=0.250000, 0.200000<=pK<=0.250000; |
||||
|
0.200000<=pL<=0.250000, 0.250000<=pK<=0.300000; |
||||
|
0.200000<=pL<=0.250000, 0.300000<=pK<=0.350000; |
||||
|
0.200000<=pL<=0.250000, 0.350000<=pK<=0.400000; |
||||
|
0.200000<=pL<=0.250000, 0.400000<=pK<=0.450000; |
||||
|
0.200000<=pL<=0.250000, 0.450000<=pK<=0.500000; |
||||
|
0.200000<=pL<=0.250000, 0.500000<=pK<=0.550000; |
||||
|
0.200000<=pL<=0.250000, 0.550000<=pK<=0.600000; |
||||
|
0.200000<=pL<=0.250000, 0.600000<=pK<=0.650000; |
||||
|
0.200000<=pL<=0.250000, 0.650000<=pK<=0.700000; |
||||
|
0.200000<=pL<=0.250000, 0.700000<=pK<=0.750000; |
||||
|
0.200000<=pL<=0.250000, 0.750000<=pK<=0.800000; |
||||
|
0.200000<=pL<=0.250000, 0.800000<=pK<=0.850000; |
||||
|
0.200000<=pL<=0.250000, 0.850000<=pK<=0.900000; |
||||
|
0.200000<=pL<=0.250000, 0.900000<=pK<=0.950000; |
||||
|
0.200000<=pL<=0.250000, 0.950000<=pK<=0.999990; |
||||
|
0.250000<=pL<=0.300000, 0.000010<=pK<=0.050000; |
||||
|
0.250000<=pL<=0.300000, 0.050000<=pK<=0.100000; |
||||
|
0.250000<=pL<=0.300000, 0.100000<=pK<=0.150000; |
||||
|
0.250000<=pL<=0.300000, 0.150000<=pK<=0.200000; |
||||
|
0.250000<=pL<=0.300000, 0.200000<=pK<=0.250000; |
||||
|
0.250000<=pL<=0.300000, 0.250000<=pK<=0.300000; |
||||
|
0.250000<=pL<=0.300000, 0.300000<=pK<=0.350000; |
||||
|
0.250000<=pL<=0.300000, 0.350000<=pK<=0.400000; |
||||
|
0.250000<=pL<=0.300000, 0.400000<=pK<=0.450000; |
||||
|
0.250000<=pL<=0.300000, 0.450000<=pK<=0.500000; |
||||
|
0.250000<=pL<=0.300000, 0.500000<=pK<=0.550000; |
||||
|
0.250000<=pL<=0.300000, 0.550000<=pK<=0.600000; |
||||
|
0.250000<=pL<=0.300000, 0.600000<=pK<=0.650000; |
||||
|
0.250000<=pL<=0.300000, 0.650000<=pK<=0.700000; |
||||
|
0.250000<=pL<=0.300000, 0.700000<=pK<=0.750000; |
||||
|
0.250000<=pL<=0.300000, 0.750000<=pK<=0.800000; |
||||
|
0.250000<=pL<=0.300000, 0.800000<=pK<=0.850000; |
||||
|
0.250000<=pL<=0.300000, 0.850000<=pK<=0.900000; |
||||
|
0.250000<=pL<=0.300000, 0.900000<=pK<=0.950000; |
||||
|
0.250000<=pL<=0.300000, 0.950000<=pK<=0.999990; |
||||
|
0.300000<=pL<=0.350000, 0.000010<=pK<=0.050000; |
||||
|
0.300000<=pL<=0.350000, 0.050000<=pK<=0.100000; |
||||
|
0.300000<=pL<=0.350000, 0.100000<=pK<=0.150000; |
||||
|
0.300000<=pL<=0.350000, 0.150000<=pK<=0.200000; |
||||
|
0.300000<=pL<=0.350000, 0.200000<=pK<=0.250000; |
||||
|
0.300000<=pL<=0.350000, 0.250000<=pK<=0.300000; |
||||
|
0.300000<=pL<=0.350000, 0.300000<=pK<=0.350000; |
||||
|
0.300000<=pL<=0.350000, 0.350000<=pK<=0.400000; |
||||
|
0.300000<=pL<=0.350000, 0.400000<=pK<=0.450000; |
||||
|
0.300000<=pL<=0.350000, 0.450000<=pK<=0.500000; |
||||
|
0.300000<=pL<=0.350000, 0.500000<=pK<=0.550000; |
||||
|
0.300000<=pL<=0.350000, 0.550000<=pK<=0.600000; |
||||
|
0.300000<=pL<=0.350000, 0.600000<=pK<=0.650000; |
||||
|
0.300000<=pL<=0.350000, 0.650000<=pK<=0.700000; |
||||
|
0.300000<=pL<=0.350000, 0.700000<=pK<=0.750000; |
||||
|
0.300000<=pL<=0.350000, 0.750000<=pK<=0.800000; |
||||
|
0.300000<=pL<=0.350000, 0.800000<=pK<=0.850000; |
||||
|
0.300000<=pL<=0.350000, 0.850000<=pK<=0.900000; |
||||
|
0.300000<=pL<=0.350000, 0.900000<=pK<=0.950000; |
||||
|
0.300000<=pL<=0.350000, 0.950000<=pK<=0.999990; |
||||
|
0.350000<=pL<=0.400000, 0.000010<=pK<=0.050000; |
||||
|
0.350000<=pL<=0.400000, 0.050000<=pK<=0.100000; |
||||
|
0.350000<=pL<=0.400000, 0.100000<=pK<=0.150000; |
||||
|
0.350000<=pL<=0.400000, 0.150000<=pK<=0.200000; |
||||
|
0.350000<=pL<=0.400000, 0.200000<=pK<=0.250000; |
||||
|
0.350000<=pL<=0.400000, 0.250000<=pK<=0.300000; |
||||
|
0.350000<=pL<=0.400000, 0.300000<=pK<=0.350000; |
||||
|
0.350000<=pL<=0.400000, 0.350000<=pK<=0.400000; |
||||
|
0.350000<=pL<=0.400000, 0.400000<=pK<=0.450000; |
||||
|
0.350000<=pL<=0.400000, 0.450000<=pK<=0.500000; |
||||
|
0.350000<=pL<=0.400000, 0.500000<=pK<=0.550000; |
||||
|
0.350000<=pL<=0.400000, 0.550000<=pK<=0.600000; |
||||
|
0.350000<=pL<=0.400000, 0.600000<=pK<=0.650000; |
||||
|
0.350000<=pL<=0.400000, 0.650000<=pK<=0.700000; |
||||
|
0.350000<=pL<=0.400000, 0.700000<=pK<=0.750000; |
||||
|
0.350000<=pL<=0.400000, 0.750000<=pK<=0.800000; |
||||
|
0.350000<=pL<=0.400000, 0.800000<=pK<=0.850000; |
||||
|
0.350000<=pL<=0.400000, 0.850000<=pK<=0.900000; |
||||
|
0.350000<=pL<=0.400000, 0.900000<=pK<=0.950000; |
||||
|
0.350000<=pL<=0.400000, 0.950000<=pK<=0.999990; |
||||
|
0.400000<=pL<=0.450000, 0.000010<=pK<=0.050000; |
||||
|
0.400000<=pL<=0.450000, 0.050000<=pK<=0.100000; |
||||
|
0.400000<=pL<=0.450000, 0.100000<=pK<=0.150000; |
||||
|
0.400000<=pL<=0.450000, 0.150000<=pK<=0.200000; |
||||
|
0.400000<=pL<=0.450000, 0.200000<=pK<=0.250000; |
||||
|
0.400000<=pL<=0.450000, 0.250000<=pK<=0.300000; |
||||
|
0.400000<=pL<=0.450000, 0.300000<=pK<=0.350000; |
||||
|
0.400000<=pL<=0.450000, 0.350000<=pK<=0.400000; |
||||
|
0.400000<=pL<=0.450000, 0.400000<=pK<=0.450000; |
||||
|
0.400000<=pL<=0.450000, 0.450000<=pK<=0.500000; |
||||
|
0.400000<=pL<=0.450000, 0.500000<=pK<=0.550000; |
||||
|
0.400000<=pL<=0.450000, 0.550000<=pK<=0.600000; |
||||
|
0.400000<=pL<=0.450000, 0.600000<=pK<=0.650000; |
||||
|
0.400000<=pL<=0.450000, 0.650000<=pK<=0.700000; |
||||
|
0.400000<=pL<=0.450000, 0.700000<=pK<=0.750000; |
||||
|
0.400000<=pL<=0.450000, 0.750000<=pK<=0.800000; |
||||
|
0.400000<=pL<=0.450000, 0.800000<=pK<=0.850000; |
||||
|
0.400000<=pL<=0.450000, 0.850000<=pK<=0.900000; |
||||
|
0.400000<=pL<=0.450000, 0.900000<=pK<=0.950000; |
||||
|
0.400000<=pL<=0.450000, 0.950000<=pK<=0.999990; |
||||
|
0.450000<=pL<=0.500000, 0.000010<=pK<=0.050000; |
||||
|
0.450000<=pL<=0.500000, 0.050000<=pK<=0.100000; |
||||
|
0.450000<=pL<=0.500000, 0.100000<=pK<=0.150000; |
||||
|
0.450000<=pL<=0.500000, 0.150000<=pK<=0.200000; |
||||
|
0.450000<=pL<=0.500000, 0.200000<=pK<=0.250000; |
||||
|
0.450000<=pL<=0.500000, 0.250000<=pK<=0.300000; |
||||
|
0.450000<=pL<=0.500000, 0.300000<=pK<=0.350000; |
||||
|
0.450000<=pL<=0.500000, 0.350000<=pK<=0.400000; |
||||
|
0.450000<=pL<=0.500000, 0.400000<=pK<=0.450000; |
||||
|
0.450000<=pL<=0.500000, 0.450000<=pK<=0.500000; |
||||
|
0.450000<=pL<=0.500000, 0.500000<=pK<=0.550000; |
||||
|
0.450000<=pL<=0.500000, 0.550000<=pK<=0.600000; |
||||
|
0.450000<=pL<=0.500000, 0.600000<=pK<=0.650000; |
||||
|
0.450000<=pL<=0.500000, 0.650000<=pK<=0.700000; |
||||
|
0.450000<=pL<=0.500000, 0.700000<=pK<=0.750000; |
||||
|
0.450000<=pL<=0.500000, 0.750000<=pK<=0.800000; |
||||
|
0.450000<=pL<=0.500000, 0.800000<=pK<=0.850000; |
||||
|
0.450000<=pL<=0.500000, 0.850000<=pK<=0.900000; |
||||
|
0.450000<=pL<=0.500000, 0.900000<=pK<=0.950000; |
||||
|
0.450000<=pL<=0.500000, 0.950000<=pK<=0.999990; |
||||
|
0.500000<=pL<=0.550000, 0.000010<=pK<=0.050000; |
||||
|
0.500000<=pL<=0.550000, 0.050000<=pK<=0.100000; |
||||
|
0.500000<=pL<=0.550000, 0.100000<=pK<=0.150000; |
||||
|
0.500000<=pL<=0.550000, 0.150000<=pK<=0.200000; |
||||
|
0.500000<=pL<=0.550000, 0.200000<=pK<=0.250000; |
||||
|
0.500000<=pL<=0.550000, 0.250000<=pK<=0.300000; |
||||
|
0.500000<=pL<=0.550000, 0.300000<=pK<=0.350000; |
||||
|
0.500000<=pL<=0.550000, 0.350000<=pK<=0.400000; |
||||
|
0.500000<=pL<=0.550000, 0.400000<=pK<=0.450000; |
||||
|
0.500000<=pL<=0.550000, 0.450000<=pK<=0.500000; |
||||
|
0.500000<=pL<=0.550000, 0.500000<=pK<=0.550000; |
||||
|
0.500000<=pL<=0.550000, 0.550000<=pK<=0.600000; |
||||
|
0.500000<=pL<=0.550000, 0.600000<=pK<=0.650000; |
||||
|
0.500000<=pL<=0.550000, 0.650000<=pK<=0.700000; |
||||
|
0.500000<=pL<=0.550000, 0.700000<=pK<=0.750000; |
||||
|
0.500000<=pL<=0.550000, 0.750000<=pK<=0.800000; |
||||
|
0.500000<=pL<=0.550000, 0.800000<=pK<=0.850000; |
||||
|
0.500000<=pL<=0.550000, 0.850000<=pK<=0.900000; |
||||
|
0.500000<=pL<=0.550000, 0.900000<=pK<=0.950000; |
||||
|
0.500000<=pL<=0.550000, 0.950000<=pK<=0.999990; |
||||
|
0.550000<=pL<=0.600000, 0.000010<=pK<=0.050000; |
||||
|
0.550000<=pL<=0.600000, 0.050000<=pK<=0.100000; |
||||
|
0.550000<=pL<=0.600000, 0.100000<=pK<=0.150000; |
||||
|
0.550000<=pL<=0.600000, 0.150000<=pK<=0.200000; |
||||
|
0.550000<=pL<=0.600000, 0.200000<=pK<=0.250000; |
||||
|
0.550000<=pL<=0.600000, 0.250000<=pK<=0.300000; |
||||
|
0.550000<=pL<=0.600000, 0.300000<=pK<=0.350000; |
||||
|
0.550000<=pL<=0.600000, 0.350000<=pK<=0.400000; |
||||
|
0.550000<=pL<=0.600000, 0.400000<=pK<=0.450000; |
||||
|
0.550000<=pL<=0.600000, 0.450000<=pK<=0.500000; |
||||
|
0.550000<=pL<=0.600000, 0.500000<=pK<=0.550000; |
||||
|
0.550000<=pL<=0.600000, 0.550000<=pK<=0.600000; |
||||
|
0.550000<=pL<=0.600000, 0.600000<=pK<=0.650000; |
||||
|
0.550000<=pL<=0.600000, 0.650000<=pK<=0.700000; |
||||
|
0.550000<=pL<=0.600000, 0.700000<=pK<=0.750000; |
||||
|
0.550000<=pL<=0.600000, 0.750000<=pK<=0.800000; |
||||
|
0.550000<=pL<=0.600000, 0.800000<=pK<=0.850000; |
||||
|
0.550000<=pL<=0.600000, 0.850000<=pK<=0.900000; |
||||
|
0.550000<=pL<=0.600000, 0.900000<=pK<=0.950000; |
||||
|
0.550000<=pL<=0.600000, 0.950000<=pK<=0.999990; |
||||
|
0.600000<=pL<=0.650000, 0.000010<=pK<=0.050000; |
||||
|
0.600000<=pL<=0.650000, 0.050000<=pK<=0.100000; |
||||
|
0.600000<=pL<=0.650000, 0.100000<=pK<=0.150000; |
||||
|
0.600000<=pL<=0.650000, 0.150000<=pK<=0.200000; |
||||
|
0.600000<=pL<=0.650000, 0.200000<=pK<=0.250000; |
||||
|
0.600000<=pL<=0.650000, 0.250000<=pK<=0.300000; |
||||
|
0.600000<=pL<=0.650000, 0.300000<=pK<=0.350000; |
||||
|
0.600000<=pL<=0.650000, 0.350000<=pK<=0.400000; |
||||
|
0.600000<=pL<=0.650000, 0.400000<=pK<=0.450000; |
||||
|
0.600000<=pL<=0.650000, 0.450000<=pK<=0.500000; |
||||
|
0.600000<=pL<=0.650000, 0.500000<=pK<=0.550000; |
||||
|
0.600000<=pL<=0.650000, 0.550000<=pK<=0.600000; |
||||
|
0.600000<=pL<=0.650000, 0.600000<=pK<=0.650000; |
||||
|
0.600000<=pL<=0.650000, 0.650000<=pK<=0.700000; |
||||
|
0.600000<=pL<=0.650000, 0.700000<=pK<=0.750000; |
||||
|
0.600000<=pL<=0.650000, 0.750000<=pK<=0.800000; |
||||
|
0.600000<=pL<=0.650000, 0.800000<=pK<=0.850000; |
||||
|
0.600000<=pL<=0.650000, 0.850000<=pK<=0.900000; |
||||
|
0.600000<=pL<=0.650000, 0.900000<=pK<=0.950000; |
||||
|
0.600000<=pL<=0.650000, 0.950000<=pK<=0.999990; |
||||
|
0.650000<=pL<=0.700000, 0.000010<=pK<=0.050000; |
||||
|
0.650000<=pL<=0.700000, 0.050000<=pK<=0.100000; |
||||
|
0.650000<=pL<=0.700000, 0.100000<=pK<=0.150000; |
||||
|
0.650000<=pL<=0.700000, 0.150000<=pK<=0.200000; |
||||
|
0.650000<=pL<=0.700000, 0.200000<=pK<=0.250000; |
||||
|
0.650000<=pL<=0.700000, 0.250000<=pK<=0.300000; |
||||
|
0.650000<=pL<=0.700000, 0.300000<=pK<=0.350000; |
||||
|
0.650000<=pL<=0.700000, 0.350000<=pK<=0.400000; |
||||
|
0.650000<=pL<=0.700000, 0.400000<=pK<=0.450000; |
||||
|
0.650000<=pL<=0.700000, 0.450000<=pK<=0.500000; |
||||
|
0.650000<=pL<=0.700000, 0.500000<=pK<=0.550000; |
||||
|
0.650000<=pL<=0.700000, 0.550000<=pK<=0.600000; |
||||
|
0.650000<=pL<=0.700000, 0.600000<=pK<=0.650000; |
||||
|
0.650000<=pL<=0.700000, 0.650000<=pK<=0.700000; |
||||
|
0.650000<=pL<=0.700000, 0.700000<=pK<=0.750000; |
||||
|
0.650000<=pL<=0.700000, 0.750000<=pK<=0.800000; |
||||
|
0.650000<=pL<=0.700000, 0.800000<=pK<=0.850000; |
||||
|
0.650000<=pL<=0.700000, 0.850000<=pK<=0.900000; |
||||
|
0.650000<=pL<=0.700000, 0.900000<=pK<=0.950000; |
||||
|
0.650000<=pL<=0.700000, 0.950000<=pK<=0.999990; |
||||
|
0.700000<=pL<=0.750000, 0.000010<=pK<=0.050000; |
||||
|
0.700000<=pL<=0.750000, 0.050000<=pK<=0.100000; |
||||
|
0.700000<=pL<=0.750000, 0.100000<=pK<=0.150000; |
||||
|
0.700000<=pL<=0.750000, 0.150000<=pK<=0.200000; |
||||
|
0.700000<=pL<=0.750000, 0.200000<=pK<=0.250000; |
||||
|
0.700000<=pL<=0.750000, 0.250000<=pK<=0.300000; |
||||
|
0.700000<=pL<=0.750000, 0.300000<=pK<=0.350000; |
||||
|
0.700000<=pL<=0.750000, 0.350000<=pK<=0.400000; |
||||
|
0.700000<=pL<=0.750000, 0.400000<=pK<=0.450000; |
||||
|
0.700000<=pL<=0.750000, 0.450000<=pK<=0.500000; |
||||
|
0.700000<=pL<=0.750000, 0.500000<=pK<=0.550000; |
||||
|
0.700000<=pL<=0.750000, 0.550000<=pK<=0.600000; |
||||
|
0.700000<=pL<=0.750000, 0.600000<=pK<=0.650000; |
||||
|
0.700000<=pL<=0.750000, 0.650000<=pK<=0.700000; |
||||
|
0.700000<=pL<=0.750000, 0.700000<=pK<=0.750000; |
||||
|
0.700000<=pL<=0.750000, 0.750000<=pK<=0.800000; |
||||
|
0.700000<=pL<=0.750000, 0.800000<=pK<=0.850000; |
||||
|
0.700000<=pL<=0.750000, 0.850000<=pK<=0.900000; |
||||
|
0.700000<=pL<=0.750000, 0.900000<=pK<=0.950000; |
||||
|
0.700000<=pL<=0.750000, 0.950000<=pK<=0.999990; |
||||
|
0.750000<=pL<=0.800000, 0.000010<=pK<=0.050000; |
||||
|
0.750000<=pL<=0.800000, 0.050000<=pK<=0.100000; |
||||
|
0.750000<=pL<=0.800000, 0.100000<=pK<=0.150000; |
||||
|
0.750000<=pL<=0.800000, 0.150000<=pK<=0.200000; |
||||
|
0.750000<=pL<=0.800000, 0.200000<=pK<=0.250000; |
||||
|
0.750000<=pL<=0.800000, 0.250000<=pK<=0.300000; |
||||
|
0.750000<=pL<=0.800000, 0.300000<=pK<=0.350000; |
||||
|
0.750000<=pL<=0.800000, 0.350000<=pK<=0.400000; |
||||
|
0.750000<=pL<=0.800000, 0.400000<=pK<=0.450000; |
||||
|
0.750000<=pL<=0.800000, 0.450000<=pK<=0.500000; |
||||
|
0.750000<=pL<=0.800000, 0.500000<=pK<=0.550000; |
||||
|
0.750000<=pL<=0.800000, 0.550000<=pK<=0.600000; |
||||
|
0.750000<=pL<=0.800000, 0.600000<=pK<=0.650000; |
||||
|
0.750000<=pL<=0.800000, 0.650000<=pK<=0.700000; |
||||
|
0.750000<=pL<=0.800000, 0.700000<=pK<=0.750000; |
||||
|
0.750000<=pL<=0.800000, 0.750000<=pK<=0.800000; |
||||
|
0.750000<=pL<=0.800000, 0.800000<=pK<=0.850000; |
||||
|
0.750000<=pL<=0.800000, 0.850000<=pK<=0.900000; |
||||
|
0.750000<=pL<=0.800000, 0.900000<=pK<=0.950000; |
||||
|
0.750000<=pL<=0.800000, 0.950000<=pK<=0.999990; |
||||
|
0.800000<=pL<=0.850000, 0.000010<=pK<=0.050000; |
||||
|
0.800000<=pL<=0.850000, 0.050000<=pK<=0.100000; |
||||
|
0.800000<=pL<=0.850000, 0.100000<=pK<=0.150000; |
||||
|
0.800000<=pL<=0.850000, 0.150000<=pK<=0.200000; |
||||
|
0.800000<=pL<=0.850000, 0.200000<=pK<=0.250000; |
||||
|
0.800000<=pL<=0.850000, 0.250000<=pK<=0.300000; |
||||
|
0.800000<=pL<=0.850000, 0.300000<=pK<=0.350000; |
||||
|
0.800000<=pL<=0.850000, 0.350000<=pK<=0.400000; |
||||
|
0.800000<=pL<=0.850000, 0.400000<=pK<=0.450000; |
||||
|
0.800000<=pL<=0.850000, 0.450000<=pK<=0.500000; |
||||
|
0.800000<=pL<=0.850000, 0.500000<=pK<=0.550000; |
||||
|
0.800000<=pL<=0.850000, 0.550000<=pK<=0.600000; |
||||
|
0.800000<=pL<=0.850000, 0.600000<=pK<=0.650000; |
||||
|
0.800000<=pL<=0.850000, 0.650000<=pK<=0.700000; |
||||
|
0.800000<=pL<=0.850000, 0.700000<=pK<=0.750000; |
||||
|
0.800000<=pL<=0.850000, 0.750000<=pK<=0.800000; |
||||
|
0.800000<=pL<=0.850000, 0.800000<=pK<=0.850000; |
||||
|
0.800000<=pL<=0.850000, 0.850000<=pK<=0.900000; |
||||
|
0.800000<=pL<=0.850000, 0.900000<=pK<=0.950000; |
||||
|
0.800000<=pL<=0.850000, 0.950000<=pK<=0.999990; |
||||
|
0.850000<=pL<=0.900000, 0.000010<=pK<=0.050000; |
||||
|
0.850000<=pL<=0.900000, 0.050000<=pK<=0.100000; |
||||
|
0.850000<=pL<=0.900000, 0.100000<=pK<=0.150000; |
||||
|
0.850000<=pL<=0.900000, 0.150000<=pK<=0.200000; |
||||
|
0.850000<=pL<=0.900000, 0.200000<=pK<=0.250000; |
||||
|
0.850000<=pL<=0.900000, 0.250000<=pK<=0.300000; |
||||
|
0.850000<=pL<=0.900000, 0.300000<=pK<=0.350000; |
||||
|
0.850000<=pL<=0.900000, 0.350000<=pK<=0.400000; |
||||
|
0.850000<=pL<=0.900000, 0.400000<=pK<=0.450000; |
||||
|
0.850000<=pL<=0.900000, 0.450000<=pK<=0.500000; |
||||
|
0.850000<=pL<=0.900000, 0.500000<=pK<=0.550000; |
||||
|
0.850000<=pL<=0.900000, 0.550000<=pK<=0.600000; |
||||
|
0.850000<=pL<=0.900000, 0.600000<=pK<=0.650000; |
||||
|
0.850000<=pL<=0.900000, 0.650000<=pK<=0.700000; |
||||
|
0.850000<=pL<=0.900000, 0.700000<=pK<=0.750000; |
||||
|
0.850000<=pL<=0.900000, 0.750000<=pK<=0.800000; |
||||
|
0.850000<=pL<=0.900000, 0.800000<=pK<=0.850000; |
||||
|
0.850000<=pL<=0.900000, 0.850000<=pK<=0.900000; |
||||
|
0.850000<=pL<=0.900000, 0.900000<=pK<=0.950000; |
||||
|
0.850000<=pL<=0.900000, 0.950000<=pK<=0.999990; |
||||
|
0.900000<=pL<=0.950000, 0.000010<=pK<=0.050000; |
||||
|
0.900000<=pL<=0.950000, 0.050000<=pK<=0.100000; |
||||
|
0.900000<=pL<=0.950000, 0.100000<=pK<=0.150000; |
||||
|
0.900000<=pL<=0.950000, 0.150000<=pK<=0.200000; |
||||
|
0.900000<=pL<=0.950000, 0.200000<=pK<=0.250000; |
||||
|
0.900000<=pL<=0.950000, 0.250000<=pK<=0.300000; |
||||
|
0.900000<=pL<=0.950000, 0.300000<=pK<=0.350000; |
||||
|
0.900000<=pL<=0.950000, 0.350000<=pK<=0.400000; |
||||
|
0.900000<=pL<=0.950000, 0.400000<=pK<=0.450000; |
||||
|
0.900000<=pL<=0.950000, 0.450000<=pK<=0.500000; |
||||
|
0.900000<=pL<=0.950000, 0.500000<=pK<=0.550000; |
||||
|
0.900000<=pL<=0.950000, 0.550000<=pK<=0.600000; |
||||
|
0.900000<=pL<=0.950000, 0.600000<=pK<=0.650000; |
||||
|
0.900000<=pL<=0.950000, 0.650000<=pK<=0.700000; |
||||
|
0.900000<=pL<=0.950000, 0.700000<=pK<=0.750000; |
||||
|
0.900000<=pL<=0.950000, 0.750000<=pK<=0.800000; |
||||
|
0.900000<=pL<=0.950000, 0.800000<=pK<=0.850000; |
||||
|
0.900000<=pL<=0.950000, 0.850000<=pK<=0.900000; |
||||
|
0.900000<=pL<=0.950000, 0.900000<=pK<=0.950000; |
||||
|
0.900000<=pL<=0.950000, 0.950000<=pK<=0.999990; |
||||
|
0.950000<=pL<=0.999990, 0.000010<=pK<=0.050000; |
||||
|
0.950000<=pL<=0.999990, 0.050000<=pK<=0.100000; |
||||
|
0.950000<=pL<=0.999990, 0.100000<=pK<=0.150000; |
||||
|
0.950000<=pL<=0.999990, 0.150000<=pK<=0.200000; |
||||
|
0.950000<=pL<=0.999990, 0.200000<=pK<=0.250000; |
||||
|
0.950000<=pL<=0.999990, 0.250000<=pK<=0.300000; |
||||
|
0.950000<=pL<=0.999990, 0.300000<=pK<=0.350000; |
||||
|
0.950000<=pL<=0.999990, 0.350000<=pK<=0.400000; |
||||
|
0.950000<=pL<=0.999990, 0.400000<=pK<=0.450000; |
||||
|
0.950000<=pL<=0.999990, 0.450000<=pK<=0.500000; |
||||
|
0.950000<=pL<=0.999990, 0.500000<=pK<=0.550000; |
||||
|
0.950000<=pL<=0.999990, 0.550000<=pK<=0.600000; |
||||
|
0.950000<=pL<=0.999990, 0.600000<=pK<=0.650000; |
||||
|
0.950000<=pL<=0.999990, 0.650000<=pK<=0.700000; |
||||
|
0.950000<=pL<=0.999990, 0.700000<=pK<=0.750000; |
||||
|
0.950000<=pL<=0.999990, 0.750000<=pK<=0.800000; |
||||
|
0.950000<=pL<=0.999990, 0.800000<=pK<=0.850000; |
||||
|
0.950000<=pL<=0.999990, 0.850000<=pK<=0.900000; |
||||
|
0.950000<=pL<=0.999990, 0.900000<=pK<=0.950000; |
||||
|
0.950000<=pL<=0.999990, 0.950000<=pK<=0.999990; |
@ -0,0 +1,139 @@ |
|||||
|
// bounded retransmission protocol [D'AJJL01] |
||||
|
// gxn/dxp 23/05/2001 |
||||
|
// Modified by Ernst Moritz Hahn (emh@cs.uni-sb.de) |
||||
|
|
||||
|
mdp |
||||
|
//dtmc |
||||
|
|
||||
|
// number of chunks |
||||
|
const int N = 16; |
||||
|
// maximum number of retransmissions |
||||
|
const int MAX = 2; |
||||
|
|
||||
|
// reliability of channels |
||||
|
const double pL; |
||||
|
const double pK; |
||||
|
|
||||
|
global T : bool; |
||||
|
|
||||
|
module sender |
||||
|
|
||||
|
s : [0..6]; |
||||
|
// 0 idle |
||||
|
// 1 next_frame |
||||
|
// 2 wait_ack |
||||
|
// 3 retransmit |
||||
|
// 4 success |
||||
|
// 5 error |
||||
|
// 6 wait sync |
||||
|
srep : [0..3]; |
||||
|
// 0 bottom |
||||
|
// 1 not ok (nok) |
||||
|
// 2 do not know (dk) |
||||
|
// 3 ok (ok) |
||||
|
nrtr : [0..MAX]; |
||||
|
i : [0..N]; |
||||
|
bs : bool; |
||||
|
s_ab : bool; |
||||
|
fs : bool; |
||||
|
ls : bool; |
||||
|
|
||||
|
// idle |
||||
|
[NewFile] (s=0) -> (s'=1) & (i'=1) & (srep'=0); |
||||
|
// next_frame |
||||
|
[aF] (s=1) -> (s'=2) & (fs'=(i=1)) & (ls'=(i=N)) & (bs'=s_ab) & (nrtr'=0); |
||||
|
// wait_ack |
||||
|
[aB] (s=2) -> (s'=4) & (s_ab'=!s_ab); |
||||
|
[TO_Msg] (s=2) -> (s'=3); |
||||
|
[TO_Ack] (s=2) -> (s'=3); |
||||
|
// retransmit |
||||
|
[aF] (s=3) & (nrtr<MAX) -> (s'=2) & (fs'=(i=1)) & (ls'=(i=N)) & (bs'=s_ab) & (nrtr'=nrtr+1); |
||||
|
[] (s=3) & (nrtr=MAX) & (i<N) -> (s'=5) & (srep'=1); |
||||
|
[] (s=3) & (nrtr=MAX) & (i=N) -> (s'=5) & (srep'=2); |
||||
|
// success |
||||
|
[] (s=4) & (i<N) -> (s'=1) & (i'=i+1); |
||||
|
[] (s=4) & (i=N) -> (s'=0) & (srep'=3); |
||||
|
// error |
||||
|
[SyncWait] (s=5) -> (s'=6); |
||||
|
// wait sync |
||||
|
[SyncWait] (s=6) -> (s'=0) & (s_ab'=false); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module receiver |
||||
|
|
||||
|
r : [0..5]; |
||||
|
// 0 new_file |
||||
|
// 1 fst_safe |
||||
|
// 2 frame_received |
||||
|
// 3 frame_reported |
||||
|
// 4 idle |
||||
|
// 5 resync |
||||
|
rrep : [0..4]; |
||||
|
// 0 bottom |
||||
|
// 1 fst |
||||
|
// 2 inc |
||||
|
// 3 ok |
||||
|
// 4 nok |
||||
|
fr : bool; |
||||
|
lr : bool; |
||||
|
br : bool; |
||||
|
r_ab : bool; |
||||
|
recv : bool; |
||||
|
|
||||
|
|
||||
|
// new_file |
||||
|
[SyncWait] (r=0) -> (r'=0); |
||||
|
[aG] (r=0) -> (r'=1) & (fr'=fs) & (lr'=ls) & (br'=bs) & (recv'=T); |
||||
|
// fst_safe_frame |
||||
|
[] (r=1) -> (r'=2) & (r_ab'=br); |
||||
|
// frame_received |
||||
|
[] (r=2) & (r_ab=br) & (fr=true) & (lr=false) -> (r'=3) & (rrep'=1); |
||||
|
[] (r=2) & (r_ab=br) & (fr=false) & (lr=false) -> (r'=3) & (rrep'=2); |
||||
|
[] (r=2) & (r_ab=br) & (fr=false) & (lr=true) -> (r'=3) & (rrep'=3); |
||||
|
[aA] (r=2) & !(r_ab=br) -> (r'=4); |
||||
|
// frame_reported |
||||
|
[aA] (r=3) -> (r'=4) & (r_ab'=!r_ab); |
||||
|
// idle |
||||
|
[aG] (r=4) -> (r'=2) & (fr'=fs) & (lr'=ls) & (br'=bs) & (recv'=T); |
||||
|
[SyncWait] (r=4) & (ls=true) -> (r'=5); |
||||
|
[SyncWait] (r=4) & (ls=false) -> (r'=5) & (rrep'=4); |
||||
|
// resync |
||||
|
[SyncWait] (r=5) -> (r'=0) & (rrep'=0); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module checker |
||||
|
|
||||
|
[NewFile] (T=false) -> (T'=false); |
||||
|
[NewFile] (T=false) -> (T'=true); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module channelK |
||||
|
|
||||
|
k : [0..2]; |
||||
|
|
||||
|
// idle |
||||
|
[aF] (k=0) -> pK : (k'=1) + 1-pK : (k'=2); |
||||
|
// sending |
||||
|
[aG] (k=1) -> (k'=0); |
||||
|
// lost |
||||
|
[TO_Msg] (k=2) -> (k'=0); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module channelL |
||||
|
|
||||
|
l : [0..2]; |
||||
|
|
||||
|
// idle |
||||
|
[aA] (l=0) -> pL : (l'=1) + 1-pL : (l'=2); |
||||
|
// sending |
||||
|
[aB] (l=1) -> (l'=0); |
||||
|
// lost |
||||
|
[TO_Ack] (l=2) -> (l'=0); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
|
@ -0,0 +1,139 @@ |
|||||
|
// bounded retransmission protocol [D'AJJL01] |
||||
|
// gxn/dxp 23/05/2001 |
||||
|
// Modified by Ernst Moritz Hahn (emh@cs.uni-sb.de) |
||||
|
|
||||
|
mdp |
||||
|
//dtmc |
||||
|
|
||||
|
// number of chunks |
||||
|
const int N = 256; |
||||
|
// maximum number of retransmissions |
||||
|
const int MAX = 5; |
||||
|
|
||||
|
// reliability of channels |
||||
|
const double pL; |
||||
|
const double pK; |
||||
|
|
||||
|
global T : bool; |
||||
|
|
||||
|
module sender |
||||
|
|
||||
|
s : [0..6]; |
||||
|
// 0 idle |
||||
|
// 1 next_frame |
||||
|
// 2 wait_ack |
||||
|
// 3 retransmit |
||||
|
// 4 success |
||||
|
// 5 error |
||||
|
// 6 wait sync |
||||
|
srep : [0..3]; |
||||
|
// 0 bottom |
||||
|
// 1 not ok (nok) |
||||
|
// 2 do not know (dk) |
||||
|
// 3 ok (ok) |
||||
|
nrtr : [0..MAX]; |
||||
|
i : [0..N]; |
||||
|
bs : bool; |
||||
|
s_ab : bool; |
||||
|
fs : bool; |
||||
|
ls : bool; |
||||
|
|
||||
|
// idle |
||||
|
[NewFile] (s=0) -> (s'=1) & (i'=1) & (srep'=0); |
||||
|
// next_frame |
||||
|
[aF] (s=1) -> (s'=2) & (fs'=(i=1)) & (ls'=(i=N)) & (bs'=s_ab) & (nrtr'=0); |
||||
|
// wait_ack |
||||
|
[aB] (s=2) -> (s'=4) & (s_ab'=!s_ab); |
||||
|
[TO_Msg] (s=2) -> (s'=3); |
||||
|
[TO_Ack] (s=2) -> (s'=3); |
||||
|
// retransmit |
||||
|
[aF] (s=3) & (nrtr<MAX) -> (s'=2) & (fs'=(i=1)) & (ls'=(i=N)) & (bs'=s_ab) & (nrtr'=nrtr+1); |
||||
|
[] (s=3) & (nrtr=MAX) & (i<N) -> (s'=5) & (srep'=1); |
||||
|
[] (s=3) & (nrtr=MAX) & (i=N) -> (s'=5) & (srep'=2); |
||||
|
// success |
||||
|
[] (s=4) & (i<N) -> (s'=1) & (i'=i+1); |
||||
|
[] (s=4) & (i=N) -> (s'=0) & (srep'=3); |
||||
|
// error |
||||
|
[SyncWait] (s=5) -> (s'=6); |
||||
|
// wait sync |
||||
|
[SyncWait] (s=6) -> (s'=0) & (s_ab'=false); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module receiver |
||||
|
|
||||
|
r : [0..5]; |
||||
|
// 0 new_file |
||||
|
// 1 fst_safe |
||||
|
// 2 frame_received |
||||
|
// 3 frame_reported |
||||
|
// 4 idle |
||||
|
// 5 resync |
||||
|
rrep : [0..4]; |
||||
|
// 0 bottom |
||||
|
// 1 fst |
||||
|
// 2 inc |
||||
|
// 3 ok |
||||
|
// 4 nok |
||||
|
fr : bool; |
||||
|
lr : bool; |
||||
|
br : bool; |
||||
|
r_ab : bool; |
||||
|
recv : bool; |
||||
|
|
||||
|
|
||||
|
// new_file |
||||
|
[SyncWait] (r=0) -> (r'=0); |
||||
|
[aG] (r=0) -> (r'=1) & (fr'=fs) & (lr'=ls) & (br'=bs) & (recv'=T); |
||||
|
// fst_safe_frame |
||||
|
[] (r=1) -> (r'=2) & (r_ab'=br); |
||||
|
// frame_received |
||||
|
[] (r=2) & (r_ab=br) & (fr=true) & (lr=false) -> (r'=3) & (rrep'=1); |
||||
|
[] (r=2) & (r_ab=br) & (fr=false) & (lr=false) -> (r'=3) & (rrep'=2); |
||||
|
[] (r=2) & (r_ab=br) & (fr=false) & (lr=true) -> (r'=3) & (rrep'=3); |
||||
|
[aA] (r=2) & !(r_ab=br) -> (r'=4); |
||||
|
// frame_reported |
||||
|
[aA] (r=3) -> (r'=4) & (r_ab'=!r_ab); |
||||
|
// idle |
||||
|
[aG] (r=4) -> (r'=2) & (fr'=fs) & (lr'=ls) & (br'=bs) & (recv'=T); |
||||
|
[SyncWait] (r=4) & (ls=true) -> (r'=5); |
||||
|
[SyncWait] (r=4) & (ls=false) -> (r'=5) & (rrep'=4); |
||||
|
// resync |
||||
|
[SyncWait] (r=5) -> (r'=0) & (rrep'=0); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module checker |
||||
|
|
||||
|
[NewFile] (T=false) -> (T'=false); |
||||
|
[NewFile] (T=false) -> (T'=true); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module channelK |
||||
|
|
||||
|
k : [0..2]; |
||||
|
|
||||
|
// idle |
||||
|
[aF] (k=0) -> pK : (k'=1) + 1-pK : (k'=2); |
||||
|
// sending |
||||
|
[aG] (k=1) -> (k'=0); |
||||
|
// lost |
||||
|
[TO_Msg] (k=2) -> (k'=0); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module channelL |
||||
|
|
||||
|
l : [0..2]; |
||||
|
|
||||
|
// idle |
||||
|
[aA] (l=0) -> pL : (l'=1) + 1-pL : (l'=2); |
||||
|
// sending |
||||
|
[aB] (l=1) -> (l'=0); |
||||
|
// lost |
||||
|
[TO_Ack] (l=2) -> (l'=0); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
|
@ -0,0 +1,139 @@ |
|||||
|
// bounded retransmission protocol [D'AJJL01] |
||||
|
// gxn/dxp 23/05/2001 |
||||
|
// Modified by Ernst Moritz Hahn (emh@cs.uni-sb.de) |
||||
|
|
||||
|
mdp |
||||
|
//dtmc |
||||
|
|
||||
|
// number of chunks |
||||
|
const int N = 512; |
||||
|
// maximum number of retransmissions |
||||
|
const int MAX = 5; |
||||
|
|
||||
|
// reliability of channels |
||||
|
const double pL; |
||||
|
const double pK; |
||||
|
|
||||
|
global T : bool; |
||||
|
|
||||
|
module sender |
||||
|
|
||||
|
s : [0..6]; |
||||
|
// 0 idle |
||||
|
// 1 next_frame |
||||
|
// 2 wait_ack |
||||
|
// 3 retransmit |
||||
|
// 4 success |
||||
|
// 5 error |
||||
|
// 6 wait sync |
||||
|
srep : [0..3]; |
||||
|
// 0 bottom |
||||
|
// 1 not ok (nok) |
||||
|
// 2 do not know (dk) |
||||
|
// 3 ok (ok) |
||||
|
nrtr : [0..MAX]; |
||||
|
i : [0..N]; |
||||
|
bs : bool; |
||||
|
s_ab : bool; |
||||
|
fs : bool; |
||||
|
ls : bool; |
||||
|
|
||||
|
// idle |
||||
|
[NewFile] (s=0) -> (s'=1) & (i'=1) & (srep'=0); |
||||
|
// next_frame |
||||
|
[aF] (s=1) -> (s'=2) & (fs'=(i=1)) & (ls'=(i=N)) & (bs'=s_ab) & (nrtr'=0); |
||||
|
// wait_ack |
||||
|
[aB] (s=2) -> (s'=4) & (s_ab'=!s_ab); |
||||
|
[TO_Msg] (s=2) -> (s'=3); |
||||
|
[TO_Ack] (s=2) -> (s'=3); |
||||
|
// retransmit |
||||
|
[aF] (s=3) & (nrtr<MAX) -> (s'=2) & (fs'=(i=1)) & (ls'=(i=N)) & (bs'=s_ab) & (nrtr'=nrtr+1); |
||||
|
[] (s=3) & (nrtr=MAX) & (i<N) -> (s'=5) & (srep'=1); |
||||
|
[] (s=3) & (nrtr=MAX) & (i=N) -> (s'=5) & (srep'=2); |
||||
|
// success |
||||
|
[] (s=4) & (i<N) -> (s'=1) & (i'=i+1); |
||||
|
[] (s=4) & (i=N) -> (s'=0) & (srep'=3); |
||||
|
// error |
||||
|
[SyncWait] (s=5) -> (s'=6); |
||||
|
// wait sync |
||||
|
[SyncWait] (s=6) -> (s'=0) & (s_ab'=false); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module receiver |
||||
|
|
||||
|
r : [0..5]; |
||||
|
// 0 new_file |
||||
|
// 1 fst_safe |
||||
|
// 2 frame_received |
||||
|
// 3 frame_reported |
||||
|
// 4 idle |
||||
|
// 5 resync |
||||
|
rrep : [0..4]; |
||||
|
// 0 bottom |
||||
|
// 1 fst |
||||
|
// 2 inc |
||||
|
// 3 ok |
||||
|
// 4 nok |
||||
|
fr : bool; |
||||
|
lr : bool; |
||||
|
br : bool; |
||||
|
r_ab : bool; |
||||
|
recv : bool; |
||||
|
|
||||
|
|
||||
|
// new_file |
||||
|
[SyncWait] (r=0) -> (r'=0); |
||||
|
[aG] (r=0) -> (r'=1) & (fr'=fs) & (lr'=ls) & (br'=bs) & (recv'=T); |
||||
|
// fst_safe_frame |
||||
|
[] (r=1) -> (r'=2) & (r_ab'=br); |
||||
|
// frame_received |
||||
|
[] (r=2) & (r_ab=br) & (fr=true) & (lr=false) -> (r'=3) & (rrep'=1); |
||||
|
[] (r=2) & (r_ab=br) & (fr=false) & (lr=false) -> (r'=3) & (rrep'=2); |
||||
|
[] (r=2) & (r_ab=br) & (fr=false) & (lr=true) -> (r'=3) & (rrep'=3); |
||||
|
[aA] (r=2) & !(r_ab=br) -> (r'=4); |
||||
|
// frame_reported |
||||
|
[aA] (r=3) -> (r'=4) & (r_ab'=!r_ab); |
||||
|
// idle |
||||
|
[aG] (r=4) -> (r'=2) & (fr'=fs) & (lr'=ls) & (br'=bs) & (recv'=T); |
||||
|
[SyncWait] (r=4) & (ls=true) -> (r'=5); |
||||
|
[SyncWait] (r=4) & (ls=false) -> (r'=5) & (rrep'=4); |
||||
|
// resync |
||||
|
[SyncWait] (r=5) -> (r'=0) & (rrep'=0); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module checker |
||||
|
|
||||
|
[NewFile] (T=false) -> (T'=false); |
||||
|
[NewFile] (T=false) -> (T'=true); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module channelK |
||||
|
|
||||
|
k : [0..2]; |
||||
|
|
||||
|
// idle |
||||
|
[aF] (k=0) -> pK : (k'=1) + 1-pK : (k'=2); |
||||
|
// sending |
||||
|
[aG] (k=1) -> (k'=0); |
||||
|
// lost |
||||
|
[TO_Msg] (k=2) -> (k'=0); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module channelL |
||||
|
|
||||
|
l : [0..2]; |
||||
|
|
||||
|
// idle |
||||
|
[aA] (l=0) -> pL : (l'=1) + 1-pL : (l'=2); |
||||
|
// sending |
||||
|
[aB] (l=1) -> (l'=0); |
||||
|
// lost |
||||
|
[TO_Ack] (l=2) -> (l'=0); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
|
@ -0,0 +1,139 @@ |
|||||
|
// bounded retransmission protocol [D'AJJL01] |
||||
|
// gxn/dxp 23/05/2001 |
||||
|
// Modified by Ernst Moritz Hahn (emh@cs.uni-sb.de) |
||||
|
|
||||
|
mdp |
||||
|
//dtmc |
||||
|
|
||||
|
// number of chunks |
||||
|
const int N = 64; |
||||
|
// maximum number of retransmissions |
||||
|
const int MAX = 4; |
||||
|
|
||||
|
// reliability of channels |
||||
|
const double pL; |
||||
|
const double pK; |
||||
|
|
||||
|
global T : bool; |
||||
|
|
||||
|
module sender |
||||
|
|
||||
|
s : [0..6]; |
||||
|
// 0 idle |
||||
|
// 1 next_frame |
||||
|
// 2 wait_ack |
||||
|
// 3 retransmit |
||||
|
// 4 success |
||||
|
// 5 error |
||||
|
// 6 wait sync |
||||
|
srep : [0..3]; |
||||
|
// 0 bottom |
||||
|
// 1 not ok (nok) |
||||
|
// 2 do not know (dk) |
||||
|
// 3 ok (ok) |
||||
|
nrtr : [0..MAX]; |
||||
|
i : [0..N]; |
||||
|
bs : bool; |
||||
|
s_ab : bool; |
||||
|
fs : bool; |
||||
|
ls : bool; |
||||
|
|
||||
|
// idle |
||||
|
[NewFile] (s=0) -> (s'=1) & (i'=1) & (srep'=0); |
||||
|
// next_frame |
||||
|
[aF] (s=1) -> (s'=2) & (fs'=(i=1)) & (ls'=(i=N)) & (bs'=s_ab) & (nrtr'=0); |
||||
|
// wait_ack |
||||
|
[aB] (s=2) -> (s'=4) & (s_ab'=!s_ab); |
||||
|
[TO_Msg] (s=2) -> (s'=3); |
||||
|
[TO_Ack] (s=2) -> (s'=3); |
||||
|
// retransmit |
||||
|
[aF] (s=3) & (nrtr<MAX) -> (s'=2) & (fs'=(i=1)) & (ls'=(i=N)) & (bs'=s_ab) & (nrtr'=nrtr+1); |
||||
|
[] (s=3) & (nrtr=MAX) & (i<N) -> (s'=5) & (srep'=1); |
||||
|
[] (s=3) & (nrtr=MAX) & (i=N) -> (s'=5) & (srep'=2); |
||||
|
// success |
||||
|
[] (s=4) & (i<N) -> (s'=1) & (i'=i+1); |
||||
|
[] (s=4) & (i=N) -> (s'=0) & (srep'=3); |
||||
|
// error |
||||
|
[SyncWait] (s=5) -> (s'=6); |
||||
|
// wait sync |
||||
|
[SyncWait] (s=6) -> (s'=0) & (s_ab'=false); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module receiver |
||||
|
|
||||
|
r : [0..5]; |
||||
|
// 0 new_file |
||||
|
// 1 fst_safe |
||||
|
// 2 frame_received |
||||
|
// 3 frame_reported |
||||
|
// 4 idle |
||||
|
// 5 resync |
||||
|
rrep : [0..4]; |
||||
|
// 0 bottom |
||||
|
// 1 fst |
||||
|
// 2 inc |
||||
|
// 3 ok |
||||
|
// 4 nok |
||||
|
fr : bool; |
||||
|
lr : bool; |
||||
|
br : bool; |
||||
|
r_ab : bool; |
||||
|
recv : bool; |
||||
|
|
||||
|
|
||||
|
// new_file |
||||
|
[SyncWait] (r=0) -> (r'=0); |
||||
|
[aG] (r=0) -> (r'=1) & (fr'=fs) & (lr'=ls) & (br'=bs) & (recv'=T); |
||||
|
// fst_safe_frame |
||||
|
[] (r=1) -> (r'=2) & (r_ab'=br); |
||||
|
// frame_received |
||||
|
[] (r=2) & (r_ab=br) & (fr=true) & (lr=false) -> (r'=3) & (rrep'=1); |
||||
|
[] (r=2) & (r_ab=br) & (fr=false) & (lr=false) -> (r'=3) & (rrep'=2); |
||||
|
[] (r=2) & (r_ab=br) & (fr=false) & (lr=true) -> (r'=3) & (rrep'=3); |
||||
|
[aA] (r=2) & !(r_ab=br) -> (r'=4); |
||||
|
// frame_reported |
||||
|
[aA] (r=3) -> (r'=4) & (r_ab'=!r_ab); |
||||
|
// idle |
||||
|
[aG] (r=4) -> (r'=2) & (fr'=fs) & (lr'=ls) & (br'=bs) & (recv'=T); |
||||
|
[SyncWait] (r=4) & (ls=true) -> (r'=5); |
||||
|
[SyncWait] (r=4) & (ls=false) -> (r'=5) & (rrep'=4); |
||||
|
// resync |
||||
|
[SyncWait] (r=5) -> (r'=0) & (rrep'=0); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module checker |
||||
|
|
||||
|
[NewFile] (T=false) -> (T'=false); |
||||
|
[NewFile] (T=false) -> (T'=true); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module channelK |
||||
|
|
||||
|
k : [0..2]; |
||||
|
|
||||
|
// idle |
||||
|
[aF] (k=0) -> pK : (k'=1) + 1-pK : (k'=2); |
||||
|
// sending |
||||
|
[aG] (k=1) -> (k'=0); |
||||
|
// lost |
||||
|
[TO_Msg] (k=2) -> (k'=0); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module channelL |
||||
|
|
||||
|
l : [0..2]; |
||||
|
|
||||
|
// idle |
||||
|
[aA] (l=0) -> pL : (l'=1) + 1-pL : (l'=2); |
||||
|
// sending |
||||
|
[aB] (l=1) -> (l'=0); |
||||
|
// lost |
||||
|
[TO_Ack] (l=2) -> (l'=0); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
|
@ -1,69 +0,0 @@ |
|||||
// COIN FLIPPING PROTOCOL FOR POLYNOMIAL RANDOMIZED CONSENSUS [AH90] |
|
||||
// gxn/dxp 20/11/00 |
|
||||
|
|
||||
mdp |
|
||||
|
|
||||
// constants |
|
||||
const int N=4; |
|
||||
const int K=2; |
|
||||
const int range = 2*(K+1)*N; |
|
||||
const int counter_init = (K+1)*N; |
|
||||
const int left = N; |
|
||||
const int right = 2*(K+1)*N - N; |
|
||||
|
|
||||
//Coin Probabilities |
|
||||
const double p1; |
|
||||
const double p2; |
|
||||
const double p3; |
|
||||
const double p4; |
|
||||
|
|
||||
// shared coin |
|
||||
global counter : [0..range] init counter_init; |
|
||||
|
|
||||
module process1 |
|
||||
|
|
||||
// program counter |
|
||||
pc1 : [0..3]; |
|
||||
// 0 - flip |
|
||||
// 1 - write |
|
||||
// 2 - check |
|
||||
// 3 - finished |
|
||||
|
|
||||
// local coin |
|
||||
coin1 : [0..1]; |
|
||||
|
|
||||
// flip coin |
|
||||
[] (pc1=0) -> p1 : (coin1'=0) & (pc1'=1) + 1-p1 : (coin1'=1) & (pc1'=1); |
|
||||
// write tails -1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=0) & (counter>0) -> 1 : (counter'=counter-1) & (pc1'=2) & (coin1'=0); |
|
||||
// write heads +1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=1) & (counter<range) -> 1 : (counter'=counter+1) & (pc1'=2) & (coin1'=0); |
|
||||
// check |
|
||||
// decide tails |
|
||||
[] (pc1=2) & (counter<=left) -> 1 : (pc1'=3) & (coin1'=0); |
|
||||
// decide heads |
|
||||
[] (pc1=2) & (counter>=right) -> 1 : (pc1'=3) & (coin1'=1); |
|
||||
// flip again |
|
||||
[] (pc1=2) & (counter>left) & (counter<right) -> 1 : (pc1'=0); |
|
||||
// loop (all loop together when done) |
|
||||
[done] (pc1=3) -> 1 : (pc1'=3); |
|
||||
|
|
||||
endmodule |
|
||||
|
|
||||
// construct remaining processes through renaming |
|
||||
module process2 = process1[pc1=pc2,coin1=coin2,p1=p2] endmodule |
|
||||
module process3 = process1[pc1=pc3,coin1=coin3,p1=p3] endmodule |
|
||||
module process4 = process1[pc1=pc4,coin1=coin4,p1=p4] endmodule |
|
||||
|
|
||||
// labels |
|
||||
label "finished" = pc1=3 & pc2=3 & pc3=3 & pc4=3 ; |
|
||||
label "all_coins_equal_0" = coin1=0 & coin2=0 & coin3=0 & coin4=0 ; |
|
||||
label "all_coins_equal_1" = coin1=1 & coin2=1 & coin3=1 & coin4=1 ; |
|
||||
label "agree" = coin1=coin2 & coin2=coin3 & coin3=coin4 ; |
|
||||
label "finish_with_1" = pc1=3 & pc2=3 & pc3=3 & pc4=3 & coin1=1 & coin2=1 & coin3=1 & coin4=1 ; |
|
||||
|
|
||||
// rewards |
|
||||
rewards "steps" |
|
||||
true : 1; |
|
||||
endrewards |
|
||||
|
|
@ -1,69 +0,0 @@ |
|||||
// COIN FLIPPING PROTOCOL FOR POLYNOMIAL RANDOMIZED CONSENSUS [AH90] |
|
||||
// gxn/dxp 20/11/00 |
|
||||
|
|
||||
mdp |
|
||||
|
|
||||
// constants |
|
||||
const int N=4; |
|
||||
const int K=8; |
|
||||
const int range = 2*(K+1)*N; |
|
||||
const int counter_init = (K+1)*N; |
|
||||
const int left = N; |
|
||||
const int right = 2*(K+1)*N - N; |
|
||||
|
|
||||
//Coin Probabilities |
|
||||
const double p1; |
|
||||
const double p2; |
|
||||
const double p3; |
|
||||
const double p4; |
|
||||
|
|
||||
// shared coin |
|
||||
global counter : [0..range] init counter_init; |
|
||||
|
|
||||
module process1 |
|
||||
|
|
||||
// program counter |
|
||||
pc1 : [0..3]; |
|
||||
// 0 - flip |
|
||||
// 1 - write |
|
||||
// 2 - check |
|
||||
// 3 - finished |
|
||||
|
|
||||
// local coin |
|
||||
coin1 : [0..1]; |
|
||||
|
|
||||
// flip coin |
|
||||
[] (pc1=0) -> p1 : (coin1'=0) & (pc1'=1) + 1-p1 : (coin1'=1) & (pc1'=1); |
|
||||
// write tails -1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=0) & (counter>0) -> 1 : (counter'=counter-1) & (pc1'=2) & (coin1'=0); |
|
||||
// write heads +1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=1) & (counter<range) -> 1 : (counter'=counter+1) & (pc1'=2) & (coin1'=0); |
|
||||
// check |
|
||||
// decide tails |
|
||||
[] (pc1=2) & (counter<=left) -> 1 : (pc1'=3) & (coin1'=0); |
|
||||
// decide heads |
|
||||
[] (pc1=2) & (counter>=right) -> 1 : (pc1'=3) & (coin1'=1); |
|
||||
// flip again |
|
||||
[] (pc1=2) & (counter>left) & (counter<right) -> 1 : (pc1'=0); |
|
||||
// loop (all loop together when done) |
|
||||
[done] (pc1=3) -> 1 : (pc1'=3); |
|
||||
|
|
||||
endmodule |
|
||||
|
|
||||
// construct remaining processes through renaming |
|
||||
module process2 = process1[pc1=pc2,coin1=coin2,p1=p2] endmodule |
|
||||
module process3 = process1[pc1=pc3,coin1=coin3,p1=p3] endmodule |
|
||||
module process4 = process1[pc1=pc4,coin1=coin4,p1=p4] endmodule |
|
||||
|
|
||||
// labels |
|
||||
label "finished" = pc1=3 & pc2=3 & pc3=3 & pc4=3 ; |
|
||||
label "all_coins_equal_0" = coin1=0 & coin2=0 & coin3=0 & coin4=0 ; |
|
||||
label "all_coins_equal_1" = coin1=1 & coin2=1 & coin3=1 & coin4=1 ; |
|
||||
label "agree" = coin1=coin2 & coin2=coin3 & coin3=coin4 ; |
|
||||
label "finish_with_1" = pc1=3 & pc2=3 & pc3=3 & pc4=3 & coin1=1 & coin2=1 & coin3=1 & coin4=1 ; |
|
||||
|
|
||||
// rewards |
|
||||
rewards "steps" |
|
||||
true : 1; |
|
||||
endrewards |
|
||||
|
|
@ -0,0 +1,4 @@ |
|||||
|
P>=0.25 [ F "finished"&"all_coins_equal_1" ] |
||||
|
|
||||
|
|
||||
|
|
@ -0,0 +1,400 @@ |
|||||
|
0.000010<=p1<=0.050000, 0.000010<=p2<=0.050000; |
||||
|
0.000010<=p1<=0.050000, 0.050000<=p2<=0.100000; |
||||
|
0.000010<=p1<=0.050000, 0.100000<=p2<=0.150000; |
||||
|
0.000010<=p1<=0.050000, 0.150000<=p2<=0.200000; |
||||
|
0.000010<=p1<=0.050000, 0.200000<=p2<=0.250000; |
||||
|
0.000010<=p1<=0.050000, 0.250000<=p2<=0.300000; |
||||
|
0.000010<=p1<=0.050000, 0.300000<=p2<=0.350000; |
||||
|
0.000010<=p1<=0.050000, 0.350000<=p2<=0.400000; |
||||
|
0.000010<=p1<=0.050000, 0.400000<=p2<=0.450000; |
||||
|
0.000010<=p1<=0.050000, 0.450000<=p2<=0.500000; |
||||
|
0.000010<=p1<=0.050000, 0.500000<=p2<=0.550000; |
||||
|
0.000010<=p1<=0.050000, 0.550000<=p2<=0.600000; |
||||
|
0.000010<=p1<=0.050000, 0.600000<=p2<=0.650000; |
||||
|
0.000010<=p1<=0.050000, 0.650000<=p2<=0.700000; |
||||
|
0.000010<=p1<=0.050000, 0.700000<=p2<=0.750000; |
||||
|
0.000010<=p1<=0.050000, 0.750000<=p2<=0.800000; |
||||
|
0.000010<=p1<=0.050000, 0.800000<=p2<=0.850000; |
||||
|
0.000010<=p1<=0.050000, 0.850000<=p2<=0.900000; |
||||
|
0.000010<=p1<=0.050000, 0.900000<=p2<=0.950000; |
||||
|
0.000010<=p1<=0.050000, 0.950000<=p2<=0.999990; |
||||
|
0.050000<=p1<=0.100000, 0.000010<=p2<=0.050000; |
||||
|
0.050000<=p1<=0.100000, 0.050000<=p2<=0.100000; |
||||
|
0.050000<=p1<=0.100000, 0.100000<=p2<=0.150000; |
||||
|
0.050000<=p1<=0.100000, 0.150000<=p2<=0.200000; |
||||
|
0.050000<=p1<=0.100000, 0.200000<=p2<=0.250000; |
||||
|
0.050000<=p1<=0.100000, 0.250000<=p2<=0.300000; |
||||
|
0.050000<=p1<=0.100000, 0.300000<=p2<=0.350000; |
||||
|
0.050000<=p1<=0.100000, 0.350000<=p2<=0.400000; |
||||
|
0.050000<=p1<=0.100000, 0.400000<=p2<=0.450000; |
||||
|
0.050000<=p1<=0.100000, 0.450000<=p2<=0.500000; |
||||
|
0.050000<=p1<=0.100000, 0.500000<=p2<=0.550000; |
||||
|
0.050000<=p1<=0.100000, 0.550000<=p2<=0.600000; |
||||
|
0.050000<=p1<=0.100000, 0.600000<=p2<=0.650000; |
||||
|
0.050000<=p1<=0.100000, 0.650000<=p2<=0.700000; |
||||
|
0.050000<=p1<=0.100000, 0.700000<=p2<=0.750000; |
||||
|
0.050000<=p1<=0.100000, 0.750000<=p2<=0.800000; |
||||
|
0.050000<=p1<=0.100000, 0.800000<=p2<=0.850000; |
||||
|
0.050000<=p1<=0.100000, 0.850000<=p2<=0.900000; |
||||
|
0.050000<=p1<=0.100000, 0.900000<=p2<=0.950000; |
||||
|
0.050000<=p1<=0.100000, 0.950000<=p2<=0.999990; |
||||
|
0.100000<=p1<=0.150000, 0.000010<=p2<=0.050000; |
||||
|
0.100000<=p1<=0.150000, 0.050000<=p2<=0.100000; |
||||
|
0.100000<=p1<=0.150000, 0.100000<=p2<=0.150000; |
||||
|
0.100000<=p1<=0.150000, 0.150000<=p2<=0.200000; |
||||
|
0.100000<=p1<=0.150000, 0.200000<=p2<=0.250000; |
||||
|
0.100000<=p1<=0.150000, 0.250000<=p2<=0.300000; |
||||
|
0.100000<=p1<=0.150000, 0.300000<=p2<=0.350000; |
||||
|
0.100000<=p1<=0.150000, 0.350000<=p2<=0.400000; |
||||
|
0.100000<=p1<=0.150000, 0.400000<=p2<=0.450000; |
||||
|
0.100000<=p1<=0.150000, 0.450000<=p2<=0.500000; |
||||
|
0.100000<=p1<=0.150000, 0.500000<=p2<=0.550000; |
||||
|
0.100000<=p1<=0.150000, 0.550000<=p2<=0.600000; |
||||
|
0.100000<=p1<=0.150000, 0.600000<=p2<=0.650000; |
||||
|
0.100000<=p1<=0.150000, 0.650000<=p2<=0.700000; |
||||
|
0.100000<=p1<=0.150000, 0.700000<=p2<=0.750000; |
||||
|
0.100000<=p1<=0.150000, 0.750000<=p2<=0.800000; |
||||
|
0.100000<=p1<=0.150000, 0.800000<=p2<=0.850000; |
||||
|
0.100000<=p1<=0.150000, 0.850000<=p2<=0.900000; |
||||
|
0.100000<=p1<=0.150000, 0.900000<=p2<=0.950000; |
||||
|
0.100000<=p1<=0.150000, 0.950000<=p2<=0.999990; |
||||
|
0.150000<=p1<=0.200000, 0.000010<=p2<=0.050000; |
||||
|
0.150000<=p1<=0.200000, 0.050000<=p2<=0.100000; |
||||
|
0.150000<=p1<=0.200000, 0.100000<=p2<=0.150000; |
||||
|
0.150000<=p1<=0.200000, 0.150000<=p2<=0.200000; |
||||
|
0.150000<=p1<=0.200000, 0.200000<=p2<=0.250000; |
||||
|
0.150000<=p1<=0.200000, 0.250000<=p2<=0.300000; |
||||
|
0.150000<=p1<=0.200000, 0.300000<=p2<=0.350000; |
||||
|
0.150000<=p1<=0.200000, 0.350000<=p2<=0.400000; |
||||
|
0.150000<=p1<=0.200000, 0.400000<=p2<=0.450000; |
||||
|
0.150000<=p1<=0.200000, 0.450000<=p2<=0.500000; |
||||
|
0.150000<=p1<=0.200000, 0.500000<=p2<=0.550000; |
||||
|
0.150000<=p1<=0.200000, 0.550000<=p2<=0.600000; |
||||
|
0.150000<=p1<=0.200000, 0.600000<=p2<=0.650000; |
||||
|
0.150000<=p1<=0.200000, 0.650000<=p2<=0.700000; |
||||
|
0.150000<=p1<=0.200000, 0.700000<=p2<=0.750000; |
||||
|
0.150000<=p1<=0.200000, 0.750000<=p2<=0.800000; |
||||
|
0.150000<=p1<=0.200000, 0.800000<=p2<=0.850000; |
||||
|
0.150000<=p1<=0.200000, 0.850000<=p2<=0.900000; |
||||
|
0.150000<=p1<=0.200000, 0.900000<=p2<=0.950000; |
||||
|
0.150000<=p1<=0.200000, 0.950000<=p2<=0.999990; |
||||
|
0.200000<=p1<=0.250000, 0.000010<=p2<=0.050000; |
||||
|
0.200000<=p1<=0.250000, 0.050000<=p2<=0.100000; |
||||
|
0.200000<=p1<=0.250000, 0.100000<=p2<=0.150000; |
||||
|
0.200000<=p1<=0.250000, 0.150000<=p2<=0.200000; |
||||
|
0.200000<=p1<=0.250000, 0.200000<=p2<=0.250000; |
||||
|
0.200000<=p1<=0.250000, 0.250000<=p2<=0.300000; |
||||
|
0.200000<=p1<=0.250000, 0.300000<=p2<=0.350000; |
||||
|
0.200000<=p1<=0.250000, 0.350000<=p2<=0.400000; |
||||
|
0.200000<=p1<=0.250000, 0.400000<=p2<=0.450000; |
||||
|
0.200000<=p1<=0.250000, 0.450000<=p2<=0.500000; |
||||
|
0.200000<=p1<=0.250000, 0.500000<=p2<=0.550000; |
||||
|
0.200000<=p1<=0.250000, 0.550000<=p2<=0.600000; |
||||
|
0.200000<=p1<=0.250000, 0.600000<=p2<=0.650000; |
||||
|
0.200000<=p1<=0.250000, 0.650000<=p2<=0.700000; |
||||
|
0.200000<=p1<=0.250000, 0.700000<=p2<=0.750000; |
||||
|
0.200000<=p1<=0.250000, 0.750000<=p2<=0.800000; |
||||
|
0.200000<=p1<=0.250000, 0.800000<=p2<=0.850000; |
||||
|
0.200000<=p1<=0.250000, 0.850000<=p2<=0.900000; |
||||
|
0.200000<=p1<=0.250000, 0.900000<=p2<=0.950000; |
||||
|
0.200000<=p1<=0.250000, 0.950000<=p2<=0.999990; |
||||
|
0.250000<=p1<=0.300000, 0.000010<=p2<=0.050000; |
||||
|
0.250000<=p1<=0.300000, 0.050000<=p2<=0.100000; |
||||
|
0.250000<=p1<=0.300000, 0.100000<=p2<=0.150000; |
||||
|
0.250000<=p1<=0.300000, 0.150000<=p2<=0.200000; |
||||
|
0.250000<=p1<=0.300000, 0.200000<=p2<=0.250000; |
||||
|
0.250000<=p1<=0.300000, 0.250000<=p2<=0.300000; |
||||
|
0.250000<=p1<=0.300000, 0.300000<=p2<=0.350000; |
||||
|
0.250000<=p1<=0.300000, 0.350000<=p2<=0.400000; |
||||
|
0.250000<=p1<=0.300000, 0.400000<=p2<=0.450000; |
||||
|
0.250000<=p1<=0.300000, 0.450000<=p2<=0.500000; |
||||
|
0.250000<=p1<=0.300000, 0.500000<=p2<=0.550000; |
||||
|
0.250000<=p1<=0.300000, 0.550000<=p2<=0.600000; |
||||
|
0.250000<=p1<=0.300000, 0.600000<=p2<=0.650000; |
||||
|
0.250000<=p1<=0.300000, 0.650000<=p2<=0.700000; |
||||
|
0.250000<=p1<=0.300000, 0.700000<=p2<=0.750000; |
||||
|
0.250000<=p1<=0.300000, 0.750000<=p2<=0.800000; |
||||
|
0.250000<=p1<=0.300000, 0.800000<=p2<=0.850000; |
||||
|
0.250000<=p1<=0.300000, 0.850000<=p2<=0.900000; |
||||
|
0.250000<=p1<=0.300000, 0.900000<=p2<=0.950000; |
||||
|
0.250000<=p1<=0.300000, 0.950000<=p2<=0.999990; |
||||
|
0.300000<=p1<=0.350000, 0.000010<=p2<=0.050000; |
||||
|
0.300000<=p1<=0.350000, 0.050000<=p2<=0.100000; |
||||
|
0.300000<=p1<=0.350000, 0.100000<=p2<=0.150000; |
||||
|
0.300000<=p1<=0.350000, 0.150000<=p2<=0.200000; |
||||
|
0.300000<=p1<=0.350000, 0.200000<=p2<=0.250000; |
||||
|
0.300000<=p1<=0.350000, 0.250000<=p2<=0.300000; |
||||
|
0.300000<=p1<=0.350000, 0.300000<=p2<=0.350000; |
||||
|
0.300000<=p1<=0.350000, 0.350000<=p2<=0.400000; |
||||
|
0.300000<=p1<=0.350000, 0.400000<=p2<=0.450000; |
||||
|
0.300000<=p1<=0.350000, 0.450000<=p2<=0.500000; |
||||
|
0.300000<=p1<=0.350000, 0.500000<=p2<=0.550000; |
||||
|
0.300000<=p1<=0.350000, 0.550000<=p2<=0.600000; |
||||
|
0.300000<=p1<=0.350000, 0.600000<=p2<=0.650000; |
||||
|
0.300000<=p1<=0.350000, 0.650000<=p2<=0.700000; |
||||
|
0.300000<=p1<=0.350000, 0.700000<=p2<=0.750000; |
||||
|
0.300000<=p1<=0.350000, 0.750000<=p2<=0.800000; |
||||
|
0.300000<=p1<=0.350000, 0.800000<=p2<=0.850000; |
||||
|
0.300000<=p1<=0.350000, 0.850000<=p2<=0.900000; |
||||
|
0.300000<=p1<=0.350000, 0.900000<=p2<=0.950000; |
||||
|
0.300000<=p1<=0.350000, 0.950000<=p2<=0.999990; |
||||
|
0.350000<=p1<=0.400000, 0.000010<=p2<=0.050000; |
||||
|
0.350000<=p1<=0.400000, 0.050000<=p2<=0.100000; |
||||
|
0.350000<=p1<=0.400000, 0.100000<=p2<=0.150000; |
||||
|
0.350000<=p1<=0.400000, 0.150000<=p2<=0.200000; |
||||
|
0.350000<=p1<=0.400000, 0.200000<=p2<=0.250000; |
||||
|
0.350000<=p1<=0.400000, 0.250000<=p2<=0.300000; |
||||
|
0.350000<=p1<=0.400000, 0.300000<=p2<=0.350000; |
||||
|
0.350000<=p1<=0.400000, 0.350000<=p2<=0.400000; |
||||
|
0.350000<=p1<=0.400000, 0.400000<=p2<=0.450000; |
||||
|
0.350000<=p1<=0.400000, 0.450000<=p2<=0.500000; |
||||
|
0.350000<=p1<=0.400000, 0.500000<=p2<=0.550000; |
||||
|
0.350000<=p1<=0.400000, 0.550000<=p2<=0.600000; |
||||
|
0.350000<=p1<=0.400000, 0.600000<=p2<=0.650000; |
||||
|
0.350000<=p1<=0.400000, 0.650000<=p2<=0.700000; |
||||
|
0.350000<=p1<=0.400000, 0.700000<=p2<=0.750000; |
||||
|
0.350000<=p1<=0.400000, 0.750000<=p2<=0.800000; |
||||
|
0.350000<=p1<=0.400000, 0.800000<=p2<=0.850000; |
||||
|
0.350000<=p1<=0.400000, 0.850000<=p2<=0.900000; |
||||
|
0.350000<=p1<=0.400000, 0.900000<=p2<=0.950000; |
||||
|
0.350000<=p1<=0.400000, 0.950000<=p2<=0.999990; |
||||
|
0.400000<=p1<=0.450000, 0.000010<=p2<=0.050000; |
||||
|
0.400000<=p1<=0.450000, 0.050000<=p2<=0.100000; |
||||
|
0.400000<=p1<=0.450000, 0.100000<=p2<=0.150000; |
||||
|
0.400000<=p1<=0.450000, 0.150000<=p2<=0.200000; |
||||
|
0.400000<=p1<=0.450000, 0.200000<=p2<=0.250000; |
||||
|
0.400000<=p1<=0.450000, 0.250000<=p2<=0.300000; |
||||
|
0.400000<=p1<=0.450000, 0.300000<=p2<=0.350000; |
||||
|
0.400000<=p1<=0.450000, 0.350000<=p2<=0.400000; |
||||
|
0.400000<=p1<=0.450000, 0.400000<=p2<=0.450000; |
||||
|
0.400000<=p1<=0.450000, 0.450000<=p2<=0.500000; |
||||
|
0.400000<=p1<=0.450000, 0.500000<=p2<=0.550000; |
||||
|
0.400000<=p1<=0.450000, 0.550000<=p2<=0.600000; |
||||
|
0.400000<=p1<=0.450000, 0.600000<=p2<=0.650000; |
||||
|
0.400000<=p1<=0.450000, 0.650000<=p2<=0.700000; |
||||
|
0.400000<=p1<=0.450000, 0.700000<=p2<=0.750000; |
||||
|
0.400000<=p1<=0.450000, 0.750000<=p2<=0.800000; |
||||
|
0.400000<=p1<=0.450000, 0.800000<=p2<=0.850000; |
||||
|
0.400000<=p1<=0.450000, 0.850000<=p2<=0.900000; |
||||
|
0.400000<=p1<=0.450000, 0.900000<=p2<=0.950000; |
||||
|
0.400000<=p1<=0.450000, 0.950000<=p2<=0.999990; |
||||
|
0.450000<=p1<=0.500000, 0.000010<=p2<=0.050000; |
||||
|
0.450000<=p1<=0.500000, 0.050000<=p2<=0.100000; |
||||
|
0.450000<=p1<=0.500000, 0.100000<=p2<=0.150000; |
||||
|
0.450000<=p1<=0.500000, 0.150000<=p2<=0.200000; |
||||
|
0.450000<=p1<=0.500000, 0.200000<=p2<=0.250000; |
||||
|
0.450000<=p1<=0.500000, 0.250000<=p2<=0.300000; |
||||
|
0.450000<=p1<=0.500000, 0.300000<=p2<=0.350000; |
||||
|
0.450000<=p1<=0.500000, 0.350000<=p2<=0.400000; |
||||
|
0.450000<=p1<=0.500000, 0.400000<=p2<=0.450000; |
||||
|
0.450000<=p1<=0.500000, 0.450000<=p2<=0.500000; |
||||
|
0.450000<=p1<=0.500000, 0.500000<=p2<=0.550000; |
||||
|
0.450000<=p1<=0.500000, 0.550000<=p2<=0.600000; |
||||
|
0.450000<=p1<=0.500000, 0.600000<=p2<=0.650000; |
||||
|
0.450000<=p1<=0.500000, 0.650000<=p2<=0.700000; |
||||
|
0.450000<=p1<=0.500000, 0.700000<=p2<=0.750000; |
||||
|
0.450000<=p1<=0.500000, 0.750000<=p2<=0.800000; |
||||
|
0.450000<=p1<=0.500000, 0.800000<=p2<=0.850000; |
||||
|
0.450000<=p1<=0.500000, 0.850000<=p2<=0.900000; |
||||
|
0.450000<=p1<=0.500000, 0.900000<=p2<=0.950000; |
||||
|
0.450000<=p1<=0.500000, 0.950000<=p2<=0.999990; |
||||
|
0.500000<=p1<=0.550000, 0.000010<=p2<=0.050000; |
||||
|
0.500000<=p1<=0.550000, 0.050000<=p2<=0.100000; |
||||
|
0.500000<=p1<=0.550000, 0.100000<=p2<=0.150000; |
||||
|
0.500000<=p1<=0.550000, 0.150000<=p2<=0.200000; |
||||
|
0.500000<=p1<=0.550000, 0.200000<=p2<=0.250000; |
||||
|
0.500000<=p1<=0.550000, 0.250000<=p2<=0.300000; |
||||
|
0.500000<=p1<=0.550000, 0.300000<=p2<=0.350000; |
||||
|
0.500000<=p1<=0.550000, 0.350000<=p2<=0.400000; |
||||
|
0.500000<=p1<=0.550000, 0.400000<=p2<=0.450000; |
||||
|
0.500000<=p1<=0.550000, 0.450000<=p2<=0.500000; |
||||
|
0.500000<=p1<=0.550000, 0.500000<=p2<=0.550000; |
||||
|
0.500000<=p1<=0.550000, 0.550000<=p2<=0.600000; |
||||
|
0.500000<=p1<=0.550000, 0.600000<=p2<=0.650000; |
||||
|
0.500000<=p1<=0.550000, 0.650000<=p2<=0.700000; |
||||
|
0.500000<=p1<=0.550000, 0.700000<=p2<=0.750000; |
||||
|
0.500000<=p1<=0.550000, 0.750000<=p2<=0.800000; |
||||
|
0.500000<=p1<=0.550000, 0.800000<=p2<=0.850000; |
||||
|
0.500000<=p1<=0.550000, 0.850000<=p2<=0.900000; |
||||
|
0.500000<=p1<=0.550000, 0.900000<=p2<=0.950000; |
||||
|
0.500000<=p1<=0.550000, 0.950000<=p2<=0.999990; |
||||
|
0.550000<=p1<=0.600000, 0.000010<=p2<=0.050000; |
||||
|
0.550000<=p1<=0.600000, 0.050000<=p2<=0.100000; |
||||
|
0.550000<=p1<=0.600000, 0.100000<=p2<=0.150000; |
||||
|
0.550000<=p1<=0.600000, 0.150000<=p2<=0.200000; |
||||
|
0.550000<=p1<=0.600000, 0.200000<=p2<=0.250000; |
||||
|
0.550000<=p1<=0.600000, 0.250000<=p2<=0.300000; |
||||
|
0.550000<=p1<=0.600000, 0.300000<=p2<=0.350000; |
||||
|
0.550000<=p1<=0.600000, 0.350000<=p2<=0.400000; |
||||
|
0.550000<=p1<=0.600000, 0.400000<=p2<=0.450000; |
||||
|
0.550000<=p1<=0.600000, 0.450000<=p2<=0.500000; |
||||
|
0.550000<=p1<=0.600000, 0.500000<=p2<=0.550000; |
||||
|
0.550000<=p1<=0.600000, 0.550000<=p2<=0.600000; |
||||
|
0.550000<=p1<=0.600000, 0.600000<=p2<=0.650000; |
||||
|
0.550000<=p1<=0.600000, 0.650000<=p2<=0.700000; |
||||
|
0.550000<=p1<=0.600000, 0.700000<=p2<=0.750000; |
||||
|
0.550000<=p1<=0.600000, 0.750000<=p2<=0.800000; |
||||
|
0.550000<=p1<=0.600000, 0.800000<=p2<=0.850000; |
||||
|
0.550000<=p1<=0.600000, 0.850000<=p2<=0.900000; |
||||
|
0.550000<=p1<=0.600000, 0.900000<=p2<=0.950000; |
||||
|
0.550000<=p1<=0.600000, 0.950000<=p2<=0.999990; |
||||
|
0.600000<=p1<=0.650000, 0.000010<=p2<=0.050000; |
||||
|
0.600000<=p1<=0.650000, 0.050000<=p2<=0.100000; |
||||
|
0.600000<=p1<=0.650000, 0.100000<=p2<=0.150000; |
||||
|
0.600000<=p1<=0.650000, 0.150000<=p2<=0.200000; |
||||
|
0.600000<=p1<=0.650000, 0.200000<=p2<=0.250000; |
||||
|
0.600000<=p1<=0.650000, 0.250000<=p2<=0.300000; |
||||
|
0.600000<=p1<=0.650000, 0.300000<=p2<=0.350000; |
||||
|
0.600000<=p1<=0.650000, 0.350000<=p2<=0.400000; |
||||
|
0.600000<=p1<=0.650000, 0.400000<=p2<=0.450000; |
||||
|
0.600000<=p1<=0.650000, 0.450000<=p2<=0.500000; |
||||
|
0.600000<=p1<=0.650000, 0.500000<=p2<=0.550000; |
||||
|
0.600000<=p1<=0.650000, 0.550000<=p2<=0.600000; |
||||
|
0.600000<=p1<=0.650000, 0.600000<=p2<=0.650000; |
||||
|
0.600000<=p1<=0.650000, 0.650000<=p2<=0.700000; |
||||
|
0.600000<=p1<=0.650000, 0.700000<=p2<=0.750000; |
||||
|
0.600000<=p1<=0.650000, 0.750000<=p2<=0.800000; |
||||
|
0.600000<=p1<=0.650000, 0.800000<=p2<=0.850000; |
||||
|
0.600000<=p1<=0.650000, 0.850000<=p2<=0.900000; |
||||
|
0.600000<=p1<=0.650000, 0.900000<=p2<=0.950000; |
||||
|
0.600000<=p1<=0.650000, 0.950000<=p2<=0.999990; |
||||
|
0.650000<=p1<=0.700000, 0.000010<=p2<=0.050000; |
||||
|
0.650000<=p1<=0.700000, 0.050000<=p2<=0.100000; |
||||
|
0.650000<=p1<=0.700000, 0.100000<=p2<=0.150000; |
||||
|
0.650000<=p1<=0.700000, 0.150000<=p2<=0.200000; |
||||
|
0.650000<=p1<=0.700000, 0.200000<=p2<=0.250000; |
||||
|
0.650000<=p1<=0.700000, 0.250000<=p2<=0.300000; |
||||
|
0.650000<=p1<=0.700000, 0.300000<=p2<=0.350000; |
||||
|
0.650000<=p1<=0.700000, 0.350000<=p2<=0.400000; |
||||
|
0.650000<=p1<=0.700000, 0.400000<=p2<=0.450000; |
||||
|
0.650000<=p1<=0.700000, 0.450000<=p2<=0.500000; |
||||
|
0.650000<=p1<=0.700000, 0.500000<=p2<=0.550000; |
||||
|
0.650000<=p1<=0.700000, 0.550000<=p2<=0.600000; |
||||
|
0.650000<=p1<=0.700000, 0.600000<=p2<=0.650000; |
||||
|
0.650000<=p1<=0.700000, 0.650000<=p2<=0.700000; |
||||
|
0.650000<=p1<=0.700000, 0.700000<=p2<=0.750000; |
||||
|
0.650000<=p1<=0.700000, 0.750000<=p2<=0.800000; |
||||
|
0.650000<=p1<=0.700000, 0.800000<=p2<=0.850000; |
||||
|
0.650000<=p1<=0.700000, 0.850000<=p2<=0.900000; |
||||
|
0.650000<=p1<=0.700000, 0.900000<=p2<=0.950000; |
||||
|
0.650000<=p1<=0.700000, 0.950000<=p2<=0.999990; |
||||
|
0.700000<=p1<=0.750000, 0.000010<=p2<=0.050000; |
||||
|
0.700000<=p1<=0.750000, 0.050000<=p2<=0.100000; |
||||
|
0.700000<=p1<=0.750000, 0.100000<=p2<=0.150000; |
||||
|
0.700000<=p1<=0.750000, 0.150000<=p2<=0.200000; |
||||
|
0.700000<=p1<=0.750000, 0.200000<=p2<=0.250000; |
||||
|
0.700000<=p1<=0.750000, 0.250000<=p2<=0.300000; |
||||
|
0.700000<=p1<=0.750000, 0.300000<=p2<=0.350000; |
||||
|
0.700000<=p1<=0.750000, 0.350000<=p2<=0.400000; |
||||
|
0.700000<=p1<=0.750000, 0.400000<=p2<=0.450000; |
||||
|
0.700000<=p1<=0.750000, 0.450000<=p2<=0.500000; |
||||
|
0.700000<=p1<=0.750000, 0.500000<=p2<=0.550000; |
||||
|
0.700000<=p1<=0.750000, 0.550000<=p2<=0.600000; |
||||
|
0.700000<=p1<=0.750000, 0.600000<=p2<=0.650000; |
||||
|
0.700000<=p1<=0.750000, 0.650000<=p2<=0.700000; |
||||
|
0.700000<=p1<=0.750000, 0.700000<=p2<=0.750000; |
||||
|
0.700000<=p1<=0.750000, 0.750000<=p2<=0.800000; |
||||
|
0.700000<=p1<=0.750000, 0.800000<=p2<=0.850000; |
||||
|
0.700000<=p1<=0.750000, 0.850000<=p2<=0.900000; |
||||
|
0.700000<=p1<=0.750000, 0.900000<=p2<=0.950000; |
||||
|
0.700000<=p1<=0.750000, 0.950000<=p2<=0.999990; |
||||
|
0.750000<=p1<=0.800000, 0.000010<=p2<=0.050000; |
||||
|
0.750000<=p1<=0.800000, 0.050000<=p2<=0.100000; |
||||
|
0.750000<=p1<=0.800000, 0.100000<=p2<=0.150000; |
||||
|
0.750000<=p1<=0.800000, 0.150000<=p2<=0.200000; |
||||
|
0.750000<=p1<=0.800000, 0.200000<=p2<=0.250000; |
||||
|
0.750000<=p1<=0.800000, 0.250000<=p2<=0.300000; |
||||
|
0.750000<=p1<=0.800000, 0.300000<=p2<=0.350000; |
||||
|
0.750000<=p1<=0.800000, 0.350000<=p2<=0.400000; |
||||
|
0.750000<=p1<=0.800000, 0.400000<=p2<=0.450000; |
||||
|
0.750000<=p1<=0.800000, 0.450000<=p2<=0.500000; |
||||
|
0.750000<=p1<=0.800000, 0.500000<=p2<=0.550000; |
||||
|
0.750000<=p1<=0.800000, 0.550000<=p2<=0.600000; |
||||
|
0.750000<=p1<=0.800000, 0.600000<=p2<=0.650000; |
||||
|
0.750000<=p1<=0.800000, 0.650000<=p2<=0.700000; |
||||
|
0.750000<=p1<=0.800000, 0.700000<=p2<=0.750000; |
||||
|
0.750000<=p1<=0.800000, 0.750000<=p2<=0.800000; |
||||
|
0.750000<=p1<=0.800000, 0.800000<=p2<=0.850000; |
||||
|
0.750000<=p1<=0.800000, 0.850000<=p2<=0.900000; |
||||
|
0.750000<=p1<=0.800000, 0.900000<=p2<=0.950000; |
||||
|
0.750000<=p1<=0.800000, 0.950000<=p2<=0.999990; |
||||
|
0.800000<=p1<=0.850000, 0.000010<=p2<=0.050000; |
||||
|
0.800000<=p1<=0.850000, 0.050000<=p2<=0.100000; |
||||
|
0.800000<=p1<=0.850000, 0.100000<=p2<=0.150000; |
||||
|
0.800000<=p1<=0.850000, 0.150000<=p2<=0.200000; |
||||
|
0.800000<=p1<=0.850000, 0.200000<=p2<=0.250000; |
||||
|
0.800000<=p1<=0.850000, 0.250000<=p2<=0.300000; |
||||
|
0.800000<=p1<=0.850000, 0.300000<=p2<=0.350000; |
||||
|
0.800000<=p1<=0.850000, 0.350000<=p2<=0.400000; |
||||
|
0.800000<=p1<=0.850000, 0.400000<=p2<=0.450000; |
||||
|
0.800000<=p1<=0.850000, 0.450000<=p2<=0.500000; |
||||
|
0.800000<=p1<=0.850000, 0.500000<=p2<=0.550000; |
||||
|
0.800000<=p1<=0.850000, 0.550000<=p2<=0.600000; |
||||
|
0.800000<=p1<=0.850000, 0.600000<=p2<=0.650000; |
||||
|
0.800000<=p1<=0.850000, 0.650000<=p2<=0.700000; |
||||
|
0.800000<=p1<=0.850000, 0.700000<=p2<=0.750000; |
||||
|
0.800000<=p1<=0.850000, 0.750000<=p2<=0.800000; |
||||
|
0.800000<=p1<=0.850000, 0.800000<=p2<=0.850000; |
||||
|
0.800000<=p1<=0.850000, 0.850000<=p2<=0.900000; |
||||
|
0.800000<=p1<=0.850000, 0.900000<=p2<=0.950000; |
||||
|
0.800000<=p1<=0.850000, 0.950000<=p2<=0.999990; |
||||
|
0.850000<=p1<=0.900000, 0.000010<=p2<=0.050000; |
||||
|
0.850000<=p1<=0.900000, 0.050000<=p2<=0.100000; |
||||
|
0.850000<=p1<=0.900000, 0.100000<=p2<=0.150000; |
||||
|
0.850000<=p1<=0.900000, 0.150000<=p2<=0.200000; |
||||
|
0.850000<=p1<=0.900000, 0.200000<=p2<=0.250000; |
||||
|
0.850000<=p1<=0.900000, 0.250000<=p2<=0.300000; |
||||
|
0.850000<=p1<=0.900000, 0.300000<=p2<=0.350000; |
||||
|
0.850000<=p1<=0.900000, 0.350000<=p2<=0.400000; |
||||
|
0.850000<=p1<=0.900000, 0.400000<=p2<=0.450000; |
||||
|
0.850000<=p1<=0.900000, 0.450000<=p2<=0.500000; |
||||
|
0.850000<=p1<=0.900000, 0.500000<=p2<=0.550000; |
||||
|
0.850000<=p1<=0.900000, 0.550000<=p2<=0.600000; |
||||
|
0.850000<=p1<=0.900000, 0.600000<=p2<=0.650000; |
||||
|
0.850000<=p1<=0.900000, 0.650000<=p2<=0.700000; |
||||
|
0.850000<=p1<=0.900000, 0.700000<=p2<=0.750000; |
||||
|
0.850000<=p1<=0.900000, 0.750000<=p2<=0.800000; |
||||
|
0.850000<=p1<=0.900000, 0.800000<=p2<=0.850000; |
||||
|
0.850000<=p1<=0.900000, 0.850000<=p2<=0.900000; |
||||
|
0.850000<=p1<=0.900000, 0.900000<=p2<=0.950000; |
||||
|
0.850000<=p1<=0.900000, 0.950000<=p2<=0.999990; |
||||
|
0.900000<=p1<=0.950000, 0.000010<=p2<=0.050000; |
||||
|
0.900000<=p1<=0.950000, 0.050000<=p2<=0.100000; |
||||
|
0.900000<=p1<=0.950000, 0.100000<=p2<=0.150000; |
||||
|
0.900000<=p1<=0.950000, 0.150000<=p2<=0.200000; |
||||
|
0.900000<=p1<=0.950000, 0.200000<=p2<=0.250000; |
||||
|
0.900000<=p1<=0.950000, 0.250000<=p2<=0.300000; |
||||
|
0.900000<=p1<=0.950000, 0.300000<=p2<=0.350000; |
||||
|
0.900000<=p1<=0.950000, 0.350000<=p2<=0.400000; |
||||
|
0.900000<=p1<=0.950000, 0.400000<=p2<=0.450000; |
||||
|
0.900000<=p1<=0.950000, 0.450000<=p2<=0.500000; |
||||
|
0.900000<=p1<=0.950000, 0.500000<=p2<=0.550000; |
||||
|
0.900000<=p1<=0.950000, 0.550000<=p2<=0.600000; |
||||
|
0.900000<=p1<=0.950000, 0.600000<=p2<=0.650000; |
||||
|
0.900000<=p1<=0.950000, 0.650000<=p2<=0.700000; |
||||
|
0.900000<=p1<=0.950000, 0.700000<=p2<=0.750000; |
||||
|
0.900000<=p1<=0.950000, 0.750000<=p2<=0.800000; |
||||
|
0.900000<=p1<=0.950000, 0.800000<=p2<=0.850000; |
||||
|
0.900000<=p1<=0.950000, 0.850000<=p2<=0.900000; |
||||
|
0.900000<=p1<=0.950000, 0.900000<=p2<=0.950000; |
||||
|
0.900000<=p1<=0.950000, 0.950000<=p2<=0.999990; |
||||
|
0.950000<=p1<=0.999990, 0.000010<=p2<=0.050000; |
||||
|
0.950000<=p1<=0.999990, 0.050000<=p2<=0.100000; |
||||
|
0.950000<=p1<=0.999990, 0.100000<=p2<=0.150000; |
||||
|
0.950000<=p1<=0.999990, 0.150000<=p2<=0.200000; |
||||
|
0.950000<=p1<=0.999990, 0.200000<=p2<=0.250000; |
||||
|
0.950000<=p1<=0.999990, 0.250000<=p2<=0.300000; |
||||
|
0.950000<=p1<=0.999990, 0.300000<=p2<=0.350000; |
||||
|
0.950000<=p1<=0.999990, 0.350000<=p2<=0.400000; |
||||
|
0.950000<=p1<=0.999990, 0.400000<=p2<=0.450000; |
||||
|
0.950000<=p1<=0.999990, 0.450000<=p2<=0.500000; |
||||
|
0.950000<=p1<=0.999990, 0.500000<=p2<=0.550000; |
||||
|
0.950000<=p1<=0.999990, 0.550000<=p2<=0.600000; |
||||
|
0.950000<=p1<=0.999990, 0.600000<=p2<=0.650000; |
||||
|
0.950000<=p1<=0.999990, 0.650000<=p2<=0.700000; |
||||
|
0.950000<=p1<=0.999990, 0.700000<=p2<=0.750000; |
||||
|
0.950000<=p1<=0.999990, 0.750000<=p2<=0.800000; |
||||
|
0.950000<=p1<=0.999990, 0.800000<=p2<=0.850000; |
||||
|
0.950000<=p1<=0.999990, 0.850000<=p2<=0.900000; |
||||
|
0.950000<=p1<=0.999990, 0.900000<=p2<=0.950000; |
||||
|
0.950000<=p1<=0.999990, 0.950000<=p2<=0.999990; |
@ -1,65 +0,0 @@ |
|||||
// COIN FLIPPING PROTOCOL FOR POLYNOMIAL RANDOMIZED CONSENSUS [AH90] |
|
||||
// gxn/dxp 20/11/00 |
|
||||
|
|
||||
mdp |
|
||||
|
|
||||
// constants |
|
||||
const int N=2; |
|
||||
const int K=1024; |
|
||||
const int range = 2*(K+1)*N; |
|
||||
const int counter_init = (K+1)*N; |
|
||||
const int left = N; |
|
||||
const int right = 2*(K+1)*N - N; |
|
||||
|
|
||||
//Coin Probabilities |
|
||||
const double p; |
|
||||
const double q; |
|
||||
|
|
||||
// shared coin |
|
||||
global counter : [0..range] init counter_init; |
|
||||
|
|
||||
module process1 |
|
||||
|
|
||||
// program counter |
|
||||
pc1 : [0..3]; |
|
||||
// 0 - flip |
|
||||
// 1 - write |
|
||||
// 2 - check |
|
||||
// 3 - finished |
|
||||
|
|
||||
// local coin |
|
||||
coin1 : [0..1]; |
|
||||
|
|
||||
// flip coin |
|
||||
[] (pc1=0) -> p : (coin1'=0) & (pc1'=1) + 1-p : (coin1'=1) & (pc1'=1); |
|
||||
// write tails -1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=0) & (counter>0) -> 1 : (counter'=counter-1) & (pc1'=2) & (coin1'=0); |
|
||||
// write heads +1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=1) & (counter<range) -> 1 : (counter'=counter+1) & (pc1'=2) & (coin1'=0); |
|
||||
// check |
|
||||
// decide tails |
|
||||
[] (pc1=2) & (counter<=left) -> 1 : (pc1'=3) & (coin1'=0); |
|
||||
// decide heads |
|
||||
[] (pc1=2) & (counter>=right) -> 1 : (pc1'=3) & (coin1'=1); |
|
||||
// flip again |
|
||||
[] (pc1=2) & (counter>left) & (counter<right) -> 1 : (pc1'=0); |
|
||||
// loop (all loop together when done) |
|
||||
[done] (pc1=3) -> 1 : (pc1'=3); |
|
||||
|
|
||||
endmodule |
|
||||
|
|
||||
// construct remaining processes through renaming |
|
||||
module process2 = process1[pc1=pc2,coin1=coin2,p=q] endmodule |
|
||||
|
|
||||
// labels |
|
||||
label "finished" = pc1=3 & pc2=3 ; |
|
||||
label "all_coins_equal_0" = coin1=0 & coin2=0 ; |
|
||||
label "all_coins_equal_1" = coin1=1 & coin2=1 ; |
|
||||
label "agree" = coin1=coin2 ; |
|
||||
label "finish_with_1" = pc1=3 & pc2=3 & coin1=1 & coin2=1 ; |
|
||||
|
|
||||
// rewards |
|
||||
rewards "steps" |
|
||||
true : 1; |
|
||||
endrewards |
|
||||
|
|
@ -0,0 +1,56 @@ |
|||||
|
//Randomised Consensus Protocol |
||||
|
|
||||
|
mdp |
||||
|
const double p1; // in [0.2 , 0.8] |
||||
|
const double p2; // in [0.2 , 0.8] |
||||
|
|
||||
|
|
||||
|
const int N=2; |
||||
|
const int K=128; |
||||
|
const int range = 2*(K+1)*N; |
||||
|
const int counter_init = (K+1)*N; |
||||
|
const int left = N; |
||||
|
const int right = 2*(K+1)*N - N; |
||||
|
|
||||
|
// shared coin |
||||
|
global counter : [0..range] init counter_init; |
||||
|
|
||||
|
module process1 |
||||
|
|
||||
|
// program counter |
||||
|
pc1 : [0..3]; |
||||
|
// 0 - flip |
||||
|
// 1 - write |
||||
|
// 2 - check |
||||
|
// 3 - finished |
||||
|
|
||||
|
// local coin |
||||
|
coin1 : [0..1]; |
||||
|
|
||||
|
// flip coin |
||||
|
[] (pc1=0) -> p1 : (coin1'=0) & (pc1'=1) + 1 - p1 : (coin1'=1) & (pc1'=1); |
||||
|
// write tails -1 (reset coin to add regularity) |
||||
|
[] (pc1=1) & (coin1=0) & (counter>0) -> (counter'=counter-1) & (pc1'=2) & (coin1'=0); |
||||
|
// write heads +1 (reset coin to add regularity) |
||||
|
[] (pc1=1) & (coin1=1) & (counter<range) -> (counter'=counter+1) & (pc1'=2) & (coin1'=0); |
||||
|
// check |
||||
|
// decide tails |
||||
|
[] (pc1=2) & (counter<=left) -> (pc1'=3) & (coin1'=0); |
||||
|
// decide heads |
||||
|
[] (pc1=2) & (counter>=right) -> (pc1'=3) & (coin1'=1); |
||||
|
// flip again |
||||
|
[] (pc1=2) & (counter>left) & (counter<right) -> (pc1'=0); |
||||
|
// loop (all loop together when done) |
||||
|
[done] (pc1=3) -> (pc1'=3); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module process2 = process1[pc1=pc2,coin1=coin2,p1=p2] endmodule |
||||
|
label "finished" = pc1=3 &pc2=3 ; |
||||
|
label "all_coins_equal_1" = coin1=1 &coin2=1 ; |
||||
|
rewards "steps" |
||||
|
true : 1; |
||||
|
endrewards |
||||
|
|
||||
|
|
||||
|
|
@ -0,0 +1,56 @@ |
|||||
|
//Randomised Consensus Protocol |
||||
|
|
||||
|
mdp |
||||
|
const double p1; // in [0.2 , 0.8] |
||||
|
const double p2; // in [0.2 , 0.8] |
||||
|
|
||||
|
|
||||
|
const int N=2; |
||||
|
const int K=4; |
||||
|
const int range = 2*(K+1)*N; |
||||
|
const int counter_init = (K+1)*N; |
||||
|
const int left = N; |
||||
|
const int right = 2*(K+1)*N - N; |
||||
|
|
||||
|
// shared coin |
||||
|
global counter : [0..range] init counter_init; |
||||
|
|
||||
|
module process1 |
||||
|
|
||||
|
// program counter |
||||
|
pc1 : [0..3]; |
||||
|
// 0 - flip |
||||
|
// 1 - write |
||||
|
// 2 - check |
||||
|
// 3 - finished |
||||
|
|
||||
|
// local coin |
||||
|
coin1 : [0..1]; |
||||
|
|
||||
|
// flip coin |
||||
|
[] (pc1=0) -> p1 : (coin1'=0) & (pc1'=1) + 1 - p1 : (coin1'=1) & (pc1'=1); |
||||
|
// write tails -1 (reset coin to add regularity) |
||||
|
[] (pc1=1) & (coin1=0) & (counter>0) -> (counter'=counter-1) & (pc1'=2) & (coin1'=0); |
||||
|
// write heads +1 (reset coin to add regularity) |
||||
|
[] (pc1=1) & (coin1=1) & (counter<range) -> (counter'=counter+1) & (pc1'=2) & (coin1'=0); |
||||
|
// check |
||||
|
// decide tails |
||||
|
[] (pc1=2) & (counter<=left) -> (pc1'=3) & (coin1'=0); |
||||
|
// decide heads |
||||
|
[] (pc1=2) & (counter>=right) -> (pc1'=3) & (coin1'=1); |
||||
|
// flip again |
||||
|
[] (pc1=2) & (counter>left) & (counter<right) -> (pc1'=0); |
||||
|
// loop (all loop together when done) |
||||
|
[done] (pc1=3) -> (pc1'=3); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module process2 = process1[pc1=pc2,coin1=coin2,p1=p2] endmodule |
||||
|
label "finished" = pc1=3 &pc2=3 ; |
||||
|
label "all_coins_equal_1" = coin1=1 &coin2=1 ; |
||||
|
rewards "steps" |
||||
|
true : 1; |
||||
|
endrewards |
||||
|
|
||||
|
|
||||
|
|
@ -0,0 +1,56 @@ |
|||||
|
//Randomised Consensus Protocol |
||||
|
|
||||
|
mdp |
||||
|
const double p1; // in [0.2 , 0.8] |
||||
|
const double p2; // in [0.2 , 0.8] |
||||
|
|
||||
|
|
||||
|
const int N=2; |
||||
|
const int K=7; |
||||
|
const int range = 2*(K+1)*N; |
||||
|
const int counter_init = (K+1)*N; |
||||
|
const int left = N; |
||||
|
const int right = 2*(K+1)*N - N; |
||||
|
|
||||
|
// shared coin |
||||
|
global counter : [0..range] init counter_init; |
||||
|
|
||||
|
module process1 |
||||
|
|
||||
|
// program counter |
||||
|
pc1 : [0..3]; |
||||
|
// 0 - flip |
||||
|
// 1 - write |
||||
|
// 2 - check |
||||
|
// 3 - finished |
||||
|
|
||||
|
// local coin |
||||
|
coin1 : [0..1]; |
||||
|
|
||||
|
// flip coin |
||||
|
[] (pc1=0) -> p1 : (coin1'=0) & (pc1'=1) + 1 - p1 : (coin1'=1) & (pc1'=1); |
||||
|
// write tails -1 (reset coin to add regularity) |
||||
|
[] (pc1=1) & (coin1=0) & (counter>0) -> (counter'=counter-1) & (pc1'=2) & (coin1'=0); |
||||
|
// write heads +1 (reset coin to add regularity) |
||||
|
[] (pc1=1) & (coin1=1) & (counter<range) -> (counter'=counter+1) & (pc1'=2) & (coin1'=0); |
||||
|
// check |
||||
|
// decide tails |
||||
|
[] (pc1=2) & (counter<=left) -> (pc1'=3) & (coin1'=0); |
||||
|
// decide heads |
||||
|
[] (pc1=2) & (counter>=right) -> (pc1'=3) & (coin1'=1); |
||||
|
// flip again |
||||
|
[] (pc1=2) & (counter>left) & (counter<right) -> (pc1'=0); |
||||
|
// loop (all loop together when done) |
||||
|
[done] (pc1=3) -> (pc1'=3); |
||||
|
|
||||
|
endmodule |
||||
|
|
||||
|
module process2 = process1[pc1=pc2,coin1=coin2,p1=p2] endmodule |
||||
|
label "finished" = pc1=3 &pc2=3 ; |
||||
|
label "all_coins_equal_1" = coin1=1 &coin2=1 ; |
||||
|
rewards "steps" |
||||
|
true : 1; |
||||
|
endrewards |
||||
|
|
||||
|
|
||||
|
|
@ -1,67 +0,0 @@ |
|||||
// COIN FLIPPING PROTOCOL FOR POLYNOMIAL RANDOMIZED CONSENSUS [AH90] |
|
||||
// gxn/dxp 20/11/00 |
|
||||
|
|
||||
mdp |
|
||||
|
|
||||
// constants |
|
||||
const int N=4; |
|
||||
const int K=2; |
|
||||
const int range = 2*(K+1)*N; |
|
||||
const int counter_init = (K+1)*N; |
|
||||
const int left = N; |
|
||||
const int right = 2*(K+1)*N - N; |
|
||||
|
|
||||
//Coin Probabilities |
|
||||
const double p; |
|
||||
const double q; |
|
||||
|
|
||||
// shared coin |
|
||||
global counter : [0..range] init counter_init; |
|
||||
|
|
||||
module process1 |
|
||||
|
|
||||
// program counter |
|
||||
pc1 : [0..3]; |
|
||||
// 0 - flip |
|
||||
// 1 - write |
|
||||
// 2 - check |
|
||||
// 3 - finished |
|
||||
|
|
||||
// local coin |
|
||||
coin1 : [0..1]; |
|
||||
|
|
||||
// flip coin |
|
||||
[] (pc1=0) -> p : (coin1'=0) & (pc1'=1) + 1-p : (coin1'=1) & (pc1'=1); |
|
||||
// write tails -1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=0) & (counter>0) -> 1 : (counter'=counter-1) & (pc1'=2) & (coin1'=0); |
|
||||
// write heads +1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=1) & (counter<range) -> 1 : (counter'=counter+1) & (pc1'=2) & (coin1'=0); |
|
||||
// check |
|
||||
// decide tails |
|
||||
[] (pc1=2) & (counter<=left) -> 1 : (pc1'=3) & (coin1'=0); |
|
||||
// decide heads |
|
||||
[] (pc1=2) & (counter>=right) -> 1 : (pc1'=3) & (coin1'=1); |
|
||||
// flip again |
|
||||
[] (pc1=2) & (counter>left) & (counter<right) -> 1 : (pc1'=0); |
|
||||
// loop (all loop together when done) |
|
||||
[done] (pc1=3) -> 1 : (pc1'=3); |
|
||||
|
|
||||
endmodule |
|
||||
|
|
||||
// construct remaining processes through renaming |
|
||||
module process2 = process1[pc1=pc2,coin1=coin2,p=q] endmodule |
|
||||
module process3 = process1[pc1=pc3,coin1=coin3] endmodule |
|
||||
module process4 = process1[pc1=pc4,coin1=coin4,p=q] endmodule |
|
||||
|
|
||||
// labels |
|
||||
label "finished" = pc1=3 & pc2=3 & pc3=3 & pc4=3 ; |
|
||||
label "all_coins_equal_0" = coin1=0 & coin2=0 & coin3=0 & coin4=0 ; |
|
||||
label "all_coins_equal_1" = coin1=1 & coin2=1 & coin3=1 & coin4=1 ; |
|
||||
label "agree" = coin1=coin2 & coin2=coin3 & coin3=coin4 ; |
|
||||
label "finish_with_1" = pc1=3 & pc2=3 & pc3=3 & pc4=3 & coin1=1 & coin2=1 & coin3=1 & coin4=1 ; |
|
||||
|
|
||||
// rewards |
|
||||
rewards "steps" |
|
||||
true : 1; |
|
||||
endrewards |
|
||||
|
|
@ -1,67 +0,0 @@ |
|||||
// COIN FLIPPING PROTOCOL FOR POLYNOMIAL RANDOMIZED CONSENSUS [AH90] |
|
||||
// gxn/dxp 20/11/00 |
|
||||
|
|
||||
mdp |
|
||||
|
|
||||
// constants |
|
||||
const int N=4; |
|
||||
const int K=8; |
|
||||
const int range = 2*(K+1)*N; |
|
||||
const int counter_init = (K+1)*N; |
|
||||
const int left = N; |
|
||||
const int right = 2*(K+1)*N - N; |
|
||||
|
|
||||
//Coin Probabilities |
|
||||
const double p; |
|
||||
const double q; |
|
||||
|
|
||||
// shared coin |
|
||||
global counter : [0..range] init counter_init; |
|
||||
|
|
||||
module process1 |
|
||||
|
|
||||
// program counter |
|
||||
pc1 : [0..3]; |
|
||||
// 0 - flip |
|
||||
// 1 - write |
|
||||
// 2 - check |
|
||||
// 3 - finished |
|
||||
|
|
||||
// local coin |
|
||||
coin1 : [0..1]; |
|
||||
|
|
||||
// flip coin |
|
||||
[] (pc1=0) -> p : (coin1'=0) & (pc1'=1) + 1-p : (coin1'=1) & (pc1'=1); |
|
||||
// write tails -1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=0) & (counter>0) -> 1 : (counter'=counter-1) & (pc1'=2) & (coin1'=0); |
|
||||
// write heads +1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=1) & (counter<range) -> 1 : (counter'=counter+1) & (pc1'=2) & (coin1'=0); |
|
||||
// check |
|
||||
// decide tails |
|
||||
[] (pc1=2) & (counter<=left) -> 1 : (pc1'=3) & (coin1'=0); |
|
||||
// decide heads |
|
||||
[] (pc1=2) & (counter>=right) -> 1 : (pc1'=3) & (coin1'=1); |
|
||||
// flip again |
|
||||
[] (pc1=2) & (counter>left) & (counter<right) -> 1 : (pc1'=0); |
|
||||
// loop (all loop together when done) |
|
||||
[done] (pc1=3) -> 1 : (pc1'=3); |
|
||||
|
|
||||
endmodule |
|
||||
|
|
||||
// construct remaining processes through renaming |
|
||||
module process2 = process1[pc1=pc2,coin1=coin2,p=q] endmodule |
|
||||
module process3 = process1[pc1=pc3,coin1=coin3] endmodule |
|
||||
module process4 = process1[pc1=pc4,coin1=coin4,p=q] endmodule |
|
||||
|
|
||||
// labels |
|
||||
label "finished" = pc1=3 & pc2=3 & pc3=3 & pc4=3 ; |
|
||||
label "all_coins_equal_0" = coin1=0 & coin2=0 & coin3=0 & coin4=0 ; |
|
||||
label "all_coins_equal_1" = coin1=1 & coin2=1 & coin3=1 & coin4=1 ; |
|
||||
label "agree" = coin1=coin2 & coin2=coin3 & coin3=coin4 ; |
|
||||
label "finish_with_1" = pc1=3 & pc2=3 & pc3=3 & pc4=3 & coin1=1 & coin2=1 & coin3=1 & coin4=1 ; |
|
||||
|
|
||||
// rewards |
|
||||
rewards "steps" |
|
||||
true : 1; |
|
||||
endrewards |
|
||||
|
|
@ -1,69 +0,0 @@ |
|||||
// COIN FLIPPING PROTOCOL FOR POLYNOMIAL RANDOMIZED CONSENSUS [AH90] |
|
||||
// gxn/dxp 20/11/00 |
|
||||
|
|
||||
mdp |
|
||||
|
|
||||
// constants |
|
||||
const int N=6; |
|
||||
const int K=2; |
|
||||
const int range = 2*(K+1)*N; |
|
||||
const int counter_init = (K+1)*N; |
|
||||
const int left = N; |
|
||||
const int right = 2*(K+1)*N - N; |
|
||||
|
|
||||
//Coin Probabilities |
|
||||
const double p; |
|
||||
const double q; |
|
||||
|
|
||||
// shared coin |
|
||||
global counter : [0..range] init counter_init; |
|
||||
|
|
||||
module process1 |
|
||||
|
|
||||
// program counter |
|
||||
pc1 : [0..3]; |
|
||||
// 0 - flip |
|
||||
// 1 - write |
|
||||
// 2 - check |
|
||||
// 3 - finished |
|
||||
|
|
||||
// local coin |
|
||||
coin1 : [0..1]; |
|
||||
|
|
||||
// flip coin |
|
||||
[] (pc1=0) -> p : (coin1'=0) & (pc1'=1) + 1-p : (coin1'=1) & (pc1'=1); |
|
||||
// write tails -1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=0) & (counter>0) -> (counter'=counter-1) & (pc1'=2) & (coin1'=0); |
|
||||
// write heads +1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=1) & (counter<range) -> (counter'=counter+1) & (pc1'=2) & (coin1'=0); |
|
||||
// check |
|
||||
// decide tails |
|
||||
[] (pc1=2) & (counter<=left) -> (pc1'=3) & (coin1'=0); |
|
||||
// decide heads |
|
||||
[] (pc1=2) & (counter>=right) -> (pc1'=3) & (coin1'=1); |
|
||||
// flip again |
|
||||
[] (pc1=2) & (counter>left) & (counter<right) -> (pc1'=0); |
|
||||
// loop (all loop together when done) |
|
||||
[done] (pc1=3) -> (pc1'=3); |
|
||||
|
|
||||
endmodule |
|
||||
|
|
||||
// construct remaining processes through renaming |
|
||||
module process2 = process1[pc1=pc2,coin1=coin2,p=q] endmodule |
|
||||
module process3 = process1[pc1=pc3,coin1=coin3] endmodule |
|
||||
module process4 = process1[pc1=pc4,coin1=coin4,p=q] endmodule |
|
||||
module process5 = process1[pc1=pc5,coin1=coin5] endmodule |
|
||||
module process6 = process1[pc1=pc6,coin1=coin6,p=q] endmodule |
|
||||
|
|
||||
// labels |
|
||||
label "finished" = pc1=3 & pc2=3 & pc3=3 & pc4=3 & pc5=3 & pc6=3 ; |
|
||||
label "all_coins_equal_0" = coin1=0 & coin2=0 & coin3=0 & coin4=0 & coin5=0 & coin6=0 ; |
|
||||
label "all_coins_equal_1" = coin1=1 & coin2=1 & coin3=1 & coin4=1 & coin5=1 & coin6=1 ; |
|
||||
label "agree" = coin1=coin2 & coin2=coin3 & coin3=coin4 & coin4=coin5 & coin5=coin6 ; |
|
||||
label "finish_with_1" = pc1=3 & pc2=3 & pc3=3 & pc4=3 & pc5=3 & pc6=3 & coin1=1 & coin2=1 & coin3=1 & coin4=1 & coin5=1 & coin6=1; |
|
||||
|
|
||||
// rewards |
|
||||
rewards "steps" |
|
||||
true : 1; |
|
||||
endrewards |
|
||||
|
|
@ -1,70 +0,0 @@ |
|||||
// COIN FLIPPING PROTOCOL FOR POLYNOMIAL RANDOMIZED CONSENSUS [AH90] |
|
||||
// gxn/dxp 20/11/00 |
|
||||
|
|
||||
mdp |
|
||||
|
|
||||
// constants |
|
||||
const int N=6; |
|
||||
const int K=8; |
|
||||
const int range = 2*(K+1)*N; |
|
||||
const int counter_init = (K+1)*N; |
|
||||
const int left = N; |
|
||||
const int right = 2*(K+1)*N - N; |
|
||||
|
|
||||
//Coin Probabilities |
|
||||
const double p; |
|
||||
const double q; |
|
||||
|
|
||||
// shared coin |
|
||||
global counter : [0..range] init counter_init; |
|
||||
|
|
||||
module process1 |
|
||||
|
|
||||
// program counter |
|
||||
pc1 : [0..3]; |
|
||||
// 0 - flip |
|
||||
// 1 - write |
|
||||
// 2 - check |
|
||||
// 3 - finished |
|
||||
|
|
||||
// local coin |
|
||||
coin1 : [0..1]; |
|
||||
|
|
||||
// flip coin |
|
||||
[] (pc1=0) -> p : (coin1'=0) & (pc1'=1) + 1-p : (coin1'=1) & (pc1'=1); |
|
||||
// write tails -1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=0) & (counter>0) -> (counter'=counter-1) & (pc1'=2) & (coin1'=0); |
|
||||
// write heads +1 (reset coin to add regularity) |
|
||||
[] (pc1=1) & (coin1=1) & (counter<range) -> (counter'=counter+1) & (pc1'=2) & (coin1'=0); |
|
||||
// check |
|
||||
// decide tails |
|
||||
[] (pc1=2) & (counter<=left) -> (pc1'=3) & (coin1'=0); |
|
||||
// decide heads |
|
||||
[] (pc1=2) & (counter>=right) -> (pc1'=3) & (coin1'=1); |
|
||||
// flip again |
|
||||
[] (pc1=2) & (counter>left) & (counter<right) -> (pc1'=0); |
|
||||
// loop (all loop together when done) |
|
||||
[done] (pc1=3) -> (pc1'=3); |
|
||||
|
|
||||
endmodule |
|
||||
|
|
||||
// construct remaining processes through renaming |
|
||||
module process2 = process1[pc1=pc2,coin1=coin2,p=q] endmodule |
|
||||
module process3 = process1[pc1=pc3,coin1=coin3] endmodule |
|
||||
module process4 = process1[pc1=pc4,coin1=coin4,p=q] endmodule |
|
||||
module process5 = process1[pc1=pc5,coin1=coin5] endmodule |
|
||||
module process6 = process1[pc1=pc6,coin1=coin6,p=q] endmodule |
|
||||
|
|
||||
// labels |
|
||||
label "finished" = pc1=3 & pc2=3 & pc3=3 & pc4=3 & pc5=3 & pc6=3 ; |
|
||||
label "all_coins_equal_0" = coin1=0 & coin2=0 & coin3=0 & coin4=0 & coin5=0 & coin6=0 ; |
|
||||
label "all_coins_equal_1" = coin1=1 & coin2=1 & coin3=1 & coin4=1 & coin5=1 & coin6=1 ; |
|
||||
label "agree" = coin1=coin2 & coin2=coin3 & coin3=coin4 & coin4=coin5 & coin5=coin6 ; |
|
||||
label "finish_with_1" = pc1=3 & pc2=3 & pc3=3 & pc4=3 & coin1=1 & coin2=1 & coin3=1 & coin4=1 ; |
|
||||
label "finish_with_1" = pc1=3 & pc2=3 & pc3=3 & pc4=3 & pc5=3 & pc6=3 & coin1=1 & coin2=1 & coin3=1 & coin4=1 & coin5=1 & coin6=1; |
|
||||
|
|
||||
// rewards |
|
||||
rewards "steps" |
|
||||
true : 1; |
|
||||
endrewards |
|
||||
|
|
Reference in new issue
xxxxxxxxxx