23 const std::size_t nNodes(nodes.size());
24 std::vector<Node*> new_nodes;
25 new_nodes.reserve(nNodes);
26 for (std::size_t k = 0; k < nNodes; ++k)
28 new_nodes.push_back(
new Node(nodes[k]->data(), new_nodes.size()));
34 std::vector<Element*>
const& elements,
35 std::vector<Node*>
const& new_nodes,
36 std::vector<std::size_t>
const*
const node_id_map)
38 std::vector<Element*> new_elements;
39 new_elements.reserve(elements.size());
40 std::transform(elements.begin(), elements.end(),
41 std::back_inserter(new_elements),
42 [&new_nodes, &node_id_map](
auto const& element)
43 { return copyElement(element, new_nodes, node_id_map); });
51 const std::vector<Node*>& nodes,
52 std::vector<std::size_t>
const*
const id_map)
55 auto** new_nodes =
new Node*[number_of_element_nodes];
58 for (
unsigned i = 0; i < number_of_element_nodes; ++i)
60 new_nodes[i] = nodes[(*id_map)[element->
getNode(i)->
getID()]];
65 for (
unsigned i = 0; i < number_of_element_nodes; ++i)
70 return new E(new_nodes);
74 const std::vector<Node*>& nodes,
75 std::vector<std::size_t>
const*
const id_map)
80 return copyElement<Line>(element, nodes, id_map);
82 return copyElement<Line3>(element, nodes, id_map);
84 return copyElement<Tri>(element, nodes, id_map);
86 return copyElement<Tri6>(element, nodes, id_map);
88 return copyElement<Quad>(element, nodes, id_map);
90 return copyElement<Quad8>(element, nodes, id_map);
92 return copyElement<Quad9>(element, nodes, id_map);
94 return copyElement<Tet>(element, nodes, id_map);
96 return copyElement<Tet10>(element, nodes, id_map);
98 return copyElement<Hex>(element, nodes, id_map);
100 return copyElement<Hex20>(element, nodes, id_map);
102 return copyElement<Pyramid>(element, nodes, id_map);
104 return copyElement<Pyramid13>(element, nodes, id_map);
106 return copyElement<Prism>(element, nodes, id_map);
108 return copyElement<Prism15>(element, nodes, id_map);
111 ERR(
"Error: Unknown cell type.");
119 std::vector<Element*> cloned_elements;
120 cloned_elements.reserve(elements.size());
121 std::transform(begin(elements), end(elements),
122 std::back_inserter(cloned_elements),
124 return cloned_elements;