14 std::vector<dof_id_type>
16 const std::vector<std::unique_ptr<ReplicatedMesh>> & meshes,
17 const std::vector<std::vector<unsigned int>> & pattern,
18 const bool use_exclude_id,
19 const std::vector<bool> & exclude_ids)
25 std::vector<dof_id_type> integer_ids;
26 integer_ids.reserve(n);
33 integer_ids.insert(integer_ids.end(), meshes[
pattern[i][
j]]->n_elem(),
value);
38 std::vector<dof_id_type>
40 const std::vector<std::unique_ptr<ReplicatedMesh>> & meshes,
41 const std::vector<std::vector<unsigned int>> & pattern)
47 std::vector<dof_id_type> integer_ids;
48 integer_ids.reserve(n);
51 integer_ids.insert(integer_ids.end(), meshes[
pattern[i][
j]]->n_elem(),
pattern[i][
j]);
55 std::vector<dof_id_type>
57 const std::vector<std::unique_ptr<ReplicatedMesh>> & meshes,
58 const std::vector<std::vector<unsigned int>> & pattern,
59 const std::vector<std::vector<dof_id_type>> & id_pattern)
65 std::vector<dof_id_type> integer_ids;
66 integer_ids.reserve(n);
69 integer_ids.insert(integer_ids.end(), meshes[
pattern[i][
j]]->n_elem(), id_pattern[i][
j]);
75 const std::vector<std::unique_ptr<ReplicatedMesh>> & meshes,
76 const std::vector<std::vector<unsigned int>> & pattern)
78 std::set<SubdomainID> blks;
82 std::set<SubdomainID> mesh_blks;
87 blks.insert(mesh_blks.begin(), mesh_blks.end());
92 std::map<SubdomainID, unsigned int>
94 const bool has_assembly_boundary,
95 const std::set<subdomain_id_type> background_blk_ids,
96 const std::set<SubdomainID> & blks)
98 std::map<SubdomainID, unsigned int> blks_duct;
99 if (has_assembly_boundary)
101 std::set<SubdomainID> mesh_blks;
104 for (
const auto mesh_blk : mesh_blks)
105 if (!blks.count(mesh_blk) && !background_blk_ids.count(mesh_blk))
106 blks_duct[mesh_blk] = i++;
108 if (background_blk_ids.size() == 0)
109 blks_duct.erase(blks_duct.begin());
117 const unsigned int extra_id_index,
119 const bool use_exclude_id,
120 const std::vector<bool> & exclude_ids,
121 const bool has_assembly_boundary,
122 const std::set<subdomain_id_type> background_block_ids,
123 const std::vector<std::unique_ptr<ReplicatedMesh>> & input_meshes,
124 const std::vector<std::vector<unsigned int>> & pattern,
125 const std::vector<std::vector<dof_id_type>> & id_pattern)
127 std::vector<dof_id_type> integer_ids;
130 if (assign_type == AssignType::cell)
132 else if (assign_type == AssignType::pattern)
134 else if (assign_type == AssignType::manual)
137 if (has_assembly_boundary)
140 const std::set<SubdomainID> blks =
getCellBlockIDs(input_meshes, pattern);
141 const unsigned int duct_boundary_id =
142 *std::max_element(integer_ids.begin(), integer_ids.end()) + 1;
143 const std::map<SubdomainID, unsigned int> blks_duct =
144 getDuckBlockIDs(mesh, has_assembly_boundary, background_block_ids, blks);
148 unsigned int id = integer_ids[i];
149 unsigned old_id = id;
150 for (
auto elem :
mesh.element_ptr_range())
152 auto blk = elem->subdomain_id();
154 if (!blks.count(blk))
157 if (!blks_duct.count(blk))
159 elem->set_extra_integer(extra_id_index, old_id);
162 elem->set_extra_integer(extra_id_index, duct_boundary_id + blks_duct.at(blk));
167 elem->set_extra_integer(extra_id_index,
id);
170 if (i < integer_ids.size())
179 for (
auto & elem :
mesh.element_ptr_range())
180 elem->set_extra_integer(extra_id_index, integer_ids[i++]);
std::vector< dof_id_type > getManualIntegerIDs(const std::vector< std::unique_ptr< libMesh::ReplicatedMesh >> &meshes, const std::vector< std::vector< unsigned int >> &pattern, const std::vector< std::vector< dof_id_type >> &id_pattern)
assign IDs based on user-defined mapping defined in id_pattern
void assignReportingIDs(MeshBase &mesh, const unsigned int extra_id_index, const ReportingIDGeneratorUtils::AssignType assign_type, const bool use_exclude_id, const std::vector< bool > &exclude_ids, const bool has_assembly_boundary, const std::set< subdomain_id_type > background_block_ids, const std::vector< std::unique_ptr< libMesh::ReplicatedMesh >> &input_meshes, const std::vector< std::vector< unsigned int >> &pattern, const std::vector< std::vector< dof_id_type >> &id_pattern)
assign the reporting IDs to the output mesh from the cartesian or hexagonal patterned mesh generator ...
AssignType
Enum item for reporting id assign types.
std::map< SubdomainID, unsigned int > getDuckBlockIDs(const MeshBase &mesh, const bool has_assembly_boundary, const std::set< subdomain_id_type > background_blk_ids, const std::set< SubdomainID > &blks)
get list of block IDs for the assembly duck regions
std::vector< dof_id_type > getCellwiseIntegerIDs(const std::vector< std::unique_ptr< libMesh::ReplicatedMesh >> &meshes, const std::vector< std::vector< unsigned int >> &pattern, const bool use_exclude_id, const std::vector< bool > &exclude_ids)
assign IDs for each component in pattern in sequential order
The following methods are specializations for using the Parallel::packed_range_* routines for a vecto...
std::vector< dof_id_type > getPatternIntegerIDs(const std::vector< std::unique_ptr< libMesh::ReplicatedMesh >> &meshes, const std::vector< std::vector< unsigned int >> &pattern)
assign IDs for each input component type
bool has_cached_elem_data
Preparation preparation() const
Real value(unsigned n, unsigned alpha, unsigned beta, Real x)
static constexpr dof_id_type invalid_id
std::set< SubdomainID > getCellBlockIDs(const std::vector< std::unique_ptr< libMesh::ReplicatedMesh >> &meshes, const std::vector< std::vector< unsigned int >> &pattern)
get list of block IDs in input mesh cells
void subdomain_ids(std::set< subdomain_id_type > &ids, const bool global=true) const
static const std::complex< double > j(0, 1)
Complex number "j" (also known as "i")
assign the same reporting IDs for all tiles in the pattern with same input