PolyFEM
Loading...
Searching...
No Matches
SumModel.cpp
Go to the documentation of this file.
1#include "SumModel.hpp"
2
3#include <jse/jse.h>
4
5// #include <polyfem/basis/Basis.hpp>
6// #include <polyfem/autogen/auto_elasticity_rhs.hpp>
7
8// #include <igl/Timer.h>
9
10namespace polyfem::assembler
11{
12 void SumModel::add_multimaterial(const int index, const json &params, const Units &units)
13 {
14 assert(size() == 2 || size() == 3);
15 if (params.count("models") == 0)
16 return;
17
18 auto models = params["models"];
19
20 for (const auto &model : models)
21 {
22 const std::string model_name = model["type"];
23
24 const auto assembler = AssemblerUtils::make_assembler(model_name);
25 // cast assembler to elasticity assembler
26 assemblers_.emplace_back(std::dynamic_pointer_cast<NLAssembler>(assembler));
27 assert(assemblers_.back() != nullptr);
28 assemblers_.back()->set_size(size());
29 assemblers_.back()->add_multimaterial(index, model, units);
30 }
31 }
32
33 Eigen::Matrix<double, Eigen::Dynamic, 1, 0, 3, 1>
35 {
36 assert(pt.size() == size());
37 Eigen::Matrix<double, Eigen::Dynamic, 1, 0, 3, 1> res;
38 assert(false);
39
40 return res;
41 }
42
43 Eigen::VectorXd
45 {
46 Eigen::VectorXd gradient = assemblers_.front()->assemble_gradient(data);
47 for (size_t i = 1; i < assemblers_.size(); ++i)
48 {
49 const auto assembler = assemblers_[i];
50 gradient += assembler->assemble_gradient(data);
51 }
52 return gradient;
53 }
54
55 Eigen::MatrixXd
57 {
58 Eigen::MatrixXd hessian = assemblers_.front()->assemble_hessian(data);
59 for (size_t i = 1; i < assemblers_.size(); ++i)
60 {
61 const auto assembler = assemblers_[i];
62 hessian += assembler->assemble_hessian(data);
63 }
64 return hessian;
65 }
66
68 {
69 double energy = assemblers_.front()->compute_energy(data);
70 for (size_t i = 1; i < assemblers_.size(); ++i)
71 {
72 const auto assembler = assemblers_[i];
73 energy += assembler->compute_energy(data);
74 }
75 return energy;
76 }
77
79 const OutputData &data,
80 const int all_size,
81 const ElasticityTensorType &type,
82 Eigen::MatrixXd &all,
83 const std::function<Eigen::MatrixXd(const Eigen::MatrixXd &)> &fun) const
84 {
85 all.resize(data.local_pts.rows(), all_size);
86 all.setZero();
87
88 Eigen::MatrixXd tmp;
89
90 for (const auto &assembler : assemblers_)
91 {
92 std::dynamic_pointer_cast<assembler::ElasticityNLAssembler>(assembler)->assign_stress_tensor(data, all_size, type, tmp, fun);
93 all += tmp;
94 }
95 }
96
97 std::map<std::string, Assembler::ParamFunc> SumModel::parameters() const
98 {
99 std::map<std::string, Assembler::ParamFunc> params;
100 for (const auto &a : assemblers_)
101 {
102 auto p = a->parameters();
103 for (auto &it : p)
104 {
105 params[a->name() + "/" + it.first] = it.second;
106 }
107 }
108 return params;
109 }
110} // namespace polyfem::assembler
static std::shared_ptr< Assembler > make_assembler(const std::string &formulation)
const Eigen::MatrixXd & local_pts
std::map< std::string, ParamFunc > parameters() const override
Definition SumModel.cpp:97
VectorNd compute_rhs(const AutodiffHessianPt &pt) const override
Definition SumModel.cpp:34
Eigen::VectorXd assemble_gradient(const NonLinearAssemblerData &data) const override
Definition SumModel.cpp:44
Eigen::MatrixXd assemble_hessian(const NonLinearAssemblerData &data) const override
Definition SumModel.cpp:56
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:67
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:78
Used for test only.
Eigen::Matrix< AutodiffScalarHessian, Eigen::Dynamic, 1, 0, 3, 1 > AutodiffHessianPt
nlohmann::json json
Definition Common.hpp:9