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_BORDER_FIND_HH
00027 # define MLN_BORDER_FIND_HH
00028 
00034 # include <mln/core/internal/image_morpher.hh>
00035 
00036 
00037 namespace mln
00038 {
00039 
00040   namespace border
00041   {
00042 
00051     template <typename I>
00052     unsigned find(const Image<I>& ima);
00053 
00054 
00055 # ifndef MLN_INCLUDE_ONLY
00056 
00057     namespace impl
00058     {
00059 
00060       template <typename I, typename T, typename S, typename E>
00061       inline
00062       unsigned find__(const mln::internal::image_morpher<I, T, S, E>& ima)
00063       {
00064         return border::find(*ima.delegatee_());
00065       }
00066 
00067       template <typename T, typename S, typename E>
00068       inline
00069       unsigned find__(const mln::internal::image_base<T, S, E>&)
00070       {
00071         return 0;
00072       }
00073 
00074       template <typename I>
00075       inline
00076       unsigned find_(trait::image::speed::any, const I& ima)
00077       {
00078         return border::impl::find__(ima);
00079       }
00080 
00081       template <typename I>
00082       inline
00083       unsigned find_(trait::image::speed::fastest, const I& ima)
00084       {
00085         return ima.border();
00086       }
00087 
00088     } 
00089 
00090 
00091     
00092 
00093     template <typename I>
00094     inline
00095     unsigned find(const Image<I>& ima)
00096     {
00097       trace::entering("border::find");
00098 
00099       mln_precondition(exact(ima).is_valid());
00100       unsigned res = border::impl::find_(mln_trait_image_speed(I)(), exact(ima));
00101 
00102       trace::exiting("border::find");
00103       return res;
00104     }
00105 
00106 # endif // ! MLN_INCLUDE_ONLY
00107 
00108   } 
00109 
00110 } 
00111 
00112 
00113 #endif // ! MLN_BORDER_FIND_HH