Free cookie consent management tool by TermsFeed Policy Generator

source: branches/2695_dataset-ids/HeuristicLab.Optimization/3.3/Results/ResultCollection.cs @ 16189

Last change on this file since 16189 was 15051, checked in by abeham, 8 years ago

#2783:

  • Implemented GetBestIndividual as public static and protected method in SingleObjectiveBasicProblem
  • Impblemented GetParetorFronts as public static and protected method in MultiObjectiveBasicProblem
  • Implemented AddOrUpdateResult as public method in ResultCollection
File size: 3.3 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2016 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.Collections.Generic;
23using HeuristicLab.Common;
24using HeuristicLab.Core;
25using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
26
27namespace HeuristicLab.Optimization {
28  [StorableClass]
29  [Item("ResultCollection", "Represents a collection of results.")]
30  public class ResultCollection : NamedItemCollection<IResult> {
31    public ResultCollection() : base() { }
32    public ResultCollection(int capacity) : base(capacity) { }
33    public ResultCollection(IEnumerable<IResult> collection) : base(collection) { }
34    [StorableConstructor]
35    protected ResultCollection(bool deserializing) : base(deserializing) { }
36    protected ResultCollection(ResultCollection original, Cloner cloner)
37      : base(original, cloner) {
38    }
39    public override IDeepCloneable Clone(Cloner cloner) {
40      return new ResultCollection(this, cloner);
41    }
42
43    public static new System.Drawing.Image StaticItemImage {
44      get { return HeuristicLab.Common.Resources.VSImageLibrary.Object; }
45    }
46
47    public virtual void CollectResultValues(IDictionary<string, IItem> values) {
48      CollectResultValues(values, string.Empty);
49    }
50
51    public virtual void CollectResultValues(IDictionary<string, IItem> values, string rootPath) {
52      foreach (IResult result in this) {
53        var children = GetCollectedResults(result);
54        string path = string.Empty;
55        if (!string.IsNullOrWhiteSpace(rootPath))
56          path = rootPath + ".";
57        foreach (var c in children) {
58          if (string.IsNullOrEmpty(c.Key))
59            values.Add(path + result.Name, c.Value);
60          else values.Add(path + result.Name + "." + c.Key, c.Value);
61        }
62      }
63    }
64
65    protected virtual IEnumerable<KeyValuePair<string, IItem>> GetCollectedResults(IResult result) {
66      if (result.Value == null) yield break;
67      yield return new KeyValuePair<string, IItem>(string.Empty, result.Value);
68
69      var resultCollection = result.Value as ResultCollection;
70      if (resultCollection != null) {
71        var children = new Dictionary<string, IItem>();
72        resultCollection.CollectResultValues(children);
73        foreach (var child in children) yield return child;
74      }
75    }
76
77    public void AddOrUpdateResult(string name, IItem value) {
78      IResult res;
79      if (!TryGetValue(name, out res)) {
80        res = new Result(name, value);
81        Add(res);
82      } else res.Value = value;
83    }
84  }
85}
Note: See TracBrowser for help on using the repository browser.