edoBounderUniform.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 */
00026 
00027 #ifndef _edoBounderUniform_h
00028 #define _edoBounderUniform_h
00029 
00030 #include "edoBounder.h"
00031 
00037 template < typename EOT >
00038 class edoBounderUniform : public edoBounder< EOT >
00039 {
00040 public:
00041     edoBounderUniform( EOT min, EOT max )
00042         : edoBounder< EOT >( min, max )
00043     {
00044     }
00045 
00046     void operator()( EOT& sol )
00047     {
00048         assert( this->min().size() > 0 );
00049         assert( this->max().size() > 0 );
00050 
00051         assert( sol.size() > 0);
00052         assert( sol.size() == this->min().size() );
00053 
00054         eo::log << eo::debug << "BounderUniform: from sol = " << sol;
00055         eo::log.flush();
00056 
00057         unsigned int size = sol.size();
00058         for (unsigned int d = 0; d < size; ++d) {
00059 
00060             if ( sol[d] < this->min()[d] || sol[d] > this->max()[d]) {
00061                 // use EO's global "rng"
00062                 sol[d] = rng.uniform( this->min()[d], this->max()[d] );
00063             }
00064         } // for d in size
00065         
00066         eo::log << eo::debug << "\tto sol = " << sol << std::endl;
00067     }
00068 };
00069 
00070 #endif // !_edoBounderUniform_h
 All Classes Functions Variables Typedefs