Class min_cern (o2scl)¶
-
template<class func_t = funct>
class min_cern : public o2scl::min_bkt_base<funct>¶ One-dimensional minimization (CERNLIB)
The golden section search is applied in the interval
using a fixed number of function evaluations whereThe accuracy depends on the function. A choice of
usually results in a relative error of $x$ which is smaller than or of the order of .This routine strictly searches the interval
. If the function is nowhere flat in this interval, then min_bkt() will return either or and min_type is set to 1. Note that if there are more than 1 local minima in the specified interval, there is no guarantee that this method will find the global minimum.Based on the CERNLIB routines RMINFC and DMINFC, which was based on [Fletcher87], and [Krabs83] and is documented at http://wwwasdoc.web.cern.ch/wwwasdoc/shortwrupsdir/d503/top.html
Note
The number of function evaluations can be quite large if mmin::tol_abs is sufficiently small. If mmin::tol_abs is exactly zero, then the error handler will be called.
Public Functions
-
inline min_cern()¶
-
inline virtual int min_bkt(double &x, double a, double b, double &y, func_t &func)¶
Calculate the minimum
min
offunc
betweena
andb
.The initial value of
x
is ignored.If there is no minimum in the given interval, then on exit
x
will be equal to eithera
orb
and min_type will be set to 1 instead of zero. The error handler is not called, as this need not be interpreted as an error.
-
inline int set_delta(double d)¶
Set the value of
.If this is not called before min_bkt() is used, then the suggested value
is used.
-
inline virtual const char *type()¶
Return string denoting type (“min_cern”)
Public Members
-
int min_type¶
Type of minimum found.
Protected Functions
-
inline int nint(double x)¶
C analog of Fortran’s “Nearest integer” function.
-
inline min_cern()¶