* tests/topo/complex.cc: Here.
---
milena/ChangeLog | 6 ++++++
milena/tests/topo/complex.cc | 41 +++++++++++++++++++++++++----------------
2 files changed, 31 insertions(+), 16 deletions(-)
diff --git a/milena/ChangeLog b/milena/ChangeLog
index 4ebc231..57729ee 100644
--- a/milena/ChangeLog
+++ b/milena/ChangeLog
@@ -1,5 +1,11 @@
2008-10-03 Roland Levillain <roland(a)lrde.epita.fr>
+ Exercise iterators lower+higher-dimension adjacent faces.
+
+ * tests/topo/complex.cc: Here.
+
+2008-10-03 Roland Levillain <roland(a)lrde.epita.fr>
+
Add iterators on both lower- and higher-dimension adjacent faces.
* mln/topo/adj_lower_higher_face_iter.hh: New.
diff --git a/milena/tests/topo/complex.cc b/milena/tests/topo/complex.cc
index f079734..9e559de 100644
--- a/milena/tests/topo/complex.cc
+++ b/milena/tests/topo/complex.cc
@@ -36,6 +36,9 @@
using namespace mln;
+/* FIXME: Split this test (and maybe factor common parts, like the
+ construction of the complex), since it exercises too many features
+ in a single file. */
// Forward declarations.
template <unsigned N, unsigned D>
@@ -207,26 +210,18 @@ int main()
milena/tests/core/complex_image.cc) and ticket #162
(
https://trac.lrde.org/olena/ticket/162) */
- /* Iterate on the the set of (n-1)- and (n+1)-faces adjacent to the
- faces of C.
+ /* Iterate on the the set of (n-1)- and/or (n+1)-faces adjacent to
+ the faces of C.
Note: this can be solved with iterators where the dimension can
- be either static or dynamic.
+ be either static or dynamic. For the moment, our iterators are
+ dynamic w.r.t. the dimensions of the faces (both the reference
+ face and the iterated ones).
- Let's start with a dynamic one, as it would allow us to
- write something like this:
-
- mln_fwd_citer_(topo::complex<D>) f(c);
- mln_fwd_lower_nciter(topo::complex<D>) n(c);
- for_all(c)
- for_all(n)
- // ...
-
- (Note: we might want to get rid of the name `citer', and use
- `fiter' everywhere.).
-
- A static version might be useful (and more efficient) too. */
+ Static versions might be useful, and more efficient too, when
+ flexibility is not needed. */
+ // Iterate on the the set of (n-1)-faces adjacent to the faces of C.
topo::adj_lower_face_fwd_iter<D> fwd_alf(fwd_f);
topo::adj_lower_face_bkd_iter<D> bkd_alf(fwd_f);
for_all(fwd_f)
@@ -238,6 +233,7 @@ int main()
}
std::cout << std::endl;
+ // Iterate on the the set of (n+1)-faces adjacent to the faces of C.
topo::adj_higher_face_fwd_iter<D> fwd_ahf(fwd_f);
topo::adj_higher_face_bkd_iter<D> bkd_ahf(fwd_f);
for_all(fwd_f)
@@ -249,6 +245,19 @@ int main()
}
std::cout << std::endl;
+ // Iterate on the the set of (n+1)-faces *and* (n+1)-faces adjacent
+ // to the faces of C.
+ topo::adj_lower_higher_face_fwd_iter<D> fwd_alhf(fwd_f);
+ topo::adj_lower_higher_face_bkd_iter<D> bkd_alhf(fwd_f);
+ for_all(fwd_f)
+ {
+ std::cout << "Lower- and higher-dimension faces adjacent to "
<< fwd_f
+ << ": " << std::endl;
+ for_all_2(fwd_alhf, bkd_alhf)
+ std::cout << " " << fwd_alhf << '\t' <<
bkd_alhf << std::endl;
+ }
+ std::cout << std::endl;
+
/* But first, we need to clarify (existing) names. The one listed
in
https://trac.lrde.org/olena/wiki/Olena/ComplexBasedImages
are OK.
--
1.6.0.1