45 MpcOsqp(
const Eigen::MatrixXd &matrix_a,
const Eigen::MatrixXd &matrix_b,
46 const Eigen::MatrixXd &matrix_q,
const Eigen::MatrixXd &matrix_r,
47 const Eigen::MatrixXd &matrix_initial_x,
48 const Eigen::MatrixXd &matrix_u_lower,
49 const Eigen::MatrixXd &matrix_u_upper,
50 const Eigen::MatrixXd &matrix_x_lower,
51 const Eigen::MatrixXd &matrix_x_upper,
52 const Eigen::MatrixXd &matrix_x_ref,
const int max_iter,
53 const int horizon,
const double eps_abs);
56 bool Solve(std::vector<double> *control_cmd);
59 void CalculateKernel(std::vector<c_float> *P_data,
60 std::vector<c_int> *P_indices,
61 std::vector<c_int> *P_indptr);
62 void CalculateEqualityConstraint(std::vector<c_float> *A_data,
63 std::vector<c_int> *A_indices,
64 std::vector<c_int> *A_indptr);
65 void CalculateGradient();
66 void CalculateConstraintVectors();
67 OSQPSettings *Settings();
69 void FreeData(OSQPData *data);
72 T *CopyData(
const std::vector<T> &vec) {
73 T *data =
new T[vec.size()];
74 memcpy(data, vec.data(),
sizeof(T) * vec.size());
79 Eigen::MatrixXd matrix_a_;
80 Eigen::MatrixXd matrix_b_;
81 Eigen::MatrixXd matrix_q_;
82 Eigen::MatrixXd matrix_r_;
83 Eigen::MatrixXd matrix_initial_x_;
84 const Eigen::MatrixXd matrix_u_lower_;
85 const Eigen::MatrixXd matrix_u_upper_;
86 const Eigen::MatrixXd matrix_x_lower_;
87 const Eigen::MatrixXd matrix_x_upper_;
88 const Eigen::MatrixXd matrix_x_ref_;
96 Eigen::VectorXd gradient_;
97 Eigen::VectorXd lowerBound_;
98 Eigen::VectorXd upperBound_;