Free cookie consent management tool by TermsFeed Policy Generator

source: branches/VNS/HeuristicLab.Algorithms.NSGA2/3.3/BasicMultiObjectiveQualityAnalyzer.cs @ 5728

Last change on this file since 5728 was 4902, checked in by vdorfer, 14 years ago

#1040:

  • adapted NSGAII to new cloning implementation
File size: 4.1 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2010 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
4 *
5 * This file is part of HeuristicLab.
6 *
7 * HeuristicLab is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * HeuristicLab is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with HeuristicLab. If not, see <http://www.gnu.org/licenses/>.
19 */
20#endregion
21
22using System;
23using System.Collections.Generic;
24using System.Linq;
25using System.Text;
26using HeuristicLab.Operators;
27using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
28using HeuristicLab.Core;
29using HeuristicLab.Data;
30using HeuristicLab.Optimization;
31using HeuristicLab.Parameters;
32using HeuristicLab.Common;
33
34namespace HeuristicLab.Algorithms.NSGA2 {
35  [Item("BasicMultiObjectiveSolutionAnalyzer", "Basic analyzer for multiobjective problems that collects and presents the current pareto front as double matrix.")]
36  [StorableClass]
37  public class BasicMultiObjectiveQualityAnalyzer : SingleSuccessorOperator, IAnalyzer {
38    public IScopeTreeLookupParameter<IntValue> RankParameter {
39      get { return (IScopeTreeLookupParameter<IntValue>)Parameters["Rank"]; }
40    }
41    public IScopeTreeLookupParameter<DoubleArray> QualitiesParameter {
42      get { return (IScopeTreeLookupParameter<DoubleArray>)Parameters["Qualities"]; }
43    }
44    public ILookupParameter<ResultCollection> ResultsParameter {
45      get { return (ILookupParameter<ResultCollection>)Parameters["Results"]; }
46    }
47
48    [StorableConstructor]
49    protected BasicMultiObjectiveQualityAnalyzer(bool deserializing) : base(deserializing) { }
50    protected BasicMultiObjectiveQualityAnalyzer(BasicMultiObjectiveQualityAnalyzer original, Cloner cloner) : base(original, cloner) { }
51    public BasicMultiObjectiveQualityAnalyzer() {
52      Parameters.Add(new ScopeTreeLookupParameter<IntValue>("Rank", "The rank of solution describes to which front it belongs."));
53      Parameters.Add(new ScopeTreeLookupParameter<DoubleArray>("Qualities", "The vector of qualities of each solution."));
54      Parameters.Add(new LookupParameter<ResultCollection>("Results", "The result collection to store the front to."));
55    }
56
57    public override IOperation Apply() {
58      ItemArray<IntValue> ranks = RankParameter.ActualValue;
59      ItemArray<DoubleArray> qualities = QualitiesParameter.ActualValue;
60      ResultCollection results = ResultsParameter.ActualValue;
61     
62      bool populationLevel = RankParameter.Depth == 1;
63
64      int objectives = qualities[0].Length;
65      int frontSize = ranks.Count(x => x.Value == 0);
66      ItemArray<IScope> paretoArchive = null;
67      if (populationLevel) paretoArchive = new ItemArray<IScope>(frontSize);
68
69      DoubleMatrix front = new DoubleMatrix(frontSize, objectives);
70      int counter = 0;
71      for (int i = 0; i < ranks.Length; i++) {
72        if (ranks[i].Value == 0) {
73          for (int k = 0; k < objectives; k++)
74            front[counter, k] = qualities[i][k];
75          if (populationLevel) {
76            paretoArchive[counter] = (IScope)ExecutionContext.Scope.SubScopes[i].Clone();
77          }
78          counter++;
79        }
80      }
81
82      if (results.ContainsKey("Pareto Front"))
83        results["Pareto Front"].Value = front;
84      else results.Add(new Result("Pareto Front", front));
85
86      if (populationLevel) {
87        if (results.ContainsKey("Pareto Archive"))
88          results["Pareto Archive"].Value = paretoArchive;
89        else results.Add(new Result("Pareto Archive", paretoArchive));
90      }
91      return base.Apply();
92    }
93
94    public override IDeepCloneable Clone(Cloner cloner) {
95      return new BasicMultiObjectiveQualityAnalyzer(this, cloner);
96    }
97  }
98}
Note: See TracBrowser for help on using the repository browser.