00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037 #ifndef __moTSMoveLoopExpl_h
00038 #define __moTSMoveLoopExpl_h
00039
00040 #include "moMoveLoopExpl.h"
00041
00042 #include "moMoveInit.h"
00043 #include "moNextMove.h"
00044 #include "moMoveIncrEval.h"
00045 #include "moMoveSelect.h"
00046
00047 #include "moTabuList.h"
00048 #include "moAspirCrit.h"
00049 #include "moBestImprSelect.h"
00050
00052
00055 template < class M > class moTSMoveLoopExpl:public moMoveLoopExpl < M >
00056 {
00057
00059 typedef typename M::EOType EOT;
00060
00062 typedef typename M::EOType::Fitness Fitness;
00063
00064 public:
00065
00067
00074 moTSMoveLoopExpl (moMoveInit < M > &__move_init, moNextMove < M > &__next_move, moMoveIncrEval < M > &__incr_eval, moTabuList < M > &__tabu_list, moAspirCrit < M > &__aspir_crit):
00075 move_init (__move_init),
00076 next_move (__next_move),
00077 incr_eval (__incr_eval),
00078 tabu_list (__tabu_list), aspir_crit (__aspir_crit)
00079 {
00080
00081 tabu_list.init ();
00082 aspir_crit.init ();
00083 }
00084
00086
00094 void operator () (const EOT & __old_sol, EOT & __new_sol)
00095 {
00096
00097 M move;
00098
00099
00100 move_init (move, __old_sol);
00101
00102
00103 move_select.init (__old_sol.fitness ());
00104
00105 do
00106 {
00107
00108 Fitness fit = incr_eval (move, __old_sol);
00109
00110 if (!tabu_list (move, __old_sol) || aspir_crit (move, fit))
00111 {
00112 if (!move_select.update (move, fit))
00113 break;
00114 }
00115
00116 }
00117 while (next_move (move, __old_sol));
00118
00119 M best_move;
00120
00121 Fitness best_move_fit;
00122
00123 move_select (best_move, best_move_fit);
00124
00125 __new_sol.fitness (best_move_fit);
00126 best_move (__new_sol);
00127
00128
00129
00130 tabu_list.update ();
00131
00132
00133 tabu_list.add (best_move, __new_sol);
00134 }
00135
00136 private:
00137
00139 moMoveInit < M > &move_init;
00140
00142 moNextMove < M > &next_move;
00143
00145 moMoveIncrEval < M > &incr_eval;
00146
00148 moBestImprSelect < M > move_select;
00149
00151 moTabuList < M > &tabu_list;
00152
00154 moAspirCrit < M > &aspir_crit;
00155 };
00156
00157 #endif