BornAgain  1.18.0
Simulate and fit neutron and x-ray scattering at grazing incidence
Minuit2Minimizer.cpp
Go to the documentation of this file.
1 // ************************************************************************** //
2 //
3 // BornAgain: simulate and fit scattering at grazing incidence
4 //
5 //! @file Fit/RootAdapter/Minuit2Minimizer.cpp
6 //! @brief Declares class Minuit2Minimizer.
7 //!
8 //! @homepage http://www.bornagainproject.org
9 //! @license GNU General Public License v3 or higher (see COPYING)
10 //! @copyright Forschungszentrum Jülich GmbH 2018
11 //! @authors Scientific Computing Group at MLZ (see CITATION, AUTHORS)
12 //
13 // ************************************************************************** //
14 
16 #include "Fit/Tools/StringUtils.h"
17 #include <Minuit2/Minuit2Minimizer.h>
18 
19 namespace
20 {
21 
22 std::map<int, std::string> statusDescription()
23 {
24  std::map<int, std::string> result;
25  result[0] = "OK, valid minimum";
26  result[1] = "Didn't converge, covariance was made pos defined";
27  result[2] = "Didn't converge, Hessian is invalid";
28  result[3] = "Didn't converge, Edm is above max";
29  result[4] = "Didn't converge, reached call limit";
30  result[5] = "Didn't converge, unknown failure";
31  return result;
32 }
33 
34 std::map<int, std::string> covmatrixStatusDescription()
35 {
36  std::map<int, std::string> result;
37  result[-1] = "Not available (inversion failed or Hessian failed)";
38  result[0] = "Available but not positive defined";
39  result[1] = "Covariance only approximate";
40  result[2] = "Full matrix but forced pos def";
41  result[3] = "Full accurate";
42  return result;
43 }
44 
45 } // namespace
46 
47 Minuit2Minimizer::Minuit2Minimizer(const std::string& algorithmName)
48  : RootMinimizerAdapter(MinimizerInfo::buildMinuit2Info(algorithmName)),
49  m_minuit2_minimizer(new ROOT::Minuit2::Minuit2Minimizer(algorithmName.c_str()))
50 {
51  addOption("Strategy", 1, "Minimization strategy (0-low, 1-medium, 2-high quality)");
52  addOption("ErrorDef", 1.0, "Error definition factor for parameter error calculation");
53  addOption("Tolerance", 0.01, "Tolerance on the function value at the minimum");
54  addOption("Precision", -1.0, "Relative floating point arithmetic precision");
55  addOption("PrintLevel", 0, "Minimizer internal print level");
56  addOption("MaxFunctionCalls", 0, "Maximum number of function calls");
57 }
58 
60 
62 {
63  setOptionValue("Strategy", value);
64 }
65 
67 {
68  return optionValue<int>("Strategy");
69 }
70 
72 {
73  setOptionValue("ErrorDef", value);
74 }
75 
77 {
78  return optionValue<double>("ErrorDef");
79 }
80 
82 {
83  setOptionValue("Tolerance", value);
84 }
85 
87 {
88  return optionValue<double>("Tolerance");
89 }
90 
92 {
93  setOptionValue("Precision", value);
94 }
95 
97 {
98  return optionValue<double>("Precision");
99 }
100 
102 {
103  setOptionValue("PrintLevel", value);
104 }
105 
107 {
108  return optionValue<int>("PrintLevel");
109 }
110 
112 {
113  setOptionValue("MaxFunctionCalls", value);
114 }
115 
117 {
118  return optionValue<int>("MaxFunctionCalls");
119 }
120 
122 {
123  return statusDescription()[rootMinimizer()->Status()];
124 }
125 
126 std::map<std::string, std::string> Minuit2Minimizer::statusMap() const
127 {
128  auto result = RootMinimizerAdapter::statusMap();
129  result["Edm"] = StringUtils::scientific(rootMinimizer()->Edm());
130  result["CovMatrixStatus"] = covmatrixStatusDescription()[rootMinimizer()->CovMatrixStatus()];
131  result["functionCalls"] = std::to_string(rootMinimizer()->NCalls());
132  return result;
133 }
134 
135 // Fumili algorithm can work only with gradient based objective function, while others can
136 // work with both, gradient based and chi2 based functions. Historically however, we use
137 // simplified approach: if not Fumili, then chi2 only. Think of refactoring TODO.
139 {
140  return algorithmName() == "Fumili";
141 }
142 
143 //! Propagate options down to ROOT's Minuit2Minimizer.
144 
146 {
147  m_minuit2_minimizer->SetStrategy(strategy());
148  m_minuit2_minimizer->SetErrorDef(errorDefinition());
149  m_minuit2_minimizer->SetTolerance(tolerance());
150  m_minuit2_minimizer->SetPrecision(precision());
151  m_minuit2_minimizer->SetPrintLevel(printLevel());
152  m_minuit2_minimizer->SetMaxFunctionCalls(static_cast<unsigned int>(maxFunctionCalls()));
153 }
154 
156 {
157  return m_minuit2_minimizer.get();
158 }
Declares class Minuit2Minimizer.
Defines a few helper functions.
Info about a minimizer, including list of defined minimization algorithms.
Definition: MinimizerInfo.h:45
Wrapper for the CERN ROOT facade of the Minuit2 minimizer.
void setPrecision(double value)
Sets relative floating point arithmetic precision.
double tolerance() const
void propagateOptions() override
Propagate options down to ROOT's Minuit2Minimizer.
Minuit2Minimizer(const std::string &algorithmName="Migrad")
void setMaxFunctionCalls(int value)
Sets maximum number of objective function calls.
std::unique_ptr< ROOT::Minuit2::Minuit2Minimizer > m_minuit2_minimizer
void setPrintLevel(int value)
Sets minimizer internal print level.
void setStrategy(int value)
Sets minimization strategy (0-low, 1-medium, 2-high minimization quality).
int maxFunctionCalls() const
double precision() const
const root_minimizer_t * rootMinimizer() const override
std::string statusToString() const override
Returns string representation of current minimizer status.
void setTolerance(double value)
Sets tolerance on the function value at the minimum.
void setErrorDefinition(double value)
Sets error definition factor for parameter error calculation.
std::map< std::string, std::string > statusMap() const override
Returns map of string representing different minimizer statuses.
bool requiresResiduals() override
Returns true if minimizer computations are residual-based, false otherwise.
double errorDefinition() const
Pure virtual interface that adapts the CERN ROOT minimizer to our IMinimizer.
OptionContainer::option_t addOption(const std::string &optionName, T value, const std::string &description="")
void setOptionValue(const std::string &optionName, T value)
ROOT::Math::Minimizer root_minimizer_t
std::string algorithmName() const override final
Returns name of the minimization algorithm.
virtual std::map< std::string, std::string > statusMap() const
Returns map of string representing different minimizer statuses.
std::string scientific(const T value, int n=10)
Returns scientific string representing given value of any numeric type.
Definition: StringUtils.h:54
std::map< int, std::string > covmatrixStatusDescription()
std::map< int, std::string > statusDescription()