Free cookie consent management tool by TermsFeed Policy Generator

source: addons/HeuristicLab.MetaOptimization/HeuristicLab.Problems.MetaOptimization/3.3/Operators/Manipulators/DoubleValue/UniformDoubleValueManipulator.cs @ 16996

Last change on this file since 16996 was 16996, checked in by gkronber, 5 years ago

#2520 Update plugin dependencies and references for HL.MetaOptimization for new persistence

File size: 1.7 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 HEAL.Attic;
9
10namespace HeuristicLab.Problems.MetaOptimization {
11  [StorableType("DB96C01D-0E89-4BC4-A012-02D648B89DC0")]
12  public class UniformDoubleValueManipulator : SingleSuccessorOperator, IDoubleValueManipulator, IStochasticOperator {
13
14    public ILookupParameter<IRandom> RandomParameter {
15      get { return (LookupParameter<IRandom>)Parameters["Random"]; }
16    }
17
18    public UniformDoubleValueManipulator() { }
19    [StorableConstructor]
20    protected UniformDoubleValueManipulator(StorableConstructorFlag _) : base(_) { }
21    protected UniformDoubleValueManipulator(UniformDoubleValueManipulator original, Cloner cloner)
22      : base(original, cloner) {
23    }
24    public override IDeepCloneable Clone(Cloner cloner) {
25      return new UniformDoubleValueManipulator(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 vector = new RealVector(1);
35      var bounds = new DoubleMatrix(1, 2);
36      bounds[0, 0] = range.LowerBound.Value;
37      bounds[0, 1] = range.UpperBound.Value;
38      double val = value.Value;
39
40      do {
41        vector[0] = val;
42        UniformOnePositionManipulator.Apply(random, vector, bounds);
43        value.Value = vector[0];
44        value.Value = range.ApplyStepSize(value.Value);
45      } while (!range.IsInRange(value.Value));
46    }
47  }
48}
Note: See TracBrowser for help on using the repository browser.