1 | using System;
|
---|
2 | using System.Collections.Generic;
|
---|
3 | using System.Drawing;
|
---|
4 | using System.Linq;
|
---|
5 | using HeuristicLab.Analysis.FitnessLandscape.DataTables;
|
---|
6 | using HeuristicLab.Common;
|
---|
7 | using HeuristicLab.Core;
|
---|
8 | using HeuristicLab.Optimization;
|
---|
9 | using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
|
---|
10 | using HeuristicLab.Data;
|
---|
11 |
|
---|
12 | namespace HeuristicLab.Analysis.FitnessLandscape {
|
---|
13 |
|
---|
14 | [Item("InformationAnalysis Peak Aggregator", "Aggregates peak information anlyses.")]
|
---|
15 | [StorableClass]
|
---|
16 | public class InformationAnalysisPeakAggregator : Aggregator<InformationAnalysisTable> {
|
---|
17 |
|
---|
18 | [StorableConstructor]
|
---|
19 | protected InformationAnalysisPeakAggregator(bool deserializing) : base(deserializing) { }
|
---|
20 | protected InformationAnalysisPeakAggregator(InformationAnalysisPeakAggregator original, Cloner cloner) : base(original, cloner) { }
|
---|
21 | public InformationAnalysisPeakAggregator() { }
|
---|
22 | public override IDeepCloneable Clone(Cloner cloner) {
|
---|
23 | return new InformationAnalysisPeakAggregator(this, cloner);
|
---|
24 | }
|
---|
25 |
|
---|
26 | public override IResult CreateResult() {
|
---|
27 | return new Result("Inf. Peak", Aggregate(items, 10));
|
---|
28 | }
|
---|
29 |
|
---|
30 | public static ResultCollection Aggregate(List<InformationAnalysisTable> informationAnalysisTables, int nQuantiles) {
|
---|
31 | var informationContent = new List<PointD>();
|
---|
32 | var partialInformationContent = new List<PointD>();
|
---|
33 | var densityBasinInformation = new List<PointD>();
|
---|
34 | foreach (var table in informationAnalysisTables) {
|
---|
35 | List<double> deltas = table.Rows["Quality Delta"].Values.ToList();
|
---|
36 | informationContent.Add(GetPeak(deltas, table.Rows["Information Content"].Values));
|
---|
37 | partialInformationContent.Add(GetPeak(deltas, table.Rows["Partial Information Content"].Values));
|
---|
38 | densityBasinInformation.Add(GetPeak(deltas, table.Rows["Density Basin Information"].Values));
|
---|
39 | }
|
---|
40 | var results = new ResultCollection();
|
---|
41 | results.AddRange(CreateSummary("Q Delt", "Inf Cont", informationContent, true));
|
---|
42 | results.AddRange(CreateSummary("Q Delt", "Part Inf Cont", partialInformationContent, false));
|
---|
43 | results.AddRange(CreateSummary("Q Delt", "Dens Bas Inf", densityBasinInformation, false));
|
---|
44 | return results;
|
---|
45 | }
|
---|
46 |
|
---|
47 | private static PointD GetPeak(IEnumerable<double> index, IEnumerable<double> value) {
|
---|
48 | var max = index.Zip(value, (i, v) => new { i, v }).OrderByDescending(p => p.v).First();
|
---|
49 | return new PointD(max.i, max.v);
|
---|
50 | }
|
---|
51 |
|
---|
52 | private class PointD : IComparable<PointD> {
|
---|
53 | public double X;
|
---|
54 | public double Y;
|
---|
55 | public PointD(double x, double y) {
|
---|
56 | X = x;
|
---|
57 | Y = y;
|
---|
58 | }
|
---|
59 |
|
---|
60 | public int CompareTo(PointD other) {
|
---|
61 | return X.CompareTo(other.X);
|
---|
62 | }
|
---|
63 | }
|
---|
64 |
|
---|
65 | private static IEnumerable<IResult> CreateSummary(string xName, string yName, IEnumerable<PointD> values, bool showX) {
|
---|
66 | var xAnalyzer = new DistributionAnalyzer(values.Select(p => p.X));
|
---|
67 | var yAnalyzer = new DistributionAnalyzer(values.Select(p => p.Y));
|
---|
68 | if (showX) {
|
---|
69 | yield return new Result(xName + " Avg", new DoubleValue(xAnalyzer.Mean));
|
---|
70 | yield return new Result(xName + " Quart-Spread", new DoubleValue(xAnalyzer[0.75] - xAnalyzer[0.25]));
|
---|
71 | yield return new Result(xName + " 90%-Spread", new DoubleValue(xAnalyzer[0.95] - xAnalyzer[0.05]));
|
---|
72 | yield return new Result(xName + " Range", new DoubleValue(xAnalyzer[1] - xAnalyzer[0]));
|
---|
73 | }
|
---|
74 | yield return new Result(yName + " Avg", new DoubleValue(yAnalyzer.Mean));
|
---|
75 | yield return new Result(yName + " Quart-Spread", new DoubleValue(yAnalyzer[0.75] - yAnalyzer[0.25]));
|
---|
76 | yield return new Result(yName + " 90%-Spread", new DoubleValue(yAnalyzer[0.95] - yAnalyzer[0.05]));
|
---|
77 | yield return new Result(yName + " Range", new DoubleValue(yAnalyzer[1] - yAnalyzer[0]));
|
---|
78 |
|
---|
79 | yield return new Result(string.Format("{0}/{1} Quart-Spread", xName, yName), new DoubleValue(
|
---|
80 | Math.Sqrt(sqr(xAnalyzer[0.75] - xAnalyzer[0.25]) + sqr(yAnalyzer[0.75] - yAnalyzer[0.25]))));
|
---|
81 | yield return new Result(string.Format("{0}/{1} 90%-Spread", xName, yName), new DoubleValue(
|
---|
82 | Math.Sqrt(sqr(xAnalyzer[0.95] - xAnalyzer[0.05]) + sqr(yAnalyzer[0.75] - yAnalyzer[0.25]))));
|
---|
83 | yield return new Result(string.Format("{0}/{1} Range", xName, yName), new DoubleValue(
|
---|
84 | Math.Sqrt(sqr(xAnalyzer[1] - xAnalyzer[0]) + sqr(yAnalyzer[1] - yAnalyzer[0]))));
|
---|
85 | }
|
---|
86 |
|
---|
87 | private static double sqr(double x) {
|
---|
88 | return x * x;
|
---|
89 | }
|
---|
90 | }
|
---|
91 | }
|
---|