two_opt_incr_eval.cpp

00001 // -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*-
00002 
00003 // "TwoOptIncrEval.cpp"
00004 
00005 // (c) OPAC Team, LIFL, January 2006
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: paradiseo-help@lists.gforge.inria.fr
00022 */
00023 
00024 #include "two_opt_incr_eval.h"
00025 #include "node.h"
00026 
00027 int TwoOptIncrEval :: operator () (const TwoOpt & __move, const Route & __route) {
00028   
00029   /* From */
00030   Node v1 = __route [__move.first], v1_left = __route [(__move.first - 1 + numNodes) % numNodes];
00031   
00032   /* To */
00033   Node v2 = __route [__move.second], v2_right = __route [(__move.second + 1) % numNodes];
00034  
00035   if (v1 == v2 || v2_right == v1)
00036     return __route.fitness ();
00037   else 
00038     return __route.fitness () - distance (v1_left, v2) - distance (v1, v2_right) + distance (v1_left, v1) + distance (v2, v2_right);
00039 }

Generated on Sat Dec 30 14:55:34 2006 for ParadisEO-PEO - Lessons by  doxygen 1.4.7