Changeset 17538 for branches/2971_named_intervals/HeuristicLab.Problems.DataAnalysis.Symbolic.Regression
- Timestamp:
- 05/10/20 23:43:05 (5 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
branches/2971_named_intervals/HeuristicLab.Problems.DataAnalysis.Symbolic.Regression/3.4/SymbolicRegressionSolution.cs
r17510 r17538 127 127 estimationLimitResults.Add(new Result(TestNaNEvaluationsResultName, "", new IntValue())); 128 128 Add(new Result(EstimationLimitsResultsResultName, "Results concerning the estimation limits of symbolic regression solution", estimationLimitResults)); 129 Add(new Result(ModelBoundsResultName, "Results concerning the derivation of symbolic regression solution", new IntervalCollection())); 129 130 if (IntervalInterpreter.IsCompatible(Model.SymbolicExpressionTree)) 131 Add(new Result(ModelBoundsResultName, "Results concerning the derivation of symbolic regression solution", new IntervalCollection())); 132 130 133 RecalculateResults(); 131 134 } … … 176 179 177 180 //Check if the tree contains unknown symbols for the interval calculation 178 if (IntervalInterpreter.IsCompatible(Model.SymbolicExpressionTree) && DerivativeCalculator.IsCompatible(Model.SymbolicExpressionTree))181 if (IntervalInterpreter.IsCompatible(Model.SymbolicExpressionTree)) 179 182 ModelBoundsCollection = CalculateModelIntervals(this); 180 183 } … … 189 192 intervalEvaluation.AddInterval($"Target {problemData.TargetVariable}", new Interval(variableRanges[problemData.TargetVariable].LowerBound, variableRanges[problemData.TargetVariable].UpperBound)); 190 193 intervalEvaluation.AddInterval("Model Interval", interpreter.GetSymbolicExpressionTreeInterval(model.SymbolicExpressionTree, variableRanges)); 191 foreach (var inputVariable in model.VariablesUsedForPrediction.OrderBy(v => v, new NaturalStringComparer())) { 192 var derivedModel = DerivativeCalculator.Derive(model.SymbolicExpressionTree, inputVariable); 193 var derivedResultInterval = interpreter.GetSymbolicExpressionTreeInterval(derivedModel, variableRanges); 194 195 intervalEvaluation.AddInterval(" ∂f/∂" + inputVariable, 196 new Interval(derivedResultInterval.LowerBound, derivedResultInterval.UpperBound)); 194 195 if (DerivativeCalculator.IsCompatible(model.SymbolicExpressionTree)) { 196 foreach (var inputVariable in model.VariablesUsedForPrediction.OrderBy(v => v, new NaturalStringComparer())) { 197 var derivedModel = DerivativeCalculator.Derive(model.SymbolicExpressionTree, inputVariable); 198 var derivedResultInterval = interpreter.GetSymbolicExpressionTreeInterval(derivedModel, variableRanges); 199 200 intervalEvaluation.AddInterval(" ∂f/∂" + inputVariable, new Interval(derivedResultInterval.LowerBound, derivedResultInterval.UpperBound)); 201 } 197 202 } 198 203
Note: See TracChangeset
for help on using the changeset viewer.