Free cookie consent management tool by TermsFeed Policy Generator

source: trunk/sources/HeuristicLab.Problems.DataAnalysis/3.3/Dataset.cs @ 3962

Last change on this file since 3962 was 3933, checked in by mkommend, 15 years ago

removed cloning of dataset and made it readonly (ticket #938)

File size: 6.2 KB
RevLine 
[2]1#region License Information
2/* HeuristicLab
[3253]3 * Copyright (C) 2002-2010 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
[2]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;
24using System.Xml;
25using System.Globalization;
26using System.Text;
[2285]27using System.Linq;
[3376]28using HeuristicLab.Common;
[3253]29using HeuristicLab.Core;
30using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
31using HeuristicLab.Data;
[2]32
[3253]33namespace HeuristicLab.Problems.DataAnalysis {
34  [Item("Dataset", "Represents a dataset containing data that should be analyzed.")]
35  [StorableClass]
36  public sealed class Dataset : NamedItem, IStringConvertibleMatrix {
[3933]37    [StorableConstructor]
38    protected Dataset(bool deserializing)
39      : base(deserializing) {
[2319]40    }
[2]41
[3264]42    public Dataset(IEnumerable<string> variableNames, double[,] data)
[3933]43      : base() {
[2319]44      Name = "-";
[3264]45      if (variableNames.Count() != data.GetLength(1)) {
46        throw new ArgumentException("Number of variable names doesn't match the number of columns of data");
47      }
[3933]48      this.data = (double[,])data.Clone();
[3442]49      this.variableNames = variableNames.ToArray();
[2038]50    }
51
[3294]52    [Storable]
[3308]53    private string[] variableNames;
[2319]54    public IEnumerable<string> VariableNames {
55      get { return variableNames; }
[333]56    }
57
[3294]58    [Storable]
[3308]59    private double[,] data;
60    private double[,] Data {
[3253]61      get { return data; }
[2]62    }
63
[3253]64    // elementwise access
65    public double this[int rowIndex, int columnIndex] {
66      get { return data[rowIndex, columnIndex]; }
[2]67    }
[3933]68
[3839]69    public double this[string variableName, int rowIndex] {
70      get {
71        int columnIndex = GetVariableIndex(variableName);
72        return data[rowIndex, columnIndex];
73      }
74    }
[3933]75
76    public double[] GetVariableValues(int variableIndex) {
77      return GetVariableValues(variableIndex, 0, Rows);
[1287]78    }
79
[3294]80    public double[] GetVariableValues(int variableIndex, int start, int end) {
[2311]81      if (start < 0 || !(start <= end))
82        throw new ArgumentException("Start must be between 0 and end (" + end + ").");
[3308]83      if (end > Rows || end < start)
84        throw new ArgumentException("End must be between start (" + start + ") and dataset rows (" + Rows + ").");
[2311]85
86      double[] values = new double[end - start];
87      for (int i = 0; i < end - start; i++)
[3253]88        values[i] = data[i + start, variableIndex];
[2311]89      return values;
90    }
91
[3933]92    public double[] GetVariableValues(string variableName) {
93      return GetVariableValues(GetVariableIndex(variableName), 0, Rows);
94    }
95
[3294]96    public double[] GetVariableValues(string variableName, int start, int end) {
97      return GetVariableValues(GetVariableIndex(variableName), start, end);
[2311]98    }
99
[2319]100    #region Variable name methods
[3294]101    public string GetVariableName(int variableIndex) {
[2319]102      return variableNames[variableIndex];
103    }
104
[3294]105    public int GetVariableIndex(string variableName) {
[2319]106      for (int i = 0; i < variableNames.Length; i++) {
107        if (variableNames[i].Equals(variableName)) return i;
108      }
109      throw new ArgumentException("The variable name " + variableName + " was not found.");
110    }
111    #endregion
[2310]112
[3933]113    public double[,] GetClonedData() {
114      return (double[,])data.Clone();
[2]115    }
116
[3253]117    public override IDeepCloneable Clone(Cloner cloner) {
[3933]118      return this;
[2319]119    }
120
[3253]121    public event EventHandler Reset;
122    private void OnReset(EventArgs e) {
123      var listeners = Reset;
124      if (listeners != null) listeners(this, e);
[2319]125    }
[2]126
[3253]127    #region IStringConvertibleMatrix Members
[237]128
[3253]129    public int Rows {
[3933]130      get { return data.GetLength(0); }
131      set { throw new NotSupportedException(); }
[2]132    }
133
[3253]134    public int Columns {
[3933]135      get { return data.GetLength(1); }
136      set { throw new NotSupportedException(); }
[2]137    }
138
[3321]139    public bool SortableView {
[3933]140      get { return false; }
141      set { throw new NotSupportedException(); }
[3321]142    }
143
[3430]144    public bool ReadOnly {
[3933]145      get { return true; }
[3430]146    }
147
[3308]148    IEnumerable<string> IStringConvertibleMatrix.ColumnNames {
149      get { return this.VariableNames; }
[3933]150      set { throw new NotSupportedException(); }
[3308]151    }
152
[3311]153    IEnumerable<string> IStringConvertibleMatrix.RowNames {
154      get { return new List<string>(); }
[3933]155      set { throw new NotSupportedException(); }
[3311]156    }
157
[3253]158    public bool Validate(string value, out string errorMessage) {
[3933]159      throw new NotSupportedException();
[3253]160    }
[2]161
[3253]162    public string GetValue(int rowIndex, int columnIndex) {
[3308]163      return data[rowIndex, columnIndex].ToString();
[2]164    }
165
[3253]166    public bool SetValue(string value, int rowIndex, int columnIndex) {
[3933]167      throw new NotSupportedException();
[237]168    }
169
[3321]170    public event EventHandler ColumnNamesChanged;
171    private void OnColumnNamesChanged() {
172      EventHandler handler = ColumnNamesChanged;
173      if (handler != null)
174        handler(this, EventArgs.Empty);
175    }
176    public event EventHandler RowNamesChanged;
177    private void OnRowNamesChanged() {
178      EventHandler handler = RowNamesChanged;
179      if (handler != null)
180        handler(this, EventArgs.Empty);
181    }
182    public event EventHandler SortableViewChanged;
183    private void OnSortableViewChanged() {
184      EventHandler handler = SortableViewChanged;
185      if (handler != null)
186        handler(this, EventArgs.Empty);
187    }
[3253]188    public event EventHandler<EventArgs<int, int>> ItemChanged;
[3321]189    private void OnItemChanged(int rowIndex, int columnIndex) {
190      if (ItemChanged != null)
191        ItemChanged(this, new EventArgs<int, int>(rowIndex, columnIndex));
192      OnToStringChanged();
193    }
[2012]194    #endregion
[2]195  }
196}
Note: See TracBrowser for help on using the repository browser.