node.hh

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

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