node.hh

00001 // Copyright (C) 2004  EPITA Research and Development Laboratory
00002 //
00003 // This file is part of the Olena Library.  This library is free
00004 // software; you can redistribute it and/or modify it under the terms
00005 // of the GNU General Public License version 2 as published by the
00006 // Free Software Foundation.
00007 //
00008 // This library is distributed in the hope that it will be useful,
00009 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00010 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00011 // General Public License for more details.
00012 //
00013 // You should have received a copy of the GNU General Public License
00014 // along with this library; see the file COPYING.  If not, write to
00015 // the Free Software Foundation, 59 Temple Place - Suite 330, Boston,
00016 // MA 02111-1307, USA.
00017 //
00018 // As a special exception, you may use this file as part of a free
00019 // software library 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
00022 // produce an executable, this file does not by itself cause the
00023 // resulting executable to be covered by the GNU General Public
00024 // License.  This exception does not however invalidate any other
00025 // reasons why the executable file might be covered by the GNU General
00026 // Public License.
00027 
00028 #ifndef OLENA_SNAKES_NODE_HH
00029 # define OLENA_SNAKES_NODE_HH
00030 
00031 #include <oln/basics2d.hh> // FIXME: Why only 2d?
00032 
00033 namespace oln {
00034 
00035   namespace snakes {
00036 
00041     template<class I>
00042     class node : public I::point_type
00043     {
00044     public:
00045       typedef typename I::point_type    point_type;
00046       typedef typename I::dpoint_type   dpoint_type;
00047 
00048     public:
00049       node(point_type point) :
00050         I::point_type(point)
00051       {
00052       }
00053 
00054     public:
00059       inline
00060       ntg::float_s
00061       energy(const I& gradient, point_type prev, point_type next) const;
00062 
00063     private:
00064       friend std::ostream&
00065       ::operator<< <>(std::ostream&, const node&);
00066     };
00067 
00068   } // end snakes
00069 
00070 } // end oln
00071 
00073 template <class I>
00074 std::ostream& operator<<(std::ostream& os, const oln::snakes::node<I>& n)
00075 {
00076   os << "Node:" << static_cast<typename oln::snakes::node<I>::point_type>(n);
00077   return os;
00078 }
00079 
00080 #include <oln/snakes/node.hxx>
00081 
00082 #endif // !OLENA_SNAKES_NODE_HH

Generated on Thu Apr 15 20:13:13 2004 for Olena by doxygen 1.3.6-20040222