00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 
00017 
00018 
00019 
00020 
00021 
00022 
00023 
00024 
00025 
00026 
00027 #ifndef MLN_DATA_COMPUTE_HH
00028 # define MLN_DATA_COMPUTE_HH
00029 
00033 
00034 # include <mln/data/update.hh>
00035 # include <mln/core/concept/meta_accumulator.hh>
00036 
00037 
00038 
00039 namespace mln
00040 {
00041 
00042   namespace data
00043   {
00044 
00054     
00055     template <typename A, typename I>
00056     mln_result(A)
00057     compute(const Accumulator<A>& a, const Image<I>& input);
00058 
00059 
00067     
00068     template <typename A, typename I>
00069     mln_result(A)
00070     compute(Accumulator<A>& a, const Image<I>& input);
00071 
00072 
00079     template <typename A, typename I>
00080     mln_meta_accu_result(A, mln_value(I))
00081     compute(const Meta_Accumulator<A>& a, const Image<I>& input);
00082 
00083 
00084 
00085 # ifndef MLN_INCLUDE_ONLY
00086 
00087 
00088     
00089 
00090     template <typename A, typename I>
00091     inline
00092     mln_result(A)
00093     compute(const Accumulator<A>& a_, const Image<I>& input)
00094     {
00095       (void) a_;
00096       A a;
00097       return compute(a, input);
00098     }
00099 
00100 
00101     template <typename A, typename I>
00102     inline
00103     mln_result(A)
00104     compute(Accumulator<A>& a_, const Image<I>& input)
00105     {
00106       trace::entering("data::compute");
00107 
00108       A a = exact(a_);
00109       data::internal::update_tests(a, input);
00110 
00111       a.init();
00112       data::internal::update_dispatch(a, input);
00113 
00114       trace::exiting("data::compute");
00115       return a;
00116     }
00117 
00118 
00119     template <typename A, typename I>
00120     inline
00121     mln_meta_accu_result(A, mln_value(I))
00122     compute(const Meta_Accumulator<A>& a, const Image<I>& input)
00123     {
00124       typedef mln_accu_with(A, mln_value(I)) A_;
00125       A_ a_ = accu::unmeta(exact(a), mln_value(I)());
00126 
00127       return data::compute(a_, input); 
00128     }
00129 
00130 # endif // ! MLN_INCLUDE_ONLY
00131 
00132   } 
00133 
00134 } 
00135 
00136 
00137 #endif // ! MLN_DATA_COMPUTE_HH