📄 gatreegenome.h
字号:
// $Header$/* ---------------------------------------------------------------------------- tree.h mbwall 25feb95 Copyright (c) 1995 Massachusetts Institute of Technology all rights reserved DESCRIPTION: This header defines the interface for the tree genome.---------------------------------------------------------------------------- */#ifndef _ga_tree_h_#define _ga_tree_h_#include "GATree.h"#include "GAGenome.h"/* ----------------------------------------------------------------------------TreeGenome------------------------------------------------------------------------------- Beware that the tree genome can grow unbounded - there is no size limiton the tree, so if you have an objective function that encourages size the treewill grow until you run out of memory.---------------------------------------------------------------------------- */template <class T>class GATreeGenome : public GATree<T>, public GAGenome {public: GADeclareIdentity(); static int DestructiveMutator(GAGenome &, float); static int SwapNodeMutator(GAGenome &, float); static int SwapSubtreeMutator(GAGenome &, float); static int OnePointCrossover(const GAGenome&, const GAGenome&, GAGenome*, GAGenome*); static float TopologyComparator(const GAGenome&, const GAGenome&);// static float NodeComparator(const GAGenome&, const GAGenome&);public: GATreeGenome(GAGenome::Evaluator f=NULL, void * u=NULL); GATreeGenome(const GATreeGenome<T> &); GATreeGenome<T> & operator=(const GAGenome & orig) {copy(orig); return *this;} virtual ~GATreeGenome(); virtual GAGenome *clone(GAGenome::CloneMethod flag=CONTENTS) const; virtual void copy(const GAGenome &);#ifdef GALIB_USE_STREAMS virtual int write (STD_OSTREAM &) const;#endif virtual int equal(const GAGenome & c) const;// Here we do inlined versions of the access members of the super class. We// do our own here so that we can set/unset the _evaluated flag appropriately. int destroy() { _evaluated = gaFalse; return GATree<T>::destroy(); } int swaptree(GATree<T> * t) { _evaluated = gaFalse; return GATree<T>::swaptree(t); } int swaptree(unsigned int i, unsigned int j) { _evaluated = gaFalse; return GATree<T>::swaptree(i,j); } int swap(unsigned int i, unsigned int j) { _evaluated = gaFalse; return GATree<T>::swap(i,j); } GATree<T> * remove() { _evaluated = gaFalse; return GATree<T>::remove(); } int insert(GATree<T> * t, GATreeBASE::Location where=GATreeBASE::BELOW) { _evaluated = gaFalse; return GATree<T>::insert(t, where); } int insert(const T & t, GATreeBASE::Location where=GATreeBASE::BELOW) { _evaluated = gaFalse; return GATree<T>::insert(t, where); }};#ifdef GALIB_USE_BORLAND_INST#include "GATreeGenome.cpp"#endif#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -