chiark / gitweb /
recommend building in a subdir
[nlopt.git] / cdirect / cdirect.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 CDIRECT_H
24 #define CDIRECT_H
25
26 #include "nlopt-util.h"
27 #include "nlopt.h"
28
29 #ifdef __cplusplus
30 extern "C"
31 {
32 #endif /* __cplusplus */
33
34 extern nlopt_result cdirect_unscaled(int n, nlopt_func f, void *f_data,
35                                      const double *lb, const double *ub,
36                                      double *x,
37                                      double *minf,
38                                      nlopt_stopping *stop,
39                                      double magic_eps, int which_alg);
40
41 extern nlopt_result cdirect(int n, nlopt_func f, void *f_data,
42                             const double *lb, const double *ub,
43                             double *x,
44                             double *minf,
45                             nlopt_stopping *stop,
46                             double magic_eps, int which_alg);
47
48 extern nlopt_result cdirect_hybrid(int n, nlopt_func f, void *f_data,
49                             const double *lb, const double *ub,
50                             double *x,
51                             double *minf,
52                             nlopt_stopping *stop,
53                             nlopt_algorithm local_alg,
54                             int local_maxeval,
55                             int randomized_div);
56
57 extern nlopt_result cdirect_hybrid_unscaled(int n, nlopt_func f, void *f_data,
58                             const double *lb, const double *ub,
59                             double *x,
60                             double *minf,
61                             nlopt_stopping *stop,
62                             nlopt_algorithm local_alg,
63                             int local_maxeval,
64                             int randomized_div);
65
66 /* internal routines and data structures: */
67 extern int cdirect_hyperrect_compare(double *a, double *b);
68 typedef struct {
69      nlopt_func f;
70      void *f_data;
71      double *x;
72      const double *lb, *ub;
73 } cdirect_uf_data;
74 extern double cdirect_uf(unsigned n, const double *xu, double *grad, void *d_);
75
76 #ifdef __cplusplus
77 }  /* extern "C" */
78 #endif /* __cplusplus */
79
80 #endif /* DIRECT_H */