31 for (
unsigned int i = 0; i < par.
Vec().
size(); i++) {
34 v(i) = dd * grad[ext];
37 MnPrint print(
"AnalyticalGradientCalculator");
38 print.
Debug(
"User given gradient in Minuit2",
v);
46 if (!this->
G2(par, g2)) {
47 print.
Error(
"Error computing G2");
73 assert(hmat.
size() ==
n *(
n+1)/2);
76 if (extHessian.empty()) {
77 MnPrint print(
"AnalyticalGradientCalculator::Hessian");
78 print.
Info(
"FCN cannot compute Hessian matrix");
81 unsigned int next = sqrt(extHessian.size());
83 for (
unsigned int i = 0; i <
n; i++) {
86 for (
unsigned int j = i; j <
n; j++) {
89 hmat(i, j) = dxdi * extHessian[iext*next+ jext] * dxdj;
98 const unsigned int n = par.
Vec().
size();
99 assert(g2.
size() ==
n);
101 MnPrint print(
"AnalyticalGradientCalculator::G2");
107 print.
Info(
"FCN cannot compute the 2nd derivatives vector (G2)");
111 for (
unsigned int i = 0; i <
n; i++) {
114 g2(i) = dxdi * dxdi * extG2[iext];
121 print.
Info(
"FCN cannot compute the 2nd derivatives vector (G2) or the Hessian");
126 if (extHessian.empty()) {
127 print.
Info(
"FCN cannot compute Hessian matrix (needed to derive G2)");
132 const unsigned int nExt =
static_cast<unsigned int>(std::lround(std::sqrt(
static_cast<double>(extHessian.size()))));
133 if (nExt * nExt != extHessian.size()) {
134 print.
Error(
"Unexpected Hessian size; cannot derive G2 from Hessian diagonal");
140 for (
unsigned int i = 0; i <
n; i++) {
142 const double diag = extHessian[iext * nExt + iext];
144 g2(i) = dxdi * dxdi * diag;
size_t size(const MatrixT &matrix)
retrieve the size of a square matrix
virtual bool CanComputeG2() const
bool G2(const MinimumParameters &, MnAlgebraicVector &) const override
compute second derivatives (diagonal of Hessian)
virtual bool CanComputeHessian() const
const MnUserTransformation & fTransformation
const FCNBase & fGradFunc
FunctionGradient operator()(const MinimumParameters &) const override
bool Hessian(const MinimumParameters &, MnAlgebraicSymMatrix &) const override
compute Hessian matrix
unsigned int size() const
unsigned int size() const
const MnAlgebraicVector & Vec() const
void Debug(const Ts &... args)
void Error(const Ts &... args)
void Info(const Ts &... args)
LAVector MnAlgebraicVector
LASymMatrix MnAlgebraicSymMatrix