16 #ifndef SURGSIM_DATASTRUCTURES_SEGMENTMESH_INL_H 17 #define SURGSIM_DATASTRUCTURES_SEGMENTMESH_INL_H 24 namespace DataStructures
27 template <
class VertexData,
class EdgeData>
32 template <
class VertexData,
class EdgeData>
39 template <
class VertexData,
class EdgeData>
40 template <
class V,
class E>
46 template <
class VertexData,
class EdgeData>
51 template <
class VertexData,
class EdgeData>
57 template <
class VertexData,
class EdgeData>
61 return TriangleMeshType::operator=(other);
64 template <
class VertexData,
class EdgeData>
68 return TriangleMeshType::operator=(std::move(other));
71 template <
class VertexData,
class EdgeData>
75 return static_cast<size_t>(0);
78 template <
class VertexData,
class EdgeData>
82 return static_cast<size_t>(0);
85 template <
class VertexData,
class EdgeData>
86 const std::vector<typename SegmentMesh<VertexData, EdgeData>::TriangleType>&
90 return TriangleMeshType::getTriangles();
93 template <
class VertexData,
class EdgeData>
94 std::vector<typename SegmentMesh<VertexData, EdgeData>::TriangleType>&
98 return TriangleMeshType::getTriangles();
101 template <
class VertexData,
class EdgeData>
106 return TriangleMeshType::getTriangle(
id);
109 template <
class VertexData,
class EdgeData>
114 return TriangleMeshType::getTriangle(
id);
117 template <
class VertexData,
class EdgeData>
123 template <
class VertexData,
class EdgeData>
124 std::array<SurgSim::Math::Vector3d, 3>
129 std::array<Vector3d, 3> result =
140 template <
class VertexData,
class EdgeData>
146 template <
class VertexData,
class EdgeData>
149 TriangleMeshType::doClearEdges();
150 TriangleMeshType::doClearVertices();
153 template <
class VertexData,
class EdgeData>
157 for (
size_t i = 0; i < getNumVertices() - 1; ++i)
159 std::array<size_t, 2> vertices = { i, i + 1 };
166 template <
class VertexData,
class EdgeData>
172 double youngsModulus)
174 std::fstream out(fileName, std::ios::out);
178 out <<
"ply" << std::endl;
179 out <<
"format ascii 1.0" << std::endl;
180 out <<
"comment Created by OpenSurgSim, www.opensurgsim.org" << std::endl;
181 out <<
"element vertex " << getNumVertices() << std::endl;
182 out <<
"property float x\nproperty float y\nproperty float z" << std::endl;
185 out <<
"element 1d_element " << getNumEdges() << std::endl;
186 out <<
"property list uint uint vertex_indices" << std::endl;
187 out <<
"element radius 1" << std::endl;
188 out <<
"property double value" << std::endl;
189 out <<
"element material 1" << std::endl;
190 out <<
"property double mass_density" << std::endl;
191 out <<
"property double poisson_ratio" << std::endl;
192 out <<
"property double young_modulus" << std::endl;
193 out <<
"element boundary_condition 0" << std::endl;
194 out <<
"property uint vertex_index" << std::endl;
198 out <<
"element edge " << getNumEdges() << std::endl;
199 out <<
"property uint vertex1" << std::endl;
200 out <<
"property uint vertex2" << std::endl;
202 out <<
"end_header" << std::endl;
203 for (
const auto& vertex : getVertices())
205 out << vertex.position[0] <<
" " << vertex.position[1] <<
" " << vertex.position[2] << std::endl;
208 for (
const auto& edge : getEdges())
214 out << edge.verticesId[0] <<
" " << edge.verticesId[1] << std::endl;
218 out << radius << std::endl;
219 out << massDensity <<
" " << poissonRatio <<
" " << youngsModulus << std::endl;
225 <<
"There was a problem writing " << fileName;
233 <<
"Could not open " << fileName <<
" for writing.";
243 #endif // SURGSIM_DATASTRUCTURES_SEGMENTMESH_INL_H Wraps glewInit() to separate the glew opengl definitions from the osg opengl definitions only imgui n...
Definition: AddRandomSphereBehavior.cpp:36
#define SURGSIM_LOG_WARNING(logger)
Logs a message to the specified logger at the WARNING level.
Definition: LogMacros.h:96
SegmentMesh()
Constructor. The mesh is initially empty (no vertices, no edges).
Definition: SegmentMesh-inl.h:28
Definition: MockObjects.h:47
#define SURGSIM_FAILURE()
Report that something very bad has happened and abort program execution.
Definition: Assert.h:95
Eigen::Matrix< double, 3, 1 > Vector3d
A 3D vector of doubles.
Definition: Vector.h:57
The convenience header that provides the entirety of the logging API.
Class to hold the type of a SegmentMesh.
Definition: SegmentMesh.h:33
void createDefaultEdges()
Creates edges for all vertices in the mesh connecting all the points consecutively.
Definition: SegmentMesh-inl.h:154
Element structure for meshes.
Definition: MeshElement.h:44
static std::shared_ptr< Logger > getDefaultLogger()
Get default logger.
Definition: Logger.h:116
TriangleMeshType::TriangleType TriangleType
Triangle type for convenience (Ids of the 3 vertices)
Definition: SegmentMesh.h:41