43 : m_variables{detail::GradientExpressionGraph<Scalar>{
variable}
46 slp_assert(m_wrt.cols() == 1);
49 for (
size_t col = 0; col < m_wrt.size(); ++col) {
50 m_wrt[col].expr->col = col;
53 for (
auto& variable : m_variables) {
54 m_graphs.emplace_back(variable);
58 for (
auto& node : m_wrt) {
62 for (
int row = 0; row < m_variables.rows(); ++row) {
63 if (m_variables[row].expr ==
nullptr) {
67 if (m_variables[row].type() == ExpressionType::LINEAR) {
71 m_graphs[row].append_triplets(m_cached_triplets, row, m_wrt);
72 }
else if (m_variables[row].type() > ExpressionType::LINEAR) {
75 m_nonlinear_rows.emplace_back(row);
79 if (m_nonlinear_rows.empty()) {
80 m_H.setFromTriplets(m_cached_triplets.begin(), m_cached_triplets.end());
81 if constexpr (UpLo == Eigen::Lower) {
82 m_H = m_H.template triangularView<Eigen::Lower>();