ipopt_interface_meta.cpp
1 /*
2  * This file is part of CasADi.
3  *
4  * CasADi -- A symbolic framework for dynamic optimization.
5  * Copyright (C) 2010-2023 Joel Andersson, Joris Gillis, Moritz Diehl,
6  * KU Leuven. All rights reserved.
7  * Copyright (C) 2011-2014 Greg Horn
8  *
9  * CasADi is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU Lesser General Public
11  * License as published by the Free Software Foundation; either
12  * version 3 of the License, or (at your option) any later version.
13  *
14  * CasADi is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17  * Lesser General Public License for more details.
18  *
19  * You should have received a copy of the GNU Lesser General Public
20  * License along with CasADi; if not, write to the Free Software
21  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22  *
23  */
24 
25 
26  #include "ipopt_interface.hpp"
27  #include <string>
28 
29  const std::string casadi::IpoptInterface::meta_doc=
30  "\n"
31 "\n"
32 "\n"
33 "When in warmstart mode, output NLPSOL_LAM_X may be used as input\n"
34 "\n"
35 "NOTE: Even when max_iter == 0, it is not guaranteed that \n"
36 "input(NLPSOL_X0) == output(NLPSOL_X). Indeed if bounds on X or \n"
37 "constraints are unmet, they will differ.\n"
38 "\n"
39 "For a good tutorial on IPOPT, see https://drops.dagstuhl.de/storage/16dagstuhl-seminar-proceedings/dsp-\n"
40 "vol09061/DagSemProc.09061.16/DagSemProc.09061.16.pdf \n"
41 "\n"
42 "A good resource about the algorithms in IPOPT is: Wachter and L. T. \n"
43 "Biegler, On the Implementation of an Interior-Point Filter Line-Search\n"
44 " Algorithm for Large-Scale Nonlinear Programming, Mathematical \n"
45 "Programming 106(1), pp. 25-57, 2006 (As Research Report RC 23149, IBM \n"
46 "T. J. Watson Research Center, Yorktown, USA\n"
47 "\n"
48 "Caveats:\n"
49 "with default options, multipliers for the decision variables are wrong\n"
50 " for equality constraints. Change the 'fixed_variable_treatment' to \n"
51 "'make_constraint' or 'relax_bounds' to obtain correct results.\n"
52 "\n"
53 "Extra doc: https://github.com/casadi/casadi/wiki/L_21y \n"
54 "\n"
55 "\n"
56 "\n"
57 ">List of available options\n"
58 "\n"
59 "+--------------------------+-------------+---------------------------------+\n"
60 "| Id | Type | Description |\n"
61 "+==========================+=============+=================================+\n"
62 "| clip_inactive_lam | OT_BOOL | Explicitly set Lagrange |\n"
63 "| | | multipliers to 0 when bound is |\n"
64 "| | | deemed inactive (default: |\n"
65 "| | | false). |\n"
66 "+--------------------------+-------------+---------------------------------+\n"
67 "| con_integer_md | OT_DICT | Integer metadata (a dictionary |\n"
68 "| | | with lists of integers) about |\n"
69 "| | | constraints to be passed to |\n"
70 "| | | IPOPT |\n"
71 "+--------------------------+-------------+---------------------------------+\n"
72 "| con_numeric_md | OT_DICT | Numeric metadata (a dictionary |\n"
73 "| | | with lists of reals) about |\n"
74 "| | | constraints to be passed to |\n"
75 "| | | IPOPT |\n"
76 "+--------------------------+-------------+---------------------------------+\n"
77 "| con_string_md | OT_DICT | String metadata (a dictionary |\n"
78 "| | | with lists of strings) about |\n"
79 "| | | constraints to be passed to |\n"
80 "| | | IPOPT |\n"
81 "+--------------------------+-------------+---------------------------------+\n"
82 "| convexify_margin | OT_DOUBLE | When using a convexification |\n"
83 "| | | strategy, make sure that the |\n"
84 "| | | smallest eigenvalue is at least |\n"
85 "| | | this (default: 1e-7). |\n"
86 "+--------------------------+-------------+---------------------------------+\n"
87 "| convexify_strategy | OT_STRING | NONE|regularize|eigen- |\n"
88 "| | | reflect|eigen-clip. Strategy to |\n"
89 "| | | convexify the Lagrange Hessian |\n"
90 "| | | before passing it to the |\n"
91 "| | | solver. |\n"
92 "+--------------------------+-------------+---------------------------------+\n"
93 "| grad_f | OT_FUNCTION | Function for calculating the |\n"
94 "| | | gradient of the objective |\n"
95 "| | | (column, autogenerated by |\n"
96 "| | | default) |\n"
97 "+--------------------------+-------------+---------------------------------+\n"
98 "| hess_lag | OT_FUNCTION | Function for calculating the |\n"
99 "| | | Hessian of the Lagrangian |\n"
100 "| | | (autogenerated by default) |\n"
101 "+--------------------------+-------------+---------------------------------+\n"
102 "| inactive_lam_strategy | OT_STRING | Strategy to detect if a bound |\n"
103 "| | | is inactive. RELTOL: use |\n"
104 "| | | solver-defined constraint |\n"
105 "| | | tolerance * |\n"
106 "| | | inactive_lam_value|abstol: use |\n"
107 "| | | inactive_lam_value |\n"
108 "+--------------------------+-------------+---------------------------------+\n"
109 "| inactive_lam_value | OT_DOUBLE | Value used in |\n"
110 "| | | inactive_lam_strategy (default: |\n"
111 "| | | 10). |\n"
112 "+--------------------------+-------------+---------------------------------+\n"
113 "| ipopt | OT_DICT | Options to be passed to IPOPT |\n"
114 "+--------------------------+-------------+---------------------------------+\n"
115 "| jac_g | OT_FUNCTION | Function for calculating the |\n"
116 "| | | Jacobian of the constraints |\n"
117 "| | | (autogenerated by default) |\n"
118 "+--------------------------+-------------+---------------------------------+\n"
119 "| max_iter_eig | OT_DOUBLE | Maximum number of iterations to |\n"
120 "| | | compute an eigenvalue |\n"
121 "| | | decomposition (default: 50). |\n"
122 "+--------------------------+-------------+---------------------------------+\n"
123 "| pass_nonlinear_variables | OT_BOOL | Pass list of variables entering |\n"
124 "| | | nonlinearly to IPOPT |\n"
125 "+--------------------------+-------------+---------------------------------+\n"
126 "| var_integer_md | OT_DICT | Integer metadata (a dictionary |\n"
127 "| | | with lists of integers) about |\n"
128 "| | | variables to be passed to IPOPT |\n"
129 "+--------------------------+-------------+---------------------------------+\n"
130 "| var_numeric_md | OT_DICT | Numeric metadata (a dictionary |\n"
131 "| | | with lists of reals) about |\n"
132 "| | | variables to be passed to IPOPT |\n"
133 "+--------------------------+-------------+---------------------------------+\n"
134 "| var_string_md | OT_DICT | String metadata (a dictionary |\n"
135 "| | | with lists of strings) about |\n"
136 "| | | variables to be passed to IPOPT |\n"
137 "+--------------------------+-------------+---------------------------------+\n"
138 "\n"
139 "\n"
140 "\n"
141 "\n"
142 ;
static const std::string meta_doc
A documentation string.