/** -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*- ----------------------------------------------------------------------------- eoPopEvalFunc.h Abstract class for global evaluation of the population (c) GeNeura Team, 2000 This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA Contact: todos@geneura.ugr.es, http://geneura.ugr.es */ //----------------------------------------------------------------------------- #ifndef eoPopEvalFunc_H #define eoPopEvalFunc_H #include #include /** eoPopEvalFunc: This abstract class is for GLOBAL evaluators * of a population after variation. * It takes 2 populations (typically the parents and the offspring) * and is suppposed to evaluate them alltogether * * Basic use: apply an embedded eoEvalFunc to the offspring * * Time-varying fitness: apply the embedded eoEvalFunc to both * offspring and parents * * Advanced uses: Co-evolution or "parisian" approach, or ... * * Basic parallelization (synchronous standard evolution engine): * call the slaves and wait for the results * * @ingroup Evaluation */ template class eoPopEvalFunc : public eoBF & , eoPop &, void> {}; ///////////////////////////////////////////////////////////// // eoPopLoopEval ///////////////////////////////////////////////////////////// /** eoPopLoopEval: an instance of eoPopEvalFunc that simply applies * a private eoEvalFunc to all offspring * * @ingroup Evaluation */ template class eoPopLoopEval : public eoPopEvalFunc { public: /** Ctor: set value of embedded eoEvalFunc */ eoPopLoopEval(eoEvalFunc & _eval) : eval(_eval) {} /** Do the job: simple loop over the offspring */ void operator()(eoPop & _parents, eoPop & _offspring) { (void)_parents; apply(eval, _offspring); } private: eoEvalFunc & eval; }; #ifdef WITH_MPI // TODO TODOB commenter template class eoParallelPopLoopEval : public eoPopEvalFunc { public: /** Ctor: set value of embedded eoEvalFunc */ eoParallelPopLoopEval( // Job parameters eo::mpi::AssignmentAlgorithm& _assignAlgo, int _masterRank, // Default parameters for store eoEvalFunc & _eval, int _packetSize = 1 ) : assignAlgo( _assignAlgo ), masterRank( _masterRank ), needToDeleteStore( true ) { store = new eo::mpi::ParallelEvalStore( _eval, _masterRank, _packetSize ); } eoParallelPopLoopEval( // Job parameters eo::mpi::AssignmentAlgorithm& _assignAlgo, int _masterRank, eo::mpi::ParallelEvalStore* _store ) : assignAlgo( _assignAlgo ), masterRank( _masterRank ), store( _store ), needToDeleteStore( false ) { // empty } ~eoParallelPopLoopEval() { if( eo::mpi::Node::comm().rank() == masterRank ) { eo::mpi::EmptyJob job( assignAlgo, masterRank ); job.run(); } if( needToDeleteStore ) { delete store; } } /** Do the job: simple loop over the offspring */ void operator()( eoPop & _parents, eoPop & _offspring ) { (void)_parents; parallelApply(_offspring, assignAlgo, masterRank, *store); } private: eo::mpi::AssignmentAlgorithm & assignAlgo; int masterRank; eo::mpi::ParallelEvalStore* store; bool needToDeleteStore; }; #endif ///////////////////////////////////////////////////////////// // eoTimeVaryingLoopEval ///////////////////////////////////////////////////////////// /** eoPopLoopEval: an instance of eoPopEvalFunc that simply applies * a private eoEvalFunc to all offspring AND ALL PARENTS * as the fitness is supposed here to vary * * @ingroup Evaluation */ template class eoTimeVaryingLoopEval : public eoPopEvalFunc { public: /** Ctor: set value of embedded eoEvalFunc */ eoTimeVaryingLoopEval(eoEvalFunc & _eval) : eval(_eval) {} /** Do the job: simple loop over the offspring */ void operator()(eoPop & _parents, eoPop & _offspring) { apply(eval, _parents); apply(eval, _offspring); } private: eoEvalFunc & eval; }; #endif