17 #ifndef dealii_matrix_free_task_info_h 18 #define dealii_matrix_free_task_info_h 81 cell(
const std::pair<unsigned int, unsigned int> &cell_range) = 0;
86 face(
const std::pair<unsigned int, unsigned int> &face_range) = 0;
91 boundary(
const std::pair<unsigned int, unsigned int> &face_range) = 0;
96 namespace MatrixFreeFunctions
142 make_boundary_cells_divisible(std::vector<unsigned int> &boundary_cells);
187 create_blocks_serial(
188 const std::vector<unsigned int> &cells_with_comm,
189 const unsigned int dofs_per_cell,
190 const bool categories_are_hp,
191 const std::vector<unsigned int> &cell_vectorization_categories,
192 const bool cell_vectorization_categories_strict,
193 const std::vector<unsigned int> &parent_relation,
194 std::vector<unsigned int> & renumbering,
195 std::vector<unsigned char> & incompletely_filled_vectorization);
215 initial_setup_blocks_tasks(
216 const std::vector<unsigned int> &boundary_cells,
217 std::vector<unsigned int> & renumbering,
218 std::vector<unsigned char> & incompletely_filled_vectorization);
227 guess_block_size(
const unsigned int dofs_per_cell);
256 make_thread_graph_partition_color(
258 std::vector<unsigned int> & renumbering,
259 std::vector<unsigned char> &irregular_cells,
295 make_thread_graph_partition_partition(
296 const std::vector<unsigned int> &cell_active_fe_index,
298 std::vector<unsigned int> & renumbering,
299 std::vector<unsigned char> & irregular_cells,
326 make_thread_graph(
const std::vector<unsigned int> &cell_active_fe_index,
328 std::vector<unsigned int> & renumbering,
329 std::vector<unsigned char> & irregular_cells,
337 make_connectivity_cells_to_blocks(
338 const std::vector<unsigned char> &irregular_cells,
347 make_coloring_within_partitions_pre_blocked(
350 const std::vector<unsigned int> &cell_partition,
351 const std::vector<unsigned int> &partition_list,
352 const std::vector<unsigned int> &partition_size,
353 std::vector<unsigned int> & partition_color_list);
360 make_partitioning_within_partitions_post_blocked(
362 const std::vector<unsigned int> &cell_active_fe_index,
364 const unsigned int cluster_size,
366 const std::vector<unsigned int> &cell_partition,
367 const std::vector<unsigned int> &partition_list,
368 const std::vector<unsigned int> &partition_size,
369 std::vector<unsigned int> & partition_partition_list,
370 std::vector<unsigned char> & irregular_cells);
394 const unsigned int cluster_size,
395 std::vector<unsigned int> & cell_partition,
396 std::vector<unsigned int> & partition_list,
397 std::vector<unsigned int> & partition_size,
405 update_task_info(
const unsigned int partition);
423 template <
typename StreamType>
425 print_memory_statistics(StreamType &out, std::size_t data_length)
const;
virtual ~MFWorkerInterface()=default
std::vector< unsigned int > ghost_face_partition_data
void loop(ITERATOR begin, typename identity< ITERATOR >::type end, DOFINFO &dinfo, INFOBOX &info, const std::function< void(DOFINFO &, typename INFOBOX::CellInfo &)> &cell_worker, const std::function< void(DOFINFO &, typename INFOBOX::CellInfo &)> &boundary_worker, const std::function< void(DOFINFO &, DOFINFO &, typename INFOBOX::CellInfo &, typename INFOBOX::CellInfo &)> &face_worker, ASSEMBLER &assembler, const LoopControl &lctrl=LoopControl())
virtual void cell_loop_post_range(const unsigned int range_index)=0
virtual void cell_loop_pre_range(const unsigned int range_index)=0
virtual void cell(const std::pair< unsigned int, unsigned int > &cell_range)=0
TasksParallelScheme scheme
std::vector< unsigned int > partition_row_index
std::vector< unsigned int > partition_n_workers
virtual void vector_update_ghosts_finish()=0
Finishes the communication for the update ghost values operation.
std::vector< unsigned int > cell_partition_data
std::vector< unsigned int > partition_n_blocked_workers
std::vector< unsigned int > refinement_edge_face_partition_data
unsigned int vectorization_length
unsigned int n_blocked_workers
std::vector< unsigned int > boundary_partition_data
#define DEAL_II_NAMESPACE_CLOSE
unsigned int n_ghost_cells
virtual void zero_dst_vector_range(const unsigned int range_index)=0
virtual void boundary(const std::pair< unsigned int, unsigned int > &face_range)=0
std::vector< unsigned char > task_at_mpi_boundary
unsigned int n_active_cells
virtual void vector_update_ghosts_start()=0
Starts the communication for the update ghost values operation.
virtual void face(const std::pair< unsigned int, unsigned int > &face_range)=0
std::vector< unsigned int > face_partition_data
#define DEAL_II_NAMESPACE_OPEN
virtual void vector_compress_start()=0
Starts the communication for the vector compress operation.
std::vector< unsigned int > partition_odds
#define DEAL_II_DEPRECATED
std::vector< unsigned int > partition_evens
std::enable_if< std::is_fundamental< T >::value, std::size_t >::type memory_consumption(const T &t)
virtual void vector_compress_finish()=0
Finishes the communication for the vector compress operation.