GSLSimAnFunc class description.
Interface class for the objetive function to be used in simulated annealing If user wants to re-implement some of the methods (like the one defining the metric) which are used by the the simulated annealing algorithm must build a user derived class. NOTE: Derived classes must re-implement the assignment and copy constructor to call them of the parent class
Definition at line 50 of file GSLSimAnnealing.h.
Public Member Functions | |
GSLSimAnFunc (const ROOT::Math::IMultiGenFunction &func, const double *x) | |
construct from an interface of a multi-dimensional function | |
GSLSimAnFunc (const ROOT::Math::IMultiGenFunction &func, const double *x, const double *scale) | |
construct from an interface of a multi-dimensional function Use optionally a scale factor (for each coordinate) which can be used to scale the step sizes (this is used for example by the minimization algorithm) | |
virtual | ~GSLSimAnFunc () |
virtual destructor (no operations) | |
virtual GSLSimAnFunc * | Clone () const |
clone method. | |
virtual double | Distance (const GSLSimAnFunc &func) const |
calculate the distance (metric) between this one and another configuration Presently a cartesian metric is used. | |
virtual double | Energy () const |
evaluate the energy ( objective function value) re-implement by derived classes if needed to be modified | |
virtual GSLSimAnFunc & | FastCopy (const GSLSimAnFunc &f) |
fast copy method called by GSL simulated annealing internally copy only the things which have been changed must be re-implemented by derived classes if needed | |
unsigned int | NDim () const |
virtual void | Print () |
print the position in the standard output std::ostream GSL prints in addition n iteration, n function calls, temperature and energy re-implement by derived classes if necessary | |
double | Scale (unsigned int i) const |
void | SetX (const double *x) |
change the x values (used by sim annealing to take a step) | |
template<class IT > | |
void | SetX (IT begin, IT end) |
void | SetX (unsigned int i, double x) |
virtual void | Step (const GSLRandomEngine &r, double maxstep) |
change the x[i] value using a random value urndm generated between [0,1] up to a maximum value maxstep re-implement by derived classes if needed to be modified | |
const std::vector< double > & | X () const |
double | X (unsigned int i) const |
Protected Member Functions | |
GSLSimAnFunc () | |
derived classes might need to re-define completely the class | |
Private Attributes | |
const ROOT::Math::IMultiGenFunction * | fFunc |
std::vector< double > | fScale |
std::vector< double > | fX |
#include <Math/GSLSimAnnealing.h>
ROOT::Math::GSLSimAnFunc::GSLSimAnFunc | ( | const ROOT::Math::IMultiGenFunction & | func, |
const double * | x | ||
) |
construct from an interface of a multi-dimensional function
Definition at line 34 of file GSLSimAnnealing.cxx.
ROOT::Math::GSLSimAnFunc::GSLSimAnFunc | ( | const ROOT::Math::IMultiGenFunction & | func, |
const double * | x, | ||
const double * | scale | ||
) |
construct from an interface of a multi-dimensional function Use optionally a scale factor (for each coordinate) which can be used to scale the step sizes (this is used for example by the minimization algorithm)
Definition at line 43 of file GSLSimAnnealing.cxx.
|
inlineprotected |
derived classes might need to re-define completely the class
Definition at line 70 of file GSLSimAnnealing.h.
|
inlinevirtual |
virtual destructor (no operations)
Definition at line 78 of file GSLSimAnnealing.h.
|
inlinevirtual |
clone method.
Needs to be re-implemented by the derived classes for deep copying
Definition at line 92 of file GSLSimAnnealing.h.
|
virtual |
calculate the distance (metric) between this one and another configuration Presently a cartesian metric is used.
re-implement by derived classes if needed to be modified
Definition at line 66 of file GSLSimAnnealing.cxx.
|
virtual |
evaluate the energy ( objective function value) re-implement by derived classes if needed to be modified
Definition at line 50 of file GSLSimAnnealing.cxx.
|
virtual |
fast copy method called by GSL simulated annealing internally copy only the things which have been changed must be re-implemented by derived classes if needed
Definition at line 96 of file GSLSimAnnealing.cxx.
|
inline |
Definition at line 135 of file GSLSimAnnealing.h.
|
virtual |
print the position in the standard output std::ostream GSL prints in addition n iteration, n function calls, temperature and energy re-implement by derived classes if necessary
Definition at line 83 of file GSLSimAnnealing.cxx.
Definition at line 141 of file GSLSimAnnealing.h.
|
inline |
change the x values (used by sim annealing to take a step)
Definition at line 126 of file GSLSimAnnealing.h.
|
inline |
Definition at line 131 of file GSLSimAnnealing.h.
Definition at line 143 of file GSLSimAnnealing.h.
|
virtual |
change the x[i] value using a random value urndm generated between [0,1] up to a maximum value maxstep re-implement by derived classes if needed to be modified
Definition at line 55 of file GSLSimAnnealing.cxx.
|
inline |
Definition at line 139 of file GSLSimAnnealing.h.
Definition at line 137 of file GSLSimAnnealing.h.
|
private |
Definition at line 151 of file GSLSimAnnealing.h.
|
private |
Definition at line 150 of file GSLSimAnnealing.h.
|
private |
Definition at line 149 of file GSLSimAnnealing.h.