https://svn.lrde.epita.fr/svn/oln/branches/cleanup-2008/milena
Index: ChangeLog
from Nicolas Ballas <ballas(a)lrde.epita.fr>
Update documentation about the image value properties.
* doc/technical/designs/properties/values.txt: Update.
values.txt | 65 ++++++++++++++++++++++++++++++-------------------------------
1 file changed, 32 insertions(+), 33 deletions(-)
Index: doc/technical/designs/properties/values.txt
--- doc/technical/designs/properties/values.txt (revision 2425)
+++ doc/technical/designs/properties/values.txt (working copy)
@@ -3,12 +3,12 @@
Values related properties
-* TODO
- -> Are the properties related to the values sufficiant?
- -> What are the interface related to each value property?
+* What is this file about
+ -> Are the image properties about the values sufficient/correct?
+ -> What are the piece of interface related to each property?
-> How these values properties affect the fill/paste/transform process?
-* Values properties list:
+* Image values properties:
** value_access: /any/
|
@@ -33,12 +33,12 @@
value_storage == singleton
=> ima.value() -> return the image value
- value_storage == one_block
+ value_storage == one_block (what about the fastest image?)
=> image.nelements() -> return the number of elements in memory
=> image.buffer() -> return the start adress of the ima buffer
value_storage == piece_wise
- //FIXME
+ // runs iterator?
** value_browsing:/any/
|
@@ -55,7 +55,7 @@
=> ima.values_taken() -> return the current values taken by
ima
=> ima.change_value(oldVal, newVal) -> change the value oldVal to newVal
- => ima.change_values(f) -> apply f (a function v2v) to all the
+ => ima.apply(f) -> apply f (a function v2v) to all the
values
=> ima.sites(v) -> return the sites associated to the
value v
@@ -68,9 +68,11 @@
+* Impact on the fill and paste algorithms
+** fill
-* fill (depends on the value_storage property)
+Fill an image ima with a value v.
*** values_storage == oneblock
// Replace by Memcopy?
@@ -78,12 +80,10 @@
mln_value(I)* ptr = ima.buffer();
for (unsigned i = 0; i < n; ++i)
*ptr++ = val;
-
**** Method related
-> nelements
-> buffer
-
*** value_storage == piece_wise
// MemCopy on the runs?
for (ungsigned i = 0; i < ima.nruns(); ++i)
@@ -91,23 +91,37 @@
**** Method related:
nruns ???
-
-*** value_storage == any && value_browsing == value_wise
-
+*** value_browsing == value_wise
// direct access to the value
mln_viter(mln_taken_values(I)) viter(I.taken_values();
for_all(viter);
ima.changes_values(viter, v);
-
**** Method related:
-> iterator on value taken
-> change_values
-*** Generic case: all the other case
+*** generic case
mln_piter(I) p(ima.domain());
for_all(p)
ima(p) = v;
+** Paste
+
+Paste value data from an image source to destination.
+
+*** values_storage == oneblock (for source an destination)
+// Replace by Memcopy?
+const unsigned n = ima.nelements();
+mln_value(I)* ptr_src = source.buffer();
+mln_value(I)* ptr_dest = destination.buffer();
+for (unsigned i = 0; i < n; ++i)
+ *ptr_src++ = *ptr_dest++;
+
+
+*** generic case
+mln_piter(I) p(source.domain());
+for_all(p)
+ destination(p) = source(p);
* To keep in Mind
@@ -147,22 +161,7 @@
-differentiate the localization of an image and its storage method.
-* Image related with 'special' values access
-
-** Run Images (sparce, value_encoded)
-
-=> fill: *cpt++ = v sur chaque run
-|
-+-> related to memory storage
-
-** Pkey Images
-
-=> change_value
-
-
-
-* Note
+** Image related with 'special' values access
-- Cell access and Value access wise property depends on the image
- --> property related:
- cell-wise and value wise
+*** Run Images (sparse, value_encoded)
+*** Pkey Images
* mln/topo/n_face_iter.hh: New.
* mln/topo/complex.hh: Include mln/topo/n_face_iter.hh.
* tests/topo/complex.cc: Exercise n_face_fwd_iter and
n_face_bkd_iter.
---
milena/ChangeLog | 9 ++
milena/mln/topo/complex.hh | 1 +
milena/mln/topo/n_face_iter.hh | 311 ++++++++++++++++++++++++++++++++++++++++
milena/tests/topo/complex.cc | 33 +++--
4 files changed, 345 insertions(+), 9 deletions(-)
create mode 100644 milena/mln/topo/n_face_iter.hh
diff --git a/milena/ChangeLog b/milena/ChangeLog
index 4d9412b..d5309e4 100644
--- a/milena/ChangeLog
+++ b/milena/ChangeLog
@@ -1,5 +1,14 @@
2008-09-26 Roland Levillain <roland(a)lrde.epita.fr>
+ Add iterators on n-faces (with a dynamically known `n').
+
+ * mln/topo/n_face_iter.hh: New.
+ * mln/topo/complex.hh: Include mln/topo/n_face_iter.hh.
+ * tests/topo/complex.cc: Exercise n_face_fwd_iter and
+ n_face_bkd_iter.
+
+2008-09-26 Roland Levillain <roland(a)lrde.epita.fr>
+
Revive iterators on n-faces (with a statically known `n').
* mln/topo/attic/complex_faces_iter.hh: Rename as...
diff --git a/milena/mln/topo/complex.hh b/milena/mln/topo/complex.hh
index 61ce84b..13e21d0 100644
--- a/milena/mln/topo/complex.hh
+++ b/milena/mln/topo/complex.hh
@@ -49,6 +49,7 @@
# include <mln/topo/n_faces_set.hh>
# include <mln/topo/face_iter.hh>
+# include <mln/topo/n_face_iter.hh>
# include <mln/topo/static_n_face_iter.hh>
// FIXME: Disabled (moved to the attic).
# if 0
diff --git a/milena/mln/topo/n_face_iter.hh b/milena/mln/topo/n_face_iter.hh
new file mode 100644
index 0000000..1156707
--- /dev/null
+++ b/milena/mln/topo/n_face_iter.hh
@@ -0,0 +1,311 @@
+// Copyright (C) 2008 EPITA Research and Development Laboratory (LRDE)
+//
+// 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.
+// reasons why the executable file might be covered by the GNU General
+// Public License.
+
+#ifndef MLN_TOPO_N_FACE_ITER_HH
+# define MLN_TOPO_N_FACE_ITER_HH
+
+/// \file mln/topo/n_face_iter.hh
+/// \brief Definition of forward and backward iterators on all the
+/// \a n-faces of a complex, \a n being a dynamic value.
+
+# include <mln/topo/internal/complex_iter_base.hh>
+# include <mln/topo/face.hh>
+
+// FIXME: Factor a bit more? (Using complex_iter_base.)
+
+// FIXME: Rename the old commplex_faces_{fwd,bkd}_iter as
+// static_n_face_{fwd,bkd}_iter.
+
+
+namespace mln
+{
+
+ namespace topo
+ {
+
+ // Forward declaration.
+ template <unsigned D> class complex;
+
+
+ /*---------------------------.
+ | topo::n_face_fwd_iter<D>. |
+ `---------------------------*/
+
+ /// \brief Forward iterator on all the faces of an mln::complex<D>.
+ ///
+ /// \arg \p D The dimension of the complex this iterator belongs to.
+ template <unsigned D>
+ class n_face_fwd_iter
+ : public internal::complex_iter_base< face<D>, n_face_fwd_iter<D> >
+ {
+ public:
+ /// Type of associated face.
+ typedef face<D> face;
+
+ private:
+ typedef n_face_fwd_iter<D> self_;
+ typedef internal::complex_iter_base< face, self_ > super_;
+
+ public:
+ using super_::is_valid;
+ using super_::invalidate;
+
+ public:
+ /// Construction and assignment.
+ /// \{
+ n_face_fwd_iter();
+ // FIXME: See comment in internal::complex_iter_base's default ctor
+ n_face_fwd_iter(complex<D>& c, unsigned n);
+ /// \}
+
+ /// Manipulation.
+ /// \{
+ /// Test if the iterator is valid.
+ void start();
+ /// Go to the next point.
+ void next_();
+ /// \}
+
+ /// \brief Accessors.
+ ///
+ /// Shortcuts to face_'s accessors.
+ /// \{
+ unsigned n() const;
+ void set_n (unsigned n);
+ /// \}
+
+ private:
+ using super_::face_;
+ };
+
+
+ /*---------------------------.
+ | topo::n_face_bkd_iter<D>. |
+ `---------------------------*/
+
+ /// \brief Backward iterator on all the faces of an mln::complex<D>.
+ ///
+ /// \arg \p D The dimension of the complex this iterator belongs to.
+ template <unsigned D>
+ class n_face_bkd_iter
+ : public internal::complex_iter_base< face<D>, n_face_bkd_iter<D> >
+ {
+ public:
+ /// Type of associated face.
+ typedef face<D> face;
+
+ private:
+ typedef n_face_bkd_iter<D> self_;
+ typedef internal::complex_iter_base< face, self_ > super_;
+
+ public:
+ using super_::is_valid;
+ using super_::invalidate;
+
+ public:
+ /// Construction and assignment.
+ /// \{
+ n_face_bkd_iter();
+ // FIXME: See comment in internal::complex_iter_base's default ctor
+ n_face_bkd_iter(complex<D>& c, unsigned n);
+ /// \}
+
+ /// Manipulation.
+ /// \{
+ /// Start an iteration.
+ void start();
+ /// Go to the next point.
+ void next_();
+ /// \}
+
+ /// \brief Accessors.
+ ///
+ /// Shortcuts to face_'s accessors.
+ /// \{
+ unsigned n() const;
+ void set_n (unsigned n);
+ /// \}
+
+ private:
+ using super_::face_;
+ };
+
+
+
+# ifndef MLN_INCLUDE_ONLY
+
+ /*---------------------------.
+ | topo::n_face_fwd_iter<D>. |
+ `---------------------------*/
+
+ template <unsigned D>
+ inline
+ n_face_fwd_iter<D>::n_face_fwd_iter()
+ : super_()
+ {
+ }
+
+ template <unsigned D>
+ inline
+ n_face_fwd_iter<D>::n_face_fwd_iter(complex<D>& c, unsigned n)
+ : super_(c)
+ {
+ mln_precondition(n <= D);
+ set_cplx(c);
+ set_n(n);
+ mln_postcondition(!is_valid());
+ }
+
+ template <unsigned D>
+ inline
+ void
+ n_face_fwd_iter<D>::start()
+ {
+ face_.set_face_id(0u);
+ }
+
+ template <unsigned D>
+ inline
+ void
+ n_face_fwd_iter<D>::next_()
+ {
+ if (is_valid())
+ {
+ unsigned face_id = face_.face_id();
+ // The number of faces of dimension N in cplx_.
+ unsigned nn_faces = face_.cplx().nfaces(n());
+ if (face_id + 1 < nn_faces)
+ /* FIXME: Provide accessor face::face_id() returning
+ a mutable reference? This way, we could just write
+
+ ++face_.face_id();
+
+ instead of the following.
+
+ Or add {inc,add}_face_id() services. */
+ face_.set_face_id(face_id + 1);
+ else
+ invalidate();
+ }
+ }
+
+ template <unsigned D>
+ inline
+ unsigned
+ n_face_fwd_iter<D>::n() const
+ {
+ return face_.n();
+ }
+
+ template <unsigned D>
+ inline
+ void
+ n_face_fwd_iter<D>::set_n(unsigned n)
+ {
+ mln_precondition(n <= D);
+ face_.set_n(n);
+ }
+
+
+ /*---------------------------.
+ | topo::n_face_bkd_iter<D>. |
+ `---------------------------*/
+
+ template <unsigned D>
+ inline
+ n_face_bkd_iter<D>::n_face_bkd_iter()
+ : super_()
+ {
+ }
+
+ template <unsigned D>
+ inline
+ n_face_bkd_iter<D>::n_face_bkd_iter(complex<D>& c, unsigned n)
+ : super_(c)
+ {
+ mln_precondition(n <= D);
+ set_cplx(c);
+ set_n(n);
+ mln_postcondition(!is_valid());
+ }
+
+ template <unsigned D>
+ inline
+ void
+ n_face_bkd_iter<D>::start()
+ {
+ face_.set_n(n());
+ face_.set_face_id(face_.cplx().nfaces(n()) - 1);
+ }
+
+ template <unsigned D>
+ inline
+ void
+ n_face_bkd_iter<D>::next_()
+ {
+ if (is_valid())
+ {
+ unsigned face_id = face_.face_id();
+ if (face_id > 0)
+ /* FIXME: Provide accessor face::face_id() returning
+ a mutable reference? This way, we could just write
+
+ ++face_.face_id();
+
+ instead of the following.
+
+ Or add {inc,add}_face_id() services. */
+ face_.set_face_id(face_id - 1);
+ else
+ invalidate();
+ }
+ }
+
+ template <unsigned D>
+ inline
+ unsigned
+ n_face_bkd_iter<D>::n() const
+ {
+ return face_.n();
+ }
+
+ template <unsigned D>
+ inline
+ void
+ n_face_bkd_iter<D>::set_n(unsigned n)
+ {
+ mln_precondition(n <= D);
+ face_.set_n(n);
+ }
+
+# endif // ! MLN_INCLUDE_ONLY
+
+ } // end of namespace mln::topo
+
+} // end of namespace mln
+
+#endif // ! MLN_TOPO_N_FACE_ITER_HH
diff --git a/milena/tests/topo/complex.cc b/milena/tests/topo/complex.cc
index 4d220e7..16099f5 100644
--- a/milena/tests/topo/complex.cc
+++ b/milena/tests/topo/complex.cc
@@ -148,6 +148,18 @@ int main()
actual complex processing since they are not really flexible ---
but I'm not sure. */
+ // Dynamic version.
+ for (unsigned n = 0; n <= D; ++n)
+ {
+ topo::n_face_fwd_iter<D> fwd_nf(c, n);
+ topo::n_face_fwd_iter<D> bkd_nf(c, n);
+ std::cout << "test (dynamic) n_face_iters (n = " << n << "):"
+ << std::endl;
+ for_all_2(fwd_nf, bkd_nf)
+ std::cout << fwd_nf << ' ' << bkd_nf << std::endl;
+ std::cout << std::endl;
+ }
+
// Static version.
test_static_n_face_iter<0>(c);
test_static_n_face_iter<1>(c);
@@ -200,15 +212,21 @@ int main()
-----------------------------------------------------------------
Name Definition
-----------------------------------------------------------------
- complex<D> General complex
+ complex<D> General complex.
- face_data<N, D> Face data
- n_face<N, D> (Static) n-face handle
- n_faces_set<N, D> Set of face handles
- face<D> Dynamic face handle
+ face_data<N, D> Face data.
+ n_face<N, D> (Static) n-face handle.
+ n_faces_set<N, D> Set of face handles.
+ face<D> Dynamic face handle.
face_fwd_iter<D>(c) | Iterators on all the faces
- face_bkd_iter<D>(c) | of c
+ face_bkd_iter<D>(c) | of c.
+
+ n_face_fwd_iter<D>(c) | Iterators on n-faces,
+ n_face_bkd_iter<D>(c) | n being dynamic.
+
+ static_n_face_fwd_iter<D>(c) | Iterators on n-faces,
+ static_n_face_bkd_iter<D>(c) | n being static.
internal::complex_iter_base<F, E> Factoring base class.
-----------------------------------------------------------------
@@ -224,9 +242,6 @@ int main()
-----------------------------------------------------------------
Name Definition
-----------------------------------------------------------------
- n_faces_fwd_iter<D>(c) | Iterators on n-faces,
- n_faces_bkd_iter<D>(c) | n being dynamic
-
adj_lower_faces_fwd_iter<D>(c, f) | Iterators on the adjacent
adj_lower_faces_bkd_iter<D>(c, f) | (lower) (n-1)-faces of the
| n-face f of the complex c,
--
1.6.0.1
* milena/mln/core/site_set/p_complex_faces_piter.hh,
* milena/mln/core/site_set/p_faces_piter.hh,
* milena/mln/topo/complex_faces_iter.hh,
* milena/mln/topo/faces_iter.hh:
Move...
* milena/mln/core/site_set/attic/p_complex_faces_piter.hh,
* milena/mln/core/site_set/attic/p_faces_piter.hh,
* milena/mln/topo/attic/complex_faces_iter.hh,
* milena/mln/topo/attic/faces_iter.hh:
...here.
Disable these iterators...
* milena/mln/core/site_set/p_complex.hh,
* milena/mln/core/site_set/p_faces.hh,
* milena/mln/topo/complex.hh,
* milena/tests/core/image/complex_image.cc,
* milena/tests/topo/complex.cc:
...in those files.
---
milena/ChangeLog | 22 ++++++++++++++++++++
.../site_set/{ => attic}/p_complex_faces_piter.hh | 0
.../mln/core/site_set/{ => attic}/p_faces_piter.hh | 0
milena/mln/core/site_set/p_complex.hh | 9 ++++++-
milena/mln/core/site_set/p_faces.hh | 6 ++++-
milena/mln/topo/{ => attic}/complex_faces_iter.hh | 0
milena/mln/topo/{ => attic}/faces_iter.hh | 0
milena/mln/topo/complex.hh | 14 ++++++++++--
milena/tests/core/image/complex_image.cc | 8 ++----
milena/tests/topo/complex.cc | 13 ++++++++++-
10 files changed, 59 insertions(+), 13 deletions(-)
rename milena/mln/core/site_set/{ => attic}/p_complex_faces_piter.hh (100%)
rename milena/mln/core/site_set/{ => attic}/p_faces_piter.hh (100%)
rename milena/mln/topo/{ => attic}/complex_faces_iter.hh (100%)
rename milena/mln/topo/{ => attic}/faces_iter.hh (100%)
diff --git a/milena/ChangeLog b/milena/ChangeLog
index 9bd58d5..d105628 100644
--- a/milena/ChangeLog
+++ b/milena/ChangeLog
@@ -1,5 +1,27 @@
2008-09-26 Roland Levillain <roland(a)lrde.epita.fr>
+ Disable old iterators on n-faces (with n statically known).
+
+ * milena/mln/core/site_set/p_complex_faces_piter.hh,
+ * milena/mln/core/site_set/p_faces_piter.hh,
+ * milena/mln/topo/complex_faces_iter.hh,
+ * milena/mln/topo/faces_iter.hh:
+ Move...
+ * milena/mln/core/site_set/attic/p_complex_faces_piter.hh,
+ * milena/mln/core/site_set/attic/p_faces_piter.hh,
+ * milena/mln/topo/attic/complex_faces_iter.hh,
+ * milena/mln/topo/attic/faces_iter.hh:
+ ...here.
+ Disable these iterators...
+ * milena/mln/core/site_set/p_complex.hh,
+ * milena/mln/core/site_set/p_faces.hh,
+ * milena/mln/topo/complex.hh,
+ * milena/tests/core/image/complex_image.cc,
+ * milena/tests/topo/complex.cc:
+ ...in those files.
+
+2008-09-26 Roland Levillain <roland(a)lrde.epita.fr>
+
Split mln/topo/face.hh.
* milena/mln/topo/face.hh
diff --git a/milena/mln/core/site_set/p_complex_faces_piter.hh b/milena/mln/core/site_set/attic/p_complex_faces_piter.hh
similarity index 100%
rename from milena/mln/core/site_set/p_complex_faces_piter.hh
rename to milena/mln/core/site_set/attic/p_complex_faces_piter.hh
diff --git a/milena/mln/core/site_set/p_faces_piter.hh b/milena/mln/core/site_set/attic/p_faces_piter.hh
similarity index 100%
rename from milena/mln/core/site_set/p_faces_piter.hh
rename to milena/mln/core/site_set/attic/p_faces_piter.hh
diff --git a/milena/mln/core/site_set/p_complex.hh b/milena/mln/core/site_set/p_complex.hh
index a747b69..06fc8b2 100644
--- a/milena/mln/core/site_set/p_complex.hh
+++ b/milena/mln/core/site_set/p_complex.hh
@@ -37,7 +37,10 @@
# include <mln/core/site_set/complex_psite.hh>
# include <mln/core/site_set/p_complex_piter.hh>
-# include <mln/core/site_set/p_complex_faces_piter.hh>
+// FIXME: Disabled (moved to the attic).
+# if 0
+# include <mln/core/site_set/p_complex_faces_piter.hh>
+# endif
namespace mln
@@ -49,11 +52,13 @@ namespace mln
template <unsigned D, typename P> class p_complex_fwd_piter_;
template <unsigned D, typename P> class p_complex_bkd_piter_;
+// FIXME: Disabled (moved to the attic).
+# if 0
template <unsigned N, unsigned D, typename P>
class p_complex_faces_fwd_piter_;
template <unsigned N, unsigned D, typename P>
class p_complex_faces_bkd_piter_;
-
+# endif
namespace trait
{
diff --git a/milena/mln/core/site_set/p_faces.hh b/milena/mln/core/site_set/p_faces.hh
index b17f85a..6df4ded 100644
--- a/milena/mln/core/site_set/p_faces.hh
+++ b/milena/mln/core/site_set/p_faces.hh
@@ -37,7 +37,11 @@
# include <mln/topo/complex.hh>
# include <mln/core/faces_psite.hh>
-# include <mln/core/site_set/p_faces_piter.hh>
+
+// FIXME: Disabled (moved to the attic).
+# if 0
+# include <mln/core/site_set/p_faces_piter.hh>
+# endif
# include <mln/core/site_set/p_complex.hh>
diff --git a/milena/mln/topo/complex_faces_iter.hh b/milena/mln/topo/attic/complex_faces_iter.hh
similarity index 100%
rename from milena/mln/topo/complex_faces_iter.hh
rename to milena/mln/topo/attic/complex_faces_iter.hh
diff --git a/milena/mln/topo/faces_iter.hh b/milena/mln/topo/attic/faces_iter.hh
similarity index 100%
rename from milena/mln/topo/faces_iter.hh
rename to milena/mln/topo/attic/faces_iter.hh
diff --git a/milena/mln/topo/complex.hh b/milena/mln/topo/complex.hh
index bef3ca9..2ce88fd 100644
--- a/milena/mln/topo/complex.hh
+++ b/milena/mln/topo/complex.hh
@@ -49,9 +49,11 @@
# include <mln/topo/n_faces_set.hh>
# include <mln/topo/complex_iter.hh>
-# include <mln/topo/faces_iter.hh>
-# include <mln/topo/complex_faces_iter.hh>
-
+// FIXME: Disabled (moved to the attic).
+# if 0
+# include <mln/topo/faces_iter.hh>
+# include <mln/topo/complex_faces_iter.hh>
+# endif
namespace mln
{
@@ -63,8 +65,11 @@ namespace mln
template <unsigned N, unsigned D> class n_faces_set;
template <unsigned D> class complex_fwd_iter_;
template <unsigned D> class complex_bkd_iter_;
+// FIXME: Disabled (moved to the attic).
+# if 0
template <unsigned N, unsigned D> class faces_fwd_iter_;
template <unsigned N, unsigned D> class faces_bkd_iter_;
+#endif
// Forward declarations (internal).
namespace internal
@@ -91,12 +96,15 @@ namespace mln
/// Backward mln::Iterator type iterating on all faces.
typedef complex_bkd_iter_<D> bkd_citer;
+// FIXME: Disabled (moved to the attic).
+# if 0
/// Forward mln::Iterator type iterating on \p N-faces.
template <unsigned N>
struct fwd_fiter { typedef faces_fwd_iter_<N, D> ret; };
/// Backward mln::Iterator type iterating on \p N-faces.
template <unsigned N>
struct bkd_fiter { typedef faces_bkd_iter_<N, D> ret; };
+#endif
/// Complex construction.
/// \{
diff --git a/milena/tests/core/image/complex_image.cc b/milena/tests/core/image/complex_image.cc
index 148041d..47233cb 100644
--- a/milena/tests/core/image/complex_image.cc
+++ b/milena/tests/core/image/complex_image.cc
@@ -164,15 +164,13 @@ int main()
// Iterators on n-faces (with n fixed in [0, D]). //
// ----------------------------------------------- //
- // We need to instantiate a (non temporary) object on the stack, so
- // that it can be referenced later by face_psites held by iterators
- // (as for windows and neighborhoods).
-
+// FIXME: Disabled (moved to the attic).
+# if 0
// FIXME: Sugar the name of the iterator.
p_complex_faces_fwd_piter_<0, D, point2d> f0p(ima.domain());
for_all(f0p)
std::cout << "ima(" << f0p << ") = " << ima(f0p) << std::endl;
-
+#endif
/* FIXME: Implement other psite iterators, for instance:
diff --git a/milena/tests/topo/complex.cc b/milena/tests/topo/complex.cc
index 6b8c17e..eeaeb14 100644
--- a/milena/tests/topo/complex.cc
+++ b/milena/tests/topo/complex.cc
@@ -143,6 +143,8 @@ int main()
actual complex processing since they are not really flexible ---
but I'm not sure. */
+// FIXME: Disabled (moved to the attic).
+# if 0
/* Using faces_{fwd,bkd}_iter_<N, D>, which are proxies to
n_faces<N, D>. */
test_faces_iter<0>(c);
@@ -154,6 +156,7 @@ int main()
test_complex_faces_iter<0>(c);
test_complex_faces_iter<1>(c);
test_complex_faces_iter<2>(c);
+#endif
/*------------------------------.
| Iterators on adjacent faces. |
@@ -269,8 +272,11 @@ int main()
| define the iterated subset.
-----------------------------------------------------------------
- I'm unsure about the following existing iterators; should we keep
- them? What are they good for, except testing our code?
+
+ I'm unsure about the old iterators on n-faces (with a static n)
+ moved to the attic; should we keep them? What are they good for,
+ except testing our code? At least, we should find better names
+ for them, as we might confuse them with new iterators.
-----------------------------------------------------------------
Current name Definition
@@ -287,6 +293,8 @@ int main()
}
+// FIXME: Disabled (moved to the attic).
+# if 0
template <unsigned N, unsigned D>
void
test_faces_iter(topo::complex<D>& c)
@@ -315,3 +323,4 @@ test_complex_faces_iter(topo::complex<D>& c)
std::cout << fwd_ncf << ' ' << bkd_ncf << std::endl;
std::cout << std::endl;
}
+#endif
--
1.6.0.1