#include #include typedef eoRealParticle < double >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 ); const unsigned int VEC_SIZE = 2; const unsigned int POP_SIZE = 20; const unsigned int NEIGHBORHOOD_SIZE= 6; const unsigned int MAX_GEN = 100; const double INIT_POSITION_MIN = -2.0; const double INIT_POSITION_MAX = 2.0; const double INIT_VELOCITY_MIN = -1.; const double INIT_VELOCITY_MAX = 1.; const unsigned int MIG_FREQ = 10; const double omega = 1; const double C1 = 0.5; const double C2 = 2.; rng.reseed (time(0)); // Island model RingTopology topologyMig; // First eoGenContinue < Indi > genContPara (MAX_GEN); eoCombinedContinue continuatorPara (genContPara); eoCheckPoint checkpoint(continuatorPara); peoEvalFunc plainEval(f); peoPopEval< Indi > eval(plainEval); eoUniformGenerator < double >uGen (INIT_POSITION_MIN, INIT_POSITION_MAX); eoInitFixedLength < Indi > random (VEC_SIZE, uGen); eoUniformGenerator < double >sGen (INIT_VELOCITY_MIN, INIT_VELOCITY_MAX); eoVelocityInitFixedLength < Indi > veloRandom (VEC_SIZE, sGen); eoFirstIsBestInit < Indi > localInit; eoRealVectorBounds bndsFlight(VEC_SIZE,INIT_POSITION_MIN,INIT_POSITION_MAX); eoStandardFlight < Indi > flight(bndsFlight); peoPop < Indi > pop; pop.append (POP_SIZE, random); eoLinearTopology topology(NEIGHBORHOOD_SIZE); eoRealVectorBounds bnds(VEC_SIZE,INIT_VELOCITY_MIN,INIT_VELOCITY_MAX); eoStandardVelocity < Indi > velocity (topology,omega,C1,C2,bnds); eoInitializer init(eval,veloRandom,localInit,topology,pop); // Island model eoPeriodicContinue< Indi > mig_cont( MIG_FREQ ); peoPSOSelect mig_selec(topology); peoWorstPositionReplacement mig_replac; // Specific implementation (peoData.h) eoContinuator cont(mig_cont, pop); eoSelector > mig_select (mig_selec,1,pop); eoReplace > mig_replace (mig_replac,pop); // Second eoGenContinue < Indi > genContPara2 (MAX_GEN); eoCombinedContinue continuatorPara2 (genContPara2); eoCheckPoint checkpoint2(continuatorPara2); peoEvalFunc plainEval2(f); peoPopEval< Indi > eval2(plainEval2); eoUniformGenerator < double >uGen2 (INIT_POSITION_MIN, INIT_POSITION_MAX); eoInitFixedLength < Indi > random2 (VEC_SIZE, uGen2); eoUniformGenerator < double >sGen2 (INIT_VELOCITY_MIN, INIT_VELOCITY_MAX); eoVelocityInitFixedLength < Indi > veloRandom2 (VEC_SIZE, sGen2); eoFirstIsBestInit < Indi > localInit2; eoRealVectorBounds bndsFlight2(VEC_SIZE,INIT_POSITION_MIN,INIT_POSITION_MAX); eoStandardFlight < Indi > flight2(bndsFlight2); peoPop < Indi > pop2; pop2.append (POP_SIZE, random2); eoLinearTopology topology2(NEIGHBORHOOD_SIZE); eoRealVectorBounds bnds2(VEC_SIZE,INIT_VELOCITY_MIN,INIT_VELOCITY_MAX); eoStandardVelocity < Indi > velocity2 (topology2,omega,C1,C2,bnds2); eoInitializer init2(eval2,veloRandom2,localInit2,topology2,pop2); // Island model eoPeriodicContinue< Indi > mig_cont2( MIG_FREQ ); peoPSOSelect mig_selec2(topology2); peoWorstPositionReplacement mig_replac2; // Specific implementation (peoData.h) eoContinuator cont2(mig_cont2,pop2); eoSelector > mig_select2 (mig_selec2,1,pop2); eoReplace > mig_replace2 (mig_replac2,pop2); // Island model peoAsyncIslandMig< Indi, peoPop > mig(cont,mig_select, mig_replace, topologyMig, pop, pop); checkpoint.add( mig ); peoAsyncIslandMig< Indi, peoPop > mig2(cont2,mig_select2, mig_replace2, topologyMig, pop2, pop2); checkpoint2.add( mig2 ); // Parallel algorithm eoSyncEasyPSO psa(init,checkpoint,eval, velocity, flight); peoWrapper parallelPSO( psa, pop); eval.setOwner(parallelPSO); mig.setOwner(parallelPSO); eoSyncEasyPSO psa2(init2,checkpoint2,eval2, velocity2, flight2); peoWrapper parallelPSO2( psa2, pop2); eval2.setOwner(parallelPSO2); mig2.setOwner(parallelPSO2); peo :: run(); peo :: finalize(); if (getNodeRank()==1) { std::cout << "Final population :\n" << pop << std::endl; std::cout << "Final population :\n" << pop2 << std::endl; } }