68 lines
1.7 KiB
C++
68 lines
1.7 KiB
C++
/** -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*-
|
|
|
|
The above line is useful in Emacs-like editors
|
|
*/
|
|
|
|
/*
|
|
Template for simple mutation operators
|
|
======================================
|
|
*/
|
|
|
|
#ifndef eoMyStructMutation_H
|
|
#define eoMyStructMutation_H
|
|
|
|
|
|
#include <eoOp.h>
|
|
|
|
/**
|
|
* Always write a comment in this format before class definition
|
|
* if you want the class to be documented by Doxygen
|
|
*
|
|
* THere is NO ASSUMPTION on the class GenoypeT.
|
|
* In particular, it does not need to derive from EO
|
|
*/
|
|
template<class GenotypeT>
|
|
class eoMyStructMutation: public eoMonOp<GenotypeT>
|
|
{
|
|
public:
|
|
/**
|
|
* Ctor - no requirement
|
|
*/
|
|
// START eventually add or modify the anyVariable argument
|
|
eoMyStructMutation()
|
|
// eoMyStructMutation( varType _anyVariable) : anyVariable(_anyVariable)
|
|
// END eventually add or modify the anyVariable argument
|
|
{
|
|
// START Code of Ctor of an eoMyStructEvalFunc object
|
|
// END Code of Ctor of an eoMyStructEvalFunc object
|
|
}
|
|
|
|
/// The class name. Used to display statistics
|
|
string className() const { return "eoMyStructMutation"; }
|
|
|
|
/**
|
|
* modifies the parent
|
|
* @param _genotype The parent genotype (will be modified)
|
|
*/
|
|
bool operator()(GenotypeT & _genotype)
|
|
{
|
|
bool isModified(true);
|
|
// START code for mutation of the _genotype object
|
|
|
|
/** Requirement
|
|
* if (_genotype has been modified)
|
|
* isModified = true;
|
|
* else
|
|
* isModified = false;
|
|
*/
|
|
return isModified;
|
|
// END code for mutation of the _genotype object
|
|
}
|
|
|
|
private:
|
|
// START Private data of an eoMyStructMutation object
|
|
// varType anyVariable; // for example ...
|
|
// END Private data of an eoMyStructMutation object
|
|
};
|
|
|
|
#endif
|