#region License Information /* HeuristicLab * Copyright (C) 2002-2013 Heuristic and Evolutionary Algorithms Laboratory (HEAL) * * This file is part of HeuristicLab. * * HeuristicLab is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * HeuristicLab is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with HeuristicLab. If not, see . */ #endregion using System; using System.Collections.Generic; using System.Linq; using System.Drawing; using HeuristicLab.Analysis; using HeuristicLab.Core; using HeuristicLab.Data; namespace HeuristicLab.DataPreprocessing { public class ChartLogic : IChartLogic { private ITransactionalPreprocessingData preprocessingData; public ChartLogic(ITransactionalPreprocessingData preprocessingData) { this.preprocessingData = preprocessingData; } #region IChartLogic Members public DataRow CreateDataRow(string variableName, DataRowVisualProperties.DataRowChartType chartType) { IList values = preprocessingData.GetValues(variableName); DataRow row = new DataRow(variableName, "", values); row.VisualProperties.ChartType = chartType; return row; } public DataRow CreateDataRowRange(string variableName,int start, int end, DataRowVisualProperties.DataRowChartType chartType) { IList values = preprocessingData.GetValues(variableName); IList valuesRange = new List(); for (int i = 0; i < values.Count; i++) { if (i >= start && i <= end) valuesRange.Add(values[i]); else valuesRange.Add(Double.NaN); } DataRow row = new DataRow(variableName, "", valuesRange); row.VisualProperties.ChartType = chartType; return row; } private void ReplaceNANwithZero(IList values) { for (int i = 0; i < values.Count; i++) { if (Double.IsNaN(values[i])) values[i] = 0; } } public List GetVariableValues(string variableName) { return preprocessingData.GetValues(preprocessingData.GetColumnIndex(variableName)).ToList(); } public IEnumerable GetVariableNames() { List doubleVariableNames = new List(); //only return variable names from type double foreach (string variableName in preprocessingData.VariableNames) { if (preprocessingData.IsType(preprocessingData.GetColumnIndex(variableName))) doubleVariableNames.Add(variableName); } return doubleVariableNames; } public ICheckedItemList CreateVariableItemList() { ICheckedItemList itemList = new CheckedItemList(); foreach (string name in GetVariableNames()) { itemList.Add(new StringValue(name), true); } return new ReadOnlyCheckedItemList(itemList); } public event DataPreprocessingChangedEventHandler Changed { add { preprocessingData.Changed += value; } remove { preprocessingData.Changed -= value; } } public event EventHandler SelectionChanged { add { preprocessingData.SelectionChanged += value; } remove { preprocessingData.SelectionChanged -= value; } } public string GetVariableNameByIndex(int index) { return preprocessingData.GetVariableName(index); } public List CreateAllDataRows(DataRowVisualProperties.DataRowChartType chartType) { List dataRows = new List(); foreach (var name in GetVariableNames()) dataRows.Add(CreateDataRow(name, chartType)); return dataRows; } public List CreateAllSelectedDataRows(DataRowVisualProperties.DataRowChartType chartType) { List dataRows = new List(); foreach (var name in GetVariableNames()) { DataRow row = CreateSelectedDataRow(name, chartType); if(row != null) dataRows.Add(row); } return dataRows; } public DataRow CreateSelectedDataRow(string variableName, DataRowVisualProperties.DataRowChartType chartType) { IDictionary> selection = preprocessingData.GetSelection(); int variableIndex = preprocessingData.GetColumnIndex(variableName); if (selection.Keys.Contains(variableIndex)) { List selectedIndices = new List(selection[variableIndex]); //need selection with more than 1 value if(selectedIndices.Count < 2) return null; selectedIndices.Sort(); int start = selectedIndices[0]; int end = selectedIndices[selectedIndices.Count-1]; DataRow rowSelect = CreateDataRowRange(variableName, start, end, chartType); return rowSelect; } else return null; } #endregion } }