edoStat.h
00001 /*
00002 The Evolving Distribution Objects framework (EDO) is a template-based,
00003 ANSI-C++ evolutionary computation library which helps you to write your
00004 own estimation of distribution algorithms.
00005 
00006 This library is free software; you can redistribute it and/or
00007 modify it under the terms of the GNU Lesser General Public
00008 License as published by the Free Software Foundation; either
00009 version 2.1 of the License, or (at your option) any later version.
00010 
00011 This library is distributed in the hope that it will be useful,
00012 but WITHOUT ANY WARRANTY; without even the implied warranty of
00013 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00014 Lesser General Public License for more details.
00015 
00016 You should have received a copy of the GNU Lesser General Public
00017 License along with this library; if not, write to the Free Software
00018 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
00019 
00020 Copyright (C) 2010 Thales group
00021 */
00022 /*
00023 Authors:
00024     Johann Dréo <johann.dreo@thalesgroup.com>
00025     Caner Candan <caner.candan@thalesgroup.com>
00026 */
00027 
00028 #ifndef _edoStat_h
00029 #define _edoStat_h
00030 
00031 #include <eoFunctor.h>
00032 
00034 
00035 template < typename D >
00036 class edoStatBase : public eoUF< const D&, void >
00037 {
00038 public:
00039     // virtual void operator()( const D& ) = 0 (provided by eoUF< A1, R >)
00040 
00041     virtual void lastCall( const D& ) {}
00042     virtual std::string className() const { return "edoStatBase"; }
00043 };
00044 
00045 template < typename D > class edoCheckPoint;
00046 
00047 template < typename D, typename T >
00048 class edoStat : public eoValueParam< T >, public edoStatBase< D >
00049 {
00050 public:
00051     edoStat(T value, std::string description)
00052         : eoValueParam< T >(value, description)
00053     {}
00054 
00055     virtual std::string className(void) const { return "edoStat"; }
00056 
00057     edoStat< D, T >& addTo(edoCheckPoint< D >& cp) { cp.add(*this); return *this; }
00058 
00059     // TODO: edoStat< D, T >& addTo(eoMonitor& mon) { mon.add(*this); return *this; }
00060 };
00061 
00062 
00064 
00065 template < typename D >
00066 class edoDistribStat : public edoStat< D, std::string >
00067 {
00068 public:
00069     using edoStat< D, std::string >::value;
00070 
00071     edoDistribStat(std::string desc)
00072         : edoStat< D, std::string >("", desc)
00073     {}
00074 };
00075 
00076 #endif // !_edoStat_h
 All Classes Functions Variables Typedefs