Free cookie consent management tool by TermsFeed Policy Generator

Ignore:
Timestamp:
07/16/15 11:48:59 (9 years ago)
Author:
abeham
Message:

#2431:

  • branched relevant plugins
  • added analyzer to calculate quality vs evaluation first-hit graph
  • (also added results parameter)
Location:
branches/PerformanceComparison
Files:
1 added
2 copied

Legend:

Unmodified
Added
Removed
  • branches/PerformanceComparison/HeuristicLab.Analysis/3.3/QualityAnalysis/QualityVsEvaluationsAnalyzer.cs

    r12759 r12764  
    2020#endregion
    2121
     22using System;
    2223using HeuristicLab.Common;
    2324using HeuristicLab.Core;
     
    2829using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
    2930
    30 namespace HeuristicLab.Analysis.QualityAnalysis {
    31   [Item("ScaledQualityDifferenceAnalyzer", @"Calculates the quality value relative to a certain range given with a minimum and a maximum value.
    32 The difference lies in the interval [0;1] if the range [min;max] is as large as the observed quality values, otherwise the difference will become < 0 or > 1.
    33 A value towards 0 always means that it's closer to the better fitness value, while a value towards 1 means that it's closer to the worse fitness value.")]
     31namespace HeuristicLab.Analysis {
     32  [Item("QualityVsEvaluationsAnalyzer", @"Creates a plot of the solution quality with respect to the number of evaluated solutions.")]
    3433  [StorableClass]
    35   public class ScaledQualityDifferenceAnalyzer : SingleSuccessorOperator, IAnalyzer, ISingleObjectiveOperator {
     34  public class QualityVsEvaluationsAnalyzer : SingleSuccessorOperator, IAnalyzer, ISingleObjectiveOperator {
    3635    public virtual bool EnabledByDefault {
    37       get { return true; }
     36      get { return false; }
    3837    }
    3938
    40     public ILookupParameter<DoubleValue> QualityParameter {
    41       get { return (ILookupParameter<DoubleValue>)Parameters["Quality"]; }
     39    public ILookupParameter<DoubleValue> BestQualityParameter {
     40      get { return (ILookupParameter<DoubleValue>)Parameters["BestQuality"]; }
    4241    }
    43     public ILookupParameter<BoolValue> MaximizationParameter {
    44       get { return (ILookupParameter<BoolValue>)Parameters["Maximization"]; }
     42    public ILookupParameter<IntValue> EvaluatedSolutionsParameter {
     43      get { return (ILookupParameter<IntValue>)Parameters["EvaluatedSolutions"]; }
    4544    }
    46     public ILookupParameter<DoubleValue> ScaledDifferenceParameter {
    47       get { return (ILookupParameter<DoubleValue>)Parameters["ScaledDifference"]; }
    48     }
    49     public ILookupParameter<ResultCollection> ResultsParameter {
    50       get { return (ILookupParameter<ResultCollection>)Parameters["Results"]; }
    51     }
    52     public IValueLookupParameter<DoubleValue> MinimumQualityParameter {
    53       get { return (IValueLookupParameter<DoubleValue>)Parameters["MinimumQuality"]; }
    54     }
    55     public IValueLookupParameter<DoubleValue> MaximumQualityParameter {
    56       get { return (IValueLookupParameter<DoubleValue>)Parameters["MaximumQuality"]; }
     45    public IResultParameter<IndexedDataTable<int>> QualityVsEvaluationsParameter {
     46      get { return (IResultParameter<IndexedDataTable<int>>)Parameters["QualityVsEvaluations"]; }
    5747    }
    5848
    5949    [StorableConstructor]
    60     protected ScaledQualityDifferenceAnalyzer(bool deserializing) : base(deserializing) { }
    61     protected ScaledQualityDifferenceAnalyzer(ScaledQualityDifferenceAnalyzer original, Cloner cloner) : base(original, cloner) { }
    62     public ScaledQualityDifferenceAnalyzer()
     50    protected QualityVsEvaluationsAnalyzer(bool deserializing) : base(deserializing) { }
     51    protected QualityVsEvaluationsAnalyzer(QualityVsEvaluationsAnalyzer original, Cloner cloner) : base(original, cloner) { }
     52    public QualityVsEvaluationsAnalyzer()
    6353      : base() {
    64       Parameters.Add(new LookupParameter<DoubleValue>("Quality", "The quality value that should be compared."));
    65       Parameters.Add(new LookupParameter<BoolValue>("Maximization", "True if the problem is a maximization problem, false otherwise."));
    66       Parameters.Add(new LookupParameter<DoubleValue>("ScaledDifference", "The value that describes whether the quality value lies towards the better quality in the range (<=0.5) or more towards the worse quality (> 0.5)."));
    67       Parameters.Add(new LookupParameter<ResultCollection>("Results", "The result collection where the difference will be stored (in addition to the scope)."));
    68       Parameters.Add(new ValueLookupParameter<DoubleValue>("MinimumQuality", "The lower bound of the quality range to which the quality is compared."));
    69       Parameters.Add(new ValueLookupParameter<DoubleValue>("MaximumQuality", "The upper bound of the quality range to which the quality is compared."));
     54      Parameters.Add(new LookupParameter<DoubleValue>("BestQuality", "The quality value that should be compared."));
     55      Parameters.Add(new LookupParameter<IntValue>("EvaluatedSolutions", "The quality value that should be compared."));
     56      Parameters.Add(new ResultParameter<IndexedDataTable<int>>("QualityVsEvaluations", "Data table containing the first hitting graph with evaluations as the x-axis."));
     57      QualityVsEvaluationsParameter.DefaultValue = new IndexedDataTable<int>("Quality vs Evaluations") {
     58        Rows = { new IndexedDataRow<int>("First-hit Graph") { VisualProperties = { ChartType = DataRowVisualProperties.DataRowChartType.StepLine } } }
     59      };
    7060    }
    7161
    7262    public override IDeepCloneable Clone(Cloner cloner) {
    73       return new ScaledQualityDifferenceAnalyzer(this, cloner);
     63      return new QualityVsEvaluationsAnalyzer(this, cloner);
    7464    }
    7565
    7666    public override IOperation Apply() {
    77       bool maximization = MaximizationParameter.ActualValue.Value;
    78       double quality = QualityParameter.ActualValue.Value, max = MaximumQualityParameter.ActualValue.Value, min = MinimumQualityParameter.ActualValue.Value;
    79       double difference;
     67      var bestQuality = BestQualityParameter.ActualValue.Value;
     68      var evaluations = EvaluatedSolutionsParameter.ActualValue.Value;
    8069
    81       difference = ((quality - min) / (max - min));
    82       if (maximization) difference = 1.0 - difference;
    83 
    84       DoubleValue differenceValue = ScaledDifferenceParameter.ActualValue;
    85       if (differenceValue == null) {
    86         differenceValue = new DoubleValue(difference);
    87         ScaledDifferenceParameter.ActualValue = differenceValue;
    88       } else differenceValue.Value = difference;
    89 
    90       ResultCollection results = ResultsParameter.ActualValue;
    91       if (results != null) {
    92         IResult r;
    93         if (!results.TryGetValue(ScaledDifferenceParameter.TranslatedName, out r)) {
    94           r = new Result(ScaledDifferenceParameter.TranslatedName, differenceValue);
    95           results.Add(r);
    96         }
    97       }
     70      var dataTable = QualityVsEvaluationsParameter.ResultValue;
     71      dataTable.Rows["First-hit Graph"].Values.Add(Tuple.Create(evaluations, bestQuality));
    9872
    9973      return base.Apply();
Note: See TracChangeset for help on using the changeset viewer.