https://svn.lrde.epita.fr/svn/oln/branches/cleanup-2008/milena/sandbox
Index: ChangeLog
from Ugo Jardonnet <ugo.jardonnet(a)lrde.epita.fr>
INIM: Classif: Start working on max_tree version.
* classif/max_tree.hh: max_tree struct.
* classif/iccvg04.cc: minor fix.
* classif/display.hh: Put display here.
* classif/v2.cc: STart max_tree.
display.hh | 76 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
iccvg04.cc | 30 -----------------------
max_tree.hh | 15 +++++++++++
v2.cc | 25 +++++++++----------
4 files changed, 104 insertions(+), 42 deletions(-)
Index: classif/max_tree.hh
--- classif/max_tree.hh (revision 2705)
+++ classif/max_tree.hh (working copy)
@@ -13,6 +13,7 @@
# include <mln/value/int_u8.hh>
# include <mln/io/pgm/load.hh>
# include <mln/core/site_set/p_array.hh>
+# include <mln/debug/println.hh>
using namespace mln;
@@ -83,6 +84,20 @@
zpar(p) = p;
}
+ void area()
+ {
+ image2d<value::int_u16> area(f.domain());
+ level::fill(area, 1);
+ mln_fwd_piter(S) p(s);
+ for_all(p)
+ {
+ if (parent(p) == p)
+ continue;
+ area(parent(p)) += area(p);
+ }
+ debug::println(area);
+ }
+
bool is_root(const point& p) const
{
return parent(p) == p;
Index: classif/iccvg04.cc
--- classif/iccvg04.cc (revision 2705)
+++ classif/iccvg04.cc (working copy)
@@ -36,6 +36,7 @@
#include <stdlib.h>
#include "proj.hh"
+#include "display.hh"
using namespace mln;
@@ -70,35 +71,6 @@
}
}
-template <typename I>
-void display(const I& ima, const char * dir)
-{
- mkdir(dir, 0777);
- chdir(dir);
-
- image2d< mln_value(I) > out(geom::nrows(ima), geom::ncols(ima));
-
- for (int s = 0; s < geom::nslis(ima); ++s)
- {
- // image2d< value::int_u8 > out(geom::nrows(ima), geom::ncols(ima));
- for (int r = 0; r < geom::nrows(ima); ++r)
- {
- for (int c = 0; c < geom::ncols(ima); ++c)
- {
- out(point2d(r, c)) = ima(point3d(s, r, c));
- }
- }
-
- std::ostringstream is;
- is << "out_" << s << ".pgm";
-
- io::pgm::save(out, is.str());
- }
-
- chdir("..");
-}
-
-
template <typename I, typename J, typename K>
void
classify_image(const I& ima, const J& histo, const K& ws, int nbasins, int f)
Index: classif/display.hh
--- classif/display.hh (revision 0)
+++ classif/display.hh (revision 0)
@@ -0,0 +1,76 @@
+// Copyright (C) 2008 EPITA Research and Development Laboratory
+//
+// This file is part of the Olena Library. This library is free
+// software; you can redistribute it and/or modify it under the terms
+// of the GNU General Public License version 2 as published by the
+// Free Software Foundation.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this library; see the file COPYING. If not, write to
+// the Free Software Foundation, 51 Franklin Street, Fifth Floor,
+// Boston, MA 02111-1307, USA.
+//
+// As a special exception, you may use this file as part of a free
+// software library without restriction. Specifically, if other files
+// instantiate templates or use macros or inline functions from this
+// file, or you compile this file and link it with other files to
+// produce an executable, this file does not by itself cause the
+// resulting executable to be covered by the GNU General Public
+// License. This exception does not however invalidate any other
+// reasons why the executable file might be covered by the GNU General
+// Public License.
+
+#ifndef MLN__DISPLAY_HH
+# define MLN__DISPLAY_HH
+
+#include <mln/io/ppm/save.hh>
+#include <mln/geom/all.hh>
+#include <mln/value/all.hh>
+#include <mln/core/image/image3d.hh>
+
+#include <sys/stat.h>
+#include <sstream>
+#include <string.h>
+#include <stdlib.h>
+
+
+namespace mln
+{
+
+ template <typename I>
+ void display(const I& ima, const char * dir)
+ {
+ mkdir(dir, 0777);
+ chdir(dir);
+
+ image2d< mln_value(I) > out(geom::nrows(ima), geom::ncols(ima));
+
+ for (int s = 0; s < geom::nslis(ima); ++s)
+ {
+ // image2d< value::int_u8 > out(geom::nrows(ima), geom::ncols(ima));
+ for (int r = 0; r < geom::nrows(ima); ++r)
+ {
+ for (int c = 0; c < geom::ncols(ima); ++c)
+ {
+ out(point2d(r, c)) = ima(point3d(s, r, c));
+ }
+ }
+
+ std::ostringstream is;
+ is << "out_" << s << ".pgm";
+
+ io::pgm::save(out, is.str());
+ }
+
+ chdir("..");
+ }
+
+} // end of namespace mln
+
+#endif /* MLN__DISPLAY_HH */
+
Index: classif/v2.cc
--- classif/v2.cc (revision 2705)
+++ classif/v2.cc (working copy)
@@ -14,7 +14,9 @@
#include <mln/arith/revert.hh>
#include <mln/core/alias/neighb3d.hh>
-#include "min_tree.hh"
+#include "max_tree.hh"
+#include "proj.hh"
+#include "display.hh"
using namespace mln;
@@ -38,17 +40,11 @@
template <typename I, typename N>
unsigned
-compute_min_tree(const I& ima, const N& nbh)
+compute_max_tree(const I& ima, const J& histo, const N& nbh)
{
- min_tree_<I,N> run(ima, nbh);
+ max_tree_<I,N> run(ima, nbh);
- mln_piter(I) p(ima.domain());
- unsigned nnodes = 0;
- for_all(p)
- if (run.is_node(p))
- ++nnodes;
- return nnodes;
}
bool usage(int argc, char ** argv)
@@ -72,9 +68,12 @@
//make histo
image3d<unsigned> histo = fill_histo(ima,div_factor);
- //revert histo
- image3d<unsigned> rhisto = arith::revert(histo);
+ //proj
+ accu::mean<unsigned, unsigned, unsigned> mean;
+ image2d<unsigned> phisto = proj(histo, mean);
+
+ //debug::println(phisto);
- // Compute min_tree
- compute_min_tree(rhisto, c6());
+ // Compute max_tree
+ max_tree_<I,N> run(ima, nbh);
}
* mln/core/site_set/box.hh:
- Add a new version of enlarge() which can be applied on a single
dimension passed as parameter.
- Add center() which returns an approximated central site of a bo
---
milena/ChangeLog | 9 +++++++++
milena/mln/core/site_set/box.hh | 30 ++++++++++++++++++++++++++++++
2 files changed, 39 insertions(+), 0 deletions(-)
diff --git a/milena/ChangeLog b/milena/ChangeLog
index 1a947ad..2649954 100644
--- a/milena/ChangeLog
+++ b/milena/ChangeLog
@@ -1,5 +1,14 @@
2008-10-27 Guillaume Lazzara <z(a)lrde.epita.fr>
+ Add box::center() and a new overload of box::enlarge().
+
+ * mln/core/site_set/box.hh:
+ - Add a new version of enlarge() which can be applied on a single
+ dimension passed as parameter.
+ - Add center() which returns an approximated central site of a box.
+
+2008-10-27 Guillaume Lazzara <z(a)lrde.epita.fr>
+
Fix wrong or missing traces.
* milena/mln/level/fill_with_image.spe.hh,
* milena/mln/morpho/erosion.spe.hh:
diff --git a/milena/mln/core/site_set/box.hh b/milena/mln/core/site_set/box.hh
index 9e8c6db..9a03897 100644
--- a/milena/mln/core/site_set/box.hh
+++ b/milena/mln/core/site_set/box.hh
@@ -137,9 +137,16 @@ namespace mln
/// Enlarge the box with a border \p b.
void enlarge(unsigned b);
+ /// Enlarge the box with a border \p b for dimension \p dim.
+ void enlarge(unsigned dim, unsigned b);
+
/// Give a larger box.
box<P> to_larger(unsigned b) const;
+ /// Return the approximated central site of this box.
+ /// FIXME: Do we want a routine as well like geom::bbox()?
+ P center() const;
+
/// Test that the box owns valid data, i.e., is initialized and
/// with pmin being 'less-than' pmax.
bool is_valid() const;
@@ -296,6 +303,17 @@ namespace mln
template <typename P>
inline
+ void
+ box<P>::enlarge(unsigned dim, unsigned b)
+ {
+ mln_precondition(is_valid());
+ pmin_[dim] -= b;
+ pmax_[dim] += b;
+ mln_postcondition(is_valid());
+ }
+
+ template <typename P>
+ inline
box<P>
larger_than(const box<P> a, const box<P> b)
{
@@ -329,6 +347,18 @@ namespace mln
template <typename P>
inline
+ P
+ box<P>::center() const
+ {
+ mln_precondition(is_valid());
+ point2d center;
+ for (unsigned i = 0; i < P::dim; ++i)
+ center[i] = pmin_[i] + ((pmax_[i] - pmin_[i]) / 2);
+ return center;
+ }
+
+ template <typename P>
+ inline
std::size_t
box<P>::memory_size() const
{
--
1.5.6.5