Azzera filtri
Azzera filtri

How to return to the main function from function file by using return

1 visualizzazione (ultimi 30 giorni)
I'm using simulated annealing to do minimization for my model.
The following is my main function.
lb=[0.01 0.01 0.01]; ub=[0.9 3.0 0.9]; z=[0.3 2 0.4];
for i=1:100
h=@test;
est=simulannealbnd(h,z,lb,ub,options);
end
for the h function file as shown,
i have one condition to consider to estimate z
let's say the condition=exp(z(2)+(1-z(1)))-(1/z(3));
if the condition is fulfill
then run
sumQ=0;
for i=2:length(Y)
Q=model likelihood
sumQ=sumQ+Q;
end
Qfun=sumQ;
else
return;
end
Otherwise, have to go back to the main function to load simulannealbnd to obtain the new set of z from lb and ub.
The question is: When i use return to go back to main function, the error showing Qfun is not assigned any value?
Anyone can help with return command to go back to the main function and run again?

Risposte (2)

the cyclist
the cyclist il 20 Ago 2013
You could put the line
Qfun = [];
before your return statement.
  5 Commenti
Khoo
Khoo il 21 Ago 2013
This is my main function
warning('off') options=optimset('Display','off');
format long; z=[0.3 2 0.6];
samplesize=100; iterate=15; sumest=0; sumSE=0;
lb=[0.01 0.01 0.01]; ub=[0.9 10.0 0.9];
for iter=1:iterate
h=@clstest; est=simulannealbnd(h,z,lb,ub,options);%
sumest=sumest+est; SE=(est-z).^2; sumSE=sumSE+SE;
fprintf('%1.0i\n',iter);
end
MSE=sumSE/iterate; SD=sqrt(MSE/samplesize) %sample standard deviation zEstimate=sumest/iterate % sample mean
and this is my function file
function Qfun=clstest(z)
Y=invtransgen; cond=exp(z(2)*(1-z(1)))-(1/z(3));
if cond<0 sumQ=0; for i=2:length(Y)
Q=(Y(i)-z(3)*z(1)-(1-z(3)*z(1))*z(2))^2; %model likelihood
sumQ=sumQ+Q;
end
Qfun=sumQ;
else
Qfun=[];
return
end
and it turns out the error message:
Error using samakedata (line 30) Your objective function must return a scalar value.
Error in simulannealcommon (line 111) solverData = samakedata(solverData,problem,options);
Error in simulanneal (line 44) [x,fval,exitflag,output,solverData,problem,options] = ...
Error in simulannealbnd (line 122) [x, fval, exitflag, output] = simulanneal(FUN, x0, [], [], [], [], lb, ub, options);
Error in Runfile (line 21) est=simulannealbnd(h,z,lb,ub,options);%
Khoo
Khoo il 21 Ago 2013
Okay i assigned some value for Qfun and it can be passed back to the main function. But the simulannealbnd command doesn't really working as it gives me the initial values for the z estimates.

Accedi per commentare.


Walter Roberson
Walter Roberson il 20 Ago 2013
Put
Qfun = sumQ
right before the return
  3 Commenti
Khoo
Khoo il 21 Ago 2013
I don't get it. How to initialize args as the first line in the function?
Qfun=sumQ getting the same error...
Image Analyst
Image Analyst il 21 Ago 2013
Just put that line immediately after the function line, before any of the other lines in the function. Then Qfun is guaranteed to have a value, even if it's null, no matter what else happens in the code (i.e. you encounter an error before you get to assign it with the desired values). So that error about exiting the function without assigning QFun will never happen - though you may get other errors.

Accedi per commentare.

Categorie

Scopri di più su Financial Toolbox in Help Center e File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by