17#if defined(DEBUG) || defined(WARNINGMSG)
28class GradientCalculator;
36 std::cout <<
"Running Simplex with maxfcn = " << maxfcn <<
" minedm = " << minedm << std::endl;
43 unsigned int n =
x.size();
44 double wg = 1./double(
n);
45 double alpha = 1.,
beta = 0.5,
gamma = 2., rhomin = 4., rhomax = 8.;
46 double rho1 = 1. + alpha;
49 double rho2 = 1. + alpha*
gamma;
52 std::vector<std::pair<double, MnAlgebraicVector> > simpl; simpl.reserve(
n+1);
53 simpl.push_back(std::pair<double, MnAlgebraicVector>(seed.
Fval(),
x));
55 unsigned int jl = 0, jh = 0;
56 double amin = seed.
Fval(), aming = seed.
Fval();
58 for(
unsigned int i = 0; i <
n; i++) {
60 if(step(i) < dmin) step(i) = dmin;
71 simpl.push_back(std::pair<double, MnAlgebraicVector>(tmp,
x));
77 std::cout <<
"simplex initial parameters - min " << jl <<
" " << amin <<
" max " << jh <<
" " << aming << std::endl;
78 for (
unsigned int i = 0; i < simplex.
Simplex().size(); ++i)
79 std::cout <<
" i = " << i <<
" x = " << simplex(i).second <<
" fval(x) = " << simplex(i).first << std::endl;
82 double edmPrev = simplex.
Edm();
87 amin = simplex(jl).first;
88 edmPrev = simplex.
Edm();
91 std::cout <<
"\n\nsimplex iteration: edm = " << simplex.
Edm()
92 <<
"\n--> Min Param is " << jl <<
" pmin " << simplex(jl).second <<
" f(pmin) " << amin
93 <<
"\n--> Max param is " << jh <<
" " << simplex(jh).first << std::endl;
107 for(
unsigned int i = 0; i <
n+1; i++) {
108 if(i == jh)
continue;
109 pbar += (wg*simplex(i).second);
113 double ystar = mfcn(pstar);
116 std::cout <<
" pbar = " << pbar << std::endl;
117 std::cout <<
" pstar = " << pstar <<
" f(pstar) = " << ystar << std::endl;
121 if(ystar < simplex(jh).
first) {
122 simplex.
Update(ystar, pstar);
123 if(jh != simplex.
Jh())
continue;
126 double ystst = mfcn(pstst);
128 std::cout <<
"Reduced simplex pstst = " << pstst <<
" f(pstst) = " << ystst << std::endl;
130 if(ystst > simplex(jh).
first)
break;
131 simplex.
Update(ystst, pstst);
136 double ystst = mfcn(pstst);
138 std::cout <<
" pstst = " << pstst <<
" f(pstst) = " << ystst << std::endl;
141 double y1 = (ystar - simplex(jh).first)*rho2;
142 double y2 = (ystst - simplex(jh).first)*rho1;
143 double rho = 0.5*(rho2*y1 - rho1*y2)/(y1 - y2);
145 if(ystst < simplex(jl).first) simplex.
Update(ystst, pstst);
146 else simplex.
Update(ystar, pstar);
149 if(rho > rhomax) rho = rhomax;
151 double yrho = mfcn(prho);
153 std::cout <<
" prho = " << prho <<
" f(prho) = " << yrho << std::endl;
155 if(yrho < simplex(jl).
first && yrho < ystst) {
156 simplex.
Update(yrho, prho);
159 if(ystst < simplex(jl).
first) {
160 simplex.
Update(ystst, pstst);
163 if(yrho > simplex(jl).
first) {
164 if(ystst < simplex(jl).
first) simplex.
Update(ystst, pstst);
165 else simplex.
Update(ystar, pstar);
168 if(ystar > simplex(jh).
first) {
169 pstst =
beta*simplex(jh).second + (1. -
beta)*pbar;
171 if(ystst > simplex(jh).
first)
break;
172 simplex.
Update(ystst, pstst);
175 std::cout <<
"End loop : edm = " << simplex.
Edm() <<
" pstst = " << pstst <<
" f(pstst) = " << ystst << std::endl;
177 }
while( (simplex.
Edm() > minedm || edmPrev > minedm ) && mfcn.
NumOfCalls() < maxfcn);
181 amin = simplex(jl).first;
184 for(
unsigned int i = 0; i <
n+1; i++) {
185 if(i == jh)
continue;
186 pbar += (wg*simplex(i).second);
188 double ybar = mfcn(pbar);
189 if(ybar < amin) simplex.
Update(ybar, pbar);
191 pbar = simplex(jl).second;
192 ybar = simplex(jl).first;
200 std::cout <<
"End simplex " << simplex.
Edm() <<
" pbar = " << pbar <<
" f(p) = " << ybar << std::endl;
212 MN_INFO_MSG(
"Simplex did not converge, #fcn calls exhausted.");
216 if(simplex.
Edm() > minedm) {
218 MN_INFO_MSG(
"Simplex did not converge, edm > minedm.");
const MnAlgebraicVector & Gstep() const
class holding the full result of the minimization; both internal and external (MnUserParameterState) ...
interface class for gradient calculators
void TraceIteration(int iter, const MinimumState &state) const
const MnAlgebraicVector & Vec() const
MinimumSeed contains the starting values for the minimization produced by the SeedGenerator.
const FunctionGradient & Gradient() const
const MinimumParameters & Parameters() const
const MnMachinePrecision & Precision() const
MinimumState keeps the information (position, Gradient, 2nd deriv, etc) after one minimization step (...
Wrapper class to FCNBase interface used internally by Minuit.
unsigned int NumOfCalls() const
determines the relative floating point arithmetic precision.
double Eps2() const
eps2 returns 2*sqrt(eps)
static void PrintState(std::ostream &os, const MinimumState &state, const char *msg, int iter=-1)
API class for defining three levels of strategies: low (0), medium (1), high (>=2); acts on: Migrad (...
virtual FunctionMinimum Minimum(const MnFcn &, const GradientCalculator &, const MinimumSeed &, const MnStrategy &, unsigned int, double) const
class describing the simplex set of points (f(x), x ) which evolve during the minimization iteration ...
MnAlgebraicVector Dirin() const
void Update(double, const MnAlgebraicVector &)
const std::vector< std::pair< double, MnAlgebraicVector > > & Simplex() const
double beta(double x, double y)
Calculates the beta function.
VecExpr< UnaryOp< Fabs< T >, VecExpr< A, T, D >, T >, T, D > fabs(const VecExpr< A, T, D > &rhs)
Namespace for new ROOT classes and functions.
static constexpr double second