URL: https://svn.lrde.epita.fr/svn/oln/trunk/milena
ChangeLog:
2007-10-12 Guillaume Duhamel <guillaume.duhamel(a)lrde.epita.fr>
Add tests for queue.
* queue_p_fast.cc,
* queue_p_fast_priority.cc,
* queue_p_priority.cc: New tests.
* image2d.cc: Update test for (id_) in mln/core/internal.
---
image2d.cc | 10 ++++
queue_p_fast.cc | 57 +++++++++++++++++++++++++++
queue_p_fast_priority.cc | 98 +++++++++++++++++++++++++++++++++++++++++++++++
queue_p_priority.cc | 98 +++++++++++++++++++++++++++++++++++++++++++++++
4 files changed, 263 insertions(+)
Index: trunk/milena/tests/image2d.cc
===================================================================
--- trunk/milena/tests/image2d.cc (revision 1324)
+++ trunk/milena/tests/image2d.cc (revision 1325)
@@ -34,6 +34,7 @@
#include <mln/geom/size2d.hh>
#include <mln/core/init.hh>
+#include <mln/border/resize.hh>
@@ -47,6 +48,15 @@
image2d<int> f(nrows, ncols, border);
+ {
+ std::cout << f.id_() << std::endl;
+ image2d<int> g;
+ std::cout << g.id_() << std::endl;
+ g = f;
+ // border::resize (g, 2);
+ std::cout << g.id_() << std::endl;
+ }
+
mln_assertion(f.npoints() == geom::nrows(f) * geom::ncols(f));
mln_assertion(f.ncells() == (nrows + 2 * border) * (ncols + 2 * border));
}
Index: trunk/milena/tests/queue_p_fast.cc
===================================================================
--- trunk/milena/tests/queue_p_fast.cc (revision 0)
+++ trunk/milena/tests/queue_p_fast.cc (revision 1325)
@@ -0,0 +1,57 @@
+// Copyright (C) 2007 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.
+
+/*! \file tests/queue_p.cc
+ *
+ * \brief Tests on mln::queue_p.
+ */
+
+#include <mln/core/point2d.hh>
+#include <mln/core/queue_p_fast.hh>
+
+
+
+int main()
+{
+ using namespace mln;
+
+ queue_p_fast<point2d> q;
+ q
+ .push(make::point2d(6, 9))
+ .push(make::point2d(5, 1))
+ .push(make::point2d(4, 2));
+ mln_assertion(q.npoints() == 3);
+
+ std::cout << q.bbox() << std::endl;
+ std::cout << q << std::endl;
+
+ q.pop();
+ mln_assertion(q.npoints() == 2);
+ point2d p = q.front();
+ mln_assertion(q.npoints() == 2);
+ mln_assertion(p == make::point2d(5, 1));
+}
Index: trunk/milena/tests/queue_p_priority.cc
===================================================================
--- trunk/milena/tests/queue_p_priority.cc (revision 0)
+++ trunk/milena/tests/queue_p_priority.cc (revision 1325)
@@ -0,0 +1,98 @@
+// Copyright (C) 2007 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.
+
+/*! \file tests/queue_p_priority.cc
+ *
+ * \brief Tests on mln::queue_p_priority.
+ */
+
+#include <mln/core/point2d.hh>
+#include <mln/core/queue_p_priority.hh>
+
+int main ()
+{
+ using namespace mln;
+
+ mln::queue_p_priority<point2d, unsigned> q;
+ point2d p1 (6, 9);
+ point2d p2 (5, 1);
+ point2d p3 (4, 2);
+
+ mln_assertion (q.empty ());
+
+ mln_assertion (q.npoints () == 0);
+
+ q.push_force (p3);
+ q.push_force (p1, 3);
+ q.push_force (p2, 5);
+
+ std::cout << q.bbox () << std::endl;
+ std::cout << q << std::endl;
+
+ mln_assertion (!q.empty ());
+
+ mln_assertion (q.has (p1));
+ mln_assertion (q.has (p2));
+ mln_assertion (q.has (p3));
+
+ mln_assertion (q.npoints () == 3);
+ mln_assertion (q.front () == p2);
+ q.pop ();
+
+ mln_assertion (q.has (p1));
+ mln_assertion (!q.has (p2));
+ mln_assertion (q.has (p3));
+
+ mln_assertion (q.npoints () == 2);
+ mln_assertion (q.front () == p1);
+ q.pop ();
+
+ mln_assertion (!q.has (p1));
+ mln_assertion (!q.has (p2));
+ mln_assertion (q.has (p3));
+
+ mln_assertion (q.npoints () == 1);
+ mln_assertion (q.front () == p3);
+ q.pop ();
+
+ mln_assertion (!q.has (p1));
+ mln_assertion (!q.has (p2));
+ mln_assertion (!q.has (p3));
+ mln_assertion (q.npoints () == 0);
+
+ mln_assertion (q.empty ());
+
+ q.push_force (p3);
+ q.push_force (p2, 5);
+ q.push_force (p1, 3);
+
+ mln_assertion (q[2] == p3);
+ mln_assertion (q[1] == p1);
+ mln_assertion (q[0] == p2);
+ q.clear ();
+ mln_assertion (q.empty ());
+}
Index: trunk/milena/tests/queue_p_fast_priority.cc
===================================================================
--- trunk/milena/tests/queue_p_fast_priority.cc (revision 0)
+++ trunk/milena/tests/queue_p_fast_priority.cc (revision 1325)
@@ -0,0 +1,98 @@
+// Copyright (C) 2007 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.
+
+/*! \file tests/queue_p_priority.cc
+ *
+ * \brief Tests on mln::queue_p_priority.
+ */
+
+#include <mln/core/point2d.hh>
+#include <mln/core/queue_p_fast_priority.hh>
+
+int main ()
+{
+ using namespace mln;
+
+ mln::queue_p_fast_priority<point2d, unsigned> q;
+ point2d p1 (6, 9);
+ point2d p2 (5, 1);
+ point2d p3 (4, 2);
+
+ mln_assertion (q.empty ());
+
+ mln_assertion (q.npoints () == 0);
+
+ q.push_force (p3);
+ q.push_force (p1, 3);
+ q.push_force (p2, 5);
+
+ std::cout << q.bbox () << std::endl;
+ std::cout << q << std::endl;
+
+ mln_assertion (!q.empty ());
+
+ mln_assertion (q.has (p1));
+ mln_assertion (q.has (p2));
+ mln_assertion (q.has (p3));
+
+ mln_assertion (q.npoints () == 3);
+ mln_assertion (q.front () == p2);
+ q.pop ();
+
+ mln_assertion (q.has (p1));
+ mln_assertion (!q.has (p2));
+ mln_assertion (q.has (p3));
+
+ mln_assertion (q.npoints () == 2);
+ mln_assertion (q.front () == p1);
+ q.pop ();
+
+ mln_assertion (!q.has (p1));
+ mln_assertion (!q.has (p2));
+ mln_assertion (q.has (p3));
+
+ mln_assertion (q.npoints () == 1);
+ mln_assertion (q.front () == p3);
+ q.pop ();
+
+ mln_assertion (!q.has (p1));
+ mln_assertion (!q.has (p2));
+ mln_assertion (!q.has (p3));
+ mln_assertion (q.npoints () == 0);
+
+ mln_assertion (q.empty ());
+
+ q.push_force (p3);
+ q.push_force (p2, 5);
+ q.push_force (p1, 3);
+
+ mln_assertion (q[2] == p3);
+ mln_assertion (q[1] == p1);
+ mln_assertion (q[0] == p2);
+ q.clear ();
+ mln_assertion (q.empty ());
+}
URL: https://svn.lrde.epita.fr/svn/oln/trunk/milena
ChangeLog:
2007-10-12 Guillaume Duhamel <guillaume.duhamel(a)lrde.epita.fr>
Add new kind of queue.
* queue_p_fast.hh,
* queue_p_fast_priority.hh,
* queue_p_priority.hh: New kind of queue.
* internal/image_base.hh: Add (id_).
---
internal/image_base.hh | 2
queue_p_fast.hh | 275 ++++++++++++++++++++++++++++++++++++++++
queue_p_fast_priority.hh | 322 +++++++++++++++++++++++++++++++++++++++++++++++
queue_p_priority.hh | 321 ++++++++++++++++++++++++++++++++++++++++++++++
4 files changed, 920 insertions(+)
Index: trunk/milena/mln/core/internal/image_base.hh
===================================================================
--- trunk/milena/mln/core/internal/image_base.hh (revision 1323)
+++ trunk/milena/mln/core/internal/image_base.hh (revision 1324)
@@ -156,6 +156,8 @@
const util::tracked_ptr< internal::data_<E> >& hook_data_() const { return data_; }
+ const void* id_() const { return data_.ptr_; }
+
protected:
image_base_();
Index: trunk/milena/mln/core/queue_p_fast.hh
===================================================================
--- trunk/milena/mln/core/queue_p_fast.hh (revision 0)
+++ trunk/milena/mln/core/queue_p_fast.hh (revision 1324)
@@ -0,0 +1,275 @@
+// Copyright (C) 2007 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_CORE_QUEUE_P_FAST_HH
+# define MLN_CORE_QUEUE_P_FAST_HH
+
+/*! \file mln/core/queue_p_fast.hh
+ *
+ * \brief Definition of a point set class based on std::deque.
+ */
+
+# include <vector>
+# include <deque>
+# include <algorithm>
+# include <iterator>
+
+# include <mln/core/internal/point_set_base.hh>
+# include <mln/core/vec_p_piter.hh>
+# include <mln/accu/bbox.hh>
+
+
+namespace mln
+{
+
+ // Fwd decls.
+ template <typename P> struct vec_p_fwd_piter_;
+ template <typename P> struct vec_p_bkd_piter_;
+
+
+ /*! \brief Point queue class (based on std::deque).
+ *
+ * This is a mathematical set of points (unique insertion).
+ *
+ * \todo Make it work with P being a Point_Site.
+ * \todo Add a parameter flag to choose another policy for "push"
+ * (i.e., no-op if multiple or allow multiple insertions).
+ *
+ * \warning We have some troubles with point set comparison based on
+ * a call to npoints() when this container is multiple.
+ */
+ template <typename P>
+ class queue_p_fast : public internal::point_set_base_< P, queue_p_fast<P> >
+ {
+ public:
+
+ /// Forward Point_Iterator associated type.
+ typedef vec_p_fwd_piter_<P> fwd_piter;
+
+ /// Backward Point_Iterator associated type.
+ typedef vec_p_bkd_piter_<P> bkd_piter;
+
+ /// Constructor.
+ queue_p_fast();
+
+ /// Test is \p p belongs to this point set.
+ bool has(const P& p) const;
+
+ /// Test if queue is empty or not.
+ bool empty() const;
+
+ /// Give the number of points.
+ std::size_t npoints() const;
+
+ /// Give the exact bounding box.
+ const box_<P>& bbox() const;
+
+ /// Push force a point \p p in the queue.
+ queue_p_fast<P>& push_force(const P& p);
+
+ /// Push a point \p p in the queue.
+ queue_p_fast<P>& push(const P& p);
+
+ /// Pop (remove) the front point \p p from the queue; \p p is the
+ /// least recently inserted point.
+ void pop();
+
+ /// Give the front point \p p of the queue; \p p is the least
+ /// recently inserted point.
+ const P& front() const;
+
+ /// Clear the queue.
+ void clear();
+
+ /// Return the corresponding std::vector of points.
+ const std::vector<P>& vect() const;
+
+ /// Return the \p i-th point.
+ const P& operator[](unsigned i) const;
+
+ protected:
+
+ std::vector<P> q_;
+ std::size_t begin_;
+ std::size_t end_;
+
+ mutable std::vector<P> vect_;
+ mutable bool vect_needs_update_;
+ void vect_update_() const;
+
+ mutable accu::bbox<P> bb_;
+ mutable bool bb_needs_update_;
+ void bb_update_() const;
+ };
+
+
+
+# ifndef MLN_INCLUDE_ONLY
+
+ template <typename P>
+ queue_p_fast<P>::queue_p_fast()
+ {
+ // vect_needs_update_ = false;
+ bb_needs_update_ = false;
+ begin_ = 0;
+ end_ = 0;
+ }
+
+ template <typename P>
+ void
+ queue_p_fast<P>::vect_update_() const
+ {
+ vect_.clear();
+ vect_.reserve(q_.size());
+ std::copy(q_.begin(), q_.end(),
+ std::back_inserter(vect_));
+ vect_needs_update_ = false;
+ }
+
+ template <typename P>
+ void
+ queue_p_fast<P>::bb_update_() const
+ {
+ bb_.init();
+ for (std::size_t i = this->begin_; i < this->end_; ++i)
+ bb_.take(q_[i]);
+ bb_needs_update_ = false;
+ }
+
+ template <typename P>
+ bool
+ queue_p_fast<P>::has(const P& p) const
+ {
+ for (unsigned i = this->begin_; i < this->end_; ++i)
+ if (q_[i] == p)
+ return true;
+ return false;
+ }
+
+ template <typename P>
+ bool
+ queue_p_fast<P>::empty() const
+ {
+ return (this->begin_ == this->end_);
+ }
+
+ template <typename P>
+ std::size_t
+ queue_p_fast<P>::npoints() const
+ {
+ mln_precondition(this->end_ >= this->begin_);
+ return (this->end_ - this->begin_);
+ }
+
+ template <typename P>
+ const box_<P>&
+ queue_p_fast<P>::bbox() const
+ {
+ mln_precondition(npoints() != 0);
+ if (bb_needs_update_)
+ bb_update_();
+ return bb_.to_result();
+ }
+
+ template <typename P>
+ queue_p_fast<P>&
+ queue_p_fast<P>::push_force(const P& p)
+ {
+ q_.push_back(p);
+ ++this->end_;
+ if (! vect_needs_update_)
+ {
+ // vect_needs_update_ = true;
+ bb_needs_update_ = true;
+ }
+ return *this;
+ }
+
+ template <typename P>
+ queue_p_fast<P>&
+ queue_p_fast<P>::push(const P& p)
+ {
+ mln_precondition(! this->has(p));
+ // FIXME: Our choice is "error if multiple insertions"
+ return this->push_force(p);
+ }
+
+ template <typename P>
+ void
+ queue_p_fast<P>::pop()
+ {
+ ++this->begin_;
+// q_.pop_front();
+// if (! vect_needs_update_)
+// {
+// vect_needs_update_ = true;
+// bb_needs_update_ = true;
+// }
+ }
+
+ template <typename P>
+ const P&
+ queue_p_fast<P>::front() const
+ {
+ mln_precondition(! this->empty());
+ return q_[begin_];
+ }
+
+ template <typename P>
+ void
+ queue_p_fast<P>::clear()
+ {
+ this->end_ = begin_;
+// q_.clear();
+// vect_.clear();
+// vect_needs_update_ = false;
+ bb_needs_update_ = false;
+ }
+
+ template <typename P>
+ const std::vector<P>&
+ queue_p_fast<P>::vect() const
+ {
+ if (vect_needs_update_)
+ vect_update_();
+ return vect_;
+ }
+
+ template <typename P>
+ const P&
+ queue_p_fast<P>::operator[](unsigned i) const
+ {
+ mln_precondition(i < npoints());
+ return q_[begin_ + i];
+ }
+
+# endif // ! MLN_INCLUDE_ONLY
+
+} // end of namespace mln
+
+
+#endif // ! MLN_CORE_QUEUE_P_FAST_HH
Index: trunk/milena/mln/core/queue_p_fast_priority.hh
===================================================================
--- trunk/milena/mln/core/queue_p_fast_priority.hh (revision 0)
+++ trunk/milena/mln/core/queue_p_fast_priority.hh (revision 1324)
@@ -0,0 +1,322 @@
+// Copyright (C) 2007 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_CORE_QUEUE_P_FAST_PRIORITY_HH
+# define MLN_CORE_QUEUE_P_FAST_PRIORITY_HH
+
+/*! \file mln/core/queue_p_fast_priority.hh
+ *
+ * \brief Definition of a point set class based on std::deque
+ * and std::map.
+ */
+
+# include <vector>
+# include <deque>
+# include <map>
+# include <algorithm>
+# include <iterator>
+
+# include <mln/core/internal/point_set_base.hh>
+# include <mln/core/vec_p_piter.hh>
+# include <mln/accu/bbox.hh>
+# include <mln/core/queue_p_fast.hh>
+
+namespace mln
+{
+
+ // Fwd decls.
+ template <typename P> struct vec_p_fwd_piter_;
+ template <typename P> struct vec_p_bkd_piter_;
+
+
+ /*! \brief Point queue class (based on std::deque).
+ *
+ * This is a mathematical set of points (unique insertion).
+ *
+ * \todo Make it work with P being a Point_Site.
+ * \todo Add a parameter flag to choose another policy for "push"
+ * (i.e., no-op if multiple or allow multiple insertions).
+ *
+ * \warning We have some troubles with point set comparison based on
+ * a call to npoints() when this container is multiple.
+ */
+ template <typename P, typename T>
+ class queue_p_fast_priority : public internal::point_set_base_< P, queue_p_fast_priority<P, T> >
+ {
+ public:
+
+ /// Forward Point_Iterator associated type.
+ typedef vec_p_fwd_piter_<P> fwd_piter;
+
+ /// Backward Point_Iterator associated type.
+ typedef vec_p_bkd_piter_<P> bkd_piter;
+
+ /// Constructor.
+ queue_p_fast_priority();
+
+ /// Test is \p p belongs to this point set.
+ bool has(const P& p) const;
+
+ /// Test if queue is empty or not.
+ bool empty() const;
+
+ /// Give the number of points.
+ unsigned npoints() const;
+
+ /// Give the exact bounding box.
+ const box_<P>& bbox() const;
+
+ /// Push force a point \p p in the queue.
+ queue_p_fast_priority<P, T>& push_force(const P& p, T prio = 0);
+
+ /// Push a point \p p in the queue.
+ queue_p_fast_priority<P, T>& push(const P& p, T prio = 0);
+
+ /// Pop (remove) the front point \p p from the queue; \p p is the
+ /// least recently inserted point.
+ void pop();
+
+ /// Give the front point \p p of the queue; \p p is the least
+ /// recently inserted point.
+ const P& front() const;
+
+ /// Clear the queue.
+ void clear();
+
+ /// Return the corresponding std::vector of points.
+ const std::vector<P>& vect() const;
+
+ /// Return the \p i-th point.
+ const P& operator[](unsigned i) const;
+
+ protected:
+
+ std::map<const T, queue_p_fast<P> > q_;
+
+ mutable std::vector<P> vect_;
+ mutable bool vect_needs_update_;
+ void vect_update_() const;
+
+ mutable accu::bbox<P> bb_;
+ mutable bool bb_needs_update_;
+ void bb_update_() const;
+
+ };
+
+
+
+# ifndef MLN_INCLUDE_ONLY
+
+ template <typename P, typename T>
+ queue_p_fast_priority<P, T>::queue_p_fast_priority()
+ {
+ vect_needs_update_ = false;
+ bb_needs_update_ = false;
+ }
+
+ template <typename P, typename T>
+ void
+ queue_p_fast_priority<P, T>::vect_update_() const
+ {
+ vect_.clear();
+ vect_.reserve(npoints());
+
+ typename std::map<T, queue_p_fast<P> >::const_iterator it = q_.begin ();
+
+ for (; it != q_.end (); ++it)
+ std::copy((*it).second.vect().begin(), (*it).second.vect().end(),
+ std::back_inserter(vect_));
+ vect_needs_update_ = false;
+ }
+
+ template <typename P, typename T>
+ void
+ queue_p_fast_priority<P, T>::bb_update_() const
+ {
+ bb_.init();
+
+ typename std::map<T, queue_p_fast<P> >::const_iterator it = q_.begin ();
+
+ for (; it != q_.end (); ++it)
+ for (unsigned i = 0; i < (*it).second.npoints (); ++i)
+ bb_.take((*it).second[i]);
+ bb_needs_update_ = false;
+ }
+
+
+ template <typename P, typename T>
+ bool
+ queue_p_fast_priority<P, T>::has(const P& p) const
+ {
+ typename std::map<T, queue_p_fast<P> >::const_iterator it = q_.begin ();
+
+ for (; it != q_.end (); ++it)
+ if ((*it).second.has (p))
+ return true;
+ return false;
+ }
+
+ template <typename P, typename T>
+ bool
+ queue_p_fast_priority<P, T>::empty() const
+ {
+ typename std::map<T, queue_p_fast<P> >::const_iterator it = q_.begin ();
+
+ for (; it != q_.end (); ++it)
+ if (!(*it).second.empty ())
+ return false;
+ return true;
+ }
+
+ template <typename P, typename T>
+ unsigned
+ queue_p_fast_priority<P, T>::npoints() const
+ {
+ unsigned res = 0;
+
+ typename std::map<T, queue_p_fast<P> >::const_iterator it = q_.begin ();
+
+ for (; it != q_.end (); ++it)
+ if (!(*it).second.empty ())
+ res += (*it).second.npoints();
+ return res;
+ }
+
+ template <typename P, typename T>
+ const box_<P>&
+ queue_p_fast_priority<P, T>::bbox() const
+ {
+ mln_precondition(npoints() != 0);
+ if (bb_needs_update_)
+ bb_update_();
+ return bb_.to_result();
+ }
+
+ template <typename P, typename T>
+ queue_p_fast_priority<P, T>&
+ queue_p_fast_priority<P, T>::push_force(const P& p, T prio)
+ {
+ q_[prio].push_force (p);
+ if (! vect_needs_update_)
+ {
+ vect_needs_update_ = true;
+ bb_needs_update_ = true;
+ }
+ return *this;
+ }
+
+ template <typename P, typename T>
+ queue_p_fast_priority<P, T>&
+ queue_p_fast_priority<P, T>::push(const P& p, T prio)
+ {
+ if (! has(p))
+ return this->push_force(p, prio);
+ else
+ return *this;
+ }
+
+ template <typename P, typename T>
+ void
+ queue_p_fast_priority<P, T>::pop()
+ {
+ typename std::map<T, queue_p_fast<P> >::reverse_iterator it = q_.rbegin ();
+
+ for (; it != q_.rend (); ++it)
+ if (!(*it).second.empty ())
+ return (*it).second.pop ();
+
+ if (! vect_needs_update_)
+ {
+ vect_needs_update_ = true;
+ bb_needs_update_ = true;
+ }
+ }
+
+ template <typename P, typename T>
+ const P&
+ queue_p_fast_priority<P, T>::front() const
+ {
+ mln_precondition(! q_.empty());
+
+ typename std::map<T, queue_p_fast<P> >::const_reverse_iterator it = q_.rbegin ();
+
+ for (; it != q_.rend (); ++it)
+ if (!(*it).second.empty ())
+ break;
+ return (*it).second.front ();
+ }
+
+ template <typename P, typename T>
+ void
+ queue_p_fast_priority<P, T>::clear()
+ {
+ typename std::map<T, queue_p_fast<P> >::iterator it = q_.begin ();
+
+ for (; it != q_.end (); ++it)
+ (*it).second.clear ();
+ q_.clear();
+ vect_needs_update_ = false;
+ bb_needs_update_ = false;
+ }
+
+ template <typename P, typename T>
+ const std::vector<P>&
+ queue_p_fast_priority<P, T>::vect() const
+ {
+ if (vect_needs_update_)
+ vect_update_();
+ return vect_;
+ }
+
+ template <typename P, typename T>
+ const P&
+ queue_p_fast_priority<P, T>::operator[](unsigned i) const
+ {
+ mln_precondition(i < npoints());
+
+ typename std::map<T, queue_p_fast<P> >::const_reverse_iterator it = q_.rbegin ();
+ unsigned cpt = 0;
+
+ for (; it != q_.rend (); ++it)
+ {
+ if (!(*it).second.empty ())
+ for (cpt = 0; cpt < (*it).second.npoints (); ++cpt)
+ {
+ if (i == 0)
+ return (*it).second[cpt];
+ --i;
+ }
+ }
+ return (*it).second[cpt];
+ }
+
+# endif // ! MLN_INCLUDE_ONLY
+
+} // end of namespace mln
+
+
+#endif // ! MLN_CORE_QUEUE_P_FAST_PRIORITY_HH
Index: trunk/milena/mln/core/queue_p_priority.hh
===================================================================
--- trunk/milena/mln/core/queue_p_priority.hh (revision 0)
+++ trunk/milena/mln/core/queue_p_priority.hh (revision 1324)
@@ -0,0 +1,321 @@
+// Copyright (C) 2007 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_CORE_QUEUE_P_PRIORITY_HH
+# define MLN_CORE_QUEUE_P_PRIORITY_HH
+
+/*! \file mln/core/queue_p_priority.hh
+ *
+ * \brief Definition of a point set class based on std::deque.
+ */
+
+# include <vector>
+# include <deque>
+# include <map>
+# include <algorithm>
+# include <iterator>
+
+# include <mln/core/internal/point_set_base.hh>
+# include <mln/core/vec_p_piter.hh>
+# include <mln/accu/bbox.hh>
+# include <mln/core/queue_p.hh>
+
+namespace mln
+{
+
+ // Fwd decls.
+ template <typename P> struct vec_p_fwd_piter_;
+ template <typename P> struct vec_p_bkd_piter_;
+
+
+ /*! \brief Point queue class (based on std::deque).
+ *
+ * This is a mathematical set of points (unique insertion).
+ *
+ * \todo Make it work with P being a Point_Site.
+ * \todo Add a parameter flag to choose another policy for "push"
+ * (i.e., no-op if multiple or allow multiple insertions).
+ *
+ * \warning We have some troubles with point set comparison based on
+ * a call to npoints() when this container is multiple.
+ */
+ template <typename P, typename T>
+ class queue_p_priority : public internal::point_set_base_< P, queue_p_priority<P, T> >
+ {
+ public:
+
+ /// Forward Point_Iterator associated type.
+ typedef vec_p_fwd_piter_<P> fwd_piter;
+
+ /// Backward Point_Iterator associated type.
+ typedef vec_p_bkd_piter_<P> bkd_piter;
+
+ /// Constructor.
+ queue_p_priority();
+
+ /// Test is \p p belongs to this point set.
+ bool has(const P& p) const;
+
+ /// Test if queue is empty or not.
+ bool empty() const;
+
+ /// Give the number of points.
+ unsigned npoints() const;
+
+ /// Give the exact bounding box.
+ const box_<P>& bbox() const;
+
+ /// Push force a point \p p in the queue.
+ queue_p_priority<P, T>& push_force(const P& p, T prio = 0);
+
+ /// Push a point \p p in the queue.
+ queue_p_priority<P, T>& push(const P& p, T prio = 0);
+
+ /// Pop (remove) the front point \p p from the queue; \p p is the
+ /// least recently inserted point.
+ void pop();
+
+ /// Give the front point \p p of the queue; \p p is the least
+ /// recently inserted point.
+ const P& front() const;
+
+ /// Clear the queue.
+ void clear();
+
+ /// Return the corresponding std::vector of points.
+ const std::vector<P>& vect() const;
+
+ /// Return the \p i-th point.
+ const P& operator[](unsigned i) const;
+
+ protected:
+
+ std::map<const T, queue_p<P> > q_;
+
+ mutable std::vector<P> vect_;
+ mutable bool vect_needs_update_;
+ void vect_update_() const;
+
+ mutable accu::bbox<P> bb_;
+ mutable bool bb_needs_update_;
+ void bb_update_() const;
+
+ };
+
+
+
+# ifndef MLN_INCLUDE_ONLY
+
+ template <typename P, typename T>
+ queue_p_priority<P, T>::queue_p_priority()
+ {
+ vect_needs_update_ = false;
+ bb_needs_update_ = false;
+ }
+
+ template <typename P, typename T>
+ void
+ queue_p_priority<P, T>::vect_update_() const
+ {
+ vect_.clear();
+ vect_.reserve(npoints());
+
+ typename std::map<T, queue_p<P> >::const_iterator it = q_.begin ();
+
+ for (; it != q_.end (); ++it)
+ std::copy((*it).second.vect().begin(), (*it).second.vect().end(),
+ std::back_inserter(vect_));
+ vect_needs_update_ = false;
+ }
+
+ template <typename P, typename T>
+ void
+ queue_p_priority<P, T>::bb_update_() const
+ {
+ bb_.init();
+
+ typename std::map<T, queue_p<P> >::const_iterator it = q_.begin ();
+
+ for (; it != q_.end (); ++it)
+ for (unsigned i = 0; i < (*it).second.npoints (); ++i)
+ bb_.take((*it).second[i]);
+ bb_needs_update_ = false;
+ }
+
+
+ template <typename P, typename T>
+ bool
+ queue_p_priority<P, T>::has(const P& p) const
+ {
+ typename std::map<T, queue_p<P> >::const_iterator it = q_.begin ();
+
+ for (; it != q_.end (); ++it)
+ if ((*it).second.has (p))
+ return true;
+ return false;
+ }
+
+ template <typename P, typename T>
+ bool
+ queue_p_priority<P, T>::empty() const
+ {
+ typename std::map<T, queue_p<P> >::const_iterator it = q_.begin ();
+
+ for (; it != q_.end (); ++it)
+ if (!(*it).second.empty ())
+ return false;
+ return true;
+ }
+
+ template <typename P, typename T>
+ unsigned
+ queue_p_priority<P, T>::npoints() const
+ {
+ unsigned res = 0;
+
+ typename std::map<T, queue_p<P> >::const_iterator it = q_.begin ();
+
+ for (; it != q_.end (); ++it)
+ if (!(*it).second.empty ())
+ res += (*it).second.npoints();
+ return res;
+ }
+
+ template <typename P, typename T>
+ const box_<P>&
+ queue_p_priority<P, T>::bbox() const
+ {
+ mln_precondition(npoints() != 0);
+ if (bb_needs_update_)
+ bb_update_();
+ return bb_.to_result();
+ }
+
+ template <typename P, typename T>
+ queue_p_priority<P, T>&
+ queue_p_priority<P, T>::push_force(const P& p, T prio)
+ {
+ q_[prio].push_force (p);
+ if (! vect_needs_update_)
+ {
+ vect_needs_update_ = true;
+ bb_needs_update_ = true;
+ }
+ return *this;
+ }
+
+ template <typename P, typename T>
+ queue_p_priority<P, T>&
+ queue_p_priority<P, T>::push(const P& p, T prio)
+ {
+ if (! has(p))
+ return this->push_force(p, prio);
+ else
+ return *this;
+ }
+
+ template <typename P, typename T>
+ void
+ queue_p_priority<P, T>::pop()
+ {
+ typename std::map<T, queue_p<P> >::reverse_iterator it = q_.rbegin ();
+
+ for (; it != q_.rend (); ++it)
+ if (!(*it).second.empty ())
+ return (*it).second.pop ();
+
+ if (! vect_needs_update_)
+ {
+ vect_needs_update_ = true;
+ bb_needs_update_ = true;
+ }
+ }
+
+ template <typename P, typename T>
+ const P&
+ queue_p_priority<P, T>::front() const
+ {
+ mln_precondition(! q_.empty());
+
+ typename std::map<T, queue_p<P> >::const_reverse_iterator it = q_.rbegin ();
+
+ for (; it != q_.rend (); ++it)
+ if (!(*it).second.empty ())
+ break;
+ return (*it).second.front ();
+ }
+
+ template <typename P, typename T>
+ void
+ queue_p_priority<P, T>::clear()
+ {
+ typename std::map<T, queue_p<P> >::iterator it = q_.begin ();
+
+ for (; it != q_.end (); ++it)
+ (*it).second.clear ();
+ q_.clear();
+ vect_needs_update_ = false;
+ bb_needs_update_ = false;
+ }
+
+ template <typename P, typename T>
+ const std::vector<P>&
+ queue_p_priority<P, T>::vect() const
+ {
+ if (vect_needs_update_)
+ vect_update_();
+ return vect_;
+ }
+
+ template <typename P, typename T>
+ const P&
+ queue_p_priority<P, T>::operator[](unsigned i) const
+ {
+ mln_precondition(i < npoints());
+
+ typename std::map<T, queue_p<P> >::const_reverse_iterator it = q_.rbegin ();
+ unsigned cpt = 0;
+
+ for (; it != q_.rend (); ++it)
+ {
+ if (!(*it).second.empty ())
+ for (cpt = 0; cpt < (*it).second.npoints (); ++cpt)
+ {
+ if (i == 0)
+ return (*it).second[cpt];
+ --i;
+ }
+ }
+ return (*it).second[cpt];
+ }
+
+# endif // ! MLN_INCLUDE_ONLY
+
+} // end of namespace mln
+
+
+#endif // ! MLN_CORE_QUEUE_P_PRIORITY_HH
URL: https://svn.lrde.epita.fr/svn/oln/trunk/milena
ChangeLog:
2007-10-11 Matthieu Garrigues <garrigues(a)lrde.epita.fr>
Add tests macros.
* tests/value_macros.hh: Macros to factorise tests.
---
value_macros.hh | 104 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 104 insertions(+)
Index: trunk/milena/tests/value_macros.hh
===================================================================
--- trunk/milena/tests/value_macros.hh (revision 0)
+++ trunk/milena/tests/value_macros.hh (revision 1321)
@@ -0,0 +1,104 @@
+// Copyright (C) 2007 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.
+
+/*! \file tests/value_macros.hh
+ *
+ * \brief Utilities to tests value types.
+ */
+
+#define sym_compare_assert(V1, OP, V2) \
+ \
+ mln_assertion(V1 OP V2); \
+ mln_assertion(-V1 OP -V2); \
+ mln_assertion(V2 OP V1); \
+ mln_assertion(-V2 OP -V1);
+
+#define asym_compare_assert(V1, OP, V2) \
+ \
+ mln_assertion(V1 OP V2); \
+ mln_assertion(!(-V1 OP -V2)); \
+ mln_assertion(-V2 OP -V1); \
+ mln_assertion(!(V2 OP V1));
+
+// For unsigned types, V1 > V2 if op is minus
+#define test_interop(T1, T2, OP, V1, V2) \
+ \
+{ \
+ T1 i = V1; \
+ T2 j = V2; \
+ \
+ i = i OP j; \
+ sym_compare_assert(i, ==, float(V1 OP V2)); \
+ sym_compare_assert(j, ==, float(V2)); \
+ \
+ i = V1; \
+ j = V2; \
+ \
+ j = i OP j; \
+ sym_compare_assert(j, ==, float(V1 OP V2)); \
+ sym_compare_assert(i, ==, float(V1)); \
+ \
+ i = V1; \
+ i OP##= i; \
+ sym_compare_assert(i, ==, float(V1 OP V1)); \
+ \
+ i = V1; \
+ j = V2; \
+ i OP##= j; \
+ sym_compare_assert(i, ==, float(V1 OP V2)); \
+ \
+ j OP##= j; \
+ sym_compare_assert(j, ==, float(V2 OP V2)); \
+ \
+ i = V1; \
+ j = V2; \
+ j OP##= i; \
+ sym_compare_assert(j, ==, float(V2 OP V1)); \
+ \
+ i = V1; \
+ i OP##= i; \
+ sym_compare_assert(i, ==, float(((V1 OP V1)))); \
+}
+
+#define test_operator(T, OP, V1, V2) \
+ \
+{ \
+ T i = V1; \
+ T j = V2; \
+ \
+ i = i OP j; \
+ sym_compare_assert(i, ==, float(V1 OP V2)); \
+ sym_compare_assert(j, ==, float(V2)); \
+ \
+ i = V1; \
+ i OP##= i; \
+ sym_compare_assert(i, ==, float(V1 OP V1)); \
+ \
+ i = V1; \
+ j = V2; \
+ i OP##= j; \
+}
URL: https://svn.lrde.epita.fr/svn/oln/trunk/milena
ChangeLog:
2007-10-11 Matthieu Garrigues <garrigues(a)lrde.epita.fr>
Try to reduce number of files in doc/html.
* doc/Doxyfile.in: Create_subdirs = YES.
---
Doxyfile.in | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
Index: trunk/milena/doc/Doxyfile.in
===================================================================
--- trunk/milena/doc/Doxyfile.in (revision 1318)
+++ trunk/milena/doc/Doxyfile.in (revision 1319)
@@ -48,7 +48,7 @@
# source files, where putting all generated files in the same directory would
# otherwise cause performance problems for the file system.
-CREATE_SUBDIRS = NO
+CREATE_SUBDIRS = YES
# The OUTPUT_LANGUAGE tag is used to specify the language in which all
# documentation generated by doxygen is written. Doxygen will use this