Free cookie consent management tool by TermsFeed Policy Generator

source: branches/HeuristicLab.MetaOptimization/HeuristicLab.Problems.MetaOptimization/3.3/Operators/Manipulators/DoubleValue/NormalDoubleValueManipulator.cs @ 6197

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

#1215

  • some fixes
File size: 1.8 KB
Line 
1using HeuristicLab.Common;
2using HeuristicLab.Core;
3using HeuristicLab.Data;
4using HeuristicLab.Encodings.RealVectorEncoding;
5using HeuristicLab.Operators;
6using HeuristicLab.Optimization;
7using HeuristicLab.Parameters;
8using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
9
10namespace HeuristicLab.Problems.MetaOptimization {
11  [StorableClass]
12  public class NormalDoubleValueManipulator : SingleSuccessorOperator, IDoubleValueManipulator, IStochasticOperator {
13
14    public ILookupParameter<IRandom> RandomParameter {
15      get { return (LookupParameter<IRandom>)Parameters["Random"]; }
16    }
17
18    public NormalDoubleValueManipulator() { }
19    [StorableConstructor]
20    protected NormalDoubleValueManipulator(bool deserializing) : base(deserializing) { }
21    protected NormalDoubleValueManipulator(NormalDoubleValueManipulator original, Cloner cloner)
22      : base(original, cloner) {
23    }
24    public override IDeepCloneable Clone(Cloner cloner) {
25      return new NormalDoubleValueManipulator(this, cloner);
26    }
27   
28    // todo: override apply
29    public void Apply(IRandom random, DoubleValue value, DoubleValueRange range) {
30      ApplyStatic(random, value, range);
31    }
32
33    public static void ApplyStatic(IRandom random, DoubleValue value, DoubleValueRange range) {
34      var strategy = new RealVector(new double[] { (range.UpperBound.Value - range.LowerBound.Value) / 10}); // todo: add strategy parameter
35      var vector = new RealVector(1);
36      double val = value.Value;
37     
38      do {
39        vector[0] = val;
40        NormalAllPositionsManipulator.Apply(random, vector, strategy);
41        value.Value = vector[0];
42        value.Value = range.ApplyStepSize(value.Value);
43      } while(!range.IsInRange(value.Value));
44    }
45  }
46}
Note: See TracBrowser for help on using the repository browser.