BornAgain
1.19.79
Open-source research software to simulate and fit neutron and x-ray reflectometry and grazing-incidence small-angle scattering
|
Wrapper for the CERN ROOT facade of the GSL multi minimizer family (gradient descent based).
Definition at line 32 of file GSLMultiMinimizer.h.
Public Types | |
using | root_minimizer_t = ROOT::Math::Minimizer |
Public Member Functions | |
GSLMultiMinimizer (const std::string &algorithmName="ConjugateFR") | |
~GSLMultiMinimizer () override | |
std::string | algorithmName () const override |
Returns name of the minimization algorithm. More... | |
virtual void | clear () |
Clears resources (parameters) for consecutives minimizations. More... | |
int | maxIterations () const |
mumufit::MinimizerResult | minimize_residual (fcn_residual_t fcn, mumufit::Parameters parameters) override |
Runs minimization. More... | |
mumufit::MinimizerResult | minimize_scalar (fcn_scalar_t fcn, mumufit::Parameters parameters) override |
Runs minimization. More... | |
std::string | minimizerName () const override |
Returns name of the minimizer. More... | |
double | minValue () const override |
Returns minimum function value. More... | |
MinimizerOptions & | options () |
const MinimizerOptions & | options () const |
int | printLevel () const |
bool | providesError () const |
Returns true if minimizer provides error and error matrix. More... | |
virtual bool | requiresResiduals () |
Returns true if minimizer computations are residual-based, false otherwise. More... | |
void | setMaxIterations (int value) |
Sets maximum number of iterations. This is an internal minimizer setting which has no direct relation to the number of objective function calls (e.g. numberOfIteraction=5 might correspond to ~100 objective function calls). More... | |
void | setOptions (const std::string &optionString) override |
Sets option string to the minimizer. More... | |
void | setParameters (const mumufit::Parameters ¶meters) |
void | setPrintLevel (int value) |
Sets minimizer internal print level. More... | |
virtual std::map< std::string, std::string > | statusMap () const |
Returns map of string representing different minimizer statuses. More... | |
std::string | statusToString () const override |
Returns string representation of current minimizer status. More... | |
Protected Member Functions | |
template<class T > | |
OptionContainer::option_t | addOption (const std::string &optionName, T value, const std::string &description="") |
size_t | fitRank () const |
Returns number of fit parameters defined (i.e. dimension of the function to be minimized). More... | |
mumufit::MinimizerResult | minimize (mumufit::Parameters parameters) |
template<class T > | |
T | optionValue (const std::string &optionName) const |
std::vector< double > | parErrorsAtMinimum () const |
Returns errors of the variables at minimum. More... | |
std::vector< double > | parValuesAtMinimum () const |
Returns value of the variables at minimum. More... | |
void | propagateOptions () override |
void | propagateResults (mumufit::Parameters ¶meters) |
Propagates results of minimization to fit parameter set. More... | |
root_minimizer_t * | rootMinimizer () |
const root_minimizer_t * | rootMinimizer () const override |
template<class T > | |
void | setOptionValue (const std::string &optionName, T value) |
virtual void | setParameter (unsigned int index, const mumufit::Parameter &par) |
Private Attributes | |
std::unique_ptr< mumufit::ObjectiveFunctionAdapter > | m_adapter |
std::unique_ptr< ROOT::Math::GSLMinimizer > | m_gsl_minimizer |
MinimizerInfo | m_minimizerInfo |
MinimizerOptions | m_options |
bool | m_status |
|
inherited |
Definition at line 47 of file MinimizerAdapter.h.
|
explicit |
Definition at line 31 of file GSLMultiMinimizer.cpp.
References MinimizerAdapter::addOption().
|
overridedefault |
|
protectedinherited |
Definition at line 115 of file MinimizerAdapter.h.
References OptionContainer::addOption(), and MinimizerAdapter::m_options.
Referenced by GeneticMinimizer::GeneticMinimizer(), GSLLevenbergMarquardtMinimizer::GSLLevenbergMarquardtMinimizer(), GSLMultiMinimizer(), Minuit2Minimizer::Minuit2Minimizer(), and SimAnMinimizer::SimAnMinimizer().
|
overridevirtualinherited |
Returns name of the minimization algorithm.
Implements IMinimizer.
Definition at line 73 of file MinimizerAdapter.cpp.
References MinimizerInfo::algorithmName(), and MinimizerAdapter::m_minimizerInfo.
Referenced by Minuit2Minimizer::requiresResiduals().
|
inlinevirtualinherited |
Clears resources (parameters) for consecutives minimizations.
Definition at line 50 of file IMinimizer.h.
|
protectedinherited |
Returns number of fit parameters defined (i.e. dimension of the function to be minimized).
Definition at line 180 of file MinimizerAdapter.cpp.
References ROOT::Math::Minimizer::NDim(), and MinimizerAdapter::rootMinimizer().
Referenced by MinimizerAdapter::parErrorsAtMinimum(), MinimizerAdapter::parValuesAtMinimum(), and MinimizerAdapter::propagateResults().
int GSLMultiMinimizer::maxIterations | ( | ) | const |
Definition at line 56 of file GSLMultiMinimizer.cpp.
Referenced by propagateOptions().
|
protectedinherited |
Definition at line 50 of file MinimizerAdapter.cpp.
References MinimizerAdapter::m_adapter, MinimizerAdapter::m_status, ROOT::Math::Minimizer::Minimize(), MinimizerAdapter::minValue(), MinimizerAdapter::propagateOptions(), MinimizerAdapter::propagateResults(), mumufit::internal::reportToString(), MinimizerAdapter::rootMinimizer(), mumufit::MinimizerResult::setMinValue(), mumufit::MinimizerResult::setNumberOfCalls(), mumufit::MinimizerResult::setNumberOfGradientCalls(), MinimizerAdapter::setParameters(), mumufit::MinimizerResult::setParameters(), and mumufit::MinimizerResult::setReport().
Referenced by MinimizerAdapter::minimize_residual(), and MinimizerAdapter::minimize_scalar().
|
overridevirtualinherited |
Runs minimization.
Reimplemented from IMinimizer.
Definition at line 43 of file MinimizerAdapter.cpp.
References MinimizerAdapter::m_adapter, MinimizerAdapter::minimize(), MinimizerAdapter::rootMinimizer(), and ROOT::Math::Minimizer::SetFunction().
|
overridevirtualinherited |
Runs minimization.
Reimplemented from IMinimizer.
Definition at line 36 of file MinimizerAdapter.cpp.
References MinimizerAdapter::m_adapter, MinimizerAdapter::minimize(), MinimizerAdapter::rootMinimizer(), and ROOT::Math::Minimizer::SetFunction().
|
overridevirtualinherited |
Returns name of the minimizer.
Implements IMinimizer.
Definition at line 68 of file MinimizerAdapter.cpp.
References MinimizerAdapter::m_minimizerInfo, and MinimizerInfo::name().
|
overridevirtualinherited |
Returns minimum function value.
Reimplemented from IMinimizer.
Definition at line 85 of file MinimizerAdapter.cpp.
References ROOT::Math::Minimizer::MinValue(), and MinimizerAdapter::rootMinimizer().
Referenced by MinimizerAdapter::minimize(), and MinimizerAdapter::statusMap().
|
inlineinherited |
Definition at line 66 of file MinimizerAdapter.h.
References MinimizerAdapter::m_options.
Referenced by MinimizerAdapter::setOptions().
|
inlineinherited |
|
protectedinherited |
Definition at line 128 of file MinimizerAdapter.h.
References MinimizerAdapter::m_options, and OptionContainer::optionValue().
|
protectedinherited |
Returns errors of the variables at minimum.
Definition at line 197 of file MinimizerAdapter.cpp.
References MinimizerAdapter::fitRank(), and MinimizerAdapter::rootMinimizer().
Referenced by MinimizerAdapter::propagateResults().
|
protectedinherited |
Returns value of the variables at minimum.
Definition at line 187 of file MinimizerAdapter.cpp.
References MinimizerAdapter::fitRank(), and MinimizerAdapter::rootMinimizer().
Referenced by MinimizerAdapter::propagateResults().
int GSLMultiMinimizer::printLevel | ( | ) | const |
Definition at line 46 of file GSLMultiMinimizer.cpp.
Referenced by propagateOptions().
|
overrideprotectedvirtual |
Implements MinimizerAdapter.
Definition at line 66 of file GSLMultiMinimizer.cpp.
References m_gsl_minimizer, maxIterations(), and printLevel().
|
protectedinherited |
Propagates results of minimization to fit parameter set.
Definition at line 122 of file MinimizerAdapter.cpp.
References ROOT::Math::Minimizer::Correlation(), MinimizerAdapter::fitRank(), MinimizerAdapter::parErrorsAtMinimum(), MinimizerAdapter::parValuesAtMinimum(), MinimizerAdapter::providesError(), MinimizerAdapter::rootMinimizer(), mumufit::Parameters::setCorrelationMatrix(), mumufit::Parameters::setErrors(), and mumufit::Parameters::setValues().
Referenced by MinimizerAdapter::minimize().
|
inherited |
Returns true if minimizer provides error and error matrix.
Definition at line 95 of file MinimizerAdapter.cpp.
References ROOT::Math::Minimizer::ProvidesError(), and MinimizerAdapter::rootMinimizer().
Referenced by MinimizerAdapter::propagateResults(), and MinimizerAdapter::statusMap().
|
inlinevirtualinherited |
Returns true if minimizer computations are residual-based, false otherwise.
Reimplemented in Minuit2Minimizer, and GSLLevenbergMarquardtMinimizer.
Definition at line 60 of file IMinimizer.h.
|
protectedinherited |
Definition at line 207 of file MinimizerAdapter.cpp.
References MinimizerAdapter::rootMinimizer().
|
overrideprotectedvirtual |
Implements MinimizerAdapter.
Definition at line 72 of file GSLMultiMinimizer.cpp.
References m_gsl_minimizer.
Referenced by statusToString().
void GSLMultiMinimizer::setMaxIterations | ( | int | value | ) |
Sets maximum number of iterations. This is an internal minimizer setting which has no direct relation to the number of objective function calls (e.g. numberOfIteraction=5 might correspond to ~100 objective function calls).
Definition at line 51 of file GSLMultiMinimizer.cpp.
References MinimizerAdapter::setOptionValue().
|
overridevirtualinherited |
Sets option string to the minimizer.
Reimplemented from IMinimizer.
Definition at line 115 of file MinimizerAdapter.cpp.
References MinimizerAdapter::options(), and MinimizerOptions::setOptionString().
|
protectedinherited |
Definition at line 122 of file MinimizerAdapter.h.
References MinimizerAdapter::m_options, and OptionContainer::setOptionValue().
Referenced by SimAnMinimizer::setBoltzmannInitialTemp(), SimAnMinimizer::setBoltzmannK(), SimAnMinimizer::setBoltzmannMinTemp(), SimAnMinimizer::setBoltzmannMu(), Minuit2Minimizer::setErrorDefinition(), SimAnMinimizer::setIterationsAtEachTemp(), Minuit2Minimizer::setMaxFunctionCalls(), GeneticMinimizer::setMaxIterations(), GSLLevenbergMarquardtMinimizer::setMaxIterations(), setMaxIterations(), SimAnMinimizer::setMaxIterations(), GeneticMinimizer::setPopulationSize(), Minuit2Minimizer::setPrecision(), GeneticMinimizer::setPrintLevel(), GSLLevenbergMarquardtMinimizer::setPrintLevel(), setPrintLevel(), Minuit2Minimizer::setPrintLevel(), SimAnMinimizer::setPrintLevel(), GeneticMinimizer::setRandomSeed(), SimAnMinimizer::setStepSize(), Minuit2Minimizer::setStrategy(), GeneticMinimizer::setTolerance(), GSLLevenbergMarquardtMinimizer::setTolerance(), and Minuit2Minimizer::setTolerance().
|
protectedvirtualinherited |
Reimplemented in GSLLevenbergMarquardtMinimizer, and GeneticMinimizer.
Definition at line 141 of file MinimizerAdapter.cpp.
References AttLimits::isFixed(), AttLimits::isLimited(), AttLimits::isLimitless(), AttLimits::isLowerLimited(), AttLimits::isUpperLimited(), mumufit::Parameter::limits(), AttLimits::lowerLimit(), mumufit::Parameter::name(), MinimizerAdapter::rootMinimizer(), ROOT::Math::Minimizer::SetFixedVariable(), ROOT::Math::Minimizer::SetLimitedVariable(), ROOT::Math::Minimizer::SetLowerLimitedVariable(), ROOT::Math::Minimizer::SetUpperLimitedVariable(), ROOT::Math::Minimizer::SetVariable(), mumufit::Parameter::step(), AttLimits::upperLimit(), and mumufit::Parameter::value().
Referenced by GeneticMinimizer::setParameter(), GSLLevenbergMarquardtMinimizer::setParameter(), and MinimizerAdapter::setParameters().
|
inherited |
Definition at line 78 of file MinimizerAdapter.cpp.
References MinimizerAdapter::setParameter().
Referenced by MinimizerAdapter::minimize().
void GSLMultiMinimizer::setPrintLevel | ( | int | value | ) |
Sets minimizer internal print level.
Definition at line 41 of file GSLMultiMinimizer.cpp.
References MinimizerAdapter::setOptionValue().
|
virtualinherited |
Returns map of string representing different minimizer statuses.
Reimplemented in SimAnMinimizer, Minuit2Minimizer, GSLLevenbergMarquardtMinimizer, and GeneticMinimizer.
Definition at line 100 of file MinimizerAdapter.cpp.
References MinimizerAdapter::minValue(), MinimizerAdapter::providesError(), mumufit::stringUtils::scientific(), and MinimizerAdapter::statusToString().
Referenced by GeneticMinimizer::statusMap(), GSLLevenbergMarquardtMinimizer::statusMap(), Minuit2Minimizer::statusMap(), and SimAnMinimizer::statusMap().
|
overridevirtual |
Returns string representation of current minimizer status.
Reimplemented from MinimizerAdapter.
Definition at line 61 of file GSLMultiMinimizer.cpp.
References mumufit::utils::gslErrorDescription(), and rootMinimizer().
|
privateinherited |
Definition at line 110 of file MinimizerAdapter.h.
Referenced by MinimizerAdapter::minimize(), MinimizerAdapter::minimize_residual(), and MinimizerAdapter::minimize_scalar().
|
private |
Definition at line 54 of file GSLMultiMinimizer.h.
Referenced by propagateOptions(), and rootMinimizer().
|
privateinherited |
Definition at line 109 of file MinimizerAdapter.h.
Referenced by MinimizerAdapter::algorithmName(), and MinimizerAdapter::minimizerName().
|
privateinherited |
Definition at line 108 of file MinimizerAdapter.h.
Referenced by MinimizerAdapter::addOption(), MinimizerAdapter::options(), MinimizerAdapter::optionValue(), and MinimizerAdapter::setOptionValue().
|
privateinherited |
Definition at line 111 of file MinimizerAdapter.h.
Referenced by MinimizerAdapter::minimize(), and MinimizerAdapter::statusToString().