#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 HeuristicLab.Core;
using HeuristicLab.Data;
using HeuristicLab.Operators;
using HeuristicLab.Optimization;
using HeuristicLab.Optimization.Operators;
using HeuristicLab.Parameters;
using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
namespace HeuristicLab.Analysis {
///
/// An operator which analyzes the best, average and worst solution quality in the current population.
///
[Item("PopulationBestAverageWorstQualityAnalyzer", "An operator which analyzes the best, average and worst solution quality in the current population.")]
[StorableClass]
public sealed class PopulationBestAverageWorstQualityAnalyzer : AlgorithmOperator, IPopulationAnalyzer {
#region Parameter properties
public ValueLookupParameter MaximizationParameter {
get { return (ValueLookupParameter)Parameters["Maximization"]; }
}
public SubScopesLookupParameter QualityParameter {
get { return (SubScopesLookupParameter)Parameters["Quality"]; }
}
public ValueLookupParameter BestKnownQualityParameter {
get { return (ValueLookupParameter)Parameters["BestKnownQuality"]; }
}
public ValueLookupParameter BestQualityParameter {
get { return (ValueLookupParameter)Parameters["BestQuality"]; }
}
public ValueLookupParameter CurrentBestQualityParameter {
get { return (ValueLookupParameter)Parameters["CurrentBestQuality"]; }
}
public ValueLookupParameter CurrentAverageQualityParameter {
get { return (ValueLookupParameter)Parameters["CurrentAverageQuality"]; }
}
public ValueLookupParameter CurrentWorstQualityParameter {
get { return (ValueLookupParameter)Parameters["CurrentWorstQuality"]; }
}
public ValueLookupParameter AbsoluteDifferenceBestKnownToBestParameter {
get { return (ValueLookupParameter)Parameters["AbsoluteDifferenceBestKnownToBest"]; }
}
public ValueLookupParameter RelativeDifferenceBestKnownToBestParameter {
get { return (ValueLookupParameter)Parameters["RelativeDifferenceBestKnownToBest"]; }
}
public ValueLookupParameter ResultsParameter {
get { return (ValueLookupParameter)Parameters["Results"]; }
}
#endregion
[StorableConstructor]
private PopulationBestAverageWorstQualityAnalyzer(bool deserializing) : base() { }
public PopulationBestAverageWorstQualityAnalyzer()
: base() {
Initialize();
}
private void Initialize() {
#region Create parameters
Parameters.Add(new ValueLookupParameter("Maximization", "True if the problem is a maximization problem, otherwise false."));
Parameters.Add(new SubScopesLookupParameter("Quality", "The value which represents the quality of a solution."));
Parameters.Add(new ValueLookupParameter("BestKnownQuality", "The best known quality value found so far."));
Parameters.Add(new ValueLookupParameter("BestQuality", "The best quality value found in the current run."));
Parameters.Add(new ValueLookupParameter("CurrentBestQuality", "The best quality value found in the current population."));
Parameters.Add(new ValueLookupParameter("CurrentAverageQuality", "The average quality value of all solutions in the current population."));
Parameters.Add(new ValueLookupParameter("CurrentWorstQuality", "The worst quality value found in the current population."));
Parameters.Add(new ValueLookupParameter("AbsoluteDifferenceBestKnownToBest", "The absolute difference of the best known quality value to the best quality value."));
Parameters.Add(new ValueLookupParameter("RelativeDifferenceBestKnownToBest", "The relative difference of the best known quality value to the best quality value."));
Parameters.Add(new ValueLookupParameter("Results", "The variable collection where results should be stored."));
#endregion
#region Create operators
BestQualityMemorizer bestQualityMemorizer1 = new BestQualityMemorizer();
BestQualityMemorizer bestQualityMemorizer2 = new BestQualityMemorizer();
BestAverageWorstQualityCalculator bestAverageWorstQualityCalculator = new BestAverageWorstQualityCalculator();
DataTableValuesCollector dataTableValuesCollector = new DataTableValuesCollector();
QualityDifferenceCalculator qualityDifferenceCalculator = new QualityDifferenceCalculator();
ResultsCollector resultsCollector = new ResultsCollector();
bestQualityMemorizer1.BestQualityParameter.ActualName = "BestQuality";
bestQualityMemorizer1.MaximizationParameter.ActualName = "Maximization";
bestQualityMemorizer1.QualityParameter.ActualName = "Quality";
bestQualityMemorizer2.BestQualityParameter.ActualName = "BestKnownQuality";
bestQualityMemorizer2.MaximizationParameter.ActualName = "Maximization";
bestQualityMemorizer2.QualityParameter.ActualName = "Quality";
bestAverageWorstQualityCalculator.AverageQualityParameter.ActualName = "CurrentAverageQuality";
bestAverageWorstQualityCalculator.BestQualityParameter.ActualName = "CurrentBestQuality";
bestAverageWorstQualityCalculator.MaximizationParameter.ActualName = "Maximization";
bestAverageWorstQualityCalculator.QualityParameter.ActualName = "Quality";
bestAverageWorstQualityCalculator.WorstQualityParameter.ActualName = "CurrentWorstQuality";
dataTableValuesCollector.CollectedValues.Add(new LookupParameter("Current Best Quality", null, "CurrentBestQuality"));
dataTableValuesCollector.CollectedValues.Add(new LookupParameter("Current Average Quality", null, "CurrentAverageQuality"));
dataTableValuesCollector.CollectedValues.Add(new LookupParameter("Current Worst Quality", null, "CurrentWorstQuality"));
dataTableValuesCollector.CollectedValues.Add(new LookupParameter("Best Quality", null, "BestQuality"));
dataTableValuesCollector.CollectedValues.Add(new LookupParameter("Best Known Quality", null, "BestKnownQuality"));
dataTableValuesCollector.DataTableParameter.ActualName = "Qualities";
qualityDifferenceCalculator.AbsoluteDifferenceParameter.ActualName = "AbsoluteDifferenceBestKnownToBest";
qualityDifferenceCalculator.FirstQualityParameter.ActualName = "BestKnownQuality";
qualityDifferenceCalculator.RelativeDifferenceParameter.ActualName = "RelativeDifferenceBestKnownToBest";
qualityDifferenceCalculator.SecondQualityParameter.ActualName = "BestQuality";
resultsCollector.CollectedValues.Add(new LookupParameter("Current Best Quality", null, "CurrentBestQuality"));
resultsCollector.CollectedValues.Add(new LookupParameter("Current Average Quality", null, "CurrentAverageQuality"));
resultsCollector.CollectedValues.Add(new LookupParameter("Current Worst Quality", null, "CurrentWorstQuality"));
resultsCollector.CollectedValues.Add(new LookupParameter("Best Quality", null, "BestQuality"));
resultsCollector.CollectedValues.Add(new LookupParameter("Best Known Quality", null, "BestKnownQuality"));
resultsCollector.CollectedValues.Add(new LookupParameter("Absolute Difference of Best Known Quality to Best Quality", null, "AbsoluteDifferenceBestKnownToBest"));
resultsCollector.CollectedValues.Add(new LookupParameter("Relative Difference of Best Known Quality to Best Quality", null, "RelativeDifferenceBestKnownToBest"));
resultsCollector.CollectedValues.Add(new LookupParameter("Qualities"));
resultsCollector.ResultsParameter.ActualName = "Results";
#endregion
#region Create operator graph
OperatorGraph.InitialOperator = bestQualityMemorizer1;
bestQualityMemorizer1.Successor = bestQualityMemorizer2;
bestQualityMemorizer2.Successor = bestAverageWorstQualityCalculator;
bestAverageWorstQualityCalculator.Successor = dataTableValuesCollector;
dataTableValuesCollector.Successor = qualityDifferenceCalculator;
qualityDifferenceCalculator.Successor = resultsCollector;
resultsCollector.Successor = null;
#endregion
}
}
}