- Timestamp:
- 06/18/14 15:27:38 (11 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/sources/HeuristicLab.Problems.DataAnalysis.Symbolic/3.4/Analyzers/SymbolicDataAnalysisSingleObjectivePruningAnalyzer.cs
r11013 r11025 1 using System; 1 #region License Information 2 3 /* HeuristicLab 4 * Copyright (C) 2002-2014 Heuristic and Evolutionary Algorithms Laboratory (HEAL) 5 * 6 * This file is part of HeuristicLab. 7 * 8 * HeuristicLab is free software: you can redistribute it and/or modify 9 * it under the terms of the GNU General Public License as published by 10 * the Free Software Foundation, either version 3 of the License, or 11 * (at your option) any later version. 12 * 13 * HeuristicLab is distributed in the hope that it will be useful, 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of 15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16 * GNU General Public License for more details. 17 * 18 * You should have received a copy of the GNU General Public License 19 * along with HeuristicLab. If not, see <http://www.gnu.org/licenses/>. 20 */ 21 22 #endregion 23 24 using System; 2 25 using System.Linq; 3 26 using HeuristicLab.Analysis; … … 29 52 private const string PopulationSizeParameterName = "PopulationSize"; 30 53 #endregion 54 31 55 #region private members 32 56 private DataReducer prunedSubtreesReducer; … … 36 60 private EmptyOperator emptyOp; 37 61 #endregion 62 38 63 #region parameter properties 39 64 public IValueParameter<SymbolicDataAnalysisExpressionPruningOperator> PruningOperatorParameter { … … 49 74 get { return (ILookupParameter<IRandom>)Parameters[RandomParameterName]; } 50 75 } 51 private ILookupParameter<IDataAnalysisProblemData> ProblemDataParameter {52 get { return (ILookupParameter<IDataAnalysisProblemData>)Parameters[ProblemDataParameterName]; }53 }54 76 public IValueParameter<IntValue> UpdateIntervalParameter { 55 77 get { return (IValueParameter<IntValue>)Parameters[UpdateIntervalParameterName]; } … … 68 90 } 69 91 #endregion 92 70 93 #region properties 71 94 protected SymbolicDataAnalysisExpressionPruningOperator PruningOperator { get { return PruningOperatorParameter.Value; } } 72 protected IDataAnalysisProblemData ProblemData { get { return ProblemDataParameter.ActualValue; } }73 95 protected IntValue UpdateInterval { get { return UpdateIntervalParameter.Value; } } 74 96 protected IntValue UpdateCounter { get { return UpdateCounterParameter.Value; } } 75 97 protected DoubleRange PopulationSlice { get { return PopulationSliceParameter.Value; } } 76 98 protected DoubleValue PruningProbability { get { return PruningProbabilityParameter.Value; } } 77 protected IRandom Random { get { return RandomParameter.ActualValue; } } 78 protected DoubleValue NodeImpactThreshold { get { return NodeImpactThresholdParameter.Value; } } 79 protected BoolValue PruneOnlyZeroImpactNodes { get { return PruneOnlyZeroImpactNodesParameter.Value; } } 80 #endregion 99 100 protected bool PruneOnlyZeroImpactNodes { 101 get { return PruneOnlyZeroImpactNodesParameter.Value.Value; } 102 set { PruneOnlyZeroImpactNodesParameter.Value.Value = value; } 103 } 104 protected double NodeImpactThreshold { 105 get { return NodeImpactThresholdParameter.Value.Value; } 106 set { NodeImpactThresholdParameter.Value.Value = value; } 107 } 108 #endregion 109 81 110 #region IStatefulItem members 82 111 public override void InitializeState() { … … 92 121 [StorableConstructor] 93 122 protected SymbolicDataAnalysisSingleObjectivePruningAnalyzer(bool deserializing) : base(deserializing) { } 123 94 124 protected SymbolicDataAnalysisSingleObjectivePruningAnalyzer(SymbolicDataAnalysisSingleObjectivePruningAnalyzer original, Cloner cloner) 95 125 : base(original, cloner) { … … 125 155 } 126 156 127 private void InitializeOperators() {128 prunedSubtreesReducer = new DataReducer();129 prunedSubtreesReducer.ParameterToReduce.ActualName = PruningOperator.PrunedSubtreesParameter.ActualName;130 prunedSubtreesReducer.ReductionOperation.Value = new ReductionOperation(ReductionOperations.Sum); // sum all the pruned subtrees parameter values131 prunedSubtreesReducer.TargetOperation.Value = new ReductionOperation(ReductionOperations.Assign); // asign the sum to the target parameter132 prunedSubtreesReducer.TargetParameter.ActualName = TotalNumberOfPrunedSubtreesParameterName;133 134 prunedTreesReducer = new DataReducer();135 prunedTreesReducer.ParameterToReduce.ActualName = PruningOperator.PrunedTreesParameter.ActualName;136 prunedTreesReducer.ReductionOperation.Value = new ReductionOperation(ReductionOperations.Sum);137 prunedTreesReducer.TargetOperation.Value = new ReductionOperation(ReductionOperations.Assign);138 prunedTreesReducer.TargetParameter.ActualName = TotalNumberOfPrunedTreesParameterName;139 140 valuesCollector = new DataTableValuesCollector();141 valuesCollector.CollectedValues.Add(new LookupParameter<IntValue>(TotalNumberOfPrunedSubtreesParameterName));142 valuesCollector.CollectedValues.Add(new LookupParameter<IntValue>(TotalNumberOfPrunedTreesParameterName));143 valuesCollector.DataTableParameter.ActualName = "Population pruning";144 145 resultsCollector = new ResultsCollector();146 resultsCollector.CollectedValues.Add(new LookupParameter<DataTable>("Population pruning"));147 resultsCollector.ResultsParameter.ActualName = ResultsParameterName;148 149 emptyOp = new EmptyOperator();150 }151 152 157 // 153 158 /// <summary> … … 176 181 177 182 var subscopes = ExecutionContext.Scope.SubScopes; 183 var random = RandomParameter.ActualValue; 178 184 179 185 for (int i = 0; i < subscopes.Count; ++i) { 180 186 IOperator op; 181 if (range.Start <= i && i < range.End && Random.NextDouble() <= PruningProbability.Value)187 if (range.Start <= i && i < range.End && random.NextDouble() <= PruningProbability.Value) 182 188 op = PruningOperator; 183 189 else op = emptyOp; … … 204 210 return new OperationCollection { prune, reducePrunedSubtrees, reducePrunedTrees, collectValues, collectResults, base.Apply() }; 205 211 } 212 213 private void InitializeOperators() { 214 prunedSubtreesReducer = new DataReducer(); 215 prunedSubtreesReducer.ParameterToReduce.ActualName = PruningOperator.PrunedSubtreesParameter.ActualName; 216 prunedSubtreesReducer.ReductionOperation.Value = new ReductionOperation(ReductionOperations.Sum); // sum all the pruned subtrees parameter values 217 prunedSubtreesReducer.TargetOperation.Value = new ReductionOperation(ReductionOperations.Assign); // asign the sum to the target parameter 218 prunedSubtreesReducer.TargetParameter.ActualName = TotalNumberOfPrunedSubtreesParameterName; 219 220 prunedTreesReducer = new DataReducer(); 221 prunedTreesReducer.ParameterToReduce.ActualName = PruningOperator.PrunedTreesParameter.ActualName; 222 prunedTreesReducer.ReductionOperation.Value = new ReductionOperation(ReductionOperations.Sum); 223 prunedTreesReducer.TargetOperation.Value = new ReductionOperation(ReductionOperations.Assign); 224 prunedTreesReducer.TargetParameter.ActualName = TotalNumberOfPrunedTreesParameterName; 225 226 valuesCollector = new DataTableValuesCollector(); 227 valuesCollector.CollectedValues.Add(new LookupParameter<IntValue>(TotalNumberOfPrunedSubtreesParameterName)); 228 valuesCollector.CollectedValues.Add(new LookupParameter<IntValue>(TotalNumberOfPrunedTreesParameterName)); 229 valuesCollector.DataTableParameter.ActualName = "Population pruning"; 230 231 resultsCollector = new ResultsCollector(); 232 resultsCollector.CollectedValues.Add(new LookupParameter<DataTable>("Population pruning")); 233 resultsCollector.ResultsParameter.ActualName = ResultsParameterName; 234 235 emptyOp = new EmptyOperator(); 236 } 206 237 } 207 238 }
Note: See TracChangeset
for help on using the changeset viewer.