3#include <wmtk/utils/VectorUtils.h>
4#include <wmtk/AttributeCollection.hpp>
5#include <wmtk/Types.hpp>
6#include <wmtk/simplex/Simplex.hpp>
7#include <wmtk/simplex/SimplexCollection.hpp>
8#include <wmtk/utils/Logger.hpp>
10#include <tbb/concurrent_vector.h>
11#include <tbb/enumerable_thread_specific.h>
12#include <tbb/spin_mutex.h>
30 {{{0, 1}}, {{1, 2}}, {{0, 2}}, {{0, 3}}, {{1, 3}}, {{2, 3}}}};
32 static constexpr std::array<int, 4> m_map_vertex2edge = {{0, 0, 1, 3}};
33 static constexpr std::array<int, 4> m_map_vertex2oppo_face = {{3, 1, 2, 0}};
34 static constexpr std::array<int, 6> m_map_edge2face = {{0, 0, 0, 1, 2, 1}};
35 static constexpr std::array<std::array<int, 3>, 4> m_local_faces = {
36 {{{0, 1, 2}}, {{0, 2, 3}}, {{0, 1, 3}}, {{1, 2, 3}}}};
37 static constexpr std::array<std::array<int, 3>, 4> m_local_edges_in_a_face = {
38 {{{0, 1, 2}}, {{2, 5, 3}}, {{3, 4, 0}}, {{5, 1, 4}}}};
49 size_t m_global_vid = std::numeric_limits<size_t>::max();
50 size_t m_local_eid = std::numeric_limits<size_t>::max();
51 size_t m_local_fid = std::numeric_limits<size_t>::max();
52 size_t m_global_tid = std::numeric_limits<size_t>::max();
173 std::optional<Tuple> switch_tetrahedron_slow(
const TetMesh& m)
const;
181 friend bool operator==(
const Tuple& a,
const Tuple& t)
184 std::tie(a.m_global_vid, a.m_local_eid, a.m_local_fid, a.m_global_tid, a.m_hash) ==
185 std::tie(t.m_global_vid, t.m_local_eid, t.m_local_fid, t.m_global_tid, t.m_hash));
187 friend bool operator<(
const Tuple& a,
const Tuple& t)
190 std::tie(a.m_global_vid, a.m_local_eid, a.m_local_fid, a.m_global_tid, a.m_hash) <
191 std::tie(t.m_global_vid, t.m_local_eid, t.m_local_fid, t.m_global_tid, t.m_hash));
210 const Tuple& tuple() {
return m_tuple; }
211 const TetMesh& mesh() {
return m_mesh; }
219 bool is_valid()
const {
return m_tuple.
is_valid(m_mesh); }
222 size_t vid()
const {
return m_tuple.
vid(m_mesh); }
223 size_t eid()
const {
return m_tuple.
eid(m_mesh); }
224 size_t fid()
const {
return m_tuple.
fid(m_mesh); }
225 size_t tid()
const {
return m_tuple.
tid(m_mesh); }
229 std::optional<SmartTuple> switch_tetrahedron()
const
233 return std::optional<SmartTuple>({m_mesh, t.value()});
237 void check_validity()
const {
return m_tuple.
check_validity(m_mesh); }
248 std::vector<size_t> m_conn_tets;
249 bool m_is_removed =
false;
251 size_t& operator[](
const size_t index)
253 assert(index < m_conn_tets.size());
254 return m_conn_tets[index];
257 size_t operator[](
const size_t index)
const
259 assert(index < m_conn_tets.size());
260 return m_conn_tets[index];
265 return std::tie(l.m_conn_tets, l.m_is_removed) ==
266 std::tie(r.m_conn_tets, r.m_is_removed);
279 std::array<size_t, 4> m_indices;
280 bool m_is_removed =
false;
284 size_t& operator[](
size_t index)
287 return m_indices[index];
290 size_t operator[](
size_t index)
const
293 return m_indices[index];
296 int find(
size_t v_id)
const
298 for (
int j = 0; j < 4; j++) {
299 if (v_id == m_indices[j])
return j;
304 int find_local_edge(
size_t v1_id,
size_t v2_id)
const
306 std::array<int, 2> e;
307 for (
int j = 0; j < 4; j++) {
308 if (v1_id == m_indices[j])
310 else if (v2_id == m_indices[j])
313 if (e[0] > e[1]) std::swap(e[0], e[1]);
320 int find_local_face(
size_t v1_id,
size_t v2_id,
size_t v3_id)
const
322 std::array<int, 3> f;
323 for (
int j = 0; j < 4; j++) {
324 if (v1_id == m_indices[j])
326 else if (v2_id == m_indices[j])
328 else if (v3_id == m_indices[j])
331 std::sort(f.begin(), f.end());
333 std::find(m_local_faces.begin(), m_local_faces.end(), f) - m_local_faces.begin();
340 return std::tie(l.m_indices, l.m_is_removed, l.hash) ==
341 std::tie(r.m_indices, r.m_is_removed, r.hash);
370 if (!m_vertex_connectivity[i].m_is_removed) cnt++;
382 if (!m_tet_connectivity[i].m_is_removed) cnt++;
395 void init(
size_t n_vertices,
const std::vector<std::array<size_t, 4>>& tets);
396 void init_with_isolated_vertices(
398 const std::vector<std::array<size_t, 4>>& tets);
405 void init(
const MatrixXi& T);
414 bool split_edge(
const Tuple& t, std::vector<Tuple>& new_tets);
422 virtual bool collapse_edge(
const Tuple& t, std::vector<Tuple>& new_tets);
445 std::vector<Tuple>& new_edges,
448 std::map<size_t, wmtk::TetMesh::VertexConnectivity>& rollback_vert_conn,
449 std::vector<size_t>& n1_t_ids_copy,
450 std::vector<size_t>& new_tet_id,
451 std::vector<TetrahedronConnectivity>& old_tets);
477 std::map<size_t, wmtk::TetMesh::VertexConnectivity>& rollback_vert_conn,
478 std::vector<size_t>& n1_t_ids,
479 std::vector<size_t>& new_tet_id,
480 std::vector<TetrahedronConnectivity>& old_tets);
490 bool swap_edge_56(
const Tuple& t, std::vector<Tuple>& new_tets);
499 bool swap_edge_44(
const Tuple& t, std::vector<Tuple>& new_tets);
508 bool swap_edge(
const Tuple& t, std::vector<Tuple>& new_tets);
515 bool swap_face(
const Tuple& t, std::vector<Tuple>& new_tets);
533 bool split_tet(
const Tuple& t, std::vector<Tuple>& new_tets);
545 bool split_face(
const Tuple& t, std::vector<Tuple>& new_tets);
555 const std::vector<Tuple>& intersected_tets,
556 const std::vector<Tuple>& intersected_edges,
557 std::vector<size_t>& new_edge_vids,
558 std::vector<size_t>& new_center_vids,
559 std::vector<std::array<size_t, 4>>& center_split_tets);
570 bool insert_point(
const Tuple& t, std::vector<Tuple>& new_tets);
571 virtual bool insert_point_before(
const Tuple& t) {
return true; };
572 virtual bool insert_point_after(std::vector<Tuple>& new_tets) {
return true; };
603 std::vector<Tuple>
get_tets()
const;
615 virtual void for_each_face(
const std::function<
void(
const TetMesh::Tuple&)>&);
628 template <
typename T>
629 using vector = tbb::concurrent_vector<T>;
632 AbstractAttributeContainer* p_vertex_attrs =
nullptr;
633 AbstractAttributeContainer* p_edge_attrs =
nullptr;
634 AbstractAttributeContainer* p_face_attrs =
nullptr;
635 AbstractAttributeContainer* p_tet_attrs =
nullptr;
641 vector<VertexConnectivity> m_vertex_connectivity;
642 vector<TetrahedronConnectivity> m_tet_connectivity;
643 std::atomic_long current_vert_size;
644 std::atomic_long current_tet_size;
645 tbb::spin_mutex vertex_connectivity_lock;
646 tbb::spin_mutex tet_connectivity_lock;
647 bool vertex_connectivity_synchronizing_flag =
false;
648 bool tet_connectivity_synchronizing_flag =
false;
649 int MAX_THREADS = 128;
651 int m_t_empty_slot = 0;
652 int m_v_empty_slot = 0;
653 int get_next_empty_slot_t();
654 int get_next_empty_slot_v();
658 const std::vector<size_t> t_ids,
659 const std::vector<bool>& mark_surface,
660 const std::map<std::array<size_t, 2>,
size_t>& map_edge2vid,
661 std::map<std::array<size_t, 3>, std::vector<std::array<size_t, 5>>>& new_face_vids,
662 const std::vector<size_t>& new_vids,
663 std::vector<size_t>& new_tids,
664 std::vector<size_t>& new_center_vids,
665 std::vector<std::array<size_t, 4>>& center_split_tets);
668 const std::array<int, 6>& new_v_ids,
670 std::map<std::array<size_t, 3>, std::vector<std::array<size_t, 5>>>& new_face_vids,
671 std::vector<size_t>& new_tids,
672 std::vector<size_t>& new_center_vids,
673 std::vector<std::array<size_t, 4>>& center_split_tets);
676 virtual bool invariants(
const std::vector<Tuple>&) {
return true; }
679 virtual bool triangle_insertion_before(
const std::vector<Tuple>& faces) {
return true; }
680 virtual bool triangle_insertion_after(
const std::vector<std::vector<Tuple>>&) {
return true; }
739 const std::vector<std::array<size_t, 4>>& tets,
770 const std::vector<std::array<size_t, 4>>& tets,
891 std::tuple<Tuple, size_t>
tuple_from_face(
const std::array<size_t, 3>& vids)
const;
912 Tuple
tuple_from_vids(
size_t vid0,
size_t vid1,
size_t vid2,
size_t vid3)
const;
949 auto loc = t.switch_tetrahedron(*
this);
1012 std::vector<size_t> get_incident_tids_for_edge(
const Tuple& t)
const;
1013 std::vector<size_t> get_incident_tids_for_edge(
const size_t vid0,
const size_t vid1)
const;
1048 std::array<size_t, 3> get_face_vids(
const Tuple& t)
const;
1057 std::array<Tuple, 6>
tet_edges(
const Tuple& t)
const;
1076 for (
size_t tid : tids) {
1077 m_tet_connectivity[tid].m_is_removed =
true;
1078 for (
int j = 0; j < 4; j++)
1079 vector_erase(m_vertex_connectivity[m_tet_connectivity[tid][j]].m_conn_tets, tid);
1081 for (
auto& v : m_vertex_connectivity) {
1082 if (v.m_is_removed)
continue;
1083 if (v.m_conn_tets.empty()) v.m_is_removed =
true;
1086 bool m_collapse_check_link_condition =
true;
1087 bool m_collapse_check_topology =
false;
1088 bool m_collapse_check_manifold =
true;
1092 std::vector<size_t>& affected_tid,
1093 const std::vector<std::array<size_t, 4>>& new_tet_conn);
1094 void operation_failure_rollback_imp(
1095 std::map<size_t, VertexConnectivity>& rollback_vert_conn,
1096 const std::vector<size_t>& affected,
1097 const std::vector<size_t>& new_tet_id,
1098 const std::vector<TetrahedronConnectivity>& old_tets);
1100 const std::vector<size_t>& remove_id,
1101 const std::vector<std::array<size_t, 4>>& new_tet_conn,
1102 std::vector<size_t>& allocate_id);
1103 static std::vector<TetrahedronConnectivity> record_old_tet_connectivity(
1104 const TetMesh::vector<TetrahedronConnectivity>& conn,
1105 const std::vector<size_t>& tets)
1107 std::vector<TetrahedronConnectivity> tet_conn;
1108 for (
size_t i : tets) {
1109 tet_conn.push_back(conn[i]);
1115 void start_protect_attributes()
1117 if (p_vertex_attrs) {
1118 p_vertex_attrs->begin_protect();
1121 p_edge_attrs->begin_protect();
1124 p_face_attrs->begin_protect();
1127 p_tet_attrs->begin_protect();
1131 void release_protect_attributes()
1133 if (p_vertex_attrs) {
1134 p_vertex_attrs->end_protect();
1137 p_edge_attrs->end_protect();
1140 p_face_attrs->end_protect();
1143 p_tet_attrs->end_protect();
1147 void rollback_protected_attributes()
1149 if (p_vertex_attrs) {
1150 p_vertex_attrs->rollback();
1153 p_edge_attrs->rollback();
1156 p_face_attrs->rollback();
1159 p_tet_attrs->rollback();
1166 tbb::spin_mutex mutex;
1167 int owner = std::numeric_limits<int>::max();
1170 bool trylock() {
return mutex.try_lock(); }
1178 int get_owner() {
return owner; }
1180 void set_owner(
int n) { owner = n; }
1182 void reset_owner() { owner = INT_MAX; }
1186 tbb::concurrent_vector<VertexMutex> m_vertex_mutex;
1188 bool try_set_vertex_mutex(
const Tuple& v,
int threadid)
1190 bool got = m_vertex_mutex[v.vid(*
this)].trylock();
1191 if (got) m_vertex_mutex[v.vid(*
this)].set_owner(threadid);
1194 bool try_set_vertex_mutex(
size_t vid,
int threadid)
1196 bool got = m_vertex_mutex[vid].trylock();
1197 if (got) m_vertex_mutex[vid].set_owner(threadid);
1201 void unlock_vertex_mutex(
const Tuple& v) { m_vertex_mutex[v.vid(*
this)].unlock(); }
1202 void unlock_vertex_mutex(
size_t vid) { m_vertex_mutex[vid].unlock(); }
1205 void resize_vertex_mutex(
size_t v) { m_vertex_mutex.grow_to_at_least(v); }
1208 tbb::enumerable_thread_specific<std::vector<size_t>> mutex_release_stack;
1209 tbb::enumerable_thread_specific<std::vector<size_t>> get_one_ring_cache;
1212 int release_vertex_mutex_in_stack();
1300 void for_each_edge(
const std::function<
void(
const TetMesh::Tuple&)>&);
1305 void for_each_vertex(
const std::function<
void(
const TetMesh::Tuple&)>&);
1310 void for_each_tetra(
const std::function<
void(
const TetMesh::Tuple&)>&);
1311 int NUM_THREADS = 0;
a Tuple refers to a global vid and a global tet id, and a local edge id and local face id
Definition TetMesh.h:48
Tuple switch_face(const TetMesh &m) const
Definition TetMeshTuple.cpp:253
bool is_valid(const TetMesh &m) const
Definition TetMeshTuple.cpp:57
bool is_boundary_face(const TetMesh &m) const
Definition TetMeshTuple.cpp:17
void print_info() const
prints the tuple
Definition TetMeshTuple.cpp:68
std::optional< Tuple > switch_tetrahedron(const TetMesh &m) const
Definition TetMeshTuple.cpp:273
size_t eid(const TetMesh &m) const
Definition TetMeshTuple.cpp:111
Tuple switch_edge(const TetMesh &m) const
Definition TetMeshTuple.cpp:238
Tuple switch_vertex(const TetMesh &m) const
Definition TetMeshTuple.cpp:224
size_t tid(const TetMesh &m) const
Definition TetMeshTuple.cpp:219
size_t vid(const TetMesh &m) const
Definition TetMeshTuple.cpp:106
size_t fid(const TetMesh &m) const
Definition TetMeshTuple.cpp:131
bool is_boundary_edge(const TetMesh &m) const
Definition TetMeshTuple.cpp:34
void check_validity(const TetMesh &m) const
check Tuple validity and connectivity validity
Definition TetMeshTuple.cpp:358
Definition TetMesh.h:1165
size_t compute_vertex_order(const size_t vid) const
Compute the vertex order for a single vertex.
Definition TetMeshSubstructure.cpp:117
virtual bool swap_edge_44_after(const Tuple &t)
User specified modifications and desideratas for after a 4-4 edge swap.
Definition TetMesh.h:750
std::vector< Tuple > get_one_ring_vertices_for_vertex(const Tuple &t) const
Get the one ring vertices for a vertex.
Definition TetMesh.cpp:712
virtual bool swap_edge_44_before(const Tuple &t)
User specified preparations and desideratas for an 4-4 edge swap before changing the connectivity.
Definition TetMesh.h:727
virtual bool split_tet_before(const Tuple &t)
User specified preparations and desideratas for a tet split before changing the connectivity.
Definition TetMesh.h:850
size_t tet_size() const
get the number of unremoved tets
Definition TetMesh.h:378
virtual size_t get_order_of_vertex(const size_t vid) const
Get the order of a vertex.
Definition TetMesh.h:1375
std::vector< Tuple > get_faces() const
Definition TetMesh.cpp:219
std::array< Tuple, 6 > tet_edges(const Tuple &t) const
get the 6 edges of a tet represented by Tuples
Definition TetMesh.cpp:677
virtual bool smooth_after(const Tuple &t)
User specified modifications and desideratas for after smoothing a vertex.
Definition TetMesh.h:825
void consolidate_mesh()
cleans up the deleted vertices or tetrahedra, fixes the corresponding indices, and reset the version ...
Definition TetMesh.cpp:836
size_t vert_capacity() const
get the current largest global vid
Definition TetMesh.h:354
virtual bool collapse_edge_after(const Tuple &t)
User specified modifications and desideratas for after an edge collapse.
Definition TetMesh.h:719
virtual bool swap_edge_after(const Tuple &t)
User specified modifications and desideratas for after a 3-2 edge swap.
Definition TetMesh.h:796
size_t get_num_surface_faces_for_edge(const std::array< size_t, 2 > &vids) const
Get the number of surface faces incident to the edge.
Definition TetMeshSubstructure.cpp:82
bool smooth_vertex(const Tuple &t)
Definition TetMesh.cpp:339
virtual bool face_is_on_surface(const size_t fid) const
Is a face part of the substructure.
Definition TetMesh.h:1328
bool insert_point(const Tuple &t, std::vector< Tuple > &new_tets)
Insert a point into a tetmesh inside a tet. In general position, this split a tet into 4....
Definition TetMeshTriangleInsertionConn.cpp:412
bool split_edge(const Tuple &t, std::vector< Tuple > &new_tets)
Definition TetMeshEdgeSplittingConn.cpp:6
Tuple switch_face(const Tuple &t) const
wrapper function from Tuple::switch_face
Definition TetMesh.h:938
std::array< Tuple, 4 > oriented_tet_vertices(const Tuple &t) const
Definition TetMesh.cpp:637
void for_each_vertex(const std::function< void(const TetMesh::Tuple &)> &)
perform the given function for each vertex
Definition TetMesh.cpp:1355
bool try_set_vertex_mutex_one_ring(const Tuple &v, int threadid=0)
try lock the one-ring neighboring traingles' incident vertices
Definition TetMesh.cpp:1269
std::array< size_t, 4 > oriented_tet_vids(const Tuple &t) const
Definition TetMesh.cpp:649
bool collapse_edge_check_topology(const std::vector< size_t > &new_tet_id)
Check topology after collapse connectivity change. This is a sanity check and should not be necessary...
Definition TetMeshEdgeCollapsingConn.cpp:419
bool try_set_vertex_mutex_two_ring_vid(const Tuple &v, int threadid)
try lock the two-ring neighboring traingles' incident vertices using vids
Definition TetMesh.cpp:974
Tuple tuple_from_tet(size_t tid) const
get a Tuple from global tetra index
Definition TetMesh.cpp:580
void subdivide_tets(const std::vector< size_t > t_ids, const std::vector< bool > &mark_surface, const std::map< std::array< size_t, 2 >, size_t > &map_edge2vid, std::map< std::array< size_t, 3 >, std::vector< std::array< size_t, 5 > > > &new_face_vids, const std::vector< size_t > &new_vids, std::vector< size_t > &new_tids, std::vector< size_t > &new_center_vids, std::vector< std::array< size_t, 4 > > ¢er_split_tets)
Definition TetMeshTriangleInsertionConn.cpp:141
void init(size_t n_vertices, const std::vector< std::array< size_t, 4 > > &tets)
Definition TetMesh.cpp:77
void subdivide_a_tet(size_t t_id, const std::array< int, 6 > &new_v_ids, bool mark_surface, std::map< std::array< size_t, 3 >, std::vector< std::array< size_t, 5 > > > &new_face_vids, std::vector< size_t > &new_tids, std::vector< size_t > &new_center_vids, std::vector< std::array< size_t, 4 > > ¢er_split_tets)
Definition TetMeshTriangleInsertionConn.cpp:234
virtual bool swap_edge_56_before(const Tuple &t)
User specified preparations and desideratas for a 5-6 edge swap before changing the connectivity.
Definition TetMesh.h:758
std::vector< Tuple > get_incident_tets_for_edge(const Tuple &t) const
Get the incident tets for edge.
Definition TetMesh.cpp:781
virtual bool split_face_after(const Tuple &t)
Compute the attributes for the added simplices.
Definition TetMesh.h:842
bool swap_edge_56(const Tuple &t, std::vector< Tuple > &new_tets)
Definition TetMeshSwapMeshConnectivity.cpp:690
bool split_face(const Tuple &t, std::vector< Tuple > &new_tets)
Split a face in 3 faces.
Definition TetMeshFaceSplittingConn.cpp:6
bool link_condition(const Tuple &t)
Definition TetMeshEdgeCollapsingConn.cpp:310
std::vector< Tuple > get_one_ring_tets_for_edge(const Tuple &t) const
Get the one ring tets for edge.
Definition TetMesh.cpp:816
virtual bool split_face_before(const Tuple &t)
User specified preparations and desideratas for a face split before changing the connectivity.
Definition TetMesh.h:833
virtual double swap_edge_44_energy(const std::vector< std::array< size_t, 4 > > &tets, const int op_case)
User specified energy to decide which of the 4 possible orientations should be chosen.
Definition TetMesh.h:738
Tuple tuple_from_vertex(size_t vid) const
get a Tuple from global vertex index
Definition TetMesh.cpp:567
simplex::SimplexCollection get_surface_faces_for_vertex(const size_t vid) const
Get all faces on the surface that are incident to vid.
Definition TetMeshSubstructure.cpp:7
virtual void for_each_face(const std::function< void(const TetMesh::Tuple &)> &)
looping through all the unique edges and perform the given function
Definition TetMesh.cpp:205
std::vector< size_t > get_one_ring_vids_for_vertex(size_t vid, std::vector< size_t > &cache)
Get the one ring vids for vertex.
Definition TetMesh.cpp:757
std::optional< Tuple > switch_tetrahedron(const Tuple &t) const
wrapper function from Tuple::switch_tetrahedron
Definition TetMesh.h:947
size_t get_order_of_edge(const std::array< size_t, 2 > &vids) const
Compute the order of an edge.
Definition TetMeshSubstructure.cpp:203
std::vector< Tuple > get_tets() const
Definition TetMesh.cpp:308
virtual bool smooth_before(const Tuple &t)
User specified preparations and desideratas for smoothing a vertex.
Definition TetMesh.h:818
virtual bool split_edge_before(const Tuple &t)
User specified preparations and desideratas for an edge split before changing the connectivity.
Definition TetMesh.h:690
std::vector< size_t > get_one_ring_vids_for_vertex_adj(size_t vid) const
Duplicate of the function TetMesh::get_one_ring_vids_for_vertex.
Definition TetMesh.cpp:743
virtual bool swap_edge_before(const Tuple &t)
User specified preparations and desideratas for an 3-2 edge swap before changing the conenctivity.
Definition TetMesh.h:789
void triangle_insertion(const std::vector< Tuple > &intersected_tets, const std::vector< Tuple > &intersected_edges, std::vector< size_t > &new_edge_vids, std::vector< size_t > &new_center_vids, std::vector< std::array< size_t, 4 > > ¢er_split_tets)
Insert a triangle into a tetmesh, with known intersection information.
Definition TetMeshTriangleInsertionConn.cpp:11
bool check_mesh_connectivity_validity() const
checks the validity of the connectivity of the mesh. Including the validity of each Tuple
Definition TetMesh.cpp:234
bool split_tet(const Tuple &t, std::vector< Tuple > &new_tets)
Split a tet in 4 tets.
Definition TetMeshTetSplittingConn.cpp:6
Tuple tuple_from_edge(size_t tid, int local_eid) const
get a Tuple from global tetra index and local edge index (from 0-5).
Definition TetMesh.cpp:353
size_t vertex_size() const
get the number of unremoved verticies
Definition TetMesh.h:366
Tuple switch_vertex(const Tuple &t) const
wrapper function from Tuple::switch_vertex
Definition TetMesh.h:920
simplex::SimplexCollection get_surface_faces_for_edge(const std::array< size_t, 2 > &vids) const
Get all faces on the surface that are incident to the edge.
Definition TetMeshSubstructure.cpp:42
bool substructure_link_condition(const Tuple &e_tuple) const
Link condition that also considers substructures.
Definition TetMeshSubstructure.cpp:218
virtual bool swap_face_before(const Tuple &t)
User specified preparations and desideratas for an 2-3 face swap befroe changing the geometry.
Definition TetMesh.h:804
bool try_set_edge_mutex_two_ring(const Tuple &e, int threadid=0)
try lock the two-ring neighboring triangles' incident vertices for the two ends of an edge
Definition TetMesh.cpp:1023
virtual bool vertex_is_on_surface(const size_t vid) const
Is a vertex part of the substructure.
Definition TetMesh.h:1321
bool swap_edge(const Tuple &t, std::vector< Tuple > &new_tets)
3-2 edge swap
Definition TetMeshSwapMeshConnectivity.cpp:120
Tuple switch_edge(const Tuple &t) const
wrapper function from Tuple::switch_edge
Definition TetMesh.h:929
std::vector< Tuple > get_edges() const
Definition TetMesh.cpp:172
std::vector< size_t > get_one_ring_tids_for_vertex(const Tuple &t) const
Get the one ring tids for vertex.
Definition TetMesh.cpp:690
virtual bool split_tet_after(const Tuple &t)
Compute the attributes for the added simplices.
Definition TetMesh.h:859
void for_each_edge(const std::function< void(const TetMesh::Tuple &)> &)
perform the given function for each edge
Definition TetMesh.cpp:1294
bool collapse_edge_conn(const Tuple &loc0, std::vector< Tuple > &new_edges, size_t &v1_id, Tuple &new_loc, std::map< size_t, wmtk::TetMesh::VertexConnectivity > &rollback_vert_conn, std::vector< size_t > &n1_t_ids_copy, std::vector< size_t > &new_tet_id, std::vector< TetrahedronConnectivity > &old_tets)
Definition TetMeshEdgeCollapsingConn.cpp:449
void check_tuple_validity(const Tuple &t) const
Definition TetMesh.h:1061
void collapse_edge_rollback(size_t &v1_id, std::map< size_t, wmtk::TetMesh::VertexConnectivity > &rollback_vert_conn, std::vector< size_t > &n1_t_ids, std::vector< size_t > &new_tet_id, std::vector< TetrahedronConnectivity > &old_tets)
Definition TetMeshEdgeCollapsingConn.cpp:438
bool try_set_vertex_mutex_two_ring(const Tuple &v, int threadid)
try lock the two-ring neighboring traingles' incident vertices
Definition TetMesh.cpp:952
virtual bool collapse_edge(const Tuple &t, std::vector< Tuple > &new_tets)
Definition TetMeshEdgeCollapsingConn.cpp:263
bool try_set_face_mutex_two_ring(const Tuple &f, int threadid=0)
try lock the two-ring neighboring triangles' incident vertices for the 3 vertices of a face
Definition TetMesh.cpp:1069
Tuple tuple_from_face(size_t tid, int local_fid) const
get a Tuple from global tetra index and local face index (from 0-3).
Definition TetMesh.cpp:363
virtual bool split_edge_after(const Tuple &t)
This function computes the attributes for the added simplices. User specified modifications and desid...
Definition TetMesh.h:699
static constexpr std::array< std::array< int, 2 >, 6 > m_local_edges
local edges within a tet
Definition TetMesh.h:29
std::map< size_t, VertexConnectivity > operation_update_connectivity_impl(std::vector< size_t > &affected_tid, const std::vector< std::array< size_t, 4 > > &new_tet_conn)
Definition TetMeshSwapMeshConnectivity.cpp:43
std::array< Tuple, 3 > get_face_vertices(const Tuple &t) const
Get the 3 vertices of a face represented by Tuple.
Definition TetMesh.cpp:659
virtual bool swap_edge_56_after(const Tuple &t)
User specified modifications and desideratas for after a 5-6 edge swap.
Definition TetMesh.h:781
virtual bool collapse_edge_before(const Tuple &t)
User specified preparations and desideratas for an edge collapse before changing the connectivity.
Definition TetMesh.h:710
std::vector< Tuple > get_vertices() const
Definition TetMesh.cpp:323
size_t tet_capacity() const
get the current largest global tid
Definition TetMesh.h:360
std::vector< Tuple > get_one_ring_tets_for_vertex(const Tuple &t) const
Get the one ring tets for a vertex.
Definition TetMesh.cpp:701
void for_each_tetra(const std::function< void(const TetMesh::Tuple &)> &)
perform the given function for each tet
Definition TetMesh.cpp:1327
bool swap_edge_44(const Tuple &t, std::vector< Tuple > &new_tets)
Definition TetMeshSwapMeshConnectivity.cpp:472
virtual double swap_edge_56_energy(const std::vector< std::array< size_t, 4 > > &tets, const int op_case)
User specified energy to decide which of the 5 possible orientations should be chosen.
Definition TetMesh.h:769
bool swap_face(const Tuple &t, std::vector< Tuple > &new_tets)
2-3 face swap
Definition TetMeshSwapMeshConnectivity.cpp:231
void remove_tets_by_ids(const std::vector< size_t > &tids)
remove the tetrahedrons in the mesh that have given tet ids
Definition TetMesh.h:1074
Tuple tuple_from_vids(size_t vid0, size_t vid1, size_t vid2, size_t vid3) const
Get a Tuple from global vertex IDs.
Definition TetMesh.cpp:591
std::vector< std::array< size_t, 3 > > vertex_adjacent_boundary_faces(const Tuple &t) const
Definition TetMesh.cpp:915
virtual bool swap_face_after(const Tuple &t)
User specified modifications and desideratas for after a 2-3 face swap.
Definition TetMesh.h:811
Definition Simplex.hpp:57
Definition SimplexCollection.hpp:9
Definition Simplex.hpp:71