Go to the documentation of this file.
25 #ifndef SRC_OPTIMIZATION_INCLUDE_CORBO_OPTIMIZATION_SOLVER_QP_SOLVER_INTERFACE_H_
26 #define SRC_OPTIMIZATION_INCLUDE_CORBO_OPTIMIZATION_SOLVER_QP_SOLVER_INTERFACE_H_
33 #ifdef MESSAGE_SUPPORT
34 #include <corbo-communication/messages/optimization/qp_solvers.pb.h>
73 class QpSolverInterface
76 using Ptr = std::shared_ptr<QpSolverInterface>;
77 using UPtr = std::unique_ptr<QpSolverInterface>;
111 bool new_structure =
true,
bool zero_x_warmstart =
false) = 0;
127 bool update_q =
true,
bool update_A =
true,
bool update_bounds =
true) = 0;
138 virtual void clear() = 0;
140 #ifdef MESSAGE_SUPPORT
142 virtual void toMessage(corbo::messages::QpSolver& message)
const {}
143 virtual void fromMessage(
const corbo::messages::QpSolver& message, std::stringstream* issues =
nullptr) {}
148 #define FACTORY_REGISTER_QP_SOLVER(type) FACTORY_REGISTER_OBJECT(type, QpSolverInterface)
152 #endif // SRC_OPTIMIZATION_INCLUDE_CORBO_OPTIMIZATION_SOLVER_QP_SOLVER_INTERFACE_H_
A versatible sparse matrix representation.
std::unique_ptr< QpSolverInterface > UPtr
virtual bool isSupportingSimpleBounds()=0
virtual void enforceNewStructure(bool new_structure=true)=0
virtual Eigen::Ref< Eigen::VectorXd > getDualSolution()=0
Factory< QpSolverInterface > QpSolverFactory
std::shared_ptr< QpSolverInterface > Ptr
EIGEN_DEVICE_FUNC const Scalar & q
Eigen::SparseMatrix< double, Eigen::ColMajor, long long > SparseMatrix
virtual void updateDualSolutionWarmStart(const Eigen::Ref< const Eigen::VectorXd > &y)=0
virtual SolverStatus solve(SparseMatrix &P, Eigen::Ref< Eigen::VectorXd > q, SparseMatrix &A, Eigen::Ref< Eigen::VectorXd > lbA, Eigen::Ref< Eigen::VectorXd > ubA, Eigen::Ref< Eigen::VectorXd > lb, Eigen::Ref< Eigen::VectorXd > ub, bool new_structure=true, bool zero_x_warmstart=false)=0
Solve full QP.
virtual void clear()=0
clear internal caches
A matrix or vector expression mapping an existing expression.
virtual ~QpSolverInterface()=default
Virtual destructor.
MatrixType A(a, *n, *n, *lda)
virtual bool initialize()
Initialize the qp solver.
virtual void updatePrimalSolutionWarmStart(const Eigen::Ref< const Eigen::VectorXd > &x)=0
virtual Eigen::Ref< Eigen::VectorXd > getPrimalSolution()=0
virtual Ptr getInstance() const =0
Return a newly created instance of the current solver.
control_box_rst
Author(s): Christoph Rösmann
autogenerated on Wed Mar 2 2022 00:06:08