moTS.h

00001 /*
00002   <moTS.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 _moTS_h
00037 #define _moTS_h
00038 
00039 #include <eoEvalFunc.h>
00040 
00041 #include <moAlgo.h>
00042 #include <moSolContinue.h>
00043 #include <moTSMoveLoopExpl.h>
00044 
00046 
00049 template < class M >
00050 class moTS:public moAlgo < typename M::EOType >
00051 {
00053   typedef typename M::EOType EOT;
00054 
00056   typedef typename EOT::Fitness  Fitness;
00057   
00058  public:
00059   
00061 
00072   moTS (moMoveInit < M > & _move_initializer, moNextMove < M > & _next_move_generator, 
00073         moMoveIncrEval < M > & _incremental_evaluation, moTabuList < M > & _tabu_list, 
00074         moAspirCrit < M > & _aspiration_criterion, moSolContinue < EOT > & _continue, 
00075         eoEvalFunc < EOT > & _full_evaluation): 
00076   move_explorer ( *new moTSMoveLoopExpl < M >(_move_initializer, _next_move_generator, _incremental_evaluation,
00077                                               _tabu_list,_aspiration_criterion) ),
00078     continu (_continue), full_evaluation (_full_evaluation)
00079   {}
00080   
00082 
00089   moTS (moMoveExpl < M > & _move_explorer, moSolContinue < EOT > & _continue, eoEvalFunc < EOT > & _full_evaluation):
00090   move_explorer (_move_explorer), continu (_continue), full_evaluation (_full_evaluation)
00091   {}
00092   
00094 
00102   bool operator ()(EOT & _solution)
00103   {
00104     M move;
00105     
00106     EOT best_solution, new_solution;
00107 
00108     if ( _solution.invalid () )
00109       {
00110         full_evaluation (_solution);
00111       }
00112     
00113     best_solution=_solution;
00114 
00115     // code used for avoiding warning because new_solution is indirectly initialized by move_expl.
00116     new_solution=_solution;
00117     
00118     continu.init ();
00119 
00120     do
00121       {
00122         move_explorer (_solution, new_solution);
00123         
00124         // Updating the best solution found until now ?
00125         if (new_solution.fitness() > _solution.fitness())
00126           {
00127             best_solution = new_solution;
00128           }
00129         
00130         _solution = new_solution;
00131       }
00132     while ( continu (_solution) );
00133 
00134     _solution = best_solution;
00135 
00136     return true;
00137   }
00138 
00139  private:
00140 
00142   moMoveExpl < M > & move_explorer;
00143 
00145   moSolContinue < EOT > & continu;
00146 
00148   eoEvalFunc < EOT > & full_evaluation;
00149 };
00150 
00151 #endif

Generated on Wed Jan 16 15:50:40 2008 for ParadisEO-MOMovingObjects by  doxygen 1.5.4