PolyFEM
Loading...
Searching...
No Matches
NLHomoProblem.hpp
Go to the documentation of this file.
1#pragma once
2
3#include "NLProblem.hpp"
4
5namespace polyfem
6{
7 namespace assembler
8 {
9 class MacroStrainValue;
10 }
11 namespace legacy
12 {
13 class State;
14 }
15} // namespace polyfem
16
17namespace polyfem::solver
18{
19 class NLHomoProblem : public NLProblem
20 {
21 public:
22 using typename FullNLProblem::Scalar;
23 using typename FullNLProblem::THessian;
24 using typename FullNLProblem::TVector;
25
26 NLHomoProblem(const int full_size,
27 const assembler::MacroStrainValue &macro_strain_constraint,
28 const legacy::State &state,
29 const double t,
30 const std::vector<std::shared_ptr<Form>> &forms,
31 const std::vector<std::shared_ptr<AugmentedLagrangianForm>> &penalty_forms,
32 const bool solve_symmetric_macro_strain,
33 const std::shared_ptr<polysolve::linear::Solver> &solver,
34 const double char_length,
35 const double char_force,
36 StiffnessMatrix lumped_mass,
37 const int dimension);
38 virtual ~NLHomoProblem() = default;
39
40 double value(const TVector &x) override;
41 void gradient(const TVector &x, TVector &gradv) override;
42 void hessian(const TVector &x, THessian &hessian) override;
43
44 void full_hessian_to_reduced_hessian(THessian &hessian) const;
45
46 int macro_reduced_size() const;
47
48 TVector full_to_reduced(const TVector &full, const Eigen::MatrixXd &disp_grad) const;
49 TVector full_to_reduced(const TVector &full) const;
50 TVector full_to_reduced_grad(const TVector &full) const override;
51 TVector full_to_reduced_diag(const TVector &full_diag) const override;
52 TVector reduced_to_full(const TVector &reduced) const;
53
54 TVector reduced_to_extended(const TVector &reduced, bool homogeneous = false) const;
55 TVector extended_to_reduced(const TVector &extended) const;
56 TVector extended_to_reduced_grad(const TVector &extended) const;
57 void extended_hessian_to_reduced_hessian(const THessian &extended, THessian &reduced) const;
58
59 Eigen::MatrixXd reduced_to_disp_grad(const TVector &reduced, bool homogeneous = false) const;
60
61 void set_fixed_entry(const Eigen::VectorXi &fixed_entry);
62
63 void init(const TVector &x0) override;
64 bool is_step_valid(const TVector &x0, const TVector &x1) override;
65 bool is_step_collision_free(const TVector &x0, const TVector &x1) override;
66 double max_step_size(const TVector &x0, const TVector &x1) override;
67
68 void line_search_begin(const TVector &x0, const TVector &x1) override;
69 void post_step(const polysolve::nonlinear::PostStepData &data) override;
70
71 void solution_changed(const TVector &new_x) override;
72
73 void init_lagging(const TVector &x) override;
74 void update_lagging(const TVector &x, const int iter_num) override;
75
76 void update_quantities(const double t, const TVector &x) override;
77
78 void add_form(const std::shared_ptr<Form> &form) { homo_forms.push_back(form); }
79 bool has_symmetry_constraint() const { return only_symmetric; }
80
81 private:
82 void init_projection();
83 Eigen::MatrixXd constraint_grad() const;
84
85 TVector macro_full_to_reduced(const TVector &full) const;
86 Eigen::MatrixXd macro_full_to_reduced_grad(const Eigen::MatrixXd &full) const;
87 TVector macro_reduced_to_full(const TVector &reduced, bool homogeneous = false) const;
88
90 const bool only_symmetric;
92
93 Eigen::VectorXi fixed_mask_;
94 Eigen::MatrixXd macro_mid_to_reduced_; // (dim*dim) x (dim*(dim+1)/2)
96
97 std::vector<std::shared_ptr<Form>> homo_forms;
98 };
99} // namespace polyfem::solver
int x
main class that contains the polyfem solver and all its state
Definition State.hpp:114
std::vector< std::shared_ptr< Form > > & forms()
Eigen::MatrixXd reduced_to_disp_grad(const TVector &reduced, bool homogeneous=false) const
void gradient(const TVector &x, TVector &gradv) override
void init(const TVector &x0) override
void post_step(const polysolve::nonlinear::PostStepData &data) override
void set_fixed_entry(const Eigen::VectorXi &fixed_entry)
TVector macro_full_to_reduced(const TVector &full) const
const legacy::State & state_
bool is_step_valid(const TVector &x0, const TVector &x1) override
const assembler::MacroStrainValue & macro_strain_constraint_
void line_search_begin(const TVector &x0, const TVector &x1) override
void update_quantities(const double t, const TVector &x) override
TVector extended_to_reduced_grad(const TVector &extended) const
void hessian(const TVector &x, THessian &hessian) override
void init_lagging(const TVector &x) override
TVector full_to_reduced_diag(const TVector &full_diag) const override
TVector reduced_to_extended(const TVector &reduced, bool homogeneous=false) const
TVector reduced_to_full(const TVector &reduced) const
TVector extended_to_reduced(const TVector &extended) const
virtual ~NLHomoProblem()=default
std::vector< std::shared_ptr< Form > > homo_forms
Eigen::MatrixXd constraint_grad() const
Eigen::MatrixXd macro_full_to_reduced_grad(const Eigen::MatrixXd &full) const
double value(const TVector &x) override
TVector full_to_reduced(const TVector &full, const Eigen::MatrixXd &disp_grad) const
TVector full_to_reduced_grad(const TVector &full) const override
void full_hessian_to_reduced_hessian(THessian &hessian) const
void solution_changed(const TVector &new_x) override
double max_step_size(const TVector &x0, const TVector &x1) override
void extended_hessian_to_reduced_hessian(const THessian &extended, THessian &reduced) const
bool is_step_collision_free(const TVector &x0, const TVector &x1) override
void add_form(const std::shared_ptr< Form > &form)
void update_lagging(const TVector &x, const int iter_num) override
TVector macro_reduced_to_full(const TVector &reduced, bool homogeneous=false) const
polyfem::legacy::State State
Definition Remesher.hpp:19
Eigen::SparseMatrix< double, Eigen::ColMajor > StiffnessMatrix
Definition Types.hpp:24