PolyFEM
Loading...
Searching...
No Matches
ElasticVarForm.hpp
Go to the documentation of this file.
1#pragma once
2
4
5namespace polyfem::mesh
6{
7 class Obstacle;
8}
9
10namespace polyfem::solver
11{
12 class ContactForm;
13 class Form;
14} // namespace polyfem::solver
15
17{
18 class ImplicitTimeIntegrator;
19}
20
21namespace polyfem::varform
22{
23 class ElasticVarForm : public VarForm
24 {
26
27 public:
28 void init(const std::string &formulation, const Units &units, const json &args, const std::string &out_path) override;
29
30 void save_json(const Eigen::MatrixXd &solution, std::ostream &out) const override;
31 void export_data(const Eigen::MatrixXd &solution) const override;
32 io::OutputSpace output_space() const override;
33 io::OutStatsData compute_errors(const Eigen::MatrixXd &solution) override;
34
35 protected:
36 void reset() override;
37 void load_mesh(const mesh::Mesh &mesh, const json &args) override;
38 void build_basis(mesh::Mesh &mesh, const bool iso_parametric, const json &args) override;
39 void assemble_rhs(const mesh::Mesh &mesh) override;
40 void assemble_mass_mat(const mesh::Mesh &mesh, const json &args) override;
41 void build_rhs_assembler() override;
42
43 void initial_velocity(Eigen::MatrixXd &velocity) const;
44 void initial_acceleration(Eigen::MatrixXd &acceleration) const;
45 void initial_elastic_solution(Eigen::MatrixXd &solution) const;
47 std::vector<int> elastic_primitive_to_node() const;
48 std::vector<int> elastic_node_to_primitive() const;
49 void build_mesh_matrices(Eigen::MatrixXd &V, Eigen::MatrixXi &F) const;
51 const double t0,
52 const double dt,
53 const int t,
54 const time_integrator::ImplicitTimeIntegrator *time_integrator) const;
55 std::vector<io::OutputField> elastic_output_fields(
56 const io::OutputSample &sample,
57 const Eigen::MatrixXd &solution,
58 const io::OutputFieldOptions &options,
59 const mesh::Obstacle *obstacle,
60 const time_integrator::ImplicitTimeIntegrator *time_integrator,
61 const std::vector<std::pair<std::string, std::shared_ptr<solver::Form>>> &named_forms,
62 const solver::Form *elastic_form,
63 const solver::ContactForm *contact_form = nullptr) const;
65 std::vector<io::OutputField> &fields,
66 const io::OutputSample &sample,
67 const Eigen::MatrixXd &solution,
68 const io::OutputFieldOptions &options,
69 const mesh::Obstacle *obstacle = nullptr) const;
70 Eigen::MatrixXd displaced_output_normals(
71 const io::OutputSample &sample,
72 const Eigen::MatrixXd &solution) const;
73
74 virtual int n_obstacle_vertices() const { return 0; }
75
78
82
83 std::shared_ptr<assembler::RhsAssembler> rhs_assembler_;
84
87
88 double avg_mass_ = 0;
89 Eigen::MatrixXd rhs_;
90
91 std::shared_ptr<assembler::Assembler> primary_assembler_ = nullptr;
92 std::shared_ptr<assembler::Mass> mass_assembler_ = nullptr;
93 std::shared_ptr<assembler::HRZMass> pure_mass_assembler_ = nullptr;
94
95 double t0 = 0;
96 int time_steps = 0;
97 double dt = 0;
98 };
99} // namespace polyfem::varform
int V
Caches basis evaluation and geometric mapping at every element.
all stats from polyfem
Abstract mesh class to capture 2d/3d conforming and non-conforming meshes.
Definition Mesh.hpp:41
Form representing the contact potential and forces.
Implicit time integrator of a second order ODE (equivently a system of coupled first order ODEs).
void build_basis(mesh::Mesh &mesh, const bool iso_parametric, const json &args) override
assembler::AssemblyValsCache pure_mass_ass_vals_cache_
void save_json(const Eigen::MatrixXd &solution, std::ostream &out) const override
Save the solution to a JSON file, for output purposes.
io::OutputSpace output_space() const override
Get the output space of the variational formulation, for output purposes.
std::vector< int > elastic_primitive_to_node() const
io::OutStatsData compute_errors(const Eigen::MatrixXd &solution) override
Get the error statistics of the variational formulation, for output purposes.
void assemble_mass_mat(const mesh::Mesh &mesh, const json &args) override
std::shared_ptr< assembler::Assembler > primary_assembler_
void save_elastic_step_state(const double t0, const double dt, const int t, const time_integrator::ImplicitTimeIntegrator *time_integrator) const
void init(const std::string &formulation, const Units &units, const json &args, const std::string &out_path) override
Initialize the variational formulation with the given parameters.
Eigen::MatrixXd displaced_output_normals(const io::OutputSample &sample, const Eigen::MatrixXd &solution) const
std::vector< int > elastic_node_to_primitive() const
QuadratureOrders elastic_boundary_samples() const
assembler::AssemblyValsCache ass_vals_cache_
std::vector< io::OutputField > elastic_output_fields(const io::OutputSample &sample, const Eigen::MatrixXd &solution, const io::OutputFieldOptions &options, const mesh::Obstacle *obstacle, const time_integrator::ImplicitTimeIntegrator *time_integrator, const std::vector< std::pair< std::string, std::shared_ptr< solver::Form > > > &named_forms, const solver::Form *elastic_form, const solver::ContactForm *contact_form=nullptr) const
void initial_velocity(Eigen::MatrixXd &velocity) const
std::shared_ptr< assembler::HRZMass > pure_mass_assembler_
void initial_elastic_solution(Eigen::MatrixXd &solution) const
std::shared_ptr< assembler::Mass > mass_assembler_
void initial_acceleration(Eigen::MatrixXd &acceleration) const
std::shared_ptr< assembler::RhsAssembler > rhs_assembler_
assembler::AssemblyValsCache mass_ass_vals_cache_
void load_mesh(const mesh::Mesh &mesh, const json &args) override
virtual int n_obstacle_vertices() const
void assemble_rhs(const mesh::Mesh &mesh) override
friend class polyfem::test::VarFormTestAccess
void append_primary_output_fields(std::vector< io::OutputField > &fields, const io::OutputSample &sample, const Eigen::MatrixXd &solution, const io::OutputFieldOptions &options, const mesh::Obstacle *obstacle=nullptr) const
void build_mesh_matrices(Eigen::MatrixXd &V, Eigen::MatrixXi &F) const
void export_data(const Eigen::MatrixXd &solution) const override
A finite-element space for one scalar- or vector-valued field.
Definition FESpace.hpp:59
std::array< int, 2 > QuadratureOrders
Definition Types.hpp:19
nlohmann::json json
Definition Common.hpp:9
Eigen::SparseMatrix< double, Eigen::ColMajor > StiffnessMatrix
Definition Types.hpp:24
Temporary compatibility wrapper for boundary data belonging to one FE space.
Definition FESpace.hpp:152