Free cookie consent management tool by TermsFeed Policy Generator

source: trunk/HeuristicLab.Optimization/3.3/Algorithms/UserDefinedAlgorithm.cs

Last change on this file was 17180, checked in by swagner, 5 years ago

#2875: Removed years in copyrights

File size: 3.9 KB
RevLine 
[2851]1#region License Information
2/* HeuristicLab
[17180]3 * Copyright (C) Heuristic and Evolutionary Algorithms Laboratory (HEAL)
[2851]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
[5080]22using System.Linq;
[4437]23using HeuristicLab.Common;
[2851]24using HeuristicLab.Core;
[16565]25using HEAL.Attic;
[2851]26
27namespace HeuristicLab.Optimization {
28  /// <summary>
29  /// An algorithm which can be defined by the user.
30  /// </summary>
[3528]31  [Item("User-Defined Algorithm", "An algorithm which can be defined by the user.")]
[12504]32  [Creatable(CreatableAttribute.Categories.Algorithms, Priority = 100)]
[16565]33  [StorableType("8D1C0ED9-F732-4DE3-8F6C-125DFF9E8D5E")]
[4437]34  public sealed class UserDefinedAlgorithm : EngineAlgorithm, IParameterizedItem, IStorableContent {
35    public string Filename { get; set; }
36
[2851]37    public new ParameterCollection Parameters {
38      get { return base.Parameters; }
39    }
[3393]40    IKeyedItemCollection<string, IParameter> IParameterizedItem.Parameters {
[2851]41      get { return Parameters; }
42    }
43
44    public new OperatorGraph OperatorGraph {
45      get { return base.OperatorGraph; }
46      set { base.OperatorGraph = value; }
47    }
48
49    public new IScope GlobalScope {
50      get { return base.GlobalScope; }
51    }
52
[5080]53    private IValueParameter AnalyzerParameter {
[5362]54      get {
55        IParameter param;
56        if (Parameters.TryGetValue("Analyzer", out param))
57          return param as IValueParameter;
58        return null;
59      }
[5080]60    }
61    private IMultiAnalyzer Analyzer {
62      get {
63        if (AnalyzerParameter != null)
64          return AnalyzerParameter.Value as IMultiAnalyzer;
65        return null;
66      }
67    }
68
[2851]69    public UserDefinedAlgorithm() : base() { }
[2864]70    public UserDefinedAlgorithm(string name) : base(name) { }
71    public UserDefinedAlgorithm(string name, string description) : base(name, description) { }
[3280]72    [StorableConstructor]
[16565]73    private UserDefinedAlgorithm(StorableConstructorFlag _) : base(_) { }
[4722]74    private UserDefinedAlgorithm(UserDefinedAlgorithm original, Cloner cloner)
75      : base(original, cloner) {
76    }
77    internal UserDefinedAlgorithm(EngineAlgorithm original, Cloner cloner)
78      : base(original, cloner) {
79    }
80    public override IDeepCloneable Clone(Cloner cloner) {
81      return new UserDefinedAlgorithm(this, cloner);
82    }
[5080]83
84    #region update of problem specific analyzers
85    protected override void OnProblemChanged() {
86      AddProblemAnalyzer();
87      base.OnProblemChanged();
88    }
89    protected override void Problem_OperatorsChanged(object sender, System.EventArgs e) {
90      RemoveProblemAnalyzers();
91      AddProblemAnalyzer();
92      base.Problem_OperatorsChanged(sender, e);
93    }
94
95    protected override void DeregisterProblemEvents() {
96      RemoveProblemAnalyzers();
97      base.DeregisterProblemEvents();
98    }
99
100    private void RemoveProblemAnalyzers() {
101      if (Analyzer != null) {
102        foreach (var analyzer in Problem.Operators.OfType<IAnalyzer>())
103          Analyzer.Operators.Remove(analyzer);
104      }
105    }
106    private void AddProblemAnalyzer() {
107      if (Analyzer != null && Problem != null) {
108        foreach (IAnalyzer analyzer in Problem.Operators.OfType<IAnalyzer>()) {
[9151]109          Analyzer.Operators.Add(analyzer, analyzer.EnabledByDefault);
[5080]110        }
111      }
112    }
113    #endregion
[2851]114  }
115}
Note: See TracBrowser for help on using the repository browser.