GNU Octave  4.2.1
A high-level interpreted language, primarily intended for numerical computations, mostly compatible with Matlab
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
base-min.h
Go to the documentation of this file.
1 /*
2 
3 Copyright (C) 1995-2017 John W. Eaton
4 
5 This file is part of Octave.
6 
7 Octave is free software; you can redistribute it and/or modify it
8 under the terms of the GNU General Public License as published by the
9 Free Software Foundation; either version 3 of the License, or (at your
10 option) any later version.
11 
12 Octave is distributed in the hope that it will be useful, but WITHOUT
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
15 for more details.
16 
17 You should have received a copy of the GNU General Public License
18 along with Octave; see the file COPYING. If not, see
19 <http://www.gnu.org/licenses/>.
20 
21 */
22 
23 #if ! defined (octave_base_min_h)
24 #define octave_base_min_h 1
25 
26 #include "octave-config.h"
27 
28 #include "dColVector.h"
29 
30 class
32 {
33 public:
34 
35  base_minimizer (void) : x () { }
36 
37  base_minimizer (const ColumnVector& xx) : x (xx) { }
38 
39  base_minimizer (const base_minimizer& a) : x (a.x) { }
40 
41  virtual ~base_minimizer (void) { }
42 
43  base_minimizer& operator = (const base_minimizer& a)
44  {
45  if (this != &a)
46  x = a.x;
47 
48  return *this;
49  }
50 
51  // Derived classes must provide a function to actually do the
52  // minimization.
53 
54  virtual ColumnVector do_minimize (double& objf, octave_idx_type& inform,
55  ColumnVector& lambda) = 0;
56 
57  // Lots of ways to call the single function and optionally set and
58  // get additional information.
59 
60  virtual ColumnVector minimize (void)
61  {
62  double objf;
63  octave_idx_type inform;
64  ColumnVector lambda;
65  return do_minimize (objf, inform, lambda);
66  }
67 
68  virtual ColumnVector minimize (double& objf)
69  {
70  octave_idx_type inform;
71  ColumnVector lambda;
72  return do_minimize (objf, inform, lambda);
73  }
74 
75  virtual ColumnVector minimize (double& objf, octave_idx_type& inform)
76  {
77  ColumnVector lambda;
78  return do_minimize (objf, inform, lambda);
79  }
80 
81  virtual ColumnVector minimize (double& objf, octave_idx_type& inform,
82  ColumnVector& lambda)
83  {
84  return do_minimize (objf, inform, lambda);
85  }
86 
87  virtual ColumnVector minimize (const ColumnVector& x0)
88  {
89  x = x0;
90  double objf;
91  octave_idx_type inform;
92  ColumnVector lambda;
93  return do_minimize (objf, inform, lambda);
94  }
95 
96  virtual ColumnVector minimize (const ColumnVector& x0, double& objf)
97  {
98  x = x0;
99  octave_idx_type inform;
100  ColumnVector lambda;
101  return do_minimize (objf, inform, lambda);
102  }
103 
104  virtual ColumnVector minimize (const ColumnVector& x0, double& objf,
105  octave_idx_type& inform)
106  {
107  x = x0;
108  ColumnVector lambda;
109  return do_minimize (objf, inform, lambda);
110  }
111 
112  virtual ColumnVector minimize (const ColumnVector& x0, double& objf,
113  octave_idx_type& inform, ColumnVector& lambda)
114  {
115  x = x0;
116  return do_minimize (objf, inform, lambda);
117  }
118 
119  octave_idx_type size (void) const { return x.numel (); }
120 
121 protected:
122 
124 };
125 
126 #endif
base_minimizer(void)
Definition: base-min.h:35
virtual ColumnVector minimize(double &objf, octave_idx_type &inform, ColumnVector &lambda)
Definition: base-min.h:81
base_minimizer(const ColumnVector &xx)
Definition: base-min.h:37
ColumnVector x
Definition: base-min.h:123
octave_idx_type size(void) const
Definition: base-min.h:119
virtual ColumnVector minimize(double &objf, octave_idx_type &inform)
Definition: base-min.h:75
virtual ColumnVector minimize(const ColumnVector &x0, double &objf, octave_idx_type &inform)
Definition: base-min.h:104
virtual ColumnVector minimize(const ColumnVector &x0, double &objf, octave_idx_type &inform, ColumnVector &lambda)
Definition: base-min.h:112
calling an anonymous function involves an overhead quite comparable to the overhead of an m file function Passing a handle to a built in function is because the interpreter is not involved in the internal loop For a
Definition: cellfun.cc:398
virtual ~base_minimizer(void)
Definition: base-min.h:41
base_minimizer(const base_minimizer &a)
Definition: base-min.h:39
virtual ColumnVector minimize(void)
Definition: base-min.h:60
virtual ColumnVector minimize(const ColumnVector &x0, double &objf)
Definition: base-min.h:96
virtual ColumnVector minimize(const ColumnVector &x0)
Definition: base-min.h:87
virtual ColumnVector minimize(double &objf)
Definition: base-min.h:68
F77_RET_T F77_REAL &F77_RET_T F77_DBLE &F77_RET_T F77_REAL &F77_RET_T F77_DBLE &F77_RET_T F77_REAL &F77_RET_T F77_DBLE &F77_RET_T const F77_REAL const F77_REAL F77_REAL &F77_RET_T const F77_DBLE const F77_DBLE F77_DBLE &F77_RET_T F77_REAL &F77_RET_T F77_DBLE &F77_RET_T F77_DBLE &F77_RET_T F77_REAL &F77_RET_T F77_REAL &F77_RET_T F77_DBLE &F77_RET_T const F77_DBLE F77_DBLE &F77_RET_T const F77_REAL F77_REAL &F77_RET_T F77_REAL F77_REAL &F77_RET_T F77_DBLE F77_DBLE &F77_RET_T const F77_DBLE * x