27 #ifndef SCRIBO_PRIMITIVE_LINK_WITH_SINGLE_RIGHT_LINK_DMAX_RATIO_HH
28 # define SCRIBO_PRIMITIVE_LINK_WITH_SINGLE_RIGHT_LINK_DMAX_RATIO_HH
35 # include <mln/core/concept/image.hh>
36 # include <mln/core/concept/neighborhood.hh>
38 # include <mln/accu/center.hh>
39 # include <mln/labeling/compute.hh>
40 # include <mln/math/abs.hh>
41 # include <mln/util/array.hh>
43 # include <scribo/core/macros.hh>
44 # include <scribo/core/component_set.hh>
45 # include <scribo/core/object_links.hh>
47 # include <scribo/primitive/link/internal/find_link.hh>
48 # include <scribo/primitive/link/internal/link_single_dmax_ratio_base.hh>
50 # include <scribo/primitive/link/compute.hh>
51 # include <scribo/primitive/link/internal/dmax_default.hh>
76 template <
typename L,
typename F>
80 const DMax_Functor<F>& dmax_f,
105 template <
typename L>
112 # ifndef MLN_INCLUDE_ONLY
120 template <
typename L,
typename F>
121 class single_right_dmax_ratio_functor
122 :
public link_single_dmax_ratio_base<L, F,
123 single_right_dmax_ratio_functor<L,F> >
125 typedef single_right_dmax_ratio_functor<L, F> self_t;
126 typedef link_single_dmax_ratio_base<L, F, self_t> super_;
129 typedef mln_site(L) P;
131 single_right_dmax_ratio_functor(const component_set<L>&
components,
132 const DMax_Functor<F>& dmax_f)
133 : super_(components, anchor::Horizontal, exact(dmax_f))
137 void compute_next_site_(P& p)
151 template <
typename L,
typename F>
155 const DMax_Functor<F>& dmax_f,
158 mln_trace(
"scribo::primitive::link::with_single_right_link_dmax_ratio");
160 mln_precondition(components.is_valid());
162 internal::single_right_dmax_ratio_functor<L, F>
163 functor(components, dmax_f);
165 object_links<L> output =
compute(functor, anchor);
170 template <
typename L>
179 internal::dmax_default(dmax_ratio),
185 template <
typename L>
197 template <
typename L>
206 # endif // ! MLN_INCLUDE_ONLY
214 #endif // ! SCRIBO_PRIMITIVE_LINK_WITH_SINGLE_RIGHT_LINK_DMAX_RATIO_HH