00001 /* 00002 * <moeoBinaryMetricSavingUpdater.h> 00003 * Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2007 00004 * (C) OPAC Team, LIFL, 2002-2007 00005 * 00006 * Sebastien Cahon, Arnaud Liefooghe 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 //----------------------------------------------------------------------------- 00037 00038 #ifndef MOEOBINARYMETRICSAVINGUPDATER_H_ 00039 #define MOEOBINARYMETRICSAVINGUPDATER_H_ 00040 00041 #include <fstream> 00042 #include <string> 00043 #include <vector> 00044 #include <eoPop.h> 00045 #include <utils/eoUpdater.h> 00046 #include <metric/moeoMetric.h> 00047 00052 template < class MOEOT > 00053 class moeoBinaryMetricSavingUpdater : public eoUpdater 00054 { 00055 public: 00056 00058 typedef typename MOEOT::ObjectiveVector ObjectiveVector; 00059 00060 00067 moeoBinaryMetricSavingUpdater (moeoVectorVsVectorBinaryMetric < ObjectiveVector, double > & _metric, const eoPop < MOEOT > & _pop, std::string _filename) : 00068 metric(_metric), pop(_pop), filename(_filename), counter(1) 00069 {} 00070 00071 00075 void operator()() { 00076 if (pop.size()) { 00077 if (firstGen) { 00078 firstGen = false; 00079 } 00080 else { 00081 // creation of the two Pareto sets 00082 std::vector < ObjectiveVector > from; 00083 std::vector < ObjectiveVector > to; 00084 for (unsigned int i=0; i<pop.size(); i++) 00085 from.push_back(pop[i].objectiveVector()); 00086 for (unsigned int i=0 ; i<oldPop.size(); i++) 00087 to.push_back(oldPop[i].objectiveVector()); 00088 // writing the result into the file 00089 std::ofstream f (filename.c_str(), std::ios::app); 00090 f << counter++ << ' ' << metric(from,to) << std::endl; 00091 f.close(); 00092 } 00093 oldPop = pop; 00094 } 00095 } 00096 00097 00098 private: 00099 00101 moeoVectorVsVectorBinaryMetric < ObjectiveVector, double > & metric; 00103 const eoPop < MOEOT > & pop; 00105 eoPop< MOEOT > oldPop; 00107 std::string filename; 00109 bool firstGen; 00111 unsigned int counter; 00112 00113 }; 00114 00115 #endif /*MOEOBINARYMETRICSAVINGUPDATER_H_*/
1.4.7