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 #ifndef MLN_DATA_ABS_HH
00027 # define MLN_DATA_ABS_HH
00028 
00035 # include <mln/fun/v2v/abs.hh>
00036 # include <mln/data/apply.hh>
00037 # include <mln/data/transform.hh>
00038 
00039 
00040 namespace mln
00041 {
00042 
00043   namespace data
00044   {
00045 
00046 
00052     template <typename I, typename O>
00053     void abs(const Image<I>& input, Image<O>& output);
00054 
00055 
00060     template <typename I>
00061     void abs_inplace(Image<I>& input);
00062 
00063 
00064 # ifndef MLN_INCLUDE_ONLY
00065 
00066     template <typename I, typename O>
00067     inline
00068     void abs(const Image<I>& input, Image<O>& output)
00069     {
00070       trace::entering("data::abs");
00071 
00072       mln_precondition(exact(input).domain() == exact(output).domain());
00073       exact(output) = data::transform(input, fun::v2v::abs<mln_value(I)>());
00074 
00075       trace::exiting("data::abs");
00076     }
00077 
00078     template <typename I>
00079     inline
00080     void abs_inplace(Image<I>& input)
00081     {
00082       trace::entering("data::abs_inplace");
00083 
00084       mln_precondition(exact(input).is_valid());
00085       data::apply(input, fun::v2v::abs<mln_value(I)>());
00086 
00087       trace::exiting("data::abs_inplace");
00088     }
00089 
00090 # endif // ! MLN_INCLUDE_ONLY
00091 
00092   } 
00093 
00094 } 
00095 
00096 
00097 #endif // ! MLN_DATA_ABS_HH