#region License Information /* HeuristicLab * Copyright (C) 2002-2010 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 HeuristicLab.Analysis; using HeuristicLab.Common; using HeuristicLab.Core; using HeuristicLab.Data; using HeuristicLab.Encodings.SymbolicExpressionTreeEncoding; using HeuristicLab.Operators; using HeuristicLab.Optimization; using HeuristicLab.Optimization.Operators; using HeuristicLab.Parameters; using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; using HeuristicLab.Problems.DataAnalysis.Symbolic; namespace HeuristicLab.Problems.DataAnalysis.Regression.Symbolic.Analyzers { /// /// An operator that analyzes the validation best scaled symbolic regression solution. /// [Item("ValidationBestScaledSymbolicRegressionSolutionAnalyzer", "An operator that analyzes the validation best scaled symbolic regression solution.")] [StorableClass] public sealed class ValidationBestScaledSymbolicRegressionSolutionAnalyzer : AlgorithmOperator, ISymbolicRegressionAnalyzer { private const string SymbolicExpressionTreeParameterName = "SymbolicExpressionTree"; private const string ScaledSymbolicExpressionTreeParameterName = "ScaledSymbolicExpressionTree"; private const string SymbolicExpressionTreeInterpreterParameterName = "SymbolicExpressionTreeInterpreter"; private const string ProblemDataParameterName = "ProblemData"; private const string TrainingSamplesStartParameterName = "TrainingSamplesStart"; private const string TrainingSamplesEndParameterName = "TrainingSamplesEnd"; private const string ValidationSamplesStartParameterName = "ValidationSamplesStart"; private const string ValidationSamplesEndParameterName = "ValidationSamplesEnd"; private const string TestSamplesStartParameterName = "TestSamplesStart"; private const string TestSamplesEndParameterName = "TestSamplesEnd"; private const string QualityParameterName = "Quality"; private const string ScaledQualityParameterName = "ScaledQuality"; private const string UpperEstimationLimitParameterName = "UpperEstimationLimit"; private const string LowerEstimationLimitParameterName = "LowerEstimationLimit"; private const string AlphaParameterName = "Alpha"; private const string BetaParameterName = "Beta"; private const string BestSolutionParameterName = "Best solution (validation)"; private const string BestSolutionQualityParameterName = "Best solution quality (validation)"; private const string CurrentBestValidationQualityParameterName = "Current best validation quality"; private const string ResultsParameterName = "Results"; private const string BestKnownQualityParameterName = "BestKnownQuality"; public ScopeTreeLookupParameter SymbolicExpressionTreeParameter { get { return (ScopeTreeLookupParameter)Parameters[SymbolicExpressionTreeParameterName]; } } public ScopeTreeLookupParameter QualityParameter { get { return (ScopeTreeLookupParameter)Parameters[QualityParameterName]; } } public IValueLookupParameter SymbolicExpressionTreeInterpreterParameter { get { return (IValueLookupParameter)Parameters[SymbolicExpressionTreeInterpreterParameterName]; } } public IValueLookupParameter ProblemDataParameter { get { return (IValueLookupParameter)Parameters[ProblemDataParameterName]; } } public IValueLookupParameter TrainingSamplesStartParameter { get { return (IValueLookupParameter)Parameters[TrainingSamplesStartParameterName]; } } public IValueLookupParameter TrainingSamplesEndParameter { get { return (IValueLookupParameter)Parameters[TrainingSamplesEndParameterName]; } } public IValueLookupParameter ValidationSamplesStartParameter { get { return (IValueLookupParameter)Parameters[ValidationSamplesStartParameterName]; } } public IValueLookupParameter ValidationSamplesEndParameter { get { return (IValueLookupParameter)Parameters[ValidationSamplesEndParameterName]; } } public IValueLookupParameter TestSamplesStartParameter { get { return (IValueLookupParameter)Parameters[TestSamplesStartParameterName]; } } public IValueLookupParameter TestSamplesEndParameter { get { return (IValueLookupParameter)Parameters[TestSamplesEndParameterName]; } } public IValueLookupParameter UpperEstimationLimitParameter { get { return (IValueLookupParameter)Parameters[UpperEstimationLimitParameterName]; } } public IValueLookupParameter LowerEstimationLimitParameter { get { return (IValueLookupParameter)Parameters[LowerEstimationLimitParameterName]; } } public ILookupParameter BestSolutionParameter { get { return (ILookupParameter)Parameters[BestSolutionParameterName]; } } public ILookupParameter BestSolutionQualityParameter { get { return (ILookupParameter)Parameters[BestSolutionQualityParameterName]; } } public ILookupParameter ResultsParameter { get { return (ILookupParameter)Parameters[ResultsParameterName]; } } public ILookupParameter BestKnownQualityParameter { get { return (ILookupParameter)Parameters[BestKnownQualityParameterName]; } } [Storable] private UniformSubScopesProcessor subScopesProcessor; [Storable] private SymbolicRegressionSolutionLinearScaler linearScaler; [Storable] private SymbolicRegressionModelQualityAnalyzer modelQualityAnalyzer; [Storable] private SymbolicRegressionMeanSquaredErrorEvaluator validationMseEvaluator; [Storable] private BestSymbolicRegressionSolutionAnalyzer bestSolutionAnalyzer; [Storable] private UniformSubScopesProcessor cleaningSubScopesProcessor; [Storable] private Assigner removeScaledExpressionTreeAssigner; [Storable] private BestQualityMemorizer bestKnownQualityMemorizer; [Storable] private BestAverageWorstQualityCalculator bestAvgWorstValidationQualityCalculator; [Storable] private DataTableValuesCollector validationValuesCollector; [Storable] private ResultsCollector resultsCollector; public ValidationBestScaledSymbolicRegressionSolutionAnalyzer() : base() { Parameters.Add(new ScopeTreeLookupParameter(SymbolicExpressionTreeParameterName, "The symbolic expression trees to analyze.")); Parameters.Add(new ScopeTreeLookupParameter(QualityParameterName, "The quality of the symbolic expression trees to analyze.")); Parameters.Add(new ValueLookupParameter(SymbolicExpressionTreeInterpreterParameterName, "The interpreter that should be used for the analysis of symbolic expression trees.")); Parameters.Add(new ValueLookupParameter(ProblemDataParameterName, "The problem data for which the symbolic expression tree is a solution.")); Parameters.Add(new ValueLookupParameter(TrainingSamplesStartParameterName, "The first index of the training partition of the data set.")); Parameters.Add(new ValueLookupParameter(TrainingSamplesEndParameterName, "The last index of the training partition of the data set.")); Parameters.Add(new ValueLookupParameter(ValidationSamplesStartParameterName, "The first index of the validation partition of the data set.")); Parameters.Add(new ValueLookupParameter(ValidationSamplesEndParameterName, "The last index of the validation partition of the data set.")); Parameters.Add(new ValueLookupParameter(TestSamplesStartParameterName, "The first index of the test partition of the data set.")); Parameters.Add(new ValueLookupParameter(TestSamplesEndParameterName, "The last index of the test partition of the data set.")); Parameters.Add(new ValueLookupParameter(UpperEstimationLimitParameterName, "The upper estimation limit that was set for the evaluation of the symbolic expression trees.")); Parameters.Add(new ValueLookupParameter(LowerEstimationLimitParameterName, "The lower estimation limit that was set for the evaluation of the symbolic expression trees.")); Parameters.Add(new LookupParameter(BestSolutionParameterName, "The best symbolic regression solution.")); Parameters.Add(new LookupParameter(BestSolutionQualityParameterName, "The quality of the best symbolic regression solution.")); Parameters.Add(new LookupParameter(ResultsParameterName, "The result collection where the best symbolic regression solution should be stored.")); Parameters.Add(new LookupParameter(BestKnownQualityParameterName, "The best known (validation) quality achieved on the data set.")); #region operator initialization subScopesProcessor = new UniformSubScopesProcessor(); linearScaler = new SymbolicRegressionSolutionLinearScaler(); modelQualityAnalyzer = new SymbolicRegressionModelQualityAnalyzer(); validationMseEvaluator = new SymbolicRegressionMeanSquaredErrorEvaluator(); bestSolutionAnalyzer = new BestSymbolicRegressionSolutionAnalyzer(); cleaningSubScopesProcessor = new UniformSubScopesProcessor(); removeScaledExpressionTreeAssigner = new Assigner(); bestKnownQualityMemorizer = new BestQualityMemorizer(); bestAvgWorstValidationQualityCalculator = new BestAverageWorstQualityCalculator(); validationValuesCollector = new DataTableValuesCollector(); resultsCollector = new ResultsCollector(); #endregion #region parameter wiring subScopesProcessor.Depth.Value = SymbolicExpressionTreeParameter.Depth; linearScaler.AlphaParameter.ActualName = AlphaParameterName; linearScaler.BetaParameter.ActualName = BetaParameterName; linearScaler.SymbolicExpressionTreeParameter.ActualName = SymbolicExpressionTreeParameter.Name; linearScaler.ScaledSymbolicExpressionTreeParameter.ActualName = ScaledSymbolicExpressionTreeParameterName; modelQualityAnalyzer.ProblemDataParameter.ActualName = ProblemDataParameter.Name; modelQualityAnalyzer.SymbolicExpressionTreeParameter.ActualName = ScaledSymbolicExpressionTreeParameterName; modelQualityAnalyzer.SymbolicExpressionTreeParameter.Depth = SymbolicExpressionTreeParameter.Depth; modelQualityAnalyzer.UpperEstimationLimitParameter.ActualName = UpperEstimationLimitParameter.Name; modelQualityAnalyzer.LowerEstimationLimitParameter.ActualName = LowerEstimationLimitParameter.Name; modelQualityAnalyzer.SymbolicExpressionTreeInterpreterParameter.ActualName = SymbolicExpressionTreeInterpreterParameter.Name; validationMseEvaluator.LowerEstimationLimitParameter.ActualName = LowerEstimationLimitParameter.Name; validationMseEvaluator.UpperEstimationLimitParameter.ActualName = UpperEstimationLimitParameter.Name; validationMseEvaluator.SymbolicExpressionTreeParameter.ActualName = ScaledSymbolicExpressionTreeParameterName; validationMseEvaluator.SymbolicExpressionTreeInterpreterParameter.ActualName = SymbolicExpressionTreeInterpreterParameter.Name; validationMseEvaluator.QualityParameter.ActualName = ScaledQualityParameterName; validationMseEvaluator.RegressionProblemDataParameter.ActualName = ProblemDataParameter.Name; validationMseEvaluator.SamplesStartParameter.ActualName = ValidationSamplesStartParameter.Name; validationMseEvaluator.SamplesEndParameter.ActualName = ValidationSamplesEndParameter.Name; bestSolutionAnalyzer.BestSolutionParameter.ActualName = BestSolutionParameter.Name; bestSolutionAnalyzer.BestSolutionQualityParameter.ActualName = BestSolutionQualityParameter.Name; bestSolutionAnalyzer.LowerEstimationLimitParameter.ActualName = LowerEstimationLimitParameter.Name; bestSolutionAnalyzer.ProblemDataParameter.ActualName = ProblemDataParameter.Name; bestSolutionAnalyzer.QualityParameter.ActualName = ScaledQualityParameterName; bestSolutionAnalyzer.ResultsParameter.ActualName = ResultsParameter.Name; bestSolutionAnalyzer.SymbolicExpressionTreeInterpreterParameter.ActualName = SymbolicExpressionTreeInterpreterParameter.Name; bestSolutionAnalyzer.SymbolicExpressionTreeParameter.ActualName = ScaledSymbolicExpressionTreeParameterName; bestSolutionAnalyzer.SymbolicExpressionTreeParameter.Depth = SymbolicExpressionTreeParameter.Depth; bestSolutionAnalyzer.UpperEstimationLimitParameter.ActualName = UpperEstimationLimitParameter.Name; cleaningSubScopesProcessor.Depth.Value = SymbolicExpressionTreeParameter.Depth; removeScaledExpressionTreeAssigner.LeftSideParameter.ActualName = ScaledSymbolicExpressionTreeParameterName; removeScaledExpressionTreeAssigner.RightSideParameter.Value = new SymbolicExpressionTree(); bestAvgWorstValidationQualityCalculator.AverageQualityParameter.ActualName = "Current average validation quality"; bestAvgWorstValidationQualityCalculator.BestQualityParameter.ActualName = CurrentBestValidationQualityParameterName; bestAvgWorstValidationQualityCalculator.MaximizationParameter.Value = new BoolValue(false); bestAvgWorstValidationQualityCalculator.QualityParameter.ActualName = ScaledQualityParameterName; bestAvgWorstValidationQualityCalculator.QualityParameter.Depth = SymbolicExpressionTreeParameter.Depth; bestAvgWorstValidationQualityCalculator.WorstQualityParameter.ActualName = "Current worst validation quality"; bestKnownQualityMemorizer.BestQualityParameter.ActualName = BestKnownQualityParameterName; bestKnownQualityMemorizer.MaximizationParameter.Value = new BoolValue(false); bestKnownQualityMemorizer.QualityParameter.ActualName = QualityParameter.Name; bestKnownQualityMemorizer.QualityParameter.Depth = QualityParameter.Depth; validationValuesCollector.DataTableParameter.ActualName = "Validation quality"; validationValuesCollector.CollectedValues.Add(new LookupParameter(CurrentBestValidationQualityParameterName, null, CurrentBestValidationQualityParameterName)); validationValuesCollector.CollectedValues.Add(new LookupParameter(BestSolutionQualityParameter.Name, null, BestSolutionQualityParameter.Name)); resultsCollector.CollectedValues.Add(new LookupParameter(CurrentBestValidationQualityParameterName, null, CurrentBestValidationQualityParameterName)); resultsCollector.CollectedValues.Add(new LookupParameter(BestSolutionQualityParameter.Name, null, BestSolutionQualityParameter.Name)); resultsCollector.CollectedValues.Add(new LookupParameter("Validation quality")); resultsCollector.ResultsParameter.ActualName = ResultsParameter.Name; #endregion #region operator graph OperatorGraph.InitialOperator = subScopesProcessor; subScopesProcessor.Operator = linearScaler; linearScaler.Successor = validationMseEvaluator; validationMseEvaluator.Successor = null; subScopesProcessor.Successor = modelQualityAnalyzer; modelQualityAnalyzer.Successor = bestSolutionAnalyzer; bestSolutionAnalyzer.Successor = cleaningSubScopesProcessor; cleaningSubScopesProcessor.Operator = removeScaledExpressionTreeAssigner; cleaningSubScopesProcessor.Successor = bestAvgWorstValidationQualityCalculator; bestAvgWorstValidationQualityCalculator.Successor = bestKnownQualityMemorizer; bestKnownQualityMemorizer.Successor = validationValuesCollector; validationValuesCollector.Successor = resultsCollector; resultsCollector.Successor = null; #endregion Initialize(); } [StorableConstructor] private ValidationBestScaledSymbolicRegressionSolutionAnalyzer(bool deserializing) : base() { } [StorableHook(HookType.AfterDeserialization)] private void Initialize() { SymbolicExpressionTreeParameter.DepthChanged += new EventHandler(SymbolicExpressionTreeParameter_DepthChanged); } public override IDeepCloneable Clone(Cloner cloner) { ValidationBestScaledSymbolicRegressionSolutionAnalyzer clone = (ValidationBestScaledSymbolicRegressionSolutionAnalyzer)base.Clone(cloner); clone.Initialize(); return clone; } private void SymbolicExpressionTreeParameter_DepthChanged(object sender, EventArgs e) { subScopesProcessor.Depth.Value = SymbolicExpressionTreeParameter.Depth; cleaningSubScopesProcessor.Depth.Value = SymbolicExpressionTreeParameter.Depth; bestSolutionAnalyzer.SymbolicExpressionTreeParameter.Depth = SymbolicExpressionTreeParameter.Depth; bestSolutionAnalyzer.QualityParameter.Depth = SymbolicExpressionTreeParameter.Depth; bestAvgWorstValidationQualityCalculator.QualityParameter.Depth = SymbolicExpressionTreeParameter.Depth; bestKnownQualityMemorizer.QualityParameter.Depth = SymbolicExpressionTreeParameter.Depth; modelQualityAnalyzer.SymbolicExpressionTreeParameter.Depth = SymbolicExpressionTreeParameter.Depth; } } }