1 |
|
package org.sat4j.minisat.restarts; |
2 |
|
|
3 |
|
import org.sat4j.minisat.core.RestartStrategy; |
4 |
|
import org.sat4j.minisat.core.SearchParams; |
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 |
|
|
|
|
| 83,9% |
Uncovered Elements: 5 (31) |
Complexity: 3 |
Complexity Density: 0,59 |
|
33 |
|
public class LubyRestarts implements RestartStrategy { |
34 |
|
|
|
|
| 93,8% |
Uncovered Elements: 1 (16) |
Complexity: 3 |
Complexity Density: 0,3 |
|
35 |
135165
|
static final long luby_super(long i) {... |
36 |
135165
|
long power; |
37 |
135165
|
long k; |
38 |
|
|
39 |
135165
|
assert i > 0; |
40 |
|
|
41 |
135165
|
k = 1; |
42 |
135165
|
power = 2; |
43 |
1014230
|
while (power < (i + 1)) { |
44 |
879065
|
k += 1; |
45 |
879065
|
power *= 2; |
46 |
|
} |
47 |
135165
|
if (power == (i + 1)) |
48 |
19453
|
return (power / 2); |
49 |
115712
|
return (luby_super(i - (power / 2) + 1)); |
50 |
|
} |
51 |
|
|
52 |
|
private int factor; |
53 |
|
private int count; |
54 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
55 |
1
|
public LubyRestarts() {... |
56 |
1
|
setFactor(32); |
57 |
|
} |
58 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
59 |
1
|
public void setFactor(int factor) {... |
60 |
1
|
this.factor = factor; |
61 |
|
} |
62 |
|
|
|
|
| 0% |
Uncovered Elements: 1 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
63 |
0
|
public int getFactor() {... |
64 |
0
|
return factor; |
65 |
|
} |
66 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
67 |
1
|
public void init(SearchParams params) {... |
68 |
1
|
count = 1; |
69 |
|
} |
70 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
71 |
19453
|
public long nextRestartNumberOfConflict() {... |
72 |
19453
|
return luby_super(count)*factor; |
73 |
|
} |
74 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
75 |
19453
|
public void onRestart() {... |
76 |
19453
|
count++; |
77 |
|
} |
78 |
|
|
|
|
| 0% |
Uncovered Elements: 1 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
79 |
0
|
@Override... |
80 |
|
public String toString() { |
81 |
0
|
return "luby style (SATZ_rand, TiniSAT) restarts strategy with factor "+factor; |
82 |
|
} |
83 |
|
|
84 |
|
} |