Loading [MathJax]/extensions/tex2jax.js
PolyFEM
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
SumModel.hpp
Go to the documentation of this file.
1#pragma once
2
5
6namespace polyfem::assembler
7{
9 {
10 public:
14
15 // compute elastic energy
16 double compute_energy(const NonLinearAssemblerData &data) const override;
17 // necessary for mixing linear model with non-linear collision response
18 Eigen::MatrixXd assemble_hessian(const NonLinearAssemblerData &data) const override;
19 // compute gradient of elastic energy, as assembler
20 Eigen::VectorXd assemble_gradient(const NonLinearAssemblerData &data) const override;
21
22 // uses autodiff to compute the rhs for a fabricated solution
23 // uses autogenerated code to compute div(sigma)
24 // pt is the evaluation of the solution at a point
25 VectorNd compute_rhs(const AutodiffHessianPt &pt) const override;
26
27 // initialize material parameter
28 void add_multimaterial(const int index, const json &params, const Units &units) override;
29
30 std::string name() const override { return "MaterialSum"; }
31 bool allow_inversion() const override { return true; }
32 std::map<std::string, ParamFunc> parameters() const override;
33
34 protected:
35 void assign_stress_tensor(const OutputData &data,
36 const int all_size,
37 const ElasticityTensorType &type,
38 Eigen::MatrixXd &all,
39 const std::function<Eigen::MatrixXd(const Eigen::MatrixXd &)> &fun) const override;
40
41 private:
42 std::vector<std::shared_ptr<assembler::NLAssembler>> assemblers_;
43 };
44} // namespace polyfem::assembler
double assemble_energy(const bool is_volume, const std::vector< basis::ElementBases > &bases, const std::vector< basis::ElementBases > &gbases, const AssemblyValsCache &cache, const double t, const double dt, const Eigen::MatrixXd &displacement, const Eigen::MatrixXd &displacement_prev) const override
void assemble_gradient(const bool is_volume, const int n_basis, const std::vector< basis::ElementBases > &bases, const std::vector< basis::ElementBases > &gbases, const AssemblyValsCache &cache, const double t, const double dt, const Eigen::MatrixXd &displacement, const Eigen::MatrixXd &displacement_prev, Eigen::MatrixXd &rhs) const override
void assemble_hessian(const bool is_volume, const int n_basis, const bool project_to_psd, const std::vector< basis::ElementBases > &bases, const std::vector< basis::ElementBases > &gbases, const AssemblyValsCache &cache, const double t, const double dt, const Eigen::MatrixXd &displacement, const Eigen::MatrixXd &displacement_prev, utils::MatrixCache &mat_cache, StiffnessMatrix &grad) const override
bool allow_inversion() const override
Definition SumModel.hpp:31
std::map< std::string, ParamFunc > parameters() const override
Definition SumModel.cpp:109
std::string name() const override
Definition SumModel.hpp:30
VectorNd compute_rhs(const AutodiffHessianPt &pt) const override
Definition SumModel.cpp:52
Eigen::VectorXd assemble_gradient(const NonLinearAssemblerData &data) const override
Definition SumModel.cpp:62
Eigen::MatrixXd assemble_hessian(const NonLinearAssemblerData &data) const override
Definition SumModel.cpp:74
std::vector< std::shared_ptr< assembler::NLAssembler > > assemblers_
Definition SumModel.hpp:42
void add_multimaterial(const int index, const json &params, const Units &units) override
Definition SumModel.cpp:12
double compute_energy(const NonLinearAssemblerData &data) const override
Definition SumModel.cpp:85
void assign_stress_tensor(const OutputData &data, const int all_size, const ElasticityTensorType &type, Eigen::MatrixXd &all, const std::function< Eigen::MatrixXd(const Eigen::MatrixXd &)> &fun) const override
Definition SumModel.cpp:96
Used for test only.
Eigen::Matrix< AutodiffScalarHessian, Eigen::Dynamic, 1, 0, 3, 1 > AutodiffHessianPt
Eigen::Matrix< double, Eigen::Dynamic, 1, 0, 3, 1 > VectorNd
Definition Types.hpp:11
nlohmann::json json
Definition Common.hpp:9