Implements the Cross Entropy Method. More...
#include <shark/Algorithms/DirectSearch/CrossEntropyMethod.h>
Classes | |
class | ConstantNoise |
Constant noise term z_t = noise. More... | |
class | INoiseType |
Interface class for noise type. More... | |
class | LinearNoise |
Linear noise term z_t = a + t / b. More... | |
Public Member Functions | |
SHARK_EXPORT_SYMBOL | CrossEntropyMethod () |
Default c'tor. | |
std::string | name () const |
From INameable: return the class name. | |
void | read (InArchive &archive) |
Read the component from the supplied archive. | |
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 and the initial mean p. | |
SHARK_EXPORT_SYMBOL void | init (ObjectiveFunctionType const &function, SearchPointType const &initialSearchPoint, unsigned int populationSize, unsigned int selectionSize, RealVector initialSigma) |
Initializes the algorithm for the supplied objective function. | |
SHARK_EXPORT_SYMBOL void | step (ObjectiveFunctionType const &function) |
Executes one iteration of the algorithm. | |
RealVector const & | variance () const |
Access the current variance. | |
void | setVariance (RealVector variance) |
Set the variance to a vector. | |
void | setVariance (double variance) |
Set all variance values. | |
RealVector const & | mean () const |
Access the current population mean. | |
unsigned int | selectionSize () const |
Returns the size of the parent population. | |
unsigned int & | selectionSize () |
Returns a mutable reference to the size of the parent population. | |
unsigned int | populationSize () const |
Returns a immutable reference to the size of the population. | |
unsigned int & | populationSize () |
Returns a mutable reference to the size of the population. | |
void | setNoiseType (INoiseType *noiseType) |
Set the noise type from a raw pointer. | |
const INoiseType & | getNoiseType () const |
Get an immutable reference to Noise Type. | |
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 () | |
Static Public Member Functions | |
static SHARK_EXPORT_SYMBOL unsigned | suggestPopulationSize () |
Sets default value for Population size. | |
static SHARK_EXPORT_SYMBOL unsigned | suggestSelectionSize (unsigned int populationSize) |
Calculates selection size for the supplied population size. | |
Protected Types | |
typedef Individual< RealVector, double, RealVector > | IndividualType |
Protected Member Functions | |
SHARK_EXPORT_SYMBOL void | updateStrategyParameters (std::vector< IndividualType > const &parents) |
Updates the strategy parameters based on the supplied parent population. | |
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 | |
std::size_t | m_numberOfVariables |
Stores the dimensionality of the search space. | |
unsigned int | m_selectionSize |
Number of vectors chosen when updating distribution parameters. | |
unsigned int | m_populationSize |
Number of vectors sampled in a generation. | |
RealVector | m_variance |
Variance for sample parameters. | |
RealVector | m_mean |
The mean of the population. | |
unsigned | m_counter |
Counter for generations. | |
StrongNoisePtr | m_noise |
Noise type to apply in the update of distribution parameters. | |
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 Cross Entropy Method.
This class implements the noisy cross entropy method as descibed in the following article.
Christophe Thiery, Bruno Scherrer. Improvements on Learning Tetris with Cross Entropy. International Computer Games Association Journal, ICGA, 2009, 32. <inria-00418930>
The algorithm aims to minimize an objective function through stochastic search. It works iteratively until a certain stopping criteria is met. At each iteration, it samples a number of vectors from a Gaussian distribution and evaluates each of these against the supplied objective function. Based on the return value from the objective function, a subset of the the best ranked vectors are chosen to update the search parameters of the next generation.
The mean of the Gaussian distribution is set to the centroid of the best ranked vectors, and the variance is set to the variance of the best ranked vectors in each individual dimension.
Definition at line 68 of file CrossEntropyMethod.h.
|
protected |
Definition at line 199 of file CrossEntropyMethod.h.
typedef boost::shared_ptr<INoiseType> shark::CrossEntropyMethod::StrongNoisePtr |
Smart pointer for noise type.
Definition at line 80 of file CrossEntropyMethod.h.
SHARK_EXPORT_SYMBOL shark::CrossEntropyMethod::CrossEntropyMethod | ( | ) |
Default c'tor.
|
inline |
Get an immutable reference to Noise Type.
Definition at line 193 of file CrossEntropyMethod.h.
References m_noise.
SHARK_EXPORT_SYMBOL void shark::CrossEntropyMethod::init | ( | ObjectiveFunctionType const & | function, |
SearchPointType const & | initialSearchPoint, | ||
unsigned int | populationSize, | ||
unsigned int | selectionSize, | ||
RealVector | initialSigma | ||
) |
Initializes the algorithm for the supplied objective function.
|
virtual |
Initializes the algorithm for the supplied objective function and the initial mean p.
Implements shark::AbstractSingleObjectiveOptimizer< RealVector >.
|
inline |
Access the current population mean.
Definition at line 162 of file CrossEntropyMethod.h.
References m_mean.
|
inlinevirtual |
From INameable: return the class name.
Reimplemented from shark::INameable.
Definition at line 116 of file CrossEntropyMethod.h.
|
inline |
Returns a mutable reference to the size of the population.
Definition at line 182 of file CrossEntropyMethod.h.
References m_populationSize.
|
inline |
Returns a immutable reference to the size of the population.
Definition at line 177 of file CrossEntropyMethod.h.
References m_populationSize.
|
virtual |
Read the component from the supplied archive.
[in,out] | archive | The archive to read from. |
Reimplemented from shark::ISerializable.
|
inline |
Returns a mutable reference to the size of the parent population.
Definition at line 172 of file CrossEntropyMethod.h.
References m_selectionSize.
|
inline |
Returns the size of the parent population.
Definition at line 167 of file CrossEntropyMethod.h.
References m_selectionSize.
|
inline |
Set the noise type from a raw pointer.
Definition at line 187 of file CrossEntropyMethod.h.
References m_noise.
|
inline |
Set all variance values.
Definition at line 157 of file CrossEntropyMethod.h.
References m_variance, and variance().
|
inline |
Set the variance to a vector.
Definition at line 151 of file CrossEntropyMethod.h.
References m_variance, and variance().
SHARK_EXPORT_SYMBOL void shark::CrossEntropyMethod::step | ( | ObjectiveFunctionType const & | function | ) |
Executes one iteration of the algorithm.
|
static |
Sets default value for Population size.
|
static |
Calculates selection size for the supplied population size.
|
protected |
Updates the strategy parameters based on the supplied parent population.
|
inline |
Access the current variance.
Definition at line 146 of file CrossEntropyMethod.h.
References m_variance.
Referenced by setVariance(), and setVariance().
|
virtual |
Write the component to the supplied archive.
[in,out] | archive | The archive to write to. |
Reimplemented from shark::ISerializable.
|
protected |
Counter for generations.
Definition at line 212 of file CrossEntropyMethod.h.
|
protected |
The mean of the population.
Definition at line 210 of file CrossEntropyMethod.h.
Referenced by mean().
|
protected |
Noise type to apply in the update of distribution parameters.
Definition at line 214 of file CrossEntropyMethod.h.
Referenced by getNoiseType(), and setNoiseType().
|
protected |
Stores the dimensionality of the search space.
Definition at line 203 of file CrossEntropyMethod.h.
|
protected |
Number of vectors sampled in a generation.
Definition at line 205 of file CrossEntropyMethod.h.
Referenced by populationSize(), and populationSize().
|
protected |
Number of vectors chosen when updating distribution parameters.
Definition at line 204 of file CrossEntropyMethod.h.
Referenced by selectionSize(), and selectionSize().
|
protected |
Variance for sample parameters.
Definition at line 207 of file CrossEntropyMethod.h.
Referenced by setVariance(), setVariance(), and variance().