// Copyright (C) 2010 Davis E. King (davis@dlib.net) // License: Boost Software License See LICENSE.txt for the full license. #ifndef DLIB_AnY_DECISION_FUNCTION_Hh_ #define DLIB_AnY_DECISION_FUNCTION_Hh_ #include "any.h" #include "any_decision_function_abstract.h" namespace dlib { // ---------------------------------------------------------------------------------------- template < typename sample_type_, typename result_type_ = double > class any_decision_function { public: typedef sample_type_ sample_type; typedef result_type_ result_type; typedef default_memory_manager mem_manager_type; any_decision_function() { } any_decision_function ( const any_decision_function& item ) { if (item.data) { item.data->copy_to(data); } } template any_decision_function ( const T& item ) { typedef typename basic_type::type U; data.reset(new derived(item)); } void clear ( ) { data.reset(); } template bool contains ( ) const { typedef typename basic_type::type U; return dynamic_cast*>(data.get()) != 0; } bool is_empty( ) const { return data.get() == 0; } result_type operator() ( const sample_type& item ) const { // make sure requires clause is not broken DLIB_ASSERT(is_empty() == false, "\t result_type any_decision_function::operator()" << "\n\t You can't call operator() on an empty any_decision_function" << "\n\t this: " << this ); return data->evaluate(item); } template T& cast_to( ) { typedef typename basic_type::type U; derived* d = dynamic_cast*>(data.get()); if (d == 0) { throw bad_any_cast(); } return d->item; } template const T& cast_to( ) const { typedef typename basic_type::type U; derived* d = dynamic_cast*>(data.get()); if (d == 0) { throw bad_any_cast(); } return d->item; } template T& get( ) { typedef typename basic_type::type U; derived* d = dynamic_cast*>(data.get()); if (d == 0) { d = new derived(); data.reset(d); } return d->item; } any_decision_function& operator= ( const any_decision_function& item ) { any_decision_function(item).swap(*this); return *this; } void swap ( any_decision_function& item ) { data.swap(item.data); } private: struct base { virtual ~base() {} virtual void copy_to ( std::unique_ptr& dest ) const = 0; virtual result_type evaluate ( const sample_type& samp ) const = 0; }; template struct derived : public base { T item; derived() {} derived(const T& val) : item(val) {} virtual void copy_to ( std::unique_ptr& dest ) const { dest.reset(new derived(item)); } virtual result_type evaluate ( const sample_type& samp ) const { return item(samp); } }; std::unique_ptr data; }; // ---------------------------------------------------------------------------------------- template < typename sample_type, typename result_type > inline void swap ( any_decision_function& a, any_decision_function& b ) { a.swap(b); } // ---------------------------------------------------------------------------------------- template T& any_cast(any_decision_function& a) { return a.template cast_to(); } template const T& any_cast(const any_decision_function& a) { return a.template cast_to(); } // ---------------------------------------------------------------------------------------- } #endif // DLIB_AnY_DECISION_FUNCTION_Hh_