8#include <Eigen/SparseCholesky>
9#include <Eigen/SparseCore>
10#include <gch/small_vector.hpp>
12#include "sleipnir/optimization/solver/util/append_as_triplets.hpp"
19template <
typename Scalar>
22 Eigen::Vector<Scalar, Eigen::Dynamic>
y;
24 Eigen::Vector<Scalar, Eigen::Dynamic>
z;
33template <
typename Scalar>
34Eigen::Vector<Scalar, Eigen::Dynamic> lagrange_multiplier_estimate(
35 const Eigen::SparseVector<Scalar>& g,
36 const Eigen::SparseMatrix<Scalar>& A_e) {
42 return Eigen::SimplicialLDLT<Eigen::SparseMatrix<Scalar>>{A_e *
57template <
typename Scalar>
58LagrangeMultiplierEstimate<Scalar> lagrange_multiplier_estimate(
59 const Eigen::SparseVector<Scalar>& g,
60 const Eigen::SparseMatrix<Scalar>& A_e,
61 const Eigen::SparseMatrix<Scalar>& A_i,
62 const Eigen::Vector<Scalar, Eigen::Dynamic>& s, Scalar μ) {
63 using DenseVector = Eigen::Vector<Scalar, Eigen::Dynamic>;
64 using SparseMatrix = Eigen::SparseMatrix<Scalar>;
89 gch::small_vector<Eigen::Triplet<Scalar>> triplets;
93 triplets.reserve(A_e.nonZeros() + A_i.nonZeros() + s.rows());
94 append_as_triplets(triplets, 0, 0, {A_e, A_i});
95 append_diagonal_as_triplets(triplets, A_e.rows(), A_i.cols(), (-s).eval());
96 SparseMatrix A_hat{A_e.rows() + A_i.rows(), A_e.cols() + s.rows()};
97 A_hat.setFromSortedTriplets(triplets.begin(), triplets.end());
100 SparseMatrix lhs = A_hat * A_hat.transpose();
104 DenseVector rhs_temp{g.rows() + s.rows()};
105 rhs_temp.segment(0, g.rows()) = g;
106 rhs_temp.segment(g.rows(), s.rows()).setConstant(-μ);
107 DenseVector rhs = A_hat * rhs_temp;
109 Eigen::SimplicialLDLT<SparseMatrix> yz_estimator{lhs};
110 DenseVector sol = yz_estimator.solve(rhs);
111 DenseVector y = sol.segment(0, A_e.rows());
112 DenseVector z = sol.segment(A_e.rows(), s.rows());
127 for (
int row = 0; row < z.rows(); ++row) {
128 constexpr Scalar κ_Σ(1e10);
129 z[row] = std::clamp(z[row], Scalar(1) / κ_Σ * μ / s[row], κ_Σ * μ / s[row]);
132 return {std::move(y), std::move(z)};
Definition lagrange_multiplier_estimate.hpp:20
Eigen::Vector< Scalar, Eigen::Dynamic > y
Equality constraint dual estimate.
Definition lagrange_multiplier_estimate.hpp:22
Eigen::Vector< Scalar, Eigen::Dynamic > z
Inequality constraint dual estimate.
Definition lagrange_multiplier_estimate.hpp:24