PolyFEM
Loading...
Searching...
No Matches
IncompressibleElasticVarForm.hpp
Go to the documentation of this file.
1#pragma once
2
4
7
8namespace polysolve::linear
9{
10 class Solver;
11}
12
13namespace polyfem::varform
14{
16 {
17 public:
18 std::string name() const override { return "IncompressibleElastic"; }
19
20 void init(const std::string &formulation, const Units &units, const json &args, const std::string &out_path) override;
21 void save_json(const Eigen::MatrixXd &solution, std::ostream &out) const override;
22 io::OutStatsData compute_errors(const Eigen::MatrixXd &solution) override;
23
24 std::vector<io::OutputField> output_fields(
25 const io::OutputSample &sample,
26 const Eigen::MatrixXd &solution,
27 const io::OutputFieldOptions &options) const override;
28
29 private:
30 void reset() override;
31 void load_mesh(const mesh::Mesh &mesh, const json &args) override;
32 void build_basis(mesh::Mesh &mesh, const bool iso_parametric, const json &args) override;
33 void assemble_rhs(const mesh::Mesh &mesh) override;
34 void assemble_mass_mat(const mesh::Mesh &mesh, const json &args) override;
35 void solve_problem(Eigen::MatrixXd &sol) override;
36
37 int primary_ndof() const;
38 int stacked_ndof() const;
39 void prepare_initial_solution(Eigen::MatrixXd &sol) const;
40 void split_solution(const Eigen::MatrixXd &stacked, Eigen::MatrixXd &primary, Eigen::MatrixXd &pressure) const;
41 void build_stiffness_mat(StiffnessMatrix &stiffness);
43 const std::unique_ptr<polysolve::linear::Solver> &solver,
45 Eigen::VectorXd &b,
46 const bool compute_spectrum,
47 Eigen::MatrixXd &sol);
48 void solve_static_linear(Eigen::MatrixXd &sol);
49 void solve_transient_linear(Eigen::MatrixXd &sol);
50
51 void build_rhs_assembler() override;
52
55
56 std::shared_ptr<assembler::MixedAssembler> mixed_assembler_ = nullptr;
57 std::shared_ptr<assembler::Assembler> pressure_assembler_ = nullptr;
59
60 std::shared_ptr<time_integrator::ImplicitTimeIntegrator> time_integrator;
61 };
62} // namespace polyfem::varform
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
A finite-element space for one scalar- or vector-valued field.
Definition FESpace.hpp:59
std::vector< io::OutputField > output_fields(const io::OutputSample &sample, const Eigen::MatrixXd &solution, const io::OutputFieldOptions &options) const override
Get the output fields of the variational formulation, for output purposes.
void assemble_mass_mat(const mesh::Mesh &mesh, const json &args) override
std::shared_ptr< time_integrator::ImplicitTimeIntegrator > time_integrator
void save_json(const Eigen::MatrixXd &solution, std::ostream &out) const override
Save the solution to a JSON file, for output purposes.
void solve_linear_system(const std::unique_ptr< polysolve::linear::Solver > &solver, StiffnessMatrix &A, Eigen::VectorXd &b, const bool compute_spectrum, Eigen::MatrixXd &sol)
std::string name() const override
Get the name of the variational formulation.
std::shared_ptr< assembler::MixedAssembler > mixed_assembler_
void load_mesh(const mesh::Mesh &mesh, const json &args) override
void split_solution(const Eigen::MatrixXd &stacked, Eigen::MatrixXd &primary, Eigen::MatrixXd &pressure) const
void build_basis(mesh::Mesh &mesh, const bool iso_parametric, const json &args) override
std::shared_ptr< assembler::Assembler > pressure_assembler_
io::OutStatsData compute_errors(const Eigen::MatrixXd &solution) override
Get the error statistics of the variational formulation, for output purposes.
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.
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