28 #include <coin/IpTNLP.hpp> 29 #include <coin/IpTypes.hpp> 31 #include "Eigen/Dense" 45 void set_start_point(
const double x,
const double y,
const double theta,
46 const double kappa,
const double dkappa);
48 void set_end_point(
const double x,
const double y,
const double theta,
49 const double kappa,
const double dkappa);
60 std::vector<double>* ptr_kappa,
61 std::vector<double>* ptr_dkappa,
62 std::vector<double>* ptr_s,
63 std::vector<double>* ptr_x,
64 std::vector<double>* ptr_y)
const;
67 bool get_nlp_info(
int& n,
int& m,
int& nnz_jac_g,
int& nnz_h_lag,
68 IndexStyleEnum& index_style)
override;
71 bool get_bounds_info(
int n,
double* x_l,
double* x_u,
int m,
double* g_l,
72 double* g_u)
override;
76 double* z_L,
double* z_U,
int m,
bool init_lambda,
77 double* lambda)
override;
80 bool eval_f(
int n,
const double* x,
bool new_x,
double& obj_value)
override;
83 bool eval_grad_f(
int n,
const double* x,
bool new_x,
double* grad_f)
override;
86 bool eval_g(
int n,
const double* x,
bool new_x,
int m,
double* g)
override;
92 bool eval_jac_g(
int n,
const double* x,
bool new_x,
int m,
int nele_jac,
93 int* iRow,
int* jCol,
double* values)
override;
100 bool eval_h(
int n,
const double* x,
bool new_x,
double obj_factor,
int m,
101 const double* lambda,
bool new_lambda,
int nele_hess,
int* iRow,
102 int* jCol,
double* values)
override;
108 const double* z_L,
const double* z_U,
int m,
109 const double* g,
const double* lambda,
110 double obj_value,
const Ipopt::IpoptData* ip_data,
111 Ipopt::IpoptCalculatedQuantities* ip_cq)
override;
114 static constexpr
size_t N = 10;
117 void update_piecewise_spiral_paths(
const double* x,
const int n);
119 std::vector<Eigen::Vector2d> init_points_;
121 std::vector<double> opt_theta_;
123 std::vector<double> opt_kappa_;
125 std::vector<double> opt_dkappa_;
127 std::vector<double> opt_s_;
129 std::vector<double> opt_x_;
131 std::vector<double> opt_y_;
133 std::vector<double> point_distances_;
135 int num_of_variables_ = 0;
137 int num_of_constraints_ = 0;
139 int num_of_points_ = 0;
141 double default_max_point_deviation_ = 0.0;
143 const int num_of_internal_points_ = 5;
145 std::vector<double> relative_theta_;
147 std::vector<QuinticSpiralPathWithDerivation<N>> piecewise_paths_;
149 bool has_fixed_start_point_ =
false;
151 double start_x_ = 0.0;
153 double start_y_ = 0.0;
155 double start_theta_ = 0.0;
157 double start_kappa_ = 0.0;
159 double start_dkappa_ = 0.0;
161 bool has_fixed_end_point_ =
false;
167 double end_theta_ = 0.0;
169 double end_kappa_ = 0.0;
171 double end_dkappa_ = 0.0;
173 bool has_fixed_end_point_position_ =
false;
175 double weight_curve_length_ = 1.0;
177 double weight_kappa_ = 1.0;
179 double weight_dkappa_ = 1.0;
SpiralProblemInterface(std::vector< Eigen::Vector2d > points)
bool eval_f(int n, const double *x, bool new_x, double &obj_value) override
void finalize_solution(Ipopt::SolverReturn status, int n, const double *x, const double *z_L, const double *z_U, int m, const double *g, const double *lambda, double obj_value, const Ipopt::IpoptData *ip_data, Ipopt::IpoptCalculatedQuantities *ip_cq) override
void set_start_point(const double x, const double y, const double theta, const double kappa, const double dkappa)
void get_optimization_results(std::vector< double > *ptr_theta, std::vector< double > *ptr_kappa, std::vector< double > *ptr_dkappa, std::vector< double > *ptr_s, std::vector< double > *ptr_x, std::vector< double > *ptr_y) const
PlanningContext is the runtime context in planning. It is persistent across multiple frames...
Definition: atomic_hash_map.h:25
void set_element_weight_kappa(const double weight_kappa)
bool eval_jac_g(int n, const double *x, bool new_x, int m, int nele_jac, int *iRow, int *jCol, double *values) override
Planning module main class. It processes GPS and IMU as input, to generate planning info...
void set_element_weight_curve_length(const double weight_curve_length)
static constexpr size_t N
Definition: spiral_problem_interface.h:114
void set_end_point_position(const double x, const double y)
void set_default_max_point_deviation(const double point_max_deviation)
bool get_bounds_info(int n, double *x_l, double *x_u, int m, double *g_l, double *g_u) override
void set_element_weight_dkappa(const double weight_dkappa)
bool eval_g(int n, const double *x, bool new_x, int m, double *g) override
void set_end_point(const double x, const double y, const double theta, const double kappa, const double dkappa)
Definition: spiral_problem_interface.h:37
bool get_nlp_info(int &n, int &m, int &nnz_jac_g, int &nnz_h_lag, IndexStyleEnum &index_style) override
virtual ~SpiralProblemInterface()=default
bool eval_grad_f(int n, const double *x, bool new_x, double *grad_f) override
bool eval_h(int n, const double *x, bool new_x, double obj_factor, int m, const double *lambda, bool new_lambda, int nele_hess, int *iRow, int *jCol, double *values) override
bool get_starting_point(int n, bool init_x, double *x, bool init_z, double *z_L, double *z_U, int m, bool init_lambda, double *lambda) override