Robot Simulator of the Robotics Group for Self-Organization of Control  0.8.0
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
IMutationFactorStrategy.h
Go to the documentation of this file.
1 /***************************************************************************
2  * Copyright (C) 2008-2011 LpzRobots development team *
3  * Joerg Weider <joergweide84 at aol dot com> (robot12) *
4  * Georg Martius <georg dot martius at web dot de> *
5  * Frank Guettler <guettler at informatik dot uni-leipzig dot de *
6  * Frank Hesse <frank at nld dot ds dot mpg dot de> *
7  * Ralf Der <ralfder at mis dot mpg dot de> *
8  * Joern Hoffmann <jhoffmann at informatik dot uni-leipzig dot de *
9  * *
10  * This program is free software; you can redistribute it and/or modify *
11  * it under the terms of the GNU General Public License as published by *
12  * the Free Software Foundation; either version 2 of the License, or *
13  * (at your option) any later version. *
14  * *
15  * This program is distributed in the hope that it will be useful, *
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of *
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
18  * GNU General Public License for more details. *
19  * *
20  * You should have received a copy of the GNU General Public License *
21  * along with this program; if not, write to the *
22  * Free Software Foundation, Inc., *
23  * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
24  * *
25  ***************************************************************************/
26 
27 #ifndef IMUTATIONFACTORSTRATEGY_H_
28 #define IMUTATIONFACTORSTRATEGY_H_
29 
30 //includes
31 #include <vector>
32 
33 //forward declarations
34 class Gen;
35 class IValue;
36 
37 /**
38  * This is a interface for a strategy, which is used by ValueMutationStrategy
39  */
41 public:
42  /**
43  * default constructor
44  */
46 
47  /**
48  * default destructor
49  */
50  virtual ~IMutationFactorStrategy();
51 
52  /**
53  * this abstract function should later calculate the new mutation factor.
54  * It use for this a set gens. Most the gens which for one prototyp in one generation are.
55  * @param gene (vector<Gen*>) this set of gens
56  * @return (IValue*) the mutation factor
57  */
58  virtual IValue* calcMutationFactor(const std::vector<Gen*>& gene) = 0;
59 };
60 
61 #endif /* IMUTATIONFACTORSTRATEGY_H_ */
The Gen class.
Definition: Gen.h:51
This is a interface for a strategy, which is used by ValueMutationStrategy.
Definition: IMutationFactorStrategy.h:40
IMutationFactorStrategy()
default constructor
Definition: IMutationFactorStrategy.cpp:29
virtual IValue * calcMutationFactor(const std::vector< Gen * > &gene)=0
this abstract function should later calculate the new mutation factor.
This class is a interface for a value which is part of a gen.
Definition: IValue.h:38
virtual ~IMutationFactorStrategy()
default destructor
Definition: IMutationFactorStrategy.cpp:33