17#ifndef dealii_graph_coloring_h
18# define dealii_graph_coloring_h
28# include <unordered_map>
29# include <unordered_set>
55 const std::vector<types::global_dof_index> &
indices1,
56 const std::vector<types::global_dof_index> &
indices2)
62 std::vector<types::global_dof_index>::const_iterator p =
indices1.
begin(),
108 template <
typename Iterator>
109 std::vector<std::vector<Iterator>>
111 const Iterator & begin,
113 const std::function<std::vector<types::global_dof_index>(
117 unsigned int n_iterators = 0;
120 std::unordered_map<types::global_dof_index, std::vector<Iterator>>
122 for (Iterator
it = begin;
it != end; ++
it)
135 std::vector<std::vector<Iterator>>
zones(1,
136 std::vector<Iterator>(1, begin));
185 for (Iterator
it = begin;
it != end; ++
it)
188 zones.push_back(std::vector<Iterator>(1,
it));
221 template <
typename Iterator>
224 std::vector<Iterator> & partition,
225 const std::function<std::vector<types::global_dof_index>(
259 graph[i].push_back(
j);
260 graph[
j].push_back(i);
268 degrees_it = std::max_element(degrees.begin(), degrees.end());
275 std::vector<std::unordered_set<unsigned int>>
colors_used;
308 std::unordered_set<unsigned int> tmp;
326 template <
typename Iterator>
327 std::vector<std::vector<Iterator>>
331 std::vector<std::vector<Iterator>> coloring;
340 for (
unsigned int j = 0;
j < n_colors; ++
j)
365 std::unordered_set<unsigned int>
used_k;
370 std::vector<unsigned int>::iterator
it;
386 coloring[
pos].insert(
420 std::unordered_set<unsigned int>
used_k;
425 std::vector<unsigned int>::iterator
it;
539 template <
typename Iterator>
540 std::vector<std::vector<Iterator>>
542 const Iterator & begin,
544 const std::function<std::vector<types::global_dof_index>(
549 "GraphColoring is not prepared to deal with empty ranges!"));
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
#define Assert(cond, exc)
static ::ExceptionBase & ExcMessage(std::string arg1)
Task< RT > new_task(const std::function< RT()> &function)
std::vector< std::vector< Iterator > > gather_colors(const std::vector< std::vector< std::vector< Iterator > > > &partition_coloring)
std::vector< std::vector< Iterator > > create_partitioning(const Iterator &begin, const std_cxx20::type_identity_t< Iterator > &end, const std::function< std::vector< types::global_dof_index >(const Iterator &)> &get_conflict_indices)
bool have_nonempty_intersection(const std::vector< types::global_dof_index > &indices1, const std::vector< types::global_dof_index > &indices2)
void make_dsatur_coloring(std::vector< Iterator > &partition, const std::function< std::vector< types::global_dof_index >(const Iterator &)> &get_conflict_indices, std::vector< std::vector< Iterator > > &partition_coloring)
std::vector< std::vector< Iterator > > make_graph_coloring(const Iterator &begin, const std_cxx20::type_identity_t< Iterator > &end, const std::function< std::vector< types::global_dof_index >(const std_cxx20::type_identity_t< Iterator > &)> &get_conflict_indices)
unsigned int color_sparsity_pattern(const SparsityPattern &sparsity_pattern, std::vector< unsigned int > &color_indices)
typename type_identity< T >::type type_identity_t