Removed eoEsBase and created an eoFixedLength
This commit is contained in:
parent
71b0dc1771
commit
152d42d41e
5 changed files with 20 additions and 20 deletions
|
|
@ -24,25 +24,25 @@
|
|||
*/
|
||||
//-----------------------------------------------------------------------------
|
||||
|
||||
#ifndef _eoEsBase_h
|
||||
#define _eoEsBase_h
|
||||
#ifndef _eoFixedLength_h
|
||||
#define _eoFixedLength_h
|
||||
|
||||
/**
|
||||
\ingroup EvolutionStrategies
|
||||
|
||||
Base class for evolution strategies, just derives from EO and vector and
|
||||
redirects the operator< to EO (fitness based comparison)
|
||||
Base class for fixed length chromosomes, just derives from EO and vector and
|
||||
redirects the smaller than operator to EO (fitness based comparison)
|
||||
*/
|
||||
|
||||
template <class FitT>
|
||||
class eoEsBase : public EO<FitT>, public std::vector<double>
|
||||
template <class FitT, class GeneType>
|
||||
class eoFixedLength : public EO<FitT>, public std::vector<GeneType>
|
||||
{
|
||||
public :
|
||||
|
||||
typedef double Type;
|
||||
|
||||
/// to avoid conflicts between EO::operator< and vector<double>::operator<
|
||||
bool operator<(const eoEsBase<FitT>& _eo) const
|
||||
bool operator<(const eoFixedLength<FitT, GeneType>& _eo) const
|
||||
{
|
||||
return EO<FitT>::operator<(_eo);
|
||||
}
|
||||
|
|
@ -50,10 +50,10 @@ class eoEsBase : public EO<FitT>, public std::vector<double>
|
|||
};
|
||||
|
||||
/// to avoid conflicts between EO::operator< and vector<double>::operator<
|
||||
template <class FitT>
|
||||
bool operator<(const eoEsBase<FitT>& _eo1, const eoEsBase<FitT>& _eo2)
|
||||
template <class FitT, class GeneType>
|
||||
bool operator<(const eoFixedLength<FitT, GeneType>& _eo1, const eoFixedLength<FitT, GeneType>& _eo2)
|
||||
{
|
||||
return _eo1.operator<(_eo2);
|
||||
}
|
||||
|
||||
#endif
|
||||
#endif
|
||||
|
|
@ -27,7 +27,7 @@
|
|||
#ifndef _eoEsFull_h
|
||||
#define _eoEsFull_h
|
||||
|
||||
#include <es/eoEsBase.h>
|
||||
#include <eoFixedLength.h>
|
||||
|
||||
/**
|
||||
\ingroup EvolutionStrategies
|
||||
|
|
@ -37,11 +37,11 @@ rates and correlated mutations.
|
|||
*/
|
||||
|
||||
template <class Fit>
|
||||
class eoEsFull : public eoEsBase<Fit>
|
||||
class eoEsFull : public eoFixedLength<Fit, double>
|
||||
{
|
||||
public :
|
||||
|
||||
eoEsFull(void) : eoEsBase<Fit>() {}
|
||||
eoEsFull(void) : eoFixedLength<Fit, double>() {}
|
||||
|
||||
std::string className(void) const { return "eoEsFull"; }
|
||||
|
||||
|
|
|
|||
|
|
@ -218,7 +218,7 @@ public:
|
|||
keepInBounds(_eo);
|
||||
}
|
||||
|
||||
void keepInBounds(eoEsBase<FitT>& _eo) const
|
||||
void keepInBounds(eoFixedLength<FitT, double>& _eo) const
|
||||
{
|
||||
for (unsigned i = 0; i < _eo.size(); ++i)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -30,7 +30,7 @@
|
|||
#include <EO.h>
|
||||
#include <vector>
|
||||
|
||||
#include <es/eoEsBase.h>
|
||||
#include <eoFixedLength.h>
|
||||
|
||||
/**
|
||||
\ingroup EvolutionStrategies
|
||||
|
|
@ -44,11 +44,11 @@ see also eoEsStdev eoEsFull
|
|||
*/
|
||||
|
||||
template <class Fit>
|
||||
class eoEsSimple : public eoEsBase<Fit>
|
||||
class eoEsSimple : public eoFixedLength<Fit, double>
|
||||
{
|
||||
public :
|
||||
|
||||
eoEsSimple(void) : eoEsBase<Fit>() {}
|
||||
eoEsSimple(void) : eoFixedLength<Fit, double>() {}
|
||||
|
||||
std::string className(void) const { return "eoEsSimple"; }
|
||||
|
||||
|
|
|
|||
|
|
@ -27,7 +27,7 @@
|
|||
#ifndef _eoEsStdev_h
|
||||
#define _eoEsStdev_h
|
||||
|
||||
#include <es/eoEsBase.h>
|
||||
#include <eoFixedLength.h>
|
||||
|
||||
/**
|
||||
\ingroup EvolutionStrategies
|
||||
|
|
@ -37,11 +37,11 @@ deviations.
|
|||
*/
|
||||
|
||||
template <class Fit>
|
||||
class eoEsStdev : public eoEsBase<Fit>
|
||||
class eoEsStdev : public eoFixedLength<Fit, double>
|
||||
{
|
||||
public :
|
||||
|
||||
eoEsStdev(void) : eoEsBase<Fit>() {}
|
||||
eoEsStdev(void) : eoFixedLength<Fit, double>() {}
|
||||
|
||||
std::string className(void) const { return "eoEsStdev"; }
|
||||
|
||||
|
|
|
|||
Reference in a new issue