00001 /*************************************************************************** 00002 * Copyright (C) 2005-2009 by Robot Group Leipzig * 00003 * martius@informatik.uni-leipzig.de * 00004 * fhesse@informatik.uni-leipzig.de * 00005 * der@informatik.uni-leipzig.de * 00006 * guettler@informatik.uni-leipzig.de * 00007 * jhoffmann@informatik.uni-leipzig.de * 00008 * joergweide84@aol.com (robot12) * 00009 * * 00010 * This program is free software; you can redistribute it and/or modify * 00011 * it under the terms of the GNU General Public License as published by * 00012 * the Free Software Foundation; either version 2 of the License, or * 00013 * (at your option) any later version. * 00014 * * 00015 * This program is distributed in the hope that it will be useful, * 00016 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 00018 * GNU General Public License for more details. * 00019 * * 00020 * You should have received a copy of the GNU General Public License * 00021 * along with this program; if not, write to the * 00022 * Free Software Foundation, Inc., * 00023 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * 00024 *************************************************************************** 00025 * * 00026 * This is a interface for a strategy which is part of the mutation * 00027 * strategy. It calculate the factor for the mutation. To this time it is* 00028 * only used by ValueMutationStrategy. * 00029 * * 00030 * $Log: IMutationFactorStrategy.h,v $ 00031 * Revision 1.3 2009/07/21 08:37:59 robot12 00032 * add some comments 00033 * 00034 * Revision 1.2 2009/06/17 11:11:06 robot12 00035 * finishing the mutationfactorstrategy and add some comments. 00036 * 00037 * Revision 1.1 2009/05/04 15:27:55 robot12 00038 * rename of some files and moving files to other positions 00039 * - SingletonGenAlgAPI has one error!!! --> is not ready now 00040 * 00041 * Revision 1.2 2009/04/28 13:23:55 robot12 00042 * some implements... Part2 00043 * 00044 * Revision 1.1 2009/04/27 10:59:34 robot12 00045 * some implements 00046 * 00047 * 00048 ***************************************************************************/ 00049 00050 #ifndef IMUTATIONFACTORSTRATEGY_H_ 00051 #define IMUTATIONFACTORSTRATEGY_H_ 00052 00053 //includes 00054 #include <vector> 00055 00056 //forward declarations 00057 class Gen; 00058 class IValue; 00059 00060 /** 00061 * This is a interface for a strategy, which is used by ValueMutationStrategy 00062 */ 00063 class IMutationFactorStrategy { 00064 public: 00065 /** 00066 * default constructor 00067 */ 00068 IMutationFactorStrategy(); 00069 00070 /** 00071 * default destructor 00072 */ 00073 virtual ~IMutationFactorStrategy(); 00074 00075 /** 00076 * this abstract function should later calculate the new mutation factor. 00077 * It use for this a set gens. Most the gens which for one prototyp in one generation are. 00078 * @param gene (vector<Gen*>) this set of gens 00079 * @return (IValue*) the mutation factor 00080 */ 00081 virtual IValue* calcMutationFactor(const std::vector<Gen*>& gene) = 0; 00082 }; 00083 00084 #endif /* IMUTATIONFACTORSTRATEGY_H_ */