Implements the elitist CMA-ES. More...
#include <shark/Algorithms/DirectSearch/ElitistCMA.h>
Public Member Functions | |
SHARK_EXPORT_SYMBOL | ElitistCMA (random::rng_type &rng=random::globalRng) |
std::string | name () const |
From INameable: return the class name. | |
SHARK_EXPORT_SYMBOL void | read (InArchive &archive) |
Read the component from the supplied archive. | |
SHARK_EXPORT_SYMBOL void | write (OutArchive &archive) const |
Write the component to the supplied archive. | |
SHARK_EXPORT_SYMBOL void | init (ObjectiveFunctionType const &function, SearchPointType const &p) |
Initializes the algorithm for the supplied objective function. | |
SHARK_EXPORT_SYMBOL void | step (ObjectiveFunctionType const &function) |
Executes one iteration of the algorithm. | |
bool | activeUpdate () const |
Returns true when the active update is used (default true). | |
bool & | activeUpdate () |
Setter function to enable active update. Returns true when the active update is used (default true). | |
double | constrainedPenaltyFactor () const |
Returns the penalty factor for an individual that is outside the feasible area. | |
double & | constrainedPenaltyFactor () |
Returns a reference to the penalty factor for an individual that is outside the feasible area. | |
double | sigma () const |
Returns the current step length. | |
double & | sigma () |
Returns the current step length. | |
Public Member Functions inherited from shark::AbstractSingleObjectiveOptimizer< RealVector > | |
std::size_t | numInitPoints () const |
By default most single objective optimizers only require a single point. | |
virtual void | init (ObjectiveFunctionType const &function, std::vector< SearchPointType > const &initPoints) |
Initialize the optimizer for the supplied objective function using a set of initialisation points. | |
virtual const SolutionType & | solution () const |
returns the current solution of the optimizer | |
Public Member Functions inherited from shark::AbstractOptimizer< PointType, ResultT, SolutionTypeT > | |
const Features & | features () const |
virtual void | updateFeatures () |
bool | requiresValue () const |
bool | requiresFirstDerivative () const |
bool | requiresSecondDerivative () const |
bool | canSolveConstrained () const |
bool | requiresClosestFeasible () const |
virtual | ~AbstractOptimizer () |
virtual void | init (ObjectiveFunctionType const &function) |
Initialize the optimizer for the supplied objective function. | |
virtual void | init (ObjectiveFunctionType const &function, std::vector< SearchPointType > const &initPoints)=0 |
Initialize the optimizer for the supplied objective function using a set of initialisation points. | |
virtual void | step (ObjectiveFunctionType const &function)=0 |
Carry out one step of the optimizer for the supplied objective function. | |
Public Member Functions inherited from shark::INameable | |
virtual | ~INameable () |
Public Member Functions inherited from shark::ISerializable | |
virtual | ~ISerializable () |
Virtual d'tor. | |
void | load (InArchive &archive, unsigned int version) |
Versioned loading of components, calls read(...). | |
void | save (OutArchive &archive, unsigned int version) const |
Versioned storing of components, calls write(...). | |
BOOST_SERIALIZATION_SPLIT_MEMBER () | |
Additional Inherited Members | |
Public Types inherited from shark::AbstractSingleObjectiveOptimizer< RealVector > | |
typedef base_type::SearchPointType | SearchPointType |
typedef base_type::SolutionType | SolutionType |
typedef base_type::ResultType | ResultType |
typedef base_type::ObjectiveFunctionType | ObjectiveFunctionType |
Public Types inherited from shark::AbstractOptimizer< PointType, ResultT, SolutionTypeT > | |
enum | Feature { REQUIRES_VALUE = 1 , REQUIRES_FIRST_DERIVATIVE = 2 , REQUIRES_SECOND_DERIVATIVE = 4 , CAN_SOLVE_CONSTRAINED = 8 , REQUIRES_CLOSEST_FEASIBLE = 16 } |
Models features that the optimizer requires from the objective function. More... | |
typedef PointType | SearchPointType |
typedef ResultT | ResultType |
typedef SolutionTypeT | SolutionType |
typedef AbstractObjectiveFunction< PointType, ResultType > | ObjectiveFunctionType |
typedef TypedFlags< Feature > | Features |
typedef TypedFeatureNotAvailableException< Feature > | FeatureNotAvailableException |
Protected Member Functions inherited from shark::AbstractOptimizer< PointType, ResultT, SolutionTypeT > | |
void | checkFeatures (ObjectiveFunctionType const &objectiveFunction) |
Convenience function that checks whether the features of the supplied objective function match with the required features of the optimizer. | |
Protected Attributes inherited from shark::AbstractSingleObjectiveOptimizer< RealVector > | |
SolutionType | m_best |
Current solution of the optimizer. | |
Protected Attributes inherited from shark::AbstractOptimizer< PointType, ResultT, SolutionTypeT > | |
Features | m_features |
Implements the elitist CMA-ES.
The algorithm is based on
C. Igel, T. Suttorp, and N. Hansen. A Computational Efficient Covariance Matrix Update and a (1+1)-CMA for Evolution Strategies. In Proceedings of the Genetic and Evolutionary Computation Conference (GECCO 2006), pp. 453-460, ACM Press, 2006
D. V. Arnold and N. Hansen: Active covariance matrix adaptation for the (1+1)-CMA-ES. In Proceedings of the Genetic and Evolutionary
Definition at line 69 of file ElitistCMA.h.
SHARK_EXPORT_SYMBOL shark::ElitistCMA::ElitistCMA | ( | random::rng_type & | rng = random::globalRng | ) |
|
inline |
Setter function to enable active update. Returns true when the active update is used (default true).
Definition at line 95 of file ElitistCMA.h.
|
inline |
Returns true when the active update is used (default true).
Definition at line 91 of file ElitistCMA.h.
|
inline |
Returns a reference to the penalty factor for an individual that is outside the feasible area.
The value is multiplied with the distance to the nearest feasible point.
Definition at line 109 of file ElitistCMA.h.
References shark::PenalizingEvaluator::m_penaltyFactor.
|
inline |
Returns the penalty factor for an individual that is outside the feasible area.
The value is multiplied with the distance to the nearest feasible point.
Definition at line 102 of file ElitistCMA.h.
References shark::PenalizingEvaluator::m_penaltyFactor.
|
virtual |
Initializes the algorithm for the supplied objective function.
Implements shark::AbstractSingleObjectiveOptimizer< RealVector >.
Referenced by main().
|
inlinevirtual |
From INameable: return the class name.
Reimplemented from shark::INameable.
Definition at line 75 of file ElitistCMA.h.
|
virtual |
Read the component from the supplied archive.
[in,out] | archive | The archive to read from. |
Reimplemented from shark::ISerializable.
|
inline |
Returns the current step length.
Definition at line 119 of file ElitistCMA.h.
References shark::Individual< PointType, FitnessTypeT, Chromosome >::chromosome().
|
inline |
Returns the current step length.
Definition at line 114 of file ElitistCMA.h.
References shark::Individual< PointType, FitnessTypeT, Chromosome >::chromosome().
Referenced by main().
SHARK_EXPORT_SYMBOL void shark::ElitistCMA::step | ( | ObjectiveFunctionType const & | function | ) |
Executes one iteration of the algorithm.
Referenced by main().
|
virtual |
Write the component to the supplied archive.
[in,out] | archive | The archive to write to. |
Reimplemented from shark::ISerializable.