Changeset 17434 for branches/1772_HeuristicLab.EvolutionTracking/HeuristicLab.EvolutionTracking/3.4/Analyzers
- Timestamp:
- 02/11/20 13:36:02 (5 years ago)
- Location:
- branches/1772_HeuristicLab.EvolutionTracking/HeuristicLab.EvolutionTracking/3.4/Analyzers
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
branches/1772_HeuristicLab.EvolutionTracking/HeuristicLab.EvolutionTracking/3.4/Analyzers/EvolutionTrackingAnalyzer.cs
r13482 r17434 20 20 #endregion 21 21 22 using HEAL.Attic; 22 23 using HeuristicLab.Common; 23 24 using HeuristicLab.Core; … … 30 31 namespace HeuristicLab.EvolutionTracking { 31 32 [Item("EvolutionTrackingAnalyzer", "Base class for analyzers that use the genealogy graph")] 32 [Storable Class]33 [StorableType("272F8098-CFD0-473C-AFC4-A5F3A51BC154")] 33 34 public abstract class EvolutionTrackingAnalyzer : SingleSuccessorOperator, IAnalyzer { 34 35 #region parameter names … … 92 93 93 94 [StorableConstructor] 94 protected EvolutionTrackingAnalyzer( bool deserializing) : base(deserializing) { }95 protected EvolutionTrackingAnalyzer(StorableConstructorFlag _) : base(_) { } 95 96 } 96 97 97 98 [Item("EvolutionTrackingAnalyzer", "Base class for analyzers that use the genealogy graph")] 98 [Storable Class]99 [StorableType("B48D6E89-3D0F-4F38-BC23-FE648E43421F")] 99 100 public class EvolutionTrackingAnalyzer<T> : EvolutionTrackingAnalyzer where T : class, IItem { 100 101 public EvolutionTrackingAnalyzer() { } … … 107 108 108 109 [StorableConstructor] 109 protected EvolutionTrackingAnalyzer( bool deserializing) : base(deserializing) { }110 protected EvolutionTrackingAnalyzer(StorableConstructorFlag _) : base(_) { } 110 111 111 112 public new IGenealogyGraph<T> PopulationGraph { -
branches/1772_HeuristicLab.EvolutionTracking/HeuristicLab.EvolutionTracking/3.4/Analyzers/GenealogyAnalyzer.cs
r13495 r17434 22 22 using System.Collections.Generic; 23 23 using System.Linq; 24 using HEAL.Attic; 24 25 using HeuristicLab.Common; 25 26 using HeuristicLab.Core; 26 27 using HeuristicLab.Data; 28 using HeuristicLab.EvolutionTracking; 27 29 using HeuristicLab.Operators; 28 30 using HeuristicLab.Optimization; 29 31 using HeuristicLab.Parameters; 30 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 31 32 namespace HeuristicLab.EvolutionTracking { 33 [StorableClass] 34 [Item("GenealogyAnalyzer", "An analyzer which performs the necessary instrumentation to record the evolution of a genetic algorithm.")] 35 public abstract class GenealogyAnalyzer<T> : SingleSuccessorOperator, IAnalyzer 36 where T : class, IItem { 37 #region parameter names 38 private const string GenerationsParameterName = "Generations"; 39 private const string ResultsParameterName = "Results"; 40 private const string PopulationGraphParameterName = "PopulationGraph"; 41 public const string QualityParameterName = "Quality"; 42 public const string PopulationParameterName = "SymbolicExpressionTree"; 43 44 private const string CrossoverParameterName = "Crossover"; 45 private const string ManipulatorParameterName = "Mutator"; 46 private const string SolutionCreatorParameterName = "SolutionCreator"; 47 48 private const string BeforeCrossoverOperatorParameterName = "BeforeCrossoverOperator"; 49 private const string AfterCrossoverOperatorParameterName = "AfterCrossoverOperator"; 50 51 private const string BeforeManipulatorOperatorParameterName = "BeforeManipulatorOperator"; 52 private const string AfterManipulatorOperatorParameterName = "AfterManipulatorOperator"; 53 54 private const string EnableCrossoverTrackingParameterName = "EnableCrossoverTracking"; 55 private const string EnableManipulatorTrackingParameterName = "EnableManipulatorTracking"; 56 private const string EnableSolutionCreatorTrackingParameterName = "EnableSolutionCreatorTracking"; // should always be enabled. maybe superfluous 57 private const string TrimOlderGenerationsParameterName = "TrimOlderGenerations"; 58 #endregion parameter names 59 60 #region parameter properties 61 62 public IFixedValueParameter<BoolValue> TrimOlderGenerationsParameter { 63 get { return (IFixedValueParameter<BoolValue>)Parameters[TrimOlderGenerationsParameterName]; } 64 } 65 66 public IScopeTreeLookupParameter<DoubleValue> QualityParameter { 67 get { return (IScopeTreeLookupParameter<DoubleValue>)Parameters[QualityParameterName]; } 68 } 69 70 public IScopeTreeLookupParameter<T> PopulationParameter { 71 get { return (IScopeTreeLookupParameter<T>)Parameters[PopulationParameterName]; } 72 } 73 74 public IValueParameter<ICrossoverOperator<T>> BeforeCrossoverOperatorParameter { 75 get { return (IValueParameter<ICrossoverOperator<T>>)Parameters[BeforeCrossoverOperatorParameterName]; } 76 } 77 78 public IValueParameter<ICrossoverOperator<T>> AfterCrossoverOperatorParameter { 79 get { return (IValueParameter<ICrossoverOperator<T>>)Parameters[AfterCrossoverOperatorParameterName]; } 80 } 81 82 public IValueParameter<IManipulatorOperator<T>> BeforeManipulatorOperatorParameter { 83 get { return (IValueParameter<IManipulatorOperator<T>>)Parameters[BeforeManipulatorOperatorParameterName]; } 84 } 85 86 public IValueParameter<IManipulatorOperator<T>> AfterManipulatorOperatorParameter { 87 get { return (IValueParameter<IManipulatorOperator<T>>)Parameters[AfterManipulatorOperatorParameterName]; } 88 } 89 90 public ILookupParameter<ResultCollection> ResultsParameter { 91 get { return (ILookupParameter<ResultCollection>)Parameters[ResultsParameterName]; } 92 } 93 94 public ILookupParameter<IntValue> GenerationsParameter { 95 get { return (ILookupParameter<IntValue>)Parameters[GenerationsParameterName]; } 96 } 97 98 public IValueParameter<BoolValue> EnableCrossoverTrackingParameter { 99 get { return (IValueParameter<BoolValue>)Parameters[EnableCrossoverTrackingParameterName]; } 100 } 101 102 public IValueParameter<BoolValue> EnableManipulatorTrackingParameter { 103 get { return (IValueParameter<BoolValue>)Parameters[EnableManipulatorTrackingParameterName]; } 104 } 105 106 public IValueParameter<BoolValue> EnableSolutionCreatorTrackingParameter { 107 get { return (IValueParameter<BoolValue>)Parameters[EnableSolutionCreatorTrackingParameterName]; } 108 } 109 110 public ILookupParameter<ICrossover> CrossoverParameter { 111 get { return (ILookupParameter<ICrossover>)Parameters[CrossoverParameterName]; } 112 } 113 114 public ILookupParameter<IManipulator> ManipulatorParameter { 115 get { return (ILookupParameter<IManipulator>)Parameters[ManipulatorParameterName]; } 116 } 117 118 public ILookupParameter<ISolutionCreator> SolutionCreatorParameter { 119 get { return (ILookupParameter<ISolutionCreator>)Parameters[SolutionCreatorParameterName]; } 120 } 121 #endregion parameter properties 122 123 #region properties 124 public ICrossoverOperator<T> BeforeCrossoverOperator { 125 get { return BeforeCrossoverOperatorParameter.Value; } 126 } 127 128 public ICrossoverOperator<T> AfterCrossoverOperator { 129 get { return AfterCrossoverOperatorParameter.Value; } 130 } 131 132 public IManipulatorOperator<T> BeforeManipulatorOperator { 133 get { return BeforeManipulatorOperatorParameter.Value; } 134 } 135 136 public IManipulatorOperator<T> AfterManipulatorOperator { 137 get { return AfterManipulatorOperatorParameter.Value; } 138 } 139 140 public BoolValue EnableCrossoverTracking { 141 get { return EnableCrossoverTrackingParameter.Value; } 142 } 143 144 public BoolValue EnableManipulatorTracking { 145 get { return EnableManipulatorTrackingParameter.Value; } 146 } 147 148 public BoolValue EnableSolutionCreatorTracking { 149 get { return EnableSolutionCreatorTrackingParameter.Value; } 150 } 151 152 public bool TrimOlderGenerations { 153 get { return TrimOlderGenerationsParameter.Value.Value; } 154 } 155 #endregion properties 156 157 protected GenealogyAnalyzer() { 158 #region add parameters 159 // the instrumented operators 32 33 [Item("GenealogyAnalyzer", "An analyzer which performs the necessary instrumentation to record the evolution of a genetic algorithm.")] 34 [StorableType("04001C52-025C-4555-8812-AC3FA26A2B2F")] 35 public abstract class GenealogyAnalyzer<T> : SingleSuccessorOperator, IAnalyzer 36 where T : class, IItem 37 { 38 #region parameter names 39 private const string GenerationsParameterName = "Generations"; 40 private const string ResultsParameterName = "Results"; 41 private const string PopulationGraphParameterName = "PopulationGraph"; 42 public const string QualityParameterName = "Quality"; 43 public const string PopulationParameterName = "SymbolicExpressionTree"; 44 45 private const string CrossoverParameterName = "Crossover"; 46 private const string ManipulatorParameterName = "Mutator"; 47 private const string SolutionCreatorParameterName = "SolutionCreator"; 48 49 private const string BeforeCrossoverOperatorParameterName = "BeforeCrossoverOperator"; 50 private const string AfterCrossoverOperatorParameterName = "AfterCrossoverOperator"; 51 52 private const string BeforeManipulatorOperatorParameterName = "BeforeManipulatorOperator"; 53 private const string AfterManipulatorOperatorParameterName = "AfterManipulatorOperator"; 54 55 private const string EnableCrossoverTrackingParameterName = "EnableCrossoverTracking"; 56 private const string EnableManipulatorTrackingParameterName = "EnableManipulatorTracking"; 57 private const string EnableSolutionCreatorTrackingParameterName = "EnableSolutionCreatorTracking"; // should always be enabled. maybe superfluous 58 private const string TrimOlderGenerationsParameterName = "TrimOlderGenerations"; 59 #endregion parameter names 60 61 #region parameter properties 62 63 public IFixedValueParameter<BoolValue> TrimOlderGenerationsParameter { 64 get { return (IFixedValueParameter<BoolValue>)Parameters[TrimOlderGenerationsParameterName]; } 65 } 66 67 public IScopeTreeLookupParameter<DoubleValue> QualityParameter { 68 get { return (IScopeTreeLookupParameter<DoubleValue>)Parameters[QualityParameterName]; } 69 } 70 71 public IScopeTreeLookupParameter<T> PopulationParameter { 72 get { return (IScopeTreeLookupParameter<T>)Parameters[PopulationParameterName]; } 73 } 74 75 public IValueParameter<ICrossoverOperator<T>> BeforeCrossoverOperatorParameter { 76 get { return (IValueParameter<ICrossoverOperator<T>>)Parameters[BeforeCrossoverOperatorParameterName]; } 77 } 78 79 public IValueParameter<ICrossoverOperator<T>> AfterCrossoverOperatorParameter { 80 get { return (IValueParameter<ICrossoverOperator<T>>)Parameters[AfterCrossoverOperatorParameterName]; } 81 } 82 83 public IValueParameter<IManipulatorOperator<T>> BeforeManipulatorOperatorParameter { 84 get { return (IValueParameter<IManipulatorOperator<T>>)Parameters[BeforeManipulatorOperatorParameterName]; } 85 } 86 87 public IValueParameter<IManipulatorOperator<T>> AfterManipulatorOperatorParameter { 88 get { return (IValueParameter<IManipulatorOperator<T>>)Parameters[AfterManipulatorOperatorParameterName]; } 89 } 90 91 public ILookupParameter<ResultCollection> ResultsParameter { 92 get { return (ILookupParameter<ResultCollection>)Parameters[ResultsParameterName]; } 93 } 94 95 public ILookupParameter<IntValue> GenerationsParameter { 96 get { return (ILookupParameter<IntValue>)Parameters[GenerationsParameterName]; } 97 } 98 99 public IValueParameter<BoolValue> EnableCrossoverTrackingParameter { 100 get { return (IValueParameter<BoolValue>)Parameters[EnableCrossoverTrackingParameterName]; } 101 } 102 103 public IValueParameter<BoolValue> EnableManipulatorTrackingParameter { 104 get { return (IValueParameter<BoolValue>)Parameters[EnableManipulatorTrackingParameterName]; } 105 } 106 107 public IValueParameter<BoolValue> EnableSolutionCreatorTrackingParameter { 108 get { return (IValueParameter<BoolValue>)Parameters[EnableSolutionCreatorTrackingParameterName]; } 109 } 110 111 public ILookupParameter<ICrossover> CrossoverParameter { 112 get { return (ILookupParameter<ICrossover>)Parameters[CrossoverParameterName]; } 113 } 114 115 public ILookupParameter<IManipulator> ManipulatorParameter { 116 get { return (ILookupParameter<IManipulator>)Parameters[ManipulatorParameterName]; } 117 } 118 119 public ILookupParameter<ISolutionCreator> SolutionCreatorParameter { 120 get { return (ILookupParameter<ISolutionCreator>)Parameters[SolutionCreatorParameterName]; } 121 } 122 #endregion parameter properties 123 124 #region properties 125 public ICrossoverOperator<T> BeforeCrossoverOperator { 126 get { return BeforeCrossoverOperatorParameter.Value; } 127 } 128 129 public ICrossoverOperator<T> AfterCrossoverOperator { 130 get { return AfterCrossoverOperatorParameter.Value; } 131 } 132 133 public IManipulatorOperator<T> BeforeManipulatorOperator { 134 get { return BeforeManipulatorOperatorParameter.Value; } 135 } 136 137 public IManipulatorOperator<T> AfterManipulatorOperator { 138 get { return AfterManipulatorOperatorParameter.Value; } 139 } 140 141 public BoolValue EnableCrossoverTracking { 142 get { return EnableCrossoverTrackingParameter.Value; } 143 } 144 145 public BoolValue EnableManipulatorTracking { 146 get { return EnableManipulatorTrackingParameter.Value; } 147 } 148 149 public BoolValue EnableSolutionCreatorTracking { 150 get { return EnableSolutionCreatorTrackingParameter.Value; } 151 } 152 153 public bool TrimOlderGenerations { 154 get { return TrimOlderGenerationsParameter.Value.Value; } 155 } 156 #endregion properties 157 158 protected GenealogyAnalyzer() { 159 #region add parameters 160 // the instrumented operators 161 Parameters.Add(new LookupParameter<ICrossover>(CrossoverParameterName, "The crossover operator.")); 162 Parameters.Add(new LookupParameter<IManipulator>(ManipulatorParameterName, "The manipulator operator.")); 163 Parameters.Add(new LookupParameter<ISolutionCreator>(SolutionCreatorParameterName, "The solution creator operator.")); 164 // the analyzer parameters 165 Parameters.Add(new ValueParameter<BoolValue>(EnableCrossoverTrackingParameterName, new BoolValue(true))); 166 Parameters.Add(new ValueParameter<BoolValue>(EnableManipulatorTrackingParameterName, new BoolValue(true))); 167 Parameters.Add(new ValueParameter<BoolValue>(EnableSolutionCreatorTrackingParameterName, new BoolValue(true))); 168 // parameters required by the analyzer to do its work 169 Parameters.Add(new LookupParameter<IntValue>(GenerationsParameterName, "The number of generations so far.")); 170 Parameters.Add(new LookupParameter<ResultCollection>(ResultsParameterName)); 171 Parameters.Add(new ScopeTreeLookupParameter<T>(PopulationParameterName, "The population of individuals.")); 172 Parameters.Add(new ScopeTreeLookupParameter<DoubleValue>(QualityParameterName, "The individual qualities.")); 173 Parameters.Add(new ValueParameter<ICrossoverOperator<T>>(BeforeCrossoverOperatorParameterName)); 174 Parameters.Add(new ValueParameter<ICrossoverOperator<T>>(AfterCrossoverOperatorParameterName)); 175 Parameters.Add(new ValueParameter<IManipulatorOperator<T>>(BeforeManipulatorOperatorParameterName)); 176 Parameters.Add(new ValueParameter<IManipulatorOperator<T>>(AfterManipulatorOperatorParameterName)); 177 Parameters.Add(new FixedValueParameter<BoolValue>(TrimOlderGenerationsParameterName, "Remove all the generations older than the last generation from the genealoy graph to save memory.")); 178 #endregion add parameters 179 } 180 181 protected GenealogyAnalyzer(GenealogyAnalyzer<T> original, Cloner cloner) 182 : base(original, cloner) { 183 } 184 185 [StorableConstructor] 186 protected GenealogyAnalyzer(StorableConstructorFlag _) : base(_) { } 187 188 [StorableHook(HookType.AfterDeserialization)] 189 private void AfterDeserialization() { 190 // the instrumented operators 191 if (!Parameters.ContainsKey(CrossoverParameterName)) 160 192 Parameters.Add(new LookupParameter<ICrossover>(CrossoverParameterName, "The crossover operator.")); 193 if (!Parameters.ContainsKey(ManipulatorParameterName)) 161 194 Parameters.Add(new LookupParameter<IManipulator>(ManipulatorParameterName, "The manipulator operator.")); 195 if (!Parameters.ContainsKey(SolutionCreatorParameterName)) 162 196 Parameters.Add(new LookupParameter<ISolutionCreator>(SolutionCreatorParameterName, "The solution creator operator.")); 163 // the analyzer parameters 197 // the analyzer parameters 198 if (!Parameters.ContainsKey(EnableCrossoverTrackingParameterName)) 164 199 Parameters.Add(new ValueParameter<BoolValue>(EnableCrossoverTrackingParameterName, new BoolValue(true))); 200 if (!Parameters.ContainsKey(EnableManipulatorTrackingParameterName)) 165 201 Parameters.Add(new ValueParameter<BoolValue>(EnableManipulatorTrackingParameterName, new BoolValue(true))); 202 if (!Parameters.ContainsKey(EnableSolutionCreatorTrackingParameterName)) 166 203 Parameters.Add(new ValueParameter<BoolValue>(EnableSolutionCreatorTrackingParameterName, new BoolValue(true))); 167 // parameters required by the analyzer to do its work 204 // parameters required by the analyzer to do its work 205 if (!Parameters.ContainsKey(GenerationsParameterName)) 168 206 Parameters.Add(new LookupParameter<IntValue>(GenerationsParameterName, "The number of generations so far.")); 207 if (!Parameters.ContainsKey(ResultsParameterName)) 169 208 Parameters.Add(new LookupParameter<ResultCollection>(ResultsParameterName)); 209 if (!Parameters.ContainsKey(PopulationParameterName)) { 170 210 Parameters.Add(new ScopeTreeLookupParameter<T>(PopulationParameterName, "The population of individuals.")); 211 } 212 if (!Parameters.ContainsKey(QualityParameterName)) { 171 213 Parameters.Add(new ScopeTreeLookupParameter<DoubleValue>(QualityParameterName, "The individual qualities.")); 172 Parameters.Add(new ValueParameter<ICrossoverOperator<T>>(BeforeCrossoverOperatorParameterName)); 173 Parameters.Add(new ValueParameter<ICrossoverOperator<T>>(AfterCrossoverOperatorParameterName)); 174 Parameters.Add(new ValueParameter<IManipulatorOperator<T>>(BeforeManipulatorOperatorParameterName)); 175 Parameters.Add(new ValueParameter<IManipulatorOperator<T>>(AfterManipulatorOperatorParameterName)); 214 } 215 if (!Parameters.ContainsKey(TrimOlderGenerationsParameterName)) 176 216 Parameters.Add(new FixedValueParameter<BoolValue>(TrimOlderGenerationsParameterName, "Remove all the generations older than the last generation from the genealoy graph to save memory.")); 177 #endregion add parameters 178 } 179 180 protected GenealogyAnalyzer(GenealogyAnalyzer<T> original, Cloner cloner) 181 : base(original, cloner) { 182 } 183 184 [StorableConstructor] 185 protected GenealogyAnalyzer(bool deserializing) : base(deserializing) { } 186 187 [StorableHook(HookType.AfterDeserialization)] 188 private void AfterDeserialization() { 189 // the instrumented operators 190 if (!Parameters.ContainsKey(CrossoverParameterName)) 191 Parameters.Add(new LookupParameter<ICrossover>(CrossoverParameterName, "The crossover operator.")); 192 if (!Parameters.ContainsKey(ManipulatorParameterName)) 193 Parameters.Add(new LookupParameter<IManipulator>(ManipulatorParameterName, "The manipulator operator.")); 194 if (!Parameters.ContainsKey(SolutionCreatorParameterName)) 195 Parameters.Add(new LookupParameter<ISolutionCreator>(SolutionCreatorParameterName, "The solution creator operator.")); 196 // the analyzer parameters 197 if (!Parameters.ContainsKey(EnableCrossoverTrackingParameterName)) 198 Parameters.Add(new ValueParameter<BoolValue>(EnableCrossoverTrackingParameterName, new BoolValue(true))); 199 if (!Parameters.ContainsKey(EnableManipulatorTrackingParameterName)) 200 Parameters.Add(new ValueParameter<BoolValue>(EnableManipulatorTrackingParameterName, new BoolValue(true))); 201 if (!Parameters.ContainsKey(EnableSolutionCreatorTrackingParameterName)) 202 Parameters.Add(new ValueParameter<BoolValue>(EnableSolutionCreatorTrackingParameterName, new BoolValue(true))); 203 // parameters required by the analyzer to do its work 204 if (!Parameters.ContainsKey(GenerationsParameterName)) 205 Parameters.Add(new LookupParameter<IntValue>(GenerationsParameterName, "The number of generations so far.")); 206 if (!Parameters.ContainsKey(ResultsParameterName)) 207 Parameters.Add(new LookupParameter<ResultCollection>(ResultsParameterName)); 208 if (!Parameters.ContainsKey(PopulationParameterName)) { 209 Parameters.Add(new ScopeTreeLookupParameter<T>(PopulationParameterName, "The population of individuals.")); 210 } 211 if (!Parameters.ContainsKey(QualityParameterName)) { 212 Parameters.Add(new ScopeTreeLookupParameter<DoubleValue>(QualityParameterName, "The individual qualities.")); 213 } 214 if (!Parameters.ContainsKey(TrimOlderGenerationsParameterName)) 215 Parameters.Add(new FixedValueParameter<BoolValue>(TrimOlderGenerationsParameterName, "Remove all the generations older than the last generation from the genealoy graph to save memory.")); 216 } 217 218 public bool EnabledByDefault { 219 get { return false; } 220 } 221 222 private void ConfigureTrackingOperators() { 223 // at the beginning we add the before/after operators to the instrumented operators 224 var crossover = CrossoverParameter.ActualValue; 225 if (crossover != null) { 226 var instrumentedCrossover = (InstrumentedOperator)crossover; 227 instrumentedCrossover.AfterExecutionOperators.Clear(); 228 instrumentedCrossover.BeforeExecutionOperators.Clear(); 229 230 if (EnableCrossoverTracking.Value) { 231 if (BeforeCrossoverOperator != null) { 232 instrumentedCrossover.BeforeExecutionOperators.Add(BeforeCrossoverOperator); 233 } 234 if (AfterCrossoverOperator != null) { 235 instrumentedCrossover.AfterExecutionOperators.Add(AfterCrossoverOperator); 236 } 237 } 238 } 239 var manipulator = ManipulatorParameter.ActualValue; 240 if (manipulator != null) { 241 var instrumentedManipulator = (InstrumentedOperator)manipulator; 242 instrumentedManipulator.AfterExecutionOperators.Clear(); 243 instrumentedManipulator.BeforeExecutionOperators.Clear(); 244 245 if (EnableManipulatorTracking.Value) { 246 if (BeforeManipulatorOperator != null) { 247 instrumentedManipulator.BeforeExecutionOperators.Add(BeforeManipulatorOperator); 248 } 249 if (AfterManipulatorOperator != null) { 250 instrumentedManipulator.AfterExecutionOperators.Add(AfterManipulatorOperator); 251 } 252 } 253 } 254 } 255 256 protected abstract void EvaluateIntermediateChildren(); 257 258 public override IOperation Apply() { 259 IGenealogyGraph<T> genealogyGraph; 260 var results = ResultsParameter.ActualValue; 261 if (!results.ContainsKey(PopulationGraphParameterName)) { 262 genealogyGraph = new GenealogyGraph<T>(); 263 results.Add(new Result(PopulationGraphParameterName, genealogyGraph)); 264 } else { 265 genealogyGraph = (IGenealogyGraph<T>)results[PopulationGraphParameterName].Value; 266 } 267 268 var population = PopulationParameter.ActualValue; 269 var qualities = QualityParameter.ActualValue; 270 271 int generation = GenerationsParameter.ActualValue.Value; 272 if (generation == 0) { 273 ConfigureTrackingOperators(); 274 275 for (int i = 0; i < population.Length; ++i) { 276 var individual = population[i]; 277 var vertex = new GenealogyGraphNode<T>(individual) { Rank = generation }; 278 genealogyGraph.AddVertex(vertex); 279 // save the vertex id in the individual scope (so that we can identify graph indices) 280 ExecutionContext.Scope.SubScopes[i].Variables.Add(new Variable("Id", new StringValue(vertex.Id))); 281 } 282 } else { 283 int index = 0; 284 T elite = null; 285 // identify previous elite individual 286 for (int i = 0; i < population.Length; ++i) { 287 if (genealogyGraph.GetByContent(population[i]).Rank.Equals(generation - 1)) { 288 elite = population[i]; 289 index = i; 290 break; 291 } 292 } 293 // add current elite and connect with previous 294 #region add elite in the graph and connect it with the previous elite 295 if (elite != null) { 296 var prevVertex = genealogyGraph.GetByContent(elite); 297 prevVertex.IsElite = true; // mark elites in the graph retroactively 298 var v = (IGenealogyGraphNode<T>)prevVertex.Clone(); 299 v.Rank = generation; 300 v.IsElite = false; 301 population[index] = v.Data; 302 genealogyGraph.AddVertex(v); 303 genealogyGraph.AddArc(prevVertex, v); 304 // inject the graph node unique id to the scope 305 ExecutionContext.Scope.SubScopes[index].Variables[BeforeManipulatorOperator.ChildParameter.ActualName].Value = v.Data; 306 ExecutionContext.Scope.SubScopes[index].Variables["Id"].Value = new StringValue(v.Id); 307 } 308 #endregion add elite in the graph and connect it with the previous elite 309 } 310 // update qualities 217 } 218 219 public bool EnabledByDefault { 220 get { return false; } 221 } 222 223 private void ConfigureTrackingOperators() { 224 // at the beginning we add the before/after operators to the instrumented operators 225 var crossover = CrossoverParameter.ActualValue; 226 if (crossover != null) { 227 var instrumentedCrossover = (InstrumentedOperator)crossover; 228 instrumentedCrossover.AfterExecutionOperators.Clear(); 229 instrumentedCrossover.BeforeExecutionOperators.Clear(); 230 231 if (EnableCrossoverTracking.Value) { 232 if (BeforeCrossoverOperator != null) { 233 instrumentedCrossover.BeforeExecutionOperators.Add(BeforeCrossoverOperator); 234 } 235 if (AfterCrossoverOperator != null) { 236 instrumentedCrossover.AfterExecutionOperators.Add(AfterCrossoverOperator); 237 } 238 } 239 } 240 var manipulator = ManipulatorParameter.ActualValue; 241 if (manipulator != null) { 242 var instrumentedManipulator = (InstrumentedOperator)manipulator; 243 instrumentedManipulator.AfterExecutionOperators.Clear(); 244 instrumentedManipulator.BeforeExecutionOperators.Clear(); 245 246 if (EnableManipulatorTracking.Value) { 247 if (BeforeManipulatorOperator != null) { 248 instrumentedManipulator.BeforeExecutionOperators.Add(BeforeManipulatorOperator); 249 } 250 if (AfterManipulatorOperator != null) { 251 instrumentedManipulator.AfterExecutionOperators.Add(AfterManipulatorOperator); 252 } 253 } 254 } 255 } 256 257 protected abstract void EvaluateIntermediateChildren(); 258 259 public override IOperation Apply() { 260 IGenealogyGraph<T> genealogyGraph; 261 var results = ResultsParameter.ActualValue; 262 if (!results.ContainsKey(PopulationGraphParameterName)) { 263 genealogyGraph = new GenealogyGraph<T>(); 264 results.Add(new Result(PopulationGraphParameterName, genealogyGraph)); 265 } else { 266 genealogyGraph = (IGenealogyGraph<T>)results[PopulationGraphParameterName].Value; 267 } 268 269 var population = PopulationParameter.ActualValue; 270 var qualities = QualityParameter.ActualValue; 271 272 int generation = GenerationsParameter.ActualValue.Value; 273 if (generation == 0) { 274 ConfigureTrackingOperators(); 275 311 276 for (int i = 0; i < population.Length; ++i) { 312 var vertex = genealogyGraph.GetByContent(population[i]); 313 vertex.Quality = qualities[i].Value; 314 } 315 // update qualities for intermediate vertices 316 EvaluateIntermediateChildren(); 317 318 // remove extra graph nodes (added by the instrumented operators in the case of offspring selection) 319 var pop = new HashSet<T>(population); 320 var discarded = genealogyGraph.GetByRank(generation).Where(x => !pop.Contains(x.Data)).ToList(); 321 for (int i = 0; i < discarded.Count; ++i) { 322 var v = discarded[i]; 323 if (v.InDegree == 1) { 324 var p = v.Parents.First(); 325 if (p.Rank.Equals(generation - 0.5)) 326 // the individual was a product of mutation. since it wasn't selected, we must remove both it and its parent 327 // ("intermediate" vertex result of crossover) 328 discarded.Add(v.Parents.First()); 329 } 330 } 331 genealogyGraph.RemoveVertices(discarded); 332 333 //trim 334 if (TrimOlderGenerations) { 335 var vertices = genealogyGraph.Vertices.Where(x => x.Rank < generation - 1).ToList(); // select all ranks older than the previous generation 336 genealogyGraph.RemoveVertices(vertices); 337 } 338 339 return base.Apply(); 340 } 277 var individual = population[i]; 278 var vertex = new GenealogyGraphNode<T>(individual) { Rank = generation }; 279 genealogyGraph.AddVertex(vertex); 280 // save the vertex id in the individual scope (so that we can identify graph indices) 281 ExecutionContext.Scope.SubScopes[i].Variables.Add(new Variable("Id", new StringValue(vertex.Id))); 282 } 283 } else { 284 int index = 0; 285 T elite = null; 286 // identify previous elite individual 287 for (int i = 0; i < population.Length; ++i) { 288 if (genealogyGraph.GetByContent(population[i]).Rank.Equals(generation - 1)) { 289 elite = population[i]; 290 index = i; 291 break; 292 } 293 } 294 // add current elite and connect with previous 295 #region add elite in the graph and connect it with the previous elite 296 if (elite != null) { 297 var prevVertex = genealogyGraph.GetByContent(elite); 298 prevVertex.IsElite = true; // mark elites in the graph retroactively 299 var v = (IGenealogyGraphNode<T>)prevVertex.Clone(); 300 v.Rank = generation; 301 v.IsElite = false; 302 population[index] = v.Data; 303 genealogyGraph.AddVertex(v); 304 genealogyGraph.AddArc(prevVertex, v); 305 // inject the graph node unique id to the scope 306 ExecutionContext.Scope.SubScopes[index].Variables[BeforeManipulatorOperator.ChildParameter.ActualName].Value = v.Data; 307 ExecutionContext.Scope.SubScopes[index].Variables["Id"].Value = new StringValue(v.Id); 308 } 309 #endregion add elite in the graph and connect it with the previous elite 310 } 311 // update qualities 312 for (int i = 0; i < population.Length; ++i) { 313 var vertex = genealogyGraph.GetByContent(population[i]); 314 vertex.Quality = qualities[i].Value; 315 } 316 // update qualities for intermediate vertices 317 EvaluateIntermediateChildren(); 318 319 // remove extra graph nodes (added by the instrumented operators in the case of offspring selection) 320 var pop = new HashSet<T>(population); 321 var discarded = genealogyGraph.GetByRank(generation).Where(x => !pop.Contains(x.Data)).ToList(); 322 for (int i = 0; i < discarded.Count; ++i) { 323 var v = discarded[i]; 324 if (v.InDegree == 1) { 325 var p = v.Parents.First(); 326 if (p.Rank.Equals(generation - 0.5)) 327 // the individual was a product of mutation. since it wasn't selected, we must remove both it and its parent 328 // ("intermediate" vertex result of crossover) 329 discarded.Add(v.Parents.First()); 330 } 331 } 332 genealogyGraph.RemoveVertices(discarded); 333 334 //trim 335 if (TrimOlderGenerations) { 336 var vertices = genealogyGraph.Vertices.Where(x => x.Rank < generation - 1).ToList(); // select all ranks older than the previous generation 337 genealogyGraph.RemoveVertices(vertices); 338 } 339 340 return base.Apply(); 341 341 } 342 342 } -
branches/1772_HeuristicLab.EvolutionTracking/HeuristicLab.EvolutionTracking/3.4/Analyzers/SelectionSchemeAnalyzer.cs
r12894 r17434 21 21 22 22 using System.Linq; 23 using HEAL.Attic; 23 24 using HeuristicLab.Analysis; 24 25 using HeuristicLab.Common; … … 29 30 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 30 31 31 namespace HeuristicLab.EvolutionTracking { 32 namespace HeuristicLab.EvolutionTracking 33 { 32 34 [Item("SelectionSchemeAnalyzer", "An analyzer which gives information about the relative amount of individuals that get selected each generation")] 33 [StorableClass] 34 public class SelectionSchemeAnalyzer : EvolutionTrackingAnalyzer { 35 [StorableType("96FBBBE5-059C-4EA7-A633-0D2CBD7F58BE")] 36 public class SelectionSchemeAnalyzer : EvolutionTrackingAnalyzer 37 { 35 38 private const string StoreHistoryParameterName = "StoreHistory"; 36 39 … … 47 50 48 51 [StorableConstructor] 49 protected SelectionSchemeAnalyzer( bool deserializing) : base(deserializing) { }52 protected SelectionSchemeAnalyzer(StorableConstructorFlag _) : base(_) { } 50 53 51 54 protected SelectionSchemeAnalyzer(SelectionSchemeAnalyzer original, Cloner cloner) : base(original, cloner) { }
Note: See TracChangeset
for help on using the changeset viewer.