16 #ifndef dealii_block_indices_h 17 #define dealii_block_indices_h 111 reinit(
const std::vector<size_type> &block_sizes);
168 std::pair<unsigned int, size_type>
243 const unsigned int n = bi.size();
247 s << bi.block_size(0);
249 for (
unsigned int i = 1; i < n; ++i)
250 s <<
' ' << bi.block_size(i);
251 s <<
"]->" << bi.total_size();
275 n_blocks =
static_cast<unsigned int>(block_sizes.size());
316 b.start_indices = std::vector<size_type>(1, 0);
330 inline std::pair<unsigned int, BlockIndices::size_type>
386 for (
unsigned int i = 0; i <
n_blocks; ++i)
423 b.start_indices = std::vector<size_type>(1, 0);
#define AssertDimension(dim1, dim2)
#define AssertIndexRange(index, range)
size_type block_size(const unsigned int i) const
size_type total_size() const
bool operator==(const BlockIndices &b) const
#define Assert(cond, exc)
void reinit(const unsigned int n_blocks, const size_type n_elements_per_block)
#define DEAL_II_NAMESPACE_CLOSE
std::string to_string() const
void swap(BlockIndices &u, BlockIndices &v)
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
SymmetricTensor< 2, dim, Number > b(const Tensor< 2, dim, Number > &F)
unsigned int global_dof_index
BlockIndices & operator=(const BlockIndices &b)
std::size_t memory_consumption() const
#define DEAL_II_NAMESPACE_OPEN
size_type block_start(const unsigned int i) const
void push_back(const size_type size)
void swap(BlockIndices &b)
types::global_dof_index size_type
unsigned int size() const
std::pair< unsigned int, size_type > global_to_local(const size_type i) const