Help with fmincon optimization

1 visualización (últimos 30 días)
Shahab
Shahab el 30 de Ag. de 2012
I'm using these lines of code as part of an m-file:
**************************************************************************
options = optimset('Algorithm','sqp','MaxIter',3,'MaxFunEvals',3,'Display','iter');
delta = fmincon(@RI,delta0,A,b,[],[],-35*pi/180,35*pi/180,[],options);
**************************************************************************
Although I've set 'MaxIter' and 'MaxFunEvals' to 3, I get much more iterations of the function 'RI'; actually seems it's never going to end (I deliberately set max iterations such low to see when it stops). Furthermore, it doesn't display results at each iteration.
Can someone please tell me why?
  2 comentarios
Sean de Wolski
Sean de Wolski el 30 de Ag. de 2012
How are you measuring this? The more info (i.e. reproduction steps) you can give us the better.
Shahab
Shahab el 30 de Ag. de 2012
Editada: Shahab el 1 de Sept. de 2012
I don't think it'll be helpful, but in case you need the full code, here it is:
function J = RI(del)
global delta
delta = del;
[~,~,yOut] = sim('OpenLoopWC');
J = 1000/max(yOut);
timestep = .002;
t = 0:timestep:5;
n = size(t); n = n(2);
delta0 = 25*pi/180*sin(2*pi/5*t); % initial guess
global delta
delta = delta0;
A = zeros(n-1,n);
for m = 1:n-1
A(m,m) = 1;
A(m,m+1) = -1;
end
b = 45*pi/180*timestep*ones(n-1,1);
options = optimset('Algorithm','sqp','MaxIter',3,'MaxFunEvals',3,'Display','iter');
delta = fmincon(@RI,delta0,A,b,[],[],-35*pi/180,35*pi/180,[],options);

Iniciar sesión para comentar.

Respuestas (1)

Paul Kerr-Delworth
Paul Kerr-Delworth el 31 de Ag. de 2012
Hi,
With the options you have passed, fmincon should stop once your objective function, RI, has been evaluated more than 3 times.
Given that you see no iterative display in the command window, I wonder whether your simulink model is taking a long time to complete the simulation. To check this out, you could try running
[~,~,yOut] = sim('OpenLoopWC')
at the MATLAB command prompt and see how long it takes to return.
Hope this helps.
Best regards,
Paul
  2 comentarios
Shahab
Shahab el 1 de Sept. de 2012
Hi dear Paul,
The simulation takes around 10 seconds to complete, but the function is evaluated (simulation is run) much more than 3 times, it runs until I have to interrupt it by ctrl+break.
Star Strider
Star Strider el 1 de Sept. de 2012
One way you might be able to track the number of times the function calls RI and how long it's taking is to insert persistent variables. This is kludgy, but sometimes kludgy is the only way to solve problems like this.
I suggest for a start:
function J = RI(del)
persistent RIcount
tic
global delta
delta = del;
[~,~,yOut] = sim('OpenLoopWC');
J = 1000/max(yOut);
RIcount = RIcount+1;
RItimer = toc;
sprintf('\n\tRI iteration %d = %f sec\n', RIcount, RItimer)
You can remove (or comment out) the persistent statement, RIcount, RItimer and the rest when you no longer need them, but in the interim they may give you some information about RI.

Iniciar sesión para comentar.

Categorías

Más información sobre Get Started with Optimization Toolbox en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by