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 }
1.4.7