moeoFrontByFrontSharingDiversityAssignment.h

00001 /* 
00002 * <moeoFrontByFrontSharingDiversityAssignment.h>
00003 * Copyright (C) DOLPHIN Project-Team, INRIA Futurs, 2006-2007
00004 * (C) OPAC Team, LIFL, 2002-2007
00005 *
00006 * 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 MOEOFRONTBYFRONTSHARINGDIVERSITYASSIGNMENT_H_
00039 #define MOEOFRONTBYFRONTSHARINGDIVERSITYASSIGNMENT_H_
00040 
00041 #include <diversity/moeoSharingDiversityAssignment.h>
00042 
00046 template < class MOEOT >
00047 class moeoFrontByFrontSharingDiversityAssignment : public moeoSharingDiversityAssignment < MOEOT >
00048 {
00049 public:
00050 
00052     typedef typename MOEOT::ObjectiveVector ObjectiveVector;
00053 
00054 
00061     moeoFrontByFrontSharingDiversityAssignment(moeoDistance<MOEOT,double> & _distance, double _nicheSize = 0.5, double _alpha = 2.0) : moeoSharingDiversityAssignment < MOEOT >(_distance, _nicheSize, _alpha)
00062     {}
00063 
00064 
00070     moeoFrontByFrontSharingDiversityAssignment(double _nicheSize = 0.5, double _alpha = 2.0) : moeoSharingDiversityAssignment < MOEOT >(_nicheSize, _alpha)
00071     {}
00072 
00073 
00081     void updateByDeleting(eoPop < MOEOT > & _pop, ObjectiveVector & _objVec)
00082     {
00083         std::cout << "WARNING : updateByDeleting not implemented in moeoSharingDiversityAssignment" << std::endl;
00084     }
00085 
00086 
00087 private:
00088 
00089     using moeoSharingDiversityAssignment < MOEOT >::distance;
00090     using moeoSharingDiversityAssignment < MOEOT >::nicheSize;
00091     using moeoSharingDiversityAssignment < MOEOT >::sh;
00092     using moeoSharingDiversityAssignment < MOEOT >::operator();
00093 
00094 
00099     void setSimilarities(eoPop < MOEOT > & _pop)
00100     {
00101         // compute distances between every individuals
00102         moeoDistanceMatrix < MOEOT , double > dMatrix (_pop.size(), distance);
00103         dMatrix(_pop);
00104         // sets the distance to bigger than the niche size for every couple of solutions that do not belong to the same front
00105         for (unsigned int i=0; i<_pop.size(); i++)
00106         {
00107             for (unsigned int j=0; j<i; j++)
00108             {
00109                 if (_pop[i].fitness() != _pop[j].fitness())
00110                 {
00111                     dMatrix[i][j] = nicheSize;
00112                     dMatrix[j][i] = nicheSize;
00113                 }
00114             }
00115         }
00116         // compute similarities
00117         double sum;
00118         for (unsigned int i=0; i<_pop.size(); i++)
00119         {
00120             sum = 0.0;
00121             for (unsigned int j=0; j<_pop.size(); j++)
00122             {
00123                 sum += sh(dMatrix[i][j]);
00124             }
00125             _pop[i].diversity(sum);
00126         }
00127     }
00128 
00129 };
00130 
00131 #endif /*MOEOFRONTBYFRONTSHARINGDIVERSITYASSIGNMENT_H_*/

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