- Timestamp:
- 02/24/11 17:08:11 (14 years ago)
- Location:
- trunk/sources/HeuristicLab.Algorithms.ParticleSwarmOptimization/3.3
- Files:
-
- 1 added
- 10 deleted
- 9 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/sources/HeuristicLab.Algorithms.ParticleSwarmOptimization/3.3/HeuristicLab.Algorithms.ParticleSwarmOptimization-3.3.csproj
r5426 r5560 107 107 <ItemGroup> 108 108 <Compile Include="BestPointInitializer.cs" /> 109 <Compile Include="IDiscreteDoubleMatrixModifier.cs" />110 <Compile Include="IGlobalParticleUpdater.cs" />111 <Compile Include="ILocalParticleUpdater.cs" />112 109 <Compile Include="MultiPSOTopologyUpdater.cs" /> 110 <Compile Include="ParticleSwarmOptimizationMainLoop.cs" /> 113 111 <Compile Include="VelocityBoundsModifier.cs" /> 114 112 <Compile Include="RandomTopologyInitializer.cs" /> 115 113 <Compile Include="VonNeumannTopologyInitializer.cs" /> 116 114 <Compile Include="RingTopologyInitializer.cs" /> 117 <Compile Include="ITopologyUpdater.cs" />118 115 <Compile Include="NeighborUpdater.cs" /> 119 116 <Compile Include="TopologyInitializer.cs" /> 120 <Compile Include="ITopologyInitializer.cs" />121 <Compile Include="NeighborhoodParticleUpdater.cs" />122 <Compile Include="IParticleUpdater.cs" />123 <Compile Include="TotallyConnectedParticleUpdater.cs" />124 117 <Compile Include="HeuristicLabAlgorithmsParticleSwarmOptimizationPlugin.cs" /> 125 118 <Compile Include="ParticleSwarmOptimization.cs" /> 126 119 <Compile Include="Properties\AssemblyInfo.cs" /> 127 <Compile Include="ParticleUpdater.cs" />128 <Compile Include="SwarmUpdater.cs" />129 120 </ItemGroup> 130 121 <ItemGroup> -
trunk/sources/HeuristicLab.Algorithms.ParticleSwarmOptimization/3.3/HeuristicLabAlgorithmsParticleSwarmOptimizationPlugin.cs.frame
r5446 r5560 34 34 [PluginDependency("HeuristicLab.Data", "3.3")] 35 35 [PluginDependency("HeuristicLab.Encodings.RealVectorEncoding", "3.3")] 36 [PluginDependency("HeuristicLab.Encodings.IntegerVectorEncoding", "3.3")]37 36 [PluginDependency("HeuristicLab.Operators", "3.3")] 38 37 [PluginDependency("HeuristicLab.Optimization", "3.3")] -
trunk/sources/HeuristicLab.Algorithms.ParticleSwarmOptimization/3.3/MultiPSOTopologyUpdater.cs
r5435 r5560 25 25 using HeuristicLab.Core; 26 26 using HeuristicLab.Data; 27 using HeuristicLab.Encodings.IntegerVectorEncoding;28 27 using HeuristicLab.Operators; 28 using HeuristicLab.Optimization; 29 29 using HeuristicLab.Parameters; 30 30 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 31 31 32 32 namespace HeuristicLab.Algorithms.ParticleSwarmOptimization { 33 [Item("Multi PSO Topology Initializer/Updater", "Splits swarm into swarmsize / (nrOfConnections + 1) non-overlapping sub-swarms. Swarms are re-grouped every regroupingPeriod iteration. The operator is implemented as described in Liang, J.J. and Suganthan, P.N 2005. Dynamic multi-swarm particle swarm optimizer. IEEE Swarm Intelligence Symposium, pp. 124-129.")]33 [Item("Multi PSO Topology Updater", "Splits swarm into swarmsize / (nrOfConnections + 1) non-overlapping sub-swarms. Swarms are re-grouped every regroupingPeriod iteration. The operator is implemented as described in Liang, J.J. and Suganthan, P.N 2005. Dynamic multi-swarm particle swarm optimizer. IEEE Swarm Intelligence Symposium, pp. 124-129.")] 34 34 [StorableClass] 35 public sealed class MultiPSOTopologyUpdater : SingleSuccessorOperator, ITopologyUpdater , ITopologyInitializer{35 public sealed class MultiPSOTopologyUpdater : SingleSuccessorOperator, ITopologyUpdater { 36 36 public override bool CanChangeName { 37 37 get { return false; } … … 48 48 get { return (ILookupParameter<IntValue>)Parameters["SwarmSize"]; } 49 49 } 50 public IScopeTreeLookupParameter<Int egerVector> NeighborsParameter {51 get { return (IScopeTreeLookupParameter<Int egerVector>)Parameters["Neighbors"]; }50 public IScopeTreeLookupParameter<IntArray> NeighborsParameter { 51 get { return (IScopeTreeLookupParameter<IntArray>)Parameters["Neighbors"]; } 52 52 } 53 53 public ILookupParameter<IntValue> CurrentIterationParameter { … … 69 69 get { return SwarmSizeParameter.ActualValue.Value; } 70 70 } 71 private ItemArray<Int egerVector> Neighbors {71 private ItemArray<IntArray> Neighbors { 72 72 get { return NeighborsParameter.ActualValue; } 73 73 set { NeighborsParameter.ActualValue = value; } … … 84 84 private MultiPSOTopologyUpdater(bool deserializing) : base(deserializing) { } 85 85 private MultiPSOTopologyUpdater(MultiPSOTopologyUpdater original, Cloner cloner) : base(original, cloner) { } 86 86 87 public MultiPSOTopologyUpdater() 87 88 : base() { … … 89 90 Parameters.Add(new ValueLookupParameter<IntValue>("NrOfConnections", "Nr of connected neighbors.", new IntValue(3))); 90 91 Parameters.Add(new LookupParameter<IntValue>("SwarmSize", "Number of particles in the swarm.")); 91 Parameters.Add(new ScopeTreeLookupParameter<Int egerVector>("Neighbors", "The list of neighbors for each particle."));92 Parameters.Add(new ScopeTreeLookupParameter<IntArray>("Neighbors", "The list of neighbors for each particle.")); 92 93 Parameters.Add(new LookupParameter<IntValue>("CurrentIteration", "The current iteration of the algorithm.")); 93 94 Parameters.Add(new ValueLookupParameter<IntValue>("RegroupingPeriod", "Update interval (=iterations) for regrouping of neighborhoods.", new IntValue(5))); … … 100 101 // Splits the swarm into non-overlapping sub swarms 101 102 public override IOperation Apply() { 102 if (CurrentIteration % RegroupingPeriod == 0) {103 ItemArray<Int egerVector> neighbors = new ItemArray<IntegerVector>(SwarmSize);103 if (CurrentIteration > 0 && CurrentIteration % RegroupingPeriod == 0) { 104 ItemArray<IntArray> neighbors = new ItemArray<IntArray>(SwarmSize); 104 105 Dictionary<int, List<int>> neighborsPerParticle = new Dictionary<int, List<int>>(); 105 106 for (int i = 0; i < SwarmSize; i++) { … … 135 136 136 137 for (int particle = 0; particle < neighborsPerParticle.Count; particle++) { 137 neighbors[particle] = new Int egerVector(neighborsPerParticle[particle].ToArray());138 neighbors[particle] = new IntArray(neighborsPerParticle[particle].ToArray()); 138 139 } 139 140 Neighbors = neighbors; -
trunk/sources/HeuristicLab.Algorithms.ParticleSwarmOptimization/3.3/NeighborUpdater.cs
r5445 r5560 24 24 using HeuristicLab.Core; 25 25 using HeuristicLab.Data; 26 using HeuristicLab.Encodings.IntegerVectorEncoding;27 26 using HeuristicLab.Encodings.RealVectorEncoding; 28 27 using HeuristicLab.Operators; … … 42 41 get { return (IScopeTreeLookupParameter<RealVector>)Parameters["Point"]; } 43 42 } 44 public IScopeTreeLookupParameter<Int egerVector> NeighborsParameter {45 get { return (IScopeTreeLookupParameter<Int egerVector>)Parameters["Neighbors"]; }43 public IScopeTreeLookupParameter<IntArray> NeighborsParameter { 44 get { return (IScopeTreeLookupParameter<IntArray>)Parameters["Neighbors"]; } 46 45 } 47 46 public IScopeTreeLookupParameter<RealVector> BestNeighborPointParameter { … … 60 59 get { return PointsParameter.ActualValue; } 61 60 } 62 private ItemArray<Int egerVector> Neighbors {61 private ItemArray<IntArray> Neighbors { 63 62 get { return NeighborsParameter.ActualValue; } 64 63 } … … 80 79 private NeighborUpdater(NeighborUpdater original, Cloner cloner) : base(original, cloner) { } 81 80 public NeighborUpdater() { 82 Parameters.Add(new ScopeTreeLookupParameter<RealVector>(" Point", "The position of the particle."));83 Parameters.Add(new ScopeTreeLookupParameter<Int egerVector>("Neighbors", "The list of neighbors for each particle."));81 Parameters.Add(new ScopeTreeLookupParameter<RealVector>("RealVector", "The position of the particle.")); 82 Parameters.Add(new ScopeTreeLookupParameter<IntArray>("Neighbors", "The list of neighbors for each particle.")); 84 83 Parameters.Add(new ScopeTreeLookupParameter<RealVector>("BestNeighborPoint", "The position of the best neighboring particle.")); 85 84 Parameters.Add(new ScopeTreeLookupParameter<DoubleValue>("Quality", "The list of qualities of all particles.")); -
trunk/sources/HeuristicLab.Algorithms.ParticleSwarmOptimization/3.3/ParticleSwarmOptimization.cs
r5445 r5560 53 53 set { AnalyzerParameter.Value = value; } 54 54 } 55 public IDiscreteDoubleValueModifier OmegaUpdater { 56 get { return OmegaUpdaterParameter.Value; } 57 set { OmegaUpdaterParameter.Value = value; } 58 } 59 public IDiscreteDoubleMatrixModifier VelocityBoundsUpdater { 60 get { return VelocityBoundsUpdaterParameter.Value; } 61 set { VelocityBoundsUpdaterParameter.Value = value; } 55 public IDiscreteDoubleValueModifier InertiaUpdater { 56 get { return InertiaUpdaterParameter.Value; } 57 set { InertiaUpdaterParameter.Value = value; } 62 58 } 63 59 #endregion … … 76 72 get { return (IValueParameter<IntValue>)Parameters["MaxIterations"]; } 77 73 } 78 public IValueParameter<DoubleValue> OmegaParameter {79 get { return (IValueParameter<DoubleValue>)Parameters[" Omega"]; }80 } 81 public IValueParameter<DoubleValue> P hi_PParameter {82 get { return (IValueParameter<DoubleValue>)Parameters["P hi_P"]; }83 } 84 public IValueParameter<DoubleValue> Phi_GParameter {85 get { return (IValueParameter<DoubleValue>)Parameters[" Phi_G"]; }74 public IValueParameter<DoubleValue> InertiaParameter { 75 get { return (IValueParameter<DoubleValue>)Parameters["Inertia"]; } 76 } 77 public IValueParameter<DoubleValue> PersonalBestAttractionParameter { 78 get { return (IValueParameter<DoubleValue>)Parameters["PersonalBestAttraction"]; } 79 } 80 public IValueParameter<DoubleValue> NeighborsBestAttractionParameter { 81 get { return (IValueParameter<DoubleValue>)Parameters["NeighborsBestAttraction"]; } 86 82 } 87 83 public IValueParameter<MultiAnalyzer> AnalyzerParameter { 88 84 get { return (IValueParameter<MultiAnalyzer>)Parameters["Analyzer"]; } 89 85 } 90 public IValueLookupParameter<DoubleMatrix> VelocityBoundsParameter {91 get { return ( IValueLookupParameter<DoubleMatrix>)Parameters["VelocityBounds"]; }86 public ConstrainedValueParameter<IParticleCreator> ParticleCreatorParameter { 87 get { return (ConstrainedValueParameter<IParticleCreator>)Parameters["ParticleCreator"]; } 92 88 } 93 89 public ConstrainedValueParameter<IParticleUpdater> ParticleUpdaterParameter { … … 100 96 get { return (OptionalConstrainedValueParameter<ITopologyUpdater>)Parameters["TopologyUpdater"]; } 101 97 } 102 public OptionalConstrainedValueParameter<IDiscreteDoubleMatrixModifier> VelocityBoundsUpdaterParameter { 103 get { return (OptionalConstrainedValueParameter<IDiscreteDoubleMatrixModifier>)Parameters["VelocityBoundsUpdater"]; } 104 } 105 public OptionalConstrainedValueParameter<IDiscreteDoubleValueModifier> OmegaUpdaterParameter { 106 get { return (OptionalConstrainedValueParameter<IDiscreteDoubleValueModifier>)Parameters["OmegaUpdater"]; } 98 public OptionalConstrainedValueParameter<IDiscreteDoubleValueModifier> InertiaUpdaterParameter { 99 get { return (OptionalConstrainedValueParameter<IDiscreteDoubleValueModifier>)Parameters["InertiaUpdater"]; } 107 100 } 108 101 #endregion … … 114 107 [Storable] 115 108 private BestAverageWorstQualityAnalyzer qualityAnalyzer; 109 110 [Storable] 111 private SolutionsCreator solutionsCreator; 112 113 [Storable] 114 private ParticleSwarmOptimizationMainLoop mainLoop; 116 115 117 116 public ITopologyInitializer TopologyInitializer { … … 125 124 } 126 125 126 public IParticleCreator ParticleCreator { 127 get { return ParticleCreatorParameter.Value; } 128 set { ParticleCreatorParameter.Value = value; } 129 } 130 127 131 public IParticleUpdater ParticleUpdater { 128 132 get { return ParticleUpdaterParameter.Value; } 129 133 set { ParticleUpdaterParameter.Value = value; } 130 134 } 131 132 135 #endregion 133 136 … … 137 140 : base(original, cloner) { 138 141 qualityAnalyzer = cloner.Clone(original.qualityAnalyzer); 142 solutionsCreator = cloner.Clone(original.solutionsCreator); 143 mainLoop = cloner.Clone(original.mainLoop); 139 144 Initialize(); 140 145 } … … 146 151 Parameters.Add(new ValueParameter<IntValue>("MaxIterations", "Maximal number of iterations.", new IntValue(1000))); 147 152 Parameters.Add(new ValueParameter<MultiAnalyzer>("Analyzer", "The operator used to analyze each generation.", new MultiAnalyzer())); 148 Parameters.Add(new ValueParameter<DoubleValue>("Omega", "Weight for particle's velocity vector.", new DoubleValue(-0.2))); 149 Parameters.Add(new ValueParameter<DoubleValue>("Phi_P", "Weight for particle's personal best position.", new DoubleValue(-0.01))); 150 Parameters.Add(new ValueParameter<DoubleValue>("Phi_G", "Weight for global best position.", new DoubleValue(3.7))); 151 Parameters.Add(new ValueLookupParameter<DoubleMatrix>("VelocityBounds", "Maximum Velocity in every dimension", new DoubleMatrix(new double[,] { { -1, 1 } }))); 152 Parameters.Add(new ConstrainedValueParameter<IParticleUpdater>("ParticleUpdater", "Operator that calculates new position and velocity of a particle")); 153 Parameters.Add(new OptionalConstrainedValueParameter<ITopologyInitializer>("TopologyInitializer", "Creates neighborhood description vectors")); 154 Parameters.Add(new OptionalConstrainedValueParameter<ITopologyUpdater>("TopologyUpdater", "Updates the neighborhood description vectors")); 155 Parameters.Add(new OptionalConstrainedValueParameter<IDiscreteDoubleValueModifier>("OmegaUpdater", "Updates the omega parameter")); 156 Parameters.Add(new OptionalConstrainedValueParameter<IDiscreteDoubleMatrixModifier>("VelocityBoundsUpdater", "Adjusts the velocity bounds.")); 157 ParticleUpdaterParameter.ActualValue = ParticleUpdaterParameter.ValidValues.SingleOrDefault(v => v.GetType() == typeof(TotallyConnectedParticleUpdater)); 153 Parameters.Add(new ValueParameter<DoubleValue>("Inertia", "Inertia weight on a particle's movement (omega).", new DoubleValue(-0.2))); 154 Parameters.Add(new ValueParameter<DoubleValue>("PersonalBestAttraction", "Weight for particle's pull towards its personal best soution (phi_p).", new DoubleValue(-0.01))); 155 Parameters.Add(new ValueParameter<DoubleValue>("NeighborsBestAttraction", "Weight for pull towards the neighborhood best solution or global best solution in case of a totally connected topology (phi_g).", new DoubleValue(3.7))); 156 Parameters.Add(new ConstrainedValueParameter<IParticleCreator>("ParticleCreator", "Operator creates a new particle.")); 157 Parameters.Add(new ConstrainedValueParameter<IParticleUpdater>("ParticleUpdater", "Operator that updates a particle.")); 158 Parameters.Add(new OptionalConstrainedValueParameter<ITopologyInitializer>("TopologyInitializer", "Creates neighborhood description vectors.")); 159 Parameters.Add(new OptionalConstrainedValueParameter<ITopologyUpdater>("TopologyUpdater", "Updates the neighborhood description vectors.")); 160 Parameters.Add(new OptionalConstrainedValueParameter<IDiscreteDoubleValueModifier>("InertiaUpdater", "Updates the omega parameter.")); 158 161 159 162 RandomCreator randomCreator = new RandomCreator(); 160 163 VariableCreator variableCreator = new VariableCreator(); 161 SolutionsCreator solutionsCreator = new SolutionsCreator(); 162 CombinedOperator particleCreator = new CombinedOperator(); 163 Placeholder evaluatorPlaceholder = new Placeholder(); 164 Assigner bestPersonalQualityAssigner = new Assigner(); 165 BestPointInitializer bestPositionInitializer = new BestPointInitializer(); 164 solutionsCreator = new SolutionsCreator(); 166 165 Placeholder topologyInitializerPlaceholder = new Placeholder(); 167 NeighborUpdater neighborUpdater = new NeighborUpdater();166 ResultsCollector resultsCollector = new ResultsCollector(); 168 167 Placeholder analyzerPlaceholder = new Placeholder(); 169 UniformSubScopesProcessor uniformSubScopeProcessor = new UniformSubScopesProcessor(); 170 Placeholder particleUpdaterPlaceholder = new Placeholder(); 171 Placeholder topologyUpdaterPlaceholder = new Placeholder(); 172 UniformSubScopesProcessor uniformSubscopesProcessor2 = new UniformSubScopesProcessor(); 173 UniformSubScopesProcessor evaluationProcessor = new UniformSubScopesProcessor(); 174 NeighborUpdater neighborUpdater2 = new NeighborUpdater(); 175 Placeholder evaluatorPlaceholder2 = new Placeholder(); 176 SwarmUpdater swarmUpdater = new SwarmUpdater(); 177 Placeholder analyzerPlaceholder2 = new Placeholder(); 178 IntCounter currentIterationCounter = new IntCounter(); 179 Comparator currentIterationComparator = new Comparator(); 180 ConditionalBranch conditionalBranch = new ConditionalBranch(); 181 Placeholder velocityBoundsUpdaterPlaceholder = new Placeholder(); 182 Placeholder omegaUpdaterPlaceholder = new Placeholder(); 168 RealVectorSwarmUpdater swarmUpdater = new RealVectorSwarmUpdater(); 169 mainLoop = new ParticleSwarmOptimizationMainLoop(); 183 170 184 171 OperatorGraph.InitialOperator = randomCreator; … … 192 179 193 180 solutionsCreator.NumberOfSolutionsParameter.ActualName = "SwarmSize"; 194 solutionsCreator.EvaluatorParameter.Value = evaluatorPlaceholder; 195 solutionsCreator.SolutionCreatorParameter.Value = particleCreator; 196 solutionsCreator.Successor = bestPositionInitializer; 197 198 InitializeParticleCreator(particleCreator); 199 200 evaluatorPlaceholder.Name = "(Evaluator)"; 201 evaluatorPlaceholder.OperatorParameter.ActualName = "Evaluator"; 202 evaluatorPlaceholder.Successor = bestPersonalQualityAssigner; 203 204 bestPersonalQualityAssigner.LeftSideParameter.ActualName = "PersonalBestQuality"; 205 bestPersonalQualityAssigner.RightSideParameter.ActualName = "Quality"; 206 207 bestPositionInitializer.Successor = topologyInitializerPlaceholder; 181 ParameterizeSolutionsCreator(); 182 solutionsCreator.Successor = topologyInitializerPlaceholder; 208 183 209 184 topologyInitializerPlaceholder.Name = "(TopologyInitializer)"; 210 185 topologyInitializerPlaceholder.OperatorParameter.ActualName = "TopologyInitializer"; 211 topologyInitializerPlaceholder.Successor = neighborUpdater; 212 213 neighborUpdater.Successor = analyzerPlaceholder; 214 215 analyzerPlaceholder.Name = "(Analyzer)"; 216 analyzerPlaceholder.OperatorParameter.ActualName = "Analyzer"; 217 analyzerPlaceholder.Successor = uniformSubScopeProcessor; 218 219 uniformSubScopeProcessor.Operator = particleUpdaterPlaceholder; 220 uniformSubScopeProcessor.Successor = evaluationProcessor; 221 222 particleUpdaterPlaceholder.Name = "(ParticleUpdater)"; 223 particleUpdaterPlaceholder.OperatorParameter.ActualName = "ParticleUpdater"; 224 225 evaluationProcessor.Parallel = new BoolValue(true); 226 evaluationProcessor.Operator = evaluatorPlaceholder2; 227 evaluationProcessor.Successor = topologyUpdaterPlaceholder; 228 229 evaluatorPlaceholder2.Name = "(Evaluator)"; 230 evaluatorPlaceholder2.OperatorParameter.ActualName = "Evaluator"; 231 232 topologyUpdaterPlaceholder.Name = "(TopologyUpdater)"; 233 topologyUpdaterPlaceholder.OperatorParameter.ActualName = "TopologyUpdater"; 234 topologyUpdaterPlaceholder.Successor = neighborUpdater2; 235 236 neighborUpdater2.Successor = uniformSubscopesProcessor2; 237 238 uniformSubscopesProcessor2.Operator = swarmUpdater; 239 uniformSubscopesProcessor2.Successor = analyzerPlaceholder2; 240 241 analyzerPlaceholder2.Name = "(Analyzer)"; 242 analyzerPlaceholder2.OperatorParameter.ActualName = "Analyzer"; 243 analyzerPlaceholder2.Successor = currentIterationCounter; 244 245 currentIterationCounter.Name = "CurrentIteration++"; 246 currentIterationCounter.ValueParameter.ActualName = "CurrentIteration"; 247 currentIterationCounter.Successor = omegaUpdaterPlaceholder; 248 249 omegaUpdaterPlaceholder.Name = "(Omega Updater)"; 250 omegaUpdaterPlaceholder.OperatorParameter.ActualName = "OmegaUpdater"; 251 omegaUpdaterPlaceholder.Successor = velocityBoundsUpdaterPlaceholder; 252 253 velocityBoundsUpdaterPlaceholder.Name = "(Velocity Bounds Updater)"; 254 velocityBoundsUpdaterPlaceholder.OperatorParameter.ActualName = "VelocityBoundsUpdater"; 255 velocityBoundsUpdaterPlaceholder.Successor = currentIterationComparator; 256 257 currentIterationComparator.LeftSideParameter.ActualName = "CurrentIteration"; 258 currentIterationComparator.Comparison = new Comparison(ComparisonType.Less); 259 currentIterationComparator.RightSideParameter.ActualName = "MaxIterations"; 260 currentIterationComparator.ResultParameter.ActualName = "ContinueIteration"; 261 currentIterationComparator.Successor = conditionalBranch; 262 263 conditionalBranch.Name = "ContinueIteration?"; 264 conditionalBranch.ConditionParameter.ActualName = "ContinueIteration"; 265 conditionalBranch.TrueBranch = uniformSubScopeProcessor; 186 topologyInitializerPlaceholder.Successor = swarmUpdater; 187 188 swarmUpdater.Successor = resultsCollector; 189 190 resultsCollector.CollectedValues.Add(new LookupParameter<IntValue>("Iterations", null, "CurrentIteration")); 191 //resultsCollector.CollectedValues.Add(new LookupParameter<IntValue>("Current Inertia", null, "Inertia")); 192 //resultsCollector.CollectedValues.Add(new LookupParameter<IntValue>("Evaluated Solutions", null, "EvaluatedSolutions")); 193 resultsCollector.ResultsParameter.ActualName = "Results"; 194 resultsCollector.Successor = mainLoop; 195 196 mainLoop.AnalyzerParameter.ActualName = AnalyzerParameter.Name; 197 mainLoop.InertiaParameter.ActualName = InertiaParameter.Name; 198 mainLoop.MaxIterationsParameter.ActualName = MaxIterationsParameter.Name; 199 mainLoop.NeighborsBestAttractionParameter.ActualName = NeighborsBestAttractionParameter.Name; 200 mainLoop.InertiaUpdaterParameter.ActualName = InertiaUpdaterParameter.Name; 201 mainLoop.ParticleUpdaterParameter.ActualName = ParticleUpdaterParameter.Name; 202 mainLoop.PersonalBestAttractionParameter.ActualName = PersonalBestAttractionParameter.Name; 203 mainLoop.RandomParameter.ActualName = randomCreator.RandomParameter.ActualName; 204 mainLoop.SwarmSizeParameter.ActualName = SwarmSizeParameter.Name; 205 mainLoop.TopologyUpdaterParameter.ActualName = TopologyUpdaterParameter.Name; 206 mainLoop.RandomParameter.ActualName = randomCreator.RandomParameter.ActualName; 207 mainLoop.ResultsParameter.ActualName = "Results"; 208 mainLoop.EvaluatorParameter.ActualName = Problem.EvaluatorParameter.Name; 209 // mainLoop.EvaluatedMovesParameter.ActualName = "EvaluatedMoves"; 266 210 267 211 InitializeAnalyzers(); 268 InitVelocityBoundsUpdater(); 212 ////InitVelocityBoundsUpdater(); 213 InitializeParticleCreator(); 214 ParameterizeSolutionsCreator(); 269 215 UpdateAnalyzers(); 270 Update OmegaUpdater();271 Init OmegaUpdater();216 UpdateInertiaUpdater(); 217 InitInertiaUpdater(); 272 218 UpdateTopologyInitializer(); 273 219 Initialize(); 220 ParameterizeMainLoop(); 274 221 } 275 222 … … 284 231 285 232 public override void Prepare() { 286 if (Problem != null ) {233 if (Problem != null && ParticleCreator != null && ParticleUpdater != null) { 287 234 base.Prepare(); 288 if ( OmegaUpdater != null && OmegaUpdater.StartValueParameter.Value != null) {289 this. OmegaParameter.ActualValue = new DoubleValue(OmegaUpdaterParameter.Value.StartValueParameter.Value.Value);235 if (InertiaUpdater != null && InertiaUpdater.StartValueParameter.Value != null) { 236 this.InertiaParameter.ActualValue = new DoubleValue(InertiaUpdaterParameter.Value.StartValueParameter.Value.Value); 290 237 } 291 if (VelocityBoundsUpdater != null && VelocityBoundsUpdater.StartValueParameter.Value != null && VelocityBoundsParameter.Value != null) {292 DoubleMatrix matrix = VelocityBoundsParameter.Value;293 for (int i = 0; i < matrix.Rows; i++) {294 matrix[i, 0] = -VelocityBoundsUpdater.StartValueParameter.Value.Value;295 matrix[i, 1] = VelocityBoundsUpdater.StartValueParameter.Value.Value;296 }297 }238 //if (VelocityBoundsUpdater != null && VelocityBoundsUpdater.StartValueParameter.Value != null && VelocityBoundsParameter.Value != null) { 239 // DoubleMatrix matrix = VelocityBoundsParameter.Value; 240 // for (int i = 0; i < matrix.Rows; i++) { 241 // matrix[i, 0] = -VelocityBoundsUpdater.StartValueParameter.Value.Value; 242 // matrix[i, 1] = VelocityBoundsUpdater.StartValueParameter.Value.Value; 243 // } 244 //} 298 245 } 299 246 } … … 303 250 UpdateAnalyzers(); 304 251 ParameterizeAnalyzers(); 252 UpdateTopologyParameters(); 253 InitializeParticleCreator(); 254 ParameterizeSolutionsCreator(); 305 255 base.OnProblemChanged(); 306 256 } … … 310 260 } 311 261 312 void VelocityBoundsUpdaterParameter_ValueChanged(object sender, EventArgs e) {313 if (VelocityBoundsParameter.Value != null) {314 foreach (IDiscreteDoubleMatrixModifier matrixOp in VelocityBoundsUpdaterParameter.Value.ScalingOperatorParameter.ValidValues) {315 matrixOp.ValueParameter.ActualName = VelocityBoundsUpdater.ScaleParameter.Name;316 matrixOp.StartValueParameter.Value = new DoubleValue(VelocityBoundsUpdater.ScaleParameter.ActualValue.Value);317 }318 }319 }262 //void VelocityBoundsUpdaterParameter_ValueChanged(object sender, EventArgs e) { 263 // if (VelocityBoundsParameter.Value != null) { 264 // foreach (IDiscreteDoubleMatrixModifier matrixOp in VelocityBoundsUpdaterParameter.Value.ScalingOperatorParameter.ValidValues) { 265 // matrixOp.ValueParameter.ActualName = VelocityBoundsUpdater.ScaleParameter.Name; 266 // matrixOp.StartValueParameter.Value = new DoubleValue(VelocityBoundsUpdater.ScaleParameter.ActualValue.Value); 267 // } 268 // } 269 //} 320 270 #endregion 321 271 … … 325 275 } 326 276 327 private static void InitializeParticleCreator(CombinedOperator particleCreator) { 328 Placeholder positionCreator = new Placeholder(); 329 Assigner personalBestPositionAssigner = new Assigner(); 330 UniformRandomRealVectorCreator velocityCreator = new UniformRandomRealVectorCreator(); 331 332 particleCreator.Name = "Particle Creator"; 333 particleCreator.OperatorGraph.InitialOperator = positionCreator; 334 335 positionCreator.Name = "(SolutionCreator)"; 336 positionCreator.OperatorParameter.ActualName = "SolutionCreator"; 337 positionCreator.Successor = personalBestPositionAssigner; 338 339 personalBestPositionAssigner.LeftSideParameter.ActualName = "PersonalBestPoint"; 340 personalBestPositionAssigner.RightSideParameter.ActualName = "Point"; 341 personalBestPositionAssigner.Successor = velocityCreator; 342 343 velocityCreator.LengthParameter.ActualName = "ProblemSize"; 344 velocityCreator.BoundsParameter.ActualName = "VelocityBounds"; 345 velocityCreator.RealVectorParameter.ActualName = "Velocity"; 277 private void InitializeParticleCreator() { 278 if (Problem != null) { 279 IParticleCreator oldParticleCreator = ParticleCreator; 280 ParticleCreatorParameter.ValidValues.Clear(); 281 foreach (IParticleCreator Creator in Problem.Operators.OfType<IParticleCreator>().OrderBy(x => x.Name)) { 282 ParticleCreatorParameter.ValidValues.Add(Creator); 283 } 284 if (oldParticleCreator != null) { 285 IParticleCreator creator = ParticleCreatorParameter.ValidValues.FirstOrDefault(x => x.GetType() == oldParticleCreator.GetType()); 286 if (creator != null) ParticleCreator = creator; 287 } 288 } 346 289 } 347 290 … … 368 311 } 369 312 370 private void InitVelocityBoundsUpdater() {371 foreach (IDiscreteDoubleMatrixModifier matrixOp in ApplicationManager.Manager.GetInstances<IDiscreteDoubleMatrixModifier>()) {372 VelocityBoundsUpdaterParameter.ValidValues.Add(matrixOp);373 matrixOp.ValueParameter.ActualName = VelocityBoundsParameter.Name;374 matrixOp.EndIndexParameter.ActualName = MaxIterationsParameter.Name;375 matrixOp.StartIndexParameter.Value = new IntValue(0);376 matrixOp.IndexParameter.ActualName = "CurrentIteration";377 matrixOp.EndValueParameter.Value = new DoubleValue(0);378 }379 VelocityBoundsUpdaterParameter.ValueChanged += new EventHandler(VelocityBoundsUpdaterParameter_ValueChanged);380 }381 382 private void Init OmegaUpdater() {383 foreach (IDiscreteDoubleValueModifier updater in OmegaUpdaterParameter.ValidValues) {313 //private void InitVelocityBoundsUpdater() { 314 // foreach (IDiscreteDoubleMatrixModifier matrixOp in ApplicationManager.Manager.GetInstances<IDiscreteDoubleMatrixModifier>()) { 315 // VelocityBoundsUpdaterParameter.ValidValues.Add(matrixOp); 316 // matrixOp.ValueParameter.ActualName = VelocityBoundsParameter.Name; 317 // matrixOp.EndIndexParameter.ActualName = MaxIterationsParameter.Name; 318 // matrixOp.StartIndexParameter.Value = new IntValue(0); 319 // matrixOp.IndexParameter.ActualName = "CurrentIteration"; 320 // matrixOp.EndValueParameter.Value = new DoubleValue(0); 321 // } 322 // VelocityBoundsUpdaterParameter.ValueChanged += new EventHandler(VelocityBoundsUpdaterParameter_ValueChanged); 323 //} 324 325 private void InitInertiaUpdater() { 326 foreach (IDiscreteDoubleValueModifier updater in InertiaUpdaterParameter.ValidValues) { 384 327 updater.EndIndexParameter.ActualName = MaxIterationsParameter.Name; 385 328 updater.StartIndexParameter.Value = new IntValue(0); 386 329 updater.IndexParameter.ActualName = "CurrentIteration"; 387 updater.ValueParameter.ActualName = OmegaParameter.Name;330 updater.ValueParameter.ActualName = InertiaParameter.Name; 388 331 updater.StartValueParameter.Value = new DoubleValue(1); 389 332 updater.EndValueParameter.Value = new DoubleValue(0); … … 391 334 } 392 335 393 private void Update OmegaUpdater() {394 IDiscreteDoubleValueModifier old OmegaUpdater = OmegaUpdater;395 OmegaUpdaterParameter.ValidValues.Clear();336 private void UpdateInertiaUpdater() { 337 IDiscreteDoubleValueModifier oldInertiaUpdater = InertiaUpdater; 338 InertiaUpdaterParameter.ValidValues.Clear(); 396 339 foreach (IDiscreteDoubleValueModifier updater in ApplicationManager.Manager.GetInstances<IDiscreteDoubleValueModifier>().OrderBy(x => x.Name)) { 397 OmegaUpdaterParameter.ValidValues.Add(updater);398 } 399 if (old OmegaUpdater != null) {400 IDiscreteDoubleValueModifier updater = OmegaUpdaterParameter.ValidValues.FirstOrDefault(x => x.GetType() == oldOmegaUpdater.GetType());401 if (updater != null) OmegaUpdaterParameter.Value = updater;340 InertiaUpdaterParameter.ValidValues.Add(updater); 341 } 342 if (oldInertiaUpdater != null) { 343 IDiscreteDoubleValueModifier updater = InertiaUpdaterParameter.ValidValues.FirstOrDefault(x => x.GetType() == oldInertiaUpdater.GetType()); 344 if (updater != null) InertiaUpdaterParameter.Value = updater; 402 345 } 403 346 } … … 418 361 IParticleUpdater oldParticleUpdater = ParticleUpdater; 419 362 ClearTopologyParameters(); 420 if (TopologyInitializer != null) { 421 foreach (ITopologyUpdater topologyUpdater in ApplicationManager.Manager.GetInstances<ITopologyUpdater>()) 422 TopologyUpdaterParameter.ValidValues.Add(topologyUpdater); 423 foreach (IParticleUpdater particleUpdater in ApplicationManager.Manager.GetInstances<ILocalParticleUpdater>()) 424 ParticleUpdaterParameter.ValidValues.Add(particleUpdater); 425 } else { 426 foreach (IParticleUpdater particleUpdater in ApplicationManager.Manager.GetInstances<IGlobalParticleUpdater>()) 427 ParticleUpdaterParameter.ValidValues.Add(particleUpdater); 428 } 429 if (oldTopologyUpdater != null) { 430 ITopologyUpdater newTopologyUpdater = TopologyUpdaterParameter.ValidValues.FirstOrDefault(x => x.GetType() == oldParticleUpdater.GetType()); 431 if (newTopologyUpdater != null) TopologyUpdater = newTopologyUpdater; 432 } 433 if (oldParticleUpdater != null) { 434 IParticleUpdater newParticleUpdater = ParticleUpdaterParameter.ValidValues.FirstOrDefault(x => x.GetType() == oldParticleUpdater.GetType()); 435 if (newParticleUpdater != null) ParticleUpdater = newParticleUpdater; 363 if (Problem != null) { 364 if (TopologyInitializer != null) { 365 foreach (ITopologyUpdater topologyUpdater in ApplicationManager.Manager.GetInstances<ITopologyUpdater>()) 366 TopologyUpdaterParameter.ValidValues.Add(topologyUpdater); 367 foreach (IParticleUpdater particleUpdater in Problem.Operators.OfType<ILocalParticleUpdater>().OrderBy(x => x.Name)) 368 ParticleUpdaterParameter.ValidValues.Add(particleUpdater); 369 } else { 370 foreach (IParticleUpdater particleUpdater in Problem.Operators.OfType<IGlobalParticleUpdater>().OrderBy(x => x.Name)) 371 ParticleUpdaterParameter.ValidValues.Add(particleUpdater); 372 } 373 if (oldTopologyUpdater != null) { 374 ITopologyUpdater newTopologyUpdater = TopologyUpdaterParameter.ValidValues.FirstOrDefault(x => x.GetType() == oldParticleUpdater.GetType()); 375 if (newTopologyUpdater != null) TopologyUpdater = newTopologyUpdater; 376 } 377 if (oldParticleUpdater != null) { 378 IParticleUpdater newParticleUpdater = ParticleUpdaterParameter.ValidValues.FirstOrDefault(x => x.GetType() == oldParticleUpdater.GetType()); 379 if (newParticleUpdater != null) ParticleUpdater = newParticleUpdater; 380 } 436 381 } 437 382 } … … 441 386 ParticleUpdaterParameter.ValidValues.Clear(); 442 387 } 388 389 private void ParameterizeSolutionsCreator() { 390 if (Problem != null) { 391 solutionsCreator.EvaluatorParameter.ActualName = Problem.EvaluatorParameter.Name; 392 solutionsCreator.SolutionCreatorParameter.ActualName = ParticleCreatorParameter.Name; 393 } 394 } 395 396 private void ParameterizeMainLoop() { 397 mainLoop.MaxIterationsParameter.ActualName = MaxIterationsParameter.Name; 398 } 443 399 #endregion 444 400 -
trunk/sources/HeuristicLab.Algorithms.ParticleSwarmOptimization/3.3/RandomTopologyInitializer.cs
r5445 r5560 25 25 using HeuristicLab.Core; 26 26 using HeuristicLab.Data; 27 using HeuristicLab.Encodings.IntegerVectorEncoding;28 27 using HeuristicLab.Parameters; 29 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; … … 66 65 67 66 public override IOperation Apply() { 68 ItemArray<Int egerVector> neighbors = new ItemArray<IntegerVector>(SwarmSize);67 ItemArray<IntArray> neighbors = new ItemArray<IntArray>(SwarmSize); 69 68 for (int i = 0; i < SwarmSize; i++) { 70 69 var numbers = Enumerable.Range(0, SwarmSize).ToList(); … … 76 75 numbers.RemoveAt(index); 77 76 } 78 neighbors[i] = new Int egerVector(selectedNumbers.ToArray());77 neighbors[i] = new IntArray(selectedNumbers.ToArray()); 79 78 } 80 79 Neighbors = neighbors; -
trunk/sources/HeuristicLab.Algorithms.ParticleSwarmOptimization/3.3/RingTopologyInitializer.cs
r5445 r5560 22 22 using HeuristicLab.Common; 23 23 using HeuristicLab.Core; 24 using HeuristicLab.Encodings.IntegerVectorEncoding;25 24 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 25 using HeuristicLab.Data; 26 26 27 27 namespace HeuristicLab.Algorithms.ParticleSwarmOptimization { … … 43 43 44 44 public override IOperation Apply() { 45 ItemArray<Int egerVector> neighbors = new ItemArray<IntegerVector>(SwarmSize);45 ItemArray<IntArray> neighbors = new ItemArray<IntArray>(SwarmSize); 46 46 for (int i = 0; i < SwarmSize; i++) { 47 neighbors[i] = new Int egerVector(new[] { (SwarmSize + i - 1) % SwarmSize, (i + 1) % SwarmSize });47 neighbors[i] = new IntArray(new[] { (SwarmSize + i - 1) % SwarmSize, (i + 1) % SwarmSize }); 48 48 } 49 49 Neighbors = neighbors; -
trunk/sources/HeuristicLab.Algorithms.ParticleSwarmOptimization/3.3/TopologyInitializer.cs
r5445 r5560 23 23 using HeuristicLab.Core; 24 24 using HeuristicLab.Data; 25 using HeuristicLab.Encodings.IntegerVectorEncoding;26 25 using HeuristicLab.Operators; 26 using HeuristicLab.Optimization; 27 27 using HeuristicLab.Parameters; 28 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; … … 37 37 38 38 #region Parameters 39 public IScopeTreeLookupParameter<Int egerVector> NeighborsParameter {40 get { return (IScopeTreeLookupParameter<Int egerVector>)Parameters["Neighbors"]; }39 public IScopeTreeLookupParameter<IntArray> NeighborsParameter { 40 get { return (IScopeTreeLookupParameter<IntArray>)Parameters["Neighbors"]; } 41 41 } 42 42 43 public ILookupParameter<IntValue> SwarmSizeParameter { 43 44 get { return (ILookupParameter<IntValue>)Parameters["SwarmSize"]; } … … 47 48 48 49 #region Parameter Values 49 protected ItemArray<Int egerVector> Neighbors {50 protected ItemArray<IntArray> Neighbors { 50 51 get { return NeighborsParameter.ActualValue; } 51 52 set { NeighborsParameter.ActualValue = value; } … … 60 61 protected TopologyInitializer(bool deserializing) : base(deserializing) { } 61 62 protected TopologyInitializer(TopologyInitializer original, Cloner cloner) : base(original, cloner) { } 63 62 64 public TopologyInitializer() { 63 Parameters.Add(new ScopeTreeLookupParameter<Int egerVector>("Neighbors", "The list of neighbors for each particle."));65 Parameters.Add(new ScopeTreeLookupParameter<IntArray>("Neighbors", "The list of neighbors for each particle.")); 64 66 Parameters.Add(new LookupParameter<IntValue>("SwarmSize", "Number of particles in the swarm.")); 65 67 } 66 68 #endregion 67 68 69 } 69 70 -
trunk/sources/HeuristicLab.Algorithms.ParticleSwarmOptimization/3.3/VonNeumannTopologyInitializer.cs
r5445 r5560 22 22 using HeuristicLab.Common; 23 23 using HeuristicLab.Core; 24 using HeuristicLab.Encodings.IntegerVectorEncoding;25 24 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 25 using HeuristicLab.Data; 26 26 27 27 namespace HeuristicLab.Algorithms.ParticleSwarmOptimization { … … 44 44 45 45 public override IOperation Apply() { 46 ItemArray<Int egerVector> neighbors = new ItemArray<IntegerVector>(SwarmSize);46 ItemArray<IntArray> neighbors = new ItemArray<IntArray>(SwarmSize); 47 47 for (int i = 0; i < SwarmSize; i++) { 48 neighbors[i] = new Int egerVector(new[] {48 neighbors[i] = new IntArray(new[] { 49 49 (SwarmSize + i-2) % SwarmSize, 50 50 (SwarmSize + i-1) % SwarmSize,
Note: See TracChangeset
for help on using the changeset viewer.