00001 /* 00002 <moNoFitImprSolContinue.h> 00003 Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2008 00004 (C) OPAC Team, LIFL, 2002-2008 00005 00006 Sébastien Cahon, Jean-Charles Boisson (Jean-Charles.Boisson@lifl.fr) 00007 00008 This software is governed by the CeCILL license under French law and 00009 abiding by the rules of distribution of free software. You can use, 00010 modify and/ or redistribute the software under the terms of the CeCILL 00011 license as circulated by CEA, CNRS and INRIA at the following URL 00012 "http://www.cecill.info". 00013 00014 As a counterpart to the access to the source code and rights to copy, 00015 modify and redistribute granted by the license, users are provided only 00016 with a limited warranty and the software's author, the holder of the 00017 economic rights, and the successive licensors have only limited liability. 00018 00019 In this respect, the user's attention is drawn to the risks associated 00020 with loading, using, modifying and/or developing or reproducing the 00021 software by the user in light of its specific status of free software, 00022 that may mean that it is complicated to manipulate, and that also 00023 therefore means that it is reserved for developers and experienced 00024 professionals having in-depth computer knowledge. Users are therefore 00025 encouraged to load and test the software's suitability as regards their 00026 requirements in conditions enabling the security of their systems and/or 00027 data to be ensured and, more generally, to use and operate it in the 00028 same conditions as regards security. 00029 The fact that you are presently reading this means that you have had 00030 knowledge of the CeCILL license and that you accept its terms. 00031 00032 ParadisEO WebSite : http://paradiseo.gforge.inria.fr 00033 Contact: paradiseo-help@lists.gforge.inria.fr 00034 */ 00035 00036 #ifndef _moNoFitImprSolContinue_h 00037 #define _moNoFitImprSolContinue_h 00038 00039 #include <moSolContinue.h> 00040 00042 00045 template < class EOT > 00046 class moNoFitImprSolContinue:public moSolContinue < EOT > 00047 { 00048 public: 00049 00051 typedef typename EOT::Fitness Fitness; 00052 00054 00057 moNoFitImprSolContinue (unsigned int _maxNumberOfIterationWithoutImprovement) 00058 : maxNumberOfIterationsWithoutImprovement(_maxNumberOfIterationWithoutImprovement), firstFitnessSaved(true), counter(0) 00059 {} 00060 00062 00067 bool operator () (const EOT & _solution) 00068 { 00069 if (_solution.invalid()) 00070 { 00071 throw std::runtime_error("[moNoFitImprSolContinue.h]: The current solution has not been evaluated."); 00072 } 00073 00074 if (firstFitnessSaved) 00075 { 00076 fitness=_solution.fitness(); 00077 counter=0; 00078 firstFitnessSaved=false; 00079 return true; 00080 } 00081 00082 counter++; 00083 00084 if ( _solution.fitness() > fitness) 00085 { 00086 fitness=_solution.fitness(); 00087 counter=0; 00088 } 00089 00090 if (counter==maxNumberOfIterationsWithoutImprovement) 00091 { 00092 std::cout << "[moNoFitImrpSolContinue.h]: Done [" << counter << "] iterations without improvement." << std::endl; 00093 } 00094 00095 return counter!=maxNumberOfIterationsWithoutImprovement; 00096 } 00097 00099 00102 void init () 00103 { 00104 firstFitnessSaved=true; 00105 counter=0; 00106 } 00107 00108 private: 00109 00111 unsigned int maxNumberOfIterationsWithoutImprovement; 00112 00114 bool firstFitnessSaved; 00115 00117 Fitness fitness; 00118 00120 unsigned int counter; 00121 }; 00122 00123 #endif
1.5.4