Added test files for moStdDevEstimator and moStdFitnessNeighborStat
This commit is contained in:
parent
7a0b889c3d
commit
010d604926
7 changed files with 147 additions and 3 deletions
115
mo/src/continuator/moFitnessVarianceStat.h
Normal file
115
mo/src/continuator/moFitnessVarianceStat.h
Normal file
|
|
@ -0,0 +1,115 @@
|
|||
/*
|
||||
<moBestFitnessStat.h>
|
||||
Copyright (C) DOLPHIN Project-Team, INRIA Lille - Nord Europe, 2006-2010
|
||||
|
||||
Sébastien Verel, Arnaud Liefooghe, Jérémie Humeau
|
||||
|
||||
This software is governed by the CeCILL license under French law and
|
||||
abiding by the rules of distribution of free software. You can use,
|
||||
modify and/ or redistribute the software under the terms of the CeCILL
|
||||
license as circulated by CEA, CNRS and INRIA at the following URL
|
||||
"http://www.cecill.info".
|
||||
|
||||
As a counterpart to the access to the source code and rights to copy,
|
||||
modify and redistribute granted by the license, users are provided only
|
||||
with a limited warranty and the software's author, the holder of the
|
||||
economic rights, and the successive licensors have only limited liability.
|
||||
|
||||
In this respect, the user's attention is drawn to the risks associated
|
||||
with loading, using, modifying and/or developing or reproducing the
|
||||
software by the user in light of its specific status of free software,
|
||||
that may mean that it is complicated to manipulate, and that also
|
||||
therefore means that it is reserved for developers and experienced
|
||||
professionals having in-depth computer knowledge. Users are therefore
|
||||
encouraged to load and test the software's suitability as regards their
|
||||
requirements in conditions enabling the security of their systems and/or
|
||||
data to be ensured and, more generally, to use and operate it in the
|
||||
same conditions as regards security.
|
||||
The fact that you are presently reading this means that you have had
|
||||
knowledge of the CeCILL license and that you accept its terms.
|
||||
|
||||
ParadisEO WebSite : http://paradiseo.gforge.inria.fr
|
||||
Contact: paradiseo-help@lists.gforge.inria.fr
|
||||
*/
|
||||
|
||||
#ifndef moFitnessVarianceStat_h
|
||||
#define moFitnessVarianceStat_h
|
||||
|
||||
#include <continuator/moStat.h>
|
||||
|
||||
/**
|
||||
* Statistic that incrementally computes the variance of the fitness of the solutions during the search
|
||||
*/
|
||||
template <class EOT>
|
||||
class moFitnessVarianceStat : public moStat<EOT, typename EOT::Fitness>
|
||||
{
|
||||
public :
|
||||
typedef typename EOT::Fitness Fitness;
|
||||
using moStat< EOT , typename EOT::Fitness >::value;
|
||||
|
||||
/**
|
||||
* Default Constructor
|
||||
* @param _reInitSol when true the best so far is reinitialized
|
||||
*/
|
||||
moFitnessVarianceStat(bool _reInitSol = true)
|
||||
: moStat<EOT, typename EOT::Fitness>(Fitness(), "var"),
|
||||
reInitSol(_reInitSol), firstTime(true),
|
||||
nbSolutionsEncountered(0), currentAvg(0), currentVar(0)
|
||||
{ }
|
||||
|
||||
/**
|
||||
* Initialization of the best solution on the first one
|
||||
* @param _sol the first solution
|
||||
*/
|
||||
virtual void init(EOT & _sol) {
|
||||
if (reInitSol || firstTime)
|
||||
{
|
||||
value() = 0.0;
|
||||
nbSolutionsEncountered = currentAvg = currentVar = 0;
|
||||
firstTime = false;
|
||||
}
|
||||
/*else if (firstTime)
|
||||
{
|
||||
value() = 0.0;
|
||||
firstTime = false;
|
||||
}*/
|
||||
operator()(_sol);
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the best solution
|
||||
* @param _sol the current solution
|
||||
*/
|
||||
virtual void operator()(EOT & _sol) {
|
||||
++nbSolutionsEncountered;
|
||||
double x = _sol.fitness();
|
||||
double oldAvg = currentAvg;
|
||||
currentAvg = oldAvg + (x - oldAvg)/nbSolutionsEncountered;
|
||||
if (nbSolutionsEncountered > 1) // <- not really necessary
|
||||
{
|
||||
//value() = (value()/nbSolutionsEncountered + _sol.fitness())/(nbSolutionsEncountered+1);
|
||||
double oldVar = currentVar;
|
||||
currentVar = oldVar + (x - oldAvg) * (x - currentAvg);
|
||||
value() = currentVar/nbSolutionsEncountered;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @return name of the class
|
||||
*/
|
||||
virtual std::string className(void) const {
|
||||
return "moFitnessVarianceStat";
|
||||
}
|
||||
|
||||
protected:
|
||||
bool reInitSol;
|
||||
bool firstTime;
|
||||
double
|
||||
nbSolutionsEncountered
|
||||
, currentAvg
|
||||
, currentVar // actually the var * n
|
||||
;
|
||||
|
||||
};
|
||||
|
||||
#endif // moFitnessVarianceStat_h
|
||||
|
|
@ -28,7 +28,7 @@ public:
|
|||
eoEvalFunc<EOT>& fullEval,
|
||||
|
||||
/* The following should be read:
|
||||
moEval<Neighbor> >& eval = _default_eval
|
||||
moEval<Neighbor>& eval = _default_eval
|
||||
* (which is not possible to achieve as is in C++) */
|
||||
const eoOptional< moEval<Neighbor> >& eval = eoOptional< moEval<Neighbor> >::null,
|
||||
|
||||
|
|
|
|||
|
|
@ -42,7 +42,7 @@
|
|||
* From moNeighborhoodStat, to compute the average and the standard deviation of fitness in the neighborhood
|
||||
*/
|
||||
template< class Neighbor >
|
||||
class moStdFitnessNeighborStat : public moStat<typename Neighbor::EOT, double >
|
||||
class moStdFitnessNeighborStat : public moStat<typename Neighbor::EOT, double>
|
||||
{
|
||||
public :
|
||||
typedef typename Neighbor::EOT EOT ;
|
||||
|
|
|
|||
|
|
@ -4,7 +4,7 @@
|
|||
|
||||
#include <mo>
|
||||
#include <eoFunctor.h> // FIXME: Why don't we use eoFunctorBase on the mother classes
|
||||
#include "moRealNeighbor.h"
|
||||
#include "neighborhood/moRealNeighbor.h"
|
||||
|
||||
template<class Distrib, class Neighbor>
|
||||
class moRealNeighborhood : public moRndNeighborhood< Neighbor >, public eoFunctorBase
|
||||
|
|
|
|||
|
|
@ -4,6 +4,7 @@
|
|||
|
||||
include_directories(${EO_SRC_DIR}/src)
|
||||
include_directories(${MO_SRC_DIR}/src)
|
||||
include_directories(${EDO_SRC_DIR}/src)
|
||||
include_directories(${PROBLEMS_SRC_DIR})
|
||||
include_directories(${CMAKE_CURRENT_SOURCE_DIR})
|
||||
|
||||
|
|
@ -94,7 +95,11 @@ set (TEST_LIST
|
|||
t-moStatistics
|
||||
t-moIndexedVectorTabuList
|
||||
# t-moRndIndexedVectorTabuList
|
||||
t-moFitnessVarianceStat
|
||||
t-moStdDevEstimator
|
||||
t-moDynSpanCoolingSchedule
|
||||
t-moTriki
|
||||
t-moTrikiReal
|
||||
)
|
||||
|
||||
######################################################################################
|
||||
|
|
|
|||
24
mo/test/t-moFitnessVarianceStat.cpp
Normal file
24
mo/test/t-moFitnessVarianceStat.cpp
Normal file
|
|
@ -0,0 +1,24 @@
|
|||
//-----------------------------------------------------------------------------
|
||||
// t-moFitnessNeighborStat.cpp
|
||||
//-----------------------------------------------------------------------------
|
||||
|
||||
#include <eo>
|
||||
#include "es/eoReal.h"
|
||||
#include "continuator/moFitnessVarianceStat.h"
|
||||
#include "neighborhood/moRealNeighbor.h"
|
||||
#include "neighborhood/moRealNeighborhood.h"
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
|
||||
typedef eoReal< eoMinimizingFitness > EOT;
|
||||
typedef moRealNeighbor< EOT > Neighbor;
|
||||
|
||||
int main(int ac, char** av)
|
||||
{
|
||||
//moNeighborhoodStat<Neighbor> nhStat
|
||||
moFitnessVarianceStat<EOT> stat;
|
||||
EOT solution(2, 5);
|
||||
stat(solution);
|
||||
//assert(stat.value() == 1);
|
||||
std::cout << "ok " << stat.value() << std::endl;
|
||||
}
|
||||
0
mo/test/t-moStdDevEstimator.cpp
Normal file
0
mo/test/t-moStdDevEstimator.cpp
Normal file
Loading…
Add table
Add a link
Reference in a new issue