File: eoShiftMutation.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 (91 lines) | stat: -rw-r--r-- 2,545 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
90
91
// -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*-

//-----------------------------------------------------------------------------
// eoShiftMutation.h
// (c) GeNeura Team, 2000 - EEAAX 2000 - Maarten Keijzer 2000
// (c) INRIA Futurs - Dolphin Team - Thomas Legrand 2007
/*
    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
                 thomas.legrand@lifl.fr
             Marc.Schoenauer@polytechnique.fr
             mak@dhi.dk
 */
//-----------------------------------------------------------------------------

#ifndef eoShiftMutation_h
#define eoShiftMutation_h

//-----------------------------------------------------------------------------


/**
 * Shift two components of a chromosome.
 *
 * @ingroup Variators
 */
template<class EOT> class eoShiftMutation: public eoMonOp<EOT>
{
 public:

  typedef typename EOT::AtomType GeneType;

  /// CTor
  eoShiftMutation(){}


  /// The class name.
  virtual std::string className() const { return "eoShiftMutation"; }


  /**
   * Shift two components of the given eoosome.
   * @param _eo The cromosome which is going to be changed.
   */
  bool operator()(EOT& _eo)
    {

      unsigned i, j, from, to;
      GeneType tmp;

      // generate two different indices
      i=eo::rng.random(_eo.size());
      do j = eo::rng.random(_eo.size()); while (i == j);

      // indexes
      from=std::min(i,j);
      to=std::max(i,j);

      // keep the first component to change
      tmp=_eo[to];

      // shift
      for(unsigned int k=to ; k > from ; k--)
                _eo[k]=_eo[k-1];

      // shift the first component
      _eo[from]=tmp;

      return true;
    }

};
/** @example t-eoShiftMutation.cpp
 */


//-----------------------------------------------------------------------------
#endif