34 void casadi_fatrop_mproject(T1 factor,
const T1* x,
const casadi_int* sp_x,
35 T1* y,
const casadi_int* sp_y, T1* w) {
37 const casadi_int* colind_y;
40 casadi_project(x, sp_x, y, sp_y, w);
41 casadi_scal(colind_y[ncol_y], factor, y);
46 void casadi_fatrop_dense_transfer(
double factor,
const T1* x,
47 const casadi_int* sp_x, T1* y,
48 const casadi_int* sp_y, T1* w) {
49 casadi_sparsify(x, w, sp_x, 0);
50 casadi_int nrow_y = sp_y[0];
51 casadi_int ncol_y = sp_y[1];
52 const casadi_int *colind_y = sp_y+2, *row_y = sp_y + 2 + ncol_y+1;
55 for (i=0; i<ncol_y; ++i) {
56 for (el=colind_y[i]; el<colind_y[i+1]; ++el) y[nrow_y*i + row_y[el]] += factor*(*w++);
62 void casadi_fatrop_read_primal_data(
const double* primal_data, T1* x,
const struct FatropOcpCDims *s) {
64 for (k=0;k<s->K;++k) {
65 casadi_copy(primal_data+s->ux_offs[k], s->nu[k], x+s->nx[k]+s->ux_offs[k]);
66 casadi_copy(primal_data+s->ux_offs[k]+s->nu[k], s->nx[k], x+s->ux_offs[k]);
72 void casadi_fatrop_write_primal_data(
const double* x, T1* primal_data,
const struct FatropOcpCDims *s) {
74 for (k=0;k<s->K;++k) {
75 casadi_copy(x+s->nx[k]+s->ux_offs[k], s->nu[k], primal_data+s->ux_offs[k]);
76 casadi_copy(x+s->ux_offs[k], s->nx[k], primal_data+s->ux_offs[k]+s->nu[k]);
119 template<
typename T1>
130 for (k=0;k<p->
N+1;++k) {
135 for (k=0;k<p->
N;++k) {
144 template<
typename T1>
167 struct blasfeo_dvec v,
r;
168 struct blasfeo_dmat
R;
172 struct FatropOcpCStats
stats;
179 template<
typename T1>
185 template<
typename T1>
196 template<
typename T1>
197 fatrop_int casadi_fatrop_full_eval_constr_jac(
const double* primal_data,
const double* stageparams_p,
const double* globalparams_p,
198 struct blasfeo_dmat* BAbt_p,
struct blasfeo_dmat* Ggt_p,
struct blasfeo_dmat* Ggt_ineq_p,
const struct FatropOcpCDims* s,
void* user_data) {
205 casadi_fatrop_read_primal_data(primal_data, d->
x, s);
206 d_oracle->
arg[0] = d->
x;
207 d_oracle->
arg[1] = d_nlp->
p;
208 d_oracle->
res[0] = d->
g;
209 d_oracle->
res[1] = d->
a;
210 calc_function(&d->
prob->nlp_jac_g, d_oracle);
212 casadi_fatrop_mproject(-1.0, d->
a, p->sp_a, d->
AB, p->ABsp, d->
pv);
213 casadi_project(d->
a, p->sp_a, d->
CD, p->CDsp, d->
pv);
214 casadi_project(d->
a, p->sp_a, d->
I, p->Isp, d->
pv);
216 for (i=0;i<p->Isp[2+p->Isp[1]];++i) {
218 casadi_error(
"Structure mismatch: gap-closing constraints must be like this: x_{k+1}-F(xk,uk).");
225 template<
typename T1>
226 fatrop_int casadi_fatrop_full_eval_contr_viol(
const double* primal_data,
const double* stageparams_p,
const double* globalparams_p,
227 double* res,
const struct FatropOcpCDims* s,
void* user_data) {
228 casadi_int i,k,column;
234 casadi_fatrop_read_primal_data(primal_data, d->
x, s);
235 d_oracle->
arg[0] = d->
x;
236 d_oracle->
arg[1] = d_nlp->
p;
237 d_oracle->
res[0] = d->
g;
238 calc_function(&d->
prob->nlp_g, d_oracle);
240 for (k=0;k<s->K;++k) {
242 for (i=d->
a_ineq_idx[k];i<d->a_ineq_idx[k+1];++i) {
243 res[s->g_ineq_offs[k]+column] = d->
g[d->
a_ineq[i]];
246 for (i=d->
x_ineq_idx[k];i<d->x_ineq_idx[k+1];++i) {
247 res[s->g_ineq_offs[k]+column] = d->
x[d->
x_ineq[i]];
251 for (i=d->
a_eq_idx[k];i<d->a_eq_idx[k+1];++i) {
252 res[s->g_offs[k]+column] = d->
g[d->
a_eq[i]]-d->
nlp->lbz[p->
nlp->nx+d->
a_eq[i]];
255 for (i=d->
x_eq_idx[k];i<d->x_eq_idx[k+1];++i) {
256 res[s->g_offs[k]+column] = d->
x[d->
x_eq[i]]-d->
nlp->lbz[d->
x_eq[i]];
260 for (k=0;k<s->K-1;++k) {
261 const T1* lbg_k = d_nlp->
lbz+p->
nlp->nx+p->
AB[k].offset_r;
262 const T1* g_k = d->
g+p->
AB[k].offset_r;
263 casadi_copy(lbg_k, p->nx[k+1], res+s->dyn_eq_offs[k]);
264 casadi_axpy(p->nx[k+1], -1.0, g_k, res+s->dyn_eq_offs[k]);
270 template<
typename T1>
271 fatrop_int casadi_fatrop_full_eval_obj_grad(
272 double objective_scale,
273 const double *primal_data,
274 const double *stage_params_k,
275 const double *global_params,
276 double *res,
const struct FatropOcpCDims* s,
void* user_data) {
282 casadi_fatrop_read_primal_data(primal_data, d->
x, s);
283 d_oracle->
arg[0] = d->
x;
284 d_oracle->
arg[1] = d_nlp->
p;
285 d_oracle->
res[0] = d->
g;
286 calc_function(&d->
prob->nlp_grad_f, d_oracle);
288 casadi_fatrop_write_primal_data(d->
g, res, s);
289 casadi_scal(p->
nlp->nx, objective_scale, res);
294 template<
typename T1>
295 fatrop_int casadi_fatrop_full_eval_obj(
296 double objective_scale,
297 const double *primal_data,
298 const double *stage_params_k,
299 const double *global_params,
300 double *res,
const struct FatropOcpCDims* s,
void* user_data) {
305 casadi_fatrop_read_primal_data(primal_data, d->
x, s);
306 d_oracle->
arg[0] = d->
x;
307 d_oracle->
arg[1] = d_nlp->p;
308 d_oracle->
res[0] = res;
309 calc_function(&d->
prob->nlp_f, d_oracle);
311 *res *= objective_scale;
316 template<
typename T1>
317 fatrop_int casadi_fatrop_full_eval_lag_hess(
318 double objective_scale,
319 const double *primal_data,
320 const double *lam_data,
321 const double *stage_params_k,
322 const double *global_params,
323 struct blasfeo_dmat *res,
const struct FatropOcpCDims* s,
void* user_data) {
324 casadi_int k, column, i;
330 casadi_fatrop_read_primal_data(primal_data, d->
x, s);
331 for (k=0;k<s->K;++k) {
333 for (i=d->
a_ineq_idx[k];i<d->a_ineq_idx[k+1];++i) {
334 d->
lam[d->
a_ineq[i]] = lam_data[s->g_ineq_offs[k]+column];
338 for (i=d->
a_eq_idx[k];i<d->a_eq_idx[k+1];++i) {
339 d->
lam[d->
a_eq[i]] = lam_data[s->g_offs[k]+column];
343 for (k=0;k<s->K-1;++k) {
344 casadi_scaled_copy(-1.0, lam_data+s->dyn_eq_offs[k], p->nx[k+1], d->
lam+p->
AB[k].offset_r);
347 d_oracle->
arg[0] = d->
x;
348 d_oracle->
arg[1] = d_nlp->
p;
349 d_oracle->
arg[2] = &objective_scale;
350 d_oracle->
arg[3] = d->
lam;
351 d_oracle->
res[0] = d->
g;
352 d_oracle->
res[1] = d->
h;
353 calc_function(&d->
prob->nlp_hess_l, d_oracle);
355 casadi_project(d->
h, p->sp_h, d->
RSQ, p->RSQsp, d->
pv);
358 for (k=0;k<s->K-1;++k) {
359 casadi_axpy(p->nx[k+1], 1.0, lam_data+s->dyn_eq_offs[k], d->
g+p->
CD[k+1].offset_c);
362 for (k=0;k<s->K;++k) {
364 for (i=d->
x_ineq_idx[k];i<d->x_ineq_idx[k+1];++i) {
365 d->
g[d->
x_ineq[i]] += lam_data[s->g_ineq_offs[k]+column];
369 for (i=d->
x_eq_idx[k];i<d->x_eq_idx[k+1];++i) {
370 d->
g[d->
x_eq[i]] += lam_data[s->g_offs[k]+column];
381 template<
typename T1>
382 fatrop_int casadi_fatrop_eval_BAbt(
const double *states_kp1,
const double *inputs_k,
383 const double *states_k,
const double *stage_params_k,
384 const double *global_params,
struct blasfeo_dmat *res,
const fatrop_int k,
void* user_data) {
388 const T1* lbg_k = d_nlp->
lbz+p->
nlp->nx+p->
AB[k].offset_r;
389 const T1* g_k = d->
g+p->
AB[k].offset_r;
391 blasfeo_pack_tran_dmat(p->nx[k+1], p->nx[k], d->
AB+p->AB_offsets[k], p->nx[k+1], res, p->nu[k], 0);
392 blasfeo_pack_tran_dmat(p->nx[k+1], p->nu[k], d->
AB+p->AB_offsets[k]+p->nx[k]*p->nx[k+1], p->nx[k+1], res, 0, 0);
394 for (i=0; i<p->nx[k+1]; ++i) {
395 BLASFEO_DMATEL(res, p->nx[k]+p->nu[k], i) = lbg_k[i]-g_k[i];
403 template<
typename T1>
404 fatrop_int casadi_fatrop_eval_RSQrqt(
405 const double *objective_scale,
406 const double *inputs_k,
407 const double *states_k,
408 const double *lam_dyn_k,
409 const double *lam_eq_k,
410 const double *lam_eq_ineq_k,
411 const double *stage_params_k,
412 const double *global_params,
413 struct blasfeo_dmat *res,
414 const fatrop_int k,
void* user_data) {
418 int n = p->nx[k]+p->nu[k];
419 blasfeo_pack_dmat(p->nx[k], p->nx[k],
420 d->
RSQ+p->RSQ_offsets[k], n, res, p->nu[k], p->nu[k]);
421 blasfeo_pack_dmat(p->nu[k], p->nu[k],
422 d->
RSQ+p->RSQ_offsets[k]+p->nx[k]*n+p->nx[k], n, res, 0, 0);
423 blasfeo_pack_dmat(p->nu[k], p->nx[k],
424 d->
RSQ+p->RSQ_offsets[k]+p->nx[k], n, res, 0, p->nu[k]);
425 blasfeo_pack_dmat(p->nx[k], p->nu[k],
426 d->
RSQ+p->RSQ_offsets[k]+p->nx[k]*n, n, res, p->nu[k], 0);
429 blasfeo_pack_dmat(1, p->nx[k], d->
g+p->
CD[k].offset_c, 1, res, p->nx[k]+p->nu[k], p->nu[k]);
430 blasfeo_pack_dmat(1, p->nu[k], d->
g+p->
CD[k].offset_c+p->nx[k], 1, res, p->nx[k]+p->nu[k], 0);
437 template<
typename T1>
438 fatrop_int casadi_fatrop_eval_Ggt(
439 const double *inputs_k,
440 const double *states_k,
441 const double *stage_params_k,
442 const double *global_params,
443 struct blasfeo_dmat *res,
444 const fatrop_int k,
void* user_data) {
447 casadi_int i, column;
451 int ng_eq = n_a_eq+n_x_eq;
453 blasfeo_dgese(p->nx[k]+p->nu[k]+1, ng_eq, 0.0, res, 0, 0);
456 for (i=d->
a_eq_idx[k];i<d->a_eq_idx[k+1];++i) {
457 blasfeo_pack_tran_dmat(1, p->nx[k],
458 d->
CD+p->CD_offsets[k]+(d->
a_eq[i]-p->
CD[k].offset_r),
459 p->
CD[k].rows, res, p->nu[k], column);
460 blasfeo_pack_tran_dmat(1, p->nu[k],
461 d->
CD+p->CD_offsets[k]+(d->
a_eq[i]-p->
CD[k].offset_r)+p->nx[k]*p->
CD[k].rows,
462 p->
CD[k].rows, res, 0, column);
463 BLASFEO_DMATEL(res, p->nx[k]+p->nu[k], column) = d->
g[d->
a_eq[i]]-d->
nlp->lbz[p->
nlp->nx+d->
a_eq[i]];
466 for (i=d->
x_eq_idx[k];i<d->x_eq_idx[k+1];++i) {
467 int j = d->
x_eq[i]-p->
CD[k].offset_c;
473 BLASFEO_DMATEL(res, j, column) = 1;
474 BLASFEO_DMATEL(res, p->nx[k]+p->nu[k], column) = d->
x[d->
x_eq[i]]-d->
nlp->lbz[d->
x_eq[i]];
482 template<
typename T1>
483 fatrop_int casadi_fatrop_eval_Ggt_ineq(
484 const double *inputs_k,
485 const double *states_k,
486 const double *stage_params_k,
487 const double *global_params,
488 struct blasfeo_dmat *res,
489 const fatrop_int k,
void* user_data) {
492 casadi_int i, column;
496 int ng_ineq = n_a_ineq+n_x_ineq;
503 blasfeo_dgese(p->nx[k]+p->nu[k]+1, ng_ineq, 0.0, res, 0, 0);
506 for (i=d->
a_ineq_idx[k];i<d->a_ineq_idx[k+1];++i) {
507 blasfeo_pack_tran_dmat(1, p->nx[k],
508 d->
CD+p->CD_offsets[k]+(d->
a_ineq[i]-p->
CD[k].offset_r),
509 p->
CD[k].rows, res, p->nu[k], column);
510 blasfeo_pack_tran_dmat(1, p->nu[k],
511 d->
CD+p->CD_offsets[k]+(d->
a_ineq[i]-p->
CD[k].offset_r)+p->nx[k]*p->
CD[k].rows,
512 p->
CD[k].rows, res, 0, column);
513 BLASFEO_DMATEL(res, p->nx[k]+p->nu[k], column) = d->
g[d->
a_ineq[i]];
516 for (i=d->
x_ineq_idx[k];i<d->x_ineq_idx[k+1];++i) {
517 int j = d->
x_ineq[i]-p->
CD[k].offset_c;
523 BLASFEO_DMATEL(res, j, column) = 1;
524 BLASFEO_DMATEL(res, p->nx[k]+p->nu[k], column) = d->
x[d->
x_ineq[i]];
532 template<
typename T1>
533 fatrop_int casadi_fatrop_get_nx(
const fatrop_int k,
void* user_data) {
539 if (k==p->N+1)
return p->nx[k-1];
544 template<
typename T1>
545 fatrop_int casadi_fatrop_get_nu(
const fatrop_int k,
void* user_data) {
552 template<
typename T1>
553 fatrop_int casadi_fatrop_get_ng(
const fatrop_int k,
void* user_data) {
573 template<
typename T1>
574 fatrop_int casadi_fatrop_get_horizon_length(
void* user_data) {
582 template<
typename T1>
583 fatrop_int casadi_fatrop_get_ng_ineq(
const fatrop_int k,
void* user_data) {
588 return n_a_ineq+n_x_ineq;
592 template<
typename T1>
593 fatrop_int casadi_fatrop_get_bounds(
double *lower,
double *upper,
const fatrop_int k,
void* user_data) {
598 casadi_int nx = p->
nlp->nx;
602 for (i=d->
a_ineq_idx[k];i<d->a_ineq_idx[k+1];++i) {
603 lower[column] = d_nlp->
lbz[nx+d->
a_ineq[i]];
604 upper[column] = d_nlp->
ubz[nx+d->
a_ineq[i]];
608 for (i=d->
x_ineq_idx[k];i<d->x_ineq_idx[k+1];++i) {
609 lower[column] = d_nlp->
lbz[d->
x_ineq[i]];
610 upper[column] = d_nlp->
ubz[d->
x_ineq[i]];
618 template<
typename T1>
619 fatrop_int casadi_fatrop_get_initial_xk(
double *xk,
const fatrop_int k,
void* user_data) {
624 casadi_copy(d_nlp->
z+p->
CD[k].offset_c, p->nx[k], xk);
630 template<
typename T1>
631 fatrop_int casadi_fatrop_get_initial_uk(
double *uk,
const fatrop_int k,
void* user_data) {
635 casadi_copy(d_nlp->
z+p->
CD[k].offset_c+p->nx[k], p->nu[k], uk);
641 template<
typename T1>
642 void casadi_fatrop_work(
const casadi_fatrop_prob<T1>* p, casadi_int* sz_arg, casadi_int* sz_res, casadi_int* sz_iw, casadi_int* sz_w) {
643 casadi_nlpsol_work(p->
nlp, sz_arg, sz_res, sz_iw, sz_w);
646 *sz_w = casadi_max(*sz_w, 2*(p->
nlp->nx+p->
nlp->ng));
649 *sz_w += casadi_sp_nnz(p->
ABsp);
650 *sz_w += casadi_sp_nnz(p->
CDsp);
651 *sz_w += casadi_sp_nnz(p->
RSQsp);
652 *sz_w += casadi_sp_nnz(p->
Isp);
654 *sz_w += p->
nlp->nx+p->
nlp->ng;
655 *sz_w += casadi_sp_nnz(p->
sp_a);
656 *sz_w += casadi_sp_nnz(p->
sp_h);
657 *sz_w += casadi_max(p->
nlp->nx,p->
nlp->ng);
658 *sz_w += blasfeo_memsize_dvec(p->
nxu_max+1)+64;
659 *sz_w += blasfeo_memsize_dvec(p->
nx_max+p->
nlp->ng)+64;
666 *sz_iw += p->
nlp->ng;
667 *sz_iw += p->
nlp->ng;
668 *sz_iw += p->
nlp->nx;
669 *sz_iw += p->
nlp->nx;
674 template<
typename T1>
684 d->
AB = *w; *w += casadi_sp_nnz(p->
ABsp);
685 d->
CD = *w; *w += casadi_sp_nnz(p->
CDsp);
686 d->
RSQ = *w; *w += casadi_sp_nnz(p->
RSQsp);
687 d->
I = *w; *w += casadi_sp_nnz(p->
Isp);
688 d->
x = *w; *w += p->
nlp->nx;
689 d->
lam = *w; *w += p->
nlp->nx+p->
nlp->ng;
690 d->
a = *w; *w += casadi_sp_nnz(p->
sp_a);
691 d->
h = *w; *w += casadi_sp_nnz(p->
sp_h);
692 d->
g = *w; *w += casadi_max(p->
nlp->nx,p->
nlp->ng);
693 blasfeo_create_dvec(p->
nxu_max+1, &d->v, (
void*) (((
unsigned long long) (*w)+63)/64*64));
694 *w += blasfeo_memsize_dvec(p->
nxu_max+1)+64;
695 blasfeo_create_dvec(p->
nx_max+p->
nlp->ng, &d->
r, (
void*) (((
unsigned long long) (*w)+63)/64*64));
696 *w += blasfeo_memsize_dvec(p->
nx_max+p->
nlp->ng)+64;
697 blasfeo_create_dmat(p->
nxu_max, p->
nxu_max, &d->
R, (
void*) (((
unsigned long long) (*w)+63)/64*64));
705 d->
a_eq = *iw; *iw += p->
nlp->ng;
707 d->
x_eq = *iw; *iw += p->
nlp->nx;
740 template<
typename T1>
742 casadi_int k, i, start, stop, nx;
747 struct FatropOcpCInterface* ocp_interface = &d->
ocp_interface;
749 ocp_interface->get_nx = casadi_fatrop_get_nx<T1>;
750 ocp_interface->get_nu = casadi_fatrop_get_nu<T1>;
751 ocp_interface->get_ng = casadi_fatrop_get_ng<T1>;
752 ocp_interface->get_n_stage_params = 0;
753 ocp_interface->get_n_global_params = 0;
754 ocp_interface->get_default_stage_params = 0;
755 ocp_interface->get_default_global_params = 0;
756 ocp_interface->get_ng_ineq = casadi_fatrop_get_ng_ineq<T1>;
757 ocp_interface->get_horizon_length = casadi_fatrop_get_horizon_length<T1>;
759 ocp_interface->get_bounds = casadi_fatrop_get_bounds<T1>;
760 ocp_interface->get_initial_xk = casadi_fatrop_get_initial_xk<T1>;
761 ocp_interface->get_initial_uk = casadi_fatrop_get_initial_uk<T1>;
763 ocp_interface->full_eval_constr_jac = casadi_fatrop_full_eval_constr_jac<T1>;
764 ocp_interface->full_eval_obj_grad = casadi_fatrop_full_eval_obj_grad<T1>;
765 ocp_interface->full_eval_obj = casadi_fatrop_full_eval_obj<T1>;
766 ocp_interface->full_eval_contr_viol = casadi_fatrop_full_eval_contr_viol<T1>;
767 ocp_interface->full_eval_lag_hess = casadi_fatrop_full_eval_lag_hess<T1>;
769 ocp_interface->eval_BAbt = casadi_fatrop_eval_BAbt<T1>;
770 ocp_interface->eval_RSQrqt = casadi_fatrop_eval_RSQrqt<T1>;
771 ocp_interface->eval_Ggt = casadi_fatrop_eval_Ggt<T1>;
772 ocp_interface->eval_Ggt_ineq = casadi_fatrop_eval_Ggt_ineq<T1>;
773 ocp_interface->eval_rq = 0;
774 ocp_interface->eval_L = 0;
784 for (k=0;k<p->
N+1;++k) {
789 for (i=start;i<stop;++i) {
790 if (d_nlp->
lbz[nx+i]==d_nlp->
ubz[nx+i]) {
793 if (d_nlp->
lbz[nx+i]==-std::numeric_limits<T1>::infinity() && d_nlp->
ubz[nx+i]==std::numeric_limits<T1>::infinity())
continue;
802 for (i=start;i<stop;++i) {
803 if (d_nlp->
lbz[i]==d_nlp->
ubz[i]) {
806 if (d_nlp->
lbz[i]==-std::numeric_limits<T1>::infinity() && d_nlp->
ubz[i]==std::numeric_limits<T1>::infinity())
continue;
818 template<
typename T1>
821 casadi_int k, i, column;
829 fatrop_int ret = fatrop_ocp_c_solve(d->
solver);
841 const struct blasfeo_dvec* primal = fatrop_ocp_c_get_primal(d->
solver);
842 const struct blasfeo_dvec* dual = fatrop_ocp_c_get_dual(d->
solver);
843 const struct FatropOcpCDims* str = fatrop_ocp_c_get_dims(d->
solver);
844 const struct FatropOcpCStats* stats = fatrop_ocp_c_get_stats(d->
solver);
846 d->
stats.compute_sd_time = stats->compute_sd_time;
847 d->
stats.duinf_time = stats->duinf_time;
848 d->
stats.eval_hess_time = stats->eval_hess_time;
849 d->
stats.eval_jac_time = stats->eval_jac_time;
850 d->
stats.eval_cv_time = stats->eval_cv_time;
851 d->
stats.eval_grad_time = stats->eval_grad_time;
852 d->
stats.eval_obj_time = stats->eval_obj_time;
853 d->
stats.initialization_time = stats->initialization_time;
854 d->
stats.time_total = stats->time_total;
855 d->
stats.eval_hess_count = stats->eval_hess_count;
856 d->
stats.eval_jac_count = stats->eval_jac_count;
857 d->
stats.eval_cv_count = stats->eval_cv_count;
858 d->
stats.eval_grad_count = stats->eval_grad_count;
859 d->
stats.eval_obj_count = stats->eval_obj_count;
860 d->
stats.iterations_count = stats->iterations_count;
861 d->
stats.return_flag = stats->return_flag;
863 const double* primal_data = primal->pa;
864 const double* dual_data = dual->pa;
866 casadi_fatrop_read_primal_data(primal_data, d_nlp->
z, str);
869 for (k=0;k<str->K;++k) {
871 for (i=d->
a_ineq_idx[k];i<d->a_ineq_idx[k+1];++i) {
872 d_nlp->
lam[p_nlp->
nx+d->
a_ineq[i]] = dual_data[str->g_ineq_offs[k]+column];
875 for (i=d->
x_ineq_idx[k];i<d->x_ineq_idx[k+1];++i) {
876 d_nlp->
lam[d->
x_ineq[i]] = dual_data[str->g_ineq_offs[k]+column];
881 for (k=0;k<str->K;++k) {
883 for (i=d->
a_eq_idx[k];i<d->a_eq_idx[k+1];++i) {
884 d_nlp->
lam[p_nlp->
nx+d->
a_eq[i]] = dual_data[str->g_offs[k]+column];
887 for (i=d->
x_eq_idx[k];i<d->x_eq_idx[k+1];++i) {
888 d_nlp->
lam[d->
x_eq[i]] = dual_data[str->g_offs[k]+column];
893 for (k=0;k<str->K-1;++k) {
894 casadi_scaled_copy(-1.0, dual_data+str->dyn_eq_offs[k], p->
nx[k+1], d_nlp->
lam+p_nlp->
nx+p->
AB[k].
offset_r);
897 fatrop_ocp_c_destroy(d->
solver);
const casadi_fatrop_prob< T1 > * prob
int unified_return_status
struct FatropOcpCStats stats
struct FatropOcpCInterface ocp_interface
casadi_nlpsol_data< T1 > * nlp
struct FatropOcpCSolver * solver
OracleCallback nlp_grad_f
const casadi_int * I_offsets
OracleCallback nlp_hess_l
const casadi_int * RSQ_offsets
const casadi_int * CD_offsets
const casadi_nlpsol_prob< T1 > * nlp
const casadi_int * AB_offsets
casadi_oracle_data< T1 > * oracle