00001 // -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*- 00002 00003 // "part_route_eval.cpp" 00004 00005 // (c) OPAC Team, LIFL, 2003 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: cahon@lifl.fr 00022 */ 00023 00024 #include "part_route_eval.h" 00025 #include "node.h" 00026 00027 PartRouteEval :: PartRouteEval (float __from, 00028 float __to 00029 ) : from (__from), 00030 to (__to) { 00031 00032 } 00033 00034 void PartRouteEval :: operator () (Route & __route) { 00035 00036 00037 unsigned len = 0 ; 00038 00039 for (unsigned i = (unsigned) (__route.size () * from) ; 00040 i < (unsigned) (__route.size () * to) ; 00041 i ++) 00042 len += distance (__route [i], __route [(i + 1) % numNodes]) ; 00043 00044 __route.fitness (- (int) len) ; 00045 }
1.4.7