1 | package net.bmahe.genetics4j.moo.spea2.spec.replacement; | |
2 | ||
3 | import java.util.Comparator; | |
4 | import java.util.Optional; | |
5 | import java.util.function.BiFunction; | |
6 | ||
7 | import org.immutables.value.Value; | |
8 | ||
9 | import net.bmahe.genetics4j.core.Genotype; | |
10 | import net.bmahe.genetics4j.core.spec.replacement.ReplacementStrategy; | |
11 | import net.bmahe.genetics4j.moo.FitnessVector; | |
12 | ||
13 | @Value.Immutable | |
14 | public abstract class SPEA2Replacement<T extends Comparable<T>> implements ReplacementStrategy { | |
15 | ||
16 | /** | |
17 | * Defines the Pareto dominance relation | |
18 | * | |
19 | * @return | |
20 | */ | |
21 | @Value.Default | |
22 | public Comparator<T> dominance() { | |
23 |
3
1. dominance : replaced return value with null for net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement::dominance → NO_COVERAGE 2. lambda$dominance$0 : removed call to java/lang/Comparable::compareTo → NO_COVERAGE 3. lambda$dominance$0 : replaced int return with 0 for net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement::lambda$dominance$0 → NO_COVERAGE |
return (a, b) -> a.compareTo(b); |
24 | } | |
25 | ||
26 | /** | |
27 | * Comparator used for deduplication of solution prior to processing | |
28 | * <p>If not specified, it defaults to not do any deduplication | |
29 | * | |
30 | * @return | |
31 | */ | |
32 | @Value.Default | |
33 | public Optional<Comparator<Genotype>> deduplicate() { | |
34 |
1
1. deduplicate : removed call to java/util/Optional::empty → NO_COVERAGE |
return Optional.empty(); |
35 | } | |
36 | ||
37 | /** | |
38 | * Determine the k-nearest distance to compute. | |
39 | * <p>It will default to sqrt(|archive| + |population|) | |
40 | * | |
41 | * @return | |
42 | */ | |
43 | @Value.Default | |
44 | public Optional<Integer> k() { | |
45 |
1
1. k : removed call to java/util/Optional::empty → NO_COVERAGE |
return Optional.empty(); |
46 | } | |
47 | ||
48 | /** | |
49 | * Define how to compute distances in objective space between two solutions | |
50 | * | |
51 | * @return Distance | |
52 | */ | |
53 | @Value.Parameter | |
54 | public abstract BiFunction<T, T, Double> distance(); | |
55 | ||
56 | public static class Builder<T extends Comparable<T>> extends ImmutableSPEA2Replacement.Builder<T> { | |
57 | } | |
58 | ||
59 | public static <U extends Comparable<U>> Builder<U> builder() { | |
60 |
2
1. builder : replaced return value with null for net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement::builder → NO_COVERAGE 2. builder : removed call to net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement$Builder::<init> → NO_COVERAGE |
return new Builder<U>(); |
61 | } | |
62 | ||
63 | /** | |
64 | * Factory method to instantiate a SPEA2Selection when fitness is defined as a FitnessVector of a Number | |
65 | * | |
66 | * @param <U> Type of the fitness measurement | |
67 | * @param deduplicate Deduplicator comparator. Null value with disable deduplication | |
68 | * @return A new instance of SPEA2Replacement | |
69 | */ | |
70 | public static <U extends Number & Comparable<U>> SPEA2Replacement<FitnessVector<U>> ofFitnessVector( | |
71 | final Comparator<Genotype> deduplicate) { | |
72 | ||
73 |
1
1. ofFitnessVector : removed call to net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement$Builder::<init> → NO_COVERAGE |
final var builder = new Builder<FitnessVector<U>>(); |
74 |
3
1. ofFitnessVector : removed call to net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement$Builder::deduplicate → NO_COVERAGE 2. ofFitnessVector : removed call to java/util/Optional::ofNullable → NO_COVERAGE 3. ofFitnessVector : replaced call to net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement$Builder::deduplicate with receiver → NO_COVERAGE |
builder.deduplicate(Optional.ofNullable(deduplicate)); |
75 | ||
76 |
2
1. ofFitnessVector : removed call to net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement$Builder::distance → NO_COVERAGE 2. ofFitnessVector : replaced call to net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement$Builder::distance with receiver → NO_COVERAGE |
builder.distance((fv1, fv2) -> { |
77 | ||
78 |
1
1. lambda$ofFitnessVector$1 : removed call to net/bmahe/genetics4j/moo/FitnessVector::dimensions → NO_COVERAGE |
final int dimensions = fv1.dimensions(); |
79 | ||
80 |
1
1. lambda$ofFitnessVector$1 : Substituted 0.0 with 1.0 → NO_COVERAGE |
double sum = 0.0; |
81 |
5
1. lambda$ofFitnessVector$1 : Substituted 0 with 1 → NO_COVERAGE 2. lambda$ofFitnessVector$1 : removed conditional - replaced comparison check with false → NO_COVERAGE 3. lambda$ofFitnessVector$1 : negated conditional → NO_COVERAGE 4. lambda$ofFitnessVector$1 : changed conditional boundary → NO_COVERAGE 5. lambda$ofFitnessVector$1 : removed conditional - replaced comparison check with true → NO_COVERAGE |
for (int i = 0; i < dimensions; i++) { |
82 |
1
1. lambda$ofFitnessVector$1 : removed call to net/bmahe/genetics4j/moo/FitnessVector::get → NO_COVERAGE |
final double v1 = fv1.get(i) |
83 |
1
1. lambda$ofFitnessVector$1 : removed call to java/lang/Number::doubleValue → NO_COVERAGE |
.doubleValue(); |
84 |
1
1. lambda$ofFitnessVector$1 : removed call to net/bmahe/genetics4j/moo/FitnessVector::get → NO_COVERAGE |
final double v2 = fv2.get(i) |
85 |
1
1. lambda$ofFitnessVector$1 : removed call to java/lang/Number::doubleValue → NO_COVERAGE |
.doubleValue(); |
86 | ||
87 |
4
1. lambda$ofFitnessVector$1 : Replaced double subtraction with addition → NO_COVERAGE 2. lambda$ofFitnessVector$1 : Replaced double addition with subtraction → NO_COVERAGE 3. lambda$ofFitnessVector$1 : Replaced double multiplication with division → NO_COVERAGE 4. lambda$ofFitnessVector$1 : Replaced double subtraction with addition → NO_COVERAGE |
sum += (v2 - v1) * (v2 - v1); |
88 | } | |
89 | ||
90 |
4
1. lambda$ofFitnessVector$1 : replaced Double return value with 0 for net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement::lambda$ofFitnessVector$1 → NO_COVERAGE 2. lambda$ofFitnessVector$1 : removed call to java/lang/Double::valueOf → NO_COVERAGE 3. lambda$ofFitnessVector$1 : replaced call to java/lang/Math::sqrt with argument → NO_COVERAGE 4. lambda$ofFitnessVector$1 : removed call to java/lang/Math::sqrt → NO_COVERAGE |
return Math.sqrt(sum); |
91 | }); | |
92 | ||
93 |
2
1. ofFitnessVector : replaced return value with null for net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement::ofFitnessVector → NO_COVERAGE 2. ofFitnessVector : removed call to net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement$Builder::build → NO_COVERAGE |
return builder.build(); |
94 | } | |
95 | ||
96 | /** | |
97 | * Factory method to instantiate a SPEA2Selection when fitness is defined as a FitnessVector of a Number | |
98 | * | |
99 | * @param <U> Type of the fitness measurement | |
100 | * @return A new instance of SPEA2Replacement | |
101 | */ | |
102 | public static <U extends Number & Comparable<U>> SPEA2Replacement<FitnessVector<U>> ofFitnessVector() { | |
103 | ||
104 |
2
1. ofFitnessVector : removed call to net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement::ofFitnessVector → NO_COVERAGE 2. ofFitnessVector : replaced return value with null for net/bmahe/genetics4j/moo/spea2/spec/replacement/SPEA2Replacement::ofFitnessVector → NO_COVERAGE |
return ofFitnessVector(null); |
105 | } | |
106 | } | |
Mutations | ||
23 |
1.1 2.2 3.3 |
|
34 |
1.1 |
|
45 |
1.1 |
|
60 |
1.1 2.2 |
|
73 |
1.1 |
|
74 |
1.1 2.2 3.3 |
|
76 |
1.1 2.2 |
|
78 |
1.1 |
|
80 |
1.1 |
|
81 |
1.1 2.2 3.3 4.4 5.5 |
|
82 |
1.1 |
|
83 |
1.1 |
|
84 |
1.1 |
|
85 |
1.1 |
|
87 |
1.1 2.2 3.3 4.4 |
|
90 |
1.1 2.2 3.3 4.4 |
|
93 |
1.1 2.2 |
|
104 |
1.1 2.2 |