Free cookie consent management tool by TermsFeed Policy Generator

source: branches/DataAnalysis/HeuristicLab.Problems.DataAnalysis.MultiVariate/3.3/MultiVariateDataAnalysisProblem.cs @ 5060

Last change on this file since 5060 was 4461, checked in by gkronber, 14 years ago

made DataAnalysisProblem and DataAnalysisProblemData and SymbolicTimeSeriesPrognosisSolution savable and added field for conditional evaluation to Symbolic/SymbolicTimeSeriesPrognosisSolution (fix of changeset r4457). #1142

File size: 5.3 KB
RevLine 
[4056]1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2010 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 System;
23using System.Collections.Generic;
[4068]24using System.Drawing;
[4056]25using HeuristicLab.Common;
26using HeuristicLab.Core;
[4068]27using HeuristicLab.Optimization;
28using HeuristicLab.Parameters;
[4056]29using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
30
31namespace HeuristicLab.Problems.DataAnalysis.MultiVariate {
32  [Item("Multi Variate Data Analysis Problem", "Represents a multi variate data analysis problem.")]
33  [Creatable("Problems")]
34  [StorableClass]
[4457]35  public class MultiVariateDataAnalysisProblem : ParameterizedNamedItem, IMultiVariateDataAnalysisProblem, IStorableContent {
[4056]36    private const string MultiVariateDataAnalysisProblemDataParameterName = "MultiVariateDataAnalysisProblem";
37    public override Image ItemImage {
38      get { return HeuristicLab.Common.Resources.VS2008ImageLibrary.Type; }
39    }
40
[4461]41    public string Filename { get; set; }
[4457]42
[4056]43    #region Parameter Properties
44    public ValueParameter<MultiVariateDataAnalysisProblemData> MultiVariateDataAnalysisProblemDataParameter {
45      get { return (ValueParameter<MultiVariateDataAnalysisProblemData>)Parameters[MultiVariateDataAnalysisProblemDataParameterName]; }
46    }
47    #endregion
48    #region properties
49    public MultiVariateDataAnalysisProblemData MultiVariateDataAnalysisProblemData {
50      get { return MultiVariateDataAnalysisProblemDataParameter.Value; }
51    }
52    #endregion
53
[4098]54    [StorableConstructor]
[4112]55    protected MultiVariateDataAnalysisProblem(bool deserializing) : base(deserializing) { }
[4056]56    public MultiVariateDataAnalysisProblem()
57      : base() {
58      Parameters.Add(new ValueParameter<MultiVariateDataAnalysisProblemData>(MultiVariateDataAnalysisProblemDataParameterName, "The data set, target variables and input variables of the multi-variate data analysis problem.", new MultiVariateDataAnalysisProblemData()));
59      RegisterParameterEvents();
60      RegisterParameterValueEvents();
61    }
62
63    [StorableHook(HookType.AfterDeserialization)]
64    private void AfterDeserializationHook() {
65      RegisterParameterEvents();
66      RegisterParameterValueEvents();
67    }
68
69    #region events
70    protected virtual void OnMultiVariateDataAnalysisProblemChanged(EventArgs e) {
71      RaiseReset(e);
72    }
73
74    private void RegisterParameterEvents() {
75      MultiVariateDataAnalysisProblemDataParameter.ValueChanged += new EventHandler(MultiVariateDataAnalysisProblemDataParameter_ValueChanged);
76    }
77
78    private void RegisterParameterValueEvents() {
79      MultiVariateDataAnalysisProblemData.ProblemDataChanged += new EventHandler(MultiVariateDataAnalysisProblemData_ProblemDataChanged);
80    }
81
82    private void MultiVariateDataAnalysisProblemDataParameter_ValueChanged(object sender, EventArgs e) {
83      OnMultiVariateDataAnalysisProblemChanged(e);
84    }
85
86    private void MultiVariateDataAnalysisProblemData_ProblemDataChanged(object sender, EventArgs e) {
87      OnMultiVariateDataAnalysisProblemChanged(e);
88    }
89    #endregion
90
91    public override IDeepCloneable Clone(Cloner cloner) {
92      MultiVariateDataAnalysisProblem clone = (MultiVariateDataAnalysisProblem)base.Clone(cloner);
93      clone.RegisterParameterEvents();
94      clone.RegisterParameterValueEvents();
95      return clone;
96    }
97
98    #region IProblem Members
99
100    public virtual IParameter SolutionCreatorParameter {
101      get { return null; }
102    }
103
104    public virtual ISolutionCreator SolutionCreator {
105      get { return null; }
106    }
107
108    public virtual IParameter EvaluatorParameter {
109      get { return null; }
110    }
111
112    public virtual IEvaluator Evaluator {
113      get { return null; }
114    }
115
116    public virtual IEnumerable<IOperator> Operators {
117      get { return new IOperator[0]; }
118    }
119
120    public event EventHandler SolutionCreatorChanged;
121    protected void RaiseSolutionCreatorChanged(EventArgs e) {
122      var changed = SolutionCreatorChanged;
123      if (changed != null)
124        changed(this, e);
125    }
126
127    public event EventHandler EvaluatorChanged;
128    protected void RaiseEvaluatorChanged(EventArgs e) {
129      var changed = EvaluatorChanged;
130      if (changed != null)
131        changed(this, e);
132    }
133
134    public event EventHandler OperatorsChanged;
135    protected void RaiseOperatorsChanged(EventArgs e) {
136      var changed = OperatorsChanged;
137      if (changed != null)
138        changed(this, e);
139    }
140
141    public event EventHandler Reset;
142    protected void RaiseReset(EventArgs e) {
143      var changed = Reset;
144      if (changed != null)
145        changed(this, e);
146    }
147    #endregion
148  }
149}
Note: See TracBrowser for help on using the repository browser.