chiark / gitweb /
added CCSAQ algorithm; internal support for preconditioners (untested) not yet export...
[nlopt.git] / mma / mma.h
1 /* Copyright (c) 2007-2011 Massachusetts Institute of Technology
2  *
3  * Permission is hereby granted, free of charge, to any person obtaining
4  * a copy of this software and associated documentation files (the
5  * "Software"), to deal in the Software without restriction, including
6  * without limitation the rights to use, copy, modify, merge, publish,
7  * distribute, sublicense, and/or sell copies of the Software, and to
8  * permit persons to whom the Software is furnished to do so, subject to
9  * the following conditions:
10  * 
11  * The above copyright notice and this permission notice shall be
12  * included in all copies or substantial portions of the Software.
13  * 
14  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18  * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19  * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20  * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 
21  */
22
23 #ifndef MMA_H
24 #define MMA_H
25
26 #include "nlopt.h"
27 #include "nlopt-util.h"
28
29 #ifdef __cplusplus
30 extern "C"
31 {
32 #endif /* __cplusplus */
33
34 extern unsigned mma_verbose;
35
36 nlopt_result mma_minimize(unsigned n, nlopt_func f, void *f_data,
37                           unsigned m, nlopt_constraint *fc,
38                           const double *lb, const double *ub, /* bounds */
39                           double *x, /* in: initial guess, out: minimizer */
40                           double *minf,
41                           nlopt_stopping *stop,
42                           nlopt_opt dual_opt);
43
44 nlopt_result ccsa_quadratic_minimize(
45      unsigned n, nlopt_func f, void *f_data,
46      unsigned m, nlopt_constraint *fc,
47
48      nlopt_precond pre, void *pre_data, /* for f */
49      nlopt_precond *prec, void **prec_data, /* length = # constraints */
50
51      const double *lb, const double *ub, /* bounds */
52      double *x, /* in: initial guess, out: minimizer */
53      double *minf,
54      nlopt_stopping *stop,
55      nlopt_opt dual_opt);
56
57 #ifdef __cplusplus
58 }  /* extern "C" */
59 #endif /* __cplusplus */
60
61 #endif
62