• Main Page
  • Related Pages
  • Modules
  • Namespaces
  • Classes
  • Files
  • File List

superpose.hh

00001 // Copyright (C) 2009, 2010 EPITA Research and Development Laboratory
00002 // (LRDE)
00003 //
00004 // This file is part of Olena.
00005 //
00006 // Olena is free software: you can redistribute it and/or modify it under
00007 // the terms of the GNU General Public License as published by the Free
00008 // Software Foundation, version 2 of the License.
00009 //
00010 // Olena is distributed in the hope that it will be useful,
00011 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00012 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00013 // General Public License for more details.
00014 //
00015 // You should have received a copy of the GNU General Public License
00016 // along with Olena.  If not, see <http://www.gnu.org/licenses/>.
00017 //
00018 // As a special exception, you may use this file as part of a free
00019 // software project without restriction.  Specifically, if other files
00020 // instantiate templates or use macros or inline functions from this
00021 // file, or you compile this file and link it with other files to produce
00022 // an executable, this file does not by itself cause the resulting
00023 // executable to be covered by the GNU General Public License.  This
00024 // exception does not however invalidate any other reasons why the
00025 // executable file might be covered by the GNU General Public License.
00026 
00027 #ifndef MLN_LABELING_SUPERPOSE_HH
00028 # define MLN_LABELING_SUPERPOSE_HH
00029 
00033 
00034 
00035 # include <mln/core/concept/image.hh>
00036 # include <mln/util/array.hh>
00037 # include <mln/labeling/relabel.hh>
00038 # include <mln/data/paste.hh>
00039 # include <mln/pw/all.hh>
00040 
00041 # include <mln/value/next.hh>
00042 # include <mln/value/equiv.hh>
00043 
00044 namespace mln
00045 {
00046 
00047   namespace labeling
00048   {
00049 
00050 
00070     template <typename I, typename J>
00071     mln_concrete(I)
00072     superpose(const Image<I>& lhs, const mln_value(I)& lhs_nlabels,
00073               const Image<J>& rhs, const mln_value(J)& rhs_nlabels,
00074               mln_value(I)& new_nlabels);
00075 
00076 
00077 
00078 
00079 # ifndef MLN_INCLUDE_ONLY
00080 
00081     template <typename I, typename J>
00082     mln_concrete(I)
00083     superpose(const Image<I>& lhs_, const mln_value(I)& lhs_nlabels,
00084               const Image<J>& rhs_, const mln_value(J)& rhs_nlabels,
00085               mln_value(I)& new_nlabels)
00086     {
00087       trace::entering("mln::labeling::superpose");
00088 
00089       const I& lhs = exact(lhs_);
00090       const J& rhs = exact(rhs_);
00091 
00092       mlc_converts_to(mln_value(I), mln_value(J))::check();
00093       mln_precondition(lhs.is_valid());
00094       mln_precondition(rhs.is_valid());
00095       mln_precondition(lhs.domain() == rhs.domain());
00097 
00098       mln_concrete(I) output = duplicate(lhs);
00099 
00100       util::array<mln_value(J)>
00101         rebase_lbl(value::next(rhs_nlabels));
00102 
00103       rebase_lbl(0) = 0;
00104       for (unsigned i = 1; i <= rhs_nlabels; ++i)
00105         rebase_lbl(i) = i + value::equiv(lhs_nlabels);
00106 
00107       data::paste(labeling::relabel(rhs, rhs_nlabels, rebase_lbl)
00108                   | (pw::value(rhs) != pw::cst(literal::zero)),
00109                   output);
00110 
00111       new_nlabels = value::equiv(lhs_nlabels)
00112                     + value::equiv(rhs_nlabels) + 1;
00113 
00114       trace::exiting("mln::labeling::superpose");
00115       return output;
00116     }
00117 
00118 
00119 # endif // ! MLN_INCLUDE_ONLY
00120 
00121   } // end of namespace mln::labeling
00122 
00123 } // end of namespace mln
00124 
00125 
00126 #endif // ! MLN_LABELING_SUPERPOSE_HH

Generated on Tue Oct 4 2011 15:24:41 for Milena (Olena) by  doxygen 1.7.1