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