paradiseo/eo/tutorial/ParadisEO/Lesson3/CellularBitEA.cpp
kuepper 3cb80bc73b update build process to include paradiseo tutorial,
fix paradiseo headers for sstream
2004-09-22 12:38:28 +00:00

96 lines
1.7 KiB
C++

#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <iostream>
#include <stdexcept> // runtime_error
#ifdef HAVE_SSTREAM
#include <sstream>
#else
#include <strstream>
#endif
#include <eo>
#include <ga.h>
typedef eoBit<double> Indi;
#include "binary_value.h"
using namespace std;
void main_function(int argc, char **argv)
{
const unsigned int SEED = 42;
const unsigned int VEC_SIZE = 8;
const unsigned int POP_SIZE = 25;
const unsigned int MAX_GEN = 100;
const double P_MUT_PER_BIT = 0.01;
rng.reseed(SEED);
eoEvalFuncPtr<Indi, double, const vector<bool>& > eval( binary_value );
eoUniformGenerator<bool> uGen;
eoInitFixedLength<Indi> random(VEC_SIZE, uGen);
eoPop<Indi> pop(POP_SIZE, random);
apply<Indi>(eval, pop);
pop.sort();
cout << "Initial Population" << endl;
cout << pop;
eo1PtBitXover<Indi> xover1;
eoBitMutation<Indi> mutationBitFlip(P_MUT_PER_BIT);
eoGenContinue<Indi> genCont(MAX_GEN);
eoBestSelect <Indi> select ;
eoToricCellularEasyEA <Indi> gga (genCont,
eval,
select,
xover1,
mutationBitFlip,
select,
select) ;
cout << "\n Here we go\n\n";
gga(pop);
pop.sort();
cout << "FINAL Population\n" << pop << endl;
}
// A main that catches the exceptions
int main(int argc, char **argv)
{
#ifdef _MSC_VER
// rng.reseed(42);
int flag = _CrtSetDbgFlag(_CRTDBG_LEAK_CHECK_DF);
flag |= _CRTDBG_LEAK_CHECK_DF;
_CrtSetDbgFlag(flag);
// _CrtSetBreakAlloc(100);
#endif
try
{
main_function(argc, argv);
}
catch(exception& e)
{
cout << "Exception: " << e.what() << '\n';
}
return 1;
}