Free cookie consent management tool by TermsFeed Policy Generator

source: branches/ClassificationEnsembleVoting/HeuristicLab.Problems.DataAnalysis/3.4/Implementation/DataAnalysisProblem.cs @ 8471

Last change on this file since 8471 was 7866, checked in by sforsten, 13 years ago

#1776:

  • merged r7454:7863 trunk into branch to make it compatible again
  • adjusted GetConfidence of MajorityVoteWeightCalculator to be in an interval of [0, 1]
File size: 3.8 KB
RevLine 
[5540]1#region License Information
2/* HeuristicLab
[7259]3 * Copyright (C) 2002-2012 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
[5540]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
[5577]22using System;
[5540]23using HeuristicLab.Common;
24using HeuristicLab.Core;
[5578]25using HeuristicLab.Optimization;
[5577]26using HeuristicLab.Parameters;
[5540]27using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
[7866]28using HeuristicLab.Problems.Instances;
[5540]29
30namespace HeuristicLab.Problems.DataAnalysis {
31  [StorableClass]
[7866]32  public abstract class DataAnalysisProblem<T> : Problem, IDataAnalysisProblem<T>,
33    IProblemInstanceConsumer<T>, IProblemInstanceExporter<T>
[5540]34    where T : class, IDataAnalysisProblemData {
35    private const string ProblemDataParameterName = "ProblemData";
[5601]36    private const string ProblemDataParameterDescription = "The data set, target variable and input variables of the data analysis problem.";
[5540]37    #region parameter properties
[5554]38    IParameter IDataAnalysisProblem.ProblemDataParameter {
39      get { return ProblemDataParameter; }
40    }
[5540]41    public IValueParameter<T> ProblemDataParameter {
42      get { return (IValueParameter<T>)Parameters[ProblemDataParameterName]; }
43    }
44    #endregion
45    #region properties
[5554]46    IDataAnalysisProblemData IDataAnalysisProblem.ProblemData {
47      get { return ProblemData; }
48    }
[5540]49    public T ProblemData {
50      get { return ProblemDataParameter.Value; }
[6587]51      protected set {
52        ProblemDataParameter.Value = value;
53      }
[5540]54    }
55    #endregion
56    protected DataAnalysisProblem(DataAnalysisProblem<T> original, Cloner cloner)
57      : base(original, cloner) {
[6587]58      RegisterEventHandlers();
[5540]59    }
60    [StorableConstructor]
61    protected DataAnalysisProblem(bool deserializing) : base(deserializing) { }
62    public DataAnalysisProblem()
63      : base() {
[5577]64      Parameters.Add(new ValueParameter<T>(ProblemDataParameterName, ProblemDataParameterDescription));
[6587]65      RegisterEventHandlers();
[5540]66    }
[5577]67
[6587]68    [StorableHook(HookType.AfterDeserialization)]
69    private void AfterDeserialization() {
70      RegisterEventHandlers();
71    }
72
[5577]73    private void RegisterEventHandlers() {
[6587]74      ProblemDataParameter.ValueChanged += new EventHandler(ProblemDataParameter_ValueChanged);
[6635]75      if (ProblemDataParameter.Value != null) ProblemDataParameter.Value.Changed += new EventHandler(ProblemData_Changed);
[5577]76    }
[6587]77
[5577]78    private void ProblemDataParameter_ValueChanged(object sender, EventArgs e) {
[6635]79      ProblemDataParameter.Value.Changed += new EventHandler(ProblemData_Changed);
[5577]80      OnProblemDataChanged();
81      OnReset();
82    }
83
[6635]84    private void ProblemData_Changed(object sender, EventArgs e) {
85      OnReset();
86    }
87
[5577]88    public event EventHandler ProblemDataChanged;
89    protected virtual void OnProblemDataChanged() {
90      var handler = ProblemDataChanged;
91      if (handler != null) handler(this, EventArgs.Empty);
92    }
[5623]93
[7866]94    #region Import & Export
95    public void Load(T data) {
96      Name = data.Name;
97      Description = data.Description;
98      ProblemData = data;
99      OnReset();
100    }
101
102    public T Export() {
103      return ProblemData;
104    }
105    #endregion
[5540]106  }
107}
Note: See TracBrowser for help on using the repository browser.