Added many template files, and totally modified the comments in most other.
This was when preparing Evonet Summer School - though it finally was not used there!
This commit is contained in:
parent
f69b785b39
commit
7bbdd17307
14 changed files with 855 additions and 96 deletions
25
eo/tutorial/Templates/Makefile.tmpl
Normal file
25
eo/tutorial/Templates/Makefile.tmpl
Normal file
|
|
@ -0,0 +1,25 @@
|
||||||
|
# sample makefile for building an EA evolving a new genotype
|
||||||
|
|
||||||
|
.cpp: ; c++ -DPACKAGE=\"eo\" -DVERSION=\"0.9.1\" -I. -I../../src -Wall -g -o $@ $*.cpp ../../src/libeo.a ../../src/utils/libeoutils.a
|
||||||
|
|
||||||
|
.cpp.o: ; c++ -DPACKAGE=\"eo\" -DVERSION=\"0.9.1\" -DF2C -I. -I../../src -I../Points -I./Sol -I./util -Wall -g -c $*.cpp
|
||||||
|
|
||||||
|
|
||||||
|
# START eventually modify the name of EO dir
|
||||||
|
DIR_EO = ../../src
|
||||||
|
# END eventually modify the name of EO dir
|
||||||
|
|
||||||
|
LIB_EO = $(DIR_EO)/utils/libeoutils.a $(DIR_EO)/libeo.a
|
||||||
|
|
||||||
|
ALL = eoMyStructEA
|
||||||
|
|
||||||
|
eoMyStructEA : eoMyStructEA.o
|
||||||
|
c++ -g -o $@ eoMyStructEA.o ../../src/utils/libeoutils.a ../../src/libeo.a -lm
|
||||||
|
|
||||||
|
tar : ; tar czvf climat.tgz *.h *.cpp Makefile
|
||||||
|
|
||||||
|
all : $(ALL)
|
||||||
|
|
||||||
|
clean : ; /bin/rm *.o $(ALL)
|
||||||
|
|
||||||
|
|
||||||
125
eo/tutorial/Templates/README
Normal file
125
eo/tutorial/Templates/README
Normal file
|
|
@ -0,0 +1,125 @@
|
||||||
|
This directory contains sample files that should make it easy to
|
||||||
|
create an EO algorithm to evolve any type of structure
|
||||||
|
(EO comes with two examples, bitstrings and vector of real variables,
|
||||||
|
so you'll need this qs soon as you want to evolve something else).
|
||||||
|
|
||||||
|
At the moment, only algorithms involving a scalar fitness (double)
|
||||||
|
are implemented (see test dir for Pareto optimization of multiple-
|
||||||
|
objective fitness - or be patient :-)
|
||||||
|
|
||||||
|
This file will help you to build the same algorithm than the ones
|
||||||
|
in the Lesson4 of the tutorial, but with YOUR genotype instead of
|
||||||
|
*bitstrings or vector<double>
|
||||||
|
|
||||||
|
It is assumed in the following that you have read the first part of
|
||||||
|
the tutorial (Lessons 1 to 4).
|
||||||
|
|
||||||
|
Creating the algorithm for your genotype
|
||||||
|
----------------------------------------
|
||||||
|
In what follows, we will suppose that you want to evolve some data
|
||||||
|
structure, and that you have enough programming skills to be able to
|
||||||
|
write C code for its random initilialization, its crossover, its
|
||||||
|
mutation and the computation of its fitness.
|
||||||
|
|
||||||
|
The helper script create.sh will create for you the files you need
|
||||||
|
from teh examples in tutorial/Templates dir, and all you'll have to do
|
||||||
|
is to include the actual code where indicated in those files (between
|
||||||
|
keywords START and END).
|
||||||
|
|
||||||
|
First, let's choose a name: let's call the new EO class eoAppli.
|
||||||
|
All newly created classes will be named eoApplicationXXX (in the file
|
||||||
|
eoApplicationXXX)
|
||||||
|
|
||||||
|
1- create a directory for your application in the tutorial dir, "parallel" to
|
||||||
|
the LessonX dirs (though any name can do, of course, we will suppose
|
||||||
|
its full name, from the / root dir, is APPLICATION in what follows)
|
||||||
|
|
||||||
|
2- cd to the tutorial/Templates dir
|
||||||
|
|
||||||
|
3- run the helper script create.sh with the following arguments
|
||||||
|
create.sh Appli APPLICATION
|
||||||
|
|
||||||
|
4- cd to the APPLICATION dir. You should see there the following
|
||||||
|
files:
|
||||||
|
Makefile with default target eoAppliEA
|
||||||
|
eoAppli.h class eoAppli<FitT>, FitT = template fitness
|
||||||
|
eoAppliEA.cpp the main file, includes all other, to be compiled
|
||||||
|
eoAppliEvalFunc.h class for the computation of fotness
|
||||||
|
eoAppliInit.h class for genotype initlialization
|
||||||
|
eoAppliMutation.h class for mutation
|
||||||
|
eoAppliQuadCrossover.h class for (quadratic) crossover
|
||||||
|
|
||||||
|
Note: You can go directly to step 6 and 7: you'll get a lot of
|
||||||
|
warnings, but will be able to run an EA that does nothing!
|
||||||
|
|
||||||
|
5- Edit those files one after the other and add you code where
|
||||||
|
indicated (look for keywords START and END and modify code in
|
||||||
|
between).
|
||||||
|
|
||||||
|
Note: If your APPLICATION dir is in the tutorial dir, you don't need
|
||||||
|
to modify Makefile.
|
||||||
|
|
||||||
|
6- Compile eoAppliEA.cpp:
|
||||||
|
|
||||||
|
% make
|
||||||
|
|
||||||
|
7- Run the resulting program:
|
||||||
|
|
||||||
|
% eoAppliEA
|
||||||
|
|
||||||
|
The default output is one line per generation with the generation
|
||||||
|
number, the number of evaluations performed, the best and average
|
||||||
|
fitnesses in the population.
|
||||||
|
The algorithm stops by default after 100 generations.
|
||||||
|
|
||||||
|
8- Customize the parameters: copy eoAppliEA.status into
|
||||||
|
e.g. eoAppliEA.param, edit eoAppliEA.param (uncomment the lines you
|
||||||
|
want to become active), and run
|
||||||
|
|
||||||
|
% eoAppliEA @eoAppliEA.param
|
||||||
|
|
||||||
|
(see the Lesson 4 of the tutorial for more details now).
|
||||||
|
|
||||||
|
HINTS
|
||||||
|
-----
|
||||||
|
|
||||||
|
1- All new classes you will create probably require some parameters in
|
||||||
|
the constructor, and some (if not all) thoses parameters are likele to
|
||||||
|
be user parameter: you can either read them in the main file (as is
|
||||||
|
done in the sample eoAppliEA.cpp) or pass the eoParser to the
|
||||||
|
constructor of the class, and read the parameter from the parser.
|
||||||
|
|
||||||
|
2- If you stick to privacy for the data in your EO class, you will
|
||||||
|
probably need to write accessors to those data, as well as some public
|
||||||
|
methods to modify them.
|
||||||
|
|
||||||
|
3- The sample eoAppliEA.cpp supposes that you ony have one crossover
|
||||||
|
and one mutation operator. However, the code for multiple operators
|
||||||
|
is there: you can have for instance 2 crossover operators, and choose
|
||||||
|
among them according to relative weights (proportional choice) - same
|
||||||
|
for mutation. Look at the operator section in eoAppliEA.cpp
|
||||||
|
In particular, the user parameter mutationRate is totally useless for
|
||||||
|
a single operator, and is there only as a provision for using more
|
||||||
|
than one.
|
||||||
|
|
||||||
|
To add another operator, you have to create another class by mimicking
|
||||||
|
what has been done for the first operator.
|
||||||
|
For instance, let's suppose you want to create another mutation.
|
||||||
|
|
||||||
|
* duplicate the code for eoAppliMutation class
|
||||||
|
* in the second version, change the class name (eoAppliMutation) into
|
||||||
|
another name (let's say eoAppliBetterMutation) - you must change the
|
||||||
|
name in the class declaration, in the constructor and in the
|
||||||
|
className() method.
|
||||||
|
* in the new eoAppliBetterMutation class, change the code for the
|
||||||
|
operator() - and eventually the code for the constructor.
|
||||||
|
* in the eoAppliEA.cpp file, in the mutation section, uncomment the
|
||||||
|
lines
|
||||||
|
eoMyStructSecondMutation<Indi> mut2(varType _anyVariable);
|
||||||
|
double mut2Rate = parser.createParam(1.0, "mut2Rate", "Relative rate for mutation 2", '2', "Variation Operators").value();
|
||||||
|
propMutation.add(mut2, mut2Rate);
|
||||||
|
|
||||||
|
and change the name of the class from eoAppliSecondMutation to your
|
||||||
|
name eoAppliBetterMutation (you can also change the keyword from
|
||||||
|
mut2Rate to something more meaningful like BetterMutationRate).
|
||||||
|
You're done!
|
||||||
|
|
@ -1,54 +1,70 @@
|
||||||
/** -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*-
|
/** -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*-
|
||||||
|
|
||||||
The above line is usefulin Emacs-like editors
|
The above line is useful in Emacs-like editors
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Template for simple binary crossover operators
|
Template for simple binary crossover operators
|
||||||
==============================================
|
==============================================
|
||||||
|
|
||||||
Binary crossover operators modify the first parent only,
|
Binary crossover operators modify the first genotype only,
|
||||||
based on the second
|
based on the second
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef eoMyDerivedBinOp_H
|
#ifndef eoMyStructBinCrossover_H
|
||||||
#define eoMyDerivedBinOp_H
|
#define eoMyStructBinCrossover_H
|
||||||
|
|
||||||
#include <eoOp.h>
|
#include <eoOp.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Always write a comment in this format before class definition
|
* Always write a comment in this format before class definition
|
||||||
if you want the class to be documented by Doxygen
|
* if you want the class to be documented by Doxygen
|
||||||
*/
|
*
|
||||||
template<class Indi>
|
* THere is NO ASSUMPTION on the class GenoypeT.
|
||||||
class eoMyDerivedBinOp: public eoBinOp<Indi>
|
* In particular, it does not need to derive from EO
|
||||||
|
*/
|
||||||
|
template<class GenotypeT>
|
||||||
|
class eoMyStructBinCrossover: public eoBinOp<GenotypeT>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
* (Default) Constructor.
|
* Ctor - no requirement
|
||||||
*/
|
*/
|
||||||
eoMyDerivedBinOp(paramType _anyParameter) :
|
// START eventually add or modify the anyVariable argument
|
||||||
anyParameter(_anyParameter) {}
|
eoMyStructBinCrossover()
|
||||||
|
// eoMyStructBinCrossover( varType _anyVariable) : anyVariable(_anyVariable)
|
||||||
|
// END eventually add or modify the anyVariable argument
|
||||||
|
{
|
||||||
|
// START Code of Ctor of an eoMyStructEvalFunc object
|
||||||
|
// END Code of Ctor of an eoMyStructEvalFunc object
|
||||||
|
}
|
||||||
|
|
||||||
/// The class name. Used to display statistics
|
/// The class name. Used to display statistics
|
||||||
string className() const { return "eoMyDerivedBinOp"; }
|
string className() const { return "eoMyStructBinCrossover"; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* eoBin crossover - modifies first parent only
|
* binCrossover - modifies first genotype only
|
||||||
* @param Indi1 The first parent
|
* @param _genotype1 The first genotype
|
||||||
* @param Indi2 The second parent - const
|
* @param _genotype2 The second genotype - const
|
||||||
*/
|
*/
|
||||||
bool operator()(Indi& Indi1, const Indi& Indi2)
|
bool operator()(GenotypeT & _genotype1, const GenotypeT & _genotype2)
|
||||||
{
|
{
|
||||||
// do whatever needs to be done
|
// START code for crossover of _genotype1 and _genotype2 objects
|
||||||
// if Indi1 has been modified
|
|
||||||
return true;
|
/** Requirement
|
||||||
// otherwise
|
* if _genotype1 has been modified
|
||||||
// return false;
|
* return true;
|
||||||
|
* otherwise
|
||||||
|
* return false;
|
||||||
|
*/
|
||||||
|
|
||||||
|
// END code for crossover of _genotype1 and _genotype2 objects
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
paramType anyParameter
|
// START Private data of an eoMyStructBinCrossover object
|
||||||
|
// varType anyVariable; // for example ...
|
||||||
|
// END Private data of an eoMyStructBinCrossover object
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -8,38 +8,57 @@ Template for continuator in EO, i.e. stopping conditions for EO algorithms
|
||||||
==========================================================================
|
==========================================================================
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _eoMyContinue_h
|
#ifndef _eoMyStructContinue_h
|
||||||
#define _eoMyContinue_h
|
#define _eoMyStructContinue_h
|
||||||
|
|
||||||
#include <eoMyContinue.h>
|
// include the base definition of eoContinue
|
||||||
|
#include <eoContinue.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Always write a comment in this format before class definition
|
* Always write a comment in this format before class definition
|
||||||
if you want the class to be documented by Doxygen
|
* if you want the class to be documented by Doxygen
|
||||||
*/
|
*
|
||||||
|
* ATTENTION, class EOT *must* derive from EO, as operator() will
|
||||||
|
* be called with an eoPop<EOT>
|
||||||
|
*/
|
||||||
template< class EOT>
|
template< class EOT>
|
||||||
class eoMyContinue: public eoContinue<EOT> {
|
class eoMyStructContinue: public eoContinue<EOT> {
|
||||||
public:
|
public:
|
||||||
/// Ctor
|
/**
|
||||||
eoMyContinue( paramType _anyParameter) :
|
* Ctor - no requirement
|
||||||
anyParameter(_anyParameter) {}
|
*/
|
||||||
|
// START eventually add or modify the anyVariable argument
|
||||||
|
eoMyStructContinue()
|
||||||
|
// eoMyStructBinCrossover( varType _anyVariable) : anyVariable(_anyVariable)
|
||||||
|
// END eventually add or modify the anyVariable argument
|
||||||
|
{
|
||||||
|
// START Code of Ctor of an eoMyStructEvalFunc object
|
||||||
|
// END Code of Ctor of an eoMyStructEvalFunc object
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/** Returns false when you want to stop
|
/** Returns false when you want to stop
|
||||||
|
*
|
||||||
|
* @param _pop an eoPop
|
||||||
*/
|
*/
|
||||||
virtual bool operator() ( const eoPop<EOT>& _pop )
|
virtual bool operator() ( const eoPop<EOT>& _pop )
|
||||||
{
|
{
|
||||||
bool stopCondition = ... ; // compute the stopping condition
|
bool stopCondition ; // to store the stopping condition
|
||||||
|
// START Code of computation of stopping condition
|
||||||
|
// stopCondition = blablabla
|
||||||
|
// END Code of computation of stopping condition
|
||||||
if (stopCondition) // the algo will stop upon return FALSE
|
if (stopCondition) // the algo will stop upon return FALSE
|
||||||
{
|
{
|
||||||
cout << "STOP in eoMyContinue: blablabla \n";
|
cout << "STOP in eoMyStructContinue \n";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true; // == do not stop
|
return true; // == do not stop
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
paramType anyParameter
|
// START Private data of an eoMyStructContinue object
|
||||||
|
// varType anyVariable; // for example ...
|
||||||
|
// END Private data of an eoMyStructContinue object
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
13
eo/tutorial/Templates/create.sh
Executable file
13
eo/tutorial/Templates/create.sh
Executable file
|
|
@ -0,0 +1,13 @@
|
||||||
|
#! /bin/tcsh -f
|
||||||
|
if ($#argv < 2) then
|
||||||
|
echo Usage $argv[0] ApplicationName TargetDir
|
||||||
|
exit
|
||||||
|
endif
|
||||||
|
sed s/eoMyStruct/eo$1/g eoMyStruct.tmpl > $2/eo$1.h
|
||||||
|
sed s/eoMyStruct/eo$1/g init.tmpl > $2/eo$1Init.h
|
||||||
|
sed s/eoMyStruct/eo$1/g evalFunc.tmpl > $2/eo$1EvalFunc.h
|
||||||
|
sed s/eoMyStruct/eo$1/g mutation.tmpl > $2/eo$1Mutation.h
|
||||||
|
sed s/eoMyStruct/eo$1/g quadCrossover.tmpl > $2/eo$1QuadCrossover.h
|
||||||
|
sed s/eoMyStruct/eo$1/g eoMyStructEA.cpp > $2/eo$1EA.cpp
|
||||||
|
sed s/eoMyStruct/eo$1/g Makefile.tmpl > $2/Makefile
|
||||||
|
|
||||||
78
eo/tutorial/Templates/eoMyStruct.tmpl
Normal file
78
eo/tutorial/Templates/eoMyStruct.tmpl
Normal file
|
|
@ -0,0 +1,78 @@
|
||||||
|
/** -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*-
|
||||||
|
|
||||||
|
The above line is usefulin Emacs-like editors
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
Template for creating a new representation in EO
|
||||||
|
================================================
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _eoMyStruct_h
|
||||||
|
#define _eoMyStruct_h
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Always write a comment in this format before class definition
|
||||||
|
* if you want the class to be documented by Doxygen
|
||||||
|
|
||||||
|
* Note that you MUST derive your structure from EO<fitT>
|
||||||
|
* but you MAY use some other already prepared class in the hierarchy
|
||||||
|
* like eoVector for instance, if you handle a vector of something....
|
||||||
|
|
||||||
|
* If you create a structure from scratch,
|
||||||
|
* the only thing you need to provide are
|
||||||
|
* a default constructor
|
||||||
|
* IO routines printOn and readFrom
|
||||||
|
*
|
||||||
|
* Note that operator<< and operator>> are defined at EO level
|
||||||
|
* using these routines
|
||||||
|
*/
|
||||||
|
template< class FitT>
|
||||||
|
class eoMyStruct: public EO<FitT> {
|
||||||
|
public:
|
||||||
|
/** Ctor: you MUST provide a default ctor.
|
||||||
|
* though such individuals will generally be processed
|
||||||
|
* by some eoInit object
|
||||||
|
*/
|
||||||
|
eoMyStruct()
|
||||||
|
{
|
||||||
|
// START Code of default Ctor of an eoMyStruct object
|
||||||
|
// END Code of default Ctor of an eoMyStruct object
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/** printing... */
|
||||||
|
void printOn(ostream& os) const
|
||||||
|
{
|
||||||
|
// START Code of default output
|
||||||
|
|
||||||
|
/** HINTS
|
||||||
|
* in EO we systematically write the sizes of things before the things
|
||||||
|
* so readFrom is easier to code (see below)
|
||||||
|
*/
|
||||||
|
|
||||||
|
// END Code of default output
|
||||||
|
}
|
||||||
|
|
||||||
|
/** reading...
|
||||||
|
* of course, your readFrom must be able to read what printOn writes!!!
|
||||||
|
*/
|
||||||
|
void readFrom(istream& is)
|
||||||
|
{
|
||||||
|
// START Code of input
|
||||||
|
|
||||||
|
/** HINTS
|
||||||
|
* remember the eoMyStruct object will come from the default ctor
|
||||||
|
* this is why having the sizes written out is useful
|
||||||
|
*/
|
||||||
|
|
||||||
|
// END Code of input
|
||||||
|
}
|
||||||
|
|
||||||
|
private: // put all data here
|
||||||
|
// START Private data of an eoMyStruct object
|
||||||
|
// END Private data of an eoMyStruct object
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
321
eo/tutorial/Templates/eoMyStructEA.cpp
Normal file
321
eo/tutorial/Templates/eoMyStructEA.cpp
Normal file
|
|
@ -0,0 +1,321 @@
|
||||||
|
#include <iostream>
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
// eo general include
|
||||||
|
#include "eo"
|
||||||
|
// the real bounds (not yet in general eo include)
|
||||||
|
#include "utils/eoRealVectorBounds.h"
|
||||||
|
|
||||||
|
// include here whatever specific files for your representation
|
||||||
|
// Basically, this should include at least the following
|
||||||
|
|
||||||
|
/** definition of representation:
|
||||||
|
* class eoMyStruct MUST derive from EO<FitT> for some fitness
|
||||||
|
*/
|
||||||
|
#include "eoMyStruct.h"
|
||||||
|
|
||||||
|
/** definition of initilizqtion:
|
||||||
|
* class eoMyStructInit MUST derive from eoInit<eoMyStruct>
|
||||||
|
*/
|
||||||
|
#include "eoMyStructInit.h"
|
||||||
|
|
||||||
|
/** definition of mutation:
|
||||||
|
* class eoMyStructMonop MUST derive from eoMonOp<eoMyStruct>
|
||||||
|
*/
|
||||||
|
#include "eoMyStructMutation.h"
|
||||||
|
|
||||||
|
/** definition of crossover (either as eoBinOp (2->1) or eoQuadOp (2->2):
|
||||||
|
* class eoMyStructBinCrossover MUST derive from eoBinOp<eoMyStruct>
|
||||||
|
* OR
|
||||||
|
* class eoMyStructQuadCrossover MUST derive from eoQuadOp<eoMyStruct>
|
||||||
|
*/
|
||||||
|
// #include "eoMyStructBinOp.h"
|
||||||
|
// OR
|
||||||
|
#include "eoMyStructQuadCrossover.h"
|
||||||
|
|
||||||
|
/** definition of evaluation:
|
||||||
|
* class eoMyStructEvalFunc MUST derive from eoEvalFunc<eoMyStruct>
|
||||||
|
* and should test for validity before doing any computation
|
||||||
|
* see tutorial/Templates/evalFunc.tmpl
|
||||||
|
*/
|
||||||
|
#include "eoMyStructEvalFunc.h"
|
||||||
|
|
||||||
|
// GENOTYPE eoMyStruct ***MUST*** be templatized over the fitness
|
||||||
|
|
||||||
|
//*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*
|
||||||
|
// START fitness type: double or eoMaximizingFitness if you are maximizing
|
||||||
|
// eoMinimizingFitness if you are minimizing
|
||||||
|
typedef eoMyStruct<double> Indi; // ***MUST*** derive from EO
|
||||||
|
// END fitness type
|
||||||
|
//*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*
|
||||||
|
|
||||||
|
|
||||||
|
// Use existing modules to define representation independent routines
|
||||||
|
// These are parser-based definitions of objects
|
||||||
|
|
||||||
|
// how to initialize the population
|
||||||
|
// it IS representation independent if an eoInit is given
|
||||||
|
#include <do/make_pop.h>
|
||||||
|
eoPop<Indi >& make_pop(eoParser& _parser, eoState& _state, eoInit<Indi> & _init)
|
||||||
|
{
|
||||||
|
return do_make_pop(_parser, _state, _init);
|
||||||
|
}
|
||||||
|
|
||||||
|
// the stopping criterion
|
||||||
|
#include <do/make_continue.h>
|
||||||
|
eoContinue<Indi>& make_continue(eoParser& _parser, eoState& _state, eoEvalFuncCounter<Indi> & _eval)
|
||||||
|
{
|
||||||
|
return do_make_continue(_parser, _state, _eval);
|
||||||
|
}
|
||||||
|
|
||||||
|
// outputs (stats, population dumps, ...)
|
||||||
|
#include <do/make_checkpoint.h>
|
||||||
|
eoCheckPoint<Indi>& make_checkpoint(eoParameterLoader& _parser, eoState& _state, eoEvalFuncCounter<Indi>& _eval, eoContinue<Indi>& _continue)
|
||||||
|
{
|
||||||
|
return do_make_checkpoint(_parser, _state, _eval, _continue);
|
||||||
|
}
|
||||||
|
|
||||||
|
// evolution engine (selection and replacement)
|
||||||
|
#include <do/make_algo_scalar.h>
|
||||||
|
eoAlgo<Indi>& make_algo_scalar(eoParameterLoader& _parser, eoState& _state, eoEvalFunc<Indi>& _eval, eoContinue<Indi>& _continue, eoGenOp<Indi>& _op)
|
||||||
|
{
|
||||||
|
return do_make_algo_scalar(_parser, _state, _eval, _continue, _op);
|
||||||
|
}
|
||||||
|
|
||||||
|
// simple call to the algo. stays there for consistency reasons
|
||||||
|
// no template for that one
|
||||||
|
#include <do/make_run.h>
|
||||||
|
// the instanciating fitnesses
|
||||||
|
#include <eoScalarFitness.h>
|
||||||
|
void run_ea(eoAlgo<Indi>& _ga, eoPop<Indi>& _pop)
|
||||||
|
{
|
||||||
|
do_run(_ga, _pop);
|
||||||
|
}
|
||||||
|
|
||||||
|
// checks for help demand, and writes the status file
|
||||||
|
// and make_help; in libutils
|
||||||
|
void make_help(eoParser & _parser);
|
||||||
|
|
||||||
|
// now use all of the above, + representation dependent things
|
||||||
|
int main(int argc, char* argv[])
|
||||||
|
{
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
eoParser parser(argc, argv); // for user-parameter reading
|
||||||
|
|
||||||
|
eoState state; // keeps all things allocated
|
||||||
|
|
||||||
|
///// FIRST, problem or representation dependent stuff
|
||||||
|
//////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
//////////////////////////////////////////////
|
||||||
|
// the genotype - through a genotype initializer
|
||||||
|
|
||||||
|
//*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*
|
||||||
|
// START read parameters (if any) and create the initializer directly
|
||||||
|
|
||||||
|
// As far as memory management is concerned, the parameters
|
||||||
|
// AND the values are owned by the parser (handled through references)
|
||||||
|
|
||||||
|
// example of parameter reading using the most compact syntax
|
||||||
|
// varType var = parser.createParam(varType defaultValue,
|
||||||
|
// string keyword,
|
||||||
|
// string comment,
|
||||||
|
// char shortKeyword,
|
||||||
|
// string section,).value();
|
||||||
|
|
||||||
|
// an unsigned parameter
|
||||||
|
unsigned sampleUnsigned = parser.createParam(unsigned(10), "anUnsigned", "An unsigned parameter",'V', "Representation").value();
|
||||||
|
|
||||||
|
// a double parameter
|
||||||
|
double sampleDouble = parser.createParam(0.3, "aDouble", "A double parameter", 's', "Representation" ).value();
|
||||||
|
|
||||||
|
// some real bounds: [-1,1]x[-1,1] by default
|
||||||
|
eoRealVectorBounds & sampleBounds = parser.createParam(eoRealVectorBounds(2,-1,1), "someBounds", "Bounds of some real variables", 'B', "Representation").value();
|
||||||
|
// END read parameters (if any) and create the initializer directly
|
||||||
|
//*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*
|
||||||
|
|
||||||
|
//*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*
|
||||||
|
// START Modify definitions of objects by eventually add parameters
|
||||||
|
|
||||||
|
/** HINTS
|
||||||
|
*
|
||||||
|
* The following declare variables that are objects defined
|
||||||
|
* in the customized files.
|
||||||
|
* You shoudl only modify the arguments passed onto their constructors
|
||||||
|
* ("varType _anyVariable") in their definition
|
||||||
|
*
|
||||||
|
* and you can optionally uncomment and modify the lines commented between
|
||||||
|
* /* and */
|
||||||
|
|
||||||
|
// the initializer: will be used in make_pop
|
||||||
|
////////////////////
|
||||||
|
eoMyStructInit<Indi> init/* (varType _anyVariable) */;
|
||||||
|
|
||||||
|
// The fitness
|
||||||
|
//////////////
|
||||||
|
eoMyStructEvalFunc<Indi> plainEval/* (varType _anyVariable) */;
|
||||||
|
// turn that object into an evaluation counter
|
||||||
|
eoEvalFuncCounter<Indi> eval(plainEval);
|
||||||
|
|
||||||
|
/////////////////////////////
|
||||||
|
// Variation operators
|
||||||
|
////////////////////////////
|
||||||
|
// read crossover and mutations, combine each in a proportional Op
|
||||||
|
// and create the eoGenOp that calls crossover at rate pCross
|
||||||
|
// then mutation with rate pMut
|
||||||
|
|
||||||
|
// the crossovers
|
||||||
|
/////////////////
|
||||||
|
|
||||||
|
// here we can have eoQuadOp (2->2) only - no time for the eoBinOp case
|
||||||
|
|
||||||
|
// you can have more than one - combined in a proportional way
|
||||||
|
|
||||||
|
// first, define the crossover objects and read their rates from the parser
|
||||||
|
|
||||||
|
// A first crossover
|
||||||
|
eoMyStructQuadCrossover<Indi> cross1/* (varType _anyVariable) */;
|
||||||
|
// its relative rate in the combination
|
||||||
|
double cross1Rate = parser.createParam(1.0, "cross1Rate", "Relative rate for crossover 1", '1', "Variation Operators").value();
|
||||||
|
// and the creation of the combined operator with this one
|
||||||
|
eoPropCombinedQuadOp<Indi> propXover(cross1, cross1Rate);
|
||||||
|
|
||||||
|
// Optional: A second(and third, and ...) crossover
|
||||||
|
// of course you must create the corresponding classes
|
||||||
|
// and all ***MUST*** derive from eoQuadOp<Indi>
|
||||||
|
|
||||||
|
/* Uncomment if necessary - and replicate as many time as you need
|
||||||
|
eoMyStructSecondCrossover<Indi> cross2(varType _anyVariable);
|
||||||
|
double cross2Rate = parser.createParam(1.0, "cross2Rate", "Relative rate for crossover 2", '2', "Variation Operators").value();
|
||||||
|
propXover.add(cross2, cross2Rate);
|
||||||
|
*/
|
||||||
|
// if you want some gentle output, the last one shoudl be like
|
||||||
|
// propXover.add(crossXXX, crossXXXRate, true);
|
||||||
|
|
||||||
|
|
||||||
|
// the mutation: same story
|
||||||
|
////////////////
|
||||||
|
// you can have more than one - combined in a proportional way
|
||||||
|
|
||||||
|
// for each mutation,
|
||||||
|
// - define the mutator object
|
||||||
|
// - read its rate from the parser
|
||||||
|
// - add it to the proportional combination
|
||||||
|
|
||||||
|
// a first mutation
|
||||||
|
eoMyStructMutation<Indi> mut1/* (varType _anyVariable) */;
|
||||||
|
// its relative rate in the combination
|
||||||
|
double mut1Rate = parser.createParam(1.0, "mut1Rate", "Relative rate for mutation 1", '1', "Variation Operators").value();
|
||||||
|
// and the creation of the combined operator with this one
|
||||||
|
eoPropCombinedMonOp<Indi> propMutation(mut1, mut1Rate);
|
||||||
|
|
||||||
|
// Optional: A second(and third, and ...) mutation with their rates
|
||||||
|
// of course you must create the corresponding classes
|
||||||
|
// and all ***MUST*** derive from eoMonOp<Indi>
|
||||||
|
|
||||||
|
/* Uncomment if necessary - and replicate as many time as you need
|
||||||
|
eoMyStructSecondMutation<Indi> mut2(varType _anyVariable);
|
||||||
|
double mut2Rate = parser.createParam(1.0, "mut2Rate", "Relative rate for mutation 2", '2', "Variation Operators").value();
|
||||||
|
propMutation.add(mut2, mut2Rate);
|
||||||
|
*/
|
||||||
|
// if you want some gentle output, the last one shoudl be like
|
||||||
|
// propMutation.add(mutXXX, mutXXXRate, true);
|
||||||
|
|
||||||
|
// end of crossover and mutation definitions
|
||||||
|
////////////////////////////////////////////
|
||||||
|
|
||||||
|
// END Modify definitions of objects by eventually add parameters
|
||||||
|
//*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*
|
||||||
|
|
||||||
|
// from now on, you do not need to modify anything
|
||||||
|
// though you CAN add things to the checkpointing (see tutorial)
|
||||||
|
|
||||||
|
// now build the eoGenOp:
|
||||||
|
// to simulate SGA (crossover with proba pCross + mutation with proba pMut
|
||||||
|
// we must construct
|
||||||
|
// a sequential combination of
|
||||||
|
// with proba 1, a proportional combination of
|
||||||
|
// a QuadCopy and our crossover
|
||||||
|
// with proba pMut, our mutation
|
||||||
|
|
||||||
|
// but of course you're free to use any smart combination you could think of
|
||||||
|
// especially, if you have to use eoBinOp rather than eoQuad Op youùll have
|
||||||
|
// to modify that part
|
||||||
|
|
||||||
|
// First read the individual level parameters
|
||||||
|
eoValueParam<double>& pCrossParam = parser.createParam(0.6, "pCross", "Probability of Crossover", 'C', "Variation Operators" );
|
||||||
|
// minimum check
|
||||||
|
if ( (pCrossParam.value() < 0) || (pCrossParam.value() > 1) )
|
||||||
|
throw runtime_error("Invalid pCross");
|
||||||
|
|
||||||
|
eoValueParam<double>& pMutParam = parser.createParam(0.1, "pMut", "Probability of Mutation", 'M', "Variation Operators" );
|
||||||
|
// minimum check
|
||||||
|
if ( (pMutParam.value() < 0) || (pMutParam.value() > 1) )
|
||||||
|
throw runtime_error("Invalid pMut");
|
||||||
|
|
||||||
|
|
||||||
|
// the crossover - with probability pCross
|
||||||
|
eoProportionalOp<Indi> * cross = new eoProportionalOp<Indi> ;
|
||||||
|
state.storeFunctor(cross);
|
||||||
|
eoQuadOp<Indi> *ptQuad = new eoQuadCloneOp<Indi>;
|
||||||
|
state.storeFunctor(ptQuad);
|
||||||
|
cross->add(propXover, pCrossParam.value()); // crossover, with proba pcross
|
||||||
|
cross->add(*ptQuad, 1-pCrossParam.value()); // nothing, with proba 1-pcross
|
||||||
|
|
||||||
|
// now the sequential
|
||||||
|
eoSequentialOp<Indi> *op = new eoSequentialOp<Indi>;
|
||||||
|
state.storeFunctor(op);
|
||||||
|
op->add(*cross, 1.0); // always do combined crossover
|
||||||
|
op->add(propMutation, pMutParam.value()); // then mutation, with proba pmut
|
||||||
|
|
||||||
|
// that's it! (beware op is a pointer - for lazy cut-and-paste reasons!
|
||||||
|
|
||||||
|
// end of operator definition
|
||||||
|
////////////////////////////
|
||||||
|
|
||||||
|
//// Now the representation-independent things
|
||||||
|
//
|
||||||
|
// YOU SHOULD NOT NEED TO MODIFY ANYTHING BEYOND THIS POINT
|
||||||
|
// unless you want to add specific statistics to the checkpoint
|
||||||
|
//////////////////////////////////////////////
|
||||||
|
|
||||||
|
// initialize the population
|
||||||
|
// yes, this is representation indepedent once you have an eoInit
|
||||||
|
eoPop<Indi>& pop = make_pop(parser, state, init);
|
||||||
|
|
||||||
|
// stopping criteria
|
||||||
|
eoContinue<Indi> & term = make_continue(parser, state, eval);
|
||||||
|
// output
|
||||||
|
eoCheckPoint<Indi> & checkpoint = make_checkpoint(parser, state, eval, term);
|
||||||
|
// algorithm (need the operator!)
|
||||||
|
eoAlgo<Indi>& ga = make_algo_scalar(parser, state, eval, checkpoint, (*op));
|
||||||
|
|
||||||
|
///// End of construction of the algorithm
|
||||||
|
|
||||||
|
/////////////////////////////////////////
|
||||||
|
// to be called AFTER all parameters have been read!!!
|
||||||
|
make_help(parser);
|
||||||
|
|
||||||
|
//// GO
|
||||||
|
///////
|
||||||
|
// evaluate intial population AFTER help and status in case it takes time
|
||||||
|
apply(eval, pop);
|
||||||
|
// if you want to print it out
|
||||||
|
// cout << "Initial Population\n";
|
||||||
|
// pop.sortedPrintOn(cout);
|
||||||
|
// cout << endl;
|
||||||
|
|
||||||
|
run_ea(ga, pop); // run the ga
|
||||||
|
|
||||||
|
cout << "Final Population\n";
|
||||||
|
pop.sortedPrintOn(cout);
|
||||||
|
cout << endl;
|
||||||
|
|
||||||
|
}
|
||||||
|
catch(exception& e)
|
||||||
|
{
|
||||||
|
cout << e.what() << endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
65
eo/tutorial/Templates/evalFunc.tmpl
Normal file
65
eo/tutorial/Templates/evalFunc.tmpl
Normal file
|
|
@ -0,0 +1,65 @@
|
||||||
|
/** -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*-
|
||||||
|
|
||||||
|
The above line is usefulin Emacs-like editors
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
Template for continuator in EO, i.e. stopping conditions for EO algorithms
|
||||||
|
==========================================================================
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _eoMyStructEvalFunc_h
|
||||||
|
#define _eoMyStructEvalFunc_h
|
||||||
|
|
||||||
|
// include whatever general include you need
|
||||||
|
#include <stdexcept>
|
||||||
|
#include <fstream>
|
||||||
|
|
||||||
|
// include the base definition of eoEvalFunc
|
||||||
|
#include "eoEvalFunc.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
Always write a comment in this format before class definition
|
||||||
|
if you want the class to be documented by Doxygen
|
||||||
|
*/
|
||||||
|
template <class EOT>
|
||||||
|
class eoMyStructEvalFunc : public eoEvalFunc<EOT>
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/// Ctor - no requirement
|
||||||
|
// START eventually add or modify the anyVariable argument
|
||||||
|
eoMyStructEvalFunc()
|
||||||
|
// eoMyStructEvalFunc( varType _anyVariable) : anyVariable(_anyVariable)
|
||||||
|
// END eventually add or modify the anyVariable argument
|
||||||
|
{
|
||||||
|
// START Code of Ctor of an eoMyStructEvalFunc object
|
||||||
|
// END Code of Ctor of an eoMyStructEvalFunc object
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Actually compute the fitness
|
||||||
|
*
|
||||||
|
* @param EOT & _eo the EO object to evaluate
|
||||||
|
* it should stay templatized to be usable
|
||||||
|
* with any fitness type
|
||||||
|
*/
|
||||||
|
void operator()(EOT & _eo)
|
||||||
|
{
|
||||||
|
// test for invalid to avoid recomputing fitness of unmodified individuals
|
||||||
|
if (_eo.invalid())
|
||||||
|
{
|
||||||
|
double fit; // to hold fitness value
|
||||||
|
// START Code of computation of fitness of the eoMyStruct object
|
||||||
|
// fit = blablabla
|
||||||
|
// END Code of computation of fitness of the eoMyStruct object
|
||||||
|
_eo.fitness(fit);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
// START Private data of an eoMyStructEvalFunc object
|
||||||
|
// varType anyVariable; // for example ...
|
||||||
|
// END Private data of an eoMyStructEvalFunc object
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
57
eo/tutorial/Templates/init.tmpl
Normal file
57
eo/tutorial/Templates/init.tmpl
Normal file
|
|
@ -0,0 +1,57 @@
|
||||||
|
/** -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*-
|
||||||
|
|
||||||
|
The above line is usefulin Emacs-like editors
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
Template for EO objects initialization in EO
|
||||||
|
============================================
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _eoMyStructInit_h
|
||||||
|
#define _eoMyStructInit_h
|
||||||
|
|
||||||
|
// include the base definition of eoInit
|
||||||
|
#include <eoInit.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Always write a comment in this format before class definition
|
||||||
|
* if you want the class to be documented by Doxygen
|
||||||
|
*
|
||||||
|
* There is NO ASSUMPTION on the class GenoypeT.
|
||||||
|
* In particular, it does not need to derive from EO (e.g. to initialize
|
||||||
|
* atoms of an eoVector you will need an eoInit<AtomType>)
|
||||||
|
*/
|
||||||
|
template <class GenotypeT>
|
||||||
|
class eoMyStructInit: public eoInit<GenotypeT> {
|
||||||
|
public:
|
||||||
|
/// Ctor - no requirement
|
||||||
|
// START eventually add or modify the anyVariable argument
|
||||||
|
eoMyStructInit()
|
||||||
|
// eoMyStructInit( varType _anyVariable) : anyVariable(_anyVariable)
|
||||||
|
// END eventually add or modify the anyVariable argument
|
||||||
|
{
|
||||||
|
// START Code of Ctor of an eoMyStructInit object
|
||||||
|
// END Code of Ctor of an eoMyStructInit object
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/** initialize a genotype
|
||||||
|
*
|
||||||
|
* @param _genotype generally a genotype that has been default-constructed
|
||||||
|
* whatever it contains will be lost
|
||||||
|
*/
|
||||||
|
void operator()(GenotypeT & _genotype)
|
||||||
|
{
|
||||||
|
// START Code of random initialization of an eoMyStruct object
|
||||||
|
// END Code of random initialization of an eoMyStruct object
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
// START Private data of an eoMyStructInit object
|
||||||
|
// varType anyVariable; // for example ...
|
||||||
|
// END Private data of an eoMyStructInit object
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
@ -19,11 +19,14 @@ Second version, get parents using an external eoSelectOne
|
||||||
#include <eoGenOp.h>
|
#include <eoGenOp.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Always write a comment in this format before class definition
|
* Always write a comment in this format before class definition
|
||||||
if you want the class to be documented by Doxygen
|
* if you want the class to be documented by Doxygen
|
||||||
*/
|
*
|
||||||
template<class Indi>
|
* ATTENTION, class EOT *must* derive from EO, as method invalidate()
|
||||||
class eoLessOffspringExternalSelectorGenOp: public eoGenOp<Indi>
|
* must be called if the genotypes of the indis is modified
|
||||||
|
*/
|
||||||
|
template<class EOT>
|
||||||
|
class eoLessOffspringExternalSelectorGenOp: public eoGenOp<EOT>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -10,7 +10,7 @@ i.e. that takes any number of parents and generates any number of offspring
|
||||||
|
|
||||||
a GenOp that creates less offspring than there are parents
|
a GenOp that creates less offspring than there are parents
|
||||||
|
|
||||||
First version, get parents from populator using the ibbedded select() method
|
First version, get parents from populator using the imbedded select() method
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef eoLessOffspringSameSelectorGenOp_H
|
#ifndef eoLessOffspringSameSelectorGenOp_H
|
||||||
|
|
@ -19,11 +19,14 @@ First version, get parents from populator using the ibbedded select() method
|
||||||
#include <eoGenOp.h>
|
#include <eoGenOp.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Always write a comment in this format before class definition
|
* Always write a comment in this format before class definition
|
||||||
if you want the class to be documented by Doxygen
|
* if you want the class to be documented by Doxygen
|
||||||
*/
|
*
|
||||||
template<class Indi>
|
* ATTENTION, class EOT *must* derive from EO, as method invalidate()
|
||||||
class eoLessOffspringSameSelectorGenOp: public eoGenOp<Indi>
|
* must be called if the genotypes of the indis is modified
|
||||||
|
*/
|
||||||
|
template<class EOT>
|
||||||
|
class eoLessOffspringSameSelectorGenOp: public eoGenOp<EOT>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -18,11 +18,14 @@ than there are parents
|
||||||
#include <eoGenOp.h>
|
#include <eoGenOp.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Always write a comment in this format before class definition
|
* Always write a comment in this format before class definition
|
||||||
if you want the class to be documented by Doxygen
|
* if you want the class to be documented by Doxygen
|
||||||
*/
|
*
|
||||||
template<class Indi>
|
* ATTENTION, class EOT *must* derive from EO, as method invalidate()
|
||||||
class eoMoreOffspringGenOp: public eoGenOp<Indi>
|
* must be called if the genotypes of the indis is modified
|
||||||
|
*/
|
||||||
|
template<class EOT>
|
||||||
|
class eoMoreOffspringGenOp: public eoGenOp<EOT>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
/** -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*-
|
/** -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*-
|
||||||
|
|
||||||
The above line is usefulin Emacs-like editors
|
The above line is useful in Emacs-like editors
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
@ -8,44 +8,60 @@ Template for simple mutation operators
|
||||||
======================================
|
======================================
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef eoMyDerivedMonOp_H
|
#ifndef eoMyStructMutation_H
|
||||||
#define eoMyDerivedMonOp_H
|
#define eoMyStructMutation_H
|
||||||
|
|
||||||
|
|
||||||
#include <eoOp.h>
|
#include <eoOp.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Always write a comment in this format before class definition
|
* Always write a comment in this format before class definition
|
||||||
if you want the class to be documented by Doxygen
|
* if you want the class to be documented by Doxygen
|
||||||
*/
|
*
|
||||||
template<class Indi>
|
* THere is NO ASSUMPTION on the class GenoypeT.
|
||||||
class eoMyDerivedMonOp: public eoMonOp<Indi>
|
* In particular, it does not need to derive from EO
|
||||||
|
*/
|
||||||
|
template<class GenotypeT>
|
||||||
|
class eoMyStructMutation: public eoMonOp<GenotypeT>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
* (Default) Constructor.
|
* Ctor - no requirement
|
||||||
*/
|
*/
|
||||||
eoMyDerivedMonOp(paramType _anyParameter) :
|
// START eventually add or modify the anyVariable argument
|
||||||
anyParameter(_anyParameter) {}
|
eoMyStructMutation()
|
||||||
|
// eoMyStructMutation( varType _anyVariable) : anyVariable(_anyVariable)
|
||||||
|
// END eventually add or modify the anyVariable argument
|
||||||
|
{
|
||||||
|
// START Code of Ctor of an eoMyStructEvalFunc object
|
||||||
|
// END Code of Ctor of an eoMyStructEvalFunc object
|
||||||
|
}
|
||||||
|
|
||||||
/// The class name. Used to display statistics
|
/// The class name. Used to display statistics
|
||||||
string className() const { return "eoMyDerivedMonOp"; }
|
string className() const { return "eoMyStructMutation"; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* modifies the parent
|
* modifies the parent
|
||||||
* @param Indi The parent
|
* @param _genotype The parent genotype (will be modified)
|
||||||
*/
|
*/
|
||||||
bool operator()(Indi& Indi)
|
bool operator()(GenotypeT & _genotype)
|
||||||
{
|
{
|
||||||
// do whatever needs to be done
|
// START code for mutation of the _genotype object
|
||||||
// if Indi has been modified
|
|
||||||
return true;
|
/** Requirement
|
||||||
// otherwise
|
* if _genotype has been modified
|
||||||
// return false;
|
* return true;
|
||||||
|
* otherwise
|
||||||
|
* return false;
|
||||||
|
*/
|
||||||
|
|
||||||
|
// END code for mutation of the _genotype object
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
paramType anyParameter
|
// START Private data of an eoMyStructMutation object
|
||||||
|
// varType anyVariable; // for example ...
|
||||||
|
// END Private data of an eoMyStructMutation object
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -7,48 +7,63 @@ The above line is usefulin Emacs-like editors
|
||||||
Template for simple quadratic crossover operators
|
Template for simple quadratic crossover operators
|
||||||
=================================================
|
=================================================
|
||||||
|
|
||||||
Quadratic crossover operators modify the both parents
|
Quadratic crossover operators modify the both genotypes
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef eoMyDerivedQuadOp_H
|
#ifndef eoMyStructQuadCrossover_H
|
||||||
#define eoMyDerivedQuadOp_H
|
#define eoMyStructQuadCrossover_H
|
||||||
|
|
||||||
#include <eoOp.h>
|
#include <eoOp.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Always write a comment in this format before class definition
|
* Always write a comment in this format before class definition
|
||||||
if you want the class to be documented by Doxygen
|
* if you want the class to be documented by Doxygen
|
||||||
*/
|
*
|
||||||
template<class Indi>
|
* THere is NO ASSUMPTION on the class GenoypeT.
|
||||||
class eoMyDerivedQuadOp: public eoQuadOp<Indi>
|
* In particular, it does not need to derive from EO
|
||||||
|
*/
|
||||||
|
template<class GenotypeT>
|
||||||
|
class eoMyStructQuadCrossover: public eoQuadOp<GenotypeT>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
* (Default) Constructor.
|
* Ctor - no requirement
|
||||||
*/
|
*/
|
||||||
eoMyDerivedQuadOp(paramType _anyParameter) :
|
// START eventually add or modify the anyVariable argument
|
||||||
anyParameter(_anyParameter) {}
|
eoMyStructQuadCrossover()
|
||||||
|
// eoMyStructQuadCrossover( varType _anyVariable) : anyVariable(_anyVariable)
|
||||||
|
// END eventually add or modify the anyVariable argument
|
||||||
|
{
|
||||||
|
// START Code of Ctor of an eoMyStructEvalFunc object
|
||||||
|
// END Code of Ctor of an eoMyStructEvalFunc object
|
||||||
|
}
|
||||||
|
|
||||||
/// The class name. Used to display statistics
|
/// The class name. Used to display statistics
|
||||||
string className() const { return "eoMyDerivedQuadOp"; }
|
string className() const { return "eoMyStructQuadCrossover"; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* eoQuad crossover - modifies both parents
|
* eoQuad crossover - modifies both parents
|
||||||
* @param Indi1 The first parent
|
* @param _genotype1 The first parent
|
||||||
* @param Indi2 The second parent
|
* @param _genotype2 The second parent
|
||||||
*/
|
*/
|
||||||
bool operator()(Indi& Indi1, Indi& Indi2)
|
bool operator()(GenotypeT& _genotype1, GenotypeT & _genotype2)
|
||||||
{
|
{
|
||||||
// do whatever needs to be done
|
// START code for crossover of _genotype1 and _genotype2 objects
|
||||||
|
|
||||||
// if at least one individual has been modified - no way to distinguish
|
/** Requirement
|
||||||
return true;
|
* if at least one genotype has been modified - no way to distinguish
|
||||||
// otherwise
|
* return true;
|
||||||
// return false;
|
* otherwise
|
||||||
|
* return false;
|
||||||
|
*/
|
||||||
|
|
||||||
|
// END code for crossover of _genotype1 and _genotype2 objects
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
paramType anyParameter
|
// START Private data of an eoMyStructQuadCrossover object
|
||||||
|
// varType anyVariable; // for example ...
|
||||||
|
// END Private data of an eoMyStructQuadCrossover object
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
Reference in a new issue