How to calculate the second derivative of an unanalytically function

2 次查看(过去 30 天)
Dear All,
I use fmincon to optimize my likelihood function f (there are four parameters in f . And it is not in an analytic form. It needs to read in data and call other children function, etc). I also want the standard errors so I have tried to get the Hessian (more accurate, the diagonal part of it, which is the second derivative of the f at the optima). But Hessian provided by fmincon is the Hessian of the Lagrangian so I can not use it.
I tried John D'Errico's method . But in this method, it requires f to be scalar and analytic.
So I really have not idea at this moment. I think my problem is essentially about how to calculate the second derivative of an analytic function. Could anybody help me with this please? Thanks very much.
Xueqi
  3 个评论
xueqi
xueqi 2014-12-15
Hi thanks for our advice. But I am not sure exactly I should implement this. How should I decide h?
John D'Errico
John D'Errico 2014-12-15
Why don't the derivest tools (the Hessian computation) work?
All it needs is that your function return a scalar, and that it be sufficiently smooth. If your function does not return a scalar, how do you define the Hessian matrix anyway? And if it is not smooth, how would you compute the derivatives you desire?
There is no need for your function to be in any symbolic form. A black box function is fine.

请先登录,再进行评论。

回答(1 个)

Sean de Wolski
Sean de Wolski 2014-12-11
编辑:Sean de Wolski 2014-12-11
Why not just let fmincon use finite differencing?
If that is not working, then it's possible that your function is discontinuous or non-differentiable and you should look at using one of the non gradient based solvers like patternsearch.
  3 个评论
Sean de Wolski
Sean de Wolski 2014-12-15
No, if you want to use the analytical gradient, which you do not have, then you need to. Otherwise it will solve it with finite differences.

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 Solver Outputs and Iterative Display 的更多信息

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by