chiark / gitweb /
recommend building in a subdir
[nlopt.git] / mma / mma.h
1 /* Copyright (c) 2007-2014 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,
49
50      const double *lb, const double *ub, /* bounds */
51      double *x, /* in: initial guess, out: minimizer */
52      double *minf,
53      nlopt_stopping *stop,
54      nlopt_opt dual_opt);
55
56 #ifdef __cplusplus
57 }  /* extern "C" */
58 #endif /* __cplusplus */
59
60 #endif
61