00001 /* 00002 <moRandImprSelect.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 _moRandImprSelect_h 00037 #define _moRandImprSelect_h 00038 00039 #include <vector> 00040 #include <utils/eoRNG.h> 00041 #include <moMoveSelect.h> 00042 00044 00048 template < class M > 00049 class moRandImprSelect: public moMoveSelect < M > 00050 { 00051 public: 00052 00054 typedef typename M::EOType::Fitness Fitness; 00055 00057 00063 void init (const Fitness & _fitness) 00064 { 00065 initial_fitness = _fitness; 00066 better_fitnesses.clear(); 00067 better_moves.clear(); 00068 } 00069 00071 00079 bool update (const M & _move, const Fitness & _fitness) 00080 { 00081 00082 if (_fitness > initial_fitness) 00083 { 00084 better_fitnesses.push_back(_fitness); 00085 better_moves.push_back(_move); 00086 } 00087 00088 return true; 00089 } 00090 00092 00098 void operator () (M & _move, Fitness & _fitness) 00099 { 00100 unsigned int index; 00101 00102 index=0; 00103 00104 if( (better_fitnesses.size()==0) || (better_moves.size()==0) ) 00105 { 00106 throw std::runtime_error("[moRandImprSelect.h]: no move or/and no fitness already saved, update has to be called first."); 00107 } 00108 00109 index = rng.random (better_fitnesses.size ()); 00110 00111 _move = better_moves[index]; 00112 _fitness = better_fitnesses[index]; 00113 } 00114 00115 private: 00116 00118 Fitness initial_fitness; 00119 00121 std::vector < Fitness > better_fitnesses; 00122 00124 std::vector < M > better_moves; 00125 }; 00126 00127 #endif
1.5.4