Free cookie consent management tool by TermsFeed Policy Generator

source: branches/ProgrammableProblem/HeuristicLab.Problems.Programmable/3.3/MultiObjectiveProblemDefinitionScript.cs @ 11400

Last change on this file since 11400 was 11400, checked in by abeham, 10 years ago

#2174: Added multi-objective programmable problem

File size: 4.5 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2014 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
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 HeuristicLab.Common;
23using HeuristicLab.Core;
24using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
25
26namespace HeuristicLab.Problems.Programmable {
27  [Item("Multi-objective Problem Definition Script", "Script that defines the parameter vector and evaluates the solution for a programmable problem.")]
28  [StorableClass]
29  public class MultiObjectiveProblemDefinitionScript : ProblemDefinitionScript, IMultiObjectiveProblemDefinitionHost, IStorableContent {
30    public string Filename { get; set; }
31
32    [StorableConstructor]
33    protected MultiObjectiveProblemDefinitionScript(bool deserializing) : base(deserializing) { }
34    protected MultiObjectiveProblemDefinitionScript(MultiObjectiveProblemDefinitionScript original, Cloner cloner)
35      : base(original, cloner) { }
36
37    public MultiObjectiveProblemDefinitionScript() {
38      Code = CodeTemplate;
39    }
40
41    public override IDeepCloneable Clone(Cloner cloner) {
42      return new MultiObjectiveProblemDefinitionScript(this, cloner);
43    }
44
45    public new IMultiObjectiveProblemDefinition Instance {
46      get { return (IMultiObjectiveProblemDefinition)base.Instance; }
47      protected set { base.Instance = value; }
48    }
49
50    protected override string CodeTemplate {
51      get {
52        return @"using System;
53using System.Linq;
54using System.Collections.Generic;
55using HeuristicLab.Common;
56using HeuristicLab.Core;
57using HeuristicLab.Data;
58using HeuristicLab.Encodings.PermutationEncoding;
59using HeuristicLab.Optimization;
60using HeuristicLab.Problems.Programmable;
61
62public class CustomProblemDefinition : ProblemDefinition, IMultiObjectiveProblemDefinition {
63  public bool[] Maximization { get { return new [] { false, false }; } }
64
65  public override void Initialize() {
66    // when the definition is created here you can initialize variables in the variable store
67  }
68
69  public override Configuration GetConfiguration() {
70    return new Configuration()
71      // .AddBinaryVector(""b"", length: 5)
72      // .AddIntegerVector(""i"", length: 5, min: 2, max: 14, step: 4)
73      // .AddRealVector(""r"", length: 5, min: -1.0, max: 1.0)
74      // .AddPermutation(""P"", length: 5, type: PermutationTypes.Absolute)
75    ;
76  }
77
78  public double[] Evaluate(IRandom random, ParameterVector vector) {
79    var qualities = new [] { 0.0, 0.0 };
80    // use vars.yourVariable to access variables in the variable store i.e. yourVariable
81    // qualities = new [] { vector.RealVector(""r"").Sum(x => x * x), vector.RealVector(""r"").Sum(x => x * x * x) };
82    return qualities;
83  }
84
85  public void Analyze(ParameterVector[] vectors, double[][] qualities, ResultCollection results) {
86    // write or update results given the range of vectors and resulting qualities
87    // use e.g. vars.yourVariable to access variables in the variable store i.e. yourVariable
88  }
89
90  public IEnumerable<ParameterVector> GetNeighbors(IRandom random, ParameterVector vector) {
91    // Create new vectors, based on the given one that represent small changes
92    // This method is only called from move-based algorithms (LocalSearch, SimulatedAnnealing, etc.)
93    while (true) {
94      // this is not an infinite loop as only a finite amount of samples will be drawn
95      // it is possible to return a concrete amount of neighbors also
96      var neighbor = (ParameterVector)vector.Clone();
97      //e.g. make a bit flip in a binary parameter
98      //var bIndex = random.Next(neighbor.BinaryVector(""b"").Length);
99      //neighbor.BinaryVector(""b"")[bIndex] = !neighbor.BinaryVector(""b"")[bIndex];
100      yield return neighbor;
101    }
102  }
103
104  // implement further classes and methods
105}";
106      }
107    }
108  }
109}
Note: See TracBrowser for help on using the repository browser.