1
0
mirror of https://github.com/NGSolve/netgen.git synced 2025-01-18 08:50:33 +05:00
netgen/libsrc/general/spbita2d.hpp

60 lines
1.2 KiB
C++
Raw Normal View History

2009-01-13 04:40:13 +05:00
#ifndef FILE_SPBITA2D
#define FILE_SPBITA2D
/**************************************************************************/
/* File: spbita2d.hh */
/* Author: Joachim Schoeberl */
/* Date: 01. Jun. 95 */
/**************************************************************************/
/**
Implementation of sparse 2 dimensional bitarray
*/
2009-07-20 14:36:36 +06:00
namespace netgen
{
2009-01-13 04:40:13 +05:00
2009-01-25 17:35:25 +05:00
class SPARSE_BIT_Array_2D
2009-01-13 04:40:13 +05:00
{
class linestruct { public: INDEX size; INDEX maxsize; INDEX * col; };
///
linestruct * lines;
///
INDEX height, width;
public:
///
2009-01-25 17:35:25 +05:00
SPARSE_BIT_Array_2D (INDEX ah = 0, INDEX aw = 0);
2009-01-13 04:40:13 +05:00
///
2009-01-25 17:35:25 +05:00
~SPARSE_BIT_Array_2D ();
2009-01-13 04:40:13 +05:00
///
void SetSize (INDEX ah, INDEX aw = 0);
///
void DeleteElements ();
///
int Get (INDEX i, INDEX j) const;
///
INDEX Height () const { return height; }
///
INDEX Width () const { return width; }
///
void Set (INDEX i, INDEX j);
///
int Test (INDEX i, INDEX j) const;
///
INDEX BitsInLine (INDEX i) const { return lines[i-1].size; }
///
INDEX GetIndex (INDEX i, INDEX nr) const { return lines[i-1].col[nr-1]; }
};
2009-07-20 14:36:36 +06:00
}
2009-01-13 04:40:13 +05:00
#endif