EvolvingObjects
|
00001 // -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*- 00002 00003 //----------------------------------------------------------------------------- 00004 // eoFitContinue.h 00005 // (c) Maarten Keijzer, GeNeura Team, 1999, 2000 00006 /* 00007 This library is free software; you can redistribute it and/or 00008 modify it under the terms of the GNU Lesser General Public 00009 License as published by the Free Software Foundation; either 00010 version 2 of the License, or (at your option) any later version. 00011 00012 This library is distributed in the hope that it will be useful, 00013 but WITHOUT ANY WARRANTY; without even the implied warranty of 00014 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00015 Lesser General Public License for more details. 00016 00017 You should have received a copy of the GNU Lesser General Public 00018 License along with this library; if not, write to the Free Software 00019 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00020 00021 Contact: todos@geneura.ugr.es, http://geneura.ugr.es 00022 */ 00023 //----------------------------------------------------------------------------- 00024 00025 #ifndef _eoFitContinue_h 00026 #define _eoFitContinue_h 00027 00028 #include <eoContinue.h> 00029 #include <utils/eoLogger.h> 00030 00038 template< class EOT> 00039 class eoFitContinue: public eoContinue<EOT> { 00040 public: 00041 00043 typedef typename EOT::Fitness FitnessType; 00044 00046 eoFitContinue( const FitnessType _optimum) 00047 : eoContinue<EOT> (), optimum( _optimum ) {}; 00048 00050 virtual bool operator() ( const eoPop<EOT>& _pop ) 00051 { 00052 //FitnessType bestCurrentFitness = _pop.nth_element_fitness(0); 00053 FitnessType bestCurrentFitness = _pop.best_element().fitness(); 00054 if (bestCurrentFitness >= optimum) 00055 { 00056 eo::log << eo::logging << "STOP in eoFitContinue: Best fitness has reached " << 00057 bestCurrentFitness << "\n"; 00058 return false; 00059 } 00060 return true; 00061 } 00062 00063 virtual std::string className(void) const { return "eoFitContinue"; } 00064 00065 private: 00066 FitnessType optimum; 00067 }; 00068 00069 #endif