#include #include typedef eoReal Indi; double f (const Indi & _indi) { double sum; sum=_indi[1]-pow(_indi[0],2); sum=100*pow(sum,2); sum+=pow((1-_indi[0]),2); return (-sum); } int main( int __argc, char** __argv ) { peo :: init( __argc, __argv ); // Parameters const unsigned int VEC_SIZE = 2; const unsigned int POP_SIZE = 20; const unsigned int MAX_GEN = 300; const double INIT_POSITION_MIN = -2.0; const double INIT_POSITION_MAX = 2.0; const float CROSS_RATE = 0.8; const double EPSILON = 0.01; const float MUT_RATE = 0.5; const unsigned MIG_FREQ = 10; const unsigned int MIG_SIZE = 5; rng.reseed (time(0)); RingTopology topology; // Algorithm eoGenContinue < Indi > genContPara (MAX_GEN); eoCombinedContinue continuatorPara (genContPara); eoCheckPoint checkpoint(continuatorPara); peoEvalFunc mainEval( f ); peoPopEval eval(mainEval); eoUniformGenerator < double >uGen (INIT_POSITION_MIN, INIT_POSITION_MAX); eoInitFixedLength < Indi > random (VEC_SIZE, uGen); eoRankingSelect selectionStrategy; eoSelectNumber select(selectionStrategy,POP_SIZE); eoSegmentCrossover crossover; eoUniformMutation mutation(EPSILON); peoTransform transform(crossover,CROSS_RATE,mutation,MUT_RATE); peoPop < Indi > pop; pop.append (POP_SIZE, random); eoPlusReplacement replace; eoRandomSelect mig_select_one; eoSelector > mig_select (mig_select_one,MIG_SIZE,pop); eoReplace > mig_replace (replace,pop); peoSyncIslandMig > mig(MIG_FREQ,mig_select,mig_replace,topology,pop,pop); checkpoint.add(mig); eoEasyEA< Indi > eaAlg( checkpoint, eval, select, transform, replace ); // Algorithm eoGenContinue < Indi > genContPara2 (MAX_GEN); eoCombinedContinue continuatorPara2 (genContPara2); eoCheckPoint checkpoint2(continuatorPara2); peoEvalFunc mainEval2( f ); peoPopEval eval2(mainEval2); eoUniformGenerator < double >uGen2 (INIT_POSITION_MIN, INIT_POSITION_MAX); eoInitFixedLength < Indi > random2 (VEC_SIZE, uGen2); eoRankingSelect selectionStrategy2; eoSelectNumber select2(selectionStrategy2,POP_SIZE); eoSegmentCrossover crossover2; eoUniformMutation mutation2(EPSILON); peoTransform transform2(crossover2,CROSS_RATE,mutation2,MUT_RATE); peoPop < Indi > pop2; pop2.append (POP_SIZE, random2); eoPlusReplacement replace2; eoRandomSelect mig_select_one2; eoSelector > mig_select2 (mig_select_one2,MIG_SIZE,pop2); eoReplace > mig_replace2 (replace2,pop2); peoSyncIslandMig > mig2(MIG_FREQ,mig_select2,mig_replace2,topology,pop2,pop2); checkpoint2.add(mig2); eoEasyEA< Indi > eaAlg2( checkpoint2, eval2, select2, transform2, replace2 ); peoWrapper parallelEA( eaAlg, pop); eval.setOwner(parallelEA); transform.setOwner(parallelEA); mig.setOwner(parallelEA); peoWrapper parallelEA2( eaAlg2, pop2); eval2.setOwner(parallelEA2); transform2.setOwner(parallelEA2); mig2.setOwner(parallelEA2); peo :: run(); peo :: finalize(); if (getNodeRank()==1) { pop.sort(); std::cout << "Final population :\n" << pop << std::endl; } }