00001 // Copyright (C) 2001, 2002, 2003, 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_TOPO_INTER_PIXEL_NODE_HH 00029 # define OLENA_TOPO_INTER_PIXEL_NODE_HH 00030 00031 # include <oln/topo/inter-pixel/internal/dir.hh> 00032 00033 namespace oln { 00034 00035 namespace topo { 00037 namespace inter_pixel { 00045 template<class I> 00046 class node 00047 { 00048 public: 00049 enum { dim = I::dim }; 00050 00051 typedef oln_dir_type(I) dir_type; 00052 00053 public: 00054 node() : rank_(0) 00055 { 00056 for (unsigned i = 0; i < 2 * dim; ++i) 00057 data_[i] = false; 00058 } 00059 00061 void 00062 set(dir_type i) 00063 { 00064 if (data_[i] == false) 00065 ++rank_; 00066 00067 data_[i] = true; 00068 } 00069 00071 bool 00072 get(dir_type i) const 00073 { 00074 return data_[i]; 00075 } 00077 unsigned 00078 rank() const 00079 { 00080 return rank_; 00081 } 00082 00083 private: 00084 unsigned rank_; 00085 bool data_[dim * 2]; 00086 }; 00088 # define oln_node_type(ImgType) \ 00089 oln::topo::inter_pixel::node< ImgType > 00090 00092 # define oln_head_type(ImgType) \ 00093 typename std::pair<oln_point_type(ImgType), oln_dir_type(ImgType) > 00094 00095 } // end of namespace inter_pixel 00096 00097 } // end of namespace topo 00098 00099 } // end of namespace oln 00100 00101 #endif // ! OLENA_TOPO_INTER_PIXEL_NODE_HH