19 Eigen::VectorXi active_dofs)
20 : dof_num_(states[0]->ndof()),
21 states_(std::move(states)),
22 diff_caches_(std::move(diff_caches)),
23 parametrization_(std::move(parametrizations)),
24 active_dofs_(std::move(active_dofs))
31 if (!s->problem->is_time_dependent())
51 for (
int i = 0; i <
states_.size(); ++i)
53 Eigen::MatrixXd sol, vel;
54 states_[i]->initial_solution(sol);
55 states_[i]->initial_velocity(vel);
61 sol.conservativeResize(Eigen::NoChange, 1);
65 vel.conservativeResize(Eigen::NoChange, 1);
68 if (sol.rows() !=
dof_num_ || sol.cols() != 1)
70 log_and_throw_adjoint_error(
"Fail to construct initial condition variable to simulation. Reason: Invalid initial solution shape ({}, {}). Expect ({}, 1).",
73 if (vel.rows() !=
dof_num_ || vel.cols() != 1)
75 log_and_throw_adjoint_error(
"Fail to construct initial condition variable to simulation. Reason: Invalid initial velocity shape ({}, {}). Expect ({}, 1).",
79 diff_caches_[i]->initial_condition_override.solution = sol;
80 diff_caches_[i]->initial_condition_override.velocity = vel;
81 diff_caches_[i]->initial_condition_override.acceleration = {};
99 if (s.get() == &target)
115 auto &sol = dc->initial_condition_override.solution;
116 auto &vel = dc->initial_condition_override.velocity;
118 assert(sol.rows() ==
dof_num_ && sol.cols() >= 1);
119 assert(vel.rows() ==
dof_num_ && vel.cols() >= 1);
121 for (
int i = 0; i < active_num; ++i)
127 dc->initial_condition_override.acceleration = {};
133 assert(state_variables.size() == 2 *
dof_num_);
139 for (
int i = 0; i < active_num; ++i)
148 Eigen::VectorXd term, cur_term;
149 for (
int i = 0; i <
states_.size(); ++i)
158 if (term.size() != cur_term.size())
168 assert(term.size() == 2 *
dof_num_);
172 for (
int j = 0; j < active_num; ++j)
189 const Eigen::MatrixXd &sol =
diff_caches_[0]->initial_condition_override.solution;
190 const Eigen::MatrixXd &vel =
diff_caches_[0]->initial_condition_override.velocity;
191 assert(sol.rows() ==
dof_num_ && sol.cols() >= 1);
192 assert(vel.rows() ==
dof_num_ && vel.cols() >= 1);
196 for (
int j = 0; j < active_num; ++j)
main class that contains the polyfem solver and all its state
Eigen::VectorXd apply_jacobian(const Eigen::VectorXd &grad_full, const Eigen::VectorXd &x) const override
Apply jacobian for chain rule.
Eigen::VectorXd inverse_eval(const Eigen::VectorXd &y) const override
Eval x = f^-1 (y).
int inverse_size(int y_size) const override
Compute DOF of x given DOF of y.
Eigen::VectorXd eval(const Eigen::VectorXd &x) const override
Eval y = f(x).
std::vector< std::shared_ptr< DiffCache > > DiffCachePtrs
Eigen::VectorXi active_dofs_
int inverse_dof() const override
Compute optimization variables dof.
Eigen::VectorXd compute_adjoint_term(const Eigen::VectorXd &x) const override
Compute adjoint contribution of objective gradient.
Eigen::VectorXd apply_parametrization_jacobian(const Eigen::VectorXd &term, const Eigen::VectorXd &x) const override
Apply parametrization jacobian to compute the gradient w.r.t.
Eigen::VectorXd inverse_eval() const override
Compute optimization variables from forward simulation legacy::State.
std::vector< std::shared_ptr< legacy::State > > StatePtrs
std::string name() const override
InitialConditionVariableToSimulation(StatePtrs states, DiffCachePtrs diff_caches, CompositeParametrization parametrizations, Eigen::VectorXi active_dofs)
Construct InitialConditionVariableToSimulation.
DiffCachePtrs diff_caches_
void update(const Eigen::VectorXd &x) override
Update forward simulation states from optimization variables.
bool affect_state(const legacy::State &target) const override
Return true if current var2sim maps to target state.
ParameterType parameter_type() const override
void update_state_variables(const Eigen::VectorXd &x, Eigen::VectorXd &state_variables) const override
Update state variables from optimization variables.
CompositeParametrization parametrization_
bool is_active_dofs_valid(const Eigen::VectorXi &active_dofs, const std::vector< std::shared_ptr< legacy::State > > &states, std::string &reason)
Validate active solution space dofs selection given states.
void log_and_throw_adjoint_error(const std::string &msg)
Eigen::MatrixXd get_adjoint_mat(const legacy::State &state, const DiffCache &diff_cache, int type)
Get adjoint parameter nu or p.