#region License Information
/* HeuristicLab
* Copyright (C) Heuristic and Evolutionary Algorithms Laboratory (HEAL)
*
* This file is part of HeuristicLab.
*
* HeuristicLab is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* HeuristicLab is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with HeuristicLab. If not, see .
*/
#endregion
using System.Collections.Generic;
using HeuristicLab.Common;
using HeuristicLab.Core;
using HEAL.Attic;
namespace HeuristicLab.Optimization {
[StorableType("959230E3-C51B-4EC0-BDB2-0B0D71F5A6E3")]
[Item("ResultCollection", "Represents a collection of results.")]
public class ResultCollection : NamedItemCollection {
public ResultCollection() : base() { }
public ResultCollection(int capacity) : base(capacity) { }
public ResultCollection(IEnumerable collection) : base(collection) { }
[StorableConstructor]
protected ResultCollection(StorableConstructorFlag _) : base(_) { }
protected ResultCollection(ResultCollection original, Cloner cloner)
: base(original, cloner) {
}
public override IDeepCloneable Clone(Cloner cloner) {
return new ResultCollection(this, cloner);
}
public static new System.Drawing.Image StaticItemImage {
get { return HeuristicLab.Common.Resources.VSImageLibrary.Object; }
}
public virtual void CollectResultValues(IDictionary values) {
CollectResultValues(values, string.Empty);
}
public virtual void CollectResultValues(IDictionary values, string rootPath) {
foreach (IResult result in this) {
var children = GetCollectedResults(result);
string path = string.Empty;
if (!string.IsNullOrWhiteSpace(rootPath))
path = rootPath + ".";
foreach (var c in children) {
if (string.IsNullOrEmpty(c.Key))
values.Add(path + result.Name, c.Value);
else values.Add(path + result.Name + "." + c.Key, c.Value);
}
}
}
protected virtual IEnumerable> GetCollectedResults(IResult result) {
if (result.Value == null) yield break;
yield return new KeyValuePair(string.Empty, result.Value);
var resultCollection = result.Value as ResultCollection;
if (resultCollection != null) {
var children = new Dictionary();
resultCollection.CollectResultValues(children);
foreach (var child in children) yield return child;
}
}
public void AddOrUpdateResult(string name, IItem value) {
IResult res;
if (!TryGetValue(name, out res)) {
res = new Result(name, value);
Add(res);
} else res.Value = value;
}
}
}