There are now 5 lessons: 1=minimize_function, 2=HC, 3=TS, 4=SA and 5=ILS
git-svn-id: svn://scm.gforge.inria.fr/svnroot/paradiseo@1055 331e1502-861f-0410-8da2-ba01fb791d7f
This commit is contained in:
parent
9100f88efa
commit
2d4038a552
33 changed files with 1175 additions and 500 deletions
|
|
@ -6,12 +6,15 @@
|
||||||
SET(TSP_SRC_DIR ${ParadisEO-MO_SOURCE_DIR}/tutorial/examples/tsp CACHE PATH "TSP src directory")
|
SET(TSP_SRC_DIR ${ParadisEO-MO_SOURCE_DIR}/tutorial/examples/tsp CACHE PATH "TSP src directory")
|
||||||
SET(TSP_BINARY_DIR ${ParadisEO-MO_BINARY_DIR}/tutorial/examples/tsp CACHE PATH "TSP binary directory")
|
SET(TSP_BINARY_DIR ${ParadisEO-MO_BINARY_DIR}/tutorial/examples/tsp CACHE PATH "TSP binary directory")
|
||||||
|
|
||||||
|
SET(FUNCTION_SRC_DIR ${ParadisEO-MO_SOURCE_DIR}/tutorial/examples/function CACHE PATH "FUNCTION src directory")
|
||||||
|
SET(FUNCTION_BINARY_DIR ${ParadisEO-MO_BINARY_DIR}/tutorial/examples/function CACHE PATH "FUNCTION binary directory")
|
||||||
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
### 2) Where must cmake go now ?
|
### 2) Where must cmake go now ?
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
SUBDIRS(examples Lesson1 Lesson2 Lesson3 Lesson4)
|
SUBDIRS(examples Lesson1 Lesson2 Lesson3 Lesson4 Lesson5)
|
||||||
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,3 @@
|
||||||
|
|
||||||
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
### 1) Include the sources
|
### 1) Include the sources
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
@ -7,7 +5,8 @@
|
||||||
INCLUDE_DIRECTORIES(${EO_SRC_DIR}/src)
|
INCLUDE_DIRECTORIES(${EO_SRC_DIR}/src)
|
||||||
INCLUDE_DIRECTORIES(${EO_SRC_DIR}/src/utils)
|
INCLUDE_DIRECTORIES(${EO_SRC_DIR}/src/utils)
|
||||||
INCLUDE_DIRECTORIES(${ParadisEO-MO_SOURCE_DIR}/src)
|
INCLUDE_DIRECTORIES(${ParadisEO-MO_SOURCE_DIR}/src)
|
||||||
INCLUDE_DIRECTORIES(${TSP_SRC_DIR})
|
INCLUDE_DIRECTORIES(${FUNCTION_SRC_DIR})
|
||||||
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
ADD_CUSTOM_TARGET(install DEPENDS ${ParadisEO-MO_SOURCE_DIR}/tutorial/Lesson1/param )
|
ADD_CUSTOM_TARGET(install DEPENDS ${ParadisEO-MO_SOURCE_DIR}/tutorial/Lesson1/param )
|
||||||
|
|
@ -25,7 +24,7 @@ ADD_CUSTOM_COMMAND(
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
IF(NOT WIN32 OR CYGWIN)
|
IF(NOT WIN32 OR CYGWIN)
|
||||||
LINK_DIRECTORIES(${EO_BIN_DIR}/lib ${TSP_BINARY_DIR}/lib)
|
LINK_DIRECTORIES(${EO_BIN_DIR}/lib ${FUNCTION_BINARY_DIR}/lib)
|
||||||
ENDIF(NOT WIN32 OR CYGWIN)
|
ENDIF(NOT WIN32 OR CYGWIN)
|
||||||
|
|
||||||
# especially for Visual Studio
|
# especially for Visual Studio
|
||||||
|
|
@ -41,9 +40,10 @@ ENDIF(WIN32 AND NOT CYGWIN)
|
||||||
### 3) Define your target(s): just an executable here
|
### 3) Define your target(s): just an executable here
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
ADD_EXECUTABLE(hill_climbing hill_climbing.cpp)
|
ADD_EXECUTABLE(minimize_function minimize_function.cpp)
|
||||||
|
|
||||||
|
ADD_DEPENDENCIES(minimize_function function)
|
||||||
|
|
||||||
ADD_DEPENDENCIES(hill_climbing tsp)
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -52,8 +52,8 @@ ADD_DEPENDENCIES(hill_climbing tsp)
|
||||||
### 4) Optionnal: define your target(s)'s version: no effect for windows
|
### 4) Optionnal: define your target(s)'s version: no effect for windows
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
SET(HILLCLIMBING_VERSION ${GLOBAL_VERSION})
|
SET(MINIMIZEFUNCTION_VERSION ${GLOBAL_VERSION})
|
||||||
SET_TARGET_PROPERTIES(hill_climbing PROPERTIES VERSION "${HILLCLIMBING_VERSION}")
|
SET_TARGET_PROPERTIES(minimize_function PROPERTIES VERSION "${MINIMIZEFUNCTION_VERSION}")
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -62,7 +62,6 @@ SET_TARGET_PROPERTIES(hill_climbing PROPERTIES VERSION "${HILLCLIMBING_VERSION}"
|
||||||
### 5) Link the librairies for your target(s)
|
### 5) Link the librairies for your target(s)
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
TARGET_LINK_LIBRARIES(hill_climbing tsp eo eoutils)
|
TARGET_LINK_LIBRARIES(minimize_function function eo eoutils)
|
||||||
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,139 +0,0 @@
|
||||||
/*
|
|
||||||
<hill_climbing.cpp>
|
|
||||||
Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
|
||||||
(C) OPAC Team, LIFL, 2002-2008
|
|
||||||
|
|
||||||
Sébastien Cahon, Jean-Charles Boisson
|
|
||||||
|
|
||||||
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
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <eo>
|
|
||||||
#include <mo>
|
|
||||||
#include <tsp>
|
|
||||||
|
|
||||||
void manage_configuration_file(eoParser & _parser);
|
|
||||||
|
|
||||||
int
|
|
||||||
main (int _argc, char* _argv [])
|
|
||||||
{
|
|
||||||
std::string instancePath, selectionType;
|
|
||||||
unsigned int seed;
|
|
||||||
|
|
||||||
eoParser parser(_argc, _argv);
|
|
||||||
|
|
||||||
manage_configuration_file(parser);
|
|
||||||
|
|
||||||
seed=atoi( (parser.getParamWithLongName("seed")->getValue()).c_str() );
|
|
||||||
instancePath=parser.getParamWithLongName("instancePath")->getValue();
|
|
||||||
selectionType=parser.getParamWithLongName("selectionType")->getValue();
|
|
||||||
|
|
||||||
srand (seed);
|
|
||||||
Graph::load(instancePath.c_str());
|
|
||||||
|
|
||||||
Route solution;
|
|
||||||
|
|
||||||
RouteInit initializer;
|
|
||||||
initializer (solution);
|
|
||||||
|
|
||||||
RouteEval full_evaluation;
|
|
||||||
full_evaluation (solution);
|
|
||||||
|
|
||||||
std :: cout << "[From] " << solution << std :: endl;
|
|
||||||
|
|
||||||
/* Tools for an efficient (? :-))
|
|
||||||
local search ! */
|
|
||||||
|
|
||||||
TwoOptInit two_opt_initializer;
|
|
||||||
|
|
||||||
TwoOptNext two_opt_next_move_generator;
|
|
||||||
|
|
||||||
TwoOptIncrEval two_opt_incremental_evaluation;
|
|
||||||
|
|
||||||
moMoveSelect<TwoOpt>* two_opt_selection;
|
|
||||||
|
|
||||||
if (selectionType.compare("Best")==0)
|
|
||||||
{
|
|
||||||
two_opt_selection= new moBestImprSelect<TwoOpt>();
|
|
||||||
}
|
|
||||||
else if (selectionType.compare("First")==0)
|
|
||||||
{
|
|
||||||
two_opt_selection= new moFirstImprSelect<TwoOpt>();
|
|
||||||
}
|
|
||||||
else if (selectionType.compare("Random")==0)
|
|
||||||
{
|
|
||||||
two_opt_selection= new moRandImprSelect<TwoOpt>();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw std::runtime_error("[hill_climbing.cpp]: the type of selection '"+selectionType+"' is not correct.");
|
|
||||||
}
|
|
||||||
|
|
||||||
moHC <TwoOpt> hill_climbing (two_opt_initializer, two_opt_next_move_generator, two_opt_incremental_evaluation,
|
|
||||||
*two_opt_selection, full_evaluation);
|
|
||||||
hill_climbing (solution) ;
|
|
||||||
|
|
||||||
std :: cout << "[To] " << solution << std :: endl;
|
|
||||||
|
|
||||||
delete(two_opt_selection);
|
|
||||||
|
|
||||||
return EXIT_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
manage_configuration_file(eoParser & _parser)
|
|
||||||
{
|
|
||||||
std::ofstream os;
|
|
||||||
|
|
||||||
#ifdef _MSVC
|
|
||||||
_parser.createParam(std::string("..\examples\tsp\benchs\berlin52.tsp"), "instancePath", "Path to the instance.",
|
|
||||||
0, "Configuration", false);
|
|
||||||
#else
|
|
||||||
_parser.createParam(std::string("../examples/tsp/benchs/berlin52.tsp"), "instancePath", "Path to the instance.",
|
|
||||||
0, "Configuration", false);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
_parser.createParam((unsigned int)time(0), "seed", "Seed for rand.", 0, "Configuration", false);
|
|
||||||
|
|
||||||
_parser.createParam(std::string("Best"), "selectionType", "Type of the selection: 'Best', 'First' or 'Random'.",
|
|
||||||
0, "Configuration", false);
|
|
||||||
|
|
||||||
if (_parser.userNeedsHelp())
|
|
||||||
{
|
|
||||||
_parser.printHelp(std::cout);
|
|
||||||
exit(EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
|
|
||||||
os.open("current_param");
|
|
||||||
if (!os.is_open())
|
|
||||||
{
|
|
||||||
throw std::runtime_error("[hill_climbing.cpp]: the file current_param cannot be created.");
|
|
||||||
}
|
|
||||||
os <<_parser;
|
|
||||||
os.close();
|
|
||||||
}
|
|
||||||
136
trunk/paradiseo-mo/tutorial/Lesson1/minimize_function.cpp
Normal file
136
trunk/paradiseo-mo/tutorial/Lesson1/minimize_function.cpp
Normal file
|
|
@ -0,0 +1,136 @@
|
||||||
|
/*
|
||||||
|
<minimize_function.cpp>
|
||||||
|
Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
(C) OPAC Team, LIFL, 2002-2008
|
||||||
|
|
||||||
|
Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
|
||||||
|
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
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <eo>
|
||||||
|
#include <mo>
|
||||||
|
#include <function>
|
||||||
|
|
||||||
|
void manage_configuration_file(eoParser & _parser);
|
||||||
|
|
||||||
|
int
|
||||||
|
main (int _argc, char* _argv [])
|
||||||
|
{
|
||||||
|
std::string selectionType;
|
||||||
|
double initialBound, searchBound, searchStep;
|
||||||
|
eoParser parser(_argc, _argv);
|
||||||
|
|
||||||
|
manage_configuration_file(parser);
|
||||||
|
|
||||||
|
initialBound=atof( (parser.getParamWithLongName("initialBound")->getValue()).c_str() );
|
||||||
|
searchBound=atof( (parser.getParamWithLongName("searchBound")->getValue()).c_str() );
|
||||||
|
searchStep=atof( (parser.getParamWithLongName("searchStep")->getValue()).c_str() );
|
||||||
|
selectionType=parser.getParamWithLongName("selectionType")->getValue();
|
||||||
|
|
||||||
|
Affectation solution;
|
||||||
|
|
||||||
|
AffectationInit initialize(initialBound);
|
||||||
|
initialize (solution);
|
||||||
|
|
||||||
|
AffectationEval evaluation;
|
||||||
|
evaluation (solution);
|
||||||
|
|
||||||
|
std::cout << "Initial affectation : " << std::endl;
|
||||||
|
std::cout << "\t x1 = " << solution.first << std::endl;
|
||||||
|
std::cout << "\t x2 = " << solution.second << std::endl;
|
||||||
|
std::cout << "\t f(x1,x2) = " << solution.fitness() << std::endl;
|
||||||
|
|
||||||
|
DeviationInit deviation_initializer(searchBound);
|
||||||
|
|
||||||
|
DeviationNext deviation_next_move_generator(searchBound, searchStep);
|
||||||
|
|
||||||
|
DeviationIncrEval deviation_incremental_evaluation;
|
||||||
|
|
||||||
|
moMoveSelect<Deviation>* deviation_selection;
|
||||||
|
|
||||||
|
if(selectionType.compare("Best")==0)
|
||||||
|
{
|
||||||
|
deviation_selection= new moBestImprSelect<Deviation>();
|
||||||
|
}
|
||||||
|
else if (selectionType.compare("First")==0)
|
||||||
|
{
|
||||||
|
deviation_selection= new moFirstImprSelect<Deviation>();
|
||||||
|
}
|
||||||
|
else if (selectionType.compare("Random")==0)
|
||||||
|
{
|
||||||
|
deviation_selection= new moRandImprSelect<Deviation>();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw std::runtime_error("[minimize_function.cpp]: the type of selection '"+selectionType+"' is not correct.");
|
||||||
|
}
|
||||||
|
|
||||||
|
moHC <Deviation> hill_climbing (deviation_initializer, deviation_next_move_generator, deviation_incremental_evaluation,
|
||||||
|
*deviation_selection, evaluation);
|
||||||
|
hill_climbing (solution) ;
|
||||||
|
|
||||||
|
std::cout << "Final affectation : " << std::endl;
|
||||||
|
std::cout << "\t x1 = " << solution.first << std::endl;
|
||||||
|
std::cout << "\t x2 = " << solution.second << std::endl;
|
||||||
|
std::cout << "\t f(x1,x2) = " << solution.fitness() << std::endl;
|
||||||
|
|
||||||
|
delete(deviation_selection);
|
||||||
|
|
||||||
|
return EXIT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
manage_configuration_file(eoParser & _parser)
|
||||||
|
{
|
||||||
|
std::ofstream os;
|
||||||
|
|
||||||
|
_parser.createParam((double)1, "initialBound", "Bound for the initial affectation.", 0, "Configuration", false);
|
||||||
|
|
||||||
|
_parser.createParam((double)1, "searchBound", "Bound for neighbourhood exploration.", 0, "Configuration", false);
|
||||||
|
|
||||||
|
_parser.createParam((double)0.5, "searchStep", "Step between two values during the neighbourhood exploration.",
|
||||||
|
0, "Configuration", false);
|
||||||
|
|
||||||
|
_parser.createParam(std::string("First"), "selectionType", "Type of the selection: 'Best', 'First' or 'Random'.",
|
||||||
|
0, "Configuration", false);
|
||||||
|
|
||||||
|
if (_parser.userNeedsHelp())
|
||||||
|
{
|
||||||
|
_parser.printHelp(std::cout);
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
|
||||||
|
os.open("current_param");
|
||||||
|
if(!os.is_open())
|
||||||
|
{
|
||||||
|
throw std::runtime_error("[minimize_function.cpp]: the file current_param cannot be created.");
|
||||||
|
}
|
||||||
|
os <<_parser;
|
||||||
|
os.close();
|
||||||
|
}
|
||||||
|
|
@ -4,6 +4,7 @@
|
||||||
# --stopOnUnknownParam=1 # Stop if unkown param entered
|
# --stopOnUnknownParam=1 # Stop if unkown param entered
|
||||||
|
|
||||||
###### Configuration ######
|
###### Configuration ######
|
||||||
# --instancePath=../examples/tsp/benchs/berlin52.tsp # Path to the instance.
|
# --initialBound=1 # Bound for the initial affectation.
|
||||||
# --seed=1203517190 # Seed for rand.
|
# --searchBound=1 # Bound for neighbourhood exploration.
|
||||||
# --selectionType=Best # Type of the selection: 'Best', 'First' or 'Random'.
|
# --searchStep=0.5 # Step between two values during the neighbourhood exploration.
|
||||||
|
# --selectionType=First # Type of the selection: 'Best', 'First' or 'Random'.
|
||||||
|
|
|
||||||
|
|
@ -41,9 +41,9 @@ ENDIF(WIN32 AND NOT CYGWIN)
|
||||||
### 3) Define your target(s): just an executable here
|
### 3) Define your target(s): just an executable here
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
ADD_EXECUTABLE(tabu_search tabu_search.cpp)
|
ADD_EXECUTABLE(hill_climbing hill_climbing.cpp)
|
||||||
|
|
||||||
ADD_DEPENDENCIES(tabu_search tsp)
|
ADD_DEPENDENCIES(hill_climbing tsp)
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -52,8 +52,8 @@ ADD_DEPENDENCIES(tabu_search tsp)
|
||||||
### 4) Optionnal: define your target(s)'s version: no effect for windows
|
### 4) Optionnal: define your target(s)'s version: no effect for windows
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
SET(TABUSEARCH_VERSION ${GLOBAL_VERSION})
|
SET(HILLCLIMBING_VERSION ${GLOBAL_VERSION})
|
||||||
SET_TARGET_PROPERTIES(tabu_search PROPERTIES VERSION "${TABUSEARCH_VERSION}")
|
SET_TARGET_PROPERTIES(hill_climbing PROPERTIES VERSION "${HILLCLIMBING_VERSION}")
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -62,7 +62,7 @@ SET_TARGET_PROPERTIES(tabu_search PROPERTIES VERSION "${TABUSEARCH_VERSION}")
|
||||||
### 5) Link the librairies for your target(s)
|
### 5) Link the librairies for your target(s)
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
TARGET_LINK_LIBRARIES(tabu_search tsp eo eoutils)
|
TARGET_LINK_LIBRARIES(hill_climbing tsp eo eoutils)
|
||||||
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -4,8 +4,6 @@
|
||||||
# --stopOnUnknownParam=1 # Stop if unkown param entered
|
# --stopOnUnknownParam=1 # Stop if unkown param entered
|
||||||
|
|
||||||
###### Configuration ######
|
###### Configuration ######
|
||||||
# --instancePath=../examples/tsp/benchs/berlin52.tsp # Path to the instance
|
# --instancePath=../examples/tsp/benchs/berlin52.tsp # Path to the instance.
|
||||||
# --seed=1202917905 # Seed for rand
|
# --seed=1203517190 # Seed for rand.
|
||||||
# --tabuListSize=10 # Size of the tabu list
|
# --selectionType=Best # Type of the selection: 'Best', 'First' or 'Random'.
|
||||||
# --maxIter=1000 # Maximum number of iterations
|
|
||||||
# --tabuListType=TwoOpt # Type of the tabu list: 'TwoOpt', 'SimpleMove' or 'SimpleSolution'
|
|
||||||
|
|
|
||||||
|
|
@ -1,150 +0,0 @@
|
||||||
/*
|
|
||||||
<tabu_search.cpp>
|
|
||||||
Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
|
||||||
(C) OPAC Team, LIFL, 2002-2008
|
|
||||||
|
|
||||||
Sébastien Cahon, Jean-Charles Boisson
|
|
||||||
|
|
||||||
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
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <eo>
|
|
||||||
#include <mo>
|
|
||||||
#include <tsp>
|
|
||||||
|
|
||||||
void manage_configuration_file(eoParser & _parser);
|
|
||||||
|
|
||||||
int
|
|
||||||
main (int _argc, char* _argv [])
|
|
||||||
{
|
|
||||||
std::string instancePath, value;
|
|
||||||
unsigned int seed, maxIterations, tabuListSize;
|
|
||||||
|
|
||||||
eoParser parser(_argc, _argv);
|
|
||||||
|
|
||||||
manage_configuration_file(parser);
|
|
||||||
|
|
||||||
seed=atoi( (parser.getParamWithLongName("seed")->getValue()).c_str() );
|
|
||||||
maxIterations=atoi( (parser.getParamWithLongName("maxIter")->getValue()).c_str() );
|
|
||||||
tabuListSize=atoi( (parser.getParamWithLongName("tabuListSize")->getValue()).c_str() );
|
|
||||||
instancePath=parser.getParamWithLongName("instancePath")->getValue();
|
|
||||||
value=parser.getParamWithLongName("tabuListType")->getValue();
|
|
||||||
|
|
||||||
srand (seed);
|
|
||||||
Graph::load(instancePath.c_str());
|
|
||||||
|
|
||||||
Route solution;
|
|
||||||
|
|
||||||
RouteInit initializer;
|
|
||||||
initializer(solution);
|
|
||||||
|
|
||||||
RouteEval full_evaluation;
|
|
||||||
full_evaluation(solution);
|
|
||||||
|
|
||||||
std :: cout << "[From] " << solution << std :: endl;
|
|
||||||
|
|
||||||
/* Tools for an efficient (? :-))
|
|
||||||
local search ! */
|
|
||||||
|
|
||||||
TwoOptInit two_opt_initializer;
|
|
||||||
|
|
||||||
TwoOptNext two_opt_next_move_generator;
|
|
||||||
|
|
||||||
TwoOptIncrEval two_opt_incremental_evaluation;
|
|
||||||
|
|
||||||
moTabuList<TwoOpt> *tabuList;
|
|
||||||
|
|
||||||
if (value.compare("TwoOpt")==0)
|
|
||||||
{
|
|
||||||
tabuList=new TwoOptTabuList();
|
|
||||||
}
|
|
||||||
else if (value.compare("SimpleMove")==0)
|
|
||||||
{
|
|
||||||
tabuList=new moSimpleMoveTabuList<TwoOpt>(tabuListSize);
|
|
||||||
}
|
|
||||||
else if (value.compare("SimpleSolution")==0)
|
|
||||||
{
|
|
||||||
tabuList=new moSimpleSolutionTabuList<TwoOpt>(tabuListSize);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw std::runtime_error("[tabu_search.cpp]: the type of tabu list '"+value+"' is not correct.");
|
|
||||||
}
|
|
||||||
|
|
||||||
moNoAspirCrit <TwoOpt> aspiration_criterion;
|
|
||||||
|
|
||||||
moGenSolContinue <Route> continu (maxIterations);
|
|
||||||
|
|
||||||
moTS <TwoOpt> tabu_search (two_opt_initializer, two_opt_next_move_generator,
|
|
||||||
two_opt_incremental_evaluation, *tabuList, aspiration_criterion, continu, full_evaluation);
|
|
||||||
tabu_search(solution);
|
|
||||||
|
|
||||||
std :: cout << "[To] " << solution << std :: endl;
|
|
||||||
|
|
||||||
delete(tabuList);
|
|
||||||
|
|
||||||
return EXIT_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
manage_configuration_file(eoParser & _parser)
|
|
||||||
{
|
|
||||||
std::ofstream os;
|
|
||||||
|
|
||||||
#ifdef _MSVC
|
|
||||||
_parser.createParam(std::string("..\examples\tsp\benchs\berlin52.tsp"), "instancePath", "Path to the instance.",
|
|
||||||
0, "Configuration", false);
|
|
||||||
#else
|
|
||||||
_parser.createParam(std::string("../examples/tsp/benchs/berlin52.tsp"), "instancePath", "Path to the instance.",
|
|
||||||
0, "Configuration", false);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
_parser.createParam((unsigned int)time(0), "seed", "Seed for rand.", 0, "Configuration", false);
|
|
||||||
|
|
||||||
_parser.createParam((unsigned int)10, "tabuListSize", "Size of the tabu list.", 0, "Configuration", false);
|
|
||||||
|
|
||||||
_parser.createParam((unsigned int)1000, "maxIter", "Maximum number of iterations.", 0, "Configuration", false);
|
|
||||||
|
|
||||||
_parser.createParam(std::string("TwoOpt"), "tabuListType", "Type of the tabu list: 'TwoOpt', 'SimpleMove' or 'SimpleSolution'.",
|
|
||||||
0, "Configuration", false);
|
|
||||||
|
|
||||||
if (_parser.userNeedsHelp())
|
|
||||||
{
|
|
||||||
_parser.printHelp(std::cout);
|
|
||||||
exit(EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
|
|
||||||
os.open("current_param");
|
|
||||||
if (!os.is_open())
|
|
||||||
{
|
|
||||||
throw std::runtime_error("[tabu_search.cpp]: the file current_param cannot be created.");
|
|
||||||
}
|
|
||||||
os <<_parser;
|
|
||||||
os.close();
|
|
||||||
}
|
|
||||||
|
|
@ -20,6 +20,7 @@ ADD_CUSTOM_TARGET(install DEPENDS ${ParadisEO-MO_SOURCE_DIR}/tutorial/Lesson3/pa
|
||||||
${ParadisEO-MO_SOURCE_DIR}/tutorial/Lesson3/param
|
${ParadisEO-MO_SOURCE_DIR}/tutorial/Lesson3/param
|
||||||
${ParadisEO-MO_BINARY_DIR}/tutorial/Lesson3)
|
${ParadisEO-MO_BINARY_DIR}/tutorial/Lesson3)
|
||||||
|
|
||||||
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
### 2) Specify where CMake can find the libraries
|
### 2) Specify where CMake can find the libraries
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
@ -41,9 +42,9 @@ ENDIF(WIN32 AND NOT CYGWIN)
|
||||||
### 3) Define your target(s): just an executable here
|
### 3) Define your target(s): just an executable here
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
ADD_EXECUTABLE(simulated_annealing simulated_annealing.cpp)
|
ADD_EXECUTABLE(tabu_search tabu_search.cpp)
|
||||||
|
|
||||||
ADD_DEPENDENCIES(simulated_annealing tsp)
|
ADD_DEPENDENCIES(tabu_search tsp)
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -52,8 +53,8 @@ ADD_DEPENDENCIES(simulated_annealing tsp)
|
||||||
### 4) Optionnal: define your target(s)'s version: no effect for windows
|
### 4) Optionnal: define your target(s)'s version: no effect for windows
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
SET(SIMULATEDANNEALING_VERSION ${GLOBAL_VERSION})
|
SET(TABUSEARCH_VERSION ${GLOBAL_VERSION})
|
||||||
SET_TARGET_PROPERTIES(simulated_annealing PROPERTIES VERSION "${SIMULATEDANNEALING_VERSION}")
|
SET_TARGET_PROPERTIES(tabu_search PROPERTIES VERSION "${TABUSEARCH_VERSION}")
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -62,7 +63,7 @@ SET_TARGET_PROPERTIES(simulated_annealing PROPERTIES VERSION "${SIMULATEDANNEALI
|
||||||
### 5) Link the librairies for your target(s)
|
### 5) Link the librairies for your target(s)
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
TARGET_LINK_LIBRARIES(simulated_annealing tsp eo eoutils)
|
TARGET_LINK_LIBRARIES(tabu_search tsp eo eoutils)
|
||||||
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -4,11 +4,8 @@
|
||||||
# --stopOnUnknownParam=1 # Stop if unkown param entered
|
# --stopOnUnknownParam=1 # Stop if unkown param entered
|
||||||
|
|
||||||
###### Configuration ######
|
###### Configuration ######
|
||||||
# --instancePath=../examples/tsp/benchs/berlin52.tsp # Path to the instance.
|
# --instancePath=../examples/tsp/benchs/berlin52.tsp # Path to the instance
|
||||||
# --seed=1202919978 # Seed for rand.
|
# --seed=1202917905 # Seed for rand
|
||||||
# --maxIter=1000 # Maximum number of iterations.
|
# --tabuListSize=10 # Size of the tabu list
|
||||||
# --initialTemp=1000 # Initial temperature.
|
# --maxIter=1000 # Maximum number of iterations
|
||||||
# --threshold=0.1 # Minimum temperature allowed.
|
# --tabuListType=TwoOpt # Type of the tabu list: 'TwoOpt', 'SimpleMove' or 'SimpleSolution'
|
||||||
# --expoRatio=0.98 # Ratio used if exponential cooling schedule is chosen.
|
|
||||||
# --lineaRatio=0.5 # Ratio used if linear cooling schedule is chosen.
|
|
||||||
# --coolSchedType=Expo # Type the cooling schedule: 'Expo' or 'Linear'.
|
|
||||||
|
|
|
||||||
|
|
@ -1,153 +0,0 @@
|
||||||
/*
|
|
||||||
<simulated_annealing.cpp>
|
|
||||||
Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
|
||||||
(C) OPAC Team, LIFL, 2002-2008
|
|
||||||
|
|
||||||
Sébastien Cahon, Jean-Charles Boisson
|
|
||||||
|
|
||||||
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
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <eo>
|
|
||||||
#include <mo>
|
|
||||||
#include <tsp>
|
|
||||||
|
|
||||||
void manage_configuration_file(eoParser & _parser);
|
|
||||||
|
|
||||||
int
|
|
||||||
main (int _argc, char* _argv [])
|
|
||||||
{
|
|
||||||
std::string instancePath, value;
|
|
||||||
unsigned int seed, maxIterations;
|
|
||||||
double threshold, exponentialRatio, linearRatio, initialTemperature;
|
|
||||||
|
|
||||||
eoParser parser(_argc, _argv);
|
|
||||||
|
|
||||||
manage_configuration_file(parser);
|
|
||||||
|
|
||||||
seed=atoi( (parser.getParamWithLongName("seed")->getValue()).c_str() );
|
|
||||||
instancePath=parser.getParamWithLongName("instancePath")->getValue();
|
|
||||||
maxIterations=atoi( (parser.getParamWithLongName("maxIter")->getValue()).c_str() );
|
|
||||||
initialTemperature=atof( (parser.getParamWithLongName("initialTemp")->getValue()).c_str() );
|
|
||||||
threshold=atof( (parser.getParamWithLongName("threshold")->getValue()).c_str() );
|
|
||||||
exponentialRatio=atof( (parser.getParamWithLongName("expoRatio")->getValue()).c_str() );
|
|
||||||
linearRatio=atof( (parser.getParamWithLongName("lineaRatio")->getValue()).c_str() );
|
|
||||||
value=parser.getParamWithLongName("coolSchedType")->getValue();
|
|
||||||
|
|
||||||
srand (seed);
|
|
||||||
Graph::load(instancePath.c_str());
|
|
||||||
|
|
||||||
Route solution;
|
|
||||||
|
|
||||||
RouteInit initializer;
|
|
||||||
initializer (solution);
|
|
||||||
|
|
||||||
RouteEval full_evaluation;
|
|
||||||
full_evaluation (solution);
|
|
||||||
|
|
||||||
std :: cout << "[From] " << solution << std :: endl;
|
|
||||||
|
|
||||||
/* Tools for an efficient (? :-))
|
|
||||||
local search ! */
|
|
||||||
|
|
||||||
TwoOptRand two_opt_random_move_generator;
|
|
||||||
|
|
||||||
TwoOptIncrEval two_opt_incremental_evaluation;
|
|
||||||
|
|
||||||
TwoOpt move;
|
|
||||||
|
|
||||||
moCoolingSchedule* coolingSchedule;
|
|
||||||
|
|
||||||
if(value.compare("Expo")==0)
|
|
||||||
{
|
|
||||||
coolingSchedule=new moExponentialCoolingSchedule(threshold, exponentialRatio);
|
|
||||||
}
|
|
||||||
else if (value.compare("Linear")==0)
|
|
||||||
{
|
|
||||||
coolingSchedule=new moLinearCoolingSchedule(threshold, linearRatio);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw std::runtime_error("[simulated_annealing.cpp]: the type of cooling schedule '"+value+"' is not correct.");
|
|
||||||
}
|
|
||||||
|
|
||||||
moGenSolContinue <Route> continu (maxIterations);
|
|
||||||
|
|
||||||
moSA <TwoOpt> simulated_annealing (two_opt_random_move_generator, two_opt_incremental_evaluation,
|
|
||||||
continu, initialTemperature, *coolingSchedule, full_evaluation);
|
|
||||||
simulated_annealing (solution);
|
|
||||||
|
|
||||||
std :: cout << "[To] " << solution << std :: endl;
|
|
||||||
|
|
||||||
delete(coolingSchedule);
|
|
||||||
|
|
||||||
return EXIT_SUCCESS ;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
manage_configuration_file(eoParser & _parser)
|
|
||||||
{
|
|
||||||
std::ofstream os;
|
|
||||||
|
|
||||||
#ifdef _MSVC
|
|
||||||
_parser.createParam(std::string("..\examples\tsp\benchs\berlin52.tsp"), "instancePath", "Path to the instance.",
|
|
||||||
0, "Configuration", false);
|
|
||||||
#else
|
|
||||||
_parser.createParam(std::string("../examples/tsp/benchs/berlin52.tsp"), "instancePath", "Path to the instance.",
|
|
||||||
0, "Configuration", false);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
_parser.getORcreateParam((unsigned int)time(0), "seed", "Seed for rand.", 0, "Configuration", false);
|
|
||||||
|
|
||||||
_parser.getORcreateParam((unsigned int)1000, "maxIter", "Maximum number of iterations.", 0, "Configuration", false);
|
|
||||||
|
|
||||||
_parser.getORcreateParam((double)1000, "initialTemp", "Initial temperature.", 0, "Configuration", false);
|
|
||||||
|
|
||||||
_parser.getORcreateParam((double)0.1, "threshold", "Minimum temperature allowed.", 0, "Configuration", false);
|
|
||||||
|
|
||||||
_parser.getORcreateParam((double)0.98, "expoRatio", "Ratio used if exponential cooling schedule is chosen.", 0, "Configuration", false);
|
|
||||||
|
|
||||||
_parser.getORcreateParam((double)0.5, "lineaRatio", "Ratio used if linear cooling schedule is chosen.", 0, "Configuration", false);
|
|
||||||
|
|
||||||
_parser.getORcreateParam(std::string("Expo"), "coolSchedType", "Type the cooling schedule: 'Expo' or 'Linear'.",
|
|
||||||
0, "Configuration", false);
|
|
||||||
|
|
||||||
if (_parser.userNeedsHelp())
|
|
||||||
{
|
|
||||||
_parser.printHelp(std::cout);
|
|
||||||
exit(EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
|
|
||||||
os.open("current_param");
|
|
||||||
if(!os.is_open())
|
|
||||||
{
|
|
||||||
throw std::runtime_error("[simulated_annealing.cpp]: the file current_param cannot be created.");
|
|
||||||
}
|
|
||||||
os <<_parser;
|
|
||||||
os.close();
|
|
||||||
}
|
|
||||||
|
|
@ -20,6 +20,7 @@ ADD_CUSTOM_TARGET(install DEPENDS ${ParadisEO-MO_SOURCE_DIR}/tutorial/Lesson4/pa
|
||||||
${ParadisEO-MO_SOURCE_DIR}/tutorial/Lesson4/param
|
${ParadisEO-MO_SOURCE_DIR}/tutorial/Lesson4/param
|
||||||
${ParadisEO-MO_BINARY_DIR}/tutorial/Lesson4)
|
${ParadisEO-MO_BINARY_DIR}/tutorial/Lesson4)
|
||||||
|
|
||||||
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
### 2) Specify where CMake can find the libraries
|
### 2) Specify where CMake can find the libraries
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
@ -41,10 +42,9 @@ ENDIF(WIN32 AND NOT CYGWIN)
|
||||||
### 3) Define your target(s): just an executable here
|
### 3) Define your target(s): just an executable here
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
ADD_EXECUTABLE(iterated_local_search iterated_local_search.cpp)
|
ADD_EXECUTABLE(simulated_annealing simulated_annealing.cpp)
|
||||||
|
|
||||||
ADD_DEPENDENCIES(iterated_local_search tsp)
|
|
||||||
|
|
||||||
|
ADD_DEPENDENCIES(simulated_annealing tsp)
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -53,8 +53,8 @@ ADD_DEPENDENCIES(iterated_local_search tsp)
|
||||||
### 4) Optionnal: define your target(s)'s version: no effect for windows
|
### 4) Optionnal: define your target(s)'s version: no effect for windows
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
SET(ITERATEDLOCALSEARCH_VERSION ${GLOBAL_VERSION})
|
SET(SIMULATEDANNEALING_VERSION ${GLOBAL_VERSION})
|
||||||
SET_TARGET_PROPERTIES(iterated_local_search PROPERTIES VERSION "${ITERATEDLOCALSEARCH_VERSION}")
|
SET_TARGET_PROPERTIES(simulated_annealing PROPERTIES VERSION "${SIMULATEDANNEALING_VERSION}")
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -63,6 +63,7 @@ SET_TARGET_PROPERTIES(iterated_local_search PROPERTIES VERSION "${ITERATEDLOCALS
|
||||||
### 5) Link the librairies for your target(s)
|
### 5) Link the librairies for your target(s)
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
TARGET_LINK_LIBRARIES(iterated_local_search tsp eo eoutils)
|
TARGET_LINK_LIBRARIES(simulated_annealing tsp eo eoutils)
|
||||||
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -5,5 +5,10 @@
|
||||||
|
|
||||||
###### Configuration ######
|
###### Configuration ######
|
||||||
# --instancePath=../examples/tsp/benchs/berlin52.tsp # Path to the instance.
|
# --instancePath=../examples/tsp/benchs/berlin52.tsp # Path to the instance.
|
||||||
# --seed=1203080388 # Seed for rand.
|
# --seed=1202919978 # Seed for rand.
|
||||||
# --maxIter=1000 # Maximum number of iterations.
|
# --maxIter=1000 # Maximum number of iterations.
|
||||||
|
# --initialTemp=1000 # Initial temperature.
|
||||||
|
# --threshold=0.1 # Minimum temperature allowed.
|
||||||
|
# --expoRatio=0.98 # Ratio used if exponential cooling schedule is chosen.
|
||||||
|
# --lineaRatio=0.5 # Ratio used if linear cooling schedule is chosen.
|
||||||
|
# --coolSchedType=Expo # Type the cooling schedule: 'Expo' or 'Linear'.
|
||||||
|
|
|
||||||
68
trunk/paradiseo-mo/tutorial/Lesson5/CMakeLists.txt
Normal file
68
trunk/paradiseo-mo/tutorial/Lesson5/CMakeLists.txt
Normal file
|
|
@ -0,0 +1,68 @@
|
||||||
|
|
||||||
|
|
||||||
|
######################################################################################
|
||||||
|
### 1) Include the sources
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
INCLUDE_DIRECTORIES(${EO_SRC_DIR}/src)
|
||||||
|
INCLUDE_DIRECTORIES(${EO_SRC_DIR}/src/utils)
|
||||||
|
INCLUDE_DIRECTORIES(${ParadisEO-MO_SOURCE_DIR}/src)
|
||||||
|
INCLUDE_DIRECTORIES(${TSP_SRC_DIR})
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
ADD_CUSTOM_TARGET(install DEPENDS ${ParadisEO-MO_SOURCE_DIR}/tutorial/Lesson5/param )
|
||||||
|
|
||||||
|
ADD_CUSTOM_COMMAND(
|
||||||
|
TARGET install
|
||||||
|
POST_BUILD
|
||||||
|
COMMAND ${CMAKE_COMMAND}
|
||||||
|
ARGS -E copy_if_different
|
||||||
|
${ParadisEO-MO_SOURCE_DIR}/tutorial/Lesson5/param
|
||||||
|
${ParadisEO-MO_BINARY_DIR}/tutorial/Lesson5)
|
||||||
|
|
||||||
|
######################################################################################
|
||||||
|
### 2) Specify where CMake can find the libraries
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
IF(NOT WIN32 OR CYGWIN)
|
||||||
|
LINK_DIRECTORIES(${EO_BIN_DIR}/lib ${TSP_BINARY_DIR}/lib)
|
||||||
|
ENDIF(NOT WIN32 OR CYGWIN)
|
||||||
|
|
||||||
|
# especially for Visual Studio
|
||||||
|
IF(WIN32 AND NOT CYGWIN)
|
||||||
|
LINK_DIRECTORIES(${EO_BIN_DIR}\\lib\\${CMAKE_BUILD_TYPE})
|
||||||
|
ENDIF(WIN32 AND NOT CYGWIN)
|
||||||
|
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
######################################################################################
|
||||||
|
### 3) Define your target(s): just an executable here
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
ADD_EXECUTABLE(iterated_local_search iterated_local_search.cpp)
|
||||||
|
|
||||||
|
ADD_DEPENDENCIES(iterated_local_search tsp)
|
||||||
|
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
######################################################################################
|
||||||
|
### 4) Optionnal: define your target(s)'s version: no effect for windows
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
SET(ITERATEDLOCALSEARCH_VERSION ${GLOBAL_VERSION})
|
||||||
|
SET_TARGET_PROPERTIES(iterated_local_search PROPERTIES VERSION "${ITERATEDLOCALSEARCH_VERSION}")
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
######################################################################################
|
||||||
|
### 5) Link the librairies for your target(s)
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
TARGET_LINK_LIBRARIES(iterated_local_search tsp eo eoutils)
|
||||||
|
|
||||||
|
######################################################################################
|
||||||
|
|
@ -95,8 +95,18 @@ manage_configuration_file(eoParser & _parser)
|
||||||
std::ofstream os;
|
std::ofstream os;
|
||||||
|
|
||||||
#ifdef _MSVC
|
#ifdef _MSVC
|
||||||
|
os.open("..\examples\tsp\benchs\berlin52.tsp");
|
||||||
|
if(os.is_open())
|
||||||
|
{
|
||||||
_parser.createParam(std::string("..\examples\tsp\benchs\berlin52.tsp"), "instancePath", "Path to the instance.",
|
_parser.createParam(std::string("..\examples\tsp\benchs\berlin52.tsp"), "instancePath", "Path to the instance.",
|
||||||
0, "Configuration", false);
|
0, "Configuration", false);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_parser.createParam(std::string("..\..\examples\tsp\benchs\berlin52.tsp"), "instancePath", "Path to the instance.",
|
||||||
|
0, "Configuration", false);
|
||||||
|
}
|
||||||
|
os.close();
|
||||||
#else
|
#else
|
||||||
_parser.createParam(std::string("../examples/tsp/benchs/berlin52.tsp"), "instancePath", "Path to the instance.",
|
_parser.createParam(std::string("../examples/tsp/benchs/berlin52.tsp"), "instancePath", "Path to the instance.",
|
||||||
0, "Configuration", false);
|
0, "Configuration", false);
|
||||||
9
trunk/paradiseo-mo/tutorial/Lesson5/param
Normal file
9
trunk/paradiseo-mo/tutorial/Lesson5/param
Normal file
|
|
@ -0,0 +1,9 @@
|
||||||
|
|
||||||
|
###### General ######
|
||||||
|
# --help=0 # -h : Prints this message
|
||||||
|
# --stopOnUnknownParam=1 # Stop if unkown param entered
|
||||||
|
|
||||||
|
###### Configuration ######
|
||||||
|
# --instancePath=../examples/tsp/benchs/berlin52.tsp # Path to the instance.
|
||||||
|
# --seed=1203080388 # Seed for rand.
|
||||||
|
# --maxIter=1000 # Maximum number of iterations.
|
||||||
|
|
@ -4,7 +4,7 @@
|
||||||
### 1) Where must cmake go now ?
|
### 1) Where must cmake go now ?
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
SUBDIRS(tsp)
|
SUBDIRS(tsp function)
|
||||||
|
|
||||||
######################################################################################
|
######################################################################################
|
||||||
|
|
||||||
|
|
|
||||||
36
trunk/paradiseo-mo/tutorial/examples/function/CMakeLists.txt
Normal file
36
trunk/paradiseo-mo/tutorial/examples/function/CMakeLists.txt
Normal file
|
|
@ -0,0 +1,36 @@
|
||||||
|
######################################################################################
|
||||||
|
### 0) Include the sources
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
INCLUDE_DIRECTORIES(${EO_SRC_DIR}/src)
|
||||||
|
INCLUDE_DIRECTORIES(${ParadisEO-MO_SOURCE_DIR}/src)
|
||||||
|
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
######################################################################################
|
||||||
|
### 1) Define your target(s): just the tsp here
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
SET(FUNCTION_LIB_OUTPUT_PATH ${FUNCTION_BINARY_DIR}/lib)
|
||||||
|
SET(LIBRARY_OUTPUT_PATH ${FUNCTION_LIB_OUTPUT_PATH})
|
||||||
|
|
||||||
|
SET (FUNCTION_SOURCES affectation_eval.cpp
|
||||||
|
affectation_init.cpp
|
||||||
|
deviation.cpp
|
||||||
|
deviation_init.cpp
|
||||||
|
deviation_next.cpp
|
||||||
|
deviation_incr_eval.cpp )
|
||||||
|
|
||||||
|
ADD_LIBRARY(function STATIC ${FUNCTION_SOURCES})
|
||||||
|
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
|
||||||
|
######################################################################################
|
||||||
|
### 2) Optionnal: define your target(s)'s version: no effect for windows
|
||||||
|
######################################################################################
|
||||||
|
|
||||||
|
SET(FUNCTION_VERSION "${GLOBAL_VERSION}")
|
||||||
|
SET_TARGET_PROPERTIES(function PROPERTIES VERSION "${FUNCTION_VERSION}")
|
||||||
|
######################################################################################
|
||||||
49
trunk/paradiseo-mo/tutorial/examples/function/affectation.h
Normal file
49
trunk/paradiseo-mo/tutorial/examples/function/affectation.h
Normal file
|
|
@ -0,0 +1,49 @@
|
||||||
|
/*
|
||||||
|
* <affectation.h>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2007
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2007
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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 affectation_h
|
||||||
|
#define affectation_h
|
||||||
|
|
||||||
|
#include <eoScalarFitness.h>
|
||||||
|
#include <EO.h>
|
||||||
|
|
||||||
|
// A float that has to be minimized.
|
||||||
|
typedef eoScalarFitness< float, std::greater<double> > functionFitness ;
|
||||||
|
|
||||||
|
class Affectation : public EO<functionFitness>, public std::pair<double, double>
|
||||||
|
{};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -0,0 +1,53 @@
|
||||||
|
/*
|
||||||
|
* <affectationEval.cpp>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "affectation_eval.h"
|
||||||
|
|
||||||
|
void AffectationEval :: operator () (Affectation & _affectation)
|
||||||
|
{
|
||||||
|
double x1, x2, result;
|
||||||
|
|
||||||
|
//std::cout << "AffectationEval" << std::endl;
|
||||||
|
|
||||||
|
x1=_affectation.first;
|
||||||
|
x2=_affectation.second;
|
||||||
|
|
||||||
|
result=(2*x1*x1) + (x2*x2) + (x1*x2) - (2*x1) - x2;
|
||||||
|
|
||||||
|
//std::cout << result << std::endl;
|
||||||
|
|
||||||
|
_affectation.fitness(result);
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,54 @@
|
||||||
|
/*
|
||||||
|
* <affectationEval.h>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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 affectation_eval_h
|
||||||
|
#define affectation_eval_h
|
||||||
|
|
||||||
|
#include <eoEvalFunc.h>
|
||||||
|
|
||||||
|
#include "affectation.h"
|
||||||
|
|
||||||
|
//! Affectation Evaluator
|
||||||
|
class AffectationEval : public eoEvalFunc <Affectation>
|
||||||
|
{
|
||||||
|
|
||||||
|
public :
|
||||||
|
|
||||||
|
void operator () (Affectation & _affectation) ;
|
||||||
|
|
||||||
|
} ;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -0,0 +1,74 @@
|
||||||
|
/*
|
||||||
|
* <affectation_init.cpp>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <utils/eoRNG.h>
|
||||||
|
|
||||||
|
#include "affectation_init.h"
|
||||||
|
|
||||||
|
AffectationInit::AffectationInit(double _bound): bound(_bound)
|
||||||
|
{
|
||||||
|
if(bound < 0.0)
|
||||||
|
{
|
||||||
|
std::cout << "[affectation_init.cpp][AffectationInit]: bound is negative, " << bound << " is tranformed to ";
|
||||||
|
bound = -bound;
|
||||||
|
std::cout << bound << "." << std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void AffectationInit::operator()(Affectation & _affectation)
|
||||||
|
{
|
||||||
|
eoBooleanGenerator booleanGenerator;
|
||||||
|
|
||||||
|
eoUniformGenerator<double> doubleGenerator(bound);
|
||||||
|
|
||||||
|
//A value between 0.0 and bound.
|
||||||
|
_affectation.first = doubleGenerator();
|
||||||
|
|
||||||
|
//value or -value ?
|
||||||
|
if(booleanGenerator())
|
||||||
|
{
|
||||||
|
_affectation.first= - _affectation.first;
|
||||||
|
}
|
||||||
|
|
||||||
|
//A value between 0.0 and bound.
|
||||||
|
_affectation.second = doubleGenerator();
|
||||||
|
|
||||||
|
//value or -value ?
|
||||||
|
if(booleanGenerator())
|
||||||
|
{
|
||||||
|
_affectation.second= - _affectation.second;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,58 @@
|
||||||
|
/*
|
||||||
|
* <affectation_init.h>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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 affectation_init_h
|
||||||
|
#define affectation_init_h
|
||||||
|
|
||||||
|
#include <eoInit.h>
|
||||||
|
|
||||||
|
#include "affectation.h"
|
||||||
|
|
||||||
|
class AffectationInit : public eoInit <Affectation>
|
||||||
|
{
|
||||||
|
|
||||||
|
public :
|
||||||
|
|
||||||
|
AffectationInit(double _bound);
|
||||||
|
|
||||||
|
void operator () (Affectation & _affectation) ;
|
||||||
|
|
||||||
|
//! A bound for the initial value for the deviations
|
||||||
|
double bound;
|
||||||
|
|
||||||
|
} ;
|
||||||
|
|
||||||
|
#endif
|
||||||
44
trunk/paradiseo-mo/tutorial/examples/function/deviation.cpp
Normal file
44
trunk/paradiseo-mo/tutorial/examples/function/deviation.cpp
Normal file
|
|
@ -0,0 +1,44 @@
|
||||||
|
/*
|
||||||
|
* <deviation.cpp>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "deviation.h"
|
||||||
|
|
||||||
|
void Deviation::operator () (Affectation & _affectation)
|
||||||
|
{
|
||||||
|
_affectation.first += first;
|
||||||
|
_affectation.second += second;
|
||||||
|
}
|
||||||
|
|
||||||
50
trunk/paradiseo-mo/tutorial/examples/function/deviation.h
Normal file
50
trunk/paradiseo-mo/tutorial/examples/function/deviation.h
Normal file
|
|
@ -0,0 +1,50 @@
|
||||||
|
/*
|
||||||
|
* <deviation.h>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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 deviation_h
|
||||||
|
#define deviation_h
|
||||||
|
|
||||||
|
#include <moMove.h>
|
||||||
|
#include "affectation.h"
|
||||||
|
|
||||||
|
class Deviation : public moMove <Affectation>, public std :: pair <double, double>
|
||||||
|
{
|
||||||
|
public :
|
||||||
|
|
||||||
|
void operator () (Affectation & _affectation) ;
|
||||||
|
} ;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -0,0 +1,57 @@
|
||||||
|
/*
|
||||||
|
* <deviation_incr_eval.cpp>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "deviation_incr_eval.h"
|
||||||
|
|
||||||
|
functionFitness DeviationIncrEval :: operator () (const Deviation & _move, const Affectation & _affectation)
|
||||||
|
{
|
||||||
|
double x1, x2, deltaX1, deltaX2;
|
||||||
|
|
||||||
|
x1=_affectation.first;
|
||||||
|
x2=_affectation.second;
|
||||||
|
|
||||||
|
deltaX1=_move.first;
|
||||||
|
deltaX2=_move.second;
|
||||||
|
|
||||||
|
/*std::cout << (_affectation.fitness()
|
||||||
|
+ ( 2*deltaX1*deltaX1 ) + ( deltaX2*deltaX2 ) + ( deltaX1*deltaX2 ) - ( 2*deltaX1 ) - deltaX2
|
||||||
|
+ ( deltaX1 * ( (4*x1) + x2 ) ) + ( x2*deltaX1 )) << std::endl;*/
|
||||||
|
|
||||||
|
return _affectation.fitness()
|
||||||
|
+ ( 2*deltaX1*deltaX1 ) + ( deltaX2*deltaX2 ) + ( deltaX1*deltaX2 ) - ( 2*deltaX1 ) - deltaX2
|
||||||
|
+ ( deltaX1 * ( (4*x1) + x2 ) ) + ( x2*deltaX1 );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -0,0 +1,51 @@
|
||||||
|
/*
|
||||||
|
* <deviation_incr_eval.h>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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 deviation_incr_eval_h
|
||||||
|
#define deviation_incr_eval_h
|
||||||
|
|
||||||
|
#include <moMoveIncrEval.h>
|
||||||
|
#include "deviation.h"
|
||||||
|
|
||||||
|
class DeviationIncrEval : public moMoveIncrEval <Deviation>
|
||||||
|
{
|
||||||
|
public :
|
||||||
|
|
||||||
|
functionFitness operator () (const Deviation & _move, const Affectation & _route) ;
|
||||||
|
|
||||||
|
} ;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -0,0 +1,56 @@
|
||||||
|
/*
|
||||||
|
* <deviation_init.cpp>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "deviation_init.h"
|
||||||
|
|
||||||
|
DeviationInit::DeviationInit(double _bound): bound(_bound)
|
||||||
|
{
|
||||||
|
if(bound < 0.0)
|
||||||
|
{
|
||||||
|
std::cout << "[deviation_init.cpp][DeviationInit]: bound is negative, " << bound << " is tranformed to ";
|
||||||
|
bound = -bound;
|
||||||
|
std::cout << bound << "." << std::endl;;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void DeviationInit::operator () (Deviation & _move, const Affectation & _affectation)
|
||||||
|
{
|
||||||
|
//Code only used to avoid compilation warning because _affectation is not used in this procedure.
|
||||||
|
Affectation affectation(_affectation);
|
||||||
|
|
||||||
|
_move.first=-bound;
|
||||||
|
_move.second=-bound;
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,61 @@
|
||||||
|
/*
|
||||||
|
* <deviation_init.h>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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 deviation_init_h
|
||||||
|
#define deviation_init_h
|
||||||
|
|
||||||
|
#include <moMoveInit.h>
|
||||||
|
#include <utils/eoRndGenerators.h>
|
||||||
|
|
||||||
|
#include "deviation.h"
|
||||||
|
|
||||||
|
/** It sets the first couple of edges */
|
||||||
|
class DeviationInit : public moMoveInit <Deviation>
|
||||||
|
{
|
||||||
|
|
||||||
|
public :
|
||||||
|
|
||||||
|
DeviationInit(double _bound);
|
||||||
|
|
||||||
|
void operator () (Deviation & _move, const Affectation & _affectation) ;
|
||||||
|
|
||||||
|
private :
|
||||||
|
|
||||||
|
//! A bound for the initial value for the deviations
|
||||||
|
double bound;
|
||||||
|
} ;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -0,0 +1,95 @@
|
||||||
|
/*
|
||||||
|
* <deviation_next.cpp>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "deviation_next.h"
|
||||||
|
|
||||||
|
DeviationNext::DeviationNext(double _bound, double _step): bound(_bound), step(_step)
|
||||||
|
{
|
||||||
|
if(bound<0.0)
|
||||||
|
{
|
||||||
|
std::cout << "[affectation_next.cpp][DeviationNext]: bound is negative, " << bound << " is tranformed to ";
|
||||||
|
bound=-bound;
|
||||||
|
std::cout << bound << "." << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(step<0.0)
|
||||||
|
{
|
||||||
|
std::cout << "[affectation_next.cpp][DeviationNext]: step is negative, " << step << " is tranformed to ";
|
||||||
|
step=-step;
|
||||||
|
std::cout << step << "." << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(step>bound)
|
||||||
|
{
|
||||||
|
std::cout << "[affectation_next.cpp][DeviationNext]: step is higher than bound, " << step << " is tranformed to ";
|
||||||
|
step = bound / 2;
|
||||||
|
std::cout << step << "." << std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool DeviationNext::operator () (Deviation & _move, const Affectation & _affectation)
|
||||||
|
{
|
||||||
|
Affectation affectation(_affectation);
|
||||||
|
|
||||||
|
double deltaX1, deltaX2;
|
||||||
|
|
||||||
|
deltaX1=_move.first;
|
||||||
|
deltaX2=_move.second;
|
||||||
|
|
||||||
|
//std::cout << "deltaX1 = " << deltaX1 << ", deltaX2 = " << deltaX2 << std::endl;
|
||||||
|
|
||||||
|
if( (deltaX1>=bound) && (deltaX2)>=bound )
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(deltaX2 >= bound)
|
||||||
|
{
|
||||||
|
deltaX1+=step;
|
||||||
|
deltaX2=-bound;
|
||||||
|
|
||||||
|
_move.first=deltaX1;
|
||||||
|
_move.second=deltaX2;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
deltaX2+=step;
|
||||||
|
|
||||||
|
_move.second=deltaX2;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,62 @@
|
||||||
|
/*
|
||||||
|
* <deviation_next.h>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson
|
||||||
|
*
|
||||||
|
* 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 deviation_next_h
|
||||||
|
#define deviation_next_h
|
||||||
|
|
||||||
|
#include <moNextMove.h>
|
||||||
|
#include "deviation.h"
|
||||||
|
|
||||||
|
class DeviationNext : public moNextMove <Deviation>
|
||||||
|
{
|
||||||
|
|
||||||
|
public :
|
||||||
|
|
||||||
|
DeviationNext (double _bound, double _step);
|
||||||
|
|
||||||
|
bool operator () (Deviation & _move, const Affectation & _affectation) ;
|
||||||
|
|
||||||
|
|
||||||
|
private :
|
||||||
|
|
||||||
|
//! A bound for the search in the neighbourhood.
|
||||||
|
double bound;
|
||||||
|
|
||||||
|
//! A step between two values.
|
||||||
|
double step;
|
||||||
|
} ;
|
||||||
|
|
||||||
|
#endif
|
||||||
41
trunk/paradiseo-mo/tutorial/examples/function/function
Normal file
41
trunk/paradiseo-mo/tutorial/examples/function/function
Normal file
|
|
@ -0,0 +1,41 @@
|
||||||
|
/*
|
||||||
|
* <function>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2008
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson (Jean-Charles.Boisson@lifl.fr)
|
||||||
|
*
|
||||||
|
* 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 __function
|
||||||
|
#define __function
|
||||||
|
|
||||||
|
#include "function.h"
|
||||||
|
|
||||||
|
#endif
|
||||||
48
trunk/paradiseo-mo/tutorial/examples/function/function.h
Normal file
48
trunk/paradiseo-mo/tutorial/examples/function/function.h
Normal file
|
|
@ -0,0 +1,48 @@
|
||||||
|
/*
|
||||||
|
* <tsp.h>
|
||||||
|
* Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2007
|
||||||
|
* (C) OPAC Team, LIFL, 2002-2007
|
||||||
|
*
|
||||||
|
* Sébastien Cahon, Jean-Charles Boisson (Jean-Charles.Boisson@lifl.fr)
|
||||||
|
*
|
||||||
|
* 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 __function_h
|
||||||
|
#define __function_h
|
||||||
|
|
||||||
|
#include "affectation.h"
|
||||||
|
#include "affectation_eval.h"
|
||||||
|
#include "affectation_init.h"
|
||||||
|
#include "deviation.h"
|
||||||
|
#include "deviation_incr_eval.h"
|
||||||
|
#include "deviation_init.h"
|
||||||
|
#include "deviation_next.h"
|
||||||
|
|
||||||
|
#endif
|
||||||
Loading…
Add table
Add a link
Reference in a new issue