- Timestamp:
- 03/22/11 16:45:46 (14 years ago)
- Location:
- branches/DataAnalysis Refactoring/HeuristicLab.Algorithms.SimulatedAnnealing/3.3
- Files:
-
- 3 edited
- 1 copied
Legend:
- Unmodified
- Added
- Removed
-
branches/DataAnalysis Refactoring/HeuristicLab.Algorithms.SimulatedAnnealing/3.3/HeuristicLab.Algorithms.SimulatedAnnealing-3.3.csproj
r5163 r5796 12 12 <AssemblyName>HeuristicLab.Algorithms.SimulatedAnnealing-3.3</AssemblyName> 13 13 <TargetFrameworkVersion>v4.0</TargetFrameworkVersion> 14 <TargetFrameworkProfile></TargetFrameworkProfile> 14 <TargetFrameworkProfile> 15 </TargetFrameworkProfile> 15 16 <FileAlignment>512</FileAlignment> 16 17 <SignAssembly>true</SignAssembly> … … 107 108 <ItemGroup> 108 109 <Compile Include="HeuristicLabAlgorithmsSimulatedAnnealingPlugin.cs" /> 110 <Compile Include="SimulatedAnnealingImprovementOperator.cs" /> 109 111 <Compile Include="Properties\AssemblyInfo.cs" /> 110 112 <Compile Include="SimulatedAnnealing.cs" /> -
branches/DataAnalysis Refactoring/HeuristicLab.Algorithms.SimulatedAnnealing/3.3/SimulatedAnnealing.cs
r5644 r5796 189 189 variableCreator.Name = "Initialize EvaluatedMoves"; 190 190 variableCreator.CollectedValues.Add(new ValueParameter<IntValue>("EvaluatedMoves", new IntValue())); 191 variableCreator.CollectedValues.Add(new ValueParameter<IntValue>("Iterations", new IntValue(0))); 191 192 variableCreator.Successor = resultsCollector; 192 193 … … 206 207 mainLoop.AnalyzerParameter.ActualName = AnalyzerParameter.Name; 207 208 mainLoop.EvaluatedMovesParameter.ActualName = "EvaluatedMoves"; 209 mainLoop.IterationsParameter.ActualName = "Iterations"; 208 210 209 211 foreach (IDiscreteDoubleValueModifier op in ApplicationManager.Manager.GetInstances<IDiscreteDoubleValueModifier>().OrderBy(x => x.Name)) -
branches/DataAnalysis Refactoring/HeuristicLab.Algorithms.SimulatedAnnealing/3.3/SimulatedAnnealingImprovementOperator.cs
r5792 r5796 156 156 ChooseMoveOperators(); 157 157 158 ParameterizeMoveGenerators(problem as ISingleObjective Problem);159 ParameterizeMoveEvaluators(problem as ISingleObjective Problem);160 ParameterizeMoveMakers(problem as ISingleObjective Problem);161 162 ParameterizeAnalyzers(problem as ISingleObjective Problem);163 UpdateAnalyzers(problem as ISingleObjective Problem);164 } 165 166 void ParameterizeAnalyzers(ISingleObjective Problem problem) {158 ParameterizeMoveGenerators(problem as ISingleObjectiveHeuristicOptimizationProblem); 159 ParameterizeMoveEvaluators(problem as ISingleObjectiveHeuristicOptimizationProblem); 160 ParameterizeMoveMakers(problem as ISingleObjectiveHeuristicOptimizationProblem); 161 162 ParameterizeAnalyzers(problem as ISingleObjectiveHeuristicOptimizationProblem); 163 UpdateAnalyzers(problem as ISingleObjectiveHeuristicOptimizationProblem); 164 } 165 166 void ParameterizeAnalyzers(ISingleObjectiveHeuristicOptimizationProblem problem) { 167 167 qualityAnalyzer.ResultsParameter.ActualName = "Results"; 168 168 if (problem != null) { … … 174 174 } 175 175 176 void UpdateAnalyzers(ISingleObjective Problem problem) {176 void UpdateAnalyzers(ISingleObjectiveHeuristicOptimizationProblem problem) { 177 177 Analyzer.Operators.Clear(); 178 178 if (problem != null) { … … 270 270 } 271 271 272 private void ParameterizeMoveGenerators(ISingleObjective Problem problem) {272 private void ParameterizeMoveGenerators(ISingleObjectiveHeuristicOptimizationProblem problem) { 273 273 if (problem != null) { 274 274 foreach (IMultiMoveGenerator generator in problem.Operators.OfType<IMultiMoveGenerator>()) … … 276 276 } 277 277 } 278 private void ParameterizeMoveEvaluators(ISingleObjective Problem problem) {278 private void ParameterizeMoveEvaluators(ISingleObjectiveHeuristicOptimizationProblem problem) { 279 279 foreach (ISingleObjectiveMoveEvaluator op in problem.Operators.OfType<ISingleObjectiveMoveEvaluator>()) { 280 280 op.QualityParameter.ActualName = problem.Evaluator.QualityParameter.ActualName; 281 281 } 282 282 } 283 private void ParameterizeMoveMakers(ISingleObjective Problem problem) {283 private void ParameterizeMoveMakers(ISingleObjectiveHeuristicOptimizationProblem problem) { 284 284 foreach (IMoveMaker op in problem.Operators.OfType<IMoveMaker>()) { 285 285 op.QualityParameter.ActualName = problem.Evaluator.QualityParameter.ActualName; -
branches/DataAnalysis Refactoring/HeuristicLab.Algorithms.SimulatedAnnealing/3.3/SimulatedAnnealingMainLoop.cs
r5445 r5796 60 60 get { return (ValueLookupParameter<IntValue>)Parameters["InnerIterations"]; } 61 61 } 62 public LookupParameter<IntValue> IterationsParameter { 63 get { return (LookupParameter<IntValue>)Parameters["LocalIterations"]; } 64 } 62 65 public ValueLookupParameter<IntValue> MaximumIterationsParameter { 63 66 get { return (ValueLookupParameter<IntValue>)Parameters["MaximumIterations"]; } … … 109 112 Parameters.Add(new ValueLookupParameter<DoubleValue>("EndTemperature", "The end temperature.")); 110 113 Parameters.Add(new ValueLookupParameter<IntValue>("InnerIterations", "The amount of inner iterations (number of moves before temperature is adjusted again).")); 114 Parameters.Add(new LookupParameter<IntValue>("LocalIterations", "The number of generations.")); 111 115 Parameters.Add(new ValueLookupParameter<IntValue>("MaximumIterations", "The maximum number of iterations which should be processed.")); 112 116 … … 144 148 ConditionalBranch iterationsTermination = new ConditionalBranch(); 145 149 146 variableCreator.CollectedValues.Add(new ValueParameter<IntValue>("Iterations", new IntValue(0))); // Class SimulatedAnnealing expects this to be called Iterations147 150 variableCreator.CollectedValues.Add(new ValueParameter<DoubleValue>("Temperature", new DoubleValue(double.MaxValue))); 148 151 149 resultsCollector1.CollectedValues.Add(new LookupParameter<IntValue>( "Iterations"));152 resultsCollector1.CollectedValues.Add(new LookupParameter<IntValue>(IterationsParameter.Name)); 150 153 resultsCollector1.CollectedValues.Add(new LookupParameter<DoubleValue>("Temperature")); 151 154 resultsCollector1.ResultsParameter.ActualName = ResultsParameter.Name; … … 180 183 iterationsCounter.Name = "Increment Iterations"; 181 184 iterationsCounter.Increment = new IntValue(1); 182 iterationsCounter.ValueParameter.ActualName = "Iterations";185 iterationsCounter.ValueParameter.ActualName = IterationsParameter.Name; 183 186 184 187 iterationsComparator.Name = "Iterations >= MaximumIterations"; 185 iterationsComparator.LeftSideParameter.ActualName = "Iterations";188 iterationsComparator.LeftSideParameter.ActualName = IterationsParameter.Name; 186 189 iterationsComparator.RightSideParameter.ActualName = MaximumIterationsParameter.Name; 187 190 iterationsComparator.ResultParameter.ActualName = "Terminate";
Note: See TracChangeset
for help on using the changeset viewer.