16 #ifndef dealii__block_indices_h 17 #define dealii__block_indices_h 20 #include <deal.II/base/config.h> 21 #include <deal.II/base/subscriptor.h> 22 #include <deal.II/base/exceptions.h> 23 #include <deal.II/base/logstream.h> 24 #include <deal.II/base/utilities.h> 28 DEAL_II_NAMESPACE_OPEN
72 BlockIndices (
const std::vector<size_type> &block_sizes);
85 const size_type n_elements_per_block);
93 void reinit (
const std::vector<size_type> &block_sizes);
108 unsigned int size ()
const;
119 size_type
block_size (
const unsigned int i)
const;
145 std::pair<unsigned int,size_type>
152 const size_type index)
const;
157 size_type
block_start (
const unsigned int i)
const;
209 const unsigned int n = bi.
size();
215 for (
unsigned int i=1; i<n; ++i)
244 n_blocks =
static_cast<unsigned int>(block_sizes.size());
278 n_blocks(static_cast<unsigned int>(block_sizes.
size())),
296 std::pair<unsigned int,BlockIndices::size_type>
306 return std::pair<unsigned int,size_type>(block,
358 for (
unsigned int i=0; i<
n_blocks; ++i)
421 return (
sizeof(*
this) +
447 DEAL_II_NAMESPACE_CLOSE
#define AssertDimension(dim1, dim2)
Auxiliary class aiding in the handling of block structures like in BlockVector or FESystem...
size_type block_size(const unsigned int i) const
std::string to_string(const number value, const unsigned int digits=numbers::invalid_unsigned_int)
size_type total_size() const
void swap(BlockIndices &u, BlockIndices &v)
bool operator==(const BlockIndices &b) const
unsigned int global_dof_index
#define Assert(cond, exc)
void reinit(const unsigned int n_blocks, const size_type n_elements_per_block)
types::global_dof_index size_type
std::string to_string() const
size_type local_to_global(const unsigned int block, const size_type index) const
std::string int_to_string(const unsigned int value, const unsigned int digits=numbers::invalid_unsigned_int)
std::vector< size_type > start_indices
BlockIndices & operator=(const BlockIndices &b)
std::size_t memory_consumption() const
size_type block_start(const unsigned int i) const
void push_back(const size_type size)
void swap(BlockIndices &b)
unsigned int size() const
StreamType & operator<<(StreamType &s, UpdateFlags u)
std::pair< unsigned int, size_type > global_to_local(const size_type i) const