Free cookie consent management tool by TermsFeed Policy Generator

source: trunk/HeuristicLab.Optimization/3.3/Results/ResultCollection.cs @ 16612

Last change on this file since 16612 was 16565, checked in by gkronber, 6 years ago

#2520: merged changes from PersistenceOverhaul branch (r16451:16564) into trunk

File size: 3.2 KB
RevLine 
[12764]1#region License Information
2/* HeuristicLab
[16565]3 * Copyright (C) 2002-2019 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
[12764]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;
[16565]25using HEAL.Attic;
[12764]26
27namespace HeuristicLab.Optimization {
[16565]28  [StorableType("959230E3-C51B-4EC0-BDB2-0B0D71F5A6E3")]
[12764]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]
[16565]35    protected ResultCollection(StorableConstructorFlag _) : base(_) { }
[12764]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
[15051]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    }
[12764]84  }
85}
Note: See TracBrowser for help on using the repository browser.