Is there any other alternative fuction that I can use instead of fminunc?.
Ältere Kommentare anzeigen
Dear all,
I am using the function fminunc as I want to find the mode and the hessian matrix of a function. I use Matlab 2009 but I get an error related to this function
??? Error using ==> roots at 28
Input to ROOTS must not contain NaN or
Inf. Error in ==>
lineSearch>globalMinimizerOfPolyInInterval
at 304
stationaryPoint = roots([3*coeff(1)
2*coeff(2) coeff(3)]); Error in ==>
lineSearch>pickAlphaWithinInterval at 279
z =
globalMinimizerOfPolyInInterval(zlb,zub,coeff); Error in ==> lineSearch>sectioningPhase at
193
alpha =
pickAlphaWithinInterval(brcktEndpntA,brcktEndpntB,a,b,f_a,fPrime_a,f_b,fPrime_b); Error in ==> lineSearch at 55
[alpha,f_alpha,grad,exitflag,funcCount]
= sectioningPhase(funfcn, ... Error in ==> fminusub at 208
[alpha,f,grad,exitflagLnSrch,funcCountLnSrch]
= ... Error in ==> fminunc at 376
[x,FVAL,GRAD,HESSIAN,EXITFLAG,OUTPUT] =
fminusub(funfcn,x, ... Error in ==> testxa2 at 252
[xxx,fval,exitflag,output,gradient,H]=fminunc('modeA,x00,options,...
Is there any other alternative fuction that I can use instead of fminunc?. The function produces no error in Matlab2012 but only in matlab 2009
thank you
Antworten (3)
Matt Kindig
am 20 Sep. 2012
Hi Salva,
You could use fminsearch or fminbnd, two derivative-free optimizers. However, given that the error is thrown when the input to roots() is invalid, it would probably be better to catch that error before entering roots. You could put a check in your globalMinimizerOfPolyInInterval() function prior to calling roots() that checks that coeff(1:3) are all not NaN or Inf. Something like:
if all(isfinite(coeffs(1:3)),
stationaryPoint = roots([3*coeff(1) 2*coeff(2) coeff(3)]);
else
%do something to force the optimizer to reject this solution
end
Walter Roberson
am 23 Sep. 2012
0 Stimmen
If you use an options structure that turns on function value checking, then the minimization will stop at the point that inf or NaN is produced.
3 Kommentare
salva
am 25 Sep. 2012
Walter Roberson
am 25 Sep. 2012
You appear to already be constructing options, so include 'FunValCheck', 'on' when constructing the options.
salva
am 25 Sep. 2012
Sean de Wolski
am 25 Sep. 2012
fmincon's Interior-Point algorithm can recover from inf and nan output.
doc fmincon
8 Kommentare
salva
am 27 Sep. 2012
Sean de Wolski
am 27 Sep. 2012
What is the class() of the various inputs? Convert them to double before passing to fmincon
fmincon(@fun,double(x0),double(A),double(etc...)
HI Sean,
THe various inputs are already in double format. THe function that I want to maximize is 'CES_mode7cutDCfree1sem'. and the various inputs are ka, fff2,fff3,fff4,fff5,fff6 and vsigt2 all of which are in double format. I am trying to find where the mistake is but I can not
thank you
Sean de Wolski
am 27 Sep. 2012
dbstop if error
Will stop when the error is thrown and you can traverse the stack to see what variables are what where.
salva
am 1 Okt. 2012
Sean de Wolski
am 1 Okt. 2012
You could write a wrapper function to wrap around your objective function that would spit out large values relative to the inputs when a NaN or inf occurs. But this adds a discontinuity which these solvers aren't really designed to be able to handle.
The real question: Why don't you want to use fmincon's IP algorithm? It's super-awesome.
salva
am 1 Okt. 2012
Sean de Wolski
am 1 Okt. 2012
Well since you don't need constraints you can ignore all of those inputs, just put some lower and upper bounds on your variables and use it just like fminunc
fmincon(foo,x0,[],[],[],[],lb,ub,options);
Kategorien
Mehr zu Solver Outputs and Iterative Display finden Sie in Hilfe-Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!