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_LABELING_WRAP_HH
00027 # define MLN_LABELING_WRAP_HH
00028 
00033 
00034 # include <mln/core/concept/image.hh>
00035 # include <mln/data/transform.hh>
00036 # include <mln/fun/v2v/wrap.hh>
00037 # include <mln/metal/converts_to.hh>
00038 # include <mln/metal/is_a.hh>
00039 # include <mln/value/label_8.hh>
00040 
00041 
00042 namespace mln
00043 {
00044 
00045   namespace labeling
00046   {
00047 
00055     template <typename V, typename I>
00056     mln_ch_value(I,V)
00057     wrap(const V& value_type, const Image<I>& input);
00058 
00065     template <typename I>
00066     mln_ch_value(I, mln::value::label_8)
00067     wrap(const Image<I>& input);
00068 
00069 
00070 # ifndef MLN_INCLUDE_ONLY
00071 
00072     template <typename V, typename I>
00073     inline
00074     mln_ch_value(I,V)
00075     wrap(const V& value_type, const Image<I>& input)
00076     {
00077       trace::entering("labeling::wrap");
00078 
00079 
00080       mln_precondition(exact(input).is_valid());
00081       (void) value_type;
00082 
00083       mln_ch_value(I,V) output = data::transform(input, fun::v2v::wrap<V>());
00084 
00085       trace::exiting("labeling::wrap");
00086       return output;
00087     }
00088 
00089 
00090     template <typename I>
00091     inline
00092     mln_ch_value(I, mln::value::label_8)
00093     wrap(const Image<I>& input)
00094     {
00095       return wrap(mln::value::label_8(), input);
00096     }
00097 
00098 # endif // ! MLN_INCLUDE_ONLY
00099 
00100   } 
00101 
00102 } 
00103 
00104 
00105 #endif // ! MLN_LABELING_WRAP_HH