File: direct-internal.h

package info (click to toggle)
mldemos 0.5.1-3
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 32,224 kB
  • ctags: 46,525
  • sloc: cpp: 306,887; ansic: 167,718; ml: 126; sh: 109; makefile: 2
file content (122 lines) | stat: -rw-r--r-- 5,516 bytes parent folder | download | duplicates (11)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
#ifndef DIRECT_INTERNAL_H
#define DIRECT_INTERNAL_H

#include <stdio.h>
#include <stdlib.h>
#include <math.h>

#include "direct.h"
#include "nlopt-util.h"

#ifdef __cplusplus
extern "C"
{
#endif /* __cplusplus */

typedef int integer;
typedef double doublereal;
typedef direct_objective_func fp;

#define ASRT(c) if (!(c)) { fprintf(stderr, "DIRECT assertion failure at " __FILE__ ":%d -- " #c "\n", __LINE__); exit(EXIT_FAILURE); }

#define MIN(a,b) ((a) < (b) ? (a) : (b))
#define MAX(a,b) ((a) > (b) ? (a) : (b))

/* DIRsubrout.c */

extern void direct_dirheader_(
     FILE *logfile, integer *version,
     doublereal *x, integer *n, doublereal *eps, integer *maxf, integer *
     maxt, doublereal *l, doublereal *u, integer *algmethod, integer *
     maxfunc, const integer *maxdeep, doublereal *fglobal, doublereal *fglper,
     integer *ierror, doublereal *epsfix, integer *iepschange, doublereal *
     volper, doublereal *sigmaper);
extern void direct_dirinit_(
     doublereal *f, fp fcn, doublereal *c__,
     integer *length, integer *actdeep, integer *point, integer *anchor,
     integer *free, FILE *logfile, integer *arrayi,
     integer *maxi, integer *list2, doublereal *w, doublereal *x,
     doublereal *l, doublereal *u, doublereal *minf, integer *minpos,
     doublereal *thirds, doublereal *levels, integer *maxfunc, const integer *
     maxdeep, integer *n, integer *maxor, doublereal *fmax, integer *
     ifeasiblef, integer *iinfeasible, integer *ierror, void *fcndata,
     integer jones, double starttime, double maxtime, int *force_stop);
extern void direct_dirinitlist_(
     integer *anchor, integer *free, integer *
     point, doublereal *f, integer *maxfunc, const integer *maxdeep);
extern void direct_dirpreprc_(doublereal *u, doublereal *l, integer *n, 
			      doublereal *xs1, doublereal *xs2, integer *oops);
extern void direct_dirchoose_(
     integer *anchor, integer *s, integer *actdeep,
     doublereal *f, doublereal *minf, doublereal epsrel, doublereal epsabs, doublereal *thirds,
     integer *maxpos, integer *length, integer *maxfunc, const integer *maxdeep,
     const integer *maxdiv, integer *n, FILE *logfile,
     integer *cheat, doublereal *kmax, integer *ifeasiblef, integer jones);
extern void direct_dirdoubleinsert_(
     integer *anchor, integer *s, integer *maxpos, integer *point, 
     doublereal *f, const integer *maxdeep, integer *maxfunc, 
     const integer *maxdiv, integer *ierror);
extern integer direct_dirgetmaxdeep_(integer *pos, integer *length, integer *maxfunc,
			      integer *n);
extern void direct_dirget_i__(
     integer *length, integer *pos, integer *arrayi, integer *maxi, 
     integer *n, integer *maxfunc);
extern void direct_dirsamplepoints_(
     doublereal *c__, integer *arrayi, 
     doublereal *delta, integer *sample, integer *start, integer *length, 
     FILE *logfile, doublereal *f, integer *free, 
     integer *maxi, integer *point, doublereal *x, doublereal *l,
     doublereal *minf, integer *minpos, doublereal *u, integer *n, 
     integer *maxfunc, const integer *maxdeep, integer *oops);
extern void direct_dirdivide_(
     integer *new__, integer *currentlength, 
     integer *length, integer *point, integer *arrayi, integer *sample, 
     integer *list2, doublereal *w, integer *maxi, doublereal *f, 
     integer *maxfunc, const integer *maxdeep, integer *n);
extern void direct_dirinsertlist_(
     integer *new__, integer *anchor, integer *point, doublereal *f, 
     integer *maxi, integer *length, integer *maxfunc, 
     const integer *maxdeep, integer *n, integer *samp, integer jones);
extern void direct_dirreplaceinf_(
     integer *free, integer *freeold, 
     doublereal *f, doublereal *c__, doublereal *thirds, integer *length, 
     integer *anchor, integer *point, doublereal *c1, doublereal *c2, 
     integer *maxfunc, const integer *maxdeep, integer *maxdim, integer *n, 
     FILE *logfile, doublereal *fmax, integer jones);
extern void direct_dirsummary_(
     FILE *logfile, doublereal *x, doublereal *l, doublereal *u, 
     integer *n, doublereal *minf, doublereal *fglobal, 
     integer *numfunc, integer *ierror);
extern integer direct_dirgetlevel_(
     integer *pos, integer *length, 
     integer *maxfunc, integer *n, integer jones);
extern void direct_dirinfcn_(
     fp fcn, doublereal *x, doublereal *c1, 
     doublereal *c2, integer *n, doublereal *f, integer *flag__, 
     void *fcn_data);

/* DIRserial.c / DIRparallel.c */
extern void direct_dirsamplef_(
     doublereal *c__, integer *arrayi, doublereal 
     *delta, integer *sample, integer *new__, integer *length, 
     FILE *logfile, doublereal *f, integer *free, integer *maxi, 
     integer *point, fp fcn, doublereal *x, doublereal *l, doublereal *
     minf, integer *minpos, doublereal *u, integer *n, integer *maxfunc, 
     const integer *maxdeep, integer *oops, doublereal *fmax, integer *
     ifeasiblef, integer *iinfesiblef, void *fcn_data, int *force_stop);

/* DIRect.c */
extern void direct_direct_(
     fp fcn, doublereal *x, integer *n, doublereal *eps, doublereal epsabs,
     integer *maxf, integer *maxt, 
     double starttime, double maxtime, 
     int *force_stop, doublereal *minf, doublereal *l, 
     doublereal *u, integer *algmethod, integer *ierror, FILE *logfile, 
     doublereal *fglobal, doublereal *fglper, doublereal *volper, 
     doublereal *sigmaper, void *fcn_data);

#ifdef __cplusplus
}  /* extern "C" */
#endif /* __cplusplus */

#endif /* DIRECT_INTERNAL_H */