File: eoPropGAGenOp.h

package info (click to toggle)
gamera 1%3A3.4.2%2Bgit20160808.1725654-1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 22,312 kB
  • ctags: 24,991
  • sloc: xml: 122,324; ansic: 52,869; cpp: 50,664; python: 35,034; makefile: 118; sh: 101
file content (89 lines) | stat: -rw-r--r-- 2,738 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
// -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*-

//-----------------------------------------------------------------------------
// eoPropGAGenOp.h
// (c) Marc.Schoenauer 2005
/*
    This library is free software; you can redistribute it and/or
    modify it under the terms of the GNU Lesser General Public
    License as published by the Free Software Foundation; either
    version 2 of the License, or (at your option) any later version.

    This library is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
    Lesser General Public License for more details.

    You should have received a copy of the GNU Lesser General Public
    License along with this library; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

    Contact: todos@geneura.ugr.es, http://geneura.ugr.es
             Marc.Schoenauer@inria.fr
             mak@dhi.dk
 */
//-----------------------------------------------------------------------------

#ifndef _eoPropGAGenOp_h
#define _eoPropGAGenOp_h

#include "eoGenOp.h"
#include "eoInvalidateOps.h"
///////////////////////////////////////////////////////////////////////////////
// class eoSGAGenOp
///////////////////////////////////////////////////////////////////////////////

/**
 * eoPropGAGenOp (for Simple GA, but Proportional)
 * choice between Crossover, mutation or cloining
 * with respect to given relatve weights
 *
 * @ingroup Combination
 */
template<class EOT>
class eoPropGAGenOp : public eoGenOp<EOT>
{
 public:

  /** Ctor from
   *   * weight of clone
   *   * crossover (with weight)
   *   * mutation (with weight)
   */
  eoPropGAGenOp(double _wClone, eoQuadOp<EOT>& _cross, double _wCross,
                 eoMonOp<EOT>& _mut, double _wMut)
    : wClone(_wClone),
      cross(_cross),
      wCross(_wCross),
      mut(_mut),
      wMut(_wMut)
  {
    propOp.add(cross, wCross); // the crossover - with weight wCross
    propOp.add(mut, wMut); // mutation with weight wMut
    propOp.add(monClone, wClone);
  }

  /** do the job: delegate to op */
  virtual void apply(eoPopulator<EOT>& _pop)
  {
    propOp.apply(_pop);
  }

  /** inherited from eoGenOp */
  virtual unsigned max_production(void) {return 2;}

  virtual std::string className() const {return "eoPropGAGenOp";}


 private:
  double wClone;
  eoQuadOp<EOT> &cross;   // eoInvalidateXXX take the boolean output
  double wCross;
  eoMonOp<EOT> & mut;      // of the XXX op and invalidate the EOT
  double wMut;
  eoProportionalOp<EOT> propOp;
  eoMonCloneOp<EOT> monClone;
};


#endif