00001 // Copyright (C) 2001, 2002, 2003, 2004 EPITA Research and Development Laboratory 00002 // 00003 // This file is part of the Olena Library. This library is free 00004 // software; you can redistribute it and/or modify it under the terms 00005 // of the GNU General Public License version 2 as published by the 00006 // Free Software Foundation. 00007 // 00008 // This library is distributed in the hope that it will be useful, 00009 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00010 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00011 // General Public License for more details. 00012 // 00013 // You should have received a copy of the GNU General Public License 00014 // along with this library; see the file COPYING. If not, write to 00015 // the Free Software Foundation, 59 Temple Place - Suite 330, Boston, 00016 // MA 02111-1307, USA. 00017 // 00018 // As a special exception, you may use this file as part of a free 00019 // software library without restriction. Specifically, if other files 00020 // instantiate templates or use macros or inline functions from this 00021 // file, or you compile this file and link it with other files to 00022 // produce an executable, this file does not by itself cause the 00023 // resulting executable to be covered by the GNU General Public 00024 // License. This exception does not however invalidate any other 00025 // reasons why the executable file might be covered by the GNU General 00026 // Public License. 00027 00028 #ifndef OLENA_LEVEL_THRESHOLD_HH 00029 # define OLENA_LEVEL_THRESHOLD_HH 00030 00031 # include <oln/basics.hh> 00032 # include <ntg/utils/debug.hh> 00033 00034 namespace oln { 00035 00036 namespace level { 00037 00064 template<class Input, class Output, class Exact = mlc::final> 00065 class threshold : public std::unary_function<const Input&, Output> 00066 { 00067 public: 00074 threshold(const Input& threshold, 00075 const Output& min = ntg_min_val(Output), 00076 const Output& max = ntg_max_val(Output)) : 00077 m_threshold(threshold), m_min(min), m_max(max) 00078 {} 00079 00080 Output 00081 operator() (const Input& v) const 00082 { 00083 if (v >= m_threshold) 00084 return m_max; 00085 return m_min; 00086 } 00087 00088 static std::string 00089 name() 00090 { 00091 return std::string("threshold<") 00092 + ntg_name(Output) + ", " 00093 + ntg_name(Input) + ", " 00094 + Exact::name() + ">"; 00095 } 00096 00097 private: 00098 const Input m_threshold; 00099 const Output m_min; 00100 const Output m_max; 00101 }; 00102 00103 } // end of namespace convert 00104 00105 } // end of namespace oln 00106 00107 #endif // ! OLENA_LEVEL_THRESHOLD_HH