1 | using HeuristicLab.Common;
|
---|
2 | using HeuristicLab.Core;
|
---|
3 | using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
|
---|
4 |
|
---|
5 | namespace HeuristicLab.Algorithms.DataAnalysis.MoeaD {
|
---|
6 | public interface IMOEADSolution : IItem {
|
---|
7 | IItem Individual { get; set; }
|
---|
8 | double[] Qualities { get; set; }
|
---|
9 | double[] Constraints { get; set; }
|
---|
10 | int Dimensions { get; }
|
---|
11 | }
|
---|
12 |
|
---|
13 | [Item("MOEADSolution", "Represents a solution inside the MOEA/D population")]
|
---|
14 | [StorableClass]
|
---|
15 | public class MOEADSolution : Item, IMOEADSolution {
|
---|
16 | public IItem Individual { get; set; }
|
---|
17 | public double[] Qualities { get; set; }
|
---|
18 | public double[] Constraints { get; set; }
|
---|
19 |
|
---|
20 | public MOEADSolution(int nObjectives, int nConstraints) {
|
---|
21 | Qualities = new double[nObjectives];
|
---|
22 | Constraints = new double[nConstraints];
|
---|
23 | }
|
---|
24 |
|
---|
25 | public MOEADSolution(IItem individual, int nObjectives, int nConstraints) : this(nObjectives, nConstraints) {
|
---|
26 | Individual = individual;
|
---|
27 | }
|
---|
28 |
|
---|
29 | public MOEADSolution(IItem individual, double[] qualities, double[] constraints) {
|
---|
30 | Individual = individual;
|
---|
31 | Qualities = qualities;
|
---|
32 | Constraints = constraints;
|
---|
33 | }
|
---|
34 |
|
---|
35 | public MOEADSolution(double[] qualities) {
|
---|
36 | Qualities = (double[])qualities.Clone();
|
---|
37 | }
|
---|
38 |
|
---|
39 | public int Dimensions => Qualities == null ? 0 : Qualities.Length;
|
---|
40 |
|
---|
41 | public override IDeepCloneable Clone(Cloner cloner) {
|
---|
42 | return new MOEADSolution(this, cloner);
|
---|
43 | }
|
---|
44 |
|
---|
45 | protected MOEADSolution(MOEADSolution original, Cloner cloner) : base(original, cloner) {
|
---|
46 | Qualities = (double[])original.Qualities.Clone();
|
---|
47 | Constraints = (double[])original.Qualities.Clone();
|
---|
48 | Individual = (IItem)original.Individual.Clone(cloner);
|
---|
49 | }
|
---|
50 |
|
---|
51 | [StorableConstructor]
|
---|
52 | protected MOEADSolution(bool deserializing) : base(deserializing) { }
|
---|
53 | }
|
---|
54 |
|
---|
55 | [Item("MOEADSolution", "Represents a solution inside the MOEA/D population")]
|
---|
56 | [StorableClass]
|
---|
57 | public class MOEADSolution<T> : MOEADSolution where T : class, IItem {
|
---|
58 | public new T Individual {
|
---|
59 | get { return (T)base.Individual; }
|
---|
60 | set { base.Individual = value; }
|
---|
61 | }
|
---|
62 |
|
---|
63 | public MOEADSolution(T individual, int nObjectives, int nConstraints) : base(individual, nObjectives, nConstraints) { }
|
---|
64 |
|
---|
65 | protected MOEADSolution(MOEADSolution<T> original, Cloner cloner) : base(original, cloner) { }
|
---|
66 |
|
---|
67 | public override IDeepCloneable Clone(Cloner cloner) {
|
---|
68 | return new MOEADSolution<T>(this, cloner);
|
---|
69 | }
|
---|
70 |
|
---|
71 | [StorableConstructor]
|
---|
72 | protected MOEADSolution(bool deserializing) : base(deserializing) { }
|
---|
73 | }
|
---|
74 | }
|
---|