moeoContributionMetric.h

00001 /* 
00002 * <moeoContributionMetric.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 MOEOCONTRIBUTIONMETRIC_H_
00039 #define MOEOCONTRIBUTIONMETRIC_H_
00040 
00041 #include <comparator/moeoParetoObjectiveVectorComparator.h>
00042 #include <metric/moeoMetric.h>
00043 
00048 template < class ObjectiveVector >
00049 class moeoContributionMetric : public moeoVectorVsVectorBinaryMetric < ObjectiveVector, double >
00050 {
00051 public:
00052 
00058     double operator()(const std::vector < ObjectiveVector > & _set1, const std::vector < ObjectiveVector > & _set2) {
00059         unsigned int c  = card_C(_set1, _set2);
00060         unsigned int w1 = card_W(_set1, _set2);
00061         unsigned int n1 = card_N(_set1, _set2);
00062         unsigned int w2 = card_W(_set2, _set1);
00063         unsigned int n2 = card_N(_set2, _set1);
00064         return (double) (c / 2.0 + w1 + n1) / (c + w1 + n1 + w2 + n2);
00065     }
00066 
00067 
00068 private:
00069 
00071     moeoParetoObjectiveVectorComparator < ObjectiveVector > paretoComparator;
00072     
00073     
00079     unsigned int card_C (const std::vector < ObjectiveVector > & _set1, const std::vector < ObjectiveVector > & _set2) {
00080         unsigned int c=0;
00081         for (unsigned int i=0; i<_set1.size(); i++)
00082             for (unsigned int j=0; j<_set2.size(); j++)
00083                 if (_set1[i] == _set2[j]) {
00084                     c++;
00085                     break;
00086                 }
00087         return c;
00088     }
00089 
00090 
00096     unsigned int card_W (const std::vector < ObjectiveVector > & _set1, const std::vector < ObjectiveVector > & _set2) {
00097         unsigned int w=0;
00098         for (unsigned int i=0; i<_set1.size(); i++)
00099             for (unsigned int j=0; j<_set2.size(); j++)
00100                 if (paretoComparator(_set2[j], _set1[i]))
00101                 {
00102                     w++;
00103                     break;
00104                 }
00105         return w;
00106     }
00107 
00108 
00114     unsigned int card_N (const std::vector < ObjectiveVector > & _set1, const std::vector < ObjectiveVector > & _set2) {
00115         unsigned int n=0;
00116         for (unsigned int i=0; i<_set1.size(); i++) {
00117             bool domin_rel = false;
00118             for (unsigned int j=0; j<_set2.size(); j++)
00119                 if ( (paretoComparator(_set2[j], _set1[i])) || (paretoComparator(_set1[i], _set2[j])) )
00120                 {
00121                     domin_rel = true;
00122                     break;
00123                 }
00124             if (! domin_rel)
00125                 n++;
00126         }
00127         return n;
00128     }
00129 
00130 };
00131 
00132 #endif /*MOEOCONTRIBUTIONMETRIC_H_*/

Generated on Fri Oct 12 15:16:04 2007 for ParadisEO-MOEO:MultiObjectiveEvolvingObjects by  doxygen 1.4.7