EvolvingObjects
|
Simple normal mutation of a std::vector of real values. More...
#include <eoNormalMutation.h>
Public Member Functions | |
eoNormalMutation (double &_sigma, const double &_p_change=1.0) | |
(Default) Constructor. | |
eoNormalMutation (eoRealVectorBounds &_bounds, double _sigma, const double &_p_change=1.0) | |
Constructor with bounds. | |
virtual std::string | className () const |
The class name. | |
bool | operator() (EOT &_eo) |
Do it! | |
double & | Sigma () |
Accessor to ref to sigma - for update and monitor. | |
Private Attributes | |
double & | sigma |
eoRealVectorBounds & | bounds |
double | p_change |
Simple normal mutation of a std::vector of real values.
The stDev is fixed - but it is passed ans stored as a reference, to enable dynamic mutations (see eoOenFithMutation below).
As for the bounds, the values are here folded back into the bounds. The other possiblity would be to iterate until we fall inside the bounds - but this sometimes takes a long time!!!
Definition at line 120 of file eoNormalMutation.h.
eoNormalMutation< EOT >::eoNormalMutation | ( | double & | _sigma, |
const double & | _p_change = 1.0 |
||
) | [inline] |
(Default) Constructor.
The bounds are initialized with the global object that says: no bounds.
_sigma | the range for uniform nutation |
_p_change | the probability to change a given coordinate |
Definition at line 131 of file eoNormalMutation.h.
eoNormalMutation< EOT >::eoNormalMutation | ( | eoRealVectorBounds & | _bounds, |
double | _sigma, | ||
const double & | _p_change = 1.0 |
||
) | [inline] |
Constructor with bounds.
_bounds | an eoRealVectorBounds that contains the bounds |
_sigma | the range for uniform nutation |
_p_change | the probability to change a given coordinate |
Definition at line 140 of file eoNormalMutation.h.
bool eoNormalMutation< EOT >::operator() | ( | EOT & | _eo | ) | [inline, virtual] |
Do it!
_eo | The cromosome undergoing the mutation |
Implements eoUF< EOT &, bool >.
Reimplemented in eoOneFifthMutation< EOT >.
Definition at line 151 of file eoNormalMutation.h.
References eoRng::flip(), eoRealBaseVectorBounds::foldsInBounds(), and eoRng::normal().