19#ifndef itkParticleSwarmOptimizerBase_h
20#define itkParticleSwarmOptimizerBase_h
24#include "ITKOptimizersExport.h"
68 using ParameterBoundsType = std::vector<std::pair<ParametersType::ValueType, ParametersType::ValueType>>;
93 itkSetMacro(InitializeNormalDistribution,
bool);
94 itkGetMacro(InitializeNormalDistribution,
bool);
95 itkBooleanMacro(InitializeNormalDistribution);
151 SetParameterBounds(std::pair<ParametersType::ValueType, ParametersType::ValueType> & bounds,
unsigned int n);
180 itkGetMacro(PercentageParticlesConverged,
double);
181 itkSetMacro(PercentageParticlesConverged,
double);
194 itkSetMacro(UseSeed,
bool);
195 itkGetMacro(UseSeed,
bool);
196 itkBooleanMacro(UseSeed);
Control indentation during Print() invocation.
NumberOfIterationsType m_IterationIndex
ParameterBoundsType GetParameterBounds() const
void SetParameterBounds(std::pair< ParametersType::ValueType, ParametersType::ValueType > &bounds, unsigned int n)
std::ostringstream m_StopConditionDescription
unsigned int NumberOfGenerationsType
std::string GetStopConditionDescription() const override
SingleValuedNonLinearOptimizer Superclass
ParticleSwarmOptimizerBase Self
void FileInitialization()
bool m_InitializeNormalDistribution
void RandomInitialization()
CostFunctionType::MeasureType m_FunctionConvergenceTolerance
std::vector< MeasureType > m_FunctionBestValueMemory
MeasureType GetValue() const
~ParticleSwarmOptimizerBase() override
SmartPointer< const Self > ConstPointer
void SetInitialSwarm(const SwarmType &initialSwarm)
ParameterBoundsType m_ParameterBounds
CostFunctionType::MeasureType m_FunctionBestValue
Statistics::MersenneTwisterRandomVariateGenerator RandomVariateGeneratorType
SmartPointer< Self > Pointer
std::vector< ParticleData > m_Particles
virtual void ValidateSettings()
virtual void Initialize()
void PrintSelf(std::ostream &os, Indent indent) const override
ParametersType m_ParametersBestValue
void StartOptimization() override
virtual void UpdateSwarm()=0
CostFunctionType::MeasureType MeasureType
void PrintSwarm(std::ostream &os, Indent indent) const
ParticleSwarmOptimizerBase()
double m_PercentageParticlesConverged
ParametersType m_ParametersConvergenceTolerance
unsigned int NumberOfIterationsType
void PrintParamtersType(const ParametersType &x, std::ostream &os) const
NumberOfParticlesType m_NumberOfParticles
void SetParametersConvergenceTolerance(ValueType convergenceTolerance, unsigned int sz)
NumberOfIterationsType m_MaximalNumberOfIterations
NumberOfGenerationsType m_NumberOfGenerationsWithMinimalImprovement
std::vector< std::pair< ParametersType::ValueType, ParametersType::ValueType > > ParameterBoundsType
void SetNumberOfParticles(NumberOfParticlesType n)
RandomVariateGeneratorType::IntegerType m_Seed
virtual void SetParameterBounds(ParameterBoundsType &bounds)
std::vector< ParticleData > SwarmType
ParametersType::ValueType ValueType
unsigned int NumberOfParticlesType
SingleValuedNonLinearOptimizer()
Superclass::ParametersType ParametersType
Implements transparent reference counting.
MersenneTwisterRandom random variate generator.
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
ParametersType m_CurrentParameters
ParametersType m_BestParameters
ParametersType m_CurrentVelocity
CostFunctionType::MeasureType m_CurrentValue
CostFunctionType::MeasureType m_BestValue