- extra_element_id_namesList of user-defined extra element ID namesC++ Type:std::vector<std::string> Controllable:No Description:List of user-defined extra element ID names 
- extra_element_idsUser-defined extra element IDs corresponding to 'subdomains' in the same orderC++ Type:std::vector<std::vector<unsigned long>> Controllable:No Description:User-defined extra element IDs corresponding to 'subdomains' in the same order 
- inputName of an existing mesh generator to which we assign element IDsC++ Type:MeshGeneratorName Controllable:No Description:Name of an existing mesh generator to which we assign element IDs 
- subdomainsSubdomain names present in the input meshC++ Type:std::vector<SubdomainName> Controllable:No Description:Subdomain names present in the input mesh 
SubdomainExtraElementIDGenerator
Assign extra element IDs for elements on a mesh based on mesh subdomains.
Overview
The SubdomainExtraElementIDGenerator assigns extra element IDs based on mesh subdomain IDs of an input mesh. If the extra element IDs do not exist in the input mesh, this mesh generator will add them. The "subdomains" parameter can accept both subdomain names and subdomain IDs. The "extra_element_ids" parameter is a two-dimensional vector separated by semicolon and then white space as normal MOOSE input syntax for two-dimensional vectors. Its first dimensionality must be equal to the size of the "extra_element_id_names" parameter and the size of each sub-vector must be equal to the size of the "subdomains" parameter.
Listing 1: A sample input for the extra_element_ids parameter
[Mesh<<<{"href": "../../syntax/Mesh/index.html"}>>>]
  [gmg]
    type = CartesianMeshGenerator<<<{"description": "This CartesianMeshGenerator creates a non-uniform Cartesian mesh.", "href": "CartesianMeshGenerator.html"}>>>
    dim<<<{"description": "The dimension of the mesh to be generated"}>>> = 2
    dx<<<{"description": "Intervals in the X direction"}>>> = 1
    ix<<<{"description": "Number of grids in all intervals in the X direction (default to all one)"}>>> = 10
    dy<<<{"description": "Intervals in the Y direction (required when dim>1 otherwise ignored)"}>>> = '0.2 0.2 0.2 0.2 0.2'
    iy<<<{"description": "Number of grids in all intervals in the Y direction (default to all one)"}>>> = '2 2 2 2 2'
    subdomain_id<<<{"description": "Block IDs (default to all zero)"}>>> = '0 1 2 3 4'
  []
  [give_subdomain_name]
    type = RenameBlockGenerator<<<{"description": "Changes the block IDs and/or block names for a given set of blocks defined by either block ID or block name. The changes are independent of ordering. The merging of blocks is supported.", "href": "RenameBlockGenerator.html"}>>>
    input<<<{"description": "The mesh we want to modify"}>>> = gmg
    old_block<<<{"description": "Elements with these block ID(s)/name(s) will be given the new block information specified in 'new_block'"}>>> = '1 3'
    new_block<<<{"description": "The new block ID(s)/name(s) to be given by the elements defined in 'old_block'."}>>> = 'sub1 sub3'
  []
  [subdomain_ids]
    type = SubdomainExtraElementIDGenerator<<<{"description": "Assign extra element IDs for elements on a mesh based on mesh subdomains.", "href": "SubdomainExtraElementIDGenerator.html"}>>>
    input<<<{"description": "Name of an existing mesh generator to which we assign element IDs"}>>> = give_subdomain_name
    subdomains<<<{"description": "Subdomain names present in the input mesh"}>>> = '0 sub1 2 sub3'
    extra_element_id_names<<<{"description": "List of user-defined extra element ID names"}>>> = 'test_id1 test_id2 test_id3'
    extra_element_ids<<<{"description": "User-defined extra element IDs corresponding to 'subdomains' in the same order"}>>> = '
                   1 3 5 4;
                   2 9 10 11;
                   0 8 1 2
                 '
    default_extra_element_ids<<<{"description": "Default extra element IDs for elements not in 'subdomains'"}>>> = '0 12 13'
  []
[]In the above sample input, we have four subdomains listed in the "subdomains" parameter and three extra element id names in the "extra_element_id_names" parameter, thus we have two semicolons in "extra_element_ids" to separate the numbers into three groups for the three id names accordingly and each group has four numbers corresponding to the four subdomains.
Default element IDs can be provided through "default_extra_element_ids" for elements in subdomains that are not specified in the "subdomains" parameter. Because of this, "default_extra_element_ids" is active only when the "subdomains" parameter does not include all mesh subdomains.
If "default_extra_element_ids" is not set and "subdomains" does not contain all mesh subdomains, when the extra element IDs already existed in the mesh, the extra IDs for those elements of the missing subdomains will not be changed; or when the extra element IDs are newly added by this mesh generator, invalid IDs are set to elements of those missing subdomains.
Input Parameters
- default_extra_element_idsDefault extra element IDs for elements not in 'subdomains'C++ Type:std::vector<unsigned long> Controllable:No Description:Default extra element IDs for elements not in 'subdomains' 
Optional Parameters
- enableTrueSet the enabled status of the MooseObject.Default:True C++ Type:bool Controllable:No Description:Set the enabled status of the MooseObject. 
- save_with_nameKeep the mesh from this mesh generator in memory with the name specifiedC++ Type:std::string Controllable:No Description:Keep the mesh from this mesh generator in memory with the name specified 
Advanced Parameters
- nemesisFalseWhether or not to output the mesh file in the nemesisformat (only if output = true)Default:False C++ Type:bool Controllable:No Description:Whether or not to output the mesh file in the nemesisformat (only if output = true) 
- outputFalseWhether or not to output the mesh file after generating the meshDefault:False C++ Type:bool Controllable:No Description:Whether or not to output the mesh file after generating the mesh 
- show_infoFalseWhether or not to show mesh info after generating the mesh (bounding box, element types, sidesets, nodesets, subdomains, etc)Default:False C++ Type:bool Controllable:No Description:Whether or not to show mesh info after generating the mesh (bounding box, element types, sidesets, nodesets, subdomains, etc) 
Debugging Parameters
Input Files
- (tutorials/tutorial04_meshing/app/test/tests/base_mesh_generators/depletion_id.i)
- (modules/reactor/test/tests/meshgenerators/coarse_mesh_extra_element_id_generator/coarse_elem_extra_elem_id.i)
- (modules/reactor/test/tests/meshgenerators/reporting_id/depletion_id/sub_pin_depletion_id.i)
- (modules/reactor/test/tests/meshgenerators/subdomain_extra_element_id_generator/subdomain_elem_ids_test.i)
- (modules/reactor/test/tests/meshgenerators/reporting_id/depletion_id/two_depletion_ids.i)