Free cookie consent management tool by TermsFeed Policy Generator

source: branches/HeuristicLab.MetaOptimization/HeuristicLab.Problems.MetaOptimization/3.3/Encoding/ValueConfigurations/ParameterizedValueConfiguration.cs @ 8087

Last change on this file since 8087 was 6489, checked in by cneumuel, 13 years ago

#1215

  • fixed issue with multiple problems (by introducing valuesReadOnly to IOptimizable)
  • fixed error message when removing last problem instance
  • made quality measure name configurable
File size: 7.2 KB
Line 
1using System;
2using System.Collections.Generic;
3using System.Linq;
4using System.Text;
5using HeuristicLab.Common;
6using HeuristicLab.Core;
7using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
8
9namespace HeuristicLab.Problems.MetaOptimization {
10  [StorableClass]
11  public class ParameterizedValueConfiguration : ValueConfiguration {
12    [Storable]
13    protected IItemCollection<IParameterConfiguration> parameterConfigurations = new ItemCollection<IParameterConfiguration>();
14    public virtual IItemCollection<IParameterConfiguration> ParameterConfigurations {
15      get { return new ReadOnlyItemCollection<IParameterConfiguration>(this.parameterConfigurations); }
16      protected set { this.parameterConfigurations = value; }
17    }
18
19    public override bool Optimize {
20      get { return base.Optimize; }
21      set {
22        if (this.optimize != value) {
23          base.Optimize = value;
24          if (optimize) {
25            ClearParameterConfigurations();
26            PopulateParameterConfigurations(this.actualValue.Value, this.discoverValidValues);
27          } else {
28            ClearParameterConfigurations();
29          }
30        }
31      }
32    }
33
34    public override ConstrainedValue ActualValue {
35      get { return base.ActualValue; }
36      set {
37        ClearParameterConfigurations();
38        base.ActualValue = value;
39        if (this.Optimize && this.actualValue.Value != null) PopulateParameterConfigurations(this.actualValue.Value, this.discoverValidValues);
40      }
41    }
42
43    [Storable]
44    protected bool discoverValidValues;
45    public bool DiscoverValidValues {
46      get { return discoverValidValues; }
47      set { discoverValidValues = value; }
48    }
49
50    public override bool ValuesReadOnly {
51      set {
52        if (value != this.valuesReadOnly) {
53          this.valuesReadOnly = value;
54          foreach (var pc in this.parameterConfigurations) {
55            pc.ValuesReadOnly = value;
56          }
57        }
58      }
59    }
60
61    #region Constructors and Cloning
62    [StorableConstructor]
63    protected ParameterizedValueConfiguration(bool deserializing) : base(deserializing) { }
64    public ParameterizedValueConfiguration() {
65      this.ParameterConfigurations = new ItemList<IParameterConfiguration>();
66    }
67    public ParameterizedValueConfiguration(IItem value, Type valueDataType, bool discoverValidValues)
68      : base(value, valueDataType) {
69      this.discoverValidValues = discoverValidValues;
70    }
71    protected ParameterizedValueConfiguration(ParameterizedValueConfiguration original, Cloner cloner)
72      : base(original, cloner) {
73      this.discoverValidValues = original.discoverValidValues;
74      this.ParameterConfigurations = cloner.Clone(original.parameterConfigurations);
75    }
76    public override IDeepCloneable Clone(Cloner cloner) {
77      return new ParameterizedValueConfiguration(this, cloner);
78    }
79    #endregion
80
81    protected virtual void PopulateParameterConfigurations(IItem item, bool discoverValidValues) {
82      var parameterizedItem = item as IParameterizedItem;
83      if (parameterizedItem != null) {
84        foreach (var childParameter in parameterizedItem.Parameters) {
85          IValueParameter valueParameter = childParameter as IValueParameter;
86          if (valueParameter != null) {
87            var pc = new ParameterConfiguration(valueParameter.Name, valueParameter, discoverValidValues);
88            this.parameterConfigurations.Add(pc);
89          }
90        }
91      }
92    }
93
94    protected virtual void ClearParameterConfigurations() {
95      parameterConfigurations.Clear();
96    }
97
98    public override string ParameterInfoString {
99      get {
100        StringBuilder sb = new StringBuilder();
101        if ((this.Optimize) && this.ParameterConfigurations.Count > 0) {
102          var parameterInfos = new List<string>();
103          foreach (var pc in this.ParameterConfigurations) {
104            if (pc.Optimize) parameterInfos.Add(pc.ParameterInfoString);
105          }
106          sb.Append(string.Join(", ", parameterInfos.ToArray()));
107        }
108        return sb.ToString();
109      }
110    }
111
112    public override string ToString() {
113      if (ActualValue != null && ActualValue.Value != null) {
114        if (Optimize) {
115          return string.Format("{0} (Optimize)", NumberedName);
116        } else {
117          return string.Format("{0}", NumberedName);
118        }
119      } else {
120        return base.ToString();
121      }
122    }
123
124    public override List<IOptimizable> GetAllOptimizables() {
125      var list = new List<IOptimizable>();
126      foreach (var pc in ParameterConfigurations) {
127        if (pc.Optimize) {
128          if (pc.ValueConfigurations.CheckedItems.Count() > 1) list.Add(pc); // only add if there are more than 1 choices. otherwise it makes no sense to optimize which VC is selected
129          list.AddRange(pc.GetAllOptimizables());
130        }
131      }
132      return list;
133    }
134
135    public override void CollectOptimizedParameterNames(List<string> parameterNames, string prefix) {
136      foreach (var pc in ParameterConfigurations) {
137        if (pc.Optimize) {
138          parameterNames.Add(prefix + pc.ParameterName);
139          pc.CollectOptimizedParameterNames(parameterNames, prefix + pc.ParameterName + ".");
140        }
141      }
142    }
143
144    public virtual IEnumerable<string> GetOptimizedParameterNames() {
145      var list = new List<string>();
146      this.CollectOptimizedParameterNames(list, string.Empty);
147      return list;
148    }
149
150    public virtual void Parameterize(IParameterizedItem item) {
151      foreach (IParameterConfiguration pc in this.ParameterConfigurations) {
152        pc.Parameterize((IValueParameter)item.Parameters[pc.ParameterName]);
153      }
154    }
155
156    public override void Randomize(IRandom random) {
157      foreach (IParameterConfiguration pc in this.ParameterConfigurations) {
158        pc.Randomize(random);
159      }
160    }
161
162    public override void Mutate(IRandom random, MutateDelegate mutate, IIntValueManipulator intValueManipulator, IDoubleValueManipulator doubleValueManipulator) {
163      foreach (IParameterConfiguration pc in this.ParameterConfigurations) {
164        pc.Mutate(random, mutate, intValueManipulator, doubleValueManipulator);
165      }
166    }
167
168    public override void Cross(IRandom random, IOptimizable other, CrossDelegate cross, IIntValueCrossover intValueCrossover, IDoubleValueCrossover doubleValueCrossover) {
169      var otherVc = (ParameterizedValueConfiguration)other;
170      for (int i = 0; i < this.ParameterConfigurations.Count; i++) {
171        this.ParameterConfigurations.ElementAt(i).Cross(random, otherVc.ParameterConfigurations.ElementAt(i), cross, intValueCrossover, doubleValueCrossover);
172      }
173    }
174
175    public override double CalculateSimilarity(IOptimizable optimizable) {
176      var other = (ParameterizedValueConfiguration)optimizable;
177      double sum = 0;
178      int count = 0;
179      for (int i = 0; i < ParameterConfigurations.Count; i++) {
180        if (this.ParameterConfigurations.ElementAt(i).Optimize) {
181          sum += this.ParameterConfigurations.ElementAt(i).CalculateSimilarity(other.ParameterConfigurations.ElementAt(i));
182          count++;
183        }
184      }
185      return count == 0 ? 1.0 : sum / (double)count;
186    }
187  }
188}
Note: See TracBrowser for help on using the repository browser.