Help with 'fminsearch'

2 views (last 30 days)
Niles Martinsen
Niles Martinsen on 9 May 2012
Hi
I am fitting an exponential to my data using least squares, as in:
************************************************************
t = 0:7 ;
rel = [629 537 460 375 334 286 249 227];
fh = @(x,p) p(1) + p(2)*exp(-x./p(3))
errfh = @(p,x,y) sum((y(:)-fh(x(:),p)).^2)
p0 = [mean(rel) (max(rel)-min(rel)) (max(t) - min(t))/2];
P = fminsearch(errfh,p0,[],t,rel)
plot(t,rel,'bo',t,fh(t,P),'r-')
************************************************************
However, now I wish to increase MaxFunEvals. How can I do this, when I use fminsearch in this fashion?
Best, Niles.
  5 Comments
Oleg Komarov
Oleg Komarov on 9 May 2012
Usually oprimization routines all have a varargin input. Edit fminsearch or fminbnd.
Walter Roberson
Walter Roberson on 9 May 2012
In 2008, Jos sometimes made mistakes.

Sign in to comment.

Answers (2)

Oleg Komarov
Oleg Komarov on 9 May 2012
P = fminsearch(errfh,p0,optimset('MaxFunEvals',1000),t,rel)
Check the documentation for optimset
  2 Comments
Niles Martinsen
Niles Martinsen on 9 May 2012
I tried this out, but it did not have the desired effect unfortunately.
Oleg Komarov
Oleg Komarov on 9 May 2012
What do you mean it did not have the desired effect?
Try to reduce it to 10 or 50. Keep in mind it's a local solver.

Sign in to comment.


Walter Roberson
Walter Roberson on 9 May 2012
You cannot increase MaxFunEvals when you use fminsearch in that fashion, as fminsearch takes a maximum of 3 inputs, not the 5 you are using. The function handle you provide to fminsearch must take exactly one argument. The initial guess follows the function handle, and the options structure (if provided) follows that.
  4 Comments
Niles Martinsen
Niles Martinsen on 9 May 2012
Walter, actually when I think it over I am not sure I understand what you mean.
Walter Roberson
Walter Roberson on 9 May 2012
Guessing about what you are trying to pass to what:
P = fminsearch(@(p) errfh(p,t,rel), p0, optimset('MaxFunEvals',1000));

Sign in to comment.

Community Treasure Hunt

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

Start Hunting!