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
ExtreamTestFitnessStrategy.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 EXTREAMTESTFITNESSSTRATEGY_H_
28 #define EXTREAMTESTFITNESSSTRATEGY_H_
29 
30 //forward declaration
31 class Individual;
32 
33 //ga_tools includes
34 #include "IFitnessStrategy.h"
35 
36 /**
37  * An example implementation and a extreme test for gen. Alg.
38  */
40 public:
41  /**
42  * constructor
43  * This strategy needs a other fitness strategy to calculate the resulting fitness.
44  * @param fitness (IFitnessStrategy*) the other fitness
45  */
47 
48  /**
49  * default destructor
50  * do nothing
51  */
53 
54  /**
55  * implementation for getFitness of IFitnessStrategy.
56  * return aČ of the other fitness strategy if the value is lower than 10.
57  * Else it return 100.
58  * @param individual (const Indivual*) the individual for which the value is calculated
59  * @return (double) the result
60  */
61  virtual double getFitness(const Individual* individual);
62 
63 private:
64  /**
65  * a other fitness strategy which is used as base calculation.
66  */
67  IFitnessStrategy* m_strategy;
68 
69  /**
70  * disable the default constructor
71  */
73 };
74 
75 #endif /* EXTREAMTESTFITNESSSTRATEGY_H_ */
The interface for the fitness strategy of an individual.
Definition: IFitnessStrategy.h:36
An example implementation and a extreme test for gen.
Definition: ExtreamTestFitnessStrategy.h:39
This class represent one individual of the complete gen.
Definition: Individual.h:45
virtual double getFitness(const Individual *individual)
implementation for getFitness of IFitnessStrategy.
Definition: ExtreamTestFitnessStrategy.cpp:44
virtual ~ExtreamTestFitnessStrategy()
default destructor do nothing
Definition: ExtreamTestFitnessStrategy.cpp:38