Essai du nouveau "modele"
git-svn-id: svn://scm.gforge.inria.fr/svnroot/paradiseo@1655 331e1502-861f-0410-8da2-ba01fb791d7f
This commit is contained in:
parent
6a72d70f23
commit
c3085595bf
13 changed files with 85 additions and 98 deletions
|
|
@ -22,7 +22,7 @@ public:
|
||||||
* @return true if the neighbor1 is better than neighbor2
|
* @return true if the neighbor1 is better than neighbor2
|
||||||
*/
|
*/
|
||||||
virtual bool operator()(const Neighbor& _neighbor1, const Neighbor& _neighbor2) {
|
virtual bool operator()(const Neighbor& _neighbor1, const Neighbor& _neighbor2) {
|
||||||
return (neighbor1.fitness() > neighbor2.fitness());
|
return (_neighbor1.fitness() > _neighbor2.fitness());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -4,11 +4,8 @@
|
||||||
#include <neighborhood/moBitNeighbor.h>
|
#include <neighborhood/moBitNeighbor.h>
|
||||||
#include <ga.h>
|
#include <ga.h>
|
||||||
|
|
||||||
/**
|
|
||||||
* contener of the neighbor information
|
|
||||||
*/
|
|
||||||
template< class Fitness >
|
template< class Fitness >
|
||||||
class moFullEvalBitNeighbor : public moBitNeighbor<Fitness>
|
class moFullEvalBitNeighbor : public moFullEvalByModif<moBitNeighbor<Fitness> >
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
typedef eoBit<Fitness> EOType ;
|
typedef eoBit<Fitness> EOType ;
|
||||||
|
|
|
||||||
|
|
@ -2,7 +2,7 @@
|
||||||
#define moFullEvalByModif_H
|
#define moFullEvalByModif_H
|
||||||
|
|
||||||
#include <eoEvalFunc.h>
|
#include <eoEvalFunc.h>
|
||||||
#include <moEval.h>
|
#include <eval/moEval.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Full evaluation to use with a moBackableNeighbor
|
* Full evaluation to use with a moBackableNeighbor
|
||||||
|
|
@ -11,14 +11,14 @@ template<class BackableNeighbor>
|
||||||
class moFullEvalByModif : public moEval<BackableNeighbor>
|
class moFullEvalByModif : public moEval<BackableNeighbor>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
using moEval<BackableNeighbor>::EOT EOT;
|
typedef typename moEval<BackableNeighbor>::EOT EOT;
|
||||||
using moEval<BackableNeighbor>::Fitness Fitness;
|
typedef typename moEval<BackableNeighbor>::Fitness Fitness;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ctor
|
* Ctor
|
||||||
* @param _eval the full evaluation object
|
* @param _eval the full evaluation object
|
||||||
*/
|
*/
|
||||||
moFullEvalByCopy(eoEvalFunc<EOT> & _eval) : eval(_eval) {}
|
moFullEvalByModif(eoEvalFunc<EOT>& _eval) : eval(_eval) {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Full evaluation of the neighbor by copy
|
* Full evaluation of the neighbor by copy
|
||||||
|
|
@ -44,6 +44,7 @@ public:
|
||||||
_neighbor.moveBack(_sol);
|
_neighbor.moveBack(_sol);
|
||||||
// set the fitness back
|
// set the fitness back
|
||||||
_sol.fitness(tmpFit);
|
_sol.fitness(tmpFit);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -5,6 +5,7 @@
|
||||||
#include <eoFunctor.h>
|
#include <eoFunctor.h>
|
||||||
|
|
||||||
#include <neighborhood/moNeighborhood.h>
|
#include <neighborhood/moNeighborhood.h>
|
||||||
|
#include <eval/moEval.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Explore the neighborhood
|
* Explore the neighborhood
|
||||||
|
|
@ -22,7 +23,7 @@ public:
|
||||||
* @param _neighborhood the neighborhood
|
* @param _neighborhood the neighborhood
|
||||||
* @param _eval the evaluation function
|
* @param _eval the evaluation function
|
||||||
*/
|
*/
|
||||||
moNeighborhoodExplorer(Neighborhood& _neighborhood, moEval<Neighbor>& _eval):neighborhood(_neighborhood), eval(_eval) {}
|
moNeighborhoodExplorer(Neighborhood& _neighborhood, moEval<Neighbor>& _eval, moNeighborComparator<Neighbor>& _comparator):neighborhood(_neighborhood), eval(_eval), comparator(_comparator) {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Init Search parameters
|
* Init Search parameters
|
||||||
|
|
@ -73,7 +74,7 @@ public:
|
||||||
protected:
|
protected:
|
||||||
Neighborhood & neighborhood;
|
Neighborhood & neighborhood;
|
||||||
moEval<Neighbor>& eval;
|
moEval<Neighbor>& eval;
|
||||||
|
moNeighborComparator<Neighbor>& comparator;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -3,17 +3,22 @@
|
||||||
|
|
||||||
#include <explorer/moNeighborhoodExplorer.h>
|
#include <explorer/moNeighborhoodExplorer.h>
|
||||||
|
|
||||||
template< class NH >
|
template< class Neighborhood >
|
||||||
class moSimpleHCexplorer : public moNeighborhoodExplorer<NH>
|
class moSimpleHCexplorer : public moNeighborhoodExplorer<Neighborhood>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
typedef NH Neighborhood ;
|
|
||||||
typedef typename Neighborhood::EOT EOT ;
|
typedef typename Neighborhood::EOT EOT ;
|
||||||
typedef typename Neighborhood::Neighbor Neighbor ;
|
typedef typename Neighborhood::Neighbor Neighbor ;
|
||||||
|
|
||||||
|
using moNeighborhoodExplorer<Neighborhood>::neighborhood;
|
||||||
|
using moNeighborhoodExplorer<Neighborhood>::eval;
|
||||||
|
using moNeighborhoodExplorer<Neighborhood>::comparator;
|
||||||
|
|
||||||
// empty constructor
|
// empty constructor
|
||||||
moSimpleHCexplorer(Neighborhood & __neighborhood) : neighborhood(__neighborhood){
|
moSimpleHCexplorer(Neighborhood& _neighborhood, moEval<Neighbor>& _eval, moNeighborComparator<Neighbor>& _comparator) : moNeighborhoodExplorer<Neighborhood>(_neighborhood, _eval, _comparator){
|
||||||
isAccept = false;
|
isAccept = false;
|
||||||
|
current=new Neighbor();
|
||||||
|
best=new Neighbor();
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void initParam (EOT & solution) { } ;
|
virtual void initParam (EOT & solution) { } ;
|
||||||
|
|
@ -24,52 +29,51 @@ public:
|
||||||
|
|
||||||
virtual void operator() (EOT & solution) {
|
virtual void operator() (EOT & solution) {
|
||||||
|
|
||||||
//est qu'on peut initializer
|
//est qu'on peut initializer
|
||||||
|
|
||||||
if(neighborhood.hasNeighbor(solution)){
|
|
||||||
neighborhood.init(solution, *current);
|
|
||||||
|
|
||||||
(*current).eval(solution);
|
|
||||||
|
|
||||||
best = ¤t;
|
|
||||||
|
|
||||||
while (neighborhood.cont(solution)) {
|
if(neighborhood.hasNeighbor(solution)){
|
||||||
neighborhood.next(solution, *current);
|
neighborhood.init(solution, (*current));
|
||||||
|
|
||||||
(*current).eval(solution);
|
eval(solution, (*current));
|
||||||
|
|
||||||
if (current.betterThan(best)) {
|
std::cout <<"sol et neighbor:"<< solution << ", "<< (*current) << std::endl;
|
||||||
|
|
||||||
best = ¤t;
|
(*best) = (*current);
|
||||||
|
|
||||||
|
while (neighborhood.cont(solution)) {
|
||||||
|
neighborhood.next(solution, (*current));
|
||||||
|
|
||||||
|
eval(solution, (*current));
|
||||||
|
std::cout <<"sol et neighbor:"<< solution << ", "<< (*current) << std::endl;
|
||||||
|
if (comparator((*current), (*best))) {
|
||||||
|
(*best) = (*current);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
isAccept=false;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
isAccept=false;
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
virtual bool isContinue(EOT & solution) {
|
virtual bool isContinue(EOT & solution) {
|
||||||
return isAccept ;
|
return isAccept ;
|
||||||
};
|
};
|
||||||
|
|
||||||
virtual void move(EOT & solution) {
|
virtual void move(EOT & solution) {
|
||||||
|
|
||||||
best.move(solution);
|
(*best).move(solution);
|
||||||
|
|
||||||
solution.fitness(best.fitness());
|
solution.fitness((*best).fitness());
|
||||||
};
|
};
|
||||||
|
|
||||||
virtual bool accept(EOT & solution) {
|
virtual bool accept(EOT & solution) {
|
||||||
if(neighborhood.hasNeighbor(solution)){
|
if(neighborhood.hasNeighbor(solution)){
|
||||||
isAccept = (solution.fitness() < best.fitness()) ;
|
isAccept = (solution.fitness() < (*best).fitness()) ;
|
||||||
}
|
}
|
||||||
return isAccept;
|
return isAccept;
|
||||||
};
|
};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Neighborhood & neighborhood;
|
|
||||||
|
|
||||||
// attention il faut que le constructeur vide existe
|
// attention il faut que le constructeur vide existe
|
||||||
Neighbor* best;
|
Neighbor* best;
|
||||||
|
|
@ -82,12 +86,3 @@ private:
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
// Local Variables:
|
|
||||||
// coding: iso-8859-1
|
|
||||||
// mode: C++
|
|
||||||
// c-file-offsets: ((c . 0))
|
|
||||||
// c-file-style: "Stroustrup"
|
|
||||||
// fill-column: 80
|
|
||||||
// End:
|
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@
|
||||||
* Neighbor with a move back function to use in a moFullEvalByModif
|
* Neighbor with a move back function to use in a moFullEvalByModif
|
||||||
*/
|
*/
|
||||||
template< class EOT , class Fitness >
|
template< class EOT , class Fitness >
|
||||||
class moBackableNeighbor : moNeighbor<EOT, Fitness>
|
class moBackableNeighbor : public moNeighbor<EOT, Fitness>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
|
@ -13,7 +13,7 @@ public:
|
||||||
* the move back function
|
* the move back function
|
||||||
* @param _solution the solution to moveBack
|
* @param _solution the solution to moveBack
|
||||||
*/
|
*/
|
||||||
virtual moveBack(EOT & _solution) = 0;
|
virtual void moveBack(EOT & _solution){}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,24 +2,25 @@
|
||||||
#define _bitNeighbor_h
|
#define _bitNeighbor_h
|
||||||
|
|
||||||
#include <ga/eoBit.h>
|
#include <ga/eoBit.h>
|
||||||
#include <neighborhood/moNeighbor.h>
|
#include <neighborhood/moBackableNeighbor.h>
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
contener of the neighbor information
|
contener of the neighbor information
|
||||||
*/
|
*/
|
||||||
template< class Fitness >
|
template< class Fitness >
|
||||||
class moBitNeighbor : public moNeighbor< eoBit<Fitness> , Fitness>
|
class moBitNeighbor : public moBackableNeighbor<eoBit<Fitness>, Fitness>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
typedef eoBit<Fitness> EOType ;
|
typedef eoBit<Fitness> EOType ;
|
||||||
|
|
||||||
using moNeighbor< eoBit<Fitness> , Fitness>::fitness;
|
using moNeighbor<eoBit<Fitness>, Fitness>::fitness;
|
||||||
|
|
||||||
// describe the neighbor
|
// describe the neighbor
|
||||||
unsigned bit ;
|
unsigned bit ;
|
||||||
|
|
||||||
// empty constructor needed
|
// empty constructor needed
|
||||||
moBitNeighbor() : moNeighbor<eoBit<Fitness> , Fitness>() { } ;
|
moBitNeighbor() : moBackableNeighbor<eoBit<Fitness> , Fitness>() { } ;
|
||||||
|
|
||||||
// copy constructor
|
// copy constructor
|
||||||
moBitNeighbor(const moBitNeighbor & n) : moNeighbor<eoBit<Fitness> , Fitness>(n) {
|
moBitNeighbor(const moBitNeighbor & n) : moNeighbor<eoBit<Fitness> , Fitness>(n) {
|
||||||
|
|
@ -43,7 +44,11 @@ public:
|
||||||
move the solution
|
move the solution
|
||||||
*/
|
*/
|
||||||
virtual void move(EOType & solution) {
|
virtual void move(EOType & solution) {
|
||||||
solution[bit] = solution[bit]?false:true ;
|
solution[bit] = !solution[bit];
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void moveBack(EOType & solution) {
|
||||||
|
solution[bit] = !solution[bit];
|
||||||
}
|
}
|
||||||
|
|
||||||
// by default: if the fitness of the current solution is stricly higher than the other neighbor
|
// by default: if the fitness of the current solution is stricly higher than the other neighbor
|
||||||
|
|
|
||||||
|
|
@ -22,18 +22,18 @@ public:
|
||||||
initialisation of the neighborhood
|
initialisation of the neighborhood
|
||||||
*/
|
*/
|
||||||
virtual void init(EOT & solution, Neighbor & _neighbor) {
|
virtual void init(EOT & solution, Neighbor & _neighbor) {
|
||||||
currentBit = 0 ;
|
currentBit = 0 ;
|
||||||
|
|
||||||
_neighbor.bit = currentBit ;
|
_neighbor.bit = currentBit ;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Give the next neighbor
|
Give the next neighbor
|
||||||
*/
|
*/
|
||||||
virtual void next(EOT & solution, Neighbor & neighbor) {
|
virtual void next(EOT & solution, Neighbor & neighbor) {
|
||||||
currentBit++ ;
|
currentBit++ ;
|
||||||
|
|
||||||
neighbor.bit = currentBit ;
|
neighbor.bit = currentBit ;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
@ -50,11 +50,3 @@ private:
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
// Local Variables:
|
|
||||||
// coding: iso-8859-1
|
|
||||||
// mode: C++
|
|
||||||
// c-file-offsets: ((c . 0))
|
|
||||||
// c-file-style: "Stroustrup"
|
|
||||||
// fill-column: 80
|
|
||||||
// End:
|
|
||||||
|
|
|
||||||
|
|
@ -61,7 +61,7 @@ public:
|
||||||
* Copy Constructor
|
* Copy Constructor
|
||||||
* @param _neighbor to copy
|
* @param _neighbor to copy
|
||||||
*/
|
*/
|
||||||
moNeighbor(const moNeighbor<EOType, Fitness>& _neighbor) {
|
moNeighbor(const moNeighbor<EOT, Fitness>& _neighbor) {
|
||||||
repFitness = _neighbor.fitness();
|
repFitness = _neighbor.fitness();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -131,7 +131,7 @@ public:
|
||||||
_os << repFitness << ' ' ;
|
_os << repFitness << ' ' ;
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
protected:
|
||||||
// minimal information on the neighbor : fitness
|
// minimal information on the neighbor : fitness
|
||||||
Fitness repFitness ;
|
Fitness repFitness ;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -8,9 +8,6 @@ typedef EO<int> Solution;
|
||||||
|
|
||||||
class moDummyNeighbor : public moNeighbor<Solution,int>{
|
class moDummyNeighbor : public moNeighbor<Solution,int>{
|
||||||
|
|
||||||
virtual void eval(Solution & solution){}
|
|
||||||
|
|
||||||
virtual void move(Solution & solution){}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -1,18 +1,10 @@
|
||||||
#include "moTestClass.h"
|
#include "moTestClass.h"
|
||||||
|
|
||||||
|
#include <cstdlib>
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
|
||||||
int main(){
|
int main(){
|
||||||
|
|
||||||
moDummyNeighbor n1, n3;
|
|
||||||
|
|
||||||
n1.fitness(12);
|
|
||||||
|
|
||||||
moDummyNeighbor n2(n1);
|
|
||||||
assert(n1.fitness() == n2.fitness());
|
|
||||||
|
|
||||||
n3=n1;
|
|
||||||
assert(n1.fitness() == n3.fitness());
|
|
||||||
|
|
||||||
return EXIT_SUCCESS;
|
return EXIT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@ INCLUDE_DIRECTORIES(${PARADISEO_EO_SRC_DIR}/src
|
||||||
LINK_DIRECTORIES(${PARADISEO_EO_BIN_DIR}/lib)
|
LINK_DIRECTORIES(${PARADISEO_EO_BIN_DIR}/lib)
|
||||||
|
|
||||||
ADD_EXECUTABLE(testSimpleHC testSimpleHC.cpp)
|
ADD_EXECUTABLE(testSimpleHC testSimpleHC.cpp)
|
||||||
ADD_EXECUTABLE(testWithMove testWithMove.cpp)
|
#ADD_EXECUTABLE(testWithMove testWithMove.cpp)
|
||||||
|
|
||||||
TARGET_LINK_LIBRARIES(testSimpleHC eoutils ga eo)
|
TARGET_LINK_LIBRARIES(testSimpleHC eoutils ga eo)
|
||||||
TARGET_LINK_LIBRARIES(testWithMove eoutils ga eo)
|
#TARGET_LINK_LIBRARIES(testWithMove eoutils ga eo)
|
||||||
|
|
@ -40,17 +40,20 @@ using namespace std;
|
||||||
// explore the neighborhood of a bit string in order
|
// explore the neighborhood of a bit string in order
|
||||||
#include <neighborhood/moBitNeighborhood.h>
|
#include <neighborhood/moBitNeighborhood.h>
|
||||||
|
|
||||||
#include <eval/moFullEvalBitNeighbor.h>
|
#include <eval/moFullEvalByModif.h>
|
||||||
|
|
||||||
|
|
||||||
#include <oneMaxBitNeighbor.h>
|
#include <oneMaxBitNeighbor.h>
|
||||||
|
|
||||||
|
#include <comparator/moNeighborComparator.h>
|
||||||
|
|
||||||
// REPRESENTATION
|
// REPRESENTATION
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// define your individuals
|
// define your individuals
|
||||||
typedef eoBit<unsigned> Indi;
|
typedef eoBit<unsigned> Indi;
|
||||||
//typedef OneMaxBitNeighbor<unsigned> Neighbor ; // incremental evaluation
|
//typedef OneMaxBitNeighbor<unsigned> Neighbor ; // incremental evaluation
|
||||||
typedef moFullEvalBitNeighbor<unsigned> Neighbor ; // full evaluation
|
//typedef moFullEvalBitNeighbor<unsigned> Neighbor ; // full evaluation
|
||||||
typedef moBitNeighborhood<Neighbor> Neighborhood ;
|
//typedef moBitNeighborhood<Neighbor> Neighborhood ;
|
||||||
|
|
||||||
// GENERAL
|
// GENERAL
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
|
@ -121,6 +124,8 @@ void main_function(int argc, char **argv)
|
||||||
|
|
||||||
FuncOneMax<Indi> eval(vecSize);
|
FuncOneMax<Indi> eval(vecSize);
|
||||||
|
|
||||||
|
moFullEvalByModif<moBitNeighbor<unsigned int> > fulleval(eval);
|
||||||
|
|
||||||
/* =========================================================
|
/* =========================================================
|
||||||
*
|
*
|
||||||
* Initilisation of the solution
|
* Initilisation of the solution
|
||||||
|
|
@ -138,7 +143,7 @@ void main_function(int argc, char **argv)
|
||||||
* ========================================================= */
|
* ========================================================= */
|
||||||
|
|
||||||
// no need if incremental evaluation with OneMaxBitNeighbor
|
// no need if incremental evaluation with OneMaxBitNeighbor
|
||||||
Neighbor::setFullEvalFunc(eval);
|
// Neighbor::setFullEvalFunc(eval);
|
||||||
|
|
||||||
/* =========================================================
|
/* =========================================================
|
||||||
*
|
*
|
||||||
|
|
@ -146,7 +151,9 @@ void main_function(int argc, char **argv)
|
||||||
*
|
*
|
||||||
* ========================================================= */
|
* ========================================================= */
|
||||||
|
|
||||||
Neighborhood neighborhood;
|
moNeighborComparator<moBitNeighbor<unsigned int> > comparator;
|
||||||
|
|
||||||
|
moBitNeighborhood<moBitNeighbor<unsigned int> > neighborhood ;
|
||||||
|
|
||||||
/* =========================================================
|
/* =========================================================
|
||||||
*
|
*
|
||||||
|
|
@ -154,7 +161,7 @@ void main_function(int argc, char **argv)
|
||||||
*
|
*
|
||||||
* ========================================================= */
|
* ========================================================= */
|
||||||
|
|
||||||
moSimpleHCexplorer<Neighborhood> explorer(neighborhood);
|
moSimpleHCexplorer<moBitNeighborhood<moBitNeighbor<unsigned int> > > explorer(neighborhood, fulleval, comparator);
|
||||||
|
|
||||||
/* =========================================================
|
/* =========================================================
|
||||||
*
|
*
|
||||||
|
|
@ -162,9 +169,9 @@ void main_function(int argc, char **argv)
|
||||||
*
|
*
|
||||||
* ========================================================= */
|
* ========================================================= */
|
||||||
|
|
||||||
moTrueContinuator<Neighborhood> continuator;
|
moTrueContinuator<moBitNeighborhood<moBitNeighbor<unsigned int> > > continuator;
|
||||||
|
|
||||||
moLocalSearch< moSimpleHCexplorer<Neighborhood>, moTrueContinuator<Neighborhood> > localSearch(explorer, continuator);
|
moLocalSearch< moSimpleHCexplorer<moBitNeighborhood<moBitNeighbor<unsigned int> > >, moTrueContinuator<moBitNeighborhood<moBitNeighbor<unsigned int> > > > localSearch(explorer, continuator);
|
||||||
|
|
||||||
/* =========================================================
|
/* =========================================================
|
||||||
*
|
*
|
||||||
|
|
@ -180,7 +187,7 @@ void main_function(int argc, char **argv)
|
||||||
|
|
||||||
std::cout << "initial: " << solution << std::endl ;
|
std::cout << "initial: " << solution << std::endl ;
|
||||||
|
|
||||||
localSearch(solution);
|
localSearch(solution);
|
||||||
|
|
||||||
std::cout << "final: " << solution << std::endl ;
|
std::cout << "final: " << solution << std::endl ;
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue