PolyFEM
Loading...
Searching...
No Matches
OutData.hpp
Go to the documentation of this file.
1#pragma once
2
3#include <polyfem/Common.hpp>
4
6
8
11
12#include <paraviewo/ParaviewWriter.hpp>
13#include <paraviewo/VTUWriter.hpp>
14#include <paraviewo/HDF5VTUWriter.hpp>
15
17
18#include <Eigen/Dense>
19
20namespace polyfem::io
21{
24 {
25 public:
28 {
29 std::vector<std::string> fields; // fields to export, empty means all
30
31 bool volume;
32 bool surface;
33 bool wire;
34 bool points;
39
45
47
53 ExportOptions(const json &args,
54 const bool is_mesh_linear,
55 const bool mesh_has_prisms,
56 const bool is_problem_scalar);
57
60 inline std::string file_extension() const
61 {
62 return use_hdf5 ? ".hdf" : ".vtu";
63 }
64
65 bool export_field(const std::string &field) const;
66 };
67
77 static void extract_boundary_mesh(
78 const mesh::Mesh &mesh,
79 const int n_bases,
80 const std::vector<basis::ElementBases> &bases,
81 const std::vector<mesh::LocalBoundary> &total_local_boundary,
82 Eigen::MatrixXd &node_positions,
83 Eigen::MatrixXi &boundary_edges,
84 Eigen::MatrixXi &boundary_triangles,
85 std::vector<Eigen::Triplet<double>> &displacement_map_entries);
86
90 void init_sampler(const polyfem::mesh::Mesh &mesh, const double vismesh_rel_area);
91
95 void build_grid(const polyfem::mesh::Mesh &mesh, const double spacing);
96
105 void export_data(
106 const OutputSpace &space,
107 const OutputFieldFunction &output_fields,
108 const bool is_time_dependent,
109 const double tend_in,
110 const double dt,
111 const ExportOptions &opts,
112 const std::string &vis_mesh_path) const;
113
121 void save_vtu(const std::string &path,
122 const OutputSpace &space,
123 const OutputFieldFunction &output_fields,
124 const double t,
125 const double dt,
126 const ExportOptions &opts) const;
127
135 void save_volume(const std::string &path,
136 const OutputSpace &space,
137 const OutputFieldFunction &output_fields,
138 const double t,
139 const double dt,
140 const ExportOptions &opts) const;
141
149 void save_surface(const std::string &export_surface,
150 const OutputSpace &space,
151 const OutputFieldFunction &output_fields,
152 const double t,
153 const double dt_in,
154 const ExportOptions &opts) const;
155
164 const std::string &export_surface,
165 const OutputSpace &space,
166 const OutputFieldFunction &output_fields,
167 const double t,
168 const double dt_in,
169 const ExportOptions &opts) const;
170
177 void save_wire(const std::string &name,
178 const OutputSpace &space,
179 const OutputFieldFunction &output_fields,
180 const double t,
181 const ExportOptions &opts) const;
182
188 void save_points(
189 const std::string &path,
190 const OutputSpace &space,
191 const OutputFieldFunction &output_fields,
192 const ExportOptions &opts) const;
193
201 void save_pvd(const std::string &name, const std::function<std::string(int)> &vtu_names,
202 int time_steps, double t0, double dt, int skip_frame = 1) const;
203
204 private:
207
209 Eigen::MatrixXd grid_points;
211 Eigen::MatrixXi grid_points_to_elements;
213 Eigen::MatrixXd grid_points_bc;
214
226 const mesh::Mesh &mesh,
227 const std::vector<basis::ElementBases> &gbases,
228 const std::vector<mesh::LocalBoundary> &total_local_boundary,
229 Eigen::MatrixXd &boundary_vis_vertices,
230 Eigen::MatrixXd &boundary_vis_local_vertices,
231 Eigen::MatrixXi &boundary_vis_elements,
232 Eigen::MatrixXi &boundary_vis_elements_ids,
233 Eigen::MatrixXi &boundary_vis_primitive_ids,
234 Eigen::MatrixXd &boundary_vis_normals) const;
235
250 void build_vis_mesh(
251 const mesh::Mesh &mesh,
252 const Eigen::VectorXi &disc_orders,
253 const std::vector<basis::ElementBases> &gbases,
254 const std::map<int, Eigen::MatrixXd> &polys,
255 const std::map<int, std::pair<Eigen::MatrixXd, Eigen::MatrixXi>> &polys_3d,
256 const bool boundary_only,
257 Eigen::MatrixXd &points,
258 Eigen::MatrixXi &tets,
259 Eigen::MatrixXi &el_id,
260 Eigen::MatrixXd &discr,
261 Eigen::MatrixXd &local_points) const;
262
274 const mesh::Mesh &mesh,
275 const Eigen::VectorXi &output_orders,
276 const std::vector<basis::ElementBases> &bases,
277 Eigen::MatrixXd &points,
278 std::vector<paraviewo::CellElement> &elements,
279 Eigen::MatrixXi &el_id,
280 Eigen::MatrixXd &discr,
281 Eigen::MatrixXd &local_points) const;
282 };
283
284} // namespace polyfem::io
Utilies related to export of geometry.
Definition OutData.hpp:24
void build_vis_boundary_mesh(const mesh::Mesh &mesh, const std::vector< basis::ElementBases > &gbases, const std::vector< mesh::LocalBoundary > &total_local_boundary, Eigen::MatrixXd &boundary_vis_vertices, Eigen::MatrixXd &boundary_vis_local_vertices, Eigen::MatrixXi &boundary_vis_elements, Eigen::MatrixXi &boundary_vis_elements_ids, Eigen::MatrixXi &boundary_vis_primitive_ids, Eigen::MatrixXd &boundary_vis_normals) const
builds the boundary mesh for visualization
Definition OutData.cpp:495
Eigen::MatrixXd grid_points_bc
grid mesh boundaries
Definition OutData.hpp:213
void build_high_order_vis_mesh(const mesh::Mesh &mesh, const Eigen::VectorXi &output_orders, const std::vector< basis::ElementBases > &bases, Eigen::MatrixXd &points, std::vector< paraviewo::CellElement > &elements, Eigen::MatrixXi &el_id, Eigen::MatrixXd &discr, Eigen::MatrixXd &local_points) const
builds high-der visualzation mesh per element all disconnected it also retuns the mapping to element ...
Eigen::MatrixXd grid_points
grid mesh points to export solution sampled on a grid
Definition OutData.hpp:209
void save_volume(const std::string &path, const OutputSpace &space, const OutputFieldFunction &output_fields, const double t, const double dt, const ExportOptions &opts) const
saves the volume vtu file
Definition OutData.cpp:1248
void build_vis_mesh(const mesh::Mesh &mesh, const Eigen::VectorXi &disc_orders, const std::vector< basis::ElementBases > &gbases, const std::map< int, Eigen::MatrixXd > &polys, const std::map< int, std::pair< Eigen::MatrixXd, Eigen::MatrixXi > > &polys_3d, const bool boundary_only, Eigen::MatrixXd &points, Eigen::MatrixXi &tets, Eigen::MatrixXi &el_id, Eigen::MatrixXd &discr, Eigen::MatrixXd &local_points) const
builds visualzation mesh, upsampled mesh used for visualization the visualization mesh is a dense mes...
Definition OutData.cpp:721
void build_grid(const polyfem::mesh::Mesh &mesh, const double spacing)
builds the grid to export the solution
Definition OutData.cpp:1630
void save_wire(const std::string &name, const OutputSpace &space, const OutputFieldFunction &output_fields, const double t, const ExportOptions &opts) const
saves the wireframe
Definition OutData.cpp:1512
static void extract_boundary_mesh(const mesh::Mesh &mesh, const int n_bases, const std::vector< basis::ElementBases > &bases, const std::vector< mesh::LocalBoundary > &total_local_boundary, Eigen::MatrixXd &node_positions, Eigen::MatrixXi &boundary_edges, Eigen::MatrixXi &boundary_triangles, std::vector< Eigen::Triplet< double > > &displacement_map_entries)
extracts the boundary mesh
Definition OutData.cpp:95
void save_pvd(const std::string &name, const std::function< std::string(int)> &vtu_names, int time_steps, double t0, double dt, int skip_frame=1) const
save a PVD of a time dependent simulation
Definition OutData.cpp:1617
void save_contact_surface(const std::string &export_surface, const OutputSpace &space, const OutputFieldFunction &output_fields, const double t, const double dt_in, const ExportOptions &opts) const
saves the surface vtu file for for constact quantites, eg contact or friction forces
Definition OutData.cpp:1472
void export_data(const OutputSpace &space, const OutputFieldFunction &output_fields, const bool is_time_dependent, const double tend_in, const double dt, const ExportOptions &opts, const std::string &vis_mesh_path) const
exports everytihng, txt, vtu, etc
Definition OutData.cpp:1124
void save_points(const std::string &path, const OutputSpace &space, const OutputFieldFunction &output_fields, const ExportOptions &opts) const
saves the nodal values
Definition OutData.cpp:1563
void save_vtu(const std::string &path, const OutputSpace &space, const OutputFieldFunction &output_fields, const double t, const double dt, const ExportOptions &opts) const
saves the vtu file for time t
Definition OutData.cpp:1183
void init_sampler(const polyfem::mesh::Mesh &mesh, const double vismesh_rel_area)
unitalize the ref element sampler
Definition OutData.cpp:1625
void save_surface(const std::string &export_surface, const OutputSpace &space, const OutputFieldFunction &output_fields, const double t, const double dt_in, const ExportOptions &opts) const
saves the surface vtu file for for surface quantites, eg traction forces
Definition OutData.cpp:1401
Eigen::MatrixXi grid_points_to_elements
grid mesh mapping to fe elements
Definition OutData.hpp:211
utils::RefElementSampler ref_element_sampler
used to sample the solution
Definition OutData.hpp:206
Abstract mesh class to capture 2d/3d conforming and non-conforming meshes.
Definition Mesh.hpp:41
std::function< std::vector< OutputField >(const OutputSample &)> OutputFieldFunction
nlohmann::json json
Definition Common.hpp:9
std::string file_extension() const
return the extension of the output paraview files depending on use_hdf5
Definition OutData.hpp:60
std::vector< std::string > fields
Definition OutData.hpp:29
bool export_field(const std::string &field) const
Definition OutData.cpp:1151