#region License Information /* HeuristicLab * Copyright (C) 2002-2010 Heuristic and Evolutionary Algorithms Laboratory (HEAL) * * This file is part of HeuristicLab. * * HeuristicLab is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * HeuristicLab is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with HeuristicLab. If not, see . */ #endregion using System; using System.Collections.Generic; using System.Linq; using System.Text; using HeuristicLab.Operators; using HeuristicLab.Common; using HeuristicLab.Core; using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; using HeuristicLab.Parameters; using HeuristicLab.Data; using HeuristicLab.Analysis; using HeuristicLab.Optimization.Operators; using HeuristicLab.Encodings.RealVectorEncoding; using HeuristicLab.Optimization; namespace HeuristicLab.Algorithms.ParticleSwarmOptimization { /// /// An operator which represents the main loop of a PSO. /// [Item("ParticleSwarmOptimizationMainLoop", "An operator which represents the main loop of a PSO.")] [StorableClass] public class ParticleSwarmOptimizationMainLoop : AlgorithmOperator { #region Parameter properties public ValueLookupParameter ResultsParameter { get { return (ValueLookupParameter)Parameters["Results"]; } } public ValueLookupParameter EncoderParameter { get { return (ValueLookupParameter)Parameters["Encoder"]; } } public ValueLookupParameter DecoderParameter { get { return (ValueLookupParameter)Parameters["Decoder"]; } } public ValueLookupParameter MaximizationParameter { get { return (ValueLookupParameter)Parameters["Maximization"]; } } public ScopeTreeLookupParameter QualityParameter { get { return (ScopeTreeLookupParameter)Parameters["Quality"]; } } public ValueLookupParameter MaximumGenerationsParameter { get { return (ValueLookupParameter)Parameters["MaximumGenerations"]; } } public ValueLookupParameter EvaluatorParameter { get { return (ValueLookupParameter)Parameters["Evaluator"]; } } public ValueLookupParameter AnalyzerParameter { get { return (ValueLookupParameter)Parameters["Analyzer"]; } } #endregion [Storable] private ParticleUpdater velocityUpdater; [StorableConstructor] private ParticleSwarmOptimizationMainLoop(bool deserializing) : base() { } public ParticleSwarmOptimizationMainLoop() : base() { Initialize(); } private void Initialize() { #region Create parameters Parameters.Add(new ValueLookupParameter("Results", "The variable collection where results should be stored.")); Parameters.Add(new ValueLookupParameter("Encoder", "The encoding operator that maps a solution to a position vector.")); Parameters.Add(new ValueLookupParameter("Decoder", "The decoding operator that maps a position vector to a solution.")); Parameters.Add(new ValueLookupParameter("Maximization", "True if the problem is a maximization problem, otherwise false.")); Parameters.Add(new ScopeTreeLookupParameter("Quality", "The value which represents the quality of a solution.")); Parameters.Add(new ValueLookupParameter("MaximumGenerations", "The maximum number of generations which should be processed.")); Parameters.Add(new ValueLookupParameter("Evaluator", "The operator used to evaluate solutions.")); Parameters.Add(new ValueLookupParameter("Analyzer", "The operator used to analyze each generation.")); #endregion EncoderParameter.ActualNameChanged += new EventHandler(EncoderParameter_ActualNameChanged); #region Create operators VariableCreator variableCreator = new VariableCreator(); ResultsCollector resultsCollector1 = new ResultsCollector(); IntCounter intCounter = new IntCounter(); ConditionalBranch conditionalBranch = new ConditionalBranch(); velocityUpdater = new ParticleUpdater(); UniformSubScopesProcessor uniformSubScopesProcessor = new UniformSubScopesProcessor(); UniformSubScopesProcessor uniformSubScopesProcessor2 = new UniformSubScopesProcessor(); Placeholder encPlaceholder = new Placeholder(); Placeholder decPlaceholder = new Placeholder(); Placeholder evaluator = new Placeholder(); Comparator comparator = new Comparator(); SwarmUpdater swarmUpdater = new SwarmUpdater(); Placeholder analyzer1 = new Placeholder(); analyzer1.Name = "Analyzer (placeholder)"; analyzer1.OperatorParameter.ActualName = AnalyzerParameter.Name; variableCreator.CollectedValues.Add(new ValueParameter("Generations", new IntValue(0))); // Initial generation already built resultsCollector1.CollectedValues.Add(new LookupParameter("Generations")); resultsCollector1.ResultsParameter.ActualName = "Results"; intCounter.Increment = new IntValue(1); intCounter.ValueParameter.ActualName = "Generations"; comparator.Comparison = new Comparison(ComparisonType.GreaterOrEqual); comparator.LeftSideParameter.ActualName = "Generations"; comparator.ResultParameter.ActualName = "Terminate"; comparator.RightSideParameter.ActualName = MaximumGenerationsParameter.Name; conditionalBranch.ConditionParameter.ActualName = "Terminate"; velocityUpdater.BestGlobalParameter.ActualName = "CurrentBestPosition"; velocityUpdater.BestLocalParameter.ActualName = "BestPosition"; velocityUpdater.CurrentPositionParameter.ActualName = "Position"; velocityUpdater.VelocityParameter.ActualName = "Velocity"; // // ToDo: Add correctly encPlaceholder.OperatorParameter.ActualName = EncoderParameter.ActualName; decPlaceholder.OperatorParameter.ActualName = DecoderParameter.ActualName; evaluator.Name = "Evaluator (placeholder)"; evaluator.OperatorParameter.ActualName = EvaluatorParameter.Name; swarmUpdater.CurrentPositionParameter.ActualName = "Position"; swarmUpdater.CurrentQualityParameter.ActualName = "Quality"; swarmUpdater.BestGlobalParameter.ActualName = "CurrentBestPosition"; swarmUpdater.BestLocalParameter.ActualName = "BestPosition"; swarmUpdater.LocalBestQualityParameter.ActualName = "BestQuality"; swarmUpdater.GlobalBestQualityParameter.ActualName = "CurrentBestBestQuality"; #endregion #region Create operator graph OperatorGraph.InitialOperator = variableCreator; variableCreator.Successor = comparator; comparator.Successor = conditionalBranch; conditionalBranch.FalseBranch = uniformSubScopesProcessor; uniformSubScopesProcessor.Operator = velocityUpdater; uniformSubScopesProcessor.Successor = intCounter; velocityUpdater.Successor = decPlaceholder; decPlaceholder.Successor = evaluator; evaluator.Successor = swarmUpdater; swarmUpdater.Successor = null; intCounter.Successor = resultsCollector1; resultsCollector1.Successor = analyzer1; analyzer1.Successor = comparator; #endregion } private void EncoderParameter_ActualNameChanged(object sender, EventArgs e) { velocityUpdater.BoundsParameter.ActualName = EncoderParameter.ActualValue.BoundsParameter.ActualName; } } }