25 const std::vector<int> &dirichlet_nodes,
26 const std::vector<int> &neumann_nodes,
27 const std::vector<RowVectorNd> &dirichlet_nodes_position,
28 const std::vector<RowVectorNd> &neumann_nodes_position,
31 const std::vector<basis::ElementBases> &
bases,
32 const std::vector<basis::ElementBases> &
gbases,
35 const std::string bc_method,
36 const json &solver_params);
39 void assemble(
const Density &density, Eigen::MatrixXd &rhs,
const double t = 1)
const;
53 const std::vector<mesh::LocalBoundary> &local_boundary,
54 const std::vector<int> &bounday_nodes,
56 const std::vector<mesh::LocalBoundary> &local_neumann_boundary,
58 const Eigen::MatrixXd &displacement = Eigen::MatrixXd(),
59 const double t = 1)
const;
63 const Eigen::MatrixXd &displacement,
64 const Eigen::MatrixXd &displacement_prev,
65 const std::vector<mesh::LocalBoundary> &local_neumann_boundary,
68 const double t)
const;
71 const std::vector<mesh::LocalBoundary> &local_boundary,
72 const std::vector<int> &bounday_nodes,
75 const std::vector<mesh::LocalBoundary> &local_neumann_boundary,
76 const Eigen::MatrixXd &final_rhs,
78 Eigen::MatrixXd &rhs)
const;
83 const std::vector<mesh::LocalBoundary> &local_neumann_boundary,
84 const Eigen::MatrixXd &displacement,
86 const bool project_to_psd,
91 inline const std::vector<basis::ElementBases> &
bases()
const {
return bases_; }
92 inline const std::vector<basis::ElementBases> &
gbases()
const {
return gbases_; }
98 void lsq_bc(
const std::function<
void(
const Eigen::MatrixXi &,
const Eigen::MatrixXd &,
const Eigen::MatrixXd &, Eigen::MatrixXd &)> &df,
99 const std::vector<mesh::LocalBoundary> &local_boundary,
100 const std::vector<int> &bounday_nodes,
101 const int resolution,
102 Eigen::MatrixXd &rhs)
const;
105 void sample_bc(
const std::function<
void(
const Eigen::MatrixXi &,
const Eigen::MatrixXd &,
const Eigen::MatrixXd &, Eigen::MatrixXd &)> &df,
106 const std::vector<mesh::LocalBoundary> &local_boundary,
107 const std::vector<int> &bounday_nodes,
108 Eigen::MatrixXd &rhs)
const;
114 const std::function<
void(
const Eigen::MatrixXi &,
const Eigen::MatrixXd &,
const Eigen::MatrixXd &, Eigen::MatrixXd &)> &df,
115 const std::function<
void(
const Eigen::MatrixXi &,
const Eigen::MatrixXd &,
const Eigen::MatrixXd &,
const Eigen::MatrixXd &, Eigen::MatrixXd &)> &nf,
116 const std::vector<mesh::LocalBoundary> &local_boundary,
117 const std::vector<int> &bounday_nodes,
119 const std::vector<mesh::LocalBoundary> &local_neumann_boundary,
120 const Eigen::MatrixXd &displacement,
122 Eigen::MatrixXd &rhs)
const;
127 void time_bc(
const std::function<
void(
const mesh::Mesh &,
const Eigen::MatrixXi &,
const Eigen::MatrixXd &, Eigen::MatrixXd &)> &fun, Eigen::MatrixXd &sol)
const;
134 const std::vector<basis::ElementBases> &
bases_;
135 const std::vector<basis::ElementBases> &
gbases_;
Caches basis evaluation and geometric mapping at every element.
void time_bc(const std::function< void(const mesh::Mesh &, const Eigen::MatrixXi &, const Eigen::MatrixXd &, Eigen::MatrixXd &)> &fun, Eigen::MatrixXd &sol) const
void compute_energy_hess(const std::vector< int > &bounday_nodes, const QuadratureOrders &resolution, const std::vector< mesh::LocalBoundary > &local_neumann_boundary, const Eigen::MatrixXd &displacement, const double t, const bool project_to_psd, StiffnessMatrix &hess) const
const Assembler & assembler_
const AssemblyValsCache & ass_vals_cache() const
void set_bc(const std::vector< mesh::LocalBoundary > &local_boundary, const std::vector< int > &bounday_nodes, const QuadratureOrders &resolution, const std::vector< mesh::LocalBoundary > &local_neumann_boundary, Eigen::MatrixXd &rhs, const Eigen::MatrixXd &displacement=Eigen::MatrixXd(), const double t=1) const
const mesh::Mesh & mesh() const
const std::vector< RowVectorNd > & neumann_nodes_position_
const std::vector< basis::ElementBases > & gbases_
basis functions associated with geometric mapping
const Problem & problem() const
const int size_
dimension of problem
double compute_energy(const Eigen::MatrixXd &displacement, const Eigen::MatrixXd &displacement_prev, const std::vector< mesh::LocalBoundary > &local_neumann_boundary, const Density &density, const QuadratureOrders &resolution, const double t) const
const std::vector< int > & neumann_nodes_
const std::vector< RowVectorNd > & dirichlet_nodes_position_
const std::string bc_method_
const Assembler & assembler() const
const AssemblyValsCache & ass_vals_cache_
void initial_solution(Eigen::MatrixXd &sol) const
const mesh::Obstacle & obstacle_
const json solver_params_
void lsq_bc(const std::function< void(const Eigen::MatrixXi &, const Eigen::MatrixXd &, const Eigen::MatrixXd &, Eigen::MatrixXd &)> &df, const std::vector< mesh::LocalBoundary > &local_boundary, const std::vector< int > &bounday_nodes, const int resolution, Eigen::MatrixXd &rhs) const
const std::vector< basis::ElementBases > & bases_
basis functions associated with solution
const std::vector< basis::ElementBases > & gbases() const
void compute_energy_grad(const std::vector< mesh::LocalBoundary > &local_boundary, const std::vector< int > &bounday_nodes, const Density &density, const QuadratureOrders &resolution, const std::vector< mesh::LocalBoundary > &local_neumann_boundary, const Eigen::MatrixXd &final_rhs, const double t, Eigen::MatrixXd &rhs) const
void set_bc(const std::function< void(const Eigen::MatrixXi &, const Eigen::MatrixXd &, const Eigen::MatrixXd &, Eigen::MatrixXd &)> &df, const std::function< void(const Eigen::MatrixXi &, const Eigen::MatrixXd &, const Eigen::MatrixXd &, const Eigen::MatrixXd &, Eigen::MatrixXd &)> &nf, const std::vector< mesh::LocalBoundary > &local_boundary, const std::vector< int > &bounday_nodes, const QuadratureOrders &resolution, const std::vector< mesh::LocalBoundary > &local_neumann_boundary, const Eigen::MatrixXd &displacement, const double t, Eigen::MatrixXd &rhs) const
void initial_acceleration(Eigen::MatrixXd &sol) const
void initial_velocity(Eigen::MatrixXd &sol) const
void assemble(const Density &density, Eigen::MatrixXd &rhs, const double t=1) const
const std::vector< int > & dirichlet_nodes_
const std::vector< basis::ElementBases > & bases() const
void sample_bc(const std::function< void(const Eigen::MatrixXi &, const Eigen::MatrixXd &, const Eigen::MatrixXd &, Eigen::MatrixXd &)> &df, const std::vector< mesh::LocalBoundary > &local_boundary, const std::vector< int > &bounday_nodes, Eigen::MatrixXd &rhs) const
Abstract mesh class to capture 2d/3d conforming and non-conforming meshes.
std::array< int, 2 > QuadratureOrders
Eigen::SparseMatrix< double, Eigen::ColMajor > StiffnessMatrix